AP_AHRS: add get_quaternion

This commit is contained in:
Randy Mackay 2020-04-01 10:08:54 +09:00
parent e1c623183e
commit b0b78e974b
5 changed files with 45 additions and 0 deletions

View File

@ -392,6 +392,8 @@ public:
return _sin_yaw; return _sin_yaw;
} }
// return the quaternion defining the rotation from NED to XYZ (body) axes
virtual bool get_quaternion(Quaternion &quat) const WARN_IF_UNUSED = 0;
// return secondary attitude solution if available, as eulers in radians // return secondary attitude solution if available, as eulers in radians
virtual bool get_secondary_attitude(Vector3f &eulers) const WARN_IF_UNUSED { virtual bool get_secondary_attitude(Vector3f &eulers) const WARN_IF_UNUSED {

View File

@ -473,6 +473,13 @@ bool AP_AHRS_DCM::use_compass(void)
return true; return true;
} }
// return the quaternion defining the rotation from NED to XYZ (body) axes
bool AP_AHRS_DCM::get_quaternion(Quaternion &quat) const
{
quat.from_rotation_matrix(_dcm_matrix);
return true;
}
// yaw drift correction using the compass or GPS // yaw drift correction using the compass or GPS
// this function prodoces the _omega_yaw_P vector, and also // this function prodoces the _omega_yaw_P vector, and also
// contributes to the _omega_I.z long term yaw drift estimate // contributes to the _omega_I.z long term yaw drift estimate

View File

@ -96,6 +96,9 @@ public:
bool use_compass() override; bool use_compass() override;
// return the quaternion defining the rotation from NED to XYZ (body) axes
bool get_quaternion(Quaternion &quat) const override WARN_IF_UNUSED;
bool set_home(const Location &loc) override WARN_IF_UNUSED; bool set_home(const Location &loc) override WARN_IF_UNUSED;
void estimate_wind(void); void estimate_wind(void);

View File

@ -545,6 +545,36 @@ bool AP_AHRS_NavEKF::use_compass(void)
return AP_AHRS_DCM::use_compass(); return AP_AHRS_DCM::use_compass();
} }
// return the quaternion defining the rotation from NED to XYZ (body) axes
bool AP_AHRS_NavEKF::get_quaternion(Quaternion &quat) const
{
switch (active_EKF_type()) {
case EKFType::NONE:
return AP_AHRS_DCM::get_quaternion(quat);
#if HAL_NAVEKF2_AVAILABLE
case EKFType::TWO:
EKF2.getQuaternion(-1, quat);
return _ekf2_started;
#endif
#if HAL_NAVEKF3_AVAILABLE
case EKFType::THREE:
EKF3.getQuaternion(-1, quat);
return _ekf3_started;
#endif
#if CONFIG_HAL_BOARD == HAL_BOARD_SITL
case EKFType::SITL:
if (_sitl) {
const struct SITL::sitl_fdm &fdm = _sitl->state;
quat = fdm.quaternion;
return true;
} else {
return false;
}
#endif
}
// since there is no default case above, this is unreachable
return false;
}
// return secondary attitude solution if available, as eulers in radians // return secondary attitude solution if available, as eulers in radians
bool AP_AHRS_NavEKF::get_secondary_attitude(Vector3f &eulers) const bool AP_AHRS_NavEKF::get_secondary_attitude(Vector3f &eulers) const

View File

@ -115,6 +115,9 @@ public:
} }
#endif #endif
// return the quaternion defining the rotation from NED to XYZ (body) axes
bool get_quaternion(Quaternion &quat) const override WARN_IF_UNUSED;
// return secondary attitude solution if available, as eulers in radians // return secondary attitude solution if available, as eulers in radians
bool get_secondary_attitude(Vector3f &eulers) const override; bool get_secondary_attitude(Vector3f &eulers) const override;