{
 "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 BertModel, BertConfig\n",
    "\n",
    "from transformers import *\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "from torch.utils.data import Dataset, DataLoader\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.metrics import f1_score\n",
    "import textwrap\n",
    "import math\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from IPython.display import clear_output\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "clear_output()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "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": 7,
   "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": 8,
   "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": 9,
   "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": 10,
   "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": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_train.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "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": 12,
   "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": 13,
   "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": 14,
   "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": 14,
     "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": 15,
   "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": 16,
   "metadata": {
    "executionInfo": {
     "elapsed": 18,
     "status": "ok",
     "timestamp": 1695323756839,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "UmEtmaFNrakz",
    "tags": []
   },
   "outputs": [],
   "source": [
    "MAX_LEN = 200\n",
    "RANDOM_SEED = 42\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 18,
     "status": "ok",
     "timestamp": 1695323756840,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "6oWORty0p8Xo",
    "outputId": "cb12350b-753a-4c61-c7e8-3c9427f000e9",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n"
     ]
    }
   ],
   "source": [
    "PRE_TRAINED_MODEL_NAME = 'bert-base-uncased'\n",
    "config = BertConfig.from_pretrained(PRE_TRAINED_MODEL_NAME)\n",
    "tokenizer = BertTokenizer.from_pretrained(PRE_TRAINED_MODEL_NAME)\n",
    "clear_output()\n",
    "print(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {
    "id": "yDSL15DQGvrh",
    "tags": []
   },
   "outputs": [],
   "source": [
    "pre_trained_model = BertModel.from_pretrained(PRE_TRAINED_MODEL_NAME).to(device)\n",
    "clear_output()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "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": 20,
   "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": 21,
   "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": 22,
   "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": 23,
   "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": 23,
     "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": 24,
   "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": 25,
   "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": 26,
   "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, 768])\n",
      "torch.Size([11, 768])\n"
     ]
    }
   ],
   "source": [
    "print(p_emb.shape)\n",
    "print(n_emb.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "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": 28,
   "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": 29,
   "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": 30,
   "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": 31,
   "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": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data = next(iter(train_data_loader))\n",
    "data.keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "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 = BertModel.from_pretrained(PRE_TRAINED_MODEL_NAME,config=config)\n",
    "    self.FC = nn.Linear(config.hidden_size,config.hidden_size, bias=False)\n",
    "\n",
    "  def CosineNorm(self, c, b, n_words):\n",
    "    cos = torch.nn.CosineSimilarity(dim=-1, eps=1e-8)\n",
    "    simi = torch.tensor([[1.]*n_words]).to(device)\n",
    "    for i in c:\n",
    "      temp = cos(i,b).to(device)\n",
    "      temp = torch.unsqueeze(temp,0)\n",
    "      simi = torch.cat((simi,temp), dim=0)\n",
    "\n",
    "    return simi[1:]\n",
    "\n",
    "  def binary_output(self,positive, negative):\n",
    "    positive = torch.max(positive,1).values\n",
    "    negative = torch.max(negative,1).values\n",
    "\n",
    "    p_temp = torch.unsqueeze(positive,0)\n",
    "    n_temp = torch.unsqueeze(negative,0)\n",
    "\n",
    "\n",
    "    res = torch.cat((p_temp,n_temp), dim=0)\n",
    "\n",
    "    return torch.t(res)\n",
    "\n",
    "  def forward(self, input_ids, attention_mask, return_scores=False):\n",
    "    with torch.no_grad():\n",
    "      pooled_output = self.bert(\n",
    "        input_ids=input_ids,\n",
    "        attention_mask=attention_mask,\n",
    "        return_dict = False\n",
    "      )\n",
    "    pooled_output = torch.mean(pooled_output[0], dim=1) # Taking Averge pooled last layer embedding\n",
    "\n",
    "    x_sent = self.FC(pooled_output)\n",
    "\n",
    "    Ept = self.FC(p_emb)\n",
    "    Ent = self.FC(n_emb)\n",
    "\n",
    "    positive = F.relu(self.CosineNorm(x_sent, Ept, p_emb.size()[0]))\n",
    "    negative = F.relu(self.CosineNorm(x_sent, Ent, n_emb.size()[0]))\n",
    "\n",
    "    binary_out = self.binary_output(positive,negative)\n",
    "    if(return_scores==True):\n",
    "      return (positive,negative) , binary_out\n",
    "    return binary_out"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {
    "id": "HWZ37gsztWzL",
    "tags": []
   },
   "outputs": [],
   "source": [
    "model = Classifier()\n",
    "model = model.to(device)\n",
    "clear_output()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "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": 35,
   "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": 36,
   "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": 37,
   "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": 38,
   "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": 39,
   "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.7033, 0.7032],\n",
       "        [0.8269, 0.8529],\n",
       "        [0.6716, 0.7203],\n",
       "        [0.7351, 0.7316],\n",
       "        [0.7317, 0.7119],\n",
       "        [0.8407, 0.8207],\n",
       "        [0.7882, 0.7671],\n",
       "        [0.7727, 0.7187],\n",
       "        [0.7382, 0.7447],\n",
       "        [0.8068, 0.8237],\n",
       "        [0.7483, 0.7426],\n",
       "        [0.6943, 0.6435],\n",
       "        [0.6957, 0.7134],\n",
       "        [0.8491, 0.8134],\n",
       "        [0.6675, 0.6300],\n",
       "        [0.7645, 0.7670],\n",
       "        [0.8003, 0.7993],\n",
       "        [0.7649, 0.7740],\n",
       "        [0.7939, 0.8153],\n",
       "        [0.8049, 0.8105],\n",
       "        [0.7431, 0.7304],\n",
       "        [0.7833, 0.7779],\n",
       "        [0.7400, 0.7226],\n",
       "        [0.7147, 0.7244],\n",
       "        [0.7952, 0.7641],\n",
       "        [0.7440, 0.7451],\n",
       "        [0.8331, 0.7711],\n",
       "        [0.7684, 0.7399],\n",
       "        [0.7779, 0.7770],\n",
       "        [0.7991, 0.8171],\n",
       "        [0.6876, 0.6938],\n",
       "        [0.8590, 0.8634]], device='cuda:0', grad_fn=<TBackward0>)"
      ]
     },
     "execution_count": 39,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "outs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "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": 41,
   "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": 42,
   "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": 43,
   "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": 44,
   "metadata": {
    "executionInfo": {
     "elapsed": 8,
     "status": "ok",
     "timestamp": 1695325846656,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "IxncgTh4awi7",
    "tags": []
   },
   "outputs": [],
   "source": [
    "def box_plot(pp,pn,np,nn):\n",
    "  pp = pp.tolist()[0]\n",
    "  pn = pn.tolist()[0]\n",
    "  np = np.tolist()[0]\n",
    "  nn = nn.tolist()[0]\n",
    "  # Create a box plot with beeswarm using seaborn\n",
    "  sns.set(style=\"whitegrid\")  # Set the style of the plot\n",
    "  plt.figure(figsize=(8, 6))  # Set the figure size\n",
    "  ax = sns.boxplot(data=[pp,pn,np,nn], orient=\"v\", palette=\"Set2\")  # Create the box plot\n",
    "  ax = sns.swarmplot(data=[pp,pn,np,nn], orient=\"v\", color=\"0.2\")  # Add the swarm plot\n",
    "\n",
    "  # Set labels for the axes\n",
    "  ax.set_xlabel('Categories')\n",
    "  ax.set_xticklabels(['pp','pn','np','nn'])\n",
    "  ax.set_ylabel('Scores(µ)')\n",
    "\n",
    "  # Set a title for the plot\n",
    "  #plt.title()\n",
    "\n",
    "  # Show the plot\n",
    "  plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "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": 46,
   "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": 47,
   "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.5301399308452637 accuracy 0.7899939783219591\n",
      "Val   loss 0.4827544360975676 accuracy 0.8306227687425625\n",
      "\n",
      "Epoch 2/8\n",
      "----------\n",
      "Train loss 0.48921382695101623 accuracy 0.8181453231633883\n",
      "Val   loss 0.4726928008508079 accuracy 0.8310194367314557\n",
      "\n",
      "Epoch 3/8\n",
      "----------\n",
      "Train loss 0.4802544338936599 accuracy 0.8280810919309515\n",
      "Val   loss 0.4687814033484157 accuracy 0.8385561285204284\n",
      "\n",
      "Epoch 4/8\n",
      "----------\n",
      "Train loss 0.47783600953953226 accuracy 0.8274287434765155\n",
      "Val   loss 0.46536953954757015 accuracy 0.8401428004760015\n",
      "\n",
      "Epoch 5/8\n",
      "----------\n",
      "Train loss 0.47394222178964324 accuracy 0.8318948213568849\n",
      "Val   loss 0.4680943266500401 accuracy 0.8373661245537485\n",
      "\n",
      "Epoch 6/8\n",
      "----------\n",
      "Train loss 0.4718319990853054 accuracy 0.8348554797270173\n",
      "Val   loss 0.4650762149050266 accuracy 0.8385561285204284\n",
      "\n",
      "Epoch 7/8\n",
      "----------\n",
      "Train loss 0.46959471095048405 accuracy 0.8354576475311121\n",
      "Val   loss 0.46278653152381316 accuracy 0.8417294724315748\n",
      "\n",
      "Epoch 8/8\n",
      "----------\n",
      "Train loss 0.4660951740094976 accuracy 0.8401746286631875\n",
      "Val   loss 0.46214067860494684 accuracy 0.8468861562871877\n",
      "\n",
      "CPU times: user 12min 58s, sys: 6.82 s, total: 13min 4s\n",
      "Wall time: 13min 8s\n"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "train_a = []\n",
    "train_l = []\n",
    "val_a = []\n",
    "val_l = []\n",
    "best_accuracy = 0\n",
    "\n",
    "for epoch in range(EPOCHS):\n",
    "\n",
    "  print(f'Epoch {epoch + 1}/{EPOCHS}')\n",
    "  print('-' * 10)\n",
    "\n",
    "  train_acc, train_loss = train_epoch(\n",
    "    model,\n",
    "    train_data_loader,\n",
    "    loss_fn,\n",
    "    optimizer,\n",
    "    device,\n",
    "    scheduler,\n",
    "    len(df_train)\n",
    "  )\n",
    "\n",
    "  print(f'Train loss {train_loss} accuracy {train_acc}')\n",
    "\n",
    "  val_acc, val_loss, val_f1 = eval_model(\n",
    "    model,\n",
    "    val_data_loader,\n",
    "    loss_fn,\n",
    "    device,\n",
    "    len(df_val)\n",
    "  )\n",
    "\n",
    "  print(f'Val   loss {val_loss} accuracy {val_acc}')\n",
    "  print()\n",
    "\n",
    "  train_a.append(train_acc)\n",
    "  train_l.append(train_loss)\n",
    "  val_a.append(val_acc)\n",
    "  val_l.append(val_loss)\n",
    "\n",
    "  if val_acc > best_accuracy:\n",
    "    torch.save(model.state_dict(), 'bert_best_model_state.bin')\n",
    "    best_accuracy = val_acc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "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": 49,
   "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+naQAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nOzde1xUdf7H8feZAQa5lqiIeSNvhaaVmKJrlqWmZdrupnZTstplrdSoLLf9lZpFtWmmJt1EM9uy1mxt1zLKSjfdShOr1cwMwwsuYsnFCzAz5/cHMDECchEYOL6ej8c8Zs73fM85nzNOzZvvOXOOYZqmKQAAAIuw+boAAACAukS4AQAAlkK4AQAAlkK4AQAAlkK4AQAAlkK4AQAAlkK4AQAAlkK4AQAAlkK4AQAAlkK4ASzEMIxqPT755JM62d6JEydkGIaeeOKJWi3fr18/XXXVVXVSS021bt1av//976vs9/7778swDP3nP/+p0frnz5+v5cuX17Y8AKfBz9cFAKg7mzZt8pp+9NFH9fHHH2vdunVe7TExMXWyPYfDoU2bNql9+/a1Wn7x4sWy2+11Ukt9iYuL06ZNm9SjR48aLTd//nx17txZN998cz1VBqAyhBvAQvr16+c13bJlS9lstnLtlSksLJTdbq924DAMo9rrrkj37t1rvWxDCQ8PP619rEsul0sul0sBAQG+LgVo1DgsBZyhSg+3rFixQpMnT1ZUVJQCAwO1d+9eZWZmKiEhQeeff76Cg4MVGRmpK6+8stzIUEWHpZ5//nkZhqHPPvtMd9xxhyIiItSiRQtdf/31+t///ue1/MmHpb777jsZhqEFCxboySefVIcOHRQSEqIBAwZoy5Yt5fZh0aJF6ty5sxwOhy644AK99dZbGjdunM4777xqvw/vvvuuLrzwQjVr1kwxMTHlDiVVdFjq+++/1/XXX6+oqCg5HA61bt1aQ4YM0X//+19JxYe8du/erbVr13oOBZatKT09XTfccINatmwph8OhmJgYzZ8/X2XvY1z6XsybN08zZsxQx44dFRAQoDVr1igkJERTpkwpty87d+6UzWbTggULqr3/gBUxcgOc4e69915deumlevnll+V2u3X22WcrIyND/v7+mjlzpiIjI5WXl6e33npLAwcO1IYNGxQXF1fleidMmKBrr71Wr7/+utLT0zVt2jTdeuutWrNmTZXLzp07VxdccIEWLFggl8ulhx56SMOHD1d6erqCg4MlFR/2mTJlisaNG6f58+fr559/1vTp01VUVKRmzZpVa9+//PJL7dy5Uw8++KBatGih5ORk3XLLLeratasuueSSCpcxTVNXXXWVHA6Hnn76abVr107Z2dnasGGDjhw5Iklas2aNRo0apbZt2+qZZ56RJE9NmZmZiouLk2EYSkpKUtu2bfXOO+9oypQp2rNnj+bOneu1vaeffloxMTGaO3euQkJCFBMTo/Hjx+uVV17R448/7nk/JOm5555TcHCwJkyYUK39ByzLBGBZEyZMMIODgyuc995775mSzKFDh1a5HqfTaRYVFZkDBgwwb7jhBk/78ePHTUlmUlKSpy05OdmUZCYmJnqtY9asWaYk8+eff/a09e3b1xw2bJhneseOHaYkMzY21nS73Z729evXm5LMVatWmaZpmoWFhWZERIQ5aNAgr2388MMPpt1uN7t161blPkVGRprBwcHmgQMHPG35+flmaGioOWXKFE9b6fu0adMm0zRNc9++faYk8/nnnz/l+jt16uS1b6WmTp1qGoZhpqWlebXfeuutps1mM9PT073ei/PPP990Op1efXfs2GEahmEmJyd72vLy8sywsDDzT3/6U5X7Dlgdh6WAM9zvfve7cm2maWrBggW66KKLFBgYKD8/P/n7++uzzz7Tjh07qrXea6+91mu6Z8+ekqSMjIwql73mmmtkGEa5ZX/66SdJ0rfffqvDhw9rzJgxXst16tRJffr0qVZ9ktSnTx9FRUV5poODg9WpUyfPdirSunVrtW/fXo8//rieffZZbdu2TW63u9rbXLdunS666CL16tXLqz0+Pl5ut7vcL9lGjx5d7hyo8847T0OGDNFzzz3naVu2bJlyc3N15513VrsWwKoIN8AZruyXe6mkpCRNnjxZAwcO1Ntvv63PP/9cX375pQYPHqzjx49Xa70RERFe0w6HQ5KqtXxVyx4+fFiSFBkZWW7Zitqqu53SbZ2qRrvdro8//liXX365HnvsMV144YWKjIxUYmKijh49WuU2Dx8+XOF73qZNG8/8sirqK0lTpkzRt99+q/Xr10sqPiR1+eWXN4mTtIH6xjk3wBmu7AhJqeXLl+uqq67S/PnzvdpzcnIaqqxTKg0lJ5+gLEkHDx6s9+2fe+65Wrp0qaTiE3/feOMNPfroo3K73Zo3b94pl42IiFBmZma59gMHDkiSWrRo4dVe0b+PJA0fPlxdunTRwoUL5XQ6tX37ds2aNasWewNYDyM3AMoxDMMzWlJq8+bN+uqrr3xUkbcePXqoefPmWrFihVf77t27tXnz5gat5bzzztOMGTPUtWtXr/enshGgK664QmlpaZ5fVpVatmyZbDabLrvssmpt1zAM3X333Vq1apUeeeQRtW3bVqNHjz6tfQGsgnADoJxrrrlG7777rmbPnq1169Zp4cKFuvrqq9WxY0dflyZJ8vf31yOPPKL169frhhtu0Hvvvafly5dr2LBhatOmjWy2+vtf2xdffKHLL79czz33nNauXat169bpwQcf1M6dOzVkyBBPvwsuuECbN2/W3//+d23evNkTZu6//361bNlSw4YNU0pKitauXas777xTixcv1tSpU9WhQ4dq1xIfH6+goCD9+9//VkJCQqO/ICLQUDgsBaCcGTNmqLCwUIsWLdJjjz2mHj16aMmSJVq2bJnS0tJ8XZ4kafLkybLb7Zo7d67efvttnXvuuZo5c6ZeffVV5ebm1tt227Ztq/bt22vBggXat2+fbDabOnXqpPnz52vSpEmefo899piys7N16623Kj8/X926ddN3332nqKgobdq0SdOnT9f999+vvLw8derUSfPmzdPkyZNrVEtoaKhGjBiht99+W3fccUdd7yrQZBmmWeaqUQDQhB0+fFhdunTRzTffXO58ISs6fvy42rdvr+HDh2vZsmW+LgdoNBi5AdAkZWRkaO7cuRo0aJCaN2+u9PR0zZkzRwUFBbr77rt9XV69ysrK0vfff68XXnhBv/zyi6ZNm+brkoBGhXADoEkKDAzUrl279Prrr+vnn39WSEiI+vfvr6VLl6pLly6+Lq9evf322/rTn/6kc845Ry+99FKNb+oJWB2HpQAAgKX49NdS69ev18iRI9WmTRsZhqF33nmnymU+/fRT9e7dW4GBgTr33HP1/PPPN0ClAACgqfBpuDl69Kh69eqlhQsXVqt/enq6RowYoYEDB2rr1q3685//rMmTJ2vlypX1XCkAAGgqGs1hKcMwtGrVqlNehOqBBx7Q6tWrve5tk5CQoG3btmnTpk0NUSYAAGjkmtQJxZs2bdLQoUO92oYNG6bFixerqKhI/v7+5ZYp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ERRfbbuaRo4cKbfbrX/961/q06ePNmzYoLlz53rm33///Vq7dq2efvppde7cWc2aNdPvf/97FRYWVmv9pmlW2efNN9/UPffcozlz5iguLk6hoaH661//qs8//7za+1G6LeOkw3Gl2y/bfvKJuIZhlDvvqKz4+HgdOnRI8+bNU4cOHeRwOBQXF+d5D5o1a3bKuqqab7PZyr1PRUVF5foFB3uPxlX1vlW1XUkaP368HnzwQW3atEmbNm1Sx44dNXDgwCqXOx2EGwBoqgyjWoeGfK1Zs2b67W9/q9dee00//PCDunbtqt69e3vmb9iwQfHx8bruuuskFZ+Ds2fPnmqvPyYmRq+++qqOHz/u+bL9z3/+49Vnw4YN6t+/vyZNmuRp2717t1efgICAKs9RiYmJ0cqVK71CzsaNGxUaGqpzzjmn2jWfbMOGDVq0aJFGjBghSdq7d6+ys7M983v27Kl9+/bp+++/r3D0pmfPnvroo4+8DiGV1bJlS2VmZnqmc3NzlZ6eXq26TvW+hYaGqmPHjvroo490+eWXV7iOiIgIjR49WkuWLNGmTZt06623Vrnd08VhKQBAvbvpppv0r3/9SykpKbr55pu95nXu3Flvv/220tLStG3bNt14442nHOU42Y033iibzabbbrtN27dv15o1a/T000+X28bmzZu1du1aff/99/q///s/ffnll159OnbsqK+//lo7d+5UdnZ2hSMbkyZN0t69e3X33Xfru+++0z/+8Q898sgjSkxM9JxvUxudO3fWq6++qh07dujzzz/XTTfd5DUqMmjQIF166aX63e9+p9TUVKWnp+u9997T+++/L0maPn26vvzyS02aNElff/21vvvuOyUnJ3sC0uDBg/Xqq69qw4YN+vbbbzVhwgTPYcGq6qrqfZsxY4bmzJmj+fPna9euXfrqq6+0YMECrz633367XnnlFe3YscPzK7n6RLgBANS7wYMHq3nz5tq5c6duvPFGr3nPPPOMzj77bPXv318jR47UsGHDdPHFF1d73SEhIXr33Xe1fft2XXTRRXrooYf05JNPevVJSEjQb3/7W40dO1Z9+/bV4cOHvUYjJOmOO+5Qt27dPOeXlP7ip6xzzjlHa9as0RdffKFevXopISFBt912m/7yl7/U4N0oLyUlRb/88osuuugi3XLLLZo8ebJatWrl1WflypXq06eP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AE1PvV7nJj09vdaFAQAA1Lcah5vOnTvr8ssv1/Lly3XixIn6qAkAAKDWahxutm3bposuukj33nuvWrdurT/+8Y/64osv6qM2AACAGqtxuOnRo4fmzp2r/fv3a8mSJTp48KB+85vfqHv37po7d64OHTpUH3UCAABUS61/Cu7n56frrrtOb775pp588knt3r1b9913n9q2bavx48crMzOzLusEAACollqHm82bN2vSpEmKiorS3Llzdd9992n37t1at26d9u/fr1GjRtVlnQAAANVS4+vczJ07V0uWLNHOnTs1YsQILVu2TCNGjJDNVpyToqOj9cILL+i8886r82IBAACqUuNwk5ycrIkTJ+rWW29V69atK+zTvn17LV68+LSLAwAAqCku4gcAABq9er2I35IlS/TWW2+Va3/rrbf0yiuv1HR1AAAAdarG4eaJJ55QixYtyrW3atVKjz/+eJ0UBQAAUFs1Djc//fSToqOjy7V36NDB6yaXAAAAvlDjcNOqVSt9/fXX5dq3bdumiIiIOikKAACgtmocbsaNG6fJkyfr448/lsvlksvl0rp16zRlyhSNGzeuPmoEAACothr/FHz27Nn66aefdMUVV8jPr3hxt9ut8ePHc84NAADwuVr/FPz777/Xtm3b1KxZM11wwQXq0KFDXddWL/gpOAAATU9Nvr9rPHJTqmvXruratWttFwcAAKgXtQo3+/bt0+rVq5WRkaHCwkKveXPnzq2TwgAAAGqjxuHmo48+0rXXXqvo6Gjt3LlTPXr00J49e2Sapi6++OL6qBEAAKDaavxrqenTp+vee+/Vt99+q8DAQK1cuVJ79+7VoEGDdP3119dHjQAAANVW43CzY8cOTZgwQZLk5+en48ePKyQkRLNmzdKTTz5Z5wUCAADURI3DTXBwsAoKCiRJbdq00e7duz3zsrOz664yAACAWqjxOTf9+vXTZ599ppiYGF199dW699579c033+jtt99Wv3796qNGAACAaqtxuJk7d67y8/MlSTNmzFB+fr5WrFihzp0765lnnqnzAgEAAGqiRuHG5XJp79696tmzpyQpKChIixYtqpfCAAAAaqNG59zY7XYNGzZMR44cqa96AAAATkuNTyi+4IIL9OOPP9ZHLQAAAKetxuHmscce03333ad//vOfyszMVG5urtcDAADAl2p840yb7dc8ZBiG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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": 50,
   "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.8347140039447731\n",
      "F1-Macro:  0.8150549425111414\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": 51,
   "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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AAAAgDPm16oLQ4YMUU1Njdxut6QT0xlO3iHNYrFoy5YtzVdlK2HVBQAAgLatxVddGD16tM/WvwAAAEBb4lfQXbBgQXPXAQAAADQrv+boAgAAAG2d3xtGHDhwQM8995w2btyokpISRUZGavjw4br//vuVkJDQnDUCAAAATeZX0M3JydHEiRNVXV2tYcOGqUuXLsrPz9f777+vTz/9VH/961+VmJjY3LUCAAAAjeZX0H3mmWcUERGhZcuWqVu3bt72o0ePasqUKfrjH/+o5557rtmKBAAAAJrKrzm6//rXvzRz5sw6IVeSunXrphkzZuiLL75oluIAAAAAf/kVdCsrKxUREVHvscjISFVVVZ1RUQAAAMCZ8ivo9urVS++88069x95991317t37jIoCAAAAzpRfc3TvvPNOPf744yorK9PNN9+s2NhYFRQUaNWqVfr444+Vnp7e3HUCAAAATeJX0L3llltUWFioJUuWaP369ZIkwzAUGhqqhx56SBMmTGjWIgEAAICm8nsd3fvuu08/+clPtHXrVpWUlCgiIkJDhgxRp06dmrM+AAAAwC9+B11J6tSpk0aOHNlctQAAAADNxq+X0d56660G18l97rnnlJmZeUZFAQAAAGfKr6C7bNkyORyOeo9FRkbqtddea9L1cnNzNXXqVA0ePFgpKSlKT09v8hJla9eu1XnnnaexY8c2qR8AAADMya+pC/v371e/fv3qPZaYmKj9+/c3+lpOp1NTpkxRXFycFi1apKKiIs2fP18lJSVauHBho65RVVWl+fPnKyYmptH3BQAAgLn5PUe3rKys3vby8nK53e5GX2fFihVyOp3KzMxUVFSUJMlqtSo1NVXTp09XYmLiaa/x4osvKi4uTj169NCOHTsafW8AAACYl19TF8477zy9++679R5bvXp1g6O99dmwYYNSUlK8IVeSRo8eLbvd7l267FQOHDigV199VY8//nij7wkAAADz8yvoTpo0SR9++KEeffRRff3118rLy9PXX3+txx57TGvWrNHkyZMbfa2cnByfUVu73a6EhATl5OSctv/vfvc73Xjjjerfv3+TnwMAAADm5dfUhXHjxmnv3r3685//rFWrVkk6sWGE1WrV9OnTdcMNNzT6Wk6ns94X2xwOh0pLS0/Z9+OPP9bWrVv1wQcfNO0BTsEwDFVUVDTb9QAAANB8DMOQ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iaALAAAAUyLoAgAAwJQIugAAADAlgi4AAABMiaALAAAAUyLoAgAAwJQIugAAADAlgi4AAABMiaALAAAAUyLoAgAAwJQIugAAADAlgi4AAABMiaALAAAAUyLoAgAAwJQIugAAADAlgi4AAABMiaALAAAAUyLoAgAAwJQIugAAADAlgi4AAABMiaALAAAAUyLoAgAAwJQIugAAADAlgi4AAABMiaALAAAAUyLoAgAAwJQIugAAADAlgi4AAABMiaALAAAAUyLoAgAAwJQIugAAADAlgi4AAABMiaALAAAAU7IFugAA5pOVlaVDhw4pKSlJCQkJgS4HAHCWIugCaDYlJSV64IEHtGXLFkmSxWLR+PHjNXv2bAUF8QMkAEDrIugCaBLDMFRdXV3vsfT0dG/I/eHct956S4mJibr99tslSXv37tXRo0fVv39/RUVFNfne0okA3VjV1dX66quvZLPZNGTIENls/v+1FxIS0qR7AwACi6ALoNEMw9CcOXO0Z88en2Mej0c7duyot9/zzz+vd999V/v371d5ebmkE2E1JiZGcXFxLVZvaWmpvv/+e7ndbklScHCwEhIS1LFjR7+u169fP82aNYuwCwDtBEEXQLMwDMM74vrfPB6PDh065A25P5xfUFCgsLAwRUZGyjAMHT9+XC6XS+Hh4QoNDW3UfV0ul44ePaqysjJZrVZFR0crJiZGtbW12r9/f52aampqtG/fPiUlJTGVAgDOAgRdoJ051dSB1vDoo4/K5XLVe+wXv/iFvvrqK5/2m266SW+++Wa9fWJiYjRnzhz96le/Uk5Ojrf9+uuvV1pamoKCglRUVKTXX39db7/9tux2u5588kkNGDBApaWlmjJlioqLiyVJtbW1Onz4sIYNG6ZzzjlHO3fu9Lmf2+3WrbfeqquuuqrJz2632wP6tWfqBAA0jcVoaAjmLJSVlSVJSk5ODnAlQMOqqqp09913B7qMelVWVionJ8c7VUCSQkND1bNnT+3evbvePmFhYbLb7SotLfU5Fh8fL4fDoezsbNXU1HjbLRaLevXqpcrKSh05cqTe68bGxqqgoKDeYz169FB0dHRTHq1NWLp0aaNHugHArJqS1xjRBdBswsLC1L9/fxUXF8vlciksLEwREREKCgpSWFiYKisrffp07NixwUBaXFysqqqqOiFXOjGqffjw4VOGPrvd3uCx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60EJgoB169b1ahqhO5ydnWFmZoaGhgaxF9XFxQUWFhaQy+V6ZzuwsrLqNtXXHTKZDLa2tnqDrkwmg6OjI5qamvTu197evtf1A4C3tzeWL19utB5eTi1GUsGgS0REeslkMqP26qWlpd23h7Wvzp49i6VLl+pMIebh4YHs7GxcuHABq1at6rbNjBkzsGzZMqxZswaffPKJuFwmk2Hp0qWYOXMmLl++jGXLluHKlSsAbgfnJUuWYMaMGX2qk48AJno4OHThLhy6QEQkfeXl5Thw4ACqq6sREBCAl19+GQ4ODgCArKws5OTkoK2tDSYmJpg6dSpSUlKgUCggCALOnTuHM2fOwNLSEtOnT4evr6+43zuP+m1paUFQUFCfnqRGRD3jGN0+YtAlIqKWlhZUVlZi0KBBfX5YBBE9OhyjS0RE1Ec2NjYICAgwdhlE9BAY/cloRERERESPAoMuEREREUkSgy4RERERSRKDLhERERFJEoMuEREREUkSgy4RERERSRKDLhERERFJEoMuEREREUkSgy4RERERSRKDLhERERFJEoMuEREREUkSgy4RERERSRKDLhERERFJEoMuEREREUkSgy4RERERSRKDLhERERFJEoMuEREREUmSmbELeJxoNBoIgoCSkhJjl0JEREREeqjVashkMoPaMujexdA3jYiIiIiMQyaTGZzZZIIgCI+4HiIiIiKifscxukREREQkSQy6RERERCRJDLpEREREJEkMukREREQkSQy6RERERCRJDLpEREREJEkMukREREQkSQy6RERERCRJDLpEREREJEkMukREREQkSQy6RERERCRJDLpEREREJEkMukREREQkSQy6RERERCRJDLpEREREJEkMutSj5ORkREZG4vTp04iMjIS/vz9mzZqF4uJisc3kyZORnp6O7OxsTJgwAaNHj8bixYtx8+ZNI1ZOA01vrrU9e/Zg0qRJePbZZxEfH4+GhgYjVk4DzZ1r7ZtvvsGMGTMQGBiIqKgolJaWim38/Pywa9cubNiwAePGjUNQUBCSk5PR0tJixMppoDH0WsvKysK7776LsLAwhISEYPny5WhrazNi5dLAoEsGqa2tRVpaGhYsWIDNmzdDLpdjwYIFqK+vF9t88cUXOHHiBFJTU5GamoqSkhK88cYbRqyaBiJDrrWCggKcPHkSq1evxsqVK3H+/HmsWbPG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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": 52,
   "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.08481262327416174"
      ]
     },
     "execution_count": 52,
     "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": 53,
   "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": 54,
   "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": 55,
   "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": 56,
   "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.86      0.88      0.87      1603\n",
      "    positive       0.79      0.76      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": 57,
   "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.06      0.09      0.07       131\n",
      "          fear       0.05      0.05      0.05        65\n",
      "     annoyance       0.25      0.04      0.06       194\n",
      "     gratitude       0.04      0.02      0.03       260\n",
      "    admiration       0.16      0.08      0.11       348\n",
      "        caring       0.01      0.01      0.01        86\n",
      " embarrassment       0.04      0.13      0.06        23\n",
      "           joy       0.14      0.14      0.14        93\n",
      "       sadness       0.19      0.19      0.19       102\n",
      "   disapproval       0.29      0.17      0.22       195\n",
      "      optimism       0.09      0.20      0.12       107\n",
      "      approval       0.12      0.01      0.02       236\n",
      "    excitement       0.02      0.04      0.02        57\n",
      "     amusement       0.11      0.24      0.15       186\n",
      "disappointment       0.10      0.08      0.09        88\n",
      "       remorse       0.00      0.00      0.00        44\n",
      "          love       0.04      0.03      0.04       160\n",
      "       disgust       0.09      0.09      0.09        76\n",
      "        relief       0.00      0.00      0.00         7\n",
      "         pride       0.00      0.00      0.00         7\n",
      "         grief       0.00      0.00      0.00         2\n",
      "        desire       0.04      0.04      0.04        56\n",
      "   nervousness       0.00      0.00      0.00        12\n",
      "\n",
      "      accuracy                           0.08      2535\n",
      "     macro avg       0.08      0.07      0.07      2535\n",
      "  weighted avg       0.12      0.08      0.08      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": 58,
   "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.1652859960552268\n",
      "F1-Macro:  0.16012829001169374\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": 59,
   "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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",
      "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": 60,
   "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.8335305719921104\n",
      "F1-Macro:  0.8130544141286602\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": 61,
   "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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kGULAAAAMA+LYRhGsItoL7KzsyVJgwYNCnIlAAAAaIoveS3oSxcAAACA1kDQBQAAgCkRdAEAAGBKBF0AAACYEkEXAAAApkTQBQAAgCkFfR9dAACAc8mhQ4e0bNkyff3113I4HLrpppt02223KSSE+cdAI+gCAAC0kcLCQt15550qLCyUdPKE12eeeUbHjx/X7373uyBXZz4EXQAdRlZWljIyMpScnKwRI0YEuxwAJmEYhmpqatrkWW+//XZ9yD3du+++q9tuu00xMTFtUscpYWFhslgsbfrMtkTQBdAhlJeX67nnnlNlZaWWL1+uSy+9VGFhYcEuC0AHZxiGFixYoH379rXJ844cOdJke21trVJSUhQREdEmdZzSv39/zZ8/37Rhl8UgANq9N998U9dcc42+/vpr7dy5U9nZ2Xr//feDXRYA+Mxutzd7zWaztWEl5waLYRhGsItoL3w5Oxn/h6+T0ZrWr1+v2bNnN2qPj4/Xm2++qR49egShKgBm0pZLF44fP67k5GSVl5c3aL/hhhs0b968NqnhdB1x6YIveY2lC/Bbdna2nnvuOX355Zey2Ww6fPiw3njjDb5ORkC98cYbTbafOHFCf/7znzV37twO95c0gPbFYrEoPDw84ONu375db775po4ePaqBAwdqypQpOv/887Vs2TI9//zz+uqrr2QYhrp06aKHHnqoVWo417F0AX7Zs2ePpk6dqg0bNsjlcqmiokLfffedHn744WCXBpM5evRok+0ej0fffvtts+vdACCY1q9fr7vuukuff/65du3apXfeeUfJyck6dOiQLrroIv3iF79Q37595fF4VFpaqrffflt8yR54BF345eWXX1Z1dXWj9o8//pjggYC67LLLmmwPDw/X8OHDlZCQ0MYVAcCZPf/88/J4PA3aSktLlZGRoW3btul3v/ud/v3vf0uS3G63li5dqtdeey0IlZobSxfgl7179zbZ7nK59NJLL5n6DU60rZkzZ2rdunUqLi5u0N6zZ09NmzaNf88AE2jLNbJtobS0VAcOHGjy2vbt21VYWCi3293o2l//+lf9/Oc/V2jouRPPWnuN8LnzJ4mA6t69e/1voqcLDQ3V3r17deTIEfXs2TMIlcFsEhIS9O6772revHnasWOH7Ha74uLidNttt6l79+7BLg9AANTU1Gj69OnBLiNgDMNQSEhIoxld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ADCfgAfd4uJide3a1ev7R40apa1bt6q4uLi+bd26dXK5XBo9erRPz66srNTGjRvPeEAFAAAAzC9gQdfj8WjXrl168cUXde+993rdb/LkyerUqZNSUlL0xRdfKDMzUwsXLtT48eMbzOjOnTtXAwYMqP/5m2++0axZs/T+++9r69atWrVqlaZMmaKCggLdc889gfpYAAAA6KD8WqN78cUXN7s+wjAMPfTQQ3rooYcknVxH0dK+ug6HQxkZGUpLS9Ps2bMVHh6ucePGKTU1tcF9Ho9Hbre7/ue4uDi5XC499dRTKikpUUREhIYNG6YFC4W7UhYAACAASURBVBZo8ODB/nwsAAAAmIjF8GNR67PPPuvTQmBvTkhrD7KzsyWJpQ8AAADtlC95za8Z3dmzZ/vTDQAAAGgzAX8ZDQAAAGgPvA66jz76qAoKCnwa/NNPP9WqVat8LgoAAAA4W14vXcjLy9N1112nn/70p5o4caJ+9KMfKSIiotF9Bw4c0Oeff673339fx48f1+LFiwNaMAAAAOANr4NuRkaGPvvsM7300kuaOXOmQkNDdf755ys2NlZhYWEqLS3VoUOHVFpaqoiICN18882aNWuWT3vqAgAAAIHi164Lu3bt0t///nd9++23ys/PV3V1tWJiYtS3b19ddtlluvbaaxUdHd0a9bYqdl0AAABo31p914UBAwY0OLwBAAAAaG/YdQEAAACm5FfQ3bJliz7++OP6n0+cOKGZM2fqqquu0gMPPKCampqAFQgAAAD4w6+gu2TJEuXm5tb//OSTT+qbb77RsGHDtHbtWr3yyisBKxAAAADwh19B9/vvv69fo1tXV6d169YpNTVVzz33nObMmaM1a9YEtEgAAADAV34F3fLycjkcDknSzp07VVVVpWuvvVaSNHjwYB09ejRwFQIAAAB+8Cvodu3aVd9//70k6csvv1RCQoJ69OghSaqoqFBoqF+bOQAAAAAB41civfrqq/X0008rJydHH3zwgW666ab6a/v371fPnj0DViAAAADgD7+C7n333acjR47o7bff1uDBgzVr1qz6ax999JGGDRsWsAIBAAAAf/h1MlpLysvLZbfbZbfbAzlsm+BkNAAAgPbNl7x21gdGVFdX6/jx46qrq5MkRUdHd8iQCwAAAHPxO+hu3bpVv/zlLzV8+HBdc8012rt3ryRpwYIF+vTT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iImJASA3N5edO3dSU1ODr68vSUlJzJ07t7dfosj/Owq6t0lBV0TE2J588knOnDnTqT0sLIysrCzmzZvHt99+a2l3dXVl/fr1hIaGMmzYsE5ratva2qipqcHHx0f7zor0kp7kNbvvuiAiItKVu7F04rsh9ub2nJycTs+3tLSQnZ3Nzp07b7lHrre3Nx0dHXR0dNyxOrV0QOTOUNAVEZF7jtlsJiMjg5MnT97R8zo5OXUZWK9du8b+/fu7PObkyZPMmzevV/e6DQsLY+3atQq7Ij+Q3XddEBER6S3+/v6dwqPJZMLf399yx7ObmUyme3YbMBH5fprRFRGRe47JZGLt2rV3ZdeH//73v+Tn53P69GmCg4NJTEwkLCyMw4cPs3r16k79Z86cyYoVK+54Hd9HSxdE7gwFXRERuSeZTCarbSbvlMjISCIjIzu1P/7441RWVpKbm8uVK1dwcHDg4YcfZvny5XelDhG5+xR0RURE/teiRYuIj4+nvLycH/3oR7qluUgfp6ArIiLyHZ6enowZM8beZYjIHaDV9SIiIiJiSAq6IiIiImJICroiIiIiYkgKuiIiIiJiSAq6IiIiImJICroiIiIiYkgKuiIiIiJiSAq6IiIiImJICroiIiIiYkgKuiIiIiJiSAq6IiIiImJICroiIiIiYkgKuiIiIiJiSAq6IiIiImJICroiIiIiYkgKuiIiIiJiSAq6IiIiImJITvYu4F7S1taG2WymtLTU3qWIiIiISBdaW1sxmUw29VXQ/Q5bP2kiIiIiYh8mk8nmzGYym83mu1yPiIiIiEiv0xpdERERETEkBV0RERERMSQFXRERERExJAVdERERETEkBV0RERERMSQFXRERERExJAVdERERETEkBV0RERERMSQFXRERERExJAVdERERETEkBV0RERERMSQFXRERERExJAVdERERETEkBV0RERERMSQFXRERERExJAVd6VZaWhqxsbF8/PHHxMbGEhERwaxZsygpKbH0mTZtGuvWrSMnJ4cpU6YwduxYli5dysWLF+1YufQ1PRlrb731Fg899BAPPPAAycnJVFdX27Fy6WtujLXPP/+cmTNnMm7cOGbPnk1ZWZmlT3h4ONu3b+fVV19l4sSJREZGkpaWRmNjox0rl77G1rGWnZ3Nn/70J6Kjo4mKiuLFF1/kypUrdqzcGBR0xSZVVVVk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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": 62,
   "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": 63,
   "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": 64,
   "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": 65,
   "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": 66,
   "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.8366863905325443\n",
      "F1-Macro:  0.8194121604441325\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": 67,
   "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": 68,
   "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": 69,
   "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": 70,
   "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": 71,
   "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": 72,
   "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": 7,
   "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": 5,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "f1s = list(pd.read_csv('/home/m_nsu/ICLR/bert_randomizationtest.csv')['f1s'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "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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IipVsroNSzEVCAAAYBKOWAEAAFO48/O1/4W/SpIajbiVW9oAAAD4yigs1M/vbNDP72wI21vacMTqMvPDwYNK6NAh4HW54jsAAASry06+zcYV3wEAsAhTgQAAACYhWAEAAJiEYAUAAGASghUAAIBJOHkdAACYwu506v8WPed5HI4IVgAAwBQ2u11RtWpa3YalmAoEAAAwCUesAACAKdz5+Tr4yquSpCuH3sItbQAAAHxlFBbqx3V/04/r/ha2t7QhWAEAAJiEYAUAAGASghUAAIBJvA5WR48e9UcfAAAAIc/rYNW1a1fdd999+vzzz/3RDwAAQMjyOliNHj1a//nPfzR06FD16dNHq1atUm5urj96AwAACCleB6tx48bpo48+0qxZs1ShQgU9/PDD6tKli5566illZmb6o0cAABAC7E6nUubPVsr82WF7SxufTl53OBy64YYbtHz5cq1bt06pqal67bXX1LNnT915553avHmz2X0CAIAgZ7PbFdOggWIaNJDNHp6fjyvzq05ISFDnzp3VpEkTud1ubdmyRaNGjVL//v21f/9+M3oEAAAICT4HqxMnTmjhwoW67rrrNH78eDkcDs2ePVuff/650tPTde7cOT300ENm9goAAIKYOz9fmStWKnPFSrnz861uxxJe3ytw+/btWr58uTZs2CDDMHTDDTfoj3/8o5o3b+5Zp1u3bnI4HBo7dqypzQIILz8cPKiEDh18+l7D7Vaey6VIp9PrKYkra9bUu2vX+lQXoSG1Xz8dPHKkyLKy7DOX6nLft4zCQn3/2uuSpLr9+khheK9Ar4PVoEGDVL16dY0aNUo333yzqlWrVuJ69erVU0pKSpkbBBC+8m02fZuaGvjC774b+JoIqINHjrBvwS+8DlZPPfWUbrjhBkVcJIXGxcXp5Zdf9rkxAACAUON1sOrTp48/+gAAAAh5Xk8iL1q0SI8//niJzz3++ON64YUXytwUAABAKPI6WK1bt05NmjQp8blmzZpp3bp1Xm3vnXfe0ZgxY9SlSxe1bt1avXv31quvviq3211kvU2bNqlv375KTk5Wjx49tHz5cm9bBwAA8CuvpwJ//PFHNWzYsMTnGjRooB9++MGr7S1dulR16tTRpEmTVK1aNX322WeaPn26vv/+ez344IOSpG3btmnMmDHq06ePJk+erC+++ELTpk2T0+nUjTfe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/9Djjz+uRo0aaefOnZo3b55iY2OL/a6FE4JVAMTGxiorK6vY8jNnzhQ7BFuaTz75RA899JBGjBhxWR1mLevYVKhQQcnJyZLO/yFwuVx68skn1b9/fzkcDtP7DRRfx+Wll16S3W5Xr169PN+fn58vt9utrKwsRUVFyel0+q3vQDDj9+mCmJgYdenSRRs3bjSrPUv5OjaVK1eWJLVr167I8nbt2sntdmvv3r0hHazM2GfOnTunf/zjHxo4cGBIv7f8mq9j8+233+rFF1/UggULdN1110k6f0TYZrPp6aef1pAhQ1StWjW/9R3MOMcqAOLi4orNVbtcLmVmZl7SL/VXX32lcePGqWfPnnrggQf81aYlyjo2v9a8eXOdPXtWJ06cMKtFS/g6Lvv27dPBgwfVvn17XX311br66qu1fv167d27V1dffbVWr17t79b9zux95nI60dbXsalfv74iIiKKLb8wNnZ7aP+pMGOfee+995STkxPyl3L5NV/HJiMjQ5KUmJhYZHliYqIKCgp06NAh85sNEaH92xIiOnfurK1bt+rkyZOeZe+9955cLpe6dOnym9+7d+9ejRw5Um3atNGMGTO8OmwdCsoyNiX5/PPPVaFCBVWpUsXMNgPO13EZOXKkli1bVuRfx44dVbduXS1btuyy+CSTmftMdna2Nm3a5DnqGep8HRun06kOHTpoy5YtRZZv2bJF5cqVU3x8vN96DgQz9pn169erQYMGatWqlb/atISvY1O3bl1JKnbB6h07dki6fK4N5xNrrvIQXk6fPm106tTJGDx4sPHxxx8ba9euNdq2bWvcf//9RdZ76KGHjMTERM/Xx44dM7p06WJ06NDB+PTTT41t27Z5/u3cuTPQL8MvfB2bXbt2GSNGjDBWrVplfPrpp8b7779v/PnPfzaaNm1qLFy4MNAvw3S+jktJLrfrWPk6Nv/+97+N0aNHG6tXrza2bNlivPnmm0bfvn2N5s2bG9u3bw/0y/CLsuw327dvN5o3b2488MADxubNm42lS5carVq1MqZPnx7Il+AXZf19On78uJGUlGTMnj07UC0HjK9jU1BQYAwcONBo37698eqrrxpbtmwxFi1aZLRu3dq45557Av0yggrnWAVAbGysXnrpJU2bNk133323oqKilJaWpokTJxZZz+12q7Cw0PN1RkaGfvrpJ0nSrbfeWmTdunXr6sMPP/R77/7m69hUr15dsbGxWrBggY4ePaqKFSuqcePGSk9PV/fu3QP9Mkzn67iEA1/HpkaNGnK5XHr22Wd16tQpRUdHKyUlRX/5y1/UsmXLQL8MvyjLftOyZUstXLhQs2bN0ujRo1W5cmUNHTpUEyZMCORL8Iuy/j698847KigouOymASXfx8bhcOj555/X3LlztXjxYh07dky1a9fW0KFDNXr06EC/jKBiM4zL6AQDAAAAC3GOFQAAgEkIVgAAACYhWAEAAJiEYAUAAGASghUAAIBJCFYAAAAmIVgBAACYhGAFoMzWrFmjhISEEv899dRTkqSPPvpIkyZNUu/evdW8eXMlJCR4VeOHH37wbHP+/PklrvPQQw951gEAK3DldQCmmTFjhho3blxkWc2aNSWdv//Y9u3blZiYqIiIiGL3GLtU5cuX19q1azV27NgiNwc+d+6cNmzYoAoVKujs2bO+vwgAKAOCFQDTNGnSpNQbGk+bNs0ThKZOnepzsLrhhhu0atUqbdmyRR06dPAsf/vtt+V2u9W9e3f97W9/82nbvsrJyVF0dHRAawIITkwFAgiIXx5dKotGjRopJSVFq1evLrJ89erV6tGjhypWrFjse95++23dfvvt6tixo1q2bKnf//73mjlzprKzs4utu337do0ePVpt27ZVcnKyunfvrunTp3uenz9/vhISErRz506NHz9eV199tXr06OF5/oMPPtCgQYPUqlUrpaSk6LbbbtO2bdtMee0Agh9HrACYxu12q6CgoMiycuXMf5sZOHCgpk6dqtOnT6tSpUrat2+ftm3bpnvuuUfvvvtusfUPHDigzp07a/jw4YqOjta+ffu0ePFiffXVV1q2bJlnvc2bN+uuu+5S48aNNXnyZNWuXVuHDh3SJ598Umybd999t2644QYNHjzYE9DeeustTZw4UR07dtSsWbPkcrm0ZMkSDRs2TH/961911VVXmT4WAIILwQqAaW666aZiy3bu3Gl6uPr973+v6dOna/369RoyZIjeeOMN1atXT23bti0xWI0ZM8bz2DAMtWnTRnFxcRo6dKh2796tZs2aSTo/RVm7dm2tWrVKkZGRnu8ZMGBAsW327dtX48eP93ztdrv19NNPq2nTplq8eLHnCF2XLl3Uo0cPzZw5U6+99pppYwAgOBGsAJjmqaeeUlxcXJFl3oaqXx/xcjgcstlsRZaVL19ePXv21OrVqzVo0CC9+eabuuWWW4qtd8H333+vOXPmaOvWrTp+/LgMw/A8t2/fPjVr1kz79+9XZmam7rvvviKhqjSpqalFvt6/f7+OHDmi4cOHF5n2LF++vFJTU7Vy5UrOxQLCAMEKgGni4uJKPXn9UjVv3rzI1zNmzFD//v2LrTdw4EDdcsstev7553XixIkS15HOf1rwlltuUWRkpO655x41bNhQUVFR+vnnnzVu3Djl5uZKkk6cOCFJqlWr1iX1eeHTjhecPHlSklSjRo0S13W73crKyiJYAZc5ghWAoPLGG28U+bpevXolrvd///d/atSokdLT03Xttdeqdu3aJa63detWHTlyRC+//LKuueYaz/IzZ84UWa9q1aqSpMOHD/vUd5UqVSRJR48eLfbckSNHZLfbFRsb69O2AYQOPhUIIKgkJycXUS9DzAAAAbVJREFU+XchsJTkrrvuUteuXXX77beXus6F6UGn01lk+a/Pd2rUqJEaNGig1atXy+Vyed13o0aNVKtWLa1fv77IVGN2drbeffddtW7dmqNVQBjgiBWAgDh06JC+/vprSVJmZqYkacOGDZKkunXr+jSF2KdPH/Xp0+c310lJSVGlSpX06KOPaty4cSpXrpzeeust7dmzp9i6jzzyiO666y7ddNNNuvXWW1W7dm399NNP2rx5s2bNmvWbdex2ux544AFNnDhRd955pwYNGiSXy6UXXnhBWVlZuv/++71+fQBCD8EKQEB89tlneuihh4osmzBhgiSpX79+evLJJ/1St0qVKlq4cKGeeuopPfDAA4qOjtZ1112n2bNnq1+/fkXW7dSpk1555RWlp6dr2rRpysvL0xVXXKFu3bpdUq3evXsrOjpaixYt0r333iuHw6FWrVpp2bJlatOmjT9eHoAgYzN+ecwaAAAAPuMcKwAAAJMQrAAAAExCsAIAADAJwQoAAMAkBCsAAACTEKwAAABMQrACAAAwCcEKAADAJAQrAAAAkxCsAAAATEKwAgAAMAnBCgAAwCT/H6H36c7nivYxAAAAAElFTkSuQmCC",
      "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.815  # Change this to the desired position\n",
    "plt.axvline(x=vertical_line_position, color='r', linestyle='--', label='Vne')\n",
    "plt.text(x=vertical_line_position,y=max(hist),s='Native',ha='left', va='bottom')\n",
    "\n",
    "    \n",
    "plt.xlabel(\"F1-Macro\")\n",
    "plt.ylabel(\"frequency\")\n",
    "\n",
    "#plt.title(\"bert-base\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "'''\n",
    "df_randomization_test = pd.DataFrame(list(zip(f1s, accuracy,p_word_list,n_word_list)),\n",
    "               columns =['f1s', 'accuracy','p_word_list','n_word_list'])\n",
    "df_randomization_test.to_csv('bert_randomizationtest.csv')\n",
    "'''"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 115,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_neutral = df_senti[df_senti['Sentiment']=='Neutral'].sample(n=20, random_state=random_seeds[16])\n",
    "neutral_words = list(df_neutral[\"Word\"])\n",
    "\n",
    "#FETCH DEFINITIONS OF THOSE WORDS\n",
    "neutral_word_meaning_sentences = []\n",
    "for i in neutral_words:\n",
    "    a = list(df_senti.loc[df_senti['Word'] == i, 'Definition'])[0]\n",
    "    neutral_word_meaning_sentences.append(a)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "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.6094674556213018\n",
      "F1-Macro:  0.5524629333587217\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "for i in neutral_word_meaning_sentences[0:10]:\n",
    "  p_emb = torch.cat((p_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "for i in neutral_word_meaning_sentences[10:20]:\n",
    "  n_emb = torch.cat((n_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "p_emb = p_emb[1:]\n",
    "n_emb = n_emb[1:]\n",
    "\n",
    "test_acc, _, test_f1 = eval_model(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  loss_fn,\n",
    "  device,\n",
    "  len(df_test)\n",
    ")\n",
    "\n",
    "\n",
    "print(\"Accuracy: \",test_acc.item())\n",
    "print(\"F1-Macro: \",test_f1.item())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 117,
   "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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6KwLXq9X9957r+69915JJwb1N2deXQAAAMAffAq6t956a0jd8xsAAACtj09Bd/bs2f6uAwAAAPArbi4NAAAAU2py0H3ggQeUl5fXrJ2///77evvtt5tdFAAAAHCmmjx0ITc3V5dffrmuuOIKXX311brgggsUERFRb709e/boww8/1IoVK3T48GEtWLDArwUDAAAATdHkoLtkyRJ98MEHeuGFFzRjxgyFh4fr7LPPVmxsrBwOh4qKivTjjz+qqKhIERERmjRpkmbOnMmcugAAADBEsy5Gu/zyy3X55ZcrKytLa9eu1ddff60jR44oLy9PMTExGj16tC688EKNHj1aUVFRLVUzAAAAcFo+zbrQt29f9e3b19+1AAAAAH7DrAsAAAAwJZ+C7saNG7Vq1arax0ePHtWMGTM0YsQI3X333aqoqPBbgQAAAIAvfAq6CxcuVE5OTu3jRx55RF988YUGDx6s1atX66WXXvJbgQAAAIAvfAq6P/zwQ+0Y3erqaq1Zs0YpKSl66qmndPvtt+vdd9/1a5EAAABAc/kUdEtKSuRyuSRJ3377rcrKyjR69GhJ0oABA3Tw4EH/VQgAAAD4wKeg2759e/3www+SpE8//VTx8fHq1KmTJOn48eMKD/dpMgcAAADAb3xKpBdffLEef/xxZWdn66233tLEiRNrl+3evVtdunTxW4EAAACAL3wKunfeeacOHDigf/zjHxowYIBmzpxZu2zlypUaPHiw3woEAAAAfOFT0I2NjdWiRYsaXPbqq6/KbrefUVEAAADAmTrjG0aUl5fr8OHDqq6uliRFRUURdAEAAGA4n4Pupk2b9Otf/1pDhgzRpZdeqp07d0qSHnzwQb3//vt+KxAAAADwhc93Rps+fboqKip00003yePx1C6LiYnRihUr/FYgAAAA4Auf74w2cuRIZWZm6ve//32dZb1799Z3333nl+IAAAAAX/kUdHfs2KHk5GRJksViqbMsNjZWx44dO/PKAAAAgDPgU9C1Wq2qqqpqcNmxY8fUpk2bMyoKAAAAOFM+Bd3+/fvr7bffbnDZ6tWrNWjQoDMqCgAAADhTPs2je/PNN2v69Om69dZbNXHiRFksFn399dd68803tXr1ai1ZssTfdQIAAADN4lPQveiii5Senq758+frww8/lCT9+c9/lsvlUlpami644AK/FgkAAAA0l09B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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": 104,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093833,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "1MTPlFIVEd6y",
    "tags": []
   },
   "outputs": [],
   "source": [
    "max_f1_index = f1s.index(max(f1s))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "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[max_f1_index]]\n",
    "n_spurious_sentences = [list(df_senti[df_senti['Word'] == i]['Definition'])[0] for i in n_words_spurious[max_f1_index]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "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.8335305719921104\n",
      "F1-Macro:  0.818038012859357\n"
     ]
    },
    {
     "data": {
      "image/png": "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JwsVZrHo8MkzX37QrCIjIxURERGy5zPjew3+CfV7rb46/WeM77n/qjIRanjRTUxMLLcWt7i4WHv37i23drciP/74o+6//35dc801euihh2oqJlArFZd6JdX9dXSNoiv/y73QXaopS79Wyf9deuGX46f0/NotOuUu0fAL24QqomF+/TMGUJdlZ2fr008/ldvtVv/+/dW6dWujI9Ubhhfdvn376pVXXlFubq7i4uIkSatWrVJxcbH69et3xn2zsrI0btw49ezZU2lpaVVq+IAZPLbxoNERgsLj8chut5e7woLD4dCSbYfKSu7pXv86UxtP2vm5B1Crffzxx3riiSdUWvrreQYvvfSS7rvvPo0ePdrgZPWD4Z9LJScnKyYmRhMmTNAXX3yh9PR0TZ8+XUOHDvVZujB16lR17ty57OucnByNHTtWNptNd911l3766Sd9//33+v77EfExRAAAF/1JREFU77V161YjXgqAAIWFhalt27aKiYkpG3M6nWrbtm2l60RLSkrK/uEAgNooLy9PTz31VLm/q/7+979X+cpSCIzhM7pOp1MLFixQamqqJk6cqIiICA0ZMkQpKSk+23k8Hp83SmZmpg4e/HU2a9SoUT7bNm/eXJ9//nmNZweM4HA4NH/+fKNj1Jj8/HxZLJay62Q/8sgjWrlyZbntmjRpotdff11WqzXUEQ3DiSpA3bJ+/fr/397dR8d85v8ff43cE0EI0ahSieipuGnZuCl1c1S7TXdVKYJGNhykUd1tECWSWKfoYWnVvay2bhqR42ZZh6Vulq20p+3qJrVhNdbthhS5cZtJfH5/+JlvR6KZKDPy8Xyck3PMNdfnM+9MPjKvuXJd19z1zfru3bs1fPhwJ1f06HF50JWk5s2bKzU19Wf7zJo1S7NmzbLdDg8P15EjRx50acBDx2KxmHrBgre3twoKCmz/HjlypPbu3VtuWsOoUaNUq5Z5txIDUP393BtxFns6B88ygIfG119/rYEDB6pr167q0qWLEhMT1axZM/35z39Wp06d5ObmJm9vb02fPl2RkZGuLhcAftZzzz1X4U5OFotFAQEBGjVqlI4eParc3FytX7/eBRWa30MxogsAJ0+e1JgxY3Tt2jVJt/aX3LBhg4qKivTBBx9o4cKF+t3vfidJevnll11ZKgCTMQzjgewb7e7ursTERKWkpOj69VvbIrq5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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": 106,
   "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": [
       "['raft_foundation',\n",
       " 'sulky',\n",
       " 'torch',\n",
       " 'northwestern northwesterly northwest',\n",
       " 'table-tennis_racquet table-tennis_bat pingpong_paddle',\n",
       " 'script playscript book',\n",
       " 'flow',\n",
       " 'rock_of_gibraltar gibraltar calpe',\n",
       " 'creek_confederacy',\n",
       " 'usher show#']"
      ]
     },
     "execution_count": 106,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "n_words_spurious[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "metadata": {
    "executionInfo": {
     "elapsed": 33,
     "status": "aborted",
     "timestamp": 1695329093836,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "lvMoMpyEXQVt",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['individualist',\n",
       " 'instantiate',\n",
       " 'buhl boulle boule',\n",
       " 'optician lens_maker',\n",
       " 'pocket_borough',\n",
       " 'discovered_check',\n",
       " 'solanum_jasmoides potato_vine',\n",
       " 'genus_ascophyllum ascophyllum',\n",
       " 'readying preparation',\n",
       " 'enemy']"
      ]
     },
     "execution_count": 107,
     "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": 83,
   "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": 84,
   "metadata": {
    "executionInfo": {
     "elapsed": 32,
     "status": "aborted",
     "timestamp": 1695329093836,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "uAcBqk9LpYds",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Advocate.csv is Positively Spurious.\n",
      "Positive Acc: 0.7442277978493754 \n",
      "Negative Acc: 0.1926682607971088\n",
      "------------------------------------------------------------------------\n",
      "Dialogue.csv is Positively Spurious.\n",
      "Positive Acc: 0.795307651349868 \n",
      "Negative Acc: 0.17815528087536062\n",
      "------------------------------------------------------------------------\n",
      "Indian.csv is Positively Spurious.\n",
      "Positive Acc: 0.6026092825070288 \n",
      "Negative Acc: 0.4731548724088669\n",
      "------------------------------------------------------------------------\n",
      "Orientation.csv is Positively Spurious.\n",
      "Positive Acc: 0.7943917767735169 \n",
      "Negative Acc: 0.1778215628090133\n",
      "------------------------------------------------------------------------\n",
      "Colored.csv is Positively Spurious.\n",
      "Positive Acc: 0.6354568724182916 \n",
      "Negative Acc: 0.37636581903706257\n",
      "------------------------------------------------------------------------\n",
      "occupations1950_nonprofessional.csv is Positively Spurious.\n",
      "Positive Acc: 0.7751970681086078 \n",
      "Negative Acc: 0.1701125979169698\n",
      "------------------------------------------------------------------------\n",
      "Society.csv is Positively Spurious.\n",
      "Positive Acc: 0.7672848005596581 \n",
      "Negative Acc: 0.19018920620711138\n",
      "------------------------------------------------------------------------\n",
      "Money.csv is Positively Spurious.\n",
      "Positive Acc: 0.7155108835802722 \n",
      "Negative Acc: 0.20646070412010467\n",
      "------------------------------------------------------------------------\n",
      "Woman.csv is Positively Spurious.\n",
      "Positive Acc: 0.6713060078745283 \n",
      "Negative Acc: 0.35736747127736723\n",
      "------------------------------------------------------------------------\n",
      "Activist.csv is Positively Spurious.\n",
      "Positive Acc: 0.65595083041886 \n",
      "Negative Acc: 0.305288964245287\n",
      "------------------------------------------------------------------------\n",
      "Retarded.csv is Positively Spurious.\n",
      "Positive Acc: 0.6824754659491721 \n",
      "Negative Acc: 0.3303057692967637\n",
      "------------------------------------------------------------------------\n",
      "Chubby.csv is Positively Spurious.\n",
      "Positive Acc: 0.7223161489510451 \n",
      "Negative Acc: 0.27239933547228234\n",
      "------------------------------------------------------------------------\n",
      "Jew.csv is Positively Spurious.\n",
      "Positive Acc: 0.673359636283101 \n",
      "Negative Acc: 0.3844341715508439\n",
      "------------------------------------------------------------------------\n",
      "Homosexual.csv is Positively Spurious.\n",
      "Positive Acc: 0.6801533497158339 \n",
      "Negative Acc: 0.31113101187677006\n",
      "------------------------------------------------------------------------\n",
      "Misgendering.csv is Positively Spurious.\n",
      "Positive Acc: 0.6257817091076874 \n",
      "Negative Acc: 0.330385999520901\n",
      "------------------------------------------------------------------------\n",
      "Marriage.csv is Positively Spurious.\n",
      "Positive Acc: 0.7245482510047351 \n",
      "Negative Acc: 0.2067018545278379\n",
      "------------------------------------------------------------------------\n",
      "Industry.csv is Positively Spurious.\n",
      "Positive Acc: 0.7471212739504296 \n",
      "Negative Acc: 0.2214257327299693\n",
      "------------------------------------------------------------------------\n",
      "Oriental.csv is Neutral.\n",
      "Positive Acc: 0.3151751611452216 \n",
      "Negative Acc: 0.43308655529816525\n",
      "------------------------------------------------------------------------\n",
      "occupations1950_professional.csv is Positively Spurious.\n",
      "Positive Acc: 0.7821787734258725 \n",
      "Negative Acc: 0.1689765185258502\n",
      "------------------------------------------------------------------------\n",
      "Gender.csv is Neutral.\n",
      "Positive Acc: 0.5614252104498483 \n",
      "Negative Acc: 0.5282229390557593\n",
      "------------------------------------------------------------------------\n",
      "Media.csv is Positively Spurious.\n",
      "Positive Acc: 0.711494371731243 \n",
      "Negative Acc: 0.30607614403357974\n",
      "------------------------------------------------------------------------\n",
      "Islam.csv is Positively Spurious.\n",
      "Positive Acc: 0.7751701631247382 \n",
      "Negative Acc: 0.20155462246500905\n",
      "------------------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "for filename in filenames:\n",
    "    df_bias = pd.read_csv('/home/m_nsu/ICLR/Datasets/GoEmotion/bias_criterias/'+filename)\n",
    "\n",
    "    p_spurious_sentences = list(df_bias['Definition'])\n",
    "\n",
    "    p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "    n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "    for i in p_spurious_sentences:\n",
    "      p_emb = torch.cat((p_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "    for i in neutral_word_meaning_sentences[10:20]:\n",
    "      n_emb = torch.cat((n_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "    p_emb = p_emb[1:]\n",
    "    n_emb = n_emb[1:]\n",
    "\n",
    "    test_acc, _, test_f1 = eval_model(\n",
    "      model,\n",
    "      test_data_loader,\n",
    "      loss_fn,\n",
    "      device,\n",
    "      len(df_test)\n",
    "    )\n",
    "\n",
    "    positive_spurious = test_f1.item()\n",
    "\n",
    "    n_spurious_sentences = list(df_bias['Definition'])\n",
    "    p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "    n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "    for i in neutral_word_meaning_sentences[0:10]:\n",
    "      p_emb = torch.cat((p_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "    for i in n_spurious_sentences:\n",
    "      n_emb = torch.cat((n_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "    p_emb = p_emb[1:]\n",
    "    n_emb = n_emb[1:]\n",
    "\n",
    "    test_acc, _, test_f1 = eval_model(\n",
    "      model,\n",
    "      test_data_loader,\n",
    "      loss_fn,\n",
    "      device,\n",
    "      len(df_test)\n",
    "    )\n",
    "\n",
    "    negative_spurious = test_f1.item()\n",
    "\n",
    "    if positive_spurious>=0.6:\n",
    "      print(filename+' is Positively Spurious.')\n",
    "    if negative_spurious>=0.6:\n",
    "      print(filename+' is Negatively Spurious.')\n",
    "    if(positive_spurious<0.6 and negative_spurious<0.6):\n",
    "      print(filename+' is Neutral.')\n",
    "    print('Positive Acc:',positive_spurious,'\\n'+'Negative Acc:', negative_spurious)\n",
    "    print(\"------------------------------------------------------------------------\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "provenance": []
  },
  "gpuClass": "standard",
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
