## Full Evaluation Pipeline

To provide an example for running the pipeline on CIFAR10 for OptiFluence (preselect_remat) for one sample.
Run the following steps in order:

### 0. Canary Preselection

After running this step, a list of preselected indices will be saved to ```./canary_selection.json``` within the experiment directory.

```bash
PYTHONPATH=. PYTORCH_CUDA_ALLOC_CONF=expandable_segments:True \
uv run -m eval.eval_select \
    --dir "experiments/main/preselection_cifar10" \
    --num_models 20
```

For instance, on CIFAR10:
```json
{
  "canary_indices": [
    33654,
    39618,
    5874,
    13158,
    30966,
    47075,
    19569,
    23597,
    42736,
    35087
  ],
  "canary_metrics": [
    61.77001953125,
    57.48309326171875,
    57.097503662109375,
    56.45923614501953,
    55.96912384033203,
    55.162254333496094,
    55.03904342651367,
    54.6925048828125,
    54.66644287109375,
    54.15779495239258
  ]
}
```

The indices are sorted by most influential first (higher metric is better). 

### 1. Optimize Canary

We use the index of the most influential sample `33654` to initialize our optimization:

```bash
JAX_PLATFORMS=cuda XLA_FLAGS="--xla_gpu_autotune_level=2" XLA_PYTHON_CLIENT_PREALLOCATE=true XLA_PYTHON_CLIENT_MEM_FRACTION=0.95 uv run \
python -m eval.eval_optimize \
    --dir "experiments/main/cifar10_preselect_remat_0" \
    --canary-indices 0 --manual-canary-selection 33654
```

### 2. Post-process Canaries

Concatenate optimized canaries into a single tensor:
    
```bash
PYTHONPATH=. JAX_PLATFORMS=cpu uv run \
    python -m eval.generate_baseline_canaries \
    --dir "experiments/main/cifar10_preselect_remat_0" --manual-canary-selection 33654
```

### 3. Train Target and Shadow Models

Train 128 target and 128 shadow models:

```bash
XLA_PYTHON_CLIENT_PREALLOCATE=false XLA_PYTHON_CLIENT_ALLOCATOR=platform XLA_FLAGS="--xla_gpu_autotune_level=1" JAX_PLATFORMS=cuda PYTHONPATH=. uv run \
    python -m eval.eval_train --no-store-models --resume \
    --dir "experiments/main/cifar10_preselect_remat_0" \
    --model-indices "0-256" --manual-canary-selection 33654
```

### 4. Run Attack

```bash
PYTHONPATH=. uv run 
python -m eval.eval_attack \
    --dir "experiments/main/cifar10_preselect_remat_0" \
    --use-cache
```

### 5. Visualization

We have provided a 

---

## Customization

- To use fewer models for training or attack, update the index ranges and modify the configuration file accordingly.
- The configuration file maps to classes in `eval.settings` and is designed to be self-explanatory.
- A key parameter is:

  **`num_eval_models`**:  
  Controls the number of models trained in each optimization step to estimate loss or hinge scores.  
  - Recommended: `3–5` for accuracy  
  - Use `1` for fast debugging


## Notes

- All commands assume [`uv`](https://github.com/astral-sh/uv) is installed.
- Make sure your environment satisfies the dependencies for PyTorch and JAX.