AC_AttitudeControl: use new method get_quat_body_to_ned()

This commit is contained in:
Mark Whitehorn 2019-03-06 17:35:33 -07:00 committed by Andrew Tridgell
parent 3dc2db8d9a
commit 1c52458d72
2 changed files with 7 additions and 11 deletions

View File

@ -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;

View File

@ -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); }