{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "a94da4c6",
   "metadata": {},
   "source": [
    "# Tutorial"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "14c96202",
   "metadata": {},
   "source": [
    "Experimental Settings:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "463bb2cd",
   "metadata": {},
   "outputs": [],
   "source": [
    "from PriceFM import *\n",
    "\n",
    "pre_path = train_status('local') # 'local' or 'cloud', cloud for GoogleColab\n",
    "model_path = pre_path+\"Model/PriceFM.keras\" # location to save the model\n",
    "european_energy_df = pre_path+'Data/EU_Spatiotemporal_Energy_Data.csv' # location of dataset\n",
    "european_energy_df = pd.read_csv(european_energy_df)\n",
    "\n",
    "# master lists of input features [not change]\n",
    "input_features = ['day_ahead_Solar', 'day_ahead_Wind Onshore', 'day_ahead_Wind Offshore', 'Forecasted Load']\n",
    "\n",
    "# master lists of region codes [not change]\n",
    "all_regions = ['AT',    'BE',    'BG',   'CZ',    'DE_LU',   'DK_1',  'DK_2',                 \n",
    "               'EE',    'ES',    'FI',   'FR',    'GR',      'HR',    'HU',                  \n",
    "               'IT_1',  'IT_2',  'IT_3', 'IT_4',  'IT_5',    'IT_6',  'IT_7', \n",
    "               'LT',    'LV',    'NL',   'NO_1',  'NO_2',    'NO_3',  'NO_4',   'NO_5', \n",
    "               'PL',    'PT',    'RO',   'SE_1',  'SE_2',    'SE_3',  'SE_4',   'SI',   'SK']\n",
    "\n",
    "# quantiles for prediction, e.g., 10%, 50%, and 90% quantiles [can change]\n",
    "QUANTILES = [10, 50, 90] \n",
    "\n",
    "# input regions of the model [can change]\n",
    "input_regions =  all_regions \n",
    "\n",
    "# output regions for prediction;\n",
    "# here can be a list of lists, e.g., [['AT'], ['AT', 'BE']] for individual region or combinations\n",
    "# if specified as [['AT'], ['AT', 'BE']], then we train 2 models, one to predict AT, and another to predict AT and BE. [can change]\n",
    "TARGET_REGIONS = [all_regions] \n",
    "\n",
    "# optimal model hyperparameters [can change]\n",
    "num_layer, hidden_dim, epoch, batch_size, show_progress_bar = (3, 24, 20, 8, True)\n",
    "\n",
    "# data splits for training, validation, and testing [can change]\n",
    "data_splits = [('2022-01-01', '2024-01-01', '2024-07-01', '2025-01-01')]\n",
    "\n",
    "# time windows for input and output [can change]\n",
    "look_back_windows = [-24] # the last 24 hours of data as input. [-24, -23, ...-1]\n",
    "prediction_horizons = [23] # the next 24 hours to predict / look-forward window size for load, solar, and wind. [0, 1, ...23]\n",
    "\n",
    "# seeds for randomness [can change]\n",
    "seeds = [42] \n",
    "\n",
    "# run the optimal model or ablation study [can change]\n",
    "select_modes = ['optimal']"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "09966f4d",
   "metadata": {},
   "source": [
    "# 0. Regional File Formation"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "098678d9",
   "metadata": {},
   "source": [
    "Make sure to run the following line if you first time execute the code:\n",
    "\n",
    "it generates data file, where regional data can be retrieved using region code.\n",
    "\n",
    "The file is saved under 'Data' folder"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2a8df4c6",
   "metadata": {},
   "outputs": [],
   "source": [
    "generate_region_data_pickles(data_splits, look_back_windows, prediction_horizons, all_regions, european_energy_df, input_features, pre_path)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9ba402e5",
   "metadata": {},
   "source": [
    "# 1. MIMO / MISO / SISO settings"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c59b0928",
   "metadata": {},
   "source": [
    "if you prefer multi-input multi-output setup:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "eff23587",
   "metadata": {},
   "outputs": [],
   "source": [
    "input_regions =  all_regions  # keep all regions as input\n",
    "TARGET_REGIONS = [all_regions]  # predict all regions as output"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e3a2552b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# [execution code] this block remains the same\n",
    "for data_split in data_splits:\n",
    "    train_start, val_start, test_start, _ = data_split\n",
    "    for look_back_window in look_back_windows:\n",
    "        for prediction_horizon in prediction_horizons:\n",
    "            for output_regions in TARGET_REGIONS:\n",
    "                for seed in seeds:\n",
    "                    for select_mode in select_modes:\n",
    "                        print(f\"Running configuration: {train_start}, {val_start}, {test_start}, \"\n",
    "                                f\"look_back_window={look_back_window}, prediction_horizon={prediction_horizon}, \"\n",
    "                                f\"output_regions={output_regions}, seed={seed}, select_mode={select_mode}\")\n",
    "                        \n",
    "                        region_data = load_region_data(pre_path, train_start, val_start, test_start, look_back_window, prediction_horizon)\n",
    "                        train_inputs, val_inputs, y_train_dict, y_val_dict = build_data(region_data, input_regions, output_regions, QUANTILES)\n",
    "                        model = build_model_mode(select_mode, region_data, input_regions, output_regions, num_layer, hidden_dim, QUANTILES)\n",
    "                        best_model, history, model_params = run_model(model, QUANTILES, output_regions, train_inputs, val_inputs, y_train_dict, y_val_dict, epoch, batch_size, model_path, show_progress_bar)\n",
    "                        results = evaluate_model_unseen(region_data, input_regions, output_regions, model_path, QUANTILES)\n",
    "                        hyper_setup = (train_start, val_start, test_start, look_back_window, prediction_horizon, model_params, seed, select_mode)\n",
    "                        save_as_csv(results, hyper_setup, history, QUANTILES, pre_path)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1c8c08e3",
   "metadata": {},
   "source": [
    "if you prefer multi-input single-output setup:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "d275e70c",
   "metadata": {},
   "outputs": [],
   "source": [
    "input_regions =  all_regions  # keep all regions as input\n",
    "TARGET_REGIONS = [['AT']]  # predict e.g. Austria (AT)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b821789a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# [execution code] this block remains the same\n",
    "for data_split in data_splits:\n",
    "    train_start, val_start, test_start, _ = data_split\n",
    "    for look_back_window in look_back_windows:\n",
    "        for prediction_horizon in prediction_horizons:\n",
    "            for output_regions in TARGET_REGIONS:\n",
    "                for seed in seeds:\n",
    "                    for select_mode in select_modes:\n",
    "                        print(f\"Running configuration: {train_start}, {val_start}, {test_start}, \"\n",
    "                                f\"look_back_window={look_back_window}, prediction_horizon={prediction_horizon}, \"\n",
    "                                f\"output_regions={output_regions}, seed={seed}, select_mode={select_mode}\")\n",
    "                        \n",
    "                        region_data = load_region_data(pre_path, train_start, val_start, test_start, look_back_window, prediction_horizon)\n",
    "                        train_inputs, val_inputs, y_train_dict, y_val_dict = build_data(region_data, input_regions, output_regions, QUANTILES)\n",
    "                        model = build_model_mode(select_mode, region_data, input_regions, output_regions, num_layer, hidden_dim, QUANTILES)\n",
    "                        best_model, history, model_params = run_model(model, QUANTILES, output_regions, train_inputs, val_inputs, y_train_dict, y_val_dict, epoch, batch_size, model_path, show_progress_bar)\n",
    "                        results = evaluate_model_unseen(region_data, input_regions, output_regions, model_path, QUANTILES)\n",
    "                        hyper_setup = (train_start, val_start, test_start, look_back_window, prediction_horizon, model_params, seed, select_mode)\n",
    "                        save_as_csv(results, hyper_setup, history, QUANTILES, pre_path)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "184af467",
   "metadata": {},
   "source": [
    "if you prefer single-input single-output setup:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "10b8f462",
   "metadata": {},
   "outputs": [],
   "source": [
    "input_regions =  ['AT']  # keep one region as input e.g. Austria (AT)\n",
    "TARGET_REGIONS = [['AT']]  # predict e.g. Austria (AT)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9ba5b220",
   "metadata": {},
   "outputs": [],
   "source": [
    "# [execution code] this block remains the same\n",
    "for data_split in data_splits:\n",
    "    train_start, val_start, test_start, _ = data_split\n",
    "    for look_back_window in look_back_windows:\n",
    "        for prediction_horizon in prediction_horizons:\n",
    "            for output_regions in TARGET_REGIONS:\n",
    "                for seed in seeds:\n",
    "                    for select_mode in select_modes:\n",
    "                        print(f\"Running configuration: {train_start}, {val_start}, {test_start}, \"\n",
    "                                f\"look_back_window={look_back_window}, prediction_horizon={prediction_horizon}, \"\n",
    "                                f\"output_regions={output_regions}, seed={seed}, select_mode={select_mode}\")\n",
    "                        \n",
    "                        region_data = load_region_data(pre_path, train_start, val_start, test_start, look_back_window, prediction_horizon)\n",
    "                        train_inputs, val_inputs, y_train_dict, y_val_dict = build_data(region_data, input_regions, output_regions, QUANTILES)\n",
    "                        model = build_model_mode(select_mode, region_data, input_regions, output_regions, num_layer, hidden_dim, QUANTILES)\n",
    "                        best_model, history, model_params = run_model(model, QUANTILES, output_regions, train_inputs, val_inputs, y_train_dict, y_val_dict, epoch, batch_size, model_path, show_progress_bar)\n",
    "                        results = evaluate_model_unseen(region_data, input_regions, output_regions, model_path, QUANTILES)\n",
    "                        hyper_setup = (train_start, val_start, test_start, look_back_window, prediction_horizon, model_params, seed, select_mode)\n",
    "                        save_as_csv(results, hyper_setup, history, QUANTILES, pre_path)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "dbc3227e",
   "metadata": {},
   "source": [
    "# 2. Curvature value optimization and settings change"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f15bf518",
   "metadata": {},
   "source": [
    "Search the function \"get_decay_factor_for_region\" from PriceFM.py, where the decay factor is referring to the curvature value that serves as spatial regularizer, and the function looks like:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a01a5d7d",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_decay_factor_for_region(region):\n",
    "    # optimized curvature mapping per region based on val loss\n",
    "    DECAY_FACTORS = {\n",
    "        'AT': 0.8,\n",
    "        'BE': 0.8,\n",
    "        'BG': 1.0,\n",
    "        'CZ': 0.8,\n",
    "        'DE_LU': 0.0,\n",
    "        'DK_1': 0.2,\n",
    "        'DK_2': 0.4,\n",
    "        'EE': -0.6,\n",
    "        'ES': 1.0,\n",
    "        'FI': 1.0,\n",
    "        'FR': 1.0,\n",
    "        'GR': 1.0,\n",
    "        'HR': -0.2,\n",
    "        'HU': 0.0,\n",
    "        'IT_1': 1.0,\n",
    "        'IT_2': 1.0,\n",
    "        'IT_3': 1.0,\n",
    "        'IT_4': 1.0,\n",
    "        'IT_5': 1.0,\n",
    "        'IT_6': 0.8,\n",
    "        'IT_7': 1.0,\n",
    "        'LT': 0.2,\n",
    "        'LV': 0.4,\n",
    "        'NL': 0.8,\n",
    "        'NO_1': 0.8,\n",
    "        'NO_2': 0.8,\n",
    "        'NO_3': 0.8,\n",
    "        'NO_4': 0.6,\n",
    "        'NO_5': 0.8,\n",
    "        'PL': 1.0,\n",
    "        'PT': 1.0,\n",
    "        'RO': 1.0,\n",
    "        'SE_1': 0.2,\n",
    "        'SE_2': 0.8,\n",
    "        'SE_3': 1.0,\n",
    "        'SE_4': 1.0,\n",
    "        'SI': 0.2,\n",
    "        'SK': 0.0,\n",
    "    }\n",
    "\n",
    "    try:\n",
    "        return DECAY_FACTORS[region]\n",
    "    except KeyError:\n",
    "        raise ValueError(f\"No decay factor defined for region '{region}'\")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "569f9a78",
   "metadata": {},
   "source": [
    "The above values are optimized based on validation loss. However, if you believe that the market conditions changed and want to re-optimize, you need to change to MISO setup and find the optimal curvature value based on validation loss. For example:"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3a2cedbf",
   "metadata": {},
   "source": [
    "First find optimal curvature value for Austria (AT):"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "db5ed6a0",
   "metadata": {},
   "outputs": [],
   "source": [
    "input_regions =  all_regions  # keep all regions as input\n",
    "TARGET_REGIONS = [['AT']]  # optimize for Austria (AT)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d82e11b8",
   "metadata": {},
   "source": [
    "and change the value inside the function:\n",
    "\n",
    "```python\n",
    "def get_decay_factor_for_region(region):\n",
    "    # optimized curvature mapping per region based on val loss\n",
    "    DECAY_FACTORS = {\n",
    "        'AT': 0, \n",
    "        ...\n",
    "\n",
    "-> and run the [execution code] to observe validation loss: e.g. Val_loss = 0.52"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "492becaf",
   "metadata": {},
   "source": [
    "and change the value inside the function:\n",
    "\n",
    "```python\n",
    "def get_decay_factor_for_region(region):\n",
    "    # optimized curvature mapping per region based on val loss\n",
    "    DECAY_FACTORS = {\n",
    "        'AT': 0.2, \n",
    "        ...\n",
    "\n",
    "-> and run the [execution code] to observe validation loss: e.g. Val_loss' = 0.51"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "67d7b8f2",
   "metadata": {},
   "source": [
    "and change the value inside the function:\n",
    "\n",
    "```python\n",
    "def get_decay_factor_for_region(region):\n",
    "    # optimized curvature mapping per region based on val loss\n",
    "    DECAY_FACTORS = {\n",
    "        'AT': 0.4, \n",
    "        ...\n",
    "\n",
    "-> and run the [execution code] to observe validation loss: e.g. Val_loss'' = 0.35"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2ecf11e8",
   "metadata": {},
   "source": [
    "Since Val_loss'' < Val_loss' < Val_loss, the optimal curvature value is thus 0.4"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "24992184",
   "metadata": {},
   "source": [
    "Then, change the target region and repeat above procedure:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7a8821b2",
   "metadata": {},
   "outputs": [],
   "source": [
    "input_regions =  all_regions  # keep all regions as input\n",
    "TARGET_REGIONS = [['NL']]  # now optimize for Netherlands (NL)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "72bc758d",
   "metadata": {},
   "source": [
    "# Visualization of forecasts\n",
    "\n",
    "As traders observe on forecasts and make trading decisions, we provide visualization"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "657f955c",
   "metadata": {},
   "source": [
    "We first train a whatever model:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "1cdd638e",
   "metadata": {},
   "outputs": [],
   "source": [
    "input_regions =  all_regions  \n",
    "TARGET_REGIONS = [['NL']]  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "73b06580",
   "metadata": {},
   "outputs": [],
   "source": [
    "# [execution code] this block remains the same\n",
    "for data_split in data_splits:\n",
    "    train_start, val_start, test_start, _ = data_split\n",
    "    for look_back_window in look_back_windows:\n",
    "        for prediction_horizon in prediction_horizons:\n",
    "            for output_regions in TARGET_REGIONS:\n",
    "                for seed in seeds:\n",
    "                    for select_mode in select_modes:\n",
    "                        print(f\"Running configuration: {train_start}, {val_start}, {test_start}, \"\n",
    "                                f\"look_back_window={look_back_window}, prediction_horizon={prediction_horizon}, \"\n",
    "                                f\"output_regions={output_regions}, seed={seed}, select_mode={select_mode}\")\n",
    "                        \n",
    "                        region_data = load_region_data(pre_path, train_start, val_start, test_start, look_back_window, prediction_horizon)\n",
    "                        train_inputs, val_inputs, y_train_dict, y_val_dict = build_data(region_data, input_regions, output_regions, QUANTILES)\n",
    "                        model = build_model_mode(select_mode, region_data, input_regions, output_regions, num_layer, hidden_dim, QUANTILES)\n",
    "                        best_model, history, model_params = run_model(model, QUANTILES, output_regions, train_inputs, val_inputs, y_train_dict, y_val_dict, epoch, batch_size, model_path, show_progress_bar)\n",
    "                        results = evaluate_model_unseen(region_data, input_regions, output_regions, model_path, QUANTILES)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8f6a82a6",
   "metadata": {},
   "source": [
    "- Load the probabilistic forecasts from the trained model\n",
    "- Concatenate forecasts across timesteps to create a continuous timeline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "6f2c20a0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "🚀 Loading probabilistic forecasts...\n",
      "\u001b[1m6/6\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m8s\u001b[0m 850ms/step\n",
      "✅ Loaded forecasts for 1 regions\n",
      "   - Forecast shape per region: (182, 24, 3)\n",
      "   - True values shape per region: (182, 24)\n",
      "🔄 Concatenating forecasts across timesteps...\n",
      "Region NL: Concatenated 182 days × 24 hours = 4368 total timesteps\n"
     ]
    }
   ],
   "source": [
    "print(\"🚀 Loading probabilistic forecasts...\")\n",
    "forecasts_dict, y_test_dict = load_probabilistic_forecasts_multi_timestep(\n",
    "    best_model, region_data, input_regions, output_regions, QUANTILES\n",
    ")\n",
    "\n",
    "print(\"🔄 Concatenating forecasts across timesteps...\")\n",
    "concatenated_forecasts_dict, concatenated_y_test_dict = concatenate_forecasts_across_timesteps(\n",
    "    forecasts_dict, y_test_dict, QUANTILES\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "ce7d6d0d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 360x230 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Configuration for visualization\n",
    "window_size = 72  # 3 days worth of hourly data for sliding window\n",
    "stop_index = 500  # Limit visualization to first 200 timesteps for demo\n",
    "\n",
    "# Visualize for each output region\n",
    "for region in output_regions:\n",
    "    print(f\"\\n🎬 Creating dynamic visualization for region: {region}\")\n",
    "    \n",
    "    # Get concatenated data for this region\n",
    "    concatenated_forecasts = concatenated_forecasts_dict[region]  # shape: (N, n_quantiles)\n",
    "    concatenated_y_true = concatenated_y_test_dict[region]       # shape: (N,)\n",
    "    \n",
    "    # Extract quantiles: assuming QUANTILES = [10, 50, 90]\n",
    "    # The forecasts are ordered by quantiles as they appear in QUANTILES list\n",
    "    q_idx_10 = QUANTILES.index(10)  # First quantile (10%)\n",
    "    q_idx_50 = QUANTILES.index(50)  # Second quantile (50% - median)\n",
    "    q_idx_90 = QUANTILES.index(90)  # Third quantile (90%)\n",
    "    \n",
    "    y_q10 = concatenated_forecasts[:, q_idx_10]\n",
    "    y_q50 = concatenated_forecasts[:, q_idx_50]  \n",
    "    y_q90 = concatenated_forecasts[:, q_idx_90]\n",
    "    \n",
    "    y_pred_list = [y_q10, y_q50, y_q90]\n",
    "    \n",
    "    print(f\"   - Timeline length: {len(concatenated_y_true)} timesteps\")\n",
    "    print(f\"   - Window size: {window_size} timesteps\")\n",
    "    print(f\"   - Stop index: {stop_index}\")\n",
    "    \n",
    "    # Create the dynamic sliding window visualization\n",
    "    live_plot_sliding_window_multi_timestep(\n",
    "        y_pred_list, concatenated_y_true, window_size, stop_index, region\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "47fe2e69",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "🎞️ Creating GIF animations...\n",
      "Creating GIF for region: NL\n",
      "GIF created successfully: Figure/NL_GIF.gif\n",
      "✅ All visualizations completed!\n"
     ]
    }
   ],
   "source": [
    "# Create GIFs from the generated plots\n",
    "print(\"🎞️ Creating GIF animations...\")\n",
    "\n",
    "for region in output_regions:\n",
    "    print(f\"Creating GIF for region: {region}\")\n",
    "    gif_conversion(region)\n",
    "\n",
    "print(\"✅ All visualizations completed!\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "a53631cc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "📈 Visualization Summary\n",
      "==================================================\n",
      "🎯 Model Configuration:\n",
      "   - Quantiles: [10, 50, 90]\n",
      "   - Input regions: ['AT', 'BE', 'BG', 'CZ', 'DE_LU', 'DK_1', 'DK_2', 'EE', 'ES', 'FI', 'FR', 'GR', 'HR', 'HU', 'IT_1', 'IT_2', 'IT_3', 'IT_4', 'IT_5', 'IT_6', 'IT_7', 'LT', 'LV', 'NL', 'NO_1', 'NO_2', 'NO_3', 'NO_4', 'NO_5', 'PL', 'PT', 'RO', 'SE_1', 'SE_2', 'SE_3', 'SE_4', 'SI', 'SK']\n",
      "   - Output regions: ['NL']\n",
      "   - Look-back window: -24 hours\n",
      "   - Prediction horizon: 23 hours (24-hour days)\n",
      "\n",
      "📊 Data Summary:\n",
      "   - Region NL:\n",
      "     • Test samples: 182 days\n",
      "     • Hours per day: 24 hours\n",
      "     • Quantiles: 3 ([10, 50, 90])\n",
      "     • Total timeline: 4368 hourly timesteps\n",
      "\n",
      "🎬 Visualization Details:\n",
      "   - Sliding window size: 72 hours (3 days)\n",
      "   - Frames generated: 429\n",
      "   - Output files:\n",
      "     • Individual frames: Figure/NL/NL_*.png\n",
      "     • Animated GIF: Figure/NL_GIF.gif\n",
      "\n",
      "✨ The visualization shows:\n",
      "   - Black line: True electricity prices\n",
      "   - Orange line: Median forecast (Q₀.₅)\n",
      "   - Gray shaded area: Uncertainty band (Q₀.₁ - Q₀.₉)\n",
      "   - Dynamic sliding window showing forecast evolution over time\n",
      "\n",
      "🎉 Visualization completed successfully!\n",
      "   You can find the generated GIF in the Figure/ directory.\n"
     ]
    }
   ],
   "source": [
    "# Display summary information about the visualization\n",
    "print(\"📈 Visualization Summary\")\n",
    "print(\"=\" * 50)\n",
    "\n",
    "print(f\"🎯 Model Configuration:\")\n",
    "print(f\"   - Quantiles: {QUANTILES}\")\n",
    "print(f\"   - Input regions: {input_regions}\")\n",
    "print(f\"   - Output regions: {output_regions}\")\n",
    "print(f\"   - Look-back window: {look_back_window} hours\")\n",
    "print(f\"   - Prediction horizon: {prediction_horizon} hours (24-hour days)\")\n",
    "\n",
    "print(f\"\\n📊 Data Summary:\")\n",
    "for region in output_regions:\n",
    "    forecasts = forecasts_dict[region]\n",
    "    y_true = y_test_dict[region]\n",
    "    print(f\"   - Region {region}:\")\n",
    "    print(f\"     • Test samples: {forecasts.shape[0]} days\")\n",
    "    print(f\"     • Hours per day: {forecasts.shape[1]} hours\")\n",
    "    print(f\"     • Quantiles: {forecasts.shape[2]} ({QUANTILES})\")\n",
    "    print(f\"     • Total timeline: {len(concatenated_y_test_dict[region])} hourly timesteps\")\n",
    "\n",
    "print(f\"\\n🎬 Visualization Details:\")\n",
    "print(f\"   - Sliding window size: {window_size} hours ({window_size//24} days)\")\n",
    "print(f\"   - Frames generated: {stop_index - window_size + 1}\")\n",
    "print(f\"   - Output files:\")\n",
    "for region in output_regions:\n",
    "    print(f\"     • Individual frames: Figure/{region}/{region}_*.png\")\n",
    "    print(f\"     • Animated GIF: Figure/{region}_GIF.gif\")\n",
    "\n",
    "print(f\"\\n✨ The visualization shows:\")\n",
    "print(\"   - Black line: True electricity prices\")\n",
    "print(\"   - Orange line: Median forecast (Q₀.₅)\")\n",
    "print(\"   - Gray shaded area: Uncertainty band (Q₀.₁ - Q₀.₉)\")\n",
    "print(\"   - Dynamic sliding window showing forecast evolution over time\")\n",
    "\n",
    "print(\"\\n🎉 Visualization completed successfully!\")\n",
    "print(\"   You can find the generated GIF in the Figure/ directory.\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.15"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
