Skip to content
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

Merged
merged 11 commits into from
Nov 22, 2024
Merged

EKF2: ellipsoidal earth navigation #23854

merged 11 commits into from
Nov 22, 2024

Conversation

bresch
Copy link
Member

@bresch bresch commented Oct 25, 2024

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.

image

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).
image

Changelog Entry

For release notes:

TBD
New parameter: -
Documentation: -

Alternatives

Test coverage

Context

@bresch bresch force-pushed the pr-ekf2_gpos_rework branch 4 times, most recently from d80e0d9 to 24730b8 Compare October 29, 2024 10:47
@bresch bresch requested review from haumarco and dagar October 29, 2024 10:48
@bresch bresch added the EKF2 label Oct 29, 2024
@bresch bresch force-pushed the pr-ekf2_gpos_rework branch 2 times, most recently from ecbd921 to f8ac1e0 Compare October 29, 2024 16:27
src/modules/ekf2/EKF/ekf.cpp Outdated Show resolved Hide resolved
src/modules/ekf2/EKF/ekf.h Outdated Show resolved Hide resolved
@bresch bresch marked this pull request as ready for review October 29, 2024 16:32
@bresch bresch self-assigned this Oct 29, 2024
@bresch bresch force-pushed the pr-ekf2_gpos_rework branch 5 times, most recently from 828f74a to a3be0c6 Compare November 1, 2024 14:16
Copy link
Member

@Jaeyoung-Lim Jaeyoung-Lim left a 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.

@bresch
Copy link
Member Author

bresch commented Nov 4, 2024

Wouldn't this have implications in the current navigation stack where it doesn't distinguish ellipsoidal or geoid heights?

@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 LatLonAlt class.
My goal is to only use ellipsoid altitude inside EKF2 and then convert the output to AMSL. We currently don't have a geoid model, so either we add one or we continue to steal it from the GNSS receiver (i.e.: compute the difference between reported AMSL and ellipsoid alt).
This PR is however large enough so I'll do the changes in a follow-up one.

@Jaeyoung-Lim
Copy link
Member

Jaeyoung-Lim commented Nov 4, 2024

@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.

@DronecodeBot
Copy link

This pull request has been mentioned on Discussion Forum for PX4, Pixhawk, QGroundControl, MAVSDK, MAVLink. There might be relevant details there:

https://discuss.px4.io/t/px4-sync-q-a-nov-13-2024/42390/1

@bresch bresch force-pushed the pr-ekf2_gpos_rework branch 2 times, most recently from 61a0cda to 029d7c3 Compare November 15, 2024 10:03
@bresch
Copy link
Member Author

bresch commented Nov 15, 2024

Compiled for fmu-v5: Flash increase of +2192 B (0.11%)
Main:
FLASH_AXIM: 2029185 B 2016 KB 98.29%

This PR:
FLASH_AXIM: 2031377 B 2016 KB 98.40%

@hamishwillee
Copy link
Contributor

@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.

@bresch bresch force-pushed the pr-ekf2_gpos_rework branch 4 times, most recently from 71e772b to 94b2686 Compare November 21, 2024 16:55
@bresch bresch force-pushed the pr-ekf2_gpos_rework branch from 94b2686 to c4649fc Compare November 22, 2024 08:25
Copy link

FLASH Analysis

px4_fmu-v5x
    FILE SIZE        VM SIZE    
 --------------  -------------- 
  +0.1% +38.1Ki  [ = ]       0    .debug_info
    [NEW] +23.3Ki  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.4% +13.2Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +2.7% +1.59Ki  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
    +0.2%     +16  [ = ]       0    msg/topics_sources/estimator_aid_source2d.cpp
    +0.0%      +2  [ = ]       0    msg/topics_sources/uORBMessageFieldsGenerated.cpp
  +0.3% +15.9Ki  [ = ]       0    .debug_loc
    +0.6% +9.43Ki  [ = ]       0    [section .debug_loc]
    +1.4% +5.12Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW] +1.04Ki  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.2%    +304  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1% +6.85Ki  [ = ]       0    .debug_line
    +1.2% +4.40Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW] +2.33Ki  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.1%    +126  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.4% +5.00Ki  [ = ]       0    .debug_ranges
    +1.2% +3.08Ki  [ = ]       0    [section .debug_ranges]
    +1.4% +1.56Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW]    +312  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.2%     +56  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1% +2.39Ki  [ = ]       0    .debug_str
    +1.8% +5.27Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW]    +332  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
     +17%    +134  [ = ]       0    ../../src/modules/flight_mode_manager/tasks/ManualPosition/FlightTaskManualPosition.cpp
    +0.1%     +76  [ = ]       0    [section .debug_str]
     +11%     +45  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
    +1.2%     +11  [ = ]       0    ../../src/lib/tecs/TECS.cpp
    +0.0%      +6  [ = ]       0    ../../src/modules/mc_pos_control/MulticopterPositionControl.cpp
    -0.1%      -1  [ = ]       0    ../../src/lib/motion_planning/PositionSmoothing.cpp
    -0.1%      -6  [ = ]       0    ../../src/modules/ekf2/EKF/yaw_estimator/EKFGSF_yaw.cpp
   -11.5%     -10  [ = ]       0    ../../src/lib/atmosphere/atmosphere.cpp
    -0.8%     -10  [ = ]       0    ../../src/modules/temperature_compensation/temperature_calibration/accel.cpp
    -3.0% -3.44Ki  [ = ]       0    ../../src/modules/fw_pos_control/FixedwingPositionControl.cpp
  +0.1% +2.15Ki  +0.1% +2.15Ki    .text
    +0.7% +1.16Ki  +0.7% +1.16Ki    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW]    +924  [NEW]    +924    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +0.0%     +56  +0.0%     +56    [section .text]
    +0.9%     +32  +0.9%     +32    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1% +1.60Ki  [ = ]       0    .debug_abbrev
    +0.1% +1.60Ki  [ = ]       0    armv7-m/arm_vectors.c
  +0.1%    +516  [ = ]       0    .debug_frame
  +0.1%    +464  [ = ]       0    .symtab
    [NEW]    +304  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +0.8%    +112  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +4.5%     +32  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
    +0.0%     +16  [ = ]       0    [section .symtab]
  +0.0%    +319  [ = ]       0    .strtab
    [NEW]    +287  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +0.2%     +33  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +0.0%     +16  [ = ]       0    [section .strtab]
    -1.5%     -17  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1%    +128  [ = ]       0    .debug_aranges
  -8.7% -2.15Ki  [ = ]       0    [Unmapped]
  +0.1% +71.3Ki  +0.1% +2.15Ki    TOTAL

px4_fmu-v6x
    FILE SIZE        VM SIZE    
 --------------  -------------- 
  +0.1% +38.1Ki  [ = ]       0    .debug_info
    [NEW] +23.3Ki  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.4% +13.2Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +2.7% +1.59Ki  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
    +0.2%     +16  [ = ]       0    msg/topics_sources/estimator_aid_source2d.cpp
    +0.0%      +2  [ = ]       0    msg/topics_sources/uORBMessageFieldsGenerated.cpp
  +0.3% +15.9Ki  [ = ]       0    .debug_loc
    +0.6% +9.41Ki  [ = ]       0    [section .debug_loc]
    +1.5% +5.18Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW] +1.04Ki  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.2%    +304  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.2% +6.85Ki  [ = ]       0    .debug_line
    +1.2% +4.40Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW] +2.33Ki  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.1%    +126  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.4% +5.00Ki  [ = ]       0    .debug_ranges
    +1.3% +3.08Ki  [ = ]       0    [section .debug_ranges]
    +1.4% +1.56Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW]    +312  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.2%     +56  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1% +2.39Ki  [ = ]       0    .debug_str
    +1.8% +5.27Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW]    +332  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
     +17%    +134  [ = ]       0    ../../src/modules/flight_mode_manager/tasks/ManualPosition/FlightTaskManualPosition.cpp
    +0.1%     +76  [ = ]       0    [section .debug_str]
     +11%     +45  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
    +1.2%     +11  [ = ]       0    ../../src/lib/tecs/TECS.cpp
    +0.0%      +6  [ = ]       0    ../../src/modules/mc_pos_control/MulticopterPositionControl.cpp
    -0.1%      -1  [ = ]       0    ../../src/lib/motion_planning/PositionSmoothing.cpp
    -0.1%      -6  [ = ]       0    ../../src/modules/ekf2/EKF/yaw_estimator/EKFGSF_yaw.cpp
    -9.9%     -10  [ = ]       0    ../../src/lib/atmosphere/atmosphere.cpp
    -0.8%     -10  [ = ]       0    ../../src/modules/temperature_compensation/temperature_calibration/accel.cpp
    -3.0% -3.44Ki  [ = ]       0    ../../src/modules/fw_pos_control/FixedwingPositionControl.cpp
  +0.1% +2.15Ki  +0.1% +2.15Ki    .text
    +0.7% +1.16Ki  +0.7% +1.16Ki    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW]    +924  [NEW]    +924    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +0.0%     +56  +0.0%     +56    [section .text]
    +0.9%     +32  +0.9%     +32    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1% +1.60Ki  [ = ]       0    .debug_abbrev
    +0.1% +1.60Ki  [ = ]       0    armv7-m/arm_vectors.c
  +0.1%    +516  [ = ]       0    .debug_frame
  +0.1%    +464  [ = ]       0    .symtab
    [NEW]    +304  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +0.8%    +112  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +4.5%     +32  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
    +0.0%     +16  [ = ]       0    [section .symtab]
  +0.0%    +319  [ = ]       0    .strtab
    [NEW]    +287  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +0.2%     +33  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +0.0%     +16  [ = ]       0    [section .strtab]
    -1.5%     -17  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1%    +128  [ = ]       0    .debug_aranges
  -3.0% -2.15Ki  [ = ]       0    [Unmapped]
  +0.2% +71.3Ki  +0.1% +2.15Ki    TOTAL

@PX4 PX4 deleted a comment from github-actions bot Nov 22, 2024
@PX4 PX4 deleted a comment from github-actions bot Nov 22, 2024
@PX4 PX4 deleted a comment from github-actions bot Nov 22, 2024
@PX4 PX4 deleted a comment from github-actions bot Nov 22, 2024
Copy link

FLASH Analysis

px4_fmu-v5x
    FILE SIZE        VM SIZE    
 --------------  -------------- 
  +0.1% +34.4Ki  [ = ]       0    .debug_info
    [NEW] +23.3Ki  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.0% +9.41Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +2.7% +1.59Ki  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
    +0.2%     +16  [ = ]       0    msg/topics_sources/estimator_aid_source2d.cpp
    +0.0%      +2  [ = ]       0    msg/topics_sources/uORBMessageFieldsGenerated.cpp
  +0.2% +10.5Ki  [ = ]       0    .debug_loc
    +2.1% +7.55Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +0.1% +1.65Ki  [ = ]       0    [section .debug_loc]
    [NEW] +1.04Ki  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.2%    +304  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1% +4.88Ki  [ = ]       0    .debug_line
    +0.7% +2.43Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW] +2.33Ki  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.1%    +126  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.2% +2.96Ki  [ = ]       0    .debug_ranges
    +2.2% +2.43Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW]    +312  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +0.1%    +176  [ = ]       0    [section .debug_ranges]
    +1.2%     +56  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1% +2.39Ki  [ = ]       0    .debug_str
    +1.8% +5.27Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW]    +332  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
     +17%    +134  [ = ]       0    ../../src/modules/flight_mode_manager/tasks/ManualPosition/FlightTaskManualPosition.cpp
    +0.1%     +76  [ = ]       0    [section .debug_str]
     +11%     +45  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
    +1.2%     +11  [ = ]       0    ../../src/lib/tecs/TECS.cpp
    +0.0%      +6  [ = ]       0    ../../src/modules/mc_pos_control/MulticopterPositionControl.cpp
    -0.1%      -1  [ = ]       0    ../../src/lib/motion_planning/PositionSmoothing.cpp
    -0.1%      -6  [ = ]       0    ../../src/modules/ekf2/EKF/yaw_estimator/EKFGSF_yaw.cpp
   -11.5%     -10  [ = ]       0    ../../src/lib/atmosphere/atmosphere.cpp
    -0.8%     -10  [ = ]       0    ../../src/modules/temperature_compensation/temperature_calibration/accel.cpp
    -3.0% -3.44Ki  [ = ]       0    ../../src/modules/fw_pos_control/FixedwingPositionControl.cpp
  +0.1% +1.93Ki  +0.1% +1.93Ki    .text
    +0.6%    +960  +0.6%    +960    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW]    +924  [NEW]    +924    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +0.0%     +60  +0.0%     +60    [section .text]
    +0.9%     +32  +0.9%     +32    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1% +1.60Ki  [ = ]       0    .debug_abbrev
    +0.1% +1.60Ki  [ = ]       0    armv7-m/arm_vectors.c
  +0.1%    +544  [ = ]       0    .debug_frame
  +0.1%    +496  [ = ]       0    .symtab
    [NEW]    +304  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.0%    +144  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +4.5%     +32  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
    +0.0%     +16  [ = ]       0    [section .symtab]
  +0.1%    +359  [ = ]       0    .strtab
    [NEW]    +287  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +0.5%     +73  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +0.0%     +16  [ = ]       0    [section .strtab]
    -1.5%     -17  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1%    +136  [ = ]       0    .debug_aranges
  -7.8% -1.93Ki  [ = ]       0    [Unmapped]
  +0.1% +58.2Ki  +0.1% +1.93Ki    TOTAL

px4_fmu-v6x
    FILE SIZE        VM SIZE    
 --------------  -------------- 
  +0.1% +34.4Ki  [ = ]       0    .debug_info
    [NEW] +23.3Ki  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.0% +9.41Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +2.7% +1.59Ki  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
    +0.2%     +16  [ = ]       0    msg/topics_sources/estimator_aid_source2d.cpp
    +0.0%      +2  [ = ]       0    msg/topics_sources/uORBMessageFieldsGenerated.cpp
  +0.2% +10.6Ki  [ = ]       0    .debug_loc
    +2.1% +7.54Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +0.1% +1.76Ki  [ = ]       0    [section .debug_loc]
    [NEW] +1.04Ki  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.2%    +304  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1% +4.88Ki  [ = ]       0    .debug_line
    +0.7% +2.43Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW] +2.33Ki  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.1%    +126  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.2% +2.96Ki  [ = ]       0    .debug_ranges
    +2.2% +2.43Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW]    +312  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +0.1%    +176  [ = ]       0    [section .debug_ranges]
    +1.2%     +56  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1% +2.39Ki  [ = ]       0    .debug_str
    +1.8% +5.27Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW]    +332  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
     +17%    +134  [ = ]       0    ../../src/modules/flight_mode_manager/tasks/ManualPosition/FlightTaskManualPosition.cpp
    +0.1%     +76  [ = ]       0    [section .debug_str]
     +11%     +45  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
    +1.2%     +11  [ = ]       0    ../../src/lib/tecs/TECS.cpp
    +0.0%      +6  [ = ]       0    ../../src/modules/mc_pos_control/MulticopterPositionControl.cpp
    -0.1%      -1  [ = ]       0    ../../src/lib/motion_planning/PositionSmoothing.cpp
    -0.1%      -6  [ = ]       0    ../../src/modules/ekf2/EKF/yaw_estimator/EKFGSF_yaw.cpp
    -9.9%     -10  [ = ]       0    ../../src/lib/atmosphere/atmosphere.cpp
    -0.8%     -10  [ = ]       0    ../../src/modules/temperature_compensation/temperature_calibration/accel.cpp
    -3.0% -3.44Ki  [ = ]       0    ../../src/modules/fw_pos_control/FixedwingPositionControl.cpp
  +0.1% +1.93Ki  +0.1% +1.93Ki    .text
    +0.6%    +960  +0.6%    +960    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW]    +924  [NEW]    +924    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +0.0%     +60  +0.0%     +60    [section .text]
    +0.9%     +32  +0.9%     +32    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1% +1.60Ki  [ = ]       0    .debug_abbrev
    +0.1% +1.60Ki  [ = ]       0    armv7-m/arm_vectors.c
  +0.1%    +544  [ = ]       0    .debug_frame
  +0.1%    +496  [ = ]       0    .symtab
    [NEW]    +304  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.0%    +144  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +4.5%     +32  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
    +0.0%     +16  [ = ]       0    [section .symtab]
  +0.1%    +359  [ = ]       0    .strtab
    [NEW]    +287  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +0.5%     +73  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +0.0%     +16  [ = ]       0    [section .strtab]
    -1.5%     -17  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1%    +136  [ = ]       0    .debug_aranges
  -2.7% -1.93Ki  [ = ]       0    [Unmapped]
  +0.1% +58.3Ki  +0.1% +1.93Ki    TOTAL

The vertical position state is now an altitude, not just a local height
Copy link

FLASH Analysis

px4_fmu-v5x
    FILE SIZE        VM SIZE    
 --------------  -------------- 
  +0.1% +34.4Ki  [ = ]       0    .debug_info
    [NEW] +23.3Ki  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.0% +9.41Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +2.7% +1.59Ki  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
    +0.2%     +16  [ = ]       0    msg/topics_sources/estimator_aid_source2d.cpp
    +0.0%      +2  [ = ]       0    msg/topics_sources/uORBMessageFieldsGenerated.cpp
  +0.2% +10.5Ki  [ = ]       0    .debug_loc
    +2.1% +7.55Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +0.1% +1.65Ki  [ = ]       0    [section .debug_loc]
    [NEW] +1.04Ki  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.2%    +304  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1% +4.89Ki  [ = ]       0    .debug_line
    +0.7% +2.43Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW] +2.33Ki  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.1%    +126  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.2% +2.96Ki  [ = ]       0    .debug_ranges
    +2.2% +2.43Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW]    +312  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +0.1%    +176  [ = ]       0    [section .debug_ranges]
    +1.2%     +56  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1% +2.38Ki  [ = ]       0    .debug_str
    +1.8% +5.26Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW]    +332  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
     +17%    +134  [ = ]       0    ../../src/modules/flight_mode_manager/tasks/ManualPosition/FlightTaskManualPosition.cpp
    +0.1%     +75  [ = ]       0    [section .debug_str]
     +11%     +45  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
    +1.2%     +11  [ = ]       0    ../../src/lib/tecs/TECS.cpp
    +0.0%      +6  [ = ]       0    ../../src/modules/mc_pos_control/MulticopterPositionControl.cpp
    -0.1%      -1  [ = ]       0    ../../src/lib/motion_planning/PositionSmoothing.cpp
    -0.1%      -6  [ = ]       0    ../../src/modules/ekf2/EKF/yaw_estimator/EKFGSF_yaw.cpp
   -11.5%     -10  [ = ]       0    ../../src/lib/atmosphere/atmosphere.cpp
    -0.8%     -10  [ = ]       0    ../../src/modules/temperature_compensation/temperature_calibration/accel.cpp
    -3.0% -3.44Ki  [ = ]       0    ../../src/modules/fw_pos_control/FixedwingPositionControl.cpp
  +0.1% +1.93Ki  +0.1% +1.93Ki    .text
    +0.6%    +960  +0.6%    +960    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW]    +924  [NEW]    +924    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +0.0%     +60  +0.0%     +60    [section .text]
    +0.9%     +32  +0.9%     +32    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1% +1.60Ki  [ = ]       0    .debug_abbrev
    +0.1% +1.60Ki  [ = ]       0    armv7-m/arm_vectors.c
  +0.1%    +544  [ = ]       0    .debug_frame
  +0.1%    +496  [ = ]       0    .symtab
    [NEW]    +304  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.0%    +144  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +4.5%     +32  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
    +0.0%     +16  [ = ]       0    [section .symtab]
  +0.1%    +361  [ = ]       0    .strtab
    [NEW]    +287  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +0.5%     +75  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +0.0%     +16  [ = ]       0    [section .strtab]
    -1.5%     -17  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1%    +136  [ = ]       0    .debug_aranges
  -7.9% -1.93Ki  [ = ]       0    [Unmapped]
  +0.1% +58.2Ki  +0.1% +1.93Ki    TOTAL

px4_fmu-v6x
    FILE SIZE        VM SIZE    
 --------------  -------------- 
  +0.1% +34.4Ki  [ = ]       0    .debug_info
    [NEW] +23.3Ki  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.0% +9.41Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +2.7% +1.59Ki  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
    +0.2%     +16  [ = ]       0    msg/topics_sources/estimator_aid_source2d.cpp
    +0.0%      +2  [ = ]       0    msg/topics_sources/uORBMessageFieldsGenerated.cpp
  +0.2% +10.6Ki  [ = ]       0    .debug_loc
    +2.1% +7.54Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +0.1% +1.76Ki  [ = ]       0    [section .debug_loc]
    [NEW] +1.04Ki  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.2%    +304  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1% +4.89Ki  [ = ]       0    .debug_line
    +0.7% +2.43Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW] +2.33Ki  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.1%    +126  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.2% +2.96Ki  [ = ]       0    .debug_ranges
    +2.2% +2.43Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW]    +312  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +0.1%    +176  [ = ]       0    [section .debug_ranges]
    +1.2%     +56  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1% +2.38Ki  [ = ]       0    .debug_str
    +1.8% +5.26Ki  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW]    +332  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
     +17%    +134  [ = ]       0    ../../src/modules/flight_mode_manager/tasks/ManualPosition/FlightTaskManualPosition.cpp
    +0.1%     +75  [ = ]       0    [section .debug_str]
     +11%     +45  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
    +1.2%     +11  [ = ]       0    ../../src/lib/tecs/TECS.cpp
    +0.0%      +6  [ = ]       0    ../../src/modules/mc_pos_control/MulticopterPositionControl.cpp
    -0.1%      -1  [ = ]       0    ../../src/lib/motion_planning/PositionSmoothing.cpp
    -0.1%      -6  [ = ]       0    ../../src/modules/ekf2/EKF/yaw_estimator/EKFGSF_yaw.cpp
    -9.9%     -10  [ = ]       0    ../../src/lib/atmosphere/atmosphere.cpp
    -0.8%     -10  [ = ]       0    ../../src/modules/temperature_compensation/temperature_calibration/accel.cpp
    -3.0% -3.44Ki  [ = ]       0    ../../src/modules/fw_pos_control/FixedwingPositionControl.cpp
  +0.1% +1.93Ki  +0.1% +1.93Ki    .text
    +0.6%    +960  +0.6%    +960    src/modules/ekf2/modules__ekf2_unity.cpp
    [NEW]    +924  [NEW]    +924    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +0.0%     +60  +0.0%     +60    [section .text]
    +0.9%     +32  +0.9%     +32    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1% +1.60Ki  [ = ]       0    .debug_abbrev
    +0.1% +1.60Ki  [ = ]       0    armv7-m/arm_vectors.c
  +0.1%    +544  [ = ]       0    .debug_frame
  +0.1%    +496  [ = ]       0    .symtab
    [NEW]    +304  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +1.0%    +144  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +4.5%     +32  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
    +0.0%     +16  [ = ]       0    [section .symtab]
  +0.1%    +361  [ = ]       0    .strtab
    [NEW]    +287  [ = ]       0    ../../src/modules/ekf2/EKF/lat_lon_alt/lat_lon_alt.cpp
    +0.5%     +75  [ = ]       0    src/modules/ekf2/modules__ekf2_unity.cpp
    +0.0%     +16  [ = ]       0    [section .strtab]
    -1.5%     -17  [ = ]       0    ../../src/modules/ekf2/EKF/output_predictor/output_predictor.cpp
  +0.1%    +136  [ = ]       0    .debug_aranges
  -2.7% -1.93Ki  [ = ]       0    [Unmapped]
  +0.1% +58.3Ki  +0.1% +1.93Ki    TOTAL

Copy link
Contributor

@haumarco haumarco left a 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.

@bresch bresch merged commit 14fe6c2 into main Nov 22, 2024
62 checks passed
@bresch bresch deleted the pr-ekf2_gpos_rework branch November 22, 2024 14:13
@DronecodeBot
Copy link

This pull request has been mentioned on Discussion Forum for PX4, Pixhawk, QGroundControl, MAVSDK, MAVLink. There might be relevant details there:

https://discuss.px4.io/t/px4-sync-q-a-nov-27-2024/42604/1

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
Status: ✅ Done
Development

Successfully merging this pull request may close these issues.

5 participants