Make sure that ICM20948 is only updated once per loop when needed
This commit is contained in:
@@ -82,14 +82,18 @@ class IMU : public SensorBase<IMUAnglesMsg> {
|
|||||||
_msg.temperature = _imu.getTemperature();
|
_msg.temperature = _imu.getTemperature();
|
||||||
#endif
|
#endif
|
||||||
#if FT_ENABLED(USE_ICM20948)
|
#if FT_ENABLED(USE_ICM20948)
|
||||||
|
|
||||||
|
#ifndef ICM20948_GET_AGMT_UPDATED_ONCE_PER_LOOP
|
||||||
|
#define ICM20948_GET_AGMT_UPDATED_ONCE_PER_LOOP
|
||||||
if (_imu->dataReady())
|
if (_imu->dataReady())
|
||||||
{
|
{
|
||||||
_imu->getAGMT();
|
_imu->getAGMT();
|
||||||
_msg.rpy[0] = _imu->gyrX();
|
|
||||||
_msg.rpy[1] = _imu->gyrY();
|
|
||||||
_msg.rpy[2] = _imu->gyrZ();
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
_msg.rpy[0] = _imu->accX();
|
||||||
|
_msg.rpy[1] = _imu->accY();
|
||||||
|
_msg.rpy[2] = _imu->accZ();
|
||||||
|
#endif
|
||||||
#if FT_ENABLED(USE_BNO055)
|
#if FT_ENABLED(USE_BNO055)
|
||||||
#endif
|
#endif
|
||||||
return true;
|
return true;
|
||||||
|
|||||||
@@ -43,8 +43,13 @@ class Magnetometer : public SensorBase<MagnetometerMsg> {
|
|||||||
bool update() override {
|
bool update() override {
|
||||||
if (!_msg.success) return false;
|
if (!_msg.success) return false;
|
||||||
#if FT_ENABLED(USE_ICM20948)
|
#if FT_ENABLED(USE_ICM20948)
|
||||||
_mag->getAGMT();
|
#ifndef ICM20948_GET_AGMT_UPDATED_ONCE_PER_LOOP
|
||||||
if (_mag->status != ICM_20948_Stat_Ok){ return false; }
|
#define ICM20948_GET_AGMT_UPDATED_ONCE_PER_LOOP
|
||||||
|
if (_imu->dataReady())
|
||||||
|
{
|
||||||
|
_imu->getAGMT();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
_msg.rpy[0] = _mag->magX();
|
_msg.rpy[0] = _mag->magX();
|
||||||
_msg.rpy[1] = _mag->magY();
|
_msg.rpy[1] = _mag->magY();
|
||||||
_msg.rpy[2] = _mag->magZ();
|
_msg.rpy[2] = _mag->magZ();
|
||||||
|
|||||||
Reference in New Issue
Block a user