Code for the paper https://arxiv.org/abs/1904.12785, to appear CVPR 2019
Webdemo available at: http://128.135.245.233:8080/
- python3 >= 3.5
- pytorch >= 1.0
- imageio >= 2.2
- numpy >= 1.1
python3 styleTransfer.py {PATH_TO_CONTENT} {PATH_TO_STYLE} {CONTENT_WEIGHT}
The default content weight is 1.0 (for the images provided my personal favorite is 0.5, but generally 1.0 works well for most inputs). The content weight is actually multiplied by 16, see section 2.5 of paper for explanation.
The resolution of the output can be set on line 80 of styleTransfer.py; the current scale is 5, and produces outputs that are 512 pixels on the long side, setting it to 4 or 6 will produce outputs that are 256 or 1024 pixels on the long side respectively, most GPUs will run out of memory for settings of this variable above 6.
The output will appear in the same folder as 'styleTransfer.py' and be named 'output.png'
python3 styleTransfer.py {PATH_TO_CONTENT} {PATH_TO_STYLE} {CONTENT_WEIGHT} -gr {PATH_TO_CONTENT_GUIDANCE} {PATH_TO_STYLE_GUIDANCE}
guidance should take the form of two masks such as these:
Content Mask | Style Mask |
---|---|
where regions that you wish to map onto each other have the same color.