{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "6ae30370",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import sklearn.metrics as metrics\n",
    "import tensorflow as tf\n",
    "import pandas as pd\n",
    "\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "\n",
    "from SupervisedAD_methods import *\n",
    "from kdd import *"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "optical-league",
   "metadata": {},
   "source": [
    "# Data Preprocessing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "complete-bobby",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>duration</th>\n",
       "      <th>protocol_type</th>\n",
       "      <th>service</th>\n",
       "      <th>flag</th>\n",
       "      <th>src_bytes</th>\n",
       "      <th>dst_bytes</th>\n",
       "      <th>land</th>\n",
       "      <th>wrong_fragment</th>\n",
       "      <th>urgent</th>\n",
       "      <th>hot</th>\n",
       "      <th>...</th>\n",
       "      <th>dst_host_same_srv_rate</th>\n",
       "      <th>dst_host_diff_srv_rate</th>\n",
       "      <th>dst_host_same_src_port_rate</th>\n",
       "      <th>dst_host_srv_diff_host_rate</th>\n",
       "      <th>dst_host_serror_rate</th>\n",
       "      <th>dst_host_srv_serror_rate</th>\n",
       "      <th>dst_host_rerror_rate</th>\n",
       "      <th>dst_host_srv_rerror_rate</th>\n",
       "      <th>attack</th>\n",
       "      <th>level</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>tcp</td>\n",
       "      <td>ftp_data</td>\n",
       "      <td>SF</td>\n",
       "      <td>491</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.17</td>\n",
       "      <td>0.03</td>\n",
       "      <td>0.17</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.00</td>\n",
       "      <td>normal</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0</td>\n",
       "      <td>udp</td>\n",
       "      <td>other</td>\n",
       "      <td>SF</td>\n",
       "      <td>146</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.88</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>normal</td>\n",
       "      <td>15</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0</td>\n",
       "      <td>tcp</td>\n",
       "      <td>private</td>\n",
       "      <td>S0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.10</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>1.00</td>\n",
       "      <td>1.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>neptune</td>\n",
       "      <td>19</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0</td>\n",
       "      <td>tcp</td>\n",
       "      <td>http</td>\n",
       "      <td>SF</td>\n",
       "      <td>232</td>\n",
       "      <td>8153</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.03</td>\n",
       "      <td>0.04</td>\n",
       "      <td>0.03</td>\n",
       "      <td>0.01</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.01</td>\n",
       "      <td>normal</td>\n",
       "      <td>21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0</td>\n",
       "      <td>tcp</td>\n",
       "      <td>http</td>\n",
       "      <td>SF</td>\n",
       "      <td>199</td>\n",
       "      <td>420</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>normal</td>\n",
       "      <td>21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>125968</th>\n",
       "      <td>0</td>\n",
       "      <td>tcp</td>\n",
       "      <td>private</td>\n",
       "      <td>S0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.10</td>\n",
       "      <td>0.06</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>1.00</td>\n",
       "      <td>1.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>neptune</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>125969</th>\n",
       "      <td>8</td>\n",
       "      <td>udp</td>\n",
       "      <td>private</td>\n",
       "      <td>SF</td>\n",
       "      <td>105</td>\n",
       "      <td>145</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.96</td>\n",
       "      <td>0.01</td>\n",
       "      <td>0.01</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>normal</td>\n",
       "      <td>21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>125970</th>\n",
       "      <td>0</td>\n",
       "      <td>tcp</td>\n",
       "      <td>smtp</td>\n",
       "      <td>SF</td>\n",
       "      <td>2231</td>\n",
       "      <td>384</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.12</td>\n",
       "      <td>0.06</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.72</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.01</td>\n",
       "      <td>0.00</td>\n",
       "      <td>normal</td>\n",
       "      <td>18</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>125971</th>\n",
       "      <td>0</td>\n",
       "      <td>tcp</td>\n",
       "      <td>klogin</td>\n",
       "      <td>S0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.03</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>1.00</td>\n",
       "      <td>1.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>neptune</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>125972</th>\n",
       "      <td>0</td>\n",
       "      <td>tcp</td>\n",
       "      <td>ftp_data</td>\n",
       "      <td>SF</td>\n",
       "      <td>151</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.30</td>\n",
       "      <td>0.03</td>\n",
       "      <td>0.30</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>normal</td>\n",
       "      <td>21</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>125973 rows \u00c3\u2014 43 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "        duration protocol_type   service flag  src_bytes  dst_bytes  land  \\\n",
       "0              0           tcp  ftp_data   SF        491          0     0   \n",
       "1              0           udp     other   SF        146          0     0   \n",
       "2              0           tcp   private   S0          0          0     0   \n",
       "3              0           tcp      http   SF        232       8153     0   \n",
       "4              0           tcp      http   SF        199        420     0   \n",
       "...          ...           ...       ...  ...        ...        ...   ...   \n",
       "125968         0           tcp   private   S0          0          0     0   \n",
       "125969         8           udp   private   SF        105        145     0   \n",
       "125970         0           tcp      smtp   SF       2231        384     0   \n",
       "125971         0           tcp    klogin   S0          0          0     0   \n",
       "125972         0           tcp  ftp_data   SF        151          0     0   \n",
       "\n",
       "        wrong_fragment  urgent  hot  ...  dst_host_same_srv_rate  \\\n",
       "0                    0       0    0  ...                    0.17   \n",
       "1                    0       0    0  ...                    0.00   \n",
       "2                    0       0    0  ...                    0.10   \n",
       "3                    0       0    0  ...                    1.00   \n",
       "4                    0       0    0  ...                    1.00   \n",
       "...                ...     ...  ...  ...                     ...   \n",
       "125968               0       0    0  ...                    0.10   \n",
       "125969               0       0    0  ...                    0.96   \n",
       "125970               0       0    0  ...                    0.12   \n",
       "125971               0       0    0  ...                    0.03   \n",
       "125972               0       0    0  ...                    0.30   \n",
       "\n",
       "        dst_host_diff_srv_rate  dst_host_same_src_port_rate  \\\n",
       "0                         0.03                         0.17   \n",
       "1                         0.60                         0.88   \n",
       "2                         0.05                         0.00   \n",
       "3                         0.00                         0.03   \n",
       "4                         0.00                         0.00   \n",
       "...                        ...                          ...   \n",
       "125968                    0.06                         0.00   \n",
       "125969                    0.01                         0.01   \n",
       "125970                    0.06                         0.00   \n",
       "125971                    0.05                         0.00   \n",
       "125972                    0.03                         0.30   \n",
       "\n",
       "        dst_host_srv_diff_host_rate  dst_host_serror_rate  \\\n",
       "0                              0.00                  0.00   \n",
       "1                              0.00                  0.00   \n",
       "2                              0.00                  1.00   \n",
       "3                              0.04                  0.03   \n",
       "4                              0.00                  0.00   \n",
       "...                             ...                   ...   \n",
       "125968                         0.00                  1.00   \n",
       "125969                         0.00                  0.00   \n",
       "125970                         0.00                  0.72   \n",
       "125971                         0.00                  1.00   \n",
       "125972                         0.00                  0.00   \n",
       "\n",
       "        dst_host_srv_serror_rate  dst_host_rerror_rate  \\\n",
       "0                           0.00                  0.05   \n",
       "1                           0.00                  0.00   \n",
       "2                           1.00                  0.00   \n",
       "3                           0.01                  0.00   \n",
       "4                           0.00                  0.00   \n",
       "...                          ...                   ...   \n",
       "125968                      1.00                  0.00   \n",
       "125969                      0.00                  0.00   \n",
       "125970                      0.00                  0.01   \n",
       "125971                      1.00                  0.00   \n",
       "125972                      0.00                  0.00   \n",
       "\n",
       "        dst_host_srv_rerror_rate   attack  level  \n",
       "0                           0.00   normal     20  \n",
       "1                           0.00   normal     15  \n",
       "2                           0.00  neptune     19  \n",
       "3                           0.01   normal     21  \n",
       "4                           0.00   normal     21  \n",
       "...                          ...      ...    ...  \n",
       "125968                      0.00  neptune     20  \n",
       "125969                      0.00   normal     21  \n",
       "125970                      0.00   normal     18  \n",
       "125971                      0.00  neptune     20  \n",
       "125972                      0.00   normal     21  \n",
       "\n",
       "[125973 rows x 43 columns]"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = get_df('data/KDDTrain+.txt', columns=columns, drop=False)\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "vulnerable-occupation",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>duration</th>\n",
       "      <th>protocol_type</th>\n",
       "      <th>service</th>\n",
       "      <th>flag</th>\n",
       "      <th>src_bytes</th>\n",
       "      <th>dst_bytes</th>\n",
       "      <th>land</th>\n",
       "      <th>wrong_fragment</th>\n",
       "      <th>urgent</th>\n",
       "      <th>hot</th>\n",
       "      <th>...</th>\n",
       "      <th>dst_host_same_srv_rate</th>\n",
       "      <th>dst_host_diff_srv_rate</th>\n",
       "      <th>dst_host_same_src_port_rate</th>\n",
       "      <th>dst_host_srv_diff_host_rate</th>\n",
       "      <th>dst_host_serror_rate</th>\n",
       "      <th>dst_host_srv_serror_rate</th>\n",
       "      <th>dst_host_rerror_rate</th>\n",
       "      <th>dst_host_srv_rerror_rate</th>\n",
       "      <th>attack</th>\n",
       "      <th>level</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>tcp</td>\n",
       "      <td>private</td>\n",
       "      <td>REJ</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.04</td>\n",
       "      <td>0.06</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.00</td>\n",
       "      <td>1.00</td>\n",
       "      <td>neptune</td>\n",
       "      <td>21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0</td>\n",
       "      <td>tcp</td>\n",
       "      <td>private</td>\n",
       "      <td>REJ</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.06</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.00</td>\n",
       "      <td>1.00</td>\n",
       "      <td>neptune</td>\n",
       "      <td>21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>tcp</td>\n",
       "      <td>ftp_data</td>\n",
       "      <td>SF</td>\n",
       "      <td>12983</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.61</td>\n",
       "      <td>0.04</td>\n",
       "      <td>0.61</td>\n",
       "      <td>0.02</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>normal</td>\n",
       "      <td>21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0</td>\n",
       "      <td>icmp</td>\n",
       "      <td>eco_i</td>\n",
       "      <td>SF</td>\n",
       "      <td>20</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>1.00</td>\n",
       "      <td>0.28</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>saint</td>\n",
       "      <td>15</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1</td>\n",
       "      <td>tcp</td>\n",
       "      <td>telnet</td>\n",
       "      <td>RSTO</td>\n",
       "      <td>0</td>\n",
       "      <td>15</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.31</td>\n",
       "      <td>0.17</td>\n",
       "      <td>0.03</td>\n",
       "      <td>0.02</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.83</td>\n",
       "      <td>0.71</td>\n",
       "      <td>mscan</td>\n",
       "      <td>11</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22539</th>\n",
       "      <td>0</td>\n",
       "      <td>tcp</td>\n",
       "      <td>smtp</td>\n",
       "      <td>SF</td>\n",
       "      <td>794</td>\n",
       "      <td>333</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.72</td>\n",
       "      <td>0.06</td>\n",
       "      <td>0.01</td>\n",
       "      <td>0.01</td>\n",
       "      <td>0.01</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>normal</td>\n",
       "      <td>21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22540</th>\n",
       "      <td>0</td>\n",
       "      <td>tcp</td>\n",
       "      <td>http</td>\n",
       "      <td>SF</td>\n",
       "      <td>317</td>\n",
       "      <td>938</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>1.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.01</td>\n",
       "      <td>0.01</td>\n",
       "      <td>0.01</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>normal</td>\n",
       "      <td>21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22541</th>\n",
       "      <td>0</td>\n",
       "      <td>tcp</td>\n",
       "      <td>http</td>\n",
       "      <td>SF</td>\n",
       "      <td>54540</td>\n",
       "      <td>8314</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>2</td>\n",
       "      <td>...</td>\n",
       "      <td>1.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.07</td>\n",
       "      <td>0.07</td>\n",
       "      <td>back</td>\n",
       "      <td>15</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22542</th>\n",
       "      <td>0</td>\n",
       "      <td>udp</td>\n",
       "      <td>domain_u</td>\n",
       "      <td>SF</td>\n",
       "      <td>42</td>\n",
       "      <td>42</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.99</td>\n",
       "      <td>0.01</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>normal</td>\n",
       "      <td>21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22543</th>\n",
       "      <td>0</td>\n",
       "      <td>tcp</td>\n",
       "      <td>sunrpc</td>\n",
       "      <td>REJ</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>0.08</td>\n",
       "      <td>0.03</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.44</td>\n",
       "      <td>1.00</td>\n",
       "      <td>mscan</td>\n",
       "      <td>14</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>22544 rows \u00c3\u2014 43 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "       duration protocol_type   service  flag  src_bytes  dst_bytes  land  \\\n",
       "0             0           tcp   private   REJ          0          0     0   \n",
       "1             0           tcp   private   REJ          0          0     0   \n",
       "2             2           tcp  ftp_data    SF      12983          0     0   \n",
       "3             0          icmp     eco_i    SF         20          0     0   \n",
       "4             1           tcp    telnet  RSTO          0         15     0   \n",
       "...         ...           ...       ...   ...        ...        ...   ...   \n",
       "22539         0           tcp      smtp    SF        794        333     0   \n",
       "22540         0           tcp      http    SF        317        938     0   \n",
       "22541         0           tcp      http    SF      54540       8314     0   \n",
       "22542         0           udp  domain_u    SF         42         42     0   \n",
       "22543         0           tcp    sunrpc   REJ          0          0     0   \n",
       "\n",
       "       wrong_fragment  urgent  hot  ...  dst_host_same_srv_rate  \\\n",
       "0                   0       0    0  ...                    0.04   \n",
       "1                   0       0    0  ...                    0.00   \n",
       "2                   0       0    0  ...                    0.61   \n",
       "3                   0       0    0  ...                    1.00   \n",
       "4                   0       0    0  ...                    0.31   \n",
       "...               ...     ...  ...  ...                     ...   \n",
       "22539               0       0    0  ...                    0.72   \n",
       "22540               0       0    0  ...                    1.00   \n",
       "22541               0       0    2  ...                    1.00   \n",
       "22542               0       0    0  ...                    0.99   \n",
       "22543               0       0    0  ...                    0.08   \n",
       "\n",
       "       dst_host_diff_srv_rate  dst_host_same_src_port_rate  \\\n",
       "0                        0.06                         0.00   \n",
       "1                        0.06                         0.00   \n",
       "2                        0.04                         0.61   \n",
       "3                        0.00                         1.00   \n",
       "4                        0.17                         0.03   \n",
       "...                       ...                          ...   \n",
       "22539                    0.06                         0.01   \n",
       "22540                    0.00                         0.01   \n",
       "22541                    0.00                         0.00   \n",
       "22542                    0.01                         0.00   \n",
       "22543                    0.03                         0.00   \n",
       "\n",
       "       dst_host_srv_diff_host_rate  dst_host_serror_rate  \\\n",
       "0                             0.00                  0.00   \n",
       "1                             0.00                  0.00   \n",
       "2                             0.02                  0.00   \n",
       "3                             0.28                  0.00   \n",
       "4                             0.02                  0.00   \n",
       "...                            ...                   ...   \n",
       "22539                         0.01                  0.01   \n",
       "22540                         0.01                  0.01   \n",
       "22541                         0.00                  0.00   \n",
       "22542                         0.00                  0.00   \n",
       "22543                         0.00                  0.00   \n",
       "\n",
       "       dst_host_srv_serror_rate  dst_host_rerror_rate  \\\n",
       "0                           0.0                  1.00   \n",
       "1                           0.0                  1.00   \n",
       "2                           0.0                  0.00   \n",
       "3                           0.0                  0.00   \n",
       "4                           0.0                  0.83   \n",
       "...                         ...                   ...   \n",
       "22539                       0.0                  0.00   \n",
       "22540                       0.0                  0.00   \n",
       "22541                       0.0                  0.07   \n",
       "22542                       0.0                  0.00   \n",
       "22543                       0.0                  0.44   \n",
       "\n",
       "       dst_host_srv_rerror_rate   attack  level  \n",
       "0                          1.00  neptune     21  \n",
       "1                          1.00  neptune     21  \n",
       "2                          0.00   normal     21  \n",
       "3                          0.00    saint     15  \n",
       "4                          0.71    mscan     11  \n",
       "...                         ...      ...    ...  \n",
       "22539                      0.00   normal     21  \n",
       "22540                      0.00   normal     21  \n",
       "22541                      0.07     back     15  \n",
       "22542                      0.00   normal     21  \n",
       "22543                      1.00    mscan     14  \n",
       "\n",
       "[22544 rows x 43 columns]"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_df = get_df('data/KDDTest+.txt', columns=columns, drop=False)\n",
    "test_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "front-remove",
   "metadata": {},
   "outputs": [],
   "source": [
    "#  https://www.kaggle.com/code/avk256/nsl-kdd-anomaly-detection/notebook\n",
    "\n",
    "# map normal to 0, all attacks to 1\n",
    "is_attack = df.attack.map(lambda a: 0 if a == 'normal' else 1)\n",
    "test_attack = test_df.attack.map(lambda a: 0 if a == 'normal' else 1)\n",
    "\n",
    "#data_with_attack = df.join(is_attack, rsuffix='_flag')\n",
    "df['attack_flag'] = is_attack\n",
    "test_df['attack_flag'] = test_attack\n",
    "\n",
    "# map normal to 1, all attacks to 0\n",
    "is_normal = df.attack.map(lambda a: 1 if a == 'normal' else 0)\n",
    "test_normal = test_df.attack.map(lambda a: 1 if a == 'normal' else 0)\n",
    "\n",
    "df['normal_flag'] = is_normal\n",
    "test_df['normal_flag'] = test_normal\n",
    "\n",
    "# map the data and join to the data set\n",
    "attack_map = df.attack.apply(map_attack)\n",
    "df['attack_map'] = attack_map\n",
    "\n",
    "test_attack_map = test_df.attack.apply(map_attack)\n",
    "test_df['attack_map'] = test_attack_map\n",
    "\n",
    "# categorical features\n",
    "features_to_encode = ['protocol_type', 'service', 'flag']\n",
    "\n",
    "# get numeric features, we won't worry about encoding these at this point\n",
    "# numeric_features = ['duration', 'src_bytes', 'dst_bytes']\n",
    "# Use all features\n",
    "numeric_features = list(set(df.columns[:-5]) - set(features_to_encode))\n",
    "\n",
    "\n",
    "def feat_eng(df, test_df, features_to_encode=features_to_encode, numeric_features=numeric_features):\n",
    "#     https://www.kaggle.com/code/avk256/nsl-kdd-anomaly-detection/notebook\n",
    "\n",
    "    # get the intial set of encoded features and encode them\n",
    "    encoded = pd.get_dummies(df[features_to_encode])\n",
    "    test_encoded_base = pd.get_dummies(test_df[features_to_encode])\n",
    "\n",
    "    # not all of the features are in the test set, so we need to account for diffs\n",
    "    test_index = np.arange(len(test_df.index))\n",
    "    column_diffs = list(set(encoded.columns.values)-set(test_encoded_base.columns.values))\n",
    "\n",
    "    diff_df = pd.DataFrame(0, index=test_index, columns=column_diffs)\n",
    "\n",
    "    # we'll also need to reorder the columns to match, so let's get those\n",
    "    column_order = encoded.columns.to_list()\n",
    "\n",
    "    # append the new columns\n",
    "    test_encoded_temp = test_encoded_base.join(diff_df)\n",
    "\n",
    "    # reorder the columns\n",
    "    test_final = test_encoded_temp[column_order].fillna(0)\n",
    "\n",
    "    # model to fit/test\n",
    "    to_fit = encoded.join(df[numeric_features])\n",
    "    test_set = test_final.join(test_df[numeric_features])\n",
    "    \n",
    "    return to_fit, test_set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "lyric-public",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>protocol_type_icmp</th>\n",
       "      <th>protocol_type_tcp</th>\n",
       "      <th>protocol_type_udp</th>\n",
       "      <th>service_IRC</th>\n",
       "      <th>service_X11</th>\n",
       "      <th>service_Z39_50</th>\n",
       "      <th>service_aol</th>\n",
       "      <th>service_auth</th>\n",
       "      <th>service_bgp</th>\n",
       "      <th>service_courier</th>\n",
       "      <th>...</th>\n",
       "      <th>dst_host_srv_count</th>\n",
       "      <th>wrong_fragment</th>\n",
       "      <th>dst_host_same_src_port_rate</th>\n",
       "      <th>dst_host_same_srv_rate</th>\n",
       "      <th>srv_count</th>\n",
       "      <th>srv_rerror_rate</th>\n",
       "      <th>dst_host_rerror_rate</th>\n",
       "      <th>dst_host_diff_srv_rate</th>\n",
       "      <th>num_access_files</th>\n",
       "      <th>is_host_login</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>25</td>\n",
       "      <td>0</td>\n",
       "      <td>0.17</td>\n",
       "      <td>0.17</td>\n",
       "      <td>2</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.03</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0.88</td>\n",
       "      <td>0.00</td>\n",
       "      <td>1</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>26</td>\n",
       "      <td>0</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.10</td>\n",
       "      <td>6</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>255</td>\n",
       "      <td>0</td>\n",
       "      <td>0.03</td>\n",
       "      <td>1.00</td>\n",
       "      <td>5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>255</td>\n",
       "      <td>0</td>\n",
       "      <td>0.00</td>\n",
       "      <td>1.00</td>\n",
       "      <td>32</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>125968</th>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>25</td>\n",
       "      <td>0</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.10</td>\n",
       "      <td>25</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.06</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>125969</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>244</td>\n",
       "      <td>0</td>\n",
       "      <td>0.01</td>\n",
       "      <td>0.96</td>\n",
       "      <td>2</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.01</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>125970</th>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>30</td>\n",
       "      <td>0</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.12</td>\n",
       "      <td>1</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.01</td>\n",
       "      <td>0.06</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>125971</th>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>8</td>\n",
       "      <td>0</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.03</td>\n",
       "      <td>8</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>125972</th>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>...</td>\n",
       "      <td>77</td>\n",
       "      <td>0</td>\n",
       "      <td>0.30</td>\n",
       "      <td>0.30</td>\n",
       "      <td>1</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.03</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>125973 rows \u00c3\u2014 122 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "        protocol_type_icmp  protocol_type_tcp  protocol_type_udp  service_IRC  \\\n",
       "0                        0                  1                  0            0   \n",
       "1                        0                  0                  1            0   \n",
       "2                        0                  1                  0            0   \n",
       "3                        0                  1                  0            0   \n",
       "4                        0                  1                  0            0   \n",
       "...                    ...                ...                ...          ...   \n",
       "125968                   0                  1                  0            0   \n",
       "125969                   0                  0                  1            0   \n",
       "125970                   0                  1                  0            0   \n",
       "125971                   0                  1                  0            0   \n",
       "125972                   0                  1                  0            0   \n",
       "\n",
       "        service_X11  service_Z39_50  service_aol  service_auth  service_bgp  \\\n",
       "0                 0               0            0             0            0   \n",
       "1                 0               0            0             0            0   \n",
       "2                 0               0            0             0            0   \n",
       "3                 0               0            0             0            0   \n",
       "4                 0               0            0             0            0   \n",
       "...             ...             ...          ...           ...          ...   \n",
       "125968            0               0            0             0            0   \n",
       "125969            0               0            0             0            0   \n",
       "125970            0               0            0             0            0   \n",
       "125971            0               0            0             0            0   \n",
       "125972            0               0            0             0            0   \n",
       "\n",
       "        service_courier  ...  dst_host_srv_count  wrong_fragment  \\\n",
       "0                     0  ...                  25               0   \n",
       "1                     0  ...                   1               0   \n",
       "2                     0  ...                  26               0   \n",
       "3                     0  ...                 255               0   \n",
       "4                     0  ...                 255               0   \n",
       "...                 ...  ...                 ...             ...   \n",
       "125968                0  ...                  25               0   \n",
       "125969                0  ...                 244               0   \n",
       "125970                0  ...                  30               0   \n",
       "125971                0  ...                   8               0   \n",
       "125972                0  ...                  77               0   \n",
       "\n",
       "        dst_host_same_src_port_rate  dst_host_same_srv_rate  srv_count  \\\n",
       "0                              0.17                    0.17          2   \n",
       "1                              0.88                    0.00          1   \n",
       "2                              0.00                    0.10          6   \n",
       "3                              0.03                    1.00          5   \n",
       "4                              0.00                    1.00         32   \n",
       "...                             ...                     ...        ...   \n",
       "125968                         0.00                    0.10         25   \n",
       "125969                         0.01                    0.96          2   \n",
       "125970                         0.00                    0.12          1   \n",
       "125971                         0.00                    0.03          8   \n",
       "125972                         0.30                    0.30          1   \n",
       "\n",
       "        srv_rerror_rate  dst_host_rerror_rate  dst_host_diff_srv_rate  \\\n",
       "0                   0.0                  0.05                    0.03   \n",
       "1                   0.0                  0.00                    0.60   \n",
       "2                   0.0                  0.00                    0.05   \n",
       "3                   0.0                  0.00                    0.00   \n",
       "4                   0.0                  0.00                    0.00   \n",
       "...                 ...                   ...                     ...   \n",
       "125968              0.0                  0.00                    0.06   \n",
       "125969              0.0                  0.00                    0.01   \n",
       "125970              0.0                  0.01                    0.06   \n",
       "125971              0.0                  0.00                    0.05   \n",
       "125972              0.0                  0.00                    0.03   \n",
       "\n",
       "        num_access_files  is_host_login  \n",
       "0                      0              0  \n",
       "1                      0              0  \n",
       "2                      0              0  \n",
       "3                      0              0  \n",
       "4                      0              0  \n",
       "...                  ...            ...  \n",
       "125968                 0              0  \n",
       "125969                 0              0  \n",
       "125970                 0              0  \n",
       "125971                 0              0  \n",
       "125972                 0              0  \n",
       "\n",
       "[125973 rows x 122 columns]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data_train, data_test = feat_eng(df, test_df)\n",
    "data_train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "organic-cooperative",
   "metadata": {},
   "outputs": [],
   "source": [
    "scaler = StandardScaler()\n",
    "\n",
    "new_attacks = [1,2,3,4]\n",
    "test_classes = [0,1,2,3,4]\n",
    "\n",
    "\n",
    "def get_x_y(df, data, classes=[0,1]):\n",
    "\n",
    "    indices = df['attack_map'].isin(classes)\n",
    "    x = data[indices]\n",
    "    y = df['normal_flag'][indices]\n",
    "    \n",
    "    return x.to_numpy(), y.to_numpy()\n",
    "\n",
    "\n",
    "x_train, y = get_x_y(df, data_train)\n",
    "X = scaler.fit_transform(x_train)\n",
    "\n",
    "np.random.seed(0)\n",
    "np.random.shuffle(X)\n",
    "np.random.seed(0)\n",
    "np.random.shuffle(y)\n",
    "\n",
    "x_testing, y_test = get_x_y(test_df, data_test, classes=test_classes)\n",
    "x_test = scaler.transform(x_testing)\n",
    "\n",
    "num_inputs = X.shape[-1]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "dynamic-selection",
   "metadata": {},
   "source": [
    "# Modelling"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "arabic-consumption",
   "metadata": {},
   "source": [
    "## Neural Networks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "norman-commitment",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Build Models\n",
    "\n",
    "def build_layer(activation, input_layer, sigma=0.5, train=False, layer_number=1,\n",
    "                seed=0, neurons=5, batchnorm=False, regulariser=None):\n",
    "    \n",
    "    initialiser = tf.keras.initializers.GlorotUniform(seed=seed)\n",
    "    \n",
    "    if activation == \"r\":\n",
    "        layer = RBFLayer(neurons, gamma=1.0, initializer=initialiser)(input_layer)\n",
    "        \n",
    "        if batchnorm:\n",
    "            layer = tf.keras.layers.BatchNormalization()(layer)\n",
    "            \n",
    "    else:\n",
    "        hidden = tf.keras.layers.Dense(neurons,\n",
    "                      kernel_initializer=initialiser, kernel_regularizer=regulariser)(input_layer)\n",
    "        \n",
    "        if batchnorm:\n",
    "            hidden = tf.keras.layers.BatchNormalization()(hidden)\n",
    "            \n",
    "        if activation == \"b\":\n",
    "            layer = Bump(sigma=sigma, trainable=train,\n",
    "                              name=f\"bump{layer_number}\")(hidden)\n",
    "        elif activation == \"s\":\n",
    "            layer = tf.math.sigmoid(hidden)\n",
    "        else:\n",
    "            layer = tf.nn.leaky_relu(hidden, alpha=0.01)\n",
    "    \n",
    "    return layer\n",
    "\n",
    "\n",
    "def create_model(separation, activation, hidden_layers, num_inputs,\n",
    "                 hidden_neurons=[40, 20, 10, 5], dropout=[0.0, 0.0, 0.0, 0.0], lr=0.001,\n",
    "                 regularisation=[None, None, None, None],\n",
    "                 sigma=0.5, train=False, loss='binary_crossentropy', batchnorm=False,\n",
    "                 seed=0, name_suffix=\"\"):\n",
    "    \n",
    "    sep = {\"RBF\": \"r\", \"ES\": \"b\", \"HS\": \"s\"}\n",
    "    \n",
    "    tf.keras.utils.set_random_seed(seed)\n",
    "\n",
    "    input_layer = tf.keras.Input(shape=(num_inputs,))\n",
    "    \n",
    "    if len(hidden_neurons) != 0:\n",
    "        \n",
    "        hidden_layers = len(hidden_neurons)\n",
    "        hidden = input_layer\n",
    "    \n",
    "        for i, n in enumerate(hidden_neurons):\n",
    "            hidden = build_layer(activation, hidden, sigma=sigma, train=train,\n",
    "                                 layer_number=1+i, seed=seed+42*i, neurons=n,\n",
    "                                 batchnorm=batchnorm, regulariser=regularisation[i])\n",
    "            if dropout[i] > 0.:\n",
    "                hidden = tf.keras.layers.Dropout(dropout[i])(hidden)\n",
    "            \n",
    "        out = build_layer(sep[separation], hidden, sigma=sigma, layer_number=\"last\", seed=seed+2023, neurons=1)\n",
    "        \n",
    "    else:\n",
    "        hidden1 = build_layer(activation, input_layer, sigma=sigma, train=train, layer_number=1, seed=seed+42)\n",
    "        hidden2 = build_layer(activation, hidden1, sigma=sigma, train=train, layer_number=2, seed=seed+123)\n",
    "\n",
    "        if hidden_layers == 2:\n",
    "\n",
    "            out = build_layer(sep[separation], hidden2, sigma=sigma, layer_number=\"last\", seed=seed+2023, neurons=1)\n",
    "\n",
    "        elif hidden_layers == 3:\n",
    "\n",
    "            hidden3 = build_layer(activation, hidden2, sigma=sigma, train=train, layer_number=3, seed=seed+1234)   \n",
    "            out = build_layer(sep[separation], hidden3, sigma=sigma, layer_number=\"last\", seed=seed+2023, neurons=1)\n",
    "\n",
    "    model = tf.keras.Model(inputs=input_layer, outputs=out, name=f'{separation}{hidden_layers}{activation}{name_suffix}')\n",
    "\n",
    "    model.compile(optimizer=tf.keras.optimizers.Adam(learning_rate=lr),\n",
    "                            loss=loss)\n",
    "    \n",
    "    return model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "fatty-victim",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Train and Evaluate Models\n",
    "\n",
    "def train_eval(model, X, y, x_test, y_test, y_true_train=None, epochs=1000, train=False, hidden_layers=2,\n",
    "               verbose=0, shuffle=False, plot=False,\n",
    "               val_split=0.1, callbacks=[early_stopping], seed=0, diff=True, writer=False,\n",
    "               indiv=new_attacks, \n",
    "#                att_labels=df_test_att['attack'], \n",
    "              att_labels=test_df['attack_map'], pos_label=0):\n",
    "    \n",
    "    # Train the model\n",
    "    tf.keras.utils.set_random_seed(seed)\n",
    "    cbs = callbacks.copy()\n",
    "    if train:\n",
    "        # learnable sigma\n",
    "        get_weights = GetWeights(layer_names=[f\"bump{i}\" for i in range(1, hidden_layers+1)])\n",
    "        cbs.append(get_weights)\n",
    "        model.fit(X, y, epochs=epochs, verbose=verbose, shuffle=shuffle,\n",
    "                  validation_split=val_split, callbacks=cbs)\n",
    "        viz_sigma(get_weights)\n",
    "        \n",
    "    else:\n",
    "        model.fit(X, y, epochs=epochs, verbose=verbose, shuffle=shuffle,\n",
    "                  validation_split=val_split, callbacks=cbs)\n",
    "\n",
    "        \n",
    "    # Evaluation\n",
    "#     viz_boundary(data_viz, model, grid=grid, writer=writer)\n",
    "\n",
    "    y_train = model.predict(X)\n",
    "    y_pred = model.predict(x_test)\n",
    "    \n",
    "    if y_true_train is None:\n",
    "        y_true_train = y\n",
    "    else:\n",
    "        # Deep SAD: Use true labels and 0: attack, 1: normal\n",
    "        # Flip for AUPR\n",
    "        y_train = -y_train\n",
    "        y_pred = -y_pred\n",
    "        \n",
    "    aupr_train = get_metrics(y_train, y_true_train, model.name, plot=plot, pos_label=pos_label)\n",
    "    \n",
    "    aupr_test = get_metrics(y_pred, y_test, model.name, plot=plot, pos_label=pos_label)\n",
    "\n",
    "    plt.title(\"Histogram for Predictions on Test Data\")\n",
    "    y_pred_pos = y_pred[y_test == 1].squeeze()\n",
    "    y_pred_neg = y_pred[y_test == 0].squeeze()\n",
    "    plt.hist(y_pred_neg, bins=20, label=\"Negative\", alpha=0.5)\n",
    "    plt.hist(y_pred_pos, bins=20, label=\"Positive (Normal)\", alpha=0.5)\n",
    "    plt.legend()\n",
    "    plt.show()\n",
    "    \n",
    "    if indiv:\n",
    "        # get indiv auprs for different attacks\n",
    "        y_normal = len(y_pred_pos)\n",
    "        fig, ax = plt.subplots(1, len(indiv), figsize=(7.5*len(indiv), 15))\n",
    "        \n",
    "        aupr_attacks = []\n",
    "        for i, att in enumerate(indiv):\n",
    "            y_att = y_pred[att_labels == att].squeeze()\n",
    "#             print(y_pred_pos.shape)\n",
    "#             print(y_att.shape)\n",
    "#             print(y_normal)\n",
    "            aupr_attacks.append(\n",
    "                get_metrics(\n",
    "                    np.hstack((y_pred_pos, y_att)), \n",
    "                    np.hstack((np.ones(y_normal), np.zeros(len(y_att)))),\n",
    "                    model.name, plot=plot)\n",
    "            )\n",
    "            \n",
    "            ax[i].set_title(f\"Attack Pred\")\n",
    "            ax[i].hist(y_att, bins=20, label=f\"Attack {att}: {attack_labels[att]}\", alpha=0.5)\n",
    "            ax[i].hist(y_pred_pos, bins=20, label=\"Positive (Normal)\", alpha=0.5)\n",
    "            ax[i].legend()\n",
    "        plt.tight_layout()\n",
    "        plt.legend()\n",
    "        plt.show()\n",
    "            \n",
    "#         display(pd.DataFrame(data={model.name: aupr_attacks}))\n",
    "            \n",
    "        return aupr_train, aupr_test, aupr_attacks\n",
    "    \n",
    "    if diff:\n",
    "        y_pos = np.mean(y_pred_pos)\n",
    "        y_neg = np.mean(y_pred_neg)\n",
    "        diff_mean = y_pos - y_neg\n",
    "        print(f\"Average Difference between Positive and Negative Class: {diff_mean}\")\n",
    "        \n",
    "        return aupr_train, aupr_test, diff_mean\n",
    "    \n",
    "    return aupr_train, aupr_test\n",
    "\n",
    "\n",
    "# strategy = tf.distribute.MirroredStrategy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "racial-gambling",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "INFO:tensorflow:Using MirroredStrategy with devices ('/job:localhost/replica:0/task:0/device:GPU:0', '/job:localhost/replica:0/task:0/device:GPU:1')\n"
     ]
    }
   ],
   "source": [
    "strategy = tf.distribute.MirroredStrategy()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "polish-baghdad",
   "metadata": {},
   "source": [
    "### Deep SAD"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "flush-smart",
   "metadata": {},
   "outputs": [],
   "source": [
    "class SAD_Dist(tf.keras.layers.Layer):\n",
    "\n",
    "    def __init__(self, centre):\n",
    "        super(SAD_Dist, self).__init__(trainable=False)\n",
    "        self.centre = centre\n",
    "\n",
    "        \n",
    "    def build(self, input_shape):  # Create the state of the layer (weights)\n",
    "        pass\n",
    "\n",
    "    \n",
    "    def call(self, x):  # Defines the computation from inputs to outputs\n",
    "        return tf.norm(x - self.centre, axis=1)\n",
    "    \n",
    "    \n",
    "class SAD(tf.keras.Model):\n",
    "    \n",
    "    def __init__(self, encoder, dist):\n",
    "        super(SAD, self).__init__()\n",
    "        self.encoder = encoder\n",
    "        self.sad_dist = dist\n",
    "\n",
    "\n",
    "    def call(self, x):  # Defines the computation from inputs to outputs\n",
    "        return self.sad_dist(self.encoder(x))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "subject-personality",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:No training configuration found in save file, so the model was *not* compiled. Compile it manually.\n",
      "3540/3540 [==============================] - 11s 3ms/step\n",
      "<keras.regularizers.L2 object at 0x7f5271681580>\n",
      "Model: \"sad_9\"\n",
      "_________________________________________________________________\n",
      " Layer (type)                Output Shape              Param #   \n",
      "=================================================================\n",
      " ae__module_5 (AE_Module)    multiple                  16831     \n",
      "                                                                 \n",
      " sad__dist_9 (SAD_Dist)      multiple                  0         \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 16,831\n",
      "Trainable params: 16,650\n",
      "Non-trainable params: 181\n",
      "_________________________________________________________________\n",
      "Epoch 1/500\n",
      "3186/3186 [==============================] - 21s 5ms/step - loss: 0.4629 - val_loss: 0.2324\n",
      "Epoch 2/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.2384 - val_loss: 0.1545\n",
      "Epoch 3/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1772 - val_loss: 0.1255\n",
      "Epoch 4/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1536 - val_loss: 0.1133\n",
      "Epoch 5/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1448 - val_loss: 0.1042\n",
      "Epoch 6/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1401 - val_loss: 0.0981\n",
      "Epoch 7/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1295 - val_loss: 0.0938\n",
      "Epoch 8/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1210 - val_loss: 0.0906\n",
      "Epoch 9/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1162 - val_loss: 0.0851\n",
      "Epoch 10/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1104 - val_loss: 0.0812\n",
      "Epoch 11/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1066 - val_loss: 0.0774\n",
      "Epoch 12/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1024 - val_loss: 0.0734\n",
      "Epoch 13/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1008 - val_loss: 0.0705\n",
      "Epoch 14/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1033 - val_loss: 0.0673\n",
      "Epoch 15/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1083 - val_loss: 0.0650\n",
      "Epoch 16/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1030 - val_loss: 0.0633\n",
      "Epoch 17/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1062 - val_loss: 0.0616\n",
      "Epoch 18/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1025 - val_loss: 0.0606\n",
      "Epoch 19/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1038 - val_loss: 0.0591\n",
      "Epoch 20/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1007 - val_loss: 0.0585\n",
      "Epoch 21/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1065 - val_loss: 0.0578\n",
      "Epoch 22/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1127 - val_loss: 0.0569\n",
      "Epoch 23/500\n",
      "3186/3186 [==============================] - 15s 5ms/step - loss: 0.1007 - val_loss: 0.0581\n",
      "Epoch 24/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1019 - val_loss: 0.0573\n",
      "Epoch 25/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0978 - val_loss: 0.0572\n",
      "Epoch 26/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1024 - val_loss: 0.0563\n",
      "Epoch 27/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0983 - val_loss: 0.0570\n",
      "Epoch 28/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0962 - val_loss: 0.0576\n",
      "Epoch 29/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0970 - val_loss: 0.0568\n",
      "Epoch 30/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1019 - val_loss: 0.0552\n",
      "Epoch 31/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0922 - val_loss: 0.0562\n",
      "Epoch 32/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0942 - val_loss: 0.0564\n",
      "Epoch 33/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0909 - val_loss: 0.0561\n",
      "Epoch 34/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0951 - val_loss: 0.0567\n",
      "Epoch 35/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0909 - val_loss: 0.0573\n",
      "Epoch 36/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0884 - val_loss: 0.0563\n",
      "Epoch 37/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0892 - val_loss: 0.0581\n",
      "Epoch 38/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0892 - val_loss: 0.0551\n",
      "Epoch 39/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0859 - val_loss: 0.0544\n",
      "Epoch 40/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0869 - val_loss: 0.0524\n",
      "Epoch 41/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0832 - val_loss: 0.0541\n",
      "Epoch 42/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0826 - val_loss: 0.0530\n",
      "Epoch 43/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0813 - val_loss: 0.0523\n",
      "Epoch 44/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0803 - val_loss: 0.0514\n",
      "Epoch 45/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0774 - val_loss: 0.0492\n",
      "Epoch 46/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0769 - val_loss: 0.0488\n",
      "Epoch 47/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0757 - val_loss: 0.0476\n",
      "Epoch 48/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0740 - val_loss: 0.0478\n",
      "Epoch 49/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0726 - val_loss: 0.0473\n",
      "Epoch 50/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0733 - val_loss: 0.0456\n",
      "Epoch 51/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0730 - val_loss: 0.0459\n",
      "Epoch 52/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0756 - val_loss: 0.0451\n",
      "Epoch 53/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0708 - val_loss: 0.0435\n",
      "Epoch 54/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0742 - val_loss: 0.0461\n",
      "Epoch 55/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0690 - val_loss: 0.0427\n",
      "Epoch 56/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0714 - val_loss: 0.0444\n",
      "Epoch 57/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0691 - val_loss: 0.0423\n",
      "Epoch 58/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0683 - val_loss: 0.0419\n",
      "Epoch 59/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0665 - val_loss: 0.0420\n",
      "Epoch 60/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0715 - val_loss: 0.0422\n",
      "Epoch 61/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0672 - val_loss: 0.0405\n",
      "Epoch 62/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0669 - val_loss: 0.0411\n",
      "Epoch 63/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0914 - val_loss: 0.0420\n",
      "Epoch 64/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0704 - val_loss: 0.0403\n",
      "Epoch 65/500\n",
      "3186/3186 [==============================] - 15s 5ms/step - loss: 0.0654 - val_loss: 0.0395\n",
      "Epoch 66/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0670 - val_loss: 0.0408\n",
      "Epoch 67/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0643 - val_loss: 0.0388\n",
      "Epoch 68/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0658 - val_loss: 0.0385\n",
      "Epoch 69/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0630 - val_loss: 0.0380\n",
      "Epoch 70/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0639 - val_loss: 0.0401\n",
      "Epoch 71/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0660 - val_loss: 0.0419\n",
      "Epoch 72/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0605 - val_loss: 0.0403\n",
      "Epoch 73/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0627 - val_loss: 0.0421\n",
      "Epoch 74/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0616 - val_loss: 0.0397\n",
      "Epoch 75/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0651 - val_loss: 0.0389\n",
      "Epoch 76/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0626 - val_loss: 0.0401\n",
      "Epoch 77/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0593 - val_loss: 0.0387\n",
      "Epoch 78/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0601 - val_loss: 0.0371\n",
      "Epoch 79/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0601 - val_loss: 0.0375\n",
      "Epoch 80/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0593 - val_loss: 0.0372\n",
      "Epoch 81/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0576 - val_loss: 0.0366\n",
      "Epoch 82/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0616 - val_loss: 0.0378\n",
      "Epoch 83/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0580 - val_loss: 0.0366\n",
      "Epoch 84/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0629 - val_loss: 0.0381\n",
      "Epoch 85/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0578 - val_loss: 0.0367\n",
      "Epoch 86/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0599 - val_loss: 0.0363\n",
      "Epoch 87/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0564 - val_loss: 0.0361\n",
      "Epoch 88/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0610 - val_loss: 0.0381\n",
      "Epoch 89/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0590 - val_loss: 0.0367\n",
      "Epoch 90/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0566 - val_loss: 0.0355\n",
      "Epoch 91/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0622 - val_loss: 0.0365\n",
      "Epoch 92/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0573 - val_loss: 0.0376\n",
      "Epoch 93/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0600 - val_loss: 0.0378\n",
      "Epoch 94/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0638 - val_loss: 0.0374\n",
      "Epoch 95/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0615 - val_loss: 0.0359\n",
      "Epoch 96/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0562 - val_loss: 0.0400\n",
      "Epoch 97/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0554 - val_loss: 0.0358\n",
      "Epoch 98/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0560 - val_loss: 0.0359\n",
      "Epoch 99/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0542 - val_loss: 0.0372\n",
      "Epoch 100/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0547 - val_loss: 0.0365\n",
      "3540/3540 [==============================] - 11s 3ms/step\n",
      "705/705 [==============================] - 2s 3ms/step\n"
     ]
    },
    {
     "data": {
      "image/png": "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6cLIkSPp0KEDn3ySfWHQcccdx7777kuXLl24+eabARg9ejRfffUVPXr04JRTTgFg662z76sePnw4Dz/8cPk2R4wYwaRJk/jb3/7GT37yE/r06UP37t353e9+V6/1YGabHif9DXTOOecwYcIEli9fvk75eeedx/nnn8/06dO59957GTlyJAA///nPOfTQQ5kzZw4nnngiCxcuLF/m1ltvZebMmcyYMYNx48axdOlSrrjiClq1asWsWbOYMGHCOtsYNmwY99xzDwDffPMNTz75JIMGDWL8+PFst912TJ8+nenTp3PLLbfwzjv+Uiwz+z/u3tlA2267Laeeeirjxo2jVatW5eVPPPEEr732Wvn4559/zooVK3jmmWe47777ABg4cCDbb799+Tzjxo0rn7Zo0SLmzZvHjjvuWOW2jzrqKM477zxWrVrFX/7yFw4++GBatWrFY489xuzZs5k0aRIAy5cvZ968eX7e3czKOelvhB/96Ef06tWL008/vbxs7dq1TJs2jZYtWxa1jilTpvDEE0/w/PPPs+WWW9K/f/8an1Fv2bIl/fv359FHH2XixIkMH559z3VEcN111zFgwIAN3ykz26y5e2cj7LDDDpx00kmMHz++vOzII4/kuuuuKx+fNWsWAP369Svvknnsscf49NNPgaw1vv3227Plllsyd+5cpk2bVr5ss2bNWL16daXbHjZsGLfddhtTp05l4MCBAAwYMIAbb7yxfJk333yTlStX1t0Om9kmb5Nv6RfziGV9uvDCC7n++uvLx8eNG8c555xD9+7dWbNmDQcffDA33XQTY8aM4Xvf+x533nknBxxwAN/+9rfZZpttGDhwIDfddBN77bUXe+yxB3379i1f16hRo+jevTu9evVar1//yCOP5Pvf/z5DhgyhefPmAIwcOZIFCxbQq1cvIoK2bdty//33N0g9mNmmoaS/I7d3795R8UtUXn/9dfbaa69GimjDrVq1iiZNmtC0aVOef/55fvCDH5RfBdj6NtXP2axSDfzIpqSZEdG7smmbfEt/U7Fw4UJOOukk1q5dS/PmzbnlllsaOyQzyyEn/QbSuXNnXn755cYOw8xyzjdyzcxyxEnfzCxHnPTNzHLESd/MLEc2/Ru5G/IoVHXq6c12ZmalwC39DdCkSRN69OhB165dGTp0KF9++WWtln///fc58cQTgew/didPnlw+7cEHH+SKK66okzjvv/9+LrvsMgDGjh3Llltuyccff1w+veytnQ1lypQpHHPMMQA89NBDXHrppQ26fTNz0t8gZW+/fPXVV2nevDk33XRTrZbfZZddyl+KVjHpDx48mNGjR9dJnL/+9a85++yzy8fbtGlT/sUvtRURrF27tk7iAhg0aBB//vOfa33CNLON46S/kQ466CDmz5/PsmXLOO644+jevTt9+/Zl9uzZADz99NP06NGDHj160LNnT7744gsWLFhA165d+eabb7j00kuZOHEiPXr0YOLEidx+++2ce+65LF++nA4dOpQn2pUrV7LrrruyevVq3nrrLQYOHMi+++7LQQcdxNy5c9eL680336RFixbrfMnLGWecwcSJE1m2bNl681911VV07dqVrl27cs011wCwYMEC9thjD0499VS6du3K1KlT2XPPPRkxYgS77747p5xyCk888QT9+vWjc+fOvPjiiwC8+OKLHHDAAfTs2ZMDDzyQN954Y73tSaJ///489NBDG/0ZmFnxnPQ3wpo1a3jkkUfo1q0bY8aMoWfPnsyePZvLL7+cU089Fci+SvGGG25g1qxZTJ06dZ3XMDdv3pzLLruMYcOGMWvWLIYNG1Y+bbvttqNHjx48/fTTQNYdMmDAAJo1a8aoUaO47rrrmDlzJldeeeU6rfkyzz77LL169VqnbOutt+aMM87g2muvXad85syZ3HbbbbzwwgtMmzaNW265pfwfyebNm8fZZ5/NnDlz6NChA/Pnz+fCCy9k7ty5zJ07l//6r//imWee4corr+Tyyy8HYM8992Tq1Km8/PLLXHbZZet8+1eh3r17M3Xq1NpWu5lthE3/Rm4jKPtGK8ha+meeeSb7778/9957LwCHHnooS5cu5fPPP6dfv35ccMEFnHLKKZxwwgm0b9++6O0MGzaMiRMncsghh3D33Xdz9tlns2LFCp577jmGDh1aPt+qVavWW/aDDz6gbdu265X/8Ic/pEePHvz4xz8uL3vmmWc4/vjj2WqrrQA44YQTmDp1KoMHD6ZDhw7rvASuU6dOdOvWDYAuXbpw2GGHIYlu3bqxYMECIHtz6Gmnnca8efOQVOWbQr/1rW/x/vvvF10fZrbxnPQ3QFmffjFGjx7NoEGDmDx5Mv369ePRRx8t+l37gwcP5uKLL2bZsmXMnDmTQw89lJUrV9K6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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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sWJblJ3hI04AWOJmzJiR9dZbz9hYQZVSst566yl+AegUdsaKy8YAYGmxJ1YuNgYAncnuWLEtys4QaABQhbGxYvPnC0Bn8vfQisufLQBLi79zVi7+vAHoTP4eWrEt7J+vQAMAAAAAAAAAoLJVO/sEAFjxfe2XDy7R5ztpjy06dL+f/OQn2X///XP//fdnq622SpJMmDAhf/rTn7L33nsnScaMGZPVVlstu+yyyyKdS7du3fLiiy/O9z5HHXVUbrjhhmywwQa57777FvicY8aMyUc/+tFsttlmefnll7PhhhvmlFNOyT777DPfxz3wwAM59thj8/zzz2fmzJkZOHBgvvWtby3U+wGA5U1n7IxlYWM8/vjjOfzww/PUU0+llJJjjjkmJ5544nyf842N0bNnz8ycOTMHH3xwzjzzzA6f0/Dhw7PPPvvkoIMO6vBjAGB5sDL/3GLGjBnZddddM3PmzLz66qs56KCD8vnPf36+z3nZZZflc5/7XDbaaKO88sorOemkk/LP//zPb7vf9ddfn4kTJ+bUU0+d53ONGDEiu+66a3bfffd86EMfyvnnn5/+/ft3/A0CwHJmZd4db3jttdfSv3//bLTRRrnhhhs69Nz77bdf/vznP+fOO+9cpHNblriCBgArrFGjRuWDH/xgRo0a1X5swoQJuemmm9q/HzNmTO64446q5zF8+PDcfPPNC/WYgQMHZvz48XnggQfyjW98I5/61Kfyq1/9ar6POeGEE3LSSSdlwoQJuf/++/PpT396cU4bAJiHZWFjrLrqqrngggsyceLE3Hnnnbn44oszceLEBT5u4MCBmTBhQu65555ceeWV+d///d833f7qq6/WOmUA4C2WhU2x+uqr59Zbb83vfve7TJgwITfffHOH/sPHsGHDMmHChIwZMyann356nnrqqTfd/uqrr2bIkCHzjTOSZOTIkdl9990X6z0AAAu2LOyON3z961/P1ltv3eH7P//88xk3blymT5+eRx55pOKZLR0CDQBWSC+++GJuu+22fPe7383VV1+dJHnllVcyYsSIjB49Om1tbTnvvPNyySWX5Gtf+1ra2toyduzY/PSnP82OO+6Yvn37Zvfdd2//AcOLL76YI488Mr17906fPn3ywx/+8E2v98wzz2TnnXfOjTfe+LZz2XXXXfPud797kd9LW1tbRowYkX//939PkkyZMiWDBw9Onz59sttuu+Wxxx5Lkjz55JPp0aNH++N69+69yK8JAMzdsrIx/u7v/i7bbbddkmTttdfO1ltvnSeeeKLD72OttdZKv379Mnny5Jx11lk57LDDMmDAgBx22GHz3BpJcsstt6R///7ZYost2v+Vy2uvvZbPfe5z2X777dOnT59ceumlC/8bCwArmWVlU5RS0q1btyTJrFmzMmvWrIX6HPUNNtgg73//+/Poo49m+PDh+eQnP5kdd9wxp5xySi677LJ86lOfyvTp07PJJpvk9ddfT5K89NJL2XjjjTNr1qwMHz4811577due9xe/+EV23nnnbLfddhk6dGj7v8a96aabstVWW6Vfv3454YQT2q82+tJLL+Woo47KDjvskL59++a6667r8HsAgBXdsrI7kmTq1Km58cYb84lPfKLD5/+jH/0o++67bw4++OD280+SyZMnZ/fdd8+2226b7bbbLg8//HCS5Lzzzkvv3r2z7bbbtseiDz/8cPbaa6/069cvAwcOzKRJk5Ik11xzTXr16pVtt902u+66a5LkD3/4Q3bYYYe0tbWlT58+eeihhzp8rh3hI04AWCFdd9112WuvvbLFFltkvfXWy7hx49KvX7+MHDky99xzT3vs8Ne//jXdunXLZz/72STJc889lzvvvDOllHznO9/Jl7/85VxwwQX5whe+kHXWWSe///3v2+/3hqeeeipDhgzJ2WefnT322KPD53jJJZckST75yU8u8L7bbbddvvKVryRJPv3pT+eII47IEUccke9973s54YQT8pOf/CQnnXRSBg8enF122SUf/vCHc+SRR2bdddft8PkAAAu2LG6MKVOmZPz48dlxxx2TdGxjPPvss7nzzjtzxhlnZOLEiZk4cWJuu+22rLnmmtl3333nujXeeK277747Dz/8cAYNGpTJkyfnP//zP7POOuvkt7/9bWbOnJkBAwbkwx/+cHr27Lnov9EAsIJbljbFa6+91h5uHn/88e2bYsSIEenfv3+GDBkyz/fxyCOP5JFHHskHPvCBJLP/o8sdd9yRLl265LLLLkuSrLPOOmlra8tvfvObDBo0KDfccEP23HPPdO3ada7P+cwzz+Tss8/OLbfckrXWWivnnXdevvrVr+aUU07Jsccem//+7/9Oz549c8ghh7Q/5pxzzsngwYPzve99L88//3x22GGH7L777llrrbU6+kcCACusZWl3fOYzn8mXv/zl/OUvf3nT8fntjlGjRmXEiBHZcMMNc+CBB+b0009Pkhx66KE59dRTs//++2fGjBl5/fXX87Of/SzXXXdd7rrrrrzjHe/ItGnTkiTHHHNMLrnkkmy++ea56667ctxxx+XWW2/NyJEj8/Of/zwbbbRRnn/++SSzf65y4okn5tBDD80rr7yS1157bTH/BN5MoAHACmnUqFHtn8N+8MEHZ9SoUenXr98CHzd16tQMGzYsTz75ZF555ZX2/7Bwyy23vKnMfNe73pVk9r8u2W233XLxxRfnH/7hHxbqHDsSZryhaZr2r//nf/4nP/rRj5Ikhx12WE455ZQkyZFHHpk999wzN998c6677rpceuml+d3vfpfVV199oc4LAJi3ZW1jvPjiiznwwANz4YUX5p3vfGeS+W+MsWPHpm/fvllllVVy6qmnZptttsk111yTIUOGZM0110wy762RJB/72MeyyiqrZPPNN89mm22WSZMm5Re/+EXuvffe9n/9On369Dz00EMCDQCYj2VpU3Tp0iUTJkzI888/n/333z/33XdfevXqlZEjR87zPEaPHp3bbrstq6++ei699NL2K4cOHTo0Xbp0edv9hw0bltGjR2fQoEG5+uqrc9xxx83zue+8885MnDgxAwYMSDL7X/juvPPOmTRpUjbbbLP293zIIYfkW9/6VpLZV9y4/vrrc/755ydJZsyYkccee2yhLp8OACuqZWV33HDDDdlggw3Sr1+/jBkz5k23zWt3PPXUU3nooYfywQ9+MKWUdO3aNffdd1822WSTPPHEE9l///2TJGussUb7uR155JF5xzvekSR597vfnRdffDF33HFHhg4d2v68M2fOTJIMGDAgw4cPz8c+9rEccMABSZKdd94555xzTqZOnZoDDjggm2+++QJ/rxaGQAOAFc60adNy66235ve//31KKXnttddSSmm/AsX8fPrTn87JJ5+cIUOGZMyYMTnrrLPme/9VV101/fr1y89//vOFDjQWxvjx4zv0Q4X3vve9Oeqoo3LUUUelV69eue+++zo0tACABVvWNsasWbNy4IEH5tBDD23/IcKCDBw4sP2jSebU0X9d+tZLnpdS0jRNLrroouy5554deg4AWNkta5viDeuuu24GDRqUm2++Ob169ZrvfYcNG9b+r23nNK9NMWTIkJx++umZNm1axo0bl8GDB8/zuZumyR577JFRo0a96fiECRPm+5gf/vCH2XLLLed73gCwslmWdsftt9+e66+/PjfddFNmzJiRF154If/0T/+UK6+8cp7P+YMf/CDPPfdcexzywgsvZNSoUe0fXdIRr7/+etZdd925bolLLrkkd911V2688cb069cv48aNy8c//vHsuOOOufHGG7P33nvn0ksvne92WVirLLFnAoBlxLXXXpvDDjssjz76aKZMmZLHH388PXv2zNixY7P22mu/6dJZb/1++vTp2WijjZIkl19+efvxPfbYIxdffHH7929csquUku9973uZNGlSzjvvvCrv5957780XvvCFHH/88UmSXXbZpb1OveqqqzJw4MAkyc0335xZs2YlSf785z/n2WefbX8vAMDiW5Y2RtM0Ofroo7P11lvn5JNPXqLvc15bI5n92ayvv/56Hn744TzyyCPZcssts+eee+ab3/xm+w558MEH89JLLy3RcwKAFcmytCmefvrp9st5//Wvf80vf/nLbLXVVkv0/SZJt27dsv322+fEE0/MPvvsM9erbLxhp512yu23357JkycnSV566aU8+OCD2XLLLfPII49kypQpSWZfxeMNe+65Zy666KL2K5COHz9+ib8HAFgeLUu744tf/GKmTp2aKVOm5Oqrr87gwYPnG2cks6/+cfPNN2fKlCmZMmVKxo0bl6uvvjprr712evTo0f6RrDNnzszLL7+cPfbYI9///vfz8ssvJ5kdqLzzne9Mz549c8011ySZ/TOV3/3ud0mShx9+ODvuuGNGjhyZ7t275/HHH88jjzySzTbbLCeccEI++tGP5t577+3w73dHuIIGANWdtMcWS/X1Ro0alX/9139907EDDzwwo0aNyjnnnJMvfelLaWtry2mnnZZ99903Bx10UK677rpcdNFFOeusszJ06NC8613vyuDBg/PHP/4xSfJv//ZvOf7449OrV6906dIlZ555Zvu/VO3SpUtGjRqVIUOGZO21137bZToPOeSQjBkzJs8880x69OiRz3/+8zn66KPn+/nwb1x+/OWXX84GG2yQb3zjG9ltt92SJBdddFGOPPLIfOUrX0n37t3z/e9/P8nsy3meeOKJ7Zfy+spXvpL3vOc9S/B3FgCWPUtzZyxLG+P222/PFVdckd69e6etrS1Jcu6552bvvfee78boiHltjSR53/velx122CEvvPBCLrnkkqyxxhr5xCc+kSlTpmS77bZL0zTp3r17+w9IAGB5sDL/3OLJJ5/MEUcckddeey2vv/56Pvaxj2WfffZJMv/Pgl8Uw4YNy9ChQ992SfO36t69ey677LIccsgh7ZcfP/vss7PFFlvkP/7jP7LXXntlrbXWyvbbb9/+mDPOOCOf+cxn0qdPn7z++uvp2bPnXK8aBgCdbWXeHfMzt90xZcqUPProo9lpp53aj/Xs2TPrrLNO7rrrrlxxxRU59thjM2LEiHTt2jXXXHNN9tprr0yYMCH9+/fPaqutlr333jvnnnturrrqqvzLv/xLzj777MyaNSsHH3xwtt1223zuc5/LQw89lKZpsttuu2XbbbfNeeedlyuuuCJdu3bNe97znpx++umL+8fwJmXOz7Rf1vTv37+55557Ovs0AFhI999/v8/4XAnM7c+5lDKuaZr+nXRKC8XOAFg+2RkrPhsDgNrsieXXiy++mG7duqVpmhx//PHZfPPNc9JJJ3XosTYGAJ3B7lg5LMzO8BEnAAAAAADAMu/b3/522trass0222T69Ok59thjO/uUAAAWio84AQAAAAAAlnknnXRSh6+YAQCwLHIFDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVLZqZ58AACuBX39xyT7foNOW7PMBAMsvOwMAWFz2BACwtNgdKz1X0ABghdSlS5e0tbWlV69eGTp0aF5++eWFevyf/vSnHHTQQUmSCRMm5Kabbmq/7frrr8+XvvSlJXKeP/nJTzJy5MgkyVlnnZV3vOMd+b//+7/227t167ZEXqejxowZk3322SdJcsMNN2TEiBFL9fUBYFlnYywaGwMA3symWDQ2BQAsPLtj0dTaHQINAFZIa665ZiZMmJD77rsvq622Wi655JKFevx73/veXHvttUnePjiGDBmSU089dYmc55e//OUcd9xx7d+vv/76ueCCCxbpuZqmyeuvv75EzitJPvKRj+SnP/3pQo81AFiR2RiLz8YAAJtiSbApAKBj7I7FtyR3h0ADgBXewIEDM3ny5EybNi377bdf+vTpk5122in33ntvkuQ3v/lN2tra0tbWlr59++Yvf/lLpkyZkl69euWVV17JiBEjMnr06LS1tWX06NG57LLL8qlPfSrTp0/PJpts0v6X/EsvvZSNN944s2bNysMPP5y99tor/fr1y8CBAzNp0qS3ndeDDz6Y1VdfPeuvv377saOOOiqjR4/OtGnT3nb/r371q+nVq1d69eqVCy+8MEkyZcqUbLnlljn88MPTq1evjB07NltttVWGDx+eLbbYIoceemhuueWWDBgwIJtvvnnuvvvuJMndd9+dnXfeOX379s0uu+ySBx544G2vV0rJhz70odxwww2L/WcAACsiG8PGAIAlwaawKQBgabE7On93CDQAWKG9+uqr+dnPfpbevXvnzDPPTN++fXPvvffm3HPPzeGHH54kOf/883PxxRdnwoQJGTt2bNZcc832x6+22moZOXJkhg0blgkTJmTYsGHtt62zzjppa2vLb37zmySzL3G15557pmvXrjnmmGNy0UUXZdy4cTn//PPfVH2+4fbbb8922233pmPdunXLUUcdla9//etvOj5u3Lh8//vfz1133ZU777wz3/72tzN+/PgkyUMPPZTjjjsuf/jDH7LJJptk8uTJ+X//7/9l0qRJmTRpUv7rv/4rt912W84///yce+65SZKtttoqY8eOzfjx4zNy5Micfvrpc/3969+/f8aOHbuwv+0AsMKzMWwMAFgSbAqbAgCWFrtj2dgdqy72MwDAMuivf/1r2trakswuQo8++ujsuOOO+eEPf5gkGTx4cJ599tm88MILGTBgQE4++eQceuihOeCAA9KjR48Ov86wYcMyevToDBo0KFdffXWOO+64vPjii7njjjsydOjQ9vvNnDnzbY998skn071797cdP+GEE9LW1pbPfvaz7cduu+227L///llrrbWSJAcccEDGjh2bIUOGZJNNNslOO+3Uft+ePXumd+/eSZJtttkmu+22W0op6d27d6ZMmZIkmT59eo444og89NBDKaVk1qxZc31/G2ywQf70pz91+PcDAFZ0NoaNAQBLgk1hUwDA0mJ3LFu7Q6ABwArpjc9U64hTTz01H/nIR3LTTTdlwIAB+fnPf5411lijQ48dMmRITj/99EybNi3jxo3L4MGD89JLL2Xddddd4OuvueaamT59+tuOr7vuuvn4xz+eiy++uEPn8MYIecPqq6/e/vUqq6zS/v0qq6ySV199NUlyxhlnZNCgQfnxj3+cKVOm5EMf+tBcn3vGjBlvKmQBYGVnY8xmYwDA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AAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAA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AAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoLIOBxqllC6llPGllBta3/cspdxVSplcShldSlmtdXz11veTW7dvOsdznNY6/kApZc8l/m4AgOWOjQEA1GBjAAC12BkAwKJamCtonJjk/jm+Py/J15qm+UCS55Ic3Tp+dJLnWse/1rpfSil/n+TgJNsk2SvJf5RSuize6QMAKwAbAwCowcYAAGqxMwCARdKhQKOU0iPJR5J8p/V9STI4ybWtu1yeZL/W1x9tfZ/W7bu17v/RJFc3TTOzaZo/JpmcZIcl8B4AgOWUjQEA1GBjAAC12BkAwOLo6BU0LkxySpLXW9+vl+T5pmlebX0/NclGra83SvJ4krRun966f/vxuTwGAFg5XRgbAwBY8i6MjQEA1HFh7AwAYBEtMNAopeyT5P+aphm3FM4npZRjSin3lFLuefrpp5fGSwIAnWBpb4zWa9oZALCCszEAgFr89xIAYHF15AoaA5IMKaVMSXJ1Zl+q6+tJ1i2lrNq6T48kT7S+fiLJxknSun2dJM/OeXwuj2nXNM23mqbp3zRN/+7duy/0GwIAlhtLdWMkdgYArCRsDACgFv+9BABYLAsMNJqmOa1pmh5N02ya5OAktzZNc2iSXyc5qHW3I5Jc1/r6+tb3ad1+a9M0Tev4waWU1UspPZNsnuTuJfZOAIDlio0BANRgYwAAtdgZAMDiWnXBd5mnf01ydSnl7CTjk3y3dfy7Sa4opUxOMi2zR0qapvlDKeUHSSYmeTXJ8U3TvLYYrw8ArJhsDACgBhsDAKjFzgAAOmShAo2macYkGdP6+pEkO8zlPjOSDJ3H489Jcs7CniQAsGKzMQCAGmwMAKAWOwMAWBQL/IgTAAAAAAAAAAAWj0ADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAA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\n",
      "text/plain": [
       "<Figure size 2160x1080 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AUPR Train Run 1: 0.9999111376052738\n",
      "AUPR Test Run 1: 0.9506646056365564\n",
      "AUPR Indiv Test Run 1: [0.9585875435609656, 0.7922989090130894, 0.047428154430499275, 0.5163538884515257]\n",
      "WARNING:tensorflow:No training configuration found in save file, so the model was *not* compiled. Compile it manually.\n",
      "<keras.regularizers.L2 object at 0x7f52713b3670>\n",
      "Epoch 1/500\n",
      "3186/3186 [==============================] - 21s 5ms/step - loss: 0.4629 - val_loss: 0.2324\n",
      "Epoch 2/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.2384 - val_loss: 0.1545\n",
      "Epoch 3/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1772 - val_loss: 0.1255\n",
      "Epoch 4/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1536 - val_loss: 0.1133\n",
      "Epoch 5/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1448 - val_loss: 0.1042\n",
      "Epoch 6/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1401 - val_loss: 0.0981\n",
      "Epoch 7/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1295 - val_loss: 0.0938\n",
      "Epoch 8/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1210 - val_loss: 0.0907\n",
      "Epoch 9/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1162 - val_loss: 0.0851\n",
      "Epoch 10/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1104 - val_loss: 0.0811\n",
      "Epoch 11/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1065 - val_loss: 0.0774\n",
      "Epoch 12/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1024 - val_loss: 0.0734\n",
      "Epoch 13/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1008 - val_loss: 0.0705\n",
      "Epoch 14/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1035 - val_loss: 0.0673\n",
      "Epoch 15/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1069 - val_loss: 0.0650\n",
      "Epoch 16/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1030 - val_loss: 0.0635\n",
      "Epoch 17/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1067 - val_loss: 0.0614\n",
      "Epoch 18/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1032 - val_loss: 0.0602\n",
      "Epoch 19/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1045 - val_loss: 0.0590\n",
      "Epoch 20/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1009 - val_loss: 0.0588\n",
      "Epoch 21/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1006 - val_loss: 0.0582\n",
      "Epoch 22/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1016 - val_loss: 0.0583\n",
      "Epoch 23/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1079 - val_loss: 0.0565\n",
      "Epoch 24/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1015 - val_loss: 0.0570\n",
      "Epoch 25/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1028 - val_loss: 0.0571\n",
      "Epoch 26/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1001 - val_loss: 0.0571\n",
      "Epoch 27/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1003 - val_loss: 0.0562\n",
      "Epoch 28/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0967 - val_loss: 0.0572\n",
      "Epoch 29/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0988 - val_loss: 0.0559\n",
      "Epoch 30/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0942 - val_loss: 0.0558\n",
      "Epoch 31/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0960 - val_loss: 0.0559\n",
      "Epoch 32/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0923 - val_loss: 0.0568\n",
      "Epoch 33/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0946 - val_loss: 0.0575\n",
      "Epoch 34/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0905 - val_loss: 0.0586\n",
      "Epoch 35/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0918 - val_loss: 0.0562\n",
      "Epoch 36/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0901 - val_loss: 0.0566\n",
      "Epoch 37/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0875 - val_loss: 0.0563\n",
      "Epoch 38/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0895 - val_loss: 0.0559\n",
      "Epoch 39/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0858 - val_loss: 0.0544\n",
      "Epoch 40/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0850 - val_loss: 0.0543\n",
      "Epoch 41/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0841 - val_loss: 0.0514\n",
      "Epoch 42/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0826 - val_loss: 0.0524\n",
      "Epoch 43/500\n",
      "3186/3186 [==============================] - 15s 5ms/step - loss: 0.0808 - val_loss: 0.0525\n",
      "Epoch 44/500\n",
      "3186/3186 [==============================] - 15s 5ms/step - loss: 0.0784 - val_loss: 0.0505\n",
      "Epoch 45/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0772 - val_loss: 0.0487\n",
      "Epoch 46/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0777 - val_loss: 0.0484\n",
      "Epoch 47/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0747 - val_loss: 0.0510\n",
      "Epoch 48/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0748 - val_loss: 0.0451\n",
      "Epoch 49/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0749 - val_loss: 0.0492\n",
      "Epoch 50/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0726 - val_loss: 0.0461\n",
      "Epoch 51/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0748 - val_loss: 0.0488\n",
      "Epoch 52/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0702 - val_loss: 0.0434\n",
      "Epoch 53/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0738 - val_loss: 0.0465\n",
      "Epoch 54/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0694 - val_loss: 0.0438\n",
      "Epoch 55/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0716 - val_loss: 0.0438\n",
      "Epoch 56/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0695 - val_loss: 0.0433\n",
      "Epoch 57/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0693 - val_loss: 0.0431\n",
      "Epoch 58/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0682 - val_loss: 0.0470\n",
      "Epoch 59/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0674 - val_loss: 0.0438\n",
      "Epoch 60/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0736 - val_loss: 0.0412\n",
      "Epoch 61/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0680 - val_loss: 0.0399\n",
      "Epoch 62/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0691 - val_loss: 0.0415\n",
      "Epoch 63/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0678 - val_loss: 0.0428\n",
      "Epoch 64/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0716 - val_loss: 0.0402\n",
      "Epoch 65/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0639 - val_loss: 0.0403\n",
      "Epoch 66/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0749 - val_loss: 0.0407\n",
      "Epoch 67/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0703 - val_loss: 0.0397\n",
      "Epoch 68/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0666 - val_loss: 0.0395\n",
      "Epoch 69/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0621 - val_loss: 0.0393\n",
      "Epoch 70/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0662 - val_loss: 0.0385\n",
      "Epoch 71/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0616 - val_loss: 0.0383\n",
      "Epoch 72/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0632 - val_loss: 0.0395\n",
      "Epoch 73/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0635 - val_loss: 0.0391\n",
      "Epoch 74/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0642 - val_loss: 0.0385\n",
      "Epoch 75/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0618 - val_loss: 0.0377\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0653 - val_loss: 0.0376\n",
      "Epoch 77/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0627 - val_loss: 0.0373\n",
      "Epoch 78/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0613 - val_loss: 0.0373\n",
      "Epoch 79/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0606 - val_loss: 0.0380\n",
      "Epoch 80/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0600 - val_loss: 0.0368\n",
      "Epoch 81/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0601 - val_loss: 0.0382\n",
      "Epoch 82/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0590 - val_loss: 0.0382\n",
      "Epoch 83/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0606 - val_loss: 0.0378\n",
      "Epoch 84/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0603 - val_loss: 0.0373\n",
      "Epoch 85/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0595 - val_loss: 0.0357\n",
      "Epoch 86/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0582 - val_loss: 0.0377\n",
      "Epoch 87/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0615 - val_loss: 0.0368\n",
      "Epoch 88/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0570 - val_loss: 0.0353\n",
      "Epoch 89/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0581 - val_loss: 0.0370\n",
      "Epoch 90/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0566 - val_loss: 0.0364\n",
      "Epoch 91/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0564 - val_loss: 0.0366\n",
      "Epoch 92/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0566 - val_loss: 0.0368\n",
      "Epoch 93/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0555 - val_loss: 0.0363\n",
      "Epoch 94/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0553 - val_loss: 0.0363\n",
      "Epoch 95/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0564 - val_loss: 0.0365\n",
      "Epoch 96/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0551 - val_loss: 0.0357\n",
      "Epoch 97/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0546 - val_loss: 0.0379\n",
      "Epoch 98/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0571 - val_loss: 0.0365\n",
      "3540/3540 [==============================] - 12s 3ms/step\n",
      "705/705 [==============================] - 2s 3ms/step\n"
     ]
    },
    {
     "data": {
      "image/png": "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tMcff5zrr7++WuJ89NFHufbaawGYMGECe+65J59++mnx9KK3dtaWmTNncvrppwPwxBNPcM0119Tq9s3MSb9Kit5++cYbb9CwYUMmTZpUqeUPPPDA4peilUz6gwYNYuzYsdUS5y9/+UsuueSS4vGWLVsWf/FLZUUE27Ztq5a4AAYOHMgf//jHSn9gmtnOcdLfScceeyxLly5lzZo1nHnmmXTr1o0+ffqwcOFCAF544QW6d+9O9+7d6dGjB+vXr2fZsmV06dKFr7/+mmuuuYapU6fSvXt3pk6dyr333stll13GunXraNeuXXGi3bhxI23btmXLli28++67DBgwgCOOOIJjjz2WxYsX7xDXO++8Q6NGjbb7kpcLL7yQqVOnsmbNmh3mv/HGG+nSpQtdunTh5ptvBmDZsmUccsghnH/++XTp0oVZs2Zx6KGHMnLkSA4++GCGDx/Os88+S9++fenYsSOvvfYaAK+99hpHH300PXr04JhjjuHtt9/eYXuS6NevH0888cROHwMzy5+T/k7YunUrTz31FF27dmX8+PH06NGDhQsXct1113H++ecDyVcp3n777SxYsIBZs2Zt9xrmhg0bcu211zJ06FAWLFjA0KFDi6fts88+dO/enRdeeAFIukP69+9PgwYNGD16NLfeeivz5s3jhhtu2K41X+Sll16iZ8+e25XtvffeXHjhhdxyyy3blc+bN4977rmHV199ldmzZ3PXXXcV/yPZkiVLuOSSS1i0aBHt2rVj6dKlXHnllSxevJjFixfzX//1X7z44ovccMMNXHfddQAceuihzJo1i/nz53Pttddu9+1fuXr16sWsWbMqW+1mthN2/Ru5daDoG60gaelfdNFFHHXUUTz88MMAnHDCCaxevZovvviCvn37csUVVzB8+HDOPvts2rRpk/d2hg4dytSpUzn++ON58MEHueSSS9iwYQMvv/wyQ4YMKZ5v8+bNOyz70Ucf0apVqx3Kv//979O9e3d++MMfFpe9+OKLnHXWWey1114AnH322cyaNYtBgwbRrl277V4C16FDB7p27QpA586dOfHEE5FE165dWbZsGZC8OXTEiBEsWbIESWW+KfQb3/gGH374Yd71YWY7z0m/Cor69PMxduxYBg4cyPTp0+nbty9PP/103u/aHzRoEFdddRVr1qxh3rx5nHDCCWzcuJHmzZtXuP0m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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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sWJblJ3hI04AWOJmzJiR9dZbz9hYQZVSst566yl+AegUdsaKy8YAYGmxJ1YuNgYAncnuWLEtys4QaABQhbGxYvPnC0Bn8vfQisufLQBLi79zVi7+vAHoTP4eWrEt7J+vQAMAAAAAAAAAoLJVO/sEAFjxfe2XDy7R5ztpjy06dL+f/OQn2X///XP//fdnq622SpJMmDAhf/rTn7L33nsnScaMGZPVVlstu+yyyyKdS7du3fLiiy/O9z5HHXVUbrjhhmywwQa57777FvicY8aMyUc/+tFsttlmefnll7PhhhvmlFNOyT777DPfxz3wwAM59thj8/zzz2fmzJkZOHBgvvWtby3U+wGA5U1n7IxlYWM8/vjjOfzww/PUU0+llJJjjjkmJ5544nyf842N0bNnz8ycOTMHH3xwzjzzzA6f0/Dhw7PPPvvkoIMO6vBjAGB5sDL/3GLGjBnZddddM3PmzLz66qs56KCD8vnPf36+z3nZZZflc5/7XDbaaKO88sorOemkk/LP//zPb7vf9ddfn4kTJ+bUU0+d53ONGDEiu+66a3bfffd86EMfyvnnn5/+/ft3/A0CwHJmZd4db3jttdfSv3//bLTRRrnhhhs69Nz77bdf/vznP+fOO+9cpHNblriCBgArrFGjRuWDH/xgRo0a1X5swoQJuemmm9q/HzNmTO64446q5zF8+PDcfPPNC/WYgQMHZvz48XnggQfyjW98I5/61Kfyq1/9ar6POeGEE3LSSSdlwoQJuf/++/PpT396cU4bAJiHZWFjrLrqqrngggsyceLE3Hnnnbn44oszceLEBT5u4MCBmTBhQu65555ceeWV+d///d833f7qq6/WOmUA4C2WhU2x+uqr59Zbb83vfve7TJgwITfffHOH/sPHsGHDMmHChIwZMyann356nnrqqTfd/uqrr2bIkCHzjTOSZOTIkdl9990X6z0AAAu2LOyON3z961/P1ltv3eH7P//88xk3blymT5+eRx55pOKZLR0CDQBWSC+++GJuu+22fPe7383VV1+dJHnllVcyYsSIjB49Om1tbTnvvPNyySWX5Gtf+1ra2toyduzY/PSnP82OO+6Yvn37Zvfdd2//AcOLL76YI488Mr17906fPn3ywx/+8E2v98wzz2TnnXfOjTfe+LZz2XXXXfPud797kd9LW1tbRowYkX//939PkkyZMiWDBw9Onz59sttuu+Wxxx5Lkjz55JPp0aNH++N69+69yK8JAMzdsrIx/u7v/i7bbbddkmTttdfO1ltvnSeeeKLD72OttdZKv379Mnny5Jx11lk57LDDMmDAgBx22GHz3BpJcsstt6R///7ZYost2v+Vy2uvvZbPfe5z2X777dOnT59ceumlC/8bCwArmWVlU5RS0q1btyTJrFmzMmvWrIX6HPUNNtgg73//+/Poo49m+PDh+eQnP5kdd9wxp5xySi677LJ86lOfyvTp07PJJpvk9ddfT5K89NJL2XjjjTNr1qwMHz4811577due9xe/+EV23nnnbLfddhk6dGj7v8a96aabstVWW6Vfv3454YQT2q82+tJLL+Woo47KDjvskL59++a6667r8HsAgBXdsrI7kmTq1Km58cYb84lPfKLD5/+jH/0o++67bw4++OD280+SyZMnZ/fdd8+2226b7bbbLg8//HCS5Lzzzkvv3r2z7bbbtseiDz/8cPbaa6/069cvAwcOzKRJk5Ik11xzTXr16pVtt902u+66a5LkD3/4Q3bYYYe0tbWlT58+eeihhzp8rh3hI04AWCFdd9112WuvvbLFFltkvfXWy7hx49KvX7+MHDky99xzT3vs8Ne//jXdunXLZz/72STJc889lzvvvDOllHznO9/Jl7/85VxwwQX5whe+kHXWWSe///3v2+/3hqeeeipDhgzJ2WefnT322KPD53jJJZckST75yU8u8L7bbbddvvKVryRJPv3pT+eII47IEUccke9973s54YQT8pOf/CQnnXRSBg8enF122SUf/vCHc+SRR2bdddft8PkAAAu2LG6MKVOmZPz48dlxxx2TdGxjPPvss7nzzjtzxhlnZOLEiZk4cWJuu+22rLnmmtl3333nujXeeK277747Dz/8cAYNGpTJkyfnP//zP7POOuvkt7/9bWbOnJkBAwbkwx/+cHr27Lnov9EAsIJbljbFa6+91h5uHn/88e2bYsSIEenfv3+GDBkyz/fxyCOP5JFHHskHPvCBJLP/o8sdd9yRLl265LLLLkuSrLPOOmlra8tvfvObDBo0KDfccEP23HPPdO3ada7P+cwzz+Tss8/OLbfckrXWWivnnXdevvrVr+aUU07Jsccem//+7/9Oz549c8ghh7Q/5pxzzsngwYPzve99L88//3x22GGH7L777llrrbU6+kcCACusZWl3fOYzn8mXv/zl/OUvf3nT8fntjlGjRmXEiBHZcMMNc+CBB+b0009Pkhx66KE59dRTs//++2fGjBl5/fXX87Of/SzXXXdd7rrrrrzjHe/ItGnTkiTHHHNMLrnkkmy++ea56667ctxxx+XWW2/NyJEj8/Of/zwbbbRRnn/++SSzf65y4okn5tBDD80rr7yS1157bTH/BN5MoAHACmnUqFHtn8N+8MEHZ9SoUenXr98CHzd16tQMGzYsTz75ZF555ZX2/7Bwyy23vKnMfNe73pVk9r8u2W233XLxxRfnH/7hHxbqHDsSZryhaZr2r//nf/4nP/rRj5Ikhx12WE455ZQkyZFHHpk999wzN998c6677rpceuml+d3vfpfVV199oc4LAJi3ZW1jvPjiiznwwANz4YUX5p3vfGeS+W+MsWPHpm/fvllllVVy6qmnZptttsk111yTIUOGZM0110wy762RJB/72MeyyiqrZPPNN89mm22WSZMm5Re/+EXuvffe9n/9On369Dz00EMCDQCYj2VpU3Tp0iUTJkzI888/n/333z/33XdfevXqlZEjR87zPEaPHp3bbrstq6++ei699NL2K4cOHTo0Xbp0edv9hw0bltGjR2fQoEG5+uqrc9xxx83zue+8885MnDgxAwYMSDL7X/juvPPOmTRpUjbbbLP293zIIYfkW9/6VpLZV9y4/vrrc/755ydJZsyYkccee2yhLp8OACuqZWV33HDDDdlggw3Sr1+/jBkz5k23zWt3PPXUU3nooYfywQ9+MKWUdO3aNffdd1822WSTPPHEE9l///2TJGussUb7uR155JF5xzvekSR597vfnRdffDF33HFHhg4d2v68M2fOTJIMGDAgw4cPz8c+9rEccMABSZKdd94555xzTqZOnZoDDjggm2+++QJ/rxaGQAOAFc60adNy66235ve//31KKXnttddSSmm/AsX8fPrTn87JJ5+cIUOGZMyYMTnrrLPme/9VV101/fr1y89//vOFDjQWxvjx4zv0Q4X3vve9Oeqoo3LUUUelV69eue+++zo0tACABVvWNsasWbNy4IEH5tBDD23/IcKCDBw4sP2jSebU0X9d+tZLnpdS0jRNLrroouy5554deg4AWNkta5viDeuuu24GDRqUm2++Ob169ZrvfYcNG9b+r23nNK9NMWTIkJx++umZNm1axo0bl8GDB8/zuZumyR577JFRo0a96fiECRPm+5gf/vCH2XLLLed73gCwslmWdsftt9+e66+/PjfddFNmzJiRF154If/0T/+UK6+8cp7P+YMf/CDPPfdcexzywgsvZNSoUe0fXdIRr7/+etZdd925bolLLrkkd911V2688cb069cv48aNy8c//vHsuOOOufHGG7P33nvn0ksvne92WVirLLFnAoBlxLXXXpvDDjssjz76aKZMmZLHH388PXv2zNixY7P22mu/6dJZb/1++vTp2WijjZIkl19+efvxPfbYIxdffHH7929csquUku9973uZNGlSzjvvvCrv5957780XvvCFHH/88UmSXXbZpb1OveqqqzJw4MAkyc0335xZs2YlSf785z/n2WefbX8vAMDiW5Y2RtM0Ofroo7P11lvn5JNPXqLvc15bI5n92ayvv/56Hn744TzyyCPZcssts+eee+ab3/xm+w558MEH89JLLy3RcwKAFcmytCmefvrp9st5//Wvf80vf/nLbLXVVkv0/SZJt27dsv322+fEE0/MPvvsM9erbLxhp512yu23357JkycnSV566aU8+OCD2XLLLfPII49kypQpSWZfxeMNe+65Zy666KL2K5COHz9+ib8HAFgeLUu744tf/GKmTp2aKVOm5Oqrr87gwYPnG2cks6/+cfPNN2fKlCmZMmVKxo0bl6uvvjprr712evTo0f6RrDNnzszLL7+cPfbYI9///vfz8ssvJ5kdqLzzne9Mz549c8011ySZ/TOV3/3ud0mShx9+ODvuuGNGjhyZ7t275/HHH88jjzySzTbbLCeccEI++tGP5t577+3w73dHuIIGANWdtMcWS/X1Ro0alX/9139907EDDzwwo0aNyjnnnJMvfelLaWtry2mnnZZ99903Bx10UK677rpcdNFFOeusszJ06NC8613vyuDBg/PHP/4xSfJv//ZvOf7449OrV6906dIlZ555Zvu/VO3SpUtGjRqVIUOGZO21137bZToPOeSQjBkzJs8880x69OiRz3/+8zn66KPn+/nwb1x+/OWXX84GG2yQb3zjG9ltt92SJBdddFGOPPLIfOUrX0n37t3z/e9/P8nsy3meeOKJ7Zfy+spXvpL3vOc9S/B3FgCWPUtzZyxLG+P222/PFVdckd69e6etrS1Jcu6552bvvfee78boiHltjSR53/velx122CEvvPBCLrnkkqyxxhr5xCc+kSlTpmS77bZL0zTp3r17+w9IAGB5sDL/3OLJJ5/MEUcckddeey2vv/56Pvaxj2WfffZJMv/Pgl8Uw4YNy9ChQ992SfO36t69ey677LIccsgh7ZcfP/vss7PFFlvkP/7jP7LXXntlrbXWyvbbb9/+mDPOOCOf+cxn0qdPn7z++uvp2bPnXK8aBgCdbWXeHfMzt90xZcqUPProo9lpp53aj/Xs2TPrrLNO7rrrrlxxxRU59thjM2LEiHTt2jXXXHNN9tprr0yYMCH9+/fPaqutlr333jvnnnturrrqqvzLv/xLzj777MyaNSsHH3xwtt1223zuc5/LQw89lKZpsttuu2XbbbfNeeedlyuuuCJdu3bNe97znpx++umL+8fwJmXOz7Rf1vTv37+55557Ovs0AFhI999/v8/4XAnM7c+5lDKuaZr+nXRKC8XOAFg+2RkrPhsDgNrsieXXiy++mG7duqVpmhx//PHZfPPNc9JJJ3XosTYGAJ3B7lg5LMzO8BEnAAAAAADAMu/b3/522trass0222T69Ok59thjO/uUAAAWio84AQAAAAAAlnknnXRSh6+YAQCwLHIFDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVLZqZ58AACuBX39xyT7foNOW7PMBAMsvOwMAWFz2BACwtNgdKz1X0ABghdSlS5e0tbWlV69eGTp0aF5++eWFevyf/vSnHHTQQUmSCRMm5Kabbmq/7frrr8+XvvSlJXKeP/nJTzJy5MgkyVlnnZV3vOMd+b//+7/227t167ZEXqejxowZk3322SdJcsMNN2TEiBFL9fUBYFlnYywaGwMA3symWDQ2BQAsPLtj0dTaHQINAFZIa665ZiZMmJD77rsvq622Wi655JKFevx73/veXHvttUnePjiGDBmSU089dYmc55e//OUcd9xx7d+vv/76ueCCCxbpuZqmyeuvv75EzitJPvKRj+SnP/3pQo81AFiR2RiLz8YAAJtiSbApAKBj7I7FtyR3h0ADgBXewIEDM3ny5EybNi377bdf+vTpk5122in33ntvkuQ3v/lN2tra0tbWlr59++Yvf/lLpkyZkl69euWVV17JiBEjMnr06LS1tWX06NG57LLL8qlPfSrTp0/PJpts0v6X/EsvvZSNN944s2bNysMPP5y99tor/fr1y8CBAzNp0qS3ndeDDz6Y1VdfPeuvv377saOOOiqjR4/OtGnT3nb/r371q+nVq1d69eqVCy+8MEkyZcqUbLnlljn88MPTq1evjB07NltttVWGDx+eLbbYIoceemhuueWWDBgwIJtvvnnuvvvuJMndd9+dnXfeOX379s0uu+ySBx544G2vV0rJhz70odxwww2L/WcAACsiG8PGAIAlwaawKQBgabE7On93CDQAWKG9+uqr+dnPfpbevXvnzDPPTN++fXPvvffm3HPPzeGHH54kOf/883PxxRdnwoQJGTt2bNZcc832x6+22moZOXJkhg0blgkTJmTYsGHtt62zzjppa2vLb37zmySzL3G15557pmvXrjnmmGNy0UUXZdy4cTn//PPfVH2+4fbbb8922233pmPdunXLUUcdla9//etvOj5u3Lh8//vfz1133ZU777wz3/72tzN+/PgkyUMPPZTjjjsuf/jDH7LJJptk8uTJ+X//7/9l0qRJmTRpUv7rv/4rt912W84///yce+65SZKtttoqY8eOzfjx4zNy5Micfvrpc/3969+/f8aOHbuwv+0AsMKzMWwMAFgSbAqbAgCWFrtj2dgdqy72MwDAMuivf/1r2trakswuQo8++ujsuOOO+eEPf5gkGTx4cJ599tm88MILGTBgQE4++eQceuihOeCAA9KjR48Ov86wYcMyevToDBo0KFdffXWOO+64vPjii7njjjsydOjQ9vvNnDnzbY998skn071797cdP+GEE9LW1pbPfvaz7cduu+227L///llrrbWSJAcccEDGjh2bIUOGZJNNNslOO+3Uft+ePXumd+/eSZJtttkmu+22W0op6d27d6ZMmZIkmT59eo444og89NBDKaVk1qxZc31/G2ywQf70pz91+PcDAFZ0NoaNAQBLgk1hUwDA0mJ3LFu7Q6ABwArpjc9U64hTTz01H/nIR3LTTTdlwIAB+fnPf5411lijQ48dMmRITj/99EybNi3jxo3L4MGD89JLL2Xddddd4OuvueaamT59+tuOr7vuuvn4xz+eiy++uEPn8MYIecPqq6/e/vUqq6zS/v0qq6ySV199NUlyxhlnZNCgQfnxj3+cKVOm5EMf+tBcn3vGjBlvKmQBYGVnY8xmYwDA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AAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAA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AAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoLIOBxqllC6llPGllBta3/cspdxVSplcShldSlmtdXz11veTW7dvOsdznNY6/kApZc8l/m4AgOWOjQEA1GBjAAC12BkAwKJamCtonJjk/jm+Py/J15qm+UCS55Ic3Tp+dJLnWse/1rpfSil/n+TgJNsk2SvJf5RSuize6QMAKwAbAwCowcYAAGqxMwCARdKhQKOU0iPJR5J8p/V9STI4ybWtu1yeZL/W1x9tfZ/W7bu17v/RJFc3TTOzaZo/JpmcZIcl8B4AgOWUjQEA1GBjAAC12BkAwOLo6BU0LkxySpLXW9+vl+T5pmlebX0/NclGra83SvJ4krRun966f/vxuTwGAFg5XRgbAwBY8i6MjQEA1HFh7AwAYBEtMNAopeyT5P+aphm3FM4npZRjSin3lFLuefrpp5fGSwIAnWBpb4zWa9oZALCCszEAgFr89xIAYHF15AoaA5IMKaVMSXJ1Zl+q6+tJ1i2lrNq6T48kT7S+fiLJxknSun2dJM/OeXwuj2nXNM23mqbp3zRN/+7duy/0GwIAlhtLdWMkdgYArCRsDACgFv+9BABYLAsMNJqmOa1pmh5N02ya5OAktzZNc2iSXyc5qHW3I5Jc1/r6+tb3ad1+a9M0Tev4waWU1UspPZNsnuTuJfZOAIDlio0BANRgYwAAtdgZAMDiWnXBd5mnf01ydSnl7CTjk3y3dfy7Sa4opUxOMi2zR0qapvlDKeUHSSYmeTXJ8U3TvLYYrw8ArJhsDACgBhsDAKjFzgAAOmShAo2macYkGdP6+pEkO8zlPjOSDJ3H489Jcs7CniQAsGKzMQCAGmwMAKAWOwMAWBQL/IgTAAAAAAAAAAAWj0ADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAA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\n",
      "text/plain": [
       "<Figure size 2160x1080 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AUPR Train Run 2: 0.9999005059088106\n",
      "AUPR Test Run 2: 0.9541772062213786\n",
      "AUPR Indiv Test Run 2: [0.9628440726570023, 0.8000284382509387, 0.04939449820619783, 0.5110148502249012]\n",
      "WARNING:tensorflow:No training configuration found in save file, so the model was *not* compiled. Compile it manually.\n",
      "<keras.regularizers.L2 object at 0x7f52713b3460>\n",
      "Epoch 1/500\n",
      "3186/3186 [==============================] - 20s 5ms/step - loss: 0.4629 - val_loss: 0.2324\n",
      "Epoch 2/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.2384 - val_loss: 0.1545\n",
      "Epoch 3/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1772 - val_loss: 0.1255\n",
      "Epoch 4/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1536 - val_loss: 0.1133\n",
      "Epoch 5/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1448 - val_loss: 0.1042\n",
      "Epoch 6/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1401 - val_loss: 0.0981\n",
      "Epoch 7/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1295 - val_loss: 0.0938\n",
      "Epoch 8/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1210 - val_loss: 0.0906\n",
      "Epoch 9/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1162 - val_loss: 0.0852\n",
      "Epoch 10/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1104 - val_loss: 0.0811\n",
      "Epoch 11/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1066 - val_loss: 0.0774\n",
      "Epoch 12/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1023 - val_loss: 0.0734\n",
      "Epoch 13/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1012 - val_loss: 0.0706\n",
      "Epoch 14/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1059 - val_loss: 0.0679\n",
      "Epoch 15/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1028 - val_loss: 0.0650\n",
      "Epoch 16/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1041 - val_loss: 0.0627\n",
      "Epoch 17/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1055 - val_loss: 0.0612\n",
      "Epoch 18/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1044 - val_loss: 0.0602\n",
      "Epoch 19/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1028 - val_loss: 0.0590\n",
      "Epoch 20/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1003 - val_loss: 0.0587\n",
      "Epoch 21/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1056 - val_loss: 0.0580\n",
      "Epoch 22/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1064 - val_loss: 0.0575\n",
      "Epoch 23/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1000 - val_loss: 0.0571\n",
      "Epoch 24/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1046 - val_loss: 0.0570\n",
      "Epoch 25/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.1012 - val_loss: 0.0570\n",
      "Epoch 26/500\n",
      "3186/3186 [==============================] - 15s 5ms/step - loss: 0.0991 - val_loss: 0.0566\n",
      "Epoch 27/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0968 - val_loss: 0.0565\n",
      "Epoch 28/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0990 - val_loss: 0.0552\n",
      "Epoch 29/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0953 - val_loss: 0.0551\n",
      "Epoch 30/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0918 - val_loss: 0.0580\n",
      "Epoch 31/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0920 - val_loss: 0.0565\n",
      "Epoch 32/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0926 - val_loss: 0.0568\n",
      "Epoch 33/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0912 - val_loss: 0.0582\n",
      "Epoch 34/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0897 - val_loss: 0.0588\n",
      "Epoch 35/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0909 - val_loss: 0.0552\n",
      "Epoch 36/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0917 - val_loss: 0.0563\n",
      "Epoch 37/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0861 - val_loss: 0.0569\n",
      "Epoch 38/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0861 - val_loss: 0.0557\n",
      "Epoch 39/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0866 - val_loss: 0.0537\n",
      "Epoch 40/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0856 - val_loss: 0.0537\n",
      "Epoch 41/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0812 - val_loss: 0.0541\n",
      "Epoch 42/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0819 - val_loss: 0.0523\n",
      "Epoch 43/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0814 - val_loss: 0.0529\n",
      "Epoch 44/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0777 - val_loss: 0.0500\n",
      "Epoch 45/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0776 - val_loss: 0.0494\n",
      "Epoch 46/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0773 - val_loss: 0.0512\n",
      "Epoch 47/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0755 - val_loss: 0.0494\n",
      "Epoch 48/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0753 - val_loss: 0.0452\n",
      "Epoch 49/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0735 - val_loss: 0.0470\n",
      "Epoch 50/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0729 - val_loss: 0.0505\n",
      "Epoch 51/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0713 - val_loss: 0.0451\n",
      "Epoch 52/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0762 - val_loss: 0.0461\n",
      "Epoch 53/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0720 - val_loss: 0.0455\n",
      "Epoch 54/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0732 - val_loss: 0.0444\n",
      "Epoch 55/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0689 - val_loss: 0.0435\n",
      "Epoch 56/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0698 - val_loss: 0.0428\n",
      "Epoch 57/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0687 - val_loss: 0.0441\n",
      "Epoch 58/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0702 - val_loss: 0.0421\n",
      "Epoch 59/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0679 - val_loss: 0.0465\n",
      "Epoch 60/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0693 - val_loss: 0.0419\n",
      "Epoch 61/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0660 - val_loss: 0.0412\n",
      "Epoch 62/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0681 - val_loss: 0.0415\n",
      "Epoch 63/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0661 - val_loss: 0.0401\n",
      "Epoch 64/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0766 - val_loss: 0.0422\n",
      "Epoch 65/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0693 - val_loss: 0.0420\n",
      "Epoch 66/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0716 - val_loss: 0.0407\n",
      "Epoch 67/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0706 - val_loss: 0.0389\n",
      "Epoch 68/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0659 - val_loss: 0.0386\n",
      "Epoch 69/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0654 - val_loss: 0.0412\n",
      "Epoch 70/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0621 - val_loss: 0.0383\n",
      "Epoch 71/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0662 - val_loss: 0.0374\n",
      "Epoch 72/500\n",
      "3186/3186 [==============================] - 15s 5ms/step - loss: 0.0642 - val_loss: 0.0403\n",
      "Epoch 73/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0604 - val_loss: 0.0375\n",
      "Epoch 74/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0653 - val_loss: 0.0378\n",
      "Epoch 75/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0651 - val_loss: 0.0381\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0615 - val_loss: 0.0375\n",
      "Epoch 77/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0590 - val_loss: 0.0396\n",
      "Epoch 78/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0602 - val_loss: 0.0369\n",
      "Epoch 79/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0593 - val_loss: 0.0384\n",
      "Epoch 80/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0605 - val_loss: 0.0371\n",
      "Epoch 81/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0583 - val_loss: 0.0385\n",
      "Epoch 82/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0603 - val_loss: 0.0362\n",
      "Epoch 83/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0585 - val_loss: 0.0373\n",
      "Epoch 84/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0629 - val_loss: 0.0355\n",
      "Epoch 85/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0577 - val_loss: 0.0381\n",
      "Epoch 86/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0596 - val_loss: 0.0404\n",
      "Epoch 87/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0573 - val_loss: 0.0370\n",
      "Epoch 88/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0623 - val_loss: 0.0373\n",
      "Epoch 89/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0605 - val_loss: 0.0374\n",
      "Epoch 90/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0620 - val_loss: 0.0355\n",
      "Epoch 91/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0583 - val_loss: 0.0356\n",
      "Epoch 92/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0566 - val_loss: 0.0373\n",
      "Epoch 93/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0623 - val_loss: 0.0358\n",
      "Epoch 94/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0557 - val_loss: 0.0372\n",
      "Epoch 95/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0592 - val_loss: 0.0365\n",
      "Epoch 96/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0556 - val_loss: 0.0362\n",
      "Epoch 97/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0559 - val_loss: 0.0385\n",
      "Epoch 98/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0548 - val_loss: 0.0359\n",
      "Epoch 99/500\n",
      "3186/3186 [==============================] - 15s 5ms/step - loss: 0.0575 - val_loss: 0.0366\n",
      "Epoch 100/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0555 - val_loss: 0.0350\n",
      "Epoch 101/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0543 - val_loss: 0.0361\n",
      "Epoch 102/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0545 - val_loss: 0.0365\n",
      "Epoch 103/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0534 - val_loss: 0.0370\n",
      "Epoch 104/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0541 - val_loss: 0.0379\n",
      "Epoch 105/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0530 - val_loss: 0.0370\n",
      "Epoch 106/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0526 - val_loss: 0.0358\n",
      "Epoch 107/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0523 - val_loss: 0.0382\n",
      "Epoch 108/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0534 - val_loss: 0.0371\n",
      "Epoch 109/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0520 - val_loss: 0.0365\n",
      "Epoch 110/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0517 - val_loss: 0.0343\n",
      "Epoch 111/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0517 - val_loss: 0.0357\n",
      "Epoch 112/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0513 - val_loss: 0.0349\n",
      "Epoch 113/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0508 - val_loss: 0.0345\n",
      "Epoch 114/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0523 - val_loss: 0.0353\n",
      "Epoch 115/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0503 - val_loss: 0.0349\n",
      "Epoch 116/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0500 - val_loss: 0.0363\n",
      "Epoch 117/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0504 - val_loss: 0.0360\n",
      "Epoch 118/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0507 - val_loss: 0.0392\n",
      "Epoch 119/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0491 - val_loss: 0.0374\n",
      "Epoch 120/500\n",
      "3186/3186 [==============================] - 16s 5ms/step - loss: 0.0503 - val_loss: 0.0363\n",
      "3540/3540 [==============================] - 11s 3ms/step\n",
      "705/705 [==============================] - 2s 3ms/step\n"
     ]
    },
    {
     "data": {
      "image/png": "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u9OnTy+c9/jjj3PddddVSj0fffRRrrnmGgAmTpzIvvvuy0cffVQ4v+CundVl5syZnHnmmQA88cQTXH311dW6fzNz6O+Sgrtfvvbaa9SvX5877rijQusfcsghhTdFKx76AwcOZOzYsZVSz5///OdccsklhdMtWrQo/OKXiooIduzYUSn1AhgwYAB/+MMfKvyGaWa7x6G/m0444QSWL1/OunXrOPvss+natSu9e/dm0aJFAPz5z3+mW7dudOvWje7du7Nx40ZWrFhB586d+eKLL7j66quZOnUq3bp1Y+rUqdx7771897vfZcOGDbRt27YwaDdv3kybNm3Ytm0bb731Fv379+foo4/mhBNOYMmSJTvVa+nSpTRo0KDIl7xcdNFFTJ06lXXr1u20/A033EDnzp3p3LkzN910EwArVqzg8MMPZ/jw4XTu3JlZs2ZxxBFHMHLkSA477DCGDRvGs88+S58+fejQoQOvvPIKAK+88grHHXcc3bt35/jjj+fNN9/caX+S6Nu3L0888cRuPwdmlj+H/m7Yvn07Tz31FF26dGHChAl0796dRYsWce211zJ8+HAg+SrF2267jYULFzJr1qwit2GuX78+11xzDUOGDGHhwoUMGTKkcN7+++9Pt27d+POf/wwkwyH9+vWjXr16jB49mltuuYX58+dz/fXXF+nNF3jhhRfo0aNHkbLGjRtz0UUXcfPNNxcpnz9/Pvfccw8vv/wyc+bM4a677ir8R7Jly5ZxySWXsHjxYtq2bcvy5cu54oorWLJkCUuWLOG3v/0ts2fP5vrrr+faa68F4IgjjmDWrFksWLCAa665psi3f+Xq2bMns2bNqmizm9luqP0f5NaAgm+0gqSnf/HFF3Psscfy8MMPA3DyySezdu1aPv30U/r06cPll1/OsGHDOPfcc2ndunXe+xkyZAhTp07lpJNO4sEHH+SSSy5h06ZNvPjiiwwePLhwua1bt+607vvvv0/Lli13Kv/e975Ht27d+MEPflBYNnv2bM455xz2228/AM4991xmzZrFwIEDadu2bZGbwLVv354uXboA0KlTJ0455RQk0aVLF1asWAEkdw4dMWIEy5YtQ1Kpdwr9yle+wnvvvZd3e5jZ7nPo74KCMf18jB07lgEDBjB9+nT69OnD008/nfe99gcOHMj48eNZt24d8+fP5+STT2bz5s00a9as3P03atRop2/1AmjWrBkXXHABt912W151KHgjKNCgQYPCx/vss0/h9D777MP27dsBuOqqqzjppJN45JFHWLFiBX379i1x21u2bCly5mNmVa/2h/4econlCSecwJQpU7jqqquYOXMmLVq0oGnTprz11lt06dKFLl26MHfuXJYsWVJ4lgDQpEkTNm7cWOI2GzduTK9evRgzZgxnnnkmderUoWnTprRv357f/e53DB48mIhg0aJFHHXUUUXW7dixIw888ECJ27388svp1atXYUifcMIJjBw5krFjxxIRPPLII9x///273BYbNmygVatWANx7772lLrd06VI6d+68y/sxs4rzmH4lmThxIvPnz6dr166MHTuW++67D4CbbrqJzp0707VrV+rVq8cZZ5xRZL2TTjqJ119/vfCD3OKGDBnCAw88UGS8f8qUKUyePJmjjjqKTp068dhjj+203oknnsiCBQso6dbZLVq04JxzzikcFurRowcjR47kmGOO4dhjj2XUqFF07959l9viyiuvZNy4cXTv3r3wjaUkzz//PAMGDNjl/ZhZxfl++nuxMWPGcNZZZ3HqqafWdFV28uGHH3LBBRfw3HPPlTjfz7PtdfaQ++m7p78XGz9+/B57HfzKlSt3+X8GzGzX5RX6ki6TtFjSa5L+V1JDSe0lvSxpuaSpkuqnyzZIp5en89vlbGdcWv6mpF3+9u49+exkT3LQQQcxcODAmq5GiXr16lXks41cfn7Nqk65oS+pFfA9oGdEdAbqAEOBnwE3RsTXgE+Ai9NVLgY+SctvTJdD0pHpep2A/sAvJdWpaIUbNmzI2rVrHQx7qYhg7dq1eV/hZGYVk+/VO3WBRpK2AfsC7wMnAxek8+8DJgK3A4PSxwDTgFslKS1/MCK2Am9LWg4cA7xUkQq3bt2a1atXs2bNmoqsZrVIw4YNK/T/DGaWv3JDPyLelXQ9sBL4HHgGmA+sj4iCSzNWA63Sx62AVem62yVtAJqn5XNyNp27TiFJo4HRAIceeuhO9alXrx7t27fP59jMzKyYfIZ3DiDppbcHDgH2IxmeqRIRcWdE9IyIniX9R6mZme26fD7IPRV4OyLWRMQ24PdAH6CZpIIzhdbAu+njd4E2AOn8/YG1ueUlrGNmZtUgn9BfCfSWtG86Nn8K8DrwPHBeuswIoOA/hB5Pp0nn/ymST10fB4am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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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rNgWZWf4iBMAlriZM2dmvfXWMzZWUKWUrLfeeopfADqFnbHisjEAWFrsiZWLjQFAZ7I7VmyLsjMEGgBUYWys2Pz5AtCZ/D204vJnC8DS4u+clYs/bwA6k7+HVmwL++cr0AAAAAAAAAAAqKxrZ58AACu+r/3ygSX6fCftsUWH7veTn/wk+++/f+67775stdVWSZKJEyfmT3/6U/bee+8kydixY7Pqqqtm5513XqRz6d69e1544YUF3ueoo47K9ddfnw022CD33nvv2z7n2LFj85GPfCSbbbZZXnrppWy44YY55ZRTss8++yzwcffff3+OPfbYPPfcc3n55ZczaNCgfOtb31qo9wMAy5vO2BnLwsZ47LHHcvjhh+fJJ59MKSXHHHNMTjzxxAU+5+sbo1evXnn55Zdz8MEH54wzzujwOY0YMSL77LNPDjrooA4/BgCWByvzzy1mzpyZXXfdNS+//HJeffXVHHTQQfn85z+/wOe89NJL89nPfjYbbbRRXnnllZx00kn553/+57fc77rrrsukSZNy6qmnzve5Ro4cmV133TW77757PvjBD+a8887LwIEDO/4GAWA5szLvjte99tprGThwYDbaaKNcf/31HXru/fbbL3/+859zxx13LNK5LUtcQQOAFdbo0aPzgQ98IKNHj24/NnHixNx4443t348dOza333571fMYMWJEbrrppoV6zKBBgzJhwoTcf//9+cY3vpFPfvKT+dWvfrXAx5xwwgk56aSTMnHixNx333351Kc+tTinDQDMx7KwMbp27Zrzzz8/kyZNyh133JGLLrookyZNetvHDRo0KBMnTszdd9+dK664Iv/7v//7httfffXVWqcMALzJsrApVltttdxyyy353e9+l4kTJ+amm27q0H/4GD58eCZOnJixY8fm9NNPz5NPPvmG21999dUMHTp0gXFGkowaNSq77777Yr0HAODtLQu743Vf//rXs/XWW3f4/s8991zGjx+fGTNm5OGHH654ZkuHQAOAFdILL7yQW2+9Nd/97ndz1VVXJUleeeWVjBw5MmPGjElbW1vOPffcXHzxxfna176Wtra2jBs3Lj/96U+zww47pF+/ftl9993bf8Dwwgsv5Mgjj0yfPn3St2/f/PCHP3zD6z399NPZaaedcsMNN7zlXHbddde8613vWuT30tbWlpEjR+bf//3fkyRTp07NkCFD0rdv3+y222559NFHkyRPPPFEevbs2f64Pn36LPJrAgDztqxsjL/7u79L//79kyRrrbVWtt566zz++OMdfh9rrrlmBgwYkClTpuTMM8/MYYcdll122SWHHXbYfLdGktx8880ZOHBgtthii/Z/5fLaa6/ls5/9bLbbbrv07ds3l1xyycL/xgLASmZZ2RSllHTv3j1JMmvWrMyaNWuhPkd9gw02yPve97488sgjGTFiRD7xiU9khx12yCmnnJJLL700n/zkJzNjxoxssskmmT17dpLkxRdfzMYbb5xZs2ZlxIgRueaaa97yvL/4xS+y0047pX///hk2bFj7v8a98cYbs9VWW2XAgAE54YQT2q82+uKLL+aoo47K9ttvn379+uXaa6/t8HsAgBXdsrI7kmTatGm54YYb8vGPf7zD5/+jH/0o++67bw4++OD280+SKVOmZPfdd8+2226b/v3756GHHkqSnHvuuenTp0+23Xbb9lj0oYceyl577ZUBAwZk0KBBmTx5cpLk6quvTu/evbPttttm1113TZL84Q9/yPbbb5+2trb07ds3Dz74YIfPtSN8xAkAK6Rrr702e+21V7bYYoust956GT9+fAYMGJBRo0bl7rvvbo8d/vrXv6Z79+75zGc+kyR59tlnc8cdd6SUku985zv58pe/nPPPPz9f+MIXss466+T3v/99+/1e9+STT2bo0KE566yzsscee3T4HC+++OIkySc+8Ym3vW///v3zla98JUnyqU99KkcccUSOOOKIfO9738sJJ5yQn/zkJznppJMyZMiQ7LzzzvnQhz6UI488Muuuu26HzwcAeHvL4saYOnVqJkyYkB122CFJxzbGM888kzvuuCOf+9znMmnSpEyaNCm33npr1lhjjey7777z3Bqvv9Zdd92Vhx56KIMHD86UKVPyn//5n1lnnXXy29/+Ni+//HJ22WWXfOhDH0qvXr0W/TcaAFZwy9KmeO2119rDzeOPP759U4wcOTIDBw7M0KFD5/s+Hn744Tz88MN5//vfn2TOf3S5/fbb06VLl1x66aVJknXWWSdtbW35zW9+k8GDB+f666/PnnvumW7dus3zOZ9++umcddZZufnmm7Pmmmvm3HPPzVe/+tWccsopOfbYY/Pf//3f6dWrVw455JD2x5x99tkZMmRIvve97+W5557L9ttvn9133z1rrrlmR/9IAGCFtSztjk9/+tP58pe/nL/85S9vOL6g3TF69OiMHDkyG264YQ488MCcfvrpSZJDDz00p556avbff//MnDkzs2fPzs9+9rNce+21ufPOO/OOd7wj06dPT5Icc8wxufjii7P55pvnzjvvzHHHHZdbbrklo0aNys9//vNstNFGee6555LM+bnKiSeemEMPPTSvvPJKXnvttcX8E3gjgQYAK6TRo0e3fw77wQcfnNGjR2fAgAFv+7hp06Zl+PDheeKJJ/LKK6+0/4eFm2+++Q1l5jvf+c4kc/51yW677ZaLLroo//AP/7BQ59iRMON1TdO0f/0///M/+dGPfpQkOeyww3LKKackSY488sjsueeeuemmm3Lttdfmkksuye9+97usttpqC3VeAMD8LWsb44UXXsiBBx6YCy64IGuvvXaSBW+McePGpV+/fllllVVy6qmnZptttsnVV1+doUOHZo011kgy/62RJB/96EezyiqrZPPNN89mm22WyZMn5xe/+EXuueee9n/9OmPGjDz44IMCDQBYgGVpU3Tp0iUTJ07Mc889l/333z/33ntvevfunVGjRs33PMaMGZNbb701q622Wi655JL2K4cOGzYsXbp0ecv9hw8fnjFjxmTw4MG56qqrctxxx833ue+4445MmjQpu+yyS5I5/8J3p512yuTJk7PZZpu1v+dDDjkk3/rWt5LMueLGddddl/POOy9JMnPmzDz66KMLdfl0AFhRLSu74/rrr88GG2yQAQMGZOzYsW+4bX6748knn8yDDz6YD3zgAymlpFu3brn33nuzySab5PHHH8/++++fJFl99dXbz+3II4/MO97xjiTJu971rrzwwgu5/fbbM2zYsPbnffnll5Mku+yyS0aMGJGPfvSjOeCAA5IkO+20U84+++xMmzYtBxxwQDbffPO3/b1aGAINAFY406dPzy233JLf//73KaXktddeSyml/QoUC/KpT30qJ598coYOHZqxY8fmzDPPXOD9u3btmgEDBuTnP//5QgcaC2PChAkd+qHCe97znhx11FE56qij0rt379x7770dGloAwNtb1jbGrFmzcuCBB+bQQw9t/yHC2xk0aFD7R5PMraP/uvTNlzwvpaRpmlx44YXZc889O/QcALCyW9Y2xevWXXfdDB48ODfddFN69+69wPsOHz68/V/bzm1+m2Lo0KE5/fTTM3369IwfPz5DhgyZ73M3TZM99tgjo0ePfsPxiRMnLvAxP/zhD7Plllsu8LwBYGWzLO2O2267Ldddd11uvPHGzJw5M88//3z+6Z/+KVdcccV8n/MHP/hBnn322fY45Pnnn8/o0aPbP7qkI2bPnp111113nlvi4osvzp133pkbbrghAwYMyPjx4/Oxj30sO+ywQ2644YbsvffeueSSSxa4XRbWKkvsmQBgGXHNNdfksMMOyyOPPJKpU6fmscceS69evTJu3ListdZab7h01pu/nzFjRjbaaKMkyWWXXdZ+fI899shFF13U/v3rl+wqpeR73/teJk+enHPPPbfK+7nnnnvyhS98Iccff3ySZOedd26vU6+88soMGjQoSXLTTTdl1qxZSZI///nPeeaZZ9rfCwCw+JaljdE0TY4++uhsvfXWOfnkk5fo+5zf1kjmfDbr7Nmz89BDD+Xhhx/OlltumT333DPf/OY323fIAw88kBdffHGJnhMArEiWpU3x1FNPtV/O+69//Wt++ctfZquttlqi7zdJunfvnu222y4nnnhi9tlnn3leZeN1O+64Y2677bZMmTIlSfLiiy/mgQceyJZbbpmHH344U6dOTTLnKh6v23PPPXPhhRe2X4F0woQJS/w9AMDyaFnaHV/84hczbdq0TJ06NVdddVWGDBmywDgjmXP1j5tuuilTp07N1KlTM378+Fx11VVZa6210rNnz/aPZH355Zfz0ksvZY899sj3v//9vPTSS0nmBCprr712evXqlauvvjrJnJ+p/O53v0uSPPTQQ9lhhx0yatSo9OjRI4899lgefvjhbLbZZjnhhBPykY98JPfcc0+Hf787whU0AKjupD22WKqvN3r06Pzrv/7rG44deOCBGT16dM4+++x86UtfSltbW0477bTsu+++Oeigg3LttdfmwgsvzJlnnplhw4blne98Z4YMGZI//vGPSZJ/+7d/y/HHH5/evXunS5cuOeOMM9r/pWqXLl0yevToDB06NGuttdZbLtN5yCGHZOzYsXn66afTs2fPfP7zn8/RRx+9wM+Hf/3y4y+99FI22GCDfOMb38huu+2WJLnwwgtz5JFH5itf+Up69OiR73//+0nmXM7zxBNPbL+U11e+8pW8+93vXoK/swCw7FmaO2NZ2hi33XZbLr/88vTp0ydtbW1JknPOOSd77733AjdGR8xvayTJe9/73my//fZ5/vnnc/HFF2f11VfPxz/+8UydOjX9+/dP0zTp0aNH+w9IAGB5sDL/3OKJJ57IEUcckddeey2zZ8/ORz/60eyzzz5JFvxZ8Iti+PDhGTZs2Fsuaf5mPXr0yKWXXppDDjmk/fLjZ511VrbYYov8x3/8R/baa6+sueaa2W677dof87nPfS6f/vSn07dv38yePTu9evWa51XDAKCzrcy7Y0HmtTumTp2aRx55JDvuuGP7sV69emWdddbJnXfemcsvvzzHHntsRo4cmW7duuXqq6/OXnvtlYkTJ2bgwIFZddVVs/fee+ecc87JlVdemX/5l3/JWWedlVmzZuXggw/Otttum89+9rN58MEH0zRNdtttt2y77bY599xzc/nll6dbt25597vfndNPP31x/xjeoMz9mfbLmoEDBzZ33313Z58GAAvpvvvu8xmfK4F5/TmXUsY3TTOwk05podgZAMsnO2PFZ2MAUJs9sfx64YUX0r179zRNk+OPPz6bb755TjrppA491sYAoDPYHSuHhdkZPuIEAAAAAABY5n37299OW1tbttlmm8yYMSPHHntsZ58SAMBC8REnAAAAAADAMu+kk07q8BUzAACWRa6gAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAyrp29gkAsBL49ReX7PMNPm3JPh8AsPyyMwCAxWVPAABLi92x0nMFDQBWSF26dElbW1t69+6dYcOG5aWXXlqox//pT3/KQQcdlCSZOHFibrzxxvbbrrvuunzpS19aIuf5k5/8JKNGjUqSnHnmmXnHO96R//u//2u/vXv37kvkdTpq7Nix2WeffZIk119/fUaOHLlUXx8AlnU2xqKxMQDgjWyKRWNTAMDCszsWTa3dIdAAYIW0xhprZOLEibn33nuz6qqr5uKLL16ox7/nPe/JNddck+Stg2Po0KE59dRTl8h5fvnLX85xxx3X/v3666+f888/f5Geq2mazJ49e4mcV5J8+MMfzk9/+tOFHmsAsCKzMRafjQEANsWSYFMAQMfYHYtvSe4OgQYAK7xBgwZlypQpmT59evbbb7/07ds3O+64Y+65554kyW9+85u0tbWlra0t/fr1y1/+8pdMnTo1vXv3ziuvvJKRI0dmzJgxaWtry5gxY3LppZfmk5/8ZGbMmJFNNtmk/S/5F198MRtvvHFmzZqVhx56KHvttVcGDBiQQYMGZfLkyW85rwceeCCrrbZa1l9//fZjRx11VMaMGZPp06e/5f5f/epX07t37/Tu3TsXXHBBkmTq1KnZcsstc/jhh6d3794ZN25cttpqq4wYMSJbbLFFDj300Nx8883ZZZddsvnmm+euu+5Kktx1113Zaaed0q9fv+y88865//773/J6pZR88IMfzPXXX7/YfwYAsCKyMWwMAFgSbAqbAgCWFruj83eHQAOAFdqrr76an/3sZ+nTp0/OOOOM9OvXL/fcc0/OOeecHH744UmS8847LxdddFEmTpyYcePGZY011mh//KqrrppRo0Zl+PDhmThxYoYPH95+2zrrrJO2trb85je/STLnEld77rlnunXrlmOOOSYXXnhhxo8fn/POO+8N1efrbrvttvTv3/8Nx7p3756jjjoqX//6199wfPz48fn+97+fO++8M3fccUe+/e1vZ8KECUmSBx98MMcdd1z+8Ic/ZJNNNsmUKVPy//7f/8vkyZMzefLk/Nd//VduvfXWnHfeeTnnnHOSJFtttVXGjRuXCRMmZNSoUTn99NPn+fs3cODAjBs3bmF/2wFghWdj2BgAsCTYFDYFACwtdseysTu6LvYzAMAy6K9//Wva2tqSzClCjz766Oywww754Q9/mCQZMmRInnnmmTz//PPZZZddcvLJJ+fQQw/NAQcckJ49e3b4dYYPH54xY8Zk8ODBueqqq3LcccflhRdeyO23355hw4a13+/ll19+y2OfeOKJ9OjR4y3HTzjhhLS1teUzn/lM+7Fbb701+++/f9Zcc80kyQEHHJBx48Zl6NCh2WSTTbLjjju237dXr17p06dPkmSbbbbJbrvtllJK+vTpk6lTpyZJZsyYkSOOOCIPPvhgSimZNWvWPN/fBhtskD/96U8d/v0AgBWdjWFjAMCSYFPYFACwtNgdy9buEGgAsEJ6/TPVOuLUU0/Nhz/84dx4443ZZZdd8vOf/zyrr756hx47dOjQnH766Zk+fXrGjx+fIUOG5MUXX8y66677tq+/xhprZMaMGW85vu666+ZjH/tYLrroog6dw+sj5HWrrbZa+9errLJK+/errLJKXn311STJ5z73uQwePDg//vGPM3Xq1Hzwgx+c53PPnDnzDYUsAKzsbIw5bAwAWDw2xRw2BQDUZ3fMsazsDoEGAPUNPq2zzyDJnDL0yiuvzOc+97mMHTs266+/ftZee+089NBD6dOnT/r06ZPf/va3mTx5cntNmiRrrbVW/vKXv8zzObt3757tttsuJ554YvbZZ5906dIla6+9dnr16pWrr746w4YNS9M0ueeee7Ltttu+4bFbb711rrjiink+78knn5ztttuufSAMGjQoI0aMyKmnnpqmafLjH/84l19++SL/XsyYMSMbbbRRkuTSSy+d7/0eeOCB9O7de5FfBwCqWwZ2ho3xNzYGAMulZWBPJDbF3GwKAFZYdsdKvztWWexnAIDlxJlnnpnx48enb9++OfXUU3PZZZclSS644IL07t07ffv2Tbdu3fKP//iPb3jc4MGDM2nSpLS1tWXMmDFved7hw4fniiuueMPnrV155ZX57ne/m2233TbbbLNNrr322rc8btddd82ECRPSNM1bblt//fWz//77t1/qq3///hkxYkS233777LDDDvn4xz+efv36LfLvxSmnnJLTTjst/fr1ax818/LrX/86H/7whxf5dQBgZWBj/I2NAQCLzqb4G5sCAOqyO/5mae+OMq83uawYOHBgc/fdd3f2aQCwkO67775svfXWnX0ay4UTTzwx++67b3bffffOPpW3ePLJJ/Oxj30sv/rVr+Z5+7z+nEsp45umGbg0zm9x2RkAyyc7o2NsjM5jYwAs++yJjlueN8Wb2RgAdAa7o+OW592xMDvDFTQAoBOdfvrpeemllzr7NObp0Ucfzfnnn9/ZpwEALAIbAwBYEmwKAGBpWVl2R9cl8iwA8CZN06SU0tmnsczbcMMNM3To0M4+jXnabrvt5nvbsnwFLgBWfHbG27MxAGDB7ImOWV43xZvZGAB0JrujY5bX3bGwO8MVNABY4lZfffU888wz/s/vCqppmjzzzDNZffXVO/tUAFgJ2RkrLhsDgKXFnli52BgAdCa7Y8W2KDvDFTQAWOJ69uyZadOm5amnnursU6GS1VdfPT179uzs0wBgJWRnrNhsDACWBnti5WNjANBZ7I4V38LuDIEGAEtct27d0qtXr84+DQBgBWRnAACLy54AAJYWu4M38xEnAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKB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AAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQA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BgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABU1uFAo5TSpZQyoZRyfev7XqWUO0spU0opY0opq7aOr9b6fkrr9k3neo7TWsfvL6XsucTfDQCw3LExAIAabAwAoBY7AwBYVAtzBY0Tk9w31/fnJvla0zTvT/JskqNbx49O8mzr+Nda90sp5e+THJxkmyR7JfmPUkqXxTt9AGAFYGMAADXYGABALXYGALBIOhRolFJ6Jvlwku+0vi9JhiS5pnWXy5Ls1/r6I63v07p9t9b9P5LkqqZpXm6a5o9JpiTZfgm8BwBgOWVjAAA12BgAQC12BgCwODp6BY0LkpySZHbr+/WSPNc0zaut76cl2aj19UZJHkuS1u0zWvdvPz6Px7QrpRxTSrm7lHL3U0891fF3AgAsjy7IUtoYiZ0BACuRC2JjAAB1XBD/vQQAWERvG2iUUvZJ8n9N04xfCueTpmm+1TTNwKZpBvbo0WNpvCQA0AmW9sZI7AwAWBnYGABALf57CQCwuLp24D67JBlaStk7yepJ1k7y9STrllK6tqrPnkkeb93/8SQbJ5lWSumaZJ0kz8x1/HVzPwYAWPnYGABADTYGAFCLnQEALJa3vYJG0zSnNU3Ts2maTZMcnOSWpmkOTfLrJAe17nZEkmtbX1/X+j6t229pmqZpHT+4lLJaKaVXks2T3LXE3gkAsFyxMQCAGmwMAKAWOwMAWFwduYLG/PxrkqtKKWclmZDku63j301yeSllSpLpmTNS0jTNH0opP0gyKcmrSY5vmua1xXh9AGDFZGMAADXYGABALXYGANAhCxVoNE0zNsnY1tcPJ9l+HveZmWTYfB5/dpKzF/YkAYAVm40BANRgYwAAtdgZAMCieNuPOAEAAAAAAAAAYPEINAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKBBgAAAAAAAABAZQINAAAAAAAAAIDKBBoAAAAAAAAAAJUJNAAAAAAAAAAAKhNoAAAAAAAAAABUJtAAAAAAAAAAAKhMoAEAAAAAAAAAUJlAAwAAAAAAAACgMoEGAAAAAAAAAEBlAg0AAAAAAAAAgMoEGgAAAAAAAAAAlQk0AAAAAAAAAAAqE2gAAAAAAAAAAFQm0AAAAAAAAAAAqEygAQAAAAAAAABQmUADAAAAAAAAAKAygQYAAAAAAAAAQGUCDQAAAAAAAACAygQaAAAAAAAAAACVCTQAAAAAAAAAACoTaAAAAAAAAAAAVCbQAAAAAAAAAACoTKABAAAAAAAAAFCZQAMAAAAAAAAAoDKB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\n",
      "text/plain": [
       "<Figure size 2160x1080 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AUPR Train Run 3: 0.9999086769835431\n",
      "AUPR Test Run 3: 0.9505734075361489\n",
      "AUPR Indiv Test Run 3: [0.9594300799132031, 0.7927228603219767, 0.0450889109703806, 0.4993892476034562]\n",
      "AUPR (Train): 0.9999067734992092+-4.544277124660302e-06\n",
      "AUPR (Test): 0.9518050731313613+-0.0016777645486272586\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>0</th>\n",
       "      <th>1</th>\n",
       "      <th>2</th>\n",
       "      <th>AUPR Mean</th>\n",
       "      <th>AUPR Std</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.958588</td>\n",
       "      <td>0.962844</td>\n",
       "      <td>0.959430</td>\n",
       "      <td>0.960287</td>\n",
       "      <td>0.002254</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.792299</td>\n",
       "      <td>0.800028</td>\n",
       "      <td>0.792723</td>\n",
       "      <td>0.795017</td>\n",
       "      <td>0.004345</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.047428</td>\n",
       "      <td>0.049394</td>\n",
       "      <td>0.045089</td>\n",
       "      <td>0.047304</td>\n",
       "      <td>0.002155</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.516354</td>\n",
       "      <td>0.511015</td>\n",
       "      <td>0.499389</td>\n",
       "      <td>0.508919</td>\n",
       "      <td>0.008674</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          0         1         2  AUPR Mean  AUPR Std\n",
       "1  0.958588  0.962844  0.959430   0.960287  0.002254\n",
       "2  0.792299  0.800028  0.792723   0.795017  0.004345\n",
       "3  0.047428  0.049394  0.045089   0.047304  0.002155\n",
       "4  0.516354  0.511015  0.499389   0.508919  0.008674"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "([0.9999111376052738, 0.9999005059088106, 0.9999086769835431],\n",
       " [0.9506646056365564, 0.9541772062213786, 0.9505734075361489],\n",
       " {0: [0.9585875435609656,\n",
       "   0.7922989090130894,\n",
       "   0.047428154430499275,\n",
       "   0.5163538884515257],\n",
       "  1: [0.9628440726570023,\n",
       "   0.8000284382509387,\n",
       "   0.04939449820619783,\n",
       "   0.5110148502249012],\n",
       "  2: [0.9594300799132031,\n",
       "   0.7927228603219767,\n",
       "   0.0450889109703806,\n",
       "   0.4993892476034562]})"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Deep SAD\n",
    "verbose = 1      # can change this to 0 to suppress verbosity during training\n",
    "plot = False\n",
    "shuffle = False\n",
    "val_split = 0.1\n",
    "repeats = 3\n",
    "epochs = 500\n",
    "batchnorm = True\n",
    "\n",
    "train = False\n",
    "lr = 3e-4\n",
    "\n",
    "early_stopping = tf.keras.callbacks.EarlyStopping(patience=10, monitor='val_loss',\n",
    "                                                  restore_best_weights=True)\n",
    "callbacks = [early_stopping]\n",
    "\n",
    "# y for normal is 1 and for abnormal is -1\n",
    "y_DSAD = 2 * y - 1\n",
    "\n",
    "auprs_train = []\n",
    "auprs_test = []\n",
    "aupr_attacks = dict()\n",
    "\n",
    "models_deep_sad = []\n",
    "\n",
    "# Train and Evaluate the Model\n",
    "for i in range(repeats):\n",
    "    \n",
    "    with strategy.scope():\n",
    "        # Create the model\n",
    "        tf.keras.utils.set_random_seed(i)\n",
    "        \n",
    "        encoder_path = \"models/KDD99/Encoder_Bump_90_60\"\n",
    "        \n",
    "        deep_sad = tf.keras.models.load_model(encoder_path)\n",
    "        \n",
    "        if i == 0:\n",
    "            \n",
    "            train_mean = tf.cast(tf.math.reduce_mean(deep_sad.predict(X), axis=0), tf.float32)\n",
    "\n",
    "        regulariser = tf.keras.regularizers.L2(l2=1e-1)\n",
    "\n",
    "        for layer in deep_sad.layers:\n",
    "            if hasattr(layer, 'kernel_regularizer'):\n",
    "                setattr(layer, 'kernel_regularizer', regulariser)\n",
    "                \n",
    "        def deep_sad_loss(y_true, y_pred):\n",
    "\n",
    "    #         y_pred - train_mean\n",
    "    #         tf.norm(y_pred - train_mean, axis=1)\n",
    "\n",
    "            return tf.math.pow(y_pred, y_true)\n",
    "                \n",
    "        \n",
    "        model = SAD(deep_sad, SAD_Dist(train_mean))\n",
    "\n",
    "        model.compile(loss=deep_sad_loss, optimizer=tf.keras.optimizers.Adam(learning_rate=lr))\n",
    "\n",
    "        for module in model.layers:\n",
    "            if hasattr(module, 'layers'):\n",
    "                for layer in module.layers:\n",
    "                    if hasattr(layer, 'kernel_regularizer'):\n",
    "                        print(layer.kernel_regularizer)\n",
    "\n",
    "        \n",
    "        if i == 0:\n",
    "            model.build((None, num_inputs))\n",
    "            model.summary()\n",
    "\n",
    "        # Train the model\n",
    "        aupr_train, aupr_test, aupr_attack = train_eval(model, X, y_DSAD.astype(np.float32), x_test, y_test,\n",
    "                                                        y_true_train=y.astype(np.float32),\n",
    "                                                        epochs=epochs,\n",
    "                   train=train, verbose=verbose, shuffle=shuffle, plot=plot,\n",
    "                   val_split=val_split, callbacks=callbacks, seed=i, indiv=new_attacks)\n",
    "    \n",
    "    models_deep_sad.append(model)\n",
    "    \n",
    "    print(f\"AUPR Train Run {i+1}: {aupr_train}\")\n",
    "    print(f\"AUPR Test Run {i+1}: {aupr_test}\")\n",
    "    print(f\"AUPR Indiv Test Run {i+1}: {aupr_attack}\")\n",
    "    auprs_train.append(aupr_train)\n",
    "    auprs_test.append(aupr_test)\n",
    "    aupr_attacks[i] = aupr_attack\n",
    "    \n",
    "print(f\"AUPR (Train): {np.mean(auprs_train)}+-{np.std(auprs_train)}\")\n",
    "print(f\"AUPR (Test): {np.mean(auprs_test)}+-{np.std(auprs_test)}\")\n",
    "\n",
    "results_df = pd.DataFrame(data=aupr_attacks, index=new_attacks)\n",
    "results_df['AUPR Mean'] = results_df.mean(axis=1)\n",
    "results_df['AUPR Std'] = results_df.iloc[:, :-1].std(axis=1)\n",
    "display(results_df)\n",
    "# print(f\"Average Distance between Means: {np.mean(diff_means)}+-{np.std(diff_means)}\")\n",
    "auprs_train, auprs_test, aupr_attacks"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}