点云库PCL学习——kd-tree

本文介绍了在学习PCL库中使用kd-tree进行k近邻搜索和半径内邻居查找时遇到的编译问题及解决方案,包括flann::SearchParams错误、fopen和strcmp的安全警告、VS2017中pcl1.8.1的pop_t问题,以及附加依赖项的清理。通过解决这些问题,成功实现了kd-tree的功能。

如何用kd-tree找到具体点或空间位置的k近邻
或某一半径内的所有近邻;
主要函数有两个:

int nearestKSearch(int index, int k, std::vector<int>&k_indices,std::vector<float> &k_sqr_distances)
参数如下:
pcl::KdTreeFLANN<pcl::PointXYZ>kdtree;//设置搜索空间
kdtree.setInputCloud(cloud);//输入进去
pcl::PointXYZ searchPoint;//查询点            也就是第一个参数index
int K = 10;  //第二个参数
vector<int> pointIdxNKNSearch(K);   //临近点索引  第三个
vector<float> pointNKNSquaredDistance(K); //存储近邻点对应距离平方   第四个

int raiusSearch(int index,double radius, std::vector<int>&k_indices,std::vector<float> &k_sqr_distances);
index:要搜索的查询点
raidus:搜索半径
后两个同上

按照书上的内容写了kd-tree的代码,如下

#include <pcl/point_cloud.h>
#include<pcl/kdtree/kdtree_flann.h>
#include<iostream>
#include<vector>
#include<ctime>

using namespace std;
int main()
{
	srand(time(NULL));
	pcl::PointCloud<pcl::PointXYZ>::Ptr cloud(new pcl::PointCloud<pcl::PointXYZ>);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值