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

figsizes = {10:(5,4),
            100:(4,4),
            1000:(4,4),
            10000:(5.8,4)}

for n in [10, 100, 1000, 10000]:
    data = []
    for alpha in [0.0, 0.5, 1.0]:
        for seed in [0,1,2,3,4]:
            for lamb in [0.0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0]:
                file = f'result_inter\RegressionInterpolated_{alpha}_{n}_40_Basic_PACMVIBasic\VIBasic_{lamb}_{seed}_100'
                try:
                    with open(file) as f:
                        test_elpd = float(f.readline().split()[-1])
                        data.append({'$\\lambda$':lamb, '$\\alpha$':str(alpha), 'elpd':test_elpd/10000})
                except:
                    print(file)
    data = pd.DataFrame(data)

    plt.figure(figsize=figsizes[n])
    sns.lineplot(data = data, x='$\\lambda$', y='elpd', hue='$\\alpha$', legend=(n==10000),)
    plt.title(f'n={n}')
    plt.ylim([-3, -0.5])
    if n!=10:
        plt.yticks([])
        plt.ylabel('')
    if n == 10000:
        plt.legend(frameon=False, loc=(1.1, 0.4), title="$\\alpha$")
    plt.tight_layout()
    plt.savefig(f'figure2/regulraization_{n}.pdf')