function D=distancecomputing(X,m,d,n1)
[n,~]=size(X);
D=zeros(m,m);
n2=n-n1;
covdet=zeros(1,m);
for i=1:m
    temp=zeros(d,d);
    for j=1:d
        for k=j:d
            index1=(i-1)*d+j;
            index2=(i-1)*d+k;
            innprod=(X(:,index1).*X(:,index2)).';
            [~,index]=sort(abs(innprod));
            innprod=innprod(index);
            temp(j,k)=sum(innprod(1:n2))/n2;
            temp(k,j)=temp(j,k);
        end
    end
    covdet(i)=abs(det(temp));
end
            
for i=1:m
    for j=i:m
        temp=zeros(d,d);
        for k=1:d
            for l=1:d
                index1=(i-1)*d+k;
                index2=(j-1)*d+l;
                innprod=(X(:,index1).*X(:,index2)).';
                [~,index]=sort(abs(innprod));
                innprod=innprod(index);
                temp(k,l)=sum(innprod(1:n2))/n2;
            end
        end
        [~,S,~]=svd(temp);
        S=prod(diag(S));
        D(i,j)=-0.5*log(S/sqrt(covdet(i)*covdet(j)));
        D(j,i)=D(i,j);
    end
end
        