mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-04 23:18:28 -04:00
ArduCopter: move AC_Avoidance defines into libraries
This commit is contained in:
parent
4781938694
commit
cb76ce534b
@ -5,8 +5,6 @@
|
|||||||
//#define MOUNT DISABLED // disable the camera gimbal to save 8K of flash space
|
//#define MOUNT DISABLED // disable the camera gimbal to save 8K of flash space
|
||||||
//#define AUTOTUNE_ENABLED DISABLED // disable the auto tune functionality to save 7k of flash
|
//#define AUTOTUNE_ENABLED DISABLED // disable the auto tune functionality to save 7k of flash
|
||||||
//#define RANGEFINDER_ENABLED DISABLED // disable rangefinder to save 1k of flash
|
//#define RANGEFINDER_ENABLED DISABLED // disable rangefinder to save 1k of flash
|
||||||
//#define AC_AVOID_ENABLED DISABLED // disable stop-at-fence library
|
|
||||||
//#define AC_OAPATHPLANNER_ENABLED DISABLED // disable path planning around obstacles
|
|
||||||
//#define PARACHUTE DISABLED // disable parachute release to save 1k of flash
|
//#define PARACHUTE DISABLED // disable parachute release to save 1k of flash
|
||||||
//#define NAV_GUIDED DISABLED // disable external navigation computer ability to control vehicle through MAV_CMD_NAV_GUIDED mission commands
|
//#define NAV_GUIDED DISABLED // disable external navigation computer ability to control vehicle through MAV_CMD_NAV_GUIDED mission commands
|
||||||
//#define MODE_ACRO_ENABLED DISABLED // disable acrobatic mode support
|
//#define MODE_ACRO_ENABLED DISABLED // disable acrobatic mode support
|
||||||
|
@ -299,7 +299,7 @@ bool AP_Arming_Copter::parameter_checks(bool display_failure)
|
|||||||
|
|
||||||
bool AP_Arming_Copter::oa_checks(bool display_failure)
|
bool AP_Arming_Copter::oa_checks(bool display_failure)
|
||||||
{
|
{
|
||||||
#if AC_OAPATHPLANNER_ENABLED == ENABLED
|
#if AP_OAPATHPLANNER_ENABLED
|
||||||
char failure_msg[50] = {};
|
char failure_msg[50] = {};
|
||||||
if (copter.g2.oa.pre_arm_check(failure_msg, ARRAY_SIZE(failure_msg))) {
|
if (copter.g2.oa.pre_arm_check(failure_msg, ARRAY_SIZE(failure_msg))) {
|
||||||
return true;
|
return true;
|
||||||
@ -407,7 +407,7 @@ bool AP_Arming_Copter::proximity_checks(bool display_failure) const
|
|||||||
}
|
}
|
||||||
|
|
||||||
// get closest object if we might use it for avoidance
|
// get closest object if we might use it for avoidance
|
||||||
#if AC_AVOID_ENABLED == ENABLED
|
#if AP_AVOIDANCE_ENABLED
|
||||||
float angle_deg, distance;
|
float angle_deg, distance;
|
||||||
if (copter.avoid.proximity_avoidance_enabled() && copter.g2.proximity.get_closest_object(angle_deg, distance)) {
|
if (copter.avoid.proximity_avoidance_enabled() && copter.g2.proximity.get_closest_object(angle_deg, distance)) {
|
||||||
// display error if something is within 60cm
|
// display error if something is within 60cm
|
||||||
|
@ -103,10 +103,10 @@
|
|||||||
#include <AP_Beacon/AP_Beacon.h>
|
#include <AP_Beacon/AP_Beacon.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if AC_AVOID_ENABLED == ENABLED
|
#if AP_AVOIDANCE_ENABLED
|
||||||
#include <AC_Avoidance/AC_Avoid.h>
|
#include <AC_Avoidance/AC_Avoid.h>
|
||||||
#endif
|
#endif
|
||||||
#if AC_OAPATHPLANNER_ENABLED == ENABLED
|
#if AP_OAPATHPLANNER_ENABLED
|
||||||
#include <AC_WPNav/AC_WPNav_OA.h>
|
#include <AC_WPNav/AC_WPNav_OA.h>
|
||||||
#include <AC_Avoidance/AP_OAPathPlanner.h>
|
#include <AC_Avoidance/AP_OAPathPlanner.h>
|
||||||
#endif
|
#endif
|
||||||
@ -155,11 +155,11 @@
|
|||||||
#include <AC_CustomControl/AC_CustomControl.h> // Custom control library
|
#include <AC_CustomControl/AC_CustomControl.h> // Custom control library
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if AC_AVOID_ENABLED && !AP_FENCE_ENABLED
|
#if AP_AVOIDANCE_ENABLED && !AP_FENCE_ENABLED
|
||||||
#error AC_Avoidance relies on AP_FENCE_ENABLED which is disabled
|
#error AC_Avoidance relies on AP_FENCE_ENABLED which is disabled
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if AC_OAPATHPLANNER_ENABLED && !AP_FENCE_ENABLED
|
#if AP_OAPATHPLANNER_ENABLED && !AP_FENCE_ENABLED
|
||||||
#error AP_OAPathPlanner relies on AP_FENCE_ENABLED which is disabled
|
#error AP_OAPathPlanner relies on AP_FENCE_ENABLED which is disabled
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -513,7 +513,7 @@ private:
|
|||||||
AP_Mount camera_mount;
|
AP_Mount camera_mount;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if AC_AVOID_ENABLED == ENABLED
|
#if AP_AVOIDANCE_ENABLED
|
||||||
AC_Avoid avoid;
|
AC_Avoid avoid;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -369,7 +369,7 @@ bool GCS_MAVLINK_Copter::try_send_message(enum ap_message id)
|
|||||||
CHECK_PAYLOAD_SIZE(ADSB_VEHICLE);
|
CHECK_PAYLOAD_SIZE(ADSB_VEHICLE);
|
||||||
copter.adsb.send_adsb_vehicle(chan);
|
copter.adsb.send_adsb_vehicle(chan);
|
||||||
#endif
|
#endif
|
||||||
#if AC_OAPATHPLANNER_ENABLED == ENABLED
|
#if AP_OAPATHPLANNER_ENABLED
|
||||||
AP_OADatabase *oadb = AP_OADatabase::get_singleton();
|
AP_OADatabase *oadb = AP_OADatabase::get_singleton();
|
||||||
if (oadb != nullptr) {
|
if (oadb != nullptr) {
|
||||||
CHECK_PAYLOAD_SIZE(ADSB_VEHICLE);
|
CHECK_PAYLOAD_SIZE(ADSB_VEHICLE);
|
||||||
|
@ -595,7 +595,7 @@ const AP_Param::Info Copter::var_info[] = {
|
|||||||
|
|
||||||
// @Group: AVOID_
|
// @Group: AVOID_
|
||||||
// @Path: ../libraries/AC_Avoidance/AC_Avoid.cpp
|
// @Path: ../libraries/AC_Avoidance/AC_Avoid.cpp
|
||||||
#if AC_AVOID_ENABLED == ENABLED
|
#if AP_AVOIDANCE_ENABLED
|
||||||
GOBJECT(avoid, "AVOID_", AC_Avoid),
|
GOBJECT(avoid, "AVOID_", AC_Avoid),
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -917,7 +917,7 @@ const AP_Param::GroupInfo ParametersG2::var_info[] = {
|
|||||||
// @User: Standard
|
// @User: Standard
|
||||||
AP_GROUPINFO("TUNE_MAX", 32, ParametersG2, tuning_max, 0),
|
AP_GROUPINFO("TUNE_MAX", 32, ParametersG2, tuning_max, 0),
|
||||||
|
|
||||||
#if AC_OAPATHPLANNER_ENABLED == ENABLED
|
#if AP_OAPATHPLANNER_ENABLED
|
||||||
// @Group: OA_
|
// @Group: OA_
|
||||||
// @Path: ../libraries/AC_Avoidance/AP_OAPathPlanner.cpp
|
// @Path: ../libraries/AC_Avoidance/AP_OAPathPlanner.cpp
|
||||||
AP_SUBGROUPINFO(oa, "OA_", 33, ParametersG2, AP_OAPathPlanner),
|
AP_SUBGROUPINFO(oa, "OA_", 33, ParametersG2, AP_OAPathPlanner),
|
||||||
|
@ -595,7 +595,7 @@ public:
|
|||||||
AP_Float tuning_min;
|
AP_Float tuning_min;
|
||||||
AP_Float tuning_max;
|
AP_Float tuning_max;
|
||||||
|
|
||||||
#if AC_OAPATHPLANNER_ENABLED == ENABLED
|
#if AP_OAPATHPLANNER_ENABLED
|
||||||
// object avoidance path planning
|
// object avoidance path planning
|
||||||
AP_OAPathPlanner oa;
|
AP_OAPathPlanner oa;
|
||||||
#endif
|
#endif
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
// check if proximity type Simple Avoidance should be enabled based on alt
|
// check if proximity type Simple Avoidance should be enabled based on alt
|
||||||
void Copter::low_alt_avoidance()
|
void Copter::low_alt_avoidance()
|
||||||
{
|
{
|
||||||
#if AC_AVOID_ENABLED == ENABLED
|
#if AP_AVOIDANCE_ENABLED
|
||||||
int32_t alt_cm;
|
int32_t alt_cm;
|
||||||
if (!get_rangefinder_height_interpolated_cm(alt_cm)) {
|
if (!get_rangefinder_height_interpolated_cm(alt_cm)) {
|
||||||
// enable avoidance if we don't have a valid rangefinder reading
|
// enable avoidance if we don't have a valid rangefinder reading
|
||||||
|
@ -29,7 +29,7 @@
|
|||||||
#include "APM_Config.h"
|
#include "APM_Config.h"
|
||||||
#include <AP_ADSB/AP_ADSB_config.h>
|
#include <AP_ADSB/AP_ADSB_config.h>
|
||||||
#include <AP_Follow/AP_Follow_config.h>
|
#include <AP_Follow/AP_Follow_config.h>
|
||||||
|
#include <AC_Avoidance/AC_Avoidance_config.h>
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////////
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////////
|
||||||
@ -557,16 +557,8 @@
|
|||||||
// Fence, Rally and Terrain and AC_Avoidance defaults
|
// Fence, Rally and Terrain and AC_Avoidance defaults
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef AC_AVOID_ENABLED
|
#if MODE_FOLLOW_ENABLED && !AP_AVOIDANCE_ENABLED
|
||||||
#define AC_AVOID_ENABLED ENABLED
|
#error Follow Mode relies on AP_AVOIDANCE_ENABLED which is disabled
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef AC_OAPATHPLANNER_ENABLED
|
|
||||||
#define AC_OAPATHPLANNER_ENABLED ENABLED
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if MODE_FOLLOW_ENABLED && !AC_AVOID_ENABLED
|
|
||||||
#error Follow Mode relies on AC_AVOID which is disabled
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if MODE_AUTO_ENABLED && !MODE_GUIDED_ENABLED
|
#if MODE_AUTO_ENABLED && !MODE_GUIDED_ENABLED
|
||||||
|
@ -947,7 +947,7 @@ float Mode::get_pilot_desired_throttle() const
|
|||||||
|
|
||||||
float Mode::get_avoidance_adjusted_climbrate(float target_rate)
|
float Mode::get_avoidance_adjusted_climbrate(float target_rate)
|
||||||
{
|
{
|
||||||
#if AC_AVOID_ENABLED == ENABLED
|
#if AP_AVOIDANCE_ENABLED
|
||||||
AP::ac_avoid()->adjust_velocity_z(pos_control->get_pos_z_p().kP(), pos_control->get_max_accel_z_cmss(), target_rate, G_Dt);
|
AP::ac_avoid()->adjust_velocity_z(pos_control->get_pos_z_p().kP(), pos_control->get_max_accel_z_cmss(), target_rate, G_Dt);
|
||||||
return target_rate;
|
return target_rate;
|
||||||
#else
|
#else
|
||||||
|
@ -79,7 +79,7 @@ void ModeAltHold::run()
|
|||||||
case AltHold_Flying:
|
case AltHold_Flying:
|
||||||
motors->set_desired_spool_state(AP_Motors::DesiredSpoolState::THROTTLE_UNLIMITED);
|
motors->set_desired_spool_state(AP_Motors::DesiredSpoolState::THROTTLE_UNLIMITED);
|
||||||
|
|
||||||
#if AC_AVOID_ENABLED == ENABLED
|
#if AP_AVOIDANCE_ENABLED
|
||||||
// apply avoidance
|
// apply avoidance
|
||||||
copter.avoid.adjust_roll_pitch(target_roll, target_pitch, copter.aparm.angle_max);
|
copter.avoid.adjust_roll_pitch(target_roll, target_pitch, copter.aparm.angle_max);
|
||||||
#endif
|
#endif
|
||||||
|
@ -332,7 +332,7 @@ void ModeFlowHold::run()
|
|||||||
bf_angles.x = constrain_float(bf_angles.x, -angle_max, angle_max);
|
bf_angles.x = constrain_float(bf_angles.x, -angle_max, angle_max);
|
||||||
bf_angles.y = constrain_float(bf_angles.y, -angle_max, angle_max);
|
bf_angles.y = constrain_float(bf_angles.y, -angle_max, angle_max);
|
||||||
|
|
||||||
#if AC_AVOID_ENABLED == ENABLED
|
#if AP_AVOIDANCE_ENABLED
|
||||||
// apply avoidance
|
// apply avoidance
|
||||||
copter.avoid.adjust_roll_pitch(bf_angles.x, bf_angles.y, copter.aparm.angle_max);
|
copter.avoid.adjust_roll_pitch(bf_angles.x, bf_angles.y, copter.aparm.angle_max);
|
||||||
#endif
|
#endif
|
||||||
|
@ -10,7 +10,7 @@
|
|||||||
* TODO: "channel 7 option" to lock onto "pointed at" target
|
* TODO: "channel 7 option" to lock onto "pointed at" target
|
||||||
* TODO: do better in terms of loitering around the moving point; may need a PID? Maybe use loiter controller somehow?
|
* TODO: do better in terms of loitering around the moving point; may need a PID? Maybe use loiter controller somehow?
|
||||||
* TODO: extrapolate target vehicle position using its velocity and acceleration
|
* TODO: extrapolate target vehicle position using its velocity and acceleration
|
||||||
* TODO: ensure AC_AVOID_ENABLED is true because we rely on it velocity limiting functions
|
* TODO: ensure AP_AVOIDANCE_ENABLED is true because we rely on it velocity limiting functions
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// initialise follow mode
|
// initialise follow mode
|
||||||
|
@ -800,7 +800,7 @@ void ModeGuided::velaccel_control_run()
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool do_avoid = false;
|
bool do_avoid = false;
|
||||||
#if AC_AVOID_ENABLED
|
#if AP_AVOIDANCE_ENABLED
|
||||||
// limit the velocity for obstacle/fence avoidance
|
// limit the velocity for obstacle/fence avoidance
|
||||||
copter.avoid.adjust_velocity(guided_vel_target_cms, pos_control->get_pos_xy_p().kP(), pos_control->get_max_accel_xy_cmss(), pos_control->get_pos_z_p().kP(), pos_control->get_max_accel_z_cmss(), G_Dt);
|
copter.avoid.adjust_velocity(guided_vel_target_cms, pos_control->get_pos_xy_p().kP(), pos_control->get_max_accel_xy_cmss(), pos_control->get_pos_z_p().kP(), pos_control->get_max_accel_z_cmss(), G_Dt);
|
||||||
do_avoid = copter.avoid.limits_active();
|
do_avoid = copter.avoid.limits_active();
|
||||||
|
@ -93,7 +93,7 @@ void Copter::init_ardupilot()
|
|||||||
airspeed.set_log_bit(MASK_LOG_IMU);
|
airspeed.set_log_bit(MASK_LOG_IMU);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if AC_OAPATHPLANNER_ENABLED == ENABLED
|
#if AP_OAPATHPLANNER_ENABLED
|
||||||
g2.oa.init();
|
g2.oa.init();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -449,7 +449,7 @@ void Copter::allocate_motors(void)
|
|||||||
}
|
}
|
||||||
AP_Param::load_object_from_eeprom(pos_control, pos_control->var_info);
|
AP_Param::load_object_from_eeprom(pos_control, pos_control->var_info);
|
||||||
|
|
||||||
#if AC_OAPATHPLANNER_ENABLED == ENABLED
|
#if AP_OAPATHPLANNER_ENABLED
|
||||||
wp_nav = new AC_WPNav_OA(inertial_nav, *ahrs_view, *pos_control, *attitude_control);
|
wp_nav = new AC_WPNav_OA(inertial_nav, *ahrs_view, *pos_control, *attitude_control);
|
||||||
#else
|
#else
|
||||||
wp_nav = new AC_WPNav(inertial_nav, *ahrs_view, *pos_control, *attitude_control);
|
wp_nav = new AC_WPNav(inertial_nav, *ahrs_view, *pos_control, *attitude_control);
|
||||||
|
Loading…
Reference in New Issue
Block a user