Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
Ardupilot
GitHub Repository: Ardupilot/ardupilot
Path: blob/master/libraries/APM_Control/AP_FW_Controller.h
4232 views
1
#pragma once
2
3
#include <AP_Common/AP_Common.h>
4
#include "AP_AutoTune.h"
5
#include <AC_PID/AC_PID.h>
6
7
class AP_FW_Controller
8
{
9
public:
10
AP_FW_Controller(const AP_FixedWing &parms, const AC_PID::Defaults &defaults, AP_AutoTune::ATType _autotune_type);
11
12
/* Do not allow copies */
13
CLASS_NO_COPY(AP_FW_Controller);
14
15
float get_rate_out(float desired_rate, float scaler);
16
virtual float get_servo_out(int32_t angle_err, float scaler, bool disable_integrator, bool ground_mode) = 0;
17
18
// setup a one loop FF scale multiplier. This replaces any previous scale applied
19
// so should only be used when only one source of scaling is needed
20
void set_ff_scale(float _ff_scale) { ff_scale = _ff_scale; }
21
22
void reset_I();
23
24
/*
25
reduce the integrator, used when we have a low scale factor in a quadplane hover
26
*/
27
void decay_I();
28
29
void autotune_start(void);
30
void autotune_restore(void);
31
32
const AP_PIDInfo& get_pid_info(void) const
33
{
34
return _pid_info;
35
}
36
37
// set the PID notch sample rates
38
void set_notch_sample_rate(float sample_rate) { rate_pid.set_notch_sample_rate(sample_rate); }
39
40
AP_Float &kP(void) { return rate_pid.kP(); }
41
AP_Float &kI(void) { return rate_pid.kI(); }
42
AP_Float &kD(void) { return rate_pid.kD(); }
43
AP_Float &kFF(void) { return rate_pid.ff(); }
44
AP_Float &tau(void) { return gains.tau; }
45
46
protected:
47
const AP_FixedWing &aparm;
48
AP_AutoTune::ATGains gains;
49
AP_AutoTune *autotune;
50
bool failed_autotune_alloc;
51
float _last_out;
52
AC_PID rate_pid;
53
float angle_err_deg;
54
float ff_scale = 1.0;
55
56
AP_PIDInfo _pid_info;
57
58
float _get_rate_out(float desired_rate, float scaler, bool disable_integrator, float aspeed, bool ground_mode);
59
60
virtual bool is_underspeed(const float aspeed) const = 0;
61
62
virtual float get_airspeed() const = 0;
63
64
virtual float get_measured_rate() const = 0;
65
66
const AP_AutoTune::ATType autotune_type;
67
};
68
69