GAN
Outline
- Generation by GAN
- Image Generation as Example
- Theory behind GAN
- Issues and Possible Solutions
- Conditional Generation
- Unsupervised Conditional Generation
- Relation to Reinforcement Learning
Basic Idea of GAN
data:image/s3,"s3://crabby-images/5bcd6/5bcd6efb5ef60cafa8bcfce388df0eddce3b889d" alt="Imgur"
data:image/s3,"s3://crabby-images/699db/699dbb63994da9ae7a2203e9f2e5e7b1228bb476" alt="Imgur"
step 1. Fix generator G, and update discrimniator D
data:image/s3,"s3://crabby-images/383f5/383f5d2bd68e5ebbcf5e7b5e6c9d3c5f29654af4" alt="Imgur"
step 2. Fix discriminator D, and update generator G
data:image/s3,"s3://crabby-images/4d9cb/4d9cbccca9f11085cf5aa623ae6c89b4b71767ae" alt="Imgur"
Algorithm
data:image/s3,"s3://crabby-images/bc0fe/bc0fef13ca6c5171a48f27f632b386b0093ac493" alt="Imgur"
(Variational) Auto-encoder
data:image/s3,"s3://crabby-images/bb060/bb0600d5ed9f7206ebe7712c01bbd23bd2c4be5f" alt="Imgur"
Auto-encoder v.s. GAN
data:image/s3,"s3://crabby-images/7c48f/7c48f29c5e7cc00b9afe1045469c14f6df744bf0" alt="Imgur"
GAN in Depth
Generator
- A generator G is a network. The network defines a probaility distribution PG.
data:image/s3,"s3://crabby-images/cac05/cac05835d672d9d745ccfa7cd4e3a01e12aaa343" alt="Imgur"
Discriminator
data:image/s3,"s3://crabby-images/6ef5f/6ef5fbed25fd780e8b6a230af65906b7c49a2ce2" alt="Imgur"
data:image/s3,"s3://crabby-images/9b499/9b499060dd7094e735620119b0472f6818b7fd56" alt="Imgur"
data:image/s3,"s3://crabby-images/b1b70/b1b70e37bb5fe3ae5e1f9b2205378bbcd247adec" alt="Imgur"
data:image/s3,"s3://crabby-images/a937a/a937a5c7b212543b20f976d01c53854e34ede742" alt="Imgur"
Can we use other divergence?
data:image/s3,"s3://crabby-images/18557/185573516a1def6fdbb8764c2177fff628378bbe" alt="Imgur"
Sebastian Nowozin, NIPS, 2016
Issues and Possible Solutions
How to Tain a GAN?
JS divergence is not suitable
data:image/s3,"s3://crabby-images/aa0d0/aa0d0aa65554baf2937ec5c4563fee195158ad0b" alt="Imgur"
What is the problem of JS divergence?
data:image/s3,"s3://crabby-images/ae902/ae902e45a2c369b38c107231dea57f7394df8e6f" alt="Imgur"
Wassertein distance
data:image/s3,"s3://crabby-images/eb5ae/eb5ae439d582f4822ee9b45e594c2048d617d1f0" alt="Imgur"
data:image/s3,"s3://crabby-images/03ae6/03ae627488800d402c5509826ffae85e1ac43ae2" alt="Imgur"
data:image/s3,"s3://crabby-images/4ae56/4ae56316c84281e7125ab06827782dac0a25b7de" alt="Imgur"
WGAN
data:image/s3,"s3://crabby-images/1a9eb/1a9eb11341e764400ade88d96b5c943ef48563ac" alt="Imgur"
data:image/s3,"s3://crabby-images/06cc2/06cc21f4326262b7a54b7b0a1449ce018262c6d7" alt="Imgur"
Tip: Improve Quality during Testing
data:image/s3,"s3://crabby-images/fb66a/fb66a0b40e7f6e5e9bbc6627fce5b0b38b1a548c" alt="Imgur"
Mode Collapse & Mode Dropping
- Mode collapse
data:image/s3,"s3://crabby-images/252dc/252dc0e1b332c51782bebf05d6bf032da0356a66" alt="Imgur"
- Mode Dropping
data:image/s3,"s3://crabby-images/89765/89765984667f2038342b2963f36c65f42afc502d" alt="Imgur"
Tip: Ensemble
data:image/s3,"s3://crabby-images/e48f3/e48f3197c5112c1d9bd5383e2f430d0a2dbcf719" alt="Imgur"
Objective Evalution
data:image/s3,"s3://crabby-images/5b24b/5b24b2e4da2b737482cc8b2d2567e6fcd8f81076" alt="Imgur"
data:image/s3,"s3://crabby-images/41871/418718f4dc55a61d4b3a69a4a48a7a7566404d36" alt="Imgur"