clear all;
clc;  
n = 1000;  
n_per_cluster = n / 2;  
radius = 0.2;  
rng(1);
num_iterations = 10;
cluster_distances = linspace(-0.35, 0.35, 30);  
ARI_spectral_vals_all = zeros(length(cluster_distances), num_iterations);
ARI_generalized_vals_all = zeros(length(cluster_distances), num_iterations);
ARI_generalized_selfloop_vals_all = zeros(length(cluster_distances), num_iterations);
for iter = 1:num_iterations
    for idx = 1:length(cluster_distances)
        cluster_distance = cluster_distances(idx); 
        theta1 = rand(n_per_cluster, 1) * 2 * pi;  
        r1 = radius * sqrt(rand(n_per_cluster, 1)); 
        x1 = [r1 .* cos(theta1), r1 .* sin(theta1)];  
        theta2 = rand(n_per_cluster, 1) * 2 * pi;  
        r2 = radius * sqrt(rand(n_per_cluster, 1));  
        x2 = [r2 .* cos(theta2) + cluster_distance, r2 .* sin(theta2)];  
        x = [x1; x2];
        r_intra_G = 0.1;  
        r_inter_G = 0.05; 
        noise_prob_G = 1;  
        r_intra_H = 0.05;  
        r_inter_H = 0.1;  
        noise_prob_H = 1;
        A_G = generate_geometric_graph_adjacency(n_per_cluster, r_intra_G, r_inter_G, noise_prob_G, x1, x2);
        A_H = generate_geometric_graph_adjacency(n_per_cluster, r_intra_H, r_inter_H, noise_prob_H, x1, x2);
        A_G = triu(A_G) + triu(A_G, 1)'; 
        A_H = triu(A_H) + triu(A_H, 1)';  
        [s_G, t_G, weights_G] = find(triu(A_G)); 
        [clusters_spectral, ~, ~] = spectral_clustering(s_G, t_G, weights_G);
        group_labels = [ones(n_per_cluster, 1); 
                        ones(n_per_cluster, 1) * 2];  
        [~, ARI_spectral] = randindex(group_labels, clusters_spectral);
        ARI_spectral_vals_all(idx, iter) = ARI_spectral;  
        L_G = compute_normalized_laplacian(s_G, t_G, weights_G, n);  
        [s_H, t_H, weights_H] = find(triu(A_H));  
        L_H = compute_normalized_laplacian(s_H, t_H, weights_H, n);
        [~, ~, ~, ~, clusters_generalized] = generalized_eigenvalue_spectrum_with_quadratic_forms(L_G, L_H);
        [~, ARI_generalized] = randindex(group_labels, clusters_generalized);
        ARI_generalized_vals_all(idx, iter) = ARI_generalized;  
       [s_G_new, t_G_new, weights_G_new, ~] = equalize_weighted_degrees(s_G, t_G, weights_G, s_H, t_H, weights_H, n);
        G_new = graph(s_G_new, t_G_new, weights_G_new, n);
        s_H_selfloop = [s_H; 1]; 
        t_H_selfloop = [t_H; 1];  
        weights_H_selfloop = [weights_H; 1];  
        L_H_selfloop = compute_normalized_laplacian(s_H_selfloop, t_H_selfloop, weights_H_selfloop, n);
        L_G_new = compute_normalized_laplacian(s_G_new, t_G_new, weights_G_new, n);
        [~, ~, ~, ~, clusters_generalized_selfloop] = generalized_eigenvalue_spectrum_with_quadratic_forms(L_G_new, L_H_selfloop);
        [~, ARI_generalized_selfloop] = randindex(group_labels, clusters_generalized_selfloop);
        ARI_generalized_selfloop_vals_all(idx, iter) = ARI_generalized_selfloop;  
    end
end

num_iterations = size(ARI_spectral_vals_all, 2);
mean_ARI_spectral = mean(ARI_spectral_vals_all, 2);
var_ARI_spectral = std(ARI_spectral_vals_all, 0, 2) / sqrt(num_iterations);  
mean_ARI_generalized = mean(ARI_generalized_vals_all, 2);
var_ARI_generalized = std(ARI_generalized_vals_all, 0, 2) / sqrt(num_iterations); 
mean_ARI_generalized_selfloop = mean(ARI_generalized_selfloop_vals_all, 2);
var_ARI_generalized_selfloop = std(ARI_generalized_selfloop_vals_all, 0, 2) / sqrt(num_iterations);  
figure;
errorbar(cluster_distances, mean_ARI_generalized_selfloop, var_ARI_generalized_selfloop, '-d', 'LineWidth', 3, 'DisplayName', 'CC+NL');
hold on;
errorbar(cluster_distances, mean_ARI_generalized, var_ARI_generalized, '-s', 'LineWidth', 1, 'DisplayName', 'CC');
hold on;
errorbar(cluster_distances, mean_ARI_spectral, var_ARI_spectral, '-o', 'LineWidth', 2, 'DisplayName', 'SP');
xlabel('Cluster Distance');
ylabel('Adjusted Rand Index (ARI)');
title('Mean ARI vs Cluster Distance with Standard Error Bars');
lgd = legend('CC+NL', 'CC', 'SP');
set(lgd, 'Position', [.425 0.45 0.2 0.2], 'FontSize', 10);  
grid on;
xlim([-.36 .36])
ylim([-.01 1.01])
lgd.Box = 'on';  





