This code implements an Extended Kalman Filter (EKF) for fusing Global Positioning System (GPS) and Inertial Measurement Unit (IMU) measurements. The goal is to estimate the state (position and orientation) of a vehicle using both GPS and IMU data.
In our case, IMU provide data more frequently than GPS. Here is a step-by-step description of the process:
- Initialization: Firstly, initialize your EKF state [position, velocity, orientation] using the first GPS and IMU reading. The covariance matrix (P) should also be initialized to reflect initial uncertainty.
- Prediction step (also known as Time Update): In the prediction step, you make a prediction of the current state using the process model and the previously estimated state. In our case, the state can be represented as [position, velocity, orientation]. We also need to predict the state covariance matrix (P) at this point.
- Update step (also known as Measurement Update): In the update step, we correct the predicted state using the measurement data. GPS frequency is 4 Hz.
- Estimate update: With the Kalman gain, we can compute the updated (a posteriori) state estimate by combining the predicted state estimate and the weighted difference between the actual measurement and the measurement predicted by the a priori estimate (also known as the measurement residual).
- Covariance update: We also compute the updated (a posteriori) estimate covariance (P). The a posteriori state and covariance estimates at the current time become the a priori estimates for the next time step.
- Repeat steps 2-5: This process is then repeated for each time step, using the a posteriori estimates from the previous time step as the a priori estimates for the current step.
-
C++ compiler supporting C++11 or higher
-
Eigen library (for linear algebra operations)
- Install the required dependencies and ensure they are properly linked in your build environment.
- Place the input data file (localization_log2.csv) in the same directory as the code files.
- Compile the code using a C++ compiler.
- Change the CMakeLists.txt before running the compiled executable.
- The estimated position and orientation will be saved in the output_utm.csv file.
ekf.h: Header file containing the declaration of the ExtendedKalmanFilter class, which implements the EKF algorithm.
geo_ned.h: Header file containing helper functions for converting between geodetic (WGS84) and East-North-Down (ENU) coordinate systems.
utm.h: Header file containing the definition of the utm_coords struct and the utmconv namespace, which provides functions for converting between geodetic and UTM coordinates.
main_utm.cpp: The main C++ file that reads input data from a CSV file in UTM system, performs the GPS and IMU fusion using the EKF, and outputs the estimated position and orientation. (Use main.cpp for ENU coordinate system).
The input data is expected to be in a CSV file (localization_log2.csv) with the following columns:
Timestamp (in nanoseconds)
Latitude (in degrees, WGS84)
Longitude (in degrees, WGS84)
Altitude (in meters, WGS84)
Forward velocity (in meters per second)
Yaw rate (in radians per second)
The output of the code is a CSV file (output_utm.csv) containing the estimated position and orientation in UTM coordinates. The file has the following columns:
Easting (UTM coordinate, in meters)
Northing (UTM coordinate, in meters)
Yaw (orientation angle, in radians)
Estimated X position (in meters)
Estimated Y position (in meters)
Estimated yaw (in radians)
The code provides options for adjusting the standard deviation of the observation noise for x and y coordinates (xy_obs_noise_std), the yaw rate (yaw_rate_noise_std), and the forward velocity (forward_velocity_noise_std). These parameters can be modified in the code to suit your specific scenario and sensor characteristics.