function res = testLong_spectraShadow_cartProd
% testLong_spectraShadow_cartProd - unit test function of cartProd
%
% Syntax:
%    res = testLong_spectraShadow_cartProd
%
% Inputs:
%    -
%
% Outputs:
%    res - true/false
%
% Other m-files required: none
% Subfunctions: none
% MAT-files required: none
%
% See also: -

% Authors:       Adrian Kulmburg
% Written:       14-August-2023
% Last update:   23-July-2024 (TL, reduced max dim for generated polytopes)
% Last revision: ---

% ------------------------------ BEGIN CODE -------------------------------

res = true;

runs = 2;
samples = 5;

% Test the cartProd of polytopes as spectrahedra
for i=1:runs
    dimension = randi(3);
    P1 = polytope.generateRandom('Dimension', dimension);
    P2 = polytope.generateRandom('Dimension', dimension);
    
    P = cartProd(P1, P2);
    SpS = cartProd(spectraShadow(P1), spectraShadow(P2));
    
    p_P = randPoint(P,samples);
    p_SpS = randPoint(SpS,samples);
    
    for j=1:samples
        if ~P.contains(p_SpS(:,j),'exact',1e-6) || ~SpS.contains(p_P(:,j),'exact',1e-6)
            throw(CORAerror('CORA:testFailed'))
        end
    end
end

% Do the same with ellipsoids, but only in one direction (the exact
% cartProd of two ellipsoids can not be represented as an ellipsoid)
for i=1:runs
    dimension = randi(8);
    E1 = ellipsoid.generateRandom('Dimension', dimension);
    E2 = ellipsoid.generateRandom('Dimension', dimension);
    
    E = cartProd(E1, E2);
    SpS = cartProd(spectraShadow(E1), spectraShadow(E2));
    
    p_SpS = randPoint(SpS,samples);
    
    for j=1:samples
        if ~E.contains(p_SpS(:,j),'exact',1e-6)
            throw(CORAerror('CORA:testFailed'))
        end
    end
end

% Double check that empty-set computation works
A = [-1 0 0];
SpS = spectraShadow(A);
representsa(SpS,'emptySet');
SpS = cartProd(SpS, SpS);
if isempty(SpS.emptySet.val) || (~isempty(SpS.emptySet.val) && ~SpS.emptySet.val)
    throw(CORAerror('CORA:testFailed'))
end
    

% ------------------------------ END OF CODE ------------------------------
