You can use the following command to create and activate your Python environment:
conda env create -f environment.yml
conda activate gafar
We use EG3D as a pretrained face generator network based on generative neural radiance fields (GNeRF). Therefore, you need to clone its git repository and download available pretrained model:
$ git clone https://github.com/NVlabs/eg3d.git
We use ffhqrebalanced512-128.pkl
checkpoint in our experiments.
To train the face reconstruction model, you can use train.py
. For example, for blackbox attack against ElasticFace
using ArcFace
in loss function, you can use the following commands:
python train.py --path_eg3d_repo <path_eg3d_repo> --path_eg3d_checkpoint <path_eg3d_checkpoint> \
--FR_system ElasticFace --FR_loss ArcFace --path_ffhq_dataset <path_ffhq_dataset> \
Checkpoints of trained models of the mapping network for whitebox and blackbox attacks are available in the project page.
For evaluation script and also access to the dataset of presentation attack using the reconstructed face images, please check the project page.
@article{tpami2023ti3d,
author = {Hatef Otroshi Shahreza and S{\'e}bastien Marcel},
title = {Comprehensive Vulnerability Evaluation of Face Recognition Systems to Template Inversion Attacks Via 3D Face Reconstruction},
journal = {IEEE Transactions on Pattern Analysis and Machine Intelligence},
year = {2023},
volume = {45},
number = {12},
pages = {14248-14265},
doi = {10.1109/TPAMI.2023.3312123}
}
@inproceedings{iccv2023ti3d,
author = {Hatef Otroshi Shahreza and S{\'e}bastien Marcel},
title = {Template Inversion Attack against Face Recognition Systems using 3D Face Reconstruction},
booktitle = {Proceedings of the IEEE/CVF International Conference on Computer Vision (ICCV)},
pages = {19662--19672},
month = {October},
year = {2023}
}