<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <title>LLM-Navi: Navigating Motion Agents in Dynamic and Cluttered Environments through LLM Reasoning</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">

  <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>
</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">LLM-Navi: Navigating Motion Agents in Dynamic and Cluttered Environments through LLM Reasoning</h1>
        </div>
      </div>
    </div>
  </div>
</section>

<section class="hero teaser">
  <div class="container is-max-desktop">
    
        <!-- <center><h2 class="title is-3">Abstract</h2></center> -->
    <!-- <div class="hero-body has-text-centered">
        <img src = "./images/teaser.png" height="80%"></img><br>

    </div> -->

    <p>
      We introduce <b>LLM-Navi</b>, a novel large language model-based (LLMs) framework for autonomous navigation in dynamic and cluttered environments. 
      Unlike prior studies constraining LLMs to simplistic, static settings with limited movement options, LLM-Navi enables robust spatial reasoning in realistic, 
      multi-agent scenarios, achieved by uniformly encoding the environments (e.g., real-world floorplans), dynamic agents, and their trajectories as <em>tokens</em>. 
      In doing so, we unlock the zero-shot spatial reasoning capabilities inherent in LLMs without requiring retraining or fine-tuning. LLM-Navi supports multi-agent coordination, 
      dynamic obstacle avoidance, and closed-loop replanning, demonstrating generalization across diverse agents, tasks, and environments through text-based interactions. 
      Our experiments show that LLMs can autonomously generate collision-free trajectories, adapt to dynamic changes, and resolve multi-agent conflicts in real time. 
      We extend this framework to humanoid motion generation, showcasing its potential for real-world applications in robotics and human-robot interaction.  
      This work thus establishes a first foundation for integrating LLMs into embodied spatial reasoning tasks, 
      offering a scalable and semantically grounded alternative to traditional methods.
    </p>
    <br>
    <div id="video-container">
      <video id="video" muted controls playsinline>
        <source src="./video/fig1/fig1.mkv" type="video/mp4">
      </video>
      <!-- <span style="font-size:12px">* This video contains audio.</span> -->
    </div>
    
  </div>
</section>



<section class="section is-light is-small">
  <div class="container is-max-desktop">
    <center><h2 class="title is-3">Overview</h2></center>
    <div class="hero-body">
      <a href="./images/model.png"><img src = "./images/model.png" height="100%"></img></href></a><br>
    </div>
  </div>
    <!--/ Abstract. -->

</section>

<section class="section"></section>
  <div class="container is-max-desktop">

    <center><h2 class="title is-3">Qualitative Results</h2></center><br>
    <br>
    <h3 class="title is-4">Two agents playing hide and seek</h2>
    <br>
    <div class="columns is-centered">
      <div class="column">
        <div id="video-container">
          <center><p><b> "You are now a hider,</b></p></center>
          <center><p><b> find somewhere to hide."</b></p></center>
          <video id="video" muted controls playsinline="40%">
              <source src="./video/fig2/hider.mp4"
                      type="video/mp4">
            </video>
        </div>
      </div>
      <div class="column">
        <div class="content">
          <center><p><b> "Seeker designated! The hider may be anywhere. </b></p></center>
          <center><p><b> Find the hider!"</b></p></center>
          <video poster="" id="warmup" muted controls playsinline="40%">
              <source src="./video/fig2/seeker.mp4"
                      type="video/mp4">
            </video>
        </div>
      </div>
    </div>
    <div id="video-container">
      <video id="video" muted controls playsinline>
        <source src="./video/fig2/fig2.mkv" type="video/mp4">
      </video>
      <!-- <span style="font-size:12px">* This video contains audio.</span> -->
    </div>


    <br>
    <h3 class="title is-4">Dynamic Resolving</h2>
    <h3 class="title is-5">Navigate the path for three agents:
      agent 1 from (1,1) to (8,8); agent 2 from (1,8) to (8,1);
      agent 3 from (4,8) to (4,1).
      </h2>
    <div class="columns is-centered">
      <div class="column">
        <div id="video-container">
          <center><p><b> Original trajectory</b></p></center>
          <video id="video" muted controls playsinline="40%">
              <source src="./video/fig3/original.mp4"
                      type="video/mp4">
            </video>
        </div>
      </div>
      <div class="column">
        <div class="content">
          <center><p><b> Updated trajectory after resloving by LLM </b></p></center>
          <video poster="" id="warmup" muted controls playsinline="40%">
              <source src="./video/fig3/updated.mp4"
                      type="video/mp4">
            </video>
        </div>
      </div>
    </div>
    <div class="columns is-centered">
      <div class="column">
        <div id="video-container">
          <video id="video" muted controls playsinline="40%">
              <source src="./video/fig3/fig3.mkv"
                      type="video/mp4">
            </video>
        </div>
      </div>
    </div>

    <br>
    <h3 class="title is-5">Agent1 walks from (2,3) to (17,8); 
      agent2 walks from (4,8) to (3,17);
      agent3 walks from (17,8) to (4,1);
      agent4 walks from (16,15) to (6,2);
      agent5 walks from (5,20) to (1,7).      
      </h2>
    <div class="columns is-centered">
      <div class="column">
        <div id="video-container">
          <center><p><b>Top-down view</b></p></center>
          <video id="video" muted controls playsinline="40%">
              <source src="./video/fig4/fig4.mp4"
                      type="video/mp4">
            </video>
        </div>
      </div>
      <div class="column">
        <div class="content">
          <center><p><b>Generated motion</b></p></center>
          <video poster="" id="warmup" muted controls playsinline="40%">
            <source src="./video/fig4/fig4.mkv" type="video/mp4">
            </video>
        </div>
      </div>
    </div>

    <br>
    <h3 class="title is-4"> More Examples </h2>
    <h3 class="title is-5"> A person runs out of the room that is on fire from (12,1) to (11,7).
      </h2>
    <div class="columns is-centered">
      <div class="column">
        <div id="video-container">
          <center><p><b>Top-down view</b></p></center>
          <video id="video" muted controls playsinline="40%">
              <source src="./video/fig5/fig5.mp4"
                      type="video/mp4">
            </video>
        </div>
      </div>
      <div class="column">
        <div class="content">
          <center><p><b>Generated motion</b></p></center>
          <video poster="" id="warmup" muted controls playsinline="40%">
              <source src="./video/fig5/fig5.mkv"
                      type="video/mp4">
            </video>
        </div>
      </div>
    </div>

    <br>
    <h3 class="title is-5"> Agent1 walks sideways from (1,1) to (18,8); agent2 walks with hands in front
      from (2,18) to (9,19); agent3 walks from (15,2) to (13,20).
      </h2>
    <div class="columns is-centered">
      <div class="column">
        <div id="video-container">
          <center><p><b>Top-down view</b></p></center>
          <video id="video" muted controls playsinline="40%">
              <source src="./video/fig6/fig6.mp4"
                      type="video/mp4">
            </video>
        </div>
      </div>
      <div class="column">
        <div class="content">
          <center><p><b>Generated motion</b></p></center>
          <video poster="" id="warmup" muted controls playsinline="40%">
              <source src="./video/fig6/fig6.mkv"
                      type="video/mp4">
            </video>
        </div>
      </div>
    </div>

    <br>
    <h3 class="title is-5"> Agent walks from (15,8) to (15,24).
      </h2>
    <div class="columns is-centered">
      <div class="column">
        <div id="video-container">
          <center><p><b>Top-down view</b></p></center>
          <video id="video" muted controls playsinline="40%">
              <source src="./video/fig8/fig8.mp4"
                      type="video/mp4">
            </video>
        </div>
      </div>
      <div class="column">
        <div class="content">
          <center><p><b>Generated motion</b></p></center>
          <video poster="" id="warmup" muted controls playsinline="40%">
              <source src="./video/fig8/fig8.mkv"
                      type="video/mp4">
            </video>
        </div>
      </div>
    </div>

    <br>
    <h3 class="title is-5"> Agent1 walks from (2,2) to (11,9);
      agent2 walks from (2,9) to (11,2);
      agent3 walks from (13,2) to (2,9).
      </h2>
    <div class="columns is-centered">
      <div class="column">
        <div id="video-container">
          <center><p><b>Top-down view</b></p></center>
          <video id="video" muted controls playsinline="40%">
              <source src="./video/fig9/fig9.mp4"
                      type="video/mp4">
            </video>
        </div>
      </div>
      <div class="column">
        <div class="content">
          <center><p><b>Generated motion</b></p></center>
          <video poster="" id="warmup" muted controls playsinline="40%">
              <source src="./video/fig9/fig9.mkv"
                      type="video/mp4">
            </video>
        </div>
      </div>
    </div>
    

    <br>
    <h3 class="title is-4">Extension to 2.5D</h2>
    <br>
    <h3 class="title is-5">Agent walks up the stairs from (1,4,0) to (5,4,1).</h2>
      <div id="video-container">
        <video id="video" muted controls playsinline>
          <source src="./video/fig7/fig7.mkv" type="video/mp4">
        </video>
        <!-- <span style="font-size:12px">* This video contains audio.</span> -->
      </div>



<script>
      var videoContainer = document.getElementById('video-container');
      var video = document.getElementById('video');

      var videoOffset = videoContainer.offsetTop;

      window.addEventListener('scroll', function() {
        var scrollPosition = window.scrollY || window.pageYOffset;

        if (scrollPosition >= videoOffset) {
          video.play();
        } else {
          video.pause();
        }
      });
    </script>

</body>
</html>
