from .humaneval_evaluator import HumanEvalEvaluator
from .gsm8k_evaluator import Gsm8kEvaluator
from .mbpp_evaluator import MBPPEvaluator
from .mmlu_evaluator import MMLUEvaluator
from .arc_c_evaluator import ARCCEvaluator
from .hellaswag_evaluator import HellaSwagEvaluator
from .math_evaluator import MATHEvaluator
from .gpqa_evaluator import GPQAEvaluator

_EVALUATORS = {
    "humaneval": HumanEvalEvaluator,
    "gsm8k": Gsm8kEvaluator,
    "mbpp": MBPPEvaluator,
    "mmlu": MMLUEvaluator,
    "arc_c": ARCCEvaluator,
    "arc_e": ARCCEvaluator,
    "hellaswag": HellaSwagEvaluator,
    "math": MATHEvaluator,
    "gpqa": GPQAEvaluator,
}


def get_evaluator(name: str, **kwargs):
    """Factory function to get evaluator by name."""
    if name not in _EVALUATORS:
        raise ValueError(
            f"Unknown evaluator: {name}. Available: {list(_EVALUATORS.keys())}"
        )
    return _EVALUATORS[name](**kwargs)