# RTPCFR+ and RTPDCFR+

## Project Description
Core algorithm codes are named by **algorithm name** and stored uniformly in the `src/` directory.


## Environment Setup
### Basic Dependencies
This project is developed based on Python 3.10. All dependencies can be installed quickly via `requirements.txt`:
```bash
# Install dependencies
pip install -r requirements.txt
```

### Optional Conda Env 
To avoid dependency conflicts, you can create an isolated conda environment:
```bash
# Create conda environment
conda create -n [env-name] python=3.10
conda activate [env-name]

# Install dependencies
pip install -r requirements.txt
```

# Quick Start
All core algorithm codes are stored in the `src/` directory, and **the Python file name is exactly the same as the corresponding algorithm name**. You can specify the game for the algorithm to run with the `--game` parameter. For more game configurations and optional game types, please refer to `doc/gameset.md`.

### Run Core Self-Developed Algorithms
```bash
# Run the RTPCFR+ algorithm
python src/RTPCFRPlus.py --game kuhn_poker
# Run the RTPDCFR+ algorithm
python src/RTPDCFRPlus.py --game kuhn_poker
```

### Run Baseline Comparison Algorithms
```bash
# Run CFR+
python src/CFRPlus.py --game kuhn_poker
# Run DCFR
python src/DCFR.py --game kuhn_poker
# Run OGDA
python src/OGDA.py --game kuhn_poker
# Run OMWU
python src/OMWU.py --game kuhn_poker
# Run PCFR+
python src/PCFRPlus.py --game kuhn_poker
# Run Reg_CFR
python src/Reg_CFR.py --game kuhn_poker
# Run RTCFR+
python src/RTCFRPlus.py --game kuhn_poker
```

### Run Plotting Script
```bash
# Generate exploitability convergence curves
python src/plot.py
```

### Adjust Experimental Parameters
All **experimental parameters** of the algorithm files are centrally defined in the **main function/parameter configuration section** of the corresponding Python file. You can modify them directly in the file without changing the core logic code:
```python
# Modify parameters in src/RTPCFRPlus.py
    parser.add_argument("--game", type=str, default="kuhn_poker")
    parser.add_argument("--traverse_type", type=str, choices=["Enumerate", "External"], default="Enumerate")
    parser.add_argument("--iter", type=int, default=20000)
    parser.add_argument("--print_freq", type=int, default=100)

    parser.add_argument("--gamma", type=float, default=1e-10)
    parser.add_argument("--mu", type=float, default=1e-4)
    parser.add_argument("--shrink_iter", type=int, default=100)

```

## Baseline Reference
The implementation logic of **baseline algorithms** in this project refer to the **baseline module of the LiteEFG project** ([LiteEFG](https://github.com/liumy2010/LiteEFG)).

