from sklearn.metrics import adjusted_rand_score, normalized_mutual_info_score


def adjusted_rand_index(y_true, y_pred):
    """
    Computes the Adjusted Rand Index (ARI) between two clusterings.

    ARI measures the similarity between two clusterings, adjusted for chance.
    Values range from -1 to 1, with 1 being perfect agreement.

    Args:
        y_true: Ground truth labels
        y_pred: Predicted labels

    Returns:
        Float: ARI score
    """
    return adjusted_rand_score(y_true.flatten(), y_pred.flatten())


def normalized_mutual_information(y_true, y_pred):
    """
    Computes the Normalized Mutual Information (NMI) between two clusterings.

    NMI measures how much information is shared between clusterings.
    Values range from 0 to 1, with 1 being perfect agreement.

    Args:
        y_true: Ground truth labels
        y_pred: Predicted labels

    Returns:
        Float: NMI score
    """
    return normalized_mutual_info_score(y_true.flatten(), y_pred.flatten())
