mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-11 02:18:29 -04:00
ArduCopter: remove some unhelpful constraints on nav_lat and nav_lon.
Increase other constraints from 3200 to 32000. These constraints are there to ensure int32_t do not cause an overflow when added to an int16_t.
This commit is contained in:
parent
ab86eae860
commit
e780bfd4c1
@ -484,7 +484,7 @@ get_throttle_rate(int16_t z_target_speed)
|
|||||||
|
|
||||||
if(z_target_speed < 0) tmp = -tmp;
|
if(z_target_speed < 0) tmp = -tmp;
|
||||||
|
|
||||||
output = constrain(tmp, -3200, 3200);
|
output = constrain(tmp, -32000, 32000); // constraint to remove chance of overflow when adding int32_t to int16_t
|
||||||
|
|
||||||
// separately calculate p, i, d values for logging
|
// separately calculate p, i, d values for logging
|
||||||
p = g.pid_throttle.get_p(z_rate_error);
|
p = g.pid_throttle.get_p(z_rate_error);
|
||||||
|
@ -117,7 +117,7 @@ static void calc_loiter(int16_t x_error, int16_t y_error)
|
|||||||
}
|
}
|
||||||
|
|
||||||
output = p + i + d;
|
output = p + i + d;
|
||||||
nav_lon = constrain(output, -3200, 3200);
|
nav_lon = constrain(output, -32000, 32000); // constraint to remove chance of overflow when adding int32_t to int16_t
|
||||||
|
|
||||||
#if LOGGING_ENABLED == ENABLED
|
#if LOGGING_ENABLED == ENABLED
|
||||||
// log output if PID logging is on and we are tuning the yaw
|
// log output if PID logging is on and we are tuning the yaw
|
||||||
@ -154,7 +154,7 @@ static void calc_loiter(int16_t x_error, int16_t y_error)
|
|||||||
}
|
}
|
||||||
|
|
||||||
output = p + i + d;
|
output = p + i + d;
|
||||||
nav_lat = constrain(output, -3200, 3200);
|
nav_lat = constrain(output, -32000, 32000); // constraint to remove chance of overflow when adding int32_t to int16_t
|
||||||
|
|
||||||
#if LOGGING_ENABLED == ENABLED
|
#if LOGGING_ENABLED == ENABLED
|
||||||
// log output if PID logging is on and we are tuning the yaw
|
// log output if PID logging is on and we are tuning the yaw
|
||||||
@ -201,7 +201,6 @@ static void calc_nav_rate(int16_t max_speed)
|
|||||||
|
|
||||||
if(x_target_speed < 0) tilt = -tilt;
|
if(x_target_speed < 0) tilt = -tilt;
|
||||||
nav_lon += tilt;
|
nav_lon += tilt;
|
||||||
nav_lon = constrain(nav_lon, -3200, 3200);
|
|
||||||
|
|
||||||
|
|
||||||
// North / South
|
// North / South
|
||||||
@ -218,7 +217,6 @@ static void calc_nav_rate(int16_t max_speed)
|
|||||||
|
|
||||||
if(y_target_speed < 0) tilt = -tilt;
|
if(y_target_speed < 0) tilt = -tilt;
|
||||||
nav_lat += tilt;
|
nav_lat += tilt;
|
||||||
nav_lat = constrain(nav_lat, -3200, 3200);
|
|
||||||
|
|
||||||
// copy over I term to Loiter_Rate
|
// copy over I term to Loiter_Rate
|
||||||
g.pid_loiter_rate_lon.set_integrator(g.pid_nav_lon.get_integrator());
|
g.pid_loiter_rate_lon.set_integrator(g.pid_nav_lon.get_integrator());
|
||||||
|
Loading…
Reference in New Issue
Block a user