Skip to content

Latest commit

 

History

History
107 lines (89 loc) · 5.95 KB

README.md

File metadata and controls

107 lines (89 loc) · 5.95 KB

VLABench: A Large-Scale Benchmark for Language-Conditioned Robotics Manipulation with Long-Horizon Reasoning Tasks (Early Preview-Version!)

🚨 NOTICE: 🎁 The early preview version is released on my birthday (12.25) as a gift for myself🎄! Most codes are still under management or even reconstruction for a more robust and user-friendly version.(Sorry, I’ve been so busy these days). The Complete Version will be open-sourced around the Chinese Lunar New Year🧧!
I don’t like the phrase "code coming soon"; it often feels like I’ll never actually see the code on GitHub, which can be quite frustrating. So this early version is my promise.

🎓 Paper | 🌐 Project Website | 🤗 Hugging Face

News

  • 2024/12/25 The preview verison of VLABench has been released! This version is a gift for my birthday, happy birthday to myself and merry chrismas to u!🎁🎉 The preview version showcases most of the designed tasks and structure, but the functionalities are still being managed and tested. I aim to provide you with a highly user-friendly and efficient evaluation tool, so I kindly ask for your patience during this process. Thank you for your understanding, and I look forward to delivering a polished and seamless experience soon!

Installation

Install VLABench

  1. Prepare conda environment
conda create -n vlabench python=3.10
conda activate vlabench

git clone https://github.com/OpenMOSS/VLABench.git
cd VLABench
pip install -r requirements.txt
pip install -e .
  1. Download the assets
python script/download_assetes.py

The script will automatically download the necessary assets and unzip them into the correct directory.

Issues with octo

Some experiences to create octo evaluation env:

    conda env remove -n octo
    conda create -n octo python=3.10
    conda activate octo
    pip install -e .
    pip install "jax[cuda12_pip]==0.4.20" -f https://storage.googleapis.com/jax-releases/jax_cuda_releases.html flax==0.7.5 
    pip install tensorflow==2.15.0 pip install dlimp@git+https://github.com/kvablack/dlimp@5edaa4691567873d495633f2708982b42edf1972 
    pip install distrax==0.1.5 
    pip install tensorflow_probability==0.23.0 
    pip install scipy==1.12.0 
    pip install einops==0.6.1
    pip install transformers==4.34.1 
    pip install ml_collections==0.1.0 
    pip install wandb==0.12.14 
    pip install matplotlib 
    pip install gym==0.26 
    pip install plotly==5.16.1
    pip install orbax-checkpoint==0.4.0

Note: Line 5 "cuda12_pip" may be replaced by other proper version according to your machine. Refer to jax installation.

Make sure jax version=0.4.20 and flax version=0.7.5

pip show jax flax jaxlib

Run this to verify installation successful

python -c "from octo.model.octo_model import OctoModel; model = OctoModel.load_pretrained('hf://rail-berkeley/octo-base-1.5'); print('Model loaded successfully')"

Recent Work Todo

  • Manage the left few tasks not released in preview version.
  • Test the interface of humanoid and dual-arm manipulation.
  • Organize the functional code sections.
    • Reconstruct the efficient, user-friendly, and comprehensive evaluation framework.
    • Manage the automatic data augmentation workflow for existing tasks, especially the rewriting the DSL of skill libarary.
  • Organize commonly used VLA models to facilitate replication for everyone.
  • Maintain a leaderboard of VLAs and VLMs in the standard evaluation
  • Consider to transfer our work both to Issac and Genesis.

Expandation

VLABench adopts a flexible modular framework for task construction, offering high adaptability. You can follow the process outlined below to customize your own tasks.

Register New Entity

  1. Process the obj file with obj2mjcf(https://github.com/kevinzakka/obj2mjcf). Here is an use demo, obj2mjcf --verbose --obj-dir your_own_obj_dir --compile-model --save-mjcf --decompose
  2. Put the processed xml files/directory to somewhere under VLABench/assets/meshes.
  3. If it's a new class of entity, please register a entity class in VLABench/tasks/components with global register. Then, import the class in the VLABench/tasks/components/__init__.py.
  4. Register it in VLABench/configs/constant.py for global access.

Register New Task

  1. Create new task class file under VLABench/tasks/hierarchical_tasks. And register it with global register in VLABench/utils/register.py. Notice that if the current condition can not met your requirement, you should write a single Condition class in VLABench/tasks/condition.py.
  2. Import the new task class in VLABench/tasks/hierarchical_tasks/__init__.py.

Collect Data

The latest data augmentation process is still under testing. Please wait for the official release!

python scripts/trajectory_generation.py --n-sample 100 --task-name select_poker

Evaluate

I am currently updating the evaluation process, which includes making the tools more user-friendly, speeding up the entire evaluation workflow, and implementing a more comprehensive scoring system.

python scirpts/eval.py --n-sample 20 --model your_model_script

Citation

@misc{zhang2024vlabench,
      title={VLABench: A Large-Scale Benchmark for Language-Conditioned Robotics Manipulation with Long-Horizon Reasoning Tasks}, 
      author={Shiduo Zhang and Zhe Xu and Peiju Liu and Xiaopeng Yu and Yuan Li and Qinghui Gao and Zhaoye Fei and Zhangyue Yin and Zuxuan Wu and Yu-Gang Jiang and Xipeng Qiu},
      year={2024},
      eprint={2412.18194},
      archivePrefix={arXiv},
      primaryClass={cs.RO},
      url={https://arxiv.org/abs/2412.18194}, 
}