{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "executionInfo": {
     "elapsed": 5,
     "status": "ok",
     "timestamp": 1695324378707,
     "user": {
      "displayName": "m m",
      "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 XLNetModel, XLNetConfig, XLNetTokenizer\n",
    "from transformers import RobertaTokenizer, RobertaModel, RobertaConfig\n",
    "\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": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "MLk4JWizs4S9",
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_train = pd.read_csv('/home/m_nsu/ICLR/Datasets/IMDB/train.csv')\n",
    "df_val = pd.read_csv('/home/m_nsu/ICLR/Datasets/IMDB/val.csv')\n",
    "df_test = pd.read_csv('/home/m_nsu/ICLR/Datasets/IMDB/test.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "id": "YWiFI0a9QqEa",
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_senti = pd.read_excel('/home/m_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": "m m",
      "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": "m m",
      "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": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "UmEtmaFNrakz",
    "tags": []
   },
   "outputs": [],
   "source": [
    "MAX_LEN = 200\n",
    "RANDOM_SEED = 42\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 18,
     "status": "ok",
     "timestamp": 1695323756840,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "6oWORty0p8Xo",
    "outputId": "cb12350b-753a-4c61-c7e8-3c9427f000e9",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n"
     ]
    }
   ],
   "source": [
    "PRE_TRAINED_MODEL_NAME = 'roberta-large'\n",
    "config = RobertaConfig.from_pretrained(PRE_TRAINED_MODEL_NAME)\n",
    "tokenizer = RobertaTokenizer.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 = RobertaModel.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": "m m",
      "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": "m m",
      "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": 14,
   "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": 15,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 30,
     "status": "ok",
     "timestamp": 1695323767308,
     "user": {
      "displayName": "m m",
      "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": 16,
   "metadata": {
    "executionInfo": {
     "elapsed": 3468,
     "status": "ok",
     "timestamp": 1695323770756,
     "user": {
      "displayName": "m m",
      "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": 17,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 27,
     "status": "ok",
     "timestamp": 1695323770759,
     "user": {
      "displayName": "m m",
      "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": 18,
   "metadata": {
    "executionInfo": {
     "elapsed": 24,
     "status": "ok",
     "timestamp": 1695323770760,
     "user": {
      "displayName": "m m",
      "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": 19,
   "metadata": {
    "executionInfo": {
     "elapsed": 6,
     "status": "ok",
     "timestamp": 1695325189268,
     "user": {
      "displayName": "m m",
      "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": 20,
   "metadata": {
    "executionInfo": {
     "elapsed": 24,
     "status": "ok",
     "timestamp": 1695323770761,
     "user": {
      "displayName": "m m",
      "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": 21,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 6,
     "status": "ok",
     "timestamp": 1695325187523,
     "user": {
      "displayName": "m m",
      "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": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data = next(iter(train_data_loader))\n",
    "data.keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {
    "executionInfo": {
     "elapsed": 3,
     "status": "ok",
     "timestamp": 1695325688712,
     "user": {
      "displayName": "m m",
      "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 = RobertaModel.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": 23,
   "metadata": {
    "id": "HWZ37gsztWzL",
    "tags": []
   },
   "outputs": [],
   "source": [
    "model = Classifier()\n",
    "model = model.to(device)\n",
    "clear_output()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {
    "executionInfo": {
     "elapsed": 22,
     "status": "ok",
     "timestamp": 1695325221207,
     "user": {
      "displayName": "m m",
      "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": 25,
   "metadata": {
    "executionInfo": {
     "elapsed": 20,
     "status": "ok",
     "timestamp": 1695325221207,
     "user": {
      "displayName": "m m",
      "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": 26,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 21,
     "status": "ok",
     "timestamp": 1695325221208,
     "user": {
      "displayName": "m m",
      "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": 27,
   "metadata": {
    "executionInfo": {
     "elapsed": 12,
     "status": "ok",
     "timestamp": 1695325221208,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "NwvA-zp7vqc1",
    "tags": []
   },
   "outputs": [],
   "source": [
    "#del test\n",
    "torch.cuda.empty_cache()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {
    "executionInfo": {
     "elapsed": 603,
     "status": "ok",
     "timestamp": 1695325221800,
     "user": {
      "displayName": "m m",
      "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": 29,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 15,
     "status": "ok",
     "timestamp": 1695325221800,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "NHFM3QUhg3n0",
    "outputId": "602bd955-db78-44a6-931e-e5e901bb1856",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0.9874, 0.9871],\n",
       "        [0.9843, 0.9848],\n",
       "        [0.9839, 0.9840],\n",
       "        [0.9831, 0.9835],\n",
       "        [0.9866, 0.9864],\n",
       "        [0.9842, 0.9847],\n",
       "        [0.9826, 0.9827],\n",
       "        [0.9767, 0.9762],\n",
       "        [0.9822, 0.9819],\n",
       "        [0.9857, 0.9857],\n",
       "        [0.9845, 0.9844],\n",
       "        [0.9847, 0.9847],\n",
       "        [0.9820, 0.9820],\n",
       "        [0.9816, 0.9816],\n",
       "        [0.9870, 0.9868],\n",
       "        [0.9804, 0.9803],\n",
       "        [0.9835, 0.9839],\n",
       "        [0.9890, 0.9895],\n",
       "        [0.9857, 0.9855],\n",
       "        [0.9856, 0.9854],\n",
       "        [0.9825, 0.9827],\n",
       "        [0.9864, 0.9865],\n",
       "        [0.9832, 0.9829],\n",
       "        [0.9809, 0.9810],\n",
       "        [0.9891, 0.9890],\n",
       "        [0.9861, 0.9863],\n",
       "        [0.9871, 0.9869],\n",
       "        [0.9882, 0.9881],\n",
       "        [0.9827, 0.9830],\n",
       "        [0.9837, 0.9836],\n",
       "        [0.9899, 0.9909],\n",
       "        [0.9849, 0.9841]], device='cuda:0', grad_fn=<TBackward0>)"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "outs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 1022,
     "status": "ok",
     "timestamp": 1695325845248,
     "user": {
      "displayName": "m m",
      "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": 31,
   "metadata": {
    "executionInfo": {
     "elapsed": 8,
     "status": "ok",
     "timestamp": 1695325845969,
     "user": {
      "displayName": "m m",
      "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": 32,
   "metadata": {
    "executionInfo": {
     "elapsed": 9,
     "status": "ok",
     "timestamp": 1695325845971,
     "user": {
      "displayName": "m m",
      "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": 33,
   "metadata": {
    "executionInfo": {
     "elapsed": 8,
     "status": "ok",
     "timestamp": 1695325846655,
     "user": {
      "displayName": "m m",
      "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": 34,
   "metadata": {
    "executionInfo": {
     "elapsed": 8,
     "status": "ok",
     "timestamp": 1695325846656,
     "user": {
      "displayName": "m m",
      "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": 35,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000
    },
    "executionInfo": {
     "elapsed": 3203929,
     "status": "ok",
     "timestamp": 1695329051836,
     "user": {
      "displayName": "m m",
      "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.4778975872755051 accuracy 0.846875\n",
      "Val   loss 0.42859320940485424 accuracy 0.8846\n",
      "\n",
      "Epoch 2/8\n",
      "----------\n",
      "Train loss 0.4241860244750977 accuracy 0.888625\n",
      "Val   loss 0.42198177185028224 accuracy 0.8882\n",
      "\n",
      "Epoch 3/8\n",
      "----------\n",
      "Train loss 0.415394753909111 accuracy 0.8954500000000001\n",
      "Val   loss 0.42254803818502246 accuracy 0.8872\n",
      "\n",
      "Epoch 4/8\n",
      "----------\n",
      "Train loss 0.4119105999469757 accuracy 0.898475\n",
      "Val   loss 0.41206184731926887 accuracy 0.9\n",
      "\n",
      "CPU times: user 1h 54min 51s, sys: 8.02 s, total: 1h 54min 59s\n",
      "Wall time: 1h 55min 3s\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(4):\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(), 'roberta_best_model_state.bin')\n",
    "    best_accuracy = val_acc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {
    "executionInfo": {
     "elapsed": 51,
     "status": "ok",
     "timestamp": 1695329137842,
     "user": {
      "displayName": "m m",
      "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": 37,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 480
    },
    "executionInfo": {
     "elapsed": 2888,
     "status": "ok",
     "timestamp": 1695329143450,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "aUQbxyTEAPhM",
    "outputId": "b103ca88-1886-4f16-ea21-5b966a08fe7c",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHFCAYAAAAOmtghAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAPYQAAD2EBqD+naQAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nOzde1xUdf7H8feZAQYQobwB5o28FZpWYoktWbZiWpbtblrtpmi1S1ZqVG5u+yszi2rLTE1qN9HKtqxVW9u1jE1TN91KA9sSL2sYmhhhCWjKZeb8/kBGRm4zCA4cX8/HYx7M+c73nPOZs2ebt9/znTOGaZqmAAAALMLm7wIAAAAaE+EGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGsBDDMLx6fPTRR42yv2PHjskwDD355JMNWn/QoEG6+uqrG6UWX0VFRelXv/pVvf3ef/99GYah//znPz5tf+7cuVqyZElDywNwCgL8XQCAxrNp0yaP5ccee0xr167VmjVrPNpjY2MbZX8Oh0ObNm1Sly5dGrT+woULZbfbG6WWphIfH69Nmzapb9++Pq03d+5c9ejRQ7/5zW+aqDIAtSHcABYyaNAgj+X27dvLZrNVa69NaWmp7Ha714HDMAyvt12TPn36NHjd0yUiIuKU3mNjcjqdcjqdCgoK8ncpQLPGZSngDFV5uWXp0qWaPHmyoqOjFRwcrL179yovL0/Jyck6//zz1apVK0VGRurnP/95tZGhmi5LvfjiizIMQx9//LHuuOMOtW3bVu3atdONN96o7777zmP9ky9Lbd++XYZhaN68eXrqqafUtWtXhYWF6bLLLtOWLVuqvYcFCxaoR48ecjgcuuCCC/T222/rpptu0nnnnef1cXj33Xd14YUXKiQkRLGxsdUuJdV0WWrnzp268cYbFR0dLYfDoaioKA0bNkxfffWVpIpLXrt379bq1avdlwKr1pSTk6Obb75Z7du3l8PhUGxsrObOnauqv2NceSzmzJmjGTNmqFu3bgoKCtKqVasUFhamKVOmVHsvO3bskM1m07x587x+/4AVMXIDnOHuu+8+XX755Xr55Zflcrl09tlnKzc3V4GBgXr00UcVGRmp4uJivf3220pISNCGDRsUHx9f73bHjx+v6667Tm+88YZycnI0bdo0TZgwQatWrap33dmzZ+uCCy7QvHnz5HQ69dBDD2nEiBHKyclRq1atJFVc9pkyZYpuuukmzZ07Vz/88IOmT5+usrIyhYSEePXeP/vsM+3YsUMPPvig2rVrp7S0NN16663q1auXLrnkkhrXMU1TV199tRwOh5555hl17txZBQUF2rBhgw4dOiRJWrVqla6//np16tRJzz33nCS5a8rLy1N8fLwMw1Bqaqo6deqkd955R1OmTNGePXs0e/Zsj/0988wzio2N1ezZsxUWFqbY2FiNGzdOr7zyip544gn38ZCkF154Qa1atdL48eO9ev+AZZkALGv8+PFmq1atanztvffeMyWZiYmJ9W6nvLzcLCsrMy+77DLz5ptvdrcfPXrUlGSmpqa629LS0kxJZkpKisc2Zs6caUoyf/jhB3fbpZdeag4fPty9nJ2dbUoy4+LiTJfL5W5fv369KclcsWKFaZqmWVpaarZt29YcMmSIxz7+97//mXa73ezdu3e97ykyMtJs1aqVuX//fnfb4cOHzdatW5tTpkxxt1Uep02bNpmmaZr79u0zJZkvvvhindvv3r27x3urNHXqVNMwDDMrK8ujfcKECabNZjNzcnI8jsX5559vlpeXe/TNzs42DcMw09LS3G3FxcVmeHi4eeedd9b73gGr47IUcIb75S9/Wa3NNE3NmzdPF110kYKDgxUQEKDAwEB9/PHHys7O9mq71113ncdyv379JEm5ubn1rnvttdfKMIxq637zzTeSpC+//FIHDx7UmDFjPNbr3r27Bg4c6FV9kjRw4EBFR0e7l1u1aqXu3bu791OTqKgodenSRU888YSef/55bd26VS6Xy+t9rlmzRhdddJH69+/v0Z6UlCSXy1Xtm2yjR4+uNgfqvPPO07Bhw/TCCy+421599VUVFRXprrvu8roWwKoIN8AZruqHe6XU1FRNnjxZCQkJWr58uT755BN99tlnGjp0qI4ePerVdtu2beux7HA4JMmr9etb9+DBg5KkyMjIauvW1Obtfir3VVeNdrtda9eu1ZVXXqnHH39cF154oSIjI5WSkqIjR47Uu8+DBw/WeMw7duzofr2qmvpK0pQpU/Tll19q/fr1kiouSV155ZUtYpI20NSYcwOc4aqOkFRasmSJrr76as2dO9ejvbCw8HSVVafKUHLyBGVJOnDgQJPv/9xzz9XixYslVUz8ffPNN/XYY4/J5XJpzpw5da7btm1b5eXlVWvfv3+/JKldu3Ye7TX97yNJI0aMUM+ePTV//nyVl5dr27ZtmjlzZgPeDWA9jNwAqMYwDPdoSaXNmzfr888/91NFnvr27as2bdpo6dKlHu27d+/W5s2bT2st5513nmbMmKFevXp5HJ/aRoCuuuoqZWVlub9ZVenVV1+VzWbTFVdc4dV+DcPQPffcoxUrVuiRRx5Rp06dNHr06FN6L4BVEG4AVHPttdfq3Xff1axZs7RmzRrNnz9f11xzjbp16+bv0iRJgYGBeuSRR7R+/XrdfPPNeu+997RkyRINHz5cHTt2lM3WdP9p+/TTT3XllVfqhRde0OrVq7VmzRo9+OCD2rFjh4YNG+bud8EFF2jz5s3629/+ps2bN7vDzAMPPKD27dtr+PDhSk9P1+rVq3XXXXdp4cKFmjp1qrp27ep1LUlJSQoNDdW///1vJScnN/sbIgKnC5elAFQzY8YMlZaWasGCBXr88cfVt29fLVq0SK+++qqysrL8XZ4kafLkybLb7Zo9e7aWL1+uc889V48++qhee+01FRUVNdl+O3XqpC5dumjevHnat2+fbDabunfvrrlz52rSpEnufo8//rgKCgo0YcIEHT58WL1799b27dsVHR2tTZs2afr06XrggQdUXFys7t27a86cOZo8ebJPtbRu3VojR47U8uXLdccddzT2WwVaLMM0q9w1CgBasIMHD6pnz576zW9+U22+kBUdPXpUXbp00YgRI/Tqq6/6uxyg2WDkBkCLlJubq9mzZ2vIkCFq06aNcnJy9Oyzz6qkpET33HOPv8trUvn5+dq5c6deeukl/fjjj5o2bZq/SwKaFcINgBYpODhYu3bt0htvvKEffvhBYWFhGjx4sBYvXqyePXv6u7wmtXz5ct15550655xz9Je//MXnH/UErI7LUgAAwFL8+m2p9evXa9SoUerYsaMMw9A777xT7zrr1q3TgAEDFBwcrHPPPVcvvvjiaagUAAC0FH4NN0eOHFH//v01f/58r/rn5ORo5MiRSkhIUGZmpv7whz9o8uTJWrZsWRNXCgAAWopmc1nKMAytWLGizptQ/f73v9fKlSs9ftsmOTlZW7du1aZNm05HmQAAoJlrUROKN23apMTERI+24cOHa+HChSorK1NgYGC1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jRgxQrm5uTX2//e//61x48bptttu01dffaW3335bn332mW6//fbTXDkAAGiu/BpuZs+erdtuu0233367zj//fM2ZM0edO3dWWlpajf3/85//qFu3bpo8ebJiYmL0s5/9TL/73e+0efPm01w5AABorvwWbkpLS7VlyxYlJiZ6tCcmJmrjxo01rjN48GDt27dPq1atkmma+u677/S3v/1N11xzTa37KSkpUVFRkccDAABYl9/CTUFBgZxOpyIjIz3aIyMjdeDAgRrXGTx4sF5//XWNHTtWQUFBioqK0llnnaV58+bVup/U1FRFRES4H507d27U9wEAAJoXv08oNgzDY9k0zWptlbZt26bJkyfr4Ycf1pYtW/T+++8rJydHycnJtW5/+vTpKiwsdD/27t3bqPUDAIDmJcBfO27Xrp3sdnu1UZr8/PxqozmVUlNTddlll+mBBx6QJPXr10+tWrVSQkKCZs2apejo6GrrOBwOORyOxn8DAACgWfLbyE1QUJAGDBigjIwMj/aMjAwNHjy4xnV++ukn2WyeJdvtdkkVIz4AAAB+vSyVkpKil19+Wenp6crOzta9996r3Nxc92Wm6dOna9y4ce7+o0aN0vLly5WWlqavv/5aH3/8sSZPnqxLLrlEHTt29NfbAAAAzYjfLktJ0tixY3Xw4EHNnDlTeXl56tu3r1atWqWuXbtKkvLy8jzueZOUlKTi4mLNnz9f9913n8466ywNHTpUTz31lL/eAgAAaGYM8wy7nlNUVKSIiAgVFhYqPDzc3+UAAAAv+PL57fdvSwEAADQmwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUv4ebBQsWKCYmRsHBwRowYIA2bNhQZ/+SkhI99NBD6tq1qxwOh7p376709PTTVC0AAGjuAvy586VLl2rq1KlasGCBLrvsMr300ksaMWKEtm3bpi5dutS4zpgxY/Tdd99p4cKF6tGjh/Lz81VeXn6aKwcAAM2VYZqm6a+dX3rppbr44ouVlpbmbjv//PM1evRopaamVuv//vvv66abbtLXX3+tNm3aNGifRUVFioiIUGFhocLDwxtcOwAAOH18+fz222Wp0tJSbdmyRYmJiR7tiYmJ2rhxY43rrFy5UnFxcXr66ad1zjnnqFevXrr//vt19OjRWvdTUlKioqIijwcAALAuv12WKigokNPpVGRkpEd7ZGSkDhw4UOM6X3/9tf79738rODhYK1asUEFBgSZNmqQffvih1nk3qampevTRRxu9fgAA0Dz5fUKxYRgey6ZpVmur5HK5ZBiGXn/9dV1yySUaOXKkZs+ercWLF9c6ejN9+nQVFha6H3v37m309wAAAJoPv43ctGvXTna7vdooTX5+frXRnErR0dE655xzFBER4W47//zzZZqm9u3bp549e1Zbx+FwyOFwNG7xAACg2fLbyE1QUJAGDBigjIwMj/aMjAwNHjy4xnUuu+wy7d+/X4cPH3a37dy5UzabTZ06dWrSegEAQMvg18tSKSkpevnll5Wenq7s7Gzde++9ys3NVXJysqSKS0rjxo1z97/lllvUtm1bTZgwQdu2bdP69ev1wAMPaOLEiQoJCfHX2wAAAM2IX+9zM3bsWB08eFAzZ85UXl6e+vbtq1WrVqlr166SpLy8POXm5rr7h4WFKSMjQ/fcc4/i4uLUtm1bjRkzRrNmzfLXWwAAAM2MX+9z4w/c5wYAgJanSe9zk5OT0+DCAAAAmprP4aZHjx668sortWTJEh07dqwpagIAAGgwn8PN1q1bddFFF+m+++5TVFSUfve73+nTTz9titoAAAB85nO46du3r2bPnq1vv/1WixYt0oEDB/Szn/1Mffr00ezZs/X99983RZ0AAABeafBXwQMCAnTDDTforbfe0lNPPaXdu3fr/vvvV6dOnTRu3Djl5eU1Zp0AAABeaXC42bx5syZNmqTo6GjNnj1b999/v3bv3q01a9bo22+/1fXXX9+YdQIAAHjF5/vczJ49W4sWLdKOHTs0cuRIvfrqqxo5cqRstoqcFBMTo5deeknnnXdeoxcLAABQH5/DTVpamiZOnKgJEyYoKiqqxj5dunTRwoULT7k4AAAAX3ETPwAA0Ow16U38Fi1apLfffrta+9tvv61XXnnF180BAAA0Kp/DzZNPPql27dpVa+/QoYOeeOKJRikKAACgoXwON998841iYmKqtXft2tXjRy4BAAD8wedw06FDB33xxRfV2rdu3aq2bds2SlEAAAAN5XO4uemmmzR58mStXbtWTqdTTqdTa9as0ZQpU3TTTTc1RY0AAABe8/mr4LNmzdI333yjq666SgEBFau7XC6NGzeOOTcAAMDvGvxV8J07d2rr1q0KCQnRBRdcoK5duzZ2bU2Cr4IDANDy+PL57fPITaVevXqpV69eDV0dAACgSTQo3Ozbt08rV65Ubm6uSktLPV6bPXt2oxQGAADQED6Hmw8//FDXXXedYmJitGPHDvXt21d79uyRaZq6+OKLm6JGAAAAr/n8banp06frvvvu05dffqng4GAtW7ZMe/fu1ZAhQ3TjjTc2RY0AAABe8zncZGdna/z48ZKkgIAAHT16VGFhYZo5c6aeeuqpRi8QAADAFz6Hm1atWqmkpESS1LFjR+3evdv9WkFBQeNVBgAA0AA+z7kZNGiQPv74Y8XGxuqaa67Rfffdp//+979avny5Bg0a1BQ1AgAAeM3ncDN79mwdPnxYkjRjxgwdPnxYS5cuVY8ePfTcc881eoEAAAC+8CncOJ1O7d27V/369ZMkhYaGasGCBU1SGAAAQEP4NOfGbrdr+PDhOnToUFPVAwAAcEp8nlB8wQUX6Ouvv26KWgAAAE6Zz+Hm8ccf1/33369//OMfysvLU1FRkccDAADAn3z+4Uyb7UQeMgzD/dw0TRmGIafT2XjVNQF+OBMAgJanSX84c+3atQ0uDAAAoKn5HG6GDBnSFHUAAAA0Cp/Dzfr16+t8/fLLL29wMQAAAKfK53BzxRVXVGurOvemuc+5AQAA1ubzt6V+/PFHj0d+fr7ef/99DRw4UB988EFT1AgAAOA1n0duIiIiqrUNGzZMDodD9957r7Zs2dIohQEAADSEzyM3tWnfvr127NjRWJsDAABoEJ9Hbr744guPZdM0lZeXpyeffFL9+/dvtMIAAAAawudwc+GFF8owDJ18779BgwYpPT290QoDAABoCJ/DTU5OjseyzWZT+/btFRwc3GhFAQAANJTP4aZr165NUQcAAECj8HlC8eTJkzV37txq7fPnz9fUqVMbpSgAAICG8jncLFu2TJdddlm19sGDB+tvf/tboxQFAADQUD6Hm4MHD9Z4r5vw8HAVFBQ0SlEAAAAN5XO46dGjh95///1q7e+9957OPffcRikKAACgoXyeUJySkqK7775b33//vYYOHSpJ+vDDD/Xss89qzpw5jV4gAABvLIoAACAASURBVACAL3wONxMnTlRJSYkef/xxPfbYY5Kkbt26KS0tTePGjWv0AgEAAHxhmCffjc8H33//vUJCQhQWFtaYNTWpoqIiRUREqLCwUOHh4f4uBwAAeMGXz+8G3cSvvLxcPXv2VPv27d3tu3btUmBgoLp16+ZzwQAAAI3F5wnFSUlJ2rhxY7X2Tz75RElJSY1REwAAQIP5HG4yMzNrvM/NoEGDlJWV1ShFAQAANJTP4cYwDBUXF1drLywslNPpbJSiAAAAGsrncJOQkKDU1FSPION0OpWamqqf/exnjVocAACAr3yeUPz000/r8ssvV+/evZWQkCBJ2rBhgwoLC7V27dpGLxAAAMAXPo/cxMbG6osvvtCYMWOUn5+v4uJijRs3Tjt37lR5eXlT1AgAAOC1U7rPjSQdOnRIr7/+utLT05WVldXs591wnxsAAFoeXz6/fR65qbRmzRr95je/UceOHTV//nyNGDFCmzdvbujmAAAAGoVPc2727dunxYsXKz09XUeOHNGYMWNUVlamZcuWKTY2tqlqBAAA8JrXIzcjR45UbGystm3bpnnz5mn//v2aN29eU9YGAADgM69Hbj744ANNnjxZd955p3r27NmUNQEAADSY1yM3GzZsUHFxseLi4nTppZdq/vz5+v7775uyNgAAAJ95HW7i4+P1l7/8RXl5efrd736nN998U+ecc45cLpcyMjJqvGsxAADA6XZKXwXfsWOHFi5cqNdee02HDh3SsGHDtHLlysasr9HxVXAAAFqe0/JVcEnq3bu3nn76ae3bt09vvPHGqWwKAACgUZxSuKlkt9s1evToBo3aLFiwQDExMQoODtaAAQO0YcMGr9b7+OOPFRAQoAsvvNDnfQIAAOtqlHDTUEuXLtXUqVP10EMPKTMzUwkJCRoxYoRyc3PrXK+wsFDjxo3TVVdddZoqBQAALcUp//zCqbj00kt18cUXKy0tzd12/vnna/To0UpNTa11vZtuukk9e/aU3W7XO++8o6ysLK/3yZwbAABantM25+ZUlJaWasuWLUpMTPRoT0xM1MaNG2tdb9GiRdq9e7ceeeQRr/ZTUlKioqIijwcAALAuv4WbgoICOZ1ORUZGerRHRkbqwIEDNa6za9cuPfjgg3r99dcVEODd/QdTU1MVERHhfnTu3PmUawcAAM2XX+fcSJJhGB7LpmlWa5Mkp9OpW265RY8++qh69erl9fanT5+uwsJC92Pv3r2nXDMAAGi+fPrhzMbUrl072e32aqM0+fn51UZzJKm4uFibN29WZmam7r77bkmSy+WSaZoKCAjQBx98oKFDh1Zbz+FwyOFwNM2bAAAAzY7fRm6CgoI0YMAAZWRkeLRnZGRo8ODB1fqHh4frv//9r7KystyP5ORk9e7dW1lZWbr00ktPV+kAAKAZ89vIjSSlpKTo1ltvVVxcnOLj4/XnP/9Zubm5Sk5OllRxSenbb7/Vq6++KpvNpr59+3qs36FDBwUHB1drBwAAZy6/hpuxY8fq4MGDmjlzpvLy8tS3b1+tWrVKXbt2lSTl5eXVe88bAACAqvx6nxt/4D43AAC0PC3iPjcAAABNgXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAshXADAAAsxe/hZsGCBYqJiVFwcLAGDBigDRs21Np3+fLlGjZsmNq3b6/w8HDFx8dr9erVp7FaAADQ3Pk13CxdulRTp07VQw89pMzMTCUkJGjEiBHKzc2tsf/69es1bNgwrVq1Slu2bNGVV16pUaNGKTMz8zRXDgAAmivDNE3TXzu/9NJLdfHFFystLc3ddv7552v06NFKTU31aht9+vTR2LFj9fDDD3vVv6ioSBERESosLFR4eHiD6gYAAKeXL5/ffhu5KS0t1ZYtW5SYmOjRnpiYqI0bN3q1DZfLpeLiYrVp06bWPiUlJSoqKvJ4AAAA6/JbuCkoKJDT6VRkZKRHe2RkpA4cOODVNp599lkdOXJEY8aMqbVPamqqIiIi3I/OnTufUt0AAKB58/uEYsMwPJZN06zWVpM33nhDM2bM0NKlS9WhQ4da+02fPl2FhYXux969e0+5ZgAA0HwF+GvH7dq1k91urzZKk5+fX20052RLly7Vbbfdprfffls///nP6+zrcDjkcDhOuV4AANAy+G3kJigoSAMGDFBGRoZHe0ZGhgYPHlzrem+88YaSkpL017/+Vddcc01TlwkAAFoYv43cSFJKSopuvfVWxcXFKT4+Xn/+85+Vm5ur5ORkSRWXlL799lu9+uqrkiqCzbhx4/T8889r0KBB7lGfkJAQRURE+O19AACA5sOv4Wbs2LE6ePCgZs6cqby8PPXt21erVq1S165dJUl5eXke97x56aWXVF5errvuukt33XWXu338+PFavHjx6S4fAAA0Q369z40/cJ8bAABanhZxnxsAAICmQLgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWEuDvAporp9OpsrIyf5cBNLqgoCDZbPy7BoB1EW5OYpqmDhw4oEOHDvm7FKBJ2Gw2xcTEKCgoyN+lAECTINycpDLYdOjQQaGhoTIMw98lAY3G5XJp//79ysvLU5cuXTi/AVgS4aYKp9PpDjZt27b1dzlAk2jfvr3279+v8vJyBQYG+rscAGh0XHivonKOTWhoqJ8rAZpO5eUop9Pp50oAoGkQbmrAUD2sjPMbgNURblCjbt26ac6cOf4uAwAAnzHnxiKuuOIKXXjhhY0WSD777DO1atWqUbYFAMDpRLg5g5imKafTqYCA+v9nb9++/Wmo6PTy5f0DAFouLktZQFJSktatW6fnn39ehmHIMAzt2bNHH330kQzD0OrVqxUXFyeHw6ENGzZo9+7duv766xUZGamwsDANHDhQ//rXvzy2efJlKcMw9PLLL+uGG25QaGioevbsqZUrV9ZZ15IlSxQXF6fWrVsrKipKt9xyi/Lz8z36fPXVV7rmmmsUHh6u1q1bKyEhQbt373a/np6erj59+sjhcCg6Olp33323JGnPnj0yDENZWVnuvocOHZJhGProo48k6ZTef0lJiaZNm6bOnTvL4XCoZ8+eWrhwoUzTVI8ePfTMM8949P/yyy9ls9k8agcA+Afhph6maeqn0nK/PEzT9KrG559/XvHx8brjjjuUl5envLw8de7c2f36tGnTlJqaquzsbPXr10+HDx/WyJEj9a9//UuZmZkaPny4Ro0apdzc3Dr38+ijj2rMmDH64osvNHLkSP3617/WDz/8UGv/0tJSPfbYY9q6daveeecd5eTkKCkpyf36t99+q8svv1zBwcFas2aNtmzZookTJ6q8vFySlJaWprvuuku//e1v9d///lcrV65Ujx49vDomVTXk/Y8bN05vvvmm5s6dq+zsbL344osKCwuTYRiaOHGiFi1a5LGP9PR0JSQkqHv37j7XBwBoXIzP1+NomVOxD6/2y763zRyu0KD6/yeKiIhQUFCQQkNDFRUVVe31mTNnatiwYe7ltm3bqn///u7lWbNmacWKFVq5cqV7ZKQmSUlJuvnmmyVJTzzxhObNm6dPP/1UV199dY39J06c6H5+7rnnau7cubrkkkt0+PBhhYWF6YUXXlBERITefPNN9/1WevXq5VHXfffdpylTprjbBg4cWN/hqMbX979z50699dZbysjI0M9//nN3/ZUmTJighx9+WJ9++qkuueQSlZWVacmSJfrTn/7kc20AgMbHyM0ZIC4uzmP5yJEjmjZtmmJjY3XWWWcpLCxM27dvr3fkpl+/fu7nrVq1UuvWratdZqoqMzNT119/vbp27arWrVvriiuukCT3frKyspSQkFDjjeTy8/O1f/9+XXXVVd6+zVr5+v6zsrJkt9s1ZMiQGrcXHR2ta665Runp6ZKkf/zjHzp27JhuvPHGU64VAHDqGLmpR0igXdtmDvfbvhvDyd96euCBB7R69Wo988wz6tGjh0JCQvSrX/1KpaWldW7n5BBiGIZcLleNfY8cOaLExEQlJiZqyZIlat++vXJzczV8+HD3fkJCQmrdV12vSXL/8GPVS3e1/dCpr++/vn1L0u23365bb71Vzz33nBYtWqSxY8dy80cAaCYIN/UwDMOrS0P+FhQU5PUdZzds2KCkpCTdcMMNkqTDhw9rz549jVrP9u3bVVBQoCeffNI9/2fz5s0effr166dXXnlFZWVl1YJT69at1a1bN3344Ye68sorq22/8ttceXl5uuiiiyTJY3JxXep7/xdccIFcLpfWrVvnvix1spEjR6pVq1ZKS0vTe++9p/Xr13u1bwBA0+OylEV069ZNn3zyifbs2aOCgoJaR1QkqUePHlq+fLmysrK0detW3XLLLXX2b4guXbooKChI8+bN09dff62VK1fqscce8+hz9913q6ioSDfddJM2b96sXbt26bXXXtOOHTskSTNmzNCzzz6ruXPnateuXfr88881b948SRWjK4MGDdKTTz6pbdu2af369frjH//oVW31vf9u3bpp/Pjxmjhxonsi9EcffaS33nrL3cdutyspKUnTp09Xjx49FB8ff6qHDADQSAg3FnH//ffLbrcrNjbWfQmoNs8995zOPvtsDR48WKNGjdLw4cN18cUXN2o97du31+LFi/X2228rNjZWTz75ZLWvT7dt21Zr1qzR4cOHNWTIEA0YMEB/+ctf3KM448eP15w5c7RgwQL16dNH1157rXbt2uVePz09XWVlZYqLi9OUKVM0a9Ysr2rz5v2npaXpV7/6lSZNmqTzzjtPd9xxh44cOeLR57bbblNpaanHxGkAgP8ZprffN7aIoqIiRUREqLCwUOHh4R6vHTt2TDk5OYqJiVFwcLCfKkRL8fHHH+uKK67Qvn37FBkZ6e9yvMZ5DqAlquvz+2TNfzIJ0MyUlJRo7969+r//+z+NGTOmRQUbADgTcFkK8NEbb7yh3r17q7CwUE8//bS/ywEAnIRwA/goKSlJTqdTW7Zs0TnnnOPvcgAAJyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcwK1bt26aM2eOe9kwDL3zzju19t+zZ48Mw/D6ByubejsAAEjcoRh1yMvL09lnn92o20xKStKhQ4c8QlPnzp2Vl5endu3aNeq+AABnJsINahUVFXVa9mO320/bvpqbsrIy9w+FAgAaB5elLOCll17SOeecI5fL5dF+3XXXafz48ZKk3bt36/rrr1dkZKTCwsI0cOBA/etf/6pzuydflvr000910UUXKTg4WHFxccrMzPTo73Q6ddtttykmJkYhISHq3bu3nn/+effrM2bM0CuvvKK///3vMgxDhmHoo48+qvGy1Lp163TJJZfI4XAoOjpaDz74oMrLy92vX3HFFZo8ebKmTZumNm3aKCoqSjNmzKjz/Xz22WcaNmyY2rVrp4iICA0ZMkSff/65R59Dhw7pt7/9rSIjIxUcHKy+ffvqH//4h/v1jz/+WEOGDFFoaKjOPvtsDR8+XD/++KOk6pf1JOnCCy/0qMswDL344ou6/vrr1apVK82aNave41YpPT1dffr0cR+Tu+++W5I0ceJEXXvttR59y8vLFRUVpfT09DqPCQBYESM39TFNqewn/+w7MFQyjHq73XjjjZo8ebLWrl2rq666SpL0448/avXq1Xr33XclSYcPH9bIkSM1a9YsBQcH65VXXtGoUaO0Y8cOdenSpd59HDlyRNdee62GDh2qJUuWKCcnR1OmTPHo43K51KlTJ7311ltq166dNm7cqN/+9reKjo7WmDFjdP/99ys7O1tFRUVatGiRJKlNmzbav3+/x3a+/fZbjRw5UklJSXr11Ve1fft23XHHHQoODvYICq+88opSUlL0ySefaNOmTUpKStJll12mYcOG1fgeiouLNX78eM2dO1eS9Oyzz2rkyJHatWuXWrduLZfLpREjRqi4uFhLlixR9+7dtW3bNtntdklSVlaWrrrqKk2cOFFz585VQECA1q5dK6fTWe/xq+qRRx5RamqqnnvuOdnt9nqPmySlpaUpJSVFTz75pEaMGKHCwkJ9/PHHkqTbb79dl19+ufLy8hQdHS1JWrVqlQ4fPuxeHwDOJISb+pT9JD3R0T/7/sN+KahVvd3atGmjq6++Wn/961/d4ebtt99WmzZt3Mv9+/dX//793evMmjVLK1as0MqVK90jAHV5/fXX5XQ6lZ6ertDQUPXp00f79u3TnXfe6e4TGBioRx991L0cExOjjRs36q233tKYMWMUFhamkJAQlZSU1HkZasGCBercubPmz58vwzB03nnnaf/+/fr973+vhx9+WDZbxYBjv3799Mgjj0iSevbsqfnz5+vDDz+sNdwMHTrUY/mll17S2WefrXXr1unaa6/Vv/71L3366afKzs5Wr169JEnnnnuuu//TTz+tuLg4LViwwN3Wp0+feo/dyW655RZNnDjRo62u4yZV/O913333eQTKgQMHSpIGDx6s3r1767XXXtO0adMkSYsWLdKNN96osLAwn+sDgJaOy1IW8etf/1rLli1TSUmJpIowctNNN7lHHY4cOaJp06YpNjZWZ511lsLCwrR9+3bl5uZ6tf3s7Gz1799foaGh7rb4+Phq/V588UXFxcWpffv2CgsL01/+8hev91F1X/Hx8TKqjFpddtllOnz4sPbt2+du69evn8d60dHRys/Pr3W7+fn5Sk5OVq9evRQREaGIiAgdPnzYXV9WVpY6derkDjYnqxy5OVVxcXHV2uo6bvn5+dq/f3+d+7799tvdo2H5+fn65z//WS1AAcCZgpGb+gSGVoyg+GvfXho1apRcLpf++c9/auDAgdqwYYNmz57tfv2BBx7Q6tWr9cwzz6hHjx4KCQnRr371K5WWlnq1fdM06+3z1ltv6d5779Wzzz6r+Ph4tW7dWn/605/0ySefeP0+KvdlnHQ5rnL/VdtPnohrGEa1eUdVJSUl6fvvv9ecOXPUtWtXORwOxcfHu49BSEhInXXV97rNZqt2nMrKyqr1a9XKczSuvuNW334lady4cXrwwQe1adMmbdq0Sd26dVNCQkK96wGAFRFu6mMYXl0a8reQkBD94he/0Ouvv67//e9/6tWrlwYMGOB+fcOGDUpKStINN9wgqWIOzp49e7zefmxsrF577TUdPXrU/WH7n//8x6PPhg0bNHjwYE2aNMndtnv3bo8+QUFB9c5RiY2N1bJlyzxCzsaNG9W6dWudc845Xtd8sg0bNmjBggUaOXKkJGnv3r0qKChwv96vXz/t27dPO3furHH0pl+/fvrwww89LiFV1b59e+Xl5bmXi4qKlJOT41VddR231q1bq1u3bvrwww915ZVX1riNtm3bavTo0Vq0aJE2bdqkCRMm1LtfALAqLktZyK9//Wv985//VHp6un7zm994vNajRw8tX75cWVlZ2rp1q2655ZY6RzlOdsstt8hms+m2227Ttm3btGrVKj3zzDPV9rF582atXr1aO3fu1P/93//ps88+8+jTrVs3ffHFF9qxY4cKCgpqHNmYNGmS9u7dq3vuuUfbt2/X3//+dz3y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NeR4VTrTzq1OnTrpySef1ObNm7V582YNHTpU119/vb766qsa+/vtvDLhtUsuucRMTk72aDvvvPPMBx98sMb+06ZNM8877zyPtt/97nfmoEGDmqzG5sLXY7V27VpTkvnjjz+ejvKaLUnmihUr6uxzJp9XVXlzrDivKuTn55uSzHXr1tXah/PqBG+OF+fWCWeffbb58ssv1/iav84rRm68VFpaqi1btigxMdGjPTExURs3bqxxnU2bNlXrP3z4cG3evFllZWVNVqu/NeRYVbrooosUHR2tq666SmvXrm3KMlusM/W8OhVn+nlVWFgoSWrTpk2tfTivTvDmeFU6k88tp9OpN998U0eOHFF8fHyNffx1XhFuvFRQUCCn01ntF8sjIyOr/VJ5pQMHDtTYv7y8XAUFBU1Wq7815FhFR0frz3/+s5YtW6bly5erd+/euuqqq7R+/frTCVEbJQAABtBJREFUUXKLcqaeVw3BeVXxS8opKSn62c9+pr59+9baj/OqgrfH60w+t/773/8qLCxMDodDycnJWrFihWJjY2vs66/zyu8/v9DSGIbhsWyaZrW2+vrX1G5Fvhyr3r17q3fv3u7l+Ph47d27V88884wuv/zyJq2zJTqTzytfcF5Jd999t7744gv9+9//rrcv55X3x+tMPrd69+6trKwsHTp0SMuWLdP48eO1bt26WgOOP84rRm681K5dO9nt9mojD/n5+dVSaaWoqKga+wcEBKht27ZNVqu/NeRY1WTQoEHatWtXY5fX4p2p51VjOZPOq3vuuUcrV67U2rVr1alTpzr7cl75drxqcqacW0FBQerRo4fi4uKUmpqq/v376/nnn6+xr7/OK8KNl4KCgjRgwABlZGR4tGdkZGjw4ME1rhMfH1+t/wcffKC4uDgFBgY2Wa3+1pBjVZPMzExFR0c3dnkt3pl6XjWWM+G8Mk1Td999t5YvX641a9YoJiam3nXO5POqIcerJmfCuVUT0zRVUlJS42t+O6+adLqyxbz55ptmYGCguXDhQnPbtm3m1KlTzVatWpl79uwxTdM0H3zwQfPWW2919//666/N0NBQ89577zW3bdtmLly40AwMDDT/9re/+estnDa+HqvnnnvOXLFihblz507zyy+/NB988EFTkrls2TJ/vYXTpri42MzMzDQzMzNNSebs2bPNzMxM85tvvjFNk/OqKl+P1Zl6Xt15551mRESE+dFHH5l5eXnux08//eTuw3l1QkOO15l6bk2fPt1cv369mZOTY37x/+3dz0sUfxzH8desP7bdxcOmlnrRsB9ioChKSEKol9VTogiiMdFB1BIvnSxJu3mpUywE5UkI9pAIUkZBF0HyYnpQ/wGRki5tURff34Pf736/87VvfY3cXafnAwZm5zOz+/4MH5YXM59hVldtbGzMAoGAvXjxwsyyZ1wRbg7owYMHVl5ebvn5+VZfX+95VNB1Xbt06ZJn/9evX1tdXZ3l5+dbRUWFxePxNFecOQc5V1NTU1ZZWWnHjh2zaDRqzc3NNj8/n4Gq0++vR0r/vbiua2aMq3866Ln6XcfVt86RJJuenk7tw7j628+cr991bF27di31v15cXGxtbW2pYGOWPePKMftzZg8AAIAPMOcGAAD4CuEGAAD4CuEGAAD4CuEGAAD4CuEGAAD4CuEGAAD4CuEGAAD4CuEGALT3Er/Z2dlMlwHgFyDcAMi4q1evynGcfUssFst0aQCOoNxMFwAAkhSLxTQ9Pe3ZFgwGM1QNgKOMKzcAskIwGFRJSYlniUajkvZuGcXjcbW3tysUCunUqVNKJBKe49fW1tTa2qpQKKTCwkINDAwomUx69nn8+LHOnz+vYDCo0tJS3bhxw9O+s7Ojzs5OhcNhnTlzRnNzc4fbaQCHgnAD4EgYHx9XV1eX3r59q/7+fvX29mp9fV2S9PnzZ8ViMUWjUS0vLyuRSOjly5ee8BKPx3X9+nUNDAxobW1Nc3NzOn36tOc3Jicn1dPTo9XVVXV0dKivr08fPnxIaz8B/AKH/mpOAPgB13UtJyfHIpGIZ7l7966Z7b21eXBw0HPMhQsXbGhoyMzMHj58aNFo1JLJZKp9fn7eAoGAbW9vm5lZWVmZ3bp16z9rkGS3b99OfU4mk+Y4jj179uyX9RNAejDnBkBWaGlpUTwe92w7fvx4ar2pqcnT1tTUpJWVFUnS+vq6amtrFYlEUu0XL17U7u6uNjc35TiOtra21NbW9t0aampqUuuRSEQFBQV69+7dT/cJQGYQbgBkhUgksu820Y84jiNJMrPU+rf2CYVC/+v78vLy9h27u7t7oJoAZB5zbgAcCUtLS/s+V1VVSZKqq6u1srKiT58+pdoXFxcVCAR09uxZFRQUqKKiQq9evUprzQAygys3ALLC169ftb297dmWm5uroqIiSVIikVBDQ4Oam5s1MzOjN2/e6NGjR5Kkvr4+3blzR67ramJiQu/fv9fIyIiuXLmikydPSpImJiY0ODioEydOqL29XR8/ftTi4qJGRkbS21EAh45wAyArPH/+XKWlpZ5t586d08bGhqS9J5mePHmi4eFhlZSUaGZmRtXV1ZKkcDishYUFjY6OqrGxUeFwWF1dXbp3717qu1zX1ZcvX3T//n3dvHlTRUVF6u7uTl8HAaSNY2aW6SIA4Hscx9HTp091+fLlTJcC4Ahgzg0AAPAVwg0AAPAV5twAyHrcPQdwEFy5AQAAvkK4AQAAvkK4AQAAvkK4AQAAvkK4AQAAvkK4AQAAvkK4AQAAvkK4AQAAvkK4AQAAvvIHgTu/SxLdSPUAAAAASUVORK5CYII=",
      "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": 38,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 28664,
     "status": "ok",
     "timestamp": 1695329081374,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "L1ZzFERMAQk9",
    "outputId": "56411273-fc8c-476f-f660-21239bd321ad",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.9002\n",
      "F1-Macro:  0.8963633216198105\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": 39,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 605
    },
    "executionInfo": {
     "elapsed": 29278,
     "status": "ok",
     "timestamp": 1695329182045,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "zUrNTiUp8kPc",
    "outputId": "e99daa47-22f9-471e-97d4-245bf6f0b8ab",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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ddu1a+f82mKxaMyYMZo/f75LP7PZrHHjxmndunXat2+f2zzdunVTbGysli1bpk8++US7du1Sy5YtNXz4cIWHh9f6fQAAAJxD0EWlHnzwQfn7++uNN95Qdna22rVrpylTpujqq69W27Zt9dVXX7ms2oaFhen//b//J+mnfbO33nqrbr311gt+RmZmpo4cOaIrrrhCTZs2rdX7AQAAlxaT45dPIV3C0tLSJOmSebnBypUr9dJLLyk9PV3x8fG6//779etf/9qtX3l5uYqKitweIisqKtIHH3ygF154QYGBgVqyZIliYmI8+uyCggIlJyfryy+/lPTTivIdd9yhRx55pPo3BgBALVm/fr0WLVqkjIwMxcXF6a677tINN9zg1Vw7d+7Url27FB0drT59+shsNlfad+/evdqyZYsiIiLUv39/r57LMYqq5DWC7nmqE3S9fWGDr3z++ef605/+5NY+Z84cDRw40ON5iouLNWHCBEnS/PnzFRgY6Lx2+vRpnTlzRpdffrnbMWYzZszQ+++/7zbf9OnTNWLECI8/vz7g1AcAuDSsW7dOf/rTn1xOKjKZTHrqqad04403ejxPSUmJ/vKXv2jNmjXOttatW+vFF19UixYtXPqWl5fr73//uz7++GNnW0REhObOnav27dt7fzMNGEHXS9UJukVFRbr77rtruqRas2fPHhUWFrq1h4SEqEOHDtWau6ysTJmZmcrOzpYk+fv7KyYmRpGRkZJ++o/2u+++czvSTJIaNWrU4P7DXbRo0SX9mzUANHSeLlbdf//92rlzp1t7+/bt9fLLL3v8ef/+97/14osvurVfe+21+sc//uHStnr1as2YMcOtb3x8vBYvXuzxZ1amIS7WVCWvsUf3ElVUVHTB9oKCAuXm5spsNisiIsKjVwGfk5WV5Qy5klRaWqrMzExZLBZZrVY5HI4KQ670U0gGAKCuVOXtounp6RW279u3T3fddZfy8/OVn58vk8mksLAwNWrUqML+lZ1c9PXXX+vOO+90ebHS0aNHK+ybkZGhMWPGyGKxXLTuCzH620UJurWg2agbZfKvfJ9NfWA9+aNystz/4wmLaa4T/qU6tHevs+3o8WPqfsctatY+vsK5zoVWk8kke+FZbZuxvcJ+ecF+apv0K0nSD2dOVPj5La65Us1vHlDl+6lrjtIynVj2la/LAADUIYvFUuFCkcVi0bFjx1yO5LTZbM4jO6vilwtB/OG9egi6tcDkb5ZfQP3+1rYdfJ2+ffkd6fz/fkxSVId4pa/6j0vf8pJSpb3zqQY8Pll+522UP3PgkPZ/tl65WT8qONyquBt6KSKupRzl5RV+pj2/0Pl96TRikDbNf0ulxXbn9ZDIcLUddG29/95JUsV3CABoaKrydtH169dr6tSpbuFzzJgxeuWVV9z65+TkaMGCBbrssstc2l9//XUtXLjQrX/Pnj1133336b333tOxY8fUoUMHDRkyRM8++6xb30t560JV1P9EgVrRvFNbXTP+d0pf/bXyj51SaItIJfyqj46luZ+NK0nFeQU6c+CwItu2liTlHPpRG+e9qfLSn7YalJwt0vdvLVenEYMU1MSqohyb2xxNE1rrxx17lfHFRhWeylZYdHOFNG0sOaTGsZepVa+rFBAU6DYOAIDa5OnbRQcOHKiAgAC3Uxf++9//Vti/vLxc33//veLi4lza77jjDm3btk1btmxxtjVr1kyDBg3Sfffdp9LSUknStm3b1LRpU/Xv3995SpEkhYeHa8aMGTwf4gGC7iWseccENe+Y4NJ2YlfF+48kyc/8856hA19udIbc86V/8Y06DvuVtr/5oXTeb7whTZsoqHGYti56z9lmP1ionMwj6j1ptJrGx1bnVgAAqBM33HCD23Fix48fr7R/aGioXnnlFa1atUplZWXq37+/xo0bp/nz52v9+vV64oknFBAQoDfffFPjx493htxzTp8+rYiICC1ZssR5vNiAAQMIuR4i6MJFdI9Oyvxmm1t7cERjhV/e0vl13o8nKxxfnJuvqPZx6nX/7cr4cqNK7cVqdkW8Lr++h775v9fd+jvKy5X++TcEXQC4hDW0Izp/6cYbb9S8efPc9u9GRkYqNTVVGzdudLYtWrRImzdv1rx583TVVVc5X5Zks9l04MCBCuffunWrHnroIZeV4coeKm9oanvrBEG3FjhKyxrsHs7w2Gi1HXit/vv5N84VWUtoiBIGJCon84isMc1lMpnUqFmE8o65h93AsEbK/Gab0j//RmX2EkmS2eyvltdcqfwTpyv8zLyjx1VeUlrhtfrKUcFqNgDAO8XFxQ3qiM6KNG3aVMePH3euyAYEBMhsNruE3HN27typpKQkhYaGOtseeeQRmUymCh8+O378eIP//lSmto/oJOjWkPP/YTb0p/Gtkq7s1El5eXmy2+06deqU0t5dKemn37zi4uLURCYdr+A/yFBLkPZ9stal7XR6prbOfVMWi0V2u12/FFBu0vGln9fa/dQ2nogFADRq1EhxcXEqKiqSyWRSYGCgcnNzK+1fXFys4OBg2Ww22e125xGcFY1p3LhxbZZuaARdVCgwMFBms1lpaWkqP+8UheLiYqWnp6tz585q27atjh49qoKCAlksFjVv3lw2m/tDaJKUm5urmJgYHTlyxO3aL98CAwC4dD3S6w5ZzMaIJzuO7Nec1YsqvDYwrpdW7lqvnLM/H0nWtFFjJcZdpW8zd6q0vEyhgSEaflV/De54XV2VXCfsZaV6apP7dsbaYIx/SfXA+ftLGsI5up7I/Gabyr9334RRWloqdWqlhKs6KPLQj8o99KOCwxsr6oo4bV74tpSTU+F88aN/o4iDh3RgzWYVnMqWNbqZ2g68Vs07ta3tW6lx55+ja+RjWQCgrlnM/rKYPX9JUX3WvVUHxUZcpqwzP7q0R4VGKP1EpkvIlaTTBbkK8A/QS79/XDmFNjULayqLv/ffi3JHufxMfhfvaGAE3VrQEM7R9cT5Z9z+kr2wSNuWpOrYjp+PIwtt1lTNO7fT6Ywst/4hTZso7LIoWaObqfW1PWql3rrUUPdgAwDqjp/JT1Nvuk+LN6Rqc2aaHA6HurXqoHG9h+tP7z1V4Zjth/ZoYt/bFRoY4tVnlpSV6p2tn+rLfZtUaC9Sp+gEjb5mqOIiW158sAE1/DSGWhPZLs5tv60kySQV2fJdQq4k5Z84reCjx2WNaS7bkZ+PWvEzm9VpxCBWPgEAl5wmwWGa0n+s7GUlOnLmmBoFNVKzsAgFBwSppCzfrX9wQPXOk1+w/h39J2Or8+udR/+rmZ/O11O3JisyNLxaczdEBF1UKvzyGLXs2UWHN+9waW9zQy+d2n+wwjEn9x7UwL9P0bEde3U645CCGocqtndXhTav2isQAQAwiu2H9uiVb97TqfxsSVLHy+LV8/LO+nzvBre+fROu9vpzThfk6OsD7keEFtqL9MXejfrd1b/2eu6GiqCLC7rq9qFqfmVbHft+n0x+foru1kHNOiZo/Rz3Vx3+xCG/AH+1vraHIbYoAABwTtrR/fp053qdKshWQmSshnW5UZc1jrrgmOO203rmi9dUUvbzMZq7f8xQQXGRel7eWZt/SJMkmWRSn/iuuqXrrzyux15aorSj++VwOHRldFudsJ2u9CSgH20Vn39vdPUi6B48eFApKSnaunWrgoODNWTIECUnJ1/0XLXCwkLNmzdPK1eu1MmTJ9W8eXMNGzZM9913nywWSx1Vb2wmk0mXdWmvy7q0d2lvcVV75R4+5tY/sl0cr/EFABjONwe26/mv3pRDPwXJrDM/atMPO5Ry8xRd1jhKe37M0LLtq3Tg1GE1C4vQkCv7qW/bq7Xmv5tdQu45mWeO6A/XjVJSj99ox5H9cjjKdWVMO/n7uT7MfuDUIaUd2a9GgSFKjOuqRoHBkqTvDu/VC2veVH5xoSQpxBKkO3vfKn8/s0rL3c96bx0RXdPfkgbB50HXZrNp3Lhxio6O1ty5c3XmzBnNmjVLOTk5mjNnzgXHPv744/r888/18MMPq23bttqxY4fmzp2r3NxcTZs2rY7u4NLUpl9Pndp3UKfTM51tQU3CdOWomyodk3v4mI7v3C+/gADFdO+o4HDOBQQAuLKXlfi6BDcOh0NLt3ziDLnnFNjPKvX7z9WvbU89sXKByv4XMDPPHNW8df9WYUmRsgsrPnZTko7ZTuvrjG3admi3s61HbCdN6JukALO/Xt3wgdbs3+y89ubm5frjr+5UyyYt9NwXi1VU+vND44X2Iv3r63d1fUIPfXXeGEkKD7Hq+rY96s33ti7r8HnQXbp0qWw2m1JTUxURESFJMpvNSk5O1oQJExQfH1/huNLSUq1cuVL33nuvxo4dK0nq3bu3jh49qk8++YSgW8vMlgD1njRaJ/ceUE7WUYWEN9ZlXTvIbKn4GJTdH36hA1/9/HaYfSvWqOvomxXTo1NdlQwAqKfO/3P7U5uW+LCSipWWlupE3pkKr23I3KGtP+51htzzvfHtcucrfn/JZDLp9e3L3V4QsTVrlx755FkFBQXp6NGjLtfOlhTrH6tfUUREhEvIPaekrFQ7sw8qKipKubm5Ki8vV0hIiJo0baq5297x9HbrVG2/dMnnh6utW7dOiYmJzpArSYMHD5bFYtHatRU88f8/DodDZWVlCgsLc2m3Wq28qaqOmEwmNesQr3aDr1fLnl0qDbnZPxxxCbmS5Cgv1453PlFpUcN9tzkA4NJgNpvl51dxZAoICFBxccU/y0pLS9WoUSMFBwe7XYuIiFB+vvupC9JPf+3Oy8ur8FppaalKSipfEXU4HAoPD9fll1+uNm3aqEWLFgoIMMa5xN7w+YpuRkaGRo4c6dJmsVgUGxurjIyMSscFBARoxIgRWrJkibp3766EhASlpaXpnXfe0ZgxY2q7bFTi8LdpOrT5e5WcLVKz9vFqc2Mvt2PIzikrtuvkvoO67Kr2FV4HAFwazj9+8pFeY+vlCyPeDVqp5WlrXNpMMmnStUn6fM8Gl+0H50SENNbfrr9XtrP52nRwh3b++F8F+Qfq+oQe6tLyCt335nSdLXNfCbb4+atLswR9nbe9wlrGdRum//tqSYULe8nX3aHoJs28u8k6Yi8rca7c1/bRoz4PujabTVar1a29svc9n+/xxx/X9OnT9dvf/tbZNnbsWD3wwANe1+NwOFRYWFjlcZX9NmcUecdOKvvgYQU1sSrqijYy+bn/w9yz/CtlfPGN82vb4eM6lrZfzTomVDqvn9nnf1SotrNnz7q8JhkAUDXn/wy1mAPqZdC9/eoh8vMza/Wer1VoL1KzsAj9tsev1b1VRzWyBOv7w3tV5nD9WdC7zVX6+4r5OnDqkALM/rouvrvG9b5FQf87K7d7bEd9neEeZnvEdlJiXNcKr7WwRqrX5V2U1OPX+veWT1yujeg6UJc3janBu6593vwMdTgcHgdknwfdynhyE3PmzNGaNWs0c+ZMxcXFadeuXZo7d66sVqsefPBBrz63pKREe/bs8WrcOY7SMsO8OctR7tCOdz/RkS07nW2NmkWo572/dT5M5nA4VJxfoINrNrmNzz9+Ss2vbCuZpF/s4ZelUbAi2sSqvMT9adT6zlH682/g+/btu6T/LAQA1XWhP8XXF35+frr96t9oVLdBKrCflTWokfP1ulc0j9NjN43Xsm2rdODUITUPa6rrE67W+9+tVvH/9tKWlJXqq/2blVdUoOSBd0uSknr8RvuO/aBTBdnOz4kMDdfvevxakaHh+nWnvvp01zrntbCgRnrghtEymUwaftUAdYm5QhsOfieHw6FecVcpISq2Dr8jNcPbn6Genq7l86BrtVpls7k/kZiXl1fpg2iStH//fi1atEjz5s3TgAEDJEnXXHONTCaTnnrqKY0ePbrSDeAXEhAQoISEylcgK3P+b6Mnln1V5fH11cmTJ3Uky/WVvgUnzmjrC2+pbdu2zrbc3FyVV/DnF0nK+W6/WrVspcOHDzv/zGI2m9U6uqVOvbem1mqvK1dccYUCAzlSDQC8df7PUHsFR3HVNyGWoP8d4fXzz70rmsfp//36PufX72xd6Qy559uatVuHc47JGhSqLVm71K55a8UUN1NYUCMlRMUqMb6bggMCZS8r0e3X/EZ9216tXT/+V6GBjdQjtqMC/S3OUwtiwptrVPhg59z15VSFizn//2Nvfoamp6d73NfnQTc+Pt5tL67dbldWVpbb3t3znbvJDh06uLR36NBBpaWlOnLkiFdB12QyKSSk6u+XrmyTekOXnZ1dYbvNZlNpaan8/X/6J3Sh36wsFouaNWum8PBw5ebmys/PT40bN5bZbK50TEMSHBx80TOfAQCVO/9n6FObXvdhJTXnxx9/rLDdIYee2fCmTp06Jbv95yDs5+enTPtJfXPGfa/vOV8ec3/rWUPnzc/Qquzr9XnQ7du3r+bPn6/s7GyFh//0DubVq1fLbrerX79+lY6LiflpD8quXbsUHf3zIcg7d/70J/aWLVvWYtXuAgMDtWjRojr9zLpw5513avv2ijfD//Of/9Tx48c1depUWSwW9erVS5s2uW5fCA4O1qJFi1z+PzIaVnMBAL8UFBRU4ckJJpNJBQUFLiFXksrLy3Xy5EnFxja87Qf1mc+DblJSkt544w1NnDhREydO1OnTpzV79mwNGzbMZevC1KlTlZqaqt27f/pN58orr1SXLl00ffp0nTp1SnFxcUpLS9O8efP0m9/8xuW4srpgMpkMuao3aNCgCoNuly5d9Oyzz2rFihXOtvj4eA0cOFBr1qxRSUmJOnXqpKlTp6pNmzZ1WTIAoIEx4mJRfn6+7r33Xh0+fNilfcyYMfrmm28qfOC+qKhIzz33XIUP6RtVbS8W+TzoWq1WLV68WCkpKZo8ebKCgoI0dOhQJScnu/QrLy9X2Xl7QM1ms1566SX93//9n/71r3/p1KlTuuyyyzRmzBjdf//9dX0bhjV69GitXbtWGzf+fA5ueHi4evbsqZdfftmlb0ZGhtq0aaNNmzapuLi4zn/ZAAA0TEZcLAoKCtIrr7yi119/XRs2bFDjxo01fPhwDR06VGlpaRWOCQgIkNVqNdz3wpdMDt6u4HTuH17nzp19XEn94nA4tG7dOm3fvl0tWrTQ0KFDdffdd+v7779362s2m7Vlyxav9jkDAHAp+PDDDzVz5ky39iFDhmjGjBkVjlmzZo2WLFmiw4cP64orrtDdd9+trl271nap9VJV8prPV3RR/5lMJvXr189lz3RlR8GUlZW5rLwDAABXN998sw4cOKC3335bpaU/nUDQs2dP/epXv9Jf//pXZWdn65prrtHIkSMVGhqqlStXatq0ac7x33zzjb799lstWLBAXbp08dVtNAjGPCoAte7ckW6/1Lt3b7fXMgMAgJ+ZTCY9/PDDWrZsmWJiYtS6dWv169dPDz/8sD799FNt3LhRzz//vMaPH6+CggItXLjQbY6SkhK9+uqrPqi+YWFFF165++679Z///MflQbXIyEj97W9/82FVAADUL8eOHdPKlSt19uxZXXfddS5/bo+MjFSjRo1UXl6ul156yW3sf//7X7333nvK+sV59udU5TzZSxVBF14JCQnRm2++qVWrVmn27NmyWCx6++23eQANAID/+fzzzzVt2jTn9oRXXnlFo0aN0mOPPebSr7i4uMKjyCTp+++/V4sWLXTs2DG3axxFdnFsXYDXzGazbrzxRsXExCgqKooH0AAA+J+ioiI98cQTzpB7zrJly/Ttt9+6tJ17+VJFmjZtqjvuuMOt3c/PT2PHjq2ZYg2MoAsAAFDDtmzZUukq7Zo1ayRJhw8fdr5ptHfv3m79zGazRowYod/+9rd67LHHnC/LateunZ566qkKx8AVWxcAAABqWEBAQKXX/P39NXPmTH300Uc6d8prSEiIevXqpc2bN8vhcCgqKkoPPfSQ2rdvL0kaNWqURo0apfLycpdXJuPCCLoAAOCS5nA4VFxcXKNzdurUSZGRkTp16lSF1z/88EOXr/ft26f+/fvrgw8+UG5urlq3bi1/f38VFRXVaF2/FBgYKJPJVKuf4UsEXQAAcMlyOByaMWOG9u/fX+NzBwcHy2w2u5wvHxUVpffee6/C/l9++aWysrLqdMW2Xbt2mj59umHDLkEXAACgFgQHBysuLk4FBQVyOBwKCQmRv7+/bDZbpWN4YW3NIuiiWmw2m/Lz82WxWHxdCgAAVWYymTR9+vQa37pwIS+//LJee+01t/auXbvqhRdeqLM6JLYuAJV6/vnn9fLLLzv3D/3pT3/S008/zTFjAIAGxWQyKSgoqM4+784779SmTZu0Z88eZ1uTJk30yCOP1GkdlwKTgzVyp7S0NElyeWsJKrZ8+XIlJye7tf/2t7/VzJkzfVARAAANR0lJib744gvt2rVL0dHR+s1vfqPGjRv7uqwGoSp5jaB7HoKu58aOHavNmze7tQcGBurbb79VYGCgD6oCAABGV5W8xkFs8EpOTk6F7cXFxTp79mwdVwMAAOCOoAuv9OnTp8L2Tp06qUmTJnVcDQAAgDuCLrxy7733qlWrVi5tQUFBeuyxx3xUEQAAgCuCLrxy7sDrhx56SE2aNFHz5s317rvvqmfPnr4uDQAAQBLHi6EaGjdurLvuukvr16+XJMXGxvq4IgAAgJ+xogsAAABDIugCAADAkAi6AAAAMCSCLryWl5enJUuW6MCBAzpy5IgOH4fUQ8kAACAASURBVD7s65IAAACceBgNXjl9+rRuv/12ZWZmOttGjhypV155RVdffbUPKwMAAPgJQdcgHA6HiouL6+zzXnrpJZeQK0lFRUV68skn9dZbb9VZHdJPrx02mUx1+pkAAKD+I+gagMPh0IwZM7R///46+8zdu3dX2L5r1y7dcccd8vevu39a7dq10/Tp0wm7AADABXt04RWz2Vxhu8lkkp8f/6wAAIDvsaJrACaTSdOnT6/TrQvLly/XtGnT3NqHDx+uGTNm1FkdElsXAABAxQi6BmEymRQUFFRnn3fbbbfp8OHDevXVV1VcXCyTyaT+/fvrr3/9a53WAQAAUBmTw+Fw+LqI+iItLU2S1LlzZx9X0nBkZ2dr3759iomJUatWrXxdDgAAMLiq5DVWdFEt4eHh6t27t6/LAAAAcMNTQwAAADAkgi4AAAAMiaALAAAAQyLoAgAAwJAIugAAADAkgi4AAAAMiaALAAAAQyLoAgAAwJDqxQsjDh48qJSUFG3dulXBwcEaMmSIkpOTL/gq2cOHD2vAgAEVXgsICNDOnTtrq1wAAAA0AD4PujabTePGjVN0dLTmzp2rM2fOaNasWcrJydGcOXMqHdesWTO9/fbbLm0Oh0Pjx49Xr169artsAAAA1HM+D7pLly6VzWZTamqqIiIiJElms1nJycmaMGGC4uPjKxxnsVjUtWtXl7ZNmzYpLy9PQ4cOrfW6AQAAUL/5fI/uunXrlJiY6Ay5kjR48GBZLBatXbu2SnN9/PHHCg0NVf/+/Wu6TAAAADQwPg+6GRkZbqu2FotFsbGxysjI8HiekpISrVq1SgMHDlRgYGBNlwkAAIAGxudbF2w2m6xWq1u71WpVbm6ux/OsW7dOOTk51d624HA4VFhYWK05LjXfffed/v3vf+v22293204CAABQkxwOh0wmk0d9fR50K1OVm5Ck5cuXKzIyUomJidX63JKSEu3Zs6dac1wqTp48qRUrVmjjxo0ym806efKkHnroIQUEBPi6NAAAYGAWi8Wjfj4PularVTabza09Ly+v0gfRfqmgoEBr1qzRqFGjZDabq1VPQECAEhISqjXHpeDIkSOaNGmSsrOznW3Z2dn65JNP9Nhjj/mwMgAAYGTp6eke9/V50I2Pj3fbi2u325WVlaWRI0d6NMfq1at19uxZDRs2rNr1mEwmhYSEVHseo1uyZIlLyD3nww8/1MSJE9WiRQsfVAUAAIyuKn/x9/nDaH379tXGjRtdQtPq1atlt9vVr18/j+b4+OOPFRsbq6uuuqq2ysQvbNu2rcL2oqIivfTSS3I4HHVcEQAAgCufB92kpCSFhYVp4sSJWr9+vVJTUzVz5kwNGzbMZevC1KlT1bFjR7fxZ86c0YYNGzRkyJC6LPuS17hx4wrb/fz8tHfvXh09erSOKwIAAHDl86BrtVq1ePFihYSEaPLkyZo9e7aGDh2qlJQUl37l5eUqKytzG//pp5+qtLS0RrYtwHP33HNPhe1RUVHq2rWroqOj67giAAAAVyYHf2N2SktLkyR17tzZx5U0DAsXLtTcuXNVUlIik8mkyMhItW7dWs8884yaN2/u6/IAAIABVSWv+fxhNDRcf/jDHxQWFqZly5bJ399f/v7+uuWWWwi5AACgXvD51gU0bCNGjFCLFi1kNpsVHh6um2++2dclAQAASCLoopoCAwN19913KzIyUnfddRevXwYAAPUGWxdQbT169FCPHj18XQYAAIALVnQBAABgSARdAAAAGBJBFwAAAIZE0AUAAIAhEXQBAABgSARdAAAAGBJBFwAAAIZE0AUAAIAhEXQBAABgSARdAAAAGBJBFwAAAIZE0AUAAIAhEXQBAABgSARdAAAAGBJBFwAAAIZE0AUAAIAhEXQBAABgSARdAAAAGBJBFwAAAIZE0AUAAIAhEXQBAABgSARdAAAAGBJBFwAAAIZE0AUAAIAhEXQBAABgSARdAAAAGBJBFwAAAIZE0AUAAIAhEXQBAABgSARdAAAAGBJBFwAAAIZE0AUAAIAhEXQBAABgSARdAAAAGFK9CLoHDx7UPffco65duyoxMVEpKSkqKiryaGxOTo4ef/xxXXfddercubMGDx6spUuX1nLFAAAAqO/8fV2AzWbTuHHjFB0drblz5+rMmTOaNWuWcnJyNGfOnAuOLSgo0NixYxUYGKipU6eqadOmyszMVElJSR1VDwAAgPrK50F36dKlstlsSk1NVUREhCTJbDYrOTlZEyZMUHx8fKVjFyxYoKKiIr377rsKCgqSJPXq1atO6gYAAED95vOtC+vWrVNiYqIz5ErS4MGDZbFYtHbt2guOfe+99zRq1ChnyAUAAADO8XnQzcjIcFu1tVgsio2NVUZGRqXjDh06pFOnTslqteq+++7TlVdeqV69emnGjBke7+8FAACAcfl864LNZpPVanVrt1qtys3NrXTcqVOnJElPPfWUbrrpJv3rX/9Senq6nnnmGZWUlCglJcWrehwOhwoLC70aCwAAgNrlcDhkMpk86uvzoFuZi91EeXm5JCk+Pl6zZs2SJCUmJqq0tFRPPfWUpkyZoqioqCp/bklJifbs2eNd0QAAAKh1FovFo34+D7pWq1U2m82tPS8v74IPojVp0kSS1Lt3b5f23r17q7y8XBkZGV4F3YCAACUkJFR5HAAAAGpfenq6x319HnTj4+Pd9uLa7XZlZWVp5MiRlY5r1aqVAgIC3NodDockyc/Pu+3HJpNJISEhXo0FAABA7fJ024JUDx5G69u3rzZu3Kjs7Gxn2+rVq2W329WvX79Kx1ksFl177bXasGGDS/uGDRvk7+/PqiwAAMAlzudBNykpSWFhYZo4caLWr1+v1NRUzZw5U8OGDXPZujB16lR17NjRZeykSZO0b98+PfLII/rPf/6j1157Tc8//7xGjx7tclwZAAAALj0+37pgtVq1ePFipaSkaPLkyQoKCtLQoUOVnJzs0q+8vFxlZWUubV26dNGCBQv0z3/+U/fff7+aNGmiMWPGaMqUKXV5CwAAAKiHTI5zm1qhtLQ0SVLnzp19XAkAAAAqUpW85vOtCwAAAEBtIOgCAADAkAi6AAAAMCSCLgAAAAyJoAsAAABDIugCAADAkAi6AAAAMCSCLgAAAAyJoAsAAABDIugCAADAkAi6AAAAMCSCLgAAAAyJoAsAAABDIugCAADAkAi6AAAAMCSCLgAAAAyJoAsAAABDIugCAADAkAi6AAAAMCSCLgAAAAyJoAsAAABDIugCAADAkAi6AAAAMCSCLgAAAAyJoAsAAABDIugCAADAkAi6AAAAMCSCLgAAAAyJoAsAAABDIugCAADAkAi6AAAAMCSCLgAAAAyJoAsAAABD8vdmUGFhoTZv3qxt27bp+PHjKioqUnh4uBISEtSrVy+1bdu2pusEAAAAqqRKQfeHH37QokWL9PHHH6uwsFAmk0lWq1UWi0U2m03FxcUymUxq166dxo4dqxEjRsjPj0VjAAAA1D2Pg+6TTz6pt956S3FxcZo4caJ69uypjh07yt//5ylOnDih7777Tp9//rmeeOIJvfbaa5o1a5Y6d+5cK8UDAAAAlfE46O7evVuvvvqqrrnmmkr7NGvWTIMGDdKgQYOUn5+v1157Tdu2bSPoAgAAoM6ZHA6Hw9dF1BdpaWmSRDAHAACop6qS12p8A+3x48e1e/fump4WAAAAqBKvTl04evRopddWrVqlBQsWaMOGDR7Pd/DgQaWkpGjr1q0KDg7WkCFDlJycrKCgoAuOGzt2rDZv3uzW/sknnyg+Pt7jzwcAAIDxeBV0+/fvL5PJVOn1uLg4j+ey2WwaN26coqOjNXfuXJ05c0azZs1STk6O5syZc9Hx3bt316OPPurS1rJlS48/HwAAAMbkVdB98skn3YJuYWGhtmzZoi+++EKzZ8/2eK6lS5fKZrMpNTVVERERkiSz2azk5GRNmDDhoiuzVqtVXbt2rfpNAAAAwNC8CrojRoyosH306NGaPXu2nn76aS1ZssSjudatW6fExERnyJWkwYMHa+rUqVq7di1bEAAAAOCVGn8YrV+/ftqxY4fH/TMyMtzCrMViUWxsrDIyMi46fvPmzeratas6d+6sMWPG6Ntvv61yzQAAADAer1Z0LyQ7O1tNmzb1uL/NZpPVanVrt1qtys3NveDYa665RsOHD9fll1+uEydO6JVXXtFdd92lJUuWqFu3blWuXZIcDocKCwu9GgsAAIDa5XA4Lvis2PlqLOiWl5dr7969eumllzRlypRqz+fJTTz44IMuX99www0aOnSo5s2bp3/9619efW5JSYn27Nnj1VgAAADUPovF4lE/r4Ju+/btKw2hDodDjz32mB577DFJkslkuuC5ularVTabza09Ly+vyvtzQ0JC1K9fP3322WdVGne+gIAAJSQkeD0eAAAAtSc9Pd3jvl4F3UmTJnm8ZHwx8fHxbntx7Xa7srKyNHLkyCrPV90XvZlMJoWEhFRrDgAAANSOqmRQr4Lu5MmTvRlWob59+2r+/PnKzs5WeHi4JGn16tWy2+3q169fleYqLCzU2rVreYUvAAAAav7UhapKSkpSWFiYJk6cqPXr1ys1NVUzZ87UsGHDXLYuTJ06VR07dnR+vWXLFk2YMEHvv/++Nm7cqI8++kijR4/WyZMnNWnSJF/cCgAAAOoRj1d0H3/8cU2aNElRUVEeT75q1SoVFRXp5ptvrrSP1WrV4sWLlZKSosmTJysoKEhDhw5VcnKyS7/y8nKVlZU5v46KipLdbtczzzyjnJwcBQcHq1u3bpoxY4a6dOnicY0AAAAwJpPDw02t48aN03fffaeBAwdq+PDhuvrqqxUcHOzWLzMzU1988YXef/99HT9+XHPmzKnyFgRfSUtLkyS2PgAAANRTVclrHq/oLl68WJ9//rkWLlyo8ePHy9/fX61bt1ZERIQCAwOVm5urQ4cOKTc3V8HBwRoxYoQmTJhQpTN1AQAAgJri8Yru+Xbv3q2vvvpK33//vU6cOKGioiKFh4erTZs26tmzpwYMGKDQ0NDaqLdWsaILAABQv9XKiu75Onbs6PJgGAAAAFDf+PzUBQAAAKA2eBV0N2zYoE8//dT59alTpzR+/Hhde+21euSRR1RcXFxjBQIAAADe8Crozp071+VtZk8//bS2bNmibt266bPPPtPLL79cYwUCAAAA3vAq6P7www/OPbqlpaVavXq1kpOT9cILL+jBBx/UihUrarRIAAAAoKq8Crr5+fmyWq2SpF27duns2bMaMGCAJKlLly768ccfa65CAAAAwAteBd2mTZvqhx9+kCR98803io6OVosWLSRJBQUF8vf36jAHAAAAoMZ4lUivv/56Pfvss0pPT9cHH3ygW265xXntwIEDiomJqbECAQAAAG94FXQffvhhHT16VO+88466dOmiCRMmOK99/PHH6tatW40VCAAAAHjDqzejXUh+fr4sFossFktNTlsneDMaAABA/VaVvFbtF0YUFRXp+PHjKi0tlSSFhoY2yJALAAAAY/E66G7cuFG/+93v1L17d914443at2+fJGnGjBlatWpVjRUIAAAAeMPrN6Pdc889Ki4u1t13363y8nLntfDwcL3//vs1ViAAAADgDa/fjNa3b1+lpqbqoYcecrnWvn177d27t0aKAwAAALzlVdDds2ePkpKSJEkmk8nlWkREhE6fPl39ygAAAIBq8Croms1mlZSUVHjt9OnTatSoUbWKAgAAAKrLq6DbuXNnffTRRxVe++yzz9S1a9dqFQUAAABUl1cvjPjDH/6ge+65R5MmTdItt9wik8mk77//Xu+9954+++wzLV68uKbrBAAAAKrE6xdGfPjhh3ryySeVm5vrbLNarZo2bZpuvvnmGiuwLvHCCAAAgPqtKnnNqxVdSRo+fLgGDx6s7du369SpUwoPD1f37t0VEhLi7ZQAAABAjaly0C0qKtKdd96pBx98UH369FFiYmJt1AUAAABUS5UfRgsKCtL+/ftlNptrox4AAACgRnh16kK3bt20Y8eOmq4FAAAAqDFeBd1HH31Ub7/9tlJTU1VQUFDTNQEAAADV5tWpC926dVNJSYnKysok/bSd4fw3pJlMJm3durXmqqwjnLoAAABQv9X6qQuDBw92e/UvAAAAUJ94FXRnz55d03UAAAAANcqrPboAAABAfef1CyOysrL0/PPPa8OGDcrJyVF4eLj69OmjSZMmKTY2tiZrBAAAAKrMq6CbkZGhpKQkFRcXq3fv3mrWrJlOnDihTz/9VGvWrNFbb72l+Pj4mq4VAAAA8JhXQffZZ59VkyZNtGTJErVo0cLZfuzYMY0bN07PPfecnn/++RorEgAAAKgqr/bofvvtt5o8ebJLyJWkFi1aaOLEidq0aVONFAcAAAB4y6uge/bsWTVp0qTCa+Hh4SoqKqpWUQAAAEB1eRV04+LitHz58gqvrVixQm3atKlWUQAAAEB1ebVHd+zYsZo2bZry8vJ06623KioqSidPntRHH32kL7/8UikpKTVdJwAAAFAlXgXdUaNG6fTp05o/f77Wrl0rSXI4HAoKCtLDDz+skSNH1miRAAAAQFV5fY7ufffdp9///vfavn27cnJy1KRJE3Xr1k1hYWFVnuvgwYNKSUnR1q1bFRwcrCFDhig5OVlBQUEez7F69Wo98MADatu2rT7++OMq1wAAAABj8TroSlJYWJj69u1brQJsNpvGjRun6OhozZ07V2fOnNGsWbOUk5OjOXPmeDRHUVGRZs2apcjIyGrVAgAAAOPwKui+9957Onr0qCZPnux27fnnn1erVq10yy23eDTX0qVLZbPZlJqaqoiICEmS2WxWcnKyJkyY4NGLJxYsWKDo6Gi1bNlSO3furNrNAAAAwJC8OnVhyZIlslqtFV4LDw/X66+/7vFc69atU2JiojPkStLgwYNlsVic+38vJCsrS6+++qqmTZvm8WcCAADA+LwKupmZmWrXrl2F1+Lj45WZmenxXBkZGW6rthaLRbGxscrIyLjo+CeeeELDhw9X+/btPf5MAAAAGJ/Xe3Tz8vIqbM/Pz1dZWZnH89hstgpXh61Wq3Jzcy849ssvv9T27du1cuVKjz/vYhwOhwoLC2tsPgAAANQch8Mhk8nkUV+vgu4VV1yhFStWaNCgQW7XPv7440pXe6viYjdRXFysJ598UpMnT3bZ9lBdJSUl2rNnT43NBwAAgJplsVg86udV0B09erT+/Oc/69FHH9Xvf/97tWjRQseOHdO///1vrVq1Sv/4xz88nstqtcpms7m15+XlXfBBtMWLF8vPz09Dhgxxji8pKVF5eblsNpuCgoI8/iacLyAgQAkJCVUeBwAAgNqXnp7ucV+vgu6wYcN04MABLVy4UB999JGkn1ZgzWazJkyYoJtvvtnjueLj49324trtdmVlZV3wxRMHDhxQZmamEhMT3a5dc801evzxx3X77bd7XMc5JpNJISEhVR4HAACA2ufptgWpGnt0p0yZopEjR+rrr79Wdna2IiIidO211yomJqZK8/Tt21fz589Xdna2wsPDJf308ge73a5+/fpVOm78+PG69dZbXdoWLlyogwcPatasWbr88surfE8AAAAwDq9OXTinZcuWGjx4sPLz8/XFF19owYIFVVpOlqSkpCSFhYVp4sSJWr9+vVJTUzVz5kwNGzbMZevC1KlT1bFjR+fX8fHx6tWrl8v/oqKiFBISol69eql58+bVuTUAAAA0cB6v6P7jH//Qp59+qjVr1jjbCgsLNWrUKB05ckQOh0OStGLFCr377rtq06aNR/NarVYtXrxYKSkpmjx5soKCgjR06FAlJye79CsvL6/SaQ4AAAC4tJkc5xLqRSQlJal79+565JFHnG0LFy7UM888ozvvvFMPPPCA0tPTNXnyZF133XWaNWtWrRVdW9LS0iRJnTt39nElAAAAqEhV8prHWxcOHTqkK6+80qXtq6++UkREhP785z8rNDRUXbt21V133aVNmzZVsWQAAACgZnkcdG02m5o1a+b8urS0VGlpaerZs6fMZrOzvUOHDjp58mTNVgkAAABU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bDabW3teXl6lD6L90tdff62//OUvuueeezR69Ohq1RMQEKCEhIRqzQEAAIDakZ6e7nFfnwfd+Ph4t724drtdWVlZGjly5EXH79ixQw888IBuuukm/fnPf652PSaTSSEhIdWeBwAAADWvKn/x9/nDaH379tXGjRuVnZ3tbFu9erXsdrv69et3wbEZGRkaP368unfvrlmzZlXpxgEAAGBsPg+6SUn/v707D4uy6vsA/p2dYZthEwRxA8QlAkNDMbX0NdPLFrWn1OxVJEtJTQtzyXJ9nrS3Hi1FMyUz0lxKaTMt00xz6S3DB8UlRQFZZIdhne1+/+BlcpxBBhMGpu/nurqu5sy57/nNMMJ3zpz7nHFwc3NDXFwcjh49iuTkZCxfvhyPPvqo2dSFhQsXomfPnqbbRUVFiI2NhUwmw3PPPYdz584hJSUFKSkpSEtLs8dTISIiIqJW9Cl0KAAAIABJREFUxO5TF9zd3bF161asWLECM2fOhJOTE0aNGoX4+HizfkajEQaDwXT78uXLyM3NBQBMnjzZrG9AQAAOHTrU7LUTERERUeslEgRBsHcRrUVqaioAICwszM6VEBEREZE1Tclrdp+6QERERETUHBh0iYiIiMghMegSERERkUNi0CUiIiIih8SgS0REREQOiUGXiIiIiBwSgy4REREROSQGXSIiIiJySAy6REREROSQGHSJiIiIyCEx6BIRERGRQ2LQJSIiIiKHxKBLRERERA6JQZeIiIiIHBKDLhERERE5JAZdIiIiInJIDLpERERE5JAYdImIiIjIITHoEhEREZFDYtAlojbjt99+w6xZs/Dbb7/ZuxQiImoDGHSJqNUrKSlBQkIC5syZgzNnzmDt2rWora21d1lERNTKSe1dABHR7eTn52PChAnIzc01tRUVFWHNmjWYN2+eHSsjIqLWjiO6RNSqJSYmmoVcABAEAbt370ZeXp6dqiIioraAQZeIWrVTp05Zba+ursbGjRshCEILV0RERG0Fgy4RtWrOzs5W28ViMc6fP4+cnJwWroiIiNoKBl0iatUmTpxotd3T0xMRERHw9/dv4YqIiKitYNAlolZt5MiRiI2NhVj8568rtVqNDh06ICYmBiKRyI7VERFRa8ZVF4io1Xv55Zfh4+ODzz//HDKZDHK5HE888QR8fX3tXRoREbViHNElojbhqaeeQkBAAGQyGTw8PPDYY4/ZuyQiImrlGHSJqE1QKBSYMmUKvL29ERMTA4VCYe+SiIiolePUBSJqMyIjIxEZGWnvMoiIqI3giC4REREROSQGXSJqEzQaDVJSUrgbGhER2YxTF4io1duwYQMSExNRXV0NsViMhx9+GMuXL29wMwkiIiKAQZeImkgQBNTW1rbY4+3fvx/r1q0z3TYajdi/fz+cnZ3x2muvtVgdQN0FcVy3l4io7WDQJSKbCYKApUuX4tKlSy32mJcvX7bavnfvXvzxxx9mG0k0t27dumHx4sUMu0REbQSDLhE1O71eD41GA7FYDDc3t9uGU0EQYDAYIBaLIRaLYTAYGuxnNBpbNOgSEVHbwqBLRDYTiURYvHhxk6YufPnll1i5cqXpGJVKhVWrVqFv374WfQ8ePIiEhARkZmbCxcUFY8eORY8ePbBjxw6Lvt27d8fHH39850/mDnDqAhFR2yISBEGwdxGtRWpqKgAgLCzMzpUQOYbMzEyMGjXKYlRWpVLh0KFDcHJyMrX9+uuviImJgdFoNOv71FNP4eeff0Z2drapTaFQYMOGDYiKimq0hsrKSuzduxcpKSnw9fXFk08+iS5duvzFZ0ZERPbSlLzWKr7zu3r1KmJjYxEREYH+/ftjxYoVqKmpafS4ffv2YebMmRg4cCBCQ0ORmJjYAtUSka2+/fZbq1MPysrK8NNPP5m1JSUlWYRcAPj666+RlJSEF198ESqVCt7e3ti+fbtNIbesrAzjx4/Hm2++iW+//RYfffQRxowZg59//vnOnxQREbUZdg+65eXlmDRpEiorK/Hee+9h3rx5+Oqrr7Bo0aJGj92/fz+ysrLw0EMPtUClRNRUt5vioNVqzW7n5uZa7VdVVQW9Xg8nJydotVpoNBrs2bMHpaWljT5+UlISrly5YvG4K1eutKF6IiJq6+w+R3fHjh0oLy9HcnIyPD09AQASiQTx8fGYPn06goKCGjx2zZo1pgtRdu7c2SL1EtlbSy/v9VcMGDAAGzdutGhXKBTo06eP2Tc3PXv2xLlz5yz6+vr64t1338U333xjatu2bRtOnjyJpKQkKBSKBh//2LFjVtvT09Nx7do1+Pn5NeXp2B3nCBMRNY3dg+5PP/2E/v37m0IuAAwfPhwLFy7EkSNHbht0ebU1/R3V1tZiypQp9i7DZj4+PigoKDBrc3Nzw+jRo6HX6+Hm5gZvb28YDAZIJBKLqQ4ikcgs5Na7cuUKnn76abPfHfUjviKRCCqVChkZGQ3WNW/ePEgkkr/47FrWhx9+aDavmYiIbs/uQffKlSsYO3asWZtcLkfHjh0tvnIkorbH398farUaZWVlEIlEEAQB+fn5pvurqqpQWlqKkJAQhISEID8/H1VVVZDJZPD29rY6b/fmY+uDbkFBAXJyckz3ZWdnw8fHBxqNxuI4tVrd5kIuERE1nd2Dbnl5Odzd3S3a3d3dUVZW1uL1CIKAqqqqFn9cIlvdPG1heVR7yCVt56vsGp0Bz3x8yKK9trYWUa46/KN3V5y65oJ9aVnQ1GoR4SnGvf7emN/AyOyToT4YHe6P9KJyxJ05Y3af0WhEZWkxJvYJxu6Uq6jV140U9+3og3n/FQ5XhezuP8FmoDUIeP1U3fzl6urq2wZ/IqK/A0EQbJ7GZfeg25CmPIm7SafT4fz58y3+uES20ul0pv+XS0RQSNrOFJ70wnJUavVW7zt/oxRf/OcaNvz857+/tLxSHEvPQ1h7D6Tmlpj191DKMbJnIBQSMX6+kmf1nBW1OnT3VeOzmKG4XFgOHxcnBKhd7t4TahF/BtuLFy9CJmsbAZ2IqDnJ5XKb+tk96Lq7u6O8vNyiXaPR3HZ+bnORyWQIDg5u8cclslVbuRDNGi9nBUQArC3erXaSY+svf1i0Z5ZUYkpUAALULjh0KQc6gxGRgd6YfH831OrrQqDxNquBG4xGuCpkiAjwujtPwo5CQ0Nve/EdNQ131iNqmxraGt4auwfdoKAgq8v/ZGZmWszdbQkikQjOzs4t/rhEtmpNf5jzNdX4Ji0LeeVV6O6rxiPdO0Apb/jXSjs3JQZ09cWx9Btm7RKxCGH+Hth3PsvqcX8UlGPZyEjEPxSG4spaJBxLw6w9J2AUBHT1csPjYZ2sHucsk6JvoM+dP8FWRqlU8mK0v0gQBGzduhXbt29Hfn4+evXqhRdffBHR0dGm+48fP45z586hffv2GDZsGF9zolamKd/42z3oDho0CBs2bEBJSQk8PDwAAN9//z20Wi0GDx5s5+qIqCHnckvw6pe/oEpXNxXhu4vZSE69hvfGREOlbPgrpXlDwyGXnMWRK7kwGAX4uztj+gM9EOzt3uBor7drXdCQiMV48+AZ/J5dZLovvUiDDcfO44mwTkhO/XMur0wsxtyh9942eFPr1hxL6SUmJmLTpk2m2+fOncOsWbPw/vvvIzg4GC+//DJOnz5tun/t2rVYt24dOnbseFfraAyXkiO6O+z+F2DcuHH45JNPEBcXh7i4OBQVFWHlypV49NFHzaYuLFy4EMnJyUhLSzO1Xb582Wz4+tKlS9i/fz+USiVDMv0taA32uzBp7dFzppBbL7OkEp/8dhnP9e/e4HEyqQSv/lc4pj/QAxVaPXzdlBD//x/0+zu1w6mMfPP+YhGG9+iAWoMR14o0ZiG3Xo3eAKVciveffgAnr+VDIRFjUHB7eLk4odaOr9HdYM+fsT0JgoClS5fi0qVLd/WcFy9etGjX6/V4+eWXoVAoLJbCy8/PR0xMDDp1sv6tQXPp1q0bFi9ezLBL9BfZPei6u7tj69atWLFiBWbOnAknJyeMGjUK8fHxZv2MRqPF+prffvst1q1bZ7qdnJyM5ORkBAQE4NAhyyu7iRyBIPw55vn6KesXYTU3g8GAi/nWV0X5+kIu/hAsV1Jp2J87nBnc2kGt1pp2PZPL5VCpVPjXiUy4u7ujsrKywbPsTy9Gmt4VgBIAcPJMcYN9BUFASUmJ6XFUKhU8PT1bfai4+WdPTafX6xtctUKr1Vrs1levsrLStM4zEbUtIoG/OU1SU1MBAGFhYXauhKhh1dXViI2NtWsNRqMRZ8+etRq8XFxc0LVrV2g0GhgMBri5uVldKeB2K6vo9XqUlZUhOzvb9BhisRjt27dHTk6O1cft0KEDvLxsu+AsMzMTJSXmqzioVCp07tzZpuPtJTExEUql0t5ltJi7PXVBr9fj8ccfR1GR5bcCI0eOxLVr18y+NawnFotx8ODBO7p+Q6/XY8uWLUhOTkZpaSkiIyMRFxeH7t0b/tYD4NQFottpSl6z+4guETXNzX/8lkf5QW6n5cXe1hbj4MVsi/ZHQ32x//xFlFbXjY5JxSJM6ReKMeFdAABfpF7D5ylXkV9Rg04erpjYNxgDg9qbnaOiVoeJH18wC7RGoxE3cnPw2D0d8UWq+bq6XbzcsPqRnnCSmY+45Wuq8ePlHNTqjLi/sw9C26mRXliOuDPmIRcAysrK8GxnJ9zj72lxnz1pDUbTyP3fLfiIRKJGLwSr/7bP1mXXpk6dipUrV5q1KZVKTJkyBSdOnLAadAcNGmS2A19T/POf/8Tu3btNt3/55RekpaVh586dCAgIuKNzEpHtGHSJ2jC5RGy3dXRfGtQLmhotTmXUzWmUikUYfW9nHLyYYwq5AKA3Cvjg+AVEdvDG2dxibDj25zq5GSUV+Nd3KVj5qAz3d2pnaj+cUYAavflUpfpzdVC54PWHe+Pb81mo1OrRO8ALHdTOSM0pQt+OPlBI68LuoUs5+NfBFBj+f+2xbb9dxtjwzghQNbyO7vkbJYgM9P5rLwy1CK1Wi3Xr1mHPnj2oqKhAREQE5syZg/Dw8NseN27cOKhUKmzbtg03btxAWFgYnn/+eQQHB6NTp074/fffzaa+de7cGQsWLLijGouLi7F3716L9oqKCuzatQtz5sy5o/MSke0YdInaMK1BwM0bCrQkmVSCpSP7IKukAjc01Qjydse1Yg12p1y12v+7i9n46UquRbsA4NPT6Qjv8GfArNZb31QCAKp0ejwa1AkDgvxw8GI21v50zrTrmZtChoUPR6C7rxrvHP6PKeTW+/zMNfx334bXyXZ3kre6i9fqfsZ0q+XLl+Orr74y3U5JScG0adOwc+dOdOzYEadOncLHH3+M69evo3v37pgyZQpCQ0MBACNGjMCIESMszimTyfDvf/8bp0+fxsKFCyGTybBt2za4uNi+yYggCNDr9ZDJZMjOzoa+gffytWvXmvaEieiOMOgStWH1W8O2CteLrG7+Uu9wVhmKK2qs3ncuvxzzjueYvoa+3aUDx0tFOH08B7W1tbhw4YLZfZpaHRbtO42AgABU6SxHhAFg39VSyGQysx3mAEAikeD7QuDQ8ZwGH5tah8LCQuzbt8+ivbq6Gp999hnCw8MRHx9veh9lZGTgyJEj+OijjxqdGwsAPXv2NE1VsHYBWnZ23ZSdm6ce6HQ6JCQk4PPPP4dGo0F4eDimTp0KhUJhdZ4xNyYiahkMukR017i6ukIikViskAIAarUalZWVVv/oK5VK5OXlobCwEAaDAVKp1Oquib6+vqY5m/UrJtzKYDCgurq6wRrFYjG6du2KrKwsVFVVAQCcnJwQGBjIq+pv0Rzr2N4N165ds/oeq7/v6NGjFh+WampqsHHjRrz55pv4448/sGfPHuTl5eGee+7BmDFjTOu4A3WrLGi1WkgkErPnn56ejhUrVpjm8YaGhmLRokUICQnBv/71L3z55ZemvmfOnEF8fDwefvhhs5FnoO7fwuOPP46aGusf/FoDXgxHjoKrLtyEqy5QW9Baw0e977//HosWLTL7ynbs2LFYuHAhvvvuOyxcuNAshMjlcowePRo7d+60ONesWbNQU1OD/Px8ZGdnIyUlBXK5HK+//jquXLlitvD/zd544w0kJCRYXF0vEonw6aefIiQkBACQk5MDg8GAwMDAu/HUm11Lh4+amhpMmTKlxR7PVgaDAZcuXbI68u/t7Y3CwkKrx8lkMvj5+SErK8uivXPnzpDJZCgpKUF+fj4MBgNEIhE8PDzg6+sLQRBw+fJli6kIEokEXbp0aXBLUg8PD8jlcpSWlkKv18PFxQU+Pj6tfivnDz/8kDvCUavFVReIHJgtV6Lb06OPPorIyEh88803qKqqwuDBgxEREQEAeOyxx6BSqbBlyxZkZWWhR48eeP755zF79myr5zp8+DCWL1+O8ePHm0ZpdTod5s+fj7i4OKvHyGQyDBs2DEFBQXjppZdMI79SqRRz5841+8XYtWvXu/nUqYVIJBJ4eXlZBFqpVAoPDw9TqLyVTCbDjRs3LNp1Oh2Kiorg4uKC3Nw/pwMJgoDi4rr1mJVKpdVzGgyGBr9dqD93+/btbV76jojuLgZdIrrr/P39MXXqVKv3DR482GznQqPRaDV8AEBeXh4SExOtTkVITk5GTEwMtmzZYmoTiURYsGABPD094enpiR9++AFHjhxBdXU1HnjgAXh7c0WFO3X/0MmQSGxbwqulXEg9gYtnT6CmuhL+gSGIuP9huKk8of71EP732FcW/fs88AR++m679ZNJlDCKrK+Tq6moQlCvB0xzc28VGBSJ0rLD0OssN5wI7tkfkdEjbX9Styi8kYUzv/6A4oJsuKu8cU/kgwjoGHrH57sdg0GHX374qFnOTWQvDLpEZFdisRhhYWGmr6JuFh4ejvPnz1s5qm7aQWxsLIYPH44ffvgBMpkMI0aMMBuldXJywvDhw5ut9r8TiUQGifTuB93CG1n4/dR3KLyRBXe1N+7tMwSBXXqa7jcY9CjIy4Rc7gRPH3+zY3v1HoRevQdZnDMi6mGIRGKk/nYI1VUauKu9ERk9El1CIvDzod0w6HUWxzi7uKFSY323P522Bu3ad27wOQR27QWRWIzTJ741a1c6u+Ge+x5s9HWrKC/BhdTj0JQVwcevI7r1ioJcoURBXga+3r3WVG95aSGyMy9i2GPPoXPI7ZdRI6I6DLpEZHezZs3C9OnTzb4adnZ2xrRp05CQkGB1/qOHhwfc3NwQFhbGefUtwFo4/KsK87Pw9a4/g5ymrBDZGRcxZOR/o0u3CFz9IwXHD3+OmqoKAIC3byAeGvnfcFf9OTJfWnwDRoMBHt7tzeYvh0U+iNB77oemvARqT19IJHV/7oK798HFsycsagm9JxrZGedRUmS5konKox38/LsguEcfXD7/q9l9XULC4eMbCB/fQDi7uONC6gnUVGnQPjAEEVHDoHByhkGvg9FowPWMC6itrkL7wGC4utVd/FaQl4Fv92yATls37/6PtF9w9vQRjHpqJn47/q3F6y4IAv7356/NPgzcLc3xMyayN16MdhNejEZkP6mpqdi6dSsyMjIQGhqKyZMnIzg4GL/++itiYmJgNJqvbztr1iy88MILdqr276G5t5vOysqCRqOxaJfL5QgMDMSVK1cs7lMoFAgKCkJNTQ1ycnJMKxfI5XL4+/vD2dnZNB2mtLQUgiBAKpWiXbt2UKvVMBqNyM3NRVlZ3eitWCyGj48PvLy8oNVqcfXqVYsVHQIDA+Hm5gZBEFBSUmI6Vq1WQ61WQyQSQRAElJaWory8HCKRCO7u7lCpVBCJRKipqUFWVpbZknbe3t5o164drl69anVqjqenJ8rLyxtch7dHjx7NemHi3227aWpbeDEaEbU5YWFhePvtty3a+/Tpg3fffRfvvvsuLl++DKlUimnTpuH555+3Q5V0NzW0vJZWq0VJieU2zQBQW1uLyspKi80YtFotMjMzERISgvz8fLPj9Xo9cnJyIJVK4erqioCAAKhUKtTU1MDV1dV0cadcLkfXrl1RVFSE6upqyGQyeHp6wtm5bu5ucXExCgoKTB+6JBIJ3N3dIZFIkJWVhYqKCtNjVlRUoKqqCv7+/sjOzrZYt7mwsBBOTk4NLoVXWVkJuVxuNehKpVIu/UVkIwZdImr1hgwZgujoaEyePBkikQgxMTH8Q98Cmvs1trZxB1AX5BpaJxeoC4HWAqDRaERpaWmDqyAUFxdDqVSaraGcn58PDw8P+Pn5QSQSQSqVwsXFBRKJBDKZzBSCNRqNxUWTFRUVyM3NhYeHh1nIrVdaWgoXF5cGlwOsH/219sWqWCyGl5eXqc6btcQKDvz3RY6CQZeI2gyxWGzvEuguul2Qk0qlpikCNxOJRLfd2EOr1Ta4s55er0deXp7FY5aUlMDJyQkqlQqZmZlm9+fn56NTp04Nhufy8nLIZA1fbHa7zUsAQKVSWT23Wq2Gm5sb/P39UVhYCK1WC6lUCi8vLy5VRtQEDLpE1OqVlpZi+/btuHr1KuRyOa5evYoePXrYuyyHp1Ao8OGHHzbrY3z//ffYvHkzMjIy4O3tjfHjx+OZZ56BXq/HK6+8glOnTpn1nzFjBvr164eJEydaDbSLFy/GqlWrzNbDrffII4/gm2++sVqHh4cHoqOjsXnzZrN2vV4PDw8PODs7W10ZBABGjx5tcVy9OXPm4L333kNBQYHFfbNnz0b//v2xbNkynDhRd4GcVCrFmDFjMHv2bLMPdpWVlVAqlS32Ya+1b2hBZCtejHYTXoxG1PoUFBRgwoQJyMnJMbUpFAqsX78e/fr1s2NldDdVV1fDycnJ9JW5IAhYvHgxfv31V1RUVEAsFkOtVpvmy+bl5Zk2c6jn5uaGwMBAlJWVWax5K5VK0bFjR6Snp1t9/Ppd5xqaN+zl5WWx0x5QN/2iS5cuuHLlisV0C5lMhuDgYFRWViIrK8ssmLu7uyMgIMD0fGtra6HT6eDk5ASpVIpu3bph8eLFnEJAZAUvRiOiZtPSWxBv3LjRLOQCdaHgrbfewvbtDSz+30xaegvevxNrV/jXh1u1Wm1xn5+fH5ydnVFeXg5BEODm5gaVSgWgbjqATCZDcXExdDodlEolvLy8IJPJoFQqrU4ncHV1RWVlZYP1eXp6QqPRQKs13xTCz8/PFKJzc3NNQVmpVMLf3x8ikQiurq4IDg5GWVkZDAYDXF1d4eLiYnYehULBUVSiZsAR3ZtwRJfo9gRBwNKlS3Hp0qUWe8yLFy82OMrWq1cvSKUt93mdo2wtqzk+VF24cAGzZs1CeXm5qS0oKAjr16/Hvn378O6771ocM3DgQPzP//wPKisr8cUXX+DMmTPw8fHBE088geDgYLO+OTk5kEgk8PX1/Ut18kMVUcM4oktEDqOhICsSiXhxmoMTiUSmVQ/uloiICOzduxdffvklsrOz0atXL4wYMQJOTk6YOHEizp07h4MHD5r6d+3aFYsWLYKTkxOcnJwwZcqU257/5p35iMj+OKJ7E47oEjWupacuHDhwAAsXLrRoHzt2rNX25sRRtr+HtLQ0nD17Fv7+/oiOjuYHKqJWhiO6RNRsmmOU7XYef/xx5OXlYfPmzaiqqoJYLMbw4cOxYMGCFq2D/j569uyJnj3v/ha7RNTyOKJ7E47oErVeFRUVuHLlCvz8/P7y/EciImq7OKJLRA7H1dUV4eHh9i6DiIjaEE48IiIiIiKHxKBLRERERA6JQZeIiIiIHBKDLhERERE5JAZdIiIiInJIDLpERERE5JAYdImIiIjIITHoEhEREZFDYtAlIiIiIofEoEtEREREDolBl4iIiIgcEoMuERERETkkBl0iIiIickgMukRERETkkBh0iYiIiMghMegSERERkUNi0CUiIiIihyS1dwGtiU6ngyAISE1NtXcpRERERGSFVquFSCSyqS+D7k1sfdGIiIiIyD5EIpHNmU0kCILQzPUQEREREbU4ztElIiIiIofEoEtEREREDolBl4iIiIgcEoMuERERETkkBl0iIiIickgMukRERETkkBh0iYiIiMghMegSERERkUNi0CUiIiIih8SgS0REREQOiUGXiIiIiBwSgy4REREROSQGXSIiIiJySAy6REREROSQGHSJiIiIyCEx6FKj5s+fj1GjRuHIkSMYNWoUwsLCMGbMGKSkpJj6DBkyBMuWLcPmzZsxcOBAhIeHY/r06cjPz7dj5dTWNOW99sknn+Chhx5CZGQk4uLiUFxcbMfKqa2pf6+dOnUKTzzxBCIiIvDkk0/i7Nmzpj6hoaH44IMP8NZbb6Ffv37o3bs35s+fj4qKCjtWTm2Nre+1TZs24b333kN0dDSioqKwYMECVFVV2bFyx8CgSzYpKCjA0qVLERsbizVr1kAulyM2NhZFRUWmPt9//z0OHjyIJUuWYMmSJUhNTcXMmTPtWDW1Rba81w4dOoTDhw/jjTfewGuvvYZffvkFy5cvt2PV1BYVFBRgxYoViI2NxerVq1FTU4MZM2ZAp9OZ+iQlJSE9PR2rVq1CfHw8Dhw4gNdff92OVVNbZMt7bdu2bcjIyMDKlSsRFxeHr776CuvXr7dj1Y5Bau8CqG0oLS3FmjVr0L9/fwBA3759MXjwYGzduhUvv/wyAKCyshIffPAB3N3dAQB+fn6YPHkyjh07hgceeMButVPbYst7TRAEbNiwAXK5HACQkZGBxMREGI1GiMX8/E62KSsrwyeffIKQkBAAgEKhQExMDM6cOYM+ffoAAORyORISEiCRSEy3X3/9dcyYMQNBQUF2q53aFlvea97e3njnnXcAAIMGDUJqaioOHDiA+Ph4u9XtCPgXgWzi5uZmCh4A4O7ujn79+pl9pRwVFWUKuQDQv39/uLq6mvUhaowt77W+ffuaQi4ABAcHQ6fTmY36EjWmXbt2puABwBRcb9y4YWp76KGHTCEXAB5++GEIgoDU1NSWK5TaPFveawMGDDA7Jjg4GHl5eS1ToANj0CWbeHp6WrR5eXmhoKDA7HZjfYgaY8t77eYPVAAgk8kAALW1tc1bHDkUW95Ht/5eU6lUkMlkvP6AmsSW95q1PlqttvmLc3AMumQTaxf6FBUVwcfHx+x2Y32IGmPLe42opdz6e62srAw6nQ7t2rWzU0VE1BQMumQTjUaDEydOmN0+efIkwsPDTW2nTp2CRqMx3T5x4gQqKirM+hA1xpb3GlFLOXz4MAwGg+n2d999B5FIhLCwMDtWRUS24sVoZBO1Wo3XXnsNs2bNgpubGzZt2gQAmDRpkqmPi4sLpk6diqlTp0Kj0eDtt9/Gvffei4EDB9qrbGqDbHmvEbUUrVaLF198EePHj8f169fx9ttvY/jw4bwQjaiNYNAlm/j4+CA+Ph5vvfUWMjMzERISgsTERHjFrewSAAAJbUlEQVR7e5v6DBs2DH5+fli8eDHKy8sRHR2NpUuX2rFqaotsea8RtZRnn30WxcXFePXVV6HVajFs2DC88cYb9i6LiGwkEgRBsHcR1LrNnz8fZ8+exddff91gnyFDhuDBBx/kHwD6S2x5rxG1lNDQULz66quIjY21dylEdIc4R5eIiIiIHBKDLhERERE5JE5dICIiIiKHxBFdIiIiInJIDLpERERE5JAYdImIiIjIITHoEhEREZFDYtAlIvoLLly4gAULFmDIkCEICwtD7969MXr0aGzatAmlpaVNOteRI0ewdu3aZqr07rt+/TpCQ0OxZ88ee5dCRGQVV10gIrpDu3btwtKlS9GlSxeMHz8ewcHB0Ov1OHv2LHbt2oXu3bsjISHB5vMtW7YM27Ztw8WLF5ux6rtHq9UiLS0NHTt2hKenp73LISKywC2AiYjuwO+//44lS5YgOjoa69evh1wuN903YMAAxMTE4OjRo3assPkYDAYYDAbI5XJERETYuxwiogZxRJeI6A5MmzYNR48excGDB9G+ffvb9t23bx8+++wzXLp0CeXl5QgICMDQoUMRFxcHZ2dnAHXbH+/du9fi2B9++AEdOnSAIAjYvn07du3ahatXr0KhUKB///6YO3cuAgMDTf0FQcDGjRuxc+dOFBYWIiQkBK+88gref/99AEBSUpKpb05ODv7973/j559/hkajQWBgIP7xj39g8uTJEIvrZrZdv34dQ4cORXx8PHQ6HT777DPk5eXh/fffR9euXTF06FC8+eabGDNmjOm8165dw9q1a3H8+HHTeSdOnIhnnnnG1MdoNOL999/HF198gdzcXMjlcrRv3x5PPvkkJk2adAc/ESIiSxzRJSJqIoPBgJMnT6JXr16NhlygLvgNGjQIkyZNglKpRHp6OjZt2oT//Oc/+PjjjwEAcXFxqKqqwoEDB7Bz507Tse3atQMAvPHGG9i7dy+effZZxMfHo6ysDAkJCRg3bhy++OILeHt7AwBWr16NjRs34umnn8awYcOQl5eHRYsWQafToUuXLqbzFhcXY9y4cdDpdHjppZcQEBCAH3/8EatWrUJmZiaWLFli9hySkpLQuXNnzJs3D66urujUqZPV53r58mWMGzcO7du3x7x58+Dj44Njx45hxYoVKCkpwYwZMwAAmzdvxrp16zB9+nT06dMHer0e6enp0Gg0tv8giIgawaBLRNREJSUlqK6uRocOHWzqHxcXZ/p/QRBw3333ISgoCBMnTsSFCxfQvXt3dOzY0RRWb50OkJKSgl27dmH+/PmIiYkxtffp0wfDhw/Hli1bMHfuXJSVlWHLli0YOXIkli1bZuoXEhKCp59+2izobtmyBTdu3MDu3btx7733AgAGDhwIg8GAHTt2YNKkSWb9FQoFEhMTIZPJTG3Xr1+3eK5vvvkmXFxc8Omnn8LV1RVA3VQOrVaLDz74AM8++yxUKhVOnz6Nbt26YebMmaZjBw4caNPrSURkK666QETUzLKysvDKK69gwIAB6NGjB3r16oWJEycCANLT0xs9/vDhwxCJRHjssceg1+tN/3l7e6N79+745ZdfANQFYq1WixEjRpgdHxERgYCAALO2kydPIjg42BRy640ZMwaCIODkyZNm7UOGDDELudbU1tbi5MmTGDZsGJycnMxqHTRoEGpra5GSkgIACAsLw4ULF7BkyRIcPXoUFRUVjb4ORERNxRFdIqIm8vDwgFKptDqieavKykpMmDABCoUCs2fPRufOneHk5IS8vDzMmDEDNTU1jZ6jqKgIgiAgOjra6v31c3TrlzPz8vKy6FM/WlyvtLTUIvwCf06VuHVpNB8fn0brLC0thV6vR1JSktlc4JuVlJQAAF544QU4Ozvjyy+/xI4dOyCRSNCnTx/Ex8cjLCys0cciIrIFgy4RURNJJBL069cPR48eRV5eHvz8/Brse/LkSeTn5yMpKQn333+/qb0pc1E9PDwgEomwbds2s9Ud6tW3qdVqAHXB+FaFhYVmwVatVqOgoMCiX35+vukxbyYSiRqt093dHRKJBI8//jgmTJhgtU/9dA+pVIqYmBjExMSgvLwcx48fx+rVq/Hcc8/hxx9/hFKpbPTxiIgaw6kLRER34IUXXoAgCFi0aBG0Wq3F/TqdDocOHTIFxFsD6o4dOyyOqe9z6yjvgw8+CEEQcOPGDYSFhVn8FxoaCgAIDw+HXC7Hvn37zI5PSUlBdna2WVv//v1x+fJlnDt3zqw9OTkZIpEIUVFRtrwMZpRKJaKiopCWlobQ0FCrtd4aoIG6gPzII49gwoQJKC0ttaiViOhOcUSXiOgO9O7dG0uWLMHSpUsxduxYjBs3DiEhIdDr9UhLS8OuXbsQEhKCFStWQKVSYfHixZgxYwakUim++uorq5tCdOvWDQCwadMmDBo0CGKxGKGhoYiMjMTTTz+NhQsX4uzZs+jbty+USiUKCgrw22+/oVu3bpgwYQLUajViYmKwceNGuLu7m1ZdSEhIgI+Pj9mo7OTJk5GcnIwXXngBs2bNgr+/P3788Uds374d48ePN7sQrSlee+01TJgwAc888wzGjx+PgIAAVFZWIjMzE4cOHTKtMjFt2jSEhITgnnvugaenJ7Kzs7F161YEBAQ0uKIDEVFTMegSEd2hp556Cvfeey8++ugjbN68GQUFBZDJZOjcuTNGjRqFiRMnwsPDAxs3bsSqVaswd+5cKJVKDB06FKtXr8bo0aPNzjdq1CicPn0a27dvR0JCAgRBMK2ju2zZMoSHh2Pnzp349NNPYTQa0a5dO9x3331mF5TNmTMHSqUSO3bswJ49e9C1a1csWbIEq1evhru7u6mfp6cnduzYgXfeeQfvvPMOKisr0aFDB8ydO9dsZYemCg4Oxp49e7B+/XqsWbMGxcXFcHNzQ6dOnTB48GBTv6ioKBw4cAC7d+9GRUUFfHx8EB0djbi4uEYveiMishU3jCAicnBZWVkYMWIEZsyYgWnTptm7HCKiFsMRXSIiB3LhwgV8/fXX6N27N1xdXXH16lVs3rwZrq6uePLJJ+1dHhFRi2LQJSJyIEqlEmfPnsVnn30GjUYDV1dXREVFYfbs2RZLjBEROTpOXSAiIiIih8TlxYiIiIjIITHoEhEREZFDYtAlIiIiIofEoEtEREREDolBl4iIiIgcEoMuERERETkkBl0iIiIickgMukRERETkkBh0iYiIiMgh/R/XR9qVRGjPuQAAAABJRU5ErkJggg==",
      "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": 40,
   "metadata": {
    "executionInfo": {
     "elapsed": 8,
     "status": "ok",
     "timestamp": 1695329212064,
     "user": {
      "displayName": "m m",
      "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": 41,
   "metadata": {
    "executionInfo": {
     "elapsed": 27254,
     "status": "ok",
     "timestamp": 1695329239311,
     "user": {
      "displayName": "m m",
      "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": 42,
   "metadata": {
    "executionInfo": {
     "elapsed": 9,
     "status": "ok",
     "timestamp": 1695329239312,
     "user": {
      "displayName": "m m",
      "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": 43,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 9,
     "status": "ok",
     "timestamp": 1695329239312,
     "user": {
      "displayName": "m m",
      "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.88      0.92      0.90      2511\n",
      "    positive       0.92      0.88      0.90      2489\n",
      "\n",
      "    accuracy                           0.90      5000\n",
      "   macro avg       0.90      0.90      0.90      5000\n",
      "weighted avg       0.90      0.90      0.90      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": 44,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 30105,
     "status": "ok",
     "timestamp": 1695329269413,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "pOutPTF6qJY8",
    "outputId": "a034fc7e-f3ae-44e3-9bd9-2c416c5b45b3",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.0998\n",
      "F1-Macro:  0.09741574339051826\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": 45,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 605
    },
    "executionInfo": {
     "elapsed": 28733,
     "status": "ok",
     "timestamp": 1695329298142,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "F25gPUqgvw0w",
    "outputId": "747d6857-a67e-4f00-f9a9-fea35eee0d06",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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/erdm31N8TOn06kNGzZox44dat26tYYOHaqUlBT374FzBQYG6osvvlBoaKgfKgXwSzXJa36f0QWA87ntttu0Z88evfHGG+5Pdfr166ehQ4fq4YcfVl5envr376/f/va3atq0qVasWKEpU6a4x69fv16bNm3SokWLdPnll/vrNtDIBAQE6Nprr9W1117rbqtu676KigqVl1f1uhIAjZ0xHg8FYFgmk0lTpkzRhx9+qLi4OHXu3Fk33HCDUlJS9MEHH2jDhg36xz/+obFjx6q4uFjz5s3zOIfD4dCCBQv8UD0uJtddd12V7X379vV43TyAiwMzugAajSNHjmjlypUqKSnRwIEDK83AtmzZUlarVU6nUy+++KLH2N27d2vZsmXav39/lefevXt3fZUNgxg7dqy+/PJL7dixw93WokWLSp8QALi4EHQBNAqrV6/W5MmT3R8Rv/TSS0pKSvJYn1taWlrtPqjbtm1TmzZtdPToUY9j574IAKhKWFiYXnvtNa1du1ZPP/20LBaLlixZ4tOe7AAaB5YuAPC7M2fOaNq0aR7rIJcuXapNmzZVavtpM/+qtGjRQvfee69Hu8lk0j333FM3xcLQAgMDNWjQILVu3VoRERFq0qSJv0sCUAsEXQB+t2XLlipfBS6d3UFBkg4ePKj8/Hw5HA4NGDDAo19gYKDuuOMOjRkzRo899pj7pTGdO3fW888/r6uvvrr+bgAA0CixdAGA353vVatBQUF6/PHHtXz5cv20G6LZbNaAAQO0ceNGuVwutWrVSpMnT1b37t0lnd0nNSkpSU6n0zCvZAUA1BxBF0CNuFwuj1fy1tZll12mli1b6sSJEx7HTCaT3n333UptWVlZuvHGG7Vy5UoVFhYqLi5OQUFBKi0trdO6fik4OLhG71gHAPgXQReA11wul6ZPn14vOxg0a9ZMeXl57r1yTSaT2rRpo7fffrvK/mvWrNGRI0cUGBhY57VU59JLL9W0adMIuwBwkSDoAmgUmjRpom7duslms8npdCo8PFxms1n5+fn+Lg0AcJEi6ALwmslk0rRp0+p86cL5zJs3T6+88opHe58+ffTyyy83WB0SSxd+LYqKilRSUnLeteMALg4EXQA1YjKZFBIS0mDXu++++7Rx40Z999137rbmzZvrkUceadA68Ovw0ksv6fXXX3ev9546daqefPJJhYaG+rky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IiJyRvUFWZFI1KwCZ3PAEd1bNOcRXUe5dOkSLl68iMDAQAwYMIB3jxIRUbNj76kLhw4dQnx8vFX7yJEjERsba7c6gOb5rShHdMluunbtiq5duzq6DCIionvWFN+K3klUVBQKCgrw2WefoaqqChKJBE888QRiY2N5D8p9xqBLREREZGcvv/wyxowZg4yMDAQEBMDPz8/RJTklBl0iIiIiB3B1dUW3bt0cXYZT44RKIiIiInJKDLpERERE5JQYdImIiIjIKTHoEhEREZFTYtAlIiIiIqfEoEtERERETolBl4iIiIicEoMuERERETklBl0iIiIickoMukRERETklBh0iYiIiMgpMegSERERkVNi0CUiIiIip8SgS0REREROiUGXiIiIiJwSgy4REREROSUGXSIiIiJySlJHF/Ag0ev1EAQBycnJji6FiIiIiGzQ6XQQiUQN6suge4uG/tCIiIiIyDFEIlGDM5tIEAShieshIiIiIrI7ztElIiIiIqfEoEtERERETolBl4iIiIicEoMuERERETklBl0iIiIickoMukRERETklBh0iYiIiMgpMegSERERkVNi0CUiIiIip8SgS0REREROiUGXiIiIiJwSgy4REREROSUGXSIiIiJySgy6REREROSUGHSJiIiIyCkx6NJdLVy4EFFRUTh27BiioqIQHh6OUaNG4fz58+Y+Q4cOxZIlS7BhwwYMHDgQPXr0wKxZs1BQUODAyqm5acx7bdu2bRgyZAh69+6NmJgYFBcXO7Byam5uvtdOnz6NkSNHomfPnhg9ejRSUlLMfUJDQ7Fu3Tq8//77ePTRRxEREYGFCxeioqLCgZVTc9PQ99r69evx8ccfo3///oiMjMQ//vEPVFVVObBy58CgSw2i0WiwePFiTJs2DStWrIBcLse0adNQVFRk7nPw4EEcOnQI8fHxiI+PR3JyMubMmePAqqk5ash77fDhwzhy5AgWLVqEN998E2fOnME777zjwKqpOdJoNFi6dCmmTZuG5cuXo6amBrNnz4Zerzf32bp1K65du4b33nsPsbGxOHDgAN5++20HVk3NUUPea9u3b8dvv/2Gf/7zn4iJicHevXuxatUqB1btHKSOLoCah9LSUqxYsQL9+vUDAPTt2xeDBw/Gli1b8PrrrwMAKisrsW7dOqjVagBAixYtMHXqVJw4cQIDBgxwWO3U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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": 46,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 27580,
     "status": "ok",
     "timestamp": 1695329325716,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "zlbzZWECocpp",
    "outputId": "27337f4e-b8c6-4b92-a088-77f03f0ccd93",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.8748\n",
      "F1-Macro:  0.8700875816356158\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": 47,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 605
    },
    "executionInfo": {
     "elapsed": 29037,
     "status": "ok",
     "timestamp": 1695329354749,
     "user": {
      "displayName": "m m",
      "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": 48,
   "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": 49,
   "metadata": {
    "executionInfo": {
     "elapsed": 16,
     "status": "ok",
     "timestamp": 1695329438385,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "Ppy-K6l2gWtd",
    "tags": []
   },
   "outputs": [],
   "source": [
    "from IPython.display import clear_output"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {
    "executionInfo": {
     "elapsed": 38794,
     "status": "ok",
     "timestamp": 1695329477164,
     "user": {
      "displayName": "m m",
      "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": 51,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 30045,
     "status": "ok",
     "timestamp": 1695329507205,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "uEuhYVF-gMqC",
    "outputId": "3c4d554a-9320-4704-990c-0a6f0b392083",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.8884000000000001\n",
      "F1-Macro:  0.8843396816543188\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": 52,
   "metadata": {
    "executionInfo": {
     "elapsed": 13,
     "status": "ok",
     "timestamp": 1695329507206,
     "user": {
      "displayName": "m m",
      "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": 56,
   "metadata": {
    "executionInfo": {
     "elapsed": 11,
     "status": "ok",
     "timestamp": 1695329507206,
     "user": {
      "displayName": "m m",
      "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": 73,
   "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": [
    "\n",
    "print(\"Working\", end=' ')\n",
    "for i in range(186,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": 75,
   "metadata": {
    "executionInfo": {
     "elapsed": 13,
     "status": "ok",
     "timestamp": 1695379584055,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "36UtUdOcDjLK",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import statistics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 245
    },
    "executionInfo": {
     "elapsed": 13,
     "status": "error",
     "timestamp": 1695379584056,
     "user": {
      "displayName": "m m",
      "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": 77,
   "metadata": {
    "executionInfo": {
     "elapsed": 19,
     "status": "ok",
     "timestamp": 1695379585268,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "mmW3cTd4o6Hb",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 175
    },
    "executionInfo": {
     "elapsed": 17,
     "status": "error",
     "timestamp": 1695379585269,
     "user": {
      "displayName": "m m",
      "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": 79,
   "metadata": {
    "executionInfo": {
     "elapsed": 15,
     "status": "aborted",
     "timestamp": 1695379585271,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "uMGPmojj4SeF",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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e2ratKlfAgMAlG2+zNhguVzKcjoV5nB4NT0OszaYZ7PbVbFBjOkwjPO4EPvLX/6iv/71rxowYIBuv/121ahRQ4cOHdKiRYv03//+V3PmzCmOOAEAZYyxGRskZm1AieFxIdahQweNGzdOL7zwgh566CHZbDZZlqWKFSvq2WefVfv27YsjTgAAUIa4srP1v4/+KUm6omcPw9GY49Vck3379lWPHj20adMmHT9+XFWqVFFCQoIiIyP9HR8AACiDrNxc7X3rtwe/X35Dd8PRmOP1pN+RkZFq27atP2MBAAAIKl4VYpZl6YcfftDBgweVVci3HG666SafAwMAACjrPC7Efv75Z91///3au3evLMsqsN5ms1GIAQAAFIHHhdi4cePkdDo1depUxcbGyuFwFEdcAAAAZZ7HhdiWLVv07LPPqnv34L2xDgAAwB88LsQiIyNVoUKF4ogFAPI5sHevYv3wpSBPH/7Jwz4BBIrHhVjv3r21cuVKdejQoTjiAQC3bJvNzAM/edgnUOxCQkPVdPwz7mWmOCqihg0b6p///KeGDBmizp07q3LlygW26WbqSckAAKBUsNntqhTPtIgeF2IPP/ywJOnAgQP6/PPPC6y32Wzavn27z4EBAACUdR4XYgsWLPBrAKtXr9ZHH32kbdu2KTU1VbVr19btt9+ufv36KeR393KsX79eU6dO1e7du3XZZZfp7rvv1p133unXWAAAQGC4cnJ06OO1kqQa13U1HI05HhdiV199tV8DmD9/vq644gqNGjVKVatW1TfffKMJEyZo//79Gj16tCRp06ZNGjp0qHr16qUxY8bou+++0/jx4+VwONS3b1+/xgMAAIqflZOjPXPmSZKqX9vJcDTmeD3F0alTp/T999/rxIkT6tixoypVquTVfl577TVVqVLF/bpNmzZKT0/XwoUL9be//U0Oh0MzZ85U48aN9dxzz7m3+eWXXzRt2jT16dMn38gZAABAaeFVBTNz5ky1b99egwcP1ujRo3XgwAFJ0sCBAzVnzhyP9vX7IixPXFycsrKydPLkSTmdTm3cuFE9euSfmb1nz546cuSIfvzxR29SAAAAMM7jQmzhwoWaOXOmbrnlFs2ePTvfNEedOnUq9AZ+T3377beqXLmyqlatqn379ik7O1v169fPt01MTIwkaffu3T73BwAAYILHlyYXLlyou+++W6NGjVJubm6+dVdeeaX27t3rU0A//PCDli1bpmHDhslutys1NVWSFBUVlW+7vNd5671hWZbS09O9D1ZSRkZGvr/LsgvlarlcgQ7nbMcF5zsty/1aLpfP52weT87dYDu+/vw9B1Jpez8ydl6p9Bzj0nZMPZGbmeleTk9Pl/Psv/eL5WpZlmw2W7HGFkgeF2L79+9X+/btC11Xvnx5paWleR3MkSNHNGLECMXHx2vw4MH51p3vl+7LwcjOzvbbozZSUlL8sp/SoLBcs5zOwAciyVAZZqzfLKfT74+HKcq5G2zHtzh+z4FUWt6PTJ1XeX2bOMbDRo3SLydPBrzfyytX1swXXwx4vxdi/e7479y5U7azc1cX5fwtS/Nce1yIVaxYUUePHi103cGDB1W1alWvAjl16pQGDx6s8PBwvfrqqwoNDZUk95cA/jjylVfw/XGkzBOhoaHuS5zeysjIUEpKiurWrauIiAif9lXSXSjXMEP/KEz9n8hUv2EOh+Li4vyyL0/O3WA7vv78PQdSaXs/MnVe5fVt4hgfT0/XvhtvDHi/YWvWlLhzOjczU1vOLsfGxsppWUU6f5OTkwMTYIB4XIglJiZq3rx5uvbaaxUWFibpt1GpnJwcLVq0SO3atfM4iKysLN1///06evSoFi9erEsuucS9rk6dOgoNDdWePXvyTauUdyCio6M97i+PzWZTZGSk1z//exEREX7bV0lXWK5Fmb+vWJganjbUry0kxO/nWVHO3WA7vsXxew6k0vJ+ZOy8krljbCrnknhOW2FhinvicUlShUqVlHF2iqOLnb9l6bKk5MXN+iNGjND//vc/9ejRQ88//7xsNpv+8Y9/qG/fvtq7d6+GDh3q0f5ycnI0cuRI7dixQ/PmzVPNmjXzrXc4HGrTpo1Wr16dr33lypWqVq2aGjdu7GkKAADAMJvdriqt/qQqrf4km91uOhxjPC7ErrzySi1atEj169fXokWLZFmWPvjgA11yySV65513dMUVV3i0v3Hjxumzzz7TkCFDlJmZqe+//9795/Tp05KkYcOGaevWrRo7dqy++eYbvfrqq1qyZIlGjhzJM8QAAECp5dUDXWNiYvT666/L6XTqxIkTqlSpksLDw70K4KuvvpIkTZo0qcC6BQsWqHXr1kpISNCsWbP00ksvacWKFbrssss0duxYnqoPAEAp5crJ0ZH1X0iSqnXscJGtyy6vn6wv/XbZsEaNGj4F8OmnnxZpu44dO6pjx44+9QUAAEoGKydHydNnSpIubXuN4WjM8bgQe+WVVy643mazadiwYV4HBAAAECwoxAAAAAzxuBDbsWNHgbaTJ0/qX//6l9566y2P55oEACDQDuzdq9i2bQPf78GDAe8TJZtP94jlqVy5sm655RYdP35c48eP18yZM/2xWwAAikW2zaafunULeL+h8+YFvE+UbH599kN8fLw2bNjgz10CAACUWX4txHbu3FnintwLAABQUnl8aXLFihUF2pxOp3bu3KmlS5fqRgNzaAEAgL9It6MAACAASURBVNIlJDRUsaMedi/r7BRHwcbjQmzMmDGFtoeFhenGG2/UqFGjfA4KAACUbTa7PaifH5bH40Js3bp1BdrCwsJ06aWX+iUgAACAYOFxIfbHSbkBAAA8ZeXm6tjGbyRJVdu0NhyNOX55fAUAAIAnXNnZ2vniFElSm8ULDUdjjseFWKNGjWSz2Yq0rc1m048//uhxUAAAAMHA40Js2LBhWr58uc6cOaPOnTvr0ksv1ZEjR/TZZ5+pfPny6t27d3HECQAAUOZ4XIiVL19el156qT766COVL1/e3X769Gndc889Cg8P17333uvXIAEAAMoijx/o+s477+jee+/NV4RJUoUKFXTvvffqnXfe8VtwAAAAZZnHhdihQ4dkt9sLXWe323X06FGfgwIAAAgGHhdi0dHRevPNN5WdnZ2v3el0av78+apfv77fggMAACjLPL5H7MEHH9SwYcPUpUsXde3aVdWqVdORI0e0du1aHT16VDNnziyOOAEAQBliK1dOMSOGuZfldBqOyAyPC7E///nPmjdvnqZOnap33nlHLpdLNptNzZo108SJE3XNNUxXAAAALiykXDnVuLbzuQYKsaJLTExUYmKiMjIylJaWpqioKEVERPg7NgAAgDLNpyfr5z3YNTQ01C/BAACA4GDl5urEpu8lSZcktDAcjTke36wvSRs3btRtt92mli1bqlOnTtq5c6ck6ZlnntEnn3zi1wABAEDZ48rO1vZnn9P2Z5+T6w9fAAwmHo+IbdiwQffee68aNGigv/zlL5o3b5573SWXXKJly5apW7dufg0SAALpwN69im3bNuD9Xlm9uj5Zvjzg/QIwx+NCbPr06erQoYNeffVV5eTk5CvEGjVqpGXLlvk1QAAItGybTT+Z+A8lVxSAoOPxpcnt27erX79+klRg8u8qVaro2LFj/okMAACgjPO4ELPb7QUe5prn2LFjBaY+AgAAQOE8LsTi4+P14YcfFrru448/VosWwfvNBwAAAE94fI/Yfffdp0GDBmnYsGG66aabZLPZtHnzZi1dulQff/yx3nrrreKIEwAAoMzxuBC75ppr9Pzzz+u5557TunXrJEnjxo1TVFSUJk6cqFatWvk9SAAAULbYypVT/fvudS/zZH0P9OrVS9ddd502bdqko0eP6pJLLlHLli0VGRnp7/gAAEAZFFKunC7vcf25Bgqxi8vMzNTdd9+tESNG6JprrlFiYmJxxQUAAFDmeVSIhYeH66effpLdbi+ueOCjbjffrL2HDxfLvi2XS1lOp8IcDtlC8n/P48DBg8XSJxBMfH2Q7IX+jV4ID5KFCVZurtJ+3C5JimocZzgaczy+NJmQkKAtW7aodevWxREPfLT38GEjD6IM/d2DfQF4hwfJIpi4srO1dexTkqQ2ixcajsYcjx9fMXr0aC1evFgrVqzQmTNniiMmAACAoODxiNhtt92m7OxsPfbYY3rssccUHh6e7wn7NptN3377rV+DBAAAKIuKVIjt2LFD9erVU1hYmLp37+7XAPbu3avXX39dmzdv1q5du1S/fn2tXLky3zZjxozR8kLuX5g7d646dOjg13gAAAACpUiF2M0336zFixerWbNmOnjwoJ566ilFR0f7JYBdu3Zp/fr1at68uVwulyzLKnS72rVra/Lkyfna/BUDAACACUUqxBwOh5xnn+/xn//8x6/3hnXu3FldunSR9NvI19atWwvdLjw8nOmTAABAmVKkQqx27dqaP3++jh49Kkn65ptv9Ouvv553+24efOsnxIOvWAMAAJQlRSrEhg4dqlGjRmndunWy2WyaMmXKebe12Wzavn273wLMs2/fPrVq1UqZmZlq2LChhg4d6h5JAwAApYvNbteVAwe4l+VyGY7IjCIVYjfccIPatGmjn3/+WXfeeaeefPJJxcTEFHdsbnFxcYqPj1dMTIxOnTqlRYsWadiwYZo2bZpPXx6wLEvp6ek+xZaRkZHvb9MsUyfyee7to18/d+ty+XzO5vHk3OW8Ktv9+vO88rRfYzjGJUKV7r9dQcvMzi7ye5JlWfme1lDaFfnxFVWqVFGVKlV08803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AADglVJTiAEAAJQ1peIeMQAAgLKIQgwAAMAQCjEAAABDKMQAAAAMoRADAAAwhEIMAADAEAqxC/j55581aNAgtWjRQomJiRo/frwyMzMv+nOrVq3SAw88oPbt2ys2Nlavv/56AKL1njd5nj59WjNmzFDfvn3VqlUrtWnTRoMGDdK2bdsCFLV3vD2mkyZNUo8ePZSQkKCWLVuqT58++uc//xmAiL3jbZ6/t3btWsXGxiopKamYovQPb3MdMGCAYmNjC/z543RqJYUvx/TkyZN6+umn1a5dO8XHx+u6667Tu+++W8wRe8+bXA8cOFDo8YyNjVXTpk0DFLlnvD2m6enpmjx5srp06aLmzZurW7dumjFjhpxOZwCi9py3eTqdTk2aNEnt2rVTs2bNdMstt2jDhg0BiDiwypkOoKRKS0vTwIEDdcUVV2j69Ok6fvy4Jk6cqJMnT170af5r1qzR/v371alTJy1evDhAEXvH2zz/97//afHixerTp49GjBihnJwcLViwQP369dO7776rJk2aBDCLovHlmGZkZKhfv36qV6+eLMvSxx9/rIceekgul0s9e/YMUAZF40ueeTIzMzVx4kRdeumlxRytb3zNtWXLlho9enS+tlq1ahVXuF7zJc8zZ85owIABCgsL0+OPP66qVatq7969ys7ODlD0nvE21+rVqxd4v7UsS4MHD1br1q2LO2yP+XJMn376af3rX//S3/72NzVo0EBbtmzR9OnTlZqaqrFjxwYog6LxJc/nnntOH3zwgR588EHVr19fy5Yt0+DBg7V48eIS+RnjNQuFmj17ttW8eXPr2LFj7rYPP/zQatiwoZWcnHzBn83NzXUvN2zY0Jo3b16xxekrb/M8c+aMlZ6enq8tMzPTatu2rTVmzJhii9cXvhzTwtx2223WPffc488Q/cIfeb788svWnXfeaY0ePdrq0aNHcYXqM19y7d+/v3XfffcVd4h+4UueU6ZMsbp06WJlZGQUd5h+4c9/pxs3brQaNmxorVq1yt9h+szbPLOzs634+Hhr2rRp+dqfeuopKzExsdji9Za3ef76669WXFyctWDBAneby+WykpKSrCFDhhRrzIHGpcnz+OKLL5SYmKgqVaq426677jo5HA6tX7/+gj8bElJ6fq3e5hkZGamIiIh8bWFhYYqOjtbhw4eLLV5f+HJMC1O5cuUSOarga5779u3T/PnzS9z/rAvj72NaUvmS59KlS3XLLbeUmung/HlMV65cqQoVKqhz587+DtNn3uZpWZZyc3NVsWLFfO1RUVGySuBEOd7muWPHDuXm5qpdu3buNpvNpnbt2umrr74qsZdhvVF6KoYA2717t6Kjo/O1ORwO1alTp8TeQ+INf+aZnp6u7du3q379+v4M0W98zdWyLOXk5CgtLU0rVqzQ119/rTvvvLO4wvWar3lOmDBBvXr1UqNGjYorRL/xNdf//Oc/atGiheLj49W/f3/93//9X3GF6hNv89y/f7+OHj2qqKgo/fWvf1XTpk3VunVrPfPMMx7fMxgo/npPys7O1ieffKKuXbsqLCzM32H6zNs8Q0ND1bt3b7399tvavHmzzpw5o40bN+q9994rU+9HeYVWaGhogZ91Op06cOCA/4M1hHvEziMtLU1RUVEF2qOiopSammogouLhzzxffvllZWRkqH///v4Kz698zXXDhg265557JEnlypXTE088oe7du/s9Tl/5kuenn36qTZs2ac2aNcUVnl/5kutVV12lXr16qW7dujp8+LBef/113XPPPXr77beVkJBQXCF7xds8jx49Kkl68cUX1b17d82dO1fJycl66aWXlJ2drfHjxxdbzN7y13vSF198oZMnT5bYL5v4kufTTz+tp556Srfeequ7bcCAARo+fLjf4/SVt3nWrVtXkrRly5Z8921+//33klSmPocpxDxkWZZsNpvpMIqdp3l+9NFHeuutt/Tkk0/qyiuvLMbI/K+ouTZr1kzvv/++Tp8+rS+++ELPPvus7Ha7+vbtG4AofXexPLOysvTcc8/pgQceyHcZoTQqyjEdMWJEvtd//vOflZSUpFmzZmnu3LnFGZ7fXCxPl8slSYqOjtbEiRMlSYmJicrJydGLL76okSNHqlq1agGJ1VfevCddeumlSkxMLMao/K8oeU6ePFmff/65nn32WdWrV0/btm3T9OnTFRUVVeC8LqkulmeDBg109dVXa/LkybrssstUr149LVu2zD1qXZpuAbqYspOJn0VFRSktLa1A+6lTpwqt7ksrf+T59ddf67HHHtOgQYNK5NB4Hl9zrVChguLj45WYmKjRo0erX79+ev7555Wbm1sc4XrN2zzfeusthYSEqEePHkpLS1NaWpqys7PlcrmUlpZWIu/J8Oe/08jISHXs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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(f1s, bins=15,facecolor = '#008080', edgecolor='#000000', linewidth=0.5)\n",
    "\n",
    "\n",
    "vertical_line_position = 0.896  # Change this to the desired position\n",
    "plt.axvline(x=vertical_line_position, color='r', linestyle='--', label='Vne')\n",
    "plt.text(x=vertical_line_position,y=max(hist),s='Native',ha='left', va='bottom')\n",
    "\n",
    "    \n",
    "plt.xlabel(\"F1-Macro\")\n",
    "plt.ylabel(\"frequency\")\n",
    "\n",
    "#plt.title(\"bert-base\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "'''\n",
    "df_randomization_test = pd.DataFrame(list(zip(f1s, accuracy,p_word_list,n_word_list)),\n",
    "               columns =['f1s', 'accuracy','p_word_list','n_word_list'])\n",
    "df_randomization_test.to_csv('roberta_randomizationtest.csv')\n",
    "'''"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "57"
      ]
     },
     "execution_count": 90,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "f1s.index(0.8736705409712142)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_neutral = df_senti[df_senti['Sentiment']=='Neutral'].sample(n=20, random_state=random_seeds[11])\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": 92,
   "metadata": {
    "executionInfo": {
     "elapsed": 33,
     "status": "aborted",
     "timestamp": 1695329093833,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "-nnwzm980k1q",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.49400000000000005\n",
      "F1-Macro:  0.48374411815421087\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": 93,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093833,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "7cdh2kXd0-Zb",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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QCwW662OvoAjum1wRJeI6Nmh71G2EydOYN26de3aZ82ahdWrV+utDqB3jrJR1ykUCty5cwfW1tYYMGCAocvpNTiiS0REvZ6+R9lmzpyJ0tJS7N27Fw0NDTAyMsIrr7yCVatWcTcZ6hESiQSOjo6GLkPQGHSJiIj+X0REBEJCQlBUVITnnnsOzz33nKFLIqLfgUGXiIioDblcDk9PT0OXQUTdgLPriYiIiEiQGHSJiIiISJAYdImIiIhIkBh0iYiIiEiQGHSJiIiISJAYdImIiIhIkBh0iYiIiEiQGHSJiIiISJAYdImIiIhIkBh0iYiIiEiQGHSJiIiISJAYdImIiIhIkBh0iYiIiEiQGHSJiIiISJAYdImIiIhIkBh0iYiIiEiQGHSJiIiISJBMDF3As0SpVEKtVqOgoMDQpRARERFRBxQKBUQikU59GXTb0PVFIyIiIiLDEIlEOmc2kVqtVvdwPUREREREesc5ukREREQkSAy6RERERCRIDLpEREREJEgMukREREQkSAy6RERERCRIDLpEREREJEgMukREREQkSAy6RERERCRIDLpEREREJEgMukREREQkSAy6RERERCRIDLpEREREJEgMukREREQkSAy6RERERCRIDLpEREREJEgMutSp2NhYBAYG4syZMwgMDISHhwdmz56N8+fPa/r4+/tj48aN2L17N6ZMmYLRo0dj2bJlKC8vN2Dl1Nt05Vzbv38/pk6dipdeegmRkZGoqqoyYOXU2zw8186dO4fXX38dY8aMwZw5c1BYWKjp4+bmhl27dmHLli2YMGECxo4di9jYWNy/f9+AlVNvo+u5lp6ejn/84x/w8fGBt7c31qxZg4aGBgNWLgwMuqSTiooKxMfHY9GiRdi2bRskEgkWLVqEyspKTZ8TJ07g5MmTiIuLQ1xcHAoKCrB8+XIDVk29kS7nWm5uLk6dOoX169dj7dq1+P777/HBBx8YsGrqjSoqKpCQkIBFixYhOTkZTU1NiIqKglKp1PTJyMhAUVEREhMTER0djePHj2PdunUGrJp6I13OtQMHDqC4uBibN29GZGQkjh07hrS0NANWLQwmhi6Aeoeamhps27YNEydOBACMGzcOfn5+2LdvH1auXAkAqK+vx65du2BmZgYAsLe3x4IFC/DNN99g8uTJBqudehddzjW1Wo0PP/wQEokEAFBcXIw9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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": 94,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093834,
     "user": {
      "displayName": "m m",
      "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[0]]\n",
    "n_spurious_sentences = [list(df_senti[df_senti['Word'] == i]['Definition'])[0] for i in n_words_spurious[0]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093834,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "AoDiCBpM6glm",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.8028000000000001\n",
      "F1-Macro:  0.7962240928600959\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAroAAAISCAYAAAAjsmyaAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAPYQAAD2EBqD+naQAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nOzde1yUZf7/8fcwzHAQR8FDSoYhFqZpagdFSy0r29Rq0zZ2zTU1Kyhq60u5ubXaygZbfjuYZWZalL/SjqyWZm6WWqmVmXlA+4oHNA94glE5DDDz+6ONJFCZcZgb7nk9H48ej+aa+5r7M3jNzXsurvu+LR6PxyMAAADAZEKMLgAAAACoDwRdAAAAmBJBFwAAAKZE0AUAAIApEXQBAABgSgRdAAAAmBJBFwAAAKYUanQBDcnatWvl8Xhks9mMLgUAAAC1KC8vl8ViUY8ePU67LUH3BB6PR9w/AwAAoOHyJqsRdE/wy0xu165dDa4EAAAAtVm/fn2dt2WNLgAAAEyJoAsAAABTIugCAADAlAi6AAAAMCWCLgAAAEyJoAsAAABTIugCAADAlAi6AAAAMCWCLgAAAEyJoAsAAABTIugCAADAlAi6AAAAMCWCLgAAAEyJoAsAAABTIugCAADAlAi6AAAAMCWCLgAAAEyJoAsAAABTCjW6AAD4xbfffqu3335bR44c0aWXXqrk5GQ5HA6jywIANFIEXQANwnvvvaeJEyfK4/FIkr766istWLBAb775ppo2bWpwdQDgX7t379acOXO0ceNGtW3bVsnJyerZs6fRZZkOQReAVzwej8rKyvz6mi6XS08//XRVyP3Ftm3b9Oabb2rUqFFV+5Yki8Xi1/3XVVhYmGH7BmAeu3bt0u23366ioiJJUm5urj7//HNlZmZq4MCBBldnLgRdAHXm8Xj0+OOP68cff/Tr6xYXF6uwsLDW51599VUtW7ZMZWVlKi4ult1uV5MmTfy6/7o6//zzNXHiRMIuYDL18QX+VGbPnl0Vcn/hdrs1bdo09enTJ6DHGLN/gSfoAjCczWY76XOhoaHatWuXDh8+XNUWGRmp+Ph4hYZyCANwZurrC/yp7Nixo9b2X2Z6rVZrwGox+xd4fksAqDOLxaKJEyfWy8zHgw8+qGXLllVrCwkJ0dChQ/X6669Xay8uLlZsbKyysrL8XsepmH3mA0BghIaGyuVy1WgPCQlRSAgXxPIni+e3i+KC2Pr16yVJXbt2NbgSIPg4nU499thjWrp0qdxut1q3bq3/+Z//0Ztvvql169bV2D40NFQrV65UZGSkAdUCMJNAL11YuXKlHnrooRrtI0aMUEpKSsDqkBrnF3hv8hozugAaBIfDoeeee04HDhxQUVGRzj33XIWGhurVV1+tdfuKigpVVFQEuEoAZmSxWBQeHh6w/V155ZWaOHGipk+froKCAoWEhOjWW29VWloaS7L8jPlxAA1Kq1at1LFjx6qD/YABA2rd7pJLLuEauwAaraFDh+qdd95RfHy8OnTooHvuuYeQWw8IugAatNGjR6tLly7V2po3b65HHnnEoIoAwD+sVqtsNhvrcusRP1kADVpUVJTmzJmjf/7zn2rZsqViY2P1/vvvq1OnTkaXBgBo4Ai6ABo8u92u6667TmeffbZatWqlZs2aGV0SAKARIOgCAADAlFj1DAAAYBC3213r5b1Wr16t5cuXKzw8XL/73e/UsWNHA6pr/Ai6AAAAAbZs2TK9+OKLysvLk9Vq1Zw5czR27FhZLBZNnjxZ//73v6u2ff311zV+/HgNHz7cwIobJ4IuAABAAH333Xd66KGH5Ha7JUmVlZV66aWXZLFYdNFFF1ULudLPN7R45plndM0113COgpcaxBrd7du3a+zYserevbuSkpKUkZGh0tLS0/YrLi7WlClTdPXVV+uiiy7Stddeq+eff77W2+oBAAA0BP/v//2/qpB7orfeeksrVqyotU9ZWZm++eab+i7NdAyf0XU6nRo1apRiY2M1depUHT58WJmZmSosLNSUKVNO2XfSpEn6z3/+owceeEDnnXeefvjhB02dOlVFRUV69NFHA/QOAARCcXGxiouLZbPZjC4FgJ8F+ha8RsvPz6+1vbCwsNYA/Aur1VqnicDGpL5vQWx40J07d66cTqdycnIUExMj6ed/yPT0dKWkpCghIaHWfhUVFfr44491xx13aOTIkZKk3r17a8+ePVq4cCFBFzCRmTNnaubMmTp+/Lgk6bHHHtPkyZMDestOAPWnrKxMY8aMMbqMgDl48GCt7aGhofrqq69qfc5qterll1/WzJkz67O0gJs9e3a9HssNX7qwfPlyJSUlVYVcSRo0aJDsdruWLVt20n4ej0eVlZVq2rRptXaHwyGP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YdXa7Ha74uLilJeXd9q6vv76a3Xv3l2VlZW66KKLdP/995+yxtPxeDwqLi72ul9ZWZnP+0TjVlJSIrfbHbD9MdaCV6DHGhAoHNeCly/HNY/HI4vFUqdt6xx058yZ41URUVFRuvfee0+7ndPplMPhqNHucDhUVFR0yr6XXnqpbrzxRp177rkqKCjQrFmzNHr0aL3xxhvq0aOHV/X+ory8XLm5uT71Q3DasmWLbDZbwPbHWAtegR5rQKBwXAtevh7X7HZ7nbbz+1UX9u/fr0OHDqlz585n9Dp1Sev33XdftccDBgzQkCFD9OKLL2rmzPP5WtUAACAASURBVJk+7ddms6ljx45e9+PbaPBKTExUWFhYwPbHWAtegR5rQKBwXAtevhzXtm7dWudtfQq6e/bsOelzn3zyiWbMmKGVK1fW6bUcDoecTmeN9qNHj3p9ibDIyEj1799fixcv9qrfiSwWiyIjI73ud7qT7mBeERERp70Unj8x1oJXoMcaECgc14KXL8e1ui5bkHwMulddddUpdxIfH1/n10pISKixFtflcik/P7/G2t268Hg8XvcBAACA+fgUdJ944okaQbe4uFjffvutPv30U2VlZdX5tfr166fp06fryJEjio6OliQtWbJELpdL/fv396qu4uJiLVu27JQnvwEAACA4+BR0b7755lrbR4wYoaysLD311FN644036vRaycnJmjNnjlJTU5WamqpDhw4pKytLQ4cOrbZ0YcKECcrJydGmTZskSd9++61mzZqla665RrGxsSooKNCrr76qAwcO6LnnnvPlbQEAAMBE/H4yWv/+/fXWW2/VeXuHw6Hs7GxlZGQoLS1N4eHhGjJkiNLT06tt53a7VVlZWfW4VatWcrlcevrpp1VYWKiIiAj16NFDjz/+uLp16+a39wMAAIDGye9B98iRI2rRooVXfeLj4zVr1qxTbpOVlVVtSUT79u1P2wcAAADBy29B1+12a/PmzXrppZd0//33++tlAQAAAJ/4FHQ7dep00qsueDwe/fWvf9Vf//pXST9fAuKXdbUAAABAoPgUdO+55x6vrmEGAAAABJpPQTctLc3fdQAAAAB+xa1IAAAAYEp1DrqTJk3SgQMHvHrxTz75RPPnz/e6KAAAAOBM1Tnobt++XVdffbXS09O1YsUKlZSU1Lrdzp07NXv2bA0ZMkR/+9vf1KxZM78VCyB4uSoqtePwUR0tLTe6FABAI1HnNbrZ2dn6z3/+o5dfflnjxo1TaGio2rdvr5iYGIWFhamoqEi7du1SUVGRIiIidPPNNyslJcXra+oCwG+9t267Xv/m/+QsLZctJESDLmintH6dZbdajS4NANCAeXUy2tVXX62rr75amzZt0meffaZ169apoKBABw4cUHR0tAYOHKjLLrtMAwcOVFRUVH3VDCCIrMjbp2krfr1EYbnbrQ835issNET3XtHFwMoAAA2dT1dd6Ny5szp37uzvWgCghn9v2Flr+8JNu3Rnn07M6gIAToqrLgBo0A4fL6u1vaS8UiWuygBXAwBoTHwKuitXrtSiRYuqHh88eFDjxo1T37599fDDD6usrPZfTADgra6x0bW2nxsTpWYR9gBXAwBoTHwKulOnTlVeXl7V46eeekrffvutevToocWLF+uVV17xW4EAgtufLu6omMiwam2hIRbd2aeTQRUBABoLn4Lujh07qtboVlRUaMmSJUpPT9e0adN033336aOPPvJrkQCC11lNIzTjD5frjz0T1OPsFrrugnZ6YXhfJZ17ltGlAQAaOJ9ORjt27JgcDockaePGjSopKdHAgQMlSd26ddO0adP8VyGAoNcyKpwZXACA13ya0W3RooV27NghSfrqq68UGxurNm3aSJKOHz+u0FCf8jMAAADgNz4l0iuuuELPPPOMtm7dqg8++EA33XRT1XPbtm3T2Wef7bcCAQAAAF/4FHQfeOAB7dmzR2+//ba6deumlJSUquc+/PBD9ejRw28FAgAAAL7wKejGxMRo1qxZtT73+uuvy27nkj8AAAAw1hnfMKK0tFT79+9XRUWFJCkqKoqgCwAAAMP5HHRXrVqlW2+9VT179tSVV16pLVu2SJIef/xxffLJJ34rEAAAAPCFz3dGGzt2rMrKyjRmzBi53e6q56Kjo/X+++/7rUAAAADAFz7fGa1fv37KycnRX/7yl2rPderUSZs3b/ZLcQAAAICvfAq6ubm5Sk5OliRZLJZqz8XExOjQoUNnXhkAAABwBnwKularVeXl5bU+d+jQITVp0uSMigIAAADOlE9Bt2vXrpo/f36tzy1evFjdu3c/o6IAAACAM+XTdXTvvPNOjR07Vvfcc49uuukmWSwWrVu3Tu+9954WL16s7Oxsf9cJAAAAeMWnoNunTx9lZWXp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d3SJSHQGDRqEQYMGWbsM6sZ+bZKsjY3NI0OlRCLhBFuibopBl4iInjjmmmSbkpKCL774wqA9OTkZra2tSEpKMjj28ssvY8WKFV1aR0c4dIGoazDoEhHRE8kc48GTkpKg0Whw8uRJtLe3w8nJCYsXL0ZUVBQAQKFQYNeuXbh79y569eqFyZMnc1tWom6MY3QfwDG6REQ9Q01NDWpra+Hn52ewu1lzczMqKirQv39/9O/f30oVEtGjcIwuERHRr/i1EOvk5ITg4GALV0RE5sDR9UREREQkSgy6RERERCRKDLpEREREJEoMukREREQkSgy6RERERCRKDLpEREREJEoMukREREQkSgy6RERERCRKDLpEREREJEoMukREREQkSgy6RERERCRKDLpEREREJEoMukREREQkSgy6RERERCRKDLpEREREJEoMukREREQkSgy6RERERCRKttYu4EmiVqshCAJKS0utXQoRERERGaFSqSCRSEzqy6D7AFPfNCIiIiKyDolEYnJmkwiCIJi5HiIiIiIii+MYXSIiIiISJQZdIiIiIhIlBl0iIiIiEiUGXSIiIiISJQZdIiIiIhIlBl0iIiIiEiUGXSIiIiISJQZdIiIiIhIlBl0iIiIiEiUGXSIiIiISJQZdIiIiIhIlBl0iIiIiEiUGXSIiIiISJQZdIiIiIhIlBl0iIiIiEiUGXerQypUrMXXqVJw5cwZTp05FUFAQpk+fjpKSEl2fiRMnYu3atdi5cyfGjRuHkJAQLF26FLW1tVasnLqbzpxrH330ESZMmIBnn30W8fHxqK+vt2Ll1N3cP9fOnz+Pl19+GSNGjMDMmTNRVlam6xMYGIgdO3bgvffew5gxYzBy5EisXLkSzc3NVqycuhtTz7XMzEy8//77iIiIQFhYGFatWoW7d+9asXJxYNAlk9TV1SE1NRVxcXHYsmULpFIp4uLicOvWLV2f48eP48SJE0hJSUFKSgpKS0vx2muvWbFq6o5MOddOnjyJU6dOYc2aNVi9ejUuXLiAdevWWbFq6o7q6uqwfv16xMXFIS0tDa2trUhISIBardb1ycnJQUVFBTZu3IjExEQUFhYiKSnJilVTd2TKubZ371789NNPePfddxEfH48jR45g69atVqxaHGytXQB1D0qlElu2bEF4eDgAYPTo0Xj++eexe/duvPXWWwCAO3fuYMeO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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": 96,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093835,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "t-1o_fPd_MEy",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['radicalism',\n",
       " 'tilting_board teetertotter teeterboard teeter-totter teeter seesaw dandle_board',\n",
       " 'war-worn war-torn',\n",
       " 'allegorize allegorise',\n",
       " 'writ_of_election',\n",
       " 'oven_broil broil',\n",
       " 'slop_bowl slop_basin',\n",
       " 'rank_and_file rank',\n",
       " 'agama',\n",
       " 'sacral_vertebra']"
      ]
     },
     "execution_count": 96,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "n_words_spurious[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "metadata": {
    "executionInfo": {
     "elapsed": 33,
     "status": "aborted",
     "timestamp": 1695329093836,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "lvMoMpyEXQVt",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['jupiter_optimus_maximus best_and_greatest',\n",
       " 'double_cross double-crossing',\n",
       " 'mccormick cyrus_mccormick cyrus_hall_mccormick',\n",
       " 'sandwich_board',\n",
       " 'noncombinative',\n",
       " 'business_traveler',\n",
       " 'pinus genus_pinus',\n",
       " 'pilus',\n",
       " 'extrovert extravert',\n",
       " 'psidium_guineense brazilian_guava']"
      ]
     },
     "execution_count": 97,
     "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": 98,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093836,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "M4c1i-jEnOia",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import os, sys\n",
    "\n",
    "filenames = []\n",
    "\n",
    "path = \"/home/m_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": 99,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093836,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "uAcBqk9LpYds",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Advocate.csv is Positively Spurious.\n",
      "Positive Acc: 0.8787039202197783 \n",
      "Negative Acc: 0.11089385762947129\n",
      "------------------------------------------------------------------------\n",
      "Dialogue.csv is Positively Spurious.\n",
      "Positive Acc: 0.8904984997746103 \n",
      "Negative Acc: 0.10461615027262268\n",
      "------------------------------------------------------------------------\n",
      "Indian.csv is Positively Spurious.\n",
      "Positive Acc: 0.8653068421848689 \n",
      "Negative Acc: 0.14166424195629557\n",
      "------------------------------------------------------------------------\n",
      "Orientation.csv is Positively Spurious.\n",
      "Positive Acc: 0.8193288886200251 \n",
      "Negative Acc: 0.14971622041253732\n",
      "------------------------------------------------------------------------\n",
      "Colored.csv is Positively Spurious.\n",
      "Positive Acc: 0.8759178690879418 \n",
      "Negative Acc: 0.11315375629761636\n",
      "------------------------------------------------------------------------\n",
      "occupations1950_nonprofessional.csv is Positively Spurious.\n",
      "Positive Acc: 0.7766066587348277 \n",
      "Negative Acc: 0.1718250141309838\n",
      "------------------------------------------------------------------------\n",
      "Society.csv is Positively Spurious.\n",
      "Positive Acc: 0.8906280656734468 \n",
      "Negative Acc: 0.10483560101393333\n",
      "------------------------------------------------------------------------\n",
      "Money.csv is Positively Spurious.\n",
      "Positive Acc: 0.8926777280788808 \n",
      "Negative Acc: 0.10101375162457875\n",
      "------------------------------------------------------------------------\n",
      "Woman.csv is Positively Spurious.\n",
      "Positive Acc: 0.8721448780633244 \n",
      "Negative Acc: 0.12670041077129793\n",
      "------------------------------------------------------------------------\n",
      "Activist.csv is Positively Spurious.\n",
      "Positive Acc: 0.8947050563247385 \n",
      "Negative Acc: 0.0993006897790272\n",
      "------------------------------------------------------------------------\n",
      "Retarded.csv is Positively Spurious.\n",
      "Positive Acc: 0.8759322728953599 \n",
      "Negative Acc: 0.11481722392734105\n",
      "------------------------------------------------------------------------\n",
      "Chubby.csv is Positively Spurious.\n",
      "Positive Acc: 0.8936446598705692 \n",
      "Negative Acc: 0.10822027532761874\n",
      "------------------------------------------------------------------------\n",
      "Jew.csv is Positively Spurious.\n",
      "Positive Acc: 0.8934115131592416 \n",
      "Negative Acc: 0.09968784747545316\n",
      "------------------------------------------------------------------------\n",
      "Homosexual.csv is Positively Spurious.\n",
      "Positive Acc: 0.8933674115205605 \n",
      "Negative Acc: 0.09875050923098358\n",
      "------------------------------------------------------------------------\n",
      "Misgendering.csv is Positively Spurious.\n",
      "Positive Acc: 0.8735713694442723 \n",
      "Negative Acc: 0.12198151446109531\n",
      "------------------------------------------------------------------------\n",
      "Marriage.csv is Positively Spurious.\n",
      "Positive Acc: 0.8879713155658905 \n",
      "Negative Acc: 0.10705200877854831\n",
      "------------------------------------------------------------------------\n",
      "Industry.csv is Positively Spurious.\n",
      "Positive Acc: 0.8931227698987068 \n",
      "Negative Acc: 0.10007195000125314\n",
      "------------------------------------------------------------------------\n",
      "Oriental.csv is Positively Spurious.\n",
      "Positive Acc: 0.7615298514048042 \n",
      "Negative Acc: 0.1636475499611734\n",
      "------------------------------------------------------------------------\n",
      "occupations1950_professional.csv is Positively Spurious.\n",
      "Positive Acc: 0.7918435358645288 \n",
      "Negative Acc: 0.15276586235926184\n",
      "------------------------------------------------------------------------\n",
      "Gender.csv is Positively Spurious.\n",
      "Positive Acc: 0.8836184174461675 \n",
      "Negative Acc: 0.10707245758926763\n",
      "------------------------------------------------------------------------\n",
      "Media.csv is Positively Spurious.\n",
      "Positive Acc: 0.7152734494115458 \n",
      "Negative Acc: 0.23869538053298792\n",
      "------------------------------------------------------------------------\n",
      "Islam.csv is Positively Spurious.\n",
      "Positive Acc: 0.8949495797535918 \n",
      "Negative Acc: 0.10100590286902798\n",
      "------------------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "for filename in filenames:\n",
    "    df_bias = pd.read_csv('/home/m_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": []
  },
  {
   "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
}
