Skip to content

Commit

Permalink
AC_AutoTune_Heli: fix rate and accel limiting
Browse files Browse the repository at this point in the history
  • Loading branch information
bnsgeyer committed Dec 16, 2024
1 parent 2feee53 commit 8c44e56
Showing 1 changed file with 25 additions and 10 deletions.
35 changes: 25 additions & 10 deletions libraries/AC_AutoTune/AC_AutoTune_Heli.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -528,9 +528,9 @@ void AC_AutoTune_Heli::load_test_gains()
rate_test_max = orig_roll_rate;
accel_test_max = tune_roll_accel;
} else {
// have attitude controller use accel and rate limit parameter
rate_test_max = rate_max;
accel_test_max = accel_max;
// have attitude controller not perform rate limiting and angle P scaling based on accel max
rate_test_max = 0.0;
accel_test_max = 0.0;
}
if (tune_type == SP_UP || tune_type == TUNE_CHECK) {
rate_i = tune_roll_rff*AUTOTUNE_FFI_RATIO_FINAL;
Expand All @@ -552,9 +552,9 @@ void AC_AutoTune_Heli::load_test_gains()
rate_test_max = orig_pitch_rate;
accel_test_max = tune_pitch_accel;
} else {
// have attitude controller use accel and rate limit parameter
rate_test_max = rate_max;
accel_test_max = accel_max;
// have attitude controller not perform rate limiting and angle P scaling based on accel max
rate_test_max = 0.0;
accel_test_max = 0.0;
}
if (tune_type == SP_UP || tune_type == TUNE_CHECK) {
rate_i = tune_pitch_rff*AUTOTUNE_FFI_RATIO_FINAL;
Expand All @@ -577,9 +577,9 @@ void AC_AutoTune_Heli::load_test_gains()
rate_test_max = orig_yaw_rate;
accel_test_max = tune_yaw_accel;
} else {
// have attitude controller use accel and rate limit parameter
rate_test_max = rate_max;
accel_test_max = accel_max;
// have attitude controller not perform rate limiting and angle P scaling based on accel max
rate_test_max = 0.0;
accel_test_max = 0.0;
}
if (tune_type == SP_UP || tune_type == TUNE_CHECK) {
rate_i = tune_yaw_rp*AUTOTUNE_YAW_PI_RATIO_FINAL;
Expand Down Expand Up @@ -811,7 +811,22 @@ void AC_AutoTune_Heli::dwell_test_run(sweep_info &test_data)
}

if (settle_time == 0) {
target_angle_cd = -chirp_input.update((now - dwell_start_time_ms) * 0.001, degrees(tgt_attitude) * 100.0f);
dwell_freq = chirp_input.get_frequency_rads();
float tgt_att_limited = tgt_attitude;
if (is_positive(dwell_freq)) {
float tgt_att_temp = tgt_attitude;
if (is_positive(rate_max)) {
float ang_limit_rate = radians(rate_max) / dwell_freq;
tgt_att_temp = MIN(ang_limit_rate, tgt_attitude);
}
if (is_positive(accel_max)) {
float ang_limit_accel = radians(accel_max) / sq(dwell_freq);
tgt_att_limited = MIN(ang_limit_accel, tgt_att_temp);
} else {
tgt_att_limited = tgt_att_temp;
}
}
target_angle_cd = -chirp_input.update((now - dwell_start_time_ms) * 0.001, degrees(tgt_att_limited) * 100.0f);
dwell_freq = chirp_input.get_frequency_rads();
const Vector2f att_fdbk {
-5730.0f * vel_hold_gain * velocity_bf.y,
Expand Down

0 comments on commit 8c44e56

Please sign in to comment.