## Dependencies

we use Python 3.9 and the following required packages:
```bash
pip install numpy scipy statsmodels tqdm seaborn
pip install torch torchvision torchaudio
pip install tensorboardX transformers
```

## Repository Structure

```
./
├── code/          # Main source code and training/certification scripts
├── scripts/       # Shell scripts for running experiments
├── checkpoints/   # Trained model checkpoints
├── data/          # Optimal variance labels and datasets
├── reproduce/          # All data we used in the paper and the code to generate figures in the paper
└── models/        # Pre-trained diffusion and ViT models

```
You can download `checkpoints`, `data`, `reproduce` and `models` through [link](https://mega.nz/folder/OBsXjIBL#fGOp6IL7pBIulyLwMZX8Mw).


## Reproduce Paper Results

The `reproduce/` folder contains all the data used in the paper and the code to generate the figures. To reproduce the results:

1. **Navigate to the reproduce folder**:
   ```bash
   cd reproduce/
   ```

2. **Run the figure generation scripts**: The folder contains the exact data and code used to create all figures in the paper.

3. **Generate paper figures**: Execute the provided scripts to recreate the plots and tables from the paper using the preprocessed results.


## Scripts

### Training and Fine-tuning
To train the sigma estimator and fine-tune the ViT model:
```bash
bash scripts/train_and_ft.sh
```
This script performs the complete training pipeline including:
- Training the sigma estimator with CIFAR-10 ResNet-110
- Generating predictions on train/test sets
- Fine-tuning the ViT model using predicted sigma labels

### Certification
To certify the classifier with adaptive smoothing:
```bash
bash scripts/certify_classifier.sh
```
Edit the variables in the script:
- Set `vit_path` to your fine-tuned ViT model path
- Set `certify_file` to your desired output file path
- Adjust `sigma` value (0.25, 0.5, or 1.0)

To certify the sigma estimator:
```bash
bash scripts/certify_sigma_est.sh
```

### Visualization
Generate final radius plots comparing different certification approaches:
```bash
python scripts/final_radius.py <dataset> <sigma_certify_file> <class_certify_file> <sigma_list> <output_figure_path>
```
Example:
```bash
python scripts/final_radius.py cifar10 certify/sigma_est.tsv certify/class_cert.npy "0.25 0.5 1.0" figures/radius_plot.pdf
```


