This repository contains a Pytorch implementation of our paper titled "Parametric Noise Injection: Trainable Randomness to Improve Deep Neural Network Robustness against Adversarial Attack"
If you find this project useful to you, please cite our work:
@inproceedings{he2019PNI,
title={Parametric Noise Injection: Trainable Randomness to Improve Deep Neural Network Robustness against Adversarial Attack},
author={He, Zhezhi and Adnan Siraj Rakin and Fan, Deliang},
booktitle={Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition},
pages={},
year={2019}
}
Parametric Noise Injection (PNI) is a technique to improve the robustness of deep neural network against the well-known adversarial attack. We want to highlight that PNI can improve both the clean-data (i.e., attack free) accuracy and perturbed-data (i.e., under attack) accuracy.
The key idea is simple and the intuition behind it is straight-forward. For each iteration of network inference, We inject the noise sampled from the Gaussian distributed noise source upon weight (input/activation), in a layer-wise fashion. Such Gaussian noise source is trained with the aid of adversarial training (i.e., min-max optimization). The intuition that optimizer will find a moderate noise level is:
-
If the noise magnitude is too large, it will introduce too much randomness into the network inference path, thus significantly lower the inference accuracy.
-
If the noise magnitude is too small, the regularization functionality of noise injection is not performed. The famous regularizer -- Dropout can be conducted through Gaussian noise injection but with the fixed configuration.
In our paper, only the layer-wise PNI is discussed, but we also test the channel-wise/element-wise counterparts, where channel-wise variant shows the best performance.
- Python 3.6 (Anaconda)
- Pytorch >=0.41
- TensorboardX
For more specific dependency, please refer environment.yml and environment_setup.md
Please modify PYTHON=
, TENSORBOARD=
and data_path=
in the example bash code (train_cifar.sh
and eval_cifar.sh
) before running the code.
HOST=$(hostname)
echo "Current host is: $HOST"
case $HOST in
"alpha")
# python environment path
PYTHON="/home/elliot/anaconda3/envs/pytorch_041/bin/python"
# tensorboard path
TENSORBOARD='/home/elliot/anaconda3/envs/pytorch_041/bin/tensorboard'
;;
esac
data_path=''
bash train_cifar.sh
-
model
: Setmodel=vanilla_resnet20
for baseline adversarial training. Setmodel=noise_resnet20
for adversarial training with PNI technique. For switching the layer/channel/element-wise PNI on weight, please modify the layer definition in noise_Linear and noise_Conv2d. For example, if we want to configure the default layerwise PNI to channelwise:class noise_Linear(nn.Linear): def __init__(self, in_features, out_features, bias=True, pni='layerwise', w_noise=True): class noise_Linear(nn.Linear): def __init__(self, in_features, out_features, bias=True, pni='channelwise', w_noise=True):
-
epoch_delay
: Number of epochs that delaying the adversarial training, where the default setup is 5. You can disable it by setting--epoch_delay 0
in the bash script. -
adv_eval
: through enabling the adversarial evaluation, users can monitor the accuracy of perturbed test data (i.e., input image under attack) evolving with the adversarial training progress. For fast training, users can also choose to disable the evaluation, then only perfrom the evaluation with the model after adversarial traning.
bash eval_cifar.sh
- Change the
pretrained_model=
ineval_cifar.sh
for the target model.
-
Based on our experiments, since the PNI-W (i.e., Parametric Noise Injection on Weight) outperforms other PNI variants on activations and etc., we choose PNI-W as the default setup.
-
Previous works remove the normalization layer from the data-preprocessing. Since we still expect the fast convergence benefit from the normalization of input image, we add a normalization in front of the neural network which perform the identical functionality but with the normalization incoporated within the backward computation graph.
-
During the adversarial training, we take the prevention of label leaking into the consideration. Rather than directly use the groundtruth as the label to perform the adversarial attack, we take the network's output w.r.t the clean data (i.e., attack free) as the label.
Hereby, we choose the ResNet-20 on CIFAR-10 as a simple example. Besides the Layer-wise PNI we introduced in our paper, we also implement the PNI in channel-wise and element-wise fashion.
Clean data | PGD | FGSM | |
---|---|---|---|
vanilla adv. training | 83.84% | 39.14$\pm$0.05% | 46.55% |
PNI-W (layer-wise) | 84.89$\pm$0.11% | 45.94$\pm$0.11% | 54.48$\pm$0.44% |
PNI-W (channel-wise) | 85.17$\pm$0.12% | 48.40$\pm$0.37% | 56.51$\pm$0.75% |
PNI-W (element-wise) | 80.69$\pm$0.16% | 49.07$\pm$0.41% | 55.13$\pm$0.51% |