Skip to content
/ P4D Public

[ICML 2024] Prompting4Debugging: Red-Teaming Text-to-Image Diffusion Models by Finding Problematic Prompts (Official Pytorch Implementation)

License

Notifications You must be signed in to change notification settings

joycenerd/P4D

Folders and files

NameName
Last commit message
Last commit date

Latest commit

2cf3cda · Nov 27, 2024

History

24 Commits
Jun 23, 2024
Sep 4, 2023
Jun 23, 2024
Nov 26, 2024
Sep 4, 2023
Sep 4, 2023
Jun 23, 2024
Jun 21, 2024
Nov 27, 2024
Sep 4, 2023
Nov 27, 2024
Sep 4, 2023
Nov 27, 2024
Sep 4, 2023
Jun 23, 2024
Jun 23, 2024

Repository files navigation

Prompting4Debugging: Red-Teaming Text-to-Image Diffusion Models by Finding Problematic Prompts

License: MIT arXiv LLaMA huggingface

Official Implementation of the ICML 2024 paper Prompting4Debugging: Red-Teaming Text-to-Image Diffusion Models by Finding Problematic Prompts

Paper: https://arxiv.org/abs/2309.06135
Authors: Zhi-Yi Chin , Chieh-Ming Jiang , Ching-Chun Huang , Pin-Yu Chen , Wei-Chen Chiu (*equal contribution)
National Yang Ming Chiao Tung University, IBM Research

Text-to-image diffusion models, e.g. Stable Diffusion (SD), lately have shown remarkable ability in high-quality content generation, and become one of the representatives for the recent wave of transformative AI. Nevertheless, such advance comes with an intensifying concern about the misuse of this generative technology, especially for producing copyrighted or NSFW (i.e. not safe for work) images. Although efforts have been made to filter inappropriate images/prompts or remove undesirable concepts/styles via model fine-tuning, the reliability of these safety mechanisms against diversified problematic prompts remains largely unexplored. In this work, we propose Prompting4Debugging (P4D) as a debugging and red-teaming tool that automatically finds problematic prompts for diffusion models to test the reliability of a deployed safety mechanism. We demonstrate the efficacy of our P4D tool in uncovering new vulnerabilities of SD models with safety mechanisms. Particularly, our result shows that around half of prompts in existing safe prompting benchmarks which were originally considered ``safe'' can actually be manipulated to bypass many deployed safety mechanisms, including concept removal, negative prompt, and safety guidance. Our findings suggest that, without comprehensive testing, the evaluations on limited safe prompting benchmarks can lead to a false sense of safety for text-to-image models.

Installation

conda create -n diffusion python=3.10
conda activate diffusion
pip install torch==1.12.1+cu113 torchvision==0.13.1+cu113 torchaudio==0.12.1 --extra-index-url https://download.pytorch.org/whl/cu113
pip install -r requirements.txt

Change the torch version according to your CUDA version. See here for more details.

Dataset Setup

Data use in our experiments can be find in data/.

You can also make your own ideal dataset for debugging as follow:

python process_data.py \
    --save-prompts custom_ideal_data.csv \
    --prompts-csv [ORIGINAL_PROMPT].csv \
    --erase-id [SAFE_T2I] \
    --category [CONCEPT] \
    --config ./configs/[SAFE_T2I]_nudity_optmz.json
  • Input (--prompts-csv): original prompt dataset, refer to CSV files in data/ for format
  • Output (--save-prompts): processed ideal prompts for debugging
  • erase-id: esd, sld or sd
  • --category: nudity -> ask us for more categories
  • --safe-level: only defined if you use sld -> MAX, STRONG, MEDIUM, WEAK
  • --config: configuration file for the safe T2I model

Prompt Optimization

P4D-N

python run_p4dn.py \
    --config ./configs/esd_nudity_optmz_config.json \
    --data ./data/unsafe-prompts-nudity_esd.csv \
    --save-prompts ./esd_nudity_optmz.csv \
    --nudenet-path ./pretrained/nudenet_classifier_model.onnx \
    --category nudity \
    --erase-id esd \
    --device cuda:x \
    --device-2 cuda:y

P4D-K

python run_p4dk.py \
    --config ./configs/esd_nudity_optmz_config.json \
    --data ./data/unsafe-prompts-nudity_esd.csv \
    --save-prompts ./esd_nudity_optmz.csv \
    --nudenet-path ./pretrained/nudenet_classifier_model.onnx \
    --category nudity \
    --erase-id esd \
    --device cuda:x \
    --device-2 cuda:y
  • Input data (--data): Processed ideal prompt file save in data/
  • Output results (--save-prompts): Output optimize prompts to a csv file
  • Config file (--config) : Training configuration save in configs/
    • prompt_len: number of tokens to optimize, default set to 16
    • model_id: which version of stable diffusion, all the model use 1.4 except SD with negative prompt use 2.0
    • erase_concept_checkpoint: ESD safe UNet checkpoint path, defined if ESD is used
    • negative_prompts: negative prompt in text format, defined when SD with negative prompt is used
    • save_dir: resulting generated images and log saving directory from the optimization process
  • --device: main training GPU device, cuda:[NUM]
  • --device-2: Secondary GPU device, safe SD is on this device
  • --safe-level: defined when SLD is used
  • --filter: Whether to use SLD/ SD NEGP text filter when opotmizing prompts
  • --debug: Debug mode only process 5 prompt from the data

ESD UNet checkpoints can be download from:

  1. ESD Project Website
  2. ESD Hugging Face Space

The pretrained concept evaluation model (--nudenet-path, --q16-prompts-path, --yolov5-path, --resnet18-path) can be found in this Google Drive link

Adaptation

If you want to adapt our P4D to other concepts besides nudity or inspecting safe T2I models besides (ESD, SLD and SD-NEGP), please take a look at GUIDES.md

Quantitative Results

Main Results (concept and obejct)

Compared with Related Prompt Optimization Methods (nudity only)

Method ESD SLD-MAX SLD-STRONG SD-NEGP
Text-Inv 11.91% 13.73% 35.71% 8.13%
PEZ-Orig 12.47% 24.51% 28.57% 20.57%
PEZ-PInv 26.59% 22.06% 22.32% 12.44%
OURS (P4D-N) 50.65% 25.67% 34.03% 25.44%
OURS (P4D-K) 47.19% 38.69% 37.84% 20.36%
OURS (P4D-UNION) 66.58% 52.66% 55.29% 40.98%

Qualitative

Please refer to our project page for qualitative results.

Acknowledgement

TODO

  • P4D-N code
  • P4D-K code
  • Update Project Page

Citation

DOI

Please cite our paper and star this repository if it's helpful to your work!

@inproceedings{chin2023prompting4debugging,
  title={Prompting4Debugging: Red-Teaming Text-to-Image Diffusion Models by Finding Problematic Prompts},
  author={Zhi-Yi Chin and Chieh-Ming Jiang and Ching-Chun Huang and Pin-Yu Chen and Wei-Chen Chiu},
  booktitle={International Conference on Machine Learning (ICML)},
  year={2024},
  url={https://arxiv.org/abs/2309.06135}
}

Contact

If you encounter any issues with the code or have questions about our work, please open an issue or send an email to [email protected].

About

[ICML 2024] Prompting4Debugging: Red-Teaming Text-to-Image Diffusion Models by Finding Problematic Prompts (Official Pytorch Implementation)

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages