import math
from typing import Iterable, Tuple
from config import CFG

def rdp_gaussian(alpha: float, sigma: float) -> float:
    return alpha / (2.0 * sigma * sigma)

def compose_rdp(sigmas: Iterable[float], alpha: float) -> float:
    return sum(rdp_gaussian(alpha, s) for s in sigmas)

def rdp_to_eps(rdp: float, alpha: float, delta: float) -> float:
    return rdp + math.log(1.0/delta)/(alpha-1.0)

def best_eps(sigmas: Iterable[float], delta: float, orders=CFG.RDP_ORDERS) -> tuple[float,int]:
    best=(float("inf"), None)
    for a in orders:
        eps = rdp_to_eps(compose_rdp(sigmas, a), a, delta)
        if eps < best[0]: best=(eps,a)
    return best
