ardupilot/libraries/AC_AttitudeControl/AC_CommandModel.cpp

50 lines
1.6 KiB
C++

#include "AC_CommandModel.h"
#include <AP_HAL/AP_HAL.h>
// The Commmand Model class holds parameters that shape the pilot desired angular rate input. This class can
// be expanded to hold the methods that shape the pilot desired input.
extern const AP_HAL::HAL& hal;
// table of user settable parameters
const AP_Param::GroupInfo AC_CommandModel::var_info[] = {
// @Param: RATE
// @DisplayName: Maximum Controlled Rate
// @Description: Sets the maximum rate commanded.
// @Units: deg/s
// @Range: 1 360
// @User: Standard
AP_GROUPINFO("RATE", 1, AC_CommandModel, rate, 202.5),
// @Param: EXPO
// @DisplayName: Controlled Expo
// @Description: Controlled expo to allow faster rotation when stick at edges
// @Values: 0:Disabled,0.1:Very Low,0.2:Low,0.3:Medium,0.4:High,0.5:Very High
// @Range: -0.5 1.0
// @User: Advanced
AP_GROUPINFO("EXPO", 2, AC_CommandModel, expo, 0),
// @Param: RATE_TC
// @DisplayName: Rate control input time constant
// @Description: Rate control input time constant. Low numbers lead to sharper response, higher numbers to softer response
// @Units: s
// @Range: 0 1
// @Increment: 0.01
// @Values: 0.5:Very Soft, 0.2:Soft, 0.15:Medium, 0.1:Crisp, 0.05:Very Crisp
// @User: Standard
AP_GROUPINFO("RATE_TC", 3, AC_CommandModel, rate_tc, 0.05f),
AP_GROUPEND
};
// Constructor
AC_CommandModel::AC_CommandModel(float initial_rate, float initial_expo, float initial_tc)
{
AP_Param::setup_object_defaults(this, var_info);
rate = initial_rate;
expo = initial_expo;
rate_tc = initial_tc;
}