地图匹配之西雅图数据下载以及导入postgresql+postgis空间数据库

本文主要是介绍地图匹配之西雅图数据下载以及导入postgresql+postgis空间数据库,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

地图匹配之西雅图数据下载以及导入postgresql+postgis空间数据库

    • 1. 下载链接
    • 2.导入数据库

1. 下载链接

Paul Newson and John Krumm两人提出并实现了基于HMM模型的地图匹配算法,并且公开了数据集。论文链接和数据集下来链接如下:
论文:http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.187.5145&rep=rep1&type=pdf
数据集:https://www.microsoft.com/en-us/research/publication/hidden-markov-map-matching-noise-sparseness/
该数据集包含gps轨迹、路网以及真值这三个文件。
gps轨迹:每一行分别是日期,时间,纬度,经度
路网:道路id,上一条路的id,下一条路的id,是否为双向,道路限速,该条路有多少个节点,道路节点的坐标。
真值:真值文件是保存了gps输入哪一条路上id,可能有一段gps轨迹都输入同一段路。

2.导入数据库

提前安装:
postgresql+postgis空间数据库
navicat数据库工具
然后创建数据库,再根据sql命令“create extension postgis;”将postgis引入数据中

2.1 将路网导入空间数据库
将下载下来的路网文件保存为.csv格式的文件,另外我多添加了一列id,方便以后的查看吧,虽然每条道路都有唯一的edgeID了,但不方便查看是第几条道路。
创建路网表

create table if not EXISTS road_network
(id INT,EdgeID BIGINT,Source_ID BIGINT,target_ID BIGINT,Two_Way int,Speed_ms float,Vertex_Count int,LINESTRING geometry
);

然后参考这个网址:
https://blog.csdn.net/yan943789510/article/details/44196317?utm_medium=distribute.pc_relevant.none-task-blog-2defaultbaidujs_title~default-0.essearch_pc_relevant&spm=1001.2101.3001.4242.1

选中新建好的表格road_network->右键->import Wizard…
选择 CSV file(*.csv) 然后点“next”
选择要导入的路网文件,然后下一步,直到下面这一步:
在这里插入图片描述
Source Field是路网文件(.csv)中的列,Target Field是数据库中的路网表,这一步要自己手动选择路网表中的每一列对应存储的内容。确定好之后就下一步,最后一步是现在“start”,然后就开始导入。

这个路网应该是基于wgs84坐标系下的,但是使用st_srid()函数查询发现,导入数据库的路网的srid是0.因此我们需要手动修改他的srid,用如下命令:

UPDATE road_network set linestring = st_setsrid(linestring, 4326);

到这里导入结束。
可以用qgis连接数据库查看这个地图啦。

要是想把gps轨迹和真值也导入数据库,按照上面的方法导入。

这篇关于地图匹配之西雅图数据下载以及导入postgresql+postgis空间数据库的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/406628

相关文章

Python利用GeoPandas打造一个交互式中国地图选择器

《Python利用GeoPandas打造一个交互式中国地图选择器》在数据分析和可视化领域,地图是展示地理信息的强大工具,被将使用Python、wxPython和GeoPandas构建的交互式中国地图行... 目录技术栈概览代码结构分析1. __init__ 方法:初始化与状态管理2. init_ui 方法:

Python实现数据可视化图表生成(适合新手入门)

《Python实现数据可视化图表生成(适合新手入门)》在数据科学和数据分析的新时代,高效、直观的数据可视化工具显得尤为重要,下面:本文主要介绍Python实现数据可视化图表生成的相关资料,文中通过... 目录前言为什么需要数据可视化准备工作基本图表绘制折线图柱状图散点图使用Seaborn创建高级图表箱线图热

MySQL数据脱敏的实现方法

《MySQL数据脱敏的实现方法》本文主要介绍了MySQL数据脱敏的实现方法,包括字符替换、加密等方法,通过工具类和数据库服务整合,确保敏感信息在查询结果中被掩码处理,感兴趣的可以了解一下... 目录一. 数据脱敏的方法二. 字符替换脱敏1. 创建数据脱敏工具类三. 整合到数据库操作1. 创建服务类进行数据库

MySQL中处理数据的并发一致性的实现示例

《MySQL中处理数据的并发一致性的实现示例》在MySQL中处理数据的并发一致性是确保多个用户或应用程序同时访问和修改数据库时,不会导致数据冲突、数据丢失或数据不一致,MySQL通过事务和锁机制来管理... 目录一、事务(Transactions)1. 事务控制语句二、锁(Locks)1. 锁类型2. 锁粒

MybatisPlus中removeById删除数据库未变解决方案

《MybatisPlus中removeById删除数据库未变解决方案》MyBatisPlus中,removeById需实体类标注@TableId注解以识别数据库主键,若字段名不一致,应通过value属... 目录MyBATisPlus中removeBypythonId删除数据库未变removeById(Se

在 Spring Boot 中连接 MySQL 数据库的详细步骤

《在SpringBoot中连接MySQL数据库的详细步骤》本文介绍了SpringBoot连接MySQL数据库的流程,添加依赖、配置连接信息、创建实体类与仓库接口,通过自动配置实现数据库操作,... 目录一、添加依赖二、配置数据库连接三、创建实体类四、创建仓库接口五、创建服务类六、创建控制器七、运行应用程序八

Qt中实现多线程导出数据功能的四种方式小结

《Qt中实现多线程导出数据功能的四种方式小结》在以往的项目开发中,在很多地方用到了多线程,本文将记录下在Qt开发中用到的多线程技术实现方法,以导出指定范围的数字到txt文件为例,展示多线程不同的实现方... 目录前言导出文件的示例工具类QThreadQObject的moveToThread方法实现多线程QC

SpringBoot集成EasyExcel实现百万级别的数据导入导出实践指南

《SpringBoot集成EasyExcel实现百万级别的数据导入导出实践指南》本文将基于开源项目springboot-easyexcel-batch进行解析与扩展,手把手教大家如何在SpringBo... 目录项目结构概览核心依赖百万级导出实战场景核心代码效果百万级导入实战场景监听器和Service(核心

Oracle迁移PostgreSQL隐式类型转换配置指南

《Oracle迁移PostgreSQL隐式类型转换配置指南》Oracle迁移PostgreSQL时因类型差异易引发错误,需通过显式/隐式类型转换、转换关系管理及冲突处理解决,并配合验证测试确保数据一致... 目录一、问题背景二、解决方案1. 显式类型转换2. 隐式转换配置三、维护操作1. 转换关系管理2.

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3