Skip to main content

Ready-to-use artistic deep learning algorithms

Project description

Neurartist

A ready-to-use implementation of various Artistic Deep Learning Algorithms.

  • Image Style Transfer Using Convolutional Neural Networks, Gatys et. al, 2016

  • Controlling Perceptual Factors in Neural Style Transfer, Gatys et. al, 2016

Installation

# It is recommended to install torch/torchvision manually before this command, according to your hardware configuration (see below)
pip install neurartist

Please note that the use of a GPU is recommended, as CNN computations are pretty slow on a CPU.

NB for GPU users: pip ships torch/torchvision with the Cuda Toolkit 9.0. If you use a more recent version of the Cuda Toolkit, see the PyTorch website for instructions on PyTorch installation with another version of the toolkit.

Usage

Console entrypoint

# Then see the builtin help for usage details
neurartist --help

See the examples below for the most common use cases.

Library

import neurartist

To be added.

Examples

  • Basic usage: apply the style of an image to a content image, while preserving the semantic content.

neurartist -c content.jpg -s style.jpg
  • Color control: apply a style, but preserve the color of the content image.

# Luminance only
neurartist -c content.jpg -s style.jpg --color-control luminance_only
# Luminance only, luma normalized
neurartist -c content.jpg -s style.jpg --color-control luminance_only --cc-luminance-only-normalize
# Color histogram matching
neurartist -c content.jpg -s style.jpg --color-control histogram_matching
  • Style mixin: mix the coarse scale information of style1 (higher layers) with the fine scale information of style2 (lower layers), to create a mixed style to apply to a content image.

neurartist -c style1.jpg -s style2.jpg -o mixed.png --content-layers [22,29] --style-layers [1,6]
neurartist -c content.jpg -s mixed.png
  • Efficient high resolution: first pass is a low resolution style transfer that efficiently catches coarse scale style features, second pass is a high resolution style transfer that upscales the result of the first pass and fills the lost fine information using fine scale style features.

neurartist -c content.jpg -s style.jpg -o lowres.png -S 500
neurartist -c content.jpg -s style.jpg -o highres.png -S 1000 --init-image-path lowres.png
  • Spatial control: Guided gram matrices with guidance channels. Guidance paths should contain black and white guidance images (with the same size ratio as content and style images), defining the boundaries of semantic regions of each image. Style guidance images and content guidance images should have the same name, in correspondance to a semantic region. Segmentation of the image should be exhaustive.

neurartist -c content.jpg -s style.jpg --content-guidance content_image_guidance_path/ --style-guidance style_image_guidance_path/ --guidance-propagation-method inside

Development

Anaconda is strongly recommended:

conda create python=3.7 --name neurartist_env
conda activate neurartist_env

# with gpu
conda install pytorch torchvision cudatoolkit=<your cudatoolkit version> -c pytorch
conda install --file requirements.txt

# with cpu
conda install pytorch-cpu torchvision-cpu -c pytorch
conda install --file requirements.txt

You can then run the main entrypoint directly using:

python -m neurartist --help

Or build and install the wheel file with the --editable flag.

TODO

  • Documentation.

  • Implement total variation loss (see this).

  • Implement guided sums.

  • Examine if we need to add a fallback global guidance channel for pixels that aren’t covered by any channel (briefly mentioned in the article but very vague). Short answer: yes, it is needed, with bigger kernel sizes the style transfer isn’t performed at the boundary.

  • For guidance channels propagation: investigate what they mean by “erosion” (see supplementary material document linked in the original article).

  • Semantic segmentation as described in this article as to limit spillovers: different approach than guided gram matrices, but same idea of using spatial guidance channels that describe a semantic segmentation of our images.

  • More deep-artistic algorithms.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

neurartist-0.4.1.tar.gz (16.5 kB view details)

Uploaded Source

Built Distribution

neurartist-0.4.1-py3-none-any.whl (27.7 kB view details)

Uploaded Python 3

File details

Details for the file neurartist-0.4.1.tar.gz.

File metadata

  • Download URL: neurartist-0.4.1.tar.gz
  • Upload date:
  • Size: 16.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.4

File hashes

Hashes for neurartist-0.4.1.tar.gz
Algorithm Hash digest
SHA256 b89b910e22556384b106df9395c041f3e624ab5552658ea7294fb416a5658538
MD5 a40e499902db47ce4c240f2d9dc227f6
BLAKE2b-256 9f3c04fff30551a54d4ddac234c334ffcff5bb1b68d92c324464a601096cc923

See more details on using hashes here.

File details

Details for the file neurartist-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: neurartist-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 27.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.4

File hashes

Hashes for neurartist-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ac3b761c50a12ad40edee2f50c16c66484f3be2049649b3ca0201adb3dc4a846
MD5 b2b2d9368852c47734b635b4b72a1633
BLAKE2b-256 0b5d57ae37ffb75002795582381d62829ee4d6800444f91e3c783d58285e2a3d

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page