function obj = exponential(obj,options)
% exponential - computes the overapproximation of the exponential of a system 
%    matrix up to a certain accuracy
%
% Syntax:
%    obj = exponential(obj)
%
% Inputs:
%    obj - linearSys object
%    options - reachability options
%
% Outputs:
%    obj - linearSys object
%
% Example: 
%    -
%
% References: 
%   [1] M. Althoff, C. LeGuernic, and B. Krogh
%       "Reachable Set Computation for Uncertain Time-Varying
%           Linear Systems", HSCC'11.
%
% Other m-files required: none
% Subfunctions: none
% MAT-files required: none
%
% See also: ---

% Authors:       Matthias Althoff
% Written:       07-May-2007 
% Last update:   10-August-2010
%                03-September-2013
%                21-April-2020 (added reference for remainder)
% Last revision: ---

% ------------------------------ BEGIN CODE -------------------------------
   
%load data from object/options structure
A=obj.A;
A_abs=abs(A);
taylorTerms=options.taylorTerms;
n=obj.dim;
factors = options.factor;

%initialize 
Apower{1}=A;  
Apower_abs{1}=A_abs; 
M = eye(n);
    
%compute powers for each term and sum of these
for i=1:taylorTerms
    %compute powers
    Apower{i+1}=Apower{i}*A;
    Apower_abs{i+1}=Apower_abs{i}*A_abs;
    M = M + Apower_abs{i}*factors(i);
end   
%determine error due to finite Taylor series, see Prop. (2) in [1]
W=expm(A_abs*options.timeStep)-M;
%compute absolute value of W for numerical stability
W=abs(W);
E=interval(-W,W);
    
%write to object structure
obj.taylor.powers=Apower;
obj.taylor.error=E;    

% ------------------------------ END OF CODE ------------------------------
