From 086d0907ddf68992f5da35717bdf89752efebada Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Sun, 2 Jul 2023 16:52:38 +1000 Subject: [PATCH] Plane: fixed TECS state reset in VTOL auto this fixes a bug where TECS maintains its slow integrator while in a VTOL hover mode in AUTO or GUIDED. Among other things this affects PAYLOAD_PLACE and DO_VTOL_TRANSITION. In those states the height can change while hovering outside the control of TECS. When TECS regains control in a fwd transition then can lead to a very large height loss or gain until the TECS integrator can catch up --- ArduPlane/ArduPlane.cpp | 17 +++++++++++++++-- ArduPlane/quadplane.cpp | 16 ++++++++++++++++ ArduPlane/quadplane.h | 6 ++++++ 3 files changed, 37 insertions(+), 2 deletions(-) diff --git a/ArduPlane/ArduPlane.cpp b/ArduPlane/ArduPlane.cpp index d6bdeb797f..eb66712843 100644 --- a/ArduPlane/ArduPlane.cpp +++ b/ArduPlane/ArduPlane.cpp @@ -204,7 +204,13 @@ void Plane::ahrs_update() */ void Plane::update_speed_height(void) { - if (control_mode->does_auto_throttle()) { + bool should_run_tecs = control_mode->does_auto_throttle(); +#if HAL_QUADPLANE_ENABLED + if (quadplane.should_disable_TECS()) { + should_run_tecs = false; + } +#endif + if (should_run_tecs) { // Call TECS 50Hz update. Note that we call this regardless of // throttle suppressed, as this needs to be running for // takeoff detection @@ -538,7 +544,14 @@ void Plane::update_alt() } #endif - if (control_mode->does_auto_throttle() && !throttle_suppressed) { + bool should_run_tecs = control_mode->does_auto_throttle(); +#if HAL_QUADPLANE_ENABLED + if (quadplane.should_disable_TECS()) { + should_run_tecs = false; + } +#endif + + if (should_run_tecs && !throttle_suppressed) { float distance_beyond_land_wp = 0; if (flight_stage == AP_FixedWing::FlightStage::LAND && diff --git a/ArduPlane/quadplane.cpp b/ArduPlane/quadplane.cpp index d3e41e4ba6..3120f53507 100644 --- a/ArduPlane/quadplane.cpp +++ b/ArduPlane/quadplane.cpp @@ -4560,4 +4560,20 @@ bool QuadPlane::allow_stick_mixing() const return transition->allow_stick_mixing(); } +/* + return true if we should disable TECS in the current flight state + this ensures that TECS resets when we change height in a VTOL mode + */ +bool QuadPlane::should_disable_TECS() const +{ + if (in_vtol_land_descent()) { + return true; + } + if (plane.control_mode == &plane.mode_guided && + plane.auto_state.vtol_loiter) { + return true; + } + return false; +} + #endif // HAL_QUADPLANE_ENABLED diff --git a/ArduPlane/quadplane.h b/ArduPlane/quadplane.h index 3575186aaa..ae65c3768e 100644 --- a/ArduPlane/quadplane.h +++ b/ArduPlane/quadplane.h @@ -184,6 +184,12 @@ public: // Should we allow stick mixing from the pilot bool allow_stick_mixing() const; + /* + should we disable the TECS controller? + only called when in an auto-throttle mode + */ + bool should_disable_TECS() const; + private: AP_AHRS &ahrs;