{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "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 T5Config, T5Tokenizer, T5EncoderModel\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(0)"
   ]
  },
  {
   "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:0\n"
     ]
    }
   ],
   "source": [
    "PRE_TRAINED_MODEL_NAME = 't5-large'\n",
    "config = T5Config.from_pretrained(PRE_TRAINED_MODEL_NAME)\n",
    "tokenizer = T5Tokenizer.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 = T5EncoderModel.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, 1024])\n",
      "torch.Size([20, 1024])\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 = T5EncoderModel.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.5984, 0.5624],\n",
       "        [0.4702, 0.4342],\n",
       "        [0.1628, 0.3102],\n",
       "        [0.1580, 0.2764],\n",
       "        [0.1813, 0.3158],\n",
       "        [0.1721, 0.3181],\n",
       "        [0.3969, 0.4189],\n",
       "        [0.1946, 0.2876],\n",
       "        [0.1900, 0.3049],\n",
       "        [0.1671, 0.3142],\n",
       "        [0.2116, 0.3047],\n",
       "        [0.1695, 0.2429],\n",
       "        [0.1632, 0.2626],\n",
       "        [0.1728, 0.2806],\n",
       "        [0.1866, 0.2671],\n",
       "        [0.1508, 0.2735],\n",
       "        [0.1605, 0.2690],\n",
       "        [0.2412, 0.3506],\n",
       "        [0.4453, 0.4535],\n",
       "        [0.1854, 0.2414],\n",
       "        [0.1691, 0.2217],\n",
       "        [0.1876, 0.2944],\n",
       "        [0.1503, 0.2722],\n",
       "        [0.1824, 0.3652],\n",
       "        [0.4961, 0.4876],\n",
       "        [0.1618, 0.2985],\n",
       "        [0.1966, 0.3275],\n",
       "        [0.4545, 0.4704],\n",
       "        [0.1848, 0.2910],\n",
       "        [0.1611, 0.2836],\n",
       "        [0.4834, 0.4789],\n",
       "        [0.1900, 0.3027]], 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.46273171210289 accuracy 0.868425\n",
      "Val   loss 0.4148435877386931 accuracy 0.9016000000000001\n",
      "\n",
      "Epoch 2/8\n",
      "----------\n",
      "Train loss 0.418259187412262 accuracy 0.895725\n",
      "Val   loss 0.4079658379600306 accuracy 0.9054000000000001\n",
      "\n",
      "Epoch 3/8\n",
      "----------\n",
      "Train loss 0.41125567746162417 accuracy 0.90115\n",
      "Val   loss 0.40450862980192637 accuracy 0.9102\n",
      "\n",
      "Epoch 4/8\n",
      "----------\n",
      "Train loss 0.40837818138599397 accuracy 0.90295\n",
      "Val   loss 0.3999025768535152 accuracy 0.91\n",
      "\n",
      "Epoch 5/8\n",
      "----------\n",
      "Train loss 0.4043608548402786 accuracy 0.907275\n",
      "Val   loss 0.4034265405053546 accuracy 0.9082\n",
      "\n",
      "Epoch 6/8\n",
      "----------\n",
      "Train loss 0.4024663649320602 accuracy 0.9083\n",
      "Val   loss 0.3998725556643905 accuracy 0.9096000000000001\n",
      "\n",
      "Epoch 7/8\n",
      "----------\n",
      "Train loss 0.3998371074914932 accuracy 0.9105000000000001\n",
      "Val   loss 0.4002215021355137 accuracy 0.91\n",
      "\n",
      "Epoch 8/8\n",
      "----------\n",
      "Train loss 0.3970792510271072 accuracy 0.9139\n",
      "Val   loss 0.3981388327042768 accuracy 0.9116000000000001\n",
      "\n",
      "CPU times: user 1h 17min 40s, sys: 11.3 s, total: 1h 17min 51s\n",
      "Wall time: 1h 17min 58s\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(), 't5_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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Tk4+Y//XXntN/fr1k7+/v0JDQ3X77bfr2LFjDVQtAABo7LwablavXq2ZM2fqoYce0s6dOxUVFaVRo0YpPT29wv7//ve/NWnSJN1xxx365ptv9NZbb2nbtm268847G7hyAADQWHk13CxYsEB33HGH7rzzTvXq1UsLFy5Ux44dlZCQUGH///znP+rSpYumT5+usLAwXXHFFfr973+v7du3N3DlAACgsfJauMnPz9eOHTsUHR3t0R4dHa0tW7ZUOM/gwYN16NAhrV+/XqZp6n//+5/+/ve/67rrrqt0PXl5ecrJyfF4AAAA6/JauMnKypLT6VRISIhHe0hIiI4cOVLhPIMHD9Zrr72mCRMmyNfXV+3atdN5552nxYsXV7qe+Ph4BQUFuR8dO3as0+0AAACNi9dPKDYMw+O9aZrl2krs3r1b06dP18MPP6wdO3bo/fffV1pammJjYytd/uzZs5Wdne1+HDx4sE7rBwAAjYuPt1bcunVr2e32cqM0mZmZ5UZzSsTHx2vIkCF64IEHJEl9+/ZVQECAoqKiNG/ePIWGhpabx+FwyOFw1P0GAACARslrIze+vr4aMGCAkpKSPNqTkpI0ePDgCuf5+eefZbN5lmy32yUVjfgAAAB49bBUXFycXn75ZSUmJio1NVX33nuv0tPT3YeZZs+erUmTJrn7jxkzRmvXrlVCQoL279+vTz/9VNOnT9dll12m9u3be2szAABAI+K1w1KSNGHCBB07dkxz585VRkaG+vTpo/Xr16tz586SpIyMDI9r3sTExOjEiRNasmSJ7rvvPp133nkaPny4nnrqKW9tAgAAaGQM8xw7npOTk6OgoCBlZ2erZcuW3i4HAABUQ00+v73+aykAAIC6RLgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACW4vVws3TpUoWFhcnPz08DBgxQcnLyGfvn5eXpoYceUufOneVwONS1a1clJiY2ULUAAKCx8/HmylevXq2ZM2dq6dKlGjJkiF588UWNGjVKu3fvVqdOnSqcZ/z48frf//6nZcuWqVu3bsrMzFRhYWEDVw4AABorwzRN01srHzRokC699FIlJCS423r16qWxY8cqPj6+XP/3339fEydO1P79+9WqVatarTMnJ0dBQUHKzs5Wy5Yta107AABoODX5/PbaYan8/Hzt2LFD0dHRHu3R0dHasmVLhfOsW7dOERERevrpp3XBBReoR48euv/++3Xq1KlK15OXl6ecnByPBwAAsC6vHZbKysqS0+lUSEiIR3tISIiOHDlS4Tz79+/Xv//9b/n5+entt99WVlaWpk6dqh9//LHS827i4+P16KOP1nn9AACgcfL6CcWGYXi8N02zXFsJl8slwzD02muv6bLLLtPo0aO1YMECrVixotLRm9mzZys7O9v9OHjwYJ1vAwAAaDy8NnLTunVr2e32cqM0mZmZ5UZzSoSGhuqCCy5QUFCQu61Xr14yTVOHDh1S9+7dy83jcDjkcDjqtngAANBoeW3kxtfXVwMGDFBSUpJHe1JSkgYPHlzhPEOGDNHhw4eVm5vrbvvuu+9ks9nUoUOHeq0XAAA0DV49LBUXF6eXX35ZiYmJSk1N1b333qv09HTFxsZKKjqkNGnSJHf/W265RcHBwbr99tu1e/dubd68WQ888ICmTJmi5s2be2szAABAI+LV69xMmDBBx44d09y5c5WRkaE+ffpo/fr16ty5syQpIyND6enp7v6BgYFKSkrSPffco4iICAUHB2v8+PGaN2+etzYBAAA0Ml69zo03cJ0bAACannq9zk1aWlqtCwMAAKhvNQ433bp107Bhw7Rq1SqdPn26PmoCAACotRqHm127dql///6677771K5dO/3+97/X559/Xh+1AQAA1FiNw02fPn20YMEC/fDDD1q+fLmOHDmiK664Qr1799aCBQt09OjR+qgTAACgWmr9U3AfHx/ddNNNevPNN/XUU09p3759uv/++9WhQwdNmjRJGRkZdVknAABAtdQ63Gzfvl1Tp05VaGioFixYoPvvv1/79u3Txo0b9cMPP+jGG2+syzoBAACqpcbXuVmwYIGWL1+uPXv2aPTo0Vq5cqVGjx4tm60oJ4WFhenFF1/URRddVOfFAgAAVKXG4SYhIUFTpkzR7bffrnbt2lXYp1OnTlq2bNlZFwcAAFBTXMQPAAA0evV6Eb/ly5frrbfeKtf+1ltv6ZVXXqnp4gAAAOpUjcPNk08+qdatW5drb9u2rZ544ok6KQoAAKC2ahxuvv/+e4WFhZVr79y5s8dNLgEAALyhxuGmbdu2+vLLL8u179q1S8HBwXVSFAAAQG3VONxMnDhR06dP18cffyyn0ymn06mNGzdqxowZmjhxYn3UCAAAUG01/in4vHnz9P333+vqq6+Wj0/R7C6XS5MmTeKcGwAA4HW1/in4d999p127dql58+a6+OKL1blz57qurV7wU3AAAJqemnx+13jkpkSPHj3Uo0eP2s4OAABQL2oVbg4dOqR169YpPT1d+fn5HtMWLFhQJ4UBAADURo3DzUcffaQbbrhBYWFh2rNnj/r06aMDBw7INE1deuml9VEjAABAtdX411KzZ8/Wfffdp6+//lp+fn5as2aNDh48qKFDh2rcuHH1USMAAEC11TjcpKamavLkyZIkHx8fnTp1SoGBgZo7d66eeuqpOi8QAACgJmocbgICApSXlydJat++vfbt2+eelpWVVXeVAQAA1EKNz7m5/PLL9emnnyo8PFzXXXed7rvvPn311Vdau3atLr/88vqoEQAAoNpqHG4WLFig3NxcSdKcOXOUm5ur1atXq1u3bnr22WfrvEAAAICaqFG4cTqdOnjwoPr27StJ8vf319KlS+ulMAAAgNqo0Tk3drtdI0eO1PHjx+urHgAAgLNS4xOKL774Yu3fv78+agEAADhrNQ43jz/+uO6//37985//VEZGhnJycjweAAAA3lTjG2fabL/kIcMw3K9N05RhGHI6nXVXXT3gxpkAADQ99XrjzI8//rjWhQEAANS3GoeboUOH1kcdAAAAdaLG4Wbz5s1nnH7llVfWuhgAAICzVeNwc9VVV5VrK33uTWM/5wYAAFhbjX8t9dNPP3k8MjMz9f7772vgwIH64IMP6qNGAACAaqvxyE1QUFC5thEjRsjhcOjee+/Vjh076qQwAACA2qjxyE1l2rRpoz179tTV4gAAAGqlxiM3X375pcd70zSVkZGhJ598Uv369auzwgAAAGqjxuHmkksukWEYKnvtv8svv1yJiYl1VhgAAEBt1DjcpKWleby32Wxq06aN/Pz86qwoAACA2qpxuOncuXN91AEAAFAnanxC8fTp07Vo0aJy7UuWLNHMmTPrpCgAAIDaqnG4WbNmjYYMGVKuffDgwfr73/9eJ0UBAADUVo3DzbFjxyq81k3Lli2VlZVVJ0UBAADUVo3DTbdu3WFmGZoAACAASURBVPT++++Xa3/vvfd04YUX1klRAAAAtVXjE4rj4uJ099136+jRoxo+fLgk6aOPPtL8+fO1cOHCOi8QAACgJmocbqZMmaK8vDw9/vjjeuyxxyRJXbp0UUJCgiZNmlTnBQIAANSEYZa9Gl8NHD16VM2bN1dgYGBd1lSvcnJyFBQUpOzsbLVs2dLb5QAAgGqoyed3rS7iV1hYqO7du6tNmzbu9r1796pZs2bq0qVLjQsGAACoKzU+oTgmJkZbtmwp1/7ZZ58pJiamLmoCAACotRqHm507d1Z4nZvLL79cKSkpdVIUAABAbdU43BiGoRMnTpRrz87OltPprJOiAAAAaqvG4SYqKkrx8fEeQcbpdCo+Pl5XXHFFnRYHAABQUzU+ofjpp5/WlVdeqZ49eyoqKkqSlJycrOzsbH388cd1XiAAAEBN1HjkJjw8XF9++aXGjx+vzMxMnThxQpMmTdJ3332nwsLC+qgRAACg2s7qOjeSdPz4cb322mtKTExUSkpKoz/vhuvcAADQ9NTk87vGIzclNm7cqFtvvVXt27fXkiVLNGrUKG3fvr22iwMAAKgTNTrn5tChQ1qxYoUSExN18uRJjR8/XgUFBVqzZo3Cw8Prq0YAAIBqq/bIzejRoxUeHq7du3dr8eLFOnz4sBYvXlyftQEAANRYtUduPvjgA02fPl1/+MMf1L179/qsCQAAoNaqPXKTnJysEydOKCIiQoMGDdKSJUt09OjR+qwNAACgxqodbiIjI/XSSy8pIyNDv//97/XGG2/oggsukMvlUlJSUoVXLQYAAGhoZ/VT8D179mjZsmV69dVXdfz4cY0YMULr1q2ry/rqHD8FBwCg6WmQn4JLUs+ePfX000/r0KFDev31189mUQAAAHXirMJNCbvdrrFjx9Zq1Gbp0qUKCwuTn5+fBgwYoOTk5GrN9+mnn8rHx0eXXHJJjdcJAACsq07CTW2tXr1aM2fO1EMPPaSdO3cqKipKo0aNUnp6+hnny87O1qRJk3T11Vc3UKUAAKCpOOvbL5yNQYMG6dJLL1VCQoK7rVevXho7dqzi4+MrnW/ixInq3r277Ha73nnnHaWkpFR7nZxzAwBA09Ng59ycjfz8fO3YsUPR0dEe7dHR0dqyZUul8y1fvlz79u3TI488Uq315OXlKScnx+MBAACsy2vhJisrS06nUyEhIR7tISEhOnLkSIXz7N27Vw8++KBee+01+fhU7/qD8fHxCgoKcj86dux41rUDAIDGy6vn3EiSYRge703TLNcmSU6nU7fccoseffRR9ejRo9rLnz17trKzs92PgwcPnnXNAACg8arRjTPrUuvWrWW328uN0mRmZpYbzZGkEydOaPv27dq5c6fuvvtuSZLL5ZJpmvLx8dEHH3yg4cOHl5vP4XDI4XDUz0YAAIBGx2sjN76+vhowYICSkpI82pOSkjR48OBy/Vu2bKmvvvpKKSkp7kdsbKx69uyplJQUDRo0qKFKBwAAjZjXRm4kKS4uTrfddpsiIiIUGRmpv/71r0pPT1dsbKykokNKP/zwg1auXCmbzaY+ffp4zN+2bVv5+fmVawcAAOcur4abCRMm6NixY5o7d64yMjLUp08frV+/Xp07d5YkZWRkVHnNGwAAgNK8ep0bb+A6NwAAND1N4jo3AAAA9YFwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALIVwAwAALMXr4Wbp0qUKCwuTn5+fBgwYoOTk5Er7rl27ViNGjFCbNm3UsmVLRUZGasOGDQ1YLQAAaOy8Gm5Wr16tmTNn6qGHHtLOnTsVFRWlUaNGKT09vcL+mzdv1ogRI7R+/Xrt2LFDw4YN05gxY7Rz584GrhwAADRWhmmaprdWPmjQIF166aVKSEhwt/Xq1Utjx45VfHx8tZbRu3dvTZgwQQ8//HC1+ufk5CgoKEjZ2dlq2bJlreoGAAANqyaf314bucnPz9eOHTsUHR3t0R4dHa0tW7ZUaxkul0snTpxQq1atKu2Tl5ennJwcjwcAALAur4WbrKwsOZ1OhYSEeLSHhIToyJEj1VrG/PnzdfLkSY0fP77SPvHx8QoKCnI/OnbseFZ1AwCAxs3rJxQbhuHx3jTNcm0Vef311zVnzhytXr1abdu2rbTf7NmzlZ2d7X4cPHjwrGsGAACNl4+3Vty6dWvZ7fZyozSZmZnlRnPKWr16te644w699dZbuuaaa87Y1+FwyOFwnHW9AACgafDayI2vr68GDBigpKQkj/akpCQNHjy40vlef/11xcTE6G9/+5uuu+66+i4TAAA0MV4buZGkuLg43XbbbYqIiFBkZKT++te/Kj09XbGxsZKKDin98MMPWrlypaSiYDNp0iQ999xzuvzyy92jPs2bN1dQUJDXtgMAADQeXg03EyZM0LFjxzR37lxlZGSoT58+Wr9+vTp37ixJysjI8LjmzYsvvqjCwkJNmzZN06ZNc7dPnjxZK1asaOjyAQBAI+TV69x4A9e5AQCg6WkS17kBAACoD4QbAABgKYQbAABgKYQbAABgKYQbAABgKYQbAABgKYQbAABgKYQbAABgKYQbAABgKYQbAABgKYQbAABgKYQbAABgKYQbAABgKT7eLqCxcjqdKigo8HYZQJ3z9fWVzcb3GgDWRbgpwzRNHTlyRMePH/d2KUC9sNlsCgsLk6+vr7dLAYB6QbgpoyTYtG3bVv7+/jIMw9slAXXG5XLp8OHDysjIUKdOnfj7BmBJhJtSnE6nO9gEBwd7uxygXrRp00aHDx9WYWGhmjVr5u1yAKDOceC9lJJzbPz9/b1cCVB/Sg5HOZ1OL1cCAPWDcFMBhuphZfx9A7A6wg0q1KVLFy1cuNDbZQAAUGOcc2MRV111lS655JI6CyTbtm1TQEBAnSwLAICGRLg5h5imKafTKR+fqv/Z27Rp0wAVNayabD8AoOnisJQFxMTEaNOmTXruuedkGIYMw9CBAwf0ySefyDAMbdiwQREREXI4HEpOTta+fft04403KiQkRIGBgRo4cKA+/PBDj2WWPSxlGIZefvll3XTTTfL391f37t21bt26M9a1atUqRUREqEWLFmrXrp1uueUWZWZmevT55ptvdN1116lly5Zq0aKFoqKitG/fPvf0xMRE9e7dWw6HQ6Ghobr77rslSQcOHJBhGEpJSXH3PX78uAzD0CeffCJJZ7X9eXl5mjVrljp27CiHw6Hu3btr2bJlMk1T3bp10zPPPOPR/+uvv5bNZvOoHQDgHYSbKpimqZ/zC73yME2zWjU+99xzioyM1F133aWMjAxlZGSoY8eO7umzZs1SfHy8UlNT1bdvX+Xm5mr06NH68MMPtXPnTo0cOVJjxoxRenr6Gdfz6KOPavz48fryyy81evRo/fa3v9WPP/5Yaf/8/Hw99thj2rVrl9555x2lpaUpJibGPf2HH37QlVdeKT8/P23cuFE7duzQlClTVFhYKElKSEjQtGnT9Lvf/U5fffWV1q1bp27dulVrn5RWm+2fNGmS3njjDS1atEipqal64YUXFBgYKMMwNGXKFC1fvtxjHYmJiYqKilLXrl1rXB8AoG4xPl+FUwVOhT+8wSvr3j13pPx9q/4nCgoKkq+vr/z9/dWuXbty0+fOnasRI0a43wcHB6tfv37u9/PmzdPbb7+tdevWuUdGKhITE6Obb75ZkvTEE09o8eLF+vzzz3XttddW2H/KlCnu1xdeeKEWLVqkyy67TLm5uQoMDNTzzz+voKAgvfHGG+7rrfTo0cOjrvvuu08zZsxwtw0cOLCq3VFOTbf/u+++05tvvqmkpCRdc8017vpL3H777Xr44Yf1+eef67LLLlNBQYFWrVqlv/zlLzWuDQBQ9xi5OQdERER4vD958qRmzZql8PBwnXfeeQoMDNS3335b5chN37593a8DAgLUokWLcoeZStu5c6duvPFGde7cWS1atNBVV10lSe71pKSkKCoqqsILyWVmZurw4cO6+uqrq7uZlarp9qekpMhut2vo0KEVLi80NFTXXXedEhMTJUn//Oc/dfr0aY0bN+6sawUAnD1GbqrQvJldu+eO9Nq660LZXz098MAD2rBhg5555hl169ZNzZs3129+8xvl5+efcTllQ4hhGHK5XBX2PXnypKKjoxUdHa1Vq1apTZs2Sk9P18iRI93rad68eaXrOtM0Se4bP5Y+dFfZjU5ruv1VrVuS7rzzTt1222169tlntXz5ck2YMIGLPwJAI0G4qYJhGNU6NORtvr6+1b7ibHJysmJiYnTTTTdJknJzc3XgwIE6refbb79VVlaWnnzySff5P9u3b/fo07dvX73yyisqKCgoF5xatGihLl266KOPPtKwYcPKLb/k11wZGRnq37+/JHmcXHwmVW3/xRdfLJfLpU2bNrkPS5U1evRoBQQEKCEhQe+99542b95crXUDAOofh6UsokuXLvrss8904MABZWVlVTqiIkndunXT2rVrlZKSol27dumWW245Y//a6NSpk3x9fbV48WLt379f69at02OPPebR5+6771ZOTo4mTpyo7du3a+/evXr11Ve1Z88eSdKcOXM0f/58LVq0SHv37tUXX3yhxYsXSyoaXbn88sv15JNPavfu3dq8ebP+/Oc/V6u2qra/S5cumjx5sqZMmeI+EfqTTz7Rm2++6e5jt9sVExOj2bNnq1u3boqMjDzbXQYAqCOEG4u4//77ZbfbFR4e7j4EVJlnn31W559/vgYPHqwxY8Zo5MiRuvTSS+u0njZt2mjFihV66623FB4erieffLLcz6eDg4O1ceNG5ebmaujQoRowYIBeeukl9yjO5MmTtXDhQi1dulS9e/fW9ddfr71797rnT0xMVEFBgSIiIjRjxgzNmzevWrVVZ/sTEhL0m9/8RlOnTtVFF12ku+66SydPnvToc8cddyg/P9/jxGkAgPcZZnV/b2wROTk5CgoKUnZ2tlq2bOkx7fTp00pLS1NYWJj8/Py8VCGaik8//VRXXXWVDh06pJCQEG+XU238nQNois70+V1W4z+ZBGhk8vLydPDgQf3f//2fxo8f36SCDQCcCzgsBdTQ66+/rp49eyo7O1tPP/20t8sBAJRBuAFqKCYmRk6nUzt27NAFF1zg7XIAAGUQbgAAgKUQbgAAgKUQbgAAgKUQbgAAgKUQbgAAgKUQbgAAgKUQbuDWpUsXLVy40P3eMAy98847lfY/cOCADMOo9g0r63s5AABIXKEYZ5CRkaHzzz+/TpcZExOj48ePe4Smjh07KiMjQ61bt67TdQEAzk2EG1SqXbt2DbIeu93eYOtqbAoKCtw3CgUA1A0OS1nAiy++qAsuuEAul8uj/YYbbtDkyZMlSfv27dONN96okJAQBQYGauDAgfrwww/PuNyyh6U+//xz9e/fX35+foqIiNDOnTs9+judTt1xxx0KCwtT8+bN1bNnTz333HPu6XPmzNErr7yif/zjHzIMQ4Zh6JNPPqnwsNSmTZt02WWXyeFwKDQ0VA8++KAKCwvd06+66ipNnz5ds2bNUqtWrdSuXTvNmTPnjNuzbds2jRgxQq1bt1ZQUJCGDh2qL774wqPP8ePH9bvf/U4hISHy8/NTnz599M9//tM9/dNPP9XQoUPl7++v888/XyNHjtRPP/0kqfxhPUm65JJLPOoyDEMvvPCCbrzxRgUEBGjevHlV7rcSiYmJ6t27t3uf3H333ZKkKVOm6Prrr/foW1hYqHbt2ikxMfGM+wQArIiRm6qYplTws3fW3cxfMowqu40bN07Tp0/Xxx9/rKuvvlqS9NNPP2nDhg169913JUm5ubkaPXq05s2bJz8/P73yyisaM2aM9uzZo06dOlW5jpMnT+r666/X8OHDtWrVKqWlpWnGjBkefVwulzp06KA333xTrVu31pYtW/S73/1OoaGhGj9+vO6//36lpqYqJydHy5cvlyS1atVKhw8f9ljODz/8oNGjRysmJkYrV67Ut99+q7vuukt+fn4eQeGVV15RXFycPvvsM23dulUxMTEaMmSIRowYUeE2nDhxQpMnT9aiRYskSfPnz9fo0aO1d+9etWjRQi6XS6NGjdKJEye0atUqde3aVbt375bdbpckpaSk6Oqrr9aUKVO0aNEi+fj46OOPP5bT6axy/5X2yCOPKD4+Xs8++6zsdnuV+02SEhISFBcXpyeffFKjRo1Sdna2Pv30U0nSnXfeqSuvvFIZGRkKDQ2VJK1fv165ubnu+QHgXEK4qUrBz9IT7b2z7j8dlnwDquzWqlUrXXvttfrb3/7mDjdvvfWWWrVq5X7fr18/9evXzz3PvHnz9Pbbb2vdunXuEYAzee211+R0OpWYmCh/f3/17t1bhw4d0h/+8Ad3n2bNmunRRx91vw8LC9OWLVv05ptvavz48QoMDFTz5s2Vl5d3xsNQS5cuVceOHbVkyRIZhqGLLrpIhw8f1h//+Ec9/PDDstmKBhz79u2rRx55RJLUvXt3LVmyRB999FGl4Wb48OEe71988UWdf/752rRpk66//np9+OGH+vzzz5WamqoePXpIki688EJ3/6effloRERFaunSpu613795V7ruybrnlFk2ZMsWj7Uz7TSr697rvvvs8AuXAgQMlSYMHD1bPnj316quvatasWZKk5cuXa9y4cQoMDKxxfQDQ1HFYyiJ++9vfas2aNcrLy5NUFEYmTpzoHnU4efKkZs2apfDwcJ133nkKDAzUt99+q/T09GotPzU1Vf369ZO/v7+7LTIysly/F154QREREWrTpo0CAwP10ksvVXsdpdcVGRkpo9So1ZAhQ5Sbm6tDhw652/r27esxX2hoqDIzMytdbmZmpmJjY9WjRw8FBQUpKChIubm57vpSUlLUoUMHd7Apq2Tk5mxFRESUazvTfsvMzNThw4fPuO4777zTPRqWmZmpf/3rX+UCFACcKxi5qUoz/6IRFG+tu5rGjBkjl8ulf/3rXxo4cKCSk5O1YMEC9/QHHnhAGzZs0DPPPKNu3bqpefPm+s1vfqP8/PxqLd80zSr7vPnmm7r33ns1f/58RUZGqkWLFvrLX/6izz77rNrbUbIuo8zhuJL1l24veyKuYRjlzjsqLSYmRkePHtXChQvVuXNnORwORUZGuvdB8+bNz1hXVdNtNlu5/VRQUFCuX0CA52hcVfutqvVK0qRJk/Tggw9q69at2rp1q7p06aKoqKgq5wMAKyLcVMUwqnVoyNuaN2+uX/3qV3rttdf03//+Vz169NCAAQPc05OTkxUTE6ObbrpJUtE5OAcOHKj28sPDw/Xqq6/q1KlT7g/b//znPx59kpOTNXjwYE2dOtXdtm/fPo8+vr6+VZ6jEh4erjVr1niEnC1btqhFixa64IILql1zWcnJyVq6dKlGjx4tSTp48KCysrLc0/v27atDhw7pu+++q3D0pm/fvvroo488DiGV1qZNG2VkZLjf5+TkKC0trVp1nWm/tWjRQl26dNFHH32kYcOGVbiM4OBgjR07VsuXL9fWrVt1++23V7leALAqDktZyG9/+1v961//UmJiom699VaPad26ddPatWuVkpKiXbt26ZZbbjnjKEdZt9xyi2w2m+644w7t3r1b69ev1zPPPFNuHdu3b9eG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CxUdHa2TJ096u7QG06FDBz355JPavn27tm/fruHDh+vGG2/UN9984+3SGty2bdv017/+VX379vV2KQ2ud+/eysjIcD+++uorb5fUYH766ScNGTJEzZo103vvvafdu3dr/vz59X5F/MZk27ZtHv/+SUlJkqRx48Y1fDEmztpll11mxsbGerRddNFF5oMPPuilirxHkvn22297uwyvyszMNCWZmzZt8nYpXnX++eebL7/8srfLaFAnTpwwu3fvbiYlJZlDhw41Z8yY4e2SGswjjzxi9uvXz9tleM0f//hH84orrvB2GY3KjBkzzK5du5oul6vB183IzVnKz8/Xjh07FB0d7dEeHR2tLVu2eKkqeFN2drYkqVWrVl6uxDucTqfeeOMNnTx5UpGRkd4up0FNmzZN1113na655hpvl+IVe/fuVfv27RUWFqaJEydq//793i6pwaxb9zdTEAAAB41JREFUt04REREaN26c2rZtq/79++ull17ydllek5+fr1WrVmnKlCl1fpPq6iDcnKWsrCw5nc5ydzIPCQkpdwdzWJ9pmoqLi9MVV1yhPn36eLucBvXVV18pMDBQDodDsbGxevvttxUeHu7tshrMG2+8oS+++ELx8fHeLsUrBg0apJUrV2rDhg166aWXdOTIEQ0ePFjHjh3zdmkNYv/+/UpISFD37t21YcMGxcbGavr06Vq5cqW3S/OKd955R8ePH1dMTIxX1u/12y9YRdlkapqmV9IqvOvuu+/Wl19+qX//+9/eLqXB9ezZUykpKTp+/LjWrFmjyZMna9OmTedEwDl48KBmzJihDz74QH5+ft4uxytGjRrlfn3xxRcrMjJSXbt21SuvvKK4uDgvVtYwXC6XIiIi9MQTT0iS+vfvr2+++UYJCQkeN4A+VyxbtkyjRo1S+/btvbJ+Rm7OUuvWrWW328uN0mRmZpYbzYG13XPPPVq3bp0+/vhjdejQwdvlNDhfX19169ZNERERio+PV79+/fTcc895u6wGsWPHDmVmZmrAgAHy8fGRj4+PNm3apEWLFsnHx0dOp9PbJTa4gIAAXXzxxdq7d6+3S2kQoaGh5YJ8r169zpkflpT2/fff68MPP9Sdd97ptRoIN2fJ19dXA/6/vXsJbWKNowB+pg9DMgRJW2tTsLXgo1RR0IikdaPZJIqgVioSy4iLEm2LKF35wCriUlcSGNCsKoWAj4rY2vrYFKRuRkOJFUFwIaWKCxvFbPK/i3IDQ7ze66XOl47nBwPzyKTngy4OM99ktm4tzgr/2/j4ONrb2xWlIieJCPr6+nD79m08efIELS0tqiOVBRFBPp9XHcMRkUgEmUwGlmUVl1AohHg8DsuyUFlZqTqi4/L5PLLZLILBoOoojujo6Cj5CYg3b96gublZUSJ1UqkU6uvrsWfPHmUZeFtqEZw+fRrd3d0IhUIIh8MwTRPv379HIpFQHc0RuVwOb9++LW6/e/cOlmWhpqYGTU1NCpM5o7e3F7du3cK9e/fg9/uLV/GWL18Or9erOJ0zzpw5g1gshlWrVmF+fh7Dw8N49uwZRkdHVUdzhN/vL5ljpes6amtr/5i5VwMDA9i7dy+ampowNzeHy5cv48uXLzAMQ3U0R5w6dQrt7e24cuUKurq6MDU1BdM0YZqm6miOKhQKSKVSMAwDVVUKK4bjz2e51PXr16W5uVmWLVsmW7Zs+aMeA3769KkAKFkMw1AdzRE/GjsASaVSqqM55tixY8X//xUrVkgkEpFHjx6pjqXUn/Yo+KFDhyQYDEp1dbU0NjbKgQMHZHp6WnUsR92/f182btwoHo9HWltbxTRN1ZEcNzY2JgBkZmZGaQ5NRERNrSIiIiJafJxzQ0RERK7CckNERESuwnJDRERErsJyQ0RERK7CckNERESuwnJDRERErsJyQ0RERK7CckNEhIWX3969e1d1DCJaBCw3RKTc0aNHoWlayRKNRlVHI6IliO+WIqKyEI1GkUqlbPs8Ho+iNES0lPHKDRGVBY/Hg4aGBtsSCAQALNwySiaTiMVi8Hq9aGlpQTqdtp2fyWSwa9cueL1e1NbWoqenB7lczvaZmzdvYsOGDfB4PAgGg+jr67Md//TpE/bv3w+fz4e1a9diZGTk9w6aiH4LlhsiWhLOnz+Pzs5OvHz5EkeOHMHhw4eRzWYBAN++fUM0GkUgEMCLFy+QTqcxMTFhKy/JZBK9vb3o6elBJpPByMgI1qxZY/sbFy9eRFdXF169eoXdu3cjHo/j8+fPjo6TiBaB0td2EhGJiGEYUllZKbqu25ZLly6JyMKb1xOJhO2c7du3y/Hjx0VExDRNCQQCksvliscfPHggFRUVMjs7KyIijY2Ncvbs2X/MAEDOnTtX3M7lcqJpmjx8+HDRxklEzuCcGyIqCzt37kQymbTtq6mpKa6Hw2HbsXA4DMuyAADZbBabN2+GruvF4x0dHSgUCpiZmYGmafjw4QMikchPM2zatKm4rus6/H4/5ubm/veYiEgNlhsiKgu6rpfcJvo3mqYBAESkuP6jz3i93v/0fdXV1SXnFgqFX8pEROpxzg0RLQnPnz8v2W5tbQUAtLW1wbIsfP36tXh8cnISFRUVWLduHfx+P1avXo3Hjx87mpmI1OCVGyIqC/l8HrOzs7Z9VVVVqKurAwCk02mEQiHs2LEDQ0NDmJqawo0bNwAA8XgcFy5cgGEYGBwcxMePH9Hf34/u7m6sXLkSADA4OIhEIoH6+nrEYjHMz89jcnIS/f39zg6UiH47lhsiKgujo6MIBoO2fevXr8fr168BLDzJNDw8jBMnTqChoQFDQ0Noa2sDAPh8PoyNjeHkyZPYtm0bfD4fOjs7cfXq1eJ3GYaB79+/49q1axgYGEBdXR0OHjzo3ACJyDGaiIjqEEREP6NpGu7cuYN9+/apjkJESwDn3BAREZGrsNwQERGRq3DODRGVPd49J6JfwSs3RERE5CosN0REROQqLDdERETkKiw3RERE5CosN0REROQqLDdERETkKiw3RERE5CosN0REROQqLDdERETkKn8BN0smQfm5QBsAAAAASUVORK5CYII=",
      "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.9104000000000001\n",
      "F1-Macro:  0.9075946324606036\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+naQAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nOzdaWBU5eH+/WuSzGSfbEAxIBjCJhA2BQkoqCj4U1AEq1hAZFMB0UJprcsjWqkgalWwlUVQwFbEShFXQFGxyqKyyCZLiARZskDIvsxk5v+Cx8g0E0wmyZzk8P28Ivc5Z+aagM4199znHIvb7XYLAAAAMJkAowMAAAAAdYGiCwAAAFOi6AIAAMCUKLoAAAAwJYouAAAATImiCwAAAFOi6AIAAMCUgowOUJ9s375dbrdbVqvV6CgAAADwwuFwyGKxqFu3br+6L0X3HG63W9w/AwAAoP6qTlej6J7j55ncpKQkg5MAAADAm127dlV5X9boAgAAwJQougAAADAlii4AAABMiaILAAAAU6LoAgAAwJQougAAADAlii4AAABMiaILAAAAU6LoAgAAwJQougAAADAlii4AAABMiaILAAAAU6LoAgAAwJQougAAADAlii4AAABMiaILAAAAU6LoAgAAwJQougAAADClIKMDoP5LSUnR8uXL9eOPP6p9+/YaOXKkmjdvbnQsAACA86Lo4ry2bdumMWPGqLi4WJK0adMmrVq1Sm+++aYSExMNTgcAgPHKysq0ceNGffPNN4qJidGgQYN00UUXGR0LouiahtvtVklJSa0/7nPPPVdecn+Wk5Ojl156SXPmzCl/bkmyWCy1/vxVERwcbNhzAwAubA6HQ1OnTtXmzZvLx15//XXNmTNHffr0qfbjHTp0SCtWrFBaWpratGmjO++8k29Ra8Di/rmlQLt27ZIkJSUlGZyketxut5588kkdOHCg1h9327ZtXrcFBQWpS5cukiSXyyWLxWJY2Wzbtq1mzJhB2QUA+KQmk0Xvv/++Zs+eXWH8N7/5jVauXKnAwMBffW7p7GTRjh07NG3aNJWWlpZvj4iI0D/+8Q+1atXKp3y/piFOFlWnrzGji0pZLBYFBQXJ6XRW2Ga1WnXmzBkdO3ZMxcXFCgoKUpMmTdS0adMG9x8MAODCVdPJomPHjnkdT09P16hRoxQSElLlx0pLS/MouZKUn5+vSZMmKT4+3qd8v8bsk0UUXROwWCyaMWNGnSxdmD9/vl555ZUK47/97W/1xhtvyOVySZKcTqeOHz+uW2+9Vffcc0+t5zifhvhpFABgDgEBlV/AKiAgQC6XS06nU1ar9bzvVW63u8JSwZ8VFRXVOOeFiqUL52ioSxfqUllZmZ555hmtWLFCJSUlCg8P19ixY7Vnzx5t2LChwv7R0dH66quvFBTEZygAQMNQk6ULW7du1bRp0yqMd+jQQe3atdMHH3yg0tJSxcXFacKECRo0aJAkqbS0VOvWrdP8+fMVFBSkhQsXavz48Tp9+nSFx2rXrp0WL17sU75f0xAni6rT1yi656DoVi43N1cnT55Us2bNFB4erkGDBungwYNe9920aZNiY2P9nBAAAGO8+uqrWrx4sRwOhySpVatW6tChg95///0K+86dO1dJSUm69957PZZL2O12DRgwQP/+978rHPP444/r5ptvrrsX0MCwRhe1zm63y263l//coUMHr0W3WbNmio6O9mc0AAAMNX78eA0dOlTbt29XbGys2rdvrwEDBnjdd+XKldqxY0eFNcG5ubk6ePCgRo0apbffflvFxcWKjIzUXXfdRcmtAYoufDJhwgStX79ehYWFHuP333//edcrAQBgRrGxserfv78kKSsrq9J1tRkZGcrIyPC6befOnXrxxRc1fvx4ZWZmqmnTptU6mQ0V0UjgkzZt2ujNN9/UgAEDZLPZFBERoZdeeklDhw41OhoAAIaKi4vTxRdf7HVbly5dKi2vQUFBslqtCg8P1yWXXELJrQUUXfisffv2evbZZ5WUlKR27drp6quvNjoSAACGs1gsXr/hjIuL0+jRo3XjjTd6Pe6aa66h3NYyli7AZwUFBfrwww+VkZHhsX4XAIALXf/+/bVo0SKtXLlSJ0+eVKdOnXTnnXeqadOmGjp0qPbv36933323/DKdSUlJeuihhwxObT5cdeEcXHWh6r799ltNmjRJOTk55WMTJkzQ9OnTDUwFAEDDkZKSot///vcKCgrSm2++yWxuFVWnr7F0AdXmdDo1bdo0j5IrSYsWLdI333xjUCoAABqOkydPatWqVcrOztaZM2e0e/duoyOZEkUX1bZt2zalp6d73fbhhx9Kks6cOaNNmzYpNTXVY3txcbEWLVqk4cOHa9SoUVq5cmX5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Lnxy++2364knnqgwHhMTwy2ATay2yoc3hw8f9jqekZGhUaNGKTQ0tFafr7CwUHl5eQoMDFR0dHSV1mRSPhqWwsJCHTlypPznkpISHT9+XC6XS7GxsZKksrKySo93Op06cuSIxwe7U6dOqbi4WC1btqy74ABqDUUXPrnjjjv07bff6v333y8fCw8P5xbA8FlgYGCl2wICAnT69GkVFhbKZrMpNjbWo5gWFhbq5MmTKigokM1mU6NGjc77lfNPP/2kU6dOlf984sQJJSQkKCIionZeDGrMYrFoxowZNfr24Nx1t+dyu9169dVXFRAQoBMnTmjYsGFyuVwV9gsICPD6/AUFBZo6daqSkpJ8zvZr+PYAqB0UXfgkICBAzz//vNq0aaN3331XNptNERERGjJkCLcANrHaKB+V+eabb3TfffdVGO/Zs6dycnJ09OjR8rH8/HzNnz9f7du3V0pKiu666y4VFxdLOvuV808//aRbb71Vd999d4XH27hxo6ZOneox5nK5lJ+frzfffPO8hZvy4V8Wi0UhISFV2jc/P19r167VqVOn1L17d11++eVKTU31um96erqcTqfsdrsSEhI0duxYvfrqqx77REVFlS+V8SYtLU09evSo+osBYAiKLmpkzJgx2rVrl7KzsxUTE8MtgC8A1Skf1XHVVVfp0Ucf1dy5c5WXlydJ6tWrl9q0aaPly5d77JuXl6fnn39ey5cv14oVK8pL7rmWLVumsWPHymazeYx//vnnXp8/PT1dBw8eVNeuXWvnBcFvdu/ercmTJysnJ6d8rH///rrkkks8li78rEmTJh6z9/fff78uv/xyffTRR3I4HLryyiu1fPly5ebmVvqcrVq1knR2OcTHH3+s/fv3q0WLFrrpppsUGRlZi68OQE1QdFEjP98CeOnSpRo9ejS3AEaN/O53v9OQIUO0b98+xcXF6ZJLLtHQoUO97rtt2zbl5ubq0KFDXrfn5OQoMzOzwkmRv7ZEAg3PE0884VFyJenTTz/VuHHj9NVXX8npdHpsu+qqq3TffffpxIkT6ty5s8aNG6devXqpV69ekqRDhw4pNzdXQUFBatGihdLS0jyO7969u7p166bTp09r/PjxHuvLFy9erFdffZU1vEA9QdFFjV122WW67LLLjI6Beu7IkSOaN2+eNm/erOjoaN1222266667KpTLsLAwj39PlZ2EFhQUJKvVqlatWun777+vsN1ut6tRo0blP5eVlamkpEQ33HCDVq1aVWH/iy++WJ06dfL15ZmSPy7vVVNpaWmVftjZt2+fXnzxRb366qvat2+fLrroInXo0EHvvPNO+T5Hjx7VF198oSVLlqh58+Z65plntGbNmvJlC23bttV1112nr7/+WlarVddff70mTpyo4uJizZ8/v8JJlJmZmZozZ46ef/75unvRfsAyHZgFRRdAncvMzNSoUaPKTwDLzs7Ws88+qxMnTujhhx+WdLZU/fjjjwoPD1eTJk3Kj73lllu0Y8eOCo95/fXXKzQ0VHfddZc++uijCoXsrv/X3p2HNXUlbAB/Q0JCZEdABVSQTasgKIqouI5a56MdrbYu1aql06qjduzoiHYRlxm76GBrdVyrra1bnVpHa4sLXdzQtq4UXFiURdkM+5btfn8wpMYEAYuErV2RNgAAIABJREFUpO/vefo8zbnn3pyEa/Lm3HPPeeEFyGQyKJVKrF27Fv/5z39QXl6OHj164Mknn0R8fLwuzDg5OeHdd99lj+4Dampq8OKLL5q6GQ+lVCrr3XblyhUUFxcDAHx9fSEIAo4ePWpQr7y8HC+//DJsbGyQm5urt+3GjRvIzc2Ft7c3ACA5ORlz584FANy8edPo854+fdrsb8r96KOPHssQJaKWxqBLZGbMoZftQbt379ab5aDO3r17MX36dKSkpOCdd95BdnY2RCIR+vXrh9jYWLi6uiIqKgpJSUk4cOCA7s74oKAgBAYG4rnnnkNFRQUGDx6M/Px8pKSkwN3dHRMmTMCkSZNQXV2N5cuX4+DBg7rnTEpKws2bN/H+++8jJycH9vb2GDJkCORyudGxvq0Je9kMSaVS2NjYGP3bOTo66j1Wq9UGwxjqVFdX1/vvqrS0FFqt1uCH0MPmEyei1oFBl8jMmEMv24OMTfEE1K5K9eKLLyIrK0vXuyoIAs6ePYuxY8fC399fVzcgIABVVVWQSqW4e/cu1q5dq3d8mUwGf39/iMViHDt2DMeOHYNarTZYhAKofQ+XLVsGLy8vAMDnn3/ejK/28TFlL1vf4dMhFlub5Lkb0k2Rh28ObEJFWZGuzLdrbzzRMxJObdtBKq19zzRqNW7ffhNKpWEobu8VgNLi2oUljAkb8gJkNvrDaNr8eBw/nf7KoK5/93D0/8OE3/KSTEKjUeH8iR2mbgZRs2LQJaLH7mE3KVZUVBidxqmyshJVVVW6MboymQwymQwqlQqFhYUG9WtqalBUVKQ3LlepVNY7RdTDLnmTIbHYGmJJ6wy6bd29MPGlpchM/wXlpQrkZF5H+vWLSLv2M6ylNggJH4HQ8FEQS6zxROggXDqnP3xBJLJCcNhwZN1KgaLwjsHx23v5oo2dg+5xYV4WMm5ehkgkQkef7sjK+EW3rUNHf/QfOq7VvldEvzcMukRmbEV4B0jFrf8yaUG5M2btVaBcqX/Z+MluXtAKAo4ajmoAAEz1c0CQhzOu3imCVGKF7u2d8XNWIZYadtICALrbA6/1/3VVviqVGs/fSkelynD1q6gAd0zr2/pX8FNqBLx57q6pm9HqicUS+Pj3xKnje5GZlqQrVymr8ePJQ7B3bAu/rmHoMzAKYrEESRe/R01VBZzbdkCfyKfQ3ssXLm4eyExPwr38bN3+Mrkt+g97Vvf4x1OHcDEx/r5nFqFXxGg4tW0HRyc3uLXnbAtErQmDLpEZk4pFkIlb/w1UXo62WPtMBLacvYafswrhYCPF/3XviBfC/HHseg6OXssx2EcqtkJRZTWe/+RbVPwvILezl2PmgG4PfZ773w+ZWIpJvX2xLVF/yWKXNjKMC/Y2i/cOMFyxi4zTqFW4kXTO6LZrl8/Ar2sYMtN/QWFeFpxc2sHDyx/BfYZDZtMGACCVyRExdBxuJp+HSlkN9w4+COjeFzby2jl37+VnPxByAUDApfPHMPnl5Whj6wAial0YdInosVOqNTiVnoc7JZVwt5Mj0rc9ngvpAonYCsMDPXDol0yk5BXr7fOnoE54/4dfoNH+OvQgr6wK608mo08nV/yYqT98wU4mwR+f6KhXlpxbBI1WwB8CPJBdXIGyGhVCPNtiSpgf2tryjnJLo1IpoVYbH5JSVVmGS+eP4fwPv96YmJeTjlupVzDm+QUQICD+wCbczfp1JoWa6kp0Cx6ge3w77arRY2s1amRlJCOwR79meiVE1FwYdInosVv69QUk3s7XPd57MR0Xs+9hw7P9IRWLsWZMOA4lZeJ8ZgHaWEswupsXbhSU6IXcOoUV1Zgb+QTc7OQ4fj0HSo0WwR4umD3wCb3wujrhCr5K/nXZYJnECstH90bfzu4Gx6SGadQqUzehQdbWUri4eUJRYHiFwN3DGxfOfm1QXnTvLlKunEJpcaFeyAWAnNvX8dPpw+gbWbvi48NmUxBBZBbv0cOYe/uJjGHQJTJjSk3rv6x9Pa9YL+TWuVFQgu/ScjGwS3tYWVnh/7p3wp+CvXXbf86uZ+AugBqNFvMG98CsgU9ArdVCbi3RlQPA+dv5eiEXAGrUWrx94gp2ThkCiVkMWahlyr/x/TfynU/YYbJ2NIWdXIwikUiv7RKJBOWKTKhVxnt7ky+cQEVFhdFtKZdPQlOVB6D+GxitrKxwN+M88jN//o2tbz3qu4mTyNww6BKZmfu/gN48l/uQmq2Dsflz62y5dAe7U0tx9+5dVFZWQiwWw9XVFe3atUN5ufHeM5FIhIN3VPgq3/Du+DpZWVlGy4sqa/DqiVTY2dk17UW0EgwfDbOzs0OXLl2gUCigUqkgl8vh7Oysm4PZGIlEUu97KwgCBEFARUUFlEol2rZtC4VCoatvZWUFLy+vhy4tTUSmw6BLRI+VVCqtd5tIJEJ6erouNGg0GuTl5UGr1cLDwwPOzs4oKirS28fDwwMSif5HV0VFBcrKymBlZQVnZ+eHX2LmZP6Ndv971XfYdLOfMqv6wCZk376mV2YlFmNo1Mu4/ONxpKb8ZLCPj38IChQFKMzL1JW5deiMwB79IJXK0dG7GyTW9Z/j5kSjVul67vnvhCwFgy6Rmbn/C2hFeHtIW/lleEEQMO8/93CzoESvvJ29HN0dxMjNNexJKy1SYNPTIZBHdMDPWYU4nZGHwvJq2MkkCHR3wPAAV9jb1IaLdd8n4avUX3twC/PzMKm3Lz4x0pPczl6OD/7gBysz+hJXarS6nntThg+xpPXOo9tYw596ESeP7kbGzcsQBC0cnd0QMXQ82rp7od/gsSjIvY2SogJdfSeXdoDISi/kAkDB3dto7+GLiKHPtPRLIKImYtAlMmNSsZVZTJH13tN9seFUMr5NvQuNVsAAH3fMHvgEVh2/bLR+jVqDsmolnOV2CPF0wSfnb+LG/4LytzfvYvfPaVgzJhxFlTUGY3FVGi2+vHwLz/f2xe4Laai7n81JLsVbo0Ihl/AS8++VzKYN/vB0NKqrKqCsqYK9Y1vdj4c2do4YN20JMm5cRNG9XLi4esAnIAQ7Nyw2eqz06xcYdInMAIMuET12jnIpFo8IwaI/9IQgAGKr2nDh5+qAK3cUBvUdZNZob1+7Itrei+m6kFunpFqJD374BT5t7Y0+X2mNCsEebRHVvRN+yiqEncwaEd7ukDHkEmoXl8i5fQ3Finy0dfNAl8BekFhLIZFYw/+Jvnp1hXrG9mqF1n8jKBEx6BJRC7ISiYD7rr6PD/HBses5KKvRn9ZoUm9fSP8XSs9mGM7YAABX7ijg7VL/TWXWYhHaO7RBVPdOv73hZDFKiwtxeO/7KC/7dez3xfPH8NSEV3ULPtRUV0JRcAd2Ds7wCQjBjV8MF6Hw8Q9psTYT0aNj0CUik+ng0AYfju+PT368iat3FHCUS+HjYg8rkQjZxRXwcrKtdwyy2EqEIX4d8N+kTINtbnY2CPZwedzNJzN07oeDeiEXAEoUefj5zBFEjpiIn04dxuWfTvxvTlkROvp0g5NLOxQr8nT127p7IWzA/7Vwy4noUTDoEpFJdXK2wxsjQ3EyLRcrj17EzYJS4HoONp5OwYv9AjCiqyeSH1g1DQAiu7RHqJcrXo7oim3nrusWl3CSS7F0VC+IrVr/2GVqeZn1rG52O/UK2nt2wYXEb+4rFXQrnoUNjEKxIg8urh7o1KUHrHh+EZkFBl0iMrlKpRpvH7+stziCAGBb4g1snjAQo7t54ZuUbNTNz9CtnRNeHdwdQO0whxGBnvgxswBtpBJEeLvrhj3Q75tWq0FudhoAoL2nL6zEYogl1tBo1AZ1xRIprl05Y/Q4qdd+xoA/TECXgNDH2l4ian4MukRmTKkRAJj/TTFnbuWhUmUYPgAg4eZdvDokCP192uHsrTx0drbH00GdIRKJdCuh2culGBboCaA2INeYwYpxjVX7N6amupuVioSvdqCivPZqgLyNPYb+8QX4deuD5Es/GNT3f6IPbt00PguIRq2CWqWExMynVyP6PWLQJTJjb567a+omNIviYsOhCXVOZJUiPiNRb+GIHRduwcfHB9bWDB5kSKmsRvyXm6CsqdKVVVWW4ejBLXh2+hsoUeQhJ/O6bltnv2CEho+ESlkDRaHhinuu7TrCRm6L0uJCXE9KRFVlKTp4+aNLYCjE4tqv0WJFHq78dAL38nPg6OyOoN5D4daeN0ISmRqDLhGZnL29PaysrOpdpvXB1dGqqqqQk5MDb2/vFmgdAYBGo2q4UiuRfv2CXsito1YpcTvtCp58ZiYK8jJRdC8Prm6ecHHzAAAE9RqCW6mXUVby62IjEokUfSP/hFs3L+PE4e26YQ/XrpxB8uWTeHLsK7UzOez7ACplDQCgIPc20q9fwKgxL8OjU0ALvOLmYU5/Y6LGYtAlMjMymQwfffSRqZvR7H744QcsXrwY1dXVAAArKyvMmTMHCQkJKCgoMKhfXl6O9evXQy6Xt3RTTUYmk5nsuc+f2GGy524qhcJwbuY6qUk/ICPlNAoLC6FSqSCVSuHm5gZHR0cAgEd7VxTJxKiuroa1tTWcnZ2R8csJpKamGoztzctJR/z+OFRWVupCbh2tVoPvvt4BHx+f5n+BRNRoDLpEZkYkEsHGxsbUzWh2I0eORN++fXH8+HHU1NRgyJAh8PT0xNGjR43W12g0kEgkFvle0G9ja2tb7zatVov8/F/nZlYqlcjJyYGVlRXs7e2h1Wqh0WigVqshEomg0Wig1WqhUhnv7SwvL9f9OHtQVVUVBEEw6dLNRL93DLpE1Go4OTlh/PjxemXDhg3DtWvXDOr26dMH9vbGV0aj5mHOVw/+/e9/4+OPP9YrmzBhAk6fPm20vrOzM5YtW4aXXnoJ9+79OnShvLwcMTEx+Mc//mF0v379+uHOnTtITk422Obq6ort27f/hldhOqa8ekDUnBh0iahVmz59Ok6dOoUrV67oylxcXPDGG2+YsFW/D+Z89WD+/PmIjIzE0aNHIQgChg8fjvDwcPTq1cto/ezsbOzatUsv5AK1Vw727NmDsLAw/PTTTwb7jR07FsXFxXj99dcNtk2aNMls3z8iS8GgS0QtRqvVYu/evTh48CCqqqowaNAgREdHw8nJqd59bG1tsXPnTsTHx+O9996DVCrFrl274Orq2oItJ3MUFhaGsLAwvbKAgABcv37doG7Xrl1x8eJFo8dJS0vDvn37EBsbq+u5lclkePnllzFgwAAAtTdMbtu2DUVFRbCzs8PEiRMxY8aMZn5FRNRUDLpE1GJWrFiBffv26R6npqbi5MmT2LNnz0N7viQSCYYPH47PPvsMAGBnZ6fbduTIERw4cAAVFRUYOHAgpk6dyiENVK+ZM2fitddegyD8Oj+xRCLBSy+9hE2bNiE1NdVgnzZt2sDb2xu7du1CUlISFAoFgoOD9X6gTZkyBRMmTEBBQQFcXFzYk0vUSjDoElGLyMnJwf79+w3Kb968ia+//hpjx45t8jHj4uKwdetW3ePLly8jISEBn376KYMGGTV06FCsX78eO3bswO3bt+Hv74/o6GiEhoZiwoQJOHfunME+Y8eOhVQqBQD06NGj3mNbW1vDw8PjsbWdiJqOi3UTUYtITk6ud57cq1evAgByc3Nx+fJlVFRUNHi8goIC7Nixw6A8JSUFX3311W9qK1m2/v37Y/PmzYiPj8eHH36I0NDapX2HDRuGRYsW6aYaE4lEGDNmDF599VVTNpcsWGpqKkpKSlBRUaF3lYGaT6sIuhkZGYiOjkZISAgiIiKwcuXKeqdredCBAwfw5JNPIigoCFFRUfj6668fc2uJ6FF4eXnVu83d3R3z58/HiBEjMHnyZAwZMkSvp1ahUGDz5s1IT09HdnY20tLSkJycDLXa+LLBly8bX8qVqCGTJk3CoUOH4Ovri4CAAMTExOh6c4mai1qtxuLFizF9+nTk5eUhJycH06dPNzpnOP02Jh+6UFpaimnTpsHDwwMffPABFAoFVq1aheLiYqxevfqh+37zzTeIiYnR3RBw/PhxzJ8/H/b29hg4cGALvQIiaoxu3bqhT58++PHHH/XKHR0dkZaWpjdfbmVlJeLi4tCpUyf07NkTkydPRm5urm77lClTEBMTU+9ztWvXrvlfAP0uFBUVYffu3cjLy4O1tTUyMjLQrVs3UzeLHjNBEFBTU9NwxWayb98+HDt2TK8sLS0Nq1atwj//+c8WawdQe2OlJc/1LBJM3Fe+efNmbNiwAQkJCXBxcQEAHDp0CAsWLMCRI0fg6+tb776jR49GQEAA3n//fV1ZdHQ0ysrK9G54aay6y6dBQUFN3pfo9+K3fCGUlpZi9erVOHr0KFQqFXr16oW//OUvmDVrFpRKpUH9fv36wdvbG3v27DHYFhAQAFtbW4M75eVyOT7//HN06NDhkdr4MJb+hfB7l5+fj2nTpuHu3bu6MqlUinXr1iE8PNyELaPHSRAELFu2DDdu3Gix58zMzKz3yrWfnx+srFrugntAQACWLl1qVp9tTclrJu/R/eGHHxAREaELuQAwatQoLFmyBN9//329QTcrKwvp6el47bXX9MqjoqKwePFiKBQKvWMS0W/XXF8IXbt2hSAI0Gg0WLNmjdGQC9QOQbh06ZLRbTdu3EBgYCAcHR1RUlICALCxsYGHh4fROU2bgzl+IZizlu5l27p1q17IBWpXTlu9ejV27tzZYu0A+KPK0j2sj5FjdZuXyYNuWloaxo0bp1cmlUrRqVMnpKWl1btfeno6AKBLly565b6+vhAEAenp6Y8UdAVBQGVlZZP3I/o9EASh3hvKmuL+3gpra2vIZDKjgcbOzg5VVVX1HkMqlcLb2xtqtRqCIMDa2vo3t+1htFotKisrGUBagCAIePvttx/6PdDc6nuumzdv4oUXXoBE0nJfmX5+fli0aBHPtRaycOHCen9wPw6ffvqpwcp9ABASEoL33nuvxdoB1Gau+j5nW6umLK1t8qBbWloKBwcHg3IHBwddL40xddse3LfubtmH7fswKpUKKSkpj7Qv0e/B008/Xe9NYI8qKSkJ69at0zuum5sbFi9ejBs3bmDjxo0G+wwePBhTpkxp1nY0RCKRGF2OmJqfIAgt/uUrFouNlotEoha9lAzUjlNPSUlh0LVQvXv3xqlTp/R+XDk6OmLMmDG6jjx6uMbeJGryoFufxqb1B+vUdfk/6oeDtbU1/Pz8HmlfIno0wcHB6NevH7744gvk5eWhR48eGDNmDBwdHREZGQmJRILt27ejoqICYrEYI0eOxJIlSzhXroVbtmxZi/ayJSQkYMWKFQblTz31FObPn99i7QBqv8QZci3btm3bcObMGaSkpKBDhw4YNmwY2rRpY+pmmQVjC7vUx+RB18HBAaWlpQblZWVlD70R7f6e2/uXAq07lrFe4sYQiUQ80YhMoEePHvVOxj9r1iy88MILyMjIQLt27eDm5tbCrSNTsbW1bbHnGjduHIqLi/HRRx/p/ahavHgx5HJ5i7WDfj9GjhyJkSNHmroZZqcpPwJNHnR9fX0NxkUplUpkZmYajN29X93Y3PT0dL1AnJaWBpFIZDB2l4jMm62t7UNXpSJqDtHR0Zg4cSJ/VBFZCJMvGDFo0CAkJiaiqKhIV3bs2DEolUoMHjy43v06duyILl264MiRI3rlhw8fRnBwMGdcICKiR1L3o4ohl8j8mTzoTpw4Efb29pg9ezZOnjyJL7/8EitWrMBTTz2l11O7ZMkSPPHEE3r7zps3D19//TXi4uJw7tw5/POf/8Tp06cxb968ln4ZRERERNTKmHzogoODAz7++GOsXLkSc+fOhY2NDaKiorBgwQK9elqtFhqNRq9s9OjRqK6uxsaNG7Ft2zZ07twZcXFxXBWNiIiIiEy/MlprwpXRiIiIiFq3puQ1kw9dICIiIiJ6HBh0iYiIiMgiMegSERERkUVi0CUiIiIii8SgS0REREQWiUGXiIiIiCwSgy4RERERWSQGXSIiIiKySAy6RERERGSRGHSJiIiIyCIx6BIRERGRRWLQJSIiIiKLxKBLRERERBaJQZeIiIiILJLE1A1oTVQqFQRBwNWrV03dFCIiIiIyQqlUQiQSNaoug+59GvumEREREZFpiESiRmc2kSAIwmNuDxERERFRi+MYXSIiIiKySAy6RERERGSRGHSJiIiIyCIx6BIRERGRRWLQJSIiIiKLxKBLRERERBaJQZeIiIiILBKDLhERERFZJAZdIiIiIrJIDLpEREREZJEYdImIiIjIIjHoEhEREZFFYtAlIiIiIovEoEtEREREFolBl4iIiIgsEoMuNSgmJgZRUVH4/vvvERUVhaCgIDzzzDO4dOmSrs6wYcOwfPlybN26FZGRkejZsydmzZqF/Px8E7aczE1TzrVPP/0UQ4cORe/evTF79mwoFAoTtpzMTd25du7cOYwZMwYhISEYP348kpKSdHUCAwOxefNmvPvuu+jXrx9CQ0MRExOD8vJyE7aczE1jz7UtW7bggw8+QP/+/REeHo7FixejsrLShC23DAy61CgFBQVYtmwZoqOjsXbtWkilUkRHR+PevXu6OseOHcPx48cRGxuL2NhYXL16FXPnzjVhq8kcNeZcS0hIwLfffou33noLr7/+Os6fP48VK1aYsNVkjgoKCrBy5UpER0cjLi4O1dXVmDNnDlQqla7Ozp07kZ6ejnfeeQcLFixAfHw83nzzTRO2msxRY861zz77DLdv38bbb7+N2bNn49ChQ9iwYYMJW20ZJKZuAJmH4uJirF27FhEREQCAPn36YPDgwfj444/x2muvAQAqKiqwefNmODg4AADat2+P6dOn49SpUxg4cKDJ2k7mpTHnmiAI+Pe//w2pVAoAuH37NrZt2watVgsrK/5+p8YpKSnBp59+Cn9/fwCATCbDjBkzcPnyZYSFhQEApFIp1q9fD7FYrHv85ptvYs6cOfD19TVZ28m8NOZcc3V1xZo1awAAgwYNwtWrVxEfH48FCxaYrN2WgN8I1Cj29va64AEADg4O6Nevn94l5fDwcF3IBYCIiAjY2dnp1SFqSGPOtT59+uhCLgD4+flBpVLp9foSNcTd3V0XPADogmteXp6ubOjQobqQCwAjR46EIAi4evVqyzWUzF5jzrUBAwbo7ePn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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.91      0.91      0.91      2511\n",
      "    positive       0.91      0.91      0.91      2489\n",
      "\n",
      "    accuracy                           0.91      5000\n",
      "   macro avg       0.91      0.91      0.91      5000\n",
      "weighted avg       0.91      0.91      0.91      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.0896\n",
      "F1-Macro:  0.08682713481458065\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+naQAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nOzdZ2BUZcL28WsymUkhGZLQa4gJIKGjIMUFFVcsIAooKCgKiwpY8Hmxrj5YUND12XXBtdAEK2BDsQGKigULqIiAlBCagdCSTOpkksz7AZ0lZoLJZDJncvL/fTL3KXONDOTKnfucY/F4PB4BAAAAJhNmdAAAAACgNlB0AQAAYEoUXQAAAJgSRRcAAACmRNEFAACAKVF0AQAAYEoUXQAAAJhSuNEBQskPP/wgj8cjm81mdBQAAAD44Ha7ZbFY1LNnzz/dl6J7Eo/HI56fAQAAELqq09Uouif5fSa3a9euBicBAACAL5s3b67yvqzRBQAAgClRdAEAAGBKFF0AAACYEkUXAAAApkTRBQAAgClRdAEAAGBKFF0AAACYEkUXAAAApkTRBQAAgClRdAEAAGBKFF0AAACYEkUXAAAApkTRBQAAgClRdAEAAGBKFF0AAACYEkUXAAAApkTRBQAAgClRdAEAAGBK4UYHAAAg2Pbt26elS5dq79696tixo0aPHq1mzZoZHQtAgFF0AQRVWVmZ1q1bp2+//Vbx8fG69NJLKRgIqs2bN+uGG25QYWGhJOnLL7/UW2+9pcWLFysxMdHgdAACiaILIGjcbrduvfVWrVu3zjv27LPPau7cuerfv3+1z7d79269/PLL3lm5sWPHqmXLloGMDAN5PB65XK6An/fJJ5/0ltzfZWVl6T//+Y8eeugh72tLksViCfjrV0VERIRhrw2YicXz+99maPPmzZKkrl27GpwECF01KR/vvPOOHnzwwQrjLVu21Ntvv62wsFNfNnBy+di0aZOmTJmioqIi7/aGDRtq4cKFSkpK8ivfn6F8BI/H49GDDz6oHTt2BPy827Zt87ktPDxcHTp08O5n5J91hw4dNGPGDD5vgA/V6WvM6AKospqWjz179vgcz8jI0NixYxUVFVXlc+3atatcyZWknJwc/e1vf6u1Xz9TPuo+i8Uiq9Wq0tLSCtusVqtyc3N15MgRFRUVKTw8XI0aNVJCQgJ/5kAdRdEFEDSnKgsWi0VlZWUqKSmRzWY75b4ej0f5+fk+t+Xl5dU4J4xnsVg0Y8aMWlm6MG/ePC1atKjC+MiRI7Vs2TJvCS4pKVFmZqZGjhypa6+9NuA5ToXfHgCBQdEFUGU1LR9ffvmlbr311grjqamp6tGjh9566y0VFhaqWbNmmjJlioYOHSrpxNre1atXa+7cubLZbFq0aJGuuuoqZWVlVThXcnKyzxITCJSP4LJYLIqMjAz4eadMmaK8vDy99dZbcrvdioyM1Lhx45SWluZzpvfVV1/VhAkTFB7Ot0ygrmGN7klYowvUvrlz52rBggUqKSmRJLVr1049evTQihUryu1nsVg0b948devWTRMmTNCWLVu82+Li4nTBBRdo+fLlFc7/wAMP6IorrqjdNwFTyM7O1sGDB9WmTRvFxMRo5MiRSktL87nvJ598ovj4+CAnBOALa3QBhKxbbrlFo0eP1oYNG5SQkKDu3btr4MCBFfbzeDx66aWXlJqaWq7kSicKyu7duzVu3Di99tprcrlcatCgga677jpKLqosLi5OcXFx3q87duzos+i2aNFCDRs2DGY0AAFC0QUQdE2bNtXFF18sSTpy5IgKCgp87peZmanMzEyf2zZs2KC5c+dq6tSpOnTokFq1aqUGDRrUWmaY33XXXae1a9dWuMhx0qRJf3pHEAChib+5AAzVqFEjtWnTxue27t27KyIiwue28PBwhYeHy+FwqEOHDpRc1FiHDh30/PPPa9CgQQoPD1dUVJQeffRRjRgxwuhoAPxE0QVgqLCwMN12220VLvJKSEjQhAkTNGzYMJ/HDR48WNHR0cGIiHqkU6dOeuyxx9ShQwclJSXpvPPOMzoSgBpg6QIAw1100UVq1KiRXnnlFR08eFDdunXTddddp1atWunKK6/Uzz//rLffftv7wIjOnTvr73//u8GpYUaFhYX66KOPlJWVxW8JABPgrgsn4a4LQOjavn27pk2bJrvdrmXLltXKbadQv23atEnTpk0rd9u6SZMmaerUqQamAvBH1elrLF0AEPIyMzP19ttv6/jx4zp27Filj3AF/FVaWqq77rqrwr2Z58+frx9++MGgVABqiqULAEJaRkaGrrrqKh09etQ7Nn78eM2dO1eDBg0yMBnM5Mcff9ShQ4d8bvvwww/Vs2dP5ebmaufOnWrWrJlatWrl3e5yubR8+XJ9+umnstlsuvjiizVs2DAeLgKEAIougJC2YMGCciVXOjH79s9//pOii4Dx9US0k7ctXLhQCxYsUGFhoSwWiwYNGqSZM2cqOjpat956q7755hvv/l9//bU2bdqk+++/PxjRAZwCSxcAhLTvv//e5/iuXbuUnZ0d5DQwg19//VV33323BgwYoPPPP19PPvmkOnXqpISEBJ/7x8fHa+7cuSosLJR04mEmn376qWbNmqUvvviiXMn93Ztvvqm9e/fW6vsA8OeY0QUQ0ho3bqydO3dWGI+Ojub2YrXM4/HI5XIZHSOg8vPzNWHCBO+DSPLz87V48WKlp6frvvvu0z333FPuPQ8fPtx74csfrVq1Sg6Hw+c2j8ej7777Ts2aNQv8mwiCiIgIll7AFCi6AELaVVddpfXr11cYHzFihOx2uwGJ6g+Xy6UJEyYYHSOgjh8/7vNpe5999pkOHDigxMREHT9+XC6XS7Gxsdq5c6d2797t81wlJSX66KOPKn2tF154QW+++WbAsgfTokWLuLMJTIGiC9QxZpxlk078OvmNN95QRkaGUlNTddlll8nhcGjAgAG64447NG/ePOXk5MhisejSSy/V1KlTKzyq1eyYZau5U/3dKSoqUn5+vndJTG5urrKyshQdHe3zsxYREaGEhAQdP368whpfu93OfXiBEEDRBeoYM86y5efna/fu3SorK5MkrVmzRs8884xSUlJks9nkdrtls9kUHR0tm82mrVu36qabbjI4dfAZOcvWZ/B1slpthrx2IG3d9IXWf/KGz21NWnfWr9+sLjdWWFioJi1TVOqxKifriHfcag3XuRdfr1aJHXV65n598fFyHTt8QJLUsk17nf3XMYp1+F7zG6pKS9369uPFRscAAoqiC8BwGRkZ3pL7u+LiYh0+fFhNmjTRzp07VVJS4t3mdDrVrl27StdHIvCsVpus4XW/6Hbs0lebN36iPOfxcuPt2nfXwf0V14JL0oH0rbr6hoe065eNysxIV0xsnDp1P1txCSfW3zZrdZpGXnu38pxZCrNaFd2AzyUQKii6QB328FktZLfW7V9lF7pLdPmmTT63RZYUKjksX9tOKrnSieUbZdlH9NiFpwcjoqGKSz26/5uDRscwDXtElC4dM03fffGu9qZtls0eofapfdSr30V6++UnfB5TVlYqa7hN3c4875TnjnHE10ZkADVA0QXqMLvVoghr3b5LoFXhigy3qqik4n1MG0batOVglo+jpL1ZeSoqLlHDKLNfkFb257ugWmIcCTr34msrjLdN7qpjR36tMN68dbIiIrnDB1AX1e3vkADqvHBrmC44vZXPbRentlVCgwif26JsVkXZrbUZDfVM996D1ahp63JjEZHR6n/uKIMSAagpZnQBGO6mAZ2UU1isdWmH5JFks4bpiu5Juji1jWIjbNq4/2iFYy5ObSO7laKLwLFHROmyq/+fdu/4QYcP7lVswwR1SD1LkdExRkcD4CeKLgDDRdnC9cBFZ+iQs0CHcguVlBDrXZLwl+TmuvkvqXrhu51yFrllCzsxA3xDf/Ovz0XwWcNtap/aR+1T+xgdBUAAUHQBhIzmjmg1d1RcCzmye5KGdW6rDGeBEqIj5Ig0+7pcAEAgUHQB1An2cKvaJcQaHQMAUIdwMRoAAH/g8XiMjgAgAJjRBQDgN/vTt2rDF+/qSOY+xcTGq+uZ56nrGecaHQuAnyi6AABIOvRrmj5881l5PCfuXZyXm6X1n7yh0tIS9ejzV4PTAfAHSxcAAJD004a13pJ7ss0b1qqsrOIDTQCEPoouAACSco4f9jleWJCr4qLCIKcBEAgUXQAAJDVq6vsJfQ1i4xURxSOAgbooJIpuenq6Jk6cqB49eqhfv36aOXOmioqK/vS4goICPfHEEzr//PPVvXt3XXDBBZo7d66Ki4uDkBoAYCbde58va7itwnivvkNksYTEt0sA1WT4xWhOp1Pjx49Xy5YtNWfOHB0/flyzZs1Sdna2nnjiiVMe+8ADD+ijjz7S7bffrvbt2+unn37SnDlzlJOTo/vuuy9I7wAAYAaNmrbWpWOmaeP6D3Tk4F7FNmykrmecq+TTzzA6GgA/GV50ly5dKqfTqRUrVighIUGSZLVaNX36dE2ePFnJyck+jyspKdGHH36ov/3tb7rmmmskSX379lVGRobef/99ii4AoNqaNE/UhZffZHQMAAFi+O9i1q1bp379+nlLriQNGTJEdrtdn332WaXHeTwelZaWKja2/JOSHA4HN/oGAACA8TO6aWlpGjlyZLkxu92utm3bKi0trdLjbDabRowYoRdffFG9evVSSkqKNm/erOXLl2vcuHF+5/F4PCooKPD7eKC2uVwuoyME3YHsfC39Pk3bMrPV3BGtkd3bqVfrxkbHCrrCwkKVlVW8/VVtqY+fNZwQ7M8aUB0ej0cWi6VK+xpedJ1OpxwOR4Vxh8OhnJycUx77wAMPaMaMGbryyiu9Y9dcc41uvvlmv/O43W5t27bN7+OB2uZ2u42OEFT7s/I05fUvlecqkSTtPpar9emZun9IT53bvqXB6YJr+/btstkqXixVW+rbZw3/FezPGlBddru9SvsZXnQrU5W2/sQTT+jTTz/Vww8/rKSkJG3ZskVz5syRw+HQrbfe6tfr2mw2paSk+HUsEAz1bZZt6Q+7vSX3dx5JC7/ernNSWlT5p3oz6NixoyIiIoL2evXts4b/CvZnDaiOXbt2VXlfw4uuw+GQ0+msMJ6bm1vphWiStGPHDi1atEhPP/20Bg8eLEnq3bu3LBaLHn/8cY0dO1aNGjWqdh6LxaLoaO6XiNAVFmb40vqg2nooy+f4rzkFcha51TCqaj/Vm0FUVJQiIyOD9nr17bOG/wr2Zw2ojupMcBj+r1hycnKFtbjFxcXat2/fKYvu722+U6dO5cY7deqkkpIS/frrr4EPCyDomsVG+RyPiQhXA7vhP6sDAEKY4UV34MCB+vrrr5WV9d9ZmzVr1qi4uFiDBg2q9LhWrU48wWbLli3lxn/++WdJUuvWrWshLYBgG9k9Sb5+dh/eJVHhVsP/CQMAhDDDv0uMGTNGsbGxmjJlij7//HOtWLFCDz/8sIYNG1ZuRvfee+9Vamqq9+suXbqoW7dumjFjhl599VV9/fXXmj9/vubOnauLL7643O3KANRdvds20T1/7a7mv83sNrCH6+peybr+rI4GJwMAhDrDf+/ncDi0ZMkSzZw5U7fccosiIyM1dOhQTZ8+vdx+ZWVlKi0t9X5ttVr17LPP6t///rfmz5+vo0ePqkWLFho3bpxuuombfQNm8teOrdU6roF+OHBMifEx6tuumaxh9eciNARXTtYRHcncq1hHgpq1PM3oOABqwPCiK0lJSUlauHDhKfeZPXu2Zs+eXW6sUaNGeuihh2ozGgCDlZSW6aFV3+vz3ZnescT4GP1jeB81ifG9fhfwh8dTpnWrX9X2zV/rxL09pKYt2mnI5TcqKjr21AcDCEmGL10AgFN586c95UquJO3NytOTn22p5AjAP9s2fantm9fr95IrSYcP7tGXH79mWCYANUPRBRDSPtmZ4XP86z2ZKiwu8bkN8MfOrd/6HE/f+aPcxdxTGKiLKLoAQlqpx+Nz3OORyuR7G+CPEnexz3FPWZnKykp9bgMQ2ii6AELawOQWPsfPaNNYDew8ohSBk5jc1ed4i9YpiojkQUJAXUTRBRDSRnVPUveW5W8X2CQmUrcO7GxQIphVt96D1bhZm3JjEVEN1P+8UQYlAlBTIXHXBQCoTKTNqn9d3lff7TuibZk5au6I0jkpLRQRbjU6GkzGHhGl4Vf/P6Xv+EGHD+1TrCNB7VP7KDKqgdHRAPiJogsg5FksFvVJbKo+iU2NjgKTs1rDldKpt1I69TY6CoAAYOkCAAAATImiCwAAAFOi6AIAAMCUKLoAAAAwJYouAAAATImiCwAAAFOi6AIAAMCUKLoAAAAwJYouAAAATImiCwAAAFOi6AIAAMCUKLoAAAAwJYouAAAnKSrM18H9u5Sbc8zoKABqKNzoAAAAhIoNX7yrTRs+VmmJW5JF7dp307kXXSubPcLoaAD8wIwugJBRWFyi/Vl5Ki4pNToK6qGdW7/V919/+FvJlSSP9uzcpPWfvGFoLgD+Y0YXgOFKyzya99U2vfPzPhWVlMoRYdPVZyRrdK9ko6OhHvnlp698ju/c9p36D75C4eG2ICcCUFMUXQCGe2nDTi3/Md37tdPl1rNf/aL46AhdcHprfbfviJ7/Zod+ycxWc0eURnVP0ojuSQYmhhm5igp8jpeWuFXiLqboAnUQRReow4pLy4yOEBBv/bTX5/ibP+1Rk9go3fPudyot80iSDjoLNffzrSpwl+qKnqcFM6YhzPJnXBe0Sjxdx49mVBhv0qytIqMaGJAIQE1RdIE6xuPxeP/7/m8OGZgkMDwej3KKin1u251VoAfXbvOW3JMt2ZCm7woiZLFYajtiyDj5zz7Y/rtu1by69jpHe3b9pNyco96x8HC7ev/l0nrx/uvDe0T9Q9EFYCiLxaLo6GgVFFT8tXGDBg1UVFTk87iSkhKVlpYqPJx/xmrLycX627WLjQsSRC2bN1JWRJiKiopks9kUHx+vPVvXas/WtUZHCyojf6gCAonvEEAdc/IM5sNnNZfdWvdvnrIpMUL3vbdB7pN+TR9jD9fjF3bVKxt26dNdBysc07hBpP7xlzYKM/mMbnFpmXfmvj7NXgdDWdmJz1tY2H//DlmtVjVu3NioSAACjKIL1GF2a5giTFB0+7RtoqevGKA3N6Xr15wCJTd2aFT3JLVsGK2xZyTrq/TMCmtVr+mdoqhwq0GJ64eTi3Wf866T1SQXYzlzjmr9J2/qwJ7tslikNkmp6nfuSMXExhsdzVClJW7vzD0/VMEsKLoAQkJKY4fuHNy94niThnpyRD+98O1O/XI4W81jozSqR5IGd2hlQMr6yxpuM0XRLS1x68M3nlWu88RTzzwead/uLcrJOqIrrv+7wsL44QkwE4ougJDXqVmcZg3rbXQMmED6zk3eknuynKzD2rd7i9qldJO72KWsY4cUExun6JiGBqQEECgUXQBAveGr5Hq35RzTj9+s1g/frJa7uEgWS5iSTz9DAy+4SuE2exBTAgiUur+4DwCAKmrSPLHSbcWuQn37+TtyF5+404fHU6Zd277T15++Fax4AAKMogsAqDdate2olm07VBhve1pnHdy/y+cxO7Z8oxLuMQvUSRRdAEC9YbFYdOHlN+nMs4eqUdPWatysjfoMHK6/Xvo3FRbm+jympKRYJW5XkJMCCATW6AIA6pVwm129+l6oXn0vLDfeqm1HZR2teM/mRk1bKzIqJljxAAQQM7oAAEjq3ud8NfjDvXSt1nCdNegygxIBqClmdAEAkNQgJk4jrrlTW3/8QkcO7VWMI0Gde/xF8Y1bGB0NgJ8ougAA/CYqOlZn9L/I6BgAAoSlCwAAADAlii4AAABMiaILAAAAU6LoAgAAwJQougAAADAlii4AAABMiaILAAAAU6LoAgAAwJR4YAQAAL9xZh/Rpu8+0pFD+xTjSFCXXueoZZv2RscC4CeKLgAAknKyjmjFy/+Qq6hAknQ0c7/27vpJg4dO0GkdexqcDoA/WLoAAICkTd+u8Zbc33k8Hn33xTvyeDwGpQJQExRdAAAkZWak+xzPyToiV1F+kNMACASKLgAAkmIc8T7H7RFRstujgpwGQCBQdAEAkNSl1zk+x1O7n60wqzW4YQAEBEUXAABJbZJSdc6F49Qg9sTMrs0eqW69z9eZZw81OBkAf3HXBQAAftOhS1+lpPZRYb5TEVENFB5uMzoSgBqg6AIA8JsSd7F2/bJRRw7tVawjQR269FV0A4fRsQD4iaILAIAkV1GBVi59UsePZnjHfvx2jS654mY1aZ5oYDIA/mKNLgAAkjZ991G5kitJxa5CfbX2DYMSAagpii4AAJL27d7iczwzY3eFB0kAqBsougAASLLZI3yOh1nDZbWy0g+oiyi6AABI6tD5LJ/jp3XooXCbPchpAAQCRRcAAEmnd+2v1B4DZbH891tji9Yp6n/eFQamAlAT/C4GAABJFotFZ59/pXr0OV9HM/crxpGgxs3aGB0LQA1QdAEAOEmMI0ExjgSjYwAIAJYuAAAAwJQougAAADAlli4ACHnbD+foxe92avvhbDWLjdKoHqfpnJQWRscCAIQ4ii6AkJZ21Knb3vxKrpIySdLRfJe2fPi98s/tqks6tzU4HQAglLF0AUBIe/X7NG/JPdkL3+1UmcdjQCIAQF1B0QUQ0tKOOn2OH84rUm6RO8hpAAB1CUUXQEhrHdfA53hclF0xEay+AgBUjqILIKRd2eM0hVksFcav6JEkaxj/hAEAKsd3CQAhrWvLBD1yyZlq38QhSWoSE6nJAzrp6jNSDE4GAAh1/N4PQMjr266p+rZrqtIyj6xhFWd3AQDwhRldAHUGJRcAUB0UXQAAAJgSRRcAAACmRNEFAACAKVF0AQAAYEoUXQAAAJgSRRcAAACmFBJFNz09XRMnTlSPHj3Ur18/zZw5U0VFRVU6Njs7Ww888IDOPvtsde3aVUOGDNHSpUtrOTEAAABCneEPjHA6nRo/frxatmypOXPm6Pjx45o1a5ays7P1xBNPnPLY/Px8XXPNNYqIiNC9996rRo0aae/evXK73UFKDwAAgFBleNFdunSpnE6nVqxYoYSEBEmS1WrV9OnTNXnyZCUnJ1d67HPPPaeioiK99tprioyMlCSdddZZQckNAACA0Gb40oV169apX79+3pIrSUOGDJHdbtdnn312ymPfeOMNjRo1yltyAQAAgN8ZXnTT0tIqzNra7Xa1bdtWaWlplR63f/9+HT16VA6HQzfeeKO6dOmis846Sw8++GCV1/cCAADAvAxfuuB0OuVwOCqMOxwO5eTkVHrc0aNHJUmPP/64LrzwQs2fP1+7du3SP//5T7ndbs2cOdOvPB6PRwUFBX4dCwSDy+UyOgIMUlhYqLKysqC9Hp+1+ivYnzWgOjwejywWS5X2NbzoVubP3sTvfwGTk5M1a9YsSVK/fv1UUlKixx9/XLfddpuaNGlS7dd1u93atm2bf6GBIOBiy/pr+/btstlsQXs9Pmv1V7A/a0B12e32Ku1neNF1OBxyOp0VxnNzc095IVpcXJwkqW/fvuXG+/btq7KyMqWlpflVdG02m1JSUqp9HBAszLLVXx07dlRERETQXo/PWv0V7M8aUB27du2q8r6GF93k5OQKa3GLi4u1b98+jRw5stLj2rRp4/OnTY/HI0kKC/Nv+bHFYlF0dLRfxwLB4O9nG3VfVFRUUC++5bNWfwX7swZUR1WXLUghcDHawIED9fXXXysrK8s7tmbNGhUXF2vQoEGVHme32zVgwACtX7++3Pj69esVHh7OrCwAAEA9Z3jRHTNmjGJjYzVlyhR9/vnnWrFihR5++GENGzas3NKFe++9V6mpqeWOnTp1qrZv364777xTX3zxhRYvXqy5c+dq7Nix5W5XBqDuc5eW6UB2vvKLWTeK2lNWVqY9u37Sd1+s1LafvlRxMXfxAeoyw5cuOBwOLVmyRDNnztQtt9yiyMhIDR06VNOnTy+3X1lZmUpLS8uNdevWTc8995z+7//+TzfddJPi4uI0btw43XbbbcF8CwBq2dub92rxtzuUXVgsuzVMF6W20dSzU2WzGv6zOkzEXezS+6//R5kZu71jG758T0OvvFXxjZobmAyAvwwvupKUlJSkhQsXnnKf2bNna/bs2RXGBwwYoAEDBtRWNAAG+zI9U09+9rP36+LSMr29ea9sYWGa+pfUUxwJVM/mjWvLlVxJKsx36suPl2volbcalApATTAdAiCkrfhpj8/x97ful7uU+3wicNJ3bvI5nrFvh4pdhUFOAyAQKLoAQtrRfN9rJAvcJSooLglyGpiZ1er7l5wWS5gsFr5dAnURf3MBhLSuLXxfWJoYH6OGUVW7YThQFcmnn+FzPDGlq2x27ikL1EUUXQAh7eozkhX/h0JrDbPohv6nG5QIZtW558AKZTehSSudPfhKgxIBqKmQuBgNACrT3BGtZ688W69vStf2wzlqFhuly7u1U6dmcUZHg8mEhVk1eOj16nHWBTpycK9iGiaoVduO1bo5PYDQQtEFEPKaxkZpytncYQHB0ahJKzVq0sroGAACgKULAAAAMCWKLgAAAEyJogsAAABTougCAADAlCi6AAAAMCWKLgAAAEyJogsAAABT4j66AIA/VVrqNjpCUHk8HkmqVw+LqG9/xqgfKLoAgD/17ceLjY4AANXG0gUAAACYEjO6AACfIiIitGjRIqNjBJ3L5dLkyZMlSc8884wiIiIMThR89fE9w5wougAAnywWiyIjI42OYaiIiIh6//8AqMsougBCXk5hsVZu2atfMnPULDZKw7smqm18jNGxAAAhjqILIKQdyy/S1Ne/UmZuoXfs3S37NGtYb/Vq3djAZACAUMfFaABC2qvfp5UruZJUXFqmZ7/cZlAiAEBdQdEFENK+33/M5/jOI07lFBYHOQ0AoC6h6AIIaXFRdp/jEeFhirJZg5wGAFCXUHQBhLShndv6HL+gY2vZwym6AIDKUXQBhLTzOrTUxL4dvLO3YRbpvPYtNeXsVIOTAQBCHXddABDyxp3ZXpd3a6e9x/PUJCZKTWK4rykA4Ea50+4AACAASURBVM9RdAHUCQ3sNqU2jzc6BgCgDmHpAgAAAEyJogsAAABTougCAADAlCi6AAAAMCWKLgAAAEyJogsAAABTougCAADAlPy6j25BQYG+/fZbff/998rMzFRRUZHi4+OVkpKis846S+3btw90TgAAAKBaqlV09+zZo0WLFundd99VQUGBLBaLHA6H7Ha7nE6nXC6XLBaLOnTooGuuuUYjRoxQWBiTxgAAAAi+KhfdRx99VK+88oqSkpI0ZcoU9enTR6mpqQoP/+8pDh8+rB9//FEfffSRHnnkES1evFizZs1S165dayU8AAAAUJkqF92tW7fq+eefV+/evSvdp2nTprrgggt0wQUXKC8vT4sXL9b3339P0QVQI+nHcvXKxl3afjhHzWKjNLJ7kvq2a2p0LABAiKty0X3ppZeqdeKYmBjdfPPN1Q4EACfbezxXN7/+lQrcJZKk/dn52rD/qO79a3f9tWNrg9MBAEJZwBfQZmZmauvWrYE+LYB66tXvd3tL7sme/2aHPB6PAYkAAHWFX3ddyMjIqHTb6tWr9dxzz2n9+vV+hwKA320/nO1z/KCzUM4itxpG2YOcCABQV/hVdM877zxZLJZKtyclJfkdCEDVFZd6JJUZHaNWNYuN0p7jeRXGYyNsCreGyVVq7vd/4s8YAOAPv4ruo48+WqHoFhQUaMOGDfr44481e/bsgIQDcGr3f3PQ6Ai1LtcaK+lIhfHouAT9/ZtDwQ8EAKgz/Cq6I0aM8Dk+duxYzZ49W//4xz/04osv1igYAEhSbGysEhMTdejQIblcLlmtVjVu3FjNmjUzOhoAIMT5VXRPZdCgQXr11VcDfVoAv4mIiNCiRYuMjhF0LpdLN9xwg8LCwvTss88qIiLC6EhBVx/fMwDURMCLblZWlho1ahTo0wL4jcViUWRkpNExDGG1WiWdKHz19f8BAKDqAlZ0y8rK9Msvv+jZZ5/VbbfdFqjTAoAkyel0Ki8vT3Y7d1kAAFSNX0X39NNPr/SuCx6PR3fffbfuvvtuSSdmn7ivLoCaeOqpp7Ro0SK5XC5J0p133qlZs2apQYMGBicDAIQyv4ru1KlTT3l7MQAIlHfffVfPPPNMubGPP/5Yjz/+uB588EGDUgEA6gK/iu4tt9wS6BwA4NPrr7/uc3zlypW69957uUALAFCpgD8CGAACKScnx+e4y+VSYWFhkNMAAOqSKhfdBx54QEeOVLxp+6msXr1a77zzTrVDAcDv+vbt63O8c+fOiouLC3IaAEBdUuWim56ervPPP1/Tp0/X559/XulMyt69e7Vo0SINHTpUf//739WwYcOAhQVQ/0ycOFFt2rQpNxYREaE77rjDoEQAgLqiymt0lyxZoo8++kjz5s3TpEmTFB4ersTERCUkJCgiIkI5OTnav3+/cnJyFBUVpREjRmjy5MncUxdAjTRu3FjLli3TsmXLtHjxYtntds2fP1/t27c3OhpM6Oeff9Yzzzyj7du3y2azac2aNRo2bJjRsQD4yeLxeDzVPWjr1q365JNPtGnTJh0+fFhFRUWKj4/Xaaedpj59+mjw4MGKiYmpjby1avPmzZKkrl27GpwEwB8VFRVpwoQJkqRFixbxwAgE3C+//KLrrrtORUVF5cbvu+8+jRo1yqBUAP6oOn3Nr7supKamKjU11Z9DAQAISYsXL65QciVpwYIFGjFihMLCuH4bqGv4WwsAgKSdO3f6HD906FCld/8AENr8Krrr16/XBx984P366NGjmjRpkgYMGKA777zT+/QiAADqisTERJ/jCQkJio2NDXIaAIHgV9GdM2eO0tLSvF//4x//0IYNG9SzZ0+tWrVKCxYsCFhAAACC4ZprrlF4eMUVfZWNAwh9fhXdPXv2eNfolpSUaM2aNZo+fbqeeuop3XrrrXrvvfcCGhIAgNrWs2dPzZkzx/v9zWaz6fbbb9f1119vcDIA/vKr6Obl5cnhcEiStmzZosLCQg0ePFiS1K1bNx08eDBwCQEACJL+/ftr0aJF6tSpk9q3b6/Ro0cbHQlADfhVdBs1aqQ9e/ZIkr766iu1bNlSzZs3lyTl5+fzKx4AQJ1msViMjgAgAPxqpH/5y1/0r3/9S7t27dJbb72lyy67zLtt9+7datWqVcACAgAAAP7wq+jefvvtysjI0PLly9WtWzdNnjzZu+3dd99Vz549AxYQAAAA8IdfRTchIUELFy70ue2FF16Q3W6vUSgAAACgpmr8wIiioiJlZmaqpKREkhQTE0PRBQAAgOH8Lrpff/21Ro8erV69euncc8/V9u3bJUkPPvigVq9eHbCAAAAAgD/8fjLaxIkT5XK5NGHCBJWVlXm3xcfH68033wxYQAAAAMAffj8ZbeDAgVqxYoWmTZtWbtvpp5+uX375JSDhAAAAAH/5VXS3bdumMWPGSKp4r8GEhAQdO3as5skAAACAGvCr6FqtVrndbp/bjh07pgYNGtQoFAAAAFBTfhXdrl276p133vG5bdWqVerRo0eNQgEAAAA15dd9dG+44QZNnDhRU6dO1WWXXSaLxaJNmzbpjTfe0KpVq7RkyZJA5wQAAACqxa+i279/f82ePVuPPvqoPv74Y0nSQw89JIfDoVmzZunMM88MaEgAAACguvwqupI0fPhwDRkyRD/88IOOHj2q+Ph49erVS9HR0YHMBwCSpKysLOXm5vJAGgBAlVV7jW5RUZHGjBmjr776SpGRkerXr5+GDRums88+m5ILoFb885//1EUXXaTdu3frl19+0bRp05SXl2d0LABAiKt20Y2MjNSOHTtktVprIw8AlLNixQotXLiw3J1ePv/8c82ePdvAVACAusCvuy707NlTP/30U6CzAEAFlT1p8b333lNRUVGQ0wAA6hK/iu5dd92lZcuWacWKFcrPzw90JgDwys3N9TleXFxM0QUAnJJfF6ONHj1abrdb99xzj+655x5FRkaWe0KaxWLRxo0bAxYSQP01YMAA7dixo8J4ly5dFBcXZ0AiAEBd4VfRHTJkSIVH/wJAbZgwYYI++eQT7dmzxzsWHR2tu+66y7hQAIA6wa+iy0UgAIIlISFBy5cv1/Lly7VgwQLZ7XYtWrRISUlJRkcDAIQ4v9boBlp6eromTpyoHj16qF+/fpo5c2a1196tWbNGHTt21NChQ2spJQCjNGjQQFdddZUSExPVokULtWjRwuhIAIA6wO8HRuzbt09z587V+vXrlZ2drfj4ePXv319Tp05V27Ztq3wep9Op8ePHq2XLlpozZ46OHz+uWbNmKTs7W0888USVzlFUVKRZs2apcePG/r4dAAAAmIxfRTctLU1jxoyRy+VS37591bRpUx0+fFgffPCBPv30U73yyitKTk6u0rmWLl0qp9OpFStWKCEhQZJktVo1ffp0TZ48uUrnee6559SyZUu1bt1aP//8sz9vCQAAACbj19KFf/3rX4qLi9Pq1as1b948zZw5U/PmzdPq1asVFxenJ598ssrnWrdunfr16+ctudKJi93sdrs+++yzPz1+3759ev7553Xffff581YAAABgUn7N6H733Xf6+9//rubNm5cbb968uaZMmaJHHnmkyudKS0vTyJEjy43Z7Xa1bdtWaWlpf3r8I488ouHDh+v000+v8mueisfjUUFBQUDOBSBwDh8+rLy8PNlsNhUWFqqsrMzoSDApl8vl/W8+a0Do8Xg8Vb77l19Ft7CwsNL7V8bHx1frQjKn0ymHw1Fh3OFwKCcn55THrl27Vj/88IM+/PDDKr/en3G73dq2bVvAzgeg5l5//XV98MEH3scA33zzzZo8ebKioqIMTgYzOvlx09u3b5fNZjMwDQBf7HZ7lfbzq+gmJSVp5cqVGjhwYIVt7733nk477TR/TlvOn7V1l8ulRx99VLfccku5ZQ81ZbPZlJKSErDzAaiZ999/X++88065sR9//FHvv/8+S5ZQK06e0e3YsaMiIiIMTAPgj3bt2lXlff0qutdcc43uu+8+5ebm6vLLL1eTJk105MgRvfPOO1q7dq1mzpxZ5XM5HA45nc4K47m5uae8EG3JkiUKCwvTJZdc4j3e7XarrKxMTqdTkZGRVW77J7NYLIqOjq72cQBqx8qVK32Of/jhh/rf//1fRUZGBjkRzC4s7L+Xr0RFRfEZA0JMdR5a5lfRHTVqlI4dO6ZnnnnGe8GYx+NRZGSkbr/99gprbk8lOTm5wlrc4uJi7du375Tn2b17t/bu3at+/fpV2Na7d2898MADuuqqq6qcA0Bo8vWDsHRi1q2oqIgSAgColN/30b3xxht19dVX64cfflB2drbi4uLUs2dPxcbGVus8AwcO1DPPPKOsrCzFx8dLOvHwh+LiYg0aNKjS4yZNmqTLL7+83Ni8efOUnp6uWbNmqV27dtV+TwBCT//+/bVjx44K4507d670WgEAAKQaFF1Jio2N9blOtzrGjBmjl156SVOmTNGUKVN07NgxzZ49W8OGDSu3dOHee+/VihUrtHXrVkknZoL/uLThrbfeUmZmps4666waZQIQOiZMmKC1a9dq37593rHIyEjdddddBqYCANQFft1H94033tDcuXN9bps7d65WrFhR5XM5HA4tWbJE0dHRuuWWWzR79mwNHTq0wjrfsrIylZaW+hMXQB3WqFEjLV++XLfffrvi4uLUpEkTLVu2TGeccYbR0QAAIc6vGd0XX3yxwrKB38XHx+uFF17QZZddVuXzJSUlaeHChafcZ/bs2Zo9e/af7gPAfGJjYzVu3DitXbtWktS6dWuDEwEA6gK/ZnT37t2rDh06+NyWnJysvXv31igUAPxRWVmZ984qAABUhV9FVzpx+y9f8vLyWGIAIKDeeecdXXrppdq6dau2bNmiOXPm8O8MAOBP+VV0O3bsqPfee8/ntnfffbfS2V4AqK4vvvhC99xzjw4ePCjpxMzukiVLKr1OAACA3/lVdMeOHatVq1bprrvu0qZNm5SZmalNmzbp7rvv1urVqzVu3LhA5wRQT7300ks+x5ctW1buUa0AAPyRXxejDRs2TLt379a8efO8j+b0eDyyWq2aPHmyLr300oCGBFB//T6T+0dOp1P5+fncSxcAUCm/76N72223aeTIkfryyy+VlZWlhIQEDRgwQK1atQpkPgD1XPfu3X0+1zwxMVENGzY0IBEAoK7w+2I06cQtfoYMGaK8vDx9/PHHeu6553x+QwIAf02cOFEOh6PcWFhYmG677bZqPe8cAFD/VLnoPvbYYzrnnHPKjRUUFGjUqFFauHChPvvsMy1fvlyjR4/W7t27A50TQD2VmJiopUuX6vLLL1dkZKQcDoeefvppDRkyxOhoAIAQV+Wi+8MPP+jiiy8uN/bSSy/pwIEDGj9+vDZs2KClS5cqOjpa8+fPD3hQAPVXYmKi7rvvPnXs2FFJSUnq3bu30ZEAAHVAlYvu/v371aVLl3Jjn3zyiRISEnTHHXcoJiZGPXr00PXXX69vvvkm4EEBAACA6qhy0XU6nWratKn365KSEm3evFl9+vSR1Wr1jnfq1ElHjhwJbEoAAACgmqpcdBs3bqzDhw97v966datKSkoqzPKGhYXJbrcHLiEAAADghyoX3c6dO+u1116Tx+ORdOKRnBaLRf369Su33+7du9WkSZPApgQAAACqqcr30Z00aZKuuuoqXXjhhYqPj9ePP/6oM888U507dy633yeffKKuXbsGPCgAAABQHVWe0e3evbuefvppNW3aVPn5+briiiv01FNPldvnyJEjOnTokAYPHhzwoAAAAEB1VOvJaOecc06Fe+merEmTJt5HAgMAAABGqtGT0QAAAIBQRdEFAACAKVF0AQAAYEoUXQAAAJgSRRcAAACmRNEFAACAKVF0AQAAYEoUXQAAAJgSRRcAAACmRNEFAACAKVF0AQAAYEoUXQAAAJgSRRcAAACmRNEFAACAKVF0AQAAYEoUXQAAAJgSRRcAAACmRNEFAACAKVF0AQAAYEoUXQAAAJgSRRcAAACmRNEFAACAKVF0AQAAYEoUXQAAAJgSRRcAAACmRNEFAACAKVF0AQAAYEoUXQAAAJgSRRcAAACmFG50AAAAQsnhw4eVm5srm81mdBQANcSMLgAAkjwejx577DFdfvnl2r9/v3bv3q2bb75ZTqfT6GgA/ETRBQBA0ooVK/Tqq6+qtLTUO7ZhwwY99thjBqYCUBMUXQAAJL399ts+x1evXq3CwsIgpwEQCBRdAAAkFRQU+Bx3u91yu91BTgMgECi6AABIOvvss32Od+vWTQ6HI8hpAAQCRRcAAEnjx49XcnJyubGYmBjdeeedBiUCUFMUXQAAJDVs2FAvvfSS7r77bsXFxalJkyZaunSpunTpYnQ0AH6i6AIA8JuoqChddtllatmypZo0aaLGjRsbHQlADVB0AQD4zZ49ezRz5kylpaVp3759+vbbb42OBKAGKLoAAOhEyR03bpzeffdduVwu5eXl6bbbbtOHH35odDQAfuIRwACAkOTxeORyuYL2egsWLFBeXl6FDE899ZQGDRoki8UStCwRERFBfT3ArCi6AICQ4/F49OCDD2rHjh1Be820tDSf4wcOHND48eMVHh68b5kdOnTQjBkzKLtADbF0AQAASTabzed4WFiYrFZrkNMACARmdAEAIcdisWjGjBlBXbrwzTffaNq0afJ4POXGx48frxtvvDFoOSSWLgCBQtEFAIQki8WiyMjIoL3eoEGD9Oijj+o///mPDhw4oNjYWI0ePVqTJ09mRheooyi6AAD85qKLLtKFF16o7OxsxcTEVLqcAUDdQNEFAOAkFotF8fHxRscAEABcjAYAAABTougCAADAlCi6AAAAMCWKLgAAAEyJogsAAABTougCAADA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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.9032\n",
      "F1-Macro:  0.8996200042150637\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": "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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": 45,
   "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": 48,
   "metadata": {
    "executionInfo": {
     "elapsed": 38794,
     "status": "ok",
     "timestamp": 1695329477164,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "_OCeDQY6gHMj",
    "tags": []
   },
   "outputs": [],
   "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",
    "\n",
    "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"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "oEdEBFPQiasC"
   },
   "source": [
    "Paraphrased Native Injection Accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "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.9106000000000001\n",
      "F1-Macro:  0.9079445399158268\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": 33,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.load_state_dict(torch.load('/home/mostafa_nsu/ICLR/Scripts/IMDB/t5_best_model_state.bin'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "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": 33,
   "metadata": {
    "executionInfo": {
     "elapsed": 11,
     "status": "ok",
     "timestamp": 1695329507206,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "nysMxY5myqsd",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "f1s = []\n",
    "accuracy = []\n",
    "p_word_list = []\n",
    "n_word_list = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "JuMwkV_v4GvV",
    "outputId": "24e92f01-d79f-4514-f879-14a50b1f8477",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Working ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... "
     ]
    }
   ],
   "source": [
    "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": 8,
   "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": 48,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 245
    },
    "executionInfo": {
     "elapsed": 13,
     "status": "error",
     "timestamp": 1695379584056,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "N_1_hH8S4Hit",
    "outputId": "85d5684e-8de1-402e-9386-f53b050bd477",
    "tags": []
   },
   "outputs": [],
   "source": [
    "stdv = statistics.pstdev(f1s)\n",
    "median = statistics.median(f1s)\n",
    "#filters = [i>median+(2*stdv) for i in f1s]\n",
    "filters = [i>.7 for i in f1s]\n",
    "def filter_2std(target_list, filters):\n",
    "    index = [i for i in range(len(filters)) if filters[i]]\n",
    "    list_a_filtered = [target_list[i] for i in index]\n",
    "    return list_a_filtered\n",
    "\n",
    "p_words_spurious = filter_2std(p_word_list,filters)\n",
    "n_words_spurious = filter_2std(n_word_list,filters)\n",
    "\n",
    "#print(p_words_spurious)\n",
    "#print(n_words_spurious)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "6l78c6yoikRS"
   },
   "source": [
    "Neutral Injection Accuracies"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "f1s = list(pd.read_csv('/home/mostafa_nsu/ICLR/Scripts/IMDB/t5_randomizationtest.csv')['f1s'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "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": 60,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "stdv = statistics.pstdev(f1s)\n",
    "mean = statistics.mean(f1s)\n",
    "  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "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": 62,
   "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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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAsYAAAIYCAYAAABuXCrqAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAPYQAAD2EBqD+naQAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nO3de3SU9Z348fcQCAnIoIjryh2igiI3txQCCKsiIIRShCotsFjxwh0vUYHjKpVoogeK4toVkVrwhlpqWlmkRW2ButA99VCoqBRCuBTbKtdBSAyQ+f3Rk/w6DSAzmckA836d4znNd55n+IzfhX3z+MxMIBwOh5EkSZJSXK1kDyBJkiSdCQxjSZIkCcNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTgDAjjHTt28PDDDzNkyBCuvPJKcnJyTvvct956iwEDBtChQwdycnJ45513EjipJEmSzmVJD+MtW7awatUqWrZsSVZW1mmft2LFCqZNm8YNN9zAggUL6N69O/fccw+//e1vEzitJEmSzlWBcDgcTuYA5eXl1Kr19z6fNm0aH330EcuWLfva82688UYuv/xynn766cq1sWPHcujQId54442EzStJkqRzU9KvGFdEcTR27drFtm3bqtx2kZOTw8aNG9m3b1+8xpMkSVKKqJ3sAWKxbds2ANq0aROxnpWVRTgcZtu2bTRq1Cjq512/fj3hcJg6derEZU5JkiTF19GjRwkEAnTp0iXuz31WhvHBgwcBCAaDEesNGzaMeDxa4XCYcDhMWVlZ9QaUJEnSWeesDOMKgUAg4ueK26X/ef101alTh7KyMlq1akVmZma159OZraSkhO3bt7vfKcL9Ti3ud2pxv1PLli1bYroV93SclWH8j1eGGzduXLkeCoWAqleSo5WZmUm9evWq9Rw6e7jfqcX9Ti3ud2pxv1NDrBdAT0fS33wXi4p7iyvuNa5QVFREIBCocu+xJEmS9HXOyjBu3rw5bdq0Yfny5RHry5Yto2PHjjG98U6SJEmpLem3UpSUlLBq1SoAdu/ezZdffsmKFSsA+OY3v0mjRo2YMWMGhYWFfPzxx5XnTZkyhXvuuYcWLVrQo0cP3nvvPT744ANeeOGFpLwOSZIknd2SHsZ79+5l6tSpEWsVPy9evJhu3bpRXl7O8ePHI4658cYbKS0t5bnnnmPhwoW0bNmSuXPn0qtXrxqbXZIkSeeOpIdxs2bN2Lx58ymPKSgooKCgoMr60KFDGTp0aKJGkyRJUgo5K+8xliRJkuLNMJYkSZIwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIk4AwJ4+LiYsaOHUvnzp3Jzs4mLy+P0tLSrz3vyJEjzJ49m759+9KpUyf69evHM888Q1lZWQ1MLUmSpHNJ7WQPEAqFGDNmDE2aNGHevHns27eP/Px8Dhw4wOzZs0957syZM3n33Xe55557uOyyy9i4cSPz5s3j4MGDPPTQQzX0CiRJknQuSHoYL1myhFAoRGFhIY0aNQIgLS2N3Nxcxo8fT1ZW1gnPO3bsGCtWrOD2229n9OjRAHTv3p3PPvuM5cuXG8aSJEmKStJvpVi9ejXZ2dmVUQzQv39/0tPTWbVq1UnPC4fDHD9+nAYNGkSsB4NBwuFwwuaVJEnSuSnpYVxUVFTlqnB6ejotWrSgqKjopOfVqVOHm266iZdeeokNGzZw+PBh1q1bxxtvvMHIkSMTPbYkSZLOMUm/lSIUChEMBqusB4NBDh48eMpzZ86cySOPPMLNN99cuTZ69GgmTZpUrZlKSkqqdb7ODhX77H6nBvc7tbjfqcX9Ti3hcJhAIJCQ5056GJ/M6bzo2bNn85vf/IZZs2bRunVrNm3axLx58wgGg0yZMiXmX3v79u0xn6uzj/udWtzv1OJ+pxb3O3Wkp6cn5HmTHsbBYJBQKFRl/dChQyd94x3An/70J3784x/zox/9iOuvvx6Arl27EggEePLJJxk5ciQXXnhhTDO1atWKzMzMmM7V2aOkpITt27e73ynC/U4t7ndqcb9Ty5YtWxL23EkP46ysrCr3EpeVlbFz506GDRt20vO2bt0KwBVXXBGxfsUVV3Ds2DF2794dcxhnZmZSr169mM7V2cf9Ti3ud2pxv1OL+50aEnUbBZwBb77r3bs369atY//+/ZVrK1eupKysjD59+pz0vKZNmwKwadOmiPWPPvoIgGbNmiVgWkmSJJ2rkn7FeMSIEbz88stMmDCBCRMmsHfvXgoKChg8eHDErRQzZsygsLCQjz/+GICrrrqKjh078sgjj7Bnzx5at27NH//4R370ox8xcODAiI9/kyRJkr5O0sM4GAyyaNEi8vLymDx5MhkZGeTk5JCbmxtxXHl5OcePH6/8OS0tjeeee46nn36aBQsWsGfPHi655BJGjRrFuHHjavplSJIk6SyX9DAGaN26NQsXLjzlMQUFBRQUFESsXXjhhTz66KOJHE2SJEkpIun3GEuSJElnAsNYkiRJwjCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQLOkDAuLi5m7NixdO7cmezsbPLy8igtLT2tcw8cOMDMmTPp1asXHTp0oH///ixZsiTBE0uSJOlcUzvZA4RCIcaMGUOTJk2YN28e+/btIz8/nwMHDjB79uxTnnv48GFGjx5N3bp1mTFjBhdeeCE7duzg6NGjNTS9JEmSzhVJD+MlS5YQCoUoLCykUaNGAKSlpZGbm8v48ePJyso66bnz58+ntLSUN998k4yMDAC6detWI3NLkiTp3JL0WylWr15NdnZ2ZRQD9O/fn/T0dFatWnXKc5cuXcrw4cMro1iSJEmKVdKvGBcVFTFs2LCItfT0dFq0aEFRUdFJz9u1axd79uwhGAxy11138cEHH1C/fn0GDhzIgw8+WK1YLikpiflcnT0q9tn9Tg3ud2pxv1OL+51awuEwgUAgIc+d9DAOhUIEg8Eq68FgkIMHD570vD179gDw5JNPMmDAABYsWMDWrVv54Q9/yNGjR8nLy4t5pu3bt8d8rs4+7ndqcb9Ti/udWtzv1JGenp6Q5016GJ/M1/1toLy8HICsrCzy8/MByM7O5tixYzz55JNMnTqViy66KKZfu1WrVmRmZsZ0rs4eJSUlbN++3f1OEe53anG/U4v7nVq2bNmSsOdOehgHg0FCoVCV9UOHDp3yjXfnn38+AN27d49Y7969O+Xl5RQVFcUcxpmZmdSrVy+mc3X2cb9Ti/udWtzv1OJ+p4ZE3UYBZ8Cb77KysqrcS1xWVsbOnTtPGcbNmzenTp06VdbD4TAAtWol/aVJkiTpLJL0euzduzfr1q1j//79lWsrV66krKyMPn36nPS89PR0evbsydq1ayPW165dS+3atbn00ksTNrMkSZLOPUkP4xEjRtCgQQMmTJjAmjVrKCwsZNasWQwePDjiivGMGTO48sorI86dOHEimzdv5oEHHuC3v/0tP/nJT3jmmWcYOXJkxMe/SZIkSV/njLjHeNGiReTl5TF58mQyMjLIyckhNzc34rjy8nKOHz8esdaxY0fmz5/PnDlzGDduHOeffz6jRo1i6tSpNfkSJEmSdA6IOoy/+OKLmN/UdjKtW7dm4cKFpzymoKCAgoKCKus9e/akZ8+ecZ1HkiRJqSfqWymuvfZa7r33Xj788MNEzCNJkiQlRdRhPG7cOH7/+98zatQohgwZwptvvklpaWkiZpMkSZJqTNRhPGnSJH79618zZ84czjvvPP7zP/+TPn368MQTT7Bz585EzChJkiQlXEyfSpGWlsbAgQN55ZVXKCwspF+/fixZsoQBAwZw1113sWbNmnjPKUmSJCVUtT+urW3btvTu3ZvLLruM8vJy1q5dy5133slNN91EcXFxPGaUJEmSEi7mMN63bx/z58/n+uuvZ8qUKaSlpTF37lw+/PBDnn32WQ4fPsz06dPjOaskSZKUMFF/XNuGDRt45ZVXWLFiBeFwmIEDB/If//EftG/fvvKY6667jrS0NCZOnBjXYSVJkqREiTqMb7nlFho3bsydd97Jd7/7XS688MITHtesWTO6dOlS7QElSZKkmhB1GD/xxBMMHDiQOnXqnPK4rKwsXnrppZgHkyRJkmpS1GE8ZMiQRMwhSZIkJVXUb757/vnnmTVr1gkfmzVr1td+tbMkSZJ0Joo6jAsLC7nssstO+Fi7du0oLCys9lCSJElSTYs6jD/77DNatWp1wsdatGjBn//85+rOJEmSJNW4qMO4du3a7Nu374SP7d27l0AgUO2hJEmSpJoWdRhfddVVvPHGGyd87I033uCqq66q9lCSJElSTYv6Uyluu+027rrrLkaPHs13v/tdLr74Yv72t7/x2muv8fvf/57nn38+EXNKkiRJCRV1GPfu3ZtHH32UJ554gnvvvZdAIEA4HKZBgwbMmjWLa665JhFzSpIkSQkVdRgDfOc732HQoEGsX7+effv20ahRI7p06UK9evXiPZ8kSZJUI2IKY4B69erRs2fPeM4iSZIkJU1MYRwOh/njH//I7t27+eqrr6o8/u1vf7vag0mSJEk1KeowLi4uZvz48ezYsYNwOFzl8UAgYBhLkiTprBN1GD/66KOUlZUxd+5c2rZtS3p6eiLmkiRJkmpU1GG8ceNGZs2axYABAxIxjyRJkpQUUX/BR7169TjvvPMSMYskSZKUNFGH8U033cSyZcsSMYskSZKUNFHfSnH55ZfzP//zP4wbN47rrruO888/v8ox/fr1i8twkiRJUk2JOozvu+8+AP785z/zm9/8psrjgUCATz75pNqDSZIkSTUp6jBevHhxIuaQJEmSkirqMP7mN7+ZiDkkSZKkpIr5K6EPHTrEH/7wB/bv30+fPn1o2LBhPOeSJEmSalRMYfzss8+yYMECSktLCQQC/PSnP6Vhw4aMGTOGnj17cuedd8Z7TkmSJCmhov64tldeeYVnn32W4cOHM3/+/Iivhb722mtP+IY8SZIk6UwX9RXjV155hVtvvZUHHniA48ePRzzWsmVLduzYEbfhJEmSpJoS9RXjXbt2cc0115zwsfr16xMKhao9lCRJklTTog7jBg0asGfPnhM+tnv3bi688MJqDyVJkiTVtKjDODs7mxdeeIEjR45UrgUCAY4dO8Zrr71Gr1694jqgJEmSVBOivsd4ypQpDB8+nEGDBtG3b18CgQAvv/wyn3zyCZ999hlPPfVUIuaUJEmSEirqK8YtW7bktddeo02bNrz22muEw2F+/vOfc8EFF/Dqq6/SpEmTRMwpSZIkJVRMn2N86aWXsnDhQsrKyti/fz8NGzYkIyMj3rNJkiRJNSbmb74DSE9P5+KLL47XLJIkSVLSRB3G//Vf/3XKxwOBABMnTox5IEmSJCkZDGNJkiSJGML4008/rbJ24MAB3n33XRYtWsTzzz8fl8EkSZKkmhT1p1KcyPnnn8/w4cMZPHgweXl58XhKSZIkqUbFJYwrdOjQgbVr18bzKSVJkqQaEdcw3rx5M/Xq1YvnU0qSJEk1Iup7jAsLC6uslZWVsXnzZpYuXcq3vvWtuAwmSZIk1aSow3jatGknXK9bty7f+ta3eOCBB6o9lCRJklTTog7j9957r8pa3bp1ady4cVwGkiRJkpIh6jBu2rRpIuaQJEmSkiqub76TJEmSzlZRXzFu164dgUDgtI4NBAJ8/PHHUQ8lSZIk1bSow3jixIm89dZbHD58mOuuu47GjRvzxRdf8Otf/5r69etz0003JWJOSZIkKaGiDuP69evTuHFj3n77berXr1+5/uWXX/L973+fjIwMbr/99rgOKUmSJCVa1PcYv/rqq9x+++0RUQxw3nnncfvtt/Pqq6/GbThJkiSppkQdxn/7299IS0s74WNpaWns2bOn2kNJkiRJNS3qMM7KyuInP/kJR48ejVgvKyvjxRdfpE2bNnEbTpIkSaopUd9jfPfddzNx4kT69u3LDTfcwEUXXcQXX3zBypUr2bNnD88++2wi5pQkSZISKuow/vd//3deeOEF5s6dy6uvvkp5eTmBQICOHTuSn59Pjx49EjGnJEmSlFBRhzFAdnY22dnZlJSUEAqFCAaDZGZmxns2SZIkqcZU65vvKr7oo06dOnEZRpIkSUqWmMJ43bp13HLLLVx99dVce+21bN68GYAf/OAH/OpXv4rrgJIkSVJNiDqM165dy9ixY/nqq6+47bbbKC8vr3zsggsu4Gc/+1lcB5QkSZJqQtRhPG/ePHr37k1hYSF33313xGPt2rXj008/jdtwkiRJUk2JOow/+eQTRowYAfz/e4wrNGrUiL1798ZnMkmSJKkGRR3GaWlpVb7co8LevXurfFW0JEmSdDaIOow7dOjAL37xixM+9stf/pLOnTtXeyhJkiSppkX9OcZ33nknY8eOZeLEiXz7298mEAiwYcMGli5dyi9/+UsWLVqUiDklSZKkhIo6jHv06EFBQQGPP/447733HgCPPvoowWCQ/Px8vvGNb8R9SEmSJCnRYvrmuyFDhtC/f3/Wr1/Pnj17uOCCC7j66qupV69evOeTJEmSakRUYVxaWsqtt97KlClT6NGjB9nZ2YmaS5IkSapRUb35LiMjgz/96U+kpaUlah5JkiQpKaL+VIouXbqwcePGRMwiSZIkJU3UYfzggw/y+uuvU1hYyOHDhxMxkyRJklTjon7z3S233MLRo0eZPn0606dPJyMjI+Ib8AKBAB9++GFch5QkSZIS7bTC+NNPP6V169bUrVuXAQMGJHomSZIkqcadVhgPHTqU119/nY4dO7J7924eeeQRsrKyEj2bJEmSVGNO6x7j9PR0ysrKAPi///s/7y2WJEnSOee0rhg3b96cF198kT179gDwu9/9jr/+9a8nPb5fv37xmU6SJEmqIacVxhMmTOCBBx7gvffeIxAIMGfOnJMeGwgE+OSTT6Iaori4mLy8PD788EMyMzMZNGgQubm5ZGRknPZzrFy5kkmTJnHZZZexbNmyqH59SZIk6bTCeODAgXTv3p3i4mJGjhzJww8/zKWXXhqXAUKhEGPGjKFJkybMmzePffv2kZ+fz4EDB5g9e/ZpPUdpaSn5+fk0btw4LjNJkiQp9Zz2x7U1atSIRo0aMXToUK655hqaN28elwGWLFlCKBSisLCQRo0aAZCWlkZubi7jx48/rTf5zZ8/nyZNmtCsWTM++uijuMwlSZKk1BL1F3zk5+fHLYoBVq9eTXZ2dmUUA/Tv35/09HRWrVr1tefv3LmTF198kYceeihuM0mSJCn1RP0FH/FWVFTEsGHDItbS09Np0aIFRUVFX3v+Y489xpAhQ2jXrl3cZiopKYnbc+nMVbHP7ndqcL9Ti/udWtzv1BIOhyO+XC6ekh7GoVCIYDBYZT0YDHLw4MFTnvv++++zfv16VqxYEdeZtm/fHtfn05nN/U4t7ndqcb9Ti/udOtLT0xPyvEkP45P5ur8NfPXVVzz++ONMnjw54jaMeGjVqhWZmZlxfU6deUpKSti+fbv7nSLc79TifqcW9zu1bNmyJWHPnfQwDgaDhEKhKuuHDh065RvvFi1aRK1atRg0aFDl+UePHqW8vJxQKERGRkbMf5vIzMykXr16MZ2rs4/7nVrc79TifqcW9zs1JOo2CjgDwjgrK6vKvcRlZWXs3Lmzyr3H/2jbtm3s2LGD7OzsKo917dqVmTNn8t3vfjfu80qSJOnclPQw7t27N//93//N/v37ueCCC4C/f1lHWVkZffr0Oel5d9xxB0OHDo1Ye/755ykuLiY/P59WrVolcmxJkiSdY6L+uLZ4GzFiBA0aNGDChAmsWbOGwsJCZs2axeDBgyNupZgxYwZXXnll5c9ZWVl069Yt4p+LLrqIevXq0a1bNy6++OJkvBxJkiSdpZJ+xTgYDLJo0SLy8vKYPHkyGRkZ5OTkkJubG3FceXk5x48fT9KUkiRJOtclPYwBWrduzcKFC095TEFBAQUFBV97jCRJkhSLpN9KIUmSJJ0JDGNJkiQJw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCYDayR4AoLi4mLy8PD788EMyMzMZNGgQubm5ZGRknPScL7/8khdffJHVq1dTXFxM7dq1ad++Pffeey/t27evweklSZJ0Lkj6FeNQKMSYMWM4fPgw8+bN48EHH+Ttt9/moYceOuV5n332Ga+//jo9evRg7ty55OfnU15ezogRI9i0aVMNTS9JkqRzRdKvGC9ZsoRQKERhYSGNGjUCIC0tjdzcXMaPH09WVtYJz2vWrBkrV64kMzOzcq1Hjx5cf/31vPzyy+Tn59fI/JIkSTo3JP2K8erVq8nOzq6MYoD+/fuTnp7OqlWrTnpevXr1IqIYoG7dumRlZfH5558nbF5JkiSdm5J+xbioqIhhw4ZFrKWnp9OiRQuKioqieq4jR47wySefMGTIkGrNVFJSUq3zdXao2Gf3OzW436nF/U4t7ndqCYfDBAKBhDx30sM4FAoRDAarrAeDQQ4ePBjVcz311FOUlJQwatSoas20ffv2ap2vs4v7nVrc79TifqcW9zt1pKenJ+R5kx7GJxPt3wbefvttFi1axMMPP0zLli2r9Wu3atWqym0aOveUlJSwfft29ztFuN+pxf1OLe53atmyZUvCnjvpYRwMBgmFQlXWDx06dNI33v2zDz74gOnTpzN27FhGjhxZ7ZkyMzOpV69etZ9HZwf3O7W436nF/U4t7ndqSNRtFHAGvPkuKyuryr3EZWVl7Ny587TCeOPGjUyaNIkBAwZw//33J2pMSZIkneOSHsa9e/dm3bp17N+/v3Jt5cqVlJWV0adPn1OeW1RUxB133MHVV19Nfn5+Qv8GIUmSpHNb0sN4xIgRNGjQgAkTJrBmzRoKCwuZNWsWgwcPjrhiPGPGDK688srKn/fu3cvYsWOpU6cOt99+O5s2beIPf/gDf/jDH/j444+T8VIkSZJ0Fjsj7jFetGgReXl5TJ48mYyMDHJycsjNzY04rry8nOPHj1f+vHXrVv7yl78AcOutt0Yc27RpU95///2Ezy5JkqRzR9LDGKB169YsXLjwlMcUFBRQUFBQ+XO3bt3YvHlzokeTJElSikj6rRSSJEnSmcAwliRJkjCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSULSepAAABJvSURBVAIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJMIwlSZIkwDCWJEmSAMNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTgDAnj4uJixo4dS+fOncnOziYvL4/S0tLTOvett95iwIABdOjQgZycHN55550ETytJkqRzUe1kDxAKhRgzZgxNmjRh3rx57Nu3j/z8fA4cOMDs2bNPee6KFSuYNm0ad955Jz179uTdd9/lnnvuoUGDBvTq1auGXoEkSZLOBUkP4yVLlhAKhSgsLKRRo0YApKWlkZuby/jx48nKyjrpuU8//TQDBgzgvvvuA6B79+4UFxczb948w1iSJElRSfqtFKtXryY7O7syigH69+9Peno6q1atOul5u3btYtu2beTk5ESs5+TksHHjRvbt25ewmSVJknTuSfoV46KiIoYNGxaxlp6eTosWLSgqKjrpedu2bQOgTZs2EetZWVmEw2G2bdsWEdun4+jRowBs2bKFQCAQ1bk6+4TDYcD9ThXud2pxv1OL+51ajh49mrB9TnoYh0IhgsFglfVgMMjBgwdPel7FY/98bsOGDSMej0bFv+RatZJ+IV01IBAIkJ6enuwxVEPc79TifqcW9zu1BAKBczeMTyYcDp/Wi/7nYyr+1hjLv7AuXbpEfY4kSZLODUm/NBoMBgmFQlXWDx06dMIryRVOdmW44rlOda4kSZL0z5IexllZWVXuJS4rK2Pnzp2n/ESKinuLK+41rlBUVEQgEKhy77EkSZJ0KkkP4969e7Nu3Tr2799fubZy5UrKysro06fPSc9r3rw5bdq0Yfny5RHry5Yto2PHjlG/8U6SJEmpLelhPGLECBo0aMCECRNYs2YNhYWFzJo1i8GDB0dcMZ4xYwZXXnllxLlTpkzhnXfeYe7cufzud7/j8ccf54MPPmDKlCk1/TIkSZJ0lkv6m++CwSCLFi0iLy+PyZMnk5GRQU5ODrm5uRHHlZeXc/z48Yi1G2+8kdLSUp577jkWLlxIy5YtmTt3rl/uIUmSpKgFwhUf4yBJkiSlsKTfSiFJkiSdCQxjSZIkCcNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkoAUCuPi4mLGjh1L586dyc7OJi8vj9LS0tM696233mLAgAF06NCBnJwc3nnnnQRPq+qKZb+//PJLnnnmGb7zne/wjW98g+7duzN27Fg2bdpUQ1MrVtX5/V1h5cqVtG3blpycnARNqXipzn4fOHCAmTNn0qtXLzp06ED//v1ZsmRJgidWdcS630eOHGH27Nn07duXTp060a9fP5555hnKyspqYGrFaseOHTz88MMMGTKEK6+8Mqo/k+PRa0n/go+aEAqFGDNmDE2aNGHevHns27eP/Px8Dhw4wOzZs0957ooVK5g2bRp33nknPXv25N133+Wee+6hQYMGfpHIGSrW/f7ss894/fXXGTZsGFOmTOHYsWMsXryYESNGsGTJEtq3b1+Dr0Knqzq/vyuUlpaSn59P48aNEzytqqs6+3348GFGjx5N3bp1mTFjBhdeeCE7duzg6NGjNTS9olWd/Z45c2bl/8++7LLL2LhxI/PmzePgwYM89NBDNfQKFK0tW7awatUqOnXqRHl5Oaf7dRtx67VwCpg/f364U6dO4b1791au/eIXvwhffvnl4a1bt57y3AEDBoSnTJkSsXbbbbeFv/Od7yRkVlVfrPt9+PDh8JEjRyLWSktLwz179gxPmzYtYfOqeqrz+7vCU089FR45cmT4wQcfDA8aNChRoyoOqrPfc+bMCfft2zdcUlKS6DEVJ7Hu99GjR8MdOnQIP/300xHrjzzySDg7Ozth86r6jh8/Xvm/o/kzOV69lhK3UqxevZrs7GwaNWpUuda/f3/S09NZtWrVSc/btWsX27Ztq3IZPycnh40bN7Jv376EzazYxbrf9erVIzMzM2Ktbt26ZGVl8fnnnydsXlVPrPtdYefOnbz44oteQTpLVGe/ly5dyvDhw8nIyEj0mIqTWPc7HA5z/PhxGjRoELEeDAZP+wqkkqNWrejTNJ69lhJhXFRURFZWVsRaeno6LVq0oKio6KTnbdu2DYA2bdpErGdlZREOhysf15kl1v0+kSNHjvDJJ59U+b8BnTmqu9+PPfYYQ4YMoV27dokaUXEU637v2rWLPXv2EAwGueuuu7jqqqvo1q0bP/jBD6K+H101J9b9rlOnDjfddBMvvfQSGzZs4PDhw6xbt4433niDkSNHJnps1bB49lrK3GMcDAarrAeDQQ4ePHjS8yoe++dzGzZsGPG4ziyx7veJPPXUU5SUlDBq1Kh4jac4q85+v//++6xfv54VK1YkajzFWaz7vWfPHgCefPJJBgwYwIIFC9i6dSs//OEPOXr0KHl5eQmbWbGrzu/vmTNn8sgjj3DzzTdXro0ePZpJkybFfU4lVzx7LSXC+GTC4TCBQOBrj/vnYyr+M8zpnKszx+nud4W3336bRYsW8fDDD9OyZcsETqZE+Lr9/uqrr3j88ceZPHlyxH+m1dnp6/a7vLwc+PsVpPz8fACys7M5duwYTz75JFOnTuWiiy6qkVlVfafz5/ns2bP5zW9+w6xZs2jdujWbNm1i3rx5BINBpkyZUkOTqibFo9dS4laKYDBIKBSqsn7o0KET/k20wsn+plHxXKc6V8kT637/ow8++IDp06czduxY/7PbGS7W/V60aBG1atVi0KBBhEIhQqEQR48epby8nFAo5Ec6naFi3e/zzz8fgO7du0esd+/enfLy8qhvs1LNiHW///SnP/HjH/+YH/zgB9x888107dqVW2+9lalTpzJ//nz27t2byLFVw+LZaykRxllZWVX+0CsrK2Pnzp1V7l36RxX3qvzzvSlFRUUEAgHvOz1DxbrfFTZu3MikSZMYMGAA999/f6LGVJzEut/btm1jx44dZGdn07VrV7p27cqyZcsoKiqia9euLF26NNGjKwax7nfz5s2pU6dOlfWKK0qxvOFHiRfrfm/duhWAK664ImL9iiuu4NixY+zevTv+wypp4tlrKfEnQe/evVm3bh379++vXFu5ciVlZWX06dPnpOc1b96cNm3asHz58oj1ZcuW0bFjR//z6xkq1v2Gv/8muuOOO7j66qvJz8/3dpmzQKz7fccdd7B48eKIf3r16kXTpk1ZvHgx1113XU2MryjFut/p6en07NmTtWvXRqyvXbuW2rVrc+mllyZsZsUu1v1u2rQpQJUvaProo48AaNasWQKmVbLEtdei+nC3s9TBgwfD11xzTXjEiBHh1atXh996661wt27dwvfdd1/EcdOnTw9fccUVEWvLly8Pt23bNvzDH/4wvG7duvBjjz0Wbtu2bXjNmjU1+RIUhVj3e8+ePeE+ffqEe/bsGf7f//3f8Pr16yv/2bRpU02/DJ2m6vz+/md+jvGZrzr7vWHDhnD79u3D999/f3jNmjXhF198MdypU6fwY489VpMvQVGIdb+PHTsWHj58eDg7Ozv86quvhteuXRt+/vnnw507dw7ffffdNf0yFIUjR46E33nnnfA777wTHjVqVLhPnz6VP1d8nnUiey0l3nwXDAZZtGgReXl5TJ48mYyMDHJycsjNzY04rry8nOPHj0es3XjjjZSWlvLcc8+xcOFCWrZsydy5c/3WuzNYrPu9detW/vKXvwBw6623RhzbtGlT3n///YTPruhV5/e3zj7V2e+OHTsyf/585syZw7hx4zj//PMZNWoUU6dOrcmXoCjEut9paWk899xzPP300yxYsIA9e/ZwySWXMGrUKMaNG1fTL0NR2Lt3b5XfkxU/L168mG7duiW01wLhsJ90LUmSJKXEPcaSJEnS1zGMJUmSJAxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJakuPrZz35G27ZtT/jPE088AcCvf/1rHnjgAQYPHkz79u1p27ZtVL/Gn//858rnfOaZZ054zPTp0yuPkSSdnpT4SmhJqmn5+fm0adMmYu1f/uVfAFi5ciUbNmzgiiuuoE6dOmzatCmmX6N+/fq89dZbTJw4kVq1/v91jsOHD7NixQrOO+88vvzyy9hfhCSlGMNYkhLgsssuo0OHDid8LC8vrzJkH3300ZjDeODAgbz55pusXbuWnj17Vq4vX76c8vJy+vbtyy9+8YuYnjtWJSUlZGZm1uivKUnx4q0UklTD/vHqbnW0bt2aLl26sHTp0oj1pUuXcsMNN9CgQYMq5yxfvpzbbruNXr160bFjR2688UZmz57NkSNHqhy7YcMGxo0bR7du3ejQoQN9+/blscceq3z8mWeeoW3btmzatIkpU6bQtWtXbrjhhsrH33vvPW655RY6depEly5d+P73v8/69evj8tolKRG8YixJCVBeXs6xY8ci1mrXjv8fucOHD+fRRx/l4MGDNGzYkG3btrF+/XruvvtufvWrX1U5fvv27fTu3ZsxY8aQmZnJtm3bWLBgARs3bmTx4sWVx61Zs4bx48fTpk0bpk2bxiWXXMLu3bv54IMPqjzn5MmTGThwICNGjKgM7Lfffpvc3Fx69erFnDlzKCsr44UXXmD06NH85Cc/4Rvf+Ebc/11IUnUZxpKUADfffHOVtU2bNsU9jm+88UYee+wxli1bxsiRI/npT39Ks2bN6Nat2wnDeMKECZX/OxwOc/XVV5OVlcWoUaP49NNPadeuHfD3WzwuueQS3nzzTerWrVt5zrBhw6o857e//W2mTJlS+XN5eTlPPvkkl19+OQsWLKi8Qt6nTx9uuOEGZs+ezZIlS+L270CS4sUwlqQEeOKJJ8jKyopYizaK//mKc1paGoFAIGKtfv36DBgwgKVLl3LLLbfw85//nO9973tVjquwa9cunnrqKdatW8fevXsJh8OVj23bto127dpRXFzMzp07uffeeyOi+GT69esX8XNxcTGff/45Y8aMibhtpH79+vTr14/XX3/de5ElnZEMY0lKgKysrJO++e50tW/fPuLn/Px8brrppirHDR8+nO9973s899xz7Nu374THwN8/reJ73/sedevW5e6776ZVq1ZkZGTw17/+lUmTJlFaWgrAvn37ALj44otPa86KT9uosH//fgAuuuiiEx5bXl5OKBQyjCWdcQxjSTpD/fSnP434uVmzZic87t/+7d9o3bo1zz77LD169OCSSy454XHr1q3j888/56WXXuKb3/xm5fqhQ4cijmvUqBEAf/vb32Ka+4ILLgDgiy++qPLY559/Tq1atQgGgzE9tyQlkp9KIUlnqA4dOkT8UxGcJzJ+/HiuvfZabrvttpMeU3F7RXp6esT6P9/v27p1a1q0aMHSpUspKyuLeu7WrVtz8cUXs2zZsohbNY4cOcKvfvUrOnfu7NViSWckrxhLUg3bvXs3f/zjHwHYuXMnACtWrACgadOmMd2CMWTIEIYMGXLKY7p06ULDhg155JFHmDRpErVr1+btt99m8+bNVY59+OGHGT9+PDfffDO33norl1xyCX/5y19Ys2YNc+bMOeWvU6tWLe6//35yc3O56667uOWWWygrK2PhwoWEQiHuu+++qF+fJNUEw1iSatjvfvc7pk+fHrE2depUAIYOHUpBQUFCft0LLriA+fPn88QTT3D//feTmZnJ9ddfz9y5cxk6dGjEsddccw0vv/wyzz77LHl5eXz11Vf867/+K9ddd91p/VqDBw8mMzOT559/nnvuuYe0tDQ6derE4sWLufrqqxPx8iSp2gLhf/zvXJIkSVKK8h5jSZIkCcNYkiRJAgxjSZIkCTCMJUmSJMAwliRJkgDDWJIkSQIMY0mSJAkwjCVJkiTAMJYkSZIAw1iSJEkCDGNJkiQJgP8HVihK34+eGpUAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 800x600 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.9104  # Change this to the desired position\n",
    "\n",
    "plt.axvline(x=vertical_line_position, color='r',lw=2, linestyle='--', label='Vne')\n",
    "plt.text(x=vertical_line_position,y=max(hist),s='Native',ha='left', va='bottom')\n",
    "\n",
    "\n",
    "sns.set(style=\"whitegrid\")  # Set the style of the plot\n",
    "plt.figure(figsize=(8, 6))  # Set the figure size\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": 50,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "\"\\ndf_randomization_test = pd.DataFrame(list(zip(f1s, accuracy,p_word_list,n_word_list)),\\n               columns =['f1s', 'accuracy','p_word_list','n_word_list'])\\ndf_randomization_test.to_csv('t5_randomizationtest.csv')\\n\""
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "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('t5_randomizationtest.csv')\n",
    "'''"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_neutral = df_senti[df_senti['Sentiment']=='Neutral'].sample(n=20, random_state=random_seeds[0])\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": 37,
   "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.44820000000000004\n",
      "F1-Macro:  0.3386788812945307\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": 38,
   "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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DRgwoMgZ3alTp6pNmzbej9u1a6cOHTroySef1LJly7R582bNmzdPs2fP1o033lhkuTIEXnx8vN5//31ddtllioyMVI0aNXTppZdq1KhRqlevntHxAKDMunfv7nO8devWqlGjRpDTwMxKupNocnJyiS+44J8KMUd38eLFmjZtmiZOnKiIiAjdfPPNmjJlSpHt3G63XC6X92Or1arXX39dM2fO1Lx583Ty5Ek1aNBAw4cP1z333BPsL6NKio+P16JFi3T//fcrIyNDsbGxGjhwoNGxAMAvo0aN0rp164pMfQsPD9f9999vYCqYUa1atXwuoRoZGcl1QgFm8XB3Ba8dO3ZIktq3b29wksrlp59+0uLFi5WYmFji3F3gYm3evFmPP/64bDabli9fXuxmMUAgZGVl6Z133tGSJUsUFham119/XS1atDA6Fkzmyy+/1MMPP1xs/I477tCDDz5oQKLKpSx9jaJ7HoouUPE4nU7de++9Re6U2LhxYy1cuJCLHlEu8vLyNHr0aElnlxtjhQ+Uh6VLl2r+/Pk6ffq0JOnGG2/Uo48+yhJjpVCWvmb4HF0AuJC33nqr2O3Ajxw5omnTphmUCAAu3vDhw7VixQo1bdpUzZo109SpUym55YCiC6BCW7Vqlc/xb775xru+MwBURhEREQoPD1doqOGXTJkWRRdApeTxeIrdtQ8AgPNRdAFUaP369fM53qtXL59rOQMAcA5FF0CFduedd+qKK64oMhYXF6fHHnvMoEQAgMqCogugQgsPD9e8efP02muvqX79+mrSpIk++OADNW7c2OhoAIAKjtnPACqFbt26ee+6Z7PZDE4DAKgMOKMLAAAAU6LoAgAAwJQougAAnMftdquwsFBut9voKAAuEnN0AQD4X59++qlefvllHT9+XCEhIXrllVd07733ymq1Gh3N1Dwej/Lz842OEXTnf81V8euXzl5wbLFYyu35KboAAEj67rvviixb53a7tWTJEtlsNk2cONHAZOaXn5+v0aNHGx3DUOPGjTM6giEWLlyoiIiIcnt+pi4AACDprbfe8jn+7rvvqqCgIMhpAAQCZ3QBAJB0/Phxn+PZ2dk6c+aMatasGeREVdOD3e+UzVp16sm5W5mX59v3FY3TVagXvn8zKJ+r6hxJAABcQIcOHZSSklJsvEmTJqpRo4YBiaommzVUNmuY0TFgEkxd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qKgo2e127du3z+f2TqdTLpdLoaH8GkPpWSwh6tLjeiW0ukyOUydUq15jVYuyex/rfd1f1KlbP51MPaxoe6zqNrhEX/x7ns6V3PP9sv07dbtqoELDbEH+KlBZjB8/Xm3atNHKlSuVl5enq666SoMGDdKIESN8bp+ZmamGDRsqKSkpyEnNi78QAXL+WSWzraNbT1LLU5lK++WArDab6re7VD++8aHPbU9lZeqywYmymmx5tf92/jq6vMVXviZPnqxvv/222LjdbteCBQsUFlb5zzKWVnm/xXchLlfFuCL/YhUWOLX+i7f16/7tkjwKCbGqdccr1b33IO/PcpgtXBHVqisiIkquwgKddpzy/VyFTp05nano6jFB/ArKj1m+xxXN1VdfrauvvrrIWMuWLXXgwIFi2zZo0EB2uz1IyaoGc7cRg5hxHd3oerUVXa+29+OCnFyf27kLCuXxeEz39f83I2fFmvEtvgsZNWqUNm7cWGyKyLBhw7jbXhD98NUbRkcIiGPHjikjI8P7sdvt0q4t65V+bK9iY2OVlpam9PR079vKdru9xOlYYWFh2v7de0yfQZklJiZq3bp1ys0t+rd07NixXOgYYPxvwi+1W8T7HK/RqL5sUZFBTgMz69Gjh1588UU1aXJ2iTGr1aqxY8dq/PjxBidDZePxeJSVleXzsczMTGVlZSktLa3I3EmHwyG32+2z7NapU4eSC780b95cCxYs0NVXX63Q0FBFRkbqueee08CBA42OZjrmPu2GcpPQt6dSd+5TTvr/XSUfEhaq1oOuNTAVzOqGG27Q1VdfrcTERFmtVt1zzz2c9QgCs02Tyc/PV58+fXw+Vrt2bdWrV09Hjx4t9lheXp6WLVum9957Tzt27FC9evU0ZMgQde3atbwjG8bIaTJVRYsWLTRt2jSNHj1aktS7N3c+Kw8UXfglwh6tK+8frcObtpxdRzemhpr26qLourWMjgaTslgsXHgWZGabJhMREaEuXbro559/LvZYz549tWXLFp/75efnq27dunr00UfLOyKAAOOUCPxmi4pU82uvUNfRt6vtrf0ouQAqvH/84x+Kjo4uMhYXF6e//e1v6tatm899WrZsqZo1awYjHoAA4/QIAKDKaNu2rd5//3198MEHOnLkiNq0aaNbbrlFdrtdo0aN0tdff11kOcXw8HDdf//9BiYGcDEougCAKqV+/fqaMGFCsfE6dero7bff1vLly/XWW2/JZrPplVdeUevWrQ1ICSAQmLoAAMD/iomJ0ahRo9SkSRPVr19f8fG+V5gBUDlQdAEAAGBKFF0AAACYEkUXAAAApkTRBQAAgClRdAEAAGBKFF0AFV5+fr4+/vhj/fbbbzpx4oROnTpldCQAQCXAOrq4oDMnM3Rg3ffKOnJcUbVjFN/nctVsEmd0LFQhWVlZGjlypPbt2+cdGzx4sObPn6+2bdsamAwAUNFxRhclOp16Ut/+z0Id+vYnZR46qqM/7dTGmYt1Yk+K0dFQhbzxxhtFSq4kORwOJSUlGZQIAFBZcEYXJdq/ZqMKcvOKjHlcbv2y8mvVbZ2gk/t/1b5VG5R5+HdFxtRQs6u7qWmvywxKC7Nav369z/EtW7bI4XDIbrcHOREAoLKg6JYDT6FLbqNDBMCpA0d8jjt+S1Xa3gP6Ye478rjOfqVn0k5px3ufqzDPqfjelwczpiE8hS6jI1QZkZGRPsdDQ0MVFhYW5DQAgMqEolsOTrz/tdERAsLq9F3mrFarfnn7M2/JPd/+VRsUeTRTFoulvOOhihg0aJC2bt1abLx///4llmAAACTm6OIC6tSp43O8bt26ys/P9/lYYWGhXC7OdiJwhgwZoj//+c8KCfm/X1edO3fW1KlTDUwFAKgMOKMbIOHh4Vq4cKHRMQLu7bff1rx583Tq1ClVq1ZNd9xxhyZNmqRHHnlEq1evLrZ93bp1tWjRIlmtVgPSGiM8PNzoCKZmsVj0xBNPaMSIEZowYYJsNpvmz5+viIgIo6MBgN/S0tK0dOlSHTlyRGFhYdq7d686duxodCzToegGiMViMeUf3tGjR2v48OFKTU1VrVq1VK1aNUnSXXfdpa+//lpOp7PI9vfcc4+ioqKMiAqTa9CggWrWrGl0DAC4aMePH1diYqLS09MlSbm5ubr77rs1Y8YMXXnllQanM5cKUXQPHjyoadOm6aefflJkZKRuuukmTZkypVTF8aOPPtKcOXN09OhRNW3aVBMmTNANN9wQhNRVQ25urlavXq3ff/9dnTp1Us+ePWWxWNSuXTstXrxYM2fO1H/+8x/ZbDY9+uijGjJkiNGRAQAoE4/HU+KUvPIwf/58b8k9p7CwUDNnzlTXrl2DlkM6+66kma+rMbzoOhwOJSYmKi4uTrNmzdKpU6eUlJSkzMxMzZgx44L7fv7553r44Yd11113qVevXvryyy913333qXr16rwiCoCUlBSNHDlSJ06c8I716tVLr7/+umw2m3JycnTmzBm5XC65XC5lZ2cbmBZmtnHjRs2cOVO7du2SzWbTsmXLNGrUKKNjwYQyMzO1fPly79vJv/76q1q1amV0LJQjj8ejp59+uth63eXp119/9Tl+8OBBJSYmBnX6X4sWLfTkk0+atuwaXnSXL18uh8OhFStWKDY2VtLZq/qnTJmicePGKSEhocR9Z86cqeuvv17/+Mc/JEk9evTQwYMHNWvWrCpXdMvj1egTTzxRpORKZwvHokWL1LFjR919990qLCyUJDmdTj3//PNyOp0aOXJkQHP8EbO/Gq1ogn3mY9u2bRo3bpz3Iken06kZM2aooKBAd955Z9BySBxrZpeWlqY777xTx44d844lJiZq9uzZ6tatm4HJYDahoaHFpv5JZ6dB8jsmsCwej8djZIDhw4erevXqeu2117xjTqdTl112me677z6NHj3a535HjhzRtddeq5dffln9+vXzjn/00Ud65JFH9N1333mLc2nt2LFDktS+fXs/vhLjlMer0cLCQm3bts3nY1FRUQoLC1NmZmaxx0JDQ9WhQ4eg/qCa/dVoRWLUmY+srKxi46GhoWrTpg3HmokF+0XVSy+9pHfeeafYeIsWLfTmm28GLYfEi6pgC/axtn79ej366KPFxocMGaLJkycHLYdUOY+1svQ1w8/opqSkaPDgwUXGbDabmjRpopSUkm81e+DAAUlSs2bNiownJCTI4/HowIEDZS660tmDPScnp8z7Gcnj8cjtDu4tKvLy8nyOn1teLDQ0eIeW2+1WTk5OpftBrYyMONb+aCk7jjVz8ng8mj59+gX/DgRaSZ9r3759QX87uXnz5nrooYc41kzqqquu0qRJk7R48WJlZWUpLCxM119/ve6+++6g/47Nzc0N6ucLBI/HU+qfDcOLbkm38LTb7T7P4pxz7rH/3rdGjRpFHi+rgoIC7dmzx699jTRw4EDvNIJAefHFF7Vz585i47feequSk5O1efPmYo/Fxsbq3nvvLbLmaXkLDQ3VL7/8ErTPV9WVx7F2IXPnztX3339fbDwmJoZjzcQ8Hk/Q/wCXVGSNeDs5JydHe/bsoeiaWNu2bfXss88qLS1NNWrUUFRUVFBf2FV2Nput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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": 60,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093833,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "1MTPlFIVEd6y",
    "tags": []
   },
   "outputs": [],
   "source": [
    "max_f1_index = f1s.index(max(f1s))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "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": 62,
   "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.9096000000000001\n",
      "F1-Macro:  0.9068526216995837\n"
     ]
    },
    {
     "data": {
      "image/png": "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0S1PZdr63Llz9e233+rZZ59Vu3bttHv3bs2bN08ul0sPP/ywT49rs9nUvn17n/ati07/a7RTp05yOBwGpgEAoPbgNdQ3MTExld7W8KLrcrmUkZFRZjwzM7PcD6JJ0v79+7V48WK98cYbGjRokCSpd+/eslgsmjNnju644w41atSoynksFotCQ0OrvF9dFRT05zLvkJAQOZ1OA9MAAFB78Brqm8ouW5BqwIfRIiMjy6zFzc/PV3x8fIVF948236VLl1LjXbp0UWFhoY4ePer/sAAAAKg1DC+6AwYM0A8//KDU1NSSsXXr1ik/P18DBw4sd7+WLVtKknbv3l1q/Ndff5UktWrVqhrSAgAAoLYwfOnC6NGjtWzZMk2aNEmTJk3SyZMnNXv2bA0bNqzUjO7UqVMVHR2tPXv2SJK6d++unj17avr06Tpx4oTatWunXbt26Y033tD1119f6nRlAAAAqHsML7oul0tLlizRzJkz9dBDD8npdGro0KGKiooqtV1xcbGKiopKvrZarXrzzTf1yiuv6O2339aJEyfUvHlz3XnnnfrrX/8a6G8DAAAANYzhRVeS2rVrp0WLFlW4zezZszV79uxSY40aNdIzzzxTndEAAABQSxm+RhcAAACoDhRdAAAAmBJFFwAAIMDS09O1bNkyJSQkKDk5WYcPHzY6kilRdAEAAALoxIkTuuuuu/Tmm28qKytLqampGjdunLZu3Wp0NNOh6AIAAATQe++9V+bCVm63Wy+//LJBicyLogsAABBAP/74o9fx3377Tenp6QFOY24UXQAAgABq0KCB13GHwyGn0xngNOZG0QUAAAigkSNHeh2//vrr5XA4ApzG3Ci6AAAAATRkyBDdd999pWZvr7jiCv3tb38zMJU5UXQBAAAC7L777tOqVat07rnnql27dpo5c6ZCQkKMjmU6NeISwAAAAHVNWFgY5baaMaMLAAAAU2JGFwAAGMrj8cjtdhsdI+BO/57r4vcvnTrThMViqbb7p+gCAABDud1ujR8/3ugYhpo4caLREQyxePHiaj2lGksXAAAAYErM6AIAgBrj0T53yW6tO/XE4/FIUrW+fV/T5BcVas6P7wXkserOMwkAANR4dmuw7Fab0TFgEixdAAAAgClRdAEAAGBKFF0AAACYEkUXAAAApkTRBQAAgClRdAEAAGBKnF4MQI2RkJCglStX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AAAwJYouAAAATImiCwAAAFOi6AIAAMCUKLoAAAAwJYougBovKytL//rXv3To0CEdO3ZMCQkJRkcCANQCwUYHAICKpKSk6M4779ShQ4dKxm699Va99dZbuvDCCw1MBgCo6ZjRBVCjLV68uFTJlaTc3Fy98MILBiUCANQWFF0ANdrmzZu9jv/6669KS0sLcBoAQG1C0QVQo7lcLq/jdrtdTqczwGkAALUJRRdAjTZixAiv4zfccANFFwBQIYougBrtpptu0j333CO73V4ydvnll+vxxx83MBUAoDag6AKo8R555BF99tlnOu+889S5c2e9/PLLql+/vtGxAAA1HKcXA1ArhIeHKywszOgYAIBahBldAAAAmJJPM7o5OTn66aef9Msvv+j48ePKy8tTeHi42rdvrz59+qhDhw7+zgkAAABUSZWK7sGDB7V48WKtXbtWOTk5slgscrlcstvtysjIkNvtlsViUceOHTVmzBiNHDlSQUFMGgMAACDwKl10n3/+ef3rX/9Su3btNGnSJF1yySXq2rWrgoP/vIukpCTt2LFDX3/9tZ577jm9++67mjVrlnr06FEt4QEAAIDyVLro7tmzR++884569+5d7jZNmzbVtddeq2uvvVZZWVl699139csvv1B0AQAAEHCVLrrLli2r0h3Xr19fDz74YJUDAQAAAP7g9wW0x48f1549e/x9twAAAECV+HTWhYSEhHJv++qrr7RgwQJt2bLF51AAAADA2fKp6F511VWyWCzl3t6uXTufAwEAAAD+4FPRff7558sU3ZycHG3dulXr16/X7Nmz/RIOAAAA8JVPRXfkyJFex++44w7Nnj1bL774opYuXXpWwQB45/F45Ha7jY4RcKd/z3Xx+5ckh8NR4btpAIDSfCq6FRk4cKA++OADf98tgP/P7XZr/PjxRscw1MSJE42OYIjFixfL6XQaHQMAag2/n3UhNTVVjRo18vfdAgAAAFXitxnd4uJi/fbbb3rzzTc1efJkf90tgAo826e57Na681a2x+ORpDr19n1+kUf/9+Mxo2MAQK3kU9Ht3LlzuS80Ho9Hjz/+uB5//HFJp16QOK8uUD3sVoscVr+/MYMapdjoAABQa/lUdB944IE6NaMCAACA2senovvQQw/5OwcAAADgV7znCQAAAFOqdNF9+umnlZycXKU7/+qrr7R69eoqhwIA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0a0GnsIiFRsdwo/soSHqfc8t2h39tTKOJMoSZFHjTpFyZ2Tql3c/Ltlu/xeb1OevoxXWrImBaQPDU1hkdAQAfrbz5/WlSq4k5eVmafM3/9awv0w2KBWAs0HRrQZJ/95gdIRq0eGcliqIaKqgoCAdP35cyceOl7o9PztH2xesUKdOnQxKCAC+OxS7y+v4scO/K9+dK7sjJMCJAJwtPoyGKrHZbLJarUpLS/N6e1ZWloqKmO0EUPtYrd7nfixBQbJYeLkEaiNmdP3E4XBo8eLFRscImDFjxmjnzp1lxoODgzV//nyFhtadD284HA6jIwDwg/Zdeivp2MEy423bny+bnf/nQG1E0fUTi8Uip7PufBBr+PDhXovuoEGDFBERYUAiANWpqKjA6AjVrlP3vko6FqeYvVtLxho3baVu51+ub79YppSkIwpr0Fjdeg3UOS3aGhe0mtSF3zHqHooufHLbbbdp165dio6OLhnr2rWrnnrqKQNTAaguP61/1+gIAWG3SJGRkcrNzS1ZqvXZR6+puPjUR4xPJB1R3O87dO655yosLMzgtADOhEVH8InVatULL7ygVatWqW3bturYsaM++OADNW7c2OhoAHBWHA6HGjZsqHr16unEiRMlJfd0ycnJBiQDUFXM6OKMcnJylJiYqObNmyskpPSnjs877zw1atTIoGSoK9xut9asWaMjR47IbrcrJSVFLVq0MDqW6dW1zx78we12a+LEiZKk0NBQZWSUvdR5Xl6e5s+fb9o1+mb9vlD31IiiGxcXp5kzZ2rbtm0KCQnRDTfcoKioqEqteV21apUWLFigo0ePqk2bNnrggQd03XXXBSC1+Xk8Hr3yyit67733lJ2drfr162vcuHF68MEHZbFYjI6HOiIjI0Njx47V/v37S8ZGjRqlRYsWqWvXrgYmMz+zfvYgPz9fGzZsUEJCgrp3767evXuXu22zZs2UmJhYZjwiIkIul4tjISqloKBANpvN6Bh1kuFF948XsRYtWmjevHlKSUnRrFmzlJaWprlz51a47xdffKHHH39c9913n/r376+vv/5ajzzyiMLCwnTZZZcF6DswryVLlmj+/PklX2dlZem1115Tw4YNNWbMGKWkpOi9997T77//LofDoZiYGHXv3t3AxAgEj8cjt9t95g395O233y5VcqVTx42ZM2cGfLbR4XBQbGq5I0eO6L777lNCQkLJWN++ffXKK6/I4XAoJSVFH3zwgeLj42Wz2TR27Fjt2LGjzP3cdtttPBdQoeLiYi1evFgrVqxQSkqKunTpokmTJqlfv36SpMOHD+udd97RoUOHFBwcrF9++UWXXnqpwanNx+LxeDxGBnjrrbf0xhtv6Jtvvin5tP6aNWsUFRWlzz77TJGRkeXue91116ljx4565ZVXSsYmTJigzMxMrVixospZdu06dbLwHj16VHlfM7rmmmsUHx9fZrxdu3ZasmSJ/vKXv+jYsWMl43a7XW+++ab69+8fyJgIII/HoxkzZpQpntVp3759ysvL83pb9+7dZbVaA5alY8eOmj59OgWnFnvggQe0efPmMuOTJ0/W9ddfr7Fjx5aawbXb7br55pu1bt06JScnq379+rrttts0ceJEBQXxMReU7/XXX9c777xTasxqtWrRokVyuVwaN25cqWUxQUFBev7553X11VcHOmqtU5W+ZviM7saNG9WvX79Sp6QaPHiwpk6dqu+++67conv48GEdOHBAf/vb30qNDx06VE888YRSUlLq1GmuqmOWLSkpyet4cnKy5s+fX6rkSqfeDnzhhRd8+iPjbDDLZm7llQmLxcLv3eT8fVzLzs7W999/7/W2L7/8UseOHSuzTCE/P18///yzVq1apZSUFDVo0EAOh0P5+fl+y+UNx7XA8vdzze12e30tLCoq0rJly+R0Osus/S4uLtZrr72m/v37B/R3b/bnmuFFNzY2VqNGjSo1Zrfb1bp1a8XGxpa734EDBySd+jDU6SIjI+XxeHTgwAGfiq7H41FOTk6V9zOSx+PR7NmzK/x5+cJut3udSbNarVq1apXXffbt26e77rpLwcGBe2q1b99ejz32mKn/o9YkU6ZMqfYX+dN98sknevHFF8uMDxo0SE8//XTAckin/k/k5uYG9DHrquo4rhUVFam8NzEPHjyouLg4r7f9/vvvGj9+PMc1k6qO51pBQYGys7O93rZp06Zyn4dHjhzRuHHjAvpOVW18rnk8nkrnNbzoZmRkyOVylRl3uVxKT08vd78/bvvffRs0aFDq9qoqKCjQ3r17fdrXKB6Pp1pefFu0aKGsrKxSp9YJCgpS8+bNdfToUa8lOCgoKOBv5+Xk5Gjv3r216j8pKq979+666qqrtGHDhpIXh06dOmnEiBElf/DCfKrjuGa1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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": 63,
   "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": [
       "['raft_foundation',\n",
       " 'sulky',\n",
       " 'torch',\n",
       " 'northwestern northwesterly northwest',\n",
       " 'table-tennis_racquet table-tennis_bat pingpong_paddle',\n",
       " 'script playscript book',\n",
       " 'flow',\n",
       " 'rock_of_gibraltar gibraltar calpe',\n",
       " 'creek_confederacy',\n",
       " 'usher show#']"
      ]
     },
     "execution_count": 63,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "n_words_spurious[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {
    "executionInfo": {
     "elapsed": 33,
     "status": "aborted",
     "timestamp": 1695329093836,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "lvMoMpyEXQVt",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['individualist',\n",
       " 'instantiate',\n",
       " 'buhl boulle boule',\n",
       " 'optician lens_maker',\n",
       " 'pocket_borough',\n",
       " 'discovered_check',\n",
       " 'solanum_jasmoides potato_vine',\n",
       " 'genus_ascophyllum ascophyllum',\n",
       " 'readying preparation',\n",
       " 'enemy']"
      ]
     },
     "execution_count": 64,
     "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": 65,
   "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": 66,
   "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.6136972224168726 \n",
      "Negative Acc: 0.47208117041012876\n",
      "------------------------------------------------------------------------\n",
      "Dialogue.csv is Positively Spurious.\n",
      "Positive Acc: 0.8351361390051322 \n",
      "Negative Acc: 0.22123976624163494\n",
      "------------------------------------------------------------------------\n",
      "Indian.csv is Positively Spurious.\n",
      "Positive Acc: 0.8701290875163836 \n",
      "Negative Acc: 0.21265338798098568\n",
      "------------------------------------------------------------------------\n",
      "Orientation.csv is Positively Spurious.\n",
      "Positive Acc: 0.6161700050169954 \n",
      "Negative Acc: 0.36474409599026825\n",
      "------------------------------------------------------------------------\n",
      "Colored.csv is Negatively Spurious.\n",
      "Positive Acc: 0.2925271493048744 \n",
      "Negative Acc: 0.9020770287189714\n",
      "------------------------------------------------------------------------\n",
      "occupations1950_nonprofessional.csv is Neutral.\n",
      "Positive Acc: 0.5765121200494109 \n",
      "Negative Acc: 0.4575394355242422\n",
      "------------------------------------------------------------------------\n",
      "Society.csv is Positively Spurious.\n",
      "Positive Acc: 0.8527126307808893 \n",
      "Negative Acc: 0.19554507931956053\n",
      "------------------------------------------------------------------------\n",
      "Money.csv is Positively Spurious.\n",
      "Positive Acc: 0.7589139411555459 \n",
      "Negative Acc: 0.2462793512787292\n",
      "------------------------------------------------------------------------\n",
      "Woman.csv is Neutral.\n",
      "Positive Acc: 0.41617614634383765 \n",
      "Negative Acc: 0.5352291213138294\n",
      "------------------------------------------------------------------------\n",
      "Activist.csv is Positively Spurious.\n",
      "Positive Acc: 0.8496465257263415 \n",
      "Negative Acc: 0.3065006676733393\n",
      "------------------------------------------------------------------------\n",
      "Retarded.csv is Positively Spurious.\n",
      "Retarded.csv is Negatively Spurious.\n",
      "Positive Acc: 0.6870531466134295 \n",
      "Negative Acc: 0.7085871064919885\n",
      "------------------------------------------------------------------------\n",
      "Chubby.csv is Neutral.\n",
      "Positive Acc: 0.5732558096025331 \n",
      "Negative Acc: 0.5609261163623805\n",
      "------------------------------------------------------------------------\n",
      "Jew.csv is Positively Spurious.\n",
      "Positive Acc: 0.8734662758932434 \n",
      "Negative Acc: 0.14223565401348498\n",
      "------------------------------------------------------------------------\n",
      "Homosexual.csv is Positively Spurious.\n",
      "Homosexual.csv is Negatively Spurious.\n",
      "Positive Acc: 0.8382673889790906 \n",
      "Negative Acc: 0.65922306331607\n",
      "------------------------------------------------------------------------\n",
      "Misgendering.csv is Positively Spurious.\n",
      "Positive Acc: 0.8862726511318753 \n",
      "Negative Acc: 0.12902256041115745\n",
      "------------------------------------------------------------------------\n",
      "Marriage.csv is Positively Spurious.\n",
      "Positive Acc: 0.8785863081996339 \n",
      "Negative Acc: 0.2622910918722694\n",
      "------------------------------------------------------------------------\n",
      "Industry.csv is Positively Spurious.\n",
      "Positive Acc: 0.875152573580927 \n",
      "Negative Acc: 0.12542671682357384\n",
      "------------------------------------------------------------------------\n",
      "Oriental.csv is Neutral.\n",
      "Positive Acc: 0.37620517464796505 \n",
      "Negative Acc: 0.3708621206144845\n",
      "------------------------------------------------------------------------\n",
      "occupations1950_professional.csv is Positively Spurious.\n",
      "occupations1950_professional.csv is Negatively Spurious.\n",
      "Positive Acc: 0.706959316008044 \n",
      "Negative Acc: 0.7250656797421826\n",
      "------------------------------------------------------------------------\n",
      "Gender.csv is Positively Spurious.\n",
      "Positive Acc: 0.6650321536142522 \n",
      "Negative Acc: 0.5635507217940191\n",
      "------------------------------------------------------------------------\n",
      "Media.csv is Positively Spurious.\n",
      "Positive Acc: 0.8398118811126412 \n",
      "Negative Acc: 0.21733891934893873\n",
      "------------------------------------------------------------------------\n",
      "Islam.csv is Positively Spurious.\n",
      "Positive Acc: 0.8752246189142465 \n",
      "Negative Acc: 0.12711335072583022\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
}
