From 9fba96c8d0a68ba8b072eb36b7d2062190e8b756 Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Sun, 17 Apr 2022 17:03:46 +1000 Subject: [PATCH] AP_InertialSensor: fixed the last notch values to be per-instance thanks to Andy for noticing this --- libraries/AP_InertialSensor/AP_InertialSensor.cpp | 14 +++++++------- libraries/AP_InertialSensor/AP_InertialSensor.h | 6 +++--- 2 files changed, 10 insertions(+), 10 deletions(-) diff --git a/libraries/AP_InertialSensor/AP_InertialSensor.cpp b/libraries/AP_InertialSensor/AP_InertialSensor.cpp index 034e1cb1ab..2a41680344 100644 --- a/libraries/AP_InertialSensor/AP_InertialSensor.cpp +++ b/libraries/AP_InertialSensor/AP_InertialSensor.cpp @@ -1593,23 +1593,23 @@ void AP_InertialSensor::_save_gyro_calibration() void AP_InertialSensor::HarmonicNotch::update_params(uint8_t instance, bool converging, float gyro_rate) { const float center_freq = calculated_notch_freq_hz[0]; - if (!is_equal(last_bandwidth_hz, params.bandwidth_hz()) || - !is_equal(last_attenuation_dB, params.attenuation_dB()) || + if (!is_equal(last_bandwidth_hz[instance], params.bandwidth_hz()) || + !is_equal(last_attenuation_dB[instance], params.attenuation_dB()) || converging) { filter[instance].init(gyro_rate, center_freq, params.bandwidth_hz(), params.attenuation_dB()); - last_center_freq_hz = center_freq; - last_bandwidth_hz = params.bandwidth_hz(); - last_attenuation_dB = params.attenuation_dB(); - } else if (!is_equal(last_center_freq_hz, center_freq)) { + last_center_freq_hz[instance] = center_freq; + last_bandwidth_hz[instance] = params.bandwidth_hz(); + last_attenuation_dB[instance] = params.attenuation_dB(); + } else if (!is_equal(last_center_freq_hz[instance], center_freq)) { if (num_calculated_notch_frequencies > 1) { filter[instance].update(num_calculated_notch_frequencies, calculated_notch_freq_hz); } else { filter[instance].update(center_freq); } - last_center_freq_hz = center_freq; + last_center_freq_hz[instance] = center_freq; } } diff --git a/libraries/AP_InertialSensor/AP_InertialSensor.h b/libraries/AP_InertialSensor/AP_InertialSensor.h index eddf939478..5898d49b12 100644 --- a/libraries/AP_InertialSensor/AP_InertialSensor.h +++ b/libraries/AP_InertialSensor/AP_InertialSensor.h @@ -445,9 +445,9 @@ public: private: // support for updating harmonic filter at runtime - float last_center_freq_hz; - float last_bandwidth_hz; - float last_attenuation_dB; + float last_center_freq_hz[INS_MAX_INSTANCES]; + float last_bandwidth_hz[INS_MAX_INSTANCES]; + float last_attenuation_dB[INS_MAX_INSTANCES]; } harmonic_notches[HAL_INS_NUM_HARMONIC_NOTCH_FILTERS]; private: