<!DOCTYPE html>
<html data-wf-domain="" data-wf-page="596e65d120426e09785027f0" data-wf-site="596e65d120426e09785027eb" data-wf-status="1"
    class="w-mod-js wf-opensans-n3-active wf-opensans-n4-active wf-roboto-n4-active wf-opensans-i3-active wf-opensans-i4-active wf-opensans-n6-active wf-opensans-i6-active wf-opensans-n7-active wf-opensans-i7-active wf-opensans-n8-active wf-opensans-i8-active wf-roboto-n3-active wf-roboto-n5-active wf-active">

<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

    <title>DMesh</title>
    <meta content="width=device-width, initial-scale=1" name="viewport">
    <meta content="Webflow" name="generator">
    <link href="./files/supplemental.css" rel="stylesheet" type="text/css">
    <script src="./files/webfont.js" type="text/javascript"></script>
    <script type="text/javascript">
        WebFont.load({
            google: {
                families: ["Open Sans:300,300italic,400,400italic,600,600italic,700,700italic,800,800italic", "Roboto:300,regular,500"]
            }
        });
    </script>
    <script type="text/javascript">
        ! function (o, c) {
            var n = c.documentElement,
                t = " w-mod-";
            n.className += t + "js", ("ontouchstart" in o || o.DocumentTouch && c instanceof DocumentTouch) && (n.className += t + "touch")
        }(window, document);
    </script>
    <script id="MathJax-script" async src="https://cdn.jsdelivr.net/npm/mathjax@3/es5/tex-mml-chtml.js"></script>

    
</head>


<body class="body">
    <div class="section">
        <div class="container-3 w-container">
            <h1 class="papertitle">
                <font style="font-variant: small-caps">DMesh</font>: A Differentiable Mesh Representation
            </h1>
            <div class="text-block">Submission ID: 4957</div>
        </div>
    </div>

    <div class="section-2">
        <div class="container w-container">
            <ul role="list" class="list">
                <li class="list-item">
                    <a href="#overview">Overview </a>
                </li>
                <li class="list-item">
                    <a href="#experiment_1">Experiment: Mesh to DMesh </a>
                </li>
                <li class="list-item">
                    <a href="#experiment_2">Experiment: Point Cloud Reconstruction </a>
                </li>
                <li class="list-item">
                    <a href="#experiment_3">Experiment: Multi-view Image Reconstruction</a>
                </li>
                <!--

                <li class="list-item">
                    <a target="_blank" href="Differentiable_Reperesentation_for_General_3D_Mesh__Siggraph.pdf">4. Supplemental</a>
                </li>
                -->
            </ul>
        </div>
    </div>

    <div>
        <div class="container-2 w-container">
            <div class="container-2 w-container">
                <h1 id="overview" class="experimenttitle"><center>Overview</center></h1>
            </div>
            <!--<div class="videoresult w-row">
                <div class="w-col w-col w-col-12">
                    <video width="100%" height="100%" source="" src="./files/video/plant.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                </div>  
                <b><i>Figure 1. Optimization process to fit a plant model from random state. Our representation can represent
                    both open surface (leaves) and closed surface (pot), and support dynamic connectivity change.
                </i></b> 
            </div>-->

            <p class="paragraph">    

                <p>
                    <font size="+2">
                    <center>
                        <br>
                        "In this work, we present <strong><i>DMesh</i></strong>, a differentiable representation for general 3D mesh."
                        <br>
                        <br>
                    </center>
                    </font>
                </p> 
                
                <figure>
                    <div class="w-col w-col w-col-12">
                        <img width="100%" height="100%" source="" src="./files/overall.png" type="images"></img>
                        <video width="100%" height="100%" source="" src="./files/2_2/anim.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                        <figcaption>
                            <p>
                                <strong><i>Point cloud of DMesh (Left) and extracted mesh (Right) during optimization.</i>  </strong> <br>
                                <br>
                                <font size="+1">
                                    DMesh is an explicit shape representation that encodes every information into <strong>point cloud</strong>. <br>
                                    Then, we determine <strong>existence probability of faces</strong> based on the point cloud to extract mesh. <br>
                                    Therefore, we optimize the <strong>point attributes</strong> to reconstruct the target 3D mesh.
                                    <br><br>
                                </font>
                                
                            </p>
                        </figcaption>
                    </div>
                </figure>


                <figure>
                    <div class="w-col w-col w-col-12">
                        <video width="33%" height="100%" source="" src="./files/1_0/anim_blender_wire.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                        <video width="33%" height="100%" source="" src="./files/2_0/anim_blender_wire.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                        <video width="33%" height="100%" source="" src="./files/2_3/anim_blender_wire.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                
                        <figcaption>
                            <p>
                                <strong><i>Point cloud reconstruction (Left) / First (Middle) and last (Right) epoch of multi-view image reconstruction.</i>  </strong> <br>
                                <br>
                                <font size="+1">
                                    DMesh handles <strong>mesh connectivity</strong> in a differentiable manner. <br>
                                    Therefore, it admits <strong>dynamic topology change</strong>.<br><br>
                                </font>
                                
                            </p>
                        </figcaption>
                    </div>
                </figure>


                <figure>
                    <div class="w-col w-col w-col-12">

                        <figure>
                            <img width="24%" height="100%" source="" src="./files/0_3/deepfashion3d/164_0001.png" type="images"></img>
                            <img width="24%" height="100%" source="" src="./files/0_3/deepfashion3d/30_0001.png" type="images"></img>
                            <img width="24%" height="100%" source="" src="./files/0_3/deepfashion3d/320_0001.png" type="images"></img>
                            <img width="24%" height="100%" source="" src="./files/0_3/deepfashion3d/448_0001.png" type="images"></img>
                            <figcaption>
                                Open surfaces (DeepFashion3d)
                            </figcaption>
                        </figure>

                        <figure>
                            <img width="24%" height="100%" source="" src="./files/0_3/thingi32/252119_0001.png" type="images"></img>
                            <img width="24%" height="100%" source="" src="./files/0_3/thingi32/313444_0001.png" type="images"></img>
                            <img width="24%" height="100%" source="" src="./files/0_3/thingi32/527631_0001.png" type="images"></img>
                            <img width="24%" height="100%" source="" src="./files/0_3/thingi32/64444_0001.png" type="images"></img>
                            <figcaption>
                                Closed surfaces (Thingi32)
                            </figcaption>
                        </figure>

                        <figure>
                            <img width="33%" height="100%" source="" src="./files/0_3/objaverse/bigvegas_0001.png" type="images"></img>
                            <img width="33%" height="100%" source="" src="./files/0_3/objaverse/camilla_0001.png" type="images"></img>
                            <img width="33%" height="100%" source="" src="./files/0_3/objaverse/raspberry_0001.png" type="images"></img>
                            <figcaption>
                                    Mixed surfaces (Objaverse)
                            </figcaption>
                        </figure>

                        <figure>

                            <img width="100%" height="100%" source="" src="./files/versatile.png" type="images"></img>
                            <figcaption>
                                    Geometry of diverse topology
                            </figcaption>
                        </figure>

                        <figcaption>
                            <p>
                                <font size="+1">
                                    DMesh is very general representation, which can handle <strong>closed and open surfaces</strong> together.
                                </font>
                            </p>
                        </figcaption>
                    </div>
                </figure>
                </p>
            </p>
        </div>
    </div>

    <div>
        <div class="container-2 w-container">
            <div class="container-2 w-container">
                <h1 id="experiment_1" class="experimenttitle"><center>Experiment: Mesh to DMesh</center></h1>
            </div>
            <p class="paragraph">
                <font size="+1">
                    Since DMesh handles mesh connectivity in a differentiable manner, it can optimize point attributes
                    to <strong>recover the ground truth connectivity</strong> as much as possible, with only small perturbations
                    to the vertices of the mesh.
                </font>
            </p>
            <figure>
                <div class="w-col w-col w-col-6">
                    <img width="100%" height="100%" source="" src="./files/3_0/gt_0001.png" type="images"></img>
                </div>
                <div class="w-col w-col w-col-6">
                    <video width="100%" height="100%" source="" src="./files/3_0/anim_blender_wire.mp4" type="video/mp4" loop="true" autoplay="autoplay"  controls muted></video>
                </div>
                <br>
                <figcaption> 
                <font size="+1">
                    <br>
                    <br>
                    <strong><i>Ground truth mesh (Left) and DMesh (Right) during optimization.</i>  </strong> <br>
                    Even though there are slight perturbations to the vertex positions, DMesh can restore <strong>99%</strong> of connectivity
                    of the ground truth mesh, while only having less than <strong>1%</strong> false positive ratio.
                    The periodical flickering of DMesh is induced by additional point insertion.
                </font>
                    
                </figcaption>
                
            </figure>

        </div>
    </div>

    <div>
        <div class="container-2 w-container">
            <div class="container-2 w-container">
                <h1 id="experiment_2" class="experimenttitle"><center>Experiment: Point Cloud Reconstruction</center></h1>
            </div>
            <p class="paragraph">
                <br>
                <font size="+1">
                Here we assume each point cloud is comprised of 100K points.
                From there, we sample <strong>10K points to initialize DMesh</strong>.
                Then, we optimize DMesh by minimizing the <strong>expected Chamfer Distance loss</strong> to the given point cloud.
                </font>
                <br>
            </p>
            <div class="videoresult w-row">
                <div class="w-col w-col w-col-12">
                    <figure>
                        <video width="100%" height="100%" source="" src="./files/1_0/anim.mp4" type="video/mp4" loop="true" autoplay="autoplay"  controls muted></video>
                        <figcaption> 
                        <font size="+1">
                            <strong><i>Point cloud of DMesh (Left) and extracted mesh (Right) during optimization.</i>  </strong> <br>
                        In the point cloud rendering, the color of each point represents its real value.  <br>
                        Note that some points disappear because they lose weights and thus <strong>discarded</strong> during optimization. <br>
                        
                        </font>
                            
                        </figcaption>
                    </figure>
                    
                </div>
            </div>
            <div class="videoresult w-row">
                <div class="w-col w-col w-col-12">
                    <video width="49%" height="100%" source="" src="./files/1_0/anim_blender.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    <video width="49%" height="100%" source="" src="./files/1_0/anim_blender_wire.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    <figcaption> 
                        <font size="+1">
                            <strong><i>Extracted mesh without edges (Left) and with edges (Right) during optimization. </i> </strong> <br>
                        Since we already have sample points, we can use their subset to initialize our mesh. <br>
                        Therefore, it <strong>converges fast</strong> to the target shape in several optimization steps. <br>
                        Note that connectivity keeps changing mainly due to <strong>additional regularizations</strong>. 

                        </font>
                            
                        </figcaption>
                </div>
            </div>
        </div>
    </div>
    <div>
        <div class="container-2 w-container">
            <div class="container-2 w-container">
                <h1 id="experiment_3" class="experimenttitle"><center>Experiment: Multi-view Image Reconstruction</center></h1>
            </div>
            <p class="paragraph">
                <br>
                Here we assume that we are given diffuse and depth rendering of ground truth mesh from 64 viewpoints.
                We use <strong>differentiable renderer</strong> to render the object, and optimize mesh based on <strong>L1 loss</strong> to the given images.
                Unlike point cloud reconstruction, we <strong>start optimization from random state</strong>, as we do not have sample points.
                We take a <strong>coarse-to-fine approach</strong>, and optimize for 4 epochs.
                At the start of each epoch, we sample points from the previous mesh and use them to initialize the mesh.
                The number of sample points increase to get better, fine-grained results. 
                <br>
            </p>
            <figure>
                <div class="videoresult w-row">
                    <div class="w-col w-col w-col-7">
                        <video width="100%" height="100%" source="" src="./files/2_0/anim.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                    <div class="w-col w-col w-col-5">
                        <video width="49%" height="100%" source="" src="./files/2_0/anim_blender.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                        <video width="49%" height="100%" source="" src="./files/2_0/anim_blender_wire.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                </div>    
                <figcaption>
                    <font size="+1">
                        <center>
                            <strong><i>Epoch 0:</i></strong> Start optimization from 8000 regularly distributed points.
                        </center>
                    </font>
                </figcaption>
            </figure>

            <figure>
                <div class="videoresult w-row">
                    <div class="w-col w-col w-col-7">
                        <video width="100%" height="100%" source="" src="./files/2_1/anim.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                    <div class="w-col w-col w-col-5">
                        <video width="49%" height="100%" source="" src="./files/2_1/anim_blender.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                        <video width="49%" height="100%" source="" src="./files/2_1/anim_blender_wire.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                </div>  
                <figcaption>
                    <font size="+1">
                        <center>
                            <strong><i>Epoch 1:</i></strong> Sample <strong>1000 points</strong> from previous mesh to initialize mesh, and optimize.
                        </center>
                    </font>
                </figcaption>  
            </figure>

            <figure>
                <div class="videoresult w-row">
                    <div class="w-col w-col w-col-7">
                        <video width="100%" height="100%" source="" src="./files/2_2/anim.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                    <div class="w-col w-col w-col-5">
                        <video width="49%" height="100%" source="" src="./files/2_2/anim_blender.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                        <video width="49%" height="100%" source="" src="./files/2_2/anim_blender_wire.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                </div>   
                
                <figcaption>
                    <font size="+1">
                        <center>
                            <strong><i>Epoch 2:</i></strong> Sample <strong>3000 points</strong> from previous mesh to initialize mesh, and optimize.
                        </center>
                    </font>
                </figcaption>   
            </figure>
            
            <figure>
                <div class="videoresult w-row">
                    <div class="w-col w-col w-col-7">
                        <video width="100%" height="100%" source="" src="./files/2_3/anim.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                    <div class="w-col w-col w-col-5">
                        <video width="49%" height="100%" source="" src="./files/2_3/anim_blender.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                        <video width="49%" height="100%" source="" src="./files/2_3/anim_blender_wire.mp4" type="video/mp4" loop="true" autoplay="autoplay" controls muted></video>
                    </div>
                </div>

                <figcaption>
                    <font size="+1">
                        <center>
                            <strong><i>Epoch 3:</i></strong> Sample <strong>10000 points</strong> from previous mesh to initialize mesh, and optimize.
                        </center>
                    </font>
                </figcaption>  
            </figure>
            
        </div>
    </div>
    <script src="./files/jquery-3.4.1.min.220afd743d.js" type="text/javascript" integrity="sha256-CSXorXvZcTkaix6Yvo6HppcZGetbYMGWSFlBw8HfCJo=" crossorigin="anonymous"></script>
    <script src="./files/webflow.3cd0ca831.js" type="text/javascript"></script>
</body>