
import numpy as np
import matplotlib.pyplot as plt
import matplotlib
import pickle 

from numpy.random import choice
import copy
#%%
#%%
#import pylab
# this one is used to generate comparison figure
runnum = 200
T = 30
compare = T
new_colors = ['#1f77b4', '#ff7f0e', '#2ca02c', '#d62728',
              '#9467bd', '#8c564b', '#e377c2', '#7f7f7f',
              '#bcbd22', '#17becf']
# store real error
#errormat = np.ones([runnum, T])
errormat1 = np.ones([runnum, T])
errormat2 = np.ones([runnum, T])
errormat3 = np.ones([runnum, T])
errormat4 = np.ones([runnum, T])
errormat5 = np.ones([runnum, T])
errormat6 = np.ones([runnum, T])
errormat7 = np.ones([runnum, T])
errormat = np.ones([runnum, T])
x1 = list(range(1, T+1))
fig2, ax2 = plt.subplots()
for i in [0,  1, 2, 3]:
    if i == 0:
        errormat = errormat1
        str_label = 'random'
        color = 'b'
    elif i == 1:
        errormat = errormat2
        str_label = 'MES'
        color = 'y'
    elif i == 2:
        errormat = errormat3
        str_label = 'BALD'
        color = 'g'
    elif i == 3:
        errormat = errormat4
        str_label = 'ELR'
        color = 'r'
#    elif i == 4:
#        errormat = errormat5
#        str_label = 'Weighted_MOCU'
#        color = 'm'
    elif i == 4:
        errormat = errormat6
        str_label = 'Weighted_MOCU2'
    elif i == 5:
        errormat = errormat7
        str_label = 'Soft_MOCU2'
    elif i == 6:
        errormat = errormat7
        str_label = 'Soft_MOCU10'
    elif i == 7:
        errormat = errormat7
        str_label = 'Soft_MOCU20'
    elif i == 8:
        errormat = errormat7
        str_label = 'Soft_MOCU2_10'
    elif i == 9:
        errormat = errormat7
        str_label = 'Soft_MOCU2_20'
    f = open(str_label+'error.txt', 'r')
    a = f.readlines()
    b = [x.split() for x in a]
    floatmat = [[float(y) for y in x] for x in b]
    npmat = np.array(floatmat)
    errormat[:] = npmat[0:runnum]
    f.close()
    if i == 1:
        str_label = 'MES'
    elif i == 4:
        str_label = 'Weighted_MOCU'
#    ax2.plot(x1[0:compare], np.mean(errormat[:, 0:compare], axis = 0) , label = str_label, color = new_colors[i])
    stdlist = np.std(errormat[:, 0:compare], axis = 0)
#    print(stdlist)
    ax2.errorbar(x1[0:compare], np.mean(errormat[:, 0:compare], axis = 0),yerr = stdlist[ 0:compare]/np.sqrt(runnum), 
                 errorevery = 1 , label = str_label, color = new_colors[i])
#ax2.set_yscale('log')
ax2.set_xlabel('Iteration number')
ax2.set_ylabel('error')
#ax2.set_yticks([0.001, 0.005])
#ax2.get_yaxis().set_major_formatter(matplotlib.ticker.ScalarFormatter())
#ax2.set_xticks(list(range(2, 21, 2)))
#ax2.set_yticks([0.001], ['10'])
ax2.legend()

#%%
fig2.savefig('simulatederror3.pdf')
#%%
#letterEF
#import pylab
# this one is used to generate comparison figure
runnum = 500
T = 500
compare = T
new_colors = ['#1f77b4', '#ff7f0e', '#2ca02c', '#d62728',
              '#9467bd', '#8c564b', '#e377c2', '#7f7f7f',
              '#bcbd22', '#17becf']
str_list = ['random', 'MES', 'BALD', 'ELR', 'Weighted_MOCU2', 'Soft_MOCU2_10', 'Soft_MOCU2_20']
# store real error
#errormat = np.ones([runnum, T])
errormat1 = np.ones([runnum, T])
errormat2 = np.ones([runnum, T])
errormat3 = np.ones([runnum, T])
errormat4 = np.ones([runnum, T])
errormat5 = np.ones([runnum, T])
errormat6 = np.ones([runnum, T])
errormat7 = np.ones([runnum, T])
x1 = list(range(1, T+1))
fig2, ax2 = plt.subplots()
for i, str_label in enumerate(str_list):
#    if i == 0:
#        errormat = errormat1
#        str_label = 'random'
#        color = 'b'
#    elif i == 1:
#        errormat = errormat2
#        str_label = 'MES'
#        color = 'y'
#    elif i == 2:
#        errormat = errormat3
#        str_label = 'BALD'
#        color = 'g'
#    elif i == 3:
#        errormat = errormat4
#        str_label = 'ELR'
#        color = 'r'
##    elif i == 4:
##        errormat = errormat5
##        str_label = 'Weighted_MOCU'
##        color = 'm'
#    elif i == 4:
#        errormat = errormat6
#        str_label = 'Weighted_MOCU2'
#    elif i == 5:
#        errormat = errormat7
#        str_label = 'Soft_MOCU2'
#    elif i == 6:
#        errormat = errormat7
#        str_label = 'Soft_MOCU10'
#    elif i == 7:
#        errormat = errormat7
#        str_label = 'Soft_MOCU20'
#    elif i == 8:
#        errormat = errormat7
#        str_label = 'Soft_MOCU2_10'
#    elif i == 9:
#        errormat = errormat7
#        str_label = 'Soft_MOCU2_20'
    f = open(str_label+'error.txt', 'r')
    a = f.readlines()
    b = [x.split() for x in a]
    floatmat = [[float(y) for y in x] for x in b]
    npmat = np.array(floatmat)
    errormat[:] = npmat[0:runnum]
    f.close()
#    if i == 1:
#        str_label = 'MES'
#    ax2.plot(x1[0:compare], np.mean(errormat[:, 0:compare], axis = 0) , label = str_label, color = new_colors[i])
    stdlist = np.std(errormat[:, 0:compare], axis = 0)
#    print(stdlist)
    ax2.errorbar(x1[0:compare], np.mean(errormat[:, 0:compare], axis = 0),
                 yerr = stdlist[ 0:compare]/np.sqrt(runnum), errorevery = 9, label = str_label,color = new_colors[i] )
ax2.set_yscale('log')
ax2.set_xlabel('Iteration number')
ax2.set_ylabel('error regret')
#ax2.set_yticks([0.001, 0.005])
#ax2.get_yaxis().set_major_formatter(matplotlib.ticker.ScalarFormatter())
#ax2.set_xticks(list(range(2, 21, 2)))
#ax2.set_yticks([0.001], ['10'])
ax2.legend()

#%%
#import pylab
# this one is used to generate comparison figure
runnum = 5
T = 80
# store real error
errormat1 = np.ones([runnum, T])
errormat2 = np.ones([runnum, T])
errormat3 = np.ones([runnum, T])
errormat4 = np.ones([runnum, T])
errormat5 = np.ones([runnum, T])
x1 = list(range(T))
fig2, ax2 = plt.subplots()
for i in [0,1, 2, 3, 4]:
    if i == 0:
        errormat = errormat1
        str_label = 'random'
    elif i == 1:
        errormat = errormat2
        str_label = 'MES'
    
    elif i == 2:
        errormat = errormat3
        str_label = 'BALD'
    elif i == 3:
        errormat = errormat4
        str_label = 'ELR'
    elif i == 4:
        errormat = errormat5
        str_label = 'Weighted_MOCU'
    for k in range(runnum):
        f = open(str_label+str(k)+'error.txt', 'r')
        a = f.readlines()
        b = [x.split() for x in a]
        floatmat = [[float(y.replace('[', '').replace(']', '')) for y in x] for x in b] #because I store list in text
        npmat = np.array(floatmat)
        errormat[k, :] = npmat[0:runnum]
        f.close()
    ax2.plot(x1, np.mean(errormat, axis = 0), label = str_label)
    np.savetxt(str_label+'error.txt', errormat, fmt = '%10.5f')
ax2.set_yscale('log')
ax2.set_xlabel('Iteration number')
ax2.set_ylabel('error rate')
ax2.set_xticks([1, 10, 20])
ax2.legend()

#%%
with open('object2.data', 'rb') as f:
    dataMOCU, dataentropy, datauncertainty, alist, blist, clist, x1, thetar, pi_theta, pi_theta2 = pickle.load(f)

thetalist = [np.array([a,b, c]) for a in alist for b in blist 
            for c in clist]
PYeqZ = 0.8
#%%
x1 = np.linspace(-0.5, 0.5, 101)
a = thetar[0]
b = thetar[1]
c = thetar[2]
x2curve = a*x1**2+b*x1+c
for i in range(len(dataMOCU)):
    xstar = dataMOCU[i][0]
    ystar = dataMOCU[i][1]
    pi_theta = ParameterUpdate(pi_theta, xstar, ystar)
    if i%5 == 0:
        fig1, ax1 = plt.subplots()
        
        ax1.plot(x1, x2curve, 'b',  linewidth = 3)
        ax1.set_xlabel('$x_1$')
        ax1.set_ylabel('$x_2$')
        plt.ylim(0, 2)
    #    if ystar:
    #        ax1.plot(xstar[0], xstar[1], 'go')
    #    else:
    #        ax1.plot(xstar[0], xstar[1], 'rx')
    #    ax1.text(xstar[0], xstar[1], i)
    
        for j in choice(len(pi_theta), 200):
            x2_theta = thetalist[j][0]*x1**2+thetalist[j][1]*x1+thetalist[j][2]
            ax1.plot(x1, x2_theta, 'r', alpha = pi_theta[j]*1)
        for j in range(i+1):
                xstar = dataMOCU[j][0]
                ystar = dataMOCU[j][1]
                if ystar:
                    ax1.plot(xstar[0], xstar[1], 'go')
                else:
                    ax1.plot(xstar[0], xstar[1], 'rx')
                ax1.text(xstar[0], xstar[1], j+1)
#        fig1.savefig(str(i)+'.pdf')


#%%
x1 = np.linspace(-0.5, 0.5, 101)
a = thetar[0]
b = thetar[1]
c = thetar[2]
x2curve = a*x1**2+b*x1+c

#fig1, ax1 = plt.subplots()
ymin = 2*np.ones(x1.shape)
ymax = 0*np.ones(x1.shape)
for theta in theta_list:
    a = theta[0]
    b = theta[1]
    c = theta[2]
    y = a*x1**2+b*x1+c
    ymax = np.minimum(np.maximum(y, ymax), 2)
    ymin = np.maximum(np.minimum(y, ymin), 0)
fig1, ax1 = plt.subplots()
ax1.plot(x1, x2curve, 'b', linewidth = 3)
#ax1.plot(x1, ymax, 'r')
#ax1.plot(x1, ymin, 'r')
#ax1.fill_between(x1, ymin, ymax, alpha = 0.2, facecolor = 'red')
ax1.set_xlabel('$x_1$')
ax1.set_ylabel('$x_2$')

fig1.savefig('0.pdf')

showlist = [1, 3, 5, 7, 9]
k = 0

for i in range(len(data)):
    xstar = data[i][0]
    ystar = data[i][1]
    pi_theta = ParameterUpdate(pi_theta, xstar, ystar)
    if i in showlist:
        k +=1
        ymin = 2*np.ones(x1.shape)
        ymax = 0*np.ones(x1.shape)
        for theta in pi_theta:
            a = theta[0]
            b = theta[1]
            c = theta[2]
            y = a*x1**2+b*x1+c
            ymax = np.minimum(np.maximum(y, ymax), 2)
            ymin = np.maximum(np.minimum(y, ymin), 0)
        fig1, ax1 = plt.subplots()
        ax1.plot(x1, x2curve, 'b',  linewidth = 3)
        ax1.plot(x1, ymax, 'r')
        ax1.plot(x1, ymin, 'r')
        ax1.fill_between(x1, ymin, ymax, alpha = 0.2, facecolor = 'red')
        ax1.set_xlabel('$x_1$')
        ax1.set_ylabel('$x_2$')
        plt.ylim(0, 2)
        for j in range(i+1):
            xstar = data[j][0]
            ystar = data[j][1]
            if ystar:
                ax1.plot(xstar[0], xstar[1], 'go')
            else:
                ax1.plot(xstar[0], xstar[1], 'rx')
            ax1.text(xstar[0], xstar[1], j+1)
        fig1.savefig(str(k)+'.pdf')
    
            
            


#%%
for k in range(10):
    label1 = 'Entropy'+str(k)
    label2 = 'MOCU'+str(k)
    bins = np.linspace(0, 0.5, 50)
    fig3, ax3 = plt.subplots()
    ax3.hist(errormat3[:, k], bins, alpha = 0.5, label = label1, color = 'b')
    ax3.hist(errormat4[:, k], bins, alpha = 0.5, label = label2, color = 'g')
    ax3.legend()
    fig3.savefig('hist'+str(k)+'.pdf')
#%%
#write latex
with open('datawithcerror.txt', 'w') as f0:
    f0.write('& t')
    for j in range(1, errormat.shape[1], 2):
        f0.write('&'+str(j+1))
    f0.write('\\\\\n')
    f0.write('\\hline \\hline ')
    for i in range(4):
        if i == 0:
            errormat = errormat1
            str_label = 'RS'
        elif i == 1:
            errormat = errormat2
            str_label = 'US'
        elif i == 2:
            errormat = errormat3
            str_label = 'Entropy'
        else:
            errormat = errormat4
            str_label = 'MOCU'
        f0.write(str_label+'& mean')
        for j in range(1, errormat.shape[1], 2):
            f0.write('&'+str(round(np.mean(errormat, axis = 0)[j], 4)))
        f0.write('\\\\\n')
        
        f0.write('& std')
        for j in range(1, errormat.shape[1], 2):
            f0.write('&'+str(round(np.std(errormat, axis = 0)[j], 4)))
        f0.write('\\\\\n')
        f0.write('\\hline ')
    
#%%
fig2, ax2 = plt.subplots()
xx = np.array(range(10))
for i in [1, 2, 3]:
    if i == 0:
        errormat = errormat1
        str_label = 'random'
    elif i == 1:
        errormat = errormat2
        str_label = 'reduce_uncertainty'
    elif i == 3:
        errormat = errormat4
        str_label = 'MOCU'
    elif i == 2:
        errormat = errormat3
        str_label = 'Entropy'
    ax2.plot(xx, np.mean(errormat, axis = 1), label = str_label)
ax2.set_yscale('log')
ax2.set_xlabel('Iteration number')
ax2.set_ylabel('Expected OBC error')
ax2.legend()

#%%
#%%
#letterEF
#import pylab
# this one is used to generate comparison figure
runnum = 100
T = 50
compare = 16
new_colors = ['#1f77b4', '#ff7f0e', '#2ca02c', '#d62728',
              '#9467bd', '#8c564b', '#e377c2', '#7f7f7f',
              '#bcbd22', '#17becf']
# store real error
#errormat = np.ones([runnum, T])
errormat1 = np.ones([runnum, T])
errormat2 = np.ones([runnum, T])
errormat3 = np.ones([runnum, T])
errormat4 = np.ones([runnum, T])
errormat5 = np.ones([runnum, T])
errormat6 = np.ones([runnum, T])
errormat7 = np.ones([runnum, T])
x1 = list(range(1, T+1))
fig2, ax2 = plt.subplots()
for i in [0, 1, 2, 3, 4]:
    if i == 0:
        errormat = errormat1
        str_label = 'random'
        color = 'b'
        label = str_label
    elif i == 1:
        errormat = errormat2
        str_label = 'US'
        color = 'y'
        label = 'MES'
    elif i == 2:
        errormat = errormat3
        str_label = 'Entropy'
        color = 'g'
        label = 'BALD'
    elif i == 3:
        errormat = errormat4
        str_label = 'MOCU'
        color = 'r'
        label = 'ELR'
    elif i == 4:
        errormat = errormat5
        str_label = 'Weighted_MOCU'
        color = 'm'
        label = str_label
    elif i == 5:
        errormat = errormat6
        str_label = 'MOCU_modify2'
    elif i == 6:
        errormat = errormat7
        str_label = 'MOCU_modify3'
    f = open(str_label+'error.txt', 'r')
    a = f.readlines()
    b = [x.split() for x in a]
    floatmat = [[float(y) for y in x] for x in b]
    npmat = np.array(floatmat)
    errormat[:] = npmat[0:runnum]
    f.close()
    ax2.plot(x1[0:compare], np.mean(errormat[:, 0:compare], axis = 0) , label = label, color = new_colors[i])
ax2.set_yscale('log')
ax2.set_xlabel('Iteration number')
ax2.set_ylabel('error rate')
ax2.set_xticks(list(range(2, 17, 2)))
ax2.set_yticks([0.01, 0.1])
ax2.get_yaxis().set_major_formatter(matplotlib.ticker.ScalarFormatter())
ax2.legend()
#%%
fig2.savefig('letterPD.pdf')
