-
Notifications
You must be signed in to change notification settings - Fork 31
/
Copy pathplotGoldsteinPrice.m
87 lines (75 loc) · 2.75 KB
/
plotGoldsteinPrice.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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
function plotGoldsteinPrice(dataLog, iter)
% plotGoldsteinPrice(dataLog, iter)
%
% Used to display progress as the optimization progresses
%
% dataLog(iter) = struct array with data from each iteration
% .X = [n,m] = current position of each particle
% .V = [n,m] = current "velocity" of each particle
% .F = [1,m] = value of each particle
% .X_Best = [n,m] = best point for each particle
% .F_Best = [1,m] = value of the best point for each particle
% .X_Global = [n,1] = best point ever (over all particles)
% .F_Global = [1,1] = value of the best point ever
% .I_Global = [1,1] = index of the best point ever
%
global GoldsteinPriceContourHandle GoldsteinPricePopulationHandle
global GoldsteinPricePopBestHandle GoldsteinPriceGlobalHandle
figure(300); hold on;
%%%% Plot the function to be optimized
if isempty(GoldsteinPriceContourHandle)
x = linspace(-2,2,50);
y = linspace(-2,2,50);
[XX,YY] = meshgrid(x,y);
xx = reshape(XX,1,numel(XX));
yy = reshape(YY,1,numel(YY));
zz = [xx;yy];
ff = GoldsteinPrice(zz);
FF = reshape(ff,50,50);
GoldsteinPriceContourHandle = contour(XX,YY,sqrt(FF),15);
% Plot the solution:
plot(0,-1,'rx','LineWidth',3,'MarkerSize',20);
end
%%%% Plot current position
if isempty(GoldsteinPricePopulationHandle)
x = dataLog.X(1,:); %First dimension
y = dataLog.X(2,:); %Second dimension
GoldsteinPricePopulationHandle = plot(x,y,'k.','MarkerSize',10);
else
x = dataLog.X(1,:); %First dimension
y = dataLog.X(2,:); %Second dimension
set(GoldsteinPricePopulationHandle,...
'xData',x, 'yData',y);
end
%%%% Plot best position for each particle
if isempty(GoldsteinPricePopBestHandle)
x = dataLog.X_Best(1,:); %First dimension
y = dataLog.X_Best(2,:); %Second dimension
GoldsteinPricePopBestHandle = plot(x,y,'ko','MarkerSize',5,'LineWidth',1);
else
x = dataLog.X_Best(1,:); %First dimension
y = dataLog.X_Best(2,:); %Second dimension
set(GoldsteinPricePopBestHandle,...
'xData',x, 'yData',y);
end
%%%% Plot best ever position of the entire swarm
if isempty(GoldsteinPriceGlobalHandle)
x = dataLog.X_Global(1,:); %First dimension
y = dataLog.X_Global(2,:); %Second dimension
GoldsteinPriceGlobalHandle = plot(x,y,'bo','MarkerSize',8,'LineWidth',2);
else
x = dataLog.X_Global(1,:); %First dimension
y = dataLog.X_Global(2,:); %Second dimension
set(GoldsteinPriceGlobalHandle,...
'xData',x, 'yData',y);
end
%%%% Annotations
title(sprintf('Iteration: %d, ObjVal: %6.3g', iter, dataLog.F_Global));
xlabel('x1');
ylabel('x2');
%%%% Format the axis so things look right:
axis equal; axis(2*[-1,1,-1,1]);
%%%% Push the draw commands through the plot buffer
drawnow;
pause(0.05); %Slow down animation
end