"""
Experiment 1: Scalar SSM vs. 1-semiseparable attention.
"""

from __future__ import annotations

import numpy as np

from .common import ExperimentResult, causal_mask


def run(
    T: int = 20,
    a: float = 0.8,
    b: float = 1.0,
    c: float = 1.0,
    seed: int = 0
) -> ExperimentResult:
    
    rng = np.random.default_rng(seed)
    u = rng.standard_normal(T)

    x = 0.0
    y = np.zeros(T, dtype=np.float64)
    for t in range(T):
        x = a * x + b * u[t]
        y[t] = c * x

    mask, t_idx, s_idx = causal_mask(T)
    M = (a ** (t_idx - s_idx)) * mask
    y_att = c * b * (M @ u)

    max_error = float(np.max(np.abs(y - y_att)))
    details = f"T={T}, decay={a}, max |y - y_att| = {max_error:.3e}"
    meta = {"T": T, "a": a, "b": b, "c": c, "seed": seed, "max_error": max_error}
    return ExperimentResult("Scalar SSM ≡ 1-SS attention", details, meta)


if __name__ == "__main__":
    res = run()
    print(f"[{res.name}] {res.details}")
