PIAT: Parameter Interpolation based Adversarial Training for Image Classification

Prerequisites

Python (3.7)
Pytorch (1.6)
Torchvision
CUDA
Numpy
AutoAttack

Training and Testing
Train ResNet-18 on CIFAR10:
  $ CUDA_VISIBLE_DEVICES={your GPU number} python PIAT_CIFAR10_NMSE.py

Train WRN-32-10 on CIFAR10:
  $ CUDA_VISIBLE_DEVICES={your GPU number} python PIAT_CIFAR10_NMSE.py --arch 'WRN'

The evaluation will test the model using the attack, including NAT, PGD20, PGD100, CW, AutoAttack