<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <meta name="description"
        content="A versatile pipeline for generating transition sequences from two input images">
  <meta name="keywords" content="2D generative model, diffusion models, image morphing">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <title>FreeMorph</title>

  <!-- Global site tag (gtag.js) - Google Analytics -->
  <script async src="https://www.googletagmanager.com/gtag/js?id=G-PYVRSFMDRL"></script>
  <script>
    window.dataLayer = window.dataLayer || [];

    function gtag() {
      dataLayer.push(arguments);
    }

    gtag('js', new Date());

    gtag('config', 'G-PYVRSFMDRL');
  </script>
  
  <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">
  <link rel="stylesheet" href="./static/css/result.css">
  <!-- <link rel="icon" href="./static/images/favicon.svg"> -->


  <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>

</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">
          <h1 class="title is-2 publication-title">FreeMorph: Tuning-Free Generalized Image Morphing with Diffusion Model</h1>
          <div class="is-size-4 publication-authors">
            <span class="author-block">
              Anonymous Author(s)
            </span>
          </div>

          <div class="is-size-5 publication-authors">
            ICLR 2025 Submission
          </div>

          <div class="column has-text-centered">
            <div class="publication-links">
              <span class="link-block">
                <a href=""
                   class="external-link button is-normal is-rounded is-dark">
                  <span class="icon">
                      <i class="fas fa-file-pdf"></i>
                  </span>
                  <span>Paper</span>
                </a>
              </span>
              <!-- PDF Link. -->
              <span class="link-block">
                <a href=""
                   class="external-link button is-normal is-rounded is-dark">
                  <span class="icon">
                      <i class="fas fa-file-pdf"></i>
                  </span>
                  <span>Supplementary Material</span>
                </a>
              </span>
              <!-- Code Link. -->
              <span class="link-block">
                <a href=""
                   class="external-link button is-normal is-rounded is-dark">
                  <span class="icon">
                      <i class="fab fa-github"></i>
                  </span>
                  <span>Code (will release)</span>
                  </a>
              </span>
            </div>

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

<div class="my-hr">
  <hr>
</div>

<section class="section">

  <div class="container is-max-desktop">
    <div class="columns is-centered has-text-centered">
      <div class="column is-full-width">
        <table>
          <tr>
            <td><img src="./static/FreeMorph-teaser.png"></td>
          </tr>

        </table>
        <div class="content has-text-justified">
          <p>
          Given two input images, FreeMorph effectively generates smooth transitions between them within 30 seconds.
          </p>
        </div>
      </div>
    </div>
    <!-- Abstract. -->
    <div class="columns is-centered has-text-centered">
      <div class="column is-four-fifths">
        <h2 class="title is-3">Abstract</h2>
        <div class="content has-text-justified">
          <p>
            We present <strong>FreeMorph</strong>, the first tuning-free method for image morphing that accommodates inputs with varying semantics or layouts. Unlike existing methods, which rely on fine-tuning pre-trained diffusion models and are limited by time constraints and semantic/layout discrepancies, FreeMorph delivers high-fidelity image morphing without extensive training. Despite its efficiency and potential, tuning-free methods still face challenges in maintaining high-quality image morphing due to the non-linear nature of the multi-step denoising process and bias inherited from the pre-trained diffusion model. In this paper, we introduce FreeMorph to address this challenge by integrating two key innovations. <strong>1)</strong> We first propose a <strong>guidance-aware spherical interpolation</strong> design that incorporates the explicit guidance from the input images through modifying the self-attention modules, addressing identity loss and ensuring consistent transitions throughout the generated sequences. <strong>2)</strong> We further introduce a <strong>step-oriented motion flow</strong> that blends self-attention modules derived from each input image to achieve controlled and directional transitions that respect both input images. Our extensive evaluations demonstrate that FreeMorph outperforms existing methods with training that is nx times faster, establishing a new state-of-the-art for image morphing. The code will be released.
          </p>
        </div>
      </div>
    </div>
    <!--/ Abstract. -->

    <hr>
    <div class="columns is-centered has-text-centered" style="background-color: #f1f1f1;">
      <div class="column is-full-width">
        <h2 class="title is-3">Image Morphing Results</h2>
        
        <table>

        <div class="content has-text-justified" >
          <p style="font-weight: bold; font-size: 24px; color: rgba(64, 20, 114, 0.948);">1. Images with different semantics and different layouts</p>
        </div>
          <tr>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/7.mp4" type="video/mp4">
            </video>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/8.mp4" type="video/mp4">
            </video>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/15-2.mp4" type="video/mp4">
            </video>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/34.mp4" type="video/mp4">
            </video>

          </tr>


          <tr>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/40.mp4" type="video/mp4">
            </video>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/29.mp4" type="video/mp4">
            </video>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/3-2.mp4" type="video/mp4">
            </video>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/22.mp4" type="video/mp4">
            </video>


          </tr>

        <div class="content has-text-justified">
          <p style="font-weight: bold; font-size: 24px; color: rgba(64, 20, 114, 0.948);">2. Images with similar semantics and similar layouts</p>
        </div>
          <tr>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/1.mp4" type="video/mp4">
            </video>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/13.mp4" type="video/mp4">
            </video>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/16.mp4" type="video/mp4">
            </video>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/125.mp4" type="video/mp4">
            </video>



          </tr>

          <tr>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/118.mp4" type="video/mp4">
            </video>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/39.mp4" type="video/mp4">
            </video>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/15-3.mp4" type="video/mp4">
            </video>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/87.mp4" type="video/mp4">
            </video>


          </tr>

        <div class="content has-text-justified">
          <p style="font-weight: bold; font-size: 24px; color: rgba(64, 20, 114, 0.948);">3. Images with different semantics and similar layouts</p>
        </div>
          <tr>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/12.mp4" type="video/mp4">
            </video>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/6.mp4" type="video/mp4">
            </video>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/15.mp4" type="video/mp4">
            </video>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/19.mp4" type="video/mp4">
            </video>



          </tr>

        <div class="content has-text-justified">
          <p style="font-weight: bold; font-size: 24px; color: rgba(64, 20, 114, 0.948);">4. Images with similar semantics and different layouts</p>
        </div>
          <tr>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/18-2.mp4" type="video/mp4">
            </video>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/117.mp4" type="video/mp4">
            </video>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/25.mp4" type="video/mp4">
            </video>
            <video width="240" height="240" controls autoplay loop muted>
                <source src="./static/mp4/88.mp4" type="video/mp4">
            </video>


          </tr>


        </table>
      </div>
    </div>
    <hr>



    <div class="columns is-centered has-text-centered" style="background-color: #f1f1f1;">
      <div class="column is-full-width">
        <h2 class="title is-3">Comparisons with Baseline Methods</h2>
        
        <table>

          <tr>
            <td><img src="./static/comparison/12.png"></td>
          </tr>
          <tr>
            <td><img src="./static/comparison/11.png"></td>
          </tr>
          <tr>
            <td><img src="./static/comparison/1.png"></td>
          </tr>
          <tr>
            <td><img src="./static/comparison/2.png"></td>
          </tr>
          <tr>
            <td><img src="./static/comparison/4.png"></td>
          </tr>
          <tr>
            <td><img src="./static/comparison/5.png"></td>
          </tr>
          <tr>
            <td><img src="./static/comparison/6.png"></td>
          </tr>
          <tr>
            <td><img src="./static/comparison/3.png"></td>
          </tr>
          <tr>
            <td><img src="./static/comparison/7.png"></td>
          </tr>
          <tr>
            <td><img src="./static/comparison/8.png"></td>
          </tr>
          <tr>
            <td><img src="./static/comparison/9.png"></td>
          </tr>


        </table>
      </div>
    </div>

</section>  


</body>
</html>
