#!/usr/bin/python3
"""
Defines a score-based equivalence relation.

Author(s):
    Anonymized Authors @anonymized-authors

Licensed under the Apache License, Version 2.0. Copyright Anonymized, Inc. 2025.
"""
import numpy as np
import scipy.stats as stats
from pydantic import BaseModel
from typing import Any, Dict, Final, Hashable, List

from .base import BaseEquivalenceRelation


class ScoreBasedEquivalenceRelation(BaseEquivalenceRelation):
    def __init__(self, **kwargs: Dict[str, Any]):
        """
        Args:
            None.
        """
        del kwargs
        super(ScoreBasedEquivalenceRelation, self).__init__(10)
        self._cutoffs: Final[np.ndarray] = stats.norm.ppf(
            np.linspace(0.0, 1.0, self._n_classes + 1)[1:-1]
        )

    def __call__(self, x: List[BaseModel], s: List[float]) -> List[Hashable]:
        """
        Args:
            x: a list of designs to assign to their equivalence classes.
            s: a list of the corresponding critic-augmented scores.
        Returns:
            A list of the equivalence classes for each design.
        """
        assert len(x) == len(s)
        del x
        return [
            str(idx) for idx in np.searchsorted(self._cutoffs, s, side="left")
        ]
