mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-10 09:58:28 -04:00
AP_NavEKF3: pos timeout or glitch does not reset vel if fusing successfully
vel is not reset if GPS velocity, optical flow, visual odometry or wheel encoders are successfully being fused
This commit is contained in:
parent
3b38aa6d7b
commit
b726630ef4
@ -306,7 +306,7 @@ void NavEKF3_core::setAidingMode()
|
|||||||
} else if (posAidLossCritical) {
|
} else if (posAidLossCritical) {
|
||||||
// if the loss of position is critical, declare all sources of position aiding as being timed out
|
// if the loss of position is critical, declare all sources of position aiding as being timed out
|
||||||
posTimeout = true;
|
posTimeout = true;
|
||||||
velTimeout = true;
|
velTimeout = !optFlowUsed && !gpsVelUsed && !bodyOdmUsed;
|
||||||
rngBcnTimeout = true;
|
rngBcnTimeout = true;
|
||||||
gpsNotAvailable = true;
|
gpsNotAvailable = true;
|
||||||
|
|
||||||
|
@ -670,11 +670,8 @@ void NavEKF3_core::FuseVelPosNED()
|
|||||||
if (posTimeout || ((P[8][8] + P[7][7]) > sq(float(frontend->_gpsGlitchRadiusMax)))) {
|
if (posTimeout || ((P[8][8] + P[7][7]) > sq(float(frontend->_gpsGlitchRadiusMax)))) {
|
||||||
// reset the position to the current external sensor position
|
// reset the position to the current external sensor position
|
||||||
ResetPosition(resetDataSource::DEFAULT);
|
ResetPosition(resetDataSource::DEFAULT);
|
||||||
// reset the velocity to the external sensor velocity
|
|
||||||
ResetVelocity(resetDataSource::DEFAULT);
|
|
||||||
// don't fuse external sensor data on this time step
|
// don't fuse external sensor data on this time step
|
||||||
fusePosData = false;
|
fusePosData = false;
|
||||||
fuseVelData = false;
|
|
||||||
// Reset the position variances and corresponding covariances to a value that will pass the checks
|
// Reset the position variances and corresponding covariances to a value that will pass the checks
|
||||||
zeroRows(P,7,8);
|
zeroRows(P,7,8);
|
||||||
zeroCols(P,7,8);
|
zeroCols(P,7,8);
|
||||||
@ -682,7 +679,13 @@ void NavEKF3_core::FuseVelPosNED()
|
|||||||
P[8][8] = P[7][7];
|
P[8][8] = P[7][7];
|
||||||
// Reset the normalised innovation to avoid failing the bad fusion tests
|
// Reset the normalised innovation to avoid failing the bad fusion tests
|
||||||
posTestRatio = 0.0f;
|
posTestRatio = 0.0f;
|
||||||
velTestRatio = 0.0f;
|
// also reset velocity if it has timed out
|
||||||
|
if (velTimeout) {
|
||||||
|
// reset the velocity to the external sensor velocity
|
||||||
|
ResetVelocity(resetDataSource::DEFAULT);
|
||||||
|
fuseVelData = false;
|
||||||
|
velTestRatio = 0.0f;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
posHealth = false;
|
posHealth = false;
|
||||||
|
Loading…
Reference in New Issue
Block a user