<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <meta name="description"
        content="LoopSplat: Loop Closure by Registering 3D Gaussian Splats">
  <meta name="keywords" content="LoopSplat: Loop Closure by Registering 3D Gaussian Splats">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <title>LoopSplat</title>

  <!-- Bootstrap -->
  <link rel="stylesheet" href="./static/css/bootstrap-4.4.1.css">

  <!-- 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="./static/css/bulma-carousel.min.css">
  <link rel="stylesheet" href="./static/css/bulma-slider.min.css">
  <link rel="stylesheet" href="./static/css/fontawesome.all.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="icon" href="./static/images/LoopSplat_logo.webp">
  <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css">
  

  <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>
  <script src="./static/js/app.js"></script>
  <script src="./static/js/video_comparison.js"></script>

  <link rel="stylesheet" href="./static/css/dics.original.css">
  <script src="./static/js/event_handler.js"></script>
  <script src="./static/js/dics.original.js"></script>
  


</head>
<body>

  <!DOCTYPE html>
  <html lang="en">
  <head>
      <meta charset="UTF-8">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <title>LoopSplat Header</title>
      <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/bulma/0.9.3/css/bulma.min.css">
      <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.3/css/all.min.css">
      <style>
          .publication-title {
              margin-bottom: 1rem !important;
          }
          .publication-authors {
              margin-bottom: 0.0rem;
          }
          .author-block {
              display: inline-block;
              margin-bottom: 0.5rem;
              margin-right: 0.5rem;
          }
          .publication-links {
              margin-top: 0.0rem;
          }
          .link-block {
              margin-right: 0.5rem;
          }
          .header-container {
              display: flex;
              align-items: center;
              justify-content: center;
              margin-bottom: 1rem;
          }
          .logo {
              width: 70px;
              height: auto;
              margin-right: 0.5rem;
          }
      </style>
  </head>
  <body>
      <section class="hero">
          <div class="hero-body">
              <div class="container is-max-desktop">
                  <div class="columns is-centered">
                      <div class="column has-text-centered">
                          <div class="header-container">
                              <img src="static/images/LoopSplat_logo.webp" alt="LoopSplat Logo" class="logo">
                              <h1 class="title is-1 publication-title">LoopSplat</h1>
                          </div>
                          <h2 class="title is-2 publication-title" style="margin-top: 0; margin-bottom: 0">Loop Closure by Registering 3D Gaussian Splats</h2>
                          <br>
                          
                              </div>
                          </div>
                      </div>
                  </div>
              </div>
          </div>
      </section>
  </body>
  </html>

  <h2 class="subtitle has-text-centered" style="margin-top: 15px">
    <b>Anonymous 3DV Submission #185</b>
  </h2>

  <section class="hero teaser">
    <div class="container is-max-desktop">
      <div class="hero-body">
        <div class="columns is-centered has-text-centered">
          <div class="column is-full-width">
            <video 
              class="video" 
              width="100%" 
              id="xyalias6" 
              loop 
              playsinline 
              autoplay 
              muted 
              src="resources/loopsplat_0054_vis.mp4"
            ></video>
        
            <h2 class="subtitle has-text-centered" style="margin-top: 15px">
              TL;DR: We present LoopSplat, a dense RGB-D SLAM system that uses 3D Gaussian Splats as a <b>unified</b> scene representation for tracking, mapping and maintaining <b>global consistency</b>. 
            </h2>
          </div>
        </div>
      </div>
    </div>
  </section>


<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" style="margin-top: -30px">Abstract</h2>
        <div class="content has-text-justified">
          <p>
            Simultaneous Localization and Mapping (SLAM) based on 3D Gaussian Splats (3DGS) has recently shown promise towards more accurate, dense 3D scene maps. However, existing 3DGS-based methods fail to address the global consistency of the scene via loop closure. To this end, we propose LoopSplat, which takes RGB-D images as input and performs dense mapping with 3DGS submaps and frame-to-model tracking. LoopSplat triggers loop closure online and computes relative loop edge constraints between submaps directly via 3DGS registration, leading to improvements in efficiency and accuracy over traditional global-to-local point cloud registration. It uses a robust pose graph optimization formulation and rigidly aligns the submaps to achieve global consistency. Evaluation on the synthetic Replica and real-world TUM-RGBD, ScanNet, and ScanNet++ datasets demonstrates competitive or superior tracking, mapping, and rendering compared to existing methods for dense RGB-D SLAM.
          </p>
        </div>
      </div>
    </div>
    
    <!--/ Paper video. -->
  </div>
</section>




<section class="section">
  <div class="container is-max-desktop">

    <!-- Method. -->
    <div class="columns is-centered has-text-centered">
      <div class="column is-full-width">
        <h2 class="title is-3" style="margin-top: -20px">Method</h2>

        <img src="./resources/architecture.png" class="center">
        <div class="content has-text-justified">
          <p style="margin-top: 30px">
            <b>LoopSplat</b> is a <b>coupled</b> RGB-D SLAM system that uses Gaussian splats as a <b>unified</b> scene representation for tracking, mapping, and maintaining global consistency. In the front-end, it continuously estimates the camera position while constructing the scene using Gaussian splats. When the camera traverses beyond a predefined threshold, the current submap is finalized, and a new one is initiated. Concurrently, the back-end loop closure module monitors for location revisits. Upon detecting a loop, the system generates a pose graph, incorporating loop edge constraints derived from our proposed <b>3DGS registration</b>. Subsequently, pose graph optimization (PGO) is executed to refine both camera poses and submaps, ensuring overall spatial coherence.
          </p>
        </div>

      </div>
    </div>
    <!--/ Animation. -->

  </div>
</section>


<section class="section">
  <div class="container is-max-desktop">

    <!-- Results. -->
    <div class="columns is-centered ">
      <div class="column is-full-width">
        <h2 class="title is-3 has-text-centered" style="margin-top: -30px">Qualitative Results</h2>

        <!-- <h3 class="title is-4">Replica Dataset</h3> -->

        <h3 class="title is-5" id="mesh">Mesh Reconstruction</h3>
        <h3 class="title is-6">Please make sure "use hardware acceleration when available" is enabled for chrome and WebGL is enabled in Safari.</h3>
        <div class="embed-responsive embed-responsive-16by9">

          <iframe style="clip-path: inset(1px 1px)" src="https://sketchfab.com/playlists/embed?collection=2c82c463a8eb46858009511b960eefa5&autostart=0" allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture; fullscreen" mozallowfullscreen="true" webkitallowfullscreen="true" width="100%" height="100%" frameborder="0"></iframe>
        </div>

        
        <div style="height: 50px;"></div> 
        <!-- <h3 class="title is-3">Qualitative Results </h3> -->
        <h3 class="title is-4">Scene 54 </h3>
        <!-- <h3 class="title is-5">Geometry</h3> -->
        
        <div class="container">
          <ul class="nav nav-tabs nav-fill nav-justified" id="233-recon">
          </ul>
          <div class="b-dics" style="width: 1000px; font-weight: 600;">
              <img src="resources/recon/scannet/normals/go-slam.png" alt="GO-SLAM">
              <img src="resources/recon/scannet/normals/gaussian-slam.png" alt="Gaussian-SLAM">
              <img src="resources/recon/scannet/normals/loopy-slam.png" alt="Loopy-SLAM">
              <img src="resources/recon/scannet/normals/loopsplat.png" alt="LoopSplat (Ours)">
              <img src="resources/recon/scannet/normals/gt.png" alt="Ground Truth">
          </div>
        </div>

        <br>
        <!-- <h3 class="title is-4">Scene 54 </h3>
        <h3 class="title is-5">Color</h3> -->
        
        <div class="container">
          <ul class="nav nav-tabs nav-fill nav-justified" id="233-color">
          </ul>
          <div class="b-dics" style="width: 1000px; font-weight: 600;">
              <img src="resources/recon/scannet/zoom-ins/go-slam.png" alt="GO-SLAM">
              <img src="resources/recon/scannet/zoom-ins/gaussian-slam.png" alt="Gaussian-SLAM">
              <img src="resources/recon/scannet/zoom-ins/loopy-slam.png" alt="Loopy-SLAM">
              <img src="resources/recon/scannet/zoom-ins/loopsplat.png" alt="LoopSplat (Ours)">
              <img src="resources/recon/scannet/zoom-ins/gt.png" alt="Ground Truth">
          </div>
        </div>
        
        
       
        
        <br>
        <div style="height: 50px;"></div> 
        <h3 class="title is-4">Scene 181 </h3>
        <h3 class="title is-5">Topview</h3>
        <div class="b-dics" style="width: 1000px; font-weight: 600;">
          <img src="resources/recon/scannet/181_topviews/go-slam.png" alt="GO-SLAM">
          <img src="resources/recon/scannet/181_topviews/gaussian-slam.png" alt="Gaussian-SLAM">
          <img src="resources/recon/scannet/181_topviews/loopy-slam.png" alt="Loopy-SLAM">
          <img src="resources/recon/scannet/181_topviews/loopsplat.png" alt="LoopSplat (Ours)">
          <img src="resources/recon/scannet/181_topviews/gt.png" alt="Ground Truth">
      </div>
      <h3 class="title is-5">Normals</h3>
        <div class="b-dics" style="width: 1000px; font-weight: 600;">
          <img src="resources/recon/scannet/181_normals/go-slam.png" alt="GO-SLAM">
          <img src="resources/recon/scannet/181_normals/gaussian-slam.png" alt="Gaussian-SLAM">
          <img src="resources/recon/scannet/181_normals/loopy-slam.png" alt="Loopy-SLAM">
          <img src="resources/recon/scannet/181_normals/loopsplat.png" alt="LoopSplat (Ours)">
          <img src="resources/recon/scannet/181_normals/gt.png" alt="Ground Truth">
      </div>
        <!-- </div> -->
        <div style="height: 50px;"></div>
        <h3 class="title is-4">Scene 233 </h3>
        <h3 class="title is-5">Reconstruction</h3>

        <div class="b-dics" style="width: 1000px; font-weight: 600;">
          <img src="resources/recon/scannet/233_zoom-ins/go-slam.png" alt="GO-SLAM">
          <img src="resources/recon/scannet/233_zoom-ins/gaussian-slam.png" alt="Gaussian-SLAM">
          <img src="resources/recon/scannet/233_zoom-ins/loopy-slam.png" alt="Loopy-SLAM">
          <img src="resources/recon/scannet/233_zoom-ins/loopsplat.png" alt="LoopSplat (Ours)">
          <img src="resources/recon/scannet/233_zoom-ins/gt.png" alt="Ground Truth">
      </div>

      </div>
    </div>

  </div>
</section>





<footer class="footer">
  <div class="container">
    <div class="content has-text-centered">
    </div>
    <div class="columns is-centered">
      <div class="column is-8">
        <div class="content">
          <p>
            This website is licensed under a <a rel="license" href="http://creativecommons.org/licenses/by-sa/4.0/">Creative
            Commons Attribution-ShareAlike 4.0 International License</a>.
            This webpage template is from <a href="https://github.com/nerfies/nerfies.github.io">Nerfies</a>. 
            The video comparison with sliding bar is from <a href="https://dorverbin.github.io/refnerf/">Ref-NeRF</a>. 
            The image comparison with sliding bar is from <a href="https://research.nvidia.com/labs/dir/neuralangelo/">Neuralangelo</a>. 
          </p>
        </div>
      </div>
          <p></p>
        </div>
      </div>
</footer>

</body>
</html>
