-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcolourDetection.py
119 lines (90 loc) · 2.95 KB
/
colourDetection.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
109
110
111
112
113
114
115
116
# -- coding: UTF-8
import cv2
import matplotlib.pyplot as plt
from sklearn.cluster import KMeans
import numpy as np
boundaries = [
([100, 80, 0], [240, 220, 110]), # yellow
([0, 40, 50], [110, 180, 250]), # blue
([0, 60, 0], [60, 160, 70]), # green
]
color_attr = ["黄牌", "蓝牌", '绿牌', '白牌', '黑牌']
threhold_green = 13
threhold_blue = 13
threhold_yellow1 = 50
threhold_yellow2 = 70
# plt.figure()
# plt.axis("off")
# plt.imshow(image)
# plt.show()
def centroid_histogram(clt):
numLabels = np.arange(0, len(np.unique(clt.labels_)) + 1)
(hist, _) = np.histogram(clt.labels_, bins=numLabels)
# normalize the histogram, such that it sums to one
hist = hist.astype("float")
hist /= hist.sum()
# return the histogram
return hist
def plot_colors(hist, centroids):
bar = np.zeros((50, 300, 3), dtype="uint8")
startX = 0
for (percent, color) in zip(hist, centroids):
endX = startX + (percent * 300)
cv2.rectangle(bar, (int(startX), 0), (int(endX), 50),
color.astype("uint8").tolist(), -1)
startX = endX
# return the bar chart
return bar
def search_boundaries(color):
for i, color_bound in enumerate(boundaries):
if np.all(color >= color_bound[0]) and np.all(color <= color_bound[1]):
return i
return -1
def judge_color(color):
r = color[0]
g = color[1]
b = color[2]
if g - r >= threhold_green and g - b >= threhold_green:
return 2
if b - r >= threhold_blue and b - g >= threhold_blue:
return 1
if r - b > threhold_yellow2 and g - b > threhold_yellow2:
return 0
if r > 200 and b > 200 and g > 200:
return 3
if r < 50 and b < 50 and g < 50:
return 4
return -1
def judge_plate_color(img):
image = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
image = image.reshape((image.shape[0] * image.shape[1], 3))
clt = KMeans(n_clusters=2)
clt.fit(image)
hist = centroid_histogram(clt)
index = np.argmax(hist)
# print clt.cluster_centers_[index]
# color_index = search_boundaries(clt.cluster_centers_[index])
color_index = judge_color(clt.cluster_centers_[index])
if color_index == -1:
if index == 0:
secound_index = 1
else:
secound_index = 0
color_index = judge_color(clt.cluster_centers_[secound_index])
if color_index == -1:
print(clt.cluster_centers_)
bar = plot_colors(hist, clt.cluster_centers_)
# show our color bart
plt.figure()
plt.axis("off")
plt.imshow(bar)
plt.show()
if color_index != -1:
return color_attr[color_index], clt.cluster_centers_[index]
else:
return None, clt.cluster_centers_[index]
if __name__ == '__main__':
file_path = "D:/python/python_work/cnsoftbei_2/test-imgs-piliang/0000.jpg"
image = cv2.imread(file_path)
result = judge_plate_color(image)
print(result)