function [sorted_eigenvalues, sorted_eigenvectors, quadratic_forms, selected_eigenvector, cluster_labels] = generalized_eigenvalue_spectrum_with_quadratic_forms(L_G, L_H)
    threshold = 1e-6;
    [eigenvectors, eigenvalues] = eig(L_G, L_H);
    eigenvalues_diag = diag(eigenvalues);
    [sorted_eigenvalues, idx] = sort(eigenvalues_diag, 'ascend');
    sorted_eigenvectors = eigenvectors(:, idx);
    valid_indices = ~isinf(sorted_eigenvalues) & ~isnan(sorted_eigenvalues);
    sorted_eigenvalues = sorted_eigenvalues(valid_indices);
    sorted_eigenvectors = sorted_eigenvectors(:, valid_indices);
    quadratic_forms = zeros(length(sorted_eigenvalues), 1);
    for i = 1:length(sorted_eigenvalues)
        x = sorted_eigenvectors(:, i);
        numerator = x' * L_G * x;
        denominator = x' * L_H * x;
        if denominator ~= 0
            quadratic_forms(i) = numerator / denominator;
        else
            quadratic_forms(i) = NaN;
        end
    end
    if length(sorted_eigenvalues) >= 2 && sorted_eigenvalues(2) > threshold
        selected_eigenvector = sorted_eigenvectors(:, 2);
    else
        idx_above_threshold = find(sorted_eigenvalues > threshold, 1, 'first');
        if isempty(idx_above_threshold)
            error('No eigenvalues found above the specified threshold.');
        end
        selected_eigenvector = sorted_eigenvectors(:, idx_above_threshold);
    end
    cluster_labels = kmeans(selected_eigenvector, 2);
end
