地图匹配之西雅图数据下载以及导入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

相关文章

Pandas统计每行数据中的空值的方法示例

《Pandas统计每行数据中的空值的方法示例》处理缺失数据(NaN值)是一个非常常见的问题,本文主要介绍了Pandas统计每行数据中的空值的方法示例,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是空值?为什么要统计空值?准备工作创建示例数据统计每行空值数量进一步分析www.chinasem.cn处

如何使用 Python 读取 Excel 数据

《如何使用Python读取Excel数据》:本文主要介绍使用Python读取Excel数据的详细教程,通过pandas和openpyxl,你可以轻松读取Excel文件,并进行各种数据处理操... 目录使用 python 读取 Excel 数据的详细教程1. 安装必要的依赖2. 读取 Excel 文件3. 读

Spring 请求之传递 JSON 数据的操作方法

《Spring请求之传递JSON数据的操作方法》JSON就是一种数据格式,有自己的格式和语法,使用文本表示一个对象或数组的信息,因此JSON本质是字符串,主要负责在不同的语言中数据传递和交换,这... 目录jsON 概念JSON 语法JSON 的语法JSON 的两种结构JSON 字符串和 Java 对象互转

最详细安装 PostgreSQL方法及常见问题解决

《最详细安装PostgreSQL方法及常见问题解决》:本文主要介绍最详细安装PostgreSQL方法及常见问题解决,介绍了在Windows系统上安装PostgreSQL及Linux系统上安装Po... 目录一、在 Windows 系统上安装 PostgreSQL1. 下载 PostgreSQL 安装包2.

Nginx location匹配模式与规则详解

《Nginxlocation匹配模式与规则详解》:本文主要介绍Nginxlocation匹配模式与规则,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、环境二、匹配模式1. 精准模式2. 前缀模式(不继续匹配正则)3. 前缀模式(继续匹配正则)4. 正则模式(大

C++如何通过Qt反射机制实现数据类序列化

《C++如何通过Qt反射机制实现数据类序列化》在C++工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作,所以本文就来聊聊C++如何通过Qt反射机制实现数据类序列化吧... 目录设计预期设计思路代码实现使用方法在 C++ 工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作。由于数据类

SpringBoot使用GZIP压缩反回数据问题

《SpringBoot使用GZIP压缩反回数据问题》:本文主要介绍SpringBoot使用GZIP压缩反回数据问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot使用GZIP压缩反回数据1、初识gzip2、gzip是什么,可以干什么?3、Spr

Java 正则表达式URL 匹配与源码全解析

《Java正则表达式URL匹配与源码全解析》在Web应用开发中,我们经常需要对URL进行格式验证,今天我们结合Java的Pattern和Matcher类,深入理解正则表达式在实际应用中... 目录1.正则表达式分解:2. 添加域名匹配 (2)3. 添加路径和查询参数匹配 (3) 4. 最终优化版本5.设计思

数据库面试必备之MySQL中的乐观锁与悲观锁

《数据库面试必备之MySQL中的乐观锁与悲观锁》:本文主要介绍数据库面试必备之MySQL中乐观锁与悲观锁的相关资料,乐观锁适用于读多写少的场景,通过版本号检查避免冲突,而悲观锁适用于写多读少且对数... 目录一、引言二、乐观锁(一)原理(二)应用场景(三)示例代码三、悲观锁(一)原理(二)应用场景(三)示例

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient