from util_fdp import *
import ray

"""
Main code: Global results for same distribution family with different means
"""

ray.init(runtime_env={"working_dir": "."})  # Set working directory

os.makedirs("output", exist_ok=True)
dist_type = 'normal'  
gene_process = 'hete'
mode='global'
T_mode='samples'
n_sim = 1000
seed = 2025
n_clients = 10
a=0.51; b=100; c=2


Ts = [10000, 50000] if T_mode == 'samples' else [5000,10000]
taus = [0.3,0.5,0.8]
rs = [0.25,0.9]

n_clients = 10
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]]

Es = [1, 5,'log']
nn_ct = len(Ts)*len(taus)*len(client_rss)*len(Es)

# 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,T_mode=T_mode,
                n_sim=n_sim,base_seed=seed,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()

