-
Notifications
You must be signed in to change notification settings - Fork 22
/
Copy pathclassifier.py
81 lines (61 loc) · 2.13 KB
/
classifier.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
import cv2
import os
import random
import argparse
import numpy as np
from sklearn import svm
########## Variables ##########
random_seed = 42
random.seed(random_seed)
target_img_size = (32, 32)
np.random.seed(random_seed)
classifiers = {
'SVM': svm.LinearSVC(random_state=random_seed)
}
########## Methods ##########
def extract_hog_features(img):
img = cv2.resize(img, target_img_size)
win_size = (32, 32)
cell_size = (4, 4)
block_size_in_cells = (2, 2)
block_size = (block_size_in_cells[1] * cell_size[1],
block_size_in_cells[0] * cell_size[0])
block_stride = (cell_size[1], cell_size[0])
nbins = 9
hog = cv2.HOGDescriptor(win_size, block_size,
block_stride, cell_size, nbins)
h = hog.compute(img)
h = h.flatten()
return h.flatten()
def extract_features(img, feature_set='hog'):
return extract_hog_features(img)
def get_directories():
directories = []
directories_filenames = os.listdir('./data-set')
for i, fn in enumerate(directories_filenames):
directories.append(fn)
return directories
def load_dataset(feature_set='hog'):
labels = []
features = []
directories = get_directories()
for dir_name in directories:
path_to_dataset = './data-set/' + dir_name
img_filenames = os.listdir(path_to_dataset)
for i, fn in enumerate(img_filenames):
label = dir_name
labels.append(label)
path = os.path.join(path_to_dataset, fn)
img = cv2.imread(path)
features.append(extract_features(img, feature_set))
print('finished processing: ', dir_name)
return features, labels
def run_experiment(train_features, test_features, train_labels, test_labels, model_name):
model = classifiers[model_name]
print('############## Training', model_name, "##############")
# Train the model only on the training features
model.fit(train_features, train_labels)
# Test the model on images it hasn't seen before
accuracy = model.score(test_features, test_labels)
print(model_name, 'accuracy:', accuracy*100, '%')
return model