/** * @file BNO08xRptUncalGyro.cpp * @author Myles Parfeniuk */ #include "BNO08xRptUncalGyro.hpp" #include "BNO08x.hpp" /** * @brief Updates uncalibrated gyro data from decoded sensor event. * * @param sensor_val The sh2_SensorValue_t struct used in sh2_decodeSensorEvent() call. * * @return void, nothing to return */ void BNO08xRptUncalGyro::update_data(sh2_SensorValue_t* sensor_val) { imu->lock_user_data(); data = sensor_val->un.gyroscopeUncal; data.accuracy = static_cast(sensor_val->status); bias_data = sensor_val->un.gyroscopeUncal; imu->unlock_user_data(); if (rpt_bit & xEventGroupGetBits(imu->evt_grp_report_en)) signal_data_available(); } /** * @brief Grabs most recent uncalibrated gyroscope data, units are in rad/s. * * @param vel Reference to save velocity data. * @param bias Reference to save bias data. * * @return void, nothing to return */ void BNO08xRptUncalGyro::get(bno08x_gyro_t& vel, bno08x_gyro_bias_t& bias) { imu->lock_user_data(); vel = data; bias = bias_data; imu->unlock_user_data(); } /** * @brief Grabs most recent uncalibrated gyroscope velocity data, units are in rad/s. * * @return Struct containing requested data. */ bno08x_gyro_t BNO08xRptUncalGyro::get_vel() { imu->lock_user_data(); bno08x_gyro_t rqdata = data; imu->unlock_user_data(); return rqdata; } /** * @brief Grabs most recent uncalibrated gyroscope bias data, units are in rad/s. * * @return Struct containing requested data. */ bno08x_gyro_bias_t BNO08xRptUncalGyro::get_bias() { imu->lock_user_data(); bno08x_gyro_bias_t rqdata = bias_data; imu->unlock_user_data(); return rqdata; }