<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <meta name="description"
        content="Deformable Linear Object Manipulations with Differentiable Physics.">
  <meta name="keywords" content="Deformable Object Manipulation, Differentiable Physics">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <title>Deformable Linear Object Manipulations with Differentiable Physics</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="icon" href="./static/images/dlo.ico">

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

<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">
  <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-1 publication-title">Deformable Linear Object Manipulations with Differentiable Physics</h1>
          <div class="is-size-5 publication-authors">
            <span class="author-block">
              Anonymous authors
            </span>
          </div>

          <div class="is-size-5 publication-authors">
            <span class="author-block">Submission Number: 9432</span>
          </div>
        </div>
      </div>
    </div>
  </div>
</section>

<section class="hero teaser">
  <div class="container is-max-desktop">
    <div class="hero-body">
      <video id="teaser" autoplay muted loop playsinline height="100%">
        <source src="./static/videos/sim.mp4"
                type="video/mp4">
      </video>
      <h2 class="subtitle has-text-centered">
        <span class="dnerf">DLO-Lab</span> supports a wide range of material properties and <br/> enables versatile manipulations with Deformable Linear Objects (DLOs).
      </h2>
    </div>
  </div>
</section>


<section class="section">
  <div class="container is-max-desktop">
    <!-- 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 address the challenge of enabling robots to manipulate deformable linear objects (DLOs), such as wires, ropes, and rubber bands. 
            Prior work in this domain has primarily focused on narrow, task-specific problems, often relying on real-world demonstrations or handcrafted heuristics. 
            Such approaches, however, do not scale to the diverse range of materials and tasks encountered in practice, where collecting sufficiently varied real-world data is impractical. 
            Moreover, existing simulation environments provide limited support for the broad spectrum of material behaviors required for generalizable DLO manipulation. 
          </p>
          <p>
            To overcome these limitations, we introduce a differentiable physics simulator specifically designed for versatile DLO manipulation. 
            Our simulator models a wide range of material properties—including extensibility, inextensibility, elasticity, bending plasticity, and interactions with both rigid and deformable objects—thereby establishing a robust foundation for learning and evaluating manipulation skills. 
          </p>
          <p>
            Building on this simulator, we propose a benchmark suite of representative DLO manipulation tasks that highlight their unique challenges. 
            We further evaluate multiple policy learning algorithms on these tasks. The results show that reinforcement learning can learn closed-loop policies but requires prohibitively large amounts of data. 
            In contrast, trajectory optimization is more efficient: gradient-based methods achieve the best sample efficiency when gradients are available, while sampling-based approaches are broadly applicable but less efficient.
          </p>
        </div>
      </div>
    </div>
  </div>
</section>


<section class="section">
  <div class="container is-max-desktop">

    <div class="columns is-centered">
      <div class="column is-full-width">
        <h2 class="title is-3">Benchmark Tasks</h2>

        <div class="content has-text-justified">
          <p>
            We show the manipulation tasks in our benchmark, each with an initial state and the desired goal state.
          </p>
        </div>
        <div class="rows is-vcentered">
          <div class="row is-3 has-text-centered">
            <img src="./static/images/task_r1.png"
                 class="interpolation-image"
                 alt="Interpolate start reference image."/>
          </div>
          <div class="row is-3 has-text-centered">
            <img src="./static/images/task_r2.png"
                 class="interpolation-image"
                 alt="Interpolate start reference image."/>
          </div>
          <div class="row is-3 has-text-centered">
            <img src="./static/images/task_r3.png"
                 class="interpolation-image"
                 alt="Interpolate start reference image."/>
          </div>
        </div>
        <br/>

      </div>
    </div>

    <div class="columns is-centered">
      <div class="column is-full-width">
        <h2 class="title is-3">Task Demos</h2>
        <h3 class="title is-4">PPO</h3>
      </div>
    </div>

  </div>
</section>

<section class="hero is-light is-small">
  <div class="hero-body">
    <div class="container">
      <div id="results-carousel" class="carousel results-carousel">
        <div class="item item-coiling">
          <video poster="" id="coiling" autoplay controls muted loop playsinline height="100%">
            <source src="./static/videos/ppo/coiling.mp4"
                    type="video/mp4">
          </video>
        </div>
        <div class="item item-gathering">
          <video poster="" id="gathering" autoplay controls muted loop playsinline height="100%">
            <source src="./static/videos/ppo/gathering.mp4"
                    type="video/mp4">
          </video>
        </div>
        <div class="item item-lifting">
          <video poster="" id="lifting" autoplay controls muted loop playsinline height="100%">
            <source src="./static/videos/ppo/lifting.mp4"
                    type="video/mp4">
          </video>
        </div>
        <div class="item item-separation">
          <video poster="" id="separation" autoplay controls muted loop playsinline height="100%">
            <source src="./static/videos/ppo/separation.mp4"
                    type="video/mp4">
          </video>
        </div>
        <div class="item item-slingshot">
          <video poster="" id="slingshot" autoplay controls muted loop playsinline height="100%">
            <source src="./static/videos/ppo/slingshot.mp4"
                    type="video/mp4">
          </video>
        </div>
        <div class="item item-wireart">
          <video poster="" id="wireart" autoplay controls muted loop playsinline height="100%">
            <source src="./static/videos/ppo/wireart.mp4"
                    type="video/mp4">
          </video>
        </div>
        <div class="item item-wiring_post">
          <video poster="" id="wiring_post" autoplay controls muted loop playsinline height="100%">
            <source src="./static/videos/ppo/wiring_post.mp4"
                    type="video/mp4">
          </video>
        </div>
        <div class="item item-wiring_ring">
          <video poster="" id="wiring_ring" autoplay controls muted loop playsinline height="100%">
            <source src="./static/videos/ppo/wiring_ring.mp4"
                    type="video/mp4">
          </video>
        </div>
        <div class="item item-wrapping">
          <video poster="" id="wrapping" autoplay controls muted loop playsinline height="100%">
            <source src="./static/videos/ppo/wrapping.mp4"
                    type="video/mp4">
          </video>
        </div>
      </div>
    </div>
  </div>
</section>

<section class="section">
  <div class="container is-max-desktop">

    <div class="columns is-centered">
      <div class="column is-full-width">
        <h3 class="title is-4">CMA-ES</h3>
      </div>
    </div>

  </div>
</section>

<section class="hero is-light is-small">
  <div class="hero-body">
    <div class="container">
      <div id="results-carousel" class="carousel results-carousel">
        <div class="item item-coiling">
          <video poster="" id="coiling" autoplay controls muted loop playsinline height="100%">
            <source src="./static/videos/cmaes/coiling.mp4"
                    type="video/mp4">
          </video>
        </div>
        <div class="item item-gathering">
          <video poster="" id="gathering" autoplay controls muted loop playsinline height="100%">
            <source src="./static/videos/cmaes/gathering.mp4"
                    type="video/mp4">
          </video>
        </div>
        <div class="item item-lifting">
          <video poster="" id="lifting" autoplay controls muted loop playsinline height="100%">
            <source src="./static/videos/cmaes/lifting.mp4"
                    type="video/mp4">
          </video>
        </div>
        <div class="item item-separation">
          <video poster="" id="separation" autoplay controls muted loop playsinline height="100%">
            <source src="./static/videos/cmaes/separation.mp4"
                    type="video/mp4">
          </video>
        </div>
        <div class="item item-slingshot">
          <video poster="" id="slingshot" autoplay controls muted loop playsinline height="100%">
            <source src="./static/videos/cmaes/slingshot.mp4"
                    type="video/mp4">
          </video>
        </div>
        <div class="item item-wireart">
          <video poster="" id="wireart" autoplay controls muted loop playsinline height="100%">
            <source src="./static/videos/cmaes/wireart.mp4"
                    type="video/mp4">
          </video>
        </div>
        <div class="item item-wiring_post">
          <video poster="" id="wiring_post" autoplay controls muted loop playsinline height="100%">
            <source src="./static/videos/cmaes/wiring_post.mp4"
                    type="video/mp4">
          </video>
        </div>
        <div class="item item-wiring_ring">
          <video poster="" id="wiring_ring" autoplay controls muted loop playsinline height="100%">
            <source src="./static/videos/cmaes/wiring_ring.mp4"
                    type="video/mp4">
          </video>
        </div>
        <div class="item item-wrapping">
          <video poster="" id="wrapping" autoplay controls muted loop playsinline height="100%">
            <source src="./static/videos/cmaes/wrapping.mp4"
                    type="video/mp4">
          </video>
        </div>
      </div>
    </div>
  </div>
</section>

<section class="section">
  <div class="container is-max-desktop">
    <div class="columns is-centered">
      <div class="column is-full-width">
        <h2 class="title is-3">Robustness Evaluation</h2>

        <div class="content has-text-justified">
          <p>
            We evaluate the robustness of the learned PPO policy for the Separation task under different initial configurations of the DLO.
          </p>
        </div>
        <div class="content has-text-centered">
          <video id="robustness-video"
                 controls
                 muted
                 preload
                 playsinline
                 width="90%">
            <source src="./static/videos/robustness.mp4"
                    type="video/mp4">
          </video>
        </div>

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


<section class="section">
  <div class="container is-max-desktop">

    <div class="columns is-centered">
      <div class="column is-full-width">
        <h2 class="title is-3">Sim-to-Real Demo</h2>
      </div>
    </div>

  </div>
</section>

<section class="hero is-light is-small">
  <div class="hero-body">
    <div class="container is-max-desktop">
      <div class="content has-text-centered">
        <video id="sim-to-real-video-1"
              controls
              muted
              preload
              playsinline
              width="30%">
          <source src="./static/videos/silingshot_sim.mp4"
                  type="video/mp4">
        </video>
        <video id="sim-to-real-video-2"
              controls
              muted
              preload
              playsinline
              width="30%">
          <source src="./static/videos/silingshot_real.mp4"
                  type="video/mp4">
        </video>
      </div>
    </div>
  </div>
</section>

<footer class="footer">
  <div class="container">
    <div class="columns is-centered">
      <div class="column is-8">
        <div class="content">
          <p>
            This website is licensed under a <a rel="license"
                                                href="http://creativecommons.org/licenses/by-sa/4.0/">Creative
            Commons Attribution-ShareAlike 4.0 International License</a>.
          </p>
          <p>
            This means you are free to borrow the <a
              href="https://github.com/nerfies/nerfies.github.io">source code</a> of this website,
            we just ask that you link back to this page in the footer.
            Please remember to remove the analytics code included in the header of the website which
            you do not want on your website.
          </p>
        </div>
      </div>
    </div>
  </div>
</footer>

</body>
</html>
