# Code for $\mathrm{SOSMC}$
Ths repositiory contains code related to the methodology proposed in the paper "Efficient Stochastic Optimisation via Sequential Monte Carlo", provided for anonymous peer review.

Representative examples for the reward tuning of Langevin processes and EBMs (in the 2D setting) are provided, whilst the full code will be released upon publication.

## Getting Started
Simply run the following in the relevant directory to get started!
```
python -m venv <your_venv_name>
source <your_venv_name>/bin/activate
pip install -r requirements.txt
```

### Example - Reward Tuning of Langevin Processes
For a representative example of $\mathrm{SOSMC}$ applied to reward tuning of Langevin processes, we provide the `Jupyter` notebook, found at: `langevin_processes.ipynb`.

This notebook is self-documenting and can be run quickly on a CPU of a standard modern laptop.

### Example - $S^{2}$
For a representative example of $\mathrm{SOSMC}$ applied to reward tuning of EBMs, we provide the `Jupyter` notebook, found at: `ebm_2d.ipynb`, as well as a pre-trained model checkpoint, within the `ebm_experiments` folder.

This notebook is again self-documenting, however should be run on a `cuda` enable device, such as a `T4` GPU, easily accessible for free via Google Colab.