#%%
import numpy as np
import multiprocessing
import ProblemSetting as PS
from joblib import Parallel, delayed


#with open('RandomGenerator.txt', 'r') as f:
#    datalist = json.load(f)

#from tqdm import tqdm
num_cores = multiprocessing.cpu_count()
runnum = 500
T = 300
methodlist = [0, 1, 2, 3, 5, 6, 7, 8, 9, 10]
xnum = 100
thetanum = 100

inputs = list(range(runnum))
sq = np.random.SeedSequence(555)
rglist = sq.generate_state(runnum)
if __name__ == "__main__":
    processed_list = Parallel(n_jobs=num_cores)(delayed(PS.SingleIteration)(k, T, rglist, methodlist, xnum, thetanum) for k in inputs)


#if i == 0:
#    str_label = 'random'
#elif i == 1:
#    str_label = 'MES'
#elif i == 2:
#    str_label = 'BALD'
#elif i == 3:
#    str_label = 'ELR'
#elif i == 4:
#    str_label = 'Weighted_MOCU'
#elif i == 5:
#    str_label = 'Weighted_MOCU2'
#elif i == 6:
#    str_label = 'Soft_MOCU10'
#elif i == 7:
#    str_label = 'Soft_MOCU2'
#elif i == 8:
#    str_label = 'Soft_MOCU20'
#elif i == 9:
#    str_label = 'Soft_MOCU2_20'
#elif i == 10:
#    str_label = 'Soft_MOCU2_10'