<!DOCTYPE html>
<head>
    <meta charset="utf-8" />
    <title>Mani-GS: Gaussian Splatting Manipulation with Triangular Mesh</title>
	<link rel="icon" type="image/x-icon" href="../assets/css/images/favicon.ico">
    <meta content="Mani-GS: Gaussian Splatting Manipulation with Triangular Mesh" name="description" />
    <meta content="summary" name="twitter:card" />
    <meta content="width=device-width, initial-scale=1" name="viewport" />
    <link href="static/css/template.css" rel="stylesheet" type="text/css" />
    <link href="static/css/my_style.css" rel="stylesheet" type="text/css">
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css">
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/jpswalsh/academicons@1/css/academicons.min.css">
    
    <script src="https://ajax.googleapis.com/ajax/libs/webfont/1.6.26/webfont.js" type="text/javascript"></script>
    <script type="text/javascript">
        WebFont.load({
            google: {
                families: ["Lato:100,100italic,300,300italic,400,400italic,700,700italic,900,900italic", "Montserrat:100,100italic,200,200italic,300,300italic,400,400italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic", "Ubuntu:300,300italic,400,400italic,500,500italic,700,700italic", "Changa One:400,400italic", "Open Sans:300,300italic,400,400italic,600,600italic,700,700italic,800,800italic", "Varela Round:400", "Bungee Shade:regular", "Roboto:300,regular,500"]
            }
        });
    </script>
    <script type="text/javascript">
        ! function (o, c) {
            var n = c.documentElement,
                t = " w-mod-";
            n.className += t + "js", ("ontouchstart" in o || o.DocumentTouch && c instanceof DocumentTouch) && (n.className += t + "touch")
        }(window, document);
    </script>
    <link href="https://fonts.googleapis.com/css?family=Google+Sans|Noto+Sans|Castoro" rel="stylesheet">
    <script type="text/javascript" src="static/js/zoom.js"></script>
    <script type="text/javascript" src="static/js/video_comparison.js"></script>
    <!-- Google tag (gtag.js) -->
    <script async src="https://www.googletagmanager.com/gtag/js?id=G-MLDP9MKGC8"></script>
    <script>
    window.dataLayer = window.dataLayer || [];
    function gtag(){dataLayer.push(arguments);}
    gtag('js', new Date());

    gtag('config', 'G-MLDP9MKGC8');
    </script>
</head>

<body>

    <div class="section hero nerf-_v2">
        <div class="container-2 nerf_header_v2 w-container">
            <h1 class="nerf_title_v2">Mani-GS: Gaussian Splatting Manipulation with Triangular Mesh</h1>
            <div class="nerf_subheader_v2">
                <div>
                    <a>Anonymous Submission</a>
                </div>

            </div>
        </div>

    </div>

    <!-- <div data-anchor="slide1" class="section nerf_section">
        <div class="w-container grey_container">
            <p class="paragraph-3 nerf_text nerf_results_text">
                <b><i>TL;DR: &nbsp; &nbsp;</i> </b> 
                ConTex-Human is a single image to 3D Human model that enables texture-consistent and high-fidelity free view human rendering.
            </p>
        </div>
    </div> -->

    <div class="white_section_nerf  w-container">

        <div class="grid-container-1">
            <div>
                <!-- <p class="myprompt nerf_text">A dragon-cat hybrid <br>&nbsp</p> -->
                <video class="video" id="1" loop playsinline autoPlay muted controls
                src="assets/demo_r_30_cat.mp4" onplay="resizeAndPlay(this)"></video>
                <!-- <canvas class="videoMerge" id="1_merge"></canvas> -->
            </div>
        </div>

        <div class="grid-container-1">
            <img src="assets/teaser.png">
        </div>

    </div>

    <div data-anchor="slide1" class="section nerf_section">
        <div class="w-container grey_container">
            <h2 class="grey-heading_nerf">Abstract</h2>
            <p class="paragraph-3 nerf_text nerf_results_text">
                Neural 3D representations such as Neural Radiance Fields (NeRFs), excel at producing photo-realistic rendering 
                results but lack the flexibility for manipulation and editing which is crucial for content creation. Previous works 
                have attempted to address this issue by deforming a NeRF in canonical space or manipulating the radiance field based 
                on an explicit mesh. However, manipulating NeRF is not highly controllable and requires a long training and inference 
                time. With the emergence of 3D Gaussian Splatting (3DGS), extremely high-fidelity novel view synthesis can be achieved
                using an explicit point-based 3D representation with much faster training and rendering speed. However, there is still
                a lack of effective means to manipulate 3DGS freely while maintaining rendering quality. In this work, we aim to 
                tackle the challenge of achieving manipulable photo-realistic rendering. We propose to utilize a triangular mesh 
                to manipulate 3DGS directly with self-adaptation. This approach reduces the need to design various algorithms for
                different types of Gaussian manipulation. By utilizing a triangle shape-aware Gaussian binding and adapting method,
                we can achieve 3DGS manipulation and preserve high-fidelity rendering after manipulation. Our approach is capable
                of handling large deformations, local manipulations, and even physics simulations while keeping high-quality rendering.
                Furthermore, we demonstrate that our method is also effective with inaccurate meshes extracted from 3DGS. Experiments 
                conducted on NeRF synthetic datasets demonstrate the effectiveness of our method and its superiority over baseline approaches.
                <br>
            </p>
        </div>
    </div>

    <div class="white_section_nerf  w-container">
        <h2 class="grey-heading_nerf">Method Overview</h2>
        <div class="grid-container-1">
            <img src="assets/method_pipeline.png">
            
            <p style="font-size: 15px;font-family: Ubuntu; text-align: justify;">
                (1) Firstly, we extract a triangular mesh from 3DGS or a neural surface field. 
                (2) Next, we bind N Gaussians to each triangle in the local triangle space, and optmize the local gaussian 
                attributes ({u, R, s, o, c}). The triangle attributes ({u, R, e}) is calculated based on the triangle vertices. 
                (3) Finally, we manipulate the GS by transferring the mesh manipulation directly, thus achieving manipulable rendering.
            </p>
        </div>
    </div>
    
    <div class="white_section_nerf  w-container">
        <h2 class="grey-heading_nerf">Large Deformation</h2>
        <div class="grid-container-1">
            <div>
                <!-- <p class="myprompt nerf_text">A boy in mohawk hairstyle, head only, 4K, HD, raw</p> -->
                <video class="video" id="10" loop playsinline autoPlay muted controls
                src="assets/large_deformation/demo_deform_cat_white_lego.mp4" onplay="resizeAndPlay(this)"></video>
                <!-- <canvas class="videoMerge" id="10_merge"></canvas> -->
            </div>
            <div>
                <!-- <p class="myprompt nerf_text">A boy in mohawk hairstyle, head only, 4K, HD, raw</p> -->
                <video class="video" id="10" loop playsinline autoPlay muted controls
                src="assets/large_deformation/demo_deform_cat_white_chair.mp4" onplay="resizeAndPlay(this)"></video>
                <!-- <canvas class="videoMerge" id="10_merge"></canvas> -->
            </div>
            <div>
                <!-- <p class="myprompt nerf_text">A boy in mohawk hairstyle, head only, 4K, HD, raw</p> -->
                <video class="video" id="10" loop playsinline autoPlay muted controls
                src="assets/large_deformation/demo_deform_cat_white_ficus.mp4" onplay="resizeAndPlay(this)"></video>
                <!-- <canvas class="videoMerge" id="10_merge"></canvas> -->
            </div>
            <div>
                <!-- <p class="myprompt nerf_text">A boy in mohawk hairstyle, head only, 4K, HD, raw</p> -->
                <video class="video" id="10" loop playsinline autoPlay muted controls
                src="assets/large_deformation/demo_deform_cat_white_mic.mp4" onplay="resizeAndPlay(this)"></video>
                <!-- <canvas class="videoMerge" id="10_merge"></canvas> -->
            </div>
        </div>
    </div>



    <div class="white_section_nerf  w-container">
        <h2 class="grey-heading_nerf">Soft Body Simulation</h2>
        <div class="grid-container-3">
            <div>
                <!-- <p class="myprompt nerf_text">A dragon-cat hybrid <br>&nbsp</p> -->
                <video class="video" id="1" loop playsinline autoPlay muted controls
                src="assets/softbody/chair_soft_body/demo_white_r_80.mp4" onplay="resizeAndPlay(this)"></video>
                <!-- <canvas class="videoMerge" id="1_merge"></canvas> -->
            </div>
            <div>
                <!-- <p class="myprompt nerf_text">A dragon-cat hybrid <br>&nbsp</p> -->
                <video class="video" id="1" loop playsinline autoPlay muted controls
                src="assets/softbody/chair_soft_body/demo_white_r_50.mp4" onplay="resizeAndPlay(this)"></video>
                <!-- <canvas class="videoMerge" id="1_merge"></canvas> -->
            </div>
            <div>
                <!-- <p class="myprompt nerf_text">A dragon-cat hybrid <br>&nbsp</p> -->
                <video class="video" id="1" loop playsinline autoPlay muted controls
                src="assets/softbody/chair_soft_body/demo_white_r_30.mp4" onplay="resizeAndPlay(this)"></video>
                <!-- <canvas class="videoMerge" id="1_merge"></canvas> -->
            </div>
        </div>

        <div class="grid-container-3">
            <div>
                <!-- <p class="myprompt nerf_text">A dragon-cat hybrid <br>&nbsp</p> -->
                <video class="video" id="1" loop playsinline autoPlay muted controls
                src="assets/softbody/lego_soft_body/demo_white_r_6.mp4" onplay="resizeAndPlay(this)"></video>
                <!-- <canvas class="videoMerge" id="1_merge"></canvas> -->
            </div>
            <div>
                <!-- <p class="myprompt nerf_text">A dragon-cat hybrid <br>&nbsp</p> -->
                <video class="video" id="1" loop playsinline autoPlay muted controls
                src="assets/softbody/lego_soft_body/demo_white_r_125.mp4" onplay="resizeAndPlay(this)"></video>
                <!-- <canvas class="videoMerge" id="1_merge"></canvas> -->
            </div>
            <div>
                <!-- <p class="myprompt nerf_text">A dragon-cat hybrid <br>&nbsp</p> -->
                <video class="video" id="1" loop playsinline autoPlay muted controls
                src="assets/softbody/lego_soft_body/demo_white_r_50.mp4" onplay="resizeAndPlay(this)"></video>
                <!-- <canvas class="videoMerge" id="1_merge"></canvas> -->
            </div>
        </div>
    </div>


    <div class="white_section_nerf  w-container">
        <h2 class="grey-heading_nerf">Local Manipulation</h2>
        <div class="grid-container-1">
            <img src="assets/local_manipulation/local_mani.png">
        </div>
        <div class="grid-container-2">
            <div>
                <video class="video" id="1" loop playsinline autoPlay muted controls
                src="assets/local_manipulation/demo_white_lego.mp4" onplay="resizeAndPlay(this)"></video>
            </div>
            <div>
                <video class="video" id="1" loop playsinline autoPlay muted controls
                src="assets/local_manipulation/demo_white_hotdog.mp4" onplay="resizeAndPlay(this)"></video>
            </div>
        </div>
    </div>

    <div class="white_section_nerf  w-container">
        <h2 class="grey-heading_nerf">Manipulation Results on DTU</h2>
        <div class="grid-container-1">
            <img src="assets/DTU.png">
            
            <p style="font-size: 15px;font-family: Ubuntu; text-align: justify;">
                The left two columns showcase the geometry and rendered image before manipulation, 
                while the right three columns showcase the geometry and rendered image after manipulation.
                To highlight the deformed area, we have enclosed it within a red rectangle. The mesh proxy is extracted using screened poisson reconstruction and edited in Blender.
            </p>
        </div>
    </div>

    
<!-- <div class="white_section_nerf grey_container w-container">
<h2 class="grey-heading_nerf">BibTeX</h2>
<div class="bibtex">
    <pre><code>@article{mani-gs,
author    = {Xiangjun Gao and Xiaoyu Li and Chaopeng Zhang and Qi Zhang and Yanpei Cao and Ying Shan and Long Quan},
title     = {Contex-Human},
journal   = {arxiv:2312.},
year      = {2023},
}</code></pre>
</div>
</div> -->

</body>

</html>
