# Universal Image Immunization against Diffusion-based Image Editing via Semantic Injection

## Introduction
This repository contains the code for our submission to NeurIPS 2025 (ID: 5343).  
We propose a novel universal image immunization method by injecting target semantics and jointly suppressing the semantics of a source image.  
The implementation is based on PyTorch.

## Preparation
* Our method has been tested on the following environment:
  - **Operating System**: Ubuntu 20.04  
  - **diffusers**: 0.32.2
  - **Python**: 3.10.16  
  - **PyTorch**: 2.6.0  
  - **Torchvision**: 0.21.0  
  - **CUDA**: 11.6  

* Download the laion_aesthetic samples set from [here](https://huggingface.co/datasets/laion/laion2B-en-aesthetic).
* Pre-trained models will be loaded automatically from diffusers library.

​
## Usage
###  UAP Training
The commands below initiate training to craft a UAP using a surrogate model.
If you want to train the UAP in data-free setting, please uncomment line 346 in main.py.
After training, the generated UAP will be saved in your output directory.

```bash
python main.py
```