tadax / srgan

SRGAN implemetation with TensorFlow

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Super Resolution using Generative Adversarial Network (SRGAN)

This is an implementation of the SRGAN model proposed in the paper (Photo-Realistic Single Image Super-Resolution Using a Generative Adversarial Network) with TensorFlow.

Requirements

  • Python 3
  • TensorFlow 1.1
  • OpenCV
  • dlib

Usage

I. Pretrain the VGG-19 model

Download the ImageNet dataset and preprocess them with:

$ cd vgg19/imagenet
$ python get_urls.py
$ python create_db.py
$ python download_images.py
$ python preprocess.py

Train with:

$ cd vgg19
$ python train.py

Or you can download the pretrained model file: vgg19_model.tar.gz

II. Train the SRGAN (ResNet-Generator and Discriminator) model

Download the LFW dataset and preprocess them with:

$ cd /src/lfw
$ python lfw.py

Train with:

$ cd src
$ python train.py

The result will be stored in "src/result".

Results

LFW

result1

result2

result3

result4

result5

result6

result7

result8

result9

result10

result11

result12

result13

result14

result15

result16

Loss function

Adversarial loss

This implementation adopts the least squares loss function instead of the sigmoid cross entropy loss function for the discriminator. See the details: Least Squares Generative Adversarial Networks

Content loss

The paper says VGG54 is the perceptually most convincing results. But this implemetation uses all the feature maps generated by every layer (i.e. phi12, phi22, phi34, phi44, phi54) within the VGG19 network.

About

SRGAN implemetation with TensorFlow


Languages

Language:Python 100.0%