|
|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
; I* [1 ?1 @- i, E1 c' O
主要思想
* D, c5 J8 J7 S$ P# p
& R, n" q0 |' }* T! `$ v1 h
. u1 ~3 ?- H% d- i2 V+ ~' h# _5 {. e! m0 P
流程图$ F9 @8 E2 G1 k3 D, [- b
( B) M2 L" `) R- u: \, ^$ {4 y
) u- \/ Z- v) C
$ B0 q& {9 |9 y* M9 k/ w- w
% W! O$ p A$ zMATLAB代码
- Z2 y" x" J) t. H( S) w* a
% m- h" ]3 z; {- 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
6 T- w! g3 d' {3 G$ m! f8 i$ d
% t" |) X; ^/ t! ^5 w Q
# ]# |% E2 k! m3 K评价函数:
% o* p8 Q5 Q) h
) t3 i! _/ Z6 y0 ]- 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;
- end8 D9 G" q# P( ]: Q9 e
. I) |4 P7 Y( V1 p# [) W Q
, C5 a/ |2 R2 H/ Y
|
|