Autonomous SLAM & exploration using drones, a project for Caltech's ME 134
Autonomy class.
CS134_Final_Project_Report.pdf contains a
detailed description of the project and the approach used. This repository can
be cloned as a ROS package.
There are two videos showing the whole setup in action: exploring indoor environment and exploring outdoor environment. Images of the final 3D occupancy grid can be seen below.
| Indoor environment | Outdoor environment | 
|---|---|
This project was developed for ROS Kinetic (Ubuntu 16.04). The following packages are required:
- 
Drone simulation is done using hector_quadrotor and Gazebo. This page contains the instructions for installing hector_quadrotoron ROS Kinetic.
- 
OctoMap is used to generate the 3D occupancy grid. octomap_serveris used to interface OctoMap with ROS, both can be installed viaaptasros-kinetic-octomapandros-kinetic-octomap-ros.
- 
You'll need to install the OctoMap RViz plugin via aptasros-kinetic-octomap-rviz-plugins. Without it, occupancy grid visualisations in RViz will not work.
- 
To control the drone manually, you might need to install the ros-kinetic-teleop-twist-keyboardpackage and then runteleop_twist_keyboard teleop_twist_keyboard.py. There is a better tool described in the next section, but it requires pynput Python package to be installed (and available to ROS).
- 
Robot navigation is handled using the standard ROS navigation stack, namely move_base, so make sure you have that installed. Additionally, TEB local planner is used, which can be installed viaaptasros-kinetic-teb-local-planner. Make sure you haveros-kinect-pointcloud-to-laserscaninstalled for costmaps to work correctly.
- 
The scripts in this repo are written in Python 2.7 (default version for ROS Kinetic). Packages pynput, numpy are required for Python scripts to work, all of which can be installed using pip.ros_numpyis also required, it can be installed viaaptasros-kinetic-ros-numpy.
- Make sure you have the prerequisites installed.
- Clone this repo into your catkin
workspace, e.g.
into ~/catkin_ws/src/caltech_samaritan/.
- Source appropriate ROS files in your Bash instance, i.e. run source /opt/ros/kinetic/setup.bashandsource ~/catkin_ws/devel/setup.bash.
- Run catkin_makein~/catkin_ws/andsource ~/catkin_ws/devel/setup.bashagain.
- Start the simulation using roslaunch caltech_samaritan full_indoors.launch. This launch file will:- Initialize Gazebo with a sample indoors environment (if you want to try outdoors, use full_outdoors.launch),
- Spawn a simulated quadrotor with a Kinect attached to it and activate its motors,
- Launch RViz with a custom config,
- Start an OctoMap server, generating occupancy grid in real time, and
- Initialise the navigation stack.
 
- Initialize Gazebo with a sample indoors environment (if you want to try outdoors, use 
- (Optional) If you want to control the drone manually, you can use the script mentioned in the previous section.
Alternatively, you can use roslaunch caltech_samaritan teleop.launchbut it requires pynput package to be installed.
- (Optional) If you want to test the navigation stack manually, you can do the following: First, using teleop
instructions from the step above, fly around for a bit to make sure the navigation stack has something to work with;
Second, start the hover script using rosrun caltech_samaritan force_hover.py. Now you can issue "2D Nav Goals" using rviz interface to see the navigation stack in action.
- Start the exploration script with rosrun caltech_samaritan start_exploration.py.
- ???
- Profit!