25 #include <unordered_set> 33 namespace perception {
41 _lr_parameters.resize(3, 4);
42 _lr_parameters.coeffRef(0, 0) = 0.0510903f;
43 _lr_parameters.coeffRef(0, 1) = -1.00989f;
44 _lr_parameters.coeffRef(0, 2) = -1.6537f;
45 _lr_parameters.coeffRef(0, 3) = 0.130055f;
46 _lr_parameters.coeffRef(1, 0) = 0.266469f;
47 _lr_parameters.coeffRef(1, 1) = -0.538964f;
48 _lr_parameters.coeffRef(1, 2) = -0.291611f;
49 _lr_parameters.coeffRef(1, 3) = -0.070701f;
50 _lr_parameters.coeffRef(2, 0) = 0.497949f;
51 _lr_parameters.coeffRef(2, 1) = -0.504843f;
52 _lr_parameters.coeffRef(2, 2) = -0.152141f;
53 _lr_parameters.coeffRef(2, 3) = -1.38024f;
59 float x_max = -FLT_MAX;
60 float y_max = -FLT_MAX;
61 float z_max = -FLT_MAX;
62 float x_min = FLT_MAX;
63 float y_min = FLT_MAX;
64 float z_min = FLT_MAX;
65 for (
size_t i = 0; i < cloud->size(); ++i) {
66 auto pt = (*cloud)[i];
67 x_min = std::min(x_min, pt.x);
68 x_max = std::max(x_max, pt.x);
69 y_min = std::min(y_min, pt.y);
70 y_max = std::max(y_max, pt.y);
71 z_min = std::min(z_min, pt.z);
72 z_max = std::max(z_max, pt.z);
74 Eigen::Vector3f fea = {x_max - x_min, y_max - y_min, z_max - z_min};
75 Eigen::VectorXf response = fea.transpose() * _lr_parameters;
82 Eigen::MatrixXf _lr_parameters;
83 std::vector<std::string> _labels = {
"unknown",
"nonMot",
"pedestrian",
bool init()
Definition: lr_classifier.h:40
std::string GetLabel(base::PointFCloudConstPtr cloud)
Definition: lr_classifier.h:57
std::shared_ptr< const PointFCloud > PointFCloudConstPtr
Definition: point_cloud.h:473
Definition: lr_classifier.h:36
~LRClassifier()
Definition: lr_classifier.h:39