import numpy as np
from aeon.datasets import load_classification
from pathlib import Path
import json
import os
from types import SimpleNamespace
from string import Template


SLURM_SCRIPT = False
CHOLESKY = False


if CHOLESKY:
    ROOT_FOLDER = Path(f"{os.environ["WORKDIR"]}") / "KooPOT" / "classification"
else: 
    ROOT_FOLDER = Path(os.getcwd())

config_dct = dict(
    EXP_ID = 1, 
    N_FOLD = 1,
    SEED = 1,
    SAVE_FOLDER = str(ROOT_FOLDER / f"results"),
    N_JOBS = 5,
    TEST_SIZE = 0.3,
    SAMPLING_RATIO = 0.2,
    MAX_SAMPFREQ = 100,
    MAX_CONTEXT_WINDOW = 50,
    EIGEN_TOL = 1e-2,
    MAX_RANK = 10,
    POLY_ORDER = 1,
    TIKHONOV_REG = 1e-6
)

if __name__ == "__main__":

    config = SimpleNamespace(**config_dct)

    #Save config
    exp_path = Path(config.SAVE_FOLDER) / f"exp_{config.EXP_ID}"
    if not exp_path.is_dir():
        exp_path.mkdir(parents=True)
    with open(exp_path / f"settings.json", "w") as f: 
        json.dump(config_dct,f)

    # sample number of seeds
    np.random.seed(config.SEED)
    seeds = np.random.choice(int(1e6), size=config.N_FOLD, replace=False)
    for i, seed in enumerate(seeds): 
        sentence = f"python script_fold.py \
            --exp_id {config.EXP_ID} \
            --fold_id {i} \
            --seed {seed} \
            --save_folder {config.SAVE_FOLDER} \
            --n_jobs {config.N_JOBS} \
            --test_size {config.TEST_SIZE} \
            --sampling_ratio {config.SAMPLING_RATIO} \
            --max_sampfreq {config.MAX_SAMPFREQ} \
            --max_context_window {config.MAX_CONTEXT_WINDOW} \
            --eigen_tol {config.EIGEN_TOL} \
            --max_rank {config.MAX_RANK} \
            --poly_order {config.POLY_ORDER} \
            --tikhonov_reg {config.TIKHONOV_REG} "
        
        print(f"Running experiment {config.EXP_ID} fold {i}...")
        os.system(sentence)

    print(f"All experiments for exp_id {config.EXP_ID} have been launched.")

        