Skip to content

Official implementation of StyleAdv: A Usable Privacy Framework Against Facial Recognition with Adversarial Image Editing

License

Notifications You must be signed in to change notification settings

minha12/StyleAdv

Repository files navigation

StyleAdv Official implementation

Open In Colab

If you find this paper useful in your research, please cite our paper:

@inproceedings{le2024styleadv,
  title={StyleAdv: A Usable Privacy Framework Against Facial Recognition with Adversarial Image Editing},
  author={Le, Minh Ha and Carlsson, Niklas},
  booktitle={Proceedings on Privacy Enhancing Technologies (PoPETs)},
  year={2024}
}

StyleAdv: A Usable Privacy Framework Against Facial Recognition with Adversarial Image Editing

Minh-Ha Le and Niklas Carlsson

Abstract: In this era of ubiquitous surveillance and online presence, protecting facial privacy has become a critical concern for individuals and society as a whole. Adversarial attacks have emerged as a promising solution to this problem, but current methods are limited in quality or are impractical for sensitive domains such as facial editing.

This paper presents a novel adversarial image editing framework called StyleAdv, which leverages StyleGAN's latent spaces to generate powerful adversarial images, providing an effective tool against facial recognition systems. StyleAdv achieves high success rates by employing meaningful facial editing with StyleGAN while maintaining image quality, addressing a challenge faced by existing methods. To do so, the comprehensive framework integrates semantic editing, adversarial attacks, and face recognition systems, providing a cohesive and robust tool for privacy protection. We also introduce the ``residual attack" strategy, using residual information to enhance attack success rates. Our evaluation offers insights into effective editing, discussing tradeoffs in latent spaces, optimal edits for our optimizer, and the impact of utilizing residual information.

Our approach is transferable to state-of-the-art facial recognition systems, making it a versatile tool for privacy protection. In addition, we provide a user-friendly interface with multiple editing options to help users create effective adversarial images. Extensive experiments are used to provide insights and demonstrate that StyleAdv outperforms state-of-the-art methods in terms of both attack success rate and image quality. By providing a versatile tool for generating high-quality adversarial samples, StyleAdv can be used both to enhance individual users' privacy and to stimulate advances in adversarial attack and defense research.

Description

StyleAdv's framework

This repository hosts the "StyleAdv" project, directly linked to our research paper on enhancing privacy against facial recognition systems. Our work introduces two key attack strategies: semantic adversarial editing and residual attack. These strategies are designed to effectively disrupt facial recognition technology by subtle perturbations.

For practical demonstration, we provide a user-friendly demo in two formats: a Google Colab notebook and a local application using Gradio. Both platforms offer an interactive experience, allowing users to experiment with our adversarial editing techniques. The repository is showcasing the effectiveness of StyleAdv in countering facial recognition systems while being accessible to a wide audience.

Basic Requirements

  • Ubuntu 20.04
  • Pytorch 1.7.1
  • Cuda Toolkit 11.2.2

Hardware recommendations

This framework has been successfully tested on:

  • CPU: Intel core i7 10th generation
  • GPU: Nvidia RTX 3090 (this is not a requirement, any GPU with at least 12GB of VRAM should be enough)
  • RAM: 32 GB DDR4

Software Requirements

  • Anaconda/Mini conda
  • Latest Nvidia driver

Estimated Time and Storage Consumption

For the evaluation of adversarial attacks using StyleGAN2, consider these time and storage aspects:

  1. Time for Evaluation:

    • Generating each adversarial sample typically takes about 10-12 seconds.
    • The total time will depend on how many samples you're creating and other hyper parameters.
  2. Storage Requirements:

    • Make sure to have at least 5GB of free disk space for the adversarial samples and any temporary data.
    • The exact space needed may vary based on the number and resolution of the images you generate.

Environment & setups

To facilitate an easy and accessible demonstration of our StyleAdv framework, we offer three options. You can choose the one that best suits your needs and technical comfort:

Option 1: Google Colab (Recommended for Ease of Use)

Google Colab provides a user-friendly way to experience StyleAdv without the need for local software installations. Follow these steps to get started:

  1. Access the Notebook: Click on the provided link to open the Jupyter notebook in Google Colab Open In Colab
  2. Run the Notebook: Follow the instructions within the notebook to execute the code cells. Google Colab provides an interactive environment, so you can easily run and modify the code.
  3. Explore Options: Within the Colab notebook, you can change the options. This intuitive interface allows you to interact with StyleAdv, test different inputs, and see the results in real-time.
  4. No Installation Needed: Since everything runs in the cloud, you don't need to install any software on your device.

Option 2: Run Gradio app locally with conda environment

  1. We recommend to set up the virtual environment by Mini Conda:
git clone https://github.com/minha12/StyleAdv.git
cd StyleAdv
conda env create -n styleadv --file ./requirements.yaml
wget https://github.com/ninja-build/ninja/releases/download/v1.8.2/ninja-linux.zip
sudo unzip ninja-linux.zip -d /usr/local/bin/
sudo update-alternatives --install /usr/bin/ninja ninja /usr/local/bin/ninja 1 --force
python utils/download_models.py

Special requirements for Nvidia RTX 30 series

  • Install Cuda Toolkit 11.2.2
  • Pytorch 1.7.1:
pip install torch==1.7.1+cu110 torchvision==0.8.2+cu110 torchaudio===0.7.2 -f https://download.pytorch.org/whl/torch_stable.html
  1. Run the Gradio App: Navigate to the directory containing the Gradio app script and run demo.py using Python. This will start a local server, and the Gradio interface will be accessible through your web browser.
  2. Local Interaction: Experiment with the Gradio app locally, providing inputs and observing the outputs directly on your machine.

Option 3: Run Gradio app locally using Docker

Prerequisites:

  • Docker installed on your machine.
  • NVIDIA GPU with the NVIDIA Container Toolkit (for GPU support).

Step 1: Clone the Repository

  • Clone the repository containing the Gradio app and Dockerfile to your local machine.

Step 2: Build the Docker Image

  • Open a terminal or command prompt.
  • Navigate to the directory containing the Dockerfile.
  • Run the following command to build the Docker image:
docker build -t styleadv_docker .

This command builds a Docker image named styleadv_docker from the Dockerfile in the current directory.

Step 3: Run the Docker Container

  • Once the image is built, you can run the container with the following command:
docker run -d --gpus all -p 7860:7860 styleadv_docker

This command runs the container in detached mode (-d), enables GPU access (--gpus all), and maps port 7860 of the container to port 7860 on your host machine.

Step 4: Access the Gradio App

  • Open a web browser on your local machine.
  • Navigate to http://localhost:7860 to access the Gradio interface.

Step 5: Stop the Docker Container

  • If you need to stop the running Docker container, first find the container ID using:
    docker ps
    
  • Then stop the container using the following command:
    docker stop [container_id]
    
    Replace [container_id] with the actual ID of your container.

Important Note: Parameter Choices for Reproducing Results

The choice of parameters is crucial for accurately reproducing the results of the attacks. Pay special attention to the following parameters:

  1. ID Threshold (id_threshold):

    • This is the threshold of the victim model.
    • A lower id_threshold makes it easier to attack but may also reduce the attack's effectiveness.
  2. ID Lambda (id_lambda):

    • For "Guided Adversarial Editing", id_lambda should be in the range [1, 10], with a default of 2.
    • For "Residual Attack", it should be in the range [0.01, 0.2], with a default of 0.1.
  3. Learning Rate (lr):

    • The default value is 0.05 for "Guided Adversarial Editing".
    • For "Residual Attack", the default learning rate is 0.005.
    • Note that both attacks are highly sensitive to changes in the learning rate.

Adjusting these parameters can significantly impact the effectiveness and efficiency of the attacks. It's recommended to experiment with different values within the suggested ranges to find the optimal settings for your specific scenario.

Evaluation Scripts

We provide information on how to run the StyleAdv and evaluation scripts.

Running StyleAdv in batch

To run StyleAdv in batch we provide scripts with the following command:

python scripts/run_styleadv.py --input_path ./test_imgs/ --output_path ./output --id_loss_model irse50 --id_eval_model mobile_face --id_threshold 0.5

This mode allows running batch jobs where the input and output are folders. See more arguments by running:

python scripts/run_styleadv.py --help
app# python scripts/run_styleadv.py --help
usage: run_styleadv.py [-h] --input_path INPUT_PATH [--output_path OUTPUT_PATH]
                       [--target_image_path TARGET_IMAGE_PATH]
                       [--app_mode {Residual Attack,Guided Adversarial Editing,No Guidance Adversarial Editing}]
                       [--id_loss_model ID_LOSS_MODEL [ID_LOSS_MODEL ...]]
                       [--id_eval_model ID_EVAL_MODEL [ID_EVAL_MODEL ...]]
                       [--editing_direction EDITING_DIRECTION]
                       [--edit_degree EDIT_DEGREE] [--lr LR]
                       [--id_threshold ID_THRESHOLD] [--l2_lambda L2_LAMBDA]
                       [--id_lambda ID_LAMBDA] [--batch_size BATCH_SIZE]
                       [--ckpt_input CKPT_INPUT] [--stylegan_size STYLEGAN_SIZE]
                       [--lr_rampup LR_RAMPUP] [--mode {edit,other_modes}]
                       [--truncation TRUNCATION] [--seed_value SEED_VALUE]
                       [--return_latent] [--demo] [--align_image]

Run the styleadv_run function with options

optional arguments:
  -h, --help            show this help message and exit
  --input_path INPUT_PATH
                        Path to the input image
  --output_path OUTPUT_PATH
                        Path to the directory of output image
  --target_image_path TARGET_IMAGE_PATH
                        Path to the target image
  --app_mode {Residual Attack,Guided Adversarial Editing,No Guidance Adversarial Editing}
  --id_loss_model ID_LOSS_MODEL [ID_LOSS_MODEL ...]
                        ID loss model
  --id_eval_model ID_EVAL_MODEL [ID_EVAL_MODEL ...]
                        ID evaluation model
  --editing_direction EDITING_DIRECTION
                        Editing direction for guided editing
  --edit_degree EDIT_DEGREE
                        Degree of editing
  --lr LR               Learning rate
  --id_threshold ID_THRESHOLD
                        Threshold for ID loss
  --l2_lambda L2_LAMBDA
                        L2 lambda
  --id_lambda ID_LAMBDA
                        ID lambda
  --batch_size BATCH_SIZE
                        Size of each batch
  --ckpt_input CKPT_INPUT
                        Path to the StyleGAN checkpoint
  --stylegan_size STYLEGAN_SIZE
                        Resolution of StyleGAN
  --lr_rampup LR_RAMPUP

Running the Evaluation Script

After running StyleAdv, you can evaluate the successful rate by using the following command:

python scripts/eval.py --input_path ./test_imgs/ --output_path ./output/
/app# python scripts/eval.py --help
usage: eval.py [-h] --input_path INPUT_PATH --output_path OUTPUT_PATH
               [--batch_size BATCH_SIZE] [--num_workers NUM_WORKERS]

Calculate pairwise distances between images.

optional arguments:
  -h, --help            show this help message and exit
  --input_path INPUT_PATH
                        Path to the input folder
  --output_path OUTPUT_PATH
                        Path to the output folder
  --batch_size BATCH_SIZE
                        Batch size for processing images
  --num_workers NUM_WORKERS
                        Number of workers for DataLoader

Please replace ./test_imgs/ and ./output with your actual input and output paths respectively. The --id_loss_model, --id_eval_model flag is used to specify the attacker's model, victim model respectively, and --id_threshold is used to set the threshold for the evaluation.

Security/Privacy Issues and Ethical Concerns

StyleAdv is designed to protect privacy against facial recognition using image editing. While our intended use case is to help regular people avoid being tracked on social media, we acknowledge that the tool also can be misused, including by criminals trying to hide from law enforcements, for example. When realizing our tool, we ask users to use the tools responsibly. Regardless of use case, we believe that it is important to give everyone fair access to new technologies such as these and help encourage further technical developments. By giving easy-to-use access to our tool, we aim to make sure it is accessible to a broad audience, not only those proficient in the underlying techniques. We believe that everybody’s privacy must be respected, and that everybody should be in control of his or her own images.

License

This project is licensed under the MIT License - see the LICENSE file for details.

About

Official implementation of StyleAdv: A Usable Privacy Framework Against Facial Recognition with Adversarial Image Editing

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published