mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-09 17:38:32 -04:00
AP_NavEKF: Consistently set timeout flags whenever aiding is inhibited
This ensures the position and velocity measurement status will be set as timed out immediately after use of those measurements is inhibited. This will improve the timeliness of filter status reporting.
This commit is contained in:
parent
824425625c
commit
d2da16e652
@ -748,6 +748,8 @@ void NavEKF::SelectVelPosFusion()
|
|||||||
constVelMode = false; // always clear constant velocity mode if constant velocity mode is active
|
constVelMode = false; // always clear constant velocity mode if constant velocity mode is active
|
||||||
constPosMode = true;
|
constPosMode = true;
|
||||||
PV_AidingMode = AID_NONE;
|
PV_AidingMode = AID_NONE;
|
||||||
|
posTimeout = true;
|
||||||
|
velTimeout = true;
|
||||||
// reset the velocity
|
// reset the velocity
|
||||||
ResetVelocity();
|
ResetVelocity();
|
||||||
// store the current position to be used to keep reporting the last known position
|
// store the current position to be used to keep reporting the last known position
|
||||||
@ -4309,8 +4311,6 @@ void NavEKF::InitialiseVariables()
|
|||||||
|
|
||||||
// initialise other variables
|
// initialise other variables
|
||||||
gpsNoiseScaler = 1.0f;
|
gpsNoiseScaler = 1.0f;
|
||||||
velTimeout = true;
|
|
||||||
posTimeout = true;
|
|
||||||
hgtTimeout = true;
|
hgtTimeout = true;
|
||||||
magTimeout = true;
|
magTimeout = true;
|
||||||
tasTimeout = true;
|
tasTimeout = true;
|
||||||
@ -4363,6 +4363,8 @@ void NavEKF::InitialiseVariables()
|
|||||||
lastConstVelMode = false;
|
lastConstVelMode = false;
|
||||||
heldVelNE.zero();
|
heldVelNE.zero();
|
||||||
PV_AidingMode = AID_NONE;
|
PV_AidingMode = AID_NONE;
|
||||||
|
posTimeout = true;
|
||||||
|
velTimeout = true;
|
||||||
gpsVelGlitchOffset.zero();
|
gpsVelGlitchOffset.zero();
|
||||||
vehicleArmed = false;
|
vehicleArmed = false;
|
||||||
prevVehicleArmed = false;
|
prevVehicleArmed = false;
|
||||||
@ -4561,6 +4563,8 @@ void NavEKF::performArmingChecks()
|
|||||||
// set various useage modes based on the condition at arming. These are then held until the vehicle is disarmed.
|
// set various useage modes based on the condition at arming. These are then held until the vehicle is disarmed.
|
||||||
if (!vehicleArmed) {
|
if (!vehicleArmed) {
|
||||||
PV_AidingMode = AID_NONE; // When dis-armed, we only estimate orientation & height using the constant position mode
|
PV_AidingMode = AID_NONE; // When dis-armed, we only estimate orientation & height using the constant position mode
|
||||||
|
posTimeout = true;
|
||||||
|
velTimeout = true;
|
||||||
constPosMode = true;
|
constPosMode = true;
|
||||||
constVelMode = false; // always clear constant velocity mode if constant position mode is active
|
constVelMode = false; // always clear constant velocity mode if constant position mode is active
|
||||||
lastConstVelMode = false;
|
lastConstVelMode = false;
|
||||||
@ -4599,6 +4603,8 @@ void NavEKF::performArmingChecks()
|
|||||||
// Always turn aiding off when the vehicle is disarmed
|
// Always turn aiding off when the vehicle is disarmed
|
||||||
if (!vehicleArmed) {
|
if (!vehicleArmed) {
|
||||||
PV_AidingMode = AID_NONE;
|
PV_AidingMode = AID_NONE;
|
||||||
|
posTimeout = true;
|
||||||
|
velTimeout = true;
|
||||||
// set constant position mode if aiding is inhibited
|
// set constant position mode if aiding is inhibited
|
||||||
constPosMode = true;
|
constPosMode = true;
|
||||||
constVelMode = false; // always clear constant velocity mode if constant position mode is active
|
constVelMode = false; // always clear constant velocity mode if constant position mode is active
|
||||||
|
Loading…
Reference in New Issue
Block a user