forked from NVlabs/stylegan2
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
47 changed files
with
8,618 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
# Copyright (c) 2019, NVIDIA Corporation. All rights reserved. | ||
# | ||
# This work is made available under the Nvidia Source Code License-NC. | ||
# To view a copy of this license, visit | ||
# https://nvlabs.github.io/stylegan2/license.html | ||
|
||
FROM tensorflow/tensorflow:1.15.0-gpu-py3 | ||
|
||
RUN pip install scipy==1.3.3 | ||
RUN pip install requests==2.22.0 | ||
RUN pip install Pillow==6.2.1 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,101 @@ | ||
Copyright (c) 2019, NVIDIA Corporation. All rights reserved. | ||
|
||
|
||
Nvidia Source Code License-NC | ||
|
||
======================================================================= | ||
|
||
1. Definitions | ||
|
||
"Licensor" means any person or entity that distributes its Work. | ||
|
||
"Software" means the original work of authorship made available under | ||
this License. | ||
|
||
"Work" means the Software and any additions to or derivative works of | ||
the Software that are made available under this License. | ||
|
||
"Nvidia Processors" means any central processing unit (CPU), graphics | ||
processing unit (GPU), field-programmable gate array (FPGA), | ||
application-specific integrated circuit (ASIC) or any combination | ||
thereof designed, made, sold, or provided by Nvidia or its affiliates. | ||
|
||
The terms "reproduce," "reproduction," "derivative works," and | ||
"distribution" have the meaning as provided under U.S. copyright law; | ||
provided, however, that for the purposes of this License, derivative | ||
works shall not include works that remain separable from, or merely | ||
link (or bind by name) to the interfaces of, the Work. | ||
|
||
Works, including the Software, are "made available" under this License | ||
by including in or with the Work either (a) a copyright notice | ||
referencing the applicability of this License to the Work, or (b) a | ||
copy of this License. | ||
|
||
2. License Grants | ||
|
||
2.1 Copyright Grant. Subject to the terms and conditions of this | ||
License, each Licensor grants to you a perpetual, worldwide, | ||
non-exclusive, royalty-free, copyright license to reproduce, | ||
prepare derivative works of, publicly display, publicly perform, | ||
sublicense and distribute its Work and any resulting derivative | ||
works in any form. | ||
|
||
3. Limitations | ||
|
||
3.1 Redistribution. You may reproduce or distribute the Work only | ||
if (a) you do so under this License, (b) you include a complete | ||
copy of this License with your distribution, and (c) you retain | ||
without modification any copyright, patent, trademark, or | ||
attribution notices that are present in the Work. | ||
|
||
3.2 Derivative Works. You may specify that additional or different | ||
terms apply to the use, reproduction, and distribution of your | ||
derivative works of the Work ("Your Terms") only if (a) Your Terms | ||
provide that the use limitation in Section 3.3 applies to your | ||
derivative works, and (b) you identify the specific derivative | ||
works that are subject to Your Terms. Notwithstanding Your Terms, | ||
this License (including the redistribution requirements in Section | ||
3.1) will continue to apply to the Work itself. | ||
|
||
3.3 Use Limitation. The Work and any derivative works thereof only | ||
may be used or intended for use non-commercially. The Work or | ||
derivative works thereof may be used or intended for use by Nvidia | ||
or its affiliates commercially or non-commercially. As used herein, | ||
"non-commercially" means for research or evaluation purposes only. | ||
|
||
3.4 Patent Claims. If you bring or threaten to bring a patent claim | ||
against any Licensor (including any claim, cross-claim or | ||
counterclaim in a lawsuit) to enforce any patents that you allege | ||
are infringed by any Work, then your rights under this License from | ||
such Licensor (including the grants in Sections 2.1 and 2.2) will | ||
terminate immediately. | ||
|
||
3.5 Trademarks. This License does not grant any rights to use any | ||
Licensor's or its affiliates' names, logos, or trademarks, except | ||
as necessary to reproduce the notices described in this License. | ||
|
||
3.6 Termination. If you violate any term of this License, then your | ||
rights under this License (including the grants in Sections 2.1 and | ||
2.2) will terminate immediately. | ||
|
||
4. Disclaimer of Warranty. | ||
|
||
THE WORK IS PROVIDED "AS IS" WITHOUT WARRANTIES OR CONDITIONS OF ANY | ||
KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WARRANTIES OR CONDITIONS OF | ||
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE OR | ||
NON-INFRINGEMENT. YOU BEAR THE RISK OF UNDERTAKING ANY ACTIVITIES UNDER | ||
THIS LICENSE. | ||
|
||
5. Limitation of Liability. | ||
|
||
EXCEPT AS PROHIBITED BY APPLICABLE LAW, IN NO EVENT AND UNDER NO LEGAL | ||
THEORY, WHETHER IN TORT (INCLUDING NEGLIGENCE), CONTRACT, OR OTHERWISE | ||
SHALL ANY LICENSOR BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY DIRECT, | ||
INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING OUT OF | ||
OR RELATED TO THIS LICENSE, THE USE OR INABILITY TO USE THE WORK | ||
(INCLUDING BUT NOT LIMITED TO LOSS OF GOODWILL, BUSINESS INTERRUPTION, | ||
LOST PROFITS OR DATA, COMPUTER FAILURE OR MALFUNCTION, OR ANY OTHER | ||
COMMERCIAL DAMAGES OR LOSSES), EVEN IF THE LICENSOR HAS BEEN ADVISED OF | ||
THE POSSIBILITY OF SUCH DAMAGES. | ||
|
||
======================================================================= |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,221 @@ | ||
## StyleGAN2 — Official TensorFlow Implementation | ||
|
||
![Teaser image](./docs/stylegan2-teaser-1024x256.png) | ||
|
||
**Analyzing and Improving the Image Quality of StyleGAN**<br> | ||
Tero Karras, Samuli Laine, Miika Aittala, Janne Hellsten, Jaakko Lehtinen, Timo Aila<br> | ||
|
||
Paper: http://arxiv.org/abs/1912.04958<br> | ||
Video: https://youtu.be/c-NJtV9Jvp0<br> | ||
|
||
Abstract: *The style-based GAN architecture (StyleGAN) yields state-of-the-art results in data-driven unconditional generative image modeling. We expose and analyze several of its characteristic artifacts, and propose changes in both model architecture and training methods to address them. In particular, we redesign generator normalization, revisit progressive growing, and regularize the generator to encourage good conditioning in the mapping from latent vectors to images. In addition to improving image quality, this path length regularizer yields the additional benefit that the generator becomes significantly easier to invert. This makes it possible to reliably detect if an image is generated by a particular network. We furthermore visualize how well the generator utilizes its output resolution, and identify a capacity problem, motivating us to train larger models for additional quality improvements. Overall, our improved model redefines the state of the art in unconditional image modeling, both in terms of existing distribution quality metrics as well as perceived image quality.* | ||
|
||
For business inquiries, please contact [[email protected]](mailto:[email protected])<br> | ||
For press and other inquiries, please contact Hector Marinez at [[email protected]](mailto:[email protected])<br> | ||
|
||
| Additional material | | ||
| :--- | :---------- | ||
| [StyleGAN2](https://drive.google.com/open?id=1QHc-yF5C3DChRwSdZKcx1w6K8JvSxQi7) | Main Google Drive folder | ||
| ├ [stylegan2-paper.pdf](https://drive.google.com/open?id=1fnF-QsiQeKaxF-HbvFiGtzHF_Bf3CzJu) | High-quality version of the paper | ||
| ├ [stylegan2-video.mp4](https://drive.google.com/open?id=1f_gbKW6FUUHKkUxciJ_lQx29mCq_fSBy) | High-quality version of the video | ||
| ├ [images](https://drive.google.com/open?id=1Sak157_DLX84ytqHHqZaH_59HoEWzfB7) | Example images produced using our method | ||
| │ ├ [curated-images](https://drive.google.com/open?id=1ydWb8xCHzDKMTW9kQ7sL-B1R0zATHVHp) | Hand-picked images showcasing our results | ||
| │ └ [100k-generated-images](https://drive.google.com/open?id=1BA2OZ1GshdfFZGYZPob5QWOGBuJCdu5q) | Random images with and without truncation | ||
| ├ [videos](https://drive.google.com/open?id=1yXDV96SFXoUiZKU7AyE6DyKgDpIk4wUZ) | Individual clips of the video as high-quality MP4 | ||
| └ [networks](https://drive.google.com/open?id=1yanUI9m4b4PWzR0eurKNq6JR1Bbfbh6L) | Pre-trained networks | ||
|    ├ [stylegan2-ffhq-config-f.pkl](https://drive.google.com/open?id=1Mgh-jglZjgksupF0XLl0KzuOqd1LXcoE) | StyleGAN2 for <span style="font-variant:small-caps">FFHQ</span> dataset at 1024×1024 | ||
|    ├ [stylegan2-car-config-f.pkl](https://drive.google.com/open?id=1MutzVf8XjNo6TUg03a6CUU_2Vlc0ltbV) | StyleGAN2 for <span style="font-variant:small-caps">LSUN Car</span> dataset at 512×384 | ||
|    ├ [stylegan2-cat-config-f.pkl](https://drive.google.com/open?id=1MyowTZGvMDJCWuT7Yg2e_GnTLIzcSPCy) | StyleGAN2 for <span style="font-variant:small-caps">LSUN Cat</span> dataset at 256×256 | ||
|    ├ [stylegan2-church-config-f.pkl](https://drive.google.com/open?id=1N3iaujGpwa6vmKCqRSHcD6GZ2HVV8h1f) | StyleGAN2 for <span style="font-variant:small-caps">LSUN Church</span> dataset at 256×256 | ||
|    ├ [stylegan2-horse-config-f.pkl](https://drive.google.com/open?id=1N55ZtBhEyEbDn6uKBjCNAew1phD5ZAh-) | StyleGAN2 for <span style="font-variant:small-caps">LSUN Horse</span> dataset at 256×256 | ||
|    └ ⋯ | Other training configurations used in the paper | ||
|
||
## Requirements | ||
|
||
* Both Linux and Windows are supported. Linux is recommended for performance and compatibility reasons. | ||
* 64-bit Python 3.6 installation. We recommend Anaconda3 with numpy 1.14.3 or newer. | ||
* TensorFlow 1.15 with GPU support. The code does not support TensorFlow 2.0. | ||
* One or more high-end NVIDIA GPUs, NVIDIA drivers, CUDA 10.0 toolkit and cuDNN 7.5. To reproduce the results reported in the paper, you need an NVIDIA GPU with at least 16 GB of DRAM. | ||
* Docker users: use the [provided Dockerfile](./Dockerfile) to build an image with the required library dependencies. | ||
|
||
StyleGAN2 relies on custom TensorFlow ops that are compiled on the fly using [NVCC](https://docs.nvidia.com/cuda/cuda-compiler-driver-nvcc/index.html). To test that your NVCC installation is working correctly, run: | ||
|
||
```.bash | ||
nvcc test_nvcc.cu -o test_nvcc -run | ||
| test_nvcc.cu | ||
| Creating library test_nvcc.lib and object test_nvcc.exp | ||
| CPU says hello! | ||
| GPU says hello! | ||
``` | ||
|
||
On Windows, the compilation requires Microsoft Visual Studio to be in `PATH`. We recommend installing [Visual Studio Community Edition](https://visualstudio.microsoft.com/vs/) and adding into `PATH` using `"C:\Program Files (x86)\Microsoft Visual Studio\2019\Community\VC\Auxiliary\Build\vcvars64.bat"`. | ||
|
||
## Preparing datasets | ||
|
||
Datasets are stored as multi-resolution TFRecords, similar to the [original StyleGAN](https://github.com/NVlabs/stylegan). Each dataset consists of multiple `*.tfrecords` files stored under a common directory, e.g., `~/datasets/ffhq/ffhq-r*.tfrecords`. In the following sections, the datasets are referenced using a combination of `--dataset` and `--data-dir` arguments, e.g., `--dataset=ffhq --data-dir=~/datasets`. | ||
|
||
**FFHQ**. To download the [Flickr-Faces-HQ](https://github.com/NVlabs/ffhq-dataset) dataset as multi-resolution TFRecords, run: | ||
|
||
```.bash | ||
pushd ~ | ||
git clone https://github.com/NVlabs/ffhq-dataset.git | ||
cd ffhq-dataset | ||
python download_ffhq.py --tfrecords | ||
popd | ||
python dataset_tool.py display ~/ffhq-dataset/tfrecords/ffhq | ||
``` | ||
|
||
**LSUN**. Download the desired LSUN categories in LMDB format from the [LSUN project page](https://www.yf.io/p/lsun). To convert the data to multi-resolution TFRecords, run: | ||
|
||
```.bash | ||
python dataset_tool.py create_lsun_wide ~/datasets/car ~/lsun/car_lmdb --width=512 --height=384 | ||
python dataset_tool.py create_lsun ~/datasets/cat ~/lsun/cat_lmdb --resolution=256 | ||
python dataset_tool.py create_lsun ~/datasets/church ~/lsun/church_outdoor_train_lmdb --resolution=256 | ||
python dataset_tool.py create_lsun ~/datasets/horse ~/lsun/horse_lmdb --resolution=256 | ||
``` | ||
|
||
**Custom**. Create custom datasets by placing all training images under a single directory. The images must be square-shaped and they must all have the same power-of-two dimensions. To convert the images to multi-resolution TFRecords, run: | ||
|
||
```.bash | ||
python dataset_tool.py create_from_images ~/datasets/my-custom-dataset ~/my-custom-images | ||
python dataset_tool.py display ~/datasets/my-custom-dataset | ||
``` | ||
|
||
## Using pre-trained networks | ||
|
||
Pre-trained networks are stored as `*.pkl` files on the [StyleGAN2 Google Drive folder](https://drive.google.com/open?id=1QHc-yF5C3DChRwSdZKcx1w6K8JvSxQi7). Below, you can either reference them directly using the syntax `gdrive:networks/<filename>.pkl`, or download them manually and reference by filename. | ||
|
||
**Generating images**: | ||
|
||
```.bash | ||
# Generate uncurated ffhq images (matches paper Figure 12) | ||
python run_generator.py generate-images --network=gdrive:networks/stylegan2-ffhq-config-f.pkl \ | ||
--seeds=6600-6625 --truncation-psi=0.5 | ||
|
||
# Generate curated ffhq images (matches paper Figure 11) | ||
python run_generator.py generate-images --network=gdrive:networks/stylegan2-ffhq-config-f.pkl \ | ||
--seeds=66,230,389,1518 --truncation-psi=1.0 | ||
|
||
# Generate uncurated car images | ||
python run_generator.py generate-images --network=gdrive:networks/stylegan2-car-config-f.pkl \ | ||
--seeds=6000-6025 --truncation-psi=0.5 | ||
|
||
# Example of style mixing (matches the corresponding video clip) | ||
python run_generator.py style-mixing-example --network=gdrive:networks/stylegan2-ffhq-config-f.pkl \ | ||
--row-seeds=85,100,75,458,1500 --col-seeds=55,821,1789,293 --truncation-psi=1.0 | ||
``` | ||
|
||
The results are placed in `results/<RUNNING_ID>/*.png`. You can change the location with `--result-dir`. For example, `--result-dir=~/my-stylegan2-results`. | ||
|
||
**Projecting images to latent space**: | ||
|
||
```.bash | ||
# Project generated images | ||
python run_projector.py project-generated-images --network=gdrive:networks/stylegan2-car-config-f.pkl \ | ||
--seeds=0,1,5 | ||
|
||
# Project real images | ||
python run_projector.py project-real-images --network=gdrive:networks/stylegan2-car-config-f.pkl \ | ||
--dataset=car --data-dir=~/datasets | ||
``` | ||
|
||
You can import the networks in your own Python code using `pickle.load()`. For this to work, you need to include the `dnnlib` source directory in `PYTHONPATH` and create a default TensorFlow session by calling `dnnlib.tflib.init_tf()`. See [run_generator.py](./run_generator.py) and [pretrained_networks.py](./pretrained_networks.py) for examples. | ||
|
||
## Training networks | ||
|
||
To reproduce the training runs for config F in Tables 1 and 3, run: | ||
|
||
```.bash | ||
python run_training.py --num-gpus=8 --data-dir=~/datasets --config=config-f \ | ||
--dataset=ffhq --mirror-augment=true | ||
python run_training.py --num-gpus=8 --data-dir=~/datasets --config=config-f \ | ||
--dataset=car --total-kimg=57000 | ||
python run_training.py --num-gpus=8 --data-dir=~/datasets --config=config-f \ | ||
--dataset=cat --total-kimg=88000 | ||
python run_training.py --num-gpus=8 --data-dir=~/datasets --config=config-f \ | ||
--dataset=church --total-kimg 88000 --gamma=100 | ||
python run_training.py --num-gpus=8 --data-dir=~/datasets --config=config-f \ | ||
--dataset=horse --total-kimg 100000 --gamma=100 | ||
``` | ||
|
||
For other configurations, see `python run_training.py --help`. | ||
|
||
We have verified that the results match the paper when training with 1, 2, 4, or 8 GPUs. Note that training FFHQ at 1024×1024 resolution requires GPU(s) with at least 16 GB of memory. The following table lists typical training times using NVIDIA DGX-1 with 8 Tesla V100 GPUs: | ||
|
||
| Configuration | Resolution | Total kimg | 1 GPU | 2 GPUs | 4 GPUs | 8 GPUs | GPU mem | | ||
| :------------ | :-------------: | :--------: | :-----: | :-----: | :-----: | :----: | :-----: | | ||
| `config-f` | 1024×1024 | 25000 | 69d 23h | 36d 4h | 18d 14h | 9d 18h | 13.3 GB | | ||
| `config-f` | 1024×1024 | 10000 | 27d 23h | 14d 11h | 7d 10h | 3d 22h | 13.3 GB | | ||
| `config-e` | 1024×1024 | 25000 | 35d 11h | 18d 15h | 9d 15h | 5d 6h | 8.6 GB | | ||
| `config-e` | 1024×1024 | 10000 | 14d 4h | 7d 11h | 3d 20h | 2d 3h | 8.6 GB | | ||
| `config-f` | 256×256 | 25000 | 32d 13h | 16d 23h | 8d 21h | 4d 18h | 6.4 GB | | ||
| `config-f` | 256×256 | 10000 | 13d 0h | 6d 19h | 3d 13h | 1d 22h | 6.4 GB | | ||
|
||
Training curves for FFHQ config F (StyleGAN2) compared to original StyleGAN using 8 GPUs: | ||
|
||
![Training curves](./docs/stylegan2-training-curves.png) | ||
|
||
After training, the resulting networks can be used the same way as the official pre-trained networks: | ||
|
||
```.bash | ||
# Generate 1000 random images without truncation | ||
python run_generator.py generate-images --seeds=0-999 --truncation-psi=1.0 \ | ||
--network=results/00006-stylegan2-ffhq-8gpu-config-f/networks-final.pkl | ||
``` | ||
|
||
## Evaluation metrics | ||
|
||
To reproduce the numbers for config F in Tables 1 and 3, run: | ||
|
||
```.bash | ||
python run_metrics.py --data-dir=~/datasets --network=gdrive:networks/stylegan2-ffhq-config-f.pkl \ | ||
--metrics=fid50k,ppl_wend --dataset=ffhq --mirror-augment=true | ||
python run_metrics.py --data-dir=~/datasets --network=gdrive:networks/stylegan2-car-config-f.pkl \ | ||
--metrics=fid50k,ppl2_wend --dataset=car | ||
python run_metrics.py --data-dir=~/datasets --network=gdrive:networks/stylegan2-cat-config-f.pkl \ | ||
--metrics=fid50k,ppl2_wend --dataset=cat | ||
python run_metrics.py --data-dir=~/datasets --network=gdrive:networks/stylegan2-church-config-f.pkl \ | ||
--metrics=fid50k,ppl2_wend --dataset=church | ||
python run_metrics.py --data-dir=~/datasets --network=gdrive:networks/stylegan2-horse-config-f.pkl \ | ||
--metrics=fid50k,ppl2_wend --dataset=horse | ||
``` | ||
|
||
For other configurations, see the [StyleGAN2 Google Drive folder](https://drive.google.com/open?id=1QHc-yF5C3DChRwSdZKcx1w6K8JvSxQi7). | ||
|
||
Note the metrics are evaluated using a different random seed each time, so the results will vary between runs. In the paper, we reported the average result of running each metric 10 times. The following table lists the available metrics along with their expected runtimes and random variation: | ||
|
||
| Metric | FFHQ config F | 1 GPU | 2 GPUs | 4 GPUs | Description | | ||
| :---------- | :------------: | :----: | :-----: | :----: | :---------- | | ||
| `fid50k` | 2.84 ± 0.03 | 22 min | 14 min | 10 min | [Fréchet Inception Distance](https://arxiv.org/abs/1706.08500) | ||
| `is50k` | 5.13 ± 0.02 | 23 min | 14 min | 8 min | [Inception Score](https://arxiv.org/abs/1606.03498) | ||
| `ppl_zfull` | 348.0 ± 3.8 | 41 min | 22 min | 14 min | [Perceptual Path Length](https://arxiv.org/abs/1812.04948) in Z, full paths | ||
| `ppl_wfull` | 126.9 ± 0.2 | 42 min | 22 min | 13 min | [Perceptual Path Length](https://arxiv.org/abs/1812.04948) in W, full paths | ||
| `ppl_zend` | 348.6 ± 3.0 | 41 min | 22 min | 14 min | [Perceptual Path Length](https://arxiv.org/abs/1812.04948) in Z, path endpoints | ||
| `ppl_wend` | 129.4 ± 0.8 | 40 min | 23 min | 13 min | [Perceptual Path Length](https://arxiv.org/abs/1812.04948) in W, path endpoints | ||
| `ppl2_wend` | 145.0 ± 0.5 | 41 min | 23 min | 14 min | [Perceptual Path Length](https://arxiv.org/abs/1812.04948) without center crop | ||
| `ls` | 154.2 / 4.27 | 10 hrs | 6 hrs | 4 hrs | [Linear Separability](https://arxiv.org/abs/1812.04948) | ||
| `pr50k3` | 0.689 / 0.492 | 26 min | 17 min | 12 min | [Precision and Recall](https://arxiv.org/abs/1904.06991) | ||
|
||
Note that some of the metrics cache dataset-specific data on the disk, and they will take somewhat longer when run for the first time. | ||
|
||
## License | ||
|
||
Copyright © 2019, NVIDIA Corporation. All rights reserved. | ||
|
||
This work is made available under the Nvidia Source Code License-NC. To view a copy of this license, visit https://nvlabs.github.io/stylegan2/license.html | ||
|
||
## Citation | ||
|
||
``` | ||
@article{Karras2019stylegan2, | ||
title = {Analyzing and Improving the Image Quality of {StyleGAN}}, | ||
author = {Tero Karras and Samuli Laine and Miika Aittala and Janne Hellsten and Jaakko Lehtinen and Timo Aila}, | ||
journal = {CoRR}, | ||
volume = {abs/1912.04958}, | ||
year = {2019}, | ||
} | ||
``` | ||
|
||
## Acknowledgements | ||
|
||
We thank Ming-Yu Liu for an early review, Timo Viitanen for his help with code release, and Tero Kuosmanen for compute infrastructure. |
Oops, something went wrong.