-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlagrange_point_img_detection.py
57 lines (38 loc) · 1.22 KB
/
lagrange_point_img_detection.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
# -*- coding: utf-8 -*-
"""
Created on Sun May 24 23:08:24 2020
@author: atakan
"""
import cv2
import numpy as np
for i in range(1,5):
img = cv2.imread('data/lagrange/'+str(i)+'.png')
grey_img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
template = cv2.imread("data/lagrange/lagrange_point.png", 0)
w, h = template.shape[::-1]
res = cv2.matchTemplate(grey_img, template,cv2.TM_CCORR_NORMED )
#cv2.TM_CCOEFF
#cv2.TM_CCOEFF_NORMED
#cv2.TM_CCORR
#cv2.TM_CCORR_NORMED
#cv2.TM_SQDIFF
#cv2.TM_SQDIFF_NORMED
print(res)
threshold=0
for i in range(np.shape(res)[0]):
for j in range(np.shape(res)[1]):
tmax=max(res[i:i+1,j:j+1])
if threshold < tmax:
threshold=tmax
else:
threshold=threshold
loc = np.where(res >= threshold)
print(loc)
d1=int(sum(loc[0])/np.shape(loc)[1])
d2=int(sum(loc[1])/np.shape(loc)[1])
#for pt in zip(*loc[::-1]):
cv2.rectangle(img, (d2,d1), (d2 + w, d1 + h), (0, 0, 255), 1)
cv2.imshow("img", img)
#cv2.imshow("lagrange_point", template)
cv2.waitKey(0)
cv2.destroyAllWindows()