Skip to content

Using conditional variational autoencoders to manipulate the images

License

Notifications You must be signed in to change notification settings

Darth-Kronos/Image-manipulation-CVAE

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Image-manipulation-CVAE

Conditional variational autoencoder (CVAE) is an extension of VAE developed in the field of Neural machine translation. A blog on CVAE: https://ijdykeman.github.io/ml/2016/12/21/cvae.html

Dataset

CelebA dataset contains more than 200K celebrity images, each with 40 binary face attributes annotations (like Male, Smiling, eye glasses etc.). Each image has its own face attributes annotation, encoded as a 40-dimensional binary vector: 0 means that the image does not show the corresponding attribute, and 1 means that it does. The database can be downloaded using in-built functions in PyTorch/TensorFlow or can be downloaded from : https://mmlab.ie.cuhk.edu.hk/projects/CelebA.html (Download only AlignedCropped Images and Attributes Annotations). Place img_align_celeb.zip inside data directory.

Image manipulation

  • After training the model, select the attribute you want to modify and change the attribute list
  • Encode the images using the pre-trained model encoder and store the resulting mean vectors
  • Specify the desired new attributes changing the original labels
  • Decode the mean vectors, combined with the new attribute labels, using the pre-trained model decoder

Results

Original image

Non-smiling images to smiling

Non-mustached to Mustached

Non-glass wearing to Glass wearing

(Note: Quality of the output images can be further improved by training a more complex CVAE)

About

Using conditional variational autoencoders to manipulate the images

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published