import matplotlib.pyplot as plt
import numpy as np

plt.rcParams.update({'font.size': 14})


mace_accuracies = np.array([1.224, 0.67])
mace_speeds_256_from_esen_paper = 1e6/np.array([np.nan, 0.74487e+06])
mace_speeds_1000_from_esen_paper = 1e6/np.array([np.nan, 0.16723e+06])
mace_speeds_2744_from_esen_paper = 1e6/np.array([np.nan, 0.061055e+06])

esen_accuracies = np.array([0.1986, 0.1457])
esen_speeds_256_from_esen_paper = 1e6/np.array([0.79191e+06, 0.45479e+06])
esen_speeds_1000_from_esen_paper = 1e6/np.array([0.20786e+06, 0.112357e+06])
esen_speeds_2744_from_esen_paper = 1e6/np.array([0.07775e+06, 0.042092e+06])

mace_accuracies = np.array([1.224, 0.67])
mace_speeds_256 = 1e6/np.array([2.88e+06, 9.40e+05])
mace_speeds_1000 = 1e6/np.array([1.07e+06, 2.18e+05])
mace_speeds_2744 = 1e6/np.array([4.88e+05, 7.93e+04])

pet_accuracies = np.array([0.5757, 0.1057])
pet_speeds_256 = 1e6/np.array([3.18e+06, 1.37e+06])
pet_speeds_1000 = 1e6/np.array([1.08e+06, 3.46e+05])
pet_speeds_2744 = 1e6/np.array([4.31e+05, 1.30e+05])

fig, ax = plt.subplots(1, 3, figsize=(12, 4), sharey=True)
ax[0].loglog(mace_accuracies, mace_speeds_256, 'o-', label='MACE')
ax[0].loglog(esen_accuracies, esen_speeds_256_from_esen_paper, 's-', label='eSEN')
ax[0].loglog(pet_accuracies, pet_speeds_256, '^-', label='PET')
# ax[0].loglog(mace_accuracies, mace_speeds_256_from_esen_paper, 'o-', label='MACE (from eSEN)')
ax[0].set_title('256 atoms')
ax[0].set_xlabel('MAE [eV]')
ax[0].set_ylabel('Days per million evaluations')
ax[0].grid(True)
ax[0].legend(loc='upper left')

ax[1].loglog(mace_accuracies, mace_speeds_1000, 'o-', label='MACE')
ax[1].loglog(esen_accuracies, esen_speeds_1000_from_esen_paper, 's-', label='eSEN')
ax[1].loglog(pet_accuracies, pet_speeds_1000, '^-', label='PET')
# ax[1].loglog(mace_accuracies, mace_speeds_1000_from_esen_paper, 'o-', label='MACE (from eSEN)')
ax[1].set_title('1000 atoms')
ax[1].set_xlabel('MAE [eV]')
ax[1].grid(True)

ax[2].loglog(mace_accuracies, mace_speeds_2744, 'o-', label='MACE')
ax[2].loglog(esen_accuracies, esen_speeds_2744_from_esen_paper, 's-', label='eSEN')
ax[2].loglog(pet_accuracies, pet_speeds_2744, '^-', label='PET')
# ax[2].loglog(mace_accuracies, mace_speeds_2744_from_esen_paper, 'o-', label='MACE (from eSEN)')
ax[2].set_title('2744 atoms')
ax[2].set_xlabel('MAE [eV]')
ax[2].grid(True)

plt.tight_layout()
plt.savefig('spice.pdf', dpi=300)
# plt.savefig('spice-reproduced.pdf', dpi=300)
