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

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

delta_t = 16
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_npt_stepper(sim, model, device, rescale_energy=rescale_energy, random_rotation=random_rotation))
sim.run(3000000//delta_t)  # 3 ns

