当前位置: 首页 > news >正文

五种多目标优化算法(MOGWO、MOJS、NSWOA、MOPSO、MOAHA)性能对比,包含6种评价指标,9个测试函数(提供MATLAB代码)

一、5种多目标优化算法简介

1.1MOGWO

1.2MOJS

1.3NSWOA

1.4MOPSO

1.5MOAHA

二、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('./MOJS/')%添加算法路径
addpath('./MOGWO/')%添加算法路径
addpath('./NSWOA/')%添加算法路径
addpath('./MOPSO/')%添加算法路径
addpath('./MOAHA/')%添加算法路径
%%
% TestProblem测试问题说明:
%一共9个多目标测试函数1-9分别是: zdt1 zdt2 zdt3 zdt4 zdt6 Schaffer  Kursawe Viennet2 Viennet3
%%
TestProblem=9;%测试函数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] = MOGWO(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:5Fbest=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)以ZDT3为例:

(2)以Viennet3为例:

三、完整MATLAB代码

http://www.lryc.cn/news/306151.html

相关文章:

  • istio实战:springboot项目在istio中服务调用
  • 随机分布模型
  • Visual Studio:Entity设置表之间的关联关系
  • 每日五道java面试题之spring篇(二)
  • 287.【华为OD机试真题】字符串序列判定(贪心算法—JavaPythonC++JS实现)
  • Sentinel微服务流量治理组件实战上
  • Three.js加载PLY文件
  • chrome闪退后打不开问题 打开立即闪退
  • Slave被误写入数据如何恢复到主库
  • kafka生产者
  • 前后端分离Vue+node.js在线学习考试系统gqw7o
  • 关于el-select值的回显问题 : 框内显示label值还是value值
  • MCU多核异构通信原理
  • 在autodl搭建stable-diffusion-webui+sadTalker
  • 【办公类-16-10-01】“2023下学期 中4班 自主游戏观察记录(python 排班表系列)
  • 机器学习:SVM算法(Python)
  • 基于yolov5的人脸口罩检测,可进行图像目标检测,也可进行视屏和摄像检测(pytorch框架)【python源码+UI界面+功能源码详解】
  • 2024如何恢复旧版的Chrome的主题样式
  • 【文生视频】Diffusion Transformer:OpenAI Sora 原理、Stable Diffusion 3 同源技术
  • Redis 服务集群、哨兵、缓存及持久化的实现原理和应用场景
  • 通过Redis增减库存避坑
  • Windows系统搭建Elasticsearch引擎结合内网穿透实现远程连接查询数据
  • Java爬虫使用JSoup获取静态资源图片
  • LeetCode 2433.找出前缀异或的原始数组
  • C++面试:系统网络性能评估与优化
  • Java适配器模式 - 灵活应对不匹配的接口
  • [ai笔记12] chatGPT技术体系梳理+本质探寻
  • Elasticsearch:使用 ELSER v2 进行语义搜索
  • 智慧农业之智能物流
  • Redis主从、哨兵、Redis Cluster集群架构