mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-24 01:28:29 -04:00
AP_Landing: Migrate the rest of "LAND_" params from Plane to AP_Landing
This commit is contained in:
parent
6544afbcba
commit
98ae77d6a3
@ -24,7 +24,7 @@
|
|||||||
// table of user settable parameters
|
// table of user settable parameters
|
||||||
const AP_Param::GroupInfo AP_Landing::var_info[] = {
|
const AP_Param::GroupInfo AP_Landing::var_info[] = {
|
||||||
|
|
||||||
// @Param: LAND_SLOPE_RCALC
|
// @Param: SLOPE_RCALC
|
||||||
// @DisplayName: Landing slope re-calc threshold
|
// @DisplayName: Landing slope re-calc threshold
|
||||||
// @Description: This parameter is used when using a rangefinder during landing for altitude correction from baro drift (RNGFND_LANDING=1) and the altitude correction indicates your altitude is lower than the intended slope path. This value is the threshold of the correction to re-calculate the landing approach slope. Set to zero to keep the original slope all the way down and any detected baro drift will be corrected by pitching/throttling up to snap back to resume the original slope path. Otherwise, when a rangefinder altitude correction exceeds this threshold it will trigger a slope re-calculate to give a shallower slope. This also smoothes out the approach when flying over objects such as trees. Recommend a value of 2m.
|
// @Description: This parameter is used when using a rangefinder during landing for altitude correction from baro drift (RNGFND_LANDING=1) and the altitude correction indicates your altitude is lower than the intended slope path. This value is the threshold of the correction to re-calculate the landing approach slope. Set to zero to keep the original slope all the way down and any detected baro drift will be corrected by pitching/throttling up to snap back to resume the original slope path. Otherwise, when a rangefinder altitude correction exceeds this threshold it will trigger a slope re-calculate to give a shallower slope. This also smoothes out the approach when flying over objects such as trees. Recommend a value of 2m.
|
||||||
// @Range: 0 5
|
// @Range: 0 5
|
||||||
@ -33,7 +33,7 @@ const AP_Param::GroupInfo AP_Landing::var_info[] = {
|
|||||||
// @User: Advanced
|
// @User: Advanced
|
||||||
AP_GROUPINFO("SLOPE_RCALC", 1, AP_Landing, slope_recalc_shallow_threshold, 2.0f),
|
AP_GROUPINFO("SLOPE_RCALC", 1, AP_Landing, slope_recalc_shallow_threshold, 2.0f),
|
||||||
|
|
||||||
// @Param: LAND_ABORT_DEG
|
// @Param: ABORT_DEG
|
||||||
// @DisplayName: Landing auto-abort slope threshold
|
// @DisplayName: Landing auto-abort slope threshold
|
||||||
// @Description: This parameter is used when using a rangefinder during landing for altitude correction from baro drift (RNGFND_LANDING=1) and the altitude correction indicates your actual altitude is higher than the intended slope path. Normally it would pitch down steeply but that can result in a crash with high airspeed so this allows remembering the baro offset and self-abort the landing and come around for another landing with the correct baro offset applied for a perfect slope. An auto-abort go-around will only happen once, next attempt will not auto-abort again. This operation happens entirely automatically in AUTO mode. This value is the delta degrees threshold to trigger the go-around compared to the original slope. Example: if set to 5 deg and the mission planned slope is 15 deg then if the new slope is 21 then it will go-around. Set to 0 to disable. Requires LAND_SLOPE_RCALC > 0.
|
// @Description: This parameter is used when using a rangefinder during landing for altitude correction from baro drift (RNGFND_LANDING=1) and the altitude correction indicates your actual altitude is higher than the intended slope path. Normally it would pitch down steeply but that can result in a crash with high airspeed so this allows remembering the baro offset and self-abort the landing and come around for another landing with the correct baro offset applied for a perfect slope. An auto-abort go-around will only happen once, next attempt will not auto-abort again. This operation happens entirely automatically in AUTO mode. This value is the delta degrees threshold to trigger the go-around compared to the original slope. Example: if set to 5 deg and the mission planned slope is 15 deg then if the new slope is 21 then it will go-around. Set to 0 to disable. Requires LAND_SLOPE_RCALC > 0.
|
||||||
// @Range: 0 90
|
// @Range: 0 90
|
||||||
@ -42,14 +42,14 @@ const AP_Param::GroupInfo AP_Landing::var_info[] = {
|
|||||||
// @User: Advanced
|
// @User: Advanced
|
||||||
AP_GROUPINFO("ABORT_DEG", 2, AP_Landing, slope_recalc_steep_threshold_to_abort, 0),
|
AP_GROUPINFO("ABORT_DEG", 2, AP_Landing, slope_recalc_steep_threshold_to_abort, 0),
|
||||||
|
|
||||||
// @Param: LAND_PITCH_CD
|
// @Param: PITCH_CD
|
||||||
// @DisplayName: Landing Pitch
|
// @DisplayName: Landing Pitch
|
||||||
// @Description: Used in autoland to give the minimum pitch in the final stage of landing (after the flare). This parameter can be used to ensure that the final landing attitude is appropriate for the type of undercarriage on the aircraft. Note that it is a minimum pitch only - the landing code will control pitch above this value to try to achieve the configured landing sink rate.
|
// @Description: Used in autoland to give the minimum pitch in the final stage of landing (after the flare). This parameter can be used to ensure that the final landing attitude is appropriate for the type of undercarriage on the aircraft. Note that it is a minimum pitch only - the landing code will control pitch above this value to try to achieve the configured landing sink rate.
|
||||||
// @Units: centi-Degrees
|
// @Units: centi-Degrees
|
||||||
// @User: Advanced
|
// @User: Advanced
|
||||||
AP_GROUPINFO("PITCH_CD", 3, AP_Landing, pitch_cd, 0),
|
AP_GROUPINFO("PITCH_CD", 3, AP_Landing, pitch_cd, 0),
|
||||||
|
|
||||||
// @Param: LAND_FLARE_ALT
|
// @Param: FLARE_ALT
|
||||||
// @DisplayName: Landing flare altitude
|
// @DisplayName: Landing flare altitude
|
||||||
// @Description: Altitude in autoland at which to lock heading and flare to the LAND_PITCH_CD pitch. Note that this option is secondary to LAND_FLARE_SEC. For a good landing it preferable that the flare is triggered by LAND_FLARE_SEC.
|
// @Description: Altitude in autoland at which to lock heading and flare to the LAND_PITCH_CD pitch. Note that this option is secondary to LAND_FLARE_SEC. For a good landing it preferable that the flare is triggered by LAND_FLARE_SEC.
|
||||||
// @Units: meters
|
// @Units: meters
|
||||||
@ -57,7 +57,7 @@ const AP_Param::GroupInfo AP_Landing::var_info[] = {
|
|||||||
// @User: Advanced
|
// @User: Advanced
|
||||||
AP_GROUPINFO("FLARE_ALT", 4, AP_Landing, flare_alt, 3.0f),
|
AP_GROUPINFO("FLARE_ALT", 4, AP_Landing, flare_alt, 3.0f),
|
||||||
|
|
||||||
// @Param: LAND_FLARE_SEC
|
// @Param: FLARE_SEC
|
||||||
// @DisplayName: Landing flare time
|
// @DisplayName: Landing flare time
|
||||||
// @Description: Vertical time before landing point at which to lock heading and flare with the motor stopped. This is vertical time, and is calculated based solely on the current height above the ground and the current descent rate. Set to 0 if you only wish to flare based on altitude (see LAND_FLARE_ALT).
|
// @Description: Vertical time before landing point at which to lock heading and flare with the motor stopped. This is vertical time, and is calculated based solely on the current height above the ground and the current descent rate. Set to 0 if you only wish to flare based on altitude (see LAND_FLARE_ALT).
|
||||||
// @Units: seconds
|
// @Units: seconds
|
||||||
@ -65,7 +65,7 @@ const AP_Param::GroupInfo AP_Landing::var_info[] = {
|
|||||||
// @User: Advanced
|
// @User: Advanced
|
||||||
AP_GROUPINFO("FLARE_SEC", 5, AP_Landing, flare_sec, 2.0f),
|
AP_GROUPINFO("FLARE_SEC", 5, AP_Landing, flare_sec, 2.0f),
|
||||||
|
|
||||||
// @Param: LAND_PF_ALT
|
// @Param: PF_ALT
|
||||||
// @DisplayName: Landing pre-flare altitude
|
// @DisplayName: Landing pre-flare altitude
|
||||||
// @Description: Altitude to trigger pre-flare flight stage where LAND_PF_ARSPD controls airspeed. The pre-flare flight stage trigger works just like LAND_FLARE_ALT but higher. Disabled when LAND_PF_ARSPD is 0.
|
// @Description: Altitude to trigger pre-flare flight stage where LAND_PF_ARSPD controls airspeed. The pre-flare flight stage trigger works just like LAND_FLARE_ALT but higher. Disabled when LAND_PF_ARSPD is 0.
|
||||||
// @Units: meters
|
// @Units: meters
|
||||||
@ -74,7 +74,7 @@ const AP_Param::GroupInfo AP_Landing::var_info[] = {
|
|||||||
// @User: Advanced
|
// @User: Advanced
|
||||||
AP_GROUPINFO("PF_ALT", 6, AP_Landing, pre_flare_alt, 10.0f),
|
AP_GROUPINFO("PF_ALT", 6, AP_Landing, pre_flare_alt, 10.0f),
|
||||||
|
|
||||||
// @Param: LAND_PF_SEC
|
// @Param: PF_SEC
|
||||||
// @DisplayName: Landing pre-flare time
|
// @DisplayName: Landing pre-flare time
|
||||||
// @Description: Vertical time to ground to trigger pre-flare flight stage where LAND_PF_ARSPD controls airspeed. This pre-flare flight stage trigger works just like LAND_FLARE_SEC but earlier. Disabled when LAND_PF_ARSPD is 0.
|
// @Description: Vertical time to ground to trigger pre-flare flight stage where LAND_PF_ARSPD controls airspeed. This pre-flare flight stage trigger works just like LAND_FLARE_SEC but earlier. Disabled when LAND_PF_ARSPD is 0.
|
||||||
// @Units: seconds
|
// @Units: seconds
|
||||||
@ -83,7 +83,7 @@ const AP_Param::GroupInfo AP_Landing::var_info[] = {
|
|||||||
// @User: Advanced
|
// @User: Advanced
|
||||||
AP_GROUPINFO("PF_SEC", 7, AP_Landing, pre_flare_sec, 6.0f),
|
AP_GROUPINFO("PF_SEC", 7, AP_Landing, pre_flare_sec, 6.0f),
|
||||||
|
|
||||||
// @Param: LAND_PF_ARSPD
|
// @Param: PF_ARSPD
|
||||||
// @DisplayName: Landing pre-flare airspeed
|
// @DisplayName: Landing pre-flare airspeed
|
||||||
// @Description: Desired airspeed during pre-flare flight stage. This is useful to reduce airspeed just before the flare. Use 0 to disable.
|
// @Description: Desired airspeed during pre-flare flight stage. This is useful to reduce airspeed just before the flare. Use 0 to disable.
|
||||||
// @Units: m/s
|
// @Units: m/s
|
||||||
@ -92,6 +92,46 @@ const AP_Param::GroupInfo AP_Landing::var_info[] = {
|
|||||||
// @User: Advanced
|
// @User: Advanced
|
||||||
AP_GROUPINFO("PF_ARSPD", 8, AP_Landing, pre_flare_airspeed, 0),
|
AP_GROUPINFO("PF_ARSPD", 8, AP_Landing, pre_flare_airspeed, 0),
|
||||||
|
|
||||||
|
// @Param: THR_SLEW
|
||||||
|
// @DisplayName: Landing throttle slew rate
|
||||||
|
// @Description: This parameter sets the slew rate for the throttle during auto landing. When this is zero the THR_SLEWRATE parameter is used during landing. The value is a percentage throttle change per second, so a value of 20 means to advance the throttle over 5 seconds on landing. Values below 50 are not recommended as it may cause a stall when airspeed is low and you can not throttle up fast enough.
|
||||||
|
// @Units: percent
|
||||||
|
// @Range: 0 127
|
||||||
|
// @Increment: 1
|
||||||
|
// @User: User
|
||||||
|
AP_GROUPINFO("THR_SLEW", 9, AP_Landing, throttle_slewrate, 0),
|
||||||
|
|
||||||
|
// @Param: DISARMDELAY
|
||||||
|
// @DisplayName: Landing disarm delay
|
||||||
|
// @Description: After a landing has completed using a LAND waypoint, automatically disarm after this many seconds have passed. Use 0 to not disarm.
|
||||||
|
// @Units: seconds
|
||||||
|
// @Increment: 1
|
||||||
|
// @Range: 0 127
|
||||||
|
// @User: Advanced
|
||||||
|
AP_GROUPINFO("DISARMDELAY", 10, AP_Landing, disarm_delay, 20),
|
||||||
|
|
||||||
|
// @Param: THEN_NEUTRL
|
||||||
|
// @DisplayName: Set servos to neutral after landing
|
||||||
|
// @Description: When enabled, after an autoland and auto-disarm via LAND_DISARMDELAY happens then set all servos to neutral. This is helpful when an aircraft has a rough landing upside down or a crazy angle causing the servos to strain.
|
||||||
|
// @Values: 0:Disabled, 1:Servos to Neutral, 2:Servos to Zero PWM
|
||||||
|
// @User: Advanced
|
||||||
|
AP_GROUPINFO("THEN_NEUTRL", 11, AP_Landing, then_servos_neutral, 0),
|
||||||
|
|
||||||
|
// @Param: ABORT_THR
|
||||||
|
// @DisplayName: Landing abort using throttle
|
||||||
|
// @Description: Allow a landing abort to trigger with a throttle > 95%
|
||||||
|
// @Values: 0:Disabled, 1:Enabled
|
||||||
|
// @User: Advanced
|
||||||
|
AP_GROUPINFO("ABORT_THR", 12, AP_Landing, abort_throttle_enable, 0),
|
||||||
|
|
||||||
|
// @Param: FLAP_PERCNT
|
||||||
|
// @DisplayName: Landing flap percentage
|
||||||
|
// @Description: The amount of flaps (as a percentage) to apply in the landing approach and flare of an automatic landing
|
||||||
|
// @Range: 0 100
|
||||||
|
// @Units: Percent
|
||||||
|
// @User: Advanced
|
||||||
|
AP_GROUPINFO("FLAP_PERCNT", 13, AP_Landing, flap_percent, 0),
|
||||||
|
|
||||||
AP_GROUPEND
|
AP_GROUPEND
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -116,6 +116,12 @@ public:
|
|||||||
AP_Float slope_recalc_shallow_threshold;
|
AP_Float slope_recalc_shallow_threshold;
|
||||||
AP_Float slope_recalc_steep_threshold_to_abort;
|
AP_Float slope_recalc_steep_threshold_to_abort;
|
||||||
|
|
||||||
|
AP_Int8 disarm_delay;
|
||||||
|
AP_Int8 then_servos_neutral;
|
||||||
|
AP_Int8 abort_throttle_enable;
|
||||||
|
AP_Int8 flap_percent;
|
||||||
|
AP_Int8 throttle_slewrate;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
bool has_aborted_due_to_slope_recalc;
|
bool has_aborted_due_to_slope_recalc;
|
||||||
|
Loading…
Reference in New Issue
Block a user