{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "f5e6f741",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import glob\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "4a29d116",
   "metadata": {},
   "outputs": [],
   "source": [
    "# GitHub CSV file URL\n",
    "url = 'https://raw.githubusercontent.com/avisokay/va_nlp/main/data/phmrc/phmrc_adult_tokenized.csv'\n",
    "df = pd.read_csv(url)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "56ab13fe",
   "metadata": {},
   "outputs": [],
   "source": [
    "sites = df['site'].unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "fed8f432",
   "metadata": {},
   "outputs": [],
   "source": [
    "test = pd.read_csv('../src/classic_nlp/classic_predictions_ex_ap.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "1091215e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "DataFrame for ../src/classic_nlp/classic_predictions_ex_bohol.csv:\n",
      "      Unnamed: 0  Y  X_unlabeled  Yhat_NB  Yhat_SVM  Yhat_KNN\n",
      "0              0  1           51        1         1         1\n",
      "1              1  3           24        3         3         3\n",
      "2              2  1           62        3         1         1\n",
      "3              3  3           80        3         3         4\n",
      "4              4  3           76        3         3         3\n",
      "...          ... ..          ...      ...       ...       ...\n",
      "9984         883  3           35        3         3         3\n",
      "9985         884  1           83        3         1         3\n",
      "9986         885  3           17        3         3         3\n",
      "9987         886  3           20        3         3         3\n",
      "9988         887  1           60        3         3         3\n",
      "\n",
      "[9989 rows x 6 columns]\n",
      "DataFrame for ../src/classic_nlp/classic_predictions_ex_dar.csv:\n",
      "       Unnamed: 0  Y  X_unlabeled  Yhat_NB  Yhat_SVM  Yhat_KNN\n",
      "0               0  3           51        3         1         1\n",
      "1               1  4           24        3         3         3\n",
      "2               2  3           62        3         3         3\n",
      "3               3  1           80        3         3         4\n",
      "4               4  3           76        3         1         3\n",
      "...           ... ..          ...      ...       ...       ...\n",
      "11751        1040  3           30        3         3         3\n",
      "11752        1041  3           23        3         3         3\n",
      "11753        1042  3           16        3         1         3\n",
      "11754        1043  1           76        3         1         3\n",
      "11755        1044  3           65        3         3         3\n",
      "\n",
      "[11756 rows x 6 columns]\n",
      "DataFrame for ../src/classic_nlp/classic_predictions_ex_pemba.csv:\n",
      "       Unnamed: 0  Y  X_unlabeled  Yhat_NB  Yhat_SVM  Yhat_KNN\n",
      "0               0  4           51        3         0         3\n",
      "1               1  3           24        3         3         3\n",
      "2               2  3           62        3         3         3\n",
      "3               3  3           80        3         3         3\n",
      "4               4  3           76        3         3         3\n",
      "...           ... ..          ...      ...       ...       ...\n",
      "12415        1099  3           40        3         1         3\n",
      "12416        1100  4           84        3         3         3\n",
      "12417        1101  0           37        3         3         3\n",
      "12418        1102  2           47        3         2         2\n",
      "12419        1103  0           55        3         3         3\n",
      "\n",
      "[12420 rows x 6 columns]\n",
      "DataFrame for ../src/classic_nlp/classic_predictions_ex_mexico.csv:\n",
      "       Unnamed: 0  Y  X_unlabeled  Yhat_NB  Yhat_SVM  Yhat_KNN\n",
      "0               0  3           51        3         3         3\n",
      "1               1  4           24        3         3         3\n",
      "2               2  0           62        3         3         3\n",
      "3               3  4           80        3         3         3\n",
      "4               4  3           76        3         0         0\n",
      "...           ... ..          ...      ...       ...       ...\n",
      "10299         911  3           43        3         3         3\n",
      "10300         912  3           35        3         3         0\n",
      "10301         913  3           70        3         3         3\n",
      "10302         914  1           40        3         1         1\n",
      "10303         915  4           48        3         1         1\n",
      "\n",
      "[10304 rows x 6 columns]\n",
      "DataFrame for ../src/classic_nlp/classic_predictions_ex_ap.csv:\n",
      "       Unnamed: 0  Y  X_unlabeled  Yhat_NB  Yhat_SVM  Yhat_KNN\n",
      "0               0  1           51        3         3         3\n",
      "1               1  0           24        3         3         3\n",
      "2               2  3           62        3         3         3\n",
      "3               3  3           80        3         3         3\n",
      "4               4  4           76        3         3         3\n",
      "...           ... ..          ...      ...       ...       ...\n",
      "14079        1247  3           35        3         3         3\n",
      "14080        1248  3           42        3         3         3\n",
      "14081        1249  3           75        3         3         1\n",
      "14082        1250  3           60        3         3         3\n",
      "14083        1251  4           90        3         3         3\n",
      "\n",
      "[14084 rows x 6 columns]\n",
      "DataFrame for ../src/classic_nlp/classic_predictions_ex_up.csv:\n",
      "      Unnamed: 0  Y  X_unlabeled  Yhat_NB  Yhat_SVM  Yhat_KNN\n",
      "0              0  1           51        3         1         1\n",
      "1              1  2           24        3         3         3\n",
      "2              2  3           62        3         3         3\n",
      "3              3  1           80        3         1         1\n",
      "4              4  0           76        3         3         2\n",
      "...          ... ..          ...      ...       ...       ...\n",
      "2335         203  1           58        3         1         1\n",
      "2336         204  2           68        2         2         2\n",
      "2337         205  3           76        3         3         1\n",
      "2338         206  0           58        3         3         2\n",
      "2339         207  2           24        3         3         3\n",
      "\n",
      "[2340 rows x 6 columns]\n"
     ]
    }
   ],
   "source": [
    "# read in classic predictions files\n",
    "file_pattern = '../src/classic_nlp/classic_predictions_ex_*.csv'\n",
    "csv_files = glob.glob(file_pattern)\n",
    "\n",
    "# Create a dictionary to store DataFrames\n",
    "dfs = {site: pd.read_csv(site) for site in csv_files}\n",
    "\n",
    "\n",
    "# Access the DataFrames using site names\n",
    "for site, df in dfs.items():\n",
    "    print(f\"DataFrame for {site}:\")\n",
    "    print(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "45440462",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cd5f9366",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "c7e939d9",
   "metadata": {},
   "source": [
    "## Manually create results plot comparing accuracy and F1 for classic, bert, GPT-4 with non-classified and without."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "79e4e707",
   "metadata": {},
   "outputs": [],
   "source": [
    "accuracy_scores = [0.52, 0.62, 0.55, 0.55, 0.38]\n",
    "f1_scores = [0.64, 0.67, 0.58, 0.71, 0.45]\n",
    "columns_to_evaluate = ['NB', 'SVM', 'KNN', 'BERT', 'GPT4_zeroshot']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "2a51c462",
   "metadata": {},
   "outputs": [],
   "source": [
    "accuracy_scores = [0.52, 0.62, 0.55, 0.55, 0.75]\n",
    "f1_scores = [0.64, 0.67, 0.58, 0.71, 0.73]\n",
    "columns_to_evaluate = ['NB', 'SVM', 'KNN', 'BERT', 'GPT4_zeroshot']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "02ef2ddd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot the results\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "bar_width = 0.35\n",
    "index = np.arange(len(columns_to_evaluate))\n",
    "\n",
    "bar1 = ax.bar(index, accuracy_scores, bar_width, label='Accuracy')\n",
    "bar2 = ax.bar(index + bar_width, f1_scores, bar_width, label='F1 Score')\n",
    "\n",
    "ax.set_xlabel('Predictions')\n",
    "ax.set_ylabel('Scores')\n",
    "ax.set_title('Accuracy and F1 Score for Each Prediction')\n",
    "ax.set_xticks(index + bar_width / 2)\n",
    "ax.set_xticklabels(columns_to_evaluate)\n",
    "plt.xticks(rotation=45)\n",
    "ax.legend()\n",
    "# Set y-axis range to 0-1\n",
    "ax.set_ylim(0, 1)\n",
    "\n",
    "# Add scores on top of each bar\n",
    "for i, (acc, f1) in enumerate(zip(accuracy_scores, f1_scores)):\n",
    "    ax.text(i, acc + 0.01, f'{acc:.2f}', ha='center', va='bottom', color='black', fontweight='bold')\n",
    "    ax.text(i + bar_width, f1 + 0.01, f'{f1:.2f}', ha='center', va='bottom', color='black', fontweight='bold')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "78e5496a",
   "metadata": {},
   "source": [
    "## read in classic results and break into csv, save to results folder\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "f5d4cf39",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mexico\n",
      "ap\n",
      "up\n",
      "dar\n",
      "bohol\n",
      "pemba\n"
     ]
    }
   ],
   "source": [
    "for site in sites:\n",
    "    print(site)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "7df944b0",
   "metadata": {},
   "outputs": [],
   "source": [
    "test = pd.read_csv('../src/classic_nlp/classic_predictions_ex_mexico.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "2b307771",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Y</th>\n",
       "      <th>X_unlabeled</th>\n",
       "      <th>Yhat_NB</th>\n",
       "      <th>Yhat_SVM</th>\n",
       "      <th>Yhat_KNN</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>4</td>\n",
       "      <td>51</td>\n",
       "      <td>4</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0</td>\n",
       "      <td>24</td>\n",
       "      <td>4</td>\n",
       "      <td>4</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>4</td>\n",
       "      <td>62</td>\n",
       "      <td>4</td>\n",
       "      <td>4</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2</td>\n",
       "      <td>80</td>\n",
       "      <td>4</td>\n",
       "      <td>4</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>76</td>\n",
       "      <td>4</td>\n",
       "      <td>2</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1301</th>\n",
       "      <td>4</td>\n",
       "      <td>30</td>\n",
       "      <td>4</td>\n",
       "      <td>4</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1302</th>\n",
       "      <td>4</td>\n",
       "      <td>23</td>\n",
       "      <td>4</td>\n",
       "      <td>4</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1303</th>\n",
       "      <td>4</td>\n",
       "      <td>16</td>\n",
       "      <td>4</td>\n",
       "      <td>2</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1304</th>\n",
       "      <td>2</td>\n",
       "      <td>76</td>\n",
       "      <td>4</td>\n",
       "      <td>2</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1305</th>\n",
       "      <td>4</td>\n",
       "      <td>65</td>\n",
       "      <td>4</td>\n",
       "      <td>4</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1306 rows × 5 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      Y  X_unlabeled  Yhat_NB  Yhat_SVM  Yhat_KNN\n",
       "0     4           51        4         2         2\n",
       "1     0           24        4         4         4\n",
       "2     4           62        4         4         4\n",
       "3     2           80        4         4         0\n",
       "4     4           76        4         2         4\n",
       "...  ..          ...      ...       ...       ...\n",
       "1301  4           30        4         4         4\n",
       "1302  4           23        4         4         4\n",
       "1303  4           16        4         2         4\n",
       "1304  2           76        4         2         4\n",
       "1305  4           65        4         4         4\n",
       "\n",
       "[1306 rows x 5 columns]"
      ]
     },
     "execution_count": 58,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "3a99b80d",
   "metadata": {},
   "outputs": [],
   "source": [
    "nb_out = test[['Y', 'X_unlabeled', 'Yhat_KNN']]\n",
    "nb_out = nb_out.rename(columns={'X_unlabeled':'X',\n",
    "                                      'Yhat_KNN':'Y_hat'\n",
    "\n",
    "})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "3928edb1",
   "metadata": {},
   "outputs": [],
   "source": [
    "nb_out.to_csv('../data/results/mexico_KNN.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ca2e0442",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5ce0a95d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "05d29979",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "457f3f1d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "df93a1c7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0c275eec",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "143c50bc",
   "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
}
