AC_AutoTune: fix pilot testing bug
This commit is contained in:
parent
5eede68dce
commit
5780fac5fe
@ -198,29 +198,32 @@ void AC_AutoTune::run()
|
|||||||
const bool zero_rp_input = is_zero(target_roll_cd) && is_zero(target_pitch_cd);
|
const bool zero_rp_input = is_zero(target_roll_cd) && is_zero(target_pitch_cd);
|
||||||
|
|
||||||
const uint32_t now = AP_HAL::millis();
|
const uint32_t now = AP_HAL::millis();
|
||||||
if (!zero_rp_input || !is_zero(target_yaw_rate_cds) || !is_zero(target_climb_rate_cms)) {
|
|
||||||
if (!pilot_override) {
|
if (mode != SUCCESS) {
|
||||||
pilot_override = true;
|
if (!zero_rp_input || !is_zero(target_yaw_rate_cds) || !is_zero(target_climb_rate_cms)) {
|
||||||
// set gains to their original values
|
if (!pilot_override) {
|
||||||
load_gains(GAIN_ORIGINAL);
|
pilot_override = true;
|
||||||
attitude_control->use_sqrt_controller(true);
|
// set gains to their original values
|
||||||
}
|
load_gains(GAIN_ORIGINAL);
|
||||||
// reset pilot override time
|
attitude_control->use_sqrt_controller(true);
|
||||||
override_time = now;
|
}
|
||||||
if (!zero_rp_input) {
|
// reset pilot override time
|
||||||
// only reset position on roll or pitch input
|
override_time = now;
|
||||||
have_position = false;
|
if (!zero_rp_input) {
|
||||||
}
|
// only reset position on roll or pitch input
|
||||||
} else if (pilot_override) {
|
have_position = false;
|
||||||
// check if we should resume tuning after pilot's override
|
}
|
||||||
if (now - override_time > AUTOTUNE_PILOT_OVERRIDE_TIMEOUT_MS) {
|
} else if (pilot_override) {
|
||||||
pilot_override = false; // turn off pilot override
|
// check if we should resume tuning after pilot's override
|
||||||
// set gains to their intra-test values (which are very close to the original gains)
|
if (now - override_time > AUTOTUNE_PILOT_OVERRIDE_TIMEOUT_MS) {
|
||||||
// load_gains(GAIN_INTRA_TEST); //I think we should be keeping the originals here to let the I term settle quickly
|
pilot_override = false; // turn off pilot override
|
||||||
step = WAITING_FOR_LEVEL; // set tuning step back from beginning
|
// set gains to their intra-test values (which are very close to the original gains)
|
||||||
step_start_time_ms = now;
|
// load_gains(GAIN_INTRA_TEST); //I think we should be keeping the originals here to let the I term settle quickly
|
||||||
level_start_time_ms = now;
|
step = WAITING_FOR_LEVEL; // set tuning step back from beginning
|
||||||
desired_yaw_cd = ahrs_view->yaw_sensor;
|
step_start_time_ms = now;
|
||||||
|
level_start_time_ms = now;
|
||||||
|
desired_yaw_cd = ahrs_view->yaw_sensor;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (pilot_override) {
|
if (pilot_override) {
|
||||||
|
Loading…
Reference in New Issue
Block a user