一、5种多目标优化算法简介
1.1MSSA
![](https://file.jishuzhan.net/article/1760972828959576065/73409f7349520bcf1593f506179c4d0e.webp)
1.2MOJS
![](https://file.jishuzhan.net/article/1760972828959576065/ca442fad7075a5a15f6a0509beb81349.webp)
1.3NSWOA
![](https://file.jishuzhan.net/article/1760972828959576065/ae723fb97b9f9877d63a58be690fbf08.webp)
1.4MOPSO
![](https://file.jishuzhan.net/article/1760972828959576065/3f01ba3d8df8f5687580d64ea60c4255.webp)
1.5MOAHA
![](https://file.jishuzhan.net/article/1760972828959576065/23857bd3111cfd134771cd7fd2c3d052.webp)
二、5种多目标优化算法性能对比
为了测试5种算法的性能将其求解9个多目标测试函数(zdt1、zdt2 、zdt3、 zdt4、 zdt6 、Schaffer、 Kursawe 、Viennet2、 Viennet3),其中Viennet2 与Viennet3的目标数为3,其余测试函数的目标数为2,并采用6种评价指标(IGD、GD、HV、Coverage、Spread、Spacing)进行评价对比
2.1部分代码
close all;
clear ;
clc;
addpath('./MSSA/')%添加算法路径
addpath('./MOJS/')%添加算法路径
addpath('./NSWOA/')%添加算法路径
addpath('./MOPSO/')%添加算法路径
addpath('./MOAHA/')%添加算法路径
%%
% TestProblem测试问题说明:
%一共9个多目标测试函数1-9分别是: zdt1 zdt2 zdt3 zdt4 zdt6 Schaffer Kursawe Viennet2 Viennet3
%%
TestProblem=2;%测试函数1-9
MultiObj = GetFunInfo(TestProblem);
MultiObjFnc=MultiObj.name;%问题名
% Parameters
params.Np = 100; % Population size 种群大小
params.Nr = 200; % Repository size 外部存档
params.maxgen=50; % Maximum number of generations 最大迭代次数
numOfObj=MultiObj.numOfObj;%目标函数个数
%% 算法求解,分别得到paretoPOS和paretoPOF
[Xbest1,Fbest1] = MSSA(params,MultiObj);
[Xbest2,Fbest2] = MOJS(params,MultiObj);
[Xbest3,Fbest3] = NSWOA(params,MultiObj);
[Xbest4,Fbest4] = MOPSO(params,MultiObj);
[Xbest5,Fbest5] = MOAHA(params,MultiObj);
FbestData(1).data=Fbest1;
FbestData(2).data=Fbest2;
FbestData(3).data=Fbest3;
FbestData(4).data=Fbest4;
FbestData(5).data=Fbest5;
%% 获取测试函数的真实pareto前沿
True_Pareto=MultiObj.truePF;
%% 计算每个算法的评价指标
% ResultData的值分别是IGD、GD、HV、Coverage、Spread、Spacing
for i=1:5
Fbest=FbestData(i).data;
ResultData(i,:)=[IGD(Fbest,True_Pareto),GD(Fbest,True_Pareto),HV(Fbest,True_Pareto),Coverage(Fbest,True_Pareto),Spread(Fbest,True_Pareto),Spacing(Fbest,True_Pareto)];
end
%% 画图
PlotFigure;
2.2部分结果
(1)以ZDT2为例:
![](https://file.jishuzhan.net/article/1760972828959576065/2efc43b34f983b4f594b44756a20ced6.webp)
![](https://file.jishuzhan.net/article/1760972828959576065/c4efdbe51d9af2fbc13da4d52e377bd4.webp)
![](https://file.jishuzhan.net/article/1760972828959576065/ac6471947dc7fa80350b19a3e2f2ba9c.webp)
(2)以Viennet3为例:
![](https://file.jishuzhan.net/article/1760972828959576065/6a4eb21fe136fd363781e59de0893a66.webp)
![](https://file.jishuzhan.net/article/1760972828959576065/977061beced0645a5112bd0f591f53c4.webp)
![](https://file.jishuzhan.net/article/1760972828959576065/d2e27398a792718d8fe2694ddf95d087.webp)
三、完整MATLAB代码
![](https://file.jishuzhan.net/article/1760972828959576065/b5eaf7159127129d496530cef88d216c.webp)