%This is a minimal working example that can be used to produce the results
%in Appendix E (Comparison of Our Algorithm With the Fixed Point Algorithm).

%MVCE calculation requires Michael Todd's code minvol.m, which is available
%at https://epubs.siam.org/doi/10.1137/1.9781611974386#supplementary-material,
%along with its subroutines.
%Delete output argument 'time', as it is not assigned during call to minvol
%Also, comment out section that draws ellipse if d = 2 (lines 106 - 121)

%We also require Cohen et. al.'s code FixedPoint.m, which is included in
%A near-optimal algorithm for approximating the John ellipsoid (see the 
%README).
%-------------------------------------------------------------------------- 
%--------------------------------------------------------------------------

%INPUTS
n = 1e6;            %number of data points
d = 2;              %dimension
X = randn(d,n);     %generate X from standard normal distribution
percent = 10;       %percent of points sampled
tol = 1e-2;         %tolerance for MVCE algorithm

%-------------------------------------------------------------------------- 
%--------------------------------------------------------------------------

%Calculate MVCE using our algorithm
[timeD,gs_star,u2] = our_algorithm(X,percent,tol);

%Calculate MVCE using Fixed Point algorithm
X = X';
st = cputime;
[u_avg, iter] = FixedPoint(X,tol);
timeFP = cputime - st;

function [timeD,gs_star,u2] = our_algorithm(X,percent,tol)

n = size(X,2);
d = size(X,1);

s = round(percent*n);

%Calculate leverage scores
st = cputime;
A = X*X';
A_fact = chol(A);
dis_tmp = A_fact'\X;
distance = sum( dis_tmp .* dis_tmp, 1);
timelev = cputime - st;

st = cputime;
        
%Select points with highest leverage
[~,sampleInd] = maxk(distance,s); 
A = X(:,sampleInd);

%Calculate MVCE(A) where A contains the selected points
[u,R,factor,~,~,~,~,~,~,~,~] = minvol(A,tol);

timeD = cputime - st;
timeD = timelev + timeD;

%Calculate gs_star
R = R/sqrt(factor);
XUX = R'*R;
gs_star = log(det(XUX));
    
c = 0;
while isinf(gs_star) && c < 100
    c = c + 1;
    XUXsmall = XUX./(10^c);
    gs_star = log(det(XUXsmall)) + c*d*log(10);
end

%Calculate u2
u2 = zeros(n,1);
u2(sampleInd) = u;

end


