<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <meta name="description"
        content="soon">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <title>ND-SDF: Learning Normal Deflection Fields for High-Fidelity Indoor Reconstruction</title>

  <!-- Global site tag (gtag.js) - Google Analytics -->
  <script async src="https://www.googletagmanager.com/gtag/js?id=G-PYVRSFMDRL"></script>
  <script>
    window.dataLayer = window.dataLayer || [];

    function gtag() {
      dataLayer.push(arguments);
    }

    gtag('js', new Date());

    gtag('config', 'G-PYVRSFMDRL');
  </script>

  <link href="https://fonts.googleapis.com/css?family=Google+Sans|Noto+Sans|Castoro"
        rel="stylesheet">
  <link rel="stylesheet" href="./static/css/bulma.min.css">
  <link rel="stylesheet"
        href="https://cdn.jsdelivr.net/gh/jpswalsh/academicons@1/css/academicons.min.css">
  <link rel="stylesheet" href="./static/css/index.css">
  <link rel="stylesheet" href="./static/css/comparison.css">
  <!-- <link rel="icon" href="./static/images/favicon.svg"> -->

  <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
  <script defer src="./static/js/fontawesome.all.min.js"></script>
  <script src="./static/js/bulma-carousel.min.js"></script>
  <script src="./static/js/bulma-slider.min.js"></script>
  <script src="./static/js/index.js"></script>
</head>
<body>

<nav class="navbar" role="navigation" aria-label="main navigation">
  <div class="navbar-brand">
    <a role="button" class="navbar-burger" aria-label="menu" aria-expanded="false">
      <span aria-hidden="true"></span>
      <span aria-hidden="true"></span>
      <span aria-hidden="true"></span>
    </a>
  </div>
  <div class="navbar-menu">
    <div class="navbar-start" style="flex-grow: 1; justify-content: center;">
      <a class="navbar-item" href="">
      <span class="icon">
          <i class="fas fa-home"></i>
      </span>
      </a>

      <div class="navbar-item has-dropdown is-hoverable">
        <a class="navbar-link">
          Homepage
        </a>
        <!-- <div class="navbar-dropdown">
          <a class="navbar-item" href="./scannet/index.html">
            ScanNet
          </a>
        </div> -->
      </div>
    </div>

  </div>
</nav>

<!-- authors -->
<section class="hero">
  <div class="hero-body">
    <div class="container is-max-desktop">
      <div class="columns is-centered">
        <div class="column has-text-centered">
          <h1 class="title is-1 publication-title">ND-SDF: Learning Normal Deflection Fields for High-Fidelity Indoor Reconstruction</h1>
          <div class="is-size-5 publication-authors">
            <span class="author-block">
              Anonymized Authors
            
          </div>
        </div>
      </div>
    </div>
  </div>
</section>

<!-- teaser.png -->
<section class="hero teaser">
  <div class="container is-max-desktop">
    <div class="hero-body">
      <img id="teaser" height="100%" src="./static/images/teaser.png" alt="ND-SDF teaser."/>
      <p>
        We present <b>ND-SDF</b>, a framework for high-fidelity 3D indoor surface reconstruction from multi-views. Shown above is an extracted mesh from ScanNet++.
      </p>
    </div>
  </div>
</section>

<hr>
<section class="section">
  <div class="container is-max-desktop">
    <!-- Abstract. -->
    <div class="columns is-centered has-text-centered">
      <div class="column is-four-fifths">
        <h2 class="title is-3">Abstract</h2>
        <div class="content has-text-justified">
          <p>
			Neural implicit reconstruction via volume rendering has demonstrated its effectiveness in recovering dense 3D surfaces. 
			However, it is non-trivial to simultaneously recover meticulous geometry and preserve smoothness across regions with differing characteristics. 
			To address this issue, previous methods typically employ geometric priors, which are often constrained by the performance of the prior models. 
			In this paper, we propose <b>ND-SDF</b>, which learns a <b>N</b>ormal <b>D</b>eflection field to represent the angular deviation between the scene normal and the prior normal. 
			Unlike previous methods that uniformly apply geometric priors on all samples, introducing significant bias in accuracy, our proposed normal deflection 
			field dynamically learns and adapts the utilization of samples based on their specific characteristics, thereby improving both the accuracy and effectiveness of the model. 
			Our method not only obtains smooth weakly textured regions such as walls and floors but also preserves the geometric details of complex structures. 
			In addition, we introduce a novel ray sampling strategy based on the deflection angle to facilitate the unbiased rendering process, which significantly improves the quality and accuracy of intricate surfaces, 
			especially on thin structures. Consistent improvements on various challenging datasets demonstrate the superiority of our method.
          </p>
        </div>
      </div>
    </div>
    <!--/ Abstract. -->
    <hr>
    <!-- Method. -->
    <div class="columns is-centered has-text-centered">
      <div class="column is-four-fifths">
        <h2 class="title is-3">Method</h2>
        <div class="content has-text-justified">
          <img src="./static/images/framework.png"
               class="framework-image"
               alt="ND-SDF overview."/>
          
          <p>
            <b>Overview of our method.</b> We utilize multi-resolution hash grids <code class="code-latex">&#947;<sub>L</sub></code> as scene representation.
            The core of ND-SDF is the normal deflection field. We represent deflection with quaternions,
            which are predicted by the deflection network (denoted as <code class="code-latex">f<sub>d</sub></code>).
            We align the deflected normals with the prior normals to learn the deviation between the scene and the priors.
            To distinctly supervise high and low-frequency areas, we employ an adaptive deflection angle prior loss, ensuring both smoothness and detail.
            Furthermore, we utilize the deflection angle <code class="code-latex">&#916;&#952;</code> to distinguish complex structures,
            enabling angle-guided sampling and color loss to facilitate intricate surface details. Lastly,
            we combine the unbiased rendering method <a href="https://openaccess.thecvf.com/content/CVPR2023/papers/Zhang_Towards_Unbiased_Volume_Rendering_of_Neural_Implicit_Surfaces_With_Geometry_CVPR_2023_paper.pdf" class="quote">(TUVR)</a>  to promote the generation of extremely thin structures indoors.
          </p>
        </div>
      </div>
    </div>
    <!-- Our method. -->
    <!-- Paper video. -->
    
    <!--/ Paper video. -->
  </div>
</section>
<hr>
<!-- Comparisons -->
<section class="section">
  <div class="container is-max-desktop">
    <h2 class="title is-3" style="text-align: center;">Videos</h2>
    <h2 class="title is-4">ScanNet</h2>
    <div class="video-row-container">
      <video controls src="./static/videos/scannet_omni_384-21-2_3_512_latest_rgb.mp4" type="video/mp4" autoplay muted loop playsinline></video>
      <video controls src="./static/videos/scannet_omni_384-21-2_4_512_latest_rgb.mp4" type="video/mp4" autoplay muted loop playsinline></video>
    </div>

    <h2 class="title is-4">ScanNet++</h2>
    <video controls width="100%" height="100%" src="./static/videos/e0_notop_rgb.mp4" type="video/mp4" autoplay muted loop playsinline></video> 

    <h2 class="title is-4">T&T Ballroom</h2>
    <video controls width="100%" height="100%" src="./static/videos/tnt3_4_2048_latest_cat.mp4" type="video/mp4" autoplay muted loop playsinline></video> 
  </div>

  <div class="container is-max-desktop">
    <br>
    <h2 class="title is-3" style="text-align: center;">Comparisons</h2>
      <!-- ScanNet -->
      <div class="content">
        
        <h2 class="title is-4">ScanNet</h2>
        <div class="button-container" id="btn1">
          <button onclick="changeImages(event, 'cmp1','./static/images/cmp/debsdf/scannet_1.png', './static/images/cmp/ours_new/scannet_1.png')" class="cmp-button cmp-btn-checked">scan1</button>
          <button onclick="changeImages(event, 'cmp1','./static/images/cmp/debsdf/scannet_2.png', './static/images/cmp/ours_new/scannet_2.png')" class="cmp-button">scan2</button>
          <button onclick="changeImages(event, 'cmp1','./static/images/cmp/debsdf/scannet_3.png', './static/images/cmp/ours_new/scannet_3.png')" class="cmp-button">scan3</button>
          <button onclick="changeImages(event, 'cmp1','./static/images/cmp/debsdf/scannet_4.png', './static/images/cmp/ours_new/scannet_4.png')" class="cmp-button">scan4</button>
        </div>
        <div class="cmp-container" id="cmp1">
            <div class="bottom">
                <img src="./static/images/cmp/ours_new/scannet_1.png"/>
            </div>
            <div class="top">
                <img src="./static/images/cmp/debsdf/scannet_1.png"/>
            </div>
            <div class="cmp-slider"></div>
        </div>
        
      </div>
      
      <!-- scannet++ -->
      <div class="content">
        <h2 class="title is-4">ScanNet++</h2>

        <div class="button-container" id="btn2">
          <button onclick="changeImages(event, 'cmp2','./static/images/cmp/debsdf/scannetpp_1.png', './static/images/cmp/ours_new/scannetpp_1.png')" class="cmp-button cmp-btn-checked">036bce3393</button>
          <button onclick="changeImages(event, 'cmp2','./static/images/cmp/debsdf/scannetpp_2.png', './static/images/cmp/ours_new/scannetpp_2.png')" class="cmp-button">0e75f3c4d9</button>
          <button onclick="changeImages(event, 'cmp2','./static/images/cmp/debsdf/scannetpp_3.png', './static/images/cmp/ours_new/scannetpp_3.png')" class="cmp-button">108ec0b806</button>
          <button onclick="changeImages(event, 'cmp2','./static/images/cmp/debsdf/scannetpp_4.png', './static/images/cmp/ours_new/scannetpp_4.png')" class="cmp-button">7f4d173c9c</button>
          <button onclick="changeImages(event, 'cmp2','./static/images/cmp/debsdf/scannetpp_5.png', './static/images/cmp/ours_new/scannetpp_5.png')" class="cmp-button">ab11145646</button>
          <button onclick="changeImages(event, 'cmp2','./static/images/cmp/debsdf/scannetpp_6.png', './static/images/cmp/ours_new/scannetpp_6.png')" class="cmp-button">e050c15a8d</button>
        </div>
        <div class="cmp-container" id="cmp2">
            <div class="bottom">
                <img src="./static/images/cmp/ours_new/scannetpp_1.png"/>
            </div>
            <div class="top">
                <img src="./static/images/cmp/debsdf/scannetpp_1.png"/>
            </div>
            <div class="cmp-slider"></div>
        </div>
        
      </div>

      <!-- TnT -->
      <div class="content">
        <h2 class="title is-4">Tanks and Temples</h2>
        <div class="button-container" id="btn3">
          <button onclick="changeImages(event, 'cmp3','./static/images/cmp/debsdf/tnt_1.png', './static/images/cmp/ours_new/tnt_1.png')" class="cmp-button cmp-btn-checked">Courtroom</button>
          <button onclick="changeImages(event, 'cmp3','./static/images/cmp/debsdf/tnt_2.png', './static/images/cmp/ours_new/tnt_2.png')" class="cmp-button">Auditorium</button>
          <button onclick="changeImages(event, 'cmp3','./static/images/cmp/debsdf/tnt_3.png', './static/images/cmp/ours_new/tnt_3.png')" class="cmp-button">Museum</button>
          <button onclick="changeImages(event, 'cmp3','./static/images/cmp/debsdf/tnt_4.png', './static/images/cmp/ours_new/tnt_4.png')" class="cmp-button">Ballroom</button>
        </div>
        <div class="cmp-container" id="cmp3">
            <div class="bottom">
                <img src="./static/images/cmp/ours_new/tnt_1.png"/>
            </div>
            <div class="top">
                <img src="./static/images/cmp/debsdf/tnt_1.png"/>
            </div>
            <div class="cmp-slider"></div>
        </div>
      </div>

      <!-- TnT 2048-->
      <!-- <div class="content">
        <h2 class="title is-4">T&T extracted at 2048 resolution</h2>
        <p>
          The mesh extracted at 2048 resolution on T&T demonstrates that our method significantly enhances the generation of small and complex structures.
        </p>
        <div class="button-container" id="btn4">
          <button onclick="changeImages(event, 'cmp4', './static/images/cmp/tnt_normal/tnt2048_normal_1.png','./static/images/cmp/tnt_2048/tnt2048_1.png')" class="cmp-button cmp-btn-checked">Courtroom</button>
          <button onclick="changeImages(event, 'cmp4', './static/images/cmp/tnt_normal/tnt2048_normal_2.png','./static/images/cmp/tnt_2048/tnt2048_2.png')" class="cmp-button">Auditorium</button>
          <button onclick="changeImages(event, 'cmp4', './static/images/cmp/tnt_normal/tnt2048_normal_3.png','./static/images/cmp/tnt_2048/tnt2048_3.png')" class="cmp-button">Museum</button>
          <button onclick="changeImages(event, 'cmp4', './static/images/cmp/tnt_normal/tnt2048_normal_4.png','./static/images/cmp/tnt_2048/tnt2048_4.png')" class="cmp-button">Ballroom</button>
        </div>
        <div class="cmp-container" id="cmp4">
            <div class="bottom">
                <img src="./static/images/cmp/tnt_2048/tnt2048_1.png"/>
            </div>
            <div class="top">
                <img src="./static/images/cmp/tnt_normal/tnt2048_normal_1.png"/>
            </div>
            <div class="cmp-slider"></div>
        </div>
      </div> -->

    <br>
    <h2 class="title is-3" style="text-align: center;">Textured mesh</h2>
    <!-- scannet++ with texture -->
    <div class="content">
      <h2 class="title is-4">ScanNet++</h2>
      <p>
        We further demonstrate the textured mesh generated by our method on ScanNet++.
      </p>
      <div class="button-container" id="btn2">
        <button onclick="changeImages(event, 'cmp5','./static/images/cmp/pp_mesh/scannetpp_1.png', './static/images/cmp/pp_textured/scannetpp_1.png')" class="cmp-button cmp-btn-checked">036bce3393</button>
        <button onclick="changeImages(event, 'cmp5','./static/images/cmp/pp_mesh/scannetpp_2.png', './static/images/cmp/pp_textured/scannetpp_2.png')" class="cmp-button">0e75f3c4d9</button>
        <button onclick="changeImages(event, 'cmp5','./static/images/cmp/pp_mesh/scannetpp_3.png', './static/images/cmp/pp_textured/scannetpp_3.png')" class="cmp-button">108ec0b806</button>
        <button onclick="changeImages(event, 'cmp5','./static/images/cmp/pp_mesh/scannetpp_4.png', './static/images/cmp/pp_textured/scannetpp_4.png')" class="cmp-button">7f4d173c9c</button>
        <button onclick="changeImages(event, 'cmp5','./static/images/cmp/pp_mesh/scannetpp_5.png', './static/images/cmp/pp_textured/scannetpp_5.png')" class="cmp-button">ab11145646</button>
        <button onclick="changeImages(event, 'cmp5','./static/images/cmp/pp_mesh/scannetpp_6.png', './static/images/cmp/pp_textured/scannetpp_6.png')" class="cmp-button">e050c15a8d</button>
      </div>
      <div class="cmp-container" id="cmp5">
          <div class="bottom">
              <img src="./static/images/cmp/pp_textured/scannetpp_1.png"/>
          </div>
          <div class="top">
              <img src="./static/images/cmp/pp_mesh/scannetpp_1.png"/>
          </div>
          <div class="cmp-slider"></div>
      </div>
      
    </div>
    <script src="./static/js/comparison.js"></script>
  <!-- end -->
  </div>
</section>




</body>
</html>
