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

This repo is based on the open-source [pymarl](https://github.com/oxwhirl/pymarl) framework, with some implementation adapted from [ICES](https://github.com/LXXXXR/ICES). Please refer to those repo for more documentation.

## Installation instructions

Set up Google Research Football: Follow the instructions in [GRF](https://github.com/google-research/football?tab=readme-ov-file#quick-start) .


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 3v1:

```
python src/main.py --exp-config=3v1_eece_s0 --config=eece --env-config=academy_3_vs_1_with_keeper
```
