# Sampling On Metric Graphs

## Setup

### Python packages
`pip install -r requirements.txt`

### Build the CUDA kernels

Use the repo-level Makefile, which auto-detects the installed GPU architecture:

```
make kernel
```

## Run the experiments

Single run (uses `main/config.py`):

```
make run
```

Grid sweep (uses `main/grid_config.py`):

```
make grid
```

Modify configuration as needed in config.py.

To run grid of experiments with different configurations, use grid-run:

`sorcerun grid-run main.py grid_config.py`

## Relevant code

- `main/main.py` - main script to run the experiments.
- `main/config.py` - configuration file for the experiments.
- `langevin-gpu/src/langevin.cu` / `python/langevin_simulator.py` - CUDA kernels and Python wrapper for Algorithm 1.
- `torch_fvm.py` - PyTorch implementation of the baseline FVM scheme.
- `experiments/dumux_tracer/*` - DuMuX/FVM + metric-graph comparison scripts and plotting.

## DuMuX (advection–diffusion on vascular network)

Key Makefile targets (all live under `experiments/dumux_tracer/`):

- `dumux-advection-preprocess`: filter the DuMuX network, apply flux scale, subdivide edges (`target_dx`).
- `dumux-advection-run`: run the DuMuX 1D tracer example on the filtered grid.
- `dumux-advection-fvm`: extract the FVM tracer output (NPZ).
- `dumux-advection-metric`: run the metric-graph (Algorithm 1) solver using the same inputs.
- `dumux-advection-compare`: compare MG vs FVM outputs.
- `dumux-advection-plots`: runtime/density/velocity plots.
- `dumux-advection-metric-gifs`: GIFs from MG-only runs.

Revision-specific convenience targets:
- `revision-drift-data` / `revision-drift-plots` / `revision-drift-gifs`
- `revision-drift-mg-density` (MG steady-state density)
- `revision-drift-fvm-density` (FVM steady-state density)
- Diffusion counterparts: `revision-diffusion-data` / `revision-diffusion-plots` / `revision-diffusion-gifs`

## Revision plots (diffusion & drift)

- Diffusion figures/GIFs: `make revision-diffusion-data` then `make revision-diffusion-plots` (and `make revision-diffusion-gifs` if needed). Uses the latest manifest under `data/revision/diffusion/`.
- Drift (advection) figures/GIFs: `make revision-drift-data` then `make revision-drift-plots` and `make revision-drift-gifs`. Uses the latest manifest under `data/revision/drift/`. FVM density: `make revision-drift-fvm-density`. MG-only density: `make revision-drift-mg-density` (10M-particle manifest at `data/revision/drift/20251130_091748/manifest.json`).
