<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <meta name="description" content="DESCRIPTION META TAG">
  <meta property="og:title" content="Self-Correcting Text-to-Video Generation with Misalignment Detection and Localized Refinement"/>
  <meta property="og:description" content="Self-Correcting Text-to-Video Generation with Misalignment Detection and Localized Refinement"/>

  <meta name="twitter:title" content="Self-Correcting Text-to-Video Generation with Misalignment Detection and Localized Refinement">
  <meta name="twitter:description" content="Self-Correcting Text-to-Video Generation with Misalignment Detection and Localized Refinement">
  <meta name="keywords" content="KEYWORDS SHOULD BE PLACED HERE">
  <meta name="viewport" content="width=device-width, initial-scale=1">


  <title>VideoRepair</title>
  <link href="https://fonts.googleapis.com/css?family=Google+Sans|Noto+Sans|Castoro"
  rel="stylesheet">

  <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/fontawesome.all.min.css">
  <link rel="stylesheet"
  href="https://cdn.jsdelivr.net/gh/jpswalsh/academicons@1/css/academicons.min.css">
  <link rel="stylesheet" href="static/css/index.css">

  <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
  <script src="https://documentcloud.adobe.com/view-sdk/main.js"></script>
  <script defer src="static/js/fontawesome.all.min.js"></script>
  <script src="static/js/bulma-carousel.min.js"></script>
  <script src="static/js/bulma-slider.min.js"></script>
  <script src="static/js/index.js"></script>

  <!-- custom css file  -->
  <link rel="stylesheet" href="./static/css/twentytwenty.css">
  <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
  <style>
    .custom-slider-container {
        width: 100%;
        max-width: 900px;
        margin: 0 auto;
        overflow: hidden;
        position: relative;
    }

    .custom-slider {
        display: flex;
        transition: transform 0.5s ease-in-out;
    }

    .custom-slide {
        min-width: 100%;
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    .custom-gif-wrapper {
        display: flex;
        /* flex-wrap: wrap;  */
        justify-content: center; 
        align-items: center;     
        width: 100%;
        height: 100%;    
        box-sizing: border-box; 
        justify-content: space-between;        
        align-items: flex-start;
    }


    .custom-gif-container {
        display: flex;
        flex-direction: column;
        justify-content: center; /* Vertically centers the video within the container */
        align-items: center;     /* Horizontally centers the video within the container */
        width: 2%;              /* Keeps the same width as before for each video container */
        height: 100%;            /* Ensures the height of the container is used */
    }


    .custom-gif-container img {
        width: 100%;
        height: auto;
    }


    .custom-gif-container-4vid {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 25%;
    /* width: calc(50% - 10px); */
    aspect-ratio: 16 / 9; 
    /* max-width: 100%;  */
    box-sizing: border-box; 
    }

    .custom-gif-container-4vid img {
        width: 100%; 
        max-width: 100%; 
        height: 100%; 
        object-fit: contain; 
        margin-bottom: 5px;
    }

    .custom-gif-container-3vid {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    /* width: 33.33%;*/
    width: 30%;
    aspect-ratio: 16 / 9; 
    max-width: 100%; 
    box-sizing: border-box; 
    margin-bottom: 10px;   
    }

    .custom-gif-container-3vid img {
        width: 100%; 
        height: auto; 
        max-width: 100%; 
        object-fit: contain; 
    }  

    .custom-caption {
        text-align: center;
        margin-top: 5px;
        font-weight: bold; 
        font-size: 15px;  
        margin: 0;              
    }

    .custom-top-caption {
        text-align: center;
        font-size: 18px;
        margin-bottom: 10px;
    }


    .custom-arrow {
      position: absolute;
      top: 47%; /* Vertically centers the arrows */
      transform: translateY(-50%); /* Centers vertically */
      background-color: rgba(0, 0, 0, 0.5);
      color: white;
      border: none;
      font-size: 20px;
      padding: 12px;
      cursor: pointer;
      z-index: 10; /* Ensure the arrows are above the videos */
    }

    .text-with-margin {
      margin-top: 10px; /* Adds 20px space above the text */
      margin-bottom: 50px;
    }

    .custom-prev {
        left: -5px; /* Positions the left arrow slightly outside the video container */
    }

    .custom-next {
        right: -5px; /* Positions the right arrow slightly outside the video container */
    }

    .custom-gif-container:not(:last-child) {
        margin-right: 40px;
    }

    .custom-gif-container-4vid:not(:last-child) {
        margin-right: 20px;
    }

    .custom-gif-container-3vid:not(:last-child) {
    margin-right: 20px;
    }

    .dots-container {
            text-align: center;
            margin-top: 20px;
        }

    .dot {
        height: 15px;
        width: 15px;
        margin: 0 5px;
        background-color: #bbb;
        border-radius: 50%;
        display: inline-block;
        cursor: pointer;
    }

    .active {
        background-color: #717171;
    }

    .small-normal-text {
      font-weight: normal;
      font-size: 10px; /* Adjust to desired size */
    }
    @media (max-width: 768px) {
            .custom-gif-container-4vid {
                width: 45%; 
                max-width: 100%;
                height: auto; 
                aspect-ratio: 16 / 9; 
            }
        }
    @media (max-width: 768px) {
        .custom-gif-container-3vid {
            width: 45%; 
            max-width: 100%; 
            height: auto; 
            aspect-ratio: 16 / 9; 
        }
    }
  </style>
</head>
<body>


  <section class="hero">
    <div class="hero-body">
      <div class="container is-max-desktop">
        <div class="columns is-centered">
          <div class="column has-text-centered">
            <!-- title -->
            <h1 class="title is-3 publication-title">
              <img style="max-height: 36px;" src="./static/images/icon.ico"/>
              Self-Correcting Text-to-Video Generation with Misalignment Detection and Localized Refinement
            </h1>
            

            </div>
          </div>
        </div>
      </div>
    </div>
  </div>
</section>





<!-- Youtube video -->
<section class="hero is-small is-light">
  <div class="spacer"></div>

  <div class="hero-body">
    <div class="container is-max-desktop"  style="margin-top:30px;">
      <div class="section-title has-text-centered">
        <h2 class="title is-3">Qualitative Results</h2>
      </div>

      <div class="spacer"></div>

      <div class="section-title has-text-centered">
        <h2 class="title is-4">1. Comparison with Baselines (T2V-turbo)</h2>
      </div>

      <div class="spacer"></div>

      <div class="custom-slider-container">
        <div class="custom-slider" id="custom-slider-turbo">

            <div class="custom-slide">
                <div class="custom-top-caption">"1 bear and 2 people making pizza"</div> <!-- Top caption added -->
                <div class="custom-gif-wrapper">
                    <div class="custom-gif-container-4vid">
                      <img src="./static/images/turbo/bear_pizza/init.gif" alt="GIF 1">
                      <div class="custom-caption">
                        <!-- T2V-turbo -->
                        <a href="https://arxiv.org/abs/2405.18750" target="_blank" rel="noopener noreferrer">T2V-turbo</a>
                      </div>
                  </div>
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/turbo/bear_pizza/opt2i.gif" alt="GIF 2">
                      <div class="custom-caption">
                        <!-- OPT2I -->
                        <a href="https://arxiv.org/abs/2403.17804" target="_blank" rel="noopener noreferrer">+ OPT2I</a>
                      </div>
                  </div>
                    <div class="custom-gif-container-4vid">
                        <img src="./static/images/turbo/bear_pizza/vico.gif" alt="GIF 3">
                        <div class="custom-caption">
                          <!-- Vico -->
                          <a href="https://arxiv.org/abs/2407.06182" target="_blank" rel="noopener noreferrer">Vico</a>
                        </div>
                    </div>

                    <div class="custom-gif-container-4vid">
                        <img src="./static/images/turbo/bear_pizza/ours.gif" alt="GIF 4">
                        <div class="custom-caption">+ Ours (VideoRepair) </div>
                    </div>
                </div>
                
            </div>

            <div class="custom-slide">
              <div class="custom-top-caption">"A blue car parked next to a red fire hydrant on the street"</div> 
              <div class="custom-gif-wrapper">
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/turbo/fire/init.gif" alt="GIF 4">
                      <div class="custom-caption">T2V-turbo</div>
                  </div>
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/turbo/fire/opt2i.gif" alt="GIF 5">
                      <div class="custom-caption">OPT2I</div>
                  </div>
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/turbo/fire/vico.gif" alt="GIF 6">
                      <div class="custom-caption">Vico</div>
                  </div>
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/turbo/fire/ours.gif" alt="GIF 7">
                      <div class="custom-caption">Ours (VideoRepair)</div>
                  </div>
              </div>
          </div>

            <!-- <div class="custom-slide">
              <div class="custom-top-caption">"A camel lounging in front of a snowman"</div> 
              <div class="custom-gif-wrapper">
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/turbo/camel/init.gif" alt="GIF 4">
                      <div class="custom-caption">T2V-turbo</div>
                  </div>
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/turbo/camel/opt2i.gif" alt="GIF 5">
                      <div class="custom-caption">+ OPT2I</div>
                  </div>
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/turbo/camel/vico.gif" alt="GIF 6">
                      <div class="custom-caption">Vico</div>
                  </div>
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/turbo/camel/ours.gif" alt="GIF 7">
                      <div class="custom-caption">+ Ours (VideoRepair)</div>
                  </div>
              </div>
          </div> -->



            <!-- <div class="custom-slide">
              <div class="custom-top-caption">"Yellow rose swaying near a green bench"</div> 
              <div class="custom-gif-wrapper">
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/turbo/rose/init.gif" alt="GIF 4">
                      <div class="custom-caption">T2V-turbo</div>
                  </div>
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/turbo/rose/opt2i.gif" alt="GIF 5">
                      <div class="custom-caption">+ OPT2I</div>
                  </div>
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/turbo/rose/vico.gif" alt="GIF 6">
                      <div class="custom-caption">Vico</div>
                  </div>
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/turbo/rose/ours.gif" alt="GIF 7">
                      <div class="custom-caption">+ Ours (VideoRepair)</div>
                  </div>
              </div>
            </div>
        </div> -->
    

        <button class="custom-arrow custom-prev" onclick="moveCustomSlide('custom-slider-turbo', -1)">&#10094;</button>
        <button class="custom-arrow custom-next" onclick="moveCustomSlide('custom-slider-turbo', 1)">&#10095;</button>

        <div class="dots-container">
          <span class="dot" onclick="setCurrentSlide(0)"></span>
          <span class="dot" onclick="setCurrentSlide(1)"></span>
          <span class="dot" onclick="setCurrentSlide(2)"></span>
          <span class="dot" onclick="setCurrentSlide(3)"></span>
          <span class="dot" onclick="setCurrentSlide(4)"></span>
        </div>
      </div>

      <div class="spacer"></div>

<!-- =========== -->
      <div class="section-title has-text-centered">
        <h2 class="title is-4">2. Comparison with Baselines (VideoCrafter2)</h2>
      </div>

      <div class="spacer"></div>

      <div class="custom-slider-container">
        <div class="custom-slider" id="custom-slider-vc">


            <div class="custom-slide">
                <div class="custom-top-caption">"A dog sitting under a umbrella on a sunny beach"</div> 
                <div class="custom-gif-wrapper">
                    <div class="custom-gif-container-4vid">
                      <img src="./static/images/vc2/dog/init.gif" alt="GIF 1">
                      <div class="custom-caption">VideoCrafter2</div>
                  </div>
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/vc2/dog/opt2i.gif" alt="GIF 2">
                      <div class="custom-caption">+ OPT2I</div>
                  </div>
                    <div class="custom-gif-container-4vid">
                        <img src="./static/images/vc2/dog/vico.gif" alt="GIF 3">
                        <div class="custom-caption">Vico</div>
                    </div>
                    <div class="custom-gif-container-4vid">
                        <img src="./static/images/vc2/dog/ours.gif" alt="GIF 4">
                        <div class="custom-caption">+ Ours (VideoRepair) </div>
                    </div>
                </div>
            </div>

            <div class="custom-slide">
              <div class="custom-top-caption">"With the style of pointilism, A green apple and a black backpack."</div> 
              <div class="custom-gif-wrapper">
                  <div class="custom-gif-container-4vid">
                    <img src="./static/images/vc2/apple/init.gif" alt="GIF 1">
                    <div class="custom-caption">VideoCrafter2</div>
                </div>
                <div class="custom-gif-container-4vid">
                    <img src="./static/images/vc2/apple/opt2i.gif" alt="GIF 2">
                    <div class="custom-caption">+ OPT2I</div>
                </div>
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/vc2/apple/vico.gif" alt="GIF 3">
                      <div class="custom-caption">Vico</div>
                  </div>
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/vc2/apple/ours.gif" alt="GIF 4">
                      <div class="custom-caption">+ Ours (VideoRepair) </div>
                  </div>
              </div>
          </div>


            <!-- <div class="custom-slide">
              <div class="custom-top-caption">"three foxes in a snowy forest"</div> 
              <div class="custom-gif-wrapper">
                  <div class="custom-gif-container-4vid">
                    <img src="./static/images/vc2/fox/init.gif" alt="GIF 1">
                    <div class="custom-caption">VideoCrafter2</div>
                </div>
                <div class="custom-gif-container-4vid">
                    <img src="./static/images/vc2/fox/opt2i.gif" alt="GIF 2">
                    <div class="custom-caption">+ OPT2I</div>
                </div>
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/vc2/fox/vico.gif" alt="GIF 3">
                      <div class="custom-caption">Vico</div>
                  </div>
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/vc2/fox/ours.gif" alt="GIF 4">
                      <div class="custom-caption">+ Ours (VideoRepair) </div>
                  </div>
              </div>
          </div> -->



            <!-- <div class="custom-slide">
              <div class="custom-top-caption">"A basket placed below a television"</div> 
              <div class="custom-gif-wrapper">
                  <div class="custom-gif-container-4vid">
                    <img src="./static/images/vc2/tv/init.gif" alt="GIF 1">
                    <div class="custom-caption">VideoCrafter2</div>
                </div>
                <div class="custom-gif-container-4vid">
                    <img src="./static/images/vc2/tv/opt2i.gif" alt="GIF 2">
                    <div class="custom-caption">+ OPT2I</div>
                </div>
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/vc2/tv/vico.gif" alt="GIF 3">
                      <div class="custom-caption">Vico</div>
                  </div>
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/vc2/tv/ours.gif" alt="GIF 4">
                      <div class="custom-caption">+ Ours (VideoRepair) </div>
                  </div>
              </div>
          </div> -->


<!-- 
            <div class="custom-slide">
              <div class="custom-top-caption">"A penguin standing on the right side of a cactus in a desert"</div> 
              <div class="custom-gif-wrapper">
                  <div class="custom-gif-container-4vid">
                    <img src="./static/images/vc2/desert/init.gif" alt="GIF 1">
                    <div class="custom-caption">VideoCrafter2</div>
                </div>
                <div class="custom-gif-container-4vid">
                    <img src="./static/images/vc2/desert/opt2i.gif" alt="GIF 2">
                    <div class="custom-caption">+ OPT2I</div>
                </div>
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/vc2/desert/vico.gif" alt="GIF 3">
                      <div class="custom-caption">Vico</div>
                  </div>
                  <div class="custom-gif-container-4vid">
                      <img src="./static/images/vc2/desert/ours.gif" alt="GIF 4">
                      <div class="custom-caption">+ Ours (VideoRepair) </div>
                  </div>
              </div>
          </div>
        </div> -->
    

        <button class="custom-arrow custom-prev" onclick="moveCustomSlide('custom-slider-vc', -1)">&#10094;</button>
        <button class="custom-arrow custom-next" onclick="moveCustomSlide('custom-slider-vc', 1)">&#10095;</button>

        <div class="dots-container">
          <span class="dot" onclick="setCurrentSlide(0)"></span>
          <span class="dot" onclick="setCurrentSlide(1)"></span>
          <span class="dot" onclick="setCurrentSlide(2)"></span>
          <span class="dot" onclick="setCurrentSlide(3)"></span>
          <span class="dot" onclick="setCurrentSlide(4)"></span>
        </div>
      </div>

      <div class="spacer"></div>

<!-- =========== -->
    <div class="section-title has-text-centered">
      <h2 class="title is-4">3. Iterative Refinement</h2>
    </div>

    <div class="spacer"></div>

    <div class="custom-slider-container">
      <div class="custom-slider" id="custom-slider-iter">



          <div class="custom-slide">
              <div class="custom-top-caption">"A family of four set up a tent and build a campfire, enjoying a night of camping under the stars"</div> 
              <div class="custom-gif-wrapper">
                  <div class="custom-gif-container-3vid">
                    <img src="./static/images/iter/camp/iter0.gif" alt="GIF 1">
                    <div class="custom-caption">Initial video (T2V-turbo)</div>
                </div>
                <div class="custom-gif-container-3vid">
                    <img src="./static/images/iter/camp/iter1.gif" alt="GIF 2">
                    <div class="custom-caption">Iter 1</div>
                </div>
                  <div class="custom-gif-container-3vid">
                      <img src="./static/images/iter/camp/iter2.gif" alt="GIF 4">
                      <div class="custom-caption">Iter 2 </div>
                  </div>
              </div>
          </div>


          <div class="custom-slide">
              <div class="custom-top-caption">"A bright yellow umbrella with a wooden handle. It's compact and easy to carry."</div> 
              <div class="custom-gif-wrapper">
                  <div class="custom-gif-container-3vid">
                    <img src="./static/images/iter/umb/iter0.gif" alt="GIF 1">
                    <div class="custom-caption">Initial video (T2V-turbo)</div>
                </div>
                <div class="custom-gif-container-3vid">
                    <img src="./static/images/iter/umb/iter1.gif" alt="GIF 2">
                    <div class="custom-caption">Iter 1</div>
                </div>
                  <div class="custom-gif-container-3vid">
                      <img src="./static/images/iter/umb/iter2.gif" alt="GIF 4">
                      <div class="custom-caption">Iter 2 </div>
                  </div>
              </div>
          </div>


          <!-- <div class="custom-slide">
            <div class="custom-top-caption">"A group of six dancers perform a ballet on stage, their movements synchronized and graceful."</div> 
            <div class="custom-gif-wrapper">
                <div class="custom-gif-container-3vid">
                  <img src="./static/images/iter/dance/iter0.gif" alt="GIF 1">
                  <div class="custom-caption">Initial video (T2V-turbo)</div>
              </div>
              <div class="custom-gif-container-3vid">
                  <img src="./static/images/iter/dance/iter1.gif" alt="GIF 2">
                  <div class="custom-caption">Iter 1</div>
              </div>
                <div class="custom-gif-container-3vid">
                    <img src="./static/images/iter/dance/iter2.gif" alt="GIF 4">
                    <div class="custom-caption">Iter 2 </div>
                </div>
            </div>
        </div>
      </div> -->


      <button class="custom-arrow custom-prev" onclick="moveCustomSlide('custom-slider-iter', -1)">&#10094;</button>
      <button class="custom-arrow custom-next" onclick="moveCustomSlide('custom-slider-iter', 1)">&#10095;</button>

      <div class="dots-container">
        <span class="dot" onclick="setCurrentSlide(0)"></span>
        <span class="dot" onclick="setCurrentSlide(1)"></span>
        <span class="dot" onclick="setCurrentSlide(2)"></span>
        <span class="dot" onclick="setCurrentSlide(3)"></span>
      </div>
    </div>

    <div class="spacer"></div>





    <div class="spacer"></div>





<!-- custom js file  -->
<!-- <script defer src="./assets/js/fontawesome.all.min.js"></script> -->
<script src="./static/js/bulma-carousel.min.js"></script>
<script src="./static/js/bulma-slider.min.js"></script>
<script src="./static/js/index.js"></script>
<script src="./static/js/jquery.event.move.js"></script>
<script src="./static/js/jquery.twentytwenty.js"></script>
<script>
$(function(){
  $(".twentytwenty-container").twentytwenty({
    default_offset_pct: 0.5, // How much of the before image is visible when the page loads
    orientation: 'horizontal', // Orientation of the before and after images ('horizontal' or 'vertical')
    // before_label: 'January 2017', // Set a custom before label
    // after_label: 'March 2017', // Set a custom after label
    // no_overlay: true, //Do not show the overlay with before and after
    // move_slider_on_hover: true, // Move slider on mouse hover?
    // move_with_handle_only: true, // Allow a user to swipe anywhere on the image to control slider movement. 
    // click_to_move: false // Allow a user to click (or tap) anywhere on the image to move the slider to that location.
  });
});

$(function(){
  $(".main-container").twentytwenty({default_offset_pct: 0.1, orientation: 'horizontal'});
  // $(".twentytwenty-container", "#results-carousel").twentytwenty({default_offset_pct: 0.5, ratio: 0.5});
});
</script>

<script>
    let currentCustomIndex = 0;
    const customSlider = document.getElementById('custom-slider');
    const totalCustomSlides = document.querySelectorAll('.custom-slide').length;
    const dots = document.querySelectorAll('.dot');

    function updateDots() {
        dots.forEach((dot, index) => {
            dot.classList.remove('active');
            if (index === currentCustomIndex) {
                dot.classList.add('active');
            }
        });
    }


    const sliderState = {
      'custom-slider-turbo': 0,
      'custom-slider-vc': 0,
      'custom-slider-iter': 0,
    };

    function moveCustomSlide(sliderId, direction) {
      const slider = document.getElementById(sliderId);
      const slides = slider.querySelectorAll('.custom-slide');
      const totalSlides = slides.length;

      sliderState[sliderId] += direction;
      if (sliderState[sliderId] < 0) {
        sliderState[sliderId] = totalSlides - 1;
      } else if (sliderState[sliderId] >= totalSlides) {
        sliderState[sliderId] = 0;
      }

      slider.style.transform = `translateX(-${sliderState[sliderId] * 100}%)`;

    }

    function setCurrentSlide(index) {
        currentCustomIndex = index;
        customSlider.style.transform = `translateX(-${currentCustomIndex * 100}%)`;
        updateDots();
    }

    updateDots();
</script>


  </body>
  </html>
