# ICLR 2026 Artifact: Gauge-Theory-based Graph Neural Network

This package contains code to reproduce the **Synthetic Gauge Diagnostic** (binary classification) and a compact **QM9** regression subset, as described in the paper.

## Environments

- **Python** ≥ 3.9 (3.10 recommended)
- **PyTorch** ≥ 2.2 (CPU is fine; GPU optional)
- **torch-geometric** ≥ 2.4 (for QM9)
  - If pip cannot resolve `torch-scatter` / `torch-sparse`, follow the official PyG install guide.

Each subfolder has its own `requirements.txt`.

### Quickstart (Linux/Mac)
```bash
# Synthetic (Medium)
cd synthetic
python -m venv .venv && source .venv/bin/activate
pip install -r requirements.txt
bash scripts/run_synth_medium.sh
```

```bash
# QM9 (Dipole μ, base and +Z,dist variant)
cd QM9
python -m venv .venv && source .venv/bin/activate
pip install -r requirements.txt
bash scripts/run_qm9_mu_base.sh
bash scripts/run_qm9_mu_plus.sh
```

### Quickstart (Windows, cmd)
```
cd synthetic
python -m venv .venv && .venv\Scripts\activate
pip install -r requirements.txt
scripts\run_synth_medium.bat
```
```
cd QM9
python -m venv .venv && .venv\Scripts\activate
pip install -r requirements.txt
scripts\run_qm9_mu_base.bat
scripts\run_qm9_mu_plus.bat
```

## Notes
- The synthetic script prints an $O(d)$ invariance sanity statistic at the end.
- QM9 is downloaded automatically by `torch_geometric.datasets.QM9` into `~/.torch/`. No RDKit is required for these targets.
- We also include compact `results/*.csv` with our runs to help reviewers compare outputs without re-running everything.

