【Matlab群体智能算法第五期】基于改进Tent混沌映射的ITPSO算法(含完整matlab代码)

0.前言

        在第三期中,文章对基于Tent混沌映射的粒子群算法的原理及matlab代码复现进行讲解,与传统种群初始化方法,Tent能够提升初始种群的多样性及种群解的数量,从而提高算法求解效率。但Tent混沌映射在迭代后期容易衰退为周期序列。

1.改进Tent混沌映射策略原理

        为了进一步提升Tent混沌映射策略初始种群解的质量,文献[1]利用改进后的Tent混沌映射进行种群初始化操作,改进后Tent混沌映射如下所示:

z_{k+1}=\left\{\begin{matrix} 2*(z_{k}+0.1*rand(0,1)), if0\leq z_{k}< 0.5 \\ 2-2*(z_{k}+0.1*rand(0,1)), if0.5\leq z_{k}\leq 1\end{matrix}\right.

其中,k表示映射次数,z_{k}代表第k次映射的函数值。

        根据上述改进后Tent混沌映射公式,相应matlab代码如下:

%基于改进Tent映射的种群初始化
function x_apply = ITent_int(dim,a,Lb,Ub)
x(1,1)=rand(); %初始点

%根据Tent映射函数,生成后续初始种群
for i=1:dim-1
    if x(i)<a
        x(i+1)=2*(x(i)+0.1*rand);
    elseif x(i)>=a
        x(i+1)=2*(1-(x(i)+0.1*rand)) ;
    end
end

%获取在粒子边界约束内的种群解
x_apply=Lb+x.*(Ub-Lb);

%粒子边界约束检查
I=x_apply<Lb;
x_apply(I)=Lb(I);
U=x_apply>Ub;
x_apply(U)=Ub(U);
end

2.基于改进Tent混沌映射策略的ITPSO粒子群优化算法

        文章第一节中已经对改进后Tent策略的原理及matlab代码进行了相应的讲解及复现,现将改进后的Tent混沌映射策略与传统PSO算法相结合,并基于相应目标函数进行求解,以验证改进策略的可行性,具体matlab代码如下:

%% 基于改进Tent混沌映射的ITPSO粒子群算法主程序
clc;
clear all;
close all
%% 算法基本参数设置
c1=2; %学习因子1
c2=2;%学习因子2
w=0.7;%惯性权重
MaxDT=500;%最大迭代次数
D=3;%搜索空间维数(未知数个数)
N=30;%初始化群体个体数目
Lb=[-100,-100,-100];%种群解的下限
Ub=[100,100,100];%种群解的上限
Vmax=[1,1,1];%速度上限
Vmin=[-1,-1,-1];%速度下限
a=0.5;%Tent混沌系数,0~1之间
Best_f=[];pop=[];
%% 基于改进Tent混沌映射的种群初始化
for L=1:N
    pop(L,:) = ITent_int(D,a,Lb,Ub);
    Best_f(1,L)=fitness_obl(pop(L,:));
end
V=rand(N,D);
%计算各个粒子的适应度值并初始化Pi和Pg
[fitnessgbest bestindex]=min(Best_f);
gbest=pop(bestindex,:);
pbest=pop;
fitnesspbest=Best_f;
 
%% 粒子群算法更新迭代部分
for i=1:MaxDT
    for j=1:N
        %种群更新
        V(j,:)=w*V(j,:)+c1*rand*(pbest(j,:)-pop(j,:))+c2*rand*(gbest-pop(j,:));
        %更新速度边界检查
        I=V(j,:)<Vmin;
        V(j,I)=Vmin(I);
        U=V(j,:)>Vmax;
        V(j,U)=Vmax(U);
        pop(j,:)=pop(j,:)+V(j,:);
        %粒子边界检查
        PI=pop(j,:)<Lb;
        pop(j,PI)=Lb(PI);
        PU=pop(j,:)>Ub;
        pop(j,PU)=Ub(PU);
        %计算更新后种群的适应度函数值     
        Best_f(j)=fitness_obl(pop(j,:));
  
       %个体极值更新
       if Best_f(j)<fitnesspbest(j)
            pbest(j,:)=pop(j,:);
            fitnesspbest(j)=Best_f(j);
       end
 
       %全局极值更新
       if Best_f(j)<fitnessgbest
           gbest=pop(j,:);
           fitnessgbest=Best_f(j);  
       end
       
    end
   %记录粒子全局最优解
   Fgbest(i)=fitnessgbest;
   
end
%% 结果可视化
figure
plot(Fgbest)
title(['适应度曲线 ' '终止次数=' num2str(MaxDT)]);
xlabel('进化代数');
ylabel('适应度')

        为验证改进后算法的求解效果,本文将采用Tent策略改进前后及原始PSO算法寻优结果进行对比,采用测试函数与第1-4期测试函数相同,相关代码见:【Matlab群体智能算法第三期】基于Tent混沌映射的TPSO算法(含完整matlab代码)-CSDN博客

        基于上述目标函数,分别运行10次后,记录算法寻优结果的最大值、最小值及均值,已验证改进后算法的求解效率及鲁棒性。取ITPSO算法运行中某次的适应度曲线进行展示,观察算法的求解情况,求解结果如下:

图1 基于改进Tent映射的ITPSO算法迭代曲线

图2 基于Tent映射的TPSO算法迭代曲线

        根据上述适应度曲线可知,采用ITent混沌映射策略后,算法在迭代过程中有更好的初始解位置,其收敛至最优解的时间更快,求解效率更高。为进一步明确算法的求解性能,将运行10次后,各算法的适应度值进行展示,结果如下:

运行次数标准粒子群算法基于Tent映射改进后基于ITent映射改进后
10.08313.71E-298.94E-31
20.05475.55E-314.31E-32
30.02943.24E-287.70E-32
40.01192.26E-282.51E-30
50.04771.02E-288.64E-30
60.03993.00E-282.50E-31
70.04593.73E-291.34E-28
80.02358.03E-286.06E-28
90.00434.35E-291.18E-28
100.05328.26E-300.00E+00
均值0.039361.88215E-288.71164E-29
最小值0.00435.54668E-310
最大值0.08318.03128E-286.06452E-28

        从上述结果可知,在优化过程中,改进后的Tent混沌映射策略能够获得更精确的解,其求解过程中的均值、最小值及最大值均优于原始Tent混沌映射策略。而与传统PSO算法相比,TPSO算法及ITPSO算法均具有明显的提升,提高了算法的求解效率及算法的鲁棒性。

3.结语

        上述代码均为作者查阅文献学习之余复现总结,限于作者水平有限,相关代码及原理讲解难免存在疏忽之处,若有错误请大家指正,谢谢。

        您的关注是我最大的动力,本部分为对第三期内容的更新改进,仅涉及算法种群初始化部分,感谢大家耐心阅读。另,转载请注明出处,请勿以此进行二次售卖。

        作者主要更新方向为:

(1)智能算法复现及改进;

(2)微电网/综合能源系统容量配置、优化调度等方向

(3)时间序列预测(机器学习、深度学习方向)

相关参考文献:

[1] 毛清华,杨林,王艳亮.融合改进Tent混沌和模拟退火的灰狼算法[J].数学的实践与认识,2021,51(05):147-161.
往期传送门:

【Matlab群体智能算法第一期】粒子群算法及其变体(一)_matlab群运算-CSDN博客

【Matlab群体智能算法第二期】基于反向学习的改进粒子群算法(含matlab代码)-CSDN博客

【Matlab群体智能算法第三期】基于Tent混沌映射的TPSO算法(含完整matlab代码)-CSDN博客

【Matlab群体智能算法第四期】基于Tent混沌映射、自适应t分布和动态选择策略的TDPSO算法(含完整matlab代码)-CSDN博客

  • 8
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
在本文中,我们将介绍基于Matlab Tent混沌映射改进的麻雀搜索算法(SSA)优化BP神经网络回归预测的方法。 首先,我们需要了解SSA算法的基本原理。 SSA算法是一种模拟麻雀群体搜索行为的算法,其基本思想是根据自然界麻雀群体搜索食物的行为,通过一系列规则来对样本空间进行搜索,从而找到最优解。该算法具有搜索速度快、容易实现、不易陷入局部最优等优点,适用于复杂高维的优化问题。 然后,我们将该算法与BP神经网络相结合,进行对数据的回归预测。 BP神经网络具有良好的回归和分类能力,但在实际应用中需要对网络的参数进行优化才能达到最佳预测效果。我们将采用混沌优化的方法来对BP神经网络进行优化,其中使用Tent混沌映射对参数进行优化。 Tent混沌映射是一种简单易于实现的混沌映射算法,其基本原理是通过对函数进行迭代,将一个初始值转化为一组伪随机数。我们将使用该算法来优化BP神经网络中的参数,从而提高模型的预测精度。 最后,我们将实现该算法并在Matlab中对其进行测试和优化。在测试完成后,我们可以根据实验结果进行调整和优化,进一步提高我们模型的预测能力。 总之,该方法可以有效结合SSA和BP神经网络,在预测和优化问题中发挥重要作用,具备较高的实用价值和广泛应用前景。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值