IEEE ICRA 2023 - 3DSGrasp: 3D Shape-Completion for Robotic Grasp [ Youtube Video ]
We present a grasping strategy, named 3DSGrasp, that predicts the missing geometry from the partial Point-Cloud data (PCD) to produce reliable grasp poses. Our proposed PCD completion network is a Transformer-based encoder-decoder network with an Offset-Attention layer. Our network is inherently invariant to the object pose and point's permutation, which generates PCDs that are geometrically consistent and completed properly. Experiments on a wide range of partial PCD show that 3DSGrasp outperforms the best state-of-the-art method on PCD completion tasks and largely improves the grasping success rate in real-world scenarios.
- run the full pipeline (from camera depth input to kinova grasping the object) ➡️ Full Pipeline
- run only the completion network to generate shape completion on a partial.pcd ➡️ Completion Network
- run only GPD to generate grasps for PCD of either partial.pcd or complete.pcd ➡️ Test GPD
- 🚋 use our model? ➡️ Completion Network
- 🚦 use the same train-test split of the YCB dataset? ➡️ Completion Network
To begin, clone this repository locally
git clone [email protected]:NunoDuarte/3DSGrasp.git
$ export 3DSG_ROOT=$(pwd)/3DSGrasp
This repo was tested on Ubuntu 20.04 and with ROS Noetic
$ cd $3DSG_ROOT
$ conda create -n 3dsg_venv python=3.8 # or use virtualenv
$ conda activate 3dsg_venv
$ sh install.sh
- install ROS, moveit, ros_kortex, and ros_kortex_vision
- Check oficial documentation for ROS
- Check oficial documentation for Moveit or just do this
- Check oficial documentation for ROS_kortex and ROS_kortex_vision
- install gpd
- Check oficial documentation for GPD (:warning: gpd repo was tested on Ubuntu 16.04; if you have trouble installing on Ubuntu 20.04 send an issue to us and we'll help)
- replace files
src/gpd/grasp_detector.cpp
src/gpd/util/plot.cpp
include/util/plot.h
with the ones provides in folder GPD on this repo - add the correct path of your pipeline
ofstream fw("'PATH_TO_THE_DIR/gpd_grasp_scores.txt", std::ofstream::out);
- compile GPD again
- Check oficial documentation for GPD (:warning: gpd repo was tested on Ubuntu 16.04; if you have trouble installing on Ubuntu 20.04 send an issue to us and we'll help)
Open terminals:
- ROS KINOVA
source catkin/devel/setup.bash
roslaunch kortex_driver kortex_driver.launch
(optional) import rviz environment and/or table for collision detection
open config file 3DSG_ROOT/ROS/rviz/grasp_kinova.rviz
go to scene objects -> import -> 3DSG_ROOT/ROS/rviz/my_table -> Publish
- ROS KINOVA VISION
source catkin/devel/setup.bash
roslaunch kinova_vision kinova_vision_rgbd.launch device:=$IP_KINOVA
- Configure kinova and gpd files set an initial pose for kinova manually or (optional) set it as a .npy file and load it in reach_approach_grasp_pose.py
cd 3DSG_ROOT/ROS/src/
(optional) open reach_approach_grasp_pose.py and set location of initial_state.npy of kinova
# Load initial state of robot (joint angles)
initial_state = np.load('location_of_initial_state.npy')
set location of final_pose.npy and final_approach.npy (These are the best grasp and approach from GPD)
print('Load grasp pose')
final_pose = np.load('location_of_final_pose.npy')
final_approach = np.load('location_of_final_approach.npy')
- RUN PIPELINE
source catkin_ws/devel/setup.bash
cd 3DSG_ROOT/
python main_gpd.py
if segmentation fails (partial point cloud includes artifacts then "quit every plot; imediately ctrl c (multiple times), wait to close, run again"
- RUN ON KINOVA
source catkin/devel/setup.bash
roslaunch kortex_examples reach_approach_grasp_pose.launch
- When grasping the closure of the gripper is predefine, if you want to change open
reach_approach_grasp_pose.py
and change variable
approach.example_send_gripper_command(0.3)
- For acquiring the point cloud and segmenting it run:
python main_agile.py
it saves the acquired_point cloud as original_pc and the segmented as partial_pc in tmp_data
To run GPD on .pcd file
cd $GPD_ROOT/build
./detect_grasps ../cfg/eigen_params.cfg $LOCATION_OF_FILE.PCD
🎉 The pre-trained model is here (around 500 MB)!!!
To train point cloud completion model
cd Completion
python3 main.py --config ./cfgs/YCB_models/SGrasp.yaml
To test point cloud completion model
python3 main.py --test --ckpts /PATH_TO_pre_trained_MODEL/MODEL.pth --config ./cfgs/YCB_models/SGrasp.yaml
Note that the input of the network for the real-world grasping experiment should be a single sample
If you find this code useful in your research, please consider citing our paper. Available on IEEE Xplore and ArXiv:
@INPROCEEDINGS{10160350,
author={Mohammadi, Seyed S. and Duarte, Nuno F. and Dimou, Dimitrios and Wang, Yiming and Taiana, Matteo and Morerio, Pietro and Dehban, Atabak and Moreno, Plinio and Bernardino, Alexandre and Del Bue, Alessio and Santos-Victor, José},
booktitle={2023 IEEE International Conference on Robotics and Automation (ICRA)},
title={3DSGrasp: 3D Shape-Completion for Robotic Grasp},
year={2023},
volume={},
number={},
pages={3815-3822},
doi={10.1109/ICRA48891.2023.10160350}
}