This work aims to achieve the robotic ultrasound while compensating expected and unexpected movements of the object without using any markers. This way, the 3D compounding of the artery of interest will be generated and later can be used to diagnose peripheral vascular disease. The project has two main parts; first, the preoperative CT data and the point cloud captured by the depth sensor will be registered. Then using a segmentation network binary mask of the limb will be generated in real-time; later on, these masks will be compared between each frame using the dice score, and if the dice score drops below the preset threshold, then it is considered that the motion occurred. A signal will be sent to the robot to stop the scan, and later using the ICP algorithm, and the scan trajectory will be updated.
- a redundant robotic arm (LBR iiwa 14 R820, KUKA GmbH, Germany)
- a US machine (Cephasonics, USA)
- an RGB-D camera (AzureKinect, Microsoft Corporation, USA).
PC setup
- Ubuntu 18.04
- ROS Melodic
- CMake version 3.10.2
- If you do not have ROS installed in your system, follow this. In this project ROS1, Melodic distribution is used.
- Once you are done, create a catkin workspace, for that you can follow the tutorial from the official ROS website.
- Since Azure Kinect is used in this project, you need to also get the Azure Kinect ROS driver; this is the official github page. Please select the branch according to your ROS distribution. Follow the instructions. In case you face with some issues, I suggest you to follow these notes, they were helpful to me.
- Add the shape_registration and directory from this project into the src of your catkin workspace.
- Run
$catkin_make
in the root of your catkin_workspace. You will probably have an issue with PCL. I have used PCL 1.11.1, I have provided a fix for one issue in this version, since I still haven't fix the clang tidy, it is not in master, for now you can pull from this Also in case you need help, you can follow my blog post - You will also need Yaml-cpp.
- If you see any more packages, that is required for the build and you don't have it, please keep installing those, otherwise let's go to the next step.
- So now, add the ROS_Vision_Controller directory from this project into the src of your catkin workspace.
- Other packages required to be in the src of your catkin workspace; iiwa_stack, easy_handeye, easy_aruco well easy aruco, there is yet another pull request of mine, which I didn't get to chance to finish but pull from my branch, so that you can visualize the pose, position and the marker on the image.
- After this do
$catkin_make
in your catkin workspace root, and if there are no issues continue. - You will need to environments to run python codes, well since when I started this project, I started with Melodic, and I was not able to use Python3, I used pyro5 to connect my Python2 ROS workspace with the python3 environment that I used for training. Due to this you will need two python environments.
For the python2 environment in your ROS workspace:
$conda create --name ros_pyro_env python=3.8
$conda activate ros_pyro_env
$pip install -r src/shape_registration/src/ros_python_requirements.txt
For the python 3 environment:
$conda env create -f environment.yaml
$conda activate arm_tracking_env
$pip install -r tracking_arm/requirements.txt
- [Optional] After you created the environments, you can create aliases. Add below lines into your bashrc:
alias ros_pyro_env="source activate ros_pyro_env"
alias arm_tracking="source activate arm_tracking_env"
- Good luck :)
Commands | Description |
---|---|
$roslaunch shape_registration registration.launch |
To run the surface registration, please change the registration.launch file according to the path or your CT and artery data |
$roslaunch shape_registration trajectory_extraction.launch |
To create scan trajectory |
First let's start the segmentation network, go to terminal and run the following:$conda activate arm_tracking_env start the pyro server: $pyro5-ns $python tracking_arm/subscriber_pyro.py Now start the ROS part: $roslaunch shape_registration movement_monitoring_and_tracking.launch Then start the pyro server in the ros side $conda activate ros_pyro_env $rosrun shape_registration publisher_pyro.py |
Movement monitoring section is a bit tricky, follow the commands! |
$roslaunch shape_registration image_saving_for_training.launch |
To capture RGB images using the azure kinect, in case you want to create a data set. |