# Diffusion Bandit Optimization

To run one needs to go through the following steps. All the content generated by the files
is also provided in this folder and hence the steps must not be followed in this exact order.
We ran our experiments on an M1 Mac and use MPS as the default device, which can be changed
in the configs. To run the code, after installing requirements, move into the source
directory and then:

(1) generate the dataset:
python -m diffusion_bandit.dataset_generation

(2) train an unconditional score:
python -m diffusion_bandit.train_shape_score_model

(3) run DiffPS:
python -m diffusion_bandit.linear_ts_diffusion

and DiffPS-N:
python -m diffusion_bandit.linear_ts_diffusion oracle.num_generations=30

(4) run the bandit baselines:
python -m diffusion_bandit.linear_ts_baseline