mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-22 00:28:30 -04:00
AP_Vehicle: implement common harmonic notch update code
This commit is contained in:
parent
15084cb6f3
commit
301c56d30a
@ -7,6 +7,7 @@
|
||||
#include <AP_Logger/AP_Logger.h>
|
||||
#include <AP_Mission/AP_Mission.h>
|
||||
#include <AP_OSD/AP_OSD.h>
|
||||
#include <AP_RPM/AP_RPM.h>
|
||||
#include <SRV_Channel/SRV_Channel.h>
|
||||
#if CONFIG_HAL_BOARD == HAL_BOARD_CHIBIOS
|
||||
#include <AP_HAL_ChibiOS/sdcard.h>
|
||||
@ -395,19 +396,98 @@ bool AP_Vehicle::is_crashed() const
|
||||
return AP::arming().last_disarm_method() == AP_Arming::Method::CRASH;
|
||||
}
|
||||
|
||||
// update the harmonic notch filter center frequency dynamically
|
||||
void AP_Vehicle::update_dynamic_notch(AP_InertialSensor::HarmonicNotch ¬ch)
|
||||
{
|
||||
#if APM_BUILD_TYPE(APM_BUILD_ArduPlane)||APM_BUILD_COPTER_OR_HELI
|
||||
if (!notch.params.enabled()) {
|
||||
return;
|
||||
}
|
||||
const float ref_freq = notch.params.center_freq_hz();
|
||||
const float ref = notch.params.reference();
|
||||
if (is_zero(ref)) {
|
||||
notch.update_freq_hz(ref_freq);
|
||||
return;
|
||||
}
|
||||
|
||||
const AP_Motors* motors = AP::motors();
|
||||
const float motors_throttle = motors != nullptr ? MAX(0,motors->get_throttle_out()) : 0;
|
||||
const float throttle_freq = ref_freq * MAX(1.0f, sqrtf(motors_throttle / ref));
|
||||
|
||||
switch (notch.params.tracking_mode()) {
|
||||
case HarmonicNotchDynamicMode::UpdateThrottle: // throttle based tracking
|
||||
// set the harmonic notch filter frequency approximately scaled on motor rpm implied by throttle
|
||||
notch.update_freq_hz(throttle_freq);
|
||||
break;
|
||||
|
||||
case HarmonicNotchDynamicMode::UpdateRPM: // rpm sensor based tracking
|
||||
case HarmonicNotchDynamicMode::UpdateRPM2: {
|
||||
const auto *rpm_sensor = AP::rpm();
|
||||
uint8_t sensor = (notch.params.tracking_mode()==HarmonicNotchDynamicMode::UpdateRPM?0:1);
|
||||
float rpm;
|
||||
if (rpm_sensor != nullptr && rpm_sensor->get_rpm(sensor, rpm)) {
|
||||
// set the harmonic notch filter frequency from the main rotor rpm
|
||||
notch.update_freq_hz(MAX(ref_freq, rpm * ref * (1.0/60)));
|
||||
} else {
|
||||
notch.update_freq_hz(ref_freq);
|
||||
}
|
||||
break;
|
||||
}
|
||||
#if HAL_WITH_ESC_TELEM
|
||||
case HarmonicNotchDynamicMode::UpdateBLHeli: // BLHeli based tracking
|
||||
// set the harmonic notch filter frequency scaled on measured frequency
|
||||
if (notch.params.hasOption(HarmonicNotchFilterParams::Options::DynamicHarmonic)) {
|
||||
float notches[INS_MAX_NOTCHES];
|
||||
const uint8_t num_notches = AP::esc_telem().get_motor_frequencies_hz(notch.num_dynamic_notches, notches);
|
||||
|
||||
for (uint8_t i = 0; i < num_notches; i++) {
|
||||
notches[i] = MAX(ref_freq, notches[i]);
|
||||
}
|
||||
if (num_notches > 0) {
|
||||
notch.update_frequencies_hz(num_notches, notches);
|
||||
} else { // throttle fallback
|
||||
notch.update_freq_hz(throttle_freq);
|
||||
}
|
||||
} else {
|
||||
notch.update_freq_hz(MAX(ref_freq, AP::esc_telem().get_average_motor_frequency_hz() * ref));
|
||||
}
|
||||
break;
|
||||
#endif
|
||||
#if HAL_GYROFFT_ENABLED
|
||||
case HarmonicNotchDynamicMode::UpdateGyroFFT: // FFT based tracking
|
||||
// set the harmonic notch filter frequency scaled on measured frequency
|
||||
if (notch.params.hasOption(HarmonicNotchFilterParams::Options::DynamicHarmonic)) {
|
||||
float notches[INS_MAX_NOTCHES];
|
||||
const uint8_t peaks = gyro_fft.get_weighted_noise_center_frequencies_hz(notch.num_dynamic_notches, notches);
|
||||
|
||||
notch.update_frequencies_hz(peaks, notches);
|
||||
} else {
|
||||
notch.update_freq_hz(gyro_fft.get_weighted_noise_center_freq_hz());
|
||||
}
|
||||
break;
|
||||
#endif
|
||||
case HarmonicNotchDynamicMode::Fixed: // static
|
||||
default:
|
||||
notch.update_freq_hz(ref_freq);
|
||||
break;
|
||||
}
|
||||
#endif // APM_BUILD_TYPE(APM_BUILD_ArduPlane)||APM_BUILD_COPTER_OR_HELI
|
||||
}
|
||||
|
||||
|
||||
// run notch update at either loop rate or 200Hz
|
||||
void AP_Vehicle::update_dynamic_notch_at_specified_rate()
|
||||
{
|
||||
for (uint8_t i=0; i<HAL_INS_NUM_HARMONIC_NOTCH_FILTERS; i++) {
|
||||
if (ins.has_harmonic_option(i, HarmonicNotchFilterParams::Options::LoopRateUpdate)) {
|
||||
update_dynamic_notch(i);
|
||||
for (auto ¬ch : ins.harmonic_notches) {
|
||||
if (notch.params.hasOption(HarmonicNotchFilterParams::Options::LoopRateUpdate)) {
|
||||
update_dynamic_notch(notch);
|
||||
} else {
|
||||
// decimated update at 200Hz
|
||||
const uint32_t now = AP_HAL::millis();
|
||||
|
||||
const uint8_t i = ¬ch - &ins.harmonic_notches[0];
|
||||
if (now - _last_notch_update_ms[i] > 5) {
|
||||
_last_notch_update_ms[i] = now;
|
||||
update_dynamic_notch(i);
|
||||
update_dynamic_notch(notch);
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -534,3 +614,4 @@ AP_Vehicle *vehicle()
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
|
@ -249,7 +249,7 @@ public:
|
||||
#endif // AP_SCRIPTING_ENABLED
|
||||
|
||||
// update the harmonic notch
|
||||
virtual void update_dynamic_notch(uint8_t idx) {};
|
||||
void update_dynamic_notch(AP_InertialSensor::HarmonicNotch ¬ch);
|
||||
|
||||
// zeroing the RC outputs can prevent unwanted motor movement:
|
||||
virtual bool should_zero_rc_outputs_on_reboot() const { return false; }
|
||||
|
Loading…
Reference in New Issue
Block a user