Skip to content

A simplified driver for Velodyne VLP16 (PUCK) based on the official ROS velodyne driver.

License

Notifications You must be signed in to change notification settings

C-NR/velodyne_puck

 
 

Repository files navigation

velodyne_puck

Build Status

Picture of Velodyne Puck

The velodyne_puck package is a linux ROS driver for velodyne puck only of VELODYNE LIDAR. The user manual for the device can be found here or the LTE version here.

The major difference between this driver and the ROS velodyne driver is that the start of each revolution is detected using azimuth.

The package is tested on Ubuntu 14.04 with ROS indigo.

License

This driver is developed based on ROS velodyne driver, which originally has the BSD license. The COPYING file is kept in this package. However, the changed files have the GNU General Public License V3.0.

Compling

This is a Catkin package. Make sure the package is on ROS_PACKAGE_PATH after cloning the package to your workspace. And the normal procedure for compling a catkin package will work.

cd your_work_space
catkin_make --pkg velodyne_puck_driver velodyne_puck_decoder --cmake-args -DCMAKE_BUILD_TYPE=Release

Example Usage

velodyne_puck_driver

Parameters

device_ip (string, default: 192.168.1.201)

By default, the IP address of the device is 192.168.1.201.

frame_id (string, default: velodyne)

The frame ID entry for the sent messages.

Published Topics

velodyne_packets (velodyne_puck_msgs/VelodynePuckPacket)

Each message corresponds to a velodyne packet sent by the device through the Ethernet. For more details on the definition of the packet, please refer to the user manual.

velodyne_puck_decoder

Parameters

min_range (double, 0.3)

max_range (double, 100.0)

Points outside this range will be removed.

frequency (frequency, 20.0)

Note that the driver does not change the frequency of the sensor. If needed, the RPM of the sensor should be set through the brower (see user manual for more details). And the frequency parameter in the launch file should be set accordingly.

publish_point_cloud (bool, false)

If set to true, the decoder will additionally send out a local point cloud consisting of the points in each revolution.

Published Topics

velodyne_sweep (velodyne_puck_msgs/VelodynePuckSweep)

The message arranges the points within each sweep based on its scan index and azimuth.

velodyne_point_cloud (sensor_msgs/PointCloud2)

This is only published when the publish_point_cloud is set to true in the launch file.

Node

roslauch velodyne_puck_decoder velodyne_puck_decoder_nodelet.launch

Note that this launch file launches both the driver and the decoder, which is the only launch file needed to be used.

FAQ

Bug Report

Prefer to open an issue. You can also send an E-mail to sunke.polyu@gmail.com.

About

A simplified driver for Velodyne VLP16 (PUCK) based on the official ROS velodyne driver.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 91.8%
  • CMake 8.2%