{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 60,
   "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": 61,
   "id": "186f4491",
   "metadata": {},
   "outputs": [],
   "source": [
    "import tensorflow as tf"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "c743a4bb",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "from os.path import dirname\n",
    "sys.path.append(dirname(\"../\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 120,
   "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": 64,
   "id": "4af3f469",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "351f8840",
   "metadata": {},
   "source": [
    "### Read data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 228,
   "id": "d53261a3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(40520, 44) (40520,)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "((30390, 44), (10130, 44), (30390,), (10130,))"
      ]
     },
     "execution_count": 228,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "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.ccf_ad>0.0]\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[\"ccf_ad\"]\n",
    "\n",
    "print(X.shape,y.shape)\n",
    "\n",
    "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": "code",
   "execution_count": 229,
   "id": "cb345eb4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Distribution of y')"
      ]
     },
     "execution_count": 229,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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w8NVUlLiVv75559Lkrp06dKk9iWpU6dOatOmzWXp54477lDv3r310ksvqX379vr444+1Zs2aJo0XaOlYqQFMrri4WJMnT1ZYWJjHJ2Y8CQgIUFJSkhYvXixJzktBjVmd8MbBgwe1f/9+l7LXX39dHTp0cK44XHgK6JNPPnGpt2nTJrf2rFZro8d255136v3333eGiwtWr16tdu3a+eUR8JCQECUlJWnDhg0u4zp37pzWrFmjrl276oYbbvC5/YkTJ2rz5s2aNm2aIiIidP/99zd5zEBLxkoNYCKffvqp6urqVFdXp7KyMu3YsUOrVq1SQECANm7c6Hwk25OlS5fq/fff17BhwxQTE6MzZ85o5cqVkuTctK9Dhw6KjY3VH//4R915553q3LmzunTp0uDjx5cSHR2te++9V7NmzVJUVJTWrFmjvLw8Pf/882rXrp0k6dZbb9X3v/99TZ48WXV1derUqZM2btyoDz/80K29Pn36aMOGDVqyZInsdrvatGnjsm/Pt82cOVN//vOfdfvtt+vpp59W586d9dprr2nz5s2aN2+ewsLCfDqn78rOztZdd92l22+/XZMnT1ZwcLBycnL06aefau3atV7v6vxtDz74oKZNm6YPPvhATz75pIKDg/0yZqDFauYblQH4wYUnhC68goODjWuvvdYYMGCA8dxzzxllZWVux3z3iSSHw2H89Kc/NWJjYw2r1WqEh4cbAwYMMDZt2uRy3NatW42+ffsaVqvVkGSMHTvWpb0vvvjikn0Zxvmnn4YNG2a89dZbRq9evYzg4GAjLi7OePHFF92OP3z4sJGWlmaEhoYa11xzjfHEE08Ymzdvdnv66csvvzRGjhxpdOzY0bBYLC59ysNTWwcOHDDuueceIywszAgODjZuvvlmY9WqVS51Ljz99Oabb7qUX3ha6bv1PdmxY4dxxx13GCEhIUbbtm2N/v37G3/60588tteYp5++bdy4cUZgYKBx8uRJr44DzMhiGJd4JAIAcFWqra1VXFycbrvtNv3hD39o7uEAzY7LTwDQwnzxxRc6dOiQVq1apX/+85+aOnVqcw8JuCoQagCghdm8ebMefvhhRUVFKScnh8e4gf+Py08AAMAUeKQbAACYAqEGAACYAqEGAACYQqu6UfjcuXP6/PPP1aFDhyZteAUAAK4cwzB0+vRpRUdHq02bhtdjWlWo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p4ULF/ptrL5gpQYAgFaipKTE+fe6dev09NNP69ChQ86ytm3bNsew/IaVGgAAWonIyEjnKywsTBaLxaXsgw8+kN1ul81mU0JCgmbPnq26ujrn8bNmzVJMTIysVquio6M1ceJESdLAgQN1/PhxZWZmOld9mgMrNQAAQO+++64efPBBLVq0SKmpqfrHP/6hCRMmSJJmzpypt956SwsWLNAbb7yhXr16qbS0VPv375ckbdiwQTfffLMmTJig8ePHN9s5EGoAAIB+/etfa+rUqRo7dqwkKSEhQc8884x+9atfaebMmSouLlZkZKQGDRqkoKAgxcTE6Ac/+IEkqXPnzgoICFCHDh0UGRnZbOfA5ScAAKC9e/dqzpw5at++vfM1fvx4lZSUqLq6Wvfff7+++eYbJSQkaPz48dq4caPLpamrASs1AABA586d0+zZs3Xfffe5fWaz2dStWzcdOnRIeXl52rp1qx577DG98MILys/PV1BQUDOM2B2hBgAAqF+/fjp06JCuv/76Buu0bdtW9957r+6991798pe/VI8ePXTgwAH169dPwcHBqq+vv4IjdkeoAQAAevrpp3X33XerW7duuv/++9WmTRt98sknOnDggJ599lm98sorqq+vV1JSktq1a6ff//73atu2rWJjYyWd36fmgw8+0AMPPCCr1aouXbpc8XMg1AAA4G8tcJffwYMH689//rPmzJmjefPmKSgoSD169NCjjz4qSerYsaPmzp2rrKws1dfXq0+fPvrTn/6k8PBwSdKcOXP0i1/8Qt27d1dNTY0Mw7ji52AxmqPXZlJVVaWwsDBVVlYqNDS0uYdzeW3LluNoRZOb2RUzQZl33eCHAQGAuZw5c0ZFRUWKj4+XzWZr7uG0eBebz8Z+f/P0EwAAMAVCDQAAMAVCDQAAMAVCDQAAMAVCDQAATdCKnre5rPwxj4QaAAB8cGEX3erq6mYeiTlcmMem7E7MPjUAAPggICBAHTt2VFlZmSSpXbt2slgszTyqlscwDFVXV6usrEwdO3ZUQECAz20RagAA8NGFX6S+EGzgu44dOzb5F74JNQAA+MhisSgqKkrXXnutzp4929zDabGCgoKatEJzAaEGl7Qg77Bf2mFnYgBmFRAQ4JcvZTQNNwoDAABTINQAAABTINQAAABTINQAAABT4Ebhq8227OYeAQAALRIrNQAAwBQINQAAwBQINQAAwBQINQAAwBQINQAAwBQINQAAwBQINQAAwBQINQAAwBQINQAAwBQINQAAwBQINQAAwBQINQAAwBT4QUtcVP/iZX5pZ1fMBL+0AwBAQ3xaqcnJyVF8fLxsNpvsdrt27Nhx0fr5+fmy2+2y2WxKSEjQ0qVLXT5fvny5UlNT1alTJ3Xq1EmDBg3SRx995FJn1qxZslgsLq/IyEhfhg8AAEzI65WadevWKSMjQzk5OfrhD3+o3/3udxoyZIg+++wzxcTEuNUvKirS0KFDNX78eK1Zs0Z//etf9dhjj+maa67RiBEjJEnbt2/X6NGjlZKSIpvNpnnz5iktLU0HDx7Udddd52yrV69e2rp1q/N9QECAL+d81XMcrWjuIQAA0OJ4HWpefPFF/fznP9ejjz4qSVq4cKHeffddLVmyRNnZ2W71ly5dqpiYGC1cuFCS1LNnT+3Zs0fz5893hprXXnvN5Zjly5frrbfe0nvvvaeHHnro/wYbGOjV6kxNTY1qamqc76uqqhp9LAAAaFm8uvxUW1urvXv3Ki0tzaU8LS1NO3fu9HiMw+Fwqz948GDt2bNHZ8+e9XhMdXW1zp49q86dO7uUHzlyRNHR0YqPj9cDDzygo0ePXnS82dnZCgsLc766det2qVMEAAAtlFehpry8XPX19YqIiHApj4iIUGlpqcdjSktLPdavq6tTeXm5x2OmTp2q6667ToMGDXKWJSUlafXq1Xr33Xe1fPlylZaWKiUlRRUVDV+qmTZtmiorK52vEydONPZUAQBAC+PT008Wi8XlvWEYbmWXqu+pXJLmzZuntWvXavv27bLZbM7yIUOGOP/u06ePkpOT1b17d7366qvKysry2K/VapXVar30CQEAgBbPq1DTpUsXBQQEuK3KlJWVua3GXBAZGemxfmBgoMLDw13K58+fr+eee05bt27VTTfddNGxhISEqE+fPjpy5Ig3pwAAAEzKq8tPwcHBstvtysvLcynPy8tTSkqKx2OSk5Pd6m/ZskWJiYkKCgpylr3wwgt65pln9M477ygxMfGSY6mpqVFhYaGioqK8OQUAAGBSXu9Tk5WVpZdfflkrV65UYWGhMjMzVVxcrPT0dEnn72P59hNL6enpOn78uLKyslRYWKiVK1dqxYoVmjx5srPOvHnz9OSTT2rlypWKi4tTaWmpSktL9dVXXznrTJ48Wfn5+SoqKtLu3bs1cuRIVVVVaezYsU05fwAAYBJe31MzatQoVVRUaM6cOSopKVHv3r2Vm5ur2NhYSVJJSYmKi4ud9ePj45Wbm6vMzEwtXrxY0dHRWrRokfNxbun8Zn61tbUaOXKkS18zZ87UrFmzJEknT57U6NGjVV5ermuuuUb9+/fXrl27nP0CAIDWzWJcuGu3FaiqqlJYWJgqKysVGhra3MPxbFu2KTff2xUzQZl33dDcwwAAtECN/f7mBy0BAIApEGoAAIApEGoAAIApEGoAAIApEGoAAIApEGoAAIApEGoAAIApEGoAAIApEGoAAIApEGoAAIApeP3bT4Av+hcvk7aFN62R26f5ZzAAAFMi1OCKaepvWu2qOyxJ/IYUAMAjLj8BAABTINQAAABTINQAAABTINQAAABTINQAAABTINQAAABTINQAAABTINQAAABTINQAAABTINQAAABTINQAAABTINQAAABTINQAAABTINQAAABTINQAAABTINQAAABTINQAAABTINQAAABTCGzuAQCN1b942fk/toU3raHbpzV9MACAqw4rNQAAwBQINQAAwBQINQAAwBQINQAAwBQINQAAwBQINQAAwBQINQAAwBQINQAAwBQINQAAwBQINQAAwBQINQAAwBQINQAAwBQINQAAwBQINQAAwBQINQAAwBQINQAAwBR8CjU5OTmKj4+XzWaT3W7Xjh07Llo/Pz9fdrtdNptNCQkJWrp0qcvny5cvV2pqqjp16qROnTpp0KBB+uijj5rcL8zJcbSiSa8FeYe1IO9wc58GAMDPvA4169atU0ZGhmbMmKGCggKlpqZqyJAhKi4u9li/qKhIQ4cOVWpqqgoKCjR9+nRNnDhR69evd9bZvn27Ro8erW3btsnhcCgmJkZpaWk6deqUz/0CAIDWxWIYhuHNAUlJSerXr5+WLFniLOvZs6eGDx+u7Oxst/pTpkzRpk2bVFhY6CxLT0/X/v375XA4PPZRX1+vTp066aWXXtJDDz3kU7+eVFVVKSwsTJWVlQoNDW3UMVfctmw5jlY09yhMbVfMBElS5l03NPNIAACN0djvb69Wampra7V3716lpaW5lKelpWnnzp0ej3E4HG71Bw8erD179ujs2bMej6murtbZs2fVuXNnn/uVpJqaGlVVVbm8AACAOXkVasrLy1VfX6+IiAiX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W5tvvvmm8f3vf98ICgoyevToYaxfv96rfpvDmTNnjJkzZxpnzpxp1nG0Bsz1lcNcXxnM85XDXF8ZV8M8e71PDQAAwNWIX+kGAACmQKgBAACmQKgBAACmQKgBAACmQKgBAACmQKhpgpycHMXHx8tms8lut2vHjh3NPaQWLTs7W7feeqs6dOiga6+9VsOHD9ehQ4dc6hiGoVmzZik6Olpt27bVwIEDdfDgwWYasTlkZ2fLYrEoIyPDWcY8+8+pU6f04IMPKjw8XO3atdMtt9yivXv3Oj9nrv2jrq5OTz75pOLj49W2bVslJCRozpw5OnfunLMOc+2bDz74QPfcc4+io6NlsVj09ttvu3zemHmtqanRE088oS5duigkJET33nuvTp486f/BNtvD5C3cG2+8YQQFBRnLly83PvvsM2PSpElGSEiIcfz48eYeWos1ePBgY9WqVcann35q7Nu3zxg2bJgRExNjfPXVV846c+fONTp06GCsX7/eOHDggDFq1CgjKirKqKqqasaRt1wfffSRERcXZ9x0003GpEmTnOXMs398+eWXRmxsrDFu3Dhj9+7dRlFRkbF161bj73//u7MOc+0fzz77rBEeHm78+c9/NoqKiow333zTaN++vbFw4UJnHebaN7m5ucaMGTOM9evXG5KMjRs3unzemHlNT083rrvuOiMvL8/4+OOPjdtvv924+eabjbq6Or+OlVDjox/84AdGenq6S1mPHj2MqVOnNtOIzKesrMyQ5Nxk8dy5c0ZkZKQxd+5cZ50zZ84YYWFhxtKlS5trmC3W6dOnje9973tGXl6eMWDAAGeoYZ79Z8qUKcZtt93W4OfMtf8MGzbMeOSRR1zK7rvvPuPBBx80DIO59pfvhprGzOu///1vIygoyHjjjTecdU6dOmW0adPGeOedd/w6Pi4/+aC2tlZ79+5VWlqaS3laWpp27tzZTKMyn8rKSklS586dJUlFRUUqLS11mXer1aoBAwYw7z745S9/qWHDhmnQoEEu5cyz/2zatEmJiYm6//77de2116pv375avny583Pm2n9uu+02vffeezp8+LAkaf/+/frwww81dOhQScz15dKYed27d6/Onj3rUic6Olq9e/f2+9x7/dtPkMrLy1VfX+/2C+ERERFuvyQO3xiGoaysLN12223q3bu3JDnn1tO8Hz9+/IqPsSV744039PHHH+tvf/ub22fMs/8cPXpUS5YsUVZWlqZPn66PPvpIEydOlNVq1UMPPcRc+9GUKVNUWVmpHj16KCAgQPX19fr1r3+t0aNHS+Lf68ulMfNaWlqq4OBgderUya2Ov78zCTVNYLFYXN4bhuFWBt88/vjj+uSTT1x+1PQC5r1pTpw4oUmTJmnLli2y2WwN1mOem+7cuXNKTEzUc889J0nq27evDh48qCVLluihhx5y1mOum27dunVas2aNXn/9dfXq1Uv79u1TRkaGoqOjNXbsWGc95vry8GVeL8fcc/nJB126dFFAQIBbwiwrK3NLq/DeE088oU2bNmnbtm3q2rWrszwyMlKSmPcm2rt3r8rKymS32xUYGKjAwEDl5+dr0aJFCgwMdM4l89x0UVFRuvHGG13KevbsqeLiYkn8O+1P//3f/62pU6fqgQceUJ8+fTRmzBhlZmYqOztbEnN9uTRmXiMjI1VbW6t//etfDdbxF0KND4KDg2W325WXl+dSnpeXp5SUlGYaVctnGIYef/xxbdiwQe+//77i4+NdPo+Pj1dkZKTLvNfW1io/P59598Kdd96pAwcOaN++fc5XYmKi/vM//1P79u1TQkIC8+wnP/zhD922JTh8+LBiY2Ml8e+0P1VXV6tNG9evtICAAOcj3cz15dGYebXb7QoKCnKpU1JSok8//dT/c+/X245bkQuPdK9YscL47LPPjIyMDCMkJMQ4duxYcw+txfqv//ovIywszNi+fbtRUlLifFVXVzvrzJ071wgLCzM2bNhgHDhwwBg9ejSPZPrBt59+Mgzm2V8++ugjIzAw0Pj1r39tHDlyxHjttdeMdu3aGWvWrHHWYa79Y+zYscZ1113nfKR7w4YNRpcuXYxf/epXzjrMtW9Onz5tFBQUGAUFBYYk48UXXzQKCgqcW5g0Zl7T09ONrl27Glu3bjU+/vhj44477uCR7qvN4sWLjdjYWCM4ONjo16+f89Fj+EaSx9eqVaucdc6dO2fMnDnTiIyMNKxWq/GjH/3IOHDgQPMN2iS+G2qYZ//505/+ZPTu3duwWq1Gjx49jGXLlrl8zlz7R1VVlTFp0iQjJibGsNlsRkJCgjFjxgyjpqbGWYe59s22bds8/rd57NixhmE0bl6/+eYb4/HHHzc6d+5stG3b1rj77ruN4uJiv4/VYhiG4d+1HwAAgCuPe2oAAIApEGoAAIApEGoAAIApEGoAAIApEGoAAIApEGoAAIApEGoAAIApEGoAAIApEGoAAIApEGoAAIApEGoAAIAp/D+uEuJcjbv8RwAAAABJRU5ErkJggg==",
      "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": 230,
   "id": "cbbe6d21",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/500\n",
      "26/26 [==============================] - 1s 5ms/step - loss: 10.5897\n",
      "Epoch 2/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 10.0800\n",
      "Epoch 3/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 9.6641\n",
      "Epoch 4/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 9.2157\n",
      "Epoch 5/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 8.7441\n",
      "Epoch 6/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 8.2670\n",
      "Epoch 7/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 7.7983\n",
      "Epoch 8/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 7.3487\n",
      "Epoch 9/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 6.9266\n",
      "Epoch 10/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 6.5382\n",
      "Epoch 11/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 6.1887\n",
      "Epoch 12/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 5.8835\n",
      "Epoch 13/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 5.6255\n",
      "Epoch 14/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 5.4147\n",
      "Epoch 15/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 5.2499\n",
      "Epoch 16/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 5.1252\n",
      "Epoch 17/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 5.0344\n",
      "Epoch 18/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.9706\n",
      "Epoch 19/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.9266\n",
      "Epoch 20/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.8971\n",
      "Epoch 21/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.8775\n",
      "Epoch 22/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.8642\n",
      "Epoch 23/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.8552\n",
      "Epoch 24/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.8486\n",
      "Epoch 25/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.8436\n",
      "Epoch 26/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.8394\n",
      "Epoch 27/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.8356\n",
      "Epoch 28/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.8320\n",
      "Epoch 29/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.8286\n",
      "Epoch 30/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.8252\n",
      "Epoch 31/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.8217\n",
      "Epoch 32/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.8182\n",
      "Epoch 33/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.8146\n",
      "Epoch 34/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.8109\n",
      "Epoch 35/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.8072\n",
      "Epoch 36/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.8033\n",
      "Epoch 37/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.7994\n",
      "Epoch 38/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.7954\n",
      "Epoch 39/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.7912\n",
      "Epoch 40/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.7870\n",
      "Epoch 41/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.7827\n",
      "Epoch 42/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.7783\n",
      "Epoch 43/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.7738\n",
      "Epoch 44/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.7692\n",
      "Epoch 45/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.7645\n",
      "Epoch 46/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.7597\n",
      "Epoch 47/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.7548\n",
      "Epoch 48/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.7497\n",
      "Epoch 49/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.7446\n",
      "Epoch 50/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.7393\n",
      "Epoch 51/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.7340\n",
      "Epoch 52/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.7285\n",
      "Epoch 53/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.7229\n",
      "Epoch 54/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.7171\n",
      "Epoch 55/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.7113\n",
      "Epoch 56/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.7053\n",
      "Epoch 57/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.6992\n",
      "Epoch 58/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.6930\n",
      "Epoch 59/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.6866\n",
      "Epoch 60/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.6801\n",
      "Epoch 61/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.6735\n",
      "Epoch 62/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.6668\n",
      "Epoch 63/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.6599\n",
      "Epoch 64/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.6530\n",
      "Epoch 65/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.6459\n",
      "Epoch 66/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.6387\n",
      "Epoch 67/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.6313\n",
      "Epoch 68/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.6239\n",
      "Epoch 69/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.6164\n",
      "Epoch 70/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.6088\n",
      "Epoch 71/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.6012\n",
      "Epoch 72/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.5935\n",
      "Epoch 73/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.5858\n",
      "Epoch 74/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.5781\n",
      "Epoch 75/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.5703\n",
      "Epoch 76/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.5626\n",
      "Epoch 77/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.5550\n",
      "Epoch 78/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.5474\n",
      "Epoch 79/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.5399\n",
      "Epoch 80/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.5326\n",
      "Epoch 81/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.5254\n",
      "Epoch 82/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.5184\n",
      "Epoch 83/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.5116\n",
      "Epoch 84/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.5050\n",
      "Epoch 85/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4986\n",
      "Epoch 86/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4926\n",
      "Epoch 87/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4868\n",
      "Epoch 88/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4813\n",
      "Epoch 89/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4761\n",
      "Epoch 90/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4712\n",
      "Epoch 91/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4667\n",
      "Epoch 92/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.4624\n",
      "Epoch 93/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4584\n",
      "Epoch 94/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.4548\n",
      "Epoch 95/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4514\n",
      "Epoch 96/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.4483\n",
      "Epoch 97/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.4455\n",
      "Epoch 98/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.4429\n",
      "Epoch 99/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4406\n",
      "Epoch 100/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4385\n",
      "Epoch 101/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.4366\n",
      "Epoch 102/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4349\n",
      "Epoch 103/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4333\n",
      "Epoch 104/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4320\n",
      "Epoch 105/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4308\n",
      "Epoch 106/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4297\n",
      "Epoch 107/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4288\n",
      "Epoch 108/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4279\n",
      "Epoch 109/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4272\n",
      "Epoch 110/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4266\n",
      "Epoch 111/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4260\n",
      "Epoch 112/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4255\n",
      "Epoch 113/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4251\n",
      "Epoch 114/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4247\n",
      "Epoch 115/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4244\n",
      "Epoch 116/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4241\n",
      "Epoch 117/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4238\n",
      "Epoch 118/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4236\n",
      "Epoch 119/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4234\n",
      "Epoch 120/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4233\n",
      "Epoch 121/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4232\n",
      "Epoch 122/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4230\n",
      "Epoch 123/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4229\n",
      "Epoch 124/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4228\n",
      "Epoch 125/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4228\n",
      "Epoch 126/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4227\n",
      "Epoch 127/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4226\n",
      "Epoch 128/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4226\n",
      "Epoch 129/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4225\n",
      "Epoch 130/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4225\n",
      "Epoch 131/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4225\n",
      "Epoch 132/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4225\n",
      "Epoch 133/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4224\n",
      "Epoch 134/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4224\n",
      "Epoch 135/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4223\n",
      "Epoch 136/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4223\n",
      "Epoch 137/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4223\n",
      "Epoch 138/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4223\n",
      "Epoch 139/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4222\n",
      "Epoch 140/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4222\n",
      "Epoch 141/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4223\n",
      "Epoch 142/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4222\n",
      "Epoch 143/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4221\n",
      "Epoch 144/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4221\n",
      "Epoch 145/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4221\n",
      "Epoch 146/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4221\n",
      "Epoch 147/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4220\n",
      "Epoch 148/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4220\n",
      "Epoch 149/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4220\n",
      "Epoch 150/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4219\n",
      "Epoch 151/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4219\n",
      "Epoch 152/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4219\n",
      "Epoch 153/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4218\n",
      "Epoch 154/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4217\n",
      "Epoch 155/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4217\n",
      "Epoch 156/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4217\n",
      "Epoch 157/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4216\n",
      "Epoch 158/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4215\n",
      "Epoch 159/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4215\n",
      "Epoch 160/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4214\n",
      "Epoch 161/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4214\n",
      "Epoch 162/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4213\n",
      "Epoch 163/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4212\n",
      "Epoch 164/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4211\n",
      "Epoch 165/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4210\n",
      "Epoch 166/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4209\n",
      "Epoch 167/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4207\n",
      "Epoch 168/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4206\n",
      "Epoch 169/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4205\n",
      "Epoch 170/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4203\n",
      "Epoch 171/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4201\n",
      "Epoch 172/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.4199\n",
      "Epoch 173/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4198\n",
      "Epoch 174/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4195\n",
      "Epoch 175/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4192\n",
      "Epoch 176/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.4188\n",
      "Epoch 177/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4185\n",
      "Epoch 178/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4181\n",
      "Epoch 179/500\n",
      "26/26 [==============================] - 0s 7ms/step - loss: 4.4176\n",
      "Epoch 180/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4171\n",
      "Epoch 181/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4165\n",
      "Epoch 182/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4157\n",
      "Epoch 183/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.4150\n",
      "Epoch 184/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4140\n",
      "Epoch 185/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4130\n",
      "Epoch 186/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4120\n",
      "Epoch 187/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4108\n",
      "Epoch 188/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4095\n",
      "Epoch 189/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4083\n",
      "Epoch 190/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4071\n",
      "Epoch 191/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4060\n",
      "Epoch 192/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4049\n",
      "Epoch 193/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4040\n",
      "Epoch 194/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4032\n",
      "Epoch 195/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4024\n",
      "Epoch 196/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4017\n",
      "Epoch 197/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4012\n",
      "Epoch 198/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4007\n",
      "Epoch 199/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4003\n",
      "Epoch 200/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4000\n",
      "Epoch 201/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3997\n",
      "Epoch 202/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3994\n",
      "Epoch 203/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3992\n",
      "Epoch 204/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3992\n",
      "Epoch 205/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3989\n",
      "Epoch 206/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3987\n",
      "Epoch 207/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3986\n",
      "Epoch 208/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3986\n",
      "Epoch 209/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3984\n",
      "Epoch 210/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3984\n",
      "Epoch 211/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3984\n",
      "Epoch 212/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3982\n",
      "Epoch 213/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3981\n",
      "Epoch 214/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3983\n",
      "Epoch 215/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3984\n",
      "Epoch 216/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.3981\n",
      "Epoch 217/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3980\n",
      "Epoch 218/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3980\n",
      "Epoch 219/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.3980\n",
      "Epoch 220/500\n",
      "26/26 [==============================] - 0s 4ms/step - loss: 4.3981\n",
      "Epoch 221/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 222/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 223/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 224/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 225/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 226/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 227/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 228/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 229/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 230/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 231/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 232/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 233/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3980\n",
      "Epoch 234/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 235/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 236/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 237/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 238/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 239/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 240/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 241/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 242/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 243/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 244/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 245/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 246/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 247/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 248/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 249/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 250/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 251/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 252/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 253/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3978\n",
      "Epoch 254/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 255/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3978\n",
      "Epoch 256/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3978\n",
      "Epoch 257/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3978\n",
      "Epoch 258/500\n",
      "26/26 [==============================] - 0s 7ms/step - loss: 4.3978\n",
      "Epoch 259/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 260/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 261/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 262/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3978\n",
      "Epoch 263/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 264/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 265/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3977\n",
      "Epoch 266/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3979\n",
      "Epoch 267/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 268/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 269/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 270/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 271/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 272/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 273/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3977\n",
      "Epoch 274/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 275/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 276/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 277/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 278/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 279/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 280/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 281/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 282/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 283/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 284/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 285/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 286/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3980\n",
      "Epoch 287/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3978\n",
      "Epoch 288/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 289/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 290/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 291/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 292/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 293/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3980\n",
      "Epoch 294/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 295/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 296/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3980\n",
      "Epoch 297/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 298/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 299/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 300/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 301/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 302/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 303/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 304/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 305/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3981\n",
      "Epoch 306/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3977\n",
      "Epoch 307/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3980\n",
      "Epoch 308/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 309/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 310/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 311/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 312/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 313/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3981\n",
      "Epoch 314/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3981\n",
      "Epoch 315/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 316/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 317/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 318/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 319/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 320/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 321/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 322/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 323/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 324/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 325/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 326/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3978\n",
      "Epoch 327/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 328/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 329/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 330/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 331/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3979\n",
      "Epoch 332/500\n",
      "26/26 [==============================] - 0s 7ms/step - loss: 4.3979\n",
      "Epoch 333/500\n",
      "26/26 [==============================] - 0s 7ms/step - loss: 4.3979\n",
      "Epoch 334/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3978\n",
      "Epoch 335/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3978\n",
      "Epoch 336/500\n",
      "26/26 [==============================] - 0s 7ms/step - loss: 4.3978\n",
      "Epoch 337/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3978\n",
      "Epoch 338/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 339/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 340/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3978\n",
      "Epoch 341/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 342/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 343/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 344/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 345/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 346/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 347/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 348/500\n",
      "26/26 [==============================] - 0s 7ms/step - loss: 4.3979\n",
      "Epoch 349/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 350/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 351/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 352/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 353/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3977\n",
      "Epoch 354/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 355/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3980\n",
      "Epoch 356/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 357/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 358/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 359/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3982\n",
      "Epoch 360/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 361/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 362/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 363/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 364/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 365/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 366/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 367/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3980\n",
      "Epoch 368/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 369/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 370/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 371/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 372/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 373/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 374/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 375/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 376/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 377/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3980\n",
      "Epoch 378/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 379/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 380/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 381/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 382/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 383/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 384/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 385/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3981\n",
      "Epoch 386/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 387/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 388/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 389/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3977\n",
      "Epoch 390/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 391/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 392/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 393/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3980\n",
      "Epoch 394/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 395/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 396/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 397/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 398/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 399/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 400/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 401/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 402/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 403/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 404/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 405/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 406/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 407/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 408/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 409/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3980\n",
      "Epoch 410/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3979\n",
      "Epoch 411/500\n",
      "26/26 [==============================] - 0s 7ms/step - loss: 4.3979\n",
      "Epoch 412/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3978\n",
      "Epoch 413/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3979\n",
      "Epoch 414/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3980\n",
      "Epoch 415/500\n",
      "26/26 [==============================] - 0s 7ms/step - loss: 4.3978\n",
      "Epoch 416/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3979\n",
      "Epoch 417/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 418/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 419/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3978\n",
      "Epoch 420/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 421/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 422/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 423/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 424/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 425/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 426/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 427/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 428/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 429/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 430/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 431/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 432/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 433/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 434/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 435/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 436/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 437/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 438/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 439/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 440/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 441/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3979\n",
      "Epoch 442/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 443/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 444/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 445/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 446/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 447/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 448/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 449/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 450/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 451/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 452/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 453/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 454/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 455/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3979\n",
      "Epoch 456/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 457/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3979\n",
      "Epoch 458/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3978\n",
      "Epoch 459/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 460/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3981\n",
      "Epoch 461/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 462/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 463/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 464/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 465/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 466/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3977\n",
      "Epoch 467/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 468/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 469/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 470/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 471/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 472/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3980\n",
      "Epoch 473/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3981\n",
      "Epoch 474/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 475/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 476/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 477/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 478/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 479/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 480/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.4283\n",
      "Epoch 481/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3982\n",
      "Epoch 482/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 483/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 484/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n",
      "Epoch 485/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3979\n",
      "Epoch 486/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3979\n",
      "Epoch 487/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3980\n",
      "Epoch 488/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3979\n",
      "Epoch 489/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3978\n",
      "Epoch 490/500\n",
      "26/26 [==============================] - 0s 7ms/step - loss: 4.3978\n",
      "Epoch 491/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3980\n",
      "Epoch 492/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3978\n",
      "Epoch 493/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3982\n",
      "Epoch 494/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 495/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3979\n",
      "Epoch 496/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 497/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 498/500\n",
      "26/26 [==============================] - 0s 6ms/step - loss: 4.3978\n",
      "Epoch 499/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3978\n",
      "Epoch 500/500\n",
      "26/26 [==============================] - 0s 5ms/step - loss: 4.3979\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<keras.callbacks.History at 0x17c277cd0>"
      ]
     },
     "execution_count": 230,
     "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=\"relu\"),\n",
    "        tf.keras.layers.Dense(64, activation=\"relu\"),\n",
    "        tf.keras.layers.Dense(32, activation=\"softmax\"),\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=1200, epochs=500)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 231,
   "id": "2b40f9db",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "317/317 [==============================] - 0s 788us/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": 232,
   "id": "7cdccce5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "421.33042791366654"
      ]
     },
     "execution_count": 232,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mean_squared_error(y_test,mu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 233,
   "id": "87e45516",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2.8778267"
      ]
     },
     "execution_count": 233,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "alpha.min()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 234,
   "id": "a58f7b35",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "20.251049"
      ]
     },
     "execution_count": 234,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "var = np.sqrt(beta / (v * (alpha - 1)))\n",
    "var.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 235,
   "id": "e57d731e",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/kb/v0p0ypbd0wx1q2qb1kpxmmcc0000gn/T/ipykernel_10528/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": 235,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA+MAAAIgCAYAAADuj7h+AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABjvklEQVR4nO3de1gWdf7/8dcdJ4HFO4Hg5i4ENTwk5rFVsFZNRU1ky1Yri7RMbT1F6qZmbVobHiptNzdT19TU0q3UtbVIzbT8iocwylNm5TFFzPDGU6A4vz/6MdstB0FhuNXn47rmurxn3vfM5zODji9m5jM2wzAMAQAAAAAAy1xX1Q0AAAAAAOBaQxgHAAAAAMBihHEAAAAAACxGGAcAAAAAwGKEcQAAAAAALEYYBwAAAADAYoRxAAAAAAAsRhgHAAAAAMBihHEAAAAAACxGGMcVZ86cObLZbOZUrVo1ORwOtWvXTuPHj1d2dnaR74wdO1Y2m61c2zl9+rTGjh2rNWvWlOt7xW0rOjpaiYmJ5VpPRTl06JDGjh2rzMzMIssuZb9YLT8/X48//rgiIiLk5eWlJk2aVNq2UlNTtXTp0kpZ9969e2Wz2TRnzpxKWT8AXA7OreXDufXK0qdPH0VHRxeZ//3338vPz0/p6elutTabTQ0bNlRBQUGR79hsNg0ePLgym1upoqOj1adPH/Pzt99+K19fX23ZsqXqGnUNI4zjijV79mylp6dr5cqV+uc//6kmTZpo4sSJatCggVatWuVW+9hjj7n9Q1sWp0+f1rhx48r9H4ZL2VZlOnTokMaNG1fsfxg8ra3FmTZtmqZPn64xY8Zo3bp1mjdvXqVtqzLDeEREhNLT09W1a9dKWT8AVATOrWXDufXqMGLECHXs2FFxcXFFlu3YseOa+AV63bp19eCDD+rJJ5+s6qZck7yrugHApYqNjVWLFi3Mz/fee6+efPJJ3X777erevbt2796t8PBwSdJNN92km266qVLbc/r0aQUEBFiyrYpyJbR127Zt8vf397jfQp85c0bVqlUr89UPPz8/tWrVqpJbBQCXh3Pr5bsS2uqp59YLlfdcWx47d+7U0qVLlZaWVmRZYGCgmjVrpueee069evWSv79/hW9fkgoKCnTu3Dn5+flVyvrLavDgwWrRooXWr1+v+Pj4Km3LtYYr47iq1KxZU6+88opOnDih6dOnm/OLu2Vs9erVatu2rUJCQuTv76+aNWvq3nvv1enTp7V3717dcMMNkqRx48aZt+0V3tZTuL4tW7boT3/6k2rUqKE6deqUuK1CS5Ys0a233qpq1aqpdu3a+sc//uG2fM2aNbLZbHrnnXc0ZswYOZ1OVa9eXR06dNCuXbvcai+8zahQ27Zt1bZtW3N9t912myTpkUceMfsxduzYEtt6/vx5TZo0SfXr15efn5/CwsL08MMP6+DBg0W2Exsbq82bN+uOO+5QQECAateurQkTJuj8+fPF9v+3fvnlF40ePVq1atWSr6+vbrzxRg0aNEjHjx83a2w2m/71r3/pzJkzZttL+i31Cy+8IG9vbx04cKDIskcffVQhISH65ZdfSmyPzWbTqVOnNHfuXHNbhfux8PbNFStW6NFHH9UNN9yggIAA5eXl6bvvvtMjjzyimJgYBQQE6MYbb1S3bt20detWt/UXd5t64f7fvn27HnjgAdntdoWHh+vRRx+Vy+W66D4EACtwbuXceqnn1sLtDR48WNOnT1fdunXl5+enW265RQsXLnSrK+1cK0mLFi1SXFycAgMD9bvf/U6dOnXSl19+WWR7c+bMUb169eTn56cGDRrorbfeKrZd06ZNk8PhUMeOHYtdPnHiRP3444/6+9//Xmr/JGn//v166KGHFBYWZm73lVdecTtmhf8PmDRpkv72t7+pVq1a8vPz06effmr+zHz99dfq0aOH7Ha7goODNWzYMJ07d067du1S586dFRQUpOjoaE2aNMlt+7/88ouGDx+uJk2amN+Ni4vTf/7zn4u2XZKaN2+uBg0a6I033ihTPSoOYRxXnbvuukteXl767LPPSqzZu3evunbtKl9fX7355ptKS0vThAkTFBgYqPz8fEVERJi/Ke3bt6/S09OVnp6uZ5991m093bt3180336x33333ov+AZWZmKiUlRU8++aSWLFmi+Ph4PfHEE3r55ZeL1D799NPat2+f/vWvf2nGjBnavXu3unXrVuyzS6Vp1qyZZs+eLUl65plnzH489thjJX7nz3/+s0aOHKmOHTtq2bJleuGFF5SWlqb4+Hj99NNPbrVZWVl68MEH9dBDD2nZsmXq0qWLRo8erfnz55faLsMwdPfdd+vll19WcnKyli9frmHDhmnu3Lm68847zRNvenq67rrrLvn7+5ttL+k27wEDBsjb29vtP4qS9PPPP2vhwoXq27evqlWrVmKb0tPT5e/vr7vuusvc1uuvv+5W8+ijj8rHx0fz5s3Te++9Jx8fHx06dEghISGaMGGC0tLS9M9//lPe3t5q2bJlkf/kleTee+9V3bp19f7772vUqFF6++23uV0MgEfh3Po/nFvLfm4ttGzZMv3jH//Q888/r/fee09RUVF64IEH9N577xWpLe5cm5qaqgceeEC33HKL/v3vf2vevHk6ceKE7rjjDu3YscP87pw5c/TII4+oQYMGev/99/XMM8/ohRde0OrVq4tsZ/ny5frDH/6g664rPg7FxcXpnnvu0cSJE/Xzzz+X2LejR48qPj5eK1as0AsvvKBly5apQ4cOGjFiRLF3HvzjH//Q6tWr9fLLL+ujjz5S/fr1zWU9e/ZU48aN9f7776tfv36aMmWKnnzySd19993q2rWrlixZojvvvFMjR47U4sWLze/l5eXp559/1ogRI7R06VK988475t0sJf0y4kJt27bVRx99JMMwylSPCmIAV5jZs2cbkozNmzeXWBMeHm40aNDA/Pzcc88Zv/1xf++99wxJRmZmZonrOHr0qCHJeO6554osK1zfX//61xKX/VZUVJRhs9mKbK9jx45G9erVjVOnThmGYRiffvqpIcm466673Or+/e9/G5KM9PR0t3X27t27yPbbtGljtGnTxvy8efNmQ5Ixe/bsi7Z1586dhiRj4MCBbnUbN240JBlPP/2023YkGRs3bnSrveWWW4xOnToV2dZvpaWlGZKMSZMmuc1ftGiRIcmYMWOGOa93795GYGBgqev7bW1YWJiRl5dnzps4caJx3XXXGXv27Lno9wMDA4vdp4U/cw8//PBF13Hu3DkjPz/fiImJMZ588klz/p49e4och8L9f+F+GDhwoFGtWjXj/PnzF90eAFQEzq3/WyfnVneXe26VZPj7+xtZWVnmvHPnzhn169c3br75ZnNeSefa/fv3G97e3saQIUPc5p84ccJwOBxGz549DcMwjIKCAsPpdBrNmjVzO3/u3bvX8PHxMaKiosx5R44cMSQZEyZMKLa/hfvmm2++Mby8vIzhw4e79WfQoEHm51GjRhV7zP785z8bNpvN2LVrl2EY//t/QJ06dYz8/Hy32sKfmVdeecVtfpMmTQxJxuLFi815Z8+eNW644Qaje/fuRdpe6Ny5c8bZs2eNvn37Gk2bNnVbVtLP+MyZMw1Jxs6dO0tcLyoeV8ZxVTIu8lu9Jk2ayNfXV/3799fcuXP1ww8/XNJ27r333jLXNmzYUI0bN3ab16tXL+Xm5hYZwTIpKcnt86233ipJ2rdv3yW1s6w+/fRTSSpyi97vf/97NWjQQJ988onbfIfDod///vdu82699daLtrPwN9QXbqdHjx4KDAwssp2yeuKJJ5Sdna13331X0q+3BU6bNk1du3Y1R1EtfD6rcCrLbX+Fijve586dU2pqqm655Rb5+vrK29tbvr6+2r17t3bu3Fmm9RZ3vH/55ZdiRy8GgKrCufXScG6V2rdvb441IEleXl6677779N133xW5Vf/C4//xxx/r3Llzevjhh922Ua1aNbVp08YcDHDXrl06dOiQevXq5faYQFRUVJHnoA8dOiRJCgsLK7Xv9erVU9++fTV16lTt37+/2JrVq1frlltuKXLM+vTpI8MwilyVT0pKko+PT7HruvDtAA0aNJDNZlOXLl3Med7e3rr55puL/Dy8++67at26tX73u9/J29tbPj4+mjVrVpn/L1K4L3788ccy1aNiEMZx1Tl16pSOHTsmp9NZYk2dOnW0atUqhYWFadCgQapTp47q1KlTpueCfisiIqLMtQ6Ho8R5x44dc5sfEhLi9rlwYI8zZ86Uq33lVdiO4vrldDov2k7p17ZerJ3Hjh2Tt7e3+exgIZvNJofDUWQ7ZdW0aVPdcccd+uc//ylJ+u9//6u9e/e63SbWvn17+fj4mNOjjz5a5vUXt1+GDRumZ599Vnfffbc++OADbdy4UZs3b1bjxo3LfLyq6ngDQFlxbr10nFvLd5wu3E9HjhyRJN12221u2/Dx8dGiRYvM2/wL11PatgoV7suy3GI/duxYeXl5FXmcotCxY8dKPLZl6d9vBQcHu3329fVVQEBAkXb6+vq6Pau/ePFi9ezZUzfeeKPmz5+v9PR0bd68WY8++uhFn+kvVLgN/u9hLUZTx1Vn+fLlKigoMAdaKckdd9yhO+64QwUFBfriiy/02muvKSUlReHh4br//vvLtK3yjO6ZlZVV4rziTrwXU61aNfP5r9/66aefFBoaWu71/bYdhw8fLjIS7KFDhy55vcVt59y5czp69KjbfxoMw1BWVpY5MM6lGDp0qHr06KEtW7Zo6tSpqlu3rtvgLNOnT9eJEyfMz+XpU3HHe/78+Xr44YeVmprqNv+nn37S9ddfX/4OAIAH4tzKufVyzq3lOU4XHv/CdRU+a16SwvWUtq0L11nas+CFIiIilJKSogkTJmj48OHFbvfw4cNF5hdefb9wX1TGyPDz589XrVq1tGjRIrf1F/ezXJLCfVFRP48oG66M46qyf/9+jRgxQna7XQMGDCjTd7y8vNSyZUvzN76Ft7VV9G/Mt2/frq+++spt3ttvv62goCA1a9as3OuLjo7W119/7Tbv22+/LTJoWHn6ceedd0pSkUFiNm/erJ07d6p9+/blbmdxCtdz4Xbef/99nTp16rK2c88996hmzZoaPny4Vq1apYEDB7qdmOrVq6cWLVqYU+EtdlLZrjxcyGazFXklyfLly7nNC8BVg3Mr59bLObdK0ieffGJe4ZZ+va190aJFqlOnzkVfA9epUyd5e3vr+++/d9vGb6fCNkREROidd95xe6Ri3759Wr9+vds6o6Ki5O/vr++//75M/R85cqSCg4M1atSoIsvat2+vHTt2FHks4q233pLNZlO7du3KtI3LYbPZ5Ovr63ZMsrKyyjyauiT98MMPuu6661SvXr3KaCJKwJVxXLG2bdtmPjeUnZ2tzz//XLNnz5aXl5eWLFlS5Dat33rjjTe0evVqde3aVTVr1tQvv/yiN998U5LUoUMHSVJQUJCioqL0n//8R+3bt1dwcLBCQ0OLnGDKyul0KikpSWPHjlVERITmz5+vlStXauLEiQoICCj3+pKTk/XQQw9p4MCBuvfee7Vv3z5NmjSpSL/r1Kkjf39/LViwQA0aNNDvfvc7OZ3OYm81rFevnvr376/XXntN1113nbp06aK9e/fq2WefVWRkZIWN8N2xY0d16tRJI0eOVG5urlq3bq2vv/5azz33nJo2bark5ORLXreXl5cGDRqkkSNHKjAwsNhX1JSkUaNGWrNmjT744ANFREQoKCjooielxMREzZkzR/Xr19ett96qjIwMvfTSSx7/jlkAKA7nVs6txbmcc6v069XWO++8U88++6wCAwP1+uuv65tvvinyerPiREdH6/nnn9eYMWP0ww8/qHPnzqpRo4aOHDmiTZs2KTAwUOPGjdN1112nF154QY899pjuuece9evXT8ePH9fYsWOL3Kbu6+uruLg4bdiwoUztr169usaMGVPssXryySf1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GQcAAAAAwGKEcQAAAAAALEYYBwAAAADAYoRxAAAAAAAsRhgHAAAAAMBihHEAAAAAACxGGAcAAAAAwGKEcQAAAACoZJ999pm6desmp9Mpm82mpUuXVvo2f/zxRz300EMKCQlRQECAmjRpooyMjEta1969e9W3b1/VqlVL/v7+qlOnjp577jnl5+eX+r2xY8eqfv36CgwMVI0aNdShQwdt3LixSF16erruvPNOBQYG6vrrr1fbtm115swZSdKaNWtks9mKnTZv3ixJ+uqrr/TAAw8oMjJS/v7+atCggf7+97+7beOXX35Rnz591KhRI3l7e+vuu+++pH0xY8YMtW3bVtWrV5fNZtPx48cvaT2EcQAAAACoZKdOnVLjxo01depUS7aXk5Oj1q1by8fHRx999JF27NihV155Rddff32J34mOjtaaNWuKXfbNN9/o/Pnzmj59urZv364pU6bojTfe0NNPP11qO+rWraupU6dq69atWrdunaKjo5WQkKCjR4+aNenp6ercubMSEhK0adMmbd68WYMHD9Z11/0aV+Pj43X48GG36bHHHlN0dLRatGghScrIyNANN9yg+fPna/v27RozZoxGjx7ttr8LCgrk7++voUOHqkOHDmXck0WdPn1anTt3vmjfL8ZmGIZxWWsAAAAAAJSZzWbTkiVL3K7M5ufn65lnntGCBQt0/PhxxcbGauLEiWrbtu0lbWPUqFH6v//7P33++edl/k50dLTmzJlT5m2+9NJLmjZtmn744YcybyM3N1d2u12rVq1S+/btJUmtWrVSx44d9cILL5RpHWfPntVNN92kwYMH69lnny2xbtCgQdq5c6dWr15dZFmfPn10/PjxYu9Q+OCDDzR27Fht375dTqdTvXv31pgxY+Tt7e1Wt2bNGrVr1045OTml/pKjJFwZBwAAAIAq9sgjj+j//u//tHDhQn399dfq0aOHOnfurN27d1/S+pYtW6YWLVqoR48eCgsLU9OmTTVz5swKbbPL5VJwcHCZ6/Pz8zVjxgzZ7XY1btxYkpSdna2NGzcqLCxM8fHxCg8PV5s2bbRu3boS17Ns2TL99NNP6tOnT4W2T5I+/vhjPfTQQxo6dKh27Nih6dOna86cOXrxxRfLtZ6yIIwDAAAAQBX6/vvv9c477+jdd9/VHXfcoTp16mjEiBG6/fbbNXv27Eta5w8//KBp06YpJiZGH3/8sR5//HENHTpUb731VoW1+bXXXtPjjz9+0dr//ve/+t3vfqdq1appypQpWrlypUJDQ812Sr8+W96vXz+lpaWpWbNmat++fYm/iJg1a5Y6deqkyMjIEreZnp6uf//73xowYEC5+vXiiy9q1KhR6t27t2rXrm1esZ8+fXq51lMW3hcvAQAAAABUli1btsgwDNWtW9dtfl5enkJCQiT9OoBarVq1Sl3PoEGDzGekz58/rxYtWig1NVWS1LRpU23fvl3Tpk3Tww8/LEl6/PHHNX/+fPP7p0+fVpcuXeTl5WXO27Fjh2rWrOm2nUOHDqlz587q0aOHHnvssYv2r127dsrMzNRPP/2kmTNnqmfPnubV8PPnz0uSBgwYoEceecRs6yeffKI333xT48ePd1vXwYMH9fHHH+vf//53idvbvn27/vjHP+qvf/2rOnbseNH2/VZGRoY2b97sdiW8oKBAv/zyi06fPq2AgIByra80hHEAAAAAqELnz5+Xl5eXMjIy3IKwJP3ud7+TJN14443auXNnqeupUaOG+eeIiAjdcsstbssbNGig999/3/z8/PPPa8SIEebntm3bauLEiWrZsqU5z+l0uq3j0KFDateuneLi4jRjxowy9S8wMFA333yzbr75ZrVq1UoxMTGaNWuWRo8erYiICEkqtq379+8vsq7Zs2crJCRESUlJxW5rx44duvPOO9WvXz8988wzZWrfb50/f17jxo1T9+7diyyrVq1auddXGsI4AAAAAFShpk2bqqCgQNnZ2brjjjuKrfHx8VH9+vXLvM7WrVtr165dbvO+/fZbRUVFmZ/DwsIUFhZmfvb29taNN96om2++udh1/vjjj2rXrp2aN2+u2bNnm6Odl5dhGMrLy5P066BxTqez2LZ26dKlyPdmz56thx9+WD4+PkXWu337dt15553q3bv3JT/j3axZM+3atavEfVCRCOMAAAAAUMlOnjyp7777zvy8Z88eZWZmKjg4WHXr1tWDDz6ohx9+WK+88oqaNm2qn376SatXr1ajRo101113lXt7Tz75pOLj45WamqqePXtq06ZNmjFjRpmvZl/o0KFDatu2rWrWrKmXX37Z7dVkDofD/HP9+vU1fvx43XPPPTp16pRefPFFJSUlKSIiQseOHdPrr7+ugwcPqkePHpJ+HVn+L3/5i5577jk1btxYTZo00dy5c/XNN9/ovffec2vD6tWrtWfPHvXt27dI+7Zv36527dopISFBw4YNU1ZWliTJy8tLN9xwg1m3Y8cO5efn6+eff9aJEyeUmZkpSWrSpIkk6a9//asSExMVGRmpHj166LrrrtPXX3+trVu36m9/+5skKSsrS1lZWebx3Lp1q4KCglSzZs3yDRhnAAAAAAAq1aeffmpIKjL17t3bMAzDyM/PN/76178a0dHRho+Pj+FwOIx77rnH+Prrry95mx988IERGxtr+Pn5GfXr1zdmzJhRan1UVJTx6aefFrts9uzZxbb/wkgpyZg9e7ZhGIZx5swZ45577jGcTqfh6+trREREGElJScamTZuKrH/8+PHGTTfdZAQEBBhxcXHG559/XqTmgQceMOLj44tt33PPPVds26Kioor08WJ9SEtLM+Lj4w1/f3+jevXqxu9//3u3fVfStgr7XVa8ZxwAAAAAAIvxajMAAAAAACxGGAcAAAAAwGKEcQAAAAAALEYYBwAAAADAYoRxAAAAAAAsRhgHAAAAAMBihHEAAAAAACxGGAcAAAAAwGKEcQAAAAAALEYYBwAAAADAYoRxAAAAAAAsRhgHAAAAAMBi/w9CB34vVy1IBAAAAABJRU5ErkJggg==",
      "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": "markdown",
   "id": "c656e2b5",
   "metadata": {},
   "source": [
    "### Weibull Model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 236,
   "id": "72fe4ffc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1.3701864228695204, 0.0, 29.109125868710237)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x17c7cf790>"
      ]
     },
     "execution_count": 236,
     "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, floc=0.0)\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": 282,
   "id": "968f409f",
   "metadata": {},
   "outputs": [],
   "source": [
    "k=1.3701864228695204\n",
    "weibull_model = tf.keras.Sequential([\n",
    "        tf.keras.layers.Dense(1, input_dim=x_train.shape[1]),\n",
    "        tf.keras.layers.Dense(512, activation=\"relu\"),\n",
    "        tf.keras.layers.Dense(256, activation=\"softmax\"),\n",
    "        tf.keras.layers.Dense(128, activation=\"relu\"),\n",
    "        tf.keras.layers.Dense(64, activation=\"relu\"),\n",
    "        tf.keras.layers.Dense(32, activation=\"relu\"),\n",
    "        tf.keras.layers.Dense(20, activation=\"relu\"),\n",
    "        tf.keras.layers.Dense(10, 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-23)\n",
    "\n",
    "# Compile and fit the model!\n",
    "weibull_model.compile(\n",
    "    optimizer=tf.keras.optimizers.Adam(3e-3),\n",
    "    loss=weibullLoss)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 283,
   "id": "d183b7be",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/250\n",
      "13/13 [==============================] - 2s 21ms/step - loss: 6.5323\n",
      "Epoch 2/250\n",
      "13/13 [==============================] - 0s 19ms/step - loss: 4.9463\n",
      "Epoch 3/250\n",
      "13/13 [==============================] - 0s 19ms/step - loss: 3.3759\n",
      "Epoch 4/250\n",
      "13/13 [==============================] - 0s 19ms/step - loss: 3.1183\n",
      "Epoch 5/250\n",
      "13/13 [==============================] - 0s 18ms/step - loss: 3.1187\n",
      "Epoch 6/250\n",
      "13/13 [==============================] - 0s 18ms/step - loss: 3.1156\n",
      "Epoch 7/250\n",
      "13/13 [==============================] - 0s 19ms/step - loss: 3.1107\n",
      "Epoch 8/250\n",
      "13/13 [==============================] - 0s 19ms/step - loss: 3.1104\n",
      "Epoch 9/250\n",
      "13/13 [==============================] - 0s 19ms/step - loss: 3.1104\n",
      "Epoch 10/250\n",
      "13/13 [==============================] - 0s 19ms/step - loss: 3.1103\n",
      "Epoch 11/250\n",
      "13/13 [==============================] - 0s 19ms/step - loss: 3.1103\n",
      "Epoch 12/250\n",
      "13/13 [==============================] - 0s 19ms/step - loss: 3.1103\n",
      "Epoch 13/250\n",
      "13/13 [==============================] - 0s 19ms/step - loss: 3.1103\n",
      "Epoch 14/250\n",
      "13/13 [==============================] - 0s 18ms/step - loss: 3.1103\n",
      "Epoch 15/250\n",
      "13/13 [==============================] - 0s 19ms/step - loss: 3.1103\n",
      "Epoch 16/250\n",
      "13/13 [==============================] - 0s 19ms/step - loss: 3.1103\n",
      "Epoch 17/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 18/250\n",
      "13/13 [==============================] - 0s 18ms/step - loss: 3.1103\n",
      "Epoch 19/250\n",
      "13/13 [==============================] - 0s 19ms/step - loss: 3.1103\n",
      "Epoch 20/250\n",
      "13/13 [==============================] - 0s 18ms/step - loss: 3.1103\n",
      "Epoch 21/250\n",
      "13/13 [==============================] - 0s 18ms/step - loss: 3.1103\n",
      "Epoch 22/250\n",
      "13/13 [==============================] - 0s 19ms/step - loss: 3.1103\n",
      "Epoch 23/250\n",
      "13/13 [==============================] - 0s 19ms/step - loss: 3.1103\n",
      "Epoch 24/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 25/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 26/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 27/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 28/250\n",
      "13/13 [==============================] - 0s 23ms/step - loss: 3.1103\n",
      "Epoch 29/250\n",
      "13/13 [==============================] - 0s 27ms/step - loss: 3.1103\n",
      "Epoch 30/250\n",
      "13/13 [==============================] - 0s 29ms/step - loss: 3.1103\n",
      "Epoch 31/250\n",
      "13/13 [==============================] - 0s 32ms/step - loss: 3.1103\n",
      "Epoch 32/250\n",
      "13/13 [==============================] - 0s 28ms/step - loss: 3.1103\n",
      "Epoch 33/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 34/250\n",
      "13/13 [==============================] - 0s 27ms/step - loss: 3.1103\n",
      "Epoch 35/250\n",
      "13/13 [==============================] - 0s 26ms/step - loss: 3.1103\n",
      "Epoch 36/250\n",
      "13/13 [==============================] - 0s 25ms/step - loss: 3.1103\n",
      "Epoch 37/250\n",
      "13/13 [==============================] - 0s 25ms/step - loss: 3.1103\n",
      "Epoch 38/250\n",
      "13/13 [==============================] - 0s 27ms/step - loss: 3.1103\n",
      "Epoch 39/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 40/250\n",
      "13/13 [==============================] - 0s 23ms/step - loss: 3.1103\n",
      "Epoch 41/250\n",
      "13/13 [==============================] - 0s 23ms/step - loss: 3.1103\n",
      "Epoch 42/250\n",
      "13/13 [==============================] - 0s 25ms/step - loss: 3.1103\n",
      "Epoch 43/250\n",
      "13/13 [==============================] - 0s 24ms/step - loss: 3.1103\n",
      "Epoch 44/250\n",
      "13/13 [==============================] - 0s 24ms/step - loss: 3.1103\n",
      "Epoch 45/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 46/250\n",
      "13/13 [==============================] - 0s 24ms/step - loss: 3.1103\n",
      "Epoch 47/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 48/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 49/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 50/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 51/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 52/250\n",
      "13/13 [==============================] - 0s 24ms/step - loss: 3.1103\n",
      "Epoch 53/250\n",
      "13/13 [==============================] - 0s 24ms/step - loss: 3.1103\n",
      "Epoch 54/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 55/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 56/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 57/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 58/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 59/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 60/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 61/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 62/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 63/250\n",
      "13/13 [==============================] - 0s 24ms/step - loss: 3.1103\n",
      "Epoch 64/250\n",
      "13/13 [==============================] - 0s 25ms/step - loss: 3.1103\n",
      "Epoch 65/250\n",
      "13/13 [==============================] - 0s 24ms/step - loss: 3.1103\n",
      "Epoch 66/250\n",
      "13/13 [==============================] - 0s 29ms/step - loss: 3.1103\n",
      "Epoch 67/250\n",
      "13/13 [==============================] - 0s 23ms/step - loss: 3.1103\n",
      "Epoch 68/250\n",
      "13/13 [==============================] - 0s 23ms/step - loss: 3.1103\n",
      "Epoch 69/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 70/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 71/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 72/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 73/250\n",
      "13/13 [==============================] - 0s 25ms/step - loss: 3.1103\n",
      "Epoch 74/250\n",
      "13/13 [==============================] - 0s 26ms/step - loss: 3.1103\n",
      "Epoch 75/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 76/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 77/250\n",
      "13/13 [==============================] - 0s 26ms/step - loss: 3.1103\n",
      "Epoch 78/250\n",
      "13/13 [==============================] - 0s 25ms/step - loss: 3.1103\n",
      "Epoch 79/250\n",
      "13/13 [==============================] - 0s 24ms/step - loss: 3.1103\n",
      "Epoch 80/250\n",
      "13/13 [==============================] - 0s 25ms/step - loss: 3.1103\n",
      "Epoch 81/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 82/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 83/250\n",
      "13/13 [==============================] - 0s 24ms/step - loss: 3.1103\n",
      "Epoch 84/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 85/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 86/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 87/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 88/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 89/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 90/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 91/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 92/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 93/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1104\n",
      "Epoch 94/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 95/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 96/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 97/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 98/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 99/250\n",
      "13/13 [==============================] - 0s 23ms/step - loss: 3.1103\n",
      "Epoch 100/250\n",
      "13/13 [==============================] - 0s 24ms/step - loss: 3.1103\n",
      "Epoch 101/250\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "13/13 [==============================] - 0s 32ms/step - loss: 3.1103\n",
      "Epoch 102/250\n",
      "13/13 [==============================] - 0s 26ms/step - loss: 3.1103\n",
      "Epoch 103/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 104/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 105/250\n",
      "13/13 [==============================] - 0s 23ms/step - loss: 3.1103\n",
      "Epoch 106/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 107/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 108/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 109/250\n",
      "13/13 [==============================] - 0s 23ms/step - loss: 3.1103\n",
      "Epoch 110/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 111/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 112/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 113/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 114/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 115/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 116/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 117/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 118/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 119/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 120/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 121/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 122/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 123/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 124/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 125/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 126/250\n",
      "13/13 [==============================] - 0s 28ms/step - loss: 3.1103\n",
      "Epoch 127/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 128/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 129/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 130/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 131/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 132/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 133/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 134/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 135/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 136/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 137/250\n",
      "13/13 [==============================] - 0s 24ms/step - loss: 3.1103\n",
      "Epoch 138/250\n",
      "13/13 [==============================] - 0s 25ms/step - loss: 3.1103\n",
      "Epoch 139/250\n",
      "13/13 [==============================] - 0s 24ms/step - loss: 3.1103\n",
      "Epoch 140/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 141/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 142/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 143/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 144/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 145/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 146/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 147/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 148/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 149/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 150/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1104\n",
      "Epoch 151/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 152/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 153/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 154/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 155/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 156/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 157/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 158/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 159/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 160/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 161/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 162/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 163/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 164/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 165/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 166/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 167/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 168/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 169/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 170/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 171/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 172/250\n",
      "13/13 [==============================] - 0s 23ms/step - loss: 3.1103\n",
      "Epoch 173/250\n",
      "13/13 [==============================] - 0s 23ms/step - loss: 3.1103\n",
      "Epoch 174/250\n",
      "13/13 [==============================] - 0s 23ms/step - loss: 3.1103\n",
      "Epoch 175/250\n",
      "13/13 [==============================] - 0s 23ms/step - loss: 3.1103\n",
      "Epoch 176/250\n",
      "13/13 [==============================] - 0s 27ms/step - loss: 3.1103\n",
      "Epoch 177/250\n",
      "13/13 [==============================] - 0s 23ms/step - loss: 3.1103\n",
      "Epoch 178/250\n",
      "13/13 [==============================] - 0s 27ms/step - loss: 3.1103\n",
      "Epoch 179/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 180/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 181/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 182/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 183/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 184/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 185/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 186/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 187/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 188/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 189/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 190/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 191/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 192/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 193/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 194/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 195/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 196/250\n",
      "13/13 [==============================] - 0s 24ms/step - loss: 3.1103\n",
      "Epoch 197/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 198/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 199/250\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 200/250\n",
      "13/13 [==============================] - 0s 23ms/step - loss: 3.1103\n",
      "Epoch 201/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1104\n",
      "Epoch 202/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 203/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1104\n",
      "Epoch 204/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 205/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 206/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 207/250\n",
      "13/13 [==============================] - 0s 20ms/step - loss: 3.1103\n",
      "Epoch 208/250\n",
      "13/13 [==============================] - 0s 23ms/step - loss: 3.1103\n",
      "Epoch 209/250\n",
      "13/13 [==============================] - 0s 24ms/step - loss: 3.1103\n",
      "Epoch 210/250\n",
      "13/13 [==============================] - 0s 26ms/step - loss: 3.1103\n",
      "Epoch 211/250\n",
      "13/13 [==============================] - 0s 28ms/step - loss: 3.1103\n",
      "Epoch 212/250\n",
      "13/13 [==============================] - 0s 23ms/step - loss: 3.1103\n",
      "Epoch 213/250\n",
      "13/13 [==============================] - 0s 23ms/step - loss: 3.1103\n",
      "Epoch 214/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 215/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 216/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 217/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 218/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 219/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1104\n",
      "Epoch 220/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 221/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 222/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 223/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1104\n",
      "Epoch 224/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 225/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 226/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 227/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 228/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 229/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 230/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 231/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 232/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 233/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 234/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 235/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 236/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 237/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 238/250\n",
      "13/13 [==============================] - 0s 22ms/step - loss: 3.1103\n",
      "Epoch 239/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 240/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 241/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 242/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1104\n",
      "Epoch 243/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 244/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n",
      "Epoch 245/250\n",
      "13/13 [==============================] - 0s 23ms/step - loss: 3.1103\n",
      "Epoch 246/250\n",
      "13/13 [==============================] - 0s 25ms/step - loss: 3.1103\n",
      "Epoch 247/250\n",
      "13/13 [==============================] - 0s 23ms/step - loss: 3.1103\n",
      "Epoch 248/250\n",
      "13/13 [==============================] - 0s 27ms/step - loss: 3.1103\n",
      "Epoch 249/250\n",
      "13/13 [==============================] - 0s 23ms/step - loss: 3.1103\n",
      "Epoch 250/250\n",
      "13/13 [==============================] - 0s 21ms/step - loss: 3.1103\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<keras.callbacks.History at 0x17ddc0550>"
      ]
     },
     "execution_count": 283,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "weibull_model.fit(x_train, y_train, batch_size=2500, epochs=250)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 284,
   "id": "fca8a35c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "317/317 [==============================] - 0s 1ms/step\n"
     ]
    }
   ],
   "source": [
    "y_pred = weibull_model.predict(x_test)\n",
    "alpha,beta = y_pred[:,0],y_pred[:,1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 285,
   "id": "0386ac02",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.special import loggamma"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 286,
   "id": "e77b85b9",
   "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": 287,
   "id": "26535e23",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "411.78758638719387"
      ]
     },
     "execution_count": 287,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mean_squared_error(y_test,mu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 288,
   "id": "5ffec6f8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([19.681925, 19.681925, 19.681925, ..., 19.681925, 19.681925,\n",
       "       19.681925], dtype=float32)"
      ]
     },
     "execution_count": 288,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "beta"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 290,
   "id": "64cf13b4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1.0000001, 1.0000001, 1.0000001, ..., 1.0000001, 1.0000001,\n",
       "       1.0000001], dtype=float32)"
      ]
     },
     "execution_count": 290,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "alpha"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 291,
   "id": "1d68df68",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x17ddeeaf0>"
      ]
     },
     "execution_count": 291,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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WrGxsZo/f77Hft577z0VFBTowQcfrE2zAQDADaBe96lparhPDQAATc91uU8NAADANwWhBgAAWIFQAwAArECoAQAAViDUAAAAKxBqAACAFQg1AADACoQaAABgBUINAACwAqEGAABYgVADAACsQKgBAABWINQAAAArEGoAAIAVCDUAAMAKhBoAAGAFQg0AALACoQYAAFiBUAMAAKxAqAEAAFYg1AAAACsQagAAgBUINQAAwAqEGgAAYAVCDQAAsAKhBgAAWIFQAwAArECoAQAAViDUAAAAKxBqAACAFQg1AADACoQaAABgBUINAACwAqEGAABYgVADAACsQKgBAABWINQAAAArEGoAAIAVCDUAAMAKhBoAAGAFQg0AALACoQYAAFiBUAMAAKxAqAEAAFYg1AAAACsQagAAgBUINQAAwAqEGgAAYAVCDQAAsAKhBgAAWIFQAwAArECoAQAAViDUAAAAKxBqAACAFQg1AADACoQaAABgBUINAACwAqEGAABYgVADAACsQKgBAABWINQAAAArEGoAAIAVCDUAAMAKhBoAAGAFQg0AALACoQYAAFihVqEmLS1NUVFRCg4OVmhoqEaNGqW8vLxK5XJzcxUXFyen06ng4GANHDhQBQUFV6170aJF6t69uwICAhQWFqYZM2bo/PnzHmWOHTumBx54QC1btlRgYKBuvfVW5eTk1OYQAACApXxqUzgzM1MJCQmKiopSWVmZUlJSNHz4cO3bt09BQUGSpIMHD8rlcumhhx7SnDlz5HQ6lZubK39//2rrXbFihZKTk/XSSy9p0KBBys/P1+TJkyVJzz//vCTpyy+/1ODBgzVs2DC99dZbCg0N1cGDB3XTTTfV7cgBAIBVHMYYU9eNT506pdDQUGVmZiomJkaSFB8fr2bNmunVV1+tcT1Tp05Vbm6utmzZ4l72+OOPKzs7W9u3b5ckJScn689//rP7eV0UFxfL6XSqqKhIISEhda4HAABcPzU9f9drTk1RUZEkqUWLFpKkiooKbdy4Ud26ddOIESMUGhqq6OhorVu37qr1uFwu5eTkKDs7W5J06NAhbdq0SSNHjnSXWb9+vQYMGKD77rtPoaGhioyM1LJly65ab2lpqYqLiz0eAADATnUONcYYzZw5Uy6XS3369JEkFRYW6syZM1qwYIHuuusuvfPOOxo9erTGjBmjzMzMauuKj4/X3Llz5XK51KxZM3Xt2lXDhg1TcnKyu8yhQ4e0ePFi3XzzzXr77bf16KOPatq0afr9739fbb1paWlyOp3uR1hYWF0PFwAAfMPVefgpISFBGzduVFZWljp27ChJOn78uDp06KBx48Zp5cqV7rJxcXEKCgrSa6+9VmVdGRkZio+P17x58xQdHa0DBw4oKSlJU6ZMUWpqqiTJ19dXAwYM0I4dO9zbTZs2TR999JF27txZZb2lpaUqLS11Py8uLlZYWBjDTwAANCE1HX6q1UThyxITE7V+/Xpt27bNHWgkqVWrVvLx8VGvXr08yvfs2VNZWVnV1peamqoJEybo4YcfliT17dtXZ8+e1SOPPKKUlBR5eXmpXbt2Vda7evXqauv18/OTn59fXQ4RAAA0MbUKNcYYJSYmau3atcrIyFBERITHel9fX0VFRVX6mHd+fr7Cw8OrrbekpEReXp4jYd7e3jLG6PKFpMGDB9e6XgAAcOOoVahJSEjQypUr9cYbbyg4OFgnT56UJDmdTgUEBEiSZs2apbFjxyomJkbDhg3T5s2btWHDBmVkZLjrmThxojp06KC0tDRJUmxsrBYuXKjIyEj38FNqaqri4uLk7e0tSZoxY4YGDRqkZ555Rv/5n/+p7OxsLV26VEuXLm2IfgAAAE2dqQVJVT7S09M9yr344ovm29/+tvH39zf9+vUz69at81g/ZMgQM2nSJPfzixcvmqeeesp07drV+Pv7m7CwMPOTn/zEfPnllx7bbdiwwfTp08f4+fmZHj16mKVLl9am+aaoqMhIMkVFRbXaDgAANJ6anr/rdZ+apob71AAA0PRcl/vUAAAAfFMQagAAgBUINQAAwAqEGgAAYAVCDQAAsAKhBgAAWIFQAwAArECoAQAAViDUAAAAKxBqAACAFQg1AADACoQaAABgBUINAACwAqEGAABYgVADAACsQKgBAABWINQAAAArEGoAAIAVCDUAAMAKhBoAAGAFQg0AALACoQYAAFiBUAMAAKxAqAEAAFYg1AAAACsQagAAgBUINQAAwAqEGgAAYAVCDQAAsAKhBgAAWIFQAwAArECoAQAAViDUAAAAKxBqAACAFQg1AADACoQaAABgBUINAACwAqEGAABYgVADAACsQKgBAABWINQAAAArEGoAAIAVCDUAAMAKhBoAAGAFQg0AALACoQYAAFiBUAMAAKxAqAEAAFYg1AAAACsQagAAgBUINQAAwAqEGgAAYAVCDQAAsAKhBgAAWIFQAwAArECoAQAAViDUAAAAKxBqAACAFQg1AADACoQaAABgBUINAACwAqEGAABYgVADAACsQKgBAABWINQAAAArEGoAAIAVahVq0tLSFBUVpeDgYIWGhmrUqFHKy8urVC43N1dxcXFyOp0KDg7WwIEDVVBQcNW6Fy1apO7duysgIEBhYWGaMWOGzp8/717/1FNPyeFweDzatm1bm+YDAACL+dSmcGZmphISEhQVFaWysjKlpKRo+PDh2rdvn4KCgiRJBw8elMvl0kMPPaQ5c+bI6XQqNzdX/v7+1da7YsUKJScn66WXXtKgQYOUn5+vyZMnS5Kef/55d7nevXvrvffecz/39vauTfMBAIDFahVqNm/e7PE8PT1doaGhysnJUUxMjCQpJSVF99xzj37+85+7y3Xp0uWq9e7cuVODBw/W+PHjJUmdO3fWuHHjlJ2d7dlYHx+uzgAAgCrVa05NUVGRJKlFixaSpIqKCm3cuFHdunXTiBEjFBoaqujoaK1bt+6q9bhcLuXk5LhDzKFDh7Rp0yaNHDnSo9z+/fvVvn17RUREKD4+XocOHbpqvaWlpSouLvZ4AAAAO9U51BhjNHPmTLlcLvXp00eSVFhYqDNnzmjBggW666679M4772j06NEaM2aMMjMzq60rPj5ec+fOlcvlUrNmzdS1a1cNGzZMycnJ7jLR0dH6/e9/r7ffflvLli3TyZMnNWjQIH3xxRfV1puWlian0+l+hIWF1fVwAQDAN5zDGGPqsmFCQoI2btyorKwsdezYUZJ0/PhxdejQQePGjdPKlSvdZePi4hQUFKTXXnutyroyMjIUHx+vefPmKTo6WgcOHFBSUpKmTJmi1NTUKrc5e/asunbtqp/+9KeaOXNmlWVKS0tVWlrqfl5cXKywsDAVFRUpJCSkLocNAACus+LiYjmdzq89f9dqTs1liYmJWr9+vbZt2+YONJLUqlUr+fj4qFevXh7le/bsqaysrGrrS01N1YQJE/Twww9Lkvr27auzZ8/qkUceUUpKiry8Kl9QCgoKUt++fbV///5q6/Xz85Ofn19tDw8AADRBtRp+MsZo6tSpWrNmjd5//31FRER4rPf19VVUVFSlj3nn5+crPDy82npLSkoqBRdvb28ZY1TdhaTS0lLl5uaqXbt2tTkEAABgqVpdqUlISNDKlSv1xhtvKDg4WCdPnpQkOZ1OBQQESJJmzZqlsWPHKiYmRsOGDdPmzZu1YcMGZWRkuOuZOHGiOnTooLS0NElSbGysFi5cqMjISPfwU2pqquLi4twf2/6v//ovxcbGqlOnTiosLNS8efNUXFysSZMmNUQ/AACAJq5WoWbx4sWSpKFDh3osT09Pd99XZvTo0VqyZInS0tI0bdo0de/eXatXr5bL5XKXLygo8LgyM3v2bDkcDs2ePVvHjh1T69atFRsbq/nz57vL/P3vf9e4ceP0+eefq3Xr1ho4cKA++OCDq14BAgAAN446TxRuimo60QgAAHxz1PT8zXc/AQAAKxBqAACAFQg1AADACoQaAABgBUINAACwAqEGAABYgVADAACsQKgBAABWINQAAAArEGoAAIAVCDUAAMAKhBoAAGAFQg0AALACoQYAAFiBUAMAAKxAqAEAAFYg1AAAACsQagAAgBUINQAAwAqEGgAAYAVCDQAAsAKhBgAAWIFQAwAArECoAQAAViDUAAAAKxBqAACAFQg1AADACoQaAABgBUINAACwAqEGAABYgVADAACsQKgBAABWINQAAAArEGoAAIAVCDUAAMAKhBoAAGAFQg0AALACoQYAAFiBUAMAAKxAqAEAAFYg1AAAACsQagAAgBUINQAAwAqEGgAAYAVCDQAAsAKhBgAAWIFQAwAArECoAQAAViDUAAAAKxBqAACAFQg1AADACoQaAABgBUINAACwAqEGAABYgVADAACs4NPYDQCAxlJeXq6LFy82djOAG16zZs3k7e1d73oINQBuOMYYnTx5Uv/85z8buykA/uWmm25S27Zt5XA46lwHoQbADedyoAkNDVVgYGC9/ogCqB9jjEpKSlRYWChJateuXZ3rItQAuKGUl5e7A03Lli0buzkAJAUEBEiSCgsLFRoaWuehKCYKA7ihXJ5DExgY2MgtAfBVl38n6zPPjVAD4IbEkBPwzdIQv5OEGgAAYAVCDQCgyfvss8/kcDi0Z8+easuUlJToBz/4gUJCQuRwOPj021V07txZixYtcj93OBxat25do7WnppgoDAC4Ibzyyivavn27duzYoVatWsnpdDZ2k5qMEydO6Fvf+lZjN+NrEWoAoK4qyqVT26VzJ6SAdlLr2yWv+t9A7EZ28eJFNWvW7JrUffDgQfXs2VN9+vSptsyFCxfk6+t7TfbflLVt27axm1AjDD8BQF0cXSOt7yxtGSbtGH/p3/WdLy2/RoYOHarExERNnz5d3/rWt9SmTRstXbpUZ8+e1Y9+9CMFBwera9eueuuttzy227dvn+655x41b95cbdq00YQJE/T555+712/evFkul0s33XSTWrZsqe9///s6ePCge/3loZ01a9Zo2LBhCgwMVL9+/bRz586rttfhcGjx4sW6++67FRAQoIiICL3++uuV6v3jH/+ooUOHyt/fX8uXL5ckpaenq2fPnvL391ePHj30wgsveNSdnZ2tyMhI+fv7a8CAAdq9e/fX9t0vf/lLbdu2TQ6HQ0OHDpV0aZhl3rx5mjx5spxOp6ZMmSJJWr16tXr37i0/Pz917txZv/zlLz3qu7zdxIkT1bx5c4WHh+uNN97QqVOndO+996p58+bq27evPv7446u266mnnlKnTp3k5+en9u3ba9q0ae51y5cv14ABAxQcHKy2bdtq/Pjx7nu5SFJGRoYcDofefvttRUZGKiAgQN/73vdUWFiot956Sz179lRISIjGjRunkpISj76YOnWqpk6d6v6Zz549W8aYatv51eGnmr4eli1bprCwMAUGBmr06NFauHChbrrppqv2R72ZWnjmmWfMgAEDTPPmzU3r1q3Nvffeaz799NNK5fbt22diY2NNSEiIad68uYmOjjZHjhy5at3PP/+86datm/H39zcdO3Y006dPN+fOnau2HZJMUlJSbZpvioqKjCRTVFRUq+3QRJWXGXNyqzGHV176t7yssVuEb4Bz586Zffv2Vfv3pUYKVhuzwmHMCl3xcFx6FKxuuAZ/xZAhQ0xwcLCZO3euyc/PN3PnzjVeXl7m7rvvNkuXLjX5+fnmscceMy1btjRnz541xhhz/Phx06pVK/Ozn/3M5Obmml27dpk777zTDBs2zF3vn/70J7N69WqTn59vdu/ebWJjY03fvn1NeXm5McaYw4cPG0mmR48e5s033zR5eXnmhz/8oQkPDzcXL16str2STMuWLc2yZctMXl6emT17tvH29jb79u3zqLdz585m9erV5tChQ+bYsWNm6dKlpl27du5lq1evNi1atDAvv/yyMcaYM2fOmNatW5uxY8eavXv3mg0bNpguXboYSWb37t1VtuWLL74wU6ZMMbfd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",
      "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": 280,
   "id": "bea74b9e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 9.57453994, 10.05800662, 10.24595819, ...,  9.98843124,\n",
       "        10.28947824,  9.80053914]),\n",
       " array([10.191764, 10.191764, 10.191764, ..., 10.191764, 10.191764,\n",
       "        10.191764], dtype=float32))"
      ]
     },
     "execution_count": 280,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_pred_check,mu"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 281,
   "id": "69752b1d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " 57/317 [====>.........................] - ETA: 0s"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/kb/v0p0ypbd0wx1q2qb1kpxmmcc0000gn/T/ipykernel_10528/1216301696.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(131)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "317/317 [==============================] - 0s 835us/step\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Distribnution of y-pred (Weibull)')"
      ]
     },
     "execution_count": 281,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABbYAAAIgCAYAAABZBz8xAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB6bklEQVR4nOzdfXxMZ/7/8fc0dyKNqUhz16bu1l1FNdgSqqIiqLAtWy2VUkq7lKZYN9VuabuCLrpLq6iiQnW3LUtt465u6us+lS1qVVuUEtE2EndNiPP7wy+nJveJTDInXs/HYx4Pc85nzvlc1xm55nzmmnNshmEYAgAAAAAAAADAIm6p6AQAAAAAAAAAACgJCtsAAAAAAAAAAEuhsA0AAAAAAAAAsBQK2wAAAAAAAAAAS6GwDQAAAAAAAACwFArbAAAAAAAAAABLobANAAAAAAAAALAUCtsAAAAAAAAAAEuhsA0AAAAAAAAAsBQK23BZCxculM1mMx9VqlRRUFCQ2rdvr/j4eKWmpuZ5zYQJE2Sz2Uq0n4sXL2rChAnatGlTiV6X375q1aqlmJiYEm2nrJw8eVITJkxQcnJynnWl6ZfylpWVpWeffVbBwcFyc3PTvffe67R9TZo0SStWrHDKto8ePSqbzaaFCxc6ZfsAbk6MiSXDmGgt/fv3V61atYoVe/nyZTVs2FCTJ082l+X8/6hSpYqOHTuW5zWRkZEKCwsrq3TLXe7+uXz5surWras333yzwnICkD/G65JhvLaWGxmvP/roI9lsNn344Yd5Yps2bSqbzaY1a9bkWVe3bl01a9bshvO02Wx67rnnSrSdokRGRioyMjLPfiZMmGA+37Bhg2699Vb9+OOPZbpv/IbCNlzeggULtH37dq1bt05vvfWW7r33Xk2ZMkWNGjXS+vXrHWKffvppbd++vUTbv3jxoiZOnFjiDwWl2ZcznTx5UhMnTsz3Q4Gr5Zqf2bNna86cORo/fry2bt2qxYsXO21fzixsBwcHa/v27eratatTtg/g5saYWDyMiZXX22+/rbS0NA0bNizPuszMTL300ksVkFX58vDw0F/+8he9+uqr+vnnnys6HQD5YLwuHsbryiv3eB0ZGSmbzaaNGzc6xP3yyy/at2+ffHx88qw7ceKEvv/+e7Vv375E+3755Ze1fPnyG2tAGenQoYPuu+8+vfjiixWdSqXlXtEJAEUJCwtTixYtzOc9e/bUCy+8oPvvv189evTQ4cOHFRgYKEm68847deeddzo1n4sXL6pq1arlsq+yYoVc9+/fL29v7zL/FvVGXbp0SVWqVCn2bAEvLy+1atXKyVkBuFkxJt44K+TqqmNibiUdI2/UlStX9MYbb2jAgAHy8fHJs75z585aunSpRo0apaZNmzotj0uXLsnb29tp2y+O3r17a8SIEZozZw4ny4ALYry+cVbIlfE6f/mN1/7+/goLC8vzZczmzZvl7u6ugQMH5ils5zwvaWG7bt26pU/eCYYOHarHHntMr7/+ukJDQys6nUqHGduwpLvuukvTpk3TuXPnNGfOHHN5fj9X+vzzzxUZGakaNWrI29tbd911l3r27KmLFy/q6NGjuv322yVJEydONH8y1r9/f4ftffnll/rjH/+o6tWrm38kC/tp1PLly3XPPfeoSpUqqlOnjv7xj384rN+0aZNsNps++OADjR8/XiEhIapWrZqioqJ06NAhh9hatWqZ+Vzv+p+9bNq0Sb///e8lSU899ZTZjpyfwOSX69WrVzV16lQ1bNhQXl5eCggI0JNPPqkTJ07k2U9YWJh2796ttm3bqmrVqqpTp44mT56sq1ev5tv+6/36668aN26cateuLU9PT91xxx0aOnSozp49a8bYbDa9++67unTpkpl7QZfyeO211+Tu7q7jx4/nWTdgwADVqFFDv/76a4H52Gw2XbhwQYsWLTL3ldOPOT8dXLt2rQYMGKDbb79dVatWVWZmpr799ls99dRTqlevnqpWrao77rhD3bp10759+xy2n9+lSHL6/8CBA+rdu7fsdrsCAwM1YMAApaenF9mHAFAYxkTGxNKOiTn7e+655zRnzhzVr19fXl5euvvuu7Vs2TKHuMLGSEn68MMPFRERIR8fH916663q1KmT9u7dm2d/CxcuVIMGDeTl5aVGjRrp/fffL6LXfrNy5Ur9+OOPio2NzXf96NGjVaNGDY0ZM6bIbRXnWEi//UT/k08+UXh4uKpUqWLOkrTZbFq6dKnGjBmj4OBg3XrrrerWrZtOnz6tc+fOafDgwfL395e/v7+eeuopnT9/3mHbb731lh544AEFBATIx8dHTZo00dSpU3X58uUi8/f09NRjjz2muXPnyjCMIuMBVDzGa8brm328bt++vQ4dOqRTp06Zy3LeBw899JCSkpJ07tw5h3Vubm5q27atJMkwDL399tu699575e3trerVq+uPf/yjvv/+e4f9FHbJlKL6r6D/Izn9evTo0WL3Q45u3brp1ltv1bx580r8WhSNwjYs66GHHpKbm5u2bNlSYMzRo0fVtWtXeXp66r333lNiYqImT54sHx8fZWVlKTg4WImJiZKkgQMHavv27dq+fbtefvllh+306NFDv/vd7/Svf/1L77zzTqF5JScnKy4uTi+88IKWL1+u1q1b6/nnn9ff/va3PLEvvviijh07pnfffVdz587V4cOH1a1bN2VnZ5eoL5o1a6YFCxZIkl566SWzHU8//XSBr/nTn/6kMWPGqGPHjlq5cqVee+01JSYmqnXr1vrpp58cYlNSUvTEE0+ob9++Wrlypbp06aJx48YpISGh0LwMw9DDDz+sv/3tb4qNjdXq1as1YsQILVq0SA8++KA5uG7fvl0PPfSQvL29zdwLupTHM888I3d3d4cPg9K1nzAtW7ZMAwcOVJUqVQrMafv27fL29tZDDz1k7uvtt992iBkwYIA8PDy0ePFiffTRR/Lw8NDJkydVo0YNTZ48WYmJiXrrrbfk7u6uli1b5vkgV5CePXuqfv36+vjjjzV27FgtXbpUL7zwQrFeCwCFYUz8DWNi8cfEHCtXrtQ//vEPvfrqq/roo49Us2ZN9e7dWx999FGe2PzGyEmTJql37966++679c9//lOLFy/WuXPn1LZtW3399dfmaxcuXKinnnpKjRo10scff6yXXnpJr732mj7//PMic5Sk1atXKyAgQHfffXe+6319ffXSSy9pzZo1hW6zuMcix5dffqk///nPGj58uBITE9WzZ09z3YsvvqjU1FQtXLhQ06ZN06ZNm9S7d2/17NlTdrtdH3zwgUaPHq3FixfnmVn93XffqU+fPlq8eLE+/fRTDRw4UG+88YaeeeaZYvVHZGSkjh07pv379xcrHkDFY7z+DeP1zTde58y8vn7W9saNG9WuXTu1adNGNptNX3zxhcO6Zs2ayW63S7rWj3FxcYqKitKKFSv09ttv68CBA2rdurVOnz5dpv1Xljw9PdW6dWutXr3aqfu5aRmAi1qwYIEhydi9e3eBMYGBgUajRo3M56+88opx/dv6o48+MiQZycnJBW7jzJkzhiTjlVdeybMuZ3t/+ctfClx3vZo1axo2my3P/jp27GhUq1bNuHDhgmEYhrFx40ZDkvHQQw85xP3zn/80JBnbt2932Ga/fv3y7L9du3ZGu3btzOe7d+82JBkLFiwoMteDBw8akowhQ4Y4xO3cudOQZLz44osO+5Fk7Ny50yH27rvvNjp16pRnX9dLTEw0JBlTp051WP7hhx8akoy5c+eay/r162f4+PgUur3rYwMCAozMzExz2ZQpU4xbbrnFOHLkSJGv9/HxybdPc95zTz75ZJHbuHLlipGVlWXUq1fPeOGFF8zlR44cyXMccvo/dz8MGTLEqFKlinH16tUi9wfg5saY+Ns2GRMd3eiYKMnw9vY2UlJSzGVXrlwxGjZsaPzud78zlxU0Rv7www+Gu7u7MWzYMIfl586dM4KCgoxevXoZhmEY2dnZRkhIiNGsWTOHce/o0aOGh4eHUbNmzSJzbdSokdG5c+c8y6///5GZmWnUqVPHaNGihbmfdu3aGY0bNzbjS3Isatasabi5uRmHDh1yiM1533br1s1heVxcnCHJGD58uMPyhx9+2PDz8yuwbdnZ2cbly5eN999/33BzczN++eUXc12/fv3y7Z/Dhw8bkozZs2cXuF0A5Yvx+rdtMl47Yrw2jF9++cW45ZZbjMGDBxuGYRg//fSTYbPZjMTERMMwDOO+++4zRo0aZeYryRg9erRhGIaxfft2Q5Ixbdo0h20eP37c8Pb2NuMMI/9xs7j9l9//EcP4rV+vP1a53885+8nv/+X48eONW265xTh//nyedbgxzNiGpRlF/PTy3nvvlaenpwYPHqxFixbl+YlKcV0/M6cojRs3znNdxz59+igjI0Nffvmlw/Lu3bs7PL/nnnskSceOHStVnsWVc62q3D8Pu++++9SoUSNt2LDBYXlQUJDuu+8+h2X33HNPkXnmfKObez+PPvqofHx88uynuJ5//nmlpqbqX//6l6RrP0mbPXu2unbtav7kKDs7W1euXDEfxfnJWY78jveVK1c0adIk3X333fL09JS7u7s8PT11+PBhHTx4sFjbze94//rrr/neHR0ASooxsXQYE6/d2CjnWq+S5Obmpscee0zffvttnp935z7+a9as0ZUrV/Tkk0867KNKlSpq166dOSvr0KFDOnnypPr06ePwE9+aNWuqdevWxWrryZMnFRAQUGiMp6enXn/9de3Zs0f//Oc/840p6bG45557VL9+/Xy3FRMT4/C8UaNGkpRn1l6jRo30yy+/OFyOZO/everevbtq1KghNzc3eXh46Mknn1R2dra++eabQtspyeyLH3/8schYAK6D8bp0GK+tP15Xr15dTZs2Nfe1efNmubm5qU2bNpKkdu3amcc59/W1P/30U9lsNvXt29ch/6CgIIdtFqYk/VfWAgICdPXqVaWkpDh1PzcjCtuwrAsXLujnn39WSEhIgTF169bV+vXrFRAQoKFDh6pu3bqqW7eu/v73v5doX8HBwcWODQoKKnBZ7jvX16hRw+G5l5eXpGs3d3CmnDzya1dISEiReUrXci0qz59//lnu7u7mNeBy2Gw2BQUF5dlPcYWHh6tt27Z66623JF0b5I4ePepw044OHTrIw8PDfAwYMKDY28+vX0aMGKGXX35ZDz/8sFatWqWdO3dq9+7datq0abGPV0UdbwCVH2Ni6TEmluw45e6nnJ/+/v73v3fYh4eHhz788EPzp+E52ylsX0XJuflVUR5//HE1a9ZM48ePz/d61SU9FoW95/38/Byee3p6Fro85xqqP/zwg9q2basff/xRf//73/XFF19o9+7d5nEszvs+py/4HAFYB+N16TFeV47xun379vrmm2908uRJbdy4Uc2bN9ett94q6Vphe+/evUpPT9fGjRvl7u6u+++/38zfMAwFBgbmyX/Hjh15LkWTn5L0X1ljzHYe94pOACit1atXKzs727z5REHatm2rtm3bKjs7W3v27NHMmTMVFxenwMBAPf7448XaV0nuHpzfN3A5y/IbXItSpUqVPNd6lKSffvpJ/v7+Jd7e9XmcOnUqz52mT548Wert5refK1eu6MyZMw4fDAzDUEpKinmzkNIYPny4Hn30UX355ZeaNWuW6tevr44dO5rr58yZ43DjiZK0Kb/jnZCQoCeffFKTJk1yWP7TTz/ptttuK3kDAKAMMSYyJt7ImFiS45T7+OdsK+dalQXJ2U5h+yqKv7+/fvnllyLjbDabpkyZoo4dO2ru3Ln55lKSY1GS93xxrVixQhcuXNAnn3zi0G/JycnF3kZOX5TVexSA8zFeM17f7ON1+/btNX36dG3atEmbNm3SQw89ZK7LKWJv2bLFvKlkTtHb39/fvAZ3zpcp18tvWXHyz91/OQXozMxMh20Wp3BeGMZs52HGNizphx9+0KhRo2S324t9gx03Nze1bNnS/IY05ydVZf0N84EDB/Tf//7XYdnSpUvl6+urZs2alXh7tWrV0ldffeWw7Jtvvslzw8KStOPBBx+UpDw3zti9e7cOHjyoDh06lDjP/ORsJ/d+Pv74Y124cOGG9vPII4/orrvu0siRI7V+/XoNGTLEYfBu0KCBWrRoYT6uvytycb6pz81ms+UZLFevXs3PfwFUOMZExsQbGRMlacOGDQ43XcrOztaHH36ounXr5ike5NapUye5u7vru+++c9jH9Y+cHIKDg/XBBx84/Az/2LFj2rZtW7Ha2bBhQ3333XfFio2KilLHjh316quvOlz+Q3LusSiunONz/WcLwzA0b968Ym8j5/IEBd1ME4BrYbxmvGa8lh544AG5ubnpo48+0oEDBxy+5LHb7br33nu1aNEiHT161LwMiXTt0l+GYejHH3/MN/cmTZoUmVdx+i+nz3O/f1etWlWsthfk+++/V40aNRwuhYKywYxtuLz9+/eb109KTU3VF198oQULFsjNzU3Lly/P8xOh673zzjv6/PPP1bVrV91111369ddf9d5770m6dsIjSb6+vqpZs6b+/e9/q0OHDvLz85O/v3+eQaS4QkJC1L17d02YMEHBwcFKSEjQunXrNGXKFFWtWrXE24uNjVXfvn01ZMgQ9ezZU8eOHdPUqVPztLtu3bry9vbWkiVL1KhRI916660KCQnJ92duDRo00ODBgzVz5kzdcsst6tKli44ePaqXX35ZoaGheuGFF0rV9tw6duyoTp06acyYMcrIyFCbNm301Vdf6ZVXXlF4eLhiY2NLvW03NzcNHTpUY8aMkY+PT55roBWmSZMm2rRpk1atWqXg4GD5+vqqQYMGhb4mJiZGCxcuVMOGDXXPPfcoKSlJb7zxRpEfIACgLDEmMibm50bGROna7KEHH3xQL7/8snx8fPT222/rf//7n5YtW1bka2vVqqVXX31V48eP1/fff6/OnTurevXqOn36tHbt2iUfHx9NnDhRt9xyi1577TU9/fTTeuSRRzRo0CCdPXtWEyZMKPZPmyMjI/Xqq6/q4sWLxXr/TJkyRc2bN1dqaqoaN25sLnfmsSiujh07ytPTU71799bo0aP166+/avbs2UpLSyv2Nnbs2CE3Nzc98MADTswUQGkwXjNe54fxWqpWrZqaNWumFStW6JZbbjGvr52jXbt2evPNNyXJ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AAAAAABWEB8fL5vNpri4OHOZYRiaMGGCQkJC5O3trcjISB04cMDhdZmZmRo2bJj8/f3l4+Oj7t2768SJEw4xaWlpio2NNX/hHBsbq7Nnz5ZDqwAAcB6nFbYXLFiggIAAde1a+I33fv75Zx0/flzBwcGSpObNm8vDw0Pr1q0zY06dOqX9+/erdevWzkoXAIBKixNlAABc2+7duzV37lzdc889DsunTp2q6dOna9asWdq9e7eCgoLUsWNHnTt3zoyJi4vT8uXLtWzZMm3dulXnz59XTEyMsrOzzZg+ffooOTlZiYmJSkxMVHJysmJjY8utfQAAOINTCttXr17VggUL1K9fP7m7/3a1k/Pnz2vUqFHavn27jh49qk2bNqlbt27y9/fXI488Ikmy2+0aOHCgRo4cqQ0bNmjv3r3q27evmjRpoqioKGekCwBApcWJMgAAru38+fN64oknNG/ePId7TRmGoTfffFPjx49Xjx49FBYWpkWLFunixYtaunSpJCk9PV3z58/XtGnTFBUVpfDwcCUkJGjfvn1av369JOngwYNKTEzUu+++q4iICEVERGjevHn69NNPdejQoQppMwAAZcEphe3169frhx9+0IABAxyWu7m5ad++ffrDH/6g+vXrq1+/fqpfv762b98uX19fM27GjBl6+OGH1atXL7Vp00ZVq1bVqlWr5Obm5ox0AQColDhRBgDA9Q0dOlRdu3bNM5HryJEjSklJUXR0tLnMy8tL7dq107Zt2yRJSUlJunz5skNMSEiIwsLCzJjt27fLbrerZcuWZkyrVq1kt9vNmPxkZmYqIyPD4QEAgCtxSmE7OjpahmGofv36Dsu9vb21Zs0apaamKisrS8eOHdPChQvz3OSxSpUqmjlzpn7++WddvHhRq1at4kaQAACUECfKAAC4tmXLlunLL79UfHx8nnUpKSmSlOdeU4GBgea6lJQUeXp6OnyBnV9MQEBAnu0HBASYMfmJj483LzVmt9s5JwcAuBynXWMbAABUHE6UAQBwbcePH9fzzz+vhIQEValSpcA4m83m8NwwjDzLcssdk198UdsZN26c0tPTzcfx48cL3ScAAOWNwjYAAJUMJ8oAALi+pKQkpaamqnnz5nJ3d5e7u7s2b96sf/zjH3J3dze/gM79ZXFqaqq5LigoSFlZWUpLSys05vTp03n2f+bMmTxfcl/P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VatWTs6ycCVpw8aNGw1JRlpaWrnlV5RXXnnFaNq0abHjXe04lDR/VzwGRY2z+XG141CaNrjisbje888/b9StW9e4evVqvutd7Rjkp6g2uPoxQOmU5nNWUWrWrGnMmDHDYdnFixcNNzc349NPP3VY3rRpU2P8+PGlzr88OaOvDMMwrly5Yvj6+hqLFi0yl1WGGkZ59ldh+7WCiuorw8hbB3J1FdlXhmEY1atXN959990S511Ryru/SnKuUxBmbOeSlZWlpKQkRUdHOyyPjo7Wtm3bKigr15Seni5J8vPzk3RtZklKSopD33l5ealdu3Y3bd8NHTpUXbt2VVRUlMNy+uo3K1euVIsWLfToo48qICBA4eHhmjdvnrmevvrN/fffrw0bNuibb76RJP33v//V1q1b9dBDD0mirwpSnH5JSkrS5cuXHWJCQkIUFhZ2U/ed1RX0Nzg/27dvzzP2d+rUSXv27NHly5edlWKRStKGHOHh4QoODlaHDh20ceNGJ2ZXPIcPH1ZISIhq166txx9/XN9//32Bsa54HEqSfw5XOgZFjbP5cbXjUJo25HClY5EjKytLCQkJGjBggGw2W74xrnYMcitOG3K44jFA2XHW588rV64oOztbVapUcVju7e2trVu3lnq7Fams+urixYu6fPmyeR5eWWsYzuqvyqg8+yp3HchqyquvsrOztWzZMl24cEERERE3nHdFcXZ/leZcJzcK27n89NNPys7OVmBgoMPywMBApaSkVFBWrscwDI0YMUL333+/wsLCJMnsH/rummXLlunLL79UfHx8nnX01W++//57zZ49W/Xq1dOaNWv07LPPavjw4Xr//fcl0VfXGzNmjHr37q2GDRvKw8ND4eHhiouLU+/evSXRVwUpTr+kpKTI09NT1atXLzAG1lLY3+D8pKSk5PseuXLlin766SdnpFikkrYhODhYc+fO1ccff6xPPvlEDRo0UIcOHbRlyxYnZ1qwli1b6v3339eaNWs0b948paSkqHXr1vr555/zjXe141DS/F3xGBQ1zubH1Y5Dadrgiscix4oVK3T27Fn179+/wBhXOwa5FacNrnwMUHac9fnT19dXEREReu2113Ty5EllZ2crISFBO3fu1KlTp24o54pSVn01duxY3XHHHWYhqLLWMJzVX5VRefVVfnUgq3F2X+3bt0+33nqrvLy89Oyz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",
      "text/plain": [
       "<Figure size 1800x600 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig,ax=plt.subplots(figsize=(18,6))\n",
    "plt.subplot(131)\n",
    "plt.hist(y_train,bins=50)\n",
    "plt.title(\"Distribnution of y-train\")\n",
    "plt.subplot(132)\n",
    "plt.hist(edl_model.predict(x_test)[:,0],bins=50)\n",
    "plt.title(\"Distribnution of y-pred (Normal)\")\n",
    "plt.subplot(133)\n",
    "plt.hist(mu,bins=50)\n",
    "plt.title(\"Distribnution of y-pred (Weibull)\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3abdd61b",
   "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
}
