Skip to content

mit-acl/aclswarm

Repository files navigation

ACL Swarm

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.

Citation

If you use this code in your research, please cite our paper:

@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}
}

Video

ACL swarm video

Getting Started

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.

Simulation

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.

Hardware

Operation

To run an experiment, follow this sequence:

  1. Arm each of the vehicles. In simulation the vehicles are armed by default.
  2. Press START in the rqt_gui window and the vehicles will take off to their takeoff_alt.
  3. Each subsequent click of the START button causes the swarm to cycle through the formations defined in the formation group (e.g., swarm6_3d).
  4. Press END to gracefully land the vehicles in their current x-y position.
  5. Press E-STOP to emergency stop, which immediately kills the motors.

Visualization

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.

ACL swarm rviz visualization

FAQ

  1. How do I create large, random formations in simulation?
  • The formation name simformN is a special keyword, where N 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.
  1. In simulation, how do I specify between generating complete or noncomplete formation graphs?
  • In aclswarm_sim/scripts/trial.sh:60, the call the generate_random_formation.py allows for the flag -fc. Without it, randomly generated formations are noncomplete. With it, they are fully connected.
  1. 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 in formations.yaml or by forcing the operator to send gains via the send_gains arg in operator.launch. The method for generating the gains on the base station is hardcoded (but can be changed) in operator.py:190. It is currently set to createGainMatrix(adjmat, pts, method='original'). See createGainMatrix documentation for more information (including using C++ or MATLAB ADMM implementations).