# Synthetic Toy Examples

This directory contains synthetic constrained minimax optimization problems for algorithm validation and comparison.

## Overview

The project implements toy examples to validate and compare constrained minimax optimization algorithms:

- **SPACO** - Stochastic Algorithm for Couple Constrained Minimax optimization
- **MGD** - Mirror Gradient Descent

## Problems

- **Linear** - Linear constrained minimax problem
- **Nonlinear** - Nonlinear constrained minimax problem

## Quick Start

```bash
cd synthetic

# Run SPACO on nonlinear problem
make spaco problem=nonlinear

# Run MGD on linear problem
make mgd problem=linear

# View all options
make help
```

**Available Commands:**
- `make spaco` - Run SPACO algorithm
- `make mgd` - Run MGD algorithm

**Configuration:**
- `problem=<name>` - Set problem (linear, nonlinear) (default: nonlinear)
- `algo=<name>` - Set algorithm (spaco, mgd, rmpdpg, mgd2spaco, rmpdpg2spaco) (default: spaco)
- `SWANLAB_MODE=<mode>` - Set SwanLab mode (cloud|offline|disabled) (default: disabled)
- `USE_UV=true` - Use 'uv run' instead of venv python (default: false)
- `EXTRA_CONFIG=...` - Add Hydra overrides (e.g., `algo.max_iters=5000`)

## Examples

```bash
# Run SPACO on linear problem
make spaco problem=linear

# Run MGD with custom iterations
make mgd problem=nonlinear EXTRA_CONFIG="algo.max_iters=10000"
```