import numpy as np
import subprocess


def get_mean_and_std(path, col):
    # copy to the current directory
    subprocess.run(["cp", path, "."])

    maxlag = 1000
    acceptable = False
    while acceptable is False:
        command = "awk '!/#/{print 18 * 1.66e3 * 64 / $"
        command += str(col)
        command += ("}' md.out | ../../toolbox/bin/autocorr -maxlag " + str(maxlag) + f" | head")
        # run autocorr
        stdout = subprocess.run(command, shell=True, stdout=subprocess.PIPE).stdout.decode("utf-8")
        for line in stdout.split("\n"):
            if "mean:" in line:
                mean = float(line.split("mean:")[1].strip().split()[0])
                std = float(line.split("mean:")[1].strip().split()[2])
            if "a.c. time:" in line:
                ac_time = float(line.split("a.c. time:")[1].strip().split()[0])
                if maxlag > 20 * ac_time:
                    acceptable = True
                else:
                    print(f"RECOMPUTED: maxlag ({maxlag}) > 30 * ac_time ({ac_time})")
                    maxlag *= 10 ** (1/8)
                if maxlag > 100000 * ac_time:
                    print(maxlag, ac_time)
                    print("Something went wrong")
                
    subprocess.run(["rm", "md.out"])
    return mean, std

print("PET-MAD")
mean, std = get_mean_and_std(f"../water/npt/petmad/md.out", 8)
print(mean, std)

for model in ["water", "universal"]:
    for time_lag in [1, 4, 16]:
            print(model, time_lag)
            mean, std = get_mean_and_std(f"../water/npt/{model}-{time_lag}/md.out", 8)
            print(mean, std)
