/recurrence-and-attention-latent-variable-models

A first iteration attempt to implement the deep recurrent attentive writer (DRAW) ML model for generative modeling, and comparing this to a standard and ladder VAE.

Primary LanguageJupyter Notebook

Recurrence and Attention in Latent Variable Models

In recent years deep latent variable models have been widely used for image generation and representation learning. Standard approaches employ shallow inference models with restrictive mean-field assumptions. A way to increase inference expressivity is to define a hierarchy of latent variables in space and build structured approximations. Using this approach the size of the model grows linearly in the number of layers.

An orthogonal approach is to define hierarchies in time using a recurrent model. This approach exploits parameter sharing and gives us the possibility to define models with infinite depth (assuming a memory-efficient learning algorithm).

In this project, we study recurrent latent variable models for image generation. We focus on attentive models, i.e. models that use attention to decide where to focus on and what to update, refining their output with a sequential update. This is done by implementing the DRAW model, which is described in the DRAW paper, both with basic and filterbank attention. The performance of the implemented DRAW model is then compared to both a standard VAE and a LadderVAE implementation.

The project is carried out by Simon Amtoft Pedersen, and supervised by Giorgio Giannone.

Variational Autoencoder

Variational Autoencoders (VAEs) are a type of latent variable model that can be used for generative modelling. The VAEs consists of a decoder part and an encoder part, that is trained by optimizing the Evidence Lower Bound (ELBO). The generative model is given by and the samples are then drawn from the distribution by and , and reconstruction is drawn from . The objective is then to optimize where ELBO is given as .

Once the model is trained, it can generate new examples by sampling and then passing this sample through the decoder to generate a new example .

Ladder VAE

An extension of the standard VAE is the Ladder VAE, which adds sharing of information and parameters between the encoder and decoder by splitting the latent variables into L layers, such that the model can be described by:

A lot of the code for the Ladder VAE is taken from Wohlert semi-supervised pytorch project.

Deep Recurrent Attentive Writer

The Deep Recurrent Attentive Writer (DRAW) model is a VAE like model, trained with stochastic gradient descent, proposed in the original DRAW paper. The main difference is, that the DRAW model iteratively generates the final output instead of doing it in a single shot like a standard VAE. Additionally, the encoder and decoder uses recurrent networks instead of standard linear networks.

The Network

The model goes through T iterations, where we denote each time-step iteration by t. When using a diagonal Gaussian for the latent distribution, we have:

Samples are then drawn from the latent distribution , which we pass to the decoder, which outputs that is added to the canvas, , using the write operation. At each time-step, , we compute:

Data Generation

Generating images from the model is then done by iteratively picking latent samples from the prior distribution, and updating the canvas with the decoder:

Read and Write operations

Finally we have the read and write operations. These can be used both with and without attention.

In the version without attention, the entire input image is passed to the encoder for every time-step, and the decoder modifies the entire canvas at every step. The two operations are then given by

In oder to use attention when reading and writing, a two-dimensional attention form is used with an array of two-dimensional Gaussian filters. For an input of size A x B, the model generates five parameters from the output of the decoder, which is used to compute the grid center, stride and mean location of the filters:

From this, the horizontal and veritcal filterbank matrices is defined

Where and are normalisation constraints, such that

Finally, we define the read and write operations with the attention mechanism

Where is the N x N writing patch emitted by the decoder.

Results

The standard VAE, Ladder VAE and DRAW model with base attention have been trained on the standard torchvision MNIST dataset, which is transformed to be in binarized form. Below the final value of the ELBO, KL and Reconstruction metrics are reported for both the train, validation and test set. Additionally the loss plots for training and validation is shown, and finally some reconstruction and samples from the three different models are shown.

The three models are trained in the exact same manner, without using a lot of tricks to improve upon their results. For all models KL-annealing is used over the first 50 epochs. Additionally, every model uses learning rate decay that starts after 200 epochs and is around halved at the end of training. To check the model parameters used, inspect the config dict in the three different training files.

Loss Plots

alt text

Table Evaluations

Train ELBO KL Reconstruction
Standard VAE -121.88 25.96 95.92
Ladder VAE -123.75 25.18 98.57
DRAW Base Attention -84.04 25.81 58.22
Validation ELBO KL Reconstruction
Standard VAE -124.38 25.93 98.45
Ladder VAE -124.12 24.98 99.14
DRAW Base Attention -85.43 25.88 59.55
Test ELBO KL Reconstruction
Standard VAE -123.81 25.13 98.68
Ladder VAE -123.43 25.06 98.37
DRAW Base Attention -85.3 26.01 59.28

Samples and Reconstructions

alt text

Discussion

From the results it is clear that the implemented DRAW model performs better than the standard VAE. However, it is also seen that the Ladder VAE has kind of collapsed into the standard VAE, providing far worse results than in the original paper. This can be due to multiple things. First of all the model might not be exactly identical to the proposed model regarding the implementation itself and number and size of layers. Secondly, all the three models are trained in exactly the same manner, without using a lot of tricks to improve the training of the Ladder VAE, which was done in the paper.

Comment on DRAW with Filterbank Attention

The filterbank attention version of the DRAW model is somewhat of a work-in-progress. It seems to be implemented correctly using a batch size of one, but very slow computationally. Additionally when running only with a batch size of one, each epoch takes too long to make it feasible. In order to make this model able to work in practice one would have to optimize it for batch sizes larger than one and improve the computational speed.

Repo Structure

In this repo you will find the three different model classes in the models directory, and the necessary training loops for each model is found in the training directory. Additionally the attention, encoder and decoder, and other modules used in these models can be found in the layers directory.

In order to reproduce the results, first make sure you have torch installed and all the required packages specified in requirements.txt, it should then be fairly simple to run the training of each of the models by using the appropriate script: python run_vae.py or python run_lvae.py or python run_draw.py. In order to change any model or training parameters, simply change the config dict inside these scripts.

References

Diederik P. Kingma & Max Welling: An Introduction to Variational Autoencoders, arXiv:1906.02691

Carl Doersch: Tutorial on Variational Autoencoders, arXiv:1606.05908

Casper Kaae Sønderby, Tapani Raiko, Lars Maaløe, Søren Kaae Sønderby & Ole Winther, Ladder Variational Autoencoders, arXiv:1602.02282

Karol Gregor, Ivo Danihelka, Alex Graves, Danilo Jimenez Rezende & Daan Wierstra: DRAW A Recurrent Neural Network For Image Generation, arXiv:1502.04623