# ICML Anonymous Submission #15594  

## Stage-wise Distortion–Perception Traversal in Zero-shot Inverse Problems with Diffusion Models

This repository contains the code for reproducing the experiments of the ICML submission #15594.

This project is based on the following open-source implementations:

- **DDRM**: https://github.com/bahjat-kawar/ddrm  
- **DPS**: https://github.com/DPS2022/diffusion-posterior-sampling  
- **ProjDiff**: https://github.com/weigerzan/ProjDiff  

---

## Environment Setup

The environment configuration follows **DPS**.

Create the environment using:

```bash
conda env create -f environment.yml
conda activate map_rps
git clone https://github.com/VinAIResearch/blur-kernel-space-exploring bkse
```

For experiments on **MSCOCO**, please additionally install:

```bash
pip install diffusers==0.35.2
```

---

## MAP-RPS on FFHQ

### Checkpoints

Download the pre-trained FFHQ diffusion models provided by DPS:

- Repository: https://github.com/DPS2022/diffusion-posterior-sampling  
- Checkpoints: https://drive.google.com/drive/folders/1jElnRoFv7b31fG0v6pTSQkelbSX3xGZh  

Place the downloaded files under:

```text
exp/logs/ffhq/
```

---

### Test Dataset

Download the FFHQ dataset from:

- https://github.com/NVlabs/ffhq-dataset

For testing, only the folder `00000` is required.  
Place it under:

```text
exp/datasets/ffhq/
```

---

### Reproducing the Results

Run:

```bash
python main.py \
  --ni \
  --config ffhq.yml \
  --timesteps 1000 \
  --algo map_rps \
  --noise_t 10 \
  --deg {DEGRADATION} \
  --sigma_0 {SIGMA_0} \
  -i {IMAGE_FOLDER} \
  --xi {XI} \
  --optimize_iters {ITERS} \
  --vae_lr {VAE_LR} \
  --w_prior {W_PRIOR} \
  --renoise_t {RENOISE_T}
```

**Arguments:**

- `DEGRADATION`: degradation type, choose from  
  `deblur_aniso`, `sr4`, `inp`, `denoise`
- `SIGMA_0`: noise level in the observation
- `IMAGE_FOLDER`: output folder name (default: `images`)
- `XI`: step size (learning rate) for DPS
- `ITERS`: number of iterations for MAP optimization
- `VAE_LR`: base learning rate for MAP optimization
- `W_PRIOR`: weight of the prior gradient
- `RENOISE_T`: re-noising timestep for posterior sampling

Example scripts are provided in `./scripts/`.

---

## LMAP-RPS on FFHQ

### Checkpoints

Download the pre-trained latent diffusion models from:

- https://github.com/CompVis/latent-diffusion

Place the checkpoints under:

```text
exp/logs/ldm/
```

---

### Test Dataset

Same as **MAP-RPS on FFHQ**.

---

### Reproducing the Results

```bash
python main.py \
  --ni \
  --config ffhq.yml \
  --timesteps 1000 \
  --algo lmap_rps \
  --noise_t 10 \
  --deg {DEGRADATION} \
  --sigma_0 {SIGMA_0} \
  -i {IMAGE_FOLDER} \
  --xi {XI} \
  --optimize_iters {ITERS} \
  --vae_lr {VAE_LR} \
  --w_prior {W_PRIOR} \
  --renoise_t {RENOISE_T}
```

The arguments are identical to those described above.  
Example scripts can be found in `./scripts/`.

---

## LMAP-RPS on MSCOCO

### Checkpoints

We use Stable Diffusion v1.5:

- https://huggingface.co/stable-diffusion-v1-5/stable-diffusion-v1-5

The checkpoints can be downloaded automatically by the code, or manually placed under:

```text
exp/logs/runwayml/stable-diffusion-v1-5/
```

---

### Test Dataset

Download the MSCOCO dataset (with captions) from:

- https://cocodataset.org/#download

Place the test set under:

```text
exp/datasets/coco/
```

---

### Reproducing the Results

```bash
python main.py \
  --ni \
  --config coco.yml \
  --timesteps 1000 \
  --algo lmap_rps \
  --noise_t 10 \
  --deg {DEGRADATION} \
  --sigma_0 {SIGMA_0} \
  -i {IMAGE_FOLDER} \
  --xi {XI} \
  --optimize_iters {ITERS} \
  --vae_lr {VAE_LR} \
  --w_prior {W_PRIOR} \
  --renoise_t {RENOISE_T}
```

The argument definitions are the same as in the FFHQ experiments.  
Example scripts are provided in `./scripts/`.

---

## Metric Evaluation

Example scripts for computing evaluation metrics (e.g., RMSE, FID) are provided in:

```text
calculate_metrics/
```