<html>

<head>
  <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  <title>PDTrack: Progressive Dense 3D Tracking</title>
  <link href="./files/style.css" rel="stylesheet">
  <!-- <link rel="icon" href="icons/demon_logo_transparent.png" type="image/png"> -->
  <!-- <link rel="stylesheet" href="./static/css/bulma-carousel.min.css"> -->

  <!-- <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="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.4.1/css/bootstrap.min.css">
  <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.7.1/jquery.min.js"></script>
  <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.4.1/js/bootstrap.min.js"></script>

  <script type="text/javascript" src="./files/jquery.mlens-1.0.min.js"></script>
  <script type="text/javascript" src="./files/jquery.js"></script>

  <script src="js/app.js"></script>
    <script src="js/synced_video_selector.js"></script>

    <script type="module">
        import init, * as bindings from '/brush-demo/brush-desktop-f16d466fdc38a30f.js';
        const isWebGPUSupported = 'gpu' in navigator;
        const warningElement = document.getElementById('webgpu-warning');
        const canvasElement = document.getElementById('brush_canvas');

        const originalFocus = HTMLElement.prototype.focus;
        HTMLElement.prototype.focus = function () {
            if (!this.matches('[id="brush_canvas"]')) {
                originalFocus.apply(this, arguments);
            }
        };

        if (isWebGPUSupported) {
            const wasm = await init({ module_or_path: '/brush-demo/brush-desktop-f16d466fdc38a30f_bg.wasm' });

            window.wasmBindings = bindings;
            dispatchEvent(new CustomEvent("TrunkApplicationStarted", { detail: { wasm } }));
        } else {
            warningElement.style.display = 'block';
            canvasElement.style.display = 'none';
        }
    </script>

    <script type="module">
        import { setupCarousel } from "./js/splats.js"

        window.addEventListener("TrunkApplicationStarted", (e) => {
            // Load with an initial URL.
            // var start_url = "https://storage.googleapis.com/realtime-nerf-360/cat4d/kling-forest-elf-fire_deform3dgs_pruned.ply"
            var start_url = "./splat_resources/hailuo-rabbit-snow_deform3dgs_pruned.ply"
            const viewer = new window.wasmBindings.EmbeddedViewer("brush_canvas", `?url=${start_url}&zen=true&focal=1.0&min_radius=1.5&max_radius=4.5&radius=3.75&min_pitch=-20.0&max_pitch=20.0&min_yaw=-25.0&max_yaw=25.0`)
            // setupCarousel(viewer, document.querySelector("#splat-carousel"));
            window.viewer = viewer;
        });
    </script>

  <style>
    .divider {
      border-right: 2px dashed #737373;
      width: 2px;
    }
  </style>
  <style>
    .divider_horizontal {
      border-top: 2px dashed #737373;
      display: block;
      width: 100%;
      margin: 10px 0;
    }
  </style>

<style>
  body {
    padding: 2em;
    font-family: sans-serif;
  }

  iframe {
    border-radius: 0.5em;
    width: 27.5em;
    height: 27.5em;
    border: none;
    box-shadow: 0 0 1em 0em rgba(0, 0, 0, 0.15);
  }

  @media (max-width: 768px) {
    iframe {
      width: 100%;
      height: 30em;
    }
  }

  a,
  a:link {
    color: #777;
  }

  /* Styles for the instruction icons and text */
  .instructions {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 1.2em;
    text-align: center;
    padding: 0.6em;
  }

  .instruction-item {
    display: flex;
    align-items: center;
    gap: 0.5em;
    font-size: 1.2em;
  }

  .instruction-item img {
    width: 36px;
    height: 36px;
  }

  .instructions_small {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 1em;
    text-align: center;
    padding: 0.5em;
  }

  .instruction-item_small {
    display: flex;
    align-items: center;
    gap: 0.3em;
    font-size: 1.0em;
  }

  .instruction-item_small img {
    width: 30px;
    height: 30px;
  }
</style>

</head>

<body>
  <div class="content">
    <h1 style="line-height: 1.2;">
      <strong>PDTrack: Progressive Dense 3D Tracking</strong>
    </h1>
    <br>

    <center>
      <div class="video-container">
      <video class='round' autoplay muted loop playsinline style='width: 800px' src='resources/demo_trajs/butterfly.mp4'></video>
      </div>
    </center>

    <br>

    <center>
      <div class="video-container">
      <video class='round' autoplay muted loop playsinline style='width: 800px' src='resources/demo_trajs/train.mp4'></video>
      </div>
    </center>

    <br>

    <center>
      <div class="video-container">
      <video class='round' autoplay muted loop playsinline style='width: 800px' src='resources/demo_trajs/motobike.mp4'></video>
      </div>
    </center>

    <br>
    <img class="summary-img" src="./resources/demo1.gif" style="width:60%;margin-bottom: -10px;">
    <br>
    <center>
      <h4><strong>PDTrack</strong> accelerates dense 3D tracking by a factor of 5 compared to DELTA, while achieving comparable performance.</h4>
    </center>


  </div>


  <div class="content">
    <h2 style="text-align:left;"><strong>Comparison with 3D tracking approaches: <a href="https://github.com/wwsource/SceneTracker">SceneTracker</a>, <a href="https://henry123-boy.github.io/SpaTracker/">SpatialTracker</a>, and <a href="https://snap-research.github.io/DELTA/">DELTA</a> </strong></h2>
    <br>
    <tr>
      <center>
        <video class='round' autoplay muted loop playsinline style='height:120px' src='resources/deltav2/birthcake_concat_compare.mp4' controls style="border: 5px solid black;"></video>
      </center>
    </tr>

    <br>

    <tr>
      <center>
        <video class='round' autoplay muted loop playsinline style='height:120px' src='resources/deltav2/car-roundabout_concat_compare.mp4' controls style="border: 5px solid black;"></video>
      </center>
    </tr>
    
    <br>

    <tr>
      <center>
        <video class='round' autoplay muted loop playsinline style='height:120px' src='resources/deltav2/butterfly_concat_compare.mp4' controls style="border: 5px solid black;"></video>
      </center>
    </tr>
    
    <br>
  
    <tr>
      <center>
        <video class='round' autoplay muted loop playsinline style='height:120px' src='resources/deltav2/swing_concat_compare.mp4' controls style="border: 5px solid black;"></video>
      </center>
    </tr>
    
    <br>

    <tr>
      <center>
        <video class='round' autoplay muted loop playsinline style='height:120px' src='resources/deltav2/tortoise_concat_compare.mp4' controls style="border: 5px solid black;"></video>
      </center>
    </tr>

    <br>
    <h4 class="title is-3">
      More results of 3D dense tracking can be found <a href="compare_dense.html">here</a>.
    </h4>
  </div>

  <div class="content">
    <h2 style="text-align:left;"><strong>Comparison with 2D tracking approaches (3D-lifted with depth): <a href="https://co-tracker.github.io/">CoTracker</a> and <a href="https://ku-cvlab.github.io/locotrack/">LocoTrack</a> </strong></h2>
    <br>
    <tr>
      <center>
        <video class='round' autoplay muted loop playsinline style='height:120px' src='resources/deltav2_compare2d/car-roundabout_concat_compare.mp4' controls style="border: 5px solid black;"></video>
      </center>
    </tr>

    <br>

    <tr>
      <center>
        <video class='round' autoplay muted loop playsinline style='height:120px' src='resources/deltav2_compare2d/stroller_concat_compare.mp4' controls style="border: 5px solid black;"></video>
      </center>
    </tr>
    
    <br>

    <tr>
      <center>
        <video class='round' autoplay muted loop playsinline style='height:120px' src='resources/deltav2_compare2d/horsejump-high_concat_compare.mp4' controls style="border: 5px solid black;"></video>
      </center>
    </tr>
    
    <br>
  
    <tr>
      <center>
        <video class='round' autoplay muted loop playsinline style='height:120px' src='resources/deltav2_compare2d/robot_arm_concat_compare.mp4' controls style="border: 5px solid black;"></video>
      </center>
    </tr>
    
    <br>
    <h4 class="title is-3">
      More results of 3D dense tracking can be found <a href="compare_dense_with_2d.html">here</a>.
    </h4>
    
  </div>



<script>
  // Get the video element
  var video = document.getElementById("short_video");

  // Set the loop attribute to ensure continuous looping
  video.loop = true;

  // Set the playback range between frames 0 and 100
  var startFrame = 0;
  var endFrame = 1;

  // Listen for the "timeupdate" event to continuously check the playback position
  video.addEventListener("timeupdate", function() {
      // Check if the current time is beyond the specified range
      if (video.currentTime > endFrame) {
          // Set the playback position back to the start frame
          video.currentTime = startFrame;
      }
  });
</script>

</body>
</html>
