{
 "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": "iVBORw0KGgoAAAANSUhEUgAAAroAAAISCAYAAAAjsmyaAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAPYQAAD2EBqD+naQAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nOzdeXhU5eH28XsymckCCQQSloBgCLIjuxBBXEBBZFFExQpSQKqAgO0Lrli0ouDSVtGKYIkGEenPqqhoZdVg2Sxh303YCUIgG9mTybx/UEfSTCSZDHNmJt/PdXld5jnL3EMguXPynOeY7Ha7XQAAAICfCTA6AAAAAHAlUHQBAADglyi6AAAA8EsUXQAAAPglii4AAAD8EkUXAAAAfomiCwAAAL8UaHQAb7J9+3bZ7XZZLBajowAAAMCJ4uJimUwmdenS5bL7UnQvYbfbxfMzAAAAvFdVuhpF9xI/X8nt2LGjwUkAAADgzO7duyu9L3N0AQAA4JcougAAAPBLFF0AAAD4JYouAAAA/BJFFwAAAH6JogsAAAC/RNEFAACAX6LoAgAAwC9RdAEAAOCXKLoAAADwSxRdAAAA+CWKLgAAAPwSRRcAAAB+iaILAAAAv0TRBQAAgF+i6AIAAMAvUXQBAADglyi6AAAA8EuBRgcAAMDTEhMT9eWXX6qoqEh9+/bVsGHDZLFYjI4FwM0ougCAGmXevHmKj493fLx+/XqtW7dOb731lgIC+EUn4E8ougAAr2S321VYWOjWc549e1YJCQnlxjdu3Ki1a9fqhhtucLy2JJlMJre+fmUFBQUZ9tqAP6HoAgC8jt1u1/PPP69Dhw659bxZWVmy2WxOt82ZM0eLFi1SVlaW8vPzZbFYVLduXUOmNLRq1UqzZs2i7ALVRNEFANQYgYEVf9sLCAjQkSNHylxFPn/+vJo3b66QkBBPxAPgZhRdAIDXMZlMmjVrltunLpSWlur+++/XsWPHyoyHhITopptu0j//+c9y+9euXVvvvvuuW3NcDlMXAPeg6AIAvJLJZFJwcLDbz/vWW2/pmWee0a5duyRJV111lZ599lm99tprTvffvXu3ioqKFB4e7vYsAK4sii4AoEa56qqrtHjxYp08eVIFBQWKjY2VyWRSrVq1nO5vsVhktVo9nBKAO7COCgCgRmratKlatmzpmCIwdOhQp/sNGDDgilxZBnDlUXQBADVOenq6Nm7cqKNHjzrG7rzzTj3wwAMym82OsR49eujxxx83ICEAdzDZf14sENq9e7ckqWPHjgYnAQBcKW+88YaWLFmi4uJiSVLv3r01d+5chYWFSZJOnDihSZMmyWKxaOnSpVzNBbxMVfoaV3QBADXGl19+qffee89RciVpw4YNevnllx0fl5aWGhENwBVA0QUA1BjLly93Or5y5Url5eXp5Zdf1vDhw3XixAkdPnxYkydPVnZ2todTAnAXii4AoMa4cOGC0/Hi4mJ9+umn+uijj8o8OS0pKUlz5871VDwAbkbRBQDUGL1793Y63q5dO61Zs8bpttWrVys/P/9KxgJwhVB0AQA1xoMPPqiYmJgyY6GhoZoxY4by8vKcHlNcXFxmTi8A38EDIwAANUZERISWLFmiL7/8Unv27FHjxo111113KTo6Wn369NGhQ4fKHdOpUyeeigb4KK8oukeOHNHs2bOVlJSkkJAQ3XHHHZo+ffpll3TJy8vT22+/rW+++UZpaWlq2LChhgwZoocffpin2AAAnKpVq5ZGjhxZbvy3v/2t1q9fr+TkZMdY7dq1NWPGDE/GA+BGhhfd7OxsjRkzRtHR0Zo3b57S09M1Z84cZWZmVvjc8Z8999xzWrNmjX7/+9/rmmuu0a5duzRv3jxlZWVp5syZHnoHAAB/EB4eriVLlujzzz/X/PnzZbFY9P7776tJkyZGRwPgIsOL7rJly5Sdna3ly5erXr16kiSz2azp06dr4sSJio2NdXpcSUmJvvnmGz300EMaPXq0JKlXr15KTU3V119/TdEFAFRZcHCwhg0bps8//1ySVL9+fYMTAagOw29GW79+veLi4hwlV7r4XHGr1arExMQKj7Pb7bLZbI4n2fwsPDxcPOwNAAAAhl/RTUlJ0d13311mzGq1qlmzZkpJSanwOIvFouHDh+uDDz5Q165d1bJlS+3evVv/93//p1GjRrmcx263V3jnLQDA/xUWFjr+Pz8/nyelAV7GbrfLZDJVal/Di252drbTu1nDw8OVlZX1q8c+99xzmjVrlu69917H2OjRo/Xoo4+6nKe4uFj79+93+XgAgG+7dCmxgwcPymKxGJgGgDOVXXTA8KJbkcq09ddee03fffedXnjhBcXExGjv3r2aN2+ewsPDNXXqVJde12KxqGXLli4dC6B6Tp48qcTERFksFt1yyy2KjIw0OhJqoEuv6LZu3VpBQUEGpgHwvy5dGeVyDC+64eHhTp8jfuHChQpvRJOkQ4cOKT4+Xm+//bb69esnSerRo4dMJpNeeeUVPfDAAy7dRGAymRQaGlrl4wBUT3x8vP7yl7845ti//vrreumllzRo0CCDk6GmCQj45faVkJCQyy51CcCzKjttQfKCohsbG1tuLm5RUZGOHz9ebu7upX5u823bti0z3rZtW5WUlOjUqVPcLQtcAXa7vcwVL3c4fPiw/vznP5cZKy4u1syZM9W9e3fH9KafS3BVvsi5U1BQkGGvDQCoOsOLbt++fTV//nxlZGQoIiJC0sXnihcVFenGG2+s8Lif1zXcu3evoqOjHeN79uyRJDVt2vQKpgZqJrvdrueff97p06Oq48yZM07HCwsLNWbMGIWFhencuXPKy8uT1WpVZGSkIVfZWrVqpVmzZlF2fVhBQYE2bdqkkpISxcXFqXbt2i6dp7i4WCUlJQoJCXFzQgDuZHjRHTlypJYsWaJJkyZp0qRJOn/+vObOnashQ4aUmbrw9NNPa/ny5dq3b58kqUOHDrr22ms1a9YsnTt3TjExMdq9e7fefvttDRo0qMxyZQB8l81m06FDh8rcIJSenq6YmJhyywsCv2bz5s164oknHDc6h4SE6I9//KNuv/32Sp8jJydHf/7zn/X111+rsLBQ3bp104wZM9SmTZsrFRtANRhedMPDw5WQkKDZs2drypQpCg4O1uDBgzV9+vQy+5WWlspmszk+NpvNeuedd/TGG2/o3Xff1blz59S4cWONGjVKjzzyiKffBlAjmEwmzZo1y+1TF44ePaoRI0aUWwM7JCREPXv21Kefflpm3G63KzAwUPHx8W7NcTk1berClZimYpS8vDxNnz5dOTk5jrH8/Hw9++yzat++vRo0aOAYv/Q9/+/7nz59ujZv3uz4OCkpSb/73e/00Ucf+dV0uZr2dx3+y2Tn6QoOu3fvliR17NjR4CRAzfPBBx/o1VdfdfxAGxQUpJdffll/+9vf9OOPPzo9ZsOGDapbt64nY9YoBQUFGjdunNEx3CIrK0unTp1yuq1BgwaVWuGjsLCwwvXdo6KiFBUVVa2M3iQ+Pp6b8OC1qtLXDL+iCwDSxTWw+/fvr2+//VYWi0X9+/dXRESEPvroI6f7h4SEsEIKKu3Xrun8/KTNnJwc2e12hYWFyWw2l9uvqKiownNcOrUGgPeg6ALwGo0bN9ZvfvObMmP33nuvtmzZUm7fYcOGVXrBcFTfdf1+K7PZdx+ckJebpWWL/iS7k6ectWjXR9s2fa3ioovTFMxmi3r3u0ct23Yv8+v73AuZ+kf8C7Lby5+jXdf+antt7yv3BjzAZivWD2vfNzoG4FYUXQBebeDAgTp58qQWLlyo3NxcSdKgQYM0Y8YMg5PVLGazReZA3y26YXUiFXfTcG1c94mkX67uduh6k5I2fqWS4l+u1tpsxfp+zTI1jWmr2mERKiku0sljByRJrTvG6cCuDWXOXSeigVp3iPPpPx/AX1F0AXi9hx56SMOHD9e4ceNksVj0wgsvMH8QVdah601q0qy1kg8kqbTUpphrOikz/YxKtpWfkmAvLdXhg9tUN6Khvv3XYhUW5EmSLNZgte3UR+fOnFBRUYGaxbRT5+tuk8XK09MAb0TRBeATQkNDmZOLaouIbKwefQY7Pk5PS61w38KCfK35Ml4lJb8U4eKiAh3au0UP/O4FBYe6tgYvAM8JuPwuAAD4p2Yt2isgoPyNZ5JkNgeWKbk/s5UU6/Ch7Vc6GgA3oOgCAGoUu71UJ47s044tq3Xm9FHF3TRcUtk1Y7v3HixrUMXTY5wVYADeh6kLAIAao6gwX1//8286e/qoYyyifiMNvf/3On3iR5WWlirmmk6qFxWt7My0cjevXWRS81jWWwd8AUUXgM+w2+08rQnVsm3TN2VKriRlnP9J+3Z+r1sGjVF25jnt2rpOaT8dU+3wemrdsZcO7t5UZv9u1w9SnYgGAuD9KLoAvF5iYqLeeOMNHTx4UIGBgVq8eLEmTJhA6UWVVTS39sihHcq+fpA++/A1FeZfXMYu7adjMplM6nnjnSrIz5XsdrVo3UVRjZp7MjKAaqDoAvBqSUlJmjJliuPRwCUlJXrjjTdkMpk0YcIEg9PB15hU8Q9HO35Y7Si5P7Pb7Tqwa6PuHfcsP1gBPoib0QB4tffff99Rci+VkJCgkpISAxLBl7Vo3cX5eKsuOnPqiNNtWRlnyxVgAL6BogvAqx0/ftzpeEZGhi5cuODhNPB1XeNuV6OmsWXG6kU1Ua8b71KtsLpOj7FYg2X5lRUYAHgvpi4A8Gpt2rRRcnJyufHGjRurTp06BiSCL7NYgzTkvseUevyQzqedVJ2IBmrWor1MpgB16HqTTh7dX+6Ydp36yGzm2yXgi7iiC8CrjR8/XiEhIeXGJ06cqIAAvoSh6kwmk5o0b61ru/dT89iOMpku/j1q1qK9+g54QLVqX7yya7EEqWO3W9TjhiFGxgVQDfyICsCrtWrVSosXL9b8+fP1/fffy2q1atasWbrjjjuMjlaj2EqKjY7gEde07a7Y1l2Vl5Ol4JBaCrRYZS8tla201OhoV1xN+RyjZqHoAvB67dq106uvvqpx48ZJkvr162dwoprBbv/lQQk/rHvfuCDwuEs/94Av4/d+AAC/RWEDajau6AIAnLp03djrbvmtzIEWA9NUzfHDe7Vt0790Pu2UaodFqEPXm9S+S1+jY3k1W0mx48o9awbDX1B0AQCXZQ60+EzRTT3xo9Z8GS+7/eK82pwLGdqc+Jkk6doe1Zv2UlpqU+6Fi/N3LdagamcFcGVRdAEAfmXXf9Y6Su6ldm5dq47db9aZU0e0fcsqpaedUnhElDr16K9mLdpf9rwHdm/S1g0rlJeTpcBAq9pce7163XiXAszmK/E2ALgBRRcA4FeyMs46Hc/PzdbJIwe0cvkClZZefNpebk6mTp9I1q1DxyumVWdJUnFRoTLTf1Kt2nUVWvviWs3HD+/V+pUfOs5VUlKkPdu+U0BAgHrdNPwKvyMArqLoAgD8Sv2oJk7Lblid+tqd9K2j5P7CrqRN/1JMq87asWWVtm9ZpeKiAplMAYpt0019b7tfe7cnOn2t/bs2qkefIT4zrQOoaSi6ALzGN998o88++0w5OTnq06ePRo0apbCwMKNjwcd07nmbjh3eU25d2K69BuqHf3/p9Jj0tFNK3r9VP3z/hWPMbi9V8v7/yGoNVu6FTKfHFRcVqKioQCEUXcArUXQBeIU33nhDCxcudHy8Y8cOrVmzRh9++KGCg4MNTAZfE9nwKg25b5q2bfpGaWeOK7xOpDp2v1ktWnXRwb2blZ+bXe6Y8LqROrBro9PzHdq7RS3bdlf6udRy2+pERCk4pLbb3wMA96DoAjBcenq63nvvvXLjBw4c0IoVKzRixAgDUsGXNWh8tQYOf6TceKce/fXTyRSn43sqmJ5QUlKktp376GjyLhXk5zjGTSaTetwwlKW4AC/GAyMAGG7v3r0qLnb++NEdO3aoqKhI33zzjU6dOqW0tDRlZWV5OCH8RfPYjuo3eJwi6jeSdHHebp9bR6ptpz5q0qy102PqN2iqqIbNdNeox9W+y41q0PhqtWjdVUPue0wtWnXxZHwAVcQVXQCGa9iwYYXbIiIiNGrUKO3du9cxNnz4cC1atEht2rTxRDz4mdg2XRXbpqtKS20KCPhlabBO1/XXkR93KvdChmPMbA5UzxvvlCSF1amn3v3u8XheAK7jii4Aw7Vq1Uo9evQoNx4SEqLCwsIyJVeSMjMzNWfOHE/Fg5+6tORKUq3adTV89OPqdv0dataig9p17qvho59Q0+b8QAX4KoouAK/w17/+Vf3795f5v4vvX3PNNXr77beVlJTkdP+tW7cqO7v8TUVAZRUV5qu0tOyDJUJCw9Tt+ts1cPgj6tP/XkVENjYoHQB3YOoCAK8QERGhN954Q5mZmcrPz1fjxhcLRlCQ88esBgYGKjCQL2GoupQDSdq6YYWyMtIUHFJb7bvcqK5xA2Qyce0H8Df8qwbgVerWresouZI0dOhQp/v1799foaGhnooFP3Hy6H6tXfG+sjLSJEkF+TlK2viVtm9e6djHZitRZvoZFRXmGxUTgJtwOQSAV7v33nu1d+9effbZZ7Lb7ZKkDh066JlnnjE4Wc1iszlfFcPX7Nq6TpK93PjupO/UsdvNOrh7s7Zt/kYF+TkymwPVqn1P9bzxTpnN/v/t0l8+x8Cl/P9fLgCfFhAQoBdeeEGjR4/WtGnTZLValZCQwEMkPOyHte8bHcEtzqaWX0NXkgoLcrXqk7/q1KlTjjGbrUT7d23QmZP71ahRI09FBOBGTF0A4BOaNWumiIgI1apVy+go8GEhISFOxy0WizIyMpxuy8zMdPw2AYBv4You4GPsdrsKCwuNjuFxl77nmvj+pYs35nnyKVxBQUGKj4/32Otdym63a86cOUpOTnbreevXr68LFy6UW22hQYMGOnfunNNjSktLZbPZPHrzY8uWLfXUU08Z9tS1im4CBXyNyc6PqQ67d++WJHXs2NHgJEDFCgoKNG7cOKNjeFRRUZHOnTunvLw8Wa1WRUZG1sgb0eLj42vUlI0r9UPd4cOHlZCQoP379ys6OlojR45Ur1699PLLL+uzzz4rt39MTIw++ugjt+f4NZ7+oQbwJVXpa1zRBeDVioqK9OOPP6qkpESSlJubq4yMDF199dWqU6eOwelwJZlMpitS7Nu1a6eXX3653PhDDz2kxMREpaenO8YCAwP12GOP1agfMAB/QtEFfNgLPRvLavbvqz5vJu7R/v+W3EuVZp3Ty7e3NSCRZxXZ7Hp2y2mjY9QITZo00dKlS7V06VLt2bNH0dHRuu+++/gtH+DDKLqAD7OaTQoy+/c9pft+ynQ6fjwjRwVFJTIHmLTj1HmFWALVuUk9mQP87c+j9PK7wG0aNWqkP/zhD0bHAOAmFF0AXq1+rSAdSb9QbjzUEqjE5FTN33BABSU2SVLDsBD96fZuatWAKQ0AAJYXA+BFbKWlyswvlK30l3tkh3Vs7nTfPi0a6o31ex0lV5LOXMjXH/+VVOZ4AEDNxRVdAF7hH9tS9I/th5WRX6TIWkF6oHtL3dnxavVp0UjTbmyvhB9+VGZ+kazmAA1s21TBgYFy1mfPXMjXztTz6to00vNvAgDgVSi6AAz32a6jemfjAcfH53IL9UbiXtWyBurW1k11Q4tGOpOdr92nMxRdJ1SD2zfTv/adqPB8BcW2CrcBAGoOii4Aw/1z5xGn4x/vOKJO0fU16eMNOp93cT3VvT9l6NsfUzW6e0unx4RYzOrcpP4VywoA8B3M0QVguDMX8p2PZ+fro20pjpL7s5JSu75LPq1bWzcpMx5gkqb2ba9QKz/DAwC4ogvAC7RpUFd7f8ooN962UV3tPJXu5AjpSHqO/nJXL93Wuok2HT2rEItZt7Zuoub1wq50XACAj+CKLgDDje3ZSoEBZR98YTUH6MEe1ygi1Or0mGCLWaHWQHVvFqUpfdvrobg2lFwAQBlc0QVguG5XReqN4XH6x/bDOpGRq5j6YRrZtYWuiaqjYR2ba9vJ8+WOub3tVbKazQakBQD4CoouAK/QrlGEnr+9W7nxvrGNNblPOy3+z4+6UFiswACTbmvTVI/0bmNASgCAL6HoAvB6IzrHaEiHZjqVmav6tYJVJ8T5dAYAAC5F0QXgE4ICzWoRGW50DACAD+FmNAAAAPglii4AAAD8EkUXAAAAfomiCwAAAL9E0QUAAIBfougCAADAL1F0AQAA4JcougAAAPBLFF0AAAD4JYouAAAA/BJFFwAAAH6JogsAAAC/RNEFAACAX6LoAgAAwC9RdAEAAOCXKLoAAADwSxRdAAAA+CWKLgAAAPwSRRcAAAB+iaILAAAAv0TRBQAAgF+i6AIAAMAvUXQBAADglyi6AAAA8EsUXQAAAPglii4AAAD8EkUXAAAAfomiCwAAAL9E0QUAAIBfougCAADAL1F0AQAA4JcCjQ4AAJJUbCvVxiNndDYnX+0bRahdo4gy23MKi3Uk/YIa1g5Rg7AQg1ICAHwJRReA4U5m5mr651t05kK+Y6xvbCP9cUAXmQMClPDDIS3bdlgFJTaZ/rvtif6dFGLhSxgAoGJ8lwB8WJGt1OgIbvHqul1lSq4krU/5SZ/uPqYwq0Xv//CjY9wuKTHlJ4VaLZp2UwcPJ/U8f/kcA4ARvKLoHjlyRLNnz1ZSUpJCQkJ0xx13aPr06QoODr7ssZmZmXr99de1Zs0aZWVlKTo6WmPHjtXIkSM9kBzwPLvd7vj/Z7f8ZGAS9yguLta+1HSn2xK2HavwuG8OnNTJwLoKCKg5txpc+rkHAFye4UU3OztbY8aMUXR0tObNm6f09HTNmTNHmZmZeu2113712NzcXI0ePVpBQUF6+umnVb9+fR07dkzFxcUeSg/gSrPZbE7H7Xa7SktLa1TRBQBUjeFFd9myZcrOztby5ctVr149SZLZbNb06dM1ceJExcbGVnjsggULVFBQoI8//thx9bdnz54eyQ0YxWQyOf7/hZ6NZDX7ftGbkXFau09nlBsf3bmZzlzI12e7jpbb1jIyXH/u28wD6YxVZCt1XLm/9HMPALg8w4vu+vXrFRcX5yi5kjRgwAA9/fTTSkxM/NWi+8knn+jBBx+s1BQHwB9ZzQEK8oOiO/2WazX98y1KyylwjF1/dQPdfe3Vyi4o0uajZ3Q6+5c5vEGBAZrcp51fvHcAwJVjeNFNSUnR3XffXWbMarWqWbNmSklJqfC4EydO6Ny5cwoPD9fDDz+sDRs2qFatWho0aJCeeOIJl8uv3W5XXl6eS8cCnlBYWGh0BLdrFlFbS0bdpPUpPyktp0AdGkeoY/TFH37r1QrWgntv0Iq9x7X/TKYahYdoaIfmalq3lsGpPS8/P1+lpdycBqBms9vtlf4Nl+FFNzs7W+Hh4eXGw8PDlZWVVeFx586dkyS98sorGjhwoN59910lJyfrL3/5i4qLizV79myX8hQXF2v//v0uHQt4gr/OQbcGmtW/dROn28KCLbq/W8W/3akpDh48KIvFYnQMADCc1Wqt1H6GF92KXK6t/3xVIzY2VnPmzJEkxcXFqaSkRK+88oqmTZumqKioKr+uxWJRy5YtXQsNeIA/XtFF5bRu3VpBQUFGxwAAQyUnJ1d6X8OLbnh4uLKzs8uNX7hw4Vfn59atW1eS1KtXrzLjvXr1UmlpqVJSUlwquiaTSaGhoVU+DvAUVhmouUJCQrgnAUCNV5Ubcw3/jhkbG1tuLm5RUZGOHz/+q0X3qquucvorvJ/XmaQMAAAA1GyGt8G+fftq8+bNysj4ZWmh1atXq6ioSDfeeGOFx1mtVvXu3VubNm0qM75p0yYFBgYy/QAA4LKkpCRNnTpVSUlJRkcBUA2GF92RI0cqLCxMkyZN0vfff6/ly5frhRde0JAhQ8pc0X366afVrl27MsdOnjxZBw8e1OOPP65///vfev/99/Xmm2/qgQceKLNcGQAAlbVjxw69+OKLOnLkiBYtWsS8eMCHecUc3YSEBM2ePVtTpkxRcHCwBg8erOnTp5fZr7S0tNwTkq699lotWLBAf/7zn/XII4+obt26GjVqlKZNm+bJtwAA8APFxcV68skntXbtWsfY2bNntWTJEo0fP97AZABcZXjRlaSYmBgtWrToV/eZO3eu5s6dW268d+/e6t2795WKBgCoIZYtW1am5EoXVzl5//33dccdd6hRo0YGJQPgKsOnLgDA5ZzPLdC7mw7o/y3frFfX7dKPaRWvsQ246ptvvnE6fuHCBb377ruOm50B+A6vuKILABU5cyFfkz/eoPN5P8+TPK9VB05q9h3d1bN5A0Ozwb8UFBRUuG3Pnj1KTU1VkybOH2oCwDtxRReAV/toW8olJfeiklK7Fmw4YFAi+Kvbb7/d6XitWrXUpUsXRUdHezgRgOqi6ALwartOpTsdP5J+QVn5RR5OA3/2wAMPqGPHjmXGAgMD1aRJE40dO7ZKi9QD8A4UXQBerV4t54+8DbGYFWI1ezgN/FlISIgWL16s++67T1FRUYqOjtY111yje+65Rw0bNjQ6HgAXUHQBeLVhHZo7Hb+97VWymim6cC+TyaQ//OEPatWqlerWrav69etr6NChRscC4CKKLgCvdkNsI03u007hQRcf+W0JCNCgdlfp4d5tDE4GfxUUFKRx48YpMjJSY8eOVVCQ898qAPB+rLoAwOuN6ByjoR2a6VRWnurXClJ4sNXoSPBz3bp1U7du3YyOAaCaKLoAfII10KyY+mFGxwAA+BCmLgAAAMAvUXQBAADglyi6AAAA8EsUXQAAAPglii4AAAD8EkUXAAAAfomiCwAAAL9E0QUAAIBfougCAADAL1F0AQAA4Jd4BDAAr1NiK9Wqg6e08cgZBQWadVubJurZvIHRsQAAPoaiC8CrlNrtmvn1Vm05luYYW/djqh7scY3G9mxlYDIAgK9h6gIAr7L56NkyJfdnHyYl63xugQGJAAC+iqILwKtsP3ne6bit1K6dqekeTgMA8GUUXQBepU6ItcJtEb+yDQCA/0XRBeBVBrRpoqDA8l+arqpbS52a1DcgEQDAV1F0AXiVqNohmj2ouxqFhTjGWkaGq3N0fU3/fOvTShMAACAASURBVIteWbtTP6ZlGZgQAOArWHUBgNfp3ixKHz54sw6fy9aFwhK9uGq7vtx33LF99cFTemFQd/W6miXHAAAV44ouAK8UYDKpZVQdJaac1vm8wjLbSkrtWrBxv0HJAAC+gqILwKvtOuV8pYWj6TnKyi/ycBoAgC+h6ALwavVqBTkdD7GYFWI1ezgNAMCXUHQBeLVhHZo7Hb+97VWymim6AICKUXQBeLUbYhtp8g3tFB5kkSRZAgJ0R7ur9HDvNgYnAwB4O1ZdAOD1RnSK0dD2zXQqK0/1awUpPJgHRwAALo+iC8AnWAPNiqkfZnQMAIAPYeoCAAAA/BJFFwAAAH6JogsAAAC/RNEFAACAX6LoAvAJeUUl2n8mU+dzC4yOAgDwEay6AMDrfbg1WR8mJSu/2KYAk0k3X9NY02++VsEWHhgBAKgYV3QBeLV1P6bq75sPKr/YJkkqtdu19lCq5m/YZ3AyAIC3o+gC8Gor9hx3Or7qwCkVldg8nAYA4EsougC8WmZ+kdPxghKb4yovAADOUHQBeLUuTes7HW8ZGa46ITwKGABQMYouAK92f9dYNQwLKTNmMQfokd5tDUoEAPAVrLoA+LAim11SqdExrqiwEKvm3X29vtp3XAfPZKphWIgGd2iuZhG1VWjz7/cu/fw5BgC4gqIL+LBnt5w2OoIHhUp1Q3VM0t/2Z0vKNjoQAMDLMXUBAAAAfsmlK7p5eXn64YcftG3bNp05c0YFBQWKiIhQy5Yt1bNnT11zzTXuzgngv4KCghQfH290DI8rLCzUxIkTJUnz589XUFCQwYk8rya+ZwCojioV3aNHjyo+Pl4rVqxQXl6eTCaTwsPDZbValZ2drcLCQplMJrVq1UqjR4/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": 35,
   "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": 36,
   "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": 37,
   "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": 38,
   "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": 39,
   "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": 48,
   "metadata": {
    "executionInfo": {
     "elapsed": 15,
     "status": "aborted",
     "timestamp": 1695379585271,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "uMGPmojj4SeF",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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d+6srKwsff3110Wu6fiRrPHjx6tFixaKi4tTRESEdu7cqSVLliguLk7du3eXdOEc7rBhwzR9+nT17dtXX331lVauXKkZM2ZwjywAAIJM79699fLLL+vZZ59Vjx498j32ww8/aOjQoWrYsKEeeugh1a5dW+Hh4dq2bZtmzJiR90lFf1WsWFHdunXT2rVrNXHiRLndbq1Zs0YtW7ZU48aNJUmnT59WTk6OXn/9db3++uuFbufUqVNFrul4yGrZsqXeffddLVq0SKZpqnbt2rrllls0cuTIvHO4bdq00cKFC/XMM89o7dq1uuqqqzR9+vSA7/YOAACcYxiGJk2apDvvvFNvvfVWvsc++ugjpaena8GCBapdu3be8p07dxa77sCBA/X+++/r888/V61atfTNN9/osccey3s8Ojpabrdb/fr1y7v265fq1KlT5HqOh6zRo0dr9OjRl12vS5cueRelAQCA4HbdddepQ4cOSk5Oznc/q4vXaP38Ng2maRYIYxfXyczMLHLNjh07qkaNGlq9erVq1qyp8PDwfDdBjYyMVLt27fTdd98pLi6uSLeK+DWcawMAAI6YNGmSUlNTtX379rxl1113ncLCwvTAAw9o48aN+vDDDzVy5Mi8uwr8XJMmTXTy5Em98cYb2rZt22XnNXS73erfv782bNigtWvXqkePHipfvny+df74xz/q6NGjGjp0qFavXq0vvvhCH3/8sV599VXdfvvtfo3P8SNZAAAgNDVr1ky9e/fWunXr8pbFxMRowYIFeu6553TvvfeqYsWK6tOnj+644w6NGjUq38/ffvvt2r17t5599lmdPXtWpmnm3SfrUgYOHKgXX3xRqampGjRoUIHHY2NjtXr1ai1cuFDPPfecUlNTVb58edWvX9/vM2qELAAAYCnD5VKV6xLzvh44cGDeJ/h+ae7cuZo7d26+ZV27dlXXrl0LrLtr1658R6sqVKig+fPnF7rdS4WtBg0aXDaI1alTR0888cSvrlMUhCwAAGApl8ejplMmOd2G4whZQBDpOWCADhw7VuT1TZ9PWV6vwj0eGcW43Un96tW1/mf3lgEAXB4hCwgiB44d0/c9e5Z84fXrS74mAAQ5Pl0IAAAslZuZqc/7DdLn/QYp149bLFxpCFkAAAA2IGQBAADYgJAFAABgA0IWAACADQhZAAAANiBkAQAA2ID7ZAEA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h4db3aZtAh1/WFiYBg4cqNdff11bt27V+fPntXnzZr311ltB915Y2nFNVhBKS0tTdHR0geXR0dE6c+aMX9t67rnnlJGRoWHDhlnVnu2KO/5NmzbpzjvvlCSVKVNGDz/8sHr16mV5n3Yqzj74+OOPtWXLFr3//vt2tWe74oz/mmuuUb9+/dSgQQMdO3ZML730ku688069/vrratOmjV0tWy7QfXDixAlJ0lNPPaVevXpp8eLFSklJ0TPPPKPs7GwlJSXZ1rPVrHov/PTTT3X69Omg+wBIccb/2GOP6dFHH9Utt9ySt2z48OEaP3685X2GMkLWFcQ0TRmGUeT133nnHb322mt65JFHVL9+fRs7KxlFHX/Lli319ttv69y5c/r000/1+OOPy+126+abby6BLu11uX2QlZWlJ554Qvfee2++UwxXiqI8ByZMmJDv+9/85jfq06ePFi5cqMWLF9vZXom43D7w+XySpJiYGM2aNUuSlJiYqJycHD311FOaOHGiqlWrViK92iWQ98KqVasqMTHRxq5KTlHGP2fOHP3jH//Q448/roYNG2r79u2aP3++oqOjC7xGEDhCVhCKjo5WWlpageVnz54tcOj4Uj7//HNNmzZNI0eODLrDw8Udf7ly5ZSQkCDpwi8Xr9erJ598UgMHDpTb7ba8XzsEug9ee+01uVwu9e7dO+/ns7Oz5fP5lJaWpoiICHk8Htv6tooVr4GLoqKi1KVLF33wwQdWtVciAt0HFStWlCS1b98+3/L27dvL5/Npz549QROyrHgenD9/Xv/4xz80ePDgoHn9XxTo+L///nu9/PLLWrhwoa6//npJF47wGoahp556SkOHDlWVKlVs6zuUcE1WEIqJiSlwvt3r9ergwYNFemPZtm2bxo8fr169eunBBx+0q03bFHf8v9S8eXOdO3dOqampVrVou0D3wd69e3XgwAElJibqmmuu0TXXXKN169Zpz549uuaaa7Rq1Sq7W7eE1c+BYLzYN9B9ULduXYWFhRVYfnEfuFzB82vBiufBhx9+qIyMjKC6hctFgY4/JSVFkhQfH59veXx8vHJycnTkyBHrmw1RwfNqQp7OnTtr8+bNOnXqVN6yDz/8UF6vV126dPnVn92zZ49GjRqltm3batasWX4dUi8tijP+wnz55ZcqV66cKlWqZGWbtgp0H4waNUpLly7N96djx46qXbu2li5dGjSfrLLyOZCenq6NGzfmHd0MFoHuA4/How4dOmjTpk35lm/atEllypRRbGysbT1bzYrnwbp161SvXj21atXKrjZtE+j4a9euLUkFbkT97bffSgq+e8aVas7cOQLFcebMGbNTp07mkCFDzE8//dRcs2aN2a5dO/MPf/hDvvWmTZtmxsfH531/4sQJs0uXLmaHDh3Mf/3rX+aWLVvy/mzfvr2khxGwQMe/Y8cOc+TIkebKlSvNf/3rX+ZHH31k/vGPfzSbNGlivvjiiyU9jGIJdB8UJhjvkxXo+P/zn/+YY8aMMVetWmVu2rTJ/Otf/2r279/fbN68ubl169aSHkaxFOc5sHXrVrN58+bmgw8+aH722WfmK6+8YrZq1cqcOXNmSQ6h2Ir7Ojh58qTZrFkz89lnny2pli0V6PhzcnLMwYMHm4mJieYbb7xhbtq0yVy0aJHZunVr87777ivpYVzRuCYrCEVHR+u1115TUlKS7r33XkVERKhPnz6aNGlSvvV8Pp9yc3Pzvk9JSdHRo0clSXfccUe+dWvXrq2PP/7Y9t6tEOj4q1atqujoaC1cuFDHjx9X+fLl1ahRIyUnJ6t79+4lPYxiCXQfXCkCHX+1atXk9Xr1zDPP6PTp04qMjFSbNm30pz/9SS1btizpYRRLcZ4DLVu21Isvvqi5c+dqzJgxqlixooYNG6aJEyeW5BCKrbivg/fee085OTlBeapQCnz8brdbL7zwgubNm6fFixfrxIkTqlmzpoYNG6YxY8aU9DCuaIZpBuHFCAAAAKUc12QBAADYgJAFAABgA0IWAACADQhZAAAANiBkAQAA2ICQBQAAYANCFgAAgA0IWQAAADYgZAEottWrVysuLq7QP7Nnz5YkffLJJ5o8ebL69u2r5s2bKy4uzq8ahw8fztvmggULCl1n2rRpeesAgNOYVgeAZWbNmqVGjRrlW1a9enVJFyau3bp1q+Lj4xUWFlZgctqiKlu2rNasWaNx48bJ5fq//yeeP39e77//vsqVK6dz584FPggAsAghC4BlGjdurISEhEIfS0pKygtFM2bMCDhk3XjjjVq5cqU2bdqkDh065C1/99135fP51L17d/3tb38LaNuBysjIUGRkZInWBFD6cboQQIn4+VGn4mjYsKHatGmjVatW5Vu+atUq9ejRQ+XLly/wM++++67uuusudezYUS1bttRvf/tbzZkzR+np6QXW3bp1q8aMGaN27dopISFB3bt318yZM/MeX7BggeLi4rR9+3ZNmDBB11xzjXr06JH3+IYNG3TrrbeqVatWatOmje68805t2bLFkrEDCC4cyQJgGZ/Pp5ycnHzLypSx/m1m8ODBmjFjhs6cOaMKFSpo79692rJli+677z6tX7++wPr79+9X586dNWLECEVGRmrv3r1avHixtm3bpqVLl+at99lnn+mee+5Ro0aNNHXqVNWsWVNHjhzR559/XmCb9957r2688UYNGTIkL6y98847mjRpkjp27Ki5c+fK6/VqyZIlGj58uF599VVdffXVlu8LAKUXIQuAZW655ZYCy7Zv32550Prtb3+rmTNnat26dRo6dKjefvtt1alTR+3atSs0ZI0dOzbva9M01bZtW8XExGjYsGHauXOnmjZtKunCacyaNWtq5cqVCg8Pz/uZQYMGFdhm//79NWHChLzvfT6fnnrqKTVp0kSLFy/OO3LXpUsX9ejRQ3PmzNGbb75p2T4AUPoRsgBYZvbs2YqJicm3zN+A9csjYW63W4Zh5FtWtmxZ9erVS6tWrdKtt96qv/71r7rtttsKrHfRoUOH9Nxzz2nz5s06efKkTNPMe2zv3r1q2rSp9u3bp4MHD+qBBx7IF7AupWfPnvm+37dvn44dO6YRI0bkOzVatmxZ9ezZUytWrODaLSDEELIAWCYmJuaSF74XVfPmzfN9P2vWLA0cOLDAeoMHD9Ztt92mF154QampqYWuI1341OFtt92m8PBw3XfffWrQoIEiIiL0448/avz48crMzJQkpaamSpJq1KhRpD4vfmryolOnTkmSqlWrVui6Pp9PaWlphCwghBCyAJQqb7/9dr7v69SpU+h6/+///T81bNhQycnJuu6661SzZs1C19u8ebOOHTum119/Xddee23e8rNnz+Zbr3LlypKkn376KaC+K1WqJEk6fvx4gceOHTsml8ul6OjogLYNIDjx6UIApUpCQkK+PxfDS2Huuecede3aVXfdddcl17l4CtHj8eRb/svroxo2bKh69epp1apV8nq9fvfdsGFD1ahRQ+vWrct3OjI9PV3r169X69atOYoFhBiOZAEoEUeOHNE333wjSTp48KAk6f3335ck1a5dO6DTjP369VO/fv1+dZ02bdqoQoUKevTRRzV+/HiVKVNG77zzjnbt2lVg3UceeUT33HOPbrnlFt1xxx2qWbOmjh49qs8++0xz58791Toul0sPPvigJk2apLvvvlu33nqrvF6vXnrpJaWlpekPf/iD3+MDENwIWQBKxBdffKFp06blWzZx4kRJ0oABA/Tkk0/aUrdSpUp68cUXNXv2bD344IOKjIzU9ddfr2effVYDBgzIt26nTp30l7/8RcnJyUpKSlJWVpauuuoqdevWrUi1+vbtq8jISC1atEj333+/3G63WrVqpaVLl6pt27Z2DA9AKWaYPz+uDQAAAEtwTRYAAIANCFkAAAA2IGQBAADYgJAFAABgA0IWAACADQhZAAAANiBkAQAA2ICQBQAAYANCFgAAgA0IWQAAADYgZAEAANjg/wP4rZY1GQbLYQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(f1s, bins=15,facecolor = '#008080', edgecolor='#000000', linewidth=0.5)\n",
    "\n",
    "\n",
    "vertical_line_position = 0.846  # 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",
    "    \n",
    "plt.xlabel(\"F1-Macro\")\n",
    "plt.ylabel(\"frequency\")\n",
    "\n",
    "#plt.title(\"bert-base\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "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_imdb_randomizationtest.csv')\n",
    "'''"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "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": 50,
   "metadata": {
    "executionInfo": {
     "elapsed": 33,
     "status": "aborted",
     "timestamp": 1695329093833,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "-nnwzm980k1q",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.5936\n",
      "F1-Macro:  0.5823088393032435\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 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": 51,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093833,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "7cdh2kXd0-Zb",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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vFh1AQAAwI+iIpxKvu4+ffHjemXkZKl182j9rvtgtW3BOroNjaILAADgZ83DmumGvlcaHcP0mLoAAAAAU6LoAgAAwJQougAAADAlii4AAABMiaILAAAAU6LoAgAAwJQougAAADAlii4AAABMiaILAAAAU6LoAgAAwJQougAAADAlii4AAABMiaILAAAAU6LoAgAAwJQougAAADAlii4AAABMiaILAAAAU6LoAgAAwJQougAAADClUKMDoOmqcJfp543blZ91UBHRZ6nDoAsVdlZzo2MBAABIoujCR+7jxVr/3EIVHsqpGstYtUGDpt6qqI7tDEwGAABwAlMX4JOMVRuqlVxJKi8p1c4PVxiUCAAAoDqKLnySvSvd63je3l/kLir2cxoAAICaAqLoZmZmavLkyerbt6/i4uKUlJSkkpKSOu2bn5+vRx99VL/5zW/Uu3dvDR8+XIsXL27kxAh12L2Oh1itsoYyIwYAABjP8Ebicrk0YcIEtW3bVnPnzlVubq6Sk5OVn5+vOXPmnHLf48eP64477pDD4VBiYqJatmypffv2qayszE/pg1eHQRcqL/PnGuPn9ushq91mQCIAAIDqDC+6ixcvlsvlUmpqqqKjoyVJVqtVCQkJmjp1qmJjY2vd95VXXlFJSYneffddhYWFSZIGDRrkl9zBrsOgC1V4IFt7v9okT2WlJKlV1/PUa8xVBicDAAA4wfCiu27dOsXFxVWVXEkaPny4EhMTtXbt2lMW3ffff1933nlnVcmF/1gsFvUac5U6X3GJXL8cVnjUWXK2PdvoWAAAAFUML7oZGRkaO3ZstTG73a6YmBhlZGTUut/+/ft15MgROZ1O/fGPf9TXX3+tZs2aacSIEZoxY4bP5dfj8aioqKje+5WWlvr0ek1deAunwls4jY5hqOLiYlX+/7PagJkE6/sa/P++xrEWvHw51jwejywWS522NbzoulwuOZ01i5LT6VRBQUGt+x05ckSS9NRTT+nqq6/Wa6+9pvT0dD399NMqKytTUlKST3nKysq0a9cun/ZDcEpLS5PNxrxkmA/va8HL3+9rHGvBy9djzW73flH8/zK86NbmdG391/YfGxur5ORkSVJcXJzKy8v11FNP6d5771Xr1q3r/bo2m01dunSp9378NRq8unXrJofDYXQMoMHxvha8/P2+xrEWvHw51tLTvS9x6o3hRdfpdMrlctUYLywsPOX83BYtWkiSLrnkkmrjl1xyiSorK5WRkeFT0bVYLIqIiKj3fiEhAbFSGwwQHh7OPHGYEu9rwcvf72sca8HLl2OtrtMWpABYRzc2NrbGXFy3262srKxTFt0OHTp4PdXt8Xgk8X8aAACAYGd4GxwyZIg2bNigvLy8qrEVK1bI7XZr6NChte5nt9t16aWXav369dXG169fr9DQUJ+mHwAAAMA8DC+648aNU/PmzRUfH68vv/xSqampmjVrlkaPHl3tjG5iYqJ69uxZbd9p06YpLS1NDz74oL766iu98cYbeu655zR+/Phqy5UBAAAg+ATEHN0FCxYoKSlJ06dPV1hYmEaNGqWEhIRq21VWVqqioqLaWJ8+ffTKK6/o73//u/70pz+pRYsWuv3223Xvvff681sAAABAADK86EpSp06dNG/evFNuk5KSopSUlBrjl156qS699NLGigYAAIAmyvCpCwAAAEBjoOgCAADAlCi6AAAAMCWKLgAAAEyJogsAAABTougCAADAlCi6AAAAMCWKLgAAAEyJogsAAABTougCAADAlCi6AAAAMCWKLgAAAEyJogsAAABTougCAADAlCi6AAAAMCWKLgAAAEyJogsAAABTougCAADAlCi6AAAAMCWKLgAAAEwp1OgAAIDAV1FeZnQENDJ+xjAjii4AwCuPx1P17+9WvWFcEPjdyT97oClj6gIAAABMiTO6AACvLBZL1b8vvuL3sobaDEyDxlZRXlZ15v7knz3QlFF0AQCnZQ21UXQBNDlMXQAAAIApUXQBAABgShRdAAAAmBJFFwAAAKZE0QUAAIApUXQBAABgShRdAAAAmBJFFwAAAKZE0QUAAIApUXQBAABgShRdAAAAmBJFFwAAAKZE0QUAAIApUXQBAABgShRdAAAAmFKo0QEkKTMzU0lJSdq0aZPCw8M1cuRIJSQkKCws7JT73XHHHfruu+9qjH/66aeKjY1trLgAAABoAgwvui6XSxMmTFDbtm01d+5c5ebmKjk5Wfn5+ZozZ85p9+/fv79mzJhRbax9+/aNFRcAAABNhOFFd/HixXK5XEpNTVV0dLQkyWq1KiEhQVOnTj3tmVmn06m+ffv6IyoAAACaEMPn6K5bt05xcXFVJVeShg8fLrvdrrVr1xqYDAAAAE2Z4Wd0MzIyNHbs2GpjdrtdMTExysjIOO3+3333nfr27auKigpdeOGFuvfeezVw4ECf83g8HhUVFdV7v9LSUp9fE01bcXGxKisrjY4BNDje14KXv9/XONaCly/HmsfjkcViqdO2hhddl8slp9NZY9zpdKqgoOCU+w4cOFDXXXedzjvvPGVnZ2vevHmaOHGiFi5cqH79+vmUp6ysTLt27fJpPwSntLQ02Ww2o2MADY73teDl7/c1jrXg5euxZrfb67Sd4UW3NnVp6/fcc0+1ry+//HKNGjVKL774ol577TWfXtdms6lLly713o+/RoNXt27d5HA4jI4BNDje14KXv9/XONaCly/HWnp6ep23NbzoOp1OuVyuGuOFhYX1XiIsIiJCQ4cO1fLly33OY7FYFBERUe/9QkIMn+4Mg4SHh592KTygKeJ9LXj5+32NYy14+XKs1XXaghQAF6PFxsbWmIvrdruVlZXl01q4Ho+noaIBAACgCTO86A4ZMkQbNmxQXl5e1diKFSvkdrs1dOjQej1XUVGR1q5dq969ezd0TAAAADQxhhfdcePGqXnz5oqPj9eXX36p1NRUzZo1S6NHj652RjcxMVE9e/as+nrjxo2aOnWqPvjgA23YsEFLlizR+PHjlZOTo2nTphnxrQAAACCABMQc3QULFigpKUnTp09XWFiYRo0apYSEhGrbVVZWqqKiourr1q1by+126+mnn1Z+fr7Cw8PVr18/PfbYY+rTp4+/vw0AAAAEGMOLriR16tRJ8+bNO+U2KSkpSklJqfq6Y8eOp90HAAAAwcvwqQsAAABAY6DoAgAAwJQougAAADAlii4AAABMiaILAAAAU6LoAgAAwJQougAAADAlii4AAABMiaILAAAAU6LoAgAAwJQougAAADAlii4AAABMKdSXnYqKivTdd9/p+++/1+HDh1VSUqKoqCh16dJFgwYN0vnnn9/QOQEAAIB6qVfR3bt3r+bPn69PPvlERUVFslgscjqdstvtcrlcKi0tlcViUdeuXXXHHXdozJgxCgnhpDEAAAD8r85F98knn9S///1vderUSfHx8br44ovVs2dPhYb+9ymys7O1ZcsWffHFF3riiSf0xhtvKDk5Wb17926U8AAAAEBt6lx0d+7cqddff10DBw6sdZuzzz5bV111la666iodO3ZMb7zxhr7//nuKLgAAAPyuzkV30aJF9XriyMhI3X333fUOBAAAADSEBp9Ae/jwYe3cubOhnxYAAACoF59WXThw4ECtj33++ed65ZVXtH79ep9DAQAAAGfKp6J7xRVXyGKx1Pp4p06dfA4EAAAANASfiu6TTz5Zo+gWFRVp48aNWrlypVJSUhokHAAAAOArn4rumDFjvI6PHz9eKSkpmj17thYuXHhGwQAAAIAz0eAXow0dOlTbtm1r6KcFAAAA6qXBi25eXp5atmzZ0E8LAAAA1ItPUxe8qays1I8//qiXX35Z9957b0M9LQAAAOATn4pu9+7da111wePx6KGHHtJDDz0kSbJYLKyrCwAAAL/zqWEMJswAACAASURBVOhOmzbtlMuLAQAAAEbzqehOnz69oXMAAAAADarBL0YDAAAAAkGdi+6jjz6qnJycej35559/riVLltQ7FAAAAHCm6jx1ITMzU1deeaV+97vf6brrrtOAAQMUHh5eY7t9+/Zp5cqV+uCDD3T48GHNmTOnQQMDAAAAdVHnortgwQJ98cUXevXVVzVlyhSFhoaqY8eOio6OlsPhUEFBgfbv36+CggKFh4drzJgxmjp1KmvqAgAAwBD1uhjtyiuv1JVXXqmdO3dq9erV2rp1q7Kzs5WTk6OoqCgNGzZMF198sYYNG6bIyMjGygwAAACclk+rLvTs2VM9e/Zs6CwAAABBxePxsGRrI2qwO6MBAACgbrb+/KPe2fSZMo7sV6vIKI3oNUQjLhhidCzT8Wl5sfXr12vZsmVVXx85ckRTpkzRpZdeqgcffFClpaUNFhAAAMBM0g5n6m+fz1PGkf2SpCPH8vTmtx9pybZVBiczH5+K7ty5c5WRkVH19ezZs7Vx40b169dPy5cv1z//+c8GCwgAAGAmn2xfq0pPZY3xpdvXqqKywoBE5uVT0d27d2/VHN3y8nKtWLFCCQkJev7553XPPfdo6dKlDRoSAADALA4WeL8vQUHJMR13F/s5jbn5VHSPHTsmp9MpSdqxY4eKi4s1bNgwSVKfPn108ODBhksIAABgIjHR53odb9mshSIdEX5OY24+Fd2WLVtq7969kqRvvvlGbdu2VZs2bSRJx48fV2ho/a5xy8zM1OTJk9W3b1/FxcUpKSlJJSUl9XqOFStWqFu3bho1alS99gMAAPCn6/pcIbvVVmP8hr5XKsTiUzVDLXxadeGyyy7TM888o/T0dH344Ye6/vrrqx7bs2eP2rVrV+fncrlcmjBhgtq2bau5c+cqNzdXycnJys/Pr/Nd1UpKSpScnKxWrVrV+3sBAADwp44t22rmyGn6YMvnSs/Zr9aRURpxwRAN7tzP6Gim41PRve+++3TgwAG988476tOnj6ZOnVr12CeffKJ+/er+g1q8eLFcLpdSU1MVHR0tSbJarUpISNDUqVMVGxt72ud45ZVX1LZtW7Vv314//PBD/b8hAAAAP4pt3UEP/G6y0TFMz6eiGx0drXnz5nl97M0335Tdbq/zc61bt05xcXFVJVeShg8frsTERK1du/a0RTcrK0uvv/66Fi9erDfeeKPOrwsAAABzO+MbRpSUlKigoEAtW7ZUaGhovW/9m5GRobFjx1Ybs9vtiomJqbaEWW2eeOIJXXfdderevXu9Xrc2Ho9HRUVF9d6PtYODV3FxsSoray4TAzR1vK8FL3+/r3GsBS9fjrX63E3O56K7YcMGPfPMM9q+fbsk6d1331WvXr302GOPKS4uTldddVWdnsflclWt4HAyp9OpgoKCU+67atUqbd68WZ999ln9v4FalJWVadeuXT7th+CUlpYmm63mRQVAU8f7WvDy9/sax1rw8vVYq+vsAZ+K7vr163XXXXfp/PPP16RJk6rdICIqKkoffPBBnYtubU7X1ktLS/Xkk09q+vTp1aY9nCmbzaYuXbrUez/+Gg1e3bp1k8PhMDoG0OB4Xwte/n5f41gLXr4ca+np6XXe1qeiO3fuXA0ZMkQvvfSSysvLqxXd7t2764MPPqjzczmdTrlcrhrjhYWFp5yfu2DBAoWEhGjkyJFV+5eVlamyslIul0thYWH1miv8K4vFooiI+q9hFxLCciDBKjw8XGFhYUbHABpcML6veTyVytqzQzmHshTpjFZst/6y2YPvD1l/v68F47GGE3w51uo6bUHyseju2rVL//jHP7y+WHR0tI4ePVrn54qNja0xF9ftdisrK6vG3N2T7dmzR/v27VNcXFyNxwYOHKhHH31Ut956a51zAACCW5m7VMs+eFGHfv7v76SNX3+iUTdNV4uWbQxMBsBXPhVdq9Va63yao0ePqlmzZnV+rl/PDOfl5SkqKkrSiZs/uN1uDR06tNb9pkyZohtuuKHa2KuvvqrMzEwlJyfrvPPOq3MGAAC2b1pdreRKUtGxAn298l2NvHm6QakAnAmfPivo3bu3lixZ4vWx5cuXq2/fvnV+rnHjxql58+aKj4/Xl19+qdTUVM2aNUujR4+uNnUhMTFRPXv2rPo6NjZWgwYNqva/1q1bKyIiQoMGDdI555zjy7cGAAhSmT9t8Tr+S9ZuuUuL/ZwGQEPw6YzuH/7wB02ePFnTpk3T9ddfL4vFoq1bt+r999/X8uXLtWDBgjo/l9Pp1IIFC5SUlKTp06crLCxMo0aNUkJCQrXtKisrVVFR4Utcv/OUV4jFpszNU940jkUAdRcSYvU6brFYZOG2rECT5FPRHTx4sFJSUvTkk09q5cqVkqTHH39cTqdTycnJGjBgQL2er1OnTrXegOJXKSkpSklJOe02RvF4PFX/zn5vtWE54H8n/+wBNF1degxQzqF9NcY7xl4QlBekAWbg8zq61113nYYPH67NmzfryJEjioqKUv/+/X1asQAAAKP16jdEh3/Zoz27N1eNRbU6V5cOu9nAVADORL2LbklJiX7/+9/rnnvu0eDBg72uehCMTl594uwbfytLqPePwGAOnvKKqjP39VnmBEDgCgmx6sprJ+vI4f3KObRPkc5otT+vO9MWgCas3kU3LCxMu3fvltVKkauNJdSqENsZ310ZAYw52IB5tTqng1qd08HoGAAagE9/pvbr10/btm1r6CwAAABAg/Gp6M6YMUNvv/22UlNTdfz48YbOBAAAAJwxnz5fv+WWW1RWVqa//OUv+stf/qKwsLBq8xQtFos2bdrUYCEBAACA+vKp6A4fPpwLcAAAABDQfCq6Rq5XCwAAANQFa6YAAADAlHxeAysrK0vPPfec1q9fr/z8fEVFRWnw4MGaNm2aYmJiGjIjAAAAUG8+Fd2MjAyNGzdOpaWluuSSS3T22WcrOztby5Yt05o1a/Tvf/9bsbGxDZ0VAAAAqDOfiu4zzzyjFi1aaOHChWrTpk3V+KFDhzRhwgQ9++yzeu655xosJAAAAFBfPs3R/c9//qPp06dXK7mS1KZNG8XHx+vbb79tkHAAAACAr3w6o1tcXKwWLVp4fSwqKkolJSVnFAoATpaTk6N//etf2r59u9q1a6dbb71VPXr0MDoWACDA+VR0O3XqpI8//lhDhgyp8djSpUvVuXPnMw4GAJJ04MAB3XbbbcrJyaka++ijj/T888/rsssuMzAZACDQ+VR077jjDj388MMqLCzUDTfcoNatWysnJ0dLlizRqlWrlJSU1NA5AQQIj8ej0tJSv73eq6++Wq3kSlJ5eblmz56tgQMH+i2HJDkcDm6WAwBNiE9F98Ybb9TRo0f10ksvae3atZJO/PILCwvTfffdp7FjxzZoSACBwePx6LHHHtPu3bv99pppaWlexzMyMnTnnXcqNNTnVRLrrWvXrpo5cyZlFwCaCJ9/Q/zxj3/Ubbfdps2bNys/P18tWrRQv3791Lx584bMByDI1VZkQ0JCFBLCPW8AALU7o1MhzZs39zpPF4A5WSwWzZw5069TF1atWqUHHnigxvjNN9/sdbwxMXUBAJoWn4ru+++/rwMHDmj69Ok1HnvuuefUoUMHXX/99WccDkDgsVgsCgsL89vrjRgxQkeOHNHLL7+sgoICWSwWXXvttZoxY4bsdrvfcgAAmh6fPvdbuHChnE6n18eioqL05ptvnlEoADjZnXfeqWXLlqlr167q2bOnHnnkEUouAOC0fDqju2/fPnXt2tXrY7Gxsdq3b98ZhQKA/+VwOBQeHm50DABAE+LzlRyFhYVex48dO6aKigqfAwEAAAANwaei261bNy1dutTrY5988kmtZ3sBAAAAf/Gp6I4fP17Lly/XjBkztHXrVh0+fFhbt27VQw89pM8//1y33357Q+cEAAAA6sWnObqjR4/Wnj179Oqrr2rJkiWSTiwkb7VaNXXqVF177bUNGhIAAACoL5/X0b333ns1duxYff3118rLy1N0dLQuvfRStWvXriHzAQAAAD45o9sKtW/fXsOHD9exY8e0cuVKvfLKK0pPT2+obAAAAIDP6nxG929/+5uWLVumNWvWVI0VFRXpxhtv1C+//CKPxyNJWrp0qd5991117ty5wcMCAAAAdVXnM7qbN2/WiBEjqo0tWrRIP//8syZMmKCNGzdq8eLFioiI0GuvvdbgQQEAAID6qHPR3b9/vy644IJqY6tXr1Z0dLQeeOABRUZGqm/fvpo4caK+/fbbBg8KAAAA1Eedi67L5dLZZ59d9XV5ebm2b9+uiy++WFartWq8R48eysnJadiUAAAAQD3VeY5uq1atlJ2dXfX1zp07VV5eXuMsb0hICPegBxqRx+NRaWmp0TH87uTvORi/f+nEbZAtFovRMQCgyahz0e3Vq5feffddXXPNNbJYLFqyZIksFovi4uKqbbdnzx61bt26wYMCOKG0tFSTJk0yOoahpk6danQEQ8yfP19hYWFGxwCAJqPORXfKlCm69dZbdfXVVysqKkpbtmzRgAED1KtXr2rbrV69Wr17927woAAAAEB91LnoXnjhhXrxxRc1b9485efn66abbtKf//znatvk5OTo0KFDGjNmTIMHBVDTrEHnym4Nno+yf13GMJg+vndXePTXbw8aHQMAmqR63Rnt8ssv1+WXX17r461bt666JTCAxme3WuSwntF9XxDwKo0OAABNFr8hAQAAYEoUXQAAAJgSRRcAAACmFBBFNzMzU5MnT1bfvn0VFxenpKQklZSUnHa/2bNna+TIkerXr5/69++vsWPHaunSpX5IDAAAgEBXr4vRGoPL5dKECRPUtm1bzZ07V7m5uUpOTlZ+fr7mzJlzyn2Li4s1btw4derUSR6PR8uXL9f999+vyspKjR492k/fAQAAAAKR4UV38eLFcrlcSk1NVXR0tCTJarUqISFBU6dOVWxsbK37PvLII9W+vuyyy5Senq4PP/yQogsAABDkDJ+6sG7dOsXFxVWVXEkaPny47Ha71q5dW+/na9GihcrKyhoyIgAAAJogw8/oZmRkaOzYsdXG7Ha7YmJilJGRcdr9PR6PKioqVFRUpFWrVunrr7/W7Nmzfc7j8XhUVFRU7/1KS0t9fk00bcXFxaqs9N9apxxrwYtjDf7CsQZ/8eVY83g8db5xkOFF1+Vyyel01hh3Op0qKCg47f7r16/XxIkTJUmhoaH661//qquvvtrnPGVlZdq1a5dP+yE4paWlyWaz+e31ONaCF8ca/IVjDf7i67Fmt9vrtJ3hRbc2dW3rffr00Xvvvadjx45p3bp1mjVrlqxWq2666SafXtdms6lLly713o+/RoNXt27d5HA4/PZ6HGvBi2MN/sKxBn/x5VhLT0+v87aGF12n0ymXy1VjvLCw8JQXov0qMjJSvXv3liTFxcXJ7XYrJSVFY8aMkdVqrXcei8WiiIiIeu8XEmL4dGcYJDw8XGFhYX57PY614MWxBn/hWIO/+HKs1XXaghQAF6PFxsbWmIvrdruVlZVVp6L7v3r16qVjx44pNze3oSICAACgCTK86A4ZMkQbNmxQXl5e1diKFSvkdrs1dOjQej/fpk2bFBkZqaioqIaMCQAAgCbG8KkL48aN06JFixQfH6/4+HgdPXpUKSkpGj16dLUzuomJiUpNTdXOnTslST/++KPmzJmjq6++Wu3atVNRUZFWr16t9957T3/+858VGmr4twYAAOrJXcGFaWbnz5+x4W3Q6XRqwYIFSkpK0vTp0xUWFqZRo0YpISGh2naVlZWqqKio+rpVq1ZyOp168cUXlZOTo+bNm6tz58564YUXdOWVV/r72wAAAD7yeDxV/37q24UGJoG/nfyzbwyGF11J6tSpk+bNm3fKbVJSUpSSklL1datWrfT00083djQAAAA0UQFRdAEAQPA6+Sr6BwfdIbvVf2v4wv/cFWVVZ+7rs4KCLyi6AAAgYNitNoouGozhqy4AAAAAjYGiCwAAAFOi6AIAAMCUKLoAAAAwJYouAAAATImiCwAAAFOi6AIAAMCUKLoAAAAwJYouAAAATImiCwAAAFOi6AIAAMCUKLoAAAAwJYouAAAATImiCwAAAFOi6AIAAMCUKLoAAAAwJYouAAAATImiCwAAAFOi6AIAAMCUKLoAAAAwJYouAAAATImiCwAAAFOi6AIAAMCUKLoAAAAwJYouAAAATImiCwAAAFOi6AIAAMCUKLoAAAAwJYouAAAATCnU6AAAcDpHjpXog2179WN2vs5pHq4bep+nrmefZXQsAECAo+gCCGiHC4sV/+7Xyi0qrRr7Iu0XzRoxQJecd7aByQAAgY6pCwAC2lvfZ1QruZJUXunRK9/sMigRAKCpoOgCCGjbfsn1Or4395gKit1+TgMAaEoougACWnQzh9fxcJtV4Xarn9MAAJoSii6AgHbdBR29jo/o2UF2K0UXAFA7ii6AgHZZbBvdfVlPOcNskiRbSIhG9uygPwzubnAyAECgY9UFAAFv7IWdNLpXjA64ihQd4ZAzzG50JABAExAQRTczM1NJSUnatGmTwsPDNXLkSCUkJCgsLKzWfY4dO6bXX39d69atU2ZmpkJDQ9WrVy/df//96tWrlx/TA/AHe6hV50U3NzoGAKAJMXzqgsvl0oQJE3T8+HHNnTtXM2bM0Mcff6yHH374lPsdOHBAb7/9tgYPHqxnnnlGycnJqqys1Lhx47Rjxw4/pQcAAECgMvyM7uLFi+VyuZSamqro6GhJktVqVUJCgqZOnarY2Fiv+7Vv314rVqxQeHh41djgwYM1bNgwLVq0SMnJyX7JDwAAgMBk+BnddevWKS4urqrkStLw4cNlt9u1du3aWveLiIioVnIlyeFwKDY2VtnZ2Y2WFwAAAE2D4Wd0MzIyNHbs2GpjdrtdMTExysjIqNdzFRUVadeuXbruuut8zuPxeFRUVFTv/UpLS0+/EUypuLhYlZWVfns9jrXgxbEGf+FYg7/4cqx5PB5ZLJY6bWt40XW5XHI6nTXGnU6nCgoK6vVczz77rIqLi3X77bf7nKesrEy7dtX/1qJlZWU+vyaatrS0NNlsNr+9Hsda8OJYg79wrMFffD3W7Pa6rb5jeNGtTX3auiR9/PHHWrBggR555BF17Oh9gfm6sNls6tKlS73346/R4NWtWzc5HN7v3tUYONaCF8ca/IVjDf7iy7GWnp5e520NL7pOp1Mul6vGeGFhYa0Xov2vr7/+Wn/5y180efJkjR8//ozyWCwWRURE1Hu/kBDDpzvDIOHh4adcCq+hcawFL441+AvHGvzFl2OtPidCDT+yYmNja8zFdbvdysrKqlPR3bZtm+6++25dffXVeuCBBxorJgAAAJoYw4vukCFDtGHDBuXl5VWNrVixQm63W0OHDj3lvhkZGZoyZYr69++v5OTkejV8AAAAmJvhRXfcuHFq3ry54uPj9eWXXyo1NVWzZs3S6NGjq53RTUxMVM+ePau+Pnr0qCZPniybzaa77rpLO3bs0JYtW7Rlyxbt3LnTiG8FAAAAASQg5uguWLBASUlJmj59usLCwjRq1CglJCRU266yslIVFRVVX6enp+vgwYOSpN///vfVtm3Xrp1WrVrV6NkBAAAQuAwvupLUqVMnzZs375TbpKSkKCUlperrQYMGKS0trbGjAQAAoIkyfOoCAAAA0BgougAAADAlii4AAABMiaILAAAAU6LoAgAAwJQougAAADAlii4AAABMiaILAAAAU6LoAgAAwJQC4s5oaJpKC49r71cblb/vgCKiW6jjby6Ss+3ZRscCAACQRNGFj4rzXfr62TdUkl9YNbb/260aOOVmte7e2cBkAAAEvpzCXH26Y53Sc7LUOjJKV/e8TF3POc/oWKZD0YVPMlaur1ZyJamyokI7l6zUUIouAAC1yi48qv9b8g8VlhyXJP2UvU8bMrfpvivu1MDzehuczlyYowufHE3f53W88EC23MeL/JwGAICmY8m21VUl91eVnkq9tfFTgxKZF0UXPrFHNvM6brXbZHXY/ZwGAICm48dDmV7HDxRk1yjAODMUXfik46X9vY63v7iPrKHMiAEAoDYtm53ldTzcFqZwm8PPacyNoguftO3bQz2uHabQsBP/h7SEhKj9wD7qee0wg5MBABDYrur5G6/jw7pfolArJ4saEv814bPYKy5Rx0v763hOrsLOai5Hc+/TGQAAwH9dFNNTUy69Se9+/5nyiwvlCLXrt10HadyAEUZHMx2KLs5IqMOus9q3MToGAABNyrDul2ho14E6eixfZ4VHKowpC42Cogsg4JWUVeiL3b/ox8P5auMM1zU9OqhlszCjYwHAGQkNseocZ0ujY5gaRRdAQHOVuHXvB+u1N/dY1dji7/do9nWD1OOcFgYmAwAEOi5GAxDQ3v5+T7WSK0nH3eV64csdBiUCADQVFF0AAW3Dvmyv4zsO5auwpMzPaQAATQlFF0BAi7B7n2FlCwmRzcpbGACgdszRBZowd0Wl0REa3ZXd2umHg3k1xi/r0kaWEItKTf7fIBh+xgDQWCi6QBPj8Xiq/v3Xbw8ZmMQ/PJ4QtWrVSkeOHKkai4yM1GFblGZ8c8DAZP538s8eAHB6FF0AAc1isahdu3ZyOp0qKChQeHi4oqOjZbFYjI4GAI1m39ED+uHAT2oe1kwXn9ebdXZ9RNEFmpiTC96sQW1kN/k81YpKj+as2qate/579tZRUqBZIwcqOsL8b/zuisqqM/eUe6BpOew6qpVp63XkWJ66tO6oy7terAh79TXAKysrFRLy3/dxj8ej175+T6vSNlSNLfxuiR66aopiW3fwW3azoOgCTZjdGiKHyYvuBz9kavVP1acoZBwp1Etf7tTjIy4yKBUAnNqugxlK+fyfKi13S5K+2bNFK378Ro+NvFvO8Eht3r9L72z6TJlHf1Z0xFkaccEQjbxgqL7du61ayZWkwpLjemHtv/X0jTOM+FaaNIougID2xW7v83C/zjys4rJyhdt4G0PDKsjLVs6hfYp0tlSbdp2NjhN03BXlRkdoEG9sSK0qub86WJCjj7atUt8OPTR7xXxVek5cbJpbVKBF332s0vIy7cv1/p53oCBbGUf2q0NUm0bP3tj8+TPmNwSAgFZWy6oDlR6PKiq5OAsNx+Op1Lrlbynthw2SThxbrdt01NVj/qTwiObGhgsiT337ptERzlh5eXmthfWLnzZoTebGqpJ7sg+2rlBYWO23N391y4dyOMw/ZashmfszTwBN3m86n+N1vF+7lop02PycBma2c8tXSvthvX4tuZKUc2ifvl75rnGh0CSFhITUOqc+JCREZWXeb3ZTUVGhyMhIr4/ZbDbZ7fYGyxgsOKMLIKDd3LezvtuXo52H86vGoiIcmj6kl4GpYEY/7fzO63jmT1tU5i6Vzc6ZtMbicDg0f/58o2M0qCeeeELLli2rMf7AAw9ow4YN+vzzz2s8ds455+idd97R7Nmz9cknn1SNn3XWWZozZ4569OjRqJmN0NhnqCm6AAJauD1Uc8fG6evMw0o7XKBznOEa1rWtmtk5m4uGVVHLvEFPZaUqKyv8nCa4WCyWU35k3xTNmDFDx44d05dffinpRKG74447dO2116pHjx5at26dSkpKqu0zZcoUNWvWTI8++qjGjRun//znP4qKitIVV1yhiIgII76NJo+iCyDgWUNCNCT2XA2JPdfoKDCxjp0v0NHsn2uMn9u+ixxhlAzUT2RkpJ555hn9/PPPOnTokM4//3ydddZZkqTzzz9f//znP/XKK6/om2++kc1m0//93//pmmuuqdq/e/fu6t69u1HxTYOiCwCApD4Dhykrc4eOHN5fNRYWHqnBw24yMBWauvbt26t9+/Y1xktKSlRcXCyPx6PKykoVFxcbkM78KLoAAEiyO8J13W1/VuZPW5RzcJ+an9VSXXoMVFh4M6OjwWR27typ+Ph4ud0nlh9zu9168sknVVZWpltuucXgdOZC0QUA4P+zWkPVpfsAdek+wOgo8COPx6PS0lK/vd4bb7xRVXJP9vrrr2vUqFGyWq1+y+JwOEx910WKLgAACFoej0ePPfaYdu/e7bfX3Lt3r9fxI0eOaNKkSX4tul27dtXMmTNNW3YpugACXnlFpdZlHNKP2fk6p3m4ftetnZxhrCcJoGmy2+1ez+harVaFhHCLg4ZE0QUQ0I67y/Tn1G+Vll1QNbbwP+n6+/WDFNvKaWAyAGZgsVg0c+ZMv05d2LFjh6ZNm6by8upL2sXHx/t9ji5TF/wgMzNTSUlJ2rRpk8LDwzVy5EglJCScdk29Tz/9VMuWLdOWLVuUnZ2tBx98UJMnT/ZTagD+8PbmPdVKriQVlLg1d90O/WNMnEGpAJiJv9fxveiii/T888/rlVde0c6dO9WmTRuNHz9eY8aM8VuGYGF40XW5XJowYYLatm2ruXPnKjc3V8nJycrPz9ecOXNOue9nn32m/fv367e//a3efvttPyUG4E/rM7O9jm87kKtjpWXcBhhAkzRgwAANGMBFj43N8KK7ePFiuVwupaamKjo6WtKJOSoJCQmaOnWqYmNja9332WefrZrLQtEFzMlu9T5fzRpikTXEvB+3AQDOnOFFd926dYqLi6squZI0fPhwJSYmau3atacsukzYBszvd93baefh/Brjv+ncRuE2w9/CgkZFRZnREfzK4/FIkqnnLv6vYPsZIzgY/lsiIyNDY8eOrTZmt9sVExOjjIwMv+fxeDwqKiqq937+nMSOwFJcXKzKykq/vV6wHWuje3VUWnaBlu/6WZ7/P9b9nBa6d0gvQ3MZwchj7buVb/jtdWE8fx9rQH14PJ46/xFqeNF1uVxyOmteOe10OlVQUOBlj8ZVVlamXbt2+bQfglNaWppsNv/NEw22Y80aYtGMYRfqtv6xSssu0DnOcPU+N/r0H/GFlwAAG4FJREFUO5oQxxr8xd/HGlBfdnvdlpg0vOjWpj5tvSHZbDZ16dKl3vsF21k2/Fe3bt3kcDj89nonH2vuCo8k85912XPUpcWbMk4U3ebhuqHPeYrrdI7RsfzixM/4BH8fax6PRy+88ILfXs8oK1as0KeffqrCwkINGDBAN9xwgx5//HFJ0tNPP+3X/+aBwm63B9W0DTQt6enpdd7W8KLrdDrlcrlqjBcWFp5yfm5jsVgsioiIqPd+zBcOXuHh4X5dlubkY+2v3x702+sapbi4WOnp6VUfox4uLNa2A7nq0KFDtbn9wcDfx5okNWvWzK+v52/PPfec5s2bV/V1RkaG1q9fr/DwcFmtVrVo0cLv/80BnFp9/ggzvJ3FxsbWmIvrdruVlZVlSNEFEFhycnK8zhU8fPhw1QVDgC/y8/O1cOHCGuNZWVnKz695ASSApsfwM7pDhgzRSy+9pLy8PEVFRUk68TGS2+3W0KFDDU4HBB6Hw6H58+cbHcNvbr75ZuXl5dUYd7vdevrpp6veN4JBMH6E3ph2797t9Tas0olPEgA0fYYX3XHjxmnRokWKj49XfHy8jh49qpSUFI0e/f/au/eoqOv8j+OvUW6jiFfUxFsKkhVeUlO8VfozdZfaLS0RJbxsaxLaRSzSCjB2U7cWu+h6LV3NkEypPJWbecku6Nlt3TA1V7DUSiWQe3Kd3x8eZxuBGFDmK1+fj3M8p3nP5zvzZvw2vPzM5/uZuxxmdOfNm6eUlBQdOnTIXjt27JjDOo2jR4/qww8/lNVqJSTDtFz9DT5Gq24HlhYtWsjX11duboa/jaGBat++fbX3cSEWYA6G/4bw8fHRunXrlJCQoFmzZsnLy0shISGKjo52GFdRUaHy8nKH2gcffKBXX33VfjslJUUpKSny8/PTzp07XdI/gPoVERGhPXv2VFq+EB4eTsjFZencubOGDx+uTz75xKFutVqvqU8KADOz2FjkZpeWliZJCgoKqvWx58+f17Rp0yRJ7UL/T43YyN7UKkrLdCZphyTptddeu6ZmWI3w8ccf66WXXlJ6errc3Nw0Y8YMzZw5k6vCcdkKCgq0ePFiffjhhyopKVFAQIB69uypnTt3ysPDQ0uXLlXPnj2NbhPAL9Qmrxl+MRoA1GTkyJFKTk5WUFCQbrzxRk2bNo2QiyvC29tbCxYs0J49e/TWW2+poKBA7777rgoKCpSdna2IiAjt27fP6DYB1BHTjqizn3PydHzPfuWc+FHWls11/fD+atG5g9FtwcTYxg/1xWq1auvWrfrxR8ct+y5e9Lhp0yaDOgNwOQi6qJOirBx9tmStivML7bUfvvxa/aeNU7ubexjYGQDUzf79+6usf/PNN8rJyVGLFi1c3BGAy8X0COok/eMvHEKuJNkqKnR42y6DOoLZ5ebmqqCgoNrtoIDLVd0FaF5eXrJarS7uBsCVQNBFnWQfP1llveD0TyopLHJxNzC7V155RWPHjlV6eroOHz6s6OhoFRYW1nwgUAvjxo2rsn7XXXexhzHQQBF0USeePt5V1t08PeTGLwRcQe+9956WL1+u4uJie23Xrl1atGiRgV3BjMaMGaOoqCiHr4G/88479fjjjxvYFYDLQdBFnXQd2q/KeqdBfdTIrbGLu4GZvf3221XWt23b5hB+gSshPDxcDz/8sJo1a6bWrVvrkUceYdkC0IARdFEn7YMCdfP40fLwvjDz0cjdTV2G3KKed40wuDOYTW5ubpX14uJivqYVV1ReXp7Cw8P1l7/8Rfn5+crKylJoaKjDN3ICaFjYdQF11nVof3Ue1FdF2TnybNZU7la+NAFXXnBwsI4ePVqpftNNN3EVvMnZbDaXztqvWbOm0rmWn5+vhQsXauXKlS7rQ5I8PT3ZKxq4Agi69cBWVq6KmoeZQsHZLOWcvLCPbutunYxux2VsZeU1D8IVMW3aNO3cuVMnT/7vAkgvLy898cQTBnaF+maz2RQfH1/lP3LqS3p6epX1r776ShEREWrc2HXLsnr06KHY2FjCLnCZCLr14Oxm82+xZbPZ9N133ykrK8tea9Kkifz9/eXu7m5gZzCbNm3aKDk5WUlJSVq7dq08PDy0atUqBQQEGN0aTObXvpCEwAk0TARd1ElmZqZDyJWkoqIinTx5Ut26dTOoK5iVj4+PHnjgAe3evVuS1KnTtfPpwbXKYrEoNjbWpUsXUlJStHDhwkr1O++8UwsWLHBZHxJLF4ArhaB7hXh6euq1114zug2XCQ8Pd/go+aL8/Hy9+uqrDtvzmB37awL1w2KxyMvLdWv/J0yYoIyMDG3evFkVFRcWoPXr10/z5893aR8ArhyC7hXi6jdko5WWllZZLysrk5ub2zX1WgAwB4vFonnz5mnKlCk6fPiwOnTooJ49exrdFoDLQNBFnYwYMUKHDx+uVL/11lvl4+NjQEcAcGV06NBBHTp0MLoNAFcA++iiTqZNm6abb77ZodayZUs9/fTTBnUEAADgiKCLOvH29lZSUpIWLVqkdu3aqVOnTnr33XcVGBhodGsAAACSCLq4DO7u7hozZow6duyotm3bsmQBAABcVQi6AAAAMCWCLgAAAEyJoAsAAABTIugCAADAlAi6AAAAMCWCLgAAAEyJoAsAAABTIugCAADAlAi6AAAAMCWCLgAAAEyJoAsAAABTIugCAADAlNyMbgANQ15enrZs2aKvv/5anTt31v3336927doZ3RYAAEC1CLqo0ZkzZxQWFqZTp07Za+vWrdPatWvl7+9vYGcAAADVY+kCarR8+XKHkCtJ+fn5WrRokUEdAQAA1Iygixrt3bu3yvr+/ftVUlLi4m4AAACcQ9BFjXx8fKqsN2nSRI0bN3ZxNwAAAM4h6KJG48aNq7L+29/+Vm+//ba+/fZb/fDDDzpz5oyLOwMAAKgeQRc1CgsL0wMPPCB3d3dJksVi0e23365//vOf+tOf/qSsrCz9+OOPuueee3TgwAGDuwUAALiAXRdMwmazqbi4uN4ef86cOYqIiNB///tfdezYUZs3b9bu3bsdxhQWFiohIUEbNmyotz6q4unpKYvF4tLnBAAAVz+CrgnYbDbFx8fr6NGjLnvOQ4cOVVlPS0vTAw88IDc3151aPXr0UGxsLGEXAAA4uCqWLhw/flzTp09Xnz59FBwcrISEBJ0/f96pY7du3aoxY8YoKChIISEh+uCDD+q5W0iq9iI0i8WiRo2uitMKAABc4wyf0c3Ly1NERIQ6dOigl19+WdnZ2Xr++eeVk5OjF1544VeP/fDDDxUTE6M//vGPGjJkiHbs2KHHHntMzZo109ChQ130ExjPYrEoNja2XpcuXColJUWxsbGV6iEhIUpISHBZHxJLF64FOTk52rhxo44fPy4PDw8dP35cPXv2NLotAMBVzvCgm5SUpLy8PKWkpKhVq1aSLswWRkdHa+bMmerevXu1x7700ksaM2aM5syZI0kaNGiQjh8/rpdffvmaCrrShbDr5eXlsucLDQ3Vt99+qw0bNqi0tFSSNHToUMXGxrq0D5hfZmamwsLC9MMPP9hrkyZN0rJlyzRo0CADOwMAXO0MD7qffPKJgoOD7SFXkkaPHq158+Zpz5491QbdkydPKiMjQ48//rhDPSQkRE899ZSys7MdHhNXXkxMjKZPn65Dhw7Jz8+PrwO+RtT3hY+XWrFihUPIlaTi4mItXrxYGzdudFkfEp8eAEBDY3jQTU9Pr7RPq4eHhzp37qz09PRqj8vIyJAkdevWzaHevXt32Ww2ZWRk1Cno2mw2FRUV1fq4a1XTpk01YMAASeJ1uwbYbDYtXLjwV//fvNK++eabauuuvvDR399fTz75JGEXAAxks9mcfh82POjm5eVV+c1bPj4+ys3Nrfa4i/ddemzz5s0d7q+t0tJSHT58uE7HAmZns9n0888/u/Q5qwuyRlz4WFRUpMOHDxN0AcBgHh4eTo0zPOhWx9m0fukYm81WZd1Z7u7ufAQP/Ir4+HiVlJS47Pl27NihuLi4SvW7775bc+fOdVkf0oU3VkIuABjr2LFjTo81POj6+PgoLy+vUj0/P/9XL0T75cxtmzZt7PWLj1XVLLEzLBaLmjRpUqdjgWtF06ZNXfZc9913n7Kzs7V69WoVFRWpUaNGGj16tJ555hlZrVaX9QEAuDrUZsLB8KDbvXv3Suv9SkpKdOLEiUprd3/p4trcjIwMh0Ccnp4ui8VSae0ugIZrxowZmjRpktLT09W+fXu1a9fO6JYAAA2A4Tv7Dx8+XKmpqTp37py99tFHH6mkpES33XZbtcd16tRJ3bp10/vvv+9Q37Ztm3r16sWOC4DJeHt7q3fv3oRcAIDTDA+6oaGhatasmSIjI7V3716lpKToueee01133eUwUztv3jzdeOONDsfOnj1bH3zwgRITE7Vv3z79+c9/1meffabZs2e7+scAAADAVcbwpQs+Pj5at26dEhISNGvWLHl5eSkkJETR0dEO4yoqKlReXu5QGzt2rM6fP6/ly5drzZo16tKlixITE6+5L4sAAABAZRbbxW0KoLS0NElSUFCQwZ0AAACgKrXJa4YvXQAAAADqA0EXAAAApkTQBQAAgCkRdAEAAGBKBF0AAACYEkEXAAAApkTQBQAAgCkRdAEAAGBKBF0AAACYEkEXAAAApkTQBQAAgCkRdAEAAGBKBF0AAACYEkEXAAAApuRmdANXk9LSUtlsNqWlpRndCgAAAKpQUlIii8Xi1FiC7i84+6IBAADAGBaLxenMZrHZbLZ67gcAAABwOdboAgAAwJQIugAAADAlgi4AAABMiaALAAAAUyLoAgAAwJQIugAAADAlgi4AAABMiaALAAAAUyLoAgAAwJQIugAAADAlgi4AAABMiaALAAAAUyLoAgAAwJQIugAAADAlgi4AAABMiaCLGsXExCgkJER79uxRSEiIgoKCdO+99+rAgQP2MSNGjNCCBQu0evVqDRs2TL1799bMmTN19uxZAztHQ1Obc23Dhg2644471K9fP0VGRio7O9vAztHQXDzX9u3bp9///vfq06ePxo8fr4MHD9rHBAYGauXKlVq8eLEGDRqkvn37KiYmRgUFBQZ2jobG2XNt1apVevnllzV48GANHDhQTz31lIqKigzs3BwIunBKZmam4uPjNX36dC1ZskQeHh6aPn26srKy7GM++ugj7dixQ3FxcYqLi1NaWppmzZplYNdoiJw513bu3Kldu3bp2Wef1fz587V//34999xzBnaNhigzM1MJCQmaPn26EhMTdf78eUVFRam0tNQ+Zv369crIyNCiRYsUHR2t7du365lnnjGwazREzpxrb7zxhr777jstXLhQkZGReu+997Rs2TIDuzYHN6MbQMOQk5OjJUuWKDg4WJI0YMAA3XbbbVq3bp0ef/xxSVJhYaFWrlwpHx8fSVL79u01ZcoUffrppxo6dKhhvaNhceZcs9ls+tvf/iYPDw9J0nfffac1a9aooqJCjRrx73c4Jzc3Vxs2bFBAQIAkydPTU1OnTtV//vMf9e/fX5Lk4eGh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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": 56,
   "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 = 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "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": 58,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093834,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "AoDiCBpM6glm",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.7806000000000001\n",
      "F1-Macro:  0.7696040079285819\n"
     ]
    },
    {
     "data": {
      "image/png": "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n3766VpFt7i4WD/88IO+/PLLGjd2AAAAAIzgVdG96SbPd+4YP3680tPT9eyzz2rBggWNCgYAAAA0hs8vRhs+fLh++uknXz8tAAAA0CA+L7pHjx5V+/btff20AAAAQIN4NXXBk6qqKm3dulWvvvqqpk2b5qunBQAAALziVdE999xz61x1we1265FHHtEjjzwiSbJYLKyrCwAAAL/zqujed999p1xeDAAAADCaV0V36tSpvs4BAAAA+JTPL0YDAAAAmoN6F90nn3xShw4datCTf/7551q8eHGDQwEAAACNVe+pC7m5ubrqqqt09dVXa/To0brwwgsVEhJSa7udO3fqyy+/1AcffKC8vDzNmjXLp4EBAACA+qh30c3IyNAXX3yhuXPn6q677lJgYKDOOussRUZGKigoSIWFhdq9e7cKCwsVEhKim266SUlJSaypCwAAAEM06GK0q666SldddZU2b96sr776SuvXr9fBgwd16NAhRUREaMSIEbrooos0YsQIhYWFNVVmAAAA4LS8WnWhT58+6tOnj6+zAAAAAD7DqgsAAAAwJa+K7sqVK7V06dLqjw8fPqy77rpLl1xyiR5++GGVlZX5LCAAAADgDa+K7uzZs5WTk1P98bPPPqsffvhBAwYM0Geffaa//e1vPgsIAAAAeMOrovvLL79Uz9GtqKjQsmXLlJKSopdeekkPPPCAPv74Y5+GBAAAABrKq6J77NgxORwOSdKmTZtUUlKiESNGSJL69eun/fv3+y4hAAAA4AWvim779u31yy+/SJK+++47RUdHq1OnTpKk48ePKzDQq8UcAAAAAJ/xqpFedtllev7557V9+3Z9+OGHuuGGG6of27Fjh84880yfBQQAAAC84VXR/f3vf699+/bpH//4h/r166ekpKTqx5YsWaIBAwb4LCAAAADgDa+KbmRkpObNm+fxsbfeekt2u71RoQAAAIDGavQNI0pLS5WXl6eKigpJUlhYGEUXAAAAhvO66K5atUrjxo3TwIEDdcUVVyg7O1uSNHPmTH3++ec+CwgAAAB4w+s7o02ZMkVlZWWaPHmyqqqqqh+LiIjQBx984LOAAAAAgDe8vjPasGHDlJmZqd/97nc1Hjv33HO1detWn4QDAAAAvOVV0d2yZYsSExMlSRaLpcZjkZGROnLkSOOTAQAAAI3gVdG1Wq0qLy/3+NiRI0fUpk2bRoUCAAAAGsurotu3b18tXrzY42OfffaZ+vfv36hQAAAAQGN5tY7u3XffrSlTpui+++7TDTfcIIvFovXr1+v999/XZ599poyMDF/nBAAAABrEq6I7dOhQpaen6+mnn9aXX34pSfrTn/4kh8OhtLQ0XXjhhT4NCQAAADSUV0VXkkaPHq34+HitXbtWhw8fVkREhAYOHKjQ0FBf5gMAAAC80uA5uqWlpUpMTNR3332n4OBgxcXFKSEhQZdeeqnXJTc3N1dTpkxR//79FRcXp9TUVJWWljboOZYtW6ZevXpp1KhRXmUAAACAuTT4jG5wcLC2bdsmq9XqkwBOp1MTJ05UdHS0Zs+erfz8fKWlpamgoECzZs2q13OUlpYqLS1NUVFRPskEAACAls+rqQsDBgzQTz/9pCFDhjQ6wKJFi+R0OpWZmanIyEhJJ5YvS0lJUVJSkmJjY0/7HK+99pqio6PVpUsXbdy4sdGZAAAA0PJ5tbzY9OnT9c477ygzM1PHjx9vVICsrCzFxcVVl1xJio+Pl91u14oVK067/65du/TGG2/o8ccfb1QOAAAAmItXZ3THjRun8vJyPfroo3r00UcVHBxc4w5pFotFa9asqddz5eTkaMyYMTXG7Ha7unXrppycnNPu/+c//1mjR4/Wueee27BPog5ut1vFxcU+eS4AaMnKysqMjgCDlJSUqKqqym+vx7HWenlzrLnd7lp35q2LV0U3Pj6+3i9wOk6nUw6Ho9a4w+FQYWHhKfddvny51q5dq08//dQnWSSpvLxcW7Zs8dnzAUBLVdcdMGF+2dnZstlsfns9jrXWy9tjzW6312s7r4puenq6N7s1yOnaellZmZ5++mlNnTq1xrSHxrLZbOrRo4fPng8AWirOsrVevXr1UlBQkN9ej2Ot9fLmWNu+fXu9t/V6HV1fcTgccjqdtcaLiopOeSFaRkaGAgICNHLkyOr9y8vLVVVVJafTqeDg4Hq3/ZNZLBbWAgYASQEBXl3GARMICQlRcHCw316PY6318uZYa8isAq+L7q5du/Tiiy9q5cqVKigoUEREhIYOHar77rtP3bp1q/fzxMbG1pqL63K5tGvXrlpzd0+2Y8cO7dy5U3FxcbUeGzx4sJ588kndeuut9f+EAAAAYCpeFd2cnBwlJiaqrKxMF198sTp27KiDBw9q6dKl+vrrr/X222/Xa1kwSRo2bJheeeUVHT16VBEREZJO3PzB5XJp+PDhde5311136cYbb6wxNnfuXOXm5iotLU1nn322N58aAAAATMKrovv888+rXbt2WrBggTp16lQ9fuDAAU2cOFEvvPCCXnzxxXo9V2JiohYuXKjk5GQlJyfryJEjSk9PV0JCQo2yPGPGDGVmZmrz5s2STpwJ/u8y/eGHHyovL88n6/sCAACgZfNqUsy//vUvTZ06tUbJlaROnTopOTlZ33//fb2fy+FwKCMjQ6GhoZo6darS09M1atQopaam1tiuqqpKlZWV3sQFAABAK+TVGd2SkhK1a9fO42MREREqLS1t0PPFxMRo3rx5p9wmPT39tKs9+GM1CAAAALQMXp3RjYmJ0UcffeTxsY8//ljdu3dvVCgAAACgsbw6ozthwgQ9/vjjKioq0o033qgOHTro0KFDWrx4sZYvX15r2gEAAADgb14V3ZtvvllHjhzRK6+8ohUrVkg6cYOH4OBg/f73vz/lsmAAAACAP3i9ju4999yj2267TWvXrlVBQYHatWunAQMGKDw83Jf5AAAAAK806s5o4eHhGjZsmK+yAAAAAD7j1cVo77//fp3r5L744ovKzMxsVCgAAACgsbwqugsWLJDD4fD4WEREhN56661GhQIAAAAay6uiu3PnTvXs2dPjY7Gxsdq5c2ejQgEAAACN5VXRlaSioiKP48eOHeMOZgAAADCcV0W3V69e+vjjjz0+tmTJkjrP9gIAAAD+4lXRHT9+vD777DNNnz5d69evV15entavX69HHnlEn3/+uW6//XZf5wQAAAAaxKvlxRISErRjxw7NnTtXixcvlnTihhFWq1VJSUm6/vrrfRoSAAAAaCiv19GdNm2axowZo2+//VZHjx5VZGSkLrnkEp155pm+zAcAAAB4pVE3jOjSpYvi4+P1t7/9TWvXrtXGjRt1xx13qEePHr7KBwBoBioryo2OgCbG9xhmVO+i+5e//EVLly7V119/XT1WXFysm2++WXv37pXb7ZYkffzxx3r33XfVvXt3n4cFAPjPr7/XJWn18jeNCwK/O/l7D7Rk9b4Ybe3atbruuutqjC1cuFB79uzRxIkT9cMPP2jRokUKDQ3V66+/7vOgAAAAQEPU+4zu7t27dccdd9QY++qrrxQZGamHHnpIVqtV/fv316RJk7Rw4UKfBwUA+JfF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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "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": 59,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093835,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "t-1o_fPd_MEy",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['habit',\n",
       " 'calcium_hypochlorite',\n",
       " 'providence capital_of_rhode_island',\n",
       " 'phonogramic',\n",
       " 'going_under foundering',\n",
       " 'instill instil',\n",
       " 'bit',\n",
       " 'baltic-finnic',\n",
       " 'bank_of_japan',\n",
       " 'silver flatware']"
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "n_words_spurious[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {
    "executionInfo": {
     "elapsed": 33,
     "status": "aborted",
     "timestamp": 1695329093836,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "lvMoMpyEXQVt",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['skipper captain',\n",
       " 'tuareg',\n",
       " 'deploy',\n",
       " 'wavy-leaved_aster',\n",
       " \"white_dogtooth_violet white_dog's-tooth_violet erythronium_albidum blonde_lilian\",\n",
       " 'focal_infection',\n",
       " 'demotic_script demotic',\n",
       " 'magnus_hitch',\n",
       " 'bath_mat',\n",
       " 'use']"
      ]
     },
     "execution_count": 60,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "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": 61,
   "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": 62,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093836,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "uAcBqk9LpYds",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Advocate.csv is Positively Spurious.\n",
      "Positive Acc: 0.832462037671474 \n",
      "Negative Acc: 0.148456520230875\n",
      "------------------------------------------------------------------------\n",
      "Dialogue.csv is Positively Spurious.\n",
      "Positive Acc: 0.8463753931244277 \n",
      "Negative Acc: 0.14868128011221735\n",
      "------------------------------------------------------------------------\n",
      "Indian.csv is Positively Spurious.\n",
      "Positive Acc: 0.7739005648718084 \n",
      "Negative Acc: 0.17570478624795707\n",
      "------------------------------------------------------------------------\n",
      "Orientation.csv is Positively Spurious.\n",
      "Positive Acc: 0.8436148146167884 \n",
      "Negative Acc: 0.14604187545374955\n",
      "------------------------------------------------------------------------\n",
      "Colored.csv is Positively Spurious.\n",
      "Positive Acc: 0.844369399149634 \n",
      "Negative Acc: 0.15402464657607337\n",
      "------------------------------------------------------------------------\n",
      "occupations1950_nonprofessional.csv is Positively Spurious.\n",
      "Positive Acc: 0.8410600043320772 \n",
      "Negative Acc: 0.14788258679132701\n",
      "------------------------------------------------------------------------\n",
      "Society.csv is Positively Spurious.\n",
      "Positive Acc: 0.6700863680392998 \n",
      "Negative Acc: 0.21116672401546016\n",
      "------------------------------------------------------------------------\n",
      "Money.csv is Positively Spurious.\n",
      "Positive Acc: 0.8241032037112865 \n",
      "Negative Acc: 0.1550023954267513\n",
      "------------------------------------------------------------------------\n",
      "Woman.csv is Neutral.\n",
      "Positive Acc: 0.4449235610473653 \n",
      "Negative Acc: 0.4087175859522577\n",
      "------------------------------------------------------------------------\n",
      "Activist.csv is Positively Spurious.\n",
      "Positive Acc: 0.8284557312873223 \n",
      "Negative Acc: 0.15042610016351898\n",
      "------------------------------------------------------------------------\n",
      "Retarded.csv is Positively Spurious.\n",
      "Positive Acc: 0.7063051752252073 \n",
      "Negative Acc: 0.21844000659041193\n",
      "------------------------------------------------------------------------\n",
      "Chubby.csv is Neutral.\n",
      "Positive Acc: 0.5463916087147471 \n",
      "Negative Acc: 0.3177604621649328\n",
      "------------------------------------------------------------------------\n",
      "Jew.csv is Positively Spurious.\n",
      "Positive Acc: 0.8093207626874622 \n",
      "Negative Acc: 0.19719399320899797\n",
      "------------------------------------------------------------------------\n",
      "Homosexual.csv is Positively Spurious.\n",
      "Positive Acc: 0.7268705608041633 \n",
      "Negative Acc: 0.2176645680982641\n",
      "------------------------------------------------------------------------\n",
      "Misgendering.csv is Neutral.\n",
      "Positive Acc: 0.4991227630908946 \n",
      "Negative Acc: 0.31290283019644805\n",
      "------------------------------------------------------------------------\n",
      "Marriage.csv is Positively Spurious.\n",
      "Positive Acc: 0.7475713187408851 \n",
      "Negative Acc: 0.2077411266744239\n",
      "------------------------------------------------------------------------\n",
      "Industry.csv is Neutral.\n",
      "Positive Acc: 0.589811046832033 \n",
      "Negative Acc: 0.2282987731393012\n",
      "------------------------------------------------------------------------\n",
      "Oriental.csv is Positively Spurious.\n",
      "Positive Acc: 0.6104629449322323 \n",
      "Negative Acc: 0.27895080559773056\n",
      "------------------------------------------------------------------------\n",
      "occupations1950_professional.csv is Positively Spurious.\n",
      "Positive Acc: 0.845068705421059 \n",
      "Negative Acc: 0.14547828051117476\n",
      "------------------------------------------------------------------------\n",
      "Gender.csv is Neutral.\n",
      "Positive Acc: 0.5904471242004405 \n",
      "Negative Acc: 0.3042487998097697\n",
      "------------------------------------------------------------------------\n",
      "Media.csv is Positively Spurious.\n",
      "Positive Acc: 0.6085261900424744 \n",
      "Negative Acc: 0.31568108752662305\n",
      "------------------------------------------------------------------------\n",
      "Islam.csv is Positively Spurious.\n",
      "Positive Acc: 0.8441273101486748 \n",
      "Negative Acc: 0.1475244257612971\n",
      "------------------------------------------------------------------------\n"
     ]
    }
   ],
   "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(\"------------------------------------------------------------------------\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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
}
