from dataclasses import dataclass
from typing import Callable, Dict

@dataclass
class MTau:
    """Admissible, race-independent M_tau recipes R1/R2."""
    cmax: float
    depth_remaining: Callable[[str], int]      # d(v)
    s_prefix: Callable[[str], float]           # s(prefix(v))
    psi_monotone: Callable[[str], float] = None

    def r1(self, v_id: str) -> float:
        return self.s_prefix(v_id) + self.depth_remaining(v_id) * self.cmax

    def r2(self, v_id: str) -> float:
        assert self.psi_monotone is not None
        return self.psi_monotone(v_id)

    def mtau(self, v_id: str, use_r2: bool=False) -> float:
        return self.r2(v_id) if use_r2 and self.psi_monotone else self.r1(v_id)
