From a567b9956f29da1ac057ca549bc41d7a563a7e5b Mon Sep 17 00:00:00 2001 From: tumbili Date: Mon, 2 Nov 2015 16:11:24 +0100 Subject: [PATCH] fix position hold logic --- src/modules/mc_pos_control/mc_pos_control_main.cpp | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/src/modules/mc_pos_control/mc_pos_control_main.cpp b/src/modules/mc_pos_control/mc_pos_control_main.cpp index 2c2010e895..a465cc64f5 100644 --- a/src/modules/mc_pos_control/mc_pos_control_main.cpp +++ b/src/modules/mc_pos_control/mc_pos_control_main.cpp @@ -710,12 +710,12 @@ MulticopterPositionControl::control_manual(float dt) /* check for pos. hold */ if (fabsf(req_vel_sp(0)) < _params.hold_xy_dz && fabsf(req_vel_sp(1)) < _params.hold_xy_dz) { - if (!_pos_hold_engaged && (_params.hold_max_xy < FLT_EPSILON || - (fabsf(_vel(0)) < _params.hold_max_xy && fabsf(_vel(1)) < _params.hold_max_xy))) - { - _pos_hold_engaged = true; - } else { - _pos_hold_engaged = false; + if (!_pos_hold_engaged) { + if (_params.hold_max_xy < FLT_EPSILON || (fabsf(_vel(0)) < _params.hold_max_xy && fabsf(_vel(1)) < _params.hold_max_xy)) { + _pos_hold_engaged = true; + } else { + _pos_hold_engaged = false; + } } } else {