# Minimal Experiments Setup

This folder contains everything needed to run the adversarial robustness and privacy (MIA) experiments with COMPAS dataset and generate all plots.

## Structure

```
minimal_experiments/
├── README.md                           # This file
├── core/                              # Core dependencies
│   ├── awp.py                         # Rashomon set generation
│   ├── dataset.py                     # Dataset loading
│   ├── fgsm.py                        # FGSM attacks
│   └── membership_inference.py        # MIA attacks
├── experiments/                       # Experiment scripts
│   ├── adversarial_robustness.py      # Adversarial robustness experiment
│   ├── privacy_experiment.py          # Privacy/MIA experiment
│   └── generate_rashomon_sets.py      # Pre-generate Rashomon sets
├── plotting/                          # Plotting scripts
│   ├── plot_robustness.py             # Adversarial robustness plots
│   ├── plot_privacy.py                # Privacy/MIA plots
│   └── plot_combined.py               # Combined robustness-privacy plots
├── scripts/                           # SLURM job scripts
│   ├── run_adversarial.sh             # Run adversarial experiment
│   ├── run_privacy.sh                 # Run privacy experiment
│   └── generate_rashomon.sh           # Generate Rashomon sets first
└── prepare_compas.py                  # Convert COMPAS CSV to standard format

```

## Quick Start

### 1. Prepare COMPAS Dataset
```bash
conda activate diffusion
python prepare_compas.py
```

### 2. Generate Rashomon Sets (Recommended)
Generate all Rashomon sets first so both experiments can run in parallel:
```bash
sbatch scripts/generate_rashomon.sh
```
Wait for completion (~1-2 hours per dataset).

### 3. Run Experiments
Once Rashomon sets are generated:
```bash
sbatch scripts/run_adversarial.sh
sbatch scripts/run_privacy.sh
```

Or run sequentially without pre-generating:
```bash
sbatch scripts/run_adversarial.sh  # Wait for completion
sbatch scripts/run_privacy.sh
```

### 4. Generate Plots
After experiments complete:
```bash
# Robustness plots (3 datasets side-by-side for each attack strength)
python plotting/plot_robustness.py

# Privacy plots (3 datasets side-by-side)
python plotting/plot_privacy.py

# Combined robustness-privacy plots (3 datasets for each attack strength)
python plotting/plot_combined.py
```

## Configuration

### Datasets
Both experiments run on: `iris`, `seeds`, `wine`, `compas`

### Model Architecture (per dataset)
- **iris**: 16 hidden units, 2 layers
- **seeds, wine**: 25 hidden units, 3 layers
- **compas**: 20 hidden units, 4 layers

### Experiment Parameters
- Rashomon models: 100 per dataset
- Pool/ensemble sizes: 1-50
- Trials per size: 20
- FGSM attack strengths (ε): 0.1, 0.2, 0.5

### Output Locations
- Rashomon models: `../saved_models/{dataset}_rashomon_privacy/`
- Adversarial results: `../results/adversarial_robustness/{dataset}/`
- Privacy results: `../results/privacy_experiment/{dataset}/`
- Plots: `../results/combined_plots/`

## Notes

- Both experiments share the same Rashomon model directories
- Generate Rashomon sets first to enable parallel experiment execution
- Each experiment takes ~2-4 hours per dataset on GPU
- Rashomon generation takes ~30-60 minutes per dataset
