{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 209,
   "id": "fc087782",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "import openai\n",
    "import time\n",
    "import re\n",
    "import requests\n",
    "import os\n",
    "import random\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "from tqdm import tqdm\n",
    "from dotenv import load_dotenv\n",
    "from sklearn.metrics import accuracy_score, f1_score, classification_report\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "pd.set_option('display.max_colwidth', None)\n",
    "pd.set_option('display.max_columns', None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 210,
   "id": "9c064036",
   "metadata": {},
   "outputs": [],
   "source": [
    "# load API key and endpoint info from Azure AI\n",
    "load_dotenv()\n",
    "openai.api_type = \"azure\"\n",
    "openai.api_version = \"2023-05-15\" \n",
    "openai.api_base = os.getenv(\"ENDPOINT\")  \n",
    "openai.api_key = os.getenv(\"KEY1\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 211,
   "id": "08ccbb65",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.read_csv('../../data/phmrc/phmrc_adult_tokenized.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 212,
   "id": "9f56eb17",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_embedding(label: str) -> float:\n",
    "    label = label.lower()\n",
    "    if label not in label_to_score:\n",
    "        print(label)\n",
    "        return 0\n",
    "    return label_to_score[label]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 213,
   "id": "dda66077",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{4: 0.55981073488097,\n",
       " 2: 0.146976193996747,\n",
       " 1: 0.13425994381191778,\n",
       " 0: 0.09670264675439894,\n",
       " 3: 0.062250480555966284}"
      ]
     },
     "execution_count": 213,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "label_to_score = {\n",
    "    'aids-tb': 0,\n",
    "    'communicable': 1,\n",
    "    'external': 2,\n",
    "    'maternal': 3, \n",
    "    'non-communicable': 4\n",
    "}\n",
    "\n",
    "score_to_label = {\n",
    "    0: 'aids-tb',\n",
    "    1: 'communicable',\n",
    "    2: 'external',\n",
    "    3: 'maternal',\n",
    "    4: 'non-communicable' \n",
    "}\n",
    "\n",
    "colors = [(0.4, 0.7607843137254902, 0.6470588235294118),\n",
    " (0.5529411764705883, 0.6274509803921569, 0.796078431372549),\n",
    " (0.9882352941176471, 0.5529411764705883, 0.3843137254901961),\n",
    " (0.6509803921568628, 0.8470588235294118, 0.32941176470588235),\n",
    " (0.9058823529411765, 0.5411764705882353, 0.7647058823529411)]\n",
    "\n",
    "cod_list = label_to_score.keys()\n",
    "\n",
    "# get score for each label\n",
    "\n",
    "df['gs_cod_score'] = [get_embedding(x) for x in df['gs_cod']]\n",
    "\n",
    "# Create dictionary for each COD score and its proportion\n",
    "cod_proportions = df['gs_cod_score'].value_counts(normalize=True).to_dict()\n",
    "cod_proportions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 214,
   "id": "78f843a8",
   "metadata": {},
   "outputs": [],
   "source": [
    "def inspect_narrative(row):\n",
    "    print('Narrative: ' + df['narrative'][row])\n",
    "    print('True Label: ' + df['gs_text34'][row])\n",
    "    print('Broad Category: ' + df['gs_cod'][row])\n",
    "    print('Embedding Representation: ' + str(label_to_score[df['gs_cod'][row]]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 215,
   "id": "889240e2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Narrative: the client thanked for service which provided in the hospital_x000d__x000d_\n",
      "the client transfer death certificate to their original home [place]\n",
      "True Label: other cardiovascular diseases\n",
      "Broad Category: non-communicable\n",
      "Embedding Representation: 4\n"
     ]
    }
   ],
   "source": [
    "inspect_narrative(21)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 216,
   "id": "526fb4dc",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define a function to perform the random sampling within each group\n",
    "n=1\n",
    "def random_sample(group):\n",
    "    return group.sample(n, random_state = 2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 217,
   "id": "280f4c06",
   "metadata": {},
   "outputs": [],
   "source": [
    "# function to take in dataframe and output fewshot prompting examples in JSON format\n",
    "def make_fewshot_examples(input_df, obs, leave_out = ''):\n",
    "    '''\n",
    "    input_df :: pandas dataframe\n",
    "    obs :: integer value number of observations for each site/COD permutation\n",
    "    leave_out :: string for which site to leave out of the data frame for sampling\n",
    "    This function takes a random subset of size obs from df subset for each site and COD category\n",
    "    creates a user/assistant prompt example from the 'gs_cod' and 'narrative' columns\n",
    "    returns all few shot examples as a list of dictionaries\n",
    "    leave_out defaults to not excluding any sites\n",
    "    '''\n",
    "    \n",
    "    # set n for random_sample function\n",
    "    n = obs\n",
    "    \n",
    "    # subset inpute df to to all 5/6 sites other than leave_out\n",
    "    exclude_df = input_df[input_df['site'] != leave_out]\n",
    "    \n",
    "    # Apply the sample function to each group defined by 'site' and 'gs_cod'\n",
    "    subset_df = exclude_df.groupby(['site', 'gs_cod'], group_keys=False).apply(random_sample)\n",
    "    \n",
    "    # Reset index\n",
    "    subset_df.reset_index(drop=True, inplace=True)\n",
    "    \n",
    "#     # output plots of COD or SITE distributions\n",
    "#     subset_df['gs_cod'].value_counts().plot(kind='barh', title='COD Distribution for Subsample')\n",
    "#     subset_df['site'].value_counts().plot(kind='barh', title='Site Distribution for Subsample')\n",
    "\n",
    "    \n",
    "    messages = []\n",
    "    \n",
    "    for i, narratives in tqdm(subset_df.iterrows()):\n",
    "        narrative = narratives['narrative']\n",
    "        label = narratives['gs_cod']\n",
    "        \n",
    "        messages.append({\"role\": \"user\", \"content\": narrative})\n",
    "        messages.append({\"role\": \"assistant\", \"content\": label})\n",
    "    \n",
    "    print('Number of User/Assistant Pairs: ' + str(len(messages)/2))\n",
    "    return messages"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 169,
   "id": "64b4547f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "30it [00:00, 13123.60it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of User/Assistant Pairs: 30.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# select few shot examples\n",
    "fewshot_examples = make_fewshot_examples(df, 2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 235,
   "id": "a233f8fd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['mexico' 'ap' 'up' 'dar' 'bohol' 'pemba']\n",
      "['non-communicable' 'communicable' 'external' 'maternal' 'aids-tb']\n"
     ]
    }
   ],
   "source": [
    "## Manually create fewshot examples with for 1 COD in each region\n",
    "\n",
    "def subset_by_site_cod(df_, site, cod):\n",
    "    '''\n",
    "    given site and cod strings this returns the subset df\n",
    "    ''' \n",
    "    \n",
    "    # Create boolean masks for both 'Site' and 'Cod'\n",
    "    mask_site = df['site'] == site\n",
    "    mask_cod = df['gs_cod'] == cod\n",
    "\n",
    "    # Use boolean indexing to subset the DataFrame\n",
    "    subset_df = df[mask_site & mask_cod]\n",
    "\n",
    "    return subset_df[['site', 'gs_cod', 'narrative']]\n",
    "\n",
    "print(df['site'].unique())\n",
    "print(df['gs_cod'].unique())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5d852724",
   "metadata": {},
   "outputs": [],
   "source": [
    "## mexico\n",
    "\n",
    "subset_by_site_cod(df, 'mexico', 'non-communicable')\n",
    "\n",
    "mexico = [\n",
    "    # non-communicable\n",
    "    {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'non-communicable'},\n",
    "    # communicable\n",
    "        {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'communicable'},\n",
    "    # external\n",
    "    {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'external'},\n",
    "    # maternal\n",
    "        {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'maternal'},\n",
    "    # aids-tb\n",
    "    {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'aids-tb'}\n",
    "]\n",
    "\n",
    "\n",
    "\n",
    "## ap\n",
    "\n",
    "subset_by_site_cod(df, 'ap', 'non-communicable')\n",
    "\n",
    "ap = [\n",
    "    # non-communicable\n",
    "    {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'non-communicable'},\n",
    "    # communicable\n",
    "        {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'communicable'},\n",
    "    # external\n",
    "    {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'external'},\n",
    "    # maternal\n",
    "        {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'maternal'},\n",
    "    # aids-tb\n",
    "    {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'aids-tb'}\n",
    "]\n",
    "\n",
    "## up\n",
    "\n",
    "subset_by_site_cod(df, 'up', 'non-communicable')\n",
    "\n",
    "up = [\n",
    "    # non-communicable\n",
    "    {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'non-communicable'},\n",
    "    # communicable\n",
    "        {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'communicable'},\n",
    "    # external\n",
    "    {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'external'},\n",
    "    # maternal\n",
    "        {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'maternal'},\n",
    "    # aids-tb\n",
    "    {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'aids-tb'}\n",
    "]\n",
    "\n",
    "## dar\n",
    "\n",
    "subset_by_site_cod(df, 'dar', 'non-communicable')\n",
    "\n",
    "dar = [\n",
    "    # non-communicable\n",
    "    {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'non-communicable'},\n",
    "    # communicable\n",
    "        {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'communicable'},\n",
    "    # external\n",
    "    {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'external'},\n",
    "    # maternal\n",
    "        {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'maternal'},\n",
    "    # aids-tb\n",
    "    {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'aids-tb'}\n",
    "]\n",
    "\n",
    "## bohol\n",
    "\n",
    "subset_by_site_cod(df, 'bohol', 'non-communicable')\n",
    "\n",
    "bohol = [\n",
    "    # non-communicable\n",
    "    {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'non-communicable'},\n",
    "    # communicable\n",
    "        {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'communicable'},\n",
    "    # external\n",
    "    {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'external'},\n",
    "    # maternal\n",
    "        {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'maternal'},\n",
    "    # aids-tb\n",
    "    {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'aids-tb'}\n",
    "]\n",
    "\n",
    "## pemba\n",
    "\n",
    "subset_by_site_cod(df, 'pemba', 'non-communicable')\n",
    "\n",
    "pemba = [\n",
    "    # non-communicable\n",
    "    {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'non-communicable'},\n",
    "    # communicable\n",
    "        {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'communicable'},\n",
    "    # external\n",
    "    {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'external'},\n",
    "    # maternal\n",
    "        {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'maternal'},\n",
    "    # aids-tb\n",
    "    {'role': 'user',\n",
    "  'content': ''},\n",
    "    {'role': 'assistant', 'content': 'aids-tb'}\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b065dfa",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "241cd1ec",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "95a5b814",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d36cb2bc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5b5dfdc1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 171,
   "id": "9ddce92c",
   "metadata": {},
   "outputs": [],
   "source": [
    "predictions_classic = pd.read_csv('../classic_nlp/baseline_predictions.csv')\n",
    "# predictions_bert = pd.read_csv('../transformer_nlp/ansformer_nlp/predictions_bert.csv')\n",
    "\n",
    "predictions_gtp35_zeroshot = pd.read_csv('gpt35_zeroshot_score.csv')\n",
    "predictions_gtp35_zeroshot_text = pd.read_csv('gpt35_zeroshot_text.csv')\n",
    "\n",
    "predictions_gtp35_fewshot = pd.read_csv('gpt35_fewshot_score.csv')\n",
    "predictions_gtp35_fewshot_text = pd.read_csv('gpt35_fewshot_text.csv')\n",
    "\n",
    "predictions_gpt432k_zeroshot = pd.read_csv('gpt4-32k_zeroshot_score.csv')\n",
    "predictions_gpt432k_zeroshot_text = pd.read_csv('gpt4-32k_zeroshot_text.csv')\n",
    "\n",
    "predictions_gpt432k_fewshot = pd.read_csv('gpt-4-32k_fewshot_score.csv')\n",
    "predictions_gpt432k_fewshot_text = pd.read_csv('gpt-4-32k_fewshot_text.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 172,
   "id": "ceedc229",
   "metadata": {},
   "outputs": [],
   "source": [
    "accuracy_df = predictions_classic.copy()\n",
    "# accuracy_df['predictions_BERT'] = predictions_bert\n",
    "accuracy_df['predictions_GPT35_zeroshot'] = predictions_gtp35_zeroshot\n",
    "accuracy_df['predictions_GPT35_fewshot'] = predictions_gtp35_fewshot\n",
    "accuracy_df['predictions_GPT4-32k_zeroshot'] = predictions_gpt432k_zeroshot\n",
    "accuracy_df['predictions_GPT4-32k_fewshot'] = predictions_gpt432k_fewshot\n",
    "\n",
    "\n",
    "accuracy_df = accuracy_df.rename(columns={\"predictions_NB\": \"NB\", \n",
    "                            \"predictions_SVM\": \"SVM\", \n",
    "                            \"predictions_KNN\": \"KNN\",\n",
    "                            \"predictions_GPT35_zeroshot\": \"GPT35_zeroshot\",\n",
    "                            \"predictions_GPT35_fewshot\": \"GPT35_fewshot\",\n",
    "                            \"predictions_GPT4-32k_zeroshot\": \"GPT4-32k_zeroshot\",\n",
    "                            \"predictions_GPT4-32k_fewshot\": \"GPT4-32k_fewshot\"})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 173,
   "id": "07b9ff27",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Calculate accuracy and F1 score for each prediction column\n",
    "columns_to_evaluate = ['NB', 'SVM', 'KNN', 'GPT35_zeroshot', \n",
    "                       'GPT35_fewshot', 'GPT4-32k_zeroshot', 'GPT4-32k_fewshot']\n",
    "accuracy_scores = []\n",
    "f1_scores = []\n",
    "\n",
    "for column in columns_to_evaluate:\n",
    "    accuracy = accuracy_score(accuracy_df[column], accuracy_df['Test_Y'])\n",
    "    f1 = f1_score(accuracy_df[column], accuracy_df['Test_Y'] , average = 'weighted')\n",
    "    accuracy_scores.append(accuracy)\n",
    "    f1_scores.append(f1)\n",
    "\n",
    "# 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": "43fb424a",
   "metadata": {},
   "source": [
    "# Inspect text outputs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 181,
   "id": "25039050",
   "metadata": {},
   "outputs": [],
   "source": [
    "# get list of unclassified text responses from gpt, \n",
    "\n",
    "def unclassified_subset(text_predictions):\n",
    "    '''\n",
    "    get the list of all unclassified predictions\n",
    "    print true label dist\n",
    "    return new df with original narrative, true label, and prediction\n",
    "    '''\n",
    "\n",
    "    unclassified = text_predictions[~text_predictions.isin(cod_list)].dropna()\n",
    "    indices = unclassified.index\n",
    "    \n",
    "    result = df.iloc[indices][['narrative', 'gs_cod']]\n",
    "    result['prediction'] = unclassified\n",
    "    return result\n",
    "\n",
    "def plot_subset_dist(text_predictions):\n",
    "    '''\n",
    "    get the list of all unclassified predictions\n",
    "    plots the distribution of true labels\n",
    "    '''\n",
    "    \n",
    "    unclassified = text_predictions[~text_predictions.isin(cod_list)].dropna()\n",
    "    indices = unclassified.index\n",
    "    \n",
    "\n",
    "    df.iloc[indices]['gs_cod'].value_counts().plot.barh(title='COD Dist', color = colors).invert_yaxis()\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "57d871b4",
   "metadata": {},
   "source": [
    "## GPT-3.5 zeroshot\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 183,
   "id": "dba21599",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAqYAAAGxCAYAAACwQHQhAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAAA4PklEQVR4nO3de3zP9f//8ft7G9vsZE47MJkzO5BDNacNhYZIHyTJqfpoTjN9JqXwqY+hckoRJfStr0iohPZxmDmFscjmkAxpEmEMY9vr90e/vb9mw2zTXttu18vlfbns/Xw9X8/X4/3c6n33fL1e77fFMAxDAAAAQBGzKeoCAAAAAIlgCgAAAJMgmAIAAMAUCKYAAAAwBYIpAAAATIFgCgAAAFMgmAIAAMAUCKYAAAAwBYIpAAAATIFgCgCl2L59+zRw4ED5+vrKwcFBzs7OatKkiaZOnao///wzW98bN25ozpw5CgoKkpubmxwdHdWgQQO98sorOnfuXI6xQ0JCZLFYZLFYZGNjIxcXF9WuXVs9e/bUl19+qczMzDzVOGDAAOs4FotFTk5OqlGjhp544gl98sknSktLy/XYISEh9zQXCQkJmjBhgpKSku5pPwCFx8JXkgJA6TR//nyFhYWpXr16CgsLU8OGDXXjxg3t3r1b8+fPV6NGjbRixQpJ0pUrVxQaGqotW7boxRdfVJcuXeTo6Kjt27frnXfekbOzs6Kjo1WvXj3r+CEhITp58qQ+++wzSVJqaqqOHTumlStXavXq1WrdurW++eYbubm53bHOAQMGaOnSpdqwYYMk6erVqzp58qTWrFmjZcuWqX79+lq7dq2qVatm3SchIUGS1LBhwzzPx5dffqmePXtq48aN9xxqARQSAwBQ6mzbts2wtbU1OnXqZFy7di3H9rS0NGPVqlXW5y+++KIhyViyZEmOvocOHTLc3NwMPz8/Iz093doeHBxs+Pn55Xr8BQsWGJKMXr163bXW/v37G05OTrluW7dunVGmTBnj4Ycfvus4d7Ns2TJDkrFx48YCjwUgfziVDwCl0KRJk2SxWDRv3jzZ29vn2F62bFk98cQTkqTTp09rwYIF6tixo3r37p2jb926dTVmzBgdOHBAK1euzNPxBw4cqNDQUC1btkzHjx/P9+vo0KGDXnjhBf3www/avHmztT23U/lz5sxRo0aN5OzsLBcXF9WvX1+vvvqqJGnhwoXq2bOnJKlt27bWywYWLlyY79oA3DuCKQCUMhkZGdqwYYOaNm0qHx+fu/bfuHGj0tPT1b1799v2ydoWHR2d5zqeeOIJGYah2NjYPO9zu3EkZQumt1qyZInCwsIUHBysFStWaOXKlRo1apRSU1MlSZ07d9akSZMkSe+//762b9+u7du3q3PnzgWqDcC9sSvqAgAAf6+zZ8/qypUr8vX1zVP/EydOSNId+2dty+qbFw888IAk6bfffsvzPvkdZ+vWrSpfvrxmzZplbWvfvr3158qVK6tOnTqS/rou9ZFHHilQTQDyhxVTAEChsVgsee5rFNK9t3kZ56GHHtKFCxfUp08frVq1SmfPni2UYwMoXARTAChlKlWqpHLlyunYsWN56l+9enVJumP/rG15uTQgS9a1pd7e3nneJ7/j9OvXTwsWLNDx48f11FNPqUqVKnr44Yfv6dIDAPcfwRQAShlbW1u1b99ecXFx+vXXX+/av23btrKzs7vjjU1Z2x577LE81/H111/LYrGoTZs2ed7nduNIuutHPA0cOFDbtm3TxYsXtXr1ahmGoS5duhTo5isAhYtgCgCl0NixY2UYhl544QVdv349x/YbN27om2++kSR5enpq0KBBWrdunb744oscfQ8fPqwpU6bIz8/vjjdI3eyTTz7RmjVr1KdPH+uKbH5ER0fro48+UosWLdSqVas87ePk5KTHH39cr732mq5fv64DBw5IkvXTCa5evZrvegAUDDc/AUApFBQUpDlz5igsLExNmzbVSy+9JD8/P924cUN79+7VvHnz5O/vr65du0qSpk2bpkOHDunZZ5/V5s2b1bVrV9nb22vHjh1655135OLiouXLl8vW1jbbca5evaodO3ZYf/7ll1+0cuVKffvttwoODtbcuXPzVG9mZqZ1nLS0NJ04cUJr1qzR0qVL1aBBAy1duvSO+7/wwgtydHRUy5Yt5eXlpdOnTysqKkpubm5q3ry5JMnf31+SNG/ePLm4uMjBwUG+vr6qWLFi3icWQIHwzU8AUIr9+OOPmj59ujZu3KjTp0+rTJkyqlu3rrp27aphw4apcuXK1r43btzQ/PnztXjxYh04cEA3btxQjRo11K1bN0VGRuYIcCEhIYqJibE+d3JykoeHh5o0aaLevXurR48esrG5+4m7AQMGaNGiRdbnjo6Oqly5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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_subset_dist(predictions_gtp35_zeroshot_text)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 184,
   "id": "88ac8e41",
   "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>narrative</th>\n",
       "      <th>gs_cod</th>\n",
       "      <th>prediction</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>76</th>\n",
       "      <td>no.smooth interview. the informant was very nice.</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>No label applies to the narrative.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>198</th>\n",
       "      <td>no further commentsat the beginning of the interview, the informant did not want to give it because she felt it was not important. however, when i insisted on the study objective and made her realize what benefits might come of it, she agreed to give the interview, and it went well.</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>No label applies to the narrative.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>306</th>\n",
       "      <td>the client said that the service was good</td>\n",
       "      <td>communicable</td>\n",
       "      <td>None of the labels apply to the narrative as it does not provide any information related to the cause of the patient's death.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>345</th>\n",
       "      <td>respondent had nothing to add</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>No label applies to the narrative as the respondent had nothing to add.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>425</th>\n",
       "      <td>participant thanked very much for services which provided by nurses and doctors especially [hospital]</td>\n",
       "      <td>communicable</td>\n",
       "      <td>None of the labels apply to the narrative as it does not describe the cause of the patient's death.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6374</th>\n",
       "      <td>nothe interview went smoothly.  the interviewee was very cooperative.</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>Not enough information is provided in the narrative to determine which label best applies.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6413</th>\n",
       "      <td>no further commentsthe interview flowed smoothly.</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>There is not enough information in the narrative to determine which label best applies.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6450</th>\n",
       "      <td>[person] did not wish to add anything else.the interview went smoothly.</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>There is not enough information in the narrative to determine which label best applies.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6641</th>\n",
       "      <td>the client thanked for services which provided by nurses and in the hospital especial [hospital]._x000d__x000d_\\nthe client claimed serviced which provided in [hospital2].</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>There is not enough information in the narrative to determine which label best applies.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6754</th>\n",
       "      <td>respondent claimed that the service was not good because their patient had been shifted from ward to ward without a notice and bad replies</td>\n",
       "      <td>maternal</td>\n",
       "      <td>None of the labels apply to the narrative as it does not provide information about the cause of the patient's death.</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>88 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                                                                                                                                                                                                                                                        narrative  \\\n",
       "76                                                                                                                                                                                                                                              no.smooth interview. the informant was very nice.   \n",
       "198   no further commentsat the beginning of the interview, the informant did not want to give it because she felt it was not important. however, when i insisted on the study objective and made her realize what benefits might come of it, she agreed to give the interview, and it went well.   \n",
       "306                                                                                                                                                                                                                                                     the client said that the service was good   \n",
       "345                                                                                                                                                                                                                                                                 respondent had nothing to add   \n",
       "425                                                                                                                                                                                         participant thanked very much for services which provided by nurses and doctors especially [hospital]   \n",
       "...                                                                                                                                                                                                                                                                                           ...   \n",
       "6374                                                                                                                                                                                                                        nothe interview went smoothly.  the interviewee was very cooperative.   \n",
       "6413                                                                                                                                                                                                                                            no further commentsthe interview flowed smoothly.   \n",
       "6450                                                                                                                                                                                                                      [person] did not wish to add anything else.the interview went smoothly.   \n",
       "6641                                                                                                                  the client thanked for services which provided by nurses and in the hospital especial [hospital]._x000d__x000d_\\nthe client claimed serviced which provided in [hospital2].   \n",
       "6754                                                                                                                                                   respondent claimed that the service was not good because their patient had been shifted from ward to ward without a notice and bad replies   \n",
       "\n",
       "                gs_cod  \\\n",
       "76    non-communicable   \n",
       "198   non-communicable   \n",
       "306       communicable   \n",
       "345   non-communicable   \n",
       "425       communicable   \n",
       "...                ...   \n",
       "6374  non-communicable   \n",
       "6413  non-communicable   \n",
       "6450  non-communicable   \n",
       "6641  non-communicable   \n",
       "6754          maternal   \n",
       "\n",
       "                                                                                                                         prediction  \n",
       "76                                                                                               No label applies to the narrative.  \n",
       "198                                                                                              No label applies to the narrative.  \n",
       "306   None of the labels apply to the narrative as it does not provide any information related to the cause of the patient's death.  \n",
       "345                                                         No label applies to the narrative as the respondent had nothing to add.  \n",
       "425                             None of the labels apply to the narrative as it does not describe the cause of the patient's death.  \n",
       "...                                                                                                                             ...  \n",
       "6374                                     Not enough information is provided in the narrative to determine which label best applies.  \n",
       "6413                                        There is not enough information in the narrative to determine which label best applies.  \n",
       "6450                                        There is not enough information in the narrative to determine which label best applies.  \n",
       "6641                                        There is not enough information in the narrative to determine which label best applies.  \n",
       "6754           None of the labels apply to the narrative as it does not provide information about the cause of the patient's death.  \n",
       "\n",
       "[88 rows x 3 columns]"
      ]
     },
     "execution_count": 184,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "unclassified_subset(predictions_gtp35_zeroshot_text)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6f5af0fc",
   "metadata": {},
   "source": [
    "## GPT-3.5 fewshot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 185,
   "id": "4439e4b0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAqYAAAGxCAYAAACwQHQhAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAAA5DklEQVR4nO3deVwV5f///+cBFJBN3FgUE3cFwVwqzAW11FzS7K1mZm7Vx3AJtTdmWeK7ErXFpUXfWqb2qY9pplamRi6IWypKmuCSSZhhpikoKArM9w9/nJ8EKiJ6Bnjcb7dzu3FmrrnmNdeoPL1m5hyLYRiGAAAAABuzs3UBAAAAgEQwBQAAgEkQTAEAAGAKBFMAAACYAsEUAAAApkAwBQAAgCkQTAEAAGAKBFMAAACYAsEUAAAApkAwBYAybN++fRoyZIj8/f3l5OQkV1dXNWvWTNOnT9fff/+dp+2VK1c0Z84chYSEyMPDQ87OzmrUqJFeeuklnTlzJl/foaGhslgsslgssrOzk5ubm+rWras+ffroyy+/VE5OTqFqHDx4sLUfi8UiFxcX1apVS48++qg++eQTZWZmFrjv0NDQWxqLhIQERUZGKikp6Za2A1B8LHwlKQCUTfPnz1dYWJgaNGigsLAwNW7cWFeuXNHu3bs1f/58BQcHa8WKFZKkjIwMde3aVVu2bNFzzz2n7t27y9nZWdu3b9fbb78tV1dXRUdHq0GDBtb+Q0NDdfz4cX322WeSpPT0dB07dkwrV67U6tWr1aZNG33zzTfy8PC4YZ2DBw/W0qVLtWHDBknSxYsXdfz4ca1Zs0bLli1Tw4YNtXbtWtWoUcO6TUJCgiSpcePGhR6PL7/8Un369NHGjRtvOdQCKCYGAKDM2bZtm2Fvb2906dLFuHTpUr71mZmZxqpVq6zvn3vuOUOSsWTJknxtDx06ZHh4eBgBAQFGVlaWdXm7du2MgICAAve/YMECQ5LRt2/fm9Y6aNAgw8XFpcB169atM8qVK2fcf//9N+3nZpYtW2ZIMjZu3HjbfQEoGi7lA0AZNGXKFFksFs2bN0+Ojo751pcvX16PPvqoJOnkyZNasGCBOnfurH79+uVrW79+fY0fP14HDhzQypUrC7X/IUOGqGvXrlq2bJl+++23Ih9Hp06d9Oyzz+rHH3/U5s2brcsLupQ/Z84cBQcHy9XVVW5ubmrYsKFefvllSdLChQvVp08fSVL79u2ttw0sXLiwyLUBuHUEUwAoY7Kzs7VhwwY1b95cfn5+N22/ceNGZWVlqVevXtdtk7suOjq60HU8+uijMgxDsbGxhd7mev1IyhNM/2nJkiUKCwtTu3bttGLFCq1cuVJjxoxRenq6JKlbt26aMmWKJOmDDz7Q9u3btX37dnXr1u22agNwaxxsXQAA4O46ffq0MjIy5O/vX6j2ycnJknTD9rnrctsWxj333CNJ+uOPPwq9TVH72bp1qypWrKjZs2dbl3Xs2NH6c9WqVVWvXj1JV+9LfeCBB26rJgBFw4wpAKDYWCyWQrc1iunZ28L0c9999+ncuXPq37+/Vq1apdOnTxfLvgEUL4IpAJQxVapUUYUKFXTs2LFCta9Zs6Yk3bB97rrC3BqQK/feUl9f30JvU9R+Bg4cqAULFui3337T448/rmrVqun++++/pVsPANx5BFMAKGPs7e3VsWNHxcXF6ffff79p+/bt28vBweGGDzblrnv44YcLXcfXX38ti8Witm3bFnqb6/Uj6aYf8TRkyBBt27ZNqampWr16tQzDUPfu3W/r4SsAxYtgCgBl0IQJE2QYhp599lldvnw53/orV67om2++kSR5e3tr6NChWrdunb744ot8bQ8fPqxp06YpICDghg9IXeuTTz7RmjVr1L9/f+uMbFFER0fro48+UqtWrdS6detCbePi4qJHHnlEr7zyii5fvqwDBw5IkvXTCS5evFjkegDcHh5+AoAyKCQkRHPmzFFYWJiaN2+u559/XgEBAbpy5Yr27t2refPmKTAwUD169JAkvfvuuzp06JCeeuopbd68WT169JCjo6N27Niht99+W25ublq+fLns7e3z7OfixYvasWOH9edff/1VK1eu1Lfffqt27dpp7ty5hao3JyfH2k9mZqaSk5O1Zs0aLV26VI0aNdLSpUtvuP2zzz4rZ2dnPfjgg/Lx8dHJkycVFRUlDw8PtWzZUpIUGBgoSZo3b57c3Nzk5OQkf39/Va5cufADC+C28M1PAFCG/fTTT5oxY4Y2btyokydPqly5cqpfv7569OihkSNHqmrVqta2V65c0fz587V48WIdOHBAV65cUa1atdSzZ09FRETkC3ChoaGKiYmxvndxcZGXl5eaNWumfv36qXfv3rKzu/mFu8GDB2vRokXW987OzqpataqCg4P12GOPacCAASpfvny+fUvSpk2bJEmLFy/WwoULlZCQoLNnz6pKlSpq3bq1Jk6cqCZNmli3mzVrlmbNmqXk5GRlZ2frk08+0eDBgws7nABuE8EUAAAApsA9pgAAADAFgikAAABMgWAKAAAAUyCYAgAAwBQIpgAAADAFgikAAABMgQ/YR4mRk5OjP/74Q25ubrJYLLYuBwAAFIJhGDp//rx8fX1v+tnFBFOUGH/88Yf8/PxsXQYAACiC48ePq0aNGjdsQzBFieHm5ibp6h9sd3d3G1cDAAAKIy0tTX5+ftbf4zdCMEWJkXv53t3dnWAKAEAJU5jb8Hj4CQAAAKZAMAUAAIApEEwBAABgCgRTAAAAmALBFAAAAKZAMAUAAIApEEwBAABgCgRTAAAAmALBFAAAAKZAMAUAAIApEEwBAABgCgRTAAAAmALBFAAAAKZAMAUAAIApEEwBAABgCg62LgC4VS9sW6ryLhVsXQYAAKXKf9s8aesSmDEFAACAORBMAQAAYAoEUwAAAJgCwRQAAACmQDAFAACAKRBMAQAAYAoEUwAAAJgCwRQAAACmQDAFAACAKRBMAQAAYAoEUwAAAJgCwRQAAACmQDAFAACAKRBMy4BNmzbJYrHo3LlzxdJfUlKSLBaL4uPj79o+AQBA6UcwLQNatWqllJQUeXh42LoUAACA63KwdQG488qXLy9vb29blwEAAHBDNp0xDQ0N1ejRoxUREaFKlSrJ29tbkZGR1vXJycnq2bOnXF1d5e7urr59++rPP/+0ro+MjFTTpk316aefqlatWvLw8NATTzyh8+fP33C/mZmZioiIkJ+fnxwdHVWvXj19/PHH1vUxMTG677775OjoKB8fH7300kvKysrKU/eoUaMUHh4uT09PeXl5ad68eUpPT9eQIUPk5uamOnXqaM2aNdZtci9tr1u3Tvfee6+cnZ3VoUMHnTp1SmvWrFGjRo3k7u6u/v37KyMjw7pdrVq1NHPmzDz1N23aNM84WSwWffTRR3rsscdUoUIF1atXT19//XW+fV97WX3r1q1q166dKlSoIE9PT3Xu3Flnz56VJK1du1atW7dWxYoVVblyZXXv3l1Hjx7NN44HDx5Uq1at5OTkpICAAG3atOmG475t2za1bdtWzs7O8vPz0+jRo5Wenn7DbQAAQNlh80v5ixYtkouLi3788UdNnz5d//nPfxQdHS3DMNSrVy/9/fffiomJUXR0tI4ePap+/frl2f7o0aNauXKlvv32W3377beKiYnR1KlTb7jPp59+WkuWLNHs2bOVmJiouXPnytXVVZJ04sQJde3aVS1bttRPP/2kOXPm6OOPP9Ybb7yRr+4qVapo586dGjVqlJ5//nn16dNHrVq10p49e9S5c2cNHDgwT8iUrobp999/X9u2bdPx48fVt29fzZw5U59//rlWr16t6Ohovffee7c8jpMnT1bfvn21b98+de3aVQMGDNDff/9dYNv4+Hh17NhRAQEB2r59u7Zs2aIePXooOztbkpSenq6xY8dq165dWr9+vezs7PTYY48pJycnTz///ve/NW7cOO3du1etWrXSo48+qjNnzhS4z/3796tz587q3bu39u3bpy+++EJbtmzRyJEjr3tMmZmZSktLy/MCAACll8UwDMNWOw8NDVV2drZiY2Oty+677z516NBBHTt21COPPKJjx47Jz89PkpSQkKCAgADt3LlTLVu2VGRkpN566y2dPHlSbm5ukqSIiAht3rxZO3bsKHCfhw8fVoMGDRQdHa2HHnoo3/pXXnlFy5cvV2JioiwWiyTpww8/1Pjx45Wamio7O7t8dWdnZ8vDw0O9e/fW4sWLJUknT56Uj4+Ptm/frgceeECbNm1S+/bt9cMPP6hjx46SpKlTp2rChAk6evSoateuLUkaPny4kpKStHbtWklXZ0zDw8MVHh5urbFp06bq1auXddbUYrFo4sSJev311yVdDZZubm767rvv1KVLF+u+z549q4oVK+rJJ59UcnKytmzZUqjz9Ndff6latWrav3+/AgMDlZSUJH9/f02dOlXjx4+XJGVlZcnf31+jRo1SREREvn0+/fTTcnZ21n//+19rv1u2bFG7du2Unp4uJyenfPuNjIzU5MmT8y0fvGa+yrtUKFTtAACgcP7b5sk70m9aWpo8PDyUmpoqd3f3G7a1+YxpUFBQnvc+Pj46deqUEhMT5efnZw2lktS4cWNVrFhRiYmJ1mW1atWyhtJrt5ekzz77TK6urtZXbGys4uPjZW9vr3bt2hVYT2JiokJCQqyhVJIefPBBXbhwQb///nuBddvb26ty5cpq0qSJdZmXl5ckWWspaDsvLy9VqFDBGkpzl/1zm8K4tl8XFxe5ubldt5/cGdPrOXr0qJ58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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_subset_dist(predictions_gtp35_fewshot_text)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 186,
   "id": "01875a43",
   "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>narrative</th>\n",
       "      <th>gs_cod</th>\n",
       "      <th>prediction</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>respondent thanked for being visited</td>\n",
       "      <td>aids-tb</td>\n",
       "      <td>I cannot provide a label without a narrative. Please provide a narrative for me to analyze.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>they are interested in people's health, it does not make sense that they say personal treatment is not relevant, as it is part of this study. there should be a committee that supervises these institutions where poor care is provided and the patients' relatives are badly treated. will this study really be followed up? for the sake of the people that participated in it...emotional support. cellphone: [phone] [person] home :[phone2] stopped eating 2-61 was unconscious</td>\n",
       "      <td>external</td>\n",
       "      <td>It is not clear which label applies to the narrative as there is no specific information provided about the cause of death.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>client had no additional point</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>Please provide the narrative for me to label.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>no comment</td>\n",
       "      <td>communicable</td>\n",
       "      <td>I cannot provide a label without a narrative. Please provide the narrative.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>42</th>\n",
       "      <td>the death certificate has been taken by their daughter to ourservice</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>I'm sorry, but I cannot provide a label without a narrative. Please provide the narrative for me to analyze.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6724</th>\n",
       "      <td>the client has nothing to suggest</td>\n",
       "      <td>communicable</td>\n",
       "      <td>I cannot provide a label without a narrative. Please provide a narrative for me to analyze.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6727</th>\n",
       "      <td>the participant thanked for the service</td>\n",
       "      <td>aids-tb</td>\n",
       "      <td>I'm sorry, but I cannot provide a response without a narrative to analyze. Please provide a narrative for me to analyze.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6747</th>\n",
       "      <td>participant  had no nothing to add</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>I'm sorry, but I cannot provide a label without a narrative. Please provide the narrative for me to analyze.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6755</th>\n",
       "      <td>client had no additional point</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>I'm sorry, but I cannot provide a label without a narrative. Please provide the narrative for me to analyze.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6757</th>\n",
       "      <td>no further comments</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>I'm sorry, but I cannot provide a label without a narrative. Please provide the narrative for me to analyze.</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>856 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  narrative  \\\n",
       "13                                                                                                                                                                                                                                                                                                                                                                                                                                                     respondent thanked for being visited   \n",
       "15    they are interested in people's health, it does not make sense that they say personal treatment is not relevant, as it is part of this study. there should be a committee that supervises these institutions where poor care is provided and the patients' relatives are badly treated. will this study really be followed up? for the sake of the people that participated in it...emotional support. cellphone: [phone] [person] home :[phone2] stopped eating 2-61 was unconscious   \n",
       "19                                                                                                                                                                                                                                                                                                                                                                                                                                                           client had no additional point   \n",
       "23                                                                                                                                                                                                                                                                                                                                                                                                                                                                               no comment   \n",
       "42                                                                                                                                                                                                                                                                                                                                                                                                                     the death certificate has been taken by their daughter to ourservice   \n",
       "...                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     ...   \n",
       "6724                                                                                                                                                                                                                                                                                                                                                                                                                                                      the client has nothing to suggest   \n",
       "6727                                                                                                                                                                                                                                                                                                                                                                                                                                                the participant thanked for the service   \n",
       "6747                                                                                                                                                                                                                                                                                                                                                                                                                                                     participant  had no nothing to add   \n",
       "6755                                                                                                                                                                                                                                                                                                                                                                                                                                                         client had no additional point   \n",
       "6757                                                                                                                                                                                                                                                                                                                                                                                                                                                                    no further comments   \n",
       "\n",
       "                gs_cod  \\\n",
       "13             aids-tb   \n",
       "15            external   \n",
       "19    non-communicable   \n",
       "23        communicable   \n",
       "42    non-communicable   \n",
       "...                ...   \n",
       "6724      communicable   \n",
       "6727           aids-tb   \n",
       "6747  non-communicable   \n",
       "6755  non-communicable   \n",
       "6757  non-communicable   \n",
       "\n",
       "                                                                                                                       prediction  \n",
       "13                                    I cannot provide a label without a narrative. Please provide a narrative for me to analyze.  \n",
       "15    It is not clear which label applies to the narrative as there is no specific information provided about the cause of death.  \n",
       "19                                                                                  Please provide the narrative for me to label.  \n",
       "23                                                    I cannot provide a label without a narrative. Please provide the narrative.  \n",
       "42                   I'm sorry, but I cannot provide a label without a narrative. Please provide the narrative for me to analyze.  \n",
       "...                                                                                                                           ...  \n",
       "6724                                  I cannot provide a label without a narrative. Please provide a narrative for me to analyze.  \n",
       "6727     I'm sorry, but I cannot provide a response without a narrative to analyze. Please provide a narrative for me to analyze.  \n",
       "6747                 I'm sorry, but I cannot provide a label without a narrative. Please provide the narrative for me to analyze.  \n",
       "6755                 I'm sorry, but I cannot provide a label without a narrative. Please provide the narrative for me to analyze.  \n",
       "6757                 I'm sorry, but I cannot provide a label without a narrative. Please provide the narrative for me to analyze.  \n",
       "\n",
       "[856 rows x 3 columns]"
      ]
     },
     "execution_count": 186,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "unclassified_subset(predictions_gtp35_fewshot_text)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6646e8a5",
   "metadata": {},
   "source": [
    "## GPT-4k-32k zeroshot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 187,
   "id": "02f9e6cf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAqYAAAGxCAYAAACwQHQhAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAAA48UlEQVR4nO3deVhV5f7//9cGFJDJmUFRMScEca4cQS011DQ7ambmVB3DCalQy1JP5dTg0KDpyalTH9NMLU2NHHE2jBzAIZMww8wJVBQF1u+PfuyvCCoithfwfFzXvi72ve51r/fad8Wre621sRiGYQgAAACwMTtbFwAAAABIBFMAAACYBMEUAAAApkAwBQAAgCkQTAEAAGAKBFMAAACYAsEUAAAApkAwBQAAgCkQTAEAAGAKBFMAKMb27dunAQMGyM/PT05OTnJ1dVWjRo00depUnTt3Llvf69eva9asWWrWrJk8PDzk7Owsf39/jR49WmfPns0xdkhIiCwWiywWi+zs7OTm5qYaNWqoR48e+uqrr5SZmZmnGvv3728dx2KxyMXFRdWqVdPjjz+u+fPnKy0tLddjh4SE3NVnERcXp/HjxyshIeGu9gNQcCz8SVIAKJ7mzp2rsLAw1a5dW2FhYapbt66uX7+uH3/8UXPnzlX9+vW1fPlySVJqaqpCQ0O1detWvfDCC+rcubOcnZ21Y8cOvfvuu3J1dVVUVJRq165tHT8kJEQnTpzQ559/Lkm6fPmyjh8/rhUrVmj16tVq1aqVvv32W3l4eNy2zv79+2vJkiXasGGDJOnKlSs6ceKE1qxZo6VLl6pOnTpau3atKleubN0nLi5OklS3bt08fx5fffWVevTooY0bN951qAVQQAwAQLGzfft2w97e3ujYsaNx9erVHNvT0tKMlStXWt+/8MILhiRj8eLFOfoePnzY8PDwMAICAoz09HRre3BwsBEQEJDr8efNm2dIMnr27HnHWvv162e4uLjkum3dunVGiRIljIceeuiO49zJ0qVLDUnGxo0b73ksAPnDpXwAKIYmTpwoi8WiOXPmyNHRMcf2kiVL6vHHH5cknTp1SvPmzVOHDh3Uq1evHH1r1aqlUaNG6eDBg1qxYkWejj9gwACFhoZq6dKl+u233/J9Hu3bt9fzzz+vXbt2acuWLdb23C7lz5o1S/Xr15erq6vc3NxUp04dvfrqq5KkBQsWqEePHpKkNm3aWG8bWLBgQb5rA3D3CKYAUMxkZGRow4YNaty4sXx9fe/Yf+PGjUpPT1e3bt1u2SdrW1RUVJ7rePzxx2UYhqKjo/O8z63GkZQtmN5s8eLFCgsLU3BwsJYvX64VK1Zo5MiRunz5siSpU6dOmjhxoiTpo48+0o4dO7Rjxw516tTpnmoDcHccbF0AAOCfdebMGaWmpsrPzy9P/RMTEyXptv2ztmX1zYuqVatKkv74448875PfcbZt26bSpUtr5syZ1rZ27dpZf65QoYJq1qwp6e/7Uh9++OF7qglA/rBiCgAoMBaLJc99jQJ69jYv4zz44IO6cOGCevfurZUrV+rMmTMFcmwABYtgCgDFTPny5VWqVCkdP348T/2rVKkiSbftn7UtL7cGZMm6t9THxyfP++R3nL59+2revHn67bff9OSTT6pixYp66KGH7urWAwD3H8EUAIoZe3t7tWvXTjExMfr999/v2L9NmzZycHC47YNNWdseffTRPNfxzTffyGKxqHXr1nne51bjSLrjVzwNGDBA27dvV3JyslavXi3DMNS5c+d7evgKQMEimAJAMTRmzBgZhqHnn39e165dy7H9+vXr+vbbbyVJXl5eGjhwoNatW6cvv/wyR98jR45oypQpCggIuO0DUjeaP3++1qxZo969e1tXZPMjKipK//3vf9W8eXO1bNkyT/u4uLjoscce02uvvaZr167p4MGDkmT9doIrV67kux4A94aHnwCgGGrWrJlmzZqlsLAwNW7cWC+++KICAgJ0/fp1/fTTT5ozZ44CAwPVpUsXSdL777+vw4cP65lnntGWLVvUpUsXOTo6aufOnXr33Xfl5uamZcuWyd7ePttxrly5op07d1p//vXXX7VixQqtWrVKwcHBmj17dp7qzczMtI6TlpamxMRErVmzRkuWLJG/v7+WLFly2/2ff/55OTs7q0WLFvL29tapU6c0adIkeXh4qGnTppKkwMBASdKcOXPk5uYmJycn+fn5qVy5cnn/YAHcE/7yEwAUYz///LOmTZumjRs36tSpUypRooRq1aqlLl26aOjQoapQoYK17/Xr1zV37lwtWrRIBw8e1PXr11WtWjV17dpVkZGROQJcSEiINm/ebH3v4uIiT09PNWrUSL169VL37t1lZ3fnC3f9+/fXwoULre+dnZ1VoUIF1a9fX0888YT69OmjkiVL5ji2JG3atEmStGjRIi1YsEBxcXE6f/68ypcvr5YtW2rs2LGqV6+edb8ZM2ZoxowZSkxMVEZGhubPn6/+/fvn9eMEcI8IpgAAADAF7jEFAACAKRBMAQAAYAoEUwAAAJgCwRQAAACmQDAFAACAKRBMAQAAYAp8wT4KjczMTP3xxx9yc3OTxWKxdTkAACAPDMPQxYsX5ePjc8fvLiaYotD4448/5Ovra+syAABAPpw4cUKVK1e+bR+CKQoNNzc3SX//g+3u7m7jagAAQF6kpKTI19fX+nv8dgimKDSyLt+7u7sTTAEAKGTychseDz8BAADAFAimAAAAMAWCKQAAAEyBYAoAAABTIJgCAADAFAimAAAAMAWCKQAAAEyBYAoAAABTIJgCAADAFAimAAAAMAWCKQAAAEyBYAoAAABTIJgCAADAFAimAAAAMAWCKQAAAEzBwdYFAHdrxPYlKulSytZlAABQpHzS6mlbl8CKKQAAAMyBYAoAAABTIJgCAADAFAimAAAAMAWCKQAAAEyBYAoAAABTIJgCAADAFAimAAAAMAWCKQAAAEyBYAoAAABTIJgCAADAFAimAAAAMAWCKQAAAEyBYFoMbNq0SRaLRRcuXCiQ8RISEmSxWBQbG/uPHRMAABR9BNNioHnz5kpKSpKHh4etSwEAALglB1sXgPuvZMmS8vLysnUZAAAAt2XTFdOQkBANHz5ckZGRKlu2rLy8vDR+/Hjr9sTERHXt2lWurq5yd3dXz5499eeff1q3jx8/Xg0aNNBnn32matWqycPDQ0899ZQuXrx42+OmpaUpMjJSvr6+cnR0VM2aNfXpp59at2/evFkPPvigHB0d5e3trdGjRys9PT1b3cOGDVN4eLjKlCkjT09PzZkzR5cvX9aAAQPk5uamBx54QGvWrLHuk3Vpe926dWrYsKGcnZ3Vtm1bnT59WmvWrJG/v7/c3d3Vu3dvpaamWverVq2apk+fnq3+Bg0aZPucLBaL/vvf/+qJJ55QqVKlVLNmTX3zzTc5jn3jZfVt27YpODhYpUqVUpkyZdShQwedP39ekrR27Vq1bNlSpUuXVrly5dS5c2cdO3Ysx+d46NAhNW/eXE5OTgoICNCmTZtu+7lv375drVu3lrOzs3x9fTV8+HBdvnz5tvsAAIDiw+aX8hcuXCgXFxft2rVLU6dO1X/+8x9FRUXJMAx169ZN586d0+bNmxUVFaVjx46pV69e2fY/duyYVqxYoVWrVmnVqlXavHmzJk+efNtjPvvss1q8eLFmzpyp+Ph4zZ49W66urpKkkydPKjQ0VE2bNtXPP/+sWbNm6dNPP9Vbb72Vo+7y5ctr9+7dGjZsmF588UX16NFDzZs31969e9WhQwf17ds3W8iU/g7TH374obZv364TJ06oZ8+emj59ur744gutXr1aUVFR+uCDD+76c5wwYYJ69uypffv2KTQ0VH369NG5c+dy7RsbG6t27dopICBAO3bs0NatW9WlSxdlZGRIki5fvqyIiAjt2bNH69evl52dnZ544gllZmZmG+eVV17RSy+9pJ9++knNmzfX448/rrNnz+Z6zP3796tDhw7q3r279u3bpy+//FJbt27V0KFDb3lOaWlpSklJyfYCAABFl8UwDMNWBw8JCVFGRoaio6OtbQ8++KDatm2rdu3a6bHHHtPx48fl6+srSYqLi1NAQIB2796tpk2bavz48XrnnXd06tQpubm5SZIiIyO1ZcsW7dy5M9djHjlyRLVr11ZUVJQeeeSRHNtfe+01LVu2TPHx8bJYLJKkjz/+WKNGjVJycrLs7Oxy1J2RkSEPDw91795dixYtkiSdOnVK3t7e2rFjhx5++GFt2rRJbdq00Q8//KB27dpJkiZPnqwxY8bo2LFjql69uiRp8ODBSkhI0Nq1ayX9vWIaHh6u8PBwa40NGjRQt27drKumFotFY8eO1Ztvvinp72Dp5uam7777Th07drQe+/z58ypdurSefvppJSYmauvWrXmap7/++ksVK1bU/v37FRgYqISEBPn5+Wny5MkaNWqUJCk9PV1+fn4aNmyYIiMjcxzz2WeflbOzsz755BPruFu3blVwcLAuX74sJyenHMcdP368JkyYkKO9/5q5KulSKk+1AwCAvPmk1dP3ZdyUlBR5eHgoOTlZ7u7ut+1r8xXToKCgbO+9vb11+vRpxcfHy9fX1xpKJalu3boqXbq04uPjrW3VqlWzhtIb95ekzz//XK6urtZXdHS0YmNjZW9vr+Dg4FzriY+PV7NmzayhVJJatGihS5cu6ffff8+1bnt7e5UrV0716tWztnl6ekqStZbc9vP09FSpUqWsoTSr7eZ98uLGcV1cXOTm5nbLcbJWTG/l2LFjevrpp1W9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pObNmys1NVVt2rSRq6urtmzZoq1bt8rV1VUdO3bMtjK6fv16xcfHKyoqSqtWrbK2v/baa3r55ZcVGxurWrVqqXfv3kpPT5ckXb16VY0bN9aqVat04MABvfDCC+rbt6927dqV588gLS1NKSkp2V4AAKDoshiGYdi6CGQXEhKijIwMRUdHS/p7RdTDw0Pdu3fXokWLJEmnTp2St7e3duzYoYcffjjHGEOGDNGff/6pr776StLfK58XLlzQihUrrH3mzZunqVOnKj4+XhaLRdLfl+pLly6tFStWqH379urfv7/Wrl2rxMRElSxZUpKUkJAgPz8//fe//9WgQYMkSXFxcQoICFB8fLzq1KmT63l16tRJ/v7+evfdd63n2aBBA02fPj3X/uPHj9eECRNytB/5z1q5Obnc6WM0La9XWtq6BAAA/jEpKSny8PBQcnKy3N3db9uXFVOTCgoKsv5sb2+vcuXKqV69etY2T09PSdLp06clSbNnz1aTJk1UoUIFubq6au7cuUpMTLztMWJiYvTLL7/Izc1Nrq6ucnV1VdmyZXX16lUdO3bM2q9evXrWUHqrGr29vbPVk5GRobfffltBQUEqV66cXF1d9f3339+xphuNGTNGycnJ1teJEyfyvC8AACh8HGxdAHJXokSJbO8tFku2tqwVzszMTC1ZskQjR47Ue++9p2bNmsnNzU3vvPPOHS+bZ2ZmqnHjxvr8889zbKtQoYL1ZxeX3Fcnb1WPJL333nuaNm2apk+frnr16snFxUXh4eF39fCUo6OjHB0d89wfAAAUbgTTIiA6OlrNmzdXWFiYte3GFU9JKlmypDIyMrK1NWrUSF9++aUqVqx4x6X1/NTUtWtXPfPMM5L+DqxHjx6Vv79/gR4HAAAUHVzKLwJq1KihH3/8UevWrdORI0f0+uuva8+ePdn6VKtWTfv27dPhw4d15swZXb9+XX369FH58uXVtWtXRUdH6/jx49q8ebNGjBih33///Z5rioqK0vbt2xUfH69///vfOnXq1D2NCQAAijaCaREwePBgde/eXb169dJDDz2ks2fPZls9laTnn39etWvXtt6Hum3bNpUqVUpbtmxRlSpV1L17d/n7+2vgwIG6cuXKPa+gvv7662rUqJE6dOigkJAQeXl58QX/AADgtngqH4VG1lN9PJUPAEDhwVP5AAAAKHQIpgAAADAF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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_subset_dist(predictions_gpt432k_zeroshot_text)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 188,
   "id": "d44ca514",
   "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>narrative</th>\n",
       "      <th>gs_cod</th>\n",
       "      <th>prediction</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>respondent thanked for being visited</td>\n",
       "      <td>aids-tb</td>\n",
       "      <td>The narrative does not provide enough information to determine a cause of death.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>client had no additional point</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>The narrative does not provide enough information to determine the appropriate label.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>the client thanked for service which provided in the hospital_x000d__x000d_\\nthe client transfer death certificate to their original home [place]</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>The narrative does not provide enough information to determine the cause of death.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>the  client thanked for the service</td>\n",
       "      <td>communicable</td>\n",
       "      <td>The narrative does not provide information related to any of the labels.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>no comment</td>\n",
       "      <td>communicable</td>\n",
       "      <td>The narrative does not provide enough information to determine the cause of death.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6755</th>\n",
       "      <td>client had no additional point</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>The narrative does not provide enough information to determine the appropriate label.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6756</th>\n",
       "      <td>the client had nothing to say</td>\n",
       "      <td>aids-tb</td>\n",
       "      <td>The narrative does not provide enough information to determine a cause of death.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6757</th>\n",
       "      <td>no further comments</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>The narrative does not provide enough information to determine the cause of death.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6759</th>\n",
       "      <td>the participant had nothing to comment on_x000d__x000d_\\nnb:death certificate has been misplaced</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>The narrative does not provide enough information to determine a cause of death.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6762</th>\n",
       "      <td>the client thanked for the service</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>The narrative does not provide information related to any of the labels.</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1502 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                                                                                                              narrative  \\\n",
       "13                                                                                                                 respondent thanked for being visited   \n",
       "19                                                                                                                       client had no additional point   \n",
       "21    the client thanked for service which provided in the hospital_x000d__x000d_\\nthe client transfer death certificate to their original home [place]   \n",
       "22                                                                                                                  the  client thanked for the service   \n",
       "23                                                                                                                                           no comment   \n",
       "...                                                                                                                                                 ...   \n",
       "6755                                                                                                                     client had no additional point   \n",
       "6756                                                                                                                      the client had nothing to say   \n",
       "6757                                                                                                                                no further comments   \n",
       "6759                                                   the participant had nothing to comment on_x000d__x000d_\\nnb:death certificate has been misplaced   \n",
       "6762                                                                                                                 the client thanked for the service   \n",
       "\n",
       "                gs_cod  \\\n",
       "13             aids-tb   \n",
       "19    non-communicable   \n",
       "21    non-communicable   \n",
       "22        communicable   \n",
       "23        communicable   \n",
       "...                ...   \n",
       "6755  non-communicable   \n",
       "6756           aids-tb   \n",
       "6757  non-communicable   \n",
       "6759  non-communicable   \n",
       "6762  non-communicable   \n",
       "\n",
       "                                                                                 prediction  \n",
       "13         The narrative does not provide enough information to determine a cause of death.  \n",
       "19    The narrative does not provide enough information to determine the appropriate label.  \n",
       "21       The narrative does not provide enough information to determine the cause of death.  \n",
       "22                 The narrative does not provide information related to any of the labels.  \n",
       "23       The narrative does not provide enough information to determine the cause of death.  \n",
       "...                                                                                     ...  \n",
       "6755  The narrative does not provide enough information to determine the appropriate label.  \n",
       "6756       The narrative does not provide enough information to determine a cause of death.  \n",
       "6757     The narrative does not provide enough information to determine the cause of death.  \n",
       "6759       The narrative does not provide enough information to determine a cause of death.  \n",
       "6762               The narrative does not provide information related to any of the labels.  \n",
       "\n",
       "[1502 rows x 3 columns]"
      ]
     },
     "execution_count": 188,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "unclassified_subset(predictions_gpt432k_zeroshot_text)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 189,
   "id": "6b845539",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAqYAAAGxCAYAAACwQHQhAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAAA48UlEQVR4nO3deVhV5f7//9cGFJDJmUFRMScEca4cQS011DQ7ambmVB3DCalQy1JP5dTg0KDpyalTH9NMLU2NHHE2jBzAIZMww8wJVBQF1u+PfuyvCCoithfwfFzXvi72ve51r/fad8Wre621sRiGYQgAAACwMTtbFwAAAABIBFMAAACYBMEUAAAApkAwBQAAgCkQTAEAAGAKBFMAAACYAsEUAAAApkAwBQAAgCkQTAEAAGAKBFMAKMb27dunAQMGyM/PT05OTnJ1dVWjRo00depUnTt3Llvf69eva9asWWrWrJk8PDzk7Owsf39/jR49WmfPns0xdkhIiCwWiywWi+zs7OTm5qYaNWqoR48e+uqrr5SZmZmnGvv3728dx2KxyMXFRdWqVdPjjz+u+fPnKy0tLddjh4SE3NVnERcXp/HjxyshIeGu9gNQcCz8SVIAKJ7mzp2rsLAw1a5dW2FhYapbt66uX7+uH3/8UXPnzlX9+vW1fPlySVJqaqpCQ0O1detWvfDCC+rcubOcnZ21Y8cOvfvuu3J1dVVUVJRq165tHT8kJEQnTpzQ559/Lkm6fPmyjh8/rhUrVmj16tVq1aqVvv32W3l4eNy2zv79+2vJkiXasGGDJOnKlSs6ceKE1qxZo6VLl6pOnTpau3atKleubN0nLi5OklS3bt08fx5fffWVevTooY0bN951qAVQQAwAQLGzfft2w97e3ujYsaNx9erVHNvT0tKMlStXWt+/8MILhiRj8eLFOfoePnzY8PDwMAICAoz09HRre3BwsBEQEJDr8efNm2dIMnr27HnHWvv162e4uLjkum3dunVGiRIljIceeuiO49zJ0qVLDUnGxo0b73ksAPnDpXwAKIYmTpwoi8WiOXPmyNHRMcf2kiVL6vHHH5cknTp1SvPmzVOHDh3Uq1evHH1r1aqlUaNG6eDBg1qxYkWejj9gwACFhoZq6dKl+u233/J9Hu3bt9fzzz+vXbt2acuWLdb23C7lz5o1S/Xr15erq6vc3NxUp04dvfrqq5KkBQsWqEePHpKkNm3aWG8bWLBgQb5rA3D3CKYAUMxkZGRow4YNaty4sXx9fe/Yf+PGjUpPT1e3bt1u2SdrW1RUVJ7rePzxx2UYhqKjo/O8z63GkZQtmN5s8eLFCgsLU3BwsJYvX64VK1Zo5MiRunz5siSpU6dOmjhxoiTpo48+0o4dO7Rjxw516tTpnmoDcHccbF0AAOCfdebMGaWmpsrPzy9P/RMTEyXptv2ztmX1zYuqVatKkv74448875PfcbZt26bSpUtr5syZ1rZ27dpZf65QoYJq1qwp6e/7Uh9++OF7qglA/rBiCgAoMBaLJc99jQJ69jYv4zz44IO6cOGCevfurZUrV+rMmTMFcmwABYtgCgDFTPny5VWqVCkdP348T/2rVKkiSbftn7UtL7cGZMm6t9THxyfP++R3nL59+2revHn67bff9OSTT6pixYp66KGH7urWAwD3H8EUAIoZe3t7tWvXTjExMfr999/v2L9NmzZycHC47YNNWdseffTRPNfxzTffyGKxqHXr1nne51bjSLrjVzwNGDBA27dvV3JyslavXi3DMNS5c+d7evgKQMEimAJAMTRmzBgZhqHnn39e165dy7H9+vXr+vbbbyVJXl5eGjhwoNatW6cvv/wyR98jR45oypQpCggIuO0DUjeaP3++1qxZo969e1tXZPMjKipK//3vf9W8eXO1bNkyT/u4uLjoscce02uvvaZr167p4MGDkmT9doIrV67kux4A94aHnwCgGGrWrJlmzZqlsLAwNW7cWC+++KICAgJ0/fp1/fTTT5ozZ44CAwPVpUsXSdL777+vw4cP65lnntGWLVvUpUsXOTo6aufOnXr33Xfl5uamZcuWyd7ePttxrly5op07d1p//vXXX7VixQqtWrVKwcHBmj17dp7qzczMtI6TlpamxMRErVmzRkuWLJG/v7+WLFly2/2ff/55OTs7q0WLFvL29tapU6c0adIkeXh4qGnTppKkwMBASdKcOXPk5uYmJycn+fn5qVy5cnn/YAHcE/7yEwAUYz///LOmTZumjRs36tSpUypRooRq1aqlLl26aOjQoapQoYK17/Xr1zV37lwtWrRIBw8e1PXr11WtWjV17dpVkZGROQJcSEiINm/ebH3v4uIiT09PNWrUSL169VL37t1lZ3fnC3f9+/fXwoULre+dnZ1VoUIF1a9fX0888YT69OmjkiVL5ji2JG3atEmStGjRIi1YsEBxcXE6f/68ypcvr5YtW2rs2LGqV6+edb8ZM2ZoxowZSkxMVEZGhubPn6/+/fvn9eMEcI8IpgAAADAF7jEFAACAKRBMAQAAYAoEUwAAAJgCwRQAAACmQDAFAACAKRBMAQAAYAp8wT4KjczMTP3xxx9yc3OTxWKxdTkAACAPDMPQxYsX5ePjc8fvLiaYotD4448/5Ovra+syAABAPpw4cUKVK1e+bR+CKQoNNzc3SX//g+3u7m7jagAAQF6kpKTI19fX+nv8dgimKDSyLt+7u7sTTAEAKGTychseDz8BAADAFAimAAAAMAWCKQAAAEyBYAoAAABTIJgCAADAFAimAAAAMAWCKQAAAEyBYAoAAABTIJgCAADAFAimAAAAMAWCKQAAAEyBYAoAAABTIJgCAADAFAimAAAAMAWCKQAAAEzBwdYFAHdrxPYlKulSytZlAABQpHzS6mlbl8CKKQAAAMyBYAoAAABTIJgCAADAFAimAAAAMAWCKQAAAEyBYAoAAABTIJgCAADAFAimAAAAMAWCKQAAAEyBYAoAAABTIJgCAADAFAimAAAAMAWCKQAAAEyBYFoMbNq0SRaLRRcuXCiQ8RISEmSxWBQbG/uPHRMAABR9BNNioHnz5kpKSpKHh4etSwEAALglB1sXgPuvZMmS8vLysnUZAAAAt2XTFdOQkBANHz5ckZGRKlu2rLy8vDR+/Hjr9sTERHXt2lWurq5yd3dXz5499eeff1q3jx8/Xg0aNNBnn32matWqycPDQ0899ZQuXrx42+OmpaUpMjJSvr6+cnR0VM2aNfXpp59at2/evFkPPvigHB0d5e3trdGjRys9PT1b3cOGDVN4eLjKlCkjT09PzZkzR5cvX9aAAQPk5uamBx54QGvWrLHuk3Vpe926dWrYsKGcnZ3Vtm1bnT59WmvWrJG/v7/c3d3Vu3dvpaamWverVq2apk+fnq3+Bg0aZPucLBaL/vvf/+qJJ55QqVKlVLNmTX3zzTc5jn3jZfVt27YpODhYpUqVUpkyZdShQwedP39ekrR27Vq1bNlSpUuXVrly5dS5c2cdO3Ysx+d46NAhNW/eXE5OTgoICNCmTZtu+7lv375drVu3lrOzs3x9fTV8+HBdvnz5tvsAAIDiw+aX8hcuXCgXFxft2rVLU6dO1X/+8x9FRUXJMAx169ZN586d0+bNmxUVFaVjx46pV69e2fY/duyYVqxYoVWrVmnVqlXavHmzJk+efNtjPvvss1q8eLFmzpyp+Ph4zZ49W66urpKkkydPKjQ0VE2bNtXPP/+sWbNm6dNPP9Vbb72Vo+7y5ctr9+7dGjZsmF588UX16NFDzZs31969e9WhQwf17ds3W8iU/g7TH374obZv364TJ06oZ8+emj59ur744gutXr1aUVFR+uCDD+76c5wwYYJ69uypffv2KTQ0VH369NG5c+dy7RsbG6t27dopICBAO3bs0NatW9WlSxdlZGRIki5fvqyIiAjt2bNH69evl52dnZ544gllZmZmG+eVV17RSy+9pJ9++knNmzfX448/rrNnz+Z6zP3796tDhw7q3r279u3bpy+//FJbt27V0KFDb3lOaWlpSklJyfYCAABFl8UwDMNWBw8JCVFGRoaio6OtbQ8++KDatm2rdu3a6bHHHtPx48fl6+srSYqLi1NAQIB2796tpk2bavz48XrnnXd06tQpubm5SZIiIyO1ZcsW7dy5M9djHjlyRLVr11ZUVJQeeeSRHNtfe+01LVu2TPHx8bJYLJKkjz/+WKNGjVJycrLs7Oxy1J2RkSEPDw91795dixYtkiSdOnVK3t7e2rFjhx5++GFt2rRJbdq00Q8//KB27dpJkiZPnqwxY8bo2LFjql69uiRp8ODBSkhI0Nq1ayX9vWIaHh6u8PBwa40NGjRQt27drKumFotFY8eO1Ztvvinp72Dp5uam7777Th07drQe+/z58ypdurSefvppJSYmauvWrXmap7/++ksVK1bU/v37FRgYqISEBPn5+Wny5MkaNWqUJCk9PV1+fn4aNmyYIiMjcxzz2WeflbOzsz755BPruFu3blVwcLAuX74sJyenHMcdP368JkyYkKO9/5q5KulSKk+1AwCAvPmk1dP3ZdyUlBR5eHgoOTlZ7u7ut+1r8xXToKCgbO+9vb11+vRpxcfHy9fX1xpKJalu3boqXbq04uPjrW3VqlWzhtIb95ekzz//XK6urtZXdHS0YmNjZW9vr+Dg4FzriY+PV7NmzayhVJJatGihS5cu6ffff8+1bnt7e5UrV0716tWztnl6ekqStZbc9vP09FSpUqWsoTSr7eZ98uLGcV1cXOTm5nbLcbJWTG/l2LFjevrpp1W9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pObNmys1NVVt2rSRq6urtmzZoq1bt8rV1VUdO3bMtjK6fv16xcfHKyoqSqtWrbK2v/baa3r55ZcVGxurWrVqqXfv3kpPT5ckXb16VY0bN9aqVat04MABvfDCC+rbt6927dqV588gLS1NKSkp2V4AAKDoshiGYdi6CGQXEhKijIwMRUdHS/p7RdTDw0Pdu3fXokWLJEmnTp2St7e3duzYoYcffjjHGEOGDNGff/6pr776StLfK58XLlzQihUrrH3mzZunqVOnKj4+XhaLRdLfl+pLly6tFStWqH379urfv7/Wrl2rxMRElSxZUpKUkJAgPz8//fe//9WgQYMkSXFxcQoICFB8fLzq1KmT63l16tRJ/v7+evfdd63n2aBBA02fPj3X/uPHj9eECRNytB/5z1q5Obnc6WM0La9XWtq6BAAA/jEpKSny8PBQcnKy3N3db9uXFVOTCgoKsv5sb2+vcuXKqV69etY2T09PSdLp06clSbNnz1aTJk1UoUIFubq6au7cuUpMTLztMWJiYvTLL7/Izc1Nrq6ucnV1VdmyZXX16lUdO3bM2q9evXrWUHqrGr29vbPVk5GRobfffltBQUEqV66cXF1d9f3339+xphuNGTNGycnJ1teJEyfyvC8AACh8HGxdAHJXokSJbO8tFku2tqwVzszMTC1ZskQjR47Ue++9p2bNmsnNzU3vvPPOHS+bZ2ZmqnHjxvr8889zbKtQoYL1ZxeX3Fcnb1WPJL333nuaNm2apk+frnr16snFxUXh4eF39fCUo6OjHB0d89wfAAAUbgTTIiA6OlrNmzdXWFiYte3GFU9JKlmypDIyMrK1NWrUSF9++aUqVqx4x6X1/NTUtWtXPfPMM5L+DqxHjx6Vv79/gR4HAAAUHVzKLwJq1KihH3/8UevWrdORI0f0+uuva8+ePdn6VKtWTfv27dPhw4d15swZXb9+XX369FH58uXVtWtXRUdH6/jx49q8ebNGjBih33///Z5rioqK0vbt2xUfH69///vfOnXq1D2NCQAAijaCaREwePBgde/eXb169dJDDz2ks2fPZls9laTnn39etWvXtt6Hum3bNpUqVUpbtmxRlSpV1L17d/n7+2vgwIG6cuXKPa+gvv7662rUqJE6dOigkJAQeXl58QX/AADgtngqH4VG1lN9PJUPAEDhwVP5AAAAKHQIpgAAADAF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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "## GPT-4k-32k zeroshot\n",
    "\n",
    "plot_subset_dist(predictions_gpt432k_zeroshot_text)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 190,
   "id": "f1a32561",
   "metadata": {
    "scrolled": true
   },
   "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>narrative</th>\n",
       "      <th>gs_cod</th>\n",
       "      <th>prediction</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>respondent thanked for being visited</td>\n",
       "      <td>aids-tb</td>\n",
       "      <td>The narrative does not provide enough information to determine a cause of death.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>client had no additional point</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>The narrative does not provide enough information to determine the appropriate label.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>the client thanked for service which provided in the hospital_x000d__x000d_\\nthe client transfer death certificate to their original home [place]</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>The narrative does not provide enough information to determine the cause of death.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>the  client thanked for the service</td>\n",
       "      <td>communicable</td>\n",
       "      <td>The narrative does not provide information related to any of the labels.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>no comment</td>\n",
       "      <td>communicable</td>\n",
       "      <td>The narrative does not provide enough information to determine the cause of death.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6755</th>\n",
       "      <td>client had no additional point</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>The narrative does not provide enough information to determine the appropriate label.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6756</th>\n",
       "      <td>the client had nothing to say</td>\n",
       "      <td>aids-tb</td>\n",
       "      <td>The narrative does not provide enough information to determine a cause of death.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6757</th>\n",
       "      <td>no further comments</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>The narrative does not provide enough information to determine the cause of death.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6759</th>\n",
       "      <td>the participant had nothing to comment on_x000d__x000d_\\nnb:death certificate has been misplaced</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>The narrative does not provide enough information to determine a cause of death.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6762</th>\n",
       "      <td>the client thanked for the service</td>\n",
       "      <td>non-communicable</td>\n",
       "      <td>The narrative does not provide information related to any of the labels.</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1502 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                                                                                                              narrative  \\\n",
       "13                                                                                                                 respondent thanked for being visited   \n",
       "19                                                                                                                       client had no additional point   \n",
       "21    the client thanked for service which provided in the hospital_x000d__x000d_\\nthe client transfer death certificate to their original home [place]   \n",
       "22                                                                                                                  the  client thanked for the service   \n",
       "23                                                                                                                                           no comment   \n",
       "...                                                                                                                                                 ...   \n",
       "6755                                                                                                                     client had no additional point   \n",
       "6756                                                                                                                      the client had nothing to say   \n",
       "6757                                                                                                                                no further comments   \n",
       "6759                                                   the participant had nothing to comment on_x000d__x000d_\\nnb:death certificate has been misplaced   \n",
       "6762                                                                                                                 the client thanked for the service   \n",
       "\n",
       "                gs_cod  \\\n",
       "13             aids-tb   \n",
       "19    non-communicable   \n",
       "21    non-communicable   \n",
       "22        communicable   \n",
       "23        communicable   \n",
       "...                ...   \n",
       "6755  non-communicable   \n",
       "6756           aids-tb   \n",
       "6757  non-communicable   \n",
       "6759  non-communicable   \n",
       "6762  non-communicable   \n",
       "\n",
       "                                                                                 prediction  \n",
       "13         The narrative does not provide enough information to determine a cause of death.  \n",
       "19    The narrative does not provide enough information to determine the appropriate label.  \n",
       "21       The narrative does not provide enough information to determine the cause of death.  \n",
       "22                 The narrative does not provide information related to any of the labels.  \n",
       "23       The narrative does not provide enough information to determine the cause of death.  \n",
       "...                                                                                     ...  \n",
       "6755  The narrative does not provide enough information to determine the appropriate label.  \n",
       "6756       The narrative does not provide enough information to determine a cause of death.  \n",
       "6757     The narrative does not provide enough information to determine the cause of death.  \n",
       "6759       The narrative does not provide enough information to determine a cause of death.  \n",
       "6762               The narrative does not provide information related to any of the labels.  \n",
       "\n",
       "[1502 rows x 3 columns]"
      ]
     },
     "execution_count": 190,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "unclassified_subset(predictions_gpt432k_zeroshot_text)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 191,
   "id": "3052034f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# reset display \n",
    "pd.reset_option('display.max_columns', None)\n",
    "pd.reset_option('display.max_colwidth', None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 236,
   "id": "76f6758b",
   "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>0</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>non-communicable</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>non-communicable</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>non-communicable</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>non-communicable</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>non-communicable</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6758</th>\n",
       "      <td>non-communicable</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6759</th>\n",
       "      <td>The narrative does not provide enough information to determine a cause of death.</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6760</th>\n",
       "      <td>external</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6761</th>\n",
       "      <td>external</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6762</th>\n",
       "      <td>The narrative does not provide information related to any of the labels.</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>6763 rows × 1 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                                                     0\n",
       "0                                                                     non-communicable\n",
       "1                                                                     non-communicable\n",
       "2                                                                     non-communicable\n",
       "3                                                                     non-communicable\n",
       "4                                                                     non-communicable\n",
       "...                                                                                ...\n",
       "6758                                                                  non-communicable\n",
       "6759  The narrative does not provide enough information to determine a cause of death.\n",
       "6760                                                                          external\n",
       "6761                                                                          external\n",
       "6762          The narrative does not provide information related to any of the labels.\n",
       "\n",
       "[6763 rows x 1 columns]"
      ]
     },
     "execution_count": 236,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "predictions_gpt432k_zeroshot_text"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6a7bd160",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a526587f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5625516e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eaeb9bf1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6bceffc0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c6e3762b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c4a4bb3c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4739d551",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "573d009b",
   "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
}
