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:
priseborough 2015-01-10 05:34:09 +11:00 committed by Randy Mackay
parent 824425625c
commit d2da16e652

View File

@ -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