esp32_BNO08x/source/report/BNO08xRptUncalGyro.cpp

63 lines
1.6 KiB
C++

#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<BNO08xAccuracy>(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;
}