utilities for working with point clouds; Includes ROS wrappers around PCL filters, cloud sync/merge node and an obstacle detector.
rgbd_cloud
- Turns RGB-depth image pairs into point clouds.cloud_sync
- Synchronizes multiple point clouds and merges them into a single cloud.obstacle_detection
- Detects obstacles in a point cloud.
Topics:
color/image_raw
- color imagedepth/image_raw
- depth imagecloud
- point cloud
Both images must arrive with the same timestamp for a cloud to be generated.
Parameters:
/**:
ros__parameters:
# image transport for color images (default: raw)
color_transport: compressed
# image transport for depth images (default: raw)
depth_transport: compressedDepth
# horizontal resolution of the point cloud (default: 160)
cloud_width: 200
# minimum Z coordinate of a point to be included in the point cloud (default: 0.1)
min_distance: 0.1
# maximum Z coordinate of a point to be included in the point cloud (default: 5.0)
max_distance: 5.0
Topics:
inputN
- input point clouds (N = 0, 1, 2, ...)output
- merged point cloud
Parameters:
/**:
ros__parameters:
# The number of input clouds to synchronize. (default: 0, erroneous value)
number_of_inputs: 2
# The frame ID of the output cloud. (default: "base_link")
output_frame_id: "base_link"
# Whether to use approximate time synchronization. (default: true)
approx_sync: true
# Queue size for the synchronizer. (default: 10)
queue_size: 10
Topics:
input
- input point cloudoutput
- obstacle cloud
Parameters:
/**:
ros__parameters:
# The frame to which transform the point cloud before processing. It must have a world-aligned pitch and roll, so that slope can be calculated. (default: "map")
world_frame: "map"
# The radius for normal estimation. (default: 0.2)
normal_estimation_radius: 0.2
# The maximum angle between the ground and the normal for a point to be considered ground. (radians, default: 30 degrees)
max_ground_angle: 0.698
# The radius for the outlier removal filter. (default: 0.2)
outlier_removal_radius: 0.2
# The minimum number of neighbors for the outlier removal filter. (default: 10)
outlier_removal_min_neighbors: 10
# The frame of the robot. (default: "base_link")
robot_frame: "base_link"
# The minimum height relative to the robot for an obstacle point to be considered. Height is not affected by robot rotation. (default: -1.0)
min_obstacle_height: -1.0
# The maximum height for an obstacle point to be considered. (default: 1.0)
max_obstacle_height: 0.5
Those can be chained in a launch file to create a pipeline:
def generate_launch_description():
return LaunchDescription([
Node(
package='point_cloud_utils',
executable='rgbd_cloud',
remappings=[
('color/image_raw', '/camera/color/image_raw'),
('depth/image_raw', '/camera/depth/image_raw'),
('cloud', '/camera/point_cloud/raw'),
],
),
Node(
package='point_cloud_utils',
executable='voxel_grid',
remappings=[
('input', '/camera/point_cloud/raw'),
('output', '/camera/point_cloud/voxel_grid'),
],
),
Node(
package='point_cloud_utils',
executable='radius_outlier_removal',
remappings=[
('input', '/camera/point_cloud/voxel_grid'),
('output', '/camera/point_cloud'),
],
),
])