function label = SCORE(A, r)
% Algorithm parameters
n = size(A,1);	                % Number of nodes
% G = graph(A);
% if max(conncomp(G))>1
%     fprintf('not connected\n');
%     return                      % Check connectivity
% end
% if r < 2 
%     fprintf('r should >1\n');  
%     return
% end                             % Check whether r>1
[vb,db] = eigs(A,r);
vb2 = vb(:,2:r); 
%* diag(abs(db(2:r, 2:r)).^(0.5));
%rb = vb2./repmat(max(vb(:,1), 10^(-15)),[1,r-1]);
rb = vb2./repmat(vb(:,1),[1,r-1]);
threshold = 2*log(n);
rb(rb > threshold) = threshold;   % Truncate ratio
rb(rb < -threshold) = -threshold;
label = kmeans(rb,r,'Replicates',200);
end
