This is an OpenCV based implementation of visual odometery.
An invaluable resource I used in building the visual odometry system was Avi Singh's blog post here: http://avisingh599.github.io/vision/monocular-vo/ as well as his C++ implementation found here.
Steps of the algorithm are as follows are detailed here.
- Capture images: It and It + 1
- Undistort the captured images (not necessary for KITTI dataset)
- Use FAST algorithm to detect features in image It. Track these features using an optical flow methodology, remove points that fall out of frame or are not visible in It + 1. Trigger a new detection of points if the number of tracked points falls behind a threshold. Set to 2000 in this implementation.
- Apply Nister's 5-point algorithm with RANSAC to find the essential matrix.
- Estimate R, t from the essential matrix that was computed from Nister's algorithm.
- Obtain scale information from an external source and concatenate translation vectors t and rotation matrices R.
For each of the steps above, the line of code is provided to the exact location where this step is preformed in the code for easy understanding. Steps 1 and 2 are skipped as they are not necessary in the KITTI dataset.
- Line 80, monovideoodemetry.py
- Line 112, monovideoodemetry.py
- Line 113, monovideoodemtry.py
- Line 142, monovideoodemtry.py
The dataset used is: KITTI Visual Odometry
- First clone repository
- In
test.py
changeimg_path
andpose_path
to correct image sequences and pose file paths - Ensure focal length and principal point information is correct
- Adjust Lucas Kanade Parameters as needed
- Run command
python ./test.py