2016-05-27 01:13:02 -03:00
// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
2016-02-17 21:24:42 -04:00
# pragma once
2013-10-12 09:28:18 -03:00
/// @file AC_AttitudeControl.h
/// @brief ArduCopter attitude control library
2015-08-11 03:28:41 -03:00
# include <AP_Common/AP_Common.h>
# include <AP_Param/AP_Param.h>
# include <AP_Math/AP_Math.h>
# include <AP_InertialSensor/AP_InertialSensor.h>
# include <AP_AHRS/AP_AHRS.h>
# include <AP_Motors/AP_Motors.h>
# include <AC_PID/AC_PID.h>
# include <AC_PID/AC_P.h>
2013-10-12 09:28:18 -03:00
2015-11-24 23:28:42 -04:00
// TODO: change the name or move to AP_Math? eliminate in favor of degrees(100)?
# define AC_ATTITUDE_CONTROL_DEGX100 5729.57795f // constant to convert from radians to centidegrees
2016-02-15 02:26:24 -04:00
# define AC_ATTITUDE_CONTROL_ANGLE_P 4.5f // default angle P gain for roll, pitch and yaw
2016-02-18 07:48:23 -04:00
# define AC_ATTITUDE_ACCEL_RP_CONTROLLER_MIN_RADSS radians(40.0f) // minimum body-frame acceleration limit for the stability controller (for roll and pitch axis)
2015-11-24 17:11:50 -04:00
# define AC_ATTITUDE_ACCEL_RP_CONTROLLER_MAX_RADSS radians(720.0f) // maximum body-frame acceleration limit for the stability controller (for roll and pitch axis)
2016-02-18 07:48:23 -04:00
# define AC_ATTITUDE_ACCEL_Y_CONTROLLER_MIN_RADSS radians(10.0f) // minimum body-frame acceleration limit for the stability controller (for yaw axis)
2015-11-24 17:11:50 -04:00
# define AC_ATTITUDE_ACCEL_Y_CONTROLLER_MAX_RADSS radians(360.0f) // maximum body-frame acceleration limit for the stability controller (for yaw axis)
# define AC_ATTITUDE_CONTROL_SLEW_YAW_DEFAULT_CDS 1000 // constraint on yaw angle error in degrees. This should lead to maximum turn rate of 10deg/sed * Stab Rate P so by default will be 45deg/sec.
2015-11-24 23:28:42 -04:00
# define AC_ATTITUDE_CONTROL_ACCEL_RP_MAX_DEFAULT_CDSS 110000.0f // default maximum acceleration for roll/pitch axis in centidegrees/sec/sec
# define AC_ATTITUDE_CONTROL_ACCEL_Y_MAX_DEFAULT_CDSS 27000.0f // default maximum acceleration for yaw axis in centidegrees/sec/sec
2014-02-14 21:07:49 -04:00
2014-02-03 00:29:17 -04:00
# define AC_ATTITUDE_RATE_CONTROLLER_TIMEOUT 1.0f // body-frame rate controller timeout in seconds
2016-02-02 08:09:26 -04:00
# define AC_ATTITUDE_RATE_RP_CONTROLLER_OUT_MAX 1.0f // body-frame rate controller maximum output (for roll-pitch axis)
# define AC_ATTITUDE_RATE_YAW_CONTROLLER_OUT_MAX 1.0f // body-frame rate controller maximum output (for yaw axis)
2013-10-12 09:28:18 -03:00
2015-11-24 17:11:50 -04:00
# define AC_ATTITUDE_RATE_STAB_ROLL_OVERSHOOT_ANGLE_MAX_RAD radians(300.0f) // earth-frame rate stabilize controller's maximum overshoot angle (never limited)
# define AC_ATTITUDE_RATE_STAB_PITCH_OVERSHOOT_ANGLE_MAX_RAD radians(300.0f) // earth-frame rate stabilize controller's maximum overshoot angle (never limited)
# define AC_ATTITUDE_RATE_STAB_YAW_OVERSHOOT_ANGLE_MAX_RAD radians(10.0f) // earth-frame rate stabilize controller's maximum overshoot angle
# define AC_ATTITUDE_RATE_STAB_ACRO_OVERSHOOT_ANGLE_MAX_RAD radians(30.0f) // earth-frame rate stabilize controller's maximum overshoot angle
2013-10-12 09:28:18 -03:00
# define AC_ATTITUDE_100HZ_DT 0.0100f // delta time in seconds for 100hz update rate
# define AC_ATTITUDE_400HZ_DT 0.0025f // delta time in seconds for 400hz update rate
2015-05-03 19:05:15 -03:00
# define AC_ATTITUDE_CONTROL_RATE_BF_FF_DEFAULT 1 // body-frame rate feedforward enabled by default
2014-06-06 02:04:06 -03:00
2015-06-23 10:41:47 -03:00
# define AC_ATTITUDE_CONTROL_ALTHOLD_LEANANGLE_FILT_HZ 1.0f // filter (in hz) of throttle filter used to limit lean angle so that vehicle does not lose altitude
2013-10-12 09:28:18 -03:00
class AC_AttitudeControl {
public :
2015-11-24 23:28:42 -04:00
AC_AttitudeControl ( AP_AHRS & ahrs ,
2014-01-17 22:54:23 -04:00
const AP_Vehicle : : MultiCopter & aparm ,
2013-10-12 09:28:18 -03:00
AP_Motors & motors ,
2016-02-15 02:26:24 -04:00
float dt ) :
_p_angle_roll ( AC_ATTITUDE_CONTROL_ANGLE_P ) ,
_p_angle_pitch ( AC_ATTITUDE_CONTROL_ANGLE_P ) ,
_p_angle_yaw ( AC_ATTITUDE_CONTROL_ANGLE_P ) ,
_dt ( dt ) ,
2015-12-08 02:48:59 -04:00
_angle_boost ( 0 ) ,
_att_ctrl_use_accel_limit ( true ) ,
_throttle_in_filt ( AC_ATTITUDE_CONTROL_ALTHOLD_LEANANGLE_FILT_HZ ) ,
2015-11-24 23:28:42 -04:00
_ahrs ( ahrs ) ,
2014-01-17 22:54:23 -04:00
_aparm ( aparm ) ,
2016-02-15 02:21:38 -04:00
_motors ( motors )
2015-11-24 23:28:42 -04:00
{
AP_Param : : setup_object_defaults ( this , var_info ) ;
}
2014-07-14 10:37:31 -03:00
2015-11-24 23:28:42 -04:00
// Empty destructor to suppress compiler warning
virtual ~ AC_AttitudeControl ( ) { }
2013-10-12 09:28:18 -03:00
2016-02-15 02:26:24 -04:00
// pid accessors
AC_P & get_angle_roll_p ( ) { return _p_angle_roll ; }
AC_P & get_angle_pitch_p ( ) { return _p_angle_pitch ; }
AC_P & get_angle_yaw_p ( ) { return _p_angle_yaw ; }
virtual AC_PID & get_rate_roll_pid ( ) = 0 ;
virtual AC_PID & get_rate_pitch_pid ( ) = 0 ;
virtual AC_PID & get_rate_yaw_pid ( ) = 0 ;
2013-10-12 09:28:18 -03:00
2015-11-24 23:28:42 -04:00
// Gets the roll acceleration limit in centidegrees/s/s
2015-05-06 04:11:48 -03:00
float get_accel_roll_max ( ) { return _accel_roll_max ; }
2015-11-24 23:28:42 -04:00
// Sets the roll acceleration limit in centidegrees/s/s
2015-06-05 05:21:56 -03:00
void set_accel_roll_max ( float accel_roll_max ) { _accel_roll_max = accel_roll_max ; }
2015-11-24 23:28:42 -04:00
// Sets and saves the roll acceleration limit in centidegrees/s/s
2015-02-11 08:10:56 -04:00
void save_accel_roll_max ( float accel_roll_max ) { _accel_roll_max = accel_roll_max ; _accel_roll_max . save ( ) ; }
2015-11-24 23:28:42 -04:00
// Sets the pitch acceleration limit in centidegrees/s/s
2015-05-06 04:11:48 -03:00
float get_accel_pitch_max ( ) { return _accel_pitch_max ; }
2015-11-24 23:28:42 -04:00
// Sets the pitch acceleration limit in centidegrees/s/s
2015-06-05 05:21:56 -03:00
void set_accel_pitch_max ( float accel_pitch_max ) { _accel_pitch_max = accel_pitch_max ; }
2015-11-24 23:28:42 -04:00
// Sets and saves the pitch acceleration limit in centidegrees/s/s
2015-02-11 08:10:56 -04:00
void save_accel_pitch_max ( float accel_pitch_max ) { _accel_pitch_max = accel_pitch_max ; _accel_pitch_max . save ( ) ; }
2015-11-24 23:28:42 -04:00
// Gets the yaw acceleration limit in centidegrees/s/s
2015-05-06 04:11:48 -03:00
float get_accel_yaw_max ( ) { return _accel_yaw_max ; }
2015-11-24 23:28:42 -04:00
// Sets the yaw acceleration limit in centidegrees/s/s
2015-06-05 05:21:56 -03:00
void set_accel_yaw_max ( float accel_yaw_max ) { _accel_yaw_max = accel_yaw_max ; }
2015-11-24 23:28:42 -04:00
// Sets and saves the yaw acceleration limit in centidegrees/s/s
2015-02-11 08:10:56 -04:00
void save_accel_yaw_max ( float accel_yaw_max ) { _accel_yaw_max = accel_yaw_max ; _accel_yaw_max . save ( ) ; }
2015-11-24 23:28:42 -04:00
// Ensure body-frame rate controller has zero errors to relax rate controller output
2014-06-06 00:03:06 -03:00
void relax_bf_rate_controller ( ) ;
2014-01-11 04:02:42 -04:00
2015-11-24 23:28:42 -04:00
// Sets yaw target to vehicle heading
void set_yaw_target_to_current_heading ( ) { _att_target_euler_rad . z = _ahrs . yaw ; }
2014-06-06 02:45:18 -03:00
2015-11-24 23:28:42 -04:00
// Shifts earth frame yaw target by yaw_shift_cd. yaw_shift_cd should be in centidegrees and is added to the current target heading
2015-06-23 04:49:12 -03:00
void shift_ef_yaw_target ( float yaw_shift_cd ) ;
2015-11-24 23:28:42 -04:00
// Command an euler roll and pitch angle and an euler yaw rate with angular velocity feedforward and smoothing
2015-11-28 13:56:25 -04:00
void input_euler_angle_roll_pitch_euler_rate_yaw_smooth ( float euler_roll_angle_cd , float euler_pitch_angle_cd , float euler_yaw_rate_cds , float smoothing_gain ) ;
2014-02-19 02:55:45 -04:00
2015-11-24 23:28:42 -04:00
// Command an euler roll and pitch angle and an euler yaw rate
2015-11-28 13:56:25 -04:00
void input_euler_angle_roll_pitch_euler_rate_yaw ( float euler_roll_angle_cd , float euler_pitch_angle_cd , float euler_yaw_rate_cds ) ;
2014-01-11 04:02:42 -04:00
2015-11-24 23:28:42 -04:00
// Command an euler roll, pitch and yaw angle
2015-12-02 14:45:34 -04:00
void input_euler_angle_roll_pitch_yaw ( float euler_roll_angle_cd , float euler_pitch_angle_cd , float euler_yaw_angle_cd , bool slew_yaw ) ;
2014-01-11 04:02:42 -04:00
2015-11-24 23:28:42 -04:00
// Command an euler roll, pitch, and yaw rate
2015-11-28 13:56:25 -04:00
void input_euler_rate_roll_pitch_yaw ( float euler_roll_rate_cds , float euler_pitch_rate_cds , float euler_yaw_rate_cds ) ;
2014-01-28 04:30:33 -04:00
2015-11-24 23:28:42 -04:00
// Command an angular velocity
2015-11-28 13:56:25 -04:00
virtual void input_rate_bf_roll_pitch_yaw ( float roll_rate_bf_cds , float pitch_rate_bf_cds , float yaw_rate_bf_cds ) ;
2014-01-24 22:59:48 -04:00
2016-01-20 14:41:32 -04:00
// Command a quaternion attitude and a body-frame angular velocity
void input_att_quat_bf_ang_vel ( const Quaternion & att_target_quat , const Vector3f & att_target_ang_vel_rads ) ;
2015-11-24 23:28:42 -04:00
// Run angular velocity controller and send outputs to the motors
2014-02-09 22:59:51 -04:00
virtual void rate_controller_run ( ) ;
2013-10-12 09:28:18 -03:00
2015-11-24 23:28:42 -04:00
// Convert a 321-intrinsic euler angle derivative to an angular velocity vector
2015-12-08 15:15:10 -04:00
void euler_rate_to_ang_vel ( const Vector3f & euler_rad , const Vector3f & euler_rate_rads , Vector3f & ang_vel_rads ) ;
2013-10-12 09:28:18 -03:00
2015-11-24 23:28:42 -04:00
// Convert an angular velocity vector to a 321-intrinsic euler angle derivative
// Returns false if the vehicle is pitched 90 degrees up or down
2015-12-08 15:15:10 -04:00
bool ang_vel_to_euler_rate ( const Vector3f & euler_rad , const Vector3f & ang_vel_rads , Vector3f & euler_rate_rads ) ;
2013-10-12 09:28:18 -03:00
2015-11-24 23:28:42 -04:00
// Configures whether the attitude controller should limit the rate demand to constrain angular acceleration
void limit_angle_to_rate_request ( bool limit_request ) { _att_ctrl_use_accel_limit = limit_request ; }
2013-10-12 09:28:18 -03:00
2015-11-24 23:28:42 -04:00
// Return 321-intrinsic euler angles in centidegrees representing the rotation from NED earth frame to the
// attitude controller's reference attitude.
2015-12-08 17:39:34 -04:00
Vector3f get_att_target_euler_cd ( ) const { return _att_target_euler_rad * degrees ( 100.0f ) ; }
2013-10-12 09:28:18 -03:00
2015-11-24 23:28:42 -04:00
// Return a rotation vector in centidegrees representing the rotation from vehicle body frame to the
// attitude controller's reference attitude.
2015-12-08 17:39:34 -04:00
Vector3f get_att_error_rot_vec_cd ( ) const { return _att_error_rot_vec_rad * degrees ( 100.0f ) ; }
2013-10-12 09:28:18 -03:00
2015-11-24 23:28:42 -04:00
// Set x-axis angular velocity reference in centidegrees/s
void rate_bf_roll_target ( float rate_cds ) { _ang_vel_target_rads . x = radians ( rate_cds * 0.01f ) ; }
2015-04-14 10:00:44 -03:00
2015-11-24 23:28:42 -04:00
// Set y-axis angular velocity reference in centidegrees/s
void rate_bf_pitch_target ( float rate_cds ) { _ang_vel_target_rads . y = radians ( rate_cds * 0.01f ) ; }
2013-10-12 09:28:18 -03:00
2015-11-24 23:28:42 -04:00
// Set z-axis angular velocity reference in centidegrees/s
void rate_bf_yaw_target ( float rate_cds ) { _ang_vel_target_rads . z = radians ( rate_cds * 0.01f ) ; }
// Return roll rate step size in centidegrees/s that results in maximum output after 4 time steps
2015-02-11 09:03:36 -04:00
float max_rate_step_bf_roll ( ) ;
2015-11-24 23:28:42 -04:00
// Return pitch rate step size in centidegrees/s that results in maximum output after 4 time steps
2015-02-11 09:03:36 -04:00
float max_rate_step_bf_pitch ( ) ;
2015-11-24 23:28:42 -04:00
// Return yaw rate step size in centidegrees/s that results in maximum output after 4 time steps
2015-02-11 09:03:36 -04:00
float max_rate_step_bf_yaw ( ) ;
2015-11-24 23:28:42 -04:00
// Return roll step size in centidegrees that results in maximum output after 4 time steps
2015-02-11 09:03:36 -04:00
float max_angle_step_bf_roll ( ) { return max_rate_step_bf_roll ( ) / _p_angle_roll . kP ( ) ; }
2015-11-24 23:28:42 -04:00
// Return pitch step size in centidegrees that results in maximum output after 4 time steps
2015-02-11 09:03:36 -04:00
float max_angle_step_bf_pitch ( ) { return max_rate_step_bf_pitch ( ) / _p_angle_pitch . kP ( ) ; }
2015-11-24 23:28:42 -04:00
// Return yaw step size in centidegrees that results in maximum output after 4 time steps
2015-02-11 09:03:36 -04:00
float max_angle_step_bf_yaw ( ) { return max_rate_step_bf_yaw ( ) / _p_angle_yaw . kP ( ) ; }
2015-11-24 23:28:42 -04:00
// Return reference angular velocity used in the angular velocity controller
Vector3f rate_bf_targets ( ) const { return _ang_vel_target_rads * degrees ( 100.0f ) ; }
2015-02-11 09:01:11 -04:00
2015-11-24 23:28:42 -04:00
// Enable or disable body-frame feed forward
2014-06-10 03:49:49 -03:00
void bf_feedforward ( bool enable_or_disable ) { _rate_bf_ff_enabled = enable_or_disable ; }
2015-11-24 23:28:42 -04:00
// Enable or disable body-frame feed forward and save
2015-05-08 02:28:41 -03:00
void bf_feedforward_save ( bool enable_or_disable ) { _rate_bf_ff_enabled . set_and_save ( enable_or_disable ) ; }
2015-05-06 04:11:48 -03:00
2015-11-24 23:28:42 -04:00
// Return body-frame feed forward setting
2015-02-11 07:07:29 -04:00
bool get_bf_feedforward ( ) { return _rate_bf_ff_enabled ; }
2015-11-24 23:28:42 -04:00
// Enable or disable body-frame feed forward
2014-06-10 03:49:49 -03:00
void accel_limiting ( bool enable_or_disable ) ;
2015-11-24 23:28:42 -04:00
// Set output throttle
void set_throttle_out ( float throttle_in , bool apply_angle_boost , float filt_cutoff ) ;
2015-03-25 05:18:40 -03:00
2015-11-24 23:28:42 -04:00
// Set output throttle and disable stabilization
void set_throttle_out_unstabilized ( float throttle_in , bool reset_attitude_control , float filt_cutoff ) ;
2014-01-05 23:28:35 -04:00
2016-01-04 04:14:01 -04:00
// get throttle passed into attitude controller (i.e. throttle_in provided to set_throttle_out)
float get_throttle_in ( ) const { return _throttle_in ; }
2015-11-24 23:28:42 -04:00
// Return throttle increase applied for tilt compensation
2016-01-03 23:44:45 -04:00
float angle_boost ( ) const { return _angle_boost ; }
2015-06-23 10:41:47 -03:00
2015-11-24 23:28:42 -04:00
// Return tilt angle limit for pilot input that prioritises altitude hold over lean angle
virtual float get_althold_lean_angle_max ( ) const = 0 ;
2013-10-12 09:28:18 -03:00
2016-04-28 04:46:58 -03:00
// Return configured tilt angle limit in centidegrees
2015-11-27 19:31:16 -04:00
float lean_angle_max ( ) const { return _aparm . angle_max ; }
2014-01-17 22:54:23 -04:00
2015-11-24 23:28:42 -04:00
// Proportional controller with piecewise sqrt sections to constrain second derivative
2014-10-27 02:58:56 -03:00
static float sqrt_controller ( float error , float p , float second_ord_lim ) ;
2015-11-24 23:28:42 -04:00
// User settable parameters
2013-10-12 09:28:18 -03:00
static const struct AP_Param : : GroupInfo var_info [ ] ;
2014-01-29 09:50:32 -04:00
protected :
2015-12-02 19:47:52 -04:00
// Retrieve a rotation matrix from the vehicle body frame to NED earth frame
void get_rotation_vehicle_to_ned ( Matrix3f & m ) ;
// Retrieve a rotation matrix from NED earth frame to the vehicle body frame
void get_rotation_ned_to_vehicle ( Matrix3f & m ) ;
// Retrieve a rotation matrix from reference (setpoint) body frame to NED earth frame
void get_rotation_reference_to_ned ( Matrix3f & m ) ;
// Retrieve a rotation matrix from NED earth frame to reference (setpoint) body frame
void get_rotation_ned_to_reference ( Matrix3f & m ) ;
// Retrieve a rotation matrix from vehicle body frame to reference (setpoint) body frame
void get_rotation_vehicle_to_reference ( Matrix3f & m ) ;
// Retrieve a rotation matrix from reference (setpoint) body frame to vehicle body frame
void get_rotation_reference_to_vehicle ( Matrix3f & m ) ;
2016-01-20 14:41:32 -04:00
// Command an euler attitude and a body-frame angular velocity
void attitude_controller_run_euler ( const Vector3f & att_target_euler_rad , const Vector3f & att_target_ang_vel_rads ) ;
// Command a quaternion attitude and a body-frame angular velocity
void attitude_controller_run_quat ( const Quaternion & att_target_quat , const Vector3f & att_target_ang_vel_rads ) ;
2015-11-24 23:28:42 -04:00
// Update _att_target_euler_rad.x by integrating a 321-intrinsic euler roll angle derivative
2016-01-20 14:41:32 -04:00
void update_att_target_roll ( float euler_roll_rate_rads , float overshoot_max_rad ) ;
2013-10-12 09:28:18 -03:00
2015-11-24 23:28:42 -04:00
// Update _att_target_euler_rad.y by integrating a 321-intrinsic euler pitch angle derivative
2016-01-20 14:41:32 -04:00
void update_att_target_pitch ( float euler_pitch_rate_rads , float overshoot_max_rad ) ;
2014-02-13 08:34:27 -04:00
2015-11-24 23:28:42 -04:00
// Update _att_target_euler_rad.z by integrating a 321-intrinsic euler yaw angle derivative
2016-01-20 14:41:32 -04:00
void update_att_target_yaw ( float euler_yaw_rate_rads , float overshoot_max_rad ) ;
2014-02-13 08:34:27 -04:00
2015-11-24 23:28:42 -04:00
// Integrate vehicle rate into _att_error_rot_vec_rad
2014-02-13 22:52:58 -04:00
void integrate_bf_rate_error_to_angle_errors ( ) ;
2014-02-09 22:59:51 -04:00
2015-11-24 23:28:42 -04:00
// Update _ang_vel_target_rads using _att_error_rot_vec_rad
void update_ang_vel_target_from_att_error ( ) ;
2014-02-09 22:59:51 -04:00
2015-11-24 23:28:42 -04:00
// Run the roll angular velocity PID controller and return the output
2015-11-24 17:11:50 -04:00
float rate_bf_to_motor_roll ( float rate_target_rads ) ;
2015-11-24 23:28:42 -04:00
// Run the pitch angular velocity PID controller and return the output
2015-11-24 17:11:50 -04:00
float rate_bf_to_motor_pitch ( float rate_target_rads ) ;
2013-10-12 09:28:18 -03:00
2015-11-24 23:28:42 -04:00
// Run the yaw angular velocity PID controller and return the output
virtual float rate_bf_to_motor_yaw ( float rate_target_rads ) ;
2013-10-12 09:28:18 -03:00
2015-11-24 23:28:42 -04:00
// Compute a throttle value that is adjusted for the tilt angle of the vehicle
2015-07-13 03:00:24 -03:00
virtual float get_boosted_throttle ( float throttle_in ) = 0 ;
2013-10-12 09:28:18 -03:00
2015-11-24 23:28:42 -04:00
// Return angle in radians to be added to roll angle. Used by heli to counteract
// tail rotor thrust in hover. Overloaded by AC_Attitude_Heli to return angle.
2015-11-27 19:31:16 -04:00
virtual float get_roll_trim_rad ( ) { return 0 ; }
2015-11-24 17:11:50 -04:00
2015-11-24 23:28:42 -04:00
// Return the roll axis acceleration limit in radians/s/s
2015-11-24 17:11:50 -04:00
float get_accel_roll_max_radss ( ) { return radians ( _accel_roll_max * 0.01f ) ; }
2015-11-24 23:28:42 -04:00
// Return the pitch axis acceleration limit in radians/s/s
2015-11-24 17:11:50 -04:00
float get_accel_pitch_max_radss ( ) { return radians ( _accel_pitch_max * 0.01f ) ; }
2015-11-24 23:28:42 -04:00
// Return the yaw axis acceleration limit in radians/s/s
2015-11-24 17:11:50 -04:00
float get_accel_yaw_max_radss ( ) { return radians ( _accel_yaw_max * 0.01f ) ; }
2015-11-24 23:28:42 -04:00
// Return the yaw slew rate limit in radians/s
2015-11-24 17:11:50 -04:00
float get_slew_yaw_rads ( ) { return radians ( _slew_yaw * 0.01f ) ; }
2015-11-24 23:28:42 -04:00
// Return the tilt angle limit in radians
2015-11-24 17:11:50 -04:00
float get_tilt_limit_rad ( ) { return radians ( _aparm . angle_max * 0.01f ) ; }
2015-10-13 16:02:21 -03:00
2015-11-24 23:28:42 -04:00
// Maximum rate the yaw target can be updated in Loiter, RTL, Auto flight modes
AP_Float _slew_yaw ;
// Maximum rotation acceleration for earth-frame roll axis
AP_Float _accel_roll_max ;
// Maximum rotation acceleration for earth-frame pitch axis
AP_Float _accel_pitch_max ;
// Maximum rotation acceleration for earth-frame yaw axis
AP_Float _accel_yaw_max ;
// Enable/Disable body frame rate feed forward
AP_Int8 _rate_bf_ff_enabled ;
2016-01-06 23:11:27 -04:00
// Enable/Disable angle boost
AP_Int8 _angle_boost_enabled ;
2016-02-15 02:26:24 -04:00
// angle controller P objects
AC_P _p_angle_roll ;
AC_P _p_angle_pitch ;
AC_P _p_angle_yaw ;
2015-11-24 23:28:42 -04:00
// Intersampling period in seconds
float _dt ;
2015-12-02 18:05:13 -04:00
// This represents a 321-intrinsic rotation from NED frame to the reference (setpoint)
// attitude used in the attitude controller, in radians. Formerly _angle_ef_target.
2015-11-24 23:28:42 -04:00
Vector3f _att_target_euler_rad ;
// This represents an euler axis-angle rotation vector from the vehicle’ s
2015-12-02 18:05:13 -04:00
// estimated attitude to the reference (setpoint) attitude used in the attitude
// controller, in radians in the vehicle body frame of reference. Formerly
// _angle_bf_error.
2015-11-24 23:28:42 -04:00
Vector3f _att_error_rot_vec_rad ;
2015-12-02 18:05:13 -04:00
// This represents the angular velocity of the reference (setpoint) attitude used in
// the attitude controller as 321-intrinsic euler angle derivatives, in radians per
// second. Formerly _rate_ef_desired.
2015-12-05 04:28:48 -04:00
Vector3f _att_target_euler_rate_rads ;
2015-11-24 23:28:42 -04:00
2015-12-02 18:05:13 -04:00
// This represents the angular velocity of the reference (setpoint) attitude used in
// the attitude controller as an angular velocity vector, in radians per second in
// the reference attitude frame. Formerly _rate_bf_desired.
2015-11-24 23:28:42 -04:00
Vector3f _att_target_ang_vel_rads ;
2015-12-02 18:05:13 -04:00
// This represents the reference (setpoint) angular velocity used in the angular
// velocity controller, in radians per second. Formerly _rate_bf_target.
2015-11-24 23:28:42 -04:00
Vector3f _ang_vel_target_rads ;
2016-01-04 04:14:01 -04:00
// throttle provided as input to attitude controller. This does not include angle boost.
// Used only for logging.
float _throttle_in = 0.0f ;
2015-11-24 23:28:42 -04:00
// This represents the throttle increase applied for tilt compensation.
// Used only for logging.
2016-01-03 23:44:45 -04:00
float _angle_boost ;
2015-11-24 23:28:42 -04:00
// Specifies whether the attitude controller should use the acceleration limit
2015-12-08 02:48:17 -04:00
bool _att_ctrl_use_accel_limit ;
2015-11-24 23:28:42 -04:00
// Filtered throttle input - used to limit lean angle when throttle is saturated
LowPassFilterFloat _throttle_in_filt ;
// References to external libraries
2014-01-27 01:08:59 -04:00
const AP_AHRS & _ahrs ;
2014-01-17 22:54:23 -04:00
const AP_Vehicle : : MultiCopter & _aparm ;
2013-10-12 09:28:18 -03:00
AP_Motors & _motors ;
2016-05-27 01:13:02 -03:00
private :
/*
state of control monitoring
*/
struct {
2016-06-09 03:00:57 -03:00
float rms_roll_P ;
float rms_roll_D ;
float rms_pitch_P ;
float rms_pitch_D ;
2016-05-27 01:13:02 -03:00
float rms_yaw ;
} _control_monitor ;
// update state in ControlMonitor
2016-06-09 03:00:57 -03:00
void control_monitor_filter_pid ( float value , float & rms_P ) ;
2016-05-27 01:13:02 -03:00
void control_monitor_update ( void ) ;
public :
// log a CTRL message
void control_monitor_log ( void ) ;
2016-06-01 04:18:58 -03:00
// return current RMS controller filter for each axis
float control_monitor_rms_output_roll ( void ) const ;
float control_monitor_rms_output_pitch ( void ) const ;
float control_monitor_rms_output_yaw ( void ) const ;
2013-10-12 09:28:18 -03:00
} ;
# define AC_ATTITUDE_CONTROL_LOG_FORMAT(msg) { msg, sizeof(AC_AttitudeControl::log_Attitude), \
" ATT " , " cccccCC " , " RollIn,Roll,PitchIn,Pitch,YawIn,Yaw,NavYaw " }