import h5py
import scipy.stats as stats
import numpy as np
from tqdm import tqdm
import math
from scipy.special import comb
from scipy.integrate import quad

def get_k_pro(file_name,k):
    with h5py.File(file_name,'r') as f:
        dataset = f['distances']
        print(len(dataset))
        angular = []
        for i in range(len(dataset)):
            for j in range(k):
                angular.append(dataset[i][j])

    angular = np.array(angular)
    
    a, b, loc, scale = stats.beta.fit(angular, floc=0, fscale=math.pi)
    
    return a,b

def integrand(theta,M,d,fk_pdf):
    summation = sum(comb(M,j) * ((theta / math.pi) ** j) * ((1 - (theta / math.pi)) ** (M - j)) for j in range(d + 1))
    return summation * fk_pdf(theta)

if __name__ == '__main__':
    file_name = ""
    a,b = get_k_pro(file_name=file_name,k=10)
    M = 256
    K = 10
    d = 30
    fk = stats.beta(a=a,b=b,loc=0,scale=math.pi)
    fk_pdf = fk.pdf
    integeral,_ = quad(integrand,0,math.pi,args=(M,d,fk_pdf))
    
    print(integeral)