Skip to content
Code for the paper: Detecting Photoshopped Faces by Scripting Photoshop
Python Shell
Branch: master
Clone or download
Latest commit 5a2bbe0 Jan 19, 2020
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
data dataset release Jan 19, 2020
examples push test code Jul 3, 2019
networks model update Sep 30, 2019
out model update Sep 30, 2019
utils add __init__.py Jul 17, 2019
weights push test code Jul 3, 2019
LICENSE push test code Jul 3, 2019
README.md Update README.md Jan 19, 2020
eval.py dataset release Jan 19, 2020
global_classifier.py model update Sep 30, 2019
local_detector.py model update Sep 30, 2019
requirements.txt BLD: Add torchvision in requirement.txt Jul 19, 2019

README.md

Detecting Photoshopped Faces by Scripting Photoshop
[Project Page] [Paper]

Sheng-Yu Wang1, Oliver Wang2, Andrew Owens1, Richard Zhang2, Alexei A. Efros1.
UC Berkeley1, Adobe Research2.
In ICCV, 2019.

9/30/2019 Update The code and model weights have been updated to correspond to the v2 of our paper. Note that the global classifer architecture is changed from resnet-50 to drn-c-26.

1/19/2019 Update Dataset for evaluation is released! The link is here.

(0) Disclaimer

Welcome! Computer vision algorithms often work well on some images, but fail on others. Ours is like this too. We believe our work is a significant step forward in detecting and undoing facial warping by image editing tools. However, there are still many hard cases, and this is by no means a solved problem.

This is partly because our algorithm is trained on faces warped by the Face-aware Liquify tool in Photoshop, and will thus work well for these types of images, but not necessarily for others. We call this the "dataset bias" problem. Please see the paper for more details on this issue.

While we trained our models with various data augmentation to be more robust to downstream operations such as resizing, jpeg compression and saturation/brightness changes, there are many other retouches (e.g. airbrushing) that can alter the low-level statistics of the images to make the detection a really hard one.

Please enjoy our results and have fun trying out our models!

(1) Setup

Install packages

  • Install PyTorch (pytorch.org)
  • pip install -r requirements.txt

Download model weights

  • Run bash weights/download_weights.sh

(2) Run our models

Global classifer

python global_classifier.py --input_path examples/modified.jpg --model_path weights/global.pth

Local Detector

python local_detector.py --input_path examples/modified.jpg --model_path weights/local.pth --dest_folder out/

Note: Our models are trained on faces cropped by the dlib CNN face detector. Although in both scripts we included the --no_crop option to run the models without face crops, it is used for images with already cropped faces.

(3) Dataset

A validation set consisting of 500 original and 500 modified images each from Flickr and OpenImage can be downloaded here. Due to licensing issues, the released validation set is different from the set we evaluate in the paper, and the training set will not be released.

In the zip file, original faces are in the original folder, and modified faces are in the modified folder. For reference, the reference folder contains the same faces in the modified folder, but those are before modification (original).

To evaluate the dataset, run:

# Download the dataset
cd data
bash download_valset.sh
cd ..
# Run evaluation script. Model weights need to be downloaded.
python eval.py --dataroot data --global_pth weights/global.pth --local_pth weights/local.pth --gpu_id 0

The following are the models' performances on the released set:

Accuracy AP PSNR Increase
93.9% 98.9% +2.66

(A) Acknowledgments

This repository borrows partially from the pytorch-CycleGAN-and-pix2pix, drn, and the PyTorch torchvision models repositories.

(B) Citation, Contact

If you find this useful for your research, please consider citing this bibtex. Please contact Sheng-Yu Wang <sheng-yu_wang at berkeley dot edu> with any comments or feedback.

You can’t perform that action at this time.