mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-19 23:28:32 -04:00
150 lines
5.4 KiB
C++
150 lines
5.4 KiB
C++
/*
|
|
This program is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
/*
|
|
support for autotune of helicopters
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include "AC_AutoTune.h"
|
|
|
|
class AC_AutoTune_Heli : public AC_AutoTune
|
|
{
|
|
public:
|
|
// constructor
|
|
AC_AutoTune_Heli();
|
|
|
|
// save gained, called on disarm
|
|
void save_tuning_gains() override;
|
|
|
|
// var_info for holding Parameter information
|
|
static const struct AP_Param::GroupInfo var_info[];
|
|
|
|
protected:
|
|
|
|
void load_test_gains() override;
|
|
|
|
// get intra test rate I gain for the specified axis
|
|
float get_intra_test_ri(AxisType test_axis) override;
|
|
|
|
// get tuned rate I gain for the specified axis
|
|
float get_tuned_ri(AxisType test_axis) override;
|
|
|
|
// get tuned yaw rate d gain
|
|
float get_tuned_yaw_rd() override { return tune_yaw_rd; }
|
|
|
|
void test_init() override;
|
|
void test_run(AxisType test_axis, const float dir_sign) override;
|
|
|
|
// update gains for the rate p up tune type
|
|
void updating_rate_p_up_all(AxisType test_axis) override;
|
|
|
|
// update gains for the rate p down tune type
|
|
void updating_rate_p_down_all(AxisType test_axis) override {};
|
|
|
|
// update gains for the rate d up tune type
|
|
void updating_rate_d_up_all(AxisType test_axis) override;
|
|
|
|
// update gains for the rate d down tune type
|
|
void updating_rate_d_down_all(AxisType test_axis) override {};
|
|
|
|
// update gains for the rate ff up tune type
|
|
void updating_rate_ff_up_all(AxisType test_axis) override;
|
|
|
|
// update gains for the rate ff down tune type
|
|
void updating_rate_ff_down_all(AxisType test_axis) override {};
|
|
|
|
// update gains for the angle p up tune type
|
|
void updating_angle_p_up_all(AxisType test_axis) override;
|
|
|
|
// update gains for the angle p down tune type
|
|
void updating_angle_p_down_all(AxisType test_axis) override {};
|
|
|
|
// update gains for the max gain tune type
|
|
void updating_max_gains_all(AxisType test_axis) override;
|
|
|
|
// get minimum rate P (for any axis)
|
|
float get_rp_min() const override;
|
|
|
|
// get minimum angle P (for any axis)
|
|
float get_sp_min() const override;
|
|
|
|
// get minimum rate Yaw filter value
|
|
float get_yaw_rate_filt_min() const override;
|
|
|
|
// reverse direction for twitch test
|
|
bool twitch_reverse_direction() override { return positive_direction; }
|
|
|
|
void Log_AutoTune() override;
|
|
void Log_AutoTuneDetails() override;
|
|
void Log_AutoTuneSweep() override;
|
|
void Log_Write_AutoTune(uint8_t _axis, uint8_t tune_step, float dwell_freq, float meas_gain, float meas_phase, float new_gain_rff, float new_gain_rp, float new_gain_rd, float new_gain_sp, float max_accel);
|
|
void Log_Write_AutoTuneDetails(float motor_cmd, float tgt_rate_rads, float rate_rads, float tgt_ang_rad, float ang_rad);
|
|
void Log_Write_AutoTuneSweep(float freq, float gain, float phase);
|
|
// returns true if rate P gain of zero is acceptable for this vehicle
|
|
bool allow_zero_rate_p() override { return true; }
|
|
|
|
// returns true if max tested accel is used for parameter
|
|
bool set_accel_to_max_test_value() override { return false; }
|
|
|
|
// send intermittant updates to user on status of tune
|
|
void do_gcs_announcements() override;
|
|
|
|
void set_tune_sequence() override;
|
|
|
|
AP_Int8 seq_bitmask;
|
|
AP_Float min_sweep_freq;
|
|
AP_Float max_sweep_freq;
|
|
AP_Float max_resp_gain;
|
|
|
|
private:
|
|
// updating_rate_ff_up - adjust FF to ensure the target is reached
|
|
// FF is adjusted until rate requested is acheived
|
|
void updating_rate_ff_up(float &tune_ff, float rate_target, float meas_rate, float meas_command);
|
|
void updating_rate_p_up(float &tune_p, float *freq, float *gain, float *phase, uint8_t &frq_cnt, max_gain_data &max_gain_p);
|
|
void updating_rate_d_up(float &tune_d, float *freq, float *gain, float *phase, uint8_t &frq_cnt, max_gain_data &max_gain_d);
|
|
void updating_angle_p_up(float &tune_p, float *freq, float *gain, float *phase, uint8_t &frq_cnt);
|
|
void updating_angle_p_up_yaw(float &tune_p, float *freq, float *gain, float *phase, uint8_t &frq_cnt);
|
|
// updating_max_gains: use dwells at increasing frequency to determine gain at which instability will occur
|
|
void updating_max_gains(float *freq, float *gain, float *phase, uint8_t &frq_cnt, max_gain_data &max_gain_p, max_gain_data &max_gain_d, float &tune_p, float &tune_d);
|
|
|
|
uint8_t method; //0: determine freq, 1: use max gain method, 2: use phase 180 method
|
|
// updating rate FF variables
|
|
bool first_dir_complete;
|
|
float first_dir_rff;
|
|
|
|
// updating max gain variables
|
|
bool found_max_p;
|
|
bool found_max_d;
|
|
bool find_middle;
|
|
|
|
// updating angle P up variables
|
|
float phase_max;
|
|
float sp_prev_gain;
|
|
bool find_peak;
|
|
|
|
// updating angle P up yaw
|
|
uint8_t sp_prev_good_frq_cnt;
|
|
|
|
// updating rate P up
|
|
uint8_t rp_prev_good_frq_cnt;
|
|
float rp_prev_gain;
|
|
|
|
// updating rate D up
|
|
uint8_t rd_prev_good_frq_cnt;
|
|
float rd_prev_gain;
|
|
|
|
};
|