forked from fmrico/perception_asr
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDarknetDetectionNode.cpp
More file actions
70 lines (56 loc) · 2.47 KB
/
DarknetDetectionNode.cpp
File metadata and controls
70 lines (56 loc) · 2.47 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
// Copyright 2023 (c) Intelligent Robotics Lab
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#include <memory>
#include "perception_asr_stressoverflow/DarknetDetectionNode.hpp"
#include "darknet_ros_msgs/msg/bounding_boxes.hpp"
#include "vision_msgs/msg/detection2_d_array.hpp"
#include "vision_msgs/msg/detection2_d.hpp"
#include "vision_msgs/msg/object_hypothesis_with_pose.hpp"
#include "rclcpp/rclcpp.hpp"
namespace perception_asr_stressoverflow
{
using std::placeholders::_1;
DarknetDetectionNode::DarknetDetectionNode()
: Node("darkent_detection_node")
{
detection_bbxs_sub_ = create_subscription<darknet_ros_msgs::msg::BoundingBoxes>(
"input_bbxs_detection", rclcpp::SensorDataQoS().reliable(),
std::bind(&DarknetDetectionNode::detection_callback, this, _1));
detection_pub_ = create_publisher<vision_msgs::msg::Detection2DArray>(
"output_detection_2d", rclcpp::SensorDataQoS().reliable());
}
void
DarknetDetectionNode::detection_callback(
const darknet_ros_msgs::msg::BoundingBoxes::ConstSharedPtr & msg)
{
if (detection_pub_->get_subscription_count() > 0) {
vision_msgs::msg::Detection2DArray detection_array_msg;
detection_array_msg.header = msg->image_header;
for (const auto & bbx : msg->bounding_boxes) {
vision_msgs::msg::Detection2D detection_msg;
detection_msg.header = msg->image_header;
detection_msg.bbox.center.position.x = ((bbx.xmax - bbx.xmin) / 2) + bbx.xmin;
detection_msg.bbox.center.position.y = ((bbx.ymax - bbx.ymin) / 2) + bbx.ymin;
detection_msg.bbox.size_x = bbx.xmax - bbx.xmin;
detection_msg.bbox.size_y = bbx.ymax - bbx.ymin;
vision_msgs::msg::ObjectHypothesisWithPose obj_msg;
obj_msg.hypothesis.class_id = bbx.class_id;
obj_msg.hypothesis.score = bbx.probability;
detection_msg.results.push_back(obj_msg);
detection_array_msg.detections.push_back(detection_msg);
}
detection_pub_->publish(detection_array_msg);
}
}
} // namespace perception_asr_stressoverflow