Our main goal was to generate some realistic new characters of Simposon using two types of neural networks the Variational Autoencoder (VAE) and the Generative Adversarial Network (GAN). We have done 3 test, one test with VAE and 2 test with GAN, each test with a different GAN structure. In the results part we can see the new generated faces.
- Download Simpson Dataset
- Resize images to 64x64, we have used
from PIL import Image
import os, sys
path = "/content/drive/My Drive/Deep_Learning_FP/simpson/"
dirs = os.listdir( path )
def resize():
for item in dirs:
if os.path.isfile(path+item):
print(path+item)
im = Image.open(path+item)
f, e = os.path.splitext(path+item)
imResize = im.resize((64,64), Image.ANTIALIAS)
imResize.save(f+'.png', 'png', quality=80)
resize()
- Execute the code to train the CNN or use the two ckpt files in the Results folder that contain the GAN1 and the VAE already trained. They can be used in the last part of the codes to visualize the results.
Using VAE the results obtained are very blurry, however we can see good results with very few epoches.
Using the first version of GAN we have obtained a better result in terms of resolution but we are able to see some artifacts due to the face variability. Better results could be achieve with more epoches.
Using the second version of GAN we have obtained the poorest results. It does not find an equilibration point and the results are not the desired.