# Code for the figures

In this folder, we present the code we use to compute the complexity metrics considered in Section 4 and create the figures presented in the paper.

The file `requirements.txt` can be used to install (with pip) the dependencies. We tested this code woth Python 3.11.7.

## Computation of the complexities

The script `diffusion_plots/pt_to_json.py`, that takes as inputs a folder containing the results of all experiments, is responsible for the estimation of all complexity metrics. 
Additionally, for our SGLD plots on Gaussian mixture models, the script `diffusion_plots/average.py` contains the computations of means and standard deviations.

Regarding the topological complexities, their estimation can be found in the `analysis` folder. This part of the code is partially inspired by the publicly available code of the study [ADS+24], cited in the main paper.

## Plots

Once these complexities have been estimated, the folder `diffusion_plots` contains all the scripts necessary to reproduce our figures.
Calling `pt_to_json.py` creates a JSON file `all_results.json` that can has to be given as input to the other scripts.

The scripts `gmm.sh` and `workflow.sh` provide examples of the workflow.