# Codes for synthetic experiments 

Synthetic experiments for studying Preference Learning with Bradley-Terry models.

## Requirements

- Python 3.10+
- PyTorch

## Experiments

### 1. Margin
Compares baseline vs rank-normalized reward.
```bash
python experiments.py margin
```

### 2. Connectivity-Alpha
Sweeps alpha parameter controlling P- skewness.
```bash
python experiments.py connectivity-alpha
python experiments.py connectivity-alpha --compute-connectivity  # include connectivity metric
```

### 3. Optimize-Connectivity
Compares baseline vs optimized P- over beta values.
```bash
python experiments.py optimize-connectivity
python experiments.py optimize-connectivity --include-optimized  # include optimized variant
```

## Common Arguments

| Argument | Default | Description |
|----------|---------|-------------|
| `--seeds` | 0 1 2 3 4 | Random seeds |
| `--num-triplets` | 128 512 ... 131072 | Triplet counts to sweep |
| `--device` | cuda | cpu, cuda, or auto |
| `--output` | results/*.json | Output path |

## Output

Results are saved as JSON to `results/` directory.
