# High Performance Differentially Private Fine-Tuning using Dataset Distillation 


There are two steps for running SPS:

## Step 1: Measuring DS stats:
Note that `b0` controls the privacy budget. `b0=0.637` is calibrated for `eps=8` for `M=1` model.

```
python compute_ds_stats.py \
--model_save_path ./trained_models/wrn22_8_silu/model_0.pt \
--distilled_save_path ./example_output_folder/ \
--dataset_name cifar10 \
--source_n_per_class 1000 \
--activation silu \
--model_name wrn22-8 \
--target_resolution 32 \
--b0 0.637 \
--sigmoid_scale 1.0 \
--clip_power 8.0 \
--selected_classes 0,1,2,3,4,5,6,7,8,9 \
--n_features_class 512 \
--ll_grad_model_type wrn22-8 \
--stage 0 \
--bwd_sigmoid_scale 16.0 \
--clip_ratio 8 \
--class_include_indices 16,17,18\
```


## Step 2: Synthesizing images.
This generates `n_per_class` images for class it for `target_class`. This needs to be run for each class. This can be done in parallel.

```
python distill_dataset_load.py \
--forward_stages 0 \
--bwd_stages 0 \
--steps_per_batch 1000 \
--n_per_class 1000 \
--batch_size 200 \
--distilled_save_path  ./example_output_folder/  \
--dataset_name cifar10 \
--data_folder ~/Documents/train_imagenet/data/imagenet/ \
--ipc_offset 0 \
--ema_reset 10 \
--target_class 0 \
--target_resolution 32 \
--first_layer_scale 1.0 \
--class_mean_coef 30.0 \
--temperature 1.0 \
--dbn_coef 0.0 \
--selected_classes 0,1,2,3,4,5,6,7,8,9 \
--randomize_mode per_iter
```


## Step 3: Evaluating on another model
This evaluates the models on a pretrained WideResNet 34-10.

```
python3 train_model_from_distilled_fine_tune_gsam.py \
--init_model_save_path ./trained_models/wrn34_10_relu/model_0.pt \
--n_epochs 30 \
--distilled_dir  ./example_output_folder/ \
--dataset_name cifar10 \
--lr 1e-5 \
--activation relu \
--model_name wrn34-10 \
--target_resolution 32 \
--dataset_ipc 5000 \
--dataset_min_ipc 00 \
--result_save_name result.txt \
--load_stage 0

```

There should be pretrained checkpoints for one WRN22-8.
