{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "7750490f",
   "metadata": {},
   "source": [
    "# Predicting cause of death from PHMRC VA text narratives using classic NLP methods. \n",
    "## Naive Bayes, SVM, K Nearest Neighbor, rebalancing with SMOTE+ENN and reweighting\n",
    "References: <br>\n",
    "zhou 2023 circumstances preceding female firearm suicide https://mental.jmir.org/2023/1/e49359/ <br>\n",
    "https://medium.com/@bedigunjit/simple-guide-to-text-classification-nlp-using-svm-and-naive-bayes-with-python-421db3a72d34 <br>\n",
    "https://scikit-learn.org/stable/tutorial/text_analytics/working_with_text_data.html"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "id": "c4c1ae99",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import random \n",
    "import matplotlib.pyplot as plt\n",
    "import tensorflow as tf\n",
    "import imblearn\n",
    "import statsmodels.api as sm\n",
    "from tqdm.auto import tqdm\n",
    "from transformers import BertTokenizer\n",
    "from nltk.tokenize import word_tokenize\n",
    "from nltk import pos_tag\n",
    "from nltk.corpus import stopwords\n",
    "from nltk.corpus import wordnet as wn\n",
    "from nltk.stem import WordNetLemmatizer, SnowballStemmer\n",
    "from sklearn.preprocessing import LabelEncoder, OneHotEncoder\n",
    "from sklearn.feature_extraction.text import TfidfVectorizer\n",
    "from sklearn import model_selection, naive_bayes, svm\n",
    "from sklearn.metrics import accuracy_score, f1_score\n",
    "from sklearn.neighbors import KNeighborsClassifier\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from collections import defaultdict, Counter\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f3c0f460",
   "metadata": {},
   "source": [
    "## Load data as Trinity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 192,
   "id": "2d50477d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# covariates with just age\n",
    "Test_X_covariates = pd.read_csv('covariates.csv')\n",
    "Test_X_covariates = Test_X_covariates['age_yr']\n",
    "\n",
    "# # covariates with age and education\n",
    "# Test_X_covariates = pd.read_csv('covariates.csv')\n",
    "\n",
    "# predictions from 3 NLP classifiers plus the true labels (Test_Y)\n",
    "predictions_df = pd.read_csv('predictions.csv')\n",
    "\n",
    "Test_Y = predictions_df['Test_Y']\n",
    "predictions_NB = predictions_df['predictions_NB']\n",
    "predictions_SVM = predictions_df['predictions_SVM']\n",
    "predictions_KNN = predictions_df['predictions_KNN']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 193,
   "id": "f932af5e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAj4AAAGxCAYAAABiPLw8AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAAAuNElEQVR4nO3deVSV5f7//9dGYYMDO3FCFBEzM0XJWdRMzYkcGyz9eMqGj01mmU2SGVoa2inLjjmlRxtO6SnT7HS0PKWYiX3EE85WJiqVU4OgoKh4/f7oy/5FgMJ2wwau52Otey3v+77uvd9cXmvt17ruyWGMMQIAALCAn68LAAAAKC0EHwAAYA2CDwAAsAbBBwAAWIPgAwAArEHwAQAA1iD4AAAAaxB8AACANQg+AADAGgQfoAJavHixHA6HAgMDdeDAgXz7u3fvrqioqDzbGjVqJIfD4V4CAwPVpEkTjRs3Tj///PNFv3PdunV5jq9UqZLq1q2roUOHavfu3V772y6ke/fu6t69u3t9//79cjgcWrx4cbE+Z9euXZo0aZL279+fb98dd9yhRo0aXVKdAHyH4ANUYNnZ2Xr66aeL3L5Lly5KSkpSUlKSVq1apXvvvVfz5s1Tv379ivwZzz//vJKSkrR27Vo9+eSTWrNmjbp06aIff/zRkz/hktSrV09JSUnq379/sY7btWuXJk+eXGDwmThxopYvX+6lCgGUtsq+LgBAyenXr5/eeecdPfbYY4qOjr5o+8suu0ydOnVyr/fo0UMnTpzQc889p2+//VZNmza96GdcccUV7s/o1q2bLrvsMt19991avHixJkyYUOAxWVlZqlKlShH/qqJzOp15/h5vuPzyy736eQBKFzM+QAX2xBNPqGbNmnryySc9/gyXyyVJ8vf39+j43OCRe8pt0qRJcjgc+u9//6ubb75ZNWrUcIcJY4xmz56tq6++WkFBQapRo4Zuvvlm7du3L89nGmP0wgsvKCIiQoGBgWrTpo1WrVqV77sLO9W1Z88eDR8+XHXr1pXT6VTDhg11++23Kzs7W4sXL9bQoUMl/R78ck/d5X5GQae6Tp8+rbi4OEVGRiogIED169fX6NGjdfz48TztGjVqpAEDBmj16tVq06aNgoKC1KxZM/3973/P0y4rK0uPPfaYIiMjFRgYqJCQELVr107vvvtukfsdQMGY8QEqsOrVq+vpp5/Www8/rM8//1w9e/a8YHtjjM6dOyfp9x/zzZs365VXXlGXLl0UGRnpUQ179+6VJNWuXTvP9htvvFHDhg3Tfffdp8zMTEnSvffeq8WLF+uhhx7S9OnT9euvv+rZZ59V586dtXXrVtWtW1eSNHnyZE2ePFl33323br75ZqWlpWnUqFHKycnRlVdeecF6tm7dqq5du6pWrVp69tlndcUVV+jQoUNauXKlzpw5o/79++v555/XU089pddee01t2rSRVPhMjzFGQ4YM0Weffaa4uDhdc8012rZtm+Lj492nDZ1OZ57vf/TRRzV+/HjVrVtXCxYs0N13360mTZqoW7dukqRx48bprbfe0pQpU9S6dWtlZmZqx44d+uWXXzz4HwCQhwFQ4SxatMhIMps3bzbZ2dmmcePGpl27dub8+fPGGGOuvfZa06JFizzHREREGEn5lg4dOphDhw5d9DvXrl1rJJmlS5eas2fPmqysLLN+/XrTpEkTU6lSJbN161ZjjDHx8fFGknnmmWfyHJ+UlGQkmZdeeinP9rS0NBMUFGSeeOIJY4wxv/32mwkMDDQ33HBDnnZffvmlkWSuvfZa97bU1FQjySxatMi9rWfPnuayyy4zR48eLfRvee+994wks3bt2nz7Ro4caSIiItzrq1evNpLMCy+8kKfd0qVLjSQzf/5897aIiAgTGBhoDhw44N526tQpExISYu699173tqioKDNkyJBC6wPgOU51ARVcQECApkyZouTkZP3zn/+8YNuuXbtq8+bN2rx5s7788kstXLhQx44dU8+ePYt0Z5ck3XrrrfL391eVKlXUrVs35eTk6P3331erVq3ytLvpppvyrP/rX/+Sw+HQX/7yF507d869hIaGKjo6WuvWrZMkJSUl6fTp0xoxYkSe4zt37qyIiIgL1paVlaXExETdcsst+WagPPX5559L+v0U2B8NHTpUVatW1WeffZZn+9VXX62GDRu61wMDA9W0adM8d9916NBBq1at0vjx47Vu3TqdOnXKK7UC4FQXYIVhw4bpxRdf1IQJE3TjjTcW2s7lcqldu3bu9c6dO6t58+aKiYnRSy+9pISEhIt+1/Tp09WzZ09VqlRJtWrVUnh4eIHt6tWrl2f9yJEjMsa4T2f9WePGjSXJfbonNDQ0X5uCtv3Rb7/9ppycHDVo0OCif0dR/fLLL6pc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vHlz7d+/vyS/AgAAoMhKNPjwMEMAAFCWcA4KAABYg+ADAACsQfABAADWKNHgw63vAACgLOHiZgAAYA2vBJ+MjAytWLFCu3fvzrN9165dioiI8MZXAAAAXDKPgs8tt9yiWbNmSZJOnTqldu3a6ZZbblGrVq20bNkyd7vw8PALvtoCAACgNHkUfNavX69rrrlGkrR8+XIZY3T8+HG9+uqrmjJlilcLBAAA8BaPgk96erpCQkIkSatXr9ZNN92kKlWqqH///vruu++8WiAAAIC3eBR8wsPDlZSUpMzMTK1evVp9+vSRJP32228KDAz0aoEAAADeUqyXlOYaO3asRowYoWrVqikiIkLdu3eX9PspsJYtW3qzPgAAAK/xKPg88MAD6tChg9LS0tS7d2/329cbN27MNT4AAKDMcpgK/rCdjIwMuVwupaenKzg42NflAACAIiip32+PZnxycnK0ePFiffbZZzp69KjOnz+fZ//nn3/uleK8KSr+E/k5qxS5/f5p/UuwGgAA4AseBZ+HH35YixcvVv/+/RUVFcWrKQAAQLngUfBZsmSJ/vnPf+r666/3dj0AAAAlxqPb2QMCAtSkSRNv1wIAAFCiPAo+jz76qGbOnMlLSAEAQLni0amuDRs2aO3atVq1apVatGghf3//PPs/+OADrxQHAADgTR4Fn8suu0w33HCDt2sBAAAoUR4Fn0WLFnm7DgAAgBLnUfDJdezYMX3zzTdyOBxq2rSpateu7a26AAAAvM6ji5szMzN11113qV69eurWrZuuueYahYWF6e6771ZWVpa3awQAAPAKj4LPuHHjlJiYqI8++kjHjx/X8ePH9eGHHyoxMVGPPvqoVws8d+6cnn76aUVGRiooKEiNGzfWs88+m+9p0QAAABfj0amuZcuW6f3333e/lV2Srr/+egUFBemWW27RnDlzvFWfpk+frrlz5+qNN95QixYtlJycrDvvvFMul0sPP/yw174HAABUfB4Fn6ysLNWtWzff9jp16nj9VFdSUpIGDx6s/v1/f3dWo0aN9O677yo5ObnA9tnZ2crOznavZ2RkeLUeAABQfnl0qismJkbx8fE6ffq0e9upU6c0efJkxcTEeK04Seratas+++wzffvtt5KkrVu3asOGDYW+LiMhIUEul8u9hIeHe7UeAABQfnk04zNz5kz169dPDRo0UHR0tBwO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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "pd.Series(predictions_NB).value_counts().plot.barh(title='NB Predictions').invert_yaxis()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 194,
   "id": "4e4ae415",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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9cknn2j37t2aN29ejlmom5k6dapWr16tuLg4Va1aVZcuXXLeadauXbsCHQvwNYQZwKRee+01ffXVV/rggw+UkZEhh8OhypUrq127dkpISFCdOnVyvCYmJkYxMTHavn37LX9XTHGpW7eutm3bprfeekuvvfaaTpw4oTvuuEN333238xST9Pu1MSkpKRo6dKheeOEFBQUFqXv37po8ebK6det20/eZNWuW7rvvPs2YMUOzZs1SYGCg6tatq1deecU5ZuzYscrIyNBf//pXnTt3TpGRkc5bt/+sdevWWr16tcaMGaO+ffsqOztb0dHRWrJkiR566KEC/xzuvfderVy5UmPGjNHx48dVpkwZRUVFacmSJerQoUOBjwf4Er4BGAAAmBrXzAAAAFMjzAAAAFMjzAAAAFMjzAAAAFMjzAAAAFMjzAAAAFPz+e+Zyc7O1rFjxxQcHFzgL6kCAACeYRiGzp07p/DwcPn53XjuxefDzLFjxxQREeHpMgAAQCGkp6erSpUqNxzj82EmODhY0u8/jJCQEA9XAwAA8sNutysiIsL5OX4jPh9mrp9aCgkJIcwAAGAy+blEhAuAAQCAqRFmAACAqfn8aabrosaskJ81yNNlAADgUw6Pi/N0CczMAAAAc/NomFm7dq26dOmi8PBwWSwWLV68OMeYffv2qWvXrrLZbAoODlbTpk115MiR4i8WAAB4JY+GmaysLEVHR2vy5Mm57v/xxx/VsmVL1a5dW8nJydqxY4def/11lSpVqpgrBQAA3sqj18zExsYqNjY2z/2vvvqqOnfurPHjxzu31ahRozhKAwAAJuG118xkZ2frm2++Ua1atdSxY0eFhoaqSZMmuZ6K+iOHwyG73e6yAAAA3+W1YebEiRM6f/68xo0bp06dOmnlypXq3r27evTooZSUlDxfl5iYKJvN5lx4lAEAAL7Na8NMdna2JKlbt24aPny47r33Xo0ePVoPPfSQpk6dmufrEhISlJmZ6VzS09OLq2QAAOABXvs9MxUqVJC/v7/q1q3rsr1OnTpav359nq+zWq2yWq1FXR4AAPASXjszU7JkSTVu3Fj79+932X7gwAFFRkZ6qCoAAOBtPDozc/78eR06dMi5npaWptTUVJUrV05Vq1bVyJEj9cQTT+j+++9X27ZttXz5ci1dulTJycmeKxoAAHgVj4aZLVu2qG3bts71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Pfvsszc8BXSrTp8+rfT0dFWuXLnI3gMAAJhLgcLMm2++qZ07dzrXd+3apQEDBqhdu3YaPXq0li5dqsTExHwf7/z580pNTVVqaqokKS0tTampqTpy5IjOnz+vl19+WRs2bNDhw4eVnJysLl26qEKFCurevXtBygYAAD6sQGEmNTVVDz74oHN9/vz5atKkiaZPn64RI0boo48+0r/+9a98H2/Lli2KiYlRTEyMJGnEiBGKiYnRG2+8oRIlSmjXrl3q1q2batWqpfj4eNWqVUsbNmxQcHBwQcoGAAA+rEDXzJw5c0aVKlVyrqekpKhTp07O9caNGys9PT3fx2vTpo1udP3xihUrClLeDe0e2/GmFxABAADzKdDMTKVKlZSWliZJunz5srZt26ZmzZo59587d86jFwgDAIDbT4HCTKdOnTR69GitW7dOCQkJCgoKUqtWrZz7d+7cqZo1a7q9SAAAgLwU6DTT22+/rR49eqh169YqU6aMZs+erZIlSzr3z5w5Ux06dHB7kQAAAHkp0JfmXZeZmakyZcqoRIkSLtt/++03lSlTxhlwjh49qvDwcPn53dLzLG9JQb50BwAAeIeCfH4XKmXYbLYcQUaSypUr5zJTU7duXR0+fLgwbwEAAJAvRTplUohJHwAAgALx3PkfAAAANyDMAAAAUyPMAAAAUyvSMGOxWIry8AAAAAX7npmC8qYLgKPGrJCfNcjTZdzQ4XFxni4BAADTccvMjN1u1+LFi7Vv3z6X7Xv37lVkZKQ73gIAACBXhQozjz/+uCZPnixJunjxoho1aqTHH39cDRo00JdffukcFxERkev30RREtWrVZLFYciwDBw68peMCAADfUKgws3btWuczmRYtWiTDMHT27Fl99NFHevvtt91a4ObNm5WRkeFcVq1aJUl67LHH3Po+AADAnAoVZjIzM1WuXDlJ0vLly/XII48oKChIcXFxOnjwoFsLrFixosLCwpzL119/rZo1a6p169ZufR8AAGBOhQozERER2rBhg7KysrR8+XLnwyXPnDmjUqVKubXAP7p8+bLmzJmj/v3753mnlMPhkN1ud1kAAIDvKlSYGTZsmHr37q0qVaooPDxcbdq0kfT76af69eu7sz4Xixcv1tmzZ9W3b988xyQmJspmszmXiIiIIqsHAAB4XqGemi1JW7ZsUXp6utq3b68yZcpIkr75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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "pd.Series(predictions_SVM).value_counts().plot.barh(title='SVM Predictions').invert_yaxis()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 195,
   "id": "c9c9e33e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjMAAAGxCAYAAACXwjeMAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABC30lEQVR4nO3de1RVdf7/8dfBywENTqFyK0BK05QkU/OaSl4ZsizHGivD7J5lRlNKZcJMCjWNZeNoWeali1ZTojOmZJNAftVGNMpbXkZMakS8niNox4T9+6Pl+XUCFI4HzsXnY629VvuzP3vv14em73l/P/tmMgzDEAAAgI8K8HQAAACA80ExAwAAfBrFDAAA8GkUMwAAwKdRzAAAAJ9GMQMAAHwaxQwAAPBpFDMAAMCnUcwAAACfRjED+LD58+fLZDKpoKDAqf3QoUPq2rWrLrroIq1atUqSlJ6eLpPJpLCwMB0/frzKsVq3bq0bb7zRqc1kMslkMikrK6vW5/6t3Nxcx3FMJpMaNWqk8PBwjRw5Utu3b6/rkF3Sv39/9e/f37G+d+9emUwmzZ8/v07H2bZtm9LT07V3794q28aMGaPWrVufV04ArqGYAfzMDz/8oOuvv1579uzR559/rkGDBjltP3jwoF566aU6HTMrK0tHjhw5r1zTpk3TunXrtHr1ak2cOFGrVq1S79699eOPP57XcV0RGRmpdevWKTk5uU77bdu2TRkZGdUWM5MnT9aSJUvclBBAXVDMAH5k165d6t27t6xWq/Ly8tSjR48qfYYOHapXXnlFJSUltTrmwIEDVV5erqlTp55XtrZt26pHjx7q27evUlNTNX36dB09evSssyMnTpw4r3PWxGw2q0ePHmrVqpXbjnnFFVeoc+fObjsegNqjmAH8RGFhofr06aPGjRtrzZo1uvrqq6vt98ILL+j06dNKT0+v1XHbtWune++9V3//+9/1/fffuy3vmULrzDHPXAbbtGmTfv/73+uSSy7RFVdcIUkyDEOzZs3SNddco6CgIF1yySX6/e9/rz179jgd0zAMvfTSS4qNjVVgYKCuvfZarVixosq5a7rM9N1332nUqFEKDw+X2WxWTEyM7r77btntds2fP18jR46UJCUmJjoum505RnWXmX766SelpaUpLi5OTZs21aWXXqpx48bp2LFjTv3OXOJbuXKlrr32WgUFBal9+/Z6++23nfqdOHFCf/zjHxUXF6fAwECFhoaqa9euWrRoUa3/7oA/opgB/MCaNWvUv39/hYWFac2aNbr88str7BsbG6tHHnlEc+fO1c6dO2t1/PT0dDVq1EiTJ092V2Tt3r1bkqrMjtx6661q06aNPvroI73++uuSpAcffFATJkzQwIEDlZ2drVmzZmnr1q3q1auXDhw44Ng3IyNDEydO1KBBg5Sdna2HH35Y999/v3bs2HHOPN988426deum9evX609/+pNWrFihzMxM2e12nTp1SsnJyZo2bZok6e9//7vWrVt31ktVhmFo+PDhevnllzV69GgtX75cqampWrBggW644QbZ7fYq53/yySf1xBNPaOnSperUqZPuvfde5efnO/qkpqZq9uzZGj9+vFauXKl33nlHI0eO1OHDh2vxFwf8mAHAZ82bN8+QZEgyLBaLUVpaWmPfKVOmGJKMgwcPGocOHTIsFosxYsQIx/bY2FgjOTnZaR9Jxrhx4wzDMIxnn33WCAgIML755hunc2/YsOGsGVevXm1IMj744APj559/Nk6cOGHk5+cbbdq0MRo1auQ43pl8zz//vNP+69atMyQZf/3rX53ai4uLjaCgIOPpp582DMMwjh49agQGBhq33HKLU7//+7//MyQZ/fr1c7QVFRUZkox58+Y52m644Qbj4osvPuvf8KOPPjIkGatXr66yLSUlxYiNjXWsr1y50pBkvPTSS079PvjgA0OSMWfOHEdbbGysERgYaHz//feOtpMnTxqhoaHGgw8+6GiLj483hg8fXmM+4ELFzAzgB2666SZZrVZNmDBBFRUV5+zfokULTZw4UR9//LG++uqrWp3j6aefVmhoqCZOnOhSxttvv11NmjRRs2bN1LdvX1VUVOgf//iHOnXq5NRvxIgRTuv/+te/ZDKZdNddd+n06dOOJSIiQgkJCcrNzZUkrVu3Tj/99JPuvPNOp/179eql2NjYs2Y7ceKE8vLydNttt7ntPpovvvhC0i+Xn35t5MiRat68uf797387tV9zzTWKiYlxrAcGBurKK690urR33XXXacWKFZo0aZJyc3N18uRJt2QFfB3FDOAHJk+erOeff17vv/++7rrrrloVNBMmTFBUVJSefvrpWp0jJCREzz33nFauXKnVq1fXOeOLL76oDRs2aNOmTdq3b5/27Nmj4cOHV+kXGRnptH7gwAEZhqHw8HA1adLEaVm/fr0OHTokSY5LLREREVWOWV3brx09elQVFRW67LLL6jyumhw+fFiNGzeuUhyZTCZFRERUuTTUokWLKscwm81OBctrr72miRMnKjs7W4mJiQoNDdXw4cO1a9cut+UGfFFjTwcA4B4ZGRkymUzKyMhQZWWl3nvvPTVuXPN/4kFBQUpPT9cDDzyg5cuX1+ocDz/8sGbMmKGJEyfq4YcfrlO+yy+/XF27dj1nP5PJ5LTesmVLmUwmffnllzKbzVX6n2k7UwxU95RWSUnJWd8BExoaqkaNGumHH344Z77aatGihU6fPq2DBw86FTSGYaikpETdunWr8zGbN2+ujIwMZWRk6MCBA45ZmmHDhum7775zW3bA1zAzA/iR9PR0ZWRk6MMPP9Qdd9yh06dPn7X/2LFjddVVV2nSpEmqrKw85/GbNm2qF154QRs2bNBHH33krthndeONN8owDP3444/q2rVrleXMU1s9evRQYGCg3nvvPaf9165de86nsIKCgtSvXz999NFHjpme6pwpnGpzeWfAgAGSpHfffdep/eOPP1Z5eblju6vCw8M1ZswYjRo1Sjt27Ki3x9gBX8DMDOBnnn/+eQUEBGjy5MkyDEOLFi2qcYamUaNGmjZtmm655RZJqnL/SnVGjRqll19+udpHnutD79699cADD+iee+5RQUGB+vbtq+bNm2v//v2OR9AffvhhXXLJJfrjH/+oF154Qffdd59Gjhyp4uJipaenn/MykyRNnz5dffr0Uffu3TVp0iS1adNGBw4c0LJly/TGG28oODhY8fHxkqQ5c+YoODhYgYGBiouLq/YS0aBBgzRkyBBNnDhRNptNvXv31rfffqspU6aoc+fOGj16dJ3/Ft27d9eNN96oTp066ZJLLtH27dv1zjvvqGfPnmrWrFmdjwf4C4oZwA8999xzCggI0LPPPqvKykotXry4xr7Dhw9Xr169tHbt2lod22Qy6cUXX9TgwYPdFfec3njjDfXo0UNvvPGGZs2apcrKSkVFRal379667rrrHP3+9Kc/qXnz5po1a5beeecdtW/fXq+//rpefvnlc54jISFB//nPfzRlyhSlpaXp+PHjioiI0A033KCmTZtKkuLi4vTqq69qxowZ6t+/vyoqKjRv3rwqN/lKv/ydsrOzlZ6ernnz5mnq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1w4PD9c777zjyiFr9MMPP2jUqFE6dOiQWrVqpR49emj9+vW1KmQAAID/c2lmRpLKy8v13nvv6ZtvvlFQUJA6deqkUaNGqUmTJu7OeF6YmQEAwPfU+8yM9MuNuA888ICruwMAALhFrYuZZcuWKSkpSU2aNNGyZcvO2vemm24672AAAAC1UevLTAEBASopKVFYWJgCAmp+CMpkMvHVbAAAcF7q5TJTZWVltf8MAADgSS69ZwYAAMBb1Hpm5rXXXqv1QcePH+9SGAAAgLqq9T0zcXFxTusHDx7UiRMndPHFF0v65aV5zZo1U1hYmPbs2eP2oK46c80tesKHCjA383Qch71ZyZ6OAACA16rLPTO1vsxUVFTkWKZOnaprrrlG27dv15EjR3TkyBFt375d1157rf785z/XOmh+fr6GDRumqKgomUwmZWdnO20/cOCAxowZo6ioKDVr1kxDhw6t8ZtMAADgwuTSPTOTJ0/W3/72N7Vr187R1q5dO73yyit67rnnan2c8vJyJSQkaObMmVW2GYah4cOHa8+ePVq6dKm+/vprxcbGauDAgSovL3clNgAA8EMuvTRv//79+vnnn6u0V1RUVPsBypokJSUpKSmp2m27du3S+vXrtWXLFnXs2FGSNGvWLIWFhWnRokW67777XIkOAAD8jEszMwMGDND999+vgoICnbnlpqCgQA8++KAGDhzolmB2u12SFBgY6Ghr1KiRmjZtqjVr1px1P5vN5rQAAAD/5VIx8/bbb+vSSy/Vddddp8DAQJnNZnXv3l2RkZF666233BKsffv2io2NVVpamo4ePapTp04pKytLJSUl2r9/f437ZWZmymKxOJbo6Gi35AEAAN7JpctMrVq10qeffqqdO3fqu+++k2EYuuqqq3TllVe6LViTJk308ccf695771VoaKgaNWqkgQMH1nhZ6oy0tDSlpqY61m02GwUNAAB+zOUPTUpS69atZRiGrrjiCjVufF6HqlaXLl1UWFgoq9WqU6dOqVWrVurevbu6du1a4z5ms1lms9ntWQAAgHdy6TLTiRMndO+996pZs2bq2LGj9u3bJ+mXl+VlZWW5NaAkWSwWtWrVSrt27VJBQYFuvvlmt58DAAD4JpemU9LS0vTNN98oNzdXQ4cOdbQPHDhQU6ZM0aRJk2p1nLKyMu3evduxXlRUpMLCQoWGhiomJkYf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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "pd.Series(predictions_KNN).value_counts().plot.barh(title='KNN Predictions').invert_yaxis()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "40316baa",
   "metadata": {},
   "source": [
    "## sklearn for Multinomial Logistic Regression "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 196,
   "id": "7fe03dd5",
   "metadata": {},
   "outputs": [],
   "source": [
    "# # using sklearn for the multinomial logistic regression\n",
    "# model = LogisticRegression(multi_class='multinomial', solver='lbfgs')\n",
    "\n",
    "# NB_baseline = model.fit(np.array(list(Test_X_covariates)).reshape(-1,1), predictions_NB)\n",
    "# SVM_baseline = model.fit(np.array(list(Test_X_covariates)).reshape(-1,1), predictions_SVM)\n",
    "# KNN_baseline = model.fit(np.array(list(Test_X_covariates)).reshape(-1,1), predictions_KNN)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a328d4db",
   "metadata": {},
   "source": [
    "## statsmodels.api for the multinomial linear regression\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 197,
   "id": "0ba33037",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "         Current function value: 0.538097\n",
      "         Iterations: 35\n",
      "         Function evaluations: 38\n",
      "         Gradient evaluations: 38\n",
      "         Current function value: 1.968707\n",
      "         Iterations: 35\n",
      "         Function evaluations: 38\n",
      "         Gradient evaluations: 38\n",
      "         Current function value: 2.477432\n",
      "         Iterations: 35\n",
      "         Function evaluations: 38\n",
      "         Gradient evaluations: 38\n"
     ]
    }
   ],
   "source": [
    "# Add a constant term to the features for the intercept\n",
    "Test_X_covariates_constant = sm.add_constant(np.array(Test_X_covariates).reshape(-1,1))\n",
    "\n",
    "# Fit the multinomial logistic regression models using Statsmodels\n",
    "\n",
    "# DOUBLE CHECK 0 IS REFERENCE CLASS CATEGORY\n",
    "\n",
    "NB_baseline = sm.MNLogit(predictions_NB, Test_X_covariates_constant, check_rank=True).fit(method='bfgs')\n",
    "SVM_baseline = sm.MNLogit(predictions_SVM, Test_X_covariates_constant, check_rank=True).fit(method='bfgs')\n",
    "KNN_baseline = sm.MNLogit(predictions_KNN, Test_X_covariates_constant, check_rank=True).fit(method='bfgs')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 198,
   "id": "db3ed98b",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "                          MNLogit Regression Results                          \n",
      "==============================================================================\n",
      "Dep. Variable:         predictions_NB   No. Observations:                  383\n",
      "Model:                        MNLogit   Df Residuals:                      371\n",
      "Method:                           MLE   Df Model:                            6\n",
      "Date:                Fri, 09 Feb 2024   Pseudo R-squ.:                 0.04083\n",
      "Time:                        11:23:18   Log-Likelihood:                -206.09\n",
      "converged:                      False   LL-Null:                       -214.86\n",
      "Covariance Type:            nonrobust   LLR p-value:                  0.007475\n",
      "=====================================================================================\n",
      " predictions_NB=2       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "-------------------------------------------------------------------------------------\n",
      "const                 0.8099      1.118      0.724      0.469      -1.382       3.002\n",
      "x1                    0.2697      0.241      1.121      0.262      -0.202       0.742\n",
      "-------------------------------------------------------------------------------------\n",
      "predictions_NB=3       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------------\n",
      "const               -2.1579      1.752     -1.232      0.218      -5.591       1.276\n",
      "x1                   0.4823      0.283      1.704      0.088      -0.073       1.037\n",
      "------------------------------------------------------------------------------------\n",
      "predictions_NB=8       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------------\n",
      "const                2.5914      1.176      2.203      0.028       0.286       4.897\n",
      "x1                  -0.5646      0.387     -1.461      0.144      -1.322       0.193\n",
      "------------------------------------------------------------------------------------\n",
      "predictions_NB=13       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "-------------------------------------------------------------------------------------\n",
      "const                -1.9423      1.954     -0.994      0.320      -5.772       1.887\n",
      "x1                    0.3318      0.318      1.043      0.297      -0.292       0.956\n",
      "-------------------------------------------------------------------------------------\n",
      "predictions_NB=16       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "-------------------------------------------------------------------------------------\n",
      "const                 4.2852      1.021      4.197      0.000       2.284       6.287\n",
      "x1                    0.1506      0.232      0.649      0.516      -0.304       0.605\n",
      "-------------------------------------------------------------------------------------\n",
      "predictions_NB=18       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "-------------------------------------------------------------------------------------\n",
      "const                -0.0535      1.237     -0.043      0.965      -2.477       2.370\n",
      "x1                    0.2811      0.251      1.118      0.264      -0.212       0.774\n",
      "=====================================================================================\n"
     ]
    }
   ],
   "source": [
    "print(NB_baseline.summary())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 158,
   "id": "2c3cfc5a",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "                          MNLogit Regression Results                          \n",
      "==============================================================================\n",
      "Dep. Variable:                      y   No. Observations:                  383\n",
      "Model:                        MNLogit   Df Residuals:                      353\n",
      "Method:                           MLE   Df Model:                           15\n",
      "Date:                Fri, 09 Feb 2024   Pseudo R-squ.:                 0.03538\n",
      "Time:                        11:05:40   Log-Likelihood:                -754.01\n",
      "converged:                      False   LL-Null:                       -781.67\n",
      "Covariance Type:            nonrobust   LLR p-value:                 1.581e-06\n",
      "==============================================================================\n",
      "       y=2       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          1.1153      0.705      1.583      0.113      -0.266       2.496\n",
      "x1            -0.1521      0.101     -1.511      0.131      -0.349       0.045\n",
      "------------------------------------------------------------------------------\n",
      "       y=3       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -0.0442      0.795     -0.056      0.956      -1.602       1.514\n",
      "x1             0.0292      0.103      0.284      0.776      -0.172       0.231\n",
      "------------------------------------------------------------------------------\n",
      "       y=4       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -0.9445      1.404     -0.673      0.501      -3.697       1.808\n",
      "x1            -0.2258      0.248     -0.910      0.363      -0.712       0.261\n",
      "------------------------------------------------------------------------------\n",
      "       y=5       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -1.4707      1.375     -1.070      0.285      -4.165       1.224\n",
      "x1            -0.0314      0.186     -0.169      0.866      -0.396       0.334\n",
      "------------------------------------------------------------------------------\n",
      "       y=6       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -1.5522      1.119     -1.387      0.165      -3.745       0.641\n",
      "x1             0.1399      0.134      1.044      0.296      -0.123       0.403\n",
      "------------------------------------------------------------------------------\n",
      "       y=7       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          0.4565      0.786      0.581      0.562      -1.085       1.998\n",
      "x1            -0.1128      0.112     -1.011      0.312      -0.331       0.106\n",
      "------------------------------------------------------------------------------\n",
      "       y=8       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          3.1397      0.620      5.061      0.000       1.924       4.356\n",
      "x1            -0.4534      0.101     -4.511      0.000      -0.650      -0.256\n",
      "------------------------------------------------------------------------------\n",
      "       y=9       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -0.5065      1.035     -0.489      0.625      -2.535       1.522\n",
      "x1            -0.1032      0.150     -0.688      0.491      -0.397       0.191\n",
      "------------------------------------------------------------------------------\n",
      "      y=11       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -1.4542      1.548     -0.940      0.347      -4.488       1.579\n",
      "x1            -0.1279      0.237     -0.540      0.589      -0.592       0.337\n",
      "------------------------------------------------------------------------------\n",
      "      y=13       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          1.8323      0.640      2.863      0.004       0.578       3.087\n",
      "x1            -0.1531      0.089     -1.729      0.084      -0.327       0.020\n",
      "------------------------------------------------------------------------------\n",
      "      y=15       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          1.1701      0.727      1.610      0.107      -0.255       2.595\n",
      "x1            -0.2295      0.112     -2.044      0.041      -0.450      -0.009\n",
      "------------------------------------------------------------------------------\n",
      "      y=16       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          3.4751      0.589      5.897      0.000       2.320       4.630\n",
      "x1            -0.2207      0.080     -2.771      0.006      -0.377      -0.065\n",
      "------------------------------------------------------------------------------\n",
      "      y=17       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -1.0164      1.792     -0.567      0.571      -4.528       2.496\n",
      "x1            -0.4051      0.444     -0.913      0.361      -1.275       0.465\n",
      "------------------------------------------------------------------------------\n",
      "      y=18       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          1.0084      0.703      1.435      0.151      -0.369       2.386\n",
      "x1            -0.1125      0.098     -1.152      0.249      -0.304       0.079\n",
      "------------------------------------------------------------------------------\n",
      "      y=20       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -1.0433      1.117     -0.934      0.350      -3.233       1.147\n",
      "x1            -0.0008      0.147     -0.006      0.995      -0.289       0.287\n",
      "==============================================================================\n"
     ]
    }
   ],
   "source": [
    "print(SVM_baseline.summary())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 159,
   "id": "c9b3df52",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "                          MNLogit Regression Results                          \n",
      "==============================================================================\n",
      "Dep. Variable:                      y   No. Observations:                  383\n",
      "Model:                        MNLogit   Df Residuals:                      343\n",
      "Method:                           MLE   Df Model:                           20\n",
      "Date:                Fri, 09 Feb 2024   Pseudo R-squ.:                 0.02162\n",
      "Time:                        11:05:42   Log-Likelihood:                -948.86\n",
      "converged:                      False   LL-Null:                       -969.83\n",
      "Covariance Type:            nonrobust   LLR p-value:                  0.002814\n",
      "==============================================================================\n",
      "       y=1       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -0.6516      1.309     -0.498      0.619      -3.216       1.913\n",
      "x1             0.6859      0.438      1.566      0.117      -0.173       1.545\n",
      "------------------------------------------------------------------------------\n",
      "       y=2       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          2.0234      1.181      1.714      0.087      -0.290       4.337\n",
      "x1             0.4290      0.433      0.990      0.322      -0.420       1.278\n",
      "------------------------------------------------------------------------------\n",
      "       y=3       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -0.0063      1.254     -0.005      0.996      -2.463       2.451\n",
      "x1             0.6370      0.436      1.461      0.144      -0.218       1.492\n",
      "------------------------------------------------------------------------------\n",
      "       y=4       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -0.5092      1.565     -0.325      0.745      -3.577       2.559\n",
      "x1             0.2576      0.500      0.516      0.606      -0.721       1.237\n",
      "------------------------------------------------------------------------------\n",
      "       y=5       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -0.0400      1.329     -0.030      0.976      -2.645       2.565\n",
      "x1             0.4359      0.446      0.978      0.328      -0.438       1.309\n",
      "------------------------------------------------------------------------------\n",
      "       y=6       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          1.2557      1.211      1.037      0.300      -1.117       3.629\n",
      "x1             0.4038      0.436      0.926      0.354      -0.451       1.259\n",
      "------------------------------------------------------------------------------\n",
      "       y=7       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -0.5819      1.347     -0.432      0.666      -3.222       2.058\n",
      "x1             0.5865      0.442      1.328      0.184      -0.279       1.452\n",
      "------------------------------------------------------------------------------\n",
      "       y=8       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          2.2324      1.188      1.879      0.060      -0.097       4.561\n",
      "x1             0.2303      0.437      0.527      0.598      -0.625       1.086\n",
      "------------------------------------------------------------------------------\n",
      "       y=9       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          0.7810      1.237      0.631      0.528      -1.644       3.206\n",
      "x1             0.4272      0.438      0.975      0.329      -0.431       1.286\n",
      "------------------------------------------------------------------------------\n",
      "      y=10       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -1.7203      1.816     -0.947      0.343      -5.280       1.839\n",
      "x1             0.4918      0.484      1.016      0.310      -0.457       1.440\n",
      "------------------------------------------------------------------------------\n",
      "      y=11       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -2.0952      1.846     -1.135      0.256      -5.713       1.523\n",
      "x1             0.5973      0.473      1.262      0.207      -0.330       1.525\n",
      "------------------------------------------------------------------------------\n",
      "      y=12       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -0.4262      1.405     -0.303      0.762      -3.180       2.328\n",
      "x1             0.4327      0.453      0.956      0.339      -0.455       1.320\n",
      "------------------------------------------------------------------------------\n",
      "      y=13       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          1.9504      1.184      1.647      0.100      -0.370       4.271\n",
      "x1             0.4012      0.434      0.925      0.355      -0.449       1.251\n",
      "------------------------------------------------------------------------------\n",
      "      y=14       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -1.1730      1.512     -0.776      0.438      -4.136       1.790\n",
      "x1             0.5531      0.453      1.220      0.222      -0.335       1.442\n",
      "------------------------------------------------------------------------------\n",
      "      y=15       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          1.2919      1.229      1.052      0.293      -1.116       3.700\n",
      "x1             0.2785      0.441      0.631      0.528      -0.587       1.144\n",
      "------------------------------------------------------------------------------\n",
      "      y=16       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          2.4787      1.173      2.113      0.035       0.179       4.778\n",
      "x1             0.3927      0.433      0.908      0.364      -0.455       1.241\n",
      "------------------------------------------------------------------------------\n",
      "      y=17       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -0.9775      1.713     -0.571      0.568      -4.335       2.380\n",
      "x1             0.2975      0.514      0.578      0.563      -0.710       1.306\n",
      "------------------------------------------------------------------------------\n",
      "      y=18       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          0.3126      1.244      0.251      0.802      -2.126       2.751\n",
      "x1             0.5659      0.436      1.297      0.195      -0.289       1.421\n",
      "------------------------------------------------------------------------------\n",
      "      y=19       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -1.1927      1.480     -0.806      0.420      -4.093       1.708\n",
      "x1             0.5939      0.449      1.322      0.186      -0.287       1.475\n",
      "------------------------------------------------------------------------------\n",
      "      y=20       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -0.5873      1.423     -0.413      0.680      -3.377       2.203\n",
      "x1             0.4621      0.452      1.021      0.307      -0.425       1.349\n",
      "==============================================================================\n"
     ]
    }
   ],
   "source": [
    "print(KNN_baseline.summary())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b38f828",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2a949a99",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "581de427",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e2899fac",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "57c0c66c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4fe5f9dc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1da44887",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "09b3bf4e",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
