This package provides a ROS driver for PMD[vision]® CamBoard nano depth sensor.
The driver is packaged as a nodelet, therefore it may be directly merged inside another ROS node to avoid unnecessary data copying. At the same time, it may be started standalone or within a nodelet manager. The distance, depth (see "Distance vs. depth images" section), amplitude, and point cloud data are retrieved from the device and processed only if there are subscribers on the corresponding topics.
The pmd_camboard_nano.launch
script (inspired by the openni_launch stack
in ROS) starts the driver nodelet along with the image rectification nodelets.
This package requires PMD SDK to be installed in the system. It will search for
the PMDSDK root folder locally in the package folder <PACKAGE_FOLDER>/PMDSDK
,
globally in /usr/local/pmd
, or systemwide defined by an environment variable
PMDDIR
. You can also change the search folder by modifying the
PMDSDK_ROOT_DIR
variable in CMakeLists.txt
file.
You also need to copy the file 10-pmd.rules
provided with the SDK to
/etc/udev/rules.d
to allow normal users to open the camera.
Clone this repository into a local catkin workspace and simply call
catkin_make
in the workspace folder.
-
distance/camera_info
(sensor_msgs/CameraInfo)
camera calibration and metadata (see "Camera calibration" section) -
distance/image
(sensor_msgs/Image)
raw distances from the optical center of the device to scene points, containsfloat
distances (mm) -
depth/camera_info
(sensor_msgs/CameraInfo)
camera calibration and metadata (see "Camera calibration" section) -
depth/image
(sensor_msgs/Image)
depths of scene points (distances along the camera optical axis) from the device, containsfloat
depths in mm -
amplitude/camera_info
(sensor_msgs/CameraInfo)
camera calibration and metadata (see "Camera calibration" section) -
amplitude/image
(sensor_msgs/Image)
signal strengths of active illumination -
points_unrectified
(sensor_msgs/PointCloud2)
3D point cloud generated by the camera driver
-
~device_serial
(default: "")
specifies which device to open, empty means any -
~calibration_file
path to the file with camera calibration data -
~frame_id
(default: "/camera_optical_frame")
the tf frame of the camera -
~open_camera_retry_period
(default: 3)
how often (seconds) to try to open camera during the startup -
~update_rate
(default: 30)
how often (Hz) to download and publish new data from the camera -
~flip_vertical
(default: true)
flip the output images/point clouds vertically, so that the first row is swapped with the last and so on
Use the dynamic_reconfigure package to update these parameters in runtime:
-
~remove_invalid_pixels
(default: true)
replace invalid pixels in depth and amplitude images with NaNs -
~integration_time
(default: 333)
integration time of the camera in us -
~averaging_frames
(default: 0)
number of frames in sliding averaging window for distance data -
~signal_strength_check
(default: true)
activate signal strength check -
~signal_strength_threshold
(default: 200)
if the signal strength is below this threshold, the pixel is marked as invalid -
~consistency_check
(default: true)
activate consistency check -
~consistency_check_threshold
(default: 0.98)
if the consistency value of a pixel is below this threshold, it is marked as invalid -
~bilateral_filter
(default: true)
enable/disable bilateral filtering of the depth images -
~sigma_spatial
(default: 2.5)
spatial sigma parameter of the bilateral filter -
~sigma_range
(default: 25)
range sigma parameter of the bilateral filter -
~kernel_size
(default: 5)
kernel size parameter of the bilateral filter -
~bilateral_filter_enhance_image
(default: false)
activate enhanced bilateral filtering (increases robustness against motion blur)
By default the PMD plugin loads the calibration data from a file (provided with
the camera), which must be located within the working directory of the
application and have a name composed of the device serial number and ".dat"
extension. If you are using the pmd_camboard_nano.launch
file, the working
directory of the driver nodelet will be ~/.ros
. You therefore have to have a
copy of the calibration file there.
Alternatively, you can specify the location of the calibration data file as a
parameter of the nodelet (~calibration_file
).
If the PMD plugin failed to load the calibration data, then the camera info messages produced by the driver nodelet will be filled with the values that seem to be "default" (see this forum topic).
The distance data provided by the PMD SDK driver is actually the distances from the optical center of the camera to the scene points. Other cameras (e.g. Microsoft Kinect) output depth maps that are composed of distances from the cameras principal plane to the scene points along the optical axis. In other words, their depth image consists of z-coordinates of the scene points in the cameras coordinate frame.
This driver publishes both distance images (as output by the PMD SDK driver), and "Kinect-style" depth images, computed by multiplying the distances with the corresponding direction vectors.
This package was tested under Ubuntu Trusty x64 with ROS Indigo, Ubuntu Precise x64 with ROS Fuerte, and Ubuntu Oneiric x64 with ROS Electric. The version of PMD SDK is 1.3.2.
This package was tested on multiple PCs and generally worked fine, however on one Lenovo laptop the following problems were observed:
-
RViz crashed when trying to display the messages in the
/camera/points
topic. Workaround: set display style NOT to Points, e.g. to BillboardSpheres. -
While adjusting the parameters with dynamic reconfigure GUI the driver nodelet freezed and sometimes even died.