Tensorflow implementation of Adversarial Autoencoders. Based on code from a really cool blog post as well as parts of InfoGAN
To train an AAE (or other models) with default parameters on the MNIST dataset:
$ python main.py --aae
$ python main.py --vae
$ python main.py --vaae
The different models effectively refer to different types of regularization of the posterior distribution. While in the classical Variational Autoencoder the posterior distribution of latent variables is pushed to match the prior distribution through minimization of the KL-divergence, in the Adversarial Autoencoder the posterior distribution is encouraged to match a target prior distribution through a discriminator/generator min/max game. Both regularizations can, however, be easily combined (=VAAE).
The above commands will download MNIST and store it in the driectory. Alternatively, you can also define a path variable to the directory with your already downloaded mnist directory:
$ export DATASETS=~/path/to/mnist/
$ python main.py --aae
The encoding of the test set over time:
The final encoding of the test set:
Exploration of the 2-dimensional latent space:
Mathias Schmerling