"""Temporal protocol constants for the CKM Benchmark.

The benchmark splits each topic into three temporal phases:

    [2019] --Init-- [2024] --Evolution-- [2025] --Validation-- [2027]
              Phase 1         Phase 2 (6 windows)      Phase 3
"""

from dataclasses import dataclass


@dataclass(frozen=True)
class PhaseSpec:
    name: str
    start: str
    end: str
    paper_budget: int
    role: str


INIT_RANGE = PhaseSpec(
    name="initialization",
    start="2019-01-01",
    end="2024-01-01",
    paper_budget=48,
    role="Build the baseline knowledge state K_0 from historical literature.",
)

EVOLUTION_RANGE = PhaseSpec(
    name="evolution",
    start="2024-01-01",
    end="2026-01-01",
    paper_budget=96,  # per window; 6 windows of 2 months each
    role="Six 2-month sliding windows; each window adds papers and emits hypotheses.",
)

VALIDATION_RANGE = PhaseSpec(
    name="validation",
    start="2025-01-01",
    end="2027-01-01",
    paper_budget=180,
    role="Future ground truth; each generated hypothesis is graded against this set.",
)

PHASES = (INIT_RANGE, EVOLUTION_RANGE, VALIDATION_RANGE)

EVOLUTION_WINDOW_MONTHS = 2
EVOLUTION_NUM_WINDOWS = 6

# Hit threshold for the canonical two-stage judge
HIT_THRESHOLD = 6.0
PRE_FILTER_THRESHOLD = 5.0
JUDGE_SCALE_MAX = 10
