![]() |
uavprojectilecatcher repositoryuav mav mavlink plugin apm px4 px4 catkin_tools_prebuild mavlink drone_ball_catcher libmavconn mavros mavros_extras mavros_msgs test_mavros realsense2_description realsense_gazebo_plugin |
|
Repository Summary
Description | A ROS Workspace for the interception of a ball projectile via a simulated drone |
Checkout URI | https://github.com/arijitnoobstar/uavprojectilecatcher.git |
VCS Type | git |
VCS Version | master |
Last Updated | 2021-05-16 |
Dev Status | UNKNOWN |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | uav mav mavlink plugin apm px4 |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Packages
Name | Version |
---|---|
px4 | 1.0.0 |
catkin_tools_prebuild | 0.0.0 |
mavlink | 2021.1.4 |
drone_ball_catcher | 0.0.0 |
libmavconn | 1.5.1 |
mavros | 1.5.1 |
mavros_extras | 1.5.1 |
mavros_msgs | 1.5.1 |
test_mavros | 1.5.1 |
realsense2_description | 3.1.7 |
realsense_gazebo_plugin | 1.1.0 |
README
Software and Control Architecture of a Ball Catching Drone
This repository hosts a ROS workspace of the control and software architecture of a ball catching drone in a Gazebo simulation. All details can be found in ME4232_Final_Report.pdf
with a summarised version in our poster, ME4232poster.pdf
. The catkin workspace was made in ROS Melodic (Ubuntu 18.04).
We attempt to intercept the path of a moving ball
with a drone in simulation
via a depth camera
After filtering the image using colour thresholding and fringe point removal by removing points that are over 2 standard deviations from the center of the detected ball, we get the following result in simulation:
We then consider multiple possible path planning options for the drone. The first test being a simple detection and collision with a stationary ball
The next method is to simply chase after the ball in a ‘cat chase mouse’ method where the drone moves towards a moving ball and yaws if it starts to leave the view of the depth camera.
The issue with this method is that it is not very efficient, so a better way would be to predict the path of the ball via trajectory prediction and then plan the path of the drone as such.
One example would be to intercept the trajectory of the ball at the point closest to the drone.
But the issue with this is that with time, the actual path will deviate from the predicted path.
Hence it may be better to intercept earlier along a ball’s path even if it may not be the closest to the drone.
The dashboard of the control & software architecture in the Ubuntu 18.04 terminal is as shown
The RQT graph of all ROS topics and nodes is as shown: