import numpy as np
import seaborn as sns
import matplotlib.pyplot as plt
import pandas as pd
import os



data_root = "cartpole_real"
figure_name = 'real_world'
plot_name_list = ["reward", "lam", "tem"]
data_horizon = 25  # 25 training epochs

plot_config = {"y_labels": {"lam": "Average $\\lambda$", "reward": "Accumulated Reward", "tem": "Average $T$"},}

sns.set_style('whitegrid')
    # statistics = {"ib": {}, "dr": {}, "roundrobin": {}, "space": {}, "spdrl": {}, "mse": {}, "augobs": {}, "pearl": {}}

fig, axes = plt.subplots(1, 3, figsize=(12, 4.5))
for i, plot_name in enumerate(plot_name_list):
    data_folder = os.path.join(data_root, plot_name)
    data_list = os.listdir(data_folder)
    df_list = []
    for data_name in data_list:
        data_path = os.path.join(data_folder, data_name)
        df = pd.read_csv(data_path)
        # average_df = pd.DataFrame({"Value": df["Value"]})
        # average_df = average_df.apply(
            # lambda x: x.ewm(span=span).mean())  # first smooth the data using exponential weighted moving average
        # data = np.interp(np.arange(data_horizon), df["Step"], average_df["Value"])
        inter_data_frame = pd.DataFrame({"Value": df["Value"][:25]})
        df_list.append(inter_data_frame)

    if len(df_list) == 0:
        continue

    data = {f"col_from_df{i + 1}": df_list[i]["Value"] for i in range(len(df_list))}
    data_frame = pd.DataFrame(data)
    row_mean = data_frame.mean(axis=1)
    row_std = data_frame.std(axis=1)
    row_std_error = row_std / np.sqrt(len(data_frame.columns))
    data_frame['Steps'] = np.arange(data_horizon)
    data_frame['Mean'] = row_mean
    data_frame['Std'] = row_std
    data_frame['Std Error'] = row_std_error
    data_frame['Mean-Std-error'] = row_mean - row_std_error
    data_frame['Mean+Std-error'] = row_mean + row_std_error
    color = sns.color_palette()[0]
    # print(row_mean)

    line_plot = sns.lineplot(x='Steps', y='Mean', data=data_frame, ax=axes[i], label="AutoSafe",
                             legend=False, color=color, linewidth=2,)

    axes[i].fill_between(data_frame['Steps'], data_frame['Mean-Std-error'], data_frame['Mean+Std-error'],
                            alpha=0.2, color=color)

    axes[i].set_xlabel("Training Episodes", fontsize=17)
    axes[i].set_ylabel(plot_config["y_labels"][plot_name], fontsize=17)
    axes[i].tick_params(labelsize=13)
    axes[i].set_xlim([0, 25])

# try:
    # y_lims = plot_config["y_limits"][data_tag][case]
    # axes[i].set_ylim([y_lims[0], y_lims[1]])
# except:
#     pass

plt.tight_layout()
leg = axes[0].legend(fancybox=True, shadow=True, fontsize=16, facecolor='lightgray')

# axes[1, 2].set_visible(False)
for line in leg.get_lines():
    line.set_linewidth(4.0)
plt.subplots_adjust(bottom=0.15)
plt.savefig(f"{figure_name}_result.pdf", dpi=300)
