Skip to content

shangwei5/SelfDRSC

Repository files navigation

Self-supervised Learning to Bring Dual Reversed Rolling Shutter Images Alive (ICCV2023)


[arXiv] [PDF]

This repository is the official PyTorch implementation of SelfDRSC: Self-supervised Learning to Bring Dual Reversed Rolling Shutter Images Alive. We also provide an implementation in HUAWEI Mindspore at Mindspore.

Introduction

To correct RS distortions, existing methods adopt a fully supervised learning manner, where high framerate global shutter (GS) images should be collected as ground-truth supervision. In this paper, we propose a Self-supervised learning framework for Dual reversed RS distortions Correction (SelfDRSC), where a DRSC network can be learned to generate a high framerate GS video only based on dual RS images with reversed distortions. In particular, a bidirectional distortion warping module is proposed for reconstructing dual reversed RS images, and then a self-supervised loss can be deployed to train DRSC network by enhancing the cycle consistency between input and reconstructed dual reversed RS images. Besides start and end RS scanning time, GS images at arbitrary intermediate scanning time can also be supervised in SelfDRSC, thus enabling the learned DRSC network to generate a high framerate GS video. Moreover, a simple yet effective self-distillation strategy is introduced in self-supervised loss for mitigating boundary artifacts in generated GS images.

Examples of the Demo

r0_.mp4
demo_total1.MP4

Prerequisites

  • Python >= 3.8, PyTorch >= 1.7.0
  • Requirements: opencv-python, numpy, matplotlib, imageio, scikit-image, tqdm

Datasets

Please download the RS-GOPRO datasets from GoogleDrive or BaiduDisk(password: vsad).

Dataset Organization Form

|--dataset
    |--train  
        |--video 1
            |--GS
                |--frame 1
                |--frame 2
                    :
            |--RS
                |--frame 1
                |--frame 2
                    : 
        |--video 2
            :
        |--video n
    |--valid
        |--video 1
            |--GS
                |--frame 1
                |--frame 2
                    :
            |--RS
                |--frame 1
                |--frame 2
                    :   
        |--video 2
         :
        |--video n
    |--test
        |--video 1
            |--GS
                |--frame 1
                |--frame 2
                    :
            |--RS
                |--frame 1
                |--frame 2
                    :   
        |--video 2
         :
        |--video n

Download Pre-trained Model of SelfDRSC

Please download the pre-trained pwcnet from link(password:pjdx). Please put these models to ./pretrained.

Please download the pre-trained checkpoints from Stage one(password:42ep) and Stage two(password:9w64). Please put these models to ./experiments.

Getting Started

1) Testing

1.Testing on RS-GOPRO dataset:

python -m torch.distributed.launch --nproc_per_node=1 --master_port=1234 main_test_srsc_rsflow_multi_distillv2.py --opt options/test_srsc_rsflow_multi_distillv2_psnr.json  --dist True

Please change data_root and pretrained_netG in options according to yours.

1.Testing on real RS data:

python -m torch.distributed.launch --nproc_per_node=1 --master_port=1234 main_test_srsc_rsflow_multi_distillv2_real.py --opt options/test_srsc_rsflow_multi_distillv2_real.json  --dist True

Please change data_root and pretrained_netG in options according to yours.

2) Training

1.Training the first stage: (8 GPUs)

python -m torch.distributed.launch --nproc_per_node=8 --master_port=1234 main_train_srsc_rsflow_multi.py --opt options/train_srsc_rsflow_multi_psnr.json --dist True

Please change data_root and pretrained_rsg in options according to yours.

2.Training the second stage (adding self-distillation): (8 GPUs)

python -m torch.distributed.launch --nproc_per_node=8 --master_port=1234 main_train_srsc_rsflow_multi_distillv2.py --opt options/train_srsc_rsflow_multi_distillv2_psnr.json  --dist True

Please change data_root, pretrained_rsg and pretrained_netG in options according to yours.

Cite

If you use any part of our code, or SelfDRSC is useful for your research, please consider citing:

@inproceedings{shang2023self,
  title={Self-supervised Learning to Bring Dual Reversed Rolling Shutter Images Alive},
  author={Shang, Wei and Ren, Dongwei and Feng, Chaoyu and Wang, Xiaotao and Lei, Lei and Zuo, Wangmeng},
  booktitle={Proceedings of the IEEE/CVF International Conference on Computer Vision},
  pages={13086--13094},
  year={2023}
}

Contact

If you have any questions, please contact csweishang@gmail.com.

Acknowledgements

This code is built on IFED. We thank the authors for sharing the codes.

About

Self-supervised Learning to Bring Dual Reversed Rolling Shutter Images Alive (ICCV2023)

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages