{
 "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": 93,
   "id": "c4c1ae99",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import random \n",
    "import matplotlib.pyplot as plt\n",
    "import tensorflow as tf\n",
    "import imblearn\n",
    "import statsmodels.api as sm\n",
    "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": 85,
   "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": 5,
   "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": 6,
   "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": 7,
   "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": 8,
   "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": 9,
   "id": "a46f47b2",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Naive Bayes Accuracy Score ->  0.6007885657959586\n",
      "Naive Bayes Weighted F1 Score ->  0.7228294530938814\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": 10,
   "id": "214afda4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Naive Bayes Accuracy Score ->  0.6796451453918186\n",
      "Naive Bayes Weighted F1 Score ->  0.7478183672232265\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": 11,
   "id": "32617d9d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Naive Bayes Accuracy Score ->  0.6347954657466732\n",
      "Naive Bayes Weighted F1 Score ->  0.6736667401801775\n"
     ]
    }
   ],
   "source": [
    "# Applying k = 3, default Minkowski distance metrics\n",
    "KNN = KNeighborsClassifier(n_neighbors=8, 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": 12,
   "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": 13,
   "id": "4bb6efd0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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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": 14,
   "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": 15,
   "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": 16,
   "id": "0bb537d6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Vy+X7Q8cOKClS5dq+fLlWr58udauXasZM2YUeZ/9+/fX+++/r9dee03Jycl68803ValSJUnSjz/+qM6dO+vWW2/Vjh07NGfOHM2fP1/PP/98gXEHBgZq06ZNGj58uJ588kn16NFDUVFR2rp1qzp27Kh+/fq5xKN0LpJff/11bdy4UUeOHFHPnj31yiuv6L333tOnn36q+Ph4/f3vf7/ch1FTp05Vz549tXPnTnXu3Fl9+/bVr7/+Wui627dv1x133KFGjRopKSlJ69ev13333afc3FxJUkZGhkaNGqXNmzfriy++kJubmx544AHl5eW57Of//u//NHr0aG3btk1RUVG6//77deLEiULv85tvvlHHjh3VvXt37dy5U4sXL9b69ev11FNPFTmvrKwspaenu1wAAMCNzWGMMcVdOSYmRrm5uUpMTHQua9WqlWJjY3XHHXfonnvuUUpKisLCwiRJe/bsUaNGjbRp0ybdeuutiouL04svvqijR4/Kx8dHkjR27FitW7dOX375ZaH3+e233+rmm29WfHy87rzzzgK3T5w4UR9++KGSk5PlcDgkSbNnz9a4ceOUlpYmNze3AuPOzc2Vn5+funfvrn/+85+SpKNHjyokJERJSUm67bbblJCQoA4dOujzzz/XHXfcIUmaMWOGJkyYoAMHDqh27dqSpCFDhujgwYNauXKlpHNnOEeOHKmRI0c6x9isWTN169bNeZbT4XBo0qRJeu655ySdC0YfHx999tln6tSpk/O+T548qcqVK+vhhx/W4cOHtX79+mIdp59//llVq1bVN998o8aNG+vgwYMKDw/XjBkzNG7cOElSTk6OwsPDNXz4cI0dO7bAffbv319eXl6aO3euc7/r169XdHS0MjIy5OnpWeh9x8XFaerUqQWWh41cIjePisUaPwAAuLSDM+61tu/09HT5+fkpLS1Nvr6+V72/yz7D2aRJE5frISEhOn78uJKTkxUWFuaMTUm65ZZbVLlyZSUnJzuX1apVyxmb528vSe+++64qVarkvCQmJmr79u0qV66coqOjCx1PcnKy2rRp44xNSWrbtq1+++03/fDDD4WOu1y5cqpSpYoiIiKcy4KCgiTJOZbCtgsKClLFihWdsZm/7MJtiuP8/Xp7e8vHx+ei+8k/w3kxBw4c0MMPP6zatWvL19dX4eHhks59xeF8bdq0cf67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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": 17,
   "id": "e74f506b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAApIAAAGxCAYAAADRWFZjAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAAA7pklEQVR4nO3de3zO9f/H8ee1jctmBzNsxtjkzIZQmWpEkUOkbyQxUd+W4+jrVDLqW0bfovoWX0WqL0nfpEJpOTVZyCynOSRDGSI2Z7a9f3+47fq57MA+prn0uN9u1+3W5/N5f96f1+tS27P35/pcbMYYIwAAAKCI3Eq6AAAAALgmgiQAAAAsIUgCAADAEoIkAAAALCFIAgAAwBKCJAAAACwhSAIAAMASgiQAAAAsIUgCAADAEoIkABTR2rVr9eCDD6patWqy2+0KDAxUixYt9Mwzz+j3339X6dKl9cgjjxR4fmZmpry8vPTAAw9IkmbPni2bzSabzaaVK1fmGW+MUc2aNWWz2dSqVasi1dq3b1/H3DabTXa7XXXq1FFcXJzOnj1bpLmsSEtLk81m0+zZsx37xo8fL5vNVuS55s6dq6lTp+Z7zGazafz48daKBGAZQRIAimDx4sWKjIxUZmamJk+erG+++Uavv/66WrZsqY8//lgVK1bUAw88oIULF+rYsWP5zjFv3jydOXNG/fv3d9rv4+OjmTNn5hm/atUq7d69Wz4+PpZq9vT0VFJSkpKSkrRw4ULdfvvteuGFFxQdHW1pvmv1xBNPKCkpqcjnFRYkk5KS9MQTT1xjZQCKyqOkCwAAVzJ58mSFhYVp6dKl8vD4/x+hjzzyiCZPnixJ6t+/vz799FPNmTNHgwYNyjPHrFmzFBgYqI4dOzrt79Gjh+bMmaO33npLvr6+jv0zZ85UixYtlJmZaalmNzc33XHHHY7t+++/X2lpaZo/f75ee+01ValSJd/zzpw5I09PT0vXLEzVqlVVtWrVYp3z0v4A/HlYkQSAIjh69KgqVKjgFCJzubld/JHarl07Va1aVe+9916eMampqVq7dq369OmTZ46ePXtKkj766CPHvoyMDH366afq169fcbbhCF579+6VJIWGhqpTp05asGCBmjRpojJlymjChAmSpIMHD+qpp55S1apVVbp0aYWFhWnChAnKyspymvPAgQPq3r27fHx85Ofnpx49eujgwYN5rl3Qre25c+eqRYsW8vb2lre3txo3buxYoW3VqpUWL16svXv3Ot2qz5Xfre0tW7aoS5cu8vf3V5kyZdS4cWO9//77TmNWrlwpm82mjz76SM8995yCg4Pl6+urtm3baseOHU5jN27cqE6dOqlSpUqy2+0KDg5Wx44d9euvv17NWw7clAiSAFAELVq00Nq1azVkyBCtXbtWFy5cyDPGzc1Nffv2VXJysn766SenY7nhMr9g6Ovrq7/97W+aNWuWY99HH30kNzc39ejRo1j7+PnnnyVJFStWdOxLTk7WiBEjNGTIEH399dd66KGHdPDgQd12221aunSpxo0bp6+++kr9+/fXxIkT9eSTTzrOPXPmjNq2batvvvlGEydO1CeffKKgoKCrrnvcuHHq1auXgoODNXv2bH322WeKjo52BN23335bLVu2VFBQkOM2fWG3x3fs2KHIyEht3bpVb7zxhhYsWKD69eurb9++jpXjSz377LPau3ev3n33Xc2YMUO7du1S586dlZ2dLUk6deqU7r33Xh06dEhvvfWWEhISNHXqVFWrVk0nTpy4qh6Bm5IBAFy1I0eOmDvvvNNIMpJMqVKlTGRkpJk4caI5ceKEY9wvv/xibDabGTJkiGPfhQsXTFBQkGnZsqXTnO+9956RZNavX29WrFhhJJktW7YYY4xp3ry56du3rzHGmAYNGpioqKgi1RsdHW3Kli1rLly4YC5cuGB+//138/rrrxubzWaaN2/uGFe9enXj7u5uduzY4XT+U089Zby9vc3evXud9v/rX/8ykszWrVuNMcZMmzbNSDKff/6507gnn3zSSDLvvfeeY19cXJy59NfPL7/8Ytzd3U2vXr0K7aVjx46mevXq+R6TZOLi4hzbjzzyiLHb7Wbfvn1O4+6//37j5eVljh8/bowxjve7Q4cOTuPmz59vJJmkpCRjjDE//vijkWQWLlxYaI3AXw0rkgBQBAEBAUpMTNT69esVHx+vLl26aOfOnRozZozCw8N15MgRSVJYWJhat26tOXPm6Pz585Kkr776SgcPHiz0NnVUVJRuueUWzZo1S5s3b9b69euv+bb2qVOnVKpUKZUqVUoVK1ZUbGys7r//fn322WdO4yIiIlS7dm2nfYsWLVLr1q0VHBysrKwsx+v++++XdPFBIElasWKFfHx8HE+i53r00UevWF9C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1KlTnepv3Lix0/tks9n07rvv6sEHH5SXl5dq1aqlL774Is+1L73N/P333ysqKkpeXl7y9/dXu3btdOzYMUnS119/rTvvvFPlypVTQECAOnXqpN27d+d5H7dv367IyEiVKVNGDRo00MqVKwt939esWaO7775bnp6eCgkJ0ZAhQ3Tq1KlCzwEAAH8dRb61/f7776ts2bJau3atJk+erBdeeEEJCQkyxqhr1676448/tGrVKiUkJGj37t3q0aOH0/m7d+/WwoULtWjRIi1atEirVq1SfHx8odfs06eP5s2bpzfeeEOpqamaPn26vL29JUm//fabOnTooObNm+unn37StGnTNHPmTP3zn//MU3eFChW0bt06DR48WE8//bQefvhhRUZGKjk5We3atVPv3r2dQqF0Mfz++9//1po1a7R//351795dU6dO1dy5c7V48WIlJCTozTffLOrbqAkTJqh79+7atGmTOnTooF69eumPP/7Id2xKSoratGmjBg0aKCkpSatXr1bnzp2VnZ0tSTp16pSGDx+u9evXa9myZXJzc9ODDz6onJwcp3lGjBihZ555Rhs3blRkZKQeeOABHT16NN9rbt68We3atVO3bt20adMmffzxx1q9erUGDRpUaF/nzp1TZmam0wsAANycbMYYc7WDW7VqpezsbCUmJjr23XbbbbrnnnvUpk0b3X///dqzZ49CQkIkSdu2bVODBg20bt06NW/eXOPHj9crr7yigwcPysfHR5I0cuRIfffdd/rhhx/yvebOnTtVp04dJSQkqG3btnmOP/fcc/r000+Vmpoqm80mSXr77bc1atQoZWRkyM3NLU/d2dnZ8vPzU7du3fTBBx9Ikg4ePKjKlSsrKSlJd9xxh1auXKnWrVvr22+/VZs2bSRJ8fHxGjNmjHbv3q0aNWpIkmJiYpSWlqavv/5a0sUVydjYWMXGxjpqbNy4sbp27epYlbTZbBo7dqxefPFFSReDoI+Pj5YsWaL27ds7rn3s2DGVK1dOjz76qPbt26fVq1df1Z/T77//rkqVKmnz5s1q2LCh0tLSFBYWpvj4eI0aNUqSlJWVpbCwMA0ePFgjR47Mc80+ffrI09NT//nPfxzzrl69WlFRUTp16pTKlCmT77XHjx+vCRMm5NkfEjtfbnavq6ofAABcWVp8x+s2d2Zmpvz8/JSRkSFfX98CxxV5RTIiIsJpu3Llyjp8+LBSU1MVEhLiCJGSVL9+fZUrV06pqamOfaGhoY4Qeen5kjRnzhx5e3s7XomJiUpJSZG7u7uioqLyrSc1NVUtWrRwhEhJatmypU6ePKlff/0137rd3d0VEBCg8PBwx77AwEBJctSS33mBgYHy8vJyhMjcfZefczUunbds2bLy8fEpcJ7cFcmC7N69W48++qhq1KghX19fhYWFSbr4UYNLtWjRwvHPHh4eatasmdOfzaU2bNig2bNnO/15tGvXTjk5OdqzZ0+BtYwZM0YZGRmO1/79+wscCwAAXFuRH7YpVaqU07bNZlNOTo6MMU5hLtfl+ws6X5IeeOAB3X777Y5jVapU0bfffltoPfldN3eR9UrXvXRf7tjLbwdfPqaw+iXJzc1Nly/yXrhwIU/dV5rnUp6envnuz9W5c2eFhITonXfeUXBwsHJyctSwYUOdP3++0PNyr5ufnJwcPfXUUxoyZEieY9WqVStwPrvdLrvdfsXrAgAA11dsX/9Tv3597du3z2kFatu2bcrIyFC9evWuag4fHx/VrFnT8fL09FR4eLhycnK0atWqAq+7Zs0ap/C2Zs0a+fj4qEqVKtfWlAUVK1ZUenq6YzszM7PQFbyrERERoWXLluV77OjRo0pNTdXYsWPVpk0b1atXz/EQzuUu/fhAVlaWNmzYoLp16+Y79tZbb9XWrVud/jxyX6VLl76mfgAAwM2h2IJk27ZtFRERoV69eik5OVnr1q1Tnz59FBUVpWbNmlmeNzQ0VNHR0erXr58WLlyoPXv2aOXKlZo/f74kacCAAdq/f78GDx6s7du36/PPP1dcXJyGDx8uN7c//2sy77nnHn344YdKTEzUli1bFB0dLXd392uac8yYMVq/fr0GDBigTZs2afv27Zo2bZqOHDkif39/BQQEaMaMGfr555+1fPlyDR8+PN953nrrLX322Wfavn27Bg4cqGPHjqlfv375jh01apSSkpI0cOBApaSkaNeuXfriiy80ePDga+oFAADcPIotadlsNi1cuFD+/v66++671bZtW9WoUUMff/zxNc89bdo0/e1vf9OAAQNUt25dPfnkk46voalSpYqWLFmidevWqVGjRoqJiVH//v01duzYa76uFWPGjNHdd9+tTp06qUOHDuratatuueWWa5qzdu3a+uabb/TTTz/ptttuU4sW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PdW8eXPt3LlT69evV7NmzeTt7a327dvr999/d5zXqlUrxcbGOtXetWtX9e3b17EdGhqql19+Wf369ZOPj4+qVaumGTNm5Ln2pbeZt27dqo4dO8rX11c+Pj666667tHv3bknS+vXrde+996pChQry8/NTVFSUkpOT87yH6enpuv/+++Xp6amwsDB98sknhb7n27ZtU4cOHeTt7a3AwED17t1bR44cKfQcAADw1+BSQXLMmDGaNGmSnn/+eW3btk1z585VYGCgTp8+rfbt28vf31/r16/XJ598om+//VaDBg1yOn/58uU6cOCAvvvuO7322msaP368OnXqJH9/f61du1YxMTGKiYnR/v37nc6Li4vT2LFjlZycLA8PD/Xs2VMjR47U66+/rsTERO3evVvjxo0rcj+vvvqqmjVrpo0bN2rAgAF6+umntX379nzH/vbbb7r77rtVpkwZLV++XBs2bFC/fv2UlZUlSTpx4oSio6OVmJioH374QbVq1VKHDh104sQJp3mef/55PfTQQ/rpp5/02GOPqWfPnkpNTc33munp6YqKilLjxo31448/6uuvv9ahQ4fUvXv3Ans6d+6cMjMznV4AAOAmZVxEZmamsdvt5p133slzbMaMGcbf39+cPHnSsW/x4sXGzc3NHDx40BhjTHR0tKlevbrJzs52jKlTp4656667HNtZWVmmbNmy5qOPPjLGGLNnzx4jybz77ruOMR999JGRZJYtW+bYN3HiRFOnTh3HdlRUlBk6dKhTjV26dDHR0dGO7erVq5vHHnvMsZ2Tk2MqVapkpk2b5nTtjRs3GmOMGTNmjAkLCzPnz5+/4nuV24uPj4/58ssvHfskmZiYGKdxt99+u3n66afzvebzzz9v7rvvPqfx+/fvN5LMjh078r1uXFyckZTnFRI731QftSjPCwAA3HgyMjKMJJORkVHoOJdZkUxNTdW5c+fUpk2bfI81atRIZcuWdexr2bKlcnJytGPHDse+Bg0ayM3t/1sODAxUeHi4Y9vd3V0BAQE6fPiw0/wRERFO50hyOi8wMDDPOVfj0nltNpuCgoIKnCclJUV33XWXSpUqle/xw4cPKyYmRrVr15afn5/8/Px08uRJ7du3z2lcixYt8mwXtCK5YcMGrVixQt7e3o5X3bp1JclxS/1yY8aMUUZGhuN1+eouAAC4ebjMwzaenp4FHjPGyGaz5Xvs0v2XhzCbzZbvvpycHKd9l47Jne/yfZee4+bmJmOM0xwXLlzIU9vVXDtXYf1LFz8D+vvvv2vq1KmqXr267Ha7WrRoofPnzxd6Xu5185OTk6POnTtr0qRJeY5Vrlw533PsdrvsdvsVrwkAAFyfy6xI1qpVS56enlq2bFmeY/Xr11dKSopOnTrl2Pf999/Lzc1NtWvX/jPLlCRVrFhR6enpju3s7Gxt2bLlmuaMiIhQYmJivoFUkhITEzVkyBB16NBBDRo0kN1uz/ehmB9++CHPdu4q4+VuvfVWbd26VaGhoapZs6bT69LVXwAA8NfkMkGyTJkyGjVqlEaOHKkPPvhAu3fv1g8//KCZM2eqV69eKlOmjKKjo7VlyxatWLFCgwcPVu/evR23ov9M99xzjxYvXqzFixdr+/btGjBggI4fP35Ncw4aNEiZmZl65JFH9OOPP2rXrl368MMPHbfua9asqQ8//FCpqalau3atevXqle8q5ieffKJZs2Zp586diouL07p16/I8lJRr4MCB+uOPP9SzZ0+tW7dOv/zyi7755hv169dP2dnZ19QPAABwfS4TJKWLTxw/88wzGjdunOrVq6cePXro8OHD8vLy0tKlS/XHH3+oefPm+tvf/qY2bdro3//+d4nU2a9fP0VHR6tPnz6KiopSWFiYWrdufU1zBgQEaPny5Tp58qSioqLUtGlTvfPOO47b47NmzdKxY8fUpEkT9e7dW0OGDFGlSpXyzDNhwgTNmzdPERERev/99zVnzhzVr18/32sGBwfr+++/V3Z2ttq1a6eGDRtq6NCh8vPzc/qsKQAA+Guymcs/zAcUo8zMTPn5+Skkdr7c7F55jqfFdyyBqgAAQGFyf39nZGTI19e3wHEsKwEAAMASgiQAAAAsIUgCAADAEoIkAAAALCFIAgAAwBKCJAAAACwhSAIAAMASgiQAAAAsIUgCAADAEoIkAAAALCFIAgAAwBKCJAAAACzxKOkC8NewZUK7Qv/SdwAA4HpYkQQAAIAlBEkAAABYQpAEAACAJQRJAAAAWEKQBAAAgCUESQAAAFhCkAQAAIAlBEkAAABYQpAEAACAJQRJAAAAWEKQBAAAgCUESQAAAFhCkAQAAIAlBEkAAABYQpAEAACAJQRJAAAAWOJR0gXg5maMkSRlZmaWcCUAAOBq5f7ezv09XhCCJK6ro0ePSpJCQkJKuBIAAFBUJ06ckJ+fX4HHCZK4rsqXLy9J2rdvX6H/IrqqzMxMhYSEaP/+/fL19S3pcood/bmum7k3if5cHf3d+IwxOnHihIKDgwsdR5DEdeXmdvFjuH5+fi77H9PV8PX1pT8XdjP3dzP3JtGfq6O/G9vVLADxsA0AAAAsIUgCAADAEoIkriu73a64uDjZ7faSLuW6oD/XdjP3dzP3JtGfq6O/m4fNXOm5bgAAACAfrEgCAADAEoIkAAAALCFIAgAAwBKCJAAAACwhSAIAAMASgiSum7ffflthYWEqU6aMmjZtqsTExJIu6YomTpyo5s2by8fHR5UqVVLXrl21Y8cOpzHGGI0fP17BwcHy9PRUq1attHXrVqcx586d0+DBg1WhQgWVLVtWDzzwgH799dc/s5WrMnHiRNlsNsXGxjr2uXp/v/32mx577DEFBATIy8tLjRs31oYNGxzHXbm/rKwsjR07VmFhYfL09FSNGjX0wgsvKCcnxzHGlfr77rvv1LlzZwUHB8tms2nhwoVOx4url2PHjql3797y8/OTn5+fevfurePHj1/n7grv78KFCxo1apTCw8NVtmxZBQcHq0+fPjpw4MBN0d/lnnrqKdlsNk2dOtVpv6v3l5qaqgceeEB+fn7y8fHRHXfcoX379jmO38j9FRsDXAfz5s0zpUqVMu+8847Ztm2bGTp0qClbtqzZu3dvSZdWqHbt2pn33nvPbNmyxaSkpJiOHTuaatWqmZMnTzrGxMfHGx8fH/Ppp5+azZs3mx49epjKlSubzMxMx5iYmBhTpUoVk5CQYJKTk03r1q1No0aNTFZWVkm0la9169aZ0NBQExERYYYOHerY78r9/fHHH6Z69eqmb9++Zu3atWbPnj3m22+/NT///LNjjCv3989//tMEBASYRYsWmT179phPPvnEeHt7m6lTpzrGuFJ/S5YsMc8995z59NNPjSTz2WefOR0vrl7at29vGjZsaNasWWPWrFljGjZsaDp16lSi/R0/fty0bdvWfPzxx2b79u0mKSnJ3H777aZp06ZOc7hqf5f67LPPTKNGjUxwcLCZMmWK0zFX7u/nn3825cuXNyNGjDDJyclm9+7dZtGiRebQoUMu0V9xIUjiurjttttMTEyM0766deua0aNHl1BF1hw+fNhIMqtWrTLGGJOTk2OCgoJMfHy8Y8zZs2eNn5+fmT59ujHm4i+IUqVKmXnz5jnG/Pbbb8bNzc18/fXXf24DBThx4oSpVauWSUhIMFFRUY4g6er9jRo1ytx5550FHnf1/jp27Gj69evntK9bt27mscceM8a4dn+X/6Iurl62bdtmJJkffvjBMSYpKclIMtu3b7/OXf2/woJWrnXr1hlJjv/hvhn6+/XXX02VKlXMli1bTPXq1Z2CpKv316NHD8d/e/lxpf6uBbe2UezOnz+vDRs26L777nPaf99992nNmjUlVJU1GRkZkqTy5ctLkvbs2aODBw869Wa32xUVFeXobcOGDbpw4YLTmODgYDVs2PCG6X/gwIHq2LGj2rZt67Tf1fv74osv1KxZMz388MOqVKmSmjRponfeecdx3NX7u/POO7Vs2TLt3LlTkvTTTz9p9erV6tChgyTX7+9SxdVLUlKS/Pz8dPvttzvG3HHHHfLz87uh+pUu/ryx2WwqV66cJNfvLycnR71799aIESPUoEGDPMddub+cnBwtXrxYtWvXVrt27VSpUiXdfvvtTre/Xbm/oiBIotgdOXJE2dnZCgwMdNofGBiogwcPllBVRWeM0fDhw3XnnXeqYcOGkuSov7DeDh48qNKlS8vf37/AMSVp3rx5Sk5O1sSJE/Mcc/X+fvnlF02bNk21atXS0qVLFRMToyFDhuiDDz6Q5Pr9jRo1Sj179lTdunVVqlQpNWnSRLGxserZs6ck1+/vUsXVy8GDB1WpUqU881eqVOmG6vfs2bMaPXq0Hn30Ufn6+kpy/f4mTZokDw8PDRkyJN/jrtzf4cOHdfLkScXHx6t9+/b65ptv9OCDD6pbt25atWqVJNfuryg8SroA3LxsNpvTtjEmz74b2aBBg7Rp0yatXr06zzErvd0I/e/fv19Dhw7VN998ozJlyhQ4zlX7y8nJUbNmzfTyyy9Lkpo0aaKtW7dq2rRp6tOnj2Ocq/b38ccf67///a/mzp2rBg0aKCUlRbGxsQoODlZ0dLRjnKv2l5/i6CW/8TdSvxcuXNAjjzyinJwcvf3221cc7wr9bdiwQa+//rqSk5OLXIcr9Jf7gFuXLl00bNgwSVLjxo21Zs0aTZ8+XVFRUQWe6wr9FQUrkih2FSpUkLu7e57/mzp8+HCe1YUb1eDBg/XFF19oxYoVqlq1qmN/UFCQJBXaW1BQkM6fP69jx44VOKakbNiwQYcPH1bTpk3l4eEhDw8PrVq1Sm+88YY8PDwc9blqf5UrV1b9+vWd9tWrV8/xFKWr//mNGDFCo0eP1iOPPKLw8HD17t1bw4YNc6wuu3p/lyquXoKCgnTo0KE88//+++83RL8XLlxQ9+7dtWfPHiUkJDhWIyXX7i8xMVGHDx9WtWrVHD9r9u7dq2eeeUahoaGSXLu/ChUqyMPD44o/b1y1v6IgSKLYlS5dWk2bNlVCQoLT/oSEBEVGRpZQVVfHGKNBgwZpwYIFWr58ucLCwpyOh4WFKSgoyKm38+fPa9WqVY7emjZtqlKlSjmNSU9P15YtW0q8/zZt2mjz5s1KSUlxvJo1a6ZevXopJSVFNWrUcOn+WrZsmefrmnbu3Knq1atLcv0/v9OnT8vNzfnHtru7u2N1xNX7u1Rx9dKiRQtlZGRo3bp1jjFr165VRkZGifebGyJ37dqlb7/9VgEBAU7HXbm/3r17a9OmTU4/a4KDgzVixAgtXbpUkmv3V7p0aTVv3rzQnzeu3F+R/LnP9uCvIvfrf2bOnGm2bdtmYmNjTdmyZU1aWlpJl1aop59+2vj5+ZmVK1ea9PR0x+v06dOOMfHx8cbPz88sWLDAbN682fTs2TPfrySpWrWq+fbbb01ycrK55557boivj8nPpU9tG+Pa/a1bt854eHiYl156yezatcvMmTPHeHl5mf/+97+OMa7cX3R0tKlSpYrj638WLFhgKlSoYEaOHOkY40r9nThxwmzcuNFs3LjRSDKvvfaa2bhxo+Op5eLqpX379iYiIsIkJSWZpKQkEx4e/qd8vUph/V24cME88MADpmrVqiYlJcXp5825c+dcvr/8XP7UtjGu3d+CBQtMqVKlzIwZM8yuXbvMm2++adzd3U1iYqJL9FdcCJK4bt566y1TvXp1U7p0aXPrrbc6vkLnRiYp39d7773nGJOTk2Pi4uJMUFCQsdvt5u677zabN292mufMmTNm0KBBpnz58sbT09N06tTJ7Nu370/u5upcHiRdvb8vv/zSNGzY0NjtdlO3bl0zY8YMp+Ou3F9mZqYZOnSoqVatmilTpoypUaOGee6555yChyv1t2LFinz/e4uOji7WXo4ePWp69eplfHx8jI+Pj+nVq5c5duxYifa3Z8+eAn/erFixwuX7y09+QdLV+5s5c6apWbOmKVOmjGnUqJFZuHChy/RXXGzGGHN91zwBAABwM+IzkgAAALCEIAkAAABLCJIAAACwhCAJAAAASwiSAAAAsIQgCQAAAEsIkgAAALCEIAkAAABLCJIAAACwhCAJAAAASwiSAAAAsOT/AAeKQxdSa6DGAAAAAElFTkSuQmCC",
      "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": 18,
   "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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f1WnTp3k5eUlT09PtWrVSikpKZKk9evX6/bbb1fFihXl7e2t1q1ba8OGDXmuYVpamu688065ubkpODhYn3766QWv+datW9WxY0d5eHjIz89PPXv21OHDhwscn5mZqYyMDKcXAAAomYpVkBw5cqQmTZqkMWPGaOvWrfr444/l5+enU6dOqUOHDvLx8dH69ev16aefasmSJXriiSecjl+2bJn27dunVatW6ZVXXlFMTIw6d+4sHx8frV27VlFRUYqKitLevXudjhs3bpxGjx6tDRs2yNXVVd27d9ewYcP02muvKT4+XikpKRo7duxl9/Pyyy8rIiJCGzdu1IABA9S/f39t27Yt37F//vmnbr31VpUtW1bLli1TYmKi+vbtq6ysLEnSiRMn1Lt3b8XHx+unn35SrVq11LFjR504ccJpnjFjxujee+/VL7/8okceeUTdu3dXcnJyvudMS0tT69at1bBhQ/38889auHChDhw4oAceeKDAniZOnChvb2/HKzAw8LKvCwAAKB5slmVZRV3EpThx4oQqVaqkN998U4899pjTvunTp2v48OHau3evypUrJ0n6/vvv1aVLF+3bt09+fn7q06ePVqxYod9//10uLmfzc926dVW5cmWtWrVKkpSdnS1vb2+99957euihh5Samqrg4GC999576tevnyRpzpw56t69u5YuXap27dpJkuLi4jRz5kxHCGzTpo0aNmyoKVOmOGrs2rWrypcvr5kzZ0o6uyLZqlUrzZ49W5JkWZb8/f0VGxurqKgox7k3btyohg0b6tlnn9WcOXO0fft2lS5d+qLXKzs7Wz4+Pvr444/VuXNnSWcftomKitK0adMc45o2bapGjRpp6tSpec45duxYrV27VosWLXKM/+OPPxQYGKjt27erdu3aec6bmZmpzMxMx/uMjAwFBgYqMHqeXOzuF637SqTGdbqq8wMAcL3IyMiQt7e30tPT5eXlVeC4YvMZyeTkZGVmZqp9+/b57mvQoIEjREpSixYtlJOTo+3bt8vPz0+SVL9+fUeIlCQ/Pz+FhoY63pcqVUq+vr46ePCg0/zh4eFOx0hSWFiY07bzj7kU585rs9nk7+9f4DxJSUlq1apVgSHy4MGDGjt2rJYtW6YDBw4oOztbp06d0p49e5zGNWvWLM/7gp7STkxM1PLly+Xh4ZFnX0pKSr5B0m63y2635zsfAAAoWYpNkHRzcytwn2VZstls+e47d/v5Icxms+W7LScnx2nbuWNy5zt/27nHuLi46PyF3jNnzuSp7VLOnetC/UtnPwN66NAhTZkyRTVq1JDdblezZs10+vTpCx6Xe9785OTkqEuXLpo0aVKefVWqVLnovAAAoGQrNp+RrFWrltzc3LR06dI8++rVq6ekpCSdPHnSse3HH3+Ui4tLvqtmV1ulSpWUlpbmeJ+dna0tW7Zc0Zzh4eGKj4/PN5BKUnx8vAYPHqyOHTuqfv36stvt+T4U89NPP+V5X7du3XznbNSokX799VcFBQXpxhtvdHqdu/oLAACuT8UmSJYtW1bDhw/XsGHD9OGHHyolJUU//fSTZsyYoR49eqhs2bLq3bu3tmzZouXLl2vQoEHq2bOn41b0v6ldu3b67rvv9N1332nbtm0aMGCAjh8/fkVzPvHEE8rIyNBDDz2kn3/+WTt37tTs2bO1fft2SdKNN96o2bNnKzk5WWvXrlWPHj3yXcX89NNP9f7772vHjh0aN26c1q1bl+ehpFwDBw7U0aNH1b17d61bt06///67fvjhB/Xt21fZ2dlX1A8AACj+ik2QlM4+cfzUU09p7NixCgkJ0YMPPqiDBw/K3d1dixYt0tGjR9WkSRPdd999at++vd58880iqbNv377q3bu3evXqpdatWys4OFht27a9ojl9fX21bNky/fXXX2rdurUaN26s6dOnO26Pv//++zp27Jhuuukm9ezZU4MHD1blypXzzBMbG6s5c+YoPDxcs2bN0kcffaR69erle86AgAD9+OOPys7OVmRkpEJDQzVkyBB5e3s7fdYUAABcn4rNU9sonnKf+uKpbQAAio9LfWqbZSUAAAAYIUgCAADACEESAAAARgiSAAAAMEKQBAAAgBGCJAAAAIwQJAEAAGCEIAkAAAAjBEkAAAAYIUgCAADACEESAAAARlyLugBcH7bERl7wd3UCAIDihxVJAAAAGCFIAgAAwAhBEgAAAEYIkgAAADBCkAQAAIARgiQAAACMECQBAABghCAJAAAAIwRJAAAAGCFIAgAAwAhBEgAAAEYIkgAAADBCkAQAAIARgiQAAACMECQBAABghCAJAAAAIwRJAAAAGCFIAgAAwAhBEgAAAEYIkgAAADBCkAQAAIARgiQAAACMECQBAABghCAJAAAAIwRJAAAAGCFIAgAAwAhBEgAAAEYIkgAAADBCkAQAAIARgiQAAACMECQBAABghCAJAAAAIwRJAAAAGCFIAgAAwAhBEgAAAEYIkgAAADDiWtQF4PoQOm6RXOzuV23+1LhOV21uAACQP1YkAQAAYIQgCQAAACMESQAAABghSAIAAMAIQRIAAABGCJIAAAAwQpAEAACAEYIkAAAAjBAkAQAAYIQgCQAAACMESQAAABghSAIAAMAIQRKXrE2bNoqOji7qMgAAwDWCIHmN6tOnj7p27VrUZQAAABSIIFnCnT59uqhLAAAAJRRBshC0adNGgwYNUnR0tHx8fOTn56d3331XJ0+e1KOPPipPT0/dcMMNWrBggSQpOztb/fr1U3BwsNzc3FSnTh299tprjvliYmI0a9YsffXVV7LZbLLZbFqxYoUk6c8//9SDDz4oHx8f+fr66u6771Zqaqrj2NyVzIkTJyogIEC1a9dWamqqbDabPv/8c7Vt21bu7u5q0KCBEhISHMcdOXJE3bt3V7Vq1eTu7q6wsDB98skn/8r1AwAAxRNBspDMmjVLFStW1Lp16zRo0CD1799f999/v5o3b64NGzYoMjJSPXv21KlTp5STk6Nq1app3rx52rp1q8aOHatnn31W8+bNkyQ9/fTTeuCBB9ShQwelpaUpLS1NzZs316lTp9S2bVt5eHho1apVWr16tTw8PNShQwenlcelS5cqOTlZixcv1rfffuvYPmrUKD399NNKSkpS7dq11b17d2VlZUmS/vnnHzVu3FjffvuttmzZoscff1w9e/bU2rVrL+s6ZGZmKiMjw+kFAABKJptlWVZRF1HctWnTRtnZ2YqPj5d0dsXR29tb3bp104cffihJ2r9/v6pUqaKEhAQ1bdo0zxwDBw7UgQMH9Nlnn0k6u7J4/Phxffnll44x77//viZPnqzk5GTZbDZJZ29dly9fXl9++aXuuOMO9enTRwsXLtSePXtUpkwZSVJqaqqCg4P13nvvqV+/fpKkrVu3qn79+kpOTlbdunXz7atTp04KCQnRSy+95OizYcOGmjJlSoHXIiYmRrGxsXm2B0bPk4vd/UKX8YqkxnW6anMDAHC9ycjIkLe3t9LT0+Xl5VXgOFYkC0l4eLjjn0uVKiVfX1+FhYU5tvn5+UmSDh48KEl6++23FRERoUqVKsnDw0PTp0/Xnj17LniOxMRE/fbbb/L09JSHh4c8PDxUoUIF/fPPP0pJSXGMCwsLc4TIgmqsUqWKUz3Z2dl64YUXFB4eLl9fX3l4eOiHH364aE3nGzlypNLT0x2vvXv3XtbxAACg+HAt6gJKitKlSzu9t9lsTttyVxBzcnI0b948Pfnkk3r55ZfVrFkzeXp66sUXX7zobeScnBw1btxYH330UZ59lSpVcvxzuXLlLlrjufVI0ssvv6xXX31VU6ZMUVhYmMqVK6fo6OjLfljHbrfLbrdf1jEAAKB4IkgWgfj4eDVv3lwDBgxwbDt3RVGSypQpo+zsbKdtjRo10ty5c1W5cuULLjOb1nT33XfrkUcekXQ2YO7cuVMhISGFeh4AAFBycGu7CNx44436+eeftWjRIu3YsUNjxozR+vXrncYEBQVp06ZN2r59uw4fPqwzZ86oR48eqlixou6++27Fx8dr165dWrlypYYMGaI//vjjimtavHix1qxZo+TkZP33v//V/v37r2hOAABQshEki0BUVJS6deumBx98ULfccouOHDnitDopSf/5z39Up04dx+cof/zxR7m7u2vVqlWqXr26unXrppCQEPXt21d///33Fa9QjhkzRo0aNVJkZKTatGkjf39/vhAdAABcEE9t46rKfeqLp7YBACg+eGobAAAAVxVBEgAAAEYIkgAAADBCkAQAAIARgiQAAACMECQBAABghCAJAAAAIwRJAAAAGCFIAgAAwAhBEgAAAEYIkgAAADBCkAQAAIAR16IuANeHLbGRF/yl7wAAoPhhRRIAAABGCJIAAAAwQpAEAACAEYIkAAAAjBAkAQAAYIQgCQAAACMESQAAABghSAIAAMAIQRIAAABGCJIAAAAwQpAEAACAEYIkAAAAjBAkAQAAYIQgCQAAACMESQAAABghSAIAAMCIa1EXgJLNsixJUkZGRhFXAgAALlXu39u5f48XhCCJq+rIkSOSpMDAwCKuBAAAXK4TJ07I29u7wP0ESVxVFSpUkCTt2bPngv8iljQZGRkKDAzU3r175eXlVdTl/Gvo+/rqW7p+e6fv66tv6frr3bIsnThxQgEBARccR5DEVeXicvZjuN7e3tfFf3jn8/Lyou/ryPXat3T99k7f15/rqfdLWQDiYRsAAAAYIUgCAADACEESV5Xdbte4ceNkt9uLupR/FX3T9/Xieu2dvq+vvqXru/cLsVkXe64bAAAAyAcrkgAAADBCkAQAAIARgiQAAACMECQBAABghCAJAAAAIwRJXDVTp05VcHCwypYtq8aNGys+Pr6oS7oiEydOVJMmTeTp6anKlSura9eu2r59u9MYy7IUExOjgIAAubm5qU2bNvr111+dxmRmZmrQoEGqWLGiypUrp7vuukt//PHHv9nKFZk4caJsNpuio6Md20pq33/++aceeeQR+fr6yt3dXQ0bNlRiYqJjf0nsOysrS6NHj1ZwcLDc3NxUs2ZNPffcc8rJyXGMKSl9r1q1Sl26dFFAQIBsNpu+/PJLp/2F1eexY8fUs2dPeXt7y9vbWz179tTx48evcncFu1DfZ86c0fDhwxUWFqZy5copICBAvXr10r59+5zmKGl9n++///2vbDabpkyZ4rS9OPZ91VnAVTBnzhyrdOnS1vTp062tW7daQ4YMscqVK2ft3r27qEszFhkZaX3wwQfWli1brKSkJKtTp05W9erVrb/++ssxJi4uzvL09LTmz59vbd682XrwwQetKlWqWBkZGY4xUVFRVtWqVa3FixdbGzZssNq2bWs1aNDAysrKKoq2Lsu6deusoKAgKzw83BoyZIhje0ns++jRo1aNGjWsPn36WGvXrrV27dplLVmyxPrtt98cY0pi388//7zl6+trffvtt9auXbusTz/91PLw8LCmTJniGFNS+v7++++tUaNGWfPnz7ckWV988YXT/sLqs0OHDlZoaKi1Zs0aa82aNVZoaKjVuXPnf6vNPC7U9/Hjx63bbrvNmjt3rrVt2zYrISHBuuWWW6zGjRs7zVHS+j7XF198YTVo0MAKCAiwXn31Vad9xbHvq40giavi5ptvtqKiopy21a1b1xoxYkQRVVT4Dh48aEmyVq5caVmWZeXk5Fj+/v5WXFycY8w///xjeXt7W2+//bZlWWf/kC5durQ1Z84cx5g///zTcnFxsRYuXPjvNnCZTpw4YdWqVctavHix1bp1a0eQLKl9Dx8+3GrZsmWB+0tq3506dbL69u3rtK1bt27WI488YllWye37/GBRWH1u3brVkmT99NNPjjEJCQmWJGvbtm1XuauLu1CgyrVu3TpLkmMhoCT3/ccff1hVq1a1tmzZYtWoUcMpSJaEvq8Gbm2j0J0+fVqJiYm64447nLbfcccdWrNmTRFVVfjS09MlSRUqVJAk7dq1S/v3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",
      "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": 344,
   "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": 342,
   "id": "d811bf5d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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5ZdftumX3H4O3ni7b2pqqvz9/dWpU6csNV24cEGurq4aMGCAddnFixet7xknJycVKlRI/fr1y3K3zVdffaWnnnpK3t7ecnNzU1hYmJ5//vlcrxfwKCOkAsB9kvnL6o2jZteuXVOzZs1Ut25dffvttxo5cqQyMjLUvHlzjR07Vh06dND333+vsWPHKi4uTrVr17aOGkrSiy++qPfee0+dO3fWt99+q2effVatWrXS+fPnc61n5cqVqlGjhpKSkjRp0iQtX75cb7zxhk6fPi1JeuGFF9SnTx9J14NV5m2hmbczvvvuu2rfvr1Kly6tRYsWac6cObp06ZJq1Kih/fv3W48za9YsdevWTaVKldLixYv1xhtvaPTo0frpp59yrXHNmjVKTU1VixYtcr/Auv5Lp729vZo2bZrteovFombNmuncuXPatm3bbe0zKChIFSpU0KZNm5SWlpZju+joaP3888/W8Hv69Gnt3btXrq6uiouLs7ZbtWqVChYsqMjIyGz3M23aNFWrVk0BAQE2t+Pe6MMPP1RcXJwmT56suXPn6vLly2rUqJGSk5Nv65wyMjKUlpZm85Ckc+fOSZKGDx+u77//XjNnzlRYWJhq166d62ctBwwYoOnTp6tv375asWKF5syZozZt2ujs2bPWNmvWrFG1atV04cIFffTRR/r2229Vrlw5tWvXTrNmzbqt2m92/vx5nT171vq+mjdvnpo3by4vLy/Nnz9fn332mc6fP6/atWtrw4YN1u06deqk2NhYvfXWW/rxxx/16aefKjo62qbem8XHx8vV1VWNGjWy9ktOt3o+99xzcnJyynJe6enp+vLLL9W0aVPlz59fkvTll1/qmWeekZeXl2bPnq1FixbJz89PMTExNkH1bmqWpBMnTihfvnwaO3asVqxYoQ8//FAODg566qmnsr3V9t///reOHj2qTz/9VB9//LEOHjyopk2bKj093dpm5MiRGjx4sOrXr6/Y2Fi98sorevHFF+/41t1XX31VhQoV0qBBg27Zbv/+/apUqZL27t2riRMnatmyZWrcuLH69u2rkSNHWtudPHlStWrV0oEDBzR9+nR98cUXunTpknr37p1ln4cOHVKVKlU0ffp0/fjjj3rrrbf0yy+/qHr16tb3cW4/B2/k6Oio5557TosXL9bFixdt1s2fP18pKSnq1q2bpOt/1KlVq5Zm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dC/4TCoAAAAA01i2bJk8PDyszxs2bKivvvpK/fr1sy4LDQ3V6NGj9corr2jatGnZ7icpKUkDBw5URESEJCk8PNy6bsKECerQoYN1n+Hh4ZoyZYpq1aql6dOny8XFJcf6goKC9Oqrr2rYsGHZTlC0YMEC2dnZ6dNPP5XFYpEkzZw5Uz4+Plq7dq2eeeYZTZ06VUOHDlXLli0lSR988IF++OEHm/08++yzNs8/++wz+fv7a//+/SpTpowKFCggScqXL58CAgKyrdXPz08NGjTQvHnzVK9ePUnSV199JT8/P+vzd955R0OGDLGOrIaFhWn06NEaNGiQhg8frqSkJAUEBCg6OlqOjo4qXLiwKleunOP1uR8IqXgounfvLi8vr7wuAwAAACZXp04dTZ8+3frc3d1dkrRmzRq9++672r9/vy5evKi0tDSlpKTo8uXL1jY3GjBggF544QXNmTNH0dHRatOmjYoVKyZJ2rZtm3777TfNnTvX2t4wDGVkZOjw4cMqVarULWscPHiwZsyYoc8//1xt27a1WZe5b09PT5vlKSkpOnTokJKTk3X69GmboGdvb68KFSrY3JZ76NAhvfnmm9q8ebP+/PNP67qkpCSVKVPmlvXdqGPHjnrppZc0bdo0OTs7a+7cufrXv/4le3t7a70JCQnWkVNJSk9PV0pKiq5cuaI2bdpo8uTJCgsLU4MGDdSoUSM1bdpUDg4PLkoSUgEAAACYhru7e5aZfI8ePapGjRqpR48eGj16tPz8/LRhwwZ1795dqamp2e5nxIgR6tChg77//nstX75cw4cP14IFC6y3zL788svZfraycOHCudbo4+OjoUOHauTIkWrSpInNuoyMDFWoUMEmAGfKHP2UZB1lzXTzjLxNmzZVSEiIPvnkEwUFBSkjI0NlypSx3jJ8u5o2baqMjAx9//33qlSpktavX69JkybZ1Dty5Ei1atUqy7YuLi4KCQnRgQMHFBcXp1WrVqlnz56aMGGC1q1bZ719+n4jpAIAAAAwta1btyotLU0TJ06Und31aXUWLVqU63YlSpRQiRIl1L9/f7Vv314zZ85Uy5YtVb58ee3bt++evtamT58+mjJlit5//32b5eXLl9fChQvl7++f452EBQsW1JYtW1SjRg1J10cub/wqmbNnzyoxMVEzZsywttmwYYPNPpycnKzb3oqrq6tatWql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",
      "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": 339,
   "id": "d4731a6a",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "non-communicable    1517\n",
      "external             195\n",
      "aids-tb              153\n",
      "communicable          84\n",
      "maternal              80\n",
      "Name: count, dtype: int64\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA6kAAAIhCAYAAACsS/yyAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABtuklEQVR4nO3dd3yN9///8efJ3pMkQpDYSmwtsUdjr1JFidVPU5vW+rQ121qlSksnUaVoqRY1Ytas2CtV9UGo1RqJUmRcvz/8cr6OJDa5yuN+u53bzbmu93lfr+t6n4Sn9/tcx2IYhiEAAAAAAEzALrsLAAAAAAAgHSEVAAAAAGAahFQAAAAAgGkQUgEAAAAApkFIBQAAAACYBiEVAAAAAGAahFQAAAAAgGkQUgEAAAAApkFIBQAAAACYBiEVAO5RTEyMLBaL9eHg4KA8efKoU6dO+uOPPx5LDfnz51fHjh2tz9euXSuLxaK1a9feUz+bNm3SsGHDdPHixYdanyR17NhR+fPnv6u2aWlpmjlzpurUqaMcOXLI0dFRAQEBatSokRYtWqS0tDSb9sePH1ePHj1UoEABubi4yNfXVzVq1NCsWbNkGIZN26NHj9qMl6Ojo/z9/VWhQgX17dtX+/fvf1innKn098vRo0et22bPnq2JEydmaJte6/vvv39fx0p/H2T2aNmy5T31ZbFYNGzYsPuq437dWrO3t7dq1KihJUuWPJLjZfYefe+997Rw4cIMbe/3Z+xJU6NGDdWoUeOO7fLnzy+LxaLo6OgM+9Kv5XffffcIKrx3t/s9eLfnC+DhIqQCwH2aPn26Nm/erNjYWL3yyiv65ptvVLVqVV2+fPmx11K2bFlt3rxZZcuWvafXbdq0ScOHD38kIfVuXb16VQ0aNFBUVJQCAgI0depUrV69Wp988omCg4PVqlUrLVq0yNp+48aNCg8P1w8//KDevXtr2bJliomJUe7cufXyyy+rTZs2GUKtJPXs2VObN2/WunXrNHPmTDVr1kw//vijSpUqpXHjxj2y82vYsKE2b96sXLlyWbdlFVIflvfee0+bN2+2eYwaNeqRHe9hatmypTZv3qyNGzfq448/1unTp9W4ceNHElTffvttff/99zbbsgqp9/sz9rT78ssvdfDgwewu47Zu93twypQpmjJlyuMvCnjKOWR3AQDwb1WiRAmVL19eklSzZk2lpqZq5MiRWrhwodq1a5fpa65cuSI3N7eHXouXl5eee+65h97v49CvXz8tX75cM2bMUIcOHWz2tWjRQv3799c///wjSbp48aJatGghb29v/fLLLwoMDLS2bdq0qcLDwzVo0CCVLl1agwYNsukrb968NteoQYMG6tevn1q0aKEBAwaoRIkSql+//kM/v5w5cypnzpwPvd/bKVSo0L/2/RAYGGitvXLlyqpUqZIKFiyoiRMnqmHDhg/1WAUKFLjrtv/mn7HsUqlSJR04cED//e9/NX/+/Owu574UL148u0sAnkrMpALAQ5L+D9hjx45JurGU0MPDQ3v37tXzzz8vT09P1a5dW5J0/fp1vfPOOypatKicnZ2VM2dOderUSX/++adNn8nJyRowYICCgoLk5uamKlWqaOvWrRmOndVSxF9++UWNGzeWv7+/XFxcVKBAAfXp00eSNGzYMPXv31+SFBoaal1ieXMfc+fOVaVKleTu7i4PDw9FRkZq586dGY4fExOjIkWKyNnZWcWKFdNXX311V9fs9OnT+uKLLxQZGZkhoKYrVKiQwsPDJUlffPGFzp49q9GjR9sE1HQDBgxQ0aJFNW7cOCUnJ9/x+K6urvryyy/l6Oh4x9nUChUqZAhJJUuWlMViUVxcnHXbggULZLFYtHfvXkkZl/umL189duyYzdLWW02YMEGhoaHy8PBQpUqVtGXLljuez538+eef6tatm4oXLy4PDw8FBASoVq1aWr9+/R1fe+XKFb3xxhsKDQ2Vi4uL/Pz8VL58eX3zzTc27bZt26YmTZrIz89PLi4uKlOmjObNm3ffNRcoUEA5c+a0/lxJ0o8//qhKlSrJzc1Nnp6eqlu3rjZv3pzhXP/zn/8oJCTE+jMWERGhlStXWtvcutzXYrHo8uXLmjFjhnVc0pd63vozNnHiRFksFv3+++8Zah44cKCcnJz0119/WbetXLlStWvXlpeXl9zc3BQREaFVq1bdc82Z+f3339WpUycVKlRIbm5uyp07txo3bmx9D6ZLP4dvvvlGb775poKDg+Xl5aU6depkmO00DENjx45Vvnz55OLiorJly2rp0qW3reNWfn5+GjRokBYsWHBX799Dhw6pbdu2CggIsP4u+fjjjzO0279/v55//nm5ubkpZ86c6t69u5YsWZLh91dsbKyaNm2qPHnyyMXFRQULFtSrr75qMy53+j1483Lf5ORkBQQEqH379hlqunjxolxdXdWvXz/rtqSkJOvPjJOTk3Lnzq0+ffpkWG3z7bff6tlnn5W3t7fc3NwUFhamzp073/F6AU8yQioAPCTp/1i9edbs+vXratKkiWrVqqUffvhBw4cPV1pampo2barRo0erbdu2WrJkiUaPHq3Y2FjVqFHDOmsoSa+88oref/99dejQQT/88INeeOEFtWjRQhcuXLhjPcuXL1fVqlWVkJCgCRMmaOnSpXrrrbd05swZSVLXrl3Vs2dPSTeCVfqy0PTljO+9957atGmj4sWLa968eZo5c6YuXbqkqlWr6sCBA9bjxMTEqFOnTipWrJjmz5+vt956SyNHjtTq1avvWOOaNWuUnJysZs2a3fkC68Y/Ou3t7dW4ceNM91ssFjVp0kTnz5/X9u3b76rP4OBglStXTps2bVJKSkqW7erUqaOff/7ZGn7PnDmjffv2ydXVVbGxsdZ2K1euVGBgoEqWLJlpP1OmTFFERISCgoJsluPe7OOPP1ZsbKwmTpyoWbNm6fLly2rQoIESExPv6pzS0tKUkpJi85Ck8+fPS5KGDh2qJUuWaPr06QoLC1ONGjXu+FnLfv36aerUqerVq5eWLVummTNnqlWrVjp37py1zZo1axQREaGLFy/qk08+0Q8//KDSpUurdevWiomJuavab3XhwgWdO3fO+nM1e/ZsNW3aVF5eXvrmm2/05Zdf6sKFC6pRo4Y2bNhgfV379u21cOFCDRkyRCtWrNAXX3yhOnXq2NR7q82bN8vV1VUNGjSwjktWSz1ffvllOTk5ZTiv1NRUff3112rcuLFy5MghSfr666/1/PPPy8vLSzNmzNC8efPk5+enyMhIm6B6PzVL0smTJ+Xv76/Ro0dr2bJl+vjjj+Xg4KBnn30206W2//3vf3Xs2DF98cUX+uyzz3To0CE1btxYqamp1jbDhw/XwIEDVbduXS1cuFCvvfaaXnnllXteutu7d2/lzp1bAwYMuG27AwcOqEKFCtq3b5/Gjx+vxYsXq2HDhurVq5eGDx9ubXfq1ClVr15dBw8e1NSpU/XVV1/p0qVL6tGjR4Y+Dx8+rEqVKmnq1KlasWKFhgwZol9++UVVqlSx/hzf6ffgzRwdHfXyyy9r/vz5SkpKstn3zTff6OrVq+rUqZOkG/+pU716dc2YMUO9evXS0qVLNXDgQMXExKhJkybWz85v3rxZrVu3VlhYmObMmaMlS5ZoyJAht/1dBDwVDADAPZk+fbohydiyZYuRnJxsXLp0yVi8eLGRM2dOw9PT0zh9+rRhGIYRFRVlSDKmTZtm8/pvvvnGkGTMnz/fZntcXJwhyZgyZYphGIYRHx9vSDL69u1r027WrFmGJCMqKsq6bc2aNYYkY82aNdZtBQoUMAoUKGD8888/WZ7LuHHjDEnGkSNHbLYnJCQYDg4ORs+ePW22X7p0yQgKCjJefPFFwzAMIzU11QgODjbKli1rpKWlWdsdPXrUcHR0NPLly5flsQ3DMEaPHm1IMpYtW3bbdumKFi1qBAUF3bbN1KlTDUnG3LlzDcMwjCNHjhiSjHHjxmX5mtatWxuSjDNnzmTZZuXKlYYk4+effzYMwzC+/vprw9PT0+jWrZtRs2ZNa7tChQoZbdu2tT5Pf7/cfI0bNmyY6bVJr7VkyZJGSkqKdfvWrVsNScY333xz23NPfx9k9jh06FCG9ikpKUZycrJRu3Zto3nz5jb7JBlDhw61Pi9RooTRrFmz2x6/aNGiRpkyZYzk5GSb7Y0aNTJy5cplpKam3vb1koxu3boZycnJxvXr1434+Hijfv36hiTj448/tr7fSpYsadPXpUuXjICAAKNy5crWbR4eHkafPn1ue7yoqKgM4+Du7m7zs5Uus5+xFi1aGHny5LGp5aeffjIkGYsWLTIMwzAuX75s+Pn5GY0bN7bpLzU11ShVqpRRsWLFe6r5bqSkpBjXr183ChUqZPP7I/0cGjRoYNN+3rx5hiRj8+bNhmEYxoULFwwXF5cM74mNGzcakozq1avfsYZ8+fIZDRs2NAzDMD7//HOba5Jex7fffmttHxkZaeTJk8dITEy06adHjx6Gi4uLcf78ecMwDKN///6GxWIx9u/fb9MuMjIyw/jcLC0tzUhOTjaOHTtmSDJ++OEH676sfg8ahmFUr17d5nz37NljSDI+++wzm3YVK1Y0ypUrZ30+atQow87OzoiLi7Np99133xmSjJ9++skwDMN4//33DUnGxYsXM60beFoxkwoA9+m5556To6OjPD091ahRIwUFBWnp0qUZlqG+8MILNs8XL14sHx8fNW7c2Gamq3Tp0goKCrLOaK1Zs0aSMny+9cUXX5SDw+1vKfDbb7/p8OHD6tKli1xcXO753JYvX66UlBR16NDBpkYXFxdVr17dWuPBgwd18uRJtW3b1mbJar58+VS5cuV7Pu7DYPz/GYrMltDe6TW3ExERIRcXF+vSy/SZ73r16mnTpk26cuWKjh8/rkOHDqlOnTr3V/z/17BhQ9nb21ufpy93vnnJ6+2MGTNGcXFxNo+QkBBJ0ieffKKyZcvKxcVFDg4OcnR01KpVqxQfH3/bPitWrKilS5dq0KBBWrt2rc2Mv3RjJcGvv/5qfb/e/L5p0KCBTp06dVezcFOmTJGjo6OcnJxUrFgxbdq0SSNGjFC3bt2s77f27dvLzu7//gnj4eGhF154QVu2bNGVK1es9cbExOidd97Rli1b7mr5973q1KmTTpw4YbMcd/r06QoKCrJ+vnnTpk06f/68oqKibK5JWlqa6tWrp7i4OOvyz/utOSUlRe+9956KFy8uJycnOTg4yMnJSYcOHcp0XJs0aWLz/Nb31+bNm3X16tUMv3sqV66sfPny3eXV+T+dOnVS8eLFNWjQoExvanb16lWtWrVKzZs3l5ubW4b3ztWrV63LhdetW6cSJUpk+KxomzZtMvR79uxZRUdHKyQkxPpeT6//Tu/3rJQsWVLlypXT9OnTrdvi4+O1detWmyW6ixcvVokSJVS6dGmb84mMjLRZTlyhQgVJN36vz5s377HdIR4wO0IqANynr776SnFxcdq5c6dOnjypPXv2KCIiwqaNm5ubvLy8bLadOXNGFy9elJOTkxwdHW0ep0+ftn5eKn2JX1BQkM3rHRwc5O/vf9va0j/bmidPnvs6t/QlwRUqVMhQ49y5c+9YY1bbbpU3b15J0pEjR+6qrrx58+rPP/+87R2U0z/7mR7K7saxY8fk7OwsPz+/LNu4uLjYfD5w1apVqlu3rmrUqKHU1FStX7/euuz3QUPqrePr7OwsSRmCYVbCwsJUvnx5m4ezs7MmTJig1157Tc8++6zmz5+vLVu2KC4uTvXq1btj35MmTdLAgQO1cOFC1axZU35+fmrWrJkOHTok6f/eM2+88UaG90y3bt0kyeazgFl58cUXFRcXp23btungwYM6d+6c3n77bUn/9367+U7J6YKDg5WWlmZdCj937lxFRUXpiy++UKVKleTn56cOHTro9OnTd3UN70b9+vWVK1cua2C5cOGCfvzxR3Xo0MH6nwzp16Vly5YZrsuYMWNkGIZ1Gfb91tyvXz+9/fbbatasmRYtWqRffvlFcXFxKlWqVKbjeqf314P+XN/K3t5e7733nvbv368ZM2Zk2H/u3DmlpKRo8uTJGa5RgwYNJMnmd05mn0e/dVtaWpqef/55LViwQAMGDNCqVau0detWa9i925+lzHTu3FmbN2/Wr7/+KunGf0w4OzvbBOUzZ85oz549Gc7H09NThmFYz6datWpauHCh9T8F8+TJoxIlSmT4rDfwtOHuvgBwn4oVK2a9u29WMpvNy5Ejh/z9/bVs2bJMX+Pp6Snp//4hefr0aeXOndu6PyUl5Y6fUUv//N6JEydu2y4r6Z+l++677247c3Jzjbe6mzBQs2ZNOTo6auHChZl+n+Kt6tatqxUrVmjRokV66aWXMuw3DEM//vij/Pz8VK5cuTv2J0l//PGHtm/frurVq99xhrp27doaMmSItm7dqhMnTqhu3bry9PRUhQoVFBsbq5MnT6pw4cL3FJAfp6+//lo1atTQ1KlTbbZfunTpjq91d3fX8OHDNXz4cJ05c8Y6q9q4cWP9+uuv1vfM4MGD1aJFi0z7KFKkyB2PkzNnzix/rtLfb6dOncqw7+TJk7Kzs5Ovr6+kG+/hiRMnauLEiUpISNCPP/6oQYMG6ezZs1n+7N0re3t7tW/fXpMmTdLFixc1e/ZsXbt2zfq5xPQ6JGny5MlZ3h04PWDdb81ff/21OnTooPfee89m+19//SUfH597Pq87/Vzf7fcf36xp06aKiIjQ0KFD9dlnn9ns8/X1tV7L7t27Z/r60NBQa23pwf/Wum62b98+7d69WzExMYqKirJuz+xGV/eqTZs26tevn2JiYvTuu+9av9Iq/b0n3RhLV1dXTZs2LdM+0t8X0o1r07RpU127dk1btmzRqFGj1LZtW+XPn1+VKlV64HqBfyNmUgHgMWvUqJHOnTun1NTUDLNd5cuXt/5DPv2OkrNmzbJ5/bx58+54U43ChQurQIECmjZtmq5du5Zlu6xm6CIjI+Xg4KDDhw9nWmN6iChSpIhy5cqlb775xmbJ7LFjx7Rp06Y7XougoCB17dpVy5cvz/KOwIcPH9aePXsk3bjJSUBAgAYPHqyzZ89maDt27Fj9+uuvGjBggBwdHe94/H/++Uddu3ZVSkrKHW/sIt2YIU1JSdHbb7+tPHnyqGjRotbtK1eu1OrVq+9qFtXZ2fmBZnLul8VisY55uj179mS4cdOdBAYGqmPHjmrTpo0OHjyoK1euqEiRIipUqJB2796d5Xsm/T9g7leRIkWUO3duzZ492+b9dvnyZc2fP996x99b5c2bVz169FDdunW1Y8eO2x7jXsemU6dOunr1qr755hvFxMSoUqVK1veFdGOZuI+Pjw4cOJDldXFycnqgmjMb1yVLltz30tHnnntOLi4uGX73bNq06a6XnGdmzJgxOn78uCZNmmSz3c3NTTVr1tTOnTsVHh6e6TVKD87Vq1fXvn37bG7eJklz5syxeZ7+H4S3XpdPP/00Q133ulLB19dXzZo101dffaXFixfr9OnTGe7G26hRIx0+fFj+/v6Znk9mQd/Z2VnVq1fXmDFjJCnTO6kDTwtmUgHgMXvppZc0a9YsNWjQQL1791bFihXl6OioEydOaM2aNWratKmaN2+uYsWK6eWXX9bEiRPl6OioOnXqaN++fXr//fczLCHOzMcff6zGjRvrueeeU9++fZU3b14lJCRo+fLl1n98pt+B9sMPP1RUVJQcHR1VpEgR5c+fXyNGjNCbb76p//3vf6pXr558fX115swZbd261TqrZmdnp5EjR6pr165q3ry5XnnlFV28eFHDhg2762WBEyZM0P/+9z917NhRy5cvV/PmzRUYGKi//vpLsbGxmj59uubMmaPw8HD5+PhowYIFatSokcqVK6f+/furVKlSSkpK0ty5czVr1iy1bt3a+pUSN0tISNCWLVuUlpamxMRE7dy5U9OmTdOxY8c0fvx4Pf/883estVy5cvL19dWKFStsZsvq1KmjkSNHWv98JyVLltSCBQs0depUlStXTnZ2dneclX8YGjVqpJEjR2ro0KHWO6SOGDFCoaGhd/yPj2effVaNGjVSeHi4fH19FR8fr5kzZ9oEw08//VT169dXZGSkOnbsqNy5c+v8+fOKj4/Xjh079O233z5Q/XZ2dho7dqzatWunRo0a6dVXX9W1a9c0btw4Xbx4UaNHj5YkJSYmqmbNmmrbtq2KFi0qT09PxcXFadmyZVnO8qYrWbKk1q5dq0WLFilXrlzy9PS87Qxw0aJFValSJY0aNUrHjx/PMEvo4eGhyZMnKyoqSufPn1fLli0VEBCgP//8U7t379aff/6pqVOnPlDNjRo1UkxMjIoWLarw8HBt375d48aNu+/l/r6+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pZde0qVLl2573GvXrmnAgAEKCQmRs7OzChUqpC+//NK6f926dapYsaKcnZ2VK1cuDRo0SCkpKTZ19+zZU3369JGvr68CAwP12Wef6fLly+rUqZM8PT1VoEABLV261Pqa9OWvy5cvV5kyZeTq6qpatWrp7NmzWrp0qYoVKyYvLy+1adNGV65csb4uf/78mjhxok39pUuXtrlOFotFX3zxhZo3by43NzcVKlRIP/74Y4Zj37z0duPGjapevbrc3Nzk6+uryMhIXbhwQZK0bNkyValSRT4+PvL391ejRo10+PDhDNfx119/VeXKleXi4qJnnnlGa9euve1137Rpk6pVqyZXV1eFhISoV69eunz58m1fAwAAAAAP4p6X+86YMUPu7u765ZdfNHbsWI0YMUKxsbEyDEPNmjXT+fPntW7dOsXGxurw4cNq3bq1zesPHz6shQsXavHixVq8eLHWrVun0aNH3/aYHTp00Jw5czRp0iTFx8frk08+kYeHhyTpjz/+UIMGDVShQgXt3r1bU6dO1Zdffql33nknQ905cuTQ1q1b1bNnT7322mtq1aqVKleurB07digyMlLt27e3CZzSjWD90UcfadOmTTp+/LhefPFFTZw4UbNnz9aSJUsUGxuryZMn3+tl1PDhw/Xiiy9qz549atCggdq1a6fz589n2nbXrl2qXbu2nnnmGW3evFkbNmxQ48aNlZqaKkm6fPmy+vXrp7i4OK1atUp2dnZq3ry50tLSbPrp37+/Xn/9de3cuVOVK1dWkyZNdO7cuUyPuXfvXkVGRqpFixbas2eP5s6dqw0bNqhHjx63Pa9r164pKSnJ5gEAAAAAd8tiGIZxt41r1Kih1NRUrV+/3rqtYsWKqlWrlmrXrq369evryJEjCgkJkSQdOHBAzzzzjLZu3aoKFSpo2LBhGjdunE6fPi1PT09J0oABA/Tzzz9ry5YtmR7zt99+U5EiRRQbG6s6depk2P/mm29q/vz5io+Pl8VikSRNmTJFAwcOVGJiouzs7DLUnZqaKm9vb7Vo0UJfffWVJOn06dPKlSuXNm/erOeee05r165VzZo1tXLlStWuXVuSNHr0aA0ePFiHDx9WWFiYJCk6OlpHjx7VsmXLJN2YSe3Tp4/69OljrbF06dJq1qyZdTbVYrHorbfe0siRIyXdCJmenp766aefVK9ePeuxL1y4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AACYBiEVAAAAAGAahFQAAAAAgGkQUgEAAAAApuGQ3QXg6RBXvr3c3d2zu4xMRUREZHcJAAAAAP4/ZlIBAAAAAKZBSAUAAAAAmAYhFQAAAABgGoRUAAAAAIBpEFIBAAAAAKZBSDWpo0ePymKxaNeuXQ+tT4vFooULFz7WYwIAAADAveAraEwqJCREp06dUo4cObK7FAAAAAB4bAipJmVvb6+goKDsLgMAAAAAHqt/1XLftLQ0jRkzRgULFpSzs7Py5s2rd999V5K0d+9e1apVS66urvL399d//vMf/f3339bXduzYUc2aNdN7772nwMBA+fj4aPjw4UpJSVH//v3l5+enPHnyaNq0adbXpC9/nTdvnqpWrSpXV1dVqFBBv/32m+Li4lS+fHl5eHioXr16+vPPP62vq1Gjhvr06WNTe7NmzdSxY0fr8/z58+u9995T586d5enpqbx58+qzzz7LcOybl97u379fDRs2lJeXlzw9PVW1alUdPnxYkhQXF6e6desqR44c8vb2VvXq1bVjx44M1/DUqVOqX7++XF1dFRoaqm+//fa21/zAgQNq0KCBPDw8FBgYqPbt2+uvv/667WsAAAAA4H79q0Lq4MGDNWbMGL399ts6cOCAZs+ercDAQF25ckX16tWTr6+v4uLi9O2332rlypXq0aOHzetXr16tkydP6ueff9aECRM0bNgwNWrUSL6+vvrll18UHR2t6OhoHT9+3OZ1Q4cO1VtvvaUdO3bIwcFBbdq00YABA/Thhx9q/fr1Onz4sIYMGXLP5zN+/HiVL19eO3fuVLdu3fTaa6/p119/zbTtH3/8oWrVqsnFxUWrV6/W9u3b1blzZ6WkpEiSLl26pKioKK1fv15btmxRoUKF1KBBA126dMmmn7ffflsvvPCCdu/erZdffllt2rRRfHx8psc8deqUqlevrtKlS2vbtm1atmyZzpw5oxdffDHLc7p27ZqSkpJsHgAAAABwt/41y30vXbqkDz/8UB999JGioqIkSQUKFFCVKlX0+eef659//tFXX30ld3d3SdJHH32kxo0ba8yYMQoMDJQk+fn5adKkSbKzs1ORIkU0duxYXblyRf/9738l3QjBo0eP1saNG/XSSy9Zj/3GG28oMjJSktS7d2+1adNGq1atUkREhCSpS5cuiomJuedzatCggbp16yZJGjhwoD744AOt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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    1935\n",
      "external              90\n",
      "maternal               4\n",
      "Name: count, dtype: int64\n"
     ]
    },
    {
     "data": {
      "image/png": "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5ZdftumX3H4O3ni7b2pqqvz9/dWpU6csNV24cEGurq4aMGCAddnFixet7xknJycVKlRI/fr1y3K3zVdffaWnnnpK3t7ecnNzU1hYmJ5//vlcrxfwKCOkAsB9kvnL6o2jZteuXVOzZs1Ut25dffvttxo5cqQyMjLUvHlzjR07Vh06dND333+vsWPHKi4uTrVr17aOGkrSiy++qPfee0+dO3fWt99+q2effVatWrXS+fPnc61n5cqVqlGjhpKSkjRp0iQtX75cb7zxhk6fPi1JeuGFF9SnTx9J14NV5m2hmbczvvvuu2rfvr1Kly6tRYsWac6cObp06ZJq1Kih/fv3W48za9YsdevWTaVKldLixYv1xhtvaPTo0frpp59yrXHNmjVKTU1VixYtcr/Auv5Lp729vZo2bZrteovFombNmuncuXPatm3bbe0zKChIFSpU0KZNm5SWlpZju+joaP3888/W8Hv69Gnt3btXrq6uiouLs7ZbtWqVChYsqMjIyGz3M23aNFWrVk0BAQE2t+Pe6MMPP1RcXJwmT56suXPn6vLly2rUqJGSk5Nv65wyMjKUlpZm85Ckc+fOSZKGDx+u77//XjNnzlRYWJhq166d62ctBwwYoOnTp6tv375asWKF5syZozZt2ujs2bPWNmvWrFG1atV04cIFffTRR/r2229Vrlw5tWvXTrNmzbqt2m92/vx5nT171vq+mjdvnpo3by4vLy/Nnz9fn332mc6fP6/atWtrw4YN1u06deqk2NhYvfXWW/rxxx/16aefKjo62qbem8XHx8vV1VWNGjWy9ktOt3o+99xzcnJyynJe6enp+vLLL9W0aVPlz59fkvTll1/qmWeekZeXl2bPnq1FixbJz89PMTExNkH1bmqWpBMnTihfvnwaO3asVqxYoQ8//FAODg566qmnsr3V9t///reOHj2qTz/9VB9//LEOHjyopk2bKj093dpm5MiRGjx4sOrXr6/Y2Fi98sorevHFF+/41t1XX31VhQoV0qBBg27Zbv/+/apUqZL27t2riRMnatmyZWrcuLH69u2rkSNHWtudPHlStWrV0oEDBzR9+nR98cUXunTpknr37p1ln4cOHVKVKlU0ffp0/fjjj3rrrbf0yy+/qHr16tb3cW4/B2/k6Oio5557TosXL9bFixdt1s2fP18pKSnq1q2bpOt/1KlVq5Zm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dC/4TCoAAAAA01i2bJk8PDyszxs2bKivvvpK/fr1sy4LDQ3V6NGj9corr2jatGnZ7icpKUkDBw5URESEJCk8PNy6bsKECerQoYN1n+Hh4ZoyZYpq1aql6dOny8XFJcf6goKC9Oqrr2rYsGHZTlC0YMEC2dnZ6dNPP5XFYpEkzZw5Uz4+Plq7dq2eeeYZTZ06VUOHDlXLli0lSR988IF++OEHm/08++yzNs8/++wz+fv7a//+/SpTpowKFCggScqXL58CAgKyrdXPz08NGjTQvHnzVK9ePUnSV199JT8/P+vzd955R0OGDLGOrIaFhWn06NEaNGiQhg8frqSkJAUEBCg6OlqOjo4qXLiwKleunOP1uR8IqXgounfvLi8vr7wuAwAAACZXp04dTZ8+3frc3d1dkrRmzRq9++672r9/vy5evKi0tDSlpKTo8uXL1jY3GjBggF544QXNmTNH0dHRatOmjYoVKyZJ2rZtm3777TfNnTvX2t4wDGVkZOjw4cMqVarULWscPHiwZsyYoc8//1xt27a1WZe5b09PT5vlKSkpOnTokJKTk3X69GmboGdvb68KFSrY3JZ76NAhvfnmm9q8ebP+/PNP67qkpCSVKVPmlvXdqGPHjnrppZc0bdo0OTs7a+7cufrXv/4le3t7a70JCQnWkVNJSk9PV0pKiq5cuaI2bdpo8uTJCgsLU4MGDdSoUSM1bdpUDg4PLkoSUgEAAACYhru7e5aZfI8ePapGjRqpR48eGj16tPz8/LRhwwZ1795dqamp2e5nxIgR6tChg77//nstX75cw4cP14IFC6y3zL788svZfraycOHCudbo4+OjoUOHauTIkWrSpInNuoyMDFWoUMEmAGfKHP2UZB1lzXTzjLxNmzZVSEiIPvnkEwUFBSkjI0NlypSx3jJ8u5o2baqMjAx9//33qlSpktavX69JkybZ1Dty5Ei1atUqy7YuLi4KCQnRgQMHFBcXp1WrVqlnz56aMGGC1q1bZ719+n4jpAIAAAAwta1btyotLU0TJ06Und31aXUWLVqU63YlSpRQiRIl1L9/f7Vv314zZ85Uy5YtVb58ee3bt++evtamT58+mjJlit5//32b5eXLl9fChQvl7++f452EBQsW1JYtW1SjRg1J10cub/wqmbNnzyoxMVEzZsywttmwYYPNPpycnKzb3oqrq6tatWql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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    1688\n",
      "external             195\n",
      "maternal              79\n",
      "aids-tb               40\n",
      "communicable          27\n",
      "Name: count, dtype: int64\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA6kAAAIhCAYAAACsS/yyAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABuq0lEQVR4nO3dd3gUVf/+8XvTe4UQSoCEjhC6CgFCNfSmiIAQiiXSQWmP0lWa8CAoKBZApCqIAkoIVaqE3iIiDxBQilISikDK/P7wl/2ypFECGeX9uq69LnbmzJnPnOwGbs7ZWYthGIYAAAAAADABu9wuAAAAAACANIRUAAAAAIBpEFIBAAAAAKZBSAUAAAAAmAYhFQAAAABgGoRUAAAAAIBpEFIBAAAAAKZBSAUAAAAAmAYhFQAAAABgGoRUALhHs2fPlsVisT4cHBxUqFAhde3aVb/99tsjqaFo0aLq0qWL9fmGDRtksVi0YcOGe+pn69atGjlypC5fvpyj9UlSly5dVLRo0btqm5qaqrlz56pBgwbKkyePHB0dFRAQoGbNmmn58uVKTU21aX/q1Cn16tVLxYoVk4uLi3x9fVWnTh3NmzdPhmHYtD1x4oTNz8vR0VH+/v6qVq2a+vfvr0OHDuXUJWco7fVy4sQJ67b58+drypQp6dqm1free+/d17nSXgcZPZ577rl76stisWjkyJH3Vcf9urNmb29v1alTRytXrnwo58voNfruu+9q2bJl6dre73vs36ZOnTqqU6dOtu2KFi0qi8WiqKiodPvSxvLrr79+CBXeu6x+D97t9QLIWYRUALhPs2bN0rZt2xQTE6OXX35ZCxYsUK1atXTt2rVHXkvlypW1bds2Va5c+Z6O27p1q0aNGvVQQurdunHjhpo0aaLIyEgFBARoxowZWrdunT766CMVKFBAbdu21fLly63tt2zZotDQUH377bfq27evVq1apdmzZ6tgwYJ68cUX1b59+3ShVpJ69+6tbdu2aePGjZo7d65atWql7777ThUqVNDEiRMf2vU1bdpU27ZtU/78+a3bMgupOeXdd9/Vtm3bbB5jx459aOfLSc8995y2bdumLVu26MMPP9TZs2fVvHnzhxJUhw0bpm+++cZmW2Yh9X7fY4+7zz77TEeOHMntMrKU1e/B6dOna/r06Y++KOAx55DbBQDAP1W5cuVUtWpVSVLdunWVkpKiMWPGaNmyZerYsWOGx1y/fl1ubm45XouXl5eefvrpHO/3URgwYICio6M1Z84cde7c2WZfmzZtNHDgQP3111+SpMuXL6tNmzby9vbWTz/9pHz58lnbtmzZUqGhoRoyZIgqVqyoIUOG2PRVuHBhmzFq0qSJBgwYoDZt2mjQoEEqV66cGjdunOPXlzdvXuXNmzfH+81KiRIl/rGvh3z58llrr1GjhqpXr67ixYtrypQpatq0aY6eq1ixYnfd9p/8Hsst1atX1+HDh/Wf//xHS5Ysye1y7kvZsmVzuwTgscRMKgDkkLR/wJ48eVLS30sJPTw8dODAAT3zzDPy9PRU/fr1JUm3bt3S22+/rdKlS8vZ2Vl58+ZV165d9ccff9j0mZSUpEGDBikwMFBubm6qWbOmduzYke7cmS1F/Omnn9S8eXP5+/vLxcVFxYoVU79+/SRJI0eO1MCBAyVJwcHB1iWWt/exaNEiVa9eXe7u7vLw8FBERIT27NmT7vyzZ89WqVKl5OzsrDJlyuiLL764qzE7e/asPv30U0VERKQLqGlKlCih0NBQSdKnn36q8+fPa9y4cTYBNc2gQYNUunRpTZw4UUlJSdme39XVVZ999pkcHR2znU2tVq1aupBUvnx5WSwWxcbGWrctXbpUFotFBw4ckJR+uW/a8tWTJ0/aLG290+TJkxUcHCwPDw9Vr15d27dvz/Z6svPHH3+oR48eKlu2rDw8PBQQEKB69epp06ZN2R57/fp1vfHGGwoODpaLi4v8/PxUtWpVLViwwKbdzp071aJFC/n5+cnFxUWVKlXS4sWL77vmYsWKKW/evNb3lSR99913ql69utzc3OTp6amGDRtq27Zt6a71lVdeUVBQkPU9FhYWpjVr1ljb3Lnc12Kx6Nq1a5ozZ47155K21PPO99iUKVNksVj066+/pqt58ODBcnJy0p9//mndtmbNGtWvX19eXl5yc3NTWFiY1q5de881Z+TXX39V165dVaJECbm5ualgwYJq3ry59TWYJu0aFixYoDfffFMFChSQl5eXGjRokG620zAMTZgwQUWKFJGLi4sqV66sH374Ics67uTn56chQ4Zo6dKld/X6PXr0qDp06KCAgADr75IPP/wwXbtDhw7pmWeekZubm/LmzauePXtq5cqV6X5/xcTEqGXLlipUqJBcXFxUvHhxvfrqqzY/l+x+D96+3DcpKUkBAQHq1KlTupouX74sV1dXDRgwwLotMTHR+p5xcnJSwYIF1a9fv3Srbb766is99dRT8vb2lpubm0JCQtStW7dsxwv4NyOkAkAOSfvH6u2zZrdu3VKLFi1Ur149ffvttxo1apRSU1PVsmVLjRs3Th06dNDKlSs1btw4xcTEqE6dOtZZQ0l6+eWX9d5776lz58769ttv9eyzz6pNmza6dOlStvVER0erVq1aio+P1+TJk/XDDz/orbfe0rlz5yRJL730knr37i3p72CVtiw0bTnju+++q/bt26ts2bJavHix5s6dqytXrqhWrVo6fPiw9TyzZ89W165dVaZMGS1ZskRvvfWWxowZo3Xr1mVb4/r165WUlKRWrVplP8D6+x+d9vb2at68eYb7LRaLWrRooYsXL2rXrl131WeBAgVUpUoVbd26VcnJyZm2a9CggX788Udr+D137pwOHjwoV1dXxcTEWNutWbNG+fLlU/ny5TPsZ/r06QoLC1NgYKDNctzbffjhh4qJidGUKVM0b948Xbt2TU2aNFFCQsJdXVNqaqqSk5NtHpJ08eJFSdKIESO0cuVKzZo1SyEhIapTp062n7UcMGCAZsyYoT59+mjVqlWaO3eu2rZtqwsXLljbrF+/XmFhYbp8+bI++ugjffvtt6pYsaLatWun2bNn31Xtd7p06ZIuXLhgfV/Nnz9fLVu2lJeXlxYsWKDPPvtMly5dUp06dbR582brcZ06ddKyZcs0fPhwrV69Wp9++qkaNGhgU++dtm3bJldXVzVp0sT6c8lsqeeLL74oJyendNeVkpKiL7/8Us2bN1eePHkkSV9++aWeeeYZeXl5ac6cOVq8eLH8/PwUERFhE1Tvp2ZJ+v333+Xv769x48Zp1apV+vDDD+Xg4KCnnnoqw6W2//nPf3Ty5El9+umnmjlzpo4eParmzZsrJSXF2mbUqFEaPHiwGjZsqGXLlum1117Tyy+/fM9Ld/v27auCBQtq0KBBWbY7fPiwqlWrpoMHD2rSpElasWKFmjZtqj59+mjUqFHWdmfOnFF4eLiOHDmiGTNm6IsvvtCVK1fUq1evdH0eO3ZM1atX14wZM7R69WoNHz5cP/30k2rWrGl9H2f3e/B2jo6OevHFF7VkyRIlJiba7FuwYIFu3Lihrl27Svr7P3XCw8M1Z84c9enTRz/88IMGDx6s2bNnq0WLFtbPzm/btk3t2rVTSEiIFi5cqJUrV2r48OFZ/i4CHgsGAOCezJo1y5BkbN++3UhKSjKuXLlirFixwsibN6/h6elpnD171jAMw4iMjDQkGZ9//rnN8QsWLDAkGUuWLLHZHhsba0gypk+fbhiGYcTFxRmSjP79+9u0mzdvniHJiIyMtG5bv369IclYv369dVuxYsWMYsWKGX/99Vem1zJx4kRDknH8+HGb7fHx8YaDg4PRu3dvm+1XrlwxAgMDjeeff94wDMNISUkxChQoYFSuXNlITU21tjtx4oTh6OhoFClSJNNzG4ZhjBs3zpBkrFq1Kst2aUqXLm0EBgZm2WbGjBmGJGPRokWGYRjG8ePHDUnGxIkTMz2mXbt2hiTj3LlzmbZZs2aNIcn48ccfDcMwjC+//NLw9PQ0evToYdStW9farkSJEkaHDh2sz9NeL7ePcdOmTTMcm7Ray5cvbyQnJ1u379ixw5BkLFiwIMtrT3sdZPQ4evRouvbJyclGUlKSUb9+faN169Y2+yQZI0aMsD4vV66c0apVqyzPX7p0aaNSpUpGUlKSzfZmzZoZ+fPnN1JSUrI8XpLRo0cPIykpybh165YRFxdnNG7c2JBkfPjhh9bXW/ny5W36unLlihEQEGDUqFHDus3Dw8Po169flueLjIxM93Nwd3e3eW+lyeg91qZNG6NQoUI2tXz//feGJGP58uWGYRjGtWvXDD8/P6N58+Y2/aWkpBgVKlQwnnzyyXuq+W4kJycbt27dMkqUKGHz+yPtGpo0aWLTfvHixYYkY9u2bYZhGMalS5cMFxeXdK+JLVu2GJKM8PDwbGsoUqSI0bRpU8MwDOOTTz6xGZO0Or766itr+4iICKNQoUJGQkKCTT+9evUyXFxcjIsXLxqGYRgDBw40LBaLcejQIZt2ERER6X4+t0tNTTWSkpKMkydPGpKMb7/91rovs9+DhmEY4eHhNte7f/9+Q5Ixc+ZMm3ZPPvmkUaVKFevzsWPHGnZ2dkZsbKxNu6+//tqQZHz//feGYRjGe++9Z0gyLl++nGHdwOOKmVQAuE9PP/20HB0d5enpqWbNmikwMFA//PBDumWozz77rM3zFStWyMfHR82bN7eZ6apYsaICAwOtM1rr16+XpHSfb33++efl4JD1LQV++eUXHTt2TN27d5eLi8s9X1t0dLSSk5PVuXNnmxpdXFwUHh5urfHIkSP6/fff1aFDB5slq0WKFFGNGjXu+bw5wfj/MxQZLaHN7pishIWFycXFxbr0Mm3mu1GjRtq6dauuX7+uU6dO6ejRo2rQoMH9Ff//NW3aVPb29tbnacudb1/ympXx48crNjbW5hEUFCRJ+uijj1S5cmW5uLjIwcFBjo6OWrt2reLi4rLs88knn9QPP/ygIUOGaMOGDTYz/tLfKwl+/vln6+v19tdNkyZNdObMmbuahZs+fbocHR3l5OSkMmXKaOvWrRo9erR69Ohhfb116tRJdnb/908YDw8PPfvss9q+fbuuX79urXf27Nl6++23tX379rta/n2vunbtqtOnT9ssx501a5YCAwOtn2/eunWrLl68qMjISJsxSU1NVaNGjRQbG2td/nm/NScnJ+vdd99V2bJl5eTkJAcHBzk5Oeno0aMZ/lxbtGhh8/zO19e2bdt048aNdL97atSooSJFitzl6Pyfrl27qmzZshoyZEiGNzW7ceOG1q5dq9atW8vNzS3da+fGjRvW5cIbN25UuXLl0n1WtH379un6PX/+vKKiohQUFGR9rafVn93rPTPly5dXlSpVNGvWLOu2uLg47dixw2aJ7ooVK1SuXDlVrFjR5noiIiJslhNXq1ZN0t+/1xcvXvzI7hAPmB0hFQDu0xdffKHY2Fjt2bNHv//+u/bv36+wsDCbNm5ubvLy8rLZdu7cOV2+fFlOTk5ydHS0eZw9e9b6eam0JX6BgYE2xzs4OMjf3z/L2tI+21qoUKH7ura0JcHVqlVLV+OiRYuyrTGzbXcqXLiwJOn48eN3VVfhwoX1xx9/ZHkH5bTPfqaFsrtx8uRJOTs7y8/PL9M2Li4uNp8PXLt2rRo2bKg6deooJSVFmzZtsi77fdCQeufP19nZWZLSBcPMhISEqGrVqjYPZ2dnTZ48Wa+99pqeeuopLVmyRNu3b1dsbKwaNWqUbd9Tp07V4MGDtWzZMtWtW1d+fn5q1aqVjh49Kun/XjNvvPFGutdMjx49JMnms4CZef755xUbG6udO3fqyJEjunDhgoYNGybp/15vt98pOU2BAgWUmppqXQq/aNEiRUZG6tNPP1X16tXl5+enzp076+zZs3c1hnejcePGyp8/vzWwXLp0Sd999506d+5s/U+GtHF57rnn0o3L+PHjZRiGdRn2/dY8YMAADRs2TK1atdLy5cv1008/KTY2VhUqVMjw55rd6+tB39d3sre317vvvqtDhw5pzpw56fZfuHBBycnJmjZtWroxatKkiSTZ/M7J6PPod25LTU3VM888o6VLl2rQoEFau3atduzYYQ27d/teyki3bt20bds2/fzzz5L+/o8JZ2dnm6B87tw57d+/P931eHp6yjAM6/XUrl1by5Yts/6nYKFChVSuXLl0n/UGHjfc3RcA7lOZMmWsd/fNTEazeXny5JG/v79WrVqV4TGenp6S/u8fkmfPnlXBggWt+5OTk7P9jFra5/dOnz6dZbvMpH2W7uuvv85y5uT2Gu90N2Ggbt26cnR01LJlyzL8PsU7NWzYUKtXr9by5cv1wgsvpNtvGIa+++47+fn5qUqVKtn2J0m//fabdu3apfDw8GxnqOvXr6/hw4drx44dOn36tBo2bChPT09Vq1ZNMTEx+v3331WyZMl7CsiP0pdffqk6depoxowZNtuvXLmS7bHu7u4aNWqURo0apXPnzllnVZs3b66ff/7Z+poZOnSo2rRpk2EfpUqVyvY8efPmzfR9lfZ6O3PmTLp9v//+u+zs7OTr6yvp79fwlClTNGXKFMXHx+u7777TkCFDdP78+Uzfe/fK3t5enTp10tSpU3X58mXNnz9fN2/etH4uMa0OSZo2bVqmdwdOC1j3W/OXX36pzp07691337XZ/ueff8rHx+eeryu79/Xdfv/x7Vq2bKmwsDCNGDFCM2fOtNnn6+trHcuePXtmeHxwcLC1trTgf2ddtzt48KD27dun2bNnKzIy0ro9oxtd3av27dtrwIABmj17tt555x3rV1qlvfakv3+Wrq6u+vzzzzPsI+11If09Ni1bttTNmze1fft2jR07Vh06dFDRokVVvXr1B64X+CdiJhUAHrFmzZrpwoULSklJSTfbVbVqVes/5NPuKDlv3jyb4xcvXpztTTVKliypYsWK6fPPP9fNmzczbZfZDF1ERIQcHBx07NixDGtMCxGlSpVS/vz5tWDBApslsydPntTWrVuzHYvAwEC99NJLio6OzvSOwMeOHdP+/fsl/X2Tk4CAAA0dOlTnz59P13bChAn6+eefNWjQIDk6OmZ7/r/++ksvvfSSkpOTs72xi/T3DGlycrKGDRumQoUKqXTp0tbta9as0bp16+5qFtXZ2fmB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CgAAAAAwDUIqAAAAAMA0CKkAAAAAANNwyO0C8HiIrdpJ7u7u2bYLCwt7BNUAAAAAMCtmUgEAAAAApkFIBQAAAACYBiEVAAAAAGAahFQAAAAAgGkQUgEAAAAApkFINakTJ07IYrFo7969OdanxWLRsmXLHuk5AQAAAOBe8BU0JhUUFKQzZ84oT548uV0KAAAAADwyhFSTsre3V2BgYG6XAQAAAACP1D9quW9qaqrGjx+v4sWLy9nZWYULF9Y777wjSTpw4IDq1asnV1dX+fv765VXXtHVq1etx3bp0kWtWrXSu+++q3z58snHx0ejRo1ScnKyBg4cKD8/PxUqVEiff/659Zi05a+LFy9WrVq15OrqqmrVqumXX35RbGysqlatKg8PDzVq1Eh//PGH9bg6deqoX79+NrW3atVKXbp0sT4vWrSo3n33XXXr1k2enp4qXLiwZs6cme7cty+9PXTokJo2bSovLy95enqqVq1aOnbsmCQpNjZWDRs2VJ48eeTt7a3w8HDt3r073RieOXNGjRs3lqurq4KDg/XVV19lOeaHDx9WkyZN5OHhoXz58qlTp076888/szwGAAAAAO7XPyqkDh06VOPHj9ewYcN0+PBhzZ8/X/ny5dP169fVqFEj+fr6KjY2Vl999ZXWrFmjXr162Ry/bt06/f777/rxxx81efJkjRw5Us2aNZOvr69++uknRUVFKSoqSqdOnbI5bsSIEXrrrbe0e/duOTg4qH379ho0aJDef/99bdq0SceOHdPw4cPv+XomTZqkqlWras+ePerRo4dee+01/fzzzxm2/e2331S7dm25uLho3bp12rVrl7p166bk5GRJ0pUrVxQZGalNmzZp+/btKlGihJo0aaIrV67Y9DNs2DA9++yz2rdvn1588UW1b99ecXFxGZ7zzJkzCg8PV8WKFbVz506tWrVK586d0/PPP5/pNd28eVOJiYk2DwAAAAC4a8Y/RGJiouHs7Gx88skn6fbNnDnT8PX1Na5evWrdtnLlSsPOzs44e/asYRiGERkZaRQpUsRISUmxtilVqpRRq1Yt6/Pk5GTD3d3dWLBggWEYhnH8+HFDkvHpp59a2yxYsMCQZKxdu9a6bezYsUapUqWsz8PDw42+ffva1NiyZUsjMjLS+rxIkSLGiy++aH2emppqBAQEGDNmzLA59549ewzDMIyhQ4ca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2rdvr0KFCsnNzU3ly5fXggULHsn4AQAAAEAaQmoOmTNnjvLkyaMdO3aod+/eeu2119S2bVvVqFFDu3fvVkREhDp16qTr168rNTVVhQoV0uLFi3X48GENHz5c//nPf7R48WJJ0htvvKHnn39ejRo10pkzZ3TmzBnVqFFD169fV926deXh4aEff/xRmzdvloeHhxo1amQzY7p27VrFxcUpJiZGK1assG5/88039cYbb2jv3r0qWbKk2rdvr+TkZEnSjRs3VKVKFa1YsUIHDx7UK6+8ok6dOumnn366p3G4efOmEhMTbR4AAADAwzZ79mz5+Pjkdhn3rWjRopoyZUqWbUaOHKmKFSs+knpyk8UwDCO3i/inq1OnjlJSUrRp0yZJf8+Uent7q02bNvriiy8kSWfPnlX+/Pm1bds2Pf300+n66Nmzp86dO6evv/5a0t8zopcvX9ayZcusbT7//HNNmDBBcXFxslgskv5ezuvj46Nly5bpmWeeUZcuXbRq1SrFx8fLyclJknTixAkFBwfr008/Vffu3SVJhw8f1hNPPKG4uDiVLl06w+tq2rSpypQpo/fee896nRUrVszyzTNy5EiNGjUq3fbo6Gi5u7tnNYwPXVhYWK6eHwAA4FG5ceOGjh8/ruDgYLm4uFi3b9my5ZHWca///urSpYvmzJmTbvvRo0dVvHjxLI+dPXu2+vXrp8uXL9/TOe/W7Nmz1bVrV+vzwMBA1apVS+PHj1dwcPAD9//HH3/I3d1dbm5ukiSLxaJvvvnG5j41V69e1c2bN+Xv7//A53tYMnvtSVJiYqK8vb2VkJAgLy+vTPtgJjWHhIaGWv9sb28vf39/lS9f3rotX758kqTz589Lkj766CNVrVpVefPmlYeHhz755BPFx8dneY5du3bp119/laenpzw8POTh4SE/Pz/duHFDx44ds7YrX768NaBmVmP+/Plt6klJSdE777yj0NBQ+fv7y8PDQ6tXr862pjsNHTpUCQkJ1sepU6fu6XgAAAA83m5fTZj2yIkQmBO8vLx05swZ/f7775o/f7727t2rFi1aKCUl5YH7zps3rzWgZsbDw8PUATWnEFJziKOjo81zi8Visy1t5jM1NVWLFy9W//791a1bN61evVp79+5V165ds73JUWpqqqpUqaK9e/faPH755Rd16NDB2i6zGcvM6pGkSZMm6b///a8GDRqkdevWae/evYqIiLjnGy85OzvLy8vL5gEAAADcLWdnZwUGBto87O3tNXnyZJUvX17u7u4KCgpSjx49dPXq1Uz72bdvn+rWrStPT095eXmpSpUq2rlzp3X/1q1bVbt2bbm6uiooKEh9+vTRtWvXsqzNYrEoMDBQ+fPnV926dTVixAgdPHhQv/76qyRpxowZKlasmJycnFSqVCnNnTvX5viRI0eqcOHCcnZ2VoECBdSnTx/rvtuX+xYtWlSS1Lp1a1ksFuvz25f7RkdHy8XFJd3McZ8+fRQeHn7X1zl9+nSVKFFCLi4uypcvn5577rksx+BRIKTmgk2bNqlGjRrq0aOHKlWqpOLFi9vMhEqSk5NTuv+RqVy5so4ePaqAgAAVL17c5uHt7f3ANbVs2VIvvviiKlSooJCQEB09evSB+gQAAAByip2dnaZOnaqDBw9qzpw5WrdunQYNGpRp+44dO6pQoUKKjY3Vrl27NGTIEOukzYEDBxQREaE2bdpo//79WrRokTZv3qxevXrdU02urq6SpKSkJH3zzTfq27evXn/9dR08eFCvvvqqunbtqvXr10uSvv76a/33v//Vxx9/rKNHj2rZsmU2Ky9vFxsbK0maNWuWzpw5Y31+uwYNGsjHx0dLliyxbktJSdHixYvVsWPHu7rOnTt3qk+fPho9erSOHDmiVatWqXbt2vc0Bg8DITUXFC9eXDt37lR0dLR++eUXDRs2LN0Lr2jRotq/f7+OHDmiP//8U0lJSerYsaPy5Mmjli1batOmTTp+/Lg2btyovn376vTp0w9cU0xMjLZu3aq4uDi9+uqrOnv27AP1CQAAANyrFStWWD/a5uHhobZt20qS+vXrp7p16yo4OFj16tXTmDFjrDcezUh8fLwaNGig0qVLq0SJEmrbtq0qVKggSZo4caI6dOigfv36qUSJEqpRo4amTp2qL774Qjdu3LirOk+fPq2JEyeqUKFCKlmypN577z116dJFPXr0UMmSJTVgwAC1adPGen+X+Ph4BQYGqkGDBipcuLCefPJJvfzyyxn2nTdvXkmSj4+PAgMDrc9vZ29vr3bt2mn+/PnWbWvXrtWlS5esY5bddcbHx8vd3V3NmjVTkSJFVKlSJZvZ3dxCSM0FUVFRatOmjdq1a6ennnpKFy5cUI8ePWzavPzyyypVqpT1c6tbtmyRm5ubfvzxRxUuXFht2rRRmTJl1K1bN/31118PvKx22LBhqly5siIiIlSnTh0FBgbafEgbAAAAeBTq1q1r89G2qVOnSpLWr1+vhg0bqmDBgvL09FTnzp114cKFTJfoDhgwQC+99JIaNGigcePG2axc3LVrl2bPnm0ThiMiIpSamqrjx49nWltCQoI8PDysS45v3bqlpUuXysnJSXFxceluFBUWFqa4uDhJUtu2bfXXX38pJCREL7/8sr755hvrN23cr44dO2rDhg36/fffJUnz5s1TkyZN5Ovre1fX2bBhQxUpUkQhISHq1KmT5s2bp+vXrz9QTTnBIbcL+DdI+w7T293+3aVpbr+R8qxZszRr1iyb/WPHjrX+OW/evFq9enW6PgIDAzO841ma2bNnp9tWtGhR3XkTZx8fH5ttfn5+NncSzkhG1wkAAADkJHd393R38j158qSaNGmiqKgojRkzRn5+ftq8ebO6d++upKSkDPsZOXKkOnTooJUrV+qHH37QiBEjtHDhQrVu3Vqpqal69dVXM5w1LFy4cKa1eXp6avfu3bKzs1O+fPnS3Qsm7b4vaQzDsG4LCgrSkSNHFBMTozVr1qhHjx6aOHGiNm7cmO7+NnfrySefVLFixbRw4UK99tpr+uabb2wyRnbX6eTkpN27d2vDhg1avXq1hg8frpEjRyo2NjZXv86HkAoAAADA1Hbu3Knk5GRNmjRJdnZ/LwbNaqlvmpIlS6pkyZLq37+/2rdvr1mzZql169aqXLmyDh06lO3X2tzJzs4u02PKlCmjzZs3q3PnztZtW7duVZkyZazPXV1d1aJFC7Vo0UI9e/ZU6dKldeDAAVWuXDldf46Ojnd11+AOHTpo3rx5KlSokOzs7NS0aVPrvru5TgcHBzVo0EANGjTQiBEj5OPjo3Xr1qlNmzbZnvthIaQCAAAAMLVixYopOTlZ06ZNU/PmzbVlyxZ99NFHmbb/66+/NHDgQD333HMKDg7W6dOnFRsbq2effVaSNHjwYD399NPq2bOnXn75Zbm7uysuLk4xMTGaNm3afdU4cOBAPf/886pcubLq16+v5cuXa+nSpVqzZo2kv1c8pqSk6KmnnpKbm5vmzp0rV1dXFSlSJMP+ihYtqrVr1yosLEzOzs7WJbx36tixo0aNGqV33nlHzz33nM13k2Z3nStWrND//vc/1a5dW76+vvr++++VmpqqUqVK3dcY5BRCKgAAAPCYuPMzk/8UFStW1OTJkzV+/HgNHTpUtWvX1tixY21mLW9nb2+vCxcuqHPnzjp37pzy5MmjNm3aaNSoUZKk0NBQbdy4UW+++aZq1aolwzBUrFgxtWvX7r5rbNWqld5//31NnDhRffr0UXBwsGbNmqU6depI+vvjduPGjdOAAQOUkpKi8uXLa/ny5Zl+7+mkSZM0YMAAffLJJypYsGCGHyeUpBIlSqhatWqKjY21foVNmuyu08fHR0uXLtXIkSN148YNlShRQgsWLNATTzxx3+OQEyzGnR9WBHJQYmKivL29FR0dnen3tz4q/9RfygAAAPfqxo0bOn78uIKDg21m1oCHLavXXlo2SEhIyPLGr8yk4pE4dOiQ9XukHqWoqKhHfk4AAAAA94+voAEAAAAAmAYhFQAAAABgGoRUAAAAAIBpEFIBAAAAAKZBSAUAAAAAmAYhFQAAAABgGoRUAAAAAIBpEFIBAAAAAKZBSAUAAADwjzd79mz5+Pjkdhm5rkuXLmrVqlVul/FAHHK7AAAAAACPxkcfffRIzxcVFXVP7bt06aI5c+ak23706FEVL148p8q6L7Nnz1bXrl0VERGhVatWWbdfvnxZvr6+Wr9+verUqfPI6jlx4oSCg4O1Z88eVaxY0br9/fffl2EYj6yOh4GZVAAAAACm0ahRI505c8bmERwcnNtlSZIcHBy0du1arV+/PrdLyZS3t/c/fkaZkAoAAADANJydnRUYGGjzsLe31+TJk1W+fHm5u7srKChIPXr00NWrVzPtZ9++fapbt648PT3l5eWlKlWqaOfOndb9W7duVe3ateXq6qqgoCD16dNH165dy7I2d3d3de3aVUOGDMmy3W+//aZ27drJ19dX/v7+atmypU6cOGHdn5ycrD59+sjHx0f+/v4aPHiwIiMjbZbprlq1SjVr1rS2adasmY4dO2bdnxbcK1WqJIvFYp3FvX2578cff6yCBQsqNTXVpr4WLVooMjLS+nz58uWqUqWKXFxcFBISolGjRik5Odm6f+TIkSpcuLCcnZ1VoEAB9enTJ8vrf1CEVAAAAACmZ2dnp6lTp+rgwYOaM2eO1q1bp0GDBmXavmPHjipUqJBiY2O1a9cuDRkyRI6OjpKkAwcOKCIiQm3atNH+/fu1aNEibd68Wb169cq2jpEjR+rAgQP6+uuvM9x//fp11a1bVx4eHvrxxx+1efNmeXh4qFGjRrp165Ykafz48Zo3b55mzZqlLVu2KDExUcuWLbPp59q1axowYIBiY2O1du1a2dnZqXXr1tbAuWPHDknSmjVrdObMGS1dujRdLW3bttWff/5pM/N76dIlRUdHq2PHjpKk6Ohovfjii+rTp48OHz6sjz/+WLNnz9Y777wjSfr666/13//+Vx9//LGOHj2qZcuWqXz58tmO04PgM6kAAAAATGPFihXy8PCwPm/cuLG++uor9evXz7otODhYY8aM0Wuvvabp06dn2E98fLwGDhyo0qVLS5JKlChh3Tdx4kR16NDB2meJEiU0depUhYeHa8aMGXJxccm0vgIFCqhv37568803M7xB0cKFC2VnZ6dPP/1UFotFkjRr1iz5+Phow4YNeuaZZzRt2jQNHTpUrVu3liR98MEH+v777236efbZZ22ef/bZZwoICNDhw4dVrlw55c2bV5Lk7++vwMDADGv18/NTo0aNNH/+fNWvX1+S9NVXX8nPz8/6/J133tGQIUOsM6shISEaM2aMBg0apBEjRig+Pl6BgYFq0KCBHB0dVbhwYT355JOZjk9OYCYVAAAAgGnUrVtXe/futT6mTp0qSVq/fr0aNmyoggULytPTU507d9aFCxcyXaI7YMAAvfTSS2rQoIHGjRtns1R2165dmj17tjw8PKyPiIgIpaam6vjx49nWOHjwYP3xxx/6/PPP0+3btWuXfv31V3l6elr79vPz040bN3Ts2DElJCTo3LlzNkHP3t5eVapUsenn2LFj6tChg0JCQuTl5WVd3hsfH5/9IN6mY8eOWrJkiW7evClJmjdvnl544QXZ29tb6x09erTNWLz88ss6c+aMrl+/rrZt2+qvv/5SSEiIXn75ZX3zzTc2S4EfBmZSAQAAAJiGu7t7ujv5njx5Uk2aNFFUVJTGjBkjPz8/bd68Wd27d1dSUlKG/YwcOVIdOnTQypUr9cMPP2jEiBFauHChdcnsq6++muFnKwsXLpxtjT4+Pho6dKhGjRqlZs2a2exLTU1VlSpVNG/evHTHpc1+SrLOsqa58468zZs3V1BQkD755BMVKFBAqampKleunHXJ8N1q3ry5UlNTtXLlSlWrVk2bNm3S5MmTbeodNWqU2rRpk+5YFxcXBQUF6ciRI4qJidGaNWvU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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": null,
   "id": "3a58c6ba",
   "metadata": {},
   "outputs": [],
   "source": [
    "# df.loc[Test_X.index][['age_yr']].to_csv('baseline_covariates.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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": null,
   "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": null,
   "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": null,
   "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": 314,
   "id": "6caa70ea",
   "metadata": {},
   "outputs": [],
   "source": [
    "regions = df['site'].unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 315,
   "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": 316,
   "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:                Mon, 19 Feb 2024   Pseudo R-squ.:                 0.08812\n",
      "Time:                        15:24:43   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:                Mon, 19 Feb 2024   Pseudo R-squ.:                  0.1083\n",
      "Time:                        15:24:43   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:                Mon, 19 Feb 2024   Pseudo R-squ.:                  0.1055\n",
      "Time:                        15:24:44   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:                Mon, 19 Feb 2024   Pseudo R-squ.:                  0.1047\n",
      "Time:                        15:24:44   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:                Mon, 19 Feb 2024   Pseudo R-squ.:                 0.05946\n",
      "Time:                        15:24:44   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",
      "                          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:                Mon, 19 Feb 2024   Pseudo R-squ.:                 0.06082\n",
      "Time:                        15:24:44   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
}
