from util.logger import logger

from typing import Optional

from omegaconf import OmegaConf, DictConfig

from pathlib import Path

from util.basic_util import (
    get_global_variable, 
    is_none, 
    get_true_value, 
    get_attr
)
from util.plot_util import (
    save_plot, 
    get_line_chart
)


def line_chart_zeta_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}"

    concurrent_max_worker = get_global_variable("concurrent_max_worker")

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

    uni = get_true_value(cfg["task"]["zeta"]["uni"])
    beta_list = get_true_value(cfg["task"]["zeta"]["beta"])
    beta_list = list(beta_list)

    logger(f"    uni: {uni}")
    logger(f"    beta_list: {beta_list}")

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

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

    figsize = get_true_value(cfg["task"]["line_chart"]["figsize"])
    figsize = tuple(figsize)

    logger(f"    figsize: {figsize}")

    color_dict = get_true_value(cfg["task"]["line_chart"]["color_dict"])

    logger(f"    color_dict: {color_dict}")

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

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

    save_plot_root_path = get_true_value(cfg["task"]["save_plot"]["save_plot_root_path"])

    logger(f"    save_plot_root_path: {save_plot_root_path}")

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

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

    # ---------= [Prepare Save Plot Root Path] =---------
    save_plot_root_path = Path(save_plot_root_path)

    # ---------= [Prepare Line Chart] =---------
    color_uni = color_dict["uni"]
    color_beta = color_dict["beta"]

    # ---------= [Plot Line Chart] =---------
    n = len(beta_list)
    x_list = list(range(1, n + 1))

    y_list_list = [beta_list]
    y_label_list = ["Beta"]

    marker_list = ['o']
    marker_size_list = [4]

    color_list = [color_beta]

    plot_x_label = "Zeta"
    plot_y_label = "Best Reward"

    show_grid = True
    show_legend = True
    
    fig, ax = get_line_chart(
        figsize = figsize, 

        x_list = x_list, 
        y_list_list = y_list_list, 
        y_label_list = y_label_list, 

        marker_list = marker_list, 
        marker_size_list = marker_size_list, 
        
        color_list = color_list, 

        plot_x_label = plot_x_label, 
        plot_y_label = plot_y_label, 

        show_grid = show_grid, 
        show_legend = show_legend
    )

    ax.axhline(
        y = uni, 

        color = color_uni, 

        linestyle = "--", 

        label = "Uniform"
    )

    ax.set_xticks(ticks = x_list)

    ax.legend()

    save_plot(
        fig = fig, 

        save_plot_root_path = save_plot_root_path, 
        save_plot_filename = f"zeta.png"
    )

    # `line_chart_zeta_implement()` done
    pass


def line_chart_zeta(
    cfg: DictConfig
):
    line_chart_zeta_implement(cfg)

    # `line_chart_zeta()` done
    pass
