# README.md

## Project Overview

This repository contains implementations of **GEMS** and various **PSRO-based algorithms** across multiple experimental domains. It is organized into four main folders:

* **`deceptive_mean/`** – Experiments on the **Deceptive Messages** environment.
* **`khun_poker/`** – Experiments on **Kuhn Poker**, including GEMS-OMWU and multiple PSRO variants.
* **`pettingzoo/`** – Experiments using **PettingZoo MPE** environments (`simple_tag_v3` and `simple_spread_v3`).
* **`GIFs/`** – Output visualizations for **Simple Tag** runs (GEMS and PSRO).

Each folder contains a dedicated `README.md` with setup instructions, dependencies, and usage examples specific to that domain.

---

## Folder Structure

```
project_root/
│
├── deceptive_mean/
│   ├── gems.py
│   ├── psro.py
│   ├── apsro.py
│   ├── do.py
│   ├── alphapsro.py
│   └── README.md
│
├── khun_poker/
│   ├── gems.py
│   ├── psro.py
│   ├── apsro.py
│   ├── do.py
│   ├── alphapsro.py
│   └── README.md
│
├── pettingzoo/
│   ├── run.sh
│   ├── gems.py
│   ├── psro.py
│   └── README.md
│
└── GIFs/
    ├── GEMS/
    │   ├── seed_0.gif
    │   ├── seed_1.gif
    │   ├── seed_2.gif
    │   ├── seed_3.gif
    │   └── seed_4.gif
    │
    └── PSRO/
        ├── seed_0.gif
        ├── seed_1.gif
        ├── seed_2.gif
        ├── seed_3.gif
        └── seed_4.gif
```

---

## GIF Outputs

The `GIFs/` folder contains animated visualizations of the **Simple Tag** environment:

* **`GIFs/GEMS/`** – Output GIFs generated by **GEMS** runs.
* **`GIFs/PSRO/`** – Output GIFs generated by **PSRO** runs.

Each folder contains GIFs for **seeds 0, 1, 2, 3, and 4**, showcasing different random initializations.

Example structure:

```
GIFs/
  GEMS/
    seed_0.gif
    seed_1.gif
    seed_2.gif
    seed_3.gif
    seed_4.gif

  PSRO/
    seed_0.gif
    seed_1.gif
    seed_2.gif
    seed_3.gif
    seed_4.gif
```

These visualizations help qualitatively assess agent behavior in `simple_tag_v3` over time.

---

## Setup Instructions

Each experimental domain (`deceptive_mean`, `khun_poker`, `pettingzoo`) has **its own `README.md`** with detailed setup instructions. Please refer to them for:

* Required Python version and dependencies.
* How to run specific algorithms (GEMS, PSRO, etc.).
* Example commands and outputs.

General dependencies:

* **Python:** 3.11.9
* **PyTorch:** 2.8.0+cu128
* **NumPy:** 2.1.3
* **Matplotlib:** 3.10.0

Install core libraries:

```bash
pip install torch==2.8.0+cu128 numpy==2.1.3 matplotlib==3.10.0 tqdm
```

---

## Reproducibility Notes

To replicate our results:

1. Use the same Python and library versions listed above.
2. Follow the folder-specific `README.md` for correct hyperparameters.
3. Run experiments for all five seeds: `0 1 2 3 4`.
4. Collect CSV outputs and, if desired, use the provided GIFs for qualitative evaluation.

---

## Summary

This repository provides a unified framework for running GEMS and PSRO-style algorithms across three domains. By exploring each folder and following the instructions provided, you can replicate our experiments and visualize agent behaviors using the included GIF outputs.
