AC_AutoTune: comments in FreqResp and use M_2PI for 6.28

This commit is contained in:
Bill Geyer 2021-09-12 15:12:57 -04:00 committed by Bill Geyer
parent af1c8dd9bc
commit 2c1985aecd
2 changed files with 21 additions and 23 deletions

View File

@ -1,7 +1,5 @@
/* /*
This function receives time history data during a dwell test or frequency sweep and determines the gain and phase of the response to the input. This library receives time history data (angular rate or angle) during a dwell test or frequency sweep test and determines the gain and phase of the response to the input. For dwell tests once the designated number of cycles are complete, the average of the gain and phase are determined over the last 5 cycles and the cycle_complete flag is set. For frequency sweep tests, phase and gain are determined for every cycle and cycle_complete flag is set to indicate when to pull the phase and gain data. The flag is reset to enable the next cycle to be analyzed. The init function must be used when initializing the dwell or frequency sweep test.
Once the designated number of cycles are complete, the average of the gain and phase are determined over the last 5 cycles and the cycles_complete flag
is set. This function must be reset using the reset flag prior to the next dwell.
*/ */
#include <AP_HAL/AP_HAL.h> #include <AP_HAL/AP_HAL.h>
@ -31,10 +29,10 @@ void AC_AutoTune_FreqResp::init(InputType input_type)
cycle_complete = false; cycle_complete = false;
} }
// determine_gain - this function receives time history data during a dwell and frequency sweep tests for max gain, // update_rate - this function receives time history data during a dwell and frequency sweep tests for max gain,
// rate P and rate D tuning and determines the gain and phase of the response to the input. For dwell tests once // rate P and rate D tuning and determines the gain and phase of the response to the input. For dwell tests once
// the designated number of cycles are complete, the average of the gain and phase are determined over the last 5 cycles // the designated number of cycles are complete, the average of the gain and phase are determined over the last 5 cycles
// and the cycles_complete flag is set. For frequency sweep tests, phase and gain are determined for every cycle and // and the cycle_complete flag is set. For frequency sweep tests, phase and gain are determined for every cycle and
// cycle_complete flag is set to indicate when to pull the phase and gain data. The flag is reset to enable the next // cycle_complete flag is set to indicate when to pull the phase and gain data. The flag is reset to enable the next
// cycle to be analyzed. // cycle to be analyzed.
void AC_AutoTune_FreqResp::update_rate(float tgt_rate, float meas_rate, float tgt_freq) void AC_AutoTune_FreqResp::update_rate(float tgt_rate, float meas_rate, float tgt_freq)
@ -48,8 +46,8 @@ void AC_AutoTune_FreqResp::update_rate(float tgt_rate, float meas_rate, float tg
} }
if (!is_zero(tgt_freq)) { if (!is_zero(tgt_freq)) {
half_cycle_time_ms = (uint32_t)(300 * 6.28 / tgt_freq); half_cycle_time_ms = (uint32_t)(300 * M_2PI / tgt_freq);
cycle_time_ms = (uint32_t)(1000 * 6.28 / tgt_freq); cycle_time_ms = (uint32_t)(1000 * M_2PI / tgt_freq);
} }
if (input_start_time_ms == 0) { if (input_start_time_ms == 0) {
@ -101,7 +99,7 @@ void AC_AutoTune_FreqResp::update_rate(float tgt_rate, float meas_rate, float tg
if (cnt > 0) { if (cnt > 0) {
delta_time = delta_time / cnt; delta_time = delta_time / cnt;
} }
curr_test_phase = tgt_freq * delta_time * 0.001f * 360.0f / 6.28f; curr_test_phase = tgt_freq * delta_time * 0.001f * 360.0f / M_2PI;
if (curr_test_phase > 360.0f) { if (curr_test_phase > 360.0f) {
curr_test_phase = curr_test_phase - 360.0f; curr_test_phase = curr_test_phase - 360.0f;
} }
@ -157,7 +155,7 @@ void AC_AutoTune_FreqResp::update_rate(float tgt_rate, float meas_rate, float tg
if (excitation == SWEEP) { if (excitation == SWEEP) {
float tgt_period = 0.001f * (temp_max_tgt_time - sweep_tgt.max_time_m1); float tgt_period = 0.001f * (temp_max_tgt_time - sweep_tgt.max_time_m1);
if (!is_zero(tgt_period)) { if (!is_zero(tgt_period)) {
curr_test_freq = 6.28f / tgt_period; curr_test_freq = M_2PI / tgt_period;
} else { } else {
curr_test_freq = 0.0f; curr_test_freq = 0.0f;
} }
@ -166,7 +164,7 @@ void AC_AutoTune_FreqResp::update_rate(float tgt_rate, float meas_rate, float tg
} else { } else {
curr_test_gain = 0.0f; curr_test_gain = 0.0f;
} }
curr_test_phase = curr_test_freq * (float)(sweep_meas.max_time_m1 - sweep_tgt.max_time_m1) * 0.001f * 360.0f / 6.28f; curr_test_phase = curr_test_freq * (float)(sweep_meas.max_time_m1 - sweep_tgt.max_time_m1) * 0.001f * 360.0f / M_2PI;
// gcs().send_text(MAV_SEVERITY_INFO, "AutoTune: freq=%f sweepgain=%f", (double)(curr_test_freq), (double)(curr_test_gain)); // gcs().send_text(MAV_SEVERITY_INFO, "AutoTune: freq=%f sweepgain=%f", (double)(curr_test_freq), (double)(curr_test_gain));
cycle_complete = true; cycle_complete = true;
} }
@ -221,8 +219,8 @@ void AC_AutoTune_FreqResp::update_angle(float command, float tgt_angle, float me
} }
if (!is_zero(tgt_freq)) { if (!is_zero(tgt_freq)) {
half_cycle_time_ms = (uint32_t)(300 * 6.28 / tgt_freq); half_cycle_time_ms = (uint32_t)(300 * M_2PI / tgt_freq);
cycle_time_ms = (uint32_t)(1000 * 6.28 / tgt_freq); cycle_time_ms = (uint32_t)(1000 * M_2PI / tgt_freq);
} }
if (input_start_time_ms == 0) { if (input_start_time_ms == 0) {
@ -281,7 +279,7 @@ void AC_AutoTune_FreqResp::update_angle(float command, float tgt_angle, float me
if (cnt > 0) { if (cnt > 0) {
delta_time = delta_time / cnt; delta_time = delta_time / cnt;
} }
curr_test_phase = tgt_freq * delta_time * 0.001f * 360.0f / 6.28f; curr_test_phase = tgt_freq * delta_time * 0.001f * 360.0f / M_2PI;
if (curr_test_phase > 360.0f) { if (curr_test_phase > 360.0f) {
curr_test_phase = curr_test_phase - 360.0f; curr_test_phase = curr_test_phase - 360.0f;
} }
@ -345,7 +343,7 @@ void AC_AutoTune_FreqResp::update_angle(float command, float tgt_angle, float me
if (excitation == SWEEP) { if (excitation == SWEEP) {
float tgt_period = 0.001f * (temp_max_tgt_time - sweep_tgt.max_time_m1); float tgt_period = 0.001f * (temp_max_tgt_time - sweep_tgt.max_time_m1);
if (!is_zero(tgt_period)) { if (!is_zero(tgt_period)) {
curr_test_freq = 6.28f / tgt_period; curr_test_freq = M_2PI / tgt_period;
} else { } else {
curr_test_freq = 0.0f; curr_test_freq = 0.0f;
} }
@ -354,7 +352,7 @@ void AC_AutoTune_FreqResp::update_angle(float command, float tgt_angle, float me
} else { } else {
curr_test_gain = 0.0f; curr_test_gain = 0.0f;
} }
curr_test_phase = curr_test_freq * (float)(sweep_meas.max_time_m1 - sweep_tgt.max_time_m1) * 0.001f * 360.0f / 6.28f; curr_test_phase = curr_test_freq * (float)(sweep_meas.max_time_m1 - sweep_tgt.max_time_m1) * 0.001f * 360.0f / M_2PI;
//gcs().send_text(MAV_SEVERITY_INFO, "AutoTune: freq=%f gain=%f phase=%f", (double)(curr_test_freq), (double)(curr_test_gain), (double)(curr_test_phase)); //gcs().send_text(MAV_SEVERITY_INFO, "AutoTune: freq=%f gain=%f phase=%f", (double)(curr_test_freq), (double)(curr_test_gain), (double)(curr_test_phase));
cycle_complete = true; cycle_complete = true;
} }

View File

@ -133,7 +133,7 @@ void AC_AutoTune_Heli::test_init()
} }
if (!is_zero(start_freq)) { if (!is_zero(start_freq)) {
// 4 seconds is added to allow aircraft to achieve start attitude. Then the time to conduct the dwells is added to it. // 4 seconds is added to allow aircraft to achieve start attitude. Then the time to conduct the dwells is added to it.
step_time_limit_ms = (uint32_t)(4000 + (float)(AUTOTUNE_DWELL_CYCLES + 2) * 1000.0f * 6.28f / start_freq); step_time_limit_ms = (uint32_t)(4000 + (float)(AUTOTUNE_DWELL_CYCLES + 2) * 1000.0f * M_2PI / start_freq);
} }
} else if (tune_type == SP_UP) { } else if (tune_type == SP_UP) {
// initialize start frequency when dwell test is used // initialize start frequency when dwell test is used
@ -158,7 +158,7 @@ void AC_AutoTune_Heli::test_init()
// TODO add time limit for sweep test // TODO add time limit for sweep test
if (!is_zero(start_freq)) { if (!is_zero(start_freq)) {
// 1 seconds is added for a little buffer. Then the time to conduct the dwells is added to it. // 1 seconds is added for a little buffer. Then the time to conduct the dwells is added to it.
step_time_limit_ms = (uint32_t)(2000 + (float)(AUTOTUNE_DWELL_CYCLES + 7) * 1000.0f * 6.28f / start_freq); step_time_limit_ms = (uint32_t)(2000 + (float)(AUTOTUNE_DWELL_CYCLES + 7) * 1000.0f * M_2PI / start_freq);
} }
} else { } else {