#%%
import numpy as np
import multiprocessing

from joblib import Parallel, delayed
import sys
sys.path.append('D:\\Google Drive\\3-Research\\2019-MOCU-active-learning\\utils')
import ProblemSetting as PS
#with open('RandomGenerator.txt', 'r') as f:
#    datalist = json.load(f)

#from tqdm import tqdm
num_cores = 1
runnum = 2
T = 5
methodlist = [4, 5, 9]
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 == 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'
#%%
#import matplotlib.pyplot as plt
#import MethodsTrueData as Methods
#fig2, ax2 = plt.subplots()
#fig1, ax1 = plt.subplots()
#fig3, ax3 = plt.subplots()
#pi_theta = np.ones(len(PS.thetalist))
#pi_theta /= pi_theta.sum()
#problem = Methods.Problem(PS.xspace, PS.thetalist)
#problem.Initialize(pi_theta)
#
#entropymat = problem.EntropyWhole()
#ax1.plot(PS.xspace[0], entropymat)
#ax1.set_xlabel('x')
#ax1.set_ylabel('mutual information')
#fig1.savefig('entropy-change.pdf')
#
#designmat = problem.DesignValueWhole()
#ax2.plot(PS.xspace[0], designmat, 'r')
#ax2.set_xlabel('x')
#ax2.set_ylabel('design value')
#fig2.savefig('design-change.pdf')
#
#modifymat = problem.MOCU_ModifyWhole()
#ax3.plot(PS.xspace[0], modifymat, 'g')
#ax3.set_xlabel('x')
#ax3.set_ylabel('design value')
#fig3.savefig('modify.pdf')








#thetar = [0.12, 0.003]
#xstar = [0, 0.06]
#ystar = fr(xspace, thetar)
#pyx = PzGivenXTheta(xspace, thetar)