# CLIMB supplementary artifact (anonymized)

This bundle is a compact, review-friendly reproduction package. It
intentionally excludes full raw logs and model weights to keep size small.

## What is included
- figures/: final paper figures (PDF/PNG)
- results/summary/: LaTeX tables used by the paper
- paper_data/: curated intermediate data to regenerate all figures/tables without raw logs
- plots/: plotting scripts (see notes below)
- tables/: table-generation scripts (raw-log mode) + build_snapshot_from_run_summaries.py + render_snapshot_tables.py
- analysis/formula_fit_out/: diagnostic windows (also mirrored under paper_data/)
- configs/: workloads and policy configs
- policies/ (per-file mapping to paper names):
  - policies/gate_rr.py — **CLIMB**
  - policies/vanilla.py — **GlobalFIFO**
  - policies/cap_only.py — **BGCap**
  - policies/cache_aware.py — **LRUGate**
  - policies/no_switch.py — **LockGate**
  - policies/gate_rr_pp.py — **ClassDRR**
  - policies/gate_u.py — **UrgencyGate**
  - policies/gate_mix.py — **SkewMixGate**
  - policies/legacy.py — legacy variants (GateDRR-Guard / OpenDRR-Guard / GateRR-Guard / GateDRR) via configs/policies/legacy*.yaml
  - policies/base.py — shared base class
  - policies/__init__.py — policy registry
- patches/: empty (no vLLM patches in this bundle)

## Quick start (no GPU, no raw logs)
These scripts use paper_data/ to regenerate all paper figures/tables without
raw logs. Outputs go to figures/ and results/summary/:

```bash
python -m pip install -r requirements.txt
python plots/plot_wk_sweep_combo.py
python plots/plot_baseline_tradeoff.py
python plots/plot_formula_diagnostic.py
python plots/plot_phase_mech.py --paper-data
python plots/plot_rank_sweep_heatmap.py --paper-data
python tables/build_per_class_throughput_tok_eq.py
python tables/build_vip_absence_table.py
python tables/build_snapshot_from_run_summaries.py
python tables/render_snapshot_tables.py
```

Notes:
- plot_formula_diagnostic.py auto-uses paper_data/diagnostic if present.
- plot_wk_sweep_combo.py uses paper_data/figures/fig_wk_sweep_combo.json.
- plot_baseline_tradeoff.py uses paper_data/figures/fig_baseline_tradeoff.json.
- plot_phase_mech.py uses paper_data/figures/timeseries_phase_mech.csv in
  --paper-data mode (time-series, no raw logs required).
- plot_rank_sweep_heatmap.py uses paper_data/figures/rank_sweep_heatmap.npz in
  --paper-data mode (heatmap matrix, no raw logs required).
- build_snapshot_from_run_summaries.py builds paper_data/results_snapshot from paper_data/run_summaries.csv.
- render_snapshot_tables.py renders tables from paper_data/results_snapshot.

Figure provenance (no‑GPU path):
- Generated from paper_data:
  - fig_wk_sweep_combo.pdf (paper_data/figures/fig_wk_sweep_combo.json)
  - fig_baseline_tradeoff.pdf (paper_data/figures/fig_baseline_tradeoff.json)
  - fig_formula_diagnostic.pdf / fig_formula_diagnostic_appendix.pdf
    (paper_data/diagnostic/**/windows.csv)
  - fig_phase_mech.pdf (paper_data/figures/timeseries_phase_mech.csv)
  - fig_rank_sweep_heatmap_w2.pdf (paper_data/figures/rank_sweep_heatmap.npz)

Table provenance (no‑GPU path):
- Generated from paper_data:
  - tab_per_class_throughput_tok_eq.tex (tables/build_per_class_throughput_tok_eq.py)
  - tab_vip_absence.tex (tables/build_vip_absence_table.py)
- Rendered from paper_data/results_snapshot (generated from paper_data/run_summaries.csv):
  - tab_cliff_safe.tex, tab_baseline_zoo.tex, tab_controls.tex,
    tab_pro6000_k4_m8.tex, tab_bg_liveness.tex
- Rendered from paper_data/results_snapshot (curated snapshots):
  - tab_overhead_appendix.tex, tab_variant_mechanisms.tex, tab_gaterrpp_wtl.tex
  - (backed by paper_data/results_snapshot/curated_min.json)
- Static in main paper PDF:
  - Narrative/definition tables that live directly in the TeX and are not
    part of results/summary (e.g., notation tables).
  - tab:diagnostic_auc appears only in the main paper PDF; the artifact
    provides the AUC plot inputs (paper_data/diagnostic/**/windows.csv) and
    plotting script instead.

Extra (not referenced by a paper table label):
- tab_bg_liveness.tex (supplementary table; the main paper uses a paragraph)

## Optional full reproduction (GPU)
This bundle includes configs/ and policies/ so you can re-run experiments in
principle, but the full runner/logging pipeline and raw logs are not included
here. If you need to regenerate from scratch, install optional GPU deps and
adapt your runner to:

```bash
python -m pip install -r requirements-gpu.txt
```

- use configs/ as workload + policy definitions
- emit requests_log.csv and control_log.csv per run
- post-process into summary tables, then re-run plots

If you need a specific CUDA build of PyTorch, follow the comment in
requirements-gpu.txt and install the matching wheel for your system.

### GPU mini-run (K=4 and K=8, W2/M8)
Runs `vanilla` (GlobalFIFO) and `gate_rr` (CLIMB) once each at K=4 and K=8 using the local config
below. Outputs a Markdown summary under `submission_ext/reports/`, and mirrors
run logs to `submission_ext/runs/` plus report CSVs to `submission_ext/report/`.

```bash
# edit paths if needed (run inside submission_ext/)
sed -n '1,120p' configs/local_settings.sh

# run the two points (K=4, K=8)
bash scripts/run_gpu_w2_min_local.sh
```

This wrapper generates a short report:
`submission_ext/reports/gpu_run_summary.md`, and mirrors run directories / CSVs
into `submission_ext/runs/` and `submission_ext/report/`.

## Notes
- paper_data/ contains the minimal intermediate artifacts to make all figures
  and tables reproducible without raw logs.
- Policy naming in this bundle: `gate_rr` is the main CLIMB policy used in the
  paper. `legacy*` entries are historical variants kept only for auditability
  and are not used by any commands in this submission.
