import numpy as np
import scipy

results = np.array([
    [11, 10, 9, 12,],
    [29, 28, 32, 26,],
    [16, 23, 20, 17,],
    ])
denominators = np.array([28, 90, 72])
names = ["exact", "qk64", "qk128", "qk256"]

def analyze(rows, cols):
    low_perc = 0.05
    high_perc = 0.95
    print(f"percentiles {low_perc} - {high_perc} for rows {rows}:")
    total_den = sum(denominators[i] for i in rows)
    total_success = sum(results[i] for i in rows)
    print(f"raw rate: {total_success/total_den}")
    for col in cols:
        name = names[col]
        low, high = [], []
        low, high = scipy.stats.beta.ppf(np.array([low_perc, high_perc]), total_success[col] + 1, total_den - total_success[col] + 1)
        print(f"{name}: {float(low):.2f} - {float(high):.2f}")



if __name__ == '__main__':
    analyze(rows=[0,], cols=[0,1,2,3])
    analyze(rows=[1,], cols=[0,1,2,3])
    analyze(rows=[2,], cols=[0,1,2,3])
    analyze(rows=[0,1], cols=[0,1,2,3])
    analyze(rows=[0,1,2], cols=[0,1,2,3])
