mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-25 10:08:28 -04:00
AP_NavEKF3: rename source and yawFusionMethod from EXTERNAL to GPS
This commit is contained in:
parent
77af6df730
commit
27c998ad94
@ -1070,7 +1070,7 @@ bool NavEKF3::pre_arm_check(char *failure_msg, uint8_t failure_msg_len) const
|
|||||||
// check if using compass (i.e. EK3_SRCn_YAW) with deprecated MAG_CAL values (5 was EXTERNAL_YAW, 6 was EXTERNAL_YAW_FALLBACK)
|
// check if using compass (i.e. EK3_SRCn_YAW) with deprecated MAG_CAL values (5 was EXTERNAL_YAW, 6 was EXTERNAL_YAW_FALLBACK)
|
||||||
const int8_t magCalParamVal = _magCal.get();
|
const int8_t magCalParamVal = _magCal.get();
|
||||||
const AP_NavEKF_Source::SourceYaw yaw_source = sources.getYawSource();
|
const AP_NavEKF_Source::SourceYaw yaw_source = sources.getYawSource();
|
||||||
if (((magCalParamVal == 5) || (magCalParamVal == 6)) && (yaw_source != AP_NavEKF_Source::SourceYaw::EXTERNAL)) {
|
if (((magCalParamVal == 5) || (magCalParamVal == 6)) && (yaw_source != AP_NavEKF_Source::SourceYaw::GPS)) {
|
||||||
// yaw source is configured to use compass but MAG_CAL valid is deprecated
|
// yaw source is configured to use compass but MAG_CAL valid is deprecated
|
||||||
AP::dal().snprintf(failure_msg, failure_msg_len, "EK3_MAG_CAL and EK3_SRC1_YAW inconsistent");
|
AP::dal().snprintf(failure_msg, failure_msg_len, "EK3_MAG_CAL and EK3_SRC1_YAW inconsistent");
|
||||||
return false;
|
return false;
|
||||||
@ -1672,11 +1672,11 @@ void NavEKF3::convert_parameters()
|
|||||||
switch (_magCal.get()) {
|
switch (_magCal.get()) {
|
||||||
case 5:
|
case 5:
|
||||||
// EK3_MAG_CAL = 5 (External Yaw sensor). We rely on effective_magCal to interpret old "5" values as "Never"
|
// EK3_MAG_CAL = 5 (External Yaw sensor). We rely on effective_magCal to interpret old "5" values as "Never"
|
||||||
AP_Param::set_and_save_by_name("EK3_SRC1_YAW", (int8_t)AP_NavEKF_Source::SourceYaw::EXTERNAL);
|
AP_Param::set_and_save_by_name("EK3_SRC1_YAW", (int8_t)AP_NavEKF_Source::SourceYaw::GPS);
|
||||||
break;
|
break;
|
||||||
case 6:
|
case 6:
|
||||||
// EK3_MAG_CAL = 6 (ExtYaw with Compass fallback). We rely on effective_magCal to interpret old "6" values as "When Flying"
|
// EK3_MAG_CAL = 6 (ExtYaw with Compass fallback). We rely on effective_magCal to interpret old "6" values as "When Flying"
|
||||||
AP_Param::set_and_save_by_name("EK3_SRC1_YAW", (int8_t)AP_NavEKF_Source::SourceYaw::EXTERNAL_COMPASS_FALLBACK);
|
AP_Param::set_and_save_by_name("EK3_SRC1_YAW", (int8_t)AP_NavEKF_Source::SourceYaw::GPS_COMPASS_FALLBACK);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
// do nothing
|
// do nothing
|
||||||
|
@ -513,7 +513,7 @@ bool NavEKF3_core::use_compass(void) const
|
|||||||
{
|
{
|
||||||
const AP_NavEKF_Source::SourceYaw yaw_source = frontend->sources.getYawSource();
|
const AP_NavEKF_Source::SourceYaw yaw_source = frontend->sources.getYawSource();
|
||||||
if ((yaw_source != AP_NavEKF_Source::SourceYaw::COMPASS) &&
|
if ((yaw_source != AP_NavEKF_Source::SourceYaw::COMPASS) &&
|
||||||
(yaw_source != AP_NavEKF_Source::SourceYaw::EXTERNAL_COMPASS_FALLBACK)) {
|
(yaw_source != AP_NavEKF_Source::SourceYaw::GPS_COMPASS_FALLBACK)) {
|
||||||
// not using compass as a yaw source
|
// not using compass as a yaw source
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -528,7 +528,7 @@ bool NavEKF3_core::use_compass(void) const
|
|||||||
bool NavEKF3_core::using_external_yaw(void) const
|
bool NavEKF3_core::using_external_yaw(void) const
|
||||||
{
|
{
|
||||||
const AP_NavEKF_Source::SourceYaw yaw_source = frontend->sources.getYawSource();
|
const AP_NavEKF_Source::SourceYaw yaw_source = frontend->sources.getYawSource();
|
||||||
if (yaw_source == AP_NavEKF_Source::SourceYaw::EXTERNAL || yaw_source == AP_NavEKF_Source::SourceYaw::EXTERNAL_COMPASS_FALLBACK ||
|
if (yaw_source == AP_NavEKF_Source::SourceYaw::GPS || yaw_source == AP_NavEKF_Source::SourceYaw::GPS_COMPASS_FALLBACK ||
|
||||||
yaw_source == AP_NavEKF_Source::SourceYaw::GSF || !use_compass()) {
|
yaw_source == AP_NavEKF_Source::SourceYaw::GSF || !use_compass()) {
|
||||||
return imuSampleTime_ms - last_gps_yaw_fusion_ms < 5000 || imuSampleTime_ms - lastSynthYawTime_ms < 5000;
|
return imuSampleTime_ms - last_gps_yaw_fusion_ms < 5000 || imuSampleTime_ms - lastSynthYawTime_ms < 5000;
|
||||||
}
|
}
|
||||||
@ -599,7 +599,7 @@ void NavEKF3_core::checkGyroCalStatus(void)
|
|||||||
// check delta angle bias variances
|
// check delta angle bias variances
|
||||||
const float delAngBiasVarMax = sq(radians(0.15f * dtEkfAvg));
|
const float delAngBiasVarMax = sq(radians(0.15f * dtEkfAvg));
|
||||||
const AP_NavEKF_Source::SourceYaw yaw_source = frontend->sources.getYawSource();
|
const AP_NavEKF_Source::SourceYaw yaw_source = frontend->sources.getYawSource();
|
||||||
if (!use_compass() && (yaw_source != AP_NavEKF_Source::SourceYaw::EXTERNAL) && (yaw_source != AP_NavEKF_Source::SourceYaw::EXTERNAL_COMPASS_FALLBACK) &&
|
if (!use_compass() && (yaw_source != AP_NavEKF_Source::SourceYaw::GPS) && (yaw_source != AP_NavEKF_Source::SourceYaw::GPS_COMPASS_FALLBACK) &&
|
||||||
(yaw_source != AP_NavEKF_Source::SourceYaw::EXTNAV)) {
|
(yaw_source != AP_NavEKF_Source::SourceYaw::EXTNAV)) {
|
||||||
// rotate the variances into earth frame and evaluate horizontal terms only as yaw component is poorly observable without a yaw reference
|
// rotate the variances into earth frame and evaluate horizontal terms only as yaw component is poorly observable without a yaw reference
|
||||||
// which can make this check fail
|
// which can make this check fail
|
||||||
|
@ -223,8 +223,8 @@ void NavEKF3_core::SelectMagFusion()
|
|||||||
// flight using the output from the GSF yaw estimator.
|
// flight using the output from the GSF yaw estimator.
|
||||||
if ((yaw_source == AP_NavEKF_Source::SourceYaw::GSF) ||
|
if ((yaw_source == AP_NavEKF_Source::SourceYaw::GSF) ||
|
||||||
(!use_compass() &&
|
(!use_compass() &&
|
||||||
yaw_source != AP_NavEKF_Source::SourceYaw::EXTERNAL &&
|
yaw_source != AP_NavEKF_Source::SourceYaw::GPS &&
|
||||||
yaw_source != AP_NavEKF_Source::SourceYaw::EXTERNAL_COMPASS_FALLBACK &&
|
yaw_source != AP_NavEKF_Source::SourceYaw::GPS_COMPASS_FALLBACK &&
|
||||||
yaw_source != AP_NavEKF_Source::SourceYaw::EXTNAV)) {
|
yaw_source != AP_NavEKF_Source::SourceYaw::EXTNAV)) {
|
||||||
|
|
||||||
// because this type of reset event is not as time critical, require a continuous history of valid estimates
|
// because this type of reset event is not as time critical, require a continuous history of valid estimates
|
||||||
@ -259,14 +259,14 @@ void NavEKF3_core::SelectMagFusion()
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Handle case where we are using GPS yaw sensor instead of a magnetomer
|
// Handle case where we are using GPS yaw sensor instead of a magnetomer
|
||||||
if (yaw_source == AP_NavEKF_Source::SourceYaw::EXTERNAL || yaw_source == AP_NavEKF_Source::SourceYaw::EXTERNAL_COMPASS_FALLBACK) {
|
if (yaw_source == AP_NavEKF_Source::SourceYaw::GPS || yaw_source == AP_NavEKF_Source::SourceYaw::GPS_COMPASS_FALLBACK) {
|
||||||
bool have_fused_gps_yaw = false;
|
bool have_fused_gps_yaw = false;
|
||||||
if (storedYawAng.recall(yawAngDataDelayed,imuDataDelayed.time_ms)) {
|
if (storedYawAng.recall(yawAngDataDelayed,imuDataDelayed.time_ms)) {
|
||||||
if (tiltAlignComplete && (!yawAlignComplete || yaw_source_reset)) {
|
if (tiltAlignComplete && (!yawAlignComplete || yaw_source_reset)) {
|
||||||
alignYawAngle(yawAngDataDelayed);
|
alignYawAngle(yawAngDataDelayed);
|
||||||
yaw_source_reset = false;
|
yaw_source_reset = false;
|
||||||
} else if (tiltAlignComplete && yawAlignComplete) {
|
} else if (tiltAlignComplete && yawAlignComplete) {
|
||||||
fuseEulerYaw(yawFusionMethod::EXTERNAL);
|
fuseEulerYaw(yawFusionMethod::GPS);
|
||||||
}
|
}
|
||||||
have_fused_gps_yaw = true;
|
have_fused_gps_yaw = true;
|
||||||
last_gps_yaw_fusion_ms = imuSampleTime_ms;
|
last_gps_yaw_fusion_ms = imuSampleTime_ms;
|
||||||
@ -286,7 +286,7 @@ void NavEKF3_core::SelectMagFusion()
|
|||||||
lastSynthYawTime_ms = imuSampleTime_ms;
|
lastSynthYawTime_ms = imuSampleTime_ms;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (yaw_source == AP_NavEKF_Source::SourceYaw::EXTERNAL) {
|
if (yaw_source == AP_NavEKF_Source::SourceYaw::GPS) {
|
||||||
// no fallback
|
// no fallback
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -362,9 +362,9 @@ void NavEKF3_core::SelectMagFusion()
|
|||||||
magTimeout = true;
|
magTimeout = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (yaw_source != AP_NavEKF_Source::SourceYaw::EXTERNAL_COMPASS_FALLBACK) {
|
if (yaw_source != AP_NavEKF_Source::SourceYaw::GPS_COMPASS_FALLBACK) {
|
||||||
// check for and read new magnetometer measurements. We don't
|
// check for and read new magnetometer measurements. We don't
|
||||||
// read for EXTERNAL_COMPASS_FALLBACK as it has already been read
|
// read for GPS_COMPASS_FALLBACK as it has already been read
|
||||||
// above
|
// above
|
||||||
readMagData();
|
readMagData();
|
||||||
}
|
}
|
||||||
@ -375,7 +375,7 @@ void NavEKF3_core::SelectMagFusion()
|
|||||||
// Control reset of yaw and magnetic field states if we are using compass data
|
// Control reset of yaw and magnetic field states if we are using compass data
|
||||||
if (magDataToFuse) {
|
if (magDataToFuse) {
|
||||||
if (yaw_source_reset && (yaw_source == AP_NavEKF_Source::SourceYaw::COMPASS ||
|
if (yaw_source_reset && (yaw_source == AP_NavEKF_Source::SourceYaw::COMPASS ||
|
||||||
yaw_source == AP_NavEKF_Source::SourceYaw::EXTERNAL_COMPASS_FALLBACK)) {
|
yaw_source == AP_NavEKF_Source::SourceYaw::GPS_COMPASS_FALLBACK)) {
|
||||||
magYawResetRequest = true;
|
magYawResetRequest = true;
|
||||||
yaw_source_reset = false;
|
yaw_source_reset = false;
|
||||||
}
|
}
|
||||||
@ -887,7 +887,7 @@ bool NavEKF3_core::fuseEulerYaw(yawFusionMethod method)
|
|||||||
// yaw measurement error variance (rad^2)
|
// yaw measurement error variance (rad^2)
|
||||||
float R_YAW;
|
float R_YAW;
|
||||||
switch (method) {
|
switch (method) {
|
||||||
case yawFusionMethod::EXTERNAL:
|
case yawFusionMethod::GPS:
|
||||||
R_YAW = sq(yawAngDataDelayed.yawAngErr);
|
R_YAW = sq(yawAngDataDelayed.yawAngErr);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -913,7 +913,7 @@ bool NavEKF3_core::fuseEulerYaw(yawFusionMethod method)
|
|||||||
// determine if a 321 or 312 Euler sequence is best
|
// determine if a 321 or 312 Euler sequence is best
|
||||||
rotationOrder order;
|
rotationOrder order;
|
||||||
switch (method) {
|
switch (method) {
|
||||||
case yawFusionMethod::EXTERNAL:
|
case yawFusionMethod::GPS:
|
||||||
order = yawAngDataDelayed.order;
|
order = yawAngDataDelayed.order;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -1074,7 +1074,7 @@ bool NavEKF3_core::fuseEulerYaw(yawFusionMethod method)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case yawFusionMethod::EXTERNAL:
|
case yawFusionMethod::GPS:
|
||||||
// both external sensor yaw and last yaw when static are stored in yawAngDataDelayed.yawAng
|
// both external sensor yaw and last yaw when static are stored in yawAngDataDelayed.yawAng
|
||||||
innovYaw = wrap_PI(yawAngPredicted - yawAngDataDelayed.yawAng);
|
innovYaw = wrap_PI(yawAngPredicted - yawAngDataDelayed.yawAng);
|
||||||
break;
|
break;
|
||||||
|
@ -1290,7 +1290,7 @@ float NavEKF3_core::MagDeclination(void) const
|
|||||||
void NavEKF3_core::updateMovementCheck(void)
|
void NavEKF3_core::updateMovementCheck(void)
|
||||||
{
|
{
|
||||||
const AP_NavEKF_Source::SourceYaw yaw_source = frontend->sources.getYawSource();
|
const AP_NavEKF_Source::SourceYaw yaw_source = frontend->sources.getYawSource();
|
||||||
const bool runCheck = onGround && (yaw_source == AP_NavEKF_Source::SourceYaw::EXTERNAL || yaw_source == AP_NavEKF_Source::SourceYaw::EXTERNAL_COMPASS_FALLBACK ||
|
const bool runCheck = onGround && (yaw_source == AP_NavEKF_Source::SourceYaw::GPS || yaw_source == AP_NavEKF_Source::SourceYaw::GPS_COMPASS_FALLBACK ||
|
||||||
yaw_source == AP_NavEKF_Source::SourceYaw::EXTNAV || yaw_source == AP_NavEKF_Source::SourceYaw::GSF || !use_compass());
|
yaw_source == AP_NavEKF_Source::SourceYaw::EXTNAV || yaw_source == AP_NavEKF_Source::SourceYaw::GSF || !use_compass());
|
||||||
if (!runCheck)
|
if (!runCheck)
|
||||||
{
|
{
|
||||||
|
@ -123,7 +123,7 @@ bool NavEKF3_core::setup_core(uint8_t _imu_index, uint8_t _core_index)
|
|||||||
// initialise to same length of IMU to allow for multiple wheel sensors
|
// initialise to same length of IMU to allow for multiple wheel sensors
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if(frontend->sources.ext_yaw_enabled() && !storedYawAng.init(obs_buffer_length)) {
|
if(frontend->sources.gps_yaw_enabled() && !storedYawAng.init(obs_buffer_length)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
// Note: the use of dual range finders potentially doubles the amount of data to be stored
|
// Note: the use of dual range finders potentially doubles the amount of data to be stored
|
||||||
|
@ -621,7 +621,7 @@ private:
|
|||||||
// specifies the method to be used when fusing yaw observations
|
// specifies the method to be used when fusing yaw observations
|
||||||
enum class yawFusionMethod {
|
enum class yawFusionMethod {
|
||||||
MAGNETOMETER=0,
|
MAGNETOMETER=0,
|
||||||
EXTERNAL=1,
|
GPS=1,
|
||||||
GSF=2,
|
GSF=2,
|
||||||
STATIC=3,
|
STATIC=3,
|
||||||
PREDICTED=4,
|
PREDICTED=4,
|
||||||
|
Loading…
Reference in New Issue
Block a user