XReflection
XReflection copied to clipboard
XReflection is a neat toolbox tailored for single-image reflection removal(SIRR). We offer state-of-the-art SIRR solutions for training and inference, with a high-performance data pipeline, multi-GPU/...
XReflection - An Easy-to-use Toolbox for Single-image Reflection Removal

XReflection is a neat toolbox tailored for single-image reflection removal(SIRR). We offer state-of-the-art SIRR solutions for training and inference, with a high-performance data pipeline, multi-GPU/TPU support, and more!
🏆 Award
Equipped with XReflection, our team won the 1st place in the NTIRE 2025 Challenge on Single Image Reflection Removal in the Wild.

📰 News and Updates
- [2025-10-26] XReflection is now production-ready and have been applied to multiple research projects inside our team. DSIT is available in the model zoo. More models are on the way!
- [2025-07-16] DSRNet is available in the model zoo. More models are on the way!
- [2025-05-26] Release a training/testing pipeline.
💡 Key Features
- All-in-one intergration for the state-of-the-art SIRR solutions. We aim to create an out-of-the-box experience for SIRR research.
- Multi-GPU/TPU support via PyTorchLightning.
- Pretrained model zoo.
- Fast data synthesis pipeline.
📝 Introduction
Please visit the documentation for more features and usage.
🚀 Installation
Installation Commands
# Build from source
git clone https://github.com/hainuo-wang/XReflection.git
cd XReflection
# Install dependencies
pip install -r requirements.txt
python setup.py develop
📦 Getting Started
Testing a Pretrained Model
python tools/train.py --config configs/train_config.yaml --test_only pretrained.ckpt
Training a Model
python tools/train.py --config configs/train_config.yaml
Resume Training
from the last checkpoint
python tools/train.py --config configs/train_config.yaml --resume
from the a specific checkpoint
python tools/train.py --config configs/train_config.yaml --resume your_checkpoint_path.ckpt
Data Preparation
Training dataset
- 7,643 images from the Pascal VOC dataset, center-cropped as 224 x 224 slices to synthesize training pairs;
- 90 real-world training pairs provided by Zhang et al.;
- 200 real-world training pairs provided by IBCLN.
Testing dataset
- 45 real-world testing images from CEILNet dataset;
- 20 real testing pairs provided by Zhang et al.;
- 20 real testing pairs provided by IBCLN;
- 454 real testing pairs from SIR^2 dataset, containing three subsets (i.e., Objects (200), Postcard (199), Wild (55)).
Download all in one from https://checkpoints.mingjia.li/sirs.zip
🌟 Features in Detail
Pretrained Model Zoo
The performance of previous methods are improved with our new training pipeline. Access pretrained models for various SIRR algorithms. More are on the way.
| Model | Link | PSNR(dB) |
|---|---|---|
| DSRNet | https://checkpoints.mingjia.li/dsr-25.8915.ckpt | 25.8915 |
| DSIT | https://checkpoints.mingjia.li/dsit-26.6959.ckpt | 26.6959 |
🙏 License and Acknowledgement
This project is licensed under the Apache License 2.0. See the LICENSE file for details. The authors would express gratitude to the computational resource support from Google's TPU Research Cloud.