for i=1:SH if(s2(i)==1) mt{mm(i)}=mt{mm(i)}+time{s1(i),s2(i),mm(i)};%累计计算每一台机器的加工时间 finish{s1(i),s2(i)}= mt{mm(i)};%改工件当前工序的完成时间是当前机器的累计时间 total=total+time{s1(i),s2(i),mm(i)};%总的机器负载 else if(~com(mt{mm(i)},finish{s1(i),s2(i)-1}))%如果机器最大完成时间小于该工序上一步完成时间 mt{mm(i)}= finish{s1(i),s2(i)-1}+time{s1(i),s2(i),mm(i)};%一定是去上一步完成时间和该机器结束加工时间的最大者 finish{s1(i),s2(i)}= mt{mm(i)}; total=total+time{s1(i),s2(i),mm(i)}; else%如果机器完成时间大于等于该工件上一个工序的完成时间 mt{mm(i)}= mt{mm(i)}+time{s1(i),s2(i),mm(i)}; finish{s1(i),s2(i)}= mt{mm(i)}; total=total+time{s1(i),s2(i),mm(i)}; end end end
时间: 2024-04-27 16:22:08 浏览: 101
I2C TOOLS FOR LINUX
这段代码是一个关于分布式混合流水车间调度问题的MATLAB实现。具体来说,该代码通过累计计算每一台机器的加工时间,更新工件当前工序的完成时间,计算总的机器负载等方式,对车间调度进行求解。
其中,变量SH表示车间中机器数量,s1、s2、mm表示车间中的工件、工序和机器,time表示工件在不同工序和机器上的加工时间,mt、finish表示机器的累计时间和工件当前工序的完成时间。通过对每个工件的加工工序、加工时间、机器设备等因素进行建模,使用离散事件仿真的方式模拟车间生产过程,然后使用遗传算法、模拟退火等优化算法对车间调度进行求解,以达到最优化的生产效果。
总之,该段代码实现了对分布式混合流水车间调度问题的求解,为车间生产提供了科学的决策支持。
阅读全文