This repository contains code and data for the ICLR 2021 paper "Perceptual Adversarial Robustness: Defense Against Unseen Threat Models".
The code can be downloaded as this GitHub repository, which includes the scripts for running all experiments in the paper. Alternatively, it can be installed as a pip package, which includes the models, attacks, and other utilities.
-
Install Python 3.
-
Clone the repository:
git clone https://github.com/cassidylaidlaw/perceptual-advex.git cd perceptual-advex
-
Install pip requirements:
pip install -r requirements.txt
-
Install Python 3.
-
Install from PyPI:
pip install perceptual-advex
-
(Optional) Install AutoAttack if you want to use it with the package:
pip install git+git://github.com/fra31/auto-attack#egg=autoattack
-
Import the package as follows:
from perceptual_advex.perceptual_attacks import FastLagrangePerceptualAttack
See getting_started.ipynb or the Colab notebook below for examples of how to use the package.
Download pretrained models from here.
Download perceptual study data from here.
This section explains how to get started with using the code and includes information about how to run all the experiments.
The getting_started.ipynb notebook shows how to load a pretrained model and construct perceptual adversarial examples for it. It is also available on Google Colab via the link below.
The script adv_train.py
can be used to perform Perceptual Adversarial Training (PAT) or to perform regular adversarial training. To train a ResNet-50 with self-bounded PAT on CIFAR-10:
python adv_train.py --batch_size 50 --arch resnet50 --dataset cifar --attack "FastLagrangePerceptualAttack(model, bound=0.5, num_iterations=10)" --only_attack_correct
This will create a directory data/logs
, which will contain TensorBoard logs and checkpoints for each epoch.
To train a ResNet-50 with self-bounded PAT on ImageNet-100:
python adv_train.py --parallel 4 --batch_size 128 --dataset imagenet100 --dataset_path /path/to/ILSVRC2012 --arch resnet50 --attack "FastLagrangePerceptualAttack(model, bound=0.25, num_iterations=10)" --only_attack_correct
This assumes 4 GPUs are available; you can change the number with the --parallel
argument. To train a ResNet-50 with AlexNet-bounded PAT on ImageNet-100, run:
python adv_train.py --parallel 4 --batch_size 128 --dataset imagenet100 --dataset_path /path/to/ILSVRC2012 --arch resnet50 --attack "FastLagrangePerceptualAttack(model, bound=0.25, num_iterations=10, lpips_model='alexnet')" --only_attack_correct
The script generate_examples.py
will generate adversarially attacked images. For instance, to generate adversarial examples with the Perceptual Projected Gradient Descent (PPGD) and Lagrange Perceptual Attack (LPA) attacks on ImageNet, run:
python generate_examples.py --dataset imagenet --arch resnet50 --checkpoint pretrained --batch_size 20 --shuffle --layout horizontal_alternate --dataset_path /path/to/ILSVRC2012 --output examples.png \
"PerceptualPGDAttack(model, bound=0.5, num_iterations=40, lpips_model='alexnet')" \
"LagrangePerceptualAttack(model, bound=0.5, num_iterations=40, lpips_model='alexnet')"
This will create an image called examples.png
with three columns. The first is the unmodified original images from the ImageNet test set. The second and third contain adversarial attacks and magnified difference from the originals for the PPGD and LPA attacks, respectively.
--dataset
can becifar
for CIFAR-10,imagenet100
for ImageNet-100, orimagenet
for full ImageNet.--arch
can beresnet50
(orresnet34
, etc.) oralexnet
.--checkpoint
can bepretrained
to use the pretrainedtorchvision
model. Otherwise, it should be a path to a pretrained model, such as those from the robustness library.--batch_size
indicates how many images to attack.--layout
controls the layout of the resulting image. It can bevertical
,vertical_alternate
, orhorizontal_alternate
.--output
specifies where the resulting image should be stored.- The remainder of the arguments specify attacks using Python expressions. See the
perceptual_advex.attacks
andperceptual_advex.perceptual_attacks
modules for a full list of available attacks and arguments for those attacks.
The script evaluate_trained_model.py
evaluates a model against a set of attacks. The arguments are similar to generate_examples.py
(see above). For instance, to evaluate the torchvision pretrained ResNet-50 against PPGD and LPA, run:
python evaluate_trained_model.py --dataset imagenet --arch resnet50 --checkpoint pretrained --batch_size 50 --dataset_path /path/to/ILSVRC2012 --output evaluation.csv \
"PerceptualPGDAttack(model, bound=0.5, num_iterations=40, lpips_model='alexnet')" \
"LagrangePerceptualAttack(model, bound=0.5, num_iterations=40, lpips_model='alexnet')"
The following command was used to evaluate CIFAR-10 classifiers for Tables 2, 6, 7, 8, and 9 in the paper:
python evaluate_trained_model.py --dataset cifar --checkpoint /path/to/checkpoint.pt --arch resnet50 --batch_size 100 --output evaluation.csv \
"NoAttack()" \
"AutoLinfAttack(model, 'cifar', bound=8/255)" \
"AutoL2Attack(model, 'cifar', bound=1)" \
"StAdvAttack(model, num_iterations=100)" \
"ReColorAdvAttack(model, num_iterations=100)" \
"PerceptualPGDAttack(model, num_iterations=40, bound=0.5, lpips_model='alexnet_cifar', projection='newtons')" \
"LagrangePerceptualAttack(model, num_iterations=40, bound=0.5, lpips_model='alexnet_cifar', projection='newtons')"
The following command was used to evaluate ImageNet-100 classifiers for Table 3 in the paper, which shows the robustness of various models against several attacks at the medium perceptibility bound:
python evaluate_trained_model.py --dataset imagenet100 --dataset_path /path/to/ILSVRC2012 --checkpoint /path/to/checkpoint.pt --arch resnet50 --batch_size 50 --output evaluation.csv \
"NoAttack()" \
"AutoLinfAttack(model, 'imagenet100', bound=4/255)" \
"AutoL2Attack(model, 'imagenet100', bound=1200/255)" \
"JPEGLinfAttack(model, 'imagenet100', bound=0.125, num_iterations=200)" \
"StAdvAttack(model, bound=0.05, num_iterations=200)" \
"ReColorAdvAttack(model, bound=0.06, num_iterations=200)" \
"PerceptualPGDAttack(model, bound=0.5, lpips_model='alexnet', num_iterations=40)" \
"LagrangePerceptualAttack(model, bound=0.5, lpips_model='alexnet', num_iterations=40)"
If you find this repository useful for your research, please cite our paper as follows:
@inproceedings{laidlaw2021perceptual,
title={Perceptual Adversarial Robustness: Defense Against Unseen Threat Models},
author={Laidlaw, Cassidy and Singla, Sahil and Feizi, Soheil},
booktitle={ICLR},
year={2021}
}
For questions about the paper or code, please contact claidlaw@umd.edu.