From 3c8aa259e6dfc96511652908869ffd995af51028 Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Mon, 16 Aug 2021 16:04:38 +1000 Subject: [PATCH] AP_NavEKF3: added EK3_PRIMARY parameter allows for selection of which IMU to use on startup --- libraries/AP_NavEKF3/AP_NavEKF3.cpp | 33 ++++++++++++++++++----------- libraries/AP_NavEKF3/AP_NavEKF3.h | 1 + 2 files changed, 22 insertions(+), 12 deletions(-) diff --git a/libraries/AP_NavEKF3/AP_NavEKF3.cpp b/libraries/AP_NavEKF3/AP_NavEKF3.cpp index e9d67ec489..53060851a7 100644 --- a/libraries/AP_NavEKF3/AP_NavEKF3.cpp +++ b/libraries/AP_NavEKF3/AP_NavEKF3.cpp @@ -704,6 +704,14 @@ const AP_Param::GroupInfo NavEKF3::var_info2[] = { // @User: Advanced AP_GROUPINFO("GND_EFF_DZ", 7, NavEKF3, _baroGndEffectDeadZone, 4.0f), + // @Param: PRIMARY + // @DisplayName: Primary core number + // @Description: The core number (index in IMU mask) that will be used as the primary EKF core on startup. While disarmed the EKF will force the use of this core. A value of 0 corresponds to the first IMU in EK3_IMU_MASK. + // @Range: 0 2 + // @Increment: 1 + // @User: Advanced + AP_GROUPINFO("PRIMARY", 8, NavEKF3, _primary_core, 0), + AP_GROUPEND }; @@ -810,8 +818,8 @@ bool NavEKF3::InitialiseFilter(void) // set relative error scores for all cores to 0 resetCoreErrors(); - // Set the primary initially to be the lowest index - primary = 0; + // Set the primary initially to be users selected primary + primary = uint8_t(_primary_core) < num_cores? _primary_core : 0; // invalidate shared origin common_origin_valid = false; @@ -956,16 +964,17 @@ void NavEKF3::UpdateFilter(void) } } - if (primary != 0 && core[0].healthy() && !armed) { - // when on the ground and disarmed force the first lane. This - // avoids us ending with with a lottery for which IMU is used - // in each flight. Otherwise the alignment of the timing of - // the lane updates with the timing of GPS updates can lead to - // a lane other than the first one being used as primary for - // some flights. As different IMUs may have quite different - // noise characteristics this leads to inconsistent - // performance - primary = 0; + const uint8_t user_primary = uint8_t(_primary_core) < num_cores? _primary_core : 0; + if (primary != 0 && core[user_primary].healthy() && !armed) { + // when on the ground and disarmed force the selected primary + // core. This avoids us ending with with a lottery for which + // IMU is used in each flight. Otherwise the alignment of the + // timing of the core selection updates with the timing of GPS + // updates can lead to a core other than the first one being + // used as primary for some flights. As different IMUs may + // have quite different noise characteristics this leads to + // inconsistent performance + primary = user_primary; } // align position of inactive sources to ahrs diff --git a/libraries/AP_NavEKF3/AP_NavEKF3.h b/libraries/AP_NavEKF3/AP_NavEKF3.h index b4b4757f63..6e452d5942 100644 --- a/libraries/AP_NavEKF3/AP_NavEKF3.h +++ b/libraries/AP_NavEKF3/AP_NavEKF3.h @@ -427,6 +427,7 @@ private: AP_Int8 _betaMask; // Bitmask controlling when sideslip angle fusion is used to estimate non wind states AP_Float _ognmTestScaleFactor; // Scale factor applied to the thresholds used by the on ground not moving test AP_Float _baroGndEffectDeadZone;// Dead zone applied to positive baro height innovations when in ground effect (m) + AP_Int8 _primary_core; // initial core number // Possible values for _flowUse #define FLOW_USE_NONE 0