import seaborn as sns
import matplotlib
matplotlib.rcParams.update({'font.size': 24})
import matplotlib.pyplot as plt
import pandas as pd
import numpy as np

sigma1 = 1
sigma2 = 1
n = 50
m = 2000

data = []

means = np.zeros(m)

for i in range(n):
    a = np.random.randn(m) * sigma1
    for j in range(1,m):
        b = a[:j]
        std = np.std(b)
        tau = np.sqrt(np.maximum(std * std - sigma2 * sigma2, 0))
        means[j] += tau
        data.append({'N':j, 'tau':tau, 'line':i})

means /= n
data2 = []
data3 = []
for j in range(1, m):
    data2.append({'N':j, 'tau':means[j]})
    data3.append({'N':j, 'tau':np.sqrt(1/(j+1))})
data = pd.DataFrame(data)
data2 = pd.DataFrame(data2)
data3 = pd.DataFrame(data3)
print(data3)

ax = sns.lineplot(x='N',y='tau',units="line", data=data,  linewidth=0.2,  estimator=None, color='grey')
plt.setp(ax.lines, alpha=.1)
sns.lineplot(x='N',y='tau',data=data2, label='PVI Averaged', linewidth = 2.0, color='black')
sns.lineplot(x='N',y='tau',data=data3, label='VI', linewidth = 2.0, color=sns.color_palette()[1])

plt.legend()
plt.xlabel('n')
plt.ylabel('Optimal std for $q(\\theta)$')
plt.ylim([0, 2.5])
plt.title('$\sigma_{\\text{true}}=1$')
plt.tight_layout()
plt.savefig('figure2/normal/normal1.pdf')