Browse Source

mc_att_control_vector: attitude rate D component implemented

sbg
Anton Babushkin 11 years ago
parent
commit
72aa171ef9
  1. 36
      src/modules/mc_att_control_vector/mc_att_control_vector_main.cpp

36
src/modules/mc_att_control_vector/mc_att_control_vector_main.cpp

@ -136,13 +136,18 @@ private: @@ -136,13 +136,18 @@ private:
bool _att_sp_valid; /**< flag if the attitude setpoint is valid */
math::Matrix _K; /**< diagonal gain matrix for position error */
math::Matrix _K_rate; /**< diagonal gain matrix for angular rate error */
math::Matrix _K_rate_p; /**< diagonal gain matrix for angular rate error */
math::Matrix _K_rate_d; /**< diagonal gain matrix for angular rate derivative */
math::Vector3 _rates_prev; /**< angular rates on previous step */
struct {
param_t att_p;
param_t att_rate_p;
param_t att_rate_d;
param_t yaw_p;
param_t yaw_rate_p;
param_t yaw_rate_d;
} _parameter_handles; /**< handles for interesting parameters */
/**
@ -224,7 +229,10 @@ MulticopterAttitudeControl::MulticopterAttitudeControl() : @@ -224,7 +229,10 @@ MulticopterAttitudeControl::MulticopterAttitudeControl() :
/* gain matrices */
_K(3, 3),
_K_rate(3, 3)
_K_rate_p(3, 3),
_K_rate_d(3, 3),
_rates_prev(0.0f, 0.0f, 0.0f)
{
memset(&_att, 0, sizeof(_att));
@ -235,8 +243,10 @@ MulticopterAttitudeControl::MulticopterAttitudeControl() : @@ -235,8 +243,10 @@ MulticopterAttitudeControl::MulticopterAttitudeControl() :
_parameter_handles.att_p = param_find("MC_ATT_P");
_parameter_handles.att_rate_p = param_find("MC_ATTRATE_P");
_parameter_handles.att_rate_d = param_find("MC_ATTRATE_D");
_parameter_handles.yaw_p = param_find("MC_YAWPOS_P");
_parameter_handles.yaw_rate_p = param_find("MC_YAWRATE_P");
_parameter_handles.yaw_rate_d = param_find("MC_YAWRATE_D");
/* fetch initial parameter values */
parameters_update();
@ -271,22 +281,32 @@ MulticopterAttitudeControl::parameters_update() @@ -271,22 +281,32 @@ MulticopterAttitudeControl::parameters_update()
{
float att_p;
float att_rate_p;
float att_rate_d;
float yaw_p;
float yaw_rate_p;
float yaw_rate_d;
param_get(_parameter_handles.att_p, &att_p);
param_get(_parameter_handles.att_rate_p, &att_rate_p);
param_get(_parameter_handles.att_rate_d, &att_rate_d);
param_get(_parameter_handles.yaw_p, &yaw_p);
param_get(_parameter_handles.yaw_rate_p, &yaw_rate_p);
param_get(_parameter_handles.yaw_rate_d, &yaw_rate_d);
_K.setAll(0.0f);
_K(0, 0) = att_p;
_K(1, 1) = att_p;
_K(2, 2) = yaw_p;
_K_rate.setAll(0.0f);
_K_rate(0, 0) = att_rate_p;
_K_rate(1, 1) = att_rate_p;
_K_rate(2, 2) = yaw_rate_p;
_K_rate_p.setAll(0.0f);
_K_rate_p(0, 0) = att_rate_p;
_K_rate_p(1, 1) = att_rate_p;
_K_rate_p(2, 2) = yaw_rate_p;
_K_rate_d.setAll(0.0f);
_K_rate_d(0, 0) = att_rate_d;
_K_rate_d(1, 1) = att_rate_d;
_K_rate_d(2, 2) = yaw_rate_d;
return OK;
}
@ -596,9 +616,11 @@ MulticopterAttitudeControl::task_main() @@ -596,9 +616,11 @@ MulticopterAttitudeControl::task_main()
/* angular rates setpoint*/
math::Vector3 rates_sp = _K * e_R;
/* feed forward yaw setpoint rate */
rates_sp(2) += yaw_sp_move_rate;
math::Vector3 control = _K_rate * (rates_sp - rates);
math::Vector3 control = _K_rate_p * (rates_sp - rates) + _K_rate_d * (_rates_prev - rates) / fmaxf(dt, 0.003f);
_rates_prev = rates;
/* publish the attitude rates setpoint */
_rates_sp.roll = rates_sp(0);

Loading…
Cancel
Save