<!doctype html>
<html lang="en">

<head>
  <title>ID: 6078</title>
  <meta name="description" content="ID: 6078">
  <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=yes">
  <meta charset="utf-8">

  <!--Style-->
  <link href="style.css" rel="stylesheet">

  <!-- External libraries: -->
  <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.2.3/dist/css/bootstrap.min.css"
  rel="stylesheet" integrity="sha384-rbsA2VBKQhggwzxH7pPCaAqO46MgnOM80zW1RWuH61DGLwZJEdK2Kadq2F9CUG65"
  crossorigin="anonymous">
  <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.2.3/dist/js/bootstrap.bundle.min.js"
  integrity="sha384-kenU1KFdBIe4zVF0s0G1M5b4hcpxyD9F7jL+jjXkk+Q2h455rYXK/7HAuoJl+0I4"
  crossorigin="anonymous"></script>
  <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.7.1/jquery.min.js"></script>


  <!-- Carousel logic: -->
  <script src="js/app.js"></script>

</head>

<body>

  <div class="container" style="text-align:center; padding:2rem 15px">
    <div class="row" style="text-align:center">
      <h1 style="margin-bottom:-2.6rem;">ID: 6078</h1>
            <h3 style="margin-bottom:-2.6rem;">ICLR 2026 Submission</h3>
    </div>

  <!-- Add space here -->
  <div style="height: 5rem;"></div>
  <div class="container">
    <video id="overviewVideo" autoplay loop muted style="max-width: 70%; height: auto; box-sizing: border-box; margin: 0 auto; display: block;">
      <source src="videos/s00014.mp4" type="video/mp4">
    </video>


    <p>
This page offers visual examples of FastForward localizing query images across a variety of challenging scenarios, such as symmetric objects, opposing shots, or large-scale scenes. 
We visualize the camera trajectory of a user trying to localize in a location where mapping images and poses are available. 
For instance, the images and camera parameters are sourced from a tracking system used during the mapping scan recording (<i>e.g.</i>,  the Wayspots dataset).

Besides, we also provide a comparison between FastForward and its closest competitors, MASt3R and Reloc3r. 
We display the histogram of errors for each localization scan, providing a clear measurement of their potential for a good user experience.
    </p>

    <h3 style="text-align: center;" class="mt-5">Visual Localization</h3>
    <hr class="hr"/>    
    <p>
      We show examples of FastForward, doing mapping and localization of query images in a single forward-pass.   
      Instead of using all the available mapping images, we represent the scene by selecting the top K images based on a retrieval step.
      For outdoor data we use 20 mapping images, while indoor examples use 10 mapping images. From each mapping image we sample 20% of the features.
      We show the predicted query pose in blue and the ground truth pose in green. 
      We also show the camera trajectories for the mapping images in gray, and additionally display the camera frustum for the mapping images used in the prediction.
    </p>
    <p><b>
      There are two videos per dataset. Use the left and right navigation buttons to switch between the two scenes. 
    </b></p>
    
    <div class="container" style="text-align: center; margin-bottom: 2rem;">
      <button id="DatasetBtn1" class="btn btn-primary">Map-free</button>
      <button id="DatasetBtn2" class="btn btn-secondary">Wayspots</button>
      <button id="DatasetBtn3" class="btn btn-secondary">Cambridge</button>
      <button id="DatasetBtn4" class="btn btn-secondary">Indoor6</button>
    </div>

    <div id="carouselExampleCaptions" class="carousel slide" data-ride="carousel" data-interval="false">
      <div class="carousel-indicators">
        <button type="button" data-bs-target="#carouselExampleCaptions" data-bs-slide-to="0" class="active" aria-current="true" aria-label="Slide 1"></button>
        <button type="button" data-bs-target="#carouselExampleCaptions" data-bs-slide-to="1" aria-label="Slide 2"></button>
        <button type="button" data-bs-target="#carouselExampleCaptions" data-bs-slide-to="2" aria-label="Slide 3"></button>
        <button type="button" data-bs-target="#carouselExampleCaptions" data-bs-slide-to="3" aria-label="Slide 4"></button>
        <button type="button" data-bs-target="#carouselExampleCaptions" data-bs-slide-to="4" aria-label="Slide 5"></button>
        <button type="button" data-bs-target="#carouselExampleCaptions" data-bs-slide-to="5" aria-label="Slide 6"></button>
        <button type="button" data-bs-target="#carouselExampleCaptions" data-bs-slide-to="6" aria-label="Slide 7"></button>
        <button type="button" data-bs-target="#carouselExampleCaptions" data-bs-slide-to="7" aria-label="Slide 8"></button>
     </div>

      <div class="carousel-inner">
          <div class="carousel-item active">
            <video id="s00219" class="w-100" style="max-width: 70%; margin: 0 auto; display: block;" autoplay loop muted>
              <source src="videos/s00219.mp4" type="video/mp4" />
          </video>
          <div class="carousel-caption d-none d-md-block" style="bottom: 0;">
            <h5>s00219</h5>
        </div>
        </div>
        
        <div class="carousel-item">
          <video class="w-100" style="max-width: 70%; margin: 0 auto; display: block;"  autoplay loop muted>
            <source src="videos/s00406.mp4" type="video/mp4" />
          </video>
          <div class="carousel-caption d-none d-md-block">
            <h5>s00406</h5>
          </div>
        </div>
        
        <div class="carousel-item">
          <video class="w-100" style="max-width: 70%; margin: 0 auto; display: block;"  autoplay loop muted>
            <source src="videos/wayspots_therock.mp4" type="video/mp4" />
          </video>
          <div class="carousel-caption d-none d-md-block">
            <h5>The Rock</h5>
          </div>
        </div>

        <div class="carousel-item">
          <video class="w-100" style="max-width: 70%; margin: 0 auto; display: block;"  autoplay loop muted>
            <source src="videos/wayspots_bears.mp4" type="video/mp4" />
          </video>
          <div class="carousel-caption d-none d-md-block">
            <h5>Bears</h5>
          </div>
        </div>
        
        <div class="carousel-item">
          <video id="cambridge_shop" style="max-width: 70%; margin: 0 auto; display: block;" class="w-100" autoplay loop muted>
            <source src="videos/ShopFacade.mp4" type="video/mp4" />
          </video>
          <div class="carousel-caption d-none d-md-block">
            <h5>Shop Facade</h5>
          </div>
        </div>
                
        <div class="carousel-item">
          <video id="KingsCollege" style="max-width: 70%; margin: 0 auto; display: block;" class="w-100" autoplay loop muted>
            <source src="videos/KingsCollege.mp4" type="video/mp4" />
          </video>
          <div class="carousel-caption d-none d-md-block">
            <h5>King's College</h5>
          </div>
        </div>

        <div class="carousel-item">
          <video id="Indoor6Scene2_light" style="max-width: 70%; margin: 0 auto; display: block;"  class="w-100" autoplay loop muted>
            <source src="videos/scene2a_light.mp4" type="video/mp4" />
          </video>
          <div class="carousel-caption d-none d-md-block">
            <h5>Scene2a-light</h5>
          </div>
        </div>

        <div class="carousel-item">
          <video id="Indoor6Scene2_dark" class="w-100" style="max-width: 70%; margin: 0 auto; display: block;"  autoplay loop muted>
            <source src="videos/scene2a_dark.mp4" type="video/mp4" />
          </video>
          <div class="carousel-caption d-none d-md-block" style="bottom: 0;">
            <h5>Scene2a-dark</h5>
          </div>
        </div>
        
      </div>
      <button class="carousel-control-prev big-carousel-control" type="button" data-bs-target="#carouselExampleCaptions" data-bs-slide="prev">
        <span class="carousel-control-prev-icon" aria-hidden="true"></span>
        <span class="visually-hidden">Previous</span>
      </button>
      <button class="carousel-control-next big-carousel-control" type="button" data-bs-target="#carouselExampleCaptions" data-bs-slide="next">
        <span class="carousel-control-next-icon" aria-hidden="true"></span>
        <span class="visually-hidden">Next</span>
      </button>
    </div>

  <h3 style="text-align: center;" class="mt-5">Extreme Localization Scenarios</h3>
  <hr class="hr"/>    
  <p>
    We evaluate FastForward against the baseline methods Reloc3r and MASt3R in extreme visual localization scenarios. 
    For the Wayspots scenes, we only display Reloc3r estimates as MASt3R was trained on this dataset. 
    In the Wayspots scenes, we highlight two challenging scenarios: opposing shots (<i>i.e.</i>, mapping and query scans taken from opposite viewpoints) and symmetric scenes (<i>i.e.</i>, scene with similar appearance from different viewpoints). 
    We also present results on the Cambridge dataset to demonstrate how the methods generalize to scenes with scale ranges unseen during training. 
  </p>
  <p><b>
      There are two videos per dataset. Use the left and right navigation buttons to switch between the two scenes. 
    </b></p>
   <div class="container" style="text-align: center; margin-bottom: 2rem;">
    <button id="example1Btn" class="btn btn-primary">Reloc3r</button>
    <button id="example2Btn" class="btn btn-secondary">Reloc3r & MASt3R</button>
  </div>
  
  <div id="carouselExampleChallenging" class="carousel slide" data-interval="false">
    <div class="carousel-indicators">
      <button type="button" data-bs-target="#carouselExampleChallenging" data-bs-slide-to="0" class="active" aria-current="true" aria-label="Slide 1"></button>
      <button type="button" data-bs-target="#carouselExampleChallenging" data-bs-slide-to="1" aria-label="Slide 2"></button>
      <button type="button" data-bs-target="#carouselExampleChallenging" data-bs-slide-to="2" aria-label="Slide 3"></button>
      <button type="button" data-bs-target="#carouselExampleChallenging" data-bs-slide-to="3" aria-label="Slide 4"></button>
    </div>
    <div class="carousel-inner">
      <div class="carousel-item active example1">
        <video id="Lawn" style="max-width: 70%; margin: 0 auto; display: block;" class="w-100" autoplay loop muted>
          <source src="videos/wayspots_lawn.mp4" type="video/mp4" />
        </video>
        <div class="carousel-caption d-none d-md-block" style="bottom: 0;">
          <h5>Opposing viewpoints (Lawn)</h5>
        </div>
      </div>
  
      <div class="carousel-item example1">
        <video id="SquareBench" class="w-100" style="max-width: 70%; margin: 0 auto; display: block;" autoplay loop muted>
          <source src="videos/wayspots_squarebench.mp4" type="video/mp4" />
        </video>
        <div class="carousel-caption d-none d-md-block" style="bottom: 0;">
          <h5>Symmetric scene (Square Bench)</h5>
        </div>
      </div>
  
      <div class="carousel-item example2">
        <video id="StMaryChurch" style="max-width: 70%; margin: 0 auto; display: block;" class="w-100" autoplay loop muted>
          <source src="videos/StMarysChurch.mp4" type="video/mp4" />
        </video>
        <div class="carousel-caption d-none d-md-block" style="bottom: 0;">
          <h5>Unseen Large-scale Scene (St Mary's Church)</h5>
        </div>
      </div>
  
      <div class="carousel-item example2">
        <video id="OldHospital" style="max-width: 70%; margin: 0 auto; display: block;" class="w-100" autoplay loop muted>
          <source src="videos/OldHospital.mp4" type="video/mp4" />
        </video>
        <div class="carousel-caption d-none d-md-block" style="bottom: 0;">
          <h5>Unseen Large-scale Scene (Old Hospital)</h5>
        </div>
      </div>
    </div>
    <button class="carousel-control-prev big-carousel-control" type="button" data-bs-target="#carouselExampleChallenging" data-bs-slide="prev">
      <span class="carousel-control-prev-icon" aria-hidden="true"></span>
      <span class="visually-hidden">Previous</span>
    </button>
    <button class="carousel-control-next big-carousel-control" type="button" data-bs-target="#carouselExampleChallenging" data-bs-slide="next">
      <span class="carousel-control-next-icon" aria-hidden="true"></span>
      <span class="visually-hidden">Next</span>
    </button>
  </div>

  <body>
    <div class="spacer"></div>
  </body>
 
<script>
  document.getElementById('overviewVideo').playbackRate = 0.8;
  document.getElementById('cambridge_shop').playbackRate = 1.2; 
  document.getElementById('KingsCollege').playbackRate = 1.2;
  document.getElementById('Indoor6Scene2_light').playbackRate = 0.5;
  document.getElementById('Indoor6Scene2_dark').playbackRate = 0.5;
  document.getElementById('OldHospital').playbackRate = 1.1;
  document.getElementById('StMaryChurch').playbackRate = 0.9;
</script>

</html>