<!DOCTYPE html>
<html>

<head>
    <script>
    window.dataLayer = window.dataLayer || [];
    </script>

    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0, shrink-to-fit=no">
    <title>VD3D: Taming Large Video Diffusion Transformers for 3D Camera Control</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="data/assets/css/styles.css">

    <link rel="apple-touch-icon" sizes="180x180" href="apple-touch-icon.png">
    <link rel="manifest" href="site.webmanifest">

    <meta property="og:site_name" content="VD3D" />
    <meta property="og:type" content="video.other" />
    <meta property="og:title" content="VD3D: Taming Large Video Diffusion Transformers for 3D Camera Control" />
    <meta property="og:description" content="VD3D: Taming Large Video Diffusion Transformers for 3D Camera Control." />
    <meta property="og:url" content="" />

</head>

<body>
    <div class="highlight-clean" style="padding-bottom: 0px; padding-top: 20px;">
        <div class="container" style="max-width: 1024px; margin-bottom: 20px">
            <h1 class="text-center" style="font-size:33px;"><b>VD3D</b>: Taming Large Video Diffusion Transformers for 3D Camera Control</h1>
        </div>
        <div id="container">
        <div class="buttons" style="margin-top: 8px; margin-bottom: 8px;">
            <a class="btn btn-light" role="button" href="ood.html">
                <svg style="width:24px;height:24px;margin-left:-12px;margin-right:12px" width="24px" height="24px" viewBox="0 0 375 531">
                    <polygon stroke="#000000" points="0.5,0.866 459.5,265.87 0.5,530.874 "></polygon>
                </svg>
                OOD
            </a>
            <a class="btn btn-light" role="button" href="gallery.html">
                <svg style="width:24px;height:24px;margin-left:-12px;margin-right:12px" width="24px" height="24px" viewBox="0 0 375 531">
                    <polygon stroke="#000000" points="0.5,0.866 459.5,265.87 0.5,530.874 "></polygon>
                </svg>
                Results
            </a>
            <a class="btn btn-light" role="button" href="gallery_comparisons.html">
                <svg style="width:24px;height:24px;margin-left:-12px;margin-right:12px" width="24px" height="24px" viewBox="0 0 375 531">
                    <polygon stroke="#000000" points="0.5,0.866 459.5,265.87 0.5,530.874 "></polygon>
                </svg>
                Comparisons
            </a>
        </div>
        </div>
    </div>
    <hr class="divider" />
    <div class="container" style="max-width: 768px;">
        <div class="compositional captioned_videos">
            <video class="video lazy" autoplay loop playsinline muted>
                <source data-src="data/videos/teaser.mp4" type="video/mp4"></source>
            </video>
        </div>
    </div>
    <hr class="divider" />
    <div class="container" style="max-width: 768px;">
        <div class="row">
            <div class="col-md-12">
                <div class="row">
                    <div class="col-sm-12">
                        <h2>Abstract</h2>
                    </div>
                </div>
                <p>
                    Modern text-to-video synthesis models demonstrate coherent, photorealistic generation of complex videos from a text description. However, most existing models lack fine-grained control over camera movement, which is critical for downstream applications related to content creation, visual effects, and 3D vision. Recently, new methods demonstrate the ability to generate videos with controllable camera poses-these techniques leverage pre-trained U-Net-based diffusion models that explicitly disentangle spatial and temporal generation. Still, no existing approach enables camera control for new, transformer-based video diffusion models that process spatial and temporal information jointly. Here, we propose to tame video transformers for 3D camera control using a ControlNet-like conditioning mechanism that incorporates spatiotemporal camera embeddings based on Plucker coordinates. The approach demonstrates state-of-the-art performance for controllable video generation after fine-tuning on the RealEstate10K dataset. To the best of our knowledge, our work is the first to enable camera control for transformer-based video diffusion models.
                </p>
            </div>
        </div>
    </div>
    <hr class="divider" />
    <div class="container" style="max-width: 768px;">
        <div class="row">
            <div class="col-sm-12">
                <h2>Method</h2>
            </div>
        </div>
        <div class="row captioned_videos">
            <div class="col-md-12">
                <p>
                    We adapt a FIT-based architecture to incorporate camera control. We take the noisy input video, camera extrinsics, and camera intrinsics for each video frame as input. We compute the Plücker coordinates for each pixel within the video frames using the camera parameters. The input video and Plücker coordinate frames are converted to patch tokens, and we condition the video patch tokens using a mechanism similar to ControlNet. Then, the model estimates the denoised video by recurrent application of FIT blocks. Each block reads information from the patch tokens into a small set of latent tokens on which computation is performed. The results are written to the patch tokens in an iterative denoising diffusion process.
                </p>
                &nbsp;
                <img src="data/method.png" alt="architecture" style="width: 100%">
            </div>
        </div>
    </div>
    <hr class="divider" />
    <div class="container" style="max-width: 768px;">
        <div class="row">
            <div class="col-sm-12">
                <h2>Comparisons for 3D Camera Control in Dynamic Scenes</h2>
            </div>
        </div>
        <div class="row" style="margin-bottom: 0px;">
            <div class="col-xs-25 compare-title  compare-title-sm">
                <p>Reference Trajectory Video</p>
            </div>
            <div class="col-xs-25 compare-title">
                <p>Ours</p>
            </div>
            <div class="col-xs-25 compare-title  compare-title-sm">
                <p>CameraCtrl</p>
            </div>
            <div class="col-xs-25 compare-title  compare-title-sm">
                <p>MotionCtrl</p>
            </div>
        </div>
        <div class="row captioned_videos">
            <div class="video-compare-container" style="width: 100%">
                <video class="video lazy" id="vid0" loop playsinline autoPlay muted src="data/videos/comparisons/videos_out/14.mp4"></video>
            </div>
            <div class="compare-title">
                <h6 class="caption" style="font-size:14px;margin-bottom:2%">A hamster wearing virtual reality headsets is a dj in a disco</h6>
            </div>
            <div class="col-xs-100">
                <div class="video-compare-container" style="width: 100%">
                    <video class="video lazy" id="vid1" loop playsinline autoPlay muted src="data/videos/comparisons/videos_out/18.mp4"></video>
                </div>
                <div class="compare-title">
                    <h6 class="caption" style="font-size:14px;margin-bottom:2%">A man with a skull face in flames walking around Piccadilly circus</h6>
                </div>
            </div>
            <div class="col-xs-100">
                <div class="video-compare-container" style="width: 100%">
                    <video class="video lazy" id="vid3" loop playsinline autoPlay muted src="data/videos/comparisons/videos_out/25.mp4"></video>
                </div>
                <div class="compare-title">
                    <h6 class="caption" style="font-size:14px;margin-bottom:2%">A trio of fashionable, beret-clad cats sips coffee at a chic Parisian cafe</h6>
                </div>
            </div>
            <div class="col-xs-100">
                <div class="video-compare-container" style="width: 100%">
                    <video class="video lazy" id="vid4" loop playsinline autoPlay muted src="data/videos/comparisons/videos_out/26.mp4"></video>
                </div>
                <div class="compare-title">
                    <h6 class="caption" style="font-size:14px;margin-bottom:2%">Across a sun-soaked desert, two sports cars engage in a high-speed chase</h6>
                </div>
            </div>
            <div class="col-xs-100">
                <div class="video-compare-container" style="width: 100%">
                    <video class="video lazy" id="vid5" loop playsinline autoPlay muted src="data/videos/comparisons/videos_out/30.mp4"></video>
                </div>
                <div class="compare-title">
                    <h6 class="caption" style="font-size:14px;margin-bottom:2%">An astronaut cooking with a pan and fire in the kitchen</h6>
                </div>
            </div>
        </div>
        <div class="col-sm-4 my-auto center" style="margin-left:auto; margin-right: auto;">
            <a href="gallery_comparisons.html" class="btn btn-primary btn-lg btn-search">
                More Comparisons
            </a>
        </div>
    </div>
    <hr class="divider" />
    <div class="container" style="max-width: 768px;">
        <div class="row">
            <div class="col-sm-12">
                <h2>3D Camera Control in Dynamic Scenes</h2>
            </div>
        </div>
        <div class="row" style="margin-bottom: 0px;">
            <div class="col-xs-33 compare-title  compare-title-sm">
                <p>Camera Input</p>
            </div>
            <div class="col-xs-33 compare-title  compare-title-sm">
                <p>Reference Trajectory Video</p>
            </div>
            <div class="col-xs-33 compare-title">
                <p>Camera Controlled Generation</p>
            </div>
        </div>
        <div class="row captioned_videos">
            <div class="col-xs-33">
                <center>
                <div class="video-compare-container" style="width: 100%">
                    <img src="data/videos/ours_cameras/37.png" width="66%" height="66%">
                </div>
                </center>
            </div>
            <div class="col-xs-64">
                <div class="video-compare-container" style="width: 100%">
                    <video class="video lazy" id="ex16" loop playsinline autoPlay muted src="data/videos/ours/37/00000_00015.mp4"></video>
                </div>
                <div class="compare-title" style="width: 47%;margin-left: 53%">
                    <h6 class="caption" style="font-size:11px">Cats engage in a strategic chess match on an ornate board</h6>
                </div>
            </div>
        </div>
        <div class="row captioned_videos">
            <div class="col-xs-33">
                <center>
                <div class="video-compare-container" style="width: 100%">
                    <img src="data/videos/ours_cameras/0.png" width="66%" height="66%">
                </div>
                </center>
            </div>
            <div class="col-xs-64">
                <div class="video-compare-container" style="width: 100%">
                    <video class="video lazy" id="ex16" loop playsinline autoPlay muted src="data/videos/ours/0/00000_00141.mp4"></video>
                </div>
                <div class="compare-title" style="width: 47%;margin-left: 53%">
                    <h6 class="caption" style="font-size:11px">3 sheep enjoying spaghetti together</h6>
                </div>
            </div>
        </div>
        <div class="row captioned_videos">
            <div class="col-xs-33">
                <center>
                <div class="video-compare-container" style="width: 100%">
                    <img src="data/videos/ours_cameras/47.png" width="66%" height="66%">
                </div>
                </center>
            </div>
            <div class="col-xs-64">
                <div class="video-compare-container" style="width: 100%">
                    <video class="video lazy" id="ex16" loop playsinline autoPlay muted src="data/videos/ours/47/00000_00009.mp4"></video>
                </div>
                <div class="compare-title" style="width: 47%;margin-left: 53%">
                    <h6 class="caption" style="font-size:11px">A cat sits at a grand piano, its paws gracefully tapping the keys</h6>
                </div>
            </div>
        </div>
        <div class="row captioned_videos">
            <div class="col-xs-33">
                <center>
                <div class="video-compare-container" style="width: 100%">
                    <img src="data/videos/ours_cameras/17.png" width="66%" height="66%">
                </div>
                </center>
            </div>
            <div class="col-xs-64">
                <div class="video-compare-container" style="width: 100%">
                    <video class="video lazy" id="ex16" loop playsinline autoPlay muted src="data/videos/ours/17/00000_00468.mp4"></video>
                </div>
                <div class="compare-title" style="width: 47%;margin-left: 53%">
                    <h6 class="caption" style="font-size:11px">A huge dinosaur skeleton is walking in a golden wheat field on a bright sunny day</h6>
                </div>
            </div>
        </div>
        <div class="row captioned_videos">
            <div class="col-xs-33">
                <center>
                <div class="video-compare-container" style="width: 100%">
                    <img src="data/videos/ours_cameras/21.png" width="66%" height="66%">
                </div>
                </center>
            </div>
            <div class="col-xs-64">
                <div class="video-compare-container" style="width: 100%">
                    <video class="video lazy" id="ex16" loop playsinline autoPlay muted src="data/videos/ours/21/00000_00158.mp4"></video>
                </div>
                <div class="compare-title" style="width: 47%;margin-left: 53%">
                    <h6 class="caption" style="font-size:11px">A mouse in renaissance clothing eating a cheese slic</h6>
                </div>
            </div>
        </div>
        <div class="col-sm-4 my-auto center" style="margin-left:auto; margin-right: auto;">
            <a href="gallery.html" class="btn btn-primary btn-lg btn-search">
                More Results
            </a>
        </div>
    </div>
    <hr class="divider" />
    <div class="container" style="max-width: 768px;">
        <div class="row">
            <div class="col-sm-12">
                <h2>3D Camera Control for Real Image-to-Multiview Scenes</h2>
            </div>
        </div>
        <div class="row captioned_videos">
            <div class="col-xs-33">
                <center>
                <div class="video-compare-container" style="width: 100%">
                    <img src="data/videos/image_to_multiview/cameras/0.png" width="66%" height="66%">
                </div>
                </center>
            </div>
            <div class="col-xs-33">
                <center>
                <div class="video-compare-container" style="width: 100%">
                    <img src="data/videos/image_to_multiview/cameras/1.png" width="66%" height="66%">
                </div>
                </center>
            </div>
            <div class="col-xs-33">
                <center>
                <div class="video-compare-container" style="width: 100%">
                    <img src="data/videos/image_to_multiview/cameras/2.png" width="66%" height="66%">
                </div>
                </center>
            </div>
        </div>
        <div class="row captioned_videos">
            <div class="col-4">
                <div class="video-compare-container" style="width: 100%">
                    <video class="video lazy" id="0" loop playsinline autoPlay muted src="data/videos/image_to_multiview/bed/0.mp4" onplay="resizeAndPlay(this)"></video>
                </div>
            </div>
            <div class="col-4">
                <div class="video-compare-container" style="width: 100%">
                    <video class="video lazy" id="1" loop playsinline autoPlay muted src="data/videos/image_to_multiview/bed/1.mp4" onplay="resizeAndPlay(this)"></video>
                </div>
            </div>
            <div class="col-4">
                <div class="video-compare-container" style="width: 100%">
                    <video class="video lazy" id="2" loop playsinline autoPlay muted src="data/videos/image_to_multiview/bed/2.mp4" onplay="resizeAndPlay(this)"></video>
                </div>
            </div>
            <h6 class="caption" style="font-size:11px">A bedroom with a bed, lamps and a window</h6>
        </div>

        <div class="row captioned_videos">
            <div class="col-4">
                <div class="video-compare-container" style="width: 100%">
                    <video class="video lazy" id="0" loop playsinline autoPlay muted src="data/videos/image_to_multiview/house/0.mp4" onplay="resizeAndPlay(this)"></video>
                </div>
            </div>
            <div class="col-4">
                <div class="video-compare-container" style="width: 100%">
                    <video class="video lazy" id="1" loop playsinline autoPlay muted src="data/videos/image_to_multiview/house/1.mp4" onplay="resizeAndPlay(this)"></video>
                </div>
            </div>
            <div class="col-4">
                <div class="video-compare-container" style="width: 100%">
                    <video class="video lazy" id="2" loop playsinline autoPlay muted src="data/videos/image_to_multiview/house/2.mp4" onplay="resizeAndPlay(this)"></video>
                </div>
            </div>
            <h6 class="caption" style="font-size:11px">A house sitting in the middle of a grassy field</h6>
        </div>
    </div>
    <hr class="divider" />
    <script src="data/assets/js/yall.js"></script>
    <script>
        yall(
            {
                observeChanges: true
            }
        );
    </script>
</body>

</html>
