#!/usr/bin/python3
"""
Defines a random equivalence relation.

Author(s):
    Anonymized Authors @anonymized-authors

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

from .base import BaseEquivalenceRelation


class RandomEquivalenceRelation(BaseEquivalenceRelation):
    def __init__(self, seed: int = 2025, **kwargs: Dict[str, Any]):
        """
        Args:
            seed: random seed.
        """
        del kwargs
        n_classes = np.random.default_rng(seed=seed).choice(np.arange(2, 11))
        super(RandomEquivalenceRelation, self).__init__(n_classes)
        self.max_num_digits: Final[int] = 16

    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 s
        out: List[Hashable] = []
        for xi in x:
            hash_ = sha256(repr(xi).encode("utf-8")).digest()
            idx = str(int.from_bytes(hash_, byteorder="big"))
            mod_idx = int(idx[-min(len(idx), self.max_num_digits):]) % (
                self._n_classes
            )
            out.append(str(mod_idx))
        return out
