Copter: fix compilation when fence andd proximity are disabled
This adds AC_AVOID_ENABLED; avoidance must be disabled if either of fence or proximity are disabled. Parameter definitions have been reordered to avoid compiler warnings; this make sthe numbering non-linear
This commit is contained in:
parent
d3e331e1f2
commit
a233024e05
@ -91,7 +91,9 @@ Copter::Copter(void) :
|
|||||||
#if AC_FENCE == ENABLED
|
#if AC_FENCE == ENABLED
|
||||||
fence(ahrs, inertial_nav),
|
fence(ahrs, inertial_nav),
|
||||||
#endif
|
#endif
|
||||||
|
#if AC_AVOID_ENABLED == ENABLED
|
||||||
avoid(ahrs, inertial_nav, fence, g2.proximity),
|
avoid(ahrs, inertial_nav, fence, g2.proximity),
|
||||||
|
#endif
|
||||||
#if AC_RALLY == ENABLED
|
#if AC_RALLY == ENABLED
|
||||||
rally(ahrs),
|
rally(ahrs),
|
||||||
#endif
|
#endif
|
||||||
|
@ -538,8 +538,9 @@ private:
|
|||||||
#if AC_FENCE == ENABLED
|
#if AC_FENCE == ENABLED
|
||||||
AC_Fence fence;
|
AC_Fence fence;
|
||||||
#endif
|
#endif
|
||||||
|
#if AC_AVOID_ENABLED == ENABLED
|
||||||
AC_Avoid avoid;
|
AC_Avoid avoid;
|
||||||
|
#endif
|
||||||
// Rally library
|
// Rally library
|
||||||
#if AC_RALLY == ENABLED
|
#if AC_RALLY == ENABLED
|
||||||
AP_Rally_Copter rally;
|
AP_Rally_Copter rally;
|
||||||
|
@ -820,7 +820,9 @@ 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
|
||||||
GOBJECT(avoid, "AVOID_", AC_Avoid),
|
GOBJECT(avoid, "AVOID_", AC_Avoid),
|
||||||
|
#endif
|
||||||
|
|
||||||
#if AC_RALLY == ENABLED
|
#if AC_RALLY == ENABLED
|
||||||
// @Group: RALLY_
|
// @Group: RALLY_
|
||||||
@ -1001,6 +1003,10 @@ const AP_Param::GroupInfo ParametersG2::var_info[] = {
|
|||||||
// @User: Advanced
|
// @User: Advanced
|
||||||
AP_GROUPINFO("DEV_OPTIONS", 7, ParametersG2, dev_options, 0),
|
AP_GROUPINFO("DEV_OPTIONS", 7, ParametersG2, dev_options, 0),
|
||||||
|
|
||||||
|
// @Group: BCN
|
||||||
|
// @Path: ../libraries/AP_Beacon/AP_Beacon.cpp
|
||||||
|
AP_SUBGROUPINFO(beacon, "BCN", 14, ParametersG2, AP_Beacon),
|
||||||
|
|
||||||
#if PROXIMITY_ENABLED == ENABLED
|
#if PROXIMITY_ENABLED == ENABLED
|
||||||
// @Group: PRX
|
// @Group: PRX
|
||||||
// @Path: ../libraries/AP_Proximity/AP_Proximity.cpp
|
// @Path: ../libraries/AP_Proximity/AP_Proximity.cpp
|
||||||
@ -1039,10 +1045,6 @@ const AP_Param::GroupInfo ParametersG2::var_info[] = {
|
|||||||
AP_SUBGROUPINFO(gripper, "GRIP_", 13, ParametersG2, AP_Gripper),
|
AP_SUBGROUPINFO(gripper, "GRIP_", 13, ParametersG2, AP_Gripper),
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// @Group: BCN
|
|
||||||
// @Path: ../libraries/AP_Beacon/AP_Beacon.cpp
|
|
||||||
AP_SUBGROUPINFO(beacon, "BCN", 14, ParametersG2, AP_Beacon),
|
|
||||||
|
|
||||||
// @Param: FRAME_CLASS
|
// @Param: FRAME_CLASS
|
||||||
// @DisplayName: Frame Class
|
// @DisplayName: Frame Class
|
||||||
// @Description: Controls major frame class for multicopter component
|
// @Description: Controls major frame class for multicopter component
|
||||||
@ -1058,8 +1060,10 @@ const AP_Param::GroupInfo ParametersG2::var_info[] = {
|
|||||||
constructor for g2 object
|
constructor for g2 object
|
||||||
*/
|
*/
|
||||||
ParametersG2::ParametersG2(void)
|
ParametersG2::ParametersG2(void)
|
||||||
: proximity(copter.serial_manager),
|
: beacon(copter.serial_manager)
|
||||||
beacon(copter.serial_manager)
|
#if PROXIMITY_ENABLED == ENABLED
|
||||||
|
, proximity(copter.serial_manager)
|
||||||
|
#endif
|
||||||
#if ADVANCED_FAILSAFE == ENABLED
|
#if ADVANCED_FAILSAFE == ENABLED
|
||||||
,afs(copter.mission, copter.barometer, copter.gps, copter.rcmap)
|
,afs(copter.mission, copter.barometer, copter.gps, copter.rcmap)
|
||||||
#endif
|
#endif
|
||||||
|
@ -635,6 +635,7 @@ bool Copter::pre_arm_proximity_check(bool display_failure)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// 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
|
||||||
float angle_deg, distance;
|
float angle_deg, distance;
|
||||||
if (avoid.proximity_avoidance_enabled() && g2.proximity.get_closest_object(angle_deg, distance)) {
|
if (avoid.proximity_avoidance_enabled() && g2.proximity.get_closest_object(angle_deg, distance)) {
|
||||||
// display error if something is within 60cm
|
// display error if something is within 60cm
|
||||||
@ -645,6 +646,7 @@ bool Copter::pre_arm_proximity_check(bool display_failure)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
#else
|
#else
|
||||||
|
@ -642,7 +642,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////////
|
||||||
// Fence, Rally and Terrain defaults
|
// Fence, Rally and Terrain and AC_Avoidance defaults
|
||||||
//
|
//
|
||||||
|
|
||||||
// Enable/disable Fence
|
// Enable/disable Fence
|
||||||
@ -662,6 +662,17 @@
|
|||||||
#error Terrain relies on Rally which is disabled
|
#error Terrain relies on Rally which is disabled
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef AC_AVOID_ENABLED
|
||||||
|
#define AC_AVOID_ENABLED ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if AC_AVOID_ENABLED && !PROXIMITY_ENABLED
|
||||||
|
#error AC_Avoidance relies on PROXIMITY_ENABLED which is disabled
|
||||||
|
#endif
|
||||||
|
#if AC_AVOID_ENABLED && !AC_FENCE
|
||||||
|
#error AC_Avoidance relies on AC_FENCE which is disabled
|
||||||
|
#endif
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////////
|
||||||
// Developer Items
|
// Developer Items
|
||||||
//
|
//
|
||||||
|
@ -135,8 +135,10 @@ void Copter::althold_run()
|
|||||||
case AltHold_Flying:
|
case AltHold_Flying:
|
||||||
motors.set_desired_spool_state(AP_Motors::DESIRED_THROTTLE_UNLIMITED);
|
motors.set_desired_spool_state(AP_Motors::DESIRED_THROTTLE_UNLIMITED);
|
||||||
|
|
||||||
|
#if AC_AVOID_ENABLED == ENABLED
|
||||||
// apply avoidance
|
// apply avoidance
|
||||||
avoid.adjust_roll_pitch(target_roll, target_pitch, aparm.angle_max);
|
avoid.adjust_roll_pitch(target_roll, target_pitch, aparm.angle_max);
|
||||||
|
#endif
|
||||||
|
|
||||||
// call attitude controller
|
// call attitude controller
|
||||||
attitude_control.input_euler_angle_roll_pitch_euler_rate_yaw(target_roll, target_pitch, target_yaw_rate, get_smoothing_gain());
|
attitude_control.input_euler_angle_roll_pitch_euler_rate_yaw(target_roll, target_pitch, target_yaw_rate, get_smoothing_gain());
|
||||||
|
@ -632,8 +632,10 @@ void Copter::guided_set_desired_velocity_with_accel_and_fence_limits(const Vecto
|
|||||||
float vel_delta_z_max = G_Dt * pos_control.get_accel_z();
|
float vel_delta_z_max = G_Dt * pos_control.get_accel_z();
|
||||||
curr_vel_des.z += constrain_float(vel_delta.z, -vel_delta_z_max, vel_delta_z_max);
|
curr_vel_des.z += constrain_float(vel_delta.z, -vel_delta_z_max, vel_delta_z_max);
|
||||||
|
|
||||||
|
#if AC_AVOID_ENABLED
|
||||||
// limit the velocity to prevent fence violations
|
// limit the velocity to prevent fence violations
|
||||||
avoid.adjust_velocity(pos_control.get_pos_xy_kP(), pos_control.get_accel_xy(), curr_vel_des);
|
avoid.adjust_velocity(pos_control.get_pos_xy_kP(), pos_control.get_accel_xy(), curr_vel_des);
|
||||||
|
#endif
|
||||||
|
|
||||||
// update position controller with new target
|
// update position controller with new target
|
||||||
pos_control.set_desired_velocity(curr_vel_des);
|
pos_control.set_desired_velocity(curr_vel_des);
|
||||||
|
@ -572,7 +572,7 @@ void Copter::do_aux_switch_function(int8_t ch_function, uint8_t ch_flag)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case AUXSW_AVOID_PROXIMITY:
|
case AUXSW_AVOID_PROXIMITY:
|
||||||
#if PROXIMITY_ENABLED == ENABLED
|
#if PROXIMITY_ENABLED == ENABLED && AC_AVOID_ENABLED == ENABLED
|
||||||
switch (ch_flag) {
|
switch (ch_flag) {
|
||||||
case AUX_SWITCH_HIGH:
|
case AUX_SWITCH_HIGH:
|
||||||
avoid.proximity_avoidance_enable(true);
|
avoid.proximity_avoidance_enable(true);
|
||||||
|
@ -210,7 +210,9 @@ void Copter::init_ardupilot()
|
|||||||
Location_Class::set_terrain(&terrain);
|
Location_Class::set_terrain(&terrain);
|
||||||
wp_nav.set_terrain(&terrain);
|
wp_nav.set_terrain(&terrain);
|
||||||
#endif
|
#endif
|
||||||
|
#if AC_AVOID_ENABLED == ENABLED
|
||||||
wp_nav.set_avoidance(&avoid);
|
wp_nav.set_avoidance(&avoid);
|
||||||
|
#endif
|
||||||
|
|
||||||
attitude_control.parameter_sanity_check();
|
attitude_control.parameter_sanity_check();
|
||||||
pos_control.set_dt(MAIN_LOOP_SECONDS);
|
pos_control.set_dt(MAIN_LOOP_SECONDS);
|
||||||
|
Loading…
Reference in New Issue
Block a user