A simple and efficient 3D line detection algorithm for large scale unorganized point cloud. A conference paper based on this code can be found here https://arxiv.org/abs/1901.02532
support to 3 kinds of input point cloud: txt/ply/colmap-ply and 2 kinds of output: obj/txt
./src/LineFromPointCloud <input_file> <output_directory> <input_format: txt/ply/colmap> <output_format: obj/txt/txt_3d/all>
# Example usage for PLY input and OBJ output
./src/LineFromPointCloud input.ply output_directory/ ply obj
# Example usage for TXT input and TXT output
./src/LineFromPointCloud input.txt output_directory/ txt txt
# Example usage for Colmap input and OBJ output
./src/LineFromPointCloud input_colmap.txt output_directory/ colmap obj
- OpenCV > 2.4.x
- OpenMP
- No other libs
- build the project with Cmake
- run the code
- The default parameters are useful for general cases without tunning(at least for these cases in the experiences of the paper). However, you can also adjust the parameters if the result is not very good.
On a computer with Intel Core i5-3550p CPU, the computing time for point clouds with 30M, 20M, 10M, 5M, 2M and 1M points is 130s, 80s, 40s, 20s, 8s and 4s, respectively.
Feel free to correct my code, if you spotted the mistakes. You are also welcomed to Email me: [email protected]
Notice: Basically, this code works well for dense and accurate point clouds, while poor for noisy ones.
Please cite the following paper if this you feel this code helpful.
@article{lu2019fast,
title={Fast 3D Line Segment Detection From Unorganized Point Cloud},
author={Xiaohu, Lu and Yahui, Liu and Kai, Li},
journal={arXiv preprint arXiv:1901.02532},
year={2019},
}