路径规划|多目标海洋捕食者算法(MOMPA)求解最短路径问题(Matlab代码实现)

news2024/11/19 13:44:02

 💥💥💥💞💞💞欢迎来到本博客❤️❤️❤️💥💥💥

🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰

🚀支持:🎁🎁🎁如果觉得博主的文章还不错或者您用得到的话,可以关注一下博主,如果三连收藏支持就更好啦!这就是给予我最大的支持!

                                                           

📋📋📋本文目录如下:⛳️⛳️⛳️

目录

1 概述

2 海洋捕食者算法

3 Matlab部分数值实验

5 多目标海洋捕食者算法(MOMPA)求解旅行商问题

5.1 旅行商知识

5.2 运行结果

6 Matlab代码实现


1 概述

本文提出了最近提出的海洋捕食者算法(MPA)的多目标版本,称为多目标海洋捕食者算法(MOMPA)。在此算法中,引入了一个外部归档组件来存储到目前为止找到的非主导帕累托最优解。基于精英选择方法,提出一种顶级捕食者选择机制,从档案中选择有效的解决方案作为顶级捕食者,模拟捕食者的觅食行为。利用CEC2019多模态多目标基准函数对所提算法的性能进行了评价,并与9种最先进的多目标元启发式算法进行了比较。此外,利用7个多目标工程设计问题(车侧撞击问题、齿轮系设计问题、焊接梁设计问题、盘式制动器设计问题、两条桁架设计问题、弹簧设计问题和悬臂梁设计问题)进一步验证了所提算法的有效性。结果表明,所提出的MOMPA算法不仅提供了非常有竞争力的结果,而且优于其他算法。

与单目标相比,多目标的最大优点是可以同时处理多个冲突目标,并获得一组帕累托最优解。解决方案集包含更有效的信息,可以为决策者提供更多的参考信息。与多目标算法相对应的单目标算法也相应发展起来。主要原因是单目标算法在解决复杂的多目标问题方面存在许多障碍。海洋捕食者算法(MPA)是Faramarzi等人最近提出的一种基于群智能的算法。该算法模拟了海洋捕食者的猎物狩猎行为,其中捕食者根据与猎物的相遇率,采用最优觅食策略。MPA算法具有参数少、计算速度快、计算精度高等特点,目前还没有多目标版本,因此可以考虑将其转换为多目标版本来解决多目标优化问题。各种多目标优化算法已在文献中列出,但根据NF定理,从逻辑上证明没有一种算法可以解决所有优化的问题,因此研究人员开发新的算法或增强现有算法的性能。该定理不仅适用于单目标优化算法,也适用于多目标优化算法。这也是这项工作的动机。基于海洋捕食者算法,提出一种新的多目标优化算法,即多目标海洋捕食者算法(MOMPA)。

2 海洋捕食者算法

本文结构如下:

1.存档组件集成到MPA中,以存储迄今为止发现的非主导帕累托最优解决方案。

2.提出一种顶级捕食者选择机制,从档案中选择相邻解数最少的解,并确定其作为群体搜索的指南。

3.通过使用上述两个组成部分,提出了MPA的多目标版本。

4.使用CEC2019多目标测试套件和七个工程设计问题评估了MOMPA的性能,并与几种最先进的多目标算法进行了比较。

本文的其余部分组织如下:第2节介绍了多目标优化问题的基本概念以及在多目标优化领域所做的相关研究工作。第3节介绍了海洋捕食者算法,并提出了一种多目标海洋捕食者算法。第4节介绍了多目标海洋捕食者算法。第5节介绍了结果和讨论。在第6节中,使用了七个工程示例来测试MOMPA的性能。此外,实验结果在第7节中进行了深入分析。最后,第8部分是对未来工作的总结和展望。

最近,Faramarzi等人提出了一种新的高效元启发式算法,称为海洋捕食者算法。该算法模仿海洋捕食者的行为,它们使用Levy和Brownian运动作为它们捕食猎物的最佳觅食机制。捕食者的觅食行为主要有三个阶段,根据捕食者和猎物之间的速度比不同而划分,Levy和Brownian运动将在这三个阶段交替进行,图1显示了捕食者三阶段觅食的示意图。当捕食者和猎物之间的速度比v很小,等于0.1时,捕食者的最佳失落策略是Levy运动,无论此时猎物是Levy运动还是布朗运动。此阶段是算法的探索阶段。当v近似等于1时,捕食者和猎物的速度相等,如果猎物以Levy步移,则捕食者以布朗步移。当速度比v大于10时,捕食者的最佳觅食策略是保持原位,而不管猎物的步长如何。

海洋捕食者具有很强的记忆力,使它们能够记住每次成功捕食的位置。此过程是通过在 MPA 中存储来实现的。迭代后,将每个解决方案与当前最佳解决方案进行比较,如果存在更好的解决方案,则将其替换为当前最佳解决方案。MPA 的算法流程如算法 2所示。

数学模型:

\text { Elite }=\left[\begin{array}{cccc} X_{1,1}^{I} & X_{1,2}^{I} & \cdots & X_{1, D}^{I} \\ X_{2,1}^{I} & X_{2,2}^{I} & \cdots & X_{2, D}^{I} \\ \vdots & \vdots & \vdots & \vdots \\ \vdots & \vdots & \vdots & \vdots \\ \vdots & \vdots & \vdots & \vdots \\ X_{N, 1}^{I} & X_{N, 2}^{I} & \cdots & X_{N, D}^{I} \end{array}\right]_{N \times D}

\text { Prey }=\left[\begin{array}{cccc} X_{1,1} & X_{1,1} & \cdots & X_{1, D} \\ X_{2,1} & X_{2,2} & \cdots & X_{2, D} \\ X_{3,1} & X_{3,2} & \cdots & X_{3, D} \\ \vdots & \vdots & \vdots & \vdots \\ \vdots & \vdots & \vdots & \vdots \\ X_{N, 1} & X_{N, 2} & \cdots & X_{N, D} \end{array}\right]_{N \times D}

\text { Elite }=\left[\begin{array}{cccc} X_{1,1}^{1} & X_{1,2}^{1} & \cdots & X_{1, D}^{1} \\ X_{2,1}^{2} & X_{2,2}^{2} & \cdots & X_{2, D}^{2} \\ \vdots & \vdots & \vdots & \vdots \\ X_{k, 1}^{k} & X_{k, 2}^{k} & \cdots & X_{k, D}^{k} \\ X_{k+1,1}^{1} & X_{k+1,2}^{1} & \cdots & X_{k+1, D}^{1} \\ \vdots & \vdots & \vdots & \vdots \\ X_{N, 1}^{m} & X_{N, 2}^{m} & \cdots & X_{N, D}^{m} \end{array}\right]_{N \times D}

详细数学模型及解释见第4部分。

3 Matlab部分数值实验

 

参考文献

[1] X. Zhang, Y. Tian, R. Cheng, and Y. Jin, An efficient approach to
nondominated sorting for evolutionary multiobjective optimization, IEEE
Transactions on Evolutionary Computation, 2015, 19(2): 201-213.
[2] X. Zhang, Y. Tian, R. Cheng, and Y. Jin, A decision variable
clustering based evolutionary algorithm for large-scale many-objective
optimization, IEEE Transactions on Evolutionary Computation, 2018, 22(1):
97-112.

5 多目标海洋捕食者算法(MOMPA)求解旅行商问题

5.1 旅行商知识

这篇博客总结过,很详细:运筹学——图论与最短距离

5.2 运行结果

function Draw_Path(Path,X)
%{输入:待画路线  城市的坐标位置;输出:旅行商的路线}

R =  [Path(1,:) Path(1,1)]; % 一共有n个城市,但是这里R有n+1个值,是为了让路径最后再回到起点
A = X(R,:);            %根据R将坐标顺序存入A中
row = size(A,1);       %实际上row=n+1

%% 绘图
figure;
hold on
plot(X(:,1),X(:,2),'ro')   %X(:,1),X(:,2)分别代表的X轴坐标和Y轴坐标

for i = 2:row
    [arrowx,arrowy] = dsxy2figxy(gca,A(i-1:i,1),A(i-1:i,2));    %dsxy2figxy坐标转换函数,记录两个点
    annotation('textarrow',arrowx,arrowy,'HeadWidth',3,'color',[1,0,1]); %将这两个点连接起来
end

hold off

%% 绘制路线图
figure(2);
xlabel('横坐标x')
ylabel('纵坐标y')
title('旅行商轨迹图')


end

6 Matlab代码实现

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

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

相关文章

LabVIEW在面向对象编程中利用硬件抽象层(HAL)设计1

LabVIEW在面向对象编程中利用硬件抽象层(HAL)设计1 LabVIEW面向对象编程(OOP)采用仪器为中心的硬件抽象层(HAL),使用面向对象的设计模式,可以部署一个仪器重用库,该库可以随着需求和仪器趋势的变化而增长,同时在不可避免的硬件过…

【Redis】主从复制

一、简介 1、什么是主从复制 主机数据更新后根据配置和策略,自动同步到备机的master/slave机制,Matser以写为主,Slave以读为主,简单来说如下图 2、主从复制的好处 读写分离:Matser以写为主,Slave以读为主…

指针的初步认识

🏖️作者:malloc不出对象 ⛺专栏:《初识C语言》 👦个人简介:一名双非本科院校大二在读的科班编程菜鸟,努力编程只为赶上各位大佬的步伐🙈🙈 目录前言一、指针是什么1.1 如何理解编址…

《深入分布式缓存-从原理到实践》笔记

《深入分布式缓存-从原理到实践》笔记 笔记作者:arthury.dy.lee 日期:2018.12.05 笔记只是本人觉得重要的部分的一些摘要或总结,更侧重于后5章。其它更详细内容,请自行买书阅读。 文章目录《深入分布式缓存-从原理到实践》笔记…

【Linux C】线程简单介绍

线程的概念 基本概念 进程:是指⼀个内存中运⾏的应⽤程序,每个进程都有⼀个独⽴的内存空间,⼀个应⽤程序可以同时运⾏多个进程;进程也是程序的⼀次执⾏过程,是系统运⾏程序的基本单位;系统运⾏⼀个程序即…

时序预测 | MATLAB实现具有外生回归变量的ARIMAX时间序列预测(含AR、MA、ARIMA、SARIMA、VAR对比)

时序预测 | MATLAB实现具有外生回归变量的ARIMAX时间序列预测(含AR、MA、ARIMA、SARIMA、VAR对比) 目录 时序预测 | MATLAB实现具有外生回归变量的ARIMAX时间序列预测(含AR、MA、ARIMA、SARIMA、VAR对比)预测效果基本介绍程序设计ARMAARMAARIMASARIMAARIMAXVAR参考资料预测效果…

LC-6260. 矩阵查询可获得的最大分数(最小堆,并查集+离线(海平面上升问题))【周赛323】

6260. 矩阵查询可获得的最大分数 难度困难7 给你一个大小为 m x n 的整数矩阵 grid 和一个大小为 k 的数组 queries 。 找出一个大小为 k 的数组 answer ,且满足对于每个整数 queres[i] ,你从矩阵 左上角 单元格开始,重复以下过程&#xf…

2022年了,你还没搞清楚箭头函数与普通函数的区别嘛?

目录 1.箭头函数简介 2.箭头函数与普通函数的区别 A.声明方式不同,匿名函数 B.this指向不同 C.箭头函数的this永远不会变,call、apply、bind也无法改变 D.箭头函数没有原型prototype E.箭头函数不能当成一个构造函数 F.箭头函数没有自己的argume…

javaSE(数据类型、运算、逻辑控制、方法)

1.初识Java JDK、JRE、JVM之间的关系? JDK(Java Development Kit):Java开发工具包,提供给Java程序员使用,包含了JRE,同时还包含了编译器javac与自带的调试工具Jconsole、jstack等。 JRE(Java Runtime Environment):Java运行时环…

LeetCode 1775. 通过最少操作次数使数组的和相等 --双指针

通过最少操作次数使数组的和相等 中等 174 相关企业 给你两个长度可能不等的整数数组 nums1 和 nums2 。两个数组中的所有值都在 1 到 6 之间(包含 1 和 6)。 每次操作中,你可以选择 任意 数组中的任意一个整数,将它变成 1 到 6 …

Android9.0以上系统安装Edxposed

说明:仅供学习使用,请勿用于非法用途,若有侵权,请联系博主删除 作者:zhu6201976 一、背景说明 Android9.0以前,Xposed框架可通过apk进行快速安装,github地址: GitHub - rovo89/Xpos…

CRACK:CAD Exchanger SDK 3.15.0/MAC/WIN/LINUX/Android

CAD Exchanger SDK用于读取、写入和可视化 3D CAD 文件的软件库 通过访问 CAD 和 BIM 数据,快速轻松地丰富您的 Web、服务器或桌面应用程序。Ω578867473 使用 CATIA、SOLIDWORKS、Creo、STEP、JT、IFC 以及来自 C、Python、C#、Java 和 JavaScript 的更多格式。 适…

人民日报强烈推荐的13本证书,含金量都很高!

人民日报每年都会推荐一些当代最具含金量的证书,并建议大学生在大学期间的时候着手准备,为毕业后的简历添加色彩。 本次,人民日报推荐的证书主要有下列13种: 01 CPA(注册会计师) 含金量:★★…

博客管理系统

大致思路 1. 引入的依赖 数据库 Maven Repository: mysql mysql-connector-java 5.1.47 (mvnrepository.com) <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java --><dependency><groupId>mysql</groupId><artifactId>mys…

centos7用容器搭建svn仓库和管理页面

文章目录安装docker拉取 svn 仓库管理镜像创建仓库使用仓库安装docker 安装 docker 服务 yum install -y docker 修改 docker 服务配置&#xff0c;添加镜像拉取加速路径 vim /etc/docker/daemon.json javascript {"registry-mirrors": ["http://f1361db2.m.da…

【网页期末作业】基于HTML学校教育网页项目的设计与实现

&#x1f389;精彩专栏推荐 &#x1f4ad;文末获取联系 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 &#x1f482; 作者主页: 【主页——&#x1f680;获取更多优质源码】 &#x1f393; web前端期末大作业&#xff1a; 【&#x1f4da;毕设项目精品实战案例 (10…

更自动化的开发----给开发插上恣意飞翔的翅膀!

总结&#xff1a; 设置启动项&#xff1a;开机时候快速启动自己所需要的程序&#xff0c;根据程序数量不一样&#xff0c;每天节省可重复的劳动时间约为5s-1min(此处数据为自己瞎说 O(∩_∩)O哈哈~)&#xff1b; 使用生成代码的插件&#xff1a;开发使用easycode的插件&#…

m基于多D2D通信对和多蜂窝用户的LTE预编码技术matlab仿真

目录 1.算法描述 2.仿真效果预览 3.MATLAB核心程序 4.完整MATLAB 1.算法描述 LTE网络中采用MIMO技术增加系统容量&#xff0c;提升吞吐率&#xff0c;从理论上来看,多天线的空分复用能成倍增加系统容量。但实际上并非如此,如&#xff0c;22MIMO的容量C&#xff08;容量&…

深度学习实验3 - 卷积神经网络

文章目录实验要求数据集定义1 手写二维卷积1.1 自定义卷积通道1.2 自定义卷积层1.3 添加卷积层导模块中1.4 定义超参数1.5 初始化模型、损失函数、优化器1.6 定义模型训练和测试函数&#xff0c;输出训练集和测试集的损失和精确度1.7 训练1.8 loss及acc可视化2 torch.nn 实现二…

一文打通ER图(手把手教你画)

期末了&#xff0c;E-R图也是大学课程设计中经常用到的&#xff0c;也是期末考的重点&#xff0c;毕竟大学生也没什么好考的&#xff0c;最近也有不少同学问&#xff0c;不少单子也扯到E-R图&#xff0c;但是我看了看网上的玩意好像没到手把手的地步&#xff0c;那么我就写一个…