# Deepfake Generation and Disruption Benchmark

This repository contains a comprehensive benchmark for evaluating various deepfake generation models and disruption methods. The codebase provides unified interfaces for multiple deepfake generators, implements state-of-the-art disruption techniques, and offers extensive evaluation metrics.

## 📁 Repository Structure


9676/
├── deepfake_generators/     # Deepfake generation models
├── wrappers/                # Unified wrappers for each model
├── disrupting_methods/      # Disruption technique implementations
├── evaluation/              # Evaluation scripts and metrics
├── batch_*_attack.py        # Batch attack execution scripts
├── configs/                 # Configuration files
└── utils/                   # Utility functions


## 🎭 Deepfake Generators

The `deepfake_generators/` directory contains deepfake generation models.
Users must clone the original repositories and place them in the corresponding directories.
Specifically, please download and set up each generator from its official repository.

- **AGGAN**
- **BlendFace**
- **DiffFace**
- **DiffSwap**
- **DiffusionCLIP**
- **SimSwap**
- **StarGAN**
- **DiffAE**
- **Pixel2Style2Pixel**
- **StyleCLIP**

### Setup Pretrained Weights

To use these models, download the pretrained weights and place them in the corresponding checkpoint directory within each model folder:

```
deepfake_generators/
├── BlendFace/
│   └── checkpoints/        # Place BlendFace pretrained weights here
├── SimSwap/
│   └── checkpoints/        # Place SimSwap pretrained weights here
└── ...
```

## 🔧 Model Wrappers

The `wrappers/` directory provides unified interfaces for all deepfake generators, enabling consistent usage across different models. Each wrapper standardizes the input/output format and inference pipeline, making it easy to swap between different generation methods.

## 🛡️ Disruption Methods

The `disrupting_methods/` directory implements various deepfake disruption techniques:

- **Anti-Forgery** (`anti_forgery/`)
- **DF-RAP** (`df_rap/`)
- **Disrupting Deepfake** (`disrupting_deepfake/`)
- **FGSM** (`FGSM/`)
- **LEAT** (`LEAT/`)
- **NullSwap** (`nullswap/`)
- **PGD** (`PGD/`)

Each method is designed to protect source images from being used in deepfake generation.

## 🚀 Running Experiments

### Batch Attack Scripts

The repository includes batch scripts to apply disruption methods to all deepfake generators:

```bash
# Run Anti-Forgery attack
python batch_anti_attack.py

# Run DF-RAP attack
python batch_df_rap_attack.py

# Run Disrupting Deepfake attack
python batch_disrupting_deepfake_attack.py

# Run FGSM attack
python batch_fgsm_attack.py

# Run LEAT attack
python batch_latent_attack.py

# Run LEAT Ensemble attack
python batch_leat_ensemble_attack.py

# Run NullSwap attack
python batch_null_swap.py

# Run PGD attack
python batch_pgd_attack.py
```

Each script will:
1. Load the specified disruption method
2. Apply it to images using all available deepfake generators
3. Save the generated results to the output directory

## 📊 Evaluation

The `evaluation/` directory contains scripts for comprehensive evaluation of the disruption methods:

### Traditional Metrics

Run `evaluate_summary.py` to compute standard image quality and protection metrics:

```bash
python evaluation/evaluate_summary.py
```

### Proposed Metrics

#### CIDR (Counterfactual Identity Disruption Rate)

```bash
python evaluation/evaluation_cidr.py
```

#### ROB (Robustness)

```bash
python evaluation/evaluate_rob.py
```

#### TE (Transferability Effectiveness)

```bash
python evaluation/evaluate_te.py
```