-
Notifications
You must be signed in to change notification settings - Fork 17
/
demo.cpp
111 lines (99 loc) · 3.3 KB
/
demo.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
99
100
101
102
103
104
105
106
107
108
109
110
111
#include <iostream>
#include <fstream>
#include <opencv2/opencv.hpp>
#include <vector>
#include "deepsort.h"
#include "logging.h"
#include <ctime>
using std::vector;
static Logger gLogger;
void showDetection(cv::Mat& img, std::vector<DetectBox>& boxes) {
cv::Mat temp = img.clone();
for (auto box : boxes) {
cv::Point lt(box.x1, box.y1);
cv::Point br(box.x2, box.y2);
cv::rectangle(temp, lt, br, cv::Scalar(255, 0, 0), 1);
std::string lbl = cv::format("ID:%d_C:%d_CONF:%.2f", (int)box.trackID, (int)box.classID, box.confidence);
cv::putText(temp, lbl, lt, cv::FONT_HERSHEY_COMPLEX, 0.8, cv::Scalar(0,255,0));
}
cv::imshow("img", temp);
cv::waitKey(1);
}
class Tester {
public:
Tester(string modelPath) {
allDetections.clear();
out.clear();
DS = new DeepSort(modelPath, 128, 256, 0, &gLogger);
}
~Tester() {
}
public:
void split(const std::string& s, vector<std::string>& token, char delim=' ') {
token.clear();
auto string_find_first_not = [s, delim](size_t pos = 0) -> size_t {
for (size_t i = pos; i < s.size(); ++i)
if (s[i] != delim) return i;
return string::npos;
};
size_t lastPos = string_find_first_not(0);
size_t pos = s.find(delim, lastPos);
while (lastPos != string::npos) {
token.emplace_back(s.substr(lastPos, pos-lastPos));
lastPos = string_find_first_not(pos);
pos = s.find(delim, lastPos);
}
}
void loadDetections(std::string txtPath) {
//fstream f(filePath, ios::in);
this->txtPath = txtPath;
ifstream inFile;
inFile.open(txtPath, ios::binary);
std::string temp;
vector<std::string> token;
while (getline(inFile, temp)) {
// std::cout << temp << std::endl;
split(temp, token, ' ');
int frame = atoi(token[0].c_str());
int c = atoi(token[1].c_str());
int x = atoi(token[2].c_str());
int y = atoi(token[3].c_str());
int w = atoi(token[4].c_str());
int h = atoi(token[5].c_str());
float con= atof(token[6].c_str());
while (allDetections.size() <= frame) {
vector<DetectBox> t;
allDetections.push_back(t);
}
DetectBox dd(x-w/2, y-h/2, x+w/2, y+h/2, con, c);
allDetections[frame].push_back(dd);
}
allDetections.pop_back();
}
void run() {
cv::namedWindow("DeepSortTest");
int i = 1;
cv::Mat whiteBoard(1080, 1920, CV_8UC3, cv::Scalar::all(0));
for (vector<DetectBox> d : allDetections) {
cv::Mat img_rgb;
cv::cvtColor(whiteBoard, img_rgb, cv::COLOR_BGR2RGB);
DS->sort(img_rgb, d);
showDetection(whiteBoard, d);
}
cv::destroyAllWindows();
}
private:
vector<vector<DetectBox>> allDetections;
vector<DetectBox> out;
std::string txtPath;
DeepSort* DS;
};
int main(int argc, char** argv) {
if (argc < 3) {
std::cout << "./demo [input model path] [input txt path]" << std::endl;
return -1;
}
Tester* test = new Tester(argv[1]);
test->loadDetections(argv[2]);
test->run();
}