Skip to content

[NeurIPS 2024 Spotlight] SpikeReveal: Unlocking Temporal Sequences from Real Blurry Inputs with Spike Streams.

Notifications You must be signed in to change notification settings

chenkang455/S-SDM

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

27 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

If you like our project, please give us a star ⭐ on GitHub.

arXiv License GitHub repo stars 

📕 Abstract

We begin with a theoretical analysis of the relationship between spike streams, blurry images, and sharp sequences, leading to the development of our Spike-guided Deblurring Model (SDM). We further construct a self-supervised processing pipeline by cascading the denoising network and the super-resolution network to reduce the sensitivity of the SDM to spike noise and its reliance on spatial-resolution matching between the two modalities. To reduce the time consumption and enhance the utilization of spatial-temporal spike information within this pipeline, we further design a Lightweight Deblurring Network (LDN) and train it based on pseudo-labels from the teacher model, i.e., the established self-supervised processing pipeline. By further introducing re-blurring loss during LDN training, we achieve better restoration performance and faster processing speed compared to the processing-lengthy and structure-complicated teacher model.

👀 Visual Comparisons

Sequence reconstruction on RSB dataset under different light conditions. (flicker is caused by the gif compression)

Image debluring on RSB Dataset.

RSB Dataset

🗓️ TODO

  • Release the scripts for simulating GOPRO dataset.
  • Release the training and testing code.
  • Release the pretrained model.
  • Release the synthetic/real-world dataset.

🕶 Dataset

Guidance on synthesizing the spike-based GOPRO dataset can be found in GOPRO_dataset.

Converted GOPRO dataset can be found in GOPRO and the real-world blur RSB dataset will be public once our manuscript is accepted.

🍭 Prepare

Our S-SDM requires the sequential training of BSN, EDSR and LDN respectively. We provide the trained weights through the link, which should be placed in the folder model/. Meanwhile, downloaded/converted GOPRO dataset should be located under the project root folder. The structure of our project is formulated as:

<project root>
├── codes
├── imgs
├── log (train and evaluation results)
├── model
│   ├── BSN_1000.pth
│   └── ...
├── scripts
├── GOPRO
│   ├── test
│   └── train
├── train_bsn.py
├── train_deblur.py
└── train_sr.py

🌅 Train

Train BSN on the GOPRO dataset:

python train_bsn.py --base_folder GOPRO/ --bsn_len 9 --data_type GOPRO 

Train EDSR on the GOPRO dataset:

python train_sr.py --base_folder GOPRO/ --data_type GOPRO

Train LDN on the GOPRO dataset:

python train_deblur.py --base_folder GOPRO/ --bsn_path model/BSN_1000.pth  --sr_path model/SR_70.pth  --lambda_reblur 100 --data_type GOPRO 

📊 Evaluate

Evaluate BSN on the GOPRO dataset:

python train_bsn.py --test_mode --bsn_path model/BSN_1000.pth --data_type GOPRO

Evaluate EDSR on the GOPRO dataset:

python train_sr.py --test_mode --bsn_path model/BSN_1000.pth  --sr_path model/SR_70.pth --data_type GOPRO

Evaluate LDN on the GOPRO dataset:

python train_deblur.py --test_mode --bsn_path model/BSN_1000.pth  --sr_path model/SR_70.pth --deblur_path model/DeblurNet_100.pth --data_type GOPRO

📞 Contact

Should you have any questions, please feel free to contact mrchenkang@whu.edu.cn.

🤝 Citation

If you find our work useful in your research, please cite:

@article{chen2024spikereveal,
  title={SpikeReveal: Unlocking Temporal Sequences from Real Blurry Inputs with Spike Streams},
  author={Chen, Kang and Chen, Shiyan and Zhang, Jiyuan and Zhang, Baoyue and Zheng, Yajing and Huang, Tiejun and Yu, Zhaofei},
  journal={arXiv preprint arXiv:2403.09486},
  year={2024}
}

About

[NeurIPS 2024 Spotlight] SpikeReveal: Unlocking Temporal Sequences from Real Blurry Inputs with Spike Streams.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages