基于FME实现地铁路径规划
在建设智慧城市的背景下,智慧交通、智慧出行等建设在近几年日常生产、生活中占比逐渐加大。
路径规划是智慧交通、智慧出行建设过程当中较重要的专题分类。不管是百度、高德等公共服务平台,亦或是地方政府部门都在大力推动导航发展。路径规划作为数据导航的一部分,主要是让目标对象在规定范围区域内找到一条从起点到终点的无碰撞安全路径。
FME作为一款空间数据分析、转换、处理系统,其核心价值就是支持各类数据交互处理。“路径规划”则是通过数据本身的存储情况,分析出数据最优解。以此,用FME来进行“路径规划”可不就是“与君初相识,犹如故人归”。
以下为大家介绍在FME中如何高效、快捷的搭建模型,实现地铁路径规划。
一、地铁路径规划目的
通过路径分析,找到从起点到终点的最短路径。
二、地铁路径规划成果
提供类百度、高德查询功能,输入起始点名称自动找到最短路径。
如下:
起点:成都高新区理想中心(办公楼)
终点:洪河城市花园(住宅小区)
规划路线:地铁1号线 —> 地铁7号线 —> 地铁2号线
规划站点:高新 —> 火车南站 —> 三瓦窑 —> 琉璃场 —> 四川师大 —> 狮子山 —> 大观 —> 成都东客站 —> 成渝立交 —> 惠王陵 —> 洪河 —> 成都行政学院 —> 大面铺
三、基于FME地铁数据规划流程
1 数据来源
1)地铁站点数据获取
通过“高德地铁”获取地铁数据站点信息
http://map.amap.com/service/subway?_1654480548833&srhdata=5101_drw_chengdu.json
提供数据以JSON格式返回,在FME中通过“HTTPCaller”+“JSONFragmenter”的方式即可从高德地铁接口中提取到地铁站点信息,解析出JSON格式中存储的坐标经纬度信息,并通过“VertexCreator”即可将数据处理为空间点。
2)起终点数据坐标获取
起终点仅提供名称信息。在进行地铁路径分析时,需要知道距离起终点最近的地铁站信息,才可进行地铁路径规划分析。因此,首先需对名称信息进行空间化处理。
起终点数据空间化直接调用高德API数据接口自动实现。
以高德API接口为例:
https://restapi.amap.com/v3/place/text?keywords=XX&page=1&offset=1&output=JSON&key=XX
keywords:起终点名称
key:高德平台许可码
通过“HTTPCaller”获取数据并解析处理得到其空间位置。
2分析起终点与站点的距离
通过邻近分析(“NeighborFinder”),分别获得距离起终点最近的地铁站站点信息。
3 Dijkstra算法获取最近路径
Dijkstra算法具体如何使用网上教程较多,此处不再详细介绍。
给大家提供一个博主链接,大家可以自行学习。
https://blog.csdn.net/lbperfect123/article/details/84281300
1)建立字典数据组
根据Dijkstra算法,首先计算各站点与邻近站点的距离,并构成字典数据组。
地铁站点数据分析后不难发现,有以下3种数据情况:
- 线路起终点
- 线路换乘站
- 除去终点、换乘站外其他站点
且针对于起终点数据仅与其下一站直接相连;换乘站需考虑同时到不同线路;除去终点、换乘站外其他站点与其上一站、下一站直接相连。
根据以上数据关系,通过“AttributeCreator”中“Enable Adjacent Feature Attributes”(邻近数据处理)参数,获取到数据的上一站、下一站、换乘站信息。
最终形成字典数据组。
2)运用Dijkstra算法进行路径分析
将以上步骤获取的起终点地铁站点信息,站点名称、距离字典数据组信息。通过运用Dijkstra算法自动计算出最优路径。
返回从起点到终点的站点信息
4 成果空间化
通过路径规划获取最近路径对应的站点信息,通过站点自动挂机原始空间数据,形成最优线路分布空间成果。
5 坐标转换
为下一步结合2000国家大地坐标系矢量或影像数据,展示规划线路走势情况,将高德平台GCJ-02坐标转换至2000国家大地坐标系。(坐标转换可使用MyFME实现)
6 成果展示
搭建地铁路径规划自动分析模板。仅需输入起终点名称,系统自动处理,获取地铁路径规划最短路线。
列举:
(1)理想中心—>成都IFS国际金融中心
(2)成都IFS国际金融中心—>成都大熊猫繁育研究基地
(3)西南财经大学(柳林校区)—>四川大学(望江校区)
四、思考
通过FME实现地铁路径规划分析,目前处理流程差强人意,以下两方面问题值得思考与优化:
(1)地铁线路为站点连通构成,与实际地铁线路走势情况存在差异,能否获取共享平台实际地铁线路数据作为规划成果输出。
(2)能否按照百度、高德等共享平台路径规划方式,同时考虑“公交+地铁”
基于FME实现地铁路径规划相关推荐
- 2020FME博客大赛——基于FME利用高德路径规划AP实现公共服务设施可达性分析——以厦门山海健康步道为例
作者:郭文义 单位:厦门市环境科学研究院 等时圈(siochrone),指从某点出发,以某种交通方式在特定时间内能到达的距离覆盖的范围(来自于网络).(An isochrones is an isol ...
- 合肥市出行地铁路径规划——基于Dijkstra算法
合肥市出行地铁路径规划--基于Dijkstra算法 1. 引言 2. 导入相应的模块 3. 申请高德地图的API 4. 获取合肥地铁数据 5. 计算合肥各地铁站点之间的距离 6.寻找最近的地铁站 7. ...
- 基于SSD的自动路径规划算法
目录 1.场景需求 2.路径规划算法简介 2.1 .PRM算法简介 2.2.RRT算法简介 3.基于SSD的自动路径规划算法简介 4.基于SSD的自动路径规划算法详解 4.1.利用外置摄像头获取图像或 ...
- 详细介绍用MATLAB实现基于A*算法的路径规划(附完整的代码,代码逐行进行解释)(一)--------A*算法简介和环境的创建
本系列文章主要介绍基于A*算法的路径规划的实现,并使用MATLAB进行仿真演示.本文作为本系列的第一篇文章主要介绍如何进行环境的创建,还有一定要记得读前言!!! 本系列文章链接: ------- ...
- 基于群智能的路径规划算法(三)------遗传算法
本系列文章主要记录学习基于群智能的路径规划算法过程中的一些关键知识点,并按照理解对其进行描述和进行相关思考. 主要学习资料是来自 小黎的Ally 的 <第2期课程-基于群智能的三维路 ...
- 基于群智能的路径规划算法(四)------人工蜂群算法
本系列文章主要记录学习基于群智能的路径规划算法过程中的一些关键知识点,并按照理解对其进行描述和进行相关思考. 主要学习资料是来自 小黎的Ally 的 <第2期课程-基于群智能的三维路 ...
- 基于遗传算法的移动机器人路径规划
之前在网上找基于遗传算法的移动机器人路径规划资料的时候,没有找到理想的开源代码.最后参照论文,用matlab写了代码.最近开了公众号--Joe学习笔记,会不定期更新一些文章,主要是自己平时学到的知 ...
- 基于栅格地图的路径规划(一)基于Matlab二维、三维栅格地图的构建
基于栅格地图的路径规划(一)基于Matlab二维.三维栅格地图的构建 前言 1.二维栅格地图的创建 1.1.二维栅格地图构建原理 1.2.二维栅格地图构建例程 2.三维栅格地图的创建 2.1.三维栅格 ...
- 路径规划算法:基于樽海鞘算法的路径规划算法- 附代码
路径规划算法:基于樽海鞘优化的路径规划算法- 附代码 文章目录 路径规划算法:基于樽海鞘优化的路径规划算法- 附代码 1.算法原理 1.1 环境设定 1.2 约束条件 1.3 适应度函数 2.算法结果 ...
- 路径规划算法:基于蜻蜓算法的路径规划算法- 附代码
路径规划算法:基于蜻蜓优化的路径规划算法- 附代码 文章目录 路径规划算法:基于蜻蜓优化的路径规划算法- 附代码 1.算法原理 1.1 环境设定 1.2 约束条件 1.3 适应度函数 2.算法结果 3 ...
最新文章
- 虚拟机安装ROS的IMG镜像(从U盘启动)
- 索引( index )
- 艾默生变频器报警PHP,艾默生ct变频器报警ou 这个CT的变频器报警UU怎么解决?
- 我理解的invoke和begininvoke
- sql左外连接和右外连接的区别
- 3gpp协议_C-V2X: 3GPP协议阅读前的一些准备
- java 打印ascii字符串_简单使用JAVA打印纯ASCII字符构成的酷图效果
- 第 3 章 MybatisPlus 注入 SQL 原理分析
- 同时买票是怎么实现的_搞笑GIF段子:这位挖掘机司机真的很牛,同时胆子很大...
- UNIX网络编程读书笔记:原始套接口
- python大漠插件多开_[求助,]用python调用大漠插件,注册好后调用出错.完全不会了...
- 思维导图的10种类型有哪些?思维导图结构详解
- 华为业绩发布会:5G产品和供货没有受到“实体清单”影响
- fuzzy仿真 MATLAB,基于MATLAB的FUZZY控制器的设计和仿真
- C语言调试教程总结(以visual studio和Dev C++为例)
- data mining blog (foreign)
- 距阵乘以一个未知距阵得单位矩阵 怎么算_一个人可以 DIY 出什么高逼格的东西?...
- gff文件_gff/gtf格式
- Win7安装.net4.0失败如何解决_离水的鱼_新浪博客
- ORA-01122;ORA-01110;ORA-01207问题解决经验总结