from ipi.utils.scripting import InteractiveSimulation
from metatensor.torch.atomistic import load_atomistic_model
from skipmd.ipi import get_skipmd_velocity_verlet_step
import torch

from ipi.utils.depend import dstrip
from ipi.utils.units import Constants
import numpy as np

delta_t = TIMESTEP

with open("input.xml", "r") as input_xml:
    sim = InteractiveSimulation(input_xml)

model = load_atomistic_model(f"../../../models/universal_{delta_t}fs.pt")
device = ("cuda" if torch.cuda.is_available() else "cpu")

skipmd_velocity_verlet_step = get_skipmd_velocity_verlet_step(sim, model, device)

def skipmd_step(self, **_):

    self.thermostat.step()
    self.integrator.pconstraints()

    skipmd_velocity_verlet_step(self, rescale_energy=True, random_rotation=True)
    self.thermostat.step()
    self.integrator.pconstraints()

    self.ensemble.time += self.dt

sim.set_motion_step(skipmd_step)
sim.run(500000//delta_t)  # 500 ps

