0018算法笔记——【动态规划】流水作业调度问题与Johnson法则.doc

上传人:苏美尔 文档编号:9150078 上传时间:2021-02-04 格式:DOC 页数:10 大小:241KB
返回 下载 相关 举报
0018算法笔记——【动态规划】流水作业调度问题与Johnson法则.doc_第1页
第1页 / 共10页
0018算法笔记——【动态规划】流水作业调度问题与Johnson法则.doc_第2页
第2页 / 共10页
0018算法笔记——【动态规划】流水作业调度问题与Johnson法则.doc_第3页
第3页 / 共10页
0018算法笔记——【动态规划】流水作业调度问题与Johnson法则.doc_第4页
第4页 / 共10页
0018算法笔记——【动态规划】流水作业调度问题与Johnson法则.doc_第5页
第5页 / 共10页
点击查看更多>>
资源描述

《0018算法笔记——【动态规划】流水作业调度问题与Johnson法则.doc》由会员分享,可在线阅读,更多相关《0018算法笔记——【动态规划】流水作业调度问题与Johnson法则.doc(10页珍藏版)》请在三一文库上搜索。

1、1、问题描述:n个作业1,2,n要在由2台机器M1和M2组成的流水线上完成加工。每个作业加工的顺序都是先在M1上加工,然后在M2上加工。M1和M2加工作业i所需的时间分别为ai和bi。流水作业调度问题要求确定这n个作业的最优加工顺序,使得从第一个作业在机器M1上开始加工,到最后一个作业在机器M2上加工完成所需的时间最少。2、问题分析直观上,一个最优调度应使机器M1没有空闲时间,且机器M2的空闲时间最少。在一般情况下,机器M2上会有机器空闲和作业积压2种情况。设全部作业的集合为N=1,2,n。S是N的作业子集。在一般情况下,机器M1开始加工S中作业时,机器M2还在加工其他作业,要等时间t后才可利

2、用。将这种情况下完成S中作业所需的最短时间记为T(S,t)。流水作业调度问题的最优值为T(N,0)。 设是所给n个流水作业的一个最优调度,它所需的加工时间为 a(1)+T。其中T是在机器M2的等待时间为b(1)时,安排作业(2),(n)所需的时间。 记S=N-(1),则有T=T(S,b(1)。 证明:事实上,由T的定义知T=T(S,b(1)。若TT(S,b(1),设是作业集S在机器M2的等待时间为b(1)情况下的一个最优调度。则(1),(2),(n)是N的一个调度,且该调度所需的时间为a(1)+T(S,b(1)a(1)+T。这与是N的最优调度矛盾。故T=T(S,b(1)。从而T=T(S,b(1

3、)。这就证明了流水作业调度问题具有最优子结构的性质。 由流水作业调度问题的最优子结构性质可知:从公式(1)可以看出,该问题类似一个排列问题,求N个作业的最优调度问题,利用其子结构性质,对集合中的每一个作业进行试调度,在所有的试调度中,取其中加工时间最短的作业做为选择方案。将问题规模缩小。公式(2)说明一般情况下,对作业集S进行调度,在M2机器上的等待时间,除了需要等该部件在M1机器上完成时间,还要冲抵一部分原来的等待时间,如果冲抵已成负值,自然仍需等待M1将作业做完,所以公式取maxt-ai,0。3、动态规划法求解思路 假设有一组作业需要在M1和M2 两台机器上进行流水作业,他们在M1和M2上

4、的作业时间如下表:问题是如何安排他们的加工顺序,使得,到最后一个作业在机器M2上加工完成所需要的时间最少。也就是所有作业在两台机器全部加工完成所需的时间最少。思路如下:考虑如果只有一个作业的情况,肯定所需时间就是它自身需要在M1和M2 上的加工时间总和;如果有两个作业就要考虑在两种不同的加工顺序下选取最优的一种作为候选,三个作业的时会出现三种组合情况(0,(1,2); (1,(0,2); (2,(0,1),拿第一种为例,它表示先加工作业0,然后再按照作业1和作业2的优化顺序加工;将三种的作业时间计算出来,取最小值,即为三个作业的优化结果,同理可对更多的作业进行排序优化。具体做法是,用类似矩阵连

5、乘的办法,自底向上将所有能的情况计算出来,并产生一个表,供后面的计算查用,减少重复计算的工作量。对于j1 作业M2 的等待时间为b0,实际上在M2加工j0作业的同时,M1 并行加工j1,实际它需要等待b1-a0时间。2+4+(5-4)+2=9从J0和J1两个作业的加工顺序,可以看出,先加工J0后J1,所用时间最短为9,将其填入表中,依此类推,即可得出最优解。a4+a0+a2+a1+a3+(b4+b0+b1+b2)-(a0+a1+a2+a3)+b3 =1+2+3+4+6+(7+5+2+3)-(2+4+3+6)+1 =16+17-15+1=19选其中加工时间短的作为候选方案;在具体计算时非最优子集

6、不必考虑,这样可以减少计算次数。4、流水作业调度的Johnson法则 设兀是作业集S在机器M2的等待时间为t时的任一最优调度。若在这个调度中,安排在最前面的两个作业分别是i 和j ,即(1)=I,(2)=j。则有动态规划递归式可得 其中如果作业i和j满足minbi,aj minbj,ai,则称作业i和j满足Johnson不等式。如果作业i和j 不满足Johnson不等式,则交换作业i和j满足Johnson不等式。 证明 :在作业集S中,对于机器M2 的等待时间为t的调度,交换作业i和j 的加工顺序,得到作业集S 的另一个调度,它所需的加工时间为 当作业i和j 满足Johnson 不等式 min

7、bi,aj minbj,ai时,有从而由此可得因此,对任意t 有从而,tijtji,由此可见,换句话说,当作业i 和j不满足Johnson 不等式时,交换它们的加工顺序后,作业i和j满足Johnson 不等式,且不增加加工时间。由此可知,对于流水作业调度问题,必存在最优调度,使得作业(i)和(i+1)满足Johnson 不等式:这样的调度称为满足Johnson 法则的调度。进一步还可以证明,调度满足Johnson 法则当且仅当对任意ij 有: 由此可知,任意两个满足Johnson 法则的调度具有相同的加工时间,从而所有满足Johnson 法则的调度均为最优调度。5、流水作业调度问题Johnso

8、n从上面的分析可知,流水作业调度问题一定存在满足Johnson法则的最优调度,且容易由下面的算法确定: 流水作业调度问题的Johnson算法: (1)令N1=i|ai=bi;(2)将N1中作业按ai的非减序排序;将N2中作业按bi的非增序排序; (3)N1中作业接N2中作业构成满足Johnson法则的最优调度。 Johnson算法中分类及排序的作用(验证不等式)设数组c为排序后的作业排列,排序结果如下: 红线左侧满足 aci=bci 和 aci=min(bci+1,aci)其调度顺序最优; 红线右侧满足 bci=bci+1 符合johnson 不等式,min(bci,aci+1)=min(bc

9、i+1,aci)其调度顺序最优; 中间过渡部分横向比较,左侧aci bci 右侧bci+1=min(bci+1,aci)其调度顺序也最优; 程序具体代码如下:cpp1. ey=aibi?bi:ai;ob=ai=bi;ndex=i;2. 3. 4. BubbleSort(d,n);ob)5. 6. cj+=di.index;ndex;/属于N2的从后面进入,从而实现N1的非减序排序,N2的非增序排序7. 8. 9. 10. j=ac0;11. k=j+bc0;12. for(inti=1;in;i+)13. 14. j+=aci;/M1在执行ci作业的同时,M2在执行ci-1号作业,最短执行时间

10、取决于M1与M2谁后执行完15. k=jk?k+bci:j+bci;/计算最优加工时间16. 17. 18. deleted;19. returnk;20. 21. 22. /冒泡排序23. voidBubbleSort(Jobtype*d,intn)24. 25. inti,j,flag;26. Jobtypetemp;27. 28. for(i=0;ii;j-)31. /如果前一个数大于后一个数,则交换32. if(dj=dj-1)33. temp=dj;34. dj=dj-1;35. dj-1=temp;36. flag=1;37. 38. 39. /如果本次排序没有进行一次交换,则break,减少了执行之间。40. if(flag=0)41. break;42. 43. 44. 运行结果如下:

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 科普知识


经营许可证编号:宁ICP备18001539号-1