function rankinternal_nodes=rankinternal(adjmatCL)
degree = sum(adjmatCL,2);
internal_nodes = find(degree > 1);
[foo,ind] = sort(degree(internal_nodes),'descend');
internal_nodes = internal_nodes(ind);
rankinternal_nodes=internal_nodes(1);
child=find(adjmatCL(internal_nodes(1),:)>0);
pa=internal_nodes(1)*ones(1,length(child));
odd_flag=1;
while(~isempty(child))
    child_next=[];
    pa_next=[];
    for j=1:length(child)
        temp_c=find(adjmatCL(child(j),:)>0);
        temp_c=temp_c(find(temp_c~=pa(j)));
        temp_c=intersect(temp_c,internal_nodes);
        child_next=[child_next temp_c.'];
        pa_next=[pa_next child(j)*ones(1,length(temp_c))];
    end
    child=child_next;
    pa=pa_next;
    if(odd_flag)
        rankinternal_nodes=[rankinternal_nodes child];
    end
    odd_flag=1-odd_flag;
end
addition=setdiff(internal_nodes,rankinternal_nodes);
rankinternal_nodes=[rankinternal_nodes addition.'];
    
    

