<!DOCTYPE html>
<html>

<head lang="en">
    <meta charset="UTF-8">
    <meta http-equiv="x-ua-compatible" content="ie=edge">

    <title>3D Gaussian Exact and Efficient Rendering</title>
    <style>
        .highlight-row {
            background-color: #fffae6; /* 柔和黄色高亮 */
            transition: background-color 0.3s ease;
        }
        .highlight-our {
            background-color: #e6ffe7; /* 柔和绿色高亮 */
            transition: background-color 0.3s ease;
        }
        .checkbox-group {
          margin-bottom: 16px;
        }
      
        .checkbox-label {
          display: flex;
          align-items: center;
          font-size: 16px;
          font-weight: normal;
          margin-bottom: 10px;
          cursor: pointer;
          transition: background-color 0.2s ease;
        }
      
        .checkbox-label:hover {
          background-color: #f5f5f5;
          border-radius: 6px;
        }
      
        /* 隐藏原始 checkbox */
        .checkbox-label input[type="checkbox"] {
          display: none;
        }
      
        /* 自定义 checkbox 外框 */
        .custom-checkbox {
          flex-shrink: 0;  /* 不允许被压缩 */
          width: 16px;
          height: 16px;
          border: 2px solid #333;
          border-radius: 3px;
          margin-right: 10px;
          position: relative;
        }
      
        /* 显示勾 ✔️ */
        .checkbox-label input[type="checkbox"]:checked + .custom-checkbox::after {
          content: '';
          position: absolute;
          left: 3px;
          top: 0px;
          width: 6px;
          height: 10px;
          border: solid #333;
          border-width: 0 2px 2px 0;
          transform: rotate(45deg);
        }
      
        /* 禁止点击样式 */
        .readonly {
            cursor: default !important;
        }

        .readonly:hover {
            background-color: transparent !important;
        }

        table.uniform-table {
          border-collapse: collapse;
          width: 100%;
          font-size: small;
        }
        .uniform-table th,
        .uniform-table td {
          border: 1px solid #ccc;
          padding: 4px;
        }
      </style>

    <meta name="description"
        content="3DGEER: 3D Gaussian Rendering Made Exact and Efficient for Generic Cameras">
    <meta name="viewport" content="width=device-width, initial-scale=1">

    <!--FACEBOOK-->
    <meta property="og:type" content="website" />
    <meta property='og:video' content="https://youtu.be/KjF_UxBhxPc" />
    <meta property="og:title" content="3DGEER" />
    <meta property="og:description"
        content="3DGEER: 3D Gaussian Rendering Made Exact and Efficient for Generic Cameras" />

    <!--TWITTER-->
    <meta name="twitter:card" content="player" />
    <meta name="twitter:title" content="3DGEER" />
    <meta name="twitter:description"
        content="Project page for 3DGEER: 3D Gaussian Rendering Made Exact and Efficient for Generic Cameras">
    <meta name="twitter:player" content="https://youtu.be/KjF_UxBhxPc" />
    <meta name="twitter:player:width" content="640">
    <meta name="twitter:player:height" content="360">

    <link rel="icon" href="/paint.png">
    <!-- Place favicon.ico in the root directory -->

    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css">
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.4.0/css/font-awesome.min.css">
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/codemirror/5.8.0/codemirror.min.css">
    <link rel="stylesheet" href="assets/css/bog/app.css">

    <link rel="stylesheet" href="assets/css/bog/bootstrap.min.css">

    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script>
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/codemirror/5.8.0/codemirror.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/1.5.3/clipboard.min.js"></script>

    
    <script src="https://polyfill.io/v3/polyfill.min.js?features=es6"></script>
    <script type="text/javascript" id="MathJax-script" async
        src="https://cdn.jsdelivr.net/npm/mathjax@3/es5/tex-chtml.js">
    </script>

    <script src="http://www.google.com/jsapi" type="text/javascript"></script>
    <script type="text/javascript">google.load("jquery", "1.3.2");</script>
    <script>
        MathJax = {
        tex: {
            inlineMath: [['$', '$'], ['\\(', '\\)']]
        },
        options: {
            skipHtmlTags: ['script', 'noscript', 'style', 'textarea', 'pre']
        },
        chtml: {
            scale: 0.9,
            mathmlSpacing: false,
            exFactor: ".6em",
            displayAlign: 'left',
            displayIndent: '2em',
            matchFontHeight: true,
            scriptspace: .5,
            skipAttributes: {},
            ex: 6,
            width: 'container',
            linebreaks: { automatic: true },
            fontURL: 'https://cdn.jsdelivr.net/npm/mathjax@3/es5/output/chtml/fonts/woff-v2',
            adaptiveCSS: true
        },
        loader: {
            load: ['[tex]/ams']
        }
        };
    </script>  
    <script src="https://polyfill.io/v3/polyfill.min.js?features=es6"></script>
    <script id="MathJax-script" async src="https://cdn.jsdelivr.net/npm/mathjax@3/es5/tex-mml-chtml.js"></script>


    <script defer src="https://cdn.jsdelivr.net/npm/img-comparison-slider@8/dist/index.js"></script>
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/img-comparison-slider@8/dist/styles.css"/>
    <style>
        .before,
        .after {
          margin: 0;
        }
      
        .before figcaption,
        .after figcaption {
          background: #fff;
          border: 1px solid #c0c0c0;
          border-radius: 12px;
          color: #2e3452;
          opacity: 0.8;
          padding: 12px;
          position: absolute;
          top: 50%;
          transform: translateY(-50%);
          line-height: 100%;
        }
      
        .before figcaption {
          left: 12px;
        }
      
        .after figcaption {
          right: 12px;
        }
    </style>


    <link rel="stylesheet" href="assets/css/bog/dics.min.css">
    <script src="assets/js/bog/dics.min.js"></script>
    <script src="assets/js/bog/video_comparison.js"></script>
    <script>
        document.addEventListener('DOMContentLoaded', domReady);
        function domReady() {
            for (const e of document.querySelectorAll(".b-dics")) {
                new Dics({
                    container: e,
                    textPosition: "top"
                });
            }
        }
    </script>
</head>

<body>
    <div class="container" id="main">
        <div class="row">
            <h2 class="col-md-12 text-center">
                <b>3DGEER</b>: 3D Gaussian Rendering <br> Made Exact and Efficient for Generic Cameras </br>
            </h2>
        </div>
        <div class="row">
            <div class="col-md-12 text-center">
                <ul class="list-inline">
                    <li>
                        In Anonymous Submission
                    </li>
                </ul>
            </div>
        </div>

        <div class="row">
            <div class="col-md-12 text-center">
            </h5>
        </div>

        <div class="row">
            <div class="col-md-6 col-md-offset-3 text-center">
            </div>
        </div>

        <div class="row">
            <div class="col-md-8 col-md-offset-2">
                <video class="video" width="100%" id="teaser" loop playsinline autoplay muted src="video/teaser.mp4" onplay="resizeAndPlay(this)" style="height: 0px;"></video>
                <canvas height=0 class="videoMerge" id="teaserMerge"></canvas>
			</div>
            <div class="col-md-8 col-md-offset-2">
                <p class="text-center" style="font-size: 18px;">
                    Can Gaussian rendering be both exact and fast <br>without relying on lossy splatting? 
                <span style="color:#DF62D3; font-size: 18px;"><b>Checkout our 3D-GEER!</b></span>
                </p>
			</div>
        </div>

        <div class="row">
            <div class="col-md-8 col-md-offset-2">
                <h3>
                    Abstract
                </h3>
                <p class="text-justify">
                    3D Gaussian Splatting (3DGS) achieves an appealing balance between rendering quality and efficiency, but relies on approximating 3D Gaussians as 2D projections—an assumption that degrades accuracy, especially under generic large field-of-view (FoV) cameras. Despite recent extensions, no prior work has simultaneously achieved both projective exactness and real-time efficiency for general cameras. We introduce 3DGEER, a geometrically exact and efficient Gaussian rendering framework. From first principles, we derive a closed-form expression for integrating Gaussian density along a ray, enabling precise forward rendering and differentiable optimization under arbitrary camera models. To retain efficiency, we propose the Particle Bounding Frustum (PBF), which provides tight ray–Gaussian association without BVH traversal, and the Bipolar Equiangular Projection (BEAP), which unifies FoV representations, accelerates association, and improves reconstruction quality. Experiments on both pinhole and fisheye datasets show that 3DGEER outperforms prior methods across all metrics, runs 5x faster than existing projective exact ray-based baselines, and generalizes to wider FoVs unseen during training—establishing a new state of the art in real-time radiance field rendering.
                </p>
            </div>
        </div>

        <div class="row" style="margin-top: 10px;">
            <div class="col-md-8 col-md-offset-2">
                <h3>
                    Video
                </h3>
                <div class="text-center">
                    <div style="position:relative;padding-top:56.25%;">
                        <iframe src="https://www.youtube.com/embed/KjF_UxBhxPc" allowfullscreen
                            style="position:absolute;top:0;left:0;width:100%;height:100%;"></iframe>
                    </div>
                </div>
            </div>
        </div>

        

        <div class="row comp-margin" style="margin-top: 10px;">
            <div class="col-md-8 col-md-offset-2">
                <h3>
                    Visual Result <small>(<a href="comparison/index_result.html">click to zoom-in.</a>)</small>
                </h3>
            </div>
            <div class="col-md-8 col-md-offset-2">
                <h4>
                    High-Quality Large FoV Results
                </h4>
                <table width="100%">
                    <tr>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <video width="100%"  muted loop autoplay>
                                <source src="comparison/results/our_video/scannet3.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <video width="100%"  muted loop autoplay>
                                <source src="comparison/results/our_video/scannet1.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <video width="100%"  muted loop autoplay>
                                <source src="comparison/results/our_video/alameda1_web.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <video width="100%"  muted loop autoplay>
                                <source src="comparison/results/our_video/alameda2_web.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                    </tr>
                    <tr>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <video width="100%"  muted loop autoplay>
                                <source src="comparison/results/our_video/alameda3_web.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <video width="100%"  muted loop autoplay>
                                <source src="comparison/results/our_video/berlin5_web.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <video width="100%"  muted loop autoplay>
                                <source src="comparison/results/our_video/scannet4.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <video width="100%"  muted loop autoplay>
                                <source src="comparison/results/our_video/berlin2_web.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                    </tr>
                    <tr>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <video width="100%"  muted loop autoplay>
                                <source src="comparison/results/our_video/berlin1_web.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <video width="100%"  muted loop autoplay>
                                <source src="comparison/results/our_video/london1_web.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <video width="100%"  muted loop autoplay>
                                <source src="comparison/results/our_video/london2_web.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <video width="100%"  muted loop autoplay>
                                <source src="comparison/results/our_video/nyc1_web.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                    </tr>
                </table>
            </div>
            <div class="col-md-8 col-md-offset-2">
                <h4>
                    Highly Distorted & Close-Up Views
                </h4>
                <table width="100%">
                    <tr>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <video width="100%"  muted loop autoplay>
                                <source src="comparison/results/our_video/berlin3_web.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <video width="100%"  muted loop autoplay>
                                <source src="comparison/results/our_video/berlin4_web.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <video width="100%"  muted loop autoplay>
                                <source src="comparison/results/our_video/berlin8_web.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <video width="100%"  muted loop autoplay>
                                <source src="comparison/results/our_video/nyc2_web.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                    </tr>
                </table>
            </div>
            <div class="col-md-8 col-md-offset-2">
                <h4>
                    Cross-Camera Rendering <small>(train: FE 1/8; test: PH 1/4)</small>
                </h4>
                <table width="100%">
                    <tr>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <video width="100%"  muted loop autoplay>
                                <source src="comparison/results/our_video/fish2pin_demo1.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <video width="100%"  muted loop autoplay>
                                <source src="comparison/results/our_video/fish2pin_demo2.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <video width="100%"  muted loop autoplay>
                                <source src="comparison/results/our_video/fish2pin_demo3.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <video width="100%"  muted loop autoplay>
                                <source src="comparison/results/our_video/fish2pin_demo4.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                    </tr>
                </table>
                <p class="text-justify" style="color: gray; margin-top: 10px;">⚠️ HD video loading time may vary based on your internet speed and available browser memory.</p>
            </div>
            <div class="col-md-8 col-md-offset-2">
                <h3>
                    Visual Comparison <small>(<a href="comparison/index_comp.html">check more results.</a>)</small>
                </h3>
                <p class="text-justify">3DGEER outperforms both 3DGS-based (Gaussian Splatting) and 3DPRT-based (Particle Ray Tracing) approaches on novel view 
                    synthesis benchmarks — including MipNeRF360 (pinhole), ScanNet++ (fisheye) and ZipNeRF (mix). 3DGEER achieves high rendering fidelity while 
                    remaining runtime-efficient — 5× faster than 3DPRT (e.g., EVER, 3DGRT) and comparable to 3DGS, with no sacrifice in projective exactness.
                </p>
            </div>
            <div class="col-md-8 col-md-offset-2">
                <h4>
                    MipNeRF360 (Pinhole)
                </h4>
                <p class="text-justify">
                    3DGS <small>(PSNR: 27.21; FPS: 343)</small> v.s. 3DGRT <small>(PSNR: 27.20; FPS: 52)</small> v.s. 3DGEER (Ours) <small>(PSNR: 27.76; FPS:327)</small>
                </p>
                <table width="100%">
                    <tr>
                        <td align="left" valign="top" width="30%" style="padding-right: 5px; padding-left: 5px;">
                            <img-comparison-slider>
                                <figure slot="first" class="before rounded">
                                    <img width="100%" src="comparison/results/comparisons/others/3DGS_1.png" class="rounded">
                                    <figcaption style="font-size: 0.6em;">3DGS</figcaption>
                                </figure>
                                <figure slot="second" class="after rounded">
                                    <img width="100%" src="comparison/results/comparisons/others/our_1.png" class="rounded">
                                    <figcaption style="font-size: 0.6em;">Ours</figcaption>
                                </figure>
                            </img-comparison-slider>
                        </td>
                        <td align="left" valign="top" width="30%" style="padding-right: 5px; padding-left: 5px;">
                            <img-comparison-slider>
                                <figure slot="first" class="before rounded">
                                    <img width="100%" src="comparison/results/comparisons/others/3DGRT_1.png" class="rounded">
                                    <figcaption style="font-size: 0.6em;">3DGRT</figcaption>
                                </figure>
                                <figure slot="second" class="after rounded">
                                    <img width="100%" src="comparison/results/comparisons/others/our_1.png" class="rounded">
                                    <figcaption style="font-size: 0.6em;">Ours</figcaption>
                                </figure>
                            </img-comparison-slider>
                        </td>
                        <td align="left" valign="top" width="30%" style="padding-right: 5px; padding-left: 5px;">
                            <img-comparison-slider>
                                <figure slot="first" class="before rounded">
                                    <img width="100%" src="comparison/results/comparisons/others/GT_1.png" class="rounded">
                                    <figcaption style="font-size: 0.6em;">Groundtruth</figcaption>
                                </figure>
                                <figure slot="second" class="after rounded">
                                    <img width="100%" src="comparison/results/comparisons/others/our_1.png" class="rounded">
                                    <figcaption style="font-size: 0.6em;">Ours</figcaption>
                                </figure>
                            </img-comparison-slider>
                        </td>
                    </tr>
                </table>
            </div>
            <div class="col-md-8 col-md-offset-2">
                <h4>
                    ScanNet++ (Fisheye)
                </h4>
                <p class="text-justify">
                    FisheyeGS <small>(PSNR:27.81; FPS:213)</small> v.s. EVER <small>(PSNR: 29.47; FPS: 13)</small> v.s. 3DGEER (Ours) <small>(PSNR: 31.50; FPS: 251)</small>
                </p>
                <table width="100%">
                    <tr>
                        <td align="left" valign="top" width="30%" style="padding-right: 5px; padding-left: 5px;">
                            <img-comparison-slider>
                                <figure slot="first" class="before rounded">
                                    <img width="100%" src="comparison/results/comparisons/others/FisheyeGS_40.png" class="rounded">
                                    <figcaption style="font-size: 0.6em;">FisheyeGS</figcaption>
                                </figure>
                                <figure slot="second" class="after rounded">
                                    <img width="100%" src="comparison/results/comparisons/others/our_40.png" class="rounded">
                                    <figcaption style="font-size: 0.6em;">Ours</figcaption>
                                </figure>
                            </img-comparison-slider>
                        </td>
                        <td align="left" valign="top" width="30%" style="padding-right: 5px; padding-left: 5px;">
                            <img-comparison-slider>
                                <figure slot="first" class="before rounded">
                                    <img width="100%" src="comparison/results/comparisons/others/EVER_40.png" class="rounded">
                                    <figcaption style="font-size: 0.6em;">EVER</figcaption>
                                </figure>
                                <figure slot="second" class="after rounded">
                                    <img width="100%" src="comparison/results/comparisons/others/our_40.png" class="rounded">
                                    <figcaption style="font-size: 0.6em;">Ours</figcaption>
                                </figure>
                            </img-comparison-slider>
                        </td>
                        <td align="left" valign="top" width="30%" style="padding-right: 5px; padding-left: 5px;">
                            <img-comparison-slider>
                                <figure slot="first" class="before rounded">
                                    <img width="100%" src="comparison/results/comparisons/others/GT_40.png" class="rounded">
                                    <figcaption style="font-size: 0.6em;">Groundtruth</figcaption>
                                </figure>
                                <figure slot="second" class="after rounded">
                                    <img width="100%" src="comparison/results/comparisons/others/our_40.png" class="rounded">
                                    <figcaption style="font-size: 0.6em;">Ours</figcaption>
                                </figure>
                            </img-comparison-slider>
                        </td>
                    </tr>
                </table>
            </div>
            <div class="col-md-8 col-md-offset-2">
                <h4>
                    ZipNeRF Close-Up Views <small>(<a href="comparison/index_zip_2.html">click to zoom-in.</a>)</small>
                </h4>
                <p class="text-justify">
                    Our method (3DGEER) can handle soft shadow / lights or close views where the solid ellipsoid-based model (EVER) suffers.
                </p>
                <table width="100%">
                    <tr>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <p style="text-align: center;">EVER</p>
                            <video id="video_comp5" width="100%"  muted loop autoplay>
                                <source src="comparison/results/comparisons/videos/EVER_3.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <p style="text-align: center;">Ours</p>
                            <video id="video_comp6" width="100%"  muted loop autoplay>
                                <source src="comparison/results/comparisons/videos/our_3.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <p style="text-align: center;">EVER</p>
                            <video id="video_comp7" width="100%"  muted loop autoplay>
                                <source src="comparison/results/comparisons/videos/EVER_4.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <p style="text-align: center;">Ours</p>
                            <video id="video_comp8" width="100%"  muted loop autoplay>
                                <source src="comparison/results/comparisons/videos/our_4.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                    </tr>
                </table>
            </div>
            <div class="col-md-8 col-md-offset-2">
                <h4>
                    ZipNeRF Large FoV Views <small>(<a href="comparison/index_zip_1.html">click to zoom-in.</a>)</small>
                </h4>
                <p class="text-justify">
                    3DGUT and FisheyeGS are based on equidistant model for representations, which fail in much wider FoV. (See paper Fig. 5). 
                    Our method (3DGEER) can effectively sample rays in larger FoV regions and show much better results.
                </p>
                <table width="100%">
                    <tr>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <p style="text-align: center;">3DGUT</p>
                            <video id="video_comp1" width="100%"  muted loop autoplay>
                                <source src="comparison/results/comparisons/videos/3DGUT_1.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <p style="text-align: center;">Ours</p>
                            <video id="video_comp2" width="100%"  muted loop autoplay>
                                <source src="comparison/results/comparisons/videos/our_1.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <p style="text-align: center;">FisheyeGS</p>
                            <video id="video_comp3" width="100%"  muted loop autoplay>
                                <source src="comparison/results/comparisons/videos/fisheyeGS_2.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                        <td align="left" valign="top" width="22%" style="padding-right: 5px; padding-left: 5px;">
                            <p style="text-align: center;">Ours</p>
                            <video id="video_comp4" width="100%"  muted loop autoplay>
                                <source src="comparison/results/comparisons/videos/our_2.mp4" type="video/mp4">
                                Your browser does not support the video tag.
                            </video>
                        </td>
                    </tr>
                </table>
                <p class="text-justify" style="color: gray; margin-top: 10px;">⚠️ HD video loading time may vary based on your internet speed and available browser memory.</p>

            </div>
        </div>

        </div>

        
        <div class="row">
            <div class="col-md-8 col-md-offset-2">
                <h3>
                    Acknowledgements
                </h3>
                <p class="text-justify">
                    The website template was borrowed from <a href="http://mgharbi.com/">Michaël
                        Gharbi</a> and <a href="https://jonbarron.info/mipnerf360/">MipNeRF360</a>.
                </p>
            </div>
        </div>
    </div>


    <script>


        const videos = [document.getElementById('video_comp1'),
                        document.getElementById('video_comp2')];
      
        // Wait for both to know their durations
        Promise.all(videos.map(v =>
          v.readyState >= 1
            ? Promise.resolve()
            : new Promise(r => v.onloadedmetadata = r)
        )).then(() => {
          // Compute your common period: e.g. the max of their natural lengths
          const period = Math.max(...videos.map(v => v.duration));
      
          videos.forEach(v => {
            // playbackRate = naturalDuration ÷ targetPeriod
            v.playbackRate = v.duration / period;
            // now each video will take exactly `period` seconds per loop
          });
        });
    
        const videos2 = [document.getElementById('video_comp3'),
                        document.getElementById('video_comp4')];
      
        // Wait for both to know their durations
        Promise.all(videos2.map(v =>
          v.readyState >= 1
            ? Promise.resolve()
            : new Promise(r => v.onloadedmetadata = r)
        )).then(() => {
          // Compute your common period: e.g. the max of their natural lengths
          const period = Math.max(...videos2.map(v => v.duration));
      
          videos2.forEach(v => {
            // playbackRate = naturalDuration ÷ targetPeriod
            v.playbackRate = v.duration / period;
            // now each video will take exactly `period` seconds per loop
          });
        });
    
        const videos3 = [document.getElementById('video_comp5'),
                        document.getElementById('video_comp6')];
      
        // Wait for both to know their durations
        Promise.all(videos3.map(v =>
          v.readyState >= 1
            ? Promise.resolve()
            : new Promise(r => v.onloadedmetadata = r)
        )).then(() => {
          // Compute your common period: e.g. the max of their natural lengths
          const period = Math.max(...videos3.map(v => v.duration));
      
          videos3.forEach(v => {
            // playbackRate = naturalDuration ÷ targetPeriod
            v.playbackRate = v.duration / period;
            // now each video will take exactly `period` seconds per loop
          });
        });
    
        const videos4 = [document.getElementById('video_comp7'),
                        document.getElementById('video_comp8')];
      
        // Wait for both to know their durations
        Promise.all(videos4.map(v =>
          v.readyState >= 1
            ? Promise.resolve()
            : new Promise(r => v.onloadedmetadata = r)
        )).then(() => {
          // Compute your common period: e.g. the max of their natural lengths
          const period = Math.max(...videos4.map(v => v.duration));
      
          videos4.forEach(v => {
            // playbackRate = naturalDuration ÷ targetPeriod
            v.playbackRate = v.duration / period;
            // now each video will take exactly `period` seconds per loop
          });
        });

        // 互斥逻辑
        const checkboxA1 = document.getElementById('checkboxA1');
        const checkboxB1 = document.getElementById('checkboxB1');

        checkboxA1.addEventListener('change', () => {
            if (checkboxA1.checked) checkboxB1.checked = false;
        });

        checkboxB1.addEventListener('change', () => {
            if (checkboxB1.checked) checkboxA1.checked = false;
        });

        // 禁止更改 "Our method" 部分
        document.getElementById('checkboxA2').addEventListener('click', e => e.preventDefault());
        document.getElementById('checkboxB2').addEventListener('click', e => e.preventDefault());


        document.querySelectorAll('input[type="checkbox"]').forEach(cb => {
            cb.addEventListener('change', () => {
            // 清空所有行的高亮
            document.querySelectorAll('tr').forEach(row => row.classList.remove('highlight-row'));

            // 找出所有当前被勾选的 checkbox
            document.querySelectorAll('input[type="checkbox"]:checked').forEach(checkedBox => {
                const targets = checkedBox.dataset.target?.split(' ') || [];
                targets.forEach(id => {
                const row = document.getElementById(id);
                if (row) row.classList.add('highlight-row');
                });
            });
            });
        });
    </script>
      
</body>

</html>