找回密码
 注册
关于网站域名变更的通知
查看: 386|回复: 1
打印 上一主题 下一主题

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

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2020-10-21 13:53 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x

; t. I& B8 O& Z7 S3 ]主要思想
, r' ^4 x# z1 ?" x! B% N( r8 W
6 D9 D* l, L: v 6 @% t% K* c! \( o: W

. Q4 @9 b1 a- O) `& c5 J9 {流程图' c. X. Z2 V6 ^  ]+ X$ z. _0 |, {: F0 ]" j

8 A. |$ }% E8 t  j9 O( u  M5 D
/ j) M/ d! k2 _; n$ c" v
" W4 W, [( K3 @/ B1 Z! r. h  Q
) l, P* x4 A( w0 l* G$ BMATLAB代码/ v; M- D6 G6 x# z4 i& V6 ]

- O5 N+ G; f8 n
  • 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 end7 o; T0 G0 h/ ^( p) ~1 a
                9 D1 s7 P6 t( B% W  N2 ^! ^
, a8 L5 Q6 [: e. E; X
评价函数:
# }" R% W( m6 n1 y6 i& E8 @) @2 t1 h
% F2 T1 g& S% O4 }
  • 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
    : i2 G" K; c  G

. c4 C$ T8 a/ o' x+ O, R
$ d7 X$ [4 x/ J' h  

该用户从未签到

2#
发表于 2020-10-21 14:48 | 只看该作者
基于迭代局部搜索和随机惯性权重的BA算法MATLAB实现(ILSSIWBA)
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-8-12 09:26 , Processed in 0.125000 second(s), 26 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表