基于改进莱维飞行和混沌映射的粒子群算法(10种混沌映射随意切换),附matlab代码

 本篇文章对粒子群优化算法进行改进,首先通过引入混沌映射机制,对其群体进行初始化,增加粒子群个体的多样性;然后在粒子群个体的位置更新公式上引入改进的莱维飞行机制,提高搜索精度,帮助粒子群个体跳出局部最优。

可以选择1-10不同的映射,1-10分别为,tent、Logistic、Cubic、chebyshev、Piecewise、sinusoidal、Sine,ICMIC, Circle,Bernoulli。选择不同的数字可以随意切换。

先上结果图,在CEC2005函数上进行测试,种群个体设置为50个,循环次数为3000次。

ae08a74726aee78c6c04699df257e590.png

e122025606ab81d46b69c3e6f206cf69.png

273d81d9a9c156ad96b721198a56ee47.png

b96ea35c46e15bdf37af7df834f9e2df.png

614a86459af391bec6fd69204946302f.png

2ad3857e5595adbf00b18be6b704c693.png

c44278ee6016d87de75a0964bb86046c.png

d2826d3031640f91b716070705ac6ee7.png

4dae477ad01586bfefda0cbf5a84df41.png

379fec4300c48a0180b2e7d18bc30d9e.png

这里截选了前10个函数进行展示,可以看到改进前后在大部分函数在收敛速度和寻优精度上都有了很大的改进。

接下来讲一下改进的原理。

  1. 混沌映射

    依旧是采用之前文章提到的10种混沌映射,可以自由切换映射方法,本文选取的映射方法是Logistic映射,大家也可以自行更改。没看过之前文章的小伙伴可以看一下。10种混沌映射优化灰狼算法,可一键切换,可用于优化所有群智能算法,以灰狼算法为例进行介绍

  2. 改进的莱维飞行机制

    本文莱维飞行的添加并非如其他文章那样,直接在粒子更新的时候加上莱维系数,而是稍作改进,这样的效果也确实比直接加莱维系数要好。原理公式如下:

aea4104a2ab6bd14b6fd423023d3b4a5.png

其中 , α是步长缩放因子,Levy(β)是萊维随机路径。

9f2b5cbd437e51f5ca0477d4e52aea2e.png

改进的原理如下:

812aa3d3d1c7f8f8aec46f4d548ce237.png

b70d12d21bf2478ed36d31d29805ece5.png

其中α=0.01。

这么做的目的是将粒子群算法与莱维飞行进行优势互补,可以动态的调整每次寻优的比例系数。

代码如下:

clear
clc
close all
number='F10'; %选定优化函数,自行替换:F1~F23
% [lb,ub,D,y]:下界、上界、维度、目标函数表达式
[lb,ub,dim,fobj]=CEC2005(number);  
N=50; %种群规模
T=1000; %最大迭代次数%% 调用PSO算法
numm = 11;%% numm 混沌映射类型选择,1-10,tent、Logistic、Cubic、chebyshev、Piecewise、sinusoidal、Sine,ICMIC, Circle,Bernoulli,自由切换
%当numm等于11时,采用原始的随机数rand
% g 最佳位置
% gbest 最佳适应度值
% gb 收敛曲线
[g,gbest,gb]=PSO(numm,N,T,lb,ub,dim,fobj);
fprintf ('Best solution obtained by PSO: %s\n', num2str(g,'%e  '));
fprintf ('Best objective function value obtained by PSO: %e \n', gbest);%% 调用改进的PSO算法
numm = 1;%% numm 混沌映射类型选择,1-10,tent、Logistic、Cubic、chebyshev、Piecewise、sinusoidal、Sine,ICMIC, Circle,Bernoulli,自由切换
%当numm等于11时,采用原始的随机数rand
[chaosLPSOg,chaosLPSOgbest,chaosLPSOgb]=chaosLPSO(numm,N,T,lb,ub,dim,fobj);fprintf ('Best solution obtained by chaosLPSO: %s\n', num2str(chaosLPSOg,'%e  '));
fprintf ('Best objective function value obtained by chaosLPSO: %e \n', chaosLPSOgbest);%% Figurefigure1 = figure('Color',[1 1 1]);
G1=subplot(1,2,1,'Parent',figure1);
func_plot(number)
title(number)
xlabel('x')
ylabel('y')
zlabel('z')
subplot(1,2,2)
G2=subplot(1,2,2,'Parent',figure1);
CNT=20;
k=round(linspace(1,T,CNT)); %随机选CNT个点
% 注意:如果收敛曲线画出来的点很少,随机点很稀疏,说明点取少了,这时应增加取点的数量,100、200、300等,逐渐增加
% 相反,如果收敛曲线上的随机点非常密集,说明点取多了,此时要减少取点数量
iter=1:1:T;semilogy(iter(k),gb(k),'b-*','linewidth',1);
hold onsemilogy(iter(k),chaosLPSOgb(k),'g-p','linewidth',1);
grid on;
title('收敛曲线')
xlabel('迭代次数');
ylabel('适应度值');
box on
legend('PSO','chaoLOPSO')
set (gcf,'position', [300,300,800,350])

注意看第11行变量numm,可以选择1-10不同的映射,1-10分别为,tent、Logistic、Cubic、chebyshev、Piecewise、sinusoidal、Sine,ICMIC, Circle,Bernoulli。选择不同的数字可以随意切换。

获取完整代码方法,下方卡片回复关键词:LPSO

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MySQL数据库引擎及账号管理

目录 前言 二、MySQL数据库引擎 1.是什么 2.MySQL的核心 3.MySQL的存储引擎 a.InnoDB(MySQL默认引擎) b.ACID事务 c.四种隔离级别 d.MyISAM e.MEMORY(Heap) 4.存储引擎查看 三、命令行操作数据库 四、账号管理 前言 MySQL安装请看MySQL的安装…

Matlab学习-轨迹热力图绘制

Matlab学习-轨迹热力图绘制 参考链接: MathWork-scatter函数使用 问题需求: 需要将轨迹上的点另一维信息同时显示在图上,比如横纵向误差等,这个时候画轨迹与误差的热力图就能很好同时反应位置和定位误差之间的关系;…

一建建筑周超口袋书

第一部分 建筑工程技术1A414000 建筑工程材料[B-4,2021] 常见的高分子防水卷材有哪些?三元乙丙、聚氯乙烯、氯化聚乙烯、氯化聚乙烯-橡胶共混及三元丁橡胶防水卷材记忆技巧三单数年考试中,2011 年屋面女儿墙渗漏水处理,2015 年女儿墙防水识图找错&#…

【Linux】进程信号之信号的产生

进程信号 一 一、信号入门1、信号的一些特性2、信号的处理方式信号捕捉初识 3、Linux下的信号 二、信号的产生1、通过终端按键产生信号2、调用系统函数向进程发信号a、kill函数b、raise函数c、abort函数 3. 由软件条件产生信号4、硬件异常产生信号 结语 一、信号入门 什么是信号…

游游画U(秒用c++ string函数)

看到这道题&#xff0c;第一反应是简单的模拟&#xff0c;上手就写&#xff0c;后来看大佬代码&#xff0c;还是我太蠢了 我的&#xff1a; #include <bits/stdc.h> using namespace std; typedef long long LL;int main() {int n;cin>>n;string s ""…

基于ssm实现图书商城(spring+springmvc+mybatis)

一、项目功能 前台 图书基本展示,包括推荐图书展示和类图书类型展示.推荐图书包括条幅推荐,热销推荐和新品推荐.按照图书类型展示商品.图书详细信息展示.图书加入购物车.修改购物车内图书信息,例如数量等.用户登录.用户注册.修改个人信息,包括密码和收获信息.购物车付款.用户…

Java实现office办公文档在线预览(word、excel、ppt、txt等)

文章目录 一、官网下载openOffice 安装包&#xff0c;运行安装&#xff08;不同系统的安装请自行百度&#xff0c;这里不做过多描述&#xff09; 二、pom中引入依赖 三、office文件转为pdf流的工具类 四、service层代码 五、controller层代码 office办公文档&#xff0c;如doc…

Mysql数据库插入数据时提示 1366 - Incorrect string value: ‘\xE5\xBC\xA0\xE4\xB8\x89‘ 报错

背景&#xff1a; 在部署完成了mysql5.7.4数据库服务之后创建了mydb数据库&#xff0c;然后创建了如下的表&#xff1a; CREATE TABLE department(did int (4) NOT NULL PRIMARY KEY, dname varchar(20) );CREATE TABLE employee (eid int (4) NOT NULL PRIMARY KEY, ename var…

基于postman进行接口测试实战

目录 前言&#xff1a; 一&#xff1a;接口测试前准备 二&#xff1a;接口测试实战 三&#xff1a;理解cookie 四&#xff1a;接口测试实战之post接口 前言&#xff1a; 接口是不同软件系统之间进行通信和数据交换的关键要素。接口测试是一种测试方法&#xff0c;用于验证…

MySQL学习基础篇(八)---聚合函数

MySQL学习基础篇(八)—聚合函数 聚合&#xff08;或聚集、分组&#xff09;函数&#xff0c;它是对一组数据进行汇总的函数&#xff0c;输入的是一组数据的集合&#xff0c;输出的是单个值。 1. 聚合函数介绍 什么是聚合函数&#xff1a;聚合函数作用于一组数据&#xff0c;…

Kong(Without DB)的安装和基本使用

下载和安装 Docs 这里以Centos为例 sudo yum install kong-enterprise-edition-3.3.0.0.rpm配置 ​ Kong的官网提供了两个配置模式一个是 Using a database 另一个是使用 yaml配置文件的形式&#xff0c;安装好后默认配置文件默认是/etc/kong/kong.conf.default 二者对比 …

使用NLPAUG 进行文本数据的扩充增强

在机器学习中&#xff0c;训练数据集的质量在很大程度上决定了模型的有效性。我们往往没有足够的多样化数据&#xff0c;这影响了模型的准确性。这时数据增强技术就派上了用场。 数据增强可以通过添加对现有数据进行略微修改的副本或从现有数据中新创建的合成数据来增加数据量…