forked from uav4geo/OpenPointClass
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrandomforest.cpp
82 lines (66 loc) · 2.66 KB
/
randomforest.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
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
#include "randomforest.hpp"
namespace rf {
RandomForest *train(const std::vector<std::string> &filenames,
double *startResolution,
const int numScales,
const int numTrees,
const int treeDepth,
const double radius,
const int maxSamples,
const std::vector<int> &classes) {
ForestParams params;
params.n_trees = numTrees;
params.max_depth = treeDepth;
auto *rtrees = new RandomForest(params);
const AxisAlignedRandomSplitGenerator generator;
std::vector<float> ft;
std::vector<int> gt;
getTrainingData(filenames, startResolution, numScales, radius, maxSamples, classes,
[&ft, >](const std::vector<Feature *> &features, size_t idx, int g) {
for (std::size_t f = 0; f < features.size(); f++) {
ft.push_back(features[f]->getValue(idx));
}
gt.push_back(g);
},
[](size_t numFeatures, int numClasses) {});
std::cout << "Using " << gt.size() << " inliers" << std::endl;
const LabelDataView label_vector(gt.data(), gt.size(), 1);
const FeatureDataView feature_vector(ft.data(), gt.size(), ft.size() / gt.size());
std::cout << "Training..." << std::endl;
rtrees->train(feature_vector, label_vector, LabelDataView(), generator, 0, false, false);
rtrees->params.resolution = *startResolution;
rtrees->params.radius = radius;
rtrees->params.numScales = numScales;
return rtrees;
}
void saveForest(RandomForest *rtrees, const std::string &modelFilename) {
std::ofstream ofs(modelFilename.c_str(), std::ios_base::out | std::ios_base::binary | std::ios_base::trunc);
rtrees->write(ofs);
std::cout << "Saved " << modelFilename << std::endl;
}
RandomForest *loadForest(const std::string &modelFilename) {
const auto rtrees = new RandomForest();
std::cout << "Loading " << modelFilename << std::endl;
std::ifstream ifs(modelFilename.c_str(), std::ios_base::in | std::ios_base::binary);
if (!ifs.is_open()) throw std::runtime_error("Cannot open " + modelFilename);
rtrees->read(ifs);
return rtrees;
}
void classify(PointSet &pointSet,
RandomForest *rtrees,
const std::vector<Feature *> &features,
const std::vector<Label> &labels,
const Regularization regularization,
const double regRadius,
const bool useColors,
const bool unclassifiedOnly,
const bool evaluate,
const std::vector<int> &skip,
const std::string &statsFile) {
classifyData<float>(pointSet,
[&rtrees](const float *ft, float *probs) {
rtrees->evaluate(ft, probs);
},
features, labels, regularization, regRadius, useColors, unclassifiedOnly, evaluate, skip, statsFile);
}
}