- Overview
- Getting Started
- Supported Environments
- System implementations
- Usage
- Installation
- Debugging
- Logging
- Roadmap
- Contributing
- Troubleshooting and FAQ
Mava is a library for building multi-agent reinforcement learning (MARL) systems. Mava provides useful components, abstractions, utilities and tools for MARL and allows for simple scaling for multi-process system training and execution while providing a high level of flexibility and composability.
βMavaβ means experience, or wisdom, in Xhosa one of South Africaβs eleven official languages.
To read more about the motivation behind Mava, please see our blog post, release and technical report.
π·ββοΈ NOTICE: Our release of Mava is foremost to benefit the wider community and make it easier for researchers to work on MARL. However, we consider this release a Beta version of Mava. As with many frameworks, Mava is (and will probably always remain) a work in progress and there is much more the team aims to provide and improve in future releases. From incorporating the latest research and innovations to making the framework more stable, robust and well tested. Furthermore, we are committed and will do our best to keep everything working and have the experience of using Mava be as pleasant as possible. During Beta development breaking changes may occur as well as significant design changes (if we feel it could greatly improve the useability of the framework) but these will be clearly communicated before being incorporated into the codebase. It is also inevitable that there might be bugs we are not aware of and that things might break from time to time. We will do our best to fix these bugs and address any issues as quickly as possible. β
At the core of the Mava framework is the concept of a system
. A system refers to a full multi-agent reinforcement learning algorithm consisting of the following specific components: an Executor
, a Trainer
and a Dataset
.
The Executor
is the part of the system that interacts with the environment, takes actions for each agent and observes the next state as a collection of observations, one for each agent in the system. Essentially, executors are the multi-agent version of the Actor class in Acme and are themselves constructed through feeding to the executor a dictionary of policy networks. The Trainer
is responsible for sampling data from the Dataset originally collected from the executor and updating the parameters for every agent in the system. Trainers are therefore the multi-agent version of the Learner class in Acme. The Dataset
stores all of the information collected by the executors in the form of a collection of dictionaries for the actions, observations and rewards with keys corresponding to the individual agent ids. The basic system design is shown on the left in the above figure.
Several examples of system implementations can be viewed here.
Mava shares much of the design philosophy of Acme for the same reason: to allow a high level of composability for novel research (i.e. building new systems) as well as making it possible to scale systems in a simple way, using the same underlying multi-agent RL system code. Mava uses Launchpad for creating distributed programs. In Mava, the system executor (which is responsible for data collection) is distributed across multiple processes each with a copy of the environment. Each process collects and stores data which the Trainer uses to update the parameters of all the actor networks used within each executor. This approach to distributed system training is illustrated on the right in the figure above. β NOTE: In the near future, Mava aims to support additional training setups, e.g. distributed training using multiple trainers to support Bayesian optimisation or population based training (PBT).
We have a Quickstart notebook that can be used to quickly create and train your first Multi-Agent System. For more information on how to use Mava, please view our usage section.
A given multi-agent system interacts with its environment via an EnvironmentLoop
. This loop takes as input a system
instance and a multi-agent environment
instance which implements the DeepMind Environment API. Mava currently supports multi-agent environment loops and environment wrappers for the following environments and environment suites:
For details on how to add your own environment, see here.
MAD4PG on PettingZoo's Multi-Walker environment. | VDN on the SMAC 3m map. | MADQN on Flatland. |
MAD4PG on the 2D RoboCup environment using 6 executors. |
Mava includes several system implementations. Below we list these together with an indication of the maturity of the system using the following keys: π© -- Tested and working well, π¨ -- Running and training on simple environments, but not extensively tested and π₯ -- Implemented but untested and yet to show clear signs of stable training.
- π© - Multi-Agent Deep Q-Networks (MADQN).
- π© - Multi-Agent Deep Deterministic Policy Gradient (MADDPG).
- π© - Multi-Agent Distributed Distributional Deep Deterministic Policy Gradient (MAD4PG).
- π¨ - Differentiable Inter-Agent Learning (DIAL).
- π¨ - Multi-Agent Proximal Policy Optimisation (MAPPO).
- π¨ - Value Decomposition Networks (VDN).
- π₯ - Monotonic value function factorisation (QMIX).
Name | Recurrent | Continuous | Discrete | Centralised training | Communication | Multi Processing |
---|---|---|---|---|---|---|
MADQN | βοΈ | β | βοΈ | βοΈ | βοΈ | βοΈ |
DIAL | βοΈ | β | βοΈ | βοΈ | βοΈ | βοΈ |
MADDPG | βοΈ | βοΈ | βοΈ | βοΈ | β | βοΈ |
MAD4PG | βοΈ | βοΈ | βοΈ | βοΈ | β | βοΈ |
MAPPO | β | βοΈ | βοΈ | βοΈ | β | βοΈ |
VDN | β | β | βοΈ | βοΈ | β | βοΈ |
QMIX | β | β | βοΈ | βοΈ | β | βοΈ |
As we develop Mava further, we aim to have all systems well tested on a wide variety of environments.
To get a sense of how Mava systems are used we provide the following simplified example of launching a distributed MADQN system.
# Mava imports
from mava.systems.tf import madqn
from mava.components.tf.architectures import DecentralisedPolicyActor
from . import helpers
# Launchpad imports
import launchpad
# Distributed program
program = madqn.MADQN(
environment_factory=helpers.environment_factory,
network_factory=helpers.network_factory,
architecture=DecentralisedPolicyActor,
num_executors=2,
).build()
# Launch
launchpad.launch(
program,
launchpad.LaunchType.LOCAL_MULTI_PROCESSING,
)
The first two arguments to the program are environment and network factory functions.
These helper functions are responsible for creating the networks for the system, initialising their parameters on the different compute nodes and providing a copy of the environment for each executor. The next argument num_executors
sets the number of executor processes to be run.
After building the program we feed it to Launchpad's launch
function and specify the launch type to perform local multi-processing, i.e. running the distributed program on a single machine. Scaling up or down is simply a matter of adjusting the number of executor processes.
For a deeper dive, take a look at the detailed working code examples found in our examples subdirectory which show how to instantiate a few MARL systems and environments.
Mava provides several components to support the design of MARL systems such as different system architectures
and modules
. You can change the architecture to support a different form of information sharing between agents, or add a module to enhance system capabilities. Some examples of common architectures are given below.
In terms of components, you can for example update the above system code in MADQN to use a communication module by wrapping the architecture fed to the system as shown below.
from mava.components.tf.modules import communication
...
# Wrap architecture in communication module
communication.BroadcastedCommunication(
architecture=architecture,
shared=True,
channel_size=1,
channel_noise=0,
)
All modules in Mava aim to work in this way.
We have tested mava
on Python 3.7, 3.8 and 3.9.
-
Build the correct docker image using the
make
command:For Windows, before the docker image build, we recommend to first install the package manager chocolatey and run (to install make):
choco install make
1.1 Only Mava core:
make build
1.2 For optional environments:
-
PettingZoo:
make build version=pz
-
SMAC: The StarCraft Multi-Agent Challenge Environments :
Install StarCraft II using a bash script, which is a slightly modified version of the script found here:
./bash_scripts/install_sc2.sh
Build Image
make build version=sc2
-
Flatland:
make build version=flatland
-
2D RoboCup environment
make build version=robocup
-
Openspiel
make build version=openspiel
-
MeltingPot
make build version=meltingpot
To allow for agent recordings, where agents evaluations are recorded and these recordings are stored in a
/recordings
folder:make build version=[] record=true
-
-
Run an example:
make run example=dir/to/example/example.py
For example,
make run example=examples/petting_zoo/sisl/multiwalker/feedforward/decentralised/run_mad4pg.py
.Alternatively, run bash inside a docker container with mava installed,
make bash
, and from there examples can be run as follows:python dir/to/example/example.py
.To run an example with tensorboard viewing enabled, you can run
make run-tensorboard example=dir/to/example/example.py
and navigate to
http://127.0.0.1:6006/
.To run an example where agents are recorded (ensure you built the image with
record=true
):make run-record example=dir/to/example/example.py
Where example, is an example with recording available e.g.
examples/debugging/simple_spread/feedforward/decentralised/run_maddpg_record.py
.
-
If not using docker, we strongly recommend using a Python virtual environment to manage your dependencies in order to avoid version conflicts. Please note that since Launchpad only supports Linux based OSes, using a python virtual environment will only work in these cases:
python3 -m venv mava source mava/bin/activate pip install --upgrade pip setuptools
1.1 To install the core libraries, including Reverb - our storage dataset , Tensorflow and Launchpad - for distributed agent support :
- Install swig for box2d:
sudo apt-get install swig -y
- Install core dependencies:
pip install id-mava[tf,reverb,launchpad]
- Or for the latest version of mava from source (you can do this for all pip install commands below for the latest depedencies):
pip install git+https://github.com/instadeepai/Mava#egg=id-mava[reverb,tf,launchpad]
1.2 For optional environments:
-
PettingZoo:
pip install id-mava[pz]
-
Flatland:
pip install id-mava[flatland]
-
Openspiel:
pip install id-mava[open_spiel]
-
2D RoboCup environment:
A local install has only been tested using the Ubuntu 18.04 operating system. The installation can be performed by running the RoboCup bash script while inside the Mava python virtual environment.
./bash_scripts/install_robocup.sh
-
StarCraft II:
First install StarCraft II
./bash_scripts/install_sc2.sh
Then set SC2PATH to the location of 3rdparty/StarCraftII, e.g. :
export SC2PATH="/home/Documents/Code/Mava/3rdparty/StarCraftII"
-
MeltingPot:
Install MeltingPot:
./bash_scripts/install_meltingpot.sh
Add MeltingPot to your python path:
export PYTHONPATH="${PYTHONPATH}:${PWD}/../packages/meltingpot"
If this fails, follow instructions here.
-
Run an example:
python dir/to/example/example.py
For certain examples and extra functionality such as the use of Atari environments, environment wrappers, gpu support and agent episode recording, we also have a list of optional installs.
To test and debug new system implementations, we use a simplified version of the spread environment from the MPE suite.
Debugging in MARL can be very difficult and time consuming, therefore it is important to use a small environment for debugging that is simple and fast but at the same time still able to clearly show whether a system is able to learn. An illustration of the debugging environment is shown on the right. Agents start at random locations and are assigned specific landmarks which they attempt to reach in as few steps as possible. Rewards are given to each agent independently as a function of their distance to the landmark. The reward is normalised to be between 0 and 1, where 1 is given when the agent is directly on top of the landmark. The further an agent is away from its landmark the more the reward value converges to 0. Collisions between agents result in a reward of -1 received by the colliding agents. To test both discrete and continuous control systems we feature two versions of the environment. In the discrete version the action space for each agent consists of the following five actions: left
, right
, up
, down
, stand-still
. In the continuous case, the action space consists of real values bounded between -1 and 1 for the acceleration
of the agent in the x
and y
direction. Several examples of running systems on the debugging environment can be found here. Below we show the results from some of our systems trained on the debugging environment.
Mava logs various metrics using tensorboard
, with the default logging directory being
./mava/<run_timestamp>
A mava
folder will be created in the root directory and here <run_timestamp>
is the date and time at which an experiment is run. Once tensorboard has been opened, there will be three main card classes namely evaluator
, executor
and trainer
corresponding to the amount specified by the user. Under each main card there will also be logging information for each respective agent in that class.
During evaluation agents are allowed to act according to their current policies without training.
The most straightforward metrics to keep track of in order to see whether agents are learning are the MeanEpisodeReturn
and MeanEpisodeLength
metrics. These are visible under both the executor
and evaluator
cards and are both computed by using a rolling average. Relevant loss metrics are available under the trainer
card.
Here is a example of how the logger may be set up in order to be passed to the relevant system implementation:
# Log every [log_every] seconds.
log_every = 10
logger_factory = functools.partial(
logger_utils.make_logger,
directory=base_dir,
to_terminal=True,
to_tensorboard=True,
time_stamp=mava_id,
time_delta=log_every,
)
Logging occurs at user specified time intervals and, as such, the independent variable in all tensorboard
plots is when logging has occured. In the above example logging occurs every 10 seconds, and as such, each point on the x-axis of a plot corresponds to 10 seconds of system runtime. When the time_delta
parameter is set to 0, this will lead to nearly constant logging which corresponds roughly with steps taken by the system.
We have big ambitions for Mava! π But there is still much work that needs to be done. We have a clear roadmap and wish list for expanding our system implementations and associated modules, improving testing and robustness and providing support for across-machine training. Please visit them using the links below and feel free to add your own suggestions!
In the slightly more longer term, the Mava team plans to release benchmarking results for several different systems and environments and contribute a MARL specific behavioural environment suite (similar to the bsuite for single-agent RL) specifically engineered to study aspects of MARL such as cooperation and coordination.
Please read our contributing docs for details on how to submit pull requests, our Contributor License Agreement and community guidelines.
Please read our troubleshooting and FAQs guide.
If you use Mava in your work, please cite the accompanying technical report:
@article{pretorius2021mava,
title={Mava: A Research Framework for Distributed Multi-Agent Reinforcement Learning},
author={Arnu Pretorius and Kale-ab Tessera and Andries P. Smit and Kevin Eloff
and Claude Formanek and St John Grimbly and Siphelele Danisa and Lawrence Francis
and Jonathan Shock and Herman Kamper and Willie Brink and Herman Engelbrecht
and Alexandre Laterre and Karim Beguir},
year={2021},
journal={arXiv preprint arXiv:2107.01460},
url={https://arxiv.org/pdf/2107.01460.pdf},
}