forked from suixin1424/crossfire-yolo-TensorRT
-
Notifications
You must be signed in to change notification settings - Fork 0
/
mouse.cpp
98 lines (90 loc) · 2.4 KB
/
mouse.cpp
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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#include<mouse.h>
cv::Rect enlargeRect(const cv::Rect& rect, float scale)
{
int width = static_cast<int>(rect.width * scale);
int height = static_cast<int>(rect.height * scale);
int x = rect.x - static_cast<int>((width - rect.width) / 2);
int y = rect.y - static_cast<int>((height - rect.height) / 2);
return cv::Rect(x, y, width, height);
}
int mouse_control::fire(Mat img, ObjectDetector::BoxArray box)
{
std::vector<cv::Rect> aims;
for (auto& obj : box)
{
if (obj.class_label != isHead)
continue;
cv::Rect rect(cv::Point(obj.left, obj.top), cv::Point(obj.right, obj.bottom));
aims.push_back(rect);
}
if (aims.empty())
return 0;
if (lost_frame == 5)
{
is_first_frame = true;
lost_frame = 0;
}
if (is_first_frame)
{
//cout << 1 << endl;
aim = aims[0];
is_first_frame = false;
aims_last_num = aims.size();
}
else
{
float iou_max = 0;
cv::Rect aim_temp;
for (auto& obj : aims)
{
cv::Rect rect_temp((obj.tl().x + (float)pid.move_distance_x), (obj.tl().y + (float)pid.move_distance_y), obj.width, obj.height);
//rectangle(img, rect_temp, cv::Scalar(0x27, 0xC1, 0x36), 2);
float iou_temp = cal_iou(aim, rect_temp,5);
//cout << iou_temp << " ";
if (iou_temp >= iou_max)
{
iou_max = iou_temp;
aim_temp = obj;
}
}
//cout << endl;
if (iou_max == 0 && (aims.size() != aims_last_num))
{
lost_frame++;
return 0;
}
else
aim = aim_temp;
}
//rectangle(img, aim, cv::Scalar(0x27, 0xC1, 0x36), 2);
float pos_x = ((aim.x + aim.width / 2.0f - 208) / 416);
float pos_y = ((aim.y + aim.height / 2.0f - 208) / 416);
float w = aim.width / 416.0f;
float h = aim.height / 416.0f;
offset_x = pos_x * 416;
offset_y = pos_y * 416;
if (isHead == 1)
{
offset_y = ((pos_y) * 416);
}
else
{
offset_y = ((pos_y - w * 0.3) * 416);
}
pid.target_position_x = offset_x;
pid.target_position_y = offset_y;
{
pid.data_ready_ = true;
}
pid.data_cond_.notify_one();
return 0;
}
float mouse_control::cal_iou(cv::Rect rect1, cv::Rect rect2,float scale)
{
cv::Rect rect_temp1 = enlargeRect(rect1, scale);
cv::Rect rect_temp2 = enlargeRect(rect2, scale);
cv::Rect intersection = rect_temp1 & rect_temp2;
float intersectionArea = intersection.area();
float unionArea = rect_temp1.area() + rect_temp2.area()-intersectionArea;
return intersectionArea / unionArea;
}