Generating new data with VAEs
hamish - 29/05/2020
data:image/s3,"s3://crabby-images/960cd/960cd0fdea4cbc4d6df8141237232f0125b871e7" alt=""
- bit like the "identity function" of NNs
- aim is to learn the input via a small "bottleneck"
- break this task up into an "encoder" and "decoder"
Autowhat now?
(Autoencoder)
data:image/s3,"s3://crabby-images/92b6a/92b6a9b2382dc61f725aec5de487b403de605d97" alt=""
data:image/s3,"s3://crabby-images/01938/01938ca7ae2317f2a49c9cb0a9d82adc790baf04" alt=""
encoder
decoder
"bottleneck"
Latent Space
data:image/s3,"s3://crabby-images/960cd/960cd0fdea4cbc4d6df8141237232f0125b871e7" alt=""
data:image/s3,"s3://crabby-images/f19bc/f19bcded050d943ca379079ae94cf86aac850771" alt=""
???
Can we force the latent space to be more consistent?
data:image/s3,"s3://crabby-images/53eda/53eda184bc220f5201a2c0b7430ba18bdc61918c" alt=""
Add noise before bottleneck
data:image/s3,"s3://crabby-images/7ff18/7ff1844d268ac9a7b2f04b0b5b40288090fdc4e0" alt=""
- forces VAE to compensate for noise
- does this by learning to place similar things close to one another
- different things far apart
- more consistent space
How does this work?
data:image/s3,"s3://crabby-images/4b31f/4b31f03edffb0db3f6551bd146d9227df48ab75b" alt=""
"8 direction"
data:image/s3,"s3://crabby-images/f19bc/f19bcded050d943ca379079ae94cf86aac850771" alt=""
most 8s are over here
"Shift" in a direction
- find direction of feature we like
- use encoder to find position of image in latent space
- move in feature direction
- decode from that point
Downside: Implementing this is surprisingly hard, even with the code
data:image/s3,"s3://crabby-images/397dc/397dceecfa418cc17cbbfb4c65cf241bc4bcd9b6" alt=""
data:image/s3,"s3://crabby-images/872c2/872c222b4557e12c6d3e488bd208dd095d98dbb0" alt=""
data:image/s3,"s3://crabby-images/fb45e/fb45e64f9f5092369b5e4200520a5ee30c472159" alt=""
data:image/s3,"s3://crabby-images/81c32/81c3257db167999f2bd7f283c0338e856ae9bb9b" alt=""
data:image/s3,"s3://crabby-images/7c58a/7c58aa10c6ab033db0f9082957ad4bf09da1fa86" alt=""
data:image/s3,"s3://crabby-images/14ef5/14ef5ca22cc6e0ba6082c82ca748979210bffe5d" alt=""
data:image/s3,"s3://crabby-images/583d8/583d815125bd8ecee9119cf2c871b2f530741ccc" alt=""
data:image/s3,"s3://crabby-images/80049/80049653b547ae206be342afb63fb3ae6ae50b40" alt=""
Sunglasses
Black hair
Female
So why do we care?
- We (CIA) want to be able to provide actions so people can lower their energy use
- Would like to be able to "simulate" scenarios like if user got an EV
data:image/s3,"s3://crabby-images/f0b1c/f0b1cb2051657ff3375ddb3ffac611411a2e30c2" alt=""
Shift in "EV direction"
data:image/s3,"s3://crabby-images/9f026/9f026855922345f282ea87746f547646df8af93c" alt=""
learnt people charge their EVs overnight
- not really learnt the peaks you get with EVs
- causes issues with standby
- lose strong signal from other devices
David Ha https://worldmodels.github.io/
Generating new data with VAEs
By Hamish dickson
Generating new data with VAEs
- 262