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


# Load the CSV file
# df = pd.read_csv('logs/analysis/dynamics_analysis_0_to_4k.csv')  # Replace with your actual file name
# iteration_strs = ["0", "1k", "2k", "3k", "4k"]

df = pd.read_csv('logs/analysis/dynamics_analysis_layers.csv')  # Replace with your actual file name
model_its = [0, 1000, 2000, 3000, 3999]
# model_its = [0, 1000]
data_its = [0, 1000, 2000, 3000, 4000]
# data_its = ["0","1k","2k","3k","4k"]

plt.figure(figsize=(8, 5))

mat = []

for i in range(3):
    colums_names = [
    f"NEW_model_it_{model_its[j]}_data_it_{data_its[j]}_10k_samples_input_{i} - loss_train_epoch" for j in range(5)]

    data = df.loc[19, colums_names].to_numpy()*180.0/np.pi
    mat.append(data)

    plt.plot(model_its, data, marker='x',  label=f'layer {i}')

# mat = np.array(mat)
# mean = np.mean(mat, axis=0)
# plt.plot(model_its, mean, marker='x', color="red")
plt.axhline(y=1.52, linestyle="--", color="red", alpha=0.5, label="Zero-order extrapolation loss (1.52)")
# plt.yscale('log')
plt.title('Accuracy of final converged model for dynamics prediction task ()')
plt.xlabel('Iteration Numbers')
plt.ylabel('Degrees')
plt.grid()
plt.legend()
plt.ylim(0.5, 1.1)
# plt.legend([f"dataset_collected_at_{it}_iteration" for it in data_its])
# plt.xticks(ticks=x_num, labels=iteration_strs)
plt.savefig('logs/analysis/plots/dynamics_analysis_new.png')