Browse Source

AC_PosControl: add force_descend option to set_alt_target_from_climb_rate

mission-4.1.18
Jonathan Challinger 10 years ago committed by Randy Mackay
parent
commit
e81c1dd5a1
  1. 4
      libraries/AC_AttitudeControl/AC_PosControl.cpp
  2. 2
      libraries/AC_AttitudeControl/AC_PosControl.h

4
libraries/AC_AttitudeControl/AC_PosControl.cpp

@ -137,11 +137,11 @@ void AC_PosControl::set_alt_target_with_slew(float alt_cm, float dt) @@ -137,11 +137,11 @@ void AC_PosControl::set_alt_target_with_slew(float alt_cm, float dt)
/// should be called continuously (with dt set to be the expected time between calls)
/// actual position target will be moved no faster than the speed_down and speed_up
/// target will also be stopped if the motors hit their limits or leash length is exceeded
void AC_PosControl::set_alt_target_from_climb_rate(float climb_rate_cms, float dt)
void AC_PosControl::set_alt_target_from_climb_rate(float climb_rate_cms, float dt, bool force_descend)
{
// adjust desired alt if motors have not hit their limits
// To-Do: add check of _limit.pos_up and _limit.pos_down?
if ((climb_rate_cms<0 && !_motors.limit.throttle_lower) || (climb_rate_cms>0 && !_motors.limit.throttle_upper)) {
if ((climb_rate_cms<0 && (!_motors.limit.throttle_lower || force_descend)) || (climb_rate_cms>0 && !_motors.limit.throttle_upper)) {
_pos_target.z += climb_rate_cms * dt;
}
}

2
libraries/AC_AttitudeControl/AC_PosControl.h

@ -109,7 +109,7 @@ public: @@ -109,7 +109,7 @@ public:
/// should be called continuously (with dt set to be the expected time between calls)
/// actual position target will be moved no faster than the speed_down and speed_up
/// target will also be stopped if the motors hit their limits or leash length is exceeded
void set_alt_target_from_climb_rate(float climb_rate_cms, float dt);
void set_alt_target_from_climb_rate(float climb_rate_cms, float dt, bool force_descend = true);
/// set_alt_target_to_current_alt - set altitude target to current altitude
void set_alt_target_to_current_alt() { _pos_target.z = _inav.get_altitude(); }

Loading…
Cancel
Save