{
 "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\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": 1,
   "id": "c4c1ae99",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2024-03-27 10:52:40.192100: I tensorflow/core/platform/cpu_feature_guard.cc:182] This TensorFlow binary is optimized to use available CPU instructions in performance-critical operations.\n",
      "To enable the following instructions: AVX2 FMA, in other operations, rebuild TensorFlow with the appropriate compiler flags.\n"
     ]
    }
   ],
   "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",
    "import seaborn as sns\n",
    "import json\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, confusion_matrix\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": "c692059d",
   "metadata": {},
   "source": [
    "## Load Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b5401a0a",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.read_csv('../../data/phmrc/phmrc_adult_tokenized.csv')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ed9dad6c",
   "metadata": {},
   "source": [
    "## Train test split"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "b062d42d",
   "metadata": {},
   "outputs": [],
   "source": [
    "Train_X, Test_X, Train_Y, Test_Y = model_selection.train_test_split(df['tags'], df['gs_cod'],test_size=0.3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ee66983d",
   "metadata": {},
   "outputs": [],
   "source": [
    "Train_Y_list = list(Train_Y)\n",
    "Test_Y_list = list(Test_Y)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "79e809b0",
   "metadata": {},
   "source": [
    "## Create embeddings from labeled data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "49456e05",
   "metadata": {},
   "outputs": [],
   "source": [
    "Encoder = LabelEncoder()\n",
    "Train_Y = Encoder.fit_transform(Train_Y)\n",
    "Test_Y = Encoder.fit_transform(Test_Y)\n",
    "\n",
    "Tfidf_vect = TfidfVectorizer(max_features=5000)\n",
    "Tfidf_vect.fit(df['tags'])\n",
    "Train_X_Tfidf = Tfidf_vect.transform(Train_X)\n",
    "Test_X_Tfidf = Tfidf_vect.transform(Test_X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "18212013",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Create a dictionary where embeddings are keys and strings are values\n",
    "Train_Y_mapping = {int(embedding): string for string, embedding in zip(Train_Y_list, Train_Y)}\n",
    "Test_Y_mapping = {int(embedding): string for string, embedding in zip(Test_Y_list, Test_Y)}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "04b78b9e",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Save the dictionary to a JSON file\n",
    "with open('cod_embeddings.json', 'w') as file:\n",
    "    json.dump(Train_Y_mapping, file)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9cd991f2",
   "metadata": {},
   "source": [
    "## Naive Bayes Classifier"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "a46f47b2",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Naive Bayes Accuracy Score ->  0.6155741744701824\n",
      "Naive Bayes Weighted F1 Score ->  0.7330756466378946\n"
     ]
    }
   ],
   "source": [
    "# fit the training dataset on the NB classifier\n",
    "NB = naive_bayes.MultinomialNB()\n",
    "NB.fit(Train_X_Tfidf,Train_Y)\n",
    "\n",
    "# predict the labels on validation dataset\n",
    "predictions_NB = NB.predict(Test_X_Tfidf)\n",
    "\n",
    "# Use accuracy_score and f1_score functions to get the accuracy\n",
    "NB_accuracy = accuracy_score(predictions_NB, Test_Y)\n",
    "NB_weighted_f1 = f1_score(predictions_NB, Test_Y, average='weighted')\n",
    "print(\"Naive Bayes Accuracy Score -> \", NB_accuracy)\n",
    "print(\"Naive Bayes Weighted F1 Score -> \", NB_weighted_f1)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4b86229f",
   "metadata": {},
   "source": [
    "## SVM Classifier"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "214afda4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Naive Bayes Accuracy Score ->  0.6949236076885165\n",
      "Naive Bayes Weighted F1 Score ->  0.7562057465163148\n"
     ]
    }
   ],
   "source": [
    "# fit the training dataset on the SVM classifier\n",
    "SVM = svm.SVC(C=1.0, kernel='linear', degree=3, gamma='auto')\n",
    "SVM.fit(Train_X_Tfidf,Train_Y)\n",
    "\n",
    "# predict the labels on validation dataset\n",
    "predictions_SVM = SVM.predict(Test_X_Tfidf)\n",
    "\n",
    "# Use accuracy_score and f1_score functions to get the accuracy\n",
    "SVM_accuracy = accuracy_score(predictions_SVM, Test_Y)\n",
    "SVM_weighted_f1 = f1_score(predictions_SVM, Test_Y, average='weighted')\n",
    "print(\"Naive Bayes Accuracy Score -> \", SVM_accuracy)\n",
    "print(\"Naive Bayes Weighted F1 Score -> \", SVM_weighted_f1)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "62666db3",
   "metadata": {},
   "source": [
    "## K Nearest Neighbors Classifier"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "32617d9d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Naive Bayes Accuracy Score ->  0.6525381961557417\n",
      "Naive Bayes Weighted F1 Score ->  0.6944519387591063\n"
     ]
    }
   ],
   "source": [
    "# k=8 with cosine distance\n",
    "KNN = KNeighborsClassifier(n_neighbors=9, weights='distance', metric='cosine')\n",
    "KNN.fit(Train_X_Tfidf,Train_Y)\n",
    "\n",
    "# predict the labels on validation dataset\n",
    "predictions_KNN = KNN.predict(Test_X_Tfidf)\n",
    "\n",
    "# Use accuracy_score and f1_score functions to get the accuracy\n",
    "KNN_accuracy = accuracy_score(predictions_KNN, Test_Y)\n",
    "KNN_weighted_f1 = f1_score(predictions_KNN, Test_Y, average='weighted')\n",
    "print(\"Naive Bayes Accuracy Score -> \", KNN_accuracy)\n",
    "print(\"Naive Bayes Weighted F1 Score -> \", KNN_weighted_f1)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4ecc734a",
   "metadata": {},
   "source": [
    "## Results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "78e7441e",
   "metadata": {},
   "outputs": [],
   "source": [
    "accuracy_scores = {'NB': NB_accuracy, 'KNN': KNN_accuracy, 'SVM': SVM_accuracy}\n",
    "weighted_f1_scores = {'NB': NB_weighted_f1, 'KNN': KNN_weighted_f1, 'SVM': SVM_weighted_f1}"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c0230ef7",
   "metadata": {},
   "source": [
    "## Plot Differences"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "4bb6efd0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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qFB7VlaWQtghIiIiqmkVCjcdO3bEn3/+KX9fEGh++ukndO3atWoqIyIiIqqACp2W8vX1xYABA3Dt2jXk5ubi+++/x9WrVxEVFYWTJ09WdY1EREREZVahkRsnJydERkbixYsXaNGiBY4cOQJjY2NERUXBwcGhqmskIiIiKrNyj9y8fv0an332GRYsWIBt27ZVR01EREREFVbukRs1NTX89ttv1VELERERUaVV6LTU8OHDERISUsWlEBEREVVehSYUW1paYsmSJYiMjISDgwN0dHQUlnt6elZJcURERETlVaFws2XLFtSrVw8xMTGIiYlRWCaTyRhuiIiISGkqFG5u3bpV1XUQERERVYkKzbl5mxACQoiqqIWIiIio0iocbrZv3442bdpAS0sLWlpasLe3x44dO6qyNiIiIqJyq9BpqbVr12LBggWYMWMGunXrBiEEzpw5g2nTpuHx48eYPXt2VddJREREVCYVCjfr16+Hv78/Jk6cKG/78MMP0bp1a/j4+DDcEBERkdJU6LRUcnIynJycCrU7OTkhOTm50kURERERVVSFwo2lpSV++eWXQu3BwcGwsrKqdFFEREREFVWh01KLFi3CmDFjcOrUKXTr1g0ymQynT5/GsWPHigw9RERERDWlQiM3I0eOxLlz52BoaIiQkBDs378fhoaGOH/+PIYPH17VNRIRERGVWYVGbgDAwcEBO3furMpaiIiIiCqtQiM3oaGhOHz4cKH2w4cP46+//qp0UUREREQVVaFw4+3tjby8vELtQgh4e3tXuigiIiKiiqpQuElMTESrVq0KtdvY2ODGjRuVLoqIiIiooioUbvT19fHPP/8Uar9x4wZ0dHQqXRQRERFRRVUo3AwdOhSzZs3CzZs35W03btzAnDlzMHTo0CorjoiIiKi8KhRuVq9eDR0dHdjY2MDCwgIWFhawsbFBgwYNsGbNmqqukYiIiKjMKnQpuL6+PiIjIxEWFoZLly5BS0sLbdu2RY8ePaq6PiIiIqJyKdfIzblz5+SXestkMri6usLIyAhr1qzByJEj8dlnnyE7O7taCiUiIiIqi3KFGx8fH1y+fFn+/sqVK5gyZQr69esHb29vHDx4EL6+vlVeJBEREVFZlSvcxMXFoW/fvvL3e/bsQadOnfDTTz/By8sL69at47OliIiISKnKFW6ePn0KY2Nj+fuTJ09iwIAB8vcdO3bE3bt3q646IiIionIqV7gxNjbGrVu3AAA5OTm4ePEiunbtKl/+/PlzqKmpVW2FREREROVQrnAzYMAAeHt7IyIiAvPnz4e2trbCFVKXL19GixYtqrxIIiIiorIq16XgS5cuxYgRI9CrVy/o6upi27ZtUFdXly/funUrXF1dq7xIIiIiorIqV7hp2LAhIiIikJ6eDl1dXaioqCgs37t3L3R1dau0QCIiIqLyqPBN/IpiYGBQqWKIiIiIKqtCj18gIiIiqq0YboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSGG6IiIhIUhhuiIiISFIYboiIiEhSlB5uNm7cCAsLC2hqasLBwQERERFlWu/MmTNQVVVFu3btqrdAIiIieqcoNdwEBwdj1qxZ+OabbxAbG4sePXpg4MCBSEpKKnG99PR0TJw4EX379q2hSomIiOhdodRws3btWnh4eGDy5MmwtbWFn58fzMzM4O/vX+J6U6dOxbhx49C1a9caqpSIiIjeFUoLNzk5OYiJiSn0FHFXV1dERkYWu15gYCBu3ryJb7/9tkz7yc7ORkZGhsKLiIiIpEtp4ebx48fIy8uDsbGxQruxsTFSUlKKXCcxMRHe3t74+eefoapatmd++vr6Ql9fX/4yMzOrdO1ERERUeyl9QrFMJlN4L4Qo1AYAeXl5GDduHBYtWoSWLVuWefvz589Henq6/HX37t1K10xERES1V9mGP6qBoaEhVFRUCo3SpKamFhrNAYDnz58jOjoasbGxmDFjBgAgPz8fQgioqqriyJEj6NOnT6H1NDQ0oKGhUT0HQURERLWO0kZu1NXV4eDggLCwMIX2sLAwODk5Feqvp6eHK1euIC4uTv6aNm0arK2tERcXh86dO9dU6URERFSLKW3kBgC8vLwwYcIEODo6omvXrti8eTOSkpIwbdo0AG9OKd2/fx/bt29HnTp1YGdnp7C+kZERNDU1C7UTERHR+0up4WbMmDFIS0vD4sWLkZycDDs7O4SGhsLc3BwAkJycXOo9b4iIiIjeptRwAwDTp0/H9OnTi1wWFBRU4ro+Pj7w8fGp+qKIiIjonaX0q6WIiIiIqhLDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJitLDzcaNG2FhYQFNTU04ODggIiKi2L779+9Hv3790LBhQ+jp6aFr1644fPhwDVZLREREtZ1Sw01wcDBmzZqFb775BrGxsejRowcGDhyIpKSkIvufOnUK/fr1Q2hoKGJiYuDs7IwhQ4YgNja2hisnIiKi2kqp4Wbt2rXw8PDA5MmTYWtrCz8/P5iZmcHf37/I/n5+fpg7dy46duwIKysrLF++HFZWVjh48GANV05ERES1ldLCTU5ODmJiYuDq6qrQ7urqisjIyDJtIz8/H8+fP4eBgUGxfbKzs5GRkaHwIiIiIulSWrh5/Pgx8vLyYGxsrNBubGyMlJSUMm3jv//9L7KysjB69Ohi+/j6+kJfX1/+MjMzq1TdREREVLspfUKxTCZTeC+EKNRWlN27d8PHxwfBwcEwMjIqtt/8+fORnp4uf929e7fSNRMREVHtpaqsHRsaGkJFRaXQKE1qamqh0Zx/Cw4OhoeHB/bu3QsXF5cS+2poaEBDQ6PS9RIREdG7QWkjN+rq6nBwcEBYWJhCe1hYGJycnIpdb/fu3XBzc8OuXbswaNCg6i6TiIiI3jFKG7kBAC8vL0yYMAGOjo7o2rUrNm/ejKSkJEybNg3Am1NK9+/fx/bt2wG8CTYTJ07E999/jy5dushHfbS0tKCvr6+04yAiIqLaQ6nhZsyYMUhLS8PixYuRnJwMOzs7hIaGwtzcHACQnJyscM+bH3/8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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Example scores (replace these with your actual scores)\n",
    "models = ['NB', 'KNN', 'SVM']\n",
    "accuracy_scores = {'NB': NB_accuracy, 'KNN': KNN_accuracy, 'SVM': SVM_accuracy}\n",
    "weighted_f1_scores = {'NB': NB_weighted_f1, 'KNN': KNN_weighted_f1, 'SVM': SVM_weighted_f1}\n",
    "\n",
    "# Plotting\n",
    "bar_width = 0.35\n",
    "index = np.arange(len(models))\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "bar1 = ax.bar(index, list(accuracy_scores.values()), bar_width, label='Accuracy')\n",
    "bar2 = ax.bar(index + bar_width, list(weighted_f1_scores.values()), bar_width, label='Weighted F1')\n",
    "\n",
    "ax.set_xlabel('Classifier')\n",
    "ax.set_ylabel('Scores')\n",
    "ax.set_title('VA COD Classification with Classic NLP')\n",
    "ax.set_xticks(index + bar_width / 2)\n",
    "ax.set_xticklabels(models)\n",
    "# Setting y-axis limits\n",
    "ax.set_ylim(0, 1.0)\n",
    "ax.legend()\n",
    "\n",
    "# Adding labels on top of the bars\n",
    "for i, v in enumerate(list(accuracy_scores.values())):\n",
    "    ax.text(i, v + 0.01, f'{v:.2f}', ha='center', va='bottom', color='black', fontweight='bold')\n",
    "\n",
    "for i, v in enumerate(list(weighted_f1_scores.values())):\n",
    "    ax.text(i + bar_width, v + 0.01, f'{v:.2f}', ha='center', va='bottom', color='black', fontweight='bold')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "39bce592",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Convert list of embeddings to list of strings using the dictionary\n",
    "predictions_NB_text = [Train_Y_mapping[embedding] for embedding in predictions_NB]\n",
    "predictions_SVM_text = [Train_Y_mapping[embedding] for embedding in predictions_SVM]\n",
    "predictions_KNN_text = [Train_Y_mapping[embedding] for embedding in predictions_KNN]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "a02cdcc0",
   "metadata": {},
   "outputs": [],
   "source": [
    "# go back the other way. list of strings to list of embeddings\n",
    "temp = list(map(lambda x: next(key for key, value in Train_Y_mapping.items() if value == x), predictions_NB_text))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "0bb537d6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAp0AAAGxCAYAAAAgUw3uAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAAAvKUlEQVR4nO3de1hUdeLH8c+g3ERAkOSiqHhLU7ySJpogXTS1NMtb5qXMzTTN1J+XVROtzUtbW21pupm6bW3aVubPUpdSvFKa11Q0M7xUqGUKBokC398f/pjHCcTbfEP0/XqeeR7nzDlnvt85MzvvzsywDmOMEQAAAGCRR0kPAAAAANc/ohMAAADWEZ0AAACwjugEAACAdUQnAAAArCM6AQAAYB3RCQAAAOuITgAAAFhHdAIAAMA6ohMA3Gj+/PlyOBzy8fHRwYMHC90eHx+vBg0auCyrXr26HA6H8+Lj46NatWppxIgR+vnnny96n8nJyS7blylTRqGhoerWrZtSU1PdNrfixMfHKz4+3nn9wIEDcjgcmj9//mXtZ/fu3UpMTNSBAwcK3da/f39Vr179qsYJoOQQnQBgQU5OjiZMmHDJ67dq1UopKSlKSUnRsmXL9Pjjj2v27Nlq3779Je/j+eefV0pKilatWqUxY8YoKSlJrVq10g8//HAlU7gq4eHhSklJUceOHS9ru927d2vy5MlFRufEiRP10UcfuWmEAP5oZUt6AABwPWrfvr3effddjRo1So0aNbro+hUqVNBtt93mvN62bVudOnVKzz77rL755hvVqVPnovuoXbu2cx9t2rRRhQoVNGDAAM2fP1/jx48vcpvs7GyVK1fuEmd16by9vV3m4w41a9Z06/4A/LE40wkAFowePVoVK1bUmDFjrngfgYGBkiRPT88r2r4g+go+5k9MTJTD4dCWLVv04IMPKigoyBlyxhjNnDlTjRs3lq+vr4KCgvTggw/qu+++c9mnMUYzZsxQtWrV5OPjo6ZNm2rZsmWF7vtCH6/v2bNHvXr1UmhoqLy9vVW1alX17dtXOTk5mj9/vrp16ybpXHQXfF2gYB9Ffbx++vRpjRs3TlFRUfLy8lLlypU1ZMgQnTx50mW96tWrq1OnTlq+fLmaNm0qX19f1a1bV2+99ZbLetnZ2Ro1apSioqLk4+Oj4OBgxcTE6N///vclP+4AisaZTgCwwN/fXxMmTNBTTz2llStXKiEhodj1jTHKzc2VdC6kNm3apJdfflmtWrVSVFTUFY3h22+/lSTddNNNLsu7du2qnj17atCgQcrKypIkPf7445o/f76GDRum6dOn65dfftGUKVMUGxur7du3KzQ0VJI0efJkTZ48WQMGDNCDDz6ow4cPa+DAgcrLy9PNN99c7Hi2b9+u1q1bKyQkRFOmTFHt2rWVnp6uJUuW6MyZM+rYsaOef/55/fnPf9brr7+upk2bSrrwGU5jjLp06aLPP/9c48aN0+23364dO3Zo0qRJzq8qeHt7u9z/yJEjNXbsWIWGhurNN9/UgAEDVKtWLbVp00aSNGLECL399tt67rnn1KRJE2VlZWnnzp06fvz4FRwBAC4MAMBt5s2bZySZTZs2mZycHFOjRg0TExNj8vPzjTHGxMXFmfr167tsU61aNSOp0KV58+YmPT39ove5atUqI8ksXLjQnD171mRnZ5s1a9aYWrVqmTJlypjt27cbY4yZNGmSkWSeeeYZl+1TUlKMJPPiiy+6LD98+LDx9fU1o0ePNsYYc+LECePj42Puv/9+l/XWr19vJJm4uDjnsrS0NCPJzJs3z7ksISHBVKhQwRw7duyCc3n//feNJLNq1apCt/Xr189Uq1bNeX358uVGkpkxY4bLegsXLjSSzJw5c5zLqlWrZnx8fMzBgwedy3777TcTHBxsHn/8ceeyBg0amC5dulxwfACuHB+vA4AlXl5eeu655/TVV19p0aJFxa7bunVrbdq0SZs2bdL69es1d+5c/fTTT0pISLikX7BLUo8ePeTp6aly5cqpTZs2ysvL03/+8x81bNjQZb0HHnjA5frSpUvlcDj08MMPKzc313kJCwtTo0aNlJycLElKSUnR6dOn1bt3b5ftY2NjVa1atWLHlp2drdWrV6t79+6FzrxeqZUrV0o697H7+bp16yY/Pz99/vnnLssbN26sqlWrOq/7+PioTp06Ln9loHnz5lq2bJnGjh2r5ORk/fbbb24ZKwA+XgcAq3r27Km//vWvGj9+vLp27XrB9QIDAxUTE+O8Hhsbq1tuuUUtW7bUiy++qKlTp170vqZPn66EhASVKVNGISEhioyMLHK98PBwl+tHjx6VMcb5Efrv1ahRQ5KcHzGHhYUVWqeoZec7ceKE8vLyVKVKlYvO41IdP35cZcuWLRSxDodDYWFhhT4Sr1ixYqF9eHt7u4Tlq6++qipVqmjhwoWaPn26fHx81K5dO73wwguqXbu228YO3IiITgCwyOFwaPr06brrrrs0Z86cy9q24Azl9u3bL2n9GjVquIRrcWM6X0hIiBwOh9auXevyHcgCBcsKou3IkSOF1jly5Eixf0MzODhYZcqU0ffff3/R8V2qihUrKjc3Vz/99JNLeBpjdOTIEd16662XvU8/Pz/n91aPHj3qPOt57733as+ePW4bO3Aj4uN1ALDszjvv1F133aUpU6bo119/veTttm3bJkmqVKmSpZGd06lTJxlj9MMPPygmJqbQJTo6WtK5X8P7+PjonXfecdl+w4YNRf4h/PP5+voqLi5O77//frFfFygI3Ev5WPuOO+6QJP3rX/9yWf7BBx8oKyvLefuVCg0NVf/+/dWrVy/t3btX2dnZV7U/4EbHmU4A+ANMnz5dzZo107Fjx1S/fv1Ct588eVJffPGFJOns2bNKTU3V888/L29vbw0ZMsTq2Fq1aqU//elPeuSRR/TVV1+pTZs28vPzU3p6utatW6fo6Gg98cQTCgoK0qhRo/Tcc8/pscceU7du3XT48GElJiZe9ON1SXrppZfUunVrtWjRQmPHjlWtWrV09OhRLVmyRLNnz5a/v7/z/61pzpw58vf3l4+Pj6Kioor8aPyuu+5Su3btNGbMGGVmZqpVq1bOX683adJEffr0uezHokWLFurUqZMaNmyooKAgpaam6u2331bLli2t/D1T4EZCdALAH6BJkybq1auX3n333SJvX79+vVq2bClJKlOmjCpXrqzmzZtr/Pjxaty4sfXxzZ49W7fddptmz56tmTNnKj8/XxEREWrVqpWaN2/uXG/KlCny8/PTzJkz9fbbb6tu3bp644039Ne//vWi99GoUSNt3LhRkyZN0rhx43Tq1CmFhYUpISFBXl5ekqSoqCi9/PLLeuWVVxQfH6+8vDzNmzev0I+FpHNfE1i8eLESExM1b948/eUvf1FISIj69OnjDPbLlZCQoCVLluhvf/ubsrOzVblyZfXt2/eCf1wfwKVzGGNMSQ8CAAAA1ze+0wkAAADriE4AAABYR3QCAADAOqITAAAA1hGdAAAAsI7oBAAAgHX8nU5YlZ+frx9//FH+/v6F/q/3AADAtckYo1OnTikiIkIeHu45R0l0wqoff/xRkZGRJT0MAABwBQ4fPqwqVaq4ZV9EJ6zy9/eXdO5JGxAQUMKjAQAAlyIzM1ORkZHO93F3IDphVcFH6gEBAUQnAACljDu/GscPiQAAAGAd0QkAAADriE4AAABYR3QCAADAOqITAAAA1hGdAAAAsI7oBAAAgHVEJwAAAKwjOgEAAGAd0QkAAADriE4AAABYR3QCAADAOqITAAAA1hGdAAAAsI7oBAAAgHVEJwAAAKwjOgEAAGAd0QkAAADriE4AAABYR3QCAADAOqITAAAA1hGdAAAAsI7oBAAAgHVEJwAAAKwjOgEAAGAd0QkAAADriE4AAABYV7akB4AbQ4NJK+ThXa6khwEAwHXjwLSOJT2Ey8KZTgAAAFhHdAIAAMA6ohMAAADWEZ0AAACwjugEAACAdUQnAAAArCM6AQAAYB3RCQAAAOuITgAAAFhHdAIAAMA6ohMAAADWEZ0AAACwjugEAACAdUQnAAAArCM6AQAAYB3RCQAAAOuITgAAAFhHdAIAAMA6ohMAAADWEZ0AAACwjugEAACAdUQnAAAArCM6AQAAYB3RCQAAAOuITgAAAFhHdF6DkpOT5XA4dPLkSbfs78CBA3I4HNq2bdsfdp8AAADnIzqvQbGxsUpPT1dgYGBJDwUAAMAtypb0AFCYl5eXwsLCSnoYAAAAbnNZZzrj4+M1bNgwjR49WsHBwQoLC1NiYqLz9kOHDqlz584qX768AgIC1L17dx09etR5e2Jioho3bqy3335b1atXV2BgoHr27KlTp04Ve785OTkaPXq0IiMj5e3trdq1a2vu3LnO21evXq3mzZvL29tb4eHhGjt2rHJzc13GPXToUA0fPlxBQUEKDQ3VnDlzlJWVpUceeUT+/v6qWbOmli1b5tym4OPmFStWqEmTJvL19VVCQoKOHTumZcuWqV69egoICFCvXr2UnZ3t3K569ep6+eWXXcbfuHFjl8fJ4XDozTff1P33369y5cqpdu3aWrJkSaH7Pv+j7vXr1ysuLk7lypVTUFCQ2rVrpxMnTkiSli9frtatW6tChQqqWLGiOnXqpP379xd6HPfs2aPY2Fj5+Piofv36Sk5OLvZx37Bhg9q0aSNfX19FRkZq2LBhysrKKnYbAACAolz2x+sLFiyQn5+fvvzyS82YMUNTpkxRUlKSjDHq0qWLfvnlF61evVpJSUnav3+/evTo4bL9/v37tXjxYi1dulRLly7V6tWrNW3atGLvs2/fvnrvvff06quvKjU1VW+88YbKly8vSfrhhx/UoUMH3Xrrrdq+fbtmzZqluXPn6rnnnis07pCQEG3cuFFDhw7VE088oW7duik2NlZbtmxRu3bt1KdPH5eAlM6F8muvvaYNGzbo8OHD6t69u15++WW9++67+uSTT5SUlKS///3vl/swavLkyerevbt27NihDh06qHfv3vrll1+KXHfbtm264447VL9+faWkpGjdunW69957lZeXJ0nKysrSiBEjtGnTJn3++efy8PDQ/fffr/z8fJf9/M///I9GjhyprVu3KjY2Vvfdd5+OHz9e5H1+/fXXateunbp27aodO3Zo4cKFWrdunZ588sli55WTk6PMzEyXCwAAgMMYYy515fj4eOXl5Wnt2rXOZc2bN1dCQoLuuOMO3XPPPUpLS1NkZKQkaffu3apfv742btyoW2+9VYmJiXrhhRd05MgR+fv7S5JGjx6tNWvW6IsvvijyPr/55hvdfPPNSkpK0p133lno9vHjx+uDDz5QamqqHA6HJGnmzJkaM2aMMjIy5OHhUWjceXl5CgwMVNeuXfXPf/5TknTkyBGFh4crJSVFt912m5KTk9W2bVt99tlnuuOOOyRJ06ZN07hx47R//37VqFFDkjRo0CAdOHBAy5cvl3TuTOfw4cM1fPhw5xgbN26sLl26OM92OhwOTZgwQc8++6ykc9Ho7++vTz/9VO3bt3fe94kTJ1ShQgU99NBDOnTokNatW3dJx+mnn35SpUqV9PXXX6tBgwY6cOCAoqKiNG3aNI0ZM0aSlJubq6ioKA0dOlSjR48udJ99+/aVr6+vZs+e7dzvunXrFBcXp6ysLPn4+BR534mJiZo8eXKh5ZHDF8nDu9wljR8AAFzcgWkdre07MzNTgYGBysjIUEBAgFv2edlnOhs2bOhyPTw8XMeOHVNqaqoiIyOdwSlJt9xyiypUqKDU1FTnsurVqzuD8/ztJemdd95R+fLlnZe1a9dq27ZtKlOmjOLi4oocT2pqqlq2bOkMTklq1aqVfv31V33//fdFjrtMmTKqWLGioqOjnctCQ0MlyTmWorYLDQ1VuXLlnMFZsOz321yK8/fr5+cnf3//C+6n4Eznhezfv18PPfSQatSooYCAAEVFRUk693WH87Vs2dL577Jlyyom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eZo1a5Z27dqlp59+Wg8//LDWrFmjBQsWaOPGjXr11VclSYMGDVJoaKgSExMVGRmpDz74QJK0d+9epaen65VXXil2n6tXr3a579GjR2vq1KlKTU1Vw4YNJUkLFiyQn5+fvvzyS82YMUNTpkxRUlKScxsPDw+9+uqr2rlzpxYsWKCVK1dq9OjRlzXnqVOnKjAw0HmJjIy84scPAABcPxym4FQb3CorK0shISFauXKlWrZs6Vz+2GOPKTs7W++++67ef/999enTRyNGjNArr7yirVu3qk6dOpLOnbFs27atTpw44fzxzqXss2C7xYsXq3Pnzs514uPjlZeXp7Vr1zqXNW/eXAkJCZo2bVqRc3j//ff1xBNP6Oeff5Z07odEw4cPL/Z7pjk5OcrJyXFez8zMVGRkpCKHL5KHd7lLfwAvwYFpHd26PwAAcE5mZqYCAwOVkZGhgIAAt+yzrFv2gkJ2796t06dP66677nJZfubMGTVp0kSS1K1bN3300UeaOnWqZs2a5QzOq9lngZiYmELbF5zxLBAeHq5jx445r69atUrPP/+8du/erczMTOXm5ur06dPKysqSn5/fxSctydvbW97e3pe0LgAAuHEQnZbk5+dLkj755BNVrlzZ5baCKMvOztbmzZtVpkwZ7du3zy37LFBUJHp6erpcdzgczn0ePHhQHTp00KBBg/Tss88qODhY69at04ABA3T27NmLjg0AAKA4RKclt9xyi7y9vXXo0CHFxcUVuc7IkSPl4eGhZcuWqUOHDurYsaMSEhIkSV5eXpKkvLy8y9rnlfrqq6+Um5urF198UR4e577qu2jRIrfeBwAAuHERnZb4+/tr1KhRevrpp5Wfn6/WrVsrMzNTGzZsUPny5RUSEqK33npLKSkpatq0qcaOHat+/fppx44dCgoKUrVq1eRwOLR06VJ16NBBvr6+F91nv379rni8NWvWVG5urv7+97/r3nvv1fr16/XGG2+48REBAAA3Mn69btGzzz6rZ555RlOnTlW9evXUrl07/e///q+qV6+uAQMGKDExUU2bNpUkTZo0SRERERo0aJAkqXLlypo8ebLGjh2r0NBQPfnkk8XuMyoq6qrG2rhxY7300kuaPn26GjRooHfeeUdTp069ugcAAADg//HrdVhV8Os3fr0OAEDpYePX65zpBAAAgHVEJwAAAKwjOgEAAGAd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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "pd.Series(predictions_NB_text).value_counts().plot.barh(title='NB Predictions').invert_yaxis()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "e74f506b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAApIAAAGxCAYAAADRWFZjAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAAA7wklEQVR4nO3de3zP9f//8ft7G2+bHcywGWOTs20IlalGFDlE+kQSE/VtOY5yKhn1qaFPUX2KjyLVh6RPUqFYTk0WMstpDi1DGSI2Z7Y9f3+47P3zbge8TLN1u14u78ul9+v1fD1fj8dLbfeer/frzWaMMQIAAACukUtxFwAAAICSiSAJAAAASwiSAAAAsIQgCQAAAEsIkgAAALCEIAkAAABLCJIAAACwhCAJAAAASwiSAAAAsIQgCQDXaP369XrwwQdVo0YN2e12+fv7q2XLlnrmmWf0+++/q2zZsnrkkUcKPD4zM1MeHh564IEHJElz5syRzWaTzWbT6tWr84w3xqh27dqy2Wxq3br1NdXar18/x9w2m012u1316tVTbGyszp07d01zWZGWliabzaY5c+Y4tk2YMEE2m+2a55o3b56mTZuW7z6bzaYJEyZYKxKAZQRJALgGS5YsUUREhDIzMzVlyhQtX75cb7zxhlq1aqVPPvlElStX1gMPPKBFixbp+PHj+c4xf/58nT17VgMGDHDa7uXlpVmzZuUZv2bNGqWmpsrLy8tSze7u7kpMTFRiYqIWLVqk22+/XS+++KKioqIszXe9nnjiCSUmJl7zcYUFycTERD3xxBPXWRmAa+VW3AUAQEkyZcoUhYSEaNmyZXJz+/8/Qh955BFNmTJFkjRgwAB99tlnmjt3rgYPHpxnjtmzZ8vf31+dOnVy2t6zZ0/NnTtXb7/9try9vR3bZ82apZYtWyozM9NSzS4uLrrjjjsc7++//36lpaVpwYIFev3111WtWrV8jzt79qzc3d0tnbMw1atXV/Xq1Yt0zsv7A/DXYUUSAK7BsWPHVKlSJacQmcvF5dKP1Pbt26t69ep6//3384xJSUnR+vXr1bdv3zxz9OrVS5L08ccfO7ZlZGTos88+U//+/YuyDUfw2rdvnyQpODhYnTt31sKFC9W0aVOVK1dOEydOlCQdOnRITz31lKpXr66yZcsqJCREEydOVFZWltOcBw8eVI8ePeTl5SUfHx/17NlThw4dynPugm5tz5s3Ty1btpSnp6c8PT3VpEkTxwpt69attWTJEu3bt8/pVn2u/G5tb9u2TV27dpWvr6/KlSunJk2a6IMPPnAas3r1atlsNn388cd6/vnnFRgYKG9vb7Vr1067du1yGrt582Z17txZVapUkd1uV2BgoDp16qRff/31ai45UCoRJAHgGrRs2VLr16/X0KFDtX79el28eDHPGBcXF/Xr109JSUn66aefnPblhsv8gqG3t7f+8Y9/aPbs2Y5tH3/8sVxcXNSzZ88i7ePnn3+WJFWuXNmxLSkpSSNHjtTQoUP1zTff6KGHHtKhQ4d02223admyZRo/fry+/vprDRgwQHFxcXryyScdx549e1bt2rXT8uXLFRcXp08//VQBAQFXXff48ePVu3dvBQYGas6cOfr8888VFRXlCLrvvPOOWrVqpYCAAMdt+sJuj+/atUsRERHavn273nzzTS1cuFANGzZUv379HCvHl3vuuee0b98+vffee5o5c6b27NmjLl26KDs7W5J0+vRp3XvvvTp8+LDefvttxcfHa9q0aapRo4ZOnjx5VT0CpZIBAFy1o0ePmjvvvNNIMpJMmTJlTEREhImLizMnT550jPvll1+MzWYzQ4cOdWy7ePGiCQgIMK1atXKa8/333zeSzMaNG82qVauMJLNt2zZjjDEtWrQw/fr1M8YY06hRIxMZGXlN9UZFRZny5cubixcvmosXL5rff//dvPHGG8Zms5kWLVo4xtWsWdO4urqaXbt2OR3/1FNPGU9PT7Nv3z6n7f/617+MJLN9+3ZjjDHTp083kswXX3zhNO7JJ580ksz777/v2BYbG2su//Xzyy+/GFdXV9O7d+9Ce+nUqZOpWbNmvvskmdjYWMf7Rx55xNjtdrN//36ncffff7/x8PAwJ06cMMYYx/Xu2LGj07gFCxYYSSYxMdEYY8yPP/5oJJlFixYVWiPwd8OKJABcAz8/PyUkJGjjxo2aNGmSunbtqt27d2vs2LEKCwvT0aNHJUkhISFq06aN5s6dqwsXLkiSvv76ax06dKjQ29SRkZG65ZZbNHv2bG3dulUbN2687tvap0+fVpkyZVSmTBlVrlxZMTExuv/++/X55587jQsPD1fdunWdti1evFht2rRRYGCgsrKyHK/7779f0qUHgSRp1apV8vLycjyJnuvRRx+9Yn3x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OFjTpk1zqr9JkyZO18lms+m9997Tgw8+KA8PD9WpU0dffvllnnNffpv5+++/V2RkpDw8POTr66v27dvr+PHjkqRvvvlGd955pypUqCA/Pz917txZqampea7jzp07FRERoXLlyqlRo0ZavXp1odd93bp1uvvuu+Xu7q6goCANHTpUp0+fLvQYAADw93HNt7Y/+OADlS9fXuvXr9eUKVP04osvKj4+XsYYdevWTX/88YfWrFmj+Ph4paamqmfPnk7Hp6amatGiRVq8eLEWL16sNWvWaNKkSYWes2/fvpo/f77efPNNpaSkaMaMGfL09JQk/fbbb+rYsaNatGihn376SdOnT9esWbP0z3/+M0/dlSpV0oYNGzRkyBA9/fTTevjhhxUREaGkpCS1b99effr0cQqF0qXw++9//1vr1q3TgQMH1KNHD02bNk3z5s3TkiVLFB8fr7feeutaL6MmTpyoHj16aMuWLerYsaN69+6tP/74I9+xycnJatu2rRo1aqTExEStXbtWXbp0UXZ2tiTp9OnTGjFihDZu3KgVK1bIxcVFDz74oHJycpzmGTlypJ555hlt3rxZEREReuCBB3Ts2LF8z7l161a1b99e3bt315YtW/TJJ59o7dq1Gjx4cKF9nT9/XpmZmU4vAABQOtmMMeZqB7du3VrZ2dlKSEhwbLvtttt0zz33qG3btrr//vu1d+9eBQUFSZJ27NihRo0aacOGDWrRooUmTJigV199VYcOHZKXl5ckadSoUfruu+/0ww8/5HvO3bt3q169eoqPj1e7du3y7H/++ef12WefKSUlRTabTZL0zjvvaPTo0crIyJCLi0ueurOzs+Xj46Pu3bvrww8/lCQdOnRIVatWVWJiou644w6tXr1abdq00bfffqu2bdtKkiZNmqSxY8cqNTVVtWrVkiRFR0crLS1N33zzjaRLK5IxMTGKiYlx1NikSRN169bNsSpps9k0btw4vfTSS5IuBUEvLy8tXbpUHTp0cJz7+PHjqlChgh599FHt379fa9euvao/p99//11VqlTR1q1bFRoaqrS0NIWEhGjSpEkaPXq0JCkrK0shISEaMmSIRo0aleecffv2lbu7u/7zn/845l27dq0iIyN1+vRplStXLt9zT5gwQRMnTsyzPShmgVzsHldVPwAAuLK0SZ1u2NyZmZny8fFRRkaGvL29Cxx3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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "pd.Series(predictions_SVM_text).value_counts().plot.barh(title='SVM_Predictions').invert_yaxis()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "893083a1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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/Lad79ChQ4X68E1uPef3I0kBAQGO/bl8fX3zjLPb7fr7778d70eOHKmXXnpJP/30k+688075+vqqffv2l/V1TEBJ41rUBQBAcRYbGyubzabY2Fjl5OToo48+kqtr/n+0urm5KSYmRo8//ri+++67S5q/f//+eu211zR8+HD179/fuM5q1aopIiLiouPOf2ClYsWKkqTPPvtMNWrUKPC43CCW35Ppl/K0eqVKlfI8BHMlcutJS0vLE1D37dvn6OtyuLq6aujQoRo6dKiOHz+uJUuW6Nlnn1VkZKT27t0rd3f3QqkdKE5YkQSAKxQTE6PY2FjNmzdPDz/8sLKysgoc27dvX4WEhGjEiBFOTwQXpEyZMnr++ee1fv16ffrpp4VZ9iWJjIyUq6urUlJSFBERke9LOvukeZUqVfTJJ584fWXQ7t27tWbNmoue584779Ty5cu1ffv2AsfY7XZJclolLEi7du0kyelhGUlav369kpOT1b59+4vOcSHly5fXfffdp4EDB+ro0aNKTU29ovmA4ooVSQAoBGPHjpWLi4vGjBkjy7L0ySef5DuuVKlSmjBhgu655x5JZz+HdzHdu3fXSy+9pAULFhRqzZciKChIzz33nEaNGqXff/9dHTp0kI+Pjw4cOKB169apXLlyio2NlYuLi8aPH6/HHntM99xzj/7zn//o+PHjiomJuaRb288995wWLFigW2+9Vc8++6zCwsJ0/PhxLVy4UEOHDlXdunV1ww03yM3NTR999JFCQkLk4eGhgIAABQQE5JmvTp06evzxx/XGG2/IxcVFd955p1JTUzVmzBgFBgbqySefvOxr0aVLF4WGhioiIkKVKlXS7t27NWXKFNWoUUO1atW67PmAkoAgCQCFZPTo0XJxcdGoUaOUk5OjunXr5juua9euat68+SWt1ElnbzdPmjRJd9xxR2GWe8lGjhypevXq6bXXXtMnn3yizMxM+fv7q0mTJoqKinKM69evnyRp0qRJ6tatm4KCgvTss89q5cqVjodyClK1alWtW7dO48aNU1xcnI4cOaJKlSqpZcuWqlChgiTJ3d1d77//vmJjY3XHHXfozJkzGjduXIHfzzlt2jTdcMMNmjFjht566y15e3urQ4cOmjhxYr6fibyYtm3bav78+XrvvfeUkZEhf39/3X777RozZoxKly592fMBJYHNsq7Sry0A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u3YVWMvIkSOVnp7ueO3du7fAsQAAoHi77IdtSpcu7fTeZrMpJydHlmU5hblc528v6HhJuuuuu3TLLbc49lWtWlVLliy5YD35nTd3kfVi5z13W+7Y828Hnz/mQvVLkouLi85f5D1z5kyeui82z7nc3Nzy3Z6rS5cuCgwM1PTp0xUQEKCcnByFhobq9OnTFzwu97z5ycnJ0X//+18NHjw4z77q1asXOJ/dbpfdbr/oeQEAQPFXaF//U69ePe3Zs8dpBWrr1q1KT09XSEjIJc3h6empG2+80fFyc3NTWFiYcnJytHLlygLPu2bNGqfwtmbNGnl6eqpq1apX1pSBSpUqKS0tzfE+IyPjgit4lyI8PFxLly7Nd9+RI0eUnJys0aNHq3379goJCXE8hHO+cz8+kJWVpcTERNWtWzffsY0aNdKvv/7q9PPIfZUpU+aK+gEAACVDoQXJ2267TeHh4erRo4c2bNigdevWqVevXmrdurUiIiKM5w0KClLv3r3Vt29fffnll9q1a5dWrFihefPmSZIGDBigvXv3atCgQdq2bZu++uorjRs3TkOHDpWLy7//NZnt2rXT7NmzFR8fry1btqh3794qVarUFc05cuRIrV+/XgMGDNCmTZu0bds2TZs2TYcPH5aPj498fX317rvv6rffftOyZcs0dOjQfOd566239MUXX2jbtm0aOHCgjh07pr59++Y7dvjw4UpISNDAgQOVlJSknTt36uuvv9agQYOuqBcAAFByFFrSstls+vLLL+Xj46Nbb71Vt912m2rWrKm5c+de8dzTpk3TfffdpwEDBqhu3br6z3/+4/gamqpVq+r777/XunXr1KBBA0VFRalfv34aPXr0FZ/XxMiRI3Xrrbeqc+fO6tixo7p27aobbrjhiuasXbu2fvjhB/3yyy+6+eab1axZM3311VdydXWVi4uL5syZo8TERIWGhurJJ5/Uiy++mO88cXFxmjRpkho0aKD4+Hh99dVXqlixYr5jw8PDtXLlSu3cuVOtWrXSTTfdpDFjxqhKlSpX1AsAACg5LuupbeBy5T71xVPbAAAUrmL51DYAAAAgESQBAABgiCAJAAAAIwRJAAAAGCFIAgAAwAhBEgAAAEYIkgAAADBCkAQAAIARgiQAAACMECQBAABghCAJAAAAI65FXQCuD1tiIy/4uzoBAEDxw4okAAAAjBAkAQAAYIQgCQAAACMESQAAABghSAIAAMAIQRIAAABGCJIAAAAwQpAEAACAEYIkAAAAjBAkAQAAYIQgCQAAACMESQAAABghSAIAAMAIQRIAAABGCJIAAAAwQpAEAACAEYIkAAAAjBAkAQAAYIQgCQAAACMESQAAABghSAIAAMAIQRIAAABGCJIAAAAwQpAEAACAEYIkAAAAjBAkAQAAYIQgCQAAACMESQAAABghSAIAAMAIQRIAAABGCJIAAAAwQpAEAACAEYIkAAAAjBAkAQAAYIQgCQAAACMESQAAABhxLeoCcH0IHbdILnb3oi7jX5Ea16moSwAA4F/BiiQAAACMECQBAABghCAJAAAAIwRJAAAAGCFIAgAAwAhBEgAAAEYIkgAAADBCkAQAAIARgiQAAACMECQBAABghCAJAAAAIwRJAAAAGCFIAgAAwAhBEpds5syZKl++fFGXAQAArhEEyWvUihUrZLPZdPz48aIuBQAAIF8EyRLOsixlZWUVdRkAAKAEIkheRZZlafLkyapZs6bc3NzUoEEDffbZZ7IsS7fddps6dOggy7IkScePH1f16tU1atQopaamqm3btpIkHx8f2Ww29enT54Jz5spdyVy0aJEiIiJkt9sVHx+vNm3aaPDgwRo2bJgqVKggf39/xcTEONX7yiuvKCwsTOXKlVNgYKAGDBigv/7661+5VgAAoPhxLeoCSrLRo0fr888/17Rp01SrVi2tWrVKjzzyiCpVqqRZs2YpLCxMr7/+uoYMGaKoqCj5+fkpJiZGLi4umj9/vu69915t375dXl5ecnNzu+icrVu3dpx72LBheumll1SzZk3H5xpnzZqloUOHau3atUpISFCfPn3UokUL3X777ZIkFxcXvf766woKCtKuXbs0YMAADRs2TFOnTr3knjMzM5WZmel4n5GRUQhXEgAAXIsIklfJyZMn9corr2jZsmVq1qyZJKlmzZpavXq13nnnHX388cd655131LNnTx04cEDffPONNm7cqNKlS0uSKlSoIEmqXLmyIwhebM5zg+Rzzz3nCIi5wsPDNW7cOElSrVq19Oabb2rp0qWOcdHR0Y6xwcHBGj9+vPr3739ZQXLixImKjY29jCsFAACKK4LkVbJ161b9888/ecLc6dOnddNNN0mS7r//fn3xxReaOHGipk2bptq1a1/xnLkiIiLyHB8e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QpAEAACAEYIkAAAAjBAkAQAAYIQgCQAAACMESQAAABghSAIAAMAIQRIAAABGCJIAAAAwQpAEAACAEYIkAAAAjBAkAQAAYMS1qAvA9SF03CK52N0Lbb7UuE6FNhcAADDDiiQAAACMECQBAABghCAJAAAAIwRJAAAAGCFIAgAAwAhBEgAAAEYIkgAAADBCkAQAAIARgiQAAACMECQBAABghCAJAAAAIwRJAAAAGCFI4pK1adNG0dHRRV0GAAC4RhAkr1F9+vRR165di7oMAACAAhEkS7jTp08XdQkAAKCEIkgWgjZt2mjQoEGKjo6Wj4+P/Pz89O677+rkyZN69NFH5enpqRtuuEELFiyQJGVnZ6tfv34KDg6Wm5ub6tSpo9dee80xX0xMjGbNmqWvvvpKNptNNptNK1askCT9+eefevDBB+Xj4yNfX1/dfffdSk1NdRybu5I5ceJEBQQEqHbt2kpNTZXNZtPnn3+utm3byt3dXQ0aNFBCQoLjuCNHjqh79+6qVq2a3N3dFRYWpk8++eRfuX4AAKB4IkgWklmzZqlixYpat26dBg0apP79++v+++9X8+bNtWHDBkVGRqpnz546deqUcnJyVK1aNc2bN09bt27V2LFj9eyzz2revHmSpKeffloPPPCAOnTooLS0NKWlpal58+Y6deqU2rZtKw8PD61atUqrV6+Wh4eHOnTo4LTyuHTpUiUnJ2vx4sX69ttvHdtHjRqlp59+WklJSapdu7a6d++urKwsSdI///yjxo0b69tvv9WWLVv0+OOPq2fPnlq7du1lXYfMzExlZGQ4vQAAQMlksyzLKuoiirs2bdooOztb8fHxks6uOHp7e6tbt2768MMPJUn79+9XlSpVlJCQoKZNm+aZY+DAgTpw4IA+++wzSWdXFo8fP64vv/zSMeb999/X5MmTlZycLJvNJunsrevy5cvryy+/1B133KE+ffpo4cKF2rNnj8qUKSNJSk1NVXBwsN577z3169dPkrR161bVr19fycnJqlu3br59derUSSEhIXrppZccfTZs2FBTpkwp8FrExMQoNjY2z/bA6Hlysbtf6DJeltS4ToU2FwAAcJaRkSFvb2+lp6fLy8urwHGsSBaS8PBwxz+XKlVKvr6+CgsLc2zz8/OTJB08eFCS9PbbbysiIkKVKlWSh4eHpk+frj179lzwHImJifrtt9/k6ekpDw8PeXh4qEKFCvrnn3+UkpLiGBcWFuYIkQXVWKVKFad6srOz9cILLyg8PFy+vr7y8PDQDz/8cNGazjdy5Eilp6c7Xnv37r2s4wEAQPHhWtQFlBSlS5d2em+z2Zy25a4g5uTkaN68eXryySf18ssvq1mzZvL09NSLL7540dvIOTk5aty4sT766KM8+ypVquT453Llyl20xnPrkaSXX35Zr776qqZMmaKwsDCVK1dO0dHRl/2wjt1ul91uv6xjAABA8USQLALx8fFq3ry5BgwY4Nh27oqiJJUpU0bZ2dlO2xo1aqS5c+eqcuXKF1xmNq3p7rvv1iOPPCLpbMDcuXOnQkJCCvU8AACg5ODWdhG48cYb9fPPP2vRokXasWOHxowZo/Xr1zuNCQoK0qZNm7R9+3YdPnxYZ86cUY8ePVSxYkXdfffdio+P165du7Ry5UoNGTJEf/zxxxXXtHjxYq1Zs0bJycn673//q/3791/RnAAAoGQjSBaBqKgodevWTQ8++KBuueUWHTlyxGl1UpL+85//qE6dOo7PUf74449yd3fXqlWrVL16dXXr1k0hISHq27ev/v777yteoRwzZowaNWqkyMhItWnTRv7+/nwhOgAAuCCe2sZVlfvUF09tAwBQfPDUNgAAAK4qgiQAAACMECQBAABghCAJAAAAIwRJAAAAGCFIAgAAwAhBEgAAAEYIkgAAADBCkAQAAIARgiQAAACMECQBAABghCAJAAAAI65FXQCuD1tiIy/4S98BAEDxw4okAAAAjBAkAQAAYIQgCQAAACMESQAAABghSAIAAMAIQRIAAABGCJIAAAAwQpAEAACAEYIkAAAAjBAkAQAAYIQgCQAAACMESQAAABghSAIAAMAIQRIAAABGCJIAAAAwQpAEAACAEdeiLgAlm2VZkqSMjIwirgQAAFyq3L+3c/8eLwhBElfVkSNHJEmBgYFFXAkAALhcJ06ckLe3d4H7CZK4qipUqCBJ2rNnzwX/RSxpMjIyFBgYqL1798rLy6uoy/lX0fv11/v12rd0/fZ+vfYtXT+9W5alEydOKCAg4ILjCJK4qlxczn4M19vbu0T/B1cQLy+v67Jvid6vx96v176l67f367Vv6fro/VIWgHjYBgAAAEYIkgAAADBCkMRVZbfbNW7cONnt9qIu5V91vfYt0fv12Pv12rd0/fZ+vfYtXd+958dmXey5bgAAACAfrEgCAADACEESAAAARgiSAAAAMEKQBAAAgBGCJAAAAIwQJHHVTJ06VcHBwSpbtqwaN26s+Pj4oi7pikycOFFNmjSRp6enKleurK5du2r79u1OYyzLUkxMjAICAuTm5qY2bdro119/dRqTmZmpQYMGqWLFiipXrpzuuusu/fHHH/9mK1dk4sSJstlsio6OdmwryX3/+eefeuSRR+Tr6yt3d3c1bNhQiYmJjv0ltfesrCyNHj1awcHBcnNzU82aNfXcc88pJyfHMaak9L5q1Sp16dJFAQEBstls+vLLL532F1afx44dU8+ePeXt7S1vb2/17NlTx48fv8rdFexCfZ85c0bDhw9XWFiYypUrp4CAAPXq1Uv79u1zmqM49i1d/Gd+rv/+97+y2WyaMmWK0/bi2nuhs4CrYM6cOVbp0qWt6dOnW1u3brWGDBlilStXztq9e3dRl2YsMjLS+uCDD6wtW7ZYSUlJVqdOnazq1atbf/31l2NMXFyc5enpac2fP9/avHmz9eCDD1pVqlSxMjIyHGOioqKsqlWrWosXL7Y2bNhgtW3b1mrQoIGVlZVVFG1dlnXr1llBQUFWeHi4NWTIEMf2ktr30aNHrRo1alh9+vSx1q5da+3atctasmSJ9dtvvznGlNTen3/+ecvX19f69ttvrV27dlmffvqp5eHhYU2ZMsUxpqT0/v3331ujRo2y5s+fb0myvvjiC6f9hdVnhw4drNDQUGvNmjXWmjVrrNDQUKtz587/Vpt5XKjv48ePW7fddps1d+5ca9u2bVZCQoJ1yy23WI0bN3aaozj2bVkX/5nn+uKLL6wGDRpYAQEB1quvvuq0r7j2XtgIkrgqbr75ZisqKsppW926da0RI0YUUUWF7+DBg5Yka+XKlZZlWVZOTo7l7+9vxcXFOcb8888/lre3t/X2229blnX2D+fSpUtbc+bMcYz5888/LRcXF2vhwoX/bgOX6cSJE1atWrWsxYsXW61bt3YEyZLc9/Dhw62WLVsWuL8k996pUyerb9++Ttu6detmPfLII5Zlldzezw8VhdXn1q1bLUnWTz/95BiTkJBgSbK2bdt2lbu6uAuFqVzr1q2zJDkWBEpC35ZVcO9//PGHVbVqVWvLli1WjRo1nIJkSem9MHBrG4Xu9OnTSkxM1B133OG0/Y477tCaNWuKqKrCl56eLkmqUKGCJGnXrl3av3+/U992u12tW7d29J2YmKgzZ844jQkICFBoaOg1f20GDhyoTp066bbbbnPaXpL7/vrrrxUREaH7779flStX1k033aTp06c79pfk3lu2bKmlS5dqx44dkqRffvlFq1evVseOHSWV7N7PVVh9JiQkyNvbW7fccotjTNOmTeXt7V1srkV6erpsNpvKly8vqWT3nZOTo549e+qZZ55R/fr18+wvyb1fLteiLgAlz+HDh5WdnS0/Pz+n7X5+ftq/f38RVVW4LMvS0KFD1bJlS4WGhkqSo7f8+t69e7djTJkyZeTj45NnzLV8bebMmaMNGzZo/fr1efaV5L5///13TZs2TUOHDtWzzz6rdevWafDgwbLb7erVq1eJ7n348OFKT09X3bp1VapUKWVnZ+uFF15Q9+7dJZXsn/u5CqvP/fv3q3Llynnmr1y5crG4Fv/8849GjBihhx9+WF5eXpJKdt+TJk2Sq6urBg8enO/+ktz75SJI4qqx2WxO7y3LyrOtuHriiSe0adMmrV69Os8+k76v5Wuzd+9eDRkyRD/88IPKli1b4LiS1rd0dlUiIiJCEyZMkCTddNNN+vXXXzVt2jT16tXLMa4k9j537lz973//08cff6z69esrKSlJ0dHRCggIUO/evR3jSmLv+SmMPvMbXxyuxZkzZ/TQQw8pJydHU6dOvej44t53YmKiXnvtNW3YsOGyayzuvZvg1jYKXcWKFVWqVKk8/8d18ODBPP9XXxwNGjRIX3/9tZYvX65q1ao5tvv7+0vSBfv29/fX6dOndezYsQLHXGsSExN18OBBNW7cWK6urnJ1ddXKlSv1+uuvy9XV1VF3SetbkqpUqaJ69eo5bQsJCdGePXskldyfuSQ988wzGjFihB566CGFhYWpZ8+eevLJJzVx4kRJJbv3cxVWn/7+/jpw4ECe+Q8dOnRNX4szZ87ogQce0K5du7R48WLHaqRUcvuOj4/XwYMHVb16dcefebt379ZTTz2loKAgSSW3dxMESRS6MmXKqHHjxlq8eLHT9sWLF6t58+ZFVNWVsyxLTzzxhD7//HMtW7ZMwcHBTvuDg4Pl7+/v1Pfp06e1cuVKR9+NGzdW6dKlncakpaVpy5Yt1+y1ad++vTZv3qykpCTHKyIiQj169FBSUpJq1qxZIvuWpBYtWuT5iqcdO3aoRo0akkruz1ySTp06JRcX578iSpUq5fj6n5Lc+7kKq89mzZopPT1d69atc4xZu3at0tPTr9lrkRsid+7cqSVLlsjX19dpf0ntu2fPntq0aZPTn3kBAQF65plntGjRIkklt3cj//bTPbg+5H79z4wZM6ytW7da0dHRVrly5azU1NSiLs1Y//79LW9vb2vFihVWWlqa43Xq1CnHmLi4OMvb29v6/PPPrc2bN1vdu3fP92tCqlWrZi1ZssTasGGD1a5du2vu61Au5tynti2r5Pa9bt06y9XV1XrhhResnTt3Wh999JHl7u5u/e9//3OMKam99+7d26patarj638+//xzq2LFitawYcMcY0pK7ydOnLA2btxobdy40ZJkvfLKK9bGjRsdTycXVp8dOnSwwsPDrYSEBCshIcEKCwsr0q+CuVDfZ86cse666y6rWrVqVlJSktOfeZmZmY45imPflnXxn/n5zn9q27KKb++FjSCJq+att96yatSoYZUpU8Zq1KiR42tyiitJ+b4++OADx5icnBxr3Lhxlr+/v2W3261bb73V2rx5s9M8f//9t/XEE09YFSpUsNzc3KzOnTtbe/bs+Ze7uTLnB8mS3Pc333xjhYaGWna73apbt6717rvvOu0vqb1nZGRYQ4YMsapXr26VLVvWqlmzpjVq1CinEFFSel++fHm+/2337t3bsqzC6/PIkSNWjx49LE9PT8vT09Pq0aOHdezYsX+py7wu1PeuXbsK/DNv+fLljjmKY9+WdfGf+fnyC5LFtffCZrMsy/o3Vj4BAABQsvAZSQAAABghSAIAAMAIQRIAAABGCJIAAAAwQpAEAACAEYIkAAAAjBAkAQAAYIQgCQAAACMESQAAABghSAIAAMAIQRIAAABG/g9KKrsIPN4PLQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "pd.Series(predictions_KNN_text).value_counts().plot.barh(title='KNN_Predictions').invert_yaxis()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5d8ad020",
   "metadata": {},
   "source": [
    "##  Plot Total predictions, FP and FN for each class by model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "6344a886",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_confusion_bar(true_labels, predicted_labels, classes, color_mapping):\n",
    "    \"\"\"\n",
    "    Create a horizontal bar plot to visualize the counts of total predictions, false positives, and false negatives for each class.\n",
    "\n",
    "    Parameters:\n",
    "    - true_labels (list): List of true class labels.\n",
    "    - predicted_labels (list): List of predicted class labels.\n",
    "    - classes (list): List of unique class labels.\n",
    "    - color_mapping (dict): Dictionary mapping unique values to colors.\n",
    "\n",
    "    Returns:\n",
    "    None (displays the plot).\n",
    "\n",
    "    Example:\n",
    "    >>> true_labels = [1, 0, 1, 1, 0, 0, 1, 0, 1]\n",
    "    >>> predicted_labels = [1, 0, 1, 0, 1, 0, 1, 1, 0]\n",
    "    >>> classes = ['non-communicable', 'communicable', 'external', 'maternal', 'aids-tb']\n",
    "    >>> colors = sns.color_palette(\"Set2\", n_colors=len(df['gs_cod'].unique()))\n",
    "    >>> unique_cod = df['gs_cod'].unique()\n",
    "    >>> color_mapping = {value: colors[i] for i, value in enumerate(unique_cod)}\n",
    "    >>> plot_confusion_bar(true_labels, predicted_labels, classes, color_mapping)\n",
    "    \"\"\"\n",
    "    \n",
    "    # Calculate confusion matrix\n",
    "    cm = confusion_matrix(true_labels, predicted_labels, labels=classes)\n",
    "\n",
    "    # Calculate counts of false positives and false negatives\n",
    "    fp_counts = np.sum(cm, axis=0)\n",
    "    fn_counts = np.sum(cm, axis=1) - np.diag(cm)\n",
    "\n",
    "    # Get the total count of predictions for each class\n",
    "    total_counts = np.sum(cm, axis=1)\n",
    "\n",
    "    # Sort classes based on total predictions in descending order\n",
    "    sorted_indices = np.argsort(total_counts)[::-1]\n",
    "    sorted_classes = [classes[i] for i in sorted_indices]\n",
    "\n",
    "    # Create a horizontal bar plot\n",
    "    fig, ax = plt.subplots(figsize=(10, 6))\n",
    "    bar_width = 0.25\n",
    "    indices = np.arange(len(sorted_classes))\n",
    "\n",
    "    # Plot total predictions as \"Predictions\"\n",
    "    total_colors = [color_mapping[cls] for cls in sorted_classes]\n",
    "    ax.barh(indices, [total_counts[classes.index(cls)] for cls in sorted_classes], color=total_colors, label='Predictions', height=bar_width)\n",
    "\n",
    "#     # Plot false positives\n",
    "#     ax.barh(indices + bar_width, [fp_counts[classes.index(cls)] for cls in sorted_classes], \n",
    "#             color=sns.light_palette(\"grey\")[2], label='False Positives', height=bar_width)\n",
    "\n",
    "#     # Plot false negatives\n",
    "#     ax.barh(indices + 2 * bar_width, [fn_counts[classes.index(cls)] for cls in sorted_classes], \n",
    "#             color=sns.light_palette(\"grey\")[4], label='False Negatives', height=bar_width)\n",
    "\n",
    "    # Set labels, title, and legend\n",
    "    ax.set(yticks=indices + bar_width, yticklabels=sorted_classes, ylim=[-bar_width, len(sorted_classes) + 3 * bar_width - 1])\n",
    "    \n",
    "    # Move the legend to the lower right\n",
    "    ax.legend(loc='lower right')\n",
    "\n",
    "    ax.invert_yaxis()  # Invert the y-axis\n",
    "\n",
    "    plt.xlabel('Count')\n",
    "    plt.title('Predicted COD with False Positives and Negatives')\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "d811bf5d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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2267TU888YTL63Kpz8HzL/dNS0tTWFiYOnfunK2m48ePy9fXVwMHDnQuS01Ndb5nvLy8VKxYMfXv3z/b1Taff/65ateureDgYPn5+SkqKkrdu3e/5PkCbmaEVADII1n/WD1/1uzcuXO699571bhxY82bN08jR45UZmam2rZtq9GjR6tjx476+uuvNXr0aCUkJKhhw4bOWUNJeuyxx/T666+rS5cumjdvnu6//361b99ex44du2Q9ixcv1t13362UlBS9+eabWrhwoV544QUdOnRIkvToo4+qb9++kv4OVlmXhWZdzvjaa6+pQ4cOqlixombPnq1PP/1UJ0+e1N13361t27Y59zNlyhR169ZNFSpU0Jw5c/TCCy/o5Zdf1rfffnvJGpcvX660tDS1a9fu0idYf/+j093dXW3atMlxvcPh0L333qujR49q3bp1l9Vn0aJFVb16da1evVrp6em5tmvatKm+++47Z/g9dOiQtmzZIl9fXyUkJDjbLV26VEWKFFHlypVz7Oe9995T3bp1FR4e7nI57vkmTJighIQEjR8/XtOmTdOpU6fUsmVLnThx4rKOKTMzU+np6S4PSTp69Kgkafjw4fr66681efJkRUVFqWHDhpf8ruXAgQM1ceJEPfXUU1q0aJE+/fRTPfjggzpy5IizzfLly1W3bl0dP35c77//vubNm6eqVavq4Ycf1pQpUy6r9gsdO3ZMR44ccb6vpk+frrZt2yooKEgzZszQRx99pGPHjqlhw4b6/vvvndt17txZ8fHxevHFF7VkyRJNmjRJTZs2dan3QomJifL19VXLli2dr0tul3o+8sgj8vLyynZcGRkZ+uyzz9SmTRsVKlRIkvTZZ5/pnnvuUVBQkKZOnarZs2crNDRUsbGxLkH1amqWpN9++00FCxbU6NGjtWjRIk2YMEEeHh6qXbt2jpfaPvfcc9q7d68mTZqkDz74QDt37lSbNm2UkZHhbDNy5EgNGTJEzZo1U3x8vJ588kk99thjV3zpbr9+/VSsWDENHjz4ou22bdummjVrasuWLXrjjTe0YMECtWrVSk899ZRGjhzpbHfgwAE1aNBAO3bs0MSJE/XJJ5/o5MmT6tOnT7Y+d+3apZiYGE2cOFFLlizRiy++qB9//FH16tVzvo8v9Tl4Pk9PTz3yyCOaM2eOUlNTXdbNmDFDZ86cUbdu3ST9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bc0DBw7UsGHD1K5dO82fP18//vijkpKSVKVKlRxf10uNr2t9X1/I3d1dr732mrZu3aqpU6dmW3/kyBGlp6frnXfeyXaOWrZsKUkunzk5fR/9wmWZmZm65557NHfuXA0ePFjLli3T2rVrnWH3ct9LOenevbsSExO1fft2SX//YcLb29slKB86dEibN2/OdjyBgYEyxjiPp379+oqPj3f+UbB48eKqVKlStu96A7ca7u4LAFepQoUKzrv75ian2bxChQqpYMGCWrRoUY7bBAYGSvrfPyQPHjyoYsWKOdenp6df8jtqWd/f279//0Xb5Sbru3RffPHFRWdOzq/xQpcTBho1aiRPT0/Fx8fn+HuKF2rWrJmWLFmi+fPn61//+le29cYYffXVVwoNDVX16tUv2Z8k/frrr1q3bp0aNGhwyRnqJk2a6MUXX9TatWu1f/9+NWvWTIGBgapZs6YSEhL022+/6fbbb7+igHwjffbZZ2rYsKEmTpzosvzkyZOX3Nbf318jR47UyJEjdejQIeesaps2bbR9+3bnmHn22WfVvn37HPsoV67cJfdTuHDhXN9XWePtwIED2db99ttvcnNzU0hIiKS/x/D48eM1fvx4paSk6KuvvtLQoUN1+PDhXN97V8rd3V2dO3fW22+/rePHj2v69Ok6e/as83uJWXVI0jvvvJPr3YGzAtbV1vzZZ5+pS5cueu2111yW//HHHypQoMAVH9el3teX+/vH52vbtq3q1q2r4cOH64MPPnBZFxIS4jyXvXv3znH70qVLO2vLCv4X1nW+LVu2aNOmTZoyZYri4uKcy3O60dWV6tChgwYOHKgpU6bo1Vdfdf6kVdbYk/5+LX19ffXxxx/n2EfWuJD+Pjdt27bV2bNntWbNGo0aNUodO3ZUqVKlFBMTc831Av9EzKQCwA3WunVrHTlyRBkZGdlmu2rUqOH8h3zWHSWnTZvmsv3s2bMveVON22+/XWXKlNHHH3+ss2fP5toutxm62NhYeXh4aNeuXTnWmBUiypUrp4iICM2YMcPlktm9e/dq9erVlzwX4eHhevTRR7V48eJc7wi8a9cubd68WdLfNzkJCwvTs88+q8OHD2drO3bsWG3fvl2DBw+Wp6fnJff/119/6dFHH1V6evolb+wi/T1Dmp6ermHDhql48eIqX768c/nSpUv17bffXtYsqre39zXN5Fwth8PhfM2zbN68OduNmy6lSJEi6tq1qzp06KAdO3bo9OnTKleunMqWLatNmzblOmay/gBztcqVK6dixYpp+vTpLuPt1KlTmjNnjvOOvxcqUaKE+vTpo2bNmmn9+vUX3ceVvjbdunXTmTNnNGPGDE2ZMkUxMTHOcSH9fZl4gQIFtG3btlzPi5eX1zXVnNPr+vXXX1/1paN33XWXfHx8sn32rF69+rIvOc/JmDFjtG/fPr399tsuy/38/NSoUSNt2LBB0dHROZ6jrODcoEEDbdmyxeXmbZI0c+ZMl+dZfyC88Lz8+9//zlbXlV6pEBISonbt2umTTz7RggULdPDgwWx3423durV27dqlggUL5ng8OQV9b29vNWjQQGPGjJGkHO+kDtwqmEkFgBvsX//6l6ZNm6aWLVuqX79+qlWrljw9PbV//34tX75cbdu21X333acKFSrokUce0fjx4+Xp6ammTZtqy5Ytev3117NdQpyTCRMmqE2bNrrrrrs0YMAAlShRQikpKVq8eLHzH59Zd6B96623FBcXJ09PT5UrV06lSpXSSy+9pOeff17//e9/1bx5c4WEhOjQoUNau3atc1bNzc1NL7/8sh599FHdd999euyxx3T8+HGNGDHisi8LfPPNN/Xf//5XXbt21eLFi3XfffepSJEi+uOPP5SQkKDJkydr5syZio6OVoECBTR37ly1bt1a1atX16BBg1SlShWlpqZq1qxZmjZtmh5++GHnT0qcLyUlRWvWrFFmZqZOnDihDRs26OOPP9bevXv1xhtv6J577rlkrdWrV1dISIiWLFniMlvWtGlTvfzyy87/vpTKlStr7ty5mjhxoqpXry43N7dLzsrnhdatW+vll1/W8OHDnXdIfemll1S6dOlL/uGjdu3aat26taKjoxUSEqLk5GR9+umnLsHw3//+t1q0aKHY2Fh17dpVxYoV09GjR5WcnKz169fr888/v6b63dzcNHbsWHXq1EmtW7fWE088obNnz2rcuHE6fvy4Ro8eLUk6ceKEGjVqpI4dO6p8+fIKDAxUUlKSFi1alOssb5bKlStrxYoVmj9/viIiIhQYGHjRGeDy5csrJiZGo0aN0r59+7LNEgYEBOidd95RXFycjh49qgceeEBhYWH6/ffftWnTJv3++++aOHHiNdXcunVrTZkyReXLl1d0dLTWrVuncePGXfXl/iEhIXrmmWf0yiuv6NFHH9WDDz6offv2XdH7Oid169ZV27ZtNW/evGzr3nrrLdWrV0933323nnzySZUqVUonT57UL7/8ovnz5zvvFt6/f399/PHHatGihV566SUVKVJE06dPd156m/Vd5fLly6tMmTIaOnSojDEKDQ3V/PnzXe7EnSW3z8GL/VGle/fumjVrlvr06aPixYtne9/3799fc+bMUf369TVgwABFR0crMzNTKSkpWrJkiZ5++mnVrl1bL774ovbv368mTZqoePHiOn78uN566y15enqqQYMGV3eigZtB/t2zCQD+mbLu1nrhXRsvFBcXZ/z9/XNcl5aWZl5//XVTpUoV4+PjYwICAkz58uXNE0884XIX1rNnz5qnn37ahIWFGR8fH3PXXXeZxMREU7JkyUve3dcYYxITE02LFi1McHCw8fb2NmXKlMl2t+Bnn33WFC1a1Li5uWXrIz4+3jRq1MgEBQUZb29vU7JkSfPAAw+YpUuXuvQxadIkU7ZsWePl5WVuv/128/HHH+d459TcpKenm6lTp5rGjRub0NBQ4+HhYQoXLmxatGhhpk+fnu2usCkpKaZ3794mKirKeHl5meDgYFO/fn3z2Wefudxl2Jj/3TE36+Hu7m5CQkJM9erVTf/+/bPdJfRS7rvvPiPJTJs2zbns3Llzxt/f37i5uZljx465tM/p7r5Hjx41DzzwgClQoIBxOBwm63/HF7sTsS64225Ocrpr6vnOnj1rnnnmGVOsWDHj4+NjqlWrZuLj43N8rS7c39ChQ02NGjVMSEiI8fb2NlFRUWbAgAHmjz/+cNlu06ZN5qGHHjJhYWHG09PThIeHm8aNG5v333//orVn7bN3796XbBcfH29q165tfHx8jL+/v2nSpIn54YcfnOvPnDljevbsaaKjo01QUJDx9fU15cqVM8OHDzenTp1ytsvpuDdu3Gjq1q1r/Pz8XO5km9t7zBhjPvjgAyPJ+Pr6Zrs7bZaVK1eaVq1amdDQUOPp6WmKFStmWrVq5XytLrfmnBw7dsz06NHDhIWFGT8/P1OvXj2zatWqbHemzW18ZI27yZMnO5dlZmaaUaNGmcjISOPl5WWio6PN/Pnzs/WZm/Pv7nu+bdu2GXd391zr6N69uylWrJjx9PQ0hQsXNnXq1DGvvPKKS7stW7aYpk2bGh8fHxMaGmp69Ohhpk6daiSZTZs2ueyrWbNmJjAw0ISEhJgHH3zQpKSk5Pheyu1zMLfjzcjIMJGRkUaSef7553M8B3/++ad54YUXTLly5ZyfU5UrVzYDBgxw3gV+wYIFpkWLFqZYsWLGy8vLhIWFmZYtW5pVq1Zd6hQDNzWHMZdxS0MAAADAUo8//rhmzJihI0eO5Hj5NIB/Fi73BQAAwD/GSy+9pKJFiyoqKkp//vmnFixYoEmTJumFF14goAI3CUIqAAAA/jE8PT01btw47d+/X+np6SpbtqzefPNN9evXL79LA5BHuNwXAAAAAGANfoIGAAAAAGANQioAAAAAwBqEVAAAAACANbhxEq6rzMxM/fbbbwoMDJTD4cjvcgAAAADkE2OMTp48qaJFi8rNLff5UkIqrqvffvtNkZGR+V0GAAAAAEvs27dPxYsXz3U9IRXXVWBgoKS/B2JQUFA+VwMAAAAgv6SmpioyMtKZEXJDSMV1lXWJb1BQECEVAAAAwCW/BsiNkwAAAAAA1iCkAgAAAACsQUgFAAAAAFiDkAoAAAAAsAYhFQAAAABgDUIqAAAAAMAahFQAAAAAgDUIqQAAAAAAaxBSAQAAAADWIKQCAAAAAKxBSAUAAAAAWIOQCgAAAACwBiEVAAAAAGANQioAAAAAwBqEVAAAAACANQipAAAAAABreOR3Abg19Fs9W17+fvldBgAAAHDL+PfdHfO7hKvCTCoAAAAAwBqEVAAAAACANQipAAAAAABrEFIBAAAAANYgpAIAAAAArEFIBQAAAABYg5AKAAAAALAGIRUAAAAAYA1CKgAAAADAGoRUAAAAAIA1CKkAAAAAAGsQUgEAAAAA1iCkAgAAAACsQUgFAAAAAFiDkAoAAAAAsAYhFQAAAABgDUIqAAAAAMAahFQAAAAAgDUIqQAAAAAAaxBSAQAAAADWIKQCAAAAAKxBSAUAAAAAWIOQCgAAAACwBiEVAAAAAGANQioAAAAAwBqEVAAAAACANQipAAAAAABrEFIBAAAAANYgpAIAAAAArEFIBQAAAABYg5AKAAAAALAGIRUAAAAAYA1CKgAAAADAGoRUAAAAAIA1CKkAAAAAAGsQUgEAAAAA1iCkAgAAAACs4ZHfBeDW8FadhxQUFJTfZQAAAACwHDOpAAAAAABrEFIBAAAAANYgpAIAAAAArEFIBQAAAABYg5AKAAAAALAGIRUAAAAAYA1CKgAAAADAGoRUAAAAAIA1CKkAAAAAAGsQUgEAAAAA1iCkAgAAAACsQUgFAAAAAFiDkAoAAAAAsAYhFQAAAABgDUKqhVasWCGHw6Hjx4/nSX979uyRw+HQxo0bb9g+AQAAAOBqEFItVKdOHR04cEDBwcH5XQoAAAAA3FAe+V0AsvPy8lJ4eHh+lwEAAAAAN9wVzaQ2bNhQTz31lAYPHqzQ0FCFh4drxIgRzvUpKSlq27atAgICFBQUpIceekiHDh1yrh8xYoSqVq2qTz/9VKVKlVJwcLD+9a9/6eTJkxfd79mzZzV48GBFRkbK29tbZcuW1UcffeRcv3LlStWqVUve3t6KiIjQ0KFDlZ6e7lJ337591b9/f4WEhKhIkSL64IMPdOrUKXXr1k2BgYEqU6aMFi5c6Nwm6/LXxYsX684775Svr68aN26sw4cPa+HChapQoYKCgoLUoUMHnT592rldqVKlNH78eJf6q1at6nKeHA6HJk2apPvuu09+fn4qW7asvvrqq2z7Pv/S2x9++EENGjSQn5+fQkJCFBsbq2PHjkmSFi1apHr16qlAgQIqWLCgWrdurV27dmU7j9u3b1edOnXk4+OjO+64QytWrLjoeV+9erXq168vX19fRUZG6qmnntKpU6cuug0AAAAAXIsrvtx36tSp8vf3148//qixY8fqpZdeUkJCgowxateunY4ePaqVK1cqISFBu3bt0sMPP+yy/a5duxQfH68FCxZowYIFWrlypUaPHn3RfXbp0kUzZ87U22+/reTkZL3//vsKCAiQJP36669q2bKlatasqU2bNmnixIn66KOP9Morr2Sru1ChQlq7dq369u2rJ598Ug8++KDq1Kmj9evXKzY2Vp07d3YJnNLfwfrdd9/V6tWrtW/fPj300EMaP368pk+frq+//loJCQl65513rvQ0auTIkXrooYe0efNmtWzZUp06ddLRo0dzbLtx40Y1adJEd9xxhxITE/X999+rTZs2ysjIkCSdOnVKAwcOVFJSkpYtWyY3Nzfdd999yszMdOln0KBBevrpp7VhwwbVqVNH9957r44cOZLjPn/++WfFxsaqffv22rx5s2bNmqXvv/9effr0uehxnT17VqmpqS4PAAAAALhs5go0aNDA1KtXz2VZzZo1zZAhQ8ySJUuMu7u7SUlJca7bunWr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55835FwBAAAAgCR55HcBN7MXXnhBc+fO1cSJE1W2bFl99913euSRR1S4cGFNnTpVlStX1ttvv61+/fqpZ8+eKlKkiEaMGCE3NzfNmTNH999/v3bs2KGgoCD5+vpess8GDRo49z148GC9/vrrioqKcn6PdOrUqRo4cKB+/PFHJSYmqmvXrqpbt66aNWsmSXJzc9Pbb7+tUqVKaffu3erVq5cGDx6s995777KP+ezZszp79qzzeWpqah6cSQAAAAC3CofJmspDnjp16pQKFSqkb7/9VjExMc7ljz76qE6fPq3p06fr888/V+fOnTVw4EC99dZb2rBhg26//XZJf8+INmrUSMeOHXOGzMvpM2u7+Ph4tW3b1tmmYcOGysjI0KpVq5zLatWqpcaNG2v06NE5HsPnn3+uJ598Un/88Yekv2+c1L9//4t+T3bEiBEaOXJktuUnTpxQUFDQpU8cAAAAgJtSamqqgoODL5kNmEm9TrZt26YzZ844ZymznDt3Tnfeeack6cEHH9SXX36pUaNGaeLEic6Aei19ZqlRo0a27aOjo12eR0RE6PDhw87ny5cv12uvvaZt27YpNTVV6enpOnPmjE6dOiV/f/9LH7SkZ599VgMHDnQ+T01NVWRk5GVtCwAAAACE1OskMzNTkvT111+rWLFiLuu8vb0lSadPn9a6devk7u6unTt35kmfWXIKlZ6eni7PHQ6Hs8+9e/eqZcuW6tmzp15++WWFhobq+++/V48ePZSWlnbJ2s6v48JaAAAAAOByEVKvk4oVK8rb21spKSku3xU939NPPy03NzctXLhQLVu2VKtWrdS4cWNJkpeXlyQpIyPjivq8Wj/99JPS09P1xhtvyM3t7/tpzZ49O0/3AQAAAACXQki9TgIDA/XMM89owIAByszMVL169ZSamqrVq1crICBAhQoV0scff6zExERVq1ZNQ4cOVVxcnDZv3qyQkBCVLFlSDodDCxYsUMuWLeXr63vJPuPi4q663jJlyig9PV3vvPOO2rRpox9++EHvv/9+Hp4RAAAAALg0foLmOnr55Zf14osvatSoUapQoYJiY2M1f/58lSpVSj169NCIESNUrVo1SdLw4cNVtGhR9ezZU5JUrFgxjRw5UkOHDlWRIkXUp0+fi/ZZunTpa6q1atWqevPNNzVmzBhVqlRJ06ZN06hRo67tBAAAAADA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yiuvaOnSpdlmU7OcPHlSb731lt59913FxcVJksqUKaN69epJknPfBQsWVHh4eI59ZF2ePGXKFLVo0UKS9OGHHyohIUEfffSRBg0a5Gz76quvqkGDBpKkoUOHqlWrVjpz5ox8fHyUkpKiQYMGqXz58pKksmXLXuWZvHzMpAIAAADAeRYsWKCAgAD5+PgoJiZG9evX1zvvvCNJKlmypDMkStK6dev0559/qmDBggoICHA+du/erV27dkmSkpOTFRMT47KPC5+fLzk5WWfPnnUG46uxa9cupaWlqW7dus5lnp6eqlWrlpKTk13aRkdHO/87IiJCknT48GFJ0sCBA/Xoo4+qadOmGj16tPOYridmUgEAAADgPI0aNdLEiRPl6empokWLulzeeuEdfjMzMxUREaEVK1Zk66dAgQJXtX9fX9+r2u58WXf5dTgc2ZZfuOz848tal5mZKenvn8rp2LGjvv76ay1cuFDDhw/XzJkzdd99911zjblhJhUAAAAAzuPv76/bbrtNJUuWvOT3L6tVq6aDBw/Kw8NDt912m8ujUKFCkqQKFSpozZo1Lttd+Px8ZcuWla+vr5YtW5bjei8vL0lSRkZGrn3cdttt8vLy0vfff+9clpaWpp9++kkVKlS46DFd6Pbbb9eAAQO0ZMkStW/fXpMnT76i7a8UM6kAAAAAcJWaNm2qmJgYtWvXTmPGjFG5cuX022+/6ZtvvlG7du1Uo0YN9evXT3FxcapRo4bq1aunadOmaevWrYqKisqxTx8fHw0ZMkSDBw+Wl5eX6tatq99//11bt25Vjx49FBYWJl9fXy1atEjFixeXj49Ptp+f8ff315NPPqlBgwYpNDRUJUqU0NixY3X69Gn16NHjso7tr7/+0qBBg/TAAw+odOnS2r9/v5KSknT//fdf83m7GEIqAAAAgBvm33d3zO8S8pTD4dA333yj559/Xt27d9fvv/+u8PBw1a9f33k33ocffli7du3SkCFDdObMGd1///168skntXjx4lz7HTZsmDw8PPTiiy/qt99+U0REhHr27ClJ8vDw0Ntvv62XXnpJL774ou6+++4cLzcePXq0MjMz1blzZ508eVI1atTQ4sWLFRISclnH5u7uriNHjqhLly46dOiQChUqpPbt22vkyJFXfqKugMNkXawMXAepqakKDg7WiRMnFBQUlN/lAAAA4AY4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lCTGw60sr1778PBwHTp0KFv/v//+O+PjH4iQijzn5eWl6tWrKyEhwWV5QkKC6tSpk09V4XowxqhPnz6aO3euvv32W5UuXdplfenSpRUeHu4yFs6dO6eVK1c6x0L16tXl6enp0ubAgQPasmUL4+UfpkmTJvr555+1ceNG56NGjRrq1KmTNm7cqKioKMbDLaRu3brZfpLqP//5j0qWLCmJz4dbzenTp+Xm5vrPTnd3d+dP0DAebl159drHxMToxIkTWrt2rbPNjz/+qBMnTjA+/ony425NuPnNnDnTeHp6mo8++shs27bN9O/f3/j7+5s9e/bkd2nIQ08++aQJDg42K1asMAcOHHA+Tp8+7WwzevRoExwcbObOnWt+/vln06FDBxMREWFSU1OdbXr27GmKFy9uli5datavX28aN25sqlSpYtLT0/PjsJCHzr+7rzGMh1vJ2rVrjYeHh3n11VfNzp07zbRp04yfn5/57LPPnG0YD7eOuLg4U6xYMbNgwQKze/duM3fuXFOoUCEzePBgZxvGw83r5MmTZsOGDWbDhg1GknnzzTfNhg0bzN69e40xeffaN2/e3ERHR5vExESTmJhoKleubFq3bn3DjxfXjpCK62bChAmmZMmSxsvLy1SrVs35syS4eUjK8TF58mRnm8zMTDN8+HATHh5uvL29Tf369c3PP//s0s9ff/1l+vTpY0JDQ42vr69p3bq1SUlJucFHg+vhwpDKeLi1zJ8/31SqVMl4e3ub8uXLmw8++MBlPePh1pGammr69etnSpQoYXx8fExUVJR5/vnnzdmzZ51tGA83r+XLl+f474W4uDhjTN699keOHDGdOnUygYGBJjAw0HTq1MkcO3bsBh0l8pLDGGPyZw4XAAAAAABXfCcVAAAAAGANQioAAAAAwBqEVAAAAACANQipAAAAAABrEFIBAAAAANYgpAIAAAAArEFIBQAAAABYg5AKAAAAALAGIRUAAAAAYA1CKgAAyNXBgwfVt29fRUVFydvbW5GRkWrTpo2WLVt2Q+twOByKj4+/ofsEAOQPj/wuAAAA2GnPnj2qW7euChQooLFjxyo6OlppaWlavHixevfure3bt+d3iQCAm5DDGGPyuwgAAGCfli1bavPmzdqxY4f8/f1d1h0/flwFChRQSkqK+vbtq2XLlsnNzU3NmzfXO++8oyJFikiSunbtquPHj7vMgvbv318bN27UihUrJEkNGzZUdHS0fHx8NGnSJHl5ealnz54aMWKEJKlUqVLau3evc/uSJUtqz5491/PQAQD5iMt9AQBANkePHtWiRYvUu3fvbAFVkgoUKCBjjNq1a6ejR49q5cqVSkhI0K5du/Twww9f8f6mTp0qf39//fjjjxo7dqxeeuklJSQkSJKSkpIkSZMnT9aBAweczwEANycu9wUAANn88ssvMsaofPnyubZZunSpNm/erN27dysyMlKS9Omnn+qOO+5QUlKSatasedn7i46O1vDhwyVJZcuW1bvvvqtly5apWbNmKly4sKS/g3F4ePg1HBUA4J+AmVQAAJBN1reBHA5Hrm2Sk5MVGRnpDKiSVLFiRRUoUEDJyclXtL/o6GiX5xERETp8+PAV9QEAuDkQUgEAQDZly5aVw+G4aNg0xuQYYs9f7ubmpgtvf5GWlpZtG09PT5fnDodDmZmZV1M6AOAfjpAKAACyCQ0NVWxsrCZMmKBTp05lW3/8+HFVrFhRKSkp2rdvn3P5tm3bdOLECVWoUEGSVLhwYR04cMBl240bN15xPZ6ensrIyLji7QAA/zyEVAAAkKP33ntPGRkZqlWrlubMmaOdO3cqOTlZb7/9tmJiYtS0aVNFR0erU6dOWr9+vdauXasuXbqoQYMGqlGjhiSpcePG+umnn/TJJ59o586dGj58uLZs2XLFtZQqVUrLli3TwYMHdezYsbw+VACARQipAAAgR6VLl9b69evVqFEjPf3006pUqZKaNWumZcuWaeLEiXI4HIqPj1dISIjq16+vpk2bKioqSrNmzXL2ERsbq2HDhmnw4MGqWbOmTp48qS5dulxxLW+88YYSEhIUGRmpO++8My8PEwBgGX4nFQAAAABgDWZSAQAAAADWIKQCAAAAAKxBSAUAAAAAWIOQCgAAAACwBiEVAAAAAGANQioAAAAAwBqEVAAAAACANQipAAAAAABrEFIBAAAAANYgpAIAAAAArEFIBQAAAABY4/8Bv3sLzd1Rc8UAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# define labels for comparison\n",
    "true_labels = [Train_Y_mapping[embedding] for embedding in Test_Y]\n",
    "predicted_labels = predictions_NB_text\n",
    "classes = list(pd.Series(predictions_NB_text).unique())\n",
    "\n",
    "# Create a mapping between unique values in 'gs_cod' and colors\n",
    "colors = sns.color_palette(\"Set2\", n_colors=len(df['gs_cod'].unique()))\n",
    "unique_cod = df['gs_cod'].unique()\n",
    "color_mapping = {value: colors[i] for i, value in enumerate(unique_cod)}\n",
    "\n",
    "plot_confusion_bar(true_labels, predicted_labels, classes, color_mapping)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "59df9192",
   "metadata": {},
   "source": [
    "## Loop through models and plot on 1x3 grid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "d4731a6a",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "non-communicable    1508\n",
      "external             194\n",
      "aids-tb              154\n",
      "communicable         105\n",
      "maternal              68\n",
      "Name: count, dtype: int64\n"
     ]
    },
    {
     "data": {
      "image/png": "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goOD1bZtW7Vo0UIHDx7U1atXVaRIERUqVEi7d+9Od8yk/AHmfhUpUkS5cuXSrFmzHMbblStXNH/+fPsdf2+VJ08edevWTXXq1NGOHTtuu497fW3atWuna9euafbs2Zo2bZoiIiLs40L6+zLxLFmyaP/+/emeFzc3tweqOa3XdcmSJfd96egzzzwjDw+PVJ89mzZtuutLztMyevRonThxQh999JHDci8vL9WoUUM7d+5UeHh4mucoJThHRkZq7969Djdvk6Q5c+Y4PE/5A+Gt5+W///1vqrru9UqFgIAANW3aVF9++aUWL16sU6dOpbobb6NGjXT48GFlzZo1zeNJK+i7u7srMjJSo0ePlqQ076QOPCmYSQWAR+xf//qXZs6cqQYNGqhnz556+umn5erqqt9++01r165VkyZN9Pzzz6tYsWJ65ZVXNH78eLm6uqp27drau3ev3n///VSXEKdlwoQJaty4sZ555hn17t1befLk0fHjx7V8+XL7Pz5T7kD74YcfKioqSq6uripSpIjy5cunt99+W2+99Zb+97//qV69egoICNDp06e1detW+6yak5OT3nnnHXXs2FHPP/+8Xn31VV28eFHDhg2768sCP/jgA/3vf/9T27ZttXz5cj3//PMKDg7Wn3/+qZUrV2rq1KmaM2eOwsPDlSVLFi1YsECNGjVSuXLl1LdvX5UqVUrx8fGaO3euZs6cqebNm9t/UuJmx48f1+bNm5WcnKy4uDjt3LlTU6ZM0bFjxzRu3Dg9++yzd6y1XLlyCggI0IoVKxxmy2rXrq133nnH/t93UrJkSS1YsEATJ05UuXLl5OTkdMdZ+YzQqFEjvfPOOxo6dKj9Dqlvv/228ufPf8c/fFSsWFGNGjVSeHi4AgICFBsbqxkzZjgEw//+97+qX7++6tatq7Zt2ypXrlw6f/68YmNjtWPHDn399dcPVL+Tk5PGjBmjVq1aqVGjRnr99dd1/fp1jR07VhcvXtSoUaMkSXFxcapRo4ZatmypokWLytfXVzExMVq2bFm6s7wpSpYsqXXr1mnRokXKkSOHfH19bzsDXLRoUUVERGjkyJE6ceJEqllCHx8fffzxx4qKitL58+f14osvKigoSGfPntXu3bt19uxZTZw48YFqbtSokaZNm6aiRYsqPDxc27dv19ixY+/7cv+AgAC9+eabevfdd9WxY0e9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5ciRQwMGDFBiYqJD3d27d1evXr0UEBCg4OBgTZo0SVeuXFG7du3k6+urAgUKaOnSpfZtUi5/Xb58ucqUKSNPT0/VrFlTZ86c0dKlS1WsWDH5+fmpRYsWunr1qn27fPnyafz48Q71ly5d2uE82Ww2TZ48Wc8//7y8vLxUqFAhff/996n2ffOltxs3blRkZKS8vLwUEBCgunXr6sKFC5KkZcuWqUqVKsqSJYuyZs2qRo0a6fDhw6nO44EDB1SpUiV5eHjoqaee0rp162573jdt2qRq1arJ09NToaGh6tGjh65cuXLbbQAAAADgQdzz5b7Tp0+Xt7e3tmzZojFjxujtt9/WypUrZYxR06ZNdf78ea1fv14rV67U4cOH1bx5c4ftDx8+rIULF2rx4sVavHix1q9fr1GjRt12n23atNGcOXP00UcfKTY2Vp999pl8fHwkSb///rsaNGigChUqaPfu3Zo4caK++OILvfvuu6nqzpYtm7Zu3aru3burc+fOeumll1SpUiXt2LFDdevWVevWrR0Cp/R3sP7kk0+0adMmnThxQi+//LLGjx+vWbNmacmSJVq5cqU+/vjjez2NGj58uF5++WXt2bNHDRo0UKtWrXT+/Pk02+7atUu1atXSU089pejoaP30009q3LixkpKSJElXrlxRnz59FBMTo9WrV8vJyUnPP/+8kpOTHfrp27ev3njjDe3cuVOVKlXSc889p3PnzqW5z59//ll169ZVs2bNtGfPHs2dO1c//fSTunXrdtvjun79uuLj4x0eAAAAAHDXzD2IjIw0VapUcVhWoUIF079/f7NixQrj7Oxsjh8/bl+3b98+I8ls3brVGGPM0KFDjZeXl4mPj7e36du3r6lYsWK6+zx48KCRZFauXJnm+n//+9+mSJEiJjk52b5swoQJxsfHxyQlJaVZd2JiovH29jatW7e2Lzt58qSRZKKjo40xxqxdu9ZIMqtWrbK3GTlypJFkDh8+bF/2+uuvm7p169qf582b1/znP/9xqLFUqVJm6NCh9ueSzKBBg+zPL1++bGw2m1m6dKnDvi9cuGCMMaZFixamcuXK6Z6jW505c8ZIMj///LMxxpgjR44YSWbUqFH2NgkJCSZ37txm9OjRae6zdevW5rXXXnPod8OGDcbJycn89ddf6e576NChRlKqR1xc3F3XDwAAAOCfJy4u7q6y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",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "non-communicable    1932\n",
      "external              92\n",
      "maternal               5\n",
      "Name: count, dtype: int64\n"
     ]
    },
    {
     "data": {
      "image/png": "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2267TU888YTL63Kpz8HzL/dNS0tTWFiYOnfunK2m48ePy9fXVwMHDnQuS01Ndb5nvLy8VKxYMfXv3z/b1Taff/65ateureDgYPn5+SkqKkrdu3e/5PkCbmaEVADII1n/WD1/1uzcuXO699571bhxY82bN08jR45UZmam2rZtq9GjR6tjx476+uuvNXr0aCUkJKhhw4bOWUNJeuyxx/T666+rS5cumjdvnu6//361b99ex44du2Q9ixcv1t13362UlBS9+eabWrhwoV544QUdOnRIkvToo4+qb9++kv4OVlmXhWZdzvjaa6+pQ4cOqlixombPnq1PP/1UJ0+e1N13361t27Y59zNlyhR169ZNFSpU0Jw5c/TCCy/o5Zdf1rfffnvJGpcvX660tDS1a9fu0idYf/+j093dXW3atMlxvcPh0L333qujR49q3bp1l9Vn0aJFVb16da1evVrp6em5tmvatKm+++47Z/g9dOiQtmzZIl9fXyUkJDjbLV26VEWKFFHlypVz7Oe9995T3bp1FR4e7nI57vkmTJighIQEjR8/XtOmTdOpU6fUsmVLnThx4rKOKTMzU+np6S4PSTp69Kgkafjw4fr66681efJkRUVFqWHDhpf8ruXAgQM1ceJEPfXUU1q0aJE+/fRTPfjggzpy5IizzfLly1W3bl0dP35c77//vubNm6eqVavq4Ycf1pQpUy6r9gsdO3ZMR44ccb6vpk+frrZt2yooKEgzZszQRx99pGPHjqlhw4b6/vvvndt17txZ8fHxevHFF7VkyRJNmjRJTZs2dan3QomJifL19VXLli2dr0tul3o+8sgj8vLyynZcGRkZ+uyzz9SmTRsVKlRIkvTZZ5/pnnvuUVBQkKZOnarZs2crNDRUsbGxLkH1amqWpN9++00FCxbU6NGjtWjRIk2YMEEeHh6qXbt2jpfaPvfcc9q7d68mTZqkDz74QDt37lSbNm2UkZHhbDNy5EgNGTJEzZo1U3x8vJ588kk99thjV3zpbr9+/VSsWDENHjz4ou22bdummjVrasuWLXrjjTe0YMECtWrVSk899ZRGjhzpbHfgwAE1aNBAO3bs0MSJE/XJJ5/o5MmT6tOnT7Y+d+3apZiYGE2cOFFLlizRiy++qB9//FH16tVzvo8v9Tl4Pk9PTz3yyCOaM2eOUlNTXdbNmDFDZ86cUbdu3ST9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bc0DBw7UsGHD1K5dO82fP18//vijkpKSVKVKlRxf10uNr2t9X1/I3d1dr732mrZu3aqpU6dmW3/kyBGlp6frnXfeyXaOWrZsKUkunzk5fR/9wmWZmZm65557NHfuXA0ePFjLli3T2rVrnWH3ct9LOenevbsSExO1fft2SX//YcLb29slKB86dEibN2/OdjyBgYEyxjiPp379+oqPj3f+UbB48eKqVKlStu96A7ca7u4LAFepQoUKzrv75ian2bxChQqpYMGCWrRoUY7bBAYGSvrfPyQPHjyoYsWKOdenp6df8jtqWd/f279//0Xb5Sbru3RffPHFRWdOzq/xQpcTBho1aiRPT0/Fx8fn+HuKF2rWrJmWLFmi+fPn61//+le29cYYffXVVwoNDVX16tUv2Z8k/frrr1q3bp0aNGhwyRnqJk2a6MUXX9TatWu1f/9+NWvWTIGBgapZs6YSEhL022+/6fbbb7+igHwjffbZZ2rYsKEmTpzosvzkyZOX3Nbf318jR47UyJEjdejQIeesaps2bbR9+3bnmHn22WfVvn37HPsoV67cJfdTuHDhXN9XWePtwIED2db99ttvcnNzU0hIiKS/x/D48eM1fvx4paSk6KuvvtLQoUN1+PDhXN97V8rd3V2dO3fW22+/rePHj2v69Ok6e/as83uJWXVI0jvvvJPr3YGzAtbV1vzZZ5+pS5cueu2111yW//HHHypQoMAVH9el3teX+/vH52vbtq3q1q2r4cOH64MPPnBZFxIS4jyXvXv3znH70qVLO2vLCv4X1nW+LVu2aNOmTZoyZYri4uKcy3O60dWV6tChgwYOHKgpU6bo1Vdfdf6kVdbYk/5+LX19ffXxxx/n2EfWuJD+Pjdt27bV2bNntWbNGo0aNUodO3ZUqVKlFBMTc831Av9EzKQCwA3WunVrHTlyRBkZGdlmu2rUqOH8h3zWHSWnTZvmsv3s2bMveVON22+/XWXKlNHHH3+ss2fP5toutxm62NhYeXh4aNeuXTnWmBUiypUrp4iICM2YMcPlktm9e/dq9erVlzwX4eHhevTRR7V48eJc7wi8a9cubd68WdLfNzkJCwvTs88+q8OHD2drO3bsWG3fvl2DBw+Wp6fnJff/119/6dFHH1V6evolb+wi/T1Dmp6ermHDhql48eIqX768c/nSpUv17bffXtYsqre39zXN5Fwth8PhfM2zbN68OduNmy6lSJEi6tq1qzp06KAdO3bo9OnTKleunMqWLatNmzblOmay/gBztcqVK6dixYpp+vTpLuPt1KlTmjNnjvOOvxcqUaKE+vTpo2bNmmn9+vUX3ceVvjbdunXTmTNnNGPGDE2ZMkUxMTHOcSH9fZl4gQIFtG3btlzPi5eX1zXVnNPr+vXXX1/1paN33XWXfHx8sn32rF69+rIvOc/JmDFjtG/fPr399tsuy/38/NSoUSNt2LBB0dHROZ6jrODcoEEDbdmyxeXmbZI0c+ZMl+dZfyC88Lz8+9//zlbXlV6pEBISonbt2umTTz7RggULdPDgwWx3423durV27dqlggUL5ng8OQV9b29vNWjQQGPGjJGkHO+kDtwqmEkFgBvsX//6l6ZNm6aWLVuqX79+qlWrljw9PbV//34tX75cbdu21X333acKFSrokUce0fjx4+Xp6ammTZtqy5Ytev3117NdQpyTCRMmqE2bNrrrrrs0YMAAlShRQikpKVq8eLHzH59Zd6B96623FBcXJ09PT5UrV06lSpXSSy+9pOeff17//e9/1bx5c4WEhOjQoUNau3atc1bNzc1NL7/8sh599FHdd999euyxx3T8+HGNGDHisi8LfPPNN/Xf//5XXbt21eLFi3XfffepSJEi+uOPP5SQkKDJkydr5syZio6OVoECBTR37ly1bt1a1atX16BBg1SlShWlpqZq1qxZmjZtmh5++GHnT0qcLyUlRWvWrFFmZqZOnDihDRs26OOPP9bevXv1xhtv6J577rlkrdWrV1dISIiWLFniMlvWtGlTvfzyy87/vpTKlStr7ty5mjhxoqpXry43N7dLzsrnhdatW+vll1/W8OHDnXdIfemll1S6dOlL/uGjdu3aat26taKjoxUSEqLk5GR9+umnLsHw3//+t1q0aKHY2Fh17dpVxYoV09GjR5WcnKz169fr888/v6b63dzcNHbsWHXq1EmtW7fWE088obNnz2rcuHE6fvy4Ro8eLUk6ceKEGjVqpI4dO6p8+fIKDAxUUlKSFi1alOssb5bKlStrxYoVmj9/viIiIhQYGHjRGeDy5csrJiZGo0aN0r59+7LNEgYEBOidd95RXFycjh49qgceeEBhYWH6/ffftWnTJv3++++aOHHiNdXcunVrTZkyReXLl1d0dLTWrVuncePG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ALAGIRUAAAAAYA1CKgAAAADAGoRUAAAAAIA1CKkAAAAAAGsQUgEAAAAA1iCkAgAAAACsQUgFAAAAAFiDkAoAAAAAsAYhFQAAAABgDUKqhVasWCGHw6Hjx4/nSX979uyRw+HQxo0bb9g+AQAAAOBqEFItVKdOHR04cEDBwcH5XQoAAAAA3FAe+V0AsvPy8lJ4eHh+lwEAAAAAN9wVzaQ2bNhQTz31lAYPHqzQ0FCFh4drxIgRzvUpKSlq27atAgICFBQUpIceekiHDh1yrh8xYoSqVq2qTz/9VKVKlVJwcLD+9a9/6eTJkxfd79mzZzV48GBFRkbK29tbZcuW1UcffeRcv3LlStWqVUve3t6KiIjQ0KFDlZ6e7lJ337591b9/f4WEhKhIkSL64IMPdOrUKXXr1k2BgYEqU6aMFi5c6Nwm6/LXxYsX684775Svr68aN26sw4cPa+HChapQoYKCgoLUoUMHnT592rldqVKlNH78eJf6q1at6nKeHA6HJk2apPvuu09+fn4qW7asvvrqq2z7Pv/S2x9++EENGjSQn5+fQkJCFBsbq2PHjkmSFi1apHr16qlAgQIqWLCgWrdurV27dmU7j9u3b1edOnXk4+OjO+64QytWrLjoeV+9erXq168vX19fRUZG6qmnntKpU6cuug0AAAAAXIsrvtx36tSp8vf3148//qixY8fqpZdeUkJCgowxateunY4ePaqVK1cqISFBu3bt0sMPP+yy/a5duxQfH68FCxZowYIFWrlypUaPHn3RfXbp0kUzZ87U22+/reTkZL3//vsKCAiQJP36669q2bKlatasqU2bNmnixIn66KOP9Morr2Sru1ChQlq7dq369u2rJ598Ug8++KDq1Kmj9evXKzY2Vp07d3YJnNLfwfrdd9/V6tWrtW/fPj300EMaP368pk+frq+//loJCQl65513rvQ0auTIkXrooYe0efNmtWzZUp06ddLRo0dzbLtx40Y1adJEd9xxhxITE/X999+rTZs2ysjIkCSdOnVKAwcOVFJSkpYtWyY3Nzfdd999yszMdOln0KBBevrpp7VhwwbVqVNH9957r44cOZLjPn/++WfFxsaqffv22rx5s2bNmqXvv/9effr0uehxnT17VqmpqS4PAAAAALhs5go0aNDA1KtXz2VZzZo1zZAhQ8ySJUuMu7u7SUlJca7bunWr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55835FwBAAAAgCR55HcBN7MXXnhBc+fO1cSJE1W2bFl99913euSRR1S4cGFNnTpVlStX1ttvv61+/fqpZ8+eKlKkiEaMGCE3NzfNmTNH999/v3bs2KGgoCD5+vpess8GDRo49z148GC9/vrrioqKcn6PdOrUqRo4cKB+/PFHJSYmqmvXrqpbt66aNWsmSXJzc9Pbb7+tUqVKaffu3erVq5cGDx6s995777KP+ezZszp79qzzeWpqah6cSQAAAAC3CofJmspDnjp16pQKFSqkb7/9VjExMc7ljz76qE6fPq3p06fr888/V+fOnTVw4EC99dZb2rBhg26//XZJf8+INmrUSMeOHXOGzMvpM2u7+Ph4tW3b1tmmYcOGysjI0KpVq5zLatWqpcaNG2v06NE5HsPnn3+uJ598Un/88Yekv2+c1L9//4t+T3bEiBEaOXJktuUnTpxQUFDQpU8cAAAAgJtSamqqgoODL5kNmEm9TrZt26YzZ844ZymznDt3Tnfeeack6cEHH9SXX36pUaNGaeLEic6Aei19ZqlRo0a27aOjo12eR0RE6PDhw87ny5cv12uvvaZt27YpNTVV6enpOnPmjE6dOiV/f/9LH7SkZ599VgMHDnQ+T01NVWRk5GVtCwAAAACE1OskMzNTkvT111+rWLFiLuu8vb0lSadPn9a6devk7u6unTt35kmfWXIKlZ6eni7PHQ6Hs8+9e/eqZcuW6tmzp15++WWFhobq+++/V48ePZSWlnbJ2s6v48JaAAAAAOByEVKvk4oVK8rb21spKSku3xU939NPPy03NzctXLhQLVu2VKtWrdS4cWNJkpeXlyQpIyPjivq8Wj/99JPS09P1xhtvyM3t7/tpzZ49O0/3AQAAAACXQki9TgIDA/XMM89owIAByszMVL169ZSamqrVq1crICBAhQoV0scff6zExERVq1ZNQ4cOVVxcnDZv3qyQkBCVLFlSDodDCxYsUMuWLeXr63vJPuPi4q663jJlyig9PV3vvPOO2rRpox9++EHvv/9+Hp4RAAAAALg0foLmOnr55Zf14osvatSoUapQoYJiY2M1f/58lSpVSj169NCIESNUrVo1SdLw4cNVtGhR9ezZU5JUrFgxjRw5UkOHDlWRIkXUp0+fi/ZZunTpa6q1atWqevPNNzVmzBhVqlRJ06ZN06hRo67tBAAAAADAFeLuvriuLvcOXgAAAABubpebDZhJBQAAAABYg5AKAAAAALAGIRUAAAAAYA1CKgAAAADAGoRUAAAAAIA1CKkAAAAAAGsQUgEAAAAA1iCkAgAAAACsQUgFAAAAAFiDkAoAAAAAsAYhFQAAAABgDUIqAAAAAMAahFQAAAAAgDUIqQAAAAAAaxBSAQAAAADWIKQCAAAAAKxBSAUAAAAAWIOQCgAAAACwBiEVAAAAAGANQioAAAAAwBqEVAAAAACANQipAAAAAABrEFIBAAAAANYgpAIAAAAArEFIBQAAAABYg5AKAAAAALAGIRUAAAAAYA1CKgAAAADAGoRUAAAAAIA1CKkAAAAAAGsQUgEAAAAA1iCkAgAAAACsQUgFAAAAAFiDkAoAAAAAsAYhFQAAAABgDUIqAAAAAMAahFQAAAAAgDUIqQAAAAAAaxBSAQAAAADWIKQCAAAAAKxBSAUAAAAAWIOQCgAAAACwBiEVAAAAAGANQioAAAAAwBqEVAAAAACANQipAAAAAABrEFIBAAAAANYgpAIAAAAArEFIBQAAAABYg5AKAAAAALAGIRUAAAAAYA1CKgAAAADAGoRUAAAAAIA1CKkAAAAAAGsQUgEAAAAA1iCkAgAAAACsQUgFAAAAAFiDkAoAAAAAsAYhFQAAAABgDUIqAAAAAMAahFQAAAAAgDUIqQAAAAAAaxBSAQAAAADWIKQCAAAAAKxBSAUAAAAAWIOQCgAAAACwBiEVAAAAAGANQioAAAAAwBqEVAAAAACANQipAAAAAABrEFIBAAAAANYgpAIAAAAArEFIBQAAAABYg5AKAAAAALAGIRUAAAAAYA1CKgAAAADAGoRUAAAAAIA1CKkAAAAAAGsQUgEAAAAA1iCkAgAAAACsQUgFAAAAAFiDkAoAAAAAsAYhFQAAAABgDUIqAAAAAMAahFQAAAAAgDUIqQAAAAAAaxBSAQAAAADWIKQCAAAAAKxBSAUAAAAAWMMjvwvAreHQW4k67eOf32X8o4UPqpffJQAAAADXHTOpAAAAAABrEFIBAAAAANYgpAIAAAAArEFIBQAAAABYg5AKAAAAALAGIRUAAAAAYA1CKgAAAADAGoRUAAAAAIA1CKkAAAAAAGsQUgEAAAAA1iCkAgAAAACsQUgFAAAAAFiDkAoAAAAAsAYhFQAAAABgDUIqAAAAAMAahFQAAAAAgDUIqQAAAAAAaxBSAQAAAADWIKQCAAAAAKxBSAUAAAAAWIOQCgAAAACwBiEVAAAAAGANQioAAAAAwBqEVAAAAACANQipAAAAAABrEFIBAAAAANYgpAIAAAAArEFIBQAAAABYg5AKAAAAALAGIRUAAAAAYA1CKgAAAADAGoRUAAAAAIA1CKkAAAAAAGsQUgEAAAAA1iCkAgAAAACsQUgFAAAAAFiDkAoAAAAAsIZHfheAW0ORfjEKCgrK7zIAAAAAWI6ZVAAAAACANQipAAAAAABrEFIBAAAAANYgpAIAAAAArEFIBQAAAABYg5AKAAAAALAGIRUAAAAAYA1CKgAAAADAGoRUAAAAAIA1CKkAAAAAAGsQUgEAAAAA1iCkAgAAAACsQUgFAAAAAFiDkAoAAAAAsAYhFZetYcOG6t+/f36XAQAAAOAmRki1VNeuXdWuXbv8LgMAAAAAbihC6k3u3Llz+V0CAAAAAFw2QmoeaNiwofr27av+/fsrJCRERYoU0QcffKBTp06pW7duCgwMVJkyZbRw4UJJUkZGhnr06KHSpUvL19dX5cqV01tvveXsb8SIEZo6darmzZsnh8Mhh8OhFStWSJJ+/fVXPfzwwwoJCVHBggXVtm1b7dmzx7lt1gzsqFGjVLRoUd1+++3as2ePHA6H5s6dq0aNGsnPz09VqlRRYmKic7sjR46oQ4cOKl68uPz8/FS5cmXNmDHjhpw/AAAAAMhCSM0jU6dOVaFChbR27Vr17dtXTz75pB588EHVqVNH69evV2xsrDp37qzTp08rMzNTxYsX1+zZs7Vt2za9+OKLeu655zR79mxJ0jPPPKOHHnpIzZs314EDB3TgwAHVqVNHp0+fVqNGjRQQEKDvvvtO33//vQICAtS8eXOXGdNly5YpOTlZCQkJWrBggXP5888/r2eeeUYbN27U7bffrg4dOig9PV2SdObMGVWvXl0LFizQli1b9Pjjj6tz58768ccfr+g8nD17VqmpqS4PAAAAALhcDmOMye8i/ukaNmyojIwMrVq1StLfM6XBwcFq3769PvnkE0nSwYMHFRERocTERN11113Z+ujdu7cOHTqkL774QtLfM6LHjx9XfHy8s83HH3+ssWPHKjk5WQ6HQ9Lfl/MWKFBA8fHxuueee9S1a1ctWrRIKSkp8vLykiTt2bNHpUuX1qRJk9SjRw9J0rZt23THHXcoOTlZ5cuXz/G4WrVqpQoVKuj11193HmfVqlU1fvz4XM/FiBEjNHLkyGzLT5w4oaCgoIudRgAAAAA3sdTUVAUHB18yGzCTmkeio6Od/+3u7q6CBQuqcuXKzmVFihSRJB0+fFiS9P7776tGjRoqXLiwAgIC9OGHHyolJeWi+1i3bp1++eUXBQYGKiAgQAEBAQoNDdWZM2e0a9cuZ7vKlSs7A2puNUZERLjUk5GRoVdffVXR0dEqWLCgAgICtGTJkkvWdKFnn31WJ06ccD727dt3RdsDAAAAuLV55HcBNwtPT0+X5w6Hw2VZ1sxnZmamZs+erQEDBuiNN95QTEyMAgMDNW7cuEteWpuZmanq1atr2rRp2dYVLlzY+d/+/v6XrPH8eiTpjTfe0P/93/9p/Pjxqly5svz9/dW/f/8rvvGSt7e3vL29r2gbAAAAAMhCSM0Hq1atUp06ddSrVy/nsvNnQiXJy8tLGRkZLsuqVaumWbNmKSwsLM8vnV21apXatm2rRx55RNLf4XXnzp2qUKFCnu4HAAAAAC6Gy33zwW233aaffvpJixcv1n/+8x8NGzZMSUlJLm1KlSqlzZs3a8eOHfrjjz+UlpamTp06qVChQmrbtq1WrVql3bt3a+XKlerXr5/2799/zTUlJCRo9erVSk5O1hNPPKGDBw9eU58AAAAAcKUIqfmgZ8+eat++vR5++GHVrl1bR44ccZlVlaTHHntM5cqVc35v9YcffpCfn5++++47lShRQu3bt1eFChXUvXt3/fXXX9c8szps2DBVq1ZNsbGxatiwocLDw9WuXbtr6hMAAAAArhR398V1dbl38AIAAABwc+PuvgAAAACAfxxCKgAAAADAGoRUAAAAAIA1CKkAAAAAAGsQUgEAAAAA1iCkAgAAAACsQUgFAAAAAFiDkAoAAAAAsAYhFQAAAABgDUIqAAAAAMAahFQAAAAAgDUIqQAAAAAAaxBSAQAAAADWIKQCAAAAAKxBSAUAAAAAWIOQCgAAAACwBiEVAAAAAGANQioAAAAAwBqEVAAAAACANQipAAAAAABrEFIBAAAAANYgpAIAAAAArEFIBQAAAABYg5AKAAAAALAGIRUAAAAAYA1CKgAAAADAGoRUAAAAAIA1CKkAAAAAAGsQUgEAAAAA1iCkAgAAAACsQUgFAAAAAFiDkAoAAAAAsAYhFQAAAABgDUIqAAAAAMAahFQAAAAAgDUIqQAAAAAAaxBSAQAAAADW8MjvAgAAAADcnIwxSk9PV0ZGRn6XghvA3d1dHh4ecjgc19QPIRUAAABAnjt37pwOHDig06dP53cpuIH8/PwUEREhLy+vq+6DkAoAAAAgT2VmZmr37t1yd3dX0aJF5eXldc2za7CbMUbnzp3T77//rt27d6ts2bJyc7u6b5cSUgEAAADkqXPnzikzM1ORkZHy8/PL73Jwg/j6+srT01N79+7VuXPn5OPjc1X9cOMkAAAAANfF1c6k4Z8rL15zRg0AAAAAwBqEVAAAAACANQipAAAAAHCDjRgxQlWrVnU+79q1q9q1a3dNfeZFHzbgxkkAAAAAbpgnVk2/ofv7990dr6h9165dNXXqVEmSh4eHIiMj1b59e40cOVL+/v7Xo0RJ0ltvvSVjzGW13bNnj0qXLq0NGza4BN0r6cNmhFQAAAAAOE/z5s01efJkpaWladWqVXr00Ud16tQpTZw40aVdWlqaPD0982SfwcHBVvRhAy73BQAAAIDzeHt7Kzw8XJGRkerYsaM6deqk+Ph45yW6H3/8saKiouTt7S1jjE6cOKHHH39cYWFhCgoKUuPGjbVp0yaXPkePHq0iRYooMDBQPXr00JkzZ1zWX3ipbmZmpsaMGaPbbrtN3t7eKlGihF599VVJUunSpSVJd955pxwOhxo2bJhjH2fPntVTTz2lsLAw+fj4qF69ekpKSnKuX7FihRwOh5YtW6YaNWrIz89PderU0Y4dO5xtNm3apEaNGikwMFBBQUGqXr26fvrpp7w4zbkipAIAAADARfj6+iotLU2S9Msvv2j27NmaM2eONm7cKElq1aqVDh48qG+++Ubr1q1TtWrV1KRJEx09elSSNHv2bA0fPlyvvvqqfvrpJ0VEROi999676D6fffZZjRkzRsOGDdO2bds0ffp0FSlSRJK0du1aSdLSpUt14MABzZ07N8c+Bg8erDlz5mjq1Klav369brvtNsXGxjrryvL888/rjTfe0E8//SQPDw91797dua5Tp04qXry4kpKStG7dOg0dOjTPZo9zw+W+AAAAAJCLtWvXavr06WrSpIkk6dy5c/r0009VuHBhSdK3336rn3/+WYcPH5a3t7ck6fXXX1d8fLy++OILPf744xo/fry6d++uRx99VJL0yiuvaOnSpdlmU7OcPHlSb731lt59913FxcVJksqUKaN69epJknPfBQsWVHh4eI59ZF2ePGXKFLVo0UKS9OGHHyohIUEfffSRBg0a5Gz76quvqkGDBpKkoUOHqlWrVjpz5ox8fHyUkpKiQYMGqXz58pKksmXLXuWZvHzMpAIAAADAeRYsWKCAgAD5+PgoJiZG9evX1zvvvCNJKlmypDMkStK6dev0559/qmDBggoICHA+du/erV27dkmSkpOTFRMT47KPC5+fLzk5WWfPnnUG46uxa9cupaWlqW7dus5lnp6eqlWrlpKTk13aRkdHO/87IiJCknT48GFJ0sCBA/Xoo4+qadOmGj16tPOYridmUgEAAADgPI0aNdLEiRPl6empokWLulzeeuEdfjMzMxUREaEVK1Zk66dAgQJXtX9fX9+r2u58WXf5dTgc2ZZfuOz848tal5mZKenvn8rp2LGjvv76ay1cuFDDhw/XzJkzdd99911zjblhJhUAAAAAzuPv76/bbrtNJUuWvOT3L6tVq6aDBw/Kw8NDt912m8ujUKFCkqQKFSpozZo1Lttd+Px8ZcuWla+vr5YtW5bjei8vL0lSRkZGrn3cdttt8vLy0vfff+9clpaWpp9++kkVKlS46DFd6Pbbb9eAAQO0ZMkStW/fXpMnT76i7a8UM6kAAAAAcJWaNm2qmJgYtWvXTmPGjFG5cuX022+/6ZtvvlG7du1Uo0YN9evXT3FxcapRo4bq1aunadOmaevWrYqKisqxTx8fHw0ZMkSDBw+Wl5eX6tatq99//11bt25Vjx49FBYWJl9fXy1atEjFixeXj49Ptp+f8ff315NPPqlBgwYpNDRUJUqU0NixY3X69Gn16NHjso7tr7/+0qBBg/TAAw+odOnS2r9/v5KSknT//fdf83m7GEIqAAAAgBvm33d3zO8S8pTD4dA333yj559/Xt27d9fvv/+u8PBw1a9f33k33ocffli7du3SkCFDdObMGd1///168skntXjx4lz7HTZsmDw8PPTiiy/qt99+U0REhHr27ClJ8vDw0Ntvv62XXnpJL774ou6+++4cLzcePXq0MjMz1blzZ508eVI1atTQ4sWLFRISclnH5u7uriNHjqhLly46dOiQChUqpPbt22vkyJFXfqKugMNkXawMXAepqakKDg7WiRMnFBQUlN/lAAAA4AY4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lCTGw60sr1778PBwHTp0KFv/v//+O+PjH4iQijzn5eWl6tWrKyEhwWV5QkKC6tSpk09V4XowxqhPnz6aO3euvv32W5UuXdplfenSpRUeHu4yFs6dO6eVK1c6x0L16tXl6enp0ubAgQPasmUL4+UfpkmTJvr555+1ceNG56NGjRrq1KmTNm7cqKioKMbDLaRu3brZfpLqP//5j0qWLCmJz4dbzenTp+Xm5vrPTnd3d+dP0DAebl159drHxMToxIkTWrt2rbPNjz/+qBMnTjA+/ony425NuPnNnDnTeHp6mo8++shs27bN9O/f3/j7+5s9e/bkd2nIQ08++aQJDg42K1asMAcOHHA+Tp8+7WwzevRoExwcbObOnWt+/vln06FDBxMREWFSU1OdbXr27GmKFy9uli5datavX28aN25sqlSpYtLT0/PjsJCHzr+7rzGMh1vJ2rVrjYeHh3n11VfNzp07zbRp04yfn5/57LPPnG0YD7eOuLg4U6xYMbNgwQKze/duM3fuXFOoUCEzePBgZxvGw83r5MmTZsOGDWbDhg1GknnzzTfNhg0bzN69e40xeffaN2/e3ERHR5vExESTmJhoKleubFq3bn3DjxfXjpCK62bChAmmZMmSxsvLy1SrVs35syS4eUjK8TF58mRnm8zMTDN8+HATHh5uvL29Tf369c3PP//s0s9ff/1l+vTpY0JDQ42vr69p3bq1SUlJucFHg+vhwpDKeLi1zJ8/31SqVMl4e3ub8uXLmw8++MBlPePh1pGammr69etnSpQoYXx8fExUVJR5/vnnzdmzZ51tGA83r+XLl+f474W4uDhjTN699keOHDGdOnUygYGBJjAw0HTq1MkcO3bsBh0l8pLDGGPyZw4XAAAAAABXfCcVAAAAAGANQioAAAAAwBqEVAAAAACANQipAAAAAABrEFIBAAAAANYgpAIAAAAArEFIBQAAAABYg5AKAAAAALAGIRUAAAAAYA1CKgAAyNXBgwfVt29fRUVFydvbW5GRkWrTpo2WLVt2Q+twOByKj4+/ofsEAOQPj/wuAAAA2GnPnj2qW7euChQooLFjxyo6OlppaWlavHixevfure3bt+d3iQCAm5DDGGPyuwgAAGCfli1bavPmzdqxY4f8/f1d1h0/flwFChRQSkqK+vbtq2XLlsnNzU3NmzfXO++8oyJFikiSunbtquPHj7vMgvbv318bN27UihUrJEkNGzZUdHS0fHx8NGnSJHl5ealnz54aMWKEJKlUqVLau3evc/uSJUtqz5491/PQAQD5iMt9AQBANkePHtWiRYvUu3fvbAFVkgoUKCBjjNq1a6ejR49q5cqVSkhI0K5du/Twww9f8f6mTp0qf39//fjjjxo7dqxeeuklJSQkSJKSkpIkSZMnT9aBAweczwEANycu9wUAANn88ssvMsaofPnyubZZunSpNm/erN27dysyMlKS9Omnn+qOO+5QUlKSatasedn7i46O1vDhwyVJZcuW1bvvvqtly5apWbNmKly4sKS/g3F4ePg1HBUA4J+AmVQAAJBN1reBHA5Hrm2Sk5MVGRnpDKiSVLFiRRUoUEDJyclXtL/o6GiX5xERETp8+PAV9QEAuDkQUgEAQDZly5aVw+G4aNg0xuQYYs9f7ubmpgtvf5GWlpZtG09PT5fnDodDmZmZV1M6AOAfjpAKAACyCQ0NVWxsrCZMmKBTp05lW3/8+HFVrFhRKSkp2rdvn3P5tm3bdOLECVWoUEGSVLhwYR04cMBl240bN15xPZ6ensrIyLji7QAA/zyEVAAAkKP33ntPGRkZqlWrlubMmaOdO3cqOTlZb7/9tmJiYtS0aVNFR0erU6dOWr9+vdauXasuXbqoQYMGqlGjhiSpcePG+umnn/TJJ59o586dGj58uLZs2XLFtZQqVUrLli3TwYMHdezYsbw+VACARQipAAAgR6VLl9b69evVqFEjPf3006pUqZKaNWumZcuWaeLEiXI4HIqPj1dISIjq16+vpk2bKioqSrNmzXL2ERsbq2HDhmnw4MGqWbOmTp48qS5dulxxLW+88YYSEhIUGRmpO++8My8PEwBgGX4nFQAAAABgDWZSAQAAAADWIKQCAAAAAKxBSAUAAAAAWIOQCgAAAACwBiEVAAAAAGANQioAAAAAwBqEVAAAAACANQipAAAAAABrEFIBAAAAANYgpAIAAAAArEFIBQAAAABY4/8Bv3sLzd1Rc8UAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "non-communicable    1660\n",
      "external             218\n",
      "maternal              63\n",
      "communicable          48\n",
      "aids-tb               40\n",
      "Name: count, dtype: int64\n"
     ]
    },
    {
     "data": {
      "image/png": "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goOD1bZtW7Vo0UIHDx7U1atXVaRIERUqVEi7d+9Od8yk/AHmfhUpUkS5cuXSrFmzHMbblStXNH/+fPsdf2+VJ08edevWTXXq1NGOHTtuu497fW3atWuna9euafbs2Zo2bZoiIiLs40L6+zLxLFmyaP/+/emeFzc3tweqOa3XdcmSJfd96egzzzwjDw+PVJ89mzZtuutLztMyevRonThxQh999JHDci8vL9WoUUM7d+5UeHh4mucoJThHRkZq7969Djdvk6Q5c+Y4PE/5A+Gt5+W///1vqrru9UqFgIAANW3aVF9++aUWL16sU6dOpbobb6NGjXT48GFlzZo1zeNJK+i7u7srMjJSo0ePlqQ076QOPCmYSQWAR+xf//qXZs6cqQYNGqhnz556+umn5erqqt9++01r165VkyZN9Pzzz6tYsWJ65ZVXNH78eLm6uqp27drau3ev3n///VSXEKdlwoQJaty4sZ555hn17t1befLk0fHjx7V8+XL7Pz5T7kD74YcfKioqSq6uripSpIjy5cunt99+W2+99Zb+97//qV69egoICNDp06e1detW+6yak5OT3nnnHXXs2FHPP/+8Xn31VV28eFHDhg2768sCP/jgA/3vf/9T27ZttXz5cj3//PMKDg7Wn3/+qZUrV2rq1KmaM2eOwsPDlSVLFi1YsECNGjVSuXLl1LdvX5UqVUrx8fGaO3euZs6cqebNm9t/UuJmx48f1+bNm5WcnKy4uDjt3LlTU6ZM0bFjxzRu3Dg9++yzd6y1XLlyCggI0IoVKxxmy2rXrq133nnH/t93UrJkSS1YsEATJ05UuXLl5OTkdMdZ+YzQqFEjvfPOOxo6dKj9Dqlvv/228ufPf8c/fFSsWFGNGjVSeHi4AgICFBsbqxkzZjgEw//+97+qX7++6tatq7Zt2ypXrlw6f/68YmNjtWPHDn399dcPVL+Tk5PGjBmjVq1aqVGjRnr99dd1/fp1jR07VhcvXtSoUaMkSXFxcapRo4ZatmypokWLytfXVzExMVq2bFm6s7wpSpYsqXXr1mnRokXKkSOHfH19bzsDXLRoUUVERGjkyJE6ceJEqllCHx8fffzxx4qKitL58+f14osvKigoSGfPntXu3bt19uxZTZw48YFqbtSokaZNm6aiRYsqPDxc27dv19ixY+/7cv+AgAC9+eabevfdd9WxY0e9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5ciRQwMGDFBiYqJD3d27d1evXr0UEBCg4OBgTZo0SVeuXFG7du3k6+urAgUKaOnSpfZtUi5/Xb58ucqUKSNPT0/VrFlTZ86c0dKlS1WsWDH5+fmpRYsWunr1qn27fPnyafz48Q71ly5d2uE82Ww2TZ48Wc8//7y8vLxUqFAhff/996n2ffOltxs3blRkZKS8vLwUEBCgunXr6sKFC5KkZcuWqUqVKsqSJYuyZs2qRo0a6fDhw6nO44EDB1SpUiV5eHjoqaee0rp162573jdt2qRq1arJ09NToaGh6tGjh65cuXLbbQAAAADgQdzz5b7Tp0+Xt7e3tmzZojFjxujtt9/WypUrZYxR06ZNdf78ea1fv14rV67U4cOH1bx5c4ftDx8+rIULF2rx4sVavHix1q9fr1GjRt12n23atNGcOXP00UcfKTY2Vp999pl8fHwkSb///rsaNGigChUqaPfu3Zo4caK++OILvfvuu6nqzpYtm7Zu3aru3burc+fOeumll1SpUiXt2LFDdevWVevWrR0Cp/R3sP7kk0+0adMmnThxQi+//LLGjx+vWbNmacmSJVq5cqU+/vjjez2NGj58uF5++WXt2bNHDRo0UKtWrXT+/Pk02+7atUu1atXSU089pejoaP30009q3LixkpKSJElXrlxRnz59FBMTo9WrV8vJyUnPP/+8kpOTHfrp27ev3njjDe3cuVOVKlXSc889p3PnzqW5z59//ll169ZVs2bNtGfPHs2dO1c//fSTunXrdtvjun79uuLj4x0eAAAAAHDXzD2IjIw0VapUcVhWoUIF079/f7NixQrj7Oxsjh8/bl+3b98+I8ls3brVGGPM0KFDjZeXl4mPj7e36du3r6lYsWK6+zx48KCRZFauXJnm+n//+9+mSJEiJjk52b5swoQJxsfHxyQlJaVZd2JiovH29jatW7e2Lzt58qSRZKKjo40xxqxdu9ZIMqtWrbK3GTlypJFkDh8+bF/2+uuvm7p169qf582b1/znP/9xqLFUqVJm6NCh9ueSzKBBg+zPL1++bGw2m1m6dKnDvi9cuGCMMaZFixamcuXK6Z6jW505c8ZIMj///LMxxpgjR44YSWbUqFH2NgkJCSZ37txm9OjRae6zdevW5rXXXnPod8OGDcbJycn89ddf6e576NChRlKqR1xc3F3XDwAAAOCfJy4u7q6y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PkTGGI0ZM0ZhYWHy9PRUqVKl9M0338gYo9q1a6tevXoyxkiSLl68qDx58uitt97S0aNHVaNGDUlSQECAbDab2rZte9s+U6TMwC5fvlzly5eXu7u7NmzYoOrVq6tHjx7q16+fAgMDFRISomHDhjnU+8EHH6hkyZLy9vZWaGiounTposuXLz+ScwUAAAAAkuSS2QX8kw0aNEgLFizQxIkTVahQIf3444965ZVXlD17dk2fPl0lS5bURx99pJ49e6pTp04KDg7WsGHD5OTkpPnz5+uFF17QwYMH5efnJ09Pzzv2GRkZad93v3799P777yssLMz+PdLp06erT58+2rJli6Kjo9W2bVtVrlxZderUkSQ5OTnpo48+Ur58+XTkyBF16dJF/fr106effnrXx3z9+nVdv37d/jw+Pj4DziQAAACAJ4XNpEzlIUNduXJF2bJl05o1axQREWFf3rFjR129elWzZs3S119/rdatW6tPnz768MMPtXPnThUuXFjS3zOiNWrU0IULF+wh8276TNlu4cKFatKkib1N9erVlZSUpA0bNtiXPf3006pZs6ZGjRqV5jF8/fXX6ty5s/78809Jf984qVevXrf9nuywYcM0fPjwVMvj4uLk5+d35xMHAAAA4B8pPj5e/v7+d8wGzKQ+JPv379e1a9fss5Qpbty4oTJlykiSXnrpJX377bcaOXKkJk6caA+oD9JnivLly6faPjw83OF5jhw5dObMGfvztWvXasSIEdq/f7/i4+OVmJioa9eu6cqVK/L29r7zQUsaOHCg+vTpY38eHx+v0NDQu9oWAAAAAAipD0lycrIkacmSJcqVK5fDOnd3d0nS1atXtX37djk7O+vQoUMZ0meKtEKlq6urw3ObzWbv89ixY2rQoIE6deqkd955R4GBgfrpp5/UoUMHJSQk3LG2m+u4tRYAAAAAuFuE1IekePHicnd31/Hjxx2+K3qzN954Q05OTlq6dKkaNGighg0bqmbNmpIkNzc3SVJSUtI99Xm/tm3bpsTERI0bN05OTn/fT2vevHkZug8AAAAAuBNC6kPi6+urN998U71791ZycrKqVKmi+Ph4bdq0ST4+PsqWLZumTJmi6OholS1bVgMGDFBUVJT27NmjgIAA5c2bVzabTYsXL1aDBg3k6el5xz6joqLuu94CBQooMTFRH3/8sRo3bqyNGzfq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",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# create list of predictions lists\n",
    "predictions_all = [predictions_KNN_text, predictions_NB_text, predictions_SVM_text]\n",
    "\n",
    "for i, prediction in enumerate(predictions_all):\n",
    "    # define labels for comparison\n",
    "    true_labels = [Train_Y_mapping[embedding] for embedding in Test_Y]\n",
    "    predicted_labels = prediction\n",
    "    classes = list(pd.Series(prediction).unique())\n",
    "    \n",
    "    print(pd.Series(predicted_labels).value_counts())\n",
    "\n",
    "    # Create a mapping between unique values in 'gs_cod' and colors\n",
    "    colors = sns.color_palette(\"Set2\", n_colors=len(df['gs_cod'].unique()))\n",
    "    unique_cod = df['gs_cod'].unique()\n",
    "    color_mapping = {value: colors[i] for i, value in enumerate(unique_cod)}\n",
    "\n",
    "    plot_confusion_bar(true_labels, predicted_labels, classes, color_mapping)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7230827f",
   "metadata": {},
   "source": [
    "## Using covariates to predict on Y_nlp. \n",
    "### A. 6 baseline betas - for each site, regress true Y on X.\n",
    "### B. 6 transportability betas.\n",
    "### C. 6 ppi++ corrected betas. "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b8e0d838",
   "metadata": {},
   "source": [
    "## Saving data for Trinity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "3a58c6ba",
   "metadata": {},
   "outputs": [],
   "source": [
    "# df.loc[Test_X.index][['age_yr']].to_csv('baseline_covariates.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "fcb36052",
   "metadata": {},
   "outputs": [],
   "source": [
    "# predictions_df = pd.DataFrame({'Test_Y': Test_Y, \n",
    "#                                'predictions_NB': predictions_NB,\n",
    "#                                'predictions_SVM': predictions_SVM, \n",
    "#                                'predictions_KNN': predictions_KNN})\n",
    "# predictions_df.to_csv('baseline_predictions.csv', index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5bfec38c",
   "metadata": {},
   "source": [
    "## Load data as Trinity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "691bf612",
   "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": "markdown",
   "id": "40316baa",
   "metadata": {},
   "source": [
    "## sklearn for Multinomial Logistic Regression "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "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": 25,
   "id": "0ba33037",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "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",
    "# 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": "markdown",
   "id": "de84c604",
   "metadata": {},
   "source": [
    "## Ground Truth Parameter Estimates - For each site, regress Gold Label Y on X"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "6caa70ea",
   "metadata": {},
   "outputs": [],
   "source": [
    "regions = df['site'].unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "ff22b90a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# write function to loop through sites and perform sm.MNLogit prediction of True Y on X, and return df of \n",
    "\n",
    "def mnlogit(df, site):\n",
    "    '''\n",
    "    takes in dataframe and site name as a string\n",
    "    runs sm.MNlogit on Y and X \n",
    "    returns parameter point estimates and standard errors as a df \n",
    "    '''\n",
    "    # Get Y and X for regressing\n",
    "    df_site = df[df['site']==site]\n",
    "    Y_text = df_site['gs_cod']\n",
    "    # get integer embedding from text using mapping dict\n",
    "    df_site['gs_cod_embed'] = list(map(lambda x: next(key for key, value in Train_Y_mapping.items() if value == x), Y_text))\n",
    "    df_site.sort_values(by='gs_cod_embed', ascending=True)['gs_cod_embed']\n",
    "    Y = df_site['gs_cod_embed']\n",
    "    X = df_site['age_yr']\n",
    "\n",
    "    # Reorder the unique values so that 0 becomes the reference category\n",
    "    df_site['gs_cod_embed'] = pd.Categorical(df_site['gs_cod_embed'], categories=[0,1,2,3,4], ordered=True)\n",
    "\n",
    "    print(site)\n",
    "    print(df_site.shape)\n",
    "    \n",
    "    # Create design matrices\n",
    "    X = df_site['age_yr']\n",
    "    X = sm.add_constant(X)\n",
    "    y = pd.get_dummies(df_site['gs_cod_embed'])\n",
    "\n",
    "    # Fit the multinomial logistic regression model\n",
    "    model = sm.MNLogit(y, X)\n",
    "    result = model.fit()\n",
    "\n",
    "    # output table just to verify the levels are correct\n",
    "    print(result.summary())\n",
    "\n",
    "    # Extract labels, parameter estimates and standard errors\n",
    "    class_labels = result.model.endog_names\n",
    "    age_yr_params = result.params.loc['age_yr']\n",
    "    age_yr_std_errors = result.bse.loc['age_yr']\n",
    "\n",
    "    # Create a DataFrame for the results\n",
    "    results_df = pd.DataFrame({\n",
    "        'Class': [1,2,3,4], # HARD CODED -> IDK HOW TO GET THIS OUTPUT FROM result\n",
    "        'Parameter Estimate': age_yr_params,\n",
    "        'Standard Error': age_yr_std_errors\n",
    "    })\n",
    "    \n",
    "    return results_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "a995388f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mexico\n",
      "(1306, 13)\n",
      "Optimization terminated successfully.\n",
      "         Current function value: 0.930912\n",
      "         Iterations 8\n",
      "                          MNLogit Regression Results                          \n",
      "==============================================================================\n",
      "Dep. Variable:                      y   No. Observations:                 1306\n",
      "Model:                        MNLogit   Df Residuals:                     1298\n",
      "Method:                           MLE   Df Model:                            4\n",
      "Date:                Wed, 13 Mar 2024   Pseudo R-squ.:                 0.08812\n",
      "Time:                        10:11:26   Log-Likelihood:                -1215.8\n",
      "converged:                       True   LL-Null:                       -1333.3\n",
      "Covariance Type:            nonrobust   LLR p-value:                 1.119e-49\n",
      "==============================================================================\n",
      "       y=1       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -3.0209      0.396     -7.628      0.000      -3.797      -2.245\n",
      "age_yr         0.0668      0.008      8.483      0.000       0.051       0.082\n",
      "------------------------------------------------------------------------------\n",
      "       y=2       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -0.6621      0.352     -1.882      0.060      -1.352       0.027\n",
      "age_yr         0.0183      0.008      2.283      0.022       0.003       0.034\n",
      "------------------------------------------------------------------------------\n",
      "       y=3       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          0.0134      0.527      0.025      0.980      -1.020       1.047\n",
      "age_yr        -0.0344      0.015     -2.306      0.021      -0.064      -0.005\n",
      "------------------------------------------------------------------------------\n",
      "       y=4       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -1.0082      0.292     -3.450      0.001      -1.581      -0.435\n",
      "age_yr         0.0642      0.007      9.705      0.000       0.051       0.077\n",
      "==============================================================================\n",
      "ap\n",
      "(1144, 13)\n",
      "Optimization terminated successfully.\n",
      "         Current function value: 1.178931\n",
      "         Iterations 8\n",
      "                          MNLogit Regression Results                          \n",
      "==============================================================================\n",
      "Dep. Variable:                      y   No. Observations:                 1144\n",
      "Model:                        MNLogit   Df Residuals:                     1136\n",
      "Method:                           MLE   Df Model:                            4\n",
      "Date:                Wed, 13 Mar 2024   Pseudo R-squ.:                  0.1083\n",
      "Time:                        10:11:26   Log-Likelihood:                -1348.7\n",
      "converged:                       True   LL-Null:                       -1512.5\n",
      "Covariance Type:            nonrobust   LLR p-value:                 1.216e-69\n",
      "==============================================================================\n",
      "       y=1       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -1.6692      0.341     -4.899      0.000      -2.337      -1.001\n",
      "age_yr         0.0319      0.008      4.106      0.000       0.017       0.047\n",
      "------------------------------------------------------------------------------\n",
      "       y=2       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          0.1721      0.280      0.615      0.539      -0.377       0.721\n",
      "age_yr         0.0010      0.007      0.143      0.886      -0.013       0.015\n",
      "------------------------------------------------------------------------------\n",
      "       y=3       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          1.8685      0.532      3.509      0.000       0.825       2.912\n",
      "age_yr        -0.1068      0.020     -5.403      0.000      -0.146      -0.068\n",
      "------------------------------------------------------------------------------\n",
      "       y=4       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -1.6977      0.270     -6.279      0.000      -2.228      -1.168\n",
      "age_yr         0.0646      0.006     10.347      0.000       0.052       0.077\n",
      "==============================================================================\n",
      "up\n",
      "(1380, 13)\n",
      "Optimization terminated successfully.\n",
      "         Current function value: 1.220999\n",
      "         Iterations 7\n",
      "                          MNLogit Regression Results                          \n",
      "==============================================================================\n",
      "Dep. Variable:                      y   No. Observations:                 1380\n",
      "Model:                        MNLogit   Df Residuals:                     1372\n",
      "Method:                           MLE   Df Model:                            4\n",
      "Date:                Wed, 13 Mar 2024   Pseudo R-squ.:                  0.1055\n",
      "Time:                        10:11:26   Log-Likelihood:                -1685.0\n",
      "converged:                       True   LL-Null:                       -1883.6\n",
      "Covariance Type:            nonrobust   LLR p-value:                 1.071e-84\n",
      "==============================================================================\n",
      "       y=1       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          0.7237      0.342      2.115      0.034       0.053       1.394\n",
      "age_yr         0.0139      0.008      1.786      0.074      -0.001       0.029\n",
      "------------------------------------------------------------------------------\n",
      "       y=2       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          2.4596      0.331      7.432      0.000       1.811       3.108\n",
      "age_yr        -0.0275      0.008     -3.439      0.001      -0.043      -0.012\n",
      "------------------------------------------------------------------------------\n",
      "       y=3       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          2.4753      0.373      6.630      0.000       1.744       3.207\n",
      "age_yr        -0.0555      0.010     -5.424      0.000      -0.076      -0.035\n",
      "------------------------------------------------------------------------------\n",
      "       y=4       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          0.3860      0.328      1.178      0.239      -0.256       1.028\n",
      "age_yr         0.0406      0.007      5.505      0.000       0.026       0.055\n",
      "==============================================================================\n",
      "dar\n",
      "(1564, 13)\n",
      "Optimization terminated successfully.\n",
      "         Current function value: 1.146181\n",
      "         Iterations 7\n",
      "                          MNLogit Regression Results                          \n",
      "==============================================================================\n",
      "Dep. Variable:                      y   No. Observations:                 1564\n",
      "Model:                        MNLogit   Df Residuals:                     1556\n",
      "Method:                           MLE   Df Model:                            4\n",
      "Date:                Wed, 13 Mar 2024   Pseudo R-squ.:                  0.1047\n",
      "Time:                        10:11:26   Log-Likelihood:                -1792.6\n",
      "converged:                       True   LL-Null:                       -2002.3\n",
      "Covariance Type:            nonrobust   LLR p-value:                 1.772e-89\n",
      "==============================================================================\n",
      "       y=1       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -0.8341      0.280     -2.977      0.003      -1.383      -0.285\n",
      "age_yr         0.0073      0.006      1.142      0.254      -0.005       0.020\n",
      "------------------------------------------------------------------------------\n",
      "       y=2       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          1.0616      0.301      3.530      0.000       0.472       1.651\n",
      "age_yr        -0.0500      0.009     -5.863      0.000      -0.067      -0.033\n",
      "------------------------------------------------------------------------------\n",
      "       y=3       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          2.0153      0.329      6.120      0.000       1.370       2.661\n",
      "age_yr        -0.0867      0.011     -8.171      0.000      -0.107      -0.066\n",
      "------------------------------------------------------------------------------\n",
      "       y=4       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -0.6710      0.207     -3.242      0.001      -1.077      -0.265\n",
      "age_yr         0.0407      0.005      8.830      0.000       0.032       0.050\n",
      "==============================================================================\n",
      "bohol\n",
      "(1109, 13)\n",
      "Optimization terminated successfully.\n",
      "         Current function value: 0.985313\n",
      "         Iterations 7\n",
      "                          MNLogit Regression Results                          \n",
      "==============================================================================\n",
      "Dep. Variable:                      y   No. Observations:                 1109\n",
      "Model:                        MNLogit   Df Residuals:                     1101\n",
      "Method:                           MLE   Df Model:                            4\n",
      "Date:                Wed, 13 Mar 2024   Pseudo R-squ.:                 0.05946\n",
      "Time:                        10:11:26   Log-Likelihood:                -1092.7\n",
      "converged:                       True   LL-Null:                       -1161.8\n",
      "Covariance Type:            nonrobust   LLR p-value:                 7.009e-29\n",
      "==============================================================================\n",
      "       y=1       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          1.4728      0.669      2.202      0.028       0.162       2.784\n",
      "age_yr         0.0118      0.012      1.011      0.312      -0.011       0.035\n",
      "------------------------------------------------------------------------------\n",
      "       y=2       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          3.2060      0.659      4.868      0.000       1.915       4.497\n",
      "age_yr        -0.0265      0.012     -2.234      0.025      -0.050      -0.003\n",
      "------------------------------------------------------------------------------\n",
      "       y=3       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          3.0082      0.732      4.112      0.000       1.574       4.442\n",
      "age_yr        -0.0574      0.015     -3.838      0.000      -0.087      -0.028\n",
      "------------------------------------------------------------------------------\n",
      "       y=4       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          2.5040      0.639      3.921      0.000       1.252       3.756\n",
      "age_yr         0.0172      0.011      1.538      0.124      -0.005       0.039\n",
      "==============================================================================\n",
      "pemba\n",
      "(260, 13)\n",
      "Optimization terminated successfully.\n",
      "         Current function value: 1.344506\n",
      "         Iterations 8\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "                          MNLogit Regression Results                          \n",
      "==============================================================================\n",
      "Dep. Variable:                      y   No. Observations:                  260\n",
      "Model:                        MNLogit   Df Residuals:                      252\n",
      "Method:                           MLE   Df Model:                            4\n",
      "Date:                Wed, 13 Mar 2024   Pseudo R-squ.:                 0.06082\n",
      "Time:                        10:11:26   Log-Likelihood:                -349.57\n",
      "converged:                       True   LL-Null:                       -372.21\n",
      "Covariance Type:            nonrobust   LLR p-value:                 3.490e-09\n",
      "==============================================================================\n",
      "       y=1       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          3.4187      1.236      2.766      0.006       0.996       5.841\n",
      "age_yr        -0.0230      0.021     -1.086      0.278      -0.065       0.019\n",
      "------------------------------------------------------------------------------\n",
      "       y=2       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          5.0843      1.230      4.134      0.000       2.674       7.495\n",
      "age_yr        -0.0598      0.022     -2.757      0.006      -0.102      -0.017\n",
      "------------------------------------------------------------------------------\n",
      "       y=3       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          4.8264      1.253      3.852      0.000       2.371       7.282\n",
      "age_yr        -0.0695      0.023     -3.024      0.002      -0.115      -0.024\n",
      "------------------------------------------------------------------------------\n",
      "       y=4       coef    std err          z      P>|z|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          3.4493      1.223      2.820      0.005       1.052       5.847\n",
      "age_yr        -0.0155      0.021     -0.744      0.457      -0.056       0.025\n",
      "==============================================================================\n"
     ]
    }
   ],
   "source": [
    "# Loop through the list of sites and output results to csv\n",
    "sites = df['site'].unique()\n",
    "\n",
    "for site in sites:\n",
    "\n",
    "    # Create a DataFrame for the results\n",
    "    results_df = mnlogit(df, site)\n",
    "\n",
    "    # Save results to a CSV file\n",
    "    results_df.to_csv(f'ground_truth_{site}.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "30119bac",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4de33e5a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "956a07ae",
   "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
}
