m基于PSO粒子群优化的柔性作业车间调度问题matlab仿真,并输出甘特图

简介: m基于PSO粒子群优化的柔性作业车间调度问题matlab仿真,并输出甘特图

1.算法描述

   PSO算法是一种随机的、并行的优化算法。它的优点是:不要求被优化函数具有可微、可导、连续等性质,收敛速度较快,算法简单,容易编程实现。然而,PSO算法的缺点在于:(1)对于有多个局部极值点的函数,容易陷入到局部极值点中,得不到正确的结果。造成这种现象的原因有两种,其一是由于待优化函数的性质;其二是由于微粒群算法中微粒的多样性迅速消失,造成早熟收敛。这两个因素通常密不可分地纠缠在一起。(2)由于缺乏精密搜索方法的配合,PSO算法往往不能得到精确的结果。造成这种问题的原因是PSO算法并没有很充分地利用计算过程中获得的信息,在每一步迭代中,仅仅利用了群体最优和个体最优的信息。(3)PSO算法虽然提供了全局搜索的可能,但是并不能保证收敛到全局最优点上。(4)PSO算法是一种启发式的仿生优化算法,当前还没有严格的理论基础,仅仅是通过对某种群体搜索现象的简化模拟而设计的,但并没有从原理上说明这种算法为什么有效,以及它适用的范围。因此,PSO算法一般适用于一类高维的、存在多个局部极值点而并不需要得到很高精度解的优化问题。
    当前针对PSO算法开展的研究工作种类繁多,经归纳整理分为如下八个大类:(1)对PSO算法进行理论分析,试图理解其工作机理;(2)改变PSO算法的结构,试图获得性能更好的算法;(3)研究各种参数配置对PSO算法的影响;(4)研究各种拓扑结构对PSO算法的影响;(5)研究离散版本的PSO算法;(6)研究PSO算法的并行算法;(7)利用PSO算法对多种情况下的优化问题进行求解;(8)将PSO算法应用到各个不同的工程领域。以下从这八大类别着手,对PSO算法的研究现状作一梳理。由于文献太多,无法面面俱到,仅捡有代表性的加以综述。

   PSO初始化为一群随机粒子(随机解)。然后通过迭代找到最优解。在每一次迭代中,粒子通过跟踪两个“极值(pbest和gbest)”来更新自己。在找到这两个最优值后,粒子通过下面的公式来更新自己的速度和位置。

1.png

标准PSO算法流程
初始化一群微粒(群体规模为N),包括随机位置和速度;
评价每个微粒的适应度;
对每个微粒,将其适应值与其经过的最好位置pbest作比较,如果较好,则将其作为当前的最好位置pbest;
对每个微粒,将其适应值与其经过的最好位置gbest作比较,如果较好,则将其作为当前的最好位置gbest;
根据公式(2)、(3)调整微粒的速度和位置;
未达到结束条件则转到第二步。
迭代终止条件根据具体问题一般选为最大迭代次数Gk或微粒群迄今为止搜索到的最优位置满足预定最小适应阈值。

   甘特图以图示通过活动列表和时间刻度表示出特定项目的顺序与持续时间。一条线条图,横轴表示时间,纵轴表示项目,线条表示期间计划和实际完成情况。直观表明计划何时进行,进展与要求的对比。便于管理者弄清项目的剩余任务,评估工作进度。

   甘特图是以作业排序为目的,将活动与时间联系起来的最早尝试的工具之一,帮助企业描述工作中心、超时工作等资源的使用。

甘特图包含以下三个含义:

1、以图形或表格的形式显示活动;

2、通用的显示进度的方法;

3、构造时含日历天和持续时间,不将周末节假算在进度内。

简单、醒目、便于编制,在管理中广泛应用。

甘特图按内容不同,分为计划图表、负荷图表、机器闲置图表、人员闲置图表和进度表五种形式。

2.仿真效果预览
matlab2022a仿真结果如下:

2.png
3.png

3.MATLAB核心程序

wmax    = 1.2;  
wmin    = 0.1;  
c1      = 1.5;
c2      = 2;
%粒子群规模
Pso_Num = 100;
%迭代次数
Max_Gen = 300;
%同一个工序下的作业数量
Job_num = 4;
%不同工序的数量
Job_para= 4;
%初始PSO变量
Time_job = zeros(Job_num,Job_para);
seqs_job = zeros(Job_num,Job_para);
rng(1);
%初始化PSO变量的随机赋初值
for ii = 1:Job_num
    for jj = 1:Job_para
        Time_job(ii,jj) = round(1+9*rand);
    end
    seqs_job(ii,:) = randperm(Job_para);
end
 
%总工序
All_Num      = Job_num*Job_para;
%粒子初始化
Part_initial = rand(Pso_Num,All_Num+1);  
%速度初始化
Vpso         = rand(Pso_Num,All_Num);
 
%初始化车间作业布局
for i=1:Pso_Num
    [K1,K2]                  = sort(Part_initial(i,1:All_Num));
    Arrays                   = ceil(K2/Job_para);
    Span_initial             = func_span(Arrays,Time_job,seqs_job);
    Part_initial(i,All_Num+1)= Span_initial;
end
 
%个体
Pbestp = zeros(Pso_Num,All_Num);
Pbestg = zeros(1,All_Num);              
%速度
Vbestp = zeros(Pso_Num,1);
Vbestg = zeros(1,1);         
 
%初始化粒子群的初始状态
for i=1:Pso_Num
    Pbestp(i,1:All_Num) = Part_initial(i,1:All_Num);
    Vbestp(i)           = Part_initial(i,All_Num+1);
end
 
%初始化粒子群速度和坐标
[I,J]   = sort(Part_initial(:,All_Num+1));
Pbestg  = Part_initial(J(1),1:All_Num);
Vbestg  = Part_initial(J(1),All_Num+1);
iter    = 0;
E0      = zeros(1,Pso_Num);
E1      = zeros(1,Max_Gen); 
%粒子群权值
w       = 0.5;
 
%开始迭代
while iter<Max_Gen
      iter
      for i = 1:Pso_Num%对每个PSO个体进行循环处理
          rng(i*iter);
          %随机化系数
          K1                        = rand/4;
          K2                        = rand/4;
          %PSO粒子群自适应迭代公式  
          Vpso(i,:)                 = w*Vpso(i,:)+...
                                      c1*K1*(Pbestp(i,:) - Part_initial(i,1:All_Num))+...
                                      c2*K2*(Pbestg      - Part_initial(i,1:All_Num));
          %将更新后的PSO状态叠加到粒子群初始状态上,并逐渐迭代到最优状态                          
          Part_initial(i,1:All_Num) = Part_initial(i,1:All_Num) + Vpso(i,:);
 
          %估计
          [Value_g,Index_g]         = sort(Part_initial(i,1:All_Num));
          
          Arrays                    = ceil(Index_g/Job_para);
          %将每次迭代后的PSO状态进行优化作业布局
          Span_initial              = func_span(Arrays,Time_job,seqs_job);
          
          Part_initial(i,All_Num+1) = Span_initial;
          %将较优的PSO状态和速度更新到变量Pbestp和Vbestp中
          if Part_initial(i,All_Num+1) < Vbestp(i)
             Pbestp(i,:) = Part_initial(i,1:All_Num);
             Vbestp(i)   = Part_initial(i,1+All_Num);
          end
          if Vbestp(i) < Vbestg
             Pbestg = Pbestp(i,:);
             Vbestg = Vbestp(i);
          end
          E0(i) = Span_initial;
      end
      iter=iter+1;
      E1(iter) = mean(E0);
end
................................................
figure;
[Rows,Cols] = size(Time_s);
 
for i=1:Rows
    for j=1:Cols
        %根据得到的时间点进行划分
        x = [Time_s(i,j),Time_s(i,j),Time_e(i,j),Time_e(i,j)];
        y = [Rows+1-i-0.3,Rows+1-i+0.3,Rows+1-i+0.3,Rows+1-i-0.3];
        %不同的工序进行标注不同的颜色
        if Job_sech(i,j) == 1
           fill(x,y,'r'); 
        end
        if Job_sech(i,j) == 2
           fill(x,y,'b'); 
        end        
        if Job_sech(i,j) == 3
           fill(x,y,'c'); 
        end
        if Job_sech(i,j) == 4
           fill(x,y,'g'); 
        end
        %标记工序的编号
        Name_jobs   = strcat(int2str(Job_sech(i,j)));
        Name_start  = strcat(int2str(Time_s(i,j)));
        Name_end    = strcat(int2str(Time_e(i,j)));
        text((Time_s(i,j)+Time_e(i,j))/2-0.2,Rows+1-i,Name_jobs);
        text(Time_s(i,j)-0.2,Rows+1-i-0.5,Name_start);
        text(Time_e(i,j)-0.2,Rows+1-i-0.5,Name_end);
        hold on
   end
end
axis([-1,max(max(Time_e))+2,0,Job_para+1]);
title('车间作业布局优化后的甘特图');
02_031m
相关文章
|
1天前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于PSO粒子群优化的GroupCNN分组卷积网络时间序列预测算法matlab仿真
本项目展示了一种结合粒子群优化(PSO)与分组卷积神经网络(GroupCNN)的时间序列预测算法。该算法通过PSO寻找最优网络结构和超参数,提高预测准确性与效率。软件基于MATLAB 2022a,提供完整代码及详细中文注释,并附带操作步骤视频。分组卷积有效降低了计算成本,而PSO则智能调整网络参数。此方法特别适用于金融市场预测和天气预报等场景。
|
7天前
|
机器学习/深度学习 算法 数据挖掘
基于GWO灰狼优化的CNN-LSTM的时间序列回归预测matlab仿真
本项目展示了一种结合灰狼优化(GWO)与深度学习模型(CNN和LSTM)的时间序列预测方法。GWO算法高效优化模型超参数,提升预测精度。CNN提取局部特征,LSTM处理长序列依赖,共同实现准确的未来数值预测。项目包括MATLAB 2022a环境下运行的完整代码及视频教程,代码内含详细中文注释,便于理解和操作。
|
1月前
|
安全
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
本文介绍了2023年高教社杯数学建模竞赛D题的圈养湖羊空间利用率问题,包括问题分析、数学模型建立和MATLAB代码实现,旨在优化养殖场的生产计划和空间利用效率。
106 6
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
|
1月前
|
存储 算法 搜索推荐
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
本文提供了2022年华为杯数学建模竞赛B题的详细方案和MATLAB代码实现,包括方形件组批优化问题和排样优化问题,以及相关数学模型的建立和求解方法。
79 3
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
|
1月前
|
数据采集 存储 移动开发
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
本文介绍了2023年五一杯数学建模竞赛B题的解题方法,详细阐述了如何通过数学建模和MATLAB编程来分析快递需求、预测运输数量、优化运输成本,并估计固定和非固定需求,提供了完整的建模方案和代码实现。
62 0
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
|
4月前
|
数据安全/隐私保护
耐震时程曲线,matlab代码,自定义反应谱与地震波,优化源代码,地震波耐震时程曲线
地震波格式转换、时程转换、峰值调整、规范反应谱、计算反应谱、计算持时、生成人工波、时频域转换、数据滤波、基线校正、Arias截波、傅里叶变换、耐震时程曲线、脉冲波合成与提取、三联反应谱、地震动参数、延性反应谱、地震波缩尺、功率谱密度
基于混合整数规划的微网储能电池容量规划(matlab代码)
基于混合整数规划的微网储能电池容量规划(matlab代码)
|
4月前
|
算法 调度
含多微网租赁共享储能的配电网博弈优化调度(含matlab代码)
含多微网租赁共享储能的配电网博弈优化调度(含matlab代码)
|
4月前
|
Serverless
基于Logistic函数的负荷需求响应(matlab代码)
基于Logistic函数的负荷需求响应(matlab代码)
|
4月前
|
供应链 算法
基于分布式优化的多产消者非合作博弈能量共享(Matlab代码)
基于分布式优化的多产消者非合作博弈能量共享(Matlab代码)