{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "ec985243",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "2444bbcc",
   "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": 6,
   "id": "caa4c5b9",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2023-04-22 11:18:12.535505: 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": 17,
   "id": "cd365ac5",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "from os.path import dirname\n",
    "sys.path.append(dirname(\"../\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "b6372730",
   "metadata": {},
   "outputs": [],
   "source": [
    "from src.edl import dense_layers,dense_loss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 319,
   "id": "d1246705",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "064da201",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c553afee",
   "metadata": {},
   "source": [
    "### Read data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 288,
   "id": "f2b1a986",
   "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": 288,
     "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": 289,
   "id": "5a5effd4",
   "metadata": {},
   "outputs": [],
   "source": [
    "y_cols = [\"recovery_rate\",\"CCF\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 291,
   "id": "1a7d1354",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((40896, 43), (40896,))"
      ]
     },
     "execution_count": 291,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X = df_clean.drop(columns=y_cols + list(df_clean.columns)[35:39])\n",
    "y = df_clean[\"recovery_rate\"]\n",
    "\n",
    "X.shape,y.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 292,
   "id": "1a68c323",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((30672, 43), (10224, 43), (30672,), (10224,))"
      ]
     },
     "execution_count": 292,
     "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": "bae9671b",
   "metadata": {},
   "source": [
    "### Test normla regression model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "2180964f",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = tf.keras.Sequential(\n",
    "    [\n",
    "        tf.keras.layers.Dense(units = X_train.shape[1], activation=\"relu\"),\n",
    "        tf.keras.layers.Dense(32, activation=\"relu\"),\n",
    "        tf.keras.layers.Dense(1), # Evidential distribution!\n",
    "    ]\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "8541436b",
   "metadata": {},
   "outputs": [],
   "source": [
    "model.compile(\n",
    "    optimizer=tf.keras.optimizers.Adam(1e-3), \n",
    "    loss=tf.keras.losses.mean_squared_error # Evidential loss!\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "57871d3f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 96.0077\n",
      "Epoch 2/500\n",
      "31/31 [==============================] - 0s 3ms/step - loss: 69.7884\n",
      "Epoch 3/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 97.3274\n",
      "Epoch 4/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 126.7926\n",
      "Epoch 5/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 65.5658\n",
      "Epoch 6/500\n",
      "31/31 [==============================] - 0s 3ms/step - loss: 59.9571\n",
      "Epoch 7/500\n",
      "31/31 [==============================] - 0s 3ms/step - loss: 79.1397\n",
      "Epoch 8/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 71.1408\n",
      "Epoch 9/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 108.9554\n",
      "Epoch 10/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 50.5168\n",
      "Epoch 11/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 82.9137\n",
      "Epoch 12/500\n",
      "31/31 [==============================] - 0s 3ms/step - loss: 126.9080\n",
      "Epoch 13/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 58.4872\n",
      "Epoch 14/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 54.8032\n",
      "Epoch 15/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 43.3235\n",
      "Epoch 16/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 51.8241\n",
      "Epoch 17/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 56.0528\n",
      "Epoch 18/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 104.2306\n",
      "Epoch 19/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 347.7373\n",
      "Epoch 20/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 69.3837\n",
      "Epoch 21/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 37.4479\n",
      "Epoch 22/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 34.3378\n",
      "Epoch 23/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 61.6476\n",
      "Epoch 24/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 53.3493\n",
      "Epoch 25/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 68.2476\n",
      "Epoch 26/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 124.6457\n",
      "Epoch 27/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 67.8912\n",
      "Epoch 28/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 133.5929\n",
      "Epoch 29/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 173.5477\n",
      "Epoch 30/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 44.1863\n",
      "Epoch 31/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 29.6536\n",
      "Epoch 32/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 47.8900\n",
      "Epoch 33/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 161.3658\n",
      "Epoch 34/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 239.1588\n",
      "Epoch 35/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 65.6201\n",
      "Epoch 36/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 51.2637\n",
      "Epoch 37/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 61.3795\n",
      "Epoch 38/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 77.5433\n",
      "Epoch 39/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 876.1581\n",
      "Epoch 40/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 609.8904\n",
      "Epoch 41/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 57.4279\n",
      "Epoch 42/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 36.6733\n",
      "Epoch 43/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 32.2791\n",
      "Epoch 44/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 24.7738\n",
      "Epoch 45/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 22.6160\n",
      "Epoch 46/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 23.3816\n",
      "Epoch 47/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 21.7679\n",
      "Epoch 48/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 19.4130\n",
      "Epoch 49/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 18.1710\n",
      "Epoch 50/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 19.0727\n",
      "Epoch 51/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 21.7313\n",
      "Epoch 52/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 22.1717\n",
      "Epoch 53/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 64.8599\n",
      "Epoch 54/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 88.6005\n",
      "Epoch 55/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 64.8448\n",
      "Epoch 56/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 33.4998\n",
      "Epoch 57/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 24.4370\n",
      "Epoch 58/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 24.6584\n",
      "Epoch 59/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 23.9009\n",
      "Epoch 60/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 116.8769\n",
      "Epoch 61/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 479.6741\n",
      "Epoch 62/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 391.8230\n",
      "Epoch 63/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 272.7322\n",
      "Epoch 64/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 43.3686\n",
      "Epoch 65/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 32.1021\n",
      "Epoch 66/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 804.3415\n",
      "Epoch 67/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 1873.9410\n",
      "Epoch 68/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 80.7091\n",
      "Epoch 69/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 22.6038\n",
      "Epoch 70/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 346.1356\n",
      "Epoch 71/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 4651.2476\n",
      "Epoch 72/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 2100.2029\n",
      "Epoch 73/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 1229.2710\n",
      "Epoch 74/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 116.8032\n",
      "Epoch 75/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 38.2119\n",
      "Epoch 76/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 12.4428\n",
      "Epoch 77/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 11.2471\n",
      "Epoch 78/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 12.1299\n",
      "Epoch 79/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 40.4930\n",
      "Epoch 80/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 80.1953\n",
      "Epoch 81/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 13.8975\n",
      "Epoch 82/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 13.5660\n",
      "Epoch 83/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 253.1689\n",
      "Epoch 84/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 40257.5664\n",
      "Epoch 85/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 40509.6562\n",
      "Epoch 86/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 2424.9204\n",
      "Epoch 87/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 432.1400\n",
      "Epoch 88/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 208.6587\n",
      "Epoch 89/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 73.8895\n",
      "Epoch 90/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 26.7882\n",
      "Epoch 91/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 15.6441\n",
      "Epoch 92/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 13.2876\n",
      "Epoch 93/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 13.1270\n",
      "Epoch 94/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 13.6568\n",
      "Epoch 95/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 13.6890\n",
      "Epoch 96/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 12.2118\n",
      "Epoch 97/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 11.7074\n",
      "Epoch 98/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 12.5489\n",
      "Epoch 99/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 11.6172\n",
      "Epoch 100/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "31/31 [==============================] - 0s 1ms/step - loss: 11.3573\n",
      "Epoch 101/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 11.3935\n",
      "Epoch 102/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 12.3365\n",
      "Epoch 103/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 13.2086\n",
      "Epoch 104/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 10.4267\n",
      "Epoch 105/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 10.4176\n",
      "Epoch 106/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 10.6482\n",
      "Epoch 107/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 10.9885\n",
      "Epoch 108/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 10.1655\n",
      "Epoch 109/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 11.0368\n",
      "Epoch 110/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 10.6487\n",
      "Epoch 111/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 9.9402\n",
      "Epoch 112/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 9.0020\n",
      "Epoch 113/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 8.6857\n",
      "Epoch 114/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 23.7900\n",
      "Epoch 115/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 97.8028\n",
      "Epoch 116/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 42.6511\n",
      "Epoch 117/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 12.0798\n",
      "Epoch 118/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 7.5886\n",
      "Epoch 119/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 25.7751\n",
      "Epoch 120/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 24.7078\n",
      "Epoch 121/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 11.6439\n",
      "Epoch 122/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 15.8323\n",
      "Epoch 123/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 12.9169\n",
      "Epoch 124/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 11.9949\n",
      "Epoch 125/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 9.8800\n",
      "Epoch 126/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 372.1389\n",
      "Epoch 127/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 1216.9396\n",
      "Epoch 128/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 1565.9697\n",
      "Epoch 129/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 211.1026\n",
      "Epoch 130/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 43.1369\n",
      "Epoch 131/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 20.2268\n",
      "Epoch 132/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 54.8298\n",
      "Epoch 133/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 26.6809\n",
      "Epoch 134/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 108.4407\n",
      "Epoch 135/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 5540.5732\n",
      "Epoch 136/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 4835.6553\n",
      "Epoch 137/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 1527.9036\n",
      "Epoch 138/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 298.7305\n",
      "Epoch 139/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 51.7109\n",
      "Epoch 140/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 62.5877\n",
      "Epoch 141/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 211.0815\n",
      "Epoch 142/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 206.3432\n",
      "Epoch 143/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 361.7569\n",
      "Epoch 144/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 1560.8157\n",
      "Epoch 145/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 145.7755\n",
      "Epoch 146/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 30.5876\n",
      "Epoch 147/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 15.7185\n",
      "Epoch 148/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 28.1367\n",
      "Epoch 149/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 23.8117\n",
      "Epoch 150/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 1845.0815\n",
      "Epoch 151/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 4273.4038\n",
      "Epoch 152/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 719.0889\n",
      "Epoch 153/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 55.7988\n",
      "Epoch 154/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 21.6119\n",
      "Epoch 155/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 40.4975\n",
      "Epoch 156/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 55.3924\n",
      "Epoch 157/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 23.5924\n",
      "Epoch 158/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 116.9646\n",
      "Epoch 159/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 3581.9258\n",
      "Epoch 160/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 29423.1816\n",
      "Epoch 161/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 1445.3359\n",
      "Epoch 162/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 228.5029\n",
      "Epoch 163/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 74.4580\n",
      "Epoch 164/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 40.2826\n",
      "Epoch 165/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 18.7317\n",
      "Epoch 166/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 16.9642\n",
      "Epoch 167/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 13.1369\n",
      "Epoch 168/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 18.0227\n",
      "Epoch 169/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 12.7258\n",
      "Epoch 170/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 16.5763\n",
      "Epoch 171/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 26.1051\n",
      "Epoch 172/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 16.4702\n",
      "Epoch 173/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 10.0313\n",
      "Epoch 174/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 10.4699\n",
      "Epoch 175/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 11.1599\n",
      "Epoch 176/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 10.5828\n",
      "Epoch 177/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 9.9239\n",
      "Epoch 178/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 17.2467\n",
      "Epoch 179/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 16.7101\n",
      "Epoch 180/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 12.4325\n",
      "Epoch 181/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 13.0512\n",
      "Epoch 182/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 12.5656\n",
      "Epoch 183/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 12.3888\n",
      "Epoch 184/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 30.6018\n",
      "Epoch 185/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 11.2054\n",
      "Epoch 186/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 11.7788\n",
      "Epoch 187/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 104.2393\n",
      "Epoch 188/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 886.1687\n",
      "Epoch 189/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 2083.1934\n",
      "Epoch 190/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 44.9801\n",
      "Epoch 191/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 10.6494\n",
      "Epoch 192/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 10.7647\n",
      "Epoch 193/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 338.0403\n",
      "Epoch 194/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 7874.2129\n",
      "Epoch 195/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 1087.8383\n",
      "Epoch 196/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 208.7123\n",
      "Epoch 197/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 41.0773\n",
      "Epoch 198/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "31/31 [==============================] - 0s 1ms/step - loss: 12.2066\n",
      "Epoch 199/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 9.6572\n",
      "Epoch 200/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 11.5600\n",
      "Epoch 201/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 132.2389\n",
      "Epoch 202/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 82.9089\n",
      "Epoch 203/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 223.7684\n",
      "Epoch 204/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 326.9326\n",
      "Epoch 205/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 5844.0029\n",
      "Epoch 206/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 2894.1301\n",
      "Epoch 207/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 313.4097\n",
      "Epoch 208/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 154.0089\n",
      "Epoch 209/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 13.1469\n",
      "Epoch 210/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 16.4504\n",
      "Epoch 211/500\n",
      "31/31 [==============================] - 0s 3ms/step - loss: 14.5283\n",
      "Epoch 212/500\n",
      "31/31 [==============================] - 0s 3ms/step - loss: 8.5985\n",
      "Epoch 213/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 10.0056\n",
      "Epoch 214/500\n",
      "31/31 [==============================] - 0s 3ms/step - loss: 7.9962\n",
      "Epoch 215/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 169.0551\n",
      "Epoch 216/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 462.4236\n",
      "Epoch 217/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 356.9100\n",
      "Epoch 218/500\n",
      "31/31 [==============================] - 0s 3ms/step - loss: 17.2287\n",
      "Epoch 219/500\n",
      "31/31 [==============================] - 0s 4ms/step - loss: 64.0482\n",
      "Epoch 220/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 76.6589\n",
      "Epoch 221/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 12017.4590\n",
      "Epoch 222/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 7960.4106\n",
      "Epoch 223/500\n",
      "31/31 [==============================] - 0s 3ms/step - loss: 319.9372\n",
      "Epoch 224/500\n",
      "31/31 [==============================] - 0s 5ms/step - loss: 56.2297\n",
      "Epoch 225/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 37.3227\n",
      "Epoch 226/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 26.1413\n",
      "Epoch 227/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 40.2089\n",
      "Epoch 228/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 18.6284\n",
      "Epoch 229/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 35.3150\n",
      "Epoch 230/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 17.3712\n",
      "Epoch 231/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 20.2426\n",
      "Epoch 232/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 23.1125\n",
      "Epoch 233/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 12.6996\n",
      "Epoch 234/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 16.5610\n",
      "Epoch 235/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 9.6383\n",
      "Epoch 236/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 7.7474\n",
      "Epoch 237/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 10.4132\n",
      "Epoch 238/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 20.1219\n",
      "Epoch 239/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 23.1500\n",
      "Epoch 240/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 117.1691\n",
      "Epoch 241/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 28.1558\n",
      "Epoch 242/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 105.2571\n",
      "Epoch 243/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 148.4738\n",
      "Epoch 244/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 2130.3079\n",
      "Epoch 245/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 12432.9072\n",
      "Epoch 246/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 4544.2446\n",
      "Epoch 247/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 644.4783\n",
      "Epoch 248/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 119.7510\n",
      "Epoch 249/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 29.1198\n",
      "Epoch 250/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 30.6001\n",
      "Epoch 251/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 18.0612\n",
      "Epoch 252/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 14.5572\n",
      "Epoch 253/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 15.3949\n",
      "Epoch 254/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 16.8118\n",
      "Epoch 255/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 25.6106\n",
      "Epoch 256/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 16.2354\n",
      "Epoch 257/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 13.0209\n",
      "Epoch 258/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 10.9406\n",
      "Epoch 259/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 76.7438\n",
      "Epoch 260/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 21.8272\n",
      "Epoch 261/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 11.7363\n",
      "Epoch 262/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 10.1109\n",
      "Epoch 263/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 17.3768\n",
      "Epoch 264/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 9.2713\n",
      "Epoch 265/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 80.3052\n",
      "Epoch 266/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 333.9331\n",
      "Epoch 267/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 347.3664\n",
      "Epoch 268/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 296.2472\n",
      "Epoch 269/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 16997.9121\n",
      "Epoch 270/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 898.9994\n",
      "Epoch 271/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 60.4757\n",
      "Epoch 272/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 46.2722\n",
      "Epoch 273/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 25.9775\n",
      "Epoch 274/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 22.1401\n",
      "Epoch 275/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 77.9113\n",
      "Epoch 276/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 20.3147\n",
      "Epoch 277/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 18.7532\n",
      "Epoch 278/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 17.6469\n",
      "Epoch 279/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 13.5497\n",
      "Epoch 280/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 16.6738\n",
      "Epoch 281/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 48.8576\n",
      "Epoch 282/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 24.5951\n",
      "Epoch 283/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 23.5207\n",
      "Epoch 284/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 35.5070\n",
      "Epoch 285/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 6.7015\n",
      "Epoch 286/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 19.5015\n",
      "Epoch 287/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 6.5810\n",
      "Epoch 288/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 662.8239\n",
      "Epoch 289/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 3626.4990\n",
      "Epoch 290/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 938.3051\n",
      "Epoch 291/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 749.5394\n",
      "Epoch 292/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 168.9768\n",
      "Epoch 293/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 73.4717\n",
      "Epoch 294/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 17.5854\n",
      "Epoch 295/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 44.7399\n",
      "Epoch 296/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "31/31 [==============================] - 0s 2ms/step - loss: 57.3058\n",
      "Epoch 297/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 270.9296\n",
      "Epoch 298/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 96.5005\n",
      "Epoch 299/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 529.9844\n",
      "Epoch 300/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 7362.4902\n",
      "Epoch 301/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 745.5800\n",
      "Epoch 302/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 145.8209\n",
      "Epoch 303/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 222.3454\n",
      "Epoch 304/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 93.1669\n",
      "Epoch 305/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 41.1919\n",
      "Epoch 306/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 11.7467\n",
      "Epoch 307/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 16.1872\n",
      "Epoch 308/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 82.8525\n",
      "Epoch 309/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 26.2736\n",
      "Epoch 310/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 14.8689\n",
      "Epoch 311/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 15.0488\n",
      "Epoch 312/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 112.6020\n",
      "Epoch 313/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 3059.2214\n",
      "Epoch 314/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 254.5825\n",
      "Epoch 315/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 194.6024\n",
      "Epoch 316/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 153.4053\n",
      "Epoch 317/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 25.5282\n",
      "Epoch 318/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 159.8905\n",
      "Epoch 319/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 556.3019\n",
      "Epoch 320/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 206.6920\n",
      "Epoch 321/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 256.4037\n",
      "Epoch 322/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 10359.2314\n",
      "Epoch 323/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 1781.2446\n",
      "Epoch 324/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 352.1808\n",
      "Epoch 325/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 93.3077\n",
      "Epoch 326/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 42.3040\n",
      "Epoch 327/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 35.1277\n",
      "Epoch 328/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 30.3845\n",
      "Epoch 329/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 61.1588\n",
      "Epoch 330/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 54.4882\n",
      "Epoch 331/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 48.4869\n",
      "Epoch 332/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 16.7832\n",
      "Epoch 333/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 45.0250\n",
      "Epoch 334/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 17.2136\n",
      "Epoch 335/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 39.4238\n",
      "Epoch 336/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 106.8626\n",
      "Epoch 337/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 1157.5436\n",
      "Epoch 338/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 437.4302\n",
      "Epoch 339/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 85.7992\n",
      "Epoch 340/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 387.1101\n",
      "Epoch 341/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 1064.5795\n",
      "Epoch 342/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 2650.6455\n",
      "Epoch 343/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 2662.6707\n",
      "Epoch 344/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 173.3622\n",
      "Epoch 345/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 212.0045\n",
      "Epoch 346/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 101.1886\n",
      "Epoch 347/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 27.1244\n",
      "Epoch 348/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 26.0897\n",
      "Epoch 349/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 84.2756\n",
      "Epoch 350/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 19.9046\n",
      "Epoch 351/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 16.1899\n",
      "Epoch 352/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 29.9991\n",
      "Epoch 353/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 27.3297\n",
      "Epoch 354/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 32.3427\n",
      "Epoch 355/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 1705.5662\n",
      "Epoch 356/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 629.3265\n",
      "Epoch 357/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 464.0641\n",
      "Epoch 358/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 90.6321\n",
      "Epoch 359/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 204.7883\n",
      "Epoch 360/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 399.2573\n",
      "Epoch 361/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 1915.1326\n",
      "Epoch 362/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 871.0245\n",
      "Epoch 363/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 84.3515\n",
      "Epoch 364/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 96.1818\n",
      "Epoch 365/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 211.0003\n",
      "Epoch 366/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 72.3337\n",
      "Epoch 367/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 528.1249\n",
      "Epoch 368/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 3349.6331\n",
      "Epoch 369/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 256.4557\n",
      "Epoch 370/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 145.1660\n",
      "Epoch 371/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 73.2144\n",
      "Epoch 372/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 84.3137\n",
      "Epoch 373/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 181.2995\n",
      "Epoch 374/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 66.1953\n",
      "Epoch 375/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 62.8950\n",
      "Epoch 376/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 55.4393\n",
      "Epoch 377/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 164.9682\n",
      "Epoch 378/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 6692.8496\n",
      "Epoch 379/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 1313.8291\n",
      "Epoch 380/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 191.8176\n",
      "Epoch 381/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 25.6126\n",
      "Epoch 382/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 16.3044\n",
      "Epoch 383/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 17.0590\n",
      "Epoch 384/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 33.3986\n",
      "Epoch 385/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 85.3069\n",
      "Epoch 386/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 24.1995\n",
      "Epoch 387/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 40.8344\n",
      "Epoch 388/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 39.2233\n",
      "Epoch 389/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 168.0421\n",
      "Epoch 390/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 30.5503\n",
      "Epoch 391/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 437.1317\n",
      "Epoch 392/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 430.7125\n",
      "Epoch 393/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 57.2942\n",
      "Epoch 394/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "31/31 [==============================] - 0s 2ms/step - loss: 40.9376\n",
      "Epoch 395/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 2116.2837\n",
      "Epoch 396/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 3152.4414\n",
      "Epoch 397/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 1898.2975\n",
      "Epoch 398/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 320.2913\n",
      "Epoch 399/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 523.8872\n",
      "Epoch 400/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 94.5734\n",
      "Epoch 401/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 17.3920\n",
      "Epoch 402/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 39.4817\n",
      "Epoch 403/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 105.3304\n",
      "Epoch 404/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 59.4194\n",
      "Epoch 405/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 44.6050\n",
      "Epoch 406/500\n",
      "31/31 [==============================] - 0s 3ms/step - loss: 39.9683\n",
      "Epoch 407/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 14.7052\n",
      "Epoch 408/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 5.4753\n",
      "Epoch 409/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 127.2395\n",
      "Epoch 410/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 25.0123\n",
      "Epoch 411/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 305.8991\n",
      "Epoch 412/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 2238.7095\n",
      "Epoch 413/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 474.4022\n",
      "Epoch 414/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 180.6148\n",
      "Epoch 415/500\n",
      "31/31 [==============================] - 0s 4ms/step - loss: 473.5470\n",
      "Epoch 416/500\n",
      "31/31 [==============================] - 0s 3ms/step - loss: 56.5951\n",
      "Epoch 417/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 50.1184\n",
      "Epoch 418/500\n",
      "31/31 [==============================] - 0s 4ms/step - loss: 93.0903\n",
      "Epoch 419/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 13.2241\n",
      "Epoch 420/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 3895.6785\n",
      "Epoch 421/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 58.2451\n",
      "Epoch 422/500\n",
      "31/31 [==============================] - 0s 4ms/step - loss: 13.2904\n",
      "Epoch 423/500\n",
      "31/31 [==============================] - 0s 3ms/step - loss: 11.5627\n",
      "Epoch 424/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 11.1758\n",
      "Epoch 425/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 4.3768\n",
      "Epoch 426/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 5.0727\n",
      "Epoch 427/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 3.3976\n",
      "Epoch 428/500\n",
      "31/31 [==============================] - 0s 3ms/step - loss: 31.4827\n",
      "Epoch 429/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 505.3726\n",
      "Epoch 430/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 240.1646\n",
      "Epoch 431/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 2287.4199\n",
      "Epoch 432/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 4712.1460\n",
      "Epoch 433/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 1171.1295\n",
      "Epoch 434/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 40.9893\n",
      "Epoch 435/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 14.4267\n",
      "Epoch 436/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 4.6413\n",
      "Epoch 437/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 4.0389\n",
      "Epoch 438/500\n",
      "31/31 [==============================] - 0s 3ms/step - loss: 4.9080\n",
      "Epoch 439/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 3.9855\n",
      "Epoch 440/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 3.4257\n",
      "Epoch 441/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 5.5630\n",
      "Epoch 442/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 7.1136\n",
      "Epoch 443/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 8.3208\n",
      "Epoch 444/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 4.1460\n",
      "Epoch 445/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 7.2270\n",
      "Epoch 446/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 4.1115\n",
      "Epoch 447/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 881.3264\n",
      "Epoch 448/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 876.9453\n",
      "Epoch 449/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 346.7725\n",
      "Epoch 450/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 531.6672\n",
      "Epoch 451/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 139.4343\n",
      "Epoch 452/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 153.6859\n",
      "Epoch 453/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 232.5061\n",
      "Epoch 454/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 3323.4365\n",
      "Epoch 455/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 1220.1698\n",
      "Epoch 456/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 945.6548\n",
      "Epoch 457/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 186.2157\n",
      "Epoch 458/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 22.5672\n",
      "Epoch 459/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 4.3050\n",
      "Epoch 460/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 3.2764\n",
      "Epoch 461/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 2.2828\n",
      "Epoch 462/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 1.6762\n",
      "Epoch 463/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 4.7546\n",
      "Epoch 464/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 4.5526\n",
      "Epoch 465/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 22.7749\n",
      "Epoch 466/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 59.4080\n",
      "Epoch 467/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 4.4679\n",
      "Epoch 468/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 7.4751\n",
      "Epoch 469/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 61.0052\n",
      "Epoch 470/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 7115.1445\n",
      "Epoch 471/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 1402.2913\n",
      "Epoch 472/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 236.3906\n",
      "Epoch 473/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 87.0182\n",
      "Epoch 474/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 9.4842\n",
      "Epoch 475/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 5.6059\n",
      "Epoch 476/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 5.0654\n",
      "Epoch 477/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 5.1208\n",
      "Epoch 478/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 3.9211\n",
      "Epoch 479/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 3.6629\n",
      "Epoch 480/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 3.1605\n",
      "Epoch 481/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 2.9520\n",
      "Epoch 482/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 3.1459\n",
      "Epoch 483/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 9.2881\n",
      "Epoch 484/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 40.1792\n",
      "Epoch 485/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 6689.4600\n",
      "Epoch 486/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 1629.9241\n",
      "Epoch 487/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 491.4200\n",
      "Epoch 488/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 63.6608\n",
      "Epoch 489/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 11.5398\n",
      "Epoch 490/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 12.0258\n",
      "Epoch 491/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 10.7328\n",
      "Epoch 492/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "31/31 [==============================] - 0s 2ms/step - loss: 3.4556\n",
      "Epoch 493/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 2.8802\n",
      "Epoch 494/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 3.6484\n",
      "Epoch 495/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 4.3272\n",
      "Epoch 496/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 2.8891\n",
      "Epoch 497/500\n",
      "31/31 [==============================] - 0s 2ms/step - loss: 2.5087\n",
      "Epoch 498/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 2.6308\n",
      "Epoch 499/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 3.0828\n",
      "Epoch 500/500\n",
      "31/31 [==============================] - 0s 1ms/step - loss: 7.4051\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<keras.callbacks.History at 0x1701476d0>"
      ]
     },
     "execution_count": 47,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.fit(X_train, y_train, batch_size=1000, epochs=500)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "45dff614",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "320/320 [==============================] - 0s 722us/step\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "7.180107071724819"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mean_squared_error(y_test,model.predict(X_test))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f4c2e757",
   "metadata": {},
   "source": [
    "### Deep evidential model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 310,
   "id": "2190b1d3",
   "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",
    "        dense_layers.DenseNormalGamma(1),\n",
    "    ])\n",
    "\n",
    "def EvidentialRegressionLoss(true, pred):\n",
    "        return dense_loss.EvidentialRegression(true, pred, coeff=1e-3)\n",
    "\n",
    "# Compile and fit the model!\n",
    "edl_model.compile(\n",
    "    optimizer=tf.keras.optimizers.Adam(5e-5),\n",
    "    loss=EvidentialRegressionLoss)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 311,
   "id": "b2e6bfe1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "False"
      ]
     },
     "execution_count": 311,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.any(np.isnan(X_train.values))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 312,
   "id": "0be60f8a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(30672, 43)"
      ]
     },
     "execution_count": 312,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_train.values[:,:].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 313,
   "id": "d0139968",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/100\n",
      "Tensor(\"EvidentialRegressionLoss/split:0\", shape=(None, 1), dtype=float32) Tensor(\"EvidentialRegressionLoss/split:1\", shape=(None, 1), dtype=float32) Tensor(\"EvidentialRegressionLoss/split:2\", shape=(None, 1), dtype=float32) Tensor(\"EvidentialRegressionLoss/split:3\", shape=(None, 1), dtype=float32)\n",
      "Tensor(\"EvidentialRegressionLoss/split:0\", shape=(None, 1), dtype=float32) Tensor(\"EvidentialRegressionLoss/split:1\", shape=(None, 1), dtype=float32) Tensor(\"EvidentialRegressionLoss/split:2\", shape=(None, 1), dtype=float32) Tensor(\"EvidentialRegressionLoss/split:3\", shape=(None, 1), dtype=float32)\n",
      "31/31 [==============================] - 1s 4ms/step - loss: 4.4600\n",
      "Epoch 2/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: 2.3839\n",
      "Epoch 3/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: 2.0630\n",
      "Epoch 4/100\n",
      "31/31 [==============================] - 0s 3ms/step - loss: 1.9283\n",
      "Epoch 5/100\n",
      "31/31 [==============================] - 0s 3ms/step - loss: 1.8193\n",
      "Epoch 6/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: 1.7214\n",
      "Epoch 7/100\n",
      "31/31 [==============================] - 0s 3ms/step - loss: 1.6161\n",
      "Epoch 8/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: 1.5193\n",
      "Epoch 9/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: 1.4183\n",
      "Epoch 10/100\n",
      "31/31 [==============================] - 0s 3ms/step - loss: 1.3024\n",
      "Epoch 11/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: 1.2261\n",
      "Epoch 12/100\n",
      "31/31 [==============================] - 0s 6ms/step - loss: 1.1345\n",
      "Epoch 13/100\n",
      "31/31 [==============================] - 0s 5ms/step - loss: 1.0403\n",
      "Epoch 14/100\n",
      "31/31 [==============================] - 0s 5ms/step - loss: 0.9521\n",
      "Epoch 15/100\n",
      "31/31 [==============================] - 0s 5ms/step - loss: 0.8551\n",
      "Epoch 16/100\n",
      "31/31 [==============================] - 0s 8ms/step - loss: 0.7781\n",
      "Epoch 17/100\n",
      "31/31 [==============================] - 0s 6ms/step - loss: 0.6913\n",
      "Epoch 18/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: 0.6097\n",
      "Epoch 19/100\n",
      "31/31 [==============================] - 0s 5ms/step - loss: 0.5300\n",
      "Epoch 20/100\n",
      "31/31 [==============================] - 0s 7ms/step - loss: 0.4527\n",
      "Epoch 21/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: 0.3767\n",
      "Epoch 22/100\n",
      "31/31 [==============================] - 0s 5ms/step - loss: 0.3032\n",
      "Epoch 23/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: 0.2205\n",
      "Epoch 24/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: 0.1291\n",
      "Epoch 25/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: 0.0657\n",
      "Epoch 26/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.0313\n",
      "Epoch 27/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.1008\n",
      "Epoch 28/100\n",
      "31/31 [==============================] - 0s 3ms/step - loss: -0.1723\n",
      "Epoch 29/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.2294\n",
      "Epoch 30/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.3083\n",
      "Epoch 31/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.3590\n",
      "Epoch 32/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.4159\n",
      "Epoch 33/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.4518\n",
      "Epoch 34/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.5098\n",
      "Epoch 35/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.5323\n",
      "Epoch 36/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.5633\n",
      "Epoch 37/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.5923\n",
      "Epoch 38/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.6165\n",
      "Epoch 39/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.6043\n",
      "Epoch 40/100\n",
      "31/31 [==============================] - 0s 3ms/step - loss: -0.6327\n",
      "Epoch 41/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.6444\n",
      "Epoch 42/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.6500\n",
      "Epoch 43/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.6622\n",
      "Epoch 44/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.6775\n",
      "Epoch 45/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.6644\n",
      "Epoch 46/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.6904\n",
      "Epoch 47/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.6828\n",
      "Epoch 48/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.7025\n",
      "Epoch 49/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.6991\n",
      "Epoch 50/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.7145\n",
      "Epoch 51/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.7231\n",
      "Epoch 52/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.7056\n",
      "Epoch 53/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.7253\n",
      "Epoch 54/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.7427\n",
      "Epoch 55/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.7495\n",
      "Epoch 56/100\n",
      "31/31 [==============================] - 0s 5ms/step - loss: -0.7421\n",
      "Epoch 57/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.7490\n",
      "Epoch 58/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.7479\n",
      "Epoch 59/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.7535\n",
      "Epoch 60/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.7632\n",
      "Epoch 61/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.7664\n",
      "Epoch 62/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.7720\n",
      "Epoch 63/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.7676\n",
      "Epoch 64/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.7715\n",
      "Epoch 65/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.7906\n",
      "Epoch 66/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.7783\n",
      "Epoch 67/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.7914\n",
      "Epoch 68/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.7946\n",
      "Epoch 69/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8000\n",
      "Epoch 70/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8011\n",
      "Epoch 71/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.7979\n",
      "Epoch 72/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8028\n",
      "Epoch 73/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8000\n",
      "Epoch 74/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8178\n",
      "Epoch 75/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8202\n",
      "Epoch 76/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8118\n",
      "Epoch 77/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8268\n",
      "Epoch 78/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8200\n",
      "Epoch 79/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8141\n",
      "Epoch 80/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8268\n",
      "Epoch 81/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8307\n",
      "Epoch 82/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8307\n",
      "Epoch 83/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8327\n",
      "Epoch 84/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8407\n",
      "Epoch 85/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8458\n",
      "Epoch 86/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8279\n",
      "Epoch 87/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8432\n",
      "Epoch 88/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8387\n",
      "Epoch 89/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8464\n",
      "Epoch 90/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8377\n",
      "Epoch 91/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8454\n",
      "Epoch 92/100\n",
      "31/31 [==============================] - 0s 5ms/step - loss: -0.8458\n",
      "Epoch 93/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8566\n",
      "Epoch 94/100\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8520\n",
      "Epoch 95/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8585\n",
      "Epoch 96/100\n",
      "31/31 [==============================] - 0s 4ms/step - loss: -0.8645\n",
      "Epoch 97/100\n",
      "31/31 [==============================] - 0s 6ms/step - loss: -0.8502\n",
      "Epoch 98/100\n",
      "31/31 [==============================] - 0s 6ms/step - loss: -0.8664\n",
      "Epoch 99/100\n",
      "31/31 [==============================] - 0s 5ms/step - loss: -0.8607\n",
      "Epoch 100/100\n",
      "31/31 [==============================] - 0s 5ms/step - loss: -0.8673\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<keras.callbacks.History at 0x176db61c0>"
      ]
     },
     "execution_count": 313,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "edl_model.fit(X_train.values[:,:43], y_train.values[:], batch_size=1000, epochs=100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 330,
   "id": "a235f910",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "320/320 [==============================] - 0s 737us/step\n"
     ]
    }
   ],
   "source": [
    "y_pred = edl_model.predict(X_test.values[:,:])\n",
    "mu, v, alpha, beta = y_pred[:,0],y_pred[:,1],y_pred[:,2],y_pred[:,3]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 331,
   "id": "7784845e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.008341871227287755"
      ]
     },
     "execution_count": 331,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mean_squared_error(y_test,mu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 332,
   "id": "12a0a6be",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x1781321f0>"
      ]
     },
     "execution_count": 332,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(X_test[\"dti\"],y_test,label=\"true\")\n",
    "plt.scatter(X_test[\"dti\"],mu,label=\"$\\mu$\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 338,
   "id": "b36b1f92",
   "metadata": {},
   "outputs": [],
   "source": [
    "var = np.sqrt(beta / (v * (alpha - 1)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 337,
   "id": "e75434ae",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([  0.17817199,   0.35634156,   0.        ,   0.71268311,\n",
       "          0.89085994,   0.35634398,   2.4943909 ,   2.13806385,\n",
       "          1.78170779,   4.09795572,   5.52333162,   5.34512336,\n",
       "          6.94870752,   7.4831727 ,   9.79945932,  12.82838311,\n",
       "         15.50085774,  15.67913491,  24.23122588,  25.65676622,\n",
       "         29.39837796,  34.9214726 ,  46.32471679,  53.27306279,\n",
       "         61.29116375,  72.69417096,  92.11429252, 101.37986097,\n",
       "        118.66173852, 139.50866633, 146.81371782, 138.08235339,\n",
       "        139.50866633, 125.43222811, 110.28846036,  92.11491762,\n",
       "         72.51550688,  48.10643667,  30.46720313,  14.96644696,\n",
       "          7.12687951,   3.20707401,   0.17817199,   0.        ,\n",
       "          0.        ,   0.17817199,   0.35634398,   0.        ,\n",
       "          0.17817199,   0.53451596]),\n",
       " array([0.03678579, 0.03733475, 0.03788371, 0.03843267, 0.03898163,\n",
       "        0.03953059, 0.04007955, 0.04062851, 0.04117747, 0.04172643,\n",
       "        0.04227539, 0.04282435, 0.04337331, 0.04392227, 0.04447123,\n",
       "        0.04502019, 0.04556915, 0.04611811, 0.04666707, 0.04721604,\n",
       "        0.04776499, 0.04831395, 0.04886292, 0.04941187, 0.04996084,\n",
       "        0.0505098 , 0.05105875, 0.05160772, 0.05215668, 0.05270564,\n",
       "        0.0532546 , 0.05380356, 0.05435252, 0.05490148, 0.05545044,\n",
       "        0.0559994 , 0.05654836, 0.05709732, 0.05764628, 0.05819524,\n",
       "        0.0587442 , 0.05929316, 0.05984212, 0.06039108, 0.06094004,\n",
       "        0.061489  , 0.06203796, 0.06258692, 0.06313588, 0.06368484,\n",
       "        0.0642338 ]),\n",
       " <BarContainer object of 50 artists>)"
      ]
     },
     "execution_count": 337,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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4fBPwQACjhkWAKZy6NAh/exnP1NBQYEsFotPfQ3DaLNPbm6uYmNj3UtiYuL1lgugkzDDAsBUPvzwQ9XU1Khv377ubY2NjXrhhReUl5enU6dOyWazqaGhQefOnfOYZampqVFycrLXY2dmZiojI8O97nA4CC1Q/yW7r7vPqVce8NIS/sIMCwBTmTVrln7/+9+rvLzcvdjtdv3gBz/Q+++/L0kaNWqUIiMjVVRU5O5XVVWlo0ePthlYrFarYmJiPBYAoYEZFgCdrq6uTidPnnSvV1RUqLy8XHFxcerbt6969erl0T4yMlI2m0233367JCk2NlZPPfWUXnjhBfXq1UtxcXFatGiRhg8f7v7UEIDwQmAB0OnKyso0adIk93rzbZo5c+aooKCgQ8dYvXq1IiIiNGPGDF28eFGTJ09WQUGBunbtGoiScYO7lttG8C8CC4BOl5KSIsMwOtz+1KlTLbZ1795da9eu1dq1a/1YGQCz4hkWAABgegQWAABgegQWAABgegQWAABgegQWAABgegQWAABgegQWAABgegQWAABgegQWAABgegQWAABgegQWAABgegQWAABgegQWAABgegQWAABgegQWAABgegQWAABgej4HltLSUk2dOlV2u10Wi0U7d+702G+xWFpdfvKTn3g9ZkFBQat9Ll265PMJAQCA8ONzYLlw4YJGjBih/Pz8VvdXVVV5LG+++aYsFoseffTRNo8bExPTom/37t19LQ8AAIShCF87pKenKz093et+m83msf7ee+9p0qRJGjhwYJvHtVgsLfoCAABI1xBYfPGXv/xFu3fv1qZNm9ptW1dXp379+qmxsVF33nmnXnrpJY0cOdJre6fTKafT6V53OBySJJfLJZfL5bVf8z5rF6PFNviueewYQ/8I5fEMxZoBhI6ABpZNmzYpOjpa06ZNa7Pd4MGDVVBQoOHDh8vhcOhnP/uZxo8fr48//lhJSUmt9snNzVV2dnaL7YWFhYqKimq3tpdGN7n/vGfPnnbbo21FRUXBLiGshOJ41tfXB7sEAGEsoIHlzTff1BNPPNHusyhjx47V2LFj3evjx4/XXXfdpbVr12rNmjWt9snMzFRGRoZ73eFwKDExUWlpaYqJifH6s1wul4qKirS8rIucTRZJ0tGsKb6cFr6meTxTU1MVGRkZ7HJCXiiPZ/MsJwAEQsACy4cffqjj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woQJWrFihR5++GG999572rt3r/bt2+eHUwQAAKHO58BSVlamSZMmudebnyOZM2eO1q1bpz/84Q9666239NVXXykhIUGTJk3Stm3bFB0d7e5TWVmpLl3+PrmTnJysrVu3atmyZVq+fLkGDRqkbdu2acyYMddzbgAAIEz4HFhSUlJkGIbX/e+//367xyguLm6xbfr06Zo+fbqv5QAAgBsA7xICAACmR2ABAACmR2ABAACmR2ABAACmR2ABAACmR2ABAACmR2ABAACmR2ABAACmR2ABAACmR2ABAACmR2ABAACmR2ABAACmR2ABAACmR2ABAACmR2AB0OlKS0s1depU2e12WSwW7dy502O/YRjKysqS3W5Xjx49lJKSomPHjnm0cTqdeu6559S7d2/17NlTDz30kD7//PNOPAsAnYnAAqDTXbhwQSNGjFB+fn6r+1euXKlVq1YpPz9fBw8elM1mU2pqqs6fP+9us2DBAu3YsUNbt27Vvn37VFdXpwcffFCNjY2ddRoIEf2X7PZYEJoigl0AgBtPenq60tPTW91nGIby8vK0dOlSTZs2TZK0adMmxcfHa8uWLZo7d65qa2u1YcMGvf3227rvvvskSZs3b1ZiYqL27t2rKVOmdNq5AOgczLAAMJWKigpVV1crLS3Nvc1qtWrixInav3+/JOnQoUNyuVwebex2u4YNG+ZuAyC8MMMCwFSqq6slSfHx8R7b4+Pjdfr0aXebbt266eabb27Rprl/a5xOp5xOp3vd4XD4q2wAAcYMCwBTslgsHuuGYbTYdrX22uTm5io2Nta9JCYm+qVWAIFHYAFgKjabTZJazJTU1NS4Z11sNpsaGhp07tw5r21ak5mZqdraWvdy5swZP1cPIFAILABMZcCAAbLZbCoqKnJva2hoUElJiZKTkyVJo0aNUmRkpEebqqoqHT161N2mNVarVTExMR4LgNDAMywAOl1dXZ1OnjzpXq+oqFB5ebni4uLUt29fLViwQDk5OUpKSlJSUpJycnIUFRWlmTNnSpJiY2P11FNP6YUXXlCvXr0UFxenRYsWafjw4e5PDQEILwQWAJ2urKxMkyZNcq9nZGRIkubMmaOCggItXrxYFy9e1Lx583Tu3DmNGTNGhYWFio6OdvdZvXq1IiIiNGPGDF28eFGTJ09WQUGBunbt2unnAyDwCCwAOl1KSooMw/C6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7NmzamxsVHx8vMf2+Ph4VVdXt9qnurq61faXL1/W2bNnlZCQ0KJPbm6usrOzW2wfMGDAdVR/Y+v902BXgHBw/vx5xcbGdsrP8vV64+26kZiY6Jd6YvP8chjAL/z9++jr8Xxt3961I2CfErJYPGcvDMNosa299q1tb5aZmamMjAz3elNTk/72t7+pV69ebf4ch8OhxMREnTlzRjExMe2eB9rGePpXKI+nYRg6f/687HZ7p//sjl5vrvW60RlC+b99Z2KcOi5Uxqqj1w6/B5bevXura9euLf51U1NT0+JfQc1sNlur7SMiItSrV69W+1itVlmtVo9tN910U4frjImJMfV/wFDDePpXqI5nZ82sNPP1enO9143OEKr/7Tsb49RxoTBWHbl2+P1TQt26ddOoUaNUVFTksb2oqEjJycmt9hk3blyL9oWFhRo9enTI3ccH0Hmu5XoDIDQF5GPNGRkZ+sUvfqE333xTn376qRYuXKjKyko988wzkq5My86ePdvd/plnntHp06eVkZGhTz/9VG+++aY2bNigRYsWBaI8AGGkvesNgPAQkGdYHn/8cf31r3/Viy++qKqqKg0bNkx79uxRv379JElVVVUe35EwYMAA7dmzRwsXLtRrr70mu92uNWvWBOQjzVarVf/xH//RYloY14bx9C/G03ftXW9CBf/tO4Zx6rhwGyuL0ZmfQQQAALgGAftqfgAAAH8hsAAAANMjsAAAANMjsAAAANMLy8Di66vmS0pKNGrUKHXv3l0DBw7U66+/3kmVhgZfxrO4uFgWi6XF8sc//rETKzan0tJSTZ06VXa7XRaLRTt37my3D7+boSuQ16GtW7fKYrHokUce8XPVweHvsSooKGj1OnTp0qVAnkbABeJ36quvvtL8+fOVkJCg7t2764477tCePXsCdQrXxwgzW7duNSIjI4033njD+OSTT4znn3/e6Nmzp3H69OlW2//5z382oqKijOeff9745JNPjDfeeMOIjIw0fvnLX3Zy5ebk63h+8MEHhiTj+PHjRlVVlXu5fPlyJ1duPnv27DGWLl1qbN++3ZBk7Nixo832/G6GrkBeh06dOmXceuutxje/+U3j4YcfDvCZBF4gxmrjxo1GTEyMxzWoqqqqs04pIAIxTk6n0xg9erRx//33G/v27TNOnTplfPjhh0Z5eXlnnZZPwi6w3HPPPcYzzzzjsW3w4MHGkiVLWm2/ePFiY/DgwR7b5s6da4wdOzZgNYYSX8ezObCcO3euE6oLXR0JLPxuhq5AXYcuX75sjB8/3vjFL35hzJkzJywCSyDGauPGjUZsbKzfaw2mQIzTunXrjIEDBxoNDQ3+LzgAwuqWUPOr5tPS0jy2e3vVvCQdOHCgRfspU6aorKxMLpcrYLWGgmsZz2YjR45UQkKCJk+erA8++CCQZYYtfjdDUyCvQy+++KJuueUWPfXUU/4vPAgCOVZ1dXXq16+fbrvtNj344IM6cuSI/0+gkwRqnHbt2qVx48Zp/vz5io+P17Bhw5STk6PGxsbAnMh1CqvA4uur5iWpurq61faXL1/W2bNnA1ZrKLiW8UxISND69eu1fft2vfvuu7r99ts1efJklZaWdkbJYYXfzdAUqOvQb3/7W23YsEFvvPFGYAoPgkCN1eDBg1VQUKBdu3bpnXfeUffu3TV+/HidOHEiMCcSYIEapz//+c/65S9/qcbGRu3Zs0fLli3TT3/6U7388suBOZHrFJCv5g+2jr5qvq32rW2/Ufkynrfffrtuv/129/q4ceN05swZvfrqq5owYUJA6wxH/G6GLn9eh86fP6/vfOc7euONN9S7d2//Fxtk/r5mjx07VmPHjnXvHz9+vO666y6tXbtWa9as8VfZnc7f49TU1KQ+ffpo/fr16tq1q0aNGqUvv/xSP/nJT/Tv//7vfq7++oVVYPH1VfOSZLPZWm0fERGhXr16BazWUHAt49masWPHavPmzf4uL+zxuxmaAnEdOnbsmE6dOqWpU6e69zc1NUmSIiIidPz4cQ0aNMjPZxJ4nXXN7tKli+6+++6QnWEJ1DglJCQoMjJSXbt2dbe54447VF1drYaGBnXr1s3PZ3J9wuqW0LW8an7cuHEt2hcWFmr06NGKjIwMWK2h4FrGszVHjhxRQkKCv8sLe/xuhqZAXIcGDx6sP/zhDyovL3cvDz30kCZNmqTy8nIlJiYG7HwCqbOu2YZhqLy8PGSvQ4Eap/Hjx+vkyZPu8CtJn332mRISEkwXViSF78eaN2zYYHzyySfGggULjJ49exqnTp0yDMMwlixZYsyaNcvdvvmjXwsXLjQ++eQTY8OGDXx09Gt8Hc/Vq1cbO3bsMD777DPj6NGjxpIlSwxJxvbt24N1CqZx/vx548iRI8aRI0cMScaqVauMI0eOuD+WyO9m+OiM61C4fEooEGOVlZVl/PrXvzb+9Kc/GUeOHDH+9V//1YiIiDA++uijTj8/fwnEOFVWVhr/8A//YDz77LPG8ePHjV/96ldGnz59jB//+Medfn4dEXaBxTAM47XXXjP69etndOvWzbjrrruMkpIS9745c+YYEydO9GhfXFxsjBw50ujWrZvRv39/Y926dZ1csbn5Mp4rVqwwBg0aZHTv3t24+eabjXvvvdfYvXt3EKo2n+aPfF+9zJkzxzAMfjfDTaCvQ+ESWAzD/2O1YMECo2/fvka3bt2MW265xUhLSzP279/fGacSUIH4ndq/f78xZswYw2q1GgMHDjRefvll035vlsUw/v+ncAAAAEwqrJ5hAQAA4YnAAgAATI/AAgAATI/AAgAATI/AAgAATI/AAgAATI/AAgAATI/AAgAATI/AAgAATI/AAgAATI/AAgAATI/AAgAATO//A+EShVN2puWcAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.subplot(121)\n",
    "df_clean[\"recovery_rate\"].hist(bins=50,density=True)\n",
    "plt.subplot(122)\n",
    "plt.hist(mu,bins=50,density=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 344,
   "id": "7a342153",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "320/320 [==============================] - 0s 755us/step\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "array([ 0.05603308, 13.668682  , 15.863758  ,  0.33370343], dtype=float32)"
      ]
     },
     "execution_count": 344,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "edl_model.predict(X_test.values[:,:])[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 352,
   "id": "47c572e4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<tf.Tensor: shape=(), dtype=float32, numpy=1.5244192>"
      ]
     },
     "execution_count": 352,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "edl.dense_loss.NIG_NLL(0.123010,1.0,2.0,3.0,4.0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 349,
   "id": "6d080689",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "member_id\n",
       "6992858     0.123010\n",
       "7689310     0.000000\n",
       "5777816     0.091326\n",
       "21288088    0.000000\n",
       "19776195    0.000000\n",
       "              ...   \n",
       "5227627     0.109019\n",
       "37286818    0.000000\n",
       "10311199    0.139656\n",
       "8178973     0.115050\n",
       "674338      0.020051\n",
       "Name: recovery_rate, Length: 10224, dtype: float64"
      ]
     },
     "execution_count": 349,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_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
}
