59 lines
1.4 KiB
C++
59 lines
1.4 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;
|
||
|
|
bias_data = sensor_val->un.gyroscopeUncal;
|
||
|
|
imu->unlock_user_data();
|
||
|
|
}
|
||
|
|
|
||
|
|
/**
|
||
|
|
* @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;
|
||
|
|
}
|