mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-09 09:28:31 -04:00
Copter: complete rename to SmartRTL
Also fix parameter description for CH7_OPT
This commit is contained in:
parent
6d15a72f3a
commit
44a436642b
@ -64,7 +64,7 @@
|
|||||||
* Roberto Navoni :Library testing, Porting to VRBrain
|
* Roberto Navoni :Library testing, Porting to VRBrain
|
||||||
* Sandro Benigno :Camera support, MinimOSD
|
* Sandro Benigno :Camera support, MinimOSD
|
||||||
* Sandro Tognana :PosHold flight mode
|
* Sandro Tognana :PosHold flight mode
|
||||||
* Sebastian Quilter :SafeRTL
|
* Sebastian Quilter :SmartRTL
|
||||||
* ..and many more.
|
* ..and many more.
|
||||||
*
|
*
|
||||||
* Code commit statistics can be found here: https://github.com/ArduPilot/ardupilot/graphs/contributors
|
* Code commit statistics can be found here: https://github.com/ArduPilot/ardupilot/graphs/contributors
|
||||||
|
@ -37,7 +37,7 @@ Copter::Copter(void) :
|
|||||||
guided_mode(Guided_TakeOff),
|
guided_mode(Guided_TakeOff),
|
||||||
rtl_state(RTL_InitialClimb),
|
rtl_state(RTL_InitialClimb),
|
||||||
rtl_state_complete(false),
|
rtl_state_complete(false),
|
||||||
smart_rtl_state(SafeRTL_PathFollow),
|
smart_rtl_state(SmartRTL_PathFollow),
|
||||||
circle_pilot_yaw_override(false),
|
circle_pilot_yaw_override(false),
|
||||||
simple_cos_yaw(1.0f),
|
simple_cos_yaw(1.0f),
|
||||||
simple_sin_yaw(0.0f),
|
simple_sin_yaw(0.0f),
|
||||||
|
@ -414,8 +414,8 @@ private:
|
|||||||
bool terrain_used;
|
bool terrain_used;
|
||||||
} rtl_path;
|
} rtl_path;
|
||||||
|
|
||||||
// SafeRTL
|
// SmartRTL
|
||||||
SafeRTLState smart_rtl_state; // records state of SafeRTL
|
SmartRTLState smart_rtl_state; // records state of SmartRTL
|
||||||
|
|
||||||
// Circle
|
// Circle
|
||||||
bool circle_pilot_yaw_override; // true if pilot is overriding yaw
|
bool circle_pilot_yaw_override; // true if pilot is overriding yaw
|
||||||
|
@ -389,42 +389,42 @@ const AP_Param::Info Copter::var_info[] = {
|
|||||||
// @Param: CH7_OPT
|
// @Param: CH7_OPT
|
||||||
// @DisplayName: Channel 7 option
|
// @DisplayName: Channel 7 option
|
||||||
// @Description: Select which function is performed when CH7 is above 1800 pwm
|
// @Description: Select which function is performed when CH7 is above 1800 pwm
|
||||||
// @Values: 0:Do Nothing, 2:Flip, 3:Simple Mode, 4:RTL, 5:Save Trim, 7:Save WP, 9:Camera Trigger, 10:RangeFinder, 11:Fence, 13:Super Simple Mode, 14:Acro Trainer, 15:Sprayer, 16:Auto, 17:AutoTune, 18:Land, 19:Gripper, 21:Parachute Enable, 22:Parachute Release, 23:Parachute 3pos, 24:Auto Mission Reset, 25:AttCon Feed Forward, 26:AttCon Accel Limits, 27:Retract Mount, 28:Relay On/Off, 34:Relay2 On/Off, 35:Relay3 On/Off, 36:Relay4 On/Off, 29:Landing Gear, 30:Lost Copter Sound, 31:Motor Emergency Stop, 32:Motor Interlock, 33:Brake, 37:Throw, 38:ADSB-Avoidance, 39:PrecLoiter, 40:Object Avoidance, 41:ArmDisarm, 52:SafeRTL
|
// @Values: 0:Do Nothing, 2:Flip, 3:Simple Mode, 4:RTL, 5:Save Trim, 7:Save WP, 9:Camera Trigger, 10:RangeFinder, 11:Fence, 13:Super Simple Mode, 14:Acro Trainer, 15:Sprayer, 16:Auto, 17:AutoTune, 18:Land, 19:Gripper, 21:Parachute Enable, 22:Parachute Release, 23:Parachute 3pos, 24:Auto Mission Reset, 25:AttCon Feed Forward, 26:AttCon Accel Limits, 27:Retract Mount, 28:Relay On/Off, 34:Relay2 On/Off, 35:Relay3 On/Off, 36:Relay4 On/Off, 29:Landing Gear, 30:Lost Copter Sound, 31:Motor Emergency Stop, 32:Motor Interlock, 33:Brake, 37:Throw, 38:ADSB-Avoidance, 39:PrecLoiter, 40:Object Avoidance, 41:ArmDisarm, 42:SmartRTL
|
||||||
// @User: Standard
|
// @User: Standard
|
||||||
GSCALAR(ch7_option, "CH7_OPT", AUXSW_DO_NOTHING),
|
GSCALAR(ch7_option, "CH7_OPT", AUXSW_DO_NOTHING),
|
||||||
|
|
||||||
// @Param: CH8_OPT
|
// @Param: CH8_OPT
|
||||||
// @DisplayName: Channel 8 option
|
// @DisplayName: Channel 8 option
|
||||||
// @Description: Select which function is performed when CH8 is above 1800 pwm
|
// @Description: Select which function is performed when CH8 is above 1800 pwm
|
||||||
// @Values: 0:Do Nothing, 2:Flip, 3:Simple Mode, 4:RTL, 5:Save Trim, 7:Save WP, 9:Camera Trigger, 10:RangeFinder, 11:Fence, 13:Super Simple Mode, 14:Acro Trainer, 15:Sprayer, 16:Auto, 17:AutoTune, 18:Land, 19:Gripper, 21:Parachute Enable, 22:Parachute Release, 23:Parachute 3pos, 24:Auto Mission Reset, 25:AttCon Feed Forward, 26:AttCon Accel Limits, 27:Retract Mount, 28:Relay On/Off, 34:Relay2 On/Off, 35:Relay3 On/Off, 36:Relay4 On/Off, 29:Landing Gear, 30:Lost Copter Sound, 31:Motor Emergency Stop, 32:Motor Interlock, 33:Brake, 37:Throw, 38:ADSB-Avoidance, 39:PrecLoiter, 40:Object Avoidance, 41:ArmDisarm, 52:SafeRTL
|
// @Values: 0:Do Nothing, 2:Flip, 3:Simple Mode, 4:RTL, 5:Save Trim, 7:Save WP, 9:Camera Trigger, 10:RangeFinder, 11:Fence, 13:Super Simple Mode, 14:Acro Trainer, 15:Sprayer, 16:Auto, 17:AutoTune, 18:Land, 19:Gripper, 21:Parachute Enable, 22:Parachute Release, 23:Parachute 3pos, 24:Auto Mission Reset, 25:AttCon Feed Forward, 26:AttCon Accel Limits, 27:Retract Mount, 28:Relay On/Off, 34:Relay2 On/Off, 35:Relay3 On/Off, 36:Relay4 On/Off, 29:Landing Gear, 30:Lost Copter Sound, 31:Motor Emergency Stop, 32:Motor Interlock, 33:Brake, 37:Throw, 38:ADSB-Avoidance, 39:PrecLoiter, 40:Object Avoidance, 41:ArmDisarm, 42:SmartRTL
|
||||||
// @User: Standard
|
// @User: Standard
|
||||||
GSCALAR(ch8_option, "CH8_OPT", AUXSW_DO_NOTHING),
|
GSCALAR(ch8_option, "CH8_OPT", AUXSW_DO_NOTHING),
|
||||||
|
|
||||||
// @Param: CH9_OPT
|
// @Param: CH9_OPT
|
||||||
// @DisplayName: Channel 9 option
|
// @DisplayName: Channel 9 option
|
||||||
// @Description: Select which function is performed when CH9 is above 1800 pwm
|
// @Description: Select which function is performed when CH9 is above 1800 pwm
|
||||||
// @Values: 0:Do Nothing, 2:Flip, 3:Simple Mode, 4:RTL, 5:Save Trim, 7:Save WP, 9:Camera Trigger, 10:RangeFinder, 11:Fence, 13:Super Simple Mode, 14:Acro Trainer, 15:Sprayer, 16:Auto, 17:AutoTune, 18:Land, 19:Gripper, 21:Parachute Enable, 22:Parachute Release, 23:Parachute 3pos, 24:Auto Mission Reset, 25:AttCon Feed Forward, 26:AttCon Accel Limits, 27:Retract Mount, 28:Relay On/Off, 34:Relay2 On/Off, 35:Relay3 On/Off, 36:Relay4 On/Off, 29:Landing Gear, 30:Lost Copter Sound, 31:Motor Emergency Stop, 32:Motor Interlock, 33:Brake, 37:Throw, 38:ADSB-Avoidance, 39:PrecLoiter, 40:Object Avoidance, 41:ArmDisarm, 52:SafeRTL
|
// @Values: 0:Do Nothing, 2:Flip, 3:Simple Mode, 4:RTL, 5:Save Trim, 7:Save WP, 9:Camera Trigger, 10:RangeFinder, 11:Fence, 13:Super Simple Mode, 14:Acro Trainer, 15:Sprayer, 16:Auto, 17:AutoTune, 18:Land, 19:Gripper, 21:Parachute Enable, 22:Parachute Release, 23:Parachute 3pos, 24:Auto Mission Reset, 25:AttCon Feed Forward, 26:AttCon Accel Limits, 27:Retract Mount, 28:Relay On/Off, 34:Relay2 On/Off, 35:Relay3 On/Off, 36:Relay4 On/Off, 29:Landing Gear, 30:Lost Copter Sound, 31:Motor Emergency Stop, 32:Motor Interlock, 33:Brake, 37:Throw, 38:ADSB-Avoidance, 39:PrecLoiter, 40:Object Avoidance, 41:ArmDisarm, 42:SmartRTL
|
||||||
// @User: Standard
|
// @User: Standard
|
||||||
GSCALAR(ch9_option, "CH9_OPT", AUXSW_DO_NOTHING),
|
GSCALAR(ch9_option, "CH9_OPT", AUXSW_DO_NOTHING),
|
||||||
|
|
||||||
// @Param: CH10_OPT
|
// @Param: CH10_OPT
|
||||||
// @DisplayName: Channel 10 option
|
// @DisplayName: Channel 10 option
|
||||||
// @Description: Select which function is performed when CH10 is above 1800 pwm
|
// @Description: Select which function is performed when CH10 is above 1800 pwm
|
||||||
// @Values: 0:Do Nothing, 2:Flip, 3:Simple Mode, 4:RTL, 5:Save Trim, 7:Save WP, 9:Camera Trigger, 10:RangeFinder, 11:Fence, 13:Super Simple Mode, 14:Acro Trainer, 15:Sprayer, 16:Auto, 17:AutoTune, 18:Land, 19:Gripper, 21:Parachute Enable, 22:Parachute Release, 23:Parachute 3pos, 24:Auto Mission Reset, 25:AttCon Feed Forward, 26:AttCon Accel Limits, 27:Retract Mount, 28:Relay On/Off, 34:Relay2 On/Off, 35:Relay3 On/Off, 36:Relay4 On/Off, 29:Landing Gear, 30:Lost Copter Sound, 31:Motor Emergency Stop, 32:Motor Interlock, 33:Brake, 37:Throw, 38:ADSB-Avoidance, 39:PrecLoiter, 40:Object Avoidance, 41:ArmDisarm, 52:SafeRTL
|
// @Values: 0:Do Nothing, 2:Flip, 3:Simple Mode, 4:RTL, 5:Save Trim, 7:Save WP, 9:Camera Trigger, 10:RangeFinder, 11:Fence, 13:Super Simple Mode, 14:Acro Trainer, 15:Sprayer, 16:Auto, 17:AutoTune, 18:Land, 19:Gripper, 21:Parachute Enable, 22:Parachute Release, 23:Parachute 3pos, 24:Auto Mission Reset, 25:AttCon Feed Forward, 26:AttCon Accel Limits, 27:Retract Mount, 28:Relay On/Off, 34:Relay2 On/Off, 35:Relay3 On/Off, 36:Relay4 On/Off, 29:Landing Gear, 30:Lost Copter Sound, 31:Motor Emergency Stop, 32:Motor Interlock, 33:Brake, 37:Throw, 38:ADSB-Avoidance, 39:PrecLoiter, 40:Object Avoidance, 41:ArmDisarm, 42:SmartRTL
|
||||||
// @User: Standard
|
// @User: Standard
|
||||||
GSCALAR(ch10_option, "CH10_OPT", AUXSW_DO_NOTHING),
|
GSCALAR(ch10_option, "CH10_OPT", AUXSW_DO_NOTHING),
|
||||||
|
|
||||||
// @Param: CH11_OPT
|
// @Param: CH11_OPT
|
||||||
// @DisplayName: Channel 11 option
|
// @DisplayName: Channel 11 option
|
||||||
// @Description: Select which function is performed when CH11 is above 1800 pwm
|
// @Description: Select which function is performed when CH11 is above 1800 pwm
|
||||||
// @Values: 0:Do Nothing, 2:Flip, 3:Simple Mode, 4:RTL, 5:Save Trim, 7:Save WP, 9:Camera Trigger, 10:RangeFinder, 11:Fence, 13:Super Simple Mode, 14:Acro Trainer, 15:Sprayer, 16:Auto, 17:AutoTune, 18:Land, 19:Gripper, 21:Parachute Enable, 22:Parachute Release, 23:Parachute 3pos, 24:Auto Mission Reset, 25:AttCon Feed Forward, 26:AttCon Accel Limits, 27:Retract Mount, 28:Relay On/Off, 34:Relay2 On/Off, 35:Relay3 On/Off, 36:Relay4 On/Off, 29:Landing Gear, 30:Lost Copter Sound, 31:Motor Emergency Stop, 32:Motor Interlock, 33:Brake, 37:Throw, 38:ADSB-Avoidance, 39:PrecLoiter, 40:Object Avoidance, 41:ArmDisarm, 52:SafeRTL
|
// @Values: 0:Do Nothing, 2:Flip, 3:Simple Mode, 4:RTL, 5:Save Trim, 7:Save WP, 9:Camera Trigger, 10:RangeFinder, 11:Fence, 13:Super Simple Mode, 14:Acro Trainer, 15:Sprayer, 16:Auto, 17:AutoTune, 18:Land, 19:Gripper, 21:Parachute Enable, 22:Parachute Release, 23:Parachute 3pos, 24:Auto Mission Reset, 25:AttCon Feed Forward, 26:AttCon Accel Limits, 27:Retract Mount, 28:Relay On/Off, 34:Relay2 On/Off, 35:Relay3 On/Off, 36:Relay4 On/Off, 29:Landing Gear, 30:Lost Copter Sound, 31:Motor Emergency Stop, 32:Motor Interlock, 33:Brake, 37:Throw, 38:ADSB-Avoidance, 39:PrecLoiter, 40:Object Avoidance, 41:ArmDisarm, 42:SmartRTL
|
||||||
// @User: Standard
|
// @User: Standard
|
||||||
GSCALAR(ch11_option, "CH11_OPT", AUXSW_DO_NOTHING),
|
GSCALAR(ch11_option, "CH11_OPT", AUXSW_DO_NOTHING),
|
||||||
|
|
||||||
// @Param: CH12_OPT
|
// @Param: CH12_OPT
|
||||||
// @DisplayName: Channel 12 option
|
// @DisplayName: Channel 12 option
|
||||||
// @Description: Select which function is performed when CH12 is above 1800 pwm
|
// @Description: Select which function is performed when CH12 is above 1800 pwm
|
||||||
// @Values: 0:Do Nothing, 2:Flip, 3:Simple Mode, 4:RTL, 5:Save Trim, 7:Save WP, 9:Camera Trigger, 10:RangeFinder, 11:Fence, 13:Super Simple Mode, 14:Acro Trainer, 15:Sprayer, 16:Auto, 17:AutoTune, 18:Land, 19:Gripper, 21:Parachute Enable, 22:Parachute Release, 23:Parachute 3pos, 24:Auto Mission Reset, 25:AttCon Feed Forward, 26:AttCon Accel Limits, 27:Retract Mount, 28:Relay On/Off, 34:Relay2 On/Off, 35:Relay3 On/Off, 36:Relay4 On/Off, 29:Landing Gear, 30:Lost Copter Sound, 31:Motor Emergency Stop, 32:Motor Interlock, 33:Brake, 37:Throw, 38:ADSB-Avoidance, 39:PrecLoiter, 40:Object Avoidance, 41:ArmDisarm, 52:SafeRTL
|
// @Values: 0:Do Nothing, 2:Flip, 3:Simple Mode, 4:RTL, 5:Save Trim, 7:Save WP, 9:Camera Trigger, 10:RangeFinder, 11:Fence, 13:Super Simple Mode, 14:Acro Trainer, 15:Sprayer, 16:Auto, 17:AutoTune, 18:Land, 19:Gripper, 21:Parachute Enable, 22:Parachute Release, 23:Parachute 3pos, 24:Auto Mission Reset, 25:AttCon Feed Forward, 26:AttCon Accel Limits, 27:Retract Mount, 28:Relay On/Off, 34:Relay2 On/Off, 35:Relay3 On/Off, 36:Relay4 On/Off, 29:Landing Gear, 30:Lost Copter Sound, 31:Motor Emergency Stop, 32:Motor Interlock, 33:Brake, 37:Throw, 38:ADSB-Avoidance, 39:PrecLoiter, 40:Object Avoidance, 41:ArmDisarm, 42:SmartRTL
|
||||||
// @User: Standard
|
// @User: Standard
|
||||||
GSCALAR(ch12_option, "CH12_OPT", AUXSW_DO_NOTHING),
|
GSCALAR(ch12_option, "CH12_OPT", AUXSW_DO_NOTHING),
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
/*
|
/*
|
||||||
* Init and run calls for Smart_RTL flight mode
|
* Init and run calls for Smart_RTL flight mode
|
||||||
*
|
*
|
||||||
* This code uses the SafeRTL path that is already in memory, and feeds it into WPNav, one point at a time.
|
* This code uses the SmartRTL path that is already in memory, and feeds it into WPNav, one point at a time.
|
||||||
* Once the copter is close to home, it will run a standard land controller.
|
* Once the copter is close to home, it will run a standard land controller.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -23,7 +23,7 @@ bool Copter::smart_rtl_init(bool ignore_checks)
|
|||||||
set_auto_yaw_mode(get_default_auto_yaw_mode(true));
|
set_auto_yaw_mode(get_default_auto_yaw_mode(true));
|
||||||
|
|
||||||
// wait for cleanup of return path
|
// wait for cleanup of return path
|
||||||
smart_rtl_state = SafeRTL_WaitForPathCleanup;
|
smart_rtl_state = SmartRTL_WaitForPathCleanup;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -39,19 +39,19 @@ void Copter::smart_rtl_exit()
|
|||||||
void Copter::smart_rtl_run()
|
void Copter::smart_rtl_run()
|
||||||
{
|
{
|
||||||
switch (smart_rtl_state) {
|
switch (smart_rtl_state) {
|
||||||
case SafeRTL_WaitForPathCleanup:
|
case SmartRTL_WaitForPathCleanup:
|
||||||
smart_rtl_wait_cleanup_run();
|
smart_rtl_wait_cleanup_run();
|
||||||
break;
|
break;
|
||||||
case SafeRTL_PathFollow:
|
case SmartRTL_PathFollow:
|
||||||
smart_rtl_path_follow_run();
|
smart_rtl_path_follow_run();
|
||||||
break;
|
break;
|
||||||
case SafeRTL_PreLandPosition:
|
case SmartRTL_PreLandPosition:
|
||||||
smart_rtl_pre_land_position_run();
|
smart_rtl_pre_land_position_run();
|
||||||
break;
|
break;
|
||||||
case SafeRTL_Descend:
|
case SmartRTL_Descend:
|
||||||
rtl_descent_run(); // Re-using the descend method from normal rtl mode.
|
rtl_descent_run(); // Re-using the descend method from normal rtl mode.
|
||||||
break;
|
break;
|
||||||
case SafeRTL_Land:
|
case SmartRTL_Land:
|
||||||
rtl_land_run(); // Re-using the land method from normal rtl mode.
|
rtl_land_run(); // Re-using the land method from normal rtl mode.
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -67,7 +67,7 @@ void Copter::smart_rtl_wait_cleanup_run()
|
|||||||
|
|
||||||
// check if return path is computed and if yes, begin journey home
|
// check if return path is computed and if yes, begin journey home
|
||||||
if (g2.smart_rtl.request_thorough_cleanup()) {
|
if (g2.smart_rtl.request_thorough_cleanup()) {
|
||||||
smart_rtl_state = SafeRTL_PathFollow;
|
smart_rtl_state = SmartRTL_PathFollow;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -81,7 +81,7 @@ void Copter::smart_rtl_path_follow_run()
|
|||||||
if (g2.smart_rtl.get_num_points() == 0) {
|
if (g2.smart_rtl.get_num_points() == 0) {
|
||||||
// this is the very last point, add 2m to the target alt and move to pre-land state
|
// this is the very last point, add 2m to the target alt and move to pre-land state
|
||||||
next_point.z -= 2.0f;
|
next_point.z -= 2.0f;
|
||||||
smart_rtl_state = SafeRTL_PreLandPosition;
|
smart_rtl_state = SmartRTL_PreLandPosition;
|
||||||
fast_waypoint = false;
|
fast_waypoint = false;
|
||||||
}
|
}
|
||||||
// send target to waypoint controller
|
// send target to waypoint controller
|
||||||
@ -89,7 +89,7 @@ void Copter::smart_rtl_path_follow_run()
|
|||||||
wp_nav->set_fast_waypoint(fast_waypoint);
|
wp_nav->set_fast_waypoint(fast_waypoint);
|
||||||
} else {
|
} else {
|
||||||
// this can only happen if we fail to get the semaphore which should never happen but just in case, land
|
// this can only happen if we fail to get the semaphore which should never happen but just in case, land
|
||||||
smart_rtl_state = SafeRTL_PreLandPosition;
|
smart_rtl_state = SmartRTL_PreLandPosition;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -115,11 +115,11 @@ void Copter::smart_rtl_pre_land_position_run()
|
|||||||
// choose descend and hold, or land based on user parameter rtl_alt_final
|
// choose descend and hold, or land based on user parameter rtl_alt_final
|
||||||
if (g.rtl_alt_final <= 0 || failsafe.radio) {
|
if (g.rtl_alt_final <= 0 || failsafe.radio) {
|
||||||
rtl_land_start();
|
rtl_land_start();
|
||||||
smart_rtl_state = SafeRTL_Land;
|
smart_rtl_state = SmartRTL_Land;
|
||||||
} else {
|
} else {
|
||||||
rtl_path.descent_target.alt = g.rtl_alt_final;
|
rtl_path.descent_target.alt = g.rtl_alt_final;
|
||||||
rtl_descent_start();
|
rtl_descent_start();
|
||||||
smart_rtl_state = SafeRTL_Descend;
|
smart_rtl_state = SmartRTL_Descend;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -70,7 +70,7 @@ enum aux_sw_func {
|
|||||||
AUXSW_PRECISION_LOITER = 39, // enable precision loiter
|
AUXSW_PRECISION_LOITER = 39, // enable precision loiter
|
||||||
AUXSW_AVOID_PROXIMITY = 40, // enable object avoidance using proximity sensors (ie. horizontal lidar)
|
AUXSW_AVOID_PROXIMITY = 40, // enable object avoidance using proximity sensors (ie. horizontal lidar)
|
||||||
AUXSW_ARMDISARM = 41, // arm or disarm vehicle
|
AUXSW_ARMDISARM = 41, // arm or disarm vehicle
|
||||||
AUXSW_SMART_RTL = 42, // change to SafeRTL flight mode
|
AUXSW_SMART_RTL = 42, // change to SmartRTL flight mode
|
||||||
AUXSW_SWITCH_MAX,
|
AUXSW_SWITCH_MAX,
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -222,12 +222,12 @@ enum RTLState {
|
|||||||
};
|
};
|
||||||
|
|
||||||
// Safe RTL states
|
// Safe RTL states
|
||||||
enum SafeRTLState {
|
enum SmartRTLState {
|
||||||
SafeRTL_WaitForPathCleanup,
|
SmartRTL_WaitForPathCleanup,
|
||||||
SafeRTL_PathFollow,
|
SmartRTL_PathFollow,
|
||||||
SafeRTL_PreLandPosition,
|
SmartRTL_PreLandPosition,
|
||||||
SafeRTL_Descend,
|
SmartRTL_Descend,
|
||||||
SafeRTL_Land
|
SmartRTL_Land
|
||||||
};
|
};
|
||||||
|
|
||||||
// Alt_Hold states
|
// Alt_Hold states
|
||||||
|
@ -179,7 +179,7 @@ bool Copter::init_arm_motors(bool arming_from_gcs)
|
|||||||
}
|
}
|
||||||
calc_distance_and_bearing();
|
calc_distance_and_bearing();
|
||||||
|
|
||||||
// Reset SafeRTL return location. If activated, SafeRTL will ultimately try to land at this point
|
// Reset SmartRTL return location. If activated, SmartRTL will ultimately try to land at this point
|
||||||
g2.smart_rtl.reset_path(position_ok());
|
g2.smart_rtl.reset_path(position_ok());
|
||||||
|
|
||||||
// enable gps velocity based centrefugal force compensation
|
// enable gps velocity based centrefugal force compensation
|
||||||
|
@ -597,7 +597,7 @@ void Copter::do_aux_switch_function(int8_t ch_function, uint8_t ch_flag)
|
|||||||
|
|
||||||
case AUXSW_SMART_RTL:
|
case AUXSW_SMART_RTL:
|
||||||
if (ch_flag == AUX_SWITCH_HIGH) {
|
if (ch_flag == AUX_SWITCH_HIGH) {
|
||||||
// engage SafeRTL (if not possible we remain in current flight mode)
|
// engage SmartRTL (if not possible we remain in current flight mode)
|
||||||
set_mode(SMART_RTL, MODE_REASON_TX_COMMAND);
|
set_mode(SMART_RTL, MODE_REASON_TX_COMMAND);
|
||||||
} else {
|
} else {
|
||||||
// return to flight mode switch's flight mode if we are currently in RTL
|
// return to flight mode switch's flight mode if we are currently in RTL
|
||||||
|
@ -228,7 +228,7 @@ void Copter::init_ardupilot()
|
|||||||
// initialise mission library
|
// initialise mission library
|
||||||
mission.init();
|
mission.init();
|
||||||
|
|
||||||
// initialize SafeRTL
|
// initialize SmartRTL
|
||||||
g2.smart_rtl.init();
|
g2.smart_rtl.init();
|
||||||
|
|
||||||
// initialise DataFlash library
|
// initialise DataFlash library
|
||||||
|
Loading…
Reference in New Issue
Block a user