Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/reiinakano/gan-playground
GAN Playground - Experiment with Generative Adversarial Nets in your browser. An introduction to GANs.
https://github.com/reiinakano/gan-playground
deep-learning gan generative-adversarial-network machine-learning neural-network
Last synced: 4 days ago
JSON representation
GAN Playground - Experiment with Generative Adversarial Nets in your browser. An introduction to GANs.
- Host: GitHub
- URL: https://github.com/reiinakano/gan-playground
- Owner: reiinakano
- License: mit
- Created: 2017-09-30T18:58:24.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2017-11-05T02:51:26.000Z (about 7 years ago)
- Last Synced: 2025-01-08T16:19:02.144Z (12 days ago)
- Topics: deep-learning, gan, generative-adversarial-network, machine-learning, neural-network
- Language: TypeScript
- Homepage: https://reiinakano.github.io/gan-playground
- Size: 916 KB
- Stars: 345
- Watchers: 23
- Forks: 49
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Welcome to GAN Playground
Demo website: https://reiinakano.github.io/gan-playground
![demo_screen](demo_screen.jpg)
## FAQ
### What is this about?
GAN Playground lets you play around with Generative Adversarial Networks right in your browser. Currently, it contains three built-in datasets: MNIST, Fashion MNIST, and CIFAR-10.
GAN Playground provides you the ability to set your models' hyperparameters and build up your discriminator and generator layer-by-layer. You can observe the network learn in real time as the generator produces more and more realistic images, or more likely, gets stuck in failure modes such as mode collapse.
### What are Generative Adversarial Networks?
From Wikipedia, "Generative Adversarial Networks, or GANs, are a class of artifical intelligence algorithms used in unsupervised machine learning, implemented by a system of two neural networks contesting with each other in a zero-sum game framework. They were introduced by Ian Goodfellow et al. in 2014."
In my own words, GANs are composed of two neural networks, each one trying to outcompete the other. The **discriminator** tries to figure out whether a given image is real or synthetically generated by the other neural network. The **generator** attempts to output images that are indistinguishable from real ones in an attempt to fool the discriminator. The hope is that the generator learns enough to create realistic images that can *fool humans*. If you want more information, there are tons of great resources on the internet that give a good introduction to GANs. Here's the [original paper on GANs](https://arxiv.org/abs/1406.2661).
### Why did you make this?
My hope is that this project gives beginners a bit of exposure in training GANs with as little setup as possible. The easiest way to do this is through the browser, and with deeplearn.JS, it's now finally possible. In fact, when I started this project, I didn't have any experience with GANs, and my target audience was myself!
### How long should I wait / what's the best set of parameters to see realistic images?
To be honest, I'm not sure. GANs are notoriously hard to train, and even I haven't found the right set of parameters and layers for this demo that'd produce very realistic images. It's either that or I haven't waited long enough for it to train... Either way, if you *do* find a good set of parameters and layers, please [file an issue](https://github.com/reiinakano/gan-playground/issues) or [submit a pull request](https://github.com/reiinakano/gan-playground/pulls), and I'll add it to this demo.
### This looks like the deeplearn.JS Model Builder demo.
Yup, this is pretty much [deeplearn.JS's Model Builder demo](http://deeplearnjs.org/demos/model-builder/) repurposed for training GANs! I just ripped out the parts I didn't need and replaced it with the parts I do need.
## Development
To run this locally, clone the project and prepare the development environment:
```bash
$ git clone https://github.com/reiinakano/gan-playground.git
$ cd gan-playground
$ npm install && bower install # Install node modules and bower components
```To interactively develop the application
```bash
$ ./scripts/watch-demo src/gan-playground.ts
>> Waiting for initial compile...
>> 1023189 bytes written to src/bundle.js (0.71 seconds) at 2:20:06 AM
>> Starting up http-server, serving ./
>> Available on:
>> http://127.0.0.1:8080
>> Hit CTRL-C to stop the server
```