当前位置: 首页 > news >正文

以node / link文件表征的道路网络-----基于南京公路公开数据做路径规划(下)------dijkstra算法的一些简单花样

在不改变dijkstra算法本身的情况下,完全可以从数据源的角度出发,解决我们的一些简单需求:

比较初级且粗暴的玩法,可以是强行赋予一些link极端的路段长度

对于我们坚决不希望车辆行驶的道路、禁行区、或是危险区,就赋予一个无穷大的长度。那么就会有一下两种情况:
①dijkstra算法提供了不经过这些路段的最短路线,成功完成运输任务;
②计算出来的结果是,最短路线长度趋向于无穷大,那么我们就认定为,找不到合适的路线,要不这个时段就换别的交通方式运输吧,或者适当放开一些路段的限制;

对于我们希望车辆采用的路段,那么就适当缩小对应路段的长度,当然这个长度不能为负数,这是dijkstra算法自身的特性决定的。

如果调整的量级足够有“诱惑力”,路线自然就切换到了我们引导的方向上,某些地图软件的各类“猜你喜欢”“大路优先”“高速优先”就是这么来的。

当然,拍脑袋、看心情地调整局部的几个路段长度,只能解决一些临时性封堵、批量修改数据的情况,

如何较为智慧地修改全域的路段“权重”,此处提出一种相对可解释性较好,但是也未见得真的很科学的方法:

下图展示了部分可能影响全域的**路段“权重”**的因素,大致包括“静态”的固有数据和“动态”的运行数据
在这里插入图片描述

经过这样的调整
路网的“物理位置关系”没变,但是“拓扑关系”,或者说在算法中的“两点距离”已经变了
在这里插入图片描述
这样,就在原始层面的dijkstra算法基础上,通过一点点的变化,获得了更贴近我们需求的结果。

http://www.lryc.cn/news/427084.html

相关文章:

  • 计算机操作员中级理论知识试题
  • Redis主从同步配置
  • 输出重定向
  • ubuntu20.04挂载机械硬盘
  • Python轻量级 NoSQL 数据库之tinydb使用详解
  • 【数据结构】二叉树(二)遍历
  • NGINX 常用内置变量
  • Windows采用VS2019实现Open3D的C++应用
  • 冒泡排序、选择排序、插入排序,三种简单排序算法的区别?
  • Docker 日志管理
  • JavaScript初级——基础知识
  • 0817(持久层框架:JDBC,MyBatis)
  • 在亚马逊云科技上安全、合规地创建AI大模型训练基础设施并开发AI应用服务
  • 无人机模拟训练室技术详解
  • 【Spring框架】
  • uniapp 日常业务 随便写写 源码
  • 【软件测试】单元测试20套练习题
  • 8.16 day bug
  • 《Nginx核心技术》第11章:实现MySQL数据库的负载均衡
  • 使用 Gnosis Safe 创建多签名钱包
  • LeetCode 算法:前 K 个高频元素 c++
  • MySQL的SQL语句更新某个字段的值在原来值的基础上随机增加100~600
  • LeetCode --- 410周赛
  • 最佳的iPhone解锁软件和应用程序
  • 初等函数和它的表达式
  • Android 12系统源码_多屏幕(二)模拟辅助设备功能开关实现原理
  • 【Go语言初探】(二)、项目文件结构和GOPATH设置
  • 三种简单排序:插入排序、冒泡排序与选择排序 【算法 05】
  • Python -- GUI图形界面编程—GUI编程实例 博主也在持续学习中[ 持续更新中!!! 欢迎白嫖 也求粉啊啊啊~ ]
  • Vue2和Vue3中的diff算法