function [RI, ARI] = randindex(labels1, labels2)
    N = numel(labels1);
    try
        C = confusionmat(labels1, labels2);
    catch
        C = myConfusionMat(labels1, labels2);
    end
    total_pairs = N * (N - 1) / 2;
    sum_comb_C = 0.5 * sum(C(:) .* (C(:) - 1));
    sum_comb_rows = 0.5 * sum((sum(C, 2) .* (sum(C, 2) - 1)));
    sum_comb_cols = 0.5 * sum((sum(C, 1) .* (sum(C, 1) - 1)));
    expected_index = (sum_comb_rows * sum_comb_cols) / total_pairs;
    max_index = 0.5 * (sum_comb_rows + sum_comb_cols);
    ARI = (sum_comb_C - expected_index) / (max_index - expected_index);
    agreements = sum_comb_C + (total_pairs - sum_comb_rows - sum_comb_cols + sum_comb_C);
    RI = agreements / total_pairs;
end
