12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- #include <boost/program_options.hpp>
- #include <pcl/point_types.h>
- #include <pcl/io/pcd_io.h>
- #include <pcl/common/point_operators.h>
- #include <pcl/common/io.h>
- #include <pcl/search/organized.h>
- #include <pcl/search/octree.h>
- #include <pcl/search/kdtree.h>
- #include <pcl/features/normal_3d_omp.h>
- #include <pcl/filters/conditional_removal.h>
- #include <pcl/segmentation/sac_segmentation.h>
- #include <pcl/segmentation/extract_clusters.h>
- #include <pcl/surface/gp3.h>
- #include <pcl/io/vtk_io.h>
- #include <pcl/filters/voxel_grid.h>
- #include <iostream>
- #include <fstream>
- using namespace pcl;
- using namespace std;
- namespace po = boost::program_options;
- //i=1;for x in ./*.bin; do ./build/bin2pcd --infile $x --outfile ./$i.pcd; let i=i+1; done
- int main(int argc, char **argv){
- ///The file to read from.
- string infile;
- ///The file to output to.
- string outfile;
- // Declare the supported options.
- po::options_description desc("Program options");
- desc.add_options()
- //Options
- ("infile", po::value<string>(&infile)->required(), "the file to read a point cloud from")
- ("outfile", po::value<string>(&outfile)->required(), "the file to write the DoN point cloud & normals to")
- ;
- // Parse the command line
- po::variables_map vm;
- po::store(po::parse_command_line(argc, argv, desc), vm);
- // Print help
- if (vm.count("help"))
- {
- cout << desc << "\n";
- return false;
- }
- // Process options.
- po::notify(vm);
- // load point cloud
- fstream input(infile.c_str(), ios::in | ios::binary);
- if(!input.good()){
- cerr << "Could not read file: " << infile << endl;
- exit(EXIT_FAILURE);
- }
- input.seekg(0, ios::beg);
- pcl::PointCloud<PointXYZI>::Ptr points (new pcl::PointCloud<PointXYZI>);
- int i;
- for (i=0; input.good() && !input.eof(); i++) {
- PointXYZI point;
- input.read((char *) &point.x, 3*sizeof(float));
- input.read((char *) &point.intensity, sizeof(float));
- points->push_back(point);
- std::cout<<" x: "<<point.x<<" y: "<<point.y<<std::endl;
- }
- input.close();
- cout << "Read KTTI point cloud with " << i << " points, writing to " << outfile << endl;
- pcl::PCDWriter writer;
- // Save DoN features
- writer.write<PointXYZI> (outfile, *points, false);
- }
|