<!DOCTYPE html>
<html>

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

  <!-- <meta http-equiv="x-ua-compatible" content="ie=edge"> -->

  <title>HoloScene</title>

  <meta name="description" content="">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <!-- mirror: F0%9F%AA%9E&lt -->

  <link rel="stylesheet" type="text/css" href="./src/slick.css">
  <link rel="stylesheet" type="text/css" href="./src/slick-theme.css">
  <link rel="stylesheet" href="./src/bulma.min.css">
  <link rel="stylesheet" href="./src/bulma-slider.min.css">
  <link rel="stylesheet" href="./src/bulma-carousel.min.css">
  <link rel="stylesheet" href="./src/bootstrap.min.css">
  <link rel="stylesheet" href="./src/font-awesome.min.css">
  <link rel="stylesheet" href="./src/codemirror.min.css">
  <link rel="stylesheet" href="./src/app.css">
  <link rel="stylesheet" href="./src/index.css">
  <link rel="stylesheet" href="./src/select.css">
  <link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/jpswalsh/academicons@1/css/academicons.min.css">
  <link rel="stylesheet" href="resources/glide.core.min.css">
  <link rel="stylesheet" href="resources/glide.theme.min.css">
  <link rel="stylesheet" href="resources/glide-custom.css">
  <script src="resources/handlers.js"></script>
  <script src="./src/jquery.min.js"></script>
  <script src="./src/bootstrap.min.js"></script>
  <script src="./src/codemirror.min.js"></script>
  <script src="./src/clipboard.min.js"></script>
  <script src="./src/video_comparison.js"></script>
  <script src="./src/select.js"></script>
  <script src="./src/bulma-slider.min.js"></script>
  <script src="./src/bulma-carousel.min.js"></script>
  <!-- <script src="./src/app.js"></script> -->
  <script src="./src/index.js"></script>
  <!-- <script src="./src/slick.js"></script> -->
  
  <script src="resources/glide.min.js"></script>
  <script>
  window.onload = function() {
    // Initialize carousels with error handling
    try {
      const dynamicCarousel = document.getElementById("dynamic-carousel");
      if (dynamicCarousel) {
        new Glide("#dynamic-carousel", {
          type: "carousel",
          perView: 1.68,
          focusAt: "center",
          autoplay: 13000,
          hoverpause: true
        }).mount();
      }
    } catch (e) {
      // Dynamic carousel initialization failed
    }
    
    try {
      const realtimeCarousel = document.getElementById("realtime-carousel");
      if (realtimeCarousel) {
        new Glide("#realtime-carousel", {
          type: "carousel",
          perView: 2.05,
          focusAt: "center",
          autoplay: 3000,
          hoverpause: true
        }).mount();
      }
    } catch (e) {
      // Realtime carousel initialization failed
    }
    
    // Wait a bit more for DOM to be fully ready, then initialize video sync
    setTimeout(() => {
      initializeSynchronizedVideos();
    }, 2000);
  };

  function initializeSynchronizedVideos() {
    // Find all video sections using specific IDs
    const videoSectionIds = ['video-section-1', 'video-section-2', 'video-section-3', 'video-section-4'];
    let sectionsFound = 0;
    
    videoSectionIds.forEach((sectionId, sectionIndex) => {
      const section = document.getElementById(sectionId);
      
      if (section) {
        const videos = section.querySelectorAll('video');
        
        if (videos.length > 0) {
          setupSynchronizedPlayback(videos, sectionIndex, sectionId);
          sectionsFound++;
        }
      }
    });
    
    // Fallback: If sections not found by ID, try direct video selection
    if (sectionsFound === 0) {
      // Find all videos that have autoplay and are not in carousels
      const allVideos = document.querySelectorAll('video[autoplay]:not(.game)');
      
      if (allVideos.length > 0) {
        // Group videos by their parent containers
        const videoGroups = new Map();
        
        allVideos.forEach((video, index) => {
          // Find the closest container div
          const container = video.closest('.col-md-12');
          const containerId = container ? container.innerHTML.substring(0, 50) : `group-${Math.floor(index / 6)}`;
          
          if (!videoGroups.has(containerId)) {
            videoGroups.set(containerId, []);
          }
          videoGroups.get(containerId).push(video);
        });
        
        // Set up playback for each group
        let groupIndex = 0;
        videoGroups.forEach((videos, groupId) => {
          setupSynchronizedPlayback(videos, groupIndex, `direct-group-${groupIndex}`);
          groupIndex++;
        });
      }
    }
    
    // Final fallback - find ANY videos with autoplay attribute
    setTimeout(() => {
      const fallbackVideos = document.querySelectorAll('video[autoplay]');
      
      if (fallbackVideos.length > 0 && sectionsFound === 0) {
        setupSynchronizedPlayback(Array.from(fallbackVideos), 0, 'fallback-all-videos');
      }
    }, 1000);
  }

  function setupSynchronizedPlayback(videos, sectionIndex, sectionId) {
    // Remove autoplay attribute and set up manual control
    videos.forEach(video => {
      video.removeAttribute('autoplay');
      video.currentTime = 0;
      video.muted = true; // Ensure videos are muted for autoplay
      video.loop = false; // Disable loop since we're controlling it manually
    });

    // Function to play all videos simultaneously
    function playAllVideos() {
      videos.forEach(video => {
        video.currentTime = 0;
        video.play().catch(e => {
          // Video play failed silently
        });
      });
    }

    // Ensure videos are ready to play
    videos.forEach(video => {
      video.addEventListener('loadeddata', function() {
        if (this.readyState >= 2) {
          this.currentTime = 0;
        }
      });
    });

    // Start playing all videos initially with a delay to ensure they're loaded
    setTimeout(() => {
      playAllVideos();
    }, 2000);

    // Set up timer to replay all videos every 5 seconds
    setInterval(() => {
      playAllVideos();
    }, 5000);

    // Handle visibility change to restart videos when page becomes visible
    document.addEventListener('visibilitychange', function() {
      if (!document.hidden) {
        setTimeout(() => {
          playAllVideos();
        }, 500);
      }
    });
  }
  </script>
  <script async src="https://www.googletagmanager.com/gtag/js?id=G-RZ6PES7EKD"></script>
  <script>
    window.dataLayer = window.dataLayer || [];
    function gtag(){dataLayer.push(arguments);}
    gtag('js', new Date());
    gtag('config', 'G-RZ6PES7EKD');
  </script>
</head>

<body>
  <div class="container" id="header" style="text-align: center; margin: auto;">
    <div class="row" id="title-row" style="max-width: 100%; margin: 0 auto; display: inline-block">
      <h1 class="col-md-12 text-center" id="title">
        <b>HoloScene</b>: Simulation-Ready Interactive 3D Worlds <br>from a Single Video<br>
      </h1>
    </div>
  </div>
  <script>
  </script>
  <div class="container" id="main">
    <div class="row">
      <div class="col-sm-10 col-sm-offset-1 text-center">
        <ul class="list-inline">
          <li> <a href="https://xiahongchi.github.io/">Hongchi Xia<sup>1</sup></a> </li>
          <li> <a href="https://chih-hao-lin.github.io/">Chih-Hao Lin<sup>1</sup></a>  </li>
          <li> <a href="https://haoyuhsu.github.io/">Hao-Yu Hsu<sup>1</sup></a> </li>
          <li> <a href="https://www.linkedin.com/in/quentinleboutet/?originalSubdomain=de">Quentin Leboutet<sup>2</sup></a> </li>
          <li> <a href="https://sites.google.com/view/katelyn-gao/home">Katelyn Gao<sup>2</sup></a> </li>
          <li> <a href="https://www.linkedin.com/in/michael-paulitsch/?originalSubdomain=de">Michael Paulitsch<sup>2</sup></a> </li>
          <br>
          <li> <a href="https://scholar.google.com/citations?user=QGlp5ywAAAAJ&hl=en">Benjamin Ummenhofer<sup>2</sup></a> </li>
          <li> <a href="https://shenlong.web.illinois.edu/">Shenlong Wang<sup>1</sup></a> </li>
        </ul>
        <ul class="list-inline">
          <li> <sup>1</sup>University of Illinois at Urbana-Champaign </li>
          <li> <sup>2</sup>Intel </li>
        </ul>
        <div style="font-size: 1.2em; margin-top: 15px;">NeurIPS 2025</div>
      </div>
    </div>

    <div class="row">
      <div class="col-sm-8 col-sm-offset-2 text-center">
        
        <span class="link-block">
          <a href="https://arxiv.org/pdf/2510.05560" class="external-link button is-normal is-rounded is-dark">
            <span class="icon">
              <svg class="svg-inline--fa fa-file-pdf fa-w-12" aria-hidden="true" focusable="false" data-prefix="fas"
                data-icon="file-pdf" role="img" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 384 512"
                data-fa-i2svg="">
                <path fill="currentColor"
                  d="M181.9 256.1c-5-16-4.9-46.9-2-46.9 8.4 0 7.6 36.9 2 46.9zm-1.7 47.2c-7.7 20.2-17.3 43.3-28.4 62.7 18.3-7 39-17.2 62.9-21.9-12.7-9.6-24.9-23.4-34.5-40.8zM86.1 428.1c0 .8 13.2-5.4 34.9-40.2-6.7 6.3-29.1 24.5-34.9 40.2zM248 160h136v328c0 13.3-10.7 24-24 24H24c-13.3 0-24-10.7-24-24V24C0 10.7 10.7 0 24 0h200v136c0 13.2 10.8 24 24 24zm-8 171.8c-20-12.2-33.3-29-42.7-53.8 4.5-18.5 11.6-46.6 6.2-64.2-4.7-29.4-42.4-26.5-47.8-6.8-5 18.3-.4 44.1 8.1 77-11.6 27.6-28.7 64.6-40.8 85.8-.1 0-.1.1-.2.1-27.1 13.9-73.6 44.5-54.5 68 5.6 6.9 16 10 21.5 10 17.9 0 35.7-18 61.1-61.8 25.8-8.5 54.1-19.1 79-23.2 21.7 11.8 47.1 19.5 64 19.5 29.2 0 31.2-32 19.7-43.4-13.9-13.6-54.3-9.7-73.6-7.2zM377 105L279 7c-4.5-4.5-10.6-7-17-7h-6v128h128v-6.1c0-6.3-2.5-12.4-7-16.9zm-74.1 255.3c4.1-2.7-2.5-11.9-42.8-9 37.1 15.8 42.8 9 42.8 9z">
                </path>
              </svg><!-- <i class="fas fa-file-pdf"></i> Font Awesome fontawesome.com -->
            </span>
            <span>Paper</span>
          </a>
        </span>
        
        <span class="link-block">
          <a href="https://github.com/xiahongchi/HoloScene" class="external-link button is-normal is-rounded is-dark">
            <span class="icon">
              <svg class="svg-inline--fa fa-github fa-w-16" aria-hidden="true" focusable="false" data-prefix="fab"
                data-icon="github" role="img" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 496 512" data-fa-i2svg="">
                <path fill="currentColor"
                  d="M165.9 397.4c0 2-2.3 3.6-5.2 3.6-3.3.3-5.6-1.3-5.6-3.6 0-2 2.3-3.6 5.2-3.6 3-.3 5.6 1.3 5.6 3.6zm-31.1-4.5c-.7 2 1.3 4.3 4.3 4.9 2.6 1 5.6 0 6.2-2s-1.3-4.3-4.3-5.2c-2.6-.7-5.5.3-6.2 2.3zm44.2-1.7c-2.9.7-4.9 2.6-4.6 4.9.3 2 2.9 3.3 5.9 2.6 2.9-.7 4.9-2.6 4.6-4.6-.3-1.9-3-3.2-5.9-2.9zM244.8 8C106.1 8 0 113.3 0 252c0 110.9 69.8 205.8 169.5 239.2 12.8 2.3 17.3-5.6 17.3-12.1 0-6.2-.3-40.4-.3-61.4 0 0-70 15-84.7-29.8 0 0-11.4-29.1-27.8-36.6 0 0-22.9-15.7 1.6-15.4 0 0 24.9 2 38.6 25.8 21.9 38.6 58.6 27.5 72.9 20.9 2.3-16 8.8-27.1 16-33.7-55.9-6.2-112.3-14.3-112.3-110.5 0-27.5 7.6-41.3 23.6-58.9-2.6-6.5-11.1-33.3 2.6-67.9 20.9-6.5 69 27 69 27 20-5.6 41.5-8.5 62.8-8.5s42.8 2.9 62.8 8.5c0 0 48.1-33.6 69-27 13.7 34.7 5.2 61.4 2.6 67.9 16 17.7 25.8 31.5 25.8 58.9 0 96.5-58.9 104.2-114.8 110.5 9.2 7.9 17 22.9 17 46.4 0 33.7-.3 75.4-.3 83.6 0 6.5 4.6 14.4 17.3 12.1C428.2 457.8 496 362.9 496 252 496 113.3 383.5 8 244.8 8zM97.2 352.9c-1.3 1-1 3.3.7 5.2 1.6 1.6 3.9 2.3 5.2 1 1.3-1 1-3.3-.7-5.2-1.6-1.6-3.9-2.3-5.2-1zm-10.8-8.1c-.7 1.3.3 2.9 2.3 3.9 1.6 1 3.6.7 4.3-.7.7-1.3-.3-2.9-2.3-3.9-2-.6-3.6-.3-4.3.7zm32.4 35.6c-1.6 1.3-1 4.3 1.3 6.2 2.3 2.3 5.2 2.6 6.5 1 1.3-1.3.7-4.3-1.3-6.2-2.2-2.3-5.2-2.6-6.5-1zm-11.4-14.7c-1.6 1-1.6 3.6 0 5.9 1.6 2.3 4.3 3.3 5.6 2.3 1.6-1.3 1.6-3.9 0-6.2-1.4-2.3-4-3.3-5.6-2z">
                </path>
              </svg><!-- <i class="fab fa-github"></i> Font Awesome fontawesome.com -->
            </span>
            <span>Code</span>
          </a>
        </span>

      </div>
    </div>

    <div class="row">
      <div class="col-sm-10 col-sm-offset-1 text-center">
        <img src="./src/images/teaser.png" class="img-responsive" alt="overview" width="100%"
            style="max-height: 450px;margin:auto;">
      </div>
    </div>


    <div class="row">
      <div class="col-md-10 col-md-offset-1">
        <h3>
            Abstract 
        </h3>
        <div class="text-justify">
          Digitizing the physical world into accurate simulation-ready virtual environments offers significant opportunities in a variety of fields such as augmented and virtual reality, gaming, and robotics. However, current 3D reconstruction and scene-understanding methods commonly fall short in one or more critical aspects, such as geometry completeness, object interactivity, physical plausibility, photorealistic rendering, or realistic physical properties for reliable dynamic simulation. To address these limitations, we introduce HoloScene, a novel interactive 3D reconstruction framework that simultaneously achieves these requirements. HoloScene leverages a comprehensive interactive scene-graph representation, encoding object geometry, appearance, and physical properties alongside hierarchical and inter-object relationships. Reconstruction is formulated as an energy-based optimization problem, integrating observational data, physical constraints, and generative priors into a unified, coherent objective. Optimization is efficiently performed via a hybrid approach combining sampling-based exploration with gradient-based refinement. The resulting digital twins exhibit complete and precise geometry, physical stability, and realistic rendering from novel viewpoints. Evaluations conducted on multiple benchmark datasets demonstrate superior performance, while practical use-cases in interactive gaming and real-time digital-twin manipulation illustrate HoloScene's broad applicability and effectiveness.
        </div>

      </div>
    </div>

    <div class="row">
      <div class="col-md-10 col-md-offset-1">
        <h3>
          Framework Overview
        </h3>
        <div class="text-justify">
          Given multiple posed images as well as some visual cues (instance masks, monocular geometry priors), we first employ a gradient-based optimization as the initialization. 
    Then we adopt a generative sampling and tree search strategy along the topology of the scene graph to obtain the complete geometry with physical plausibility.
    Finally, the final fine-tuning over the scene further enhances the realism of the reconstructed scene.
        </div>
      </div>
    </div>

    <div class="row">
      <div class="col-sm-10 col-sm-offset-1 text-center">
        <img src="./src/images/method.png" class="img-responsive" alt="overview" 
            style="max-height: 450px;margin:auto;">
      </div>
    </div>


    <!-- Result visualization -->
    <div class="row">
      <div class="col-md-10 col-md-offset-1">
        <h3>
          Watch our 3D Textured Object Visualization Here! (Click Load to start the visualization!)
        </h3>
        <div class="text-justify">
          Interactive 3D viewer for reconstructed objects. Drag to rotate, scroll to zoom, and toggle object visibility below.
        </div>
      </div>
    </div>

    <!-- 3D Viewer Container -->
    <div class="row">
      <div class="col-md-10 col-md-offset-1">
        <!-- Scene Selector -->
        <div id="scene-selector" style="margin-top: 20px;">
          <div style="margin-bottom: 10px; font-weight: bold; font-size: 16px; text-align: center;">Select Scene:</div>
          <div style="display: flex; justify-content: space-between; align-items: center; gap: 10px; margin-bottom: 20px;">
            <div id="scene-buttons" style="display: flex; flex-wrap: wrap; justify-content: flex-start; gap: 10px; flex: 1;">
              <!-- Scene buttons will be dynamically generated here -->
            </div>
            <button id="load-scene-btn" style="
              padding: 10px 30px;
              background-color: #4CAF50;
              color: white;
              border: none;
              border-radius: 4px;
              cursor: pointer;
              font-size: 16px;
              font-weight: bold;
              transition: all 0.3s;
              white-space: nowrap;
            ">Load</button>
          </div>
        </div>
        
        <div id="obj-viewer-container" style="width: 100%; height: 600px; background-color: #1a1a1a; border-radius: 8px; position: relative;">
          <div id="obj-viewer-canvas"></div>
          <div id="loading-indicator" style="position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); color: white; font-size: 18px; display: none;">
            Loading models...
          </div>
        </div>
        
        <!-- Visibility Controls -->
        <div id="visibility-controls" style="margin-top: 20px; text-align: center;">
          <div style="margin-bottom: 10px; font-weight: bold;">Object Visibility Controls:</div>
          <div id="visibility-buttons" style="display: flex; flex-wrap: wrap; justify-content: center; gap: 10px;">
            <!-- Buttons will be dynamically generated here -->
          </div>
        </div>
      </div>
    </div>

    <!-- Three.js and OBJLoader -->
    <script src="https://cdnjs.cloudflare.com/ajax/libs/three.js/r128/three.min.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/three@0.128.0/examples/js/loaders/OBJLoader.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/three@0.128.0/examples/js/loaders/MTLLoader.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/three@0.128.0/examples/js/controls/OrbitControls.js"></script>

    <script>
      // 3D OBJ Viewer Implementation
      (function() {
        // List of scenes with their names and URLs
        const SCENES = [
          {
            name: 'Replica',
            url: 'https://huggingface.co/datasets/hongchi/HoloScene/resolve/main/replica_room_0'
          },
          {
            name: 'ScanNet++',
            url: 'https://huggingface.co/datasets/hongchi/HoloScene/resolve/main/scannetpp_67d'
          },
          {
            name: 'iGibson',
            url: 'https://huggingface.co/datasets/hongchi/HoloScene/resolve/main/gibson_beechwood_0'
          },
          {
            name: 'UIUC Siebel Game Room',
            url: 'https://huggingface.co/datasets/hongchi/HoloScene/resolve/main/uiuc_siebel_game_room'
          }
        ];
        
        const MAX_OBJECTS = 100; // Maximum number of objects to try loading
        
        let scene, camera, renderer, controls;
        let loadedObjects = [];
        let objectMeshes = new Map(); // Map of index to mesh group
        let currentSceneIndex = 0;
        
        function init3DViewer() {
          const container = document.getElementById('obj-viewer-canvas');
          const loadingIndicator = document.getElementById('loading-indicator');
          
          // Set up axis to +Z (default is +Y)
          THREE.Object3D.DefaultUp.set(0, 0, 1);
          
          // Scene setup
          scene = new THREE.Scene();
          scene.background = new THREE.Color(0x1a1a1a);
          
          // Camera setup
          const width = container.parentElement.clientWidth;
          const height = container.parentElement.clientHeight;
          camera = new THREE.PerspectiveCamera(75, width / height, 0.1, 1000);
          camera.position.set(0.5, 0.5, 0.4);
          camera.up.set(0, 0, 1); // Set camera up vector to +Z
          
          // Renderer setup
          renderer = new THREE.WebGLRenderer({ antialias: true });
          renderer.setSize(width, height);
          renderer.shadowMap.enabled = true;
          container.appendChild(renderer.domElement);
          
          // Orbit controls
          controls = new THREE.OrbitControls(camera, renderer.domElement);
          controls.enableDamping = true;
          controls.dampingFactor = 0.05;
          controls.screenSpacePanning = false;
          controls.minDistance = 0.1;
          controls.maxDistance = 200;
          controls.target.set(0, 0, 0);
          
          // Lighting
          const ambientLight = new THREE.AmbientLight(0xffffff, 0.7);
          scene.add(ambientLight);
          
          const directionalLight1 = new THREE.DirectionalLight(0xffffff, 0.8);
          directionalLight1.position.set(5, 5, 10);
          directionalLight1.castShadow = true;
          scene.add(directionalLight1);
          
          const directionalLight2 = new THREE.DirectionalLight(0xffffff, 0.4);
          directionalLight2.position.set(-5, -5, 5);
          scene.add(directionalLight2);
          
          const directionalLight3 = new THREE.DirectionalLight(0xffffff, 0.3);
          directionalLight3.position.set(0, 0, -10);
          scene.add(directionalLight3);
          
          // Grid helper on XY plane (since Z is up)
          const gridHelper = new THREE.GridHelper(20, 20, 0x444444, 0x222222);
          gridHelper.rotation.x = Math.PI / 2; // Rotate to XY plane
          scene.add(gridHelper);
          
          // Add axes helper to visualize orientation
          const axesHelper = new THREE.AxesHelper(2);
          scene.add(axesHelper);
          
          // Handle window resize
          window.addEventListener('resize', onWindowResize, false);
          
          // Start animation loop
          animate();
          
          // Create scene selector buttons
          createSceneButtons();
          
          // Set up Load button
          setupLoadButton();
          
          // Don't load automatically - wait for user to click Load button
        }
        
        function onWindowResize() {
          const container = document.getElementById('obj-viewer-canvas');
          const width = container.parentElement.clientWidth;
          const height = container.parentElement.clientHeight;
          
          camera.aspect = width / height;
          camera.updateProjectionMatrix();
          renderer.setSize(width, height);
        }
        
        function animate() {
          requestAnimationFrame(animate);
          controls.update();
          renderer.render(scene, camera);
        }
        
        function createSceneButtons() {
          const sceneButtonsContainer = document.getElementById('scene-buttons');
          sceneButtonsContainer.innerHTML = ''; // Clear existing buttons
          
          SCENES.forEach((sceneInfo, index) => {
            const button = document.createElement('button');
            button.textContent = sceneInfo.name;
            button.id = `scene-btn-${index}`;
            
            const isActive = (index === currentSceneIndex);
            const activeColor = isActive ? '#2196F3' : '#757575';
            
            button.style.cssText = `
              padding: 10px 20px;
              background-color: ${activeColor};
              color: white;
              border: none;
              border-radius: 4px;
              cursor: pointer;
              font-size: 16px;
              font-weight: bold;
              transition: all 0.3s;
            `;
            
            button.addEventListener('click', function() {
              selectScene(index);
            });
            
            button.addEventListener('mouseenter', function() {
              if (index !== currentSceneIndex) {
                this.style.backgroundColor = '#9E9E9E';
              }
            });
            
            button.addEventListener('mouseleave', function() {
              if (index !== currentSceneIndex) {
                this.style.backgroundColor = '#757575';
              }
            });
            
            sceneButtonsContainer.appendChild(button);
          });
        }
        
        function setupLoadButton() {
          const loadButton = document.getElementById('load-scene-btn');
          
          loadButton.addEventListener('click', function() {
            loadScene(currentSceneIndex);
          });
          
          loadButton.addEventListener('mouseenter', function() {
            this.style.backgroundColor = '#45a049';
          });
          
          loadButton.addEventListener('mouseleave', function() {
            this.style.backgroundColor = '#4CAF50';
          });
        }
        
        function selectScene(sceneIndex) {
          currentSceneIndex = sceneIndex;
          
          // Update scene button styles
          SCENES.forEach((_, index) => {
            const button = document.getElementById(`scene-btn-${index}`);
            if (button) {
              button.style.backgroundColor = (index === sceneIndex) ? '#2196F3' : '#757575';
            }
          });
        }
        
        function loadScene(sceneIndex) {
          // Clear existing objects
          clearScene();
          
          // Load new scene
          loadOBJFiles(SCENES[sceneIndex].url);
        }
        
        function clearScene() {
          // Remove all loaded objects from the scene
          loadedObjects.forEach(obj => {
            scene.remove(obj.object);
          });
          
          // Clear arrays and maps
          loadedObjects = [];
          objectMeshes.clear();
          
          // Clear visibility buttons
          const buttonsContainer = document.getElementById('visibility-buttons');
          buttonsContainer.innerHTML = '';
        }
        
        function loadOBJFiles(objFolder) {
          const loadingIndicator = document.getElementById('loading-indicator');
          loadingIndicator.style.display = 'block';
          
          const objLoader = new THREE.OBJLoader();
          const mtlLoader = new THREE.MTLLoader();
          let loadedCount = 0;
          let errorCount = 0;
          
          // Try to load objects sequentially
          function loadNextObject(index) {
            if (index >= MAX_OBJECTS || errorCount > 5) {
              // Stop if we've tried too many or had too many consecutive errors
              loadingIndicator.style.display = 'none';
              if (loadedCount === 0) {
                loadingIndicator.textContent = 'No models found. Please check the folder path.';
                loadingIndicator.style.display = 'block';
              }
              return;
            }
            
            const objPath = `${objFolder}/surface_${index}.obj`;
            const mtlPath = `${objFolder}/surface_${index}.mtl`;
            
            // Try to load MTL file first
            mtlLoader.load(
              mtlPath,
              function(materials) {
                // MTL file exists, use it
                materials.preload();
                objLoader.setMaterials(materials);
                loadOBJWithMaterials(index, objPath, true);
              },
              undefined,
              function(error) {
                // MTL doesn't exist, load OBJ without materials
                loadOBJWithMaterials(index, objPath, false);
              }
            );
          }
          
          function loadOBJWithMaterials(index, objPath, hasMTL) {
            objLoader.load(
              objPath,
              function(object) {
                // Success - reset error count
                errorCount = 0;
                loadedCount++;
                
                // Apply material to all meshes in the object
                object.traverse(function(child) {
                  if (child instanceof THREE.Mesh) {
                    // Check if the geometry has vertex colors
                    const hasVertexColors = child.geometry.attributes.color !== undefined;
                    
                    if (!hasMTL) {
                      // No MTL file, create material based on vertex colors or random color
                      if (hasVertexColors) {
                        child.material = new THREE.MeshPhongMaterial({
                          vertexColors: true,
                          flatShading: false,
                          side: THREE.DoubleSide
                        });
                      } else {
                        // Create a random color for each object
                        const color = new THREE.Color();
                        color.setHSL(Math.random(), 0.7, 0.6);
                        
                        child.material = new THREE.MeshPhongMaterial({
                          color: color,
                          flatShading: false,
                          side: THREE.DoubleSide
                        });
                      }
                    } else {
                      // Has MTL, but ensure vertex colors are enabled if present
                      if (hasVertexColors && child.material) {
                        child.material.vertexColors = true;
                        child.material.needsUpdate = true;
                      }
                    }
                    
                    child.castShadow = true;
                    child.receiveShadow = true;
                  }
                });
                
                // Store the object
                objectMeshes.set(index, object);
                scene.add(object);
                
                // All objects visible by default
                const isVisible = true;
                object.visible = isVisible;
                loadedObjects.push({ index: index, object: object, visible: isVisible });
                
                // Update loading indicator
                loadingIndicator.textContent = `Loading models... (${loadedCount} loaded)`;
                
                // Create visibility button
                createVisibilityButton(index, isVisible);
                
                // Load next object
                loadNextObject(index + 1);
              },
              function(xhr) {
                // Progress callback (optional)
              },
              function(error) {
                // Error callback - file doesn't exist or can't be loaded
                errorCount++;
                // Try next object
                loadNextObject(index + 1);
              }
            );
          }
          
          // Start loading from index 0
          loadNextObject(0);
        }
        
        function createVisibilityButton(index, isVisible) {
          const buttonsContainer = document.getElementById('visibility-buttons');
          
          const button = document.createElement('button');
          button.textContent = `Object ${index}`;
          button.id = `obj-btn-${index}`;
          
          // Set initial color based on visibility
          const initialColor = isVisible ? '#4CAF50' : '#f44336';
          button.style.cssText = `
            padding: 8px 16px;
            background-color: ${initialColor};
            color: white;
            border: none;
            border-radius: 4px;
            cursor: pointer;
            font-size: 14px;
            transition: all 0.3s;
          `;
          
          button.addEventListener('click', function() {
            toggleObjectVisibility(index);
          });
          
          button.addEventListener('mouseenter', function() {
            if (this.style.backgroundColor === 'rgb(76, 175, 80)') { // Green
              this.style.backgroundColor = '#45a049';
            } else {
              this.style.backgroundColor = '#c62828';
            }
          });
          
          button.addEventListener('mouseleave', function() {
            const obj = loadedObjects.find(o => o.index === index);
            if (obj && obj.visible) {
              this.style.backgroundColor = '#4CAF50';
            } else {
              this.style.backgroundColor = '#f44336';
            }
          });
          
          buttonsContainer.appendChild(button);
        }
        
        function toggleObjectVisibility(index) {
          const obj = loadedObjects.find(o => o.index === index);
          if (obj) {
            obj.visible = !obj.visible;
            obj.object.visible = obj.visible;
            
            // Update button style
            const button = document.getElementById(`obj-btn-${index}`);
            if (obj.visible) {
              button.style.backgroundColor = '#4CAF50'; // Green
            } else {
              button.style.backgroundColor = '#f44336'; // Red
            }
          }
        }
        
        // Initialize when DOM is ready
        if (document.readyState === 'loading') {
          document.addEventListener('DOMContentLoaded', init3DViewer);
        } else {
          init3DViewer();
        }
      })();
    </script>


    <div class="row">
      <div class="col-md-10 col-md-offset-1">
        <h3>
          Interactive 3D Editing
        </h3>
        <div class="text-justify">
          In our simulation environment, we could also achieve high-quality interactive 3D editing by moving the object Gaussians 
          with its underlying physical mesh geometry. Here we demonstrate this by changing the location and orientation of the interactable chair.
        </div>
      </div>
    </div>

    <!-- Video section -->
    <div class="video-container  text-center" style="margin-top: 20px;">
      <video controls autoplay muted loop style="max-width: 800px; width: 100%; height: auto;">
          <source src="src/videos/int/editing/demo.mp4" type="video/mp4">
          Your browser does not support the video tag.
      </video>
    </div>

    <div class="row">
      <div class="col-md-10 col-md-offset-1">
        <h3>
          3D Printing of Reconstructed Scene
        </h3>
        <div class="text-justify">
          In order to demonstrate the geometry realism and physical plausibility of our reconstructed scene, we select our UIUC Siebel Game Room and print the reconstructed scene.
          Here we show an overview image, video, and interactions of human-3d printed scene. All objects are movable, and we selected some objects to show the interactions. 
          (Thanks to the printout by <a href="https://www.linkedin.com/in/hnyu/">Sydney Yu</a>.)

        <!-- Three media items in a row -->
        <div class="row text-center" style="margin-top: 20px;">
          <div class="col-xs-4">
              <img src="src/images/3dprint/3dprint_0.jpg" style="width: 100%; height: auto; display: block;" alt="3D printed scene overview" id="print-ref-img">
          </div>
          <div class="col-xs-4">
              <video controls autoplay muted loop style="width: 100%; height: 100%; object-fit: cover; aspect-ratio: 3/4;">
                  <source src="src/images/3dprint/3dprint_1.MOV" type="video/mp4">
                  Your browser does not support the video tag.
              </video>
          </div>
          <div class="col-xs-4">
              <video controls autoplay muted loop style="width: 100%; height: 100%; object-fit: cover; aspect-ratio: 3/4;">
                  <source src="src/images/3dprint/3dprint_2.MOV" type="video/mp4">
                  Your browser does not support the video tag.
              </video>
          </div>
        </div>
      </div>
    </div>

    <!-- Images and Video section -->
    


    <div class="row">
      <div class="col-md-10 col-md-offset-1">
        <h3>
          Dynamic Visual Effects
        </h3>
        <div class="text-justify">
          To enhance immersion, we augment the scene with dynamic
          visual effects, including rigid body simulations,
          character animations, and particle effects. We
          adopt visual effects from AutoVFX to
          overlay virtual content and shadows onto the
          image. As we can see from the following videos, we produce effects that
          blend naturally with the scene.
        </div>

        <!-- Three videos in a row -->
        <div class="row text-center" style="margin-top: 20px;">
          <div class="col-xs-4">
              <video controls autoplay muted loop style="width: 100%; height: auto;">
                  <source src="src/videos/int/vfx/blended_0.mp4" type="video/mp4">
                  Your browser does not support the video tag.
              </video>
              <p style="margin-top: 10px; font-style: italic;">Setting fire on the chair</p>
          </div>
          <div class="col-xs-4">
              <video controls autoplay muted loop style="width: 100%; height: auto;">
                  <source src="src/videos/int/vfx/blended_1.mp4" type="video/mp4">
                  Your browser does not support the video tag.
              </video>
              <p style="margin-top: 10px; font-style: italic;">Dropping box and balls</p>
          </div>
          <div class="col-xs-4">
              <video controls autoplay muted loop style="width: 100%; height: auto;">
                  <source src="src/videos/int/vfx/blended_2.mp4" type="video/mp4">
                  Your browser does not support the video tag.
              </video>
              <p style="margin-top: 10px; font-style: italic;">Insert animated characters</p>
          </div>
        </div>
      </div>
    </div>

    <div class="row">
      <div class="col-md-10 col-md-offset-1">
        <h3>
          Immersive Experience Recording
        </h3>
        <div class="text-justify">
          We show our interactable reconstructed 3D objects with immersive experience recording. 
          Given a static RGB video of a person manipulating an object, we can recover the object's 6D pose and resimulate its motion in a virtual 3D scene.
        </div>

        <!-- insert two videos in a row here -->
         <!-- Two videos in a row -->
        <div class="row">
          <div class="col-md-6 col-sm-6">
              <div class="video-container">
                <video controls autoplay muted loop style="width: 100%; height: auto;">
                  <source src="src/videos/int/immerse/obj1.mp4" type="video/mp4">
                  Your browser does not support the video tag.
                </video>
              </div>
          </div>
          <div class="col-md-6 col-sm-6">
              <div class="video-container">
                <video controls autoplay muted loop style="width: 100%; height: auto;">
                  <source src="src/videos/int/immerse/obj2.mp4" type="video/mp4">
                  Your browser does not support the video tag.
                </video>
              </div>
          </div>
        </div>
      </div>
    </div>

    <div class="row">
      <div class="col-md-10 col-md-offset-1">
        <h3>
          Physical Simulation
        </h3>
        <div class="text-justify">
          We compare geometry layouts and
          appearance within the physical simulation. HoloScene's complete, non-interpenetrating geometry remains stable in physics
          simulators, unlike baseline methods. Our Gaussian on mesh delivers high-quality, real-time rendering
          throughout the simulation process.
        </div>
      </div>
    </div>


    <div class="row">

      <br>
      <div class="col-md-12 col-md-offset-1">
        <div class="text-justify">
        Scenes from Scannet++ dataset:
        <br>
        <!-- <b>Replay the simulation by refreshing the page.</b>  -->
        </div>
      </div>

      <div class="col-md-12 col-md-offset-1">
        <!-- Two rows of videos layout -->
        <div id="video-section-1" style="margin-top: 20px; padding-left: 0; padding-right: 0;">
          <!-- First row: 1 image + 4 videos -->
          <div class="row text-center" style="padding-left: 0; padding-right: 0;">
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <img src="src/videos/physim/67d/DSC09303.JPG" alt="Description" style="width: 100%; height: auto;">
                  <p style="margin-top: 10px; font-style: italic;">Ref Image</p>
              </div>
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/67d/objectsdf/trace_video_t.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">ObjectSDF</p>
              </div>
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/67d/phyrecon/trace_video_t.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">PhyRecon</p>
              </div>
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/67d/dprecon/trace_video_t.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">DP-Recon</p>
              </div>
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/67d/ours/trace_video_t.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">Ours</p>
              </div>
          </div>
          
          <!-- Second row: 2 videos aligned with rightmost videos from first row -->
          <div class="row text-center" style="margin-top: 15px;  padding-left: 0; padding-right: 0;">
              <div class="col-xs-2 col-xs-offset-6" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/67d/dprecon/trace_video_t_shade.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">DP-Recon</p>
              </div>
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/67d/ours/trace_video_t_gs.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">Ours</p>
              </div>
          </div>
        </div>
      </div>

      <div class="col-md-12 col-md-offset-1">
        <!-- Two rows of videos layout -->
        <div id="video-section-2" style="margin-top: 20px; padding-left: 0; padding-right: 0;">
          <!-- First row: 1 image + 4 videos -->
          <div class="row text-center" style="padding-left: 0; padding-right: 0;">
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <img src="src/videos/physim/783/DSC04096.JPG" alt="Description" style="width: 100%; height: auto;">
                  <p style="margin-top: 10px; font-style: italic;">Ref Image</p>
              </div>
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/783/objectsdf/trace_video_t.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">ObjectSDF</p>
              </div>
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/783/phyrecon/trace_video_t.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">PhyRecon</p>
              </div>
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/783/dprecon/trace_video_t.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">DP-Recon</p>
              </div>
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/783/ours/trace_video_t.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">Ours</p>
              </div>
          </div>
          
          <!-- Second row: 2 videos aligned with rightmost videos from first row -->
          <div class="row text-center" style="margin-top: 15px;  padding-left: 0; padding-right: 0;">
              <div class="col-xs-2 col-xs-offset-6" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/783/dprecon/trace_video_t_shade.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">DP-Recon</p>
              </div>
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/783/ours/trace_video_t_gs.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">Ours</p>
              </div>
          </div>
        </div>
      </div>

      <br>
      <div class="col-md-12 col-md-offset-1">
        <div class="text-justify">
        Scene from Replica dataset:
        <br>
        <!-- <b>Replay the simulation by refreshing the page.</b>  -->
        </div>
      </div>

      <div class="col-md-12 col-md-offset-1">
        <!-- Two rows of videos layout -->
        <div id="video-section-3" style="margin-top: 20px; padding-left: 0; padding-right: 0;">
          <!-- First row: 1 image + 4 videos -->
          <div class="row text-center" style="padding-left: 0; padding-right: 0;">
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <img src="src/videos/physim/room2/frame000201.jpg" alt="Description" style="width: 100%; height: auto;">
                  <p style="margin-top: 10px; font-style: italic;">Ref Image</p>
              </div>
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/room2/objectsdf/trace_video_t.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">ObjectSDF</p>
              </div>
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/room2/phyrecon/trace_video_t.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">PhyRecon</p>
              </div>
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/room2/dprecon/trace_video_t.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">DP-Recon</p>
              </div>
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/room2/ours/trace_video_t.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">Ours</p>
              </div>
          </div>
          
          <!-- Second row: 2 videos aligned with rightmost videos from first row -->
          <div class="row text-center" style="margin-top: 15px;  padding-left: 0; padding-right: 0;">
              <div class="col-xs-2 col-xs-offset-6" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/room2/dprecon/trace_video_t_shade.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">DP-Recon</p>
              </div>
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/room2/ours/trace_video_t_gs.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">Ours</p>
              </div>
          </div>
        </div>
      </div>

      <br>
      <div class="col-md-12 col-md-offset-1">
        <div class="text-justify">
        Scene from iGibson dataset: DP-Recon fails to reconstruct the complete
        background mesh, leading to object falling in the figure.
        <br>
        <!-- <b>Replay the simulation by refreshing the page.</b>  -->
        </div>
      </div>

      <div class="col-md-12 col-md-offset-1">
        <!-- Two rows of videos layout -->
        <div id="video-section-4" style="margin-top: 20px; padding-left: 0; padding-right: 0;">
          <!-- First row: 1 image + 4 videos -->
          <div class="row text-center" style="padding-left: 0; padding-right: 0;">
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <img src="src/videos/physim/bw1/00142.png" alt="Description" style="width: 100%; height: auto;">
                  <p style="margin-top: 10px; font-style: italic;">Ref Image</p>
              </div>
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/bw1/objectsdf/trace_video_t.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">ObjectSDF</p>
              </div>
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/bw1/phyrecon/trace_video_t.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">PhyRecon</p>
              </div>
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/bw1/dprecon/trace_video_t.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">DP-Recon</p>
              </div>
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/bw1/ours/trace_video_t.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">Ours</p>
              </div>
          </div>
          
          <!-- Second row: 2 videos aligned with rightmost videos from first row -->
          <div class="row text-center" style="margin-top: 15px;  padding-left: 0; padding-right: 0;">
              <div class="col-xs-2 col-xs-offset-6" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/bw1/dprecon/trace_video_t_shade.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">DP-Recon</p>
              </div>
              <div class="col-xs-2" style="padding-left: 1px; padding-right: 1px;">
                  <video  autoplay muted  style="width: 100%; height: auto;padding-left: 0; padding-right: 0;">
                      <source src="src/videos/physim/bw1/ours/trace_video_t_gs.mp4" type="video/mp4">
                      Your browser does not support the video tag.
                  </video>
                  <p style="margin-top: 10px; font-style: italic;">Ours</p>
              </div>
          </div>
        </div>
      </div>


    </div>

    <div class="row">
      <div class="col-md-10 col-md-offset-1">
        <h3>
          Real-Time Interactive Game
        </h3>
        <div class="text-justify">
          We demonstrate our interactive game in Unreal Engine. 
          we build a third-person game with the reconstructed texture meshes. 
          The objects could be physically rearranged in the game world, 
          and the game agent could also interact with the scene through realistic physics.
        </div>
      </div>
    </div>

    <div class="glide" id="dynamic-carousel">
      <div class="glide__track" data-glide-el="track">
        <ul class="glide__slides">
          <li class="glide__slide">
            <video class="game" controls muted loop autoplay>
              <source src="src/videos/int/game/game1_1.mp4" type="video/mp4"/>
            </video>
          </li>
          <li class="glide__slide">
            <video class="game" controls muted loop autoplay>
              <source src="src/videos/int/game/game1_2.mp4" type="video/mp4"/>
            </video>
          </li>
          <li class="glide__slide">
            <video class="game" controls muted loop autoplay>
              <source src="src/videos/int/game/game1_3.mp4" type="video/mp4"/>
            </video>
          </li>
          <li class="glide__slide">
            <video class="game" controls muted loop autoplay>
              <source src="src/videos/int/game/game2_1.mp4" type="video/mp4"/>
            </video>
          </li>
          <li class="glide__slide">
            <video  class="game" controls muted loop autoplay>
              <source src="src/videos/int/game/game2_2.mp4" type="video/mp4"/>
            </video>
          </li>
          <li class="glide__slide">
            <video  class="game" controls muted loop autoplay>
              <source src="src/videos/int/game/game2_3.mp4" type="video/mp4"/>
            </video>
          </li>
          <li class="glide__slide">
            <video  class="game" controls muted loop autoplay>
              <source src="src/videos/int/game/game2_4.mp4" type="video/mp4"/>
            </video>
          </li>
        </ul>
      </div>


      <div class="glide__arrows" data-glide-el="controls">
        <span class="glide__arrow glide__arrow--left" data-glide-dir="<"><img src="resources/arrow-left-circle-fill.svg"/></span>
        <span class="glide__arrow glide__arrow--right" data-glide-dir=">"><img src="resources/arrow-right-circle-fill.svg"/></span>
      </div>
      <div class="glide__bullets" data-glide-el="controls[nav]">
        <span class="glide__bullet" data-glide-dir="=0"></span>
        <span class="glide__bullet" data-glide-dir="=1"></span>
        <span class="glide__bullet" data-glide-dir="=2"></span>
        <span class="glide__bullet" data-glide-dir="=3"></span>
        <span class="glide__bullet" data-glide-dir="=4"></span>
        <span class="glide__bullet" data-glide-dir="=5"></span>
        <span class="glide__bullet" data-glide-dir="=6"></span>
      </div>
    </div>

    <div class="row">
      <div class="col-md-10 col-md-offset-1">
        <h3>
          Bibtex
        </h3>
        <div class="bibtexsection">
      @misc{xia2025holoscene,
            title={HoloScene: Simulation-Ready Interactive 3D Worlds from a Single Video}, 
            author={Hongchi Xia and Chih-Hao Lin and Hao-Yu Hsu and Quentin Leboutet and Katelyn Gao and Michael Paulitsch and Benjamin Ummenhofer and Shenlong Wang},
            year={2025},
            eprint={2510.05560},
            archivePrefix={arXiv},
            primaryClass={cs.CV},
            url={https://arxiv.org/abs/2510.05560}, 
      }
        </div>
      </div>
    </div>



  </div>
</body>

</html>