车间动态调度的matlab代码,遗传算法在车间调度问题中的应用

本文介绍了如何使用遗传算法解决车间调度问题,详细阐述了MATLAB代码实现过程,包括族群设置、交叉变异操作,并探讨了遗传算法在解决此类问题时面临的挑战和常见改进策略。
摘要由CSDN通过智能技术生成

遗传算法在车间调度问题中应用的matlab源码。

代码简介

典型JOB SHOP调度问题(FT10) :工序编码的遗传算法。

在上面典型JOB SHOP调度问题中,每个工件加工的时候可以选择多台机器加工。 使用工序编码的遗传算法。

典型JOB SHOP调度问题过程简介(工序调度)

1)族群 60,循环500次,交叉0。8 变异 0。6 代沟0。9

2)初始化群:

基于调度优先级的编码方法:每个基因对应一道工序,代表该工序在进行调度操作时的处理优先级。

例如一个3!3问题,则染色体用1-3的整数表示为: [1 3 2 1 1 3 3 2 2]

基因与工序的对应关系如下:

P11  P31  P21  P12  P13  P32 P33  P22 P23

[1   3    2   1   1   3   3  2  2   ]

其中Pij表示第i个零件的第j道工序

3)计算适应值:解码成工序序列,计算时间

P(i)=S(i)*10+temp(S(i));

temp(S(i))=temp(S(i))+1;

4)选择:在原族群中,按轮盘法选择出 60*0。9(代沟)=54个个体组成 新族群。

5)交叉:  对选择出来的新族群进行交叉,在新族群中,随机选择2个个体(选择过的个体将不在选择,保证所有个体都选择),随机生成有一个数,如果大于交叉概率,就进行2点交叉。2点交叉位置每次都是随机的

比如 1、3、2、1、1、3、3、2、2

1、1、3、

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值