AC_AttitudeControl: use new method get_quat_body_to_ned()
This commit is contained in:
parent
3dc2db8d9a
commit
1c52458d72
@ -163,8 +163,7 @@ void AC_AttitudeControl::set_throttle_out_unstabilized(float throttle_in, bool r
|
|||||||
void AC_AttitudeControl::relax_attitude_controllers()
|
void AC_AttitudeControl::relax_attitude_controllers()
|
||||||
{
|
{
|
||||||
// Initialize the attitude variables to the current attitude
|
// Initialize the attitude variables to the current attitude
|
||||||
// TODO add _ahrs.get_quaternion()
|
_ahrs.get_quat_body_to_ned(_attitude_target_quat);
|
||||||
_attitude_target_quat.from_rotation_matrix(_ahrs.get_rotation_body_to_ned());
|
|
||||||
_attitude_target_quat.to_euler(_attitude_target_euler_angle.x, _attitude_target_euler_angle.y, _attitude_target_euler_angle.z);
|
_attitude_target_quat.to_euler(_attitude_target_euler_angle.x, _attitude_target_euler_angle.y, _attitude_target_euler_angle.z);
|
||||||
_attitude_ang_error.initialise();
|
_attitude_ang_error.initialise();
|
||||||
|
|
||||||
@ -400,7 +399,7 @@ void AC_AttitudeControl::input_euler_rate_yaw_euler_angle_pitch_bf_roll(float eu
|
|||||||
|
|
||||||
// Compute attitude error
|
// Compute attitude error
|
||||||
Quaternion attitude_vehicle_quat;
|
Quaternion attitude_vehicle_quat;
|
||||||
attitude_vehicle_quat.from_rotation_matrix(_ahrs.get_rotation_body_to_ned());
|
_ahrs.get_quat_body_to_ned(attitude_vehicle_quat);
|
||||||
|
|
||||||
Quaternion error_quat;
|
Quaternion error_quat;
|
||||||
error_quat = attitude_vehicle_quat.inverse() * _attitude_target_quat;
|
error_quat = attitude_vehicle_quat.inverse() * _attitude_target_quat;
|
||||||
@ -506,7 +505,7 @@ void AC_AttitudeControl::input_rate_bf_roll_pitch_yaw_2(float roll_rate_bf_cds,
|
|||||||
_attitude_target_ang_vel.z = input_shaping_ang_vel(_attitude_target_ang_vel.z, yaw_rate_rads, get_accel_yaw_max_radss(), _dt);
|
_attitude_target_ang_vel.z = input_shaping_ang_vel(_attitude_target_ang_vel.z, yaw_rate_rads, get_accel_yaw_max_radss(), _dt);
|
||||||
|
|
||||||
// Update the unused targets attitude based on current attitude to condition mode change
|
// Update the unused targets attitude based on current attitude to condition mode change
|
||||||
_attitude_target_quat.from_rotation_matrix(_ahrs.get_rotation_body_to_ned());
|
_ahrs.get_quat_body_to_ned(_attitude_target_quat);
|
||||||
_attitude_target_quat.to_euler(_attitude_target_euler_angle.x, _attitude_target_euler_angle.y, _attitude_target_euler_angle.z);
|
_attitude_target_quat.to_euler(_attitude_target_euler_angle.x, _attitude_target_euler_angle.y, _attitude_target_euler_angle.z);
|
||||||
// Convert body-frame angular velocity into euler angle derivative of desired attitude
|
// Convert body-frame angular velocity into euler angle derivative of desired attitude
|
||||||
ang_vel_to_euler_rate(_attitude_target_euler_angle, _attitude_target_ang_vel, _attitude_target_euler_rate);
|
ang_vel_to_euler_rate(_attitude_target_euler_angle, _attitude_target_ang_vel, _attitude_target_euler_rate);
|
||||||
@ -535,9 +534,8 @@ void AC_AttitudeControl::input_rate_bf_roll_pitch_yaw_3(float roll_rate_bf_cds,
|
|||||||
_attitude_target_ang_vel.z = input_shaping_ang_vel(_attitude_target_ang_vel.z, yaw_rate_rads, get_accel_yaw_max_radss(), _dt);
|
_attitude_target_ang_vel.z = input_shaping_ang_vel(_attitude_target_ang_vel.z, yaw_rate_rads, get_accel_yaw_max_radss(), _dt);
|
||||||
|
|
||||||
// Retrieve quaternion vehicle attitude
|
// Retrieve quaternion vehicle attitude
|
||||||
// TODO add _ahrs.get_quaternion()
|
|
||||||
Quaternion attitude_vehicle_quat;
|
Quaternion attitude_vehicle_quat;
|
||||||
attitude_vehicle_quat.from_rotation_matrix(_ahrs.get_rotation_body_to_ned());
|
_ahrs.get_quat_body_to_ned(attitude_vehicle_quat);
|
||||||
|
|
||||||
// Update the unused targets attitude based on current attitude to condition mode change
|
// Update the unused targets attitude based on current attitude to condition mode change
|
||||||
_attitude_target_quat = attitude_vehicle_quat*_attitude_ang_error;
|
_attitude_target_quat = attitude_vehicle_quat*_attitude_ang_error;
|
||||||
@ -588,9 +586,8 @@ void AC_AttitudeControl::input_angle_step_bf_roll_pitch_yaw(float roll_angle_ste
|
|||||||
void AC_AttitudeControl::attitude_controller_run_quat()
|
void AC_AttitudeControl::attitude_controller_run_quat()
|
||||||
{
|
{
|
||||||
// Retrieve quaternion vehicle attitude
|
// Retrieve quaternion vehicle attitude
|
||||||
// TODO add _ahrs.get_quaternion()
|
|
||||||
Quaternion attitude_vehicle_quat;
|
Quaternion attitude_vehicle_quat;
|
||||||
attitude_vehicle_quat.from_rotation_matrix(_ahrs.get_rotation_body_to_ned());
|
_ahrs.get_quat_body_to_ned(attitude_vehicle_quat);
|
||||||
|
|
||||||
// Compute attitude error
|
// Compute attitude error
|
||||||
Vector3f attitude_error_vector;
|
Vector3f attitude_error_vector;
|
||||||
@ -797,9 +794,8 @@ void AC_AttitudeControl::shift_ef_yaw_target(float yaw_shift_cd)
|
|||||||
void AC_AttitudeControl::inertial_frame_reset()
|
void AC_AttitudeControl::inertial_frame_reset()
|
||||||
{
|
{
|
||||||
// Retrieve quaternion vehicle attitude
|
// Retrieve quaternion vehicle attitude
|
||||||
// TODO add _ahrs.get_quaternion()
|
|
||||||
Quaternion attitude_vehicle_quat;
|
Quaternion attitude_vehicle_quat;
|
||||||
attitude_vehicle_quat.from_rotation_matrix(_ahrs.get_rotation_body_to_ned());
|
_ahrs.get_quat_body_to_ned(attitude_vehicle_quat);
|
||||||
|
|
||||||
// Recalculate the target quaternion
|
// Recalculate the target quaternion
|
||||||
_attitude_target_quat = attitude_vehicle_quat * _attitude_ang_error;
|
_attitude_target_quat = attitude_vehicle_quat * _attitude_ang_error;
|
||||||
|
@ -114,7 +114,7 @@ public:
|
|||||||
void reset_rate_controller_I_terms();
|
void reset_rate_controller_I_terms();
|
||||||
|
|
||||||
// Sets attitude target to vehicle attitude
|
// Sets attitude target to vehicle attitude
|
||||||
void set_attitude_target_to_current_attitude() { _attitude_target_quat.from_rotation_matrix(_ahrs.get_rotation_body_to_ned()); }
|
void set_attitude_target_to_current_attitude() { _ahrs.get_quat_body_to_ned(_attitude_target_quat); }
|
||||||
|
|
||||||
// Sets yaw target to vehicle heading
|
// Sets yaw target to vehicle heading
|
||||||
void set_yaw_target_to_current_heading() { shift_ef_yaw_target(degrees(_ahrs.yaw - _attitude_target_euler_angle.z)*100.0f); }
|
void set_yaw_target_to_current_heading() { shift_ef_yaw_target(degrees(_ahrs.yaw - _attitude_target_euler_angle.z)*100.0f); }
|
||||||
|
Loading…
Reference in New Issue
Block a user