# Supplementary Material: Source Code for Numerical Experiments

This folder contains the source code for reproducing the numerical experiments presented in Appendix D of the paper.

## Requirements

- Python 3.10 or later
- NumPy
- Matplotlib

Install dependencies:
```bash
pip install numpy matplotlib
```

## File Description

- `synthetic_vi_experiment.py`: Main experiment script implementing the RG and ROG algorithms on synthetic variational inequality problems.

## Reproducing the Experiments

### Running All Experiments (Batch Mode)

To reproduce all six experimental configurations (monotone and strongly monotone cases with different noise levels):

```bash
python synthetic_vi_experiment.py --batch --t-max 500000 --seeds 5
```

This will generate the following output files:
- `synthetic_vi_monotone_sigma0.1_t500000.png`
- `synthetic_vi_monotone_sigma0.01_t500000.png`
- `synthetic_vi_monotone_sigma0_t500000.png`
- `synthetic_vi_strongly-monotone_sigma0.1_t500000.png`
- `synthetic_vi_strongly-monotone_sigma0.01_t500000.png`
- `synthetic_vi_strongly-monotone_sigma0_t500000.png`

### Running Individual Experiments

For a single experiment with custom parameters:

```bash
python synthetic_vi_experiment.py --d 10 --t-max 500000 --sigma 0.1 --seeds 5 --out output.png
```

### Command-Line Arguments

| Argument | Default | Description |
|----------|---------|-------------|
| `--d` | 10 | Dimension of the problem |
| `--t-max` | 5000 | Number of iterations |
| `--sigma` | 0.1 | Noise standard deviation |
| `--mu` | 0.0 | Strong monotonicity parameter (0 for monotone case) |
| `--bound` | 1.0 | Box constraint bound (domain is [-bound, bound]^d) |
| `--seeds` | 5 | Number of random seeds for averaging |
| `--out` | synthetic_vi_gap.png | Output file path |
| `--only` | both | Which algorithm to run: `rg`, `rog`, or `both` |
| `--slopes` | 0.4 | Reference slopes for comparison (comma-separated) |
| `--batch` | - | Run all six preset configurations |
| `--mu-strong` | 0.2 | Strong monotonicity parameter for batch mode |
| `--strong-c` | 2.0 | Constant c for ROG strongly monotone step size |

## Experiment Setup

The experiments use a synthetic linear operator V(x) = Ax + b where:
- A = S + K + mu * I
  - S: symmetric positive semidefinite matrix
  - K: skew-symmetric matrix
  - mu: strong monotonicity parameter (0 for monotone case)
- Domain: X = [-1, 1]^d with d = 10
- Noisy feedback: g_hat = V(x) + noise, where noise ~ N(0, sigma^2 * I)

The algorithms use the parameter schedules specified in the theorems:
- **RG (monotone)**: gamma_t = t^{-4/5}, eta_t = (D/G) * t^{-3/5}
- **ROG (monotone)**: adaptive schedules from Theorem 6.1
- **RG (strongly monotone)**: gamma_t = 0, eta_t = 1/(lambda * t)
- **ROG (strongly monotone)**: gamma_t = 0, eta_t = c/(lambda * (t + t_0))
