From c755deff215dd8ee066544b1364a2bc742c01cc5 Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Sat, 23 Feb 2019 11:20:20 +1100 Subject: [PATCH] Plane: allow fwd motor to run in VTOL land hor positioning this fixes an issue with vtol landings below the takeoff point --- ArduPlane/quadplane.cpp | 23 +++++++++++++++++------ 1 file changed, 17 insertions(+), 6 deletions(-) diff --git a/ArduPlane/quadplane.cpp b/ArduPlane/quadplane.cpp index 62f2985654..751b854646 100644 --- a/ArduPlane/quadplane.cpp +++ b/ArduPlane/quadplane.cpp @@ -2404,12 +2404,23 @@ int8_t QuadPlane::forward_throttle_pct(void) // inhibit reverse throttle and allow petrol engines with min > 0 int8_t fwd_throttle_min = (plane.aparm.throttle_min <= 0) ? 0 : plane.aparm.throttle_min; vel_forward.integrator = constrain_float(vel_forward.integrator, fwd_throttle_min, plane.aparm.throttle_max); - - // If we are below alt_cutoff then scale down the effect until it turns off at alt_cutoff and decay the integrator - float alt_cutoff = MAX(0,vel_forward_alt_cutoff); - float height_above_ground = plane.relative_ground_altitude(plane.g.rangefinder_landing); - vel_forward.last_pct = linear_interpolate(0, vel_forward.integrator, - height_above_ground, alt_cutoff, alt_cutoff+2); + + if (in_vtol_auto() && is_vtol_land(plane.mission.get_current_nav_cmd().id) && + (poscontrol.state == QPOS_POSITION1 || poscontrol.state == QPOS_POSITION2)) { + // when we are doing horizontal positioning in a VTOL land + // we always allow the fwd motor to run. Otherwise a bad + // lidar could cause the aircraft not to be able to + // approach the landing point when landing below the takeoff point + vel_forward.last_pct = vel_forward.integrator; + } else { + // If we are below alt_cutoff then scale down the effect until + // it turns off at alt_cutoff and decay the integrator + float alt_cutoff = MAX(0,vel_forward_alt_cutoff); + float height_above_ground = plane.relative_ground_altitude(plane.g.rangefinder_landing); + + vel_forward.last_pct = linear_interpolate(0, vel_forward.integrator, + height_above_ground, alt_cutoff, alt_cutoff+2); + } if (vel_forward.last_pct == 0) { // if the percent is 0 then decay the integrator vel_forward.integrator *= 0.95f;