# EECE: Ensemble-based Epistemic and Cooperative Exploration for Multi-Agent Reinforcement Learning

This is the implementation of our paper "EECE: Ensemble-based Epistemic and Cooperative Exploration for Multi-Agent Reinforcement Learning". This repo is based on the open-source [pymarl2](https://github.com/hijkzzz/pymarl2) framework, and please refer to that repo for more documentation.

## Installation instructions

Set up StarCraft II and SMAC:

```shell
bash install_sc2.sh
```

Install Python environment with conda:

```bash
conda create -n eece python=3.8 -y
conda activate eece
```

then install with `requirements.txt` using pip:

```bash
pip install -r requirements.txt
```

## Run an experiment 

```shell
python src/main.py --config=[Algorithm name] --env-config=[Env name] --exp-config=[Experiment name]
```

The config files are all located in `src/config`.

`--config` refers to the config files in `src/config/algs`.
`--env-config` refers to the config files in `src/config/envs`.
`--exp-config` refers to the config files in `src/config/exp`. If you want to change the configuration of a particular experiment, you can do so by modifying the yaml file here.

All results will be stored in the `work_dirs` folder.

For example, run EECE on 2s_vs_1sc:

```
python src/main.py --exp-config=2s_vs_1sc_s0 --config=eece --env-config=sc2
```