-
Notifications
You must be signed in to change notification settings - Fork 21
/
Copy pathpcanet_test.py
106 lines (77 loc) · 3.05 KB
/
pcanet_test.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
import os
from os.path import isdir, join
import timeit
import argparse
from sklearn.svm import SVC
from sklearn.metrics import accuracy_score
from models.pcanet import PCANet
from pcanet_utils import load_model, save_model, set_device
from data_loader import MnistLoader
parser = argparse.ArgumentParser(description="PCANet example")
parser.add_argument("--gpu", "-g", type=int, default=-1,
help="GPU ID (negative value indicates CPU)")
subparsers = parser.add_subparsers(dest="mode",
help='Choice of train/test mode')
subparsers.required = True
train_parser = subparsers.add_parser("train")
train_parser.add_argument("--out", "-o", default="results",
help="Directory to output the result")
test_parser = subparsers.add_parser("test")
test_parser.add_argument("--pretrained-model", default="result",
dest="pretrained_model",
help="Directory to the trained model")
args = parser.parse_args()
def train(train_set, train_label):
images_train, y_train = train_set, train_label
# pcanet = PCANet(
# image_shape=28,
# filter_shape_l1=5, step_shape_l1=1, n_l1_output=8,
# filter_shape_l2=5, step_shape_l2=1, n_l2_output=4,
# filter_shape_pooling=5, step_shape_pooling=5
# )
pcanet = PCANet(
image_shape=45,
filter_shape_l1=5, step_shape_l1=1, n_l1_output=8,
filter_shape_l2=5, step_shape_l2=1, n_l2_output=4,
filter_shape_pooling=5, step_shape_pooling=5
)
pcanet.validate_structure()
t1 = timeit.default_timer()
pcanet.fit(images_train)
t2 = timeit.default_timer()
train_time = t2 - t1
t1 = timeit.default_timer()
X_train = pcanet.transform(images_train)
t2 = timeit.default_timer()
transform_time = t2 - t1
classifier = SVC(C=10)
classifier.fit(X_train, y_train)
return pcanet, classifier
def test(pcanet, classifier, test_data, test_label):
images_test, y_test = test_data, test_label
X_test = pcanet.transform(images_test)
y_pred = classifier.predict(X_test)
return y_pred, y_test
loader = MnistLoader()
if args.gpu >= 0:
set_device(args.gpu)
if args.mode == "train":
train_set = loader.data_train
train_label = loader.label_train
print("Training the model...")
pcanet, classifier = train(train_set, train_label)
if not isdir(args.out):
os.makedirs(args.out)
save_model(pcanet, join(args.out, "pcanet.pkl"))
save_model(classifier, join(args.out, "classifier.pkl"))
elif args.mode == "test":
log = open(args.out+'pcanet.log','w')
test_set = loader.data_test
test_label = loader.label_test
print("Testing the model...")
pcanet = load_model(join(args.pretrained_model, "pcanet.pkl"))
classifier = load_model(join(args.pretrained_model, "classifier.pkl"))
y_test, y_pred = test(pcanet, classifier, test_set, test_label)
accuracy = accuracy_score(y_test, y_pred)
print("accuracy: {}".format(accuracy))
log.write("accuracy: {}".format(accuracy))