function [objective, TerminalReorder, TreeChildren] = mainMCMC(X)

fig = figure('position',[100,100,600,600]);
maxiter = 10000;
% X: NumDat x Features
n = size(X,1);
D = squareform( pdist( X ) ); % Pair-wise dist. matrix
D = exp((-1)*D/10);

% Superpermutation for binary tree
SupTree = ones(1,(n-1)*(n-1));
for ii=1:n-1
    SupTree( (ii-1)*(n-1)+1:ii*(n-1) ) = randperm(n-1);
end

% Superpermutation for terminal nodes
SupTerminal = ones(1, n^2);
for ii= 1:n
    SupTerminal( (ii-1)*n+1:ii*n ) = randperm(n);
end

% Subsequence for binary tree
SubIndTree = zeros(1,n-1);
indSet = 1:(n-1)^2;
for ii=1:n-1
    temp = indSet(SupTree==ii);
    temptemp = randi(length(temp));
    SubIndTree(ii) = temp(temptemp);
end
sigma = SupTree(sort(SubIndTree,'ascend'));

% Subsequence for binary tree
SubIndTerminal = zeros(1,n);
indSet = 1:n^2;
for ii=1:n
    temp = indSet(SupTerminal==ii);
    temptemp = randi(length(temp));
    SubIndTerminal(ii) = temp(temptemp);
end
TerminalReorder = SupTerminal(sort(SubIndTerminal,'ascend'));

%%% MCMC initialization
[TreeChildren, CountMat] = P2BT(sigma);
%objective = zeros(1,maxiter*2+1);
objective = DasguptaScore(D, TerminalReorder, TreeChildren, CountMat);

%%% MCMC loop
for iter = 1:maxiter
    % Update for Tree
    id_update = randi(n-1);
    new_SubIndTree = SubIndTree;
    temp = indSet(SupTree==id_update);
    temptemp = randi(length(temp));
    new_SubIndTree(id_update) = temp(temptemp);
    new_sigma = SupTree(sort(new_SubIndTree,'ascend'));
    [new_TreeChildren, new_CountMat] = P2BT(new_sigma);
    new_objective = DasguptaScore(D, TerminalReorder, new_TreeChildren, new_CountMat);
    if rand(1) < exp(objective(end)-new_objective)
        SubIndTree = new_SubIndTree;
        sigma = new_sigma;
        TreeChildren = new_TreeChildren;
        CountMat = new_CountMat;
        objective = [objective;new_objective];
    else
        objective = [objective;objective(end)];
    end

    % Update for TerminalReorder
    id_update = randi(n);
    new_SubIndTerminal = SubIndTerminal;
    temp = indSet(SupTerminal==id_update);
    temptemp = randi(length(temp));
    new_SubIndTerminal(id_update) = temp(temptemp);
    new_TerminalReorder = SupTerminal(sort(new_SubIndTerminal,'ascend'));
    new_objective = DasguptaScore(D, new_TerminalReorder, TreeChildren, CountMat);
    if rand(1) < exp(objective(end)-new_objective)
        SubIndTerminal = new_SubIndTerminal;
        TerminalReorder = new_TerminalReorder;
        objective = [objective;new_objective];
    else
        objective = [objective;objective(end)];
    end
    
    visualizaMCMC(n, objective, TreeChildren, D, TerminalReorder, sigma);
    
%     subplot(2,2,1);
%     
%     
%     subplot(2,2,2);
%     plot(objective);title('Negative log marginal likelihood');
%     pause(0.01);
%     subplot(2,2,4);
%     imagesc(D(TerminalReorder,TerminalReorder).^2);title('Similarity matrix');
%     pause(0.01);
end

%plot(objective);