- Detects the n major planes of a 3D point cloud using the PCL library
- (https://github.com/PointCloudLibrary/pcl/releases)
- PCL-1.9.1-AllInOne-msvc2017-win64.exe
prebuilt works fine for Visual Studio 2019 Preview - Make sure to add the path to the PCL and OpenNI2 dlls to the env path
- e.g C:/Program Files/PCL 1.9.1/bin/ and C:/Program Files/OpenNI2/Redist/
- Unit testing is powered by Google Unit Tests. (https://github.com/google/googletest/)
- When cloning project from GIT also Update Submodule googletest
- When running CMake use gtest_force_shared_crt for googletest
- Documentation can be provided by running doxygen on the source files.
- The executable can be called with up to 4 arguments:
- (Mandatory): Input File Path: A file containing the point cloud. Acceptable types:
- Simple text file of the format {x y z}, one point per line delimited with spaces, not commas and with the extension .xyz
- PCL cloud point file format, either ASCII or encoded with the extension .pcd.
- (Mandatory): Number of planes to detect: An integer. If the points are exhausted before the planes reach this number the rest will be omitted.
- (Optional): Distance threshold: A double that is used to parameterize the segmentation algorithm. If set too small, all points will be considered in the same plane. It should be set depending on the how close to each other are the points. The smaller the scale the smaller the threshold. Default value is 1.0.
- (Optional): Enable Visualization: A boolean that enables visualization using the PCLVisualizer. When set to true an interactive window appears showing the whole point cloud in 3D space, while the rest of the processing halts. Once the window is terminated, another appears showing the point cloud of the major plane and a vector from the centroid of the plane. This is repeated for all planes detected. Finally a window with the remaining (unclassified) points appears.
- (Mandatory): Input File Path: A file containing the point cloud. Acceptable types:
- Example: pcl_detect_planes.exe ..\cloud3D.xyz 3 0.01 true
When the file is loaded we construct a pcl::PointCloud object and fill it with pcl::PointXYZ type points. Then we use the pcl::SACSegmentation method to segment the cloud into planes. The parameters we use for that is SACMODEL_PLANE model, SAC_RANSAC method, 1000 max iterations, and a variable for the distance threshold. For the provided files roadbed.xyz, urban.xyz and suburban.xyz it was found experimentally that the optimal threshold is 10.0.
This process produces the inlier points, i.e. the points that belong to the major plane within that threshold distance and the coefficients of the plane, in the form ax+by+cz+d=0.
We also calculate the centroid of the plane, so that if visualization is enabled, we draw the normal of the plane from the centroid up to 50 units vertical to the plane.
We then extract the inliers from the cloud and repeat the process with the rest of the cloud, finding the next major plane.
Finally we assign -1 as a plane id of the remaining points (if any) that were not classified in any major plane.