# README

Anonymous ICML 2026 code bundle for normalization-equivariant denoising.

## Contents

- `analysis/`: scripts for the analysis section (Δ distributions, coverage, residual difficulty).
- `artifacts/`: figure assets and analysis outputs.
- `data/`: train/test datasets (BSD400, Set12/68) and helper scripts to download (Waterloo, DIV2K, Flickr2K).

- `eval.py`: PSNR evaluation/plotting (uses `model_logs.py`, `logs/` for checkpoints).
- `eval_logs/`: CSVs/plots used in the paper.
-
- `figure_scripts/`: misc. figures and tables scripts (parrot figure, ship figure, adaptive filters, PSNR table).

- `model_logs.py`: checkpoint registry mapping model names to paths.
- `logs/`: checkpoints + first/last PSNR plots.
- `train.py`, `experiments_cfg.py`: training configs for Gaussian and non-Gaussian experiments.

- `speed_test.py`: runtime benchmarks.

## Setup (uv)

- Install uv: see <https://docs.astral.sh/uv/>.
- Install deps in the repo root: `uv sync`
- Run commands with the env: `uv run ...`

## Package (se)

- Python package lives in `se/` and installs as `se` after `uv sync` (see `pyproject.toml`).
- Models: DnCNN (Zhang et al., IEEE TIP 2017), and its normalization-equivariant (NE) and scale-equivariant (SE) architectural variants (Herbreteau et al., NeurIPS 2023), SwinIR (Liang et al., ICCV Workshops 2021).
- Wrappers: our normalization-equivariant wrapper and a scale-equivariant wrapper.
- Miscellaneous helpers: `se/utils` (noise models, PSNR plotting, metrics, training utilities).

## Training

- Default run uses `cfg_50_dncnn_wne` from `experiments_cfg.py`:  
  `uv run train.py`
- All experiments train in under 2 days on a single NVIDIA GeForce RTX 4090.

## Evaluation

- Uses `model_logs.py` to locate the checkpoints.
- Quick run (defaults to SwinIR σ=50 on Set12, baseline vs WNE):  
  `uv run eval.py`
- To customize, change the `EvalConfig` instance in the script.
