This example is ported over from pytorch-examples.
It uses ignite
to implement an algorithm for artistic style transfer as described in Perceptual Losses for Real-Time Style Transfer and Super-Resolution.
torch
torchvision
ignite
Example for virtualenv
setup:
virtualenv --python=/usr/bin/python3.5 env
source env/bin/activate
pip install torch torchvision pytorch-ignite
The code runs on CPU, but GPU allows it to run much faster. If using GPU, please ensure proper libraries are installed.
Code can be used to train a style transfer model for any image. To run code correctly, ensure that MSCOCO dataset and a style image are downloaded.
Since the code using Pytorch's Dataset functions, ensure that directory with MSCOCO dataset is formatted as shown below. The directory should be setup such that the location of the dataset is MSCOCO, which contains a single folder 0, containing all the images.
├── MSCOCO
│ ├── 0
│ │ ├── RY48TY43YT.jpg
│ │ ├── 4324J0FNFL.jpg
│ │ ├── Y9REWJKNFE.jpg
python neural_style.py train --epochs 2 --cuda 1 --dataset mscoco --dataroot /path/to/mscoco --style_image ./images/style_images/mosaic.jpg
--epochs
: number of training epochs, default is 2.--batch_size
: batch size for training, default is 8.--dataset
: type of dataset.--dataroot
: path to training dataset, the path should point to a folder containing another folder with all the training images.--style_image
: path to style-image.--checkpoint_model_dir
: path to folder where checkpoints of trained models will be saved.--checkpoint_interval
: number of batches after which a checkpoint of trained model will be created.--image_size
: size of training images, default is 256 X 256.--style_size
: size of style-image, default is the original size of style image.--cuda
: set it to 1 for running on GPU, 0 for CPU.--seed
: random seed for training.--content_weight
: weight for content-loss, default is 1e5.--style_weight
: weight for style-loss, default is 1e10.--lr
: learning rate, default is 1e-3.
Code can be used to stylize an image using a trained style transfer model.
python neural_style.py eval --content_image ./images/content_images/amber.jpg --output_image test.png --cuda 1 --model /tmp/checkpoints/checkpoint_net_2.pth
--content_image
: path to content image you want to stylize.--content_scale
: factor for scaling down the content image.--output_image
: path for saving the output image.--model
: saved model to be used for stylizing the image.--cuda
: set it to 1 for running on GPU, 0 for CPU.