function display(I)
% display - Displays the properties of an interal object (lower and upper
%    bounds) on the command window
%
% Syntax:
%    display(I)
%
% Inputs:
%    I - interval object
%
% Outputs:
%    ---
%
% Example: 
%    I = interval(2,3);
%    display(I);
%
% Other m-files required: none
% Subfunctions: none
% MAT-files required: none
%
% See also: none

% Authors:       Matthias Althoff
% Written:       19-June-2015
% Last update:   22-February-2016 (DG, now it displays the name)
%                01-May-2020 (MW, handling of empty case)
%                11-September-2023 (TL, respect output display format)
% Last revision: ---

% ------------------------------ BEGIN CODE -------------------------------

if isemptyobject(I)
    
    dispEmptyObj(I,inputname(1));

else
    fprintf(newline);
    disp([inputname(1), ' =']);
    fprintf(newline);

    if issparse(I)

        % non-zero indices of infimum
        [inf_row,inf_col] = find(I.inf);
        % non-zero indices of supremum
        [sup_row,sup_col] = find(I.sup);

        % for sparse matrices, we plot all indices where either the infimum
        % or the supremum is non-zero
        indices = [[inf_row inf_col];[sup_row sup_col]];
        indices = unique(indices,'rows');
        
        % loop over all indices
        for i=1:size(indices,1)
            idxRow = indices(i,1);
            idxCol = indices(i,2);
            % set index
            idxStr = sprintf("(%i,%i)",idxRow,idxCol);
            % values
            lb = full(I.inf(idxRow,idxCol));
            ub = full(I.sup(idxRow,idxCol));
            % print value
            lb = strtrim(formattedDisplayText(lb));
            ub = strtrim(formattedDisplayText(ub));
            fprintf('  %-8s [%s, %s]\n',idxStr,lb,ub);
        end

    else

        %determine size of interval
        [rows, cols] = size(I.inf);

        for i = 1:rows
            str = ' ';
            % display one row
            for j = 1:cols
                lb = strtrim(formattedDisplayText(I.inf(i,j)));
                ub = strtrim(formattedDisplayText(I.sup(i,j)));
                newStr = sprintf('[%s, %s]',lb,ub);
                str = [str,' ',newStr];
            end
            disp(str);
        end

    end
    
    fprintf(newline);
end

% ------------------------------ END OF CODE ------------------------------
