import numpy as np
import matplotlib.pyplot as plt
from matplotlib.ticker import ScalarFormatter

# Define colloc and error arrays
colloc = [500, 1000, 1500, 2000]

RMSE_mean = [0.00041, 0.00037, 0.00056, 0.00038]
RMSE_std = [0.000072, 0.000040, 0.00019, 0.000093]

rel_err_mean = [0.00058, 0.00052, 0.00080, 0.00054]
rel_err_std = [0.00010, 0.000057, 0.00027, 0.00013]

# Create a figure
plt.figure(figsize=(10, 6))

# Plot RMSE mean with standard deviation bars
plt.errorbar(colloc, RMSE_mean, yerr=RMSE_std, fmt='-o', color='b', ecolor='b', elinewidth=3, capsize=7, label='RMSE',
             linestyle='-', linewidth=5, marker='o', markersize=8, markerfacecolor='blue', markeredgewidth=2)

# Plot relative error mean with standard deviation bars
plt.errorbar(colloc, rel_err_mean, yerr=rel_err_std, fmt='-s', color='r', ecolor='r', elinewidth=3, capsize=7, label='Relative Error',
             linestyle='--', linewidth=5, marker='s', markersize=8, markerfacecolor='red', markeredgewidth=2)

# Adding labels and title with increased font size
plt.xlabel('# Collocation points', fontsize=30)
plt.ylabel('Error', fontsize=30)

# Set x-axis ticks to only the values in the colloc array and increase font size
plt.xticks(colloc, fontsize=30)

# Set y-axis ticks to be in scientific notation ('e') and increase font size
plt.gca().yaxis.set_major_formatter(ScalarFormatter(useMathText=True))
plt.tick_params(axis='y', labelsize=30)

# Adding a legend without a box and increase font size
plt.legend(frameon=False, fontsize=30)

# Show the plot
plt.tight_layout()
plt.savefig('error_vs_colloc.png', dpi=300, bbox_inches="tight")
plt.show()
