function res = testLong_nonlinParamSys_reach_output
% testLong_nonlinParamSys_reach_output - tests if output equation works
%
% Syntax:
%    res = testLong_nonlinParamSys_reach_output
%
% Inputs:
%    -
%
% Outputs:
%    res - true/false
%
% Other m-files required: none
% Subfunctions: none
% MAT-files required: none
%
% See also: none

% Authors:       Mark Wetzlinger
% Written:       19-November-2022
% Last update:   ---
% Last revision: ---

% ------------------------------ BEGIN CODE -------------------------------

% assume satisfaction
res = true;

% model parameters
params.tFinal = 0.1;
params.R0 = zonotope(ones(2,1),0.05*eye(2));
params.U = zonotope(0,0.01);

% reachability settings
options.timeStep = 0.01;
options.taylorTerms = 4;
options.intermediateTerms = 4;
options.zonotopeOrder = 30;
options.alg = 'lin';
options.tensorOrder = 2;
options.tensorOrderOutput = 2;

% dynamic equation
f = @(x,u,p) [x(1)^2 - x(2) + p(1); x(2) - u(1)];
% linear output equation
g_lin = @(x,u,p) x(1) + x(2);
% quadratic output equation
g_quad = @(x,u,p) x(1) + x(2)^2;
% cubic output equation
g_cub = @(x,u,p) x(1) + x(2)^3;

% instantiate nonlinearSys objects
sys1 = nonlinParamSys('sys1',f,g_lin);
sys2 = nonlinParamSys('sys2',f,g_quad);
sys3 = nonlinParamSys('sys3',f,g_cub);

paramInt = {1,interval(0.99,1.01)};
for p=1:2
    % either numeric or interval as paramInt
    params.paramInt = paramInt{p};
    % reachability analysis
    reach(sys1,params,options);
    reach(sys2,params,options);
    options.tensorOrderOutput = 3;
    reach(sys3,params,options);
end

% ------------------------------ END OF CODE ------------------------------
