百度地图的搜索路线是怎么计算出来的呢,好高级啊!
在百度地图上面选一个起点,选一个终点,就能自动帮我们计算规划路线,那么多路线,可以说是无限的路线,这些路线不可能是百度地图的人提前录入的吧,那么它是怎么计算出来的路线呢?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
在百度地图上面选一个起点,选一个终点,就能自动帮我们计算规划路线,那么多路线,可以说是无限的路线,这些路线不可能是百度地图的人提前录入的吧,那么它是怎么计算出来的路线呢?
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
接受
或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
发布评论
评论(2)
哈哈,问题很可爱。
路径检索服务器中,保存了全国采集到的路网数据,这些数据是人工开车采集的,比如我的老东家高德有4000多人的数据采集和加工团队。
道路的数据的存储结构就是加权图,权值是根据距离等因素计算的一个数值,当你将你的起点终点请求算路时候,服务器要做的就是进行图的最小权值路径检索,当然现代的算路算法有不同的权值,可以同时算出多条路线:
路程最短
,时间最快
,不走高速
等等。如果好奇算路算法,可以去搜一下A*(A星)算法。这个算法是个基础算法,其他大部分算法都是A*的改良型。
当然,服务器应该也会对热门和高频率算路结果进行多级缓存,减小计算压力(这个是我猜的)。
祝你好运。
A*启发式搜索算法
虽说有无限的路径,但其中很大一部分都是无用的。可以设置一个估值函数,当某一路线的估值大于一个阈值时,立刻退出。