

<!DOCTYPE html>


<html lang="en" data-content_root="" >

  <head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="generator" content="Docutils 0.19: https://docutils.sourceforge.io/" />

    <title>ManiSkill3 Supplemental</title>
  
  
  
  <script data-cfasync="false">
    document.documentElement.dataset.mode = localStorage.getItem("mode") || "";
    document.documentElement.dataset.theme = localStorage.getItem("theme") || "";
  </script>
  <!--
    this give us a css class that will be invisible only if js is disabled
  -->
  <noscript>
    <style>
      .pst-js-only { display: none !important; }

    </style>
  </noscript>
  
  <!-- Loaded before other Sphinx assets -->
  <link href="./_static/styles/theme.css?digest=8878045cc6db502f8baf" rel="stylesheet" />
<link href="./_static/styles/pydata-sphinx-theme.css?digest=8878045cc6db502f8baf" rel="stylesheet" />

    <link rel="stylesheet" type="text/css" href="./_static/pygments.css" />
    <link rel="stylesheet" type="text/css" href="./_static/copybutton.css" />
    <link rel="stylesheet" type="text/css" href="./_static/togglebutton.css" />
    <link rel="stylesheet" type="text/css" href="./_static/sphinx-design.4cbf315f70debaebd550c87a6162cf0f.min.css" />
    <link rel="stylesheet" type="text/css" href="./_static/css/custom.css" />
  
  <!-- So that users can add custom icons -->
  <script src="./_static/scripts/fontawesome.js?digest=8878045cc6db502f8baf"></script>
  <!-- Pre-loaded scripts that we'll load fully later -->
  <link rel="preload" as="script" href="./_static/scripts/bootstrap.js?digest=8878045cc6db502f8baf" />
<link rel="preload" as="script" href="./_static/scripts/pydata-sphinx-theme.js?digest=8878045cc6db502f8baf" />

    <script data-url_root="../../" id="documentation_options" src="./_static/documentation_options.js"></script>
    <script src="./_static/doctools.js"></script>
    <script src="./_static/sphinx_highlight.js"></script>
    <script src="./_static/clipboard.min.js"></script>
    <script src="./_static/copybutton.js"></script>
    <script>let toggleHintShow = 'Click to show';</script>
    <script>let toggleHintHide = 'Click to hide';</script>
    <script>let toggleOpenOnPrint = 'true';</script>
    <script src="./_static/togglebutton.js"></script>
    <script>var togglebuttonSelector = '.toggle, .admonition.dropdown';</script>
    <script src="./_static/design-tabs.js"></script>
    <script>
        DOCUMENTATION_OPTIONS.theme_version = '0.16.1';
        DOCUMENTATION_OPTIONS.theme_switcher_json_url = '_static/version_switcher.json';
        DOCUMENTATION_OPTIONS.theme_switcher_version_match = 'v3.0.0b18';
        DOCUMENTATION_OPTIONS.show_version_warning_banner =
            false;
        </script>
    <link rel="icon" href="./_static/favicon.svg"/>
    <link rel="index" title="Index" href="../../genindex.html" />
    <link rel="search" title="Search" href="../../search.html" />
    <link rel="next" title="Demo Scripts" href="scripts.html" />
    <link rel="prev" title="Demos" href="index.html" />
  <meta name="viewport" content="width=device-width, initial-scale=1"/>
  <meta name="docsearch:language" content="en"/>
  <meta name="docsearch:version" content="3.0.0b18" />
  </head>
  
  
  <body data-bs-spy="scroll" data-bs-target=".bd-toc-nav" data-offset="180" data-bs-root-margin="0px 0px -60%" data-default-mode="">

  
  
  <div id="pst-skip-link" class="skip-link d-print-none"><a href="#main-content">Skip to main content</a></div>
  
  <div id="pst-scroll-pixel-helper"></div>
  
  <button type="button" class="btn rounded-pill" id="pst-back-to-top">
    <i class="fa-solid fa-arrow-up"></i>Back to top</button>

<!--   
  <dialog id="pst-search-dialog">
    
<form class="bd-search d-flex align-items-center"
      action="../../search.html"
      method="get">
  <i class="fa-solid fa-magnifying-glass"></i>
  <input type="search"
         class="form-control"
         name="q"
         placeholder="Search the docs ..."
         aria-label="Search the docs ..."
         autocomplete="off"
         autocorrect="off"
         autocapitalize="off"
         spellcheck="false"/>
  <span class="search-button__kbd-shortcut"><kbd class="kbd-shortcut__modifier">Ctrl</kbd>+<kbd>K</kbd></span>
</form>
  </dialog> -->

  <div class="pst-async-banner-revealer d-none">
  <aside id="bd-header-version-warning" class="d-none d-print-none" aria-label="Version warning"></aside>
</div>

  
    <header class="bd-header navbar navbar-expand-lg bd-navbar d-print-none">
<div class="bd-header__inner bd-page-width">
  
  <div class="col-lg-9 navbar-header-items">
    
    <div class="me-auto navbar-header-items__center">
      
        <div class="navbar-item">
</div>
      
    </div>
    

  
  
    <div class="navbar-persistent--mobile">

<button class="btn search-button-field search-button__button pst-js-only" title="Search" aria-label="Search" data-bs-placement="bottom" data-bs-toggle="tooltip">
 <i class="fa-solid fa-magnifying-glass"></i>
 <span class="search-button__default-text">Search</span>
 <span class="search-button__kbd-shortcut"><kbd class="kbd-shortcut__modifier">Ctrl</kbd>+<kbd class="kbd-shortcut__modifier">K</kbd></span>
</button>
    </div>
  

  
    <button class="pst-navbar-icon sidebar-toggle secondary-toggle" aria-label="On this page">
      <span class="fa-solid fa-outdent"></span>
    </button>
  
</div>

    </header>
  

  <div class="bd-container">
    <div class="bd-container__inner bd-page-width">
      
      
      
      <dialog id="pst-primary-sidebar-modal"></dialog>
      <div id="pst-primary-sidebar" class="bd-sidebar-primary bd-sidebar">
        

  
  <div class="sidebar-header-items sidebar-primary__section">
    
    
      <div class="sidebar-header-items__center">
        
          
          
            <div class="navbar-item">
<div class="version-switcher__container dropdown pst-js-only">
  <button id="pst-version-switcher-button-3"
    type="button"
    class="version-switcher__button btn btn-sm dropdown-toggle"
    data-bs-toggle="dropdown"
    aria-haspopup="listbox"
    aria-controls="pst-version-switcher-list-3"
    aria-label="Version switcher list"
  >
    Choose version  <!-- this text may get changed later by javascript -->
    <span class="caret"></span>
  </button>
  <div id="pst-version-switcher-list-3"
    class="version-switcher__menu dropdown-menu list-group-flush py-0"
    role="listbox" aria-labelledby="pst-version-switcher-button-3">
    <!-- dropdown will be populated by javascript on page load -->
  </div>
</div>
</div>
          
        
          
          
            <div class="navbar-item">
<nav>
  <ul class="bd-navbar-elements navbar-nav">

  </ul>
</nav></div>
          
        
      </div>
    
    
    
      <div class="sidebar-header-items__end">
        
          <div class="navbar-item">

<button class="btn btn-sm nav-link pst-navbar-icon theme-switch-button pst-js-only" aria-label="Color mode" data-bs-title="Color mode"  data-bs-placement="bottom" data-bs-toggle="tooltip">
  <i class="theme-switch fa-solid fa-sun                fa-lg" data-mode="light" title="Light"></i>
  <i class="theme-switch fa-solid fa-moon               fa-lg" data-mode="dark"  title="Dark"></i>
  <i class="theme-switch fa-solid fa-circle-half-stroke fa-lg" data-mode="auto"  title="System Settings"></i>
</button></div>
        
          <div class="navbar-item"><ul class="navbar-icon-links"
    aria-label="Icon Links">
        
        <li class="nav-item">
          
          
          
          
          
          
        </li>
</ul></div>
        
      </div>
    
  </div>
  
  <div class="sidebar-primary-items__end sidebar-primary__section">
      <div class="sidebar-primary-item">
<div id="ethical-ad-placement"
      class="flat"
      data-ea-publisher="readthedocs"
      data-ea-type="readthedocs-sidebar"
      data-ea-manual="true">
</div></div>
  </div>


      </div>
      
      <main id="main-content" class="bd-main" role="main">
        
        
          <div class="bd-content">
            <div class="bd-article-container">
              
              <div class="bd-header-article d-print-none">
<div class="header-article-items header-article__inner">
  
    <div class="header-article-items__start">
      
        <div class="header-article-item">

<!-- <nav aria-label="Breadcrumb" class="d-print-none">
  <ul class="bd-breadcrumbs">
    
    <li class="breadcrumb-item breadcrumb-home">
      <a href="../../index.html" class="nav-link" aria-label="Home">
        <i class="fa-solid fa-home"></i>
      </a>
    </li>
    
    <li class="breadcrumb-item"><a href="../index.html" class="nav-link">User Guide</a></li>
    
    
    <li class="breadcrumb-item"><a href="index.html" class="nav-link"><svg version="4.0.0.63c5cb3" width="1.0em" height="1.0em" class="sd-material-icon sd-material-icon-notes" viewBox="0 0 24 24" aria-hidden="true"><path d="M0 0h24v24H0V0z" fill="none"></path><path d="M3 18h12v-2H3v2zM3 6v2h18V6H3zm0 7h18v-2H3v2z"></path></svg> Demos</a></li>
    
    <li class="breadcrumb-item active" aria-current="page"><span class="ellipsis">Demo Gallery</span></li>
  </ul>
</nav> -->
</div>
      
    </div>
  
  
</div>
</div>
              
              
              
                
<div id="searchbox"></div>
                <article class="bd-article">
                  
  <section class="tex2jax_ignore mathjax_ignore" id="demo-gallery">
<h1>Supplemental<a class="headerlink" href="#demo-gallery" title="Permalink to this heading">#</a></h1>
<p>This is the page documenting and showcasing various demonstration videos of the ManiSkill3 system. Best viewed by opening the supplemental.html file in a web browser such as Chrome, otherwise one can look through the videos folder for the individual videos and follow this document for descriptions of each video.</p>
<section id="parallel-rendering">
<h2>Parallel Rendering<a class="headerlink" href="#parallel-rendering" title="Permalink to this heading">#</a></h2>
<p><video controls="True" width="100%" style="max-width: min(100%, 512px);" playsinline="true"><source src="./videos/parallel_rendering.mp4" type="video/mp4"></video></p>
<caption>
    Parallel rendering of the AnymalC Quadruped robot controlled by a visual-based RL policy walking to a goal, showcasing a subset of the 1024 environments being rendered in parallel.
</caption>
</section>
<section id="heterogeneous-simulation">
<h2>Heterogeneous Simulation<a class="headerlink" href="#heterogeneous-simulation" title="Permalink to this heading">#</a></h2>
<p><video controls="True" width="100%" style="max-width: min(100%, 512px);" playsinline="true" ><source src="./videos/heterogeneous_simulation.mp4" type="video/mp4"></video></p>
<caption>
    Parallel heterogeneous simulation of the mobile manipulator Fetch robot opening different cabinets of different degrees of freedom, showcasing the ability to simulate different geometries and articulations in one GPU simulation. The robot is controlled by a state-based RL policy trained in 15 minutes on a single 4090 GPU.
</caption>
</section>
<section id="fast-visual-training-speed">
<h2>Fast Visual Training Speed<a class="headerlink" href="#fast-visual-training-speed" title="Permalink to this heading">#</a></h2>
<p><video controls="True" width="49%" style="display: inline-block;" playsinline="true"><source src="./videos/pickcube_low_closeup.mp4" type="video/mp4"></video><video controls="True" width="49%" style="display: inline-block;" playsinline="true"><source src="./videos/pusht_low_close.mp4" type="video/mp4"></video></p>
<caption>
    Fast training speed of a state and vision-based RL policy for the PickCube and PushT tasks. With state inputs PickCube is solved in about 1 minute, PushT is solved in about 5 minutes. With visual inputs PickCube is solved in about 10 minutes and PushT is solved in about 50 minutes. PPO is used for training with 4096 parallel environments for state-based experiments and 1024 parallel environments for vision-based experiments, running on a single 4090 GPU.
</caption>
</section>
<section id="vision-based-zero-shot-sim2real-manipulation">
<h2>Vision-Based Zero-shot Sim2Real Manipulation<a class="headerlink" href="#vision-based-zero-shot-sim2real-manipulation" title="Permalink to this heading">#</a></h2>
<p>We demonstrate some zero-shot sim2real manipulation results using the low-cost $300 Koch v1.1. robot arm and <a class="reference external" href="https://github.com/huggingface/LeRobot">🤗 LeRobot</a> code for robot hardware interface/control. Policy is trained with PPO on RGB camera inputs and robot proprioceptive data for about an hour on a single 4090 GPU on a domain randomized simulation environment.</p>
<section id="real-world-uncut-evaluation">
<h3>Real World Uncut Evaluation<a class="headerlink" href="#real-world-uncut-evaluation" title="Permalink to this heading">#</a></h3>
<p><video controls="True" width="100%" style="max-width: min(100%, 512px);" playsinline="true" ><source src="./videos/koch_arm_pickcube_eval_compressed.mp4" type="video/mp4"></video></p>
<caption>
    Real world evaluation of the PickCube task at 1x speed. 18/20 trials were successful where success is defined as the robot arm being able to pick up the cube and move it back to a rest position. In all 20/20 trials the robot arm was always able to grasp the cube. The camera observation fed to the policy is displayed on the phone screen. This demo was setup by picking a random table in a house and following our to be open-sourced tutorial to setup the robot and perform training in the new scene.
</caption>
<br/>
<br/>
<p>Interestingly there are some untrained behaviors such as being able to pick up non cube-shaped objects, although we do not claim this kind of generalization always works.</p>
<p><video controls="True" width="100%" style="max-width: min(100%, 512px);" playsinline="true" ><source src="./videos/koch_arm_pickcube_eval_ood_compressed.mp4" type="video/mp4"></video></p>
<caption>
    Real world evaluation of the PickCube task at 1x speed on unseen object shapes.
</caption>
</section>
<section id="reset-distributions">
<h3>Reset Distributions<a class="headerlink" href="#reset-distributions" title="Permalink to this heading">#</a></h3>
<p><video controls="True" width="32%" style="display: inline-block;" playsinline="true"><source src="./videos/koch_arm_pickcube_reset_distribution_sim.mp4" type="video/mp4"></video><video controls="True" width="32%" style="display: inline-block;" playsinline="true"><source src="./videos/koch_arm_pickcube_reset_distribution_sim_overlay.mp4" type="video/mp4"></video><video controls="True" width="32%" style="display: inline-block;" playsinline="true"><source src="./videos/koch_arm_pickcube_reset_distribution_real.mp4" type="video/mp4"></video></p>
<caption>
    Reset distribution of the PickCube task with the low-cost Koch v1.1. robot arm from LeRobot. Left: Simulation without overlay. Middle: Simulation with overlay. Right: Real world. Reset distribution here shows the domain randomizations all applied together to the simulation environment as well as the robustness testing we perform in the real world by testing on different cube sizes, colors, and poses.
</caption>
</section>
</section>
<section id="real2sim-evaluation-environments">
<h2>Real2Sim Evaluation Environments<a class="headerlink" href="#real2sim-evaluation-environments" title="Permalink to this heading">#</a></h2>
<p><video controls="True" width="49%" style="max-width: min(100%, 512px);display: inline-block;" playsinline="true"><source src="./videos/octo_base_put_eggplant_in_basket.mp4" type="video/mp4"></video>
<video controls="True" width="49%" style="display: inline-block;" playsinline="true"><source src="./videos/octo_small_put_spoon_on_towel.mp4" type="video/mp4"></video>
<video controls="True" width="49%" style="display: inline-block;" playsinline="true"><source src="./videos/octo_small_stack_green_block_on_yellow_block.mp4" type="video/mp4"></video>
<video controls="True" width="49%" style="display: inline-block;" playsinline="true"><source src="./videos/rt1x_put_carrot_on_plate.mp4" type="video/mp4"></video></p>
<p>We port over some of the Real2Sim evaluation environments from the SIMPLER project. The videos below show 4 different vision language action (VLA) models being evaluated on 4 different tasks (videos are originally from SIMPLER). These videos are subsets of the 128 environments that are being simulated and rendered in parallel to evaluate VLAs.</p>
<!-- ## Teleoperation -->
</section>
<section id="teleoperation">
  <h2>Teleoperation<a class="headerlink" href="#teleoperation" title="Permalink to this heading">#</a></h2>
  <p><video controls="True" style="max-width: min(100%, 512px);" playsinline="true"><source src="./videos/teleop_ability_hand.mp4" type="video/mp4"></video>
  <p>We provide a VR based teleoperation system for various robot configurations that is integrated with ManiSkill3, enabling low-latency teleoperation with 4K stereo video streaming to the user at 60 Hz. The video shows a teleoperator controlling two dextrous 5-fingered hands to pick up an object from the YCB dataset in simulation via the Meta Quest 3.</p>
  <!-- ## Teleoperation -->
  </section>
</section>


                </article>
              
              
              
              
              
                <footer class="prev-next-footer d-print-none">
<!--                   
<div class="prev-next-area">
    <a class="left-prev"
       href="index.html"
       title="previous page">
      <i class="fa-solid fa-angle-left"></i>
      <div class="prev-next-info">
        <p class="prev-next-subtitle">previous</p>
        <p class="prev-next-title"><svg version="4.0.0.63c5cb3" width="1.0em" height="1.0em" class="sd-material-icon sd-material-icon-notes" viewBox="0 0 24 24" aria-hidden="true"><path d="M0 0h24v24H0V0z" fill="none"></path><path d="M3 18h12v-2H3v2zM3 6v2h18V6H3zm0 7h18v-2H3v2z"></path></svg> Demos</p>
      </div>
    </a>
    <a class="right-next"
       href="scripts.html"
       title="next page">
      <div class="prev-next-info">
        <p class="prev-next-subtitle">next</p>
        <p class="prev-next-title">Demo Scripts</p>
      </div>
      <i class="fa-solid fa-angle-right"></i>
    </a>
</div> -->
                </footer>
              
            </div>
            
            
              
                <dialog id="pst-secondary-sidebar-modal"></dialog>
                <div id="pst-secondary-sidebar" class="bd-sidebar-secondary bd-toc"><div class="sidebar-secondary-items sidebar-secondary__inner">


  <div class="sidebar-secondary-item">
<div
    id="pst-page-navigation-heading-2"
    class="page-toc tocsection onthispage">
    <i class="fa-solid fa-list"></i> On this page
  </div>
  <nav class="bd-toc-nav page-toc" aria-labelledby="pst-page-navigation-heading-2">
    <ul class="visible nav section-nav flex-column">
<li class="toc-h2 nav-item toc-entry"><a class="reference internal nav-link" href="#parallel-rendering">Parallel Rendering</a></li>
<li class="toc-h2 nav-item toc-entry"><a class="reference internal nav-link" href="#heterogeneous-simulation">Heterogeneous Simulation</a></li>
<li class="toc-h2 nav-item toc-entry"><a class="reference internal nav-link" href="#fast-visual-training-speed">Fast Visual Training Speed</a></li>
<li class="toc-h2 nav-item toc-entry"><a class="reference internal nav-link" href="#vision-based-zero-shot-sim2real-manipulation">Vision-Based Zero-shot Sim2Real Manipulation</a><ul class="nav section-nav flex-column">
<li class="toc-h3 nav-item toc-entry"><a class="reference internal nav-link" href="#real-world-uncut-evaluation">Real World Uncut Evaluation</a></li>
<li class="toc-h3 nav-item toc-entry"><a class="reference internal nav-link" href="#reset-distributions">Reset Distributions</a></li>
</ul>
</li>
<li class="toc-h2 nav-item toc-entry"><a class="reference internal nav-link" href="#real2sim-evaluation-environments">Real2Sim Evaluation Environments</a></li>
<li class="toc-h2 nav-item toc-entry"><a class="reference internal nav-link" href="#teleoperation">Teleoperation</a></li>
</ul>
  </nav></div>
          </div>
          <footer class="bd-footer-content">
            
          </footer>
        
      </main>
    </div>
  </div>
  
  <!-- Scripts loaded after <body> so the DOM is not blocked -->
  <script defer src="./_static/scripts/bootstrap.js?digest=8878045cc6db502f8baf"></script>
<script defer src="./_static/scripts/pydata-sphinx-theme.js?digest=8878045cc6db502f8baf"></script>
  </body>
</html>