hainuo-wang / XReflection

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/NPU support, and more!

Repository from Github https://github.comhainuo-wang/XReflectionRepository from Github https://github.comhainuo-wang/XReflection

XReflection - An Easy-to-use Toolbox for Single-image Reflection Removal

XReflection Logo

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.

NTIRE 2025 Award


πŸ“° 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.

About

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/NPU support, and more!


Languages

Language:Python 98.9%Language:C++ 1.1%Language:Shell 0.0%