function visQMCMC(n, objective, TreeChildren, D, TerminalReorder, sigma, num_STdecomp)

ww = cell2mat(objective);
ww = ww(end,:);
ww = exp((min(ww(:))-ww)/50);

for mm=1:num_STdecomp
    x = [1:(n-1), (1:n)-0.5];
    y{mm} = [sigma{mm}(1:(n-1)), ones(1,n)*n];
    s = zeros(1,2*(n-1));
    t = zeros(1,2*(n-1));
    weights = 5 * ww(mm) * ones(1,2*(n-1));
    jj = 1;
    for ii=1:size(TreeChildren{mm},1)
        s(jj) = ii;
        t(jj) = TreeChildren{mm}(ii,1);
        s(jj+1) = ii;
        t(jj+1) = TreeChildren{mm}(ii,2);
        jj=jj+2;
    end
    G{mm} = graph(s,t,weights);
end

subplot(2,2,1);
for mm=1:num_STdecomp
    plot(G{mm},'XData',x,'YData',y{mm},'NodeLabel',{},'LineWidth',G{mm}.Edges.Weight);
    hold on
end
hold off;
set(gca,'YDir','reverse');
title('Binary tree')

subplot(2,2,2);
plot(cell2mat(objective)/num_STdecomp);
title('Negative log marginal likelihood');

subplot(2,2,3);
permMat = zeros(n,n);
for mm=1:num_STdecomp
    for ii=1:n
        permMat(ii,TerminalReorder{mm}(ii))...
            =permMat(ii,TerminalReorder{mm}(ii)) + 1/num_STdecomp;
    end
end
imagesc(permMat);
title('Terminal node permutation')

subplot(2,2,4);
SimMat = zeros(n,n);
for mm=1:num_STdecomp
    SimMat = SimMat + D(TerminalReorder{mm},TerminalReorder{mm});
end
for ii=1:n
    SimMat(ii,ii)=0;
end
imagesc(SimMat);title('Similarity matrix');



