# WhisperSplat

A zero-footprint steganography method for 3D Gaussian Splatting (3DGS) models. WhisperSplat hides a full-resolution 2D image in a single view without altering the rendering quality or speed of other views.


## Environment Setup

This repository includes a Conda environment specification. To create and activate the environment:

```bash
conda env create -f whispersplat_environment.yml
conda activate whispersplat
```


## Data Preparation

1. **Pretrained 3DGS Checkpoints**: Prepare your pretrained model checkpoints for each scene you plan to embed, and place them under:

   ```
   ./pretrained_model/<scene_name>/
   ```

2. **Scene Data**: The data scenes used in our code are publicly available here: [https://jonbarron.info/mipnerf360/](https://jonbarron.info/mipnerf360/)

   Download and extract each scene into:

   ```
   ./data/<scene_name>/
   ```


## Usage

### 1. Run WhisperSplat Embedding

Execute the main embedding pipeline:

```bash
./whispersplat.sh
```

This script calls `whispersplat.py` to embed a secret image into one view of each scene. After completion, you will have:

- original clean renders
- the target secret 2D image
- rendered hidden image

### 2. Refine the Hidden Renders

For improved fidelity, you can refine the hidden renders by running:

```bash
./whispersplat_refiner.sh
```

This wrapper runs `whispersplat_refiner.py`, producing refined versions of the hidden renders.

---

## Repository Structure

```
.
├── whispersplat_environment.yml   # Conda environment file
├── whispersplat.py                # Embedding implementation
├── whispersplat.sh                # Wrapper to launch embedding
├── whispersplat_refiner.py        # Refinement implementation
└── whispersplat_refiner.sh        # Wrapper to launch refiner
```

