import matplotlib.pyplot as plt
import pandas as pd

def plot_errors(error_trace):
    df_err = pd.DataFrame(error_trace)

    plt.figure(figsize=(10, 5))
    plt.plot(df_err["step"], df_err["error_b"], label="error_b (%)")
    plt.plot(df_err["step"], df_err["error_a"], label="error_a (%)")
    plt.yscale("log")  # log scale for relative error
    plt.xlabel("Outer step")
    plt.ylabel("Error (%)")
    plt.title("Error over time (log scale)")
    plt.grid(True, which="both", linestyle="--", linewidth=0.5)
    plt.legend()
    plt.tight_layout()
    plt.show()


def plot_utilities(u1_values, u2_values):
    plt.figure(figsize=(10, 4))
    plt.plot(u1_values, label="u1 (principal)")
    plt.title("Principal utility over time")
    plt.xlabel("Step")
    plt.ylabel("u1")
    plt.grid(True)
    plt.legend()
    plt.tight_layout()
    plt.show()

    plt.figure(figsize=(10, 4))
    plt.plot(u2_values, label="u2 (agent)")
    plt.title("Agent utility over time")
    plt.xlabel("Step")
    plt.ylabel("u2")
    plt.grid(True)
    plt.legend()
    plt.tight_layout()
    plt.show()
