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


delta_t = 16
print(delta_t)

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

model = load_atomistic_model(f"../../models/water_qtip4pf_{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(100000//delta_t)  # 100 ps
