当前位置: 首页>>代码示例>>C++>>正文


C++ Searcher::search_k_neighbors方法代码示例

本文整理汇总了C++中Searcher::search_k_neighbors方法的典型用法代码示例。如果您正苦于以下问题:C++ Searcher::search_k_neighbors方法的具体用法?C++ Searcher::search_k_neighbors怎么用?C++ Searcher::search_k_neighbors使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Searcher的用法示例。


在下文中一共展示了Searcher::search_k_neighbors方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: nn_search

void nn_search(Searcher& searcher, double* const nn, double* const dists, const long R, const long N,
				const long dim, const double* p, const double* ref, const long NNR, const mmatrix& past, const double epsilon,
				const int ref_or_direct)
{	
	if (searcher.geterr()) {
		mexErrMsgTxt("Error preparing searcher, maybe wrong preprocessing data were given or the point set has changed");
	}	 
	
	double*	const coord = (double*) malloc(dim * sizeof(double)); 	
	
	for (long n=0; n < R; n++) { /* iterate over all reference points */ 
		vector<neighbor> v;
		
		if (ref_or_direct) {
			const long actual = int(ref[n])-1;		// Matlab to C means indices change from 1 to 0, 2 to 1, 3 to 2
			for (long k=0; k < dim; k++) 
				coord[k] = p[actual+k*N];

			searcher.search_k_neighbors(v, NNR, coord, (long) past(n+1,1)-1, (long) past(n+1,2)-1, epsilon);
		} else {
			for (long k=0; k < dim; k++) 
				coord[k] = ref[n+k*R];

			searcher.search_k_neighbors(v, NNR, coord, (long) past(n+1,1)-1, (long) past(n+1,2)-1, epsilon);
		}	
		
		for (long k = 0; k < v.size(); k++) { 	// v is the sorted vector of neighbors
				nn[n+k*R] = v[k].index() +1;	// convert indices back to Matlab (1..N) style 
				dists[n+k*R] = v[k].dist();
		}
	}
	
	free(coord);
}
开发者ID:Claycau,项目名称:hqn229,代码行数:34,代码来源:nn_search.cpp


注:本文中的Searcher::search_k_neighbors方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。