from utils import *
import numpy as np
import scipy.stats as stats
import pandas as pd
import random
from scipy.stats import norm
n_seeds = 100
results_n_rej = []
results_prop = []
results_n_fd = []
n_boundaryfalse = []
# alpha_list = [0.1, 0.2, 0.3, 0.4, 0.5] 
alpha = 0.2
# pi1list = [0.1,0.2,0.3,0.4,0.5]
signal_list = [4,5,6,7,8]
pi1 = 0.2
all_results_records = []
for signal in signal_list:
    print(f"\n>>> Running for signal = {signal}")
    for seed in range(n_seeds):
        np.random.seed(seed)
        p_values_null , p_values_alt, Sigma = generate_correlated_data(m=100, pi1=pi1, muc=signal, sigma=1, rho=0.5, structure='cs', seed=seed)
        e_values_null , e_values_alt = generate_correlated_data_evalues(m=100, pi1=pi1, muc=signal, sigma=1, rho=0.5, seed=seed)
        p_values = np.concatenate([p_values_null, p_values_alt])
        e_values = np.concatenate([e_values_null, e_values_alt])
        n_null = len(p_values_null)
        n_alt = len(p_values_alt)
        ground_truth = np.concatenate([np.zeros(n_null), np.ones(n_alt)])
        
        
        # simes_pbfdr
        reject_indices_simes, boundary_indices_simes, _ = simesdomino(p_values,  alpha=alpha)
        is_boundary_false_simes = 0
        if boundary_indices_simes > -1:
       
            if ground_truth[boundary_indices_simes] == 0:
                is_boundary_false_simes = 1
                
        # slmethod
        reject_indices_sl, boundary_indices_sl ,_ = sl_procedure(p_values,  alpha=alpha)
        
        is_boundary_false_sl = 0
        if boundary_indices_sl > -1:
           
            if ground_truth[boundary_indices_sl] == 0:
                is_boundary_false_sl = 1
                
        # harmonic-pbfdr
        reject_indices_harmonic, boundary_indices_harmonic ,_ = harmonicpbfdr(p_values,  alpha=alpha)
        is_boundary_false_harmonic = 0 
        if boundary_indices_harmonic > -1:
            if ground_truth[boundary_indices_harmonic] == 0:
                is_boundary_false_harmonic = 1
        
        reject_indices_ebfdr, boundary_indices_ebfdr = bfdr_k_eclosure(e_values, k=1, alpha=alpha)
        is_boundary_false_ebfdr = kbfdr_evaluate(ground_truth, boundary_indices_ebfdr, k=1)
        
        #2domino_pbfdr
        reject_indices_2dominop, boundary_indices_2dominop = bfdr_k_domino(p_values, k=2, alpha=alpha)
        is_boundary_false_2dominop = kbfdr_evaluate(ground_truth, boundary_indices_2dominop, k=2)
        
        #2edomino_ebfdr
        reject_indices_2edominoe, boundary_indices_2edominoe = bfdr_k_eclosure(e_values, k=2, alpha=alpha)
        is_boundary_false_2edominoe = kbfdr_evaluate(ground_truth, boundary_indices_2edominoe, k=2)
        
        # 3-domino_pbfdr
        reject_indices_3dominop, boundary_indices_3dominop = bfdr_k_domino(p_values, k=3, alpha=alpha)
        is_boundary_false_3dominop = kbfdr_evaluate(ground_truth, boundary_indices_3dominop, k=3)
        
        # 3edomino_ebfdr
        reject_indices_3edominoe, boundary_indices_3edominoe = bfdr_k_eclosure(e_values, k=3, alpha=alpha)
        is_boundary_false_3edominoe = kbfdr_evaluate(ground_truth, boundary_indices_3edominoe, k=3)
        
        
        n_rej_ebfdr, prop_ebfdr, n_fd_ebfdr = evaluate_procedure(reject_indices_ebfdr, p_values, ground_truth)
        n_rej_2dominop, prop_2dominop, n_fd_2dominop = evaluate_procedure(reject_indices_2dominop, p_values, ground_truth)
        n_rej_simes, prop_simes, n_fd_simes = evaluate_procedure(reject_indices_simes, p_values, ground_truth)
        n_rej_sl, prop_sl, n_fd_sl = evaluate_procedure(reject_indices_sl, p_values, ground_truth)
        n_rej_harmonic, prop_harmonic, n_fd_harmonic = evaluate_procedure(reject_indices_harmonic, p_values, ground_truth)
        n_rej_2edominoe, prop_2edominoe, n_fd_2edominoe = evaluate_procedure(reject_indices_2edominoe, p_values, ground_truth)
        n_rej_3dominop, prop_3dominop, n_fd_3dominop = evaluate_procedure(reject_indices_3dominop, p_values, ground_truth)
        n_rej_3edominoe, prop_3edominoe, n_fd_3edominoe = evaluate_procedure(reject_indices_3edominoe, p_values, ground_truth)
        n_rej_sl, prop_sl, n_fd_sl = evaluate_procedure(reject_indices_sl, p_values, ground_truth)
        record = {
            "alpha": alpha,            
            "seed": seed, 
            "signal": signal,               
            "n_rej_simes": n_rej_simes,            
            "rejectionprop_simes": prop_simes,             
            "n_fd_simes": n_fd_simes,              
            "boundary_error_simes": is_boundary_false_simes,
            "n_rej_harmonic": n_rej_harmonic,            
            "rejectionprop_harmonic": prop_harmonic,             
            "n_fd_harmonic": n_fd_harmonic,             
            "boundary_error_harmonic": is_boundary_false_harmonic,
            "n_rej_sl": n_rej_sl,
            "rejectionprop_sl": prop_sl,
            "n_fd_sl": n_fd_sl,
            "boundary_error_sl": is_boundary_false_sl,
            "n_rej_ebfdr": n_rej_ebfdr,
            "rejectionprop_ebfdr": prop_ebfdr,
            "n_fd_ebfdr": n_fd_ebfdr,
            "boundary_error_ebfdr": is_boundary_false_ebfdr,
            "rejectionprop_2dominop": prop_2dominop,            
            "n_fd_2dominop": n_fd_2dominop,              
            "boundary_error_2dominop": is_boundary_false_2dominop,
            "n_rej_2edominoe": n_rej_2edominoe,          
            "rejectionprop_2edominoe": prop_2edominoe,              
            "n_fd_2edominoe": n_fd_2edominoe,              
            "boundary_error_2edominoe": is_boundary_false_2edominoe,
            "n_rej_3dominop": n_rej_3dominop,            
            "rejectionprop_3dominop": prop_3dominop,              
            "n_fd_3dominop": n_fd_3dominop,              
            "boundary_error_3dominop": is_boundary_false_3dominop,
            "n_rej_3edominoe": n_rej_3edominoe,           
            "rejectionprop_3edominoe": prop_3edominoe,              
            "n_fd_3edominoe": n_fd_3edominoe,             
            "boundary_error_3edominoe": is_boundary_false_3edominoe,
            "n_rej_2dominop": n_rej_2dominop,            
            
        }
        all_results_records.append(record)
df_raw = pd.DataFrame(all_results_records)
        
df_summary = df_raw.groupby("signal").agg(
avg_n_rej_simes=('n_rej_simes', 'mean'),
rejection_prop_simes=('rejectionprop_simes', 'mean'),
avg_fd_simes=('n_fd_simes', 'mean'),
bfdr_simes=('boundary_error_simes', 'mean'),
avg_n_rej_harmonic=('n_rej_harmonic', 'mean'),
rejection_prop_harmonic=('rejectionprop_harmonic', 'mean'),
avg_fd_harmonic=('n_fd_harmonic', 'mean'),
bfdr_harmonic=('boundary_error_harmonic', 'mean'),
avg_sl_n_rej_sl=('n_rej_sl', 'mean'),
rejection_prop_sl=('rejectionprop_sl', 'mean'),
avg_fd_sl=('n_fd_sl', 'mean'),
bfdr_sl=('boundary_error_sl', 'mean'),
avg_n_rej_ebfdr=('n_rej_ebfdr', 'mean'),
rejection_prop_ebfdr=('rejectionprop_ebfdr', 'mean'),
avg_fd_ebfdr=('n_fd_ebfdr', 'mean'),
bfdr_ebfdr=('boundary_error_ebfdr', 'mean'),
avg_n_rej_2dominop=('n_rej_2dominop', 'mean'),
rejection_prop_2dominop=('rejectionprop_2dominop', 'mean'),
avg_fd_2dominop=('n_fd_2dominop', 'mean'),
bfdr_2dominop=('boundary_error_2dominop', 'mean'),
avg_n_rej_2edominoe=('n_rej_2edominoe', 'mean'),
rejection_prop_2edominoe=('rejectionprop_2edominoe', 'mean'),
avg_fd_2edominoe=('n_fd_2edominoe', 'mean'),
bfdr_2edominoe=('boundary_error_2edominoe', 'mean'),
avg_n_rej_3dominop=('n_rej_3dominop', 'mean'),
rejection_prop_3dominop=('rejectionprop_3dominop', 'mean'),
avg_fd_3dominop=('n_fd_3dominop', 'mean'),
bfdr_3dominop=('boundary_error_3dominop', 'mean'),
avg_n_rej_3edominoe=('n_rej_3edominoe', 'mean'),
rejection_prop_3edominoe=('rejectionprop_3edominoe', 'mean'),
avg_fd_3edominoe=('n_fd_3edominoe', 'mean'),
bfdr_3edominoe=('boundary_error_3edominoe', 'mean'),
).reset_index()
print(df_summary)