I utilized a kalman filter to estimate the state of a moving object of interest (bicycle that travels around the vehicle) with noisy lidar and radar measurements.
Please checkout reference.pdf for Equations used in the code.
The Flow of my code is as shown below
The 3 important steps are
-
Initializing the matrices
On the first measurment we will update the state and covariance matrix.
-
Predict the state
Compute the time elapsed between previous and current measurment.
Use the time difference to compute the state and covariance matrix.
Predict the new state and covariance
-
Update the state
If the measurement is from Laser, set up the Laser matrices and update the new measurment.
If the measurement is from Radar, convert to linear, set up the Radar matrices and update the new measurement.
Lidar measurements are red circles, radar measurements are blue circles with an arrow pointing in the direction of the observed angle, and estimation markers are green triangles.
Here is a brief overview of what happens when you run the code files:
Main.cpp reads in the data and sends a sensor measurement to FusionEKF.cpp
FusionEKF.cpp takes the sensor data and initializes variables and updates variables. The Kalman filter equations are not in this file. FusionEKF.cpp has a variable called ekf_, which is an instance of a KalmanFilter class. The ekf_ instance holds the matrix and vector values and calls the predict and update equations.
The KalmanFilter class is defined in kalman_filter.cpp and kalman_filter.h. 'kalman_filter.cpp' contains functions for the prediction and update steps.
The Simulator involved in the project can be downloaded from here
This repository includes two files that can be used to set up and install uWebSocketIO for either Linux or Mac systems. For windows you can use either Docker, VMware, or even Windows 10 Bash on Ubuntu to install uWebSocketIO.
Once the install for uWebSocketIO is complete, the main program can be built and run by doing the following from the project top directory.
- mkdir build
- cd build
- cmake ..
- make
- ./ExtendedKF
INPUT: values provided by the simulator to the c++ program ["sensor_measurement"] => the measurement that the simulator observed (either lidar or radar)
OUTPUT: values provided by the c++ program to the simulator ["estimate_x"] <= kalman filter estimated position x ["estimate_y"] <= kalman filter estimated position y ["rmse_x"] ["rmse_y"] ["rmse_vx"] ["rmse_vy"]
- cmake >= 3.5
- All OSes: click here for installation instructions
- make >= 4.1 (Linux, Mac), 3.81 (Windows)
- Linux: make is installed by default on most Linux distros
- Mac: install Xcode command line tools to get make
- Windows: Click here for installation instructions
- gcc/g++ >= 5.4
- Linux: gcc / g++ is installed by default on most Linux distros
- Mac: same deal as make - install Xcode command line tools
- Windows: recommend using MinGW
- Clone this repo.
- Make a build directory:
mkdir build && cd build
- Compile:
cmake .. && make
- On windows, you may need to run:
cmake .. -G "Unix Makefiles" && make
- On windows, you may need to run:
- Run it:
./ExtendedKF