-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathYSPSO.m
67 lines (56 loc) · 1.11 KB
/
YSPSO.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
function [ xm, fv ] = YSPSO( fitness, N, c1, c2, M, D )
%YSPSO 带压缩因子的粒子群算法
%待优化的目标函数:fitness
%粒子数目:N
%学习因子1:c1
%学习因子2:c2
%惯性权重:w
%最大迭代次数:M
%问题的维数:D
%目标函数取最小值时的自变量值:xm
%目标函数的最小值:fv
x = zeros(N, D);
v = zeros(N, D);
y = zeros(N, D);
p = zeros(1, N);
phi = c1 + c2;
if phi < 4
disp('c1与c2的和必须大于4!');
xm = NaN;
fv = NaN;
return;
end
format long;
for i=1:N
for j=1:D
x(i,j)=rand; %初始化微粒位置
v(i,j)=rand; %初始化微粒速度
end
end
for i=1:N
p(i) = fitness(x(i,:));
y(i,:) = x(i,:);
end
pg = x(N,:);
for i=1:N-1
if fitness(x(i,:)<fitness(pg))
pg = x(i,:);
end
end
for t=1:M
for i=1:N
ksi = 2/abs(2-phi-sqrt(phi^2 -4*phi));
v(i,:)=ksi*(v(i,:) + c1*rand*(y(i,:)-x(i,:)) + c2*rand*(pg-x(i,:)));
x(i,:)=x(i,:) + v(i,:);
if fitness(x(i,:)) < p(i)
p(i) = fitness(x(i,:));
y(i,:) = x(i,:);
end
if(p(i)<fitness(pg))
pg = x(i,:);
end
end
end
xm = pg';
fv = fitness(pg);
end