From a2f52f6a1854c7850960c519d84a401090ea2885 Mon Sep 17 00:00:00 2001 From: Leonard Hall Date: Wed, 30 Nov 2022 15:54:33 +1030 Subject: [PATCH] AP_WheelEncoder: Support changing update period --- libraries/AP_WheelEncoder/AP_WheelRateControl.cpp | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/libraries/AP_WheelEncoder/AP_WheelRateControl.cpp b/libraries/AP_WheelEncoder/AP_WheelRateControl.cpp index 732a2e35c2..ff8739eb45 100644 --- a/libraries/AP_WheelEncoder/AP_WheelRateControl.cpp +++ b/libraries/AP_WheelEncoder/AP_WheelRateControl.cpp @@ -189,9 +189,6 @@ float AP_WheelRateControl::get_rate_controlled_throttle(uint8_t instance, float // determine which PID instance to use AC_PID& rate_pid = (instance == 0) ? _rate_pid0 : _rate_pid1; - // set PID's dt - rate_pid.set_dt(dt); - // check for timeout uint32_t now = AP_HAL::millis(); if (now - _last_update_ms > AP_WHEEL_RATE_CONTROL_TIMEOUT_MS) { @@ -205,11 +202,11 @@ float AP_WheelRateControl::get_rate_controlled_throttle(uint8_t instance, float // convert desired rate as a percentage to radians/sec float desired_rate = desired_rate_pct * 0.01f * get_rate_max_rads(); - // get actual rate from wheeel encoder + // get actual rate from wheel encoder float actual_rate = _wheel_encoder.get_rate(instance); // constrain and set limit flags - float output = rate_pid.update_all(desired_rate, actual_rate, (_limit[instance].lower || _limit[instance].upper)); + float output = rate_pid.update_all(desired_rate, actual_rate, dt, (_limit[instance].lower || _limit[instance].upper)); output += rate_pid.get_ff(); // set limits for next iteration