import pandas as pd
import matplotlib.pyplot as plt
import seaborn as sns
import numpy as np

fontsize=14
tick_fontsize=13
legend_fontsize=14
palette = {'VGB': 'green', 'ActionLevel': 'grey'}
markers = {'VGB': 's', 'ActionLevel': 'o'}



def plot(data, y, ylabel, save_path):
    df = pd.DataFrame(data)
    fig, axes = plt.subplots(1,3,figsize=(12,3))
    T = 10
    for ax, N in zip(axes, sorted(df['N'].unique())):
        subdf = df[df['N'] == N]
        sns.lineplot(subdf, x='H', y=y, hue='Algorithm',style='Algorithm', errorbar='se', palette=palette, markers=markers, dashes=False, ax=ax)

        ax.set_xlabel("Horizon length (H)", fontweight="bold",fontsize=fontsize)
        ax.set_ylabel(ylabel, fontweight="bold",fontsize=fontsize)
        ax.set_title(f"N = {N}", fontweight="bold",fontsize=fontsize)
        ax.tick_params(axis='both', labelsize=tick_fontsize)
        handles, labels = ax.get_legend_handles_labels()
        by_label = dict(zip(labels, handles))   # removes duplicates
        ax.legend(by_label.values(), by_label.keys(),loc="upper left",fontsize=legend_fontsize)

    fig.tight_layout()
    if save_path is not None:
        plt.savefig(save_path, bbox_inches='tight')
    plt.show()

