clear all;
clc;  
n = 1000;     
p_fixed = 0.2;  
q_values = linspace(0.12, 0.2, 40);  
num_repeats = 20;  
rng(1);
for idx = 1:length(q_values)
    q = q_values(idx);  
    p = p_fixed;        
    for repeat_idx = 1:num_repeats
        group_labels = randsample([1, 2], n, true);  
        [s_G, t_G, weights_G, ~] = stochastic_block_model(n, p, q, group_labels);
        G = graph(s_G, t_G, weights_G, n);
       [clusters_spectral, ~, ~] = spectral_clustering(s_G, t_G, weights_G);
        [s_H, t_H, weights_H, ~] = stochastic_block_model(n, q, p, group_labels);
        L_G = compute_normalized_laplacian(s_G, t_G, weights_G, n);  
        L_H = compute_normalized_laplacian(s_H, t_H, weights_H, n);  
        [~, ~, ~, ~, clusters_generalized] = generalized_eigenvalue_spectrum_with_quadratic_forms(L_G, L_H);
        [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 = [s_H; 1]; 
        t_H = [t_H; 1]; 
        weights_H = [weights_H; 1];  
        H_selfloop = add_selfloops_to_H(s_H, t_H, weights_H, n);
        L_H_selfloop = compute_normalized_laplacian(s_H, t_H, weights_H, 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);
        [RI_spectral, ARI_spectral] = randindex(group_labels, clusters_spectral);
        RI_spectral_repeats(repeat_idx, idx) = RI_spectral;
        ARI_spectral_repeats(repeat_idx, idx) = ARI_spectral;
        [RI_generalized, ARI_generalized] = randindex(group_labels, clusters_generalized);
        RI_generalized_repeats(repeat_idx, idx) = RI_generalized;
        ARI_generalized_repeats(repeat_idx, idx) = ARI_generalized;
        [RI_generalized_selfloop, ARI_generalized_selfloop] = randindex(group_labels, clusters_generalized_selfloop);
        RI_generalized_selfloop_repeats(repeat_idx, idx) = RI_generalized_selfloop;
        ARI_generalized_selfloop_repeats(repeat_idx, idx) = ARI_generalized_selfloop;
    end
end
RI_mean_spectral = mean(RI_spectral_repeats);
RI_variance_spectral = var(RI_spectral_repeats);
ARI_mean_spectral = mean(ARI_spectral_repeats);
ARI_variance_spectral = var(ARI_spectral_repeats);
RI_mean_generalized = mean(RI_generalized_repeats);
RI_variance_generalized = var(RI_generalized_repeats);
ARI_mean_generalized = mean(ARI_generalized_repeats);
ARI_variance_generalized = var(ARI_generalized_repeats);
RI_mean_generalized_selfloop = mean(RI_generalized_selfloop_repeats);
RI_variance_generalized_selfloop = var(RI_generalized_selfloop_repeats);
ARI_mean_generalized_selfloop = mean(ARI_generalized_selfloop_repeats);
ARI_variance_generalized_selfloop = var(ARI_generalized_selfloop_repeats);
figure;
errorbar(q_values, ARI_mean_generalized_selfloop, sqrt(ARI_variance_generalized_selfloop), '-d', ...
    'LineWidth', 3, 'DisplayName', sprintf('Constrain Clustering\n(Self-loops)'));
hold on;
errorbar(q_values, ARI_mean_generalized, sqrt(ARI_variance_generalized), '-s', ...
    'LineWidth', 1, 'DisplayName', 'Constrain Clustering ');
errorbar(q_values, ARI_mean_spectral, sqrt(ARI_variance_spectral), '-o', ...
    'LineWidth', 2, 'DisplayName', 'Spectral Clustering');
hold on;
xlabel('Inter-cluster Edge Probability (q)', 'FontSize', 14, 'FontWeight', 'bold');
ylabel('Adjusted Rand Index (ARI)', 'FontSize', 14, 'FontWeight', 'bold');
title('Mean ARI vs q with Error Bars', 'FontSize', 16, 'FontWeight', 'bold');
legend('Location', 'Best', 'FontSize', 12);
grid on;
ylim([-0.05, 1.05]);
xlim([.1175, .2025]);
box on;







