CppRobotics
CppRobotics copied to clipboard
cpp implementation of robotics algorithms including localization, mapping, SLAM, path planning and control
CppRobotics
This is the cpp implementation of the PythonRobotics
Requirment
- cmake
- opencv 3.3
- Eigen 3
- CppAD / IPOPT (for MPC convex optimization) install tips
- ~~ROS~~ (~~To make the repo lightweight :)~~. Yet, we may still need it for 3D visualization.)
Build
$ mkdir build
$ cd build
$ cmake ../
$ make -j 8
Find all the executable files in build/bin.
Table of Contents
-
Localization
- Extended kalmam filter
- Particle filter
- Histogram filter
-
Mapping
- Gaussian grid map
-
SLAM
- FastSLAM 1.0
-
Path Planning
- Dijkstra
- A Star
- RRT
- Dynamic Window Approach
- Model Predictive Trajectory Generator
- Cubic Spline Planner
- State Lattice Planner
- Frenet Frame Trajectory
-
Path Tracking Control
- LQR Sterring Control
- LQR Speed and Steering Control
- Model Predictive Speed and Steering Control
-
Aerial Navigation
- Drone 3D Trajectory Following
- Rocket Powered Landing
Localization
Extended Kalman Filter Localization
- green line: the groundtruth trajectory
- black line: dead reckoning
- red points: observations (e.g. GPS)
- blue line: estimated positions
data:image/s3,"s3://crabby-images/4d642/4d6428863b94b0c8692ccceb04acd752695b0e3f" alt="ekf"
Particle Filter Localization
- green line: the groundtruth trajectory
- black line: dead reckoning
- red points: landmarks
- blue line: estimated positions
data:image/s3,"s3://crabby-images/508ab/508abe378846495e36a838e81c343a34b0d8e253" alt="pf"
Path Planning
Dijkstra
- blue point: the start point
- red point: the goal point
A star
- blue point: the start point
- red point: the goal point
RRT
- red circle: the start point
- blue circle: the goal point
- black circle: obstacles
Dynamic Window Approach
- blue circle: the target point
- red circle: the robot
data:image/s3,"s3://crabby-images/1e35b/1e35ba96ceb4d80e7f1e2ec45337976bb754f43e" alt="dwa"
The dynamic window approach to collision avoidance
Model Predictive Trajectory Generator
This part is based on the bicycle motion model.
- blue circle: the target point
- red circle: the initial point
data:image/s3,"s3://crabby-images/85d5c/85d5c75858e395e8cc08adec2f9a8018bb2b863d" alt="mptg"
Cubic Spline Planner
data:image/s3,"s3://crabby-images/0ae07/0ae07f1a6edd2bac1c7bd3e0ba8e204e6aa38298" alt="csp"
State Lattice Planner
- blue circle: the target point
- red circle: the initial point
data:image/s3,"s3://crabby-images/8b436/8b43685a5333d53b8d8e0a50501566a0b7a3d11d" alt="slp"
Frenet Frame Trajectory
- black line: the planned spline path
- red circle: the obstacle
- blue circle: the planned trajectory
- green circle: the real-time position of robot
data:image/s3,"s3://crabby-images/4283e/4283e87229d809ce53fabdcbd181bb709da6b1cb" alt="frenet"
Optimal Trajectory Generation for Dynamic Street Scenarios in a Frenet Frame
Path Tracking Control
LQR Steering Control
- black line: the planned spline path
- red circle: the position under lqr control
data:image/s3,"s3://crabby-images/f7b61/f7b61432c32fe00d8a9db5df31cb050ea3310b7e" alt="lqr_steering"
LQR Speed and Steering Control
- black line: the planned spline path
- red circle: the position under lqr control
data:image/s3,"s3://crabby-images/fb909/fb909acb456d92cc9bde1337105f13e9d27eb9a4" alt="lqr_full"
MPC Speed and Steering Control
- black line: the planned spline path
- blue line: the passed path
- yellow cross: the reference trajectory for MPC
(To compile this part, you need to uncomment the related lines in CMakeLists.txt and install CppAD and IPOPT.)
data:image/s3,"s3://crabby-images/2f4a5/2f4a59a0bd27a4a6874447b702c2824068dd6e2f" alt="mpc"