Generative Adversarial Network (GAN) for abstract artwork generation

Date:

This python machine-learning script involves two ‘competing’ algorithms: the generator and the discriminator. The discriminator is trained on an image dataset with the goal of determining an ‘authentic’ image from a ‘generated’ image. The generator is an algorithm that produces images which are then fed into the discriminator to determine if the image is sufficiently realistic, subsequently adjusting its weights based on the discriminator’s feedback. Eventually, the generator will reach steady-state, the point at which the generator is either no longer improving or the discriminator can no longer differentiate between the training set, or ‘authentic,’ images and the generator’s ‘generated’ images. The generator can then be used to create realistic images that are similar to the training dataset images. I trained my model on approximately 16,000 abstract artwork images from online databases and achieved pretty good results for the relatively small dataset and lack of powerful computational servers (I used my laptop to train the model and because of my limited GPU was restricted to training on 64x64 pixel images). An interesting next step would be to gather larger datasets and to use a more powerful online server to create higher-definition images.

Github Repository

Samples of generated images: