mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-24 09:38:29 -04:00
AP_NavEKF: Fix bug that resets position to origin when vehicle arms
This commit is contained in:
parent
b8d3da3846
commit
9f552eaa4b
@ -452,11 +452,14 @@ void NavEKF::ResetPosition(void)
|
|||||||
// write to state vector and compensate for GPS latency
|
// write to state vector and compensate for GPS latency
|
||||||
state.position.x = gpsPosNE.x + gpsPosGlitchOffsetNE.x + 0.001f*velNED.x*float(_msecPosDelay);
|
state.position.x = gpsPosNE.x + gpsPosGlitchOffsetNE.x + 0.001f*velNED.x*float(_msecPosDelay);
|
||||||
state.position.y = gpsPosNE.y + gpsPosGlitchOffsetNE.y + 0.001f*velNED.y*float(_msecPosDelay);
|
state.position.y = gpsPosNE.y + gpsPosGlitchOffsetNE.y + 0.001f*velNED.y*float(_msecPosDelay);
|
||||||
|
// the estimated states at the last GPS measurement are set equal to the GPS measurement to prevent transients on the first fusion
|
||||||
|
statesAtPosTime.position.x = gpsPosNE.x;
|
||||||
|
statesAtPosTime.position.y = gpsPosNE.y;
|
||||||
}
|
}
|
||||||
// stored horizontal position states to prevent subsequent GPS measurements from being rejected
|
// stored horizontal position states to prevent subsequent GPS measurements from being rejected
|
||||||
for (uint8_t i=0; i<=49; i++){
|
for (uint8_t i=0; i<=49; i++){
|
||||||
storedStates[i].position[0] = state.position[0];
|
storedStates[i].position.x = state.position.x;
|
||||||
storedStates[i].position[1] = state.position[1];
|
storedStates[i].position.y = state.position.y;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4617,10 +4620,16 @@ void NavEKF::performArmingChecks()
|
|||||||
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
|
||||||
} else {
|
} else {
|
||||||
PV_AidingMode = AID_ABSOLUTE; // we have GPS data and can estimate all vehicle states
|
PV_AidingMode = AID_ABSOLUTE; // we have GPS data and can estimate all vehicle states
|
||||||
|
posTimeout = false;
|
||||||
|
velTimeout = false;
|
||||||
constPosMode = false;
|
constPosMode = false;
|
||||||
constVelMode = false;
|
constVelMode = false;
|
||||||
// we reset the position in case the initial GPS setting the origin was off or the vehicle has been moved a significant distance
|
// we need to reset the GPS timers to prevent GPS timeout logic being invoked on entry into GPS aiding
|
||||||
ResetPosition();
|
// this is becasue the EKF can be interrupted for an arbitrary amount of time during vehicle arming checks
|
||||||
|
lastFixTime_ms = imuSampleTime_ms;
|
||||||
|
secondLastFixTime_ms = imuSampleTime_ms;
|
||||||
|
// reset the last valid position fix time to prevent unwanted activation of GPS glitch logic
|
||||||
|
posFailTime = imuSampleTime_ms;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Reset filter positon, height and velocity states on arming or disarming
|
// Reset filter positon, height and velocity states on arming or disarming
|
||||||
|
Loading…
Reference in New Issue
Block a user