{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "executionInfo": {
     "elapsed": 5,
     "status": "ok",
     "timestamp": 1695324378707,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "F7toc08bpdQ1",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "from transformers import T5Config, T5Tokenizer, T5EncoderModel\n",
    "\n",
    "from transformers import *\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "from torch.utils.data import Dataset, DataLoader\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.metrics import f1_score\n",
    "import textwrap\n",
    "import math\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from IPython.display import clear_output\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "clear_output()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "executionInfo": {
     "elapsed": 15,
     "status": "ok",
     "timestamp": 1695323483676,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "MLk4JWizs4S9",
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_train = pd.read_csv('/home/m_nsu/ICLR/Datasets/GoEmotion/train.csv')\n",
    "df_val = pd.read_csv('/home/m_nsu/ICLR/Datasets/GoEmotion/val.csv')\n",
    "df_test = pd.read_csv('/home/m_nsu/ICLR/Datasets/GoEmotion/test.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "id": "YWiFI0a9QqEa",
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_senti = pd.read_excel('/home/m_nsu/ICLR/Datasets/GoEmotion/sentiwords.xlsx')\n",
    "conditions = [\n",
    "    (df_senti['PosScore'] > df_senti['NegScore']),\n",
    "    (df_senti['PosScore'] < df_senti['NegScore']),\n",
    "    (df_senti['PosScore'] == df_senti['NegScore'])\n",
    "    ]\n",
    "\n",
    "values = ['Positive','Negative','Neutral']\n",
    "\n",
    "df_senti = df_senti[['PosScore','NegScore','Word','Definition']]\n",
    "df_senti['Sentiment'] = np.select(conditions, values)\n",
    "df_senti = df_senti.dropna(axis=0)\n",
    "df_senti.drop(columns=['PosScore', 'NegScore'], inplace=True)\n",
    "df_senti = df_senti[['Word', 'Sentiment', 'Definition']]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "executionInfo": {
     "elapsed": 48,
     "status": "ok",
     "timestamp": 1695323754433,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "vX1DfZpN1W01",
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_train.dropna(inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "executionInfo": {
     "elapsed": 48,
     "status": "ok",
     "timestamp": 1695323754435,
     "user": {
      "displayName": "m m",
      "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": 7,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 206
    },
    "executionInfo": {
     "elapsed": 49,
     "status": "ok",
     "timestamp": 1695323754437,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "e0NG9J-oq_wW",
    "outputId": "f1bb3869-364e-4c7a-8c3f-a62ce4b182c7",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>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": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_train.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "executionInfo": {
     "elapsed": 45,
     "status": "ok",
     "timestamp": 1695323754437,
     "user": {
      "displayName": "m m",
      "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": 9,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 45,
     "status": "ok",
     "timestamp": 1695323754438,
     "user": {
      "displayName": "m m",
      "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": 10,
   "metadata": {
    "executionInfo": {
     "elapsed": 33,
     "status": "ok",
     "timestamp": 1695323754438,
     "user": {
      "displayName": "m m",
      "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": 11,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 35
    },
    "executionInfo": {
     "elapsed": 33,
     "status": "ok",
     "timestamp": 1695323754439,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "_xxZFLJwxfpy",
    "outputId": "914e4d70-43c6-462e-dc72-954759c555eb",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'gratitude'"
      ]
     },
     "execution_count": 11,
     "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": 12,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 33,
     "status": "ok",
     "timestamp": 1695323754440,
     "user": {
      "displayName": "m m",
      "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": 13,
   "metadata": {
    "executionInfo": {
     "elapsed": 18,
     "status": "ok",
     "timestamp": 1695323756839,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "UmEtmaFNrakz",
    "tags": []
   },
   "outputs": [],
   "source": [
    "MAX_LEN = 200\n",
    "RANDOM_SEED = 42\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "device = torch.device(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 18,
     "status": "ok",
     "timestamp": 1695323756840,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "6oWORty0p8Xo",
    "outputId": "cb12350b-753a-4c61-c7e8-3c9427f000e9",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda:1\n"
     ]
    }
   ],
   "source": [
    "PRE_TRAINED_MODEL_NAME = 't5-large'\n",
    "config = T5Config.from_pretrained(PRE_TRAINED_MODEL_NAME)\n",
    "tokenizer = T5Tokenizer.from_pretrained(PRE_TRAINED_MODEL_NAME)\n",
    "clear_output()\n",
    "print(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {
    "id": "yDSL15DQGvrh",
    "tags": []
   },
   "outputs": [],
   "source": [
    "pre_trained_model = T5EncoderModel.from_pretrained(PRE_TRAINED_MODEL_NAME).to(device)\n",
    "clear_output()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {
    "executionInfo": {
     "elapsed": 35,
     "status": "ok",
     "timestamp": 1695323767305,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "R2PbApHJGstz",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def get_cls(sent):\n",
    "  encoded_review = tokenizer.encode_plus(\n",
    "  sent,\n",
    "  max_length=MAX_LEN,\n",
    "  add_special_tokens=True,\n",
    "  return_token_type_ids=False,\n",
    "  truncation = True,\n",
    "  padding='max_length',\n",
    "  return_attention_mask=True,\n",
    "  return_tensors='pt',\n",
    "  )\n",
    "  input_ids = encoded_review['input_ids'].to(device)\n",
    "  attention_mask = encoded_review['attention_mask'].to(device)\n",
    "\n",
    "  pre_trained_model.eval()\n",
    "  with torch.no_grad():\n",
    "    output = pre_trained_model(input_ids, attention_mask)\n",
    "    return torch.mean(output[0], dim=1)[0] #Output Avg pooled vector embedding of last layer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {
    "executionInfo": {
     "elapsed": 33,
     "status": "ok",
     "timestamp": 1695323767305,
     "user": {
      "displayName": "m m",
      "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": 18,
   "metadata": {
    "executionInfo": {
     "elapsed": 33,
     "status": "ok",
     "timestamp": 1695323767306,
     "user": {
      "displayName": "m m",
      "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": 19,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "ok",
     "timestamp": 1695323767306,
     "user": {
      "displayName": "m m",
      "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": 20,
   "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": 20,
     "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": 21,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 30,
     "status": "ok",
     "timestamp": 1695323767308,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "Y_8HhXvskRFY",
    "outputId": "a8dbea0e-bd42-4116-8e55-4b9c17f6f627",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "12\n",
      "11\n"
     ]
    }
   ],
   "source": [
    "print(len(positive_word_meaning_sentences))\n",
    "print(len(negative_word_meaning_sentences))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {
    "executionInfo": {
     "elapsed": 3468,
     "status": "ok",
     "timestamp": 1695323770756,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "LNSmtyIyoOUv",
    "tags": []
   },
   "outputs": [],
   "source": [
    "p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "\n",
    "for i in positive_word_meaning_sentences:\n",
    "  p_emb = torch.cat((p_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "for i in negative_word_meaning_sentences:\n",
    "  n_emb = torch.cat((n_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "\n",
    "\n",
    "p_emb = p_emb[1:]\n",
    "n_emb = n_emb[1:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 27,
     "status": "ok",
     "timestamp": 1695323770759,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "V_qXeXCGgjtq",
    "outputId": "b32eec10-206d-4ac3-ed65-f7bef84586d2",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([12, 1024])\n",
      "torch.Size([11, 1024])\n"
     ]
    }
   ],
   "source": [
    "print(p_emb.shape)\n",
    "print(n_emb.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {
    "executionInfo": {
     "elapsed": 24,
     "status": "ok",
     "timestamp": 1695323770760,
     "user": {
      "displayName": "m m",
      "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": 25,
   "metadata": {
    "executionInfo": {
     "elapsed": 24,
     "status": "ok",
     "timestamp": 1695323770760,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "OtZt1p7ys7XD",
    "tags": []
   },
   "outputs": [],
   "source": [
    "class IMDBDataset(Dataset):\n",
    "\n",
    "  def __init__(self, reviews, sentiments, 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": 26,
   "metadata": {
    "executionInfo": {
     "elapsed": 6,
     "status": "ok",
     "timestamp": 1695325189268,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "UuOujQajtL5f",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def create_data_loader(df, tokenizer, max_len, batch_size):\n",
    "  ds = IMDBDataset(\n",
    "    reviews=df.review.to_numpy(),\n",
    "    sentiments=df['sentiment'].to_numpy(),\n",
    "    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": 27,
   "metadata": {
    "executionInfo": {
     "elapsed": 24,
     "status": "ok",
     "timestamp": 1695323770761,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "3zzA4eBytOqj",
    "tags": []
   },
   "outputs": [],
   "source": [
    "BATCH_SIZE = 32\n",
    "\n",
    "train_data_loader = create_data_loader(df_train, tokenizer, MAX_LEN, BATCH_SIZE)\n",
    "val_data_loader = create_data_loader(df_val, tokenizer, MAX_LEN, BATCH_SIZE)\n",
    "test_data_loader = create_data_loader(df_test, tokenizer, MAX_LEN, BATCH_SIZE)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 6,
     "status": "ok",
     "timestamp": 1695325187523,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "AoUfRPy0tQgk",
    "outputId": "4cc31257-8fe1-4cce-883e-8aff4ebf2185",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['review', 'input_ids', 'attention_mask', 'sentiments', 'emotions'])"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data = next(iter(train_data_loader))\n",
    "data.keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {
    "executionInfo": {
     "elapsed": 3,
     "status": "ok",
     "timestamp": 1695325688712,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "Y3Nil-yatUqF",
    "tags": []
   },
   "outputs": [],
   "source": [
    "class Classifier(nn.Module):\n",
    "  def __init__(self):\n",
    "    super(Classifier, self).__init__()\n",
    "    self.bert = T5EncoderModel.from_pretrained(PRE_TRAINED_MODEL_NAME,config=config)\n",
    "    self.FC = nn.Linear(config.hidden_size,config.hidden_size, bias=False)\n",
    "\n",
    "  def CosineNorm(self, c, b, n_words):\n",
    "    cos = torch.nn.CosineSimilarity(dim=-1, eps=1e-8)\n",
    "    simi = torch.tensor([[1.]*n_words]).to(device)\n",
    "    for i in c:\n",
    "      temp = cos(i,b).to(device)\n",
    "      temp = torch.unsqueeze(temp,0)\n",
    "      simi = torch.cat((simi,temp), dim=0)\n",
    "\n",
    "    return simi[1:]\n",
    "\n",
    "  def binary_output(self,positive, negative):\n",
    "    positive = torch.max(positive,1).values\n",
    "    negative = torch.max(negative,1).values\n",
    "\n",
    "    p_temp = torch.unsqueeze(positive,0)\n",
    "    n_temp = torch.unsqueeze(negative,0)\n",
    "\n",
    "\n",
    "    res = torch.cat((p_temp,n_temp), dim=0)\n",
    "\n",
    "    return torch.t(res)\n",
    "\n",
    "  def forward(self, input_ids, attention_mask, return_scores=False):\n",
    "    with torch.no_grad():\n",
    "      pooled_output = self.bert(\n",
    "        input_ids=input_ids,\n",
    "        attention_mask=attention_mask,\n",
    "        return_dict = False\n",
    "      )\n",
    "    pooled_output = torch.mean(pooled_output[0], dim=1) # Taking Averge pooled last layer embedding\n",
    "\n",
    "    x_sent = self.FC(pooled_output)\n",
    "\n",
    "    Ept = self.FC(p_emb)\n",
    "    Ent = self.FC(n_emb)\n",
    "\n",
    "    positive = F.relu(self.CosineNorm(x_sent, Ept, p_emb.size()[0]))\n",
    "    negative = F.relu(self.CosineNorm(x_sent, Ent, n_emb.size()[0]))\n",
    "\n",
    "    binary_out = self.binary_output(positive,negative)\n",
    "    if(return_scores==True):\n",
    "      return (positive,negative) , binary_out\n",
    "    return binary_out"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {
    "id": "HWZ37gsztWzL",
    "tags": []
   },
   "outputs": [],
   "source": [
    "model = Classifier()\n",
    "model = model.to(device)\n",
    "clear_output()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {
    "executionInfo": {
     "elapsed": 22,
     "status": "ok",
     "timestamp": 1695325221207,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "HWy57v2CxxCM",
    "tags": []
   },
   "outputs": [],
   "source": [
    "for name, param in model.named_parameters():\n",
    "    if name.startswith('bert'):\n",
    "        param.requires_grad = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {
    "executionInfo": {
     "elapsed": 20,
     "status": "ok",
     "timestamp": 1695325221207,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "e5iLu13CYlux",
    "tags": []
   },
   "outputs": [],
   "source": [
    "#for name, param in model.named_parameters():\n",
    "#    print(name, param.requires_grad)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 21,
     "status": "ok",
     "timestamp": 1695325221208,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "nZpqz6yDtYZ4",
    "outputId": "c0ba4f97-cad5-46b8-e1ff-e818ff5b4035",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([32, 200])\n",
      "torch.Size([32, 200])\n"
     ]
    }
   ],
   "source": [
    "input_ids = data['input_ids'].to(device)\n",
    "attention_mask = data['attention_mask'].to(device)\n",
    "sentiments = data['sentiments'].to(device)\n",
    "\n",
    "print(input_ids.shape) # batch size x seq length\n",
    "print(attention_mask.shape) # batch size x seq length"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {
    "executionInfo": {
     "elapsed": 12,
     "status": "ok",
     "timestamp": 1695325221208,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "NwvA-zp7vqc1",
    "tags": []
   },
   "outputs": [],
   "source": [
    "#del test\n",
    "torch.cuda.empty_cache()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {
    "executionInfo": {
     "elapsed": 603,
     "status": "ok",
     "timestamp": 1695325221800,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "-9Z37OXOtb0q",
    "tags": []
   },
   "outputs": [],
   "source": [
    "(positive,negative),outs = model(input_ids, attention_mask,return_scores=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 15,
     "status": "ok",
     "timestamp": 1695325221800,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "NHFM3QUhg3n0",
    "outputId": "602bd955-db78-44a6-931e-e5e901bb1856",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0.4575, 0.3412],\n",
       "        [0.4656, 0.4286],\n",
       "        [0.8797, 0.9845],\n",
       "        [0.5627, 0.5261],\n",
       "        [0.8726, 0.9833],\n",
       "        [0.6212, 0.5178],\n",
       "        [0.7404, 0.7070],\n",
       "        [0.8693, 0.9920],\n",
       "        [0.8766, 0.9803],\n",
       "        [0.6457, 0.6518],\n",
       "        [0.2722, 0.2357],\n",
       "        [0.8697, 0.9928],\n",
       "        [0.6161, 0.5602],\n",
       "        [0.5056, 0.4244],\n",
       "        [0.8788, 0.9884],\n",
       "        [0.5712, 0.5329],\n",
       "        [0.8740, 0.9877],\n",
       "        [0.5677, 0.5223],\n",
       "        [0.8691, 0.9960],\n",
       "        [0.5860, 0.5244],\n",
       "        [0.6023, 0.4887],\n",
       "        [0.5983, 0.5176],\n",
       "        [0.8739, 0.9795],\n",
       "        [0.8382, 0.8769],\n",
       "        [0.5113, 0.4514],\n",
       "        [0.4333, 0.3824],\n",
       "        [0.8856, 0.9909],\n",
       "        [0.8782, 0.9906],\n",
       "        [0.5749, 0.5390],\n",
       "        [0.5764, 0.5102],\n",
       "        [0.1930, 0.1451],\n",
       "        [0.6749, 0.6126]], device='cuda:1', grad_fn=<TBackward0>)"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "outs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 1022,
     "status": "ok",
     "timestamp": 1695325845248,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "cjMVWA5a_6lf",
    "outputId": "bae8764e-0ce8-4118-e676-267b2c3ac06b",
    "tags": []
   },
   "outputs": [],
   "source": [
    "EPOCHS = 8\n",
    "\n",
    "optimizer = AdamW(model.parameters(), lr=0.001)\n",
    "total_steps = len(train_data_loader) * EPOCHS\n",
    "\n",
    "scheduler = get_linear_schedule_with_warmup(\n",
    "  optimizer,\n",
    "  num_warmup_steps=math.floor((1./5)*total_steps),\n",
    "  num_training_steps=total_steps\n",
    ")\n",
    "\n",
    "loss_fn = nn.CrossEntropyLoss().to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {
    "executionInfo": {
     "elapsed": 8,
     "status": "ok",
     "timestamp": 1695325845969,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "cLFDb4pzbx9W",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def train_epoch(\n",
    "  model,\n",
    "  data_loader,\n",
    "  loss_fn,\n",
    "  optimizer,\n",
    "  device,\n",
    "  scheduler,\n",
    "  n_examples\n",
    "):\n",
    "  model = model.train()\n",
    "\n",
    "  losses = []\n",
    "  correct_predictions = 0\n",
    "\n",
    "  for d in data_loader:\n",
    "    input_ids = d[\"input_ids\"].to(device)\n",
    "    attention_mask = d[\"attention_mask\"].to(device)\n",
    "    sentiments = d[\"sentiments\"].to(device)\n",
    "\n",
    "    outputs = model(\n",
    "      input_ids=input_ids,\n",
    "      attention_mask=attention_mask\n",
    "    ).to(device)\n",
    "\n",
    "    _, preds = torch.max(outputs, dim=1)\n",
    "    loss = loss_fn(outputs, sentiments)\n",
    "\n",
    "    correct_predictions += torch.sum(preds == sentiments)\n",
    "    losses.append(loss.item())\n",
    "\n",
    "\n",
    "    loss.backward()\n",
    "    nn.utils.clip_grad_norm_(model.parameters(), max_norm=1.0)\n",
    "    optimizer.step()\n",
    "    scheduler.step()\n",
    "    optimizer.zero_grad()\n",
    "\n",
    "  return correct_predictions.double() / n_examples, np.mean(losses)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {
    "executionInfo": {
     "elapsed": 9,
     "status": "ok",
     "timestamp": 1695325845971,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "z4GAdIawtUue",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def eval_model(model, data_loader, loss_fn, device, n_examples, on_new=False):\n",
    "  model = model.eval()\n",
    "\n",
    "  losses = []\n",
    "  f1s = []\n",
    "\n",
    "  correct_predictions = 0\n",
    "\n",
    "  with torch.no_grad():\n",
    "    for d in data_loader:\n",
    "      input_ids = d[\"input_ids\"].to(device)\n",
    "      attention_mask = d[\"attention_mask\"].to(device)\n",
    "      sentiments = d[\"sentiments\"].to(device)\n",
    "\n",
    "      outputs = model(\n",
    "        input_ids=input_ids,\n",
    "        attention_mask=attention_mask,\n",
    "      ).to(device)\n",
    "      _, preds = torch.max(outputs, dim=1)\n",
    "\n",
    "      loss = loss_fn(outputs, sentiments)\n",
    "\n",
    "      correct_predictions += torch.sum(preds == sentiments)\n",
    "      losses.append(loss.item())\n",
    "\n",
    "      f1s.append(f1_score(sentiments.cpu(), preds.cpu(), average='macro'))\n",
    "\n",
    "  return correct_predictions.double() / n_examples, np.mean(losses), np.mean(f1s)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {
    "executionInfo": {
     "elapsed": 8,
     "status": "ok",
     "timestamp": 1695325846655,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "9tWEJ4saOU6Q",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def batch_calc_score_sum(positive, negative, sentiments):\n",
    "  p_filter = sentiments ^ torch.ones(sentiments.size()[0], dtype=torch.int8).to(device) # Positive ( sentiment xor [1,1,...])\n",
    "  n_filter = sentiments # Negative\n",
    "\n",
    "  pos_score_pos_sent = positive[p_filter.nonzero(), :]\n",
    "  pos_score_neg_sent = positive[n_filter.nonzero(), :]\n",
    "\n",
    "  neg_score_pos_sent = negative[p_filter.nonzero(), :]\n",
    "  neg_score_neg_sent = negative[n_filter.nonzero(), :]\n",
    "\n",
    "  pp_count = pos_score_pos_sent.size()[0]\n",
    "  pn_count = pos_score_neg_sent.size()[0]\n",
    "  pp_sum = torch.sum(pos_score_pos_sent,dim=0)\n",
    "  pn_sum = torch.sum(pos_score_neg_sent,dim=0)\n",
    "\n",
    "\n",
    "#  np_count = neg_score_pos_sent.size()[0] # same as pn_count\n",
    "#  nn_count = neg_score_neg_sent.size()[0] # same as pn_count\n",
    "  np_sum = torch.sum(neg_score_pos_sent,dim=0)\n",
    "  nn_sum = torch.sum(neg_score_neg_sent,dim=0)\n",
    "\n",
    "  return pp_sum,pn_sum,np_sum,nn_sum, pp_count, pn_count\n",
    "\n",
    "def eval_scores_average(model, data_loader, device):\n",
    "  model = model.eval()\n",
    "\n",
    "\n",
    "  pp_sum_agg = torch.zeros(1,p_emb.size()[0]).to(device)\n",
    "  pn_sum_agg = torch.zeros(1,p_emb.size()[0]).to(device)\n",
    "\n",
    "  np_sum_agg = torch.zeros(1,n_emb.size()[0]).to(device)\n",
    "  nn_sum_agg = torch.zeros(1,n_emb.size()[0]).to(device)\n",
    "\n",
    "  pp_count_agg, pn_count_agg = 0,0\n",
    "\n",
    "  with torch.no_grad():\n",
    "    for d in data_loader:\n",
    "      input_ids = d[\"input_ids\"].to(device)\n",
    "      attention_mask = d[\"attention_mask\"].to(device)\n",
    "      sentiments = d[\"sentiments\"].to(device)\n",
    "\n",
    "      (positive,negative),_= model(\n",
    "        input_ids=input_ids,\n",
    "        attention_mask=attention_mask,\n",
    "        return_scores=True\n",
    "      )\n",
    "      positive.to(device)\n",
    "      negative.to(device)\n",
    "\n",
    "\n",
    "      pp_sum,pn_sum,np_sum,nn_sum, pp_count, pn_count = batch_calc_score_sum(positive,negative,sentiments)\n",
    "\n",
    "      pp_sum_agg += pp_sum\n",
    "      pn_sum_agg += pn_sum\n",
    "\n",
    "      np_sum_agg += np_sum\n",
    "      nn_sum_agg += nn_sum\n",
    "\n",
    "      pp_count_agg += pp_count\n",
    "      pn_count_agg += pn_count\n",
    "\n",
    "\n",
    "\n",
    "  return pp_sum_agg/pp_count_agg, pn_sum_agg/pn_count_agg, np_sum_agg/pp_count_agg, nn_sum_agg/pn_count_agg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {
    "executionInfo": {
     "elapsed": 8,
     "status": "ok",
     "timestamp": 1695325846656,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "IxncgTh4awi7",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def box_plot(pp,pn,np,nn):\n",
    "  pp = pp.tolist()[0]\n",
    "  pn = pn.tolist()[0]\n",
    "  np = np.tolist()[0]\n",
    "  nn = nn.tolist()[0]\n",
    "  # Create a box plot with beeswarm using seaborn\n",
    "  sns.set(style=\"whitegrid\")  # Set the style of the plot\n",
    "  plt.figure(figsize=(8, 6))  # Set the figure size\n",
    "  ax = sns.boxplot(data=[pp,pn,np,nn], orient=\"v\", palette=\"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": 42,
   "metadata": {
    "executionInfo": {
     "elapsed": 7,
     "status": "ok",
     "timestamp": 1695325846656,
     "user": {
      "displayName": "m m",
      "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": 43,
   "metadata": {
    "executionInfo": {
     "elapsed": 3,
     "status": "ok",
     "timestamp": 1695325847286,
     "user": {
      "displayName": "m m",
      "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": 44,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000
    },
    "executionInfo": {
     "elapsed": 3203929,
     "status": "ok",
     "timestamp": 1695329051836,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "IqdIHJsrANr0",
    "outputId": "ee79ec9a-a033-47e0-bc8b-a7b71698465c",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/8\n",
      "----------\n",
      "Train loss 0.5691608014975467 accuracy 0.7352468887996789\n",
      "Val   loss 0.541135681203649 accuracy 0.7639825466084887\n",
      "\n",
      "Epoch 2/8\n",
      "----------\n",
      "Train loss 0.5073815100552757 accuracy 0.8027900441589724\n",
      "Val   loss 0.5418708645090272 accuracy 0.7564458548195161\n",
      "\n",
      "Epoch 3/8\n",
      "----------\n",
      "Train loss 0.49283722755805637 accuracy 0.8148334002408671\n",
      "Val   loss 0.4995683378811124 accuracy 0.8254660848869496\n",
      "\n",
      "Epoch 4/8\n",
      "----------\n",
      "Train loss 0.48306024710783796 accuracy 0.8242673625050181\n",
      "Val   loss 0.4895446809786784 accuracy 0.8155493851646172\n",
      "\n",
      "Epoch 5/8\n",
      "----------\n",
      "Train loss 0.4817112097770789 accuracy 0.8245182657567243\n",
      "Val   loss 0.4824474450153641 accuracy 0.8294327647758826\n",
      "\n",
      "Epoch 6/8\n",
      "----------\n",
      "Train loss 0.4755373206796845 accuracy 0.8311421116017664\n",
      "Val   loss 0.4753905934623525 accuracy 0.8310194367314557\n",
      "\n",
      "Epoch 7/8\n",
      "----------\n",
      "Train loss 0.4724140093089298 accuracy 0.8340525893215577\n",
      "Val   loss 0.4762372291540798 accuracy 0.8270527568425228\n",
      "\n",
      "Epoch 8/8\n",
      "----------\n",
      "Train loss 0.4680159537310011 accuracy 0.8371136089923725\n",
      "Val   loss 0.4757541949990429 accuracy 0.8298294327647758\n",
      "\n",
      "CPU times: user 1h 58min 7s, sys: 10.9 s, total: 1h 58min 18s\n",
      "Wall time: 1h 58min 22s\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "train_a = []\n",
    "train_l = []\n",
    "val_a = []\n",
    "val_l = []\n",
    "best_accuracy = 0\n",
    "\n",
    "for epoch in range(EPOCHS):\n",
    "\n",
    "  print(f'Epoch {epoch + 1}/{EPOCHS}')\n",
    "  print('-' * 10)\n",
    "\n",
    "  train_acc, train_loss = train_epoch(\n",
    "    model,\n",
    "    train_data_loader,\n",
    "    loss_fn,\n",
    "    optimizer,\n",
    "    device,\n",
    "    scheduler,\n",
    "    len(df_train)\n",
    "  )\n",
    "\n",
    "  print(f'Train loss {train_loss} accuracy {train_acc}')\n",
    "\n",
    "  val_acc, val_loss, val_f1 = eval_model(\n",
    "    model,\n",
    "    val_data_loader,\n",
    "    loss_fn,\n",
    "    device,\n",
    "    len(df_val)\n",
    "  )\n",
    "\n",
    "  print(f'Val   loss {val_loss} accuracy {val_acc}')\n",
    "  print()\n",
    "\n",
    "  train_a.append(train_acc)\n",
    "  train_l.append(train_loss)\n",
    "  val_a.append(val_acc)\n",
    "  val_l.append(val_loss)\n",
    "\n",
    "  if val_acc > best_accuracy:\n",
    "    torch.save(model.state_dict(), 't5_best_model_state.bin')\n",
    "    best_accuracy = val_acc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {
    "executionInfo": {
     "elapsed": 51,
     "status": "ok",
     "timestamp": 1695329137842,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "FowMSU5U7SDQ",
    "tags": []
   },
   "outputs": [],
   "source": [
    "train_a = [i.item() for i in train_a]\n",
    "train_l = [i.item() for i in train_l]\n",
    "val_a = [i.item() for i in val_a]\n",
    "val_l = [i.item() for i in val_l]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 480
    },
    "executionInfo": {
     "elapsed": 2888,
     "status": "ok",
     "timestamp": 1695329143450,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "aUQbxyTEAPhM",
    "outputId": "b103ca88-1886-4f16-ea21-5b966a08fe7c",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHFCAYAAAAOmtghAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAPYQAAD2EBqD+naQAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nOzdeXxM5+IG8OfMnp0skiAkBBU7CcJFaVEppYul2hJa96baorZbv97botqoa2toUrdX7LdF0WqbVtPSSnERhKpYqtEEo5EgmyyznN8fk4yMJDKTTExyPN/P53xmzjvvOec9UzWP933POYIoiiKIiIiIJELm6AYQERER2RPDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNERERSQrDDREREUkKww0RERFJCsMNkYQIgmDV8uOPP9rleEVFRRAEAYsXL67R9r1798Zjjz1ml7bYys/PD88880y19b799lsIgoD//e9/Nu0/JiYGmzdvrmnziKgWFI5uABHZz6FDhyzW33nnHezbtw979+61KA8JCbHL8dRqNQ4dOoQWLVrUaPu1a9dCLpfbpS11JTw8HIcOHULHjh1t2i4mJgbBwcF4/vnn66hlRFQVhhsiCendu7fFuo+PD2QyWYXyqpSUlEAul1sdOARBsHrflenQoUONt71fPDw8anWO9mQwGGAwGKBSqRzdFKJ6jcNSRA+osuGWrVu3Ytq0afD394dGo0FGRga0Wi2ioqLQvn17uLi4wNfXF48++miFnqHKhqU++ugjCIKAAwcOYMqUKfDy8oK3tzdGjx6NP//802L7u4elzp49C0EQsGrVKrz//vto2bIlXF1d0bdvXxw7dqzCOcTGxiI4OBhqtRqdOnXC9u3bMW7cODz00ENWfw9ffvklunbtCicnJ4SEhFQYSqpsWOr8+fMYPXo0/P39oVar4efnh8GDB+PXX38FYBryunjxIvbs2WMeCizfprS0NDz77LPw8fGBWq1GSEgIYmJiUP45xmXfxcqVKzF//nwEBgZCpVIhISEBrq6umD59eoVzOXfuHGQyGVatWmX1+RNJEXtuiB5ws2bNQv/+/fGf//wHRqMRjRs3Rnp6OpRKJRYsWABfX1/k5eVh+/bt6NevH5KSkhAeHl7tfidOnIgnnngCn3zyCdLS0jB3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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": 47,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 28664,
     "status": "ok",
     "timestamp": 1695329081374,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "L1ZzFERMAQk9",
    "outputId": "56411273-fc8c-476f-f660-21239bd321ad",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.8319526627218935\n",
      "F1-Macro:  0.8162541777341353\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": 48,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 605
    },
    "executionInfo": {
     "elapsed": 29278,
     "status": "ok",
     "timestamp": 1695329182045,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "zUrNTiUp8kPc",
    "outputId": "e99daa47-22f9-471e-97d4-245bf6f0b8ab",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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ykp9+umnevfddzV9+vSoFAcAABCPqqurtWDBAnk8HhmGod27d+u4446zuqy4E/auC+GaPn261qxZo+eeey6aj20R7LoAAACaW0VFha655pqgk2Hbtm2rf/zjH+rdu7eFlbUOjclrUX8ZbdCgQfryyy+j/VgAAIC48NxzzwWFXOngtqwPPvigRRXFr6gH3bKyMrVv3z7ajwUAAIgLy5cvDzn+5Zdfyu12t3A18S2iHt1QAoGA1q9fr8cee0w33nhjtB4LAAAQV1JSUkKOJyYmyuFwtHA18S2ioNurV696d10wTVNTpkzRlClTJEmGYSKCjakAACAASURBVLCvLgAAwI+GDRumL774os74kCFD5HQ6LagofkUUdCdNmtTg9mIAAAAIbfjw4frqq6/0yiuvyO/3S5L69++vW265xeLK4k/Ud11ozdh1AQAAtJStW7fq8ssvl81mU3FxsZKTk60uqVVoTF6LWo8uAAAAwte5c2clJBDFmlPYuy7cc8892rVrV6MevnjxYr3xxhuNLgoAAABoqrB/jNiyZYuGDBmiCy64QMOHD9cZZ5wRcol927Ztevfdd/Xaa69px44dmjlzZlQLBgAAAMIRdtCdO3eu3nnnHT3xxBMaP368EhISdPzxxys9PV1JSUmqqKjQ119/rYqKCiUnJ2vEiBGaMGECe+oCAADAEo1qDBkyZIiGDBmitWvXasmSJfriiy+0c+dO7dq1S2lpaRo8eLDOOussDR48WG3btm2umgEAAIDDiqgD+pRTTtEpp5wS7VoAAACAqIn6EcAAAABALIgo6K5YsUJvv/127ce7d+/W+PHjde655+rWW29VTU1N1AoEAAAAIhFR0J01a5ZKS0trP37ggQf06aefql+/fioqKtI///nPqBUIAAAARCKioLt169baHl2fz6fi4mLl5eWpoKBAN9xwg958882oFgkAAAA0VkRBd//+/XK5XJKkNWvWqKqqSoMHD5Yk9enTR99//330KgQAAAAiEFHQbd++vbZu3SpJ+vDDD9WlSxcdffTRkqQDBw5wnB0AAAAsF1HQPe+88/TQQw9p+vTpmjNnjoYMGVJ7bfPmzeratWvUCkTsW758uS699FItX77c6lIAAABqRRR0b7rpJvXq1UsvvfSSTj75ZE2YMKH22sKFC9WvX7+oFYjYFQgEtGjRIt16663aunWrZsyY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F/LYXung9mLPPvtsk4oCAAAAmiqioLtt2zb16NEj5LXMzExt27atSUUBAAAATRVR0JUOHtEbyv79+9kGDAAAAJaLKOj27NlTb775ZshrCxcurHe1FwAAAGgpEQXdUaNGqaioSLfddpu++OIL7dixQ1988YWmTJmixYsXa/To0dGuEwAAAGiUiLYXGzZsmDZv3qwnnnhCb7zxhqSDB0bY7XZNmDBBv/71r6NaJAAAANBYEe+je+ONN2rkyJFavny5ysrKlJ6ernPPPVddu3aNZn0AAABARCJ+GU2Sjj32WOXk5Gj//v1699139fjjj2vTpk3Rqg0AAACIWNgrun/961/19ttv6/33368dq6ys1G9/+1t9++23Mk1TkvTmm2/q5Zdf1oknnhj1YgEAAIBwhb2iu2rVKl188cVBY/PmzdM333yjsWPH6tNPP9X8+fOVkpKiJ598MuqFAgAAAI0RdtD9+uuvdeqppwaNLVmyROnp6brlllvUtm1b9e3bV1deeaU+/vjjqBcKAAAANEbYQdftdqtTp061H/t8PpWUlOiss86S3W6vHT/55JO1a9eu6FYJAAAANFLYQbdDhw7auXNn7cdr166Vz+ers8prs9nkcDiiVyEAAAAQgbCDbu/evfXyyy/XvnT2xhtvyDAMZWdnB923efNmdezYMbpVAgAAAI0U9q4L48eP12WXXaaLLrpIaWlp+vzzz3XGGWeod+/eQfctWbJEWVlZUS8UAAAAaIywV3RPO+00Pfroo+rUqZMOHDigSy+9VAUFBUH37Nq1Sz/88IMGDx4c9UIBAACAxmjUyWjnn3++zj///Hqvd+zYsfZIYAAAAMBKTToZDQAAAIhVBF0AAADEJYIuAAAA4hJBFwAAAHGJoAsAAIC4RNAFAABAXGrU9mIAAACIjl27dsnv98swDKtLiVus6AIAALQg0zT14IMP6tJLL1VNTY2qq6v1xz/+UW632+rS4g4rugAAAGEyTVPV1dVNesbChQv1r3/9K2hs5cqVmj59uu68884mPdvpdLJCfAiCLgAAQBhM09SkSZO0evXqJj2nvqC8ePFiffDBB00KqllZWSooKCDs/ojWBQAAgDBFI0CaphmFShAOVnQBAADCYBiGCgoKmty68Nhjj+n555+vM37qqadq9uzZTXo2rQvBCLoAAABhMgxDycnJTXrGVVddpRUrVmjz5s21Y23btlVeXl6Tn41gBF0AAIAWdNRRR+nZZ5/VW2+9pTVr1uiYY47R8OHD1bFjR6tLizsEXQAAgBbmdDo1YsQIjRgxwupS4hovowEAACAuEXQBAAAQlwi6AAAAiEsEXQAAAMQlgi4AAADiUkwE3S1btmjcuHHq27evsrOzlZ+fH9ZmzA888IAuueQS9evXT/3799fIkSP15ptvtkDFAAAAiHWWby/mdrs1duxYdenSRbNmzdLevXs1bdo0lZeXa+bMmQ3OraqqUm5urrp16ybTNFVUVKSbb75ZgUBAw4YNa6GvAAAAALHI8qA7f/58ud1uFRYWKj09XZJkt9uVl5enCRMmKDMzs965d911V9DH5513njZt2qR///vfBF0AAIAjnOWtC8uWLVN2dnZtyJWknJwcORwOLV26tNHPS01NldfrjWaJAAAAaIUsX9EtLS3VyJEjg8YcDocyMjJUWlp62Pmmacrv96uyslLvvfeeli9frgceeCDiekzTVGVlZcTzAQAA0HxM05RhGGHda3nQdbvdcrlcdcZdLpcqKioOO3/FihW68sorJUkJCQm68847ddFFF0Vcj9fr1bp16yKeDwAAgOblcDjCus/yoFufcNN6nz599Morr2j//v1atmyZ7r33Xtntdl166aURfd7ExER17949orkAAABoXps2bQr7XsuDrsvlktvtrjO+b9++Bl9E+0nbtm2VlZUlScrOzpbH49H06dM1YsQI2e32RtdjGIZSUlIaPQ8AAADNL9y2BSkGXkbLzMys04vr8Xi0ffv2sILu/+rdu7f279+vvXv3RqtEAAAAtEKWB92BAwfqo48+UllZWe1YcXGxPB6PBg0a1OjnrVy5Um3btlVaWlo0ywQAAEArY3nQzc3NVbt27TRx4kR98MEHKiws1L333qthw4YFrehOnTpVp5xySu3H69ev19VXX61XXnlFK1as0Lvvvqs77rhDr7zyiq699lolJFjelQEAAAALWZ4GXS6X5s6dq/z8fE2ePFlOp1NDhw5VXl5e0H2BQEB+v7/24w4dOsjlcunRRx/Vrl271K5dO5144on6xz/+oSFDhrT0lwEAAIAYY5imaVpdRKwoKSmRpNqX2wAAABBbGpPXLG9dAAAAAJoDQRcAAABxiaALAACAuETQBQAAQFwi6AIAACAuEXQBAAAQlwi6AAAA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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "pp,pn,np,nn = eval_scores_average(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  device,\n",
    ")\n",
    "\n",
    "box_plot(pp,pn,np,nn)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "uSAQhl1kh5jw"
   },
   "source": [
    "Accuracy of Emotions on Test Set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 30028,
     "status": "ok",
     "timestamp": 1695329212062,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "aw1XJc94pY9f",
    "outputId": "17d0fe97-0a2d-470d-aa5f-db29bc0c41f7",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.09428007889546351"
      ]
     },
     "execution_count": 49,
     "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": 50,
   "metadata": {
    "executionInfo": {
     "elapsed": 8,
     "status": "ok",
     "timestamp": 1695329212064,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "d7DaFLMiAWps",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def get_predictions(model, data_loader):\n",
    "  model = model.eval()\n",
    "\n",
    "  review = []\n",
    "  predictions = []\n",
    "  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": 51,
   "metadata": {
    "executionInfo": {
     "elapsed": 27254,
     "status": "ok",
     "timestamp": 1695329239311,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "kZhYtki1AYx8",
    "tags": []
   },
   "outputs": [],
   "source": [
    "y_review_texts, y_pred, 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": 52,
   "metadata": {
    "executionInfo": {
     "elapsed": 9,
     "status": "ok",
     "timestamp": 1695329239312,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "mO1FHn0GAbCU",
    "tags": []
   },
   "outputs": [],
   "source": [
    "from sklearn.metrics import classification_report\n",
    "from sklearn.metrics import confusion_matrix\n",
    "class_names = ['negative', 'positive']"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "PnBSQFJuh_As"
   },
   "source": [
    "Pos/Neg Classification Report"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 9,
     "status": "ok",
     "timestamp": 1695329239312,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "J9-01snpAcM8",
    "outputId": "4d6f7fff-9a14-49bf-c847-d2e8ba79f5f7",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "              precision    recall  f1-score   support\n",
      "\n",
      "    negative       0.87      0.86      0.87      1603\n",
      "    positive       0.77      0.78      0.77       932\n",
      "\n",
      "    accuracy                           0.83      2535\n",
      "   macro avg       0.82      0.82      0.82      2535\n",
      "weighted avg       0.83      0.83      0.83      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": 54,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 7,
     "status": "ok",
     "timestamp": 1695329239312,
     "user": {
      "displayName": "m m",
      "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.10      0.31      0.14       131\n",
      "          fear       0.06      0.22      0.10        65\n",
      "     annoyance       0.00      0.00      0.00       194\n",
      "     gratitude       0.00      0.00      0.00       260\n",
      "    admiration       0.24      0.30      0.27       348\n",
      "        caring       0.04      0.13      0.06        86\n",
      " embarrassment       0.00      0.00      0.00        23\n",
      "           joy       0.00      0.00      0.00        93\n",
      "       sadness       0.00      0.00      0.00       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.10      0.31      0.15       186\n",
      "disappointment       0.12      0.02      0.04        88\n",
      "       remorse       0.03      0.16      0.05        44\n",
      "          love       0.00      0.00      0.00       160\n",
      "       disgust       0.09      0.03      0.04        76\n",
      "        relief       0.00      0.00      0.00         7\n",
      "         pride       0.00      0.14      0.01         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.09      2535\n",
      "     macro avg       0.03      0.07      0.04      2535\n",
      "  weighted avg       0.06      0.09      0.06      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": 55,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 30105,
     "status": "ok",
     "timestamp": 1695329269413,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "pOutPTF6qJY8",
    "outputId": "a034fc7e-f3ae-44e3-9bd9-2c416c5b45b3",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.1680473372781065\n",
      "F1-Macro:  0.16216510445007365\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": 56,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 605
    },
    "executionInfo": {
     "elapsed": 28733,
     "status": "ok",
     "timestamp": 1695329298142,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "F25gPUqgvw0w",
    "outputId": "747d6857-a67e-4f00-f9a9-fea35eee0d06",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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NzfX6tIAxIgZXQAAvtWnTx/NnTvX6jIAxAkzugAAAEhKBF0AAAAkJYIuAAAAkhJBFwAAAEmJoAsAAICkRNAFAABAUiLoAgAAICkRdAEAAJCUCLoAAABISgRdAAAAJKWECLpbt27V2LFj1bt3b2VnZys/P18+n69e1x48eFD33nuvfvjDHyorK0s5OTlasGBBE1cMAACAROewugCv16sxY8aoU6dOmj17tvbv36/p06fr4MGDmjVrVp3XHjp0SKNHj1ZKSoqmTJmiE044Qdu2bVMgEGim6gEAAJCoLA+6CxYskNfrVWFhodq1aydJstvtysvL0/jx45WZmVnrtXPnzpXP59NLL70kt9stSRowYECz1A0AAIDEZnnrwooVK5SdnV0dciUpJydHLpdLy5cvr/Pal19+Wddcc011yAUAAACOsHxGt6SkRCNGjIgYc7lc6tq1q0pKSmq9bseOHdq7d688Ho9uueUWrVy5Uq1atdIVV1yhO++8M+bwa5qmKioqYroWaOnq2xuP6CorK2WaptVlAEBSM01ThmHU61zLg67X65XH46kx7vF4VFpaWut1e/fulSTNnDlTl19+uZ588klt3rxZf/rTnxQIBJSfnx9TPYFAQBs2bIjpWqClq6qqsrqEFm3jxo1KSUmxugwASHoul6te51kedGtzrLQeDoclSZmZmZo+fbokKTs7W8FgUDNnztRtt92m9u3bN/jrOp1O9ejRI7aigRaOGd3G6dmzJ61UANDENm/eXO9zLQ+6Ho9HXq+3xnhZWVmdD6K1bdtWknThhRdGjF944YUKh8MqKSmJKegahqG0tLQGXwckg/p+FIToUlNTlZqaanUZAJDUGvJeZfnDaJmZmTV6cf1+v7Zv315n0D3llFPkdDprjB/pj7PZLP/WAAAAYCHL0+DAgQO1evVqHThwoHpsyZIl8vv9GjRoUK3XuVwu/eAHP9CqVasixletWiWHw0H7AQAAwHHO8qCbm5ur1q1ba8KECXr33XdVWFioadOmadiwYREzulOmTFGvXr0irp04caI+++wz/fa3v9V7772n5557To8++qhGjhwZsVwZAAAAjj8J0aM7b9485efna/LkyXK73Ro6dKjy8vIizguHwwqFQhFj5557rubOnas//vGP+uUvf6m2bdtq1KhRuu2225rzWwAAAEACMkwWfaxWXFwsScrK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1lSPbdu2TQUFBcrLy7OwMgCxavSGET6fT7t27VIwGJQkpaenE3QBAC3O/PnzI0KuJJmmqQULFujLL7+0qCoAjRFz0F29erWuu+469e3bVz/+8Y/12WefSZLuu+8+LV68OG4FAgDQHN5+++2o48FgUA899JBM02zmigA0Vsw7o40dO1ZVVVX6xS9+oXA4XH0sIyNDr7zyStwKBACgORz5ZDKaDz/8UNu2bWvGagDEQ8w7ow0cOFCFhYX61a9+FXGsZ8+e2rhxY1yKAwCguVx55ZVRx51OpwYMGKBTTz21mSsC0FgxBd0NGzYoNzdXkmQYRsSxdu3aad++fY2vDACAZpSbm6uLLrooYsxms6lVq1a6/fbba7zfAUh8MQVdu92uQCAQ9di+ffvUqlWrRhUFAEBzczqdmjNnjn72s5/J7XYrNTVV6enpGj16NOvDAy1UTEE3KytLCxcujHqsqKhIvXv3blRRAABY5Y477lCnTp3kdDrVvn17jRw50uqSAMQopqB78803a8mSJZo4caLefvttGYahTz75RPfff7+Kiop00003xbtOAACahdvt1q9//WuddNJJuuOOO+R2u60uCUCMDDPG9VL+/e9/68EHH1RpaWn1mMfj0dSpU2tt6E90xcXFkg7PWANILJWVlcrJyZF0+JOj1NRUiysCAFihIXktpp3RJGn48OHKycnRRx99pL179yojI0N9+/ZVWlparLcEAAAA4qbBQdfn8+mGG27QrbfeqosuukjZ2dlNURcAAADQKA3u0XW73dq0aZPsdntT1AMAAADERUwPo/Xp00effvppvGsBAAAA4iamoHvnnXfqxRdfVGFhoQ4dOtToIrZu3aqxY8eqd+/eys7OVn5+vnw+X4PusWTJEp155pkaOnRoo+sBAABAyxfTw2jXXXedAoGA7r77bt19991yu90RO8YYhqE1a9bU615er1djxoxRp06dNHv2bO3fv1/Tp0/XwYMHNWvWrHrdw+fzafr06TrxxBNj+XYAAACQhGIKujk5OXHbCnHBggXyer0qLCxUu3btJB3eeS0vL0/jx49XZmbmMe8xd+5cderUSV26dNHatWvjUhcAAABatpiC7owZM+JWwIoVK5SdnV0dcqXDQXrKlClavnz5MYPu9u3b9eyzz2rBggV67rnn4lYXAAAAWraY19GNl5KSEo0YMSJizOVyqWvXriopKTnm9Q888ICGDx+unj17xqUe0zRVUVERl3sBiJ+j+/YrKysV4143AIAWzjTNencWxBx0t2/frkcffVSrVq3SwYMHlZGRoYsuukgTJ05U165d630fr9crj8dTY9zj8UTsuhbN22+/rY8++khvvvlmg+uvTSAQ0IYNG+J2PwDxUVVVVf3vGzduVEpKioXVAACs5HK56nVeTEG3pKREubm5qqqq0oUXXqgOHTpo9+7deuONN7Rs2TL97W9/q1dvbV2Oldarqqr04IMPavLkyRFtD43ldDrVo0ePuN0PQHwcPaPbs2dPud1uC6sBAFhl8+bN9T43pqD78MMPq23btnrhhRfUsWPH6vFvvvlGY8aM0SOPPKJHH320XvfyeDzyer01xsvKyuoMy/PmzZPNZtOQIUOqrw8EAgqHw/J6vXK73fVO+0czDINtjIEEdPQvvqmpqUpNTbWwGgCAVRqyIEJM6+j+73//0+TJkyNCriR17NhREyZM0Pvvv1/ve2VmZtboxfX7/dq+fXudQXfLli3atm2bsrOz1b9/f/Xv31+LFi1SSUmJ+vfvr5dffrlh3xQAAACSSkwzupWVlWrbtm3UYxkZGQ3a7GHgwIF6/PHHdeDAAWVkZEg6vPmD3+/XoEGDar1u3LhxuuqqqyLGnnjiCW3dulXTp09Xt27d6l0DAAAAkk9MM7rdu3fXq6++GvXYa6+9ptNOO63e98rNzVXr1q01YcIEvfvuuyosLNS0adM0bNiwiBndKVOmqFevXtWvMzMzNWDAgIh/2rdvr7S0NA0YMEAnnXRSLN8aAAAAkkRMM7qjR4/W1KlTVVZWpquuukrt27fXnj17tHDhQr399tvKz8+v9708Ho/mzZun/Px8TZ48WW63W0OHDlVeXl7EeeFwWKFQKJZyAQAAcBwyzBgXo5w7d64ef/zx6iV/TNOU2+3WhAkTdPPNN8e1yOZSXFwsScrKyrK4EgDfV1lZqZycHElSUVERD6MBwHGqIXkt5nV0b7nlFv385z/XRx99pIMHD6pt27bq06ePWrduHestAQAAgLhp1M5orVu31sCBA+NVCwAAABA3MT2M9vLLL9e6Tu6jjz6qwsLCRhUFAAAANFZMQfeFF16Ium2vdHh5seeff75RRQEAAACNFVPQ3bZtm84444yoxzIzM7Vt27ZGFQUAAAA0VkxBVzq8RW805eXlLAMGAAAAy8UUdM8880y99tprUY8tWrSo1tleAAAAoLnEFHRHjhypoqIi3Xnnnfrkk0+0a9cuffLJJ7rrrru0ePFijRo1Kt51AgAAAA0S0/Jiw4YN05YtW/TEE09o4cKFkg5vGGG32zV+/HhdeeWVcS0SAAAAaKiY19G97bbbNGLECK1cuVIHDhxQu3bt9IMf/ECdO3eOZ30AAABATGJ+GE2SunTpopycHJWXl2vp0qWaO3euNm/eHK/aAAAAgJjVe0b3D3/4g9544w0tW7aseqyiokLXXHONvvrqK5mmKUl67bXX9NJLL+m0006Le7EAAABAfdV7Rvejjz7SFVdcETE2f/58ffnllxozZow++OADLViwQGlpaXryySfjXigAAADQEPUOujt27NA555wTMfbOO++oXbt2+s1vfqP09HT17t1bN954o95///24FwoAAAA0RL2DrtfrVYcOHapfB4NBFRcX64ILLpDdbq8eP+uss7Rnz574VgkAAAA0UL2D7oknnqjdu3dXv16/fr2CwWCNWV6bzSaXyxW/CgEAAIAY1Dvonn322XrppZeqHzpbuHChDMNQdnZ2xHlbtmxR+/bt41slAAAA0ED1XnVh3Lhxuv7663X55ZcrIyNDH3/8sfr166ezzz474rx33nlHWVlZcS8UAAAAaIh6z+ied955mjNnjjp06KBDhw7p2muvVUFBQcQ5e/bs0TfffKPBgwfHvVAAAACgIRq0M9rFF1+siy++uNbj7du3r94SGAAAALBSo3ZGAwAAABIVQRcAAABJiaALAACApETQBQAAQFIi6AIAACApEXQBAACQlBq0vBgAWGXv3r3y+/2y2fj9HABQP7xjAEh4Dz30kIYOHaqysjKVlpZq8uTJKisrs7osAECCY0YXQJMxTVM+n69R91i4cKGee+65iLFVq1Zp2rRpuu+++xp1b7fbLcMwGnUPAEDiIugCaBKmaWrixIlau3Zto+5TWloadfy1117TqlWrGhVUs7KyVFBQQNgFgCRF6wKAJhOPAGmaZkzHAABgRhdAkzAMQwUFBY1uXZg9e7aef/75GuPnnHNOjZaGhqJ1AQCSG0EXQJMxDEOpqamNusctt9yi9957T1u2bKkea9WqlaZMmdLoewMAkhtBF0BCa9u2rRYsWKCFCxdq7dq16tSpk0aMGKGOHTtaXRoA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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "pp,pn,np,nn = eval_scores_average(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  device,\n",
    ")\n",
    "\n",
    "box_plot(pp,pn,np,nn)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "3NU7ySjLiPKH"
   },
   "source": [
    "Foreign Injection Accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 27580,
     "status": "ok",
     "timestamp": 1695329325716,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "zlbzZWECocpp",
    "outputId": "27337f4e-b8c6-4b92-a088-77f03f0ccd93",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.8220907297830374\n",
      "F1-Macro:  0.8104164469294268\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).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "for i in new_negative_word_meaning_sentences:\n",
    "  n_emb = torch.cat((n_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "p_emb = p_emb[1:]\n",
    "n_emb = n_emb[1:]\n",
    "\n",
    "test_acc, _, test_f1 = eval_model(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  loss_fn,\n",
    "  device,\n",
    "  len(df_test)\n",
    ")\n",
    "\n",
    "print(\"Accuracy: \",test_acc.item())\n",
    "print(\"F1-Macro: \",test_f1.item())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 605
    },
    "executionInfo": {
     "elapsed": 29037,
     "status": "ok",
     "timestamp": 1695329354749,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "DGrasP1mxQrD",
    "outputId": "87f1fe38-fe1b-4d6c-bf39-3c3e36c56fae",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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W8UUdCdNmqTCwkLNnTtXGzdu1DfffKONGzfql7/8pV5//XVNnjw53nUCAAAArRLT9mJjx47Vtm3b9Oijj+qll16StP/ACKfTqenTp+uyyy6La5EAAABAa8W8j+5NN92kCRMmaO3atSorK1O3bt00cuRI9e3bN571AQAAADGJ+WE0STr22GOVnZ2tqqoqvfnmm1q2bFmrzh8GAAAA2kvUM7p33323XnvtNb3zzjsNbTU1Nbryyiv1n//8Rwd2KXvllVf017/+Vccff3zciwUAAACiFfWM7oYNG3TJJZc0anvmmWe0a9cuTZ06VR9++KGWL1+ulJQUPfbYY3EvFAAAAGiNqIPuzp07ddpppzVqe/vtt9WtWzfddtttSk1N1ZAhQ3Tdddfpn//8Z9wLBQAAAFoj6qDr9/t19NFHN7wOhUIqKirSWWedJafT2dB+yimnaM+ePfGtEgAAAGilqINujx49tHv37obXmzdvVigUajLL63A45PF44lchAAAAEIOog+6pp56qv/71rw0Pnb300ksyDENZWVmN7tu2bZt69uwZ3yoBAACAVop614UbbrhB11xzjS6++GKlp6fr448/1g9+8AOdeuqpje57++23lZmZGfdCAQAAgNaIekb39NNP19KlS3X00UerurpaV111lZYsWdLonj179ui///2vzj///LgXCgAAALSGYR5YiwAVFRVJEjPSAAAACao1ea1NJ6MBAAAAiYqgCwAAAFsi6AIAAMCWCLoAAACwJYIuAAAAbImgCwAAAFsi6AIAAMCWCLoAAACwJYIuAAAAbImgCwAAAFsi6AIAAMCWCLoAAACwJYIuAAAAbImgCwAAAFsi6AIAAMCWCLoAAACwJYIuAAAAbImgCwAAAFsi6AIAAMCWCLoAAACwJYIuAAAAbImgCwAAAFsi6AIAAMCWCLoAAACwJYIuAAAAbImgCwAAAFsi6AIAAMCWCLoAAACwJYIuAAAAbCkhgu727ds1bdo0DRkyRFlZWcrNzVVdXd1h+91777269NJLNXToUA0bNkwTJkzQK6+80gEVAwAAING5rC7A7/dr6tSp6tOnjxYvXqzS0lLl5eWpvLxcixYtOmTf2tpaTZw4UQMGDJBpmiosLNScOXMUiUQ0duzYDvoEAAAASESWB93ly5fL7/eroKBA3bp1kyQ5nU7l5ORo+vTpysjIaLHv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Jy4uTj179tQrr7yimpoaRUdHa+HChV6sGu2RJ+ca0FamTp2qs2fPau7cubLb7YqLi9OCBQu8XRYAD1kMwzC8XQRubxkZGSorK9O77757zT4TJkzQ+PHj+QDADfHkXAPaSkREhObOnavp06d7uxQA14k5ugAAADAlgi4AAABMiakLAAAAMCVGdAEAAGBKBF0AAACYEkEXAAAApkTQBQAAgCkRdAEAAGBKBF0AuAGHDh3SCy+8oAkTJigyMlJDhw7VE088oby8PFVVVbVqXx9++KFef/31W1TpzXf8+HFFRERo69at3i4FAJrF8mIAcJ0KCwu1cOFC3XfffUpMTFRYWJgaGhpUVlamwsJCDRw4UDk5OR7vb9GiRdq4caM+++yzW1j1zWO323Xw4EH16dNHwcHB3i4HAJrw9XYBANAe/eMf/1BmZqaio6O1cuVKWa1W13OjR49WSkqKiouLvVjhreN0OuV0OmW1WjVkyBBvlwMA18SILgBch1mzZqm4uFgffPCBevXq9Z1933vvPW3ZskWHDx9WTU2NQkNDFRsbq9TUVHXs2FGSlJGRoW3btjXZ9q9//at69+4twzC0adMmFRYW6osvvpC/v79GjRqlOXPm6J577nH1NwxDubm52rx5s06fPq3w8HA9//zzWrVqlSQpPz/f1ffrr7/W7373O/3tb39TbW2t7rnnHv385z/XtGnT1KHD5Zltx48fV2xsrNLT0+VwOLRlyxZVVFRo1apV6tevn2JjY7VkyRJNnDjRtd+jR4/q9ddf1969e137nTJlip588klXn8bGRq1atUrbt2/Xf//7X1mtVvXq1UuTJk1ScnLydfxEAKApRnQBoJWcTqdKSkp0//33txhypcvBb+zYsUpOTpbNZlN5ebny8vL0r3/9S3/84x8lSampqaqvr9eOHTu0efNm17Y9evSQJC1YsEDbtm3T1KlTlZ6erurqauXk5CghIUHbt29X9+7dJUlZWVnKzc3V5MmTFRcXp4qKCr300ktyOBy67777XPs9e/asEhIS5HA49Otf/1qhoaHas2ePli5dqmPHjikzM9Pte8jPz1ffvn01b948BQYG6t577232ez1y5IgSEhLUq1cvzZs3TyEhIfroo4+0ePFinTt3TmlpaZKkNWvWKDs7W0899ZSGDx+uhoYGlZeXq7a21vMfBAC0gKALAK107tw5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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": 59,
   "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": 60,
   "metadata": {
    "executionInfo": {
     "elapsed": 18,
     "status": "ok",
     "timestamp": 1695329438384,
     "user": {
      "displayName": "m m",
      "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": 61,
   "metadata": {
    "executionInfo": {
     "elapsed": 16,
     "status": "ok",
     "timestamp": 1695329438385,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "Ppy-K6l2gWtd",
    "tags": []
   },
   "outputs": [],
   "source": [
    "from IPython.display import clear_output"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {
    "executionInfo": {
     "elapsed": 38794,
     "status": "ok",
     "timestamp": 1695329477164,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "_OCeDQY6gHMj",
    "tags": []
   },
   "outputs": [],
   "source": [
    "new_positive_word_meaning_sentences = []\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": 63,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 30045,
     "status": "ok",
     "timestamp": 1695329507205,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "uEuhYVF-gMqC",
    "outputId": "3c4d554a-9320-4704-990c-0a6f0b392083",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.8189349112426035\n",
      "F1-Macro:  0.8080405196508049\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "for i in new_positive_word_meaning_sentences:\n",
    "  p_emb = torch.cat((p_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "for i in new_negative_word_meaning_sentences:\n",
    "  n_emb = torch.cat((n_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "p_emb = p_emb[1:]\n",
    "n_emb = n_emb[1:]\n",
    "\n",
    "test_acc, _, test_f1 = eval_model(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  loss_fn,\n",
    "  device,\n",
    "  len(df_test)\n",
    ")\n",
    "\n",
    "\n",
    "\n",
    "print(\"Accuracy: \",test_acc.item())\n",
    "print(\"F1-Macro: \",test_f1.item())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {
    "executionInfo": {
     "elapsed": 13,
     "status": "ok",
     "timestamp": 1695329507206,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "2qBYfr3zgvAs",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import random\n",
    "random.seed(42)\n",
    "\n",
    "inputNumbers = range(0,10000)\n",
    "random_seeds = random.sample(inputNumbers, 300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {
    "executionInfo": {
     "elapsed": 11,
     "status": "ok",
     "timestamp": 1695329507206,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "nysMxY5myqsd",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "JuMwkV_v4GvV",
    "outputId": "24e92f01-d79f-4514-f879-14a50b1f8477",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Working ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... "
     ]
    }
   ],
   "source": [
    "f1s = []\n",
    "accuracy = []\n",
    "p_word_list = []\n",
    "n_word_list = []\n",
    "\n",
    "print(\"Working\", end=' ')\n",
    "for i in range(300):\n",
    "    #SELECT RANDOM WORDS FROM NEUTRAL SENTIWORD\n",
    "    df_neutral = df_senti[df_senti['Sentiment']=='Neutral'].sample(n=20, random_state=random_seeds[i])\n",
    "    neutral_words = list(df_neutral[\"Word\"])\n",
    "\n",
    "    #FETCH DEFINITIONS OF THOSE WORDS\n",
    "    neutral_word_meaning_sentences = []\n",
    "    for i in neutral_words:\n",
    "        a = list(df_senti.loc[df_senti['Word'] == i, 'Definition'])[0]\n",
    "        neutral_word_meaning_sentences.append(a)\n",
    "\n",
    "    #MAKE EMBEDDING OF THESE DEFINITIONS\n",
    "    neutral_p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "    neutral_n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "\n",
    "    for i in neutral_word_meaning_sentences[0:10]:\n",
    "      neutral_p_emb = torch.cat((neutral_p_emb,get_cls(i).unsqueeze(0)), dim=0)\n",
    "\n",
    "    for i in neutral_word_meaning_sentences[10:20]:\n",
    "      neutral_n_emb = torch.cat((neutral_n_emb,get_cls(i).unsqueeze(0)), dim=0)\n",
    "\n",
    "    p_emb = neutral_p_emb[1:]\n",
    "    n_emb = neutral_n_emb[1:]\n",
    "\n",
    "    print('...', end=' ')\n",
    "\n",
    "    p_samples = neutral_words[0:10]\n",
    "    n_samples = neutral_words[10:20]\n",
    "\n",
    "    #EVALUATE ON THESE WORDS\n",
    "    test_acc,_, test_f1 = eval_model(\n",
    "      model,\n",
    "      test_data_loader,\n",
    "      loss_fn,\n",
    "      device,\n",
    "      len(df_test),\n",
    "    )\n",
    "\n",
    "    accuracy.append(test_acc.item())\n",
    "    f1s.append(test_f1.item())\n",
    "    p_word_list.append(p_samples)\n",
    "    n_word_list.append(n_samples)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {
    "executionInfo": {
     "elapsed": 13,
     "status": "ok",
     "timestamp": 1695379584055,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "36UtUdOcDjLK",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import statistics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 245
    },
    "executionInfo": {
     "elapsed": 13,
     "status": "error",
     "timestamp": 1695379584056,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "N_1_hH8S4Hit",
    "outputId": "85d5684e-8de1-402e-9386-f53b050bd477",
    "tags": []
   },
   "outputs": [],
   "source": [
    "stdv = statistics.pstdev(f1s)\n",
    "median = statistics.median(f1s)\n",
    "#filters = [i>median+(2*stdv) for i in f1s]\n",
    "filters = [i>.7 for i in f1s]\n",
    "def filter_2std(target_list, filters):\n",
    "    index = [i for i in range(len(filters)) if filters[i]]\n",
    "    list_a_filtered = [target_list[i] for i in index]\n",
    "    return list_a_filtered\n",
    "\n",
    "p_words_spurious = filter_2std(p_word_list,filters)\n",
    "n_words_spurious = filter_2std(n_word_list,filters)\n",
    "\n",
    "#print(p_words_spurious)\n",
    "#print(n_words_spurious)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "6l78c6yoikRS"
   },
   "source": [
    "Neutral Injection Accuracies"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {
    "executionInfo": {
     "elapsed": 19,
     "status": "ok",
     "timestamp": 1695379585268,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "mmW3cTd4o6Hb",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 175
    },
    "executionInfo": {
     "elapsed": 17,
     "status": "error",
     "timestamp": 1695379585269,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "_sc9N6PqFDAF",
    "outputId": "86645206-6fd6-4dcd-eb48-1555f0dcda27",
    "tags": []
   },
   "outputs": [],
   "source": [
    "(hist, bin_edges) = np.histogram(f1s,bins=15)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {
    "executionInfo": {
     "elapsed": 15,
     "status": "aborted",
     "timestamp": 1695379585271,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "uMGPmojj4SeF",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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RT9PwJgU51xjUpCTo63/nU5KSgranqr09PSgbNcKYROqTp48qTvuuEMxMTF65ZVXFBUVJUkqW7aspKJ7pDIzMyUV3YPlC8MwFBcX5/fzw0lsbKzi4uJk2HXSvl27YqlL3YuoruFwhMVn0tnPE/wPY1LUb8ek4Fe/f+Li4oIWqsL10J/kx4nqhw8ftryJ3NxcDR8+XEeOHNGcOXNUvnx577I6deooKipKe/bsKfScs0k1ISHB8n4AAAB85XOo6tixo+677z598cUXljSQn5+vMWPGaOfOnZozZ45q1qxZaLnL5VLr1q21atWqQvNXrlypypUrq3Hjxpb0AQAAEAifQ9WwYcP0n//8R4MGDVKvXr20ePFi5eTk+N3ApEmT9NFHH2nYsGHKycnRV1995f1z6tQpSdLIkSO1bds2TZw4UZ9//rleeeUVLV68WGPGjOEaVQAAICz4fE7VqFGjNHz4cK1Zs0YLFizQI488omnTpqlPnz668cYbVadOHZ+2949//EOS9OyzzxZZNn/+fLVq1Uqpqal6+eWX9fzzz2v58uWqVq2aJk6cyNXUAQAIEw6XS6kzpnunSyK/TlR3Op269tprde2112rnzp1asGCB3n77bc2bN0/t2rXToEGD1K5duwva1ocffnhB63Xo0EEdOnTwp10AABBkhsOhOB93rFxsAj52lpSUpPbt26tBgwbyeDzauHGj7rzzTvXp00d79+61okcAAICw53eoOnbsmF577TVdddVVGj16tJxOp6ZPn64vvvhCM2fO1OnTpzVhwgQrewUAAGHKk5enAwsX6cDCRdym5kJt2bJFCxYs0OrVq2Wapq699lrdfPPNatKkiXedTp06yel0auTIkZY2CwAAwpNZUKDv335HklSzdy/pv9ebLEl8DlX9+/dXpUqVdOedd+rGG29UxYoVi12vVq1aSk1NDbhBAACASOBzqHr66ad17bXXeq94fi4JCQl68803/W4MAEqaH/bvV1KbNiGve2mVKlq7bFnI6wIXG59DVa9evYLRBwCUeHmGoW+7dg194bVrQ18TuAj5fKL6rFmz9MQTTxS77IknntDrr78ecFMAAACRxudQtXz5cjVo0KDYZY0aNdLy5csDbgoAACDS+ByqfvzxR9WtW7fYZXXq1NEPP/wQaE8AAAARx+dzqi655BIdO3as2GVHjx6VYRgBNwUA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detWzZ8/37vep59+quHDh6t+/foaP368qlevroMHD+qzzz4rss27775b1157rQYMGOANZytWrNDYsWPVtm1bPffcc3K73ZozZ44GDx6sv/zlL7rsssssHwsA4YNQBcAyN9xwQ5F527dvtzxYXXPNNZoyZYpWrlypgQMH6t1331WtWrXUqlWrYkPViBEjvNOmaaply5ZKSEjQoEGDtHPnTjVq1EjSmcOS1atX1+LFixUdHe19Tt++fYts87rrrtPo0aO9jz0ej5555hk1bNhQs2fP9u6Z69Chg7p06aJp06bp7bfftmwMAIQfQhUAyzz99NNKSEgoNM/XQPXbPV1Op1OGYRSaV6pUKXXr1k1LlixR//799d577+mmm24qst5Z33//vV544QVt2rRJR48elWma3mV79uxRo0aNtHfvXh04cED33XdfoUB1Ll27di30eO/evTp06JCGDBlS6FBnqVKl1LVrVy1atIhzr4CLHKEKgGUSEhLOeaL6hWrSpEmhx1OnTlWfPn2KrNevXz/ddNNNevXVV3Xs2LFi15HOfCvwpptuUnR0tO655x7VrVtXMTEx+vnnnzVq1Cjl5ORIko4dOyZJqlq16gX1efZbjWcdP35cklS5cuVi1/V4PMrMzCRUARcxQhWAsPLuu+8WelyrVq1i1/vDH/6gevXqaebMmbryyitVvXr1YtfbtGmTDh06pDfffFNXXHGFd/7JkycLrVehQgVJ0i+//OJX3+XLl5ckHT58uMiyQ4cOyeFwKD4+3q9tA4gMfPsPQFhJSUkp9OdsWCnO8OHD1bFjR912223nXOfsIUGXy1Vo/m/Pb6pXr57q1KmjJUuWyO12+9x3vXr1VLVqVa1cubLQ4cWsrCytXbtWLVq0YC8VcJFjTxWAkDh48KC+/vprSdKBAwckSatXr5Yk1axZ06/Dhr169VKvXr1+d53U1FSVLVtWjz32mEaNGqVLLrlEK1as0K5du4qs++ijj2r48OG64YYbdMstt6h69er66aef9Omnn+q555773ToOh0MPPPCAxo4dq7vuukv9+/eX2+3W66+/rszMTN1///0+vz4AkYVQBSAkPv/8c02YMKHQvDFjxkiSevfuraeeeioodcuXL6/XXntNTz/9tB544AHFxsbqqquu0vTp09W7d+9C67Zr105//etfNXPmTE2ePFm5ubmqVq2aOnXqdEG1evbsqdjYWM2aNUv33nuvnE6nmjdvrvnz56tly5bBeHkAwohh/no/NQAAAPzCOVUAAAAWIFQBAABYgFAFAABgAUIVAACABQhVAAAAFiBUAQAAWIBQBQAAYAFCFQAAgAUIVQAAABYgVAEAAFiAUAUAAGABQhUAAIAF/h9bHf1QeY+9EgAAAABJRU5ErkJggg==",
      "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.816  # 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": null,
   "metadata": {},
   "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('t5_randomizationtest.csv')\n",
    "'''"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "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": 73,
   "metadata": {
    "executionInfo": {
     "elapsed": 33,
     "status": "aborted",
     "timestamp": 1695329093833,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "-nnwzm980k1q",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.29743589743589743\n",
      "F1-Macro:  0.2491747408806977\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).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "for i in neutral_word_meaning_sentences[10:20]:\n",
    "  n_emb = torch.cat((n_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "p_emb = p_emb[1:]\n",
    "n_emb = n_emb[1:]\n",
    "\n",
    "test_acc, _, test_f1 = eval_model(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  loss_fn,\n",
    "  device,\n",
    "  len(df_test)\n",
    ")\n",
    "\n",
    "\n",
    "print(\"Accuracy: \",test_acc.item())\n",
    "print(\"F1-Macro: \",test_f1.item())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093833,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "7cdh2kXd0-Zb",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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UhJFFwAAACmJogsAAICURNEFAABASkqIortz505NmjRJffr0UW5urgoKClRdXR3RvqWlpbrtttv0/e9/X7169VJeXp4WL17czIkBAACQ6Cy/j67X69WECRPUpUsXzZs3T4cOHdLs2bNVWlqquXPnNrpvRUWFxo8fr/T0dM2cOVMdOnTQZ599Jr/f30LpAQAAkKgsL7qLFy+W1+tVUVGRsrOzJUk2m035+fmaMmWKcnJyGtz3kUceUXV1tZYuXSqXyyVJGjBgQIvkBgAAiNW6det033336Te/+Y0GDhxodZyUY/nShTVr1ig3N7e25EpSXl6enE6nVq9e3ei+zz33nC6++OLakgsAAJAMdu3apdtvv135+fnatWuX7rjjjoiXbSJyls/oFhcXa8yYMXXGnE6nunbtquLi4gb32717tw4cOCCPx6Mrr7xS69atU5s2bXTRRRfpxhtvjLr8mqapysrKqPZtjY7+pqyqqpJpmhamQSrjXEst/ECPDd8DyW337t268sordfjw4dqxffv26ZZbbtHtt99uYbLkYJqmDMOIaFvLi67X65XH46k37vF4VFZW1uB+Bw4ckCTdfffdGjZsmB577DHt2LFD99xzj/x+vwoKCqLK4/f7tW3btqj2bY1qampq///27duVnp5uYRqkMs611HL03yeaju+B5Pbkk0/WKbnfeOutt7R69Wp17tzZglTJxel0RrSd5UW3Id/V1kOhkCQpJydHs2fPliTl5uYqEAjo7rvv1rXXXqtOnTo1+fM6HA517949utCt0NGzMj169GAZCZoN51pqYUY3NnwPJLc9e/aEHTdNU8uXL9ddd90V8Yxla7Rjx46It7W86Ho8Hnm93nrj5eXljV6I1r59e0nSueeeW2f83HPPVSgUUnFxcVRF1zAMZWRkNHm/1urob0S32y23221hGqQyzrXUwg/x2PA9kNyysrK0c+fOsK9t2rRJ+/fv18knn9yyoZJIU94/LL8YLScnp95aXJ/Pp127djVadE888UQ5HI5649+sWUpLs/xLAwAAqGfixIlhx51OpwYMGKCTTjqphROlLsvb4KBBg7RhwwaVlJTUjq1atUo+n0+DBw9ucD+n06mBAwdq/fr1dcbXr18vu93O8gMAAJCQcnNzNWPGjDozk3a7Xenp6fXGERvLi+7YsWOVmZmpqVOnau3atSoqKtKs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5BGtX78+6lAAAFjFcBmydWFRLpAKoiq6P/zhDxu94Khbt25RBwIAAADiIaqie+edd9YrupWVlXr33Xf1+uuvq7CwMC7hAAAAgGhFVXRHjx4ddnzcuHEqLCzUnDlz9NRTT8UUDAAAAIhF3FfZDx48WB9++GG8DwsAAAA0SdyLbklJiTp06BDvwwIAAABNErfbi4VCIW3fvl0PP/ywrr322ngdFgAAAIhKVEW3R48eDd51wTRN3XTTTbrpppskSYZhaOvWrdEnBAAAAKIQVdGdNm1ao7cXAwAAAKwWVdGdPn16vHMAAAAAccWzDQEAAGv1caEAACAASURBVJCSIi66t912m/bv39+kg69cuVLLli1rcigAAAAgVhEvXdi5c6eGDh2qH/3oRxo1apTOOeccud3uett99tlnev311/X888/rq6++0ty5c+MaGAAAAIhExEV30aJFeu211/Too49q8uTJstvtOumkk5Sdna309HSVlZVp9+7dKisrk9vt1ujRozVlyhTuqQsAAABLNOlitKFDh2ro0KHaunWr3nzzTW3atEn79u3T/v37lZWVpSFDhqh///4aMmSI2rZt21yZAQAAgO8U1V0XevbsqZ49e8Y7CwAAABA33HUBAAAAKSmqort+/Xq98sortR8fOHBAkydP1sCBA3XDDTeopqYmbgEBAACAaERVdOfNm6fi4uLaj+fMmaN3331Xffv21YoVK/T444/HLSAAAAAQjaiK7n//+9/aNbqBQECrVq1Sfn6+5s+fr2uuuUbLly+Pa0gAAACgqaIquocPH5bH45EkffTRR6qqqtKQIUMkSWeddZa+/PLLJh1v586dmjRpkvr06aPc3FwVFBSourq6ScdYtWqVTj/9dI0YMaJJ+wEAACA1RVV0O3TooP/+97+SpH/961/q0qWLjj32WElSRUWF7PbIb+bg9Xo1YcIEVVRUaN68ebrxxhv14osv6uabb474GNXV1Zo9e7Y6duzYpK8DAAAAqSuq24udf/75uvfee7Vjxw794x//0E9+8pPa1z799FMdf/zxER9r8eLF8nq9KioqUnZ2tiTJZrMpPz9fU6ZMUU5Oznce45FHHlGXLl10wgknaMuWLU3/ggAAAJByoprRnTFjhnr06KG///3vOuOMMzRlypTa11566SX17ds34mOtWbNGubm5tSVXkvLy8uR0OrV69erv3H/Xrl1auHBhk2aAAQAAkPqimtHNzs7WggULwr725JNPyul0Rnys4uJijRkzps6Y0+lU165d69zZoSF33HGHRo0apR49ekT8ORtjmqYqKyvjcqx4aep6ZdRVVVUl0zStjpEUONdiw7kWOc612HCuoTUzTVOGYUS0bVRF92jV1dUqKytThw4dZLfbm/zoX6/XW3th29E8Ho/Kysoa3feNN97Qxo0b9eqrrzbpczbG7/dr27ZtcTtePHBf4ths375d6enpVsdICpxrseFcixznWmw419DaRTqpGnXR3bBhg+69915t3rxZkrR06VKdeeaZuv3225Wbm6sLL7ww2kNL+u62XlNTozvvvFPTp0+vs+whVg6HQ927d4/b8eKBmY/Y9OjRQy6Xy+oYSYFzLTaca5HjXIsN5xpasx07dkS8bVRFd/369briiit06qmn6le/+lWdB0RkZWXp+eefj7joejweeb3eeuPl5eWNXoi2aNEipaWlafjw4bX7+/1+hUIheb1euVyuJi2h+IZhGMrIyGjyfs0p0ul5hOd2u+V2u62OkRQ412LDuRY5zrXYcK6hNWvK+0fUT0YbNGiQioqK9Jvf/KbOaz169ND27dsjPlZOTk69tbg+n0+7du1qtOh++umn+uyzz5Sbm6t+/fqpX79+eumll1RcXKx+/frpueeea9oXBQAAgJQS1Yzutm3b9Oc//1lS/VadnZ2tgwcPRnysQYMG6aGHHlJJSYmysrIkHXn4g8/n0+DBgxvcb/LkyfrpT39aZ+zRRx/Vzp07NXv2bJ188skRZwAAAEDqiWpG12azye/3h33t4MGDatOmTcTHGjt2rDIzMzV16lStXbtWRUVFmjVrlkaOHFlnRnfmzJm1jx2WjswEDxgwoM5/nTp1UkZGhgYMGKBjjjkmmi8NAAAAKSKqoturVy8tW7Ys7GsrVqxQnz59Ij6Wx+PRokWLlJGRoenTp6uwsFAjRoxQQUFBne1CoZCCwWA0cQEAANAKRbV04de//rUmTZqkadOm6Sc/+YkMw9CmTZv03HPPacWKFVq0aFGTjtetW7cG78v7jcLCQhUWFn7nNgAAAIAUZdE977zzVFhYqDvvvFOvv/66JOmPf/yjPB6PZs+erXPOOSeuIQEAAICmivo+uqNGjVJeXp42btyoAwcOKCsrS2effXbC3ZoLAAAArVOTi251dbUuv/xyXXPNNTrvvPOUm5vbHLkAAACAmDT5YjSXy6VPPvlENputOfIAAAAAcRHVXRf69u2rDz/8MN5ZAAAAgLiJqujeeOONWrJkiYqKilRRURHvTAAAAEDMoroY7Re/+IX8fr9+97vf6Xe/+51cLledJ6QZhqH33nsvbiEBAACApoqq6Obl5dV79C8AAACQSKIqujyYAQAAAIkuqjW6AAAAQKKL+oERu3bt0v3336/169ertLRUWVlZOu+88zRt2jR17do1nhkBAACAJouq6BYXF2vs2LGqqanRueeeq86dO2vfvn165ZVX9NZbb+mvf/2rcnJy4p0VAAAAiFhURffee+9V+/bt9dRTT+nYY4+tHd+7d68mTJig++67T/fff3/cQgIAAABNFdUa3X//+9+aPn16nZIrSccee6ymTp2qt99+Oy7hAAAAgGhFVXSrqqrUvn37sK9lZWWpuro6plAAAABArKIqut26ddOLL74Y9rXly5frlFNOiSkUAAAAEKuo1uiOHz9eN998s8rLy/XTn/5UnTp10v79+7Vs2TK98cYbKigoiHdOAAAAoEmiKroXX3yxDh48qIceekirV6+WJJmmKZfLpRkzZmjMmDFxDQkAAAA0VdT30b3yyiv1y1/+Uhs3blRpaanat2+vvn37KjMzM575AAAAgKhEXXQlKTMzU4MGDYpXFgAAACBuoroY7bnnnmvwPrn333+/ioqKYgoFAAAAxCqqovvUU0/J4/GEfS0rK0tPPvlkTKEAAACAWEVVdD/77DOddtppYV/LycnRZ599FlMoAAAAIFZRFV1JKi8vDzt++PBhBYPBqAMBAAAA8RBV0T399NO1fPnysK+99NJLDc72AgAAAC0lqqI7btw4rVixQjfeeKM2bdqkr776Sps2bdJNN92klStX6tJLL413TgAAAKBJorq92MiRI/Xpp5/q0Ucf1bJlyyQdeWCEzWbTlClT9H//939xDQkAAAA0VdT30b322ms1ZswYrVu3TiUlJcrOztbAgQN1/PHHxzMfAAAAEJWoL0aTpBNOOEF5eXk6fPiwXn/9dT3yyCPasWNHvLIBQK1PDpl66T+m3tljKhgyrY4DAEgCEc/o3nXXXXrllVf01ltv1Y5VVlbq4osv1hdffCHTPPKDZ/ny5Vq6dKlOOeWUuIcF0PoEQqYK15ta9/m3Yyd6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43/84x+y2WwKDAw0sSoAnuJiNHikUqVKmjBhgkaMGKEKFSooPj5ektS/f39Xn/Lly2vw4MEaPHiwMjMzNWPGDDVp0kTt2rUzq2yUQJ6ca0BxcTqd+tOf/qTevXvr/PnzmjFjhrp27cqFaEAJQdCFR6pVq6aoqCh98sknOnv2rAICArR48WJVrVrV1SckJEQ1atTQhx9+qIyMDLVp00aTJ082sWqURJ6ca0Bx6devn65evar3339fTqdTISEhmjRpktllAfCQzTAMw+wi8GQbO3asDh8+rE2bNj2yT+fOndWxY0feAFAonpxrQHFp1KiR3n//fQ0aNMjsUgAUEGt0AQAAYEkEXQAAAFgSSxcAAABgSczoAgAAwJIIugAAALAkgi4AAAAsiaALAAAASyLoAgAAwJIIugBQCMeOHdO4cePUuXNnBQYGqnnz5nrzzTcVHx+v9PT0fB1rx44dmjNnzmOqtOidP39ejRo10rp168wuBQByxfZiAFBAa9eu1eTJk1W/fn317t1b/v7+unv3rg4fPqy1a9eqcePGmjt3rsfHmzJlilauXKn//Oc/j7HqouN0OnXkyBHVqVNHVapUMbscAMihjNkFAEBJtH//fkVHR6tNmzaaN2+evL29Xc+1bdtWAwcO1M6dO02s8PG5d++e7t27J29vbzVr1szscgDgkZjRBYACGDp0qHbu3KlvvvlGNWvW/NW+mzdv1hdffKHjx48rIyNDfn5+6tKliyIiIlSuXDlJ0tixY7V+/focY//5z3+qVq1aMgxDq1at0tq1a3Xq1Cn5+PgoODhYo0ePVu3atV39DcNQXFyc1qxZoytXriggIECjRo3SggULJEkJCQmuvj///LP+8pe/aPfu3crMzFTt2rX19ttva8CAASpV6peVbefPn1eXLl0UFRWlrKwsffHFF7p48aIWLFigBg0aqEuXLpo6dap69OjhOu7p06c1Z84cfffdd67jhoeHq2/fvq4+2dnZWrBggTZs2KALFy7I29tbNWvWVM+ePdW/f/8C/IsAQE7M6AJAPt27d09JSUl64YUX8gy50i/Br3379urfv7/sdruSk5MVHx+vgwcPavny5ZKkiIgI3bx5U1u2bNGaNWtcY6tXry5JmjRpktavX69+/fopKipK165d09y5cxUWFqYNGzaoatWqkqTY2FjFxcWpV69eCgkJ0cWL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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": 75,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093833,
     "user": {
      "displayName": "m m",
      "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": 76,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093834,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "J3ymzSst9jH9",
    "tags": []
   },
   "outputs": [],
   "source": [
    "p_spurious_sentences = [list(df_senti[df_senti['Word'] == i]['Definition'])[0] for i in p_words_spurious[0]]\n",
    "n_spurious_sentences = [list(df_senti[df_senti['Word'] == i]['Definition'])[0] for i in n_words_spurious[0]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093834,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "AoDiCBpM6glm",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.8272189349112425\n",
      "F1-Macro:  0.8061116568721637\n"
     ]
    },
    {
     "data": {
      "image/png": "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qjFjxuiEE07Q7t27NX/+fP3ud7/TwoULNXDgwKjq8fv92rRpU1THNpeamhqrS0hqmzdvVnp6utVlAEgSde+53D+SHz9DY5Oo3wNOpzOi/SwPuo2JJK1fc8019V6fddZZGjVqlB588EE9+uijUX1ch8OhHj16RHVsc+G30dj06tXriDN4AMD36t5zuX8kP36GxiYRvwe2bt0a8b6WB12PxyOv19ugvaKioslThGVkZGjYsGFatmxZ1PUYhqGMjIyoj28OkXbPIzy32y232211GQCSRN17LveP5MfP0Ngk4vdAU76mlj+MlpOT02Asrs/n0/bt26OaCzfRxpEAAADAGpYH3aFDh2rNmjUqKyurbVu+fLl8Pp+GDRvWpHNVVlZq5cqV6tu3b7zLBAAAQJKJauhCZWWlPvjgA3300UfatWuXqqurlZWVpR49emjw4MHq2bNnxOfKy8vTokWLNHXqVE2dOlWlpaUqLCzU6NGj6/Xozpo1S0VFRdq4caMk6cMPP9T8+fN1zjnnqGPHjtq9e7eeeOIJ7dmzR//4xz+ieVsAAABIIU0Kul9++aUef/xxLVmyRJWVlTIMQx6PR06nU16vVzU1NTIMQyeeeKImTpyosWPHymY7fKexx+PRggULVFBQoOnTp8vlcmnUqFHKz8+vt18oFFIwGKx93aFDB/l8Pt17770qLy+X2+3WwIEDddttt6lfv35NeVsAAABIQREH3bvuuktPP/20unXrpqlTp+q0005T7969lZb2wyl2796tdevWacWKFbrzzjv15JNPavbs2UccStCtWzfNnz//sPsUFhaqsLCw9nXXrl2PeExKCgWsrqCh78dFJ9KA/0T8PAEAgBYVcdDduHGjnnjiicMuxnDMMcfo3HPP1bnnnqsDBw7oySef1EcffcSY2Thq89H/Wl0CAABAUog46C5atKhJJ87MzNTVV1/d5IIAAACAeIj7PLq7du1SaWmpevfuHe9Tt1oulyumuYGbU3V1tcaMGSNJ+uc//5lwk0pLSsiaAABA84sq6O7cubPRba+//roefvhhrV69OuqiUJ9hGAk3WXM4LpcrKeoEgMasW7dODz30kLxer2w2m1599VWNGzfO6rIARCmqoPuLX/zisKtSdOvWLeqCAACwwsaNG3XFFVfI5/NJOjTbzx133CG/36+8vDyLqwMQjaiC7l133dUg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VbfeeqsuueSSyN8UAAAAUkpUQffCCy9UaWmpHnroodqZEUzTlMvl0nXXXXfYgPpjQ4cO1UMPPaSysjJlZWVJOrT4g8/n07Bhwxo97vLLL9cFF1xQr+2RRx5RSUmJZs+erRNOOKHpbwwAAAApI+p5dK+88kr95je/0ccff6zy8nK1a9dOAwcOVNu2bZt0nry8PC1atEhTp07V1KlTVVpaqsLCQo0ePbre0IVZs2apqKhIGzdulHSoJ/jHQxteeukl7dq1S4MHD472bQEAACBFxLQyWtu2bcOO020Kj8ejBQsWqKCgQNOnT5fL5dKoUaOUn59fb79QKKRgMBjTxwIAAEDrEVXQfeGFF7Rz505Nnz69wbb7779fP/nJT/SrX/0q4vN169ZN8+fPP+w+hYWFKiwsPOI+AAAAgBTlymgLFy4MO/etdGh6saeeeiqmogAAAIBYRRV0t23bphNPPDHstpycHG3bti2mogAAAIBYRb3cS0VFRdj2AwcOMJYWAAAAlosq6P7Xf/2Xli5dGnbbkiVLGu3tBQAAAFpKVEF3/PjxWrZsmWbOnKlPPvlEu3bt0ieffKKbbrpJr7/+uiZMmBDvOgEAAIAmiWrWhdGjR+uLL77QI488opdfflnSoQUj7Ha7pkyZol/+8pdxLRIAAABoqqjn0b322ms1btw4vfvuuyorK1N2draGDBmiTp06xbM+AAAAICpRP4wmSZ07d9aIESN04MABvfHGG3r44Ye1devWeNUGAAAARC3iHt2//vWveu211/T222/XtlVWVurCCy/U119/LdM0JUlLly7Vc889p+7du8e9WAAAACBSEffofvzxxzr//PPrtS1atEhfffWVJk2apA8//FCLFy9WRkaGHn300bgXCgAAADRFxEF3x44dOvnkk+u1vfXWW8rOztYNN9ygzMxMDRgwQL/73e/0/vvvx71QAAAAoCkiDrper1fHHHNM7etAIKD169frtNNOk91ur20/6aSTtGfPnvhWCQAAADRRxEG3ffv22r17d+3rjRs3KhAINOjltdlscjqd8asQAAAAiELEQbdPnz567rnnah86e/nll2UYhnJzc+vt98UXX6hDhw7xrRIAAABooohnXbj88st1ySWX6LzzzlNWVpbWrVunU045RX369Km331tvvaW+ffvGvVAAAACgKSLu0e3fv78efPBBHXPMMTp48KAuuugizZs3r94+e/bs0bfffqvhw4fHvVAAAACgKZq0MtpZZ52ls846q9HtHTp0qF0SGAAAALBSTCujAQAAAImKoAsAAICURNAFAABASiLoAgAAICURdAEAAJCSCLoAAABISQRdAAAApCSCLgAAAFISQRcAAAApiaALAACAlETQBQAAQEoi6AIAACAlEXQBAACQkgi6AAAASEkEXQAAAKQkgi4AAABSEkEXAAAAKYmgCwAAgJRE0AUAAEBKIugCAAAgJRF0AQAAkJIIugAAAEhJBF0AAACkJIIuAAAAUhJBFwAAACmJoAsAAICUlBBBt6SkRJdddpkGDBig3NxcFRQUqLq6+ojH3XPPPRo5cqQGDhyoQYMGady4cVq6dGkLVAwAAIBEl2Z1AV6vV5MmTVLHjh01d+5c7du3T7Nnz1Z5ebnmzJlz2GOrqqqUl5enbt26yTRNLVu2TNdff71CoZBGjx7dQu8AAAAAicjyoLt48WJ5vV4VFRUpOztbkmS325Wfn68pU6YoJyen0WP//Oc/13t95plnauvWrXrppZcIugAAAK2c5UMXVq1apdzc3NqQK0kjRoyQ0+nUypUrm3y+du3aye/3x7NEAAAAJCHLg25xcXGDXlun06kuXbqouLj4iMebpqlAIFDbK/zuu+9q/PjxzVUuAAAAkoTlQxe8Xq88Hk+Ddo/Ho/379x/x+NWrV+t3v/udJCktLU1/+tOfdN5550Vdj2maqqysjPr41qbuQ4NVVVUyTdPCagAki0geOEbjuN9GjmstNol4rZmmKcMwItrX8qDbmEjfRL9+/fT888/rwIEDWrVqle644w7Z7XZddNFFUX1cv9+vTZs2RXVsa1RTU1P7782bNys9Pd3CapDqNmzYoBdffFFjx47VySefbHU5iEHdeweajvtt5LjWYpOo15rT6YxoP8uDrsfjkdfrbdBeUVFx2AfRvpeZmam+fftKknJzc+Xz+VRYWKixY8fKbrc3uR6Hw6EePXo0+bjWqu5vyr169ZLL5bKwGqSqTZs26ZFHHtHq1atlGIYWLlyoZ599lustidHLFhvut5HjWotNIl5rW7dujXhfy4NuTk5Og7G4Pp9P27dv17hx45p8vj59+mjRokXat2+fOnTo0OTjDcNQRkZGk49rrer2urvdbrndbgurQSravHmzrrjiino/rL755hvd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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "for i in p_spurious_sentences:\n",
    "  p_emb = torch.cat((p_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "for i in n_spurious_sentences:\n",
    "  n_emb = torch.cat((n_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "p_emb = p_emb[1:]\n",
    "n_emb = n_emb[1:]\n",
    "\n",
    "test_acc, _, test_f1 = eval_model(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  loss_fn,\n",
    "  device,\n",
    "  len(df_test)\n",
    ")\n",
    "\n",
    "print(\"Accuracy: \",test_acc.item())\n",
    "print(\"F1-Macro: \",test_f1.item())\n",
    "\n",
    "\n",
    "pp,pn,np,nn = eval_scores_average(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  device,\n",
    ")\n",
    "\n",
    "box_plot(pp,pn,np,nn)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093835,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "t-1o_fPd_MEy",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['aquavit akvavit',\n",
       " 'bituminous',\n",
       " 'dairyman',\n",
       " 'pirouette',\n",
       " 'sudanese',\n",
       " 'phrenologist craniologist',\n",
       " 'masa',\n",
       " 'forefoot',\n",
       " 'caucus',\n",
       " 'betaine']"
      ]
     },
     "execution_count": 78,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "n_words_spurious[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "metadata": {
    "executionInfo": {
     "elapsed": 33,
     "status": "aborted",
     "timestamp": 1695329093836,
     "user": {
      "displayName": "m m",
      "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": 79,
     "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": 80,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093836,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "M4c1i-jEnOia",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import os, sys\n",
    "\n",
    "filenames = []\n",
    "\n",
    "path = \"/home/m_nsu/ICLR/Datasets/GoEmotion/bias_criterias\"\n",
    "dir = os.listdir( path )\n",
    "\n",
    "for file in dir:\n",
    "   if(file.endswith('.csv')):\n",
    "    filenames.append(file)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093836,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "uAcBqk9LpYds",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Advocate.csv is Neutral.\n",
      "Positive Acc: 0.5967545121580203 \n",
      "Negative Acc: 0.1922678833074659\n",
      "------------------------------------------------------------------------\n",
      "Dialogue.csv is Positively Spurious.\n",
      "Positive Acc: 0.7614375185525406 \n",
      "Negative Acc: 0.18732972420316102\n",
      "------------------------------------------------------------------------\n",
      "Indian.csv is Positively Spurious.\n",
      "Positive Acc: 0.7202759801242402 \n",
      "Negative Acc: 0.21215318512206932\n",
      "------------------------------------------------------------------------\n",
      "Orientation.csv is Positively Spurious.\n",
      "Positive Acc: 0.6271275832829678 \n",
      "Negative Acc: 0.23241142459191658\n",
      "------------------------------------------------------------------------\n",
      "Colored.csv is Neutral.\n",
      "Positive Acc: 0.3686465655773493 \n",
      "Negative Acc: 0.49309047718373655\n",
      "------------------------------------------------------------------------\n",
      "occupations1950_nonprofessional.csv is Neutral.\n",
      "Positive Acc: 0.44568422423258147 \n",
      "Negative Acc: 0.2371180787689892\n",
      "------------------------------------------------------------------------\n",
      "Society.csv is Positively Spurious.\n",
      "Positive Acc: 0.6738532869990778 \n",
      "Negative Acc: 0.22188040438691714\n",
      "------------------------------------------------------------------------\n",
      "Money.csv is Positively Spurious.\n",
      "Positive Acc: 0.7322646145537827 \n",
      "Negative Acc: 0.2065376978782801\n",
      "------------------------------------------------------------------------\n",
      "Woman.csv is Neutral.\n",
      "Positive Acc: 0.4026726032453312 \n",
      "Negative Acc: 0.2763224153439422\n",
      "------------------------------------------------------------------------\n",
      "Activist.csv is Positively Spurious.\n",
      "Positive Acc: 0.7184096442537482 \n",
      "Negative Acc: 0.23223137624114143\n",
      "------------------------------------------------------------------------\n",
      "Retarded.csv is Positively Spurious.\n",
      "Positive Acc: 0.7836583464341912 \n",
      "Negative Acc: 0.22448515498630153\n",
      "------------------------------------------------------------------------\n",
      "Chubby.csv is Positively Spurious.\n",
      "Positive Acc: 0.6573369635821086 \n",
      "Negative Acc: 0.21546121561824155\n",
      "------------------------------------------------------------------------\n",
      "Jew.csv is Neutral.\n",
      "Positive Acc: 0.43045862658636497 \n",
      "Negative Acc: 0.27169798975454207\n",
      "------------------------------------------------------------------------\n",
      "Homosexual.csv is Neutral.\n",
      "Positive Acc: 0.4565196439589963 \n",
      "Negative Acc: 0.340797455847619\n",
      "------------------------------------------------------------------------\n",
      "Misgendering.csv is Positively Spurious.\n",
      "Positive Acc: 0.730784285613197 \n",
      "Negative Acc: 0.1881968685525187\n",
      "------------------------------------------------------------------------\n",
      "Marriage.csv is Positively Spurious.\n",
      "Positive Acc: 0.7031596973797104 \n",
      "Negative Acc: 0.25353803535138736\n",
      "------------------------------------------------------------------------\n",
      "Industry.csv is Positively Spurious.\n",
      "Positive Acc: 0.8095377116578859 \n",
      "Negative Acc: 0.22344318087359422\n",
      "------------------------------------------------------------------------\n",
      "Oriental.csv is Positively Spurious.\n",
      "Positive Acc: 0.6475149349857425 \n",
      "Negative Acc: 0.24905062143089926\n",
      "------------------------------------------------------------------------\n",
      "occupations1950_professional.csv is Positively Spurious.\n",
      "Positive Acc: 0.7102804639036088 \n",
      "Negative Acc: 0.2450485713768174\n",
      "------------------------------------------------------------------------\n",
      "Gender.csv is Positively Spurious.\n",
      "Positive Acc: 0.6386767955293875 \n",
      "Negative Acc: 0.18567833637415865\n",
      "------------------------------------------------------------------------\n",
      "Media.csv is Neutral.\n",
      "Positive Acc: 0.37615364978971455 \n",
      "Negative Acc: 0.2227495975026847\n",
      "------------------------------------------------------------------------\n",
      "Islam.csv is Positively Spurious.\n",
      "Positive Acc: 0.7358631609055653 \n",
      "Negative Acc: 0.19301367752655949\n",
      "------------------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "for filename in filenames:\n",
    "    df_bias = pd.read_csv('/home/m_nsu/ICLR/Datasets/GoEmotion/bias_criterias/'+filename)\n",
    "\n",
    "    p_spurious_sentences = list(df_bias['Definition'])\n",
    "\n",
    "    p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "    n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "    for i in p_spurious_sentences:\n",
    "      p_emb = torch.cat((p_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "    for i in neutral_word_meaning_sentences[10:20]:\n",
    "      n_emb = torch.cat((n_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "    p_emb = p_emb[1:]\n",
    "    n_emb = n_emb[1:]\n",
    "\n",
    "    test_acc, _, test_f1 = eval_model(\n",
    "      model,\n",
    "      test_data_loader,\n",
    "      loss_fn,\n",
    "      device,\n",
    "      len(df_test)\n",
    "    )\n",
    "\n",
    "    positive_spurious = test_f1.item()\n",
    "\n",
    "    n_spurious_sentences = list(df_bias['Definition'])\n",
    "    p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "    n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "    for i in neutral_word_meaning_sentences[0:10]:\n",
    "      p_emb = torch.cat((p_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "    for i in n_spurious_sentences:\n",
    "      n_emb = torch.cat((n_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "    p_emb = p_emb[1:]\n",
    "    n_emb = n_emb[1:]\n",
    "\n",
    "    test_acc, _, test_f1 = eval_model(\n",
    "      model,\n",
    "      test_data_loader,\n",
    "      loss_fn,\n",
    "      device,\n",
    "      len(df_test)\n",
    "    )\n",
    "\n",
    "    negative_spurious = test_f1.item()\n",
    "\n",
    "    if positive_spurious>=0.6:\n",
    "      print(filename+' is Positively Spurious.')\n",
    "    if negative_spurious>=0.6:\n",
    "      print(filename+' is Negatively Spurious.')\n",
    "    if(positive_spurious<0.6 and negative_spurious<0.6):\n",
    "      print(filename+' is Neutral.')\n",
    "    print('Positive Acc:',positive_spurious,'\\n'+'Negative Acc:', negative_spurious)\n",
    "    print(\"------------------------------------------------------------------------\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093837,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "-uK78aaNYFzK"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093837,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "ySv7ncTicMkQ"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "provenance": []
  },
  "gpuClass": "standard",
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
