附近地点搜索初探 百度地图 搜索地点

附近地点搜索,顾名思义,就是搜索用户附近有哪些地点。随着GPS和带有GPS功能的移动设备的普及,附近地点搜索也变得炙手可热。不过在网上却很少有这方面的讨论。本文的方法并不算最好,但足以应付一般的应用了。

本文中,数据库采用MySQL,语言采用python。理论上别的数据库和语言也没问题,但我们要在经纬度上设置两个索引,所以如果你的数据库不支持索引,或者不支持在一个查询中使用两个索引,那就只能想别的办法了。 球面最短距离公式

球面上任意两点之间的距离计算公式可以参考维基百科上的下述文章,这里就不再赘述了。

Great-circle distance

Haversine formula

值得一提的是,维基百科推荐使用Haversine公式,理由是Great-circle distance公式用到了大量余弦函数,而两点间距离很短时(比如地球表面上相距几百米的两点),余弦函数会得出0.999...的结果,会导致较大的舍入误差。而Haversine公式采用了正弦函数,即使距离很小,也能保持足够的有效数字。以前采用三角函数表计算时的确会有这个问题,但经过实际验证,采用计算机来计算时,两个公式的区别不大。稳妥起见,这里还是采用Haversine公式。



其中



R为地球半径,可取平均值 6371km;

φ1, φ2 表示两点的纬度;

Δλ 表示两点经度的差值。

距离计算函数

下面就是计算球面间两点(lat0, lng)-(lat1, lng1)之间距离的函数。

from math import sin, asin, cos, radians, fabs, sqrtEARTH_RADIUS=6371 # 地球平均半径,6371kmdef hav(theta): s = sin(theta / 2) return s * sdef get_distance_hav(lat0, lng0, lat1, lng1): "用haversine公式计算球面两点间的距离。" # 经纬度转换成弧度 lat0 = radians(lat0) lat1 = radians(lat1) lng0 = radians(lng0) lng1 = radians(lng1) dlng = fabs(lng0 - lng1) dlat = fabs(lat0 - lat1) h = hav(dlat) + cos(lat0) * cos(lat1) * hav(dlng) distance = 2 * EARTH_RADIUS * asin(sqrt(h)) return distance范围搜索算法

在庞大的地理数据库中搜索地点,索引是很重要的。但是,我们的需求是搜索附近地点,例如,坐标(39.91, 116.37)附近500米内有什么地点?搜索条件是地点坐标与当前坐标之间的距离,显然是无法应用索引的。

那么换个思路:首先算出“给定坐标附近500米”这个范围的坐标范围。虽然它是个圆,但我们可以先求出该圆的外接正方形,然后拿正方形的经纬度范围去搜索数据库。



如图,红色部分为要求的搜索范围,绿色部分为实际搜索范围。

先来求东西两侧的的范围边界。在haversin公式中令φ1 = φ2,可得



写成python代码就是

dlng = 2 * asin(sin(distance / (2 * EARTH_RADIUS)) / cos(lat))dlng = degrees(dlng) # 弧度转换成角度

然后求南北两侧的范围边界,在haversin公式中令 Δλ = 0,可得



写成python代码就是

dlat = distance / EARTH_RADIUSdlng = degrees(dlat) # 弧度转换成角度

这样,根据当前点坐标,我们可以得出搜索范围为

left-top : (lat + dlat, lng - dlng)right-top : (lat + dlat, lng + dlng)left-bottom : (lat - dlat, lng - dlng)right-bottom: (lat - dlat, lng + dlng)

然后利用这个范围构造SQL语句,即可实现范围查询:

SELECT * FROM place WHERE lat > lat1 AND lat < lat2 AND lng > lng1 AND lng < lng2;

在lat和lng列上建立索引,能从一定程度上提高范围查询的效率。

不过,这样查询到的地点是正方形范围内的地点,一些结果与当前点的距离可能会超出给定的距离。如果要求严格,可以遍历结果并计算与当前点之间的距离,并过滤掉不符合要求的结果。

总结
附近地点搜索初探 百度地图 搜索地点

附近地点搜索条件是距离,而数据库中一般只保存地点的经纬度,因此无法直接查询。本文将距离转化成经纬度范围,利用经纬度上的索引,提高查询效率。

  

爱华网本文地址 » http://www.aihuau.com/a/25101012/116239.html

更多阅读

百度地图附近搜索美食 百度地图定位搜索附近

百度地图附近搜索美食——简介百度手机地图可以根据你的位置,搜索你周边的美食、酒店,你造么?支持手动输入精确搜索哦,附近的美食酒店一网打尽!!!百度地图附近搜索美食——工具/原料百度地图百度地图附近搜索美食——方法/步骤

百度地图怎么看街景 百度街景是实时的吗

百度地图怎么看街景——简介百度地图的街景地图也上线一段时间了,相信很多朋友都体验过了,有了街景地图,确实给我们带来很多不一样的感觉和便捷,可以非常直观的查看到现场的场景,对于找地方非常方便了,而且可以当做欣赏街景哦,也非常不错,今

驾车导航用百度,步行导航诺基亚好 百度地图步行导航方法

用过不少导航软件,比较了一下,推荐百度和诺基亚。百度驾车导航之所以强大,当然是建立在百度强有力的地图上!我想不用我说,电脑上查地图的话,绝大数人必然用百度。相应的,手机上百度地图完全复制了电脑版本,配上功能繁多的导航,查询等,让我们

使用百度地图精准定位经纬度坐标的方法 百度地图经纬度定位

使用百度地图精准定位经纬度坐标的方法——简介如何在百度地图上精确定位自己的地理位置,很多朋友都不是很清楚。 小空在使用百度地图的过程中有一些经验体会,愿与大家分享, 以方便大家可以精确的定位自己地理位置,少走弯路。使用百度

百度地图离线包怎么下载 百度地图离线包手机版

百度地图离线包怎么下载——简介百度地图是百度推出的手机地图应用,力在为用户提供方便的出行贴士,以及周边公共设施。百度地图在联网时需要一定的数据流量,而很多用户手机数据流量非常宝贵,于是离线地图便起到了作用。百度地图离线包

声明:《附近地点搜索初探 百度地图 搜索地点》为网友一棵凋零的草分享!如侵犯到您的合法权益请联系我们删除