

import numpy as np
from scipy.stats import chi2

def hfsm_mahalanobis(
    decay_rate, s, tau,

    mu_d=0.5, mu_s=0.32, mu_tau=-0.5,
    sigma_d=0.05, sigma_s=0.08, sigma_tau=0.71,
    cov=None,
    penalty_if_out_of_bounds=False,
    bounds=None,           
    score_mode="gaussian"  
):
    if penalty_if_out_of_bounds and bounds is not None:
        br = bounds.get('decay_rate', (None, None))
        bs = bounds.get('s', (None, None))
        bt = bounds.get('tau', (None, None))
        if (br[0] is not None and decay_rate < br[0]) or (br[1] is not None and decay_rate > br[1]) \
           or (bs[0] is not None and s < bs[0]) or (bs[1] is not None and s > bs[1]) \
           or (bt[0] is not None and tau < bt[0]) or (bt[1] is not None and tau > bt[1]):
            return {"score": 0.0, "D2": np.inf, "p_value": 0.0}

    theta = np.array([decay_rate, s, tau], dtype=float)
    mu    = np.array([mu_d, mu_s, mu_tau], dtype=float)

    if cov is None:
        cov = np.diag([sigma_d**2, sigma_s**2, sigma_tau**2])
    inv_cov = np.linalg.inv(cov)


    delta = theta - mu
    D2 = float(delta.T @ inv_cov @ delta)

    if score_mode == "gaussian":
        score = np.exp(-0.5 * D2)
    else:
        score = 1.0 / (1.0 + D2)

    p_value = 1.0 - chi2.cdf(D2, df=3)

    return {"score": score, "D2": D2, "p_value": p_value,"the square root of D2": np.sqrt(D2)}  


# decay rate, s, tau
res_rwkv = hfsm_mahalanobis(0.27, 1.62, 0.59)
res_mamba = hfsm_mahalanobis(0.28, 1.59, 0.33)
res_llama = hfsm_mahalanobis(0.13, 2.0, 1.00)
res_deepseek = hfsm_mahalanobis(0.35, 1.69, -0.24)
res_sgd = hfsm_mahalanobis(0.41, 2.0, 0.15)
res_er = hfsm_mahalanobis(0.27, 2.0, 1.02)
res_ewc = hfsm_mahalanobis(0.22, 2.0, 1.65)



print("LLAMA:", res_llama)
print("DEEPSEEK:", res_deepseek)
print("RWKV:", res_rwkv)
print("Mamba:", res_mamba)
print("SGD:", res_sgd)
print("ER:", res_er)
print("EWC:", res_ewc)

