{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "executionInfo": {
     "elapsed": 5,
     "status": "ok",
     "timestamp": 1695324378707,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "F7toc08bpdQ1",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "from transformers import BertModel, BertConfig\n",
    "\n",
    "from transformers import *\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "from torch.utils.data import Dataset, DataLoader\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.metrics import f1_score\n",
    "import textwrap\n",
    "import math\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from IPython.display import clear_output\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "clear_output()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "executionInfo": {
     "elapsed": 15,
     "status": "ok",
     "timestamp": 1695323483676,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "MLk4JWizs4S9",
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_train = pd.read_csv('/home/mostafa_nsu/ICLR/Datasets/IMDB/train.csv')\n",
    "df_val = pd.read_csv('/home/mostafa_nsu/ICLR/Datasets/IMDB/val.csv')\n",
    "df_test = pd.read_csv('/home/mostafa_nsu/ICLR/Datasets/IMDB/test.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "id": "YWiFI0a9QqEa",
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_senti = pd.read_excel('/home/mostafa_nsu/ICLR/Datasets/GoEmotion/sentiwords.xlsx')\n",
    "conditions = [\n",
    "    (df_senti['PosScore'] > df_senti['NegScore']),\n",
    "    (df_senti['PosScore'] < df_senti['NegScore']),\n",
    "    (df_senti['PosScore'] == df_senti['NegScore'])\n",
    "    ]\n",
    "\n",
    "values = ['Positive','Negative','Neutral']\n",
    "\n",
    "df_senti = df_senti[['PosScore','NegScore','Word','Definition']]\n",
    "df_senti['Sentiment'] = np.select(conditions, values)\n",
    "df_senti = df_senti.dropna(axis=0)\n",
    "df_senti.drop(columns=['PosScore', 'NegScore'], inplace=True)\n",
    "df_senti = df_senti[['Word', 'Sentiment', 'Definition']]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "executionInfo": {
     "elapsed": 48,
     "status": "ok",
     "timestamp": 1695323754433,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "vX1DfZpN1W01",
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_train.dropna(inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 206
    },
    "executionInfo": {
     "elapsed": 49,
     "status": "ok",
     "timestamp": 1695323754437,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "e0NG9J-oq_wW",
    "outputId": "f1bb3869-364e-4c7a-8c3f-a62ce4b182c7",
    "tags": []
   },
   "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>Unnamed: 0</th>\n",
       "      <th>review</th>\n",
       "      <th>sentiment</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>48539</td>\n",
       "      <td>This was a very funny movie not Oscarworthy bu...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>26308</td>\n",
       "      <td>I know this film has had a fairly rough ride f...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>14603</td>\n",
       "      <td>Being stuck in bed with the flu and feeling to...</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>45794</td>\n",
       "      <td>This isnt exactly a great film but I admire th...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>21688</td>\n",
       "      <td>It is difficult to rate a writerdirectors firs...</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Unnamed: 0                                             review  sentiment\n",
       "0       48539  This was a very funny movie not Oscarworthy bu...          0\n",
       "1       26308  I know this film has had a fairly rough ride f...          0\n",
       "2       14603  Being stuck in bed with the flu and feeling to...          1\n",
       "3       45794  This isnt exactly a great film but I admire th...          0\n",
       "4       21688  It is difficult to rate a writerdirectors firs...          1"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_train.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "executionInfo": {
     "elapsed": 18,
     "status": "ok",
     "timestamp": 1695323756839,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "UmEtmaFNrakz",
    "tags": []
   },
   "outputs": [],
   "source": [
    "MAX_LEN = 200\n",
    "RANDOM_SEED = 42\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 18,
     "status": "ok",
     "timestamp": 1695323756840,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "6oWORty0p8Xo",
    "outputId": "cb12350b-753a-4c61-c7e8-3c9427f000e9",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n"
     ]
    }
   ],
   "source": [
    "PRE_TRAINED_MODEL_NAME = 'bert-base-uncased'\n",
    "config = BertConfig.from_pretrained(PRE_TRAINED_MODEL_NAME)\n",
    "tokenizer = BertTokenizer.from_pretrained(PRE_TRAINED_MODEL_NAME)\n",
    "clear_output()\n",
    "print(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "id": "yDSL15DQGvrh",
    "tags": []
   },
   "outputs": [],
   "source": [
    "pre_trained_model = BertModel.from_pretrained(PRE_TRAINED_MODEL_NAME).to(device)\n",
    "clear_output()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "executionInfo": {
     "elapsed": 35,
     "status": "ok",
     "timestamp": 1695323767305,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "R2PbApHJGstz",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def get_cls(sent):\n",
    "  encoded_review = tokenizer.encode_plus(\n",
    "  sent,\n",
    "  max_length=MAX_LEN,\n",
    "  add_special_tokens=True,\n",
    "  return_token_type_ids=False,\n",
    "  truncation = True,\n",
    "  padding='max_length',\n",
    "  return_attention_mask=True,\n",
    "  return_tensors='pt',\n",
    "  )\n",
    "  input_ids = encoded_review['input_ids'].to(device)\n",
    "  attention_mask = encoded_review['attention_mask'].to(device)\n",
    "\n",
    "  pre_trained_model.eval()\n",
    "  with torch.no_grad():\n",
    "    output = pre_trained_model(input_ids, attention_mask)\n",
    "    return torch.mean(output[0], dim=1)[0] #Output Avg pooled vector embedding of last layer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "executionInfo": {
     "elapsed": 33,
     "status": "ok",
     "timestamp": 1695323767305,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "dN4TFCeRzGXw",
    "tags": []
   },
   "outputs": [],
   "source": [
    "neg_words = ['ambiguous','angry','annoying','appalling','awful','barbaric','bizarre','blasphemous','brainless','chaotic','contradictory','controversy','cringe','cruel',\n",
    "             'degrading','disturbed','failed','fake','gimmick','hateful','hideous','inadequate','inappropriate','incoherent','loopholes','meaningless','obscure','offensive',\n",
    "             'pathetic','weird']\n",
    "            \n",
    "pos_words = ['acclaimed','accurate','adventurous','astonishing','authentic','beautiful','calming','catchy','charismatic','cheerish','coherent','constructrive','cool',\n",
    "             'cute','daring','eloquent','enthusiastic','romantic','flawless','humorous','inspirational','love','modern','motivated','obsession','phenomenal','relistic',\n",
    "             'refreshing','vibrant','wholesome']\n",
    "\n",
    "\n",
    "new_pos_words = ['captivating','enjoy','outstanding','thoughtful','fun', 'pleasant', 'warm', 'enticing', 'realistic','friendly']\n",
    "new_neg_words = ['biased','horrible','bored','disappointed','frustrate','hostile','ridiculous','malign','rude','unpleasant']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "id": "5hjM7ggAiHnM",
    "tags": []
   },
   "outputs": [],
   "source": [
    "positive_word_meaning_sentences = [\n",
    "'to praise or welcome somebody/something publicly', #acclaimed(verb)\n",
    "'correct and true in every detail', #accurate(adjective)\n",
    "'including new and interesting things, methods and ideas', #adventurous(adjective)\n",
    "'very surprising; difficult to believe',#astonishing (adjective)\n",
    "'known to be real and what somebody claims it is and not a copy',#authentic(adjective)\n",
    "'having beauty; giving pleasure to the senses or to the mind', #beautiful(adjective)\n",
    "'to make somebody/something become quiet and more relaxed, especially after strong emotion or excitement',#calming(verb)\n",
    "'pleasant and easily remembered',#catchy(adjective)\n",
    "'the powerful personal quality that some people have to attract and impress other people',#charisma(noun)\n",
    "'(of a person or their behaviour) happy and cheerful',#cheery(adjective)\n",
    "'(of ideas, thoughts, arguments, etc.) logical and well organized; easy to understand and clear',#coherent(adjective)\n",
    "'having a useful and helpful effect rather than being negative or with no purpose',#constructive(adjective)\n",
    "'used to show that you admire or approve of somebody/something because they are/it is fashionable, attractive and often different',#cool(adjective)\n",
    "'pretty and attractive',#cute(adjective)\n",
    "'brave; willing to do dangerous or unusual things; involving danger or taking risks',#daring(adjective)\n",
    "'able to use language and express your opinions well, especially when you are speaking in public',#eloquent(adjective)\n",
    "'feeling or showing a lot of excitement and interest about somebody/something',#enthusiastic(adjective)\n",
    "'without flaws and therefore perfect',#flawless(adjective)\n",
    "'funny; showing a sense of humour',#humorous(adjective)\n",
    "'providing exciting new ideas; making somebody want to create something, especially in art, literature or music',#inspirational(adjective)\n",
    "]\n",
    "\n",
    "new_positive_word_meaning_sentences = [\n",
    "'taking all your attention; very attractive and interesting',#captivating(adjective)\n",
    "'to get pleasure from something',#enjoy(verb)\n",
    "'extremely good; excellent',#outstanding(adjective)\n",
    "'showing that you think about and care for other people',#thoughtful(adjective)\n",
    "'the feeling of enjoying yourself; activities that you enjoy',#fun(noun)\n",
    "'affording pleasure; being in harmony with your taste or likings', \n",
    "'get warm or warmer', \n",
    "'provoke someone to do something through (often false or exaggerated', \n",
    "'aware or expressing awareness of things as they really are', \n",
    "'kind and pleasant',\n",
    "'a very strong feeling of liking and caring for somebody/something, especially a member of your family or a friend',#love(noun)\n",
    "'of the present time or recent times',#modern(adjective)\n",
    "'wanting to do something, especially something that involves hard work and effort',#motivated(adjective)\n",
    "'a person or thing that somebody thinks about too much',#obsession(noun)\n",
    "'very great or impressive',#phenomenal(adjective)\n",
    "'accepting in a sensible way what it is actually possible to do or achieve in a particular situation',#realistic(adjective)\n",
    "'pleasantly new or different',#refreshing(adjective)\n",
    "'connected with or about love or a sexual relationship',#romantic(adjective)\n",
    "'full of life and energy',#vibrant(adjective)\n",
    "'morally good; having a good moral influence'#wholesome(adjective)\n",
    "]\n",
    "\n",
    "\n",
    "negative_word_meaning_sentences = [\n",
    "'that can be understood in more than one way; having different meanings', #ambiguous(adjective)\n",
    "'having strong feelings about something that you dislike very much or about an unfair situation',#angry(adjective)\n",
    "'making somebody feel slightly angry',#annoying(adjective)\n",
    "'extremely bad, especially from a moral point of view',#appalling(adjective)\n",
    "'very bad or unpleasant',#awful(adjective)\n",
    "'cruel and violent and not as expected from people who are educated and respect each other',#barbaric(adjective)\n",
    "'very strange or unusual',#bizarre(adjective)\n",
    "'(of behaviour or language) showing a lack of respect for God or religion',#blasphemous(adjective)\n",
    "'stupid; not able to think or talk in an intelligent way',#brainless(adjective)\n",
    "'without any order; in a completely confused state',#chaotic(adjective)\n",
    "'containing or showing a lack of agreement between statements, facts, opinions or actions',#contradictory(adjective)\n",
    "'public discussion and argument about something that many people strongly disagree about, think is bad, or are shocked by',#controversy(noun)\n",
    "'to feel very embarrassed and uncomfortable about something',#cringe(verb)\n",
    "'having a desire to cause physical or mental pain and make somebody suffer',#cruel(adjective)\n",
    "'treating somebody as if they have no value, so that they lose their self-respect and the respect of other people',#degrading(adjective)\n",
    "'mentally ill, especially because of very unhappy or unpleasant experiences',#disturbed(adjective)\n",
    "'not successful', #failed(adjective)\n",
    "'not what somebody claims it is; appearing to be something it is not',#fake(adjective)\n",
    "'an unusual trick or unnecessary device that is intended to attract attention or to persuade people to buy something',#gimmick(noun)\n",
    "'very unkind or unpleasant',#hateful(adjective)\n",
    "]\n",
    "\n",
    "new_negative_word_meaning_sentences = [\n",
    "'tending to show favour towards or against one group of people or one opinion for personal reasons; making unfair judgements',#biased(adjective)\n",
    "'very bad or unpleasant; used to describe something that you do not like',#horrible(adjective)\n",
    "'feeling tired and impatient because you have lost interest in somebody/something or because you have nothing to do',#bored(adjective)\n",
    "'upset because something you hoped for has not happened or been as good, successful, etc. as you expected',#disappointed(adjective)\n",
    "'to make somebody feel annoyed or impatient because they cannot do or achieve what they want',#frustrate(verb),\n",
    "'showing or feeling opposition or dislike; unfriendly',\n",
    "'inspiring scornful pity', \n",
    "'speak unfavorably about', \n",
    "'socially incorrect in behavior', \n",
    "'offensive or disagreeable; causing discomfort or unhappiness',\n",
    "'very ugly or unpleasant',#hideous(adjective)\n",
    "'not enough; not good enough',#inadequate(adjective)\n",
    "'not suitable or appropriate in a particular situation',#inappropriate(adjective)\n",
    "'unable to express yourself clearly, often because of emotion',#incoherent(adjective)\n",
    "'a mistake in the way a law, contract, etc. has been written that enables people to legally avoid doing something that the law, contract, etc. had intended them to do',#loophole(noun)\n",
    "'without any purpose or reason and therefore not worth doing or having',#meaningless(adjective)\n",
    "'difficult to understand',#obscure(adjective)\n",
    "'rude in a way that causes somebody to feel upset or annoyed because it shows a lack of respect',#offensive(adjective)\n",
    "'making you feel sad',#pathetic\n",
    "'very strange or unusual and difficult to explain',#weird(adjective)\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 30,
     "status": "ok",
     "timestamp": 1695323767308,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "Y_8HhXvskRFY",
    "outputId": "a8dbea0e-bd42-4116-8e55-4b9c17f6f627",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "20\n",
      "20\n"
     ]
    }
   ],
   "source": [
    "print(len(new_positive_word_meaning_sentences))\n",
    "print(len(new_negative_word_meaning_sentences))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "executionInfo": {
     "elapsed": 3468,
     "status": "ok",
     "timestamp": 1695323770756,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "LNSmtyIyoOUv",
    "tags": []
   },
   "outputs": [],
   "source": [
    "p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "\n",
    "for i in positive_word_meaning_sentences:\n",
    "  p_emb = torch.cat((p_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "for i in negative_word_meaning_sentences:\n",
    "  n_emb = torch.cat((n_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "\n",
    "\n",
    "p_emb = p_emb[1:]\n",
    "n_emb = n_emb[1:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 27,
     "status": "ok",
     "timestamp": 1695323770759,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "V_qXeXCGgjtq",
    "outputId": "b32eec10-206d-4ac3-ed65-f7bef84586d2",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([20, 768])\n",
      "torch.Size([20, 768])\n"
     ]
    }
   ],
   "source": [
    "print(p_emb.shape)\n",
    "print(n_emb.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {
    "executionInfo": {
     "elapsed": 24,
     "status": "ok",
     "timestamp": 1695323770760,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "OtZt1p7ys7XD",
    "tags": []
   },
   "outputs": [],
   "source": [
    "class IMDBDataset(Dataset):\n",
    "\n",
    "  def __init__(self, reviews, sentiments, tokenizer, max_len):\n",
    "    self.reviews = reviews\n",
    "    self.sentiments = sentiments\n",
    "    self.tokenizer = tokenizer\n",
    "    self.max_len = max_len\n",
    "\n",
    "  def __len__(self):\n",
    "    return len(self.reviews)\n",
    "\n",
    "  def __getitem__(self, item):\n",
    "    review = str(self.reviews[item])\n",
    "    sentiment = self.sentiments[item]\n",
    "\n",
    "\n",
    "    encoding = self.tokenizer.encode_plus(\n",
    "      review,\n",
    "      add_special_tokens=True,\n",
    "      max_length=self.max_len,\n",
    "      return_token_type_ids=False,\n",
    "      padding='max_length',\n",
    "      truncation = True,\n",
    "      return_attention_mask=True,\n",
    "      return_tensors='pt',\n",
    "    )\n",
    "\n",
    "    return {\n",
    "      'review': review,\n",
    "      'input_ids': encoding['input_ids'].flatten(),\n",
    "      'attention_mask': encoding['attention_mask'].flatten(),\n",
    "      'sentiments': torch.tensor(sentiment, dtype=torch.long),\n",
    "\n",
    "    }"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {
    "executionInfo": {
     "elapsed": 6,
     "status": "ok",
     "timestamp": 1695325189268,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "UuOujQajtL5f",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def create_data_loader(df, tokenizer, max_len, batch_size):\n",
    "  ds = IMDBDataset(\n",
    "    reviews=df.review.to_numpy(),\n",
    "    sentiments=df['sentiment'].to_numpy(),\n",
    "    tokenizer=tokenizer,\n",
    "    max_len=max_len\n",
    "  )\n",
    "\n",
    "  return DataLoader(\n",
    "    ds,\n",
    "    batch_size=batch_size,\n",
    "    num_workers=8\n",
    "  )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {
    "executionInfo": {
     "elapsed": 24,
     "status": "ok",
     "timestamp": 1695323770761,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "3zzA4eBytOqj",
    "tags": []
   },
   "outputs": [],
   "source": [
    "BATCH_SIZE = 32\n",
    "\n",
    "train_data_loader = create_data_loader(df_train, tokenizer, MAX_LEN, BATCH_SIZE)\n",
    "val_data_loader = create_data_loader(df_val, tokenizer, MAX_LEN, BATCH_SIZE)\n",
    "test_data_loader = create_data_loader(df_test, tokenizer, MAX_LEN, BATCH_SIZE)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 6,
     "status": "ok",
     "timestamp": 1695325187523,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "AoUfRPy0tQgk",
    "outputId": "4cc31257-8fe1-4cce-883e-8aff4ebf2185",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['review', 'input_ids', 'attention_mask', 'sentiments'])"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data = next(iter(train_data_loader))\n",
    "data.keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {
    "executionInfo": {
     "elapsed": 3,
     "status": "ok",
     "timestamp": 1695325688712,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "Y3Nil-yatUqF",
    "tags": []
   },
   "outputs": [],
   "source": [
    "class Classifier(nn.Module):\n",
    "  def __init__(self):\n",
    "    super(Classifier, self).__init__()\n",
    "    self.bert = BertModel.from_pretrained(PRE_TRAINED_MODEL_NAME,config=config)\n",
    "    self.FC = nn.Linear(config.hidden_size,config.hidden_size, bias=False)\n",
    "\n",
    "  def CosineNorm(self, c, b, n_words):\n",
    "    cos = torch.nn.CosineSimilarity(dim=-1, eps=1e-8)\n",
    "    simi = torch.tensor([[1.]*n_words]).to(device)\n",
    "    for i in c:\n",
    "      temp = cos(i,b).to(device)\n",
    "      temp = torch.unsqueeze(temp,0)\n",
    "      simi = torch.cat((simi,temp), dim=0)\n",
    "\n",
    "    return simi[1:]\n",
    "\n",
    "  def binary_output(self,positive, negative):\n",
    "    positive = torch.max(positive,1).values\n",
    "    negative = torch.max(negative,1).values\n",
    "\n",
    "    p_temp = torch.unsqueeze(positive,0)\n",
    "    n_temp = torch.unsqueeze(negative,0)\n",
    "\n",
    "\n",
    "    res = torch.cat((p_temp,n_temp), dim=0)\n",
    "\n",
    "    return torch.t(res)\n",
    "\n",
    "  def forward(self, input_ids, attention_mask, return_scores=False):\n",
    "    with torch.no_grad():\n",
    "      pooled_output = self.bert(\n",
    "        input_ids=input_ids,\n",
    "        attention_mask=attention_mask,\n",
    "        return_dict = False\n",
    "      )\n",
    "    pooled_output = torch.mean(pooled_output[0], dim=1) # Taking Averge pooled last layer embedding\n",
    "\n",
    "    x_sent = self.FC(pooled_output)\n",
    "\n",
    "    Ept = self.FC(p_emb)\n",
    "    Ent = self.FC(n_emb)\n",
    "\n",
    "    positive = F.relu(self.CosineNorm(x_sent, Ept, p_emb.size()[0]))\n",
    "    negative = F.relu(self.CosineNorm(x_sent, Ent, n_emb.size()[0]))\n",
    "\n",
    "    binary_out = self.binary_output(positive,negative)\n",
    "    if(return_scores==True):\n",
    "      return (positive,negative) , binary_out\n",
    "    return binary_out"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {
    "id": "HWZ37gsztWzL",
    "tags": []
   },
   "outputs": [],
   "source": [
    "model = Classifier()\n",
    "model = model.to(device)\n",
    "clear_output()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {
    "executionInfo": {
     "elapsed": 22,
     "status": "ok",
     "timestamp": 1695325221207,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "HWy57v2CxxCM",
    "tags": []
   },
   "outputs": [],
   "source": [
    "for name, param in model.named_parameters():\n",
    "    if name.startswith('bert'):\n",
    "        param.requires_grad = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {
    "executionInfo": {
     "elapsed": 20,
     "status": "ok",
     "timestamp": 1695325221207,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "e5iLu13CYlux",
    "tags": []
   },
   "outputs": [],
   "source": [
    "#for name, param in model.named_parameters():\n",
    "#    print(name, param.requires_grad)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 21,
     "status": "ok",
     "timestamp": 1695325221208,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "nZpqz6yDtYZ4",
    "outputId": "c0ba4f97-cad5-46b8-e1ff-e818ff5b4035",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([32, 200])\n",
      "torch.Size([32, 200])\n"
     ]
    }
   ],
   "source": [
    "input_ids = data['input_ids'].to(device)\n",
    "attention_mask = data['attention_mask'].to(device)\n",
    "sentiments = data['sentiments'].to(device)\n",
    "\n",
    "print(input_ids.shape) # batch size x seq length\n",
    "print(attention_mask.shape) # batch size x seq length"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {
    "executionInfo": {
     "elapsed": 12,
     "status": "ok",
     "timestamp": 1695325221208,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "NwvA-zp7vqc1",
    "tags": []
   },
   "outputs": [],
   "source": [
    "#del test\n",
    "torch.cuda.empty_cache()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {
    "executionInfo": {
     "elapsed": 603,
     "status": "ok",
     "timestamp": 1695325221800,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "-9Z37OXOtb0q",
    "tags": []
   },
   "outputs": [],
   "source": [
    "(positive,negative),outs = model(input_ids, attention_mask,return_scores=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 15,
     "status": "ok",
     "timestamp": 1695325221800,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "NHFM3QUhg3n0",
    "outputId": "602bd955-db78-44a6-931e-e5e901bb1856",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0.7787, 0.7418],\n",
       "        [0.6113, 0.6000],\n",
       "        [0.5249, 0.5214],\n",
       "        [0.5865, 0.5298],\n",
       "        [0.5628, 0.5107],\n",
       "        [0.6240, 0.5789],\n",
       "        [0.6570, 0.6334],\n",
       "        [0.5873, 0.5240],\n",
       "        [0.6013, 0.5566],\n",
       "        [0.5580, 0.5310],\n",
       "        [0.5968, 0.5503],\n",
       "        [0.5646, 0.5202],\n",
       "        [0.5744, 0.5418],\n",
       "        [0.6685, 0.6126],\n",
       "        [0.6362, 0.5906],\n",
       "        [0.5838, 0.5487],\n",
       "        [0.5841, 0.5069],\n",
       "        [0.6330, 0.5700],\n",
       "        [0.6680, 0.6189],\n",
       "        [0.5592, 0.5441],\n",
       "        [0.5393, 0.5341],\n",
       "        [0.5757, 0.5478],\n",
       "        [0.3895, 0.3685],\n",
       "        [0.5862, 0.5498],\n",
       "        [0.7733, 0.7106],\n",
       "        [0.5794, 0.5528],\n",
       "        [0.5690, 0.5451],\n",
       "        [0.6809, 0.6763],\n",
       "        [0.5971, 0.5540],\n",
       "        [0.6146, 0.5749],\n",
       "        [0.7245, 0.7167],\n",
       "        [0.6103, 0.5649]], device='cuda:0', grad_fn=<TBackward0>)"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "outs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 1022,
     "status": "ok",
     "timestamp": 1695325845248,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "cjMVWA5a_6lf",
    "outputId": "bae8764e-0ce8-4118-e676-267b2c3ac06b",
    "tags": []
   },
   "outputs": [],
   "source": [
    "EPOCHS = 8\n",
    "\n",
    "optimizer = AdamW(model.parameters(), lr=0.001)\n",
    "total_steps = len(train_data_loader) * EPOCHS\n",
    "\n",
    "scheduler = get_linear_schedule_with_warmup(\n",
    "  optimizer,\n",
    "  num_warmup_steps=math.floor((1./5)*total_steps),\n",
    "  num_training_steps=total_steps\n",
    ")\n",
    "\n",
    "loss_fn = nn.CrossEntropyLoss().to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {
    "executionInfo": {
     "elapsed": 8,
     "status": "ok",
     "timestamp": 1695325845969,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "cLFDb4pzbx9W",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def train_epoch(\n",
    "  model,\n",
    "  data_loader,\n",
    "  loss_fn,\n",
    "  optimizer,\n",
    "  device,\n",
    "  scheduler,\n",
    "  n_examples\n",
    "):\n",
    "  model = model.train()\n",
    "\n",
    "  losses = []\n",
    "  correct_predictions = 0\n",
    "\n",
    "  for d in data_loader:\n",
    "    input_ids = d[\"input_ids\"].to(device)\n",
    "    attention_mask = d[\"attention_mask\"].to(device)\n",
    "    sentiments = d[\"sentiments\"].to(device)\n",
    "\n",
    "    outputs = model(\n",
    "      input_ids=input_ids,\n",
    "      attention_mask=attention_mask\n",
    "    ).to(device)\n",
    "\n",
    "    _, preds = torch.max(outputs, dim=1)\n",
    "    loss = loss_fn(outputs, sentiments)\n",
    "\n",
    "    correct_predictions += torch.sum(preds == sentiments)\n",
    "    losses.append(loss.item())\n",
    "\n",
    "\n",
    "    loss.backward()\n",
    "    nn.utils.clip_grad_norm_(model.parameters(), max_norm=1.0)\n",
    "    optimizer.step()\n",
    "    scheduler.step()\n",
    "    optimizer.zero_grad()\n",
    "\n",
    "  return correct_predictions.double() / n_examples, np.mean(losses)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {
    "executionInfo": {
     "elapsed": 9,
     "status": "ok",
     "timestamp": 1695325845971,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "z4GAdIawtUue",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def eval_model(model, data_loader, loss_fn, device, n_examples, on_new=False):\n",
    "  model = model.eval()\n",
    "\n",
    "  losses = []\n",
    "  f1s = []\n",
    "\n",
    "  correct_predictions = 0\n",
    "\n",
    "  with torch.no_grad():\n",
    "    for d in data_loader:\n",
    "      input_ids = d[\"input_ids\"].to(device)\n",
    "      attention_mask = d[\"attention_mask\"].to(device)\n",
    "      sentiments = d[\"sentiments\"].to(device)\n",
    "\n",
    "      outputs = model(\n",
    "        input_ids=input_ids,\n",
    "        attention_mask=attention_mask,\n",
    "      ).to(device)\n",
    "      _, preds = torch.max(outputs, dim=1)\n",
    "\n",
    "      loss = loss_fn(outputs, sentiments)\n",
    "\n",
    "      correct_predictions += torch.sum(preds == sentiments)\n",
    "      losses.append(loss.item())\n",
    "\n",
    "      f1s.append(f1_score(sentiments.cpu(), preds.cpu(), average='macro'))\n",
    "\n",
    "  return correct_predictions.double() / n_examples, np.mean(losses), np.mean(f1s)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {
    "executionInfo": {
     "elapsed": 8,
     "status": "ok",
     "timestamp": 1695325846655,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "9tWEJ4saOU6Q",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def batch_calc_score_sum(positive, negative, sentiments):\n",
    "  p_filter = sentiments ^ torch.ones(sentiments.size()[0], dtype=torch.int8).to(device) # Positive ( sentiment xor [1,1,...])\n",
    "  n_filter = sentiments # Negative\n",
    "\n",
    "  pos_score_pos_sent = positive[p_filter.nonzero(), :]\n",
    "  pos_score_neg_sent = positive[n_filter.nonzero(), :]\n",
    "\n",
    "  neg_score_pos_sent = negative[p_filter.nonzero(), :]\n",
    "  neg_score_neg_sent = negative[n_filter.nonzero(), :]\n",
    "\n",
    "  pp_count = pos_score_pos_sent.size()[0]\n",
    "  pn_count = pos_score_neg_sent.size()[0]\n",
    "  pp_sum = torch.sum(pos_score_pos_sent,dim=0)\n",
    "  pn_sum = torch.sum(pos_score_neg_sent,dim=0)\n",
    "\n",
    "\n",
    "#  np_count = neg_score_pos_sent.size()[0] # same as pn_count\n",
    "#  nn_count = neg_score_neg_sent.size()[0] # same as pn_count\n",
    "  np_sum = torch.sum(neg_score_pos_sent,dim=0)\n",
    "  nn_sum = torch.sum(neg_score_neg_sent,dim=0)\n",
    "\n",
    "  return pp_sum,pn_sum,np_sum,nn_sum, pp_count, pn_count\n",
    "\n",
    "def eval_scores_average(model, data_loader, device):\n",
    "  model = model.eval()\n",
    "\n",
    "\n",
    "  pp_sum_agg = torch.zeros(1,p_emb.size()[0]).to(device)\n",
    "  pn_sum_agg = torch.zeros(1,p_emb.size()[0]).to(device)\n",
    "\n",
    "  np_sum_agg = torch.zeros(1,n_emb.size()[0]).to(device)\n",
    "  nn_sum_agg = torch.zeros(1,n_emb.size()[0]).to(device)\n",
    "\n",
    "  pp_count_agg, pn_count_agg = 0,0\n",
    "\n",
    "  with torch.no_grad():\n",
    "    for d in data_loader:\n",
    "      input_ids = d[\"input_ids\"].to(device)\n",
    "      attention_mask = d[\"attention_mask\"].to(device)\n",
    "      sentiments = d[\"sentiments\"].to(device)\n",
    "\n",
    "      (positive,negative),_= model(\n",
    "        input_ids=input_ids,\n",
    "        attention_mask=attention_mask,\n",
    "        return_scores=True\n",
    "      )\n",
    "      positive.to(device)\n",
    "      negative.to(device)\n",
    "\n",
    "\n",
    "      pp_sum,pn_sum,np_sum,nn_sum, pp_count, pn_count = batch_calc_score_sum(positive,negative,sentiments)\n",
    "\n",
    "      pp_sum_agg += pp_sum\n",
    "      pn_sum_agg += pn_sum\n",
    "\n",
    "      np_sum_agg += np_sum\n",
    "      nn_sum_agg += nn_sum\n",
    "\n",
    "      pp_count_agg += pp_count\n",
    "      pn_count_agg += pn_count\n",
    "\n",
    "\n",
    "\n",
    "  return pp_sum_agg/pp_count_agg, pn_sum_agg/pn_count_agg, np_sum_agg/pp_count_agg, nn_sum_agg/pn_count_agg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {
    "executionInfo": {
     "elapsed": 8,
     "status": "ok",
     "timestamp": 1695325846656,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "IxncgTh4awi7",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def box_plot(pp,pn,np,nn):\n",
    "  pp = pp.tolist()[0]\n",
    "  pn = pn.tolist()[0]\n",
    "  np = np.tolist()[0]\n",
    "  nn = nn.tolist()[0]\n",
    "  # Create a box plot with beeswarm using seaborn\n",
    "  sns.set(style=\"whitegrid\")  # Set the style of the plot\n",
    "  plt.figure(figsize=(8, 6))  # Set the figure size\n",
    "  ax = sns.boxplot(data=[pp,pn,np,nn], orient=\"v\", palette=\"Set2\")  # Create the box plot\n",
    "  ax = sns.swarmplot(data=[pp,pn,np,nn], orient=\"v\", color=\"0.2\")  # Add the swarm plot\n",
    "\n",
    "  # Set labels for the axes\n",
    "  ax.set_xlabel('Categories')\n",
    "  ax.set_xticklabels(['pp','pn','np','nn'])\n",
    "  ax.set_ylabel('Scores(µ)')\n",
    "\n",
    "  # Set a title for the plot\n",
    "  #plt.title()\n",
    "\n",
    "  # Show the plot\n",
    "  plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000
    },
    "executionInfo": {
     "elapsed": 3203929,
     "status": "ok",
     "timestamp": 1695329051836,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "IqdIHJsrANr0",
    "outputId": "ee79ec9a-a033-47e0-bc8b-a7b71698465c",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/8\n",
      "----------\n",
      "Train loss 0.5172158502340317 accuracy 0.79835\n",
      "Val   loss 0.4626644360032051 accuracy 0.8502000000000001\n",
      "\n",
      "Epoch 2/8\n",
      "----------\n",
      "Train loss 0.4786549539804459 accuracy 0.8298000000000001\n",
      "Val   loss 0.4574837891539191 accuracy 0.8496\n",
      "\n",
      "Epoch 3/8\n",
      "----------\n",
      "Train loss 0.4683668098211288 accuracy 0.8396250000000001\n",
      "Val   loss 0.4651137687218417 accuracy 0.8464\n",
      "\n",
      "Epoch 4/8\n",
      "----------\n",
      "Train loss 0.4657680220603943 accuracy 0.8423\n",
      "Val   loss 0.47870393562468755 accuracy 0.8298000000000001\n",
      "\n",
      "Epoch 5/8\n",
      "----------\n",
      "Train loss 0.46242413325309756 accuracy 0.8447250000000001\n",
      "Val   loss 0.4534809705178449 accuracy 0.8546\n",
      "\n",
      "Epoch 6/8\n",
      "----------\n",
      "Train loss 0.45975721588134766 accuracy 0.8464250000000001\n",
      "Val   loss 0.4507953370832334 accuracy 0.8548\n",
      "\n",
      "Epoch 7/8\n",
      "----------\n",
      "Train loss 0.45698634297847746 accuracy 0.848375\n",
      "Val   loss 0.4513694040334908 accuracy 0.8524\n",
      "\n",
      "Epoch 8/8\n",
      "----------\n",
      "Train loss 0.4545000075340271 accuracy 0.8530000000000001\n",
      "Val   loss 0.4493409194004763 accuracy 0.8542000000000001\n",
      "\n",
      "CPU times: user 44min 41s, sys: 10 s, total: 44min 51s\n",
      "Wall time: 45min\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "train_a = []\n",
    "train_l = []\n",
    "val_a = []\n",
    "val_l = []\n",
    "best_accuracy = 0\n",
    "\n",
    "for epoch in range(EPOCHS):\n",
    "\n",
    "  print(f'Epoch {epoch + 1}/{EPOCHS}')\n",
    "  print('-' * 10)\n",
    "\n",
    "  train_acc, train_loss = train_epoch(\n",
    "    model,\n",
    "    train_data_loader,\n",
    "    loss_fn,\n",
    "    optimizer,\n",
    "    device,\n",
    "    scheduler,\n",
    "    len(df_train)\n",
    "  )\n",
    "\n",
    "  print(f'Train loss {train_loss} accuracy {train_acc}')\n",
    "\n",
    "  val_acc, val_loss, val_f1 = eval_model(\n",
    "    model,\n",
    "    val_data_loader,\n",
    "    loss_fn,\n",
    "    device,\n",
    "    len(df_val)\n",
    "  )\n",
    "\n",
    "  print(f'Val   loss {val_loss} accuracy {val_acc}')\n",
    "  print()\n",
    "\n",
    "  train_a.append(train_acc)\n",
    "  train_l.append(train_loss)\n",
    "  val_a.append(val_acc)\n",
    "  val_l.append(val_loss)\n",
    "\n",
    "  if val_acc > best_accuracy:\n",
    "    torch.save(model.state_dict(), 'bert_best_model_state.bin')\n",
    "    best_accuracy = val_acc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {
    "executionInfo": {
     "elapsed": 51,
     "status": "ok",
     "timestamp": 1695329137842,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "FowMSU5U7SDQ",
    "tags": []
   },
   "outputs": [],
   "source": [
    "train_a = [i.item() for i in train_a]\n",
    "train_l = [i.item() for i in train_l]\n",
    "val_a = [i.item() for i in val_a]\n",
    "val_l = [i.item() for i in val_l]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 480
    },
    "executionInfo": {
     "elapsed": 2888,
     "status": "ok",
     "timestamp": 1695329143450,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "aUQbxyTEAPhM",
    "outputId": "b103ca88-1886-4f16-ea21-5b966a08fe7c",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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XbtqxYoVksou/P3LX/6ixx57TE6nU4sWLapz2YiICGVlZVVrP3TokCSpTZs2bu01/feRpDFjxqhHjx5aunSpSktLtXPnTs2fP/8M9gawHkZuAFRjGIZrtKTCli1b9NVXX3mpInf9+vVT69attWrVKrf2vXv3asuWLee0lt69e2vu3Lnq2bOn2/dT2wjQ1Vdfre3bt7t+WVXh1Vdflc1m0xVXXNGg7RqGod/85jd655139Oijj6pDhw4aP378We0LYBWEGwDVXH/99Xrvvfe0YMECbdiwQUuXLtV1112nLl26eLs0SZKvr68effRRbdy4Ubfeeqvef/99rVy5UqNHj1a7du1kszXd/9q++OILXXnllXrhhRe0bt06bdiwQQ899JB2796tkSNHuvpdeOGF2rJli/76179qy5YtrjDz4IMPKjIyUqNHj1ZqaqrWrVune+65R8uWLdPMmTPVuXPnBteSkJCgoKAg/etf/1JiYmKzvyEicK5wWgpANXPnzlVxcbGSk5P1+OOPq1+/flq+fLleffVVbd++3dvlSZKmT58uu92uhQsXavXq1eratavmzZun1157Tfn5+U223Q4dOqhTp05asmSJDhw4IJvNpm7dumnx4sWaNm2aq9/jjz+u3Nxc3XHHHSosLFSvXr20a9cuxcTEaPPmzZozZ44efPBBFRQUqFu3blq0aJGmT5/uUS2hoaEaO3asVq9erbvvvruxdxVosQzTrHTXKABowY4cOaIePXrotttuq3a9kBWdPHlSnTp10pgxY/Tqq696uxyg2WDkBkCLlJmZqYULF2rEiBFq3bq1MjIy9Oyzz6qoqEi/+c1vvF1ek8rJydG3336rl156SceOHdPs2bO9XRLQrBBuALRIAQEB2rNnj9544w0dPXpUISEhGjp0qFasWKEePXp4u7wmtXr1av36179W+/bt9ac//cnjh3oCVsdpKQAAYCle/bXUxo0bNW7cOLVr106GYejdd9+td5lPP/1UAwcOVEBAgLp27aoXX3zxHFQKAABaCq+GmxMnTmjAgAFaunRpg/pnZGRo7NixGj58uLZt26bf/e53mj59ut5+++0mrhQAALQUzea0lGEYeuedd+q8CdVvf/tbrVmzxu3ZNomJidqxY4c2b958LsoEAADNXIu6oHjz5s0aNWqUW9vo0aO1bNkylZSUyNfXt9oyRUVFKioqck07nU4dPXpUERERtd7WHAAANC+maaqgoKBBN+psUeEmOzu72kPxoqKiVFpaqtzc3FofADhv3rxzVSIAAGhC+/fvV4cOHers06LCjVT9IXIVZ9VqG4WZM2eOZs2a5ZrOy8tTp06dtH//foWFhTVdoQAAoNHk5+erY8eOCg0Nrbdviwo30dHR1Z74m5OTIx8fH9dTgqvy9/ev9gBASQoLCyPcAADQwjTkkpIW9eDM+Ph4rV+/3q3tww8/1KBBg2q83gYAAJx/vBpuCgsLtX37dteD+DIyMrR9+3ZlZmZKKjulNHnyZFf/xMREff/995o1a5bS09OVmpqqZcuW6YEHHvBK/QAAoPnx6mmpLVu26Morr3RNV1wbM2XKFK1YsUJZWVmuoCNJsbGxWrt2re677z698MILateunRYvXqyf/exn57x2AADQPDWb+9ycK/n5+QoPD1deXh7X3ABokRwOh0pKSrxdBtDo/Pz8av2ZtyfH7xZ1QTEAnM9M01R2draOHz/u7VKAJmGz2RQbGys/P7+zWg/hBgBaiIpg07ZtWwUFBXEjUliK0+nUoUOHlJWVpU6dOp3V3zfhBgBaAIfD4Qo2td36AmjpIiMjdejQIZWWlp7Vr6Bb1E/BAeB8VXGNTVBQkJcrAZpOxekoh8NxVush3ABAC8KpKFhZY/19E24AAIClEG4AAC1Kly5dtGjRIm+XgWaMC4oBAE3qiiuu0EUXXdRogeTLL79UcHBwo6wL1kS4AQB4nWmacjgc8vGp/7AUGRl5Dio6tzzZf9SP01IAgCaTkJCgTz/9VM8//7wMw5BhGNq3b58++eQTGYahdevWadCgQfL391daWpr27t2rG2+8UVFRUQoJCdHgwYP1z3/+022dVU9LGYahl19+WTfddJOCgoLUo0cPrVmzps66Vq5cqUGDBik0NFTR0dGaNGmScnJy3Pr897//1XXXXaewsDCFhoZq+PDh2rt3r2t+amqq+vbtK39/f8XExOjee++VJO3bt0+GYbiemyhJx48fl2EY+uSTTyTprPa/qKhIs2fPVseOHeXv768ePXpo2bJlMk1T3bt31zPPPOPW/5tvvpHNZnOr3eoINwDQQpmmqR+LS73yauiTe55//nnFx8fr7rvvVlZWlrKystSxY0fX/NmzZyspKUnp6enq37+/CgsLNXbsWP3zn//Utm3bNHr0aI0bN87tOYM1mTdvniZMmKCvv/5aY8eO1S9+8QsdPXq01v7FxcV67LHHtGPHDr377rvKyMhQQkKCa/7Bgwd1+eWXKyAgQBs2bNDWrVs1depUlZaWSpJSUlJ0zz336Je//KX+85//aM2aNerevXuDvpPKzmT/J0+erL/85S9avHix0tPT9eKLLyokJESGYWjq1Klavny52zZSU1M1fPhwdevWzeP6WirGvwCghTpZ4lDcI+u8su2d80cryK/+Q0h4eLj8/PwUFBSk6OjoavPnz5+vkSNHuqYjIiI0YMAA1/SCBQv0zjvvaM2aNa6RkZokJCTo1ltvlSQ98cQTWrJkib744gtde+21NfafOnWq63PXrl21ePFiXXrppSosLFRISIheeOEFhYeH6y9/+YvrZnI9e/Z0q+v+++/XjBkzXG2DBw+u7+uoxtP9//bbb/Xmm29q/fr1uuaaa1z1V7jjjjv0yCOP6IsvvtCll16qkpISrVy5Un/4wx88rq0lY+QGAOA1gwYNcps+ceKEZs+erbi4OF1wwQUKCQnRrl276h256d+/v+tzcHCwQkNDq51mqmzbtm268cYb1blzZ4WGhuqKK66QJNd2tm/fruHDh9d4l9ycnBwdOnRIV199dUN3s1ae7v/27dtlt9s1YsSIGtcXExOj6667TqmpqZKkv//97zp16pRuvvnms661JWHkBgBaqEBfu3bOH+21bTeGqr96evDBB7Vu3To988wz6t69uwIDA/Xzn/9cxcXFda6naggxDENOp7PGvidOnNCoUaM0atQorVy5UpGRkcrMzNTo0aNd2wkMDKx1W3XNk+R6qnXlU3e1PcXd0/2vb9uSdNddd+n222/Xc889p+XLl2vixInn3Z2tCTcA0EIZhtGgU0Pe5ufn1+Db6aelpSkhIUE33XSTJKmwsFD79u1r1Hp27dql3NxcPfnkk67rf7Zs2eLWp3///nrllVdUUlJSLTiFhoaqS5cu+uijj3TllVdWW3/Fr7mysrJ08cUXS5LbxcV1qW//L7zwQjmdTn366aeu01JVjR07VsHBwUpJSdH777+vjRs3NmjbVsJpKQBAk+rSpYs+//xz7du3T7m5ubWOqEhS9+7dtXr1am3fvl07duzQpEmT6ux/Jjp16iQ/Pz8tWbJE3333ndasWaPHHnvMrc+9996r/Px83XLLLdqyZYv27Nmj1157Tbt375YkzZ07V88++6wWL16sPXv26KuvvtKSJUsklY2uXHbZZXryySe1c+dObdy4Ub///e8bVFt9+9+lSxdNmTJFU6dOdV0I/cknn+jNN9909bHb7UpISNCcOXPUvXt3xcfHn+1X1uIQbgAATeqBBx6Q3W5XXFyc6xRQbZ577jm1atVKQ4cO1bhx4zR69GhdcskljVpPZGSkVqxYobfeektxcXF68sknq/18OiIiQhs2bFBhYaFGjBihgQMH6k9/+pNrFGfKlClatGiRkpOT1bdvX11//fXas2ePa/nU1FSVlJRo0KBBmjFjhhYsWNCg2hqy/ykpKfr5z3+uadOmqXfv3rr77rt14sQJtz533nmniouL3S6cPp8YZkN/z2cR+fn5Cg8PV15ensLCwrxdDgA0yKlTp5SRkaHY2FgFBAR4uxw0c5999pmuuOIKHThwQFFRUd4up8Hq+jv35Pjd/E/WAgCABikqKtL+/fv1f//3f5owYUKLCjaNidNSAABYxBtvvKFevXopLy9PTz/9tLfL8RrCDQAAFpGQkCCHw6GtW7eqffv23i7Hawg3AADAUgg3AADAUgg3AADAUgg3AADAUgg3AADAUgg3AADAUgg3AIBmr0uXLlq0aJFr2jAMvfvuu7X237dvnwzDaPADK5t6PTi3uEMxAKDFycrKUqtWrRp1nQkJCTp+/LhbaOrYsaOysrLUpk2bRt0WmhbhBgDQ4kRHR5+T7djt9nO2reampKTE9aDQlobTUgCAJvPSSy+pffv2cjqdbu033HCDpkyZIknau3evbrzxRkVFRSkkJESDBw/WP//5zzrXW/W01BdffKGLL75YAQEBGjRokLZt2+bW3+Fw6M4771RsbKwCAwPVq1cvPf/88675c+fO1SuvvKK//e1vMgxDhmHok08+qfG01KeffqpLL71U/v7+iomJ0UMPPaTS0lLX/CuuuELTp0/X7Nmz1bp1a0VHR2vu3Ll17s+XX36pkSNHqk2bNgoPD9eIESP01VdfufU5fvy4fvnLXyoqKkoBAQHq16+f/v73v7vmf/bZZxoxYoSCgoLUqlUrjR49WseOHZNU/bSeJF100UVudRmGoRdffFE33nijgoODtWDBgnq/twqpqanq27ev6zu59957JUlTp07V9ddf79a3tLRU0dHRSk1NrfM7ORuM3ABAS2WaUsmP3tm2b5BkGPV2u/nmmzV9+nR9/PHHuvrqqyVJx44d07p16/Tee+9JkgoLCzV27FgtWLBAAQEBeuWVVzRu3Djt3r1bnTp1qncbJ06c0PXXX6+rrrpKK1euVEZGhmbMmOHWx+l0qkOHDnrzzTfVpk0bbdq0Sb/85S8VExOjCRMm6IEHHlB6erry8/O1fPlySVLr1q116NAht/UcPHhQY8eOVUJCgl599VXt2rVLd999twICAtyCwiuvvKJZs2bp888/1+bNm5WQkKBhw4Zp5MiRNe5DQUGBpkyZosWLF0uSnn32WY0dO1Z79uxRaGionE6nxowZo4KCAq1cuVLdunXTzp07ZbfbJUnbt2/X1VdfralTp2rx4sXy8fHRxx9/LIfDUe/3V9mjjz6qpKQkPffcc7Lb7fV+b5KUkpKiWbNm6cknn9SYMWOUl5enzz77TJJ011136fLLL1dWVpZiYmIkSWvXrlVhYaFr+aZAuAGAlqrkR+mJdt7Z9u8OSX7B9XZr3bq1rr32Wv35z392hZu33npLrVu3dk0PGDBAAwYMcC2zYMECvfPOO1qzZo1rBKAur7/+uhwOh1JTUxUUFKS+ffvqwIED+vWvf+3q4+vrq3nz5rmmY2NjtWnTJr355puaMGGCQkJCFBgYqKKiojpPQyUnJ6tjx45aunSpDMNQ7969dejQIf32t7/VI488Iput7IRI//799eijj0qSevTooaVLl+qjjz6qNdxcddVVbtMvvfSSWrVqpU8//VTXX3+9/vnPf+qLL75Qenq6evbsKUnq2rWrq//TTz+tQYMGKTk52dXWt2/fer+7qiZNmqSpU6e6tdX1vUll/73uv/9+t0A5ePBgSdLQoUPVq1cvvfbaa5o9e7Ykafny5br55psVEhLicX0NxWkpAECT+sUvfqG3335bRUVFksrCyC233OIadThx4oRmz56tuLg4XXDBBQoJCdGuXbuUmZnZoPWnp6drwIABCgoKcrXFx8dX6/fiiy9q0KBBioyMVEhIiP70pz81eBuVtxUfHy+j0qjVsGHDVFhYqAMHDrja+vfv77ZcTEyMcnJyal1vTk6OEhMT1bNnT4WHhys8PFyFhYWu+rZv364OHTq4gk1VFSM3Z2vQoEHV2ur63nJycnTo0KE6t33XXXe5RsNycnL0j3/8o1qAamyM3ABAS+UbVDaC4q1tN9C4cePkdDr1j3/8Q4MHD1ZaWpoWLlzomv/ggw9q3bp1euaZZ9S9e3cFBgbq5z//uYqLixu0ftM06+3z5ptv6r777tOzzz6r+Ph4hYaG6g9/+IM+//zzBu9HxbaMKqfjKrZfub3qhbiGYVS77qiyhIQEHT58WIsWLVLnzp3l7++v+Ph413cQGBhYZ131zbfZbNW+p5KSkmr9goPdR+Pq+97q264kTZ48WQ899JA2b96szZs3q0uXLho+fHi9y50Nwg0AtFSG0aBTQ94WGBion/70p3r99df1v//9Tz179tTAgQNd89PS0pSQkKCbbrpJUtk1OPv27Wvw+uPi4vTaa6/p5MmTroPtv//9b7c+aWlpGjp0qKZNm+Zq27t3r1sfPz+/eq9RiYuL09tvv+0WcjZt2qTQ0FC1b9++wTVXlZaWpuTkZI0dO1aStH//fuXm5rrm9+/fXwcOHNC3335b4+hN//799dFHH7mdQqosMjJSWVlZrun8/HxlZGQ0qK66vrfQ0FB16dJFH330ka688soa1xEREaHx48dr+fLl2rx5s+644456t3u2OC0FAGhyv/jFL/SPf/xDqampuu2229zmde/eXatXr9b27du1Y8cOTZo0qc5RjqomTZokm82mO++8Uzt37tTatWv1zDPPVNvGli1btG7dOn377bf6v//7P3355Zdufbp06aKvv/5au3fvVm5ubo0jG9OmTdP+/fv1m9/8Rrt27dLf/vY3Pfroo5o1a5brepsz0b17d7322mtKT0/X559/rl/84hduoyIjRozQ5Zdfrp/97Gdav369MjIy9P777+uDDz6QJM2ZM0dffvmlpk2bpq+//lq7du1SSkqKKyBdddVVeu2115SWlqZvvvlGU6ZMcZ0WrK+u+r63uXPn6tlnn9XixYu1Z88effXVV1qyZIlbn7vuukuvvPKK0tPTXb+Sa0qEGwBAk7vqqqvUunVr7d69W5MmTXKb99xzz6lVq1YaOnSoxo0bp9GjR+uSSy5p8LpDQkL03nvvaefOnbr44ov18MMP66mnnnLrk5iYqJ/+9KeaOHGihgwZoiNHjriNRkjS3XffrV69ermuL6n4xU9l7du319q1a/XFF19owIABSkxM1J133qnf//73Hnwb1aWmpurYsWO6+OKLdfvtt2v69Olq27atW5+3335bgwcP1q233qq4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wX6Nvi0AAFA7r4WbNm3ayG63VxulycnJqTaaUyEpKUnDhg3Tgw8+KEnq37+/goODNXz4cC1YsEAxMdUfAOjv7y9//6Y/3WOzGXozMb7JtwMAAOrmtXMjfn5+GjhwoNavX+/Wvn79eg0dOrTGZX788UfZbO4l2+1lP3324nXRAACgGfHqhR+zZs3Syy+/rNTUVKWnp+u+++5TZmamEhMTJZWdUpo8ebKr/7hx47R69WqlpKTou+++02effabp06fr0ksvVbt27by1GwAAoBnx6jU3EydO1JEjRzR//nxlZWWpX79+Wrt2rTp37ixJysrKUmZmpqt/QkKCCgoKtHTpUt1///264IILdNVVV+mpp57y1i4AAIBmxqv3ufGGc3mfGwAA0Dg8OX7ze2QAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGApXg83ycnJio2NVUBAgAYOHKi0tLQ6+xcVFenhhx9W586d5e/vr27duik1NfUcVQsAAJo7H29ufNWqVZo5c6aSk5M1bNgwvfTSSxozZox27typTp061bjMhAkT9MMPP2jZsmXq3r27cnJyVFpaeo4rBwAAzZVhmqbprY0PGTJEl1xyiVJSUlxtffr00fjx45WUlFSt/wcffKBbbrlF3333nVq3bn1G28zPz1d4eLjy8vIUFhZ2xrUDAIBzx5Pjt9dOSxUXF2vr1q0aNWqUW/uoUaO0adOmGpdZs2aNBg0apKefflrt27dXz5499cADD+jkyZO1bqeoqEj5+fluLwAAYF1eOy2Vm5srh8OhqKgot/aoqChlZ2fXuMx3332nf/3rXwoICNA777yj3NxcTZs2TUePHq31upukpCTNmzev0esHAADNk9cvKDYMw23aNM1qbRWcTqcMw9Drr7+uSy+9VGPHjtXChQu1YsWKWkdv5syZo7y8PNdr//79jb4PAACg+fDayE2bNm1kt9urjdLk5ORUG82pEBMTo/bt2ys8PNzV1qdPH5mmqQMHDqhHjx7VlvH395e/v3/jFg8AAJotr43c+Pn5aeDAgVq/fr1b+/r16zV06NAalxk2bJgOHTqkwsJCV9u3334rm82mDh06NGm9AACgZfDqaalZs2bp5ZdfVmpqqtLT03XfffcpMzNTiYmJkspOKU2ePNnVf9KkSYqIiNAdd9yhnTt3auPGjXrwwQc1depUBQYGems3AABAM+LV+9xMnDhRR44c0fz585WVlaV+/fpp7dq16ty5syQpKytLmZmZrv4hISFav369fvOb32jQoEGKiIjQhAkTtGDBAm/tAgAAaGa8ep8bb+A+NwAAtDxNep+bjIyMMy4MAACgqXkcbrp3764rr7xSK1eu1KlTp5qiJgAAgDPmcbjZsWOHLr74Yt1///2Kjo7Wr371K33xxRdNURsAAIDHPA43/fr108KFC3Xw4EEtX75c2dnZ+slPfqK+fftq4cKFOnz4cFPUCQAA0CBn/FNwHx8f3XTTTXrzzTf11FNPae/evXrggQfUoUMHTZ48WVlZWY1ZJwAAQIOccbjZsmWLpk2bppiYGC1cuFAPPPCA9u7dqw0bNujgwYO68cYbG7NOAACABvH4PjcLFy7U8uXLtXv3bo0dO1avvvqqxo4dK5utLCfFxsbqpZdeUu/evRu9WAAAgPp4HG5SUlI0depU3XHHHYqOjq6xT6dOnbRs2bKzLg4AAMBT3MQPAAA0e016E7/ly5frrbfeqtb+1ltv6ZVXXvF0dQAAAI3K43Dz5JNPqk2bNtXa27ZtqyeeeKJRigIAADhTHoeb77//XrGxsdXaO3fu7PaQSwAAAG/wONy0bdtWX3/9dbX2HTt2KCIiolGKAgAAOFMeh5tbbrlF06dP18cffyyHwyGHw6ENGzZoxowZuuWWW5qiRgAAgAbz+KfgCxYs0Pfff6+rr75aPj5lizudTk2ePJlrbgAAgNed8U/Bv/32W+3YsUOBgYG68MIL1blz58aurUnwU3AAAFoeT47fHo/cVOjZs6d69ux5posDAAA0iTMKNwcOHNCaNWuUmZmp4uJit3kLFy5slMIAAADOhMfh5qOPPtINN9yg2NhY7d69W/369dO+fftkmqYuueSSpqgRAACgwTz+tdScOXN0//3365tvvlFAQIDefvtt7d+/XyNGjNDNN9/cFDUCAAA0mMfhJj09XVOmTJEk+fj46OTJkwoJCdH8+fP11FNPNXqBAAAAnvA43AQHB6uoqEiS1K5dO+3du9c1Lzc3t/EqAwAAOAMeX3Nz2WWX6bPPPlNcXJyuu+463X///frPf/6j1atX67LLLmuKGgEAABrM43CzcOFCFRYWSpLmzp2rwsJCrVq1St27d9dzzz3X6AUCAAB4wqNw43A4tH//fvXv31+SFBQUpOTk5CYpDAAA4Ex4dM2N3W7X6NGjdfz48aaqBwAA4Kx4fEHxhRdeqO+++64pagEAADhrHoebxx9/XA888ID+/ve/KysrS/n5+W4vAAAAb/L4wZk22+k8ZBiG67NpmjIMQw6Ho/GqawI8OBMAgJanSR+c+fHHH59xYQAAAE3N43AzYsSIpqgDAACgUXgcbjZu3Fjn/Msvv/yMiwEAADhbHoebK664olpb5Wtvmvs1NwAAwNo8/rXUsWPH3F45OTn64IMPNHjwYH344YdNUSMAAECDeTxyEx4eXq1t5MiR8vf313333aetW7c2SmEAAABnwuORm9pERkZq9+7djbU6AACAM+LxyM3XX3/tNm2aprKysvTkk09qwIABjVYYAADAmfA43Fx00UUyDENV7/132WWXKTU1tdEKAwAAOBMeh5uMjAy3aZvNpsjISAUEBDRaUQAAAGfK43DTuXPnpqgDAACgUXh8QfH06dO1ePHiau1Lly7VzJkzG6UoAACAM+VxuHn77bc1bNiwau1Dhw7VX//610YpCgAA4Ex5HG6OHDlS471uwsLClJub2yhFAQAAnCmPw0337t31wQcfVGt///331bVr10YpCgAA4Ex5fEHxrFmzdO+99+rw4cO66qqrJEkfffSRnn32WS1atKjRCwQAAPCEx+Fm6tSpKioq0uOPP67HHntMktSlSxelpKRo8uTJjV4gAACAJwyz6t34PHD48GEFBgYqJCSkMWtqUvn5+QoPD1deXp7CwsK8XQ4AAGgAT47fZ3QTv9LSUvXo0UORkZGu9j179sjX11ddunTxuGAAAIDG4vEFxQkJCdq0aVO19s8//1wJCQmNURMAAMAZ8zjcbNu2rcb73Fx22WXavn17oxQFAABwpjwON4ZhqKCgoFp7Xl6eHA5HoxQFAABwpjwON8OHD1dSUpJbkHE4HEpKStJPfvKTRi0OAADAUx5fUPz000/r8ssvV69evTR8+HBJUlpamvLy8vTxxx83eoEAAACe8HjkJi4uTl9//bUmTJignJwcFRQUaPLkyfr2229VWlraFDUCAAA02Fnd50aSjh8/rtdff12pqanavn17s7/uhvvcAADQ8nhy/PZ45KbChg0bdNttt6ldu3ZaunSpxowZoy1btpzp6gAAABqFR9fcHDhwQCtWrFBqaqpOnDihCRMmqKSkRG+//bbi4uKaqkYAAIAGa/DIzdixYxUXF6edO3dqyZIlOnTokJYsWdKUtQEAAHiswSM3H374oaZPn65f//rX6tGjR1PWBAAAcMYaPHKTlpamgoICDRo0SEOGDNHSpUt1+PDhpqwNAADAYw0ON/Hx8frTn/6krKws/epXv9Jf/vIXtW/fXk6nU+vXr6/xrsUAAADn2ln9FHz37t1atmyZXnvtNR0/flwjR47UmjVrGrO+RsdPwQEAaHnOyU/BJalXr156+umndeDAAb3xxhtnsyoAAIBGcVbhpoLdbtf48ePPaNQmOTlZsbGxCggI0MCBA5WWltag5T777DP5+Pjooosu8nibAADAuhol3JypVatWaebMmXr44Ye1bds2DR8+XGPGjFFmZmady+Xl5Wny5Mm6+uqrz1GlAACgpTjrxy+cjSFDhuiSSy5RSkqKq61Pnz4aP368kpKSal3ulltuUY8ePWS32/Xuu+9q+/btDd4m19wAANDynLNrbs5GcXGxtm7dqlGjRrm1jxo1Sps2bap1ueXLl2vv3r169NFHG7SdoqIi5efnu70AAIB1eS3c5ObmyuFwKCoqyq09KipK2dnZNS6zZ88ePfTQQ3r99dfl49Ow+w8mJSUpPDzc9erYseNZ1w4AAJovr15zI0mGYbhNm6ZZrU2SHA6HJk2apHnz5qlnz54NXv+cOXOUl5fneu3fv/+sawYAAM2XRw/ObExt2rSR3W6vNkqTk5NTbTRHkgoKCrRlyxZt27ZN9957ryTJ6XTKNE35+Pjoww8/1FVXXVVtOX9/f/n7+zfNTgAAgGbHayM3fn5+GjhwoNavX+/Wvn79eg0dOrRa/7CwMP3nP//R9u3bXa/ExET16tVL27dv15AhQ85V6QAAoBnz2siNJM2aNUu33367Bg0apPj4eP3xj39UZmamEhMTJZWdUjp48KBeffVV2Ww29evXz235tm3bKiAgoFo7AAA4f3k13EycOFFHjhzR/PnzlZWVpX79+mnt2rXq3LmzJCkrK6vee94AAABU5tX73HgD97kBAKDlaRH3uQEAAGgKhBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGAphBsAAGApXg83ycnJio2NVUBAgAYOHKi0tLRa+65evVojR45UZGSkwsLCFB8fr3Xr1p3DagEAQHPn1XCzatUqzZw5Uw8//LC2bdum4cOHa8yYMcrMzKyx/8aNGzVy5EitXbtWW7du1ZVXXqlx48Zp27Zt57hyAADQXBmmaZre2viQIUN0ySWXKCUlxdXWp08fjR8/XklJSQ1aR9++fTVx4kQ98sgjDeqfn5+v8PBw5eXlKSws7IzqBgAA55Ynx2+vjdwUFxdr69atGjVqlFv7qFGjtGnTpgatw+l0qqCgQK1bt661T1FRkfLz891eAADAurwWbnJzc+VwOBQVFeXWHhUVpezs7Aat49lnn9WJEyc0YcKEWvskJSUpPDzc9erYseNZ1Q0AAJo3r19QbBiG27RpmtXaavLGG29o7ty5WrVqldq2bVtrvzlz5igvL8/12r9//1nXDAAAmi8fb224TZs2stvt1UZpcnJyqo3mVLVq1Srdeeedeuutt3TNNdfU2dff31/+/v5nXS8AAGgZvDZy4+fnp4EDB2r9+vVu7evXr9fQoUNrXe6NN95QQkKC/vznP+u6665r6jIBAEAL47WRG0maNWuWbr/9dg0aNEjx8fH64x//qMzMTCUmJkoqO6V08OBBvfrqq5LKgs3kyZP1/PPP67LLLnON+gQGBio8PNxr+wEAAJoPr4abiRMn6siRI5o/f76ysrLUr18/rV27Vp07d5YkZWVlud3z5qWXXlJpaanuuece3XPPPa72KVOmaMWKFee6fAAA0Ax59T433sB9bgAAaHlaxH1uAAAAmgLhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWArhBgAAWIrXw01ycrJiY2MVEBCggQMHKi0trc7+n376qQYOHKiAgAB17dpVL7744jmqFAAAtAReDTerVq3SzJkz9fDDD2vbtm0aPny4xowZo8zMzBr7Z2RkaOzYsRo+fLi2bdum3/3ud5o+fbrefvvtc1w5AABorgzTNE1vbXzIkCG65JJLlJKS4mrr06ePxo8fr6SkpGr9f/vb32rNmjVKT093tSUmJmrHjh3avHlzg7aZn5+v8PBw5eXlKSws7Ox3AgAANDlPjt9eG7kpLi7W1q1bNWrUKLf2UaNGadOmTTUus3nz5mr9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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(train_a, label='train accuracy')\n",
    "plt.plot(val_a, label='validation accuracy')\n",
    "\n",
    "plt.title('Training history')\n",
    "plt.ylabel('Accuracy')\n",
    "plt.xlabel('Epoch')\n",
    "plt.legend()\n",
    "plt.ylim([0, 1])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "SbT4YzHFh1s7"
   },
   "source": [
    "Accuracy of Pos/Neg on Test Set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 28664,
     "status": "ok",
     "timestamp": 1695329081374,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "L1ZzFERMAQk9",
    "outputId": "56411273-fc8c-476f-f660-21239bd321ad",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.8494\n",
      "F1-Macro:  0.8443936391180008\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "test_acc, _, test_f1 = eval_model(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  loss_fn,\n",
    "  device,\n",
    "  len(df_test)\n",
    ")\n",
    "\n",
    "\n",
    "print(\"Accuracy: \",test_acc.item())\n",
    "print(\"F1-Macro: \",test_f1.item())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "-Vexpkg79IXK"
   },
   "source": [
    "Scores Average of PP - Poisitve Scores on Positive Sentences\n",
    "                  PN - Poisitve Scores on Negative Sentences\n",
    "                  NP - Negative Scores on Positive Sentences\n",
    "                  NN - Negative Scores on Negative Sentences"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 605
    },
    "executionInfo": {
     "elapsed": 29278,
     "status": "ok",
     "timestamp": 1695329182045,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "zUrNTiUp8kPc",
    "outputId": "e99daa47-22f9-471e-97d4-245bf6f0b8ab",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAroAAAISCAYAAAAjsmyaAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAPYQAAD2EBqD+naQAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nOzdd3hUZeL28XuSTCYJyZCEhJIgggldlCpElCIIFsoKFhQRCbIK1t3F7isqKKyLv3XRFbGAFNe2roii0gVUVEBKpJMAoRlqep/M+wfr6GwmkAyTOcnJ93Nde12b55S5Q5Gbh+c8x+J0Op0CAAAATCbA6AAAAABAdaDoAgAAwJQougAAADAlii4AAABMiaILAAAAU6LoAgAAwJQougAAADClIKMD1CSbNm2S0+mU1Wo1OgoAAAA8KCkpkcViUadOnc55LkX3d5xOp3h/BgAAQM1Vla5G0f2dX2dyO3ToYHASAAAAeJKSklLpc1mjCwAAAFOi6AIAAMCUKLoAAAAwJYouAAAATImiCwAAAFOi6AIAAMCUKLoAAAAwJYouAAAATImiCwAAAFOi6AIAAMCUKLoAAAAwJYouAAAATImiCwAAAFOi6AIAAMCUKLoAAAAwJYouAAAATImiCwAAAFOi6AIAAMCUgowOgJpv6dKlWrRokQoLC9W3b1/ddNNNCg4ONjoWAADAWVF0cVZ/+9vf9NZbb7m+Xrt2rZYvX6633npLgYGBBiYDAAA4O4quSTidThUVFfn0nkePHtWcOXPKjX/33XdaunSp+vbt6/psSbJYLD79/Mqy2WyGfTYAAKi5KLom4HQ69eyzz2r37t0+ve+pU6fkcDg8HnvhhRf0zjvv6OTJk8rPz1dwcLBiYmIMWdLQqlUrTZo0ibILAADcUHRRoaCgin95BAQEaOfOnSosLHSNZWRkqGXLlgoPD/dHPAAAgLOi6JqAxWLRpEmTfL50oaysTMOHD1daWprbeFhYmHr37q0PPvig3PnBwcGaPXu2T3OcC0sXAACAJxRdk7BYLAoJCfH5fd944w099thj2rBhgySpefPmmjx5sqZMmeLx/JSUFBUVFal+/fo+zwIAAFAVFF2c1QUXXKB3331Xhw8fVmFhoS666CJZLBZFRER4PD84OFg2m83PKQEAAMrjhRGolPj4eCUkJLiWCAwbNszjeddff321zCwDAABUFUUX53T8+HGtXr1ae/bscY0NHz5cycnJbg+s9ezZU08++aQREQEAAMqxOH/dBBVKSUmRJHXo0MHgJDXHX//6V82fP18lJSWSzpTZl19+WXa7XZJ06NAh3X333bLZbPrXv/7FbC4AAKhWVelrzOiiQh9//LFmz57tKrmS9O2332ry5Mmur4uLi1VWVlbhfrsAAABGoeiiQp988onH8S+//FJ5eXl65plndP311ystLU07d+7UmDFjdPr0aT+nBAAA8Iyiiwrl5uZ6HC8pKdGHH36o9957T2VlZa7xn376qcJtxwAAAPyNoosKXXnllR7HO3TooCVLlng8tmTJEhUUFFRnLAAAgEqh6KJCycnJSkxMdBurV6+ennzyyQrLbElJiduaXgAAAKPwwghUKCoqSh999JE+/fRTbd26VfHx8brxxhvVuHFj9enTRzt37ix3TefOnV07MgAAABipRmwvtm/fPk2ZMkUbN25UaGiorr/+ek2cOPGcW1Xl5+frtdde01dffaXjx4+rUaNGGjx4sO6++24FBwdXOQfbi1Vedna2Ro0a5VZ27Xa75syZo4svvtjAZAAAwMyq0tcMn9HNzs7W6NGjFRcXpxkzZujUqVOaOnWqMjMzNX369LNe+8wzz2j58uX605/+pJYtW2rr1q2aMWOGsrKy9NRTT/npO6ib7Ha7PvzwQy1cuFCvvPKKgoODNX/+fMXHxxsdDQAAQFINKLrvv/++srOztXDhQkVHR0uSAgMDNXHiRI0fP14JCQkerystLdVXX32lu+66S6NGjZIk9ejRQ0eOHNEXX3xB0fUDm82moUOH6tNPP5UkNWjQwOBEAAAAvzH8YbQ1a9YoKSnJVXIlaeDAgQoODtbq1asrvM7pdMrhcCgiIsJt3G63qwasxgAAAIDBDJ/RTU1N1fDhw93GgoOD1axZM6WmplZ4ndVq1bBhwzR//nx17txZiYmJSklJ0Ycffqjbb7/d6zxOp1P5+fleX1/XFBUVuf5/QUGB2766AAAAvuZ0OmWxWCp1ruFFNzs72+NT+na7XVlZWWe99plnntGkSZN08803u8ZGjRql++67z+s8JSUl2rFjh9fX1zW/30ps165dslqtBqYBAAB1QWU3HTC86FakMm19+vTp+vrrrzV58mS1aNFC27Zt04wZM2S32/XAAw94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x44d0+bNm7V8+XI9//zzeueddzR16lR16NChWsIDAAAAFal00d2+fbvmzJmjbt26VXhOw4YNNWDAAA0YMEC5ubl655139NNPP1F0AQAA4HeVLroLFiyo0o3Dw8N13333VTkQAAAA4As+X0CbkZGh7du3+/q2AAAAQJV4tevCkSNHKjy2dOlSzZo1S+vWrfM6FAAAAHC+vCq6V111lSwWS4XHW7Ro4XUgAAAAwBe8KrovvPBCuaKbn5+vDRs2aMWKFZo2bZpPwgEAAJhVamqqsrKyZLVa5XQ6jY5jShanj39kp02bpm3btmn+/Pm+vK1fpKSkSBK7RAAAgGpTWlqqSZMmacmSJa6xxMREvfrqq4qJiTEwWe1Qlb7m84fRevfura1bt/r6tgAAAKbw73//263kStLevXv117/+1aBE5uXzonv69Gk1aNDA17cFAAAwha+++srj+Jo1a1RQUODnNObm1RpdT8rKyrRz5069/vrrevDBB311WwAAAFMpKSnxOO5wOORwOPycxty8Krpt2rSpcNcFp9Opxx57TI899pikM++vZl9dAACAM/r06aNdu3aVG+/WrZvCw8MNSGReXhXde++996zbiwEAAMCzkSNHat26dW7PNDVo0EAPP/ywganMyee7LtRm7LoAAAD8weFwaMWKFZo+fbqCgoK0YMECRUdHGx2rVjB01wUAAACcXWBgoHr16qWYmBhFRkYqLCzM6EimVOmi+8wzz+j48eNVuvnSpUu1aNGiKocCAAAAzlel1+ju27dP/fv319VXX62hQ4eqa9euCg0NLXfegQMHtGLFCv3nP/9RRkaGpk+f7tPAAAAAQGVUuujOnTtXy5cv1xtvvKFx48YpKChIF154oaKjo2Wz2ZSVlaWDBw8qKytLoaGhGjZsmMaPH8+eugAAADBElXZd6N+/v/r376/t27dr1apV2rJli44dO6bjx48rKipK/fr102WXXaZ+/fqxPQYAAAAM5dX2Yu3atVO7du18nQUAAADwGXZdAAAAgCl5VXTXrVunL7/80vX1iRMnNG7cOPXs2VOPPPKIioqKfBYQAAAA8IZXRXfGjBlKTU11ff23v/1NGzZsUKdOnbRkyRK99dZbPgsIAAAAeMOrort//37XGt3S0lItW7ZMEydO1KuvvqoHHnhAixcv9mlIAAAAoKq8Krq5ubmy2+2SpG3b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RUZHAgAAkETRxXn44osv1LdvX61evVpbtmzRtm3btHDhQqNjAQAASKLowkvr1q3Tn//8Z506dUqS5HA4dPToUb3++uv65ZdfDE4HAABA0YWX5syZI6fTWW48IyNDs2fP9ngMAADAnyi68MqBAwc8jjscDm3evFlHjhzxcyIAAAB3FF14pVOnTh7HbTabOnXqpLi4OD8nAgAAcEfRhVfGjRunevXqlRuPj49XcnKyLBaLAakAAAB+Q9GFVxISEvTRRx+pY8eOCgkJkd1uV8uWLZWcnKxGjRoZHQ8AAICiC+8lJCRo3rx5uuKKK9SyZUs1b95cQ4YMMToWAACAJIouzpPNZlNycrJiYmI0ZswY2Ww2oyMBAABIkoKMDoDar0uXLurSpYvRMQAAANwwowsAAABTougCAADAlCi6AAAAMCWKLgAAAEyJogsAAABTougCAADAlCi6AAAAMCWKLgAAAEyJogsAAABTougCAADAlCi6AAAAMCWKLgAAAEyJogsAAABTougCAADAlCi6AAAAfnbw4EG9+OKLOnDggA4fPqyffvrJ6EimRNEFAADwo/T0dI0ePVqLFi1SUVGR8vLy9NBDD2n58uVGRzOdIKMDAAAAGMnpdKqoqMhvnzd79mxlZ2e7jZWVlenVV19Vz549ZbFY/JbFZrP59fP8jaILAADqLKfTqWeffVa7d+/222fu37/f4/ihQ4d05513KjAw0G9ZWrVqpUmTJpm27LJ0Aedt48aNeuCBB7Rx40ajowAAUOMFBXmeZwwICFBAANXMl5jRhdc2btyoV155RevXr5fVatXBgwf1/vvvy2azGR0NAIBKsVgsmjRpkl+XLvzwww+aOHGinE6n2/jIkSN19913+y2HZP6lCxbn//4o12EpKSmSpA4dOhicpOb7+eefdeutt6q4uNhtfNCgQXrppZcMSgUAQO2wePFivf766zp69Kjq1aunG2+8URMmTPDrsoXaqip9jRldeOXtt98uV3IlacmSJfrzn/+s+Ph4A1IBAFA7XH/99br22mt16tQp2e12BQcHGx3JlFgIAq/s2bPH43hJSYnefPPNcv8cAwAA3AUEBCgmJoaSW40ouvBKkyZNPI4HBQVp165dOnLkiJ8TAQAAuKPowiv33nuvxydDmzRpoksvvVRxcXEGpAIAAPhNjSi6+/bt09ixY9WxY0clJSVp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0FD06NGD36CpVkRGRhqd9+3u7s5rzcotWLAAarW6Ts6dkZGB69evw9fXF61btwbwYP5ubGysQd/Bgwdj6tSpdVJHdaRSKa9romqkpKSY3NfsQdfZ2dnor5KKi4v/8Ea0R0duFQqFrv3huYyNEptCJBLB3t7+qY59nrz22mtIT0/H2rVrodVqIRKJ4O7ujqZNmyIqKuoPl+UhqonBgwcjPT0dcXFxunVNXV1d0aRJE15rz4G6+vq6ubmhffv2em2DBw9GcXEx1q1bh+LiYtja2uLPf/4z5syZw7vhiRqQmvwQaPagGxAQYDAHS61WIzMz02Du7qMezs1NS0vTC8SpqakQiUQGc3ep9r333ntQKBTYsWMHJBIJJBIJBg8ezCWfqNZNnz4dHh4e+Prrr2FrawupVMprjerEuHHjMHz4cGRmZsLT0xNubm7mLomInoHZ19Ht3bs3Tp8+jfv37+vavv/+e6jVarz44ovVHufn5wd/f38cOHBAr33//v0IDQ3ligv1ZPjw4fDx8YGtrS3c3Ny42DXVmddffx0+Pj6QSCS81qhOyeVyBAcHM+QSWQGzB92RI0fCyckJ0dHROHbsGHbv3o1PPvkEf/nLX/RGaufOnaubR/XQ1KlTcfDgQSxbtgxnzpzB3//+d5w4caLe51I9z7jYNdUXXmtERFRTZp+64OzsjK+++gqLFi3ClClTYGdnh4iICMTExOj1q6qqglar1WsbOHAgysvLsWbNGmzcuBHNmjXDsmXLuFlEPeNi11RfeK0REVFNiISHyxQQkpKSAAAhISFmroSIiIiIjKlJXjP71AUiIiIiorrAoEtEREREVolBl4iIiIisEoMuEREREVklBl0iIiIiskoMukRERERklRh0iYiIiMgqMegSERERkVVi0CUiIiIiq8SgS0RERERWiUGXiIiIiKwSgy4RERERWSUGXSIiIiKySgy6RERERGSVbM1dQEOi0WggCAKSkpLMXQoRERERGaFWqyESiUzqy6D7CFM/NCIiIiIyD5FIZHJmEwmCINRxPURERERE9Y5zdImIiIjIKjHoEhEREZFVYtAlIiIiIqvEoEtEREREVolBl4iIiIisEoMuEREREVklBl0iIiIiskoMukRERERklRh0iYiIiMgqMegSERERkVVi0CUiIiIiq8SgS0RERERWiUGXiIiIiKwSgy4RERER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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "pp,pn,np,nn = eval_scores_average(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  device,\n",
    ")\n",
    "\n",
    "box_plot(pp,pn,np,nn)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "uSAQhl1kh5jw"
   },
   "source": [
    "Accuracy of Emotions on Test Set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {
    "executionInfo": {
     "elapsed": 8,
     "status": "ok",
     "timestamp": 1695329212064,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "d7DaFLMiAWps",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def get_predictions(model, data_loader):\n",
    "  model = model.eval()\n",
    "\n",
    "  review = []\n",
    "  predictions = []\n",
    "\n",
    "  prediction_probs = []\n",
    "  real_values = []\n",
    "\n",
    "  pos_scores = []\n",
    "  neg_scores = []\n",
    "\n",
    "\n",
    "  with torch.no_grad():\n",
    "    for d in data_loader:\n",
    "\n",
    "      reviews = d[\"review\"]\n",
    "      input_ids = d[\"input_ids\"].to(device)\n",
    "      attention_mask = d[\"attention_mask\"].to(device)\n",
    "      sentiments = d[\"sentiments\"].to(device)\n",
    "\n",
    "\n",
    "      scores,outputs = model(\n",
    "        input_ids=input_ids,\n",
    "        attention_mask=attention_mask,\n",
    "        return_scores=True,\n",
    "      )\n",
    "      _, preds = torch.max(outputs, dim=1)\n",
    "\n",
    "\n",
    "      probs = F.softmax(outputs, dim=1)\n",
    "\n",
    "      review.extend(reviews)\n",
    "      predictions.extend(preds)\n",
    "\n",
    "      prediction_probs.extend(probs)\n",
    "      real_values.extend(sentiments)\n",
    "\n",
    "      pos_scores.extend(scores[0])\n",
    "      neg_scores.extend(scores[1])\n",
    "\n",
    "\n",
    "  predictions = torch.stack(predictions).cpu()\n",
    "\n",
    "  prediction_probs = torch.stack(prediction_probs).cpu()\n",
    "  real_values = torch.stack(real_values).cpu()\n",
    "    \n",
    "  pos_scores = torch.stack(pos_scores).cpu()\n",
    "  neg_scores = torch.stack(neg_scores).cpu()\n",
    "  return review, predictions, prediction_probs, real_values, pos_scores, neg_scores"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {
    "executionInfo": {
     "elapsed": 27254,
     "status": "ok",
     "timestamp": 1695329239311,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "kZhYtki1AYx8",
    "tags": []
   },
   "outputs": [],
   "source": [
    "y_review_texts, y_pred , y_pred_probs, y_test, pos_scores, neg_scores = get_predictions(\n",
    "  model,\n",
    "  test_data_loader\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {
    "executionInfo": {
     "elapsed": 9,
     "status": "ok",
     "timestamp": 1695329239312,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "mO1FHn0GAbCU",
    "tags": []
   },
   "outputs": [],
   "source": [
    "from sklearn.metrics import classification_report\n",
    "from sklearn.metrics import confusion_matrix\n",
    "class_names = ['negative', 'positive']"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "PnBSQFJuh_As"
   },
   "source": [
    "Pos/Neg Classification Report"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 9,
     "status": "ok",
     "timestamp": 1695329239312,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "J9-01snpAcM8",
    "outputId": "4d6f7fff-9a14-49bf-c847-d2e8ba79f5f7",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "              precision    recall  f1-score   support\n",
      "\n",
      "    negative       0.83      0.88      0.85      2511\n",
      "    positive       0.87      0.82      0.84      2489\n",
      "\n",
      "    accuracy                           0.85      5000\n",
      "   macro avg       0.85      0.85      0.85      5000\n",
      "weighted avg       0.85      0.85      0.85      5000\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(classification_report(y_test, y_pred, target_names=class_names))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "GhTpYmfdiF-P"
   },
   "source": [
    "Reverse Native Injection Accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 30105,
     "status": "ok",
     "timestamp": 1695329269413,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "pOutPTF6qJY8",
    "outputId": "a034fc7e-f3ae-44e3-9bd9-2c416c5b45b3",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.1506\n",
      "F1-Macro:  0.1466251959518551\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "p_emb, n_emb = n_emb, p_emb\n",
    "\n",
    "\n",
    "test_acc, _, test_f1 = eval_model(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  loss_fn,\n",
    "  device,\n",
    "  len(df_test)\n",
    ")\n",
    "\n",
    "print(\"Accuracy: \",test_acc.item())\n",
    "print(\"F1-Macro: \",test_f1.item())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 605
    },
    "executionInfo": {
     "elapsed": 28733,
     "status": "ok",
     "timestamp": 1695329298142,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "F25gPUqgvw0w",
    "outputId": "747d6857-a67e-4f00-f9a9-fea35eee0d06",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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R4/W8OHDFRDARWPAnUwmk4KDg42OYaigoKAa/2cAALi8Shfdl156SUuXLlVMTIwmTZqk6667Tu3atVNg4C+nOHv2rHbs2KE1a9boxRdf1Pvvv685c+aoY8eOVyQ8AAAAUJFKF919+/bpvffeU48ePSrcp0GDBrrtttt02223KScnR++//762bdtG0QUAAIDHVbroLlmypEonrl27th599NEqBwIAAADcwe0TaM+cOaN9+/a5+7QAAABAlbi06kJqamqF21atWqUFCxZo06ZNLocCAAAAqsulonvLLbfIZDJVuD0mJsblQAAAAIA7uFR0X3rppXJFNy8vT1u3btXatWs1d+5ct4QDgJ8dPnxY6enpslqtstt5LC4A4PJMdjd/x5g7d6727t2rDz74wJ2n9Yjdu3dLEqtEAF7EZrPp6aef1ooVKxxjrVu31oIFCxQVFWVgMgCAEarS19x+M9qNN96oXbt2ufu0AGqoZcuWlSm5knTw4EG9+OKLBiUCAPgKtxfdjIwM1a9f392nBVBD/W/J/dm6deuUl5fn4TQAAF/i0hxdZ0pLS3XgwAG98847mjZtmrtOC6CGKyoqcjpus9lks9k8nAYA4EtcKrpt2rSpcNUFu92uJ598Uk8++aQkyWQysa4uAJf169dPBw4cKDd+3XXXKSwszIBEAABf4VLRnTx58q8uLwYA7jJmzBj9+9//1s6dOx1j9evX1zPPPGNgKgCAL3D7qgu+jFUXAO9UUlKiVatW6ZVXXpHVatXSpUsVGRlpdCwAgAEMXXUBANwtMDBQt9xyi6KjoxUZGanatWsbHQkA4AMqXXSfe+45paWlVenkq1at0hdffFHlUAAAAEB1VXqO7pEjR9S/f3/deuutGjZsmLp3766QkJBy+x07dkxr167Vp59+qjNnzui1115za2AAAACgMipddBMSErRmzRotXLhQEyZMUGBgoJo3b6569eopKChIWVlZOnHihLKyshQSEqLhw4dr4sSJrKkLAAAAQ1Rp1YX+/furf//+2rdvn7799lvt3LlTZ8+eVVpamiIiItSvXz9dd9116tevH3PoAAAAYCiXlhdr166d2rVr5+4sAAAAgNuw6gIAAAD8kktFd9OmTfrXv/7l+PjcuXOaMGGCevfurccff1yFhYVuCwgAAAC4wqWiO2/ePKWkpDg+fvXVV7V161Z16dJFK1eu1N///ne3BQQAAABc4VLRPXr0qGOObklJiVavXq3p06frrbfe0tSpU/XVV1+5NSQAAABQVS4V3ZycHIWHh0uS9u7dq/z8fPXr10+SdO211+r06dPuSwgAAAC4wKWiW79+fR09elSStHHjRkVHR6tRo0aSpNzcXAUGurSYAwAAAOA2LjXSG264QX/961+VnJyszz77THfeeadj2+HDh9WkSRO3BQQAAABc4VLR/f3vf6/U1FT93//9n6699lpNnDjRsW3FihXq0qWL2wICAAAArnCp6NarV0+LFi1yum3x4sWyWq3VCgUAAABUV7UfGFFQUKAzZ86opKREklS7dm2KLgAAAAznctHdvHmz7rvvPnXt2lU333yzDh48KEl6/vnntWrVKrcFBAAAAFzh8pPRxo8fr8LCQo0bN06lpaWObREREfr000/dFhAAAABwhctPRuvbt6+WL1+uxx57rMy2Nm3a6MCBA24JBwAAALjKpaK7f/9+jRw5UpJkMpnKbKtXr57Onz9f/WQAAABANbhUdM1ms4qLi51uO3/+vGrVqlWtUAAAAEB1uVR0O3bsqC+++MLptpUrV6pz587VCgUAl9q/f79mzJihffv2KTk5WevWrTM6EgDAB7hUdH/3u99p9erVmjx5statWyeTyaSdO3fqT3/6k1auXKmHHnqoSuc7cuSIxo8fr86dOysuLk6zZ89WQUFBlc6xevVqtW7dWoMHD67ScQC826FDhzR69GitW7dOxcXFys3N1YwZM7jpFQBwWSa73W535cDPP/9cL730krKyshxj4eHhmjlzpoYOHVrp82RnZ2vw4MGKjo7WpEmTlJ6erjlz5uiGG27Qa6+9VqlzFBQUaNCgQSosLFRERIRWrFhR5fcjSbt375Z08Yo1AO/wxBNPOP033bhxY61atUoBAdVeDhwA4EOq0tdcejKaJA0bNkwDBgzQ9u3bde7cOUVERKhr164KDQ2t0nmWLVum7OxsLV++XPXq1ZN0cQ7w9OnTNXHiRMXGxl72HAsWLFB0dLSaNm2qPXv2uPR+AHinilZxOX36tLKyshQREeHhRAAAX1HlSyEFBQUaOXKkNm7cqODgYMXFxWnIkCHq06dPlUuuJK1fv15xcXGOkitJAwYMkNVqVWJi4mWPP378uN577z3NnDmzyq8NwPs1a9bM6XhERITCwsI8nAYA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k5Nx+/ZttGjRAh06dADwaP7uwoULtfoOGzZMPWfaUMzNzRlyieiZTZw4UeeD0I6OjggKCkLPnj35WUMNYty4cVi6dKlWu729Pe81PSQmJurd1+hB187ODkVFRVrtxcXFT30Q7fGRWxcXF3V79bWettzV00gkElhZWdXrXGOztrZulOs6Ojpq7cwybNgwFBUVYc2aNSgqKoJUKsWQIUPw4Ycf8ml4ImqSIiIikJKSgk2bNqGqqgoA4ODggGbNmmHSpEmN9hlLL54hQ4YgJSUF27ZtU99rtra2cHd3572mh7r8EGD0oOvn56c1t1ShUCA1NVVr7u7jqufmJiUlaQTiu3fvQiKRcEkrA4iMjMSoUaOQkpICNze3F+rhPyISp3feeQcODg7Yt28fTE1NIZVK8frrr3PJJ2pwM2fOhIODA/bv3897rREZfR3dPn364OLFi8jPz1e3HT9+HAqFAn379q3xPC8vL/j6+uLIkSMa7YcPH0ZQUBBDl4FYWlqibdu2fL+JSDSGDx8ODw8PmJmZwdHRkZuTUKMZMWIE77VGZvSgO2rUKNja2mLGjBk4c+YMDhw4gH/+858YMmSIxkjtwoUL0a5dO41zo6KicPToUaxYsQJxcXH4v//7P5w7dw5RUVGGfhlERCQS3JyEDIX3WuMz+tQFOzs7bN26FcuWLcO7774LCwsLREREIDo6WqNfVVUVVCqVRtvgwYMhl8uxdu1abNq0CT4+PlixYgU3iyAiomfCzUnIUHivNS6JUL1MASE+Ph4AEBgYaORKiIiIiEiXuuQ1o09dICIiIiJqDAy6RERERCRKDLpEREREJEoMukREREQkSgy6RERERCRKDLpEREREJEoMukREREQkSgy6RERERCRKDLpEREREJEoMukREREQkSgy6RERERCRKDLpEREREJEoMukREREQkSgy6RERERCRKZsYu4HmiVCohCALi4+ONXQoRERER6aBQKCCRSPTqy6D7GH3fNCIiIiIyDolEondmkwiCIDRyPUREREREBsc5ukREREQkSgy6RERERCRKDLpEREREJEoMukREREQkSgy6RERERCRKDLpEREREJEoMukREREQkSgy6RERERCRKDLpEREREJEoMukREREQkSgy6RERERCRKDLpEREREJEoMukREREQkSgy6RERERCRKDLpEREREJEoMulSr+fPn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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "pp,pn,np,nn = eval_scores_average(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  device,\n",
    ")\n",
    "\n",
    "box_plot(pp,pn,np,nn)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "3NU7ySjLiPKH"
   },
   "source": [
    "Foreign Injection Accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 27580,
     "status": "ok",
     "timestamp": 1695329325716,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "zlbzZWECocpp",
    "outputId": "27337f4e-b8c6-4b92-a088-77f03f0ccd93",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.7982\n",
      "F1-Macro:  0.7927509900641921\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "\n",
    "\n",
    "p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "for i in new_positive_word_meaning_sentences:\n",
    "  p_emb = torch.cat((p_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "for i in new_negative_word_meaning_sentences:\n",
    "  n_emb = torch.cat((n_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "p_emb = p_emb[1:]\n",
    "n_emb = n_emb[1:]\n",
    "\n",
    "test_acc, _, test_f1 = eval_model(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  loss_fn,\n",
    "  device,\n",
    "  len(df_test)\n",
    ")\n",
    "\n",
    "print(\"Accuracy: \",test_acc.item())\n",
    "print(\"F1-Macro: \",test_f1.item())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 605
    },
    "executionInfo": {
     "elapsed": 29037,
     "status": "ok",
     "timestamp": 1695329354749,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "DGrasP1mxQrD",
    "outputId": "87f1fe38-fe1b-4d6c-bf39-3c3e36c56fae",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAroAAAISCAYAAAAjsmyaAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAPYQAAD2EBqD+naQAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nOzdaXyU1d3G8WsyycwkJAMJe0AwhEXZAyjGBawgWAloASuKFAGpDQham0eR2iJKhSrVFlusCxEELVaBFEXLJosKuETZEUhYAoQlIcuE7MnM84KPqTEJJMNk7mTy+76bc+5zz38UPnNx5tznmFwul0sAAACAj/EzugAAAACgNhB0AQAA4JMIugAAAPBJBF0AAAD4JIIuAAAAfBJBFwAAAD6JoAsAAACf5G90AXXJd999J5fLpYCAAKNLAQAAQCWKi4tlMpkUFRV12WsJuj/icrnE+RkAAAB1V02yGkH3R36Yye3Ro4fBlQAAAKAye/bsqfa1rNEFAACATyLoAgAAwCcRdAEAAOCTCLoAAADwSQRdAAAA+CSCLgAAAHwSQRcAAAA+iaALAAAAn0TQBQAAgE8i6AIAAMAnEXQBAADgkwi6AAAA8EkEXQAAAPgkgi4AAAB8Up0IukePHtWkSZPUu3dvRUdHa86cOSooKLjsuLy8PM2fP1+DBw9Wr169NGTIEL3yyisqKiryQtUAAACoy/yNLsDhcGj8+PEKDw/XggULlJGRoblz5yorK0vz58+/5NhnnnlGGzZs0G9/+1t16tRJu3fv1oIFC5Sdna2nn37aS58AAAAAdZHhQXf58uVyOBxKSEhQWFiYJMlsNisuLk6xsbGKjIysdFxJSYn++9//6qGHHtK4ceMkSTfccINSU1P18ccfE3QBAAAaOMOXLmzdulXR0dFlIVeShg4dKovFoi1btlQ5zuVyqbS0VCEhIeXa7Xa7XC5XrdULAACA+sHwGd3k5GSNGjWqXJvFYlG7du2UnJxc5biAgACNHDlSS5cuVZ8+fdSxY0ft2bNH//73v/XAAw+4XY/L5VJeXp7b4xuStLQ0LV++XPv27VPr1q1177336pprrjG6LAAA4MNcLpdMJlO1rjU86DocDtnt9grtdrtd2dnZlxz7zDPPaNasWfrlL39Z1jZu3Dg98sgjbtdTXFysAwcOuD2+oUhPT9cf//hHZWVllbV9+OGH+t3vfqfevXsbWBkAAPB1FoulWtcZHnSrUp20Pn/+fG3evFnPPfecIiIitG/fPi1YsEB2u13Tp093630DAgLUsWNHt8YayeVyeXW3iRUrVpQLuZJUWlqqFStWaOTIkV6rQ7r4h726/7IDAAD1W1JSUrWvNTzo2u12ORyOCu05OTlVPogmSYcOHVJ8fLwWLlyoQYMGSZKuu+46mUwmvfDCCxo7dqyaNm1a43pMJpOCgoJqPM5ILpdLs2fP1qFDh7z2nvv27au0PTk5WQ8//LD8/b33R6tz586aNWsWYRcAgAagJt/3hj+MFhkZWWEtblFRkVJSUi4ZdH9I89dee2259muvvVYlJSU6deqU54tFmYCAgErb/fz85Odn+B8rAAAA42d0BwwYoFdffVWZmZkKDQ2VJK1fv15FRUUaOHBglePatGkj6eLMYnh4eFn73r17JUlt27atxarrFpPJpFmzZqmwsNBr77lhwwb97ne/q9B+7733asaMGV6rQ5KsViuzuQAAoALDg+6YMWO0bNkyTZkyRVOmTNH58+c1b948DR8+vNyM7syZM5WQkKD9+/dLkrp3766ePXtq1qxZSk9PV0REhPbs2aOFCxfqzjvvLLddWUNgMplks9m89n4xMTFKT0/XP/7xDzkcDplMJt19992aOXNmtReIAwAA1CaTqw5sOnv06FHNmTNHiYmJstlsiomJUVxcXLngNmPGDK1atUoHDx4sazt//rz+9re/6fPPP1d6erpat26tIUOG6De/+Y0aNWpU4zr27NkjSerRo8eVf6gGIisrSxMmTFBAQIDefvttr4ZtAADQ8NQkr9WJoFtXEHRrrqCgQBMnTpQkxcfHE3QBAECtqkle46khXFZGRoYOHTrk1TXAAAAAV4qgiyoVFBRoxowZuuWWWzR8+HANGDBA77zzTln/+fPntXDhQh0+fFjHjx/X4cOHDawWAIC66cCBA9qwYYNOnDhhdCkNjuEPo6Huev7557Vq1aqy11lZWXr22WcVHh6ua6+9Vvfee6/OnDlT1n/ffffpn//8p26++WYjygUAoE7JycnR//3f/+mbb76RdPHB8ZiYGD399NMym80GV9cwEHRRqby8PCUkJFTa969//UtXXXVVuZArXTw++YUXXiDoAgDqFZfLVSvL81588cWykPvD+3z44Ye6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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "pp,pn,np,nn = eval_scores_average(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  device,\n",
    ")\n",
    "\n",
    "box_plot(pp,pn,np,nn)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {
    "id": "K-QhJy24rDkl",
    "tags": []
   },
   "outputs": [],
   "source": [
    "from parrot import Parrot\n",
    "import torch\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "\n",
    "\n",
    "def random_state(seed):\n",
    "  torch.manual_seed(seed)\n",
    "  if torch.cuda.is_available():\n",
    "    torch.cuda.manual_seed_all(seed)\n",
    "\n",
    "random_state(1234)\n",
    "\n",
    "parrot = Parrot(model_tag=\"prithivida/parrot_paraphraser_on_T5\")\n",
    "clear_output()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {
    "executionInfo": {
     "elapsed": 16,
     "status": "ok",
     "timestamp": 1695329438385,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "Ppy-K6l2gWtd",
    "tags": []
   },
   "outputs": [],
   "source": [
    "from IPython.display import clear_output"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "20"
      ]
     },
     "execution_count": 93,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "new_positive_word_meaning_sentences = ['an acknowledgement or a public welcome',\n",
    " 'true to the point',\n",
    " 'including new and interesting things, methods and ideas',\n",
    " \"it's surprising\",\n",
    " 'known to be real and what somebody claims it is and not a copy',\n",
    " 'beauty delights the senses or the mind',\n",
    " \"to make someone quiet and more relaxed especially when there's intense emotion or excitement\",\n",
    " 'pleasant and easily remembered',\n",
    " 'the personal power of a person to attract and impress other people',\n",
    " '(of a person or their behaviour) happy and cheerful',\n",
    " '(of ideas, thoughts, arguments, etc.) logical and well organized; easy to understand and clear',\n",
    " 'having a useful and helpful effect rather than being negative or with no purpose',\n",
    " 'used to show that you admire or approve of somebody/something because they are/it is fashionable, attractive and often different',\n",
    " 'attractive and pretty',\n",
    " 'brave enough to do something dangerous or unusual involving danger or taking risks',\n",
    " 'allow yourself to use language and express your views well especially when speaking in public',\n",
    " 'feeling excitement or showing an interest about someone  something',\n",
    " 'without flaws and therefore perfect',\n",
    " 'funny with a sense of humor',\n",
    " 'providing exciting new ideas; making somebody want to create something, especially in art, literature or music' \n",
    " ]\n",
    "\n",
    "len(new_positive_word_meaning_sentences)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "20"
      ]
     },
     "execution_count": 94,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "new_negative_word_meaning_sentences = ['that can be understood in more than one way; having different meanings',\n",
    " 'having strong feelings about something you really dislike or an unfair situation',\n",
    " 'making somebody feel slightly angry',\n",
    " 'extremely bad, especially from a moral point of view',\n",
    " 'very bad or uncomfortable',\n",
    " 'cruel and violent and not what one wants from people who suss out education and respect each other',\n",
    " 'very strange or unusual',\n",
    " '(of behaviour or language) showing a lack of respect for God or religion',\n",
    " 'stupid; not able to think or talk in an intelligent way',\n",
    " 'without any order; in a completely confused state',\n",
    " 'containing or showing a lack of agreement between statements, facts, opinions or actions',\n",
    " 'public discussion and argument about something that many people strongly disagree about, think is bad, or are shocked by',\n",
    " 'to feel very embarrassed about something',\n",
    " 'a desire to cause psychological or physical pain',\n",
    " \"treating someone as if they don't have any value so that they lose their self-respect and respect for other people\",\n",
    " 'mentally ill particularly because of very unpleasant or extremely unhappy experiences',\n",
    " 'not doing well',\n",
    " 'not what somebody claims it is; appearing to be something it is not',\n",
    " \"a strange trick or unnecessary device that's meant to appeal to people or to get them to buy something\",\n",
    " 'very unfriendly or unpleasant'\n",
    " ]\n",
    "\n",
    "len(new_negative_word_meaning_sentences)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "metadata": {
    "executionInfo": {
     "elapsed": 38794,
     "status": "ok",
     "timestamp": 1695329477164,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "_OCeDQY6gHMj",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'\\nnew_positive_word_meaning_sentences = []\\n\\nfor i in positive_word_meaning_sentences:\\n  print(i)\\n  para_phrases = parrot.augment(input_phrase=i, max_return_phrases = 10)\\n  temp = list(list(zip(*para_phrases))[0])[0]\\n  new_positive_word_meaning_sentences.append(temp)\\n\\n\\nnew_negative_word_meaning_sentences = []\\n\\nfor i in negative_word_meaning_sentences:\\n  print(i)\\n  para_phrases = parrot.augment(input_phrase=i, max_return_phrases = 10)\\n  temp = list(list(zip(*para_phrases))[0])[0]\\n  new_negative_word_meaning_sentences.append(temp)\\n\\nclear_output()\\n'"
      ]
     },
     "execution_count": 95,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "'''\n",
    "new_positive_word_meaning_sentences = []\n",
    "\n",
    "for i in positive_word_meaning_sentences:\n",
    "  print(i)\n",
    "  para_phrases = parrot.augment(input_phrase=i, max_return_phrases = 10)\n",
    "  temp = list(list(zip(*para_phrases))[0])[0]\n",
    "  new_positive_word_meaning_sentences.append(temp)\n",
    "\n",
    "\n",
    "new_negative_word_meaning_sentences = []\n",
    "\n",
    "for i in negative_word_meaning_sentences:\n",
    "  print(i)\n",
    "  para_phrases = parrot.augment(input_phrase=i, max_return_phrases = 10)\n",
    "  temp = list(list(zip(*para_phrases))[0])[0]\n",
    "  new_negative_word_meaning_sentences.append(temp)\n",
    "\n",
    "clear_output()\n",
    "'''\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "oEdEBFPQiasC"
   },
   "source": [
    "Paraphrased Native Injection Accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 30045,
     "status": "ok",
     "timestamp": 1695329507205,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "uEuhYVF-gMqC",
    "outputId": "3c4d554a-9320-4704-990c-0a6f0b392083",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.8512000000000001\n",
      "F1-Macro:  0.8462264065177272\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "for i in new_positive_word_meaning_sentences:\n",
    "  p_emb = torch.cat((p_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "for i in new_negative_word_meaning_sentences:\n",
    "  n_emb = torch.cat((n_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "p_emb = p_emb[1:]\n",
    "n_emb = n_emb[1:]\n",
    "\n",
    "test_acc, _, test_f1 = eval_model(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  loss_fn,\n",
    "  device,\n",
    "  len(df_test)\n",
    ")\n",
    "\n",
    "\n",
    "\n",
    "print(\"Accuracy: \",test_acc.item())\n",
    "print(\"F1-Macro: \",test_f1.item())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.load_state_dict(torch.load('/home/mostafa_nsu/ICLR/bert_best_model_state.bin'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {
    "executionInfo": {
     "elapsed": 13,
     "status": "ok",
     "timestamp": 1695329507206,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "2qBYfr3zgvAs",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import random\n",
    "random.seed(42)\n",
    "\n",
    "inputNumbers = range(0,10000)\n",
    "random_seeds = random.sample(inputNumbers, 300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {
    "executionInfo": {
     "elapsed": 11,
     "status": "ok",
     "timestamp": 1695329507206,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "nysMxY5myqsd",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "JuMwkV_v4GvV",
    "outputId": "24e92f01-d79f-4514-f879-14a50b1f8477",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Working ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... "
     ]
    }
   ],
   "source": [
    "f1s = []\n",
    "accuracy = []\n",
    "p_word_list = []\n",
    "n_word_list = []\n",
    "\n",
    "print(\"Working\", end=' ')\n",
    "for i in range(300):\n",
    "    #SELECT RANDOM WORDS FROM NEUTRAL SENTIWORD\n",
    "    df_neutral = df_senti[df_senti['Sentiment']=='Neutral'].sample(n=20, random_state=random_seeds[i])\n",
    "    neutral_words = list(df_neutral[\"Word\"])\n",
    "\n",
    "    #FETCH DEFINITIONS OF THOSE WORDS\n",
    "    neutral_word_meaning_sentences = []\n",
    "    for i in neutral_words:\n",
    "        a = list(df_senti.loc[df_senti['Word'] == i, 'Definition'])[0]\n",
    "        neutral_word_meaning_sentences.append(a)\n",
    "\n",
    "    #MAKE EMBEDDING OF THESE DEFINITIONS\n",
    "    neutral_p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "    neutral_n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "\n",
    "    for i in neutral_word_meaning_sentences[0:10]:\n",
    "      neutral_p_emb = torch.cat((neutral_p_emb,get_cls(i).unsqueeze(0)), dim=0)\n",
    "\n",
    "    for i in neutral_word_meaning_sentences[10:20]:\n",
    "      neutral_n_emb = torch.cat((neutral_n_emb,get_cls(i).unsqueeze(0)), dim=0)\n",
    "\n",
    "    p_emb = neutral_p_emb[1:]\n",
    "    n_emb = neutral_n_emb[1:]\n",
    "\n",
    "    print('...', end=' ')\n",
    "\n",
    "    p_samples = neutral_words[0:10]\n",
    "    n_samples = neutral_words[10:20]\n",
    "\n",
    "    #EVALUATE ON THESE WORDS\n",
    "    test_acc,_, test_f1 = eval_model(\n",
    "      model,\n",
    "      test_data_loader,\n",
    "      loss_fn,\n",
    "      device,\n",
    "      len(df_test),\n",
    "    )\n",
    "\n",
    "    accuracy.append(test_acc.item())\n",
    "    f1s.append(test_f1.item())\n",
    "    p_word_list.append(p_samples)\n",
    "    n_word_list.append(n_samples)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "executionInfo": {
     "elapsed": 13,
     "status": "ok",
     "timestamp": 1695379584055,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "36UtUdOcDjLK",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import statistics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 245
    },
    "executionInfo": {
     "elapsed": 13,
     "status": "error",
     "timestamp": 1695379584056,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "N_1_hH8S4Hit",
    "outputId": "85d5684e-8de1-402e-9386-f53b050bd477",
    "tags": []
   },
   "outputs": [],
   "source": [
    "stdv = statistics.pstdev(f1s)\n",
    "median = statistics.median(f1s)\n",
    "#filters = [i>median+(2*stdv) for i in f1s]\n",
    "filters = [i>.7 for i in f1s]\n",
    "def filter_2std(target_list, filters):\n",
    "    index = [i for i in range(len(filters)) if filters[i]]\n",
    "    list_a_filtered = [target_list[i] for i in index]\n",
    "    return list_a_filtered\n",
    "\n",
    "p_words_spurious = filter_2std(p_word_list,filters)\n",
    "n_words_spurious = filter_2std(n_word_list,filters)\n",
    "\n",
    "#print(p_words_spurious)\n",
    "#print(n_words_spurious)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "6l78c6yoikRS"
   },
   "source": [
    "Neutral Injection Accuracies"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "executionInfo": {
     "elapsed": 19,
     "status": "ok",
     "timestamp": 1695379585268,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "mmW3cTd4o6Hb",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 175
    },
    "executionInfo": {
     "elapsed": 17,
     "status": "error",
     "timestamp": 1695379585269,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "_sc9N6PqFDAF",
    "outputId": "86645206-6fd6-4dcd-eb48-1555f0dcda27",
    "tags": []
   },
   "outputs": [],
   "source": [
    "(hist, bin_edges) = np.histogram(f1s,bins=15)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "f1s = list(pd.read_csv('/home/mostafa_nsu/ICLR/bert_randomizationtest.csv')['f1s'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "executionInfo": {
     "elapsed": 15,
     "status": "aborted",
     "timestamp": 1695379585271,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "uMGPmojj4SeF",
    "tags": []
   },
   "outputs": [],
   "source": [
    "plt.hist(f1s, bins=15,facecolor = '#008080', edgecolor='#000000', linewidth=0.5)\n",
    "\n",
    "\n",
    "vertical_line_position = 0.815  # Change this to the desired position\n",
    "plt.axvline(x=vertical_line_position, color='r', linestyle='--', label='Vne')\n",
    "plt.text(x=vertical_line_position,y=max(hist),s='Native',ha='left', va='bottom')\n",
    "\n",
    "    \n",
    "plt.xlabel(\"F1-Macro\")\n",
    "plt.ylabel(\"frequency\")\n",
    "\n",
    "#plt.title(\"bert-base\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "'''\n",
    "df_randomization_test = pd.DataFrame(list(zip(f1s, accuracy,p_word_list,n_word_list)),\n",
    "               columns =['f1s', 'accuracy','p_word_list','n_word_list'])\n",
    "df_randomization_test.to_csv('bert_randomizationtest.csv')\n",
    "'''"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_neutral = df_senti[df_senti['Sentiment']=='Neutral'].sample(n=20, random_state=random_seeds[16])\n",
    "neutral_words = list(df_neutral[\"Word\"])\n",
    "\n",
    "#FETCH DEFINITIONS OF THOSE WORDS\n",
    "neutral_word_meaning_sentences = []\n",
    "for i in neutral_words:\n",
    "    a = list(df_senti.loc[df_senti['Word'] == i, 'Definition'])[0]\n",
    "    neutral_word_meaning_sentences.append(a)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "executionInfo": {
     "elapsed": 33,
     "status": "aborted",
     "timestamp": 1695329093833,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "-nnwzm980k1q",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "for i in neutral_word_meaning_sentences[0:10]:\n",
    "  p_emb = torch.cat((p_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "for i in neutral_word_meaning_sentences[10:20]:\n",
    "  n_emb = torch.cat((n_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "p_emb = p_emb[1:]\n",
    "n_emb = n_emb[1:]\n",
    "\n",
    "test_acc, _, test_f1 = eval_model(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  loss_fn,\n",
    "  device,\n",
    "  len(df_test)\n",
    ")\n",
    "\n",
    "\n",
    "print(\"Accuracy: \",test_acc.item())\n",
    "print(\"F1-Macro: \",test_f1.item())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093833,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "7cdh2kXd0-Zb",
    "tags": []
   },
   "outputs": [],
   "source": [
    "pp,pn,np,nn = eval_scores_average(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  device,\n",
    ")\n",
    "\n",
    "box_plot(pp,pn,np,nn)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093833,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "1MTPlFIVEd6y",
    "tags": []
   },
   "outputs": [],
   "source": [
    "max_f1_index = f1s.index(max(f1s))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093834,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "J3ymzSst9jH9",
    "tags": []
   },
   "outputs": [],
   "source": [
    "p_spurious_sentences = [list(df_senti[df_senti['Word'] == i]['Definition'])[0] for i in p_words_spurious[max_f1_index]]\n",
    "n_spurious_sentences = [list(df_senti[df_senti['Word'] == i]['Definition'])[0] for i in n_words_spurious[max_f1_index]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093834,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "AoDiCBpM6glm",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "for i in p_spurious_sentences:\n",
    "  p_emb = torch.cat((p_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "for i in n_spurious_sentences:\n",
    "  n_emb = torch.cat((n_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "p_emb = p_emb[1:]\n",
    "n_emb = n_emb[1:]\n",
    "\n",
    "test_acc, _, test_f1 = eval_model(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  loss_fn,\n",
    "  device,\n",
    "  len(df_test)\n",
    ")\n",
    "\n",
    "print(\"Accuracy: \",test_acc.item())\n",
    "print(\"F1-Macro: \",test_f1.item())\n",
    "\n",
    "\n",
    "pp,pn,np,nn = eval_scores_average(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  device,\n",
    ")\n",
    "\n",
    "box_plot(pp,pn,np,nn)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093835,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "t-1o_fPd_MEy",
    "tags": []
   },
   "outputs": [],
   "source": [
    "n_words_spurious[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "executionInfo": {
     "elapsed": 33,
     "status": "aborted",
     "timestamp": 1695329093836,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "lvMoMpyEXQVt",
    "tags": []
   },
   "outputs": [],
   "source": [
    "p_words_spurious[0]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "aUzQP5etB1qH"
   },
   "source": [
    "Using Bias categories to test if they are neutral or not"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093836,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "M4c1i-jEnOia",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import os, sys\n",
    "\n",
    "filenames = []\n",
    "\n",
    "path = \"/home/mostafa_nsu/ICLR/Datasets/GoEmotion/bias_criterias\"\n",
    "dir = os.listdir( path )\n",
    "\n",
    "for file in dir:\n",
    "   if(file.endswith('.csv')):\n",
    "    filenames.append(file)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093836,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "uAcBqk9LpYds",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "for filename in filenames:\n",
    "    df_bias = pd.read_csv('/home/mostafa_nsu/ICLR/Datasets/GoEmotion/bias_criterias/'+filename)\n",
    "\n",
    "    p_spurious_sentences = list(df_bias['Definition'])\n",
    "\n",
    "    p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "    n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "    for i in p_spurious_sentences:\n",
    "      p_emb = torch.cat((p_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "    for i in neutral_word_meaning_sentences[10:20]:\n",
    "      n_emb = torch.cat((n_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "    p_emb = p_emb[1:]\n",
    "    n_emb = n_emb[1:]\n",
    "\n",
    "    test_acc, _, test_f1 = eval_model(\n",
    "      model,\n",
    "      test_data_loader,\n",
    "      loss_fn,\n",
    "      device,\n",
    "      len(df_test)\n",
    "    )\n",
    "\n",
    "    positive_spurious = test_f1.item()\n",
    "\n",
    "    n_spurious_sentences = list(df_bias['Definition'])\n",
    "    p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "    n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "    for i in neutral_word_meaning_sentences[0:10]:\n",
    "      p_emb = torch.cat((p_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "    for i in n_spurious_sentences:\n",
    "      n_emb = torch.cat((n_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "    p_emb = p_emb[1:]\n",
    "    n_emb = n_emb[1:]\n",
    "\n",
    "    test_acc, _, test_f1 = eval_model(\n",
    "      model,\n",
    "      test_data_loader,\n",
    "      loss_fn,\n",
    "      device,\n",
    "      len(df_test)\n",
    "    )\n",
    "\n",
    "    negative_spurious = test_f1.item()\n",
    "\n",
    "    if positive_spurious>=0.6:\n",
    "      print(filename+' is Positively Spurious.')\n",
    "    if negative_spurious>=0.6:\n",
    "      print(filename+' is Negatively Spurious.')\n",
    "    if(positive_spurious<0.6 and negative_spurious<0.6):\n",
    "      print(filename+' is Neutral.')\n",
    "    print('Positive Acc:',positive_spurious,'\\n'+'Negative Acc:', negative_spurious)\n",
    "    print(\"------------------------------------------------------------------------\")"
   ]
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "provenance": []
  },
  "gpuClass": "standard",
  "kernelspec": {
   "display_name": "Python 3",
   "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
