mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-03 06:28:27 -04:00
AP_NavEKF3: Remove unncessary local position height reporting offset
The offset generated by the EK3_OGN_HGT_MASK parameter bit 2 option is applied to the baro or range finder sensor so it does not have to be applied to the local position height.
This commit is contained in:
parent
5fded75eb6
commit
91423d4c71
@ -260,17 +260,7 @@ bool NavEKF3_core::getPosNE(Vector2f &posNE) const
|
|||||||
// Return true if the estimate is valid
|
// Return true if the estimate is valid
|
||||||
bool NavEKF3_core::getPosD_local(float &posD) const
|
bool NavEKF3_core::getPosD_local(float &posD) const
|
||||||
{
|
{
|
||||||
// The EKF always has a height estimate regardless of mode of operation
|
posD = outputDataNew.position.z + posOffsetNED.z;
|
||||||
// Correct for the IMU offset (EKF calculations are at the IMU)
|
|
||||||
// Also correct for changes to the origin height
|
|
||||||
if ((frontend->_originHgtMode & (1<<2)) == 0) {
|
|
||||||
// Any sensor height drift corrections relative to the WGS-84 reference are applied to the origin.
|
|
||||||
posD = outputDataNew.position.z + posOffsetNED.z;
|
|
||||||
} else {
|
|
||||||
// The origin height is static and corrections are applied to the local vertical position
|
|
||||||
// so that height returned by getLLH() = height returned by getOriginLLH - posD
|
|
||||||
posD = outputDataNew.position.z + posOffsetNED.z + 0.01f * (float)EKF_origin.alt - (float)ekfGpsRefHgt;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Return the current height solution status
|
// Return the current height solution status
|
||||||
return filterStatus.flags.vert_pos;
|
return filterStatus.flags.vert_pos;
|
||||||
|
Loading…
Reference in New Issue
Block a user