L1_Control: Ensure that LIM_BANK passes a sea level sanity check
This fixes #6637 where the LIM_BANK can be set such that the vehicle demands a radius at sea level that is much higher then the loiter radius was configured to be. This effectively feels like a fly away and is due to bad parameters usually. If this happens just fall back to the simple EAS2TAS scaling of the radius.
This commit is contained in:
parent
909f109b3f
commit
2894b7cbea
@ -158,8 +158,14 @@ float AP_L1_Control::loiter_radius(const float radius) const
|
||||
return radius * eas2tas_sq;
|
||||
} else {
|
||||
float sea_level_radius = sq(nominal_velocity_sea_level) / lateral_accel_sea_level;
|
||||
// select the requested radius, or the required altitude scale, whichever is safer
|
||||
return MAX(sea_level_radius * eas2tas_sq, radius);
|
||||
if (sea_level_radius > radius) {
|
||||
// If we've told the plane that its sea level radius is unachievable fallback to
|
||||
// straight altitude scaling
|
||||
return radius * eas2tas_sq;
|
||||
} else {
|
||||
// select the requested radius, or the required altitude scale, whichever is safer
|
||||
return MAX(sea_level_radius * eas2tas_sq, radius);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user