function display(P)
% display - Displays the properties of a polytope object (inequality and
%    equality constraints) on the command window
%
% Syntax:
%    display(P)
%
% Inputs:
%    P - polytope object
%
% Outputs:
%    (to console)
%
% Example: 
%    A = [1 2; -1 2; -2 -2; 1 -2];
%    b = ones(4,1);
%    P = polytope(A,b);
%    display(P);
%
% Other m-files required: none
% Subfunctions: none
% MAT-files required: none
%
% See also: none

% Authors:       Viktor Kotsev, Mark Wetzlinger
% Written:       06-June-2022
% Last update:   01-December-2022 (MW, adapt to other CORA display)
% Last revision: ---

% ------------------------------ BEGIN CODE -------------------------------

% display input variable
fprintf(newline);
disp(inputname(1) + " =");
fprintf(newline);

%display dimension
display@contSet(P);
fprintf(newline);

% display vertex representation
if P.isVRep.val
    disp('Vertex representation:');
    displayMatrixVector(P.V_.val,'V');
else
    disp('Vertex representation: (not computed)');
end

% display inequality constraints
if isempty(P.A_.val)
    disp('Inequality constraints (A*x <= b): (none)');
else
    disp('Inequality constraints (A*x <= b):');
    displayMatrixVector(P.A_.val,'A');
    displayMatrixVector(P.b_.val,'b');
end

% display equality constraints
if isempty(P.Ae_.val)
    disp('Equality constraints (Ae*x = be): (none)');
else
    disp('Equality constraints (Ae*x = be):');
    displayMatrixVector(P.Ae_.val,'Ae');
    displayMatrixVector(P.be_.val,'be');
end

disp(" ");
% display set properties
disp(['Bounded?                          ' aux_prop2string(P.bounded)]);
disp(['Empty set?                        ' aux_prop2string(P.emptySet)]);
disp(['Full-dimensional set?             ' aux_prop2string(P.fullDim)]);

disp(['Minimal halfspace representation? ' aux_prop2string(P.minHRep)]);
disp(['Minimal vertex representation?    ' aux_prop2string(P.minVRep)]);

end


% Auxiliary functions -----------------------------------------------------

function res = aux_prop2string(prop)
% helper function to display three-valued logic in set properties

if isempty(prop.val)
    res = 'Unknown';
elseif prop.val
    res = 'true';
elseif ~prop.val
    res = 'false';
end

end

% ------------------------------ END OF CODE ------------------------------
