Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Save more on your purchases! discount-offer-chevron-icon
Savings automatically calculated. No voucher code required.
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Free Learning
Arrow right icon
Arrow up icon
GO TO TOP
Hands-On Image Generation with TensorFlow

You're reading from   Hands-On Image Generation with TensorFlow A practical guide to generating images and videos using deep learning

Arrow left icon
Product type Paperback
Published in Dec 2020
Publisher Packt
ISBN-13 9781838826789
Length 306 pages
Edition 1st Edition
Languages
Arrow right icon
Author (1):
Arrow left icon
Soon Yau Cheong Soon Yau Cheong
Author Profile Icon Soon Yau Cheong
Soon Yau Cheong
Arrow right icon
View More author details
Toc

Table of Contents (15) Chapters Close

Preface 1. Section 1: Fundamentals of Image Generation with TensorFlow
2. Chapter 1: Getting Started with Image Generation Using TensorFlow FREE CHAPTER 3. Chapter 2: Variational Autoencoder 4. Chapter 3: Generative Adversarial Network 5. Section 2: Applications of Deep Generative Models
6. Chapter 4: Image-to-Image Translation 7. Chapter 5: Style Transfer 8. Chapter 6: AI Painter 9. Section 3: Advanced Deep Generative Techniques
10. Chapter 7: High Fidelity Face Generation 11. Chapter 8: Self-Attention for Image Generation 12. Chapter 9: Video Synthesis 13. Chapter 10: Road Ahead 14. Other Books You May Enjoy

Swapping faces

Here comes the last step of the deepfake pipeline, but let's first recap the pipeline. The deepfake production pipeline involves three main stages:

  1. Extract a face from an image using dlib and OpenCV.
  2. Translate the face using the trained encoder and decoders.
  3. Swap the new face back into the original image.

The new face generated by the autoencoder is an aligned face of size 64×64, so we will need to warp it to the position, size, and angle of the face in the original image. We'll use the affine matrix obtained from step 1 in the face extraction stage. We'll use cv2.warpAffine like before, but this time, the cv2.WARP_INVERSE_MAP flag is used to reverse the direction of image transformation as follows:

h, w, _ = image.shape
size = 64
new_image = np.zeros_like(image, dtype=np.uint8)
new_image = cv2.warpAffine(np.array(new_face, 						   dtype=np.uint8)
           ...
lock icon The rest of the chapter is locked
Register for a free Packt account to unlock a world of extra content!
A free Packt account unlocks extra newsletters, articles, discounted offers, and much more. Start advancing your knowledge today.
Unlock this book and the full library FREE for 7 days
Get unlimited access to 7000+ expert-authored eBooks and videos courses covering every tech area you can think of
Renews at $19.99/month. Cancel anytime
Banner background image