夜光精讲 Opentcs 三大算法(七)路径算法
夜光序言:
生活多么无趣,但一则则无趣的生活编织在一起,才构成了生命的繁华。
正文:
4.哈希表实现
(1)哈希表底层结构体的实现
(2)哈希表节点类型
(3)哈希表操作方法实现
(4)时间复杂度和空间复杂度
空间消耗由维护局部更新数据和哈希表产生。假设地图有n个点,那么最多有n*n个需要插入的元索,tableSize大小设为n。
INSERT操作的最坏情况时间为0(1)。
DELETE操作的最坏情况时间为0(n)。
查找不成功的SEARCH操作的平均运行时间为0(n),最坏情况时间为0(n)。
查找成功的SEARCH操作的平均运行时间为0((n+U/2),最坏情况时间为0(n)。
哈希表存储有较明显的优势:
a.访问速度快,存储大小可拓展。
b.省去每次新路径读入时,都要重新计算窗口中相同起点终点出现次数的比较,提高算法的效率。保证输出结果有较小的延时。
C.记录维护各自的hash表。(分区域仓库中毎个map/area都有自己的哈希表;整个仓库有拓扑哈希表。这样利于维护,只需要更新局部数据)
评估函数和性能指标的确定
该系统的路径解决方案设定一下以下评估指标:
1.距离Distance:小车行驶的路径长度;
2.转弯数目Tur ns:尽量避免小车的转弯,从而提高运行速度和效率;
3.运行时间TravelTime:区分"距离"指标,对于相同长度的两条边,可能预设的限速值不同,从而经过两条边的用时也不同;
4.跳数Hops:一条路径上经历的点或区域地图块的数目越多,就需要AGV进行更多的坐标扫描定位和位置信息上报通信,甚至需要AGV乘坐电梯进行跨区域任务,因此应尽量减少跳数,提高运作效率。
【沉下心来,好好研究】
函数实现和调用流程
给定要寻找的路的起始点和终止点(Point A->PointB)
1)首先要调用isRou table()判断此两点之间是否可达(可通行)
2)调用getCost()函数计算给定路径的花费,
3)毎走一步,需要判定未经过的点是否可以通行(不能通行要上报,重新指派)
需要注意,当起始点和目标点是同一点时,返回的路径不为空(NULL),将此点放入路径链路表中,因此AGV相当于在此点停留一次。