import numpy as np
from scipy import stats

def Wald_Test(heads, tails):
    # this test follows the procedure described in
    # https://stats.stackexchange.com/a/530465
    x = heads
    n = heads + tails
    p_hat = x / n
    print(f"Point estimate p_hat = {x}/{n} = {p_hat:.3f}")
    z_critical = 1.96  # for 95% CI
    margin_error = z_critical * np.sqrt(p_hat * (1 - p_hat) / n)
    ci_lower = p_hat - margin_error
    ci_upper = p_hat + margin_error
    print(f"95% CI: ({ci_lower:.3f}, {ci_upper:.3f})")
    p_value = stats.binomtest(x, n, 0.5).pvalue
    print(f"P-value for fairness test: {p_value:.3f}")
    alpha = 0.05
    if p_value < alpha:
        print(f"Reject H0: Coin is significantly unfair (p < {alpha})")
    else:
        print(f"Fail to reject H0: Cannot conclude coin is unfair (p ≥ {alpha})")