The development of automated truck trailers has the potential to improve transportation efficiency at loading docks and warehouses. One crucial aspect of an automated truck trailer is the motion planning system, which generates a feasible path for the vehicle to follow. However, when a path requires the truck trailer to move in reverse, there is a significant risk of the trailer folding inwards and hitting the truck, a phenomenon known as jackknifing. This paper describes a method to mitigate this issue by implementing an MPC to counteract jackknifing. This enables robust backward driving of a truck-trailer combination, as well as a more flexible path planning algorithm for use in a warehouse parking scenario.
This GitHub page contains all code used to implement an Anti-Jackknifing controller together with a motion planner based on a Hybrid A* path finding algorithm with a Trajectory optimization algorithm.
As a basis for this project the code from Erik Nordeus has been used: https://github.com/Habrador/Self-driving-vehicle. Big improvements have been made for the scenario with a truck and trailer as this was a TODO item for Nordeus. New heuristic costs have been developed to increase the performance of the path finding algorithm. The smoothing of the path is now also done by an optimization algorithm. The basic PID controller has been replaced by an MPC, resulting in better driving of the truck trailer, especially going backwards.
The target for this project is to autonomously park a truck trailer in a warehouse scenario as can be seen in the image below. The truck will need to dinamically find a path between the starting position and the target position. When a path is found the truck will need to drive this path without the trailer jackkniffing. The following image show a general overview of how this project works.
Videos of these parts can be seen here:
- Hybrid A*
- Trajectory Optimization
- Model Predictive Controller
A scenario has been created with different parking spots. A truck trailer model can be placed in one of these spots. The Hybrid A* algorithm will find a path between the start position and the end position with the lowest costs. This path is found by expanding nodes in forward and backward direction under different steering angles to find new nodes. For each node a cost is calculated and the node with the lowest cost is expanded upon. These costs are based on two parts:
-
Cost to go
- Driven distance forward
- Driven distance backward
- Absolute steering wheel angle
- Change in steering wheel angle
- Hitch Angle
-
Heuristics
- Absolute Euclidian distance between current and end trailer
- Sideways distance between current and end trailer
- Forward distance between current and end trailer
- Angle between the current and end trailer
- Switching direction of movement
After a path has been found this path is saved and sent to the trajectory optimization code. This algorithm optimizes the trajectory by making the path smooth, so it can be more easily followed by the controller, this is done by optimizing a cost function. The trajectory animation is defined as a minimization problem, that also includes constraints on the states and control inputs of the system (this is to prevent jackknifing and abrupt changes in speed or steering). There are also constraints added to avoid collisions.
The optimized path is sent back to be used in the controller to control the truck. The MPC controller will follow this path while making sure no jackkniffing occurs. This is again described as an optimization problem, with a cost function that includes the difference between the optimized path's states and the actual states. And also includes constraints on the states and control inputs. No collision constraints are considered for the MPC, as in reality the MPC should ideally not be deviating from the optimized path, which is already collision free. And adding the constraints would increase the computation time a lot.
To generate the collision constraints in a way that can be used by the solver (IPOPT) we have used the method described in Optimization-Based Collision Avoidance. This method is known as optimization based collision avoidance (OBCA)
- What software do I need? To make this project work you need Unity together with Python.
- Where can I find the Hybrid A* algorithm? This implementation can be found under Assets/Scripts/Pathfinding/Hybrid A star/HybridAStar.cs. The parameters used can be found in Assets/Scripts/Pathfinding/Parameters.cs
- Where can I find the Trajectory Optimization code? This is located in the folder PythonParts.
- Where can I find the MPC controller code? This is located in the folder PythonParts.
TU Delft BEP by: Cedric Pelsma, Erwin Bus, Kik Kramer, Matthijs Steyerberg, Mitchel Castelyns
Special thanks to our supervisor: Luyao Zhang