from ase.io import read, write
import matplotlib.pyplot as plt
import sys
import numpy as np

interv = 64 // int(sys.argv[2])
frames = read(sys.argv[1], f'::{interv}')


positions = []
for f in frames:
    positions.append(f.positions)
positions = np.array(positions)


max_lag = 500


msd_lag = []
for ti in range(1, max_lag):
    disp = positions[ti:] - positions[:-ti]
    sq_disp = disp ** 2
    msd_lag.append(sq_disp.mean(axis=0))

msd_lag = np.array(msd_lag)


np.save("msd.npy", msd_lag)


