15 #include "nav2_collision_monitor/scan.hpp"
20 namespace nav2_collision_monitor
24 const nav2_util::LifecycleNode::WeakPtr & node,
25 const std::string & source_name,
26 const std::shared_ptr<tf2_ros::Buffer> tf_buffer,
27 const std::string & base_frame_id,
28 const std::string & global_frame_id,
29 const tf2::Duration & transform_tolerance,
30 const rclcpp::Duration & source_timeout,
31 const bool base_shift_correction)
33 node, source_name, tf_buffer, base_frame_id, global_frame_id,
34 transform_tolerance, source_timeout, base_shift_correction),
49 auto node =
node_.lock();
51 throw std::runtime_error{
"Failed to lock node"};
54 std::string source_topic;
59 rclcpp::QoS scan_qos = rclcpp::SensorDataQoS();
60 data_sub_ = node->create_subscription<sensor_msgs::msg::LaserScan>(
61 source_topic, scan_qos,
66 const rclcpp::Time & curr_time,
67 std::vector<Point> & data)
const
71 if (
data_ ==
nullptr) {
78 tf2::Transform tf_transform;
83 !nav2_util::getTransform(
95 !nav2_util::getTransform(
104 float angle =
data_->angle_min;
105 for (
size_t i = 0; i <
data_->ranges.size(); i++) {
109 data_->ranges[i] * std::cos(angle),
110 data_->ranges[i] * std::sin(angle),
112 tf2::Vector3 p_v3_b = tf_transform * p_v3_s;
115 data.push_back({p_v3_b.x(), p_v3_b.y()});
117 angle +=
data_->angle_increment;
rclcpp::Subscription< sensor_msgs::msg::LaserScan >::SharedPtr data_sub_
Laser scanner data subscriber.
void dataCallback(sensor_msgs::msg::LaserScan::ConstSharedPtr msg)
Laser scanner data callback.
sensor_msgs::msg::LaserScan::ConstSharedPtr data_
Latest data obtained from laser scanner.
Scan(const nav2_util::LifecycleNode::WeakPtr &node, const std::string &source_name, const std::shared_ptr< tf2_ros::Buffer > tf_buffer, const std::string &base_frame_id, const std::string &global_frame_id, const tf2::Duration &transform_tolerance, const rclcpp::Duration &source_timeout, const bool base_shift_correction)
Scan constructor.
void getData(const rclcpp::Time &curr_time, std::vector< Point > &data) const
Adds latest data from laser scanner to the data array.
void configure()
Data source configuration routine. Obtains ROS-parameters and creates laser scanner subscriber.
rclcpp::Logger logger_
Collision monitor node logger stored for further usage.
std::string base_frame_id_
Robot base frame ID.
tf2::Duration transform_tolerance_
Transform tolerance.
void getCommonParameters(std::string &source_topic)
Supporting routine obtaining ROS-parameters common for all data sources.
bool configure()
Source configuration routine.
std::string global_frame_id_
Global frame ID for correct transform calculation.
std::string source_name_
Name of data source.
nav2_util::LifecycleNode::WeakPtr node_
Collision Monitor node.
std::shared_ptr< tf2_ros::Buffer > tf_buffer_
TF buffer.
bool sourceValid(const rclcpp::Time &source_time, const rclcpp::Time &curr_time) const
Checks whether the source data might be considered as valid.
bool base_shift_correction_
Whether to correct source data towards to base frame movement, considering the difference between cur...