[CVPR 2024] Official repository of "TACO: Benchmarking Generalizable Bimanual Tool-ACtion-Object Understanding".
📃Paper | 🏠Project | 🎥Video | 📁Dataset (pre-released version) | 📁Dataset
Yun Liu, Haolin Yang, Xu Si, Ling Liu, Zipeng Li, Yuxiang Zhang, Yebin Liu, Li Yi
The pre-released version contains 244 high-quality motion sequences spanning 137 <tool, action, object> triplets. Please refer to the "Data Visualization" section for data usage.
We back up the data at BaiduNetDisk. Some of the files are split due to file size limitations. To get the original zip files, please use the following commands:
cat Allocentric_RGB_Videos_split.* > Allocentric_RGB_Videos.zip
cat Egocentric_Depth_Videos_split.* > Egocentric_Depth_Videos.zip
Dataset contents:
- 244 high-quality motions sequences spanning 137
<tool, action, object>
triplets - 206 High-resolution object models (10K~100K faces per object mesh)
- Hand-object pose and mesh annotations
- Egocentric RGB-D videos
- 8 allocentric RGB videos
The whole dataset (version 1) contains 2317 motion sequences. Please refer to the "Data Visualization" section for data usage.
This link is a backup of this dataset.
Dataset contents:
- 2317 motions sequences spanning 151
<tool, action, object>
triplets - 206 High-resolution object models (10K~100K faces per object mesh)
- Hand-object pose and mesh annotations
- Egocentric RGB-D videos
- 12 allocentric RGB videos
- Camera parameters
- Automatic Hand-object 2D segmentations
If you have questions about the dataset, please contact [email protected]
.
The files of the dataset are organized as follows:
|-- Allocentric_RGB_Videos
|-- <triplet_1>
|-- <sequence_1>
|-- 22070938.mp4
|-- 22139905.mp4
...
|-- <sequence_2>
...
|-- <triplet_2>
...
|-- Egocentric_Depth_Videos
|-- <triplet_1>
|-- <sequence_1>
egocentric_depth.avi
|-- <sequence_2>
...
|-- <triplet_2>
...
|-- Egocentric_RGB_Videos
|-- <triplet_1>
|-- <sequence_1>
color.mp4
|-- <sequence_2>
...
|-- <triplet_2>
...
|-- Hand_Poses
|-- <triplet_1>
|-- <sequence_1>
left_hand_shape.pkl
left_hand.pkl
right_hand_shape.pkl
right_hand.pkl
|-- <sequence_2>
...
|-- <triplet_2>
...
|-- Object_Poses
|-- <triplet_1>
|-- <sequence_1>
target_<target_name>.npy
tool_<tool_name>.npy
|-- <sequence_2>
...
|-- <triplet_2>
...
|-- Object_Models
|-- 001_cm.obj
...
|-- 218_cm.obj
[1] Environment Setup:
Our code is tested on Ubuntu 20.04 with NVIDIA GeForce RTX 3090. The driver version is 535.146.02. The CUDA version is 12.2.
Please install the environment using the following commands:
conda create -n taco python=3.9
conda activate taco
<install PyTorch >= 1.7.1, we use PyTorch 1.11.0>
<install PyTorch3D >= 0.6.1, we use PyTorch3D 0.7.2>
pip install -r requirements.txt
[2] Download MANO models, and put MANO_LEFT.pkl
and MANO_RIGHT.pkl
in the folder dataset_utils/manopth/mano/models
.
[3] Visualize Hand-Object Poses in a Fixed View:
cd dataset_utils
python visualization.py --dataset_root <dataset root directory> --object_model_root <object model root directory> --triplet <triplet name> --sequence_name <sequence name> --save_path <path to save the visualization result> --device <device for the rendering process>
For example, if you select the following data sequence:
python visualization.py --dataset_root <dataset root directory> --object_model_root <object model root directory> --triplet "(stir, spoon, bowl)" --sequence_name "20231105_019" --save_path "./example.gif" --device "cuda:0"
You can obtain the following visualization result:
To visualize hand-object poses in dataset's third-person views, please change the constants IMAGE_SIZE
, INTRINSIC
, and CAMERA_TO_WORLD
to the values from the data folder Allocentric_Camera_Parameters
.
[4] Visualize Hand-Object Poses in Egocentric Frames:
cd dataset_utils
python project_pose_to_egocentric_view.py --dataset_root <dataset root directory> --object_model_root <object model root directory> --triplet <triplet name> --sequence_name <sequence name> --save_path <path to save the visualization result> --device <device for the rendering process>
For example, if you select the following data sequence:
python project_pose_to_egocentric_view.py --dataset_root <dataset root directory> --object_model_root <object model root directory> --triplet "(brush, brush, box)" --sequence_name "20231006_163" --save_path "./egocentric_example.gif" --device "cuda:0"
You can obtain the following visualization result:
[5] Parse Egocentric Depth Videos:
Please use the following command for each video:
ffmpeg -i <egocentric depth video path> -f image2 -start_number 0 -vf fps=fps=30 -qscale:v 2 <egocentric depth image save path>
For example:
mkdir ./decode
ffmpeg -i ./egocentric_depth.avi -f image2 -start_number 0 -vf fps=fps=30 -qscale:v 2 ./decode/%05d.png
Each depth image is a 1920x1080 uint16 array. The depth scale is 1000 (i.e. depth values are stored in millimeters).
We provide three data lists in the folder data_lists
:
data_lists/v1_overall_data_sequences.txt
(2317 sequences) is the overall data list of the whole dataset (Version 1) with available data modalities except egocentric color and depth videos.data_lists/v1_egocentric_data_available_sequences.txt
(2212 sequences) is the data sequences of the whole dataset (Version 1) where all data modalities are available.v1_overall_data_train_test_split.txt
(2317 sequences) is the train-test split of the whole dataset (Version 1):- "train" is the training set
- "test_1" is the test set S1 (no generalization)
- "test_2" is the test set S2 (geometry-level generalization)
- "test_3" is the test set S3 (interaction-level generalization)
- "test_4" is the test set S4 (compound generalization)
If you find our work useful in your research, please consider citing:
@inproceedings{liu2024taco,
title={Taco: Benchmarking generalizable bimanual tool-action-object understanding},
author={Liu, Yun and Yang, Haolin and Si, Xu and Liu, Ling and Li, Zipeng and Zhang, Yuxiang and Liu, Yebin and Yi, Li},
booktitle={Proceedings of the IEEE/CVF Conference on Computer Vision and Pattern Recognition},
pages={21740--21751},
year={2024}
}
This work is licensed under a CC BY 4.0 license.
If you have any questions, please contact [email protected]
.