一、获取代码方式

获取代码方式1:
完整代码已上传我的资源:【车间调度】基于matlab遗传算法求解柔性车间调度问题【含Matlab源码 660期】

获取代码方式2:
通过订阅紫极神光博客付费专栏,凭支付凭证,私信博主,可获得此代码。

备注:
订阅紫极神光博客付费专栏,可免费获得1份代码(有效期为订阅日起,三天内有效);

二、车间调度简介

1 车间调度定义
车间调度是指根据产品制造的合理需求分配加工车间顺序,从而达到合理利用产品制造资源、提高企业经济效益的目的。车间调度问题从数学上可以描述为有n个待加工的零件要在m台机器上加工。问题需要满足的条件包括每个零件的各道工序使用每台机器不多于1次,每个零件都按照一定的顺序进行加工。

2 传统作业车间调度
传统作业车间带调度实例

有若干工件,每个工件有若干工序,有多个加工机器,但是每道工序只能在一台机器上加工。对应到上面表格中的实例就是,两个工件,工件J1有三道工序,工序Q11只能在M3上加工,加工时间是5小时。
约束是对于一个工件来说,工序的相对顺序不能变。O11->O12->O13。每时刻,每个工件只能在一台机器上加工;每个机器上只能有一个工件。
调度的任务则是安排出工序的加工顺序,加工顺序确定了,因为每道工序只有一台机器可用,加工的机器也就确定了。
调度的目的是总的完工时间最短(也可以是其他目标)。举个例子,比如确定了O21->O22->O11->O23->O12->O13的加工顺序之后,我们就可以根据加工机器的约束,计算出总的加工时间。
M2加工O21消耗6小时,工件J2当前加工时间6小时。
M1加工O22消耗9小时,工件J2当前加工时间6+9=15小时。
M3加工O11消耗5小时,工件J1当前加工时间5小时。
M4加工O23消耗7小时,工件J2加工时间15+7=22小时。
M1加工O12消耗11小时,但是要等M1加工完O22之后才开始加工O12,所以工件J1的当前加工时间为max(5,9)+11=20小时。
M5加工O13消耗8小时,工件J2加工时间20+8=28小时。
总的完工时间就是max(22,28)=28小时。

2 柔性作业车间调度
柔性作业车间带调度实例(参考自高亮老师论文
《改进遗传算法求解柔性作业车间调度问题》——机械工程学报)

相比于传统作业车间调度,柔性作业车间调度放宽了对加工机器的约束,更符合现实生产情况,每个工序可选加工机器变成了多个,可以由多个加工机器中的一个加工。比如上表中的实例,J1的O12工序可以选择M2和M4加工,加工时间分别是8小时和4小时,但是并不一定选择M4加工,最后得出来的总的完工时间就更短,所以,需要调度算法求解优化。

相比于传统作业车间,柔性车间作业调度的调度任务不仅要确定工序的加工顺序,而且需要确定每道工序的机器分配。比如,确定了O21->O22->O11->O23->O12->O13的加工顺序,我们并不能相应工序的加工机器,所以还应该确定对应的[M1、M3、M5]->[M1、M2、M3]->[M1、M2、M3、M4、M5]->[M2、M3、M4、M5]->[M2、M4]->[M1、M3、M4、M5]的机器组合。调度的目的还是总的完工时间最短(也可以是其他目标,比如机器最大负荷最短、总的机器负荷最短)

三、遗传算法简介

1 遗传算法概述
遗传算法(Genetic Algorithm,GA)是进化计算的一部分,是模拟达尔文的遗传选择和自然淘汰的生物进化过程的计算模型,是一种通过模拟自然进化过程搜索最优解的方法。该算法简单、通用,鲁棒性强,适于并行处理。

2 遗传算法的特点和应用
遗传算法是一类可用于复杂系统优化的具有鲁棒性的搜索算法,与传统的优化算法相比,具有以下特点:
(1)以决策变量的编码作为运算对象。传统的优化算法往往直接利用决策变量的实际值本身来进行优化计算,但遗传算法是使用决策变量的某种形式的编码作为运算对象。这种对决策变量的编码处理方式,使得我们在优化计算中可借鉴生物学中染色体和基因等概念,可以模仿自然界中生物的遗传和进化激励,也可以很方便地应用遗传操作算子。
(2)直接以适应度作为搜索信息。传统的优化算法不仅需要利用目标函数值,而且搜索过程往往受目标函数的连续性约束,有可能还需要满足“目标函数的导数必须存在”的要求以确定搜索方向。遗传算法仅使用由目标函数值变换来的适应度函数值就可确定进一步的搜索范围,无需目标函数的导数值等其他辅助信息。直接利用目标函数值或个体适应度值也可以将搜索范围集中到适应度较高部分的搜索空间中,从而提高搜索效率。
(3)使用多个点的搜索信息,具有隐含并行性。传统的优化算法往往是从解空间的一个初始点开始最优解的迭代搜索过程。单个点所提供的搜索信息不多,所以搜索效率不高,还有可能陷入局部最优解而停滞;遗传算法从由很多个体组成的初始种群开始最优解的搜索过程,而不是从单个个体开始搜索。对初始群体进行的、选择、交叉、变异等运算,产生出新一代群体,其中包括了许多群体信息。这些信息可以避免搜索一些不必要的点,从而避免陷入局部最优,逐步逼近全局最优解。
(4) 使用概率搜索而非确定性规则。传统的优化算法往往使用确定性的搜索方法,一个搜索点到另一个搜索点的转移有确定的转移方向和转移关系,这种确定性可能使得搜索达不到最优店,限制了算法的应用范围。遗传算法是一种自适应搜索技术,其选择、交叉、变异等运算都是以一种概率方式进行的,增加了搜索过程的灵活性,而且能以较大概率收敛于最优解,具有较好的全局优化求解能力。但,交叉概率、变异概率等参数也会影响算法的搜索结果和搜索效率,所以如何选择遗传算法的参数在其应用中是一个比较重要的问题。
综上,由于遗传算法的整体搜索策略和优化搜索方式在计算时不依赖于梯度信息或其他辅助知识,只需要求解影响搜索方向的目标函数和相应的适应度函数,所以遗传算法提供了一种求解复杂系统问题的通用框架。它不依赖于问题的具体领域,对问题的种类有很强的鲁棒性,所以广泛应用于各种领域,包括:函数优化、组合优化生产调度问题、自动控制
、机器人学、图像处理(图像恢复、图像边缘特征提取…)、人工生命、遗传编程、机器学习。

3 遗传算法的基本流程及实现技术
基本遗传算法(Simple Genetic Algorithms,SGA)只使用选择算子、交叉算子和变异算子这三种遗传算子,进化过程简单,是其他遗传算法的基础。

3.1 遗传算法的基本流程
通过随机方式产生若干由确定长度(长度与待求解问题的精度有关)编码的初始群体;
通过适应度函数对每个个体进行评价,选择适应度值高的个体参与遗传操作,适应度低的个体被淘汰;
经遗传操作(复制、交叉、变异)的个体集合形成新一代种群,直到满足停止准则(进化代数GEN>=?);
将后代中变现最好的个体作为遗传算法的执行结果。

其中,GEN是当前代数;M是种群规模,i代表种群数量。

3.2 遗传算法的实现技术
基本遗传算法(SGA)由编码、适应度函数、遗传算子(选择、交叉、变异)及运行参数组成。
3.2.1 编码
(1)二进制编码
二进制编码的字符串长度与问题所求解的精度有关。需要保证所求解空间内的每一个个体都可以被编码。
优点:编、解码操作简单,遗传、交叉便于实现
缺点:长度大
(2)其他编码方法
格雷码、浮点数编码、符号编码、多参数编码等
3.2.2 适应度函数
适应度函数要有效反映每一个染色体与问题的最优解染色体之间的差距。
3.2.3选择算子

3.2.4 交叉算子
交叉运算是指对两个相互配对的染色体按某种方式相互交换其部分基因,从而形成两个新的个体;交叉运算是遗传算法区别于其他进化算法的重要特征,是产生新个体的主要方法。在交叉之前需要将群体中的个体进行配对,一般采取随机配对原则。
常用的交叉方式:
单点交叉
双点交叉(多点交叉,交叉点数越多,个体的结构被破坏的可能性越大,一般不采用多点交叉的方式)
均匀交叉
算术交叉
3.2.5 变异算子
遗传算法中的变异运算是指将个体染色体编码串中的某些基因座上的基因值用该基因座的其他等位基因来替换,从而形成一个新的个体。

就遗传算法运算过程中产生新个体的能力方面来说,交叉运算是产生新个体的主要方法,它决定了遗传算法的全局搜索能力;而变异运算只是产生新个体的辅助方法,但也是必不可少的一个运算步骤,它决定了遗传算法的局部搜索能力。交叉算子与变异算子的共同配合完成了其对搜索空间的全局搜索和局部搜索,从而使遗传算法能以良好的搜索性能完成最优化问题的寻优过程。

3.2.6 运行参数

4 遗传算法的基本原理
4.1 模式定理


4.2 积木块假设
具有低阶、定义长度短,且适应度值高于群体平均适应度值的模式称为基因块或积木块。
积木块假设:个体的基因块通过选择、交叉、变异等遗传算子的作用,能够相互拼接在一起,形成适应度更高的个体编码串。
积木块假设说明了用遗传算法求解各类问题的基本思想,即通过积木块直接相互拼接在一起能够产生更好的解。

四、部分源代码

function [Chromosome] = POX_GA(T,Iterations,PopSize,Pc,Pm)
%% INPUT:
%T--input matrix:
%  For example:
%  A partial flexible scheduling problem in which 8 jobs are processed
%  on 8 machines, in which the number of available machining machines per
%  step of job is less than or equal to the total number of machines
% J1 ={[5 3 5 3 3 0 10 9];[10 0 5 8 3 9 9 6];[0 10 0 5 6 2 4 5]};
% J2 ={[5 7 3 9 8 0 9 0];[0 8 5 2 6 7 10 9];[0 10 0 5 6 4 1 7];[10 8 9 6 4 7 0 0]};
% J3 ={[10 0 0 7 6 5 2 4];[0 10 6 4 8 9 10 0];[1 4 5 6 0 10 0 7]};
% J4 ={[3 1 6 5 9 7 8 4];[12 11 7 8 10 5 6 9];[4 6 2 10 3 9 5 7]};
% J5 ={[3 6 7 8 9 0 10 0];[10 0 7 4 9 8 6 0];[0 9 8 7 4 2 7 0];[11 9 0 6 7 5 3 6]};
% J6 ={[6 7 1 4 6 9 0 10];[11 0 9 9 9 7 6 4];[10 5 9 10 11 0 10 0]};
% J7 ={[5 4 2 6 7 0 10 0];[0 9 0 9 11 9 10 5];[0 8 9 3 8 6 0 10]};
% J8 ={[2 8 5 9 0 4 0 10];[7 4 7 8 9 0 10 0];[9 9 0 8 5 6 7 1];[9 0 3 7 1 5 8 0]};
%T={J1;J2;J3;J4;J5;J6;J7;J8}; 8*1 cell
%Iterations--The number of iterations of the genetic algorithm;
%PopSize--Population size in genetic algorithms,2*PopSize+1
%Pc--probability of crossover
%Pm--probability of mutation
%% OUTPUT
% Chromosome--The best Chromosome of the genetic algorithm
%% variable declaration
num_of_jobs = length(T);                                                   %number of jobs
num_of_machines = length(T{1}{1});                                         %number of machines
steps_of_job =[];
for i = 1:num_of_jobssteps_of_job=[steps_of_job;length(T{i})];
end
len_of_chromosome = sum(steps_of_job);
PopSize = PopSize+1;Performance1 =[];
machine_of_job=cell(num_of_jobs,1);
% calculate the machine set for each steps of each job
for i=1:num_of_jobssteps=cell(steps_of_job(i),1);for j = 1:steps_of_job(i)machineset=[];for k=1:length(T{i}{j})if T{i}{j}(k)~=0machineset=[machineset k]; endendsteps{j}=machineset;endmachine_of_job{i}=steps;
enddisp('begin interating ...')
%% Coding
[Population] = Coding(T,PopSize);%% Population iteration
FITNESS = zeros(PopSize,1);    % fitness values for population
for iterator = 1:Iterations%% fitness calculationfor index=1:PopSize                         chromosome=Population{index};                                     % choose one chromosome from population[FitnessValue] = FitnessCalculator(T,chromosome);                  % fitness calculation                            FITNESS(index)=FitnessValue;                                       % the larger the Pfit_valueendBestFitness=min(FITNESS);                                              % find the best chromosomeposition=find(FITNESS==BestFitness);                                   % and the position,may be more than oneBestChromosome=Population{position(1)};                                % choose one chromosome from population%% Selection :Elitism and 2-tournament selection are usedParent = cell(PopSize,1);Pr =0.8;for index =1:PopSize-1pos = randperm(PopSize,2);chromosome1 = Population{pos(1)};chromosome2 = Population{pos(2)};if (rand(1)<Pr) && FITNESS(pos(1))>FITNESS(pos(2))chromosome = chromosome1;elsechromosome = chromosome2;endParent{index} = chromosome;endParent{PopSize}=BestChromosome;                                         %% Crossover: IPOX for steps, MPX for machine Children_group1=cell(PopSize,1);for i=1:(PopSize-1)%Parent individuals are selected for crossover operation:%Parent1 is selected sequentially and Parent2 is selected randomly.index_parent2 = randi([1,(PopSize-1)]);Parent1=Parent{i};Parent2=Parent{index_parent2};Children1=zeros(2,len_of_chromosome);Children2=zeros(2,len_of_chromosome);if rand(1)<=Pc %Use the probability to determine if crossover is required%% Part1: IPX for step%Randomly divide the set of jobs {1,2,3...,n} into two non-empty sub-sets J1 and J2.num_J1 = randi([1,num_of_jobs]);   if num_J1==num_of_jobsnum_J1 = fix(num_of_jobs/2);  endJ = randperm(num_of_jobs);          J1 =J(1:num_J1);J2 =J(num_J1+1:num_of_jobs); % Copy the jobs that Parent1 contains in J1 to Children1, % and Parent2 contains in J2 to Children2, and keep them in place.for index = 1:num_J1                                            % look for jobs that Parent1 are included in J1job = J1(index);for j = 1:len_of_chromosomeif job == Parent1(1,j)Children1(1,j)=Parent1(1,j);end end   endfor index = 1:num_of_jobs-num_J1                                % look for jobs that Parent2 are included in J2job = J2(index);for j = 1:len_of_chromosomeif job == Parent2(1,j)Children2(1,j)=Parent2(1,j);end end   end           %Copy the jobs that Parent1 contains in J1 to Children2, %and Parent2 contains in J2 to Children1 in their order.for index = 1:len_of_chromosome                                            % look for jobs that Parent1 are included in J1job = Parent1(1,index);if ~isempty(find(J1==job, 1))for gene = 1:len_of_chromosomeif Children2(1,gene)==0Children2(1,gene)=job;break;endendendendfor index = 1:len_of_chromosome                                            % look for jobs that Parent1 are included in J1job = Parent2(1,index);if ~isempty(find(J2==job, 1))for gene = 1:len_of_chromosomeif Children1(1,gene)==0Children1(1,gene)=job;break;endendendend%%IPOX cross operation completed%% Part 2 MPX for machine %The process of crossover operation is as follows: firstly, a set rand0_1 %composed of 0 and 1 that is equal to the length of chromosome is randomly %generated, and then the genes at the same position of 1 in the set of rand0_1%in the two parental generations are interchanged, and two offspring are%obtained after the crossoverrand0_1 = zeros(1,len_of_chromosome);for gene = 1:len_of_chromosomeif rand(1)>0.5rand0_1(gene)=1;endendfor gene = 1:len_of_chromosomeif rand0_1(gene)==1Children1(2,gene) = Parent2(2,gene);Children2(2,gene) = Parent1(2,gene);elseChildren1(2,gene) = Parent1(2,gene);Children2(2,gene) = Parent2(2,gene);                   endend    %MOX cross operation completedelse  Children1 = Parent1;Children2 = Parent2;  end%% Select the Fitness value best retained to the next generation[Parent1_FitnessValue] = FitnessCalculator(T,Parent1);[Parent2_FitnessValue] = FitnessCalculator(T,Parent2);[Children1_FitnessValue] = FitnessCalculator(T,Children1);[Children2_FitnessValue] = FitnessCalculator(T,Children2);[~, pos] = max([Parent1_FitnessValue Parent2_FitnessValue Children1_FitnessValue Children2_FitnessValue]);temp_group ={Parent1 Parent2 Children1 Children2};
%         if rand(1)>0.5
%             Children_group1{i}=Children1;
%         else
%             Children_group1{i}=Children2;
%         endChildren_group1{i}=temp_group{pos};end

五、运行结果


六、matlab版本及参考文献

1 matlab版本
2014a

2 参考文献
[1] 包子阳,余继周,杨杉.智能优化算法及其MATLAB实例(第2版)[M].电子工业出版社,2016.
[2]张岩,吴水根.MATLAB优化算法源代码[M].清华大学出版社,2017.

【车间调度】基于matlab遗传算法求解柔性车间调度问题【含Matlab源码 660期】相关推荐

  1. 【优化调度】基于改进遗传算法求解农业水资源调度问题(Matlab代码实现)

    目录 1 概述 2 运行结果 3 参考文献 4 Matlab代码实现 1 概述 科学的渠系配水决策可以减少渠系输水过程中的渗水损失和无效弃水,提高灌溉水利用率.国内外学者对渠系优化配水决策方法进行了许 ...

  2. 【Matlab验证码识别】遗传算法和最大熵优化+大津法(OTSU)+自定义阈值数字验证码识别【含GUI源码 1694期】

    一.代码运行视频(哔哩哔哩) [Matlab验证码识别]遗传算法和最大熵优化+大津法(OTSU)+自定义阈值数字验证码识别[含GUI源码 1694期] 二.matlab版本及参考文献 1 matlab ...

  3. 【Matlab路径规划】改进的遗传算法机器人避障路径规划【含GUI源码 703期】

    一.代码运行视频(哔哩哔哩) [Matlab路径规划]改进的遗传算法机器人避障路径规划[含GUI源码 703期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] ...

  4. 【Matlab生物电信号】生物电信号仿真【含GUI源码 684期】

    一.代码运行视频(哔哩哔哩) [Matlab生物电信号]生物电信号仿真[含GUI源码 684期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]董兵,超于毅,李 ...

  5. 【Matlab语音分析】语音信号分析【含GUI源码 1718期】

    一.代码运行视频(哔哩哔哩) [Matlab语音分析]语音信号分析[含GUI源码 1718期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]韩纪庆,张磊,郑铁 ...

  6. 【Matlab人脸识别】BP神经网络人脸识别(含识别率)【含GUI源码 891期】

    一.代码运行视频(哔哩哔哩) [Matlab人脸识别]BP神经网络人脸识别(含识别率)[含GUI源码 891期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] ...

  7. 【Matlab人脸识别】形态学教室人数统计(带面板)【含GUI源码 1703期】

    一.代码运行视频(哔哩哔哩) [Matlab人脸识别]形态学教室人数统计(带面板)[含GUI源码 1703期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]孟 ...

  8. 【Matlab人脸识别】人脸实时检测与跟踪【含GUI源码 673期】

    一.代码运行视频(哔哩哔哩) [Matlab人脸识别]人脸实时检测与跟踪[含GUI源码 673期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]孟逸凡,柳益君 ...

  9. 【Matlab图像融合】小波变换遥感图像融合【含GUI源码 744期】

    一.代码运行视频(哔哩哔哩) [Matlab图像融合]小波变换遥感图像融合[含GUI源码 744期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 包子阳,余 ...

  10. 【Matlab语音加密】语音信号加密解密(带面板)【含GUI源码 181期】

    一.代码运行视频(哔哩哔哩) [Matlab语音加密]语音信号加密解密(带面板)[含GUI源码 181期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]韩纪庆 ...

最新文章

  1. 重视隐私信息安全,笑迎人脸识别百亿蓝海
  2. java rxtx version_java – 不匹配的RXTX版本
  3. 网络推广运营过程中站长是否考虑过用户为什么愿意产生购买行为呢?
  4. Entity SQL Language 三 Where/Exists/In/Like/参数及外键查询
  5. 【转】C#获取当前路径7种方法
  6. docker 拉取oracle_Docker 拉取 oracle 11g镜像配置-Go语言中文社区
  7. 你是否为类编写接口?我乞求你停下!
  8. Android开发笔记(四十一)Service的生命周期
  9. mysql 存储过程 大于等于_mysql 存储过程 大于
  10. 山东建筑大学计算机期末试题,2018年山东建筑大学计算机科学与技术学院900计算机专业综合之计算机操作系统考研基础五套测试题...
  11. 下载蓝盒插件_chrome迅雷下载插件-迅雷下载支持插件下载 v3.1官方版--pc6下载站...
  12. Smart210使用superboot刷机
  13. 常用自动化测试工具汇总
  14. 数字孪生智慧选煤厂:数据监控赋能矿山高效生产
  15. 125w短波通信距离_陕西烽火通信短波及超短波产品.doc
  16. keil中断函数的写法_keil中怎样定义外部中断函数原型?
  17. 2018谷歌大会android,谷歌召开2018中国开发者大会,带来了Android 9多项更新
  18. java计算根号二的无穷_java怎么计算根号
  19. 紫外线杀菌器:过流式Photoscience紫外线杀菌器
  20. 有趣的概率:三门问题

热门文章

  1. [Js-Java SE]文件/文件夹复制(递归)
  2. Selenium 三种等待
  3. 初识Git 如何使用Git将本地项目上传到Github
  4. Bitmap算法应用实例(转)
  5. 20200121每日一句
  6. 每个初学者都应该搞懂的问题
  7. 欧盟《一般数据保护法案》(GDPR)核心要点 本文更多的是站在企业角度来思考法案对物联网行业的影响以及应对措施,一来希望与同行企业可以就GDPR进行更多的互动讨论;二来也是希望传播国际法案对于安全和
  8. Atitit 机器学习算法分类 五大分类v5 t56.docx Atitit 机器学习算法分类 目录 1. 传统的机器学习算法 vs 深度学习 1 1.1. 传统的机器学习算法包括决策树、聚类、贝
  9. Atitit 减少财政支出之减少通讯支出 解决方案attilax总结
  10. Atitit.提升语言可读性原理与实践