This repository has been archived by the owner on Sep 26, 2023. It is now read-only.
/
test-svm.js
74 lines (64 loc) · 1.74 KB
/
test-svm.js
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
var fs = require("fs"),
path = require("path"),
nomnom = require("nomnom"),
svm = require("svm"),
params = require("./params"),
utils = require("../../utils"),
collect = require("../collect");
var opts = nomnom.options({
pos: {
abbr: 'p',
list: true,
required: true,
help: "Directory of positive test images"
},
neg: {
abbr: 'n',
list: true,
required: true,
help: "Directory of negative test images"
},
jsonFile: {
default: __dirname + "/svm.json",
help: "SVM JSON file"
},
sample: {
flag: true,
help: "sub-sample the negative images"
}
}).colors().parse();
testSVM();
function testSVM() {
var json = require(opts.jsonFile)
var SVM = new svm.SVM();
SVM.fromJSON(json);
var data = collect.collectData(opts.pos, opts.neg, opts.sample ? 1 : 0,
undefined, undefined, params);
console.time("TEST")
var truePos = 0, trueNeg = 0, falsePos = 0, falseNeg = 0;
for (var i = 0; i < data.length; i++) {
var output = data[i].output[0];
input = data[i].input;
var result = SVM.predict([input])[0];
if (result == 1 && output == 1) {
truePos++;
}
else if (result == -1 && output == 0) {
trueNeg++;
}
else if (result == 1 && output == 0) {
falsePos++;
}
else if (result == -1 && output == 1) {
falseNeg++;
}
}
console.timeEnd("TEST");
console.log("precision: " + truePos / (truePos + falsePos))
console.log("recall: " + truePos / (truePos + falseNeg))
console.log(truePos + " true positives");
console.log(trueNeg + " true negatives");
console.log(falsePos + " false positives");
console.log(falseNeg + " false negatives");
console.log(data.length + " total");
}