-
Notifications
You must be signed in to change notification settings - Fork 13.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
EKF2: ellipsoidal earth navigation #23854
Conversation
d80e0d9
to
24730b8
Compare
ecbd921
to
f8ac1e0
Compare
828f74a
to
a3be0c6
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nice!
The height definitions in mavlink is based on AMSL, which are defined by a geoid.
Wouldn't this have implications in the current navigation stack where it doesn't distinguish ellipsoidal or geoid heights?
The GPS returns both, but I couldn't find where this would be explicitly distinguished.
@Jaeyoung-Lim You're right, it's not ideal but we still use AMSL everywhere so it's at least consistent on the altitude reporting side. A current issue is that we use AMSL instead of ellipsoid height in the calculations inside the |
@bresch Thanks! I think this would be anyway a huge improvement in navigation performance, especially when you care about altitude above terrain. Last thing I would like to comment (For myself really) is that this would probably break the gazebo gps plugin setup, since gazebo assumes a cartesian world. I have a separate gps sensor plugin that considers the simulated world as the projected surface on the geoid to simulate flying in a CH1903/LV03 digital elevation map in Switzerland. We can probably adapt this to UTM coordinates for more general locations. |
This pull request has been mentioned on Discussion Forum for PX4, Pixhawk, QGroundControl, MAVSDK, MAVLink. There might be relevant details there: |
61a0cda
to
029d7c3
Compare
Compiled for fmu-v5: Flash increase of +2192 B (0.11%) This PR: |
@bresch Would appreciate your thoughts on this one: mavlink/mavlink#2168 (comment) - we're proposing that MAVLink uses EGM96 geoid by default as the global altitude reference instead of "UBLOX MSL". Wondering if you might be able to common on the implications. |
71e772b
to
94b2686
Compare
The position error state is still defined in a body-fixed NED frame but the position state itself is latitude-longitude-altitude.
Flow only provides velocity information
This is to better show that the altitude is also used to set the origin.
This reduces flash usage
94b2686
to
c4649fc
Compare
FLASH Analysispx4_fmu-v5x
px4_fmu-v6x
|
FLASH Analysispx4_fmu-v5x
px4_fmu-v6x
|
The vertical position state is now an altitude, not just a local height
FLASH Analysispx4_fmu-v5x
px4_fmu-v6x
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looking good, since all performance tests in SITL and SIH were successful it should be ready.
This pull request has been mentioned on Discussion Forum for PX4, Pixhawk, QGroundControl, MAVSDK, MAVLink. There might be relevant details there: |
Solved Problem
The current EKF evolves in a fixed local NED tangent-plane frame with an origin set at boot. This works well for short and moderate distances but degrades when flying over long distances (>100km) as the tangent frame gets significantly further from the ellipsoid surface.
Solution
Mechanize the navigation equations using a local-navigation-frame which is NED-oriented and with its origin attached at the CG of the vehicle. The position state now defines the global position of the drone (geodetic Latitude-Longitude-Altitude) and the local position is constructed by projecting the global position using an arbitrary origin (initialized at boot or manually by the user).
The error-state is defined in a fixed local-navigation-frame to ignore all the -really small- pseudo-forces due to the frame rotation. This allows us to keep the covariance prediction really simple and unchanged from the previous local tangent frame approximation. The position uncertainty is also defined in the local NED which makes it more intuitive than latitude/longitude errors.
Note that the global position state is not directly included in the state vector from the derivation as lat/lon require double precision. The global position is stored in a new class
LatLonAlt
which contains operators to combine ellipsoidal position and Cartesian position errors (to compute position innovations and apply corrections).When no latitude/longitude/altitude is available, the EKF assumes to be started at 0/0/0. This avoids having to handle multiple conditions everywhere in the code and the incorrect radii of curvatures is insignificant when navigating close to the starting location. It is then still possible to manually set the current position of the drone to automatically initialize the EKF at the correct location and continue dead-reckoning from there.
The position of the output predictor is considered as an error relative to the main (delayed-time EKF) and thus integrates the velocity and position directly on the Cartesian local-navigation-frame (origin at the LLA of the delayed-time EKF).
Changelog Entry
For release notes:
Alternatives
Test coverage
Context