# Spherical Watermark: Encryption-Free, Lossless Watermarking for Diffusion Models
This is a detailed implementation of our submission 14944. This projects includes:
1. Specification of dependencies
2. Evaluation code
3. Inference code

We have not included any training scripts, as our method requires no additional training and integrates directly with the pretrained diffusion framework. Likewise, we have not distributed the Stable Diffusion model weights (which are prohibitively large); instead, they may be downloaded from the official Hugging Face repository.

## Getting Started
1. Install dependencies
> pip install -r requirements.txt
2. For example, we can use SD v2.1 as the generative model, and use the pretrained model from the official Hugging Face repository.
> Download link:  https://huggingface.co/stabilityai/stable-diffusion-2-1-base
3. Generate signature as you are the model developer: (can skip)
```
replace line 4 of options/ours_test.yaml with "from_file:"
modify the main function of main.py to run build phase, please refer to the comments
the console will report the location of the signature, like:
"Constructed watermark signet located at ./choice-keys/sph/qLWEAFAHapBLw4B6Tl5RUb1SlxXKrpd2jbiim3d1W75GlmNe1R9ZnsrZq7YKMb2K_1_31_16384_512.pkl"
If you want to use the signature, you can modify the line 4 of options/ours_test.yaml to "from_file: qLWEAFAHapBLw4B6Tl5RUb1SlxXKrpd2jbiim3d1W75GlmNe1R9ZnsrZq7YKMb2K_1_31_16384_512"
```
4. Generate watermarked images and try extracting watermark
>  python main.py
> 
you can modify some parameters, like prompt, save path, etc.

## Evaluations
We evaluated two primary metrics in our experiments:

### 1. Undetectability
- **Latent-level Classification**: 
  - Quantified through classification training on the latent space
  - Results obtained via: `python performance_test.py`
  
- **Image-level Classification**: 
  - Used the publicly available ResNet architecture for classification tasks

- **Quality Metrics**:
  - Employed standardized image quality benchmarks:
    - Fréchet Inception Distance (FID)
    - Inception Score (IS)

### 2. Attribution Accuracy
- **Tracing Accuracy**:
  - Procedure:
    1. Invoke main function with batch processing mode
    2. Monitor ACC and TPR consistency across:
       - Multiple model architectures
       - Diverse prompts
       
## Notes
Due to space limitations, the complete source code is not included in this submission. The provided simplified implementation:
- Preserves core algorithmic logic while removing auxiliary components
- Maintains essential functional modules for method validation
- Follows standard Python coding conventions for reproducibility

This simplified version enables readers to:
1. Grasp fundamental implementation principles
2. Reproduce core experimental results
3. Adapt the framework to specific application scenarios

Upon completion of the peer-review process, we will fully open-source the implementation through a public code repository. The complete codebase will include:
- Full implementation of all pipelines, including ours and baseline methods
- Detailed documentation
- Used Prompt Dataset
- Other resources

### Diffuser Library Integration
We demonstrate seamless integration with the [diffuser library](https://github.com/huggingface/diffusers), a state-of-the-art diffusion modeling framework.