- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我知道如何构建 kd 树。但是我面临的问题是如何使用 KD 树查找最近邻居。我在 google 上搜索过,但无法找到查找最近邻居的代码,尽管给出了算法。但由于语言的原因,我在将该算法转换为代码时遇到了困难。
您能为我提供可以理解的 Java NNSearch 代码吗?
最佳答案
这是假设目标点未存储在树中的伪代码。 (如果是,只需添加逻辑忽略它):
nearest_point = NULL
nearest_distance = INFINITE;
target_point = <set to the target point>
void nn_search(KD_NODE node) {
FLOAT d = node->point.distance_to(target_point);
if (d < nearest_distance) {
nearest_distance = d;
nearest_point = node->point;
}
BOX left_bb = node->left.bounding_box();
BOX right_bb = node->right.bounding_box();
if (left_bb.contains(target)) {
search_children(node->left, node->right, right_bb);
else { // right_bb must contain target
search_children(node->right, node->left, left_bb);
}
}
void search_children(KD_NODE a, KD_NODE b, BOX b_bb) {
nn_search(a);
// This condition makes the search expected O(log n) time rather than O(n).
// Skip searching the other child unless it might improve the answer.
if (b_bb.contains_point_closer_than(target, nearest_distance)) {
nn_search(b);
}
}
运行后,nearest_point
包含距目标最近的点。请注意,将边界框计算为 nn_search 的参数很简单,而不是像此代码那样将它们存储在节点内。在生产代码中,您需要这样做以节省每个节点 4 个 float 的空间。为了简单起见,我省略了参数。
如果边界框中存在距离目标比给定距离更近的点,则谓词 contains_point_closer_than
返回 true。令人高兴的是,只考虑框中的一点就足够了。例如,如果当前节点在X
处将搜索空间分成左右两半,那么您只需要考虑点(X, Y_target)
及其到目标的距离。这个距离就是 abs(X - X_target)
!我会让你相信这一点,无需进一步讨论
关于java - 使用 KDtree 的最近邻,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41373558/
到 N 点的列表 [(x_1,y_1), (x_2,y_2), ... ] 我试图找到每个点的最近邻居基于距离的点。我的数据集太大,无法使用蛮力方法,因此 KDtree 似乎是最好的。 我看到 skl
我尝试创建一个 WGS84 坐标的 KD 树并在一定半径内找到邻居 from sklearn.neighbors.dist_metrics import DistanceMetric from skl
以下类从 g++ 返回以下错误: tree.h:9: error: expected unqualified-id before 'template' 如果第 5 行没有注释,同样的错误发生,只在第
我有一个经纬度坐标数组,我正在尝试使用 KDTree 和 scipy 的 query_ball_point 返回指定纬度和经度 1 英里半径范围内的所有数据点。 问题是 query_ball_poin
给定一个样本屏蔽数组和一个 KDTree 查询, In [6]: data = np.arange(9).reshape((3,3))*1.0 In [7]: madata = np.ma.array
我正在用 java 实现 KdTree。我已经完成了程序的大部分其余部分,但我似乎无法让我的最近邻搜索算法正常工作。无论如何,它总是返回根节点的值。这是我的代码: public Point2D n
我一直在尝试从头开始实现 KdTree。成功实现添加、查找最近邻居和在范围方法中查找节点后,我现在被困在删除节点上。 维基百科上描述的方法含糊不清,而且毫无用处。相反,我使用 these slides
我知道如何构建 kd 树。但是我面临的问题是如何使用 KD 树查找最近邻居。我在 google 上搜索过,但无法找到查找最近邻居的代码,尽管给出了算法。但由于语言的原因,我在将该算法转换为代码时遇到了
我正在编写一个算法,要求我搜索点的最近邻居。我从这篇文章( Using Google's C KD Tree Library )中找到了 kdtree 库,但它没有从树中删除单个节点的功能。所以我开始
我正在处理一个核心转储问题,但我找不到解决方案。任何形式的帮助将不胜感激,因为我已经绝望了。 我假设在第二次执行构建函数时出现错误,但我不知道有什么大惊小怪的。 http://pastebin.com
例如,看起来我无法在 sklearn KDTree 中使用此相似性度量,但我需要,因为我正在使用测量单词向量相似性。对于这种情况,快速鲁棒定制算法是什么?我了解本地敏感度哈希,但它应该经过大量调整和测
我正在尝试在我的类(class)中使用 nanoflann 的 kdtree 结构。我有以下 kdtree 适配器的 header ,它只是 this 的一个小(可能是坏的)变体。 ,应该允许以 3d
我使用以下示例: from scipy import spatial x, y = np.mgrid[0:5, 2:8] tree = spatial.KDTree(list(zip(x.ravel(
给定点列表,如何在 KDTree 中获取它们的索引? from scipy import spatial import numpy as np #some data x, y = np.mgrid[0
我正在研究 scipy 库中的 KDTree 实现,发现自己对这行 https://github.com/scipy/scipy/blob/master/scipy/spatial/kdtree.py
所以,我正在实现 KD-Tree进行最近邻搜索。我已经开始构建树部分,但我不认为我完全理解搜索部分。 关于遍历树寻找邻居,维基百科文章是这样说的: Starting with the root nod
所以对于一个项目,我已经实现了一个平衡的 KD 树和 k 最近邻搜索算法,作为标准树的“传统”方式——即我有如下的节点结构 struct KDNode{ int level; //used f
我有一个非常大的 ndarray A 和一个排序的点列表 k(一个小列表,大约 30 个点)。 对于 A 的每个元素,我想确定点列表 k 中最近的元素以及索引。所以像这样: >>> A = np.as
我有一个表示道路网络的图形数据结构(节点是道路中的点/交叉点,边缘是道路)。 Node 对象具有与其关联的纬度和经度。 我正在使用 Accord 的 KDTree 类查找给定 GPS 坐标的附近节点。
我目前正在寻找一种方法来构建几个 kd 树以快速查询一些 n 维数据。但是,我在使用 scipy KD 树算法时遇到了一些问题 我的数据由 id -> {data: somedata, coordin
我是一名优秀的程序员,十分优秀!