This is the official repo for the ECCV paper: "On the Robustness of Quality Measures for GANs", which was accepted to ECCV 2022.
Preprint available here.
If you find our work useful, please cite it appropriately as:
@inproceedings{alfarra2022robustness,
title={On the robustness of quality measures for gans},
author={Alfarra, Motasem and P{\'e}rez, Juan C and Fr{\"u}hst{\"u}ck, Anna and Torr, Philip HS and Wonka, Peter and Ghanem, Bernard},
booktitle={European Conference on Computer Vision},
pages={18--33},
year={2022},
organization={Springer}
}
To reproduce the experiments of our paper, first you need to install the environment by running the following line:
conda env create -f env.yml
Then, activate the environment by running
conda activate attack_gan_metrics
To run pixel attacks on the Inception Score (IS), run
python main_is.py
However, you will need to pass the arguments for the experiment you want to run. To run the optimization that generates good-looking images with bad scores, you need to set the following arguments:
--dataset
: Eithercifar10
orimagenet
--dataset-path
: the path to the directory where the dataset is located--dataset-split
: eithertrain
orval
--eps
: The allowed perturbation budget per image
On the other hand, to create a random dataset (images with noise) but good scores, you would need to set the following arguments:
First, keep --eps
as None
--num-instances
: Number of images in that dataset--resolution
: The resolution of the noise images
To run pixel attacks on Fréchet Inception Distance (FID), run
python main_fid.py
Please follow the same setup as before, but include the following:
--real-dataset-path
path to the real dataset the FID will be computed against
To compute the Robust version of FID, noted as R-FID, run the following line
python main_fid.py
with passing the following arguments:
--real-dataset-path
path to the real dataset the FID will be computed against--evaluate-path
path to the dataset that needs to be evaluated with R-FID--robust-inception-path
path to the robustly trained inception model. We provide two robustly trained inception models on ImageNet.
Pending
To access the adversarially-trained Inception models, please download them from:
this link,
where the zip file contains three models: (1) ffhq.pkl
is an FFHQ pretrained GAN that was used in our experiments, (2)
kappa_64.pth.tar
and (3) kappa_128.pth.tar
are adversarially-trained InceptionV3 models that are trained with $\ell_\infty$
PGD adversarial training.