基于离散的人工蜂群进化的自动导向车辆调度方法

文档序号:28116976发布日期:2021-12-22 14:46阅读:163来源:国知局
基于离散的人工蜂群进化的自动导向车辆调度方法

1.本发明涉及自动导向车辆(agv)调度技术领域,特别是属于一种基于离散的人工蜂群的进化算法以解决矩阵式制造车间的送料和取货问题的调度方法。


背景技术:

2.随着我国社会经济与科技的不断发展,智能制造业得到了广泛的发展。制造过程中的物料以及成品的运输是制造车间生产过程中必不可少的过程,也是车间作业调度问题的重要组成部分。传统的物料配送方式也正在慢慢的向智能化与自动化趋势发展。根据人口统计数据可以推断出,在未来的一段时间,我国的劳动力人口呈现逐年下降的趋势,进而则会导致雇佣劳动力成本增加,这个成本对企业来说是非常大的。所以如何控制劳动力成本增长及如何节省企业生产成本成为企业及国家有待解决的问题之一。
3.为了解决劳动力问题,多数车间的配送作业可由自动化设备进行完成。虽然前期购买自动化设备增加了企业资金投入,但对于后期的整个生产效益必然产生积极影响。生产效率的提高,产品质量得到保证,进而在总体上降低生产成本。总之,“机器人代替人”必将成为我国提高企业生产率,降低人口劳动成本的重要举措。
4.随着智能制造的不断发展,自动导向车辆(agv)以其高度的灵活性、安全性和利用率成为智能矩阵制造车间的主要运输和取货工具之一。agv中的自动导向装置能够使agv按照预定的送料和取货路线完成运输工作。矩阵制造车间的不断扩大和顾客需求的多样化增加,多品种材料、多产品的同时运输变得更加复杂。运输需求给agv调度系统带来了许多新的挑战。提出合理的agv调度方法,提高服务效率,降低服务成本,已成为迫切需要解决的问题。agv调度问题是指在规定的时间内将顾客分配到agv,确定运输顺序,实现调度目标的过程。本发明的目标旨在减少agv运输过程的总成本包括:旅行成本、时间成本agv成本。因此,agv调度问题是一个np

hard问题,同时送货和取货的agv调度问题是一个更加复杂的问题。因此,研究同时送货和取货的agv调度问题无疑对生产企业改造车间物流结构、降低车间物流成本和提升车间物流效率具有重要意义。
5.矩阵制造车间被划分为几个区域,每个区域需要不同的生产材料。每个区域都有一些以矩阵形式排列的工作站。每个工作站由几台数控机床和一个材料缓冲器组成。数控机床通过消耗储存在缓冲器中的材料来生产产品。当消耗的物料或产品库存在缓冲器中达到预定值时,工作站将向agv系统发送信号,提供送货或取货服务。这个工作站叫做顾客工作站。发送信号的时间称为呼叫时间。agv系统收到信号后,根据顾客的需求和agv的数量计算出解决方案,agv开始为顾客服务。从仓库出发的每辆agv都计算旅行费用。agv不能晚于顾客要求的时间到达,否则数控机床会关闭。但是,如果提前服务,就会产生时间成本,而时间成本会根据提前服务的程度而不同。服务完成后agv返回仓库。因此,如何分配agv和配送序列,使出行成本、时间成本和agv成本最小化,是评价服务方案的重要标准。


技术实现要素:

6.本发明的目的即在于提供一种基于离散的人工蜂群进化的自动导向车辆调度方法,以达到提高agv的运输效率以及节省agv的运输成本(agv运输距离成本、agv成本、提前交付的惩罚成本)的目的。
7.本发明所提供的基于离散的人工蜂群进化的自动导向车辆调度方法,其特征在于,包括以下步骤:
8.步骤1:初始参数设置;
9.设定在一个周期内发出信号的机器(顾客)数量;迭代进化的过程中产生的解决方案的数量ps;一个解决方案中的需要的agv数量以及设置算法进化的时间、操作算子的迭代次数;
10.步骤2:解决方案的初始化;
11.(2.1)构建编码方式;
12.(2.2)采用一种基于动态的取货和送料方法分配顾客给agv;
13.(2.3)采用松弛时间的启发式算法产生1个解决方案;
14.(2.4)随机产生ps

1个解决方案,构建初始化种群,计算每个解决方案的总成本,找出种群中最小的总成本;最小总成本对应的初始解决方案为当前最佳解决方案;
15.步骤3:离散的人工蜂群进化;
16.对当前种群中每个解决方案进行离散的人工蜂群进化,包括以下过程:
17.(3.1)雇佣蜂阶段:通过邻域操作算子对每个解决方案进行进化;
18.(3.2)观察蜂阶段:按照中位数轮盘赌概率选择方法从种群中选择多个解决方案,通过邻域操作算子对解决方案进行进化,找出种群中当前最好的解决方案,对最好的解决方案进行局部搜索;
19.(3.3)侦察蜂阶段:对于质量差的解决方案,使用基于问题的搜索算子进行局部搜索,计算总成本,如果总成本未改变,则使用基于松弛时间的启发式算法重新生成一个新的解决方案;
20.步骤4:计算当前所有解决方案中的最佳总成本,更新最佳总成本f
best
及其解决方案,判断进化的时间是否达到迭代循环的时间t,若达到,则进化结束,输出当前最优的解决方案及其对应的总成本,否则回到步骤3。
21.进一步的,在步骤2中,按照以下方法编码:将所有机器进行编号,不同agv的任务之间用0间隔;根据收集到的任务找出距离仓库最近的任务,在满足时间和容量约束的前提下装入agv,判断距离最近的任务是否满足时间和容量约束,满足,则装入agv,不满足,则在编码中添加0,重复上述过程,直到呼叫任务全部装入agv,产生初始可行解,初始化过程结束。
22.进一步的,按照以下公式计算总成本c
sum
,c
sum
=c1+c2+c3,其中c1、c2和c3分别为agv行驶距离成本、agv的成本以及提前到达任务单元的时间惩罚成本,种群中最小的总成本f
best
对应的解决方案为当前最佳解决方案。
23.进一步的,在步骤(2.3)中,基于松弛时间的启发式算法,考虑顾客的紧急程度和顾客之间的距离,依次将顾客插入到agv路线中,直到所有的顾客被分配。
24.进一步的,在计算总成本的过程中设置以下约束:一个周期内被分配的agv能够在
本周期内及时返回仓库,保证下一个周期的正常运行。
25.进一步的,在步骤(3.1)中,在雇佣蜂阶段使用四个邻域操作算子对解决方案进行进化,所述的邻域操作算子通过相同agv交换、相同agv插入、不同agv交换和不同agv插入对每个解决方案进行全局搜索。
26.进一步的,在步骤(3.2)中,所述的基于问题的搜索算子的搜索方法为选择一个顾客插入到解决方案中的所有位置,并找到最佳解决方案,直到所有顾客都被考虑在内。
27.进一步的,邻域操作算子的实现方法如下:
28.相同agv插入方法如下:从当前最佳解决方案中随机选择一辆agv的两个位置p和p’,从位置p’中提取任务j,并将其重新插入任务i所在的位置p中,得到一个新的解决方案;
29.不同agv插入方法如下:从当前最佳解决方案中随机选取两辆agv,随机选取每辆agv中的一个位置,分别为p和p’,将原来的位置p’中提取任务j,并将其重新插入任务i所在的位置p中,得到一个新的解决方案;
30.相同agv交换方法如下:从当前最佳解决方案中随机选择一辆agv,随机选取agv中的两个位置,分别为p和p’,交换任务i在位置p和任务j在位置p’,得到一个新的解决方案;
31.不同agv交换方法如下:从当前最佳解决方案中随机选择两辆agv,随机选取每辆agv路径中的一个位置,分别设p和p’,交换任务i在位置p和任务j在位置p’,得到一个新的解决方案。
32.本发明所提供的基于离散的人工蜂群进化的自动导向车辆调度方法,具有以下积极效果:
33.(1)本发明引入了一种动态计算的送料和取货的方法和一种离散的人工蜂群算法,提高了agv的利用率、生产效率,从节约了运输总成本。
34.(2)本发明克服了算法性能无法充分适应研究问题的缺点,更加容易获得高质量的解决方案。
35.(3)本发明设计了邻域操作算子、基于问题的搜索算子对算法进行优化。
36.(4)本发明在离散的人工蜂群算法中设计了中位数轮盘赌概率选择方法和侦察蜂阶段的重新生成策略来提高解决方案的质量以及避免求得的解决方案陷入局部最优。
附图说明
37.图1为本发明的结构示意图;
38.图2为本发明应用的矩阵制造车间布局图。
具体实施方式
39.如图1

2所示,通过本发明的实现过程的具体描述,对本发明的基于离散的人工蜂群进化的自动导向车辆调度方法做进一步的详细说明。
40.步骤1:初始参数设置;
41.设定在一个周期内发出信号的机器(顾客)数量,本方法在迭代进化的过程中产生的解决方案的数量为ps=50,一个解决方案中的需要的agv数量为m,设置算法进化的时间为t=5s,操作算子的迭代次数为count=30。
42.步骤2:解决方案的初始化;
43.(2.1)在本实例中,为了适应问题的特点,采用一种简单的一维序列表示编码方式。顾客按照服务顺序加入agv,每个agv序列之间插入0来区分。例如:有11个顾客(s1,...s
11
),需要3辆agv(agv1,agv2,agv3)。agv1服务顺序为(s
11
,s6,s5),agv2服务顺序(s1,s8,s
10
,s9,s7,s4),agv3服务顺序(s2,s3),则解可表示为(s
11
,s6,s5,0,s1,s8,s
10
,s9,s7,s4,0,s2,s3)。
44.(2.2)采用一种基于动态的取货和送料方法分配顾客给agv。为了有效降低agv的成本,每台agv须服务尽可能多的顾客。例如:agv满载通过顾客i,顾客i需要有a重量的材料,考虑动态过程,在服务顾客i后,如果顾客j的要求取货的重量小于a,agv在满足约束的前提下可以服务j,即顾客j可以加入到agv路径中。具体地装载计算方法和判断是否满足装载条件的计算公式如下:
45.w(顾客j需要agv取的产品重量)可以表示为:
46.w=n
j
g
υ
47.其中,n
j
表示顾客j的产品数量,υ表示物品的种类,g
υ
表示物品υ的单位重量。
48.在服务顾客i之前,agv中装有的产品重量q
i
:
[0049][0050]
其中,n
i
表示顾客i的产品数量,υ表示物品的种类,g
υ
表示物品υ的单位重量。
[0051]
如果顾客i发出送料信号,物料重量需满足:
[0052]
q

+q
i
≤q
[0053]
其中,υ表示物品的种类,q

表示客户i需要agv运送物品υ的重量,q表示agv的最大载重量。
[0054]
如果顾客i发送取货信号,产品重量需满足:
[0055]
w+q
i
≤q
[0056]
其中,w表示顾客i需要agv取的产品重量,q
i
表示在服务顾客i之前,agv中装有的产品重量,q表示agv的最大载重量。
[0057]
(2.3)采用松弛时间的启发式算法产生1个解决方案,松弛时间的启发式算法的具体设计如下:
[0058]
松弛时间=最晚到达时间

呼叫时间
[0059]
松弛时间在很大程度上反映了顾客的紧迫性,松弛时间越短,优先级越高,被选择的可能性越大。具体方法为:计算并存储每个顾客的松弛时间,选择一个agv作为当前的agv路径,选择松弛时间最短的顾客作为当前顾客,添加到agv路径中,如果满足时间和容量的约束条件,重复地从剩余顾客中选择离当前顾客最近的顾客,将其添加到agv路径中,作为当前顾客;否则,打开一个新的agv,从剩余顾客中重新选择松弛时间最短的顾客作为当前顾客,重复上述过程,直到分配完所有顾客。
[0060]
(2.4)在满足约束条件的前提下,随机产生ps

1个解决方案。
[0061]
在本实例中,共产生ps个解决方案,即初始化种群。计算每个解决方案的总成本。找出种群中最小的总成本f
best
,最小总成本对应的初始解决方案为当前最佳解决方案。按照以下公式计算总成本c
sum
,c
sum=
c1+c2+c3,其中c1、c2和c3分别为agv行驶距离成本、agv的成本以及提前到达任务单元的时间惩罚成本,最佳总成本f
best
即为初始解的总成本。设置算
法的迭代循环的时间为t=5s。
[0062]
步骤3:离散的人工蜂群进化;
[0063]
对当前种群中每个解决方案进行离散的人工蜂群进化,包括以下过程:
[0064]
(3.1)雇佣蜂阶段:将初始种群中的所有解决方案分配给雇佣蜂,然后选择一个随机邻域算子进行开发,记录开发后的总成本,如果低于原有成本,则进行替换,否则,记录解决方案未改变的次数,直到迭代次数满足为止,从而对每个解决方案进行进化,其中,可从4个有效的邻域操作算子(相同agv插入、相同agv交换、不同agv插入、不同agv交换)进行随机选择使用。
[0065]
(3.2)观察蜂阶段:按照中位数轮盘赌概率选择方法从种群中选择多个解决方案,通过邻域操作算子进行进化。此外,通过基于问题的搜索算子搜索当前最优的解决方案,上述基于问题的搜索算子的具体方法为选择一个顾客插入到解决方案中的所有位置,并找到最佳解决方案,直到所有顾客都被考虑在内。
[0066]
(3.3)侦察蜂阶段:在经历了雇佣蜜蜂阶段,观察蜂阶段之后,得到了每个解决方案在进化中未改变的次数。在这个阶段,侦察蜂的角色是丢弃未改变的次数比我们期望值大的解决方案,并产生一个新的解决方案来代替它。具体方法为:对于质量差的解决方案,使用基于问题的搜索算子进行局部搜索,计算总成本,如果总成本未改变,则使用基于松弛时间的启发式算法重新生成一个新的解决方案。
[0067]
步骤4:计算当前所有解决方案中的最佳总成本,更新最佳总成本f
best
及其解决方案,判断进化的时间是否达到迭代循环的时间t,若达到,则进化结束,输出当前最优的解决方案及其对应的总成本,否则回到步骤3。
[0068]
下面,通过本发明的仿真实验,对本发明的应用及其应用效果做进一步的描述说明。选取带有取货和送料的agv调度问题进行测试,仿真实验所采用数据来自某制造企业的实例。仿真实验环境:本发明采用c++语言编程实现,程序运行环境为windows 10操作系统下的i5

6200u cpu、2.30ghz、ram=8gb的笔记本电脑。仿真内容:本发明与其他算法的性能比较。
[0069]
根据一个周期内顾客发送物料需求的情况,统计仓库的所在位置、agv出发时间、载重量和速度、储料缓冲池的库存以及各顾客发出请求的顾客编号、位置、距离仓库的最短距离、发出请求的时间、发出请求时缓冲区库存、agv最晚到达时间。
[0070]
本实例方法适用于一个仓库,多辆同型号agv,求解目标是确定一个最小化总成本的解决方案,总成本包括旅行成本、时间成本和agv成本,以一个周期内收集30个任务为例进行仿真实验。
[0071]
仓库坐标为(0,0),agv出发时间、载重量、速度、卸料用时分别是365s、250kg、1m/s和15s,各cnc单元间的横向和纵向距离分别为5.5m和8.8m。以一个顾客为例,其具体的数据信息:有顾客属性{63,7,3,64.9,307,937,2}。63表示顾客的身份。(7,3)指顾客的位置。64.9m表示距离仓库最近的距离;307s表示送料信号的时间;937s是指最晚的到达时间;2表示材料的类型要求。如果它是一个取货实例,则customer属性为{42,2,45.1,21,621}。42表示顾客的身份。(5,2)指顾客的位置。45.1m为离仓库最近的距离,21s为取货信号发出时间,621s为最迟到达时间。
[0072]
本实验将本发明与迭代贪婪算法(ig)、人工蜂群算法(abc)、混合果蝇优化算法
(hfoa)、离散人工蜂群算法(dabc*)、改进和声搜索算法[46]、混合遗传算法(hga)进行比较。为了使实验更具准确性,我们使用20个实例进行实验,每个实例独立重复运行20次。为了使结果更加明显,本实验使用rpi进行分析,其中,
[0073]
式中c
i
为每个测试实例的第i种算法总成本的最优值,c
best
为每个测试实例的所有比较算法总成本的最小值,rpi越小,结果越好。
[0074]
实验结果下表所示:
[0075][0076][0077]
通过对不同算法的计算结果分析,在比较的20个实例中,本发明使用的方法明显优于其他方法。由此证明本发明的基于离散的人工蜂群进化的自动导向车辆调度方法具有很好的稳定性。从实验结果来看,本发明能够计算出高质量的解决方案,提供出能够有效的解决矩阵制造车间内带有同时取货和送料的agv调度问题的优质解决方案。
[0078]
综上所述,本发明能够解决矩阵制造车间自动引导车辆调度问题,产生一个调度解决方案,使总成本最小化,包括agv行驶距离成本、agv的成本以及提前到达任务单元的时间惩罚成本。提高了agv运输效率,节省了运输总成本。
[0079]
本发明不局限于上述实施例,本发明可根据矩阵车间内呼叫顾客的数量做出相应
的变化。凡依据本发明技术方案的精神实质和原理下做的改变、只要符合本发明的发明目的,只要不背离本发明的技术原理和发明构思,都属于本发明的保护范围。
当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1