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

def smooth_curve(data, window_size=20):
    """Smooth the curve using a moving average."""
    return data.rolling(window=window_size, min_periods=1, center=True).mean()

# Load the CSV file
# df = pd.read_csv('logs/analysis/data/dynamics_pedi.csv')  # Pedipulation dynamics

df = pd.read_csv('p4rl_assets/csvs/kinematics_validation.csv')  # Replace with your actual file name

step = df.iloc[:, 0]
columns = 6
colors = ['blue', 'orange', 'green', 'red', 'purple', 'brown']  # High contrast colors

# Set up the plot
plt.figure(figsize=(10, 6))

subset_idx = range(0, 2)

# for i in range(num_configs):
for i in subset_idx:
    idx = 4 + i*columns
    runs = df.iloc[:, idx]

    plt.plot(step, runs, label=f'Config {i+1}', 
             color=colors[i],
             )
    # plt.fill_between(step, mean_vals - std_vals, mean_vals + std_vals, 
    #                  alpha=0.3, 
    #                  color=colors[i], 
    #                  label="_nolegend_")

# run_names = df.columns.tolist()
# run_names_for_legend = run_names[1::runs_per_config]
# legend = ["RL with trained dynamics module - Frozen",
#             "random_init - Frozen", 
#             "random_init - Unfrozen",
#             "Trained (velocity tracking, initial) - Unfrozen",
#             "3-layer MLP baseline", 
#             "RL with trained dynamics module - Trainable",
#           ]


# plt.xlim(0, 300)
# plt.ylim(-20, 20)

legend = ["penultimate dimension = 128",
            "penultimate dimension = 30", 
          ]

legend = [legend[i] for i in subset_idx]

plt.xlabel('Epochs')
plt.ylabel('Mean distance error (m)')
# plt.title('Training Curves with Mean ± Std Dev')
# plt.legend(run_names_for_legend)
plt.legend(legend)
plt.grid(True)
plt.tight_layout()
plt.savefig('logs/analysis/plots/kinematics_pretraining.pdf')