clear all
clear variables;
S = load('grasp_molene_data.mat');
rng(10)
temperature_types = {'temperature', 'maximal temperature', 'minimal temperature'};
num_data_types = length(temperature_types);
overlap_results = cell(num_data_types * 3, 5);

for data_idx = 1:num_data_types
    data_type = temperature_types{data_idx};
    graph_idx = 2;
    data_name_idx = find(strcmpi(S.molene_graphs{graph_idx, 1}.data_name, data_type));
    overlap_counts_SC = 0;
    no_overlap_counts_SC = 0;
    overlap_counts_CCNL = 0;
    no_overlap_counts_CCNL = 0;
    overlap_counts_selfloop = 0;
    no_overlap_counts_selfloop = 0;

    for hour = 1:744
        data_values = S.molene_graphs{graph_idx, 1}.data{data_name_idx, 1}(:, hour);
        data_values = data_values - 273.15;
        A_temp = plotWeightedGraphWithAdjacency(S.molene_graphs{graph_idx, 1}, data_type);
        H_temp = createInverseSimilarityHMatrix(S.molene_graphs{graph_idx, 1}, data_values, 10);
        L_temp = compute_normalized_laplacian_graph_mat(A_temp);
        [s_A, t_A, weights_A] = find(triu(A_temp)); 
        [s_G, t_G, weights_G] = find(triu(A_temp));
        [s_H, t_H, weights_H] = find(triu(H_temp));
        num_nodes = length(unique([s_G; t_G; s_H; t_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, num_nodes);
        G_norm_new = compute_normalized_laplacian(s_G_new, t_G_new, weights_G_new, num_nodes);
        [clusters_classical_temp, ~, ~] = spectral_clustering(s_A, t_A, weights_A);
        L_H_temp = compute_normalized_laplacian_graph_mat(H_temp);
        [~, ~, ~, ~, clusters_generalized_temp] = generalized_eigenvalue_spectrum_with_quadratic_forms(L_temp, L_H_temp);
        [s_H, t_H, weights_H] = find(triu(H_temp));
        num_nodes = length(unique([s_H; t_H]));
        s_H_selfloop = [s_H; 1];
        t_H_selfloop = [t_H; 1];
        weights_H_selfloop = [weights_H; 1];
        L_H_selfloop = add_selfloops_to_H(s_H_selfloop, t_H_selfloop, weights_H_selfloop, num_nodes);
        [~, ~, ~, ~, clusters_generalized_selfloop] = generalized_eigenvalue_spectrum_with_quadratic_forms(G_norm_new, L_H_selfloop);
        [mean_classical_temp, se_classical_temp] = calculate_cluster_stats_with_se(clusters_classical_temp, data_values);
        [mean_generalized_temp, se_generalized_temp] = calculate_cluster_stats_with_se(clusters_generalized_temp, data_values);
        [mean_selfloop_temp, se_selfloop_temp] = calculate_cluster_stats_with_se(clusters_generalized_selfloop, data_values);
        interval_SC_cluster1 = [mean_classical_temp(1) - se_classical_temp(1), mean_classical_temp(1) + se_classical_temp(1)];
        interval_SC_cluster2 = [mean_classical_temp(2) - se_classical_temp(2), mean_classical_temp(2) + se_classical_temp(2)];
        interval_CCNL_cluster1 = [mean_generalized_temp(1) - se_generalized_temp(1), mean_generalized_temp(1) + se_generalized_temp(1)];
        interval_CCNL_cluster2 = [mean_generalized_temp(2) - se_generalized_temp(2), mean_generalized_temp(2) + se_generalized_temp(2)];
        interval_selfloop_cluster1 = [mean_selfloop_temp(1) - se_selfloop_temp(1), mean_selfloop_temp(1) + se_selfloop_temp(1)];
        interval_selfloop_cluster2 = [mean_selfloop_temp(2) - se_selfloop_temp(2), mean_selfloop_temp(2) + se_selfloop_temp(2)];

        if interval_SC_cluster1(2) >= interval_SC_cluster2(1) && interval_SC_cluster1(1) <= interval_SC_cluster2(2)
            overlap_counts_SC = overlap_counts_SC + 1;
        else
            no_overlap_counts_SC = no_overlap_counts_SC + 1;
        end

        if interval_CCNL_cluster1(2) >= interval_CCNL_cluster2(1) && interval_CCNL_cluster1(1) <= interval_CCNL_cluster2(2)
            overlap_counts_CCNL = overlap_counts_CCNL + 1;
        else
            no_overlap_counts_CCNL = no_overlap_counts_CCNL + 1;
        end

        if interval_selfloop_cluster1(2) >= interval_selfloop_cluster2(1) && interval_selfloop_cluster1(1) <= interval_selfloop_cluster2(2)
            overlap_counts_selfloop = overlap_counts_selfloop + 1;
        else
            no_overlap_counts_selfloop = no_overlap_counts_selfloop + 1;
        end
    end

    percent_overlap_SC = (overlap_counts_SC / 744) * 100;
    percent_no_overlap_SC = (no_overlap_counts_SC / 744) * 100;
    percent_overlap_CCNL = (overlap_counts_CCNL / 744) * 100;
    percent_no_overlap_CCNL = (no_overlap_counts_CCNL / 744) * 100;
    percent_overlap_selfloop = (overlap_counts_selfloop / 744) * 100;
    percent_no_overlap_selfloop = (no_overlap_counts_selfloop / 744) * 100;

    overlap_results(data_idx, :) = {data_type, overlap_counts_SC, no_overlap_counts_SC, percent_overlap_SC, percent_no_overlap_SC};
    overlap_results(data_idx + num_data_types, :) = {data_type, overlap_counts_CCNL, no_overlap_counts_CCNL, percent_overlap_CCNL, percent_no_overlap_CCNL};
    overlap_results(data_idx + 2 * num_data_types, :) = {data_type, overlap_counts_selfloop, no_overlap_counts_selfloop, percent_overlap_selfloop, percent_no_overlap_selfloop};
end

overlap_summary_table = cell2table(overlap_results, 'VariableNames', ...
    {'Data_Type', 'Overlap_Count', 'No_Overlap_Count', 'Percent_Overlap', 'Percent_No_Overlap'});
disp(overlap_summary_table);






