MATLAB实现遗传算法优化第三类生产线平衡问题

本文主要是介绍MATLAB实现遗传算法优化第三类生产线平衡问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第三类生产线平衡问题的数学模型

假设

  1. 工作站数量(m)和生产线节拍(CT)是预设并固定的。
  2. 每个任务(或作业元素)只能分配到一个工作站中。
  3. 任务的执行顺序是预先确定的,且不可更改。
  4. 每个任务的作业时间是已知的,且不会因为分配到不同的工作站而改变。
  5. 不考虑工作站之间的物料搬运时间和等待时间。

变量说明

  • n:工序的数量
  • i:工序的索引,i = 1, 2, ..., n
  • t_i:任务 i 的作业时间
  • m:工作站的数量
  • CT:生产线的节拍时间
  • x_{ij}:二进制变量,如果任务 i 被分配到工作站 j,则 x_{ij} = 1;否则,x_{ij} = 0
  • S_{j}:工作站 j 的总作业时间
  • Pr_{ik}:二进制变量,如果工序i是工序j的紧前工序,则Pr_{ik}=1 ;否则,Pr_{ik}=0

目标函数

平衡率(Balance Rate, BR)是评估生产线平衡效果的重要指标,其计算公式为:

\text{Maximize } P=\frac{\sum_{j=1}^{m}S_j}{CT\times m}

 其中,S_j是工作站 j 的总作业时间,计算公式为:

 S_j = \sum_{i=1}^{n} t_i \times x_{ij}

约束条件

(1)每个任务只能分配到一个工作站:

 \sum_{j=1}^{m} x_{ij} = 1, \forall i \in {1, 2, ..., n}

(2)工作站的总作业时间不能超过生产线的节拍时间:

 S_j \leq CT, \forall j \in {1, 2, ..., m}

(3)作业顺序约束(确保任务按照预定的顺序进行):

Pr_{ik}=1, 则

 \sum_{j=1}^{m} j \times x_{ij} \leq \sum_{j=1}^{m} j \times x_{kj}, \forall i, k这个约束确保了任务之间的先后顺序得到遵守。

遗传算法的流程已经有很多了, 我们不再赘述.

下面我们结合一个20个工序的小算例来用MATLAB实现遗传算法优化第三类生产线平衡问题:

紧前关系:

数据:

工序紧前工序工作时间(min)
1020
2110
3223
4024
5420
6622
73、621
8716
9020
10912
11021
12010
1310、11、1214
14810
151311
1614、1523
171621
18015
191725
201910

工作站设定为4, 节拍为95, 求最大化平衡率, 部分MATLAB主程序如下:

程序结果如下:

算法运行时间

runtime1 =

                23.9561303

遗传算法优化得到的最优目标函数值

bestValue_ga =

          1.01149425287356

遗传算法优化得到的最优染色体

bestChrom_ga =

     3     5     6    18     7    16     1     2     9    10    11    12    17     4    14    13    15     8    19    20    95

工作站数量

stationnumber =

     4

节拍

CT =

    88

平滑指数

SI =

          1.22474487139159

平衡率

P =

         0.988636363636364

>> 紧前关系矩阵 premat

premat =

     0     1     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0
     0     0     1     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0
     0     0     0     0     0     0     1     0     0     0     0     0     0     0     0     0     0     0     0     0
     0     0     0     0     1     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0
     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0
     0     0     0     0     0     1     1     0     0     0     0     0     0     0     0     0     0     0     0     0
     0     0     0     0     0     0     0     1     0     0     0     0     0     0     0     0     0     0     0     0
     0     0     0     0     0     0     0     0     0     0     0     0     0     1     0     0     0     0     0     0
     0     0     0     0     0     0     0     0     0     1     0     0     0     0     0     0     0     0     0     0
     0     0     0     0     0     0     0     0     0     0     0     0     1     0     0     0     0     0     0     0
     0     0     0     0     0     0     0     0     0     0     0     0     1     0     0     0     0     0     0     0
     0     0     0     0     0     0     0     0     0     0     0     0     1     0     0     0     0     0     0     0
     0     0     0     0     0     0     0     0     0     0     0     0     0     0     1     0     0     0     0     0
     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     1     0     0     0     0
     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     1     0     0     0     0
     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     1     0     0     0
     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     1     0
     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0
     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     1
     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0     0

>> 

这篇关于MATLAB实现遗传算法优化第三类生产线平衡问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/961848

相关文章

2024 年第四届长三角高校数学建模竞赛赛题B题超详细解题思路+问题一二代码分享

2024年第四届长三角数学建模竞赛B题详细解题思路 赛道B:人工智能范式的物理化学家 长三角分享资料(问题一代码+论文+思路)链接(18点更新):  链接:https://pan.baidu.com/s/1lteKvIWNZ4v-Gd7oOcgO9w  提取码:sxjm  这一题目主要是数据科学和机器学习应用在化学研究上。您需要从提供的大规模数据集中发现规律,构建模型,预测化学物质的物理化学

CogVLM 本地部署体验(问题解决)docker容器版

硬件要求(模型推理): INT4 : RTX30901,显存24GB,内存32GB,系统盘200GB INT4 : RTX40901或RTX3090*2,显存24GB,内存32GB,系统盘200GB 模型微调硬件要求更高。一般不建议个人用户环境使用 如果要运行官方web界面streamlit run composite_demo/main.py 显存需要40G以上,至少需两张RTX3090显卡。

武汉星起航深耕亚马逊跨境,助力合作伙伴实现全球业务增长

在数字化浪潮席卷全球的今天,跨境电商业务蓬勃发展,成为推动国际贸易增长的重要引擎。亚马逊,作为全球最大的电商平台之一,以其独特的平台特点和全球化布局,为卖家和买家提供了便捷、高效的交易环境,成为众多企业进军国际市场的重要舞台。 亚马逊跨境电商业务的成功,离不开其全球化的销售平台。这个平台打破了地域限制,让卖家能够轻松地将商品推向全球市场,实现业务的快速扩张。对于卖家而言,亚马逊不仅是一个销售渠道

代码随想录训练营Day33:完全背包问题2

1.322零钱兑换 与昨天的零钱兑换问题的区别主要不同点在于dp数组的含义,相同点都是属于组合问题。 1.dp数组的含义:dp[j]:代表容量为j时候的最少零钱个数 2.递推公式:dp[j] = min(dp[j],dp[j-coins[i]]+1);dp[j-coins[i]]+1 = dp[j - weight[i]]+value[i],所以还是属于一个变式。因为题目要求的是最小个数,所

【高阶数据结构(四)】图的最短路径问题

💓博主CSDN主页:杭电码农-NEO💓   ⏩专栏分类:高阶数据结构专栏⏪   🚚代码仓库:NEO的学习日记🚚   🌹关注我🫵带你学习更多数据结构   🔝🔝 高阶数据结构 1. 前言2. 单源最短路径问题3. dijkstra算法讲解4. bellman-Ford算法讲解5. 多源最短路径问题6. Floyd-Warshall算法讲解7. 总结

实现一个带有存储状态的Python函数

本文简单的介绍一下,如果通过Python的类来实现一个带有存储状态的Python函数,比如这个函数可以记录自己的调用次数等。 实现的方法主要是通过类的__new__方法来让类在初始化之前就返回一个自定义的内容,也就是函数的执行结果,同时,在__new__方法也可以访问类的存储状态。下面我们看一下代码 class func_with_state:_count = 0def __new__(cls

对于集合中的自定义对象使用collections.sort 进行排序,需要实现compartor接口

/**  * 榜单 业务类  *  * @author seawind  *  */ public class RankService {     // 查看榜单     public List<Orderitem> showRank() {         RankDAO rankDAO = new RankDAO();         List<O

关于大小图片路径的问题; 在javabean 中加上getters

<img src="${product.img_s }"  img-s 是小图片路径;该字段在数据库中不存在;  在使用el 的时候总是报错; 说是空指针异常; 当时我在product 类里面这么写的;     其中img 是我在数据库中存的;   public String getImg_s() {                   String temp = img.su

Android_permission 问题

permission 我在用contentprovider 的时候; 用另外一个单独工程JunitTEst工程来对 contentprovider 进行crud; 但是明明已经配置了 provider 的清单;还是说权限问题; 但是 外界访问content provider 似乎不用权限啊;JunitTEst 的的访问权限都是自己的<?xml version="1.0" encod

Extjs 实现文件上传

弄了N久,终于成功了。 必须设置 <interceptor-ref name="fileUploadStack"></interceptor-ref>   [html] view plain copy <action name="uploadfile"  class="org.lib.main.action.UploadAction">      <interceptor-ref