给定纬度和经度的最近道路

Posted

技术标签:

【中文标题】给定纬度和经度的最近道路【英文标题】:Nearest road given latitude & longitude 【发布时间】:2013-09-18 14:27:51 【问题描述】:

我有一个数据库,其中包含英国每条道路的所有航点。

我正在尝试构建一个导航应用程序,给定用户的纬度和经度,它将从数据库中计算最近的道路并显示名称

数据库的 JSON 表示片段

[

    "NAME": "Trinity Road",
    "coordinates": [
        [
            1.7595267,
            52.4778475
        ],
        [
            1.7587864,
            52.4774
        ]
    ]
,

    "NAME": "Wilde Street",
    "coordinates": [
        [
            1.7593497,
            52.4795499
        ],
        [
            1.7594677,
            52.4795041
        ],
        [
            1.7598164,
            52.4793277
        ]
    ]

]

我遇到的问题是正确找到最近的道路。我找不到任何合适的算法,给定一个点会找到最近的路径/线

它不能简单地比较坐标,因为最近的道路可能在 2 个路点之间(排除“最近点对问题”)。

有人能推荐一个合适的算法吗?

我能想到的最佳解决方案是加权网格/矩阵,其中道路的权重取决于它们与用户的接近程度,然后选择用户周围价值最高的道路(但这可能很昂贵)。

我想在不使用 google-maps 等 Web api 或 PostGIS(必须使用 sqlite - 移动应用)的情况下解决这个问题

【问题讨论】:

这个数据库是基于 OpenstreetMap、Ordnance Survey、TomTom 还是诺基亚地图? 现在是免费的,还是在与操作系统的合同中,顺便看看我的答案 【参考方案1】:

您可以使用 r-tree 或四叉树来限制搜索空间,然后使用 voronoi 图来查找最近的道路。然后,您可以使用 2 个或更多道路点来输入 voronoi 图,然后在图中搜索包含该位置的 voronoi 单元格。也许您可以尝试加权 voronoi 图。可以下载我的php类additivley加权voronoi图@https://awvd.codeplex.com/。

【讨论】:

【参考方案2】:

使用四叉树是限制搜索空间的正确方法。对四叉树进行参数化,使其每个四叉节点的行数不超过 100 条。

您不需要(复杂的)voronoi 图。

在四叉树中搜索后,结果将是与四叉节点重叠的行列表。

现在使用 distanceToLineSegment(Point, point0, point1); (在 Internet 上搜索该名称)

走最短距离。

您必须在调用 distanceToLineSegment 之前动态转换点,以便它们位于笛卡尔空间中。使用四边形节点的中心作为变换中心。

【讨论】:

以上是关于给定纬度和经度的最近道路的主要内容,如果未能解决你的问题,请参考以下文章

特定的纬度/经度落在啥“道路”上?美国人口普查形状文件

计算两个经纬度之间的道路距离

在给定经纬度位置的情况下查找最近的街道

在路线中以固定时间间隔确定中间纬度/经度

给定一个纬度/经度,从 c# 中的经度/经度列表中找到最近的经度/经度对

如何使用捕捉到道路的道路 API 请求?