AR_AttitudeControl: use _desired_speed instead of desired_speed for throttle-speed controller
This commit is contained in:
parent
e6f488ccc1
commit
2e5c201222
@ -635,11 +635,11 @@ float AR_AttitudeControl::get_throttle_out_speed(float desired_speed, bool motor
|
|||||||
// calculate base throttle (protect against divide by zero)
|
// calculate base throttle (protect against divide by zero)
|
||||||
float throttle_base = 0.0f;
|
float throttle_base = 0.0f;
|
||||||
if (is_positive(cruise_speed) && is_positive(cruise_throttle)) {
|
if (is_positive(cruise_speed) && is_positive(cruise_throttle)) {
|
||||||
throttle_base = desired_speed * (cruise_throttle / cruise_speed);
|
throttle_base = _desired_speed * (cruise_throttle / cruise_speed);
|
||||||
}
|
}
|
||||||
|
|
||||||
// calculate final output
|
// calculate final output
|
||||||
float throttle_out = _throttle_speed_pid.update_all(desired_speed, speed, (motor_limit_low || motor_limit_high || _throttle_limit_low || _throttle_limit_high));
|
float throttle_out = _throttle_speed_pid.update_all(_desired_speed, speed, (motor_limit_low || motor_limit_high || _throttle_limit_low || _throttle_limit_high));
|
||||||
throttle_out += _throttle_speed_pid.get_ff();
|
throttle_out += _throttle_speed_pid.get_ff();
|
||||||
throttle_out += throttle_base;
|
throttle_out += throttle_base;
|
||||||
|
|
||||||
@ -654,10 +654,10 @@ float AR_AttitudeControl::get_throttle_out_speed(float desired_speed, bool motor
|
|||||||
// protect against reverse output being sent to the motors unless braking has been enabled
|
// protect against reverse output being sent to the motors unless braking has been enabled
|
||||||
if (!_brake_enable) {
|
if (!_brake_enable) {
|
||||||
// if both desired speed and actual speed are positive, do not allow negative values
|
// if both desired speed and actual speed are positive, do not allow negative values
|
||||||
if ((desired_speed >= 0.0f) && (throttle_out <= 0.0f)) {
|
if ((_desired_speed >= 0.0f) && (throttle_out <= 0.0f)) {
|
||||||
throttle_out = 0.0f;
|
throttle_out = 0.0f;
|
||||||
_throttle_limit_low = true;
|
_throttle_limit_low = true;
|
||||||
} else if ((desired_speed <= 0.0f) && (throttle_out >= 0.0f)) {
|
} else if ((_desired_speed <= 0.0f) && (throttle_out >= 0.0f)) {
|
||||||
throttle_out = 0.0f;
|
throttle_out = 0.0f;
|
||||||
_throttle_limit_high = true;
|
_throttle_limit_high = true;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user