{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "af23284d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "\n",
    "from scipy import stats as sc_stats\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.metrics import mean_squared_error\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "186f4491",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2023-04-25 11:05:15.168906: I tensorflow/core/platform/cpu_feature_guard.cc:193] This TensorFlow binary is optimized with oneAPI Deep Neural Network Library (oneDNN) to use the following CPU instructions in performance-critical operations:  SSE4.1 SSE4.2 AVX AVX2 FMA\n",
      "To enable them in other operations, rebuild TensorFlow with the appropriate compiler flags.\n"
     ]
    }
   ],
   "source": [
    "import tensorflow as tf"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "c743a4bb",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "from os.path import dirname\n",
    "sys.path.append(dirname(\"../\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "dd89bbc6",
   "metadata": {},
   "outputs": [],
   "source": [
    "from src.edl import dense_layers,dense_loss\n",
    "from src.weibull_edl import loss_and_layers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "4af3f469",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "351f8840",
   "metadata": {},
   "source": [
    "### Read data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "255b0784",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/kb/v0p0ypbd0wx1q2qb1kpxmmcc0000gn/T/ipykernel_16477/337633262.py:4: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df_clean1[\"recovery_rate_ad\"] = np.where(df_clean1[\"recovery_rate\"]<=0.8,df_clean1[\"recovery_rate\"],0.8)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1.2867963559278057, -0.0018208449989562774, 0.1174991468898883)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x169502b80>"
      ]
     },
     "execution_count": 10,
     "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": [
    "df_clean = pd.read_csv(\"../data/data_preprocessed_v0.csv\",index_col=0)\n",
    "df_clean[\"ccf_ad\"] = (1.0-df_clean[\"CCF\"])*100\n",
    "df_clean1 = df_clean[df_clean.recovery_rate>0.0]\n",
    "df_clean1[\"recovery_rate_ad\"] = np.where(df_clean1[\"recovery_rate\"]<=0.8,df_clean1[\"recovery_rate\"],0.8)\n",
    "# df_clean.head()\n",
    "\n",
    "y_cols = [\"recovery_rate\",\"CCF\"]\n",
    "\n",
    "X = df_clean1.drop(columns=y_cols + list(df_clean1.columns)[35:39])\n",
    "y = df_clean1[\"recovery_rate_ad\"] * 1.0\n",
    "\n",
    "rv = sc_stats.weibull_min.fit(y)\n",
    "print (rv)\n",
    "plt.hist(y,alpha=0.5,density=True,bins=30,label=\"Histogram of y\")\n",
    "plt.scatter(y, sc_stats.weibull_min.pdf(y,*rv),label=\"Fitted Weibull\",color=\"black\")\n",
    "plt.title(\"y\")\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "d53261a3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(23300, 45) (23300,)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "((18640, 45), (4660, 45), (18640,), (4660,))"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y=y-(-0)\n",
    "print(X.shape,y.shape)\n",
    "\n",
    "x_train, x_test, y_train, y_test = train_test_split(X, y, test_size=0.2)\n",
    "x_train.shape,x_test.shape,y_train.shape,y_test.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "a1193fa4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1.2867963559278057, -0.0018208449989562774, 0.1174991468898883)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x169502e50>"
      ]
     },
     "execution_count": 12,
     "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": [
    "rv = sc_stats.weibull_min.fit(y)\n",
    "print (rv)\n",
    "plt.hist(y_train,alpha=0.5,density=True,bins=30,label=\"Histogram of y\")\n",
    "plt.scatter(y_train, sc_stats.weibull_min.pdf(y_train,*rv),label=\"Fitted Weibull\",color=\"black\")\n",
    "plt.title(\"y-train\")\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "cb345eb4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Distribution of y')"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAhYAAAGxCAYAAAA+tv8YAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAArmUlEQVR4nO3de1xVdb7/8fcWZHMJUCkVB8RbanlJ0/JWebdjlt1suulDK5uczOvDmaRmvDVFZqY1qWnHsDLNcqScnGzw5HXCjteTZgctSbEwixJMchvw/f0xh/1zByhr893Aptfz8ViPh3vxXd/1+bBF3q7bdhljjAAAACyoU90FAACA2oNgAQAArCFYAAAAawgWAADAGoIFAACwhmABAACsIVgAAABrCBYAAMAaggUAALCGYAFYsmzZMrlcLu8SHh6uxo0bq2/fvkpJSdGJEydKbTNjxgy5XC5H+ykoKNCMGTO0adMmR9uVta9mzZrpxhtvdDTPhaxYsULz588v82sul0szZsywuj/b/uu//ktdu3ZVVFSUXC6X3nnnneouCQgqodVdAFDbpKamqm3btvr555914sQJbdu2TbNnz9azzz6rVatWacCAAd6xo0eP1n/8x384mr+goEAzZ86UJPXp06fC2/mzL3+sWLFC+/fv18SJE0t9LSMjQwkJCQGvwV/GGP32t79V69attXbtWkVFRalNmzbVXRYQVAgWgGXt27dX165dva9vv/12TZo0Sddcc41uu+02HTp0SI0aNZIkJSQkBPwXbUFBgSIjI6tkXxfSvXv3at3/hXz99df6/vvvdeutt6p///7VXQ4QlDgVAlSBpk2bau7cuTp16pQWL17sXV/W6YkPP/xQffr0UVxcnCIiItS0aVPdfvvtKigo0JdffqlLLrlEkjRz5kzvaZdRo0b5zLd7924NGzZM9evXV8uWLcvdV4m0tDR17NhR4eHhatGihV544QWfr5ec5vnyyy991m/atEkul8t7WqZPnz5at26djhw54nNaqERZp0L279+vm2++WfXr11d4eLg6deqkV199tcz9rFy5Uo8//riaNGmimJgYDRgwQJmZmeV/48+xbds29e/fX9HR0YqMjFTPnj21bt0679dnzJjhDV6PPvqoXC6XmjVrVuZcP/74o+rVq6eHHnqo1Ne+/PJLhYSEaM6cORWqC6htCBZAFbnhhhsUEhKiLVu2lDvmyy+/1JAhQxQWFqZXXnlF69ev19NPP62oqCidPXtW8fHxWr9+vSTpgQceUEZGhjIyMvTnP//ZZ57bbrtNrVq10ttvv62XXnrpvHXt3btXEydO1KRJk5SWlqaePXtqwoQJevbZZx33uHDhQvXq1UuNGzf21paRkVHu+MzMTPXs2VOffvqpXnjhBa1Zs0aXX365Ro0apWeeeabU+Mcee0xHjhzRf/7nf2rJkiU6dOiQbrrpJhUVFZ23rs2bN6tfv37Ky8vT0qVLtXLlSkVHR+umm27SqlWrJP37VNGaNWskSePGjVNGRobS0tLKnO+iiy7S/fffrzfeeEN5eXmlvgdhYWG6//77z1sTUGsZAFakpqYaSWbHjh3ljmnUqJG57LLLvK+nT59uzv0xXL16tZFk9u7dW+4c3377rZFkpk+fXuprJfNNmzat3K+dKykpybhcrlL7GzhwoImJiTGnT5/26S0rK8tn3MaNG40ks3HjRu+6IUOGmKSkpDJr/2Xdd911l3G73ebo0aM+4wYPHmwiIyPNyZMnffZzww03+Ix76623jCSTkZFR5v5KdO/e3TRs2NCcOnXKu66wsNC0b9/eJCQkmOLiYmOMMVlZWUaSmTNnznnnM8aYL774wtSpU8fMmzfPu+6nn34ycXFx5r777rvg9kBtxRELoAoZY8779U6dOiksLEy/+93v9Oqrr+rw4cN+7ef222+v8Nh27drpiiuu8Fl3zz33KD8/X7t37/Zr/xX14Ycfqn///kpMTPRZP2rUKBUUFJQ62jF06FCf1x07dpQkHTlypNx9nD59Wh9//LGGDRumiy66yLs+JCREI0aM0LFjxyp8OuVcLVq00I033qiFCxd639cVK1YoNzdXjzzyiOP5gNqCYAFUkdOnTys3N1dNmjQpd0zLli21YcMGNWzYUGPHjlXLli3VsmVLPf/88472FR8fX+GxjRs3Lnddbm6uo/06lZubW2atJd+jX+4/Li7O57Xb7ZYk/fTTT+Xu44cffpAxxtF+KmrChAk6dOiQ0tPTJUkLFixQjx49dOWVV/o1H1AbcFcIUEXWrVunoqKiC94ieu211+raa69VUVGRdu7cqb/+9a+aOHGiGjVqpLvuuqtC+3LybIzjx4+Xu67kF3l4eLgkyePx+Iz77rvvKryfssTFxSknJ6fU+q+//lqSdPHFF1dqfkmqX7++6tSpE5D99OvXT+3bt9eLL76oiy66SLt379by5csrVS8Q7DhiAVSBo0ePasqUKYqNjS3zToKyhISEqFu3blqwYIEkeU9LVOR/6U58+umn+p//+R+fdStWrFB0dLT3f94ld0d88sknPuPWrl1baj63213h2vr3768PP/zQ+wu+xGuvvabIyEgrt6dGRUWpW7duWrNmjU9dxcXFWr58uRISEtS6dWu/5x8/frzWrVun5ORkNWrUSHfccUelawaCGUcsAMv279+vwsJCFRYW6sSJE9q6datSU1MVEhKitLQ07+2iZXnppZf04YcfasiQIWratKnOnDmjV155RZK8D9aKjo5WUlKS3n33XfXv318NGjTQxRdfXO6tkRfSpEkTDR06VDNmzFB8fLyWL1+u9PR0zZ49W5GRkZKkq666Sm3atNGUKVNUWFio+vXrKy0tTdu2bSs1X4cOHbRmzRotWrRIXbp0UZ06dXye63Gu6dOn67333lPfvn01bdo0NWjQQG+88YbWrVunZ555RrGxsX719EspKSkaOHCg+vbtqylTpigsLEwLFy7U/v37tXLlSsdPPz3X8OHDlZycrC1btuhPf/qTwsLCrNQMBK1qvngUqDVK7pwoWcLCwkzDhg1N7969zVNPPWVOnDhRaptf3qmRkZFhbr31VpOUlGTcbreJi4szvXv3NmvXrvXZbsOGDaZz587G7XYbSWbkyJE+83377bcX3Jcx/74rZMiQIWb16tWmXbt2JiwszDRr1sw899xzpbY/ePCgGTRokImJiTGXXHKJGTdunFm3bl2pu0K+//57M2zYMFOvXj3jcrl89qky7mbZt2+fuemmm0xsbKwJCwszV1xxhUlNTfUZU3JXyNtvv+2zvuQujl+OL8vWrVtNv379TFRUlImIiDDdu3c3f//738ucryJ3hZxr1KhRJjQ01Bw7dszRdkBt5DLmApepAwDKdfbsWTVr1kzXXHON3nrrreouB6h2nAoBAD98++23yszMVGpqqr755htNnTq1uksCagSCBQD4Yd26dbrvvvsUHx+vhQsXcosp8H84FQIAAKzhdlMAAGANwQIAAFhDsAAAANZU+cWbxcXF+vrrrxUdHV2ph9IAAICqY4zRqVOn1KRJE9WpU/5xiSoPFl9//XWpTzIEAADBITs7WwkJCeV+vcqDRXR0tKR/FxYTE1PVuwcAAH7Iz89XYmKi9/d4eao8WJSc/oiJiSFYAAAQZC50GQMXbwIAAGsIFgAAwBqCBQAAsIbPCgEABD1jjAoLC1VUVFTdpQStkJAQhYaGVvpREAQLAEBQO3v2rHJyclRQUFDdpQS9yMhIxcfHKywszO85CBYAgKBVXFysrKwshYSEqEmTJgoLC+Phi34wxujs2bP69ttvlZWVpUsvvfS8D8E6H4IFACBonT17VsXFxUpMTFRkZGR1lxPUIiIiVLduXR05ckRnz55VeHi4X/Nw8SYAIOj5+79r+LLxfeSdAAAA1hAsAACANVxjAQColealH6yyfU0a2LrK9lWePn36qFOnTpo/f3611kGwAACgCl3orpWRI0dq2bJljudds2aN6tat62dV9hAsAACoQjk5Od4/r1q1StOmTVNmZqZ3XUREhM/4n3/+uUKBoUGDBvaKrASusQAAoAo1btzYu8TGxsrlcnlfnzlzRvXq1dNbb72lPn36KDw8XMuXL1dubq7uvvtuJSQkKDIyUh06dNDKlSt95u3Tp48mTpzofd2sWTM99dRTuv/++xUdHa2mTZtqyZIlAe+PIxbBYGOKnXn6JtuZBwAQUI8++qjmzp2r1NRUud1unTlzRl26dNGjjz6qmJgYrVu3TiNGjFCLFi3UrVu3cueZO3eunnjiCT322GNavXq1fv/73+u6665T27ZtA1Y7wQIAgBpm4sSJuu2223zWTZkyxfvncePGaf369Xr77bfPGyxuuOEGPfzww5L+HVbmzZunTZs2ESwAAPg16dq1q8/roqIiPf3001q1apW++uoreTweeTweRUVFnXeejh07ev9ccsrlxIkTAam5BMECAIAa5peBYe7cuZo3b57mz5+vDh06KCoqShMnTtTZs2fPO88vL/p0uVwqLi62Xu+5CBYAANRwW7du1c0336zhw4dL+veHrx06dEiXXXZZNVdWGneFAABQw7Vq1Urp6en66KOP9Nlnn+mhhx7S8ePHq7usMnHEIghkHM61Mk+PvlamAYCgUBOehmnLn//8Z2VlZen6669XZGSkfve73+mWW25RXl5edZdWissYY6pyh/n5+YqNjVVeXp5iYmKqctdBK2PplAsPqoAeDzxrZR4AqCnOnDmjrKwsNW/e3O+P+cb/d77vZ0V/f3MqBAAAWEOwAAAA1hAsAACA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4sSqK7QSnPS4Zs0aDRw4UJdccoliYmLUo0cPffDBB1VYrXNO+tu2bZt69eqluLg4RUREqG3btpo3b14VVuuc05/BEv/6178UGhqqTp06BbZAC5z0uGnTJrlcrlLL//7v/1Zhxc44fQ89Ho8ef/xxJSUlye12q2XLlnrllVeqqFrnnPQ3atSoMt+/du3aVWHFzjl9D9944w1dccUVioyMVHx8vO677z7l5uYGrkAnH0JWnd58801Tt25d8/LLL5sDBw6YCRMmmKioKHPkyJEyxx8+fNhERkaaCRMmmAMHDpiXX37Z1K1b16xevbqKK68Yp/1lZWWZ8ePHm1dffdV06tTJTJgwoWoL9oPTHidMmGBmz55t/vu//9scPHjQJCcnm7p165rdu3dXceUV47S/3bt3mxUrVpj9+/ebrKws8/rrr5vIyEizePHiKq68Ypz2V+LkyZOmRYsWZtCgQeaKK66ommL95LTHjRs3GkkmMzPT5OTkeJfCwsIqrrxi/HkPhw4darp162bS09NNVlaW+fjjj0t9EGVN4bS/kydP+rxv2dnZpkGDBmb69OlVW7gDTnvcunWrqVOnjnn++efN4cOHzdatW027du3MLbfcErAagyZYXH311WbMmDE+69q2bWumTp1a5vg//vGPpm3btj7rHnroIdO9e/eA1VgZTvs7V+/evYMiWFSmxxKXX365mTlzpu3SrLDR36233mqGDx9uuzQr/O3vzjvvNH/605/M9OnTa3ywcNpjSbD44YcfqqC6ynPa3/vvv29iY2NNbm5uVZRXaZX9GUxLSzMul8t8+eWXgSjPCqc9zpkzx7Ro0cJn3QsvvGASEhICVmNQnAo5e/asdu3apUGDBvmsHzRokD766KMyt8nIyCg1/vrrr9fOnTv1888/B6xWf/jTX7Cx0WNxcbFOnTqlBg0aBKLESrHR3549e/TRRx+pd+/egSixUvztLzU1VV988YWmT58e6BIrrTLvYefOnRUfH6/+/ftr48aNgSzTb/70t3btWnXt2lXPPPOMfvOb36h169aaMmWKfvrpp6oo2REbP4NLly7VgAEDqv1J0uXxp8eePXvq2LFj+sc//iFjjL755hutXr1aQ4YMCVidfn1selX77rvvVFRUVOoTVBs1alTqk1ZLHD9+vMzxhYWF+u677xQfHx+wep3yp79gY6PHuXPn6vTp0/rtb38biBIrpTL9JSQk6Ntvv1VhYaFmzJih0aNHB7JUv/jT36FDhzR16lRt3bpVoaE1/58af3qMj4/XkiVL1KVLF3k8Hr3++uvq37+/Nm3apOuuu64qyq4wf/o7fPiwtm3bpvDwcKWlpem7777Tww8/rO+//77GXWdR2X9jcnJy9P7772vFihWBKrHS/OmxZ8+eeuONN3TnnXfqzJkzKiws1NChQ/XXv/41YHXW/J/2c7hcLp/XxphS6y40vqz1NYXT/oKRvz2uXLlSM2bM0LvvvquGDRsGqrxK86e/rVu36scff9T27ds1depUtWrVSnfffXcgy/RbRfsrKirSPffco5kzZ6p169ZVVZ4VTt7DNm3aqE2bNt7XPXr0UHZ2tp599tkaFyxKOOmvuLhYLpdLb7zxhvfjsp977jkNGzZMCxYsUERERMDrdcrff2OWLVumevXq6ZZbbglQZfY46fHAgQMaP368pk2bpuuvv145OTn6wx/+oDFjxmjp0qUBqS8ogsXFF1+skJCQUonsxIkTpZJbicaNG5c5PjQ0VHFxcQGr1R/+9BdsKtPjqlWr9MADD+jtt9/WgAEDAlmm3yrTX/PmzSVJHTp00DfffKMZM2bUuGDhtL9Tp05p586d2rNnjx555BFJ//4lZYxRaGio/vnPf6pfv35VUntF2fo57N69u5YvX267vErzp7/4+Hj95je/8YYKSbrssstkjNGxY8d06aWXBrRmJyrz/hlj9Morr2jEiBEKCwsLZJmV4k+PKSkp6tWrl/7whz9Ikjp27KioqChde+21+stf/hKQo/dBcY1FWFiYunTpovT0dJ/16enp6tmzZ5nb9OjRo9T4f/7zn+ratavq1q0bsFr94U9/wcbfHleuXKlRo0ZpxYoVAT0nWFm23kNjjDwej+3yKs1pfzExMdq3b5/27t3rXcaMGaM2bdpo79696tatW1WVXmG23sM9e/bUqFOtJfzpr1evXvr666/1448/etcdPHhQderUUUJCQkDrdaoy79/mzZv1+eef64EHHghkiZXmT48FBQWqU8f3V31ISIik/38U37qAXRZqWcktNkuXLjUHDhwwEydONFFRUd6rd6dOnWpGjBjhHV9yu+mkSZPMgQMHzNKlS4PidtOK9meMMXv27DF79uwxXbp0Mffcc4/Zs2eP+fTTT6uj/Apx2uOKFStMaGioWbBggc8tYSdPnqyuFs7LaX8vvviiWbt2rTl48KA5ePCgeeWVV0xMTIx5/PHHq6uF8/Ln7+i5guGuEKc9zps3z6SlpZmDBw+a/fv3m6lTpxpJ5m9/+1t1tXBeTvs7deqUSUhIMMOGDTOffvqp2bx5s7n00kvN6NGjq6uF8/L37+jw4cNNt27dqrpcvzjtMTU11YSGhpqFCxeaL774wmzbts107drVXH311QGrMWiChTHGLFiwwCQlJZmwsDBz5ZVXms2bN3u/NnLkSNO7d2+f8Zs2bTKdO3c2YWFhplmzZmbRokVVXLEzTvuTVGpJSkqq2qIdctJj7969y+xx5MiRVV94BTnp74UXXjDt2rUzkZGRJiYmxnTu3NksXLjQFBUVVUPlFeP07+i5giFYGOOsx9mzZ5uWLVua8PBwU79+fXPNNdeYdevWVUPVFef0Pfzss8/MgAEDTEREhElISDCTJ082BQUFVVx1xTnt7+TJkyYiIsIsWbKkiiv1n9MeX3jhBXP55ZebiIgIEx8fb+69915z7NixgNXnMiZQx0IAAMCvTVBcYwEAAIIDwQIAAFhDsAAAANYQLAAAgDUECwAAYA3BAgAAWEOwAAAA1hAsAACANQQLAABgDcECAABYQ7AAAADW/D/JlSu5y17JxAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(y_train,density=True,alpha=0.5,label=\"Train\",bins=25)\n",
    "plt.hist(y_test,density=True,alpha=0.5,label=\"Test\",bins=25)\n",
    "plt.legend()\n",
    "plt.title(\"Distribution of y\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "60e6641e",
   "metadata": {},
   "source": [
    "### Benchmark Model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "cbbe6d21",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2023-04-25 11:06:03.413316: I tensorflow/core/platform/cpu_feature_guard.cc:193] This TensorFlow binary is optimized with oneAPI Deep Neural Network Library (oneDNN) to use the following CPU instructions in performance-critical operations:  SSE4.1 SSE4.2 AVX AVX2 FMA\n",
      "To enable them in other operations, rebuild TensorFlow with the appropriate compiler flags.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/150\n",
      "187/187 [==============================] - 2s 2ms/step - loss: -0.1663\n",
      "Epoch 2/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2531\n",
      "Epoch 3/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2536\n",
      "Epoch 4/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2545\n",
      "Epoch 5/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2508\n",
      "Epoch 6/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2569\n",
      "Epoch 7/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2549\n",
      "Epoch 8/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2545\n",
      "Epoch 9/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2525\n",
      "Epoch 10/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2549\n",
      "Epoch 11/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2560\n",
      "Epoch 12/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2550\n",
      "Epoch 13/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2570\n",
      "Epoch 14/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2528\n",
      "Epoch 15/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2560\n",
      "Epoch 16/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2551\n",
      "Epoch 17/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2577\n",
      "Epoch 18/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2570\n",
      "Epoch 19/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2504\n",
      "Epoch 20/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2567\n",
      "Epoch 21/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2529\n",
      "Epoch 22/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2567\n",
      "Epoch 23/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2538\n",
      "Epoch 24/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2529\n",
      "Epoch 25/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2558\n",
      "Epoch 26/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2548\n",
      "Epoch 27/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2576\n",
      "Epoch 28/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2575\n",
      "Epoch 29/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2561\n",
      "Epoch 30/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2556\n",
      "Epoch 31/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2575\n",
      "Epoch 32/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2566\n",
      "Epoch 33/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2559\n",
      "Epoch 34/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2542\n",
      "Epoch 35/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2569\n",
      "Epoch 36/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2546\n",
      "Epoch 37/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2558\n",
      "Epoch 38/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2566\n",
      "Epoch 39/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2569\n",
      "Epoch 40/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2580\n",
      "Epoch 41/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2506\n",
      "Epoch 42/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2548\n",
      "Epoch 43/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2550\n",
      "Epoch 44/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2567\n",
      "Epoch 45/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2573\n",
      "Epoch 46/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2562\n",
      "Epoch 47/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2566\n",
      "Epoch 48/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2557\n",
      "Epoch 49/150\n",
      "187/187 [==============================] - 1s 3ms/step - loss: -1.2551\n",
      "Epoch 50/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2567\n",
      "Epoch 51/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2542\n",
      "Epoch 52/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2586\n",
      "Epoch 53/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2573\n",
      "Epoch 54/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2539\n",
      "Epoch 55/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2549\n",
      "Epoch 56/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2571\n",
      "Epoch 57/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2544\n",
      "Epoch 58/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2555\n",
      "Epoch 59/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2552\n",
      "Epoch 60/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2576\n",
      "Epoch 61/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2554\n",
      "Epoch 62/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2574\n",
      "Epoch 63/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2562\n",
      "Epoch 64/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2508\n",
      "Epoch 65/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2533\n",
      "Epoch 66/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2567\n",
      "Epoch 67/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2583\n",
      "Epoch 68/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2589\n",
      "Epoch 69/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2571\n",
      "Epoch 70/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2538\n",
      "Epoch 71/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2564\n",
      "Epoch 72/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2564\n",
      "Epoch 73/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2550\n",
      "Epoch 74/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2544\n",
      "Epoch 75/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2565\n",
      "Epoch 76/150\n",
      "187/187 [==============================] - 1s 3ms/step - loss: -1.2583\n",
      "Epoch 77/150\n",
      "187/187 [==============================] - 1s 3ms/step - loss: -1.2565\n",
      "Epoch 78/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2558\n",
      "Epoch 79/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2561\n",
      "Epoch 80/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2573\n",
      "Epoch 81/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2576\n",
      "Epoch 82/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2538\n",
      "Epoch 83/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2581\n",
      "Epoch 84/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2583\n",
      "Epoch 85/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2574\n",
      "Epoch 86/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2562\n",
      "Epoch 87/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2558\n",
      "Epoch 88/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2573\n",
      "Epoch 89/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2567\n",
      "Epoch 90/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2572\n",
      "Epoch 91/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2574\n",
      "Epoch 92/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2575\n",
      "Epoch 93/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2551\n",
      "Epoch 94/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2561\n",
      "Epoch 95/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2577\n",
      "Epoch 96/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2576\n",
      "Epoch 97/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2573\n",
      "Epoch 98/150\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2578\n",
      "Epoch 99/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2588\n",
      "Epoch 100/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2555\n",
      "Epoch 101/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2565\n",
      "Epoch 102/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2582\n",
      "Epoch 103/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.2571\n",
      "Epoch 104/150\n",
      "187/187 [==============================] - 0s 3ms/step - loss: -1.5212\n",
      "Epoch 105/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.7567\n",
      "Epoch 106/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.7872\n",
      "Epoch 107/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.7987\n",
      "Epoch 108/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8073\n",
      "Epoch 109/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8110\n",
      "Epoch 110/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8144\n",
      "Epoch 111/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8225\n",
      "Epoch 112/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8276\n",
      "Epoch 113/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8282\n",
      "Epoch 114/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8319\n",
      "Epoch 115/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8328\n",
      "Epoch 116/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8373\n",
      "Epoch 117/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8348\n",
      "Epoch 118/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8369\n",
      "Epoch 119/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8330\n",
      "Epoch 120/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8457\n",
      "Epoch 121/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8406\n",
      "Epoch 122/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8489\n",
      "Epoch 123/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8415\n",
      "Epoch 124/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8522\n",
      "Epoch 125/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8545\n",
      "Epoch 126/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8567\n",
      "Epoch 127/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8549\n",
      "Epoch 128/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8579\n",
      "Epoch 129/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8592\n",
      "Epoch 130/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8660\n",
      "Epoch 131/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8665\n",
      "Epoch 132/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8690\n",
      "Epoch 133/150\n",
      "187/187 [==============================] - 1s 3ms/step - loss: -1.8731\n",
      "Epoch 134/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8776\n",
      "Epoch 135/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8715\n",
      "Epoch 136/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8752\n",
      "Epoch 137/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8823\n",
      "Epoch 138/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8854\n",
      "Epoch 139/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.8942\n",
      "Epoch 140/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.9013\n",
      "Epoch 141/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.9002\n",
      "Epoch 142/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.9082\n",
      "Epoch 143/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.9220\n",
      "Epoch 144/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.9377\n",
      "Epoch 145/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.9409\n",
      "Epoch 146/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -1.9670\n",
      "Epoch 147/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -2.0025\n",
      "Epoch 148/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -2.0532\n",
      "Epoch 149/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -2.1657\n",
      "Epoch 150/150\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -2.3827\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<keras.callbacks.History at 0x169050190>"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "edl_model = tf.keras.Sequential([\n",
    "        tf.keras.layers.Dense(1, input_dim=x_train.shape[1]),\n",
    "        tf.keras.layers.Dense(200, activation=\"relu\"),\n",
    "        tf.keras.layers.Dense(128, activation=\"softmax\"),\n",
    "        tf.keras.layers.Dense(100, activation=\"relu\"),\n",
    "        tf.keras.layers.Dense(64, activation=\"softmax\"),\n",
    "        tf.keras.layers.Dense(32, activation=\"relu\"),\n",
    "        tf.keras.layers.Dense(20, activation=\"relu\"),\n",
    "        dense_layers.DenseNormalGamma(1),\n",
    "    ])\n",
    "\n",
    "def EvidentialRegressionLoss(true, pred):\n",
    "        return dense_loss.EvidentialRegression(true, pred, coeff=1e-10)\n",
    "\n",
    "# Compile and fit the model!\n",
    "edl_model.compile(\n",
    "    optimizer=tf.keras.optimizers.Adam(1e-3),\n",
    "    loss=EvidentialRegressionLoss)\n",
    "\n",
    "edl_model.fit(x_train, y_train, batch_size=100, epochs=150)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "2b40f9db",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "146/146 [==============================] - 0s 922us/step\n"
     ]
    }
   ],
   "source": [
    "y_pred = edl_model.predict(x_test)\n",
    "mu, v, alpha, beta = y_pred[:,0],y_pred[:,1],y_pred[:,2],y_pred[:,3]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "7cdccce5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.40115699505008506"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mean_squared_error(y_test,mu)*100/y_test.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "87e45516",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.0002207"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "alpha.min()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "a58f7b35",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.21359845"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "var = np.sqrt(beta / (v * (alpha - 1)))\n",
    "var.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "e57d731e",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/kb/v0p0ypbd0wx1q2qb1kpxmmcc0000gn/T/ipykernel_16477/1373794708.py:2: MatplotlibDeprecationWarning: Auto-removal of overlapping axes is deprecated since 3.6 and will be removed two minor releases later; explicitly call ax.remove() as needed.\n",
      "  plt.subplot(121)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Distribnution of y-pred(Normal)')"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA+MAAAIOCAYAAADTKdw4AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABWXElEQVR4nO3deXgUZb728bvNRohJDwkmnUgMiIBAEBUUggv7EkGGxcGRkYERcWHRCBwFGY9BHQI4giMIgw6yIxwXFA8aCQdBGUAhyivbICpgGBKiGBLA2AF83j88qUNngw5JdTp8P9dV12VVPV31q+7gU3fXU9UOY4wRAAAAAACwzWW+LgAAAAAAgEsNYRwAAAAAAJsRxgEAAAAAsBlhHAAAAAAAmxHGAQAAAACwGWEcAAAAAACbEcYBAAAAALAZYRwAAAAAAJsRxgEAAAAAsBlhHH5n4cKFcjgc1lSnTh25XC517txZaWlpys3NLfWa1NRUORwOr/bz008/KTU1VRs2bPDqdWXtq2HDhurTp49X26kqR44cUWpqqnbs2FFqXWXeF7sVFRXpoYceUmxsrAICAnT99ddX276mTJmid955p1q2ffDgQTkcDi1cuLBatg8AF4O+1Tv0rf5l2LBhatiwYanl33zzjUJCQrRlyxaPtg6HQy1bttTZs2dLvcbhcGj06NHVWW61atiwoYYNG2bNf/XVVwoODtbnn3/uu6IuYYRx+K0FCxZoy5YtysjI0Msvv6zrr79e06ZNU/PmzbVu3TqPtvfff7/H/2gvxE8//aTJkyd7fcJQmX1VpyNHjmjy5MllnjDUtFrLMnfuXM2bN0+TJk3Spk2btGTJkmrbV3WG8djYWG3ZskW9e/eulu0DQFWgb70w9K21w/jx49W9e3clJSWVWrdnz55L4gv0pk2b6g9/+IMee+wxX5dySQr0dQFAZSUmJqpt27bW/MCBA/XYY4/p1ltv1YABA7R//37FxMRIkho0aKAGDRpUaz0//fST6tata8u+qoo/1Lpr1y6FhobWuG+hCwsLVadOnQu++hESEqL27dtXc1UAcHHoWy+eP9RaU/vWkrzta72xd+9evfPOO0pPTy+1LiwsTDfeeKOefvppDR48WKGhoVW+f0k6e/aszpw5o5CQkGrZ/oUaPXq02rZtq82bN6tDhw4+reVSw5Vx1CpXXXWVXnjhBZ04cULz5s2zlpc1ZGz9+vXq1KmToqKiFBoaqquuukoDBw7UTz/9pIMHD+qKK66QJE2ePNkatlc8rKd4e59//rnuuusu1atXT40bNy53X8VWrVql6667TnXq1NHVV1+tl156yWP9hg0b5HA49Prrr2vSpEmKi4tTRESEunXrpn379nm0LTnMqFinTp3UqVMna3s33XSTJOlPf/qTdRypqanl1vrLL79o+vTpuvbaaxUSEqLo6Gj98Y9/1OHDh0vtJzExUdu2bdNtt92munXr6uqrr9bUqVP1yy+/lHn85/r55581ceJENWrUSMHBwbryyis1atQoHT9+3GrjcDj0j3/8Q4WFhVbt5X1L/eyzzyowMFBZWVml1t13332KiorSzz//XG49DodDp06d0qJFi6x9Fb+PxcM3165dq/vuu09XXHGF6tatK7fbra+//lp/+tOf1KRJE9WtW1dXXnml7rzzTu3cudNj+2UNUy9+/3fv3q177rlHTqdTMTExuu+++5Sfn3/e9xAA7EDfSt9a2b61eH+jR4/WvHnz1LRpU4WEhKhFixZasWKFR7uK+lpJWrlypZKSkhQWFqbLL79cPXv21BdffFFqfwsXLlSzZs0UEhKi5s2ba/HixWXWNXfuXLlcLnXv3r3M9dOmTdO///1v/e1vf6vw+CTpu+++07333qvo6Ghrvy+88ILHZ1Z8HjB9+nQ999xzatSokUJCQvTRRx9ZfzNffvmlfve738npdCoyMlJjx47VmTNntG/fPvXq1Uvh4eFq2LChpk+f7rH/n3/+WePGjdP1119vvTYpKUnvvvvueWuXpDZt2qh58+b6+9//fkHtUXUI46h17rjjDgUEBOjjjz8ut83BgwfVu3dvBQcH67XXXlN6erqmTp2qsLAwFRUVKTY21vqmdPjw4dqyZYu2bNmip556ymM7AwYM0DXXXKM33njjvP8D27Fjh1JSUvTYY49p1apV6tChgx599FH99a9/LdX2ySef1KFDh/SPf/xDr7zyivbv368777yzzHuXKnLjjTdqwYIFkqQ///nP1nHcf//95b7m4Ycf1hNPPKHu3btr9erVevbZZ5Wenq4OHTrohx9+8Gibk5OjP/zhD7r33nu1evVqJScna+LEiVq6dGmFdRlj1K9fP/31r3/VkCFDtGbNGo0dO1aLFi1Sly5drI53y5YtuuOOOxQaGmrVXt4w7wcffFCBgYEeJ4qS9OOPP2rFihUaPny46tSpU25NW7ZsUWhoqO644w5rX3PmzPFoc9999ykoKEhLlizRm2++qaCgIB05ckRRUVGaOnWq0tPT9fLLLyswMFDt2rUrdZJXnoEDB6pp06Z66623NGHCBC1fvpzhYgBqFPrW/0PfeuF9a7HVq1frpZde0jPPPKM333xTCQkJuueee/Tmm2+WaltWXztlyhTdc889atGihf7rv/5LS5Ys0YkTJ3Tbbbdpz5491msXLlyoP/3pT2revLneeust/fnPf9azzz6r9evXl9rPmjVrdPvtt+uyy8qOQ0lJSerfv7+mTZumH3/8sdxj+/7779WhQwetXbtWzz77rFavXq1u3bpp/PjxZY48eOmll7R+/Xr99a9/1QcffKBrr73WWjdo0CC1bt1ab731lkaMGKGZM2fqscceU79+/dS7d2+tWrVKXbp00RNPPKG3337bep3b7daPP/6o8ePH65133tHrr79ujWYp78uIkjp16qQPPvhAxpgLao8qYgA/s2DBAiPJbNu2rdw2MTExpnnz5tb8008/bc79c3/zzTeNJLNjx45yt/H9998bSebpp58uta54e//5n/9Z7rpzJSQkGIfDUWp/3bt3NxEREebUqVPGGGM++ugjI8nccccdHu3+67/+y0gyW7Zs8djm0KFDS+2/Y8eOpmPHjtb8tm3bjCSzYMGC89a6d+9eI8mMHDnSo92nn35qJJknn3zSYz+SzKeffurRtkWLFqZnz56l9nWu9PR0I8lMnz7dY/nKlSuNJPPKK69Yy4YOHWrCwsIq3N65baOjo43b7baWTZs2zVx22WXmwIED5319WFhYme9p8d/cH//4x/Nu48yZM6aoqMg0adLEPPbYY9byAwcOlPocit//ku/DyJEjTZ06dcwvv/xy3v0BQFWgb/2/bdK3errYvlWSCQ0NNTk5OdayM2fOmGuvvdZcc8011rLy+trvvvvOBAYGmjFjxngsP3HihHG5XGbQoEHGGGPOnj1r4uLizI033ujRfx48eNAEBQWZhIQEa9nRo0eNJDN16tQyj7f4vfnXv/5lAgICzLhx4zyOZ9SoUdb8hAkTyvzMHn74YeNwOMy+ffuMMf93HtC4cWNTVFTk0bb4b+aFF17wWH799dcbSebtt9+2lp0+fdpcccUVZsCAAaVqL3bmzBlz+vRpM3z4cHPDDTd4rCvvb/zVV181kszevXvL3S6qHlfGUSuZ83yrd/311ys4OFgPPPCAFi1apG+//bZS+xk4cOAFt23ZsqVat27tsWzw4MEqKCgo9QTLvn37esxfd911kqRDhw5Vqs4L9dFHH0lSqSF6N998s5o3b67/+Z//8Vjucrl08803eyy77rrrzltn8TfUJffzu9/9TmFhYaX2c6EeffRR5ebm6o033pD067DAuXPnqnfv3tZTVIvvzyqeLmTYX7GyPu8zZ85oypQpatGihYKDgxUYGKjg4GDt379fe/fuvaDtlvV5//zzz2U+vRgAfIW+tXLoW6WuXbtazxqQpICAAN199936+uuvSw3VL/n5f/jhhzpz5oz++Mc/euyjTp066tixo/UwwH379unIkSMaPHiwx20CCQkJpe6DPnLkiCQpOjq6wmNv1qyZhg8frtmzZ+u7774rs8369evVokWLUp/ZsGHDZIwpdVW+b9++CgoKKnNbJX8doHnz5nI4HEpOTraWBQYG6pprrin19/DGG2/olltu0eWXX67AwEAFBQVp/vz5F3wuUvxe/Pvf/76g9qgahHHUOqdOndKxY8cUFxdXbpvGjRtr3bp1io6O1qhRo9S4cWM1btz4gu4LOldsbOwFt3W5XOUuO3bsmMfyqKgoj/niB3sUFhZ6VZ+3iuso67ji4uLOW6f0a63nq/PYsWMKDAy07h0s5nA45HK5Su3nQt1www267bbb9PLLL0uS/vu//1sHDx70GCbWtWtXBQUFWdN99913wdsv630ZO3asnnrqKfXr10/vvfeePv30U23btk2tW7e+4M/LV583AFwo+tbKo2/17nMq+T4dPXpUknTTTTd57CMoKEgrV660hvkXb6eifRUrfi8vZIh9amqqAgICSt1OUezYsWPlfrYXcnznioyM9JgPDg5W3bp1S9UZHBzsca/+22+/rUGDBunKK6/U0qVLtWXLFm3btk333Xffee/pL1a8D8497MXT1FHrrFmzRmfPnrUetFKe2267TbfddpvOnj2r7du3a9asWUpJSVFMTIx+//vfX9C+vHm6Z05OTrnLyup4z6dOnTrW/V/n+uGHH1S/fn2vt3duHdnZ2aWeBHvkyJFKb7es/Zw5c0bff/+9x0mDMUY5OTnWg3Eq45FHHtHvfvc7ff7555o9e7aa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",
      "text/plain": [
       "<Figure size 1200x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig,ax = plt.subplots(1,1,figsize=(12,6))\n",
    "plt.subplot(121)\n",
    "plt.hist(y_train,bins=50)\n",
    "plt.title(\"Distribnution of y-train\")\n",
    "plt.subplot(122)\n",
    "plt.hist(mu,bins=100)\n",
    "plt.title(\"Distribnution of y-pred(Normal)\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "59edea9c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x16a5355e0>"
      ]
     },
     "execution_count": 23,
     "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(y_test,mu)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "837aea30",
   "metadata": {},
   "source": [
    "### Weibull Model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "72fe4ffc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1.2863025440677656, -0.0018491764409905276, 0.11740979265460841)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x16a58d430>"
      ]
     },
     "execution_count": 24,
     "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": [
    "rv = sc_stats.weibull_min.fit(y_train)\n",
    "print (rv)\n",
    "plt.hist(y_train,alpha=0.5,density=True,bins=30,label=\"Histogram of y\")\n",
    "plt.scatter(y_train, sc_stats.weibull_min.pdf(y_train,*rv),label=\"Fitted Weibull\",color=\"black\")\n",
    "plt.title(\"y-train\")\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "id": "968f409f",
   "metadata": {},
   "outputs": [],
   "source": [
    "k=1.286\n",
    "weibull_model = tf.keras.Sequential([\n",
    "        tf.keras.layers.Dense(1, input_dim=x_train.shape[1]),\n",
    "        tf.keras.layers.Dense(200, activation=\"relu\"),\n",
    "        tf.keras.layers.Dense(100, activation=\"relu\"),\n",
    "        tf.keras.layers.Dense(64, activation=\"relu\"),\n",
    "        tf.keras.layers.Dense(32, activation=\"tanh\"),\n",
    "        tf.keras.layers.Dense(20, activation=\"relu\"),\n",
    "        tf.keras.layers.Dense(16, activation=\"relu\"),\n",
    "        loss_and_layers.DenseWeibullGamma(1),\n",
    "    ])\n",
    "\n",
    "def weibullLoss(true, pred):\n",
    "        return loss_and_layers.weibull_evidence_Regression(true, pred, k=k, coeff=1e-3)\n",
    "\n",
    "# Compile and fit the model!\n",
    "weibull_model.compile(\n",
    "    optimizer=tf.keras.optimizers.Adam(5e-3),\n",
    "    loss=weibullLoss)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "id": "d183b7be",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/200\n",
      "187/187 [==============================] - 2s 2ms/step - loss: -0.6801\n",
      "Epoch 2/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7057\n",
      "Epoch 3/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7088\n",
      "Epoch 4/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7086\n",
      "Epoch 5/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7088\n",
      "Epoch 6/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7094\n",
      "Epoch 7/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7103\n",
      "Epoch 8/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7110\n",
      "Epoch 9/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7100\n",
      "Epoch 10/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7105\n",
      "Epoch 11/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7100\n",
      "Epoch 12/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7108\n",
      "Epoch 13/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7099\n",
      "Epoch 14/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7109\n",
      "Epoch 15/200\n",
      "187/187 [==============================] - 0s 3ms/step - loss: -0.7108\n",
      "Epoch 16/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7100\n",
      "Epoch 17/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7109\n",
      "Epoch 18/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7104\n",
      "Epoch 19/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7109\n",
      "Epoch 20/200\n",
      "187/187 [==============================] - 1s 3ms/step - loss: -0.7106\n",
      "Epoch 21/200\n",
      "187/187 [==============================] - 1s 3ms/step - loss: -0.7103\n",
      "Epoch 22/200\n",
      "187/187 [==============================] - 1s 4ms/step - loss: -0.7100\n",
      "Epoch 23/200\n",
      "187/187 [==============================] - 0s 3ms/step - loss: -0.7111\n",
      "Epoch 24/200\n",
      "187/187 [==============================] - 1s 4ms/step - loss: -0.7112\n",
      "Epoch 25/200\n",
      "187/187 [==============================] - 1s 4ms/step - loss: -0.7108\n",
      "Epoch 26/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7109\n",
      "Epoch 27/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7106\n",
      "Epoch 28/200\n",
      "187/187 [==============================] - 0s 3ms/step - loss: -0.7103\n",
      "Epoch 29/200\n",
      "187/187 [==============================] - 1s 6ms/step - loss: -0.7110\n",
      "Epoch 30/200\n",
      "187/187 [==============================] - 1s 4ms/step - loss: -0.7107\n",
      "Epoch 31/200\n",
      "187/187 [==============================] - 1s 3ms/step - loss: -0.7110\n",
      "Epoch 32/200\n",
      "187/187 [==============================] - 1s 3ms/step - loss: -0.7112\n",
      "Epoch 33/200\n",
      "187/187 [==============================] - 1s 4ms/step - loss: -0.7110\n",
      "Epoch 34/200\n",
      "187/187 [==============================] - 1s 4ms/step - loss: -0.7108\n",
      "Epoch 35/200\n",
      "187/187 [==============================] - 1s 4ms/step - loss: -0.7112\n",
      "Epoch 36/200\n",
      "187/187 [==============================] - 1s 4ms/step - loss: -0.7112\n",
      "Epoch 37/200\n",
      "187/187 [==============================] - 1s 3ms/step - loss: -0.7104\n",
      "Epoch 38/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7110\n",
      "Epoch 39/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7112\n",
      "Epoch 40/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 41/200\n",
      "187/187 [==============================] - 1s 5ms/step - loss: -0.7106\n",
      "Epoch 42/200\n",
      "187/187 [==============================] - 1s 4ms/step - loss: -0.7106\n",
      "Epoch 43/200\n",
      "187/187 [==============================] - 1s 5ms/step - loss: -0.7111\n",
      "Epoch 44/200\n",
      "187/187 [==============================] - 1s 5ms/step - loss: -0.7114\n",
      "Epoch 45/200\n",
      "187/187 [==============================] - 1s 4ms/step - loss: -0.7111\n",
      "Epoch 46/200\n",
      "187/187 [==============================] - 1s 4ms/step - loss: -0.7110\n",
      "Epoch 47/200\n",
      "187/187 [==============================] - 1s 4ms/step - loss: -0.7113\n",
      "Epoch 48/200\n",
      "187/187 [==============================] - 1s 3ms/step - loss: -0.7115\n",
      "Epoch 49/200\n",
      "187/187 [==============================] - 1s 3ms/step - loss: -0.7114\n",
      "Epoch 50/200\n",
      "187/187 [==============================] - 0s 3ms/step - loss: -0.7108\n",
      "Epoch 51/200\n",
      "187/187 [==============================] - 1s 3ms/step - loss: -0.7113\n",
      "Epoch 52/200\n",
      "187/187 [==============================] - 1s 3ms/step - loss: -0.7111\n",
      "Epoch 53/200\n",
      "187/187 [==============================] - 1s 3ms/step - loss: -0.7110\n",
      "Epoch 54/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7113\n",
      "Epoch 55/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7112\n",
      "Epoch 56/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 57/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7113\n",
      "Epoch 58/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 59/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7113\n",
      "Epoch 60/200\n",
      "187/187 [==============================] - 1s 3ms/step - loss: -0.7115\n",
      "Epoch 61/200\n",
      "187/187 [==============================] - 1s 3ms/step - loss: -0.7111\n",
      "Epoch 62/200\n",
      "187/187 [==============================] - 1s 3ms/step - loss: -0.7113\n",
      "Epoch 63/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 64/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7113\n",
      "Epoch 65/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7113\n",
      "Epoch 66/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 67/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7113\n",
      "Epoch 68/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7111\n",
      "Epoch 69/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7113\n",
      "Epoch 70/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 71/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7112\n",
      "Epoch 72/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7113\n",
      "Epoch 73/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 74/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7112\n",
      "Epoch 75/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 76/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 77/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 78/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7113\n",
      "Epoch 79/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 80/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 81/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7112\n",
      "Epoch 82/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7112\n",
      "Epoch 83/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 84/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7112\n",
      "Epoch 85/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 86/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7112\n",
      "Epoch 87/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 88/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 89/200\n",
      "187/187 [==============================] - 1s 3ms/step - loss: -0.7115\n",
      "Epoch 90/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7112\n",
      "Epoch 91/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7117\n",
      "Epoch 92/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7111\n",
      "Epoch 93/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7113\n",
      "Epoch 94/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7117\n",
      "Epoch 95/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7111\n",
      "Epoch 96/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 97/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 98/200\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7118\n",
      "Epoch 99/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 100/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 101/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 102/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7113\n",
      "Epoch 103/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7113\n",
      "Epoch 104/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 105/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7117\n",
      "Epoch 106/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 107/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 108/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 109/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7108\n",
      "Epoch 110/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 111/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7117\n",
      "Epoch 112/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7111\n",
      "Epoch 113/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7113\n",
      "Epoch 114/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 115/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 116/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 117/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7111\n",
      "Epoch 118/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7111\n",
      "Epoch 119/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 120/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7117\n",
      "Epoch 121/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 122/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 123/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 124/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 125/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7113\n",
      "Epoch 126/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 127/200\n",
      "187/187 [==============================] - 1s 3ms/step - loss: -0.7115\n",
      "Epoch 128/200\n",
      "187/187 [==============================] - 1s 3ms/step - loss: -0.7112\n",
      "Epoch 129/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 130/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 131/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7113\n",
      "Epoch 132/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 133/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 134/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 135/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 136/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 137/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 138/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7117\n",
      "Epoch 139/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7112\n",
      "Epoch 140/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 141/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7113\n",
      "Epoch 142/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 143/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7113\n",
      "Epoch 144/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 145/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 146/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 147/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 148/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 149/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 150/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 151/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 152/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7111\n",
      "Epoch 153/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 154/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 155/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 156/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 157/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7113\n",
      "Epoch 158/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 159/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 160/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 161/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 162/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 163/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 164/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 165/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7117\n",
      "Epoch 166/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 167/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 168/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 169/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 170/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 171/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7117\n",
      "Epoch 172/200\n",
      "187/187 [==============================] - 0s 3ms/step - loss: -0.7114\n",
      "Epoch 173/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 174/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 175/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 176/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7117\n",
      "Epoch 177/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 178/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 179/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 180/200\n",
      "187/187 [==============================] - 0s 3ms/step - loss: -0.7116\n",
      "Epoch 181/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7117\n",
      "Epoch 182/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 183/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 184/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7113\n",
      "Epoch 185/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 186/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 187/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7118\n",
      "Epoch 188/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 189/200\n",
      "187/187 [==============================] - 0s 3ms/step - loss: -0.7115\n",
      "Epoch 190/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 191/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 192/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 193/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7113\n",
      "Epoch 194/200\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 195/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7116\n",
      "Epoch 196/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 197/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7117\n",
      "Epoch 198/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7114\n",
      "Epoch 199/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7115\n",
      "Epoch 200/200\n",
      "187/187 [==============================] - 0s 2ms/step - loss: -0.7117\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<keras.callbacks.History at 0x16d8d7730>"
      ]
     },
     "execution_count": 94,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "weibull_model.fit(x_train, y_train, batch_size=100, epochs=200)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "id": "57cdaf24",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "146/146 [==============================] - 1s 3ms/step\n"
     ]
    }
   ],
   "source": [
    "y_pred = weibull_model.predict(x_test)\n",
    "alpha,beta = y_pred[:,0],y_pred[:,1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "id": "42167135",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([22.049084, 22.049084, 22.049084, ..., 22.049084, 22.049082,\n",
       "       22.049082], dtype=float32)"
      ]
     },
     "execution_count": 91,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "alpha"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "id": "b8ee1a9a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([2.309096, 2.309096, 2.309096, ..., 2.309096, 2.309096, 2.309096],\n",
       "      dtype=float32)"
      ]
     },
     "execution_count": 92,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "beta"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "c4f0f3a3",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.special import loggamma"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "2723d6cd",
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_pred_log = (loggamma(1+ (1/k)) - loggamma(alpha) + loggamma(alpha-(1/k))\\\n",
    "                + (1/k)*np.log(beta))\n",
    "mu = np.exp(mean_pred_log)\n",
    "\n",
    "var_term1 = (loggamma(1+ (2/k)) - loggamma(alpha) + loggamma(alpha-(2/k))\\\n",
    "                + (2/k)*np.log(beta))\n",
    "var = np.exp(var_term1) - np.square(mu)\n",
    "# var"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "e22946ee",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "12.367465278035958"
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mean_squared_error(y_test,mu)*100/y_test.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "79781039",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x16c2e1610>"
      ]
     },
     "execution_count": 66,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAj4AAAGdCAYAAAASUnlxAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABDV0lEQVR4nO3de1xVdb7/8fdmKzcDSkTApC02XsMM4YjXoCYpTsey289isjyTNZaWRFOjQ05kJV0ms6aw8JDlpKNdrGmKTtJFR8caiuBxMh2x1CCDQCbBW5D4/f1B7txykbUBL6zX8/HYj9jf/V3f9fnsDfJu7bUXDmOMEQAAgA34nOgCAAAAjheCDwAAsA2CDwAAsA2CDwAAsA2CDwAAsA2CDwAAsA2CDwAAsA2CDwAAsI1uJ7qAk8mhQ4f07bffKigoSA6H40SXAwAA2sAYoz179qhPnz7y8Wn9mA7B5wjffvutoqKiTnQZAADAC2VlZerbt2+rcwg+RwgKCpLU+MQFBwef4GoAAEBb1NbWKioqyv17vDUEnyMcfnsrODiY4AMAwCmmLaepcHIzAACwDYIPAACwDYIPAACwDc7xAYAWGGN08OBBNTQ0nOhSANtzOp3q1q1buy83Q/ABgGbU19ervLxc+/fvP9GlAPhJYGCgIiMj5evr6/UaBB8AOMqhQ4e0fft2OZ1O9enTR76+vlzUFDiBjDGqr69XVVWVtm/frgEDBhzzQoUtIfgAwFHq6+t16NAhRUVFKTAw8ESXA0BSQECAunfvrq+//lr19fXy9/f3ah1ObgaAFnj7f5QAOkdH/EzyUw0AAGyD4AMAAGyD4AMAsIUdO3bI4XCouLi4xTn79+/XVVddpeDgYDkcDu3evfu41Xeq6devnxYuXOi+73A49MYbb5ywetqKk5sBAPjJiy++qHXr1mnDhg3q1auXQkJCTnRJp4zy8nKdccYZJ7qMYyL4AEBnOtQgVa2TDpRLAZFS2HjJx3miqzql/fjjj+revXunrP3VV19pyJAhiomJaXFOfX19u64j01VFRESc6BLahLe6AKCzlK2S3uwnvX+BtCG18b9v9msc7yRJSUm6/fbblZaWpjPOOEPh4eHKycnRvn379N///d8KCgrS2WefrXfeecdju02bNuk///M/ddpppyk8PFxTpkzRrl273I//7//+r8aNG6fTTz9doaGh+q//+i999dVX7scPv420atUqXXDBBQoMDNTw4cP10UcftVqvw+HQokWLlJKSooCAAEVHR+uVV15psu7LL7+spKQk+fv766WXXpIkLVmyREOGDJG/v78GDx6s7Oxsj7ULCgoUGxsrf39/xcfHq6io6JjP3eOPP66///3vcjgcSkpKktT4ls6DDz6oqVOnKiQkRDfffLMk6bXXXtM555wjPz8/9evXT48//rjHeoe3u+GGG3TaaafJ5XLpr3/9q6qqqnT55ZfrtNNO07Bhw/Tpp5+2WldmZqbOOuss+fn5qU+fPrrjjjvcj7300kuKj49XUFCQIiIilJqaqsrKSvfja9askcPh0LvvvqvY2FgFBATowgsvVGVlpd555x0NGTJEwcHBuu666zwu1pmUlKSZM2dq5syZ7tf83nvvlTGmxTqPfKurrd8Pixcvdl824oorrtCCBQt0+umnt/p8tJuBW01NjZFkampqTnQpAE6gAwcOmE2bNpkDBw54v0jpa8YscxizTEfdHI230tc6ruAjJCYmmqCgIPPAAw+YkpIS88ADDxgfHx+TkpJicnJyTElJibn11ltNaGio2bdvnzHGmG+//db06tXLzJkzx2zevNl89tlnZsKECeaCCy5wr/vqq6+a1157zZSUlJiioiIzceJEM2zYMNPQ0GCMMWb79u1Gkhk8eLB56623zJYtW8zVV19tXC6X+fHHH1usV5IJDQ01ixcvNlu2bDH33nuvcTqdZtOmTR7r9uvXz7z22mtm27ZtZufOnSYnJ8dERka6x1577TXTs2dP88ILLxhjjNm7d68JCwszkydPNhs3bjR/+9vfTP/+/Y0kU1RU1Gwt1dXV5uabbzajR4825eXlprq62hhjjMvlMsHBweaxxx4zW7duNVu3bjWffvqp8fHxMfPmzTNbtmwxS5YsMQEBAWbJkiXu9Vwul+nZs6d59tln3c97UFCQueSSS8zLL79stmzZYiZNmmSGDBliDh061GxNr7zyigkODjZ5eXnm66+/Nv/85z9NTk6O+/Hc3FyTl5dnvvrqK/PRRx+ZUaNGmZSUFPfjH374oZFkRo0aZdavX28+++wz84tf/MIkJiaa5ORk89lnn5m///3vJjQ01Dz88MMe30ennXaamTVrlvnXv/5lXnrpJRMYGOixb5fLZZ544gmP1/L1119v8/fD+vXrjY+Pj3nsscfMli1bzDPPPGN69uxpQkJCWvx+aeln08rvb4LPEQg+AIzpgODTcNCY1/s2E3qOCD+vRzXO62CJiYlm3Lhx7vsHDx40PXr0MFOmTHGPlZeXG0nmo48+MsYYM3fuXJOcnOyxTllZmZFktmzZ0ux+KisrjSTz+eefG2N+/kX3P//zP+45X3zxhZFkNm/e3GK9ksz06dM9xhISEsytt97qse7ChQs95kRFRZnly5d7jD3wwANm9OjRxhhjnnvuOdOzZ093uDPGmEWLFrUafIwxZtasWSYxMdFjzOVymUmTJnmMpaammgkTJniM3X333Wbo0KEe211//fXu+4ef97lz57rHPvroIyPJlJeXN1vP448/bgYOHGjq6+tbrPlIBQUFRpLZs2ePMebn4PPee++552RlZRlJ5quvvnKP/eY3vzEXX3yx+35iYmKTQPa73/3ODBkyxKO/YwWf1r4fJk+ebC699FKP+n/1q191evDhrS4A6GhV66T937QywUj7yxrndYJzzz3X/bXT6VRoaKiGDRvmHgsPD5ck91sihYWF+vDDD3Xaaae5b4MHD5Yk99tZX331lVJTU9W/f38FBwcrOjpaklRaWtriviMjIz3205LRo0c3ub9582aPsfj4ePfXVVVVKisr00033eRR84MPPuiud/PmzRo+fLjHlbeP3o8VR+7/8Ppjx471GBs7dqy2bt3q8Udtj3w+Dj/vrb0WR7vmmmt04MAB9e/fXzfffLNef/11HTx40P14UVGRLr/8crlcLgUFBbnfnmvtdQkPD1dgYKD69+/vMXZ0DaNGjfL4Uy2jR49u0t+xtPb9sGXLFo0cOdJj/tH3OwMnNwNARztQ3rHzLDr6xF+Hw+ExdviX2aFDh9z/nThxoh555JEmax3+ZTVx4kRFRUVp8eLF6tOnjw4dOqSYmBjV19e3uO+j92PF0X8brUePHu6vD6+3ePFiJSQkeMxzOhtPHDetnIvijSP3f3j9o2tsbp/NPR9WnqOoqCht2bJF+fn5eu+993Tbbbfpscce09q1a1VfX6/k5GQlJyfrpZdeUlhYmEpLS3XxxRcf83Vp7nvEm9fpWFrrta3PYUcj+ABARwuI7Nh5nWzEiBF67bXX1K9fP3Xr1vTXQnV1tTZv3qznnntO48ePlyStX7++w/b/8ccf64YbbvC4Hxsb2+L88PBwnXnmmdq2bZt+9atfNTtn6NCh+vOf/6wDBw4oICDAvW5HGTp0aJPnYMOGDRo4cKA7fHWUgIAAXXbZZbrssss0Y8YMDR48WJ9//rmMMdq1a5cefvhhRUVFSdIxT5S24ujn6+OPP9aAAQM6rL/BgweroKDAY6wj628Jb3UBQEcLGy8F9pXU0l90d0iBUY3zTgIzZszQv//9b1133XUqKCjQtm3btHr1av36179WQ0ODzjjjDIWGhionJ0dffvmlPvjgA6Wnp3fY/l955RU9//zzKikp0X333aeCggLNnDmz1W0yMzOVlZWlJ598UiUlJfr888+1ZMkSLViwQJKUmpoqHx8f3XTTTdq0aZPy8vL0xz/+scNqvuuuu/T+++/rgQceUElJiV588UU9/fTT+u1vf9th+5CkF154Qbm5udq4caO2bdumP//5zwoICJDL5dJZZ50lX19f/elPf9K2bdv05ptv6oEHHuiwfZeVlSk9PV1btmzRX/7yF/3pT3/SrFmzOmz922+/XXl5eVqwYIG2bt2q5557Tu+8806To0AdjeADAB3NxynFPfnTnaP/Ef/pftzCk+Z6Pn369NE//vEPNTQ06OKLL1ZMTIxmzZqlkJAQ+fj4yMfHRytWrFBhYaFiYmJ055136rHHHuuw/d9///1asWKFzj33XL344otatmyZhg4d2uo206ZN0//8z//ohRde0LBhw5SYmKgXXnjBfe7Raaedpr/97W/atGmTYmNjlZGR0exbed4aMWKEXn75Za1YsUIxMTH6wx/+oHnz5mnq1Kkdtg9JOv3007V48WKNHTtW5557rt5//3397W9/U2hoqMLCwvTCCy/olVde0dChQ/Xwww93aLi74YYbdODAAY0cOVIzZszQ7bffrltuuaXD1h87dqyeffZZLViwQMOHD9f//u//6s477/T6r663lcMcjzfUThG1tbUKCQlRTU2NgoODT3Q5AE6QH374Qdu3b1d0dHT7/hEuWyUVzvI80TkwqjH0RF3Z7jq7AofDoddff12TJk060aXgCElJSTrvvPM8/iTF8XDzzTfrX//6l9ata/7E/5Z+Nq38/uYcHwDoLFFXSmdezpWbgRb88Y9/1IQJE9SjRw+98847evHFF5tciLKjEXwAoDP5OKXwpBNdBXBSKigo0KOPPqo9e/aof//+euqppzRt2rRO3SfBBwBwwnC2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YV588UVz3nnnmVmzZh3fgi2y2t+sWbPMI488YgoKCkxJSYmZM2eO6d69u/nss8+Oc+VtZ7XHzz77zCxfvtxs3LjRbN++3fz5z382gYGB5rnnnjvOlbeN1f4O2717t+nfv79JTk42w4cPPz7Feslqjx9++KGRZLZs2WLKy8vdt4MHDx7nytvGm9fwsssuMwkJCSY/P99s377d/POf/zT/+Mc/jmPVbWe1v927d3u8bmVlZaZnz57mvvvuO76FW2C1x3Xr1hkfHx/z5JNPmm3btpl169aZc845x0yaNKnTaiT4dJCRI0ea6dOne4wNHjzYzJ49u9n599xzjxk8eLDH2G9+8xszatSoTquxPaz2d6TExMSTPvi0p7/Dhg4dau6///6OLq3DdESPV1xxhbn++us7urQO4W1/kydPNvfee6+57777TvrgY7XHw8Hn+++/Pw7VtZ/V/t555x0TEhJiqqurj0d57dben8HXX3/dOBwOs2PHjs4or0NY7fGxxx4z/fv39xh76qmnTN++fTutRt7q6gD19fUqLCxUcnKyx3hycrI2bNjQ7DYfffRRk/kXX3yxPv30U/3444+dVqs3vOnvVNIR/R06dEh79uxRz549O6PEduuIHouKirRhwwYlJiZ2Ront4m1/S5Ys0VdffaX77ruvs0tst/a8hrGxsYqMjNQvf/lLffjhh51Zpte86e/NN99UfHy8Hn30UZ155pkaOHCgfvvb3+rAgQPHo2RLOuJnMDc3VxdddJH7T0SdbLzpccyYMfrmm2+Ul5cnY4y+++47vfrqq236Q+Tesvy3utDUrl271NDQoPDwcI/x8PBwVVRUNLtNRUVFs/MPHjyoXbt2tfkvyh8P3vR3KumI/h5//HHt27dP/+///b/OKLHd2tNj3759VVVVpYMHDyozM1PTpk3rzFK94k1/W7du1ezZs7Vu3bomf/T4ZORNj5GRkcrJyVFcXJzq6ur05z//Wb/85S+1Zs0anX/++cej7Dbzpr9t27Zp/fr18vf31+uvv65du3bptttu07///e+T7jyf9v47U15ernfeeUfLly/vrBLbzZsex4wZo2XLlmny5Mn64YcfdPDgQV122WX605/+1Gl1nvw/7acQh8Phcd8Y02TsWPObGz9ZWO3vVONtf3/5y1+UmZmpv/71r+rdu3dnldchvOlx3bp12rt3rz7++GPNnj1bv/jFL3Tdddd1Zplea2t/DQ0NSk1N1f3336+BAwcer/I6hJXXcNCgQRo0aJD7/ujRo1VWVqY//vGPJ13wOcxKf4cOHZLD4dCyZcvcf5l7wYIFuvrqq/XMM88oICCg0+u1ytt/Z1544QWdfvrpmjRpUidV1nGs9Lhp0ybdcccd+sMf/qCLL75Y5eXluvvuuzV9+nTl5uZ2Sn0Enw7Qq1cvOZ3OJom2srKySfI9LCIiotn53bp1U2hoaKfV6g1v+juVtKe/lStX6qabbtIrr7yiiy66qDPLbJf29BgdHS1JGjZsmL777jtlZmaedMHHan979uzRp59+qqKiIs2cOVNS4y9RY4y6deum1atX68ILLzwutbdVR/0cjho1Si+99FJHl9du3vQXGRmpM8880x16JGnIkCEyxuibb77RgAEDOrVmK9rz+hlj9Pzzz2vKlCny9fXtzDLbxZses7KyNHbsWN19992SpHPPPVc9evTQ+PHj9eCDD3bKux+c49MBfH19FRcXp/z8fI/x/Px8jRkzptltRo8e3WT+6tWrFR8fr+7du3dard7wpr9Tibf9/eUvf9HUqVO1fPnyTn0/uiN01GtojFFdXV1Hl9duVvsLDg7W559/ruLiYvdt+vTpGjRokIqLi5WQkHC8Sm+zjnoNi4qKTqq30g/zpr+xY8fq22+/1d69e91jJSUl8vHxUd++fTu1Xqva8/qtXbtWX375pW666abOLLHdvOlx//798vHxjCJOp1PSz++CdLhOO23aZg5/hC83N9ds2rTJpKWlmR49erjPvp89e7aZMmWKe/7hj7PfeeedZtOmTSY3N/eU+Dh7W/szxpiioiJTVFRk4uLiTGpqqikqKjJffPHFiSj/mKz2t3z5ctOtWzfzzDPPeHzcdPfu3SeqhWOy2uPTTz9t3nzzTVNSUmJKSkrM888/b4KDg01GRsaJaqFV3nyPHulU+FSX1R6feOIJ8/rrr5uSkhKzceNGM3v2bCPJvPbaayeqhVZZ7W/Pnj2mb9++5uqrrzZffPGFWbt2rRkwYICZNm3aiWqhVd5+j15//fUmISHheJfrFas9LlmyxHTr1s1kZ2ebr776yqxfv97Ex8ebkSNHdlqNBJ8O9MwzzxiXy2V8fX3NiBEjzNq1a92P3XjjjSYxMdFj/po1a0xsbKzx9fU1/fr1M4sWLTrOFVtjtT9JTW4ul+v4Fm2Blf4SExOb7e/GG288/oVbYKXHp556ypxzzjkmMDDQBAcHm9jYWJOdnW0aGhpOQOVtY/V79EinQvAxxlqPjzzyiDn77LONv7+/OeOMM8y4cePM22+/fQKqbjurr+HmzZvNRRddZAICAkzfvn1Nenq62b9//3Guuu2s9rd7924TEBBgcnJyjnOl3rPa41NPPWWGDh1qAgICTGRkpPnVr35lvvnmm06rz2FMZx1LAgAAOLlwjg8AALANgg8AALANgg8AALANgg8AALANgg8AALANgg8AALANgg8AALANgg8AALANgg8AALANgg8AALANgg8AALANgg8AALCN/w+gYJQa1ljBAwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from scipy.stats import invgamma\n",
    "rv = invgamma(a=alpha,scale=beta*1.0)\n",
    "theta = rv.rvs()\n",
    "lambda_weibull = theta**(1/k)\n",
    "y_pred_check = np.array([lambda_weibull*np.random.weibull(a=k) for i in range(100)]).mean(axis=0)\n",
    "\n",
    "# plt.plot(x_test,y_test,label=\"y_test\")\n",
    "plt.scatter(y_test,mu,color=\"orange\",label=\"mean pred from sampling\")\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1cf4af1a",
   "metadata": {},
   "outputs": [],
   "source": [
    "y_pred_check,mu"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2bf16852",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.scatter(y_pred_check,mu,color=\"orange\",label=\"mean pred from sampling\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d5a23e5",
   "metadata": {},
   "outputs": [],
   "source": [
    "fig,ax=plt.subplots(figsize=(18,6))\n",
    "plt.subplot(131)\n",
    "plt.hist(y_train,bins=50,density=True)\n",
    "plt.title(\"Distribnution of y-train\")\n",
    "plt.subplot(132)\n",
    "plt.hist(edl_model.predict(x_test)[:,0],bins=50,density=True)\n",
    "plt.title(\"Distribnution of y-pred (Normal)\")\n",
    "plt.subplot(133)\n",
    "plt.hist(mu,bins=50,density=True)\n",
    "plt.title(\"Distribnution of y-pred (Weibull)\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b0738ce0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a6058157",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c00abd15",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8cd62aa7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ec5278a3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0d031793",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
