多维空间搜索算法RTree

好的,现在有这么一个需求:你现在需要开发一个应用,数据库里已经有了全市区所有饭店的经纬度坐标,现在你站在某地定位了你的坐标,如何找出附近的最近的饭店?多维就空间的搜索,用RTree来实现。当然,你如果自己手写计算各点的距离也行,算法效率就不说了。或者,你也可以自己用Java代码实现RTree。这里只推荐可用的JAR包。 

在线API:http://jsi.sourceforge.net/apidocs/index.html   

maven文件,可下载jar包:https://github.com/aled/jsi-examples

最新的代码可以在http://github.com/aled/jsi上找到


根据例子,你就可以完成这个功能了。下面附上自己的low代码。

package net.sf.jsi.examples;

import gnu.trove.procedure.TIntProcedure;
import net.sf.jsi.Point;
import net.sf.jsi.Rectangle;
import net.sf.jsi.SpatialIndex;
import net.sf.jsi.rtree.RTree;

/**
 * Created by Administrator on 2017/5/31.
 */
public class TestRTree {
    private void run() {
        //当前所在坐标
        final Point point = new Point(0, 0);
        //点 矩形
        final Rectangle[] rectangle = new Rectangle[4];
        rectangle[0] = new Rectangle(1, 1, 1, 1);
        rectangle[1] = new Rectangle(0, 1, 0, 1);
        rectangle[2] = new Rectangle(-1, -1, -1, -1);
        rectangle[3] = new Rectangle(-2, -2, -2, -2);
        //将点 矩形依次放入RTree中
        SpatialIndex si = new RTree();
        si.init(null);
        for (int i = 0; i < rectangle.length; i++) {
            si.add(rectangle[i], i);
        }
        //离点最近的3个点 矩形
        si.nearestN(point, new TIntProcedure() {
            public boolean execute(int i) {
                System.out.println("点 矩形" + i + " " + rectangle[i] + ",距离=" + rectangle[i].distance(point));
                return true;
            }
        }, 3, Float.MAX_VALUE);

    }

    public static void main(String[] args) {
        new TestRTree().run();
    }
}



你可能感兴趣的:(JAVA,SE,JAVA,WEB,工具)