from utils_self import *

device = torch.device("cuda") if torch.cuda.is_available() else torch.device("cpu")

# NonLinear
cfg = DGPConfig(
    taus=24, p=3, seed=2026, device=device,
    emission="nonlinear",
    phi1_range=0.3,
    Xi1_range=0.2,
    alpha_mean=0.0,
    alpha_sd=0.3,
    add_state_noise=False,
    round_digits=None,
)
params = generate_params(cfg)

res = monte_carlo_ATE_with_linear_baseline(
    params,
    Iter_n=[1000],
    emission="nonlinear",
    seed=2026,
    add_state_noise=cfg.add_state_noise,
    act_hi=+1.0,
    act_lo=-1.0,
    include_closed_form=True,  
)
print("\nNonlinear emission example (MC + linear baseline):")
print("Linear baseline (rec):", res[-1])
print("Closed-form baseline:", res[-2])
print("MC 1000:", res[1000])

