function [TreeChildren, CountMat] = P2BT(sigma)
% 1:(n-1) : Inner nodes
% n:(2n-1) : Terminal nodes
%sigma = [3, 1, 2, 5, 4];
n=length(sigma)+1;
indSet = 1:(n-1);

TreeChildren = zeros(n-1,2); 
% TreeChildren(ii,1): Left child of the ii-th node
% TreeChildren(ii,2): Right child of the ii-th node

for ii=1:n-1
anc = indSet(sigma(1:n-1) < sigma(ii));
anc_upper = min(anc(anc>ii));
anc_lower = max(anc(anc<ii));

if ~isempty(anc_upper)
    temp = indSet((indSet>ii) & (indSet<anc_upper));
else
    temp = indSet(indSet>ii);
end
[~,temptemp] = min(sigma(temp));
if ~isempty(temptemp)
    upper_child = temp(temptemp);
else
    upper_child = n + ii;
end

if ~isempty(anc_lower)
    temp = indSet((indSet<ii) & (indSet>anc_lower));
else
    temp = indSet(indSet<ii);
end
[~,temptemp] = min(sigma(temp));
if ~isempty(temptemp)
    lower_child = temp(temptemp);
else
    lower_child = n + ii -1;
end
TreeChildren(ii,1) = lower_child;
TreeChildren(ii,2) = upper_child;
end

x = [1:(n-1), (1:n)-0.5];
y = [sigma(1:(n-1)), ones(1,n)*n];

s = zeros(1,2*(n-1));
t = zeros(1,2*(n-1));
weights = ones(1,2*(n-1));
jj = 1;
for ii=1:size(TreeChildren,1)
    s(jj) = ii;
    t(jj) = TreeChildren(ii,1);
    s(jj+1) = ii;
    t(jj+1) = TreeChildren(ii,2);
    jj=jj+2;
end
G = graph(s,t,weights);

[~,I]=sort(sigma(1:n-1),'descend');
CountMat = zeros(2*n-1,n);
for ii=n:1:(2*n-1)
    CountMat(ii,ii-(n-1)) = 1; 
end
for ii=1:(n-1)
    jj = I(ii);
    CountMat(jj,:)...
        = CountMat(TreeChildren(jj,1),:)...
        + CountMat(TreeChildren(jj,2),:);
end


%plot(G,'XData',x,'YData',y);
%set(gca,'YDir','reverse');
