function [objective, sigma] = SuperTSP_QuantumMCMC(X, num_STdecomp)

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

for mm=1:num_STdecomp
    % Subsequence for each particles
    SubInd{mm} = zeros(1,n);
    indSet = 1:n^2;
    for ii=1:n
        temp = indSet(SupPerm==ii);
        temptemp = randi(length(temp));
        SubInd{mm}(ii) = temp(temptemp);
    end
    sigma{mm} = SupPerm(sort(SubInd{mm},'ascend'));

    %%% MCMC initialization
    objective{mm} = TSPScore(D, sigma{mm});
end

%%% MCMC loop
for iter = 1:maxiter
    for mm=1:num_STdecomp
        if mm == 1
            left_particleID = num_STdecomp;
        else
            left_particleID = mm-1;
        end
        if mm == num_STdecomp
            right_particleID = 1;
        else
            right_particleID = mm+1;
        end
        [sigma{mm},SubInd{mm}] = update_sigma_QMCMC(n,D,sigma{mm},SubInd{mm},SupPerm,objective{mm},...
            SubInd{left_particleID}, SubInd{right_particleID}, num_STdecomp);
        objective{mm} = [objective{mm};TSPScore(D, sigma{mm})];
    end
    subplot(1,2,1);
    visTSP_QMCMC(X,sigma,n,num_STdecomp);
    subplot(1,2,2);
    plot(cell2mat(objective));
    drawnow
end

end

function [sigma,SubInd] = update_sigma_QMCMC(n,D,sigma,SubInd,SupPerm,objective,...
    left_SubInd, right_SubInd, num_STdecomp)
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);

%%% Quantum effect
q_const = log( 1 + n/(exp(n/num_STdecomp)-1) );
new_objective = new_objective...
    - q_const * (sum(ismember(SubInd,left_SubInd))+sum(ismember(SubInd,right_SubInd)));

if rand(1) < exp(objective(end)-new_objective)
    SubInd = new_SubInd;
    sigma = new_sigma;
    objective = [objective;new_objective];
end
end


function visTSP_QMCMC(X,sigma,n,num_STdecomp)
x = X(:,1);
y = X(:,2);
for mm=1:num_STdecomp
    s = zeros(1,n);
    t = zeros(1,n);
    weights = ones(1,n);
    for ii=1:length(sigma{mm})-1
        s(ii) = sigma{mm}(ii);
        t(ii) = sigma{mm}(ii+1);
    end
    s(length(sigma{mm}))=sigma{mm}(end);
    t(length(sigma{mm}))=sigma{mm}(1);
    G{mm} = graph(s,t,weights);
end
for mm=1:num_STdecomp
plot(G{mm},'XData',x,'YData',y);
hold on
end
hold off
set(gca,'YDir','reverse');
end

