Clothoid path planning
data:image/s3,"s3://crabby-images/e95b6/e95b69469b053fc226b8b843498760c1860b738f" alt="https://github.com/AtsushiSakai/PythonRoboticsGifs/raw/master/PathPlanning/ClothoidPath/animation1.gif"
data:image/s3,"s3://crabby-images/03b9c/03b9c2c24899ccbd5528e63b0db5f9f5126526f5" alt="https://github.com/AtsushiSakai/PythonRoboticsGifs/raw/master/PathPlanning/ClothoidPath/animation2.gif"
data:image/s3,"s3://crabby-images/73a0f/73a0fe447defdf5b9b07bec65080880270eb4325" alt="https://github.com/AtsushiSakai/PythonRoboticsGifs/raw/master/PathPlanning/ClothoidPath/animation3.gif"
This is a clothoid path planning sample code.
This can interpolate two 2D pose (x, y, yaw) with a clothoid path, which its curvature is linearly continuous. In other words, this is G1 Hermite interpolation with a single clothoid segment.
This path planning algorithm as follows:
Step1: Solve g function
Solve the g(A) function with a nonlinear optimization solver.
Where
\(\delta\): the orientation difference between start and goal pose.
\(\phi_{s}\): the orientation of the start pose.
\(Y\): \(Y(a, b, c)=\int_{0}^{1} \sin \left(\frac{a}{2} \tau^{2}+b \tau+c\right) d \tau\)
Step2: Calculate path parameters
We can calculate these path parameters using \(A\),
\(L\): path length
where
\(R\): the distance between start and goal pose
\(X\): \(X(a, b, c)=\int_{0}^{1} \cos \left(\frac{a}{2} \tau^{2}+b \tau+c\right) d \tau\)
\(\kappa\): curvature
\(\kappa'\): curvature rate
Step3: Construct a path with Fresnel integral
The final clothoid path can be calculated with the path parameters and Fresnel integrals.