"""Wilson 95% CI for the per-stratum recovery rates of Table 4."""
import math, sys
sys.stdout.reconfigure(encoding="utf-8")

def wilson(x, n, z=1.959963984540054):
    if n == 0: return (0.0, 0.0, 0.0)
    p = x/n
    denom = 1 + z*z/n
    centre = (p + z*z/(2*n)) / denom
    half = (z * math.sqrt(p*(1-p)/n + z*z/(4*n*n))) / denom
    return (p*100, max(0.0,(centre-half))*100, min(1.0,(centre+half))*100)

def fisher_pvalue(a, b, c, d):
    """Two-sided Fisher exact p-value on 2x2 table [[a,b],[c,d]]."""
    from math import comb
    n = a+b+c+d; r1 = a+b; c1 = a+c
    obs = comb(r1,a)*comb(n-r1,c1-a)/comb(n,c1)
    p = 0.0
    for k in range(max(0,c1-(n-r1)), min(r1,c1)+1):
        pk = comb(r1,k)*comb(n-r1,c1-k)/comb(n,c1)
        if pk <= obs + 1e-12: p += pk
    return p

cells = [
    ("Lean-Retry",    {"TO":(23,61), "SO":(14,16), "BF":(2,14),  "TS":(92,95)}),
    ("SAF",           {"TO":(23,61), "SO":(12,16), "BF":(6,14),  "TS":(88,95)}),
    ("Sample-Filter", {"TO":(23,61), "SO":(11,16), "BF":(4,14),  "TS":(93,95)}),
]

print("Wilson 95% CI for recovery rates:\n")
print(f"{'Method':<16} {'TO->TS':<22} {'SO->TS':<22} {'BF->TS':<22} {'TS retain':<22}")
for name, d in cells:
    parts = []
    for k in ("TO","SO","BF","TS"):
        x, n = d[k]
        p, lo, hi = wilson(x, n)
        parts.append(f"{p:5.1f}% [{lo:4.1f},{hi:4.1f}]")
    print(f"{name:<16} " + " ".join(parts))

print("\nFisher exact p-value, pairwise homogeneity of TO->TS rate (23/61 vs 23/61):")
for (a, _), (b, _) in [(("LR",1),("SAF",2)), (("LR",1),("SF",3)), (("SAF",2),("SF",3))]:
    p = fisher_pvalue(23, 61-23, 23, 61-23)
    print(f"  {a} vs {b}: p = {p:.4f}")
