{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "executionInfo": {
     "elapsed": 5,
     "status": "ok",
     "timestamp": 1695324378707,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "F7toc08bpdQ1",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "from transformers import 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": 2,
   "metadata": {
    "executionInfo": {
     "elapsed": 15,
     "status": "ok",
     "timestamp": 1695323483676,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "MLk4JWizs4S9",
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_train = pd.read_csv('/home/m_nsu/ICLR/Datasets/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": 3,
   "metadata": {
    "id": "YWiFI0a9QqEa",
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_senti = pd.read_excel('/home/m_nsu/ICLR/Datasets/GoEmotion/sentiwords.xlsx')\n",
    "conditions = [\n",
    "    (df_senti['PosScore'] > df_senti['NegScore']),\n",
    "    (df_senti['PosScore'] < df_senti['NegScore']),\n",
    "    (df_senti['PosScore'] == df_senti['NegScore'])\n",
    "    ]\n",
    "\n",
    "values = ['Positive','Negative','Neutral']\n",
    "\n",
    "df_senti = df_senti[['PosScore','NegScore','Word','Definition']]\n",
    "df_senti['Sentiment'] = np.select(conditions, values)\n",
    "df_senti = df_senti.dropna(axis=0)\n",
    "df_senti.drop(columns=['PosScore', 'NegScore'], inplace=True)\n",
    "df_senti = df_senti[['Word', 'Sentiment', 'Definition']]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "executionInfo": {
     "elapsed": 48,
     "status": "ok",
     "timestamp": 1695323754433,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "vX1DfZpN1W01",
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_train.dropna(inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "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": 6,
   "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": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_train.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "executionInfo": {
     "elapsed": 45,
     "status": "ok",
     "timestamp": 1695323754437,
     "user": {
      "displayName": "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": 8,
   "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": 9,
   "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": 10,
   "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": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "emotion_map['gratitude']  # Get Encoded Label from Categorical Label\n",
    "map_emotion[3]  # Get Categorical Label from Encoded Label"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 33,
     "status": "ok",
     "timestamp": 1695323754440,
     "user": {
      "displayName": "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": 12,
   "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": 13,
   "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": 14,
   "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": 15,
   "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": 16,
   "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": 17,
   "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": 18,
   "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": 19,
   "metadata": {
    "id": "5hjM7ggAiHnM",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "\"\\nambiguous_word_meaning_sentences = ['the process of becoming aware of something',#realization\\n                                'an event, a piece of news, etc. that is unexpected or that happens suddenly',#surprise\\n                                ' a strong desire to know about something',#curiosity\\n                                'a state of not being certain about what is happening, what you should do, what something means, etc.',#confusion\\n]\\n\\nneutral_word_meaning_sentences = ['not supporting or helping either side in a disagreement, competition, etc.']\\n\""
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "positive_word_meaning_sentences = ['the feeling that you have when you enjoy something that is funny',#amusement\n",
    "                                   'the state of feeling or showing happiness and enthusiasm',#excitement\n",
    "                                   'a feeling of great happiness',#joy\n",
    "                                   'a very strong feeling of liking and caring for somebody/something, especially a member of your family or a friend',#love\n",
    "                                   'a strong wish to have or do something',#desire\n",
    "                                   'a feeling that good things will happen and that something will be successful',#optimism\n",
    "                                   'kind, helpful and showing that you care about other people',#caring\n",
    "                                   'a feeling of being pleased or satisfied that you get when you or people who are connected with you have done something well or own something that other people admire',#pride\n",
    "                                   'a feeling of respect for and approval of somebody/something',#admiration\n",
    "                                   'the feeling of being grateful and wanting to express your thanks',#gratitude\n",
    "                                   'the feeling of happiness that you have when something unpleasant stops or does not happen',#relief\n",
    "                                   'the feeling that somebody/something is good or acceptable; a positive opinion of somebody/something',#approval\n",
    "]\n",
    "\n",
    "negative_word_meaning_sentences = ['the bad feeling that you have when you are in danger or when a particular thing frightens you',#fear\n",
    "                                   'the feeling of being anxious about something or afraid of something',#nervousness\n",
    "                                   'the feeling of being extremely sorry for something wrong or bad that you have done',#remorse\n",
    "                                   'shy, uncomfortable or guilty feelings; a feeling of being embarrassed',#embarrassment\n",
    "                                   'the feeling of being sad because something has not happened or been as good, successful, etc. as you expected or hoped',#disappointment\n",
    "                                   'the feeling of being sad',#sadness\n",
    "                                   'a very sad feeling, especially when somebody dies',#grief\n",
    "                                   'a strong feeling of dislike for somebody/something that you feel is unacceptable, or for something that looks, smells, etc. unpleasant',#disgust\n",
    "                                   'the strong feeling that you have when something has happened that you think is bad and unfair',#anger\n",
    "                                   'the feeling of being slightly angry',#annoyance\n",
    "                                   'a feeling that you do not like an idea, an action or somebody’s behaviour because you think it is bad, not suitable or going to have a bad effect on somebody else',#disapproval\n",
    "]\n",
    "\n",
    "\n",
    "'''\n",
    "ambiguous_word_meaning_sentences = ['the process of becoming aware of something',#realization\n",
    "                                'an event, a piece of news, etc. that is unexpected or that happens suddenly',#surprise\n",
    "                                ' a strong desire to know about something',#curiosity\n",
    "                                'a state of not being certain about what is happening, what you should do, what something means, etc.',#confusion\n",
    "]\n",
    "\n",
    "neutral_word_meaning_sentences = ['not supporting or helping either side in a disagreement, competition, etc.']\n",
    "'''"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 30,
     "status": "ok",
     "timestamp": 1695323767308,
     "user": {
      "displayName": "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": 21,
   "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": 22,
   "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": 23,
   "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": 24,
   "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": 25,
   "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": 26,
   "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": 27,
   "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": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data = next(iter(train_data_loader))\n",
    "data.keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {
    "executionInfo": {
     "elapsed": 3,
     "status": "ok",
     "timestamp": 1695325688712,
     "user": {
      "displayName": "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_p = nn.Linear(config.hidden_size,config.hidden_size, bias=False)\n",
    "    self.FC_n = nn.Linear(config.hidden_size,config.hidden_size, bias=False)\n",
    "    \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_p = self.FC_p(pooled_output)\n",
    "    x_sent_n = self.FC_n(pooled_output)\n",
    "    \n",
    "\n",
    "    Ept = self.FC_p(p_emb)\n",
    "    Ent = self.FC_n(n_emb)\n",
    "\n",
    "    positive = F.relu(self.CosineNorm(x_sent_p, Ept, p_emb.size()[0]))\n",
    "    negative = F.relu(self.CosineNorm(x_sent_n, Ent, n_emb.size()[0]))\n",
    "\n",
    "    binary_out = self.binary_output(positive,negative)\n",
    "    if(return_scores==True):\n",
    "      return (positive,negative) , binary_out\n",
    "    return binary_out"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {
    "id": "HWZ37gsztWzL",
    "tags": []
   },
   "outputs": [],
   "source": [
    "model = Classifier()\n",
    "model = model.to(device)\n",
    "clear_output()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {
    "executionInfo": {
     "elapsed": 22,
     "status": "ok",
     "timestamp": 1695325221207,
     "user": {
      "displayName": "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": 31,
   "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": 32,
   "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": 33,
   "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": 34,
   "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": 35,
   "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.6931, 0.7351],\n",
       "        [0.8051, 0.8642],\n",
       "        [0.6433, 0.7368],\n",
       "        [0.7226, 0.7579],\n",
       "        [0.7086, 0.7584],\n",
       "        [0.8050, 0.8263],\n",
       "        [0.7665, 0.7864],\n",
       "        [0.7547, 0.7517],\n",
       "        [0.7270, 0.7549],\n",
       "        [0.7705, 0.8241],\n",
       "        [0.7193, 0.7411],\n",
       "        [0.7094, 0.6865],\n",
       "        [0.6715, 0.7525],\n",
       "        [0.8346, 0.8122],\n",
       "        [0.6697, 0.6891],\n",
       "        [0.7430, 0.7806],\n",
       "        [0.7822, 0.8144],\n",
       "        [0.7600, 0.7852],\n",
       "        [0.7723, 0.8251],\n",
       "        [0.8221, 0.8400],\n",
       "        [0.7135, 0.7711],\n",
       "        [0.7531, 0.7876],\n",
       "        [0.7183, 0.7598],\n",
       "        [0.7033, 0.7550],\n",
       "        [0.7596, 0.7774],\n",
       "        [0.7154, 0.7440],\n",
       "        [0.8161, 0.7920],\n",
       "        [0.7428, 0.7854],\n",
       "        [0.7678, 0.7881],\n",
       "        [0.7763, 0.8461],\n",
       "        [0.6667, 0.7107],\n",
       "        [0.8496, 0.8634]], device='cuda:0', grad_fn=<TBackward0>)"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "outs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 1022,
     "status": "ok",
     "timestamp": 1695325845248,
     "user": {
      "displayName": "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": 37,
   "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": 38,
   "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": 39,
   "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": 40,
   "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": 41,
   "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": 42,
   "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": 43,
   "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.5314175793198483 accuracy 0.7767462866318747\n",
      "Val   loss 0.48213750501222247 accuracy 0.828639428798096\n",
      "\n",
      "Epoch 2/8\n",
      "----------\n",
      "Train loss 0.48967919796466064 accuracy 0.8183460457647531\n",
      "Val   loss 0.47356011746804927 accuracy 0.8361761205870686\n",
      "\n",
      "Epoch 3/8\n",
      "----------\n",
      "Train loss 0.4793056096062423 accuracy 0.8276294660778803\n",
      "Val   loss 0.46944211404534836 accuracy 0.8381594605315351\n",
      "\n",
      "Epoch 4/8\n",
      "----------\n",
      "Train loss 0.47518329463456643 accuracy 0.8315937374548374\n",
      "Val   loss 0.4695041870014577 accuracy 0.8377627925426419\n",
      "\n",
      "Epoch 5/8\n",
      "----------\n",
      "Train loss 0.47127917858609036 accuracy 0.8378161380971497\n",
      "Val   loss 0.46625023212613936 accuracy 0.8389527965093218\n",
      "\n",
      "Epoch 6/8\n",
      "----------\n",
      "Train loss 0.4687215634180684 accuracy 0.8399237254114814\n",
      "Val   loss 0.4663801034794578 accuracy 0.8405394684648949\n",
      "\n",
      "Epoch 7/8\n",
      "----------\n",
      "Train loss 0.4660437993980334 accuracy 0.8421316740264955\n",
      "Val   loss 0.4643342721311352 accuracy 0.8421261404204681\n",
      "\n",
      "Epoch 8/8\n",
      "----------\n",
      "Train loss 0.46312069127494604 accuracy 0.8461963067041349\n",
      "Val   loss 0.4623873788344709 accuracy 0.8429194763982547\n",
      "\n",
      "CPU times: user 12min 57s, sys: 10.7 s, total: 13min 8s\n",
      "Wall time: 13min 12s\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(), 'goemot_bert_best_model_state.bin')\n",
    "    best_accuracy = val_acc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {
    "executionInfo": {
     "elapsed": 51,
     "status": "ok",
     "timestamp": 1695329137842,
     "user": {
      "displayName": "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": 45,
   "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+naQAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nOzdeXwU9f3H8ffshtwkcoZwJnJpQBAIR6ARRQFBEawKeEFEbSMqYFSU2p8cokEriIDEi4CIVbSKxRbFKCpUqBwCaglHMRiO0BiOHAg5duf3R5IlSwJJIMkmw+v5eOxjd77znZnPrCnz7ndmZwzTNE0BAABYhM3TBQAAAFQlwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg0AALAUwg1gIYZhVOj19ddfV8n2Tp06JcMwNGvWrPNavk+fPrr++uurpJbKatasmW699dZy+3322WcyDEP//ve/K7X+efPmadmyZedbHoAL4OXpAgBUnQ0bNrhNP/PMM/rqq6+0Zs0at/aIiIgq2Z6Pj482bNig1q1bn9fyixYtkt1ur5JaqktUVJQ2bNigzp07V2q5efPmqV27drrrrruqqTIAZ0O4ASykT58+btNNmjSRzWYr1X42eXl5stvtFQ4chmFUeN1l6dSp03kvW1OCg4MvaB+rksPhkMPhkLe3t6dLAWo1TksBF6ni0y3Lly/XhAkTFBoaKl9fX+3fv19paWmKjY3V5ZdfroCAAIWEhOi6664rNTJU1mmpV199VYZh6Ntvv9X999+vRo0aqXHjxrrtttv0v//9z235M09L7dy5U4ZhaP78+Xr++efVpk0bBQYGql+/ftqyZUupfVi4cKHatWsnHx8fXXHFFfrggw80evRoXXbZZRX+Hj755BNdeeWV8vPzU0RERKlTSWWdltq9e7duu+02hYaGysfHR82aNdPAgQP1n//8R1LhKa+9e/dq9erVrlOBJWtKSUnR7bffriZNmsjHx0cRERGaN2+eSj7HuPi7mDt3rqZNm6awsDB5e3tr1apVCgwM1MSJE0vty65du2Sz2TR//vwK7z9gRYzcABe5Rx99VFdddZXefPNNOZ1ONWjQQKmpqapXr56mT5+ukJAQZWdn64MPPlB0dLTWrVunqKioctc7duxY3XTTTXr33XeVkpKiyZMn65577tGqVavKXXbOnDm64oorNH/+fDkcDj311FMaMmSIUlJSFBAQIKnwtM/EiRM1evRozZs3T0ePHtWUKVOUn58vPz+/Cu37pk2btGvXLj355JNq3LixEhISdPfdd6tDhw7q1atXmcuYpqnrr79ePj4+evHFF9WqVStlZGRo3bp1On78uCRp1apVGj58uFq2bKmXXnpJklw1paWlKSoqSoZhKD4+Xi1bttTHH3+siRMnat++fZozZ47b9l588UVFRERozpw5CgwMVEREhMaMGaO33npLzz33nOv7kKRXXnlFAQEBGjt2bIX2H7AsE4BljR071gwICChz3qeffmpKMgcNGlTuegoKCsz8/HyzX79+5u233+5qP3nypCnJjI+Pd7UlJCSYksy4uDi3dcyYMcOUZB49etTV1rt3b3Pw4MGu6eTkZFOSGRkZaTqdTlf72rVrTUnmihUrTNM0zby8PLNRo0Zm//793bbx3//+17Tb7WbHjh3L3aeQkBAzICDAPHTokKstJyfHrF+/vjlx4kRXW/H3tGHDBtM0TfPAgQOmJPPVV1895/rbtm3rtm/FJk2aZBqGYW7bts2t/Z577jFtNpuZkpLi9l1cfvnlZkFBgVvf5ORk0zAMMyEhwdWWnZ1tBgUFmQ888EC5+w5YHaelgIvcLbfcUqrNNE3Nnz9f3bp1k6+vr7y8vFSvXj19++23Sk5OrtB6b7rpJrfpLl26SJJSU1PLXfbGG2+UYRillv3ll18kST/99JOOHDmikSNHui3Xtm1b9ezZs0L1SVLPnj0VGhrqmg4ICFDbtm1d2ylLs2bN1Lp1az333HN6+eWXtX37djmdzgpvc82aNerWrZu6du3q1h4TEyOn01nql2wjRowodQ3UZZddpoEDB+qVV15xtS1dulRZWVl68MEHK1wLYFWEG+AiV/LgXiw+Pl4TJkxQdHS0PvroI3333XfatGmTBgwYoJMnT1ZovY0aNXKb9vHxkaQKLV/eskeOHJEkhYSElFq2rLaKbqd4W+eq0W6366uvvtI111yjZ599VldeeaVCQkIUFxenEydOlLvNI0eOlPmdN2/e3DW/pLL6StLEiRP1008/ae3atZIKT0ldc801deIibaC6cc0NcJErOUJSbNmyZbr++us1b948t/bMzMyaKuucikPJmRcoS9Lhw4erffuXXnqplixZIqnwwt/33ntPzzzzjJxOp+bOnXvOZRs1aqS0tLRS7YcOHZIkNW7c2K29rP8+kjRkyBC1b99eCxYsUEFBgXbs2KEZM2acx94A1sPIDYBSDMNwjZYU27x5s77//nsPVeSuc+fOatiwoZYvX+7WvnfvXm3evLlGa7nssss0bdo0dejQwe37OdsI0LXXXqtt27a5fllVbOnSpbLZbLr66qsrtF3DMPTwww9rxYoVmjp1qlq2bKkRI0Zc0L4AVkG4AVDKjTfeqE8++UQzZ87UmjVrtGDBAt1www0KCwvzdGmSpHr16mnq1Klau3atbr/9dn366adatmyZBg8erObNm8tmq75/2jZu3KhrrrlGr7zyilavXq01a9boySef1K5duzRw4EBXvyuuuEKbN2/W3/72N23evNkVZh5//HE1adJEgwcPVmJiolavXq0HH3xQixYt0qRJk9SmTZsK1xITEyN/f3/961//UmxsbK2/ISJQUzgtBaCUadOmKS8vTwsXLtSzzz6rzp07a/HixVq6dKm2bdvm6fIkSRMmTJDdbtecOXP00Ucf6dJLL9X06dP19ttvKysrq9q227JlS7Vu3Vrz58/XgQMHZLPZ1LZtW82bN0/jx4939Xv22WeVkZGhe+65Rzk5OerYsaN27typ0NBQbdiwQVOmTNHjjz+u7OxstW3bVnPnztWECRMqVUv9+vU1dOhQffTRR7r//vureleBOsswzRJ3jQKAOuzIkSNq37697rrrrlLXC1nRyZMn1bp1aw0ZMkRLly71dDlArcHIDYA6KTU1VXPmzFH//v3VsGFDpaSkaPbs2crNzdXDDz/s6fKqVXp6unbv3q3XXntNx44d0+TJkz1dElCrEG4A1Em+vr7as2eP3n33XR09elSBgYHq27evlixZovbt23u6vGr10Ucf6YEHHlCLFi30xhtvVPqhnoDVcVoKAABYikd/LbV27VoNGzZMzZs3l2EY+vjjj8td5ptvvlGPHj3k6+urSy+9VK+++moNVAoAAOoKj4abEydOqGvXrlqwYEGF+qekpGjo0KGKjo7W1q1b9ac//UkTJkzQhx9+WM2VAgCAuqLWnJYyDEMrVqw4502onnjiCa1cudLt2TaxsbHavn27NmzYUBNlAgCAWq5OXVC8YcMGDRo0yK1t8ODBWrRokfLz81WvXr1Sy+Tm5io3N9c17XQ6dfToUTVq1OistzUHAAC1i2mays7OrtCNOutUuDl8+HCph+KFhISooKBAGRkZZ30A4PTp02uqRAAAUI3279+vli1bnrNPnQo3UumHyBWfVTvbKMyUKVMUFxfnms7MzFTr1q21f/9+BQUFVV+hAACgymRlZalVq1aqX79+uX3rVLhp1qxZqSf+pqeny8vLy/WU4DP5+PiUegCgJAUFBRFuAACoYypySUmdenBmVFSUkpKS3No+//xzRUZGlnm9DQAAuPh4NNzk5ORo27ZtrgfxpaSkaNu2bUpNTZVUeEppzJgxrv6xsbH65ZdfFBcXp+TkZCUmJmrRokV67LHHPFI/AACofTx6Wmrz5s265pprXNPF18aMHTtWS5YsUVpamivoSFJ4eLhWrVqlRx55RK+88oqaN2+uefPm6ZZbbqnx2gEAQO1Ua+5zU1OysrIUHByszMxMrrkBUCc5HA7l5+d7ugygynl7e5/1Z96VOX7XqQuKAeBiZpqmDh8+rOPHj3u6FKBa2Gw2hYeHy9vb+4LWQ7gBgDqiONg0bdpU/v7+3IgUluJ0OnXo0CGlpaWpdevWF/T3TbgBgDrA4XC4gs3Zbn0B1HVNmjTRoUOHVFBQcEG/gq5TPwUHgItV8TU2/v7+Hq4EqD7Fp6McDscFrYdwAwB1CKeiYGVV9fdNuAEAAJZCuAEA1ClhYWGaO3eup8tALcYFxQCAanX11VfryiuvrLJAsmnTJgUEBFTJumBNhBsAgMeZpimHwyEvr/IPS02aNKmBimpWZfYf5eO0FACg2sTExOibb77Ryy+/LMMwZBiG9u3bp6+//lqGYWj16tWKjIyUj4+P1q1bp71792r48OEKCQlRYGCgevbsqS+++MJtnWeeljIMQ2+++aZuvvlm+fv7q3379lq5cuU561q2bJkiIyNVv359NWvWTHfccYfS09Pd+vznP//RDTfcoKCgINWvX1/R0dHau3eva35iYqI6deokHx8fhYaG6qGHHpIk7du3T4ZhuJ6bKEnHjx+XYRj6+uuvJemC9j83N1eTJ09Wq1at5OPjo/bt22vRokUyTVPt2rXTiy++6Nb/p59+ks1mc6vd6gg3AFBHmaap3/IKPPKq6JN7Xn75ZUVFRen+++9XWlqa0tLS1KpVK9f8yZMnKz4+XsnJyerSpYtycnI0dOhQffHFF9q6dasGDx6sYcOGuT1nsCzTp0/XyJEj9cMPP2jo0KG68847dfTo0bP2z8vL0zPPPKPt27fr448/VkpKimJiYlzzDx48qKuuukq+vr5as2aNtmzZonHjxqmgoECSlJCQoAcffFB/+MMf9OOPP2rlypVq165dhb6Tks5n/8eMGaP33ntP8+bNU3Jysl599VUFBgbKMAyNGzdOixcvdttGYmKioqOj1bZt20rXV1cx/gUAddTJfIcinl7tkW3vmDFY/t7lH0KCg4Pl7e0tf39/NWvWrNT8GTNmaODAga7pRo0aqWvXrq7pmTNnasWKFVq5cqVrZKQsMTExuv322yVJzz33nObPn6+NGzfq+uuvL7P/uHHjXJ8vvfRSzZs3T7169VJOTo4CAwP1yiuvKDg4WO+9957rZnIdOnRwq+vRRx/VxIkTXW09e/Ys7+sopbL7v3v3br3//vtKSkrSdddd56q/2D333KOnn35aGzduVK9evZSfn69ly5bpL3/5S6Vrq8sYuQEAeExkZKTb9IkTJzR58mRFRETokksuUWBgoHbu3FnuyE2XLl1cnwMCAlS/fv1Sp5lK2rp1q4YPH642bdqofv36uvrqqyXJtZ1t27YpOjq6zLvkpqen69ChQ7r22msruptnVdn937Ztm+x2u/r371/m+kJDQ3XDDTcoMTFRkvSPf/xDp06d0m233XbBtdYljNwAQB3lV8+uHTMGe2zbVeHMXz09/vjjWr16tV588UW1a9dOfn5+uvXWW5WXl3fO9ZwZQgzDkNPpLLPviRMnNGjQIA0aNEjLli1TkyZNlJqaqsGDB7u24+fnd9ZtnWueJNdTrUueujvbU9wru//lbVuS7rvvPt1999166aWXtHjxYo0aNeqiu7M14QYA6ijDMCp0asjTvL29K3w7/XXr1ikmJkY333yzJCknJ0f79u2r0np27typjIwMzZo1y3X9z+bNm936dOnSRW+99Zby8/NLBaf69esrLCxMX375pa655ppS6y/+NVdaWpq6desmSW4XF59Left/xRVXyOl06ptvvnGdljrT0KFDFRAQoISEBH366adau3ZthbZtJZyWAgBUq7CwMH333Xfat2+fMjIyzjqiIknt2rXTRx99pG3btmn79u264447ztn/fLRu3Vre3t6aP3++fv75Z61cuVLPPPOMW5+HHnpIWVlZGj16tDZv3qw9e/bo7bff1q5duyRJ06ZN0+zZszVv3jzt2bNH33//vebPny+pcHSlT58+mjVrlnbs2KG1a9fqz3/+c4VqK2//w8LCNHbsWI0bN851IfTXX3+t999/39XHbrcrJiZGU6ZMUbt27RQVFXWhX1mdQ7gBAFSrxx57THa7XREREa5TQGfz0ksvqUGDBurbt6+GDRumwYMHq3v37lVaT5MmTbRkyRJ98MEHioiI0KxZs0r9fLpRo0Zas2aNcnJy1L9/f/Xo0UNvvPGGaxRn7Nixmjt3rhYuXKhOnTrpxhtv1J49e1zLJyYmKj8/X5GRkZo4caJmzpxZodoqsv8JCQm69dZbNX78eF122WW6//77deLECbc+9957r/Ly8twunL6YGGZFf89nEVlZWQoODlZmZqaCgoI8XQ4AVMipU6eUkpKi8PBw+fr6eroc1HLffvutrr76ah04cEAhISGeLqfCzvV3Xpnjd+0/WQsAACokNzdX+/fv1//93/9p5MiRdSrYVCVOSwEAYBHvvvuuOnbsqMzMTL3wwgueLsdjCDcAAFhETEyMHA6HtmzZohYtWni6HI8h3AAAAEsh3AAAAEsh3AAAAEsh3AAAAEsh3AAAAEsh3AAAAEsh3AAAar2wsDDNnTvXNW0Yhj7++OOz9t+3b58Mw6jwAyurez2oWdyhGABQ56SlpalBgwZVus6YmBgdP37cLTS1atVKaWlpaty4cZVuC9WLcAMAqHOaNWtWI9ux2+01tq3aJj8/3/Wg0LqG01IAgGrz2muvqUWLFnI6nW7tN910k8aOHStJ2rt3r4YPH66QkBAFBgaqZ8+e+uKLL8653jNPS23cuFHdunWTr6+vIiMjtXXrVrf+DodD9957r8LDw+Xn56eOHTvq5Zdfds2fNm2a3nrrLf3973+XYRgyDENff/11maelvvnmG/Xq1Us+Pj4KDQ3Vk08+qYKCAtf8q6++WhMmTNDkyZPVsGFDNWvWTNOmTTvn/mzatEkDBw5U48aNFRwcrP79++v7779363P8+HH94Q9/UEhIiHx9fdW5c2f94x//cM3/9ttv1b9/f/n7+6tBgwYaPHiwjh07Jqn0aT1JuvLKK93qMgxDr776qoYPH66AgADNnDmz3O+tWGJiojp16uT6Th566CFJ0rhx43TjjTe69S0oKFCzZs2UmJh4zu/kQjByAwB1lWlK+b95Ztv1/CXDKLfbbbfdpgkTJuirr77StddeK0k6duyYVq9erU8++USSlJOTo6FDh2rmzJny9fXVW2+9pWHDhmnXrl1q3bp1uds4ceKEbrzxRg0YMEDLli1TSkqKJk6c6NbH6XSqZcuWev/999W4cWOtX79ef/jDHxQaGqqRI0fqscceU3JysrKysrR48WJJUsOGDXXo0CG39Rw8eFBDhw5VTEyMli5dqp07d+r++++Xr6+vW1B46623FBcXp++++04bNmxQTEyM+vXrp4EDB5a5D9nZ2Ro7dqzmzZsnSZo9e7aGDh2qPXv2qH79+nI6nRoyZIiys7O1bNkytW3bVjt27JDdbpckbdu2Tddee63GjRunefPmycvLS1999ZUcDke5319JU6dOVXx8vF566SXZ7fZyvzdJSkhIUFxcnGbNmqUhQ4YoMzNT3377rSTpvvvu01VXXaW0tDSFhoZKklatWqWcnBzX8tWBcAMAdVX+b9JzzT2z7T8dkrwDyu3WsGFDXX/99frrX//qCjcffPCBGjZs6Jru2rWrunbt6lpm5syZWrFihVauXOkaATiXd955Rw6HQ4mJifL391enTp104MABPfDAA64+9erV0/Tp013T4eHhWr9+vd5//32NHDlSgYGB8vPzU25u7jlPQy1cuFCtWrXSggULZBiGLrvsMh06dEhPPPGEnn76adlshSdEunTpoqlTp0qS2rdvrwULFujLL788a7gZMGCA2/Rrr72mBg0a6JtvvtGNN96oL774Qhs3blRycrI6dOggSbr00ktd/V944QVFRkZq4cKFrrZOnTqV+92d6Y477tC4cePc2s71vUmF/70effRRt0DZs2dPSVLfvn3VsWNHvf3225o8ebIkafHixbrtttsUGBhY6foqitNSAIBqdeedd+rDDz9Ubm6upMIwMnr0aNeow4kTJzR58mRFRETokksuUWBgoHbu3KnU1NQKrT85OVldu3aVv7+/qy0qKqpUv1dffVWRkZFq0qSJAgMD9cYbb1R4GyW3FRUVJaPEqFW/fv2Uk5OjAwcOuNq6dOnitlxoaKjS09PPut709HTFxsaqQ4cOCg4OVnBwsHJyclz1bdu2TS1btnQFmzMVj9xcqMjIyFJt5/re0tPTdejQoXNu+7777nONhqWnp+uf//xnqQBV1Ri5AYC6qp5/4QiKp7ZdQcOGDZPT6dQ///lP9ezZU+vWrdOcOXNc8x9//HGtXr1aL774otq1ayc/Pz/deuutysvLq9D6TdMst8/777+vRx55RLNnz1ZUVJTq16+vv/zlL/ruu+8qvB/F2zLOOB1XvP2S7WdeiGsYRqnrjkqKiYnRr7/+qrlz56pNmzby8fFRVFSU6zvw8/M7Z13lzbfZbKW+p/z8/FL9AgLcR+PK+97K264kjRkzRk8++aQ2bNigDRs2KCwsTNHR0eUudyEINwBQVxlGhU4NeZqfn59+//vf65133tF///tfdejQQT169HDNX7dunWJiYnTzzTdLKrwGZ9++fRVef0REhN5++22dPHnSdbD997//7dZn3bp16tu3r8aPH+9q27t3r1sfb2/vcq9RiYiI0IcffugWctavX6/69eurRYsWFa75TOvWrdPChQs1dOhQSdL+/fuVkZHhmt+lSxcdOHBAu3fvLnP0pkuXLvryyy/dTiGV1KRJE6Wlpbmms7KylJKSUqG6zvW91a9fX2FhYfryyy91zTXXlLmORo0aacSIEVq8eLE2bNige+65p9ztXihOSwEAqt2dd96pf/7zn0pMTNRdd93lNq9du3b66KOPtG3bNm3fvl133HHHOUc5znTHHXfIZrPp3nvv1Y4dO7Rq1Sq9+OKLpbaxefNmrV69Wrt379b//d//adOmTW59wsLC9MMPP2jXrl3KyMgoc2Rj/Pjx2r9/vx5++GHt3LlTf//73zV16lTFxcW5rrc5H+3atdPbb7+t5ORkfffdd7rzzjvdRkX69++vq666SrfccouSkpKUkpKiTz/9VJ999pkkacqUKdq0aZPGjx+vH374QTt37lRCQoIrIA0YMEBvv/221q1bp59++kljx451nRYsr67yvrdp06Zp9uzZmjdvnvbs2aPvv/9e8+fPd+tz33336a233lJycrLrV3LViXADAKh2AwYMUMOGDbVr1y7dcccdbvNeeuklNWjQQH379tWwYcM0ePBgde/evcLrDgwM1CeffKIdO3aoW7dueuqpp/T888+79YmNjdXvf/97jRo1Sr1799aRI0fcRiMk6f7771fHjh1d15cU/+KnpBYtWmjVqlXauHGjunbtqtjYWN17773685//XIlvo7TExEQdO3ZM3bp10913360JEyaoadOmbn0+/PBD9ezZU7fffrsiIiI0efJk10hThw4d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2990ww03nHU7ubm5ys3NdU1nZWVVzQ7UQgUOp/5zKMt1imnzL8d09ESeWx+7zVDn5kFF18sUnmZqGODZp7cCAFCVPBZuMjIy5HA4FBIS4tYeEhKiw4cPl7lM37599c4772jUqFE6deqUCgoKdNNNN2n+/Pln3U58fLymT59epbXXFqfyHdqaetx1j5nvU4/ptzPuK+Nbz6ZurU6fYurW+hIF+Hj8UisAAKqNx49yZ/482DTNs/5keMeOHZowYYKefvppDR48WGlpaXr88ccVGxurRYsWlbnMlClTFBcX55rOyspSq1atqm4HalDmb/na/Mvp62V+PJhZ6jECQb5ebqMyV7QIlrcXF/8CAC4eHgs3jRs3lt1uLzVKk56eXmo0p1h8fLz69eunxx9/XJLUpUsXBQQEKDo6WjNnzlRoaGipZXx8fOTj41P1O1ADDmeecgWZTfuOatf/snXmFVLNgnyLRmUKR2c6NK3Pxb8AgIuax8KNt7e3evTooaSkJN18882u9qSkJA0fPrzMZX777Td5ebmXbLcX3l/Fg9dFVwnTNJWScaLoeplj2rTvqFKP/laq36WNA9SraFSmV3hDtWzgx83xAAAowaOnpeLi4nT33XcrMjJSUVFRev3115WamqrY2FhJhaeUDh48qKVLl0qShg0bpvvvv18JCQmu01KTJk1Sr1691Lx5c0/uSqU5nKaS07Jc18ts2ndMGTm5bn1shhRRdPFvr7CGigxrqCb16+YoFAAANcWj4WbUqFE6cuSIZsyYobS0NHXu3FmrVq1SmzZtJElpaWlKTU119Y+JiVF2drYWLFigRx99VJdccokGDBig559/3lO7UGGn8h364UCm65dMW345ppzcArc+3l42XdnqEtdPsru3vkT1fet5qGIAAOomj97nxhNq6j43WafyteWXY67rZbbvz1Sew/0xBvV9vNQjrIHrFFOXlsHy8eIxBgAAnKlO3OfGanJyC7R296/amFI4MrPzcJbOeIqBmtT3KRyVKbr497JmQbJz8S8AAFWKcFNFDmee1Ph3vndra9PI3zUq0yusodo08ufiXwAAqhnhpoq0bRKoPpc2VMeQ+q4b5jUN8vV0WQAAXHQIN1XEMAy994coT5cBAMBFj1vXAgAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAASyHcAAAAS/F4uFm4cKHCw8Pl6+urHj16aN26defsn5ubq6eeekpt2rSRj4+P2rZtq8TExBqqFgAA1HZentz48uXLNWnSJC1cuFD9+vXTa6+9piFDhmjHjh1q3bp1mcuMHDlS//vf/7Ro0SK1a9dO6enpKigoqOHKAQBAbWWYpml6auO9e/dW9+7dlZCQ4Gq7/PLLNWLECMXHx5fq/9lnn2n06NH6+eef1bBhw/PaZlZWloKDg5WZmamgoKDzrh0AANScyhy/PXZaKi8vT1u2bNGgQYPc2gcNGqT169eXuczKlSsVGRmpF154QS1atFCHDh302GOP6eTJk2fdTm5urrKystxeAADAujx2WiojI0MOh0MhISFu7SEhITp8+HCZy/z888/617/+JV9fX61YsUIZGRkaP368jh49etbrbuLj4zV9+vQqrx8AANROHr+g2DAMt2nTNEu1FXM6nTIMQ++884569eqloUOHas6cOVqyZMlZR2+mTJmizMxM12v//v1Vvg8AAKD28NjITePGjWW320uN0qSnp5cazSkWGhqqFi1aKDg42NV2+eWXyzRNHThwQO3bty+1jI+Pj3x8fKq2eAAAUGt5bOTG29tbPXr0UFJSklt7UlKS+vbtW+Yy/fr106FDh5STk+Nq2717t2w2m1q2bFmt9QIAgLrBo6el4uLi9OabbyoxMVHJycl65JFHlJqaqtjYWEmFp5TGjBnj6n/HHXeoUaNGuueee7Rjxw6tXbtWjz/+uMaNGyc/Pz9P7QYAAKhFPHqfm1GjRunIkSOaMWOG0tLS1LlzZ61atUpt2rSRJKWlpSk1NdXVPzAwUElJSXr44YcVGRmpRo0aaeTIkZo5c6andgEAANQyHr3PjSdwnxsAAOqear3PTUpKynkXBgAAUN0qHW7atWuna665RsuWLdOpU6eqoyYAAIDzVulws337dnXr1k2PPvqomjVrpj/+8Y/auHFjddQGAABQaZUON507d9acOXN08OBBLV68WIcPH9bvfvc7derUSXPmzNGvv/5aHXUCAABUyHn/FNzLy0s333yz3n//fT3//PPau3evHnvsMbVs2VJjxoxRWlpaVdYJAABQIecdbjZv3qzx48crNDRUc+bM0WOPPaa9e/dqzZo1OnjwoIYPH16VdQIAAFRIpe9zM2fOHC1evFi7du3S0KFDtXTpUg0dOlQ2W2FOCg8P12uvvabLLrusyosFAAAoT6XDTUJCgsaNG6d77rlHzZo1K7NP69attWjRogsuDgAAoLK4iR8AAKj1qvUmfosXL9YHH3xQqv2DDz7QW2+9VdnVAQAAVKlKh5tZs2apcePGpdqbNm2q5557rkqKAgAAOF+VDje//PKLwsPDS7W3adPG7SGXAAAAnlDpcNO0aVP98MMPpdq3b9+uRo0aVUlRAAAA56vS4Wb06NGaMGGCvvrqKzkcDjkcDq1Zs0YTJ07U6NGjq6NGAACACqv0T8FnzpypX375Rddee628vAoXdzqdGjNmDNfcAAAAjzvvn4Lv3r1b27dvl5+fn6644gq1adOmqmurFvwUHACAuqcyx+9Kj9wU69Chgzp06HC+iwMAAFSL8wo3Bw4c0MqVK5Wamqq8vDy3eXPmzKmSwgAAAM5HpcPNl19+qZtuuknh4eHatWuXOnfurH379sk0TXXv3r06agQAAKiwSv9aasqUKXr00Uf1008/ydfXVx9++KH279+v/v3767bbbquOGgEAACqs0uEmOTlZY8eOlSR5eXnp5MmTCgwM1IwZM/T8889XeYEAAACVUelwExAQoNzcXElS8+bNtXfvXte8jIyMqqsMAADgPFT6mps+ffro22+/VUREhG644QY9+uij+vHHH/XRRx+pT58+1VEjAABAhVU63MyZM0c5OTmSpGnTpiknJ0fLly9Xu3bt9NJLL1V5gQAAAJVRqXDjcDi0f/9+denSRZLk7++vhQsXVkthAAAA56NS19zY7XYNHjxYx48f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QrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACWQrgBAACW4vFws3DhQoWHh8vX11c9evTQunXrztn/m2++UY8ePeTr66tLL71Ur776ag1VCgAA6gKPhpvly5dr0qRJeuqpp7R161ZFR0dryJAhSk1NLbN/SkqKhg4dqujoaG3dulV/+tOfNGHCBH344Yc1XDkAAKitDNM0TU9tvHfv3urevbsSEhJcbZdffrlGjBih+Pj4Uv2feOIJrVy5UsnJya622NhYbd++XRs2bKjQNrOyshQcHKzMzEwFBQVd+E4AAIBqV5njt8dGbvLy8rRlyxYNGjTIrX3QoEFav359mcts2LChVP/Bgwdr8+bNys/Pr7ZaAQBA3eHlqQ1nZGTI4XAoJCTErT0kJESHDx8uc5nDhw+X2b+goEAZGRkKDQ0ttUxubq5yc3Nd05mZmZIKEyAAAKgbio/bFTnh5LFwU8wwDLdp0zRLtZXXv6z2YvHx8Zo+fXqp9latWlW2VAAA4GHZ2dkKDg4+Zx+PhZvGjRvLbreXGqVJT08vNTpTrFmzZmX29/LyUqNGjcpcZsqUKYqLi3NNO51OHT16VI0aNTpniDofWVlZatWqlfbv339RXs9zse+/xHdwse+/xHfA/l/c+y9V33dgmqays7PVvHnzcvt6LNx4e3urR48eSkpK0s033+xqT0pK0vDhw8tcJioqSp988olb2+eff67IyEjVq1evzGV8fHzk4+Pj1nbJJZdcYPXnFhQUdNH+UUvsv8R3cLHvv8R3wP5f3PsvVc93UN6ITTGP/hQ8Li5Ob775phITE5WcnKxHHnlEqampio2NlVQ4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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(train_a, label='train accuracy')\n",
    "plt.plot(val_a, label='validation accuracy')\n",
    "\n",
    "plt.title('Training history')\n",
    "plt.ylabel('Accuracy')\n",
    "plt.xlabel('Epoch')\n",
    "plt.legend()\n",
    "plt.ylim([0, 1])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "SbT4YzHFh1s7"
   },
   "source": [
    "Accuracy of Pos/Neg on Test Set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 28664,
     "status": "ok",
     "timestamp": 1695329081374,
     "user": {
      "displayName": "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.831163708086785\n",
      "F1-Macro:  0.8107517623571312\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "test_acc, _, test_f1 = eval_model(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  loss_fn,\n",
    "  device,\n",
    "  len(df_test)\n",
    ")\n",
    "\n",
    "\n",
    "print(\"Accuracy: \",test_acc.item())\n",
    "print(\"F1-Macro: \",test_f1.item())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "-Vexpkg79IXK"
   },
   "source": [
    "Scores Average of PP - Poisitve Scores on Positive Sentences\n",
    "                  PN - Poisitve Scores on Negative Sentences\n",
    "                  NP - Negative Scores on Positive Sentences\n",
    "                  NN - Negative Scores on Negative Sentences"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 605
    },
    "executionInfo": {
     "elapsed": 29278,
     "status": "ok",
     "timestamp": 1695329182045,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "zUrNTiUp8kPc",
    "outputId": "e99daa47-22f9-471e-97d4-245bf6f0b8ab",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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JSUldbkem82moUOHdnkcAAAAel5paWmnrw150HU6nW324no8HpWXl2vSpEkdjjvwkCeddFJA+0knnaSWlhZ9//33QQVdi8Wi6OjoLo8DAABAz+vstgWpF7yMNmbMGG3atEk1NTX+trVr18rj8Sg7O7vDcWlpaZKkzZs3B7R/8803kqSBAwf2QLUAAAA4VoR8RTcnJ0fPPvuscnNzlZubq6qqKs2fP18TJkwI2LowZ84cFRYWasuWLZKkk08+WSNHjtTdd9+tyspKDR48WMXFxXriiSd06aWXBhxXBgAAgJ+ekAddh8OhFStWKD8/X7Nnz1ZkZKTGjx+vvLy8gOt8Pp9aW1v9n61Wq/7617/qL3/5i5YuXarKykoNGDBAU6ZM0W9/+9uj/RgAAADoZSwG367gV1xcLEnKyMgIcSUAAABoT1fyWsj36AIAAAA9gaALAAAAUyLoAgAAwJQIugAAADAlgi4AAABMiaALAAAAUyLoAgAAwJQIugAAADAlgi4AAABMiaALAAAAUyLoAgAAwJQIugAAADAlgi4AAABMiaALAAAAUyLoAgAAwJQIugAAADAlgi4AAABMiaALAAAAUyLoAgAAwJQIugAAADAlgi4AAABMiaALAAAAUyLoAgAAwJQIugAAADAlgi4AAABMiaALAAAAUyLoAgAAwJQIugAAADAlgi4AAABMiaALAAAAUwoPdQEAAADoWUVFRXr11VdVX1+vM888Uzk5OYqJiQl1WT2OoAsAABAC33zzjb755hulpqbqnHPOkdVqPaL5PvzwQ7377ruSpAsvvFDnnHOOJOnpp5/WY4895r/u888/17vvvqvly5crKirqiO7Z2xF0AQDAT5phGGpubj7kNd9//70+//xzORwOZWVlyW63B30/r9erP/3pT9qwYYO/LT09XY888oj69esX1JyPPvqoXnzxRf/nNWvWaPLkyZoxY4b+9re/tbm+tLRUr7zyiq666ipZLJag7nkssBiGYYS6iN6iuLhYkpSRkRHiSgAAwNFgGIbuvfde/ec//+nwmn379qmmpsb/2Wq1Ki0tTZGRkQHzSOpUaKyurlZlZWWb9j59+igtLa0r5UuSmpubtWPHjnb7+vXrpz179rTbFxsbq+zsbN19993HVNjtSl5jRRcAAIRUZ1ZUe/LePp+vw/6GhoaAkCtJra2t2r17twYNGiSv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9mjLli3dPS0AAADQJUGdulBRUdFh3zvvvKPFixdr48aNQRcFAAAAHKmggu4vfvELWSyWDvsHDx4cdEEAAABAdwgq6N5///1tgm5jY6M+/fRTvffee5o/f363FAcAAAAEq9tfRps/f742b96slStXdue0RwUvowEAAPRuIX0ZLTs7W19//XV3TwsAAAB0SbcH3ZqaGiUlJXX3tAAAAECXBLVHtz0+n0/ffvut/vrXv+qWW27prmkBAACAoAS1R3fYsGEdnrpgGEZAn8ViOWbO1WWPLgAAQO/WlbwW1IrujTfeeMjjxQAAAIBQCyrozia4vsgAACAASURBVJ49u7vrAAAAALpVt7+MBgAAAPQGnQ6699xzj/bt29elyd955x2tXr26y0UBAAAAR6rTWxe2bdumCy+8UL/85S81ceJEnX766YqKimpz3Y4dO/Tee+/p5Zdf1p49e7RgwYJuLRgAAADojE4H3RUrVujdd9/VkiVLNHPmTIWHh+v4449XYmKiIiIiVFdXp++++051dXWKiorSFVdcoVmzZnGmLgAAAEIiqOPFtmzZovfff19fffWV9u7dK7fbrYSEBA0ZMkRnnnmmLrjgAsXExPREvT2K48UAAAB6tx4/Xmz48OEaPnx4MEMBAACAo4JTFwAAAGBKQQXdjRs36s033/R/rqys1MyZM3XOOefo97//vZqbm7utQAAAACAYQQXdhQsXqqyszP/5wQcf1KeffqpRo0bp7bff1t/+9rduKxAAAAAIRlBBd/v27f49ui0tLVq7dq3y8vL02GOP6eabb9brr7/erUUCAAAAXRVU0N2/f78cDockafPmzWpqatIFF1wgSRo5cqR27drVpfm2bdum6dOnKzMzU1lZWcrPz5fb7T7suKlTp+rEE09s8+vg1WYAAAD8NAV16kJSUpK2b9+u008/XR999JFSU1PVv39/SVJDQ4PCwzs/rcvl0rRp05SamqqFCxequrpaBQUFqq2t7dSXTZx66qm64447AtoGDhzYtQcCAACA6QQVdM877zw98sgjKi0t1SuvvKLLL7/c37d161alpaV1eq5Vq1bJ5XKpsLBQiYmJkiSr1aq8vDzNmjVLTqfzkOMdDocyMzODeQwAAACYWFBbF2677TYNGzZM//jHP3TSSSdp1qxZ/r7XXntNo0aN6vRcRUVFysrK8odcSRo7dqzsdrvWr18fTHkAAABAcCu6iYmJWrZsWbt9zzzzjOx2e6fnKisr06RJkwLa7Ha70tPTO7XX9l//+pcyMzPV2tqqU045RbfccovOOOOMTt//xwzDUGNjY9DjAQAA0HMMw5DFYunUtUEF3YO53W7V1dUpKSlJ4eHhXf7qX5fL5X+x7WAOh0N1dXWHHHvGGWdo4sSJGjRokPbu3atly5bpuuuu08qVK7u0qnwwr9erkpKSoMYCAACg53V2UTXooLtp0yY98sgj/u8bfuGFFzRixAjde++9ysrK0kUXXRTs1JI6l9ZvvvnmgM8///nPNX78eD3xxBNaunRpUPe12WwaOnRoUGMBAADQs0pLSzt9bVBBd+PGjZoxY4ZOOOEEXX/99QFfEJGQkKCXX36500HX4XDI5XK1aa+vrz/si2g/Fh0drezsbL399ttdGncwi8Wi6OjooMcDAACg53R224J0BN+MNmbMGBUWFurWW28N6Bs2bJi+/fbbTs/ldDrb7MX1eDwqLy/vctCVflgJBgAAAIIKuiUlJcrJyZHUNlUnJiaqqqqq03ONGTNGmzZtUk1Njb9t7dq18ng8ys7O7lJdjY2NWr9+vTIyMro0DgAAAOYTVNC1Wq3yer3t9lVVValPnz6dnisnJ0exsbHKzc3Vhg0bVFhYqHnz5mnChAkBK7pz5szxf+2wJH366aeaNWuWXn75ZW3atEmrV6/WNddco3379unGG28M5rEAAABgIkHt0c3IyNDq1at14YUXtul7++23u/QFDg6HQytWrFB+fr5mz56tyMhIjR8/Xnl5eQHX+Xw+tba2+j/37dtXHo9HDz/8sGpraxUVFaVRo0bp3nvv1ciRI4N5LAAAAJiIxQhiU+tHH32k6dOn6xe/+IUuv/xy3XzzzbrrrrtUWlqq559/XitWrNDpp5/eE/X2qAMnSLD1AQAAoHfqSl4LKuhK0quvvqr7778/4Kxbh8OhuXPn6rLLLgtmypAj6AIAAPRuXclrQZ+jO3HiRI0dO1ZffPGFKisrlZCQoFNPPZWjuQAAANArdDnout1u/frXv9bNN9+ss88+W1lZWT1RFwAAAHBEunzqQmRkpP7zn//IarX2RD0AAABAtwjqeLFRo0bp66+/7u5aAAAAgG4TVNC944479Pzzz6uwsFANDQ3dXRMAAABwxII6dWHUqFHyer3+c20jIyMDviHNYrHos88+674qjxJOXQAAAOjdevzUhbFjx7b56l8AAACgNwkq6M6fP7+76wAAAAC6VVB7dAEAAIDeLugvjCgvL9eiRYu0ceNG1dbWKiEhQWeffbZuvPFGpaend2eNAAAAQJcFFXTLysqUk5Oj5uZmnXXWWUpJSdHevXv15ptv6oMPPtBzzz0np9PZ3bUCAAAAnRZU0H3kkUcUHx+vlStXqn///v723bt3a9q0aXr00Ue1aNGibisSAAAA6Kqg9uh+8sknmj17dkDIlaT+/fsrNzdXH3/8cbcUBwAAAAQrqKDb1NSk+Pj4dvsSEhLkdruPqCgAAADgSAUVdAcPHqw1a9a02/f6669ryJAhR1QUAAAAcKSC2qM7depUzZ07V/X19frVr36lvn37at++fVq9erXWrVun/Pz87q4TAAAA6JKggu7kyZNVVVWlJ598UuvXr5ckGYahyMhI3XbbbZo0aVK3FgkAAAB0VdDn6N5www26+uqr9cUXX6i2tlbx8fEaNWqUYmNju7M+AAAAIChBB11Jio2N1ZgxY7qrFgAAAKDbBPUy2ksvvdThObmLFi1SYWHhERUFAAAAHKmggu7KlSvlcDja7UtISNAzzzxzREUBAAAARyqooLtjxw797Gc/a7fP6XRqx44dR1QUAAAAcKSCCrqSVF9f3277/v371draGnRBAAAAQHcIKuieeOKJev3119vte+211zpc7QUAAACOlqCC7jXXXKO3335bd9xxh7766ivt2bNHX331lf7whz/onXfe0ZQpU7q7TgAAAKBLgjpebMKECdq6dauWLFmi1atXS/rhCyOsVqtmzZqlyy67rFuLBAAAALoq6HN0b7nlFk2aNEkffvihampqlJiYqHPOOUdpaWndWR8AAAAQlKBfRpOkgQMHauzYsdq/f7/ee+89LV68WKWlpd1VGwAAABC0Tq/o/vnPf9abb76pDz74wN/W2NioyZMn6/vvv5dhGJKk119/XS+88IKGDBnS7cUCAAAAndXpFd0vvvhCl156aUDbs88+q507d2ratGn69NNPtWrVKkVHR2vp0qXdXigAAADQFZ0Out99951OPvnkgLb3339fiYmJ+t3vfqeYmBhlZmbquuuu08cff9zthQIAAABd0emg63K5lJKS4v/c0tKi4uJinXnmmbJarf72k046Sfv27eveKgEAAIAu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sudaE6kohYWF/P73vycqKoorV67w/vvv06NHD92IJlJJKOiKXXx9fYmPj2fevHlcunSJoKAg1qxZg4+Pj6VP9+7d8fPzY9asWeTk5BAWFkZiYqIDq5bKyJ5rTaSiDBs2jDt37vDmm29SWFhI9+7dmTlzpqPLEhE7Gcxms9nRRcizbcqUKaSlpbF79+7H9unatSudO3fWLwD5j9hzrYlUlODgYN58801GjBjh6FJE5Alpjq6IiIiIOCUFXRERERFxSpq6ICIiIiJOSSO6IiIiIuKUFHRFRERExCkp6IqIiIiIU1LQFRERERGnpKArIiIiIk5JQVdE5D9w+vRppk6dSteuXQkJCaF169b07duXVatWkZWVVa5jHT58mEWLFj2lSv/7rly5QnBwMDt27HB0KSIiNml5MRGRJ7R161YSExNp3LgxUVFRBAYGUlxcTFpaGlu3bqV58+YsWbLE7uPNnj2bjRs38u9///spVv3fU1hYyMmTJwkICMDb29vR5YiIlFLV0QWIiFRG//rXv0hISCAsLIylS5diNBot2zp27EhMTAzJyckOrPDpKSkpoaSkBKPRSKtWrRxdjojIY2lEV0TkCYwePZrk5GT2799P3bp1f7Lvnj172L59O2fOnCEnJwd/f3+6detGbGwsHh4eAEyZMoWdO3eW2vfzzz+nfv36mM1mNm3axNatWzl//jxubm506NCBSZMm0aBBA0t/s9nMihUr2LJlC7du3SIoKIiJEyeyfPlyANavX2/p+/333/PBBx/w5ZdfkpubS4MGDfjd737H8OHDqVLlx5ltV65coVu3bsTHx1NUVMT27du5fv06y5cvp0mTJnTr1o333nuPfv36WY574cIFFi1axJEjRyzHHTp0KEOGDLH0uX//PsuXL+eTTz7h2rVrGI1G6taty4ABA4iOjn6C74iISGka0RURKaeSkhJSUlJ44YUXygy58GPwi4iIIDo6Gnd3d86dO8eqVav49ttv+dOf/gRAbGwsd+/eZd++fWzZssWyb506dQCYOXMmO3fuZNiwYcTHx5Odnc2SJUuIjIzkk08+wcfHB4AFCxawYsUKBg0aRPfu3bl+/TpvvfUWRUVFNG7c2HLcO3fuEBkZSVFREePHj8ff359Dhw4xd+5cLl26REJCgtVzWL9+PY0aNWLy5Ml4enrSsGFDm881PT2dyMhI6tat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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": 48,
   "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.08284023668639053"
      ]
     },
     "execution_count": 48,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "emotion_test_acc = eval_emotions(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  loss_fn,\n",
    "  device,\n",
    "  len(df_test)\n",
    ")\n",
    "\n",
    "emotion_test_acc.item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {
    "executionInfo": {
     "elapsed": 8,
     "status": "ok",
     "timestamp": 1695329212064,
     "user": {
      "displayName": "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": 50,
   "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": 51,
   "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": 52,
   "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.78      0.75      0.77       932\n",
      "\n",
      "    accuracy                           0.83      2535\n",
      "   macro avg       0.82      0.81      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": 53,
   "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.12      0.02      0.04       131\n",
      "          fear       0.11      0.37      0.17        65\n",
      "     annoyance       0.12      0.03      0.05       194\n",
      "     gratitude       0.14      0.11      0.13       260\n",
      "    admiration       0.15      0.02      0.03       348\n",
      "        caring       0.02      0.01      0.01        86\n",
      " embarrassment       0.01      0.13      0.03        23\n",
      "           joy       0.08      0.14      0.10        93\n",
      "       sadness       0.28      0.10      0.14       102\n",
      "   disapproval       0.18      0.04      0.06       195\n",
      "      optimism       0.06      0.21      0.10       107\n",
      "      approval       0.17      0.00      0.01       236\n",
      "    excitement       0.00      0.00      0.00        57\n",
      "     amusement       0.10      0.22      0.14       186\n",
      "disappointment       0.29      0.07      0.11        88\n",
      "       remorse       0.00      0.00      0.00        44\n",
      "          love       0.11      0.19      0.14       160\n",
      "       disgust       0.06      0.08      0.07        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.03      0.02      0.02        56\n",
      "   nervousness       0.00      0.00      0.00        12\n",
      "\n",
      "      accuracy                           0.08      2535\n",
      "     macro avg       0.09      0.08      0.06      2535\n",
      "  weighted avg       0.13      0.08      0.07      2535\n",
      "\n"
     ]
    }
   ],
   "source": [
    "class_names = list(emotion_map.keys())\n",
    "\n",
    "print(classification_report(emo_y_test, emo_pred, target_names=class_names))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "GhTpYmfdiF-P"
   },
   "source": [
    "Reverse Native Injection Accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 30105,
     "status": "ok",
     "timestamp": 1695329269413,
     "user": {
      "displayName": "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.6343195266272189\n",
      "F1-Macro:  0.5622920369898934\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "p_emb, n_emb = n_emb, p_emb\n",
    "\n",
    "\n",
    "test_acc, _, test_f1 = eval_model(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  loss_fn,\n",
    "  device,\n",
    "  len(df_test)\n",
    ")\n",
    "\n",
    "print(\"Accuracy: \",test_acc.item())\n",
    "print(\"F1-Macro: \",test_f1.item())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 605
    },
    "executionInfo": {
     "elapsed": 28733,
     "status": "ok",
     "timestamp": 1695329298142,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "F25gPUqgvw0w",
    "outputId": "747d6857-a67e-4f00-f9a9-fea35eee0d06",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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pwEANCcUXQABbejQobWO9+nTR23atPFzGgBAc0LRBRDQpk6dqm7dulUba9WqlX73u9+ZlAgA0FxQdAEEtMjISGVmZmr27NmKjIxUp06d9Oqrr6pv375mRwMABDiKLoCA16pVK918882KiYlR586d1blzZ7MjAQCaAYouAAAALImiCwAAAEui6AIAAMCSKLoAAACwJIouAAAALImiCwAAAEui6AIAAMCSKLoAAACwJIouAAAALImiCwAAAEui6AIAAMCSKLoAAACwJIouLlhOTo5mzZqlnJwcs6MAAABUoejiguTn5ys9PV0FBQVasmSJysrKzI4EAAAgSQo2OwCaJ8Mw9NBDDykzM1OGYUiS9u3bp8zMTCUlJZmcDgAAgBld+OjVV1/Vyy+/XFVyJenUqVNatGiRDh48aGIyAACaD5b/NS2KLnyybNmyWsePHz+u5557rloBBgAA1ZWWluq1117T/fffr127dunpp59m+V8TYOkCfOJ2u2sdNwxDW7Zs0f79+9WlSxc/pwIAIPAVFRVp+vTp2rNnT9VYYWGhFi1apFmzZpmYzHoCYkY3Pz9f06ZNU79+/ZSQkKDU1FSVlpaec59Tp07piSee0E033aQrrrhCgwcP1rRp07Rt2zY/pW7ZRowYUet469atNWDAAEVHR/s5EQAAzcMLL7xQreRKUmVlpV577TWW/zUy04uu2+1WUlKSTp8+rQULFmj27Nl66623dP/9959zv/379+uVV17R1Vdfrccff1xpaWmqrKzUxIkTKbt+MG3aNMXFxVUbs9vtuvjiizVlyhTZbDaTkgEAENjWrl1b63hJSYmeeeYZlv81ItOXLmRmZsrtdisrK0tRUVGSzhSmlJQUJScn1yhT3+vatauys7MVFhZWNXb11Vdr+PDhevHFF5WWluaX/C1VmzZttGzZMs2dO1effvqpnE6n2rdvr5tuukmdOnUyOx4AAAErOLj2+mWz2bR9+3aW/zUi02d016xZo4SEhKqSK0mjRo2S0+nU6tWr69wvPDy8WsmVpJCQEMXFxenw4cNNlhf/FRISooceekh9+/ZV586d1bFjR40bN87sWAAABLQbbrih1vGIiAj169eP5X+NyPQZ3by8PE2YMKHamNPpVExMjPLy8hp0rOLiYu3YsUPjx4/3OY9hGCouLvZ5/5Zo0qRJevnll3XLLbeooqKCzx+axNlnI5eUlKiystLENC0DZ4C3XHyPNa2RI0fqyy+/1IoVK6rGwsLC1LlzZ02cOFElJSUmpgt8hmHUe4mk6UXX7XbL5XLVGHe5XCoqKmrQsf72t7+ppKREt956q895vF6vduzY4fP+LVFISIh++ctfShKfOzQZr9db9fddu3bJ4XCYmKZlOPtzjpaF77Gmd/311ys8PFzr1q2Tw+FQSEiIBg8erGPHjunYsWNmxwt4TqezXtuZXnTr0pC2LklvvfWWMjIy9Mc//lEXX3yxz6/rcDgUHx/v8/4AmsbZs4s9evRQSEiIiWlaBmZ0Wy6+x/yjW7du2rdvn06cOKHIyEhNnjyZz3s95Obm1ntb04uuy+Wq9ZqsJ0+erPNEtP+1du1a/f73v9e0adM0adKkC8pjs9kUHh5+QccA0PiCgv57SkFYWJhCQ0NNTNMynP05R8vC95h/hIeHa9q0acrIyFBSUpIiIyPNjtQsNGQi1PSiGxcXV2MtrsfjUUFBQY21u7XZsmWLfv3rX+vaa6/Vb3/726aKCQAA0OgGDhyogQMHmh3Dskz/7/qwYcO0fv16FRYWVo1lZ2fL4/EoMTHxnPvm5eVp+vTpGjBggNLS0rh2KwAAAKqYXnQnTpyoiIgIzZgxQ5988omysrI0b948jR07ttrShTlz5qhnz55Vj48dO6Zp06bJ4XDo9ttv17Zt27R582Zt3rxZ27dvN+NDAQAAQAAxfemCy+VSRkaGUlNTNXPmTIWGhmrMmDFKSUmptl1lZaUqKiqqHufm5urAgQOSVHXG//e6dOmijz76qMmzAwAAIHCZXnQlKTY2VosXLz7nNunp6UpPT696PGjQIO3ataupowEAAKCZMn3pAgCcz9q1a3Xbbbfpq6++0o4dO/Tyyy+bHQkA0AwExIwugObDMAy/Xl/1q6++UnJyctXSJY/Ho/nz58vj8SgpKclvOaQzN0fhpFcAaD4ougDqzTAMPfTQQ9q9e7ffXnPv3r3V1ud/b+HChVq1apVfi2f37t01d+5cyi4ANBMsXQAQ0OqaPS4vL6+1AAMA8D1mdAHUm81m09y5c/26dGHOnDlauXJljfFOnTpp6dKlfr17F0sXAKB5oegCaBCbzebXW4NOnz5dq1atqlGu77zzTm7XDQA4J5YuAAhol112mTIyMpSYmKh27dqpd+/eevTRR3XzzTebHQ0AEOCY0QUQ8Hr37q2FCxeaHQMA0MwwowsAAABLougCAADAkii6AAAAsCSKLoBmIycnR7NmzVJOTo7ZUQAAzQAnowEIeLm5uVq0aJE+/vhj2e12HT58WBkZGQoJCTE7GgAggDGjCyCg5eXladKkSXr33XdVUlKiU6dOaevWrZo3b57Z0QAAAY6iCyCgLV68WKdOnaox/s477+jAgQMmJAIANBcUXQABbdu2bbWOezweLVq0SIZh+DkRAKC5oOgCCGjt2rWrddxut2vXrl3av3+/nxMBAJoLii6AgParX/2q1vEOHTqob9++io6O9nMiAEBzQdEFENAGDx6sP/7xj1VXWLDb7erUqZMuuugiTZkyRTabzeSEAIBAxeXFAAS8n//857LZbHrzzTdls9kUFBSk8ePHq1OnTmZHAwAEMGZ0ATQL48ePV7t27WSz2RQZGalx48aZHQkAEOAougCahZCQEE2dOlXt27fXlClTuFkEAOC8WLoAoNkYOHCgBg4caHYMAEAzwYwuAAAALImiCwAAAEui6AIAAMCSKLoAAACwJIouAAAALImiCwAAAEui6AIAAMCSKLoAAACwJIouAAAALImiCwAAAEui6AIAAMCSKLoAAACwpGCzAwAAECi8njL9e8cXOnLgG0W0iVKPXglqFdHW7FiWZxiGysrKTH19j8dj2uubyel0ymazmfb6ISEhTfr6FF0AACSVlpzSW5l/U+Gxg1VjX33xoUbf9Gt1vOgS84K1AGVlZZo6darZMWCCJUuWKDQ0tMmOz9IFAAB0ptSeXXIlyesp1WcfvW5SIgAXihldAAAk7cvfXuv44QN7VVZarJDQcP8GaqHuG3SbnHb/1hPDMOStLPfrawYKR1Cw35cueCrK9ciGf/rltQKi6Obn5ys1NVU5OTkKCwvT6NGjlZKSct6p7HfffVcrVqzQ5s2bdfjwYd13332aNm2an1IDAKzE6az9d06QPVh2PxevlsxpD5bT7vD764bI6ffXRNMzfemC2+1WUlKSTp8+rQULFmj27Nl66623dP/995933/fee0/79u3TT37yEz8kBQBYWfdeg2sdj+sxQMEOShDQHJn+X9TMzEy53W5lZWUpKipKkmS325WSkqLk5GTFxcXVue/f/vY3BQWd6eqvvPKKX/ICQEtUUeE1O0KTi790oI4d/lbbv/pERmWlJCk6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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": 56,
   "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.8307692307692307\n",
      "F1-Macro:  0.8089539120960915\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": 57,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.3203155818540434\n",
      "F1-Macro:  0.2989482647005196\n"
     ]
    }
   ],
   "source": [
    "#REVERSE FOREIGN INJECTION ACCURACY\n",
    "\n",
    "\n",
    "import numpy as np\n",
    "new_negative_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_positive_word_meaning_sentences = [\n",
    "'tending to show favour towards or against one group of people or one opinion for personal reasons; making unfair judgements',#biased(adjective)\n",
    "'very bad or unpleasant; used to describe something that you do not like',#horrible(adjective)\n",
    "'feeling tired and impatient because you have lost interest in somebody/something or because you have nothing to do',#bored(adjective)\n",
    "'upset because something you hoped for has not happened or been as good, successful, etc. as you expected',#disappointed(adjective)\n",
    "'to make somebody feel annoyed or impatient because they cannot do or achieve what they want',#frustrate(verb),\n",
    "'showing or feeling opposition or dislike; unfriendly',\n",
    "'inspiring scornful pity',\n",
    "'speak unfavorably about',\n",
    "'socially incorrect in behavior',\n",
    "'offensive or disagreeable; causing discomfort or unhappiness']\n",
    "\n",
    "\n",
    "\n",
    "p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "for i in new_positive_word_meaning_sentences:\n",
    "  p_emb = torch.cat((p_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "for i in new_negative_word_meaning_sentences:\n",
    "  n_emb = torch.cat((n_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "p_emb = p_emb[1:]\n",
    "n_emb = n_emb[1:]\n",
    "\n",
    "test_acc, _, test_f1 = eval_model(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  loss_fn,\n",
    "  device,\n",
    "  len(df_test)\n",
    ")\n",
    "\n",
    "print(\"Accuracy: \",test_acc.item())\n",
    "print(\"F1-Macro: \",test_f1.item())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 605
    },
    "executionInfo": {
     "elapsed": 29037,
     "status": "ok",
     "timestamp": 1695329354749,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "DGrasP1mxQrD",
    "outputId": "87f1fe38-fe1b-4d6c-bf39-3c3e36c56fae",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAroAAAISCAYAAAAjsmyaAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAPYQAAD2EBqD+naQAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nOzde0BUdcL/8c8wzAwgjIJ4Cc1USMtW87JW2KZdLNu85Ko9a1lrWq6rLrXb8mS57bo9ssGWmz3Wk2utFmVq24310kXLErefWrJmlmiBFpUXFIERuQ3M+f3RxsYCCsMwBw7v11/ynfM98yFJPnz5nnNshmEYAgAAACwmxOwAAAAAQEug6AIAAMCSKLoAAACwJIouAAAALImiCwAAAEui6AIAAMCSKLoAAACwpFCzA7Qmu3fvlmEYcjgcZkcBAABAPbxer2w2m4YMGXLWYym632MYhnh+BgAAQOvVlK5G0f2e71ZyBw4caHISAAAA1Gfv3r2NPpY9ugAAALAkii4AAAAsiaILAAAAS6LoAgAAwJIougAAALAkii4AAAAsiaILAAAAS6LoAgAAwJIougAAALAkii4AAAAsiaILAAAASwo1O4AkHTp0SCkpKcrKylJ4eLjGjh2r5ORkhYWFNTjn66+/1jXXXFPvaw6HQ5988klLxQUAAEAbYHrR9Xg8mj59uuLi4rR06VKdPHlSqampKioq0uLFixuc17VrV7344ou1xgzD0KxZs3TppZe2dGwAAAC0cqYX3bVr18rj8SgjI0MxMTGSJLvdruTkZM2ZM0fx8fH1znM6nRo8eHCtsZ07d+rUqVMaN25ci+cGAABA62b6Ht3MzEwlJibWlFxJGjNmjJxOp7Zu3dqkc23YsEGRkZG6+uqrAx0TAAAAbYzpK7q5ubmaPHlyrTGn06levXopNze30efxer3atGmTrr32WrlcLr/zGIah0tJSv+cDAACg5RiGIZvN1qhjTS+6Ho9Hbre7zrjb7VZxcXGjz5OZmamioqJmb1vwer3Kzs5u1jkAAADQcpxOZ6OOM73oNqQpbV2S1q9fr9jYWCUmJjbrfR0OhxISEpp1DgAAgMb46KOPtGbNGt188811rj1C/XJychp9rOlF1+12y+Px1Bk/depUgxei/afTp0/rvffe05QpU2S325uVx2azKSIiolnnAAAAOJOCggKtWbNGr732miTp6aef1l/+8pdmbb9sL5qyEGr6xWjx8fF19uJWVlYqLy+v0UV38+bNKisr0/jx41siIgAAQMAcO3ZMt912m5599lkVFxeruLhYn3zyiR577DGzo1mO6UV35MiR2rFjhwoLC2vGNm/erMrKSo0aNapR59iwYYN69eqliy++uKViAgAABER6erry8/NrjRmGoXXr1uno0aMmpbIm04vu1KlTFRUVpblz52rbtm3KyMjQokWLNH78+ForugsWLNCAAQPqzD958qS2b9+usWPHBjM2AACAX7Kysuodr6io0PLly2UYRpATWZfpRdftdis9PV0RERFKSkpSWlqaxo0bp5SUlFrH+Xw+VVdX15n/xhtvqKqqim0LAACgTejQoUO94zabTdnZ2Tp8+HCQE1mXzeDHhhp79+6VJA0cONDkJAAAwKrefvtt3XfffXXGO3XqpNGjR2v+/PlNuuCqvWlKXzN9RRcAAKA9GT16tGbOnKmQkH/XMLfbrW7dumnGjBmU3AAy/fZiAAAA7c3cuXPVsWNHvfrqq7Lb7XI4HJo4caK6detmdjRLYUUXAADABFOmTFH37t0VGhqq6OhoTZgwwexIlkPRBQAAMIHL5dLMmTMVGxurGTNm8LCIFsDWBQAAAJMMGzZMw4YNMzuGZbGiCwAAAEui6AIAAMCSKLoAAACwJIouAAAALImiCwAAAEui6AIAAMCSKLoAAACwJIouAAAALImiCwAAAEui6AIAAMCSKLoAAACwJIouAAAALImiCwAAAEui6AIAAMCSKLoAAACwJIouAAAALImiCwAAAEui6AIAAMCSKLoAAACwJIouAAAALImiCwAAAEui6AIAAMCSKLoAAACwJIouAAAALImiCwAAAEui6AIAAMCSKLoAAACwJIouAAAALImiCwAAAEui6AIAAMCSQs0OAACAmTIyMvTaa6/p1KlTGjFihGbOnKmYmBizYwEIAIouAKDdWrJkidLT02s+PnjwoDIzM7V69WpFRkaamAxAIFB0AQCtkmEYqqioaLHznzx5UqtXr64znpeXp5dfflk//elPZbPZWuz9z8Tlcpn23oCVUHQBAK2OYRh68MEH9dlnn7XYe5SUlMjr9db72jPPPKNNmza12HufTb9+/bRw4ULKLtBMFF0AQLvkcDgafC00NFSFhYUqKiqS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uRwOh9xut/6Ws0XKaYFPvI2g6AIAAPipQ4cO6t27t6qqqhQSElJrm0DPnj11/PhxlZSUyDAMRUZGqkuXLvrmm2/qPVd1dbU6d+4sl8slj8cjwzDUoUOHmm0NLpdLvXv3lsfjUWVlpcLCwuR2u2u2PISEhKhjx47q2LFjUD73toCiCwAATOVyubRy5UpT3tswDKWmpionx/9lT5vNJofDUWc8NDRU55xzTs1WhO9+TV/fSq8k2e122e12derUqcF734aGhiomJsbvrP8pISFB999/v2m3GHO5XC16foouAAAwlc1ma/ItpgLpwQcfDOp9fPft26d58+bVbHf4zrx58/Rf//VfQcshtfx9bM1G0QUAAO1asIv20KFD9cQTT2j58uX69NNPFRcXp2nTpmnixIlBy9BeUHQBAACCbNiwYXrqqafMjmF5PDACAAAAlkTRBQAAgCVRdAEAAGBJFF0AAACTZGVl6a677lJWVpbZUSyJi9EAAACCoKSkRBkZGdqzZ4+6du2qcePGaeXKlSosLNTKlSv1gx/8oMXvK9veUHQBAABaWHFxse644w598cUXNWMvv/yyunfvrg4dOqioqEjr1q3TTTfdZF5IC2LrAlq94uJirVmzRsuWLdOePXvMjgMAQJOtXbu2VsmVvn3kb35+vgzDkGEYWrdunY4ePWpOQItiRbcd2rlzpzIyMlReXq6rrrpKN9xwg0JDm/alUFlZqbfffls5OTlKSEjQtddeW+/jD5vrww8/1C9+8QuVlJRIkh577DFNmjRJDz30kKWf5AIAsJadO3fWO+71elVVVSWHwyHDMPTss89q/vz5fI8LEIquRRiG0ajHF65YsUJLly6t+fj111/Xxo0btWTJEoWEhMjr9Wrbtm06ceKEhg0bpvj4+DrnKCgo0J133qmDBw/WjPXt21d//etf1blzZ7/yHz16VBs3blRxcbEuvfRSjRgxQoZh6N57760pud959dVXdfnll2v06NGSrP/4QgBA29epU6cGXwsJ+fYX7D6fTx9//LEOHz6sHj16BCuapdkMwzDMDtFa7N27V5I0cODAJs9tbNFsCYZhKDU1VTk5OWc8zuv1au/evarvrzwhIUEul0uff/65Kisra8ZjY2PVq1evWkXyiy++UEFBQZ1zxMbG6rzzzmty/uLiYuXm5tbK1alTJ3Xr1k0HDhyod05MTIz69OlTk/3+++83rexStAEAZ5OZmal77rmnznhUVJTOOecc/f/27j2+5vuO4/jrJJw4ciNN1P2WRGwVl6KECuWh2CPbKqwuZZFmHbIwrWjdhdpMHyymiyFRU5eGGtqasqrLtET3WGsVpkpC0CHkKiQ5Sc7+6CNnjiTNiYkjp+/n4+HxcL7n+/2dz0l+Sd755vv7/uDbwNupUyfN6FajJnlNM7oPSFFRES+++KKjy/hOt27dqjTkAuTl5VFQUGATcgFu3LiBp6cnPj4+1racnJxKj5Gdnf2dQbe0tJTs7GxKSkrw8PDAw8MDi8XCxYsXK9SVk5NDw4YN7Xpf586dIyoqyq6+teGtt956qPdIFxGRuic0NJRp06aRmJhIQUEBBoMBk8lEw4YNKSwstP4ciYyMVMh9gBR0H5C6MDHu6ur6nc8XFBRU2p6VlWUTdKv6AixvLy4uca6yjgAAFSBJREFUxmKx2GyRUlBQwNdff01paam1zcfHBz8/P8xmc6XHu337Nm5ubpXOlN9dj6PVhc+9iIg43rhx4xg+fDhnz57lL3/5C3v37uX27dsAmEwmQkNDefzxxx1cpXPRrgvfI56enpXuz2cwGPD29q5yXHmQKysro6ysrMqQ6e3tzVdffcXJkydJTU3l1KlT1vW1Fy5csAm58G2AzsvLq/J1XV1dadeuXYUL5Zo0afKd9YqIiDyq3N3dSUtLY+/evTbtd+7c4dixY9p14QHTjO4Dcvcsp99zoRjqfffsqaO4D+jKiXc+IP8/mQC4eXnwxHODefwH/lz9w5/Jv3qjwpimIZ3JuPANmWfTMRjAt0M7vI0u5F7+3xdj47YtKCy4Q8FdF44VFhZy7kI6PX4+nMIq7vhS5uOBR5kvt65VfF3/4YN4zL81rc1mrv/7PMUFd/ANaIO7n+Nncy0lpWTu+jtQ9Qy3iIhIZf76179W2p6Xl0dSUhJz5szRz5YHREG3FpQHoEdVh+atudPYj9LSUtzd3TGcyuD6qQxaNPLl68xsm5lXb29v0g8cty4vsFgg80waDRo0oEOHDjbris5euFLhtUqLikl/72CVtRRdyaR18+acy86zrg82GAw0a9aM0i/Oc/2L8wC4Aiag4EoOlS+wEBERqRvy8/OrfO7kyZPadeEBUtD9njKZTBXa3N3dCQ4OJisrC7PZjKenJ8XFxeTm5lboW1hYSFlZGX5+fsC3yxCqe707d+5UaG/cuDEmk4lOnTqRn59PSUkJnp6etbInr4iIyKNgwIABpKenV2g3mUx069aN5s2bO6Aq56Sg+4C4ubnx1ltvObqMB27t2rUkJCRU+tzIkSMJDw9n8uTJuLu74+LiQllZWYV+s2fPpnnz5kRHR3Pjxv+WKIwYMYJ58+bV+T/P6L7kIiJSEz//+c85dOiQTdh1cXHh8ccf164LD5iC7gNiMBiccouprl27VvlcQEAAmzdv5vz58xiNRsLCwnj//fdt+vTu3Ztnn30WV1dXDhw4wMcff8zNmzd56qmnCAoKqu3yRUREHjmenp5s2rSJ3/zmNxw9epR69erh7e3NyJEjtevCA6YbRtzl/7lhhLOyWCyMHz+ef/zjHzbtffr0ISMjg8uXL1vbGjRoQFRUFKdPn6aoqIhBgwbx/PPPYzQaH3bZIiIij7yioiJeeeUVsrOz8fHxYfny5foroR10w4jvodq8M9vKlSt5++232b9/Py4uLgwZMoTMzEyOHj1q06+wsJADBw6QnJxsbSsrK6OwsLBW6iqnO5OJiEhd5ObmxosvvsiGDRuIiIhQyK0FmtG9S12d0bVYLCxcuJCzZ88+tNc8depUlQG2S5cuFfa+rU0dOnRgwYIFCrsiIiLfAzXJa7phhNyXqoKswWDAxUWnlYiIiDieli44AYPBwIIFC2pt6UJl9uzZw6xZsyq0h4eHM3/+/IdWB2jpgoiIiFROQddJPOxdH8LDw/nmm29ISkrizp07uLi4MHjwYObOneuUu0+IiIhI3aM1unepq2t0HSkvL4+vv/6aZs2aaYNrERERqXXadUEeGi8vL7p37+7oMkREREQq0FVDIiIiIuKUFHRFRERExCkp6IqIiIiIU1LQFRERERGnpKArIiIiIk5JQVdEREREnJKCroiIiIg4JQVdEREREXFKCroiIiIi4pQUdEVERETEKSnoioiIiIhTeiSCbnp6OlFRUXTt2pWQkBAWL15MYWGhXWN37tzJ0KFDCQ4OJiwsjA8//LCWqxURERGRuqCeowvIy8sjIiKC5s2bs3LlSrKysliyZAk5OTksW7bsO8fu3buXmTNn8stf/pK+ffuyf/9+Xn75ZTw9PXn66acf0jsQERERkUeRw4NucnIyeXl57Nq1Cx8fHwBcXV2JjY1l8uTJ+Pv7Vzn2D3/4A0OHDmX69OkA9O7dm/T0dFauXKmgKyIiIvI95/ClC3//+98JCQmxhlyAIUOGYDQaOXz4cJXjLl26RFpaGmFhYTbtYWFhfPnll2RlZdVazSIiIiLy6HP4jO758+cZMWKETZvRaKR169acP3++ynFpaWkAtG/f3qbd398fi8VCWlqaTXi2l8Vi4fbt2zUeJyIiIiK1z2KxYDAY7Orr8KCbl5eHl5dXhXYvLy9yc3OrHFf+3L1jvb29bZ6vKbPZzL///e/7GisiIiIitc9oNNrVz+FBtyr2pvV7+1gslkrb7WE2mwGoX79+jceKiIiISO0zm83WzFYdhwddLy8v8vLyKrTn5+d/54Vod8/c+vr6WtvLj1XZLHF1ysPx/YRkEREREal9BoOh7ixd8Pf3r7AWt7i4mIyMjAprd+9WvjY3LS3NJhCfP38eg8FQYe2uPbp161bjMSIiIiLyaHL4rguhoaGkpKSQnZ1tbfvoo48oLi6mf//+VY5r1aoV7du3Z8+ePTbtu3fvpnPnzvd1IZqIiIiIOA+HB93Ro0fj6elJdHQ0R44cYdeuXbz++uv8+Mc/tpmpnT17Nj/84Q9txk6dOpUPP/yQ+Ph4jh8/zm9/+1s+/fRTpk6d+rDfhoiIiIg8Yhy+dMHLy4sNGzawePFipkyZQoMGDQgLCyM2NtamX1lZGaWlpTZtw4YNo7CwkNWrV7Nu3TratGlDfHy8bhYhIiIiIhgs5dsUiIiIiIg4EYcvXRARERERqQ0KuiIiIiLilBR0RURERMQpKeiKiIiIiFNS0BURERERp6SgKyIiIiJOSUFXRERERJySgq6IiIiIOCUFXRERERFxSgq6IiIiIuKUFHRFRERExCkp6Eq1Zs6cSVhYGIcPHyYsLIzg4GDCw8M5ceKEtc/AgQNZtGgRSUlJ9OvXjy5dujB58mSuX7/uwMqlrqnJubZp0yaeeeYZunfvTnR0NFlZWQ6sXOqa8nPt+PHjPPfcc3Tt2pWRI0eSmppq7RMUFMTatWt544036N27N926dWPmzJncunXLgZVLXWPvuZaYmMjKlSvp06cPvXr1YtasWdy+fduBlTsHBV2xS2ZmJgsXLiQqKooVK1ZgNBqJiori5s2b1j4fffQR+/fvJy4ujri4OE6ePMmUKVMcWLXURfacawcOHODgwYPMnz+fOXPm8Nlnn/H66687sGqpizIzM1m8eDFRUVHEx8dTWFhITEwMZrPZ2mfjxo2kpaWxdOlSYmNj2bdvH/PmzXNg1VIX2XOubd68mYsXL/K73/2O6OhoPvjgA1atWuXAqp1DPUcXIHVDTk4OK1asICQkBICePXvSv39/NmzYwCuvvAJAQUEBa9euxcvLC4CmTZsyYcIEPvnkE55++mmH1S51iz3nmsVi4U9/+hNGoxGAixcvsm7dOsrKynBx0e/vYp/c3Fw2bdpEYGAgAG5ubkRGRvKvf/2LHj16AGA0GklISMDV1dX6eN68ecTExODv7++w2qVusedc8/X1Zfny5QCEhoZy8uRJ9u3bR2xsrMPqdgb6iSB28fT0tAYPAC8vL3r37m3zJ+VevXpZQy5ASEgIHh4eNn1EqmPPudazZ09ryAUICAjAbDbbzPqKVKdJkybW4AFYg+u1a9esbc8884w15AI8++yzWCwWTp48+fAKlTrPnnOtb9++NmMCAgK4evXqwynQiSnoil18fHwqtD322GNkZmbaPK6uj0h17DnX7v6FCqB+/foAFBUV1W5x4lTsOY/u/b7m7e1N/fr1df2B1Ig951plfYqLi2u/OCenoCt2qexCn5s3b+Ln52fzuLo+ItWx51wTeVju/b6Wm5uL2WymSZMmDqpIRGpCQVfskp+fz7Fjx2wep6Sk0KVLF2vb8ePHyc/Ptz4+duwYt27dsukjUh17zjWRh+XgwYOUlpZaH//tb3/DYDAQHBzswKpExF66GE3s0qhRI+bMmcPUqVPx9PQkMTERgIiICGsfd3d3XnrpJV566SXy8/NZtmwZnTt3pl+/fo4qW+oge841kYeluLiYX/3qV4wZM4bLly+zbNkyhgwZogvRROoIBV2xi5+fH7GxsbzxxhtkZGQQGBjIunXr8PX1tfYZPHgwTZs2ZcGCBeTl5dGnTx8WLlzowKqlLrLnXBN5WMaPH09WVhavvvoqxcXFDB48mPnz5zu6LBGxk8FisVgcXYQ82mbOnElqaiq7d++uss/AgQMZMGCAfgDI/8Wec03kYQkKCuLVV18lKirK0aWIyH3SGl0RERERcUoKuiIiIiLilLR0QURERESckmZ0RURERMQpKeiKiIiIiFNS0BURERERp6SgKyIiIiJOSUFXRERERJySgq6IyP/hzJkzzJo1i4EDBxIcHEy3bt0YPnw4iYmJ5OTk1OhYhw8f5s0336ylSh+8y5cvExQUxI4dOxxdiohIpbS9mIjIfdq2bRsLFy6kXbt2jBkzhoCAAEpKSkhNTWXbtm107NiRhIQEu4+3aNEiNm/ezFdffVWLVT84xcXFnD59mtatW+Pj4+PockREKqjn6AJEROqiL774gri4OPr06cOqVaswGo3W5/r27UtkZCRHjhxxYIW1p7S0lNLSUoxGI127dnV0OSIiVdKMrojIfZg0aRJHjhxh//79NGvW7Dv77tmzh+3bt3P27Fny8vJo0aIFgwYNIjo6moYNGwIwc+ZMdu7cWWHsxx9/TMuWLbFYLGzZsoVt27aRnp6Om5sbISEhzJgxg1atWln7WywW1qxZw9atW7lx4waBgYFMnz6d1atXA7Bx40Zr32+++Ybf//73fPrpp+Tn59OqVSt+9rOfMWHCBFxcvl3ZdvnyZQYNGkRsbCxms5nt27dz9epVVq9eTfv27Rk0aBBLliwhPDzcetwLFy7w5ptvcvToUetxx40bxwsvvGDtU1ZWxurVq3nvvff4z3/+g9FopFmzZowcOZKIiIj7+IyIiFSkGV0RkRoqLS0lJSWFJ554otqQC98Gv9DQUCIiIjCZTKSlpZGYmMiXX37J22+/DUB0dDS3b99m3759bN261Tq2SZMmAMyfP5+dO3cyfvx4YmNjyc3NJSEhgdGjR/Pee+/h6+sLQHx8PGvWrGHUqFEMHjyYq1evMnfuXMxmM+3atbMeNysri9GjR2M2m/n1r39NixYtOHToEEuXLiUjI4O4uDib97Bx40batm3La6+9hoeHB23atKn0vZ47d47Ro0fTrFkzXnvtNfz8/Pjkk09YvHgx2dnZxMTEAJCUlMQf//hHJk+eTI8ePSgpKSEtLY38/Hz7PxEiItVQ0BURqaHs7Gzu3LlDy5Yt7eofHR1t/b/FYuHJJ5/E39+fcePGcebMGTp27Ejr1q2tYfXe5QAnTpxg27ZtzJw5k8jISGt7jx49GDJkCOvXr2fGjBnk5uayfv16fvSjH7Fo0SJrv8DAQEaNGmUTdNevX8+1a9d499136dy5MwD9+vWjtLSU5ORkIiIibPq7ubmxbt066tevb227fPlyhfe6ZMkS3N3deeedd/Dw8AC+XcpRXFzM2rVrGT9+PN7e3nz++ed06NCBKVOmWMf269fPro+niIi9tOuCiEgtu3TpEtOnT6dv37784Ac/4IknnmDcuHEApKWlVTv+4MGDGAwGfvKTn1BSUmL95+vrS8eOHfnss8+AbwNxcXExw4YNsxnftWtXWrRoYdOWkpJCQECANeSWCw8Px2KxkJKSYtM+cOBAm5BbmaKiIlJSUhg8eDANGjSwqTU0NJSioiJOnDgBQHBwMGfOnCEuLo4jR45w69ataj8OIiI1pRldEZEaaty4MSaTqdIZzXsVFBQwduxY3NzcmDZtGm3btqVBgwZcvXqVmJgYCgsLqz3GzZs3sVgs9OnTp9Lny9folm9n9thjj1XoUz5bXC4nJ6dC+IX/LZW4d2s0Pz+/auvMycmhpKSEjRs32qwFvlt2djYAEydOpGHDhrz//vskJyfj6upKjx49iI2NJTg4uNrXEhGxh4KuiEgNubq60rt3b44cOcLVq1dp2rRplX1TUlK4fv06Gzdu5KmnnrK212QtauPGjTEYDGzevNlmd4dy5W2NGjUCvg3G97px44ZNsG3UqBGZmZkV+l2/ft36mnczGAzV1unl5YWrqys//elPGTt2bKV9ypd71KtXj8jISCIjI8nLy+Po0aPEx8fzi1/8gkOHDmEymap9PRGR6mjpgojIfZg4cSIWi4W5c+dSXFxc4Xmz2cyBAwesAfHegJqcnFxhTHmfe2d5BwwYgMVi4dq1awQHB1f4FxQUBECXLl0wGo3s2bPHZvyJEye4cuWKTVtISAjnzp3j1KlTNu27du3CYDDQq1cvez4MNkwmE7169eL06dMEBQVVWuu9ARq+DchDhw5l7Nix5OTkVKhVROR+aUZXROQ+dOvWjbi4OBYuXMiIESMYPXo0gYGBlJSUcPr0abZt20ZgYCCLFy/G29ubBQsWEBMTQ7169fjggw8qvSlEhw4dAEhMTCQ0NBQXFxeCgoLo3r07o0aNYvbs2aSmptKzZ09MJhOZmZn885//pEOHDowdO5ZGjRoRGRnJmjVr8PLysu66kJCQgJ+fn82s7IQJE9i1axcTJ05k6tSpNG/enEOHDrFlyxbGjBljcyFaTcyZM4exY8fywgsvMGbMGFq0aEFBQQEZGRkcOHDAusvEpEmTCAwMpFOnTvj4+HDlyhU2bNhAixYtqtzRQUSkphR0RUTu0/PPP0/nzp3585//TFJSEpmZmdSvX5+2bdsSFhbGuHHjaNy4MWvWrGHp0qXMmDEDk8nEoEGDiI+PZ/jw4TbHCwsL4/PPP2fLli0kJCRgsVis++guWrSILl26sHXrVt555x3Kyspo0qQJTz75pM0FZS+//DImk4nk5GR27NhB+/btiYuLIz4+Hi8vL2s/Hx8fkpOTWb58OcuXL6egoICWLVsyY8YMm50daiogIIAdO3awatUqVqxYQVZWFp6enrRp04b+/ftb+/Xq1Yt9+/bx7rvvcuvWLfz8/OjTpw/R0dHVXvQmImIv3TBCRMTJXbp0iWHDhhETE8OkSZMcXY6IyEOjGV0RESdy5swZdu/eTbdu3fDw8CA9PZ2kpCQ8PDwYOXKko8sTEXmoFHRFRJyIyWQiNTWV7du3k5+fj4eHB7169WLatGkVthgTEXF2WrogIiIiIk5J24uJiIiIiFNS0BURERERp6SgKyIiIiJOSUFXRERERJySgq6IiIiIOCUFXRERERFxSgq6IiIiIuKUFHRFRERExCn9F5Y7tXjFDJZ9AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "pp,pn,np,nn = eval_scores_average(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  device,\n",
    ")\n",
    "\n",
    "box_plot(pp,pn,np,nn)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {
    "id": "K-QhJy24rDkl",
    "tags": []
   },
   "outputs": [],
   "source": [
    "from parrot import Parrot\n",
    "import torch\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "\n",
    "\n",
    "def random_state(seed):\n",
    "  torch.manual_seed(seed)\n",
    "  if torch.cuda.is_available():\n",
    "    torch.cuda.manual_seed_all(seed)\n",
    "\n",
    "random_state(1234)\n",
    "\n",
    "parrot = Parrot(model_tag=\"prithivida/parrot_paraphraser_on_T5\")\n",
    "clear_output()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {
    "executionInfo": {
     "elapsed": 18,
     "status": "ok",
     "timestamp": 1695329438384,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "p84O3JV6tRdP",
    "tags": []
   },
   "outputs": [],
   "source": [
    "#ORIGINAL EMOTION LABELS\n",
    "positive_word_meaning_sentences = ['the feeling that you have when you enjoy something that is funny',#amusement\n",
    "                                   'the state of feeling or showing happiness and enthusiasm',#excitement\n",
    "                                   'a feeling of great happiness',#joy\n",
    "                                   'a very strong feeling of liking and caring for somebody/something, especially a member of your family or a friend',#love\n",
    "                                   'a strong wish to have or do something',#desire\n",
    "                                   'a feeling that good things will happen and that something will be successful',#optimism\n",
    "                                   'kind, helpful and showing that you care about other people',#caring\n",
    "                                   'a feeling of being pleased or satisfied that you get when you or people who are connected with you have done something well or own something that other people admire',#pride\n",
    "                                   'a feeling of respect for and approval of somebody/something',#admiration\n",
    "                                   'the feeling of being grateful and wanting to express your thanks',#gratitude\n",
    "                                   'the feeling of happiness that you have when something unpleasant stops or does not happen',#relief\n",
    "                                   'the feeling that somebody/something is good or acceptable; a positive opinion of somebody/something',#approval\n",
    "]\n",
    "\n",
    "negative_word_meaning_sentences = ['the bad feeling that you have when you are in danger or when a particular thing frightens you',#fear\n",
    "                                   'the feeling of being anxious about something or afraid of something',#nervousness\n",
    "                                   'the feeling of being extremely sorry for something wrong or bad that you have done',#remorse\n",
    "                                   'shy, uncomfortable or guilty feelings; a feeling of being embarrassed',#embarrassment\n",
    "                                   'the feeling of being sad because something has not happened or been as good, successful, etc. as you expected or hoped',#disappointment\n",
    "                                   'the feeling of being sad',#sadness\n",
    "                                   'a very sad feeling, especially when somebody dies',#grief\n",
    "                                   'a strong feeling of dislike for somebody/something that you feel is unacceptable, or for something that looks, smells, etc. unpleasant',#disgust\n",
    "                                   'the strong feeling that you have when something has happened that you think is bad and unfair',#anger\n",
    "                                   'the feeling of being slightly angry',#annoyance\n",
    "                                   'a feeling that you do not like an idea, an action or somebody’s behaviour because you think it is bad, not suitable or going to have a bad effect on somebody else',#disapproval\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {
    "executionInfo": {
     "elapsed": 16,
     "status": "ok",
     "timestamp": 1695329438385,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "Ppy-K6l2gWtd",
    "tags": []
   },
   "outputs": [],
   "source": [
    "from IPython.display import clear_output"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {
    "executionInfo": {
     "elapsed": 38794,
     "status": "ok",
     "timestamp": 1695329477164,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "_OCeDQY6gHMj",
    "tags": []
   },
   "outputs": [],
   "source": [
    "new_positive_word_meaning_sentences = []\n",
    "\n",
    "for i in positive_word_meaning_sentences:\n",
    "  para_phrases = parrot.augment(input_phrase=i, max_return_phrases = 10)\n",
    "  temp = list(list(zip(*para_phrases))[0])[0]\n",
    "  new_positive_word_meaning_sentences.append(temp)\n",
    "\n",
    "\n",
    "new_negative_word_meaning_sentences = []\n",
    "\n",
    "for i in negative_word_meaning_sentences:\n",
    "  para_phrases = parrot.augment(input_phrase=i, max_return_phrases = 10)\n",
    "  temp = list(list(zip(*para_phrases))[0])[0]\n",
    "  new_negative_word_meaning_sentences.append(temp)\n",
    "\n",
    "\n",
    "clear_output()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "oEdEBFPQiasC"
   },
   "source": [
    "Paraphrased Native Injection Accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 30045,
     "status": "ok",
     "timestamp": 1695329507205,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "uEuhYVF-gMqC",
    "outputId": "3c4d554a-9320-4704-990c-0a6f0b392083",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.831163708086785\n",
      "F1-Macro:  0.8108028285902705\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "for i in new_positive_word_meaning_sentences:\n",
    "  p_emb = torch.cat((p_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "for i in new_negative_word_meaning_sentences:\n",
    "  n_emb = torch.cat((n_emb,get_cls(i).unsqueeze(dim=0)), dim=0)\n",
    "\n",
    "p_emb = p_emb[1:]\n",
    "n_emb = n_emb[1:]\n",
    "\n",
    "test_acc, _, test_f1 = eval_model(\n",
    "  model,\n",
    "  test_data_loader,\n",
    "  loss_fn,\n",
    "  device,\n",
    "  len(df_test)\n",
    ")\n",
    "\n",
    "\n",
    "\n",
    "print(\"Accuracy: \",test_acc.item())\n",
    "print(\"F1-Macro: \",test_f1.item())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {
    "executionInfo": {
     "elapsed": 13,
     "status": "ok",
     "timestamp": 1695329507206,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "2qBYfr3zgvAs",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import random\n",
    "random.seed(42)\n",
    "\n",
    "inputNumbers = range(0,10000)\n",
    "random_seeds = random.sample(inputNumbers, 300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {
    "executionInfo": {
     "elapsed": 11,
     "status": "ok",
     "timestamp": 1695329507206,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "nysMxY5myqsd",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "JuMwkV_v4GvV",
    "outputId": "24e92f01-d79f-4514-f879-14a50b1f8477",
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Working ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... ... "
     ]
    }
   ],
   "source": [
    "f1s = []\n",
    "accuracy = []\n",
    "p_word_list = []\n",
    "n_word_list = []\n",
    "\n",
    "print(\"Working\", end=' ')\n",
    "for i in range(300):\n",
    "    #SELECT RANDOM WORDS FROM NEUTRAL SENTIWORD\n",
    "    df_neutral = df_senti[df_senti['Sentiment']=='Neutral'].sample(n=20, random_state=random_seeds[i])\n",
    "    neutral_words = list(df_neutral[\"Word\"])\n",
    "\n",
    "    #FETCH DEFINITIONS OF THOSE WORDS\n",
    "    neutral_word_meaning_sentences = []\n",
    "    for i in neutral_words:\n",
    "        a = list(df_senti.loc[df_senti['Word'] == i, 'Definition'])[0]\n",
    "        neutral_word_meaning_sentences.append(a)\n",
    "\n",
    "    #MAKE EMBEDDING OF THESE DEFINITIONS\n",
    "    neutral_p_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "    neutral_n_emb = torch.tensor([[1.]*config.hidden_size]).to(device)\n",
    "\n",
    "\n",
    "    for i in neutral_word_meaning_sentences[0:10]:\n",
    "      neutral_p_emb = torch.cat((neutral_p_emb,get_cls(i).unsqueeze(0)), dim=0)\n",
    "\n",
    "    for i in neutral_word_meaning_sentences[10:20]:\n",
    "      neutral_n_emb = torch.cat((neutral_n_emb,get_cls(i).unsqueeze(0)), dim=0)\n",
    "\n",
    "    p_emb = neutral_p_emb[1:]\n",
    "    n_emb = neutral_n_emb[1:]\n",
    "\n",
    "    print('...', end=' ')\n",
    "\n",
    "    p_samples = neutral_words[0:10]\n",
    "    n_samples = neutral_words[10:20]\n",
    "\n",
    "    #EVALUATE ON THESE WORDS\n",
    "    test_acc,_, test_f1 = eval_model(\n",
    "      model,\n",
    "      test_data_loader,\n",
    "      loss_fn,\n",
    "      device,\n",
    "      len(df_test),\n",
    "    )\n",
    "\n",
    "    accuracy.append(test_acc.item())\n",
    "    f1s.append(test_f1.item())\n",
    "    p_word_list.append(p_samples)\n",
    "    n_word_list.append(n_samples)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {
    "executionInfo": {
     "elapsed": 13,
     "status": "ok",
     "timestamp": 1695379584055,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "36UtUdOcDjLK",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import statistics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 245
    },
    "executionInfo": {
     "elapsed": 13,
     "status": "error",
     "timestamp": 1695379584056,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "N_1_hH8S4Hit",
    "outputId": "85d5684e-8de1-402e-9386-f53b050bd477",
    "tags": []
   },
   "outputs": [],
   "source": [
    "stdv = statistics.pstdev(f1s)\n",
    "median = statistics.median(f1s)\n",
    "#filters = [i>median+(2*stdv) for i in f1s]\n",
    "filters = [i>.7 for i in f1s]\n",
    "def filter_2std(target_list, filters):\n",
    "    index = [i for i in range(len(filters)) if filters[i]]\n",
    "    list_a_filtered = [target_list[i] for i in index]\n",
    "    return list_a_filtered\n",
    "\n",
    "p_words_spurious = filter_2std(p_word_list,filters)\n",
    "n_words_spurious = filter_2std(n_word_list,filters)\n",
    "\n",
    "#print(p_words_spurious)\n",
    "#print(n_words_spurious)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "6l78c6yoikRS"
   },
   "source": [
    "Neutral Injection Accuracies"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {
    "executionInfo": {
     "elapsed": 19,
     "status": "ok",
     "timestamp": 1695379585268,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "mmW3cTd4o6Hb",
    "tags": []
   },
   "outputs": [],
   "source": [
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 175
    },
    "executionInfo": {
     "elapsed": 17,
     "status": "error",
     "timestamp": 1695379585269,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "_sc9N6PqFDAF",
    "outputId": "86645206-6fd6-4dcd-eb48-1555f0dcda27",
    "tags": []
   },
   "outputs": [],
   "source": [
    "(hist, bin_edges) = np.histogram(f1s,bins=15)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "#f1s = list(pd.read_csv('/home/m_nsu/ICLR/bert_randomizationtest.csv')['f1s'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "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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kyZNqnVAAAAA4YJCDAAAwCY1LsS2bdvm03b06FG9++67evnllzV//ny/BAYAANDQ1fhbk1Vp3ry5rrnmGqWnp2v69On+GBIAAKDB80shViEpKUnr16/355AAAAANll8Lse3btys6OtqfQwIAADRYNX5GbNWqVT5tHo9H27dv1xtvvKFf/epXfgkMAAA0XKUOQ3/o2lmnbd6s89jiqPqmTJlSZXtERIR+9atf6f77769zUAAAoGErNwy936K5enjCe4ujGhdi69at82mLiIhQq1at/BIQAABAuKhxIdahQwe/BrB7924tWrRImzdv1otDbagAACAASURBVI4dO9StWzdlZmb69MvKylJGRoays7PVrl073XjjjRo1apRPv0WLFmnp0qU6ePCgevToofvvv18DBgzwa8wAAKBunKapwUfzdJo7QmZ5edheFfPrw/q1sWPHDmVlZen0009XXFxclX02bdqk2267TYmJiVqwYIGuuuoqTZ8+XcuXL7f0W7RokTIyMjRq1CjNnz9fp59+uiZMmKDt27cH46MAAIBqcnlNPbZrj26LaSFvaand4dimxlfEevbsKcMwqtXXMAx9/fXXJ+2TmpqqIUOGSPrp+bMtW7b49JkzZ44SExP1xBNPSJIGDhyoH374QbNmzdLVV18th8Mhj8ejuXPn6vrrr9e4ceMkSf3791d6errmzZunjIyMmnxMAACAgKtxITZp0iStXLlSx48fV2pqqlq1aqWDBw/q/fffV+PGjTVixIgajedwnPyinMfj0YYNG3Tvvfda2tPT0/X666/r66+/Vu/evbVx40YVFBQoLS2tso/T6dSwYcP04osvyjTNaheQAAAAwVDjQqxx48Zq1aqVVq9ercaNG1e2Hzt2TDfddJMiIyM1fvx4vwW4Z88elZaWqlu3bpb2+Ph4SVJ2drZ69+6t7OxsSfLpFxcXp+PHj2v//v1q166d3+ICAACoqxoXYq+++qruv/9+SxEmSU2aNNH48eP11FNP+bUQy8vLkyTFxMRY2iteVxzPz8+X2+1WZGSkpV+zZs0k/bQfZm0LMdM0VVhYWKv3BltRUZHlZ7gjH1bkw4p8+CInVuGUD9PrtW3uwsJCOf08f6jcCatxIbZ//345T/DNBqfTqUOHDtU5qKqcKJk/b6+qj2maJ31/dZSWlmrr1q21fr8dcnJy7A6hXiEfVuTDinz4IidW4ZCPEo/Htrm3b98uw+32+7juAIzpbzUuxOLi4vTXv/5VgwcPlutnK+F6PB699NJLPrcG66riilbFla8K+fn5kv53ZSwmJkYlJSUqKSlRRESET7+KcWrD5XJV3gqt74qKipSTk6MuXbooKirK7nBsRz6syIcV+fBFTqzCKR8RNhYtCQkJcv7ijlZd7dy506/jBUqNC7G77rpLkyZN0pAhQ3TJJZeodevWOnjwoN555x0dOnRIc+bM8WuAnTt3lsvl0rfffqvBgwdXtlckuGLJi4qf2dnZSkxMrOyXnZ2txo0bq23btrWOwTCMkNtDMyoqKuRiDiTyYUU+rMiHL3JiFQ75ME7x5Tl/K3UYevz0jmq35SstjImRo1GNS5KTCoXbklIt1hG78MILtXDhQrVt21avvvqqMjIytHTpUrVr104LFizQhRde6NcA3W63Bg4cqLVr11raMzMz1bp168qi66yzzlLTpk21Zs2ayj7l5eVau3atUlJSQuY3BACAcFBuGFrbMlb/LinyexEWSmr1yZOTk5WcnKyioiLl5+crJiam1pdsi4qKlJWVJUnat2+fjh07pjfffFPST+uAxcbGatKkSRo9erSmTp2q9PR0bdy4UcuXL9e0adMql79wu92aOHGiMjIyFBsbq8TERC1fvlx79+7VzJkzaxUbAABAINWpBK24yuSqw67pubm5mjx5sqWt4vXixYs1YMAA9evXT88//7xmzpypVatWqV27dpo6daquvfZay/vGjh0r0zS1ZMkSHTp0SD169ND8+fOVkJBQ6/gAAID/OU1T/fML1MEV3lsc1aoQ27BhgzIyMvTll19KkpYvX64zzjhDjz76qJKTkzV06NBqj9WxY8dqbUGUkpKilJSUk/YxDEPjx4/36/IZAADA/1xeUzOyc6RmP21xdKIVGRq6Gj8jtn79eo0bN04lJSUaO3asvD9b96NFixZasWKFXwMEAABoqGpciM2ePVuDBw/WqlWrdNddd1mO9ezZU9u2bfNbcAAAAA1ZjQuxrVu3auTIkZJ8vxoaGxur3Nxc/0QGAADQwNW4EHM6nSotLa3yWG5urs/WRwAAAKhajQuxpKQk/fOf/6zy2FtvvaW+ffvWOSgAAIBwUONvTd58880aN26cJk2apCuvvFKGYWjz5s1644039NZbb+nll18ORJwAAAAN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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(f1s, bins=15,facecolor = '#008080', edgecolor='#000000', linewidth=0.5)\n",
    "\n",
    "\n",
    "vertical_line_position = 0.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": 73,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "\"\\ndf_randomization_test = pd.DataFrame(list(zip(f1s, accuracy,p_word_list,n_word_list)),\\n               columns =['f1s', 'accuracy','p_word_list','n_word_list'])\\ndf_randomization_test.to_csv('bert_randomizationtest.csv')\\n\""
      ]
     },
     "execution_count": 73,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "'''\n",
    "df_randomization_test = pd.DataFrame(list(zip(f1s, accuracy,p_word_list,n_word_list)),\n",
    "               columns =['f1s', 'accuracy','p_word_list','n_word_list'])\n",
    "df_randomization_test.to_csv('bert_randomizationtest.csv')\n",
    "'''"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "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": 75,
   "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.7999999999999999\n",
      "F1-Macro:  0.7663454669516407\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": 76,
   "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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thYtWqSYmBhJktVq1YQJEzRmzBjFxsae9THefvttNWnSRM2aNdPWrVu9fUkAAAAwEa9WXUhJSVH//v21dOlStW3bVrfffrsuueQSffnll7r77ruVkpJS6cdavXq1unTp4i650qk5wDabTatWrTrr/nv37tXcuXP1zDPPePNSAAAAYFJeHdGdOnWqoqKi9N5776lRo0bu8UOHDmnIkCF6/fXXNX369Eo91u+l+XQ2m00XXHBBpQrziy++qH79+uniiy+u2ouogMvlUl5eXpX3czqdPnl+BJ78/HyVlpYaHSMobNy4Uf/+97913333qZyLZbAAACAASURBVGPHjkbHMT0+14KXvz/XeK8FL2/eay6Xq9KLInhVdH/66Sf97W9/K1NyJalRo0YaO3asXnzxxUo/VnZ2thwOR7lxh8OhrKysM+67fPlybdiwQUuWLKn0851NUVGRduzY4dV+CE7JyckKCwszOobppaWl6d1331Vpaanmzp2rESNG8HWvZnyuBS9/f67xXgte3r7XbDZbpbbzqujm5+crKirK433R0dEqKCjw5mHLOFtbdzqdeumll/Twww+XmfZwrsLCwtSqVasq78dvo8GrTZs2stvtRscwrZKSEj3//PP64osv3GPp6enavHmzBg0aZGAy8+NzLXj5+3ON91rw8ua9tmvXrkpv61XRbdGihT777DN179693H2ff/65WrZsWenHcjgcys7OLjeek5NzxhPRkpKSFBISoltvvdW9f1FRkUpLS5Wdna3w8PBKt/3TWSwWRUZGVnm/kBCvpjvDBCIiIqq0FB6q5v333y9TcqVTv2wnJSWpb9++5f6yBN/hcy14+ftzjfda8PLmvVaVazl4VXQHDx6sZ555Rjk5ObrjjjtUv359HT16VJ9++qmWL1+u+Pj4Sj9WbGxsubm4hYWF2rt3b7m5u6fbvXu30tLS1KVLl3L3XXnllZo0aZLuu+++yr8oADXS559/7nE8MzNTs2bN0jPPPMMFbAAAHnlVdO+66y4dP35cM2bMcK+M4HK5FB4erscff/yMBfWPunfvrhkzZigjI0PR0dGSTl38obCwUD169Khwv5EjR+qOO+4oMzZz5kylpqZqypQpuvDCC6v+wgDUOCdPnqzwvq1btyo9PV1Nmzb1YyIAQKDweh3dUaNG6f7779eGDRuUmZmpqKgoderUSXXq1KnS49x7772aN2+exo4dq7Fjx+r48eNKSEjQbbfdVmbqwtNPP61FixZp+/btkk4dCf7j1IZPPvlEhw8f1tVXX+3tywJQw/Tq1UszZswoN167dm116tRJTZo0MSAVACAQnNOV0erUqeNxnm5VOBwOJSUlKT4+Xg8//LDCw8PVp08fTZgwocx2paWlKikpOafnAhB4hg0bppUrV5ZZDSU0NFTnn3++hg0bxrQFAECFvCq6H330kdLT0/Xwww+Xu2/69Ok6//zzdfvtt1f68Vq0aKE5c+accZuEhAQlJCScdRsA5lKrVi0tWLBA8fHxWrVqlcLCwhQTE6P+/furYcOGRseDCblcLjkLcmWzRSjEajU6DoBz4FXRfe+998rNj/1ddHS03n333SoVXQA4k9DQUD311FM6evSoMjIyFBMTo759+xodCya0a8fP+um7xcrJOiabPULtOvVQ5663sCoAEKC8+peblpam1q1be7wvNjZWaWlp5xQKAP7Ibrdr+PDhqlevnoYNG8baxfC5/Wm/avnnScrJOiZJKnTma8PaJfrlhy/OsieAmsrrObo5OTkex0+ePMlcWgDVonPnzurcubPRMWBSW9evkOQqN75t42pd3uVmpjEAAcirI7pt2rSpcG3LxYsXV3i0FwCAmion64THcWdBngqd+X5OA8AXvCq6AwcO1NKlS/XEE09o06ZNOnz4sDZt2qQnn3xSX331FZflBAAEnPqNm3scd0TVkz2ilp/TAPAFr6Yu3Hbbbdq9e7dmzpypTz/9VNKps1StVqvGjBnDSSIAgIDT8ao/a89vm/5w9NaiK7r1YRk7IEB5PUf30UcfVf/+/fX999+7z4Lu1q0bVygCAASkqJiGun3gBG1c95WOHkpTbUdddeh8nZpdeInR0QB46ZwuGNGsWTP17t1bs2fP1oYNG7R161Y98MADatWqla/yAQDgN1ExDXXdzYONjgHARypddF9++WV9+eWXWrlypXssLy9Pd911lw4cOCCX69SZqp9//rk+/PBDtWzZ0udhAQAAgMqq9MloGzZs0C233FJmbN68edq/f7+GDBmin3/+WQsWLFBkZKRmzZrl86AAAABAVVS66O7bt0/t27cvM7ZixQrFxMRo4sSJql27tjp27Khhw4Zp3bp1Pg8KAAAAVEWli252drYaNGjgvl1cXKwtW7boqquukvW0RbQvueQSHT161LcpAQAAgCqqdNGtV6+ejhw54r69fft2FRcXlzvKGxISIpvN5ruEAAAAgBcqXXTbtWunDz/80H3S2aeffiqLxaIuXbqU2W737t2qX7++b1MCAAAAVVTpVRdGjhyp++67TzfddJOio6O1ceNGXXHFFWrXrl2Z7VasWKEOHTr4PCgAAABQFZU+onvZZZfprbfeUoMGDZSbm6u7775bb775Zpltjh49qkOHDqlnz54+DwoAAABURZUuGHHdddfpuuuuq/D++vXruy8JDAAAABip0kd0AQAAgEBC0QUAAIApUXQBAABgShRdAAAAmBJFFwAAAKZE0QUAAIApUXQBAABgShRdAAAAmBJFFwAAAKZE0QUAAIApUXQBAABgShRdAAAAmBJFFwAAAKZE0QUAAIApUXQBAABgShRdAAAAmBJFFwAAAKZE0QUAAIApUXQBAABgShRdAAAAmFKo0QEA4Gx27NihmTNnauvWrWrSpIkeeOAB9ezZ0+hYAIAajqILoEb77bffNHjwYOXn50uS0tPT9fPPPys+Pl533HGHwekAADUZRRdAlbhcLjmdTr8938yZM90l93T//Oc/1bt3b4WE+G8Glt1ul8Vi8dvzAQDODUUXQKW5XC5NnjxZO3fu9NtzJicnexw/ePCghg4dqtBQ/32MtW7dWnFxcZRdAAgQnIwGoEaz2Wwex61Wq6xWq5/TAAACCUd0AVSaxWJRXFycX6cu/PLLLxo1apRKS0vLjI8aNUojRozwWw6JqQsAEGgougCqxGKxKDw83G/P17VrV73xxht64403tGvXLoWGhmrMmDEaNWoUpRMAcEYUXQA13g033KCuXbtq6NChslgs7v8CAHAmFF0gwPh71YOawul0uldYCMbXLzF1AgCqiqILBBin06nhw4cbHcNQY8aMMTqCIRITE/06bQQAAh2rLgAAAMCUOKILBLAXrm4smzV4/pTtcrkkKaj+fF9Y4tKz6w4aHQMAAhJFFwhgNqtFdit/mDG30rNvAgDwiJ+QAAAAMCWKLgAAAEyJogsAAABTougCAADAlCi6AAAAMCWKLgAAAEyJogsAAABTougCAADAlCi6AAAAMCWKLgAAAEyJogsAAABTCjU6AAAAwO8KS4qMjoBq5s/vMUUXAAAYyuVyuf//lXXvGZgE/nb69746MHUBAAAApsQRXQB+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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": 77,
   "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": 78,
   "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": 79,
   "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.8307692307692307\n",
      "F1-Macro:  0.8095342665287977\n"
     ]
    },
    {
     "data": {
      "image/png": "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syk5OTmsUxd27NihSZMmqbi4uMz45MmTNXLkyLDlkJi6AAAAYGk2m01utztsr9erVy+98MIL+utf/6otW7bI4XDot7/9bdhLbl3A9XEAAIAw69Onj1544QVdeOGFatu2rYYPH252JEui6AIAAMCSKLoAAACwJIouAAAALImiCwAAAEui6AIAAMCSKLoAAACwJIouAAAALImiCwAAAEui6AIAAMCSKLoAAACwJIouAAAALImiCwAAAEui6AIAAMCSKLoAAACwJIouAAAALImiCwAAAEui6AIAAMCSKLoAAACwJIouAAAALImiCwAAAEui6AIAAMCSKLoAAACwJIouAAAALImiCwAAAEui6AIAAMCSIs0OAAAAUBdt2bJFmZmZioyMVHFxsdlxLIkrugAAAGFUVFSke++9V5MnT1ZGRoaOHj2q0aNH6+jRo2ZHsxyKLgAAQBgtW7ZM69evLzN2+PBhzZo1y6RE1kXRBQAACKOPPvoo4Pjnn3+uvLy8MKexNoouAABAGBmGUeF4RdsQHIouAABAGA0ePDjgeP/+/RUTExPmNNZG0QUAAAijm2++Wf369Ssz1qxZMz300EMmJbIuii4AAEAYuVwuvfDCC5o9e7YaNWqkZs2a6fXXX1fLli3NjmY5rKMLAABggl69eik+Pl6S5HA4TE5jTVzRBQAAgCVRdAEAAGBJFF0AAABYEkUXAAAAlkTRBQAAgCVRdAEAAGBJFF0AAABYEkUXAAAgzPbs2aPHH39c6enpOnTokNavX292JEui6AIAAITR3r17NX78eH300Ufy+XzKz8/Xww8/rHfffdfsaJZD0QUAAAijxYsXKy8vr9z4ggUL5Pf7TUhkXRRdAACAMNq5c2fA8SNHjignJyfMaayNogsAABBGLVq0CDhev359xcTEhDmNtVF0AQAAwmj06NGKiChfwUaNGqXIyEgTEllXjSi66enpGj9+vHr06KH+/ftrxowZKiwsrNSxWVlZevzxx3XZZZepW7duGjJkiJYtW1bNiQEAAILTp08fpaSkqG3btpIku92uO+64Q+PHjzc3mAWZ/mNDTk6OkpKS1Lx5c82ePVunT5/WzJkzlZWVpWefffacx+bl5WnMmDFyuVx65JFH1LBhQ+3fv18+ny9M6QEAAKruyiuv1IABA3T77bfLZrPp9ttvD3iVF+fH9KK7bNky5eTk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DABAyF199dXavn17ufFBgwYpOjrahEQAzldQN6N16dJFXbp0CXUWAABMM2rUKH377bdlpjC0bdtW06ZNMzEVgPPB72IAAJDkcDj0xz/+US+//LKaNm2qVq1aacmSJUpISDA7GoAgBVV0N2zYoH/961+lX588eVITJkzQwIED9dBDD8nr9YYsIAAA4dS5c2fFx8crNjZWdrvd7DgAzkNQRXf27NlKS0sr/fqZZ57R119/rZ49e+qDDz7QSy+9FLKAAAAAQDCCKrr79u0rnaNbXFysVatWaerUqXrhhRd0zz336L333gtpSAAAAKCqgiq6ubm58ng8kqTt27eroKBAgwcPliR1795dR48eDV1CAAAAIAhBFd2GDRtq3759kqTPP/9czZs3V9OmTSVJeXl5iozkycIAAAAwV1CN9PLLL9dzzz2nPXv26O2339Z1111Xum3v3r1q0aJFyAICAAAAwQiq6N533306cuSI3njjDXXv3l0TJ04s3fbuu++qZ8+eIQsIAAAABCOoohsfH6+FCxcG3PbKK6/I6XSeVygAAADgfJ33AyMKCwt1/PhxFRcXS5JiYmIougAAADBd0EX3iy++0E033aRevXrpl7/8pXbt2iVJmj59uj788MOQBQQAAACCEfST0caPHy+v16tx48bJ7/eXbouLi9Nbb70VsoAAAABAMIJ+MtqgQYO0YsUK/fa3vy2zrVOnTvr+++9DEg4AgHA7evSocnJyVFBQYHYUAOcpqKK7c+dOjRo1SpJks9nKbIuPj9epU6fOPxkAAGFkGIb+8Ic/aMSIETp06JDS09N11113KSsry+xoAIIUVNG12+3y+XwBt506dUr16tU7r1AAAITbm2++qeXLl5eZjvftt99q1qxZJqYCcD6CKrrdunXTypUrA2774IMP1KNHj/MKBQBAuL3zzjsBx1etWsU0BqCWCqro/u///q9WrVqlyZMn6+OPP5bNZtOWLVv0xBNP6IMPPtAdd9wR6pwAoE2bNumee+7Rpk2bzI4CC6qozBYXF1f4W0wANVtQRXfAgAFKSUnR119/rSlTpsgwDD3xxBN69913NXPmTPXp0yfUOQHUYXl5eXrllVf04IMPatu2bZo7d668Xq/ZsWAxl19+ecDxHj16yOPxhDkNgFAI6sloknTttddqyJAh2rx5s06ePKm4uDj16tVL0dHRocwH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WO8srsVi4eTJk78YdOvO5tad1a1z4sQJTCZTvbO7IiIiIvK/xek7ulFRUbzxxhtcuHCBLl26ALBnzx4sFgsjR4686byePXvSr18/du3aRXR0tG18586dhIWFNetCNKvVimEYHDlypOlvRERERERanMVicXhX1+k7urGxsXh7e5OcnExBQQE7duxg6dKlPProo3Y7ui+//DJ333233dxZs2bx/vvvk5mZyaFDh/jDH/7Axx9/zKxZs5rVi8lkavbZXhERERFpeU3Jayaj7uotJyopKSEjI4PPP/8cDw8PYmJiSE1NxcPDw1aTlpZGfn4+3377rd3c/Px81q5dy5kzZ+jduzcpKSmMHz++td+CiIiIiNxibomgKyIiIiLya3P60QURERERkZagoCsiIiIiLklBV0RERERckoKuiIiIiLgkBV0RERERcUkKuiIiIiLikhR0RURERMQlKeiKiIiIiEtS0BURERERl6SgKyIiIiIuSUFXRERERFySgq6IiIiIuCQFXRERERFxSQq6IiIiIuKSFHSlUWlpacTExHDw4EFiYmIIDQ1lwoQJHD582FYzatQolixZwoYNGxgxYgQDBw5k5syZnDt3zomdS1vTlLX21ltv8fDDD3P//feTnJxMeXm5EzuXtqZurR06dIjHHnuMQYMGMXHiRIqKimw1ISEhrF+/nldffZVhw4YxePBg0tLSuHjxohM7l7bG0bWWnZ3N6tWriYyMJDw8nJdeeonLly87sXPXoKArDikrK2Px4sUkJSWxatUqzGYzSUlJnD9/3lazZ88e9u7dS3p6Ounp6Rw5coRnn33WiV1LW+TIWtu3bx/79+9n4cKFzJ8/n88++4ylS5c6sWtpi8rKysjIyCApKYnMzEyuXLlCSkoKVqvVVpOTk0NxcTHLly8nNTWV3bt3s2DBAid2LW2RI2tt8+bNfPfdd/zxj38kOTmZ9957jzVr1jixa9fQ3tkNSNtQUVHBqlWriIiIAGDo0KGMHDmSN998kxdffBGAS5cusX79enx8fADo1q0bU6dO5aOPPuLBBx90Wu/Stjiy1gzD4I033sBsNgPw3XffsXHjRq5du0a7dvr3uzimsrKSt956i+DgYAA6dOhAYmIiX331FUOGDAHAbDaTlZWFm5ub7fGCBQtISUkhMDDQab1L2+LIWvPz82PlypUAREVFceTIEXbv3k1qaqrT+nYF+okgDvH29rYFDwAfHx+GDRtm91/K4eHhtpALEBERgZeXl12NSGMcWWtDhw61hVyAoKAgrFar3a6vSGO6du1qCx6ALbiePXvWNvbwww/bQi7AmDFjMAyDI0eOtF6j0uY5staGDx9uNycoKIjS0tLWadCFKeiKQ3x9feuN3X777ZSVldk9bqxGpDGOrLWf/4MKwN3dHYCrV6+2bHPiUhxZRzf+vdapUyfc3d11/YE0iSNrraEai8XS8s25OAVdcUhDF/qcP38ef39/u8eN1Yg0xpG1JtJabvx7rbKyEqvVSteuXZ3UkYg0hYKuOKS6uppPP/3U7nFhYSEDBw60jR06dIjq6mrb408//ZSLFy/a1Yg0xpG1JtJa9u/fT21tre3x3//+d0wmE6GhoU7sSkQcpYvRxCGdO3dm/vz5zJo1C29vb7KzswFISEiw1dx2221MmzaNadOmUV1dzYoVKwgLC2PEiBHOalvaIEfWmkhrsVgs/P73vycuLo7Tp0+zYsUKxo4dqwvRRNoIBV1xiL+/P6mpqbz66qucPHmS4OBgNm7ciJ+fn60mOjqabt26sWjRIqqqqoiMjGTx4sVO7FraIkfWmkhrmTJlCuXl5cydOxeLxUJ0dDQLFy50dlsi4iCTYRiGs5uQW1taWhpFRUXs3LnzpjWjRo3ioYce0g8A+a84stZEWktISAhz584lKSnJ2a2ISDPpjK6IiIiIuCQFXRERERFxSTq6ICIiIiIuSTu6IiIiIuKSFHRFRERExCUp6IqIiIiIS1LQFRERERGXpKArIiIiIi5JQVdE5L9w7NgxXnrpJUaNGkVoaCiDBw/m8ccfJzs7m4qKiia91sGDB3nttddaqNNf3+nTpwkJCWH79u3ObkVEpEG6vZiISDPl5eWxePFi+vbtS1xcHEFBQdTU1FBUVEReXh4DBgwgKyvL4ddbsmQJmzdv5ttvv23Brn89FouFo0eP0qtXL3x9fZ3djohIPe2d3YCISFv05Zdfkp6eTmRkJGvWrMFsNtueGz58OImJiRQUFDixw5ZTW1tLbW0tZrOZQYMGObsdEZGb0o6uiEgzzJgxg4KCAvbu3Uv37t1/sXbXrl1s27aNf/3rX1RVVREQEMDo0aNJTk6mY8eOAKSlpZGfn19v7j/+8Q969OiBYRhs2bKFvLw8SkpK6NChAxEREcyZM4eePXva6g3DYN26dWzdupUff/yR4OBgZs+ezdq1awHIycmx1X7//ff86U9/4uOPP6a6upqePXvyu9/9jqlTp9Ku3fWTbadPn2b06NGkpqZitVrZtm0bpaWlrF27ln79+jF69GiWLVvGhAkTbK/773//m9dee41PPvnE9rqTJ0/mqaeestVcu3aNtWvX8u677/LDDz9gNpvp3r07EydOJCEhoRnfERGR+rSjKyLSRLW1tRQWFnLPPfc0GnLhevCLiooiISEBT09PiouLyc7O5uuvv+avf/0rAMnJyVy+fJndu3ezdetW29yuXbsCsHDhQvLz85kyZQqpqalUVlaSlZVFbGws7777Ln5+fgBkZmaybt06Jk2aRHR0NKWlpbzyyitYrVb69u1re93y8nJiY2OxWq0899xzBAQEcODAAZYvX87JkydJT0+3ew85OTn06dOHefPm4eXlRe/evRt8r8ePHyc2Npbu3bszb948/P39+eijj8jIyODChQukpKQAsGHDBl5//XVmzpzJkCFDqKmpobi4mOrqase/ESIijVDQFRFpogsXLvDTTz/Ro0cPh+qTk5NtfzYMg/vuu4/AwEAmT57MsWPHGDBgAL169bKF1RuPAxw+fJi8vDzS0tJITEy0jQ8ZMoSxY8eyadMm5syZQ2VlJZs2beKRRx5hyZIltrrg4GAmTZpkF3Q3bdrE2bNneeeddwgLCwNgxIgR1NbWkpubS0JCgl19hw4d2LhxI+7u7rax06dP13uvy5Yt47bbbuPtt9/Gy8sLuH6Uw2KxsH79eqZMmUKnTp344osv6N+/P88++6xt7ogRIxz6eoqIOEp3XRARaWGnTp1i9uzZDB8+nLvuuot77rmHyZMnA1BcXNzo/P3792MymfjNb35DTU2N7cPPz48BAwbw2WefAdcDscViYfz48XbzBw0aREBAgN1YYWEhQUFBtpBbZ8KECRiGQWFhod34qFGj7EJuQ65evUphYSHR0dF4eHjY9RoVFcXVq1c5fPgwAKGhoRw7doz09HQKCgq4ePFio18HEZGm0o6uiEgTdenSBU9PzwZ3NG906dIl4uPj6dChA88//zx9+vTBw8OD0tJSUlJSuHLlSqOvcf78eQzDIDIyssHn687o1t3O7Pbbb69XU7dbXKeioqJe+IX/Pypx463R/P39G+2zoqKCmpoacnJy7M4C/9yFCxcAmD59Oh07duRvf/sbubm5uLm5MWTIEFJTUwkNDW30c4mIOEJBV0Skidzc3Bg2bBgFBQWUlpbSrVu3m9YWFhZy7tw5cnJyeOCBB2zjTTmL2qVLF0wmE5s3b7a7u0OdurHOnTsD14PxjX788Ue7YNu5c2fKysrq1Z07d872OX/OZDI12qePjw9ubm789re/JT4+vsGauuMe7du3JzExkcTERKqqqvjkk0/IzMzk6aef5sCBA3h6ejb6+UREGqOjCyIizTB9+nQMw+CVV17BYrHUe95qtbJv3z5bQLwxoObm5tabU1dz4y7vQw89hGEYnD17ltDQ0HofISEhAAwcOBCz2cyuXbvs5h8+fJgzZ87YjUVERHD8+HG++eYbu/EdO3ZgMpkIDw935Mtgx9PTk/DwcI4ePUpISEiDvd4YoOF6QB43bhzx8fFUVFTU61VEpLm0oysi0gyDBw8mPT2dxYsX88QTTxAbG0twcDA1NTUcPXqUvLw8goODycjIoFOnTixatIiUlBTat2/Pe++91+Avhejfvz8A2dnZREVF0a5dO0JCQrj//vuZNGkSL7/8MkVFRQwdOhRPT0/Kysr4/PPP6d+/P/Hx8XTu3JnExETWrVuHj4+P7a4LWVlZ+Pv72+3KTp06lR07djB9+nRmzZrFnXfeyYEDB9iyZQtxcXF2F6I1xfz584mPj+epp54iLi6OgIAALl26xMmTJ9m3b5/tLhMzZswgODiYe++9F19fX86cOcObb75JQEDATe/oICLSVAq6IiLN9OSTTxIWFsZf/vIXNmzYQFlZGe7u7vTp04eYmBgmT55Mly5dWLduHcuXL2fOnDl4enoyevRoMjMzefzxx+1eLyYmhi+++IItW7aQlZWFYRi2++guWbKEgQMHsnXrVt5++22uXbtG165due++++wuKHvhhRfw9PQkNzeX7du3069fP9LT08nMzMTHx8dW5+vrS25uLitXrmTlypVcunSJHj16MGfOHLs7OzRVUFAQ27dvZ82aNaxatYry8nK8vb3p3bs3I0eOtNWFh4eze/du3nnnHS5evIi/vz+RkZEkJyc3etGbiIij9AsjRERc3KlTpxg/fjwpKSnMmDHD2e2IiLQa7eiKiLiQY8eOsXPnTgYPHoyXlxclJSVs2LABLy8vJk6c6Oz2RERalYKuiIgL8fT0pKioiG3btlFdXY2Xlxfh4eE8//zz9W4xJiLi6nR0QURERERckm4vJiIiIiIuSUFXRERERFySgq6IiIiIuCQFXRERERFxSQq6IiIiIuKSFHRFRERExCUp6IqIiIiIS1LQFRERERGX9B9lctHp+QXLMAAAAABJRU5ErkJggg==",
      "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": 80,
   "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": [
       "['thunnus genus_thunnus',\n",
       " 'rajidae family_rajidae',\n",
       " 'brush_fire',\n",
       " 'genus_aethionema aethionema',\n",
       " 'plane_table',\n",
       " 'succus juice',\n",
       " 'simplex',\n",
       " 'disqualify',\n",
       " 'go_board',\n",
       " 'sunnah sunna hadith']"
      ]
     },
     "execution_count": 80,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "n_words_spurious[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "metadata": {
    "executionInfo": {
     "elapsed": 33,
     "status": "aborted",
     "timestamp": 1695329093836,
     "user": {
      "displayName": "m m",
      "userId": "12156804663229931259"
     },
     "user_tz": -360
    },
    "id": "lvMoMpyEXQVt",
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['megagametophyte',\n",
       " 'woolly_thistle scotch_thistle onopordum_acanthium onopordon_acanthium cotton_thistle',\n",
       " 'grubstake',\n",
       " 'sit#',\n",
       " 'correspondence_school',\n",
       " 'cricket_match',\n",
       " 'baseball_season',\n",
       " 'nasopharyngeal',\n",
       " 'harness',\n",
       " 'alundum']"
      ]
     },
     "execution_count": 81,
     "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": 82,
   "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": 83,
   "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",
      "Advocate.csv is Negatively Spurious.\n",
      "Positive Acc: 0.8139978343490666 \n",
      "Negative Acc: 0.6837036646309669\n",
      "------------------------------------------------------------------------\n",
      "Dialogue.csv is Positively Spurious.\n",
      "Positive Acc: 0.8106342348363533 \n",
      "Negative Acc: 0.5495738957632732\n",
      "------------------------------------------------------------------------\n",
      "Indian.csv is Positively Spurious.\n",
      "Indian.csv is Negatively Spurious.\n",
      "Positive Acc: 0.810624027245748 \n",
      "Negative Acc: 0.6833504218879306\n",
      "------------------------------------------------------------------------\n",
      "Orientation.csv is Positively Spurious.\n",
      "Positive Acc: 0.8110451090737474 \n",
      "Negative Acc: 0.5432007208024967\n",
      "------------------------------------------------------------------------\n",
      "Colored.csv is Positively Spurious.\n",
      "Colored.csv is Negatively Spurious.\n",
      "Positive Acc: 0.8108120985147227 \n",
      "Negative Acc: 0.7238016500150313\n",
      "------------------------------------------------------------------------\n",
      "occupations1950_nonprofessional.csv is Positively Spurious.\n",
      "occupations1950_nonprofessional.csv is Negatively Spurious.\n",
      "Positive Acc: 0.8100763260911398 \n",
      "Negative Acc: 0.7213410512689709\n",
      "------------------------------------------------------------------------\n",
      "Society.csv is Positively Spurious.\n",
      "Society.csv is Negatively Spurious.\n",
      "Positive Acc: 0.8113558975576473 \n",
      "Negative Acc: 0.6029627914154212\n",
      "------------------------------------------------------------------------\n",
      "Money.csv is Positively Spurious.\n",
      "Money.csv is Negatively Spurious.\n",
      "Positive Acc: 0.8122687396218613 \n",
      "Negative Acc: 0.61581938667103\n",
      "------------------------------------------------------------------------\n",
      "Woman.csv is Positively Spurious.\n",
      "Woman.csv is Negatively Spurious.\n",
      "Positive Acc: 0.7987737152079967 \n",
      "Negative Acc: 0.7642464108477087\n",
      "------------------------------------------------------------------------\n",
      "Activist.csv is Positively Spurious.\n",
      "Activist.csv is Negatively Spurious.\n",
      "Positive Acc: 0.8100648900519787 \n",
      "Negative Acc: 0.7611849440032612\n",
      "------------------------------------------------------------------------\n",
      "Retarded.csv is Positively Spurious.\n",
      "Retarded.csv is Negatively Spurious.\n",
      "Positive Acc: 0.8135606341777187 \n",
      "Negative Acc: 0.7707259409924155\n",
      "------------------------------------------------------------------------\n",
      "Chubby.csv is Positively Spurious.\n",
      "Chubby.csv is Negatively Spurious.\n",
      "Positive Acc: 0.8115058463920277 \n",
      "Negative Acc: 0.7553653772935512\n",
      "------------------------------------------------------------------------\n",
      "Jew.csv is Positively Spurious.\n",
      "Jew.csv is Negatively Spurious.\n",
      "Positive Acc: 0.8102334475939333 \n",
      "Negative Acc: 0.7018914953756618\n",
      "------------------------------------------------------------------------\n",
      "Homosexual.csv is Positively Spurious.\n",
      "Homosexual.csv is Negatively Spurious.\n",
      "Positive Acc: 0.8090580702376997 \n",
      "Negative Acc: 0.7252811160275562\n",
      "------------------------------------------------------------------------\n",
      "Misgendering.csv is Positively Spurious.\n",
      "Misgendering.csv is Negatively Spurious.\n",
      "Positive Acc: 0.7833807371440348 \n",
      "Negative Acc: 0.780033278340669\n",
      "------------------------------------------------------------------------\n",
      "Marriage.csv is Positively Spurious.\n",
      "Marriage.csv is Negatively Spurious.\n",
      "Positive Acc: 0.8082898802294043 \n",
      "Negative Acc: 0.7584539037670331\n",
      "------------------------------------------------------------------------\n",
      "Industry.csv is Positively Spurious.\n",
      "Industry.csv is Negatively Spurious.\n",
      "Positive Acc: 0.8093796005796872 \n",
      "Negative Acc: 0.6332938907338749\n",
      "------------------------------------------------------------------------\n",
      "Oriental.csv is Positively Spurious.\n",
      "Oriental.csv is Negatively Spurious.\n",
      "Positive Acc: 0.8121441090800436 \n",
      "Negative Acc: 0.6621151483085826\n",
      "------------------------------------------------------------------------\n",
      "occupations1950_professional.csv is Positively Spurious.\n",
      "occupations1950_professional.csv is Negatively Spurious.\n",
      "Positive Acc: 0.8149561497619245 \n",
      "Negative Acc: 0.6307504233000087\n",
      "------------------------------------------------------------------------\n",
      "Gender.csv is Positively Spurious.\n",
      "Gender.csv is Negatively Spurious.\n",
      "Positive Acc: 0.8071281515072526 \n",
      "Negative Acc: 0.7687738605979565\n",
      "------------------------------------------------------------------------\n",
      "Media.csv is Positively Spurious.\n",
      "Media.csv is Negatively Spurious.\n",
      "Positive Acc: 0.8097547572722206 \n",
      "Negative Acc: 0.7478197621343761\n",
      "------------------------------------------------------------------------\n",
      "Islam.csv is Positively Spurious.\n",
      "Positive Acc: 0.8118678001213222 \n",
      "Negative Acc: 0.3902625399599454\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
}
