from dataclasses import dataclass
from typing import List
import numpy as np
@dataclass
class ClusterData:
    ref_index: List[int]
    bound_index: List[int]
    ref_emb: np.ndarray = None
    bound_emb: np.ndarray = None
    diameter: float = 0.0
    def __post_init__(self):
        if not isinstance(self.ref_index, list):
            self.ref_index = list(self.ref_index)
        if not isinstance(self.bound_index, list):
            self.bound_index = list(self.bound_index)
        if self.ref_emb is not None and len(self.ref_index) != len(self.ref_emb):
            raise ValueError("Number of reference indices must match number of reference embeddings")
        if self.bound_emb is not None and len(self.bound_index) != len(self.bound_emb):
            raise ValueError("Number of boundary indices must match number of boundary embeddings")
    @property
    def size(self) -> int:
        return len(self.ref_index) + len(self.bound_index)
    @property
    def has_embeddings(self) -> bool:
        return self.ref_emb is not None and self.bound_emb is not None
    def __str__(self) -> str:
        return (f"ClusterData(ref_points={len(self.ref_index)}, "
                f"bound_points={len(self.bound_index)}, "
                f"diameter={self.diameter:.4f})")
    def __repr__(self) -> str:
        return (f"ClusterData(ref_index={self.ref_index}, "
                f"bound_index={self.bound_index}, "
                f"diameter={self.diameter:.4f}, "
                f"has_embeddings={self.has_embeddings})")
