From 7938432f866a4a2a68360da08d7dc0a5ae8fd66a Mon Sep 17 00:00:00 2001 From: Adam Aposhian Date: Thu, 12 Oct 2023 14:55:46 -0600 Subject: [PATCH 1/2] allow for configuring packet topics qos --- ouster-ros/src/os_cloud_node.cpp | 5 ++++- ouster-ros/src/os_sensor_node.cpp | 6 ++++-- 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/ouster-ros/src/os_cloud_node.cpp b/ouster-ros/src/os_cloud_node.cpp index 9a381d20..b4b80889 100644 --- a/ouster-ros/src/os_cloud_node.cpp +++ b/ouster-ros/src/os_cloud_node.cpp @@ -154,11 +154,14 @@ class OusterCloud : public OusterProcessingNodeBase { if (check_token(tokens, "PCL") || check_token(tokens, "SCAN")) { lidar_packet_handler = LidarPacketHandler::create_handler( info, use_ros_time, processors); + rclcpp::SubscriptionOptions subscription_options; + subscription_options.qos_overriding_options = rclcpp::QosOverridingOptions::with_default_policies(); lidar_packet_sub = create_subscription( "lidar_packets", selected_qos, [this](const PacketMsg::ConstSharedPtr msg) { lidar_packet_handler(msg->buf.data()); - }); + }, + subscription_options); } } diff --git a/ouster-ros/src/os_sensor_node.cpp b/ouster-ros/src/os_sensor_node.cpp index 191a0f6c..3bb8bbde 100644 --- a/ouster-ros/src/os_sensor_node.cpp +++ b/ouster-ros/src/os_sensor_node.cpp @@ -642,9 +642,11 @@ void OusterSensor::create_publishers() { rclcpp::QoS sensor_data_qos = rclcpp::SensorDataQoS(); auto selected_qos = use_system_default_qos ? system_default_qos : sensor_data_qos; + rclcpp::PublisherOptions publisher_options; + publisher_options.qos_overriding_options = rclcpp::QosOverridingOptions::with_default_policies(); lidar_packet_pub = - create_publisher("lidar_packets", selected_qos); - imu_packet_pub = create_publisher("imu_packets", selected_qos); + create_publisher("lidar_packets", selected_qos, publisher_options); + imu_packet_pub = create_publisher("imu_packets", selected_qos, publisher_options); } void OusterSensor::allocate_buffers() { From 9376a64d1b5461f6f336145f161e3a7b81e636eb Mon Sep 17 00:00:00 2001 From: Adam Aposhian Date: Thu, 12 Oct 2023 15:08:49 -0600 Subject: [PATCH 2/2] increase default history depth for packets topic --- ouster-ros/src/os_cloud_node.cpp | 2 +- ouster-ros/src/os_sensor_node.cpp | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/ouster-ros/src/os_cloud_node.cpp b/ouster-ros/src/os_cloud_node.cpp index b4b80889..130a830f 100644 --- a/ouster-ros/src/os_cloud_node.cpp +++ b/ouster-ros/src/os_cloud_node.cpp @@ -157,7 +157,7 @@ class OusterCloud : public OusterProcessingNodeBase { rclcpp::SubscriptionOptions subscription_options; subscription_options.qos_overriding_options = rclcpp::QosOverridingOptions::with_default_policies(); lidar_packet_sub = create_subscription( - "lidar_packets", selected_qos, + "lidar_packets", selected_qos.keep_last(100), [this](const PacketMsg::ConstSharedPtr msg) { lidar_packet_handler(msg->buf.data()); }, diff --git a/ouster-ros/src/os_sensor_node.cpp b/ouster-ros/src/os_sensor_node.cpp index 3bb8bbde..03d9b901 100644 --- a/ouster-ros/src/os_sensor_node.cpp +++ b/ouster-ros/src/os_sensor_node.cpp @@ -645,7 +645,7 @@ void OusterSensor::create_publishers() { rclcpp::PublisherOptions publisher_options; publisher_options.qos_overriding_options = rclcpp::QosOverridingOptions::with_default_policies(); lidar_packet_pub = - create_publisher("lidar_packets", selected_qos, publisher_options); + create_publisher("lidar_packets", selected_qos.keep_last(100), publisher_options); imu_packet_pub = create_publisher("imu_packets", selected_qos, publisher_options); }