from __future__ import annotations

from typing import Any, Dict

from python_src.precision import normalize_precision_model, precision_format_to_dag_dtype
from server.run_manager import make_response
from tools.baseline_candidate import poly_to_dag
from traditional.chebyshev import chebyshev_approximate
from traditional.minimax import minimax_approximate
from traditional.taylor import taylor_approximate


def run_baseline(payload: Dict[str, Any]) -> Dict[str, Any]:
    method = payload.get("method")
    function = payload.get("function")
    interval = payload.get("interval")
    degree = int(payload.get("degree", 8))
    if not method or not function or not interval:
        return make_response(
            "error",
            errors=[
                {
                    "code": "missing_inputs",
                    "message": "method, function, and interval are required",
                    "details": {},
                }
            ],
        )

    return_candidate = bool(payload.get("return_candidate", False))
    candidate_dtype = payload.get("candidate_dtype")
    if not candidate_dtype:
        precision_model = payload.get("precision_model")
        if precision_model is not None:
            precision_info = normalize_precision_model(precision_model)
            candidate_dtype = precision_format_to_dag_dtype(precision_info["compute_format"])
    candidate_dtype = str(candidate_dtype or "float32")
    candidate_name = str(payload.get("candidate_name") or f"{method}_poly")

    if method == "chebyshev":
        result = chebyshev_approximate(
            function,
            interval,
            degree,
            sample_points=payload.get("sample_points"),
        )
        data = {"method": method, "result": result}
        if return_candidate and result.get("coefficients") is not None:
            data["candidate"] = poly_to_dag(
                result["coefficients"],
                dtype=candidate_dtype,
                name=candidate_name,
            )
        return make_response("ok", data=data)
    if method == "minimax":
        result = minimax_approximate(
            function,
            interval,
            degree,
            max_iter=int(payload.get("max_iter", 8)),
            grid_size=int(payload.get("grid_size", 4096)),
        )
        data = {"method": method, "result": result}
        if return_candidate and result.get("coefficients") is not None:
            data["candidate"] = poly_to_dag(
                result["coefficients"],
                dtype=candidate_dtype,
                name=candidate_name,
            )
        return make_response("ok", data=data)
    if method == "taylor":
        result = taylor_approximate(function, interval, degree, center=payload.get("center"))
        data = {"method": method, "result": result}
        if return_candidate and result.get("coefficients") is not None:
            data["candidate"] = poly_to_dag(
                result["coefficients"],
                dtype=candidate_dtype,
                name=candidate_name,
            )
        return make_response("ok", data=data)
    if method == "compare":
        results = {
            "chebyshev": chebyshev_approximate(
                function,
                interval,
                degree,
                sample_points=payload.get("sample_points"),
            ),
            "minimax": minimax_approximate(
                function,
                interval,
                degree,
                max_iter=int(payload.get("max_iter", 8)),
                grid_size=int(payload.get("grid_size", 4096)),
            ),
            "taylor": taylor_approximate(function, interval, degree, center=payload.get("center")),
        }
        data = {"method": method, "result": results}
        if return_candidate:
            candidates: Dict[str, Any] = {}
            for key, res in results.items():
                coeffs = res.get("coefficients")
                if coeffs is None:
                    continue
                candidates[key] = poly_to_dag(
                    coeffs,
                    dtype=candidate_dtype,
                    name=f"{key}_poly",
                )
            if candidates:
                data["candidates"] = candidates
        return make_response("ok", data=data)

    return make_response(
        "error",
        errors=[{"code": "unknown_method", "message": f"Unknown method: {method}", "details": {}}],
    )
