# DGAD: Diffusion-based Generative Adversarial Detection

## Environment Setup

1. Create and activate conda environment:
```bash
conda env create -f environment.yaml
conda activate dgad
```

## Quick Start

### Training

1. Extract DGAD.zip file
2. A small sample dataset is provided in the `train_datasets` directory, containing the following subdirectories:
   - source_processed: source images
   - object_processed: target objects
   - target_processed: target images
   - mask_processed: mask images

3. Run the training script:
```bash
python train.py
```

### Inference

Use the following script for inference:
```bash
python inference/inference_base_sdinpaint_ipadapter.py
```

### Evaluation Metrics

Use the calculate_metrics script to compute model performance metrics:
```bash
python calculate_metrics.py
```

## Dataset Structure

The training dataset should contain the following four subdirectories:
- source_processed/: source image directory
- object_processed/: target object directory
- target_processed/: target image directory
- mask_processed/: mask image directory

Each image pair should have the same filename, for example:
```
source_processed/000000001.png
object_processed/000000001.png
target_processed/000000001.png
mask_processed/000000001.png
```

## Notes

1. Ensure all dependencies are correctly installed
2. Check dataset paths before training
3. Make sure model weights exist before inference
4. Verify test dataset format before calculating metrics 