mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-14 04:38:30 -04:00
AP_InertialSensor: fixed the last notch values to be per-instance
thanks to Andy for noticing this
This commit is contained in:
parent
97d42308a7
commit
9fba96c8d0
@ -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;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -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:
|
||||
|
Loading…
Reference in New Issue
Block a user