{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "f9af087a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "ba91ca27",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy import stats as sc_stats\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.metrics import mean_squared_error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "b36656a0",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2023-04-23 09:59:40.246506: 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": 4,
   "id": "0f8c852b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "from os.path import dirname\n",
    "sys.path.append(dirname(\"../\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "15f3aaa7",
   "metadata": {},
   "outputs": [],
   "source": [
    "from src.weibull_edl import loss_and_layers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1d577c70",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "6c54dcf8",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "87ca0a9d",
   "metadata": {},
   "source": [
    "### Read data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "6619f5e5",
   "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>grade:A</th>\n",
       "      <th>grade:B</th>\n",
       "      <th>grade:C</th>\n",
       "      <th>grade:D</th>\n",
       "      <th>grade:E</th>\n",
       "      <th>grade:F</th>\n",
       "      <th>grade:G</th>\n",
       "      <th>home_ownership:MORTGAGE</th>\n",
       "      <th>home_ownership:NONE</th>\n",
       "      <th>home_ownership:OTHER</th>\n",
       "      <th>...</th>\n",
       "      <th>dti</th>\n",
       "      <th>delinq_2yrs</th>\n",
       "      <th>inq_last_6mths</th>\n",
       "      <th>mths_since_last_delinq</th>\n",
       "      <th>open_acc</th>\n",
       "      <th>pub_rec</th>\n",
       "      <th>total_acc</th>\n",
       "      <th>acc_now_delinq</th>\n",
       "      <th>recovery_rate</th>\n",
       "      <th>CCF</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>member_id</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",
       "      <th></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",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1314167</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.00</td>\n",
       "      <td>0.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.046832</td>\n",
       "      <td>0.817416</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1306957</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>5.55</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>11.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>13.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.033761</td>\n",
       "      <td>0.971068</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1306721</th>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>18.08</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.050100</td>\n",
       "      <td>0.874701</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1298717</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>10.08</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>9.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.049367</td>\n",
       "      <td>0.860429</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1303503</th>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>...</td>\n",
       "      <td>7.06</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>14.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>29.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.064510</td>\n",
       "      <td>0.456653</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 49 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "           grade:A  grade:B  grade:C  grade:D  grade:E  grade:F  grade:G   \n",
       "member_id                                                                  \n",
       "1314167        0.0      0.0      1.0      0.0      0.0      0.0      0.0  \\\n",
       "1306957        0.0      0.0      0.0      0.0      0.0      1.0      0.0   \n",
       "1306721        0.0      1.0      0.0      0.0      0.0      0.0      0.0   \n",
       "1298717        0.0      0.0      1.0      0.0      0.0      0.0      0.0   \n",
       "1303503        0.0      1.0      0.0      0.0      0.0      0.0      0.0   \n",
       "\n",
       "           home_ownership:MORTGAGE  home_ownership:NONE  home_ownership:OTHER   \n",
       "member_id                                                                       \n",
       "1314167                        0.0                  0.0                   0.0  \\\n",
       "1306957                        0.0                  0.0                   0.0   \n",
       "1306721                        0.0                  0.0                   0.0   \n",
       "1298717                        0.0                  0.0                   0.0   \n",
       "1303503                        0.0                  0.0                   0.0   \n",
       "\n",
       "           ...    dti  delinq_2yrs  inq_last_6mths  mths_since_last_delinq   \n",
       "member_id  ...                                                               \n",
       "1314167    ...   1.00          0.0             5.0                     0.0  \\\n",
       "1306957    ...   5.55          0.0             2.0                     0.0   \n",
       "1306721    ...  18.08          0.0             0.0                     0.0   \n",
       "1298717    ...  10.08          0.0             1.0                     0.0   \n",
       "1303503    ...   7.06          0.0             2.0                     0.0   \n",
       "\n",
       "           open_acc  pub_rec  total_acc  acc_now_delinq  recovery_rate   \n",
       "member_id                                                                \n",
       "1314167         3.0      0.0        4.0             0.0       0.046832  \\\n",
       "1306957        11.0      0.0       13.0             0.0       0.033761   \n",
       "1306721         2.0      0.0        3.0             0.0       0.050100   \n",
       "1298717         4.0      0.0        9.0             0.0       0.049367   \n",
       "1303503        14.0      0.0       29.0             0.0       0.064510   \n",
       "\n",
       "                CCF  \n",
       "member_id            \n",
       "1314167    0.817416  \n",
       "1306957    0.971068  \n",
       "1306721    0.874701  \n",
       "1298717    0.860429  \n",
       "1303503    0.456653  \n",
       "\n",
       "[5 rows x 49 columns]"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_clean = pd.read_csv(\"../data/data_preprocessed_v0.csv\",index_col=0)\n",
    "df_clean.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "328f4195",
   "metadata": {},
   "outputs": [],
   "source": [
    "y_cols = [\"recovery_rate\",\"CCF\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "f55c27a4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "23300"
      ]
     },
     "execution_count": 52,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(y>0.00).sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "4bb92529",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((23300, 43), (23300,))"
      ]
     },
     "execution_count": 54,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_clean1 = df_clean[df_clean.recovery_rate>0.00]\n",
    "X = df_clean1.drop(columns=y_cols + list(df_clean.columns)[35:39])\n",
    "y = df_clean1[\"recovery_rate\"]*100 \n",
    "\n",
    "X.shape,y.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "2fff784f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((17475, 43), (5825, 43), (17475,), (5825,))"
      ]
     },
     "execution_count": 55,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.25, random_state=42)\n",
    "X_train.shape,X_test.shape,y_train.shape,y_test.shape"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c4051de3",
   "metadata": {},
   "source": [
    "### Estimate shape of weibull for y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "269b43b6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1.1890561651969371, 0, 11.385575855882676)"
      ]
     },
     "execution_count": 56,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rv = sc_stats.weibull_min.fit(y, floc=0)\n",
    "rv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "f5379a79",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.06235741, 0.06556923, 0.06134987, ..., 0.03391391, 0.03842998,\n",
       "       0.03140155])"
      ]
     },
     "execution_count": 57,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sc_stats.weibull_min.pdf(y,*rv)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 132,
   "id": "eddba60e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x175bf9700>"
      ]
     },
     "execution_count": 132,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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d2+lpaVp+vTpOnTokMs2LDNOBrr04osvGtHR0cbTTz9tfPzxx8asWbOM3r17G/v37w90awExYcIE4ze/+Y3x4YcfGpWVlcbkyZONIUOGGMePH3fWLF682Ojbt6+xdu1aY9euXcbUqVON1NRUo6mpKYCdB862bduMYcOGGZdeeqkxa9Ys53LGyTCOHDliDB061PiXf/kX49133zWqq6uN119/3fjss8+cNYyTYTzyyCNGYmKi8Ze//MWorq42/vCHPxh9+vQxSkpKnDXhOE6lpaXGwoULjbVr1xqSjD/96U8u73syJgUFBcagQYOMsrIyY+fOncb1119vXHbZZUZbW1sP743/dDdOR48eNcaPH2+sWbPG+OSTT4zy8nLjyiuvNLKzs122YZVxIrB044orrjAKCgpclo0cOdKYN29egDqylvr6ekOSsWnTJsMwDKO9vd1ISUkxFi9e7Kw5ffq0kZCQYKxcuTJQbQbMsWPHjAsvvNAoKyszrrvuOmdgYZzOmDt3rnHNNdd0+T7jdMbkyZONu+66y2XZ9773PWPatGmGYTBOhmF0+iL2ZEyOHj1qREdHGy+++KKz5uDBg0ZERISxfv36Huu9J7kLdh1t27bNkOT8h7mVxolTQl1oaWnRjh07lJ+f77I8Pz9fW7duDVBX1tLY2ChJGjDgzKPFq6urVVdX5zJmdrtd1113XViO2X333afJkydr/PjxLssZpzPWrVunnJwcff/739fAgQM1ZswYPf300873GaczrrnmGr3xxhvas2ePJOn999/X22+/rUmTJklinNzxZEx27Nih1tZWl5q0tDSNGjUqbMdNOvP3us1mcz6bz0rj5NXTmsNBQ0ODHA5HpwcwJicnd3pQYzgyDENFRUW65pprNGrUKElyjou7Mdu/f3+P9xhIL774onbu3Kn33nuv03uM0xl79+7VihUrVFRUpAULFmjbtm2aOXOm7Ha7pk+fzjj9n7lz56qxsVEjR45UZGSkHA6HHn30Ud1+++2S+H1yx5MxqaurU0xMjPr379+pJlz/jj99+rTmzZunO+64w/nwQyuNE4HlHGw2m8vPhmF0WhaO7r//fn3wwQdun/cU7mN24MABzZo1Sxs2bFBsbGyXdeE+Tu3t7crJydFjjz0mSRozZow++ugjrVixQtOnT3fWhfs4rVmzRs8//7z+93//VxdffLEqKys1e/ZspaWl6Uc/+pGzLtzHyR1vxiRcx621tVW33Xab2tvbtXz58nPWB2KcOCXUhaSkJEVGRnZKkPX19Z1Se7j56U9/qnXr1umtt97S4MGDnctTUlIkKezHbMeOHaqvr1d2draioqIUFRWlTZs2admyZYqKinKORbiPU2pqqi666CKXZVlZWc5nkfH7dMa//du/ad68ebrtttt0ySWX6M4771RhYaGKi4slMU7ueDImKSkpamlp0VdffdVlTbhobW3VD37wA1VXV6usrMx5dEWy1jgRWLoQExOj7OxslZWVuSwvKyvTuHHjAtRVYBmGofvvv18vvfSS3nzzTWVkZLi8n5GRoZSUFJcxa2lp0aZNm8JqzL797W9r165dqqysdL5ycnL0wx/+UJWVlcrMzGScJF199dWdbovfs2eP80Gq/D6dcfLkSUVEuP5VHRkZ6bytmXHqzJMxyc7OVnR0tEtNbW2tPvzww7Aat7Nh5dNPP9Xrr7+uxMREl/ctNU49eolvkDl7W/OqVauMjz/+2Jg9e7bRu3dvY9++fYFuLSDuueceIyEhwdi4caNRW1vrfJ08edJZs3jxYiMhIcF46aWXjF27dhm33357yN9e6Ymv3yVkGIyTYZy5GyEqKsp49NFHjU8//dT43e9+Z/Tq1ct4/vnnnTWMk2H86Ec/MgYNGuS8rfmll14ykpKSjJ/97GfOmnAcp2PHjhkVFRVGRUWFIclYunSpUVFR4by7xZMxKSgoMAYPHmy8/vrrxs6dO40bbrgh5G5r7m6cWltbjVtuucUYPHiwUVlZ6fL3enNzs3MbVhknAss5PPnkk8bQoUONmJgYY+zYsc5beMORJLev3/zmN86a9vZ24xe/+IWRkpJi2O1249prrzV27doVuKYtomNgYZzO+POf/2yMGjXKsNvtxsiRI42nnnrK5X3GyTCampqMWbNmGUOGDDFiY2ONzMxMY+HChS5fKOE4Tm+99Zbbv49+9KMfGYbh2ZicOnXKuP/++40BAwYYcXFxxk033WTU1NQEYG/8p7txqq6u7vLv9bfeesu5DauMk80wDKPnjucAAACYxzUsAADA8ggsAADA8ggsAADA8ggsAADA8ggsAADA8ggsAADA8ggsAADA8ggsAADA8ggsAADA8ggsAADA8ggsAADA8ggsAADA8v4/Y0FG+kmbqDgAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(y,alpha=0.5,density=True,bins=30,label=\"Histogram of data\")\n",
    "plt.scatter(y, sc_stats.weibull_min.pdf(y,*rv),label=\"Fitted Weibull\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "id": "6269f89b",
   "metadata": {},
   "outputs": [],
   "source": [
    "k=1.2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ea55ce58",
   "metadata": {},
   "source": [
    "### Build model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 117,
   "id": "f8f9424f",
   "metadata": {},
   "outputs": [],
   "source": [
    "edl_model = tf.keras.Sequential([\n",
    "        tf.keras.layers.Dense(1, input_dim=X.shape[1]),\n",
    "        tf.keras.layers.Dense(128, activation=\"relu\"),\n",
    "        tf.keras.layers.Dropout(0.3),\n",
    "        tf.keras.layers.Dense(64, activation=\"relu\"),\n",
    "        tf.keras.layers.Dense(32, activation=\"relu\"),\n",
    "        tf.keras.layers.Dense(32, activation=\"relu\"),\n",
    "        loss_and_layers.DenseWeibullGamma(1),\n",
    "    ])\n",
    "\n",
    "def weibullLoss(true, pred):\n",
    "        return loss_and_layers.weibull_evidence_Regression(true, pred, k=k, coeff=1e-1)\n",
    "\n",
    "# Compile and fit the model!\n",
    "edl_model.compile(\n",
    "    optimizer=tf.keras.optimizers.Adam(1e-2),\n",
    "    loss=weibullLoss)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 118,
   "id": "f18b8514",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/50\n",
      "35/35 [==============================] - 1s 3ms/step - loss: 6860882.0000\n",
      "Epoch 2/50\n",
      "35/35 [==============================] - 0s 3ms/step - loss: 12.2635\n",
      "Epoch 3/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.7612\n",
      "Epoch 4/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.6747\n",
      "Epoch 5/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.6050\n",
      "Epoch 6/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.6012\n",
      "Epoch 7/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5504\n",
      "Epoch 8/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5777\n",
      "Epoch 9/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5821\n",
      "Epoch 10/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5454\n",
      "Epoch 11/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5434\n",
      "Epoch 12/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5579\n",
      "Epoch 13/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5243\n",
      "Epoch 14/50\n",
      "35/35 [==============================] - 0s 3ms/step - loss: 11.5685\n",
      "Epoch 15/50\n",
      "35/35 [==============================] - 0s 3ms/step - loss: 11.7192\n",
      "Epoch 16/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 12.0036\n",
      "Epoch 17/50\n",
      "35/35 [==============================] - 0s 3ms/step - loss: 11.5837\n",
      "Epoch 18/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5336\n",
      "Epoch 19/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5232\n",
      "Epoch 20/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5368\n",
      "Epoch 21/50\n",
      "35/35 [==============================] - 0s 3ms/step - loss: 11.5092\n",
      "Epoch 22/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5252\n",
      "Epoch 23/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5144\n",
      "Epoch 24/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5168\n",
      "Epoch 25/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5230\n",
      "Epoch 26/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5101\n",
      "Epoch 27/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5132\n",
      "Epoch 28/50\n",
      "35/35 [==============================] - 0s 3ms/step - loss: 11.5139\n",
      "Epoch 29/50\n",
      "35/35 [==============================] - 0s 3ms/step - loss: 11.5059\n",
      "Epoch 30/50\n",
      "35/35 [==============================] - 0s 3ms/step - loss: 11.5156\n",
      "Epoch 31/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5435\n",
      "Epoch 32/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5496\n",
      "Epoch 33/50\n",
      "35/35 [==============================] - 0s 3ms/step - loss: 11.5159\n",
      "Epoch 34/50\n",
      "35/35 [==============================] - 0s 3ms/step - loss: 11.5097\n",
      "Epoch 35/50\n",
      "35/35 [==============================] - 0s 3ms/step - loss: 11.5192\n",
      "Epoch 36/50\n",
      "35/35 [==============================] - 0s 3ms/step - loss: 11.5126\n",
      "Epoch 37/50\n",
      "35/35 [==============================] - 0s 3ms/step - loss: 11.5157\n",
      "Epoch 38/50\n",
      "35/35 [==============================] - 0s 3ms/step - loss: 11.5174\n",
      "Epoch 39/50\n",
      "35/35 [==============================] - 0s 3ms/step - loss: 11.5184\n",
      "Epoch 40/50\n",
      "35/35 [==============================] - 0s 3ms/step - loss: 11.5193\n",
      "Epoch 41/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5204\n",
      "Epoch 42/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5167\n",
      "Epoch 43/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5097\n",
      "Epoch 44/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5071\n",
      "Epoch 45/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5087\n",
      "Epoch 46/50\n",
      "35/35 [==============================] - 0s 3ms/step - loss: 11.5093\n",
      "Epoch 47/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5180\n",
      "Epoch 48/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5207\n",
      "Epoch 49/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5239\n",
      "Epoch 50/50\n",
      "35/35 [==============================] - 0s 2ms/step - loss: 11.5068\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<keras.callbacks.History at 0x175441be0>"
      ]
     },
     "execution_count": 118,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "edl_model.fit(X_train.values[:,:], y_train.values[:], batch_size=500, epochs=50)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 119,
   "id": "72990ac4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "183/183 [==============================] - 0s 729us/step\n"
     ]
    }
   ],
   "source": [
    "y_pred = edl_model.predict(X_test)\n",
    "alpha,beta = y_pred[:,0],y_pred[:,1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 120,
   "id": "90b8f6cb",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.special import loggamma"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 121,
   "id": "b55bec79",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([1., 1., 1., ..., 1., 1., 1.], dtype=float32),\n",
       " array([0.15397003, 0.12977953, 0.09351879, ..., 0.12186086, 0.12701651,\n",
       "        0.13640003], dtype=float32))"
      ]
     },
     "execution_count": 121,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "alpha,beta"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 122,
   "id": "aa313508",
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_pred_log = loggamma((k*alpha-1)/k) - np.log(k) - ((alpha-1)/k)*np.log(beta)\n",
    "mu = np.exp(mean_pred_log)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 123,
   "id": "39a65d3d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([4.6385956, 4.6385956, 4.6385956, ..., 4.6385956, 4.6385956,\n",
       "       4.6385956], dtype=float32)"
      ]
     },
     "execution_count": 123,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mu"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 124,
   "id": "17ac6085",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "140.22997505341613"
      ]
     },
     "execution_count": 124,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mean_squared_error(y_test,mu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 125,
   "id": "9e8a28ec",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([1.98014352e+03, 5.40039142e+02, 1.04007538e+03, 8.28060017e+02,\n",
       "        0.00000000e+00, 9.72070455e+02, 1.36809916e+03, 0.00000000e+00,\n",
       "        8.00057988e+02, 1.26009133e+03, 5.76041751e+02, 1.22408872e+03,\n",
       "        6.12044361e+02, 2.80020296e+02, 1.04407567e+03, 7.92057408e+02,\n",
       "        2.52018266e+02, 4.68033923e+02, 6.12044361e+02, 0.00000000e+00,\n",
       "        3.96028704e+02, 9.00065236e+02, 1.44010438e+02, 9.36067845e+02,\n",
       "        4.80034793e+02, 1.08007828e+02, 7.92057408e+02, 6.12044361e+02,\n",
       "        2.16015657e+02, 3.24023485e+02, 4.00028994e+02, 2.16015657e+02,\n",
       "        3.96028704e+02, 7.20052189e+02, 2.16015657e+02, 6.12044361e+02,\n",
       "        4.80034793e+02, 1.08007828e+02, 5.04036532e+02, 6.48046970e+02,\n",
       "        7.56054798e+02, 8.00057988e+02, 8.64062627e+02, 9.36067845e+02,\n",
       "        1.36809916e+03, 3.96028704e+02, 1.44010438e+03, 1.84013337e+03,\n",
       "        1.08007828e+03, 1.76988828e+05]),\n",
       " array([4.63836145, 4.63836622, 4.63837099, 4.63837528, 4.63838005,\n",
       "        4.63838482, 4.63838959, 4.63839436, 4.63839912, 4.63840342,\n",
       "        4.63840818, 4.63841295, 4.63841772, 4.63842249, 4.63842678,\n",
       "        4.63843155, 4.63843632, 4.63844109, 4.63844585, 4.63845062,\n",
       "        4.63845491, 4.63845968, 4.63846445, 4.63846922, 4.63847399,\n",
       "        4.63847828, 4.63848305, 4.63848782, 4.63849258, 4.63849735,\n",
       "        4.63850212, 4.63850641, 4.63851118, 4.63851595, 4.63852072,\n",
       "        4.63852549, 4.63853025, 4.63853455, 4.63853931, 4.63854408,\n",
       "        4.63854885, 4.63855362, 4.63855791, 4.63856268, 4.63856745,\n",
       "        4.63857222, 4.63857698, 4.63858175, 4.63858604, 4.63859081,\n",
       "        4.63859558]),\n",
       " <BarContainer object of 50 artists>)"
      ]
     },
     "execution_count": 125,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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7zq7a1dEiAIAAFc1duxYrV279qo1L7zwgmw223Vtr6GhQWPGjFFISIjefPNNHTx4UEuXLtUXv/hFs2bgwIFauXKlDhw4oO3bt6t///5KTU3V6dOnzRq3263Dhw/r9ddf14EDBzRt2jTNmDFD+/fvt9LNDuMbywEAwFWNHTtWWVlZysrKarf9vffeU3p6uvbs2aOYmBgVFRVp6tSpV9zevHnz9Kc//Unbtm277mPw+XxyOBzatGmTHnjgAUnSF77wBa1atUput9us69u3r37xi19o1qxZ171tq5iJAgAAln388cf69re/rZUrV8rpdF7Xc15//XWNHDlSjzzyiKKiojR8+HCtXr36ivVNTU16+eWX5XA4NGzYMHP9N77xDb322mv66KOPdOnSJRUWFsrv92vs2LGftVvXhRAFAAAs+/73v6/Ro0frwQcfvO7n/PWvf9WqVat0zz336K233tJTTz2l7Oxs/frXvw6oe+ONN/SFL3xBPXr00PLly1VWVqbIyEiz/bXXXtOnn36qvn37ym6368knn1RRUZG+8pWvdFr/robTeQAAIMDChQu1cOFC8/HFixcVEhKi4OBgc92bb76phoYG5ebmav/+/frCF74gSbLZbNc8nRcaGqqRI0dqx44d5rrs7Gzt2bNHO3fuNNdduHBBtbW1OnPmjFavXq23335bu3btUlRUlCRpzpw52r17txYuXKjIyEht2LBBy5cv17Zt2zR06NDOGo4rIkQBAIAAH330kT766CPz8WOPPaaHH35Y06ZNM9f169dP+fn5+s///E/dccf/ndhqaWnRHXfcoW9+85vasmVLu9uPi4vThAkT9N///d/mulWrVulnP/uZPvzwwyse1z333KPvfOc7ys/P1wcffKC7775bVVVVGjJkiFkzfvx43X333frlL39ppesdEnztEgAAcDvp06eP+vTpYz7u2bOnoqKidPfddwfUzZs3T0888UTAuqFDh2r58uXKyMi44vbHjBmjw4cPB6w7cuSI4uLirnpchmHI7/dL+vu1WJICApwkBQUF6dKlS1fdTmchRAEAAEucTme7F5PfddddGjBggPn4gQce0EMPPaRnnnlG0v9dR7Vw4UJNnz5du3fv1ssvv6yXX35Z0t9P4y1YsEBTpkxRTEyMzp49qxdffFEnTpzQI488Ikm69957dffdd+vJJ5/UkiVL1LdvX23YsEFlZWV64403PofeE6IAAEAX++CDD3TmzBnz8X333aeioiLl5+dr/vz5GjBggF544QU99thjkv4+m/SXv/xFr7zyis6cOaO+ffvqvvvu07Zt28xTdyEhIdq4caPmzZunjIwMNTY26u6779Yrr7yif/qnf/pc+sU1UQAAABbwFQcAAAAWEKIAAAAsIEQBAABYQIgCAACwgBAFAABgASEKAADAAkIUAACABYQoAAAACwhRAAAAFhCiAAAALCBEAQAAWECIAgAAsOD/AUKXnwQMiJ6eAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(mu,bins=50,density=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3c5a04e0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6bdedee0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "id": "2985b938",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "183/183 [==============================] - 0s 1ms/step\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "array([[1.7279198e+17, 1.6998290e+17],\n",
       "       [1.9909627e+17, 1.9585956e+17],\n",
       "       [2.5875091e+17, 2.5454440e+17],\n",
       "       ...,\n",
       "       [2.1160929e+17, 2.0816916e+17],\n",
       "       [1.9598071e+17, 1.9279466e+17],\n",
       "       [1.7157451e+17, 1.6878522e+17]], dtype=float32)"
      ]
     },
     "execution_count": 69,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "edl_model.predict(X_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "44cb3d7d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "02816c99",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fbb03cb5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bce1f8a2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bebf9be6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "34adb4b0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a6702f9f",
   "metadata": {},
   "outputs": [],
   "source": [
    "y_test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ddee0438",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1a5a8d7a",
   "metadata": {},
   "outputs": [],
   "source": [
    "weibullLoss(y_test,edl_model.predict(X_test))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "27896eb0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "320/320 [==============================] - 0s 694us/step\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "array([[1.108159  , 0.1165923 ],\n",
       "       [1.1039628 , 0.1122489 ],\n",
       "       [1.0514863 , 0.05717027],\n",
       "       ...,\n",
       "       [1.0977554 , 0.10580984],\n",
       "       [1.0489044 , 0.05441312],\n",
       "       [1.0936749 , 0.10156785]], dtype=float32)"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "edl_model.predict(X_test)"
   ]
  }
 ],
 "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
}
