15#ifndef __PBMAP_PLANE_H
16#define __PBMAP_PLANE_H
18#include <mrpt/config.h>
26#include <pcl/point_types.h>
27#include <pcl/common/pca.h>
31#define USE_COMPLETNESS_HEURISTICS 1
32#define USE_INFERRED_STRUCTURE 1
57 bFromStructure(false),
59 polygonContourPtr(new pcl::PointCloud<pcl::PointXYZRGBA>),
60 planePointCloudPtr(new pcl::PointCloud<pcl::PointXYZRGBA>)
99 bool isSamePlane(
Plane &plane,
const float &cosAngleThreshold,
const float &distThreshold,
const float &proxThreshold);
101 bool isSamePlane(Eigen::Matrix4f &Rt,
Plane &plane_,
const float &cosAngleThreshold,
const float &distThreshold,
const float &proxThreshold);
183 std::vector<float>
r;
184 std::vector<float>
g;
185 std::vector<float>
b;
192 std::vector<float>
c1;
193 std::vector<float>
c2;
194 std::vector<float>
c3;
#define DEFINE_SERIALIZABLE_POST_CUSTOM_LINKAGE(class_name, _LINKAGE_)
#define DEFINE_SERIALIZABLE_PRE_CUSTOM_LINKAGE(class_name, _LINKAGE_)
This declaration must be inserted in all CSerializable classes definition, before the class declarati...
#define DEFINE_SERIALIZABLE(class_name)
This declaration must be inserted in all CSerializable classes definition, within the class declarati...
static std::vector< size_t > DEFAULT_VECTOR
A class used to store a planar feature (Plane for short).
std::string label_context
std::set< unsigned > nearbyPlanes
void calcConvexHullandParams(pcl::PointCloud< pcl::PointXYZRGBA >::Ptr &pointCloud, std::vector< size_t > &indices=DEFAULT_VECTOR)
std::vector< Eigen::Vector3f > prog_Nrgb
void mergePlane(Plane &plane)
std::vector< int32_t > inliers
! Convex Hull
void transform(Eigen::Matrix4f &Rt)
std::vector< double > prog_area
std::vector< double > prog_elongation
void computeMassCenterAndArea()
Compute the patch's convex-hull area and mass center.
Eigen::Vector3f v3PpalDir
void forcePtsLayOnPlane()
pcl::PointCloud< pcl::PointXYZRGBA >::Ptr polygonContourPtr
std::vector< Eigen::Vector3f > prog_C1C2C3
std::vector< float > intensity
std::vector< float > prog_intensity
std::map< unsigned, unsigned > neighborPlanes
pcl::PointCloud< pcl::PointXYZRGBA >::Ptr planePointCloudPtr
unsigned nFramesAreaIsStable
bool isPlaneNearby(Plane &plane, const float distThreshold)
bool isSamePlane(Eigen::Matrix4f &Rt, Plane &plane_, const float &cosAngleThreshold, const float &distThreshold, const float &proxThreshold)
Eigen::Vector3f v3colorC1C2C3
std::vector< std::vector< float > > prog_hist_H
std::vector< float > hist_H
Eigen::Vector3f v3colorNrgbDev
void calcElongationAndPpalDir()
bool isSamePlane(Plane &plane, const float &cosAngleThreshold, const float &distThreshold, const float &proxThreshold)
unsigned id
! Parameters to allow the plane-based representation of the map by a graph
bool hasSimilarDominantColor(Plane &plane, const float colorThreshold)
float compute2DPolygonalArea()
Compute the area of a 2D planar polygon patch - using a given normal.
pcl::PointCloud< pcl::PointXYZRGBA >::Ptr outerPolygonPtr
void calcConvexHull(pcl::PointCloud< pcl::PointXYZRGBA >::Ptr &pointCloud, std::vector< size_t > &indices=DEFAULT_VECTOR)
! Calculate the plane's convex hull with the monotone chain algorithm.
Eigen::Vector3f v3center
! Geometric description
Eigen::Matrix4f information
void mergePlane2(Plane &plane)
Eigen::Vector3f v3colorNrgb
! Radiometric description
This is the global namespace for all Mobile Robot Programming Toolkit (MRPT) libraries.