function obj = inputTie(obj,options)
% inputTie - tie: time interval error; computes the error done by 
% the linear assumption of the constant input solution
%
% Syntax:
%    obj = inputTie(obj,options)
%
% Inputs:
%    obj - linearSys object
%    options - options struct
%
% Outputs:
%    obj - linearSys object
%
% Example: 
%
% Other m-files required: none
% Subfunctions: none
% MAT-files required: none
%
% See also: expm, inputSol

% Authors:       Matthias Althoff
% Written:       11-May-2009
% Last update:   13-November-2017
%                22-February-2018
% Last revision: ---

% ------------------------------ BEGIN CODE -------------------------------

% load data from object structure
Apower=obj.taylor.powers;
E = obj.taylor.error;
taylorTerms=options.taylorTerms;
r=options.timeStep;
n=obj.dim;

% initialize Asum
Asum_pos=zeros(n);
Asum_neg=zeros(n);

for i=2:(taylorTerms+1)
    % compute factor
    exp1=-i/(i-1); exp2=-1/(i-1);
    factor=(i^exp1-i^exp2)*options.factor(i); 
    
    % init Apos, Aneg
    Apos=zeros(n);
    Aneg=zeros(n);
    
    % obtain positive and negative parts
    pos_ind = Apower{i-1}>0;
    neg_ind = Apower{i-1}<0;
    
    Apos(pos_ind) = Apower{i-1}(pos_ind);
    Aneg(neg_ind) = Apower{i-1}(neg_ind);
    
    % compute powers; factor is always negative
    Asum_pos=Asum_pos + factor*Aneg; 
    Asum_neg=Asum_neg + factor*Apos;
end
% instantiate interval matrix
Asum = interval(Asum_neg,Asum_pos);

% compute error due to finite Taylor series according to internal document
% "Input Error Bounds in Reachability Analysis"
Einput = E*r;

%write to object structure
obj.taylor.inputF=Asum+Einput; %rewrite this equation when E is computed with the new method

% ------------------------------ END OF CODE ------------------------------
