zfu006 / TAP

Official PyTorch implementation of "Temporal As a Plugin: Unsupervised Video Denoising with Pre-Trained Image Denoisers" in ECCV 2024.
21 stars 3 forks source link

Temporal As a Plugin: Unsupervised Video Denoising with Pre-Trained Image Denoisers

Zixuan Fu, Lanqing Guo, Chong Wang, Yufei Wang, Zhihao Li and Bihan Wen*.

This is the official implementation of Temporal As a Plugin: Unsupervised Video Denoising with Pre-Trained Image Denoisers (ECCV 2024).

Abstract

Recent advancements in deep learning have shown impressive results in image and video denoising, leveraging extensive pairs of noisy and noise-free data for supervision. However, the challenge of acquiring paired videos for dynamic scenes hampers the practical deployment of deep video denoising techniques. In contrast, this obstacle is less pronounced in image denoising, where paired data is more readily available. Thus, a well-trained image denoiser could serve as a reliable spatial prior for video denoising. In this paper, we propose a novel unsupervised video denoising framework, named ``Temporal As a Plugin'' (TAP), which integrates tunable temporal modules into a pre-trained image denoiser. By incorporating temporal modules, our method can harness temporal information across noisy frames, complementing its power of spatial denoising. Furthermore, we introduce a progressive fine-tuning strategy that refines each temporal module using the generated pseudo clean video frames, progressively enhancing the network's denoising performance. Compared to other unsupervised video denoising methods, our framework demonstrates superior performance on both sRGB and raw video denoising datasets.

Setup

Requirements

Pretrained models

Download pretrained models here and place them into /checkpoints/ folder.

Quick test

Raw video denoising

Run main_test_tap_crvd_indoor.py/main_test_tap_crvd_outdoor.py for evaluation.

Samples

denoised noisy


denoised noisy

Train

Fine-tuning on raw videos

Run the following command to train video denoiser on CRVD

python main_finetune_crvd_tap.py --stage 1 --pretrained_checkpoints_dir './checkpoints/nafnet/nafnet_raw.pth' --save_dir ./saves/ft_crvd_indoor/ --test_clean_vid_dir ./Datasets/video_denoising/CRVD_dataset/indoor_raw_gt/ --test_noisy_vid_dir ./Datasets/video_denoising/CRVD_dataset/indoor_raw_noisy/ --n_frames 5 --scene_type indoor --patch_size 256 --train_batch_size 6 --test_batch_size 6 --num_workers 32 --gpu_ids 0 1 3 --in_nc 4 --nc 64 --verbose --G_lr 1e-3 --pixel_loss_type L1 --epochs 1000 --test_step 120 --save_models --bayer_aug --prepare_datasets

Note to change the stages and the corresponding checkpoints directory for progressive tuning.

Reference

Our implementation is based on KAIR, RViDeNet, NAFNet. We would like to thank them.

Citation

@article{fu2024temporal,
  title={Temporal As a Plugin: Unsupervised Video Denoising with Pre-Trained Image Denoisers},
  author={Fu, Zixuan and Guo, Lanqing and Wang, Chong and Wang, Yufei and Li, Zhihao and Wen, Bihan},
  journal={arXiv preprint arXiv:2409.11256},
  year={2024}
}