q# QM9 (Compact Split)

Reproduces dipole moment `μ` and internal energy `U0` on a compact split (3000/300/300).

## Environment
```bash
python -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt
```

If PyG extras (torch-scatter, torch-sparse) fail to resolve via pip, install them per:
https://pytorch-geometric.readthedocs.io/en/latest/install/installation.html

## Run (Linux/Mac)
```bash
bash scripts/run_qm9_mu_base.sh   # base model
bash scripts/run_qm9_mu_plus.sh   # +Z,dist variant
```

## Run (Windows)
```
scripts\run_qm9_mu_base.bat
scripts\run_qm9_mu_plus.bat
```

# QM9 Reproduction

Configs reported in the paper:
- mu, base: depth=1, k=6
- mu, plus: depth=2, k=8
- U0, base: depth=1, k=6
- U0, plus: depth=2, k=8


One-command runs (optional):
- Linux:  scripts/run_qm9_mu_base.sh, scripts/run_qm9_mu_plus.sh, ...
- Win:    scripts/run_qm9_mu_base.bat, scripts/run_qm9_mu_plus.bat, ...

Notes:
- “plus” = atomic numbers Z and pairwise distances enabled.
- Check logs for the chosen checkpoint (best-by-validation).


## Notes
- Dataset is pulled automatically by `torch_geometric.datasets.QM9`.
- Results are written under `runs/` and summarized in `results/metrics.csv`.
