# Offpolicy Training of Discrete Diffusion Samplers


## Setup

We use `uv` to manage the project. Install it following the [instructions](https://docs.astral.sh/uv/getting-started/installation/).

Once installed, run the following command in the root of the project to install the dependencies:
```bash
uv sync
```

This will create `.venv` in the root of the project.

## Run the experiments

Activate the environment with `source .venv/bin/activate`.
We recommend to set the environment variable `TORCH_COMPILE=1` to enable compilation.

To reproduce the results in table 1 & 2, run the following command:
```bash
python run.py seed=<seed> target=<target> algorithm=mcmc algorithm/mcmc=hamming_ball algorithm.mcmc.L=5
python run.py seed=<seed> target=<target> algorithm=mdns
python run.py seed=<seed> target=<target> algorithm=logvar
python run.py seed=<seed> target=<target> algorithm=logvar_iwbuf
python run.py seed=<seed> target=<target> algorithm=logvar_iwbuf_mcmc algorithm/mcmc=hamming_ball algorithm.mcmc.L=5
python run.py seed=<seed> target=<target> algorithm=tb
python run.py seed=<seed> target=<target> algorithm=tb_iwbuf
python run.py seed=<seed> target=<target> algorithm=tb_iwbuf_mcmc algorithm/mcmc=hamming_ball algorithm.mcmc.L=5
```
for each seed {0, 1, 2, 3, 4} and target {40gmm_2d, 40gmm_4d, manywell_4d, manywell_10d, ising_L16_critical, ising_L16_low, ising_L16_lower, potts_L16_critical, potts_L16_low}.

