`train_EBM_single.py` is a script designed to train an energy-based model (EBM) for a single MNIST image. The desired source image can be selected by adjusting the label parameter. Once the training process concludes, the model checkpoint will be saved within the "./saved_models" directory.

`train_adv_classifier.py` is a script specifically purposed for training a robust victim classifier. After the training phase, the checkpoint for this model is also saved in the "./saved_models" directory.

`sample.py` is utilized to draw samples from the adversarial distribution, given a fully-trained EBM and a victim classifier. Users can manipulate different functions f (fCE, fCW, fJE, fPE) by adjusting their corresponding weights. The default parameters is corresponding to fCW.

Pretrained models associated with these scripts can be downloaded via the following link: https://mega.nz/folder/Z20HnY7T#um1Xu4M02F-qaE9ftjIhVQ

After downloading the pretrained models and placing them into the `./saved_models` directory, you can generate the samples using the following script:

```
bash run.sh
```

The generated samples will be stored in the `./samples` directory. Please note, this demo does not include the sample refinement stage, as this process is quite time-consuming.

Please note, the version of Pytorch-lightning should be 1.9.2.

