{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Load mean, fit kernel on the residuals\n",
    "advantage: regularize independently"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[INFO] running on GPU core 3\n"
     ]
    }
   ],
   "source": [
    "# restart kernel\n",
    "from IPython.core.display import HTML\n",
    "HTML(\"<script>Jupyter.notebook.kernel.restart()</script>\")\n",
    "\n",
    "import math, random, pickle, os, copy, itertools, sys, gpytorch\n",
    "import torch, logging, scipy.io\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "from numpy import random\n",
    "from datetime import datetime\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "from collections.abc import Iterable\n",
    "%matplotlib inline\n",
    "\n",
    "BASE_DIR = os.path.dirname(os.path.dirname(os.getcwd()))\n",
    "sys.path.insert(1, BASE_DIR)\n",
    "\n",
    "import config\n",
    "config.init()\n",
    "from config import device\n",
    "from utils_pv import visualize_env\n",
    "from utils.analyze_results import *\n",
    "from utils.assistive_functions import load_trained_models, softplus_inverse\n",
    "from utils.pf_scheduler import PriorFactorScheduler\n",
    "from utils.train_models import train_models\n",
    "\n",
    "random_seed = 5\n",
    "random.seed(random_seed)\n",
    "np.random.seed(random_seed)\n",
    "random_state = np.random.RandomState(random_seed)\n",
    "\n",
    "if torch.cuda.is_available() and not str(device)=='cpu':\n",
    "    print('[INFO] running on GPU core ' + str(torch.cuda.current_device()))\n",
    "else:\n",
    "    print('[WARN] running on CPU')\n",
    "#import platform\n",
    "#platform.platform()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "exp_name = 'PV_UniModal'         # PV_BiModal, PV_UniModal_augmented', PV_UniModal\n",
    "mode = 'ours'            # ours or meta_fedavg\n",
    "\n",
    "ts_data = False\n",
    "scenario_name_fl = 'sml'\n",
    "criteria = ['rsmse']\n",
    "methods = [\n",
    "    'resgp_nn32_nn44', 'resgp_nn32_nn16', 'resgp_nn32_nn32', 'resgp_nn32_nn4444', 'resgp_nn32_nn16x4', 'resgp_nn32_nn64',\n",
    "    'resgp_lingp_nn22', 'resgp_lingp_nn44', 'resgp_lingp_nn16', 'resgp_lingp_nn32', 'resgp_lingp_nn4444',\n",
    "    'resgp_nn22_nn22', 'resgp_nn22_nn44',\n",
    "    'resgp_nn44_nn44', 'resgp_nn44_nn16', 'resgp_nn44_nn32', 'resgp_nn44_nn4444', \n",
    "    'resgp_nn16x4_nn16', 'resgp_nn16x4_nn32',\n",
    "    'resgp_nn4x4_nn4x2', 'resgp_nn4x4_nn4x4', 'resgp_nn4x4_nn16x2', \n",
    "    # fix noise\n",
    "    'resgp_nn32_nn16_fixnoise2', 'resgp_nn32_nn16_fixnoise4', 'resgp_nn32_nn16_fixnoise6',\n",
    "    'resgp_nn16x4_nn16_fixnoise2', 'resgp_nn16x4_nn16_fixnoise4', 'resgp_nn16x4_nn16_fixnoise6', 'resgp_nn16x4_nn16_fixnoise8', \n",
    "    'resgp_nn16x4_nn32_fixnoise2', 'resgp_nn16x4_nn32_fixnoise4', 'resgp_nn16x4_n32_fixnoise6', 'resgp_nn32x4_nn16_fixnoise8'   \n",
    "] \n",
    "methods_to_run = [\n",
    "] \n",
    "\n",
    "assert mode == 'ours'"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Load data\n",
    "* vary the tilt of the installation and the azimuthal orientation\n",
    "* same coordinates and altitude of central Lausanne"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[INFO] loaded data for 24 clients\n",
      "\n",
      "24 households at Lausanne - tilt_std: 5.0, az_std: 15.0, weather_dev: 0.1, irrad_std: 0.2, altitude_dev: 0.1, shadow_peak_red: 0.8, different module_name, different inverter_name, \n",
      "Subset of clients for demonstration:  [12, 14, 15, 17, 22]\n",
      "\n",
      "[INFO] 15 features:  H_sun T2m WS10m station_irrad_direct_prev lag 1 lag 2 lag 4 lag 18 lag 20 lag 22 lag 43 lag 70 lag 74 lag 121 lag 145\n"
     ]
    }
   ],
   "source": [
    "# ------ LOAD DATA ------\n",
    "# NOTE: env generated in notebook 1_visualization\n",
    "filename_env = config.PVDATA_DIR + '/'+ exp_name+\"_env\"\n",
    "file = open(filename_env, 'rb')\n",
    "env_dict = pickle.load(file)\n",
    "msg = '[INFO] loaded data for {:2.0f} clients'.format(env_dict['num_clients'])\n",
    "print(msg)\n",
    "file.close()\n",
    "num_clients = env_dict['num_clients'] \n",
    "print('\\n'+env_dict['info'])\n",
    "\n",
    "# ----- SELECT A SUBSET OF CLIENTS -----\n",
    "clients_subset= [12, 14, 15, 17, 22]\n",
    "print('Subset of clients for demonstration: ', clients_subset)\n",
    "\n",
    "num_features = len(env_dict['feature_names'])\n",
    "print('\\n[INFO] {:2.0f} features: '.format(\n",
    "    len(env_dict['feature_names'])), *env_dict['feature_names'])\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Step 1: load mean model and compute residuals"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "if len(methods_to_run)>0:\n",
    "    assert len(methods_to_run)==1\n",
    "    method_to_run = methods_to_run[0]\n",
    "    assert method_to_run.startswith('resgp')\n",
    "    mean_method = method_to_run.split('_')[1]\n",
    "    covar_method = method_to_run.split('_')[2]\n",
    "\n",
    "    # ---------- Load Mean Model from Global ----------\n",
    "    filename_res = os.path.join(os.getcwd(), \"saved_results\", exp_name, 'global') # NOTE\n",
    "    model_mean, _ = load_trained_models(\n",
    "        mode='ours', methods=[mean_method], ts_data=ts_data,\n",
    "        filename_res=filename_res+'_'+scenario_name_fl)\n",
    "\n",
    "    model_mean = model_mean[mean_method][scenario_name_fl]['rsmse'] # NOTE: picl the best model based on RSMSE\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# compute residuals\n",
    "if len(methods_to_run)>0:\n",
    "    env_dict_res = copy.deepcopy(env_dict)\n",
    "\n",
    "    # calculate residuals if the mean model is not zero\n",
    "\n",
    "    del env_dict_res['train_scenarios'][scenario_name_fl]['time_series']\n",
    "    res_train_std, res_valid_std = np.zeros(num_clients), np.zeros(num_clients)\n",
    "    res_train_mean, res_valid_mean = np.zeros(num_clients), np.zeros(num_clients)\n",
    "    for client_num in np.arange(num_clients):\n",
    "        x_train, y_train, x_valid, y_valid = env_dict['train_scenarios'][scenario_name_fl]['clients_data'][client_num]\n",
    "        # x_train, y_train = _handle_input_dimensionality(x_train, y_train)\n",
    "        # x_valid, y_valid = _handle_input_dimensionality(x_valid, y_valid)\n",
    "        \n",
    "        # residual of train\n",
    "        y_train_pred, _ = model_mean.predict(x_train, y_train, x_train)\n",
    "        y_valid_pred, _ = model_mean.predict(x_train, y_train, x_valid)\n",
    "        y_train_pred = y_train_pred.reshape(y_train.shape)\n",
    "        y_valid_pred = y_valid_pred.reshape(y_valid.shape)\n",
    "        data_tup = (x_train, \n",
    "                    y_train-y_train_pred,\n",
    "                    x_valid,\n",
    "                    y_valid-y_valid_pred)\n",
    "\n",
    "        env_dict_res['train_scenarios'][scenario_name_fl]['clients_data'][client_num] = data_tup\n",
    "\n",
    "    # plot: can see bi-modality in residuals \n",
    "    # TODO: add labels and titles, normalize before plotting\n",
    "    num_days = 7\n",
    "    num_modes = env_dict['num_modes']\n",
    "    fig, axs = plt.subplots(2, 1, figsize=(40,10*2))\n",
    "    # fig, axs = plt.subplots(2*num_modes, 1, figsize=(40,10*2))\n",
    "    clients_res = env_dict_res['train_scenarios']['1y']['clients_data']\n",
    "\n",
    "    inds_plot = np.arange(num_days*len(env_dict_res['hours'])+1)\n",
    "\n",
    "    client_num = 0\n",
    "    colors = ['b', 'g']\n",
    "    for mode_num in np.arange(num_modes):\n",
    "        for _ in np.arange(env_dict_res['num_clients_per_mode'][mode_num]): # TODO\n",
    "            x_train, res_train, x_valid, res_valid = clients_res[client_num]\n",
    "            assert len(res_valid) >= len(inds_plot)\n",
    "            axs[0].plot(res_valid[inds_plot], c=colors[mode_num])\n",
    "            axs[1].plot(res_train[inds_plot], c=colors[mode_num])\n",
    "            \n",
    "            # axs[2*mode_num].plot(res_valid[inds_plot])\n",
    "            # axs[2*mode_num+1].plot(res_train[inds_plot])\n",
    "            client_num += 1\n",
    "        \n",
    "    day_sts = len(env_dict_res['hours']) * np.arange(num_days)\n",
    "    for ax in axs:\n",
    "        ax.set_xlabel('time')\n",
    "        ax.set_ylabel('residual')\n",
    "        for day_st in day_sts[:-1]:\n",
    "            ax.axvline(day_st, ymin=0, ymax=1, color='black', linestyle='dashed')\n",
    "        ax.axvline(day_sts[-1], ymin=0, ymax=1, color='black', linestyle='dashed', label='day start')\n",
    "        ax.legend()\n",
    "    axs[0].set_title('residuals of the shared ' + mean_method + ' mean on validation set')\n",
    "    axs[1].set_title('residuals of the shared ' + mean_method + ' mean on train set')\n",
    "    plt.tight_layout()\n",
    "    plt.show()\n",
    "    \n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# fit kernel"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABbEAAAIQCAYAAAC/oSPlAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAAEAAElEQVR4nOzdd3hT5f/G8XeSbkoLpZu9N2XvsqEioiAquBgKKoqLn3uwHLgFJ4oLN4gKfmWDIFOQvVpm2VAooy3dbc7vj9BopUBbkqYt9+u6cvX05Iw7JykP+eTJ85gMwzAQERERERERERERESmGzK4OICIiIiIiIiIiIiJyKSpii4iIiIiIiIiIiEixpSK2iIiIiIiIiIiIiBRbKmKLiIiIiIiIiIiISLGlIraIiIiIiIiIiIiIFFsqYouIiIiIiIiIiIhIsaUitoiIiIiIiIiIiIgUWypii4iIiIiIiIiIiEixpSK2iIiIiIiIiIiIiBRbKmJLoY0bNw6TyZRrXbVq1Rg6dKjTz33gwAFMJhNfffWVfd3QoUPx9fV1+rlzmEwmxo0bV2Tnk7xfcyIiJYnaTrWdl5PXc1RcVatWjRtuuMHVMfLtq6++wmQyceDAAVdHEZESQO212mtxraFDh1KtWjVXx5BiRkVscbm5c+cW2wayOGcTEZFrV3Fun4pzNimYnTt3Mm7cOBV+RUQKqTi3icU527WoKJ+PlJQUxo0bx7Jly4rkfCKOoiK2ONSuXbuYOnVqgfaZO3cu48ePL9A+VatWJTU1lbvvvrtA+xXU5bKlpqbywgsvOPX8ktsLL7xAamqqq2OIiDiU2k4prnbu3Mn48eNVxBYRQe21OFdhXiuFlZKSwvjx41XElhJHRWxxKE9PT9zd3Z12/KysLDIyMjCZTHh5eWGxWJx2rivx8vLCzc3NZecvDpKTk4v0fG5ubnh5eRXpOfOSkpLi6ggiUoqo7by2FHXbKUVHz61I6ab2+tqif9NLPz3HJY+K2JIvK1eupFWrVnh5eVGzZk0++eSTPLf77zhhmZmZjB8/ntq1a+Pl5UWFChXo2LEjixYtAmzjHH344YeAbdytnBv8MxbYW2+9xaRJk6hZsyaenp7s3LnzsmNG7t+/n6ioKMqUKUN4eDgTJkzAMAz7/cuWLcNkMl30qeN/j3m5bDnr/vt1n02bNtG7d2/8/Pzw9fWle/fu/PXXX7m2yRmTcdWqVYwePZqgoCDKlClD//79OXXqVN5PwH/88ccfREZGUqZMGcqVK8dNN91EdHS0/f6ZM2diMpn4888/L9r3k08+wWQysX37dvu6mJgYbrnlFgICAvDy8qJly5b89ttveeb+888/efDBBwkODqZSpUqXzJhznWfMmMErr7xCpUqV8PLyonv37uzdu/ei7X/66SdatGiBt7c3gYGB3HXXXRw9ejTXNnmNTbdo0SI6duxIuXLl8PX1pW7dujz33HO5tklPT2fs2LHUqlULT09PKleuzFNPPUV6evol8+fo0qULjRo1YsOGDXTq1AkfHx/78WfPnk2fPn0IDw/H09OTmjVr8tJLL5GdnW3f/7333sNisXDu3Dn7urfffhuTycTo0aPt67KzsylbtixPP/30FTOJSMmgtlNtZ0HbzkspyLnyc42sVivjxo0jPDwcHx8funbtys6dO3O9Fr/66ituvfVWALp27Wp/Lv/7Gli5ciWtW7fGy8uLGjVq8PXXX+frMSUlJfHYY49RrVo1PD09CQ4OpmfPnmzcuDHXdmvXruX666+nfPnylClThiZNmjB58mT7/Vu3bmXo0KHUqFEDLy8vQkNDueeeezh9+nS+csybN8/+uihbtix9+vRhx44dV9zvcs/twYMHefDBB6lbty7e3t5UqFCBW2+9NVeP9nPnzmGxWHjvvffs6+Lj4zGbzVSoUCHX39/IkSMJDQ3N1+MRkYJTe632ujDt9cmTJ7n33nsJCQnBy8uLiIgIpk2blmsbRzwf/36tvPvuu1StWhVvb286d+6c63GC7b1rly5dLsr67/GlDxw4QFBQEADjx4+3n+tKQ5ns2bOHAQMGEBoaipeXF5UqVWLQoEEkJCTk2u7bb7+ldevW+Pj4UL58eTp16sTChQvt9+fnPfSlWK1WJk2aRMOGDfHy8iIkJIT777+fs2fPXnHfnHHl9+3bx/XXX0/ZsmW58847AVixYgW33norVapUsdcLHn/88VzfAv/tt98wmUxs3brVvu7nn3/GZDJx88035zpX/fr1GThw4BUzScFd2x+tSb5s27aNXr16ERQUxLhx48jKymLs2LGEhIRccd9x48YxceJEhg8fTuvWrUlMTGT9+vVs3LiRnj17cv/993Ps2DEWLVrEN998k+cxvvzyS9LS0rjvvvvw9PQkICAAq9Wa57bZ2dlcd911tG3bljfeeIP58+czduxYsrKymDBhQoEed36y/duOHTuIjIzEz8+Pp556Cnd3dz755BO6dOnCn3/+SZs2bXJt//DDD1O+fHnGjh3LgQMHmDRpEqNGjWL69OmXPc/ixYvp3bs3NWrUYNy4caSmpvL+++/ToUMHNm7cSLVq1ejTpw++vr7MmDGDzp0759p/+vTpNGzYkEaNGtlzd+jQgYoVK/LMM89QpkwZZsyYQb9+/fj555/p379/rv0ffPBBgoKCGDNmTL4+uXzttdcwm8088cQTJCQk8MYbb3DnnXeydu1a+zZfffUVw4YNo1WrVkycOJG4uDgmT57MqlWr2LRpE+XKlbvkNb/hhhto0qQJEyZMwNPTk71797Jq1Sr7NlarlRtvvJGVK1dy3333Ub9+fbZt28a7777L7t27mTVr1hUfw+nTp+nduzeDBg3irrvusr/2v/rqK3x9fRk9ejS+vr788ccfjBkzhsTERN58800AIiMjsVqtrFy50j4B1ooVKzCbzaxYscJ+jk2bNnH+/Hk6dep0xTwiUvyp7VTb+W8FbTv/e40Kcq78XKNnn32WN954g759+xIVFcWWLVuIiooiLS3Nvk2nTp145JFHeO+993juueeoX78+gP0nwN69e7nlllu49957GTJkCF988QVDhw6lRYsWNGzY8LKP64EHHmDmzJmMGjWKBg0acPr0aVauXEl0dDTNmzcHbB9U33DDDYSFhfHoo48SGhpKdHQ0v//+O48++qh9m/379zNs2DBCQ0PZsWMHn376KTt27OCvv/667ITQ33zzDUOGDCEqKorXX3+dlJQUPv74Yzp27MimTZvyNaFUXs/t33//zerVqxk0aBCVKlXiwIEDfPzxx3Tp0oWdO3fi4+NDuXLlaNSoEcuXL+eRRx4BbIU0k8nEmTNn2Llzp/0arlixgsjIyCtmEZGCU3ut9vrf8ttep6am0qVLF/bu3cuoUaOoXr06P/30E0OHDuXcuXP2Niq/8vN8fP311yQlJfHQQw+RlpbG5MmT6datG9u2bcvX6zVHUFAQH3/8MSNHjqR///72AmyTJk0uuU9GRgZRUVGkp6fz8MMPExoaytGjR/n99985d+4c/v7+gK0oPm7cONq3b8+ECRPw8PBg7dq1/PHHH/Tq1QvI33voy12nnNrBI488QmxsLB988AGb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N1q0aGGMHz/eSEhIuOzj6Ny5s9GwYcM871u1apXRtm1bw9vb2wgPDzeeeuopY8GCBXk+j3PmzDEAo3fv3rnWDx8+3ACMzz///LI5RKTkUduptrOgbeel2sirOVde1ygrK8t48cUXjdDQUMPb29vo1q2bER0dbVSoUMF44IEHcu0/depUo0aNGobFYsl1nKpVqxp9+vS56DF07tzZ6Ny582UfZ3p6uvHkk08aERERRtmyZY0yZcoYERERxkcffXTRtitXrjR69uxp365JkybG+++/b7//yJEjRv/+/Y1y5coZ/v7+xq233mocO3bsotdazvWJjY296PpERUUZ/v7+hpeXl1GzZk1j6NChxvr16y/7GC733J49e9YYNmyYERgYaPj6+hpRUVFGTEzMRX/rOYKDgw3AiIuLy/W4ASMyMvKyOUTk6qm9Vntd0PbaMAwjLi7O/m+9h4eH0bhx44vab8O4+ufj36+Vt99+26hcubLh6elpREZGGlu2bLnofN9++61Ro0YNw8PDw2jatKmxYMECY8iQIUbVqlVzbbd69Wr76z6v5/vf9u/fb9xzzz1GzZo1DS8vLyMgIMDo2rWrsXjx4ou2/eKLL+zv68uXL2907tzZWLRokf3+/L6HziuzYRjGp59+arRo0cLw9vY2ypYtazRu3Nh46qmnjGPHjl0yf87xypQpk+d9O3fuNHr06GH4+voagYGBxogRI4wtW7bk+X+yHTt2GIBRv379XOtffvllAzBefPHFy+aQq2MyDCfM8iIiIiIiIiXGuXPnKF++PC+//DLPP/+8q+OIiIgIcODAAapXr86bb77JE0884eo4Ii6lMbFFRERERK4hqampF63LGUe6S5cuRRtGRERERCQfNCa2iIiIiMg1ZPr06Xz11Vdcf/31+Pr6snLlSn744Qd69epFhw4dXB1PREREROQiKmKLiIiIiFxDmjRpgpubG2+88QaJiYn2yR5ffvllV0cTEREREcmThhMREREphZYvX07fvn0JDw/HZDIxa9asK+6zbNkymjdvjqenJ7Vq1eKrr75yek4RKXrNmzdn8eLFxMfHk5GRweHDh5k0aRK+vr6ujiZyzVF7LSKXU61aNQzD0HjYIqiILSIiUiolJycTERHBhx9+mK/tY2Nj6dOnD127dmXz5s089thjDB8+nAULFjg5qYiIyLVL7bWIiEj+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3333cfz48Rxtxo8fn+M1APvMuJ06dcLPzw9vb28aNGjAiy++mKNNamoq48aNo27duri5uREaGspzzz1HampqvvlFRK6WaqdqZ2FrZ34Ks6+CnCObzcb48eOpUqUKnp6e3HDDDezZsyfHe3HmzJncddddANxwww3Zr+Wl74HVq1fTtm1b3N3dqV27Nl999VWBjikpKYmnnnqKmjVr4ubmRmBgIDfddBNbtmzJ0W79+vXccsstVKxYES8vL5o3b87777+f/fyOHTsYNmwYtWvXxt3dneDgYO6//37OnDlToBy//vpr9vuiQoUK9O7dm927dxdoXREpH1SvVa+LUq9PnTrFAw88QFBQEO7u7oSFhTFr1qwcbRzxevz7vfLee+9Ro0YNPDw86Nq1a47jBOjWrRvdunXLlXXYsGHUrFkze3uVK1cGYMKECdn7uvT1vtSBAwe44447CA4Oxt3dnWrVqnH33XeTkJCQo90333xD27Zt8fT0pGLFinTp0oXffvst+/mffvqJ3r17U6VKFdzc3KhTpw6vvvoqmZmZl90/2P9+mTp1Kk2aNMHd3Z2goCAefvhhzp07d8V1xVy6FFFKzM6dO+nZsyeVK1dm/PjxZGRkMG7cOIKCgq647vjx45k0aRIPPvggbdu2JTExkU2bNrFlyxZuuukmHn74YU6cOMHSpUv5+uuv89zGl19+ycWLF3nooYdwc3PD398fm82WZ9vMzEx69erF9ddfz+TJk1m8eDHjxo0jIyODiRMnFuq4C5Lt33bv3k3nzp3x8fHhueeew8XFhU8++YRu3brx+++/065duxztH3/8cSpWrMi4ceM4fPgwU6dO5bHHHmPOnDmX3c+yZcu4+eabqV27NuPHjyclJYUPPviAjh07smXLFmrWrEnv3r3x9vbmhx9+oGvXrjnWnzNnDk2aNKFp06bZuTt27EjVqlV54YUX8PLy4ocffqBfv37897//pX///jnWHzVqFJUrV2bs2LEkJydf8by8+eabWK1WnnnmGRISEpg8eTL33nsv69evz24zc+ZMhg8fznXXXcekSZOIjY3l/fffZ82aNWzduhU/P798z/mtt95K8+bNmThxIm5ubkRGRrJmzZrsNjabjb59+7J69WoeeughGjVqxM6dO3nvvffYv38/CxYsuOIxiIgUlmqnaue/FbZ2XnqOCrOvgpyjMWPG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iLvvvpsffvghR4f2gQMH2L17d67jyzoHlx6fiMjVUu0sGNXOKyvKvgpad+vWrZujnb+/f3bbgrp0X1n7y9pXZmYmMTExOW5paWkATJ48mV27dhEaGkrbtm0ZP358js7vgwcPAmT/JDw/Z8+e5cknnyQoKAgPDw8qV66cfb4vHafz37I6nW688cZc5/a3337T3wci1wDV64JRvc47a7169XJ11mYNuXW5f8MWVV7v0/r16zv0tU9JSclVt8F+XkaPHs1nn31GQEAA4eHhTJs2LUedPXjwIFarlcaNG192H7t376Z///74+vri4+ND5cqVue+++4Ar1+2EhAQCAwNzvZ7nz59X3S7lNCa2lAldunTh4MGD/PTTT/z222989tlnvPfee0yfPp0HH3ywQNv49zd1jpDf2IgFmUjAkfL7htf418QcV8PNzY1+/frx448/8tFHHxEbG8uaNWt44403sttkdfY+88wz+V5tcOk/cgv7ehTncXp4ePDHH3+wcuVKFi5cyOLFi5kzZw433ngjv/32G05OTthsNpo1a8a7776b5zZCQ0OvOoeIiCOpdubvWqmdV7Ov4j5HhdnX0aNHc3UIrFy5km7dujFgwAA6d+7Mjz/+yG+//cbbb7/NW2+9xfz587n55psLnGHAgAGsXbuWZ599lhYtWuDt7Y3NZqNXr175/koL/jm3X3/9NcHBwbmed3bWP7dE5PJUr/N3rdXr/JT062GxWPI8xwXd35w5cxg+fHiOZVnbe+eddxg2bFj2+/2JJ55g0qRJ/PXXXwWetDo+Pp6uXbvi4+PDxIkTqVOnDu7u7mzZsoXnn3/+inU7MDCQb7/9Ns/nC/OLBil5+qtKSkTlypXx8PDI8ydS+/btK9A2/P39GT58OMOHD+f8+fN06dKF8ePHZxf2y024U1g2m41Dhw5lf/sKsH//foDsyXmyvgWOj4/PsW5e35YWNFvlypXx9PTM85zs3bsXq9XqkM7SGjVqAHmf+7179xIQEICXl1f2soEDBzJr1iyWL19OREQEhmFk/7wKyP4m38XFhR49elx1vqL49zFlDfGRZd++fdnP58dqtdK9e3e6d+/Ou+++yxtvvMFLL73EypUr6dGjB3Xq1GH79u10797doe81EZH8qHaqdjpKcewr63xERkbm6GA+c+ZMrivkrvZ9FhwczNKlS3MsCwsLy34c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r62jnO0bluWZat0GUqpszpw5JiQkxLzzzjtm69at5u677zb169c3WVlZxhhjRo8ebSZOnFi5/bPPPmuCg4PN+++/bw4fPly5FBYW+qoJVVLddv5YbbjTcHXbuH//fhMZGWkeeOABs2PHDrNgwQITGxtr/vCHP/iqCRdU3TZOmjTJREZGmnfffddkZmaaTz75xLRu3dqMGDHCV024oMLCQpORkWEyMjIMYP785z+bjIwMs2/fPmOMMRMnTjSjR4+u3D4zM9OEh4ebhx9+2Gzbts1MmzbNOBwOs2jRIl814YKq28ZZs2YZp9Nppk2bdtp55/jx475qQpVUt50/NmnSJNOlSxcvRVu3VPdcsXLlSuN0Os0LL7xgtm3bZiZNmmSCgoLMpk2bfNUEvxAoYwRPC4QxiDcEwjjHGwJhLOUNgTBe8wbla2soX1tD+doaytfWUc6+eL7K1ypie9DUqVNNs2bNTHBwsOnVq5f58ssvK5/r16+fGTNmTOXj5s2bG+CMZdKkSd4PvJqq084fqy0JqbptXLVqlUlOTjYhISGmVatW5plnnjHl5eVejrp6qtPGsrIy8+STT5rWrVub0NBQk5SUZO6//36Tl5fn/cCr6LPPPjvre+z7do0ZM8b069fvjH26du1qgoODTatWrczbb7/t9biro7pt7Nev33m391c1+Vv+LxWxL051z4fvvfeeadeunQkODjYdO3Y0Cxcu9HLE/ilQxgieFghjEG8IhHGON9T1sZQ3BMJ4zVuUr62hfG0N5WtrKF9bRzn74vgqX9uM0bXvIiIiIiIiIiIiIuKfNCe2iIiIiIiIiIiIiPgtFbFFRERERERERERExG+piC0iIiIiIiIiIiIifktFbBERERERERERERHxWypii4iIiIiIiIiIiIjfUhFbRERERERERERERPyWitgiIiIiIiIiIiIi4rdUxBYRERERERERERERv6UitoiIiIiIiIiIiIj4LRWxRURERERERERERMRvqYgtIiIiIiIiIiIiIn5LRWwRERERERERERER8Vv/D8o5RHAaWc2TAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1800x600 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hyper_prior_dicts = [\n",
    "    {'noise_raw_loc': softplus_inverse(0.6), 'noise_raw_scale': 0.4,\n",
    "    'constant_mean_loc':0, 'constant_mean_scale':1,},\n",
    "    {'noise_raw_loc': softplus_inverse(0.4), 'noise_raw_scale': 0.4,\n",
    "    'constant_mean_loc':0, 'constant_mean_scale':1,},\n",
    "    {'noise_raw_loc': softplus_inverse(0.4), 'noise_raw_scale': 0.6,\n",
    "    'constant_mean_loc':0, 'constant_mean_scale':1,}\n",
    "]\n",
    "\n",
    "\n",
    "import scipy.stats as stats\n",
    "import torch.nn.functional as F\n",
    "fig, axs = plt.subplots(2, 3, figsize=(18,6))\n",
    "noises = []\n",
    "lscales = []\n",
    "oscales = []\n",
    "for hyper_prior_dict in hyper_prior_dicts:\n",
    "    mu = hyper_prior_dict['noise_raw_loc']\n",
    "    sigma = hyper_prior_dict['noise_raw_scale']\n",
    "    if not (mu, sigma) in noises:\n",
    "        x = np.linspace(mu - 3*sigma, mu + 3*sigma, 100)\n",
    "        axs[0][0].plot(x, stats.norm.pdf(x, mu, sigma), label='N({:2.4f}, {:2.4f}^2)'.format(mu,sigma))\n",
    "        x = torch.tensor(x)\n",
    "        axs[1][0].plot(F.softplus(x), stats.norm.pdf(x, mu, sigma), label='N({:2.4f}, {:2.4f}^2)'.format(mu,sigma))\n",
    "        noises.append((mu, sigma))\n",
    "    # --- lengthscale ---\n",
    "    if 'lengthscale_raw_loc' in hyper_prior_dict.keys():\n",
    "        mu = hyper_prior_dict['lengthscale_raw_loc']\n",
    "        sigma = hyper_prior_dict['lengthscale_raw_scale']\n",
    "        if not (mu, sigma) in lscales:\n",
    "            x = np.linspace(mu - 3*sigma, mu + 3*sigma, 100)\n",
    "            axs[0][1].plot(x, stats.norm.pdf(x, mu, sigma), label='N({:2.4f}, {:2.4f}^2)'.format(mu,sigma))\n",
    "            x = torch.tensor(x)\n",
    "            axs[1][1].plot(F.softplus(x), stats.norm.pdf(x, mu, sigma), label='N({:2.4f}, {:2.4f}^2)'.format(mu,sigma))\n",
    "            lscales.append((mu, sigma))\n",
    "    if 'outputscale_raw_loc' in hyper_prior_dict.keys():\n",
    "        mu = hyper_prior_dict['outputscale_raw_loc']\n",
    "        sigma = hyper_prior_dict['outputscale_raw_scale']\n",
    "        if not (mu, sigma) in oscales:\n",
    "            x = np.linspace(mu - 3*sigma, mu + 3*sigma, 100)\n",
    "            axs[0][2].plot(x, stats.norm.pdf(x, mu, sigma), label='N({:2.4f}, {:2.4f}^2)'.format(mu,sigma))\n",
    "            x = torch.tensor(x)\n",
    "            axs[1][2].plot(F.softplus(x), stats.norm.pdf(x, mu, sigma), label='N({:2.4f}, {:2.4f}^2)'.format(mu,sigma))\n",
    "            oscales.append((mu, sigma))\n",
    "axs[0][0].set_title('distribution over noise raw')\n",
    "axs[1][0].set_title('distribution over noise')\n",
    "axs[0][1].set_title('distribution over length-scale raw')\n",
    "axs[1][1].set_title('distribution over length-scale')\n",
    "axs[0][2].set_title('distribution over output-scale raw')\n",
    "axs[1][2].set_title('distribution over output-scale')\n",
    "del noises\n",
    "del lscales\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "# set properties that are different based on the GP mean\n",
    "options_base={\n",
    "        # noise setup\n",
    "        'optimize_noise':True,\n",
    "        'noise_std':None,  \n",
    "        'likelihood_str': 'Gaussian',\n",
    "        # zero mean NN kernel\n",
    "        'covar_module_str': ['NN'], 'mean_module_str':['constant'],\n",
    "        'kernel_nn_layers': [], 'mean_nn_layers':[],\n",
    "        'nonlinearity_output_m': None, 'nonlinearity_output_k': None,  \n",
    "        'nonlinearity_hidden_m': None, 'nonlinearity_hidden_k': torch.tanh,\n",
    "        'feature_dim':2, \n",
    "        'optimize_lengthscale': False, 'lengthscale_fix':[[[0.3,0.3]],], # NOTE\n",
    "        # Configuration for GP-Prior learning\n",
    "        'lr': 1e-2,             # initial learning rate for Adam optimizer'\n",
    "        'lr_decay': 0.90,       # 'multiplicative learning rate decay factor applied after every 1000 steps'\n",
    "        'task_batch_size': 5,  # number of clients for computing grads'\n",
    "        'normalize_data': True,\n",
    "        'hyper_prior_dict':hyper_prior_dicts,\n",
    "        # iterations\n",
    "        'num_iter_fit': 5000,\n",
    "        'max_iter_fit': 7000,\n",
    "        'early_stopping': True,\n",
    "        'n_threads': 8,\n",
    "        # time-series prediction\n",
    "        'ts_data':ts_data\n",
    "}\n",
    "\n",
    "# options specific to our method\n",
    "options_base['num_particles'] = 4 if 'Bi' in exp_name else [4, 1]\n",
    "options_base['bandwidth'] = -1        # heuristic lengthscale for SVGD heuristically            \n",
    "#options_base['initial_particles'] = {'noise_raw': softplus_inverse(0.2)}\n",
    "\n",
    "options = {}\n",
    "for method_to_run in methods_to_run:\n",
    "        options[method_to_run] = copy.deepcopy(options_base)\n",
    "        # --- set kernel nn layers size ---\n",
    "        if covar_method=='nn22':\n",
    "                kernel_nn_layers=[(2,2)]\n",
    "        elif covar_method=='nn44':\n",
    "                kernel_nn_layers=[(4,4)]\n",
    "        elif covar_method=='nn16':\n",
    "                kernel_nn_layers=[(16,16)]\n",
    "        elif covar_method=='nn32':\n",
    "                kernel_nn_layers=[(32,32)]\n",
    "        elif covar_method=='nn64':\n",
    "                kernel_nn_layers=[(64,64)]\n",
    "        elif covar_method=='nn4444':\n",
    "                kernel_nn_layers=[(4,4,4,4)]\n",
    "        elif 'x' in covar_method:\n",
    "                num_neurons = int(covar_method.split('x')[0][2:])\n",
    "                num_layers = int(covar_method.split('x')[-1])\n",
    "                kernel_nn_layers=[(num_neurons, )*num_layers]\n",
    "        else:\n",
    "                raise NotImplementedError\n",
    "        options[method_to_run].update({'kernel_nn_layers':kernel_nn_layers})\n",
    "\n",
    "\n",
    "        beta = env_dict['train_scenarios'][scenario_name_fl]['clients_data'][0][0].shape[0]\n",
    "\n",
    "        pf_scheduler_big = PriorFactorScheduler(\n",
    "                method='grid', num=10, space='log', \n",
    "                pf_range=(0.05, 1), #(1e-2, 1+1/num_clients/beta-1e-6),\n",
    "                test_no_regul=True, init_step_size=None, \n",
    "                early_stopping=True, thresh=0.025,\n",
    "                check_of_any=False # enough not to over-fit on average\n",
    "                ) if mode=='ours' else None\n",
    "        pf_scheduler_sml = PriorFactorScheduler(\n",
    "                method='grid', num=5, space='log', \n",
    "                pf_range=(5e-2, 2e-1),\n",
    "                test_no_regul=False, init_step_size=None, \n",
    "                early_stopping=True, thresh=0.025,\n",
    "                check_of_any=False # enough not to over-fit on average\n",
    "                ) if mode=='ours' else None\n",
    "        \n",
    "        # ---------- TRAIN ----------\n",
    "        train_models(\n",
    "                exp_name=exp_name, method_to_run=method_to_run, \n",
    "                mode=mode,\n",
    "                env_dict=env_dict_res, random_seed=random_seed, \n",
    "                criteria=criteria,\n",
    "                options=options, save_models=True, pf_scheduler=pf_scheduler_big,\n",
    "                verbose=True, clients_subset=None, train_scenarios=scenario_name_fl,\n",
    "                file_name=os.path.join(mode+'_' + scenario_name_fl, method_to_run),\n",
    "                )\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "# [RES] best over all:\n",
    "# with rsmsecriterion: train = 0.2642, valid = 0.4493\n",
    "# obtained by: \n",
    "# with calibrcriterion: train = 0.0701, valid = 0.0588\n",
    "# obtained by: \n",
    "# with nllcriterion: train = 3.2683, valid = 4.0276\n",
    "# obtained by: "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Step 2: Analysis\n",
    "### 2.1 Box Plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "[WARN] results of method resgp_nn32_nn16 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn32_nn16_fixnoise4 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn44_nn44 not found.\n",
      "\n",
      "[WARN] results of method resgp_lingp_nn16 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn16x4_nn16_fixnoise8 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn16x4_nn32_fixnoise4 not found.\n",
      "\n",
      "[WARN] results of method resgp_lingp_nn44 not found.\n",
      "\n",
      "[INFO] results of method resgp_nn4x4_nn4x2 loaded.\n",
      "\n",
      "[WARN] results of method resgp_lingp_nn32 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn32_nn64 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn16x4_nn16_fixnoise2 not found.\n",
      "\n",
      "[WARN] results of method resgp_lingp_nn4444 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn16x4_nn16_fixnoise6 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn16x4_n32_fixnoise6 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn44_nn16 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn32_nn4444 not found.\n",
      "\n",
      "[WARN] results of method resgp_lingp_nn22 not found.\n",
      "\n",
      "[INFO] results of method resgp_nn4x4_nn4x4 loaded.\n",
      "\n",
      "[WARN] results of method resgp_nn16x4_nn16_fixnoise4 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn32_nn44 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn16x4_nn32 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn22_nn44 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn32_nn16_fixnoise6 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn32_nn32 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn32_nn16x4 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn22_nn22 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn44_nn4444 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn32_nn16_fixnoise2 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn16x4_nn32_fixnoise2 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn32x4_nn16_fixnoise8 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn44_nn32 not found.\n",
      "\n",
      "[WARN] results of method resgp_nn16x4_nn16 not found.\n",
      "\n",
      "[INFO] results of method resgp_nn4x4_nn16x2 loaded.\n"
     ]
    },
    {
     "data": {
      "image/png": "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7+n1119Xx44dM63Xvn17paamaubMmU7l06ZNk8ViccxQnfb/zbOWT58+3em11WrVY489phUrVujXX39Nt75Tp05lZ3NuKzIyUgEBAZo4caKuXr1q6npbt24tb29vvfvuu05XhD/88EOdP38+w5nXzZZ2hfrG9V+5ckWzZ8/OdpuPPfaYTp8+ne53f+N6unbtqtTUVI0fPz5dnWvXrqV7vBkAADmBK9oAAI+R2dDtG3Xs2FEtWrTQyJEjdfDgQdWqVUvffPONPv/8c7344ouOK8W1a9dWVFSUZs+erfPnz+uBBx5QTEyMEhIS0rX5z3/+U7GxsWrYsKGio6NVtWpV/f3334qPj9f69evTPR/aDAEBAXrvvff05JNPqm7duurWrZuCgoJ0+PBhrV69WhERERkmlK4ICgrSiBEjNG7cOLVt21YPP/yw9uzZo9mzZ+v//u//nCYdyykPPPCAihUrpt69e2vw4MGyWCxavHhxloeC36hXr17617/+pSFDhuj7779XkyZNdOnSJa1fv14DBw7UI488ombNmmnAgAGaNGmSdu3apTZt2qhgwYLau3evli1bpnfeeSfT+/8BADALiTYAIE/x8vLSF198oTFjxmjp0qVasGCBwsPD9fbbb+vll192qjt//nwFBQVpyZIlWrVqlVq2bKnVq1enm8grJCRE33//vd544w2tXLlSs2fPVokSJVStWjW9+eabObYt3bt3V+nSpfXPf/5Tb7/9tlJSUlSmTBk1adIk01nAXfX6668rKChIM2fO1EsvvaTixYurf//+mjhxYq48R7pEiRL68ssv9fLLL2vUqFEqVqyYevbsqVatWikyMjJbbVqtVn311Vf6xz/+oY8//lgrVqxQiRIl1LhxY9WoUcNRb86cOapXr57ef/99vfbaaypQoIDCw8PVs2dPRUREmLWJAABkymLcyVfLAAAAAADACfdoAwAAAABgIhJtAAAAAABMRKINAAAAAICJSLQBAAAAADARiTYAAAAAACYi0QYAAAAAwEQk2gAAAAAAmIhEGwAAAAAAE5FoAwAAAABgIhJtAAAAAABMRKINAAAAAICJSLQBAAAAADARiTYAAAAAACYi0QYAAAAAwEQk2gAAAAAAmIhEGwAAAAAAE5FoAwAAAABgIhJtAAAAAABMRKINAAAAAICJSLQBAAAAADARiTYAAAAAACYi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Z5xeN2nSxOn3nl0ZHf9Z/QzdzN/fXz179nS89vb2VoMGDW4bb07v97sJfXTG6KPpo9PkhT46ICBA7dq106effirDMBzlS5cu1f3336977rnHUXbj5+b8+fM6ffq0mjVrpv379+v8+fO3XM+Njh07pl27dql3794qUqSIo/zBBx9U1apVb7u8K8fMsmXLVKRIET344INO+75evXry9/fPN/00kF+QaGfRqVOnlJiY6Bjql5lDhw6pUqVK6cqrVKnieP9GN/7RkOTo5ENDQ9OV2+32dH887r333nTruu+++3T58mWdOnVK0vXhdmPGjFFoaKh8fHwUGBiooKAgnTt3LsM/RmnD+Vxxc/ySVKxYMad7jg4dOqSKFSumq5dRWWZ8fX0VFBTkVFakSBGVLVs23eQ/RYoUSbd+V34naXHe3N7Ny+7du1eS1Lt3bwUFBTn9++CDD5SSkpLpH/lmzZrpscce07hx4xQYGKhHHnlECxYscPn+uIx+N0888YQiIiL09NNPKyQkRN26ddOnn36a4clWdo83V9axd+9e/fe//023T+677z5J14fXZSbtd5DR76ly5crpPjcZHQ83H3fZldE+zupn6GYZHaeuxJvT+/1uQh+dMfpo+ugb90te6KOfeOIJ/fnnn9q2bZskad++ffrxxx/1xBNPONWLi4tT69atVahQIRUtWlRBQUGOe9KzkminxZ7RZzWj7b2ZK8fM3r17df78eQUHB6fb/xcvXsw3/TSQX3CPtofI7KpEZuU3fsPrqueff14LFizQiy++qEaNGqlIkSKyWCzq1q1bhn/ob/yW+HbMjDM768mt9d8obZ+9/fbbTleAbuTv759hucVi0fLly/Xdd9/pP//5j77++mv169dPU6ZM0XfffZfpcmky+t3YbDZt2rRJsbGxWr16tdauXaulS5eqZcuW+uabb5z2UXb3oyvrsNvtqlGjhqZOnZphWzefKN6JnJwtNqN9nNXP0M2ye5x62n7Pj+ij72w99NH00VnVsWNH+fn56dNPP9UDDzygTz/9VF5eXurSpYujzr59+9SqVStVrlxZU6dOVWhoqLy9vfXVV19p2rRpLvXLZnHlmLHb7QoODtaSJUsybOPmLyUA5G0k2lkUFBSkgIAA/frrr7esFxYWpj179qQr3717t+N9M6V9c3+jP/74Q35+fo6Oe/ny5erdu7em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OToAAADzZSvRNvukadasWQoPD5evr68aNmyo77//PtO6V69e1RtvvKEKFSrI19dXtWrV0tq1a++oTQBAzjl//ryKFy8uSVq7dq0ee+wx+fn5qUOHDtq7d6+bowMAZEXao75y619qaqq7NxnIlmzdo32rk6ZXXnklS20tXbpUQ4YM0Zw5c9SwYUNNnz5dkZGR2rNnj4KDg9PVHzVqlD766CPNmzdPlStX1tdff63OnTtr69atqlOnTrbaBADknNDQUG3btk3FixfX2rVr9cknn0iSzp49K19fXzdHBwBwVWpqqpo2bqYzZ0/n2jpLFAvUpi3fZun5xZASEhJUp04dWa3WbD+ezYw27lRKSooaNmyon376STt37lTt2rVdWu7gwYMaP368NmzYoOPHj6t06dLq2bOnRo4cKW9v75wN+v/LVqJt5knT1KlTFR0drb59+0qS5syZo9WrV2v+/PkaPnx4uvqLFy/WyJEj1b59e0nSs88+q/Xr12vKlCn66KOPstUmACDnvPjii+rRo4f8/f0VFham5s2bS7o+OqpGjRruDQ4A4DK73a4zZ08r7ERbWZTz924bMnRIa2W32+8o0b5y5UquJVee4OrVq4qKilKTJk20detWt7VhhldffVWlS5fWTz/9lKXldu/eLbvdrvfff18VK1bUr7/+qujoaF26dEmTJ0/OoWidZWvoeNpJU9myZVW6dOlsnzRduXJFP/74o1q3bv2/gLy81Lp1a23bti3DZVJSUtIl8zabTVu2bMl2mwCAnDNw4EBt27ZN8+fP15YtW+Tldf1PT/ny5blHGwDyIIssssgrF/5lL5lv3ry5Bg0apBdffFGBgYGKjIzUr7/+qnbt2snf318hISF68skndfr0/67ML1++XDVq1JDNZlOJEiXUunVrXbp0SZJ07do1DR48WEWLFlWJEiU0bNgw9e7dW506dUq3zkGDBqlIkSIKDAzU6NGjZRiGSzGHh4dr4sSJ6tevnwoXLqx77rlHc+fOdbx/8OBBWSwWrVy5Ui1atJCfn59q1aqVYX4zatQoVa5cWV27dnUqT05OVrVq1dS/f39H2b59+1S4cGHNnz/fpTZup0+fPurUqZMmT56sUqVKqUSJEnruueccs9i7sq1p1qxZo2+++SbDxLhfv36qWbOmUlJSJF3PAevUqaNevXpJktq2basFCxaoTZs2Kl++vB5++GENHTpUK1euzNL23IlsXdEeOHCgGjRooD///FMPPvhgtk+aTp8+rdTUVIWEhDiVh4SEaPfu3RkuExkZqalTp6pp06aqUKGCYmJitHLlSsf9G9lpMyUlxfFLkqTExERJ17+1s9vtLm+PWdyxzvzEXb9XV90Ym6fHKnG85jR3HgNmrrd+/fqqX7++U1mHDh1cXt7T+mkA8AT0f5lbtGiRnn32WcXFxencuXNq2bKlnn76aU2bNk1JSUkaNmyYunbtqg0bNujYsWOKiorSW2+9pc6dO+vChQvavHmzI0l+8803tWTJEi1YsEBVqlTRO++8o1WrVqlFixbp1vnUU0/p+++/144dO9S/f3/dc889io6OdinmKVOmaPz48Xrttde0fPlyPfvss2rWrJkqVarkqDNy5EhNnjxZ9957r0aOHKmoqCglJCSoQIHrad2GDRu0bNky7dq1K11S6evrqyVLlqhhw4bq0KGDHnroIfXs2VMPPvig+vXr56h3qzZcERsbq1KlSik2NlYJCQl64oknVLt2baf9cLttPXHihKKjo7Vq1aoMHzH37rvvqlatWho+fLimTZumkSNH6ty5c44JuzNy4+3PuSFbibZ05ydN2fXOO+8oOjpalStXlsViUYUKFdS3b99038JkxaRJkzRu3Lh05adPn3Y6scstSUlJub7O/OT06dOOB857oht//54eq8TxmtPceQxcuHDBlHYMw9Dy5csVGxurkydPpjsxdOWPuKf10wDgCczqp+9G9957r9566y1J0oQJE1SnTh1NnDjR8f78+fMVGhqqP/74QxcvXtS1a9f06KOPKiwsTJKcRunOmDFDI0aMUOfOnSVJM2fO1FdffZVunaGhoZo2bZosFosqVaqkX375RdOmTXM50W7fvr0GDhwoSRo2bJimTZum2NhYp0R76NChjpxr3LhxqlatmhISElS5cmWdOXNGffr00UcffaSAgIAM11G7dm1NmDBBTz/9tLp166ZDhw7pyy+/dLzvShu3U6xYMc2cOVNWq1WVK1dWhw4dFBMT47QfbrWthmGoT58+euaZZ1S/fn0dPHgw3Tr8/f310UcfqVmzZipcuLCmT5+u2NjYTGNOSEjQjBkzcm3YuJTNRNuMkyZJCgwMlNVq1YkTJ5zKT5w4oZIlS2a4TFBQkFatWqXk5GSdOXNGpUuX1vDh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LeTn56datWpp27Zt6doaNWqUKleurK5duzqVJycnq1q1aurfv7+jbN++fSpcuLDmz5/vUhu306dPH3Xq1EmTJ09WqVKlVKJECT333HO6evWqy9uaZs2aNfrmm280efLkdO/169dPNWvWVEpKiqTrX6bUqVNHvXr1crmNnJblRJuTJgCAq6xWq9q0aZPhkDNfX18VLMhz1wEA5lu0aJG8vb0VFxenf/7zn2rZsqXq1KmjHTt2aO3atTpx4oQjiTx27JiioqLUr18//f7779q4caMeffRRR5L85ptvasmSJVqwYIHi4uKUmJioVatWZbjOAgUK6Pvvv9c777yjqVOn6oMPPnA55ilTpqh+/frauXOnBg4cqGeffVZ79uxxqjNy5EgNHTpUu3bt0n333aeoqChdu3bN8f6GDRu0bNkyzZo1K137vr6+WrJkiRYtWqTPP/9cqamp6tmzpx588EH169fPpTZcERsbq3379ik2NlaLFi3SwoULtXDhwixt64kTJxQdHa3FixfLz88v3TreffddXbp0ScOHD3fsl3PnzmnmzJkut5HTsjx0PO2k6ffff1exYsWc3vP19TUtMADA3aF69erav3+/ypUr5+5QAAD5xL333qu33npLkjRhwgTVqVNHEydOdLw/f/58hYaG6o8//tDFixd17do1PfroowoLC5Mk1ahRw1F3xowZGjFihDp37ixJmjlzpr766qt06wwNDdW0adNksVhUqVIl/fLLL5o2bZqio6Ndirl9+/YaOHCgJGnYsGGaNm2aYmNjValSJUedoUOHqkOHDpKkcePGqVq1akpISFDlypV15swZ9enTRx999JECAgIyXEft2rU1YcIEPf300+rWrZsOHTqkL7/80vG+K23cTrFixTRz5kxZrVZVrlxZHTp0UExMjNN+uNW2GoahPn366JlnnlH9+vV18ODBdOvw9/fXRx99pGbNmqlw4cKaPn26YmNjHTG70kZOy9bQ8bSTJgAAbmfChAkaOnSovvzySx07dkyJiYlO/wAAMFu9evUcP//000+KjY2Vv7+/41/lypUlXR86XatWLbVq1Uo1atRQly5dNG/ePJ09e1aSdP78eZ04cUINGjRwtGe1Wp3aT3P//ffLYrE4Xjdq1Eh79+5VamqqSzHXrFnT8bPFYlHJkiV18uTJTOuUKlVKkhx1oqOj1b17dzVt2vSW63n55Zd13333aebMmZo/f75KlCjheM/VNm6lWrVqTsP+S5UqdcvtuHlbZ8yYoQsXLmjEiBG3XE+jRo00dOhQjR8/Xi+//LIaN27seM/VNnJSthJtTpoAAK5q3769fvrpJz388MMqW7asihUrpmLFiqlo0aLpRkYBAGCGQoUKOX6+ePGiOnbsqF27djn927t3r5o2bSqr1ap169ZpzZo1qlq1qmbMmKFKlSrpwIEDuRrzzbdTWSyWdI9Su7FOWlKfVmfDhg2aPHmy4x73p556SufPn1eBAgWc7sE+efKk/vjjD1mtVu3du9epfVfbMHM7bq6zYcMGbdu2TT4+PipQoIBjPrD69eurd+/ejmXsdrvi4uJktVqVkJCQbjtcaSMnZWvW8fbt20uSHn74YadvbQzDkMVicflbGwDA3S82NtbdIQAA8rG6detqxYoVCg8PV4ECGac/FotFERERioiI0JgxYxQWFqbPPvtMQ4YMUUhIiH744QfHVd7U1FTFx8ene0zU9u3bnV5/9913uvfee3Pt0WTbtm1zysM+//xzvfnmm9q6davKlCnjKO/Xr59q1Kihp556StHR0WrdurWqVKmSpTZy0rvvvqsJEyY4Xh89elSRkZFaunSpGjZs6Ch/++23tXv3bn377beKjIzUggUL1Ldv3yy1kZOylWhz0gQAcFWzZs1cqjdw4EC98cYbCgwMzOGIAAD5yXPPPad58+YpKipKr776qooXL66EhAR98skn+uCDD7Rjxw7FxMSoTZs2Cg4O1vbt23Xq1ClH8vn8889r0qRJqlixoipXrqwZM2bo7NmzThccJenw4cMaMmSIBgwYoPj4eM2YMUNTpkzJte1MizfNjh075OXlperVqzvKZs2apW3btunnn39WaGioVq9erR49eui7776Tt7e3S23ktHvuucfptb+/vySpQoUKKlu2rCRp586dGjNmjJYvX66IiAhNnTpVL7zwgpo1a6by5cu71EZOy1aizUkTAMBsH330kYYOHcrfDADwcLk1etWs9ZQuXVpxcXEaNmyY2rRpo5SUFIWFhalt27by8vJSQECANm3apOnTpysxMVFhYWGaMmWK2rVrJ+n6ZF3Hjx9Xr169ZLVa1b9/f0VGRqa7Ut2rVy8lJSWpQYMGslqteuGFF5wepeVuu3fv1iuvvKIPP/xQoaGhkqTZs2er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vr5asmSJFi1apM8//1ypqanq2bOnHnzwQfXr18+lNlwRGxurffv2KTY2VosWLdLChQu1cOHCLG/rraxbt052u11HjhxRlSpVVLZsWXXt2lV//vmno867776rS5cuafjw4ZKu77tz585p5syZmbZ7/vx5FS9ePGsbnIlsP0cbOefGb77sunaLmnDVjfvR1W8WAWTfF198oXbt2qlgwYL64osvblmX240AAGa79957HY+QnDBhgurUqaOJEyc63p8/f75CQ0P1xx9/6OLFi7p27ZoeffRRx1MzbrySOmPGDI0YMcIxcnfmzJn66quv0q0zNDRU06ZNk8ViUaVKlfTLL79o2rRpio6Odinm9u3ba+DAgZKkYcOGadq0aYqNjVWlSpUcdYYOHaoOHTpIun7Vt1q1akpISFDlypV15swZ9enTRx999JECAgIyXEft2rU1YcIEPf300+rWrZsOHTqkL7/80vG+K23cTrFixTRz5kxZrVZVrlxZHTp0UExMjNN+cGVbb2X//v2y2+2aOHGi3nnnHRUpUkSjRo3Sgw8+qJ9//lne3t7y9/fXRx99pGbNmqlw4cKaPn26YmNjM92uhIQEzZgxw5Rh41IWEu13331X/fv3l6+vr959991b1h08ePAdB5afpU2EJUl/hsS4MZK7U3JyMlfSgBzWqVMnHT9+XMHBwbd8fJfFYmEkFADAdPXq1XP8/NNPPyk2Nlb+/v7p6u3bt09t2rRRq1atVKNGDUVGRqpNmzZ6/PHHVaxYMZ0/f14nTpxwutXJarWqXr166WZfv//++50msW3UqJGmTJmi1NRUl+4xT5vHRLr+97FkyZI6efJkpnVKlSolSTp58qQqV66s6Ohode/eXU2bNr3lel5++WWtWrVKM2fO1Jo1a1SiRAnHe662cSvVqlVz2t5SpUrpl19+yXQ7MtvWW7Hb7bp69areffddtWnTRpL073//WyVLllRsbKwiIyMlXf8dDB06VOPHj9ewYcPUuHHjDNs7cuSI2rZtqy5durj8xcjtuJxoT5s2TT169JCvr6+mTZuWaT2LxUKiDQD53I0nH7n5GBgAACTniWUvXryojh076s0330xXr1SpUrJarVq3bp22bt2qb775RjNmzNDIkSO1fft204YRu+LmCaYtFku6v6E31klL6tPqbNiwQV988YXjiqxhGLLb7SpQoIDm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fFWrVk0+Pj4qVaqUBg0a5Fju3LlzevrppxUUFKSAgAC1bNlSP/30k+P9119/XbVr19bixYsVHh6uIkWKqFu3brpw4YKjztq1a9W4cWMVLVpUJUqU0EMPPaR9+/Y53j948KAsFouWLl2qZs2aydfXV0uWLMlwSOJ7772nChUqyNvbW5UqVdLixYtd3gcWi0UffPCBOnfuLD8/P91777364osvHO+npqbqqaeeUrly5WSz2VSpUiW98847Tm306dNHnTp10sSJExUSEqKiRYvqjTfe0LVr1/TKK6+oePHiKlu2rBYsWOC03J9//qmuXbuqaNGiKl68uB555BEdPHjQ5dgB3P3op+mnAeBuR6KNu8qxY8cUFRWlfv366ffff9fGjRv16KOPyjAMvffee3ruuefUv39//fLLL/riiy9UsWJFx7JdunTRyZMntWbNGv3444+qW7euWrVqpb///ttRZ9++fVq1apW+/PJLffnll/r222/1z3/+0/H+pUuXNGTIEO3YsUMxMTHy8vJS586dZbfbneIcPny4XnjhBf3++++KjIxMtx2fffaZXnjhBb388sv69ddfNWDAAPXt21exsbEu74tx48apa9eu+vnnn9W+fXv16NHDsS12u11ly5bVsmXL9Ntvv2nMmDF67bXX9Omnnzq1sWHDBh09elSbNm3S1KlTNXbsWD300EMqVqyYtm/frmeeeUYDBgzQX3/9Jen6VZ/IyEgVLlxYmzdvVlxcnPz9/dW2bVtduXLF5dgB3L3op/+HfhoA7mIGcBf58ccfDUnGwYMH071XunRpY+TIkRkut3nzZiMgIMBITk52Kq9QoYLx/vvvG4ZhGGPHjjX8/PyMxMREx/uvvPKK0bBhw0zjOXXqlCHJ+OWXXwzDMIwDBw4Ykozp06c71VuwYIFRpEgRx+sHHnjAiI6OdqrTpUsXo3379pmu60aSjFGjRjleX7x40ZBkrFmzJtNlnnvuOeOxxx5zvO7du7cRFhZmpKamOsoqVapkNGnSxPH62rVrRqFChYx///vfhmEYxuLFi41KlSoZdrvdUSclJcWw2WzG119/7VLsAO5u9NPX0U8DwN2NK9q4q9SqVUutWrVSjRo11KVLF82bN09nz57VyZMndfToUbVq1SrD5X766SddvHhRJUqUkL+/v+PfgQMHnIYUhoeHq3Dhwo7XpUqV0smTJx2v9+7dq6ioKJUvX14BAQEKDw+XJB0+fNhpffXr17/ldvz++++KiIhwKouIiNDvv//u0n6QpJo1azp+LlSokAICApxinTVrlurVq6egoCD5+/tr7ty56eKsVq2avLz+102EhISoRo0ajtdWq1UlSpRwtPvTTz8pISFBhQsXduzD4sWLKzk52Wk/Asi/6Kf/h34aAO5eBdwdAGAmq9WqdevWaevWrfrmm280Y8YMjRw5UjExMbdc7uLFiypVqpQ2btyY7r0b78m7eTIci8XiNNywY8eOCgsL07x581S6dGnZ7XZVr1493XC8QoUKZX3jsuhWsX7yyScaOnSopkyZokaNGqlw4cJ6++23tX379tu2cat2L168qHr16mnJkiXp4gkKCrrjbQKQ99FP/w/9NADcvUi0cdexWCyKiIhQRESExowZo7CwMK1bt07h4eGKiYlRixYt0i1Tt25dHT9+XAUKFHBc3ciqM2fOaM+ePZo3b56aNGkiSdqyZUu22qpSpYri4uLUu3dvR1lcXJyqVq2arfZuFhcXpwceeEADBw50lJlxJaNu3bpaunSpgoODFRAQcMftAbg70U/fHv00AORtDB3HXWX79u2aOHGiduzYocOHD2vlypU6deqUqlSpotdff11TpkzRu+++q7179yo+Pl4zZsyQJLVu3VqNGjVSp06d9M033+jgwYPaunWrRo4cqR07dri07mLFiqlEiRKaO3euEhIStGHDBg0ZMiRb2/HKK69o4cKFeu+997R3715NnTpVK1eu1NChQ7PV3s3uvfde7dixQ19//bX++OMPjR49Wj/88MMdt9ujRw8FBgbqkUce0ebNm3XgwAFt3LhRgwcPdkzEAyB/o592Df00AORtXNHGXSUgIECbNm3S9OnTlZiYqLCwME2ZMkXt2rWTJCUnJ2vatGkaOnSoAgMD9fjjj0u6fnXlq6++0siRI9W3b1+dOnVKJUuWVNOmTRUSEuLSur28vPTJJ59o8ODBql69uipVqqR3331XzZs3z/J2dOrUSe+8844mT56sF154QeXKldOCBQuy1VZGBgwYoJ07d+qJJ56QxWJRVFSUBg4cqDVr1txRu35+ftq0aZOGDRumRx99VBcuXFCZMmXUqlUrrpwAkEQ/7Sr6aQDI2yyGYRjuDgIAAAAAgLsFQ8cBAAAAADARiTaQxyxZssTp0TY3/qtWrZq7wwOAfI9+GgDA0HEgj7lw4YJOnDiR4XsFCxZUWFhYLkcEALgR/TQAgEQbAAAAAAATMXQcAAAAAAATkWgDAAAAAGAiEm0AAAAAAExEog0A+H/t17EAAAAAwCB/60nsLIsAABiJNgAAAIxEGwAAAEaiDQAAACPRBgAAgFFhe2Z2IEzejgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>method</th>\n",
       "      <th>scenario_name</th>\n",
       "      <th>valid_rsmse_mean</th>\n",
       "      <th>valid_rsmse_min</th>\n",
       "      <th>valid_rsmse_max</th>\n",
       "      <th>valid_rsmse_median</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>resgp_nn4x4_nn16x2</td>\n",
       "      <td>sml</td>\n",
       "      <td>0.978444</td>\n",
       "      <td>0.942412</td>\n",
       "      <td>1.024244</td>\n",
       "      <td>0.980530</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>resgp_nn4x4_nn4x2</td>\n",
       "      <td>sml</td>\n",
       "      <td>0.993432</td>\n",
       "      <td>0.968482</td>\n",
       "      <td>1.035216</td>\n",
       "      <td>0.991953</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>resgp_nn4x4_nn4x4</td>\n",
       "      <td>sml</td>\n",
       "      <td>0.992133</td>\n",
       "      <td>0.966317</td>\n",
       "      <td>1.018134</td>\n",
       "      <td>0.991703</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "               method scenario_name  valid_rsmse_mean  valid_rsmse_min  \\\n",
       "0  resgp_nn4x4_nn16x2           sml          0.978444         0.942412   \n",
       "1   resgp_nn4x4_nn4x2           sml          0.993432         0.968482   \n",
       "2   resgp_nn4x4_nn4x4           sml          0.992133         0.966317   \n",
       "\n",
       "   valid_rsmse_max  valid_rsmse_median  \n",
       "0         1.024244            0.980530  \n",
       "1         1.035216            0.991953  \n",
       "2         1.018134            0.991703  "
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "clients_train_data = None\n",
    "if mode in ['vanilla', 'meta_fedavg']:\n",
    "    clients_train_data = []\n",
    "    for d in env_dict['train_scenarios'][scenario_name_fl]['clients_data']:\n",
    "        clients_train_data.append((d[0], d[1]))\n",
    "\n",
    "# ---------- Load Trained Models ----------\n",
    "filename_res = os.path.join(os.getcwd(), \"saved_results\", exp_name, mode)\n",
    "models_all_resgp, results_all_resgp = load_trained_models(\n",
    "    mode=mode, methods=methods, ts_data=ts_data,\n",
    "    filename_res=filename_res+'_'+scenario_name_fl,\n",
    "    clients_train_data=clients_train_data)\n",
    "\n",
    "\n",
    "# ----------       BOX PLOTS      ----------\n",
    "# perf_box_plots(env_dict, criterion='nll', methods=methods, results_all=results_all_resgp)\n",
    "# perf_box_plots(env_dict, criterion='calibr', methods=methods, results_all=results_all_resgp)\n",
    "perf_box_plots(env_dict, criterion='rsmse', methods=methods, results_all=results_all_resgp)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "[INFO] results of method nn16_nonar loaded.\n",
      "\n",
      "[INFO] results of method lingp loaded.\n",
      "\n",
      "[INFO] results of method nn4x4 loaded.\n",
      "\n",
      "[INFO] results of method nn44 loaded.\n",
      "\n",
      "[INFO] results of method nn4x6 loaded.\n",
      "\n",
      "[INFO] results of method nn8x4 loaded.\n",
      "\n",
      "[INFO] results of method nn4444 loaded.\n",
      "\n",
      "[INFO] results of method nn16 loaded.\n",
      "[WARNING] The input matches the stored training data. Did you forget to call model.train()? GPInputWarning\n",
      "in file/home/mahrokhg/anaconda3/envs/python3/lib/python3.10/site-packages/gpytorch/models/exact_gp.py at line number:274\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[WARNING] The input matches the stored training data. Did you forget to call model.train()? GPInputWarning\n",
      "in file/home/mahrokhg/anaconda3/envs/python3/lib/python3.10/site-packages/gpytorch/models/exact_gp.py at line number:274"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA9oAAAHvCAYAAACrP6dwAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAACHRElEQVR4nOzdd3wU1f7/8fduII0ktJDQYkITkCIQJCIlNAlFFEGQJtXAVZAS8SIWFPFLRKlSLypFhSuCigXhCiEUaQoBsYGAFAUChBYgDZL5/cEvK0sSSMIkuySv5+PBg90zZ898ZnZydj87Z85YDMMwBAAAAAAATGF1dAAAAAAAABQkJNoAAAAAAJiIRBsAAAAAABORaAMAAAAAYCISbQAAAAAATESiDQAAAACAiUi0AQAAAAAwEYk2AAAAAAAmItEGAAAAAMBEJNoAgELHYrHo9ddfz/Hrjhw5IovFokWLFpke05346KOPVKNGDRUtWlQlSpRwdDgAABR6JNoAAIdYtGiRLBaLLBaLvv/++wzLDcNQQECALBaLHnnkEQdEmHsbNmywbZvFYlHRokVVuXJl9e3bV3/++aep69q3b5/69++vKlWq6L333tP8+fNNbR8AAORcEUcHAAAo3Nzd3bV06VI1bdrUrnzjxo36+++/5ebm5qDI7tzw4cP1wAMP6OrVq4qJidH8+fO1atUq/fzzzypfvrwp69iwYYPS0tI0Y8YMVa1a1ZQ2AQDAneGMNgDAoTp06KDly5fr2rVrduVLly5VcHCwypYt66DI7lyzZs3Up08fDRgwQDNnztTkyZN17tw5LV68+I7bvnLliiTp9OnTkmTqkPGEhATT2gIAoDAi0QYAOFTPnj119uxZrV271laWkpKiFStWqFevXpm+5sqVK3r++ecVEBAgNzc3Va9eXZMnT5ZhGHb1kpOTNWrUKJUpU0be3t569NFH9ffff2fa5vHjxzVw4ED5+/vLzc1NtWrV0oIFC8zbUEmtWrWSJB0+fNhWtnr1ajVr1kzFihWTt7e3OnbsqF9//dXudf3795eXl5cOHTqkDh06yNvbW71791ZQUJBee+01SVKZMmUyXHs+Z84c1apVS25ubipfvryGDh2qCxcu2LXdokUL1a5dW7t27VLz5s3l6empl156yXY9+uTJkzV79mxVrlxZnp6eatu2rf766y8ZhqEJEyaoYsWK8vDw0GOPPaZz587Ztf3ll1+qY8eOKl++vNzc3FSlShVNmDBBqampmcbw22+/qWXLlvL09FSFChX09ttvZ9iHSUlJev3113XvvffK3d1d5cqVU5cuXXTo0CFbnbS0NE2fPl21atWSu7u7/P39NWTIEJ0/fz77bxYAAHeAoeMAAIcKCgpS48aN9d///lft27eXdD35vHjxonr06KF3333Xrr5hGHr00UcVHR2tQYMGqV69evrf//6nF154QcePH9e0adNsdZ9++ml9/PHH6tWrlx566CGtX79eHTt2zBDDqVOn9OCDD8pisWjYsGEqU6aMVq9erUGDBik+Pl4jR440ZVvTk8HSpUtLuj6JWb9+/RQWFqZJkyYpISFBc+fOVdOmTbV7924FBQXZXnvt2jWFhYWpadOmmjx5sjw9PdW/f399+OGH+uKLLzR37lx5eXmpbt26kqTXX39d48ePV5s2bfTMM89o//79mjt3rn788Udt2bJFRYsWtbV99uxZtW/fXj169FCfPn3k7+9vW7ZkyRKlpKToueee07lz5/T222+re/fuatWqlTZs2KAxY8bo4MGDmjlzpkaPHm3348SiRYvk5eWliIgIeXl5af369Ro3bpzi4+P1zjvv2O2b8+fPq127durSpYu6d++uFStWaMyYMapTp47tuEhNTdUjjzyiqKgo9ejRQyNGjNClS5e0du1a/fLLL6pSpYokaciQIVq0aJEGDBig4cOH6/Dhw5o1a5Z2796dYdsBAMgTBgAADrBw4UJDkvHjjz8as2bNMry9vY2EhATDMAyjW7duRsuWLQ3DMIzAwECjY8eOttetXLnSkGS8+eabdu098cQThsViMQ4ePGgYhmHs2bPHkGQ8++yzdvV69eplSDJee+01W9mgQYOMcuXKGXFxcXZ1e/ToYRQvXtwW1+HDhw1JxsKFC2+5bdHR0YYkY8GCBcaZM2eMEydOGKtWrTKCgoIMi8Vi/Pjjj8alS5eMEiVKGOHh4XavjY2NNYoXL25X3q9fP0OS8eKLL2ZY12uvvWZIMs6cOWMrO336tOHq6mq0bdvWSE1NtZXPmjXLFle60NBQQ5Ixb948u3bTt7VMmTLGhQsXbOVjx441JBn333+/cfXqVVt5z549DVdXVyMpKclWlr7fbjRkyBDD09PTrl56DB9++KGtLDk52ShbtqzRtWtX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G3cqOTlZISEh+umnn7R7927Vq1cvW687cuSIJkyYoPXr1ys2Nlbly5dXnz599PLLL+frnAPZTrTj4+NtjyMjIzV8+HC9/vrrevDBByVJ27dv1xtvvKFJkyaZHyUA4K7H5wgA3N3S0tJ09nycAk+1k0V5f+22IUNHtUZpaWm5TrRTUlIK1YRuV69eVc+ePdWsWTNt3brVYW2Y4d///rfKly+vn376KUev27dvn9LS0vSf//xHVatW1S+//KLw8HBduXJFkydPzqNoM8p2ol2iRAm7i78Nw1D37t1tZYZhSJI6depkm6UQAIB0BflzxDAMJSYmOjqM27oxxrshXg8PDyZiApyQRRZZcjfVUw7lfIh6ixYtVLt2bRUpUkQff/yx6tSpo5kzZ+qFF17Q5s2bVaxYMbVt21bTpk2Tr6+vJGnFihUaP368Dh48KE9PT9WvX19ffvmlihUrpmvXrikiIkIffvihXFxc9PTTTys2NlYXL17UypUr7dYpSR999JGKFi2qZ555Rm+88Ua2+rCgoCANHjxYBw8e1PLly1WyZEm98sortjlLjhw5okqVKumzzz7TzJkztWPHDlWrVk3z5s1T48aN7dp65ZVXVKNGDbVu3douSU5KSlJwcLCaNGmi+fPnS5IOHTqkevXqacaMGRo4cOBt27id/v3768KFC2ratKmmTJmilJQU9ejRQ9OnT1fRokWzta3pVq9ere+++06fffaZVq9ebbds4MCB2rlzp3788Ue5ubkpJSVFISEhqlOnjj788EO1a9dO7dq1s9WvXLmy9u/fr7lz5zpnoh0dHZ2XcQAACriC/DmSmJioBg0aODqMHGnSpImjQ7itmJgY7t8LIMcWL16sZ555Rlu2bNGFCxfUqlUrPf3005o2bZoSExM1ZswYde/eXevXr9fJkyfVs2dPvf3223r88cd16dIlbd682fbj76RJk7RkyRItXLhQNWvW1IwZM7Ry5Uq1bNkywzoHDRqkH374QTt37tTgwYN1zz33KDw8PFsxT5kyRRMmTNBLL72kFStW6JlnnlFoaKjtzhyS9PLLL2vy5MmqVq2aXn75ZfXs2VMHDx603RZz/fr1Wr58ufbs2aPPP//crn13d3ctWbJEISEh6tixox555BH16dNHDz/8sF2Sfas2siM6OlrlypVTdHS0Dh48qCeffFL16tWz2w+329ZT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0AcffFB79uy505gAAAUcnyMAcPdycXFRkSJF8vxfbpLrFi1aaNiwYRo5cqR8fX0VFhamX375Re3bt5eXl5f8/f311FNPKS4uzvaaFStWqE6dOvLw8FDp0qXVpk0bXblyRZJ07do1DR8+XCVKlFDp0qU1ZswY9evXT507d86wzmHDhql48eLy9fXVq6++KsMwshVzUFCQJk6cqIEDB8rb21v33HOP5s+fb1t+5MgRWSwWff7552rZsqU8PT11//33a9u2bRnaeuWVV1SjRg11797drjwpKUm1atXS4MGDbWWHDh2St7e3FixYkK02bqd///7q3LmzJk+erHLlyql06dIaOnSorl69mu1tTbd69Wp99913mjx5coZlAwcOVN26dZWcfH2UZ0pKiurXr6++fftmu438kKtE22Kx2CaxudHFixeVmpp6x0Hh9gzDUEJCglP/u3mGbEfHk91YAeQ9PkcAAHll8eLFcnV11ZYtW/TWW2+pVatWql+/vnbu3Kk1a9bo1KlTtiTy5MmT6tmzpwYOHKjff/9dGzZsUJcuXWxJ8qRJk7RkyRItXLhQW7ZsUXx8vFauXJnpOosUKaIffvhBM2bM0NSpU/X+++9nO+YpU6aoYcOG2r17t5599lk988wz2r9/v12dl19+WaNHj9aePXt07733qmfPnrp27Zpt+fr167V8+XLNnj07Q/vu7u5asmSJFi9erC+//FKpqanq06ePHn74YQ0cODBbbWRHdHS0Dh06pOjoaC1evFiLFi3SokWLcrStp06dUnh4uD766KNM77Ty7rvv6sqVK3rxxRdt++XChQuaNWtWttvID7kaOt68eXNFRkbqv//9Z9hIamqqIiMj1bRpU1MDRObutlmymSEbwI34HAEA5JVq1arp7bffliS9+eabql+/viZOnGhbvmDBAgUEBOiPP/7Q5cuXde3aNXXp0kWBgYGSpDp16tjqzpw5U2PHjtXjjz8uSZo1a5a+/fbbDOsMCAjQtGnTZLFYVL16df3888+aNm2awsPDsxVzhw4d9Oyzz0qSxowZo2nTpik6OlrVq1e31Rk9erQ6duwoSRo/frxq1aqlgwcPqkaNGjp79qz69++vjz/+WD4+Ppmuo169enrzzTf19NNPq0ePHjp69Ki++eYb2/LstHE7JUuW1KxZs+Ti4qIaNWqoY8eOioqKstsPt9pW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vffe0/nz523La9WqZfsyJ0n+/v6qU6eO7bmLi4tKly6t06dP52vcAFBQ0S8DAO4EiTbgBFxcXLR27VqtXr1a9913n2bOnKnq1avr8OHDkqSiRYva1bdYLJmWpaWl5VvMAFCQ0S8DAO4EiTbgJCwWi5o0aaLx48dr9+7dcnV11RdffOHosACg0KJfBgDkFpOhAU5gx44dioqKUtu2beXn56cdO3bozJkzqlmzpvbu3evo8ACg0KFfBgDcCc5oA07Ax8dHmzZtUocOHXTvvffqlVde0ZQpU9S+fXtHhwYAhRL9MgDgTjDrOAAAAAAAJuKMNgAAAAAAJiLRBgAAAADARCTaAAAAAACYiEQbAAAAAAATkWgDAAAAAGAiEm0AAAAAAExEog0AAAAAgIlItAEAAAAAMBGJNuDEFi1apBIlSjg6DADA/0e/DADIDothGIajgwCQucTERF26dEl+fn6ODgUAIPplAED2kGgDTurq1asqWrSoo8MAAPx/9MsAgOxi6DgKjRUrVqhOnTry8PBQ6dKl1aZNG125ckWStGDBAtWqVUtubm4qV66chg0bZnvdhQsX9PTTT6tMmTLy8fFRq1at9NNPP9mWv/7666pXr54++ugjBQUFqXjx4urRo4cuXbpkq7NmzRo1bdpUJUqUUOnSpfXII4/o0KFDtuVHjhyRxWLRsmXLFBoaKnd3dy1ZsiTTIYpz585VlSpV5OrqqurVq+ujjz7K9j6wWCx6//339fjjj8vT01PVqlXTV199ZVuempqqQYMGqVKlSvLw8FD16tU1Y8YMuzb69++vzp07a+LEifL391eJEiX0xhtv6Nq1a3rhhRdUqlQpVaxYUQsXLrR73V9//aXu3burRIkSKlWqlB577DEdOXIk27EDKHjol+mXAaCgItFGoXDy5En17NlTAwcO1O+//64NGzaoS5cuMgxDc+fO1dChQzV48GD9/PPP+uqrr1S1alXba7t166bTp09r9erV2rVrlxo0aKDWrVvr3LlztjqHDh3SypUr9c033+ibb77Rxo0b9dZbb9mWX7lyRREREdq5c6eioqJktVr1+OOPKy0tzS7OF198USNGjNDvv/+usLCwDNvxxRdfaMSIEXr++ef1yy+/aMiQIRowYICio6OzvS/Gjx+v7t27a+/everQoYN69+5t25a0tDRVrFhRy5cv12+//aZx48bppZde0qeffmrXxvr163XixAlt2rRJU6dO1WuvvaZHHnlEJUuW1I4dO/Svf/1LQ4YM0d9//y3p+lmgsLAweXt7a/PmzdqyZYu8vLzUrl07paSkZDt2AAUH/fI/6JcBoAAygEJg165dhiTjyJEjGZaVL1/eePnllzN93ebNmw0fHx8j6f+1dz8hTf9xHMdfUzvk3KKmmXXYKmKYWqBB6DCKdSmIpJKQDtIhAgODmHRY/05damVKRO5gEJJdPCYqhlgTpFFIB6kJCw9Rjgh0hwXl53cIvrUs88/4he75gIGfz/f7fX/f3+/hDW8+n81UKm1++/bt5v79+8YYY65evWry8/PN9PS0dbylpcXs3bv3j/kkEgkjybx+/doYY0w8HjeSTGtra9p5nZ2dZt26dda4pqbGnDlzJu2c+vp6c/jw4T/e62eSzKVLl6xxMpk0kkxvb+8frzl37pw5fvy4NW5sbDRut9t8+/bNmvN6vaa2ttYaf/361djtdvPo0SNjjDEPHz40Xq/XzM7OWud8+fLFrF271vT19S0odwCrC3X5O+oyAKxOrGgjK+zevVt+v18VFRWqr69XOBzW58+fNTU1pffv38vv9//2urGxMSWTSblcLhUUFFifeDyetsXQ4/HI4XBY45KSEk1NTVnjWCymhoYGbdu2TU6nUx6PR5I0OTmZdr89e/bM+xzj4+Py+Xxpcz6fT+Pj4wt6D5K0a9cu62+73S6n05mW6927d1VVVaWioiIVFBSoo6NjTp5lZWXKyflRPoqLi1VRUWGNc3Nz5XK5rLhjY2OamJiQw+Gw3uGGDRuUSqXS3iOA7EFd/oG6DACrT96/TgD4P+Tm5mpgYEAjIyPq7+9Xe3u7gsGgBgcH570umUyqpKREQ0NDc479/B29X38cx2azpW0/PHLkiNxut8LhsDZv3qzZ2VmVl5fP2Z5nt9sX/3CLNF+u3d3dCgQCCoVCqq6ulsPh0I0bNzQ6OvrXGPPFTSaTqqqqUldX15x8ioqKlv1MAFYe6vIP1GUAWH1otJE1bDabfD6ffD6frly5IrfbrYGBAXk8Hg0ODurAgQNzrqmsrNSHDx+Ul5dnrXYs1qdPn/TmzRuFw2HV1tZKkp4/f76kWKWlpYpEImpsbLTmIpGIdu7cuaR4v4pEIqqpqVFTU5M1l4mVjcrKSj1+/FgbN26U0+lcdjwAqwN1+e+oywCwMrF1HFlhdHRU169fVzQa1eTkpHp6epRIJFRaWqpr164pFAqpra1NsVhML1++VHt7uyTp4MGDqq6uVl1dnfr7+/Xu3TuNjIwoGAwqGo0u6N7r16+Xy+VSR0eHJiYm9PTpU124cGFJz9HS0qIHDx7o3r17isViunXrlnp6ehQIBJYU71c7duxQNBpVX1+f3r59q8uXL+vFixfLjnvq1CkVFhbq6NGjevbsmeLxuIaGhtTc3Gz9MA+A7EJdXhjqMgCsTKxoIys4nU4NDw+rtbVV09PTcrvdCoVCOnTokCQplUrp9u3bCgQCKiws1IkTJyR9X2158uSJgsGgTp8+rUQioU2bNmnfvn0qLi5e0L1zcnLU3d2t5uZmlZeXy+v1qq2tTfv371/0c9TV1enOnTu6efOmzp8/r61bt6qzs3NJsX7n7NmzevXqlU6ePCmbzaaGhgY1NTWpt7d3WXHz8/M1PDysixcv6tixY5qZmdGWLVvk9/tZSQGyFHV5YajLALAy2Ywx5l8nAQAAAADAasHWcQAAAAAAMohGG1glurq60v7Vzc+fsrKyf50eAGQd6jIAZC+2jgOrxMzMjD5+/PjbY2vWrJHb7f6fMwKA7EZdBoDsRaMNAAAAAEAGsXUcAAAAAIAMotEGAAAAACCDaLQBAAAAAMggGm0AAAAAADKIRhsAAAAAgAyi0QYAAAAAIINotAEAAAAAyCAabQAAAAAAMug/PIp26oLZ+d8AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>method</th>\n",
       "      <th>scenario_name</th>\n",
       "      <th>valid_calibr_mean</th>\n",
       "      <th>valid_calibr_min</th>\n",
       "      <th>valid_calibr_max</th>\n",
       "      <th>valid_calibr_median</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>resgp_nn4x4_nn16x2</td>\n",
       "      <td>sml</td>\n",
       "      <td>0.078943</td>\n",
       "      <td>0.031094</td>\n",
       "      <td>0.146623</td>\n",
       "      <td>0.068509</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>resgp_nn4x4_nn4x2</td>\n",
       "      <td>sml</td>\n",
       "      <td>0.080160</td>\n",
       "      <td>0.030224</td>\n",
       "      <td>0.146338</td>\n",
       "      <td>0.074996</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>resgp_nn4x4_nn4x4</td>\n",
       "      <td>sml</td>\n",
       "      <td>0.079212</td>\n",
       "      <td>0.023720</td>\n",
       "      <td>0.153002</td>\n",
       "      <td>0.071771</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "               method scenario_name  valid_calibr_mean  valid_calibr_min  \\\n",
       "0  resgp_nn4x4_nn16x2           sml           0.078943          0.031094   \n",
       "1   resgp_nn4x4_nn4x2           sml           0.080160          0.030224   \n",
       "2   resgp_nn4x4_nn4x4           sml           0.079212          0.023720   \n",
       "\n",
       "   valid_calibr_max  valid_calibr_median  \n",
       "0          0.146623             0.068509  \n",
       "1          0.146338             0.074996  \n",
       "2          0.153002             0.071771  "
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "filename_res = os.path.join(os.getcwd(), \"saved_results\", exp_name, 'global') # NOTE\n",
    "models_mean, _ = load_trained_models(\n",
    "    mode='ours', methods=None, ts_data=ts_data,\n",
    "    filename_res=filename_res+'_'+scenario_name_fl)\n",
    "\n",
    "# --- calibration ---\n",
    "for met in results_all_resgp.keys():\n",
    "    if results_all_resgp[met] is None:\n",
    "        continue\n",
    "    assert list(results_all_resgp[met].keys()) == [scenario_name_fl]\n",
    "    # 1. select mean model\n",
    "    mean_method = met.split('_')[1]\n",
    "    model_mean = models_mean[mean_method][scenario_name_fl][criteria[0]]\n",
    "\n",
    "    # 2. calculate env_dict_res\n",
    "    env_dict_res = copy.deepcopy(env_dict)\n",
    "    del env_dict_res['train_scenarios'][scenario_name_fl]['time_series']\n",
    "    res_train_std, res_valid_std = np.zeros(num_clients), np.zeros(num_clients)\n",
    "    res_train_mean, res_valid_mean = np.zeros(num_clients), np.zeros(num_clients)\n",
    "    for client_num in np.arange(num_clients):\n",
    "        x_train, y_train, x_valid, y_valid = env_dict['train_scenarios'][scenario_name_fl]['clients_data'][client_num]\n",
    "        # residual of train\n",
    "        y_train_pred, _ = model_mean.predict(x_train, y_train, x_train)\n",
    "        y_valid_pred, _ = model_mean.predict(x_train, y_train, x_valid)\n",
    "        y_train_pred = y_train_pred.reshape(y_train.shape)\n",
    "        y_valid_pred = y_valid_pred.reshape(y_valid.shape)\n",
    "        data_tup = (x_train, \n",
    "                    y_train-y_train_pred,\n",
    "                    x_valid,\n",
    "                    y_valid-y_valid_pred)\n",
    "\n",
    "        env_dict_res['train_scenarios'][scenario_name_fl]['clients_data'][client_num] = data_tup\n",
    "\n",
    "\n",
    "    # 3. calibr\n",
    "    model = models_all_resgp[met][scenario_name_fl]['rsmse']\n",
    "    data_tups = env_dict_res['train_scenarios'][scenario_name_fl]['clients_data'] # Note\n",
    "    # update train\n",
    "    train_data = [(d[0], d[1], d[0], d[1]) for d in data_tups]\n",
    "    results_all_resgp[met][scenario_name_fl]['calibr'] = {\n",
    "        'criterion_train': model.eval_datasets(train_data, get_full_list=True)['calibr'],\n",
    "        # update valid\n",
    "        'criterion_valid': model.eval_datasets(data_tups, get_full_list=True)['calibr']\n",
    "    }\n",
    "\n",
    "perf_box_plots(env_dict, criterion='calibr', methods=methods, results_all=results_all_resgp)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "ename": "TypeError",
     "evalue": "'NoneType' object is not subscriptable",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mTypeError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[1;32m/home/mahrokhg/Cloned_FL/Federated-Hyper-Posterior-Learning/experiments/PV/6_sep_mk.ipynb Cell 16\u001b[0m in \u001b[0;36m<cell line: 1>\u001b[0;34m()\u001b[0m\n\u001b[0;32m----> <a href='vscode-notebook-cell://ssh-remote%2B128.178.5.87/home/mahrokhg/Cloned_FL/Federated-Hyper-Posterior-Learning/experiments/PV/6_sep_mk.ipynb#ch0000015vscode-remote?line=0'>1</a>\u001b[0m results_all_resgp[\u001b[39m'\u001b[39;49m\u001b[39mresgp_nn32_nn16x4\u001b[39;49m\u001b[39m'\u001b[39;49m][scenario_name_fl][\u001b[39m'\u001b[39m\u001b[39mrsmse\u001b[39m\u001b[39m'\u001b[39m][\u001b[39m'\u001b[39m\u001b[39msetup\u001b[39m\u001b[39m'\u001b[39m][\u001b[39m'\u001b[39m\u001b[39mhyper_prior_dict\u001b[39m\u001b[39m'\u001b[39m]\n",
      "\u001b[0;31mTypeError\u001b[0m: 'NoneType' object is not subscriptable"
     ]
    }
   ],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# combine with mean model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "----- loading shared (shared_nn) models -----\n",
      "\n",
      "[INFO] results of method nn16_nonar loaded.\n",
      "\n",
      "[INFO] results of method lingp loaded.\n",
      "\n",
      "[INFO] results of method nn4x4 loaded.\n",
      "\n",
      "[INFO] results of method nn44 loaded.\n",
      "\n",
      "[INFO] results of method nn4x6 loaded.\n",
      "\n",
      "[INFO] results of method nn8x4 loaded.\n",
      "\n",
      "[INFO] results of method nn4444 loaded.\n",
      "\n",
      "[INFO] results of method nn16 loaded.\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA9oAAAHvCAYAAACrP6dwAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAACDQklEQVR4nOzdeVxUZf//8fcwCgwibgiKEoqau6l4a4amqYlLllmaprkV+s0su80yb7dcbs1cc0nTcsmszKXlzrQSMZPIMrTsLk1cSxPUVFwAlTm/P/wxtyOggAdmgNfz8fAhc53rXOdzzgwX5zPnOtexGIZhCAAAAAAAmMLD1QEAAAAAAFCYkGgDAAAAAGAiEm0AAAAAAExEog0AAAAAgIlItAEAAAAAMBGJNgAAAAAAJiLRBgAAAADARCTaAAAAAACYiEQbAAAAAAATkWgDAIoci8WiV155JcfrHT58WBaLRcuXLzc9ptuxcuVK1apVS8WLF1fp0qVdHQ4AAEUeiTYAwCWWL18ui8Uii8Wi7du3Z1huGIaCg4NlsVj0wAMPuCDC3Nu6datj3ywWi4oXL67Q0FD17dtXBw8eNHVbe/fuVf/+/VWtWjUtWbJEixcvNrV9AACQc8VcHQAAoGjz9vbWe++9pxYtWjiVf/311/rzzz/l5eXloshu33PPPad//OMfunLliuLi4rR48WJt2LBBe/bsUVBQkCnb2Lp1q+x2u15//XVVr17dlDYBAMDt4Yo2AMClOnXqpDVr1ujq1atO5e+9957CwsJUoUIFF0V2+1q2bKk+ffpowIABmjdvnmbMmKG///5bK1asuO22L168KElKTEyUJFOHjF+6dMm0tgAAKIpItAEALtWrVy+dPn1aX331laPs8uXLWrt2rR5//PFM17l48aJeeOEFBQcHy8vLSzVr1tSMGTNkGIZTvdTUVP3zn/9U+fLlVbJkST344IP6888/M23z2LFjGjhwoAIDA+Xl5aW6detq6dKl5u2opDZt2kiSDh065CjbuHGjWrZsqRIlSqhkyZLq3Lmz/vvf/zqt179/f/n6+urAgQPq1KmTSpYsqd69e6tKlSoaP368JKl8+fIZ7j1/4403VLduXXl5eSkoKEjPPPOMzp4969R269atVa9ePf3444+699575ePjo3/961+O+9FnzJihBQsWKDQ0VD4+Pmrfvr3++OMPGYahSZMmqXLlyrLZbHrooYf0999/O7X9ySefqHPnzgoKCpKXl5eqVaumSZMmKS0tLdMYfv31V913333y8fFRpUqV9Nprr2U4hikpKXrllVd05513ytvbWxUrVlS3bt104MABRx273a45c+aobt268vb2VmBgoAYPHqwzZ85k/80CAOA2MHQcAOBSVapUUfPmzfX++++rY8eOkq4ln+fOnVPPnj01d+5cp/qGYejBBx9UdHS0nnzySTVs2FBffPGFXnzxRR07dkyzZ8921H3qqaf07rvv6vHHH9c999yjLVu2qHPnzhliSEhI0N133y2LxaKhQ4eqfPny2rhxo5588kklJSXp+eefN2Vf05PBcuXKSbo2iVm/fv0UERGhadOm6dKlS1q4cKFatGihXbt2qUqVKo51r169qoiICLVo0UIzZsyQj4+P+vfvr3feeUcfffSRFi5cKF9fXzVo0ECS9Morr2jChAlq166dnn76ae3bt08LFy7UDz/8oJiYGBUvXtzR9unTp9WxY0f17NlTffr0UWBgoGPZqlWrdPnyZT377LP6+++/9dprr6lHjx5q06aNtm7dqpEjRyo+Pl7z5s3TiBEjnL6cWL58uXx9fTV8+HD5+vpqy5YtGjdunJKSkjR9+nSnY3PmzBl16NBB3bp1U48ePbR27VqNHDlS9evXd3wu0tLS9MADDygqKko9e/bUsGHDdP78eX311Vf65ZdfVK1aNUnS4MGDtXz5cg0YMEDPPfecDh06pPnz52vXrl0Z9h0AgDxhAADgAsuWLTMkGT/88IMxf/58o2TJksalS5cMwzCM7t27G/fdd59hGIYREhJidO7c2bHexx9/bEgyJk+e7NTeo48+algsFiM+Pt4wDMPYvXu3IckYMmSIU73HH3/ckGSMHz/eUfbkk08aFStWNE6dOuVUt2fPnkapUqUccR06dMiQZCxbtuym+xYdHW1IMpYuXWqcPHnSOH78uLFhwwajSpUqhsViMX744Qfj/PnzRunSpY3IyEindU+cOGGUKlXKqbxfv36GJOPll1/OsK3x48cbkoyTJ086yhITEw1PT0+jffv2RlpamqN8/vz5jrjStWrVypBkLFq0yKnd9H0tX768cfbsWUf5qFGjDEnGXXfdZVy5csVR3qtXL8PT09NISUlxlKUft+sNHjzY8PHxcaqXHsM777zjKEtNTTUqVKhgPPLII46ypUuXGpKMWbNmZWjXbrcbhmEY33zzjSHJWLVqldPyTZs2ZVoOAEBeYOg4AMDlevTooeTkZH322Wc6f/68PvvssyyHjX/++eeyWq167rnnnMpfeOEFGYahjRs3OupJylDvxqvThmFo3bp16tKliwzD0KlTpxz/IiIidO7cOcXFxeVqvwYOHKjy5csrKChInTt31sWLF7VixQo1adJEX331lc6ePatevXo5bdNqtapZs2aKjo7O0N7TTz+dre1u3rxZly9f1vPPPy8Pj//9qY+MjJSfn582bNjgVN/Ly0sDBgzItK3u3burVKlSjtfNmjWTJPXp00fFihVzKr98+bKOHTvmKLPZbI6fz58/r1OnTqlly5a6dOmS9u7d67QdX19f9enTx/Ha09NTTZs2dZqlfd26dfL399ezzz6bIU6LxSJJWrNmjUqVKqX777/f6biGhYXJ19c30+MKAIDZGDoOAHC58uXLq127dnrvvfd06dIlpaWl6dFHH8207pEjRxQUFKSSJUs6ldeuXduxPP1/Dw8Px3DidDVr1nR6ffLkSZ09e1aLFy/O8tFY6ROO5dS4cePUsmVLWa1W+fv7q3bt2o7kdP/+/ZL+d9/2jfz8/JxeFytWTJUrV87WdtOPwY376unpqdDQUMfydJUqVZKnp2embd1xxx1Or9OT7uDg4EzLr78P+r///a/GjBmjLVu2KCkpyan+uXPnnF5XrlzZkSynK1OmjH7++WfH6wMHDqhmzZpOCf6N9u/fr3PnzikgICDT5bl9LwEAyAkSbQCAW3j88ccVGRmpEydOqGPHjqbOon0zdrtd0rUrtP369cu0Tvp9zzlVv359tWvX7qbbXblyZaYzq9+YTHp5eTldnTbT9Veeb2S1WnNUbvz/CenOnj2rVq1ayc/PTxMnTlS1atXk7e2tuLg4jRw50rH/2W0vu+x2uwICArRq1apMl5cvXz5H7QEAkBsk2gAAt/Dwww9r8ODB+u6777R69eos64WEhGjz5s06f/6801Xt9KHIISEhjv/tdrvjKmi6ffv2ObWXPiN5WlpalklxXki/0h4QEGD6dtOPwb59+xQaGuoov3z5sg4dOpQv+7l161adPn1a69ev17333usov37G9ZyqVq2aduzYoStXrmQ5oVm1atW0efNmhYeH3/QLBAAA8hL3aAMA3IKvr68WLlyoV155RV26dMmyXqdOnZSWlqb58+c7lc+ePVsWi8UxQ3X6/zfOWj5nzhyn11arVY888ojWrVunX375JcP2Tp48mZvduaWIiAj5+flpypQpunLliqnbbdeunTw9PTV37lynK8Jvv/22zp07l+nM62ZLv0J9/fYvX76sN954I9dtPvLIIzp16lSG9/767fTo0UNpaWmaNGlShjpXr17N8HgzAADyAle0AQBuI6uh29fr0qWL7rvvPo0ePVqHDx/WXXfdpS+//FKffPKJnn/+eceV4oYNG6pXr1564403dO7cOd1zzz2KiopSfHx8hjZfffVVRUdHq1mzZoqMjFSdOnX0999/Ky4uTps3b87wfGgz+Pn5aeHChXriiSfUuHFj9ezZU+XLl9fRo0e1YcMGhYeHZ5pQZkf58uU1atQoTZgwQR06dNCDDz6offv26Y033tA//vEPp0nH8so999yjMmXKqF+/fnruuedksVi0cuXKHA8Fv17fvn31zjvvaPjw4fr+++/VsmVLXbx4UZs3b9aQIUP00EMPqVWrVho8eLCmTp2q3bt3q3379ipevLj279+vNWvW6PXXX8/y/n8AAMxCog0AKFA8PDz06aefaty4cVq9erWWLVumKlWqaPr06XrhhRec6i5dulTly5fXqlWr9PHHH6tNmzbasGFDhom8AgMD9f3332vixIlav3693njjDZUrV05169bVtGnT8mxfHn/8cQUFBenVV1/V9OnTlZqaqkqVKqlly5ZZzgKeXa+88orKly+v+fPn65///KfKli2rQYMGacqUKfnyHOly5crps88+0wsvvKAxY8aoTJky6tOnj9q2bauIiIhctWm1WvX555/r3//+t9577z2tW7dO5cqVU4sWLVS/fn1HvUWLFiksLExvvvmm/vWvf6lYsWKqUqWK+vTpo/DwcLN2EQCALFmM2/lqGQAAAAAAOOEebQAAAAAATESiDQAAAACAiUi0AQAAAAAwEYk2AAAAAAAmItEGAAAAAMBEJNoAAAAAAJiIRBsAAAAAABORaAMAAAAAYCISbQAAAAAATESiDQAAAACAiUi0AQAAAAAwEYk2AAAAAAAmItEGAAAAAMBEJNoAAAAAAJiIRBsAAAAAABORaAMAAAAAYCISbQAAAAAATESiDQAAAACAiUi0AQAAAAAwEYk2AAAAAAAmItEGAAAAAMBEJNoAAAAAAJiIRBsAAAAAABORaCNHli9fLovFosOHD7s6lHy3detWWSwWbd26NcfrFuXjVhTdzmcFuB1Fua+hj8bNtG7dWq1bt3a8Pnz4sCwWi5YvX37Ldfv3768qVarkWWwACicSbQBF0htvvJGtE6zCaMqUKfr4449dHQYAIAtF+W8UUFiQaCNHnnjiCSUnJyskJMTVoQC3JS9PYu69914lJyfr3nvvzZP2bxeJduFFHw1kT0hIiJKTk/XEE0+4OpRMkWgDBR+JNrLl4sWLkiSr1Spvb29ZLBYXR4R0hmEoOTnZ1WEUaumf/+zy8PCQt7e3PDzoYpE/6KPdF320e7JYLPL29pbVanV1KAAKKc4Cc+nYsWN68sknFRQUJC8vL1WtWlVPP/20Ll++7Khz8OBBde/eXWXLlpWPj4/uvvtubdiwwamd9HvKPvzwQ02YMEGVKlVSyZIl9eijj+rcuXNKTU3V888/r4CAAPn6+mrAgAFKTU11asNisWjo0KFatWqVatasKW9vb4WFhWnbtm1O9Y4cOaIhQ4aoZs2astlsKleunLp3757hnrT0e9W+/vprDRkyRAEBAapcubLTsuvXqVKlih544AFt375dTZs2lbe3t0JDQ/XOO+9kOG4///yzWrVqJZvNpsqVK2vy5MlatmxZtu6N69+/v3x9fXX06FE98MAD8vX1VaVKlbRgwQJJ0p49e9SmTRuVKFFCISEheu+99zK0kZ33RJL+/PNPde3aVSVKlFBAQID++c9/Zjju6Xbs2KEOHTqoVKlS8vHxUatWrRQTE3PTfZGknTt3KiIiQv7+/rLZbKpataoGDhx4y/XSj/cXX3yhJk2ayGaz6c0335QkffXVV2rRooVKly4tX19f1axZU//6178c65rxebvVNiQpNTVV48ePV/Xq1eXl5aXg4GC99NJLWR7DG61Zs0ZhYWGy2Wzy9/dXnz59dOzYMac66Z+HY8eOqWvXrvL19VX58uU1YsQIpaWl3fIY/ve//9XXX38ti8Uii8XiuHfvZp//7P4OZXavaOvWrVWvXj39+uuvuu++++Tj46NKlSrptddey9YxMeu4WywWXbx4UStWrHDse//+/bMVQ0FCH/2/deij6aMLWh/9wAMPKDQ0NNNlzZs3V5MmTRyvly1bpjZt2iggIEBeXl6qU6eOFi5ceMt9yOoe7Y8//lj16tWTt7e36tWrp48++uiWbaXLzmfGbrdrzpw5qlu3rry9vRUYGKjBgwfrzJkzjjo3+xsFoOAo5uoACqLjx4+radOmOnv2rAYNGqRatWrp2LFjWrt2rS5duiRPT08lJCTonnvu0aVLl/Tcc8+pXLlyWrFihR588EGtXbtWDz/8sFObU6dOlc1m08svv6z4+HjNmzdPxYsXl4eHh86cOaNXXnlF3333nZYvX66qVatq3LhxTut//fXXWr16tZ577jl5eXnpjTfeUIcOHfT999+rXr16kqQffvhB3377rXr27KnKlSvr8OHDWrhwoVq3bq1ff/1VPj4+Tm0OGTJE5cuX17hx4255RS8+Pl6PPvqonnzySfXr109Lly5V//79FRYWprp160q6duJ73333yWKxaNSoUSpRooTeeusteXl5ZfvYp6WlqWPHjrr33nv12muvadWqVRo6dKhKlCih0aNHq3fv3urWrZsWLVqkvn37qnnz5qpataokZfs9SU5OVtu2bXX06FE999xzCgoK0sqVK7Vly5YM8WzZskUdO3ZUWFiYxo8fLw8PD8cf/W+++UZNmzbNdD8SExPVvn17lS9fXi+//LJKly6tw4cPa/369dk6Dvv27VOvXr00ePBgRUZGqmbNmvrvf/+rBx54QA0aNNDEiRPl5eWl+Pj4TE8oc/t5y8427Ha7HnzwQW3fvl2DBg1S7dq1tWfPHs2ePVu///77LYcsL1++XAMGDNA//vEPTZ06VQkJCXr99dcVExOjXbt2qXTp0o66aWlpioiIULNmzTRjxgxt3rxZM2fOVLVq1fT0009nuY05c+bo2Wefla+vr0aPHi1JCgwMdKqT2ec/p79DNzpz5ow6dOigbt26qUePHlq7dq1Gjhyp+vXrq2PHjlmuZ+ZxX7lypZ566ik1bdpUgwYNkiRVq1btpnEXNPTRGdFH00enKwh99GOPPaa+ffvqhx9+0D/+8Q9H+ZEjR/Tdd99p+vTpjrKFCxeqbt26evDBB1WsWDH95z//0ZAhQ2S32/XMM8/c6q1y8uWXX+qRRx5RnTp1NHXqVJ0+fVoDBgxwfJF1M9n9zAwePNhxDJ977jkdOnRI8+fP165duxQTE6PixYtn628UgALAQI717dvX8PDwMH744YcMy+x2u2EYhvH8888bkoxvvvnGsez8+fNG1apVjSpVqhhpaWmGYRhGdHS0IcmoV6+ecfnyZUfdXr16GRaLxejYsaNT+82bNzdCQkKcyiQZkoydO3c6yo4cOWJ4e3sbDz/8sKPs0qVLGeKNjY01JBnvvPOOo2zZsmWGJKNFixbG1atXneqnLzt06JCjLCQkxJBkbNu2zVGWmJhoeHl5GS+88IKj7NlnnzUsFouxa9cuR9np06eNsmXLZmgzM/369TMkGVOmTHGUnTlzxrDZbIbFYjE++OADR/nevXsNScb48eMdZdl9T+bMmWNIMj788ENHvYsXLxrVq1c3JBnR0dGGYVx7r2vUqGFEREQ43nfDuHacq1atatx///1ZHrePPvrIkJTpZ+hW0o/3pk2bnMpnz55tSDJOnjyZ5bq3+3nLzjZWrlxpeHh4OB1nwzCMRYsWGZKMmJiYLNe9fPmyERAQYNSrV89ITk52lH/22WeGJGPcuHGOsvTPw8SJE53aaNSokREWFpblNtLVrVvXaNWqVYbym33+s/s7lH6c0z8rhmEYrVq1ylAvNTXVqFChgvHII4/cNFazj3uJEiWMfv363XSbBRl9NH20YdBHZ6Ug9NHnzp3L8Pk0DMN47bXXDIvFYhw5csRRltnvTUREhBEaGupU1qpVK6c+/9ChQ4YkY9myZY6yhg0bGhUrVjTOnj3rKPvyyy8NSRl+r2+Unc/MN998Y0gyVq1a5VS+adOmDOVZ/Y0CUHAwdDyH7Ha7Pv74Y3Xp0sVp6FK69PviPv/8czVt2lQtWrRwLPP19dWgQYN0+PBh/frrr07r9e3bV8WLF3e8btasmQzDyDDkqFmzZvrjjz909epVp/LmzZsrLCzM8fqOO+7QQw89pC+++MIxRMtmszmWX7lyRadPn1b16tVVunRpxcXFZdiXyMjIbN+7VKdOHbVs2dLxunz58qpZs6YOHjzoKNu0aZOaN2+uhg0bOsrKli2r3r17Z2sb6Z566inHz6VLl1bNmjVVokQJ9ejRw1Fes2ZNlS5d2mn72X1PPv/8c1WsWFGPPvqoo56Pj4/j6l+63bt3a//+/Xr88cd1+vRpnTp1SqdOndLFixfVtm1bbdu2TXa7PdN9SP/G/7PPPtOVK1dytP+SVLVqVUVERGTa5ieffJLldtPl9vOWnW2sWbNGtWvXVq1atRzH5NSpU2rTpo0kKTo6Osu4du7cqcTERA0ZMkTe3t6O8s6dO6tWrVqZDiH9v//7P6fXLVu2dHrfcyuzz39Of4du5Ovrqz59+jhee3p6qmnTpreMN6+Pe2FCH505+mj66HQFoY/28/NTx44d9eGHH8owDEf56tWrdffdd+uOO+5wlF3/e3Pu3DmdOnVKrVq10sGDB3Xu3Lmbbud6f/31l3bv3q1+/fqpVKlSjvL7779fderUueX62fnMrFmzRqVKldL999/vdOzDwsLk6+tbZPppoKgg0c6hkydPKikpyTHULytHjhxRzZo1M5TXrl3bsfx61//RkOTo5IODgzOU2+32DH88atSokWFbd955py5duqSTJ09Kujbcbty4cQoODpaXl5f8/f1Vvnx5nT17NtM/RunD+bLjxvglqUyZMk73HB05ckTVq1fPUC+zsqx4e3urfPnyTmWlSpVS5cqVM0z+U6pUqQzbz857kh7nje3duO7+/fslSf369VP58uWd/r311ltKTU3N8o98q1at9Mgjj2jChAny9/fXQw89pGXLlmX7/rjM3pvHHntM4eHheuqppxQYGKiePXvqww8/zPRkK7eft+xsY//+/frvf/+b4Zjceeedkq4Nr8tK+nuQ2ftUq1atDL83mX0ebvzc5VZmxzinv0M3yuxzmp148/q4Fyb00Zmjj6aPvv64FIQ++rHHHtMff/yh2NhYSdKBAwf0448/6rHHHnOqFxMTo3bt2qlEiRIqXbq0ypcv77gnPSeJdnrsmf2uZra/N8rOZ2b//v06d+6cAgICMhz/CxcuFJl+GigquEfbTWR1VSKr8uu/4c2uZ599VsuWLdPzzz+v5s2bq1SpUrJYLOrZs2emf+iv/5b4VsyMMzfbya/tXy/9mE2fPt3pCtD1fH19My23WCxau3atvvvuO/3nP//RF198oYEDB2rmzJn67rvvslwvXWbvjc1m07Zt2xQdHa0NGzZo06ZNWr16tdq0aaMvv/zS6Rjl9jhmZxt2u13169fXrFmzMm3rxhPF25GXs8Vmdoxz+jt0o9x+Tt3tuBdF9NG3tx36aPronOrSpYt8fHz04Ycf6p577tGHH34oDw8Pde/e3VHnwIEDatu2rWrVqqVZs2YpODhYnp6e+vzzzzV79uxs9ctmyc5nxm63KyAgQKtWrcq0jRu/lABQsJFo51D58uXl5+enX3755ab1QkJCtG/fvgzle/fudSw3U/o399f7/fff5ePj4+i4165dq379+mnmzJmOOikpKTp79qypsWQlJCRE8fHxGcozK8ur7WfnPQkJCdEvv/wiwzCcrpjcuG76BFJ+fn5q165drmK6++67dffdd+vf//633nvvPfXu3VsffPCB09DLnPDw8FDbtm3Vtm1bzZo1S1OmTNHo0aMVHR2d6xhzuo1q1arpp59+Utu2bXP8iKH092Dfvn2OYYzp9u3bZ+rvTW4ef+TK3yEzj3thfvQTfXTu0UdnRB/tLD/76BIlSuiBBx7QmjVrNGvWLK1evVotW7ZUUFCQo85//vMfpaam6tNPP3UaBZCbIdjpsWf2u5rZ5zIrN/vMVKtWTZs3b1Z4ePgtvygrzP00UFQwdDyHPDw81LVrV/3nP//Rzp07MyxP/1a5U6dO+v777x1DnqRrzzldvHixqlSpkq37fXIiNjbW6R6+P/74Q5988onat2/v+EbZarVmuHowb968Wz5mwywRERGKjY3V7t27HWV///13lt/smi2770mnTp10/PhxrV271lHv0qVLWrx4sVN7YWFhqlatmmbMmKELFy5k2F76cNDMnDlzJsN7kX7FJbtDE2/0999/Zyi73TZzs40ePXro2LFjWrJkSYa6ycnJN50duUmTJgoICNCiRYucYt64caN+++03de7c+Tb34H9KlCiR4wTGVb9DZh/33Ox7QUEfnXv00f9DH525/OyjpWvDx48fP6633npLP/30U4Zh4+m/O9e/V+fOndOyZctyvK2KFSuqYcOGWrFihdOQ86+++irDnA2Zyc5npkePHkpLS9OkSZMyrH/16lWnfrkw99NAUcEV7VyYMmWKvvzyS7Vq1crxaIy//vpLa9as0fbt21W6dGm9/PLLev/999WxY0c999xzKlu2rFasWKFDhw5p3bp18vAw9zuOevXqKSIiwunRMZI0YcIER50HHnhAK1euVKlSpVSnTh3FxsZq8+bNKleunKmxZOWll17Su+++q/vvv1/PPvus49Exd9xxh/7+++88//Y2u+9JZGSk5s+fr759++rHH39UxYoVtXLlygyP1vHw8NBbb72ljh07qm7duhowYIAqVaqkY8eOKTo6Wn5+fvrPf/6TaSwrVqzQG2+8oYcffljVqlXT+fPntWTJEvn5+alTp0652r+JEydq27Zt6ty5s0JCQpSYmKg33nhDlStXdppc6HZkZxtP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J07UiRMnlJKSos2bN+vOO+/McVwAAHM0adJEDz/8sNNjIDt37qzw8HAXRgUAKKxWrFghT09PxcTE6NVXX1WbNm3UqFEj7dy5U5s2bVJCQoIjifzrr7/Uq1cvDRw4UL/99pu2bt2qbt26OZLkadOmadWqVVq2bJliYmKUlJSUIf9I32axYsX0/fff6/XXX9esWbP01ltvZTvmmTNnqkmTJtq1a5eGDBmip59+Wvv27XOqM3r0aI0YMUK7d+/WnXfeqV69eunq1auO5Vu2bNGaNWu0YMGCDO17e3tr1apVWrFihT755BOlpaWpT58+uv/++zVw4MBstZEd0dHROnDggKKjo7VixQotX748Qz53q31NSEhQZGSkVq5cmemkiHPnztXFixf18ssvO47L2bNnNX/+/Czjuv725/yQ68d7NWnSRE2aNHEq69y5820HBAAoXAzD0Nq1axUdHa3ExMQMk+jk57fLAICioUaNGnrttdckSZMnT1ajRo00ZcoUx/KlS5cqODhYv//+uy5cuKCrV6+qW7duCgkJkSSnUbrz5s3TqFGj9PDDD0uS5s+fr88//zzDNoODgzV79mxZLBbVrFlTe/bs0ezZsxUZGZmtmDt16qQhQ4ZIkkaOHKnZs2crOjpaNWvWdNQZMWKEI+eaMGGC6tatq/j4eNWqVUunT59W//799e6772b5RI6GDRtq8uTJeuqpp9SzZ08dOXJEn332mWN5dtq4lTJlymj+/PmyWq2qVauWOnfurKioKKfjcLN9NQxD/fv31//93/+pSZMmOnz4cIZt+Pr66t1331WrVq1UsmRJzZkzR9HR0VnGHB8fr3nz5uXbsHEpl4k2J00AgOx6/vnn9eabb+q+++5TYGAgz2QFAOS5sLAwx88//fSToqOjnUZVpTtw4IDat2+vtm3bqn79+oqIiFD79u316KOPqkyZMjp37pwSEhLUtGlTxzpWq1VhYWEZcqC7777b6W9c8+bNNXPmTKWlpWXrHvMGDRo4frZYLKpQoYISExOzrJP+hKXExETVqlVLkZGRevzxx3XvvffedDsvvPCCPv74Y82fP18bN25UuXLlHMuy28bN1K1b12l/K1asmGFC65vt67x583T+/HmNGjXqpttp3ry5RowYoUmTJmnkyJFq0aJFpvWOHTumDh06qHv37tn+0sMMuUq0OWkCAGTXypUr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3vr44481evRoxzM4165dq3vuucfF0QHIDcMwlJycbHq717eZF+3bbDZZLBbT2y0q7Ha7EhIT9P789/Ml8U1LS1Ovob1kt9tva3uXL18uUhNvXrlyRb169VLLli317bffuqwNM7z00ksKCgrSTz/95NI2ciPXj/fipAkAcCtpaWk6e/astm3bpjJlyjgtmz59OlcogAIqOTlZjRs3ztNthIeHm95mXFycfHx8TG+3qLFarSpWLFdpRL5o3bq16tWrp2LFiundd99V/fr1NW/ePL344ov65ptvVKJECbVv316zZ8+Wv7+/pGt5zIQJExQfHy8fHx81atRIn3zyiUqUKKGrV69q+PDheuedd2S1WvXUU0/pxIkTOnfunD7++GOnbUrSypUrVbx4cT399NOaOHFitr7cqVKligYNGqT4+HitWbNGZcqU0ZgxYzRo0CBJ0uHDh1W1alWtW7dO8+bN044dO1SjRg0tWrRIzZs3d2przJgxqlWrltq2beuUJKekpCgsLEzh4eFavHixJOnAgQNq2LChXn/9dQ0cOPCWbdxK//79dfbsWbVo0UIzZ87U5cuXHbcWFy9ePFv7mm7jxo368ssvtW7dOm3cuNFp2cCBA7Vz50798MMP8vLy0uXLl9WsWTPVr19f77zzTrbayGs5ngzt+pOmc+fOafz48Y5l06dP14oVK0wNEABQcFmtVrVv3z7TIWfe3t6OP7oAAJhpxYoV8vT0VExMjF599VW1adNGjRo10s6dO7Vp0yYlJCSoR48ekqS//vpLvXr10sCBA/Xbb79p69at6tatmwzDkCRNmzZNq1at0rJlyxQTE6OkpCRHgn3jNosVK6bvv/9er7/+umbNmqW33nor2zHPnDlTTZo00a5duzRkyBA9/fTT2rdvn1Od0aNHa8SIEdq9e7fuvPNO9erVS1evXnUs37Jli9asWaMFCxZkaN/b21urVq3SihUr9MknnygtLU19+vTR/fff75Rk36yN7IiOjtaBAwcUHR2tFStWaPny5Vq+fHmO9jUhIUGRkZFauXJlpl+OzZ07VxcvXtTLL7/sOC5nz57V/Pnzs91GXsvxV1HpJ02//fZbhqsT3t7epgUGACgc6tWrp4MHD6pq1aquDgWASWw2m+Li4kxv1zAMpaSkSLp2Xmn2MG+bzWZqe3BfNWrU0GuvvSZJmjx5sho1aqQp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vAoHAAAgX+U60T579qy+//57JSYmZph5sG/fvpI4aQKAoqphw4ayWCwyDOOWj+nLr+exAgAA5JdcJdr/+c9/1Lt3b124cEF+fn5OJ1EWi8WRaAMAiqZDhw45ft61a5dGjBihF198Uc2bN5ckxcbGaubMmXrttddcFSIAAECeyVWi/cILL2jgwIGaMmUKz04GAGQQEhLi+Ll79+6aO3euOnXq5Chr0KCBgoODNXbsWHXt2tUFEQIAAOSdXCXax44d03PPPUeSDQC4pT179qhq1aoZyqtWrapff/3VBREBAHIrLS0tw22jecnDw6PIPbcbhUOuEu2IiAjt3LlToaGhZscDAChkateuralTp+qtt96Sp6enJOny5cuaOnWqateu7eLoAADZlZaWpjatWynh5Kl822ZgeX9t2fo1yXYOxcfHq1GjRrJarTp79qzL2sitf//739qwYYN2794tT0/PLLe/fPlyzZo1S7///rv8/PzUvXt3LViwIFvbOHz4sCZNmqQtW7boxIkTCgoKUp8+fTR69GjH+crtyFWi3blzZ7344ov69ddfVb9+fRUvXtxp+YMPPnjbgQEACodFixapS5cuqly5smOG8Z9//lkWi0X/+c9/XBwdACC77Ha7Ek6e0tp/PqFiHnn/lOCrdrsenb1Sdrv9thLty5cvm5I4FRRXrlxRr1691LJlS3377bcua+N2XL58Wd27d1fz5s319ttvZ1pn1qxZmjlzpqZPn65mzZrp4sWLOnz4cLa3sXfvXtntdr355puqXr26fvnlF0VGRurixYuaMWPGbe9Drn5DIiMj9ccff2jixInq3r27unbt6vj38MMP33ZQAIDCo2nTpjp48KAmT56sBg0aqEGDBvr3v/+tgwcPqmnTpq4ODwCQQ8U8PFTMmg//cpnMt27dWkOHDtXzzz8vf39/RURE6JdfflHHjh3l6+urwMBAPfHEEzp16n9X5teuXav69evLZrOpXLlyateunS5evChJunr1qp577jmVLl1a5cqV08iRI9WvXz+nOUbStzl06FCVKlVK/v7+Gjt2rAzDyFbMVapU0ZQpUzRw4ECVLFlSd9xxhxYvXuxYfvjwYVksFq1fv1733XeffHx8dNdddyk2NjZDW2PGjFGtWrXUo0cPp/KUlBTVrVtXgwYNcpQdOHBAJUuW1NKlS7PVxq30799fXbt21YwZM1SxYkWVK1dOzzzzjK5cuZLtfZWkCRMm6J///Kfq16+f6XbOnDmjMWPG6J133tHjjz+uatWqqUGDBk4XfAcOHKgGDRooNTVV0rXkvVGjRo6Juzt06KBly5apffv2Cg0N1YMPPqgRI0Zo/fr1OdrnrOTq02u327P8x2NaAAA3KlGihAYNGqRZs2Zp1qxZioyMVIkSJVwdFgCgkFqxYoU8PT0VExOjV199VW3atFGjRo20c+dObdq0SQkJCY4k8q+//lKvXr00cOBA/fbbb9q6dau6devmSJKnTZumVatWadmyZYqJiVFSUpI+/vjjTLdZrFgxff/993r99dc1a9YsvfXWW9mOeebMmWrSpIl27dqlIUOG6Omnn9a+ffuc6owePVojRozQ7t27deedd6pXr166evWqY/mWLVu0Zs2aTIdPe3t7a9WqVVqxYoU++eQTpaWlqU+fPrr//vs1cODAbLWRHdHR0Tpw4ICio6O1YsUKLV++XMuXL8/xvt7MV199JbvdrmPHjql27dqqXLmyevTooT/++MNRZ+7cubp48aJefvllSdeO3dmzZzV//vws2z137pzKli2bsx3OQq6fow0AQFY+/fRTdezYUcWLF9enn35607rcbgQAMFuNGjUcj5CcPHmyGjVqpClTpjiWL126VMHBwfr999914cIFXb16Vd26dXM8NeP6K6nz5s3TqFGjHCN358+fr88//zzDNoODgzV79mxZLBbVrFlTe/bs0ezZsxUZGZmtmDt16qQhQ4ZIkkaOHKnZs2crOjpaNWvWdNQZMWKEOnfuLOnaVd+6desqPj5etWrV0unTp9W/f3+9++678vPzy3QbDRs21OTJk/XUU0+pZ8+eOnLkiD777DPH8uy0cStlypTR/PnzZbVaVatWLXXu3FlRUVFOxyE7+3ozBw8elN1u15QpU/T666+rVKlSGjNmjO6//379/PPP8vT0lK+vr9599121atVKJUuW1Jw5cxQdHZ3lfsXHx2vevHmmDBuXcpBoz507V4MGDZK3t7fmzp1707rPPffcbQcGACi4unbtqhMnTiggIOCmj++yWCyMhAIAmC4sLMzx808//aTo6Gj5+vpmqHfgwAG1b99ebdu2Vf369RUREaH27dvr0UcfVZkyZXTu3DklJCQ43epktVoVFhaWYfb1u+++WxaLxfG6efPmmjlzptLS0rJ1j3n6PCbStb+PFSpUUGJiYpZ1KlasKElKTExUrVq1FBkZqccff1z33nvvTbfzwgsv6OOPP9b8+fO1ceNGlStXzrEsu23cTN26dZ32t2LFitqzZ0+W+5HVvt6M3W7XlStXNHfuXLVv316S9P7776tChQqKjo5WRESEpGvvwYgRIzRp0iSNHDlSLVq0yLS9Y8eOqUOHDurevXu2vxi5lWwn2rNnz1bv3r3l7e2t2bNnZ1nPYrGQaANAEXf9yUd+PgYGAABJTrcnXbhwQV26dNG0adMy1KtYsaKsVqu++uorffvtt/ryyy81b948jR49Wjt27DBtGHF23DjBtMViyfA39Po66Ul9ep0tW7bo008/dVyRNQxDdrtdxYoV0+LFix3DwxMTE/X777/LarVq//796tChg6PN7LZh5n5kVedm0r9kqFOnjqOsfPny8vf319GjRx1ldrtdMTExslqtio+Pz7St48eP67777tM999yT4V7x25HtRPvQoUOZ/gwAAAAA7qpx48Zat26dqlSpomLFMk9/LBaLwsPDFR4ernHjxikkJEQfffSRhg8frsDAQP3www+Oq7xpaWmKi4tTw4YNndrYsWOH0+vvvvtONWrUyLdHk8XGxjqNEvvkk080bdo0ffvtt6pUqZKjfODAgapfv76efPJJRUZGql27do7HbWa3DVcLDw+XJO3bt0+VK1eWJP399986deqUY/i/JE2fPl179+7V119/rYiICC1btkwDBgxwLD927Jjuu+8+hYWFadmyZfIwcTZ97tEGAJjuVrcYXY9RUACAvPTMM89oyZIl6tWrl1566SWVLVtW8fHx+uCDD/TWW29p586dioqKUvv27RUQEKAdO3bo5MmTjuTz2Wef1dSpU1W9enXVqlVL8+bN05kzZ5yGiUvS0aNHNXz4cA0ePFhxcXGaN2+eZs6cmW/7mR5vup07d8rDw0P16tVzlC1YsECxsbH6+eefFRwcrA0bNqh379767rvv5Onpma028sPRo0f1999/6+jRo0pLS9Pu3bslSdWrV5evr6/uvPNOPfTQQxo2bJgWL14sPz8/jRo1SrVq1dJ9990nSdq1a5fGjRuntWvXKjw8XLNmzdKwYcPUqlUrhYaG6tixY2rdurVCQkI0Y8YMnTx50rH9ChUq3PY+5DrR/vPPP/Xpp5/q6NGjunz5stOy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75tvvjH8/PyMlJQUp/Jq1aoZb775pmEYhjF+/HjDx8fHSEpKcix/8cUXjWbNmmUZz8mTJw1Jxp49ewzDMIxDhw4Zkow5c+Y41Vu2bJlRqlQpx+t77rnHiIyMdKrTvXt3o1OnTllu63qSjDFjxjheX7hwwZBkbNy4Mct1nnnmGeORRx5xvO7Xr58REhJipKWlOcpq1qxptGzZ0vH66tWrRokSJYz333/fMAzDWLlypVGzZk3Dbrc76qSmpho2m8344osvshU7gMKPvvoa+moAKNy4oo1C46677lLbtm1Vv359de/eXUuWLNGZM2eUmJio48ePq23btpmu99NPP+nChQsqV66cfH19Hf8OHTrkNJywSpUqKlmypON1xYoVlZiY6Hi9f/9+9erVS6GhofLz81OVKlUkSUePHnXaXpMmTW66H7/99pvCw8OdysLDw/Xbb79l6zhIUoMGDRw/lyhRQn5+fk6xLliwQGFhYSpfvrx8fX21ePHiDHHWrVtXHh7/6yICAwNVv359x2ur1apy5co52v3pp58UHx+vkiVLOo5h2bJllZKS4nQcARRt9NX/Q18NAIVXMVcHAJjFarXqq6++0rfffqsvv/xS8+bN0+jRoxUVFXXT9S5cuKCKFStq69atGZZdfz/ejRPhWCwWp6GGXbp0UUhIiJYsWaKgoCDZ7XbVq1cvw1C8EiVK5HzncuhmsX7wwQcaMWKEZs6cqebNm6tkyZKaPn26duzYccs2btbuhQsXFBYWplWrVmWIp3z58re9TwAKB/rq/6GvBoDCi0QbhYrFYlF4eLjCw8M1btw4hYSE6KuvvlKVKlUUFRWl++67L8M6jRs31okTJ1SsWDHHlY2cOn36tPbt26clS5aoZcuWkqTt27fnqq3atWsrJiZG/fr1c5TFxMSoTp06uWrvRjExMbrnnns0ZMgQR5kZVzEaN26s1atXKyAgQH5+frfdHoDCi7761uirAaBgY+g4Co0dO3ZoypQp2rlzp44ePar169fr5MmTql27tl555RXNnDlTc+fO1f79+xUXF6d58+ZJktq1a6fmzZura9eu+vLLL3X48GF9++23Gj16tHbu3JmtbZcpU0blypXT4sWLFR8fry1btmj48OG52o8XX3xRy5cv18KFC7V//37NmjVL69ev14gRI3LV3o1q1Kjx/9q7e5VGwigMwG8EGwurgEKKYJUiuQYRrKwMQRCxSiVYJE0ghXgHij83YCV4BQY7iaWCfZrUYmcau2yxILuLhbsOK5HngakGzpxpDrx8h5k8PDzk5uYmo9Eoh4eHub+//3Td3d3dlMvlbG5u5u7uLuPxOLe3t+l0Om8f4QEwqz/GrAaYbU60+TYWFxczHA5zenqal5eXVKvVHB8fZ2NjI0ny+vqak5OT9Hq9lMvlbG1tJfl5snJ9fZ2Dg4O02+08Pz9neXk5q6urWVpa+tCz5+bmcnV1lU6nk0ajkVqtlvPz86ytrf31ezSbzZydneXo6CjdbjcrKyu5uLj4p1rv2dvby+PjY7a3t1MqlbKzs5P9/f0MBoNP1V1YWMhwOEy/30+r1cpkMkmlUsn6+rpTE+CNWf0xZjXAbCtNp9PpVzcBAAAA34XVcQAAACiQoA0z5PLy8rff2vx61ev1r24PgJjVAFgdh5kymUzy9PT07r35+flUq9X/3BEAfzKrARC0AQAAoEBWxwEAAKBAgjYAAAAUSNAGAACAAgnaAAAAUCBBGwAAAAokaAMAAECBBG0AAAAokKANAAAABfoBifTkhBwrGFEAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>method</th>\n",
       "      <th>scenario_name</th>\n",
       "      <th>valid_rsmse_mean</th>\n",
       "      <th>valid_rsmse_min</th>\n",
       "      <th>valid_rsmse_max</th>\n",
       "      <th>valid_rsmse_median</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>resgp_nn4x4_nn16x2</td>\n",
       "      <td>sml</td>\n",
       "      <td>0.429943</td>\n",
       "      <td>0.378309</td>\n",
       "      <td>0.503815</td>\n",
       "      <td>0.424637</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>resgp_nn4x4_nn4x2</td>\n",
       "      <td>sml</td>\n",
       "      <td>0.436542</td>\n",
       "      <td>0.390493</td>\n",
       "      <td>0.496287</td>\n",
       "      <td>0.436250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>resgp_nn4x4_nn4x4</td>\n",
       "      <td>sml</td>\n",
       "      <td>0.435960</td>\n",
       "      <td>0.388656</td>\n",
       "      <td>0.511551</td>\n",
       "      <td>0.431319</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "               method scenario_name  valid_rsmse_mean  valid_rsmse_min  \\\n",
       "0  resgp_nn4x4_nn16x2           sml          0.429943         0.378309   \n",
       "1   resgp_nn4x4_nn4x2           sml          0.436542         0.390493   \n",
       "2   resgp_nn4x4_nn4x4           sml          0.435960         0.388656   \n",
       "\n",
       "   valid_rsmse_max  valid_rsmse_median  \n",
       "0         0.503815            0.424637  \n",
       "1         0.496287            0.436250  \n",
       "2         0.511551            0.431319  "
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# shared_nn models\n",
    "print('\\n\\n----- loading shared (shared_nn) models -----')\n",
    "models_shared_nn, results_shared_nn = load_trained_models(\n",
    "    mode='ours', ts_data=ts_data,\n",
    "    filename_res=os.path.join(os.getcwd(), \"saved_results\", exp_name, 'global_'+scenario_name_fl)\n",
    " )   \n",
    "\n",
    "# combine with mean nn\n",
    "results_ours_comb = copy.deepcopy(results_all_resgp)\n",
    "for met in results_all_resgp.keys():\n",
    "    if results_all_resgp[met] is None:\n",
    "        continue\n",
    "    # set rsmse\n",
    "    for train_scenario in results_ours_comb[met].keys():\n",
    "        for valid_or_train in results_all_resgp[met][train_scenario]['rsmse'].keys():\n",
    "            if valid_or_train.startswith('criterion'):\n",
    "                arr1 = np.array(results_all_resgp[met][train_scenario]['rsmse'][valid_or_train])\n",
    "                arr2 = np.array(results_shared_nn[met.split('_')[1]][train_scenario]['rsmse'][valid_or_train])\n",
    "                results_ours_comb[met][train_scenario]['rsmse'][valid_or_train] = arr1 * arr2\n",
    "        # TODO: how to combine other metrics?\n",
    "\n",
    "perf_box_plots(env_dict, criterion='rsmse', methods=methods, results_all=results_ours_comb)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "ename": "TypeError",
     "evalue": "'NoneType' object is not subscriptable",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mTypeError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[1;32m/home/mahrokhg/Cloned_FL/Federated-Hyper-Posterior-Learning/experiments/PV/6_sep_mk.ipynb Cell 19\u001b[0m in \u001b[0;36m<cell line: 2>\u001b[0;34m()\u001b[0m\n\u001b[1;32m      <a href='vscode-notebook-cell://ssh-remote%2B128.178.5.87/home/mahrokhg/Cloned_FL/Federated-Hyper-Posterior-Learning/experiments/PV/6_sep_mk.ipynb#ch0000018vscode-remote?line=0'>1</a>\u001b[0m \u001b[39m# get quantiles\u001b[39;00m\n\u001b[0;32m----> <a href='vscode-notebook-cell://ssh-remote%2B128.178.5.87/home/mahrokhg/Cloned_FL/Federated-Hyper-Posterior-Learning/experiments/PV/6_sep_mk.ipynb#ch0000018vscode-remote?line=1'>2</a>\u001b[0m tmp \u001b[39m=\u001b[39m results_ours_comb[\u001b[39m'\u001b[39;49m\u001b[39mresgp_nn32_nn16\u001b[39;49m\u001b[39m'\u001b[39;49m][\u001b[39m'\u001b[39;49m\u001b[39m1y\u001b[39;49m\u001b[39m'\u001b[39;49m][\u001b[39m'\u001b[39m\u001b[39mrsmse\u001b[39m\u001b[39m'\u001b[39m][\u001b[39m'\u001b[39m\u001b[39mcriterion_valid\u001b[39m\u001b[39m'\u001b[39m]\n\u001b[1;32m      <a href='vscode-notebook-cell://ssh-remote%2B128.178.5.87/home/mahrokhg/Cloned_FL/Federated-Hyper-Posterior-Learning/experiments/PV/6_sep_mk.ipynb#ch0000018vscode-remote?line=2'>3</a>\u001b[0m \u001b[39mprint\u001b[39m(np\u001b[39m.\u001b[39mquantile(tmp, \u001b[39m0.25\u001b[39m),np\u001b[39m.\u001b[39mquantile(tmp, \u001b[39m0.5\u001b[39m), np\u001b[39m.\u001b[39mquantile(tmp, \u001b[39m0.75\u001b[39m))\n",
      "\u001b[0;31mTypeError\u001b[0m: 'NoneType' object is not subscriptable"
     ]
    }
   ],
   "source": [
    "# get quantiles\n",
    "# tmp = results_ours_comb['resgp_nn32_nn16']['1y']['rsmse']['criterion_valid']\n",
    "# print(np.quantile(tmp, 0.25),np.quantile(tmp, 0.5), np.quantile(tmp, 0.75))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.10.4 ('python3')",
   "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.4"
  },
  "vscode": {
   "interpreter": {
    "hash": "98d0820a7d16c01dd14be774e41e0e13359f9b2ee065b64ad6e280dcddbc9693"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
