function [vars,vars_der] = symVariables(varargin)
% symVariables - generates symbolic variables of a continuous system 
%
% Syntax:
%    [vars,vars_der] = symVariables(varargin)
%
% Inputs:
%    obj - contDynamics object
%    type - defines if 'LR' brackets should be used
%
% Outputs:
%    x - symbolic state variables
%    u - symbolic input variables
%    y - symbolic constraint variables
%    o - symbolic output variables
%    p - symbolic parameters
%    dx - symbolic state deviation form linearization point
%    du - symbolic input deviation form linearization point
%    dy - symbolic constraint deviation form linearization point
%    do - symbolic output deviation form linearization point
%
% Example: 
%    sys = contDynamics('test',3,1,2);
%    [vars,vars_der] = symVariables(sys);
%
% Other m-files required: none
% Subfunctions: none
% MAT-files required: none
%
% See also: 

% Authors:       Matthias Althoff
% Written:       18-January-2008
% Last update:   06-July-2017
%                05-November-2017
%                14-January-2018
%                19-November-2022 (MW, add outputs)
%                03-February-2023 (SM, real symbolic variables)
%                05-March-2024 (LL, consider nonlinearARX sys)
% Last revision: ---

% ------------------------------ BEGIN CODE -------------------------------

if nargin==1
    obj=varargin{1};
    type=[];
elseif nargin==2
    obj=varargin{1};
    type=varargin{2};
end

if strcmp(type,'LRbrackets')
    %generate symbolic states
    if isprop(obj,'dim') && obj.dim>0
        if isa(obj, 'nonlinearARX')
            dim_x = obj.dim * obj.nrOfOutputs;
        else
            dim_x = obj.dim;
        end
        for i=1:dim_x
            command=['x(',num2str(i),',1)=sym(''xL',num2str(i),'R'',''real'');'];
            eval(command);
            command=['dx(',num2str(i),',1)=sym(''dxL',num2str(i),'R'',''real'');'];
            eval(command);
        end
    else
        x = [];
        dx = [];
    end

    %generate symbolic inputs
    if isprop(obj,'nrOfInputs') && obj.nrOfInputs>0
        if isa(obj, 'nonlinearARX')
            dim_u = (obj.dim+1) * obj.nrOfInputs;
        else
            dim_u = obj.nrOfInputs;
        end
        for i=1:dim_u
            command=['u(',num2str(i),',1)=sym(''uL',num2str(i),'R'',''real'');'];
            eval(command);
            command=['du(',num2str(i),',1)=sym(''duL',num2str(i),'R'',''real'');'];
            eval(command);
        end
    else
        u = [];
        du = [];
    end
    
    %generate symbolic constraint states
    if isprop(obj,'nrOfConstraints') && obj.nrOfConstraints>0
        for i=1:obj.nrOfConstraints
            command=['y(',num2str(i),',1)=sym(''yL',num2str(i),'R'',''real'');'];
            eval(command);
            command=['dy(',num2str(i),',1)=sym(''dyL',num2str(i),'R'',''real'');'];
            eval(command);
        end 
    else
        y = [];
        dy = [];
    end

    % generate symbolic outputs
    if isprop(obj,'nrOfOutputs') && obj.nrOfOutputs>0
        for i=1:obj.nrOfOutputs 
            command=['o(',num2str(i),',1)=sym(''oL',num2str(i),'R'',''real'');'];
            eval(command);
            command=['do(',num2str(i),',1)=sym(''doL',num2str(i),'R'',''real'');'];
            eval(command);  
        end  
    else
        o = [];
        do = [];
    end
    
    %generate symbolic parameters
    if isprop(obj,'nrOfParam') && obj.nrOfParam>0
        for i=1:obj.nrOfParam
            command=['p(',num2str(i),',1)=sym(''pL',num2str(i),'R'',''real'');'];
            eval(command);
        end 
    else
        p = [];
    end
    
else
    %generate symbolic states
    if isprop(obj,'dim') && obj.dim>0
        for i=1:obj.dim
            command=['x(',num2str(i),',1)=sym(''x',num2str(i),''',''real'');'];
            eval(command);
            command=['dx(',num2str(i),',1)=sym(''dx',num2str(i),''',''real'');'];
            eval(command);
        end
    else
        x = [];
        dx = [];
    end

    %generate symbolic inputs
    if isprop(obj,'nrOfInputs') && obj.nrOfInputs>0
        for i=1:obj.nrOfInputs
            command=['u(',num2str(i),',1)=sym(''u',num2str(i),''',''real'');'];
            eval(command);
            command=['du(',num2str(i),',1)=sym(''du',num2str(i),''',''real'');'];
            eval(command);
        end
    else
        u = [];
        du = [];
    end

    %generate symbolic outputs
    if isprop(obj,'nrOfOutputs') && obj.nrOfOutputs>0
        for i=1:obj.nrOfOutputs
            command=['o(',num2str(i),',1)=sym(''o',num2str(i),''',''real'');'];
            eval(command);
            command=['do(',num2str(i),',1)=sym(''do',num2str(i),''',''real'');'];
            eval(command);
        end
    else
        o = [];
        do = [];
    end
    
    %generate symbolic constraint states
    if isprop(obj,'nrOfConstraints') && obj.nrOfConstraints>0
        for i=1:obj.nrOfConstraints
            command=['y(',num2str(i),',1)=sym(''y',num2str(i),''',''real'');'];
            eval(command);
            command=['dy(',num2str(i),',1)=sym(''dy',num2str(i),''',''real'');'];
            eval(command);
        end  
    else
        y = [];
        dy = [];
    end
    
    %generate symbolic parameters
    if isprop(obj,'nrOfParam') && obj.nrOfParam
        for i=1:obj.nrOfParam
            command=['p(',num2str(i),',1)=sym(''p',num2str(i),''',''real'');'];
            eval(command);
        end   
    else
        p = [];
    end  
end

% combine variables
vars.x = x;
vars.u = u;
vars.y = y;
vars.o = o;
vars.p = p;

vars_der.x = dx;
vars_der.u = du;
vars_der.y = dy;
vars_der.o = do;

% ------------------------------ END OF CODE ------------------------------
