【重新发现PostgreSQL之美】- 27 无中生有

本文涉及的产品
云原生数据库 PolarDB PostgreSQL 版,标准版 2核4GB 50GB
云原生数据库 PolarDB MySQL 版,通用型 2核8GB 50GB
简介: 大家好,这里是重新发现PostgreSQL之美 - 27 无中生有

背景


场景:

•   路径规划: 大型商业综合体, 自动驾驶, 虚拟现实.

•   共享出行(拼车), 配送调度(餐饮、包裹).

•   刑侦: 轨迹相遇分析

                       《重新发现PostgreSQL之美- 11 时空轨迹系统新冠&刑侦&预测》

挑战:

•   传统数据库不支持路网数据, 需要move data到应用端进行计算.

•   现实中轨迹存在缺失点, 当需要分析轨迹相遇事件时, 准确度下降.

•   在共享出行拼单, 包裹和餐饮配送中存在一到多, 多到多的路径规划, 非常复杂传统数据库不支持.

PG 解决方案:

•   支持路网数据存储: 点, 线. 支持道路正、反权重来表示路段通畅度.

•   内置多重路径规划算法, 支持one to one,one to many,many to one,many to many等算法.

 

pgrouting

https://docs.pgrouting.org/latest/en/index.html

https://workshop.pgrouting.org/

数据库路由优点:

•   兼容更多客户端, 都可以修改数据和属性,例如QGIS通过JDBC、ODBC 或直接使用Pl/pgSQL。客户端可以是PC 或移动设备。

•   数据更新后, 全网可见. 无需预先计算。

•   路径规划中的变量: “成本”、“路段” 参数可以通过SQL 动态计算,其值可以来自多个字段或表。

◦                    例如路段施工、路段拥堵都可以实时反馈.

核心功能, pgRouting 库包含以下功能(算法):

•   All Pairs Shortest Path, Johnson’s Algorithm

•   All Pairs Shortest Path, Floyd-Warshall Algorithm

•   Shortest Path A*

•   Bi-directional Dijkstra Shortest Path

•   Bi-directional A* Shortest Path

•   Shortest Path Dijkstra

•   Driving Distance

•   K-Shortest Path, Multiple Alternative Paths

•   K-Dijkstra, One to Many Shortest Path

•   Traveling Sales Person

•   Turn Restriction Shortest Path (TRSP)

 

例子

某个轨迹信息:

point1, ts  

point2, ts  

...  

pointn, ts  

绘图后发现缺失某些点, 出现飞行轨迹, 怎么办?以下是路网情况, cost可以表示为当时的道路通过耗时

pointx1, pointy1, cost, reverse_cost  

pointy1, pointz1, cost, reverse_cost  

...  

point??, point??, cost, reverse_cost  

无中生有:

采用one to one的算法的到缺失路径

https://docs.pgrouting.org/latest/en/pgr_dijkstra.html

pgr_dijkstra(Edges SQL, start_vid,  end_vid [, directed])  

pgr_dijkstra(Edges SQL, start_vid,  end_vids [, directed])  

pgr_dijkstra(Edges SQL, start_vids, end_vid  [, directed])

pgr_dijkstra(Edges SQL, start_vids, end_vids [, directed])  

pgr_dijkstra(Edges SQL, Combinations SQL [, directed]) -- Proposed on v3.1  

RETURNS SET OF (seq, path_seq [, start_vid] [, end_vid], node, edge, cost, agg_cost)  

OR EMPTY SET  

Example

•   From vertex to vertex on a directed graph

SELECT * FROM pgr_dijkstra(  

   'SELECT id, source, target, cost, reverse_cost FROM edge_table',  

   2, 3  

);  

seq | path_seq | node | edge | cost | agg_cost  

-----+----------+------+------+------+----------  

  1 |        1 |    2 |    4 |   1 |        0  

  2 |        2 |   5 |    8 |    1 |       1  

  3 |        3 |   6 |    9 |    1 |       2  

  4 |        4 |   9 |   16 |    1 |       3  

  5 |        5 |   4 |    3 |    1 |       4  

  6 |        6 |   3 |   -1 |    0 |       5  

(6 rows)  

 

参考

https://locatepress.com/pgrouting

https://pgrouting.org/

https://www.openstreetmap.org/#map=4/36.96/104.17

 

 

 



相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
相关文章
|
5月前
|
存储 JSON 关系型数据库
带你走进PostgreSQL的世界
带你走进PostgreSQL的世界
175 0
|
算法 关系型数据库 PostgreSQL
【重新发现PostgreSQL之美】- 22 黄帝内经
大家好,这里是重新发现PostgreSQL之美 - 22 黄帝内经
|
关系型数据库 数据库 PostgreSQL
【重新发现PostgreSQL之美】- 43 快速破镜重圆
大家好,这里是重新发现PostgreSQL之美 - 43 快速破镜重圆
|
JSON 关系型数据库 数据库
【重新发现PostgreSQL之美】- 44 摩斯电码
大家好,这里是重新发现PostgreSQL之美 - 44 摩斯电码
|
传感器 SQL 监控
【重新发现PostgreSQL之美】- 28 旋转门
大家好,这里是重新发现PostgreSQL之美 - 28 旋转门
|
安全 Oracle 关系型数据库
【重新发现PostgreSQL之美】- 36 方世玉 安全第一
大家好,这里是重新发现PostgreSQL之美 - 36 方世玉 安全第一
|
SQL 关系型数据库 数据库
【重新发现PostgreSQL之美】- 50 一粒老鼠屎
大家好,这里是重新发现PostgreSQL之美 - 50 一粒老鼠屎
|
自然语言处理 算法 关系型数据库
【重新发现PostgreSQL之美 】- 30 打蛇打七寸
大家好,这里是重新发现PostgreSQL之美 - 30 打蛇打七寸
|
SQL NoSQL 关系型数据库
【重新发现PostgreSQL之美】- 37 三焦者,决渎之官,水道出焉. FDW
大家好,这里是重新发现PostgreSQL之美 - 37 三焦者,决渎之官,水道出焉. FDW
|
存储 负载均衡 搜索推荐
【重新发现PostgreSQL之美】- 23 彭祖的长寿秘诀
大家好,这里是重新发现PostgreSQL之美 - 23 彭祖的长寿秘诀