from ipi.utils.scripting import InteractiveSimulation
from metatensor.torch.atomistic import load_atomistic_model
from flashmd.ipi import get_nvt_stepper
import torch

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

delta_t = TIMESTEP
rescale_energy = True
random_rotation = True

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")

sim.set_motion_step(get_nvt_stepper(sim, model, device, rescale_energy=rescale_energy, random_rotation=random_rotation))
sim.run(500000//delta_t)  # 0.5 ns

