function text = benchmark_nonlinear_reach_ARCH23_laubLoomis()
% benchmark_nonlinear_reach_ARCH23_laubLoomis - example of 
%    nonlinear reachability analysis
%
% Syntax:
%    benchmark_nonlinear_reach_ARCH23_laubLoomis
%
% Inputs:
%    ---
%
% Outputs:
%    res - true/false
%

% Authors:       Matthias Althoff, Niklas Kochdumper
% Written:       27-March-2019
% Last update:   25-March-2023 (MW, use adaptive algorithm)
% Last revision: ---

% ------------------------------ BEGIN CODE -------------------------------


dim_x = 7;

% Parameters --------------------------------------------------------------

params.tFinal = 20;
x0 = [1.2; 1.05; 1.5; 2.4; 1; 0.1; 0.45];


% Reachability Analysis ---------------------------------------------------

R = cell(3,1);

% Initial set W = 0.1
W = 0.1;
params.R0 = polyZonotope(x0,W*eye(dim_x));

options1.alg = 'poly-adaptive';
% options1.verbose = true;

sys = nonlinearSys('laubLoomis1_ARCH23',@laubLoomis); 

tic
R{1} = reach(sys, params, options1);
tComp1 = toc;

width1 = 2*rad(interval(project(R{1}.timePoint.set{end},4)));
disp(['computation time of reachable set (W=0.1): ',num2str(tComp1)]);
disp(['width of final reachable set (W=0.1): ',num2str(width1)]);
disp(' ');


% Initial set W = 0.05
W = 0.05;
params.R0 = zonotope([x0,W*eye(dim_x)]);

options2.alg = 'lin-adaptive';
% options2.verbose = true;

sys = nonlinearSys('laubLoomis2_ARCH23',@laubLoomis); 

tic
R{2} = reach(sys, params, options2);
tComp2 = toc;

width2 = 2*rad(interval(project(R{2}.timePoint.set{end},4)));
disp(['computation time of reachable set (W=0.05): ',num2str(tComp2)]);
disp(['width of final reachable set (W=0.05): ',num2str(width2)]);
disp(' ');


% Initial set W = 0.01
W = 0.01;
params.R0 = zonotope([x0,W*eye(dim_x)]);

options3.alg = 'lin-adaptive';
% options3.verbose = true;

sys = nonlinearSys('laubLoomis3_ARCH23',@laubLoomis); 

tic
R{3} = reach(sys, params, options3);
tComp3 = toc;

width3 = 2*rad(interval(project(R{3}.timePoint.set{end},4)));
disp(['computation time of reachable set (W=0.01): ',num2str(tComp3)]);
disp(['width of final reachable set (W=0.01): ',num2str(width3)]);
disp(' ');


% Visualization -----------------------------------------------------------

colors = {colorblind('b'),colorblind('y'),colorblind('r')};

figure; hold on; box on;

% plot results over time
for k = 1:length(R)
    plotOverTime(R{k},4,'FaceColor',colors{k},'Unify',true);
end

% specs
plot([0,20],[4.5,4.5],'r--');
plot([0,20],[5,5],'r--');

xlabel('$t$','interpreter','latex');
ylabel('$x_4$','interpreter','latex');
axis([0,20,1.5,5.5]);

% text for .csv
text{1} = ['LALO20,W001,1,',num2str(tComp3),',',num2str(width3),', '];
text{2} = ['LALO20,W005,1,',num2str(tComp2),',',num2str(width2),', '];
text{3} = ['LALO20,W01,1,',num2str(tComp1),',',num2str(width1),', '];


% ------------------------------ END OF CODE ------------------------------
