<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta name="description"
          content="The .">
    <meta name="keywords" content="Convergent Functions, Divergent Forms">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <!-- <meta name="color-scheme" content="light dark"> -->
    <title>Convergent Functions, Divergent Forms</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">
    <link rel="icon" href="./static/images/favicon.svg">

    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.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>
    <!-- Load MathJax -->
    <script type="text/javascript" async
        src="https://cdn.jsdelivr.net/npm/mathjax@3/es5/tex-mml-chtml.js">
    </script>
    <!-- MathJax Configuration -->
    <script type="text/javascript">
        MathJax = {
            tex: {
                inlineMath: [['$', '$']],
                displayMath: [['$$', '$$']],
            }
        };
    </script>

</head>
<body>

<!--<nav class="navbar" role="navigation" aria-label="main navigation">-->
<!--    <div class="navbar-brand">-->
<!--        <a role="button" class="navbar-burger" aria-label="menu" aria-expanded="false">-->
<!--            <span aria-hidden="true"></span>-->
<!--            <span aria-hidden="true"></span>-->
<!--            <span aria-hidden="true"></span>-->
<!--        </a>-->
<!--    </div>-->
<!--</nav>-->

<section class="hero is-dark">
    <div class="hero-body">
      <div class="container is-max-desktop" style="max-width: 1200px;">
        <div class="columns is-centered">
          <div class="column has-text-centered">
                    <h1 class="title is-3 publication-title">
                        Convergent Functions, Divergent Forms
                        <!-- LOKI 
                        </span> : <u>L</u>ocally <u>O</u>ptimized <u>K</u>inematic <u>I</u>nstantiations -->
                    </h1>
                      <div class="is-size-5 publication-authors">
                        <span class="author-block">
                          Anonymous authors
                        </span>
                    </div>
                </div>
            </div>
        </div>
    </div>
</section>

<br>

<section class="hero teaser">
    <div class="container is-max-desktop" style="max-width: 1200px;">
        <div class="hero">
            <br>
            <h2 class="subtitle">
                <strong>LOKI (<u>L</u>ocally <u>O</u>ptimized <u>K</u>inematic <u>I</u>nstantiations)</strong> <img src="./static/images/LOKI_green-old.png" class="no-darkmode-invert" alt="LOKI Logo" style="height: 1em; margin-left: 0.3em;"> is a compute-efficient co-design framework that discovers <strong>diverse</strong>, high-performing robot morphologies (<i>divergent forms</i>) using <strong>shared control policies</strong> (<i>convergent functions</i>) and dynamic local search <a href="#reference" style="color: red;">[1]</a> instead of mutation.
                <br>
                <br>
                The policy reuse allows us to explore $\sim780\times$ more designs using 78% fewer simulation steps and 40% less compute per design (see <a href="#efficiency_comparison" style="color: blue;">Efficiency and Coverage Comparison</a>).
                <br>
                <br>
                Beyond being substantially more efficient, <strong>LOKI</strong> <img src="./static/images/LOKI_green-old.png" class="no-darkmode-invert" alt="LOKI Logo" style="height: 1em; margin-left: 0.3em;"> discovers both genetically and behaviorally diverse high-performing morphologies that effectively generalize across various unseen tasks. (see <a href="#locomotion" style="color: blue;">Qualitative Results</a>).

            </h2>
            <img src="./static/images/method_v3.png"
                 class="interpolation-image"
                 alt="header-image."/>
            <br>
            <h2 class="subtitle">
                <strong>(A)</strong> UNIMAL <a href="#reference" style="color: red;">[2]</a>, an expressive design space encompassing approximately 10<sup>18</sup> unique morphologies with fewer than 10 limbs, is partitioned into 40 clusters based on morphological similarity in a learned latent space.
                <br>
                <br>
                <strong>(B)</strong> A shared control policy is trained within each cluster on a dynamic pool of elite morphologies, for a simple flat-terrain locomotion task. 
                <br>
                <br>
                <strong>(C)</strong> Morphologies co-evolve with the shared policy as elites are iteratively refined through dynamic local search. The top 2–3 agents from the final training pool of each cluster are selected to form the final population. 
                <!-- (see <a href="#design">Design Qualitative Results</a>). -->
            </h2>

            <!-- <br>
            <br> -->
            <br>
        </div>
        <!-- <div class="content has-text-justified">
            <h2 class="title is-3 has-text-centered">Supplementary website contents</h2>
            <p>
                This supplementary website contains a collection of qualitative examples and quantitative results of our <strong>RING</strong> policy in the
                real-world and simulation. We also provide details about our data, training recipe, and model architecture.
            </p>
            <ul>
                <li><a style="font-size: 1.5rem" href='#Real-world examples'>Real-world examples</a>
                    <ul>
                        <li><a href='#rb_y1'>RB-Y1 wheeled humanoid with iPhone 16 Pro Camera: Navigate to plant/mug/trashcan/apple.</a></li>
                        <li><a href='#stretch_og_apple'>Stretch RE-1 with the factory config camera: Find an apple.</a></li>
                        <li><a href='#stretch_mug'>Stretch RE-1 with the camera config used in SPOC: Find a mug.</a></li>
                        <li><a href='#unitree_toilet'>Unitree GO1: Move to the toilet.</a></li>
                        <li><a href='#locobot_basketball'>LoCoBot: Find a basketball.</a></li>
                        <li><a href='#embodiment_adaptive'>Embodiment-Adaptive Behavior: Navigate to the trashcan.</a>
                            <ul>
                                <li><a href='#embodiment_adaptive'>Stretch RE-1 goes around a dining table.</a></li>
                                <li><a href='#embodiment_adaptive'>Unitree GO1 navigates under a blocking dining table.</a></li>
                            </ul>
                        </li>
                        <li><a href='#fail_example'>Failure case (due to embodiment limitation of Unitree GO1): Go To the sofa.</a></li>
                    </ul>
                </li>
                <li><a style="font-size: 1.5rem" href='#Human_evaluation'>Human Evaluation</a>
                    <ul>
                        <li><a href='#Human_evaluation_houseplant'>Find a houseplant</a></li>
                        <li><a href='#Human_evaluation_apple'>Find an apple</a></li>
                    </ul>
                </li>
                <li><a style="font-size: 1.5rem" href='#embodiment_adaptive_behavior'>Simulation examples show that <strong>RING</strong> adapts its behavior to different embodiments</a>
                </li>
                <li><a style="font-size: 1.5rem" href='#RING'>Details about our data, training recipe, and model architecture</a>
                </li>
                <li><a style="font-size: 1.5rem" href='#numbers'>Quantitative Results</a>
                    <ul>
                        <li><a href='#simulation_numbers'>In simulation benchmarks</a></li>
                        <li><a href='#real_world_numbers'>In the real-world benchamrks</a></li>
                        <li><a href='#human_eval_numbers'>Human evaluation experiment</a></li>
                    </ul>
                </li>
            </ul>
            <br/>
        </div>
    </div> -->
</section>


<!-- Qualitative results -->
<section class="section hero is-light">
    <div class="container is-max-desktop" style="max-width: 1200px;">
        <div class="columns is-centered">
            <div class="column is-full-width">
                <h2 class="title is-3 has-text-centered" id="locomotion">Qualitative Results</h2>
                <!-- <p>
                   
                </p>
                <br> -->
                <h3 class="title is-4" id="simulation_numbers">Evolved Agents for Flat-Terrain Locomotion</h3>
                <p style="text-align: justify;">
                    <strong>LOKI</strong> <img src="./static/images/LOKI_green-old.png" class="no-darkmode-invert" alt="LOKI Logo" style="height: 1em; margin-left: 0.3em;"> discovers high-performing morphologies with <strong>diverse locomotion behaviors</strong> (e.g. Spinners, Crawlers, Bipedals, etc.).
                    <br> 
                    This is due to localizing the competition within each cluster and having a broader exploration within each cluster (using Dynamic Local Search). (see <a href="#diversity" style="color: blue;">Quality Diversity Metrics</a>)
                </p>
                <br>
                <p>
                <div class="grid-container-one">
                    <video
                            controls
                            muted
                            preload
                            playsinline
                            width="100%"
                            autoplay
                            loop>
                            <source src="static/videos/supple_ft_videos_sort_caption.mp4" type="video/mp4">
                        </video>
                </div>

                <br>
                <h3 class="title is-4" id="real_world_numbers">Transitioning to Unseen Tasks</h3>
                <p style="text-align: justify;">
                    <strong>LOKI</strong> <img src="./static/images/LOKI_green-old.png" class="no-darkmode-invert" alt="LOKI Logo" style="height: 1em; margin-left: 0.3em;"> produces a diverse set of solutions that are better suited for adaptation to various unseen tasks and environments, reducing the need to re-evolve agents for each setting.
                    The final set of evolved designs are trained on a suite of downstream tasks across three domains: agility (<i>bump</i>, <i>obstacle</i>, <i>exploration</i>), stability (<i>incline</i>), and manipulation (<i>push box incline</i>, <i>manipulation ball</i>). 
                    (see <a href="#behavior" style="color: blue;">Morphology-Level Task Adaptability</a>).
                </p>
                <br>
                <h4 class="title is-4" style="text-align: center;">Bump</h4>

                <div class="grid-container-two-no-border">
                    <video
                        controls
                        muted
                        preload
                        playsinline
                        width="100%"
                        autoplay
                        loop>
                        <source src="static/videos/ft/spinner_crop_caption.mp4" type="video/mp4">
                    </video>
                    
                    <video
                        controls
                        muted
                        preload
                        playsinline
                        width="100%"
                        autoplay
                        loop>
                        <source src="static/videos/bump_crop_1_caption.mp4" type="video/mp4">
                    </video>
        
                    
                </div>

                <br>
                <h4 class="title is-4" style="text-align: center;">Obstacle (n=150)</h4>

                <div class="grid-container-two-no-border">
                    <video
                        controls
                        muted
                        preload
                        playsinline
                        width="100%"
                        autoplay
                        loop>
                        <source src="static/videos/ft/quadrupedal_crop_caption.mp4" type="video/mp4">
                    </video>
                    
                    <video
                        controls
                        muted
                        preload
                        playsinline
                        width="100%"
                        autoplay
                        loop>
                        <source src="static/videos/many_obs_crop_1_caption.mp4" type="video/mp4">
                    </video>
        
                    
                </div>
                <br>
                <h4 class="title is-4" style="text-align: center;">Exploration</h4>

                <div class="grid-container-two-no-border">
                    <video
                        controls
                        muted
                        preload
                        playsinline
                        width="100%"
                        autoplay
                        loop>
                        <source src="static/videos/ft/cheetah_crop_caption.mp4" type="video/mp4">
                    </video>
                    
                    <video
                        controls
                        muted
                        preload
                        playsinline
                        width="100%"
                        autoplay
                        loop>
                        <source src="static/videos/exploration_crop_1_caption.mp4" type="video/mp4">
                    </video>
        
                    
                </div>
                <br>
                <h4 class="title is-4" style="text-align: center;">Incline</h4>

                <div class="grid-container-two-no-border">
                    <video
                        controls
                        muted
                        preload
                        playsinline
                        width="100%"
                        autoplay
                        loop>
                        <source src="static/videos/ft/bipedal_crop_caption.mp4" type="video/mp4">
                    </video>
                    
                    <video
                        controls
                        muted
                        preload
                        playsinline
                        width="100%"
                        autoplay
                        loop>
                        <source src="static/videos/incline_crop_1_caption.mp4" type="video/mp4">
                    </video>

                </div>
                <br>
                <h4 class="title is-4" style="text-align: center;">Push box incline</h4>
                <div class="grid-container-two-no-border">
                    <video
                        controls
                        muted
                        preload
                        playsinline
                        width="100%"
                        autoplay
                        loop>
                        <source src="static/videos/ft/crawler_crop_caption.mp4" type="video/mp4">
                    </video>
                    
                    <video
                        controls
                        muted
                        preload
                        playsinline
                        width="100%"
                        autoplay
                        loop>
                        <source src="static/videos/push_box_incline_crop_1_caption.mp4" type="video/mp4">
                    </video>
        
                    
                </div>
                <br>
                <h4 class="title is-4" style="text-align: center;">Manipulation ball</h4>
                <div class="grid-container-two-no-border">
                    <video
                        controls
                        muted
                        preload
                        playsinline
                        width="100%"
                        autoplay
                        loop>
                        <source src="static/videos/ft/crab_crop_caption.mp4" type="video/mp4">
                    </video>
                    
                    <video
                        controls
                        muted
                        preload
                        playsinline
                        width="100%"
                        autoplay
                        loop>
                        <source src="static/videos/manipulation_ball_crop_2_caption.mp4" type="video/mp4">
                    </video>
        
                    
                </div>

                

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

<!-- Convergent functions -->
<section class="section hero">
    <div class="container is-max-desktop" style="max-width: 1200px;">
        <div class="columns is-centered">
            <div class="column is-full-width">
                <h2 class="title is-3 has-text-centered" id="convergence">Multi-design Control Policies</h2>
                <div style="text-align: center;">
                    <img src="./static/images/training_process.png"
                    class="interpolation-image"
                    alt="header-image."
                    width="65%"/>
                </div>
                
                <br>
                <p>
                    We leverage structural commonalities within the design space by training multi-design policies for clusters of morphologies that share structural and behavioral similarities. These cluster-specific policies serve as surrogate scoring functions, enabling efficient evaluation of a large number of designs within each cluster without retraining, thereby significantly improving <strong>search efficiency</strong>.
                </p>
                <br>
                <div id="efficiency_comparison" style="text-align: center;">
                    <img src="./static/images/efficiency_table.png"
                         class="interpolation-image"
                         alt="Efficiency and Coverage Table"
                         width="75%"/>
                  </div>
                <br>
                <p>
                    <strong>LOKI</strong> <img src="./static/images/LOKI_green-old.png" class="no-darkmode-invert" alt="LOKI Logo" style="height: 1em; margin-left: 0.3em;"> explores a much larger design space while requiring significantly fewer simulation steps and less training FLOPs per evaluated design.
                </p>

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


<!-- Diverse forms -->
<section class="section hero is-light">
    <div class="container is-max-desktop" style="max-width: 1200px;">
        <div class="columns is-centered">
            <div class="column is-full-width">
                <h2 class="title is-3 has-text-centered" id="diversity">Diverse High-performing designs <small>(Quality-Diversity Metrics)</small></h2>
                <div style="text-align: center;">
                <img src="./static/images/diverse_form_updated.png"
                 class="interpolation-image"
                 alt="header-image."
                 width="90%"/>
                 </div>
                <br>
                <p>
                    <strong>LOKI</strong> <img src="./static/images/LOKI_green-old.png" class="no-darkmode-invert" alt="LOKI Logo" style="height: 1em; margin-left: 0.3em;"> maintains both <strong>quality</strong> and <strong>diversity</strong>.
                    It achieves the highest QD-Score <a href="#reference" style="color: red;">[3]</a> among all baselines, demonstrating its ability to find high-performing solutions across a wide range of niches. 
                    Furthermore, <strong>LOKI</strong> <img src="./static/images/LOKI_green-old.png" class="no-darkmode-invert" alt="LOKI Logo" style="height: 1em; margin-left: 0.3em;"> evolves significantly more <strong>sparse</strong> solutions (measured by the average distance to k-nearest neighbors). 
                    This is due to using Dynamic Local Search for sampling designs, rather than mutations. 
                </p>

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

<!-- Morphology-level Adaptability -->
<section class="section hero">
    <div class="container is-max-desktop" style="max-width: 1200px;">
        <div class="columns is-centered">
            <div class="column is-full-width">
                <h2 class="title is-3 has-text-centered" id="behavior">Morphology-level Task Adaptability</h2>
                <div style="text-align: center;">
                    <img src="./static/images/morph_adaptability_updated.png"
                 class="interpolation-image"
                 alt="header-image."
                 width="90%"/>
                </div>
                
                <br>
                <p>
                    We evolve diverse morphologies on flat terrain that generalize more effectively to unseen tasks requiring varied skills. DERL <a href="#reference" style="color: red;">[2]</a> morphologies are overfitted to flat terrain and perform best on <i>obstacle (n=50)</i> and <i>incline</i>, which are structurally similar. In contrast, <strong>LOKI</strong> <img src="./static/images/LOKI_green-old.png" class="no-darkmode-invert" alt="LOKI Logo" style="height: 1em; margin-left: 0.3em;"> shows significantly better adaptability on <i>bump</i> (981 $\rightarrow$ 1908), <i>push box incline</i> (1519 $\rightarrow$ 3148), <i>manipulation ball</i> (142 $\rightarrow$ 172) enabled by its morphological diversity (e.g., crawlers, crabs) and the emergence of more complex behaviors (e.g., spinning, rolling).
                </p>
            </div>
        </div>
    </div>
</section>

<!-- Policy-level Adaptability -->
<section class="section hero is-light">
    <div class="container is-max-desktop" style="max-width: 1200px;">
        <div class="columns is-centered">
            <div class="column is-full-width">
                <h2 class="title is-3 has-text-centered" id="behavior">Policy-level Task Adaptability</h2>
                <div style="text-align: center;">
                    <img src="./static/images/policy_adaptability.png"
                 class="interpolation-image"
                 alt="header-image."
                 width="90%"/>
                </div>
                
                <br>
                <p>
                    Our co-evolution framework not only produces a diverse set of morphologies but also cluster-specific policies that generalize more effectively to unseen tasks. Each cluster captures distinct morphologies and behaviors, enabling its policy to better adapt to tasks aligned with those traits.
                </p>
            </div>
        </div>
    </div>
</section>

<!-- Reference -->
<section class="section hero">
    <div class="container is-max-desktop" style="max-width: 1200px;">
        <div class="columns is-centered">
            <div class="column is-full-width">
                <h2 class="title is-3 has-text-centered" id="reference">Reference</h2>
                <div class="content has-text-justified">

                    <div class="content has-text-justified">
                        <p>
                            [1]: Holger H. Hoos and Thomas Stützle. Stochastic Local Search Algorithms: An Overview, pages 1085–1105. Springer Berlin Heidelberg, Berlin, Heidelberg, 2015.
                        </p>
                        <p>
                            [2]: Agrim Gupta, Silvio Savarese, Surya Ganguli, and Li Fei-Fei. Embodied intelligence via learning and evolution. Nature communications, 12(1):5721, 2021.
                        </p>
                        <p>
                            [3]: Justin K Pugh, Lisa B Soros, and Kenneth O Stanley. Quality diversity: A new frontier for evolutionary computation. Frontiers in Robotics and AI, 3:40, 2016.
                        </p>
                    </div>


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


<footer class="footer" style="background-color: #f5f5f5">
    <div class="container">
        <div class="columns is-centered">
            <div class="column is-8">
                <div class="content">
                    <p>
                        This website based on the <a href="https://creativecommons.org/licenses/by-sa/4.0/">CC BY-SA
                        4.0</a> licensed
                        <a rel="template" href="https://github.com/nerfies/nerfies.github.io">Nerfies website</a>.
                    </p>
                </div>
            </div>
        </div>
    </div>
</footer>

</body>
</html>



