import os
from pathlib import Path

from time import sleep

import yaml
import subprocess

ROOT_DIR = Path(os.path.dirname(os.path.realpath(__file__)))

from verify_file import verify

SAVE_PATH = "where/the/results/from/evaluate/are/stored/persistent_patterns"

SCRIPT_PAHT = ROOT_DIR / "run_persistent_patterns.sh"

DATA_DIR = Path("where/the/results/from/evaluate/are/stored")
FILE_PATHS = [
    DATA_DIR / "preds" / "nd_preds" / "TALOS_20240216-185022+TorchTrainer_995a1ad7+nd.csv",
    DATA_DIR / "preds" / "nd_preds" / "TALOS_20240201-180351+TorchTrainer_d9c8c887+nd.csv",
    DATA_DIR / "preds" / "d_preds" / "TALOS_20240121-203233+TorchTrainer_e9bc79c6+d.csv",
    DATA_DIR / "preds" / "sreal_preds" / "TALOS_20240216-185022+TorchTrainer_995a1ad7+sreal.csv",
    DATA_DIR / "preds" / "mlreal_preds" / "TALOS_20240216-185022+TorchTrainer_995a1ad7+mlreal.csv",
    DATA_DIR / "preds" / "sreal_preds" / "TALOS_20240201-180351+TorchTrainer_d9c8c887+sreal.csv",
    DATA_DIR / "preds" / "mlreal_preds" / "TALOS_20240201-180351+TorchTrainer_d9c8c887+mlreal.csv",
    DATA_DIR / "preds" / "sreal_preds" / "TALOS_20240121-203233+TorchTrainer_e9bc79c6+sreal.csv",
    DATA_DIR / "preds" / "mlreal_preds" / "TALOS_20240121-203233+TorchTrainer_e9bc79c6+mlreal.csv",
]

calculate_overlap = ""

for file1 in FILE_PATHS:
    file = str(file1)
    data_type = file.split("+")[-1].split(".")[0]
    model_name = file.split(data_type+"_preds")[1].split(data_type)[0][:-1][1:]
    print("Model Name:", model_name)
    print("Data Type:", data_type)
    
    assert verify(file1)
    for sp_type in ["True", "Pred"]:
        thres = -1
        if sp_type == "Pred":
            with open(
                os.path.join(
                    SAVE_PATH, data_type,
                    "details_" + data_type + "_True_" + model_name + ".yaml",
                ),
                "r",
            ) as yaml_file:
                thres = yaml.safe_load(yaml_file)["results"]["threshold"]

        rc = subprocess.call(
            [
                "bash",
                SCRIPT_PAHT,
                file,
                sp_type,
                data_type,
                model_name,
                str(thres),
                calculate_overlap,
            ],
        )
        sleep(1)
