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
|
// @RebootRequired: True
|
||||||
AP_GROUPINFO("GSF_RST_MAX", 57, NavEKF2, _gsfResetMaxCount, 2),
|
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
|
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)
|
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);
|
AP::dal().writeExtNavData(pos, quat, posErr, angErr, timeStamp_ms, delay_ms, resetTime_ms);
|
||||||
|
if (!option_is_set(Option::DisableExternalNav) && core) {
|
||||||
if (core) {
|
|
||||||
for (uint8_t i=0; i<num_cores; i++) {
|
for (uint8_t i=0; i<num_cores; i++) {
|
||||||
core[i].writeExtNavData(pos, quat, posErr, angErr, timeStamp_ms, delay_ms, resetTime_ms);
|
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)
|
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);
|
AP::dal().writeExtNavVelData(vel, err, timeStamp_ms, delay_ms);
|
||||||
|
if (!option_is_set(Option::DisableExternalNav) && core) {
|
||||||
if (core) {
|
|
||||||
for (uint8_t i=0; i<num_cores; i++) {
|
for (uint8_t i=0; i<num_cores; i++) {
|
||||||
core[i].writeExtNavVelData(vel, err, timeStamp_ms, delay_ms);
|
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 _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 _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_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
|
// Possible values for _flowUse
|
||||||
#define FLOW_USE_NONE 0
|
#define FLOW_USE_NONE 0
|
||||||
|
Loading…
Reference in New Issue
Block a user