|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
$ A% g$ E- r5 o! F3 a1 v主要思想) |3 A- { l2 i" O
3 p6 B! L/ I6 e% Z
1 _/ }- d- Z8 z9 s0 b7 p, s
" O. h( N% f% _7 j( Q" }+ D流程图% G1 y7 S2 [5 T% W+ s4 [7 Q$ ~4 ]: n
. M& S8 e; v/ |# K1 b0 Z9 [; m+ c
: e. F: z/ _& d' x: W; M4 ?4 v: ]9 Z2 `) Z F% q
9 q; @. w' {2 L' s P
MATLAB代码
- `9 V% C& K& D2 U2 b% p( U W6 r# _' Z. o3 D# n2 O* q* Q3 C
- 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
- T1 g8 r& v$ B2 k1 l+ ]! D ' Y( ` @: u1 n2 h" l1 [, @
0 n7 J { Q2 v" I
评价函数:
* w6 x C0 Y# @0 m8 O8 J( D% r' Y) X9 T
- 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
" [! a) G" l( i/ L; G : ^0 e0 E. }) p% z
% V5 y4 P) e9 A |
|