Plane: Auto takeoff roll-limits to use TKOFF_LVL_ALT
This commit is contained in:
parent
0779aef362
commit
96ee3651d2
@ -737,12 +737,12 @@ public:
|
||||
// var_info for holding parameter information
|
||||
static const struct AP_Param::GroupInfo var_info[];
|
||||
|
||||
AP_Int16 target_alt;
|
||||
AP_Int16 level_alt;
|
||||
AP_Float ground_pitch;
|
||||
|
||||
protected:
|
||||
AP_Int16 target_alt;
|
||||
AP_Int16 target_dist;
|
||||
AP_Int16 level_alt;
|
||||
AP_Int8 level_pitch;
|
||||
|
||||
bool takeoff_started;
|
||||
|
@ -16,12 +16,12 @@ const AP_Param::GroupInfo ModeTakeoff::var_info[] = {
|
||||
|
||||
// @Param: LVL_ALT
|
||||
// @DisplayName: Takeoff mode altitude level altitude
|
||||
// @Description: This is the altitude below which wings are held level for TAKEOFF mode
|
||||
// @Description: This is the altitude below which the wings are held level for TAKEOFF and AUTO modes. Below this altitude, roll demand is restricted to LEVEL_ROLL_LIMIT. Normal-flight roll restriction resumes above TKOFF_LVL_ALT*2 or TKOFF_ALT, whichever is lower. Roll limits are scaled while between those altitudes for a smooth transition.
|
||||
// @Range: 0 50
|
||||
// @Increment: 1
|
||||
// @Units: m
|
||||
// @User: Standard
|
||||
AP_GROUPINFO("LVL_ALT", 2, ModeTakeoff, level_alt, 20),
|
||||
AP_GROUPINFO("LVL_ALT", 2, ModeTakeoff, level_alt, 5),
|
||||
|
||||
// @Param: LVL_PITCH
|
||||
// @DisplayName: Takeoff mode altitude initial pitch
|
||||
|
@ -133,19 +133,26 @@ void Plane::takeoff_calc_roll(void)
|
||||
// during takeoff use the level flight roll limit to prevent large
|
||||
// wing strike. Slowly allow for more roll as we get higher above
|
||||
// the takeoff altitude
|
||||
float roll_limit = roll_limit_cd*0.01f;
|
||||
float baro_alt = barometer.get_altitude();
|
||||
// below 5m use the LEVEL_ROLL_LIMIT
|
||||
const float lim1 = 5;
|
||||
// at 15m allow for full roll
|
||||
const float lim2 = 15;
|
||||
if ((baro_alt < auto_state.baro_takeoff_alt+lim1) || (auto_state.highest_airspeed < g.takeoff_rotate_speed)) {
|
||||
roll_limit = g.level_roll_limit;
|
||||
} else if (baro_alt < auto_state.baro_takeoff_alt+lim2) {
|
||||
float proportion = (baro_alt - (auto_state.baro_takeoff_alt+lim1)) / (lim2 - lim1);
|
||||
roll_limit = (1-proportion) * g.level_roll_limit + proportion * roll_limit;
|
||||
int32_t takeoff_roll_limit_cd = roll_limit_cd;
|
||||
|
||||
if (auto_state.highest_airspeed < g.takeoff_rotate_speed) {
|
||||
// before Vrotate (aka, on the ground)
|
||||
takeoff_roll_limit_cd = g.level_roll_limit * 100;
|
||||
} else {
|
||||
// lim1 - below altitude TKOFF_LVL_ALT, restrict roll to LEVEL_ROLL_LIMIT
|
||||
// lim2 - above altitude (TKOFF_LVL_ALT * 3) allow full flight envelope of LIM_ROLL_CD
|
||||
// In between lim1 and lim2 use a scaled roll limit.
|
||||
// The *3 scheme should scale reasonably with both small and large aircraft
|
||||
const float lim1 = MAX(mode_takeoff.level_alt, 0);
|
||||
const float lim2 = MIN(mode_takeoff.level_alt*3, mode_takeoff.target_alt);
|
||||
const float current_baro_alt = barometer.get_altitude();
|
||||
|
||||
takeoff_roll_limit_cd = linear_interpolate(g.level_roll_limit*100, roll_limit_cd,
|
||||
current_baro_alt,
|
||||
auto_state.baro_takeoff_alt+lim1, auto_state.baro_takeoff_alt+lim2);
|
||||
}
|
||||
nav_roll_cd = constrain_int32(nav_roll_cd, -roll_limit*100UL, roll_limit*100UL);
|
||||
|
||||
nav_roll_cd = constrain_int32(nav_roll_cd, -takeoff_roll_limit_cd, takeoff_roll_limit_cd);
|
||||
}
|
||||
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user