function res = test_polyZonotope_uminus
% test_polyZonotope_uminus - unit test function of uminus
%
% Syntax:
%    res = test_polyZonotope_uminus
%
% Inputs:
%    -
%
% Outputs:
%    res - true/false
%
% Other m-files required: none
% Subfunctions: none
% MAT-files required: none
%
% See also: -

% Authors:       Tobias Ladner
% Written:       06-April-2023
% Last update:   ---
% Last revision: ---

% ------------------------------ BEGIN CODE -------------------------------

resvec = true(0);

% init
c = [1;2];
G = [1 0 1; 0 1 1];
GI = [1;2];
E = [1 0 4; 2 1 3];
pZ = polyZonotope(c,G,GI,E);

% negate
npZ = -pZ;
resvec(end+1) = all(npZ.c == -c, 'all');
resvec(end+1) = all(npZ.G == -G, 'all');
resvec(end+1) = all(npZ.GI == -GI, 'all');

% compare with -1 * pZ
resvec(end+1) = isequal(npZ, -1*pZ);

% test empty case
resvec(end+1) = isemptyobject(-polyZonotope());

% add results
res = all(resvec);

% ------------------------------ END OF CODE ------------------------------
