Plane: Fix before squash

This commit is contained in:
Leonard Hall 2021-05-19 23:38:14 +09:30 committed by Andrew Tridgell
parent e294991b08
commit 8b3b6cf693
2 changed files with 27 additions and 27 deletions

View File

@ -41,6 +41,7 @@ void QAutoTune::get_pilot_desired_rp_yrate_cd(float &des_roll_cd, float &des_pit
void QAutoTune::init_z_limits() void QAutoTune::init_z_limits()
{ {
// set vertical speed and acceleration limits
plane.quadplane.pos_control->set_max_speed_accel_z(-plane.quadplane.get_pilot_velocity_z_max_dn(), plane.quadplane.pos_control->set_max_speed_accel_z(-plane.quadplane.get_pilot_velocity_z_max_dn(),
plane.quadplane.pilot_velocity_z_max_up, plane.quadplane.pilot_velocity_z_max_up,
plane.quadplane.pilot_accel_z); plane.quadplane.pilot_accel_z);

View File

@ -1080,15 +1080,14 @@ void QuadPlane::run_z_controller(void)
{ {
const uint32_t now = AP_HAL::millis(); const uint32_t now = AP_HAL::millis();
if (!pos_control->is_active_z()) { if (!pos_control->is_active_z()) {
// initialize vertical maximum speeds and acceleration // set vertical speed and acceleration limits
pos_control->set_max_speed_accel_z(-get_pilot_velocity_z_max_dn(), pilot_velocity_z_max_up, pilot_accel_z); pos_control->set_max_speed_accel_z(-get_pilot_velocity_z_max_dn(), pilot_velocity_z_max_up, pilot_accel_z);
// initialise the vertical position controller
if (!is_tailsitter()) { if (!is_tailsitter()) {
// initialize the Alt Hold controller with no decent
pos_control->init_z_controller(); pos_control->init_z_controller();
} else { } else {
// initialize the Alt Hold controller with no decent // initialise the vertical position controller with no descent
// todo: do we need to add this function just for this?
pos_control->init_z_controller_no_descent(); pos_control->init_z_controller_no_descent();
} }
} }
@ -1131,7 +1130,7 @@ void QuadPlane::init_qacro(void)
// init quadplane hover mode // init quadplane hover mode
void QuadPlane::init_hover(void) void QuadPlane::init_hover(void)
{ {
// initialize vertical maximum speeds and acceleration // set vertical speed and acceleration limits
pos_control->set_max_speed_accel_z(-get_pilot_velocity_z_max_dn(), pilot_velocity_z_max_up, pilot_accel_z); pos_control->set_max_speed_accel_z(-get_pilot_velocity_z_max_dn(), pilot_velocity_z_max_up, pilot_accel_z);
set_climb_rate_cms(0, false); set_climb_rate_cms(0, false);
@ -1169,7 +1168,7 @@ void QuadPlane::hold_hover(float target_climb_rate_cms)
// motors use full range // motors use full range
motors->set_desired_spool_state(AP_Motors::DesiredSpoolState::THROTTLE_UNLIMITED); motors->set_desired_spool_state(AP_Motors::DesiredSpoolState::THROTTLE_UNLIMITED);
// initialize vertical speeds and acceleration // set vertical speed and acceleration limits
pos_control->set_max_speed_accel_z(-get_pilot_velocity_z_max_dn(), pilot_velocity_z_max_up, pilot_accel_z); pos_control->set_max_speed_accel_z(-get_pilot_velocity_z_max_dn(), pilot_velocity_z_max_up, pilot_accel_z);
// call attitude controller // call attitude controller
@ -1318,7 +1317,7 @@ void QuadPlane::init_loiter(void)
loiter_nav->clear_pilot_desired_acceleration(); loiter_nav->clear_pilot_desired_acceleration();
loiter_nav->init_target(); loiter_nav->init_target();
// initialize vertical speed and acceleration // set vertical speed and acceleration limits
pos_control->set_max_speed_accel_z(-get_pilot_velocity_z_max_dn(), pilot_velocity_z_max_up, pilot_accel_z); pos_control->set_max_speed_accel_z(-get_pilot_velocity_z_max_dn(), pilot_velocity_z_max_up, pilot_accel_z);
init_throttle_wait(); init_throttle_wait();
@ -1437,7 +1436,7 @@ float QuadPlane::landing_descent_rate_cms(float height_above_ground) const
if ((options & OPTION_THR_LANDING_CONTROL) != 0) { if ((options & OPTION_THR_LANDING_CONTROL) != 0) {
// allow throttle control for landing speed // allow throttle control for landing speed
float thr_in = get_pilot_land_throttle(); const float thr_in = get_pilot_land_throttle();
const float dz = 0.1; const float dz = 0.1;
const float thresh1 = 0.5+dz; const float thresh1 = 0.5+dz;
const float thresh2 = 0.5-dz; const float thresh2 = 0.5-dz;
@ -1488,7 +1487,7 @@ void QuadPlane::control_loiter()
// motors use full range // motors use full range
motors->set_desired_spool_state(AP_Motors::DesiredSpoolState::THROTTLE_UNLIMITED); motors->set_desired_spool_state(AP_Motors::DesiredSpoolState::THROTTLE_UNLIMITED);
// initialize vertical speed and acceleration // set vertical speed and acceleration limits
pos_control->set_max_speed_accel_z(-get_pilot_velocity_z_max_dn(), pilot_velocity_z_max_up, pilot_accel_z); pos_control->set_max_speed_accel_z(-get_pilot_velocity_z_max_dn(), pilot_velocity_z_max_up, pilot_accel_z);
// process pilot's roll and pitch input // process pilot's roll and pitch input
@ -1513,7 +1512,7 @@ void QuadPlane::control_loiter()
last_pidz_init_ms, last_pidz_init_ms+transition_time_ms*2); last_pidz_init_ms, last_pidz_init_ms+transition_time_ms*2);
if (plane.nav_pitch_cd > pitch_limit_cd) { if (plane.nav_pitch_cd > pitch_limit_cd) {
plane.nav_pitch_cd = pitch_limit_cd; plane.nav_pitch_cd = pitch_limit_cd;
pos_control->set_limit_xy(); pos_control->set_externally_limited_xy();
} }
} }
@ -2525,7 +2524,7 @@ void QuadPlane::update_land_positioning(void)
poscontrol.target_cm += poscontrol.target_vel_cms * dt; poscontrol.target_cm += poscontrol.target_vel_cms * dt;
poscontrol.pilot_correction_active = (fabsf(roll_in) > 0 || fabsf(pitch_in) > 0); poscontrol.pilot_correction_active = (!is_zero(roll_in)|| !is_zero(pitch_in));
if (poscontrol.pilot_correction_active) { if (poscontrol.pilot_correction_active) {
poscontrol.pilot_correction_done = true; poscontrol.pilot_correction_done = true;
} }
@ -2605,14 +2604,13 @@ void QuadPlane::vtol_position_controller(void)
} else { } else {
poscontrol.max_speed = target_speed; poscontrol.max_speed = target_speed;
} }
pos_control->set_vel_desired_xy_cms(target_speed_xy.x*100, pos_control->set_vel_desired_xy_cms(target_speed_xy * 100);
target_speed_xy.y*100);
// reset position controller xy target to current position // reset position controller xy target to current position
// because we only want velocity control (no position control) // because we only want velocity control (no position control)
const Vector3f& curr_pos = inertial_nav.get_position(); const Vector3f& curr_pos = inertial_nav.get_position();
pos_control->set_pos_target_xy_cm(curr_pos.x, curr_pos.y); pos_control->set_pos_target_xy_cm(curr_pos.x, curr_pos.y);
pos_control->set_accel_desired_xy_cmss(0.0f, 0.0f); pos_control->set_accel_desired_xy_cmss(Vector2f());
// run horizontal velocity controller // run horizontal velocity controller
run_xy_controller(); run_xy_controller();
@ -2642,7 +2640,7 @@ void QuadPlane::vtol_position_controller(void)
plane.nav_pitch_cd = pitch_limit_cd; plane.nav_pitch_cd = pitch_limit_cd;
// tell the pos controller we have limited the pitch to // tell the pos controller we have limited the pitch to
// stop integrator buildup // stop integrator buildup
pos_control->set_limit_xy(); pos_control->set_externally_limited_xy();
} }
// call attitude controller // call attitude controller
@ -2665,8 +2663,8 @@ void QuadPlane::vtol_position_controller(void)
for final land repositioning and descent we run the position controller for final land repositioning and descent we run the position controller
*/ */
if (poscontrol.pilot_correction_done) { if (poscontrol.pilot_correction_done) {
// if we have done any repositioning then to handle GPS glitches we need to switch // if the pilot has repositioned the vehicle then we switch to velocity control. This prevents the vehicle
// to velocity control // shifting position in the event of GPS glitches.
Vector3f zero; Vector3f zero;
pos_control->input_vel_accel_xy(poscontrol.target_vel_cms, zero); pos_control->input_vel_accel_xy(poscontrol.target_vel_cms, zero);
} else { } else {
@ -2681,7 +2679,7 @@ void QuadPlane::vtol_position_controller(void)
run_xy_controller(); run_xy_controller();
// nav roll and pitch are controller by position controller // nav roll and pitch are controlled by position controller
plane.nav_roll_cd = pos_control->get_roll_cd(); plane.nav_roll_cd = pos_control->get_roll_cd();
plane.nav_pitch_cd = pos_control->get_pitch_cd(); plane.nav_pitch_cd = pos_control->get_pitch_cd();
@ -2817,7 +2815,7 @@ void QuadPlane::setup_target_position(void)
} }
last_loiter_ms = now; last_loiter_ms = now;
// setup vertical speed and acceleration // set vertical speed and acceleration limits
pos_control->set_max_speed_accel_z(-get_pilot_velocity_z_max_dn(), pilot_velocity_z_max_up, pilot_accel_z); pos_control->set_max_speed_accel_z(-get_pilot_velocity_z_max_dn(), pilot_velocity_z_max_up, pilot_accel_z);
} }
@ -2834,8 +2832,8 @@ void QuadPlane::takeoff_controller(void)
setup_target_position(); setup_target_position();
// set position controller desired velocity and acceleration to zero // set position controller desired velocity and acceleration to zero
pos_control->set_vel_desired_xy_cms(0.0f,0.0f); pos_control->set_vel_desired_xy_cms(Vector2f());
pos_control->set_accel_desired_xy_cmss(0.0f,0.0f); pos_control->set_accel_desired_xy_cmss(Vector2f());
// set position control target and update // set position control target and update
Vector3f zero; Vector3f zero;
@ -2945,7 +2943,7 @@ void QuadPlane::init_qrtl(void)
plane.prev_WP_loc = plane.current_loc; plane.prev_WP_loc = plane.current_loc;
poscontrol.state = QPOS_POSITION1; poscontrol.state = QPOS_POSITION1;
poscontrol.speed_scale = 0; poscontrol.speed_scale = 0;
pos_control->set_accel_desired_xy_cmss(0.0f, 0.0f); pos_control->set_accel_desired_xy_cmss(Vector2f());
pos_control->init_xy_controller(); pos_control->init_xy_controller();
int32_t from_alt; int32_t from_alt;
int32_t to_alt; int32_t to_alt;
@ -2983,10 +2981,10 @@ bool QuadPlane::do_vtol_takeoff(const AP_Mission::Mission_Command& cmd)
} }
throttle_wait = false; throttle_wait = false;
// initialize vertical speed and acceleration // set vertical speed and acceleration limits
pos_control->set_max_speed_accel_z(-get_pilot_velocity_z_max_dn(), pilot_velocity_z_max_up, pilot_accel_z); pos_control->set_max_speed_accel_z(-get_pilot_velocity_z_max_dn(), pilot_velocity_z_max_up, pilot_accel_z);
// initialize the Alt Hold controller with no decent // initialise the vertical position controller
pos_control->init_z_controller(); pos_control->init_z_controller();
// also update nav_controller for status output // also update nav_controller for status output
@ -3034,6 +3032,7 @@ bool QuadPlane::do_vtol_land(const AP_Mission::Mission_Command& cmd)
poscontrol.state = QPOS_POSITION1; poscontrol.state = QPOS_POSITION1;
poscontrol.speed_scale = 0; poscontrol.speed_scale = 0;
// initialise the position controller
pos_control->init_xy_controller(); pos_control->init_xy_controller();
pos_control->init_z_controller(); pos_control->init_z_controller();
@ -3656,7 +3655,7 @@ void QuadPlane::update_throttle_mix(void)
// check for large acceleration - falling or high turbulence // check for large acceleration - falling or high turbulence
bool accel_moving = (throttle_mix_accel_ef_filter.get().length() > LAND_CHECK_ACCEL_MOVING); bool accel_moving = (throttle_mix_accel_ef_filter.get().length() > LAND_CHECK_ACCEL_MOVING);
// check for requested decent // check for requested descent
bool descent_not_demanded = pos_control->get_vel_desired_cms().z >= 0.0f; bool descent_not_demanded = pos_control->get_vel_desired_cms().z >= 0.0f;
if (large_angle_request || large_angle_error || accel_moving || descent_not_demanded) { if (large_angle_request || large_angle_error || accel_moving || descent_not_demanded) {