import trackexp as tx
import matplotlib.pyplot as plt
df = tx.get_data("exp_video-alanine-ack-stairway", 'training_inner')
df_o = tx.get_data("exp_video-alanine-ack-stairway", 'training')

import numpy as np
import pandas as pd
import matplotlib.pyplot as plt

def ema(series, span):
    return series.ewm(span=span, adjust=False).mean()

df['kappa_bar_0_smooth'] = ema(df['kappa_bar_0'], span=50)
df['kappa_bar_0_est_smooth'] = ema(df['kappa_bar_0_est'], span=50)

micro_iter = np.arange(df.shape[0])
micro_iter = df_o.shape[0] * (micro_iter / micro_iter[-1])

fig, ax1 = plt.subplots(figsize=(5,3))

plt.rcParams.update({'font.size': 12})
plt.grid(True)

ax1.plot(micro_iter, np.abs(df['kappa_bar_0_smooth']), label=r'real $\bar{\kappa}$', color='k')
ax1.plot(micro_iter, df['kappa_bar_0_est_smooth'], label=r'est $\bar{\kappa}$', color='gray')
ax1.set_ylabel(r'$\bar{\kappa}$')

ax2 = ax1.twinx()
ax2.plot(df_o['test_acc_averaged model'], color='r', label='test accuracy')
ax2.set_ylabel('Test Accuracy')
ax1.set_xlabel(r'Epoch')

ax1.legend(loc='upper left')
ax2.legend(loc='upper right')
plt.tight_layout()
plt.savefig("kappa_bar_evolution.pdf")