mirror of https://github.com/ArduPilot/ardupilot
AP_NavEKF2: added EK2_OPTIONS
this allows for disabling of external navigation data (such as visual odomotry) in EKF2. This is very useful when using EKF2 as a fallback and truth reference when testing visual odomotry on EKF3
This commit is contained in:
parent
2e1364e3b0
commit
1b4fb403f2
|
@ -599,6 +599,13 @@ const AP_Param::GroupInfo NavEKF2::var_info[] = {
|
|||
// @RebootRequired: True
|
||||
AP_GROUPINFO("GSF_RST_MAX", 57, NavEKF2, _gsfResetMaxCount, 2),
|
||||
|
||||
// @Param: OPTIONS
|
||||
// @DisplayName: Optional EKF behaviour
|
||||
// @Description: optional EKF2 behaviour. Disabling external navigation prevents use of external vision data in the EKF2 solution
|
||||
// @Bitmask: 0:DisableExternalNavigation
|
||||
// @User: Advanced
|
||||
AP_GROUPINFO("OPTIONS", 58, NavEKF2, _options, 0),
|
||||
|
||||
AP_GROUPEND
|
||||
};
|
||||
|
||||
|
@ -1514,8 +1521,7 @@ void NavEKF2::updateLaneSwitchPosDownResetData(uint8_t new_primary, uint8_t old_
|
|||
void NavEKF2::writeExtNavData(const Vector3f &pos, const Quaternion &quat, float posErr, float angErr, uint32_t timeStamp_ms, uint16_t delay_ms, uint32_t resetTime_ms)
|
||||
{
|
||||
AP::dal().writeExtNavData(pos, quat, posErr, angErr, timeStamp_ms, delay_ms, resetTime_ms);
|
||||
|
||||
if (core) {
|
||||
if (!option_is_set(Option::DisableExternalNav) && core) {
|
||||
for (uint8_t i=0; i<num_cores; i++) {
|
||||
core[i].writeExtNavData(pos, quat, posErr, angErr, timeStamp_ms, delay_ms, resetTime_ms);
|
||||
}
|
||||
|
@ -1568,8 +1574,7 @@ void NavEKF2::writeDefaultAirSpeed(float airspeed)
|
|||
void NavEKF2::writeExtNavVelData(const Vector3f &vel, float err, uint32_t timeStamp_ms, uint16_t delay_ms)
|
||||
{
|
||||
AP::dal().writeExtNavVelData(vel, err, timeStamp_ms, delay_ms);
|
||||
|
||||
if (core) {
|
||||
if (!option_is_set(Option::DisableExternalNav) && core) {
|
||||
for (uint8_t i=0; i<num_cores; i++) {
|
||||
core[i].writeExtNavVelData(vel, err, timeStamp_ms, delay_ms);
|
||||
}
|
||||
|
|
|
@ -364,6 +364,17 @@ private:
|
|||
AP_Int8 _gsfRunMask; // mask controlling which EKF2 instances run a separate EKF-GSF yaw estimator
|
||||
AP_Int8 _gsfUseMask; // mask controlling which EKF2 instances will use EKF-GSF yaw estimator data to assit with yaw resets
|
||||
AP_Int8 _gsfResetMaxCount; // maximum number of times the EKF2 is allowed to reset it's yaw to the EKF-GSF estimate
|
||||
AP_Int32 _options; // optional behaviour bitmask
|
||||
|
||||
// enum for processing options
|
||||
enum class Option {
|
||||
DisableExternalNav = (1U<<0),
|
||||
};
|
||||
|
||||
// return true if an option is set
|
||||
bool option_is_set(Option option) const {
|
||||
return (uint32_t(option) & uint32_t(_options)) != 0;
|
||||
}
|
||||
|
||||
// Possible values for _flowUse
|
||||
#define FLOW_USE_NONE 0
|
||||
|
|
Loading…
Reference in New Issue