# Asymmetric Perturbation in Solving Extensive-Form Game

Implementation of various solvers for Extensive-Form Games.

## Usage

Basic execution command:

```bash
uv run -m train algorithm=AsymPDGDA
```

### Customizing Parameters

You can customize various parameters through the configuration file (`src/train/conf/config.yaml`) or command-line arguments.

```bash
# Specify algorithm and iteration count
uv run -m train algorithm=CFR iter=50000

# Change the game type
uv run -m train algorithm=PGDA game=kuhn_poker iter=100000
```

## Configuration Parameters

- `game`: Game type (default: `kuhn_poker`)
- `traverse_type`: Traversal method (default: `Enumerate`)
- `iter`: Number of iterations (default: `100000`)
- `print_freq`: Progress display frequency (default: `1000`)
- `algorithm`: Algorithm to use (default: `CFR`)

## Available Algorithms

The following algorithms are available:

- `AsymPDGDA` - Asymmetric Perturbed Dilated Gradient Descent-Ascent
- `CFR` - Counterfactual Regret Minimization
- `CFRPlus` - CFR+
- `DCFR` - Discounted CFR
- `DGDA` - Dilated Gradient Descent-Ascent
- `DMWU` - Dilated Multiplicative Weights Update
- `DOGDA` - Discounted Online Gradient Descent-Ascent
- `DOMWU` - Discounted Online Multiplicative Weights Update
- `LCFR` - Linear CFR
- `SymPDGDA` - Symmetric Perturded Dilated Gradient Descent-Ascent

Each algorithm has a corresponding configuration file in the `src/train/conf/algorithm/` directory.

### Algorithm Parameters Example (AsymPDGDA)

```yaml
_target_: algorithm.AsymPDGDA
eta: 0.1
tau: 0.1
weighted: false
```

## Output

Execution results are saved in the `logs/` directory.
The output path follows this format:

```
logs/{game}/{algorithm}/{parameters}/
```

## Project Structure

```
src/
├── algorithm/          # Algorithm implementations
│   ├── BaseSolver.py
│   ├── CFR.py
│   ├── AsymPDGDA.py
│   └── ...
└── train/             # Training scripts
    ├── __main__.py
    └── conf/          # Hydra configuration files
        ├── config.yaml
        └── algorithm/
            ├── CFR.yaml
            ├── AsymPDGDA.yaml
            └── ...
```

## Dependencies

Dependencies are managed in `pyproject.toml`.
Install using uv:

```bash
uv sync
```
