-
Notifications
You must be signed in to change notification settings - Fork 12
/
predict_example_main.py
108 lines (97 loc) · 3.8 KB
/
predict_example_main.py
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
import cv2
import matplotlib.pyplot as plt
import numpy as np
from utils.buffTracker import F_BuffTracker, BBox
from utils.parameterUtils import Parameter
from utils.angleProcessor import bigPredictor, smallPredictor, angleObserver, trans, clock, mode
"""
超参数
color = red | blue
moveMode = mode.big | mode.small
freq : 帧率
time_interval : 预测间隔
"""
color = 'blue'
moveMode = mode.small
freq = 50
deltaT = 0.2
FPS_ = []
angles = []
isImshow = True
LIST = [
r"./examples/example_for_prediction/6_dark_blue_big/parameter.yaml",
r"./examples/example_for_prediction/7_dark_red_big/parameter.yaml",
r"./examples/example_for_prediction/8_dark_blue_small/parameter.yaml",
r"./examples/example_for_prediction/9_dark_red_small/parameter.yaml",
r"./examples/example_for_prediction/10_dark_red_small_near/parameter.yaml"
]
paramterPath = LIST[2]
param = Parameter(paramterPath)
cap = cv2.VideoCapture(param.videoRelPath)
ret, frame = cap.read()
if ret is False:
exit(-1)
height, width, channel = frame.shape
# fourcc = cv2.VideoWriter_fourcc(*'PIM1')
# out = cv2.VideoWriter(r'./examples/example_for_prediction/10_dark_red_small_near/10_dark_red_small_near.avi', fourcc, 50, (width, height))
# 建议example 5旧符放大两倍
xy = []
frameCount = 0
while ret:
ret, frame = cap.read()
if not ret:
break
# frame = cv2.resize(frame, (width * 2, height * 2))
frameCount += 1
print(frameCount)
if frameCount >= param.start:
if frameCount == param.start:
rect = cv2.selectROI('roi', frame)
rect2 = cv2.selectROI("roi2", frame)
R_Box = BBox(rect[0], rect[1], rect[0] + rect[2], rect[1] + rect[3])
fanBladeBox = BBox(rect2[0], rect2[1], rect2[0] + rect2[2], rect2[1] + rect2[3])
tracker = F_BuffTracker(fanBladeBox, R_Box, param, isImshow=isImshow)
if color == "red":
observer = angleObserver(clockMode=clock.clockwise)
elif color == "blue":
observer = angleObserver(clockMode=clock.anticlockwise)
if moveMode == mode.small:
predictor = smallPredictor(freq=freq, deltaT=deltaT)
elif moveMode == mode.big:
predictor = bigPredictor(freq=freq, deltaT=deltaT)
interval = int(freq * deltaT)
flag = tracker.update(frame, True)
if flag is False:
print(False)
raise ValueError("画面中没有扇叶了")
x, y = tracker.fanBladeBox.center_2f - tracker.R_Box.center_2f
angle = observer.update(x, y, tracker.radius)
angles.append(angle)
flag, deltaAngle = predictor.update(angle)
if flag is True:
angle = trans(x, y) + deltaAngle
x = np.cos(angle) * tracker.radius
y = np.sin(angle) * tracker.radius
x, y = np.array([x, y]) + tracker.R_Box.center_2f
xy.append([x, y])
cv2.circle(frame, (int(x), int(y)), 10, (0, 255, 0), -1)
cv2.putText(frame, "now predict", (int(x), int(y)), cv2.FONT_HERSHEY_SIMPLEX, 0.75, (0, 0, 255), 2)
if len(xy) >= interval:
x, y = xy[len(xy) - interval]
cv2.circle(frame, (int(x), int(y)), 10, (0, 255, 0), -1)
cv2.putText(frame, "0.2s before predict", (int(x), int(y)), cv2.FONT_HERSHEY_SIMPLEX, 0.75, (0, 0, 255),
2)
pass
cv2.rectangle(frame, tracker.fanBladeBox.p1, tracker.fanBladeBox.p2, (0, 255, 0), 3)
# out.write(frame)
cv2.imshow("frame", frame)
c = cv2.waitKey(1)
if c == ord('q') or c == ord('Q'):
break
# out.release()
with open("8_dark_blue_small.txt", 'w') as f:
for angle in angles:
f.write("{}\n".format(angle))
plt.plot(range(len(angles)), angles)
plt.show()
print("DONE")