{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "31408e0a-71b9-4bc7-af4a-7286faa79ebf",
   "metadata": {},
   "source": [
    "# Summarise and Visualisation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "abb61c6a-aaeb-447b-bc3a-3f060eeb238d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "import random\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from scipy.stats import ttest_ind"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "99c719c3",
   "metadata": {},
   "outputs": [],
   "source": [
    "def process_data(data_file):\n",
    "    data_different_row = [row.split() for row in data_file.strip().split('\\n')]\n",
    "    data_matrix = np.expand_dims(np.array(data_different_row, dtype=float), axis=-1)\n",
    "    data_matrix = np.concatenate((data_matrix[:, :5], data_matrix[:, 5:10], data_matrix[:, 10:15], data_matrix[:, 15:20], data_matrix[:, 20:]), axis=-1)\n",
    "\n",
    "    return data_matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "cc195a26",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "create matrix of shape (8, 5, 5)\n",
      "Synthetic mean average results is \n",
      " [[ 36.526  41.462  41.732  41.126  41.318]\n",
      " [ 97.798 118.246 117.788 127.248 135.03 ]\n",
      " [138.782 164.026 141.71  132.586 125.554]\n",
      " [229.716 269.664 220.952 208.3   188.428]\n",
      " [230.756 270.834 220.93  208.33  184.916]\n",
      " [ 93.734 101.028 118.01   88.528 132.276]\n",
      " [114.71  126.654 137.12  105.218 137.19 ]\n",
      " [111.662 122.082 150.572 175.844  87.886]]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "synthetic_main = '''\n",
    "38.72\t45.77\t47.89\t47.65\t48.81\t53.7\t62.7\t62.79\t60.08\t57.64\t32.52\t31.06\t27.14\t26.24\t26.49\t20.91\t24.59\t24.68\t23.6\t23.1\t36.78\t43.19\t46.16\t48.06\t50.55\n",
    "128.23\t157.42\t149.67\t156.99\t165.87\t95.89\t116.6\t110.94\t116.47\t122.71\t98.06\t115.33\t119.98\t129.34\t138.92\t84.82\t103.44\t112.4\t126.8\t135.04\t81.99\t98.44\t95.95\t106.64\t112.61\n",
    "210.26\t256.08\t222.67\t209.23\t199.17\t159.13\t188.76\t165.05\t154.06\t145.58\t110.65\t126.96\t106.12\t98.83\t93.25\t90.94\t102.66\t89.58\t83.77\t79.29\t122.93\t145.67\t125.13\t117.04\t110.48\n",
    "321.88\t383.84\t315.67\t299.75\t272.67\t275.69\t323.64\t273.36\t255.11\t238.85\t178.35\t204.81\t163.81\t154.64\t139.16\t161.99\t190.24\t154.97\t145.17\t129.86\t210.67\t245.79\t196.95\t186.83\t161.6\n",
    "334.18\t399.78\t329.11\t312.35\t280.25\t271.78\t318.94\t263.04\t246.17\t216.22\t180.02\t205.14\t166.16\t155.83\t142.56\t152.46\t178.35\t142.29\t133.61\t113.86\t215.34\t251.96\t204.05\t193.69\t171.69\n",
    "146.96\t167.65\t207.92\t157.29\t256.08\t92.06\t97.5\t105.74\t74.33\t97.1\t69.24\t67.01\t71.77\t50.77\t68.75\t71.04\t76.94\t93.15\t65.17\t102.08\t89.37\t96.04\t111.47\t95.08\t137.37\n",
    "152.52\t173.81\t198.76\t156.15\t203.4\t147\t164.38\t183.5\t130.62\t193\t97.37\t104\t91.14\t79.38\t76.45\t101.74\t115.47\t135.4\t101.09\t146.9\t74.92\t75.61\t76.8\t58.85\t66.2\n",
    "161.42\t187.59\t237.4\t283.79\t140\t87.21\t89.11\t101.8\t91.65\t85.71\t79.07\t84.19\t93.37\t112.61\t44.16\t58.32\t60.3\t75.4\t82.85\t45.46\t172.29\t189.22\t244.89\t308.32\t124.1\n",
    "'''\n",
    "synthetic_main_matrix = process_data(synthetic_main)\n",
    "print(f'create matrix of shape {synthetic_main_matrix.shape}')\n",
    "print(f'Synthetic mean average results is \\n {np.mean(synthetic_main_matrix, axis=-1)}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "1eafba78",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_p_matrix(matrix):\n",
    "    N, T, s = matrix.shape\n",
    "    p_value_matrix = np.zeros((N, N))\n",
    "\n",
    "    # Perform t-tests between all pairs of models\n",
    "    for i in range(N):\n",
    "        for j in range(i, N):\n",
    "            if i == j:\n",
    "                # Diagonal should be zero since it is the same model\n",
    "                p_value_matrix[i, j] = 0.0\n",
    "            else:\n",
    "                # Flatten the arrays to combine all measurements and seeds\n",
    "                model_i = matrix[i].flatten()\n",
    "                model_j = matrix[j].flatten()\n",
    "\n",
    "                # Perform the t-test\n",
    "                t_stat, p_value = ttest_ind(model_i, model_j, equal_var=False)\n",
    "\n",
    "                if p_value < 0.001:\n",
    "                    p_value = -0.001\n",
    "                elif p_value < 0.05:\n",
    "                    p_value = -0.05\n",
    "                else:\n",
    "                    p_value = p_value\n",
    "\n",
    "                # Store the p-value in the matrix\n",
    "                p_value_matrix[i, j] = p_value\n",
    "                p_value_matrix[j, i] = 0.0  # Symmetric matrix\n",
    "    \n",
    "    return p_value_matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "aabf650f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 0.    -0.001 -0.001 -0.001 -0.001 -0.001 -0.001 -0.001]\n",
      "[ 0.          0.          0.05737748 -0.001      -0.001       0.24921046\n",
      "  0.62747007  0.51046345]\n",
      "[ 0.          0.          0.         -0.001      -0.001      -0.05\n",
      "  0.22846242  0.54482357]\n",
      "[ 0.          0.          0.          0.          0.98997388 -0.001\n",
      " -0.001      -0.001     ]\n",
      "[ 0.     0.     0.     0.     0.    -0.001 -0.001 -0.001]\n",
      "[0.         0.         0.         0.         0.         0.\n",
      " 0.19462488 0.2053983 ]\n",
      "[0.         0.         0.         0.         0.         0.\n",
      " 0.         0.75756781]\n",
      "[0. 0. 0. 0. 0. 0. 0. 0.]\n"
     ]
    }
   ],
   "source": [
    "p_matrix = get_p_matrix(synthetic_main_matrix)\n",
    "for line in p_matrix:\n",
    "    print(line)\n",
    "# print(get_p_matrix(synthetic_main_matrix))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "d92102a4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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98JqteKqq67CQw89hF/96lcIBoO45JJLcM0116Curg7Nzc1oamrCueeei2AwiJtvvhmvv/46Lr300qh6E0WJSAaUlpbilVdewcGDB/HOO+/gmWeewdNPP43nn38eJpNJ6ealTTribG9vx759+/DMM8/I3NrULTTOO++8E3feeSfefPNNbN++Hf/8z/+c8XEQPkkcP34ct912G7xeL84991ysWbMGH330Ea688koMDw8jGAziX/7lX2Ium8rnCYKwsMan+LmZiFMpSsTZ39+PjRs34sc//jEcDseCY0iHLVu2oLGxEW+//TbeeustXHXVVfjVr36Fc845J6Hlr7zySrz00kt444038OCDD+KVV15Ja/vWrl0r9TfP83jwwQdx4MABCIKA0dFRLFmyREpELrzwQim5POuss/C3v/0NALB8+XK0trbi2LFjOO+88+aM7a233kJzczMAoLi4GJdeeineeustKREJbwsAnH/++bDZbABOnue2ZMkSmEwmmEwm1NXV4cSJE3A4HPiv//ovDA8PS8tNT0/j6NGjMWNMFF01kyannXYajh07hrGxsZjlBoMBS5cuxbe//W08++yz6O7uxt///veI97z55pu48sorceWVV6K1tTUTzU6anHF2dnbil7/8JZ544gkUFxfLGsd8MrE+v/CFL2BqakqaYDLl1FNPxbFjx+B2uwEA1dXVaG9vx80334yJiQkAwKJFi9De3o4//vGPuPTSS3HnnXdKCURhYWFUv4yNjUnr7JprrsGVV16Jb3zjGwBOHnvv6emR3tvT04Py8nLNxakUJeIcGBhAY2MjbrnlFlx++eWZCDNhFRUVWLt2LR544AF87Wtfw2uvvZbwsldddRWeeuopmM1m1NbWpr1t4uFJAHjiiScwPj6Of/mXf8Err7yCK664An6/XyoXD/0CkE6WB4DGxkbs2rULZWVl2LFjB3784x/P+XmzE4Lwv8PbEuvzYn0+z/NgGAYvvPAC2tvb0d7ejtdffx0333zznPUmghKRNKmpqcGqVauwZcsWaeMXBAEvv/wyDh48iOPHj0vvPXr0KILBIFwuV0QdX/jCF6SVm61nPMsVZ2dnJ372s5/hiSeeyMiX1HzkiDMYDOKTTz6Ryg8dOoTR0VFUVVVlJCZRbW0tLrnkkojYAGBmZibqvUajEVu2bEF/fz/eeOMNAMAFF1yAzs5OjI+PAwAGBwfxhz/8AV/4whcAAM8++yza29ulX92XXXYZXn75ZUxPT8Pv92Pv3r0ZOQSS6TiVkuk4BwcH0djYiA0bNuCqq66SObrETU1N4d///d+lBMvr9eLo0aNJbV8OhwPf/e53ceedd8rVTMnExARKSkpgNpsxPDyccMIkxnT11Vfj5ptvxsGDB2O+b8WKFXjuuecAAKOjo3jjjTdw3nnnLajNeXl5+PznP4/HHntMem1gYAD9/f0LqpcOzaTRfffdh9bWVnzjG98Ax3EQBAHnnHMOTCYT7r33XkxMTMBisYBlWTz44IMxzz+YbdeuXdizZw9GR0fR3NwMs9mMl19+OaFl5SJHnN///vdRUlKCjRs3Sq+JJ4UqJd1x8jyP5uZmeDwesCwLq9WKn//85xEnGGbK/fffj7a2NnzjG9+AwWBAfn4+iouLcdNNN8Hr9Ua8NycnB5s2bcKjjz6KlStXYsWKFfjmN7+Jb33rW2AYBgzDYNOmTdKVCrMtX74cl112mXRM+6tf/SouvPBC2WMEMhvn8ePH8c1vfhNerxc+nw8XXnghbr75Zlx//fWaivORRx6RzgN48sknAQDf+ta3sG7dOtnjnO0f//EfpfM4fD4flixZgvvuuw9msxnBYBAXXHBB0v2fqThuuOEG3H777bjyyivhcDikxG8+Tz/9NN5++20YjUawLDvnpcV33XUXWlpasGbNGgiCgKamJumwzEI8+OCD2LZtm7Q9W61W/OQnP4HT6Uy5TkbI5AFbQgghhJAwdGiGEEIIIYqhRIQQQgghiqFEhBBCCCGKoUSEEEIIIYqhRIQQQgghiqFEhBBCCCGKoUSEEEIIIYqhRIQQQgghiqFEhBBCCCGKoUSEEEIIIYqhRIQQQgghivn/AaaN14vXo925AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model_names = [\"CSI-1\", \"CSI-2\", \"CSI-3\", \"GRU-0\", \"GRU-1\", \"GRU-2\", \"LSTM\", \"Transformer\"]\n",
    "\n",
    "custom_palette = {\n",
    "    'CSI-1': sns.color_palette(\"Set3\")[0],\n",
    "    'CSI-2': sns.color_palette(\"Set3\")[1],\n",
    "    'CSI-3': sns.color_palette(\"Set3\")[2],\n",
    "    'GRU-0': sns.color_palette(\"Set3\")[3],\n",
    "    'GRU-1': sns.color_palette(\"Set3\")[4],\n",
    "    'GRU-2': sns.color_palette(\"Set3\")[5],\n",
    "    'LSTM': sns.color_palette(\"Set3\")[6],\n",
    "    'Transformer': sns.color_palette(\"Set3\")[7]\n",
    "}\n",
    "\n",
    "color_list = [custom_palette[model] for model in model_names]\n",
    "\n",
    "B, T, N = synthetic_main_matrix.shape\n",
    "data_reshaped = synthetic_main_matrix.reshape(B, -1).T\n",
    "# Create a box plot for each model\n",
    "plt.figure(figsize=(6, 4))\n",
    "sns.set(style=\"whitegrid\")\n",
    "sns.boxplot(data=data_reshaped, palette=color_list, linewidth=1.5)\n",
    "# plt.xlabel('Models', fontsize=10)\n",
    "plt.ylabel('Error (MSE)', fontsize=10)\n",
    "# plt.title('Box Plot of Results for Each Model', fontsize=8)\n",
    "plt.xticks(ticks=range(B), labels=model_names, fontsize=8)\n",
    "plt.yticks(fontsize=9)\n",
    "plt.grid(True, linestyle='--', alpha=0.7)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "697436e4-a582-4945-b533-ab9e760ce2f1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "create matrix of shape (6, 5, 5)\n"
     ]
    }
   ],
   "source": [
    "synthetic_different_k = \"\"\"\n",
    "46.59 54.33 57.32 55.64 56.23 60.23 68.5 63.76 60.05 57.07 42.6 42.63 39.35 39.94 40.69 25.84 30.27 31.88 30.77 30.66 51.22 56.28 50.84 48.14 45.74\n",
    "38.72 45.77 47.89 47.65 48.81 53.7 62.7 62.79 60.08 57.64 32.52 31.06 27.14 26.24 26.49 20.91 24.59 24.68 23.6 23.1 36.78 43.19 46.16 48.06 50.55\n",
    "39.11 46.34 48.78 49.18 50.37 51.42 60.04 59.84 57.32 54.97 34.55 37.27 36.02 35.38 36.44 21.56 25.37 25.68 24.65 24.16 35.69 42.02 43.17 44.21 45.43\n",
    "64.08 77.43 90.1 101.5 115.37 54.44 66.22 69.74 69.99 72.23 29.91 29.21 24.3 23.66 23.26 16.42 19.36 18.63 18.29 18.39 31.69 37.86 38.88 39.04 39.28\n",
    "46.27 55.94 63.15 67.19 71.23 55.65 67.48 73.79 75.38 80.46 31.46 31.07 25.68 24.81 24.26 17.02 20.06 19.83 19.16 19.34 31.29 37.25 38.18 38.52 39.28\n",
    "43.24 52.14 58.33 63.11 68.09 51.34 62.32 64.48 61.19 60.94 29.66 28.7 23.63 23.24 23.08 17.51 20.75 20.8 20.57 20.63 29.7 35.36 36.86 37.52 38.46\n",
    "\"\"\"\n",
    "synthetic_k_matrix = process_data(synthetic_different_k)\n",
    "print(f'create matrix of shape {synthetic_k_matrix.shape}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "490a381f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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wAD8fr/VQ7ENZmYMc9OPmRnD3PRLhcxYdNiAoihwu91QFMXqodgGMzOGuenHzIxhbvqlQmYsOoiIiMgULDqIiIjIFIIaunBAmnvllVegqmpSXrlPVVUEAgFIksTrM8SJmRnD3PRjZsYwN/2SOTOfzwdBEHDBBRfEvB+PXvn/ku0FnE0QBDidTquHYSvMzBjmph8zM4a56ZfMmQmCENfnKLd0EBERkSm4TwcRERGZgkUHERERmYJFBxEREZmCRQcRERGZgkUHERERmYJFBxEREZmCRQcRERGZgkUHERERmYJFBxEREZmCRQcRERGZgkUHERERmYJFRxLzeDy4/vrrsX79erS0tOCHP/yh1UOyjfe+971Yv3491q9fj61bt1o9HEOWehk2b96MX/3qV5rbfv/73+O6665DS0sLPvnJT+Ktt95a9POkultvvRUXXnghbr/99vBtx44dw8c+9jFceeWV2L17t4Wji1+05QCWflkeeeQRPPXUU5rbJicn8ZnPfAbnn38+HnrooUU/h5mszK2zsxOf+MQncM0116C1tRUvvfTSop/HdColrUAgoE5NTamqqqpTU1PqmjVr1JGREYtHZQ+rVq2yegiLpmcZurq61Lvuuivmfe666y71l7/8pea2P//5z+rg4KCqqqr6+9//Xv3Upz6lf6AxKIqiBoPBJe3Tai+++KL6wgsvqLfddlv4ttbWVrWzs1P1+/1qa2ur+tZbb1k4wvhEWw5V1b8sn/70p2O279q1S92/f7/mNq/Xq7788svq008/rT744IPGFmABgUAgIf1amdvJkyfVU6dOqaqqqsePH1fXrFljYAliS1RuIdzSkcQcDgcyMzMBAF6vF4qiQOVFgWkJNTc3o7S0FMCZLSsDAwMR9+nu7sa1116Lu+66C1dffTW+9KUvhefh7373O6xfvx7XXHMNtm/fHr599erV+PrXv44NGzbg1KlTuPbaa7F582asW7cOHR0d+MUvfoG///u/x8c+9jG88847pi3vUrjooouQnZ0d/ntgYADBYBArV66EJEloaWmJ2KKUjOYuB2DessiyjAsvvBAZGRkx77d69Wo89NBDaGlpwWc+8xlMTU0BAN544w1s2LABLS0tuPPOO+H1egEAa9aswe7du/HJT34SL7/8MlavXo3t27dj/fr1uOWWW3DkyBHccMMNuPLKK/Hqq68aGruVudXX16O2thYA0NjYiKmpKQSDwYj7JWNuISw6ktzExASuvfZafPjDH8YXvvAFFBUVWT0kW5icnERraytuuOEGvPzyy1YPxxCzl+GZZ57BJZdcErXt7bffxs0334znnnsOp0+fxtGjRzEzM4O7774b3/nOd/Czn/0M77zzDp5//nkAwNjYGD7wgQ/g4MGDcDqd4ccfOnQIL7/8Mo4ePYof/ehH+PSnPx2xCdluBgcHUV5eHv67vLw8avFmB8m2LGNjY7jssstw6NAhlJeX43/+538AnPmp8O6778ahQ4eQmZmJAwcOhB9TWFiI//iP/8DFF1+MsbExXHHFFfjpT38Kr9eLp556Ck8//TTuvvtuPPbYY0s2Titye/7553H22WfD4XBEtCVzbtKiHk0Jl5eXh5/97GcYHh7Gpk2b8Hd/93coKSmxelhJ74UXXkB5eTn+8pe/4Itf/CIOHTqEnJwcq4elSzzLsGXLFvz5z3+G3+/H8PAw1q9fDwDYtm0b3v/+98f9XH/84x/xgx/8AP/+7/8etb2hoQFNTU0Azmwd6e7uRnZ2NhoaGrBs2TIAwDXXXIMjR45g7dq1yMjIwOWXX655fGNjIwCgqakJH/zgBwEAK1aswG9+85u4x5mMom19FATBgpEsXrzL8s1vfhO//vWvAQDvvvtueN5t2rQJV1555ZKNJysrCxdffDEA4Oyzz0ZPTw/cbjd8Pl94fq9fvx5PPPEEPve5zwEArrrqKs3jL7roIgDAe97zHjQ0NEAURaxYsQI9PT1LNk6zc3v33Xfx9a9/HY8//njU9mTOjUWHTZSUlGDFihX4v//7P1x99dVWDyfphb51nHXWWWhqasLJkydxzjnnWDwqfeJZhu3btwM48xPI7t278eCDD+p+nq6uLtx1113YvXs3CgsLo97H6XSG/+9wOKAoSsR9VFUNr2jnbjaf/XhRFCHLcvj/0fqyk7nfagcGBsI/WdlNvMvy5S9/GV/+8pcBADfeeCP279+fkPGE5gnwt3k39wN+9rwDtHNv9uMTOe/MzG1sbAy33nor7rvvPtTV1UW9TzLnxp9Xktjw8DA8Hg+AM0eyHDlyBA0NDRaPKvmNj4/D5/MBAPr7+3HixAnU1NRYPCp9zFqGiYkJtLW14Z577sF73vMeXY9taGjAO++8g56eHiiKgueeew4f+MAHlnyMya68vByiKOLNN99EIBDA4cOHccUVV1g9LEPssCx5eXmQZRnHjh0DABw+fNjyeWdWbj6fD5s2bcJnP/vZ8JaMeCVLbtzSkcT6+/uxdetWqKoKVVXxj//4j1i5cqXVw0p6J06cQEdHBwRBgCAI2Lp1KwoKCqweli6JWobNmzfD5XIBAM477zysXLkS3d3d2LFjB4Az33B+9KMfxdVXRkYGtm3bhra2NgSDQVxyySX46Ec/uugxJrt//ud/xhtvvIHp6Wlcdtll2L17N+655x585Stfgdfrxfr167FixQqrh7mgaMtx7rnnJmRZvv3tb4f3BaisrMQPfvADfOxjH8PQ0BD8fj+effZZHDx4MO4tRNu3b8e9994Lr9eL5uZm3HDDDYseY7yszO1Tn/oU/vjHP8LtduPf/u3fAABPPvnkvFso57IytxBB5eEQREREZAL+vEJERESmYNFBREREpmDRQURERKZg0UFERESmYNFBREREpmDRQURERKZg0UFERESmYNFBREREpmDRQURERKZg0UFERESmYNFBREREpvh/0s1Su/3GYucAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model_names = [\"3\", \"5\", \"5 + L2 norm\", \"10\", \"10 + L1 norm\", \"10 + L2 norm\"]\n",
    "\n",
    "B, T, N = synthetic_k_matrix.shape\n",
    "data_reshaped = synthetic_k_matrix.reshape(B, -1).T\n",
    "# Create a box plot for each model\n",
    "plt.figure(figsize=(6, 4))\n",
    "sns.set(style=\"whitegrid\")\n",
    "sns.boxplot(data=data_reshaped, palette=\"Set3\")\n",
    "# plt.xlabel('Latent Dimension', fontsize=10)\n",
    "plt.ylabel('Error (MSE)', fontsize=10)\n",
    "# plt.title('Box Plot of Results for Each Model', fontsize=8)\n",
    "plt.xticks(ticks=range(B), labels=model_names, fontsize=7)\n",
    "plt.yticks(fontsize=9)\n",
    "plt.grid(True, linestyle='--', alpha=0.7)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "c121293f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "create matrix of shape (6, 5, 5)\n"
     ]
    }
   ],
   "source": [
    "synthetic_different_n ='''\n",
    "38.72\t45.77\t47.89\t47.65\t48.81\t53.7\t62.7\t62.79\t60.08\t57.64\t32.52\t31.06\t27.14\t26.24\t26.49\t20.91\t24.59\t24.68\t23.6\t23.1\t36.78\t43.19\t46.16\t48.06\t50.55\n",
    "32.45\t39.13\t41.95\t43.47\t44.62\t48.95\t57.5\t55.72\t53.06\t51.21\t23.55\t23.11\t19.75\t18.95\t18.36\t21.43\t25.3\t26.04\t25.46\t25.45\t30.45\t35.39\t37.46\t38.19\t39.37\n",
    "28.79\t34.33\t36.24\t36.32\t37.71\t65.96\t77.17\t77.18\t74.53\t71.91\t21.79\t24.06\t22.43\t23.18\t23.58\t18.61\t22.25\t23.8\t23.86\t22.8\t26.92\t31.54\t33.16\t34.85\t36.93\n",
    "146.96\t167.65\t207.92\t157.29\t256.08\t92.06\t97.5\t105.74\t74.33\t97.1\t69.24\t67.01\t71.77\t50.77\t68.75\t71.04\t76.94\t93.15\t65.17\t102.08\t89.37\t96.04\t111.47\t95.08\t137.37\n",
    "198.92\t231.19\t292.7\t244.5\t385.78\t81.95\t90.97\t101.67\t68.31\t97.73\t114.22\t128.54\t131.05\t105.17\t143.94\t62.49\t66.54\t81.97\t55.86\t89.9\t105.2\t115.62\t144.32\t106.71\t179.44\n",
    "196.4\t224.2\t285.1\t196.04\t334.49\t77.25\t87.7\t104.43\t84.29\t80.55\t87.2\t94.89\t94.05\t69.86\t81.42\t37.83\t36.71\t42.98\t27.71\t37.74\t123.06\t135.6\t169.97\t129.43\t201.63\n",
    "'''\n",
    "\n",
    "synthetic_n_matrix = process_data(synthetic_different_n)\n",
    "print(f'create matrix of shape {synthetic_n_matrix.shape}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "bfd5676f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model_names = [\"CSI-VAE-50K\", \"CSI-VAE-100K\", \"CSI-VAE-200K\", \"GRU-50K\", \"GRU-100K\", \"GRU-200K\"]\n",
    "\n",
    "B, T, N = synthetic_n_matrix.shape\n",
    "data_reshaped = synthetic_n_matrix.reshape(B, -1).T\n",
    "# Create a box plot for each model\n",
    "plt.figure(figsize=(6, 4))\n",
    "sns.set(style=\"whitegrid\")\n",
    "sns.boxplot(data=data_reshaped, palette=\"Set3\")\n",
    "# plt.xlabel('Training Data Size', fontsize=10)\n",
    "plt.ylabel('Error (MSE)', fontsize=10)\n",
    "# plt.title('Box Plot of Results for Each Model', fontsize=8)\n",
    "plt.xticks(ticks=range(B), labels=model_names, fontsize=7)\n",
    "plt.yticks(fontsize=9)\n",
    "plt.grid(True, linestyle='--', alpha=0.7)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ffb2f806",
   "metadata": {},
   "source": [
    "### For Spotify Results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "40f4adb2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "create matrix of shape (8, 5, 5)\n",
      "Spotify mean average results is \n",
      " [[ 68.234  82.94   83.528  81.972  79.626]\n",
      " [253.846 312.526 305.076 303.684 302.83 ]\n",
      " [757.938 937.068 800.546 704.66  634.716]\n",
      " [215.418 260.652 193.41  137.2   117.058]\n",
      " [223.612 269.688 205.912 141.534 126.358]\n",
      " [154.184 187.418 177.962 133.356 127.578]\n",
      " [130.354 156.024 133.276  94.354  85.924]\n",
      " [133.42  157.66  154.614 164.706 158.03 ]]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "spotify_main = \"\"\"\n",
    "40.58\t49.17\t51.54\t51.86\t51.55\t131.62\t160.72\t158.63\t155.76\t151.85\t55.29\t66.45\t63.39\t61.33\t59.06\t67.18\t82.03\t85.9\t83.24\t78.94\t46.5\t56.33\t58.18\t57.67\t56.73\n",
    "132.01\t161.17\t149.2\t154\t159.31\t188.04\t231.16\t193.11\t181.48\t183.53\t166.48\t201.74\t172.8\t160.79\t157.37\t652.58\t810.72\t869.81\t881.95\t868.57\t130.12\t157.84\t140.46\t140.2\t145.37\n",
    "654.5\t810.65\t693.58\t611.88\t551.85\t1015.24\t1255.04\t1085.07\t963.35\t873.18\t648.82\t796.31\t679\t597.22\t537.5\t831\t1030.65\t872.28\t761.96\t682.48\t640.13\t792.69\t672.8\t588.89\t528.57\n",
    "151.16\t181.72\t127.72\t81.64\t69.16\t311.61\t379.42\t288.25\t214.07\t180.64\t227.44\t274.32\t212.79\t159.75\t138.93\t227.49\t276.06\t200.6\t136.28\t114.17\t159.39\t191.74\t137.69\t94.26\t82.39\n",
    "166.1\t199.9\t152.89\t95.39\t93.3\t337.31\t408.9\t319.38\t236.14\t205.56\t238.89\t286.54\t228.71\t171.23\t153.67\t207.26\t250.23\t178.65\t108.88\t93.38\t168.5\t202.87\t149.93\t96.03\t85.88\n",
    "115.01\t139.79\t139.33\t100.95\t108.82\t231.79\t283\t259.08\t203.64\t187.85\t153.24\t185.12\t166.34\t126.72\t113.1\t156.05\t190.37\t189.17\t130.17\t130.01\t114.83\t138.81\t135.89\t105.3\t98.11\n",
    "76.68\t91.59\t76.47\t51.45\t44.19\t215.04\t260.2\t220.04\t156.15\t139.18\t151.23\t180.05\t151.64\t115.98\t104.78\t127.26\t151\t136.28\t92.73\t90.43\t81.56\t97.28\t81.95\t55.46\t51.04\n",
    "148.23\t174.68\t195.6\t258.68\t277.81\t164.16\t194.32\t165.57\t128.99\t113.51\t138.08\t163.71\t145.18\t140.7\t132.8\t78.43\t91.32\t83.33\t73.56\t67.58\t138.2\t164.27\t183.39\t221.6\t198.45\n",
    "\"\"\"\n",
    "\n",
    "spotify_main_matrix = process_data(spotify_main)\n",
    "print(f'create matrix of shape {spotify_main_matrix.shape}')\n",
    "print(f'Spotify mean average results is \\n {np.mean(spotify_main_matrix, axis=-1)}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "34a0ff90",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[ 0.         -0.001      -0.001      -0.001      -0.001      -0.001\n",
      "  -0.05       -0.001     ]\n",
      " [ 0.          0.         -0.001       0.05838809  0.08084802 -0.05\n",
      "  -0.05       -0.05      ]\n",
      " [ 0.          0.          0.         -0.001      -0.001      -0.001\n",
      "  -0.001      -0.001     ]\n",
      " [ 0.          0.          0.          0.          0.7054523   0.12938715\n",
      "  -0.05        0.10946841]\n",
      " [ 0.          0.          0.          0.          0.          0.0608959\n",
      "  -0.001       0.05150527]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "  -0.05        0.86987713]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.         -0.05      ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.        ]]\n"
     ]
    }
   ],
   "source": [
    "print(get_p_matrix(spotify_main_matrix))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "86a2ce17",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model_names = [\"CSI-1\", \"CSI-2\", \"CSI-3\", \"GRU-0\", \"GRU-1\", \"GRU-2\", \"LSTM\", \"Transformer\"]\n",
    "\n",
    "B, T, N = spotify_main_matrix.shape\n",
    "data_reshaped = spotify_main_matrix.reshape(B, -1).T\n",
    "# Create a box plot for each model\n",
    "plt.figure(figsize=(6, 4))\n",
    "sns.set(style=\"whitegrid\")\n",
    "sns.boxplot(data=data_reshaped, palette=\"Set3\")\n",
    "# plt.xlabel('Models', fontsize=10)\n",
    "plt.ylim(0, 1000)\n",
    "plt.ylabel('Error (MSE)', fontsize=10)\n",
    "# plt.title('Box Plot of Results for Each Model', fontsize=8)\n",
    "plt.xticks(ticks=range(B), labels=model_names, fontsize=8)\n",
    "plt.yticks(fontsize=9)\n",
    "plt.grid(True, linestyle='--', alpha=0.7)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "47a53577",
   "metadata": {},
   "outputs": [],
   "source": [
    "spotify_selected_matrix = np.vstack((spotify_main_matrix[:2], spotify_main_matrix[3:]))\n",
    "# np.mean(spotify_selected_matrix, axis=-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "1e0ffc7f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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fv7zn+Pxxx/HmTNnAADvvfceKioqoNfrAQCHDx/GF77wBczMzOAvf/mLeNfwN954A/X19bjjjjuifm+SdfPNNwMIfK4ffvghPvaxjwEAlixZgh//+McL+l6h7HY77r77bkxPT+OGG27A3XffnbL3WkhUdKTQrl274HA48Nvf/hYWiwV+vx9//OMf8dxzz+Gvf/0rnnvuORgMBni9XnR1dcXV55VXXom6ujrs2rUrxaNfOKnI4brrrsPevXuh0Wjw7//+79i+fTv++Mc/pnhJkrNz505MT0+Lyw8Af/rTn/Duu++itLQUy5YtE4uEw4cP49vf/jY6OjqSeq///u//xssvv4w//OEP0Gg0uPXWW/GJT3wC69atW7DlSVY6c7Barfj2t7+Nv/3tb3j99dcXbBkWQjpzKC0txZNPPomSkhJMTExg48aNuOiii/CJT3xiwZYnFbxeL+655x489dRTuOiiiwAA77//PnJycvDwww+Lz7vmmmvw05/+VFKsAIDNZsOf/vQnfO5znwMAtLa2YuXKlSkZa1tbGwCgu7sbmzZtEv89e3k0moX9c/v666/DbDbjf//v/53Q61IxlkT6paIjRc6dO4dXXnkF//7v/y5OLCzL4sYbb8TTTz+NgoICsTrXaDRYsWJFXP1+/OMfT9mYUyFVOVx77bXi/3/84x9HT08P/H5/2K2u5fbhhx/itddew5///Gdx+YHAZAkAb775puT5V1xxBX74wx8m/X4dHR245ZZbxLswb9q0CS+//LLsRUe6cygrK0NZWVncRWy6pDuH0OLCbDZj6dKl6O7uVnzRMTU1hampKZSUlIiPLV26NO7Xb9q0Ca2trfjc5z6HiYkJvPXWW/j85z8Pl8uViuFGdM011+CLX/wiXn/9dVitVjQ1NeEb3/gGpqam4HK5cOWVV2LXrl1gGAY/+9nP8OGHH2JqagofffQRiouL8dOf/hT5+fn4f//v/2HPnj3w+Xzw+XzYunUrqqursX//fkxOTuLmm2/Gt771LVxwwQXYvXs3PvroI/A8j9tvvx1f/vKXI46luroaH3zwAaampvD+++/joosuwl133YV9+/ahp6cH1113HXbu3AkAGBoawve+9z309PTA5XLhuuuuw3333Rex38cee2zOXKjoSJGzZ8+iqqoKhYWFYW2f//zn8bvf/Q7XXnstLrvsMtTW1uKmm26CwWCQYaSplY4cnnnmGXz6059WXMEBAH/729+wePFi5Ofnx/X8V155RbyXUDL6+vpw+eWXi/+uqKhQxBagdOegVHLm0NXVJf4BUzqLxYItW7Zg/fr1uOyyy7Bq1SrU1dVhyZIlcb3+8ssvx7PPPouBgQH86U9/wg033ACO41I86nB9fX145plnwDAMXC4XWlpaYDKZ4PP50NjYiD/+8Y+44YYbAABvvfUWnnvuOeTn52PHjh347W9/i7vuugsHDx7EP/3TP2HDhg0AAIfDAYvFgq9//ev485//LO463L59O5YuXYp//dd/xcjICDZu3IiamhpceumlYWP52c9+hjNnzqC1tRVGoxG33HILHnvsMfziF7+A1+vFtddei1tvvRVLlixBU1MTGhoacPnll8Pr9eKuu+7Cq6++iuuvvz6s33hQ0SGDkpISvPTSS3jrrbdw4sQJHDlyBM8++yx+97vfQafTyT28tFmIHNra2nD06FEcOXIkxaNNXuiX8aOPPsK9994Lp9OJyy+/HBs2bMB7772Hm2++GcPDw/B6vfj9738f8bXJvJ+Sbq2U7hyUSo4c+vv70djYiO985zsoLS2d9zKkw65du1BfX48333wTb7zxBm655Rb84he/wGWXXRbX62+++Wa88MILeO211/Doo4/ipZdeSvGIw23cuFH8zPx+Px599FEcP34cPM9jdHQUK1asEIuOq6++WixGV61ahb///e8AgLVr16K5uRnnzp3DFVdcEXX533jjDTQ1NQEAioqKcP311+ONN94Qi47QsQDAVVddBbPZDCBw/NyKFSug0+mg0+mwZMkSnD9/HqWlpfi///f/Ynh4WHzd9PQ03n///YjLGA/l/TTMEBdffDHOnTuHsbGxiO0cx2HNmjX42te+ht/85jfo7u7Gu+++K3nO66+/jptvvhk333wzmpub0zHsBZfKHDo6OvCv//qveOqpp1BUVJTS5UjWRRddhHPnzsHhcAAAFi9ejLa2Ntx1110YHx8HACxbtgxtbW3485//jOuvvx7333+/WCwUFBSEZTc2NiYu76233oqbb74ZX/ziFwEE9mX39PSIz+3p6UF5eXnKl3Mu6c5BqeTIYWBgAPX19bj77rtx4403pmMxF8yiRYuwceNG/PCHP8QXvvAFvPLKK3G/9pZbbsGhQ4eg1+tRXV2dukHGIOzmBICnnnoKdrsdv//97/HSSy/hpptugtvtFtuF3cwAxAPuAaC+vh4HDx6E1WrF448/ju985ztR32/2H//Qf4eOJdL7RXp/v98PhmHw3HPPoa2tDW1tbXj11Vdx1113Re13LlR0pEhVVRXWr1+PXbt2iZMJz/N48cUX8dZbb+Gjjz4Sn/v+++/D6/XCZrNJ+vjkJz8pftBqOTJ5tlTl0NHRgR//+Md46qmnFPFHNZrq6mpce+21kuUHgJmZmbDnarVa7Nq1C/39/XjttdcAAOvWrUNHRwfsdjsAYHBwEH/605/wyU9+EgDwm9/8Bm1tbeKv4RtuuAEvvvgipqen4Xa70draqojdFOnOQanSncPg4CDq6+uxbds23HLLLSleuoUzNTWF//iP/xCLLafTiffffx+VlZVx91FaWopvfOMbuP/++1M1zISMj4+juLgYer0ew8PDcRdQwnJ/6Utfwl133YW33nor4vOuvPJK/Pa3vwUAjI6O4rXXXsMVV1wxrzHn5ubiE5/4BJ544gnxsYGBAfT39yfdJ+1eSaHvf//7aG5uxhe/+EVoNBrwPI/LLrsMOp0ODz/8MMbHx2EwGMCyLB599NGIxz3MdvDgQRw+fBijo6NoamqCXq/Hiy++GNdr5ZKKHL75zW+iuLgYjY2N4mPCgalK88gjj6ClpQVf/OIXwXEc8vLyUFRUhDvvvBNOp1Py3JycHOzYsQM/+9nPcN111+HKK6/EV77yFXz1q18FwzBgGAY7duwQj+ifbe3atbjhhhvE/b+f//zncfXVV6d8GeORzhw++ugjfOUrX4HT6YTL5cLVV1+Nu+66C7fddls6FjWmdObw05/+VNzn/swzzwAAvvrVr2LTpk0pX85E/dM//ZN43IXL5cKKFSvw/e9/H3q9Hl6vF+vWrUv481PSct5+++247777cPPNN6O0tFQsFOfy7LPP4s0334RWqwXLslFP+X3wwQexe/dubNiwATzPo6GhQdy1Mh+PPvoo9u3bJ84pRqMR3/3ud1FWVpZUfwyvpJ2+hBBCCMlYtHuFEEIIIWlBRQchhBBC0oKKDkIIIYSkBRUdhBBCCEkLKjoIIYQQkhZUdBBCCCEkLajoIIQQQkhaUNFBCCGEkLSgooMQQgghaUFFByGEEELSgooOQgghhKTF/w8UudYW3Vn6UAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model_names = [\"CSI-1\", \"CSI-2\", \"GRU-0\", \"GRU-1\", \"GRU-2\", \"LSTM\", \"Transformer\"]\n",
    "\n",
    "custom_palette = {\n",
    "    'CSI-1': sns.color_palette(\"Set3\")[0],\n",
    "    'CSI-2': sns.color_palette(\"Set3\")[1],\n",
    "    'CSI-3': sns.color_palette(\"Set3\")[2],\n",
    "    'GRU-0': sns.color_palette(\"Set3\")[3],\n",
    "    'GRU-1': sns.color_palette(\"Set3\")[4],\n",
    "    'GRU-2': sns.color_palette(\"Set3\")[5],\n",
    "    'LSTM': sns.color_palette(\"Set3\")[6],\n",
    "    'Transformer': sns.color_palette(\"Set3\")[7]\n",
    "}\n",
    "\n",
    "color_list = [custom_palette[model] for model in model_names]\n",
    "\n",
    "B, T, N = spotify_selected_matrix.shape\n",
    "data_reshaped = spotify_selected_matrix.reshape(B, -1).T\n",
    "# Create a box plot for each model\n",
    "plt.figure(figsize=(6, 4))\n",
    "sns.set(style=\"whitegrid\")\n",
    "sns.boxplot(data=data_reshaped, palette=color_list)\n",
    "# plt.xlabel('Models', fontsize=10)\n",
    "plt.ylim(0, 450)\n",
    "plt.ylabel('Error (MSE)', fontsize=10)\n",
    "# plt.title('Box Plot of Results for Each Model', fontsize=8)\n",
    "plt.xticks(ticks=range(B), labels=model_names, fontsize=8)\n",
    "plt.yticks(fontsize=9)\n",
    "plt.grid(True, linestyle='--', alpha=0.7)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "b72d6e0b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "create matrix of shape (6, 5, 5)\n"
     ]
    }
   ],
   "source": [
    "spotify_different_n ='''\n",
    "40.58\t49.17\t51.54\t51.86\t51.55\t131.62\t160.72\t158.63\t155.76\t151.85\t55.29\t66.45\t63.39\t61.33\t59.06\t67.18\t82.03\t85.9\t83.24\t78.94\t46.5\t56.33\t58.18\t57.67\t56.73\n",
    "31.89\t38.54\t38.73\t38.38\t37.65\t89.05\t108.84\t109.59\t109.06\t106.82\t70.38\t85.13\t84.15\t73.94\t68.57\t71.64\t87.76\t96.71\t99.68\t100.09\t29.36\t35.25\t34.51\t33.55\t32.47\n",
    "33.34\t40.44\t40.78\t40.08\t38.85\t99.75\t122.06\t127.68\t126.65\t122.9\t44.59\t53.51\t53.93\t53.04\t52.23\t55.43\t67.08\t65.17\t62.78\t60.11\t25.82\t30.98\t30.3\t29.57\t29.11\n",
    "115.01\t139.79\t139.33\t100.95\t108.82\t231.79\t283\t259.08\t203.64\t187.85\t153.24\t185.12\t166.34\t126.72\t113.1\t156.05\t190.37\t189.17\t130.17\t130.01\t114.83\t138.81\t135.89\t105.3\t98.11\n",
    "99.19\t119.28\t121.22\t81.26\t81.04\t212.65\t259.64\t244.08\t193.07\t190.97\t163.89\t198.81\t182.96\t140.93\t125.33\t124.39\t150.26\t143.34\t88.95\t85.24\t110.23\t133.7\t130.78\t93.67\t92.92\n",
    "95.31\t115.54\t119.8\t86.99\t80.02\t203.47\t249.22\t233.39\t186.74\t174.36\t141.72\t172.33\t165.87\t118.51\t119.03\t103.91\t125.16\t120.6\t76.9\t77.52\t92.62\t112.07\t114.83\t71.12\t83\n",
    "'''\n",
    "\n",
    "spotify_n_matrix = process_data(spotify_different_n)\n",
    "print(f'create matrix of shape {spotify_n_matrix.shape}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "id": "9ceca9de",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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fQ8U695zJUL3re3PP/98LFiwADNnzkRDQwNCodBk9ov+5ujRo+jp6QEA9PT04LnnnjO5R0RERPpo2tMBAK+//joOHjyIo0ePYtq0aVi5ciWWL1+O/Pz8VPQvq506dQpHjx6Neuzo0aO46KKL4PF4TOoVERGRPprO6Xj66afR3d2N5cuX44knnsDZZ5+dyr5lNUVR8NOf/jTmSiFZlvHTn/4UmzZtsvTtjVPNZrOhqKiIJztrxNyIKJWSLjruu+8+VFVVYcmSJRAEAU8//XTc5916662T1rls1tbWhrfffjtu29tvv422tjZUVlYa3CvrsNvtKCsrM7sblsPciCiVki46/vEf/xEA8Je//GXM5/CX9+SpqKhAXl4e+vv7Y9ry8vI45Pw4ZFlGIBCAJEkQRd2nLmUd5kZEqZR00fH444+nsh80Snt7e9yCAwD6+/vR3t7OPR0JBINBNDU1oaamhoNdacDciCiV+FMmTXm9XsyaNStu26xZs+D1eg3uERER0cQkVXQ88sgjGBgYSGqCb7zxBn77299OpE9ERESUgZI6vHLixAlcdtllWLx4MRYuXIjzzz8fJSUlAIBQKIQTJ07g2LFjeOaZZ3Dq1Cls3749pZ3OBm1tbThx4kTcthMnTvBEUiIispykio7t27fjnXfewRNPPIG6ujr09fXBZrPB4XBgaGgIADB79mxcc801WLFiBUfMnARerxfnnnsuGhoaoi6bFQQB5557Lg+vJIGXferD3IgoVZI+kfScc87Btm3b8J3vfAfvvvsumpqa4Pf7UVxcjHPOOUfd80GTQxAErFmzBrfddltM25o1a3il0DicTiemT59udjcsh7kRUSppHpFUEAScc845OOeccyb85vv27cPTTz+N9957D5deeikeeughtW3Lli04fPhw1J0uf/zjH2PevHkAhs+yv/vuu3H48GEAwPLly3HrrbfCbtc8S2lNEISYAcJG/01ERGQFpl694vF4sGHDBnzxi1+M275mzRq8/vrr6r9IwQEAu3fvxrFjx3D48GEcPnwYr776Kvbs2WNU11MuMiLp6D0agiDEHamUogUCAXz00UcIBAJmd8VSmBsRpZKpRceiRYtw+eWXo7i4WPNrDx48iBtuuAEejwcejwfr16/HwYMHU9BLc0RGJJVlOepxWZbVEUlpbIqiIBgMsjjTiLkRUSql9bGIQ4cO4dChQygvL8eqVauwdu1aiKKInp4etLW1Yfbs2epzZ8+ejZaWFvT19aGgoED3e/r9/qi/RVGEw+GALMsIBoMxz48MoBQIBGI21Ha7HTabDeFwOOYuvIIgQJIkKIoS91dlRUUFzj33XLzzzjtRhYcoijjnnHPg9XoTTjfevACAw+GAKIoIBoMxBY3NZoPdbh93XhNNNxQKIRwOR7VNRoaJphsvQ7/fr05L72cz3rxqzTDZ6ZqZod/vRzgcVvsnSRIEQZj05Tsy3UQZJvvZxMsy24zOINkMs53WbQSXtdgMIuuyoihJnWuYtkXHddddh82bN8PtduP48eO4+eabIYoi1q5dq44ZMrK4KCwsBDA8WqfeokOWZTQ2NkY9VlBQgIqKCoTD4Zg2AOoAXqdOnVKv5ImoqKhAQUEBfD4fOjo6otpcLheqqqqgKErc6U6fPh1r1qxBfX19TNuyZcsgCAIGBwdj9ng4nU7U1NQAAJqammJWpKlTp0KSJHR1daG3tzeqrbi4GKWlpfD7/Whubo5qs9vtmDZtGgCgtbU1ZkM2ZcoU5ObmoqenB11dXVFthYWF8Hg8CIVCMfMqCAJmzpwJYHgU1tELtNfrRX5+Pnw+Hzo7O6Pa8vLyUFlZGfdzk2VZXQE6OztjxpkpLy+H2+3GwMAA2tvbo9pycnJQXV0NAHE/m9raWoiiiDNnzqCvry+qraSkBCUlJRgaGkJLS0tUm8PhQG1tLQCgpaUlpgCorq5GTk4Ouru70d3dHdXmdrtRXl6OYDAY0ydRFDFjxgwAw3vIRn/JV1ZWIi8vD319fTh9+nRUW35+vlrANjY2QpZlDA0Noa2tDaIoqp9NR0cHBgcHo17r8XhQWFiI/v5+nDp1KqotNzcXU6ZMGTPDadOmwW634/Tp0/D5fFFtpaWlKC4uxtDQEFpbW6PaJEnC1KlTAQDNzc3qsO3ZrqmpKaqQKCsrQ1FR0bjbiGwX2T4mu43gsha7rEW2EbIsJ3Xlm6aiIxQKYe7cufj5z3+Os846S2NXtZkzZ476/wsuuADr1q3DoUOHsHbtWrhcLgCAz+dTr5qJbPzz8vJ0v6coijErY+T+EzabLeGK6vF44lbKwPCGPScnJ6ot8oUoCELc6YqiCI/Hg0WLFuH5559Xq8jPf/7z6hdXbm5uzGtHVpqRL854fSouLobb7Y5qiyww422U4o0PEjnh1+12Iz8/P2ZeIu+daLoVFRUJM8zNzY073Xifm9/vVzcUZWVlY07X5XIlzDBefyM5lZSUoKioKG5bTk5OwulWVVXFTDeSYVFRUUzhHJlXh8ORMEOv1zvmvBYUFKjrzujpRpZvv9+P1tZWeL3eqGHQy8vLx5xuXl6e7gwjBUa8tvEyjBQ1/PU5vK6P/LwiGY63jch2kSyS3UZwWYtd1iKSvVeTpqLDbrejqqoqZneoEUbOkNvthtfrRUNDg/qrp6GhAZWVlRM6tAJgzPtNiKKY8F4UiXZX2my2MStAQRASTvcLX/gC/vCHP6C7uxtutxvLli1TV4ZE0wXGnhcAUVcFjTbevCZqs9vtY15BNJEME003XoYOhwN2u109ZDEWZjgskmGkqMnJyYnKLVXLd6IMJ/LZZBun0xk3j/EyzHaRokPv8p2NxlrWki1mNZ9IesMNN+C+++6L2f2rRygUgt/vRygUgizL8Pv96u6rI0eOwOfzQVEUHD9+HI8++igWLVqkvnblypXYs2cPOjo60NHRgYcffhirV6+ecJ/SjSRJuPbaa1FSUoJrr72Wx2KTJIoiXC4X75SqEXMjolTSfE7H448/jo8++gif/vSnUVVVFbO79mc/+1nS09q9ezd27dql/j137lzMnz8fjz/+OPbv34/bb78d4XAYHo8Ha9aswfXXX68+d8OGDeju7sbSpUsBDI/TsX79eq2zYwlz5sxBXV2det4KjS8UCqG3txeFhYUZN3ZLKjE3IkolzVuVyy+/fNLefOPGjdi4cWPctv379yd8rcPhQH19fdwTLTNNOBzGmTNnkJeXxy+CJDEzfZgbEaWS5q3KjTfemIp+EBERUYbT/VPmrbfewsmTJyEIAmbNmoVzzz13MvtFREREGUZz0XH69Gn827/9G/70pz+hsLAQiqKgr68PCxYswH/8x3/wxm9EREQUl+ai484774TP58Ozzz6rDgpy4sQJ3HLLLfjud7+L+++/f9I7me1EUURBQQGvKNCAmelj9dwCJlzOb5ZsmlfKHJqLjhdffBE/+clP1IIDGB6Vs76+PurqEpo8DocDFRUVZnfDUpiZPlbMbeSgTvecaE3wzMzFe+WQVWj+OSPLctwBfSL3m6DJF7nfBvNNHjPTh7kRUSpp3tNx0UUX4a677sJ9992n/iJqb2/H3XffjU9+8pOT3kGCer+NmpoajsKYJGamjxVzGzkS4pZZlZAsemhIq4Asq3t2OLQ5WYXmouP222/Hhg0b8LnPfQ5erxeCIKC1tRVnnXUWduzYkYo+EhElRRLFrCk6iKxIc9FRWVmJn/3sZ/jd736H999/H4qiYNasWfjUpz6Viv4RERFRhtB9l9mLL74YF198car6RSMcP34cTz75JK655hp84hOfMLs7REREumjaD2nmXWazVSAQwIEDB9Db24sDBw6oN8QjIiKyGlPvMkvjO3r0KHp7ewEAvb29eO6550zukTU4nU7MmjXLMidDpgvmRkSpZOpdZimxU6dO4bnnnlOvwVcUBc899xwuuugieDwek3tHRESkjal3maWxKYqCn/70p2M+vmnTJl4ml0AgEMCpU6fg8XggSZLZ3bGMY8eOqecP/cM//IPZ3SGDyOGg2V0wTDbNazrSfCIpAKxatQqVlZUp6RANa2trw9tvvx3zuCzLePvtt9HW1sbPIAFFUTA0NMSRGjUIBALYt28fBgYGsG/fPpx//vks2DLYyHXjw1/H/sDJBtw+GE/ziaQ/+tGPEA6HU9Uf+huv14tzzz035h4Yoihizpw58Hq9JvWMMtXhw4cxMDAAABgYGMCzzz5rco+IKNNoPrzyyU9+En/6059QXV2div7Q3wiCgDVr1qC+vj7u4zy0QpPp1KlTeP7556Mee/7553HxxRfz/KEMNXIbMm3hGoi22NtbZCI5HFT37HA7ajzNRcell16K+++/H3/5y18wZ84c5ObmRrV/7nOfm7TOZTuPx4PFixfj6NGjUBQFgiBg8eLFKC8vN7trlEEURcFjjz025uP/7//9P26cM5xoc0C0Z0fRQebSXHTccccdAICf/OQnMW2CIKChoWHCnaK/W7JkCV5++WV0d3fD7XZj8eLFZnfJEux2OyoqKmC3a17Es05raytOnDgRt+3EiRNobW1FVVWVwb0iokykeYv8zjvvpKIfNAZJknDttdfiv/7rv/ClL32JJ/YlyWazoaCgwOxuEBHRCLwzkgWcd9552LJlC8477zyzu2IZ4XAYPT09POk5CZWVlZg1a1bcto997GO8SoqIJk3SRce6devQ19en/r179251pEwA6OrqwtKlSye3dwRg+FLljo4O9ZJlGh8zS54gCFi2bFnctmXLlvF8DiKaNEkXHS+99FLUfT8effRR9PT0qH+Hw2F88MEHk9s7Iko5RVFw+PDhuG3PPPMMxzIgokmTdNExesPDDRFRZkjmRFIiosnAczqIiIjIEEkXHYIg8NiuSQRBgMvlYv4aMLPk8URSIjJK0pfMKoqCLVu2qJdsBgIB3HHHHergYCPP96DJJUkSx0nQiJklTxAE/Mu//Atuu+22uI+zcCOKFQhlzykGkzmvSRcdK1asiPr7yiuvjHnO1VdfPeEOUSxFUdQRSfkFkBxmpo3H48EVV1wRNRT6FVdcwdFviUYYeS7jPf/Tl+CZmWui53MmXXTcfffdE3oj0i8QCKCxsRE1NTVwOp1md8cSmJl2y5Ytw4svvoiBgQHk5eXhC1/4gtldIqIMwzGiiQjA8CGpL3/5y3jyySdxzTXXcPRbolFG7jXd8vkCSPbs2IsaCCnqnp2J7jlm0UFEqvPPPx9FRUWoqakxuyu6BGQFgGzoe0Z2Nxt9GG94Xskskl3ImqJjMrHoIKKMcc+JFrO7QEQJcJwOIiIiMgT3dFiAJEmYPn06RJE1YrKYmT5WzE2SJOzcudOU9/b7/airqwMAbN++HTk5Oab0g+ffkFWw6LAAQRBgs9nM7oalMDN9rJibIAhpcYVSTk5OWvSDKJ1Z5+dMFgsGg2htbUUwGDS7K5bBzPRhbvoxM6LxcU+HBciyjP7+fpSUlJjdFUMpiqJ7pNuhoSGcOXMGeXl5kGV9VzNIkpR1A4tl67I2GfQuZ0TZhEUHpSVFUbBjxw6cPHnStD7MnDkTdXV1WVd4EBGlCg+vEBERkSG4p4PSkiAIqKur03V4ZeQVBXfddRcKCgp09SEbD68QEaUSiw4LsNlsKCsrs9xVBRM1GVcl5Obm8ooCDbJ1WZsMzIxofCw6LMBut6OoqMjsbliS3c5FXAsua/pxWSMaH8/psIBwOAyfz4dwOGx2VyyHmWnDZU0/ZkY0PhYdFhAKhdDW1oZQKGR2VyyHmWnDZU0/ZkY0PlOLjn379mHlypU477zzsGHDhqi2YDCIbdu2Yf78+Zg/fz7uvPPOqJV6vHYiIiJKL6YWHR6PBxs2bMAXv/jFmLbdu3fj2LFjOHz4MA4fPoxXX30Ve/bsSbqdiIiI0oupRceiRYtw+eWXo7i4OKbt4MGDuOGGG+DxeODxeLB+/XocPHgw6XaibKQoCvx+v+5/Q0NDE3q9oihmR0BEaSwtT7fu6elBW1sbZs+erT42e/ZstLS0oK+vD7IsJ2zXOy4DMDzGw0iiKMLhcECW5bj3VohcjhkIBGI2uHa7HTabDeFwOObQjyAIkCRpzKG+I2NEBINBBAIB2Gw29Xk2mw12uz3hdOPNCwA4HA6IoohgMBgzbHNkuuPNa6LphkKhmBPqJiPDRNMdneHI/gmCoPuzGW9etWaY7HT1ZqgoCu6991588MEHMe1GmTFjBm666SaIopj08j1WhmYt3/GWl7E+m5F9iBR8WqY7WdsIvRlGyGHjD01HsjB6LJyR8xrpQ7KfTbzPN9uMziCyHCqKktRnmZZFx8DAAABEFQ+FhYUAgP7+fnXhGKtdb9EhyzIaGxujHisoKEBFRQXC4XBMGwDMmjULAHDq1CkMDQ1FtVVUVKCgoAA+nw8dHR1RbS6XC1VVVVAUJe50p0+fDpvNhs7OTvT39wMA2tvbAQBlZWUoKirC4OAg2traol7ndDpRU1MDAGhqaopZkaZOnQpJktDV1YXe3t6otuLiYpSWlsLv96O5uTmqzW63Y9q0aQCA1tbWmA3ZlClTkJubi56eHnR1dUW1FRYWwuPxIBQKxcyrIAiYOXOmOn+jF2iv14v8/Hz4fD50dnZGteXl5aGysjLmcxu5gZYkCZ2dneoyFVFeXg63242BgQE114icnBxUV1cDQNzPpra2FqIo4syZM+jr64tqKykpQUlJCYaGhtDS0hLV5nA4UFtbCwBoaWmJKSyqq6uRk5OD7u5udHd3R7W53W6Ul5cjGAzG9EkURcyYMQOA+Tcd8/v9aGxshMvlwpQpUwDEz3DatGmw2+04ffo0fD5fVFtpaSmKi4sxNDSE1tbWqDZJkjB16lQAQHNzc8yXbU1NDZxOJ7q7u9HT0xPVVlRUhLKyMgQCATQ1NUW1iaKo9vevf/1rTI6VlZVwuVzo6urCmTNn1MdHPi8UCsUdtj+yfDc3N8dsIzweDwoKCjA4OBizfOvZRkQku42I+PDXT8RMPxtEto/JbiP03gsqkzQ1NUUVrZHlW5blpMaqScuiw+VyAQB8Pp9646nIxn3kDbzGatdLFMWYlVEUh49A2Wy2mLaRPB5P3EoZAPLz85GTkxPVFqkIBUGIO93I+5aVlcXcfCvywebm5sa8dmSlGfnijNen4uJiuN3uuNONt1EaqbKyMuYxh8MBYPjLMT8/P+682O32hNOtqKhImGFubm7c6Y7+3EYXLmVlZWNO1+VyJcwwXn8jOZWUlMSMaRFpy8nJSTjdqqqqmOlGMiwqKoopnCPz6nA4xsxQEARs3rw5Zv6T3Vvk8/mwdetWAMMjuUqSpP6KSfaXYOT5yWYYKTDitY2XYaRIGGlkhpEfIqOnK0lS1HQVRcEDDzww4T1E3/rWt3S/dubMmdi0aVPU/Bmxjch2kSyS3UZwT8fw90q8ARcjy+N40rLocLvd8Hq9aGhoUH/VNDQ0oLKyUt0Yj9eu11ijV4qimHBky9G7K0ey2WxjVoDjjbrpcDjg9/vR1NQU82Enmi4w9rxEpjuW8eY1UZvdbofdbo/aJSzLcsKVNVFbKBQa86qk8aYLYMzDbYmmO9Zu8ohEexPC4bD6xZ5oGPVkMownmc9mrPbxRmYd2VdJkqK+tPWO6prM8j0Wo5ZvRVGS3mCmktPpjLu8pCpDSZKwc+dO7R2dBJN1q4KJimy39W6/s9FY25hki1lTi47IL69QKKR+gUSON65cuRJ79uzBhRdeCAB4+OGHsXr1avW147VnGqudoBcIBLBp0yazu6H+cjfDzp07OQS7BUzkPj8AMDQ0hKamJvXQjh5m3OdnMm4zMBkkSUqLfpAxTC06du/ejV27dql/z507F/Pnz8fjjz+ODRs2oLu7G0uXLgUALF++HOvXr1efO147EVGyJvoFHPn1xy9PosRMLTo2btyIjRs3xm1zOByor69HfX29rnZKH3feeSUkydhFzawz4wOBEG677ReGvicRkVWk5TkdlFkkyQ6nk4saEWWOQNj4Q96m/ZiaxHnlN4EFOBwOTJ06lXexJMMkOjmRonH9nBirLmv3/LJv/CdRDK4lFhAZaInIKOlwNYdVcP2cGC5r2YVFhwUEg0F0dXWhuLjYsr8KyFqCwSBPikwS18+JsdKyli6XGX/ve9+LGQ/JKBMtsFl0WIAsy+jt7Y0ZzIsoVUaP9Elj4/o5MVZa1tLlMmOHw5EW/dCD+7WIiIjIECw6iIiIyBA8vGKAse4SmayRtxvXw4zRDomIiEZj0ZFiiqJgx44dce8+aZSZM2eirq6OhQcljfeaSJ7NZkNxcTEz04m5aWflzFh0EFEMjjmRPLvdjtLSUrO7YVlc1rSzcmbW7bmBJnp4ZNOmTbpfHwgE1JuW3XnnncjJydE8DUmSJtT/yDS4pyR7WOmKArNFblbpdDo55oQOXNa0s3JmLDqSkC53TL3ttttMe2/eMTW7BINB5Obmmt0NSwgGg2hubp7QXWazGZc17aycGctyIiIiMgT3dGg058urIBp8PM2sm/zIoRD+vP+goe9JRNYwkcPOI6/ECwQCuq7M4yFfa2LRoZFot8PmYGxElL0m86q8yDlrWvGqPGvi4RUiogmy8tUEREbimkJEMXhCZPKcTiemTZtmdjcMJQgC6urqJnRV3EQPG2fz4RUrr58sOoiISLN0ufkZWQsPrxBRDL1D7mcjv9+PDz/8kJlpxNz0s3JmLDqIiCYoFAqZ3QVLYm7Zh0UHERERGYJFBxERERmCRQcREREZglevUMoFAtlz3DZT5tXhcJjdBctwOByYMmUKM9MoW3PTO5LryJNHIzcZ1MPsS41ZdFBKRK7BB4DbbvuFiT0xz8gMrIZ3S02eKIqWvfmWmbIxt8kayfWWW27R/VqzR3LlloWIYvCqguSFQiGcPn2amWnE3LIT93RQSoysou+880pIUnYsaoFASN2zY+XREsPhsNldsIxwOIyuri7k5+dzOHQNsjG3iY7kOjQ0hKamJtTU1OgemI2HVyjjSZIdTicXNSKiiY7k6nQ61X9WxMMrREREZAgWHURERGQI7vMmSiN6L6ebDCMvwQsGg6bd38HsY85aiaKIwsJCXvGjEXPTLhMyY9FBlEYCgQA2bdpkdjfwrW99y7T33rlzp6WOVzscDng8HrO7YTnMTbtMyMy65RIRURqQZRmBQACyLJvdFUthbtplQmbc00GUplZd/TXY7caO1hgZ0MzowxuhUBAHf/6Ioe85WYLBIBobGyd0GWM2Ym7aZUJmLDo0koPZM5BNNs1rOrLbHYYXHUREqcSiIwkjh7P+8xMHTeyJeaw8pDcREaUHntNBREREhuCejiSMPL4959pVEB3ZEZscDKl7dqx0CSOR0bh+6MPctLN6Ztnx7TmJRIcdtiwpOohofE6nEzNnzjS7G5bD3LTLhMx4eIWIiIgMwaKDiGgCAoEAGhsbTRtJ1qqYm3aZkBmPE2gkh4y/jNSssRPMmFciq1EUBX6/n1d4acTctMuEzFh0aPTn/dl5ySwREdFEseggSlOhUNDsLhgmm+aVKJux6EiCJEnYuXOnKe/t9/tRV1cHALjrrrtQUFBgSj8kSTLlfbPNyN2mVh0WfKKsvOuYiBJL66Jjy5YtOHz4MByOvw8F/eMf/xjz5s0DMDwO/d13343Dhw8DAJYvX45bb70VdvvkzpYgCGkxzr3L5UqLfhDR39ntdni93knf7mQ65qZdJmSW9j1fs2YNtm7dGrdt9+7dOHbsmFp0rFu3Dnv27MGNN95oZBcNY7PZzO4CpdjIk4XNuOGbWUbe8M1qgx/ZbDbk5+eb3Q3LYW7aZUJmaV90JHLw4EHceuut8Hg8AID169dj+/btEyo6/H5/1N+iKMLhcECWZQSDscedI3seAoFAzG5hu90Om82GcDiM0KgrQQRBgCRJUBQl7uVPkiRBEISo9+zv7wcwvODZ7faE0403LwDgcDggiiKCwWDM7ZEj0x1vXhNNNxQKIRwOx31OthmdQTKfzUjZesO3UCgEp9Np2vIdb10evXyPJMsy/H4/XC5X3ENDRmwjxprXdN5GhEIhDAwMwOVyQZKkCW9n4302ke33eBnq/WzGm1etGY43XUEQMDAwgJycnJjifDK+qyaSoaIoSf1gSPui49ChQzh06BDKy8uxatUqrF27FqIooqenB21tbZg9e7b63NmzZ6OlpQV9fX26zn2QZRmNjY1RjxUUFKCiogLhcDimDQBmzZoFADh16hSGhoai2ioqKlBQUACfz4eOjo6oNpfLhaqqKiiKEne606dPh81mw+nTp9XHWltb4XQ6UVZWhqKiIgwODqKtrS3qdU6nEzU1NQCApqammIVr6tSpkCQJXV1d6O3tjWorLi5GaWkp/H4/mpubo9rsdjumTZum9mP0SjhlyhTk5uaip6cHXV1dlr6OfLI0NTVFnQvjcDhQW1sLAGhpaYlZuaurqy33Kz8VfD4f8vLyMDQ0hNbW1qg2SZIwdepUAEBzc3PMBj1yy+/u7m709PREtRUVFaGsrAyBQABNTU1RbTabDdOnTwcwvHyP3mhXVVXB5XKht7cXZ86ciWrLzc3F4OAgvF5vzPoIpH4b0dnZqf4gibDCNkKWZQwODiI3NxdFRUXweDwIhUIx8yoIgjoKZ3t7e8yXsdfrRX5+Pnw+Hzo7O6Pa8vLyUFlZGXfbDgAzZsyAIAjo7OzEwMBAVFt5eTncbjcGBgbQ3t4e1ZaTk4Pq6moAiDvd2tpaiKKIM2fOoK+vL6qtpKQEJSUlGBoaQktLS1TbeNsIj8eDzs5O5OXlxXzmbrcb5eXlCAaDMX0SRREzZswAALS1tcVsnysrK5GXl4e+vr6o7xwAyM/Ph9frHfM7MPLZyLKc1N74tC46rrvuOmzevBlutxvHjx/HzTffDFEUsXbtWnUBGVlcFBYWAhjeI6Cn6BBFUV0ZRz4GDG+URreN5PF44laPwPCHlpOTE9UW+XIRBCHudCPvW1paqj4W2UBFPtjc3NyY14780oqsFPH6VFxcDLfbHdUWme7IjVI8lZWVMY9FfqW73W7k5+dzTweG8x95Ds7Iz6aqqirm+Q6HI+4vlGwT2X2ck5OTcPmeMmVKzGsjy2FRUZG6PYiILN+SJI27fMfb0wEMb2Py8vKi2kKhEAYHB03bRpSVlaGkpCSqzSrbiNbWVni9XuTm5qrvnWi6FRUVCTOMTCciklG8bTvw9yzKysrGnK7L5UqYYbzpRnIqKSlBUVFR3Lbxlu9424hIkV1YWBjzmUfm1eFwJMzQ6/WOOa8FBQVwuVxxpzve8h153njSuuiYM2eO+v8LLrgA69atw6FDh7B27Vo1GJ/Pp4YfqShHbxS0GOtETVEUE57EmejqDpvNNmYFON5JqiN3uUuSFPXcRNMFxp6X0dMdbbx5TdRmt9stfZLTZHI6nWNmxROCxxZZfsxavhOty4mW73TYRmiZLmD+NsJms8HpdKrvlarPZrwM9X42gLEZRn7M2e32lHxXTSTDZPfSWmoY9JGVlNvthtfrRUNDg/pYQ0MDKisrTbuslIiIiMaW1kXHkSNH4PP5oCgKjh8/jkcffRSLFi1S21euXIk9e/ago6MDHR0dePjhh7F69WoTe5xaye6+IiLjiKKIvLw8rp8aMTftMiGztN4Pvn//ftx+++0Ih8PweDxYs2YNrr/+erV9w4YN6O7uxtKlSwEMj9Oxfv16s7qbcol21RGRORwOR9xzGCgx5qZdJmSW9kVHIg6HA/X19aivrzeoR+biSI1E6UdRFMiyDFEUefWRBsxNu0zIzLr7aLIQL0MlSj+BQAAffPAB10+NmJt2mZAZiw4iIiIyRFofXskUY43kloyR410EAgFd419ERowjIiIyE4uOFFMUBTt27MDJkycnPK2x7kEznpkzZ6Kuro6FBxERmYpFB1GaCoWMH500crKy0QWqGfNKRMZj0ZFigiCgrq5uQif+yLIMRVF0n7Fs9uGVQCA0/pMmmVlfnpM5r5G7rlJ6kyRJvYcHJY+5aZcJmbHoMMB4w8dmuttu+4XZXSBKGUEQLP0lYBbmpl0mZMaiwwICgQA6OztRVlaWcNx8sj5JkrBz505T3tvv96Ourg4AcNddd5l2OwGrLeNcP/VhbtplQmYsOixAURQMDAxYanAwfnnq+/JMl71io28uSGOz4vqZDpibdpmQGYsOSgl+eRIR0WgcHIyIiIgMwaKDiIiIDMGiwwLsdjvKy8tht/NomFbMTB/mljyun/owN+0yITPr9jyL2Gw2uN1us7thSTabzewuWBJzSx7XT32Ym3aZkBmLDgsIh8MYGBiAy+XKqi8DvfesGXl/moGBAd3vb/agamYKh8Nmd8EysnX9nCjmpl0mZMaiwwJCoRDa29tRU1Nj2QVNq8m6Z82WLVt0vzab71kTChk/iqxVZeP6ORmYm3aZkBnP6SAiIiJDcE8HpaWJ3rNmaGgITU1NqKmp0T1ORzYfXiEiSgUWHZS2JjrAmNPpVP9lC73nwQDR58IEAoGov5PFQo2IEmHRYQGCICAnJ4cbcw2yMbPJOg8GALZu3arrddl4Hkw2LmuTgblplwmZseiwAEmSUF1dbXY3LIWZkVG4rOnD3LTLhMxYdBBliImeBwNAvZGU3l9SPLxCRImw6LAAv9+PxsbGCZ0UmW2yNbOJngeTrblNBDPTh7lplwmZ8ZJZIiIiMgSLDiIiIjIEiw4iIiIyBIsOIiIiMgRPJLUAh8OB2tpay461bwZmpg9z046Z6cPctMuEzFh0WIAoihBF7pTSgpnpw9y0Y2b6MDftMiEza/c+SwSDQbS3tyMYDJrdFctgZvowN+2YmT7MTbtMyIxFhwXIsoy+vj7Ismx2VyyDmenD3LRjZvowN+0yITMWHURERGQIFh1ERERkCEGJ3Gwhy7322mtQFAWSJJndlRiKoiAUCsFut/O+FkliZvowN+2YmT7MTbt0ziwQCEAQBFx44YUJn8erV/4m3T7AkQRBgMPhMLsblsLM9GFu2jEzfZibdumcmSAISX2Pck8HERERGYLndBAREZEhWHQQERGRIVh0EBERkSFYdBAREZEhWHQQERGRIVh0EBERkSFYdBAREZEhWHQQERGRIVh0EBERkSFYdBAREZEhWHQQERGRIVh0TFBrays2bNiAyy+/HEuXLsU3v/lNtLa24uabb8by5cuxdOlSfPWrXwUANDU1YeXKlVGvb2xsxOWXXx71WCAQwKc+9Sn09fUBANasWYObbrop6jnXXXcdFi9ejKuuugpXXXUVvve978X07aOPPsLVV1+tPueFF15Q2xYsWKD+/+c//zlWrlypvp8R0jm3iFOnTuHCCy/Evn371MfMzC2dM2tqasLHP/5x9Tnf//731Tazl7XxtLW1YePGjfjc5z6HlStXYu3atXjzzTfx4IMP4tJLL8VVV12FJUuW4PDhw+prrrvuOrz33nvq33/84x+xadOmmGn7fD6sWrUKV111FZYvX44DBw6obQsXLkR/fz8A4OWXX8YVV1yB1tbWFM7p5EllZhGDg4O47LLLcO+996qPWTkzIPW5nXvuueo6uHXrVvXxdMqNd5mdAEVR8I1vfAP//M//jIceeggA8NJLL+HQoUOYPn06HnjgAQDAu+++O+Y0ampq4Ha7cfz4cZx//vnqND7+8Y+joKAA7e3t6O7uRmtrKwYGBuByudTX7ty5E2edddaY066srMSBAwcgSRLOnDmDq6++GgsXLoy6E+Avf/lL/OhHP8Jjjz2GgoKCicSRtHTPLeK+++7DxRdfHLfN6NyskNnMmTPx9NNPj9luxrI2HkVRsGHDBlx77bV48MEHAQANDQ14//33AQBf+9rX8JWvfAXvv/8+Vq1ahSuuuELTXT5zc3Oxb98+5ObmYnBwEMuWLcPnP/95FBcXq8957bXXUF9fjx/+8IeorKyc3BlMgVRnFrFnzx7MnTs3bpvVMgOMya2goACHDh0asz0dcuOejgn4/e9/j7y8PFx99dXqY5dccgk6OztRUlKiPnb22WcnnM7SpUvx3HPPqX8/99xzWLJkCQDg6NGjWLJkCS655BL89re/1dQ/SZIgSRIAYGBgALIsR7W/+OKLuP/++/HDH/4wqr+plu65AcArr7yC/Pz8uF+0ZuRmhcwSMWtZG8/LL7+MvLw8rF69Wn1s9uzZ+MIXvhD1vBkzZsDlcqGnp0fT9G02G3JzcwEAfr8fsixj5I29GxoasHnzZuzatQu1tbUTmBPjpDozAPjwww/x/vvv4zOf+UxMmxUzA4zJLZF0yY1FxwScOHECs2fPjnl8xYoV2LVrF9asWYNdu3aNuxtryZIleP755wEM7+7+3e9+h4ULFwL4+xfB4sWLceTIkajXbdq0Sd2Vtnfv3jH7uHz5cixfvhx33HGHupejv78fdXV1eOSRR1BRUaF11ick3XMLhULYuXMnNm7cGNNmVm7pnhkAfPDBB7j66qvxr//6r3jnnXfUx81c1sZz8uTJuLmO9uabb6K6uhplZWWa36O3txdXXnklPvOZz+CrX/1qVNG1YcMGbN++fdxiMZ0Ykdm9996Lf//3f4/bZsXMAGNy6+/vx8qVK7FmzRr86U9/impLl9x4eGUCFEWJOlQRMWfOHLzwwgv4v//7P/zmN7/BihUr8Oyzz445naqqKpSWluL48ePo6OjAvHnzkJ+fj5aWFgwMDOBjH/sYpk+fjq1bt8Ln8yE/Px9Acru8Z82ahWeeeQYfffQRbrnlFnz605+G0+lEbm4uzj77bDzzzDP4xje+MbEgNEr33Pbv34/FixejqKgops2s3NI9M4/Hg9/85jcoKirCH/7wB9x0001qcWPmsjae0blu2rQJJ06cwIUXXoiKigo88sgjeOKJJ/Dhhx9iz549ut6jsLAQv/jFL9DZ2Ykbb7wRV1xxhfqFctFFF+Gpp57ChRdeOCnzY4RUZ/arX/0K06ZNw/Tp0/H666/HtFsxM8CYZe2FF15ARUUF3nvvPXz961/HM888o67D6ZIb93RMwKxZs/D222/HbcvPz8fSpUuxY8cOzJ07F6+88kpU++bNm3HVVVdh8+bNAIZ/gR49ehRHjx7F0qVLAQz/8mxtbcXChQuxaNEi9Pb24te//vWY/WlqalJ/jY7chQ4AtbW1yM/PV4/5i6KIH/zgB3j++edx8OBB3Rnoke65vfnmm/jhD3+IhQsX4rHHHsODDz6Ip556CoB5uaV7ZpIkqUXaRRddBFEUcebMGQDmLmvjmTVrFhoaGtS/d+7cifr6evT29gIYPs5+5MgR7Ny5E1u3boXf7wcAFBcXq88BgJ6eHhQXFyMQCKi5/Od//mfUe5WVleHss8+O+nzuvPNOtLa2qsf4rSDVmb3xxhs4cuQIFi5ciHvvvRcHDhzArl271NdZMTPAmGUtsifxrLPOwsyZM/HBBx+or0ub3BTSTZZl5eqrr1Z+/vOfq4+98MILyquvvqr09PQoiqIo/f39ypIlS5Q33nhDaWxsVFasWBF3Wq2trcpll12mXHzxxUp/f7+iKIqycuVKpaGhQX3Oiy++qKxfv15RFEX5yle+orz77rsJ+9fS0qL4/X5FURSlra1NufTSS5XTp08riqIo8+fPVx9fuHCh8r//+796ItAl3XMbaefOncrjjz+u/m1Wbume2enTp5VQKKQoiqI0NDQol112mSLLsqIo5i5r45FlWVmxYoXy9NNPq4/99re/VTZu3Bjz2X/ta19TnnzySUVRFOWxxx5TbrvtNkVRFCUcDisbN25UfvGLX8RMv6OjQ+nr61MURVH6+vqUpUuXqjlfdtllis/nU/r6+pQrr7xSOXDgQMrmczKlOrORDh48qNxzzz3q31bNTFFSn1t3d7e6vW9tbVU++9nPKl1dXYqipFduPLwyAYIg4Ac/+AG2bduGXbt2QZIknHvuubj44otxxx13AABkWcaKFSswd+5cNDU1jTktr9cLr9eLsrIyuFwuNDY2oru7G+ecc476nAULFuCWW25RLzfctGkTnE4ngOETCLdv3x41zXfffRf33XcfRFGEIAj41re+FXMSX0VFBXbv3o1169bhoYcewpw5cyYjmoTSPbdkGJ1bumf2yiuvYOfOnbDZbHA6ndi+fXvM4SAzlrXxRHL97ne/iwcffBDl5eUoKCjADTfcgJdffjnqud/4xjdw66234p/+6Z/wpS99Cd/97ndx5ZVXQlEUXHLJJTEnBALDl0hu3boViqJAURR8+ctfjsoZGN5T9cgjj+Daa6+Fx+OJe/JkOkl1ZsmwWmZA6nM7efIk6uvrIQgCBEHA1q1bYw4Rp0NugqKMOJWaiIiIKEV4TgcREREZgkUHERERGYJFBxERERmCRQcREREZgkUHERERGYJFBxERERmCRQcREREZgkUHERERGYJFBxERERmCRQcREREZgkUHERERGeL/A2UrInvnswC4AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model_names = [\"CSI-VAE-3K\", \"CSI-VAE-4K\", \"CSI-VAE-5K\", \"GRU-3K\", \"GRU-4K\", \"GRU-5K\"]\n",
    "\n",
    "B, T, N = spotify_n_matrix.shape\n",
    "data_reshaped = spotify_n_matrix.reshape(B, -1).T\n",
    "# Create a box plot for each model\n",
    "plt.figure(figsize=(6, 4))\n",
    "sns.set(style=\"whitegrid\")\n",
    "sns.boxplot(data=data_reshaped, palette=\"Set3\")\n",
    "# plt.xlabel('Training Data Size', fontsize=10)\n",
    "plt.ylabel('Error (MSE)', fontsize=10)\n",
    "# plt.title('Box Plot of Results for Each Model', fontsize=8)\n",
    "plt.xticks(ticks=range(B), labels=model_names, fontsize=7)\n",
    "plt.yticks(fontsize=9)\n",
    "plt.grid(True, linestyle='--', alpha=0.7)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "9908b88e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "create matrix of shape (6, 5, 5)\n",
      "Synthetic mean average results is \n",
      " [[2.408 2.898 2.954 2.97  2.976]\n",
      " [3.64  4.7   4.984 5.176 5.392]\n",
      " [3.676 5.15  4.91  4.74  4.624]\n",
      " [1.79  2.19  1.978 1.758 1.53 ]\n",
      " [1.78  2.242 2.002 1.778 1.564]\n",
      " [1.642 1.914 1.904 1.732 1.702]]\n"
     ]
    }
   ],
   "source": [
    "spotify_median = '''\n",
    "2.38\t2.82\t2.9\t2.95\t2.97\t2.68\t3.27\t3.28\t3.26\t3.25\t2.15\t2.54\t2.58\t2.64\t2.64\t2.26\t2.72\t2.76\t2.73\t2.7\t2.57\t3.14\t3.25\t3.27\t3.32\n",
    "2.73\t3.48\t3.45\t3.42\t3.38\t3.33\t4.37\t4.42\t4.32\t4.35\t3.38\t4.3\t4.56\t4.71\t4.69\t4.58\t6.19\t6.78\t7.29\t8.08\t4.18\t5.16\t5.71\t6.14\t6.46\n",
    "3.62\t4.87\t4.69\t4.55\t4.36\t3.98\t5.83\t5.61\t5.46\t5.28\t3.5\t5.03\t4.73\t4.56\t4.46\t3.88\t5.48\t5.2\t5.01\t4.9\t3.4\t4.54\t4.32\t4.12\t4.12\n",
    "1.76\t2.01\t1.84\t1.68\t1.52\t1.98\t2.59\t2.3\t2.02\t1.7\t1.76\t2.24\t2\t1.73\t1.47\t1.76\t2.1\t1.96\t1.7\t1.48\t1.69\t2.01\t1.79\t1.66\t1.48\n",
    "1.84\t2.27\t2.05\t1.85\t1.62\t1.9\t2.31\t2.06\t1.8\t1.58\t1.72\t2.22\t2\t1.7\t1.52\t1.77\t2.26\t2.03\t1.85\t1.61\t1.67\t2.15\t1.87\t1.69\t1.49\n",
    "1.66\t1.92\t1.9\t1.74\t1.74\t1.74\t2.07\t2.04\t1.83\t1.81\t1.51\t1.77\t1.83\t1.64\t1.64\t1.71\t2\t1.98\t1.8\t1.76\t1.59\t1.81\t1.77\t1.65\t1.56\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\t\n",
    "'''\n",
    "\n",
    "spotify_median_matrix = process_data(spotify_median)\n",
    "print(f'create matrix of shape {spotify_median_matrix.shape}')\n",
    "print(f'Synthetic mean average results is \\n {np.mean(spotify_median_matrix, axis=-1)}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "cc122630",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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L36Bj370o7jsssugKAp6enrw5JNP4sknn0ztyK266667UFxcjOOPPx6/+c1vVnnp1o6TuT399NN44okncNZZZ2Hjxo1QVRWPPfYYLr/8cnz605/Gpz71qTVY4pVzMjNVVaHrOj72sY+hsbERoijij3/8I77zne/gmWeewc6dO1d/gW246667cO2116KtrQ0f/ehH8ZrXvAYA8PLLL+NnP/sZzj33XPziF79Ac3Nz6jXf+973UFpairm5OTz11FO47bbb8Nxzz+HBBx9ckycNxmIxXHDBBZiensa2bdtQWVmJO+64AxdddBFuu+02vPGNb1z191yOG3J75ZVX8PDDD+OII47A2972NvzsZz9b9fewwg2Z3XLLLaiqqsInPvEJNDU1YWBgAN/97ndx9tln4+67706NeU3olGbPnj36EUccoV944YV6NBpNa49Go/ovf/lL/dVXX9U7Ozv1b3zjGxn7SSQSqf/u6enROzs79e9973umxrDwte95z3v0j3zkIxaXIveczm1sbEzXNC3t51u3btVf97rXZRyT05zObCk33HCD3tnZqb/66qu2+1gtu3fv1g8//HD9kksuWXIdPvroo/rg4KCu67q+Y8cOvbOzUx8bGzP8zpVXXql3dnbqv//97w0/7+zs1Ldv356x38cee0zv7OzU//CHPyw7zh/96Ed6Z2envmfPntTP4vG4ftppp+nnnnvusq9fbW7JbeHc3bt3r97Z2anfd999y75uLbgls9HR0bSfDQ4O6kcddZT+hS98YdnXrwTPacjgu9/9LgRBwLXXXgtFUdLaFUXBySefjMnJSQBIOwSVJIr2413Ja53idG7BYDDj8+A3btyI+fn51PvmE6czW0owGAQASJK0qv3a8d3vfheSJOGaa67JmBEAvPvd70ZtbW3Wfl772tcCOPQVwlr45S9/iba2NmzatCn1M1mWceaZZ2Lv3r0YGhpak/ddiltyy6d9nVsyq6ysTPtZbW0tamtrMTg4uCbvmcSvJxZJJBL4wx/+gKOOOgp1dXVZf3fDhg0oKyvDt7/9bYiiiBNOOAGNjY05Gml+yefcdu3ahWAwmHFDc1I+ZabrOhKJBCKRCPbs2YPbbrsNp59+Ourr61ftPexIJBLYtWsXXvva16KmpmZFffX29gLAmn3n+/e//x1veMMb0n5+2GGHpdqX+7BZLW7KLV+4PbOenh709/fjlFNOWdP3YdGwyMTEBObn503tkIuLi/HVr34V//Zv/5Y6sSUQCOD444/HWWedhZNOOmmth5s38jW3e+65B8888wy2bduWF381L5RPmT366KP4l3/5l9S/zznnHFx77bUr6nM1TExMIBKJZCxeEokEdF1P/VuSJMORJk3ToKoq5ubm8PTTT+Ouu+7C6aefjqOOOmpNxjo5OYny8vK0nyd/lssjXW7KLV+4OTNVVfGFL3wBxcXFuOCCC9b0vVg0rNDb3vY2PPHEE3jqqafw7LPPYt++ffjVr36Fxx9/fMmzZJNUVTX8e/FELGS5yO23v/0ttm/fjne96104//zzV30Zcm0tMzvxxBNx7733YnZ2Fn/6059wyy23YHJyMnVkIx+dc8452L9/f+rfi68WOeGEEwy/f9xxx+H6669f0Xsmj8gsJMv/2I1m237zZdvOx9zyXT5npus6tm3bhmeffRY7duxY9qjlSrlnreVIRUUFioqKUoeXzPD5fDjllFNSh4X6+/tx8cUX44477sB555235Jmsi6tQpy8zWol8y+3JJ5/Epz/9aZxwwgn46le/mjc77IXyKbPy8vLUZWTHH388mpub8dnPfha/+tWvbF8BtBoqKirg8/nQ39+f1va1r30N8/PzGBkZwSc/+cm09p07d6KkpARTU1O4++678T//8z+49tprcc011xh+T5KktJ1zUvLnyZ31Aw88gM9//vOG3/nrX/8K4NCRn0xHE6ampgAg41GIteKm3PKFGzNLFgw//elPcf3116/5VxMAi4Y0kiTh+OOPx5NPPonBwUGEQiHLfdTX1+P9738//uM//gN///vfl9yR33vvvYZ/u/l8iHzK7cknn8Sll16K4447Dt/85jeXPKHJafmU2WLJAuLgwYOWx7Sakhk9/fTTGB4eNnzX3NHRAQBLFl2HHXZY6oTOE044ARdeeCHuvvtunHvuuTj66KNTv1dZWbnkSYrJn1dVVQEA3vGOd6RlmdTZ2Ym//e1vaT9P/mxNL4NbxE255Qu3ZZYsGO6//35cd911OOussywsrX35edzRYZdccgl0Xce///u/IxaLpbXH43H8+te/RjgcxuzsbMY+Dhw4AABZT6jZuHGj4X8VFRWrswAOyYfcnnrqKVx66aV4wxvegO985zt5WzAk5UNmmezatQsA0NLSYnZR1szWrVuRSCRw9dVXIx6P2+pDEARcddVVkCQJ3/jGNwxtb37zm7Fr1y6Mj48bfq7rOh5//HE0NDSkcqioqEjLMumUU07Byy+/jD//+c+pn6mqip/+9Kd43etel7OTIJPckls+cUtmyX3G/fffj2uuuQZbtmyxNVY7eKQhg02bNuFLX/oStm/fji1btuCDH/wgXvOa10BVVbzwwgupm2dUV1fjoosuwmmnnYbjjjsONTU1mJqawm9/+1v85Cc/wRvf+Ea8/vWvtzWGffv2oa+vDwAQDodTkwo49AHQ0NCwasu7WpzObffu3bj00ktRVVWFSy65BC+++KKhvaOjAyUlJau1uKvC6czuuusu7N69GyeeeCJCoRDm5+exe/du/OhHP8KmTZtw8sknr8FSW/OGN7wBV111Fb785S/jnHPOwfvf/350dHRAFEWMjIzg5z//OQAsu25bW1vx/ve/H3feeSd2796NY489FgBw6aWX4je/+Q3e9773YevWrWhpacHo6Cjuvvtu7Nu3D1//+tdNjfPcc8/FnXfeicsvvxyf+9znUFlZiTvvvBMHDx7EbbfdtqIM7HBLbgBS+7aenh4AwPPPP5+6G2ku7+bqlsy+/OUv495778WWLVvQ2dmJP/3pT6k2RVFw5JFH2lp+MwR94SmhZLB//37s3LkzdWtfj8eD1tZWvOMd78BHPvIRyLKMO+64A3/4wx9w8OBBjI+Pw+PxoKWlBe9617vwsY99DD6fD4D120hfeeWVeOCBBzK25fu5D07ltviWrouZvRWwE5zKbM+ePbj55pvxl7/8BRMTE5Bl2dBnUVFRLhbflOSttpO39hUEAaFQCJs2bcJ73/ve1K2ak/Pg97//feqQcdLY2BhOOeUUbNy4ET/84Q9TP3/llVdSr5mYmEBxcTGOPvpoXHTRRZZuAT06Ooru7m488cQTmJ+fxxFHHIHLL78cb37zm1cnBBvckFvystRMnDj3Id8zO+mkk1J/VC7W0NCAX//61zaXfHksGoiIiMgUntNAREREprBoICIiIlNYNBAREZEpLBqIiIjIFBYNREREZAqLBiIiIjKFRQMRERGZwqKBiIiITGHRQERERKawaCAiIiJTWDQQERGRKSwaiIiIyJT/By8+I0DFwb/+AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model_names = [\"CSI-1\", \"CSI-2\", \"CSI-3\", \"GRU-0\", \"GRU-1\", \"GRU-2\"]\n",
    "\n",
    "custom_palette = {\n",
    "    'CSI-1': sns.color_palette(\"Set3\")[0],\n",
    "    'CSI-2': sns.color_palette(\"Set3\")[1],\n",
    "    'CSI-3': sns.color_palette(\"Set3\")[2],\n",
    "    'GRU-0': sns.color_palette(\"Set3\")[3],\n",
    "    'GRU-1': sns.color_palette(\"Set3\")[4],\n",
    "    'GRU-2': sns.color_palette(\"Set3\")[5]\n",
    "}\n",
    "\n",
    "color_list = [custom_palette[model] for model in model_names]\n",
    "\n",
    "B, T, N = spotify_median_matrix.shape\n",
    "data_reshaped = spotify_median_matrix.reshape(B, -1).T\n",
    "# Create a box plot for each model\n",
    "plt.figure(figsize=(6, 4))\n",
    "sns.set(style=\"whitegrid\")\n",
    "sns.boxplot(data=data_reshaped, palette=color_list)\n",
    "# plt.xlabel('Models', fontsize=10)\n",
    "plt.ylabel('Error (MSE)', fontsize=10)\n",
    "# plt.title('Box Plot of Results for Each Model', fontsize=8)\n",
    "plt.xticks(ticks=range(B), labels=model_names, fontsize=12)\n",
    "plt.yticks(fontsize=9)\n",
    "plt.grid(True, linestyle='--', alpha=0.7)\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
