This repository contains code for training and evaluating policies on the DROID dataset. DROID is a large-scale, in-the-wild robot manipulation dataset. This codebase is built as a fork of robomimic
, a popular repository for imitation learning algorithm development. For more information about DROID, please see the following links:
[Homepage] [Documentation] [Paper] [Dataset Visualizer].
- [12/21/24]: We provide an updated set of DROID language annotations on HuggingFace -- 3 natural language annotations for 95% of all successful DROID episodes (75k episodes)
Create a python3 conda environment (tested with Python 3.10) and run the following:
- Create python 3.10 conda environment:
conda create --name droid_policy_learning_env python=3.10
- Activate the conda environment:
conda activate droid_policy_learning_env
- Install octo, pinned at commit
85b83fc19657ab407a7f56558a5384ae56fe453b
(used for data loading) - Run
pip install -e .
indroid_policy_learning
.
With this you are all set up for training policies on DROID. If you want to evaluate your policies on a real robot DROID setup, please install the DROID robot controller in the same conda environment (follow the instructions here).
We provide all DROID datasets in RLDS format, which makes it easy to co-train with various other robot-learning datasets (such as those in the Open X-Embodiment).
To download the DROID dataset from the Google cloud bucket, install the gsutil package and run the following command (Note: the full dataset is 1.7TB in size):
gsutil -m cp -r gs://gresearch/robotics/droid <path_to_your_target_dir>
We also provide a small (2GB) example dataset with 100 DROID trajectories that uses the same format as the full RLDS dataset and can be used for code prototyping and debugging:
gsutil -m cp -r gs://gresearch/robotics/droid_100 <path_to_your_target_dir>
For good performance of DROID policies in your target setting, it is helpful to include a small number of demonstrations in your target domain into the training mix ("co-training").
Please follow the instructions here for collecting a small teleoperated dataset in your target domain and instructions here converting it to the RLDS training format.
Make sure that all datasets you want to train on are under the same root directory DATA_PATH
.
Note: We also provide the raw DROID dataset at stereo, full HD resolution. If your training pipeline requires this information, you can download the dataset from gs://gresearch/robotics/droid_raw
. For a detailed description of the raw data format, please see our developer documentation.
To train policies, update DATA_PATH
, EXP_LOG_PATH
, and EXP_NAMES
in robomimic/scripts/config_gen/droid_runs_language_conditioned_rlds.py
and then run:
python robomimic/scripts/config_gen/droid_runs_language_conditioned_rlds.py --wandb_proj_name <WANDB_PROJ_NAME>
This will generate a python command that can be run to launch training. You can also update other training parameters within robomimic/scripts/config_gen/droid_runs_language_conditioned_rlds.py
. Please see the robomimic
documentation for more information on how robomimic
configs are defined. The three
most important parameters in this file are:
DATA_PATH
: This is the directory in which all RLDS datasets were prepared.EXP_LOG_PATH
: This is the path at which experimental data (eg. policy checkpoints) will be stored.EXP_NAMES
: This defines the name of each experiment (as will be logged inwandb
), the RLDS datasets corresponding to that experiment, and the desired sample weights between those datasets. Seerobomimic/scripts/config_gen/droid_runs_language_conditioned_rlds.py
for a template on how this should be formatted.
During training, we use a shuffle buffer to ensure that training samples are properly randomized. It is important to use a large enough shuffle buffer size.
The default shuffle_buffer_size
is set to 500000
, but you may need to reduce this based on your RAM availability. For best results, we recommend using shuffle_buffer_size >= 100000
if possible. All polices were trained on a single NVIDIA A100 GPU.
To specify your information for Weights and Biases logging, make sure to update the WANDB_ENTITY
and WANDB_API_KEY
values in robomimic/macros.py
.
We also provide a stand-alone example to load data from DROID here.
File | Description | |
---|---|---|
Hyperparameters | droid_runs_language_conditioned_rlds.py | Generates a config based on defined hyperparameters |
Training Loop | train.py | Main training script. |
Datasets | dataset.py | Functions for creating datasets and computing dataset statistics, |
RLDS Data Processing | rlds_utils.py | Processing to convert RLDS dataset into dataset compatible for DROID training |
General Algorithm Class | algo.py | Defines a high level template for all algorithms (eg. diffusion policy) to extend |
Diffusion Policy | diffusion_policy.py | Implementation of diffusion policy |
Observation Processing | obs_nets.py | General observation pre-processing/encoding |
Visualization | vis_utils.py | Utilities for generating trajectory visualizations |
To evaluate policies, make sure that you additionally install DROID in your conda environment and then run:
python scripts/evaluation/evaluate_policy.py
from the DROID root directory. Make sure to use the appropriate command line arguments for the model checkpoint path and whether to do goal or language conditioning, and then follow all resulting prompts in the terminal. To replicate experiments from the paper, use the language conditioning mode.
Natively, robomimic uses HDF5 files to store and load data. While we mainly support RLDS as the data format for training with DROID, here are instructions for how to run training with the HDF5 data format.
@misc{droid_2024,
title={DROID: A Large-Scale In-The-Wild Robot Manipulation Dataset},
author = {Alexander Khazatsky and Karl Pertsch and Suraj Nair and Ashwin Balakrishna and Sudeep Dasari and Siddharth Karamcheti and Soroush Nasiriany and Mohan Kumar Srirama and Lawrence Yunliang Chen and Kirsty Ellis and Peter David Fagan and Joey Hejna and Masha Itkina and Marion Lepert and Yecheng Jason Ma and Patrick Tree Miller and Jimmy Wu and Suneel Belkhale and Shivin Dass and Huy Ha and Arhan Jain and Abraham Lee and Youngwoon Lee and Marius Memmel and Sungjae Park and Ilija Radosavovic and Kaiyuan Wang and Albert Zhan and Kevin Black and Cheng Chi and Kyle Beltran Hatch and Shan Lin and Jingpei Lu and Jean Mercat and Abdul Rehman and Pannag R Sanketi and Archit Sharma and Cody Simpson and Quan Vuong and Homer Rich Walke and Blake Wulfe and Ted Xiao and Jonathan Heewon Yang and Arefeh Yavary and Tony Z. Zhao and Christopher Agia and Rohan Baijal and Mateo Guaman Castro and Daphne Chen and Qiuyu Chen and Trinity Chung and Jaimyn Drake and Ethan Paul Foster and Jensen Gao and David Antonio Herrera and Minho Heo and Kyle Hsu and Jiaheng Hu and Donovon Jackson and Charlotte Le and Yunshuang Li and Kevin Lin and Roy Lin and Zehan Ma and Abhiram Maddukuri and Suvir Mirchandani and Daniel Morton and Tony Nguyen and Abigail O'Neill and Rosario Scalise and Derick Seale and Victor Son and Stephen Tian and Emi Tran and Andrew E. Wang and Yilin Wu and Annie Xie and Jingyun Yang and Patrick Yin and Yunchu Zhang and Osbert Bastani and Glen Berseth and Jeannette Bohg and Ken Goldberg and Abhinav Gupta and Abhishek Gupta and Dinesh Jayaraman and Joseph J Lim and Jitendra Malik and Roberto Martín-Martín and Subramanian Ramamoorthy and Dorsa Sadigh and Shuran Song and Jiajun Wu and Michael C. Yip and Yuke Zhu and Thomas Kollar and Sergey Levine and Chelsea Finn},
year = {2024},
}