Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/angeluriot/Generative_adversarial_network
A deep learning model that can create high quality images by training on a dataset.
https://github.com/angeluriot/Generative_adversarial_network
deep-learning gan generative-ai pytorch
Last synced: 3 months ago
JSON representation
A deep learning model that can create high quality images by training on a dataset.
- Host: GitHub
- URL: https://github.com/angeluriot/Generative_adversarial_network
- Owner: angeluriot
- License: mit
- Created: 2023-01-15T22:25:55.000Z (about 2 years ago)
- Default Branch: master
- Last Pushed: 2024-05-06T00:03:28.000Z (9 months ago)
- Last Synced: 2024-08-01T20:47:54.248Z (6 months ago)
- Topics: deep-learning, gan, generative-ai, pytorch
- Language: Python
- Homepage:
- Size: 720 MB
- Stars: 52
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# π¨ Generative Adversarial Network (GAN)
![Release](https://img.shields.io/badge/Release-v2.1-blueviolet)
![Language](https://img.shields.io/badge/Language-Python-f2cb1b)
![Libraries](https://img.shields.io/badge/Libraries-PyTorch-00cf2c)
![Size](https://img.shields.io/badge/Size-15Mo-f12222)
![Open Source](https://badges.frapsoft.com/os/v2/open-source.svg?v=103)
This project is a deep convolutional generative adversarial network that can create high quality images from a random seed like portraits, animals, drawings and more.
# π Summary
* **[π Summary](#-summary)**
* **[π€ Model](#-model)**
* [ποΈ Architecture](#%EF%B8%8F-architecture)
* [π§ͺ Tests](#-tests)
* [ποΈ Trained weights](#%EF%B8%8F-trained-weights)
* **[π¦ Dependencies](#-dependencies)**
* **[π¦Ύ Training](#-training)**
* **[βοΈ Testing](#%EF%B8%8F-testing)**
* **[π Credits](#-credits)**
# π€ Model
## ποΈ Architecture
The model is a Generative Adversarial Network (GAN) like described in the paper [**Generative Adversarial Nets**](https://doi.org/10.48550/arXiv.1406.2661) from **Montreal University** (2014)
The generator and the discriminator are both deep convolutional neural networks like in the paper [**Unsupervised Representation Learning with Deep Convolutional Generative Adversarial Networks**](https://doi.org/10.48550/arXiv.1511.06434) from **Facebook AI Research** (2015) but with a few improvements:
### For both networks:
* I added **Equalized Learning Rate Layers** from the paper [**Progressive Growing of GANs for Improved Quality, Stability, and Variation**](https://doi.org/10.48550/arXiv.1710.10196) by **Nvidia** (2017)
* I added **Bilinear Upsampling / Downsampling** from the paper [**Making Convolutional Networks Shift-Invariant Again**](https://doi.org/10.48550/arXiv.1904.11486) by **Adobe Research** (2019)
* I implemented **Wavelet Transform** from the paper [**SWAGAN: A Style-based Wavelet-driven Generative Model**](https://doi.org/10.48550/arXiv.2102.06108) by **Tel-Aviv University** (2021)
### For the generator:
* I used a **Style-Based Architecture** with a **Constant Input**, **Learned Styles** from a **Mapping Network** and **Noise Injection** from the paper [**A Style-Based Generator Architecture for Generative Adversarial Networks**](https://doi.org/10.48550/arXiv.1812.04948) by **Nvidia** (2018)
* I added **Skip Connections** from the paper [**MSG-GAN: Multi-Scale Gradients for Generative Adversarial Networks**](https://doi.org/10.48550/arXiv.1903.06048) by **TomTom** and **Adobe** (2019)
### For the discriminator:
* I added **Residual Blocks** from the paper [**Deep Residual Learning for Image Recognition**](https://doi.org/10.48550/arXiv.1512.03385) by **Microsoft Research** (2015)
* I added **Minibatch Standard Deviation** at the end of the discriminator from the paper [**Improved Techniques for Training GANs**](https://doi.org/10.48550/arXiv.1606.03498) by **OpenAI** (2016)
### For training:
* I kept the original **Non-Saturating Loss** from the paper [**Generative Adversarial Nets**](https://doi.org/10.48550/arXiv.1406.2661) by **Montreal University** (2014)
* I added **Path Length Regularization** on the generator from the paper [**Analyzing and Improving the Image Quality of StyleGAN**](https://doi.org/10.48550/arXiv.1912.04958) by **Nvidia** (2019)
* I added **Gradient Penalty Regularization** on the discriminator from the paper [**Improved Training of Wasserstein GANs**](https://doi.org/10.48550/arXiv.1704.00028) by **Google Brain** (2017)
* I added **Adaptive Discriminator Augmentation (ADA)** from the paper [**Training Generative Adversarial Networks with Limited Data**](https://doi.org/10.48550/arXiv.2006.06676) by **Nvidia** (2020) but the augmentation probability is not trained and has to be set manually *(and some augmentations are disabled because of a missing PyTorch implementation)*
### For testing:
* I added the computation of the **FrΓ©chet Inception Distance (FID)** during training from the paper [**GANs Trained by a Two Time-Scale Update Rule Converge to a Local Nash Equilibrium**](https://doi.org/10.48550/arXiv.1706.08500) by **University Linz** (2017) using the **pytorch-fid** module
* I added a **Projector** like in the paper [**Analyzing and Improving the Image Quality of StyleGAN**](https://doi.org/10.48550/arXiv.1912.04958) by **Nvidia** (2019)
## π§ͺ Tests
Human faces 256*256 (FID: 5.97)
Animal faces 256*256 (FID: 6.56)
Anime faces 256*256 (FID: 3.74)
Painting faces 256*256 (FID: 20.32)
## ποΈ Trained weights
The trained weights on multiple datasets are available on [**Google Drive**](https://drive.google.com/drive/folders/1m4Puqmb9OD8dcbgr7HStpT7QIFksJ8LR?usp=sharing), you just need to download the `.pt` files and put them in the `models` folder.
# π¦ Dependencies
* [**Python**](https://www.python.org/)
* [**PyTorch**](https://pytorch.org/)
* [**Matplotlib**](https://matplotlib.org/)
* [**Pillow**](https://pillow.readthedocs.io/)
* [**Scipy**](https://www.scipy.org/)
* [**PSUtil**](https://github.com/giampaolo/psutil)
* [**PyTorch FID**](https://github.com/mseitzer/pytorch-fid)
Run the following command to install the dependencies:
```shell
$ pip install -r requirements.txt
```
*(You may need to use a [**specific command**](https://pytorch.org/get-started/locally/) for PyTorch if you want to use CUDA)*
# π¦Ύ Training
* First, you need to find and download a dataset of images *(less than 5,000 may be too little and more than 150,000 is not necessary)*. You can find a lot of datasets on [**Kaggle**](https://www.kaggle.com/datasets) and the ones I used on [**my Google Drive**](https://drive.google.com/drive/u/1/folders/15nmil1s50AKEL4PvNPsZ1VSGC_jGGLGE).
* Then, in the `training/settings.py` file, specify the **path** to the dataset
* If you don't have an overpriced 24GB GPU like me, the default settings may not work for you. You can try to:
* Lower the **batch size** *(less stable and worse lower point)*
* Increase the **accumulation steps** *(fix previous problems but slower)*
* Lower the **min features** *(worse results)*
* Decrease the **image size*** Run the `training.ipynb` file *(you can stop the training at any time and resume it later thanks to the checkpoints)*
# βοΈ Testing
* Run the `testing.ipynb` file to generate random images
* Run the `testing/interpolation.ipynb` file to generate the images of a smooth interpolation video
* Run the `testing/projector.ipynb` file to project real images into the latent space
* Run the `testing/style_mixing.ipynb` file to generate the images of a style mixing interpolation video
* Run the `testing/timelapse.ipynb` file to generate the images of a training timelapse video
# π Credits
* [**Angel Uriot**](https://github.com/angeluriot) : Creator of the project.