09.05.2023 Views

pdfcoffee

You also want an ePaper? Increase the reach of your titles

YUMPU automatically turns print PDFs into web optimized ePapers that Google loves.

Generative Adversarial Networks

# If at save interval => save generated image samples

if epoch % save_interval == 0:

self.save_imgs(epoch)

Lastly, we need a helper function to save images:

def save_imgs(self, epoch):

r, c = 5, 5

noise = np.random.normal(0, 1, (r * c, self.latent_dim))

gen_imgs = self.generator.predict(noise)

# Rescale images 0 - 1

gen_imgs = 0.5 * gen_imgs + 0.5

fig, axs = plt.subplots(r, c)

cnt = 0

for i in range(r):

for j in range(c):

axs[i,j].imshow(gen_imgs[cnt, :,:,0], cmap='gray')

axs[i,j].axis('off')

cnt += 1

fig.savefig("images/dcgan_mnist_%d.png" % epoch)

plt.close()

Let us now train our GAN:

dcgan = DCGAN(28,28,1)

dcgan.train(epochs=4000, batch_size=32, save_interval=50)

The images generated by our GAN as it learned to fake handwritten digits are:

[ 206 ]

Hooray! Your file is uploaded and ready to be published.

Saved successfully!

Ooh no, something went wrong!