from __future__ import annotations
import numpy as np
from dataclasses import dataclass


@dataclass
class DiversityScores:
    energy: float
    average: float


def energy_diversity(D: np.ndarray, eps: float = 1e-6) -> float:
    i, j = np.triu_indices_from(D, k=1)
    N = D.shape[0]
    return float((1 / (N * (N - 1))) * np.sum((1 / (D[i, j] + eps))))


def energy_fitness_method(D: np.ndarray, eps: float = 1e-6) -> float:
    N = D.shape[0]
    i, j = np.triu_indices_from(D, k=1)
    return (2 * (np.sum(1 / (D[i, j] + eps)) + 1e-6 * N) / (N * (N - 1))).item()


def average_diversity(D: np.ndarray) -> float:
    i, j = np.triu_indices_from(D, k=1)
    return float(np.mean(D[i, j]))


def diversity_fitness_method(D: np.ndarray) -> float:
    N = D.shape[0]
    return ((np.sum(D) + 1e-6 * N) / (N * (N - 1))).item()


def summarize(D: np.ndarray, eps: float = 1e-6) -> DiversityScores:
    return DiversityScores(
        energy=energy_fitness_method(D, eps=eps),
        average=diversity_fitness_method(D),
    )
