【优化算法】蛾群优化算法(MSA)【含Matlab源码 1807期】

举报
海神之光 发表于 2022/05/30 00:42:55 2022/05/30
【摘要】 一、获取代码方式 获取代码方式1: 完整代码已上传我的资源:【优化算法】蛾群优化算法(MSA)【含Matlab源码 1807期】 二、部分源代码 %_________________________...

一、获取代码方式

获取代码方式1:
完整代码已上传我的资源:【优化算法】蛾群优化算法(MSA)【含Matlab源码 1807期】

二、部分源代码

%______________________________________________________________________________________________
%  Moth Swarm Algorithm (MSA)                                                            
                                                                                               
%  Developed in MATLAB R2008b 
%                                                                                                     
%  ___________________
%    This algorithm has a fast convergence characteristics. 
%    Appreciated results can be obtained with a small number of iterations.   

for iji=[1,8,21]
     if iji==1;F=('F1');elseif iji==2;F=('F2');elseif iji==3;F=('F3');elseif iji==4;F=('F4');elseif iji==5;F=('F5'); ...
     elseif iji==6;F=('F6');elseif iji==7; F=('F7'); elseif iji==8; F=('F8');elseif iji==9; F=('F9'); ... 
     elseif iji==10; F=('F10');elseif iji==11; F=('F11');elseif iji==12; F=('F12'); ...
     elseif iji==13; F=('F13');elseif iji==14; F=('F14');elseif iji==15; F=('F15');
     elseif iji==16; F=('F16');elseif iji==17; F=('F17');elseif iji==18; F=('F18');
     elseif iji==19; F=('F19');elseif iji==20; F=('F20');elseif iji==21; F=('F21');
     elseif iji==22; F=('F22');elseif iji==23; F=('F23');
     end
     
     if iji < 14;Max_iteration=1000;else Max_iteration=500;end% Maximum number of iterations

     SearchAgents_no=30;% Number of search agents
     Nc=6;% Number of Pathfinders: 4 <=  Nc  <= 20% of SearchAgents_no

     % Load details of the selected benchmark function
     [lb,ub,dim,fobj]=Get_Functions_details(F);
     
     [Best_pos,Best_score,Convergence_curve]=MSA(SearchAgents_no,Nc,Max_iteration,ub,lb,dim,fobj);
     
%Draw and display objective function

figure,semilogy(Convergence_curve); title( F ); xlabel('Iteration'); ylabel('Best score');
display(['The optimal solution of ',F, ' is: ',num2str(Best_pos)]);
display(['The optimal value of ',F,' is : ', num2str(Best_score)]);
end

% =====================================================
  

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38

三、运行结果

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

四、matlab版本及参考文献

1 matlab版本
2014a

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

文章来源: qq912100926.blog.csdn.net,作者:海神之光,版权归原作者所有,如需转载,请联系作者。

原文链接:qq912100926.blog.csdn.net/article/details/123605220

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。