function  Dscore = DasguptaScore(D, TerminalReorder, TreeChildren, CountMat)
% X: Observation data (Num x features)
% D: NumDat x NumDat pari-wise distance matrix

%D = squareform( pdist( X(TerminalReorder,:) ) ); % Pair-wise dist. matrix

D = D(TerminalReorder, TerminalReorder);

Dscore = 0;
for ii=1:size(TreeChildren,1)
    temp = D(logical(CountMat(TreeChildren(ii,1),:)), logical(CountMat(TreeChildren(ii,2),:)));
    Dscore = Dscore + sum(temp(:))*sum(CountMat(ii,:));
end