基于迭代局部搜索和随机惯性权重的BA算法MATLAB实现(ILSSIWBA)

BA算法简介

http://www.omegaxyz.com/2019/02/12/ba-matlab/

该论文修改

作者在原有BA算法上进行3个修改

  1. 跳出局部最优(扰动个体)
  2. 使得算法变得稳定
  3. 脉搏和响度修改,平衡局部与全局搜索

主要思想

在这里插入图片描述

流程图

在这里插入图片描述

function [bestMin, bestID] = ILSSIWBA()
%A new bat algorithm based on iterative local search and stochastic inertia weight
 
%omegaxyz.com QQ: 644327005
 
clc;
%% 经典BA参数设置
 
t = 1; 
maxT = 100; %最大迭代次数
dim = 30; %问题的维度
sizep = 50; %种群大小
xmin = -0.5;
xmax = 0.5; %位置向量的范围
 
A = 0.6.*ones(sizep,1);    % 响度 (不变或者减小)
r = zeros(sizep,1);      % 脉冲率 (不变或增加))
Qmin = 0;         % 最小频率
Qmax = 1;         % 最大频率
 
%% 初始化
 
Lb = xmin*ones(1,dim);
Ub = xmax*ones(1,dim);
pop = Lb+(Ub-Lb).*rand(sizep,dim); %种群初始化
popv = zeros(sizep,dim);   % 速度
Q = zeros(sizep,1);   % 频率
 
pfitness = zeros(dim,1);
for i = 1:sizep
    pfitness(i) = evaluate2(pop(i,:)); %评价
end
[bestMin, bestID]=min(pfitness);
bestS = pop(bestID, :);
bestArchive = zeros(maxT,1);
 
%% 论文中的新策略参数
 
umin = 0.4; %The second modification (SIW method)
umax = 0.9;
sigma = 0.2;
 
R0 = 0.1; %The 3th modification
Rupper = 0.7;
A0 = 0.9;
Alower = 0.6;
 
 
 
%% 具体迭代过程
 
while t <= maxT
    for i = 1:sizep
        Q(i)=Qmin+(Qmin-Qmax)*rand();
        w = umin +(umax-umin)*rand()+sigma*randn(); %The second modification (SIW method)
        popv(i,:)=w*popv(i,:)+(pop(i,:)-bestS)*Q(i); %The second modification (SIW method)
        Stemp = pop(i,:)+popv(i,:);
        % 脉冲率
         if rand>r(i)
             Stemp=bestS-1+2*rand(1,dim);
         end
         fitTemp = evaluate2(Stemp);
         if (fitTemp<=pfitness(i))&&(rand()<A(i))
            pop(i,:) = Stemp;
            pfitness(i) = fitTemp;
            A(i) = (A0-Alower)/(1-maxT)*(t-maxT)+Alower; %The 3th modification
            r(i) = (R0-Rupper)/(1-maxT)*(t-maxT)+Rupper; %The 3th modification
         end
         if fitTemp <= bestMin
            bestID = i;
            bestMin = fitTemp;
         	bestS = Stemp;
         end
    end
    
    interX = bestS.*rand(); %The 1th modification (ILS method)
    interXfit = evaluate2(interX);
    if interXfit < bestMin
        bestMin = interXfit;
        bestS = interX;
        pop(bestID,:) = bestS;
        pfitness(bestID,:) = bestMin;
    else
        if exp(bestMin-interXfit) > rand()
            bestMin = interXfit;
            bestS = interX;
            pop(bestID,:) = bestS;
            pfitness(bestID,:) = bestMin;
        end
    end
    
    bestArchive(t) = bestMin;
    fprintf('GEN: %d  min: %.4f\n', t, bestMin);
    t = t +1;
end
 
 
end%.m end

评价函数:

function z = evaluate2(u)
%Weierstrass
 
dim= length(u);
sum_1=0;
sum_2=0;
sum_3=0;
a = 0.5;
b = 3;
for i=1:dim
    for k=0:30
       sum_1=sum_1+(a^k)*(cos(2*pi*(b^k)*(u(i)+0.5)));
    end
    sum_2=sum_2+sum_1;
    sum_1 = 0;
end
for k=0:30
       sum_3=sum_3+(a^k)*(cos(2*pi*(b^k)*0.5));
end
z=sum_2-dim*sum_3;
end

更多内容访问omegaxyz.com
网站所有代码采用Apache 2.0授权
网站文章采用知识共享许可协议BY-NC-SA4.0授权
© 2019 • OmegaXYZ-版权所有 转载请注明出处

迭代自适应算法(Iterative Adaptive Algorithm, IAA)是一种用于信号处理和图像处理的算法,它可以用来恢复或增强噪声或失真的信号或图像。IAA算法是在迭代过程中根据当前的估计结果来自适应地更新估计参数,以达到更好的恢复或增强效果。 IAA算法的核心思想是通过迭代的方式,将预测误差与原始信号或图像的局部特征结合起来,不断调整估计参数,使得估计结果逼近原始信号或图像。而IAA算法能够根据误差的大小和特征的变化自适应地调整参数,具有较好的自适应性和鲁棒性。 在Matlab中,可以使用IAA算法进行信号或图像的恢复或增强。首先,需要将原始信号或图像进行分析,获取局部特征信息。然后,在迭代过程中根据误差和特征信息来调整估计参数,逐步改善估计结果。最后,根据迭代结果生成恢复或增强后的信号或图像。 使用Matlab进行IAA算法实现时,可以利用图像处理或信号处理工具包中的函数和工具,如MATLAB Image Processing Toolbox或MATLAB Signal Processing Toolbox。通过调用这些函数,结合IAA算法的核心思想,可以较容易地实现IAA算法,并得到较好的恢复或增强效果。 总之,IAA算法是一种能够根据误差和特征信息自适应调整参数的信号处理和图像处理算法。在Matlab中,可以利用相关工具包中的函数和工具实现IAA算法,并获得较好的结果。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值