Matlab群体智能优化算法之海象优化算法(WO)

news2025/1/18 17:00:41

文章目录

    • 一、灵感来源
    • 二、算法的初始化
    • 三、GTO的数学模型
      • Phase1:危险信号和安全信号
      • Phase2:迁移(探索)
      • Phase3:繁殖(开发)
    • 四、流程图
    • 五、伪代码
    • 六、算法复杂度
    • 七、WO搜索示意图
    • 八、实验分析和结果
      • 23个常见的基础测试函数
      • CEC2021测试函数
      • 实际工程优化问题

Walrus optimizer: A novel nature-inspired metaheuristic algorithm

Walrus optimizer: A novel nature-inspired metaheuristic algorithm

摘要:该文献Introduction介绍了为什么做这个元启发式算法的原因;Related works列举了2021-2023年一些算法。我将按照自己理解完全复现这篇文章,包括理论介绍、完整的实验部分。个人能力有限,如有不足,还请见谅。参考文献:Han M, Du Z, Yuen K, et al. Walrus Optimizer: A novel nature-inspired metaheuristic algorithm[J]. Expert Systems with Applications, 2023: 122413.

注:仅记录学习,如有侵权,联系删除。

  • 1、所写内容只是个人理解,如有错误,还请包涵
  • 2、所用主题为slandarer提供的墨滴模板
  • 3、CSDN:勉为其难免免
  • 4、微信公众号:飘散在人间的一缕青丝

一、灵感来源

  海象是海洋中除鲸鱼外最大的哺乳动物。海象主要生活在北极或附近的温带水域,海象是群居动物,过着两栖生活。海象群的数量从几十到几百到几千不等。它的身体是圆柱形的,粗壮而肥胖,头部扁平,枪口末端钝。在上唇周围有大约400根长而硬的胡须,带有血管和神经,导致触觉敏锐。海象最独特的特征是那对白色、发育良好的上犬齿,它们在其一生中不断生长,形成象牙。象牙可用于自卫,在泥沙中挖掘蛤蜊、虾和螃蟹等食物,或在冰上攀爬时支撑身体。

  海象庞大的身体看起来很笨重,但在水中很灵活。在众多的海洋动物中,海象是最好的潜水员。他们可以在水中潜水 20 分钟,深度为 500 m。海象潜入海底后可以在水下停留长达 2 小时,一旦需要新鲜空气,它们可以在 3 分钟内浮出水面。

  海象具有很强的社区意识,如下所示:

  (1)、当繁殖季节开始时,海象会在海滩上建立自己的领地。最好的位置被最强壮的男性占据。领土的面积根据男性占据的女性数量而变化。

  (2)、海象习惯于生活在阳光无法到达的海洋深水区。像蝙蝠和海豚一样,海象缺乏独特的视力;它们依靠合理的定位进行觅食,并通过与同龄人交流来共享食物信息。

  (3)、海象有很强的社交习惯,当它们在水中遇到虎鲸时,它们会采取集体防御策略来保护自己并帮助受伤的虎鲸。长期的生存斗争经验使海象无法放松警惕。在这一点上,两只海象充当警卫。一旦他们的同类受伤,他们就会去帮忙。

  受海象迁徙、繁殖、栖息和觅食行为的启发(如图1所示),我们首次提出了一种新的元启发式算法WO算法。这里需要澄清两个假设:

  (1)、海象种群通过危险和安全信号来判断种群行为。

  (2)、海象种群的行为和角色划分在海象算法中建模。具体来说,海象算法假设雄性、雌性和幼年海象之间的社会结构和相互作用。

海象行为和种群划分

  创新之处在于,海象群中的“义警”是影响象群方向的决定性因素。“治安队员”发出的[危险信号]及[安全信号],在[行动计划]的执行过程中起着关键作用。在WO中,“危险信号”用于确定WO是执行勘探阶段还是开发阶段。当“危险信号”满足一定条件时,海象群迁移到解空间内的新域,这是算法早期阶段的探索阶段。相反,海象群繁殖,这是算法后期的开发阶段。“安全信号”在开发阶段起着关键作用,它影响着海象是选择栖息行为还是觅食。其中,雄性海象、雌性海象和幼年海象在栖息行为中相互作用,使种群朝着有利于生存的方向移动;觅食行为包括典型的聚集和逃跑现象,这些现象由“危险信号”控制。在有序的警务环境中,海象群可以避免被捕食者捕获或死亡(落入局部最佳状态),并实现种群增长(寻找全局最佳状态)。

二、算法的初始化

  X代表WO种群矩阵, X i = ( x i , 1 , x i , 2 , . . . , x i , m ) X_{i}=(x_{i,1},x_{i,2},...,x_{i,m}) Xi=(xi,1,xi,2,...,xi,m)是WO的第i个成员(候选解)。
  F代表适应度函数值。
X = [ X 1 ⋮ X i ⋮ X N ] N × m = [ x 1 , 1 ⋯ x 1 , j ⋯ x 1 , m ⋮ ⋱ ⋮ ⋮ x i , 1 ⋯ x i , j ⋯ x i , m ⋮ ⋮ ⋱ ⋮ x N , 1 ⋯ x N , j ⋯ x N , m ] N × m X=\left[\begin{array}{c} X_{1} \\ \vdots \\ X_{i} \\ \vdots \\ X_{N} \end{array}\right]_{N \times m}=\left[\begin{array}{ccccc} x_{1,1} & \cdots & x_{1, j} & \cdots & x_{1, m} \\ \vdots & \ddots & \vdots & & \vdots \\ x_{i, 1} & \cdots & x_{i, j} & \cdots & x_{i, m} \\ \vdots & & \vdots & \ddots & \vdots \\ x_{N, 1} & \cdots & x_{N, j} & \cdots & x_{N, m} \end{array}\right]_{N \times m} X= X1XiXN N×m= x1,1xi,1xN,1x1,jxi,jxN,jx1,mxi,mxN,m N×m
x i , j = l b j +  rand  ⋅ ( u b j − l b j ) , i = 1 , 2 , … , N , j = 1 , 2 , … , m x_{i, j}=lb_{j}+\text { rand } \cdot\left(ub_{j}-lb_{j}\right), i=1,2, \ldots, N, j=1,2, \ldots, m xi,j=lbj+ rand (ubjlbj),i=1,2,,N,j=1,2,,m
F = [ F 1 ⋮ F i ⋮ F N ] N × 1 = [ F ( X 1 ) ⋮ F ( X i ) ⋮ F ( X N ) ] N × 1 F=\left[\begin{array}{c} F_{1} \\ \vdots \\ F_{i} \\ \vdots \\ F_{N} \end{array}\right]_{N \times 1}=\left[\begin{array}{c} F\left(X_{1}\right) \\ \vdots \\ F\left(X_{i}\right) \\ \vdots \\ F\left(X_{N}\right) \end{array}\right]_{N \times 1} F= F1FiFN N×1= F(X1)F(Xi)F(XN) N×1

  式中: x i , j x_{i, j} xi,j代表第i个成员的第j个变量的值;N是种群大小;m是维度;rand代表[0,1]之间的随机数; l b j lb_{ j} lbj代表下限; u b j ub_{ j} ubj代表上限。

三、GTO的数学模型

  海象种群分为成年和幼体,分别占种群的90%和10%。在成年海象中,雄性与雌性的比例为1:1。

Phase1:危险信号和安全信号

  海象在觅食和栖息时都非常警惕。会有1至2只海象作为警卫在周围巡逻,一旦发现意外情况,会立即发出危险信号。其中危险信号和安全信号定义如下:

 Dangersignal  = A ∗ R α = 1 − t / T A = 2 × α R = 2 × r 1 − 1 \begin{aligned} & \text { Dangersignal }=A^* R \\ & \alpha=1-t / T \\ & A=2 \times \alpha \\ & R=2 \times r_1-1 \end{aligned}  Dangersignal =ARα=1t/TA=2×αR=2×r11

  其中 A A A R R R是危险因子, α \alpha α随着迭代次数的增加,从1减小到0。  Levy  (  Dim  ) \text { Levy }(\text { Dim })  Levy ( Dim )Levy飞行 T T T是最大迭代次数。

  WO中危险信号对应的安全信号定义如下:
 Safetysignal  = r 2 \begin{aligned} & \text { Safetysignal }=r_2 \\ \end{aligned}  Safetysignal =r2
  其中 r 1 r_1 r1 r 2 r_2 r2是在[0,1]内的随机数。

Phase2:迁移(探索)

  当危险因子过高时,海象群会迁移到更适合种群生存的地区。在此阶段,海象位置更新如下:

X i , j t + 1 = X i , j t +  Migrationstep  X_{i, j}^{t+1}=X_{i, j}^t+\text { Migrationstep } Xi,jt+1=Xi,jt+ Migrationstep 
 Migrationstep  = ( X m t − X n t ) ∙ β ∙ r 3 2 \text { Migrationstep } =\left(X_m^t-X_n^t\right) \bullet \beta \bullet r_3{ }^2  Migrationstep =(XmtXnt)βr32
β = 1 − 1 1 + exp ⁡ ( − t − T 2 T × 10 ) \beta=1-\frac{1}{1+\exp \left(-\frac{t-\frac{T}{2}}{T} \times 10\right)} β=11+exp(Tt2T×10)1
  其中 X i , j t + 1 X_{i, j}^{t+1} Xi,jt+1是i个个体在第j个维度上的更新位置, X i , j t X_{i, j}^{t} Xi,jt是当前位置,Migration_step是海象运动的步长,从种群中随机选择两个警惕者,其位置对应于 X m t X_m^t Xmt X m n X_m^n Xmn, β \beta β是迁移步长控制因子,它随着迭代变化为平滑曲线, r 3 r_3 r3是在[0,1]内的随机数。

Phase3:繁殖(开发)

  与迁徙相反,当风险因素较低时,海象群倾向于在洋流中繁殖。在繁殖过程中,主要有两种行为,陆上栖息和水下觅食。数学模型如下。

  (1)栖息行为

  雄性、雌性和幼年海象是我们对种群成员的分类。他们有不同的方式来更新他们的立场。

  第 1 步:雄性海象的重新分布

  采用Halton序列分布进行雄性海象位置更新,可以扩大种群的搜索分布

  第 2 步:更新雌性海象的位置

  雌性海象受到雄性海象  Male  i , j t \text { Male }_{i, j}^t  Male i,jt和领头海象 X best  t X_{\text {best }}^t Xbest t的影响。随着迭代过程的进行,雌性海象逐渐减少对配偶的影响,而更多地受到领导者的影响。

 Female  i , j t + 1 =  Female  i , j t + α ∙ (  Male  i , j t −  Female  i , j t ) + ( 1 − α ) ∙ ( X best  t −  Female  i , j t ) \begin{aligned} \text { Female }_{i, j}^{t+1}= & \text { Female }_{i, j}^t+\alpha \bullet\left(\text { Male }_{i, j}^t-\text { Female }_{i, j}^t\right)+(1-\alpha) \\ & \bullet\left(X_{\text {best }}^t-\text { Female }_{i, j}^t\right) \end{aligned}  Female i,jt+1= Female i,jt+α( Male i,jt Female i,jt)+(1α)(Xbest t Female i,jt)

  第 3 步:更新幼年海象的位置

  种群边缘的幼年海象经常成为虎鲸和北极熊的目标。因此,幼年海象需要更新其当前位置以避免捕食。

 Juvenile  i , j t + 1 = ( O −  Juvenile  i , j t ) ∙ P O = X best  t +  Juvenile  i , j t ∙ L F \begin{aligned} & \text { Juvenile }_{i, j}^{t+1}=\left(O-\text { Juvenile }_{i, j}^t\right) \bullet P \\ & O=X_{\text {best }}^t+\text { Juvenile }_{i, j}^t \bullet L F \end{aligned}  Juvenile i,jt+1=(O Juvenile i,jt)PO=Xbest t+ Juvenile i,jtLF

  P是幼年海象的遇险系数,是[0,1]的随机数,O是参考安全位置,LF是基于 L ́evy分布的随机数向量,表示Levy运动。

Levy ⁡ ( a ) = 0.05 × x ∣ y ∣ 1 a σ x = [ Γ ( 1 + α ) sin ⁡ ( π α 2 ) Γ ( 1 + α 2 ) α 2 ( α − 1 ) 2 ] 1 α , σ y = 1 , α = 1.5 \begin{gathered} \operatorname{Levy}(a)=0.05 \times \frac{x}{|y|^{\frac{1}{a}}} \\ \sigma_x=\left[\frac{\Gamma(1+\alpha) \sin \left(\frac{\pi \alpha}{2}\right)}{\Gamma\left(\frac{1+\alpha}{2}\right) \alpha 2^{\frac{(\alpha-1)}{2}}}\right]^{\frac{1}{\alpha}}, \sigma_y=1, \alpha=1.5 \end{gathered} Levy(a)=0.05×ya1xσx=[Γ(21+α)α22(α1)Γ(1+α)sin(2πα)]α1,σy=1,α=1.5

  其中,其中x和y是两个正态分布变量, x   N ( 0 , σ x 2 ) x \mathrm{~N}\left(0, \sigma_x^2\right) x N(0,σx2) y   N ( 0 , σ x 2 ) y \mathrm{~N}\left(0, \sigma_x^2\right) y N(0,σx2) σ x \sigma_x σx σ y \sigma_y σy是标准差, Γ ( x ) = ( x + 1 ) ! \Gamma(x)=(x+1) ! Γ(x)=(x+1)!

  (2)觅食行为

  水下觅食包括逃跑和采集行为

  a) 逃跑行为

  海象在水下觅食时也会受到天敌的攻击,它们会根据同伴发出的危险信号逃离当前的活动区域。这种行为发生在WO的后期迭代中,对种群的一定程度的扰动有助于海象进行全局探索。
在这里插入图片描述

  其中, X 1 X_1 X1 X 2 X_2 X2是影响海象聚集行为的两个权重, X second  t X_{\text {second }}^t Xsecond t是第二只海象在当前迭代中的位置, ∣ X second  t − X i , j t ∣ \left|X_{\text {second }}^t-X_{i, j}^t\right| Xsecond tXi,jt 表示当前海象与第二只海象之间的距离,a和b为聚集系数, r 5 r_5 r5为随机数,位于[0,1], θ \theta θ取的值范围为0到π。

四、流程图

  在WO中,危险信号用于确定WO是执行勘探阶段还是开发阶段。当危险信号绝对值不小于1时,海象群迁移到解空间内的新域,即算法早期的探索阶段;相反,海象群繁殖,这是算法后期的开发阶段。安全信号在开发阶段起着关键作用,它影响着个体海象是选择栖息行为还是觅食行为。其中,觅食行为包括聚集和逃跑两种典型现象,它们受危险信号的控制。

WO流程图

五、伪代码

WO伪代码

六、算法复杂度

  在求解优化问题时,计算复杂度对于评估算法的效率非常有用,它取决于三个主要过程:初始化、适应度评估和解决方案的更新。初始化过程和更新机制的计算复杂度分别为O(N)和O(N × T)+ O(N × T × D),其中N为种群大小,T为最大迭代次数,D为给定问题的维数。因此,WO的计算复杂度为O(N ×( T +T × D +1))。算法在运行过程中临时占用的内存空间量可以用空间复杂度来衡量。WO算法的空间复杂度是在其初始化过程中考虑的任何时间使用的最大空间量。因此,WO算法的空间复杂度为 O(N × Dim)。

七、WO搜索示意图

  为了可视化所提出的算法的行为,本节显示了海象群行为的模拟。下图描绘了30个海象在三维空间中寻找单峰和多峰函数最优解的群体行为。红点表示全局最佳位置,其余为海象位置。当t=1时,海象在解空间中随机生成,散射范围较宽。随着迭代的继续,所有海象的搜索范围逐渐缩小。最后,所有海象都汇聚到红点上。单模态函数的搜索结果可以表明WO具有较好的开发能力,多模态函数的搜索结果可以反映WO较强的探索能力。(注:与文献中稍有不同的是我加了一个原函数图像,Sphere就是常见的测试函数F1,Rastrigin函数是F9,直接修改序号即可)

八、实验分析和结果

  写了很久笔记了,也没有写完整的实验。在这篇中,完整的复现一下。包括多次独立运行、对数据的统计、导入到excel、出图,锻炼一下,顺便缝缝补补自己以前的烂代码。整体的思路就按照这篇论文的来写吧。后续看到好看的图再补充吧。

  为了适当验证WO算法的性能,原作者进行了大量实验。

23个常见的基础测试函数

  1、定性分析

  使用几种单峰和多模态标准准则函数对WO的定性结果进行评估,并使用WO的4个不同标准对结果进行评估,包括搜索历史、第一智能体的轨迹、平均拟合度和收敛曲线。搜索历史图显示了海象个体在迭代期间访问的所有位置;轨迹图监控第一只海象在迭代过程中的变化情况;平均适应度图显示了海象种群的整体变化;收敛行为图记录了总体每次迭代后的最佳解。

  从23个基准测试中选出10个典型函数进行分析。从搜索历史可以看出,WO在处理不同情况时,包括促进多样化、探索解决方案空间的有利区域、开发最优位置邻域等,都呈现出相似的模式。(一旦涉及了位置绘图可视化,要么每个测试问题的维度设置为2,要么就是画图的时候选择前两个位置。在此我选择第二种方法)

  种群大小设置为30,迭代次数设置为400。从23个里面选择了十个来进行分析。

%% 定性分析23个基准测试函数
clear
clc
close all
populationSize = 30;
Max_iteration = 400;
selet_fcn = [1,3,7,8,10,12,14,15,18,21];
for i=1:length(selet_fcn)-5
    fn = 1;
    Function_name=strcat('F',num2str(selet_fcn(i)));
    [lb,ub,dim,fobj]=Get_Functions_details(Function_name);
    % dim = 2;
    % rng('shuffle');%根据当前时间初始化生成器,在每次调用 rng 后会产生一个不同的随机数序列。
    [Best_score,Best_pos,PO_cg_curve,All_Pos,fitness1st,fitnessallmean]=WO3(populationSize,Max_iteration,lb,ub,dim,fobj);
    %% 绘制定性分析图
    figure('NumberTitle','off','Color','w','Name','函数图像','Units','centimeters','Position',[4,15,40,7])
    tiledlayout(1,5);
    nexttile
    %绘制原图像
    fun_plot(Function_name)
    nexttile
    %搜索历史图
    fun_plot(Function_name);
    h = gca;
    h.Children(2).Visible = "off";
    hold on
    view(0,90)
    for i = 1:length(All_Pos)
        temp = All_Pos{i};
        scatter(temp(:,1),temp(:,2),12,'k')
    end
    title('Search history')
    box on
    grid on
    nexttile
    plot(fitness1st,'Color',[6, 253, 244]./255,'LineWidth',1.5)
    title('Trajectory in 1st agents')
    box on
    grid on
    nexttile
    plot(fitnessallmean,'Color',[28, 29, 252]./255,'LineWidth',1.5)
    title('average fitness of all agents')
    box on
    grid on
    nexttile
    semilogx(PO_cg_curve,'Color',[245, 42, 237]./255,'LineWidth',1.5)
    title('Convergence curve')
    box on
    grid on
end


  关于图搜索历史和第一智能体的迹和原文不一样,理解不到位。暂时先这样放着,待后续理解更透彻了再修改这个图。其实这个每跑一次产生的图都不一样,感兴趣的可以多跑几次试试。

  2、定量分析

  这部分仿真时,文中未明确说明种群大小和迭代次数,在此我设置种群大小为30,迭代次数为100。文中所提及的ABC、AOS、ChoA、FOA、SHO算法我暂时没有,在此我换四个其他算法,AEO、ARO、CHIO、FDA、SMA。为了节约时间,我独立运行了30次,并调用excel的com服务器将结果写在了excel表中。在此列出前四个函数的表格。对每一行的最小值进行的字体加粗,颜色设置为红色的处理。


%% 存储多个算法对比数据 平均值 最优值 最差值 中位数 标准差
clc
clear
close all
%% 加载实验数据
load 20231107_30_100_30_16_PM.mat
file_path=[pwd,'\AlgorithmComparison.xlsx'];%设置当前路径
try
    excelApp=actxGetRunningServer('Excel.Application');%如果Excel 服务器已经打开,返回其句柄
catch
    excelApp=actxserver('Excel.Application');%如果Excel服务器没有打开,则创建一个Excel服务器,并返回句柄
end
excelApp.Visible = true; % 使 Excel 可见
%% 添加一个新的工作簿
%如果存在test.xlsx文件,则打开文件,若不存在则创建一个,然后保存
if exist(file_path,'file')
    workbook=excelApp.Workbooks.Open(file_path);%打开 注意这里打开的必须是绝对路径
else
    workbook=excelApp.Workbooks.Add;%创建 创建工作簿的时候默认是1 在excel选项中设置
    workbook.SaveAs(file_path)%保存   
end

%% 使用默认的工作表
sheet = workbook.Sheets.Item(1);
%% 设置工作表的名称
sheet.Name = 'Algorithm Comparison';
%% 合并单元格并设置 "Comparative algorithms" 标题
% 假设总共有12个算法名称加上'Function'和'target'列,因此共14列
titleRange = sheet.Range('A1:R1'); % 直接指定从A1到N1的范围
titleRange.MergeCells = true;
titleRange.Value = 'Comparative algorithms';
titleRange.HorizontalAlignment = -4108;%使用 xlCenter 的数值 
titleRange.Font.Bold = true;
titleRange.RowHeight = 50;
titleRange.Font.Size = 24;
% 填充算法名称 从加载的数据中读取
for i = 1:length(algorithms)
    temp = strsplit(algorithms{i},'.');
    algorithms(i)=temp(1);
end
% algorithms = {'AEO', 'ACO', 'SSA', 'SSA', 'SSA', 'SSA', 'SSA', 'SSA', 'SSA', 'SSA', 'SSA', 'SSA'};
% 从第三列开始填充算法名称
for i = 1:length(algorithms)
    % 使用Excel列字母可以使得引用更加清晰
    colLetter = char('B' + i); % 因为算法从第三列开始,所以是 'B' + i
    rangeStr = sprintf('%s2', colLetter); % 生成范围字符串,如 'C2', 'D2', 等
    sheet.Range(rangeStr).Value = algorithms{i};
end
%% 假设有以下函数和指标
functions = {'F1', 'F2', 'F3', 'F4'};
metrics = {'Best', 'Worst', 'Avg', 'Std', 'Median'};
% 为函数名、指标和随机数据填充表格
% 为函数名、指标和随机数据填充表格
for i = 1:length(functions)
    % 合并相同函数名的单元格
    startRow = (i-1)*length(metrics)+3; % 函数开始的行号
    endRow = startRow + length(metrics) - 1; % 函数结束的行号
    mergeRangeStr = sprintf('A%d:A%d', startRow, endRow);
    mergeRange = sheet.Range(mergeRangeStr);
    mergeRange.MergeCells = true;
    mergeRange.Value = functions{i};
    mergeRange.VerticalAlignment = -4108;   % 垂直居中
    mergeRange.HorizontalAlignment = -4108; % 水平居中
    
    % 为每个指标生成并填充随机数据
    for j = 1:length(metrics)
        metricCell = sprintf('B%d', (i-1)*length(metrics)+j+2);
        sheet.Range(metricCell).Value = metrics{j};
        
        % 为每个指标的算法生成并填充随机数据
        % for k = 1:length(algorithms)
        %     dataCell = sprintf('%s%d', char('B' + k), (i-1)*length(metrics)+j+2);
        %     sheet.Range(dataCell).Value = rand();
        % end
    end
end
sheet.Range('A2').Value = 'Function';
sheet.Range('B2').Value = 'Target';
% 调整列宽
% 调整第一列和第二列的列宽
sheet.Range('A:A').ColumnWidth = 15;
sheet.Range('B:B').ColumnWidth = 15;

% 假设算法从第三列开始,一共有12个算法
% 调整算法列的列宽
for i = 3:(2+length(algorithms))
    colLetter = char('A' + i - 1); % 将列号转换为列字母
    sheet.Range([colLetter ':' colLetter]).ColumnWidth = 10;
end
%% 获取用过的范围(整个数据区域)
usedRange = sheet.UsedRange;
% 你现在可以对这个范围进行操作,比如设置单元格的格式
% 设置整个区域的单元格内容居中对齐
usedRange.HorizontalAlignment = -4108; % 水平居中
usedRange.VerticalAlignment = -4108; % 垂直居中
%% 设置字体颜色
% 找到最小值的位置
minall = min(comparealg,[],2);
[minindexX,minindexY]=find(comparealg==minall);

minLocations = [minindexX,minindexY]; % 最小值位置矩阵

% 转换最小值位置到 Excel 单元格地址并设置为红色
for i = 1:size(minLocations, 1)
    % 计算 Excel 单元格地址
    rowIndex = minLocations(i, 1) + 2; % +2 是因为数据从 C3 开始
    colIndex = minLocations(i, 2) + 2; % +2 是因为数据从第三列开始
    cellAddress = sprintf('%s%d', char('A' + colIndex-1), rowIndex);
    sheet.Range(cellAddress).Font.Color = 255; % 设置字体颜色为红色
    sheet.Range(cellAddress).Font.Bold = true; % 设置字体为加粗
end
% 假设每个函数的数据占据 5 行
numRowsPerFunction = 5;
numFunctions = 4; % F1, F2, F3, F4
startCol = 'A'; % 数据开始的列
endCol = 'R'; % 数据结束的列
startRow = 3; % 数据开始的行

% 加粗每个函数数据行的底部边框
for i = 1:numFunctions
    % 计算函数数据块的最后一行
    lastRow = startRow + i * numRowsPerFunction - 1;
    % 构建范围字符串
    rangeStr = sprintf('%s%d:%s%d', startCol, lastRow, endCol, lastRow);
    % 获取范围
    range = sheet.Range(rangeStr);
    % 设置底部边框样式为加粗
    range.Borders.Item('xlEdgeBottom').LineStyle = 1; % Continuous line
    range.Borders.Item('xlEdgeBottom').Weight = 4; % Thick weight
end
%% 存数据指定 Excel 范围
range = sheet.Range('C3:R22');
% 将数据一次性写入指定范围
range.Value = comparealg;
%% 保存工作簿 指定为绝对路径
workbook.Save();

%% 清理
workbook.Close();
excelApp.Quit();
excelApp.release;

两个变量

实验结果

  3、收敛性分析

  就是一个常规的迭代曲线图。文献中这么排版了,在此列出前四个函数。

%% 绘制迭代曲线
clear;clc;close all
addpath Algorithms\
addpath Algorithms\
cd Algorithms\
s = what;
algorithms = s.m;
cd D:\智能优化算法\WO\定量分析
SearchAgents_no = 30;
Max_iteration = 100;
figure('NumberTitle','off', ...
    'Color','w', ...
    'Name','迭代曲线对比图', ...
    'Units','centimeters', ...
    'Position',[4,15,40,7])
tiledlayout(1,4)
for j=1:4
    fn = j;
    Function_name=strcat('F',num2str(fn));
    [lb,ub,dim,fobj]=Get_Functions_details(Function_name);
    [Min_AEO,~, AEO_curve] = AEO(SearchAgents_no,Max_iteration,lb,ub,dim,fobj  );
    [Min_ARO,~, ARO_curve] = ARO(SearchAgents_no,Max_iteration,lb,ub,dim,fobj );
    [Min_BOA,~, BOA_curve] =GWO(SearchAgents_no,Max_iteration,lb,ub,dim,fobj);
    [Min_BWOA,~, BWOA_curve]=BWOA(SearchAgents_no,Max_iteration,lb,ub,dim,fobj);
    [Min_CHIO,~, CHIO_curve]=CHIO(SearchAgents_no,Max_iteration,lb,ub,dim,fobj);
    [Min_FDA,~, FDA_curve]=FDA(SearchAgents_no,Max_iteration,lb,ub,dim,fobj);
    [Min_GA,~, GA_curve]=GA(SearchAgents_no,Max_iteration,lb,ub,dim,fobj);
    [Min_GWO,~, GWO_curve]=GWO(SearchAgents_no,Max_iteration,lb,ub,dim,fobj);
    [Min_MFO,~, MFO_curve]=MFO(SearchAgents_no,Max_iteration,lb,ub,dim,fobj);
    [Min_PSO,~, PSO_curve]=PSO(SearchAgents_no,Max_iteration,lb,ub,dim,fobj);
    [Min_SCSO,~, SCSO_curve]=SCSO(SearchAgents_no,Max_iteration,lb,ub,dim,fobj);
    [Min_SMA,~, SMA_curve]=SMA(SearchAgents_no,Max_iteration,lb,ub,dim,fobj);
    [Min_SOA,~, SOA_curve]=SOA(SearchAgents_no,Max_iteration,lb,ub,dim,fobj);
    [Min_SSA,~, SSA_curve]=SSA(SearchAgents_no,Max_iteration,lb,ub,dim,fobj);
    [Min_WO,~, WO_curve]=WO(SearchAgents_no,Max_iteration,lb,ub,dim,fobj);
    [Min_WOA,~, WOA_curve]=WOA(SearchAgents_no,Max_iteration,lb,ub,dim,fobj);
    nexttile
    semilogy(AEO_curve)
    hold on
    semilogy(ARO_curve);semilogy(BOA_curve);semilogy(BWOA_curve);semilogy(CHIO_curve);
    semilogy(FDA_curve);semilogy(GA_curve);semilogy(GWO_curve);semilogy(MFO_curve);
    semilogy(PSO_curve);semilogy(SCSO_curve);semilogy(SMA_curve);semilogy(SOA_curve);
    semilogy(SSA_curve);semilogy(WO_curve,'r','LineWidth',2);semilogy(WOA_curve);
    xlabel('iteration')
    ylabel('fitness')
end

% 填充算法名称 从加载的数据中读取
for i = 1:length(algorithms)
    temp = strsplit(algorithms{i},'.');
    algorithms(i)=temp(1);
end
legnedpos = gca().Position;
legend(algorithms,'Position',legnedpos+[legnedpos(3)+0.003,0,-0.1,0])

  4、稳定性分析

  画了一个箱线图。在此列出matlab代码。

%% 稳定性分析
% 绘制箱线图
clc;clear;close all
% 加载独立运行得到的数据
load 20231107_30_100_30_16_PM.mat
% 填充算法名称 从加载的数据中读取
for i = 1:length(algorithms)
    temp = strsplit(algorithms{i},'.');
    algorithms(i)=temp(1);
end
% 绘制小提琴图
for i=1:4
    F1 = resultall{i};

    figure('NumberTitle','off', ...
        'Color','w', ...
        'Name','稳定性分析', ...
        'Units','centimeters', ...
        'Position',[4,15,30,7])
    handelbox = boxchart(F1);
    box on
    set(gca,'xticklabels',algorithms, ...
        'LineWidth',2)
    xlabel('Algorithm')
    ylabel('Fitness Value')
    grid on
    handelbox.BoxFaceColor = 'w';
    handelbox.BoxEdgeColor = 'b';
    handelbox.BoxMedianLineColor = 'r';
    handelbox.LineWidth = 2;
    handelbox.MarkerColor = 'r';
    handelbox.MarkerStyle = ".";
    handelbox.MarkerSize = 15;
    title(strcat('F',num2str(i)))
end

  5、灵敏性分析

  这个分析就是来寻找算法的最佳参数设置。文中选取了最大迭代次数,种群个数以及雄性个体占比三个参数。

  原文中,图7 ( a )和( b )分别展示了F1在不同的最大迭代次数和搜索代理数下的WO收敛曲线。图7 ( c )展示了WO在F5上的收敛曲线,以及不同比例的雄性个体在群体中的分布。计算结果和可视化表明,当最大迭代次数增加时,WO收敛到最优解。此外,从图7 ( b )可以看出,当种群数量的数量增加时,迭代次数减少。图7 ( c )显示了当p从0.3到0.4时WO的相对稳定的行为。基于此分析,p的最佳值可以被建议为其最大值(即p = 0.45),其中WO的结果最好。

clear ;clc;close all
%% F5 6 12 13 14 15
populationSize = [30,50,80,100];
Max_iteration = [200,500,1000,2000];
p = [0.3,0.35,0.4,0.45];
populationSize=populationSize(4);
p = p(4);
fn=1;
Function_name=strcat('F',num2str(fn));
[lb,ub,dim,fobj]=Get_Functions_details(Function_name);
colormap = ['k','m','c','b'];
figure('Color','w')
for i=1:length(Max_iteration)
    rng('shuffle');
    [Best_score,Best_pos,WO_cg_curve]=WO(populationSize,Max_iteration(i),lb,ub,dim,fobj,p);
    semilogy(WO_cg_curve,colormap(i),'LineWidth',2)
    hold on
    
end
set(gca,'XMinorGrid','on','YMinorGrid','on', ...
    'LineWidth',1)
legend({'T=200';'T=500';'T=1000';'T=2000'})
xlabel('Iteration')
ylabel('Best score obtained so far')


T(N=100,p=0.45)

clear ;clc;close all
%% F5 6 12 13 14 15
populationSize = [30,50,80,100];
Max_iteration = [200,500,1000,2000];
p = [0.3,0.35,0.4,0.45];
Max_iteration =Max_iteration(4);
p = p(4);
fn=1;
Function_name=strcat('F',num2str(fn));
[lb,ub,dim,fobj]=Get_Functions_details(Function_name);
colormap = ['k','m','c','b'];
figure('Color','w')
for i=1:length(populationSize)
    rng('shuffle');
    [Best_score,Best_pos,WO_cg_curve]=WO(populationSize(i),Max_iteration,lb,ub,dim,fobj,p);
    semilogy(WO_cg_curve,colormap(i),'LineWidth',2)
    hold on
    
end
set(gca,'XMinorGrid','on','YMinorGrid','on', ...
    'LineWidth',1)
% legend({'T=200';'T=500';'T=1000';'T=2000'})
legend({'N=30';'N=50';'N=80';'N=100'})
% legend({'T=200';'T=500';'T=1000';'T=2000'})
xlabel('Iteration')
ylabel('Best score obtained so far')

N(T=2000,p=0.45)

clear ;clc;close all
%% F5 6 12 13 14 15
populationSize = [30,50,80,100];
Max_iteration = [200,500,1000,2000];
p = [0.3,0.35,0.4,0.45];
populationSize=populationSize(4);
Max_iteration =Max_iteration(4);
fn=5;
Function_name=strcat('F',num2str(fn));
[lb,ub,dim,fobj]=Get_Functions_details(Function_name);
colormap = ['k','m','c','b'];
figure('Color','w')
for i=1:length(p)
    rng('shuffle');
    [Best_score,Best_pos,WO_cg_curve]=WO(populationSize,Max_iteration,lb,ub,dim,fobj,p(i));
    semilogy(WO_cg_curve,colormap(i),'LineWidth',2)
    hold on
    
end
set(gca,'XMinorGrid','on','YMinorGrid','on', ...
    'LineWidth',1)
% legend({'T=200';'T=500';'T=1000';'T=2000'})
% legend({'N=30';'N=50';'N=80';'N=100'})
legend({'P=0.30';'P=0.35';'P=0.40';'P=0.45'})
xlabel('Iteration')
ylabel('Best score obtained so far')

p(T=2000,N=100)

  从上面三幅图中可以看出,T,N,P三个参数都有影响。种群个数和迭代次数的增加会导致算法时间上的增加,在做具体案例分析时,应该选择合适的迭代次数和种群个数;P值的影响不会特别大,按照原文献的介绍,我也用F5测试函数,想要达到文献的效果。是需要多次运行的,这些P值在解决具体问题的时候,个人觉得不会影响特别大。P在[0.30,0.45]之间都可以。源代码上P值默认设置的是0.4。

  6、可扩充性分析

  通过改变F1 ~ F13的维度来测试所提出的WO的可扩展性,以确定增加维度对不同测试函数计算结果的影响。测试函数的维度分别为50、100、500。文献中对其进行了大量分析,用了13个测试函数,做了三个表格,感兴趣的可以参考一下。最后对所有算法进行Friedman检验,做了一个排名,证明了所提算法的优越性。

这张图截取自原文献
  结果表明,WO排在第一位,而SCSO、SHO和WOA分别排在第二位、第三位和第四位。

CEC2021测试函数

  测试函数下载地址

  这节中,作者又换了几个算法。做了定量分析,收敛性分析和稳定性分析。我不再重复绘图了。在这简单说一下CEC系列的函数怎么使用吧。CEC系列的测试函数有很多,一般下载下来就会给你编译好的matlab可执行文件,后缀名.mexw64。以CEC2017为例

  1. run the following command in Matlab window:
mex cec17_func.cpp -DWINDOWS

  2. Then you can use the test functions as the following example:
f = cec17_func(x,func_num);
here x is a D*pop_size matrix.

一个简单的说明

实际工程优化问题

六个经典的案例

SNS for Eng Prob

  经典工程优化malab代码下载链接

  注:原文已经进行大量实验结果分析,感兴趣的请阅读原文,学习学习一篇好的论文是怎么写的。源代码也已公开,我就不点运行和截图了,大家自行下载。

  特别提示:不要买什么基本的算法,这些算法都是全网公开的,优秀的东西从来都不保密,不怕任何人抄袭的,各位不要再交智商税了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1224849.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Kafka(四)消费者消费消息

文章目录 如何确保不重复消费消息?消费者业务逻辑重试消费者提交自定义反序列化类消费者参数配置及其说明重要的参数session.time.ms和heartbeat.interval.ms和group.instance.id增加消费者的吞吐量消费者消费的超时时间和poll()方法的关系 消费者消费逻辑启动消费者…

哈希

欢迎来到Cefler的博客😁 🕌博客主页:那个传说中的man的主页 🏠个人专栏:题目解析 🌎推荐文章:题目大解析(3) 目录 👉🏻unordered系列关联式容器un…

探索NLP中的核心架构:编码器与解码器的区别

❤️觉得内容不错的话,欢迎点赞收藏加关注😊😊😊,后续会继续输入更多优质内容❤️ 👉有问题欢迎大家加关注私戳或者评论(包括但不限于NLP算法相关,linux学习相关,读研读博…

【刷题专栏—突破思维】LeetCode 138. 随机链表的复制

前言 随机链表的复制涉及到复制一个链表,该链表不仅包含普通的next指针,还包含random指针,该指针指向链表中的任意节点或空节点。 文章目录 原地修改链表 题目链接: LeetCode 138. 随机链表的复制 原地修改链表 题目介绍&#xf…

Arduino驱动LM35线性温度传感器(温湿度传感器)

目录 1、传感器特性 2、控制器和传感器连线图 3、驱动程序 LM35半导体的温度传感器,可以用来对环境温度进行定性的检测。LM35半导体温度传感器是美国国家半导体公司生产的线性温度传感器。其测温范围是-40℃到150℃,灵敏度为10mV/℃,输出电压与温度成正比。

亚马逊云Amazon OpenSearch Serverless“利刃在手,‘向量’八方“

全Serverless架构新价值 随着Amazon OpenSearch Serverless正式上线“商用”,亚马逊云科技的全栈“Serverless”应用架构也“初见雏形”,这也意味着,未来企业可以在亚马逊云科技之上简单和轻松的搭建完整的无服务器应用架构。 数据也显示&am…

【LeetCode刷题日志】225.用队列实现栈

🎈个人主页:库库的里昂 🎐C/C领域新星创作者 🎉欢迎 👍点赞✍评论⭐收藏✨收录专栏:LeetCode 刷题日志🤝希望作者的文章能对你有所帮助,有不足的地方请在评论区留言指正,…

Git配置代理:fatal: unable to access*** github Failure when receiving data from

~吐槽一下 github自从被微软收购以后,大多数情况没点科技上网都进不去了,还是怀念以前随时访问的时光。 我一直都是开着系统代理的,但是今天拉一个项目发现拉不下来了,报错: fatal: unable to access https://githu…

人工智能基础_机器学习044_逻辑回归代码实现与手动计算概率---人工智能工作笔记0084

上面我们已经把逻辑回归的公式,以及,公式对应的图形都画画出来了,然后我们再来看看 如何用代码实现 可以看到上面是代码,咱们自己去写一下 import numpy as np from sklearn.linear_model import LogistieRegression from sklearn import datasets # 训练数据和测试数据拆分…

浅析AcrelEMS-CIA机场智慧能源管平台解决方案-安科瑞 蒋静

1 概述 机场智慧能源管平台解决方案对机场范围内变电站内的高低压配电设备 、 发电机、变压器 、UPS、EPS 、广场照明 、 室内照明 、通风及排水等机电设备进行实时分布式监控和集中管理 , 实现无人值守 , 确保高速公路安全畅通 , 提高 自动化管理水平 , 降低机电设备的运行维…

联想笔记本电脑触摸板失灵了怎么办

这里写自定义目录标题 thinkbook笔记本电脑触摸板失灵 thinkbook笔记本电脑触摸板失灵 由于重装系统,导致笔记本的触控板失灵, 网上说的办法有 1、按键盘上的ctrlf6键,打开触控板功能:无效 2、设置——>设备——>触控板&am…

buuctf-web-p6 [NPUCTF2020]web 狗

java: HelloWorld.class import java.io.PrintStream;public class HelloWorld {public static void main(String[] paramArrayOfString){System.out.println("众所周知,你是一名WEB选手,掌握javaweb也是一项必备技能,那么逆向个java应…

央企太卷.....来自央企的7个面试题,一个一个生产难题

说在前面 在40岁老架构师尼恩的(50)读者社群中,最近小伙伴,面试央企、美团、京东、阿里、 百度、头条等大厂。 下面是一个小伙伴成功拿到通过了一个央企设计研究院一面面试,现在把面试真题和参考答案收入咱们的宝典。…

Git企业开发级讲解(五)

📘北尘_:个人主页 🌎个人专栏:《Linux操作系统》《经典算法试题 》《C》 《数据结构与算法》 ☀️走在路上,不忘来时的初心 文章目录 一、bug 分⽀二、删除临时分支三、小结 一、bug 分⽀ 假如我们现在正在 dev2 分⽀上进⾏开发…

LeetCode994.腐烂的橘子

看完题我觉得这不是和上一道岛屿的题一样简单嘛,然后写了将近2个小时才写出来,我的思路就是,用check()先对grid检查一下,是否有以下情况: (如果有1的周围都是空,则这个位置用不腐烂,…

清华学霸告诉你:如何自学人工智能?

清华大学作为中国顶尖的学府之一,培养了许多优秀的人才,其中不乏在人工智能领域有所成就的学霸。通过一位清华学霸的经验分享,揭示如何自学人工智能,帮助你在这场科技浪潮中勇往直前。 一、夯实基础知识 数学基础:学习…

【Qt开发流程】之HelloWorld程序

【Qt开发流程】之HelloWorld程序 目的编写程序新建项目文件说明及界面设计 程序运行及发布程序运行程序发布手动构建使用windeployqt进行构建 设置应用程序图标修改快捷键类型列表命令行编译程序命令行编译.ui文件自定义类项目模式及项目文件介绍项目模式项目文件 目的 从Hell…

vue --version无法显示,只弹出vs窗口

参考连接: nodejs环境配置(解压包)安装教程_nodejs解压版安装及环境配置_tubond的博客-CSDN博客 原因:环境没搞好,没有设置全局文件夹,node默认放在C盘了,C盘有权限。因为npm -i vue/cli创建…

2023最新最全【OpenMV】 入门教程

1. 什么是OpenMV OpenMV 是一个开源,低成本,功能强大的 机器视觉模块。 OpenMV上的机器视觉算法包括 寻找色块、人脸检测、眼球跟踪、边缘检测、标志跟踪 等。 以STM32F427CPU为核心,集成了OV7725摄像头芯片,在小巧的硬件模块上&a…

电磁场与电磁波part4--时变电磁场

1、采用洛伦兹条件使得矢量位 与标量位 分离在两个独立的方程中,且矢量位 仅与电流密度 有关,而标量位 仅与电荷密度 有关。 2、电磁能量守恒定理(坡印廷定理) 即减少的电磁能量电磁场所做的功流出的电磁能量 3、设u(r,t)是…