Running ROS inside of Docker is an excellent way to experiment with DOPE, as it allows the user to completely isolate all software and configuration changes from the host system. This document describes how to create and run a Docker image that contains a complete ROS environment that supports DOPE, including all required components, such as ROS Kinetic, rviz, CUDA with cuDNN, and other packages.
The current configuration assumes all components are installed on an x86 host platform running Ubuntu 16.04. Further, use of the DOPE Docker container requires an NVIDIA GPU to be present, and it uses NVIDIA Docker for seamless CUDA usage.
(This setup was tested with NVIDIA Docker v2. Although these steps should work with NVIDIA Docker v1, that version is no longer supported by NVIDIA; rather, users are encouraged to upgrade.)
-
Download the DOPE code
$ git clone https://github.com/NVlabs/Deep_Object_Pose.git dope
-
Build the docker image
$ cd dope/docker $ nvidia-docker build -t nvidia-dope:kinetic-v1 -f Dockerfile.kinetic ..
This will take several minutes and requires an internet connection.
-
Plug in your camera Docker will not recognize a USB device that is plugged in after the container is started.
-
Run the container
$ ./run_dope_docker.sh [name] [host dir] [container dir]
Parameters:
-
name
is an optional field that specifies the name of this image. By default, it isnvidia-dope-v1
. By using different names, you can create multiple containers from the same image. -
host dir
andcontainer dir
are a pair of optional fields that allow you to specify a mapping between a directory on your host machine and a location inside the container. This is useful for sharing code and data between the two systems. By default, it maps the directory containing dope to/root/catkin_ws/src/dope
in the container.Only the first invocation of this script with a given name will create a container. Subsequent executions will attach to the running container allowing you -- in effect -- to have multiple terminal sessions into a single container.
-
-
Build DOPE Return to step 7 of the installation instructions (downloading the weights).
Note: Since the Docker container binds directly to the host's network, it will see
roscore
even if running outside the docker container.
The DOPE Docker image is based on NVIDIA's Redtail Docker image.