【优化分配】基于粒子群算法和萤火虫算法求解二次分配优化问题附matlab代码

简介: 【优化分配】基于粒子群算法和萤火虫算法求解二次分配优化问题附matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。

🍎个人主页:Matlab科研工作室

🍊个人信条:格物致知。

更多Matlab仿真内容点击👇

智能优化算法       神经网络预测       雷达通信      无线传感器        电力系统

信号处理              图像处理               路径规划       元胞自动机        无人机

⛄ 内容介绍

针对当前火力分配(WTA)的难题,论文提出了一种基于粒子群优化算法(PSO)和萤火虫算法火力分配优化方法.介绍了算法的具体实现步骤,并通过在计算机上进行MATLAB仿真实验,验证了此方法的可行性和科学性,是一种有益的尝试与探索,对现代战争中指挥决策和理论研究有一定的参考价值.

⛄ 部分代码

%



clc;

clear;

close all;


%% Problem Definition


model=CreateModel();


CostFunction=@(s) MyCost(s, model);        % Cost Function


nVar=model.m;       % Number of Decision Variables


VarSize=[1 nVar];   % Size of Decision Variables Matrix


VarMin=0;         % Lower Bound of Variables

VarMax=1;         % Upper Bound of Variables



%% PSO Parameters


MaxIt=1000;      % Maximum Number of Iterations


nPop=80;         % Population Size (Swarm Size)


% PSO Parameters

w=1;            % Inertia Weight

wdamp=0.99;     % Inertia Weight Damping Ratio

c1=1.5;         % Personal Learning Coefficient

c2=2.0;         % Global Learning Coefficient


% Velocity Limits

VelMax=0.1*(VarMax-VarMin);

VelMin=-VelMax;


nParticleMutation = 1;      % Number of Mutations Performed on Each Particle

nGlobalBestMutation = 3;    % Number of Mutations Performed on Global Best


%% Initialization


empty_particle.Position=[];

empty_particle.Cost=[];

empty_particle.Sol=[];

empty_particle.Velocity=[];

empty_particle.Best.Position=[];

empty_particle.Best.Cost=[];

empty_particle.Best.Sol=[];


particle=repmat(empty_particle,nPop,1);


GlobalBest.Cost=inf;


for i=1:nPop

   

   % Initialize Position

   particle(i).Position=unifrnd(VarMin,VarMax,VarSize);

   

   % Initialize Velocity

   particle(i).Velocity=zeros(VarSize);

   

   % Evaluation

   [particle(i).Cost, particle(i).Sol]=CostFunction(particle(i).Position);

   

   % Update Personal Best

   particle(i).Best.Position=particle(i).Position;

   particle(i).Best.Cost=particle(i).Cost;

   particle(i).Best.Sol=particle(i).Sol;

   

   % Update Global Best

   if particle(i).Best.Cost<GlobalBest.Cost

       GlobalBest=particle(i).Best;

   end

   

end


BestCost=zeros(MaxIt,1);


%% PSO Main Loop


for it=1:MaxIt

   

   for i=1:nPop

       

       % Update Velocity

       particle(i).Velocity = w*particle(i).Velocity ...

           +c1*rand(VarSize).*(particle(i).Best.Position-particle(i).Position) ...

           +c2*rand(VarSize).*(GlobalBest.Position-particle(i).Position);

       

       % Apply Velocity Limits

       particle(i).Velocity = max(particle(i).Velocity,VelMin);

       particle(i).Velocity = min(particle(i).Velocity,VelMax);

       

       % Update Position

       particle(i).Position = particle(i).Position + particle(i).Velocity;

       

       % Velocity Mirror Effect

       IsOutside=(particle(i).Position<VarMin | particle(i).Position>VarMax);

       particle(i).Velocity(IsOutside)=-particle(i).Velocity(IsOutside);

       

       % Apply Position Limits

       particle(i).Position = max(particle(i).Position,VarMin);

       particle(i).Position = min(particle(i).Position,VarMax);

       

       % Evaluation

       [particle(i).Cost, particle(i).Sol] = CostFunction(particle(i).Position);

       

       % Perform Mutation

       for j=1:nParticleMutation

           NewParticle = particle(i);

           NewParticle.Position = Mutate(particle(i).Position);

           [NewParticle.Cost, NewParticle.Sol] = CostFunction(NewParticle.Position);

           if NewParticle.Cost <= particle(i).Cost

               particle(i) = NewParticle;

           end

       end

       

       % Update Personal Best

       if particle(i).Cost<particle(i).Best.Cost

           

           particle(i).Best.Position=particle(i).Position;

           particle(i).Best.Cost=particle(i).Cost;

           particle(i).Best.Sol=particle(i).Sol;

           

           % Update Global Best

           if particle(i).Best.Cost<GlobalBest.Cost

               GlobalBest=particle(i).Best;

           end

           

       end

       

   end

   

   % Perform Mutation on Global Best

   for i=1:nGlobalBestMutation

       NewParticle = GlobalBest;

       NewParticle.Position = Mutate(GlobalBest.Position);

       [NewParticle.Cost, NewParticle.Sol] = CostFunction(NewParticle.Position);

       if NewParticle.Cost <= GlobalBest.Cost

           GlobalBest = NewParticle;

       end

   end

   

   

   BestCost(it)=GlobalBest.Cost;

   

   disp(['Iteration ' num2str(it) ': Best Cost = ' num2str(BestCost(it))]);

   

   w=w*wdamp;

   

   figure(1);

   PlotSolution(GlobalBest.Position, model);

   pause(0.01);

   

end


BestSol = GlobalBest;


%% Results


figure;

plot(BestCost,'LineWidth',2);

xlabel('迭代次数');

ylabel('最优值');

grid on;


⛄ 运行结果

⛄ 参考文献

[1] 王光源, 徐鹏飞, 赵勇. 基于粒子群优化算法求解火力分配问题[J]. 舰船电子工程, 2013, 33(11):34-36.

[2] 周洪斌, 吕强. 利用混合粒子群优化算法求解二次分配问题[J]. 计算机应用与软件, 2009, 26(11):3.

[3] 朱渊萍, 陈素芬. 萤火虫群优化算法在公差分配优化的应用[J]. 机械设计与制造, 2014(6):3.

⛳️ 完整代码

❤️部分理论引用网络文献,若有侵权联系博主删除
❤️ 关注我领取海量matlab电子书和数学建模资料


相关文章
|
1天前
|
算法
基于大爆炸优化算法的PID控制器参数寻优matlab仿真
本研究基于大爆炸优化算法对PID控制器参数进行寻优,并通过Matlab仿真对比优化前后PID控制效果。使用MATLAB2022a实现核心程序,展示了算法迭代过程及最优PID参数的求解。大爆炸优化算法通过模拟宇宙大爆炸和大收缩过程,在搜索空间中迭代寻找全局最优解,特别适用于PID参数优化,提升控制系统性能。
|
8天前
|
存储 关系型数据库 分布式数据库
PolarDB的PolarStore存储引擎以其高效的索引结构、优化的数据压缩算法、出色的事务处理能力著称
PolarDB的PolarStore存储引擎以其高效的索引结构、优化的数据压缩算法、出色的事务处理能力著称。本文深入解析PolarStore的内部机制及优化策略,包括合理调整索引、优化数据分布、控制事务规模等,旨在最大化其性能优势,提升数据存储与访问效率。
20 5
|
23天前
|
算法 调度
基于遗传模拟退火混合优化算法的车间作业最优调度matlab仿真,输出甘特图
车间作业调度问题(JSSP)通过遗传算法(GA)和模拟退火算法(SA)优化多个作业在并行工作中心上的加工顺序和时间,以最小化总完成时间和机器闲置时间。MATLAB2022a版本运行测试,展示了有效性和可行性。核心程序采用作业列表表示法,结合遗传操作和模拟退火过程,提高算法性能。
|
23天前
|
人工智能 算法 大数据
Linux内核中的调度算法演变:从O(1)到CFS的优化之旅###
本文深入探讨了Linux操作系统内核中进程调度算法的发展历程,聚焦于O(1)调度器向完全公平调度器(CFS)的转变。不同于传统摘要对研究背景、方法、结果和结论的概述,本文创新性地采用“技术演进时间线”的形式,简明扼要地勾勒出这一转变背后的关键技术里程碑,旨在为读者提供一个清晰的历史脉络,引领其深入了解Linux调度机制的革新之路。 ###
|
1月前
|
存储 缓存 算法
优化轮询算法以提高资源分配的效率
【10月更文挑战第13天】通过以上这些优化措施,可以在一定程度上提高轮询算法的资源分配效率,使其更好地适应不同的应用场景和需求。但需要注意的是,优化策略的选择和实施需要根据具体情况进行详细的分析和评估,以确保优化效果的最大化。
|
4月前
|
安全
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
本文介绍了2023年高教社杯数学建模竞赛D题的圈养湖羊空间利用率问题,包括问题分析、数学模型建立和MATLAB代码实现,旨在优化养殖场的生产计划和空间利用效率。
205 6
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
|
4月前
|
存储 算法 搜索推荐
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
本文提供了2022年华为杯数学建模竞赛B题的详细方案和MATLAB代码实现,包括方形件组批优化问题和排样优化问题,以及相关数学模型的建立和求解方法。
131 3
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
|
4月前
|
数据采集 存储 移动开发
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
本文介绍了2023年五一杯数学建模竞赛B题的解题方法,详细阐述了如何通过数学建模和MATLAB编程来分析快递需求、预测运输数量、优化运输成本,并估计固定和非固定需求,提供了完整的建模方案和代码实现。
95 0
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
|
7月前
|
数据安全/隐私保护
耐震时程曲线,matlab代码,自定义反应谱与地震波,优化源代码,地震波耐震时程曲线
地震波格式转换、时程转换、峰值调整、规范反应谱、计算反应谱、计算持时、生成人工波、时频域转换、数据滤波、基线校正、Arias截波、傅里叶变换、耐震时程曲线、脉冲波合成与提取、三联反应谱、地震动参数、延性反应谱、地震波缩尺、功率谱密度
基于混合整数规划的微网储能电池容量规划(matlab代码)
基于混合整数规划的微网储能电池容量规划(matlab代码)