from util_fdp import *
import ray

"""
Main code: Global results for different distribution families with the same mean, only consider the median
"""


ray.init(runtime_env={"working_dir": "."})  # Set working directory
os.makedirs("output", exist_ok=True)
dist_type = 'normal'   
gene_process = 'hete_d' # 'homo /hete' / 'hete_d'
mode='global'
T_mode='samples'
n_sim = 1000
seed = 2025
n_clients = 10
a,b,c = 0.51, 100, 2

Ts = [10000, 50000] if T_mode == 'samples' else [5000,10000]
taus = [0.3,0.5,0.8] if gene_process == 'homo' else [0.5]

rs = [0.25,0.9]
client_rss = generate_lists(rs[0], rs[1], n_clients)
lr_ratio = np.mean(client_rss,axis=1)
rs_names = [rs[0],'hetero',rs[1]]

nn_ct = len(Ts)*len(taus)*len(client_rss)

# Initialize result storage dictionaries
cvgdict = {}
maedict = {}

# Federated simulation
ct = 0
for T in Ts:
    # Initialize dictionary level for current T
    cvgdict[T] = {};maedict[T] = {}
    for tau in taus:
        # Initialize dictionary level for current quantiles
        cvgdict[T][tau] = {};maedict[T][tau] = {}
        for name_idx, client_rs in enumerate(client_rss):
            c_rs = c * lr_ratio[name_idx]
            name = rs_names[name_idx]
            cvgdict[T][tau][name] = {};maedict[T][tau][name] = {}
        
            t1 = time.time()
            fed_results = run_federated_simulation(
                dist_type=dist_type,taus=tau,
                client_rs=client_rs,n_clients=n_clients,
                T=T,E_typ='cons',E_cons=1,gene_process=gene_process,mode=mode,
                n_sim=n_sim,base_seed=seed,
                T_mode=T_mode, a=a, b=b,c=c_rs)
            # Analyze results
            output = analyze_results(fed_results,z_score=6.74735)
            cvg = output['coverage'];mae = output['mae']
    
            # Store results
            cvgdict[T][tau][name] = cvg;maedict[T][tau][name] = mae
            t2 = time.time()
            ct += 1
            save_pickle(cvgdict, f'output/case_{mode}_{gene_process}_cvg.pkl');save_pickle(maedict, f'output/case_{mode}_{gene_process}_mae.pkl')
            print(f'Ts:{T} tau:{tau} TC:{(t2-t1)/60:.2f}min LTC:{(t2-t1)*(nn_ct-ct)/60:.2f}min')
                    
ray.shutdown()
