function P_out = empty(n)
% empty - instantiates an empty n-dimensional polytope
%
% Syntax:
%    P_out = polytope.empty(n)
%
% Inputs:
%    n - dimension
%
% Outputs:
%    P_out - empty n-dimensional polytope
%
% Examples:
%    P = polytope.empty(2);
%
% Other m-files required: none
% Subfunctions: none
% MAT-files required: none
%
% See also: none

% Authors:       Mark Wetzlinger
% Written:       16-December-2023
% Last update:   15-January-2024 (TL, parse input)
% Last revision: ---

% ------------------------------ BEGIN CODE -------------------------------

% parse input
if nargin == 0
    n = 0;
end
inputArgsCheck({{n,'att','numeric',{'scalar','nonnegative'}}});

% the polytope 0*x <= -1 is empty
nrRows = min([n,1]);
P_out = polytope(zeros(nrRows,n),-ones(nrRows,1));
% assign properties
P_out.isHRep.val = true;
P_out.emptySet.val = true;
P_out.bounded.val = true;
P_out.fullDim.val = false;
P_out.minHRep.val = true;
P_out.minVRep.val = true;
P_out.V_.val = zeros(n,0);
P_out.isVRep.val = true;

% ------------------------------ END OF CODE ------------------------------
