mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-10 09:58:28 -04:00
Copter: Fix Rate expo calculation
This fixes a bug in the yaw rate expo and makes these changes consistent with roll and pitch rate expo.
This commit is contained in:
parent
768dcb6768
commit
c90e31fc75
@ -10,18 +10,16 @@ float Copter::get_pilot_desired_yaw_rate(int16_t stick_angle)
|
|||||||
}
|
}
|
||||||
float yaw_request;
|
float yaw_request;
|
||||||
|
|
||||||
|
// range check expo
|
||||||
|
g2.acro_y_expo = constrain_float(g2.acro_y_expo, 0.0f, 1.0f);
|
||||||
|
|
||||||
// calculate yaw rate request
|
// calculate yaw rate request
|
||||||
if (g2.acro_y_expo <= 0) {
|
if (is_zero(g2.acro_y_expo)) {
|
||||||
yaw_request = stick_angle * g.acro_yaw_p;
|
yaw_request = stick_angle * g.acro_yaw_p;
|
||||||
} else {
|
} else {
|
||||||
// expo variables
|
// expo variables
|
||||||
float y_in, y_in3, y_out;
|
float y_in, y_in3, y_out;
|
||||||
|
|
||||||
// range check expo
|
|
||||||
if (g2.acro_y_expo > 1.0f || g2.acro_y_expo < 0.5f) {
|
|
||||||
g2.acro_y_expo = 1.0f;
|
|
||||||
}
|
|
||||||
|
|
||||||
// yaw expo
|
// yaw expo
|
||||||
y_in = float(stick_angle)/ROLL_PITCH_YAW_INPUT_MAX;
|
y_in = float(stick_angle)/ROLL_PITCH_YAW_INPUT_MAX;
|
||||||
y_in3 = y_in*y_in*y_in;
|
y_in3 = y_in*y_in*y_in;
|
||||||
|
@ -82,20 +82,18 @@ void ModeAcro::get_pilot_desired_angle_rates(int16_t roll_in, int16_t pitch_in,
|
|||||||
roll_in *= ratio;
|
roll_in *= ratio;
|
||||||
pitch_in *= ratio;
|
pitch_in *= ratio;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// range check expo
|
||||||
|
g.acro_rp_p = constrain_float(g.acro_rp_p, 0.0f, 1.0f);
|
||||||
|
|
||||||
// calculate roll, pitch rate requests
|
// calculate roll, pitch rate requests
|
||||||
if (g.acro_rp_expo <= 0) {
|
if (is_zero(g.acro_rp_expo)) {
|
||||||
rate_bf_request.x = roll_in * g.acro_rp_p;
|
rate_bf_request.x = roll_in * g.acro_rp_p;
|
||||||
rate_bf_request.y = pitch_in * g.acro_rp_p;
|
rate_bf_request.y = pitch_in * g.acro_rp_p;
|
||||||
} else {
|
} else {
|
||||||
// expo variables
|
// expo variables
|
||||||
float rp_in, rp_in3, rp_out;
|
float rp_in, rp_in3, rp_out;
|
||||||
|
|
||||||
// range check expo
|
|
||||||
if (g.acro_rp_expo > 1.0f) {
|
|
||||||
g.acro_rp_expo = 1.0f;
|
|
||||||
}
|
|
||||||
|
|
||||||
// roll expo
|
// roll expo
|
||||||
rp_in = float(roll_in)/ROLL_PITCH_YAW_INPUT_MAX;
|
rp_in = float(roll_in)/ROLL_PITCH_YAW_INPUT_MAX;
|
||||||
rp_in3 = rp_in*rp_in*rp_in;
|
rp_in3 = rp_in*rp_in*rp_in;
|
||||||
|
Loading…
Reference in New Issue
Block a user