function [objective, sigma] = SuperTSP_MCMC(X)

maxiter = 10000;
beta = 10; % Inverse temperature
% X: NumDat x Features
n = size(X,1);
D = squareform( pdist( X ) ); % Pair-wise dist. matrix
%D = exp((-1)*D/10);

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

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

%%% MCMC initialization
objective = TSPScore(D, sigma);

%%% MCMC loop
for iter = 1:maxiter
[sigma,SubInd] = update_sigma(n,D,sigma,SubInd,SupPerm,objective);
objective = [objective;TSPScore(D, sigma)];
subplot(1,2,1);
visTSP(X,sigma,n);
subplot(1,2,2);
plot(objective);
drawnow
end

end

function [sigma,SubInd] = update_sigma(n,D,sigma,SubInd,SupPerm,objective)
indSet = 1:n^2;
id_update = randi(n);
new_SubInd = SubInd;
temp = indSet(SupPerm==id_update);
temptemp = randi(length(temp));
new_SubInd(id_update) = temp(temptemp);
new_sigma = SupPerm(sort(new_SubInd,'ascend'));
new_objective = TSPScore(D, new_sigma);
if rand(1) < exp(objective(end)-new_objective)
    SubInd = new_SubInd;
    sigma = new_sigma;
    objective = [objective;new_objective];
end
end


function visTSP(X,sigma,n)
x = X(:,1);
y = X(:,2);
s = zeros(1,n);
t = zeros(1,n);
weights = ones(1,n);
for ii=1:length(sigma)-1
    s(ii) = sigma(ii);
    t(ii) = sigma(ii+1);
end
s(length(sigma))=sigma(end);
t(length(sigma))=sigma(1);
G = graph(s,t,weights);
plot(G,'XData',x,'YData',y);
set(gca,'YDir','reverse');
end

