function res = testLong_component_ellipsoid_minkDiffDouble
% testLong_component_ellipsoid_minkDiffDouble - unit test function of
%    minkDiff
%
% Syntax:
%    res = testLong_component_ellipsoid_minkDiffDouble
%
% Inputs:
%    -
%
% Outputs:
%    res - true/false
%
% Other m-files required: none
% Subfunctions: none
% MAT-files required: none
%
% See also: none

% Authors:       Victor Gassmann
% Written:       18-March-2021
% Last update:   ---
% Last revision: ---

% ------------------------------ BEGIN CODE -------------------------------

res = true;
nRuns = 5;
bools = [false,true];

% smaller dims since halfspaces and vertices are involved
for i=10:5:15
    for j=1:nRuns

        % degenerate and non-degenerate
        for k=1:2 
            % init random ellipsoid
            E = ellipsoid.generateRandom('Dimension',i,'IsDegenerate',bools(k));
            % generate points randomly
            V = randn(dim(E),2*dim(E));
            
            for m=1:2
                [U,S,V] = svd(V);
                S(1,1) = bools(m)*S(1,1);
                V = U*S*V';
                Eo = minkDiff(E,V);
                Ei = minkDiff(E,V,'inner');
                Eres = ellipsoid(E.Q,E.q-sum(V,2));
                % check if the same
                if ~(Eres==Eo) || ~(Eres==Ei)
                    res = false;
                    return;
                end
            end
        end

    end
end

% ------------------------------ END OF CODE ------------------------------
