{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "39274922",
   "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": "2c6543cb",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2023-05-17 16:04:33.133379: 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": "bccabf61",
   "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": "19863f2f",
   "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": "52074af1",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "554c8863",
   "metadata": {},
   "source": [
    "### Read the LGD dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "cff53c54",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/kb/v0p0ypbd0wx1q2qb1kpxmmcc0000gn/T/ipykernel_3934/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 0x16ab49f10>"
      ]
     },
     "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": "825409a5",
   "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": "326b511c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Fitted k =1.246204234699603\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x16ae9f7f0>"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiwAAAGxCAYAAABBZ+3pAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABNqUlEQVR4nO3deVxU9f4/8Nc4wLAPisoui7mGpg5pgqReE3PJTC1yI9ciLVmu5XrNbMHMDDc0FfWa5pLazVtcE0sMla8rmCm5hWAIIZigogwM5/eHPydHBpgzzDDD8Ho+HvN4XA7vzznv84nbvDqrRBAEAURERERmrImpGyAiIiKqDQMLERERmT0GFiIiIjJ7DCxERERk9hhYiIiIyOwxsBAREZHZY2AhIiIis8fAQkRERGaPgYWIiIjMHgMLEZnMV199hfj4eKOt38/PD+PHjzfa+omo/kj4aH4iMpUhQ4bg119/xdWrV42y/vT0dDg7O6N169ZGWT8R1R8rUzdARKQLlUqFiooKyGQyncd07drViB0RUX3iKSEi0ltqaiokEgm2bdtW5XebN2+GRCLBiRMntI7t06cPvv/+e2RnZ0Mikag/AHD16lVIJBIsXrwYH374Ifz9/SGTyXDw4EHcv38f//znP9GlSxfI5XI0a9YMPXv2xLfffltlG4+fEkpJSVH3O3fuXHh6esLZ2RnPPfccLly4YJhJISKj4CkhIqqTbt26wd7eHocPH9ZY3r17dwDA8ePHtY47f/48Xn/9dVy5cgXffPONevkzzzyDq1evwt/fH15eXmjbti2mTZsGZ2dntGnTBk2bNkV0dDT69esHLy8vKJVKHDhwAEuXLsXGjRsRERGhXpefnx/69OmDTZs2AXgQWPr27Qs/Pz+EhIRg9OjRKCkpwcyZMyGTyZCZmQmpVGrgGSIiQ+ApISKqk+nTp2PChAnIyMhAly5dAAAnTpzAiRMn8O9//7vacR07doSLiwtkMhmeeeYZrTW2trb44YcfYG1trbF848aN6v+tUqnQr18//PXXX4iPj9cILDVte8uWLeqfpVIpXnnlFZw4caLaXojItHhKiIjqZNSoUWjZsiVWrVqlXrZixQq0aNEC4eHhqKysREVFhfqjUql0XvfQoUOrhBUA+PrrrxESEgJHR0dYWVnB2toaiYmJyMzM1Hm9j+rcuTMAIDs7W+feiKh+MbAQUZ3IZDK88cYb+Oqrr3Dr1i3cuHEDO3fuxOTJkyGTybBw4UJYW1urP2Lu2PHw8KiybM+ePXjllVfg5eWFLVu2IC0tDSdOnMDEiRNx//59ndbr6upaZR8A4N69ezr3RkT1i6eEiKjO3nzzTSxatAgbNmzA/fv3UVFRgcjISADA66+/jiFDhqhrxdzl8/Ai3Edt2bIF/v7+2LFjh8bvy8rK6rAHRGTuGFiIqM48PDzw8ssvIyEhAUqlEi+88AJatWoFAPD09ISnp6fWcTKZTPRRDYlEAhsbG42wkp+fr/UuISKyHDwlREQGERUVhStXruDatWt46623dBrTqVMnFBQUYPXq1Th+/DhOnjxZ65ghQ4bgwoULmDp1Kn766Sf8+9//Rq9evbSePiIiy8EjLERkEN27d4efnx/s7OzQr18/ncZERUXh3LlzmDNnDoqLiyEIAmp70sKECRNQUFCANWvWYMOGDQgICMCsWbPwxx9/4P333zfErhCRGeJzWIjIIH755Rc89dRTWLVqFaZOnWrqdojIwjCwEFGdXLlyBdnZ2ZgzZw5ycnJw+fJl2Nvbm7otIrIwvIaFiOrkgw8+QP/+/XHnzh18/fXXDCtEZBQ8wkJERERmj0dYiIiIyOwxsBAREZHZY2AhIiIis2cxz2GprKzE9evX4eTkpPVx3kRERGR+BEHA7du34enpiSZNqj+OYjGB5fr16/Dx8TF1G0RERKSHa9euwdvbu9rfW0xgcXJyAvBgh52dnU3cDREREemipKQEPj4+6u/x6lhMYHl4GsjZ2ZmBhYiIqIGp7XIOXnRLREREZo+BhYiIiMweAwsRERGZPYu5hoWIiOpGEARUVFRApVKZuhWyIFKpFFZWVnV+5AgDCxERQalUIi8vD6WlpaZuhSyQvb09PDw8YGNjo/c6GFiIiBq5yspKZGVlQSqVwtPTEzY2NnwAJxmEIAhQKpW4ceMGsrKy0KZNmxofDlcTBhYiokZOqVSisrISPj4+sLe3N3U7ZGHs7OxgbW2N7OxsKJVK2Nra6rUeXnRLREQAoPd/+RLVxhB/W/zrJCIiIrPHwEJERERmj9ewEBFRtT5Pvlhv24rp39Zo6960aROio6Nx69Yto23DUgiCgDfeeAO7du3CX3/9hfT0dHTp0sXUbfEICxERNVzjx4/HsGHDqixPSUmBRCJRB5Tw8HBcvKhb+Nq0aRNcXFwM12QDs2/fPmzatAnfffcd8vLyEBgYaOqWAPAICxERNQJ2dnaws7MzdRtVlJeXw9ra2tRtaLhy5Qo8PDwQHBxs6lY08AgLERFZvMePmpw5cwZ9+/aFk5MTnJ2doVAocPLkSaSkpGDChAkoLi6GRCKBRCLBggULAAB//fUXIiIi0LRpU9jb22PgwIG4dOmSxnbWrVunvj38pZdewtKlSzW2u2DBAnTp0gUbNmxAQEAAZDIZBEHAvn370KtXL7i4uMDV1RVDhgzBlStX1OOuXr0KiUSCnTt3IjQ0FHZ2dnj66adx8eJFnDhxAkFBQXB0dMTzzz+PGzdu1DgXhw4dQvfu3SGTyeDh4YFZs2ahoqICwIMjVm+//TZycnIgkUjg5+dXZfzdu3fh7OyMXbt2aSz/73//CwcHB9y+fVuHfyLi8QiLharLeWdjnkcmIjIHY8aMQdeuXbF69WpIpVJkZGTA2toawcHBiI+Px/z583HhwgUAgKOjI4AHX+aXLl3C3r174ezsjJkzZ2LQoEE4f/48rK2tceTIEURGRuKTTz7B0KFDceDAAfzrX/+qsu3Lly9j586d2L17N6RSKYAHISA2NhadOnXC3bt3MX/+fLz00kvIyMjQuCX4vffeQ3x8PFq1aoWJEydi1KhRcHZ2xrJly2Bvb49XXnkF8+fPx+rVq7Xud25uLgYNGoTx48dj8+bN+O233zBlyhTY2tpiwYIFWLZsGVq3bo21a9fixIkT6v4e5eDggFdffRUbN27EyJEj1csf/uzk5KT/P5gaMLAQEVGD9t1336lDxUO1vQ8pJycH77zzDtq3bw8AaNOmjfp3crkcEokE7u7u6mUPg8qRI0fUp0q2bt0KHx8f/Oc//8HLL7+MFStWYODAgZgxYwYAoG3btjh69Ci+++47jW0rlUp8+eWXaNGihXrZiBEjNGoSExPRsmVLnD9/XuMakhkzZmDAgAEAgKioKIwaNQo//vgjQkJCAACTJk3Cpk2bqt3vhIQE+Pj4YOXKlZBIJGjfvj2uX7+OmTNnYv78+ZDL5XBycoJUKtXY/8dNnjwZwcHBuH79Ojw9PVFYWIjvvvsOycnJ1Y6pK54SIiKiBq1v377IyMjQ+Kxfv77GMbGxsZg8eTKee+45LFq0SOP0izaZmZmwsrJCjx491MtcXV3Rrl07ZGZmAgAuXLiA7t27a4x7/GcA8PX11QgrwIPrRkaPHo2AgAA4OzvD398fwINg9ajOnTur/7ebmxsAoFOnThrLCgoKatyPnj17arx6ISQkBHfu3MEff/xR7bjHde/eHU8++SQ2b94MAPjyyy/RqlUrPPvsszqvQywGFiIiatAcHBzwxBNPaHy8vLxqHLNgwQKcO3cOgwcPxk8//YSOHTvim2++qbZeEIRqlz/88n/0f9c0zsHBocqyF154AUVFRVi3bh2OHTuGY8eOAXhwNOZRj16g+3Bbjy+rrKyscT+q61Hs+6MmT56MjRs3AnhwOmjChAlGfQcVAwsRETVKbdu2RUxMDPbv34/hw4erv3xtbGyqnFLq2LEjKioq1EECAIqKinDx4kV06NABANC+fXscP35cY9zJkydr7aOoqAiZmZmYN28e+vXrhw4dOuCvv/6q6+5p1bFjRxw9elQjSB09ehROTk61hrzHjR07Fjk5OVi+fDnOnTuH1157zdDtamBgISKiRuXevXt46623kJKSguzsbBw5cgQnTpxQBw8/Pz/cuXMHP/74IwoLC1FaWoo2bdrgxRdfxJQpU3D48GGcOXMGY8eOhZeXF1588UUAwNtvv42kpCQsXboUly5dwhdffIH//e9/tR51aNq0KVxdXbF27VpcvnwZP/30E2JjY42y71OnTsW1a9fw9ttv47fffsO3336L9957D7GxsaLf99O0aVMMHz4c77zzDsLCwuDt7W2Unh/iRbdERFQtS7xrUCqVoqioCBEREfjzzz/RvHlzDB8+HO+//z4AIDg4GJGRkQgPD0dRURHee+89LFiwABs3bkRUVBSGDBkCpVKJZ599FklJSepTMiEhIVizZg3ef/99zJs3DwMGDEBMTAxWrlxZYz9NmjTB9u3bMX36dAQGBqJdu3ZYvnw5+vTpY/B99/LyQlJSEt555x089dRTaNasGSZNmoR58+bptb5Jkybhq6++wsSJEw3caVUSoboTcw1MSUkJ5HI5iouL4ezsbOp2TI63NRORru7fv4+srCz4+/vD1tbW1O1YlClTpuC3335DamqqqVsxiq1btyIqKgrXr1+HjY1NtXU1/Y3p+v3NIyxEREQGsmTJEvTv3x8ODg743//+h3//+99ISEgwdVsGV1paiqysLMTFxeGNN96oMawYCq9hISIiMpDjx4+jf//+6NSpE9as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",
      "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": "markdown",
   "id": "29ae4307",
   "metadata": {},
   "source": [
    "### Experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "843936c4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "fitting benchmark 0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2023-05-17 16:04:41.487313: 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=84.23602, test = 84.14709\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=32.66350, test = 33.53005\n",
      "fitting benchmark 1\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=84.61977, test = 84.80188\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 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=43.56094, test = 44.12186\n",
      "fitting benchmark 2\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=83.81411, test = 83.73596\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",
      "Error for i=2\n",
      "fitting benchmark 2\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Traceback (most recent call last):\n",
      "  File \"/var/folders/kb/v0p0ypbd0wx1q2qb1kpxmmcc0000gn/T/ipykernel_3934/440964472.py\", line 21, 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=84.31469, test = 84.38790\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=41.89696, test = 42.54202\n",
      "fitting benchmark 3\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=84.11184, test = 83.99479\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 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=41.51511, test = 41.79720\n",
      "fitting benchmark 4\n",
      "583/583 [==============================] - 1s 2ms/step\n",
      "146/146 [==============================] - 0s 2ms/step\n",
      "MSE train=84.24113, test = 84.22983\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=1557.84021, test = 1560.03503\n"
     ]
    }
   ],
   "source": [
    "results_trial={}\n",
    "i = 0\n",
    "while i <5:\n",
    "    try:\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.043,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.5,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}\")\n",
    "        i+=1\n",
    "    except:\n",
    "        print (f\"Error for i={i}\")\n",
    "        traceback.print_exc()\n",
    "        continue"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "746a822a",
   "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": 15,
   "id": "dacdef3d",
   "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>84.236015</td>\n",
       "      <td>2.758631</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>84.147095</td>\n",
       "      <td>2.746076</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>32.663502</td>\n",
       "      <td>2.348293</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>33.530048</td>\n",
       "      <td>2.346795</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>84.619774</td>\n",
       "      <td>2.765545</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>1</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>84.801880</td>\n",
       "      <td>2.754825</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>1</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>43.560936</td>\n",
       "      <td>2.303972</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>1</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>44.121861</td>\n",
       "      <td>2.301469</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>2</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>84.314690</td>\n",
       "      <td>2.762047</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>2</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>84.387901</td>\n",
       "      <td>2.752372</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>2</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>41.896961</td>\n",
       "      <td>2.301214</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>2</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>42.542015</td>\n",
       "      <td>2.298230</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>3</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>train</td>\n",
       "      <td>84.111839</td>\n",
       "      <td>2.778562</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>3</td>\n",
       "      <td>benchmark</td>\n",
       "      <td>test</td>\n",
       "      <td>83.994789</td>\n",
       "      <td>2.773341</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>3</td>\n",
       "      <td>proposed</td>\n",
       "      <td>train</td>\n",
       "      <td>41.515110</td>\n",
       "      <td>2.303470</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>3</td>\n",
       "      <td>proposed</td>\n",
       "      <td>test</td>\n",
       "      <td>41.797199</td>\n",
       "      <td>2.299477</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    trial model_type data_type        mse       nll\n",
       "0       0  benchmark     train  84.236015  2.758631\n",
       "1       0  benchmark      test  84.147095  2.746076\n",
       "2       0   proposed     train  32.663502  2.348293\n",
       "3       0   proposed      test  33.530048  2.346795\n",
       "4       1  benchmark     train  84.619774  2.765545\n",
       "5       1  benchmark      test  84.801880  2.754825\n",
       "6       1   proposed     train  43.560936  2.303972\n",
       "7       1   proposed      test  44.121861  2.301469\n",
       "8       2  benchmark     train  84.314690  2.762047\n",
       "9       2  benchmark      test  84.387901  2.752372\n",
       "10      2   proposed     train  41.896961  2.301214\n",
       "11      2   proposed      test  42.542015  2.298230\n",
       "12      3  benchmark     train  84.111839  2.778562\n",
       "13      3  benchmark      test  83.994789  2.773341\n",
       "14      3   proposed     train  41.515110  2.303470\n",
       "15      3   proposed      test  41.797199  2.299477"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result_trial[result_trial[\"trial\"]<=3]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "8f1bbbfe",
   "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=\"4\" halign=\"left\">mean</th>\n",
       "      <th colspan=\"4\" halign=\"left\">std</th>\n",
       "    </tr>\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\">mse</th>\n",
       "      <th colspan=\"2\" halign=\"left\">nll</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",
       "      <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",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>test</th>\n",
       "      <td>84.332916</td>\n",
       "      <td>40.497780</td>\n",
       "      <td>2.756653</td>\n",
       "      <td>2.311492</td>\n",
       "      <td>0.352046</td>\n",
       "      <td>4.745195</td>\n",
       "      <td>0.011720</td>\n",
       "      <td>0.023573</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>train</th>\n",
       "      <td>84.320580</td>\n",
       "      <td>39.909126</td>\n",
       "      <td>2.766196</td>\n",
       "      <td>2.314237</td>\n",
       "      <td>0.216237</td>\n",
       "      <td>4.911397</td>\n",
       "      <td>0.008714</td>\n",
       "      <td>0.022736</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                 mean                                      std             \n",
       "                  mse                  nll                 mse             \n",
       "model_type  benchmark   proposed benchmark  proposed benchmark  proposed   \n",
       "data_type                                                                  \n",
       "test        84.332916  40.497780  2.756653  2.311492  0.352046  4.745195  \\\n",
       "train       84.320580  39.909126  2.766196  2.314237  0.216237  4.911397   \n",
       "\n",
       "                                \n",
       "                 nll            \n",
       "model_type benchmark  proposed  \n",
       "data_type                       \n",
       "test        0.011720  0.023573  \n",
       "train       0.008714  0.022736  "
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result_trial[result_trial[\"trial\"]<=3].pivot_table(index=\"data_type\",columns=[\"model_type\"],\\\n",
    "                                                  aggfunc=[np.mean,np.std],\\\n",
    "                                                  values=[\"mse\",\"nll\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "9dff35ab",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"sequential_10\"\n",
      "_________________________________________________________________\n",
      " Layer (type)                Output Shape              Param #   \n",
      "=================================================================\n",
      " dense_100 (Dense)           (None, 1)                 46        \n",
      "                                                                 \n",
      " dense_101 (Dense)           (None, 350)               700       \n",
      "                                                                 \n",
      " dense_102 (Dense)           (None, 300)               105300    \n",
      "                                                                 \n",
      " dense_103 (Dense)           (None, 300)               90300     \n",
      "                                                                 \n",
      " dense_104 (Dense)           (None, 250)               75250     \n",
      "                                                                 \n",
      " dense_105 (Dense)           (None, 250)               62750     \n",
      "                                                                 \n",
      " dense_106 (Dense)           (None, 200)               50200     \n",
      "                                                                 \n",
      " dense_107 (Dense)           (None, 200)               40200     \n",
      "                                                                 \n",
      " dense_108 (Dense)           (None, 200)               40200     \n",
      "                                                                 \n",
      " dense_normal_gamma_5 (Dense  (None, 4)                804       \n",
      " NormalGamma)                                                    \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 465,750\n",
      "Trainable params: 465,750\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "benchmark_model_i.summary()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "f5aabdda",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"sequential_11\"\n",
      "_________________________________________________________________\n",
      " Layer (type)                Output Shape              Param #   \n",
      "=================================================================\n",
      " dense_110 (Dense)           (None, 1)                 46        \n",
      "                                                                 \n",
      " dense_111 (Dense)           (None, 350)               700       \n",
      "                                                                 \n",
      " dense_112 (Dense)           (None, 300)               105300    \n",
      "                                                                 \n",
      " dense_113 (Dense)           (None, 300)               90300     \n",
      "                                                                 \n",
      " dense_114 (Dense)           (None, 250)               75250     \n",
      "                                                                 \n",
      " dense_115 (Dense)           (None, 250)               62750     \n",
      "                                                                 \n",
      " dense_116 (Dense)           (None, 200)               50200     \n",
      "                                                                 \n",
      " dense_117 (Dense)           (None, 200)               40200     \n",
      "                                                                 \n",
      " dense_118 (Dense)           (None, 200)               40200     \n",
      "                                                                 \n",
      " dense_weibull_gamma_5 (Dens  (None, 2)                402       \n",
      " eWeibullGamma)                                                  \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 465,348\n",
      "Trainable params: 465,348\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "proposed_model_i.summary()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "acd160da",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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
}
