<!DOCTYPE html>
<html>

<head>
    <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>

    <!-- Google tag (gtag.js) -->
    <script async src="https://www.googletagmanager.com/gtag/js?id=G-XB3PR2Y1TQ"></script>
    <script>
        window.dataLayer = window.dataLayer || [];

        function gtag() {
            dataLayer.push(arguments);
        }
        gtag('js', new Date());

        gtag('config', 'G-XB3PR2Y1TQ');
    </script>

    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0, shrink-to-fit=no">
    <title>Triangle Splatting</title>
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.5.0/css/bootstrap.min.css">
    <link href='https://fonts.googleapis.com/css?family=Source+Sans+Pro:300,400,500,600' rel='stylesheet'
        type='text/css'>
    <link rel="stylesheet" href="assets/css/Highlight-Clean.css">
    <link rel="stylesheet" href="assets/css/styles.css">
    <!-- compare two images -->
    <!-- <link rel="stylesheet" href="assets/css/bulma.min.css"> -->
    <link rel="stylesheet" href="assets/css/bulma-carousel.min.css">
    <link rel="stylesheet" href="assets/css/bulma-slider.min.css">

    <link rel="apple-touch-icon" sizes="180x180" href="assets/logo.png">
    <link rel="icon" type="image/png" sizes="32x32" href="assets/logo.png">
    <link rel="icon" type="image/png" sizes="16x16" href="assets/logo.png">


    <link rel="manifest" href="site.webmanifest">

    <meta property="og:site_name" content="Triangle Splatting for Real-Time Radiance Field Rendering" />
    <meta property="og:type" content="video.other" />
    <meta property="og:title" content="Triangle Splatting for Real-Time Radiance Field Rendering" />
    <meta property="og:description" content="Triangle Splatting for Real-Time Radiance Field Rendering, 2025." />

    <script src="assets/js/video_comparison.js"></script>
    <script type="module" src="https://unpkg.com/@google/model-viewer@2.0.1/dist/model-viewer.min.js"></script>

    <script src="assets/js/bulma-carousel.min.js"></script>
    <script src="assets/js/bulma-slider.min.js"></script>


    <style>
        .small-bal-container {
            width: 560px; /* Set the desired width */
            height: 322px; /* Set the height proportional to the aspect ratio (e.g., 16:9) */
            margin: 0 auto; /* Center the images */
            position: relative; /* Maintain the positioning for the slider and labels */
            overflow: hidden; /* Ensure content stays within the container */
        }
    
        .small-bal-container img {
            width: 100%;
            height: 100%;
            object-fit: cover; /* Ensure images scale proportionally */
        }
        .carousel-control-prev-icon,
        .carousel-control-next-icon {
            background-color: black; /* Black circle */
            border-radius: 50%; /* Make it circular */
            width: 50px; /* Larger circle width */
            height: 50px; /* Larger circle height */
            display: flex;
            justify-content: center;
            align-items: center;
            border: 3px solid white; /* White border around the circle */
        }

        .carousel-control-prev-icon::after,
        .carousel-control-next-icon::after {
            content: ''; /* Remove default arrow */
            display: inline-block;
            width: 8px; /* Slightly larger arrow width */
            height: 8px; /* Slightly larger arrow height */
            border: solid white; /* White arrow */
        }

        .carousel-control-prev-icon::after {
            border-width: 0 4px 4px 0; /* Adjust arrow thickness */
            transform: rotate(135deg); /* Left arrow */
            margin-left: -3px; /* Centering tweak */
        }

        .carousel-control-next-icon::after {
            border-width: 0 4px 4px 0; /* Adjust arrow thickness */
            transform: rotate(-45deg); /* Right arrow */
            margin-right: -3px; /* Centering tweak */
        }
    </style>


</head>

<body>

    <div class="highlight-clean" style="padding-bottom: 1;">
        <div class="container" style="max-width: 100%; margin-bottom: 10px;">
            <h1 class="text-center" style="margin-bottom: 5px;">Triangle Splatting for Real-Time Radiance Field Rendering</h1>
        </div>
        
        

        <div class="container">
        
            <hr class="divider" />
            <h2></h2>
            
            <div class="row">
                <!-- Example 2 -->
                <div class="col-md-6">
                    <h5 class="text-center">2D Gaussian Splatting vs Triangle Splatting</h5>
                    <div id="example2" class="bal-container-small small-bal-container">
                        <div class="bal-wrapper">
                            <div class="bal-after">
                                <img src="assets/comparisons/Compressed/stump_ts.png" alt="Example 2 After">
                                <div class="bal-afterPosition afterLabel">
                                    Triangle Splatting (Ours)
                                </div>
                            </div>
                            <div class="bal-before">
                                <div class="bal-before-inset">
                                    <img src="assets/comparisons/Compressed/stump_2dgs.png" alt="Example 2 Before">
                                    <div class="bal-beforePosition beforeLabel">
                                        2D Gaussian Splatting
                                    </div>
                                </div>
                            </div>
                            <div class="bal-handle">
                                <span class="handle-left-arrow"></span>
                                <span class="handle-right-arrow"></span>
                            </div>
                        </div>
                    </div>
                </div>
                <!-- Example 3 -->
                <div class="col-md-6">
                    <h5 class="text-center">Ground truth vs Triangle Splatting</h5>
                    <div id="example3" class="bal-container-small small-bal-container">
                        <div class="bal-wrapper">
                            <div class="bal-after">
                                <img src="assets/comparisons/Compressed/bonsai.png" alt="Example 3 After">
                                <div class="bal-afterPosition afterLabel">
                                    Triangle Splatting (Ours)
                                </div>
                            </div>
                            <div class="bal-before">
                                <div class="bal-before-inset">
                                    <img src="assets/comparisons/Compressed/bonsai_gt.png" alt="Example 3 Before">
                                    <div class="bal-beforePosition beforeLabel">
                                        Ground truth
                                    </div>
                                </div>
                            </div>
                            <div class="bal-handle">
                                <span class="handle-left-arrow"></span>
                                <span class="handle-right-arrow"></span>
                            </div>
                        </div>
                    </div>
                </div>
            </div>


            <div class="row">
                <!-- Example 2 -->
                <div class="col-md-6">
                    <div id="example6" class="bal-container-small small-bal-container">
                        <div class="bal-wrapper">
                            <div class="bal-after">
                                <img src="assets/comparisons/Compressed/bicycle_ts.png" alt="Example 2 After">
                                <div class="bal-afterPosition afterLabel">
                                    Triangle Splatting (Ours)
                                </div>
                            </div>
                            <div class="bal-before">
                                <div class="bal-before-inset">
                                    <img src="assets/comparisons/Compressed/bicycle_2dgs.png" alt="Example 2 Before">
                                    <div class="bal-beforePosition beforeLabel">
                                        2D Gaussian Splatting
                                    </div>
                                </div>
                            </div>
                            <div class="bal-handle">
                                <span class="handle-left-arrow"></span>
                                <span class="handle-right-arrow"></span>
                            </div>
                        </div>
                    </div>
                </div>
                <!-- Example 3 -->
                <div class="col-md-6">
                    <div id="example7" class="bal-container-small small-bal-container">
                        <div class="bal-wrapper">
                            <div class="bal-after">
                                <img src="assets/comparisons/Compressed/room_ts2.png" alt="Example 3 After">
                                <div class="bal-afterPosition afterLabel">
                                    Triangle Splatting (Ours)
                                </div>
                            </div>
                            <div class="bal-before">
                                <div class="bal-before-inset">
                                    <img src="assets/comparisons/Compressed/room_gt2.png" alt="Example 3 Before">
                                    <div class="bal-beforePosition beforeLabel">
                                        Ground truth
                                    </div>
                                </div>
                            </div>
                            <div class="bal-handle">
                                <span class="handle-left-arrow"></span>
                                <span class="handle-right-arrow"></span>
                            </div>
                        </div>
                    </div>
                </div>
            </div>


            <div class="row">
                <!-- Example 2 -->
                <div class="col-md-6">
                    <div id="example4" class="bal-container-small small-bal-container">
                        <div class="bal-wrapper">
                            <div class="bal-after">
                                <img src="assets/comparisons/Compressed/room_ts.png" alt="Example 2 After">
                                <div class="bal-afterPosition afterLabel">
                                    Triangle Splatting (Ours)
                                </div>
                            </div>
                            <div class="bal-before">
                                <div class="bal-before-inset">
                                    <img src="assets/comparisons/Compressed/room_2dgs.png" alt="Example 2 Before">
                                    <div class="bal-beforePosition beforeLabel">
                                        2D Gaussian Splatting
                                    </div>
                                </div>
                            </div>
                            <div class="bal-handle">
                                <span class="handle-left-arrow"></span>
                                <span class="handle-right-arrow"></span>
                            </div>
                        </div>
                    </div>
                </div>
                <!-- Example 3 -->
                <div class="col-md-6">
                    <div id="example5" class="bal-container-small small-bal-container">
                        <div class="bal-wrapper">
                            <div class="bal-after">
                                <img src="assets/comparisons/Compressed/garden_ts2.png" alt="Example 3 After">
                                <div class="bal-afterPosition afterLabel">
                                    Triangle Splatting (Ours)
                                </div>
                            </div>
                            <div class="bal-before">
                                <div class="bal-before-inset">
                                    <img src="assets/comparisons/Compressed/garden_gt2.png" alt="Example 3 Before">
                                    <div class="bal-beforePosition beforeLabel">
                                        Ground truth
                                    </div>
                                </div>
                            </div>
                            <div class="bal-handle">
                                <span class="handle-left-arrow"></span>
                                <span class="handle-right-arrow"></span>
                            </div>
                        </div>
                    </div>
                </div>
            </div>

        </div>

        <p class="text-center" style="padding-top: 10px; margin: 0 auto; max-width: 1100px;">
            Triangle Splatting achieves high-quality novel view synthesis and fast rendering by representing scenes with triangles.
        In contrast, the inherent softness of Gaussian primitives often leads to blurring and a loss of fine details, for example, beneath the bench or at the room’s door, whereas Triangle Splatting preserves sharp edges and accurately captures fine details.        
        </p>



        <div class="container">
            <hr class="divider" />
            <h2></h2>
             <h2 style="font-weight: bold;">Geometry accuracy</h2>
            <div class="row">
                <!-- Example 2 -->
                <div class="col-md-6">
                    <div id="examplenorm1" class="bal-container-small small-bal-container">
                        <div class="bal-wrapper">
                            <div class="bal-after">
                                <img src="assets/comparisons/Compressed/truck_ts.png" alt="Example 2 After">
                                <div class="bal-afterPosition afterLabel">
                                    RGB image
                                </div>
                            </div>
                            <div class="bal-before">
                                <div class="bal-before-inset">
                                    <img src="assets/comparisons/Compressed/truck_normal.png" alt="Example 2 Before">
                                    <div class="bal-beforePosition beforeLabel">
                                        Normal map
                                    </div>
                                </div>
                            </div>
                            <div class="bal-handle">
                                <span class="handle-left-arrow"></span>
                                <span class="handle-right-arrow"></span>
                            </div>
                        </div>
                    </div>
                </div>
                <!-- Example 3 -->
                <div class="col-md-6">
                    <div id="examplenorm2" class="bal-container-small small-bal-container">
                        <div class="bal-wrapper">
                            <div class="bal-after">
                                <img src="assets/comparisons/Compressed/garden_normal_rgb.png" alt="Example 3 After">
                                <div class="bal-afterPosition afterLabel">
                                    RGB image
                                </div>
                            </div>
                            <div class="bal-before">
                                <div class="bal-before-inset">
                                    <img src="assets/comparisons/Compressed/garden_normal.png" alt="Example 3 Before">
                                    <div class="bal-beforePosition beforeLabel">
                                        Normal map
                                    </div>
                                </div>
                            </div>
                            <div class="bal-handle">
                                <span class="handle-left-arrow"></span>
                                <span class="handle-right-arrow"></span>
                            </div>
                        </div>
                    </div>
                </div>
            </div>

        </div>
            

        <p class="text-center" style="padding-top: 10px; margin: 0 auto; max-width: 1100px;">
            The triangles are well aligned with the underlying geometry. All triangles share a consistent orientation and lie flat on the surface.
        </p>

        
        
        <hr class="divider" />
        <div class="container" style="max-width: col-sm-12;">
            <h2 style="font-weight: bold;">More Visual Results</h2>
            

            <div class="row">
                <div class="col-md-6">
                    <div id="example12" class="bal-container-small small-bal-container">
                        <div class="bal-wrapper">
                            <div class="bal-after">
                                <video  src="assets/video/flowers.mp4" autoplay loop muted playsinline class="img-fluid"></video>
                                <div class="bal-afterPosition afterLabel">
                                    Triangle Splatting (Ours)
                                </div>
                            </div>
                            <div class="bal-before">
                                <div class="bal-before-inset">
                                    <video  src="assets/video/flowers_gauss.mp4" autoplay loop muted playsinline class="img-fluid"></video>
                                    <div class="bal-beforePosition beforeLabel">
                                        3D Gaussian Splatting
                                    </div>
                                </div>
                            </div>
                            <div class="bal-handle">
                                <span class="handle-left-arrow"></span>
                                <span class="handle-right-arrow"></span>
                            </div>
                        </div>
                    </div>
                </div>
                <!-- Example 2 -->
                <div class="col-md-6">
                    <div id="example11" class="bal-container-small small-bal-container">
                        <div class="bal-wrapper">
                            <div class="bal-after">
                                <video  src="assets/video/bicycle_ts.mp4" autoplay loop muted playsinline class="img-fluid"></video>
                                <div class="bal-afterPosition afterLabel">
                                    Triangle Splatting (Ours)
                                </div>
                            </div>
                            <div class="bal-before">
                                <div class="bal-before-inset">
                                    <video  src="assets/video/bicycle_cvx.mp4" autoplay loop muted playsinline class="img-fluid"></video>
                                    <div class="bal-beforePosition beforeLabel">
                                        3D Convex Splatting
                                    </div>
                                </div>
                            </div>
                            <div class="bal-handle">
                                <span class="handle-left-arrow"></span>
                                <span class="handle-right-arrow"></span>
                            </div>
                        </div>
                    </div>
                </div>
            </div>


            <p style="text-align: justify;">
                Triangle Splatting produces sharper and more detailed images. Notably, it renders the flowers and the background with greater realism and captures finer details compared to 3DGS or 3DCS. (If the videos appear out of sync, please reload the page to ensure proper alignment.
)
            </p>
        </div>



        <div class="container">
        <hr class="divider" />
        <h2 style="font-weight: bold;">Byproduct of the Triangle-Based Representation</h2>
        <div class="row">
            <div class="col-md-6 text-center">
                <video class="img-fluid" autoplay muted loop playsinline>
                    <source src="assets/video/room_unity.mp4" type="video/mp4">
                    Your browser does not support the video tag.
                </video>
            </div>
            <div class="col-md-6 text-center">
                <video class="img-fluid" autoplay muted loop playsinline>
                    <source src="assets/video/garden_unity.mp4" type="video/mp4">
                    Your browser does not support the video tag.
                </video>
            </div>
        </div>
    </div>


        
        <p class="text-center" style="padding-top: 10px; margin: 0 auto; max-width: 1100px;">
            Triangle Splatting unifies differentiable scene optimization with traditional graphics pipelines. The triangle soup is compatible with any mesh-based
            renderer, enabling seamless integration into traditional graphics pipelines. 
            In a game engine, we render at 2400+ FPS at 1280×720 resolution on an RTX4090.

            <br><br>
            The current visuals are rendered without shaders and were not specifically trained or optimized for game engine fidelity, which accounts for the limited visual quality. 
            Nevertheless, it demonstrates an important first step toward the direct integration of radiance fields into interactive 3D environments. 
            Future work could explore training strategies specifically tailored to maximize visual fidelity in mesh-based renderers, paving the way for seamless integration of reconstructed scenes into standard game engines for real-time applications such as AR/VR or interactive simulations.
        </p>






        <script src="https://polyfill.io/v3/polyfill.js?features=IntersectionObserver"></script>
        <script src="assets/js/yall.js"></script>
        <script>
            yall({
                observeChanges: true
            });
        </script>
        <script src="assets/js/scripts.js"></script>
        <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
        <script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.5.0/js/bootstrap.bundle.min.js">
        </script>
        <script src="https://uploads-ssl.webflow.com/51e0d73d83d06baa7a00000f/js/webflow.fd002feec.js"></script>
        <!-- Import the component -->

        <script>
            document.addEventListener('DOMContentLoaded', (event) => {
                var video = document.getElementById('speed025');
                video.playbackRate = 0.1; // Play at half speed
            });
        </script>
       
        <script>
            new BeforeAfter({
                id: '#example1'
            });
        </script>

        <script>
            new BeforeAfter({
                id: '#example2'
            });
        </script>

        <script>
            new BeforeAfter({
                id: '#example3'
            });
        </script>


        <script>
            new BeforeAfter({
                id: '#example4'
            });
        </script>

        <script>
            new BeforeAfter({
                id: '#example5'
            });
        </script>

        <script>
            new BeforeAfter({
                id: '#examplenorm1'
            });
        </script>

        <script>
            new BeforeAfter({
                id: '#examplenorm2'
            });
        </script>



        <script>
            new BeforeAfter({
                id: '#example6'
            });
        </script>


        <script>
            new BeforeAfter({
                id: '#example7'
            });
        </script>


        <script>
            new BeforeAfter({
                id: '#example11'
            });
        </script>

        <script>
            new BeforeAfter({
                id: '#example12'
            });
        </script>

        <script>
            new BeforeAfter({
                id: '#example13'
            });
        </script>

        <script>
            new BeforeAfter({
                id: '#example14'
            });
        </script>

        <script src="https://code.jquery.com/jquery-3.5.1.slim.min.js"></script>
        <script src="https://cdn.jsdelivr.net/npm/@popperjs/core@2.9.3/dist/umd/popper.min.js"></script>
        <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.5.0/js/bootstrap.min.js"></script>


</body>

</html>
