-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathclassifier_nbc.cpp
37 lines (31 loc) · 985 Bytes
/
classifier_nbc.cpp
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
#include "classifier_nbc.h"
ClassifierNBC::ClassifierNBC()
{
}
void ClassifierNBC::trainData(const std::vector<cv::Point> &data, const std::vector<int> &labels)
{
cls.clear();
loadData(data, labels);
// std::cout << "data: cols=" << pData.cols << ", rows=" << pData.rows << " : " << pData << std::endl;
// std::cout << "labl: cols=" << lData.cols << ", rows=" << lData.rows << " : " << lData << std::endl;
// cls = cv::NormalBayesClassifier(pData, lData);
cls.train(pData, lData);
isTrainedFlag = true;
}
/*
int ClassifierNBC::classify(const cv::Point &p)
{
return classify(p.x, p.y);
}
*/
int ClassifierNBC::classify(int x, int y)
{
testSample.at<float>(0) = (float)x;
testSample.at<float>(1) = (float)y;
// std::cout << "cols=" << testSample.cols << ", rows=" << testSample.rows << " : " << testSample << std::endl;
return cvRound(cls.predict(testSample));
}
QString ClassifierNBC::toQString() const
{
return QString("NBC");
}