得分:_______
南 京 林 业 大 学
研究生课程论文
2011~2012学年 第一学期
课 程 号:
课程名称:
论文题目:
学科专业:
学 号:
73327 Matlab语言
基于遗传算法的车间调度算法 交通运输工程 8113102
姓 名: 闫盖 任课教师: 王一雄
二○一一年十二月
基于遗传算法的车间调度算法
【摘要】车间调度问题具有建模复杂性、计算复杂性、动态多约束、多目标性等特点。近几年,各种演化计算方法逐渐被引入到生产调度中,特别是遗传算法的应用。本文主要介绍了企业车间调度问题的遗传算法实现,通过Matlab实现对遗传算法的编程,其仿真调度结果验证了遗传算法用于求解车间调度问题的可行性和有效性。 【关键词】遗传算法 车间调度 Matlab
Flow-Shop scheduling based on genetic algorithm
Abstract:The Flow-Shop scheduling problem has the property of modeling complexity, computational complexity, dynamic multi-constraint and multi-targeted. In recent years a variety of evolutionary computation methods, in particular, the application of genetic algorithms has been gradually introduced into the production scheduling problem. This paper puts forward a method to design Flow-Shop by using genetic algorithm. Program about genetic algorithm designs by using Matlab, Simulation results of our experiment show the feasibility and effectiveness of genetic algorithm for solving Flow-Shop scheduling. Key words:Genetic algorithm Flow-Shop scheduling Matlab
引言
生产调度对企业的生产作业过程具有重要的作用。有效的调度方法和优化技术是实现先进制造和提高生产效益的基础和关键。研究和解决好调度问题,能极大提高企业的生产效率,从而提高这些企业的竞争力。自从1954年Johnson发表第一篇关于流水车间调度问题的文章以来,流水车间调度问题引起了许多学者的关注,提出了许多解决的方法。其中,以遗传算法、模拟退火、禁忌搜索以及人工神经网络为代表的智能化优化技术迅速发展,用来解决流水车间调度问题,受到人们的普遍关注。遗传算法以其优良的计算性能和显著的应用效果而特别引人注目,很多启发式混合方法都是在此基础上发展起来的。本文采用遗传算法进行求解。
1车间调度问题描述
车间调度是指根据产品制造的合理需求分配加工车间顺序,从而达到合理利用产品制造资源,提高企业经济效益的目的。车间调度问题从数学上可以描述为有n个代加工的零件在m台机器上加工,车间调度的数学模型如下:
(1) 机器集M?{m1,m2,?,mm},mj表示第j台机器,j=1,2,…,m。 (2) 零件集P?{p1,p2,?,pn},pi表示第i个零件,i=1,2,…,n。
(3) 工序序列集OP?{op1,op2,?,opn},opi?{opi1,opi2,?,opik}表示零件pi加工工序序列。
(4) 可选机器集OPM?{opi1,opi2,?,opik},opij?{opij1,opij2,?,opijk}表示零件
pi加工工序j可以选择的加工机器。
(5) 使用机器加工零件的时间矩阵T,tij?T,表示第i个零件pi使用第j个机器的加
工时间。
(6) 使用机器加工零件的费用矩阵C,cij?C,表示第i个零件pi使用第j个机器的加
工费用。 另外,问题需要满足的条件包括每个零件的各道工序使用每台机器不多于1次,每个零件加工都按照一定的顺序进行加工。
2遗传算法的车间调度算法模型建立
基于多层编码遗传算法的车间调度算法流程如下图所示。其中,种群初始化模块初始化种群构成问题的初始解集,适应度值计算模块计算染色体的适用度值,选择操作采用轮盘赌法选择优秀个体;交叉操作采用整数交叉法得到优秀个体,变异操作采用证书变异法得到优秀个体。
N 种群初始化 适应度值计算 选择 操作 交叉 操作 变异 操作 算法是否结束 Y 结束 算法流程图
3模型算法的实现
3.1个体编码
染色体编码方式为证书编码,每个染色体表示全部工件的加工顺序,当待加工的工件总
k数为n,工件ni的加工工序共为mj时,则个体表示为长度为2?nimj的整数串。其中,染
i?1色体的前半部分表示所有工件在机器上的加工顺序,后半部分表示工件每道工序的加工机器序号。如个体
[2 4 3 1 1 2 3 4 2 1 3 3 2 2 1 3]
该个体表达了4个加工工序都是2次的工件在3台机器上的加工顺序。其中,前8位表示工件的加工顺序,为工件2→工件4→工件3→工件1→工件1→工件2→工件3→工件4;9到16位表示加工机器,依次为机器2→机器1→机器3→机器3→机器2→机器2→机器1→机器3。 3.2适应度值
染色体的适应度值为全部工件的完成时间,适应度值计算公式为:fitness(i)?time 其中,time指全部任务完成时间,全部工件完成时间越短,该染色体越好。
3.3选择操作
选择操作采用轮盘赌法选择适应度较好的染色体,个体选择概率为:
npi(i)?Fitness(i)/?Fitness(i);Fitness(i)?1/fitness(i)
i?1其中,pi(i)表示染色体i在每次选择中被选中的概率。 3.4交叉操作
种群通过交叉操作获得新染色体,从而推动整个种群向前进化,交叉操作采用整数交叉
k法。交叉操作首先从种群中随机选取两个染色体,并取出每个染色体的前?nimj位,然后
i?1k随机选择交叉位置进行交叉。操作方法如下:交叉位置为5,只对个体前?nimj位进行交
i?1叉。
个体-[112 3 2 2 3 31112121222] 交叉 [221322331112121222] 极值-[22133121311221 211 1] [11233121311221 211 1] 交叉后某些工件的工序多余(如个体中的工件2),某些工件的工序缺失(如个体中的工件1),因此,把工件工序多余的操作变为工件工序缺失的操作,并按交叉前个体的操作机器来调整
k?k?个体??nimj?1?位到2?nimj位的加工机器,如下所示:
?i?1?i?1交叉后个体-[221322331112121222] 调整 [221312331112221222] 3.5变异操作
种群通过变异操作获得新的个体,从而推动整个种群向前进化。变异算子首先从种群中随机选取变异个体,然后选择变异位置pos1和pos2,最后把个体中pos1和pos2位的加工工序以及对应的加工机器序号对换,如下列示,交叉位置为2和4。
个体-[221322331112121222] 交叉 个体-[231222331112121222]
4Matlab程序实现和仿真结果
采用多层编码遗传算法求解车间调度问题,共有6个工件,在10台机器上加工,每个工件都要经过6道加工工序,每个工序可选择机器序号下表所示。
工序可选机器表
工件 工序1 工序2 工序3 工件1 3,10 1 2 工件2 2 3 5,8 工件3 3,9 4,7 6,8 工件4 4 1,9 3,7 工件5 5 2,7 3,10 工件6 2 4,7 6,9 工序4 工序5 工序6 4,7 6,8 5 6,7 1 4,10 1 2,10 5 2,8 5 6 6,9 1 4,8 1 5,8 3 每道工序加工时间如下表所示。 工序加工时间表
工件 工序1 工序2 工序3 工序4 工序5 工件1 3,5 10 9 5,4 3,3 工件2 6 8 1,4 5,6 3 工件3 1,4 5,7 5,6 5 9,11 工件4 7 4,3 4,6 3,5 1 工件5 6 10,12 7,9 8,8 5 工件6 2 4,7 6,9 1 5,8 工序6 10 3,3 1 3 4,7 3 根据多层编码遗传算法原理,在Matlab中编程实现基于多层编码遗传算法的车间调度算法,首先进行个体初始化,然后采用选择、交叉和变异操作搜索最佳个体,得到最优的车间调度方法,主要代码如下:
[PNumber MNumber]=size(Jm); %PNumber 工件个数、MNumber工序个数 trace=zeros(2, MAXGEN); %寻优结果的初始值 WNumber=PNumber*MNumber; %工序总个数 Number=zeros(1,PNumber); for i=1:PNumber
Number(i)=MNumber; end
Chrom=zeros(NIND,2*WNumber); for j=1:NIND
WPNumberTemp=Number; for i=1:WNumber
val=unidrnd(PNumber);
while WPNumberTemp(val)==0 val=unidrnd(PNumber); end
Chrom(j,i)= val;
WPNumberTemp(val)=WPNumberTemp(val)-1; Temp=Jm{val,MNumber-WPNumberTemp(val)}; SizeTemp=length(Temp);
Chrom(j,i+WNumber)= unidrnd(SizeTemp); end
end
[PVal ObjV P S]=cal(Chrom,JmNumber,T,Jm); %计算目标函数值 while gen