Code for the paper "Learning Language-Conditioned Robot Behavior from Offline Data and Crowd-Sourced Annotation"
This is code for the paper "Learning Language-Conditioned Robot Behavior from Offline Data and Crowd-Sourced Annotation" Suraj Nair, Eric Mitchell, Kevin Chen, Brian Ichter, Silvio Savarese, Chelsea Finn. CoRL 2021.
The code contains the Mujoco simulation environments used for training the agent, as well as the data collection script used to collect data and annotations from the simulator. It also contains the training script to train the LOReL language-conditioned reward function from either the simulated data (or pre-collected real robot data). It also contains code to load a pre-trained visual dynamics model, and use the dynamics model with the LOReL reward for executing language-conditioned tasks in simulation.
For installation please set up a virtual environment with conda/venv with python 3.6 and install requirements in requirements.txt
.
For using the simulation environment, the key packages needed are mujoco-py
and metaworld
. For mujoco-py, be sure to have GPU rendering activated to make data collection and environment execution more efficient. For metaworld
you may need an older version of the codebase.
The environment is located under the env
folder and can be installed by calling pip install -e .
from
To run the data collection script run
python collect_data.py --savepath="data/<YOURPATH>/" --num_episodes=<NUM EPISODES>
This should output an HDF5 file with the episodes and a CSV with the language labels to the save directory.
Given the collected simulation data you can train the LOReL reward with the following command. If you'd rather use the pre-collected dataset from the paper it can be found here.
python train_lorel.py --batchsize=32 --datapath=<PATH TO DATA FOLDER> --savedir=logs/ --expname=<EXPERIMENT NAME> --num_labeled=<HOW MANY EPISODES TO USE> --aug=1 --hidden_size=128 --trainsteps=400000 --fn=1 --robot=0 --langaug=1 --alpha=0
You can also train the LOReL reward on the pre-collected real robot dataset, consisting of a Franka Emika Panda operating over a desk, and crowdsourced language annotations of the episodes. This dataset can be found here. If you do train the model on this data, you should simply change the command to:
python train_lorel.py --batchsize=32 --datapath=<PATH TO ROBOT DATA FOLDER> --savedir=logs/ --expname=<EXPERIMENT NAME> --num_labeled=<HOW MANY EPISODES TO USE> --aug=1 --hidden_size=128 --trainsteps=400000 --fn=1 --robot=1 --langaug=1 --alpha=0.25
If you do use the real robot data, please cite the project from which the data was collected.
@inproceedings{
wu2021exampledriven,
title={Example-Driven Model-Based Reinforcement Learning for Solving Long-Horizon Visuomotor Tasks},
author={Bohan Wu and Suraj Nair and Fei-Fei Li and Chelsea Finn},
booktitle={5th Annual Conference on Robot Learning },
year={2021},
url={https://openreview.net/forum?id=_daq0uh6yXr}
}
If you want to use the same visual planning pipeline as the paper, you will need to use the SV2P video prediction model [Babaeizadeh et al]. The code for this model is part of the tensor2tensor
package, and you'll want to clone and install this custom version of tensor2tensor. This installation is tricky - it will automatically upgrade the tensorflow version, however SV2P still requires and old version. You will need to downgrade tensorflow-gpu
and associated tensorflow packages tensorflow-probability
, etc. to the ones listed in the requirements.txt
. You'll also need to manually install gast=0.2.2
.
If the above is done correctly, you should be able to directly load the pre-trained SV2P data and SV2P model here. You can also re-train the SV2P dynamics model if desired using the tensor2tensor
repo.
Finally, given the trained SV2P model and trained LOReL reward, you can run CEM planning to complete language-conditioned tasks with the following command:
python run_planning.py --batchsize=<NUMBER OF TRIALS> --savedir=logs/ --expname=<EXPERIMENT NAME> --reward_path=<PATH TO LOReL REWARD CHECKPOINT> --cost="lorel" --instruction="turn faucet right" --verbose=0 --hidden_size=128 --cem_iters=3 --samples=200 --model_path=<PATH TO SV2P DIRECTORY>
The LCBC baseline trains vanilla behavior cloning conditioned on the language instruction:
python train_baselines.py --batchsize=32 --datapath=<PATH TO DATA FOLDER> --savedir=logs/ --expname=<EXPERIMENT NAME> --num_labeled=<HOW MANY EPISODES TO USE> --aug=1 --hidden_size=128 --trainsteps=400000 --alpha=0 --rl=0
The LCRL baseline trains a Q function conditioned on the initial state and language, where terminal transitions have reward 1 and all other states have reward 0:
python train_baselines.py --batchsize=32 --datapath=<PATH TO DATA FOLDER> --savedir=logs/ --expname=<EXPERIMENT NAME> --num_labeled=<HOW MANY EPISODES TO USE> --aug=1 --hidden_size=128 --trainsteps=400000 --alpha=0 --rl=1
To evaluate one of the trained baseline models simply run the run_planning.py
file
python run_planning.py --batchsize=<NUMBER OF TRIALS> --savedir=logs/ --expname=<EXPERIMENT NAME> --reward_path=<PATH TO Q FUNC/POLICY CHECKPOINT> --cost="q/bc" --instruction="turn faucet right" --verbose=0 --hidden_size=128 --cem_iters=3 --samples=200