夜光精讲 Opentcs 三大算法(七)路径算法

夜光序言:

 

 

 

生活多么无趣,但一则则无趣的生活编织在一起,才构成了生命的繁华。

 

 

 

 

 

 

 

夜光精讲 Opentcs 三大算法(七)路径算法

 

 

正文:

 

4.哈希表实现
(1)哈希表底层结构体的实现

夜光精讲 Opentcs 三大算法(七)路径算法


(2)哈希表节点类型

夜光精讲 Opentcs 三大算法(七)路径算法

 


(3)哈希表操作方法实现

夜光精讲 Opentcs 三大算法(七)路径算法

(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相当于在此点停留一次。