<!DOCTYPE html>
<html lang="en-us">

  <head>
  <link href="http://gmpg.org/xfn/11" rel="profile">
  <meta http-equiv="content-type" content="text/html; charset=utf-8">

  <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1">

  <title>
    
      GAN2Shape - Create 3D Shape with 2D GANs &middot; The ICLR Blog Track
    
  </title>

  
  <link rel="canonical" href="https://iclr.iro.umontreal.ca/0a0d7c4d-a3e2-413f-b9da-d9e5b06d97c0_1642139457/2022/01/13/gan2shape/">
  

  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/0a0d7c4d-a3e2-413f-b9da-d9e5b06d97c0_1642139457/public/css/poole.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/0a0d7c4d-a3e2-413f-b9da-d9e5b06d97c0_1642139457/public/css/syntax.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/0a0d7c4d-a3e2-413f-b9da-d9e5b06d97c0_1642139457/public/css/lanyon.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/0a0d7c4d-a3e2-413f-b9da-d9e5b06d97c0_1642139457/public/css/custom.css">
  <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=PT+Serif:400,400italic,700%7CPT+Sans:400">

  <link rel="apple-touch-icon-precomposed" sizes="144x144" href="https://iclr.iro.umontreal.ca/0a0d7c4d-a3e2-413f-b9da-d9e5b06d97c0_1642139457/public/apple-touch-icon-precomposed.png">
  <link rel="shortcut icon" href="https://iclr.iro.umontreal.ca/0a0d7c4d-a3e2-413f-b9da-d9e5b06d97c0_1642139457/public/favicon.ico">

  <link rel="alternate" type="application/rss+xml" title="RSS" href="https://iclr.iro.umontreal.ca/0a0d7c4d-a3e2-413f-b9da-d9e5b06d97c0_1642139457/atom.xml">

  

  <script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.1/MathJax.js?config=TeX-AMS-MML_HTMLorMML" type="text/javascript" ></script>
 <!-- <script type="text/x-mathjax-config"> MathJax.Hub.Config({ TeX: { equationNumbers: { autoNumber: "AMS" } } }); </script> -->
  <script type="text/x-mathjax-config">
      MathJax.Hub.Config({
        tex2jax: { inlineMath: [ ['$','$'], ["\\(","\\)"] ],
         processEscapes: false
        }
      });
</script>
</head>


  <body>

    <!-- Target for toggling the sidebar `.sidebar-checkbox` is for regular
     styles, `#sidebar-checkbox` for behavior. -->
<input type="checkbox" class="sidebar-checkbox" id="sidebar-checkbox">
<!-- <input type="checkbox" class="sidebar-checkbox" id="sidebar-checkbox" > -->

<!-- Toggleable sidebar -->
<div class="sidebar" id="sidebar">
  <div class="sidebar-item">
    <p>For short-term, peer-sourced tests of time, generalizations, specializations, reproductions, etc.!</p>
  </div>

  <nav class="sidebar-nav">

    

    
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/0a0d7c4d-a3e2-413f-b9da-d9e5b06d97c0_1642139457/">ICLR 2022 Blog Track</a>
        
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/0a0d7c4d-a3e2-413f-b9da-d9e5b06d97c0_1642139457/about/">About</a>
        
      
    
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/0a0d7c4d-a3e2-413f-b9da-d9e5b06d97c0_1642139457/submitting/">Submitting</a>
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/0a0d7c4d-a3e2-413f-b9da-d9e5b06d97c0_1642139457/tags/">Tags</a>
        
      
    

    <a class="sidebar-nav-item" href="https://github.com/iclr-blog-track/iclr-blog-track.github.io">GitHub project</a>
    <span class="sidebar-nav-item">Currently vICLR Spring 2021</span>
  </nav>

  <div class="sidebar-item">
    <p>
      &copy; 2022. All rights reserved.
    </p>
  </div>
</div>


    <!-- Wrap is the content to shift when toggling the sidebar. We wrap the
         content to avoid any CSS collisions with our real content. -->
    <div class="wrap">
      <div class="masthead">
        <div class="container">
          <h3 class="masthead-title">
            <a href="/" title="Home">The ICLR Blog Track</a>
            <small></small>
          </h3>
        </div>
      </div>

      <div class="container content">
        <div class="post">
  <h1 id="iclr-post-title" class="post-title">GAN2Shape - Create 3D Shape with 2D GANs</h1>
  <span class="post-date">13 Jan 2022 | 
    <a class="content-tag" href="/tags/#3d"> 3D, </a>
  
    <a class="content-tag" href="/tags/#deep"> deep </a>
  
    <a class="content-tag" href="/tags/#learning"> learning, </a>
  
    <a class="content-tag" href="/tags/#gans"> GANs </a>
  </span>

  <span id="iclr-post-authors" class="post-date">author 1; author 2</span>
  <p>In this blog post, we will discuss the key points of the paper “<a href="https://arxiv.org/abs/2011.00844">Do 2D GANs Know 3D Shape? Unsupervised 3D Shape Reconstruction from 2D Image GANs</a>” (GAN2Shape) by Pan et al. We will discuss both the theory and code (in the author’s <a href="https://github.com/XingangPan/GAN2Shape">GitHub repository</a> and use a demo Colab notebook to show how GAN2Shape is able to transform 2D images to 3D images in multiple view images format.</p>

<p>The GAN2Shape paper presents the first attempt to directly mine 3D geometric cues from GANs trained on 2D RGB images. The technique can be used in very interesting real world scenarios such as image editing of relighting and object rotation after reconstructing 3D shapes from 2D images.</p>

<p>The previous attempts of 3D reconstruction using GANs have a number of limitations such as requiring 2D keypoint or 3D annotations, heavy memory consumption because of reliance on explicitly modeling 3D representation and rendering during training, lower 3D image generation quality than 2D counterparts, or assumptions such as object shapes are symmetric.</p>

<p>The GAN2Shape paper was the first attempt to reconstruct the 3D object shapes using GANs pretrained on 2D images only, without relying on the symmetry assumption of object shapes.
It’s able to generate highly photo-realistic 3D-aware image manipulations: rotation and relighting without using external 3D models.</p>
<h2 id="relevant-topics">Relevant Topics</h2>
<p>Before diving into the tutorial of the GAN2Shape paper, let’s first briefly review a few of the relevant concepts in case you are unfamiliar with them: 3D deep learning, GANs,StyleGAN2 and Unsup3D.</p>

<h3 id="3d-deep-learning">3D Deep Learning</h3>
<p>Using deep learning models to analyze or synthesize 3D data is an interesting area and can have a wide range of applications: such as 3D art, self-driving cars, virtual reality and augmented reality.</p>

<p>If you are new to this topic, watch the <a href="https://youtu.be/vfL6uJYFrp4">3D Deep Learning Tutorial</a> by SU Lab at UCSD for a great overview, which is briefly summarized below.</p>

<p>Regular images are typically represented in 1D or 2D arrays while 3D images, on the other hand, can have different representation formats:</p>

<ul>
  <li>Multi-view images which can be captured by positioning multiple cameras that take photos from different angles of the same object or scene.</li>
  <li>Volumetric display that is made of voxels, the equivalent of pixels in 2D images.</li>
  <li>Point-cloud which consists of a set of points collected from raw sensors.</li>
  <li>Mesh which consists of a set of points and the relationship of these points.</li>
</ul>

<p>The common 3D deep learning tasks include image classification, which is  a well solved problem in both 2D and 3D; 3D object detection, segmentation and reconstruction where using GAN for 3D reconstruction is one of the options.</p>

<p>There are different options for 3D image reconstruction: from single-view or from multi views. This GAN2Shape paper which we are discussing in this blog post, reconstructs 3D shape from a single view image leveraging the power of GANs.</p>

<h3 id="gans">GANs</h3>
<p>Generative Adversarial Neural Networks (GANs) are a type of generative models that can be used for image synthesis among many other tasks such as super resolution and image colorization etc. There are two networks in a GAN: a generator and a discriminator. We input random noise to the generator which generates images that resemble the training images and the discriminator tries to distinguish between the generated fake images and the real (training) images. The generator improves the image quality with the feedback from the discriminator.</p>

<p>There have been many GAN variants since 2014 and these variants aim to either improve the GAN training stability and or the quality of the generated images.</p>

<h3 id="stylegan2">StyleGAN2</h3>
<p>StyleGAN2 <a href="https://arxiv.org/abs/1912.04958">Karras et al.</a> introduced an improved GAN architecture that makes use of a style- based generator. This new generator firstly maps the input latent code to an intermediate latent space, which is then added to the generator for adjusting the “style” of the generated image. These modifications enable the generator to distinguish between various high level attributes from the low level ones, thus improving the interpolation properties as well the overall image quality.</p>

<p>StyleGAN2 architecture also facilitates GAN inversion, ie. projecting an image into the latent space, and can be converted  back to the original sample with minimum reconstruction loss. This conversion and reconstruction process reveals the underlying mechanism of the generator which allows us to manipulate the attributes of the original image. This paper <a href="https://arxiv.org/abs/2101.05278">GAN Inversion: A Survey</a> provides a good analysis of how GAN inversion works and its applications. GAN2Shape makes use of a pretrained StyleGAN2 generator for GAN inversion and discriminator for computing reconstruction loss.</p>

<h3 id="unsup3d">Unsup3D</h3>
<p>Unsup3D is an unsupervised 3D reconstruction model proposed by <a href="https://openaccess.thecvf.com/content_CVPR_2020/papers/Wu_Unsupervised_Learning_of_Probably_Symmetric_Deformable_3D_Objects_From_Images_CVPR_2020_paper.pdf">Shangzhe Wu et al.</a> in CVPR 2020 (Best Paper Award). It uses four individual autoencoder networks to decompose a single 2D image based on factors of view, lighting, depth and albedo, assuming they are symmetric. GAN2Shape adopts Unsup3D architecture and improves upon it  by making use of StyleGAN2 hich we will discuss in more detail below.</p>

<h2 id="how-gan2shape-works">How GAN2Shape Works</h2>
<p>Now that you have the background info on 3D deep learning and GAN variants related to the GAN2Shape paper, let’s take a look at how GAN2Shape works.</p>

<p>The complex architecture and training of GAN2Shape can be broken down into three steps and we will be explaining the theory behind each of them. In addition, we will walk through its code implementation and add links to all the important modules and functions from the official <a href="https://github.com/XingangPan/GAN2Shape">GAN2Shape GitHub repository</a>.</p>

<h3 id="step-1-creating-pseudo-samples">Step 1: Creating Pseudo Samples</h3>
<p>The first step in the GAN2Shape model architecture is the generation of pseudo samples. In this step, an input 2D image is passed onto 4 networks: view (V), light (L), depth (D) and albedo (A), and using the outputs of each of these networks we reconstruct a set of 2D images with different viewpoints and lighting conditions, which are referred to as pseudo samples. This method to recover 3D shape from a single view 2D image was introduced in Unsup3D by <a href="https://openaccess.thecvf.com/content_CVPR_2020/papers/Wu_Unsupervised_Learning_of_Probably_Symmetric_Deformable_3D_Objects_From_Images_CVPR_2020_paper.pdf">Shangzhe Wu et al.</a> as mentioned above.</p>

<p align="center">
  <img src="/public/images/2022-01-13-gan2shape/1-step1.png" alt="Step 1" style="width:40%" />
  <span><small><i><b>Step 1</b>: Four networks V, L, D and A initialized with a convex shape prior for generating a set of pseudo samples.</i></small></span>
</p>

<p>This problem of decomposing a 2D image to the four above-mentioned factors is an ill-posed one and hence we have to make an assumption inorder to solve it. So one thing we assume is that all objects including faces and cars have a convex shape prior, which provides a hint on initial viewpoint and lighting conditions.</p>

<p>To implement this firstly the depth map is initialized with an ellipsoid shape. The function that predicts depth, albedo, viewpoint, lighting are implemented using individual neural networks:
The depth and albedo are generated by encoder-decoder networks. 
The viewpoint and lighting are measured using simple encoder networks.</p>

<p>In step 1 we only train the Albedo network, to optimize it we reconstruct the original input image from these four factors via a rendering process and then a reconstruction loss is also calculated by taking a weighted combination of L1 loss and Perceptual loss, introduced by <a href="https://cs.stanford.edu/people/jcjohns/papers/eccv16/JohnsonECCV16.pdf">Johnson et al</a>.</p>

<p>To create pseudo samples, we randomly sample different lighting directions and viewpoints along with the depth and albedo network outputs we have obtained. If our input is a 2D image of a face, the pseudo samples will contain a set of images that indicates how the lighting changes when the face is rotated at different angles.</p>

<p><strong>Code</strong></p>

<p>The <a href="https://github.com/XingangPan/GAN2Shape/blob/deb9ac081d4f9243361a66befa7b9cfdb670d88c/gan2shape/networks.py#L90"><code class="language-plaintext highlighter-rouge">Encoder</code></a> class defines the architecture for the View and Light networks and the <a href="https://github.com/XingangPan/GAN2Shape/blob/deb9ac081d4f9243361a66befa7b9cfdb670d88c/gan2shape/networks.py#L12"><code class="language-plaintext highlighter-rouge">EDDeconv</code></a> class for the Albedo and Depth networks. All the processes discussed in this step are executed inside the <a href="https://github.com/XingangPan/GAN2Shape/blob/deb9ac081d4f9243361a66befa7b9cfdb670d88c/gan2shape/model.py#L462"><code class="language-plaintext highlighter-rouge">forward_step1</code></a> function. Firstly the input image is passed onto the four networks for calculating the respective factors, and then using a <a href="https://github.com/hiroharu-kato/neural_renderer">Neural 3D Mesh Renderer</a> defined in the <a href="https://github.com/XingangPan/GAN2Shape/blob/deb9ac081d4f9243361a66befa7b9cfdb670d88c/gan2shape/renderer/renderer.py#L13"><code class="language-plaintext highlighter-rouge">Renderer</code></a> class, the original input is reconstructed. Then to calculate L1 loss, the <a href="https://github.com/XingangPan/GAN2Shape/blob/deb9ac081d4f9243361a66befa7b9cfdb670d88c/gan2shape/utils.py#L105"><code class="language-plaintext highlighter-rouge">photometric_loss</code></a> function is called and the <a href="https://github.com/XingangPan/GAN2Shape/blob/deb9ac081d4f9243361a66befa7b9cfdb670d88c/gan2shape/stylegan2/stylegan2-pytorch/lpips/__init__.py#L12"><code class="language-plaintext highlighter-rouge">PerceptualLoss</code></a> class for calculating perceptual loss.</p>

<h3 id="step-2-obtain-projected-samples">Step 2: Obtain Projected Samples</h3>
<p>The pseudo samples we have at this point are useful images showing different viewpoints of the image and indicate how the change in light affects the image but at the same time it consists of unnatural shadows, distortions, so our next step is to transform them into photorealistic images.</p>

<p>This is where StyleGAN2 comes into picture. In step 2, we use a pretrained StyleGAN2 generator for GAN inversion and a pretrained StyleGAN2 discriminator for calculating the reconstruction loss in order to optimize the encoder network.</p>

<p align="center">
  <img src="/public/images/2022-01-13-gan2shape/2-step2.png" alt="Step 2" style="width:45%" />
  <span><small><i><b>Step 2</b>: Conversion of Pseudo samples to Projected samples using GAN Inversion. An Encoder and a StyleGAN2 Generator is used for GAN inversion and a Discriminator network for calculating loss to optimize the encoder network.</i></small></span>
</p>

<p>We perform GAN inversion to these pseudo samples and convert each sample into a latent vector using a standard ResNet encoder. These latent vectors are then projected back to their original space using the StyleGAN2 generator. This way we project the pseudo samples into a GAN image manifold making them more photorealistic, and these new samples are termed as projected samples.</p>

<p>While performing GAN inversion the latent vectors obtained for the pseudo samples are added to the latent representation of the original input.This way we can make the generated images look much more realistic without actually changing other features such as face orientation and shading.</p>

<p>To measure the difference between the generated projected samples and the input pseudo samples, we make use of a discriminator network similar to the one in StyleGAN2 architecture.  Both generated and original set of images are passed through the discriminator and the distance between the obtained features along with a regularization term is used as the reconstruction loss for this step. This method was proposed by <a href="https://arxiv.org/abs/2003.13659v2">Pan et al</a>. The reconstruction loss further ensures that these generated samples will not have different lighting conditions and viewpoints compared to the pseudo samples.</p>

<p>$ \theta_{E} = arg_{\theta_{E}}min \frac{1}{m} \sum_{i=0}^m L’(I_{i},G(E(I_{i}) + w)) + \lambda ||E(I_{i})||_{2} $</p>

<p>The reconstruction objected for the encoder is represented in Eq.2, where G is the StyleGAN generator, E is the encoder  Ľ represents the distance metric which is used to calculate the loss between the generated and original input features. A regularization term is further added to prevent the latent offset from growing too large.</p>

<p><strong>Code</strong></p>

<p>All the processes discussed in this step are implemented inside the <a href="https://github.com/XingangPan/GAN2Shape/blob/deb9ac081d4f9243361a66befa7b9cfdb670d88c/gan2shape/model.py#L613"><code class="language-plaintext highlighter-rouge">forward_step2</code></a> function. The architecture for generator and discriminator are defined inside classes <a href="https://github.com/XingangPan/GAN2Shape/blob/deb9ac081d4f9243361a66befa7b9cfdb670d88c/gan2shape/stylegan2/stylegan2-pytorch/model.py#L398"><code class="language-plaintext highlighter-rouge">Generator</code></a> and <a href="https://github.com/XingangPan/GAN2Shape/blob/deb9ac081d4f9243361a66befa7b9cfdb670d88c/gan2shape/stylegan2/stylegan2-pytorch/model.py#L681"><code class="language-plaintext highlighter-rouge">Discriminator</code></a> respectively. Firstly the <a href="https://github.com/XingangPan/GAN2Shape/blob/deb9ac081d4f9243361a66befa7b9cfdb670d88c/gan2shape/model.py#L594"><code class="language-plaintext highlighter-rouge">gan_invert</code></a> function is called for performing GAN inversion. The encoder used here is defined in the class <a href="https://github.com/XingangPan/GAN2Shape/blob/deb9ac081d4f9243361a66befa7b9cfdb670d88c/gan2shape/networks.py#L143"><code class="language-plaintext highlighter-rouge">ResEncoder</code></a>. After this we obtain the projected samples and then we calculate the reconstruction loss. The <a href="https://github.com/XingangPan/GAN2Shape/blob/deb9ac081d4f9243361a66befa7b9cfdb670d88c/gan2shape/utils.py#L105"><code class="language-plaintext highlighter-rouge">photometric_loss</code></a> function is used to calculate L1 loss and the <a href="https://github.com/XingangPan/GAN2Shape/blob/deb9ac081d4f9243361a66befa7b9cfdb670d88c/gan2shape/losses.py#L23"><code class="language-plaintext highlighter-rouge">DiscriminatorLoss</code></a> class calculates the features of image samples using the discriminator networks, which is then used for calculating the total reconstruction loss.</p>

<h3 id="step-3-from-2d-to-3d">Step 3: From 2D to 3D</h3>
<p>After Step 2 we have projected samples which are sets of photorealistic images of a particular object with multiple viewpoints and lighting conditions. To learn its 3D shape, we again make use of the four networks View, Light, Depth and Albedo used in 
Step 1.</p>

<p>The main differences in Step 3 are that</p>
<ul>
  <li>View and Lighting conditions are predicted using the projected samples generated in Step 2, and the V and L encoder networks take the projected samples as the input</li>
  <li>The reconstruction loss is computed in a different way compared to Step 1, and the loss is used to optimize all four networks.</li>
  <li>For generating the 3D view, viewpoint and lighting obtained from the projected samples are used for rendering, and the images generated at this stage are more photorealistic and better represents the 3D view of the input image.</li>
</ul>

<p align="center">
  <img src="/public/images/2022-01-13-gan2shape/3-step3.png" alt="Step 3" style="width:65%" />
  <span><small><i><b>Step 3</b>: Generating the 3D view using the 4 networks V, L, D and A. Viewpoint and Lighting are predicted from the projected samples. Reconstruction loss is also taken to optimize all the four networks.</i></small></span>
</p>

<p>In step 3 firstly the albedo and depth factors are predicted by the respective encoder-decoder networks using the original input. The viewpoint and lighting are predicted by the corresponding encoder networks using the projected samples generated in Step 2. All the 4 networks are jointly trained to reconstruct the original image and the reconstruction objective formulated in Eq.3, where I and Ĩ represents the original input image and the projected samples respectively. A smoothness loss is also added for overcoming gradient locality as proposed by <a href="https://openaccess.thecvf.com/content_cvpr_2017/papers/Zhou_Unsupervised_Learning_of_CVPR_2017_paper.pdf">Zho et al</a>.</p>

<p>$\theta_{E},\theta_{A},\theta_{V},\theta_{L} = argmin_{\theta_{E}\theta_{A}\theta_{V}\theta_{L}} \frac{1}{m} \sum^m_{i=0} L(\tilde{I}_{i},\Phi(D(I),A(I),V(\tilde{I}),L(\tilde{I}))) + \lambda _{2} L _{smooth} (D(I))$</p>

<p>The four networks are similarly trained to render the 3D view of the input image, similar to how pseudo samples were generated in Step 1. These rendered sets of images are much more photorealistic in representing the 3D view compared to the pseudo samples.</p>

<p><strong>Code</strong></p>

<p>Processes involved in Step 3 are implemented inside the <a href="https://github.com/XingangPan/GAN2Shape/blob/main/gan2shape/model.py#L662"><code class="language-plaintext highlighter-rouge">forward_step3</code></a> function. The Depth and Albedo encoder-decoder networks make predictions the same way as in Step 1 whereas View and Light encoders take in the projected samples as input for predicting the factors. The same <a href="https://github.com/XingangPan/GAN2Shape/blob/deb9ac081d4f9243361a66befa7b9cfdb670d88c/gan2shape/renderer/renderer.py#L13"><code class="language-plaintext highlighter-rouge">Renderer</code></a> used in Step 1 is used to reconstruct the original input. The <a href="https://github.com/XingangPan/GAN2Shape/blob/deb9ac081d4f9243361a66befa7b9cfdb670d88c/gan2shape/utils.py#L105"><code class="language-plaintext highlighter-rouge">photometric_loss</code></a> function and the <a href="https://github.com/XingangPan/GAN2Shape/blob/deb9ac081d4f9243361a66befa7b9cfdb670d88c/gan2shape/stylegan2/stylegan2-pytorch/lpips/__init__.py#L12"><code class="language-plaintext highlighter-rouge">PerceptualLoss</code></a> class are used to calculate the reconstruction loss similar to Step 1. The loss thus obtained is used to optimize the four networks.</p>

<h3 id="iterative-self-refinement">Iterative self-refinement</h3>
<p>One important note about this GAN2Shape model is that the training has more than one cycle of repeating the above 3 steps to transform a 2D image into a 3D image; however, those steps need to be repeated to refine the 3D image. The paper used four cycles (or stages) to repeat these 3 steps mentioned above.</p>

<p>Another note about the process: The GAN2Shape model needs to be separately trained for each 2D input image, which involves repeating the 3 training steps discussed above for 4 cycles (or stages) and the output thus obtained would contain a set of images that can be used to construct a multi-view 3D image.</p>

<h2 id="gan2shape-colab-demo">GAN2Shape Colab Demo</h2>
<p>We have discussed how GAN2Shape works in theory, and how each of the steps relates to the code in the author’s repo. Now let’s use this <a href="https://iclr.iro.umontreal.ca/0a0d7c4d-a3e2-413f-b9da-d9e5b06d97c0_1642139457/_includes/2022-01-13-gan2shape/GAN2Shape_Colab_Demo_Modified.html">Colab notebook</a> to demonstrate how GAN2Shape works, and discuss some of the output results. Please refer to the notebook for details of code implementation and here we are discussing the key steps only.</p>

<h3 id="dependencies">Dependencies</h3>
<p>First we need to install the dependencies such as torch, torchvision, mmvc and pytorch neural render etc. Also note the dependency on <a href="https://github.com/daniilidis-group/neural_renderer">neural renderer</a> which is used for the rendering process.</p>

<h3 id="clone-the-repo">Clone the repo</h3>
<p>We clone the official GAN2Shape repo and change to the repo/ directory:</p>
<div class="language-plaintext highlighter-rouge"><div class="highlight"><pre class="highlight"><code>!git clone https://github.com/XingangPan/GAN2Shape.git repo
%cd repo/
</code></pre></div></div>

<h3 id="download-training-data-and-pretrained-weights">Download training data and pretrained weights</h3>
<p>Run <a href="https://github.com/daniilidis-group/neural_renderer">download.sh</a> shell script to download the repo <a href="https://github.com/XingangPan/GAN2Shape/releases/">release files</a> such as data.tar.gz, X00, X01 etc. which contains the training data and pretrained weights.</p>

<div class="language-plaintext highlighter-rouge"><div class="highlight"><pre class="highlight"><code>!sh /content/repo/scripts/download.sh
</code></pre></div></div>

<p>After this step you will notice a /data folder containing <code class="language-plaintext highlighter-rouge">car</code>, <code class="language-plaintext highlighter-rouge">cat</code> and <code class="language-plaintext highlighter-rouge">celeba</code> etc. And the <code class="language-plaintext highlighter-rouge">celeba</code> folder contains 400 images from the CelebA dataset.</p>

<p><img src="https://iclr.iro.umontreal.ca/0a0d7c4d-a3e2-413f-b9da-d9e5b06d97c0_1642139457/public/images/2022-01-13-gan2shape/4-datasets.png" alt="Datasets" /></p>

<h3 id="run-scripts">Run scripts</h3>
<p>Then we use the <code class="language-plaintext highlighter-rouge">run.py</code> script to train the GAN2Shape model on the celebA data.</p>

<div class="language-plaintext highlighter-rouge"><div class="highlight"><pre class="highlight"><code>!python run.py --launcher none --config configs/celeba.yml 2&gt;&amp;1 | tee results/celeba/log.txt
</code></pre></div></div>
<p>Note the authors of the paper experimented GAN2Shape on four different datasets while here we only tried on CelebA.</p>

<h3 id="results">Results</h3>
<p>The GAN2Shape model was successful in recovering 3D shapes from 2D images of numerous objects such as cars, buildings, human faces, cats etc. Some of the results obtained by running the scripts are shown below.</p>

<p align="center">
  <img src="/public/images/2022-01-13-gan2shape/5-results.gif" alt="" style="width:65%" />
</p>

<p>Prior to GAN2Shape, Unsup3D was the state of the art model for obtaining the 3D view of an input 2D image. But the model assumed every object to be symmetric and the lighting and textures were added accordingly to the 3D shape. GAN2Shape results showed that the model was successful even without the 3D assumption, producing a more realistic 3D view. The image below compares the performance of the two models.</p>

<p align="center">
  <img src="/public/images/2022-01-13-gan2shape/6-vs-unsup3d.png" alt="Comparison" style="width:65%" />
  <span><small><i>Comparison between GAN2Shape and Unsup3D.</i></small></span>
</p>

<p>GAN2Shape works well for images of human or cat faces where a convex shape prior provides a hint on the viewpoint and lighting condition, but fails when this is not the case. Due to this GAN2Shape was observed to not perform well on the LSUN horse dataset.</p>

<p align="center">
  <img src="/public/images/2022-01-13-gan2shape/7-limitations.png" alt="Limitations" style="width:65%" />
  <span><small><i>Some examples where convex shape prior doesn’t hint at the view and lighting of the object, hence causing GAN2Shape to perform poorly.</i></small></span>
</p>

<h2 id="summary">Summary</h2>
<p>In this post, we gave a brief introduction to 3D deep learning, GANs, StyleGAN2, and Unsup3D . Then we discussed in detail the key steps of GAN2Shape: how to transform a 2D image into 3D shapes, by using Unsup3D and StyleGAN2D. We demonstrated the training process with a Colab notebook to show the input image and the generated 3D images.</p>

<p>In summary, GAN2Shape is able to generate 3D shapes from 2D images which are readily available, without any additional annotations, 3D models or assumptions of object symmetry, and provide better results than previous 3D construction GAN models.</p>

<h2 id="references">References</h2>
<ul>
  <li>3D Deep Learning Tutorial: <a href="https://youtu.be/vfL6uJYFrp4">YouTube video</a> by the SU lab at UCSD.</li>
  <li>StyleGAN2 paper: <a href="https://arxiv.org/abs/1912.04958">Analyzing and Improving the Image Quality of StyleGAN</a></li>
  <li>GAN Inversion paper: <a href="https://arxiv.org/abs/2101.05278">GAN Inversion: A Survey</a></li>
  <li>Unsup3D paper: <a href="https://arxiv.org/abs/1911.11130">Unsupervised Learning of Probably Symmetric Deformable 3D Objects from Images in the Wild</a></li>
  <li>GAN2Shape paper: <a href="(https://arxiv.org/abs/2011.00844)">Do 2D GANs Know 3D Shape? Unsupervised 3D shape reconstruction from 2D Image GANs</a> - <a href="https://github.com/XingangPan/GAN2Shape">GitHub repository</a> and <a href="https://colab.research.google.com/drive/124D_f0RIu7Bbwa1SFV6pmvmBrNkB8Ow_?usp=sharing">Colab demo</a></li>
</ul>

</div>

<div id="bibtex-container" class="related">
  For attribution in academic contexts, please cite this work as
  <pre id="bibtex-academic-attribution">

  </pre>

  BibTeX citation
  <pre id="bibtex-box">

  </pre>
</div>
<script>
  let authorsSpan = document.getElementById("iclr-post-authors");
  let authorsText = authorsSpan.textContent;
  let lnameFnameInstitution = authorsText.split(";");
  let lfiList = lnameFnameInstitution.map(lfi => lfi.split(",").map(item => item.trim()));
  let bibtexLFI = lfiList.map(lfi => lfi[0] + ", " + lfi[1]).join(" and ")
  let academicLFI = lfiList.map(lfi => lfi[0]);
  {
    if(academicLFI.length > 2) academicLFI = academicLFI[0] + ", et al.";
    else if(academicLFI.length == 2) academicLFI = academicLFI[0] + " & " + academicLFI[1];
    else academicLFI = academicLFI[0];
  }

  let titleSpan = document.getElementById("iclr-post-title");
  let titleText = titleSpan.textContent.trim();
  let bibtexTitleShorthand = (lfiList[0][1]+
    "2022"+
    titleText.split(" ").slice(0, 3).join("")
  ).replace(" ", "").replace(/[\p{P}$+<=>^`|~]/gu, '').toLowerCase().trim();

  let bibtexTemplate = `
@inproceedings{${bibtexTitleShorthand}},
  author = {${bibtexLFI}},
  title = {${titleText}},
  booktitle = {ICLR Blog Track},
  year = {2022},
  note = {${window.location.href}},
  url  = {${window.location.href}}
}
  `.trim();
  document.getElementById("bibtex-box").innerText = bibtexTemplate;

  let academicTemplate = `
${academicLFI}, "${titleText}", ICLR Blog Track, 2022.
`.trim();
  document.getElementById("bibtex-academic-attribution").innerText = academicTemplate;

</script>


<div class="related">
  <h2>Related posts</h2>
  <ul class="related-posts">
    
      <li>
        <h3>
          <a href="/2021/09/01/sample-submission/">
            Sample Submission
            <small>01 Sep 2021 | 
    <a class="content-tag" href="/tags/#3d"> 3D, </a>
  
    <a class="content-tag" href="/tags/#deep"> deep </a>
  
    <a class="content-tag" href="/tags/#learning"> learning, </a>
  
    <a class="content-tag" href="/tags/#gans"> GANs </a>
  </small>
          </a>
        </h3>
      </li>
    
      <li>
        <h3>
          <a href="/2020/04/02/example-content/">
            Example content (Basic Markdown)
            <small>02 Apr 2020 | 
    <a class="content-tag" href="/tags/#3d"> 3D, </a>
  
    <a class="content-tag" href="/tags/#deep"> deep </a>
  
    <a class="content-tag" href="/tags/#learning"> learning, </a>
  
    <a class="content-tag" href="/tags/#gans"> GANs </a>
  </small>
          </a>
        </h3>
      </li>
    
  </ul>
</div>


<script src="https://utteranc.es/client.js"
        repo="iclr-blog-track/iclr-blog-track.github.io"
        issue-term="pathname"
        label="utterance"
        theme="boxy-light"
        crossorigin="anonymous"
        >
</script>


      </div>
    </div>

    <label for="sidebar-checkbox" class="sidebar-toggle"></label>

    <script src='/public/js/script.js'></script>
  </body>
</html>
