%% Global parameters
clc;clear;close all;

n = 1000;  % graph dimension

sigma_vec = linspace(0, 0.8, 15)';
ss_len = length(sigma_vec);

delta_vec = sigma_vec;


ind_run = 1;  % reduce randomness, every test need run 'ind_run' times
clean_up = 10;
tol = 1e-10;

% seed = randi(100);
rng(24)


% Allocation memory
wass_corr_lidp2 = zeros(ss_len, ind_run);

time_lidp2 = zeros(ss_len, ind_run);



%% Main algorithm
for sim_ind = 1:ind_run
    fprintf('The %i Independent run, n=%d\n', sim_ind, n);
    
    for j = 1:ss_len
        sigma = sigma_vec(j);
        fprintf('sigma = %f\n', sigma)

        s = 1 - sigma^2;

        p = (log(n))^2/n;

        % parent graph
        A = binornd(1,p,n,n);
        A = triu(A,1);
        A = A + A';


        % first graph
        Z1 = binornd(1,s,n,n);
        Z1 = triu(Z1, 1);
        Z1 = Z1 + Z1';
        W1 = A .* Z1;

        % second graph (permuted)
        perp_rnd = randperm(n);
        S_rnd = zeros(n, n);
        S_rnd(1:n, perp_rnd) = eye(n);
        A_permuted = S_rnd*A*S_rnd';


        Z2 = binornd(1,s,n,n);
        Z2 = triu(Z2, 1);
        Z2 = Z2 + Z2';
        W2 = A_permuted.*Z2;

        
       
        %%%% LiDP %%%%
        fprintf('LiDP:    ')
        tic
        [S_lidp_old, D_lidp, ~, ~, isPerm_fast, msg_fast] = match_fast4(W1, W2);

        r_lidp = full(sum(sum(dot(S_lidp_old, S_rnd))))/n;

        if isPerm_fast ~= 1
            M_lidp = matchpairs((-1)*D_lidp', -99999, 'max');
            S_lidp_new = full(sparse(M_lidp(:, 1), M_lidp(:, 2), 1, n, n));
            r_old = full(sum(dot(S_lidp_old, S_lidp_new))/n);
    
            [~, r_lidp] = cleanup_csgo_optimized(W2, W1, S_lidp_new, clean_up, r_old, S_rnd, tol);
        end
        
        time_lidp2(j, sim_ind) = toc;
        wass_corr_lidp2(j, sim_ind) = r_lidp;
        fprintf("Wasserstein correct fraction is %.4f   time is %.2fs\n", r_lidp, time_lidp2(j, sim_ind))
 
    end
end

%% Results Processing
wass_corr_lidp2_mean = median(wass_corr_lidp2, 2);

time_lidp2_mean = mean(time_lidp2, 2);


%% Plot
figure
hold on
set(gca, 'Fontsize', 20)
plot(delta_vec, wass_corr_lidp2_mean, '-h', 'LineWidth', 2);
xlabel('Noise $\sqrt{\delta}$', 'Interpreter', 'latex');  ylabel("Fractional correct percentage");
legend("LiDP", 'Location', 'best')
title('ER graph test')
hold off

figure
hold on
set(gca, 'Fontsize', 20)
plot(delta_vec, time_lidp2_mean, '-h', 'LineWidth', 2);
xlabel('Noise $\sqrt{\delta}$', 'Interpreter', 'latex');  ylabel("Time(s)");
legend("LiDP", 'Location', 'best')
title('ER graph test')
hold off

