Skip to content

Latest commit

 

History

History
26 lines (26 loc) · 2.93 KB

README.md

File metadata and controls

26 lines (26 loc) · 2.93 KB

FCC-GAN - Pytorch

This is a very basic unofficial implementation of FCC-GAN in pytorch, only on the MNIST dataset. The Generator and Discriminator models are classes in generator_fcc.py and discriminator_fcc.py. Other than that the pretrained models itself and the state_dict are stored in Saved_Models folder.

As for implementation details there are few things which I have changed. Those changes and details include:

  1. I have trained the network for 15 epochs. This models learns about everything it has to in about 10 epochs.
  2. In the Generator network the dimensions weren't matching up. That's why I had to change it, still I tried to keep the number of layers exactly the same. Overall in Generator I only changed the last layer, where the kernel size was made 4 instead of 3 and a padding of 2 was added.
  3. Same issue occurs in Discriminator. So just like before I tried to keep the number of layers exactly the same. The only change which has been made is that I added padding of 1 in the last convolutional layer.
  4. Now the most important and major change is removing batchnorm from Discriminator. Now when batchnorm was added the output of Generator was pretty much garbage and even after 10 epochs the Generator hadn't learned anything. From the loss of both the networks I concluded that adding the batchnorm layer in Discriminator helps it converge a lot faster and thus its outputs from sigmoid are much closer to the edges(very close to 0 or 1) where the gradient is almost 0 essentially indicating that the generator won't be learning much and as the training goes on the superior position of Discriminator solidifies even more. Thus removing the batchnorm from Discriminator balances the networks and lets Generator learn meaningful information.
  5. Another major change is done in training process where instead of going with the classical loss function I have used the slightly tweaked one. You can find more details about it in dcgan tutorial of pytorch.
  6. I don't remember exactly if I used the weight initialization which was also taken from the dcgan tutorial of pytorch. Still that weight initialization doesn't have much effect but still if I had to say then the output with weight initialization seems slightely better but that variation also occurs between two different training runs.
  7. Regarding other hyperparameters, I have kept the learning rate at 0.0001, weight decay at 0.000001, Leaky-ReLU negative slope at 0.2 and batch size of 32. The weight decay originally was 0.00001.

  8. This implementation isn't perfect and can be improved in many aspects so suggestions are appreciated

    FCC-GAN: A Fully Connected and Convolutional Net Architecture for GANs by Sukarna Barua