ROS implementation of a formation flying pipeline with distributed motion planning, decentralized task assignment, and onboard localization---all running onboard each vehicle.
In this pipeline, an operator dispatches a desired formation shape to a team of multirotors. Each multirotor needs only the relative translation to each of its neighbors, a subset of the team defined by the desired formation. These relative translations make up a vehicle's local knowledge and can be measured using methods such as RGB-D sensors or communication.
Upon receiving a desired formation (or to break gridlocks), we would like multirotors to assign themselves to a point in the formation that is closest to their current position. Because each vehicle only has local knowledge of the team, we present a decentralized task assignment algorithm wherein each vechicle auctions on its preferred formation points using only its understanding of its neighbors positions. Using consensus, global convergence is achieved with limited communication.
Using these techniques with an off-the-shelf VIO/SLAM system, large aerial formations can be achieved without external infrastructure or global knowledge.
If this pipeline is useful, please cite:
P. Lusk, X. Cai, S. Wadhwania, A. Paris, K. Fathian, J. How, "A Distributed Pipeline for Scalable, Deconflicted Formation Flying", arXiv:2003.01851.
The aclswarm
pipeline leverages ROS and the MIT ACL custom autopilot stack. This stack targets the Qualcomm Snapdragon Flight and supports software-in-the-loop (SIL) simulation.
This software has been tested with ROS Indigo, Kinetic and Melodic. We assume your preferred flavors of Ubuntu/ROS have already been installed.
To get started, create a new workspace and use wstool to setup the necessary dependencies.
$ mkdir -p aclswarm_ws/src && cd aclswarm_ws/src
$ catkin init && catkin config --extend /opt/ros/melodic # or whatever
$ git clone https://github.com/mit-acl/aclswarm
$ wstool init
$ wstool merge ./aclswarm/.simulation.rosinstall.https
$ wstool up -j8
Then, build and source your workspace as usual
$ catkin build
$ source ../devel/setup.bash
To run a simulation (referred to as a trial) use the following incantation. There must not be a roscore
running before you run this step.
$ rosrun aclswarm_sim trials.sh -f swarm6_3d -i
This will spin up a simulation and open an rviz
window (see Visualization section below) and an rqt_gui
window. Wait for the following message in the terminal (depending on your machine you may need to wait a few seconds after this message for good measure):
Simulation initialized. You may now press 'START'.
Once rqt_gui (7260) is quit, simulation will clean up.
Follow the instructions in the Operation section below. Note that exiting the rqt_gui
window will quit the entire simulation.
To run an experiment, follow this sequence:
- Arm each of the vehicles. In simulation the vehicles are armed by default.
- Press START in the
rqt_gui
window and the vehicles will take off to theirtakeoff_alt
. - Each subsequent click of the START button causes the swarm to cycle through the formations defined in the formation group (e.g.,
swarm6_3d
). - Press END to gracefully land the vehicles in their current x-y position.
- Press E-STOP to emergency stop, which immediately kills the motors.
We use rviz to visualize the formation. In the image below, the elements represented are as follows
- Quadrotor meshes: the position of each vehicle in the (unknown) global frame
- Black spheres: the desired formation aligned to the swarm via centralized Arun's method. These are only for debugging and this data is not used in the pipeline. That is why the UAVs often do not end up at these points; instead, they serve to give a rough indication of what the swarm is doing.
- Blue lines: Desired command calculated by the distributed motion planning on-board each UAV.
- Red lines: Output of
safety
node --- takes the desired command (blue lines) and implements collision avoidance if needed.