<!DOCTYPE html>
<html lang="en">
<head>
    <!-- <meta http-equiv="refresh" content="5; url="> -->
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">

   <!-- <meta content="ViBiDSampler" property="og:title"> -->
    <meta content="Effortless Event-Augmented Latent Diffusion for Video Frame Interpolation" property="twitter:title">
    <meta property="og:type" content="website">
    <link rel="icon" href="assets/video.svg"/>
    <title>Effortless Event-Augmented Latent Diffusion for Video Frame Interpolation</title>
    <meta name="description" content="keyframe interpolation">
    <meta name="keywords" content="keyframe interpolation, image-to-video diffusion model">

    <meta content="Effortless Event-Augmented Latent Diffusion for Video Frame Interpolation" property="twitter:title" />
    <meta content="Effortless Event-Augmented Latent Diffusion for Video Frame Interpolation" property="twitter:description" />


    <meta property="og:image" content="assets/teaser.jpg">
    <meta property="og:type" content="website" />
    <meta property="og:url" content=""/>

    <meta name="twitter:card" content="summary_large_image" />
    <meta name="twitter:image" content="assets/teaser.jpg" />

    <!-- Google tag (gtag.js) -->
    <!-- <script async src=""></script>
    <script>
        window.dataLayer = window.dataLayer || [];
        function gtag(){dataLayer.push(arguments);}
        gtag('js', new Date());

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

   <script src="https://code.jquery.com/jquery-3.2.1.slim.min.js" integrity="sha384-KJ3o2DKtIkvYIK3UENzmM7KCkRr/rE9/Qpg6aAZGJwFDMVNA/GpGFF93hXpG5KkN" crossorigin="anonymous"></script>
   <!-- popper used for tooltips -->
   <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js"></script>
   <!-- bootstrap styling used for carousel -->
   <script src="https://cdn.jsdelivr.net/npm/bootstrap@4.0.0/dist/js/bootstrap.min.js" integrity="sha384-JZR6Spejh4U02d8jOt6vLEHfe/JQGiRRSQQxSfFWpi1MquVdAyjUar5+76PVCmYl" crossorigin="anonymous"></script>
   <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@4.0.0/dist/css/bootstrap.min.css">

   <link rel="stylesheet" href="./static/css/bulma.min.css">
   <link rel="stylesheet" href="./static/css/bulma-carousel.min.css">
   <link rel="stylesheet" href="./static/css/bulma-slider.min.css">
   <link rel="stylesheet" href="./static/css/index.css">
   <link rel="stylesheet" href="./static/css/custom.css">
   <link rel="stylesheet" href="./static/css/fonts.css">

   <link rel="stylesheet" href="./static/css/fontawesome.all.min.css">
   <link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/jpswalsh/academicons@1/css/academicons.min.css">

   <script defer src="./static/js/fontawesome.all.min.js"></script>
   <script src="./static/js/interactions.js"></script>
   <script src="./static/js/bulma-carousel.min.js"></script>
   <script src="./static/js/bulma-slider.min.js"></script>
   <meta charset="UTF-8">

    <style>
      .center-item {
      display: flex;
      justify-content: center;
      align-items: center;
      }
    </style>

</head>
<body>
    <script src="static/js/select_frame.js"></script>

    <section class="hero">
        <div class="hero-body" style="padding: 3rem 1.5rem 0.5rem 1.5rem;">
            <div class="container is-max-desktop">
                <div class="columns is-centered">
                    <div class="column has-text-centered">
                        <h1 class="title is-1 publication-title" style="font-size: 44px;"> Effortless Event-Augmented Latent Diffusion for Video Frame Interpolation </h1>
                        
                        <div class="column has-text-centered">
                            <div class="publication-links">
                                <!-- <span class="link-block">
                                    <a href="https://huggingface.co/spaces/fffiloni/svd_keyframe_interpolation" target="_blank" class="external-link button is-normal is-rounded is-dark">
                                        <span class="icon">
                                            <img src="assets/hf-logo.svg" />
                                        </span>
                                        <span>Demo</span>
                                    </a>
                                </span> -->
                            </div>
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </section>

    <!-- <section class="hero teaser">
    <div class="hero-body is-centered">
      <div class="columns is-centered">
        <div class="column is-centered is-full is-three-quarters-widescreen">
        <video id="teaser" autoplay muted playsinline loop style="display: block; margin: auto;">
          <source src="assets/teaser.mp4" type="video/mp4">
        </video>
          <h2 class="caption is-size-5 subtitle has-text-centered">
          Keyframe interpolation result using our method (81-frames).
          </h2>
        </div>
      </div>
    </div>
  </section>
    <hr> -->

    <section class="section">
        <div class="container is-max-desktop">
            <h2 class="title is-2 is-centered has-text-centered">Abstract</h2>
                <div class="">
                    Latent Diffusion Models have advanced video frame interpolation by generating intermediate frames between input frames. 
                    However, effectively handling large temporal gaps and complex motion remains a challenge, often leading to artifacts. 
                    We argue that event camera signals, with their ability to capture continuous motion at high temporal resolutions, are ideal for bridging these temporal gaps and enhancing interpolation precision. Given the impracticality of training an event-assisted model from scratch, we introduce a novel adapter-based framework that seamlessly and effortlessly integrates high-temporal-resolution cues from event cameras into pre-trained image-to-video models without modifying their underlying structure. Our method leverages Image Warped Events (IWEs) and bidirectional sparse optical flow for precise spatial and temporal alignment, significantly reducing artifacts and improving interpolation quality. Experimental results demonstrate that our event-enhanced interpolation achieves superior accuracy and temporal coherence compared to existing state-of-the-art methods.
                </div>
         </div>
    </section>
    <hr>

    <section class="section">
        <div class="container is-max-desktop">
            <h2 class="title is-2 is-centered has-text-centered">Method</h2>
                <div class="hero is-full">
                    <div class="results-single">
                        <img src="assets/fig_method.jpg" style="max-width: 90%; height: auto; display: block; margin: 0 auto;">
                    </div>
                </div>
                <div class="">
                    Illustration of Our Framework. (a) We extract bidirectional sparse optical flow and  IWEs from the input event stream using the Contrast Maximization (CMax) method.
(b) During fine-tuning, the model is enhanced with three components: an IWE encoder, alignment adapters inserted into a subset of DiT blocks, and LoRA layers applied to all DiT blocks.
(c) The flow-based alignment adapter leverages the bidirectional flows to warp intermediate features from neighboring frames, aligning them temporally with the current frame. This facilitates motion-consistent feature propagation throughout the denoising process
                </div>
        </div>
    </section>
    <hr>
   

    <section id="results1" class="section">
        <!-- <div class="container"> -->
        <!-- <div style="width: 100%;"> -->
        <div class="container" style="max-width: 100%; width: 100%;">
            <h2 class="title is-2 is-centered has-text-centered">Baseline comparisons</h2>
             <h2 class="caption is-size-5 subtitle has-text-centered">x 24 interpolation</h2>
        <!-- 标题区域 -->
        <div class="row1" style="display: flex; justify-content: center; gap: 0px; font-size: 0; margin-bottom: 10px;">
        <div class="media1" style="width: 240px; text-align: center; font-size: 14px;">Input pairs</div>
        <div class="media1" style="width: 240px; text-align: center; font-size: 14px;">Ground Truth</div>
        <div class="media1" style="width: 240px; text-align: center; font-size: 14px;">Timelens</div>
        <div class="media1" style="width: 240px; text-align: center; font-size: 14px;">CBMNet</div>
        <div class="media1" style="width: 240px; text-align: center; font-size: 14px;">WAN2.1 FLF2V</div>
        <div class="media1" style="width: 240px; text-align: center; font-size: 14px;"><b>Ours</b></div>
        </div>

        <!-- 视频区域 -->
        <div class="row1" style="display: flex; flex-wrap: nowrap; gap: 0px; justify-content: center; overflow-x: auto;">
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <img src="assets/videos/Comparison/videos/Input_pairs/tackle/frame1.png" alt="frame 1" data-base-path="assets/videos/Comparison/videos/Input_pairs/tackle/" width="230" style="display: block;">
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/gt/gt_tackle.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/timelens/timelens_tackle.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/cbmnet/cbmnet_tackle.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/Wan21/wan21_tackle.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/Ours/ours_tackle.mp4" type="video/mp4">
            </video>
        </div>
        </div>

         <!-- 视频区域 -->
        <div class="row1" style="display: flex; flex-wrap: nowrap; gap: 0px; justify-content: center; overflow-x: auto;">
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <img src="assets/videos/Comparison/videos/Input_pairs/choreography/frame1.png" alt="frame 1" data-base-path="assets/videos/Comparison/videos/Input_pairs/choreography/"  width="230" style="display: block;">
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/gt/gt_choreography.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/timelens/timelens_choreography.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/cbmnet/cbmnet_choreography.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/Wan21/wan21_choreography.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/Ours/ours_choreography.mp4" type="video/mp4">
            </video>
        </div>
        </div>


        <!-- 视频区域 -->
        <div class="row1" style="display: flex; flex-wrap: nowrap; gap: 0px; justify-content: center; overflow-x: auto;">
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <img src="assets/videos/Comparison/videos/Input_pairs/bike_trial/frame1.png" alt="frame 1" data-base-path="assets/videos/Comparison/videos/Input_pairs/bike_trial/"  width="230" style="display: block;">
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/gt/gt_bike_trial.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/timelens/timelens_bike_trial.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/cbmnet/cbmnet_bike_trial.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/Wan21/wan21_bike_trial.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/Ours/ours_bike_trial.mp4" type="video/mp4">
            </video>
        </div>
        </div>

         <!-- 视频区域 -->
        <div class="row1" style="display: flex; flex-wrap: nowrap; gap: 0px; justify-content: center; overflow-x: auto;">
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <img src="assets/videos/Comparison/videos/Input_pairs/basket_08/frame1.png" alt="frame 1" data-base-path="assets/videos/Comparison/videos/Input_pairs/basket_08/"  width="230" style="display: block;">
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/gt/gt_basket_08.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/timelens/timelens_basket_08.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/cbmnet/cbmnet_basket_08.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/Wan21/wan21_basket_08.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/Ours/ours_basket_08.mp4" type="video/mp4">
            </video>
        </div>
        </div>

         <!-- 视频区域 -->
        <div class="row1" style="display: flex; flex-wrap: nowrap; gap: 0px; justify-content: center; overflow-x: auto;">
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <img src="assets/videos/Comparison/videos/Input_pairs/5362/frame1.png" alt="frame 1" data-base-path="assets/videos/Comparison/videos/Input_pairs/5362/"  width="230" style="display: block;">
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/gt/gt_5362.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/timelens/timelens_5362.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/cbmnet/cbmnet_5362.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/Wan21/wan21_5362.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/Ours/ours_5362.mp4" type="video/mp4">
            </video>
        </div>
        </div>
<!-- 
                </div> -->

        </div>
    
    <hr>
 


    <section id="results1" class="section">
        <!-- <div class="container"> -->
        <!-- <div style="width: 100%;"> -->
        <div class="container" style="max-width: 100%; width: 100%;">
            <h2 class="title is-2 is-centered has-text-centered">Baseline comparisons with VDM-EVFI</h2>
             <h2 class="caption is-size-5 subtitle has-text-centered">x 12 interpolation</h2>
        <!-- 标题区域 -->
        <div class="row1" style="display: flex; justify-content: center; gap: 0px; font-size: 0; margin-bottom: 10px;">
        <div class="media1" style="width: 240px; text-align: center; font-size: 14px;">Input pairs</div>
        <div class="media1" style="width: 240px; text-align: center; font-size: 14px;">Ground Truth</div>
        <div class="media1" style="width: 240px; text-align: center; font-size: 14px;">VDM-EVFI</div>
        <div class="media1" style="width: 240px; text-align: center; font-size: 14px;"><b>Ours</b></div>
        </div>

        <!-- 视频区域 -->
        <div class="row1" style="display: flex; flex-wrap: nowrap; gap: 0px; justify-content: center; overflow-x: auto;">
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <img src="assets/videos/Comparison/videos/Input_pairs/football_04/frame1.png" alt="frame 1" data-base-path="assets/videos/Comparison/videos/Input_pairs/football_04/" width="230" style="display: block;">
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/gt/gt_football_04.mp4" type="video/mp4">
            </video>
        </div>
 
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/vdm_vfi/vdm_vfi_football_04.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/Ours/ours_football_04.mp4" type="video/mp4">
            </video>
        </div>
        </div>
 
                <!-- 视频区域 -->
        <!-- <div class="row1" style="display: flex; flex-wrap: nowrap; gap: 0px; justify-content: center; overflow-x: auto;">
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <img src="assets/videos/Comparison/videos/Input_pairs/2796/frame1.png" alt="frame 1" data-base-path="assets/videos/Comparison/videos/Input_pairs/2796/" width="230" style="display: block;">
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/gt/gt_2796.mp4" type="video/mp4">
            </video>
        </div>
 
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/vdm_vfi/vdm_vfi_2796.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/Ours/ours_2796.mp4" type="video/mp4">
            </video>
        </div>
        </div> -->

                <!-- 视频区域 -->
        <div class="row1" style="display: flex; flex-wrap: nowrap; gap: 0px; justify-content: center; overflow-x: auto;">
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <img src="assets/videos/Comparison/videos/Input_pairs/ball_06/frame1.png" alt="frame 1" data-base-path="assets/videos/Comparison/videos/Input_pairs/ball_06/" width="230" style="display: block;">
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/gt/gt_ball_06.mp4" type="video/mp4">
            </video>
        </div>
 
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/vdm_vfi/vdm_vfi_ball_06.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/Ours/ours_ball_06.mp4" type="video/mp4">
            </video>
        </div>
        </div>


                <!-- 视频区域 -->
        <div class="row1" style="display: flex; flex-wrap: nowrap; gap: 0px; justify-content: center; overflow-x: auto;">
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <img src="assets/videos/Comparison/videos/Input_pairs/jacket_03/frame1.png" alt="frame 1" data-base-path="assets/videos/Comparison/videos/Input_pairs/jacket_03/" width="230" style="display: block;">
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/gt/gt_jacket_03.mp4" type="video/mp4">
            </video>
        </div>
 
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/vdm_vfi/vdm_vfi_jacket_03.mp4" type="video/mp4">
            </video>
        </div>
        <div class="media1" style="flex: 0 0 auto; width: 240px; margin: 0; padding: 0;">
            <video autoplay muted loop playsinline width="230" style="display: block;">
            <source src="assets/videos/Comparison/videos/Ours/ours_jacket_03.mp4" type="video/mp4">
            </video>
        </div>
        </div>
 
     

        </div>
    
    <hr>

</body>
</html>
