转自基于R-Tree的最近邻查询

BAB(Branch.and.Band)算法是由Nick Roussopoulousnl等人于1995年提出的,是最早的基于R.树的静态最近邻查询算法。该算法使用MINDIST和MINMAXDIST两个距离作为查询过程中的判断条件,对R树进行深度优先

搜索以查找最近邻,适用于基于静态对象的最近邻搜索。BAB思想已经被广泛的应用于人工智能以及运筹学等领域。如果搜索顺序和剪枝的规则选取适当,可以有效的减少系统在大规模空间搜索过程中的结点访问数目。

一、The MBR Face Property

Lemma:Every face of any MBR contains at least one point of an
actual spatial object 如图:

二、距离度量MINDIST和MINMAXDIST

为了减少计算量,文中的距离都以实际欧式距离的平方为标准。

给定一个查询点p及包含在一个MBR中的空间数据对象O,定义两个距离MINDIST和MINMAXDIST作为最近邻的度量和约束。其中:

MINDIST(P,R):  the shortest distance from P to R

MINMAXDIST(P,R):the minimum over all dimensions distance from P  to the furthest point of the closest face of the R

Theorem:

1. Any object O in R has distance from P that is at least as large as MINDIST

2.There exists at least one object within R with distance <= to MINMAXDIST

so:

MINDIST(P,R)  <=  NN(P)  <=  MINMAXDIST(P,R)            (1)

三、MINDIST和MINMAXDIST的计算

    MINDIST:

1.查询点p在R内或R的边界上则MINDIST=0

2.查询点p在R外,若最短距离距离(p到R的边)存在,则MINDIST=p到R的边的最短距离

否则,MINDIST=p到R的顶点的最短最短距离。

MINMAXDIST的计算过程:

1.找出与第k轴垂直的并且离查询点p最近的面,记为H

2.选择从查询点p到面H中距离最远的那个点,记为a

3.计算查询点p到点a的距离,记为dk

4.对每个坐标轴重复步骤1-步骤3,记计算所得距离为d1,d2,...dk

5.从所有计算所得距离中选出最小的那一个,即MINMAXDIST

例如:下图中查询点p在外接矩形R之外,根据上面的计算步骤我们可得:

X轴:找到点(4,8,12)  计算p到此点的距离的平方dx=185

y轴:找到点(13,2,12) 计算p到此点的距离的平方dy=313

z轴:找到点(13,8,4)  计算p到ci点的距离的平方dz=210

所以此例中的MINMAXDIST(p,R)=185

下图表示了二维空间中点P与几个最小包含矩形MBR的MINDIST和MINMAXDIST的一个例子。二维空间中共有四个MBR,点P到它们的MINDIST和MINMAxDIST值在图中用箭头标出。如果点P位于MBR内部MINDIST值为0。

下图表示了三维空间中的MINDIST和MINMAXDIST。

四、减枝策略

由以上讨论,剪枝过程按以下三种策略进行:

1.若一个最小包含矩形E的MINDIST值大于另一个最小包含矩形E’的MINMAXDIST值,则最小包含矩形E内不可能包含最近邻对象。所以E可以被忽略。该策略用于向下剪枝。

2.若查询点q到某对象O的距离值大于点q到最小包含矩形E的MINMAXDIST的值则对象O被丢弃。因为最小包含矩形层此时包含距离查询点口更近的对象O’。该策略用于向上剪枝。

3.若最小包含矩形E的MINDIST值大于查询点g到某对象O的距离,则E被丢弃,因为最小包含矩形E内部不可能包含比对象O更近的对象。该策略用于向上剪枝。

尽管规定在向下剪枝时用MINMAXDIST进行判断,然而在某些情况下使用MINDIST效果会更好。例如当R树的结点中不存在死区或者死区很少时,在R树的某一层上MINDIST相对于MINMAxDIST而言是查询点到最近邻对象实际距离的更好估计。此时使用MINDIST可以剪掉更多无关的候选MBR。

五、Branch and Bound算法

该算法从根结点开始向下访问各层MBR。算法中首先假定最近邻距离Nearest为无穷大。随着搜索的下降,对每个最新访问的非叶结点首先计算出其中所有的MBR的MINDIST值,并将这些值排序后放入活动分支链表ABL(Active
Branch
List)中,接着对ABL运用剪枝策略1和策略2来移除不必要的分支。算法在ABL上重复进行直至ABL为空。每次重复过程中都选择链表中的下一个分支,并在与该分支的MBR相应的结点上递归进行以上过程。对于叶结点算法对每个对象调用一个特定类型的距离函数,并将计算出的值逐个与Nearest比较,选择其中更小的值替换Nearest。在递归过程返回时使用这个新的最近邻距离的估计值作为判断条件,采用策略3剪枝以移除ABL中所有MINDIST值大子Nearest的MBR所在的分支。

算法伪代码:

参考:

Nearest Neighborhood Queries.Nick Roussopoulos等.

http://www.doc88.com/p-146668818114.html

http://zh.scribd.com/doc/73414427/32/Fig-4-4-Example-of-MINDIST-and-MINMAXDIST

最新文章

  1. 解决yum update失败
  2. (转) 如何让 UITableView 的 headerView跟随 cell一起滚动
  3. javascript基础二数据类型
  4. Setup Oracle 11gR2 for Redhat Linux AS 4 Update 7 x64
  5. Centos6 编译安装局域网NTP服务器
  6. WPF Radio组的绑定
  7. 浅谈:配置本地yum源(centos)
  8. 详解Spring中的CharacterEncodingFilter--forceEncoding为true在java代码中设置失效--html设置编码无效
  9. Codeforces Round #364 (Div. 2) E. Connecting Universities (DFS)
  10. JSP处理AJAX
  11. xshell连不上虚拟机
  12. Tinkoff Challenge - Final Round (Codeforces Round #414, rated, Div. 1 + Div. 2)
  13. java连接数据库(jdbc)调用配置文件
  14. sqli-labs(十二)(union以及select的过滤)
  15. django migrate无效的解决方法
  16. springboot实现xml传参和返回值
  17. PKG_CONFIG_PATH变量 与 ld.so.conf 文件
  18. java 定时执行
  19. win10如何安装和创建 证书
  20. [Re:从零开始的分布式] 0.x——分布式基础概念

热门文章

  1. set的应用:UVa10815-Andy's First Dictionary
  2. leetcode刷题——排序
  3. HDU 3045 DP 斜率优化 Picnic Cows
  4. arrive 和reach 的区别
  5. GitHub中国区前100名到底是什么样的人?(转载)
  6. svg path 动画效果
  7. 六 、harbor使用
  8. GT使用说明
  9. Jmeter接口测试-简单分析结果数、聚合报告以及图形结果(二)
  10. xtu数据结构 G. Count the Colors