from __future__ import annotations

from typing import Any, Dict, Iterable, List


def _as_float_list(values: Iterable[Any]) -> List[float]:
    return [float(v) for v in values]


def poly_to_dag(
    coefficients: Iterable[Any],
    dtype: str = "float32",
    name: str = "baseline_poly",
) -> Dict[str, Any]:
    """Build a minimal DAG JSON for a polynomial using Horner form.

    Coefficients are in increasing degree order (c0 + c1*x + ...).
    """
    coeffs = _as_float_list(coefficients)
    if not coeffs:
        coeffs = [0.0]

    nodes: List[Dict[str, Any]] = []
    # Input node (x)
    nodes.append({"type": 0, "value": 0.0, "prev": []})
    x_idx = 0

    def add_const(value: float) -> int:
        nodes.append({"type": 7, "value": float(value), "prev": []})
        return len(nodes) - 1

    # Start with highest-degree coefficient.
    cur = add_const(coeffs[-1])

    # Horner: (((c_n * x + c_{n-1}) * x + c_{n-2}) ...)
    for c in reversed(coeffs[:-1]):
        const_idx = add_const(c)
        nodes.append({"type": 6, "value": 0.0, "prev": [cur, x_idx, const_idx]})
        cur = len(nodes) - 1

    # Output node.
    nodes.append({"type": 1, "value": 0.0, "prev": [cur]})

    return {
        "num_inputs": 1,
        "dtype": dtype,
        "nodes": nodes,
        "id": -1,
        "parent_id": -1,
        "name": name,
        "source": "baseline_polynomial",
    }
