蒲公英优化器Dandelion Optimizer附matlab代码

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

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

🍊个人信条:格物致知。

更多Matlab仿真内容点击👇

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

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

⛄ 内容介绍

群智能优化算法作为当前优化算法中的一个主要研究热点,经过近年的发展,已经发展为较为新颖的演化计算技术,受到越来越多不同领域研究工作者的关注.群智能优化算法比传统优化方法求解各种复杂优化问题上表现出了更好的高效性以及稳定性,并且算法的结构和操作性相对简单,隐含并行性,容易理解和编程,因此在优化技术应用上有较强的实用性,具有一定的现实意义.本文首先介绍了群体智能优化算法研究背景、意义及其国内外研究现状和应用情况.本文的主要研究工作如下:1.通过模拟蒲公英飘落繁殖过程,提出了一种新的群体智能算法——蒲公英智能优化算法(Dandelion Optimization Algorithm,简称DOA),蒲公英智能优化算法为解决优化问题提供一种新的基础算法.模拟蒲公英在繁殖过程中飘落生长的植物特性,以弥漫式并行搜索方式对解空间进行搜索,直到找到最优解为止。

每值春夏之际,大地上长满了成片的蒲公英,每片的蒲公英群都会由一定范围内星星点点

的蒲公英繁殖而来,受蒲公英飘落繁殖现象的启发,本人在导师高岳林的指导下提出模拟蒲公

英繁衍方式的蒲公英优化算法( DOA ),将蒲公英繁殖生长的空间比作成优化问题的搜索空间,

将生长在此区域内的母代和子代蒲公英个体看作是问题的候选解,通过目标函数评估蒲公英

子代的适应度值,算法越接近目标函数的最优解,对应的适应度值就会越高,以此来比较算法

的优劣性.根据蒲公英植物的生长繁殖规律,实时对蒲公英子代的飘落位置进行更新,同时对

蒲公英子代进行增肥和灌溉,提高幼苗的生长质量.幼苗作为下一阶段蒲公英繁衍的位置,且

生长的蒲公英个体将保留在原来的位置上.通过对挑选出的优质蒲公英个体进行不停的繁殖,

这样的操作不停地进行,繁殖的后代也会不停的接近最适合蒲公英种子生长的位置附近,最终

在算法满足终止条件时,蒲公英种群中适应度值最优的位置就当作目标函数在解空间的最优

值.

蒲公英算法通过实数编码的方式,随机地初始化种群,种群的迭代过程是受 3 个分量(风

速、风向、种群密度)的共同作用,在整个迭代过程中,为了保持种群多样性,对蒲公英种子落

地生根时的位置进行更新移植,并通过施肥和灌溉等操作,直到满足终止条件

⛄ 部分代码

%__________________________________________________________________

%  Dandelion Optimizer

%  Developed in MATLAB R2018a

%  Engineering Applications of Artificial Intelligence

%  DOI:10.1016/j.engappai.2022.105075

%

%__________________________________________________________________

clear all 

clc

N=30; % Number of search agents

Max_iter=500; % Maximum numbef of iterations

F_name='F15'; % Name of the test function

% Load details of the selected benchmark function

[lb,ub,dim,fobj]=Get_Functions_details(F_name);

tic;

[Bestfitness,Bestposition,Convergencecurve]=DO(N,Max_iter,lb,ub,dim,fobj);

Run_time=toc;

figure('Position',[500 500 660 290])

%Draw search space

subplot(1,2,1);

func_plot(F_name);

title('Parameter space')

xlabel('x_1');

ylabel('x_2');

zlabel([F_name,'( x_1 , x_2 )'])

%Draw objective space

subplot(1,2,2);

semilogy(1:Max_iter,Convergencecurve,'color','r','linewidth',2.5);

title('Convergence curve');

xlabel('Iteration');

ylabel('Best score obtained so far')

display(['The running time is:', num2str(Run_time)]);

display(['The best fitness is:', num2str(Bestfitness)]);

display(['The best position is: ', num2str(Bestposition)]);

⛄ 运行结果

⛄ 参考文献

❤️ 关注我领取海量matlab电子书和数学建模资料

❤️部分理论引用网络文献,若有侵权联系博主删除

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

天天Matlab科研工作室

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值