Skip to content

Commit

Permalink
feat(pointcloud_preprocessor): make concatenate node to publish point…
Browse files Browse the repository at this point in the history
…clouds in sensor frame (autowarefoundation#6586)

* feat: make concatenate node to publish pointclouds in sensor frame

Signed-off-by: yoshiri <[email protected]>

* chore: disable frame transform if not necessary

Signed-off-by: yoshiri <[email protected]>

---------

Signed-off-by: yoshiri <[email protected]>
  • Loading branch information
YoshiRi committed May 10, 2024
1 parent 5ebf86f commit cc79cb8
Show file tree
Hide file tree
Showing 4 changed files with 50 additions and 6 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -126,6 +126,7 @@ class PointCloudConcatenateDataSynchronizerComponent : public rclcpp::Node
double timeout_sec_ = 0.1;

bool publish_synchronized_pointcloud_;
bool keep_input_frame_in_synchronized_pointcloud_;
std::string synchronized_pointcloud_postfix_;

std::set<std::string> not_subscribed_topic_names_;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -138,6 +138,7 @@ class PointCloudDataSynchronizerComponent : public rclcpp::Node

/** \brief Output TF frame the concatenated points should be transformed to. */
std::string output_frame_;
bool keep_input_frame_in_synchronized_pointcloud_;

/** \brief Input point cloud topics. */
// XmlRpc::XmlRpcValue input_topics_;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -112,7 +112,9 @@ PointCloudConcatenateDataSynchronizerComponent::PointCloudConcatenateDataSynchro
}

// Check if publish synchronized pointcloud
publish_synchronized_pointcloud_ = declare_parameter("publish_synchronized_pointcloud", false);
publish_synchronized_pointcloud_ = declare_parameter("publish_synchronized_pointcloud", true);
keep_input_frame_in_synchronized_pointcloud_ =
declare_parameter("keep_input_frame_in_synchronized_pointcloud", true);
synchronized_pointcloud_postfix_ =
declare_parameter("synchronized_pointcloud_postfix", "pointcloud");
}
Expand Down Expand Up @@ -391,10 +393,23 @@ PointCloudConcatenateDataSynchronizerComponent::combineClouds(
pcl::concatenatePointCloud(
*concat_cloud_ptr, *transformed_delay_compensated_cloud_ptr, *concat_cloud_ptr);
}
// gather transformed clouds
transformed_delay_compensated_cloud_ptr->header.stamp = oldest_stamp;
transformed_delay_compensated_cloud_ptr->header.frame_id = output_frame_;
transformed_clouds[e.first] = transformed_delay_compensated_cloud_ptr;
// convert to original sensor frame if necessary
bool need_transform_to_sensor_frame = (e.second->header.frame_id != output_frame_);
if (keep_input_frame_in_synchronized_pointcloud_ && need_transform_to_sensor_frame) {
sensor_msgs::msg::PointCloud2::SharedPtr transformed_cloud_ptr_in_sensor_frame(
new sensor_msgs::msg::PointCloud2());
pcl_ros::transformPointCloud(
(std::string)e.second->header.frame_id, *transformed_delay_compensated_cloud_ptr,
*transformed_cloud_ptr_in_sensor_frame, *tf2_buffer_);
transformed_cloud_ptr_in_sensor_frame->header.stamp = oldest_stamp;
transformed_cloud_ptr_in_sensor_frame->header.frame_id = e.second->header.frame_id;
transformed_clouds[e.first] = transformed_cloud_ptr_in_sensor_frame;
} else {
transformed_delay_compensated_cloud_ptr->header.stamp = oldest_stamp;
transformed_delay_compensated_cloud_ptr->header.frame_id = output_frame_;
transformed_clouds[e.first] = transformed_delay_compensated_cloud_ptr;
}

} else {
not_subscribed_topic_names_.insert(e.first);
}
Expand Down Expand Up @@ -449,6 +464,19 @@ void PointCloudConcatenateDataSynchronizerComponent::publish()
debug_publisher_->publish<tier4_debug_msgs::msg::Float64Stamped>(
"debug/processing_time_ms", processing_time_ms);
}
for (const auto & e : cloud_stdmap_) {
if (e.second != nullptr) {
if (debug_publisher_) {
const auto pipeline_latency_ms =
std::chrono::duration<double, std::milli>(
std::chrono::nanoseconds(
(this->get_clock()->now() - e.second->header.stamp).nanoseconds()))
.count();
debug_publisher_->publish<tier4_debug_msgs::msg::Float64Stamped>(
"debug" + e.first + "/pipeline_latency_ms", pipeline_latency_ms);
}
}
}
}

///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,9 @@ PointCloudDataSynchronizerComponent::PointCloudDataSynchronizerComponent(
std::string synchronized_pointcloud_postfix;
{
output_frame_ = static_cast<std::string>(declare_parameter("output_frame", ""));
if (output_frame_.empty()) {
keep_input_frame_in_synchronized_pointcloud_ =
static_cast<bool>(declare_parameter("keep_input_frame_in_synchronized_pointcloud", false));
if (output_frame_.empty() && !keep_input_frame_in_synchronized_pointcloud_) {
RCLCPP_ERROR(get_logger(), "Need an 'output_frame' parameter to be set before continuing!");
return;
}
Expand Down Expand Up @@ -339,6 +341,18 @@ PointCloudDataSynchronizerComponent::synchronizeClouds()
pcl_ros::transformPointCloud(
adjust_to_old_data_transform, *transformed_cloud_ptr,
*transformed_delay_compensated_cloud_ptr);
// transform to sensor frame if needed
bool need_transform_to_sensor_frame = (e.second->header.frame_id != output_frame_);
if (keep_input_frame_in_synchronized_pointcloud_ && need_transform_to_sensor_frame) {
sensor_msgs::msg::PointCloud2::SharedPtr
transformed_delay_compensated_cloud_ptr_in_input_frame(
new sensor_msgs::msg::PointCloud2());
transformPointCloud(
transformed_delay_compensated_cloud_ptr,
transformed_delay_compensated_cloud_ptr_in_input_frame, e.second->header.frame_id);
transformed_delay_compensated_cloud_ptr =
transformed_delay_compensated_cloud_ptr_in_input_frame;
}
// gather transformed clouds
transformed_delay_compensated_cloud_ptr->header.stamp = oldest_stamp;
transformed_delay_compensated_cloud_ptr->header.frame_id = output_frame_;
Expand Down

0 comments on commit cc79cb8

Please sign in to comment.