-
Notifications
You must be signed in to change notification settings - Fork 68
CatkinBuild
- Introduction
- catkin build and rosinstall
- catkin build and git submodules
- cmake; make and git submodules
We suggest 3 different ways to retrieve all the dVRK required source repositories and compile them. The first two methods are for Linux/ROS users only and rely on the catkin build tools. Pleas note that we do not support catkin_make
.
The rosinstall
configuration file is provided in dVRK 2.x and higher but can also be used with older versions (see https://github.com/jhu-dvrk/dvrk-ros). The rosinstall
file defines all the github repositories that need to be cloned in your workspace as well as which branches.
This section assumes you already have ROS installed (see https://www.ros.org). You will need to install a few more packages for the dVRK software. This has to be done once per computer.
-
Ubuntu 16.04 with ROS Kinetic (not supported for release 2.2 and up):
sudo apt-get install libxml2-dev libraw1394-dev libncurses5-dev qtcreator swig flite sox espeak cmake-curses-gui cmake-qt-gui libopencv-dev git subversion gfortran libcppunit-dev qt5-default python-vcstool python-catkin-tools
-
Ubuntu 18.04 with ROS Melodic:
sudo apt install libxml2-dev libraw1394-dev libncurses5-dev qtcreator swig sox espeak cmake-curses-gui cmake-qt-gui git subversion gfortran libcppunit-dev libqt5xmlpatterns5-dev libbluetooth-dev libhidapi-dev python-vcstool python-catkin-tools
-
Ubuntu 20.04 with ROS Noetic:
sudo apt install libxml2-dev libraw1394-dev libncurses5-dev qtcreator swig sox espeak cmake-curses-gui cmake-qt-gui git subversion gfortran libcppunit-dev libqt5xmlpatterns5-dev libbluetooth-dev libhidapi-dev python3-pyudev python3-vcstool python3-catkin-tools python3-osrf-pycommon python-is-python3
- Ubuntu 16.04 support has been dropped
- Ubuntu 18.04 support requires clang instead of gcc. You will need to install clang with
sudo apt install clang
and configure your workspace using:catkin config --cmake-args -DCMAKE_C_COMPILER=clang -DCMAKE_CXX_COMPILER=clang++ -DCMAKE_BUILD_TYPE=Release
which python
should return /usr/bin/python
). You should also make sure your ROS environment variables match the workspace and ROS version you're using (check with env | grep -i ros
).
If you're using ROS Noetic and the master branch, you can just copy/paste the following block of commands in a terminal. For other configurations, make sure your replace noetic
by melodic
or whatever version of ROS you're using. For the devel
branches, replace master
by devel
.
source /opt/ros/noetic/setup.bash # or use whatever version of ROS is installed!
mkdir ~/catkin_ws # create the catkin workspace
cd ~/catkin_ws # go in the workspace
catkin init # create files for catkin build tool
catkin config --cmake-args -DCMAKE_BUILD_TYPE=Release # all code should be compiled in release mode
mkdir src
cd src # go in source directory to pull code
vcs import --recursive --input https://raw.githubusercontent.com/jhu-dvrk/dvrk-github-workflow/main/vcs/ros1-dvrk-2.2.1.vcs
catkin build --summary # ... and finally compile everything
If you want to use the release 2.1, replace the vcs command with:
vcs import --recursive --input https://raw.githubusercontent.com/jhu-dvrk/dvrk-github-workflow/main/vcs/ros1-dvrk-2.1.0.vcs
For the development branches, use:
vcs import --recursive --input https://raw.githubusercontent.com/jhu-dvrk/dvrk-github-workflow/main/vcs/ros1-dvrk-devel.vcs
This is recommended if you're going to use a single catkin workspace (as most users do): https://github.com/jhu-cisst/cisst/wiki/Compiling-cisst-and-SAW-with-CMake#setting-up-your-environment-variables-for-ros
This approach is a bit more complicated and will add some extra repositories for SAW components not needed for the dVRK software. Compilation time will be slightly longer. Most repositories in cisst/SAW will be cloned using git sub-modules.
You will first need to build cisst and its dependencies. Follow the instructions provided for cisst/SAW catkin build and then come back to this page for the dVRK/ROS specific packages.
These packages are not part of the cisst-saw repositories so you have to clone them manually. You first need to download the cisst-saw libraries and components (see instructions above) and then do:
cd ~/catkin_ws/src
git clone https://github.com/jhu-dvrk/dvrk-ros
git clone https://github.com/jhu-dvrk/dvrk-gravity-compensation
git clone https://github.com/collaborative-robotics/crtk_msgs crtk/crtk_msgs
git clone https://github.com/collaborative-robotics/crtk_python_client crtk/crtk_python_client
git clone https://github.com/collaborative-robotics/crtk_matlab_client crtk/crtk_matlab_client
catkin build --summary
This is not recommended for most users but can be useful if you don't have ROS or want to compile some of the dVRK code on Windows. See: https://github.com/jhu-dvrk/sawIntuitiveResearchKit/wiki/Build
Community
Getting Started
- First Steps
- Software installation
- Controller Connectivity
- Configuration files
- Hardware Setup
- Calibration
- Classic/Standard
- Si
- Examples
Advanced
- Software Architecture
- Application Development
- APIs
- UI Customization
- Teleoperation
- Kinematics Simulation
- Potentiometer Issues
- Development Branches
- Release Checklist
- Projects
- Controllers/versions
- E-STOP Wiring
- Full da Vinci System
- Head Sensor
- Foot Pedals
- Video
- Instruments
Miscellaneous
- Frequently Asked Questions
- User manuals Classic and Si moved
- QLA Heat Sink
- Build w/o ROS Linux Mac
- cisst
- JHU
Deprecated