%%
% Fig 18 in Sec C.5
% Showing that when f_0 have multiple potential wells, a unique invariant
% distribution can exist.
% f_0=k(x^2-1) for k=0.02
% f_1,eps=eps*sin(x/eps)



%%
k=0.02; % parameter in f_0
epsilon=0.0001;
eta=0.05;
f_0=@(x)k*(x.^2-1).^2;      % f_0, the object function with 2 potential wells
f_1=@(x)epsilon*sin(x/epsilon);
f=@(x)f_0(x)+f_1(x);
grad_0=@(x)k*4*x.*(x.^2-1); % gradient of f_0
grad_1=@(x)cos(x/epsilon);  % gradient of f_1
pts_init=1.2:0.00001:1.3;   % distribution of initial ensemble
pts=pts_init;
MAX=10000;                  % number of steps for evolving the ensemble
MAX_Orbit=100000;           % number of steps for evolving a single orbit
orbit_1=[];           
orbit_2=[];
%%
for i=1:MAX
    pts=pts-eta*grad_0(pts)-eta*grad_1(pts);    % evolving to get invariant distribution
    %pts=pts-eta*grad_0(pts)-eta*cos(rand(1,length(pts))*2*pi);
end

% Note that though start from different potential wells of f_0, the orbit
% converge to a same distribution
x_1=1.1;    % initial conditions in the right well of illustrative orbits
for i=1:MAX_Orbit
    x_1=x_1-eta*grad_0(x_1)-eta*grad_1(x_1);    % evolving for a single orbit
    orbit_1=[orbit_1,x_1];                      % save results for plotting
end
x_2=-1.1;   % initial conditions in the left well of illustrative orbits
for i=1:MAX_Orbit
    x_2=x_2-eta*grad_0(x_2)-eta*grad_1(x_2);    % evolving for a single orbit
    orbit_2=[orbit_2,x_2];                      % save results for plotting
end
%% plot the result
xbins=-1.5:0.1:1.5;
histogram(pts_init,xbins,'Normalization','pdf');
hold on;
histogram(pts,xbins,'Normalization','pdf');
set(gca,'FontSize',16);
xlabel('x')
ylabel('pdf');
ylim([0,1.2])
title('evolution of ensemble empirical distribution');
legend('initial distri.',['@ iteration #',num2str(MAX)]);
set(gcf,'Position',[400 300 800 600]);

figure
histogram(orbit_1,xbins,'Normalization','pdf');
set(gca,'FontSize',16);
title(['hist of an orbit over time (IC=',num2str(orbit_1(1)),')']);
xlabel('x')
ylabel('pdf')
ylim([0,1.2])
set(gcf,'Position',[400 300 800 600]);

figure
histogram(orbit_2,xbins,'Normalization','pdf');
set(gca,'FontSize',16);
title(['hist of another orbit over time (IC=',num2str(orbit_2(1)),')']);
xlabel('x')
ylabel('pdf')
ylim([0,1.2])
set(gcf,'Position',[400 300 800 600]);

figure
plot(orbit_1);
set(gca,'FontSize',16);
title(['one orbit (IC=',num2str(orbit_1(1)),')']);
xlabel('# of iteration');
ylabel('x');
axis([0 MAX_Orbit -1.9 1.9]);
set(gcf,'Position',[400 300 800 600]);


figure
plot(orbit_2);
set(gca,'FontSize',16);
xlabel('# of iteration');
ylabel('x');
xlim([0,MAX_Orbit])
title(['one orbit (IC=',num2str(orbit_2(1)),')']);
set(gcf,'Position',[400 300 800 600]);
