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 you use this code in your research, please cite our paper:
- P. C. Lusk, X. Cai, S. Wadhwania, A. Paris, K. Fathian and J. P. How, "A Distributed Pipeline for Scalable, Deconflicted Formation Flying," in IEEE Robotics and Automation Letters, vol. 5, no. 4, pp. 5213-5220, Oct. 2020, doi: 10.1109/LRA.2020.3006823.
@ARTICLE{Lusk2020formation,
author={P. C. {Lusk} and X. {Cai} and S. {Wadhwania} and A. {Paris} and K. {Fathian} and J. P. {How}},
journal={IEEE Robotics and Automation Letters},
title={A Distributed Pipeline for Scalable, Deconflicted Formation Flying},
year={2020},
volume={5},
number={4},
pages={5213-5220}
}
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.
- How do I create large, random formations in simulation?
- The formation name
simformN
is a special keyword, whereN
is the number of vehicles in the formation. For example,rosrun aclswarm_sim trials.sh -f simform20 -i
will create 20 vehicles with two random formations.
- In simulation, how do I specify between generating complete or noncomplete formation graphs?
- In
aclswarm_sim/scripts/trial.sh:60
, the call thegenerate_random_formation.py
allows for the flag-fc
. Without it, randomly generated formations are noncomplete. With it, they are fully connected.
- Where are the formation gains calculated?
- The ADMM solver is required when designing formations (offline step). The solver can run either on the base station or independently on each vehicle. If the
coordination_ros.cpp
node onboard each UAV does not receive gains with the formation sent by the operator, the C++ ADMM solver will automatically be invoked. Gains can be included either manually informations.yaml
or by forcing the operator to send gains via thesend_gains
arg inoperator.launch
. The method for generating the gains on the base station is hardcoded (but can be changed) inoperator.py:190
. It is currently set tocreateGainMatrix(adjmat, pts, method='original')
. SeecreateGainMatrix
documentation for more information (including using C++ or MATLAB ADMM implementations).