"""Column name conventions inferred from the released CSVs.

The goal is to keep all parsing logic centralized and robust to minor variants.
"""
from __future__ import annotations
from dataclasses import dataclass

@dataclass(frozen=True)
class RealRunsCols:
    dataset: str = "dataset_name"
    seed: str = "seed"
    c: str = "probe_c"
    outcome: str = "R_true"
    pred: str = "R_pred"
    squared_error: str = "squared_error"

@dataclass(frozen=True)
class RealCurveCols:
    dataset: str = "dataset_name"
    c: str = "probe_c"
    risk: str = "L_hat"
    mean_outcome: str = "R_mean"
    var_outcome: str = "R_var"
    n: str = "n"

@dataclass(frozen=True)
class SynthRunCols:
    task: str = "task_id"
    seed: str = "seed"
    c: str = "probe_c"
    outcome: str = "R_true"
    pred: str = "R_pred"
    squared_error: str = "squared_error"

@dataclass(frozen=True)
class SynthCurveCols:
    task: str = "task_id"
    c: str = "probe_c"
    risk: str = "L_hat"
    n: str = "n_seeds"

REAL_RUNS = RealRunsCols()
REAL_CURVES = RealCurveCols()
SYN_RUNS = SynthRunCols()
SYN_CURVES = SynthCurveCols()
