mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-03 06:28:27 -04:00
AP_L1_Control: Made changes to avoid zero division in proposed formula
According suggestion from Andrew Tridgell: https://github.com/ArduPilot/ardupilot/pull/24331#discussion_r1267798397
This commit is contained in:
parent
c2f4661b90
commit
ae1eb93aec
@ -84,9 +84,12 @@ int32_t AP_L1_Control::nav_roll_cd(void) const
|
||||
liftForce * cos(roll) = gravityForce * cos(pitch);
|
||||
liftForce * sin(roll) = gravityForce * lateralAcceleration / gravityAcceleration; // as mass = gravityForce/gravityAcceleration
|
||||
see issue 24319 [https://github.com/ArduPilot/ardupilot/issues/24319]
|
||||
Multiplier 100.0f is for converting degrees to centidegrees
|
||||
*/
|
||||
ret = degrees(atanf(_latAccDem * (1.0f/(GRAVITY_MSS * cosf(_ahrs.pitch))))) * 100.0f;
|
||||
Multiplier 100.0f is for converting degrees to centidegrees
|
||||
Made changes to avoid zero division as proposed by Andrew Tridgell: https://github.com/ArduPilot/ardupilot/pull/24331#discussion_r1267798397
|
||||
*/
|
||||
float pitchLimL1 = radians(60); // Suggestion: constraint may be modified to pitch limits if their absolute values are less than 90 degree and more than 60 degrees.
|
||||
float pitchL1 = constrain_float(_ahrs.pitch,-pitchLimL1,pitchLimL1);
|
||||
ret = degrees(atanf(_latAccDem * (1.0f/(GRAVITY_MSS * cosf(pitchL1))))) * 100.0f;
|
||||
ret = constrain_float(ret, -9000, 9000);
|
||||
return ret;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user