Path planning for autonomous vehicles.
The problem formulation is basically the same as path_optimizer and path_optimizer_2, but solved through constrained ilqr.
Yellow line: initial path;
Blue dots: free space boundaries;
- Problem formulated under the frenet frame;
- Kappa and kappa rate constraints;
- Compared to the previous work, there is less accuracy loss on the safety constraints and the vehicle dynamics due to the ilqr solver.
(...)
- Tested on ROS Kinetic (Ubuntu 16) and Noetic (Ubuntu 20);
- Other dependencies: glog, gflags, grid_map;
- Put these ROS packages in your ros workspace: ros_viz_tools, tinyspline_ros.
A png image is loaded as the grid map. You can click to specify the global reference path and the start/goal state of the vehicle.
roslaunch frenet_ilqr_test demo.launch
- Pick at least six points.
- There are no hard and fast rules about the spacing of the points.
- If you want to abandon the chosen points, just double click anywhere when using the "Publish Point" tool.
- You can replace
gridmap.png
with other black and white images. Note that the resolution indemo.cpp
is set to 0.2m, whick means that the length of one pixel is 0.2m on the map. - In application, the reference path is given by a global path or by a search algorithm like A*.
- Currently, it's not strictly required to reach the goal state. But this can be changed.
- The start state must be ahead of the first reference point.