## Dependencies

See `requirements.txt`.

## Running the experiments

The experiments in Figure 2 use the codes at `plotting/toy.py`.

For the golf putting models, we run `run/run.py` with `Golf2` or `GolfGeo3` as the model (see implementations under `model/` for details).

For the election models, the codes to use are at `run/run.py`, with different specifications of the models (See models under `model/` for details. Models starting with `Voting` use simulated data and models starting with `Election` use real data).

For the cryoEM experiments, we run `run/run_batch.py` for PVI and `run/run_sbi_cryoem.py` for SBI. Before running any cryoEM experiments, the simulated datasets are generated by running `model/hsp90_no_rot.py`.

For the posteriordb models, we run `run/run_pdb.py`.

For the regression models, we run `run/run_inter.py` for the simple regressions, `run/run_interval.py` and `run/run_outlier.py` for comparing different scoring rules, `run/run_crps.py` for the y2-regressions, `run/run_sbi_torch2.py` and `run/run_sbi_torch4` for the baselines of y2-regressions.

