{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "7750490f",
   "metadata": {},
   "source": [
    "# Predicting cause of death from PHMRC VA text narratives using BERT\n",
    "References: <br>\n",
    "https://github.com/theartificialguy/NLP-with-Deep-Learning/blob/master/BERT/Multi-Class%20classification%20TF-BERT/multi_class.ipynb"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "c4c1ae99",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import random \n",
    "import matplotlib.pyplot as plt\n",
    "import tensorflow as tf\n",
    "from tqdm.auto import tqdm\n",
    "from transformers import BertTokenizer\n",
    "from nltk.tokenize import word_tokenize\n",
    "from nltk import pos_tag\n",
    "from nltk.corpus import stopwords\n",
    "from nltk.corpus import wordnet as wn\n",
    "from nltk.stem import WordNetLemmatizer\n",
    "from sklearn.preprocessing import LabelEncoder, OneHotEncoder\n",
    "from sklearn.feature_extraction.text import TfidfVectorizer\n",
    "from sklearn import model_selection, naive_bayes, svm\n",
    "from sklearn.metrics import accuracy_score, f1_score\n",
    "from sklearn.neighbors import KNeighborsClassifier\n",
    "from collections import defaultdict\n",
    "from transformers import TFBertModel"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c692059d",
   "metadata": {},
   "source": [
    "## Load Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b5401a0a",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.read_csv('../../data/phmrc/phmrc_children_cleaned.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "778f0289",
   "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>gs_cod</th>\n",
       "      <th>narrative</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Fires</td>\n",
       "      <td>My son frequently suffered with urine problem....</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>Fires</td>\n",
       "      <td>On 18/04/09, a gas cylinder was burst at home ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>Road Traffic</td>\n",
       "      <td>My nice was studying in a hostel at Mulugu. On...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>Fires</td>\n",
       "      <td>My daughter fell into the hot water accidently...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>Fires</td>\n",
       "      <td>When my son was playing with a kite, its threa...</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         gs_cod                                          narrative\n",
       "0         Fires  My son frequently suffered with urine problem....\n",
       "1         Fires  On 18/04/09, a gas cylinder was burst at home ...\n",
       "2  Road Traffic  My nice was studying in a hostel at Mulugu. On...\n",
       "3         Fires  My daughter fell into the hot water accidently...\n",
       "4         Fires  When my son was playing with a kite, its threa..."
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "98605d53",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'My son frequently suffered with urine problem. We have taken him to hospital. Then we came to know that both his kidneys were infected. He died in 3 days. nan nan nan nan nan nan nan nan nan'"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df['narrative'][0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "bc90e36b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'Other Cardiovascular Diseases': 'THE CLIENT HAS NOTHING TO SUGGEST nan nan nan nan nan nan nan nan nan'}"
      ]
     },
     "execution_count": 61,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Strange case??\n",
    "{df['gs_cod'][1035]:df['narrative'][1035]}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "dcba9096",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Axes: title={'center': 'Class Distribution'}, ylabel='gs_cod'>"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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dOzYETMzMxwcHPjf//7HjRs3aN68OWZmZnh4eHD8+HGddtetW0eFChXQarU4Ojoyffp0nfKMdgMDA7G0tKR79+5ERERgZWXFxo0bKV++PFqtlitXrgBw//59unTpgrm5Ofb29ixevFinveHDh+Pm5oaJiQnOzs4EBwfz+PFjnToTJkygePHimJub061bN0aMGKEzBSswMJAWLVqor9PT05k8eTIuLi5otVrs7e2ZOHFiltcxMDCQ/v37k5CQgEajwdHREXg67WvKlCk4OztjbGxM5cqVWbt2rdp+6dKlWbhwoU5bJ06cQKPRcOnSJQCSk5Pp0aMHxYsXx8LCgk8++YTffvtNrR8SEoKnpyfLli3D2dkZrVb7WiNBQgghhCj4JEERBdLp06fx9fWlVatWnDp1itWrV7N//3769eunU2/mzJnUqlWLkydP4ufnR4cOHejYsSNffPEFJ06cwMXFhY4dO6ofiqOjo/H396dt27acPn2akJAQgoODiYiI0Gl36tSpVKxYkejoaIKDg4GniUhoaChLlizhzJkzFC9eHIDp06dTtWpVTp48SZ8+fejduzd//PGH2pa5uTkRERHExsYye/ZswsLCmDlzplq+YsUKJk6cyOTJk4mOjsbe3p4FCxbkeH1GjhzJ5MmTCQ4OJjY2lpUrV1KiRIks686ePZtx48ZRunRpEhMTOXbsGABff/014eHhLFiwgDNnzjBw4EC++OIL9uzZg56eHm3btmXFihU6ba1cuZIaNWrg7OyMoij4+flx7do1Nm3aRHR0NF5eXtSvX5/bt2+rx1y4cIE1a9awbt06YmJisowxNTWVlJQUnU0IIYQQ7yeNIl9XinwkMDCQH374ASMjI539T5484eHDh+oalI4dO2JsbMyiRYvUOvv378fb25t79+5hZGSEo6MjH3/8Md9//z0A165dw9bWluDgYMaNGwfA4cOHqVGjBomJidjY2BAQEMCNGzfYtm2b2u6wYcP49ddfOXPmDPB0BKVKlSqsX79erRMREUHnzp2JiYmhcuXK6v7nY1AUBRsbG8aOHUuvXr2yvAZTp05l9erV6sjORx99RNWqVZk3b55ap3bt2ty9e1f9QP/s2p1///2XYsWKMW/ePLp165ar6z5r1ixmzZpFfHw8APfu3aNo0aLs2rWLGjVqqPW6devG/fv3WblyJSdPnuSDDz7g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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "df['gs_cod'].value_counts().plot(kind='barh', title='Class Distribution')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "24a0f979",
   "metadata": {},
   "source": [
    "## Pre-processing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "89fe3ba3",
   "metadata": {},
   "outputs": [],
   "source": [
    "tokenizer = BertTokenizer.from_pretrained('bert-base-cased')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "19e625b5",
   "metadata": {},
   "outputs": [],
   "source": [
    "# create empty vectors for storing id and masks\n",
    "X_input_ids = np.zeros((len(df), 256))\n",
    "X_attn_masks = np.zeros((len(df), 256))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "6e009a4c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_training_data(df, ids, masks, tokenizer):\n",
    "    for i, text in tqdm(enumerate(df['narrative'])):\n",
    "        tokenized_text = tokenizer.encode_plus(\n",
    "            text,\n",
    "            max_length=256, \n",
    "            truncation=True, \n",
    "            padding='max_length', \n",
    "            add_special_tokens=True,\n",
    "            return_tensors='tf'\n",
    "        )\n",
    "        ids[i, :] = tokenized_text.input_ids\n",
    "        masks[i, :] = tokenized_text.attention_mask\n",
    "    return ids, masks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "e2dc693c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d383a904ae0a47eaab33bf82369343e4",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "X_input_ids, X_attn_masks = generate_training_data(df, X_input_ids, X_attn_masks, tokenizer)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "729a9ad5",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/adam/anaconda3/lib/python3.11/site-packages/sklearn/preprocessing/_encoders.py:972: FutureWarning: `sparse` was renamed to `sparse_output` in version 1.2 and will be removed in 1.4. `sparse_output` is ignored unless you leave `sparse` to its default value.\n",
      "  warnings.warn(\n"
     ]
    }
   ],
   "source": [
    "# create one-hot encoded target tensor from output classes\n",
    "nominal_vector = np.array(df['gs_cod']).reshape(-1, 1)\n",
    "\n",
    "# Create an instance of OneHotEncoder\n",
    "encoder = OneHotEncoder(sparse=False)\n",
    "\n",
    "# Fit and transform the nominal vector\n",
    "labels = encoder.fit_transform(nominal_vector)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "82a8c76b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# creating a data pipeline using tensorflow dataset utility, creates batches of data for easy training\n",
    "dataset = tf.data.Dataset.from_tensor_slices((X_input_ids, X_attn_masks, labels))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "cf27be82",
   "metadata": {},
   "outputs": [],
   "source": [
    "# map function to return correct batch\n",
    "def SentimentDatasetMapFunction(input_ids, attn_masks, labels):\n",
    "    return {\n",
    "        'input_ids': input_ids,\n",
    "        'attention_mask': attn_masks\n",
    "    }, labels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "974e70ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "# converting to required format for tensorflow dataset \n",
    "dataset = dataset.map(SentimentDatasetMapFunction)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "952b5d0c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# batch size, drop any left out tensor\n",
    "dataset = dataset.shuffle(10000).batch(16, drop_remainder=True) \n",
    "\n",
    "# for each 16 batch of data we will have len(df)//16 samples, 80/20 train test split\n",
    "p = 0.8\n",
    "train_size = int((len(df)//16)*p) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "3b12881c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "103"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_size"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "186bc96b",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_dataset = dataset.take(train_size)\n",
    "val_dataset = dataset.skip(train_size)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "63c67582",
   "metadata": {},
   "source": [
    "## Build the BERT model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "4e54920b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "abbf207cf7cf4d67838754803d23dfce",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Downloading model.safetensors:   0%|          | 0.00/436M [00:00<?, ?B/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Some weights of the PyTorch model were not used when initializing the TF 2.0 model TFBertModel: ['cls.predictions.transform.dense.weight', 'cls.predictions.bias', 'cls.seq_relationship.weight', 'cls.predictions.transform.LayerNorm.bias', 'cls.seq_relationship.bias', 'cls.predictions.transform.dense.bias', 'cls.predictions.transform.LayerNorm.weight']\n",
      "- This IS expected if you are initializing TFBertModel from a PyTorch model trained on another task or with another architecture (e.g. initializing a TFBertForSequenceClassification model from a BertForPreTraining model).\n",
      "- This IS NOT expected if you are initializing TFBertModel from a PyTorch model that you expect to be exactly identical (e.g. initializing a TFBertForSequenceClassification model from a BertForSequenceClassification model).\n",
      "All the weights of TFBertModel were initialized from the PyTorch model.\n",
      "If your task is similar to the task the model of the checkpoint was trained on, you can already use TFBertModel for predictions without further training.\n"
     ]
    }
   ],
   "source": [
    "model = TFBertModel.from_pretrained('bert-base-cased') # bert base model with pretrained weights"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "f3ed96e4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"model_2\"\n",
      "__________________________________________________________________________________________________\n",
      " Layer (type)                Output Shape                 Param #   Connected to                  \n",
      "==================================================================================================\n",
      " input_ids (InputLayer)      [(None, 256)]                0         []                            \n",
      "                                                                                                  \n",
      " attention_mask (InputLayer  [(None, 256)]                0         []                            \n",
      " )                                                                                                \n",
      "                                                                                                  \n",
      " bert (TFBertMainLayer)      TFBaseModelOutputWithPooli   1083102   ['input_ids[0][0]',           \n",
      "                             ngAndCrossAttentions(last_   72         'attention_mask[0][0]']      \n",
      "                             hidden_state=(None, 256, 7                                           \n",
      "                             68),                                                                 \n",
      "                              pooler_output=(None, 768)                                           \n",
      "                             , past_key_values=None, hi                                           \n",
      "                             dden_states=None, attentio                                           \n",
      "                             ns=None, cross_attentions=                                           \n",
      "                             None)                                                                \n",
      "                                                                                                  \n",
      " intermediate_layer (Dense)  (None, 512)                  393728    ['bert[2][1]']                \n",
      "                                                                                                  \n",
      " output_layer (Dense)        (None, 21)                   10773     ['intermediate_layer[0][0]']  \n",
      "                                                                                                  \n",
      "==================================================================================================\n",
      "Total params: 108714773 (414.71 MB)\n",
      "Trainable params: 108714773 (414.71 MB)\n",
      "Non-trainable params: 0 (0.00 Byte)\n",
      "__________________________________________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "# defining 2 input layers for input_ids and attn_masks\n",
    "input_ids = tf.keras.layers.Input(shape=(256,), name='input_ids', dtype='int32')\n",
    "attn_masks = tf.keras.layers.Input(shape=(256,), name='attention_mask', dtype='int32')\n",
    "\n",
    "bert_embds = model.bert(input_ids, attention_mask=attn_masks)[1] # 0 -> activation layer (3D), 1 -> pooled output layer (2D)\n",
    "intermediate_layer = tf.keras.layers.Dense(512, activation='relu', name='intermediate_layer')(bert_embds)\n",
    "output_layer = tf.keras.layers.Dense(21, activation='softmax', name='output_layer')(intermediate_layer) # softmax -> calcs probs of classes\n",
    "\n",
    "cod_model = tf.keras.Model(inputs=[input_ids, attn_masks], outputs=output_layer)\n",
    "cod_model.summary()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "852d4fe5",
   "metadata": {},
   "outputs": [],
   "source": [
    "# loss function, optimizer, and accuracy matrix \n",
    "optim = tf.keras.optimizers.legacy.Adam(learning_rate=1e-5, decay=1e-6)\n",
    "loss_func = tf.keras.losses.CategoricalCrossentropy()\n",
    "acc = tf.keras.metrics.CategoricalAccuracy('accuracy')\n",
    "\n",
    "cod_model.compile(optimizer=optim, loss=loss_func, metrics=[acc])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5af895aa",
   "metadata": {},
   "source": [
    "## Train BERT model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "9f26aed3",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  8/103 [=>............................] - ETA: 55:56 - loss: 3.1911 - accuracy: 0.1016"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "KeyboardInterrupt\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# # LONG RUN TIME\n",
    "# hist = cod_model.fit(\n",
    "#     train_dataset,\n",
    "#     validation_data=val_dataset,\n",
    "#     epochs=1 # can use more epochs (20-25) on better machine with good GPU\n",
    "# )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "09e9b5e7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "INFO:tensorflow:Assets written to: cod_model/assets\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:tensorflow:Assets written to: cod_model/assets\n"
     ]
    }
   ],
   "source": [
    "cod_model.save('cod_model')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6223ed32",
   "metadata": {},
   "source": [
    "## Prediction with BERT model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "39120e7c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# load model from memory\n",
    "cod_model = tf.keras.models.load_model('sentiment_model')\n",
    "\n",
    "tokenizer = BertTokenizer.from_pretrained('bert-base-cased')\n",
    "\n",
    "def prepare_data(input_text, tokenizer):\n",
    "    token = tokenizer.encode_plus(\n",
    "        input_text,\n",
    "        max_length=256, \n",
    "        truncation=True, \n",
    "        padding='max_length', \n",
    "        add_special_tokens=True,\n",
    "        return_tensors='tf'\n",
    "    )\n",
    "    return {\n",
    "        'input_ids': tf.cast(token.input_ids, tf.float64),\n",
    "        'attention_mask': tf.cast(token.attention_mask, tf.float64)\n",
    "    }\n",
    "\n",
    "def make_prediction(model, processed_data, classes=['Negative', 'A bit negative', 'Neutral', 'A bit positive', 'Positive']):\n",
    "    probs = model.predict(processed_data)[0]\n",
    "    return classes[np.argmax(probs)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "2f5c1abf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1035    ['client', 'nothing', 'suggest', 'nan', 'nan',...\n",
       "121     ['baby', 'bear', 'muslim', 'hospital', 'doctor...\n",
       "1431    ['child', 'suffer', 'fever', 'get', 'relief', ...\n",
       "535     ['girl', 'die', 'high', 'fever', 'due', 'say',...\n",
       "319     ['nan', 'nan', 'nan', 'nan', 'nan', 'nan', 'na...\n",
       "                              ...                        \n",
       "1427    ['baby', 'ailment', 'stomach', 'since', 'birth...\n",
       "1146    ['respondetn', 'explain', 'cause', 'death', 'p...\n",
       "1851    ['client', 'thank', 'service', 'nan', 'nan', '...\n",
       "1321    ['client', 'thank', 'service', 'provide', 'nur...\n",
       "2021    ['child', 'severe', 'pain', 'head', 'month', '...\n",
       "Name: tags, Length: 623, dtype: object"
      ]
     },
     "execution_count": 54,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Test_X"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "4409c608",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "\"['baby', 'bear', 'muslim', 'hospital', 'doctor', 'tell', 'u', 'fine', 'bear', 'cry', 'fifteen', 'day', 'continuously', 'take', 'muslim', 'hospital', 'tell', 'u', 'baby', 'two', 'hole', 'heart', 'suggest', 'admit', 'apollo', 'hospital', 'keep', 'observation', 'apollo', 'twenty', 'four', 'hour', 'also', 'say', 'baby', 'survive', 'take', 'niloufer', 'hospital', 'treatment', 'give', 'niloufer', 'good', 'baby', 'difficulty', 'breathe', 'normally', 'finally', 'die', 'nan', 'nan', 'nan', 'nan', 'nan', 'nan', 'nan']\""
      ]
     },
     "execution_count": 56,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Test_X[121]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "fe4a00fb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<_SkipDataset element_spec=({'input_ids': TensorSpec(shape=(16, 256), dtype=tf.float64, name=None), 'attention_mask': TensorSpec(shape=(16, 256), dtype=tf.float64, name=None)}, TensorSpec(shape=(16, 21), dtype=tf.float64, name=None))>"
      ]
     },
     "execution_count": 63,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "val_dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "faa106bb",
   "metadata": {},
   "outputs": [],
   "source": [
    "input_text = input('Enter movie review here: ')\n",
    "processed_data = prepare_data(input_text, tokenizer)\n",
    "result = make_prediction(cod_model, processed_data=processed_data)\n",
    "print(f\"Predicted Sentiment: {result}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b886d60",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "55fdab42",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed14e33d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0af52eb7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c419352e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "68e8f0dd",
   "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
}
