from util.logger import logger

from typing import List, Tuple, Dict

from omegaconf import DictConfig

import gc

from pathlib import Path

from util.basic_util import (
    get_global_variable, 
    is_none, 
    get_true_value, 
    get_attr
)
from ..util.result_util import (
    get_reward_scaling_list_from_result, 
    get_turning_point_tuple_list
)


def get_scaling_list_implement(
    cfg: DictConfig
):
    # ---------= [Basic Global Variables] =---------
    exp_name = get_global_variable("exp_name")
    start_time = get_global_variable("start_time")
    device = get_global_variable("device")
    seed = get_global_variable("seed")
    exp_time_str = f"{exp_name}_{start_time}"

    # ---------= [Reward] =---------
    logger(f"[Reward] Loading started. ")

    reward_type = get_true_value(cfg["task"]["reward"]["reward_type"])
    original = get_true_value(cfg["task"]["reward"]["original"])

    logger(f"    reward_type: {reward_type}")
    logger(f"    original: {original}")

    logger(
        f"[Reward] Loading finished. "
        "\n"
    )

    # ---------= [Path] =---------
    logger(f"[Path] Loading started. ")

    exp_root_path = get_true_value(cfg["task"]["path"]["exp_root_path"])
    exp_name_list = get_true_value(cfg["task"]["path"]["exp_name_list"])
    folder_name_list = get_true_value(cfg["task"]["path"]["folder_name_list"])

    logger(f"    exp_root_path: {exp_root_path}")
    logger(f"    exp_name_list: {exp_name_list}")
    logger(f"    folder_name_list: {folder_name_list}")

    logger(
        f"[Path] Loading finished. "
        "\n"
    )

    # ---------= [Num Sample] =---------
    logger(f"[Num Sample] Loading started. ")

    num_sample = get_true_value(cfg["task"]["path"]["num_sample"])

    logger(f"    num_sample: {num_sample}")

    logger(
        f"[Num Sample] Loading finished. "
        "\n"
    )

    # ---------= [Use Merged Reward] =---------
    logger(f"[Use Merged Reward] Loading started. ")

    use_merged_reward = get_true_value(cfg["task"]["use_merged_reward"])

    logger(f"    use_merged_reward: {use_merged_reward}")

    logger(
        f"[Use Merged Reward] Loading finished. "
        "\n"
    )

    # ---------= [All Components Loaded] =---------
    logger(
        f"All components loaded. "
        "\n"
    )

    # ---------= [Prepare Everything] =---------
    exp_root_path = Path(exp_root_path)

    if (not use_merged_reward) and original:
        logger(
            "Only original reward types have final rewards. ", 
            log_type = "error"
        )

        breakpoint()

    # ---------= [Get Scaling List] =---------
    avg_reward_scaling_list = get_reward_scaling_list_from_result(
        setting_root_path = exp_root_path, 
        setting_name_list = exp_name_list, 
        folder_name_list = folder_name_list if (folder_name_list != "all") \
            else None, 

        original = original, 
        reward_type = reward_type, 

        num_sample = num_sample, 

        use_merged_reward = use_merged_reward
    )

    turning_point_tuple_list = get_turning_point_tuple_list(
        reward_scaling_list = avg_reward_scaling_list
    )

    print(f"[Result]")
    print(f"avg_reward_scaling_list: {avg_reward_scaling_list}")
    print(f"turning_point_tuple_list: {turning_point_tuple_list}")

    # `get_scaling_list_implement()` done
    pass


def get_scaling_list(
    cfg: DictConfig
):
    get_scaling_list_implement(cfg)

    # `get_scaling_list()` done
    pass
