import numpy as np
import matplotlib.pyplot as plt

# Data
Ns = np.array([10, 15, 25, 30, 35])

# Fun 5 — 100 Epochs (z = 2·sin(x) + cos(x))
fun5_train = np.array([3.1103267669677734, 4.610773801803589, 10.042689085006714, 13.501886367797852, 18.37820529937744])
fun5_infer = np.array([0.17627811431884766, 0.3388803005218506, 2.1052234172821045, 4.982216835021973, 8.980262517929077])

# Fun 4 — 100 Epochs (z = x² + y²)
fun4_train = np.array([3.0516347885131836, 4.567049264907837, 10.211522579, 13.92661714553833, 17.586484670639038])
fun4_infer = np.array([0.18546175956726074, 0.3325192928314209, 2.3124789758, 4.982546091079712, 9.070284128189087])

x = Ns**2  # x axis: N^2

# Plotting
fig, axes = plt.subplots(1, 2, figsize=(12, 5), sharey=True)



axes[0].plot(x, fun4_train, marker='o',c="red", label='Training Time')
axes[0].plot(x, fun4_infer, marker='s',c="blue", label='Inference Time')
axes[0].set_title('Fun 4 — 100 Epochs\nz = x² + y²')
axes[0].set_xlabel('Number of data points')
axes[0].set_ylabel('Time (s)')
axes[0].set_xticks(x)
axes[0].grid(True)
axes[0].legend()

axes[1].plot(x, fun5_train, marker='o',c="red", label='Training Time')
axes[1].plot(x, fun5_infer, marker='s', c="blue", label='Inference Time')
axes[1].set_title('Fun 5 — 100 Epochs\nz = 2·sin(x) + cos(x)')
axes[1].set_xlabel('Number of data points')
axes[1].set_xticks(x)
axes[1].grid(True)
axes[1].legend()

fig.subplots_adjust(wspace=0.35)
plt.savefig('time_plot.png', dpi=200)
plt.show()