{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "executionInfo": {
     "elapsed": 5,
     "status": "ok",
     "timestamp": 1695324378707,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "F7toc08bpdQ1",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "from transformers import RobertaModel, RobertaConfig, RobertaTokenizer\n",
    "\n",
    "from transformers import *\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "from torch.utils.data import Dataset, DataLoader\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.metrics import f1_score\n",
    "import textwrap\n",
    "import math\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from IPython.display import clear_output\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "clear_output()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "executionInfo": {
     "elapsed": 15,
     "status": "ok",
     "timestamp": 1695323483676,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "MLk4JWizs4S9",
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_train = pd.read_csv('/home/mostafa_nsu/ICLR/Datasets/GoEmotion/train.csv')\n",
    "df_val = pd.read_csv('/home/mostafa_nsu/ICLR/Datasets/GoEmotion/val.csv')\n",
    "df_test = pd.read_csv('/home/mostafa_nsu/ICLR/Datasets/GoEmotion/test.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "id": "YWiFI0a9QqEa",
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_senti = pd.read_excel('/home/mostafa_nsu/ICLR/Datasets/GoEmotion/sentiwords.xlsx')\n",
    "conditions = [\n",
    "    (df_senti['PosScore'] > df_senti['NegScore']),\n",
    "    (df_senti['PosScore'] < df_senti['NegScore']),\n",
    "    (df_senti['PosScore'] == df_senti['NegScore'])\n",
    "    ]\n",
    "\n",
    "values = ['Positive','Negative','Neutral']\n",
    "\n",
    "df_senti = df_senti[['PosScore','NegScore','Word','Definition']]\n",
    "df_senti['Sentiment'] = np.select(conditions, values)\n",
    "df_senti = df_senti.dropna(axis=0)\n",
    "df_senti.drop(columns=['PosScore', 'NegScore'], inplace=True)\n",
    "df_senti = df_senti[['Word', 'Sentiment', 'Definition']]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "executionInfo": {
     "elapsed": 48,
     "status": "ok",
     "timestamp": 1695323754433,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "vX1DfZpN1W01",
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_train.dropna(inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "executionInfo": {
     "elapsed": 48,
     "status": "ok",
     "timestamp": 1695323754435,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "q_pTZIR8ltaJ",
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_train.rename(columns={'Text': 'review'}, inplace=True)\n",
    "df_val.rename(columns={'Text': 'review'}, inplace=True)\n",
    "df_test.rename(columns={'Text': 'review'}, inplace=True)\n",
    "\n",
    "\n",
    "df_train.rename(columns={'Mapped Sentiment': 'sentiment'}, inplace=True)\n",
    "df_val.rename(columns={'Mapped Sentiment': 'sentiment'}, inplace=True)\n",
    "df_test.rename(columns={'Mapped Sentiment': 'sentiment'}, inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 206
    },
    "executionInfo": {
     "elapsed": 49,
     "status": "ok",
     "timestamp": 1695323754437,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "e0NG9J-oq_wW",
    "outputId": "f1bb3869-364e-4c7a-8c3f-a62ce4b182c7",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>review</th>\n",
       "      <th>Emotions</th>\n",
       "      <th>sentiment</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>my favorite food is anything i did not have to...</td>\n",
       "      <td>neutral</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>now if he does off himself everyone will think...</td>\n",
       "      <td>neutral</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>why the fuck is bayless isoing</td>\n",
       "      <td>anger</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>to make her feel threatened</td>\n",
       "      <td>fear</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>dirty southern wankers</td>\n",
       "      <td>annoyance</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                              review   Emotions  sentiment\n",
       "0  my favorite food is anything i did not have to...    neutral          3\n",
       "1  now if he does off himself everyone will think...    neutral          3\n",
       "2                     why the fuck is bayless isoing      anger          1\n",
       "3                        to make her feel threatened       fear          1\n",
       "4                             dirty southern wankers  annoyance          1"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_train.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "executionInfo": {
     "elapsed": 45,
     "status": "ok",
     "timestamp": 1695323754437,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "RN48HyYaC2VD",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def filter_rows_by_values(df, col, values):\n",
    "    return df[~df[col].isin(values)]\n",
    "\n",
    "df_train = filter_rows_by_values(df_train,'sentiment',[2,3])\n",
    "df_test = filter_rows_by_values(df_test,'sentiment',[2,3])\n",
    "df_val = filter_rows_by_values(df_val,'sentiment',[2,3])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 45,
     "status": "ok",
     "timestamp": 1695323754438,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "Qm9XHUHuuSXq",
    "outputId": "6e7765c0-f186-4b8c-db5a-d954fbb3dc9a",
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_train['emotion'], map = pd.factorize(df_train['Emotions'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "executionInfo": {
     "elapsed": 33,
     "status": "ok",
     "timestamp": 1695323754438,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "TCTYc5frxZfx",
    "tags": []
   },
   "outputs": [],
   "source": [
    "emotion_map = dict(zip(map, range(len(map))))\n",
    "map_emotion = {v: k for k, v in emotion_map.items()}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 35
    },
    "executionInfo": {
     "elapsed": 33,
     "status": "ok",
     "timestamp": 1695323754439,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "_xxZFLJwxfpy",
    "outputId": "914e4d70-43c6-462e-dc72-954759c555eb",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'gratitude'"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "emotion_map['gratitude']  # Get Encoded Label from Categorical Label\n",
    "map_emotion[3]  # Get Categorical Label from Encoded Label"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 33,
     "status": "ok",
     "timestamp": 1695323754440,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "k-a5Ww9MhpdO",
    "outputId": "ecf8deb0-f932-4d16-a103-9acc16f252ec",
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_val['emotion'] = df_val[\"Emotions\"].apply(lambda x: emotion_map[x])\n",
    "df_test['emotion'] = df_test[\"Emotions\"].apply(lambda x: emotion_map[x])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "executionInfo": {
     "elapsed": 18,
     "status": "ok",
     "timestamp": 1695323756839,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "UmEtmaFNrakz",
    "tags": []
   },
   "outputs": [],
   "source": [
    "MAX_LEN = 200\n",
    "RANDOM_SEED = 42\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "device = torch.device(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 18,
     "status": "ok",
     "timestamp": 1695323756840,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "6oWORty0p8Xo",
    "outputId": "cb12350b-753a-4c61-c7e8-3c9427f000e9",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda:1\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": 14,
   "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": 15,
   "metadata": {
    "executionInfo": {
     "elapsed": 35,
     "status": "ok",
     "timestamp": 1695323767305,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "R2PbApHJGstz",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def get_cls(sent):\n",
    "  encoded_review = tokenizer.encode_plus(\n",
    "  sent,\n",
    "  max_length=MAX_LEN,\n",
    "  add_special_tokens=True,\n",
    "  return_token_type_ids=False,\n",
    "  truncation = True,\n",
    "  padding='max_length',\n",
    "  return_attention_mask=True,\n",
    "  return_tensors='pt',\n",
    "  )\n",
    "  input_ids = encoded_review['input_ids'].to(device)\n",
    "  attention_mask = encoded_review['attention_mask'].to(device)\n",
    "\n",
    "  with torch.no_grad():\n",
    "    output = pre_trained_model(input_ids, attention_mask)\n",
    "    last_hidden_state = output[0]\n",
    "    mean_last_hidden_state = torch.mean(last_hidden_state, 1)\n",
    "    \n",
    "    return mean_last_hidden_state"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {
    "executionInfo": {
     "elapsed": 33,
     "status": "ok",
     "timestamp": 1695323767305,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "dN4TFCeRzGXw",
    "tags": []
   },
   "outputs": [],
   "source": [
    "positive_words = ['amusement','excitement','joy','love','desire','optimism','caring','pride','admiration','gratitude','relief','approval']\n",
    "negative_words = ['fear','nervousness','remorse','embarrassment','disappointment','sadness','grief','disgust','anger','annoyance','disapproval']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {
    "executionInfo": {
     "elapsed": 33,
     "status": "ok",
     "timestamp": 1695323767306,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "I20K8jlAz2pE",
    "tags": []
   },
   "outputs": [],
   "source": [
    "pos_word_map = [emotion_map[i] for i in positive_words]\n",
    "neg_word_map = [emotion_map[i] for i in negative_words]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "ok",
     "timestamp": 1695323767306,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "GbnDb91dWp_w",
    "tags": []
   },
   "outputs": [],
   "source": [
    "pos_word_map = dict(zip(range(len(pos_word_map)),pos_word_map))\n",
    "neg_word_map = dict(zip(range(len(neg_word_map)),neg_word_map))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {
    "id": "5hjM7ggAiHnM",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "\"\\nambiguous_word_meaning_sentences = ['the process of becoming aware of something',#realization\\n                                'an event, a piece of news, etc. that is unexpected or that happens suddenly',#surprise\\n                                ' a strong desire to know about something',#curiosity\\n                                'a state of not being certain about what is happening, what you should do, what something means, etc.',#confusion\\n]\\n\\nneutral_word_meaning_sentences = ['not supporting or helping either side in a disagreement, competition, etc.']\\n\""
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "positive_word_meaning_sentences = ['the feeling that you have when you enjoy something that is funny',#amusement\n",
    "                                   'the state of feeling or showing happiness and enthusiasm',#excitement\n",
    "                                   'a feeling of great happiness',#joy\n",
    "                                   'a very strong feeling of liking and caring for somebody/something, especially a member of your family or a friend',#love\n",
    "                                   'a strong wish to have or do something',#desire\n",
    "                                   'a feeling that good things will happen and that something will be successful',#optimism\n",
    "                                   'kind, helpful and showing that you care about other people',#caring\n",
    "                                   'a feeling of being pleased or satisfied that you get when you or people who are connected with you have done something well or own something that other people admire',#pride\n",
    "                                   'a feeling of respect for and approval of somebody/something',#admiration\n",
    "                                   'the feeling of being grateful and wanting to express your thanks',#gratitude\n",
    "                                   'the feeling of happiness that you have when something unpleasant stops or does not happen',#relief\n",
    "                                   'the feeling that somebody/something is good or acceptable; a positive opinion of somebody/something',#approval\n",
    "]\n",
    "\n",
    "negative_word_meaning_sentences = ['the bad feeling that you have when you are in danger or when a particular thing frightens you',#fear\n",
    "                                   'the feeling of being anxious about something or afraid of something',#nervousness\n",
    "                                   'the feeling of being extremely sorry for something wrong or bad that you have done',#remorse\n",
    "                                   'shy, uncomfortable or guilty feelings; a feeling of being embarrassed',#embarrassment\n",
    "                                   'the feeling of being sad because something has not happened or been as good, successful, etc. as you expected or hoped',#disappointment\n",
    "                                   'the feeling of being sad',#sadness\n",
    "                                   'a very sad feeling, especially when somebody dies',#grief\n",
    "                                   'a strong feeling of dislike for somebody/something that you feel is unacceptable, or for something that looks, smells, etc. unpleasant',#disgust\n",
    "                                   'the strong feeling that you have when something has happened that you think is bad and unfair',#anger\n",
    "                                   'the feeling of being slightly angry',#annoyance\n",
    "                                   'a feeling that you do not like an idea, an action or somebody’s behaviour because you think it is bad, not suitable or going to have a bad effect on somebody else',#disapproval\n",
    "]\n",
    "\n",
    "\n",
    "'''\n",
    "ambiguous_word_meaning_sentences = ['the process of becoming aware of something',#realization\n",
    "                                'an event, a piece of news, etc. that is unexpected or that happens suddenly',#surprise\n",
    "                                ' a strong desire to know about something',#curiosity\n",
    "                                'a state of not being certain about what is happening, what you should do, what something means, etc.',#confusion\n",
    "]\n",
    "\n",
    "neutral_word_meaning_sentences = ['not supporting or helping either side in a disagreement, competition, etc.']\n",
    "'''"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 30,
     "status": "ok",
     "timestamp": 1695323767308,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "Y_8HhXvskRFY",
    "outputId": "a8dbea0e-bd42-4116-8e55-4b9c17f6f627",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "12\n",
      "11\n"
     ]
    }
   ],
   "source": [
    "print(len(positive_word_meaning_sentences))\n",
    "print(len(negative_word_meaning_sentences))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {
    "executionInfo": {
     "elapsed": 3468,
     "status": "ok",
     "timestamp": 1695323770756,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "LNSmtyIyoOUv",
    "tags": []
   },
   "outputs": [],
   "source": [
    "p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "\n",
    "for i in positive_word_meaning_sentences:\n",
    "  p_emb = torch.cat((p_emb,get_cls(i)), dim=0)\n",
    "\n",
    "for i in negative_word_meaning_sentences:\n",
    "  n_emb = torch.cat((n_emb,get_cls(i)), dim=0)\n",
    "\n",
    "\n",
    "\n",
    "p_emb = p_emb[1:]\n",
    "n_emb = n_emb[1:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 27,
     "status": "ok",
     "timestamp": 1695323770759,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "V_qXeXCGgjtq",
    "outputId": "b32eec10-206d-4ac3-ed65-f7bef84586d2",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([12, 1024])\n",
      "torch.Size([11, 1024])\n"
     ]
    }
   ],
   "source": [
    "print(p_emb.shape)\n",
    "print(n_emb.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {
    "executionInfo": {
     "elapsed": 24,
     "status": "ok",
     "timestamp": 1695323770760,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "awfjtxT93yF_",
    "tags": []
   },
   "outputs": [],
   "source": [
    "#df_train = df_train[:100]\n",
    "#df_test = df_test[:100]\n",
    "#df_val = df_val[:100]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {
    "executionInfo": {
     "elapsed": 24,
     "status": "ok",
     "timestamp": 1695323770760,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "OtZt1p7ys7XD",
    "tags": []
   },
   "outputs": [],
   "source": [
    "class IMDBDataset(Dataset):\n",
    "\n",
    "  def __init__(self, reviews, sentiments, emotions, tokenizer, max_len):\n",
    "    self.reviews = reviews\n",
    "    self.sentiments = sentiments\n",
    "    self.emotions = emotions\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",
    "    emotion = self.emotions[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",
    "      'emotions': torch.tensor(emotion, dtype=torch.long),\n",
    "\n",
    "    }"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {
    "executionInfo": {
     "elapsed": 6,
     "status": "ok",
     "timestamp": 1695325189268,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "UuOujQajtL5f",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def create_data_loader(df, tokenizer, max_len, batch_size):\n",
    "  ds = IMDBDataset(\n",
    "    reviews=df.review.to_numpy(),\n",
    "    sentiments=df['sentiment'].to_numpy(),\n",
    "    emotions=df['emotion'].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": 26,
   "metadata": {
    "executionInfo": {
     "elapsed": 24,
     "status": "ok",
     "timestamp": 1695323770761,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "3zzA4eBytOqj",
    "tags": []
   },
   "outputs": [],
   "source": [
    "BATCH_SIZE = 32\n",
    "\n",
    "train_data_loader = create_data_loader(df_train, tokenizer, MAX_LEN, BATCH_SIZE)\n",
    "val_data_loader = create_data_loader(df_val, tokenizer, MAX_LEN, BATCH_SIZE)\n",
    "test_data_loader = create_data_loader(df_test, tokenizer, MAX_LEN, BATCH_SIZE)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 6,
     "status": "ok",
     "timestamp": 1695325187523,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "AoUfRPy0tQgk",
    "outputId": "4cc31257-8fe1-4cce-883e-8aff4ebf2185",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['review', 'input_ids', 'attention_mask', 'sentiments', 'emotions'])"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data = next(iter(train_data_loader))\n",
    "data.keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {
    "executionInfo": {
     "elapsed": 3,
     "status": "ok",
     "timestamp": 1695325688712,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "Y3Nil-yatUqF",
    "tags": []
   },
   "outputs": [],
   "source": [
    "class Classifier(nn.Module):\n",
    "  def __init__(self):\n",
    "    super(Classifier, self).__init__()\n",
    "    self.bert = 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": 29,
   "metadata": {
    "id": "HWZ37gsztWzL",
    "tags": []
   },
   "outputs": [],
   "source": [
    "model = Classifier()\n",
    "model = model.to(device)\n",
    "clear_output()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {
    "executionInfo": {
     "elapsed": 22,
     "status": "ok",
     "timestamp": 1695325221207,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "HWy57v2CxxCM",
    "tags": []
   },
   "outputs": [],
   "source": [
    "for name, param in model.named_parameters():\n",
    "    if name.startswith('bert'):\n",
    "        param.requires_grad = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {
    "executionInfo": {
     "elapsed": 20,
     "status": "ok",
     "timestamp": 1695325221207,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "e5iLu13CYlux",
    "tags": []
   },
   "outputs": [],
   "source": [
    "#for name, param in model.named_parameters():\n",
    "#    print(name, param.requires_grad)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 21,
     "status": "ok",
     "timestamp": 1695325221208,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "nZpqz6yDtYZ4",
    "outputId": "c0ba4f97-cad5-46b8-e1ff-e818ff5b4035",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([32, 200])\n",
      "torch.Size([32, 200])\n"
     ]
    }
   ],
   "source": [
    "input_ids = data['input_ids'].to(device)\n",
    "attention_mask = data['attention_mask'].to(device)\n",
    "sentiments = data['sentiments'].to(device)\n",
    "\n",
    "print(input_ids.shape) # batch size x seq length\n",
    "print(attention_mask.shape) # batch size x seq length"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {
    "executionInfo": {
     "elapsed": 12,
     "status": "ok",
     "timestamp": 1695325221208,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "NwvA-zp7vqc1",
    "tags": []
   },
   "outputs": [],
   "source": [
    "#del test\n",
    "torch.cuda.empty_cache()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {
    "executionInfo": {
     "elapsed": 603,
     "status": "ok",
     "timestamp": 1695325221800,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "-9Z37OXOtb0q",
    "tags": []
   },
   "outputs": [],
   "source": [
    "(positive,negative),outs = model(input_ids, attention_mask,return_scores=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 15,
     "status": "ok",
     "timestamp": 1695325221800,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "NHFM3QUhg3n0",
    "outputId": "602bd955-db78-44a6-931e-e5e901bb1856",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0.9928, 0.9938],\n",
       "        [0.9944, 0.9939],\n",
       "        [0.9928, 0.9934],\n",
       "        [0.9931, 0.9932],\n",
       "        [0.9885, 0.9895],\n",
       "        [0.9881, 0.9890],\n",
       "        [0.9907, 0.9924],\n",
       "        [0.9885, 0.9883],\n",
       "        [0.9857, 0.9870],\n",
       "        [0.9918, 0.9923],\n",
       "        [0.9922, 0.9930],\n",
       "        [0.9830, 0.9833],\n",
       "        [0.9783, 0.9797],\n",
       "        [0.9925, 0.9926],\n",
       "        [0.9915, 0.9925],\n",
       "        [0.9932, 0.9939],\n",
       "        [0.9920, 0.9923],\n",
       "        [0.9894, 0.9919],\n",
       "        [0.9941, 0.9943],\n",
       "        [0.9955, 0.9961],\n",
       "        [0.9867, 0.9867],\n",
       "        [0.9934, 0.9937],\n",
       "        [0.9914, 0.9918],\n",
       "        [0.9929, 0.9928],\n",
       "        [0.9892, 0.9903],\n",
       "        [0.9917, 0.9926],\n",
       "        [0.9954, 0.9957],\n",
       "        [0.9873, 0.9884],\n",
       "        [0.9818, 0.9824],\n",
       "        [0.9880, 0.9891],\n",
       "        [0.9908, 0.9912],\n",
       "        [0.9949, 0.9929]], device='cuda:1', grad_fn=<TBackward0>)"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "outs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 1022,
     "status": "ok",
     "timestamp": 1695325845248,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "cjMVWA5a_6lf",
    "outputId": "bae8764e-0ce8-4118-e676-267b2c3ac06b",
    "tags": []
   },
   "outputs": [],
   "source": [
    "EPOCHS = 8\n",
    "\n",
    "optimizer = AdamW(model.parameters(), lr=0.001)\n",
    "total_steps = len(train_data_loader) * EPOCHS\n",
    "\n",
    "scheduler = get_linear_schedule_with_warmup(\n",
    "  optimizer,\n",
    "  num_warmup_steps=math.floor((1./5)*total_steps),\n",
    "  num_training_steps=total_steps\n",
    ")\n",
    "\n",
    "loss_fn = nn.CrossEntropyLoss().to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {
    "executionInfo": {
     "elapsed": 8,
     "status": "ok",
     "timestamp": 1695325845969,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "cLFDb4pzbx9W",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def train_epoch(\n",
    "  model,\n",
    "  data_loader,\n",
    "  loss_fn,\n",
    "  optimizer,\n",
    "  device,\n",
    "  scheduler,\n",
    "  n_examples\n",
    "):\n",
    "  model = model.train()\n",
    "\n",
    "  losses = []\n",
    "  correct_predictions = 0\n",
    "\n",
    "  for d in data_loader:\n",
    "    input_ids = d[\"input_ids\"].to(device)\n",
    "    attention_mask = d[\"attention_mask\"].to(device)\n",
    "    sentiments = d[\"sentiments\"].to(device)\n",
    "\n",
    "    outputs = model(\n",
    "      input_ids=input_ids,\n",
    "      attention_mask=attention_mask\n",
    "    ).to(device)\n",
    "\n",
    "    _, preds = torch.max(outputs, dim=1)\n",
    "    loss = loss_fn(outputs, sentiments)\n",
    "\n",
    "    correct_predictions += torch.sum(preds == sentiments)\n",
    "    losses.append(loss.item())\n",
    "\n",
    "\n",
    "    loss.backward()\n",
    "    nn.utils.clip_grad_norm_(model.parameters(), max_norm=1.0)\n",
    "    optimizer.step()\n",
    "    scheduler.step()\n",
    "    optimizer.zero_grad()\n",
    "\n",
    "  return correct_predictions.double() / n_examples, np.mean(losses)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {
    "executionInfo": {
     "elapsed": 9,
     "status": "ok",
     "timestamp": 1695325845971,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "z4GAdIawtUue",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def eval_model(model, data_loader, loss_fn, device, n_examples, on_new=False):\n",
    "  model = model.eval()\n",
    "\n",
    "  losses = []\n",
    "  f1s = []\n",
    "\n",
    "  correct_predictions = 0\n",
    "\n",
    "  with torch.no_grad():\n",
    "    for d in data_loader:\n",
    "      input_ids = d[\"input_ids\"].to(device)\n",
    "      attention_mask = d[\"attention_mask\"].to(device)\n",
    "      sentiments = d[\"sentiments\"].to(device)\n",
    "\n",
    "      outputs = model(\n",
    "        input_ids=input_ids,\n",
    "        attention_mask=attention_mask,\n",
    "      ).to(device)\n",
    "      _, preds = torch.max(outputs, dim=1)\n",
    "\n",
    "      loss = loss_fn(outputs, sentiments)\n",
    "\n",
    "      correct_predictions += torch.sum(preds == sentiments)\n",
    "      losses.append(loss.item())\n",
    "\n",
    "      f1s.append(f1_score(sentiments.cpu(), preds.cpu(), average='macro'))\n",
    "\n",
    "  return correct_predictions.double() / n_examples, np.mean(losses), np.mean(f1s)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {
    "executionInfo": {
     "elapsed": 8,
     "status": "ok",
     "timestamp": 1695325846655,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "9tWEJ4saOU6Q",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def batch_calc_score_sum(positive, negative, sentiments):\n",
    "  p_filter = sentiments ^ torch.ones(sentiments.size()[0], dtype=torch.int8).to(device) # Positive ( sentiment xor [1,1,...])\n",
    "  n_filter = sentiments # Negative\n",
    "\n",
    "  pos_score_pos_sent = positive[p_filter.nonzero(), :]\n",
    "  pos_score_neg_sent = positive[n_filter.nonzero(), :]\n",
    "\n",
    "  neg_score_pos_sent = negative[p_filter.nonzero(), :]\n",
    "  neg_score_neg_sent = negative[n_filter.nonzero(), :]\n",
    "\n",
    "  pp_count = pos_score_pos_sent.size()[0]\n",
    "  pn_count = pos_score_neg_sent.size()[0]\n",
    "  pp_sum = torch.sum(pos_score_pos_sent,dim=0)\n",
    "  pn_sum = torch.sum(pos_score_neg_sent,dim=0)\n",
    "\n",
    "\n",
    "#  np_count = neg_score_pos_sent.size()[0] # same as pn_count\n",
    "#  nn_count = neg_score_neg_sent.size()[0] # same as pn_count\n",
    "  np_sum = torch.sum(neg_score_pos_sent,dim=0)\n",
    "  nn_sum = torch.sum(neg_score_neg_sent,dim=0)\n",
    "\n",
    "  return pp_sum,pn_sum,np_sum,nn_sum, pp_count, pn_count\n",
    "\n",
    "def eval_scores_average(model, data_loader, device):\n",
    "  model = model.eval()\n",
    "\n",
    "\n",
    "  pp_sum_agg = torch.zeros(1,p_emb.size()[0]).to(device)\n",
    "  pn_sum_agg = torch.zeros(1,p_emb.size()[0]).to(device)\n",
    "\n",
    "  np_sum_agg = torch.zeros(1,n_emb.size()[0]).to(device)\n",
    "  nn_sum_agg = torch.zeros(1,n_emb.size()[0]).to(device)\n",
    "\n",
    "  pp_count_agg, pn_count_agg = 0,0\n",
    "\n",
    "  with torch.no_grad():\n",
    "    for d in data_loader:\n",
    "      input_ids = d[\"input_ids\"].to(device)\n",
    "      attention_mask = d[\"attention_mask\"].to(device)\n",
    "      sentiments = d[\"sentiments\"].to(device)\n",
    "\n",
    "      (positive,negative),_= model(\n",
    "        input_ids=input_ids,\n",
    "        attention_mask=attention_mask,\n",
    "        return_scores=True\n",
    "      )\n",
    "      positive.to(device)\n",
    "      negative.to(device)\n",
    "\n",
    "\n",
    "      pp_sum,pn_sum,np_sum,nn_sum, pp_count, pn_count = batch_calc_score_sum(positive,negative,sentiments)\n",
    "\n",
    "      pp_sum_agg += pp_sum\n",
    "      pn_sum_agg += pn_sum\n",
    "\n",
    "      np_sum_agg += np_sum\n",
    "      nn_sum_agg += nn_sum\n",
    "\n",
    "      pp_count_agg += pp_count\n",
    "      pn_count_agg += pn_count\n",
    "\n",
    "\n",
    "\n",
    "  return pp_sum_agg/pp_count_agg, pn_sum_agg/pn_count_agg, np_sum_agg/pp_count_agg, nn_sum_agg/pn_count_agg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {
    "executionInfo": {
     "elapsed": 8,
     "status": "ok",
     "timestamp": 1695325846656,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "IxncgTh4awi7",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def box_plot(pp,pn,np,nn):\n",
    "  pp = pp.tolist()[0]\n",
    "  pn = pn.tolist()[0]\n",
    "  np = np.tolist()[0]\n",
    "  nn = nn.tolist()[0]\n",
    "  # Create a box plot with beeswarm using seaborn\n",
    "  sns.set(style=\"whitegrid\")  # Set the style of the plot\n",
    "  plt.figure(figsize=(8, 6))  # Set the figure size\n",
    "  ax = sns.boxplot(data=[pp,pn,np,nn], orient=\"v\", palette=\"tab10\", width=0.5)  # 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": 41,
   "metadata": {
    "executionInfo": {
     "elapsed": 7,
     "status": "ok",
     "timestamp": 1695325846656,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "bSVNs5ZMpIsj",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def max_emotion(a,b):\n",
    "  emotion_list = []\n",
    "\n",
    "  max_a_values = torch.stack((torch.max(a,1).values, torch.max(b,1).values))\n",
    "  max_a_indices = torch.stack((torch.max(a,1).indices, torch.max(b,1).indices))\n",
    "  agg_max = torch.max(max_a_values,0)\n",
    "  emotions_indices = [i[1][agg_max.indices[i[0]]] for i in enumerate(max_a_indices.t())]\n",
    "\n",
    "  emotions_indices = torch.stack(emotions_indices)\n",
    "  for i in range(len(emotions_indices)):\n",
    "    if(agg_max.indices[i] == 0):\n",
    "      emotion_list.append(pos_word_map[emotions_indices[i].item()])\n",
    "    else:\n",
    "      emotion_list.append(neg_word_map[emotions_indices[i].item()])\n",
    "  return torch.tensor(emotion_list)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {
    "executionInfo": {
     "elapsed": 3,
     "status": "ok",
     "timestamp": 1695325847286,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "E3rc-qAmeZiM",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def eval_emotions(model, data_loader, loss_fn, device, n_examples):\n",
    "  model = model.eval()\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",
    "      emotions = d[\"emotions\"].to(device)\n",
    "\n",
    "      (a,b), _ = model(\n",
    "        input_ids=input_ids,\n",
    "        attention_mask=attention_mask,\n",
    "        return_scores = True\n",
    "      )\n",
    "\n",
    "      preds = max_emotion(a,b).to(device)\n",
    "      correct_predictions += torch.sum(preds == emotions)\n",
    "\n",
    "  return correct_predictions.double() / n_examples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000
    },
    "executionInfo": {
     "elapsed": 3203929,
     "status": "ok",
     "timestamp": 1695329051836,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "IqdIHJsrANr0",
    "outputId": "ee79ec9a-a033-47e0-bc8b-a7b71698465c",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/8\n",
      "----------\n",
      "Train loss 0.5659949503970567 accuracy 0.7414692894419912\n",
      "Val   loss 0.5260013749327841 accuracy 0.7953193177310591\n",
      "\n",
      "Epoch 2/8\n",
      "----------\n",
      "Train loss 0.5036445422693011 accuracy 0.804245283018868\n",
      "Val   loss 0.49068567760383025 accuracy 0.8318127727092424\n",
      "\n",
      "Epoch 3/8\n",
      "----------\n",
      "Train loss 0.48915400426613576 accuracy 0.8181955038137294\n",
      "Val   loss 0.48119664946688884 accuracy 0.8250694168980564\n",
      "\n",
      "Epoch 4/8\n",
      "----------\n",
      "Val   loss 0.4826617497432081 accuracy 0.8238794129313765\n",
      "\n",
      "Epoch 5/8\n",
      "----------\n",
      "Train loss 0.47926817784148656 accuracy 0.8274287434765155\n",
      "Val   loss 0.4743523341190966 accuracy 0.8306227687425625\n",
      "\n",
      "Epoch 6/8\n",
      "----------\n",
      "Train loss 0.4772705547690966 accuracy 0.8263247691690084\n",
      "Val   loss 0.4753692138798629 accuracy 0.8333994446648155\n",
      "\n",
      "Epoch 7/8\n",
      "----------\n",
      "Train loss 0.47282751528830247 accuracy 0.8331995182657568\n",
      "Val   loss 0.47187508586086807 accuracy 0.8385561285204284\n",
      "\n",
      "Epoch 8/8\n",
      "----------\n",
      "Train loss 0.47295388675042177 accuracy 0.8321457246085909\n",
      "Val   loss 0.4697058249877978 accuracy 0.8409361364537882\n",
      "\n",
      "CPU times: user 1h 19min 27s, sys: 12.1 s, total: 1h 19min 39s\n",
      "Wall time: 1h 19min 44s\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "train_a = []\n",
    "train_l = []\n",
    "val_a = []\n",
    "val_l = []\n",
    "best_accuracy = 0\n",
    "\n",
    "for epoch in range(EPOCHS):\n",
    "\n",
    "  print(f'Epoch {epoch + 1}/{EPOCHS}')\n",
    "  print('-' * 10)\n",
    "\n",
    "  train_acc, train_loss = train_epoch(\n",
    "    model,\n",
    "    train_data_loader,\n",
    "    loss_fn,\n",
    "    optimizer,\n",
    "    device,\n",
    "    scheduler,\n",
    "    len(df_train)\n",
    "  )\n",
    "\n",
    "  print(f'Train loss {train_loss} accuracy {train_acc}')\n",
    "\n",
    "  val_acc, val_loss, val_f1 = eval_model(\n",
    "    model,\n",
    "    val_data_loader,\n",
    "    loss_fn,\n",
    "    device,\n",
    "    len(df_val)\n",
    "  )\n",
    "\n",
    "  print(f'Val   loss {val_loss} accuracy {val_acc}')\n",
    "  print()\n",
    "\n",
    "  train_a.append(train_acc)\n",
    "  train_l.append(train_loss)\n",
    "  val_a.append(val_acc)\n",
    "  val_l.append(val_loss)\n",
    "\n",
    "  if val_acc > best_accuracy:\n",
    "    torch.save(model.state_dict(), 'roberta_best_model_state.bin')\n",
    "    best_accuracy = val_acc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {
    "executionInfo": {
     "elapsed": 51,
     "status": "ok",
     "timestamp": 1695329137842,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "FowMSU5U7SDQ",
    "tags": []
   },
   "outputs": [],
   "source": [
    "train_a = [i.item() for i in train_a]\n",
    "train_l = [i.item() for i in train_l]\n",
    "val_a = [i.item() for i in val_a]\n",
    "val_l = [i.item() for i in val_l]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 480
    },
    "executionInfo": {
     "elapsed": 2888,
     "status": "ok",
     "timestamp": 1695329143450,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "aUQbxyTEAPhM",
    "outputId": "b103ca88-1886-4f16-ea21-5b966a08fe7c",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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a/z4V199tZYuXSrJfeHvX//6Vz399NNyuVyaN2/eBbeNiIhQRkZGmfJDhw5Jkho2bOhVXt5/H0kaPny42rdvr4ULF6qoqEg7duzQ7Nmzq3A2gPXQcwOgDMMwPL0lJbZu3apvv/3WRy3y1qVLFzVo0EArVqzwKt+7d6+2bt16WdtyzTXXaObMmerQoYPX53O+HqAbb7xRKSkpnjurSixbtkw2m0033HBDhY5rGIYeeughrVq1Sk899ZSaN2+u0aNHX9K5AFZBuAFQxq233qoPPvhAc+bM0YYNG7Rw4ULdcsstat26ta+bJkny9/fXU089pY0bN+rOO+/URx99pOXLl2vYsGFq2rSpbLaa+7+2r7/+WoMGDdKrr76qdevWacOGDXr88ce1a9cuDRkyxFOva9eu2rp1q/72t79p69atnjDz2GOPqVGjRho2bJiSkpK0bt06PfDAA1q8eLGmTp2qVq1aVbgtcXFxCg4O1r/+9S/Fx8fX+gkRgcuFYSkAZcycOVMFBQVatGiRnnnmGXXp0kVLlizRsmXLlJKS4uvmSZImT54su92uuXPnauXKlbr66qs1a9YsvfXWW8rJyamx4zZv3lwtW7bUggULdPDgQdlsNrVt21bz58/XpEmTPPWeeeYZZWVl6Z577lFeXp46duyonTt3KioqSlu2bNGMGTP02GOPKTc3V23bttW8efM0efLkSrWlXr16GjFihFauXKn777+/uk8VqLMM0yw1axQA1GFHjx5V+/bt9etf/7rM9UJWdPr0abVs2VLDhw/XsmXLfN0coNag5wZAnZSWlqa5c+dq4MCBatCggfbt26eXXnpJ+fn5euihh3zdvBqVmZmp3bt36/XXX9fx48c1ffp0XzcJqFUINwDqpMDAQO3Zs0fvvPOOjh07ptDQUPXr109Lly5V+/btfd28GrVy5Ur97ne/U7NmzfTGG29U+qGegNUxLAUAACzFp3dLbdy4USNHjlTTpk1lGIZWr1590W2++OIL9erVS4GBgbr66qv12muvXYaWAgCAusKn4ebkyZPq3r27Fi5cWKH6+/bt04gRIzRgwAAlJyfrD3/4gyZPnqz333+/hlsKAADqilozLGUYhlatWnXBSah+//vfa82aNV7PtomPj9f27du1ZcuWy9FMAABQy9WpC4q3bNmioUOHepUNGzZMixcvVmFhofz9/ctsk5+fr/z8fM+yy+XSsWPHFBERcd5pzQEAQO1imqZyc3MrNFFnnQo3hw8fLvNQvMjISBUVFSkrK+u8DwCcNWvW5WoiAACoQQcOHFDz5s0vWKdOhRup7EPkSkbVztcLM2PGDE2bNs2znJ2drZYtW+rAgQMKCwuruYYCAIBqk5OToxYtWqhevXoXrVunwk2TJk3KPPE3MzNTfn5+nqcEn8vhcJR5AKAkhYWFEW4AAKhjKnJJSZ16cGZsbKzWr1/vVfbJJ58oJiam3OttAADAlcen4SYvL08pKSmeB/Ht27dPKSkpSktLk+QeUho/frynfnx8vH766SdNmzZNqampSkpK0uLFi/Xoo4/6pP0AAKD28emw1NatWzVo0CDPcsm1MRMmTNDSpUuVkZHhCTqS1KZNG61du1YPP/ywXn31VTVt2lTz58/XL37xi8vedgAAUDvVmnluLpecnByFh4crOzuba24A1ElOp1OFhYW+bgZQ7QICAs57m3dlvr/r1AXFAHAlM01Thw8f1okTJ3zdFKBG2Gw2tWnTRgEBAZe0H8INANQRJcGmcePGCg4OZiJSWIrL5dKhQ4eUkZGhli1bXtK/b8INANQBTqfTE2zON/UFUNc1atRIhw4dUlFR0SXdBV2nbgUHgCtVyTU2wcHBPm4JUHNKhqOcTucl7YdwAwB1CENRsLLq+vdNuAEAAJZCuAEA1CmtW7fWvHnzfN0M1GJcUAwAqFE33HCDrr322moLJN98841CQkKqZV+wJsINAMDnTNOU0+mUn9/Fv5YaNWp0GVp0eVXm/HFxDEsBAGpMXFycvvjiC73yyisyDEOGYWj//v36/PPPZRiG1q1bp5iYGDkcDm3atEl79+7VqFGjFBkZqdDQUPXu3Vv//Oc/vfZ57rCUYRj6y1/+ojFjxig4OFjt27fXmjVrLtiu5cuXKyYmRvXq1VOTJk101113KTMz06vOv//9b91yyy0KCwtTvXr1NGDAAO3du9ezPikpSZ07d5bD4VBUVJQefPBBSdL+/ftlGIbnuYmSdOLECRmGoc8//1ySLun88/PzNX36dLVo0UIOh0Pt27fX4sWLZZqm2rVrpxdffNGr/g8//CCbzebVdqsj3ABAHWWapk4VFPnkVdEn97zyyiuKjY3V/fffr4yMDGVkZKhFixae9dOnT1dCQoJSU1PVrVs35eXlacSIEfrnP/+p5ORkDRs2TCNHjvR6zmB5Zs2apbFjx+q7777TiBEj9Ktf/UrHjh07b/2CggI9/fTT2r59u1avXq19+/YpLi7Osz49PV3XX3+9AgMDtWHDBm3btk0TJ05UUVGRJCkxMVEPPPCAfvOb3+j777/XmjVr1K5duwp9JqVV5fzHjx+vv/71r5o/f75SU1P12muvKTQ0VIZhaOLEiVqyZInXMZKSkjRgwAC1bdu20u2rq+j/AoA66nShU9FPrvPJsXfMHqbggIt/hYSHhysgIEDBwcFq0qRJmfWzZ8/WkCFDPMsRERHq3r27Z3nOnDlatWqV1qxZ4+kZKU9cXJzuvPNOSdKzzz6rBQsW6Ouvv9bNN99cbv2JEyd6/r766qs1f/58XXfddcrLy1NoaKheffVVhYeH669//atnMrkOHTp4teuRRx7RlClTPGW9e/e+2MdRRmXPf/fu3Xr33Xe1fv163XTTTZ72l7jnnnv05JNP6uuvv9Z1112nwsJCLV++XH/6058q3ba6jJ4bAIDPxMTEeC2fPHlS06dPV3R0tK666iqFhoZq586dF+256datm+fvkJAQ1atXr8wwU2nJyckaNWqUWrVqpXr16umGG26QJM9xUlJSNGDAgHJnyc3MzNShQ4d04403VvQ0z6uy55+SkiK73a6BAweWu7+oqCjdcsstSkpKkiT94x//0JkzZ3T77bdfclvrEnpuAKCOCvK3a8fsYT47dnU4966nxx57TOvWrdOLL76odu3aKSgoSL/85S9VUFBwwf2cG0IMw5DL5Sq37smTJzV06FANHTpUy5cvV6NGjZSWlqZhw4Z5jhMUFHTeY11onSTPU61LD92d7ynulT3/ix1bku677z7dfffdevnll7VkyRKNGzfuipvZmnADAHWUYRgVGhrytYCAgApPp79p0ybFxcVpzJgxkqS8vDzt37+/Wtuzc+dOZWVl6bnnnvNc/7N161avOt26ddObb76pwsLCMsGpXr16at26tT799FMNGjSozP5L7ubKyMhQjx49JMnr4uILudj5d+3aVS6XS1988YVnWOpcI0aMUEhIiBITE/XRRx9p48aNFTq2lTAsBQCoUa1bt9ZXX32l/fv3Kysr67w9KpLUrl07rVy5UikpKdq+fbvuuuuuC9avipYtWyogIEALFizQjz/+qDVr1ujpp5/2qvPggw8qJydH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UFf5B7t7UHx17AoaOXKkXC6XPvzwQ/Xu3VubNm3S3LlzPesfe+wxrVu3Ti+++KLatWunoKAg/fKXv1RBQUGF9m+a5kXrvPvuu3r44Yf10ksvKTY2VvXq1dOf/vQnffXVVxU+j5JjGecMx5Ucv3T5uRfiGoZR5rqj0uLi4nTkyBHNmzdPrVq1ksPhUGxsrOczCAoKumC7LrbeZrOV+ZwKCwvL1AsJ8e6Nu9jndrHjStL48eP1+OOPa8uWLdqyZYtat26tAQMGXHS7S0G4AYC6yjAqNDTka0FBQfr5z3+ut99+W//5z3/UoUMH9erVy7N+06ZNiouL05gxYyS5r8HZv39/hfcfHR2tt956S6dPn/Z82f7f//2fV51NmzapX79+mjRpkqds7969XnUCAgIueo1KdHS03n//fa+Qs3nzZtWrV0/NmjWrcJvPtWnTJi1atEgjRoyQJB04cEBZWVme9d26ddPBgwe1e/fucntvunXrpk8//dRrCKm0Ro0aKSMjw7Ock5Ojffv2VahdF/rc6tWrp9atW+vTTz/VoEGDyt1HRESERo8erSVLlmjLli265557LnrcS8WwFACgxv3qV7/Shx9+qKSkJP3617/2WteuXTutXLlSKSkp2r59u+66664L9nKc66677pLNZtO9996rHTt2aO3atXrxxRfLHGPr1q1at26ddu/erf/5n//RN99841WndevW+u6777Rr1y5lZWWV27MxadIkHThwQA899JB27typv//973rqqac0bdo0z/U2VdGuXTu99dZbSk1N1VdffaVf/epXXr0iAwcO1PXXX69f/OIXWr9+vfbt26ePPvpIH3/8sSRpxowZ+uabbzRp0iR999132rlzpxITEz0BafDgwXrrrbe0adMm/fDDD5owYYJnWPBi7brY5zZz5ky99NJLmj9/vvbs2aNvv/1WCxYs8Kpz33336c0331RqaqrnLrmaRLgBANS4wYMHq0GDBtq1a5fuuusur3Uvv/yy6tevr379+mnkyJEaNmyYevbsWeF9h4aG6oMPPtCOHTvUo0cPPfHEE3r++ee96sTHx+vnP/+5xo0bpz59+ujo0aNevRGSdP/996tjx46e60tK7vgprVmzZlq7dq2+/vprde/eXfHx8br33nv1xz/+sRKfRllJSUk6fvy4evToobvvvluTJ09W48aNveq8//77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FMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFMINAACwFJ+Hm0WLFqlNmzYKDAxUr169tGnTpgvWz8/P1xNPPKFWrVrJ4XCobdu2SkpKukytBQAAtZ2fLw++YsUKTZ06VYsWLVL//v31+uuva/jw4dqxY4datmxZ7jZjx47Vf//7Xy1evFjt2rVTZmamioqKLnPLAQBAbWWYpmn66uB9+vRRz549lZiY6Cnr1KmTRo8erYSEhDL1P/74Y91xxx368ccf1aBBgyodMycnR+Hh4crOzlZYWFiV2w4AAC6fynx/+2xYqqCgQNu2bdPQoUO9yocOHarNmzeXu82aNWsUExOjF154Qc2aNVOHDh306KOP6vTp0+c9Tn5+vnJycrxeAADAunw2LJWVlSWn06nIyEiv8sjISB0+fLjcbX788Uf961//UmBgoFatWqWsrCxNmjRJx44dO+91NwkJCZo1a1a1tx8AANROPr+g2DAMr2XTNMuUlXC5XDIMQ2+//bauu+46jRgxQnPnztXSpUvP23szY8YMZWdne14HDhyo9nMAAAC1h896bho2bCi73V6mlyYzM7NMb06JqKgoNWvWTOHh4Z6yTp06yTRNHTx4UO3bty+zjcPhkMPhqN7GAwCAWstnPTcBAQHq1auX1q9f71W+fv169evXr9xt+vfvr0OHDikvL89Ttnv3btlsNjVv3rxG2wsAAOoGnw5LTZs2TX/5y1+UlJSk1NRUPfzww0pLS1N8fLwk95DS+PHjPfXvuusuRURE6J577tGOHTu0ceNGPfbYY5o4caKCgoJ8dRoAAKAW8ek8N+PGjdPRo0c1e/ZsZWRkqEuXLlq7dq1atWolScrIyFBaWpqnfmhoqNavX6+HHnpIMTExioiI0NixYzVnzhxfnQIAAKhlfDrPjS8wzw0AAHVPjc5zs2/fvio3DAAAoKZVOty0a9dOgwYN0vLly3XmzJmaaBMAAECVVTrcbN++XT169NAjjzyiJk2a6Le//a2+/vrrmmgbAABApVU63HTp0kVz585Venq6lixZosOHD+tnP/uZOnfurLlz5+rIkSM10U4AAIAKqfKt4H5+fhozZozeffddPf/889q7d68effRRNW/eXOPHj1dGRkZ1thMAAKBCqhxutm7dqkmTJikqKkpz587Vo48+qr1792rDhg1KT0/XqFGjqrOdAAAAFVLpeW7mzp2rJUuWaNeuXRoxYoSWLVumESNGyGZz56Q2bdro9ddf1zXXXFPtjQUAALiYSoebxMRETZw4Uffcc4+aNGlSbp2WLVtq8eLFl9w4AACAymISPwAAUOvV6CR+S5Ys0XvvvVem/L333tObb75Z2d0BAABUq0qHm+eee04NGzYsU964cWM9++yz1dIoAACAqqp0uPnpp5/Upk2bMuWtWrXyesglAACAL1Q63DRu3FjfffddmfLt27crIiKiWhoFAABQVZUON3fccYcmT56szz77TE6nU06nUxs2bNCUKVN0xx131EQbAQAAKqzSt4LPmTNHP/30k2688Ub5+bk3d7lcGj9+PNfcAAAAn6vyreC7d+/W9u3bFRQUpK5du6pVq1bV3bYawa3gAADUPZX5/q50z02JDh06qEOHDlXdHAAAoEZUKdwcPHhQa9asUVpamgoKCrzWzZ07t1oaBgAAUBWVDjeffvqpbrvtNrVp00a7du1Sly5dtH//fpmmqZ49e9ZEGwEAACqs0ndLzZgxQ4888oh++OEHBQYG6v3339eBAwc0cOBA3X777TXRRgAAgAqrdLhJTU3VhAkTJEl+fn46ffq0QkNDNXv2bD3//PPV3kAAAIDKqHS4CQkJUX5+viSpadOm2rt3r2ddVlZW9bUMAACgCip9zU3fvn315ZdfKjo6WrfccoseeeQRff/991q5cqX69u1bE20EAACosEqHm7lz5yovL0+SNHPmTOXl5WnFihVq166dXn755WpvIAAAQGVUKtw4nU4dOHBA3bp1kyQFBwdr0aJFNdIwAACAqqjUNTd2u13Dhg3TiRMnaqo9AAAAl6TSFxR37dpVP/74Y020BQAA4JJVOtw888wzevTRR/WPf/xDGRkZysnJ8XoBAAD4UqUfnGmznc1DhmF4/jZNU4ZhyOl0Vl/ragAPzgQAoO6p0QdnfvbZZ1VuGAAAQE2rdLgZOHBgTbQDAACgWlQ63GzcuPGC66+//voqNwYAAOBSVTrc3HDDDWXKSl97U9uvuQEAANZW6buljh8/7vXKzMzUxx9/rN69e+uTTz6piTYCAABUWKV7bsLDw8uUDRkyRA6HQw8//LC2bdtWLQ0DAACoikr33JxPo0aNtGvXruraHQAAQJVUuufmu+++81o2TVMZGRl67rnn1L1792prGAAAQFVUOtxce+21MgxD587917dvXyUlJVVbwwAAAKqi0uFm3759Xss2m02NGjVSYGBgtTUKAACgqiodblq1alUT7QAAAKgWlb6gePLkyZo/f36Z8oULF2rq1KnV0igAAICqqnS4ef/999W/f/8y5f369dPf/va3amkUAABAVVU63Bw9erTcuW7CwsKUlZVVLY0CAACoqkqHm3bt2unjjz8uU/7RRx/p6quvrpZGAQAAVFWlLyieNm2aHnzwQR05ckSDBw+WJH366ad66aWXNG/evGpvIAAAQGVUOtxMnDhR+fn5euaZZ/T0009Lklq3bq3ExESNHz++2hsIAABQGYZ57mx8lXDkyBEFBQUpNDS0OttUo3JychQeHq7s7GyFhYX5ujkAAKACKvP9XaVJ/IqKitS+fXs1atTIU75nzx75+/urdevWlW4wAABAdan0BcVxcXHavHlzmfKvvvpKcXFx1dEmAACAKqt0uElOTi53npu+ffsqJSWlWhoFAABQVZUON4ZhKDc3t0x5dna2nE5ntTQKAACgqiodbgYMGKCEhASvION0OpWQkKCf/exn1do4AACAyqr0BcUvvPCCrr/+enXs2FEDBgyQJG3atEnZ2dn67LPPqr2BAAAAlVHpnpvo6Gh99913Gjt2rDIzM5Wbm6vx48dr9+7dKioqqok2AgAAVNglzXMjSSdOnNDbb7+tpKQkpaSk1PrrbpjnBgCAuqcy39+V7rkpsWHDBv36179W06ZNtXDhQg0fPlxbt26t6u4AAACqRaWuuTl48KCWLl2qpKQknTx5UmPHjlVhYaHef/99RUdH11QbAQAAKqzCPTcjRoxQdHS0duzYoQULFujQoUNasGBBTbYNAACg0ircc/PJJ59o8uTJ+t3vfqf27dvXZJsAAACqrMI9N5s2bVJubq5iYmLUp08fLVy4UEeOHKnJtgEAAFRahcNNbGys3njjDWVkZOi3v/2t/vrXv6pZs2ZyuVxav359ubMWAwAAXG6XdCv4rl27tHjxYr311ls6ceKEhgwZojVr1lRn+6odt4IDAFD3XJZbwSWpY8eOeuGFF3Tw4EG98847l7IrAACAanFJ4aaE3W7X6NGjq9Rrs2jRIrVp00aBgYHq1auXNm3aVKHtvvzyS/n5+enaa6+t9DEBAIB1VUu4qaoVK1Zo6tSpeuKJJ5ScnKwBAwZo+PDhSktLu+B22dnZGj9+vG688cbL1FIAAFBXXPLjFy5Fnz591LNnTyUmJnrKOnXqpNGjRyshIeG8291xxx1q37697Ha7Vq9erZSUlAofk2tuAACoey7bNTeXoqCgQNu2bdPQoUO9yocOHarNmzefd7slS5Zo7969euqppyp0nPz8fOXk5Hi9AACAdfks3GRlZcnpdCoyMtKrPDIyUocPHy53mz179ujxxx/X22+/LT+/is0/mJCQoPDwcM+rRYsWl9x2AABQe/n0mhtJMgzDa9k0zTJlkuR0OnXXXXdp1qxZ6tChQ4X3P2PGDGVnZ3teBw4cuOQ2AwCA2qtSD86sTg0bNpTdbi/TS5OZmVmmN0eScnNztXXrViUnJ+vBBx+UJLlcLpmmKT8/P33yyScaPHhwme0cDoccDkfNnAQAAKh1fNZzExAQoF69emn9+vVe5evXr1e/fv3K1A8LC9P333+vlJQUzys+Pl4dO3ZUSkqK+vTpc7maDgAAajGf9dxI0rRp03T33XcrJiZGsbGx+vOf/6y0tDTFx8dLcg8ppaena9myZbLZbOrSpYvX9o0bN1ZgYGCZcgAAcOXyabgZN26cjh49qtmzZysjI0NdunTR2rVr1apVK0lSRkbGRee8AQAAKM2n89z4AvPcAABQ99SJeW4AAABqAuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYCuEGAABYis/DzaJFi9SmTRsFBgaqV69e2rRp03nrrly5UkOGDFGjRo0UFham2NhYrVu37jK2FgAA1HY+DTcrVqzQ1KlT9cQTTyg5OVkDBgzQ8OHDlZaWVm79jRs3asiQIVq7dq22bdumQYMGaeTIkUpOTr7MLQcAALWVYZqm6auD9+nTRz179lRiYqKnrFOnTho9erQSEhIqtI/OnTtr3LhxevLJJytUPycnR+Hh4crOzlZYWFiV2g0AAC6vynx/+6znpqCgQNu2bdPQoUO9yocOHarNmzdXaB8ul0u5ublq0KDBeevk5+crJyfH6wUAAKzLZ+EmKytLTqdTkZGRXuWRkZE6fPhwhfbx0ksv6eTJkxo7dux56yQkJCg8PNzzatGixSW1GwAA1G4+v6DYMAyvZdM0y5SV55133tHMmTO1YsUKNW7c+Lz1ZsyYoezsbM/rwIEDl9xmAABQe/n56sANGzaU3W4v00uTmZlZpjfnXCtWrNC9996r9957TzfddNMF6zocDjkcjktuLwAAqBt81nMTEBCgXr16af369V7l69evV79+/c673TvvvKO4uDj97//+r2655ZaabiYAAKhjfNZzI0nTpk3T3XffrZiYGMXGxurPf/6z0tLSFB8fL8k9pJSenq5ly5ZJcgeb8ePH65VXXlHfvn09vT5BQUEKDw/32XkAAIDaw6fhZty4cTp69Khmz56tjIwMdenSRWvXrlWrVq0kSRkZGV5z3rz++usqKirSAw88oAceeMBTPmHCBC1duvRyNx8AANRCPp3nxheY5wYAgLqnTsxzAwAAUBMINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAAwFIINwAA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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(train_a, label='train accuracy')\n",
    "plt.plot(val_a, label='validation accuracy')\n",
    "\n",
    "plt.title('Training history')\n",
    "plt.ylabel('Accuracy')\n",
    "plt.xlabel('Epoch')\n",
    "plt.legend()\n",
    "plt.ylim([0, 1])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "SbT4YzHFh1s7"
   },
   "source": [
    "Accuracy of Pos/Neg on Test Set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 28664,
     "status": "ok",
     "timestamp": 1695329081374,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "L1ZzFERMAQk9",
    "outputId": "56411273-fc8c-476f-f660-21239bd321ad",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.8252465483234713\n",
      "F1-Macro:  0.8061357723986251\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": 47,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 605
    },
    "executionInfo": {
     "elapsed": 29278,
     "status": "ok",
     "timestamp": 1695329182045,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "zUrNTiUp8kPc",
    "outputId": "e99daa47-22f9-471e-97d4-245bf6f0b8ab",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAroAAAISCAYAAAAjsmyaAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAPYQAAD2EBqD+naQAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nOzdeXhU1eHG8ffOlpkEAmFRBEQRtIjiVkSB/sAqixUsKi4oUrQWrSDigoIUWxcqiLgUU2VxQ6hLXUAUEcUFLOIGiKwiAUFFICwhgWQms9zfH2hgzASSmcncyc338zw8mnPn3ryJ4LycnHuuYZqmKQAAAMBmHFYHAAAAAKoDRRcAAAC2RNEFAACALVF0AQAAYEsUXQAAANgSRRcAAAC2RNEFAACALbmsDpBOli1bJtM05Xa7rY4CAACAGILBoAzD0Omnn37Y11J0D2Kapnh+BgAAQPqqSlej6B7kl5ncdu3aWZwEAAAAsaxYsaLSr2WNLgAAAGyJogsAAABbougCAADAlii6AAAAsCWKLgAAAGyJogsAAABbougCAADAlii6AAAAsCWKLgAAAGyJogsAAABbougCAADAlii6AAAAsCWKLgAAAGyJogsAAABbougCAADAlii6AAAAsCWKLgAAAGyJogsAAABbclkdADXX9u3bNWPGDK1YsUJNmzZV//791bZtW6tjAQAASKLoIk5btmzR5Zdfrvz8/LKxN954Q//+97/VtWtXC5MBAADsR9GthUzTlN/vT+gaTz75ZFTJlaRgMKjx48erQ4cOCV3b6/XKMIyErgEAAEDRrWVM09SQIUO0cuXKhK6zc+fOmOPr169X9+7d5XDEv/y7Xbt2ys3NpewCAICEcDNaLZSMAllRkTUMg4IKAADSAjO6tYxhGMrNzU146cL777+v22+/vdx4v379NGLEiISuzdIFAACQDBTdWsgwDPl8voSu0bt3b+3YsUP//ve/VVhYKEm6+OKLNWrUKHk8nmTEBAAASAhLFxC3Pn36qH///nK73fL5fBo4cCAlFwAApA2KLuKyfft29e3bV08++aSCwaBKSkp0xRVX6NNPP7U6GgAAgCSKLuL01FNP6ccff4waCwQCevDBBy1KBAAAEC0tiu7GjRt13XXX6bTTTlPHjh01ZsyYSt0sVVxcrAkTJqhbt2469dRT1aNHDz3++OMqLS1NQerabfHixTHHV69erYKCghSnAQAAKM/ym9EKCws1cOBANW3aVBMnTtSuXbs0duxYFRQUaMKECYc895577tH8+fN166236vjjj9fXX3+tiRMnas+ePRo9enSKvoLaqX79+jHHvV5vwje6AQAAJIPlRfell15SYWGhZs2apQYNGkiSnE6nhg8frhtvvFGtWrWKeV4oFNI777yjv/zlLxowYIAk6eyzz9aWLVv09ttvU3Sr2RVXXKHPP/+83HifPn2UkZFhQSIAAIBoli9dWLhwoTp27FhWciWpZ8+e8ng8WrBgQYXnmaapcDisunXrRo1nZ2fLNM1qy4v9evfurZtvvjlq9rZHjx4aOXKkhakAAAAOsHxGNy8vT3379o0a83g8atGihfLy8io8z+1265JLLtH06dN1xhlnqHXr1lqxYoX++9//6uqrr447j2maKi4ujvv82uTaa6/VhRdeqMsvv1xOp1P33nuvJPH9AwAA1cY0zUo/WMryoltYWKjs7Oxy49nZ2dqzZ88hz73nnnv0j3/8Q5dffnnZ2IABA3TTTTfFnScYDGrNmjVxn1/blJSUyOVyyTAMrV27lmULAACg2lV2337Li25FKtPWJ0yYoI8++kj333+/WrZsqVWrVmnixInKzs7WzTffHNfndbvdat26dVzn1jZz585Vbm6u8vPzZRiGPvroIw0dOlROp9PqaAAAwKbWr19f6ddaXnSzs7PLHiF7sKKiogpvRJOkdevW6ZlnntETTzyh8847T5J05plnyjAMjR8/Xv3791fDhg2rnMcwDGVmZlb5vNrmf//7n/72t7+VrYc2TVPTpk2Tz+fTrbfeanE6AABgV5VdtiClwc1orVq1KrcWt7S0VJs3bz5k0f2lzZ944olR4yeeeKJCoVC5hxkguZ5//vmYN/298MILCgaDFiQCAACIZnnR7dKliz799FPt3r27bOy9995TaWmpunbtWuF5zZo1kyStWrUqanzlypWSpObNm1dDWvxiy5YtMccLCwu1d+/eFKcBAAAoz/Ki269fP9WtW1eDBw/Wxx9/rFmzZun+++/XhRdeGDWjO2rUKLVt27bs45NPPlmnnHKK/vGPf+jFF1/Up59+qqlTp+rxxx/XBRdcELVdGZLvlFNOiTl+zDHHVPgwCQAAgFRKizW606ZN05gxYzR06FB5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Dk12DgAAACCpkn4zGgAAAJAOKl1077nnHuXn51fp4u+++65mz55d5VAAAABAoiq9dGHjxo3q1q2bunfvrj59+qh9+/by+XzlXrdp0ya9//77ev3117Vt2zZNmDAhqYEBAACAyqh00Z02bZrmz5+vKVOmaNCgQXK5XDrmmGPUoEEDZWRkaM+ePfr++++1Z88e+Xw+XXLJJbrxxhvZUxcAAACWqNLNaN26dVO3bt20evVqffjhh1q+fLm2b9+u/Px85eTk6LzzzlOHDh103nnnqU6dOtWVGQAAADisuHZdaNu2rdq2bZvsLAAAAEDSsOsCAAAAbCmuort48WLNnTu37OMdO3Zo0KBB6ty5s+68804FAoGkBQQAAADiEVfRnThxovLy8so+fuihh/Tll1/q9NNP17x58/TUU08lLSAAAAAQj7iK7nfffVe2RjcUCum9997T8OHDlZubq5tvvllz5sxJakgAAAA7CpqmTNO0OoZtxVV09+7dq+zsbEnSqlWrVFJSovPOO0+SdMopp+inn35KXkIAAACbWRkKaUJJsUaWFOvekhJ9ECyl8FaDuIpuw4YN9d1330mSPvnkEzVt2lRNmjSRJO3bt08uV1ybOQAAANheXjis50oD+unnYlskU3OCQb0fClqczH7iaqT/93//p0cffVTr16/XzJkzddFFF5Ud27Bhg5o1a5a0gAAAAHayIBRUrLnbhcGgfu9yy2kYKc9kV3EV3VtvvVVbtmzRf//7X51yyim68cYby4699dZbOv3005MWEAAAwE52RiIxx/dJKpHEI7eSJ66i26BBAz399NMxjz3//PPyeDwJhQIAALCrZg6HtobD5cZzDEOZFuSxs4QfGOH3+7Vt2zaFQiFJUp06dSi6AAAAFfi926NYTamH2y0HyxaSKu6i++mnn+qKK67QGWecod///vf65ptvJEn33nuv3n333aQFBAAAsJOjHA4N9Xp1qtOpHMNQK4dD13oy1MHltjqa7cT9ZLTrrrtOgUBAf/7znxU5aK1JTk6OXn/99aQFBAAAsJtMGcoxHMox9v+zHjO51SLuJ6N16dJFs2bN0i233BJ1rE2bNlq7dm1SwgEAANjNrkhEj/n9+igU1IZIRF+GQ5oY8Gt1OGR1NNuJ62a0NWvW6F//+pckyfjV30AaNGignTt3Jp4MAAAgiUolKebGXqk1PxRU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AAAAtkTRBQAAgC1RdAEAAGBLabHrwsaNGzVmzBgtWbJEPp9PvXr10vDhw+X1eis8Z+/evXr22We1cOFCbdy4US6XSyeddJJuu+02nXTSSSlMDwAAgHRk+YxuYWGhBg4cqH379mnixIkaMWKE3nzzTY0ePfqQ523ZskUvv/yyOnXqpEcffVRjx45VJBJRv379tGrVqhSlBwAAQLqyfEb3pZdeUmFhoWbNmqUGDRpIkpxOp4YPH64bb7xRrVq1inle8+bN9d5770Xto9mpUyedd955mjFjhsaOHZuS/AAAAEhPls/oLly4UB07diwruZLUs2dPeTweLViwoMLzMjMzy20Wn5GRoVatWmn79u3VlhdA6kUiES1atEjFxcXy+/0JP20NAFA7WD6jm5eXp759+0aNeTwetWjRQnl5eVW6VnFxsdasWaM+ffrEncc0TRUXF8d9PoDk8vv9GjZsmJYuXVo2dvHFF+vJJ5/UMcccY2EyAEjMwX9pLykpkWmaFqapOUzTrPTj2y0vuoWFhcrOzi43np2drT179lTpWo899phKSkp09dVXx50nGAxqzZo1cZ8PILlmz54dVXIlKT8/X/fcc4/uvPNOi1IBQOICgUDZv69du1YZGRkWpqlZPB5PpV5nedGtSFXauiS9+eabmjZtmv7+978nNMvjdrt5tCiQRh544IGY46tWrdLRRx/NU9IA1FgHz+i2adPmkLtN4YD169dX+rWWF93s7GwVFhaWGy8qKqrwRrRfW7Roke666y5dd9116t+/f0J5DMNQZmZmQtcAkDwuV+z/TRmGoaysLP68AqixDp7Q8/l85e49QmxVmQi1/Ga0Vq1alVuLW1paqs2bN1eq6H799de66aabdP755+uOO+6orpgALHLBBRfEHO/atauysrJSnAYAUJNYXnS7dOmiTz/9VLt37y4be++991RaWqquXbse8ty8vDwNGjRIZ5xxhsaOHVulhg+gZrjqqqvUvXv3qLHjjjvusHttA0A6Kykp0ezZsxUIBBQMBpWfn291JFsyTItv8SssLFTv3r3VrFkzDR48WDt37tS4ceP0u9/9ThMmTCh73ahRozRr1iytXr1akrRz50717dtXoVBIDz30UNR0v8fjUdu2baucZcWKFZKkdu3aJfhVAUi2pUuX6q9//ascDofef/99ZnMB1FgFBQW6/vrrtWHD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McLdJYiIiJudO3fO5b5uD7p+fn5UV1c3aa+pqbnjiWhfX7kNCAhwtDceq7lVYldYLBa6du3aprEiIiIicm+1ZjHT7XdGCw4ObrIX12azceHChTsG3ca9uY17dRudP38ei8XSZO+uiIiIiPxvcXvQjY6OpqCggIqKCkfb+++/j81mY9y4cbcd17dvXwYOHMihQ4ec2g8ePMiQIUN0xQURERGR/3FuD7pxcXH4+vqSlJREfn4+Bw4c4LXXXuPJJ590WtFdvnw53/72t53GLly4kN///vekp6dz4sQJfv7zn/Phhx+ycOHC9n4ZIiIiInKfuS/26O7atYs1a9awYMECunTpQmxsLCkpKU79GhoaqK+vd2qbMmUKN27cIDMzkx07dtC/f3/S09N1swgRERERwWLc7YUoTeTUqVPAV7cFFREREZH7T2vymtu3LoiIiIiI3AsKuiIiIiJiSgq6IiIiImJKCroiIiIiYkoKuiIiIiJiSgq6IiIiImJKCroiIiIiYkoKuiIiIiJiSgq6IiIiImJKCroiIiIiYkoKuiIiIiJiSp3dXcD9xG63YxiG4x7KIiIiInJ/sdlsWCwWl/oq6H6Nq2+aiIiIiLiHxWJxObNZDMMw7nE9IiIiIiLtTnt0RURERMSUFHRFRERExJQUdEVERETElBR0RURERMSUFHRFRERExJQUdEVERETElBR0RURERMSUFHRFRERExJQUdEVERETElBR0RURERMSUFHRFRERExJQUdEVERETElBR0RURERMSUFHRFRERExJQUdEVERETElBR0pUWpqanExsZy/PhxYmNjCQ8PZ+rUqZw8edLRZ/z48axevZrt27czduxYhg4dyvz587ly5YobK5eOpjVz7c033+SJJ57g0UcfJSkpifLycjdWLh1N41w7ceIEP/zhDxk2bBjTpk2jsLDQ0ScsLIxt27bx+uuvM3r0aIYPH05qairXrl1zY+XS0bg617Kysti0aRNRUVFERESwbNkyrl+/7sbKzUFBV1xSVlbGqlWrmDNnDhs3bsTLy4s5c+Zw9epVR5/333+fw4cPk5aWRlpaGqdOnWLBggVurFo6Ilfm2pEjRzh69CgrV65kxYoVfPLJJ7z22mturFo6orKyMtasWcOcOXNIT0/nxo0bJCcnY7fbHX2ys7MpKipi3bp1pKSkkJeXxyuvvOLGqqUj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TuOHDRtGUFCQU1tBQQEhISGOkNto6tSpGIZBQUGBU/v48eOdQm5zbt68SUFBATExMXTp0sWp1ujoaG7evMnJkycBCA8P58yZM6SlpZGfn8+1a9dafB9ERFpLK7oiIq3Uo0cPrFZrsyuat6qtrSU+Ph5vb29eeOEFBgwYQJcuXSgtLSU5OZkbN260eIyrV69iGAZRUVHNPt+4R7fxcmYPPvhgkz6Nq8WNKisrm4Rf+P+tErdeGi0wMLDFOisrK6mrqyM7O9tpL/DXVVRUADB37ly6du3K7373O3JycvDw8GDkyJGkpKQQHh7e4tcSEXGFgq6ISCt5eHgwevRo8vPzKS0tpVevXrftW1BQwJUrV8jOzua73/2uo701e1F79OiBxWJh9+7dTld3aNTY1r17d+CrYHyrL774winYdu/enbKysib9rly54viaX2exWFqs08/PDw8PD37wgx8QHx/fbJ/G7R6dO3cmMTGRxMREqqur+eijj0hPT+cnP/kJx44dw2q1tvj1RERaoq0LIiJtMHfuXAzD4OWXX8ZmszV53m63c+TIEUdAvDWg5uTkNBnT2OfWVd7HH38cwzC4fPky4eHhTf6FhYUBMHToULy8vDh06JDT+JMnT3Lp0iWntsjISM6dO8c//vEPp/YDBw5gsViIiIhw5W1wYrVaiYiI4PTp04SFhTVb660BGr4KyJMnTyY+Pp7KysomtYqItJVWdEVE2mD48OGkpaWxatUqnnnmGeLi4ggNDaWuro7Tp0+Tm5tLaGgoa9asoVu3brz66qskJyfTuXNn3nvvvWZvCjFo0CAAsrKyiI6OplOnToSFhfHoo48yffp0li9fTmFhIaNGjcJqtVJWVsZf/vIXBg0aRHx8PN27dycxMZGtW7fi5+fnuOpCRkYGgYGBTquys2fP5sCBA8ydO5eFCxfy0EMPcezYMfbs2cOMGTOcTkRrjRUrVhAfH8+zzz7LjBkzCAoKora2lgsXLnDkyBHHVSbmzZtHaGgo3/nOd/D39+fSpUvs2rWLoKCg217RQUSktRR0RUTa6Mc//jFDhgzhN7/5Ddu3b6esrAxPT08GDBhAbGwsM2fOpEePHmzdupV169axZMkSrFYrEyZMID09naefftrpeLGxsXz66afs2bOHjIwMDMNwXEd39erVDB06lL179/LWW2/R0NBAz549GTFihNMJZYsWLcJqtZKTk8P+/fsZOHAgaWlppKen4+fn5+jn7+9PTk4OGzZsYMOGDdTW1tKnTx+WLFnidGWH1goJCWH//v1s2bKFjRs3Ul5ejq+vL/3792fcuHGOfhEREeTl5fH2229z7do1AgMDiYqKIikpqcWT3kREXKUbRoiImNzFixeZMmUKycnJzJs3z93liIi0G63oioiYyJkzZzh48CDDhw/Hx8eH4uJitm/fjo+PD9OmTXN3eSIi7UpBV0TERKxWK4WFhezbt4+amhp8fHyIiIjghRdeaHKJMRERs9PWBRERERExJV1eTERERERMSUFXRERERExJQVdERERETElBV0RERERMSUFXRERERExJQVdERERETElBV0RERERMSUFXREREREzpv0ozBL24IrsjAAAAAElFTkSuQmCC",
      "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": 48,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 30028,
     "status": "ok",
     "timestamp": 1695329212062,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "aw1XJc94pY9f",
    "outputId": "17d0fe97-0a2d-470d-aa5f-db29bc0c41f7",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.07061143984220906"
      ]
     },
     "execution_count": 48,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "emotion_test_acc = eval_emotions(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  loss_fn,\n",
    "  device,\n",
    "  len(df_test)\n",
    ")\n",
    "\n",
    "emotion_test_acc.item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {
    "executionInfo": {
     "elapsed": 8,
     "status": "ok",
     "timestamp": 1695329212064,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "d7DaFLMiAWps",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def get_predictions(model, data_loader):\n",
    "  model = model.eval()\n",
    "\n",
    "  review = []\n",
    "  predictions = []\n",
    "  emo_predictions = []\n",
    "\n",
    "  prediction_probs = []\n",
    "  real_values = []\n",
    "  emo_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",
    "      emotions = d[\"emotions\"].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",
    "      emo_preds = max_emotion(scores[0],scores[1]).to(device)\n",
    "\n",
    "      probs = F.softmax(outputs, dim=1)\n",
    "\n",
    "      review.extend(reviews)\n",
    "      predictions.extend(preds)\n",
    "      emo_predictions.extend(emo_preds)\n",
    "\n",
    "      prediction_probs.extend(probs)\n",
    "      real_values.extend(sentiments)\n",
    "      emo_real_values.extend(emotions)\n",
    "\n",
    "      pos_scores.extend(scores[0])\n",
    "      neg_scores.extend(scores[1])\n",
    "\n",
    "\n",
    "  predictions = torch.stack(predictions).cpu()\n",
    "  emo_predictions = torch.stack(emo_predictions).cpu()\n",
    "  prediction_probs = torch.stack(prediction_probs).cpu()\n",
    "  real_values = torch.stack(real_values).cpu()\n",
    "  emo_real_values = torch.stack(emo_real_values).cpu()\n",
    "  pos_scores = torch.stack(pos_scores).cpu()\n",
    "  neg_scores = torch.stack(neg_scores).cpu()\n",
    "  return review, predictions, emo_predictions, prediction_probs, real_values, emo_real_values, pos_scores, neg_scores"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {
    "executionInfo": {
     "elapsed": 27254,
     "status": "ok",
     "timestamp": 1695329239311,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "kZhYtki1AYx8",
    "tags": []
   },
   "outputs": [],
   "source": [
    "y_review_texts, y_pred, emo_pred , y_pred_probs, y_test, emo_y_test, pos_scores, neg_scores = get_predictions(\n",
    "  model,\n",
    "  test_data_loader\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {
    "executionInfo": {
     "elapsed": 9,
     "status": "ok",
     "timestamp": 1695329239312,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "mO1FHn0GAbCU",
    "tags": []
   },
   "outputs": [],
   "source": [
    "from sklearn.metrics import classification_report\n",
    "from sklearn.metrics import confusion_matrix\n",
    "class_names = ['negative', 'positive']"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "PnBSQFJuh_As"
   },
   "source": [
    "Pos/Neg Classification Report"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 9,
     "status": "ok",
     "timestamp": 1695329239312,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "J9-01snpAcM8",
    "outputId": "4d6f7fff-9a14-49bf-c847-d2e8ba79f5f7",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "              precision    recall  f1-score   support\n",
      "\n",
      "    negative       0.86      0.87      0.86      1603\n",
      "    positive       0.77      0.75      0.76       932\n",
      "\n",
      "    accuracy                           0.83      2535\n",
      "   macro avg       0.81      0.81      0.81      2535\n",
      "weighted avg       0.82      0.83      0.82      2535\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(classification_report(y_test, y_pred, target_names=class_names))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "Bjg-0Nj-iCPU"
   },
   "source": [
    "Emotion Classification Report"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 7,
     "status": "ok",
     "timestamp": 1695329239312,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "DHauMLMCsqPx",
    "outputId": "44723e85-2e11-4fc7-ab2b-a901729cfc0a",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "                precision    recall  f1-score   support\n",
      "\n",
      "         anger       0.00      0.00      0.00       131\n",
      "          fear       0.00      0.00      0.00        65\n",
      "     annoyance       0.17      0.20      0.18       194\n",
      "     gratitude       0.16      0.20      0.18       260\n",
      "    admiration       0.00      0.00      0.00       348\n",
      "        caring       0.02      0.09      0.03        86\n",
      " embarrassment       0.00      0.00      0.00        23\n",
      "           joy       0.03      0.30      0.06        93\n",
      "       sadness       0.08      0.51      0.13       102\n",
      "   disapproval       0.00      0.00      0.00       195\n",
      "      optimism       0.00      0.00      0.00       107\n",
      "      approval       0.00      0.00      0.00       236\n",
      "    excitement       0.00      0.00      0.00        57\n",
      "     amusement       0.00      0.00      0.00       186\n",
      "disappointment       0.00      0.00      0.00        88\n",
      "       remorse       0.00      0.00      0.00        44\n",
      "          love       0.00      0.00      0.00       160\n",
      "       disgust       0.00      0.00      0.00        76\n",
      "        relief       0.00      0.00      0.00         7\n",
      "         pride       0.00      0.00      0.00         7\n",
      "         grief       0.00      0.00      0.00         2\n",
      "        desire       0.00      0.00      0.00        56\n",
      "   nervousness       0.00      0.00      0.00        12\n",
      "\n",
      "      accuracy                           0.07      2535\n",
      "     macro avg       0.02      0.06      0.03      2535\n",
      "  weighted avg       0.03      0.07      0.04      2535\n",
      "\n"
     ]
    }
   ],
   "source": [
    "class_names = list(emotion_map.keys())\n",
    "\n",
    "print(classification_report(emo_y_test, emo_pred, target_names=class_names))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "GhTpYmfdiF-P"
   },
   "source": [
    "Reverse Native Injection Accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 30105,
     "status": "ok",
     "timestamp": 1695329269413,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "pOutPTF6qJY8",
    "outputId": "a034fc7e-f3ae-44e3-9bd9-2c416c5b45b3",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.1747534516765286\n",
      "F1-Macro:  0.1685982399772843\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": 55,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 605
    },
    "executionInfo": {
     "elapsed": 28733,
     "status": "ok",
     "timestamp": 1695329298142,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "F25gPUqgvw0w",
    "outputId": "747d6857-a67e-4f00-f9a9-fea35eee0d06",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAroAAAISCAYAAAAjsmyaAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAPYQAAD2EBqD+naQAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nOzdeXhU5eH28fvMlpkQAmFTgYIIKqKo8FPZLGpFYlGkgigKiJXSCkjdoqhFi68oaLEq4IqyKCpWUURcAipFBdGKKDtIWESRnTAJYZJZzvsHGhIzgWQyyZk5fD/XxdXmmTln7gRD7jzznOcYpmmaAgAAAGzGYXUAAAAAoDpQdAEAAGBLFF0AAADYEkUXAAAAtkTRBQAAgC1RdAEAAGBLFF0AAADYksvqAIlk2bJlMk1Tbrfb6igAAACIIhgMyjAMtWvX7qjPpeiWYJqmuH8GAABA4qpMV6PolvDrTG7btm0tTgIAAIBoVqxYUeHnskYXAAAAtkTRBQAAgC1RdAEAAGBLFF0AAADYEkUXAAAAtkTRBQAAgC1RdAEAAGBLFF0AAADYEkUXAAAAtkTRBQAAgC1RdAEAAGBLFF0AAADYEkUXAAAAtkTRBQAAgC1RdAEAAGBLFF0AAADYEkUXAAAAtkTRBQAAgC25rA4AAECi2L17t2bOnKlVq1bphBNO0DXXXKNTTz3V6lgAYkTRBQBA0vbt2zVw4EDt2rWreGzOnDl68skn1aVLFwuTAYgVRRcAkPRM01QgEKjSOSZPnlyq5EpSKBTSv//9b7Vv375K5/Z6vTIMo0rnAFB5FF0AQFIzTVPDhw/XypUrq3Se/Pz8qOM5OTm65JJL5HDEfllL27ZtNWnSJMouUMO4GA0AkPTiUSCPdA4KKpCcmNEFACQ1wzA0adKkKi9dWLBgge69994y43379tXtt99epXOzdAGwBkUXAJD0DMOQz+er0jl69OihPXv26Pnnn1deXp4k6bLLLlNWVpZSUlLiERNADWPpAgAAv7jiiit07bXXyul0yu12a9CgQZRcIIlRdAEA0KE9dK+77jo9//zzCofDCgaDGjhwoP73v/9ZHQ1AjCi6AABImjZtmn766adSY4WFhfr3v/9tUSIAVZUQRXfTpk0aPHiwzj77bHXq1Eljxoyp0EUFBQUFGj9+vLp166azzjpL3bt318SJE1VUVFQDqQEAdrJkyZKo42vWrNH+/ftrOA2AeLD8YjS/369BgwapcePGmjBhgvbu3auxY8cqNzdX48ePP+Kxo0eP1kcffaTbbrtNJ598spYvX64JEyZo//79GjVqVA19BgAAO6hTp07Uca/XK6/XW8NpAMSD5UV35syZ8vv9mj17turVqydJcjqdysrK0tChQ9WyZcuox4VCIX344Yf6y1/+ooEDB0qSOnbsqG3btun999+n6AIAKqVPnz5aunRpmfEePXpwQRqQpCxfuvDpp5+qU6dOxSVXkjIzM+XxeLRw4cJyjzNNU+FwWLVr1y41np6eLtM0qy0vAMCeevTooZtuuqnU7O1FF12kO++808JUAKrC8hndnJwc9enTp9SYx+NRs2bNlJOTU+5xbrdbvXv31ssvv6z27durVatWWrFihf7zn/9owIABMecxTVMFBQUxHw8ASF7XX3+9evTooX79+snhcOi+++7j5wKQYEzTrPANWCwvun6/X+np6WXG09PTj7r4f/To0frnP/+pq6++unhs4MCBuvnmm2POEwwGtWbNmpiPBwAkt0AgIIfDIcMwtHbtWpYtAAnI4/FU6HmWF93yVKStjx8/Xv/973/14IMPqkWLFlq1apUmTJig9PR0/f3vf4/pdd1ut1q1ahXTsQCA5DZv3jw999xzys/PlyQtXrxYf/vb3+R0Oi1OBuBXGzZsqPBzLS+66enp8vv9Zcbz8vLKvRBNktavX68pU6bo6aef1sUXXyxJOvfcc2UYhh599FH1799f9evXr3QewzCUmppa6eMAAMntiy++0AMPPFDqOo8ZM2bI5/Np+PDhFiYDUFJFly1ICXAxWsuWLcusxS0qKtIPP/xwxKL7a5s/7bTTSo2fdtppCoVCZTb9BgDgSF599dWoFzO//vrrCgaDFiQCUFWWF92uXbtqyZIl2rdvX/HY/PnzVVRUpAsuuKDc45o0aSJJWrVqVanxlStXSpKaNm1aDWkBAHa1bdu2qON+v794KQOA5GJ50e3Xr59q166tYcOG6bPPPtPs2bP14IMPqmfPnqVmdO+99161adOm+OMzzjhDZ555pv75z3/qtdde05IlSzR58mRNnDhRPXr0KLVdGQAAR3PGGWdEHf/d736nunXr1nAaAPGQEGt0p0+frjFjxmjEiBHyer26/PLLlZWVVep5kUhE4XC4+GOn06lnn31WTz75pCZPnqzdu3frhBNO0IABA3TTTTfV9KcBAEhyf/7zn/Xxxx+Xmr01DEPDhg2r1JpAAInDMLm7QrEVK1ZIktq2bWtxEgCAFTZv3qzJkyfrgw8+kMPh0GOPPXbEZXQAal5l+prlSxcAAEgUJ554okaNGqW0tDSlpqbqvPPOszoSgCqg6AIAAMCWKLoAAACwJYouAAAAbImiCwAAAFui6AIAAMCWKLoAAACwJYouAAAAbImiCwAAAFui6AIAAMCWKLoAAACwJYouAAAAbImiCwAAAFui6AIAAMCWKLoAAACwJYouAAAAbImiCwAAAFui6AIAAMCWKLoAAACwJYouAAAAbMlldQAAwLHHNE0FAgGrY0RVMleiZvR6vTIMw+oYQMKj6AIAalwgEFBmZqbVMY6qV69eVkeIKjs7Wz6fz+oYQMJj6QIAAABsiRldAIClwj3DiffTyPzlfxNpdUBIcr7rtDoFkFQS7Z8WAMCxxiV+GgGoFixdAAAAgC1RdAEAKMGMmIr4IzKLzKM/GUBC480iAAB+EVwbVPCboMyDpuSUXKe65OngkeFIpMW6ACqKogsAgKTQDyEVLSo6PBCWQqtDkkNK6ZBiXTAAMWPpAgAA+qXURhtfF5IZZhkDkIwougAASIociER/IPjLHwBJh6ILAIAk5/HR96g16hoyvKzRBZIRRRcAAEnuM92S9zeDhuQ5x2NJHgBVx8VoAABIctR2yNfLp+DKoCK7IzLSDLnbuOVsxN3IgGRF0QUA4BeONIdSOrLDAmAXLF0AAACALVF0AQAAYEsUXQAAANgSRRdAUigsLNSGDRuUm5trdRQAQJLgYjQACW/GjBl6+umntX//frndbvXq1Uv/+Mc/5PGw7RMAoHwUXQDVxjRNBQKBKp1jwYIFGjt2bPHHwWBQb775ptxut+64444qndvr9cowuBEAANgVRRdAtTBNU8OHD9fKlSurdB6/3x91/LXXXlN2dnaVimrbtm01adIkyi4A2BRrdAFUm3gUyEgkUu5jpmlW+fwAAPtiRhdAtTAMQ5MmTary0oVHHnlEb7zxRpnxli1b6vXXX6/SuVm6AAD2RtEFUG0Mw5DP56vSOf76179qwYIF2r17d/GYy+VSVlZWlc8NALA3li4ASGiNGzfWG2+8oUGDBsnlciklJUXTpk1T165drY4GAEhwFF0ACa9Ro0YaMWKE6tSpo7S0NLVu3drqSACAJEDRBQAAgC1RdAEAAGBLFF0AAADYEkUXAAAAtkTRBQAAgC1RdAEAAGBLFF0AAADYEkUXAAAAtkTRBQAAgC1RdAEAAGBLFF0AAADYEkUXAAAAtkTRBQAAgC1RdAEAAGBLFF0ACa+wsFBz585Vfn6+Dh48qL1791odCQCQBCi6ABKa3+/Xtddeq9GjR6uwsFAFBQW66qqrtHr1aqujAQASHEUXQEKbOnWq1q1bV2rM7/fr4YcftigRACBZUHQBJLSFCxdGHV+2bJn8fn8NpwEAJBOKLoCE5vP5oo67XC653e4aTgMASCYUXQAJrVevXlHHu3fvXm4JBgBAougCSHB9+/bVNddcI4fj8D9X7dq10z/+8Q8LUwEAkgFFF0BCMwxD999/v9555x2lpaWpTp06mjx5surWrWt1NABAgnNZHQAAKuKEE05QSkqK1TEAAEmEGV0AAADYEkUXAAAAtkTRBQAAgC2xRhcAgBLCO8KK7IrISDPkbOaU4TCsjgQgRhRdAAAkmWFThR8XKrw1XDxmpBvy/tErRxpvgALJiO9cAAAkhVaHSpVcSTL9pooWF1mUCEBVUXQBAJAU2hiKOh7+MSyzyKzhNADigaILAMCR0HGBpEXRBQBAkvNEZ/TxJk4ZHi5IA5IRRRcAAEnu091yNC79Y9FIM+Tp7LEoEYCqYtcFAAAkGS5Dvj/6FN4WVnhXWI40h5wnOmU4mc0FkhVFFwBwzDFNU2aBKcNjyHCXLrLOxk45G0dfxgAguVB0AQDHlNDmkIq+KpKZZ0pOydXKJU9HjwwXM7eA3VB0AQDHjPDOsAo/KTy8k0JYCq0LSaaU8vsUS7MBiD+KLgDAWtG3r62el1oVirpdWGhDSJ72HkX8EQW/Cyq8+9AaXXcbt1wnJciPyhr8OgF2kSDfvQCAY4lpHm6bzndrbj2seaCcTXEjUmR2RIFA4PBQYUSFnxXK+J8hjyexdl4o+fUDUD62FwMAHDOczuil2jAMhULRp0wLCwsplkCSYkYXAFDjDOPwhV/hnuEa+2nkPOiUMdeQWVC6uLo7uhVcE5Ryyx5jmqbCPcIyvBZfrBY6PPtd8usHoHwUXQCAtVyqsZ9GjtoOea/wKrgyqMj2iIxUQ67TXHI1dSn8c1jh3HCZYwyfIaWK90CBJJQQ37abNm3S4MGDdfbZZ6tTp04aM2ZMqXVSR5Kbm6vRo0fr/PPPV9u2bZWZmamZM2dWc2IAQLJy1HIopUOKfL188l7ilavpoZbtPsMtRZkodbd1y3AwgwokI8tndP1+vwYNGqTGjRtrwoQJ2rt3r8aOHavc3FyNHz/+iMceOHBAAwcOVEpKiu69917Vr19fW7ZsUTAYrKH0AAC7cB7nlDfTq6JvihTZFZGRZsh9hlvuNm6rowGIkeVFd+bMmfL7/Zo9e7bq1asn6dDFAllZWRo6dKhatmxZ7rHPPfecAoGA3njjDXm9XklShw4daiQ3AMB+nE2c8jXxWR0DQJxYvnTh008/VadOnYpLriRlZmbK4/Fo4cKFRzx21qxZuuqqq4pLLgAAAPAry2d0c3Jy1KdPn1JjHo9HzZo1U05OTrnHbd26Vbt371Z6err+9re/adGiRapVq5Z69OihkSNHxlx+TdNUQUFBTMcCqD4l1+0fPHiQ7Z6SXEWvw7BCaGtIoZyQFJFczV1ytnAm3BpdvgdwLDNNs8I7j1hedP1+v9LT08uMp6ena//+/eUet3v3bknSo48+qksvvVSTJ0/Whg0b9O9//1vBYFBjxoyJKU8wGNSaNWtiOhZA9SksLCz+/2vXrlVKCrdrTWYl/z4TSdH/ihRcfvg6j/CmsJxbnPL+IbHeOeR7AMe6it7ExfKiW56jtfVIJCJJatmypcaOHStJ6tSpk0KhkB599FHdcsstatiwYaVf1+12q1WrVrGFBlBtSs4Atm7dmiVLSS4RZ3QjeREFV5S9mDm8KazwtrCcjWvuDm5Hw/cAjmUbNmyo8HMtL7rp6eny+/1lxvPy8o54IVrdunUlSR07diw13rFjR0UiEeXk5MRUdA3DUGpqaqWPA1C9Sv7i6/P55PNxwVAyS8QbHoR/DkvlrAZItKLL9wCOZZX598Pyi9FatmxZZi1uUVGRfvjhhyMW3d/97ndyu8tu+fLrmiWHw/JPDQCQRI505zPL74oGICaWt8GuXbtqyZIl2rdvX/HY/PnzVVRUpAsuuKDc4zwej7p06aIvvvii1PgXX3whl8vF8gMAQKU4mzpl1IpSaF2Sq6Xlb4ACiIHlRbdfv36qXbu2hg0bps8++0yzZ8/Wgw8+qJ49e5aa0b333nvVpk2bUscOHz5c69at01133aXPP/9c06ZN08SJE9W/f/9S25UBAHA0ZsCU+xy3jLqHy66RZsh7iffQbYABJB3Lf0VNT0/X9OnTNWbMGI0YMUJer1eXX365srKySj0vEokoHC59D/IzzzxTzz33nB577DHddNNNqlu3rgYMGKBbbrmlJj8FAEASM8OmihYVKbQhdGiNrlNyneKS6zSXHPUdCbmeGEDFWF50JalFixZ68cUXj/iccePGady4cWXGu3Tpoi5dulRXNACAzQWXBhX6PnR4ICyF1ofkaOSQs0HiXIAGoPIsX7oAAIBVTNNUcF3ZLcUkKbQ2FHUcQPJIiBldAMAxzMo+GZZUFP0h86BpbbbfSqQsQJKg6AIALOV819rlAU6ns8w1IJLkKnLJ+TZLF4BkxtIFAMAxLdqtdA3D4Ba7gA0wowsAqHFer1fZ2dlWxyj2448/6q233tKWLVtkGIa+/PJLBYNBvfrqq2rcuLHV8crg9r9AxVB0AQA1zjCMhLqF7cknn6yhQ4dq8ODB+v777yVJoVBIN9xwg5599lmdfvrpFicEEAuWLgAAIGnatGnFJfdXeXl5evTRRy1KBKCqKLoAAEj6/PPPo45/99138vv9NZwGQDxQdAEAkJSamhp13O12y+1213AaAPFA0QUAQFLPnj2jjl9yySUJtZ4YQMVRdAEAkNS7d2/169dPTufhvXPbt2+vkSNHWpgKQFVQdAEA0KGdIO6++27NmjVLPp9PtWrV0lNPPaU6depYHQ1AjNheDACAEo477jjW5AI2wYwuAAAAbImiCwAAAFui6AIAAMCWKLoAAACwJYouAAAAbImiCwAAAFtiezEASWHVqlUKBAJyOBwKh8NWxwEAJAFmdAEktGAwqFtuuUWDBg3SgQMHlJeXp2uuuUbbt2+3OhoAIMFRdAEktFdeeUUfffRRqbHNmzdrzJgxFiUCACQLii6AhPbBBx9EHV+4cKEOHDhQw2kAAMmEogsgoUUikajjpmnKNM0aTgMASCYUXQAJ7ZJLLok63qlTJ6WlpdVwGgBAMqHoAkho119/vc4999xSY8cdd5xGjRplUSIAQLKg6AJIaF6vV1OnTtWECRPk8/mUlpamWbNmqXnz5lZHAwAkOPbRBZDwDMNQ586dlZqaKulQ+QUA4GiY0QUAAIAtUXQBAABgSyxdAFDMNE0FAgGrY0RVMleiZvR6vTIMw+oYAIBfUHQBFAsEAsrMzLQ6xlH16tXL6ghRZWdny+fzWR0DAPALli4AAADAlpjRBRDVU11zleJMrDuP/XojtERaHVAYNjT807pWxwAAREHRBRBVitOU12l1imSQWL8MAAAOY+kCAAAAbImiCwAAAFti6QKApLDjgKnv90rH1ZJOrpdAi3QBAAmLogsgoUVMU08vNfXBRinyy3LYMxqauq+LofQUCi8AoHwsXQCQ0D7Mkd7LOVxyJWnlLumZb7gIDABwZBRdAAnt483RC+3nP0qBEGUXAFA+ii6AhBYIRx8PRQ79AQCgPBRdAAnt3BOij7dpIKV5WKMLACgfRRdAQruqtaGTfnPjsTSPNLQdJRcAcGTsugAgoaV5DD3eTVr4g7R+r6njahnqdqJU10vRBQAcGUUXQMLzOA1d0kK6pAXlFgBQcSxdAAAAgC1RdAEAAGBLFF0AAADYEkUXAAAAtkTRBQAAgC1RdAEAAGBLMW0vVlBQoK+++krffPONduzYoUAgoIyMDLVq1UodOnTQySefHO+cAAAAQKVUquhu3rxZU6ZM0dy5c1VQUCDDMJSeni6PxyO/36/CwkIZhqFTTjlFAwcOVO/eveVwMGkMAACAmlfhovvwww/r1VdfVYsWLTRs2DCdd955atOmjVyuw6fYuXOnvv32W3300Ud66KGHNG3aNI0dO1Zt27atlvAAAABAeSpcdFevXq2pU6fq3HPPLfc5jRo1Uvfu3dW9e3fl5+dr2rRp+uabbyi6AAAAqHEVLrozZsyo1InT0tJ08803VzoQAAAAEA9xX0C7Y8cOrV69Ot6nBQAAAColpl0Xtm3bVu5j8+bN03PPPacvvvgi5lAAAABAVcVUdP/whz/IMIxyH2/RokXMgQAAAIB4iKnoPvzww2WKbkFBgb7++mt9/PHHGjduXFzCAQAAALGKqej27t076nj//v01btw4/etf/9LLL79cpWAAAABAVcT9YrQLLrhAy5cvj/dpAQAAgEqJe9Hdt2+f6tevH+/TAgAAAJUS09KFaCKRiNauXatnn31Wt9xyS7xOCwAAAMQkpqLbunXrcnddME1Td999t+6++25JkmEY7KsLAACAGhdT0R0+fPgRtxcDAAAArBZT0R0xYkS8cwAAAABxFfeL0QAAAIBEUOGiO3r0aO3atatSJ583b57mzJlT6VAAAABAVVV46cKmTZvUrVs3XXLJJerVq5fOOecc+Xy+Ms/bsmWLPv74Y7311lvasWOHxo8fH9fAAAAAQEVUuOhOnz5dH330kZ5//nkNGTJELpdLzZs3V7169ZSSkqL9+/dr69at2r9/v3w+n3r37q2hQ4eypy4AAAAsUamL0bp166Zu3bpp9erVWrBggb777jvt3LlTu3btUkZGhi6++GKdd955uvjii5WWllZdmQEAAICjimnXhTZt2qhNmzbxzgIAAADEDbsuAAAAwJZiKrpffPGFPvjgg+KPd+/erSFDhqhLly666667VFhYGLeAAAAAQCxiKroTJkxQTk5O8cf/+te/9PXXX6tdu3bKzs7WCy+8ELeAAAAAQCxiKrqbN28uXqMbCoU0f/58ZWVladKkSfr73/+u9957L64hAUCSisKmTNO0OgYAIEnEVHTz8/OVnp4uSVq1apUOHjyoiy++WJJ05pln6ueff45fQgDHvCU/mRr6YUS93jTVf46p/6yh8AIAji6molu/fn1t3rxZkrR48WI1btxYxx9/vCTpwIEDcrli2swBAMpYvtPUg4tMbd5/6ON9AWnqclMz11ibCwCQ+GJqpL///e/1+OOPa8OGDXr77bf1pz/9qfixjRs3qkmTJnELCODY9vY6U5Eok7ez15u6urXkdBg1HwoAkBRiKrq33Xabtm3bpv/85z8688wzNXTo0OLH5s6dq3bt2sUtIIBj28/50cf9hVJ+UKqTUrN5AADJI6aiW69ePb344otRH3vppZfk8XiqFAoAftUyQ9riLzveKFWqzT81AIAjqPINIwKBgHbs2KFQKCRJSktLo+gCiJu+rQ15o/xK3v90Qw6DZQsAgPLFXHSXLFmia665Ru3bt9dFF12kdevWSZIeeOABzZs3L24BARzbTqxr6LE/GPr97w7N4rZtKN1/vqHuJ1FyAQBHFvOd0QYPHqzCwkLdeOONikQixY9lZGTorbfeiltAAKidcqjkNqp16E99n9WJAADJIOY7o3Xt2lWzZ8/WrbfeWuqx1q1ba+3atXEJBwA7Dpi6Zb6pWeuklbukjzdLt39k6stt7KMLADiymC5GW7NmjZ588klJkvGbNXL16tXTnj17qp4MgKUKw1YnOOS11ab2BUqPhU3pxe9MnXWc9csXEuXrBAAoK6ai63Q6FQwGoz62Z88e1apVq1Ln27Rpk8aMGaOlS5fK5/PpsssuU1ZWlrxeb4XPMX/+fN188806+eSTNXfu3Eq9PoBDSt5tbPinGRYmOSw3N1dS2Ta51S/d+HEdORxVvqY2brhbGwAklph+QrRt21Zz5syJ+lh2drbOPvvsCp/L7/dr0KBBOnDggCZMmKCRI0fq3Xff1ahRoyp8jkAgoLFjx6pBgwYVPgZAciivyBqGUeYdJQAASoppRvevf/2rBg8erOHDh+tPf/qTDMPQd999p1mzZik7O1vTp0+v8Llmzpwpv9+v2bNnq169epIOzRhnZWVp6NChatmy5VHP8dxzz6lx48Zq2rSpVq5cGcunBECllyI91XWfUpwWhvnFl9tMjVtcdvzyVqZuPCu35gP9RmH48Ow3xRsAEktMRbdz584aN26cHn74YX388ceSpP/3//6f0tPTNXbsWJ1zzjkVPtenn36qTp06FZdcScrMzNS9996rhQsXHrXo/vDDD5o6dapmzpypadOmxfLpAIgixSl5E6DoXvA7Q/720oxVpvyFktshXdJCGnKWIXcC5AMAJK6Yiq4k9erVS5mZmVq2bJl2796tjIwMtW/fXqmpqZU6T05Ojvr06VNqzOPxqFmzZsrJyTnq8Q899JB69eql1q1bV+p1ASSPnicbyjxJ2nlAquuV0jzMnAIAjq7SRTcQCOiGG27Q3//+d3Xu3FmdOnWqUgC/36/09PQy4+np6dq/f/8Rj/3kk0+0bNkyffjhh1XKUJJpmiooKIjb+YBkEggEjv4ki3ichpqW/acioRw8eJAL0myg5PcBf6dA4jFNs8JLxSpddL1er9avXy+ns3rfMzzaJ1FYWKiHH35YI0aMKLXsoaqCwaDWrFkTt/MByaSwsNDqCElt7dq1SklJsToGqqjk9wF/p0Bi8ng8FXpeTEsX2rVrp+XLl6tDhw6xHF5Kenq6/H5/mfG8vLwjrs+dPn26HA6HLrvssuLjg8GgIpGI/H6/vF5vhb8IJbndbrVq1arSxwF2kMgzukVhUzsOSBkJvHShdevWldoWEYmp5PcBf6dA4tmwYUOFnxtT0R05cqSGDRumhg0b6pJLLqn0vrkltWzZssxa3KKiIv3www9l1u6WtHHjRm3ZsiXq0olzzz1Xo0eP1rXXXlvpPIZhVHqdMWAXibprwLvfm7+5GM3UTe0MuZ2Jldfn88nn4/7Eya7k9wF/p0DiqczPqpiK7jXXXKNgMKh77rlH99xzj7xeb6kXNQxDS5curdC5unbtqmeeeUb79u1TRsahLXrmz5+voqIiXXDBBeUeN2TIEF155ZWlxp5//nlt2rRJY8eO1Yknnlj5TwxAwvniJ1NPf3N4jWQwIr2fI6U4Tf21XWIVXQBAYomp6GZmZsZt5qdfv36aMWOGhg0bpmHDhmnPnj0aN26cevbsWWrpwr333qvZs2dr9erVkg7NBP92acPbb7+tHTt2xGVJBYDE8O730S8E+nCj9OczzYSb1QUAJI6Yiu64cePiFiA9PV3Tp0/XmDFjNGLECHm9Xl1++eXKysoq9bxIJNdD02gAACAASURBVKJwmJvKA8eafeUsGz4YOvSHvXQBAOWJeR/deGrRooVefPHFIz5n3LhxRy3Y8SzgABLD6Q2kzVF2GmyeLqWnMJsLAChfzEX3hx9+0MSJE/XFF18oNzdXGRkZ6ty5s4YPH65mzZrFMyOAY1jf0wwt/sksNbPrNKQ/n0XJBQAcWUxFNycnR/369VNhYaE6duyoRo0aaefOnfrggw/03//+V6+++upRb90LABVxXC1DT14ivbPe1Pq9UqNa0hUnGzqlHkUXAHBkMRXdxx9/XHXr1tXLL7+s448/vnh8+/btGjRokJ544glNnDgxbiEBHNsaphr6y9kUWwBA5ThiOeh///ufRowYUarkStLxxx+vYcOG6csvv4xLOAAAACBWMRXdgwcPqm7dulEfy8jISOi7KwEAAODYEFPRbdGihd59992oj7333ns66aSTqhQKAAAAqKqY1ugOHDhQo0aNUl5enq688ko1bNhQu3bt0pw5c/TJJ59ozJgx8c4JAAAAVEpMRfeqq67Snj179Mwzz2jhwoWSJNM05fV6ddttt6lPnz5xDQkAAABUVsz76P7tb3/Tddddp2XLlik3N1d169ZVu3btVLt27XjmAwAAAGJSpTuj1a5dW127do1XFgAAACBuYroYbdasWeXukztx4kTNnj27SqEAAACAqoqp6L788stKT0+P+lhGRoZeeumlKoUCgJK+3WHqjo8j6vlGRH95L6K5G0yrIwEAkkBMSxe2bNmiU045JepjLVu21JYtW6oUCgB+tXaPqfs+NRWKHPr4p3zpqaWmisJS71O5WxoAoHwxzehKUl5eXtTx/Px8hcPhmAMBQElvrj1ccn87Ho4wswsAKF9MRffUU0/Ve++9F/WxuXPnljvbCwCV9aM/+vi+gJQfrNksAIDkElPR7d+/v7KzszVy5Eh999132rFjh7777jvdfffdmjdvngYMGBDvnACOUc3rRB+v75PS3DWbBQCQXGJao9uzZ09t3LhRzz//vObMmSPp0A0jnE6nhg4dqiuuuCKuIQEcu65qbeiLn0wFf7N84ZrTDDkdrNEFAJQv5n10b7nlFvXp00eLFi3Svn37VK9ePXXp0kVNmjSJZz4Ax7iT6xkad5H0yipT6/dIjWodugjt4hMpuQCAI6vSDSOaNm2qzMxMvfDCC1q2bJlWrlyp66+/Xq1atYpXPgBQmwaGHrqAYgsAqJwKF91HHnlEH3zwgf773/8WjxUUFOiqq67STz/9JNM8dPXze++9pzfeeEMnnXRS3MMCAAAAFVXhi9GWLVumHj16lBqbMWOGfvzxRw0aNEhff/21Zs6cqdTUVE2ePDnuQQEAqG7BYFDz589XIBBQYWGh9u/fb3UkAFVQ4aK7detWnXHGGaXGFixYoHr16unOO+9UWlqazj77bP35z3/Wl19+GfegAABUp/z8fA0aNEj333+/ioqKVFhYqH79+mn9+vVWRwMQowovXfD7/WrUqFHxx6FQSCtWrFC3bt3kdDqLx0877TTt2rUrvikBADgC0zQVCASqdI4XX3xRq1evLjWWm5urhx9+WM8880yVzu31emUYrDMHalqFi26DBg20c+fO4o9Xr16tUChUZpbX4XDI4/HELyEAAEdgmqaGDx+ulStXVuk8+fn5Uce//fZbde/evUpFtW3btpo0aRJlF6hhFV66cPrpp+uNN94ovuhszpw5MgxDnTp1KvW8jRs3qmHDhvFNCQDAEcSjQFJCAfup8IzukCFDdO211+rSSy9VRkaGvv32W51zzjk6/fTTSz1vwYIFatu2bdyDAgAQjWEYmjRpUpWXLsyaNUvjx48vM/6HP/xBDz30UJXOzdIFwBoVLrpnnXWWnn76ab344ovKzc1V3759dccdd5R6zq5du7R9+3b17t077kEBACiPYRjy+XxVOse1116r77//XnPmzCl+9/KMM87QqFGjqnxuANao1A0jLrzwQl144YXlPt6wYcPiWwIDAJBMnE6nHnjgAd14441atWqVTjjhBLVr187qWACqoEp3RgMAwG6aN2+u5s2bWx0DQBxU+GI0AAAAIJlQ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ehIaGtqmsSIiIiKtERkZ6e4S2p1Tp0653NftQdfPz4/q6upG7TU1Nf/zQrRvztwGBgY62huO1dQssSssFgtdunRp01gRERERubdaM5np9jujhYSENFqLa7PZOHv27P8Mug1rcxvW6jY4ffo0Foul0dpdEREREflucXvQjY2NpaioiKtXrzraPvjgA2w2G+PGjWt2XN++fRk4cCD79+93at+3bx9Dhw7VjgsiIiIi33FuD7qJiYn4+vqSmppKYWEhe/fu5fXXX+fHP/6x04zu4sWL+f73v+80dsGCBfzxj38kKyuLY8eO8atf/YqPP/6YBQsW3O8vQ0REREQeMA/EGt1t27axYsUK5s+fT+fOnUlISGi0j9ytW7ca3Ylr0qRJ3Lhxg40bN5Kbm0v//v3JysrSzSJEREREBIuhW3M4nDhxArh9+zwRERERefC0Jq+5femCiIiIiMi9oKArIiIiIqakoCsiIiIipqSgKyIiIiKmpKArIiIiIqakoCsiIiIipqSgKyIiIiKmpKArIiIiIqakoCsiIiIipqSgKyIiIiKmpKArIiIiIqbU0d0FPEjsdjuGYTjuoSwiIiIiDxabzYbFYnGpr4LuN7j6TRMRERER97BYLC5nNothGMY9rkdERERE5L7TGl0RERERMSUFXRERERExJQVdERERETElBV0RERERMSUFXRERERExJQVdERERETElBV0RERERMSUFXRERERExJQVdERERETElBV0RERERMSUFXRERERExJQVdERERETElBV0RERERMSUFXRERERExJQVdERERETElBV1pUWZmJgkJCRw9epSEhAQiIiKYMmUKx48fd/SJi4tj+fLlbNmyhbFjxzJs2DDmzZvHpUuX3Fi5tDetOde2b9/O+PHjGTFiBKmpqVRUVLixcmlvGs61Y8eO8dOf/pThw4czdepUiouLHX3Cw8PZvHkzb7zxBqNHjyYyMpLMzEyuXbvmxsqlvXH1XMvJyWHdunXExMQQFRXFokWLuH79uhsrNwcFXXFJeXk5y5YtY/bs2axduxYvLy9mz57NlStXHH0++OADDh48iNVqxWq1cuLECebPn+/GqqU9cuVcO3ToEIcPH2bp0qUsWbKEzz77jNdff92NVUt7VF5ezooVK5g9ezZZWVncuHGDtLQ07Ha7o09eXh6lpaWsWrWK9PR0Dhw4wKuvvurGqqU9cuVc27FjB1988QW//vWvSU1N5f3332fDhg1urNocOrq7AGkfKisrWbt2LdHR0QCMGjWKcePGsW3bNl588UUAamtr2bx5M35+fgD06tWLWbNm8dFHH/GjH/3IbbVL++LKuWYYBr/97W/x8vIC4IsvviA3N5dbt27RoYPev4trqqqq2L59O2FhYQB06tSJlJQU/v73vzNy5EgAvLy8yM7OxsPDw/H41VdfJS0tjZCQELfVLu2LK+daYGAga9asASA2NpYTJ05w4MAB0tPT3Va3GegVQVzi6+vrCB4Afn5+jB492ulPylFRUY6QCxAdHY2Pj49TH5GWuHKujRo1yhFyAUJDQ7Hb7U6zviIt6dmzpyN4AI7gevHiRUfb+PHjHSEX4LHHHsMwDE6cOHH/CpV2z5VzbcyYMU5jQkNDKSsruz8FmpiCrrgkICCgUVuPHj0oLy93etxSH5GWuHKuffMNFYCnpycAN2/evLfFiam4ch7d+XvN398fT09PXX8greLKudZUH5vNdu+LMzkFXXFJUxf6XLlyhaCgIKfHLfURaYkr55rI/XLn77Wqqirsdjs9e/Z0U0Ui0hoKuuKSmpoaPv30U6fHRUVFDBs2zNF27NgxampqHI8//fRTrl275tRHpCWunGsi98vhw4epr693PP7zn/+MxWIhIiLCjVWJiKt0MZq4pFu3bixZsoQFCxbg6+tLTk4OAMnJyY4+Xbt25ZlnnuGZZ56hpqaG1atXM3ToUMaOHeuusqUdcuVcE7lfbDYbzz77LNOnT+f8+fOsXr2axx9/XBeiibQTCrrikqCgINLT03njjTc4e/YsYWFh5ObmEhgY6OgTHx9Pr169eO2116iuriYmJoZly5a5sWppj1w510Tul5kzZ1JRUcFLL72EzWYjPj6epUuXurssEXGRxTAMw91FyIMtMzOT4uJi9u3b12yfuLg4Hn30Ub0AyF1x5VwTuV/Cw8N56aWXmD17trtLEZE20hpdERERETElBV0RERERMSUtXRARERERU9KMroiIiIiYkoKuiIiIiJiSgq6IiIiImJKCroiIiIiYkoKuiIiIiJiSgq6IyF0oKSlh0aJFxMXFERERQWRkJE8++SQ5OTlUVla26lhHjx7lrbfeukeVfvvOnz9PeHg4e/bscXcpIiJN0vZiIiJtVFBQwLJly3j44YeZPn06oaGh1NXVUVxcTEFBAYMHDyY7O9vl4y1fvpwdO3bw73//+x5W/e2x2WycPHmSfv36ERAQ4O5yREQa6ejuAkRE2qO//e1vWK1WYmJi2LBhA15eXo7nxowZQ0pKCoWFhW6s8N6pr6+nvr4eLy8vhg8f7u5yRESapRldEZE2mDt3LoWFhRw8eJDevXv/z7779+9n9+7d/Oc//6G6uprg4GAmTJhAamoqXbp0ASAzM5N333230dgPP/yQPn36YBgGO3fupKCggDNnztCpUyeio6PJyMigb9++jv6GYbBp0yZ27drF5cuXCQsLY+HChWzcuBGAvLw8R9+vvvqKN998k48//piamhr69u3Lz372M2bNmkWHDrdXtp0/f54JEyaQnp6O3W5n9+7dlJWVsXHjRgYOHMiECRNYuXIlU6ZMcRz3v//9L2+99RaffPKJ47gzZszg6aefdvS5desWGzdu5L333uPChQt4eXnRu3dvpk6dSnJychv+R0REGtOMrohIK9XX11NUVMSQIUNaDLlwO/jFxsaSnJyMt7c3paWl5OTk8I9//IPf//73AKSmpnL9+nUOHDjArl27HGN79uwJwNKlS3n33XeZOXMm6enpVFVVkZ2dTWJiIu+99x6BgYEAZGVlsWnTJqZNm0Z8fDxlZWW88sor2O12Hn74YcdxKyoqSExMxG6389xzzxEcHMyRI0dYtWoVZ8+exWq1On0NeXl5DBgwgJdffhkfHx/69+/f5Nd66tQpEhMT6d27Ny+//DJBQUF89NFHrFixgqtXr5KWlgbAli1bWL9+PfPmzWPkyJHU1dVRWlpKTU2N6/8RIiItUNAVEWmlq1ev8vXXX9OnTx+X+qempjr+bRgGjzzyCCEhIcyYMYOSkhIGDx5Mv379HGH1zuUAx48fp6CggMzMTFJSUhztI0eO5PHHH2fr1q1kZGRQVVXF1q1beeKJJ1i+fLmjX1hYGNOmTXMKulu3buXixYu88847DB06FICxY8dSX19Pfn4+ycnJTv07depEbm4unp6ejrbz5883+lpXrlxJ165defvtt/Hx8QFuL+Ww2Wxs3ryZmTNn4u/vz+eff86gQYOYP3++Y+zYsWNd+n6KiLhKuy6IiNxj586dY+HChYwZM4bvfe97DBkyhBkzZgBQWlra4vjDhw9jsVj4yU9+Ql1dneMjMDCQwYMH89lnnwG3A7HNZmPSpElO44cPH05wcLBTW1FREaGhoY6Q22DKlCkYhkFRUZFTe1xcnFPIbcrNmzcpKioiPj6ezp07O9UaGxvLzZs3OX78OAARERGUlJRgtVopLCzk2rVrLX4fRERaSzO6IiKt1L17d7y9vZuc0bxTbW0tSUlJdOrUieeff54BAwbQuXNnysrKSEtL48aNGy0e48qVKxiGQUxMTJPPN6zRbdjOrEePHo36NMwWN6isrGwUfuH/l0rcuTVaUFBQi3VWVlZSV1dHXl6e01rgb7p69SoAc+bMoUuXLvzhD38gPz8fDw8PRo4cSXp6OhERES1+LhERVyjoioi0koeHB6NHj6awsJCysjJ69erVbN+ioiIuXbpEXl4eP/zhDx3trVmL2r17dywWCzt27HDa3aFBQ1u3bt2A28H4TpcvX3YKtt26daO8vLxRv0uXLjk+5zdZLJYW6/Tz88PDw4PJkyeTlJTUZJ+G5R4dO3YkJSWFlJQUqqur+eSTT8jKyuIXv/gFR44cwdvbu8XPJyLSEi1dEBFpgzlz5mAYBq+88go2m63R83a7nUOHDjkC4p0BNT8/v9GYhj53zvI++uijGIbBxYsXiYiIaPQRHh4OwLBhw/Dy8mL//v1O448fP86XX37p1BYdHc2pU6f45z//6dS+d+9eLBYLUVFRrnwbnHh7exMVFcXJkycJDw9vstY7AzTcDsgTJ04kKSmJysrKRrWKiLSVZnRFRNogMjISq9XKsmXLeOqpp0hMTCQsLIy6ujpOnjxJQUEBYWFhrFixAn9/f1577TXS0tLo2LEj77//fpM3hRg0aBAAOTk5xMbG0qFDB8LDwxkxYgTTpk1j8eLFFBcXM2rUKLy9vSkvL+evf/0rgwYNIikpiW7dupGSksKmTZvw8/Nz7LqQnZ1NUFCQ06zsrFmz2Lt3L3PmzGHBggU89NBDHDlyhJ07dzJ9+nSnC9FaY8mSJSQlJfH0008zffp0goODqa2t5ezZsxw6dMixy8TcuXMJCwvjBz/4AQEBAXz55Zds27aN4ODgZnd0EBFpLQVdEZE2+vnPf87QoUP53e9+x5YtWygvL8fT05MBAwaQkJDAjBkz6N69O5s2bWLVqlVkZGTg7e3NhAkTyMrK4sknn3Q6XkJCAp9//jk7d+4kOzsbwzAc++guX76cYcOGsWvXLt5++21u3bpFz549eeSRR5wuKHvhhRfw9vYmPz+fPXv2MHDgQKxWK1lZWfj5+Tn6BQQEkJ+fz5o1a1izZg21tbX06dOHjIwMp50dWis0NJQ9e/awYcMG1q5dS0VFBb6+vvTv359x48Y5+kVFRXHgwAHeeecdrl27RlBQEDExMaSmprZ40ZuIiKt0wwgREZM7d+4ckyZNIi0tjblz57q7HBGR+0YzuiIiJlJSUsK+ffuIjIzEx8eHM2fOsGXLFnx8fJg6daq7yxMRua8UdEVETMTb25vi4mJ2795NTU0NPj4+REVF8fzzzzfaYkxExOy0dEFERERETEnbi4mIiIiIKSnoioiIiIgpKeiKiIiIiCkp6IqIiIiIKSnoioiIiIgpKeiKiIiIiCkp6IqIiIiIKSnoioiIiIgp/R/fqg4AjQcegQAAAABJRU5ErkJggg==",
      "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": 56,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 27580,
     "status": "ok",
     "timestamp": 1695329325716,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "zlbzZWECocpp",
    "outputId": "27337f4e-b8c6-4b92-a088-77f03f0ccd93",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.8027613412228797\n",
      "F1-Macro:  0.7585396883512185\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\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",
    "\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",
    "\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)), dim=0)\n",
    "\n",
    "for i in new_negative_word_meaning_sentences:\n",
    "  n_emb = torch.cat((n_emb,get_cls(i)), 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": 57,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 605
    },
    "executionInfo": {
     "elapsed": 29037,
     "status": "ok",
     "timestamp": 1695329354749,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "DGrasP1mxQrD",
    "outputId": "87f1fe38-fe1b-4d6c-bf39-3c3e36c56fae",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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0f35z38u4xDT6127do04EAAAQCL7OBhscPyzUFA+05SLJQxRE1HRveeee+oV3crKSn3wwQd66623NHXq1KiEAwAASDTU2NiJqOhecsklDY6PGjVKU6dO1fTp0zV//vxmBQMAAEhEp9rt+ioUqjfew2ZnNjfKor7iefDgwfrkk0+ifVkAAICE8LMkh3ra7HXGjjEMXeJ0WpQocUV914U9e/aoXbt20b4sAABAQkgyDF3rcumLYFBfhUJKMwz1tttlZzY36qJWdEOhkDZu3KhHHnlEN9xwQ7QuCwAAkJBOttt1st1++AMRsYiKbo8ePV7+rcEAACAASURBVBrddcE0Tf3xj3/UH//4R0mSYRhav3595AkBAACACERUdCdMmHDI7cUAAAAAq0VUdCdOnBjtHAAAAEBU8Zw5AAAAJKSwi+6dd96pHTt2NOnib7zxhhYuXNjkUAAAAEBzhb10oaysTEOGDNH555+vESNG6PTTT5fb7a533ObNm/XWW2/ppZde0rZt2zRjxoyoBgYAAADCEXbRnTdvnt58803NmTNH48aNU1JSkk488USlp6crOTlZ5eXl+uqrr1ReXi63261LLrlEeXl57KkLAAAASzTpZrQhQ4ZoyJAhWr9+vd555x19/PHH2r59u3bs2KG0tDSdd955OvPMM3XeeecpNTX1SGUGAAAADiuiXRd69eqlXr16RTsLAAAAEDXsugAAAICEFFHRXblypV577bXa1zt37tS4ceM0cOBA3Xzzzaquro5aQAAAACASERXdmTNnqrS0tPb19OnT9cEHH6hfv34qKSnRP/7xj6gFBAAAACIRUdH98ssva9fo1tTUaMmSJcrPz9esWbM0adIkvfrqq1ENCQAAADRVREV3//798ng8kqRPP/1UVVVVOu+88yRJffv21TfffBO9hAAAAEAEIiq67dq105dffilJ+ve//62OHTvquOOOkyRVVFQoKSmizRwAAACAqImokf7sZz/T/fffr02bNunll1/WL3/5y9r3vvjiC3Xq1ClqAQEAAIBIRFR0b7zxRm3dulXPP/+8+vbtq7y8vNr3Fi9erH79+kUtIAAAQDT4JUmmxSnq+j6NYWmKuvxWB4iiiIpuenq65s6d2+B7Tz31lJxOZ7NCAQAARNvfrA6AmGv2AyN8Pp+2bdummpoaSVJqaipFFwAAAJaL+K6xVatW6f7779fatWslSS+88IJ69+6tu+66S9nZ2brgggvCvlZZWZkKCgq0evVqud1uDR06VPn5+XK5XGFfY8mSJbr++uvVvXt3LV68uMlfDwAASDwul0slJSVWx2iQz+fTiBEjJEmvvPJKk3pPrMRjpqaIqOiuXLlS1157rbp3765rrrmmzgMi0tLS9NJLL4VddL1er8aMGaOOHTtq5syZ2r17twoLC7V3717NmDEjrGv4fD4VFhbqmGOOieTLAQAACcowDLndbqtjHJbL5WoROVuaiIruzJkzNWjQIM2ePVs1NTV1im6PHj300ksvhX2toqIieb1eFRcXKz09XZJkt9uVn5+vvLw8ZWRkHPYajz76qDp27KjOnTtr3bp1Tf+CAAAAYsw0TZlmfN0cl2giWqO7YcMG5ebmSjrwN6WDpaena9euXWFfa/ny5crOzq4tuZKUk5Mjp9OpZcuWHfb8LVu26IknntBtt90W9mcCAABY6Y033tAVV1yhqqoqVVVVae7cuQqFQlbHSjgRzeja7XYFAoEG39u1a5datWoV9rVKS0s1cuTIOmNOp1NdunRRaWnpYc//61//qhEjRqhHjx5hf+ahmKapysrKqFwLAADgx1avXq0//elPdWZzn3zySUnSNddcY1GqlsM0zXoTrY2JqOhmZmZq4cKFGjJkSL33SkpKlJWVFfa1vF5v7eOED+bxeFReXn7Ic99++2199NFHev3118P+vMMJBALasGFD1K4HAABwsMcff7zBJQvPP/+8zjzzTNntdgtStSzh7vAVUdH97W9/q7Fjx2rChAn65S9/KcMw9PHHH2vBggUqKSnRvHnzIrlsHYdr69XV1brnnns0ceLEOssemsvhcKhbt25Rux4AAMDB9u/f3+B4ZWWlOnfurLZt28Y4UcuyadOmsI+NqOieffbZmjp1qu655x699dZbkqS//OUv8ng8Kiws1Omnnx72tTwej7xeb73xffv2HfJGtHnz5slms2no0KG15wcCAYVCIXm9Xrlcroj28zUMQykpKU0+DwAAIBx9+vRRWVlZvfFOnTrp+OOPD/vH8kerpvz+RLyP7ogRI5STk6OPPvpIO3fuVFpamvr379/kkpiRkVFvLa7f79eWLVvqrd092BdffKHNmzcrOzu73ntnnHGG7rzzTv36179uUhYAAIAjbcyYMXr77bdVUVFRO2YY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Ltx+++167bXX6o0fd9xxWrhwoWy2yP++ztIFAEhsFF0AR4xhGHK73c26xm9/+1stXbpUVVVVdcYnTJigVq1aNevaAIDExtIFAHHtlFNO0fz583XuuefKZrMpKSlJ06ZN0yWXXGJ1NABAnKPoAoh7PXv21PTp05WWlqY2bdro5z//udWRAAAtAEUXzbZixQpddtllWrFihdVRAAAAarFGFxH77LPPNHv2bL311luSpDvvvFOLFi2Sy+WyOBkAAAAzuojQpk2blJubq9dee01+v19+v19btmzRrbfeanU0AAAASczoIkKPPfaYKisr642XlJRoy5Yt6tKliwWp0FzReJLZkXJwrnjNyHZlABBfKLqIyKefftrgeDAY1PTp0zVz5kz+wG+BfD6fcnJyrI5xWCNGjLA6QoNKSkqavZ0aACB6WLqAiLRr167BccMwtGbNGm3evDnGiQAAAOpiRhcRue6667Rq1ap646mpqRowYIBOPPFEC1Ihmh4atFfJ9vh6xO73T/yNpx8WVAcNTVje1uoYAIAGUHQRkezsbN111126++67VVNTI5vNJrfbrdatW+vGG29k2UICSLabctmtTtESxNdfBgAAP6DoImK5ubnav3+/5s2bJ0my2WwaPXq0OnXqZHEyAAAA1uiimUaPHq327dvLMAwdc8wxGjVqlNWRAAAAJFF00Uwul0s33XSTjj32WE2ePJmHRQAAgLjB0gU028CBAzVw4ECrYwAAANTBjC4AAAASEkUXAAAACYmiCwAAgIRE0QUAAEBCougCAAAgIVF0AQAAkJAougAAAEhIFF0AAAAkJIouAAAAElJcPBmtrKxMBQUFWr16tdxut4YOHar8/PxDPk52//79euKJJ7R8+XKVlZUpKSlJvXv31uTJk9W7d+8YpgcAAEA8snxG1+v1asyYMaqoqNDMmTN1yy23aNGiRbrtttsOed7WrVv13HPP6eyzz9b999+vwsJChUIh5ebm6tNPP41RegAAAMQry2d0i4qK5PV6VVxcrPT0dEmS3W5Xfn6+8vLylJGR0eB5nTt31pIlS+R2u2vHzj77bJ133nl6+umnVVhYGJP8AAAAiE+Wz+guX75c2dnZtSVXknJycuR0OrVs2bJGz0tJSalTciUpOTlZGRkZ2r59+xHLCwAAgJbB8qJbWlpab9bW6XSqS5cuKi0tbdK1Kisr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duxYb3v37t01YMAALVu2TNOmTdPZs2e1bNky/frXv9asWbO8/eLi4jRs2DCfoLts2TKdPHlS7733njp37ixJ6tOnjzwej1atWqXRo0f79A8NDdXSpUsVEhLibTt27FiFn/WFF15QWFiY3n33XYWHh0u6sJTD6XRq8eLFevDBB9W4cWN9/fXX6tixoyZNmuQd26dPH79+nwDgL3ZdAIAr7OjRo5o6dap69+6tX/ziF7rppps0atQoSVJubm614z/55BNZLBbdfffdcrvd3q9mzZrphhtu0I4dOyRdCMROp1ODBg3yGd+1a1fFxMT4tOXk5KhDhw7ekFtuyJAhMgxDOTk5Pu39+vXzCbmVKS0tVU5OjpKSkmS3231qTUxMVGlpqXbt2iVJio+P1759+5SRkaFt27bp3Llz1f4eAKCmmNEFgBpq0qSJHA5HpTOalzp//rxGjBih0NBQPfroo2rXrp3sdrtOnDihiRMnqqSkpNpjnD59WoZhqFevXpU+X75Gt3w7s2uuuaZCn/LZ4nIFBQUVwq/041KJS7dGi46OrrbOgoICud1urVixwmct8MXOnDkjSRo/frwaNWqkP//5z1q1apWsVqu6d++utLQ0xcfHV/u9AMAfBF0AqCGr1aoePXpo27ZtOnHihFq2bFll35ycHH3//fdasWKFfvWrX3nba7IWtUmTJrJYLFq5cqXP7g7lytuioqIkXQjGlzp16pRPsI2KilJeXl6Fft9//733e17MYrFUW2dkZKSsVqvuuecejRgxotI+5cs9goODNXbsWI0dO1aFhYX64osvlJmZqd/97nf69NNP5XA4qv1+AFAdli4AQC2MHz9ehmHo6aefltPprPC8y+XSli1bvAHx0oC6atWqCmPK+1w6y3v77bfLMAydPHlS8fHxFb46deokSerSpYtsNps2bNjgM37Xrl367rvvfNp69uypAwcO6J///KdPe3Z2tiwWixISEvz5NfhwOBxKSEjQ3r171alTp0prvTRASxcC8sCBAzVixAgVFBRUqBUAaosZXQCohW7duikjI0MzZ87U/fffr5SUFMXFxcntdmvv3r1as2aN4uLiNHv2bDVu3FjPPvusJk6cqODgYH344YeV3hSiY8eOkqSsrCwlJiYqKChInTp10i233KJhw4bpySef1J49e3TrrbfK4XAoLy9PX331lTp27KgRI0YoKipKY8eO1aJFixQZGenddWHBggWKjo72mZUdM2aMsrOzNX78eE2ePFnXXXedPv30U73zzjsaPny4z4VoNfHUU09pxIgRGjlypIYPH66YmBidP39eR44c0ZYtW7y7TEyYMEFxcXH65S9/qaZNm+q7777T8uXLFRMTU+WODgBQUwRdAKilBx54QJ07d9Zbb72lJUuWKC8vTyEhIWrXrp2Sk5M1atQoNWnSRIsWLdJLL72kadOmyeFwqH///srMzNR9993nc7zk5GR9/fXXeuedd7RgwQIZhuHdR3fWrFnq0qWLVq9erXfffVdlZWVq3ry5br75Zp8LyqZMmSKHw6FVq1bp/fffV2xsrDIyMpSZmanIyEhvv6ZNm2rVqlV65ZVX9Morr+j8+fNq1aqVpk2b5rOzQ0116NBB77//vt544w3NmzdP+fn5ioiIUNu2bdW3b19vv4SEBG3atEnvvfeezp07p+joaPXq1UupqanVXvQGAP7ihhEAEOCOHj2qQYMGaeLEiZowYYLZ5QBAvWFGFwACyL59+7R+/Xp169ZN4eHhOnTokJYsWaLw8HANHTrU7PIAoF4RdAEggDgcDu3Zs0dr165VUVGRwsPDlZCQoEcffbTCFmMAEOhYugAAAICAxPZiAAAACEgEXQAAAAQkgi4AAAACEkEXAAAAAYmgCwAAgIBE0AUAAEBAIugCAAAgIBF0AQAAEJD+P9DBl9iKbIf5AAAAAElFTkSuQmCC",
      "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": 58,
   "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": 59,
   "metadata": {
    "executionInfo": {
     "elapsed": 18,
     "status": "ok",
     "timestamp": 1695329438384,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "p84O3JV6tRdP",
    "tags": []
   },
   "outputs": [],
   "source": [
    "#ORIGINAL EMOTION LABELS\n",
    "positive_word_meaning_sentences = ['the feeling that you have when you enjoy something that is funny',#amusement\n",
    "                                   'the state of feeling or showing happiness and enthusiasm',#excitement\n",
    "                                   'a feeling of great happiness',#joy\n",
    "                                   'a very strong feeling of liking and caring for somebody/something, especially a member of your family or a friend',#love\n",
    "                                   'a strong wish to have or do something',#desire\n",
    "                                   'a feeling that good things will happen and that something will be successful',#optimism\n",
    "                                   'kind, helpful and showing that you care about other people',#caring\n",
    "                                   'a feeling of being pleased or satisfied that you get when you or people who are connected with you have done something well or own something that other people admire',#pride\n",
    "                                   'a feeling of respect for and approval of somebody/something',#admiration\n",
    "                                   'the feeling of being grateful and wanting to express your thanks',#gratitude\n",
    "                                   'the feeling of happiness that you have when something unpleasant stops or does not happen',#relief\n",
    "                                   'the feeling that somebody/something is good or acceptable; a positive opinion of somebody/something',#approval\n",
    "]\n",
    "\n",
    "negative_word_meaning_sentences = ['the bad feeling that you have when you are in danger or when a particular thing frightens you',#fear\n",
    "                                   'the feeling of being anxious about something or afraid of something',#nervousness\n",
    "                                   'the feeling of being extremely sorry for something wrong or bad that you have done',#remorse\n",
    "                                   'shy, uncomfortable or guilty feelings; a feeling of being embarrassed',#embarrassment\n",
    "                                   'the feeling of being sad because something has not happened or been as good, successful, etc. as you expected or hoped',#disappointment\n",
    "                                   'the feeling of being sad',#sadness\n",
    "                                   'a very sad feeling, especially when somebody dies',#grief\n",
    "                                   'a strong feeling of dislike for somebody/something that you feel is unacceptable, or for something that looks, smells, etc. unpleasant',#disgust\n",
    "                                   'the strong feeling that you have when something has happened that you think is bad and unfair',#anger\n",
    "                                   'the feeling of being slightly angry',#annoyance\n",
    "                                   'a feeling that you do not like an idea, an action or somebody’s behaviour because you think it is bad, not suitable or going to have a bad effect on somebody else',#disapproval\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {
    "executionInfo": {
     "elapsed": 16,
     "status": "ok",
     "timestamp": 1695329438385,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "Ppy-K6l2gWtd",
    "tags": []
   },
   "outputs": [],
   "source": [
    "from IPython.display import clear_output"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {
    "executionInfo": {
     "elapsed": 38794,
     "status": "ok",
     "timestamp": 1695329477164,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "_OCeDQY6gHMj",
    "tags": []
   },
   "outputs": [],
   "source": [
    "new_positive_word_meaning_sentences = []\n",
    "\n",
    "for i in positive_word_meaning_sentences:\n",
    "  para_phrases = parrot.augment(input_phrase=i, max_return_phrases = 10)\n",
    "  temp = list(list(zip(*para_phrases))[0])[0]\n",
    "  new_positive_word_meaning_sentences.append(temp)\n",
    "\n",
    "\n",
    "new_negative_word_meaning_sentences = []\n",
    "\n",
    "for i in negative_word_meaning_sentences:\n",
    "  para_phrases = parrot.augment(input_phrase=i, max_return_phrases = 10)\n",
    "  temp = list(list(zip(*para_phrases))[0])[0]\n",
    "  new_negative_word_meaning_sentences.append(temp)\n",
    "\n",
    "\n",
    "clear_output()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "oEdEBFPQiasC"
   },
   "source": [
    "Paraphrased Native Injection Accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 30045,
     "status": "ok",
     "timestamp": 1695329507205,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "uEuhYVF-gMqC",
    "outputId": "3c4d554a-9320-4704-990c-0a6f0b392083",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.8256410256410256\n",
      "F1-Macro:  0.8075598022159112\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)), dim=0)\n",
    "\n",
    "for i in new_negative_word_meaning_sentences:\n",
    "  n_emb = torch.cat((n_emb,get_cls(i)), 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": 63,
   "metadata": {
    "executionInfo": {
     "elapsed": 13,
     "status": "ok",
     "timestamp": 1695329507206,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "2qBYfr3zgvAs",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import random\n",
    "random.seed(42)\n",
    "\n",
    "inputNumbers = range(0,10000)\n",
    "random_seeds = random.sample(inputNumbers, 300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {
    "executionInfo": {
     "elapsed": 11,
     "status": "ok",
     "timestamp": 1695329507206,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "nysMxY5myqsd",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "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": 65,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "JuMwkV_v4GvV",
    "outputId": "24e92f01-d79f-4514-f879-14a50b1f8477",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Working ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... "
     ]
    }
   ],
   "source": [
    "f1s = []\n",
    "accuracy = []\n",
    "p_word_list = []\n",
    "n_word_list = []\n",
    "\n",
    "print(\"Working\", end=' ')\n",
    "for i in range(300):\n",
    "    #SELECT RANDOM WORDS FROM NEUTRAL SENTIWORD\n",
    "    df_neutral = df_senti[df_senti['Sentiment']=='Neutral'].sample(n=20, random_state=random_seeds[i])\n",
    "    neutral_words = list(df_neutral[\"Word\"])\n",
    "\n",
    "    #FETCH DEFINITIONS OF THOSE WORDS\n",
    "    neutral_word_meaning_sentences = []\n",
    "    for i in neutral_words:\n",
    "        a = list(df_senti.loc[df_senti['Word'] == i, 'Definition'])[0]\n",
    "        neutral_word_meaning_sentences.append(a)\n",
    "\n",
    "    #MAKE EMBEDDING OF THESE DEFINITIONS\n",
    "    neutral_p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "    neutral_n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "\n",
    "    for i in neutral_word_meaning_sentences[0:10]:\n",
    "      neutral_p_emb = torch.cat((neutral_p_emb,get_cls(i)), 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)), 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": 66,
   "metadata": {
    "executionInfo": {
     "elapsed": 13,
     "status": "ok",
     "timestamp": 1695379584055,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "36UtUdOcDjLK",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import statistics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 245
    },
    "executionInfo": {
     "elapsed": 13,
     "status": "error",
     "timestamp": 1695379584056,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "N_1_hH8S4Hit",
    "outputId": "85d5684e-8de1-402e-9386-f53b050bd477",
    "tags": []
   },
   "outputs": [],
   "source": [
    "stdv = statistics.pstdev(f1s)\n",
    "median = statistics.median(f1s)\n",
    "#filters = [i>median+(2*stdv) for i in f1s]\n",
    "filters = [i>.5 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": 68,
   "metadata": {
    "executionInfo": {
     "elapsed": 19,
     "status": "ok",
     "timestamp": 1695379585268,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "mmW3cTd4o6Hb",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 175
    },
    "executionInfo": {
     "elapsed": 17,
     "status": "error",
     "timestamp": 1695379585269,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "_sc9N6PqFDAF",
    "outputId": "86645206-6fd6-4dcd-eb48-1555f0dcda27",
    "tags": []
   },
   "outputs": [],
   "source": [
    "(hist, bin_edges) = np.histogram(f1s,bins=15)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "metadata": {
    "executionInfo": {
     "elapsed": 15,
     "status": "aborted",
     "timestamp": 1695379585271,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "uMGPmojj4SeF",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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Q9S4cWM99NBDqlevniIjI/X1119r+vTpysnJ8atm1apV1a1bN61bt04TJ06U3W7X2rVr1apVKzVt2lSSdOLECeXn5+uVV17RK6+84nU7x48fL3ZN42Fs/PjxatmypRISEhQVFaWdO3dq6dKlSkhIUPfu3XXgwAFNmTJFqampatiwoU6ePKmVK1fq22+/1cKFC023DwAAgsRms2nSpEm6/fbb9cYbbxRa9sEHHygrK0sLFy4sdPWFQHwCs3///tqwYYM+++wzXX755frmm2/02GOPeZbHxsbKbrerb9++uu2227xu40I7lLwxHsZatWqld955R4sXL5ZlWapXr55uueUWjRw5Uk6nUxUrVlSlSpWUlpamY8eOyeFwqGXLllqyZIk6depkun0AABBE11xzjTp27Ki0tLRCl6Cw2WyS5Dm0KZ09henXoe3cOr7sKbv22mtVp04drVmzRnXr1lVkZGShC9RHR0erXbt2+u6775SQkFCoB38YD2OjR4/W6NGjL7i8atWqeu6550LYEQAAKE0mTZqk/v376+jRo2rQoIGksyHN4XDovvvu05133imXy6WVK1cqMzOzyOObNWumjRs36rXXXlPLli1ls9kuem9qu92ufv36admyZapUqZJ69OjhuV/2OX/84x912223aciQIbr11ltVr149nTlzRhkZGfroo48ueJFZb4yHMQAAgItJSkpS7969tX79es+8uLg4LVy4UM8++6zuueceVa1aVampqRoxYoRGjRpV6PG///3v9cMPP2jevHk6deqULMvyXGfsQvr3768XXnhBx44d04ABA4osj4+P15o1a7Ro0SI9++yzOnbsmCpXrqwrrrii2Cfun0MYAwAARtgiIlTjmg6e6f79+3s+sfhrc+fO1dy5c/XNN9945nXt2lVdu3Ytsu6vg1aVKlW0YMECr9u9UChr1KjRJQNb/fr19cQTT1x0neIgjAEAACMinE41f3CS6TaMI4wBfuh5003af+hQyOteUbu2Nq5dG/K6AIDgIYwBfth/6JC+79kz9IU3bgx9TQBAUEVcehUAAIDAK8jJ0Wd9B+izvgNU4OdFWssDwhgAAIBBhDEAAACDCGMAAAAGEcYAAAAMIowBAAAYRBgDAAAwiOuMAQAAI2wREar2m7ae6XBFGAMAAEZEOJ1KeuSPptswLnxjKAAAQClAGAMAADCI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AAAGEcYAAAAMIowBAAAYRBgDAAAwiDAGAABgENcZAwAARkRERurq5S95psMVYQwAABhhs9nkqFLFdBvGcZgSAADAIPaMAQAAI9x5edr74l8kSY1HjuB2SAAAAKFkFRTov+9u0H/f3RDWt0NizxiAUuun/fuV0LFjwLdrud3KdbkU6XTKFlH0b9IratfWxrVrA14XALwhjAEotfJsNn3fs2foC2/cGPqaAMIWhykBAAAMIowBAAAYRBgDAAAwiDAGAABgECfwAwAAIyKcTv1m8XOe6XBFGAMAAEbYIiIUVae26TaM4zAlAACAQewZAwAARrjz8rT/1dckSVcMvS1sb4dEGEOZdu4K7Ze6onrA6x44EPQaAFDeWQUF+nnd3yRJDW8dJBHGgLLH1BXaHUuXhrwmAKB84pwxAAAAgwhjAAAABvkcxg4fPhyMPgAAAMKSz2Gsa9euuu+++/TFF18Eox8AAICw4nMYGzNmjP7zn/9o6NCh6tu3r958803l5OQEozcAAIByz+cwNn78eH388ceaO3euKlWqpIcfflhdunTRU089pYyMjGD0CAAAyqEIp1MpC+cpZeG8sL4dkl8n8Nvtdt1www1asWKF1q1bp549e+r1119Xr169dNddd+nTTz8NdJ8AAKCcsUVEKKZhQ8U0bBiSa0SWViV+5gkJCercubOaNm0qt9utzZs3a/To0erfv7/27t0biB4BAADKLb/D2LFjx/TCCy/ouuuu04QJE2S32zVv3jx98cUXSktL05kzZzR16tRA9goAAMoRd16eMlauUsbKVXLn5Zluxxifr8C/bds2rVixQhs2bJBlWbrhhhv0+9//Xi1atPCs061bN9ntdo0bNy6gzZYlPW+6SfsPHQr4di91258ratfWxrVrA14XAIBAswoK9OPrb0iS6t3Ul9shFdegQYNUs2ZNjR49Wrfeeqtq1Kjhdb369esrJSWlxA2WVfsPHTJymx5t3Bj6mgAAwG8+h7GnnnpKN9xwgxyXSK9xcXF65ZVX/G4MAAAgHPgcxvr27RuMPgAAAMKSzyfwL168WI8//rjXZY8//rhefPHFEjcFAAAQLnwOY+vWrVPTpk29LmvevLnWrVvn0/beffddjR07Vl26dFGbNm3Up08fvfbaa3K73YXW27Rpk/r166fk5GT16NFDK1as8LV1AACAUsfnw5Q///yzGjVq5HVZw4YN9dNPP/m0vWXLlunyyy/X5MmTVaNGDX3++eeaOXOmfvzxRz344IOSpK1bt2rs2LHq27evpkyZoi+//FIzZsyQ0+nUzTff7OtTAAAAKDV8DmMVKlTQsWPHvC47evSobDabT9t7/vnnVb16dc/X7du3V1ZWllasWKF7771XTqdTaWlpSkpK0hNPPOFZ55dfftH8+fM1YMAARYTxVXsBACirIhwOtZrzlGc6XPmcYlq2bKk33njD67I33nhDLVu29Gl75wexcxITE5Wbm6sTJ07I5XJpy5Yt6t27d6F1+vTpo8OHD+u7777zqR4AACgdbHa7KjeNV+Wm8bLZ7abbMcbnPWN33HGH7rrrLg0bNky33nqr6tSpo4MHD2rlypX6z3/+o8WLF5e4qS+++EJVq1ZVjRo1tHfvXuXl5alJkyaF1omPj5ck7d692+cAeI5lWcrKyipxv163/atz3kLFcruD9pwuVdcIy6IudQNfNszeR+eeb3Z2tiR5/sdZjIt3psbFsiyfj8KVdj6Hsc6dO2v69Ol66qmndN9998lms8myLFWuXFmPP/64OnXqVKKGvvnmG61Zs0bjxo2T3W7XyZMnJUmxsbGF1jv39bnl/sjLy9OOHTv8b/Yicl2uoGy3OHWD9ZwuVdcEQxGBuuW8bri9j379fPft22ekj9KOcfGuJONiFRSo4PN/S5Ls7a4q9t4xp9Ppd83SyOcwJkk333yzevfura1bt+rYsWOqXr26UlJSFBMTU6JmDh8+rAkTJig5OVmjRo0qtOxCKbgk6djhcHj2sAVapKEXSqTTqcTERCN1TTD1txF1y3fdcHsfnXu+2dnZ2rdvnxo1aqTo6GgjvZRGjIt3gRiXgpwcfT3z7DljSUNulT0q6pKPSU9P96tWaeZXGJOkmJgYdezYMWCNnDp1SqNGjVJUVJSee+45zxX+q1SpIqnoHrDMzExJRfeY+cJms5U4QF5w24Y+VGCLiAjac7pUXSNM7aqmbrmuG27vo18/3+joaCPPv7RjXLwrybgUnPeaj4mJKVYYK2+HKCU/w5hlWfrmm2904MAB5ebmFlner18/n7aXm5uru+++W0eOHNGqVatUrVo1z7KGDRvK4XBoz5496ty5s2f+uWQcFxfnz1MAAAAoFXwOY3v37tXdd9+t/fv3y/Jycq3NZvMpjOXn52vixInauXOnXn31VdWrV6/QcqfTqfbt2+vdd9/ViBEjPPPXr1+vWrVqKSkpydenAAAAUGr4HMamT58ul8ulefPmKSEhocQn0U2fPl0ff/yxHnjgAeXk5Oirr77yLIuPj1elSpU0btw4DR06VNOmTVOfPn305Zdf6s0339T06dO5xhgAACjTfA5jX3/9tR5//HH16tUrIA384x//kCQ9/fTTRZYtX75c7dq1U0pKihYtWqRnnnlG69at02WXXaZp06Zx9X0AAFDm+RzGYmJiVKlSpYA18NFHHxVrvS5duqhLly4BqwsAAFAa+BzG+vfvr/Xr1xc6mR4AAMBXEQ6HWs74k2c6XPkcxpo1a6b/+7//05gxY9StWzdVrVq1yDo9e/YMSHMAAKD8stntqpLs3110yhOfw9j9998vSfrpp5/097//vchym81m5MrVAAAAZZHPYWz58uXB6AMAAIQZd36+Dr73viSpzvU9FFHB72vRl2k+P+urr746GH0AAIAwY+Xna8/ipZKk2td1lQhjvjl16pS++uorHT9+XF26dPHctggAAADF51cYS0tL05IlS5STkyObzaa33npLVapU0fDhw9WxY0eNHj060H0CAACUSz5fvn7FihVKS0vTwIED9cILLxS6JVLXrl29ntQPAAAA73zeM7ZixQqNGDFCkydPVkFBQaFlV1xxhfbv3x+w5gAAAMo7n/eM/fjjj+rUqZPXZRUrVlRmZmaJmwIAAAgXPoexypUr68iRI16XHThwQDVq1ChxUwAAAOHC58OUHTp00NKlS3XdddcpMjJS0tkLvebn52vlypW69tprA94kAAAofyIcDiU+/JBnOlz5HMYmTJiggQMHqnfv3urevbtsNpteffVV7dixQz///LOeffbZYPQJAADKGZvdrupX/sZ0G8b5HMauuOIKrVy5UrNmzdLKlStlWZb++te/ql27dpozZ44uv/zyYPQJACHz0/79SujYMfR1DxwIeU0A5vl1nbH4+Hi9+OKLcrlcOn78uKpUqaKoqKhA9wYARuTZbPq+Z8+Q13UsXRrymoBJ7vx8Hd70iSSpVpfO3A7JH06nU3Xq1AlULwAAIIxY+flKX5AmSarZ8Rpuh1Rcf/7zny+63Gazady4cX43BAAAEE4IYwAAAAb5HMZ27txZZN6JEyf0wQcf6OWXX9bixYsD0hgAAEA48Pmir95U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MQAAYIQ9Kkod3njNdBvGcZgSAADAIMIYAACAQRymBAAARrhdLu188mlJUvMpDyjC6TTckRmEMQAAYITlduv4F196psMVhykBAAAMKjNhbO/evRo5cqTatGmjDh06aMaMGcrJyTHdFgAAQImUicOUmZmZGj58uC6//HItWLBAx44d06xZs3TixAnNmTPHdHsAAAB+KxNh7PXXX1dmZqbWrVun6tWrS5LsdrsmTZqku+++W3FxcYY7BAAA8E+ZOEz5ySefqEOHDp4gJknXX3+9nE6nNm3aZLAzAACAkrFZlmWZbuJSOnTooAEDBmjSpEmF5vfu3Vtt2rTRzJkzfd7ml19+Kcuy5HA4AtVmIT/98ovyoqODsu2LsZ06JatyZepSl7rUpW4prB1udR3Z2apft+6FV7As5R4+LEmKrFVLstkuuc28vDzZbDa1bds2UG0aVyYOU2ZmZio2NrbI/NjYWJ08edKvbdr+9w23FeMb748Gl18elO1eUrVq1KUudalL3dJam7qF2WyKqlPHp03abLag/e42pUyEsQuxLMvvb0hKSkqAuwEAAPBdmThnLDY2VpmZmUXmnzp1yuseMwAAgLKiTISxuLg47d69u9A8l8uljIwMPkkJAADKtDIRxjp37qwtW7bo+PHjnnnvv/++XC6XunTpYrAzAACAkikTn6bMzMxUamqq6tWrp7Fjx+ro0aN68sknde2113LRVwAAUKaViTAmnb0d0owZM/TFF18oKipKqampmjRpkqKioky3BgAA4LcyE8YAAADKozJxzhgAAEB5RRgDAAAwiDAGAABgEGEMAADAIMIYAACAQYQxAAAAgwhjpcTevXs1cuRItWnTRh06dNCMGTOUk5Nz0cecPn1aCxcu1M0336wrr7xS7du318iRI7V9+/YQdR0a/oyNJD399NPq3bu3UlJS1LZtWw0YMED/93//F4KOQ8PfcTnf+++/r4SEBKWmpgapy9Dzd1yGDRumhISEIv9+fSu2sqokr5cTJ07oscce07XXXqvk5GRdf/31ev3114PccWj4My4//fST19dKQkKCWrZsGaLOg8vf10tWVpbmzJmj7t27q3Xr1urZs6cWLlwol8sVgq7LrgqmG8DZOwwMHz5cl19+uRYsWKBjx45p1qxZOnHixEXvMPDzzz9r1apVGjBggCZMmKD8/HwtX75cgwcP1uuv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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.825  # 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",
    "plt.xlabel(\"F1-Macro\")\n",
    "plt.ylabel(\"frequency\")\n",
    "\n",
    "#plt.title(\"bert-base\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_neutral = df_senti[df_senti['Sentiment']=='Neutral'].sample(n=20, random_state=random_seeds[6])\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": 72,
   "metadata": {
    "executionInfo": {
     "elapsed": 33,
     "status": "aborted",
     "timestamp": 1695329093833,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "-nnwzm980k1q",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.2611439842209073\n",
      "F1-Macro:  0.2532050280569619\n"
     ]
    }
   ],
   "source": [
    "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)), dim=0)\n",
    "\n",
    "for i in neutral_word_meaning_sentences[10:20]:\n",
    "  n_emb = torch.cat((n_emb,get_cls(i)), 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": 73,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093833,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "7cdh2kXd0-Zb",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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OADAcekHP/iBrr/++rrH+/bti7hdZWWlKisr1a5du9YqDUCCMKILAICkfv36RWzv0aMHIRdIUQRdAAAk3XDDDerYsWNYm91u17Rp0yyqCEC8CLoAAEjq1q2bnnzySV177bWy2+1yOBx6+OGHNWTIEKtLAxAjgi4AAN868cQTdfPNN6tNmzZyu93q3bu31SUBiANBFwAAAGmJoAsAAIC0RNAFAOBbR44c0dNPP63q6mrV1NTo66+/trokAHEg6AIAIOnAgQMaM2aM5s6dK7/fL5/Pp+uvv14bNmywujQAMSLoAgAg6bHHHtP27dvD2qqqqjRnzhyLKgIQL4IuAACS1q1bF7F98+bNOnToUCtXAyARuAUwAKDVmaapmpoaq8sI06ZNm4jtTqdToVBI1dXVrVxR41wulwzDsLoMIOkRdAEAra6mpkb5+flWlxHG5/NFbDdNU6NGjWrlapq2cuVKud1uq8sAkh5TFwAA0NGRW6fTGdaWkZEhl8tlUUUA4sWILgDAUsGRwaT5aeSQQ/ZKu4K7grK1t8neya6QQlaXdVRAsi+3W10FkFKS5NQCADhuZShpfhr5t/rl+9An1UiySxk/zJBzoFOGnfmwQCpi6gIAAJICOwLy/fPbkCtJQSmwNSDf+5Hn7gJIfgRdAAAkBbYEIrd/GpAZNFu5GgCJQNAFAEBSqLKRubj+b/8BSDkEXQAAJNlPinyhl9HOkOFiji6Qigi6AABIcpztkL6/kpghOc91RtweQPJLkutcAQCwli3bJvcot/yb/ArtC8loa8jR2yF7F5b0AlIVQRcx2717tx577DFVVFTIZrOptLRU/fr1s7osAIiZra1NmednWl0GgARh6gJismvXLo0ePVqPPvqofD6fampqdP3112v16tVWlwYAcTNDrLIApAOCLmLyyCOPaO/evWFtgUBAc+bMsagiAIhfYEdA1SXVqvpHlar+vyr5N/plmoReIFURdBGT999/P2L7Z599poqKilauBgDiF/wmqNrXahXaf3SZMbPKlO9fPvk/YW0xIFURdBGTTp06RWzPyspSmzZtWrkaAIiff5NfijB469/kZyoDkKIIuojJddddF7F99OjRcjpZigdA6gkdauSGETWSuAswkJIIuojJT3/6U82YMUMnnHBCXdsVV1yh2267zcKqACB2to6RfyQabQyJhRiAlETQRczG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/9NjcGQwCX4apYDAf0a/mdIGRCcpTi05OTlauHBhk9sUFxeruLi47vGpp556zD4AgBSQoST5aQQg3Vg+dQEAAABoCQRdAAAApCWCLgAAANISQRcAAABpiaALAACAtETQBQAAQFoi6AIAACAtEXQBAACQlgi6AAAASEsEXQAAAKQlgi4AAADSEkEXAAAAaYmgCwAAgLRE0AUAAEBayoilU1VVlf71r3/pww8/1O7du1VTU6P27durZ8+eGjhwoE4//fRE1wkAAAA0S7OC7hdffKFHH31UK1asUFVVlQzDkMfjkdPplNfrVW1trQzD0A9/+EONHTtWV155pWw2Bo0BAADQ+qIOunfddZeefPJJ5eTkaNKkSRowYIB69+6tjIz/7GLPnj366KOP9Nprr+lPf/qTHnvsMc2ePVt9+vRpkeIBAACAxkQddLds2aJ//OMfOu+88xrdpkuXLho2bJiGDRumI0eO6LHHHtOHH35I0AUAAECrizroLlmypFk7btu2raZMmdLsggAAAIBESPgE2t27d2vLli2J3i0AAADQLDGturBr165Gn3v11Vf10EMPad26dTEXBQAAAMQrpqB78cUXyzCMRp/PycmJuSAAAAAgEWIKunfddVeDoFtVVaX3339fr7/+uoqLixNSHAAAABCrmILulVdeGbF9zJgxKi4u1j333KPFixfHVRgAAAAQj4RfjDZkyBB98sknid4tAAAA0CwJD7oVFRXq2LFjoncLAAAANEtMUxciCYVCKi0t1d/+9jdNmzYtUbsFAAAAYhJT0O3Vq1ejqy6Ypqnbb79dt99+uyTJMAzW1QUAAECriynoTp48ucnlxQAAAACrxRR0p06dmug6AAAAgIRK+MVoAAAAQDKIOujeeeed2rt3b7N2/uqrr2rZsmXNLgoAAACIV9RTF7Zt26ZLLrlEP/3pTzVq1Cide+65crvdDbbbvn27Xn/9dT3//PPavXu35syZk9CCAQAAgGhEHXQXLVqk1157TQ8//LBuuukmZWRk6NRTT1WHDh2UmZmpQ4cO6csvv9ShQ4fkdrt15ZVXauLEiaypCwAAAEs062K0Sy65RJdccom2bNmiN998Ux9//LH27NmjvXv3qn379ho6dKgGDBigoUOHqm3bti1VMwAAAHBMMa260Lt3b/Xu3TvRtQAAAAAJw6oLAAAAFggEAgqFQjJN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J5Wbm5voWgEAAGLmlORMqkiZrMxjb5IiYgq6c+fOVbt27bR48WKddNJJde3ffPONxo0bp7/+9a+6//77E1YkAAAA0FwxzdF97733NHXq1LCQK0knnXSSJk2apHfffTchxQEAAACxiinoVldXq127dhGfa9++fdIukQEAAIDjR0xTF3JycrR8+XINHjy4wXMvvviievToEXdhaETQb3UFqYGvEwAAx72Ygu7YsWM1c+ZMHT58WFdccYU6d+6svXv3atmyZXrjjTdUVFSU6DqPa6b5n0nhbTY8aWElqan+1w8AABw/Ygq6V111lfbv368FCxZo9erVko6GCZfLpVtuuUWjR49OaJEAAABAc8W8ju6vfvUrXXfdddqwYYMOHjyodu3aqV+/fsrOzk5kfZDCbr1X2e86ye6wsJoUEfTXjX6n8q0LAQBA7GIOupKUnZ0dcZ4uWpDdQdAFAACIQkyrLjz33HONrpN7//33q6SkJK6iAAAAgHjFFHQXL14sj8cT8bn27dvr8ccfj6soAAAAIF4xBd3t27frhz/8YcTncnNztX379riKAgAAAOIVU9CVpMOHD0dsP3LkiILBYMwFAQAAAIkQU9A944wz9OKLL0Z8bsWKFY2O9gIAAACtJaagO2bMGK1cuVLTp0/Xxx9/rN27d+vjjz/W7bffrldffVXXX399ousEAAAAmiWm5cVGjhypzz//XA8//LCWLVsm6egNI+x2uyZOnKif//znCS0SAAAAaK6Y19GdNm2aRo8erXfeeUcVFRXq0KGDBg0apG7duiWyPgCQJJWVlWnjxo3q2rWrBgwYwI1AAADHFNcNI0455RTl5+fr73//uzZs2KBNmzbpv//7v9WzZ89E1QfgOBcMBjVjxgytWLGirq1Xr17629/+ps6dO1tYGQAg2UUddP/85z/r5Zdf1ltvvVXXVlVVpauuukpfffWVTNOUJL344ot65pln1KNHj4QXCyC1mKapmpqauPaxdOnSsJArSaWlpfrjH/+ou+++O659u1wuRoYBII1FHXQ3bNigyy67LKxtyZIl2rlzp2644QZNmTJFZWVlmjp1qh555BHNnj074cUCSB2maWry5MnatGlTXPs5dOhQxPY33nhDw4YNiyuo9unTR/PnzyfsAkCainrVhS+//FI/+tGPwtrefPNNdejQQbfeeqvatm2rvn376sYb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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": 74,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093833,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "1MTPlFIVEd6y",
    "tags": []
   },
   "outputs": [],
   "source": [
    "#len(positive_word_meaning_sentences)\n",
    "#len(neutral_word_meaning_sentences[0:11])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093834,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "J3ymzSst9jH9",
    "tags": []
   },
   "outputs": [],
   "source": [
    "p_spurious_sentences = [list(df_senti[df_senti['Word'] == i]['Definition'])[0] for i in p_words_spurious[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": 76,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093834,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "AoDiCBpM6glm",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.6260355029585799\n",
      "F1-Macro:  0.6189981364126684\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAroAAAISCAYAAAAjsmyaAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAPYQAAD2EBqD+naQAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nOzdfXxT9d3/8ffJXZNCM1pudIBoLU4EUUARq5fgRC0TGCpuY6JjDNmkrPrTddNxuamzk+q4xAHiDaJWuPbA+w50iigKzoFOBUEBuVpRHCq3bVNo06TJ+f2BVmpTSJO0Jwmv5+PBg0e+Oef00/abk3e/+Z7vMUzTNAUAAACkGZvVBQAAAADtgaALAACAtETQBQAAQFoi6AIAACAtEXQBAACQlgi6AAAASEsEXQAAAKQlh9UFJJN169bJNE05nU6rSwEAAEAEwWBQhmFo8ODBR9yWoHsI0zTF/TMAAACSV1uyGkH3EF+P5A4cONDiSgAAABDJxo0bo96WOboAAABISwRdAAAApCWCLgAAANISQRcAAABpiaALAACAtETQBQAAQFoi6AIAACAtEXQBAACQlgi6AAAASEsEXQAAAKQlgi4AAADSEkEXAAAAaSkpgu62bds0ZcoUDRo0SPn5+SopKZHf7z/ifnV1dZo1a5YuvPBCnX766br44os1d+5cBQKBDqgaAAAAycxhdQE+n0+TJk1Sz549NWfOHO3bt08zZ85UdXW1Zs2addh9b7vtNr3yyiu64YYbdNJJJ2nDhg2aM2eOampqdMstt3TQdwAAAIBkZHnQXbJkiXw+n8rLy5WTkyNJstvtKi4u1rRp05SXlxdxv8bGRr300ku65pprdPXVV0uSzj77bH3++ef6xz/+QdAFAAA4ylk+dWH16tXKz89vCrmSVFBQIJfLpVWrVrW6n2maCoVCysrKatbu9Xplmma71QsAAIDUYHnQraysbDFq63K51KdPH1VWVra6n9Pp1OWXX65Fixbp/fff14EDB7R27Vo9+eSTmjhxYnuXDQAAgCRn+dQFn88nr9fbot3r9aqmpuaw+95222269dZb9eMf/7ip7eqrr9avf/3rmOsxTVN1dXUx7w8AAID2Y5qmDMOIalvLg25rovkmZs2apddff1133HGHcnNz9eGHH2rOnDnyer267rrrYvq6wWBQmzdvjmlfAEBqq6mp0WuvvaZt27apa9euuuCCC9S7d2+rywLwLS6XK6rtLA+6Xq9XPp+vRXttbW2rF6JJ0tatW/XII49o/vz5GjlypCRp6NChMgxDd999tyZOnKiuXbu2uR6n06m+ffu2eT8AQGrbtWuXbr75Zu3evbup7V//+pfuuusunX322RZWBuBQFRUVUW9redDNy8trMRc3EAho+/btGj9+fKv7ff1NnnLKKc3aTznlFDU2NmrHjh0xBV3DMJSZmdnm/QAA1jFNM6r11w9n8eLFzUKudPBTvvnz5ys/Pz+uY7vd7qg/agVweG15LVkedIcPH677779fVVVVys7OliStWLFCgUBAI0aMaHW/Xr16SZI+/PBD9ezZs6n9gw8+kCQ+agKAo4Rpmpo+fXrT+T9W+/fvj9heUVGhiy66SDZb7NdvDxw4UPPmzSPsAh3M8qA7YcIELV68WIWFhSosLNTevXtVWlqqsWPHNpu6MGPGDJWXl2vTpk2SpFNPPVWnnXaabr31Vu3Zs0e5ubnauHGj5s+fr0suuaTZcmUAgPSWiAB5uGMQUIHUZHnQ9Xq9KisrU0lJiYqKiuR2uzVmzBgVFxc32y4cDisUCjU9ttvteuCBB/TXv/5VCxYs0J49e/Td735XV111la699tqO/jYAABYxDEPz5s2Le+rCypUr9d///d8t2q+44gr95je/ievYTF0ArGGY3F2hycaNGyUd/IgJAHD0KSsr04IFC5qmMVxyySW69dZblZGRYXFlAL7Wlrxm+Q0jAABIFpMmTdKyZcvUqVMnde7cWX/4wx8IuUAKs3zqAlLfO++8o6VLlyoYDGrkyJEaOXIkH9EBSFlut1t2u93qMgAkAEEXcZk/f77++te/Nj1+9tlndemll+quu+6ysCoAAACC7lEpEetNStLOnTs1b968Fu3l5eX64Q9/qCFDhsR0XC7aAAAAiUDQPcokar1JSaqvr2+2EsahioqK1Llz55iOy3qTAAAgEbgY7SiUqADJmpMAACCZMaJ7lEnEepN1dXX67LPP1LVrV02YMEF79uxp9nxGRoaee+45de/ePabjM3UBAAAkAkH3KGQYhjweT0z73nfffVq4cKEOHDggl8ulESNGaOXKlU1TGLp166Y///nP6tOnTyJLBgAAaDOCLqL21FNPac6cOU2PA4GAVqxYoczMTGVkZGjWrFkaNmyYnE6nhVUCAAAcxBxdRG3JkiUR2+vr6+VyuXTGGWcQcgEAQNIg6CJqe/fujdhumqa4kzQAAEg2BF1EbejQoRHbnU4nF48BAICkQ9BF1AoLC5Wdnd2sze12x7xeLgAAQHviYjRELTc3V88995wWL16sLVu2KCsrS9XV1Xrrrbdkt9u1cuVKjR492uoyAQAAJBF00Ubf/e539dvf/lZbt27VT37yE9XV1UmSwuGwbrzxRvn9fo0fP97iKgEAAJi6gBgtWLCgKeQe6r777lM4HLagIgAAgOYIuojJ5s2bI7bv2LFD1dXVHVwNAABASwRdxKS1O59lZ2fL6/V2cDUAAAAtEXQRk8mTJ8tma9l9Jk2aJIeDqd8AAMB6JJIUYJqm/H6/1WU0c+qpp+qee+7RvHnzVFFRIZvNpmuvvVaTJk1SfX291eU143a7WecXQDM+n08PP/ywXn31VdlsNo0aNUq/+MUv5PF4rC4NQAIRdFOA3+9XQUGB1WW0qkePHjIMQ88884yeeeYZq8tpYfny5bx5AWgSCoV07bXXatOmTU1tCxYs0MaNG/XAAw9YWBmARGPqAuLGaCmAVLJ69epmIfdra9eu1fr16y2oCEB7YUQ3xRwYMlGyJdmvzTQP/p9MgTfcqE7v/a/VVQBIQlu3bm31uY8++kgnn3xyB1YDoD0lWWLCEdkckt1pdRUAkLJaWzVGko477jitWrVKfr9fNptNBw4cYOoTkMKYugAAOKqMHDlSxx13XIv2fv366YEHHtDNN9+sQCAgv9+vn/zkJ6qsrLSgSgCJQNAFABxVXC6XHn74YV188cVyOBzKyMjQ2LFjdfbZZ2vDhg3Ntt27d6/uuusuiyoFEC+mLgAAjjrHHHOM7r77boXDYRmGIcMwNGHChIjbvv3226qtrVVWVlYHVwkgXgRdAMBR69Ab3zidka9/sNvt3AgHSFFMXQAAQNIPfvCDiO3nn38+F6QBKYqgi8MyA/UKbPu3GjatVOOXW2V+vZTYV8L79yn4nw8V2vcfiyoEgMT48Y9/rFGjRjVrO+mkk3TzzTdbVBGAePFZDFoVqvlS9Wv+JgUO3tI3KMnWtY88Z0+QbA41vP+CGre/37S9rUtPeYb9WEZGJ4sqBoDYORwOlZaW6qqrrtI111wjm82msrIyZWZmWl0agBgxootWNbz/YlPI/Vp473YFt72rxk/ebRZyJSlc/bkaNi7vyBIBIOHy8vLkcrnkcDi48yOQ4hjRRURhf63C1Z9HfK7xi48kma0+ZzYGZDhc7VgdAADAkTGii4gMm7315+wOKdQY+UkzfPAfAACAxQi6iMhwZcre48SIzzl6D5D92JMiPmfr2keG092epQEAAESFoItWZZw+Wras7s3aHH0GyXHc6XLlnS3bd45tvoMrUxmnXtyBFQIAALSOObpolc3jlef8qQrt+URmvU/2nN6yde568Elnhjzn/VyNn29RuPpzGZnfkbP3QBku1poEAADJgaCLwzIMQ47uuZGfs9nl7D1A6j2gg6sCAAA4MqYuAAAAIC0RdAEAAJCWkmLqwrZt21RSUqJ3331XHo9Ho0ePVnFxsdzu1q/e/89//qORI0dGfM7pdOqDDz5or3IBAACQAiwPuj6fT5MmTVLPnj01Z84c7du3TzNnzlR1dbVmzZrV6n49evTQE0880azNNE1NnTpVw4YNa++yAQAAkOQsD7pLliyRz+dTeXm5cnJyJEl2u13FxcWaNm2a8vLyIu7ncrk0aNCgZm1vvfWWamtrNWbMmHavGwAAAMnN8jm6q1evVn5+flPIlaSCggK5XC6tWrWqTcd6/vnn1blzZ11wwQWJLhMAAAApxvIR3crKSo0fP75Zm8vlUp8+fVRZWRn1cYLBoF5++WVddNFFysjIiLke0zRVV1cX8/7twe/3W11CSquvr5dpmlaXASBFHHrO5fwBJB/TNGUYRlTbWh50fT6fvF5vi3av16uampqoj7N69WpVV1fHPW0hGAxq8+bNcR0j0RoaGqwuIaVt2bIlrj9+ABxdDj3ncv4AkpPL5YpqO8uDbmvaktYladmyZerWrZvy8/Pj+rpOp1N9+/aN6xiJxohufPr163fYFTwA4FCHnnM5fwDJp6KiIuptLQ+6Xq9XPp+vRXttbW2rF6J924EDB/T666/riiuukN1uj6sewzCUmZkZ1zESrS2BHy15PB55PNyaGEB0Dj3ncv4Akk9bcpHlF6Pl5eW1mIsbCAS0ffv2qIPuihUrVF9fr7Fjx7ZHiQAAAEhBlgfd4cOHa+3ataqqqmpqW7FihQKBgEaMGBHVMZ5//nn16dNHp59+enuVCQAAgBRjedCdMGGCsrKyVFhYqDfeeEPl5eW64447NHbs2GYjujNmzFD//v1b7L9v3z6tWbNGo0eP7siyAQAAkOSSYo5uWVmZSkpKVFRUJLfbrTFjxqi4uLjZduFwWKFQqMX+L774ohobG5m2AAAAgGYsD7qSlJubq4ULFx52m9LSUpWWlrZonzhxoiZOnNhepQEAACBFWT51AQAAAGgPBF0AAACkJYIuAAAA0hJBFwAAwAI+n0/r1q3TF198YXUpaSspLkYDAAA4mjz44IN6/PHH1dDQIMMwdP755+v2229PuruzpjqCLgAAQJRM05Tf74/rGC+//LIWLFjQ7JivvfaaOnfurN/97ndxHdvtdrfpFrnpjqALAAAQBdM0NX36dH3wwQdxHae1oLxs2TK98sorcQXVgQMHat68eYTdrzBHFwAAIEqJCJCmaSagEkSDEV0AAIAoGIahefPmxT11Ye7cuXryySdbtJ988sl6+OGH4zo2UxeaI+gCAABEyTAMeTyeuI4xZcoUvfnmm9qxY0dTm9vt1o033hj3sdEcUxcAAAA6UNeuXbVo0SJNmzZNdrtdDodDjz76qM444wyrS0s7BF0AAIAO5vV6deWVVyojI0Mul0u9e/e2uqS0RNAFAABAWiLoAgAAIC0RdAEAAJCWCLoAAABISwRdAAAApCWCLgAAANISQRcAAABpiaALAACAtETQBQAAQFoi6AIAACAtEXQBAACQlgi6AAAAFmhoaFA4HJZpmlaXkrYIugAAAB3sf//3f3XZZZfJ7/ervr5epaWlamhosLqstEPQBQAA6ECvvvqqZs+erdra2qa2F154QXPmzLGwqvRE0AUAAOhAzzzzTMT2pUuXKhAIdHA16Y2gCwAA0IH27t0bsb2+vl51dXUdXE16I+gCAAB0oCFDhkRs79u3r7p06dLB1aQ3gi4AAEAHmjRpkrp3796szeFw6LrrrrOoovRF0AUAAOhAxx57rBYtWqSf/exnstlsstvtWrBggc455xyrS0s7BF0AAIAO1q1bN02dOlVut1sZGRnq27ev1SWlJYIuAAAA0pLD6gLQRqGg1RWkBn5OAAAc9Qi6KeDQWwN2Wvc3CytJTdxaEQCAoxNBFwDQ4UzTlN/vt7qMiA6tK1lrdLvdMgzD6jKApEfQTQGHnswODL5SsjstrCZFhIJNo9+8GQDJx+/3q6CgwOoyjmjcuHFWlxDR8uXL5fF4rC4DSHoE3VRjdxJ0AQAAokDQBQBYKjQ2lHzvRl9P7U+mD4QaJfsyu9VVACklKU4t27ZtU0lJid599115PB6NHj1axcXFcrvdR9y3urpa9957r1555RXV1NSoZ8+emjx5siZMmNABlQMA4uZQkrwbAUg3lp9afD6fJk2apJ49e2rOnDnat2+fZs6cqerqas2aNeuw+x44cEBXX321MjIyNGPGDHXt2lWffvqpgkGWlgIAADjaWR50lyxZIp/Pp/LycuXk5EiS7Ha7iouLNW3aNOXl5bW674MPPii/36+nnnqqafR32LBhHVI3AAAAkpvld0ZbvXq18vPzm0KuJBUUFMjlcmnVqlWH3feZZ57RFVdcEdUUBwAAABxdLB/Rrays1Pjx45u1uVwu9enTR5WVla3u99lnn2nPnj3yer361a9+pTfffFOdOnXSJZdcoptuuinm8Guapurq6mLat70k6zqOqaK+vp6bRgBJhvNafDivpYdDXwf8TqNnmmbUS4daHnR9Pp+8Xm+Ldq/Xq5qamlb327NnjyTp7rvv1qhRo7RgwQJVVFTonnvuUTAYVElJSUz1BINBbd68OaZ920tDQ4PVJaS0LVu2KCMjw+oyAByC81p8OK+lh0NfB/xO28blckW1neVBtzVHSuvhcFiSlJeXp5kzZ0qS8vPz1djYqLvvvlvXX3+9unfv3uav63Q61bdv39iKbieMfMSnX79+TG8BkgzntfhwXksPh74O+J1Gr6KiIuptLQ+6Xq9XPp+vRXttbe1hL0Tr0qWLJOnss89u1n722WcrHA6rsrIypqBrGIYyMzPbvF974s5e8fF4PNxBCEgynNfiw3kt9VVXV+vpp59WQ0ODDMPQrl271K9fP6vLSgltOX9YfjFaXl5ei7m4gUBA27dvP2zQPe644+R0trxD2NfzW2w2y781AACAFvbs2aOrr75aDz30kEKhkBobG/WLX/xC77zzjtWlpR3L0+Dw4cO1du1aVVVVNbWtWLFCgUBAI0aMaHU/l8ulc889V2vWrGnWvmbNGjkcjqSbfgAAACBJZWVl+uKLL5q1BQIBzZ4926KK0pflQXfChAnKyspSYWGh3njjDZWXl+uOO+7Q2LFjm43ozpgxQ/3792+27/Tp0/XRRx/pd7/7nf75z3/qscce09y5czVx4sRmy5UBAAAki7fffjti+0cffXTYC/HRdkkxR7esrEwlJSUqKiqS2+3WmDFjVFxc3Gy7cDisUCjUrO20007Tgw8+qP/5n//Rtddeqy5duuiqq67S9ddf35HfAgAAQNSys7MjtmdkZHBBWoJZHnQlKTc3VwsXLjzsNqWlpSotLW3Rfu655+rcc89tr9IAAAAS6rLLLos4H3f06NEsMZZglk9dAAAAOJoUFBTo2muvbbZyxgUXXKAbb7zRwqrSE0EXAACgg11zzTV67rnnmqYr3H777UxbaAdJMXUBAADgaNOpUyfZ7Xary0hrjOgCAAAgLRF0AQAAkJaYugAAANKWaZry+/1WlxHRoXUla41utzulb9lN0AUAAGnL7/eroKDA6jKOaNy4cVaXENHy5cubrQ6Rapi6AAAAgLTEiC4AADgq3CTJZXUR32J+9X8yTQ4ISLrL6iIShKALAACOCi5JrqSKlMnKPPImKYKpCwAAAEhLBF0AAACkJYIuAAAA0hJBFwAAAGmJoAsAAIC0RNAFAABAWiLoAgAAIC0RdAEAAJCWCLoAAABISwRdAAAApCWCLgAAANISQRcAAABpiaALAACAtETQBQAAQFoi6AIAACAtEXQBAACQlgi6AAAASEsEXQAAAKQlgi4AAADSEkEXAAAAaYmgCwAAgLRE0AUAAEBaIugCAABYwDRN1ZmmQqZpdSlpy2F1AQAAAEeb9Y2NejEY0B7TVKak/3I4dZHTKZthWF1aWiHoImbh/fsUqFyrcPXnMjzfkfPEs+TodrzVZQEAkNS2hkJaHGjQ1+O4dZJebgzKlDTK5bKwsvRD0EVMwvv3qe6NR6Wg/2BDzU6Fvvw/uc+8TI6ep1hbHAAASWx1MKhIkxX+2RjURU6n7IzqJgxzdBGTQMW/vgm5TUw1bH5dJnONAABoVZUZjthe/9U/JA5BFzEJV30esd08sE8K8jIFAKA1x9nsEdu7GoY6dXAt6Y6gi5gYHm/kJxwZB/8BAICIvu90yv2tNkNSgdMlg2kLCUXQRUycJw6N3J57hoxW/lIFAADSMTabrnN7dKbdoR6GoX42u67JyNAZDi6dSrSk+Ilu27ZNJSUlevfdd+XxeDR69GgVFxfL7f723zvNXX311Xr77bdbtP/jH/9QXl5ee5ULSY4eecoYPFaBLatk1vskR4acJwyRq98Iq0sDACDpHWOz6acZfALa3iwPuj6fT5MmTVLPnj01Z84c7du3TzNnzlR1dbVmzZp1xP2HDBmim266qVlb796926tcHMJ53Gly9B4os2G/DKdHht3y7gQAANDE8mSyZMkS+Xw+lZeXKycnR5Jkt9tVXFysadOmHXFk1uv1atCgQR1RKiIwDEOGO8vqMgAAAFqwfI7u6tWrlZ+f3xRyJamgoEAul0urVq2ysDIAAACkMstHdCsrKzV+/PhmbS6XS3369FFlZeUR93/77bc1aNAghUIhnX766br++us1dGjkC6WiYZqm6urqYt6/Pfj9316vFm1RX1/P2r5AkuG8Fh/Oa9Gjr8UnGfuaaZpRr05hedD1+XzyelsuVeX1elVTU3PYfYcOHapx48bphBNO0K5du7Rw4UJNnjxZixYt0uDBg2OqJxgMavPmzTHt214aGhqsLiGlbdmyRRlM+AeSCue1+HBeix59LT7J2tdcUd4q2fKg25po0vp1113X7PH555+vMWPGaP78+VqwYEFMX9fpdKpv374x7dte+Gs0Pv369TviCh4AOhbntfhwXosefS0+ydjXKioqot7W8qDr9Xrl8/latNfW1rZ5ibDMzEyNGDFCy5cvj7kewzCUmZkZ8/7tgcWj4+PxeOTxeKwuA8AhOK/Fh/Na9Ohr8UnGvtaW36nlF6Pl5eW1mIsbCAS0ffv2mNbCTbZ5JAAAALCG5UF3+PDhWrt2raqqqpraVqxYoUAgoBEj2nbzgbq6Oq1atUoDBw5MdJkAAABIMZYH3QkTJigrK0uFhYV64403VF5erjvuuENjx45tNqI7Y8YM9e/fv+nxO++8o2nTpunZZ5/V2rVrtXTpUk2cOFG7d+/W9OnTrfhWAAAAkESSYo5uWVmZSkpKVFRUJLfbrTFjxqi4uLjZduFwWKFQqOlx9+7dFQgEdM8996i6uloej0eDBw/W7bffrtNOO62jvw0AAAAkGcuDriTl5uZq4cKFh92mtLRUpaWlTY+PP/74I+4DAACAo5flUxcAAACA9kDQBQAAQFoi6AIAACAtEXQBAACQlgi6AAAASEsEXQAAAKQlgi4AAADSEkEXAAAAaSkpbhgBAIdjmqbWrFmjjRs3qlevXrrooouUkZFhdVkAgCRH0AWQ1Px+vwoLC/XWW281tc2ePVuPPPKIjj/+eAsrAwAkO4IugHZjmqb8fn9cx3j00UebhVxJ+vLLL/WnP/1J8+bNi+vYbrdbhmHEdQwAQPIi6AJoF6Zpavr06frggw/iOk51dXXE9rVr1+qiiy6SzRb7pQYDBw7UvHnzCLsAkKZiCrp1dXV6++239d5772nnzp3y+/3Kzs5W3759NWzYMJ100kmJrhNACmrvAElABQAcTpuC7ieffKJHHnlEzz//vOrq6mQYhrxer1wul3w+nxoaGmQYhr73ve/p6quv1uWXXx7XaAuA1GUYhubNmxf31IXFixfr3nvvbdF+3nnnafbs2XEdm6kLAJDeog66d955p/72t78pNzdXhYWFOuuss9S/f385HN8cYteuXVq/fr1eeeUV/fnPf9Zjjz2mmTNnauDAge1SPIDkZhiGPB5PXMf4+c9/rg0bNmjlypVNbccff7xuvfXWuI8NAEhvUQfdTZs26dFHH9XQoUNb3aZHjx66+OKLdfHFF2v//v167LHH9N577xF0AcTM6XRq7ty5+ve//63CwkLZ7XY9+eST6ty5s9WlAQCSXNRBd/HixW06cOfOnfXrX/+6zQUBQCSnnnpq0wiu3W63uBoAQCpI+ATanTt3atOmTYk+LAAAANAmMa268Pnnn7f63Msvv6wHH3xQa9asibkoAAAAIF4xBd0LLrjgsFcq5+bmxlwQAAAAkAgxBd0777yzRdCtq6vTO++8o1dffVWlpaUJKQ4AAACIVUxB9/LLL4/YPnHiRJWWluovf/mLFi1aFFdhAAAAQDwSfjHaiBEjtGHDhkQfFgAAAGiThAfdqqoqde3aNdGHBQAAANokpqkLkYTDYW3ZskUPPPCArr/++kQdFgAAAIhJTEG3X79+ra66YJqmbr75Zt18882SDt4ClHV1AQAA0NFiCrrTp08/7PJiAAAAgNViCrpFRUWJrgMAAABIqIRfjAYAAAAkg6iD7m233abdu3e36eAvv/yyli5d2uaiAAAAgHhFPXVh27ZtuvDCC3XRRRdp3LhxOvPMM+XxeFps9+mnn+rVV1/Vs88+q507d2rWrFkJLRgAAACIRtRBt6ysTK+88ooeeughTZ06VQ6HQ8cff7xycnKUkZGhmpoaffbZZ6qpqZHH49Hll1+uadOmsaYuAAAALNGmi9EuvPBCXXjhhdq0aZNee+01vf/++9q1a5d2796t7OxsjRw5UmeddZZGjhypzp07t1fNAAAAwBHFtOpC//791b9//0TXAgAAACQMqy4AAAAgLcUUdNesWaMXX3yx6fGePXs0depUnXvuufrd736nhoaGhBUIAAAAxCKmoDtnzhxVVlY2Pf7LX/6id955R4MHD9by5cv18MMPJ6xAAAAAIBYxBd1PPvmkaY5uY2OjVqxYoeLiYs2bN0/XXXedXnjhhYQWCQAAALRVTEF3//798nq9kqQPP/xQ9fX1GjlypCTptNNO0xdffJG4CgEAAIAYxBR0u3btqk8++USS9K9//Us9e/bUscceK0k6cOCAHI62Leawbds2TZkyRYMGDVJ+fr5KSkrk9/vbdIwVK1bo5JNP1pgxY9q0HwAAANJTTMuLnXfeeZo9e7YqKir03HPP6RVaZp8AACAASURBVNJLL2167uOPP1avXr2iPpbP59OkSZPUs2dPzZkzR/v27dPMmTNVXV0d9V3V/H6/Zs6cqW7durX5ewEAAEB6iino3nDDDfr888/15JNP6rTTTtO0adOannv++ec1ePDgqI+1ZMkS+Xw+lZeXKycnR5Jkt9tVXFysadOmKS8v74jHePDBB9WzZ0/17t1bH3zwQdu/IQAAAKSdmIJuTk6OFi5cGPG5xx9/XC6XK+pjrV69Wvn5+U0hV5IKCgo0Y8YMrVq16ohBd/v27Xr00Ue1ZMkSPfbYY1F/XQAAAKS3mILuofx+v2pqatS1a1c5HI423/q3srJS48ePb9bmcrnUp0+fZkuYtebPf/6zxo0bp379+rXp67bGNE3V1dUl5FiJ0tb5ymiuvr5epmlaXQbidOjrgN9p6uO8Fh9eA9Gjr8UnGfuaaZoyDCOqbWMOumvXrtXs2bO1ceNGSdJTTz2lAQMG6Pbbb1d+fr4uvvjiqI7j8/maVnA4lNfrVU1NzWH3XblypdatW6eXXnqp7d9AK4LBoDZv3pyw4yUCN+CIz5YtW5SRkWF1GYjToa8Dfqepj/NafHgNRI++Fp9k7WvRzh6IKeiuWbNG11xzjU466ST94he/aHaDiOzsbD377LNRB93WHCmtNzQ06M4771RRUVGzaQ/xcjqd6tu3b8KOlwj8NRqffv36ye12W10G4nTo64DfaerjvBYfXgPRo6/FJxn7WkVFRdTbxhR058yZo+HDh+v+++9XY2Njs6Dbr18/Pfvss1Efy+v1yufztWivra097PzcsrIy2Ww2jR49umn/YDCocDgsn88nt9vdprnCXzMMQ5mZmW3erz1FOzyPyDwejzwej9VlIE6Hvg74naY+zmvx4TUQPfpafJKxr7XldxpT0N28ebP++te/RvxiOTk52rt3b9THysvLazEXNxAIaPv27S3m7h7q448/1qeffqr8/PwWzw0dOlS33XabfvrTn0ZdBwAAANJLTEHXbrcrGAxGfG7v3r3q1KlT1Mf6emS4qqpK2dnZkg7e/CEQCGjEiBGt7jd16lRddtllzdoeeughbdu2TTNnztQJJ5wQdQ0AAABIPzHdGW3gwIFaunRpxOeWL1+uQYMGRX2sCRMmKCsrS4WFhXrjjTdUXl6uO+64Q2PHjm02dWHGjBnq379/0+O8vDwNGzas2b/u3bsrMzNTw4YN0zHHHBPLtwYAAIA0EdOI7i9/+UtNmTJF06dP16WXXirDMPT+++/rmWee0fLly1VWVhb1sbxer8rKylRSUqKioiK53W6NGTNGxcXFzbYLh8MKhUKxlAsAAICjUExB95xzzlFpaanuvPNOvfrqq5KkP/3pT/J6vZo5c6bOPPPMNh0vNze31RtQfK20tFSlpaVH3AYAAACQ4lhHd9y4cSooKNC6deu0Z88eZWdna8iQIUm3YgEAAACOTm0Oun6/Xz//+c913XXX6Zxzzom46gEAAABgtTZfjOZ2u7V161bZ7fb2qAcAAABIiJhWXRg8eLA2bNiQ6FoAAACAhIkp6N5000164oknVF5ergMHDiS6JgAAACBuMV2M9pOf/ETBYFC///3v9fvf/15ut7vZHdIMw9C7776bsCIBAACAtoop6BYUFHDvaAAAACS1mIIu69UCAAAg2cU0RxcAAABIdjHfMGL79u2aO3eu1qxZo+rqamVnZ+ucc87R9OnT1adPn0TWCAAAALRZTEG3srJSEyZMUENDg84++2z16NFDu3bt0osvvqjXX39df/vb35SXl5foWgEAAICoxRR0Z8+erS5dumjRokU69thjm9q//PJLTZo0Sffee6/mzp2bsCIBAACAtoppju6///1vFRUVNQu5knTssceqsLBQb731VkKKAwAAAGIVU9Ctr69Xly5dIj6XnZ0tv98fV1EAAABAvGIKurm5uVq2bFnE51544QWdeOKJcRUFAAAAxCumObpXX321brnlFtXW1uqyyy5T9+7dtXv3bi1dulQrV65USUlJousEAAAA2iSmoHvFFVdo7969uv/++7Vq1SpJkmmacrvduuGGGzR+/PiE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b6FHjx4AgOHDh6O0tBTx8fG4e/culEolRo0ahenTp8PcXPRo9tKrS5AX/dns1q1blbW4Wq0W165dq7J292mVa3Nzc3MNAnFOTg5kMlmVtbv04oWGhmLSpEm4dOkS2rVrh9dee03skkiiPvnkE4wbNw55eXmwt7eHjY2N2CWRRIWEhMDPzw+5ubl47bXX+LpGDSKXy9G/f/9q7xs5ciQ++OAD3Lt3DzY2NrCysmri6l4Non9gxIABA5Ceno4HDx7oxw4fPgytVouBAwfWuF3Hjh3h6OiIgwcPGowfOHAAPXv25BUXmoi1tTXc3Nz4y4AanZWVFZydnRlyqdFZW1ujZ8+efF2jRmdubo62bdsy5DYi0YOur68vWrRogbCwMKSlpSE1NRVffPEFPvzwQ4MjtVFRUVU+jGD69On44YcfEBsbizNnzuDLL7/EyZMnMX369KZ+GERERET0khF96YJKpUJSUhJiYmIwbdo0WFlZwcfHBxEREQbzKioqqpy9OGLECJSUlGDDhg3YtGkTOnfujNjYWH5YBBERERFBJjzv+havmMzMTACAq6uryJUQERERUXXqktdEX7pARERERNQYGHSJiIiISJIYdImIiIhIkhh0iYiIiEiSGHSJiIiISJIYdImIiIhIkhh0iYiIiEiSGHSJiIiISJIYdImIiIhIkhh0iYiIiEiSGHSJiIiISJIYdImIiIhIkhh0iYiIiEiSGHSJiIiISJLMxS7gZaLT6SAIAjIzM8UuhYiIiIiqodVqIZPJjJrLoPsUY580IiIiIhKHTCYzOrPJBEEQGrkeIiIiIqImxzW6RERERCRJDLpEREREJEkMukREREQkSQy6RERERCRJDLpEREREJEkMukREREQkSQy6RERERCRJDLpEREREJEkMukREREQkSQy6RERERCRJDLpEREREJEkMukREREQkSQy6RERERCRJDLpEREREJEkMukREREQkSQy6VKvIyEj4+PjgxIkT8PHxgaurK0aPHo1z587p5wwaNAhLlizBxo0b4e3tjV69eiE0NBR3794VsXIyNXXpta1bt+L999/H22+/jbCwMOTn54tYOZmayl47c+YMPv74Y7i5uWHs2LHIysrSz3FxcUFCQgKWL1+Ovn37wt3dHZGRkSgqKhKxcjI1xvZaYmIiVq9ejX79+sHT0xPz5s1DcXGxiJVLA4Mu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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)), dim=0)\n",
    "\n",
    "for i in n_spurious_sentences:\n",
    "  n_emb = torch.cat((n_emb,get_cls(i)), 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": 77,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093835,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "t-1o_fPd_MEy",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['aquavit akvavit',\n",
       " 'bituminous',\n",
       " 'dairyman',\n",
       " 'pirouette',\n",
       " 'sudanese',\n",
       " 'phrenologist craniologist',\n",
       " 'masa',\n",
       " 'forefoot',\n",
       " 'caucus',\n",
       " 'betaine']"
      ]
     },
     "execution_count": 77,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "n_words_spurious[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "metadata": {
    "executionInfo": {
     "elapsed": 33,
     "status": "aborted",
     "timestamp": 1695329093836,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "lvMoMpyEXQVt",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['squatina genus_squatina',\n",
       " 'keynote',\n",
       " 'recorded',\n",
       " 'tip tilt slant lean angle',\n",
       " 'rut',\n",
       " 'petroleum_geologist oil_geologist',\n",
       " 'juneau capital_of_alaska',\n",
       " 'nguyen_tat_thanh ho_chi_minh',\n",
       " 'recognition realization realisation',\n",
       " 'supervisor']"
      ]
     },
     "execution_count": 78,
     "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": 79,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093836,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "M4c1i-jEnOia",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import os, sys\n",
    "\n",
    "filenames = []\n",
    "\n",
    "path = \"/home/mostafa_nsu/ICLR/Datasets/GoEmotion/bias_criterias\"\n",
    "dir = os.listdir( path )\n",
    "\n",
    "for file in dir:\n",
    "   if(file.endswith('.csv')):\n",
    "    filenames.append(file)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093836,
     "user": {
      "displayName": "Mostafa Mushsharat",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "uAcBqk9LpYds",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dialogue.csv is Positively Spurious.\n",
      "Positive Acc: 0.7519259215859769 \n",
      "Negative Acc: 0.2031088590136391\n",
      "------------------------------------------------------------------------\n",
      "Indian.csv is Neutral.\n",
      "Positive Acc: 0.457810221933505 \n",
      "Negative Acc: 0.24757003589322873\n",
      "------------------------------------------------------------------------\n",
      "Orientation.csv is Positively Spurious.\n",
      "Positive Acc: 0.6957527353309582 \n",
      "Negative Acc: 0.20188758112325264\n",
      "------------------------------------------------------------------------\n",
      "Colored.csv is Neutral.\n",
      "Positive Acc: 0.2654867358088932 \n",
      "Negative Acc: 0.38800794934421345\n",
      "------------------------------------------------------------------------\n",
      "occupations1950_nonprofessional.csv is Neutral.\n",
      "Positive Acc: 0.4787859174343276 \n",
      "Negative Acc: 0.27913820301387626\n",
      "------------------------------------------------------------------------\n",
      "Society.csv is Neutral.\n",
      "Positive Acc: 0.5580490552549142 \n",
      "Negative Acc: 0.25977857348442607\n",
      "------------------------------------------------------------------------\n",
      "Money.csv is Neutral.\n",
      "Positive Acc: 0.27195801172114387 \n",
      "Negative Acc: 0.32838815896304063\n",
      "------------------------------------------------------------------------\n",
      "Woman.csv is Neutral.\n",
      "Positive Acc: 0.508020434000159 \n",
      "Negative Acc: 0.3544043177765802\n",
      "------------------------------------------------------------------------\n",
      "Activist.csv is Neutral.\n",
      "Positive Acc: 0.5817234666307198 \n",
      "Negative Acc: 0.17490141143889795\n",
      "------------------------------------------------------------------------\n",
      "Retarded.csv is Positively Spurious.\n",
      "Positive Acc: 0.626088402613813 \n",
      "Negative Acc: 0.25931532856909356\n",
      "------------------------------------------------------------------------\n",
      "Chubby.csv is Positively Spurious.\n",
      "Positive Acc: 0.8021474875411527 \n",
      "Negative Acc: 0.16921932056730504\n",
      "------------------------------------------------------------------------\n",
      "Jew.csv is Neutral.\n",
      "Positive Acc: 0.41094202315931005 \n",
      "Negative Acc: 0.47417398889182694\n",
      "------------------------------------------------------------------------\n",
      "Homosexual.csv is Neutral.\n",
      "Positive Acc: 0.24545403007343713 \n",
      "Negative Acc: 0.29690422198366706\n",
      "------------------------------------------------------------------------\n",
      "Misgendering.csv is Neutral.\n",
      "Positive Acc: 0.5343262841288057 \n",
      "Negative Acc: 0.3013709649015432\n",
      "------------------------------------------------------------------------\n",
      "Marriage.csv is Positively Spurious.\n",
      "Positive Acc: 0.6962485360227344 \n",
      "Negative Acc: 0.23501595559917982\n",
      "------------------------------------------------------------------------\n",
      "Industry.csv is Neutral.\n",
      "Positive Acc: 0.585358750545615 \n",
      "Negative Acc: 0.21138419243947154\n",
      "------------------------------------------------------------------------\n",
      "Oriental.csv is Neutral.\n",
      "Positive Acc: 0.27349050096927874 \n",
      "Negative Acc: 0.27400135066921477\n",
      "------------------------------------------------------------------------\n",
      "occupations1950_professional.csv is Neutral.\n",
      "Positive Acc: 0.5172545878650169 \n",
      "Negative Acc: 0.2724977989078097\n",
      "------------------------------------------------------------------------\n",
      "Gender.csv is Neutral.\n",
      "Positive Acc: 0.4871935966761634 \n",
      "Negative Acc: 0.1943181572445825\n",
      "------------------------------------------------------------------------\n",
      "Media.csv is Neutral.\n",
      "Positive Acc: 0.37680374865128013 \n",
      "Negative Acc: 0.4669473779480751\n",
      "------------------------------------------------------------------------\n",
      "Islam.csv is Positively Spurious.\n",
      "Positive Acc: 0.7563570439722567 \n",
      "Negative Acc: 0.19400174662629524\n",
      "------------------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "for filename in filenames:\n",
    "    df_bias = pd.read_csv('/home/mostafa_nsu/ICLR/Datasets/GoEmotion/bias_criterias/'+filename)\n",
    "\n",
    "    p_spurious_sentences = list(df_bias['Definition'])\n",
    "\n",
    "    p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "    n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "    for i in p_spurious_sentences:\n",
    "      p_emb = torch.cat((p_emb,get_cls(i)), dim=0)\n",
    "\n",
    "    for i in neutral_word_meaning_sentences[10:20]:\n",
    "      n_emb = torch.cat((n_emb,get_cls(i)), 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)), dim=0)\n",
    "\n",
    "    for i in n_spurious_sentences:\n",
    "      n_emb = torch.cat((n_emb,get_cls(i)), dim=0)\n",
    "\n",
    "    p_emb = p_emb[1:]\n",
    "    n_emb = n_emb[1:]\n",
    "\n",
    "    test_acc, _, test_f1 = eval_model(\n",
    "      model,\n",
    "      test_data_loader,\n",
    "      loss_fn,\n",
    "      device,\n",
    "      len(df_test)\n",
    "    )\n",
    "\n",
    "    negative_spurious = test_f1.item()\n",
    "\n",
    "    if positive_spurious>=0.6:\n",
    "      print(filename+' is Positively Spurious.')\n",
    "    if negative_spurious>=0.6:\n",
    "      print(filename+' is Negatively Spurious.')\n",
    "    if(positive_spurious<0.6 and negative_spurious<0.6):\n",
    "      print(filename+' is Neutral.')\n",
    "    print('Positive Acc:',positive_spurious,'\\n'+'Negative Acc:', negative_spurious)\n",
    "    print(\"------------------------------------------------------------------------\")"
   ]
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "provenance": []
  },
  "gpuClass": "standard",
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
