mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-20 15:48:29 -04:00
Copter: factor out takeoff_trigger from althold, sport and loiter
This commit is contained in:
parent
2c0df87585
commit
bf5f51a616
@ -242,3 +242,23 @@ void Copter::Mode::update_navigation()
|
|||||||
// run autopilot to make high level decisions about control modes
|
// run autopilot to make high level decisions about control modes
|
||||||
run_autopilot();
|
run_autopilot();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool Copter::Mode::takeoff_triggered(const float target_climb_rate) const
|
||||||
|
{
|
||||||
|
if (!ap.land_complete) {
|
||||||
|
// can't take off if we're already flying
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (target_climb_rate <= 0.0f) {
|
||||||
|
// can't takeoff unless we want to go up...
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
#if FRAME_CONFIG == HELI_FRAME
|
||||||
|
if (!motors->rotor_runup_complete()) {
|
||||||
|
// hold heli on the ground until rotor speed runup has finished
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
@ -72,6 +72,9 @@ protected:
|
|||||||
ap_t ≈
|
ap_t ≈
|
||||||
takeoff_state_t &takeoff_state;
|
takeoff_state_t &takeoff_state;
|
||||||
|
|
||||||
|
// takeoff support
|
||||||
|
bool takeoff_triggered(float target_climb_rate) const;
|
||||||
|
|
||||||
// gnd speed limit required to observe optical flow sensor limits
|
// gnd speed limit required to observe optical flow sensor limits
|
||||||
float &ekfGndSpdLimit;
|
float &ekfGndSpdLimit;
|
||||||
|
|
||||||
|
@ -49,17 +49,10 @@ void Copter::ModeAltHold::run()
|
|||||||
float target_climb_rate = get_pilot_desired_climb_rate(channel_throttle->get_control_in());
|
float target_climb_rate = get_pilot_desired_climb_rate(channel_throttle->get_control_in());
|
||||||
target_climb_rate = constrain_float(target_climb_rate, -get_pilot_speed_dn(), g.pilot_speed_up);
|
target_climb_rate = constrain_float(target_climb_rate, -get_pilot_speed_dn(), g.pilot_speed_up);
|
||||||
|
|
||||||
#if FRAME_CONFIG == HELI_FRAME
|
|
||||||
// helicopters are held on the ground until rotor speed runup has finished
|
|
||||||
bool takeoff_triggered = (ap.land_complete && (target_climb_rate > 0.0f) && motors->rotor_runup_complete());
|
|
||||||
#else
|
|
||||||
bool takeoff_triggered = ap.land_complete && (target_climb_rate > 0.0f);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// Alt Hold State Machine Determination
|
// Alt Hold State Machine Determination
|
||||||
if (!motors->armed() || !motors->get_interlock()) {
|
if (!motors->armed() || !motors->get_interlock()) {
|
||||||
althold_state = AltHold_MotorStopped;
|
althold_state = AltHold_MotorStopped;
|
||||||
} else if (takeoff_state.running || takeoff_triggered) {
|
} else if (takeoff_state.running || takeoff_triggered(target_climb_rate)) {
|
||||||
althold_state = AltHold_Takeoff;
|
althold_state = AltHold_Takeoff;
|
||||||
} else if (!ap.auto_armed || ap.land_complete) {
|
} else if (!ap.auto_armed || ap.land_complete) {
|
||||||
althold_state = AltHold_Landed;
|
althold_state = AltHold_Landed;
|
||||||
|
@ -101,17 +101,10 @@ void Copter::ModeLoiter::run()
|
|||||||
wp_nav->loiter_soften_for_landing();
|
wp_nav->loiter_soften_for_landing();
|
||||||
}
|
}
|
||||||
|
|
||||||
#if FRAME_CONFIG == HELI_FRAME
|
|
||||||
// helicopters are held on the ground until rotor speed runup has finished
|
|
||||||
bool takeoff_triggered = (ap.land_complete && (target_climb_rate > 0.0f) && motors->rotor_runup_complete());
|
|
||||||
#else
|
|
||||||
bool takeoff_triggered = ap.land_complete && (target_climb_rate > 0.0f);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// Loiter State Machine Determination
|
// Loiter State Machine Determination
|
||||||
if (!motors->armed() || !motors->get_interlock()) {
|
if (!motors->armed() || !motors->get_interlock()) {
|
||||||
loiter_state = Loiter_MotorStopped;
|
loiter_state = Loiter_MotorStopped;
|
||||||
} else if (takeoff_state.running || takeoff_triggered) {
|
} else if (takeoff_state.running || takeoff_triggered(target_climb_rate)) {
|
||||||
loiter_state = Loiter_Takeoff;
|
loiter_state = Loiter_Takeoff;
|
||||||
} else if (!ap.auto_armed || ap.land_complete) {
|
} else if (!ap.auto_armed || ap.land_complete) {
|
||||||
loiter_state = Loiter_Landed;
|
loiter_state = Loiter_Landed;
|
||||||
|
@ -71,17 +71,10 @@ void Copter::ModeSport::run()
|
|||||||
float target_climb_rate = get_pilot_desired_climb_rate(channel_throttle->get_control_in());
|
float target_climb_rate = get_pilot_desired_climb_rate(channel_throttle->get_control_in());
|
||||||
target_climb_rate = constrain_float(target_climb_rate, -get_pilot_speed_dn(), g.pilot_speed_up);
|
target_climb_rate = constrain_float(target_climb_rate, -get_pilot_speed_dn(), g.pilot_speed_up);
|
||||||
|
|
||||||
#if FRAME_CONFIG == HELI_FRAME
|
|
||||||
// helicopters are held on the ground until rotor speed runup has finished
|
|
||||||
bool takeoff_triggered = (ap.land_complete && (target_climb_rate > 0.0f) && motors->rotor_runup_complete());
|
|
||||||
#else
|
|
||||||
bool takeoff_triggered = ap.land_complete && (target_climb_rate > 0.0f);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// State Machine Determination
|
// State Machine Determination
|
||||||
if (!motors->armed() || !motors->get_interlock()) {
|
if (!motors->armed() || !motors->get_interlock()) {
|
||||||
sport_state = Sport_MotorStopped;
|
sport_state = Sport_MotorStopped;
|
||||||
} else if (takeoff_state.running || takeoff_triggered) {
|
} else if (takeoff_state.running || takeoff_triggered(target_climb_rate)) {
|
||||||
sport_state = Sport_Takeoff;
|
sport_state = Sport_Takeoff;
|
||||||
} else if (!ap.auto_armed || ap.land_complete) {
|
} else if (!ap.auto_armed || ap.land_complete) {
|
||||||
sport_state = Sport_Landed;
|
sport_state = Sport_Landed;
|
||||||
|
Loading…
Reference in New Issue
Block a user