import numpy as np
import subprocess


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

    maxlag = 100
    acceptable = False
    while acceptable is False:
        command = "awk '!/#/{print $"
        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 *= np.sqrt(np.sqrt(10.0))
                if maxlag > 100000 * ac_time:
                    print(maxlag, ac_time)
                    print("Something went wrong")
                
    subprocess.run(["rm", "md.out"])
    return mean, std

for model in ["water", "universal"]:
    for time_lag in [1, 4, 16]:
        for rescale in [False, True]:
            for thermostat in ["langevin", "svr"]:
                for selection in "all", "O", "H":
                    
                    print()
                    print(thermostat, model, time_lag, rescale, selection)
                    path = f"../water/nvt-{thermostat}/{model}-{time_lag}-{rescale}/md.out"
                    if selection == "all":
                        col = 4
                        factor = 1.0
                    elif selection == "O":
                        col = 8
                        factor = 315774.66 / (64-16/18) / 1.5
                    elif selection == "H":
                        col = 9
                        factor = 315774.66 / (128-2/18) / 1.5
                    else:
                        raise ValueError()
                    
                    mean, std = get_mean_and_std(path, col)
                    mean *= factor
                    std *= factor
                    print(mean-450.0, std)
