mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-10 01:48:29 -04:00
AP_NavEKF: Use GPS vertical velocity observations to estimate Z accel bias
This commit is contained in:
parent
e48171ab11
commit
3e67080002
@ -2166,10 +2166,10 @@ void NavEKF::FuseVelPosNED()
|
|||||||
for (uint8_t i= 0; i<=12; i++) {
|
for (uint8_t i= 0; i<=12; i++) {
|
||||||
Kfusion[i] = P[i][stateIndex]*SK;
|
Kfusion[i] = P[i][stateIndex]*SK;
|
||||||
}
|
}
|
||||||
// Only height observations are used to update z accel bias estimate
|
// Only height and height rate observations are used to update z accel bias estimate
|
||||||
// Protect Kalman gain from ill-conditioning
|
// Protect Kalman gain from ill-conditioning
|
||||||
// Don't update Z accel bias if off-level by greater than 60 degrees to avoid scale factor error effects
|
// Don't update Z accel bias if off-level by greater than 60 degrees to avoid scale factor error effects
|
||||||
if (obsIndex == 5 && prevTnb.c.z > 0.5f) {
|
if ((obsIndex == 5 || obsIndex == 2) && prevTnb.c.z > 0.5f) {
|
||||||
Kfusion[13] = constrain_float(P[13][stateIndex]*SK,-1.0f,0.0f);
|
Kfusion[13] = constrain_float(P[13][stateIndex]*SK,-1.0f,0.0f);
|
||||||
} else {
|
} else {
|
||||||
Kfusion[13] = 0.0f;
|
Kfusion[13] = 0.0f;
|
||||||
|
Loading…
Reference in New Issue
Block a user