Fast-Neural-Style-Transfer
Fast-Neural-Style-Transfer copied to clipboard
Fast Neural Style Transfer implementation using PyTorch
Fast-Neural-Style π
The model uses the method described in Perceptual Losses for Real-Time Style Transfer and Super-Resolution along with Instance Normalization.
Train:
There are several arguments to change in config.yaml
, the important ones are listed below:
-
dataset
: path to training dataset, the path should point to a folder containing another folder with all the training images. I used COCO 2014 Training images dataset [83K/13GB] (download). -
save-model-dir
: path to folder where trained models will be saved.
Run:
-
python train.py --styles images/style-images
train for all style images inimages/style-images
folder.
Stylize:
In config.yaml
, modify inside STYLIZE
-
model
: path to saved models to be used for stylizing the image (eg:weights
) -
output-image
: path for saving the output images. -
content-scale
: factor for scaling down the content image if memory is an issue (eg: value of 2 will halve the height and width of content-image)
Run:
-
python stylize.py --img images/content-images/uzb.jpg
Input image:
data:image/s3,"s3://crabby-images/9f5e5/9f5e543c47a68446f92e43f7e7e03f24ecbb8288" alt=""
π Samarkand, Uzbekistan πΊπΏ
data:image/s3,"s3://crabby-images/f7b82/f7b82da0c64c638a836e9965875736b8f6b985ca" alt=""
data:image/s3,"s3://crabby-images/b7a32/b7a32ef1dce3217bd4b02235e21aa44c7273ee43" alt=""
data:image/s3,"s3://crabby-images/aaa1f/aaa1f55b40be2403b19179d5a038ed5e4383a7fd" alt=""
data:image/s3,"s3://crabby-images/42c5e/42c5e3ade99a83d93090c9cc054023658a5f8223" alt=""
data:image/s3,"s3://crabby-images/8af25/8af2535ec80f423d89ec9c95c3ecc074017e2e24" alt=""
data:image/s3,"s3://crabby-images/7bb4f/7bb4f42ccb8322507f96b796bc320a6c3f1d5960" alt=""
data:image/s3,"s3://crabby-images/57766/5776610af25e1a4ea5069305aa3c21aaf4f7a860" alt=""
data:image/s3,"s3://crabby-images/106d0/106d01f7a12ecde9ff00ed19500e2bb5cf1b349e" alt=""
Requirements:
The program is written in Python, and uses PyTorch. A GPU is not necessary, but can provide a significant speed up especially for training a new model. Regular sized images can be styled on a laptop or desktop using saved models.
config.yaml
:
TRAIN:
'num_epochs': 5 # Number of training epochs
'batch_size': 8 # Batch size for training
'dataset': '../Datasets/train2014/' # Path to training dataset
'save_model_dir': 'weights'
'image_size': 256 # Train image size, default is 256 X 256
'style_size': # Style-image size, default is the original size of style image
'seed': 42
'content_weight': 1.e+5 # Weight for content-loss, default is 1e5
'style_weight': 1.e+10 # Weight for style-loss, default is 1e10
'lr': 1.e-3 # Learning rate, default is 1e-3
'log_interval': 500 # Number of batch intervals to show stats, default is 500
STYLIZE:
content_scale: 1.0 # Factor for scaling down the content image, float
output_path: 'images/output-images' # Path for saving the output image
models_path: 'weights' # Path to style models