# I-PGD-AT: Efficient Adversarial Training via Imitating Iterative PGD Attack

This repository is the official implementation of I-PGD-AT: Efficient Adversarial Training via Imitating Iterative PGD Attack.

# Requirements

python >= 3.7.10

pytorch >= 1.7.1

torchvision >= 0.8.2

numpy >= 1.19.2

# Training & Evaluation

Taking the experiments on CIFAR-10 for examples, run this command for I-PGD2-AT:
```
python train_cifar.py --epochs 30 --lr-max 0.2 --fgsm-alpha 1. --attack ipgd --steps 1 --imitation-steps 2 --fname models/
```

Run this command for I-PGD3-AT:
```
python train_cifar.py --epochs 30 --lr-max 0.2 --fgsm-alpha 1. --attack ipgd --steps 1 --imitation-steps 2 --fname models/
```

Run this command for I-PGD2-AT_{PGD2}:
```
python train_cifar.py --epochs 200 --lr-schedule onedrop --lr-max 0.2 --pgd-alpha 2 --attack ipgd --steps 2 --imitation-steps 2 --fname models/
```

