APM: added a SCALING_SPEED parameter
this allows users to adjust the base speed used for scaling roll/pitch PIDs. This can be used to make PIDs work for both airspeed and non-airspeed control
This commit is contained in:
parent
3c2fc72654
commit
6bcfe913f7
@ -14,7 +14,7 @@ static void stabilize()
|
||||
if (airspeed.use()) {
|
||||
float aspeed = airspeed.get_airspeed();
|
||||
if (aspeed > 0) {
|
||||
speed_scaler = STANDARD_SPEED / aspeed;
|
||||
speed_scaler = g.scaling_speed / aspeed;
|
||||
} else {
|
||||
speed_scaler = 2.0;
|
||||
}
|
||||
@ -226,7 +226,7 @@ static void calc_nav_roll()
|
||||
#else
|
||||
// this is the old nav_roll calculation. We will use this for 2.50
|
||||
// then remove for a future release
|
||||
float nav_gain_scaler = (float)g_gps->ground_speed / (STANDARD_SPEED * 100.0);
|
||||
float nav_gain_scaler = 0.01 * g_gps->ground_speed / g.scaling_speed;
|
||||
nav_gain_scaler = constrain(nav_gain_scaler, 0.2, 1.4);
|
||||
nav_roll = g.pidNavRoll.get_pid(bearing_error, nav_gain_scaler); //returns desired bank angle in degrees*100
|
||||
#endif
|
||||
|
@ -163,6 +163,7 @@ public:
|
||||
k_param_kff_rudder_mix,
|
||||
k_param_kff_pitch_to_throttle,
|
||||
k_param_kff_throttle_to_pitch,
|
||||
k_param_scaling_speed,
|
||||
|
||||
//
|
||||
// 210: flight modes
|
||||
@ -265,6 +266,9 @@ public:
|
||||
AP_Float kff_pitch_to_throttle;
|
||||
AP_Float kff_throttle_to_pitch;
|
||||
|
||||
// speed used for speed scaling
|
||||
AP_Float scaling_speed;
|
||||
|
||||
// Crosstrack navigation
|
||||
//
|
||||
AP_Float crosstrack_gain;
|
||||
@ -402,6 +406,7 @@ public:
|
||||
kff_rudder_mix (RUDDER_MIX),
|
||||
kff_pitch_to_throttle (P_TO_T),
|
||||
kff_throttle_to_pitch (T_TO_P),
|
||||
scaling_speed (SCALING_SPEED),
|
||||
|
||||
crosstrack_gain (XTRACK_GAIN_SCALED),
|
||||
crosstrack_entry_angle (XTRACK_ENTRY_ANGLE_CENTIDEGREE),
|
||||
|
@ -392,6 +392,13 @@ static const AP_Param::Info var_info[] PROGMEM = {
|
||||
// @User: User
|
||||
GSCALAR(airspeed_cruise_cm, "TRIM_ARSPD_CM"),
|
||||
|
||||
// @Param: SCALING_SPEED
|
||||
// @DisplayName: speed used for speed scaling calculations
|
||||
// @Description: Airspeed in m/s to use when calculating surface speed scaling. Note that changing this value will affect all PID values
|
||||
// @Units: m/s
|
||||
// @User: Advanced
|
||||
GSCALAR(scaling_speed, "SCALING_SPEED"),
|
||||
|
||||
// @Param: MIN_GNDSPD_CM
|
||||
// @DisplayName: Minimum ground speed
|
||||
// @Description: Minimum ground speed in cm/s when under airspeed control
|
||||
|
@ -817,11 +817,9 @@
|
||||
// Developer Items
|
||||
//
|
||||
|
||||
#ifndef STANDARD_SPEED
|
||||
# define STANDARD_SPEED 15.0
|
||||
#define STANDARD_SPEED_SQUARED (STANDARD_SPEED * STANDARD_SPEED)
|
||||
#ifndef SCALING_SPEED
|
||||
# define SCALING_SPEED 15.0
|
||||
#endif
|
||||
#define STANDARD_THROTTLE_SQUARED (THROTTLE_CRUISE * THROTTLE_CRUISE)
|
||||
|
||||
// use this to enable servos in HIL mode
|
||||
#ifndef HIL_SERVOS
|
||||
|
Loading…
Reference in New Issue
Block a user