Drone Navigation - Rapidly-Exploring Random Tree
by BradyW22 in Circuits > Robots
165 Views, 1 Favorites, 0 Comments
Drone Navigation - Rapidly-Exploring Random Tree
data:image/s3,"s3://crabby-images/3cb55/3cb55f14577793ddc460c494fa3e67e0b4e9c4b7" alt="Screenshot 2024-08-27 at 4.28.15 PM.png"
This project implements a navigation algorithm known as a Rapidly-Exploring Random Tree (RRT) to navigate through an obstacle course
Supplies
Crazyflie 2.1 Drone
Jupyter Notebook
Overview
data:image/s3,"s3://crabby-images/5fcee/5fcee223f00371540d609237fc168e61a4bc78f2" alt="Screenshot 2024-08-28 at 1.53.25 PM.png"
This project takes the theory of the RRT algorithm and implements it into a crazyflie drone to navigate a known obstacle course. While researching, I stumbled upon this paper by Steven M. Lavelle. He outlines the benefit of an RRT to be robust across many scenarios - holonomic & non-holonomic constraints and higher DoF systems. This allowed me to use the RRT to path-plan for a 6 DoF non-holonomic drone.
This story outlines the code for RRT creation, configuration space planning, and hardware implementation. A video at the end displays the drone's performance.
RRT Algorithm Setup and Helper Functions
data:image/s3,"s3://crabby-images/e11c9/e11c9400be63394fb553b773e653ca9332ddbad1" alt="Screenshot 2024-08-28 at 1.56.59 PM.png"
data:image/s3,"s3://crabby-images/44d60/44d60a321a95d27374f0b3a3c9ae6809e26bf320" alt="Screenshot 2024-08-28 at 1.56.35 PM.png"
data:image/s3,"s3://crabby-images/f3701/f3701386962bea7a030ab0305cdb4647ad1d34c3" alt="Screenshot 2024-08-28 at 1.57.26 PM.png"
data:image/s3,"s3://crabby-images/cd1cd/cd1cdc3ff7d05957024dd109503e2c0e9554add4" alt="Screenshot 2024-08-28 at 2.00.05 PM.png"
data:image/s3,"s3://crabby-images/8d324/8d324304e51b4b0e82c0dba0a04a873a662fb801" alt="Screenshot 2024-08-28 at 2.01.47 PM.png"
These blocks are for the setup and helper functions of the main RRT algorithm. The blocks follow the photo sequence:
- Setup
- Configuration checking
- Edge checking
- Random configuration sampling
- Path creation
Main RRT Algorithm
data:image/s3,"s3://crabby-images/ed283/ed28399a4f959783247c9b5fe597e5c4b8dbcafd" alt="Screenshot 2024-08-28 at 2.04.50 PM.png"
data:image/s3,"s3://crabby-images/dcf09/dcf091c83e25e20318047d7f7d269442b7cb6882" alt="Screenshot 2024-08-28 at 2.05.11 PM.png"
The algorithm follows the sudo-code developed by Steven LaVelle in his paper.
The blocks follow the photo sequence:
- Main RRT algorithm
- Path creation through back tracking
Define Configuration Space
data:image/s3,"s3://crabby-images/c246a/c246ae1a2125bdf7b1f666349340c1ee9f283fc0" alt="Screenshot 2024-08-28 at 2.08.06 PM.png"
This creates a configuration space for the RRT navigation. The algorithm "knows" how the course will look by receiving measurements of the location and size of each obstacle in advance. The drone has a set boundary that determines the universal location. Although the RRT depicts the drone as a point, the obstacles are "inflated" to compensate for the drones volume.
Plot the Trajectory
data:image/s3,"s3://crabby-images/8b40d/8b40d8b0ba2fe03ed8bdc051ba834745f67935df" alt="Screenshot 2024-08-28 at 2.09.11 PM.png"
data:image/s3,"s3://crabby-images/616d9/616d9b0c04f1d10d78ded2cdf47f56b966b1185a" alt="Screenshot 2024-08-28 at 2.09.42 PM.png"
After plotting the trajectory, the path should look something like the above. Sometimes a path isn't found due to the RRT's random nature. Just retry the block until a path is found.
Implement Into the Hardware
A file for the entire code file is provided below
Downloads
Results
data:image/s3,"s3://crabby-images/69fe2/69fe254bf2675799055a1b514bdad872661dad29" alt="drone_RRT_navigation"
The output should look similar to this:
Trajectory Setpoints
The final result video is embedded above.