import numpy as np
import random
from environment import Environment
import time
import concurrent.futures

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)
    env = Environment(L, C)
    Linear_problem = C2MAB_V(K, env, T, CB_coefficient, log_ind, LCB_coefficient)
    reward_t, violation_t, starttime = Linear_problem.run()
    runtime = time.time() - starttime

    np.savez('C2MAB_V_SUC_' + 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)
    env = Environment(L, C)
    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_SUC_' + 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 = 10
    choose_seed = [500, 501, 502, 503, 504, 505, 506, 507, 508, 509]
    m = 10000
    with concurrent.futures.ProcessPoolExecutor(max_workers=6) 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.5, 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.5, 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.5, 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.5, 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.5, log_ind=choose_seed[i],CB_coefficient=0.3,LCB_coefficient=0.01,epsilon_num=10)