{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "4868a3e4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "from tqdm.notebook import tqdm\n",
    "import pickle\n",
    "import glob\n",
    "import traceback\n",
    "\n",
    "from scipy import stats as sc_stats\n",
    "from scipy.special import gamma,loggamma\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.metrics import mean_squared_error\n",
    "from sklearn.metrics import mean_absolute_percentage_error\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "abb218f6",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2023-05-17 04:00:14.667839: I tensorflow/core/platform/cpu_feature_guard.cc:193] This TensorFlow binary is optimized with oneAPI Deep Neural Network Library (oneDNN) to use the following CPU instructions in performance-critical operations:  SSE4.1 SSE4.2 AVX AVX2 FMA\n",
      "To enable them in other operations, rebuild TensorFlow with the appropriate compiler flags.\n"
     ]
    }
   ],
   "source": [
    "import tensorflow as tf"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "37c5838a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "import os\n",
    "from os.path import dirname\n",
    "sys.path.append(dirname(\"../../\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ea3af6cb",
   "metadata": {},
   "outputs": [],
   "source": [
    "from src.edl import dense_layers,dense_loss\n",
    "from src.weibull_edl import loss_and_layers\n",
    "from src.exp_utils import lgd_data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "977d90ec",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "344852d5",
   "metadata": {},
   "source": [
    "### Read the LGD dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d2e52ba2",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/kb/v0p0ypbd0wx1q2qb1kpxmmcc0000gn/T/ipykernel_74865/642432279.py:10: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_clean1[\"recovery_rate_ad\"] = np.where(df_clean1[\"recovery_rate\"]<=1.2,df_clean1[\"recovery_rate\"],1.2)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1.2450120227851276, -0.13070932725535367, 11.690199379997253)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x169248d30>"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiwAAAGxCAYAAABBZ+3pAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABKTklEQVR4nO3deVhUdf8//uc4wLCPisgOQmpiWOqQBkpqJaaWuVRqqZVL0SIIWa6Z2W1YeiuiIrl/vCu1XMr8kokliMKdSpCl5IqiOESgstwow3J+f/hjcmRxzjDDDDPPx3XNdcV7XufM67wl5+lZJYIgCCAiIiIyYW2M3QARERHR/TCwEBERkcljYCEiIiKTx8BCREREJo+BhYiIiEweAwsRERGZPAYWIiIiMnkMLERERGTyGFiIiIjI5DGwEBERkcljYCEiIiKTx8BCREREJo+BhYhMTlpaGiQSCbZt21bvva1bt0IikeD48eNG6IyIjEXCpzUTkSnq3bs37O3tceTIEY3xPn36AACOHTtmjLaIyEi4h4WITFJkZCSOHj2K7Oxs9djx48dx/PhxvPPOO8ZrjIiMgntYiMgkVVZWwtfXFyNGjMD69esBAJMmTcL+/ftx5coVyGQyI3dIRC2Je1iIyCTJZDK88cYb+Oqrr3Dz5k38/fff+PrrrzF16lSGFSILxD0sRGSylEol/Pz8sGTJEty+fRsLFizAxYsX4evra+zWiKiFMbAQkUl7+eWX8csvv0ClUkGhUGDPnj3GbomIjICBhYhM2rFjx9C3b18AwMGDB/Hkk08auSMiMgYGFiIyef7+/rCzs8Pp06eN3QoRGYmVsRsgImrKyZMncenSJaxZs8bYrRCREXEPCxGZpAsXLuDy5cuYO3cu8vLycP78edjb2xu7LSIyEl7WTEQm6eOPP8bgwYNRXl6Ob775hmGFyMJxDwsRERGZPO5hISIiIpPHwEJEREQmj4GFiIiITJ7ZXNZcW1uLa9euwcnJCRKJxNjtEBERkRYEQUBZWRk8PT3Rpk3j+1HMJrBcu3YNPj4+xm6DiIiIdHDlyhV4e3s3+r7ZBBYnJycAdzbY2dnZyN0QERGRNkpLS+Hj46P+Hm+M2QSWusNAzs7ODCxEREStzP1O5+BJt0RERGTyGFiIiIjI5DGwEBERkckzm3NYiIioeQRBQHV1NWpqaozdCpkRqVQKKyurZt9yhIGFiIigUqmgVCpRUVFh7FbIDNnb28PDwwM2NjY6r4OBhYjIwtXW1iI3NxdSqRSenp6wsbHhDThJLwRBgEqlwt9//43c3Fx06dKlyZvDNYWBhYjIwqlUKtTW1sLHxwf29vbGbofMjJ2dHaytrXH58mWoVCrY2trqtB6edEtERACg8798ie5HH79b/O0kIiIik8fAQkRERCaP57AQEVGjViSfbbHPih7c1WDr3rJlC2bMmIGbN28a7DPMhSAIeOONN7Bz507cuHEDWVlZ6Nmzp7Hb4h4WIiJqvV599VWMHDmy3nhKSgokEok6oIwdOxZnz2oXvrZs2YK2bdvqr8lWZv/+/diyZQv27dsHpVKJoKAgY7cEgHtYiIjIAtjZ2cHOzs7YbdRTVVUFa2trY7eh4cKFC/Dw8EBoaKixW9HAPSxERGT27t1r8ttvv2HQoEFwcnKCs7MzFAoFTpw4gZSUFLz22msoKSmBRCKBRCLBwoULAQA3btzApEmT0K5dO9jb22Po0KE4d+6cxuesX79efXn4qFGjsHz5co3PXbhwIXr27IlNmzYhICAAMpkMgiBg//796N+/P9q2bQsXFxc888wzuHDhgnq5S5cuQSKR4Ouvv0ZYWBjs7Ozw6KOP4uzZszh+/DiCg4Ph6OiIp59+Gn///XeTc5Gamoo+ffpAJpPBw8MDs2fPRnV1NYA7e6ymT5+OvLw8SCQSdOrUqd7y//vf/+Ds7IydO3dqjH///fdwcHBAWVmZFn8i4nEPi5lqznFnQx5HJiIyBS+//DJ69eqFtWvXQiqVIjs7G9bW1ggNDUVcXBwWLFiAM2fOAAAcHR0B3PkyP3fuHPbu3QtnZ2fMmjULw4YNw+nTp2FtbY2jR48iIiICn376KUaMGIGDBw/igw8+qPfZ58+fx9dff41du3ZBKpUCuBMCYmJi0KNHD/zvf//DggULMGrUKGRnZ2tcEvzhhx8iLi4Ovr6+mDx5MsaPHw9nZ2esXLkS9vb2ePHFF7FgwQKsXbu2we3Oz8/HsGHD8Oqrr2Lr1q34888/MW3aNNja2mLhwoVYuXIlHnjgAaxbtw7Hjx9X93c3BwcHjBs3Dps3b8bzzz+vHq/72cnJSfc/mCYwsBARUau2b98+daioc7/nIeXl5eG9995Dt27dAABdunRRvyeXyyGRSODu7q4eqwsqR48eVR8q+fLLL+Hj44Nvv/0WL7zwAlatWoWhQ4di5syZAICuXbsiPT0d+/bt0/hslUqF//znP3B1dVWPjRkzRqNm48aN6NixI06fPq1xDsnMmTMxZMgQAEBUVBTGjx+Pn376Cf369QMATJkyBVu2bGl0uxMSEuDj44PVq1dDIpGgW7duuHbtGmbNmoUFCxZALpfDyckJUqlUY/vvNXXqVISGhuLatWvw9PREUVER9u3bh+Tk5EaXaS4eEiIiolZt0KBByM7O1nht2LChyWViYmIwdepUPPXUU1iyZInG4ZeG5OTkwMrKCn379lWPubi44MEHH0ROTg4A4MyZM+jTp4/Gcvf+DAB+fn4aYQW4c97ISy+9hICAADg7O8Pf3x/AnWB1t4cfflj9325ubgCAHj16aIwVFhY2uR0hISEaj17o168fysvLcfXq1UaXu1efPn3w0EMPYevWrQCA//znP/D19cXjjz+u9TrEYmAhIqJWzcHBAZ07d9Z4eXl5NbnMwoULcerUKQwfPhw///wzunfvjj179jRaLwhCo+N1X/53/3dTyzk4ONQbe/bZZ1FcXIz169fjl19+wS+//ALgzt6Yu919gm7dZ907Vltb2+R2NNaj2OdHTZ06FZs3bwZw53DQa6+9ZtBnUDGwEBGRReratSuio6Nx4MABjB49Wv3la2NjU++QUvfu3VFdXa0OEgBQXFyMs2fPIjAwEADQrVs3HDt2TGO5EydO3LeP4uJi5OTkYP78+XjyyScRGBiIGzduNHfzGtS9e3ekp6drBKn09HQ4OTndN+Tda8KECcjLy0N8fDxOnTqFV155Rd/tamBgISIii3Lr1i288847SElJweXLl3H06FEcP35cHTw6deqE8vJy/PTTTygqKkJFRQW6dOmC5557DtOmTcORI0fw22+/YcKECfDy8sJzzz0HAJg+fTqSkpKwfPlynDt3Dp9//jl++OGH++51aNeuHVxcXLBu3TqcP38eP//8M2JiYgyy7W+99RauXLmC6dOn488//8R3332HDz/8EDExMaKf99OuXTuMHj0a7733HsLDw+Ht7W2QnuvwpFsiImqUOV41KJVKUVxcjEmTJuGvv/5Chw4dMHr0aHz00UcAgNDQUERERGDs2LEoLi7Ghx9+iIULF2Lz5s2IiorCM888A5VKhccffxxJSUnqQzL9+vVDYmIiPvro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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_clean = pd.read_csv(\"../../data/data_preprocessed_v0.csv\",index_col=0)\n",
    "\n",
    "# Select columns with 'float64' dtype  \n",
    "float64_cols = list(df_clean.select_dtypes(include='float64'))\n",
    "\n",
    "# The same code again calling the columns\n",
    "df_clean[float64_cols] = df_clean[float64_cols].astype('float32')\n",
    "df_clean[\"ccf_ad\"] = (1.0-df_clean[\"CCF\"])*100\n",
    "df_clean1 = df_clean[df_clean.recovery_rate>0.0]\n",
    "df_clean1[\"recovery_rate_ad\"] = np.where(df_clean1[\"recovery_rate\"]<=1.2,df_clean1[\"recovery_rate\"],1.2)\n",
    "# df_clean.head()\n",
    "\n",
    "y_cols = [\"recovery_rate\",\"CCF\"]\n",
    "\n",
    "X = df_clean1.drop(columns=y_cols + list(df_clean1.columns)[35:39])\n",
    "y = df_clean1[\"recovery_rate_ad\"] * 100.0\n",
    "\n",
    "rv = sc_stats.weibull_min.fit(y)\n",
    "print (rv)\n",
    "plt.hist(y,alpha=0.5,density=True,bins=30,label=\"Histogram of y\")\n",
    "plt.scatter(y, sc_stats.weibull_min.pdf(y,*rv),label=\"Fitted Weibull\",color=\"black\")\n",
    "plt.title(\"y\")\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "16bcda7a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(23300, 45) (23300,)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "((18640, 45), (4660, 45), (18640,), (4660,))"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y=y-(-0.13071235094229539)\n",
    "print(X.shape,y.shape)\n",
    "\n",
    "x_train, x_test, y_train, y_test = train_test_split(X, y, test_size=0.2)\n",
    "x_train.shape,x_test.shape,y_train.shape,y_test.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "2b31ac37",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1.2453514212295727, 0.0007319641015313121, 11.690848862859276)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x16952fe80>"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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r16N6dOnG7otvVuxYgV69eoFJycnzJ8/v0m2ySMsREREevLVV18ZuoUmsXjxYvUrC5oKj7Dowd3vnLj34+npaej2iIiImj0Glkbq1KlTva8hv3LliqQP0iEiImoJGFgaoVOnTvd9nHMNhhYiIqKGY2BpoOLiYp3DSg2GFiIiooZhYGmg+k4D1ad79+76bYSIiKgFYGBpgC+++KLBY0+fPn3f154TERGRJgaWBpg8eXKjxpuZ8W5yIiKpDRo0CLNnz26y7W3btq3BR98b49799PLyQkxMTKPWmZycDJlMhps3bwIw3L7djYFFpL/++ksv6zl79qxe1kNEZExUKhWSk5Oxfft2JCcnS35E+cUXX9T6SIkLFy4gPj4ey5YtU9dq+yJvyi/iRx55BK+88orGsvXr10Mmk2HLli0ay6dNm4agoCCd1nvvfpoqBhaRunXrppf1dO3aVS/rISIyFvHx8fDy8sLgwYPx7LPPYvDgwfDy8kJ8fLyk23388ceRl5en8fH29kbbtm1ha2sr6bbFGDx4MA4ePKixLDk5GR4eHlqXDx48WKf1Gtt+SoWBRaQ///zT0C0QERmd+Ph4TJgwAVevXtVYnpubiwkTJkgaWhQKBZydnTU+crlc41TJoEGDkJ2djcjISPVRmOTkZEyZMkXj4Z81T29VKpX417/+BTc3N9jY2KBfv35ITk7W2O62bdvg6ekJa2trjB07FkVFRfX2OXjwYJw9exZ5eXnqZYcOHcL8+fM11n3lyhVcunRJHVhOnz6N0NBQtG7dGk5OTnj++edRWFiortd26uvWrVt49tln0bp1a7i6umLNmjXq312+fBkymQwZGRnqZTdv3lTPibFiYDEgKysrQ7dARNRoKpUKEREREASh1u9qls2ePdugNxzEx8fD3d0dS5cuVR+FCQoKQkxMDOzs7NTL5syZAwCYMmUKDh8+jB07duD333/HU089hccffxznz58HAPz666+YOnUqZs6ciYyMDAwePBjvvPNOvT30798f5ubm6lBw+vRplJWVYerUqSgpKVGv++DBg7CwsEBQUBDy8vIwcOBA9OrVC8eOHcO+ffvw559/4umnn653Wx988AF69uyJ3377DfPnz0dkZCSSkpIaOYuGxas/Rbh+/bpe11deXq7X9RERGUJKSkqtIyt3EwQBV65cQUpKCgYNGqT37e/duxet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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "rv = sc_stats.weibull_min.fit(y_train)\n",
    "print (rv)\n",
    "plt.hist(y_train,alpha=0.5,density=True,bins=30,label=\"Histogram of y\")\n",
    "plt.scatter(y_train, sc_stats.weibull_min.pdf(y_train,*rv),label=\"Fitted Weibull\",color=\"black\")\n",
    "plt.title(\"y-train\")\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "e04092c5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Distribution of y')"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiwAAAGxCAYAAABBZ+3pAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA7w0lEQVR4nO3de1xVdb7/8feWy95qggoFkoBg00jRzU2ZFGU3HLUcJ2u0GbOLl6GbAsdf3iqNpmjKinESyAKbxlIqdcZGTollZLlnHA3KjKM1kZjBEHQCi+S6fn942LXbG2UjygJez8djPR7u7/6stb7rO4773XfdLIZhGAIAADCxPl3dAQAAgGMhsAAAANMjsAAAANMjsAAAANMjsAAAANMjsAAAANMjsAAAANMjsAAAANMjsAAAANMjsAAm9/zzz8tisTgXm82m0NBQXXHFFUpPT1dlZaXbOkuXLpXFYvFqP3V1dVq6dKnefvttr9bztK9hw4bp2muv9Wo7x/LSSy8pIyPD43cWi0VLly7t1P11tjfffFNxcXHq37+/LBaL/vrXv3Z1l4BuxberOwCgfVatWqURI0aosbFRlZWVevfdd/WHP/xBy5YtU15enq6++mpn7cyZM/WLX/zCq+3X1dXpwQcflCSNGTOm3et1ZF8d8dJLL+mjjz5ScnKy23cOh0NDhw494X3oKMMw9Otf/1pnnnmmNm7cqP79++vnP/95V3cL6FYILEA3ERsbq7i4OOfnyZMnKyUlRZdeeqmuv/56ffLJJwoJCZEkDR069IT/gNfV1alfv34nZV/HcvHFF3fp/o/lyy+/1Ndff61f/epXuuqqq7q6O0C3xCkhoBuLiIjQE088oUOHDumZZ55xtns6TfPWW29pzJgxCgoKUt++fRUREaHJkyerrq5On3/+uU499VRJ0oMPPug8/XTrrbe6bO/999/XDTfcoEGDBmn48OFt7qvVhg0bdO6558pmsyk6OlrLly93+b71dNfnn3/u0v7222/LYrE4T0+NGTNGmzZt0v79+11Oj7XydEroo48+0i9/+UsNGjRINptN559/vv785z973M+aNWu0ePFihYWFKSAgQFdffbX27t3b9sD/yLvvvqurrrpKAwYMUL9+/RQfH69NmzY5v1+6dKkz0M2fP18Wi0XDhg3zuK1vv/1WAwcO1O9+9zu37z7//HP5+Pjo8ccfb1e/gJ6GwAJ0c+PHj5ePj4/eeeedNms+//xzTZgwQf7+/srNzdXrr7+uRx99VP3791dDQ4OGDBmi119/XZI0Y8YMORwOORwO3X///S7buf7663XGGWfolVdeUXZ29lH7VVxcrOTkZKWkpGjDhg2Kj4/X3LlztWzZMq+PMTMzU5dccolCQ0OdfXM4HG3W7927V/Hx8dqzZ4+WL1+u9evX66yzztKtt96qxx57zK1+0aJF2r9/v5577jmtXLlSn3zyia677jo1NzcftV+FhYW68sorVVNTo5ycHK1Zs0YDBgzQddddp7y8PElHTpmtX79eknTPPffI4XBow4YNHrd3yimn6Pbbb9eLL76ompoatzHw9/fX7bffftQ+AT2WAcDUVq1aZUgy/vWvf7VZExISYsTExDg/L1myxPjx/71fffVVQ5JRXFzc5ja++uorQ5KxZMkSt+9at/fAAw+0+d2PRUZGGhaLxW1/11xzjREQEGB89913LsdWWlrqUrd161ZDkrF161Zn24QJE4zIyEiPff9pv6dOnWpYrVajrKzMpW7cuHFGv379jG+++cZlP+PHj3epe/nllw1JhsPh8Li/VhdffLFx2mmnGYcOHXK2NTU1GbGxscbQoUONlpYWwzAMo7S01JBkPP7440fdnmEYxr///W+jT58+xlNPPeVs+/77742goCDjtttuO+b6QE/FDAvQAxiGcdTvzz//fPn7+2v27Nn685//rM8++6xD+5k8eXK7a88++2ydd955Lm2/+c1vVFtbq/fff79D+2+vt956S1dddZXCw8Nd2m+99VbV1dW5zc5MnDjR5fO5554rSdq/f3+b+/juu+/0z3/+UzfccINOOeUUZ7uPj49uvvlmffHFF+0+rfRj0dHRuvbaa5WZmen83/Wll15SdXW17r77bq+3B/QUBBagm/vuu+9UXV2tsLCwNmuGDx+uLVu26LTTTtNdd92l4cOHa/jw4frjH//o1b6GDBnS7trQ0NA226qrq73ar7eqq6s99rV1jH66/6CgIJfPVqtVkvT999+3uY///d//lWEYXu2nvebOnatPPvlEBQUFkqQVK1Zo9OjRGjlyZIe2B/QE3CUEdHObNm1Sc3PzMW9FTkhIUEJCgpqbm7Vz50796U9/UnJyskJCQjR16tR27cubZ7tUVFS02dYaEGw2mySpvr7epa6qqqrd+/EkKChI5eXlbu1ffvmlJCk4OPi4ti9JgwYNUp8+fU7Ifq688krFxsbq6aef1imnnKL3339fq1evPq7+At0dMyxAN1ZWVqZ58+YpMDDQ450lnvj4+GjUqFFasWKFJDlPz7RnVsEbe/bs0QcffODS9tJLL2nAgAHOmYLWu2U+/PBDl7qNGze6bc9qtba7b1dddZXeeustZ3Bo9cILL6hfv36dcht0//79NWrUKK1fv96lXy0tLVq9erWGDh2qM888s8PbnzNnjjZt2qSFCxcqJCREN95443H3GejOmGEBuomPPvpITU1NampqUmVlpbZt26ZVq1bJx8dHGzZscN6W7El2drbeeustTZgwQRERETp8+LByc3MlyfnAuQEDBigyMlJ/+9vfdNVVV2nw4MEKDg5u8xbcYwkLC9PEiRO1dOlSDRkyRKtXr1ZBQYH+8Ic/qF+/fpKkCy+8UD//+c81b948NTU1adCgQdqwYYPeffddt+2dc845Wr9+vbKysmS329WnTx+X59L82JIlS/T3v/9dV1xxhR544AENHjxYL774ojZt2qTHHntMgYGBHTqmn0pPT9c111yjK664QvPmzZO/v78yMzP10Ucfac2aNV4/bfjHpk2bpoULF+qdd97RfffdJ39//07pM9BtdfFFvwCOofVOmtbF39/fOO2004zLL7/ceOSRR4zKykq3dX56547D4TB+9atfGZGRkYbVajWCgoKMyy+/3Ni4caPLelu2bDEuuOACw2q1GpKMW265xWV7X3311TH3ZRhH7hKaMGGC8eqrrxpnn3224e/vbwwbNsx48skn3dbft2+fkZiYaAQEBBinnnqqcc899xibNm1yu0vo66+/Nm644QZj4MCBhsVicdmnPNzdtHv3buO6664zAgMDDX9/f+O8884zVq1a5VLTepfQK6+84tLeelfPT+s92bZtm3HllVca/fv3N/r27WtcfPHFxmuvveZxe+25S+jHbr31VsPX19f44osvvFoP6IkshnGM2wsAACddQ0ODhg0bpksvvVQvv/xyV3cH6HKcEgIAE/nqq6+0d+9erVq1Sv/5z3+0YMGCru4SYAoEFgAwkU2bNum2227TkCFDlJmZya3MwP/hlBAAADA9bmsGAACmR2ABAACmR2ABAACm12Muum1padGXX36pAQMGHNfDmgAAwMljGIYOHTqksLAw9enT9jxKjwksX375pdubWQEAQPdw4MABDR06tM3ve0xgGTBggKQjBxwQENDFvQEAAO1RW1ur8PBw5+94W3pMYGk9DRQQEEBgAQCgmznW5RxcdAsAAEyPwAIAAEyPwAIAAEyvx1zDAgBAZzMMQ01NTWpubu7qrnRbPj4+8vX1Pe5HjhBYAADwoKGhQeXl5aqrq+vqrnR7/fr105AhQ+Tv79/hbXQosGRmZurxxx9XeXm5zj77bGVkZCghIaHN+sLCQqWmpmrPnj0KCwvTvffeq6SkJJeajIwMZWVlqaysTMHBwbrhhhuUnp4um83WkS4CANBhLS0tKi0tlY+Pj8LCwuTv789DSTvAMAw1NDToq6++UmlpqX72s58d9eFwR+N1YMnLy1NycrIyMzN1ySWX6JlnntG4ceP08ccfKyIiwq2+tLRU48eP16xZs7R69Wq99957uvPOO3Xqqadq8uTJkqQXX3xRCxYsUG5uruLj47Vv3z7deuutkqSnnnqqQwcGAEBHNTQ0qKWlReHh4erXr19Xd6db69u3r/z8/LR//341NDR0eCLCYhiG4c0Ko0aN0siRI5WVleVsi4mJ0aRJk5Senu5WP3/+fG3cuFElJSXOtqSkJH3wwQdyOBySpLvvvlslJSV68803nTX/9V//pR07dmjbtm3t6ldtba0CAwNVU1PDc1gAAMfl8OHDKi0tVVRUFDP9neBo49ne32+v5mUaGhq0a9cuJSYmurQnJiZq+/btHtdxOBxu9WPHjtXOnTvV2NgoSbr00ku1a9cu7dixQ5L02WefKT8/XxMmTGizL/X19aqtrXVZAABAz+TVKaGqqio1NzcrJCTEpT0kJEQVFRUe16moqPBY39TUpKqqKg0ZMkRTp07VV199pUsvvdR5RfYdd9yhBQsWtNmX9PR0Pfjgg950HwAAdFMduuj2pxceGYZx1IuRPNX/uP3tt9/Www8/rMzMTI0aNUqffvqp5s6dqyFDhuj+++/3uM2FCxcqNTXV+bn1XQQAAJxITxXsO2n7SrnmzJO2r6MZM2aMzj//fGVkZHRZH7wKLMHBwfLx8XGbTamsrHSbRWkVGhrqsd7X11dBQUGSpPvvv18333yzZs6cKUk655xz9N1332n27NlavHixxyuKrVarrFarN90HAKBHO9adTLfccouef/55r7e7fv16+fn5dbBXncOra1j8/f1lt9tVUFDg0l5QUKD4+HiP64wePdqtfvPmzYqLi3MefF1dnVso8fHxkWEY8vKaYAAAeq3y8nLnkpGRoYCAAJe2P/7xjy71rdeSHsvgwYOP+TblE83rm6FTU1P13HPPKTc3VyUlJUpJSVFZWZnzuSoLFy7U9OnTnfVJSUnav3+/UlNTVVJSotzcXOXk5GjevHnOmuuuu05ZWVlau3atSktLVVBQoPvvv18TJ06Uj49PJxwmAAA9X2hoqHMJDAyUxWJxfj58+LAGDhyol19+WWPGjJHNZtPq1atVXV2tm266SUOHDlW/fv10zjnnaM2aNS7bHTNmjJKTk52fhw0bpkceeUS33367BgwYoIiICK1cufKEHpvX17BMmTJF1dXVSktLU3l5uWJjY5Wfn6/IyEhJR9JdWVmZsz4qKkr5+flKSUnRihUrFBYWpuXLlzufwSJJ9913nywWi+677z4dPHhQp556qq677jo9/PDDnXCIPU9nnT81y7lRAMDJM3/+fD3xxBNatWqVrFarDh8+LLvdrvnz5ysgIECbNm3SzTffrOjoaI0aNarN7TzxxBN66KGHtGjRIr366qu64447dNlll2nEiBEnpN8duuj2zjvv1J133unxO0/nxi6//HK9//77bXfC11dLlizRkiVLOtIdAADQTsnJybr++utd2n581uOee+7R66+/rldeeeWogWX8+PHOLDB//nw99dRTevvtt80VWAAAQPcUFxfn8rm5uVmPPvqo8vLydPDgQdXX16u+vl79+/c/6nbOPfdc559bTz1VVlaekD5LBBYAAHqVnwaRJ554Qk899ZQyMjJ0zjnnqH///kpOTlZDQ8NRt/PTu4YsFotaWlo6vb+tCCwAAPRi27Zt0y9/+UtNmzZN0pEXP37yySeKiYnp4p656tgrEwEAQI9wxhlnqKCgQNu3b1dJSYl+97vftfn0+q7EDAsAAF7oaXdY3n///SotLdXYsWPVr18/zZ49W5MmTVJNTU1Xd82F129rNqve9LZmbmsGgBOLtzV3rpP+tmYAAICuQGABAACmR2ABAACmR2ABAACmR2ABAACmR2ABAACmR2ABAACmR2ABAACmR2ABAACmx6P5AQDwxtb0k7evKxaevH2ZHDMsAAD0EBaL5ajLrbfe2uFtDxs2TBkZGZ3WV28xwwIAQA9RXl7u/HNe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CwtT3759NWbMGO3Zs6eLemwe6enpslgsSk5OdrYxVj84ePCgpk2bpqCgIPXr10/nn3++du3a5fyesfpBU1OT7rvvPkVFRalv376Kjo5WWlqaWlpanDW9dbzeeecdXXfddQoLC5PFYtFf//pXl+/bMy719fW65557FBwcrP79+2vixIn64osvTuJRnBxHG6vGxkbNnz9f55xzjvr376+wsDBNnz5dX37p+gLWkzpWBjxau3at4efnZzz77LPGxx9/bMydO9fo37+/sX///q7uWpcaO3assWrVKuOjjz4yiouLjQkTJhgRERHGt99+66x59NFHjQEDBhjr1q0zdu/ebUyZMsUYMmSIUVtb24U971o7duwwhg0bZpx77rnG3Llzne2M1RFff/21ERkZadx6663GP//5T6O0tNTYsmWL8emnnzprGKsf/P73vzeCgoKMv//970ZpaanxyiuvGKeccoqRkZHhrOmt45Wfn28sXrzYWLdunSHJ2LBhg8v37RmXpKQk4/TTTzcKCgqM999/37jiiiuM8847z2hqajrJR3NiHW2svvnmG+Pqq6828vLyjP/5n/8xHA6HMWrUKMNut7ts42SOFYGlDRdddJGRlJTk0jZixAhjwYIFXdQjc6qsrDQkGYWFhYZhGEZLS4sRGhpqPProo86aw4cPG4GBgUZ2dnZXdbNLHTp0yPjZz35mFBQUGJdffrkzsDBWP5g/f75x6aWXtvk9Y+VqwoQJxu233+7Sdv311xvTpk0zDIPxavXTH+H2jMs333xj+Pn5GWvXrnXWHDx40OjTp4/x+uuvn7S+n2yewt1P7dixw5Dk/A/3kz1WnBLyoKGhQbt27VJiYqJLe2JiorZv395FvTKnmpoaSdLgwYMlSaWlpaqoqHAZO6vVqssvv7zXjt1dd92lCRMm6Oqrr3ZpZ6x+sHHjRsXFxenGG2/UaaedpgsuuEDPPvus83vGytWll16qN998U/v27ZMkffDBB3r33Xc1fvx4SYxXW9ozLrt27VJjY6NLTVhYmGJjY3v12ElH/r23WCzOFw2f7LHy+tH8vUFVVZWam5vd3hYdEhLi9lbp3swwDKWmpurSSy9VbGysJDnHx9PY7d+//6T3sautXbtW77//vv71r3+5fcdY/eCzzz5TVlaWUlNTtWjRIu3YsUNz5syR1WrV9OnTGaufmD9/vmpqajRixAj5+PioublZDz/8sG666SZJ/N1qS3vGpaKiQv7+/ho0aJBbTW/+9//w4cNasGCBfvOb3zjf1nyyx4rAchQWi8Xls2EYbm292d13360PP/zQ40sqGTvpwIEDmjt3rjZv3iybzdZmHWMltbS0KC4uTo888ogk6YILLtCePXuUlZWl6dOnO+sYqyPy8vK0evVqvfTSSzr77LNVXFys5ORkhYWF6ZZbbnHWMV6edWRcevPYNTY2aurUqWppaVFmZuYx60/UWHFKyIPg4GD5+Pi4JcTKykq3ZN5b3XPPPdq4caO2bt2qoUOHOttDQ0MlibHTkenSyspK2e12+fr6ytfXV4WFhVq+fLl8fX2d48FYSUOGDNFZZ53l0hYTE+N8kSp/r1z9v//3/7RgwQJNnTpV55xzjm6++WalpKQoPT1dEuPVlvaMS2hoqBoaGvS///u/bdb0Jo2Njfr1r3+t0tJSFRQUOGdXpJM/VgQWD/z9/WW321VQUODSXlBQoPj4+C7qlTkYhqG7775b69ev11tvvaWoqCiX76OiohQaGuoydg0NDSosLOx1Y3fVVVdp9+7dKi4udi5xcXH67W9/q+LiYkVHRzNW/+eSSy5xuz1+3759zrfA8/fKVV1dnfr0cf3n28fHx3lbM+PlWXvGxW63y8/Pz6WmvLxcH330Ua8bu9aw8sknn2jLli0KCgpy+f6kj1WnX8bbQ7Te1pyTk2N8/PHHRnJystG/f3/j888/7+qudak77rjDCAwMNN5++22jvLzcudTV1TlrHn30USMwMNBYv369sXv3buOmm27qFbdTtseP7xIyDMaq1Y4dOwxfX1/j4YcfNj755BPjxRdfNPr162esXr3aWcNY/eCWW24xTj/9dOdtzevXrzeCg4ONe++911nTW8fr0KFDRlFRkVFUVGRIMp588kmjqKjIeWdLe8YlKSnJGDp0qLFlyxbj/fffN6688soeeVvz0caqsbHRmDhxojF06FCjuLjY5d/7+vp65zZO5lgRWI5ixYoVRmRkpOHv72+MHDnSeetubybJ47Jq1SpnTUtLi7FkyRIjNDTUsFqtxmWXXWbs3r276zptIj8NLIzVD1577TUjNjbWsFqtxogRI4yVK1e6fM9Y/aC2ttaYO3euERERYdhsNiM6OtpYvHixyw9Jbx2vrVu3evw36pZbbjEMo33j8v333xt33323MXjwYKNv377Gtddea5SVlXXB0ZxYRxur0tLSNv+937p1q3MbJ3OsLIZhGJ0/bwMAANB5uIYFAACYHoEFAACYHoEFAACYHoEFAACYHoEFAACYHoEFAACYHoEFAACYHoEFAACYHoEFAACYHoEFAACYHoEFAACY3v8HLHyHjNtihiwAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(y_train,density=True,alpha=0.5,label=\"Train\",bins=25)\n",
    "plt.hist(y_test,density=True,alpha=0.5,label=\"Test\",bins=25)\n",
    "plt.legend()\n",
    "plt.title(\"Distribution of y\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "59371de6",
   "metadata": {},
   "source": [
    "### Experiment variable"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "1a5d0cb0",
   "metadata": {},
   "outputs": [],
   "source": [
    "EXP_NAME = \"exp4\" #experiment name\n",
    "N_REGUL = 20 #number of regularisation values to try"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "37cbcc40",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "../../exp_results/exp4 is empty\n"
     ]
    }
   ],
   "source": [
    "base_dir = f\"../../exp_results/{EXP_NAME}\"\n",
    "\n",
    "if len(os.listdir(base_dir)) == 0:\n",
    "    print(f\"{base_dir} is empty\")\n",
    "else:    \n",
    "    print(f\"{base_dir} is not empty, Removing files\")\n",
    "    [os.remove(f) for f in glob.glob(base_dir+\"/*\")]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2b487e15",
   "metadata": {},
   "source": [
    "### Helper plotting func"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "35666f41",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_results(ax, mu, var, model_type, n):\n",
    "    sort_idx = y_test.values.argsort()\n",
    "    mu_sorted = mu[sort_idx]\n",
    "    var_sort = var[sort_idx]\n",
    "    if model_type == \"proposed\":\n",
    "        a = 1\n",
    "        b = 2\n",
    "        var_check = np.sqrt(var_sort)\n",
    "    else:\n",
    "        a = 1\n",
    "        b = 2\n",
    "        var_check = var_sort\n",
    "        var_check\n",
    "    #plot\n",
    "    ax.plot(y_test.values[sort_idx],label=\"True Test\",alpha = 1, color=\"black\")\n",
    "    ax.plot(mu_sorted, zorder=3, label=\"Mean Pred\",color=\"red\")\n",
    "    ax.fill_between(x=range(len(mu[sort_idx])),\\\n",
    "                     y1=(mu_sorted - a * var_check), \\\n",
    "                     y2=(mu_sorted + a * var_check),\\\n",
    "                     label=f\"{a} std PI\",color=\"grey\",alpha=0.7)\n",
    "    ax.fill_between(x=range(len(mu[sort_idx])),\n",
    "                     y1=(mu - b * var_check), \\\n",
    "                     y2=(mu + b * var_check),\\\n",
    "                     label=f\"{b} std PI\",color=\"pink\",alpha=0.2)\n",
    "    ax.set_ylim(-100,200)\n",
    "    ax.legend()\n",
    "    ax.set_title(f\"{model_type} Model\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c9783eb3",
   "metadata": {},
   "source": [
    "### Experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "3a4f1ab3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Fitted k =1.2453514212295727\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x1693a1fa0>"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiwAAAGxCAYAAABBZ+3pAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABNu0lEQVR4nO3deVhU9f4H8Pc4wLDIoqjsCKQmiqaCGRguqZhouZZZRrmUZCVCdt265lJh5jVyQXNBW9VSKq+RQSpGyk00MFPcERQhhBQ0loHh/P7wx+TIgHNgDjMM79fzzPNcDp/vOZ/z1eu8O6tMEAQBREREREaslaEbICIiIrofBhYiIiIyegwsREREZPQYWIiIiMjoMbAQERGR0WNgISIiIqPHwEJERERGj4GFiIiIjB4DCxERERk9BhYiMpgvv/wSMTExkq3fy8sLL774omTrJ6KmI+Oj+YnIUEaNGoU//vgDly9flmT96enpsLOzwwMPPCDJ+omo6ZgZugEiIl2oVCpUVVVBoVDoPKZ3794SdkRETYmnhIiowVJSUiCTybB9+/Zav/v0008hk8mQlpamdeygQYPw/fffIzs7GzKZTP0BgMuXL0Mmk2HFihV455134O3tDYVCgYMHD6K8vBxvvPEGevXqBXt7e7Rt2xaBgYH47rvvam3j3lNCycnJ6n4XLlwIV1dX2NnZYejQoTh79qx+JoWIJMFTQkTUKH369IG1tTV++eUXjeUPP/wwAODo0aNax50+fRovv/wyLl68iG+++Ua9/JFHHsHly5fh7e0NNzc3dOnSBa+++irs7OzQuXNntGnTBrNnz8aQIUPg5uYGpVKJn376CatWrcLWrVsRFhamXpeXlxcGDRqEbdu2AbgTWAYPHgwvLy/0798fzz77LEpKSjB37lwoFApkZmZCLpfreYaISB94SoiIGmXWrFmYMmUKMjIy0KtXLwBAWloa0tLS8Mknn9Q5rlu3bnBwcIBCocAjjzyitcbS0hI//vgjzM3NNZZv3bpV/b9VKhWGDBmCGzduICYmRiOw1Lftzz//XP2zXC7H008/jbS0tDp7ISLD4ikhImqUSZMmoUOHDli3bp162Zo1a9C+fXtMnDgR1dXVqKqqUn9UKpXO637yySdrhRUA+Prrr9G/f3+0bt0aZmZmMDc3x5YtW5CZmanzeu/Ws2dPAEB2drbOvRFR02JgIaJGUSgUmDFjBr788kvcvHkT169fx1dffYXp06dDoVBg6dKlMDc3V3/E3LHj4uJSa1l8fDyefvppuLm54fPPP0dqairS0tIwdepUlJeX67ReR0fHWvsAAGVlZTr3RkRNi6eEiKjRXnnlFSxfvhxxcXEoLy9HVVUVwsPDAQAvv/wyRo0apa4Vc5dPzUW4d/v888/h7e2NnTt3avy+oqKiEXtARMaOgYWIGs3FxQVPPfUUYmNjoVQq8cQTT8DT0xMA4OrqCldXV63jFAqF6KMaMpkMFhYWGmElPz9f611CRGQ6eEqIiPQiIiICFy9exJUrV/Daa6/pNKZHjx4oKCjA+vXrcfToURw7duy+Y0aNGoWzZ89i5syZOHDgAD755BM8+uijWk8fEZHp4BEWItKLhx9+GF5eXrCyssKQIUN0GhMREYFTp05hwYIFKC4uhiAIuN+TFqZMmYKCggJs2LABcXFx8PHxwbx583D16lUsWbJEH7tCREaIz2EhIr34/fff8dBDD2HdunWYOXOmodshIhPDwEJEjXLx4kVkZ2djwYIFyMnJwYULF2BtbW3otojIxPAaFiJqlGXLlmHYsGG4ffs2vv76a4YVIpIEj7AQERGR0eMRFiIiIjJ6DCxERERk9BhYiIiIyOiZzHNYqqurce3aNdja2mp9nDcREREZH0EQcOvWLbi6uqJVq7qPo5hMYLl27Ro8PDwM3QYRERE1wJUrV+Du7l7n700msNja2gK4s8N2dnYG7oaIiIh0UVJSAg8PD/X3eF1MJrDUnAays7NjYCEiImpm7nc5By+6JSIiIqPHwEJERERGj4GFiIiIjJ7JXMNCRESNIwgCqqqqoFKpDN0KmRC5XA4zM7NGP3KEgYWIiKBUKpGXl4fS0lJDt0ImyNraGi4uLrCwsGjwOhhYiIhauOrqamRlZUEul8PV1RUWFhZ8ACfphSAIUCqVuH79OrKystC5c+d6Hw5XHwYWIqIWTqlUorq6Gh4eHrC2tjZ0O2RirKysYG5ujuzsbCiVSlhaWjZoPbzoloiIAKDB/+VLdD/6+LvFv51ERERk9BhYiIiIyOjxGhYiIqrTh0nnmmxbkcO6SLbubdu2Yfbs2bh586Zk2zAVgiBgxowZ2LVrF27cuIH09HT06tXL0G3xCAsRETVfL774IsaMGVNreXJyMmQymTqgTJw4EefO6Ra+tm3bBgcHB/012czs27cP27Ztw969e5GXlwc/Pz9DtwSAR1iIiKgFsLKygpWVlaHbqKWyshLm5uaGbkPDxYsX4eLigqCgIEO3ooFHWIiIyOTde9TkxIkTGDx4MGxtbWFnZwd/f38cO3YMycnJmDJlCoqLiyGTySCTybB48WIAwI0bNxAWFoY2bdrA2toaI0aMwPnz5zW2s2nTJvXt4WPHjsWqVas0trt48WL06tULcXFx8PHxgUKhgCAI2LdvHx599FE4ODjA0dERo0aNwsWLF9XjLl++DJlMhq+++grBwcGwsrJC3759ce7cOaSlpSEgIACtW7fG448/juvXr9c7F4cOHcLDDz8MhUIBFxcXzJs3D1VVVQDuHLF6/fXXkZOTA5lMBi8vr1rj//77b9jZ2WHXrl0ay//73//CxsYGt27d0uFPRDweYTFRjTnvLOV5ZCIiY/Dcc8+hd+/eWL9+PeRyOTIyMmBubo6goCDExMRg0aJFOHv2LACgdevWAO58mZ8/fx579uyBnZ0d5s6di9DQUJw+fRrm5uY4fPgwwsPD8f777+PJJ5/ETz/9hH//+9+1tn3hwgV89dVX2L17N+RyOYA7ISAqKgo9evTA33//jUWLFmHs2LHIyMjQuCX47bffRkxMDDw9PTF16lRMmjQJdnZ2+Oijj2BtbY2nn34aixYtwvr167Xud25uLkJDQ/Hiiy/i008/xZkzZ/DSSy/B0tISixcvxkcffYQHHngAGzduRFpamrq/u9nY2OCZZ57B1q1bMWHCBPXymp9tbW0b/gdTDwYWIiJq1vbu3asOFTXu9z6knJwcvPnmm+jatSsAoHPnzurf2dvbQyaTwdnZWb2sJqgcPnxYfarkiy++gIeHB7799ls89dRTWLNmDUaMGIE5c+YAALp06YIjR45g7969GttWKpX47LPP0L59e/Wy8ePHa9Rs2bIFHTp0wOnTpzWuIZkzZw6GDx8OAIiIiMCkSZOwf/9+9O/fHwAwbdo0bNu2rc79jo2NhYeHB9auXQuZTIauXbvi2rVrmDt3LhYtWgR7e3vY2tpCLpdr7P+9pk+fjqCgIFy7dg2urq4oLCzE3r17kZSUVOeYxuIpISIiatYGDx6MjIwMjc/mzZvrHRMVFYXp06dj6NChWL58ucbpF20yMzNhZmaGfv36qZc5OjriwQcfRGZmJgDg7NmzePjhhzXG3fszAHTs2FEjrAB3rht59tln4ePjAzs7O3h7ewO4E6zu1rNnT/X/dnJyAgD06NFDY1lBQUG9+xEYGKjx6oX+/fvj9u3buHr1ap3j7vXwww+je/fu+PTTTwEAn332GTw9PTFgwACd1yEWAwsRETVrNjY26NSpk8bHzc2t3jGLFy/GqVOnMHLkSBw4cADdunXDN998U2e9IAh1Lq/58r/7f9c3zsbGptayJ554AkVFRdi0aRN+/fVX/PrrrwDuHI25290X6NZs695l1dXV9e5HXT2KfX/U9OnTsXXrVgB3TgdNmTJF0ndQMbAQEVGL1KVLF0RGRiIxMRHjxo1Tf/laWFjUOqXUrVs3VFVVqYMEABQVFeHcuXPw9fUFAHTt2hVHjx7VGHfs2LH79lFUVITMzEy89dZbGDJkCHx9fXHjxo3G7p5W3bp1w5EjRzSC1JEjR2Bra3vfkHevyZMnIycnB6tXr8apU6fwwgsv6LtdDQwsRETUopSVleG1115DcnIysrOzcfjwYaSlpamDh5eXF27fvo39+/ejsLAQpaWl6Ny5M0aPHo2XXnoJv/zyC06cOIHJkyfDzc0No0ePBgC8/vrrSEhIwKpVq3D+/Hl8/PHH+OGHH+571KFNmzZwdHTExo0bceHCBRw4cABRUVGS7PvMmTNx5coVvP766zhz5gy+++47vP3224iKihL9vp82bdpg3LhxePPNNxESEgJ3d3dJeq7Bi26JiKhOpnjXoFwuR1FREcLCwvDnn3+iXbt2GDduHJYsWQIACAoKQnh4OCZOnIiioiK8/fbbWLx4MbZu3YqIiAiMGjUKSqUSAwYMQEJCgvqUTP/+/bFhwwYsWbIEb731FoYPH47IyEisXbu23n5atWqFHTt2YNasWfDz88ODDz6I1atXY9CgQXrfdzc3NyQkJODNN9/EQw89hLZt22LatGl46623GrS+adOm4csvv8TUqVP13GltMqGuE3PNTElJCezt7VFcXAw7OztDt2NwvK2ZiHRVXl6OrKwseHt7w9LS0tDtmJSXXnoJZ86cQUpKiqFbkcQXX3yBiIgIXLt2DRYWFnXW1fd3TNfvbx5hISIi0pOVK1di2LBhsLGxwQ8//IBPPvkEsbGxhm5L70pLS5GVlYXo6GjMmDGj3rCiL7yGhYiISE+OHj2KYcOGoUePHtiwYQNWr16N6dOnG7otvVuxYgV69eoFJycnzJ8/v0m2ySMsREREevLVV18ZuoUmsXjxYvUrC5oKj7Dowd3vnLj34+npaej2iIiImj0Glkbq1KlTva8hv3LliqQP0iEiImoJGFgaoVOnTvd9nHMNhhYiIqKGY2BpoOLiYp3DSg2GFiIiooZhYGmg+k4D1ad79+76bYSIiKgFYGBpgC+++KLBY0+fPn3f154TERGRJgaWBpg8eXKjxpuZ8W5yIiKpDRo0CLNnz26y7W3btq3BR98b49799PLyQkxMTKPWmZycDJlMhps3bwIw3L7djYFFpL/++ksv6zl79qxe1kNEZExUKhWSk5Oxfft2JCcnS35E+cUXX9T6SIkLFy4gPj4ey5YtU9dq+yJvyi/iRx55BK+88orGsvXr10Mmk2HLli0ay6dNm4agoCCd1nvvfpoqBhaRunXrppf1dO3aVS/rISIyFvHx8fDy8sLgwYPx7LPPYvDgwfDy8kJ8fLyk23388ceRl5en8fH29kbbtm1ha2sr6bbFGDx4MA4ePKixLDk5GR4eHlqXDx48WKf1Gtt+SoWBRaQ///zT0C0QERmd+Ph4TJgwAVevXtVYnpubiwkTJkgaWhQKBZydnTU+crlc41TJoEGDkJ2djcjISPVRmOTkZEyZMkXj4Z81T29VKpX417/+BTc3N9jY2KBfv35ITk7W2O62bdvg6ekJa2trjB07FkVFRfX2OXjwYJw9exZ5eXnqZYcOHcL8+fM11n3lyhVcunRJHVhOnz6N0NBQtG7dGk5OTnj++edRWFiortd26uvWrVt49tln0bp1a7i6umLNmjXq312+fBkymQwZGRnqZTdv3lTPibFiYDEgKysrQ7dARNRoKpUKEREREASh1u9qls2ePdugNxzEx8fD3d0dS5cuVR+FCQoKQkxMDOzs7NTL5syZAwCYMmUKDh8+jB07duD333/HU089hccffxznz58HAPz666+YOnUqZs6ciYyMDAwePBjvvPNOvT30798f5ubm6lBw+vRplJWVYerUqSgpKVGv++DBg7CwsEBQUBDy8vIwcOBA9OrVC8eOHcO+ffvw559/4umnn653Wx988AF69uyJ3377DfPnz0dkZCSSkpIaOYuGxas/Rbh+/bpe11deXq7X9RERGUJKSkqtIyt3EwQBV65cQUpKCgYNGqT37e/duxetW7dW/zxixAh8/fXXGjVt27aFXC6Hra0tnJ2d1cvt7e0hk8k0ll28eBHbt2/H1atX4erqCgCYM2cO9u3bh61bt+K9997DRx99hOHDh2PevHkAgC5duuDIkSPYt29fnX3a2Nigb9++SE5OxqRJk5CcnIxHH30UCoUC/fv3R3JyMjp37ozk5GT069cP1tbWWL58Ofr06YP33ntPvZ64uDh4eHjg3Llz6NKli9Zt9e/fX6O3w4cP48MPP8SwYcN0nVajwyMsInTu3Fnv69TXRbxERIZy9ykOfdSJNXjwYGRkZKg/q1evbtT6fvvtNwiCgC5duqB169bqz6FDh9QPDM3MzERgYKDGuHt/rqvXmiMsycnJ6gA3cOBAjeWPPfYYAOD48eM4ePCgRh8110DW9/BSbb1lZmbetz9jxiMsIhQXF+t9nY6OjloPoxIRNRcuLi56rRPLxsYGnTp10tv6qqurIZfLcfz4ccjlco3f1RzJaei/24MHD8a7776L3NxcHDp0SH0KauDAgVizZg1ycnKQlZWlvn6luroaTzzxBN5///1a6xI7nzVPW2/VqlWtfaisrGzQ/jQlBhYiImqU4OBguLu7Izc3V+sXuUwmg7u7O4KDgw3Q3T8sLCxqXUejbVnv3r2hUqlQUFBQZ8/dunXD//73P41l9/6sTVBQEBQKBWJjY1FWVgZ/f38AQEBAAIqLi/Hxxx/D0tISjzzyCACgT58+2L17N7y8vEQ9w0tbbzVHZtq3bw/gzhGv3r17A4DGBbjGiqeEjABPCxFRcyaXy/HRRx8BqP3OtJqfY2Jiah2taGpeXl74+eefkZubq77LxsvLC7dv38b+/ftRWFiI0tJSdOnSBc899xzCwsIQHx+PrKwspKWl4f3330dCQgIAYNasWdi3bx9WrFiBc+fOYe3atfVev1LDysoK/fr1w5o1a9C/f3/1nJibmyMwMBBr1qxRhxoAePXVV/HXX39h0qRJOHr0KC5duoTExERMnTq13ouYDx8+rO5t3bp1+PrrrxEREaHu4ZFHHsHy5ctx+vRp/Pzzz3jrrbcaNbdNgYFFR2VlZZKt29HRUbJ1ExE1hXHjxmHXrl1wc3PTWO7u7o5du3Zh3LhxBursH0uXLsXly5fxwAMPqI8yBAUFITw8HBMnTkT79u2xYsUKAMDWrVsRFhaGN954Aw8++CCefPJJ/Prrr/Dw8ABw5yFwmzdvxpo1a9CrVy8kJibq/KU/ePBg3Lp1q9YFyAMHDsStW7c0nr/i6uqKw4cPQ6VSYfjw4fDz80NERATs7e3Vp3a0eeONN3D8+HH07t0by5Ytw3/+8x8MHz5c/fu4uDhUVlYiICAAERER973DyRjIBBO5gKKkpAT29vYoLi6GnZ2d3tc/efLkRr1D6H70/cfwYdK5Bo+NHKb9qnMiMk3l5eXIysqCt7c3LC0tG7UulUqFlJQU5OXlwcXFBcHBwQY/skKGV9/fMV2/v3kNi46kDCtERKai5oFtRPrGU0ISmDBhAtzd3UWNef755yXqhoiIqPlrUGCJjY1VH9bx9/dHSkpKvfWHDh2Cv78/LC0t4ePjgw0bNtSquXnzJl599VW4uLjA0tISvr6+6oubmptPP/0UV65cETXm888/l6gbIiKi5k90YNm5cydmz56NhQsXIj09HcHBwRgxYgRycnK01mdlZSE0NBTBwcFIT0/HggULMGvWLOzevVtdo1QqMWzYMFy+fBm7du3C2bNnsWnTploXbzUXfOQ+ERGRfom+hmXVqlWYNm0apk+fDuDOrWo//vgj1q9fj+jo6Fr1GzZsgKenp/qV3r6+vjh27BhWrlyJ8ePHA7hztfJff/2FI0eOwNzcHADQsWPHhu5Ts5Wfn6/xeGgioqZkIvdgkBHSx98tUUdYlEoljh8/jpCQEI3lISEhOHLkiNYxqampteqHDx+OY8eOqZ+st2fPHgQGBuLVV1+Fk5MT/Pz88N5779V7j3lFRQVKSko0PlK5fft2g8bVvMdBV1I9BZKIqD41/6FYWlpq4E7IVNX83ar5u9YQoo6wFBYWQqVSwcnJSWO5k5MT8vPztY7Jz8/XWl9VVYXCwkK4uLjg0qVLOHDgAJ577jkkJCTg/PnzePXVV1FVVYVFixZpXW90dDSWLFkipv0GmzBhQoPGRUdHY/ny5XruhohIv+RyORwcHFBQUAAAsLa2rvUAOKKGEAQBpaWlKCgogIODQ6NucW/Qbc33/kUWBKHev9za6u9eXl1djQ4dOmDjxo2Qy+Xw9/fHtWvX8MEHH9QZWObPn4+oqCj1zyUlJeoH+uhbYmKiJOslIjIWNaeja0ILkT45ODg0+pIHUYGlXbt2kMvltY6mFBQU1DqKUsPZ2VlrvZmZmfoJry4uLjA3N9dIXr6+vsjPz4dSqYSFhUWt9SoUCvWji6Um5txbz549G7WtkydPokePHo1aBxGRWDKZDC4uLujQoUOzeBEeNR/3fr83lKjAYmFhAX9/fyQlJWHs2LHq5UlJSRg9erTWMYGBgfjvf/+rsSwxMREBAQHqc1n9+/fHl19+ierqavWjhs+dOwcXFxetYcWY/fzzzxo/3+/o07169uzJC9+IyGDkcjmfTEtGSfRtzVFRUdi8eTPi4uKQmZmJyMhI5OTkIDw8HMCdUzVhYWHq+vDwcGRnZyMqKgqZmZmIi4vDli1b1K/UBoBXXnkFRUVFiIiIwLlz5/D999/jvffew6uvvqqHXWxa9vb2hm6BiIjI5Ii+hmXixIkoKirC0qVLkZeXBz8/PyQkJKhvQ87Ly9N4Jou3tzcSEhIQGRmJdevWwdXVFatXr1bf0gwAHh4eSExMRGRkJHr27Ak3NzdERERg7ty5ethFIiIiau748kMdiDmlo206vb29cfnyZZ3XcenSJXh7e+tcrw1ffkhERM2Brt/ffJdQE8jKyhJV7+PjI1EnREREzRMDCxERERk9Bpb7UCqVhm6BiIioxWNguY9ly5bpZT179+4VVV/fawmIiIhaGgaW+3j//fd1rq3vHQkjR44Utd2al0USERERA8t9VVVV6Vx7+vRpvW337ufUEBERtXQMLPdhZqb7o2o6deokYSdEREQtFwPLfej6DBZdXiGwY8eOxrZDRETUIjGw3IeudwnpUjdx4kRR2z5w4ICoeiIiIlPFwGLEhgwZYugWiIiIjAIDCxERERk9BhYiIiIyegwsTSw7O1tUfVlZmUSdEBERNR8MLHrSqpVuU+np6SlqvaNHj25IO0RERCZF94eMtEBi3iNUXV0tSQ9JSUn4MOmcJOsmIiJqLniEpR5r1qwxdAtEREQEBpZ6iXkOirW1tc618fHxDWmHiIioxWJgqcfRo0d1rt22bZvOtWPHjhXVx9VL+ntHERERUXPEwKIn48aNk2zdq8LFBRwiIiJTw8BSj3bt2ulU5+rqCrlcLnE3RERELRcDSz3Mzc11qnN0dJS4EyIiopaNgaUeV69e1Wvd3Y4dOyZ6DBERUUvFwFIPQRD0Wnc3f39/UfVHkhNEb4OIiMhUMLDUw9nZWa91jbHrvUjJt0FERGSs+KTbeigUikbX8Sm1REREjccjLPWwsrLSa929QsLeaNA4IiKiloaBpR4VFRV6rbvX45NfFlVfJeLdRkRERKaEgaUe+jglpE+frZzbJNshIiIyNgws9SgvL9drXWOd5J1CRETUQjGw1OPGjRt6rSMiIqKGYWCpR2VlpV7rtJm8dH2DxxIREbUUDCz10PXIibW1dYO30eeRx0TV5+dcaPC2iIiImisGljqUlZWhrKxMp9qmfJfQiukjm2xbRERExoKBpQ4zZ87UubYxp4SIiIjo/hhY6rBjxw6da93d3SXshIiIiBhY6iDmVuUBAwY0altTl29p1HgiIiJTx8CiB6+//nqjxvv1eVRU/dVLpxu1PSIiouaGgUUPLCwsmnR7q8LHNun2iIiIDI2BpQ5yuVyvdURERNRwDCx18Pb21msdERERNRwDSx2cnJz0Wnc/M2O+0Mt6iIiITBEDSx2OHz+u17r76dQtQFT9X/m5etkuERFRc9CgwBIbGwtvb29YWlrC398fKSkp9dYfOnQI/v7+sLS0hI+PDzZs2KDx+23btkEmk9X6NNVbkLVRqVR6rdO3d8LEPdKfiIioORMdWHbu3InZs2dj4cKFSE9PR3BwMEaMGIGcnByt9VlZWQgNDUVwcDDS09OxYMECzJo1C7t379aos7OzQ15ensbH0tKyYXtFREREJsVM7IBVq1Zh2rRpmD59OgAgJiYGP/74I9avX4/o6Oha9Rs2bICnpydiYmIAAL6+vjh27BhWrlyJ8ePHq+tkMhmcnZ0buBv6J5PJ9FpHREREDSfqCItSqcTx48cREhKisTwkJARHjhzROiY1NbVW/fDhw3Hs2DGNd/Dcvn0bHTt2hLu7O0aNGoX09PR6e6moqEBJSYnGR5+USqVe63QRteEbva2LiIjIlIgKLIWFhVCpVLXujHFyckJ+fr7WMfn5+Vrrq6qqUFhYCADo2rUrtm3bhj179mD79u2wtLRE//79cf78+Tp7iY6Ohr29vfrj4eEhZleMkrtPN1H1Z37/n0SdEBERGZcGXXR772kQQRDqPTWirf7u5Y888ggmT56Mhx56CMHBwfjqq6/QpUsXrFmzps51zp8/H8XFxerPlStXGrIrzdrGOS8YugUiIqImIeoalnbt2kEul9c6mlJQUFDn80icnZ211puZmcHR0VHrmFatWqFv3771HmFRKBRQKBRi2iciIqJmStQRFgsLC/j7+yMpKUljeVJSEoKCgrSOCQwMrFWfmJiIgIAAmJubax0jCAIyMjLg4uIipj294qP5iYiIjIfoU0JRUVHYvHkz4uLikJmZicjISOTk5CA8PBzAnVM1YWFh6vrw8HBkZ2cjKioKmZmZiIuLw5YtWzBnzhx1zZIlS/Djjz/i0qVLyMjIwLRp05CRkaFepyEY6jksr63ertf1ERERmQLRtzVPnDgRRUVFWLp0KfLy8uDn54eEhAR07NgRAJCXl6fxTBZvb28kJCQgMjIS69atg6urK1avXq1xS/PNmzfx8ssvIz8/H/b29ujduzd+/vlnPPzww3rYxebFp2sfUfV//PYL/Po8KlE3RERExkEm1FwB28yVlJTA3t4excXFsLOza/T6xDxfpb4p/DDpnOhtR4U8KKp+VeJZ0duoT+SwLnpdHxERUV10/f7mu4SIiIjI6DGwEBERkdFjYDFCczbuMXQLRERERoWBxQi5eom7huXwgb0SdUJERGQcGFgaqVUrw0/h7uVvGLoFIiIiSRn+29YIFRcXG7oFIiIiugsDixaPPfaYzrV80i0REZH0GFi0+O2333Su7dSpkyQ9zFq7U5L1EhERNUcMLI30yy+/SLJery69RNX/tOtTSfogIiIyBgwsjdS2bVtDtwAASNj4rqFbICIikgwDCxERERk9BhYiIiIyegwsRuxfm783dAtERERGgYHFiDl7irsDaX/85xJ1QkREZFgMLCbk+w3LDN0CERGRJBhYiIiIyOgxsBAREZHRY2AxcrNjdxm6BSIiIoNjYDFynp16iKrnhbdERGSKGFhMDC+8JSIiU8TAQkREREaPgYWIiIiMHgNLMzBn4x5Dt0BERGRQDCzNgKvXg6Lq93y8SqJOiIiIDIOBxQQl7/7Y0C0QERHpFQMLERERGT0GFiIiIjJ6DCzNxNIdqYZugYiIyGAYWJqJ1m3biqrfvCxCok6IiIiaHgOLiTqdss/QLRAREekNAwsREREZPQaW5sSytaE7ICIiMggGlmZk+c5fRNWX374tUSdERERNi4GlGbGwshJVv3jqcIk6ISIialoMLCZMebPQ0C0QERHpBQMLERERGT0GlmamX+hThm6BiIioyTGwNDMTZ78jqj7nwkmJOiEiImo6ZoZuoLn7MOmcoVuoV8zMCViVeNbQbRARETUKj7AQERGR0WNgISIiIqPHwNIMPfTYE4ZugYiIqEk1KLDExsbC29sblpaW8Pf3R0pKSr31hw4dgr+/PywtLeHj44MNGzbUWbtjxw7IZDKMGTOmIa21CC/MWymq/n8/80WIRETUvIkOLDt37sTs2bOxcOFCpKenIzg4GCNGjEBOTo7W+qysLISGhiI4OBjp6elYsGABZs2ahd27d9eqzc7Oxpw5cxAcHCx+T6hOX70TYegWiIiIGkV0YFm1ahWmTZuG6dOnw9fXFzExMfDw8MD69eu11m/YsAGenp6IiYmBr68vpk+fjqlTp2LlSs2jBCqVCs899xyWLFkCHx+f+/ZRUVGBkpISjQ8RERGZJlGBRalU4vjx4wgJCdFYHhISgiNHjmgdk5qaWqt++PDhOHbsGCorK9XLli5divbt22PatGk69RIdHQ17e3v1x8PDQ8yuEBERUTMiKrAUFhZCpVLByclJY7mTkxPy8/O1jsnPz9daX1VVhcLCO++6OXz4MLZs2YJNmzbp3Mv8+fNRXFys/ly5ckXMrjR7ExZ8aOgWiIiImkyDLrqVyWQaPwuCUGvZ/eprlt+6dQuTJ0/Gpk2b0K5dO517UCgUsLOz0/i0JEGDQkXVfxO7XKJOiIiIpCfqSbft2rWDXC6vdTSloKCg1lGUGs7OzlrrzczM4OjoiFOnTuHy5ct44ol/btWtrq6+05yZGc6ePYsHHnhATJukRcq3WzF25jxDt0FERNQgoo6wWFhYwN/fH0lJSRrLk5KSEBQUpHVMYGBgrfrExEQEBATA3NwcXbt2xcmTJ5GRkaH+PPnkkxg8eDAyMjJ4bQoRERGJf5dQVFQUnn/+eQQEBCAwMBAbN25ETk4OwsPDAdy5tiQ3NxeffvopACA8PBxr165FVFQUXnrpJaSmpmLLli3Yvn07AMDS0hJ+fn4a23BwcACAWsubwp49e5p8m0RERFQ/0YFl4sSJKCoqwtKlS5GXlwc/Pz8kJCSgY8eOAIC8vDyNZ7J4e3sjISEBkZGRWLduHVxdXbF69WqMHz9ef3uhR6NHjzZ0CzobNfNt7I1dYug2iIiIJCcTaq6AbeZKSkpgb2+P4uLiRl2AW9/Fw9oY+k3IUSEP6lzr++hwvLRo9X3rIod1aUxLREREOtP1+5vvEmpBMn/50dAtEBERNQgDSyNEbfjG0C0QERG1CAwsjeDu083QLcDSqaOhWyAiIpIcA0sz9862H0TV//a/AxJ1QkREJB0GlmaulVwuqv7zRa9I1AkREZF0GFiIiIjI6DGwEBERkdFjYDEBPQePMnQLREREkmJgMQEvzv+PqPodHy6UqBMiIiJpMLC0QEd/2GXoFoiIiERhYLlH165ddapr79lJ4k6IiIioBgPLPbp00e09Oh1cPSTuhIiIiGowsNxj3LhxOtX59Q+RuBNxRs9+V1R9fs4FiTohIiLSPwaWe3TsqNuj7h2d3STuRJyBoRNE1a+YPlKiToiIiPSPgeUewcHBcHR0rLfG2s4BPn4BTdQRERERMbAQERGR0WNguUdKSgqKiorqrSktuYlLfxxroo501y34cUO3QEREJAkGlnvk5eXpVFfy13WJOxFv+r8/ElUf+2++CJGIiJoHBpZ7uLi46FRn17a9xJ1I78KvBwzdAhERkU4YWO4RHBwMd3d3yGSyOipkcGjvzItuiYiImhADyz3kcjk++ujOqZXaoeXOz2NeWYhWcnkTd0ZERNRyMbBoMW7cOOzatQtubprPWnFo74QXF61Gz0eN66Fxd3ty1jJR9f/7eZ9EnRAREemPTBAEwdBN6ENJSQns7e1RXFwMOzs7vaxTpVIhJSUFWxJ/g13b9vDxC2gWR1aiQh4UVb8q8azGz5HDdHs9ARERUWPp+v1t1oQ9NTtyuRyDBg1CeqWroVshIiJq0XhKiIiIiIweA4sJcusZaOgWiIiI9IqBxQS9sXKbqPq3X9btDdVERESGwsBCuHX5lKFbICIiqhcDCxERERk9BhYiIiIyegwsJip81Wei6jcueV2iToiIiBqPgcVEdfF7WFT9mcOJEnVCRETUeAwsREREZPQYWIiIiMjoMbCYsMeeflVUfeKOOIk6ISIiahwGFhM2avosUfX74t6XqBMiIqLGYWAhIiIio8fAQkREREaPgcXEPRg0TFR9fs4FiTohIiJqOAYWEzdj8VpR9Sumj5SoEyIiooZjYCEiIiKjx8BCRERERq9BgSU2Nhbe3t6wtLSEv78/UlJS6q0/dOgQ/P39YWlpCR8fH2zYsEHj9/Hx8QgICICDgwNsbGzQq1cvfPaZuHfhUN36DBsjql6lUknTCBERUQOJDiw7d+7E7NmzsXDhQqSnpyM4OBgjRoxATk6O1vqsrCyEhoYiODgY6enpWLBgAWbNmoXdu3era9q2bYuFCxciNTUVv//+O6ZMmYIpU6bgxx9/bPiekdrkN8U9X2XMmDHSNEJERNRAMkEQBDED+vXrhz59+mD9+vXqZb6+vhgzZgyio6Nr1c+dOxd79uxBZmamell4eDhOnDiB1NTUOrfTp08fjBw5EsuWLdP6+4qKClRUVKh/LikpgYeHB4qLi2FnZydml+7rw6Rzel2fIUSFPCiqXuRfCyIiogYpKSmBvb39fb+/RR1hUSqVOH78OEJCQjSWh4SE4MiRI1rHpKam1qofPnw4jh07hsrKylr1giBg//79OHv2LAYMGFBnL9HR0bC3t1d/PDw8xOwKERERNSOiAkthYSFUKhWcnJw0ljs5OSE/P1/rmPz8fK31VVVVKCwsVC8rLi5G69atYWFhgZEjR2LNmjUYNqzuZ4jMnz8fxcXF6s+VK1fE7EqLE/ryQlH1vI6FiIiMSYMuupXJZBo/C4JQa9n96u9dbmtri4yMDKSlpeHdd99FVFQUkpOT61ynQqGAnZ2dxofqNnRCmKj6WbPEvYeIiIhISqICS7t27SCXy2sdTSkoKKh1FKWGs7Oz1nozMzM4Ojr+00irVujUqRN69eqFN954AxMmTNB6TQw1jdjYWEO3QEREpCYqsFhYWMDf3x9JSUkay5OSkhAUFKR1TGBgYK36xMREBAQEwNzcvM5tCYKgcVEtERERtVyiTwlFRUVh8+bNiIuLQ2ZmJiIjI5GTk4Pw8HAAd64tCQv75/RDeHg4srOzERUVhczMTMTFxWHLli2YM2eOuiY6OhpJSUm4dOkSzpw5g1WrVuHTTz/F5MmT9bCLVOPF9zaJqud1LEREZCzMxA6YOHEiioqKsHTpUuTl5cHPzw8JCQno2LEjACAvL0/jmSze3t5ISEhAZGQk1q1bB1dXV6xevRrjx49X1/z999+YOXMmrl69CisrK3Tt2hWff/45Jk6cqIddpBo9A+q+60qbRYsW4d1335WoGyIiIt2Jfg6LsdL1Pu6GMIXnsNTg81iIiMiYSPIcFiIiIiJDYGBpYZ54bYmo+r/++kuiToiIiHTHwNLCDH7yGVH13bt3l6gTIiIi3TGwUL3qeoIxERFRU2JgISIiIqPHwNICPbt4naj6s2fPStQJERGRbhhYWqCAoKGi6rt27SpRJ0RERLphYCEiIiKjx8BCRERERo+BpYWatXanqPpvvvlGok6IiIjuj4GlhfLq0ktU/bhx46RphIiISAcMLERERGT0GFiIiIjI6DGwtGBir2P57LPPJOqEiIiofgwsLZjY61jCwsKkaYSIiOg+GFiIiIjI6DGwtHBtvR8UVZ+bmytRJ0RERHVjYGnh/hUj7joWd3d3iTohIiKqGwNLC2dhZWXoFoiIiO6LgYWIiIiMHgML4bXV20XVHzhwQKJOiIiItGNgIfh07SOqfsiQIRJ1QkREpB0DCxERERk9BhYCAMjNLUTVX7hwQaJOiIiIamNgIQDAwq1Jouo7d+4sUSdERES1MbAQAMChg7OhWyAiIqoTAwsREREZPQYWUpuw4ENR9R9//LFEnRAREWliYCG1oEGhourDw8Ml6oSIiEgTAwsREREZPQYW0mDeuq2o+j179kjUCRER0T8YWEjD21v3iaofPXq0RJ0QERH9g4GFNFjb2xu6BSIioloYWKjR8vPzDd0CERGZOAYWquX8+fOi6jt16iRRJ0RERHcwsFAtYgPI33//LVEnREREdzCwkF6oVCpDt0BERCaMgYW0io+PF1W/cuVKiTohIiJiYKE6jB07VlT9vHnzJOqEiIiIgYXqYW5uLqqep4WIiEgqDCxUp7Nnz4qq37hxo0SdEBFRS8fAQnXy9vYWVT9z5kyJOiEiopauQYElNjYW3t7esLS0hL+/P1JSUuqtP3ToEPz9/WFpaQkfHx9s2LBB4/ebNm1CcHAw2rRpgzZt2mDo0KE4evRoQ1ojIiIiEyQ6sOzcuROzZ8/GwoULkZ6ejuDgYIwYMQI5OTla67OyshAaGorg4GCkp6djwYIFmDVrFnbv3q2uSU5OxqRJk3Dw4EGkpqbC09MTISEhyM3NbfiekV6cOXNGVH1WVpZEnRARUUsmEwRBEDOgX79+6NOnD9avX69e5uvrizFjxiA6OrpW/dy5c7Fnzx5kZmaql4WHh+PEiRNITU3Vug2VSoU2bdpg7dq1CAsL01pTUVGBiooK9c8lJSXw8PBAcXEx7OzsxOzSfX2YdE6v6zN2kcO6aPwsk8l0Hmtubg6lUqnvloiIyESVlJTA3t7+vt/foo6wKJVKHD9+HCEhIRrLQ0JCcOTIEa1jUlNTa9UPHz4cx44dQ2VlpdYxpaWlqKysRNu2bevsJTo6Gvb29uqPh4eHmF0hEaytrXWurevPlIiIqDFEBZbCwkKoVCo4OTlpLHdycqrzBXj5+fla66uqqlBYWKh1zLx58+Dm5oahQ4fW2cv8+fNRXFys/ly5ckXMrpAI586JO8J04cIFiTohIqKWyqwhg+49RSAIQr2nDbTVa1sOACtWrMD27duRnJwMS0vLOtepUCigUCjEtE0N5ObmJqq+c+fOEHmmkYiIqF6ijrC0a9cOcrm81tGUgoKCWkdRajg7O2utNzMzg6Ojo8bylStX4r333kNiYiJ69uwppjWSWH2n57ThdSxERKRPogKLhYUF/P39kZSUpLE8KSkJQUFBWscEBgbWqk9MTERAQIDGk1Q/+OADLFu2DPv27UNAQICYtqgJnDp1SlT9smXLJOqEiIhaItG3NUdFRWHz5s2Ii4tDZmYmIiMjkZOTg/DwcAB3ri25+86e8PBwZGdnIyoqCpmZmYiLi8OWLVswZ84cdc2KFSvw1ltvIS4uDl5eXsjPz0d+fj5u376th10kfXB2dhZV/84770jUCRERtUSir2GZOHEiioqKsHTpUuTl5cHPzw8JCQno2LEjACAvL0/jmSze3t5ISEhAZGQk1q1bB1dXV6xevRrjx49X18TGxkKpVGLChAka23r77bexePHiBu4a6VurVq1QXV2tc71SqYSFhYWEHRERUUsh+jksxkrX+7gboqU/h6XGhQsX0LlzZ53Xs2jRIixZskRfbRERkQmS5Dks1LJ16tRJVP3SpUsl6oSIiFoaBhaSFK9DIiIifWBgIVF+//13UfWhoaESdUJERC0JAwuJ0qNHD1H193uTNxERkS4YWEi0rl27iqo/ffq0RJ0QEVFLwcBCov3vf/8TVd+9e3eJOiEiopaCgYVEs7e3Fz2Gj+onIqLGYGChBpk9e7ao+gULFkjTCBERtQgMLNQg77//vqj6//znPxJ1QkRELQEDCzWIhYUFZDKZqDG5ubkSdUNERKaOgYUa7OLFi6LqfX19JeqEiIhMHQMLNZi3t7eo+lu3bknUCRERmToGFmoUKysrUfXff/+9RJ0QEZEpY2ChRjl//ryo+lGjRknUCRERmTIzQzdAxufDpHOSrj8/Px/Ozs6SboOIiEwLj7BQo0Vt+EZUvdhrX4iIiBhYqNHcfbqJqi8vL4dKpZKoGyIiMkUMLKQXzj7iblnevn27RJ0QEZEpYmAhvXjt/U9E1T///PMSdUJERKaIgYX0wroBL0S8cOGCBJ0QEZEpYmAhvZmzcY+o+s6dO0vUCRERmRoGFtIbV68HRY8pKyuToBMiIjI1DCykV9u2bRNV36dPH2kaISIik8LAQno1efJkUfVnzpyBUqmUqBsiIjIVDCykV3K5HP7+/qLGhIaGStQNERGZCgYW0ruUlBRR9fv37+eD5IiIqF4MLKR3Yt/gDABffvmlBJ0QEZGpYGAhSZw5c0ZUfVhYmESdEBGRKWBgIUk8+KD4W5xTU1Ml6ISIiEwBAwtJRuxRlqCgIIk6ISKi5o6BhSTTkKMsOTk5EnRCRETNHQMLSWr9+vWi6jt27ChRJ0RE1JwxsJCkXnrpJdFjeC0LERHdi4GFJCWXyxEYGChqDK9lISKiezGwkOT2798veszZs2cl6ISIiJorBhaSnJWVFXr37i1qTNeuXSXqhoiImiMGFmoSaWlposd8+OGHEnRCRETNEQMLNQm5XI7w8HBRY6KioviOISIiAsDAQk1o7dq1osf069dPgk6IiKi5YWChJiOXy7FhwwZRY44fP46ysjKJOiIiouaCgYWa1IwZM0SPeeCBByTohIiImpMGBZbY2Fh4e3vD0tIS/v7+SElJqbf+0KFD8Pf3h6WlJXx8fGr9V/apU6cwfvx4eHl5QSaTISYmpiFtUTORnZ0tqj4vL49HWYiIWjjRgWXnzp2YPXs2Fi5ciPT0dAQHB2PEiBF1vgMmKysLoaGhCA4ORnp6OhYsWIBZs2Zh9+7d6prS0lL4+Phg+fLlcHZ2bvjeULPg6ekpeoy1tbUEnRARUXMhOrCsWrUK06ZNw/Tp0+Hr64uYmBh4eHjU+c6YDRs2wNPTEzExMfD19cX06dMxdepUrFy5Ul3Tt29ffPDBB3jmmWegUCgavjfUbJSWlooe8/HHH0vQCRERNQeiAotSqcTx48cREhKisTwkJARHjhzROiY1NbVW/fDhw3Hs2DFUVlaKbPcfFRUVKCkp0fhQ82FlZYVevXqJGhMeHs7bnImIWihRgaWwsBAqlQpOTk4ay52cnJCfn691TH5+vtb6qqoqFBYWimz3H9HR0bC3t1d/PDw8GrwuMoxjx46JHuPi4iJBJ0REZOwadNGtTCbT+FkQhFrL7levbbkY8+fPR3Fxsfpz5cqVBq+LDEMul2P27Nmixly/fh1ffPGFNA0REZHREhVY2rVrB7lcXutoSkFBQa2jKDWcnZ211puZmcHR0VFku/9QKBSws7PT+FDzc/e1TLqaPHkyTw0REbUwogKLhYUF/P39kZSUpLE8KSkJQUFBWscEBgbWqk9MTERAQADMzc1FtkumRi6XY+fOnaLHWVpaStANEREZK9GnhKKiorB582bExcUhMzMTkZGRyMnJUb8nZv78+QgLC1PXh4eHIzs7G1FRUcjMzERcXBy2bNmCOXPmqGuUSiUyMjKQkZEBpVKJ3NxcZGRk4MKFC3rYRTJ2Tz/9NFxdXUWNqaqqqvO6KSIiMj1mYgdMnDgRRUVFWLp0KfLy8uDn54eEhAR07NgRwJ2HfN39TBZvb28kJCQgMjIS69atg6urK1avXo3x48era65du4bevXurf165ciVWrlyJgQMHIjk5uRG7R83FhQsXRD9rxcXFRX09FBERmTaZYCL/4peUlMDe3h7FxcV6v57lw6Rzel2fKYsc1qXBY0eMGIF9+/aJGuPp6Sn6yblERGQ8dP3+5ruEyGj88MMPkMvlosbk5OQgMjJSoo6IiMhYMLCQUamoqBA9JiYmBkqlUoJuiIjIWDCwkFGRy+W1Xo6pC941RERk2hhYyOjMmDFD9BhBEGBvby9BN0REZAwYWMgoVVVViR5TUlKCTz75RIJuiIjI0BhYyCg19IFyL774Ip+CS0RkghhYyGg9/fTT6Nu3r+hxZmaiHy9ERERGjoGFjFpqamqDxjXmxZpERGR8GFjIqMnlcmzbtq1BY9u1a6ffZoiIyGAYWMjovfDCCw16enFRURFfsElEZCIYWKhZKC4uRqtW4v+6VlVVQaFQSNARERE1JQYWajYaevePUqlESEiInrshIqKmxMBCzUpD39WZlJSEiIgIPXdDRERNhfd/kl415s3Wur7puaqqqkG3Lq9evRqXLl3Cf//7X9FjiYjIsHiEhZqdxtw5tHfvXvTu3Vu/DRERkeQYWKhZauidQwCQkZEBGxsbPXdERERSYmChZqu4uLjBD4grLS2Fra2tnjsiIiKpMLBQs1ZdXd3gsbdv38ZDDz2kx26IiEgqDCzU7DX0ziEA+P333+Hl5aW/ZoiISBIMLGQSGhNasrOzYW5uDqVSqceOiIhInxhYyGQ0JrTUPBE3PDxcjx0REZG+MLCQSREEoVFvav74448hk8l4tIWIyMgwsJDJacyFuDUUCgVmzZqlh26IiEgfGFjIJDXm9FCNNWvWwMbGpsHvMCIiIv1hYCGTJQgC5HJ5o9ZRWloKMzMzfPbZZ3rqioiIGoKBhUxaVVVVo65pqREWFgaFQoGysjI9dEVERGIxsJDJq66uhpWVVaPXo1QqYW1tDQcHBxQXF+uhMyIi0hUDC7UIpaWlyMvL08u6iouL4eDgAAsLCwYXIqImwsBCLYazs7NeLsatUVlZCQcHB1hZWeH27dt6Wy8REdXGwEItjiAIsLS01Nv6ysvLYWtrCxsbGx5xISKSCAMLtUhlZWWIi4vT6zpLS0vh4OAAmUyGxx9/nEddiIj0iIGFWqwpU6agqqpKr0dbavz444+wtbWFlZUVj7oQEekBAwu1aHK5HGVlZQgNDZVk/eXl5XBwcIBcLsecOXOwf/9+PoiOiKgBGFiIAHz//fcoLS3FgAEDJFl/dXU1/vOf/2Do0KEwMzPDk08+yfBCRCSCTNDnbRMGVFJSAnt7exQXF8POzk6v6/4w6Zxe10f6Fzmsi97WpVKpoFAomixMtGrVCl26dMGLL76IyMhIWFhYNMl2iYiMga7f3zzCQnQPuVyOqqoqjBgxokm2V11djTNnzmDevHlQKBSQy+Vwd3fHjBkz+GRdIqL/x8BCVIeEhASUlpaie/fuTbrd6upq5ObmYuPGjbC2toZMJoNMJoONjQ1GjhzJu4+IqEViYCGqh5WVFf744w9UVFRg8eLFBu2ltLQUCQkJsLW1haWlJby9vdG/f3988MEHUCqVBu2NiEhqvIZFB7yGxfSJuQZm1KhR+P777yXspmHatGmDyspKVFdXw8HBAc888wxCQ0MxaNCgRr+1mohIKryGhUgie/fuRWlpKaZPn66XN0Hry40bN3D79m2Ulpbi2rVrWLVqFYYOHYq2bdti1KhRsLGxgYWFBaysrNChQwe0bdsWrq6ucHNzg7OzM7p3747nnnsOiYmJvHuJiIwOj7DogEdYqD5TH3ZCx44dTe4BcQ4ODqisrAQA2NnZoaSkBFVVVXBwcMDQoUORmpqKP//8E61bt8bjjz+ODh06ICMjA9bW1hgwYABee+013vFERPel6/c3A4sOGFhIF8qyMmxf9RZOHNpr6FaMQqtWrRAREQE3NzekpKTg77//Rvv27eHt7Y2BAwdCEAR88cUXKCkpgaurKwIDA+Hq6gqVSoVDhw4hKysLf/75JyoqKuDl5YWwsDAMGTJE/bC/N954A2lpaXBwcMCQIUNw69YtVFdXo7i4GIIgID8/H05OTmjVqpX64X0DBgxAq1atkJ+fj+vXr8PR0RHXrl3Djz/+iPPnz8POzg79+/dHcHAwPDw8EBwcDABITk7GgQMHkJ2dDZVKpb4Qurq6GtevX0fr1q0RHByMGTNmYPPmzbh48SK8vb3Ro0cP5Ofn49dff4VKpYJcLkffvn1x48YNtG/fHs7OzgCAgoICtGvXDmlpadi0aRPKy8vh5eWFoKAgnDx5Un33mLOzM8zMzNC3b18UFhaisLAQV69ehaenJwYNGoTy8nIsXrwY165dg62tLcaMGYOhQ4dCLpert3Hy5ElcvHgRMpkM/fr1g7OzM06cOIHDhw/D1tYWzzzzDDIzM3H58mU88MADmDlzJgAgNjYWFy9eVC+7N4yqVCr1POXk5MDd3R0ODg44efIkiouL8ddff8HKygpWVlawsbFBeXm5xp+7UqnEypUrceLECZSVlcHKygoeHh7w9fVV/52p+bNIS0tDaWkprK2t4e/vD0dHR9y8eROtWrVCcHAwysvLsWTJEly+fBl2dnZ4+eWX8cYbb8DCwgIqlQopKSnIzs7Gt99+i7///htdunTB8uXLcezYMeTm5uL69esafz7Xrl3D4cOHcfLkSZSUlKBHjx7o3bs3OnTogLS0tDr/bGu2BQCDBg1Sn56tWZ6XlwcXFxcEBwfXOm1bM5/Jycm1xt9dc7/13I8u2ykrK8Obb76J8+fPo3Pnzvjggw9gZWUlajv1kTSwxMbG4oMPPkBeXh66d++OmJgY9f+xtTl06BCioqJw6tQpuLq64l//+hfCw8M1anbv3o1///vf6v9DvPvuuxg7dqzOPTGwkDEpv30bn0RH4vxvR1CtqjJ0OyajdevW8PX1RVpaWpNsz9HRERUVFS36zqya0553f1XI5XJERUVhxYoVAID4+Hi8/PLLKCoqMkiPuho9ejSOHz+Oq1evGmT7jo6OmDp1KrZv367Rg7u7Oz766COMGzcOQN3z6ejoiI0bN2LcuHGIj49HREREveu5H122M2bMGHz33Xe1xo4ePRrffvutrrteL8kCy86dO/H8888jNjYW/fv3x8cff4zNmzfj9OnT8PT0rFWflZUFPz8/vPTSS5gxYwYOHz6MmTNnYvv27Rg/fjwAIDU1FcHBwVi2bBnGjh2Lb775BosWLcIvv/yCfv366XWHG4KBhRqjWqXCqV9/xvYVb6K89Jah2yHSmzfffBOPPPKI+t9yapiaULhr1y4AuO98vvnmm1i5ciXu/fq+ez33Cy3x8fH33U7fvn3r/Y8DfYUWyQJLv3790KdPH6xfv169zNfXF2PGjEF0dHSt+rlz52LPnj3IzMxULwsPD8eJEyeQmpoKAJg4cSJKSkrwww8/qGsef/xxtGnTBtu3b9epLwYWag6qlEr8/N1nOPHzPlw5+7uh2yFqFLlcDicnJ1y7ds3QrTR7MpkMbm5uEAQBubm59da2atUK1dXVda7H3d0dWVlZdZ4eUqlU8PLy0suRptLS0kafHtL1+9tMzEqVSiWOHz+OefPmaSwPCQnBkSNHtI5JTU1FSEiIxrLhw4djy5YtqKyshLm5OVJTUxEZGVmrJiYmps5eKioqUFFRof655oLHkpISMbukk/K/W+7hYNK/oNCJCAqdCAC4feMG1i+cght5VwzcFZF4KpWKYUVPBEHQOUDUFVZq1nPlyhXs27evzks1UlJS9HZaLCIiAitXrmzUOmq+t+93/ERUYCksLIRKpYKTk5PGcicnJ+Tn52sdU3Ph2731VVVVKCwshIuLS501da0TAKKjo7FkyZJayz08PHTdHSIiIpM0atSoJtnOpk2bsGnTJr2s69atW7C3t6/z96ICS417nz0hCEK9z6PQVn/vcrHrnD9/PqKiotQ/V1dX46+//oKjo6Nen41RUlICDw8PXLlyRe+nmkwN50p3nCvdca50x7kSh/OlOynnShAE3Lp1C66urvXWiQos7dq1g1wur3Xko6CgoNYRkhrOzs5a683MzODo6FhvTV3rBACFQgGFQqGxzMHBQdddEc3Ozo5/oXXEudId50p3nCvdca7E4XzpTqq5qu/ISg1RT7q1sLCAv78/kpKSNJYnJSUhKChI65jAwMBa9YmJiQgICIC5uXm9NXWtk4iIiFoW0aeEoqKi8PzzzyMgIACBgYHYuHEjcnJy1M9VmT9/PnJzc/Hpp58CuHNH0Nq1axEVFYWXXnoJqamp2LJli8bdPxERERgwYADef/99jB49Gt999x1++ukn/PLLL3raTSIiImrORAeWiRMnoqioCEuXLkVeXh78/PyQkJCAjh07AgDy8vKQk5Ojrvf29kZCQgIiIyOxbt06uLq6YvXq1Rr3fwcFBWHHjh1466238O9//xsPPPAAdu7cqfMzWKSkUCjw9ttv1zr9RLVxrnTHudId50p3nCtxOF+6M4a5MplH8xMREZHp4tuaiYiIyOgxsBAREZHRY2AhIiIio8fAQkREREaPgYWIiIiMHgNLPWJjY+Ht7Q1LS0v4+/sjJSXF0C0ZXHR0NPr27QtbW1t06NABY8aMwdmzZzVqBEHA4sWL4erqCisrKwwaNAinTp0yUMfGIzo6GjKZDLNnz1Yv41z9Izc3F5MnT4ajoyOsra3Rq1cvHD9+XP17ztU/qqqq8NZbb8Hb2xtWVlbw8fHB0qVLNV6K11Ln6+eff8YTTzwBV1dXyGQyfPvttxq/12VeKioq8Prrr6Ndu3awsbHBk08+qbeXBRqT+uaqsrISc+fORY8ePWBjYwNXV1eEhYXVetllk86VQFrt2LFDMDc3FzZt2iScPn1aiIiIEGxsbITs7GxDt2ZQw4cPF7Zu3Sr88ccfQkZGhjBy5EjB09NTuH37trpm+fLlgq2trbB7927h5MmTwsSJEwUXFxehpKTEgJ0b1tGjRwUvLy+hZ8+eQkREhHo55+qOv/76S+jYsaPw4osvCr/++quQlZUl/PTTT8KFCxfUNZyrf7zzzjuCo6OjsHfvXiErK0v4+uuvhdatWwsxMTHqmpY6XwkJCcLChQuF3bt3CwCEb775RuP3usxLeHi44ObmJiQlJQm//fabMHjwYOGhhx4SqqqqmnhvpFXfXN28eVMYOnSosHPnTuHMmTNCamqq0K9fP8Hf319jHU05VwwsdXj44YeF8PBwjWVdu3YV5s2bZ6COjFNBQYEAQDh06JAgCIJQXV0tODs7C8uXL1fXlJeXC/b29sKGDRsM1aZB3bp1S+jcubOQlJQkDBw4UB1YOFf/mDt3rvDoo4/W+XvOlaaRI0cKU6dO1Vg2btw4YfLkyYIgcL5q3PslrMu83Lx5UzA3Nxd27NihrsnNzRVatWol7Nu3r8l6b2rawt29jh49KgBQ/4d7U88VTwlpoVQqcfz4cYSEhGgsDwkJwZEjRwzUlXEqLi4GALRt2xYAkJWVhfz8fI25UygUGDhwYIudu1dffRUjR47E0KFDNZZzrv6xZ88eBAQE4KmnnkKHDh3Qu3dvjVfWc640Pfroo9i/fz/OnTsHADhx4gR++eUXhIaGAuB81UWXeTl+/DgqKys1alxdXeHn59ei5w648++9TCZTv2i4qedK9KP5W4LCwkKoVKpab4t2cnKq9VbplkwQBERFReHRRx+Fn58fAKjnR9vcZWdnN3mPhrZjxw789ttvSEtLq/U7ztU/Ll26hPXr1yMqKgoLFizA0aNHMWvWLCgUCoSFhXGu7jF37lwUFxeja9eukMvlUKlUePfddzFp0iQA/LtVF13mJT8/HxYWFmjTpk2tmpb87395eTnmzZuHZ599Vv225qaeKwaWeshkMo2fBUGotawle+211/D7779rfUkl5w64cuUKIiIikJiYCEtLyzrrOFdAdXU1AgIC8N577wEAevfujVOnTmH9+vUICwtT13Gu7ti5cyc+//xzfPnll+jevTsyMjIwe/ZsuLq64oUXXlDXcb60a8i8tOS5q6ysxDPPPIPq6mrExsbet16queIpIS3atWsHuVxeKyEWFBTUSuYt1euvv449e/bg4MGDcHd3Vy93dnYGAM4d7hwuLSgogL+/P8zMzGBmZoZDhw5h9erVMDMzU88H5wpwcXFBt27dNJb5+vqqX6TKv1ea3nzzTcybNw/PPPMMevTogeeffx6RkZGIjo4GwPmqiy7z4uzsDKVSiRs3btRZ05JUVlbi6aefRlZWFpKSktRHV4CmnysGFi0sLCzg7++PpKQkjeVJSUkICgoyUFfGQRAEvPbaa4iPj8eBAwfg7e2t8Xtvb284OztrzJ1SqcShQ4da3NwNGTIEJ0+eREZGhvoTEBCA5557DhkZGfDx8eFc/b/+/fvXuj3+3Llz6rfA8++VptLSUrRqpfnPt1wuV9/WzPnSTpd58ff3h7m5uUZNXl4e/vjjjxY3dzVh5fz58/jpp5/g6Oio8fsmnyu9X8ZrImpua96yZYtw+vRpYfbs2YKNjY1w+fJlQ7dmUK+88opgb28vJCcnC3l5eepPaWmpumb58uWCvb29EB8fL5w8eVKYNGlSi7idUhd33yUkCJyrGkePHhXMzMyEd999Vzh//rzwxRdfCNbW1sLnn3+uruFc/eOFF14Q3Nzc1Lc1x8fHC+3atRP+9a9/qWta6nzdunVLSE9PF9LT0wUAwqpVq4T09HT1nS26zEt4eLjg7u4u/PTTT8Jvv/0mPPbYYyZ5W3N9c1VZWSk8+eSTgru7u5CRkaHx731FRYV6HU05Vwws9Vi3bp3QsWNHwcLCQujTp4/61t2WDIDWz9atW9U11dXVwttvvy04OzsLCoVCGDBggHDy5EnDNW1E7g0snKt//Pe//xX8/PwEhUIhdO3aVdi4caPG7zlX/ygpKREiIiIET09PwdLSUvDx8REWLlyo8UXSUufr4MGDWv+NeuGFFwRB0G1eysrKhNdee01o27atYGVlJYwaNUrIyckxwN5Iq765ysrKqvPf+4MHD6rX0ZRzJRMEQdD/cRsiIiIi/eE1LERERGT0GFiIiIjI6DGwEBERkdFjYCEiIiKjx8BCRERERo+BhYiIiIweAwsREREZPQYWIiIiMnoMLERERGT0GFiIiIjI6DGwEBERkdH7PzbFSKp1/1GZAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#b.get k from train data\n",
    "rv = sc_stats.weibull_min.fit(y_train)\n",
    "k=float(rv[0])\n",
    "print (f\"Fitted k ={k}\")\n",
    "\n",
    "plt.hist(y_train,alpha=0.5,density=True,bins=30,label=\"Histogram of y\")\n",
    "plt.scatter(y_train, sc_stats.weibull_min.pdf(y_train,*rv),label=\"Fitted Weibull\",color=\"black\")\n",
    "plt.title(\"y-train\")\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "0fc9382f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# mu_prop_i, var_prop_i, y_pred_train_prop_i,\\\n",
    "#         y_pred_test_prop_i, proposed_model_i, hist_prop_i = lgd_data.results_weibull_model(0.4,x_train,y_train,x_test,k,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "ee7a37e6",
   "metadata": {},
   "outputs": [],
   "source": [
    "# lgd_data.metrics_proposed(y_train,y_pred_train_prop_i,k)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "f74db639",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Fitting for c=0.4\n",
      "fitting benchmark\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2023-05-17 04:00:43.514827: I tensorflow/core/platform/cpu_feature_guard.cc:193] This TensorFlow binary is optimized with oneAPI Deep Neural Network Library (oneDNN) to use the following CPU instructions in performance-critical operations:  SSE4.1 SSE4.2 AVX AVX2 FMA\n",
      "To enable them in other operations, rebuild TensorFlow with the appropriate compiler flags.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=83.89068, test = 82.21315\n",
      "fitting proposed\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=44.45522, test = 43.31512\n",
      "\n",
      "Fitting for c=0.4421052631578948\n",
      "fitting benchmark\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 3ms/step\n",
      "MSE train=84.52784, test = 82.98943\n",
      "fitting proposed\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 2s 3ms/step\n",
      "146/146 [==============================] - 0s 3ms/step\n",
      "Error for c= 0.4421052631578948\n",
      "\n",
      "Fitting for c=0.4842105263157895\n",
      "fitting benchmark\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Traceback (most recent call last):\n",
      "  File \"/var/folders/kb/v0p0ypbd0wx1q2qb1kpxmmcc0000gn/T/ipykernel_74865/1687128321.py\", line 30, in <module>\n",
      "    a1,b1 = lgd_data.metrics_proposed(y_train,y_pred_train_prop_i,k)\n",
      "  File \"/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py\", line 30, in metrics_proposed\n",
      "    mse = mean_squared_error(y_true, mu)\n",
      "  File \"/Users/ashish1610dhiman/opt/anaconda3/envs/iuq_project/lib/python3.9/site-packages/sklearn/metrics/_regression.py\", line 442, in mean_squared_error\n",
      "    y_type, y_true, y_pred, multioutput = _check_reg_targets(\n",
      "  File \"/Users/ashish1610dhiman/opt/anaconda3/envs/iuq_project/lib/python3.9/site-packages/sklearn/metrics/_regression.py\", line 102, in _check_reg_targets\n",
      "    y_pred = check_array(y_pred, ensure_2d=False, dtype=dtype)\n",
      "  File \"/Users/ashish1610dhiman/opt/anaconda3/envs/iuq_project/lib/python3.9/site-packages/sklearn/utils/validation.py\", line 921, in check_array\n",
      "    _assert_all_finite(\n",
      "  File \"/Users/ashish1610dhiman/opt/anaconda3/envs/iuq_project/lib/python3.9/site-packages/sklearn/utils/validation.py\", line 161, in _assert_all_finite\n",
      "    raise ValueError(msg_err)\n",
      "ValueError: Input contains NaN.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 2s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=85.81403, test = 84.22236\n",
      "fitting proposed\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=1327.98511, test = 1351.88745\n",
      "\n",
      "Fitting for c=0.5263157894736843\n",
      "fitting benchmark\n",
      "583/583 [==============================] - 2s 3ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=86.28921, test = 84.65395\n",
      "fitting proposed\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=39.47301, test = 38.61917\n",
      "\n",
      "Fitting for c=0.5684210526315789\n",
      "fitting benchmark\n",
      "583/583 [==============================] - 2s 2ms/step\n",
      "146/146 [==============================] - 0s 3ms/step\n",
      "MSE train=83.89674, test = 82.51781\n",
      "fitting proposed\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=42.91616, test = 41.62476\n",
      "\n",
      "Fitting for c=0.6105263157894737\n",
      "fitting benchmark\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=85.58620, test = 83.97108\n",
      "fitting proposed\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "Error for c= 0.6105263157894737\n",
      "\n",
      "Fitting for c=0.6526315789473685\n",
      "fitting benchmark\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Traceback (most recent call last):\n",
      "  File \"/var/folders/kb/v0p0ypbd0wx1q2qb1kpxmmcc0000gn/T/ipykernel_74865/1687128321.py\", line 30, in <module>\n",
      "    a1,b1 = lgd_data.metrics_proposed(y_train,y_pred_train_prop_i,k)\n",
      "  File \"/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py\", line 30, in metrics_proposed\n",
      "    mse = mean_squared_error(y_true, mu)\n",
      "  File \"/Users/ashish1610dhiman/opt/anaconda3/envs/iuq_project/lib/python3.9/site-packages/sklearn/metrics/_regression.py\", line 442, in mean_squared_error\n",
      "    y_type, y_true, y_pred, multioutput = _check_reg_targets(\n",
      "  File \"/Users/ashish1610dhiman/opt/anaconda3/envs/iuq_project/lib/python3.9/site-packages/sklearn/metrics/_regression.py\", line 102, in _check_reg_targets\n",
      "    y_pred = check_array(y_pred, ensure_2d=False, dtype=dtype)\n",
      "  File \"/Users/ashish1610dhiman/opt/anaconda3/envs/iuq_project/lib/python3.9/site-packages/sklearn/utils/validation.py\", line 921, in check_array\n",
      "    _assert_all_finite(\n",
      "  File \"/Users/ashish1610dhiman/opt/anaconda3/envs/iuq_project/lib/python3.9/site-packages/sklearn/utils/validation.py\", line 161, in _assert_all_finite\n",
      "    raise ValueError(msg_err)\n",
      "ValueError: Input contains NaN.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 3ms/step\n",
      "MSE train=86.71085, test = 85.14158\n",
      "fitting proposed\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 2s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=39.23157, test = 38.25730\n",
      "\n",
      "Fitting for c=0.6947368421052631\n",
      "fitting benchmark\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=83.57335, test = 82.19935\n",
      "fitting proposed\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 2s 3ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=36.06256, test = 35.16274\n",
      "\n",
      "Fitting for c=0.736842105263158\n",
      "fitting benchmark\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=85.83443, test = 84.12417\n",
      "fitting proposed\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 3ms/step\n",
      "MSE train=39.45606, test = 37.60229\n",
      "\n",
      "Fitting for c=0.7789473684210526\n",
      "fitting benchmark\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 3ms/step\n",
      "MSE train=85.24264, test = 83.74780\n",
      "fitting proposed\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=2467.90332, test = 2443.00806\n",
      "\n",
      "Fitting for c=0.8210526315789474\n",
      "fitting benchmark\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=83.16659, test = 81.63902\n",
      "fitting proposed\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=37.56917, test = 36.35085\n",
      "\n",
      "Fitting for c=0.8631578947368421\n",
      "fitting benchmark\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=85.36418, test = 83.76313\n",
      "fitting proposed\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=33.64161, test = 32.40651\n",
      "\n",
      "Fitting for c=0.9052631578947369\n",
      "fitting benchmark\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=83.80761, test = 82.14481\n",
      "fitting proposed\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=29.68857, test = 29.09846\n",
      "\n",
      "Fitting for c=0.9473684210526316\n",
      "fitting benchmark\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=84.09640, test = 82.44645\n",
      "fitting proposed\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=30.28188, test = 29.65323\n",
      "\n",
      "Fitting for c=0.9894736842105263\n",
      "fitting benchmark\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=85.14849, test = 83.53432\n",
      "fitting proposed\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=99.52686, test = 97.94930\n",
      "\n",
      "Fitting for c=1.0315789473684212\n",
      "fitting benchmark\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=84.75706, test = 83.14893\n",
      "fitting proposed\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=98.98349, test = 97.68988\n",
      "\n",
      "Fitting for c=1.0736842105263158\n",
      "fitting benchmark\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=83.13462, test = 81.78959\n",
      "fitting proposed\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=29.64447, test = 28.93715\n",
      "\n",
      "Fitting for c=1.1157894736842104\n",
      "fitting benchmark\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 3ms/step\n",
      "MSE train=83.70718, test = 82.07370\n",
      "fitting proposed\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "Error for c= 1.1157894736842104\n",
      "\n",
      "Fitting for c=1.1578947368421053\n",
      "fitting benchmark\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Traceback (most recent call last):\n",
      "  File \"/var/folders/kb/v0p0ypbd0wx1q2qb1kpxmmcc0000gn/T/ipykernel_74865/1687128321.py\", line 30, in <module>\n",
      "    a1,b1 = lgd_data.metrics_proposed(y_train,y_pred_train_prop_i,k)\n",
      "  File \"/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py\", line 30, in metrics_proposed\n",
      "    mse = mean_squared_error(y_true, mu)\n",
      "  File \"/Users/ashish1610dhiman/opt/anaconda3/envs/iuq_project/lib/python3.9/site-packages/sklearn/metrics/_regression.py\", line 442, in mean_squared_error\n",
      "    y_type, y_true, y_pred, multioutput = _check_reg_targets(\n",
      "  File \"/Users/ashish1610dhiman/opt/anaconda3/envs/iuq_project/lib/python3.9/site-packages/sklearn/metrics/_regression.py\", line 102, in _check_reg_targets\n",
      "    y_pred = check_array(y_pred, ensure_2d=False, dtype=dtype)\n",
      "  File \"/Users/ashish1610dhiman/opt/anaconda3/envs/iuq_project/lib/python3.9/site-packages/sklearn/utils/validation.py\", line 921, in check_array\n",
      "    _assert_all_finite(\n",
      "  File \"/Users/ashish1610dhiman/opt/anaconda3/envs/iuq_project/lib/python3.9/site-packages/sklearn/utils/validation.py\", line 161, in _assert_all_finite\n",
      "    raise ValueError(msg_err)\n",
      "ValueError: Input contains NaN.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 2s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=85.74465, test = 84.11288\n",
      "fitting proposed\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "Error for c= 1.1578947368421053\n",
      "\n",
      "Fitting for c=1.2\n",
      "fitting benchmark\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Traceback (most recent call last):\n",
      "  File \"/var/folders/kb/v0p0ypbd0wx1q2qb1kpxmmcc0000gn/T/ipykernel_74865/1687128321.py\", line 30, in <module>\n",
      "    a1,b1 = lgd_data.metrics_proposed(y_train,y_pred_train_prop_i,k)\n",
      "  File \"/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py\", line 30, in metrics_proposed\n",
      "    mse = mean_squared_error(y_true, mu)\n",
      "  File \"/Users/ashish1610dhiman/opt/anaconda3/envs/iuq_project/lib/python3.9/site-packages/sklearn/metrics/_regression.py\", line 442, in mean_squared_error\n",
      "    y_type, y_true, y_pred, multioutput = _check_reg_targets(\n",
      "  File \"/Users/ashish1610dhiman/opt/anaconda3/envs/iuq_project/lib/python3.9/site-packages/sklearn/metrics/_regression.py\", line 102, in _check_reg_targets\n",
      "    y_pred = check_array(y_pred, ensure_2d=False, dtype=dtype)\n",
      "  File \"/Users/ashish1610dhiman/opt/anaconda3/envs/iuq_project/lib/python3.9/site-packages/sklearn/utils/validation.py\", line 921, in check_array\n",
      "    _assert_all_finite(\n",
      "  File \"/Users/ashish1610dhiman/opt/anaconda3/envs/iuq_project/lib/python3.9/site-packages/sklearn/utils/validation.py\", line 161, in _assert_all_finite\n",
      "    raise ValueError(msg_err)\n",
      "ValueError: Input contains NaN.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=83.89341, test = 82.30563\n",
      "fitting proposed\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=27.66714, test = 26.99947\n",
      "\n"
     ]
    }
   ],
   "source": [
    "results_dict={}\n",
    "model_dict={}\n",
    "data_dict={}\n",
    "\n",
    "#d.initialise and run benchmark model\n",
    "results_benchmark_eps = {}\n",
    "for c_i in np.linspace(0.4,1.2,N_REGUL):\n",
    "    try:\n",
    "        print (f\"Fitting for c={c_i}\")\n",
    "        print(\"fitting benchmark\")\n",
    "        #run benchmark model\n",
    "        mu_i, var_i, y_pred_train_i, y_pred_test_i,\\\n",
    "        benchmark_model_i, hist_i = lgd_data.results_benchmark_model(c_i/10,x_train,y_train,x_test,0)\n",
    "        a,b = lgd_data.metrics_benchmark(y_train,y_pred_train_i)\n",
    "        results_dict[(c_i/10,\"benchmark\",\"train\")] = {\n",
    "                \"mse\":a, \"nll\":b, \"loss\": hist_i.history[\"loss\"][-1],\n",
    "            }\n",
    "        c,d = lgd_data.metrics_benchmark(y_test,y_pred_test_i)\n",
    "#         print (f\"MSE train={a:.5f}, test = {c:.5f}\")\n",
    "        results_dict[(c_i/10,\"benchmark\",\"test\")] = {\n",
    "                \"mse\":c, \"nll\":d\n",
    "            }\n",
    "        print (f\"MSE train={a:.5f}, test = {c:.5f}\")\n",
    "        model_dict[(c_i/10,\"benchmark\")] = benchmark_model_i\n",
    "            \n",
    "        print(\"fitting proposed\")\n",
    "        #run proposed model\n",
    "        mu_prop_i, var_prop_i, y_pred_train_prop_i,\\\n",
    "        y_pred_test_prop_i, proposed_model_i, hist_prop_i = lgd_data.results_weibull_model(c_i,x_train,y_train,x_test,k,0)\n",
    "        a1,b1 = lgd_data.metrics_proposed(y_train,y_pred_train_prop_i,k)\n",
    "        results_dict[(c_i,\"proposed\",\"train\")] = {\n",
    "                \"mse\":a1, \"nll\":b1, \"loss\": hist_prop_i.history[\"loss\"][-1],\n",
    "            }\n",
    "        c1,d1 = lgd_data.metrics_proposed(y_test,y_pred_test_prop_i,k)\n",
    "        results_dict[(c_i,\"proposed\",\"test\")] = {\n",
    "                \"mse\":c1, \"nll\":d1\n",
    "            }\n",
    "        print (f\"MSE train={a1:.5f}, test = {c1:.5f}\")\n",
    "        model_dict[(c_i,\"proposed\")] = proposed_model_i\n",
    "        #plot the results\n",
    "        fig,ax = plt.subplots(1,2,figsize=(12,6))\n",
    "        plot_results(ax[0],mu_i,var_i,\"benchmark\",n=3400)\n",
    "        plot_results(ax[1],mu_prop_i,var_prop_i,\"proposed\",n=3400)\n",
    "        fig.suptitle(f\"c for benchmark= {c_i/10}, proposed = {c_i}\")\n",
    "        fig.savefig(base_dir+f\"/results_c={c_i}.png\")\n",
    "        plt.close()\n",
    "    except Exception as e:\n",
    "        print (f\"Error for c= {c_i}\")\n",
    "        traceback.print_exc()\n",
    "    print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "615194ea",
   "metadata": {},
   "outputs": [],
   "source": [
    "results_dict={}\n",
    "model_dict={}\n",
    "data_dict={}\n",
    "\n",
    "#d.initialise and run benchmark model\n",
    "results_benchmark_eps = {}\n",
    "for c_i in np.linspace(0.4,1.2,N_REGUL):\n",
    "    try:\n",
    "        print (f\"Fitting for c={c_i}\")\n",
    "        print(\"fitting benchmark\")\n",
    "        #run benchmark model\n",
    "        mu_i, var_i, y_pred_train_i, y_pred_test_i,\\\n",
    "        benchmark_model_i, hist_i = lgd_data.results_benchmark_model(c_i/10,x_train,y_train,x_test,0)\n",
    "        a,b = lgd_data.metrics_benchmark(y_train,y_pred_train_i)\n",
    "        results_dict[(c_i/10,\"benchmark\",\"train\")] = {\n",
    "                \"mse\":a, \"nll\":b, \"loss\": hist_i.history[\"loss\"][-1],\n",
    "            }\n",
    "        c,d = lgd_data.metrics_benchmark(y_test,y_pred_test_i)\n",
    "#         print (f\"MSE train={a:.5f}, test = {c:.5f}\")\n",
    "        results_dict[(c_i/10,\"benchmark\",\"test\")] = {\n",
    "                \"mse\":c, \"nll\":d\n",
    "            }\n",
    "        print (f\"MSE train={a:.5f}, test = {c:.5f}\")\n",
    "        model_dict[(c_i/10,\"benchmark\")] = benchmark_model_i\n",
    "            \n",
    "        print(\"fitting proposed\")\n",
    "        #run proposed model\n",
    "        mu_prop_i, var_prop_i, y_pred_train_prop_i,\\\n",
    "        y_pred_test_prop_i, proposed_model_i, hist_prop_i = lgd_data.results_weibull_model(c_i,x_train,y_train,x_test,k,0)\n",
    "        a1,b1 = lgd_data.metrics_proposed(y_train,y_pred_train_prop_i,k)\n",
    "        results_dict[(c_i,\"proposed\",\"train\")] = {\n",
    "                \"mse\":a1, \"nll\":b1, \"loss\": hist_prop_i.history[\"loss\"][-1],\n",
    "            }\n",
    "        c1,d1 = lgd_data.metrics_proposed(y_test,y_pred_test_prop_i,k)\n",
    "        results_dict[(c_i,\"proposed\",\"test\")] = {\n",
    "                \"mse\":c1, \"nll\":d1\n",
    "            }\n",
    "        print (f\"MSE train={a1:.5f}, test = {c1:.5f}\")\n",
    "        model_dict[(c_i,\"proposed\")] = proposed_model_i\n",
    "        #plot the results\n",
    "        fig,ax = plt.subplots(1,2,figsize=(12,6))\n",
    "        plot_results(ax[0],mu_i,var_i,\"benchmark\",n=3400)\n",
    "        plot_results(ax[1],mu_prop_i,var_prop_i,\"proposed\",n=3400)\n",
    "        fig.suptitle(f\"c for benchmark= {c_i/10}, proposed = {c_i}\")\n",
    "        fig.savefig(base_dir+f\"/results_c={c_i}.png\")\n",
    "        plt.close()\n",
    "    except Exception as e:\n",
    "        print (f\"Error for c= {c_i}\")\n",
    "        traceback.print_exc()\n",
    "    print()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "441369d4",
   "metadata": {},
   "source": [
    "### Save Results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "01f9f232",
   "metadata": {},
   "outputs": [],
   "source": [
    "result_df = pd.DataFrame.from_dict(results_dict,orient=\"index\").reset_index()\n",
    "result_df = result_df.rename(columns={\"level_0\":\"c\",\\\n",
    "                                     \"level_1\":\"model_type\",\"level_2\":\"data_type\"})\n",
    "# result_df = pd.pivot_table(result_df,index=[\"c\"],\\\n",
    "#               columns=[\"model_type\",\"data_type\"])\n",
    "result_df.to_csv(base_dir+\"/mse_nll_results.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "82d65ac3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_normal_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:31         5287\n",
      "metadata.json                                  2023-05-17 09:17:31           64\n",
      "variables.h5                                   2023-05-17 09:17:31      5642216\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_weibull_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:31         5054\n",
      "metadata.json                                  2023-05-17 09:17:31           64\n",
      "variables.h5                                   2023-05-17 09:17:31      5637864\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_normal_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:31         5305\n",
      "metadata.json                                  2023-05-17 09:17:31           64\n",
      "variables.h5                                   2023-05-17 09:17:31      5642216\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_normal_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:31         5305\n",
      "metadata.json                                  2023-05-17 09:17:31           64\n",
      "variables.h5                                   2023-05-17 09:17:32      5642216\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_weibull_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:32         5056\n",
      "metadata.json                                  2023-05-17 09:17:32           64\n",
      "variables.h5                                   2023-05-17 09:17:32      5637864\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_normal_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:32         5305\n",
      "metadata.json                                  2023-05-17 09:17:32           64\n",
      "variables.h5                                   2023-05-17 09:17:32      5642216\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_weibull_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:32         5056\n",
      "metadata.json                                  2023-05-17 09:17:32           64\n",
      "variables.h5                                   2023-05-17 09:17:32      5637864\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_normal_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:32         5305\n",
      "metadata.json                                  2023-05-17 09:17:32           64\n",
      "variables.h5                                   2023-05-17 09:17:32      5642216\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_weibull_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:32         5056\n",
      "metadata.json                                  2023-05-17 09:17:32           64\n",
      "variables.h5                                   2023-05-17 09:17:33      5637864\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_normal_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:33         5316\n",
      "metadata.json                                  2023-05-17 09:17:33           64\n",
      "variables.h5                                   2023-05-17 09:17:33      5642216\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_normal_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:33         5316\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "metadata.json                                  2023-05-17 09:17:33           64\n",
      "variables.h5                                   2023-05-17 09:17:33      5642216\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_weibull_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:33         5067\n",
      "metadata.json                                  2023-05-17 09:17:33           64\n",
      "variables.h5                                   2023-05-17 09:17:33      5637864\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_normal_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:33         5316\n",
      "metadata.json                                  2023-05-17 09:17:33           64\n",
      "variables.h5                                   2023-05-17 09:17:34      5642216\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_weibull_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:34         5067\n",
      "metadata.json                                  2023-05-17 09:17:34           64\n",
      "variables.h5                                   2023-05-17 09:17:34      5637864\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_normal_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:34         5316\n",
      "metadata.json                                  2023-05-17 09:17:34           64\n",
      "variables.h5                                   2023-05-17 09:17:34      5642216\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_weibull_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:34         5067\n",
      "metadata.json                                  2023-05-17 09:17:34           64\n",
      "variables.h5                                   2023-05-17 09:17:34      5637864\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_normal_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:34         5316\n",
      "metadata.json                                  2023-05-17 09:17:34           64\n",
      "variables.h5                                   2023-05-17 09:17:34      5642216\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_weibull_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:35         5067\n",
      "metadata.json                                  2023-05-17 09:17:35           64\n",
      "variables.h5                                   2023-05-17 09:17:35      5637864\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_normal_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:35         5317\n",
      "metadata.json                                  2023-05-17 09:17:35           64\n",
      "variables.h5                                   2023-05-17 09:17:35      5642216\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_weibull_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:35         5068\n",
      "metadata.json                                  2023-05-17 09:17:35           64\n",
      "variables.h5                                   2023-05-17 09:17:35      5637864\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_normal_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:35         5317\n",
      "metadata.json                                  2023-05-17 09:17:35           64\n",
      "variables.h5                                   2023-05-17 09:17:35      5642216\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_weibull_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:35         5068\n",
      "metadata.json                                  2023-05-17 09:17:35           64\n",
      "variables.h5                                   2023-05-17 09:17:36      5637864\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_normal_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:36         5317\n",
      "metadata.json                                  2023-05-17 09:17:36           64\n",
      "variables.h5                                   2023-05-17 09:17:36      5642216\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_weibull_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:36         5068\n",
      "metadata.json                                  2023-05-17 09:17:36           64\n",
      "variables.h5                                   2023-05-17 09:17:36      5637864\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_normal_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:36         5317\n",
      "metadata.json                                  2023-05-17 09:17:36           64\n",
      "variables.h5                                   2023-05-17 09:17:36      5642216\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_weibull_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:36         5068\n",
      "metadata.json                                  2023-05-17 09:17:36           64\n",
      "variables.h5                                   2023-05-17 09:17:36      5637864\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_normal_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:36         5317\n",
      "metadata.json                                  2023-05-17 09:17:36           64\n",
      "variables.h5                                   2023-05-17 09:17:37      5642216\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_weibull_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:37         5068\n",
      "metadata.json                                  2023-05-17 09:17:37           64\n",
      "variables.h5                                   2023-05-17 09:17:37      5637864\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_normal_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:37         5317\n",
      "metadata.json                                  2023-05-17 09:17:37           64\n",
      "variables.h5                                   2023-05-17 09:17:37      5642216\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_weibull_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:37         5068\n",
      "metadata.json                                  2023-05-17 09:17:37           64\n",
      "variables.h5                                   2023-05-17 09:17:37      5637864\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_normal_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:37         5317\n",
      "metadata.json                                  2023-05-17 09:17:37           64\n",
      "variables.h5                                   2023-05-17 09:17:37      5642216\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_weibull_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "config.json                                    2023-05-17 09:17:37         5068\n",
      "metadata.json                                  2023-05-17 09:17:37           64\n",
      "variables.h5                                   2023-05-17 09:17:38      5637864\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_normal_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:38         5317\n",
      "metadata.json                                  2023-05-17 09:17:38           64\n",
      "variables.h5                                   2023-05-17 09:17:38      5642216\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_normal_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:38         5317\n",
      "metadata.json                                  2023-05-17 09:17:38           64\n",
      "variables.h5                                   2023-05-17 09:17:38      5642216\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_normal_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:38         5317\n",
      "metadata.json                                  2023-05-17 09:17:38           64\n",
      "variables.h5                                   2023-05-17 09:17:38      5642216\n",
      "Keras weights file (<HDF5 file \"variables.h5\" (mode r+)>) saving:\n",
      "...layers\n",
      "......dense\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_1\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_2\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_3\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_4\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_5\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_6\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_7\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_8\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "......dense_weibull_gamma\n",
      ".........dense\n",
      "............vars\n",
      "...............0\n",
      "...............1\n",
      ".........vars\n",
      "...metrics\n",
      "......mean\n",
      ".........vars\n",
      "............0\n",
      "............1\n",
      "...optimizer\n",
      "......vars\n",
      ".........0\n",
      ".........1\n",
      ".........10\n",
      ".........11\n",
      ".........12\n",
      ".........13\n",
      ".........14\n",
      ".........15\n",
      ".........16\n",
      ".........17\n",
      ".........18\n",
      ".........19\n",
      ".........2\n",
      ".........20\n",
      ".........21\n",
      ".........22\n",
      ".........23\n",
      ".........24\n",
      ".........25\n",
      ".........26\n",
      ".........27\n",
      ".........28\n",
      ".........29\n",
      ".........3\n",
      ".........30\n",
      ".........31\n",
      ".........32\n",
      ".........33\n",
      ".........34\n",
      ".........35\n",
      ".........36\n",
      ".........37\n",
      ".........38\n",
      ".........39\n",
      ".........4\n",
      ".........40\n",
      ".........5\n",
      ".........6\n",
      ".........7\n",
      ".........8\n",
      ".........9\n",
      "...vars\n",
      "Keras model archive saving:\n",
      "File Name                                             Modified             Size\n",
      "config.json                                    2023-05-17 09:17:38         5068\n",
      "metadata.json                                  2023-05-17 09:17:38           64\n",
      "variables.h5                                   2023-05-17 09:17:38      5637864\n"
     ]
    }
   ],
   "source": [
    "exp_metadata = {\"data\":data_dict, \"models\": model_dict}\n",
    "\n",
    "with open(base_dir + f'/exp_metadata.pickle', 'wb') as handle:\n",
    "    pickle.dump(exp_metadata, handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "e19a8ce2",
   "metadata": {},
   "outputs": [],
   "source": [
    "benchmark_result = result_df[result_df.model_type==\"benchmark\"]\n",
    "benchmark_result = pd.pivot_table(benchmark_result.drop(columns=[\"model_type\"]),\\\n",
    "                                  index=[\"c\"],columns=[\"data_type\"])\n",
    "benchmark_result[\"rnk_\"] = benchmark_result[\"loss\"].rank()\n",
    "proposed_result = result_df[result_df.model_type==\"proposed\"]\n",
    "proposed_result = pd.pivot_table(proposed_result.drop(columns=[\"model_type\"]),index=[\"c\"],\\\n",
    "              columns=[\"data_type\"])\n",
    "proposed_result[\"rnk_\"] = proposed_result[\"loss\"].rank()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "f355fa82",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "      data_type\n",
       "loss  train         3.149649\n",
       "mse   test         83.136963\n",
       "      train        84.709305\n",
       "nll   test          2.855415\n",
       "      train         2.840984\n",
       "rnk_               10.500000\n",
       "dtype: float64"
      ]
     },
     "execution_count": 58,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "benchmark_result.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "050ee521",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "      data_type\n",
       "loss  train        0.129283\n",
       "mse   test         1.039321\n",
       "      train        1.078741\n",
       "nll   test         0.070181\n",
       "      train        0.073340\n",
       "rnk_               5.916080\n",
       "dtype: float64"
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "benchmark_result.std()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "e9afdc60",
   "metadata": {},
   "outputs": [
    {
     "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 tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr:last-of-type th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>loss</th>\n",
       "      <th colspan=\"2\" halign=\"left\">mse</th>\n",
       "      <th colspan=\"2\" halign=\"left\">nll</th>\n",
       "      <th>rnk_</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>data_type</th>\n",
       "      <th>train</th>\n",
       "      <th>test</th>\n",
       "      <th>train</th>\n",
       "      <th>test</th>\n",
       "      <th>train</th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>c</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0.04</th>\n",
       "      <td>2.949185</td>\n",
       "      <td>82.21315</td>\n",
       "      <td>83.890678</td>\n",
       "      <td>2.817839</td>\n",
       "      <td>2.796753</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "               loss       mse                  nll           rnk_\n",
       "data_type     train      test      train      test     train     \n",
       "c                                                                \n",
       "0.04       2.949185  82.21315  83.890678  2.817839  2.796753  1.0"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "benchmark_result[benchmark_result[\"rnk_\"]==1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "e1b45579",
   "metadata": {},
   "outputs": [
    {
     "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 tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr:last-of-type th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>loss</th>\n",
       "      <th colspan=\"2\" halign=\"left\">mse</th>\n",
       "      <th colspan=\"2\" halign=\"left\">nll</th>\n",
       "      <th>rnk_</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>data_type</th>\n",
       "      <th>train</th>\n",
       "      <th>test</th>\n",
       "      <th>train</th>\n",
       "      <th>test</th>\n",
       "      <th>train</th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>c</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0.4</th>\n",
       "      <td>2.436734</td>\n",
       "      <td>43.315121</td>\n",
       "      <td>44.455223</td>\n",
       "      <td>2.303172</td>\n",
       "      <td>2.307779</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "               loss        mse                  nll           rnk_\n",
       "data_type     train       test      train      test     train     \n",
       "c                                                                 \n",
       "0.4        2.436734  43.315121  44.455223  2.303172  2.307779  1.0"
      ]
     },
     "execution_count": 45,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "proposed_result[proposed_result[\"rnk_\"]==1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "b989523b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/340\n",
      "156/156 [==============================] - 2s 6ms/step - loss: 5.6702\n",
      "Epoch 2/340\n",
      "156/156 [==============================] - 1s 5ms/step - loss: 3.9960\n",
      "Epoch 3/340\n",
      "156/156 [==============================] - 1s 5ms/step - loss: 3.9766\n",
      "Epoch 4/340\n",
      "156/156 [==============================] - 1s 5ms/step - loss: 3.9637\n",
      "Epoch 5/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.9520\n",
      "Epoch 6/340\n",
      "156/156 [==============================] - 1s 5ms/step - loss: 3.9407\n",
      "Epoch 7/340\n",
      "156/156 [==============================] - 1s 5ms/step - loss: 3.9242\n",
      "Epoch 8/340\n",
      "156/156 [==============================] - 1s 5ms/step - loss: 3.9003\n",
      "Epoch 9/340\n",
      "156/156 [==============================] - 1s 5ms/step - loss: 3.8350\n",
      "Epoch 10/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.7097\n",
      "Epoch 11/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.6257\n",
      "Epoch 12/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.5729\n",
      "Epoch 13/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.5564\n",
      "Epoch 14/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.5356\n",
      "Epoch 15/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.5330\n",
      "Epoch 16/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.5262\n",
      "Epoch 17/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.5248\n",
      "Epoch 18/340\n",
      "156/156 [==============================] - 1s 5ms/step - loss: 3.5266\n",
      "Epoch 19/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.5206\n",
      "Epoch 20/340\n",
      "156/156 [==============================] - 1s 5ms/step - loss: 3.5265\n",
      "Epoch 21/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.5207\n",
      "Epoch 22/340\n",
      "156/156 [==============================] - 1s 5ms/step - loss: 3.5204\n",
      "Epoch 23/340\n",
      "156/156 [==============================] - 1s 5ms/step - loss: 3.5120\n",
      "Epoch 24/340\n",
      "156/156 [==============================] - 1s 5ms/step - loss: 3.5159\n",
      "Epoch 25/340\n",
      "156/156 [==============================] - 1s 5ms/step - loss: 3.5087\n",
      "Epoch 26/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.5103\n",
      "Epoch 27/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.5108\n",
      "Epoch 28/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.5042\n",
      "Epoch 29/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.5028\n",
      "Epoch 30/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.4983\n",
      "Epoch 31/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.5000\n",
      "Epoch 32/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.4985\n",
      "Epoch 33/340\n",
      "156/156 [==============================] - 1s 5ms/step - loss: 3.4928\n",
      "Epoch 34/340\n",
      "156/156 [==============================] - 1s 5ms/step - loss: 3.4940\n",
      "Epoch 35/340\n",
      "156/156 [==============================] - 1s 5ms/step - loss: 3.4911\n",
      "Epoch 36/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.4903\n",
      "Epoch 37/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.4889\n",
      "Epoch 38/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.4815\n",
      "Epoch 39/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.4798\n",
      "Epoch 40/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.4869\n",
      "Epoch 41/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.4753\n",
      "Epoch 42/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.4740\n",
      "Epoch 43/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.4725\n",
      "Epoch 44/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.4729\n",
      "Epoch 45/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.4683\n",
      "Epoch 46/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.4590\n",
      "Epoch 47/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.4596\n",
      "Epoch 48/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.4574\n",
      "Epoch 49/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.4573\n",
      "Epoch 50/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.4532\n",
      "Epoch 51/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.4541\n",
      "Epoch 52/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.4474\n",
      "Epoch 53/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.4422\n",
      "Epoch 54/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.4398\n",
      "Epoch 55/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.4372\n",
      "Epoch 56/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.4357\n",
      "Epoch 57/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.4312\n",
      "Epoch 58/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.4222\n",
      "Epoch 59/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.4230\n",
      "Epoch 60/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.4224\n",
      "Epoch 61/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.4200\n",
      "Epoch 62/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.4141\n",
      "Epoch 63/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.4075\n",
      "Epoch 64/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.4084\n",
      "Epoch 65/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.4037\n",
      "Epoch 66/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.3981\n",
      "Epoch 67/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.3950\n",
      "Epoch 68/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.3900\n",
      "Epoch 69/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.3894\n",
      "Epoch 70/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.3790\n",
      "Epoch 71/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.3760\n",
      "Epoch 72/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.3775\n",
      "Epoch 73/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.3671\n",
      "Epoch 74/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.3630\n",
      "Epoch 75/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.3588\n",
      "Epoch 76/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.3550\n",
      "Epoch 77/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.3565\n",
      "Epoch 78/340\n",
      "156/156 [==============================] - 1s 6ms/step - loss: 3.3465\n",
      "Epoch 79/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.3411\n",
      "Epoch 80/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.3396\n",
      "Epoch 81/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.3365\n",
      "Epoch 82/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.3308\n",
      "Epoch 83/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.3237\n",
      "Epoch 84/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.3151\n",
      "Epoch 85/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.3173\n",
      "Epoch 86/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.3137\n",
      "Epoch 87/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.3009\n",
      "Epoch 88/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.3017\n",
      "Epoch 89/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.2951\n",
      "Epoch 90/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.2900\n",
      "Epoch 91/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.2866\n",
      "Epoch 92/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.2786\n",
      "Epoch 93/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.2782\n",
      "Epoch 94/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.2684\n",
      "Epoch 95/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.2667\n",
      "Epoch 96/340\n",
      "156/156 [==============================] - 2s 10ms/step - loss: 3.2583\n",
      "Epoch 97/340\n",
      "156/156 [==============================] - 2s 11ms/step - loss: 3.2624\n",
      "Epoch 98/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.2505\n",
      "Epoch 99/340\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "156/156 [==============================] - 1s 9ms/step - loss: 3.2450\n",
      "Epoch 100/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.2410\n",
      "Epoch 101/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.2347\n",
      "Epoch 102/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.2332\n",
      "Epoch 103/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.2328\n",
      "Epoch 104/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.2268\n",
      "Epoch 105/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.2233\n",
      "Epoch 106/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.2200\n",
      "Epoch 107/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.2120\n",
      "Epoch 108/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.2046\n",
      "Epoch 109/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.2078\n",
      "Epoch 110/340\n",
      "156/156 [==============================] - 2s 10ms/step - loss: 3.2045\n",
      "Epoch 111/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1943\n",
      "Epoch 112/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1911\n",
      "Epoch 113/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1903\n",
      "Epoch 114/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1874\n",
      "Epoch 115/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1813\n",
      "Epoch 116/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.1817\n",
      "Epoch 117/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.1767\n",
      "Epoch 118/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.1743\n",
      "Epoch 119/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1689\n",
      "Epoch 120/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1669\n",
      "Epoch 121/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1665\n",
      "Epoch 122/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1578\n",
      "Epoch 123/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.1594\n",
      "Epoch 124/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.1578\n",
      "Epoch 125/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1508\n",
      "Epoch 126/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1496\n",
      "Epoch 127/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1500\n",
      "Epoch 128/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1437\n",
      "Epoch 129/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1433\n",
      "Epoch 130/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1419\n",
      "Epoch 131/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1386\n",
      "Epoch 132/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1373\n",
      "Epoch 133/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1351\n",
      "Epoch 134/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1329\n",
      "Epoch 135/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1272\n",
      "Epoch 136/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1280\n",
      "Epoch 137/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1294\n",
      "Epoch 138/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1229\n",
      "Epoch 139/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1227\n",
      "Epoch 140/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1201\n",
      "Epoch 141/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.1175\n",
      "Epoch 142/340\n",
      "156/156 [==============================] - 2s 11ms/step - loss: 3.1165\n",
      "Epoch 143/340\n",
      "156/156 [==============================] - 2s 10ms/step - loss: 3.1161\n",
      "Epoch 144/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.1175\n",
      "Epoch 145/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.1122\n",
      "Epoch 146/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.1102\n",
      "Epoch 147/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.1088\n",
      "Epoch 148/340\n",
      "156/156 [==============================] - 1s 10ms/step - loss: 3.1080\n",
      "Epoch 149/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.1031\n",
      "Epoch 150/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1046\n",
      "Epoch 151/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1014\n",
      "Epoch 152/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.1016\n",
      "Epoch 153/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.1009\n",
      "Epoch 154/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.0985\n",
      "Epoch 155/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0971\n",
      "Epoch 156/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0937\n",
      "Epoch 157/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0928\n",
      "Epoch 158/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0913\n",
      "Epoch 159/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.0945\n",
      "Epoch 160/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0884\n",
      "Epoch 161/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0892\n",
      "Epoch 162/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0867\n",
      "Epoch 163/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0845\n",
      "Epoch 164/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0848\n",
      "Epoch 165/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0835\n",
      "Epoch 166/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0829\n",
      "Epoch 167/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0801\n",
      "Epoch 168/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0786\n",
      "Epoch 169/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.0770\n",
      "Epoch 170/340\n",
      "156/156 [==============================] - 2s 10ms/step - loss: 3.0777\n",
      "Epoch 171/340\n",
      "156/156 [==============================] - 2s 11ms/step - loss: 3.0793\n",
      "Epoch 172/340\n",
      "156/156 [==============================] - 2s 10ms/step - loss: 3.0790\n",
      "Epoch 173/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.0730\n",
      "Epoch 174/340\n",
      "156/156 [==============================] - 2s 10ms/step - loss: 3.0706\n",
      "Epoch 175/340\n",
      "156/156 [==============================] - 2s 10ms/step - loss: 3.0725\n",
      "Epoch 176/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.0669\n",
      "Epoch 177/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.0667\n",
      "Epoch 178/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.0699\n",
      "Epoch 179/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0638\n",
      "Epoch 180/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0629\n",
      "Epoch 181/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0607\n",
      "Epoch 182/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.0642\n",
      "Epoch 183/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0594\n",
      "Epoch 184/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0599\n",
      "Epoch 185/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0574\n",
      "Epoch 186/340\n",
      "156/156 [==============================] - 2s 10ms/step - loss: 3.0561\n",
      "Epoch 187/340\n",
      "156/156 [==============================] - 2s 12ms/step - loss: 3.0569\n",
      "Epoch 188/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0524\n",
      "Epoch 189/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.0520\n",
      "Epoch 190/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.0514\n",
      "Epoch 191/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.0483\n",
      "Epoch 192/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.0467\n",
      "Epoch 193/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.0450\n",
      "Epoch 194/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0447\n",
      "Epoch 195/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.0457\n",
      "Epoch 196/340\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "156/156 [==============================] - 2s 10ms/step - loss: 3.0442\n",
      "Epoch 197/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.0434\n",
      "Epoch 198/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0401\n",
      "Epoch 199/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0385\n",
      "Epoch 200/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0395\n",
      "Epoch 201/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.0356\n",
      "Epoch 202/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0351\n",
      "Epoch 203/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.0358\n",
      "Epoch 204/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0356\n",
      "Epoch 205/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0314\n",
      "Epoch 206/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.0310\n",
      "Epoch 207/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0292\n",
      "Epoch 208/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0268\n",
      "Epoch 209/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0266\n",
      "Epoch 210/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.0294\n",
      "Epoch 211/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0238\n",
      "Epoch 212/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0224\n",
      "Epoch 213/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.0259\n",
      "Epoch 214/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0193\n",
      "Epoch 215/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.0193\n",
      "Epoch 216/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0156\n",
      "Epoch 217/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0165\n",
      "Epoch 218/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.0132\n",
      "Epoch 219/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0145\n",
      "Epoch 220/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0124\n",
      "Epoch 221/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0100\n",
      "Epoch 222/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0095\n",
      "Epoch 223/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 3.0126\n",
      "Epoch 224/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0052\n",
      "Epoch 225/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0064\n",
      "Epoch 226/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0040\n",
      "Epoch 227/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 3.0039\n",
      "Epoch 228/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0041\n",
      "Epoch 229/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 3.0063\n",
      "Epoch 230/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 2.9982\n",
      "Epoch 231/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9991\n",
      "Epoch 232/340\n",
      "156/156 [==============================] - 2s 11ms/step - loss: 2.9979\n",
      "Epoch 233/340\n",
      "156/156 [==============================] - 2s 10ms/step - loss: 2.9949\n",
      "Epoch 234/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9944\n",
      "Epoch 235/340\n",
      "156/156 [==============================] - 2s 10ms/step - loss: 2.9951\n",
      "Epoch 236/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9950\n",
      "Epoch 237/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9919\n",
      "Epoch 238/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9881\n",
      "Epoch 239/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9884\n",
      "Epoch 240/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9873\n",
      "Epoch 241/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9893\n",
      "Epoch 242/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9835\n",
      "Epoch 243/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9859\n",
      "Epoch 244/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9811\n",
      "Epoch 245/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 2.9792\n",
      "Epoch 246/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9816\n",
      "Epoch 247/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9782\n",
      "Epoch 248/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9759\n",
      "Epoch 249/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9755\n",
      "Epoch 250/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9736\n",
      "Epoch 251/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9716\n",
      "Epoch 252/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9796\n",
      "Epoch 253/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9724\n",
      "Epoch 254/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9709\n",
      "Epoch 255/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9677\n",
      "Epoch 256/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9710\n",
      "Epoch 257/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9680\n",
      "Epoch 258/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9673\n",
      "Epoch 259/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9645\n",
      "Epoch 260/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9633\n",
      "Epoch 261/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9604\n",
      "Epoch 262/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9587\n",
      "Epoch 263/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9574\n",
      "Epoch 264/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9601\n",
      "Epoch 265/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9555\n",
      "Epoch 266/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9554\n",
      "Epoch 267/340\n",
      "156/156 [==============================] - 1s 10ms/step - loss: 2.9551\n",
      "Epoch 268/340\n",
      "156/156 [==============================] - 2s 11ms/step - loss: 2.9511\n",
      "Epoch 269/340\n",
      "156/156 [==============================] - 2s 10ms/step - loss: 2.9548\n",
      "Epoch 270/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9505\n",
      "Epoch 271/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9514\n",
      "Epoch 272/340\n",
      "156/156 [==============================] - 2s 11ms/step - loss: 2.9477\n",
      "Epoch 273/340\n",
      "156/156 [==============================] - 2s 15ms/step - loss: 2.9458\n",
      "Epoch 274/340\n",
      "156/156 [==============================] - 3s 19ms/step - loss: 2.9458\n",
      "Epoch 275/340\n",
      "156/156 [==============================] - 2s 16ms/step - loss: 2.9427\n",
      "Epoch 276/340\n",
      "156/156 [==============================] - 3s 16ms/step - loss: 2.9451\n",
      "Epoch 277/340\n",
      "156/156 [==============================] - 2s 15ms/step - loss: 2.9416\n",
      "Epoch 278/340\n",
      "156/156 [==============================] - 3s 18ms/step - loss: 2.9417\n",
      "Epoch 279/340\n",
      "156/156 [==============================] - 2s 16ms/step - loss: 2.9411\n",
      "Epoch 280/340\n",
      "156/156 [==============================] - 2s 10ms/step - loss: 2.9384\n",
      "Epoch 281/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9366\n",
      "Epoch 282/340\n",
      "156/156 [==============================] - 2s 11ms/step - loss: 2.9418\n",
      "Epoch 283/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9370\n",
      "Epoch 284/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9344\n",
      "Epoch 285/340\n",
      "156/156 [==============================] - 2s 11ms/step - loss: 2.9346\n",
      "Epoch 286/340\n",
      "156/156 [==============================] - 2s 10ms/step - loss: 2.9369\n",
      "Epoch 287/340\n",
      "156/156 [==============================] - 2s 10ms/step - loss: 2.9316\n",
      "Epoch 288/340\n",
      "156/156 [==============================] - 2s 10ms/step - loss: 2.9347\n",
      "Epoch 289/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9305\n",
      "Epoch 290/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9281\n",
      "Epoch 291/340\n",
      "156/156 [==============================] - 1s 10ms/step - loss: 2.9283\n",
      "Epoch 292/340\n",
      "156/156 [==============================] - 2s 10ms/step - loss: 2.9291\n",
      "Epoch 293/340\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9263\n",
      "Epoch 294/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9266\n",
      "Epoch 295/340\n",
      "156/156 [==============================] - 1s 10ms/step - loss: 2.9280\n",
      "Epoch 296/340\n",
      "156/156 [==============================] - 2s 10ms/step - loss: 2.9232\n",
      "Epoch 297/340\n",
      "156/156 [==============================] - 2s 12ms/step - loss: 2.9255\n",
      "Epoch 298/340\n",
      "156/156 [==============================] - 1s 10ms/step - loss: 2.9232\n",
      "Epoch 299/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9211\n",
      "Epoch 300/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9218\n",
      "Epoch 301/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9196\n",
      "Epoch 302/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9226\n",
      "Epoch 303/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9232\n",
      "Epoch 304/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9193\n",
      "Epoch 305/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9206\n",
      "Epoch 306/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9193\n",
      "Epoch 307/340\n",
      "156/156 [==============================] - 2s 11ms/step - loss: 2.9169\n",
      "Epoch 308/340\n",
      "156/156 [==============================] - 2s 10ms/step - loss: 2.9165\n",
      "Epoch 309/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9138\n",
      "Epoch 310/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9145\n",
      "Epoch 311/340\n",
      "156/156 [==============================] - 2s 12ms/step - loss: 2.9168\n",
      "Epoch 312/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9190\n",
      "Epoch 313/340\n",
      "156/156 [==============================] - 1s 9ms/step - loss: 2.9117\n",
      "Epoch 314/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9107\n",
      "Epoch 315/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9135\n",
      "Epoch 316/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9130\n",
      "Epoch 317/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9093\n",
      "Epoch 318/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9101\n",
      "Epoch 319/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9130\n",
      "Epoch 320/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9097\n",
      "Epoch 321/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 2.9080\n",
      "Epoch 322/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9080\n",
      "Epoch 323/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9132\n",
      "Epoch 324/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9082\n",
      "Epoch 325/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9091\n",
      "Epoch 326/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9068\n",
      "Epoch 327/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9056\n",
      "Epoch 328/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9086\n",
      "Epoch 329/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9090\n",
      "Epoch 330/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9091\n",
      "Epoch 331/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9083\n",
      "Epoch 332/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 2.9026\n",
      "Epoch 333/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9048\n",
      "Epoch 334/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9031\n",
      "Epoch 335/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 2.9026\n",
      "Epoch 336/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 2.9039\n",
      "Epoch 337/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9013\n",
      "Epoch 338/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9028\n",
      "Epoch 339/340\n",
      "156/156 [==============================] - 1s 8ms/step - loss: 2.9062\n",
      "Epoch 340/340\n",
      "156/156 [==============================] - 1s 7ms/step - loss: 2.9042\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    }
   ],
   "source": [
    "mu_i, var_i, y_pred_train_i, y_pred_test_i,\\\n",
    "benchmark_model_i, hist_i = lgd_data.results_benchmark_model(0.035,x_train,y_train,x_test,1)\n",
    "a,b = lgd_data.metrics_benchmark(y_train,y_pred_train_i)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ce5d2f24",
   "metadata": {},
   "source": [
    "### Same experiment multiple trials"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "id": "08e12a79",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "fitting benchmark 0\n",
      "583/583 [==============================] - 2s 3ms/step\n",
      "146/146 [==============================] - 1s 3ms/step\n",
      "MSE train=85.27309, test = 83.61375\n",
      "fitting proposed 0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=43.37643, test = 42.59977\n",
      "fitting benchmark 1\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=85.24995, test = 83.56085\n",
      "fitting proposed 1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 2s 3ms/step\n",
      "146/146 [==============================] - 0s 3ms/step\n",
      "MSE train=43.33632, test = 42.36553\n",
      "fitting benchmark 2\n",
      "583/583 [==============================] - 2s 3ms/step\n",
      "146/146 [==============================] - 0s 3ms/step\n",
      "MSE train=85.09217, test = 83.44994\n",
      "fitting proposed 2\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=39.86990, test = 38.88181\n",
      "fitting benchmark 3\n",
      "583/583 [==============================] - 2s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=84.85599, test = 83.21169\n",
      "fitting proposed 3\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 2s 3ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=43.63609, test = 42.28419\n",
      "fitting benchmark 4\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=84.79243, test = 83.07029\n",
      "fitting proposed 4\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=108.31773, test = 106.80090\n",
      "fitting benchmark 5\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=85.59720, test = 83.93134\n",
      "fitting proposed 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=44.92524, test = 43.77564\n",
      "fitting benchmark 6\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=84.04485, test = 82.39215\n",
      "fitting proposed 6\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 2s 3ms/step\n",
      "146/146 [==============================] - 1s 3ms/step\n",
      "MSE train=1092.64038, test = 1075.74438\n",
      "fitting benchmark 7\n",
      "583/583 [==============================] - 2s 3ms/step\n",
      "146/146 [==============================] - 0s 3ms/step\n",
      "MSE train=85.93303, test = 84.27103\n",
      "fitting proposed 7\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=1094.50757, test = 1075.63867\n",
      "fitting benchmark 8\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 3ms/step\n",
      "MSE train=90.12973, test = 88.79160\n",
      "fitting proposed 8\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=41.64584, test = 40.69294\n",
      "fitting benchmark 9\n",
      "583/583 [==============================] - 2s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=84.87725, test = 83.24466\n",
      "fitting proposed 9\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/ashish1610dhiman/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:61: RuntimeWarning: divide by zero encountered in divide\n",
      "  var = np.sqrt(beta / (v * (alpha - 1)))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n"
     ]
    },
    {
     "ename": "ValueError",
     "evalue": "Input contains NaN.",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[69], line 19\u001b[0m\n\u001b[1;32m     16\u001b[0m \u001b[38;5;66;03m#run proposed model\u001b[39;00m\n\u001b[1;32m     17\u001b[0m mu_prop_i, var_prop_i, y_pred_train_prop_i,\\\n\u001b[1;32m     18\u001b[0m y_pred_test_prop_i, proposed_model_i, hist_prop_i \u001b[38;5;241m=\u001b[39m lgd_data\u001b[38;5;241m.\u001b[39mresults_weibull_model(\u001b[38;5;241m0.4\u001b[39m,x_train,y_train,x_test,k,\u001b[38;5;241m0\u001b[39m)\n\u001b[0;32m---> 19\u001b[0m a1,b1 \u001b[38;5;241m=\u001b[39m \u001b[43mlgd_data\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mmetrics_proposed\u001b[49m\u001b[43m(\u001b[49m\u001b[43my_train\u001b[49m\u001b[43m,\u001b[49m\u001b[43my_pred_train_prop_i\u001b[49m\u001b[43m,\u001b[49m\u001b[43mk\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     20\u001b[0m results_trial[(i,\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mproposed\u001b[39m\u001b[38;5;124m\"\u001b[39m,\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mtrain\u001b[39m\u001b[38;5;124m\"\u001b[39m)] \u001b[38;5;241m=\u001b[39m {\n\u001b[1;32m     21\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mmse\u001b[39m\u001b[38;5;124m\"\u001b[39m:a1, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mnll\u001b[39m\u001b[38;5;124m\"\u001b[39m:b1}\n\u001b[1;32m     22\u001b[0m c1,d1 \u001b[38;5;241m=\u001b[39m lgd_data\u001b[38;5;241m.\u001b[39mmetrics_proposed(y_test,y_pred_test_prop_i,k)\n",
      "File \u001b[0;32m~/data_projects/iuq_project/notebooks/neurips_experiments/../../src/exp_utils/lgd_data.py:30\u001b[0m, in \u001b[0;36mmetrics_proposed\u001b[0;34m(y_true, y_pred, k)\u001b[0m\n\u001b[1;32m     27\u001b[0m mean_pred_log \u001b[38;5;241m=\u001b[39m (loggamma(\u001b[38;5;241m1\u001b[39m \u001b[38;5;241m+\u001b[39m (\u001b[38;5;241m1\u001b[39m \u001b[38;5;241m/\u001b[39m k)) \u001b[38;5;241m-\u001b[39m loggamma(alpha) \u001b[38;5;241m+\u001b[39m loggamma(alpha \u001b[38;5;241m-\u001b[39m (\u001b[38;5;241m1\u001b[39m \u001b[38;5;241m/\u001b[39m k)) \\\n\u001b[1;32m     28\u001b[0m                  \u001b[38;5;241m+\u001b[39m (\u001b[38;5;241m1\u001b[39m \u001b[38;5;241m/\u001b[39m k) \u001b[38;5;241m*\u001b[39m np\u001b[38;5;241m.\u001b[39mlog(beta))\n\u001b[1;32m     29\u001b[0m mu \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39mexp(mean_pred_log)\n\u001b[0;32m---> 30\u001b[0m mse \u001b[38;5;241m=\u001b[39m \u001b[43mmean_squared_error\u001b[49m\u001b[43m(\u001b[49m\u001b[43my_true\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmu\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     31\u001b[0m nll \u001b[38;5;241m=\u001b[39m loss_and_layers\u001b[38;5;241m.\u001b[39mweibull_NLL(y_true,alpha,beta, k, reduce\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m)\u001b[38;5;241m.\u001b[39mnumpy()\n\u001b[1;32m     32\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m (mse,nll)\n",
      "File \u001b[0;32m~/opt/anaconda3/envs/iuq_project/lib/python3.9/site-packages/sklearn/metrics/_regression.py:442\u001b[0m, in \u001b[0;36mmean_squared_error\u001b[0;34m(y_true, y_pred, sample_weight, multioutput, squared)\u001b[0m\n\u001b[1;32m    382\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mmean_squared_error\u001b[39m(\n\u001b[1;32m    383\u001b[0m     y_true, y_pred, \u001b[38;5;241m*\u001b[39m, sample_weight\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m, multioutput\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124muniform_average\u001b[39m\u001b[38;5;124m\"\u001b[39m, squared\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m\n\u001b[1;32m    384\u001b[0m ):\n\u001b[1;32m    385\u001b[0m \u001b[38;5;250m    \u001b[39m\u001b[38;5;124;03m\"\"\"Mean squared error regression loss.\u001b[39;00m\n\u001b[1;32m    386\u001b[0m \n\u001b[1;32m    387\u001b[0m \u001b[38;5;124;03m    Read more in the :ref:`User Guide <mean_squared_error>`.\u001b[39;00m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    440\u001b[0m \u001b[38;5;124;03m    0.825...\u001b[39;00m\n\u001b[1;32m    441\u001b[0m \u001b[38;5;124;03m    \"\"\"\u001b[39;00m\n\u001b[0;32m--> 442\u001b[0m     y_type, y_true, y_pred, multioutput \u001b[38;5;241m=\u001b[39m \u001b[43m_check_reg_targets\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m    443\u001b[0m \u001b[43m        \u001b[49m\u001b[43my_true\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43my_pred\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmultioutput\u001b[49m\n\u001b[1;32m    444\u001b[0m \u001b[43m    \u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    445\u001b[0m     check_consistent_length(y_true, y_pred, sample_weight)\n\u001b[1;32m    446\u001b[0m     output_errors \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39maverage((y_true \u001b[38;5;241m-\u001b[39m y_pred) \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39m \u001b[38;5;241m2\u001b[39m, axis\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m0\u001b[39m, weights\u001b[38;5;241m=\u001b[39msample_weight)\n",
      "File \u001b[0;32m~/opt/anaconda3/envs/iuq_project/lib/python3.9/site-packages/sklearn/metrics/_regression.py:102\u001b[0m, in \u001b[0;36m_check_reg_targets\u001b[0;34m(y_true, y_pred, multioutput, dtype)\u001b[0m\n\u001b[1;32m    100\u001b[0m check_consistent_length(y_true, y_pred)\n\u001b[1;32m    101\u001b[0m y_true \u001b[38;5;241m=\u001b[39m check_array(y_true, ensure_2d\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mFalse\u001b[39;00m, dtype\u001b[38;5;241m=\u001b[39mdtype)\n\u001b[0;32m--> 102\u001b[0m y_pred \u001b[38;5;241m=\u001b[39m \u001b[43mcheck_array\u001b[49m\u001b[43m(\u001b[49m\u001b[43my_pred\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mensure_2d\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mFalse\u001b[39;49;00m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mdtype\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mdtype\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    104\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m y_true\u001b[38;5;241m.\u001b[39mndim \u001b[38;5;241m==\u001b[39m \u001b[38;5;241m1\u001b[39m:\n\u001b[1;32m    105\u001b[0m     y_true \u001b[38;5;241m=\u001b[39m y_true\u001b[38;5;241m.\u001b[39mreshape((\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m, \u001b[38;5;241m1\u001b[39m))\n",
      "File \u001b[0;32m~/opt/anaconda3/envs/iuq_project/lib/python3.9/site-packages/sklearn/utils/validation.py:921\u001b[0m, in \u001b[0;36mcheck_array\u001b[0;34m(array, accept_sparse, accept_large_sparse, dtype, order, copy, force_all_finite, ensure_2d, allow_nd, ensure_min_samples, ensure_min_features, estimator, input_name)\u001b[0m\n\u001b[1;32m    915\u001b[0m         \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mValueError\u001b[39;00m(\n\u001b[1;32m    916\u001b[0m             \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mFound array with dim \u001b[39m\u001b[38;5;132;01m%d\u001b[39;00m\u001b[38;5;124m. \u001b[39m\u001b[38;5;132;01m%s\u001b[39;00m\u001b[38;5;124m expected <= 2.\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    917\u001b[0m             \u001b[38;5;241m%\u001b[39m (array\u001b[38;5;241m.\u001b[39mndim, estimator_name)\n\u001b[1;32m    918\u001b[0m         )\n\u001b[1;32m    920\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m force_all_finite:\n\u001b[0;32m--> 921\u001b[0m         \u001b[43m_assert_all_finite\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m    922\u001b[0m \u001b[43m            \u001b[49m\u001b[43marray\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    923\u001b[0m \u001b[43m            \u001b[49m\u001b[43minput_name\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43minput_name\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    924\u001b[0m \u001b[43m            \u001b[49m\u001b[43mestimator_name\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mestimator_name\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    925\u001b[0m \u001b[43m            \u001b[49m\u001b[43mallow_nan\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mforce_all_finite\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m==\u001b[39;49m\u001b[43m \u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mallow-nan\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m    926\u001b[0m \u001b[43m        \u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    928\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m ensure_min_samples \u001b[38;5;241m>\u001b[39m \u001b[38;5;241m0\u001b[39m:\n\u001b[1;32m    929\u001b[0m     n_samples \u001b[38;5;241m=\u001b[39m _num_samples(array)\n",
      "File \u001b[0;32m~/opt/anaconda3/envs/iuq_project/lib/python3.9/site-packages/sklearn/utils/validation.py:161\u001b[0m, in \u001b[0;36m_assert_all_finite\u001b[0;34m(X, allow_nan, msg_dtype, estimator_name, input_name)\u001b[0m\n\u001b[1;32m    144\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m estimator_name \u001b[38;5;129;01mand\u001b[39;00m input_name \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mX\u001b[39m\u001b[38;5;124m\"\u001b[39m \u001b[38;5;129;01mand\u001b[39;00m has_nan_error:\n\u001b[1;32m    145\u001b[0m     \u001b[38;5;66;03m# Improve the error message on how to handle missing values in\u001b[39;00m\n\u001b[1;32m    146\u001b[0m     \u001b[38;5;66;03m# scikit-learn.\u001b[39;00m\n\u001b[1;32m    147\u001b[0m     msg_err \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m (\n\u001b[1;32m    148\u001b[0m         \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;132;01m{\u001b[39;00mestimator_name\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m does not accept missing values\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    149\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124m encoded as NaN natively. For supervised learning, you might want\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    159\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124m#estimators-that-handle-nan-values\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    160\u001b[0m     )\n\u001b[0;32m--> 161\u001b[0m \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mValueError\u001b[39;00m(msg_err)\n",
      "\u001b[0;31mValueError\u001b[0m: Input contains NaN."
     ]
    }
   ],
   "source": [
    "results_trial={}\n",
    "for i in range(10):\n",
    "    print(f\"fitting benchmark {i}\")\n",
    "    #run benchmark model\n",
    "    mu_i, var_i, y_pred_train_i, y_pred_test_i,\\\n",
    "    benchmark_model_i, hist_i = lgd_data.results_benchmark_model(0.04,x_train,y_train,x_test,0)\n",
    "    a,b = lgd_data.metrics_benchmark(y_train,y_pred_train_i)\n",
    "    results_trial[(i,\"benchmark\",\"train\")] = {\n",
    "                \"mse\":a, \"nll\":b}\n",
    "    c,d = lgd_data.metrics_benchmark(y_test,y_pred_test_i)\n",
    "#         print (f\"MSE train={a:.5f}, test = {c:.5f}\")\n",
    "    results_trial[(i,\"benchmark\",\"test\")] = {\n",
    "                \"mse\":c, \"nll\":d}\n",
    "    print (f\"MSE train={a:.5f}, test = {c:.5f}\")\n",
    "    print(f\"fitting proposed {i}\")\n",
    "    #run proposed model\n",
    "    mu_prop_i, var_prop_i, y_pred_train_prop_i,\\\n",
    "    y_pred_test_prop_i, proposed_model_i, hist_prop_i = lgd_data.results_weibull_model(0.4,x_train,y_train,x_test,k,0)\n",
    "    a1,b1 = lgd_data.metrics_proposed(y_train,y_pred_train_prop_i,k)\n",
    "    results_trial[(i,\"proposed\",\"train\")] = {\n",
    "            \"mse\":a1, \"nll\":b1}\n",
    "    c1,d1 = lgd_data.metrics_proposed(y_test,y_pred_test_prop_i,k)\n",
    "    results_trial[(i,\"proposed\",\"test\")] = {\n",
    "            \"mse\":c1, \"nll\":d1}\n",
    "    print (f\"MSE train={a1:.5f}, test = {c1:.5f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "id": "5ac3541d",
   "metadata": {},
   "outputs": [],
   "source": [
    "result_trial = pd.DataFrame.from_dict(results_trial,orient=\"index\").reset_index()\n",
    "result_trial = result_trial.rename(columns={\"level_0\":\"trial\",\\\n",
    "                                     \"level_1\":\"model_type\",\"level_2\":\"data_type\"})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "id": "46c44bb9",
   "metadata": {},
   "outputs": [
    {
     "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 tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr:last-of-type th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th colspan=\"2\" halign=\"left\">mse</th>\n",
       "      <th colspan=\"2\" halign=\"left\">nll</th>\n",
       "      <th colspan=\"2\" halign=\"left\">trial</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>model_type</th>\n",
       "      <th>benchmark</th>\n",
       "      <th>proposed</th>\n",
       "      <th>benchmark</th>\n",
       "      <th>proposed</th>\n",
       "      <th>benchmark</th>\n",
       "      <th>proposed</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>data_type</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>test</th>\n",
       "      <td>83.953728</td>\n",
       "      <td>278.753754</td>\n",
       "      <td>2.804861</td>\n",
       "      <td>2.589688</td>\n",
       "      <td>4.5</td>\n",
       "      <td>4.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>train</th>\n",
       "      <td>85.584572</td>\n",
       "      <td>283.583923</td>\n",
       "      <td>2.787982</td>\n",
       "      <td>2.597638</td>\n",
       "      <td>4.5</td>\n",
       "      <td>4.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                  mse                   nll               trial         \n",
       "model_type  benchmark    proposed benchmark  proposed benchmark proposed\n",
       "data_type                                                               \n",
       "test        83.953728  278.753754  2.804861  2.589688       4.5      4.0\n",
       "train       85.584572  283.583923  2.787982  2.597638       4.5      4.0"
      ]
     },
     "execution_count": 78,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result_trial.pivot_table(index=\"data_type\",columns=[\"model_type\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "5c923996",
   "metadata": {},
   "outputs": [
    {
     "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>trial</th>\n",
       "      <th>model_type</th>\n",
       "      <th>data_type</th>\n",
       "      <th>mse</th>\n",
       "      <th>nll</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>85.273094</td>\n",
       "      <td>2.754417</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>83.613747</td>\n",
       "      <td>2.774736</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>43.376431</td>\n",
       "      <td>2.303232</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>42.599773</td>\n",
       "      <td>2.298116</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>85.249954</td>\n",
       "      <td>2.765092</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>1</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>83.560852</td>\n",
       "      <td>2.781921</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>1</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>43.336319</td>\n",
       "      <td>2.318605</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>1</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>42.365532</td>\n",
       "      <td>2.314586</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>2</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>85.092171</td>\n",
       "      <td>2.756333</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>2</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>83.449944</td>\n",
       "      <td>2.774932</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>2</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>39.869900</td>\n",
       "      <td>2.312612</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>2</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>38.881805</td>\n",
       "      <td>2.307631</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>3</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>84.855988</td>\n",
       "      <td>2.757930</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>3</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>83.211693</td>\n",
       "      <td>2.775242</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>3</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>43.636093</td>\n",
       "      <td>2.311005</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>3</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>42.284187</td>\n",
       "      <td>2.306424</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>4</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>84.792435</td>\n",
       "      <td>2.759606</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>4</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>83.070290</td>\n",
       "      <td>2.777184</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>4</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>108.317734</td>\n",
       "      <td>2.646003</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>4</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>106.800896</td>\n",
       "      <td>2.643455</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>5</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>85.597198</td>\n",
       "      <td>2.759997</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>5</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>83.931343</td>\n",
       "      <td>2.777694</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>5</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>44.925240</td>\n",
       "      <td>2.298689</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>5</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>43.775642</td>\n",
       "      <td>2.292509</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>6</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>84.044846</td>\n",
       "      <td>2.761224</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>6</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>82.392151</td>\n",
       "      <td>2.779083</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>6</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>1092.640381</td>\n",
       "      <td>3.464163</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>6</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>1075.744385</td>\n",
       "      <td>3.432618</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>7</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>85.933029</td>\n",
       "      <td>2.762670</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>7</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>84.271027</td>\n",
       "      <td>2.778553</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>7</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>1094.507568</td>\n",
       "      <td>3.419099</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>7</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>1075.638672</td>\n",
       "      <td>3.411159</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>8</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>90.129730</td>\n",
       "      <td>3.036243</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>8</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>88.791595</td>\n",
       "      <td>3.044197</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>8</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>41.645840</td>\n",
       "      <td>2.305331</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>8</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>40.692940</td>\n",
       "      <td>2.300697</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>36</th>\n",
       "      <td>9</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>84.877251</td>\n",
       "      <td>2.766304</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>37</th>\n",
       "      <td>9</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>83.244659</td>\n",
       "      <td>2.785069</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    trial model_type data_type          mse       nll\n",
       "0       0  benchmark     train    85.273094  2.754417\n",
       "1       0  benchmark      test    83.613747  2.774736\n",
       "2       0   proposed     train    43.376431  2.303232\n",
       "3       0   proposed      test    42.599773  2.298116\n",
       "4       1  benchmark     train    85.249954  2.765092\n",
       "5       1  benchmark      test    83.560852  2.781921\n",
       "6       1   proposed     train    43.336319  2.318605\n",
       "7       1   proposed      test    42.365532  2.314586\n",
       "8       2  benchmark     train    85.092171  2.756333\n",
       "9       2  benchmark      test    83.449944  2.774932\n",
       "10      2   proposed     train    39.869900  2.312612\n",
       "11      2   proposed      test    38.881805  2.307631\n",
       "12      3  benchmark     train    84.855988  2.757930\n",
       "13      3  benchmark      test    83.211693  2.775242\n",
       "14      3   proposed     train    43.636093  2.311005\n",
       "15      3   proposed      test    42.284187  2.306424\n",
       "16      4  benchmark     train    84.792435  2.759606\n",
       "17      4  benchmark      test    83.070290  2.777184\n",
       "18      4   proposed     train   108.317734  2.646003\n",
       "19      4   proposed      test   106.800896  2.643455\n",
       "20      5  benchmark     train    85.597198  2.759997\n",
       "21      5  benchmark      test    83.931343  2.777694\n",
       "22      5   proposed     train    44.925240  2.298689\n",
       "23      5   proposed      test    43.775642  2.292509\n",
       "24      6  benchmark     train    84.044846  2.761224\n",
       "25      6  benchmark      test    82.392151  2.779083\n",
       "26      6   proposed     train  1092.640381  3.464163\n",
       "27      6   proposed      test  1075.744385  3.432618\n",
       "28      7  benchmark     train    85.933029  2.762670\n",
       "29      7  benchmark      test    84.271027  2.778553\n",
       "30      7   proposed     train  1094.507568  3.419099\n",
       "31      7   proposed      test  1075.638672  3.411159\n",
       "32      8  benchmark     train    90.129730  3.036243\n",
       "33      8  benchmark      test    88.791595  3.044197\n",
       "34      8   proposed     train    41.645840  2.305331\n",
       "35      8   proposed      test    40.692940  2.300697\n",
       "36      9  benchmark     train    84.877251  2.766304\n",
       "37      9  benchmark      test    83.244659  2.785069"
      ]
     },
     "execution_count": 79,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result_trial"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "id": "82d6ea84",
   "metadata": {},
   "outputs": [
    {
     "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>level_0</th>\n",
       "      <th>level_1</th>\n",
       "      <th>level_2</th>\n",
       "      <th>mse</th>\n",
       "      <th>nll</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>85.273094</td>\n",
       "      <td>2.754417</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>83.613747</td>\n",
       "      <td>2.774736</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>43.376431</td>\n",
       "      <td>2.303232</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>42.599773</td>\n",
       "      <td>2.298116</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>85.249954</td>\n",
       "      <td>2.765092</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>1</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>83.560852</td>\n",
       "      <td>2.781921</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>1</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>43.336319</td>\n",
       "      <td>2.318605</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>1</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>42.365532</td>\n",
       "      <td>2.314586</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>2</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>85.092171</td>\n",
       "      <td>2.756333</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>2</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>83.449944</td>\n",
       "      <td>2.774932</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>2</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>39.869900</td>\n",
       "      <td>2.312612</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>2</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>38.881805</td>\n",
       "      <td>2.307631</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>3</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>84.855988</td>\n",
       "      <td>2.757930</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>3</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>83.211693</td>\n",
       "      <td>2.775242</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>3</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>43.636093</td>\n",
       "      <td>2.311005</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>3</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>42.284187</td>\n",
       "      <td>2.306424</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>4</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>84.792435</td>\n",
       "      <td>2.759606</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>4</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>83.070290</td>\n",
       "      <td>2.777184</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>4</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>108.317734</td>\n",
       "      <td>2.646003</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>4</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>106.800896</td>\n",
       "      <td>2.643455</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>5</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>85.597198</td>\n",
       "      <td>2.759997</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>5</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>83.931343</td>\n",
       "      <td>2.777694</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>5</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>44.925240</td>\n",
       "      <td>2.298689</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>5</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>43.775642</td>\n",
       "      <td>2.292509</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>6</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>84.044846</td>\n",
       "      <td>2.761224</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>6</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>82.392151</td>\n",
       "      <td>2.779083</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>6</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>1092.640381</td>\n",
       "      <td>3.464163</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>6</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>1075.744385</td>\n",
       "      <td>3.432618</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>7</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>85.933029</td>\n",
       "      <td>2.762670</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>7</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>84.271027</td>\n",
       "      <td>2.778553</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>7</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>1094.507568</td>\n",
       "      <td>3.419099</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>7</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>1075.638672</td>\n",
       "      <td>3.411159</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>8</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>90.129730</td>\n",
       "      <td>3.036243</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>8</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>88.791595</td>\n",
       "      <td>3.044197</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>8</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>41.645840</td>\n",
       "      <td>2.305331</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>8</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>40.692940</td>\n",
       "      <td>2.300697</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>36</th>\n",
       "      <td>9</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>84.877251</td>\n",
       "      <td>2.766304</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>37</th>\n",
       "      <td>9</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>83.244659</td>\n",
       "      <td>2.785069</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    level_0    level_1 level_2          mse       nll\n",
       "0         0  benchmark   train    85.273094  2.754417\n",
       "1         0  benchmark    test    83.613747  2.774736\n",
       "2         0   proposed   train    43.376431  2.303232\n",
       "3         0   proposed    test    42.599773  2.298116\n",
       "4         1  benchmark   train    85.249954  2.765092\n",
       "5         1  benchmark    test    83.560852  2.781921\n",
       "6         1   proposed   train    43.336319  2.318605\n",
       "7         1   proposed    test    42.365532  2.314586\n",
       "8         2  benchmark   train    85.092171  2.756333\n",
       "9         2  benchmark    test    83.449944  2.774932\n",
       "10        2   proposed   train    39.869900  2.312612\n",
       "11        2   proposed    test    38.881805  2.307631\n",
       "12        3  benchmark   train    84.855988  2.757930\n",
       "13        3  benchmark    test    83.211693  2.775242\n",
       "14        3   proposed   train    43.636093  2.311005\n",
       "15        3   proposed    test    42.284187  2.306424\n",
       "16        4  benchmark   train    84.792435  2.759606\n",
       "17        4  benchmark    test    83.070290  2.777184\n",
       "18        4   proposed   train   108.317734  2.646003\n",
       "19        4   proposed    test   106.800896  2.643455\n",
       "20        5  benchmark   train    85.597198  2.759997\n",
       "21        5  benchmark    test    83.931343  2.777694\n",
       "22        5   proposed   train    44.925240  2.298689\n",
       "23        5   proposed    test    43.775642  2.292509\n",
       "24        6  benchmark   train    84.044846  2.761224\n",
       "25        6  benchmark    test    82.392151  2.779083\n",
       "26        6   proposed   train  1092.640381  3.464163\n",
       "27        6   proposed    test  1075.744385  3.432618\n",
       "28        7  benchmark   train    85.933029  2.762670\n",
       "29        7  benchmark    test    84.271027  2.778553\n",
       "30        7   proposed   train  1094.507568  3.419099\n",
       "31        7   proposed    test  1075.638672  3.411159\n",
       "32        8  benchmark   train    90.129730  3.036243\n",
       "33        8  benchmark    test    88.791595  3.044197\n",
       "34        8   proposed   train    41.645840  2.305331\n",
       "35        8   proposed    test    40.692940  2.300697\n",
       "36        9  benchmark   train    84.877251  2.766304\n",
       "37        9  benchmark    test    83.244659  2.785069"
      ]
     },
     "execution_count": 74,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.DataFrame.from_dict(results_trial,orient=\"index\").reset_index()"
   ]
  }
 ],
 "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.9.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
