首页 > 编程语言 >基于变异混合蛙跳算法的车间调度最优化matlab仿真,可以任意调整工件数和机器数,输出甘特图

基于变异混合蛙跳算法的车间调度最优化matlab仿真,可以任意调整工件数和机器数,输出甘特图

时间:2024-06-19 22:21:42浏览次数:29  
标签:end 子群 Pop 算法 甘特图 matlab ff 蛙跳

1.程序功能描述

变异混合蛙跳算法的车间调度最优化,可以任意调整工件数和机器数,输出甘特图。

 

2.测试软件版本以及运行结果展示

MATLAB2022a版本运行

              

 

 

 

 

 

 

 

3.核心程序

%初始种群
Pop_n = round(sqrt(Npop));                  
Pop_s = ceil(Npop/Pop_n);               
Npop  =Pop_s*Pop_n;                      

[Xs,ff] = func_initial(T,Npop);

fout = zeros(Iters,1);                                      
for i = 1:Iters
i
    [ff,I] = sort(ff,'descend');
Xs     = Xs(I,:);
    Pmax   = Xs(1,:);
    Fmax   = ff(1);

    for j = 1:Pop_n
        Pops       = Xs(j:Pop_n:end,:);            % 子种群
        ff_        = ff(j:Pop_n:end,:);
        [Popss,F3] = func_FLA(T,Pops,ff_,Pmax,Fmax);

Xs(j:Pop_n:end,:) = Popss;
ff(j:Pop_n:end,:) = F3;
    end

    [Xsolve,ybest]  = func_Eval(Xs,ff);                      % 进化结果评估


fout(i) = -mean(ybest);
end




figure
[Fouts,Etime] = func_fitness(T,Xsolve);
Stime         = Etime-T(:,Xsolve); % 开始时间
fval          = -Fouts;
M1            = size(T,1);    % 行数M1为机器数
NX            = length(Xsolve);    % 列数NX为工件数
for i = 1:M1
    for j = 1:NX
        x1 = Stime(i,j);
        x2 = Etime(i,j);
        y1 = i-1;
        y2 = i-0.05;
fill([x1 x2 x2 x1],[y1 y1 y2 y2],[0,1,0]);
        text(x1*0.55+x2*0.45,(y1+y2)/2,[num2str(Xsolve(j))],'Fontsize',8,'Color','k');
        hold on;
    end
    text(-0.8,(y1+y2)/2,['机器 ',num2str(i)],'Fontsize',8,'Color','k');
end

hold off; 
xlabel('时间'); 
set(gca,'ytick',[],'YDir','reverse','Color',[1 1 1]);
axis([0 fval 0 M1-0.05]);
title(['工件数:',num2str(NX),', 机器数:',num2str(M1),', 最优值:',num2str(fval)]);


figure;
plot(1:Iters,fout(1:end),'b-o'); 
grid on;
xlabel('进化代数'); 
ylabel('适应度');
21

  

 

4.本算法原理

          基于变异混合蛙跳算法的车间调度最优化是一种结合了蛙跳算法(Shuffled Frog Leaping Algorithm, SFLA)和变异策略的优化方法,用于解决车间调度问题(Job-Shop Scheduling Problem, JSSP)。

 

4.1 车间调度问题(JSSP)描述

       给定一个车间,其中有 (n) 个作业(Jobs)和 (m) 台机器(Machines)。每个作业由一系列工序(Operations)组成,每个工序必须在特定的机器上完成,且每个作业的工序顺序是预先确定的。JSSP的目标是为每个机器找到一个作业工序的序列,使得所有作业的总完成时间最小化。

 

4.2 蛙跳算法(SFLA)基本原理

        蛙跳算法是一种群体智能优化算法,模拟了蛙群在寻找食物时的跳跃行为。在SFLA中,蛙群被分为多个子群,每个子群内的蛙通过局部搜索和信息交换寻找最优解。VHSFLA在基本SFLA的基础上引入了变异策略,以增强算法的全局搜索能力和避免陷入局部最优解。

 

4.2.1 初始化

初始化蛙群:随机生成一定数量的蛙(解),每个蛙代表一个可能的作业调度方案。

分组:将蛙群分为多个子群。

4.2.2 局部搜索

在每个子群内,蛙按照一定的规则进行跳跃(即解的更新)。跳跃的步长和方向通常由当前蛙的位置、子群内最优蛙的位置以及全局最优蛙的位置决定。

 

4.2.3 全局信息交换

经过一定次数的局部搜索后,子群内的蛙会与其他子群的蛙进行信息交换,以促进全局搜索。

 

4.2.4 变异策略

为了增强算法的全局搜索能力,VHSFLA引入了变异策略。变异操作可以随机地改变蛙的某些基因(即作业工序的顺序),从而产生新的解。

 

4.2.5 终止条件

算法会在满足一定条件时终止,如达到最大迭代次数或解的质量满足要求。

 

标签:end,子群,Pop,算法,甘特图,matlab,ff,蛙跳
From: https://www.cnblogs.com/softcodes/p/18257600

相关文章

  • matlab实验3
    一、实验目的掌握共轭梯度法的基本思想及其迭代步骤;学会运用MATLAB编程实现常用优化算法;能够正确处理实验数据和分析实验结果及调试程序。二、实验内容 (1)求解无约束优化问题:minf(x)=100(x1^2-x2)^2+(x1-1)^2,x∈R;(2)终止准则取||f(x^k)||<=10^-5,搜索方法采用非精确搜索Armijo;......
  • matlab实验4
    一、实验目的掌握共轭梯度法的基本思想及其迭代步骤;学会运用MATLAB编程实现常用优化算法;能够正确处理实验数据和分析实验结果及调试程序。二、实验内容 (1)求解无约束优化问题:minf(x)=100(x1^2-x2)^2+(x1-1)^2,x∈R;(2)终止准则取||f(x^k)||<=10^-5,搜索方法采用非精确搜索Armijo;......
  • matlab实验
    一、实验目的掌握Hesse矩阵的计算方法和Newton法的基本思想及其迭代步骤;学会运用MATLAB编程实现常用优化算法;正确处理实验数据和分析实验结果及调试程序。二、实验内容(1)求解无约束优化问题(3)完成Newton法(牛顿法)的MATLAB编程、调试;(4)选取几个与实验二中相同的初始点,并给出相关实......
  • matlab最优化工具箱
    一、实验目的(一)通过一个农业生产计划优化安排的实例求解,培养学生解决实际线性规划问题的初步能力;熟悉线性规划的建模过程;掌握Matlab优化工具箱中线性规划函数的调用。二、实验内容(一)某村计划在100公顷的土地上种植a、b、c三种农作物。可以提供的劳力、粪肥和化肥等资源的数量,种......
  • 区间预测 | Matlab实现的集成双向长短期记忆网络自适应带宽核密度BiLSTM-Adaboost-ABK
    %设置参数numLSTM=3;%LSTM模型数量numBoost=5;%Adaboost迭代次数%加载数据load(‘data.mat’);%替换为您的数据文件%数据预处理%…%初始化LSTM模型lstmModels=cell(numLSTM,1);fori=1:numLSTMlstmModels{i}=trainLSTMModel(data);%使用......
  • 基于GWO-CNN-LSTM数据时间序列预测(多输入单输出)-多维时间序列模型-MATLAB实现
    基于GWO-CNN-LSTM数据时间序列预测(多输入单输出)-多维时间序列模型-MATLAB实现基于灰狼优化(GreyWolfOptimizer,GWO)、卷积神经网络(ConvolutionalNeuralNetwork,CNN)和长短期记忆网络(LongShort-TermMemory,LSTM)的多维时间序列预测模型是一种复杂且有效的深度学习方法,适......
  • 【优化设计】基于泊松方程求解形状优化设计问题附Matlab代码
     ✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,代码获取、论文复现及科研仿真合作可私信。......
  • 【图像加密】基于线性正则变换与菲涅尔变换实现图像加密解密,MSE PSNR附Matlab代码
     ✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,代码获取、论文复现及科研仿真合作可私信。......
  • 储能参与现货电能量-调频辅助服务市场的双层交易决策研究(Matlab代码实现)
     ......
  • 电力系统潮流计算及不对称短路分析(Matlab代码实现)
    ......