Skip to content
/ SRCNN Public

My implementation of Super Resolution CNN and replication of paper's results

Notifications You must be signed in to change notification settings

sdv4/SRCNN

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

SRCNN

This is my reproduction of the model and results in the paper

Image Super-Resolution Using Deep Convolutional Networks
Chao Dong Chen Loy et al.
Published in 2017 IEEE transactions on pattern analysis and machine intelligence

This repository includes an implementation of SRCNN and model trained for 3x super resolution. The included model was trained on the BSDS500 training and validation sets. The BSDS500 test set was used as a validation set. As a test set I use the popular Set5 images, which were also used in the original paper to demonstrate their results. You can see these results here:

Contents

This repository provides:

  • A [trained SRCNN] for 3x super-resolution (models/)
  • [Code to generate] the training and validation sets (src/data/build_sr_dataset.py)
  • The [notebook used to train the model] from scratch (notebooks/SR_with_MSE_loss.ipynb)
  • A [notebook] to visualize the first conv. layer kernels (src/visualization/visualize_kernels.ipynb)
  • A [notebook] to generate demo images (src/visualization/generate_images.ipynb)

Differences from the paper

  • The paper says that they trained their models for 8x108 back-propagations. This seems unreasonably long and I suspect that it was a typo. I trained for 15x106 and achieved good results.
  • The paper says they used no padding while training to avoid boarder effects. I didn't find evidence of this problem in my images, so I pad to preserve the input image's dimensions.

Setup

All code is implemented in Python and Pytorch.

First install the project dependencies:

pip install -r requirements.txt

Then download a dataset and move it to [data/raw/] (data/raw/)

Build the training and validation datasets as follows:

python3 src/data/build_sr_dataset.py <path_to_train_images/> <data/train/file_name.hdf5> <super_resolution_factor>

python3 src/data/build_sr_dataset.py <path_to_val_images/> <data/val/file_name.hdf5> <super_resolution_factor>

Train the model by running the [training notebook] (./notebooks/SR_with_MSE_loss.ipynb)

Watch Learning Progression

Start TensorBoard on localhost:8898 after training has started

About

My implementation of Super Resolution CNN and replication of paper's results

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published