CEC2021测试函数保姆级教程:1000+种群智能优化算法求解cec2021测试函数-matlab

引言

通常需要用cec测试函数对一个新方法的性能进行多方位的验证。各大公众号和博主将开源的cec测试函数和群智能优化算法系列进行高价售卖,给小伙伴们带来一些获取难度。鉴于此,本号前几期已分享了多个cec测试函数(cec2017cec2018cec2019cec2020cec2022)测试函数的快捷用法及matlab代码下载压缩包。

那么,本期在前期的基础上,继续照猫画虎推出cec2021测试函数的使用及matlab代码,1分钟让你学会。

该cec2021测试函数共有10个单目标测试函数,基本上是cec2017和cec2014的里挑选的函数。分别是:单峰函数(F1)、基础函数(F2-F4)、混合函数(F5-F7)和组合函数(F8-F10)。测试维度有2维,10维,20维。所有的测试函数都是解决最小化问题。如下形式:

图片

其中,D为维数。为方便起见,cec2021测试函数定义了相同的搜索范围,即区间[-100, 100]。

首先需下载cec2021函数。函数的格式为cpp文件,cec21_basic_func.cpp。在matlab里需要编译。在matlab的命令行输入

mex cec21_basic_func.cpp

图片

提示MEX 已成功完成,编译生成了cec21_basic_func.mexw64文件即可。这里我们已经为各位下载并编译好了,文末可直接享用

其次,加载cec2021测试函数。cec2021测试函数有10个,输入x的数据格式需为列向量,即N*1,调用方式为:

fobj = @(x) cec21_basic_func(x,1);

数字1表示cec2021的第一个函数。当然,可以在1-10中任意选择一个数,就选择了对应的测试函数

如果你的输入数据x是一个行向量,即1*N,调用方式为:

fobj = @(x) cec21_basic_func(x',1);

考虑到大部分优化算法中x的格式为(nPop种群数,Dim维度),因此,我们采用了第二种fobj的调用方式。如果遇到的x是(Dim维度,nPop种群数),还小伙伴需要自行改写。

最后,测试应用

我们以上述三个算法为例进行测试。算法的参数设置如下:

clcclearclose all%%nPop=50; % 种群数Max_iter=500; % 最大迭代次数dim = 20; % 维度,可选 2, 10, 20
%%  选择函数Function_name=10; % 函数名:1 - 10% lb->下限,ub->上限,fobj->目标函数[lb,ub,dim,fobj] = Get_Functions_cec2021(Function_name,dim);
%% 调用算法Optimal_results={}; % 保存Optimal resultsindex = 1;% WOAtic[Best_score,Best_x,cg_curve]=WOA(nPop,Max_iter,lb,ub,dim,fobj);Optimal_results{1,index}="WOA";         % 算法名字Optimal_results{2,index}=cg_curve;      % 收敛曲线Optimal_results{3,index}=Best_score;    % 最优函数值Optimal_results{4,index}=Best_x;        % 最优变量Optimal_results{5,index}=toc;           % 运行时间index = index +1;% HHOtic[Best_score,Best_x,cg_curve]=HHO(nPop,Max_iter,lb,ub,dim,fobj);Optimal_results{1,index}="HHO";Optimal_results{2,index}=cg_curve;Optimal_results{3,index}=Best_score;Optimal_results{4,index}=Best_x;Optimal_results{5,index}=toc;index = index +1;% GWOtic[Best_score,Best_x,cg_curve]=GWO(nPop,Max_iter,lb,ub,dim,fobj);Optimal_results{1,index}="GWO";Optimal_results{2,index}=cg_curve;Optimal_results{3,index}=Best_score;Optimal_results{4,index}=Best_x;Optimal_results{5,index}=toc;index = index +1;%% plotfigure
for i = 1:size(Optimal_results, 2)%     plot(Optimal_results{2, i},'Linewidth',2)    semilogy(Optimal_results{2, i},'Linewidth',2)    hold onendtitle(['Convergence curve, Dim=' num2str(dim)])xlabel('Iteration');ylabel(['Best score F' num2str(Function_name) ]);axis tightgrid onbox onset(gcf,'Position',[400 200 400 250])legend(Optimal_results{1, :})

接下来,简单试验一下

dim = 2结果:

图片

dim = 10结果:

图片

dim = 20结果:

图片

完整Matlab代码下载

该代码一举歼灭所有群智能优化算法在cec2021测试函数的应用

该代码一举歼灭所有群智能优化算法在cec2021测试函数的应用

该代码一举歼灭所有群智能优化算法在cec2021测试函数的应用

实操cec2021测试函数(附Matlab代码)

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: 智能优化算法是一种基于计算智能原理和方法的算法,旨在通过优化搜索策略,提高求解问题的效率和准确性。CEC2020测试函数是计算智能领域中常用的一组标准测试函数,被广泛用于评估不同优化算法的性能。 对于智能优化算法在CEC2020测试函数上的测试,首先需要选择适当的智能优化算法作为测试算法,并确定测试问题的维度和优化目标。然后,将测试算法应用于CEC2020测试函数,通过迭代搜索的过程,找到最优解或接近最优解的解。 在测试过程中,需要记录和分析算法的收敛性能、收敛速度、最优解精度等指标。对于CEC2020测试函数中的每个函数,可以通过多次运行算法并取平均值的方式进行评估,以消除测试结果的随机性。 至于算法Matlab实现,可以根据测试算法的原理和步骤,利用Matlab编程语言开发相应的代码。在实现过程中,可以利用Matlab提供的向量化运算和优化工具箱,简化编码过程并提高算法效率。同时,为了便于测试和对比不同算法的性能,可以采用统一的接口和数据格式,以便于后续的分析和可视化展示。 综上所述,智能优化算法在CEC2020测试函数上的测试能够评估算法的优劣,为算法的应用和改进提供参考。通过Matlab实现测试算法,可以进一步加深对算法原理的理解,并为实际问题的求解提供可行的解决方案。 ### 回答2: 智能优化算法是一种基于计算机算法的方法,用于解决复杂问题中的优化问题。CEC2020是计算智能领域的一个国际竞赛,用于评估智能优化算法的性能和效果。CEC2020测试函数是一系列经过精心设计的函数,用于模拟真实世界的复杂问题,包括连续优化问题、多模态优化问题等。 智能优化算法在CEC2020测试函数上进行测试的目的是评估算法的搜索能力、收敛性能和鲁棒性等指标。通过对多个测试函数的优化结果进行对比和分析,可以评估算法的优劣,并进行参数调整和改进,提升算法的性能。 在Matlab中,可以实现多种智能优化算法来进行CEC2020测试函数的优化。常见的智能优化算法包括遗传算法(GA)、粒子群优化算法(PSO)、蚁群算法(ACO)等。这些算法都有相应的Matlab工具箱可以直接调用。 在实现时,可以定义CEC2020测试函数,并选择适当的智能优化算法和参数进行优化。通过迭代运行算法,并用测试函数的输出值来评估每一代的优化性能。最终,得到一个优化结果。 总之,对智能优化算法在CEC2020测试函数上的测试及其Matlab实现,是一项重要任务,可以帮助我们评估和改进智能优化算法的性能,并为解决复杂问题提供有力的工具和方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值