# SFMPE

Structured flow matching for posterior estimation.

Under development. More to come...

## Running Experiments

### Hierarchical Gaussian Example

The hierarchical Gaussian example uses Hydra for configuration management:

#### Basic run with default parameters:
```bash
python examples/hierarchical_gaussian.py
```

#### Override specific parameters:
```bash
python examples/hierarchical_gaussian.py n_simulations=5000 n_epochs=500
```

#### Parameter sweep (equivalent to the old hg_run.sh):
```bash
python examples/hierarchical_gaussian.py -m n_simulations=1000,5000,10000 n_rounds=1 n_epochs=1000
```

#### Plot results:
```bash
python examples/plot_metrics.py --output-dir outputs
```

## MCMC results


```bash
JAX_ENABLE_X64=1 python examples/seir_mcmc.py n_simulations=1000 n_post_samples=1000 mcmc.n_burnin=1000 mcmc.max_doublings=3 mcmc.step_size=0.001 n_epochs=1 n_rounds=1 n_sites=2 n_obs=5
```

Configuration files are located in `examples/conf/` and can be customised as needed.

## Testing

The project uses pytest for testing with custom markers to categorize different types of tests:

### Running Tests

#### Default test run (excludes slow and diagnostic tests):
```bash
python -m pytest test/
```

#### Run all tests including slow ones:
```bash
python -m pytest test/ -m "slow or not slow"
```

#### Run only slow tests:
```bash
python -m pytest test/ -m "slow"
```

#### Run only flow diagnostic tests:
```bash
python -m pytest test/ -m "flow_diagnostics"
```

#### Run all tests (including slow and diagnostic):
```bash
python -m pytest test/ -m ""
```

### Test Categories

- **Default tests**: Core functionality tests that run quickly and should always pass
- **Slow tests**: Tests that take longer to run (marked with `@pytest.mark.slow`)
- **Flow diagnostic tests**: Tests for validating flow-based models (marked with `@pytest.mark.flow_diagnostics`)

The default configuration excludes slow and flow diagnostic tests to keep the development feedback loop fast.

