import numpy as np
import random
from environment import Environment
import time
import concurrent.futures
from get_api_mu import answer_multiple_choice_questions
from C2MAB_V import C2MAB_V
from C2MAB_V_direct import C2MAB_V_direct

def parallel_C2MAB_V(L,K,T,C,log_ind,CB_coefficient,LCB_coefficient,epsilon_num):
    np.random.seed(log_ind)
    random.seed(log_ind)
    questions = []  # from SciQ
    mu = answer_multiple_choice_questions(questions)
    cost = []
    env = Environment(L,C,mu,cost)
    Conjunctive_problem = C2MAB_V(K,env,T,CB_coefficient,log_ind,LCB_coefficient)
    reward_t, violation_t, starttime = Conjunctive_problem.run()
    runtime = time.time()-starttime
    np.savez('C2MAB_V_AIC_'+str(K)+'_'+str(L)+'_'+str(C)+'_seed'+str(log_ind)+'_times'+str(T)+'_UCB'+str(CB_coefficient)+'_LCB'+str(LCB_coefficient),violation_t, reward_t, runtime)

def parallel_C2MAB_V_direct(L,K,T,C,log_ind,CB_coefficient,LCB_coefficient,epsilon_num):
    np.random.seed(log_ind)
    random.seed(log_ind)
    questions = []  # from SciQ
    mu = answer_multiple_choice_questions(questions)
    cost = []
    env = Environment(L,C,mu,cost)
    C2MAB_V_direct_alg = C2MAB_V_direct(K,env,T,CB_coefficient,log_ind,LCB_coefficient)

    reward_t, violation_t, starttime= C2MAB_V_direct_alg.run()
    runtime = time.time()-starttime

    np.savez('C2MAB_V_direct_AIC_'+str(K)+'_'+str(L)+'_'+str(C)+'_seed'+str(log_ind)+'_times'+str(T)+'_UCB'+str(CB_coefficient)+'_LCB'+str(LCB_coefficient),violation_t,reward_t,runtime)


if __name__ == "__main__":
    n_low = 0
    n_trials = 5
    choose_seed = [200,201,202,203,204]
    m = 10000
    with concurrent.futures.ProcessPoolExecutor(max_workers=1) as executor:
        for i in range(n_low,  n_low + n_trials):
            executor.submit(parallel_C2MAB_V,L=9,K=4,T=m,C=0.3,log_ind=choose_seed[i],CB_coefficient=0.3,LCB_coefficient=0.01,epsilon_num=10)
            executor.submit(parallel_C2MAB_V,L=9,K=4,T=m,C=0.3,log_ind=choose_seed[i],CB_coefficient=1,LCB_coefficient=0.05,epsilon_num=10)
            executor.submit(parallel_C2MAB_V,L=9,K=4,T=m,C=0.3,log_ind=choose_seed[i],CB_coefficient=0.3,LCB_coefficient=0.05,epsilon_num=10)
            executor.submit(parallel_C2MAB_V,L=9,K=4,T=m,C=0.3,log_ind=choose_seed[i],CB_coefficient=1,LCB_coefficient=0.01,epsilon_num=10)
            executor.submit(parallel_C2MAB_V_direct,L=9,K=4,T=m,C=0.3,log_ind=choose_seed[i],CB_coefficient=0.3,LCB_coefficient=0.01,epsilon_num=10)