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

相关文章

springboot下载接口限速功能实现

《springboot下载接口限速功能实现》通过Redis统计并发数动态调整每个用户带宽,核心逻辑为每秒读取并发送限定数据量,防止单用户占用过多资源,确保整体下载均衡且高效,本文给大家介绍spring... 目录 一、整体目标 二、涉及的主要类/方法✅ 三、核心流程图解(简化) 四、关键代码详解1️⃣ 设置

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求

springboot项目中整合高德地图的实践

《springboot项目中整合高德地图的实践》:本文主要介绍springboot项目中整合高德地图的实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一:高德开放平台的使用二:创建数据库(我是用的是mysql)三:Springboot所需的依赖(根据你的需求再

PostgreSQL 默认隔离级别的设置

《PostgreSQL默认隔离级别的设置》PostgreSQL的默认事务隔离级别是读已提交,这是其事务处理系统的基础行为模式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一 默认隔离级别概述1.1 默认设置1.2 各版本一致性二 读已提交的特性2.1 行为特征2.2

PostgreSQL中MVCC 机制的实现

《PostgreSQL中MVCC机制的实现》本文主要介绍了PostgreSQL中MVCC机制的实现,通过多版本数据存储、快照隔离和事务ID管理实现高并发读写,具有一定的参考价值,感兴趣的可以了解一下... 目录一 MVCC 基本原理python1.1 MVCC 核心概念1.2 与传统锁机制对比二 Postg

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

Python pip下载包及所有依赖到指定文件夹的步骤说明

《Pythonpip下载包及所有依赖到指定文件夹的步骤说明》为了方便开发和部署,我们常常需要将Python项目所依赖的第三方包导出到本地文件夹中,:本文主要介绍Pythonpip下载包及所有依... 目录步骤说明命令格式示例参数说明离线安装方法注意事项总结要使用pip下载包及其所有依赖到指定文件夹,请按照以

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

使用SpringBoot整合Sharding Sphere实现数据脱敏的示例

《使用SpringBoot整合ShardingSphere实现数据脱敏的示例》ApacheShardingSphere数据脱敏模块,通过SQL拦截与改写实现敏感信息加密存储,解决手动处理繁琐及系统改... 目录痛点一:痛点二:脱敏配置Quick Start——Spring 显示配置:1.引入依赖2.创建脱敏