Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/deven96/simple_gan
Attempt at implementation of a simple GAN using Keras
https://github.com/deven96/simple_gan
Last synced: 3 days ago
JSON representation
Attempt at implementation of a simple GAN using Keras
- Host: GitHub
- URL: https://github.com/deven96/simple_gan
- Owner: deven96
- License: mit
- Created: 2018-12-20T01:20:28.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2019-08-21T01:05:54.000Z (over 5 years ago)
- Last Synced: 2025-02-15T11:56:37.482Z (5 days ago)
- Language: Python
- Homepage:
- Size: 19.1 MB
- Stars: 7
- Watchers: 3
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Simple GAN
This is my attempt to make a wrapper class for a GAN in keras which can be used to abstract the whole architecture process.
[data:image/s3,"s3://crabby-images/b334e/b334e48409e9b6f233f5be30875ee90ccc4e4302" alt="Build Status"](https://travis-ci.com/deven96/Simple_GAN)[data:image/s3,"s3://crabby-images/0a118/0a118e3ad397be15a0098b540156f919fb241f8d" alt="PyPI version"](https://badge.fury.io/py/Adversarials)data:image/s3,"s3://crabby-images/78f5d/78f5d5fd0d6c50abb9c8a2fb752f848dd55c9022" alt="Quality Gate"
- [Simple GAN](#simple-gan)
- [Overview](#overview)
- [Flow Chart](#flow-chart)
- [Installation](#installation)
- [Example](#example)
- [Documentation](#documentation)
- [Credits](#credits)
- [Contribution](#contribution)
- [License (MIT)](#license-mit)
- [Todo](#todo)## Overview
data:image/s3,"s3://crabby-images/7b41c/7b41c972caab50ac250ae1d0af1119255efdd249" alt="alt text"
## Flow Chart
Setting up a Generative Adversarial Network involves having a discriminator and a generator working in tandem, with the ultimate goal being that the generator can come up with samples that are indistinguishable from valid samples by the discriminator.
data:image/s3,"s3://crabby-images/7c734/7c73429d7dda7bab7792777e9fc29539c5c4958d" alt="alt text"
## Installation
```bash
pip install adversarials
```## Example
```python
import numpy as np
from keras.datasets import mnistfrom adversarials.core import Log
from adversarials import SimpleGANif __name__ == '__main__':
(X_train, _), (_, _) = mnist.load_data()# Rescale -1 to 1
X_train = (X_train.astype(np.float32) - 127.5) / 127.5
X_train = np.expand_dims(X_train, axis=3)Log.info('X_train.shape = {}'.format(X_train.shape))
gan = SimpleGAN(save_to_dir="./assets/images",
save_interval=20)
gan.train(X_train, epochs=40)
```## Documentation
[Github Pages](https://deven96.github.io/Simple_GAN)
## Credits
- [Understanding Generative Adversarial Networks](https://towardsdatascience.com/understanding-generative-adversarial-networks-4dafc963f2ef) - Noaki Shibuya
- [Github Keras Gan](https://github.com/osh/KerasGAN)
- [Simple gan](https://github.com/daymos/simple_keras_GAN/blob/master/gan.py)## Contribution
You are very welcome to modify and use them in your own projects.
Please keep a link to the [original repository](https://github.com/deven96/Simple_GAN). If you have made a fork with substantial modifications that you feel may be useful, then please [open a new issue on GitHub](https://github.com/deven96/Simple_GAN/issues) with a link and short description.
## License (MIT)
This project is opened under the [MIT 2.0 License](https://github.com/deven96/Simple_GAN/blob/master/LICENSE) which allows very broad use for both academic and commercial purposes.
A few of the images used for demonstration purposes may be under copyright. These images are included under the "fair usage" laws.
## Todo
- Add view training(discriminator and generator) simultaneously using tensorboard
- Provision for Parallel data processing and multithreading
- Saving models to Protobuff files
- Using TfGraphDef and other things that could speed up training and inference