Awesome
<div align="center"> <h1 align="center"> Dex Retargeting </h1> <h3 align="center"> Various retargeting optimizers to translate human hand motion to robot hand motion. </h3> </div> <p align="center"> <!-- code check badges --> <a href='https://github.com/dexsuite/dex-retargeting/blob/main/.github/workflows/test.yml'> <img src='https://github.com/dexsuite/dex-retargeting/actions/workflows/test.yml/badge.svg' alt='Test Status' /> </a> <!-- issue badge --> <a href="https://github.com/dexsuite/dex-retargeting/issues"> <img src="https://img.shields.io/github/issues-closed/dexsuite/dex-retargeting.svg" alt="Issues Closed"> </a> <a href="https://github.com/dexsuite/dex-retargeting/issues?q=is%3Aissue+is%3Aclosed"> <img src="https://img.shields.io/github/issues/dexsuite/dex-retargeting.svg" alt="Issues"> </a> <!-- release badge --> <a href="https://github.com/dexsuite/dex-retargeting/tags"> <img src="https://img.shields.io/github/v/release/dexsuite/dex-retargeting.svg?include_prereleases&sort=semver" alt="Releases"> </a> <!-- pypi badge --> <a href="https://github.com/dexsuite/dex-retargeting/tags"> <img src="https://static.pepy.tech/badge/dex_retargeting/month" alt="pypi"> </a> <!-- license badge --> <a href="https://github.com/dexsuite/dex-retargeting/blob/main/LICENSE"> <img alt="License" src="https://img.shields.io/badge/license-MIT-blue"> </a> </p> <div align="center"> <h4>This repo originates from <a href="https://yzqin.github.io/anyteleop/">AnyTeleop Project</a></h4> <img src="example/vector_retargeting/teaser.webp" alt="Retargeting with different hands."> </div>Installation
pip install dex_retargeting
To run the example, you may need additional dependencies for rendering and hand pose detection.
git clone https://github.com/dexsuite/dex-retargeting
cd dex-retargeting
pip install -e ".[example]"
Examples
Retargeting from human hand video
This type of retargeting can be used for applications like teleoperation, e.g. AnyTeleop.
Tutorial on retargeting from human hand video
Retarget from hand object pose dataset
This type of retargeting can be used post-process human data for robot imitation, e.g. DexMV.
Tutorial on retargeting from hand-object pose dataset
FAQ and Troubleshooting
Joint Orders for Retargeting
URDF parsers, such as ROS, physical simulators, real robot driver, and this repository, may parse URDF files with
different joint orders. To use dex-retargeting
results with other libraries, handle joint ordering explicitly using
joint names, which are unique within a URDF file.
Example: Using dex-retargeting
with the SAPIEN simulator
from dex_retargeting.seq_retarget import SeqRetargeting
retargeting: SeqRetargeting
sapien_joint_names = [joint.get_name() for joint in robot.get_active_joints()]
retargeting_joint_names = retargeting.joint_names
retargeting_to_sapien = np.array([retargeting_joint_names.index(name) for name in sapien_joint_names]).astype(int)
# Use the index map to handle joint order differences
sapien_robot.set_qpos(retarget_qpos[retargeting_to_sapien])
This example retrieves joint names from the SAPIEN robot and SeqRetargeting
object, creates a mapping
array (retargeting_to_sapien
) to map joint indices, and sets the SAPIEN robot's joint positions using the retargeted
joint positions.
Citation
This repository is derived from the AnyTeleop Project and is subject to ongoing enhancements. If you utilize this work, please cite it as follows:
@inproceedings{qin2023anyteleop,
title = {AnyTeleop: A General Vision-Based Dexterous Robot Arm-Hand Teleoperation System},
author = {Qin, Yuzhe and Yang, Wei and Huang, Binghao and Van Wyk, Karl and Su, Hao and Wang, Xiaolong and Chao, Yu-Wei and Fox, Dieter},
booktitle = {Robotics: Science and Systems},
year = {2023}
}
Acknowledgments
The robot hand models in this repository are sourced directly from dex-urdf. The robot kinematics in this repo are based on pinocchio. Examples use SAPIEN for rendering and visualization.
The PositionOptimizer
leverages methodologies from our earlier
project, From One Hand to Multiple Hands.
Additionally, the DexPilotOptimizer
is crafted using insights from DexPilot.