forked from qobi/ece57000
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathimage_classifier_gui.py
76 lines (66 loc) · 1.92 KB
/
image_classifier_gui.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
from gui import *
from distances import *
from nearest_neighbor_classifier import *
import cv2
import numpy as np
points = []
labels = []
distance = bidirectional(chamfer(L2_vector(L2_scalar)), plus)
def process(image):
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
v = np.median(gray)
sigma = 0.33
lower_thresh = int(max(0, (1.0-sigma)*v))
upper_thresh = int(min(255, (1.0+sigma)*v))
edge = cv2.Canny(gray, lower_thresh, upper_thresh)
return edge
def edge_pixels(image):
m, n = image.shape
pixels = []
for i in range(0, m, 10):
for j in range(0, n, 10):
if image[i, j]>0:
pixels.append([i,j])
return pixels
def capture():
camera = cv2.VideoCapture(0)
return_value, image = camera.read()
camera.release()
edge = process(image)
if show_edges():
get_window().show_image(cv2.cvtColor(edge, cv2.COLOR_GRAY2BGR))
else:
get_window().show_image(image)
return edge_pixels(edge)
def clear_command():
global points, labels
points = []
labels = []
message("")
def cup_command():
message("")
points.append(capture())
labels.append("Cup")
def box_command():
message("")
points.append(capture())
labels.append("Box")
def classify_command():
message("")
if len(points)==0:
message("No data")
else:
message(classify(capture(), distance, points, labels))
add_button(0, 0, "Clear", clear_command, nothing)
show_edges = add_checkbox(0, 1, "Edges?", nothing)
add_button(0, 2, "Cup", cup_command, nothing)
add_button(0, 3, "Box", box_command, nothing)
add_button(0, 4, "Classify", classify_command, nothing)
add_button(0, 5, "Exit", done, nothing)
message = add_message(1, 0, 6)
camera = cv2.VideoCapture(0)
width = camera.get(cv2.CAP_PROP_FRAME_WIDTH)
height = camera.get(cv2.CAP_PROP_FRAME_HEIGHT)
fps = camera.get(cv2.CAP_PROP_FPS)
camera.release()
start_video(width, height, 2, 6)