Official Code Repository for
Zhenyu Wei1,2*, Zhixuan Xu1*, Jingxiang Guo1, Yiwen Hou1, Chongkai Gao1, Zhehao Cai1, Jiayu Luo1, Lin Shao1
1National University of Singapore, 2Shanghai Jiao Tong University
* denotes equal contribution
In this paper, we present
- Python 3.8
- PyTorch >= 2.3.0
conda create -n dro python==3.8
conda activate dro
You don't need to install Isaac Gym for training and pretraining. If evaluating grasps in Isaac Gym isn't required, you can skip this step.
Download Isaac Gym from the official website, then:
tar -xvf IsaacGym_Preview_4_Package.tar.gz
cd isaacgym/python
pip install -e .
Change the project directory, then run:
pip install -r requirements.txt
This project use Weights & Biases to monitor loss curves. If you're not familiar with it, refer to the W&B Tutorials if you haven't used before. Alternatively, you can disable the related sections in train.py
and pretrain.py
.
Download our checkpoint models and unzip the contents into the ckpt/
folder, or simply execute:
bash scripts/download_ckpt.sh
To verify that the Isaac Gym environment is correctly installed and to evaluate the performance of our model, run python scripts/example_isaac.py
. You can also run python scripts/example_pretrain.py
to obtain the matching order of our pretrained model, which is a good indicator of its effectiveness. You can visualize the correspondence matching results by running python visualizatino/vis_pretrain.py
.
You need to modify the configuration file based on your requirements. Below are the key parameters commonly adjusted in the config/
folder:
pretrain.yaml
name
: Specify the pretraining model name.gpu
: Set the GPU ID based on the available GPU device(s).training/max_epochs
: Define the number of pretraining epochs.
dataset/pretrain_dataset.yaml
robot_names
: Provide the list of robot names to be used for pretraining.
After updating the config file, simply run:
python pretrain.py
To assess the performance of the pretrained model, which is best indicated by lower matching order values, you can run the following command:
python scripts/pretrain_order.py \
--pretrain_ckpt pretrain_3robots \ # specify your model name
--data_num 200 \ # number of grasps for one robot
--epoch_list 10,20,30,40,50 \ # epochs of the pretrained model you want to test
--robot_names barrett,allegro,shadowhand # list of robots
You need to modify the configuration file based on your requirements. Below are the key parameters commonly adjusted in the config/
folder:
train.yaml
name
: Specify the training model name.gpu
: Set the GPU ID based on the available GPU device(s).training/max_epochs
: Define the number of training epochs.
model.yaml
pretrain
: Specify the name of the pretrained model, which should be placed in theckpt/
folder.
dataset/cmap_dataset.yaml
robot_names
: Provide the list of robot names to be used for pretraining.batch_size
: Set the dataloader batch size as large as possible. Note that a batch size of 1 will roughly consume 4 GB of GPU memory, and it cannot be set to 1 during training due to batch normalization requirements.object_pc_type
: Userandom
for major experiments andpartial
for partial object point cloud input. This parameter should remain the same during training and validation.
After updating the config file, simply run:
python train.py
You need to modify the configuration file based on your requirements. Below are the key parameters commonly adjusted in the config/
folder:
validate.yaml
name
: Specify the model name you want to validate.gpu
: Set the GPU ID based on the available GPU device(s).split_batch_size
: Set the number of grasps to run in parallel in Isaac Gym, constrained by GPU memory. Maximize this value to speed up the validation process.validate_epochs
: Specify the list of epochs of the trained model to validate.dataset/batch_size
: The total number of grasps for each(robot, object)
combination to validate.
dataset/cmap_dataset.yaml
robot_names
: Provide the list of robot names to be used for validation.batch_size
: Overwritten byvalidate.yaml
, ignored.object_pc_type
: Keep this the same as during training.
After updating the config file, simply run:
python validate.py
You can download our filtered dataset, URDF files and point clouds here and unzip the contents into the data/
folder, or simply execute:
bash scripts/download_data.sh
The original MultiDex
and CMapDataset
are also included for pretraining purposes. For more details on these datasets, refer to GenDexGrasp.
DRO-Grasp
├── ckpt # Checkpoint models stored here
├── configs # Configuration files
├── data # Datasets downloaded and stored here
├── data_utils # Dataset classes and related scripts
├── model # Network architecture code
├── output # Saved model checkpoints and log files
├── tmp # Temporary files generated during subprocess execution
├── scripts
│ ├── download_ckpt.sh # Download checkpoint models
│ ├── download_data.sh # Download data
│ ├── example_isaac.py # Test Isaac Gym environment and evaluate our model's performance
│ ├── example_pretrain.py # Evaluate our pretrained model's performance
│ └── pretrain_order.py # Evaluate performance of pretrained model
├── utils # Various utility scripts
├── validate # Scripts for validating in Isaac Gym
├── validate_output # Validation results saved here
├── vis_info # Visualization information saved during validation
└── visualization
│ ├── vis_controller.py # Visualize the effect of the grasp controller
│ ├── vis_dataset.py # Visualize grasps from the dataset
│ ├── vis_hand_joint.py # Visualize hand joint movements
│ ├── vis_hand_link.py # Visualize hand links
│ ├── vis_pretrain.py # Visualize pretrain matching results
│ └── vis_validation.py # Visualize validation results
├── pretrain.py # Main scripts for pretraining
├── train.py # Main scripts for training
└── validate.py # Main scripts for validation
- Modify your hand's URDF. You can refer to an existing URDF file for guidance on making modifications.
- Add virtual joints between the world and the robot to represent the base link transform. Ensure these joint names start with
virtual
so the controller can ignore them. - Use
visualization/vis_optimization.py
to view the optimization result. If no fixed joint exists at the tip links, the optimized point cloud may not align with the target point cloud at those links. In this case, add extra links beyond each tip link and ensure their names begin withextra
so their transforms are processed before optimization.
- Add virtual joints between the world and the robot to represent the base link transform. Ensure these joint names start with
- Add the hand's URDF and mesh paths to
data/data_urdf/robot/urdf_assets_meta.json
- Specify redundant link names in
data_utils/remove_links.json
. You can visualize the links usingvisualization/vis_hand_link.py
to identify which links are irrelevant for contact. - Use
data_utils/generate_pc.py
to sample point clouds for each robot link and save them. - Annotate the
link_dir
for all links in theget_link_dir()
function ofutils/controller.py
. You can adjust the direction of each link usingvis_hand_direction()
invisualization/vis_controller.py
, ensuring that the arrow points in the correct direction of motion when the joint value increases. - Pretrain and train the model using your own grasp dataset.
If you find our codes or models useful in your work, please cite our paper:
@article{wei2024dro,
title={D(R,O) Grasp: A Unified Representation of Robot and Object Interaction for Cross-Embodiment Dexterous Grasping},
author={Wei, Zhenyu and Xu, Zhixuan and Guo, Jingxiang and Hou, Yiwen and Gao, Chongkai and Cai, Zhehao and Luo, Jiayu and Shao, Lin},
journal={arXiv preprint arXiv:2410.01702},
year={2024}
}
If you have any questions, feel free to contact me through email ([email protected])!