{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Evaluation \n",
    "\n",
    "1. CF\n",
    "\n",
    "2. CB"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# For data manipulation and analysis\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "\n",
    "# For text preprocessing\n",
    "import re\n",
    "import nltk\n",
    "from nltk.corpus import stopwords\n",
    "from nltk.stem import WordNetLemmatizer\n",
    "from sklearn.feature_extraction.text import TfidfVectorizer\n",
    "import datetime\n",
    "import string\n",
    "\n",
    "# For multilabel classification\n",
    "from sklearn.preprocessing import MultiLabelBinarizer\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from sklearn.multiclass import OneVsRestClassifier\n",
    "from sklearn.ensemble import RandomForestClassifier\n",
    "from sklearn.naive_bayes import MultinomialNB\n",
    "import os\n",
    "\n",
    "# For neural networks\n",
    "\n",
    "\n",
    "\n",
    "# For model evaluation\n",
    "from sklearn.metrics import accuracy_score, f1_score, precision_score, recall_score, classification_report, confusion_matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "# df_s.drop(columns=['Unnamed: 0','Unnamed: 0.1'], inplace=True)\n",
    "# df_s.to_csv(\"../dataset/df_tag_sentiment.csv\",index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "# clusters, tags, sentiment\n",
    "\n",
    "\n",
    "tags_c = pd.read_csv('../dataset/final_clusters.csv')\n",
    "\n",
    "\n",
    "tags = pd.read_csv(\"../dataset/tags_withglovevec.csv\")\n",
    "\n",
    "df_s = pd.read_csv('../dataset/df_tag_sentiment.csv')\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "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>userId</th>\n",
       "      <th>movieId</th>\n",
       "      <th>tag</th>\n",
       "      <th>timestamp</th>\n",
       "      <th>un-lemmatised</th>\n",
       "      <th>glove_vec</th>\n",
       "      <th>has_glove_vec</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>693</td>\n",
       "      <td>296</td>\n",
       "      <td>action</td>\n",
       "      <td>2010-12-09 11:04:06</td>\n",
       "      <td>action</td>\n",
       "      <td>[ 2.0240e-02  8.4992e-01 -7.8150e-01 -8.2769e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>693</td>\n",
       "      <td>296</td>\n",
       "      <td>drug</td>\n",
       "      <td>2010-12-09 11:04:17</td>\n",
       "      <td>drugs</td>\n",
       "      <td>[-0.98609    0.12477   -0.58491   -0.71019    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>693</td>\n",
       "      <td>296</td>\n",
       "      <td>rape</td>\n",
       "      <td>2010-12-09 11:04:24</td>\n",
       "      <td>rape</td>\n",
       "      <td>[ 0.63519   0.013247 -0.35237  -0.64106  -0.56...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>693</td>\n",
       "      <td>296</td>\n",
       "      <td>violence</td>\n",
       "      <td>2010-12-09 11:04:21</td>\n",
       "      <td>violence</td>\n",
       "      <td>[ 2.5781e-02  8.0070e-01 -1.8627e-01 -4.0211e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>693</td>\n",
       "      <td>805</td>\n",
       "      <td>rape</td>\n",
       "      <td>2010-12-09 11:00:42</td>\n",
       "      <td>rape</td>\n",
       "      <td>[ 0.63519   0.013247 -0.35237  -0.64106  -0.56...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48146</th>\n",
       "      <td>138280</td>\n",
       "      <td>116797</td>\n",
       "      <td>history</td>\n",
       "      <td>2015-01-30 23:07:25</td>\n",
       "      <td>history</td>\n",
       "      <td>[ 4.5847e-02  7.4334e-02  1.5092e-02 -2.6392e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48147</th>\n",
       "      <td>138280</td>\n",
       "      <td>116797</td>\n",
       "      <td>informatics</td>\n",
       "      <td>2015-01-30 23:07:35</td>\n",
       "      <td>informatics</td>\n",
       "      <td>[ 1.7728e-01  1.5395e-01  7.7811e-01  1.6527e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48148</th>\n",
       "      <td>138280</td>\n",
       "      <td>116797</td>\n",
       "      <td>mathematics</td>\n",
       "      <td>2015-01-30 23:07:17</td>\n",
       "      <td>mathematics</td>\n",
       "      <td>[ 1.0033e+00  3.8874e-01  6.4312e-01 -6.8630e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48149</th>\n",
       "      <td>138280</td>\n",
       "      <td>117871</td>\n",
       "      <td>image</td>\n",
       "      <td>2015-01-30 23:09:16</td>\n",
       "      <td>image</td>\n",
       "      <td>[ 1.1091e-02  4.8461e-01  1.9142e-02  8.3725e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48150</th>\n",
       "      <td>138280</td>\n",
       "      <td>117871</td>\n",
       "      <td>story</td>\n",
       "      <td>2015-01-30 23:09:25</td>\n",
       "      <td>story</td>\n",
       "      <td>[-0.35058    0.58245   -0.065584  -0.41768    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>48151 rows × 7 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "       userId  movieId          tag            timestamp un-lemmatised  \\\n",
       "0         693      296       action  2010-12-09 11:04:06        action   \n",
       "1         693      296         drug  2010-12-09 11:04:17         drugs   \n",
       "2         693      296         rape  2010-12-09 11:04:24          rape   \n",
       "3         693      296     violence  2010-12-09 11:04:21      violence   \n",
       "4         693      805         rape  2010-12-09 11:00:42          rape   \n",
       "...       ...      ...          ...                  ...           ...   \n",
       "48146  138280   116797      history  2015-01-30 23:07:25       history   \n",
       "48147  138280   116797  informatics  2015-01-30 23:07:35   informatics   \n",
       "48148  138280   116797  mathematics  2015-01-30 23:07:17   mathematics   \n",
       "48149  138280   117871        image  2015-01-30 23:09:16         image   \n",
       "48150  138280   117871        story  2015-01-30 23:09:25         story   \n",
       "\n",
       "                                               glove_vec  has_glove_vec  \n",
       "0      [ 2.0240e-02  8.4992e-01 -7.8150e-01 -8.2769e-...           True  \n",
       "1      [-0.98609    0.12477   -0.58491   -0.71019    ...           True  \n",
       "2      [ 0.63519   0.013247 -0.35237  -0.64106  -0.56...           True  \n",
       "3      [ 2.5781e-02  8.0070e-01 -1.8627e-01 -4.0211e-...           True  \n",
       "4      [ 0.63519   0.013247 -0.35237  -0.64106  -0.56...           True  \n",
       "...                                                  ...            ...  \n",
       "48146  [ 4.5847e-02  7.4334e-02  1.5092e-02 -2.6392e-...           True  \n",
       "48147  [ 1.7728e-01  1.5395e-01  7.7811e-01  1.6527e-...           True  \n",
       "48148  [ 1.0033e+00  3.8874e-01  6.4312e-01 -6.8630e-...           True  \n",
       "48149  [ 1.1091e-02  4.8461e-01  1.9142e-02  8.3725e-...           True  \n",
       "48150  [-0.35058    0.58245   -0.065584  -0.41768    ...           True  \n",
       "\n",
       "[48151 rows x 7 columns]"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tags"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Unnamed: 0</th>\n",
       "      <th>userId</th>\n",
       "      <th>movieId</th>\n",
       "      <th>tag</th>\n",
       "      <th>timestamp</th>\n",
       "      <th>un-lemmatised</th>\n",
       "      <th>glove_vec</th>\n",
       "      <th>has_glove_vec</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>96</td>\n",
       "      <td>106696</td>\n",
       "      <td>animation</td>\n",
       "      <td>1396097490</td>\n",
       "      <td>animation</td>\n",
       "      <td>[ 0.037307   0.35589   -0.49355   -0.83947    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2</td>\n",
       "      <td>96</td>\n",
       "      <td>106696</td>\n",
       "      <td>beautiful</td>\n",
       "      <td>1396097497</td>\n",
       "      <td>beautiful</td>\n",
       "      <td>[ 1.1005    -0.22599   -0.41616   -0.62486   -...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>3</td>\n",
       "      <td>96</td>\n",
       "      <td>106696</td>\n",
       "      <td>character</td>\n",
       "      <td>1396097500</td>\n",
       "      <td>characters</td>\n",
       "      <td>[ 0.29665    0.34324   -0.32366   -0.18469    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>5</td>\n",
       "      <td>96</td>\n",
       "      <td>106696</td>\n",
       "      <td>feminist</td>\n",
       "      <td>1396097502</td>\n",
       "      <td>feminist</td>\n",
       "      <td>[-0.1478     0.60717   -0.75788   -0.63978    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>6</td>\n",
       "      <td>96</td>\n",
       "      <td>106696</td>\n",
       "      <td>ice</td>\n",
       "      <td>1396097505</td>\n",
       "      <td>ice</td>\n",
       "      <td>[ 0.055307  -0.45217   -0.41147    0.15984   -...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48215</th>\n",
       "      <td>139012</td>\n",
       "      <td>138345</td>\n",
       "      <td>2485</td>\n",
       "      <td>romance</td>\n",
       "      <td>1352724276</td>\n",
       "      <td>romance</td>\n",
       "      <td>[ 0.75581    0.11897    0.14055   -1.2454     ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48216</th>\n",
       "      <td>139016</td>\n",
       "      <td>138345</td>\n",
       "      <td>2485</td>\n",
       "      <td>teenager</td>\n",
       "      <td>1352724283</td>\n",
       "      <td>teenagers</td>\n",
       "      <td>[ 0.39856   -0.22003   -0.28652   -0.93199    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48217</th>\n",
       "      <td>139017</td>\n",
       "      <td>138345</td>\n",
       "      <td>3617</td>\n",
       "      <td>funny</td>\n",
       "      <td>1352724390</td>\n",
       "      <td>funny</td>\n",
       "      <td>[ 3.9595e-01 -8.3109e-02 -2.8795e-01 -2.9139e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48218</th>\n",
       "      <td>139022</td>\n",
       "      <td>138345</td>\n",
       "      <td>3617</td>\n",
       "      <td>robot</td>\n",
       "      <td>1352724375</td>\n",
       "      <td>robots</td>\n",
       "      <td>[-2.4619e-01  2.1412e-01 -3.5943e-01 -4.5980e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48219</th>\n",
       "      <td>139031</td>\n",
       "      <td>138345</td>\n",
       "      <td>58559</td>\n",
       "      <td>action</td>\n",
       "      <td>1352723994</td>\n",
       "      <td>action</td>\n",
       "      <td>[ 2.0240e-02  8.4992e-01 -7.8150e-01 -8.2769e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>48220 rows × 8 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "       Unnamed: 0  userId  movieId        tag   timestamp un-lemmatised  \\\n",
       "0               1      96   106696  animation  1396097490     animation   \n",
       "1               2      96   106696  beautiful  1396097497     beautiful   \n",
       "2               3      96   106696  character  1396097500    characters   \n",
       "3               5      96   106696   feminist  1396097502      feminist   \n",
       "4               6      96   106696        ice  1396097505           ice   \n",
       "...           ...     ...      ...        ...         ...           ...   \n",
       "48215      139012  138345     2485    romance  1352724276       romance   \n",
       "48216      139016  138345     2485   teenager  1352724283     teenagers   \n",
       "48217      139017  138345     3617      funny  1352724390         funny   \n",
       "48218      139022  138345     3617      robot  1352724375        robots   \n",
       "48219      139031  138345    58559     action  1352723994        action   \n",
       "\n",
       "                                               glove_vec  has_glove_vec  \n",
       "0      [ 0.037307   0.35589   -0.49355   -0.83947    ...           True  \n",
       "1      [ 1.1005    -0.22599   -0.41616   -0.62486   -...           True  \n",
       "2      [ 0.29665    0.34324   -0.32366   -0.18469    ...           True  \n",
       "3      [-0.1478     0.60717   -0.75788   -0.63978    ...           True  \n",
       "4      [ 0.055307  -0.45217   -0.41147    0.15984   -...           True  \n",
       "...                                                  ...            ...  \n",
       "48215  [ 0.75581    0.11897    0.14055   -1.2454     ...           True  \n",
       "48216  [ 0.39856   -0.22003   -0.28652   -0.93199    ...           True  \n",
       "48217  [ 3.9595e-01 -8.3109e-02 -2.8795e-01 -2.9139e-...           True  \n",
       "48218  [-2.4619e-01  2.1412e-01 -3.5943e-01 -4.5980e-...           True  \n",
       "48219  [ 2.0240e-02  8.4992e-01 -7.8150e-01 -8.2769e-...           True  \n",
       "\n",
       "[48220 rows x 8 columns]"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tags"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Five-Fold CV Split\n",
    "\n",
    "**For evaluation - **\n",
    "\n",
    "Since tags are already lemmatised, we do not apply stemming anymore\n",
    "\n",
    "split ratio of tags withheld is 20%\n",
    "\n",
    "Splitting dataset for Five-Fold CV"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Unnamed: 0</th>\n",
       "      <th>userId</th>\n",
       "      <th>movieId</th>\n",
       "      <th>tag</th>\n",
       "      <th>timestamp</th>\n",
       "      <th>un-lemmatised</th>\n",
       "      <th>glove_vec</th>\n",
       "      <th>has_glove_vec</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>96</td>\n",
       "      <td>106696</td>\n",
       "      <td>animation</td>\n",
       "      <td>1396097490</td>\n",
       "      <td>animation</td>\n",
       "      <td>[ 0.037307   0.35589   -0.49355   -0.83947    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2</td>\n",
       "      <td>96</td>\n",
       "      <td>106696</td>\n",
       "      <td>beautiful</td>\n",
       "      <td>1396097497</td>\n",
       "      <td>beautiful</td>\n",
       "      <td>[ 1.1005    -0.22599   -0.41616   -0.62486   -...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>3</td>\n",
       "      <td>96</td>\n",
       "      <td>106696</td>\n",
       "      <td>character</td>\n",
       "      <td>1396097500</td>\n",
       "      <td>characters</td>\n",
       "      <td>[ 0.29665    0.34324   -0.32366   -0.18469    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>5</td>\n",
       "      <td>96</td>\n",
       "      <td>106696</td>\n",
       "      <td>feminist</td>\n",
       "      <td>1396097502</td>\n",
       "      <td>feminist</td>\n",
       "      <td>[-0.1478     0.60717   -0.75788   -0.63978    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>6</td>\n",
       "      <td>96</td>\n",
       "      <td>106696</td>\n",
       "      <td>ice</td>\n",
       "      <td>1396097505</td>\n",
       "      <td>ice</td>\n",
       "      <td>[ 0.055307  -0.45217   -0.41147    0.15984   -...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48215</th>\n",
       "      <td>139012</td>\n",
       "      <td>138345</td>\n",
       "      <td>2485</td>\n",
       "      <td>romance</td>\n",
       "      <td>1352724276</td>\n",
       "      <td>romance</td>\n",
       "      <td>[ 0.75581    0.11897    0.14055   -1.2454     ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48216</th>\n",
       "      <td>139016</td>\n",
       "      <td>138345</td>\n",
       "      <td>2485</td>\n",
       "      <td>teenager</td>\n",
       "      <td>1352724283</td>\n",
       "      <td>teenagers</td>\n",
       "      <td>[ 0.39856   -0.22003   -0.28652   -0.93199    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48217</th>\n",
       "      <td>139017</td>\n",
       "      <td>138345</td>\n",
       "      <td>3617</td>\n",
       "      <td>funny</td>\n",
       "      <td>1352724390</td>\n",
       "      <td>funny</td>\n",
       "      <td>[ 3.9595e-01 -8.3109e-02 -2.8795e-01 -2.9139e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48218</th>\n",
       "      <td>139022</td>\n",
       "      <td>138345</td>\n",
       "      <td>3617</td>\n",
       "      <td>robot</td>\n",
       "      <td>1352724375</td>\n",
       "      <td>robots</td>\n",
       "      <td>[-2.4619e-01  2.1412e-01 -3.5943e-01 -4.5980e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48219</th>\n",
       "      <td>139031</td>\n",
       "      <td>138345</td>\n",
       "      <td>58559</td>\n",
       "      <td>action</td>\n",
       "      <td>1352723994</td>\n",
       "      <td>action</td>\n",
       "      <td>[ 2.0240e-02  8.4992e-01 -7.8150e-01 -8.2769e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>48220 rows × 8 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "       Unnamed: 0  userId  movieId        tag   timestamp un-lemmatised  \\\n",
       "0               1      96   106696  animation  1396097490     animation   \n",
       "1               2      96   106696  beautiful  1396097497     beautiful   \n",
       "2               3      96   106696  character  1396097500    characters   \n",
       "3               5      96   106696   feminist  1396097502      feminist   \n",
       "4               6      96   106696        ice  1396097505           ice   \n",
       "...           ...     ...      ...        ...         ...           ...   \n",
       "48215      139012  138345     2485    romance  1352724276       romance   \n",
       "48216      139016  138345     2485   teenager  1352724283     teenagers   \n",
       "48217      139017  138345     3617      funny  1352724390         funny   \n",
       "48218      139022  138345     3617      robot  1352724375        robots   \n",
       "48219      139031  138345    58559     action  1352723994        action   \n",
       "\n",
       "                                               glove_vec  has_glove_vec  \n",
       "0      [ 0.037307   0.35589   -0.49355   -0.83947    ...           True  \n",
       "1      [ 1.1005    -0.22599   -0.41616   -0.62486   -...           True  \n",
       "2      [ 0.29665    0.34324   -0.32366   -0.18469    ...           True  \n",
       "3      [-0.1478     0.60717   -0.75788   -0.63978    ...           True  \n",
       "4      [ 0.055307  -0.45217   -0.41147    0.15984   -...           True  \n",
       "...                                                  ...            ...  \n",
       "48215  [ 0.75581    0.11897    0.14055   -1.2454     ...           True  \n",
       "48216  [ 0.39856   -0.22003   -0.28652   -0.93199    ...           True  \n",
       "48217  [ 3.9595e-01 -8.3109e-02 -2.8795e-01 -2.9139e-...           True  \n",
       "48218  [-2.4619e-01  2.1412e-01 -3.5943e-01 -4.5980e-...           True  \n",
       "48219  [ 2.0240e-02  8.4992e-01 -7.8150e-01 -8.2769e-...           True  \n",
       "\n",
       "[48220 rows x 8 columns]"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tags"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Fold 0: Total length = 38518\n",
      "Fold 1: Total length = 38524\n",
      "Fold 2: Total length = 38524\n",
      "Fold 3: Total length = 38519\n",
      "Fold 4: Total length = 38519\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "from sklearn.model_selection import GroupKFold, train_test_split\n",
    "\n",
    "# Assuming `tags` DataFrame is already defined...\n",
    "\n",
    "# Filter out users with less than or equal to 5 tags\n",
    "user_counts = tags['userId'].value_counts()\n",
    "valid_users = user_counts[user_counts > 5].index\n",
    "tags = tags[tags['userId'].isin(valid_users)]\n",
    "\n",
    "# GroupKFold will be used to ensure each user is only in one fold\n",
    "num_folds = 5\n",
    "gkf = GroupKFold(n_splits=num_folds)\n",
    "\n",
    "# This is the 'group' array, where each sample is assigned to a user ID\n",
    "group_array = tags['userId'].values\n",
    "\n",
    "fold_data = {i: {\"train\": pd.DataFrame(), \"test\": pd.DataFrame()} for i in range(num_folds)}\n",
    "\n",
    "# We split based on the groups, so each user appears in only one fold\n",
    "for fold, (train_idx, test_idx) in enumerate(gkf.split(tags, groups=group_array)):\n",
    "    # Select the rows for the current fold's training and test set\n",
    "    fold_train = tags.iloc[train_idx]\n",
    "    fold_test = tags.iloc[test_idx]\n",
    "\n",
    "    # Split each user's tags in the training set of the fold into 80% train, 20% test\n",
    "    for user in fold_train['userId'].unique():\n",
    "        user_tags = fold_train[fold_train['userId'] == user]\n",
    "        user_train_tags, user_test_tags = train_test_split(user_tags, test_size=0.2, random_state=42)\n",
    "        fold_data[fold][\"train\"] = pd.concat([fold_data[fold][\"train\"], user_train_tags])\n",
    "        fold_data[fold][\"test\"] = pd.concat([fold_data[fold][\"test\"], user_test_tags])\n",
    "        \n",
    "    fold_data[fold][\"train\"].to_csv(f\"../dataset/evaluation_folds/fold_{fold}_train.csv\",index=False)\n",
    "    fold_data[fold][\"test\"].to_csv(f\"../dataset/evaluation_folds/fold_{fold}_test.csv\",index=False)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "# Let's check the sum of lengths of the train and test DataFrames\n",
    "for fold, data in fold_data.items():\n",
    "    total_length = len(data['train']) + len(data['test'])\n",
    "    print(f\"Fold {fold}: Total length = {total_length}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Unnamed: 0</th>\n",
       "      <th>Unnamed: 0.1</th>\n",
       "      <th>userId</th>\n",
       "      <th>movieId</th>\n",
       "      <th>tag</th>\n",
       "      <th>timestamp</th>\n",
       "      <th>un-lemmatised</th>\n",
       "      <th>glove_vec</th>\n",
       "      <th>has_glove_vec</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>43</td>\n",
       "      <td>1395</td>\n",
       "      <td>693</td>\n",
       "      <td>1298</td>\n",
       "      <td>musical</td>\n",
       "      <td>2010-12-09 11:00:16</td>\n",
       "      <td>musical</td>\n",
       "      <td>[ 4.6632e-01  8.8083e-02 -4.2873e-01 -1.0036e+...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>55</td>\n",
       "      <td>1407</td>\n",
       "      <td>693</td>\n",
       "      <td>2692</td>\n",
       "      <td>surreal</td>\n",
       "      <td>2010-12-09 10:54:01</td>\n",
       "      <td>surreal</td>\n",
       "      <td>[ 0.26532   -0.083012  -0.33654   -0.31641    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>44</td>\n",
       "      <td>1396</td>\n",
       "      <td>693</td>\n",
       "      <td>1298</td>\n",
       "      <td>rape</td>\n",
       "      <td>2010-12-09 11:00:19</td>\n",
       "      <td>rape</td>\n",
       "      <td>[ 0.63519   0.013247 -0.35237  -0.64106  -0.56...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45</th>\n",
       "      <td>87</td>\n",
       "      <td>1439</td>\n",
       "      <td>693</td>\n",
       "      <td>44191</td>\n",
       "      <td>dark</td>\n",
       "      <td>2010-12-09 10:48:51</td>\n",
       "      <td>dark</td>\n",
       "      <td>[ 0.05283   -0.83416   -0.21758   -0.48929    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>28</td>\n",
       "      <td>1380</td>\n",
       "      <td>693</td>\n",
       "      <td>296</td>\n",
       "      <td>action</td>\n",
       "      <td>2010-12-09 11:04:06</td>\n",
       "      <td>action</td>\n",
       "      <td>[ 2.0240e-02  8.4992e-01 -7.8150e-01 -8.2769e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50102</th>\n",
       "      <td>109162</td>\n",
       "      <td>390811</td>\n",
       "      <td>138280</td>\n",
       "      <td>93721</td>\n",
       "      <td>japan</td>\n",
       "      <td>2014-05-24 18:53:43</td>\n",
       "      <td>japan</td>\n",
       "      <td>[ 0.11557    0.30654   -0.099759  -0.60698   -...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>49985</th>\n",
       "      <td>108978</td>\n",
       "      <td>390627</td>\n",
       "      <td>138280</td>\n",
       "      <td>8638</td>\n",
       "      <td>quirky</td>\n",
       "      <td>2014-11-13 21:37:59</td>\n",
       "      <td>quirky</td>\n",
       "      <td>[ 4.2383e-01 -9.6889e-02  1.2294e-01 -3.4541e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50020</th>\n",
       "      <td>109038</td>\n",
       "      <td>390687</td>\n",
       "      <td>138280</td>\n",
       "      <td>37741</td>\n",
       "      <td>prison</td>\n",
       "      <td>2014-06-28 21:26:44</td>\n",
       "      <td>prison</td>\n",
       "      <td>[ 3.5249e-01 -8.8167e-01 -6.9944e-01 -1.3780e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50184</th>\n",
       "      <td>109304</td>\n",
       "      <td>390953</td>\n",
       "      <td>138280</td>\n",
       "      <td>116797</td>\n",
       "      <td>computer</td>\n",
       "      <td>2015-01-30 23:07:44</td>\n",
       "      <td>computers</td>\n",
       "      <td>[ 5.7791e-01  3.4929e-01  1.7129e-01 -1.1676e+...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50016</th>\n",
       "      <td>109030</td>\n",
       "      <td>390679</td>\n",
       "      <td>138280</td>\n",
       "      <td>30803</td>\n",
       "      <td>quiet</td>\n",
       "      <td>2014-11-01 20:08:37</td>\n",
       "      <td>quiet</td>\n",
       "      <td>[ 8.1732e-01  4.4344e-02  3.0515e-01 -9.0532e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>30583 rows × 9 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "       Unnamed: 0  Unnamed: 0.1  userId  movieId       tag  \\\n",
       "19             43          1395     693     1298   musical   \n",
       "28             55          1407     693     2692   surreal   \n",
       "20             44          1396     693     1298      rape   \n",
       "45             87          1439     693    44191      dark   \n",
       "11             28          1380     693      296    action   \n",
       "...           ...           ...     ...      ...       ...   \n",
       "50102      109162        390811  138280    93721     japan   \n",
       "49985      108978        390627  138280     8638    quirky   \n",
       "50020      109038        390687  138280    37741    prison   \n",
       "50184      109304        390953  138280   116797  computer   \n",
       "50016      109030        390679  138280    30803     quiet   \n",
       "\n",
       "                 timestamp un-lemmatised  \\\n",
       "19     2010-12-09 11:00:16       musical   \n",
       "28     2010-12-09 10:54:01       surreal   \n",
       "20     2010-12-09 11:00:19          rape   \n",
       "45     2010-12-09 10:48:51          dark   \n",
       "11     2010-12-09 11:04:06        action   \n",
       "...                    ...           ...   \n",
       "50102  2014-05-24 18:53:43         japan   \n",
       "49985  2014-11-13 21:37:59        quirky   \n",
       "50020  2014-06-28 21:26:44        prison   \n",
       "50184  2015-01-30 23:07:44     computers   \n",
       "50016  2014-11-01 20:08:37         quiet   \n",
       "\n",
       "                                               glove_vec  has_glove_vec  \n",
       "19     [ 4.6632e-01  8.8083e-02 -4.2873e-01 -1.0036e+...           True  \n",
       "28     [ 0.26532   -0.083012  -0.33654   -0.31641    ...           True  \n",
       "20     [ 0.63519   0.013247 -0.35237  -0.64106  -0.56...           True  \n",
       "45     [ 0.05283   -0.83416   -0.21758   -0.48929    ...           True  \n",
       "11     [ 2.0240e-02  8.4992e-01 -7.8150e-01 -8.2769e-...           True  \n",
       "...                                                  ...            ...  \n",
       "50102  [ 0.11557    0.30654   -0.099759  -0.60698   -...           True  \n",
       "49985  [ 4.2383e-01 -9.6889e-02  1.2294e-01 -3.4541e-...           True  \n",
       "50020  [ 3.5249e-01 -8.8167e-01 -6.9944e-01 -1.3780e-...           True  \n",
       "50184  [ 5.7791e-01  3.4929e-01  1.7129e-01 -1.1676e+...           True  \n",
       "50016  [ 8.1732e-01  4.4344e-02  3.0515e-01 -9.0532e-...           True  \n",
       "\n",
       "[30583 rows x 9 columns]"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fold_data[0][\"train\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sum of all folds: 192604\n"
     ]
    }
   ],
   "source": [
    "total_length_all_folds = sum([38518, 38524, 38524, 38519, 38519])\n",
    "print(f\"Sum of all folds: {total_length_all_folds}\")\n",
    "\n",
    "# the sum of all folds is greater than the original subset because tags can be used by multiple users and therefore will appear in different folds "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Collaborative Filtering Functions - Training for Fold X etc, generate and store recommendations\n",
    "\n",
    "So essentially for \n",
    "\n",
    "Recommendations for each fold are stored here: /Users/aleishamanalo/Desktop/Thesis/evaluation/cf_recommendation_fold_1\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# fold 1 "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [],
   "source": [
    "# reading in fold 1\n",
    "\n",
    "df_fold_train_1 = pd.read_csv(\"../dataset/evaluation_folds/fold_0_train.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "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>userId</th>\n",
       "      <th>movieId</th>\n",
       "      <th>tag</th>\n",
       "      <th>timestamp</th>\n",
       "      <th>un-lemmatised</th>\n",
       "      <th>glove_vec</th>\n",
       "      <th>has_glove_vec</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>693</td>\n",
       "      <td>1298</td>\n",
       "      <td>musical</td>\n",
       "      <td>2010-12-09 11:00:16</td>\n",
       "      <td>musical</td>\n",
       "      <td>[ 4.6632e-01  8.8083e-02 -4.2873e-01 -1.0036e+...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>693</td>\n",
       "      <td>2692</td>\n",
       "      <td>surreal</td>\n",
       "      <td>2010-12-09 10:54:01</td>\n",
       "      <td>surreal</td>\n",
       "      <td>[ 0.26532   -0.083012  -0.33654   -0.31641    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>693</td>\n",
       "      <td>1298</td>\n",
       "      <td>rape</td>\n",
       "      <td>2010-12-09 11:00:19</td>\n",
       "      <td>rape</td>\n",
       "      <td>[ 0.63519   0.013247 -0.35237  -0.64106  -0.56...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>693</td>\n",
       "      <td>44191</td>\n",
       "      <td>dark</td>\n",
       "      <td>2010-12-09 10:48:51</td>\n",
       "      <td>dark</td>\n",
       "      <td>[ 0.05283   -0.83416   -0.21758   -0.48929    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>693</td>\n",
       "      <td>296</td>\n",
       "      <td>action</td>\n",
       "      <td>2010-12-09 11:04:06</td>\n",
       "      <td>action</td>\n",
       "      <td>[ 2.0240e-02  8.4992e-01 -7.8150e-01 -8.2769e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30578</th>\n",
       "      <td>138280</td>\n",
       "      <td>93721</td>\n",
       "      <td>japan</td>\n",
       "      <td>2014-05-24 18:53:43</td>\n",
       "      <td>japan</td>\n",
       "      <td>[ 0.11557    0.30654   -0.099759  -0.60698   -...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30579</th>\n",
       "      <td>138280</td>\n",
       "      <td>8638</td>\n",
       "      <td>quirky</td>\n",
       "      <td>2014-11-13 21:37:59</td>\n",
       "      <td>quirky</td>\n",
       "      <td>[ 4.2383e-01 -9.6889e-02  1.2294e-01 -3.4541e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30580</th>\n",
       "      <td>138280</td>\n",
       "      <td>37741</td>\n",
       "      <td>prison</td>\n",
       "      <td>2014-06-28 21:26:44</td>\n",
       "      <td>prison</td>\n",
       "      <td>[ 3.5249e-01 -8.8167e-01 -6.9944e-01 -1.3780e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30581</th>\n",
       "      <td>138280</td>\n",
       "      <td>116797</td>\n",
       "      <td>computer</td>\n",
       "      <td>2015-01-30 23:07:44</td>\n",
       "      <td>computers</td>\n",
       "      <td>[ 5.7791e-01  3.4929e-01  1.7129e-01 -1.1676e+...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30582</th>\n",
       "      <td>138280</td>\n",
       "      <td>30803</td>\n",
       "      <td>quiet</td>\n",
       "      <td>2014-11-01 20:08:37</td>\n",
       "      <td>quiet</td>\n",
       "      <td>[ 8.1732e-01  4.4344e-02  3.0515e-01 -9.0532e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>30583 rows × 7 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "       userId  movieId       tag            timestamp un-lemmatised  \\\n",
       "0         693     1298   musical  2010-12-09 11:00:16       musical   \n",
       "1         693     2692   surreal  2010-12-09 10:54:01       surreal   \n",
       "2         693     1298      rape  2010-12-09 11:00:19          rape   \n",
       "3         693    44191      dark  2010-12-09 10:48:51          dark   \n",
       "4         693      296    action  2010-12-09 11:04:06        action   \n",
       "...       ...      ...       ...                  ...           ...   \n",
       "30578  138280    93721     japan  2014-05-24 18:53:43         japan   \n",
       "30579  138280     8638    quirky  2014-11-13 21:37:59        quirky   \n",
       "30580  138280    37741    prison  2014-06-28 21:26:44        prison   \n",
       "30581  138280   116797  computer  2015-01-30 23:07:44     computers   \n",
       "30582  138280    30803     quiet  2014-11-01 20:08:37         quiet   \n",
       "\n",
       "                                               glove_vec  has_glove_vec  \n",
       "0      [ 4.6632e-01  8.8083e-02 -4.2873e-01 -1.0036e+...           True  \n",
       "1      [ 0.26532   -0.083012  -0.33654   -0.31641    ...           True  \n",
       "2      [ 0.63519   0.013247 -0.35237  -0.64106  -0.56...           True  \n",
       "3      [ 0.05283   -0.83416   -0.21758   -0.48929    ...           True  \n",
       "4      [ 2.0240e-02  8.4992e-01 -7.8150e-01 -8.2769e-...           True  \n",
       "...                                                  ...            ...  \n",
       "30578  [ 0.11557    0.30654   -0.099759  -0.60698   -...           True  \n",
       "30579  [ 4.2383e-01 -9.6889e-02  1.2294e-01 -3.4541e-...           True  \n",
       "30580  [ 3.5249e-01 -8.8167e-01 -6.9944e-01 -1.3780e-...           True  \n",
       "30581  [ 5.7791e-01  3.4929e-01  1.7129e-01 -1.1676e+...           True  \n",
       "30582  [ 8.1732e-01  4.4344e-02  3.0515e-01 -9.0532e-...           True  \n",
       "\n",
       "[30583 rows x 7 columns]"
      ]
     },
     "execution_count": 73,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_fold_train_1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "metadata": {},
   "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>tag</th>\n",
       "      <th>sentiment_roberta</th>\n",
       "      <th>sentiment_label</th>\n",
       "      <th>sentiment_value</th>\n",
       "      <th>scaled_sentiment_value</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>s</td>\n",
       "      <td>('neutral', 0.5123)</td>\n",
       "      <td>neutral</td>\n",
       "      <td>0.5123</td>\n",
       "      <td>0.24385</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>action</td>\n",
       "      <td>('neutral', 0.6874)</td>\n",
       "      <td>neutral</td>\n",
       "      <td>0.6874</td>\n",
       "      <td>0.15630</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>twist</td>\n",
       "      <td>('neutral', 0.7575)</td>\n",
       "      <td>neutral</td>\n",
       "      <td>0.7575</td>\n",
       "      <td>0.12125</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>twist</td>\n",
       "      <td>('neutral', 0.7575)</td>\n",
       "      <td>neutral</td>\n",
       "      <td>0.7575</td>\n",
       "      <td>0.12125</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>overrate</td>\n",
       "      <td>('neutral', 0.5669)</td>\n",
       "      <td>neutral</td>\n",
       "      <td>0.5669</td>\n",
       "      <td>0.21655</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50186</th>\n",
       "      <td>history</td>\n",
       "      <td>('neutral', 0.6321)</td>\n",
       "      <td>neutral</td>\n",
       "      <td>0.6321</td>\n",
       "      <td>0.18395</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50187</th>\n",
       "      <td>informatics</td>\n",
       "      <td>('neutral', 0.7477)</td>\n",
       "      <td>neutral</td>\n",
       "      <td>0.7477</td>\n",
       "      <td>0.12615</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50188</th>\n",
       "      <td>mathematics</td>\n",
       "      <td>('neutral', 0.7053)</td>\n",
       "      <td>neutral</td>\n",
       "      <td>0.7053</td>\n",
       "      <td>0.14735</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50189</th>\n",
       "      <td>image</td>\n",
       "      <td>('neutral', 0.7328)</td>\n",
       "      <td>neutral</td>\n",
       "      <td>0.7328</td>\n",
       "      <td>0.13360</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50190</th>\n",
       "      <td>story</td>\n",
       "      <td>('neutral', 0.5695)</td>\n",
       "      <td>neutral</td>\n",
       "      <td>0.5695</td>\n",
       "      <td>0.21525</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>50191 rows × 5 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "               tag    sentiment_roberta sentiment_label  sentiment_value  \\\n",
       "0                s  ('neutral', 0.5123)         neutral           0.5123   \n",
       "1           action  ('neutral', 0.6874)         neutral           0.6874   \n",
       "2            twist  ('neutral', 0.7575)         neutral           0.7575   \n",
       "3            twist  ('neutral', 0.7575)         neutral           0.7575   \n",
       "4         overrate  ('neutral', 0.5669)         neutral           0.5669   \n",
       "...            ...                  ...             ...              ...   \n",
       "50186      history  ('neutral', 0.6321)         neutral           0.6321   \n",
       "50187  informatics  ('neutral', 0.7477)         neutral           0.7477   \n",
       "50188  mathematics  ('neutral', 0.7053)         neutral           0.7053   \n",
       "50189        image  ('neutral', 0.7328)         neutral           0.7328   \n",
       "50190        story  ('neutral', 0.5695)         neutral           0.5695   \n",
       "\n",
       "       scaled_sentiment_value  \n",
       "0                     0.24385  \n",
       "1                     0.15630  \n",
       "2                     0.12125  \n",
       "3                     0.12125  \n",
       "4                     0.21655  \n",
       "...                       ...  \n",
       "50186                 0.18395  \n",
       "50187                 0.12615  \n",
       "50188                 0.14735  \n",
       "50189                 0.13360  \n",
       "50190                 0.21525  \n",
       "\n",
       "[50191 rows x 5 columns]"
      ]
     },
     "execution_count": 74,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_s = pd.read_csv('../dataset/df_tag_sentiment.csv')\n",
    "df_s"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_s = pd.read_csv('../dataset/df_tag_sentiment.csv')\n",
    "\n",
    "# data conversions\n",
    "tags_c['tag'] = tags_c['tag'].astype('str')\n",
    "df_s['tag'] = df_s['tag'].astype('str')\n",
    "\n",
    "\n",
    "# df_s.drop(columns=['Unnamed: 0.1', 'Unnamed: 0'], inplace=True)\n",
    "\n",
    "# combine df_comb and tags_c\n",
    "df_comb = tags_c.merge(df_s, on='tag', how='left')\n",
    "\n",
    "# drop duplicates on (tag, movie) -> so the cluster average is not bias to duplicate tags per movie\n",
    "df_comb.drop_duplicates(subset='tag', inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "metadata": {},
   "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>tag</th>\n",
       "      <th>un-lemmatised</th>\n",
       "      <th>glove_vec</th>\n",
       "      <th>has_glove_vec</th>\n",
       "      <th>cluster</th>\n",
       "      <th>sentiment_roberta</th>\n",
       "      <th>sentiment_label</th>\n",
       "      <th>sentiment_value</th>\n",
       "      <th>scaled_sentiment_value</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>s</td>\n",
       "      <td>NaN</td>\n",
       "      <td>[ 0.18209    0.88297   -0.49805    0.53137   -...</td>\n",
       "      <td>True</td>\n",
       "      <td>104</td>\n",
       "      <td>('neutral', 0.5123)</td>\n",
       "      <td>neutral</td>\n",
       "      <td>0.5123</td>\n",
       "      <td>0.24385</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>446</th>\n",
       "      <td>action</td>\n",
       "      <td>action</td>\n",
       "      <td>[ 2.0240e-02  8.4992e-01 -7.8150e-01 -8.2769e-...</td>\n",
       "      <td>True</td>\n",
       "      <td>142</td>\n",
       "      <td>('neutral', 0.6874)</td>\n",
       "      <td>neutral</td>\n",
       "      <td>0.6874</td>\n",
       "      <td>0.15630</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1488</th>\n",
       "      <td>twist</td>\n",
       "      <td>twist</td>\n",
       "      <td>[-9.5859e-02 -1.7472e-01 -3.4692e-02 -3.7307e-...</td>\n",
       "      <td>True</td>\n",
       "      <td>2</td>\n",
       "      <td>('neutral', 0.7575)</td>\n",
       "      <td>neutral</td>\n",
       "      <td>0.7575</td>\n",
       "      <td>0.12125</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1535</th>\n",
       "      <td>overrate</td>\n",
       "      <td>overrated</td>\n",
       "      <td>[ 2.8151e-01 -4.2171e-01 -3.8275e-01  1.5364e-...</td>\n",
       "      <td>True</td>\n",
       "      <td>3</td>\n",
       "      <td>('neutral', 0.5669)</td>\n",
       "      <td>neutral</td>\n",
       "      <td>0.5669</td>\n",
       "      <td>0.21655</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1683</th>\n",
       "      <td>violent</td>\n",
       "      <td>violent</td>\n",
       "      <td>[ 1.3693e-01  1.8560e-01 -6.5335e-01 -5.0922e-...</td>\n",
       "      <td>True</td>\n",
       "      <td>153</td>\n",
       "      <td>('neutral', 0.485)</td>\n",
       "      <td>neutral</td>\n",
       "      <td>0.4850</td>\n",
       "      <td>0.25750</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50186</th>\n",
       "      <td>newspaper</td>\n",
       "      <td>newspaper</td>\n",
       "      <td>[-7.0318e-01  1.1424e+00  5.4770e-02 -9.5689e-...</td>\n",
       "      <td>True</td>\n",
       "      <td>25</td>\n",
       "      <td>('neutral', 0.7941)</td>\n",
       "      <td>neutral</td>\n",
       "      <td>0.7941</td>\n",
       "      <td>0.10295</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50187</th>\n",
       "      <td>static</td>\n",
       "      <td>static</td>\n",
       "      <td>[ 0.46332   -0.05737    0.13804    0.30518    ...</td>\n",
       "      <td>True</td>\n",
       "      <td>70</td>\n",
       "      <td>('positive', 0.5362)</td>\n",
       "      <td>positive</td>\n",
       "      <td>0.5362</td>\n",
       "      <td>0.76810</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50188</th>\n",
       "      <td>repeat</td>\n",
       "      <td>repeating</td>\n",
       "      <td>[ 4.8671e-01  9.3464e-01 -1.5418e-02 -4.6056e-...</td>\n",
       "      <td>True</td>\n",
       "      <td>104</td>\n",
       "      <td>('neutral', 0.6128)</td>\n",
       "      <td>neutral</td>\n",
       "      <td>0.6128</td>\n",
       "      <td>0.19360</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50189</th>\n",
       "      <td>seal</td>\n",
       "      <td>seals</td>\n",
       "      <td>[-3.5434e-01  5.1161e-01 -8.6652e-02 -2.3459e-...</td>\n",
       "      <td>True</td>\n",
       "      <td>91</td>\n",
       "      <td>('neutral', 0.6525)</td>\n",
       "      <td>neutral</td>\n",
       "      <td>0.6525</td>\n",
       "      <td>0.17375</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50190</th>\n",
       "      <td>counterespionage</td>\n",
       "      <td>counterespionage</td>\n",
       "      <td>[ 0.11309   -0.8528    -0.25529    0.02635   -...</td>\n",
       "      <td>True</td>\n",
       "      <td>65</td>\n",
       "      <td>('neutral', 0.7142)</td>\n",
       "      <td>neutral</td>\n",
       "      <td>0.7142</td>\n",
       "      <td>0.14290</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>2899 rows × 9 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                    tag     un-lemmatised  \\\n",
       "0                     s               NaN   \n",
       "446              action            action   \n",
       "1488              twist             twist   \n",
       "1535           overrate         overrated   \n",
       "1683            violent           violent   \n",
       "...                 ...               ...   \n",
       "50186         newspaper         newspaper   \n",
       "50187            static            static   \n",
       "50188            repeat         repeating   \n",
       "50189              seal             seals   \n",
       "50190  counterespionage  counterespionage   \n",
       "\n",
       "                                               glove_vec  has_glove_vec  \\\n",
       "0      [ 0.18209    0.88297   -0.49805    0.53137   -...           True   \n",
       "446    [ 2.0240e-02  8.4992e-01 -7.8150e-01 -8.2769e-...           True   \n",
       "1488   [-9.5859e-02 -1.7472e-01 -3.4692e-02 -3.7307e-...           True   \n",
       "1535   [ 2.8151e-01 -4.2171e-01 -3.8275e-01  1.5364e-...           True   \n",
       "1683   [ 1.3693e-01  1.8560e-01 -6.5335e-01 -5.0922e-...           True   \n",
       "...                                                  ...            ...   \n",
       "50186  [-7.0318e-01  1.1424e+00  5.4770e-02 -9.5689e-...           True   \n",
       "50187  [ 0.46332   -0.05737    0.13804    0.30518    ...           True   \n",
       "50188  [ 4.8671e-01  9.3464e-01 -1.5418e-02 -4.6056e-...           True   \n",
       "50189  [-3.5434e-01  5.1161e-01 -8.6652e-02 -2.3459e-...           True   \n",
       "50190  [ 0.11309   -0.8528    -0.25529    0.02635   -...           True   \n",
       "\n",
       "       cluster     sentiment_roberta sentiment_label  sentiment_value  \\\n",
       "0          104   ('neutral', 0.5123)         neutral           0.5123   \n",
       "446        142   ('neutral', 0.6874)         neutral           0.6874   \n",
       "1488         2   ('neutral', 0.7575)         neutral           0.7575   \n",
       "1535         3   ('neutral', 0.5669)         neutral           0.5669   \n",
       "1683       153    ('neutral', 0.485)         neutral           0.4850   \n",
       "...        ...                   ...             ...              ...   \n",
       "50186       25   ('neutral', 0.7941)         neutral           0.7941   \n",
       "50187       70  ('positive', 0.5362)        positive           0.5362   \n",
       "50188      104   ('neutral', 0.6128)         neutral           0.6128   \n",
       "50189       91   ('neutral', 0.6525)         neutral           0.6525   \n",
       "50190       65   ('neutral', 0.7142)         neutral           0.7142   \n",
       "\n",
       "       scaled_sentiment_value  \n",
       "0                     0.24385  \n",
       "446                   0.15630  \n",
       "1488                  0.12125  \n",
       "1535                  0.21655  \n",
       "1683                  0.25750  \n",
       "...                       ...  \n",
       "50186                 0.10295  \n",
       "50187                 0.76810  \n",
       "50188                 0.19360  \n",
       "50189                 0.17375  \n",
       "50190                 0.14290  \n",
       "\n",
       "[2899 rows x 9 columns]"
      ]
     },
     "execution_count": 76,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# df_comb.drop(columns=['Unnamed: 0'], inplace=True)\n",
    "df_comb"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "metadata": {},
   "outputs": [],
   "source": [
    "avg_sentiment_by_cluster = df_comb.groupby('cluster')['scaled_sentiment_value'].mean().reset_index()\n",
    "\n",
    "df_comb = pd.merge(df_comb, avg_sentiment_by_cluster, on='cluster', suffixes=('', '_cluster_avg'))\n",
    "\n",
    "df_comb = df_comb.drop(columns=['glove_vec'])\n",
    "\n",
    "df_comb['scaled_sentiment_value_avg'] = df_comb['scaled_sentiment_value_cluster_avg']\n",
    "\n",
    "df_mat = tags.merge(df_comb, on=['tag'], how='inner')\n",
    "\n",
    "\n",
    "df_sent = df_mat # take copy for later on \n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from collections import defaultdict\n",
    "\n",
    "def cosine_similarity(v1, v2):\n",
    "    '''Cosine similarity function only computes similarity for NON-NAN values'''\n",
    "    # Indices where both v1 and v2 are not NaN\n",
    "    shared_idx = np.where(~np.isnan(v1) & ~np.isnan(v2))\n",
    "    \n",
    "    # If no shared indices, return 0\n",
    "    if len(shared_idx[0]) == 0:\n",
    "        return 0\n",
    "    \n",
    "    # Extract shared values\n",
    "    v1_shared = v1[shared_idx]\n",
    "    v2_shared = v2[shared_idx]\n",
    "\n",
    "    # Compute the dot product and norms only on shared values\n",
    "    dot_product = np.dot(v1_shared, v2_shared)\n",
    "    norm_v1 = np.linalg.norm(v1_shared)\n",
    "    norm_v2 = np.linalg.norm(v2_shared)\n",
    "\n",
    "    # Prevent division by zero\n",
    "    if norm_v1 == 0 or norm_v2 == 0:\n",
    "        return 0\n",
    "\n",
    "    return dot_product / (norm_v1 * norm_v2)\n",
    "\n",
    "\n",
    "def get_sentiment_label(sentiment):\n",
    "    if sentiment > 0.5:\n",
    "        return \"positive\"\n",
    "    elif sentiment < -0.5:\n",
    "        return \"negative\"\n",
    "    else:\n",
    "        return \"neutral\"\n",
    "    \n",
    "\n",
    "def get_dominant_sentiment(user_sentiments):\n",
    "    pos_count = sum(1 for s in user_sentiments if s > 0.5)\n",
    "    neg_count = sum(1 for s in user_sentiments if s < -0.5)\n",
    "    neutral_count = len(user_sentiments) - pos_count - neg_count\n",
    "\n",
    "    if pos_count > neg_count and pos_count > neutral_count:\n",
    "        return \"positive\"\n",
    "    elif neg_count > pos_count and neg_count > neutral_count:\n",
    "        return \"negative\"\n",
    "    else:\n",
    "        return \"neutral\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_k_nearest_neighbors(target_user, matrix, k):\n",
    "    similarities = {}\n",
    "    \n",
    "    for user in matrix.index:\n",
    "        if user == target_user:\n",
    "            continue\n",
    "        common_movies = matrix.loc[target_user].dropna().index.intersection(matrix.loc[user].dropna().index)\n",
    "        if len(common_movies) > 0:\n",
    "            user_vector = matrix.loc[target_user][common_movies].values.reshape(1, -1)\n",
    "            target_vector = matrix.loc[user][common_movies].values.reshape(1, -1)\n",
    "            sim = cosine_similarity(user_vector, target_vector)\n",
    "\n",
    "            similarities[user] = sim\n",
    "            \n",
    "    # Sort by similarity\n",
    "    sorted_neighbors = sorted(similarities.items(), key=lambda x: x[1], reverse=True)\n",
    "    return sorted_neighbors[:k]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_distributed_recommendations(target_user, matrix, new_to_original_index, df_sent, k):\n",
    "    # Get the sentiments for movies rated by the target user\n",
    "    user_sentiments = matrix.loc[target_user].dropna()\n",
    "    \n",
    "    # Determine the dominant sentiment of the target user\n",
    "    dominant_sentiment = get_dominant_sentiment(user_sentiments)\n",
    "    \n",
    "    # Get the k-most similar users\n",
    "    similar_users = get_k_nearest_neighbors(target_user, matrix, k)\n",
    "    sentiment_buckets = defaultdict(list)\n",
    "    # For each similar user, gather movies they've rated\n",
    "\n",
    "    for user, similarity in similar_users:\n",
    "        # Map the user index to its original userId\n",
    "        original_user_id = new_to_original_index[user]\n",
    "        \n",
    "        for movie, sentiment in matrix.loc[user].items():\n",
    "            if not np.isnan(sentiment):\n",
    "                \n",
    "                # Filter df_sent to get rows for the current user and movie\n",
    "                user_movie_df = df_sent[(df_sent['userId'] == original_user_id) & (df_sent['movieId'] == movie)]\n",
    "                \n",
    "                # If there are no sentiments for this user-movie pair, continue\n",
    "                if user_movie_df.empty:\n",
    "                    continue\n",
    "                \n",
    "                # Aggregate the scaled_sentiment_values. Here, I'm using mean, but you can adjust this\n",
    "                movie_sentiment = user_movie_df['scaled_sentiment_value'].mean()\n",
    "                \n",
    "                sentiment_direction = get_dominant_sentiment([movie_sentiment])\n",
    "                sentiment_buckets[sentiment_direction].append((movie, movie_sentiment))\n",
    "\n",
    "    return sentiment_buckets[dominant_sentiment][:k] # returns movieId and sentiment value - scaled sentiment value from df_sent\n",
    "    \n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_and_store_recommendations(df_rec, mat, new_to_original_index, df_sent, k=10):\n",
    "    for idx, row in df_rec.iterrows():\n",
    "        original_user_id = row['userId']\n",
    "        \n",
    "        # Map the original userId to the new continuous index\n",
    "        target_user = original_to_new_index.get(original_user_id, None)\n",
    "        \n",
    "        # If the user exists in the matrix\n",
    "        if target_user is not None:\n",
    "            # Get recommendations\n",
    "            recommendations = get_distributed_recommendations(target_user, mat, new_to_original_index, df_sent, k)\n",
    "            \n",
    "            # Store recommendations in df_rec under the original userId\n",
    "            df_rec.at[idx, 'recommendations'] = recommendations\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define sentiment category function\n",
    "def determine_sentiment_category(sentiment_value):\n",
    "    if -1 <= sentiment_value < -0.5:\n",
    "        return 'Negative'\n",
    "    elif -0.5 <= sentiment_value <= 0.5:\n",
    "        return 'Neutral'\n",
    "    else:\n",
    "        return 'Positive'\n",
    "\n",
    "# Extract tags function\n",
    "def get_tags_for_movie(movieId, sentiment_value):\n",
    "    sentiment_category = determine_sentiment_category(sentiment_value)\n",
    "    \n",
    "    # Filter rows with matching movieId and sentiment category\n",
    "    tags = df_comb_t[(df_comb_t['movieId'] == movieId) & \n",
    "                     (df_comb_t['scaled_sentiment_value_avg'].apply(determine_sentiment_category) == sentiment_category)]['tag'].tolist()\n",
    "    \n",
    "    # Convert tags list to set and back to list to ensure distinct tags\n",
    "    distinct_tags = list(set(tags))\n",
    "    \n",
    "    return (movieId, distinct_tags)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### CF generate recommendations and store in a file here - \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "metadata": {},
   "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>userId</th>\n",
       "      <th>movieId</th>\n",
       "      <th>tag</th>\n",
       "      <th>timestamp</th>\n",
       "      <th>un-lemmatised</th>\n",
       "      <th>glove_vec</th>\n",
       "      <th>has_glove_vec</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>693</td>\n",
       "      <td>1298</td>\n",
       "      <td>musical</td>\n",
       "      <td>2010-12-09 11:00:16</td>\n",
       "      <td>musical</td>\n",
       "      <td>[ 4.6632e-01  8.8083e-02 -4.2873e-01 -1.0036e+...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>693</td>\n",
       "      <td>2692</td>\n",
       "      <td>surreal</td>\n",
       "      <td>2010-12-09 10:54:01</td>\n",
       "      <td>surreal</td>\n",
       "      <td>[ 0.26532   -0.083012  -0.33654   -0.31641    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>693</td>\n",
       "      <td>1298</td>\n",
       "      <td>rape</td>\n",
       "      <td>2010-12-09 11:00:19</td>\n",
       "      <td>rape</td>\n",
       "      <td>[ 0.63519   0.013247 -0.35237  -0.64106  -0.56...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>693</td>\n",
       "      <td>44191</td>\n",
       "      <td>dark</td>\n",
       "      <td>2010-12-09 10:48:51</td>\n",
       "      <td>dark</td>\n",
       "      <td>[ 0.05283   -0.83416   -0.21758   -0.48929    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>693</td>\n",
       "      <td>296</td>\n",
       "      <td>action</td>\n",
       "      <td>2010-12-09 11:04:06</td>\n",
       "      <td>action</td>\n",
       "      <td>[ 2.0240e-02  8.4992e-01 -7.8150e-01 -8.2769e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30578</th>\n",
       "      <td>138280</td>\n",
       "      <td>93721</td>\n",
       "      <td>japan</td>\n",
       "      <td>2014-05-24 18:53:43</td>\n",
       "      <td>japan</td>\n",
       "      <td>[ 0.11557    0.30654   -0.099759  -0.60698   -...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30579</th>\n",
       "      <td>138280</td>\n",
       "      <td>8638</td>\n",
       "      <td>quirky</td>\n",
       "      <td>2014-11-13 21:37:59</td>\n",
       "      <td>quirky</td>\n",
       "      <td>[ 4.2383e-01 -9.6889e-02  1.2294e-01 -3.4541e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30580</th>\n",
       "      <td>138280</td>\n",
       "      <td>37741</td>\n",
       "      <td>prison</td>\n",
       "      <td>2014-06-28 21:26:44</td>\n",
       "      <td>prison</td>\n",
       "      <td>[ 3.5249e-01 -8.8167e-01 -6.9944e-01 -1.3780e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30581</th>\n",
       "      <td>138280</td>\n",
       "      <td>116797</td>\n",
       "      <td>computer</td>\n",
       "      <td>2015-01-30 23:07:44</td>\n",
       "      <td>computers</td>\n",
       "      <td>[ 5.7791e-01  3.4929e-01  1.7129e-01 -1.1676e+...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30582</th>\n",
       "      <td>138280</td>\n",
       "      <td>30803</td>\n",
       "      <td>quiet</td>\n",
       "      <td>2014-11-01 20:08:37</td>\n",
       "      <td>quiet</td>\n",
       "      <td>[ 8.1732e-01  4.4344e-02  3.0515e-01 -9.0532e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>30583 rows × 7 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "       userId  movieId       tag            timestamp un-lemmatised  \\\n",
       "0         693     1298   musical  2010-12-09 11:00:16       musical   \n",
       "1         693     2692   surreal  2010-12-09 10:54:01       surreal   \n",
       "2         693     1298      rape  2010-12-09 11:00:19          rape   \n",
       "3         693    44191      dark  2010-12-09 10:48:51          dark   \n",
       "4         693      296    action  2010-12-09 11:04:06        action   \n",
       "...       ...      ...       ...                  ...           ...   \n",
       "30578  138280    93721     japan  2014-05-24 18:53:43         japan   \n",
       "30579  138280     8638    quirky  2014-11-13 21:37:59        quirky   \n",
       "30580  138280    37741    prison  2014-06-28 21:26:44        prison   \n",
       "30581  138280   116797  computer  2015-01-30 23:07:44     computers   \n",
       "30582  138280    30803     quiet  2014-11-01 20:08:37         quiet   \n",
       "\n",
       "                                               glove_vec  has_glove_vec  \n",
       "0      [ 4.6632e-01  8.8083e-02 -4.2873e-01 -1.0036e+...           True  \n",
       "1      [ 0.26532   -0.083012  -0.33654   -0.31641    ...           True  \n",
       "2      [ 0.63519   0.013247 -0.35237  -0.64106  -0.56...           True  \n",
       "3      [ 0.05283   -0.83416   -0.21758   -0.48929    ...           True  \n",
       "4      [ 2.0240e-02  8.4992e-01 -7.8150e-01 -8.2769e-...           True  \n",
       "...                                                  ...            ...  \n",
       "30578  [ 0.11557    0.30654   -0.099759  -0.60698   -...           True  \n",
       "30579  [ 4.2383e-01 -9.6889e-02  1.2294e-01 -3.4541e-...           True  \n",
       "30580  [ 3.5249e-01 -8.8167e-01 -6.9944e-01 -1.3780e-...           True  \n",
       "30581  [ 5.7791e-01  3.4929e-01  1.7129e-01 -1.1676e+...           True  \n",
       "30582  [ 8.1732e-01  4.4344e-02  3.0515e-01 -9.0532e-...           True  \n",
       "\n",
       "[30583 rows x 7 columns]"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_fold_train_1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "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>tag</th>\n",
       "      <th>un-lemmatised</th>\n",
       "      <th>glove_vec</th>\n",
       "      <th>has_glove_vec</th>\n",
       "      <th>cluster</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>s</td>\n",
       "      <td>NaN</td>\n",
       "      <td>[ 0.18209    0.88297   -0.49805    0.53137   -...</td>\n",
       "      <td>True</td>\n",
       "      <td>104</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>action</td>\n",
       "      <td>action</td>\n",
       "      <td>[ 2.0240e-02  8.4992e-01 -7.8150e-01 -8.2769e-...</td>\n",
       "      <td>True</td>\n",
       "      <td>142</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>twist</td>\n",
       "      <td>twist</td>\n",
       "      <td>[-9.5859e-02 -1.7472e-01 -3.4692e-02 -3.7307e-...</td>\n",
       "      <td>True</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>overrate</td>\n",
       "      <td>overrated</td>\n",
       "      <td>[ 2.8151e-01 -4.2171e-01 -3.8275e-01  1.5364e-...</td>\n",
       "      <td>True</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>violent</td>\n",
       "      <td>violent</td>\n",
       "      <td>[ 1.3693e-01  1.8560e-01 -6.5335e-01 -5.0922e-...</td>\n",
       "      <td>True</td>\n",
       "      <td>153</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2894</th>\n",
       "      <td>newspaper</td>\n",
       "      <td>newspaper</td>\n",
       "      <td>[-7.0318e-01  1.1424e+00  5.4770e-02 -9.5689e-...</td>\n",
       "      <td>True</td>\n",
       "      <td>25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2895</th>\n",
       "      <td>static</td>\n",
       "      <td>static</td>\n",
       "      <td>[ 0.46332   -0.05737    0.13804    0.30518    ...</td>\n",
       "      <td>True</td>\n",
       "      <td>70</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2896</th>\n",
       "      <td>repeat</td>\n",
       "      <td>repeating</td>\n",
       "      <td>[ 4.8671e-01  9.3464e-01 -1.5418e-02 -4.6056e-...</td>\n",
       "      <td>True</td>\n",
       "      <td>104</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2897</th>\n",
       "      <td>seal</td>\n",
       "      <td>seals</td>\n",
       "      <td>[-3.5434e-01  5.1161e-01 -8.6652e-02 -2.3459e-...</td>\n",
       "      <td>True</td>\n",
       "      <td>91</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2898</th>\n",
       "      <td>counterespionage</td>\n",
       "      <td>counterespionage</td>\n",
       "      <td>[ 0.11309   -0.8528    -0.25529    0.02635   -...</td>\n",
       "      <td>True</td>\n",
       "      <td>65</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>2899 rows × 5 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                   tag     un-lemmatised  \\\n",
       "0                    s               NaN   \n",
       "1               action            action   \n",
       "2                twist             twist   \n",
       "3             overrate         overrated   \n",
       "4              violent           violent   \n",
       "...                ...               ...   \n",
       "2894         newspaper         newspaper   \n",
       "2895            static            static   \n",
       "2896            repeat         repeating   \n",
       "2897              seal             seals   \n",
       "2898  counterespionage  counterespionage   \n",
       "\n",
       "                                              glove_vec  has_glove_vec  \\\n",
       "0     [ 0.18209    0.88297   -0.49805    0.53137   -...           True   \n",
       "1     [ 2.0240e-02  8.4992e-01 -7.8150e-01 -8.2769e-...           True   \n",
       "2     [-9.5859e-02 -1.7472e-01 -3.4692e-02 -3.7307e-...           True   \n",
       "3     [ 2.8151e-01 -4.2171e-01 -3.8275e-01  1.5364e-...           True   \n",
       "4     [ 1.3693e-01  1.8560e-01 -6.5335e-01 -5.0922e-...           True   \n",
       "...                                                 ...            ...   \n",
       "2894  [-7.0318e-01  1.1424e+00  5.4770e-02 -9.5689e-...           True   \n",
       "2895  [ 0.46332   -0.05737    0.13804    0.30518    ...           True   \n",
       "2896  [ 4.8671e-01  9.3464e-01 -1.5418e-02 -4.6056e-...           True   \n",
       "2897  [-3.5434e-01  5.1161e-01 -8.6652e-02 -2.3459e-...           True   \n",
       "2898  [ 0.11309   -0.8528    -0.25529    0.02635   -...           True   \n",
       "\n",
       "      cluster  \n",
       "0         104  \n",
       "1         142  \n",
       "2           2  \n",
       "3           3  \n",
       "4         153  \n",
       "...       ...  \n",
       "2894       25  \n",
       "2895       70  \n",
       "2896      104  \n",
       "2897       91  \n",
       "2898       65  \n",
       "\n",
       "[2899 rows x 5 columns]"
      ]
     },
     "execution_count": 92,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tags_c"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "metadata": {},
   "outputs": [
    {
     "ename": "KeyError",
     "evalue": "'new_cluster'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyError\u001b[0m                                  Traceback (most recent call last)",
      "File \u001b[0;32m~/anaconda3/lib/python3.11/site-packages/pandas/core/indexes/base.py:3802\u001b[0m, in \u001b[0;36mIndex.get_loc\u001b[0;34m(self, key, method, tolerance)\u001b[0m\n\u001b[1;32m   3801\u001b[0m \u001b[38;5;28;01mtry\u001b[39;00m:\n\u001b[0;32m-> 3802\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_engine\u001b[38;5;241m.\u001b[39mget_loc(casted_key)\n\u001b[1;32m   3803\u001b[0m \u001b[38;5;28;01mexcept\u001b[39;00m \u001b[38;5;167;01mKeyError\u001b[39;00m \u001b[38;5;28;01mas\u001b[39;00m err:\n",
      "File \u001b[0;32m~/anaconda3/lib/python3.11/site-packages/pandas/_libs/index.pyx:138\u001b[0m, in \u001b[0;36mpandas._libs.index.IndexEngine.get_loc\u001b[0;34m()\u001b[0m\n",
      "File \u001b[0;32m~/anaconda3/lib/python3.11/site-packages/pandas/_libs/index.pyx:165\u001b[0m, in \u001b[0;36mpandas._libs.index.IndexEngine.get_loc\u001b[0;34m()\u001b[0m\n",
      "File \u001b[0;32mpandas/_libs/hashtable_class_helper.pxi:5745\u001b[0m, in \u001b[0;36mpandas._libs.hashtable.PyObjectHashTable.get_item\u001b[0;34m()\u001b[0m\n",
      "File \u001b[0;32mpandas/_libs/hashtable_class_helper.pxi:5753\u001b[0m, in \u001b[0;36mpandas._libs.hashtable.PyObjectHashTable.get_item\u001b[0;34m()\u001b[0m\n",
      "\u001b[0;31mKeyError\u001b[0m: 'new_cluster'",
      "\nThe above exception was the direct cause of the following exception:\n",
      "\u001b[0;31mKeyError\u001b[0m                                  Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[94], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m tags_c[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mcluster\u001b[39m\u001b[38;5;124m'\u001b[39m] \u001b[38;5;241m=\u001b[39m tags_c[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mnew_cluster\u001b[39m\u001b[38;5;124m'\u001b[39m]\n\u001b[1;32m      3\u001b[0m \u001b[38;5;66;03m# tags_c.drop(columns='new_cluster', inplace=True)\u001b[39;00m\n\u001b[1;32m      5\u001b[0m df_s \u001b[38;5;241m=\u001b[39m pd\u001b[38;5;241m.\u001b[39mread_csv(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124m../dataset/df_tag_sentiment.csv\u001b[39m\u001b[38;5;124m'\u001b[39m)\n",
      "File \u001b[0;32m~/anaconda3/lib/python3.11/site-packages/pandas/core/frame.py:3807\u001b[0m, in \u001b[0;36mDataFrame.__getitem__\u001b[0;34m(self, key)\u001b[0m\n\u001b[1;32m   3805\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mcolumns\u001b[38;5;241m.\u001b[39mnlevels \u001b[38;5;241m>\u001b[39m \u001b[38;5;241m1\u001b[39m:\n\u001b[1;32m   3806\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_getitem_multilevel(key)\n\u001b[0;32m-> 3807\u001b[0m indexer \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mcolumns\u001b[38;5;241m.\u001b[39mget_loc(key)\n\u001b[1;32m   3808\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m is_integer(indexer):\n\u001b[1;32m   3809\u001b[0m     indexer \u001b[38;5;241m=\u001b[39m [indexer]\n",
      "File \u001b[0;32m~/anaconda3/lib/python3.11/site-packages/pandas/core/indexes/base.py:3804\u001b[0m, in \u001b[0;36mIndex.get_loc\u001b[0;34m(self, key, method, tolerance)\u001b[0m\n\u001b[1;32m   3802\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_engine\u001b[38;5;241m.\u001b[39mget_loc(casted_key)\n\u001b[1;32m   3803\u001b[0m \u001b[38;5;28;01mexcept\u001b[39;00m \u001b[38;5;167;01mKeyError\u001b[39;00m \u001b[38;5;28;01mas\u001b[39;00m err:\n\u001b[0;32m-> 3804\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mKeyError\u001b[39;00m(key) \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01merr\u001b[39;00m\n\u001b[1;32m   3805\u001b[0m \u001b[38;5;28;01mexcept\u001b[39;00m \u001b[38;5;167;01mTypeError\u001b[39;00m:\n\u001b[1;32m   3806\u001b[0m     \u001b[38;5;66;03m# If we have a listlike key, _check_indexing_error will raise\u001b[39;00m\n\u001b[1;32m   3807\u001b[0m     \u001b[38;5;66;03m#  InvalidIndexError. Otherwise we fall through and re-raise\u001b[39;00m\n\u001b[1;32m   3808\u001b[0m     \u001b[38;5;66;03m#  the TypeError.\u001b[39;00m\n\u001b[1;32m   3809\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_check_indexing_error(key)\n",
      "\u001b[0;31mKeyError\u001b[0m: 'new_cluster'"
     ]
    }
   ],
   "source": [
    "tags_c['cluster'] = tags_c['new_cluster']\n",
    "\n",
    "tags_c.drop(columns='new_cluster', inplace=True)\n",
    "\n",
    "df_s = pd.read_csv('../dataset/df_tag_sentiment.csv')\n",
    "\n",
    "# data conversions\n",
    "tags_c['tag'] = tags_c['tag'].astype('str')\n",
    "df_s['tag'] = df_s['tag'].astype('str')\n",
    "\n",
    "\n",
    "# df_s.drop(columns=['Unnamed: 0.1', 'Unnamed: 0'], inplace=True)\n",
    "\n",
    "# combine df_comb and tags_c\n",
    "df_comb = tags_c.merge(df_s, on='tag', how='left')\n",
    "\n",
    "# drop duplicates on (tag, movie) -> so the cluster average is not bias to duplicate tags per movie\n",
    "df_comb.drop_duplicates(subset='tag', inplace=True)\n",
    "\n",
    "avg_sentiment_by_cluster = df_comb.groupby('cluster')['scaled_sentiment_value'].mean().reset_index()\n",
    "\n",
    "df_comb = pd.merge(df_comb, avg_sentiment_by_cluster, on='cluster', suffixes=('', '_cluster_avg'))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_mat = df_fold_train_1.merge(df_comb, on=['tag'], how='inner')\n",
    "df_sent = df_mat\n",
    "df_mat"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_mat['scaled_sentiment_value_avg'] = df_mat['scaled_sentiment_value_cluster_avg']\n",
    "\n",
    "# Convert the 'scaled_sentiment_value_avg' column to float\n",
    "df_mat['scaled_sentiment_value_avg'] = df_mat['scaled_sentiment_value_avg'].astype('float')\n",
    "\n",
    "# Keep only relevant columns\n",
    "df_mat = df_mat[[\"userId\", \"movieId\", \"scaled_sentiment_value_avg\"]]\n",
    "\n",
    "# Check for duplicates and print them\n",
    "duplicates = df_mat[df_mat.duplicated(subset=['userId', 'movieId'], keep=False)]\n",
    "\n",
    "\n",
    "# Group by 'userId' and 'movieId' to get the average 'scaled_sentiment_value_avg'\n",
    "df_mat = df_mat.groupby(['userId', 'movieId'])['scaled_sentiment_value_avg'].mean().reset_index()\n",
    "\n",
    "# Create the pivot table\n",
    "mat = pd.pivot_table(df_mat, values='scaled_sentiment_value_avg', index=['userId'], columns=['movieId'])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Assuming 'mat' is your matrix\n",
    "# Resetting the index will add a column 'userId' with the original values\n",
    "mat = mat.reset_index()\n",
    "\n",
    "# creating a dictionary with original userId and new continuous index\n",
    "original_to_new_index = {old_id: new_id for new_id, old_id in enumerate(mat['userId'])}\n",
    "\n",
    "# assign new continous index to the userId column \n",
    "mat['userId'] = mat['userId'].map(original_to_new_index)\n",
    "\n",
    "# Now, set 'userId' as the index again\n",
    "mat.set_index('userId', inplace=True)\n",
    "\n",
    "user_indices = mat.index[mat.apply(lambda x: (x.count() == 1) and (x.dropna().iloc[0] > 0.5), axis=1)]\n",
    "\n",
    "new_to_original_index = {v: k for k, v in original_to_new_index.items()} # this exists outside the function to ensure the new_to_original_index exists for mapping\n",
    "\n",
    "original_to_new_index = {v: k for k, v in new_to_original_index.items()}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_comb['scaled_sentiment_value_avg'] = df_comb['scaled_sentiment_value_cluster_avg']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# creation of df_rec dataframe \n",
    "\n",
    "df_rec = df_sent[[\"userId\"]].drop_duplicates().reset_index(drop=True)\n",
    "\n",
    "\n",
    "# Initialize recommendations column in df_rec\n",
    "df_rec['recommendations'] = None\n",
    "\n",
    "# Generate and store recommendations\n",
    "generate_and_store_recommendations(df_rec, mat, new_to_original_index, df_sent)\n",
    "\n",
    "df_rec['recommendations'] = df_rec['recommendations'].apply(lambda x: [(int(a), round(b, 4)) for a, b in x])\n",
    "\n",
    "\n",
    "df_comb_t = pd.merge(tags, df_comb, on='tag', how='left')\n",
    "df_comb_t = df_comb_t[[\"movieId\", \"tag\", \"scaled_sentiment_value\", \"scaled_sentiment_value_avg\"]]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "# getting initial tags recommendation \n",
    "# Apply function on recommendations column\n",
    "df_rec['tags_movies'] = df_rec['recommendations'].apply(lambda recs: [get_tags_for_movie(movieId, sentiment_value) for movieId, sentiment_value in recs])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_rec"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Output file \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_rec.to_json(\"../dataset/evaluation/cf_train_0_recs.json\")\n",
    "\n",
    "\n",
    "# read this into the CB model to generate recommendations for each user \n",
    "# then check that df_test_fold_1 contains the recommended tags !!!"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_rec"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### CB Functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# df_wsd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# df_wsd.drop(columns=['Unnamed: 0'], inplace=True)\n",
    "# df_wsd.to_csv(\"../dataset/df_wsd.csv\",index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# loading in data\n",
    "import json \n",
    "\n",
    "df_feat = pd.read_json(\"../dataset/df_feat.json\")\n",
    "\n",
    "tag_cv = pd.read_json('../dataset/tag_csv.json')\n",
    "tag_clusters = pd.read_csv(\"../dataset/tag_clusters.csv\")\n",
    "\n",
    "\n",
    "df_wsd = pd.read_csv(\"../dataset/df_wsd.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_wsd # can directly filter on this\n",
    "\n",
    "df_feat # need to merge on tag_clusters\n",
    "df_feat_cl = pd.merge(df_feat, tag_clusters, on=['tag'], how='left')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_feat_cl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.metrics.pairwise import cosine_similarity\n",
    "\n",
    "def get_user_data(df_rec, tag_cv, target_userId):\n",
    "    \"\"\"\n",
    "    Retrieve movie recommendations, user tags, and tags_movies for a target userId.\n",
    "\n",
    "    Parameters:\n",
    "        df_rec (DataFrame): The DataFrame containing userId, recommendations, and tags_movies columns.\n",
    "        tag_cv (DataFrame): The DataFrame containing userId, movieId, and tags.\n",
    "        target_userId (int): The userId for whom the data is to be fetched.\n",
    "\n",
    "    Returns:\n",
    "        tuple: A tuple containing three lists:\n",
    "               - The first list contains recommendations (movieId, sentiment) for the target userId.\n",
    "               - The second list contains tags applied by the target userId in the format (movieId, tag).\n",
    "               - The third list contains tags_movies entries for the target userId in the format [(movieId, [tags...]), ...].\n",
    "    \"\"\"\n",
    "    # Fetch movie recommendations\n",
    "    recommendations = get_user_recommendations(df_rec, target_userId)\n",
    "    \n",
    "    # Fetch tags applied by the user\n",
    "    user_tags = get_user_tags(tag_cv, target_userId)\n",
    "    \n",
    "    # Fetch tags_movies data for the user\n",
    "    tags_movies = get_tags_movies_for_user(df_rec, target_userId)\n",
    "    \n",
    "    return recommendations, user_tags, tags_movies\n",
    "\n",
    "\n",
    "def get_user_recommendations(df_rec, target_userId):\n",
    "    filtered_df = df_rec[df_rec['userId'] == target_userId]\n",
    "    if len(filtered_df) == 0:\n",
    "        return []\n",
    "    recommendations = filtered_df['recommendations'].iloc[0]\n",
    "    return recommendations\n",
    "\n",
    "\n",
    "def get_user_tags(tag_cv, target_userId):\n",
    "    filtered_df = tag_cv[tag_cv['userId'] == target_userId]\n",
    "    if len(filtered_df) == 0:\n",
    "        return []\n",
    "    user_tags = filtered_df[['movieId', 'tag']].values.tolist()\n",
    "    return user_tags\n",
    "\n",
    "\n",
    "def get_tags_movies_for_user(df_rec, target_userId):\n",
    "    filtered_df = df_rec[df_rec['userId'] == target_userId]\n",
    "    if len(filtered_df) == 0:\n",
    "        return []\n",
    "    tags_movies = filtered_df['tags_movies'].iloc[0]\n",
    "    return tags_movies\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "def get_user_feature_set_and_wsd(df_feat, df_wsd, user_tags, tag_clusters, target_userId):\n",
    "    \"\"\"\n",
    "    Fetch additional features, WSD, and TF/TF-IDF info for a list of user tags.\n",
    "    \n",
    "    Parameters:\n",
    "        df_feat (DataFrame): The DataFrame containing features for each tag.\n",
    "        df_wsd (DataFrame): The DataFrame containing WSD information.\n",
    "        user_tags (list): The list containing tags applied by the user in the format (movieId, tag).\n",
    "        target_userId (int): The userId for whom the WSD data is to be fetched.\n",
    "        \n",
    "    Returns:\n",
    "        tuple: A tuple containing three DataFrames:\n",
    "               - The first DataFrame contains additional features for each user tag.\n",
    "               - The second DataFrame contains WSD information for the user.\n",
    "               - The third DataFrame contains TF and TF-IDF information for the user tags.\n",
    "    \"\"\"\n",
    "    # Filtering df_feat to only include rows where the tag is in user_tags\n",
    "    filtered_df_feat = df_feat[df_feat['tag'].isin([tag for _, tag in user_tags])]\n",
    "    \n",
    "    # Filtering df_wsd to include only rows for the target_userId\n",
    "    filtered_df_wsd = df_wsd[df_wsd['userId'] == target_userId]\n",
    "    \n",
    "    # joining the cluster to the tags\n",
    "\n",
    "    # Create a set of (movieId, tag) tuples for easier filtering\n",
    "    user_tags_set = set(tuple(x) for x in user_tags)\n",
    "\n",
    "\n",
    "    return filtered_df_feat, filtered_df_wsd\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.metrics.pairwise import cosine_similarity\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "\n",
    "def calculate_similarity_for_recommendations(recommendations, tags_movies, df_feat, user_features, df_wsd, user_wsd):\n",
    "    similarity_list = []\n",
    "\n",
    "    # Create a dictionary to easily fetch movie tags\n",
    "    tags_movies_dict = dict(tags_movies)\n",
    "\n",
    "    for movieId, _ in recommendations:\n",
    "        movie_tags = tags_movies_dict.get(movieId, [])  # Fetch the tags from the tags_movies dictionary\n",
    "        if not movie_tags:\n",
    "            continue\n",
    "\n",
    "        for user_tag in user_features['tag'].unique():\n",
    "            for movie_tag in movie_tags:\n",
    "\n",
    "                user_wsd_row = user_wsd[user_wsd['tag'] == user_tag]\n",
    "                movie_wsd_row = df_wsd[(df_wsd['movieId'] == movieId) & (df_wsd['tag'] == movie_tag)]\n",
    "\n",
    "                # nested loop to calculate the wsd\n",
    "                wsd_similarities = []\n",
    "                for user_sense in user_wsd_row['disambiguated_sense'].values:\n",
    "                    for movie_sense in movie_wsd_row['disambiguated_sense'].values:\n",
    "                        wsd_similarities.append(user_sense == movie_sense)\n",
    "\n",
    "                if wsd_similarities:\n",
    "                    wsd_similarity = np.mean(wsd_similarities)\n",
    "                else:\n",
    "                    wsd_similarity = 0\n",
    "\n",
    "                wsd_confidence = movie_wsd_row['confidence'].mean() if not movie_wsd_row.empty else 0\n",
    "\n",
    "                user_feat_row = user_features[user_features['tag'] == user_tag]\n",
    "                movie_feat_row = df_feat[df_feat['tag'] == movie_tag]\n",
    "\n",
    "                pos_match = (user_feat_row['POS'].values == movie_feat_row['POS'].values).mean() if user_feat_row['POS'].values.size and movie_feat_row['POS'].values.size else 0\n",
    "                ner_match = (user_feat_row['ner_label'].values == movie_feat_row['ner_label'].values).mean() if user_feat_row['ner_label'].values.size and movie_feat_row['ner_label'].values.size else 0\n",
    "                sentiment_match = (user_feat_row['sentiment_label'].values == movie_feat_row['sentiment_label'].values).mean() if user_feat_row['sentiment_label'].values.size and movie_feat_row['sentiment_label'].values.size else 0\n",
    "                \n",
    "                # Check for cluster match\n",
    "                cluster_match = int(user_feat_row['cluster'].values[0] == movie_feat_row['cluster'].values[0]) if user_feat_row['cluster'].values.size and movie_feat_row['cluster'].values.size else 0\n",
    "\n",
    "                similarity_list.append({\n",
    "                    'movieId': movieId, \n",
    "                    'user_tag': user_tag,\n",
    "                    'movie_tag': movie_tag,\n",
    "                    'wsd_similarity': wsd_similarity,\n",
    "                    'wsd_confidence': wsd_confidence,\n",
    "                    'pos_match': pos_match,\n",
    "                    'ner_match': ner_match,\n",
    "                    'sentiment_match': sentiment_match,\n",
    "                    'cluster_match': cluster_match  # Adding the cluster match to the dataframe\n",
    "                })\n",
    "\n",
    "    similarity_df = pd.DataFrame(similarity_list)\n",
    "    return similarity_df\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def calculate_total_similarity(row, weights):\n",
    "    return sum(row[metric] * weight for metric, weight in weights.items())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.metrics import precision_score, recall_score, accuracy_score\n",
    "\n",
    "# Assuming you already have the function definitions for generate_and_store_recommendations() and other helper functions\n",
    "\n",
    "precision_scores = []\n",
    "recall_scores = []\n",
    "accuracy_scores = []\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_feat"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "test_data = pd.read_csv('../dataset/evaluation_folds/fold_0_test.csv')\n",
    "train_data = df_fold_train_1\n",
    "\n",
    "df_fold_1_results = pd.DataFrame(columns=['userId', 'recommended_tags'])\n",
    "\n",
    "############ CB MODEL ############################\n",
    "\n",
    "merged_tag_cv = pd.merge(tag_cv, test_data, on=['userId', 'movieId', 'tag'], how='outer', indicator=True)\n",
    "\n",
    "# Now, filter out the rows that come only from the 'test_data' using the indicator column.\n",
    "tag_cv_filtered = merged_tag_cv[merged_tag_cv['_merge'] != 'right_only'].drop(columns=['_merge'])\n",
    "\n",
    "# Repeat the process for df_wsd.\n",
    "merged_df_wsd = pd.merge(df_wsd, test_data, on=['userId', 'movieId', 'tag'], how='outer', indicator=True)\n",
    "df_wsd_filtered = merged_df_wsd[merged_df_wsd['_merge'] != 'right_only'].drop(columns=['_merge'])\n",
    "\n",
    "for userId in train_data['userId'].unique():\n",
    "    try:\n",
    "        target_user = userId\n",
    "\n",
    "        recommendations, user_tags, tags_movies = get_user_data(df_rec, tag_cv_filtered, target_user)\n",
    "\n",
    "        user_features, user_wsd = get_user_feature_set_and_wsd(df_feat, df_wsd_filtered, user_tags, tag_clusters, target_user)\n",
    "\n",
    "        similarity_df = calculate_similarity_for_recommendations(recommendations, tags_movies, df_feat, user_features, df_wsd, user_wsd)\n",
    "\n",
    "        weights = {\n",
    "            'wsd_similarity': 0.05,\n",
    "            'wsd_confidence': 0.05,\n",
    "            'pos_match': 0.3,\n",
    "            'ner_match': 0.3,\n",
    "            'sentiment_match': 0.2,\n",
    "            'cluster_match': 0.1\n",
    "        }\n",
    "\n",
    "        # Add a check for empty DataFrame\n",
    "        if similarity_df.empty:\n",
    "            print(f\"No recommendations for user {userId}, adding empty recommendation.\")\n",
    "            recommended_tags = []\n",
    "        else:\n",
    "            # Assuming similarity_df is your DataFrame\n",
    "            similarity_df['total_similarity'] = similarity_df.apply(lambda row: calculate_total_similarity(row, weights), axis=1)\n",
    "\n",
    "            # Sort the DataFrame by 'total_similarity' in descending order\n",
    "            sorted_similarity_df = similarity_df.sort_values(by='total_similarity', ascending=False)\n",
    "\n",
    "            # Remove rows where 'movie_tag' is also present in 'user_tag' column\n",
    "            filtered_similarity_df = sorted_similarity_df[~sorted_similarity_df['movie_tag'].isin(user_tags)]\n",
    "\n",
    "            # Drop duplicates based on the 'movie_tag' column to get distinct tags\n",
    "            distinct_tags_df = filtered_similarity_df.drop_duplicates(subset=['movie_tag'])\n",
    "\n",
    "            # Get the top 10 distinct tags along with their movieId\n",
    "            top_10_distinct_tags_with_movieId = distinct_tags_df[['movieId', 'movie_tag', 'ner_match', 'pos_match', 'cluster_match', 'total_similarity']].head(10)\n",
    "            # Calculate the average similarity of the top 10 tags\n",
    "            average_similarity = top_10_distinct_tags_with_movieId['total_similarity'].mean() if not top_10_distinct_tags_with_movieId.empty else 0\n",
    "\n",
    "            recommended_tags = top_10_distinct_tags_with_movieId['movie_tag'].tolist()\n",
    "\n",
    "        # Now, we can add the results to df_fold_1_results DataFrame, regardless of whether recommendations are empty or not.\n",
    "        temp_df = pd.DataFrame({\n",
    "            'userId': [userId],  # Make sure to pass a list even if it's a single userId\n",
    "            'recommended_tags': [recommended_tags],  # The brackets ensure it's treated as a single list entry in the DataFrame\n",
    "            'average_similarity': [average_similarity]  # Add the average similarity for the top 10 tags\n",
    "        })\n",
    "        \n",
    "        # Concatenate the temporary DataFrame with the main results DataFrame\n",
    "        df_fold_1_results = pd.concat([df_fold_1_results, temp_df], ignore_index=True)\n",
    "    \n",
    "    except Exception as e:\n",
    "        print(f\"An error occurred for user {userId}: {e}\")\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### RESULTs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_fold_1_results.to_csv('../dataset/evaluation/df_fold_0_results.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "test_data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_fold_1_results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.metrics import precision_score, recall_score, accuracy_score\n",
    "import pandas as pd\n",
    "from collections import defaultdict\n",
    "\n",
    "# Assuming df_fold_1_results and test_data are your pandas DataFrames\n",
    "# df_fold_1_results = pd.read_csv('path_to_df_fold_1_results.csv')\n",
    "# test_data = pd.read_csv('path_to_test_data.csv')\n",
    "\n",
    "# Preprocess test_data to get a mapping of userId to a list of actual tags\n",
    "test_tags_dict = defaultdict(set)\n",
    "for _, row in test_data.iterrows():\n",
    "    test_tags_dict[row['userId']].add(row['tag'])\n",
    "\n",
    "# Lists to hold precision, recall, and accuracy scores for each user\n",
    "precision_scores = []\n",
    "recall_scores = []\n",
    "accuracy_scores = []\n",
    "\n",
    "# Calculating precision, recall, and accuracy per user\n",
    "for _, row in df_fold_1_results.iterrows():\n",
    "    user_id = row['userId']\n",
    "    recommended_tags = row['recommended_tags']\n",
    "    actual_tags = test_tags_dict[user_id]\n",
    "    \n",
    "    # Generating binary classification lists\n",
    "    y_true = [1 if tag in actual_tags else 0 for tag in recommended_tags]\n",
    "    y_pred = [1] * len(recommended_tags)  # Assuming all recommended tags are positive predictions\n",
    "\n",
    "    # Calculate metrics\n",
    "    precision = precision_score(y_true, y_pred, zero_division=1)  # Handle case where denominator is 0\n",
    "    recall = recall_score(y_true, y_pred, zero_division=1)\n",
    "    accuracy = accuracy_score(y_true, y_pred)\n",
    "    \n",
    "    # Append to lists\n",
    "    precision_scores.append(precision)\n",
    "    recall_scores.append(recall)\n",
    "    accuracy_scores.append(accuracy)\n",
    "\n",
    "# Calculate average precision, recall, and accuracy across all users\n",
    "avg_precision = sum(precision_scores) / len(precision_scores)\n",
    "avg_recall = sum(recall_scores) / len(recall_scores)\n",
    "avg_accuracy = sum(accuracy_scores) / len(accuracy_scores)\n",
    "\n",
    "print('Average Precision:', avg_precision)\n",
    "print('Average Recall:', avg_recall)\n",
    "print('Average Accuracy:', avg_accuracy)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### For precision calculation\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Precision "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Overall Precision: 0.799625468164794\n"
     ]
    }
   ],
   "source": [
    "# Initialize a list to store individual precisions\n",
    "individual_precisions = []\n",
    "\n",
    "# Iterate over each user in the results DataFrame\n",
    "for _, row in df_fold_1_results.iterrows():\n",
    "    user_id = row['userId']\n",
    "    recommended_tags = set(row['recommended_tags'])\n",
    "    actual_tags = test_tags_dict.get(user_id, set())\n",
    "\n",
    "    # Check for intersection between recommended and actual tags\n",
    "    if recommended_tags.intersection(actual_tags):\n",
    "        \n",
    "        individual_precisions.append(1)\n",
    "    else:\n",
    "        \n",
    "        individual_precisions.append(0)\n",
    "\n",
    "# Calculate overall precision\n",
    "overall_precision = sum(individual_precisions) / len(individual_precisions)\n",
    "\n",
    "print(\"Overall Precision:\", overall_precision)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Recall"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Initialize a dictionary to store recall scores for each user\n",
    "user_recalls = {}\n",
    "\n",
    "# Iterate over each user in the results DataFrame\n",
    "for _, row in df_fold_1_results.iterrows():\n",
    "    user_id = row['userId']\n",
    "    recommended_tags = set(row['recommended_tags'])\n",
    "    actual_tags = test_tags_dict.get(user_id, set())\n",
    "\n",
    "    # Calculate recall for this user\n",
    "    if actual_tags:\n",
    "        user_recall = len(recommended_tags.intersection(actual_tags)) / len(actual_tags)\n",
    "        user_recalls[user_id] = user_recall\n",
    "    else:\n",
    "        user_recalls[user_id] = 0\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "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>userId</th>\n",
       "      <th>recommended_tags</th>\n",
       "      <th>average_similarity</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>964</td>\n",
       "      <td>[romance, dc, stylize, england, computer, dist...</td>\n",
       "      <td>0.969847</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>969</td>\n",
       "      <td>[weird, romance, disturb, classic, dark, atmos...</td>\n",
       "      <td>0.959558</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1268</td>\n",
       "      <td>[crime, drama, psychological, thriller, romanc...</td>\n",
       "      <td>0.929286</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1418</td>\n",
       "      <td>[memory, printer, sexuality, romance, edinburg...</td>\n",
       "      <td>0.854729</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1644</td>\n",
       "      <td>[watch, challenge, stylize, disturb, confuse, ...</td>\n",
       "      <td>0.844477</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>529</th>\n",
       "      <td>137163</td>\n",
       "      <td>[prison, drug, history, redemption, endear, fl...</td>\n",
       "      <td>0.949287</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>530</th>\n",
       "      <td>137609</td>\n",
       "      <td>[christianity, friendship, tense, violent, fra...</td>\n",
       "      <td>0.954335</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>531</th>\n",
       "      <td>137869</td>\n",
       "      <td>[weird, action, relationship, horror, romance,...</td>\n",
       "      <td>0.939662</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>532</th>\n",
       "      <td>138200</td>\n",
       "      <td>[romance, disturb, car, comedy, violence, dark...</td>\n",
       "      <td>0.969503</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>533</th>\n",
       "      <td>138209</td>\n",
       "      <td>[romance, quirky, space, atmospheric, surreal,...</td>\n",
       "      <td>0.959348</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>534 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     userId                                   recommended_tags  \\\n",
       "0       964  [romance, dc, stylize, england, computer, dist...   \n",
       "1       969  [weird, romance, disturb, classic, dark, atmos...   \n",
       "2      1268  [crime, drama, psychological, thriller, romanc...   \n",
       "3      1418  [memory, printer, sexuality, romance, edinburg...   \n",
       "4      1644  [watch, challenge, stylize, disturb, confuse, ...   \n",
       "..      ...                                                ...   \n",
       "529  137163  [prison, drug, history, redemption, endear, fl...   \n",
       "530  137609  [christianity, friendship, tense, violent, fra...   \n",
       "531  137869  [weird, action, relationship, horror, romance,...   \n",
       "532  138200  [romance, disturb, car, comedy, violence, dark...   \n",
       "533  138209  [romance, quirky, space, atmospheric, surreal,...   \n",
       "\n",
       "     average_similarity  \n",
       "0              0.969847  \n",
       "1              0.959558  \n",
       "2              0.929286  \n",
       "3              0.854729  \n",
       "4              0.844477  \n",
       "..                  ...  \n",
       "529            0.949287  \n",
       "530            0.954335  \n",
       "531            0.939662  \n",
       "532            0.969503  \n",
       "533            0.959348  \n",
       "\n",
       "[534 rows x 3 columns]"
      ]
     },
     "execution_count": 67,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_fold_1_results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "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>userId</th>\n",
       "      <th>recommended_tags</th>\n",
       "      <th>average_similarity</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "Empty DataFrame\n",
       "Columns: [userId, recommended_tags, average_similarity]\n",
       "Index: []"
      ]
     },
     "execution_count": 68,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_fold_1_results[df_fold_1_results['userId'] == 96]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Calculating the average similarity of recommended tags for each user "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "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>userId</th>\n",
       "      <th>recommended_tags</th>\n",
       "      <th>average_similarity</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>964</td>\n",
       "      <td>[romance, dc, stylize, england, computer, dist...</td>\n",
       "      <td>0.969847</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>969</td>\n",
       "      <td>[weird, romance, disturb, classic, dark, atmos...</td>\n",
       "      <td>0.959558</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1268</td>\n",
       "      <td>[crime, drama, psychological, thriller, romanc...</td>\n",
       "      <td>0.929286</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1418</td>\n",
       "      <td>[memory, printer, sexuality, romance, edinburg...</td>\n",
       "      <td>0.854729</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1644</td>\n",
       "      <td>[watch, challenge, stylize, disturb, confuse, ...</td>\n",
       "      <td>0.844477</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>529</th>\n",
       "      <td>137163</td>\n",
       "      <td>[prison, drug, history, redemption, endear, fl...</td>\n",
       "      <td>0.949287</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>530</th>\n",
       "      <td>137609</td>\n",
       "      <td>[christianity, friendship, tense, violent, fra...</td>\n",
       "      <td>0.954335</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>531</th>\n",
       "      <td>137869</td>\n",
       "      <td>[weird, action, relationship, horror, romance,...</td>\n",
       "      <td>0.939662</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>532</th>\n",
       "      <td>138200</td>\n",
       "      <td>[romance, disturb, car, comedy, violence, dark...</td>\n",
       "      <td>0.969503</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>533</th>\n",
       "      <td>138209</td>\n",
       "      <td>[romance, quirky, space, atmospheric, surreal,...</td>\n",
       "      <td>0.959348</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>534 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     userId                                   recommended_tags  \\\n",
       "0       964  [romance, dc, stylize, england, computer, dist...   \n",
       "1       969  [weird, romance, disturb, classic, dark, atmos...   \n",
       "2      1268  [crime, drama, psychological, thriller, romanc...   \n",
       "3      1418  [memory, printer, sexuality, romance, edinburg...   \n",
       "4      1644  [watch, challenge, stylize, disturb, confuse, ...   \n",
       "..      ...                                                ...   \n",
       "529  137163  [prison, drug, history, redemption, endear, fl...   \n",
       "530  137609  [christianity, friendship, tense, violent, fra...   \n",
       "531  137869  [weird, action, relationship, horror, romance,...   \n",
       "532  138200  [romance, disturb, car, comedy, violence, dark...   \n",
       "533  138209  [romance, quirky, space, atmospheric, surreal,...   \n",
       "\n",
       "     average_similarity  \n",
       "0              0.969847  \n",
       "1              0.959558  \n",
       "2              0.929286  \n",
       "3              0.854729  \n",
       "4              0.844477  \n",
       "..                  ...  \n",
       "529            0.949287  \n",
       "530            0.954335  \n",
       "531            0.939662  \n",
       "532            0.969503  \n",
       "533            0.959348  \n",
       "\n",
       "[534 rows x 3 columns]"
      ]
     },
     "execution_count": 69,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_fold_1_results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The overall average similarity across all users is: 0.933249782561798\n"
     ]
    }
   ],
   "source": [
    "# ... [your existing recommendation processing code] ...\n",
    "\n",
    "# After the for-loop, calculate the average similarity across all users\n",
    "# Ensure that 'average_similarity' column exists and has the correct data type\n",
    "if 'average_similarity' in df_fold_1_results.columns:\n",
    "    overall_average_similarity = df_fold_1_results['average_similarity'].mean()\n",
    "else:\n",
    "    print(\"The 'average_similarity' column does not exist in the results DataFrame.\")\n",
    "    overall_average_similarity = None\n",
    "\n",
    "print(f\"The overall average similarity across all users is: {overall_average_similarity}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {},
   "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>userId</th>\n",
       "      <th>movieId</th>\n",
       "      <th>tag</th>\n",
       "      <th>timestamp</th>\n",
       "      <th>un-lemmatised</th>\n",
       "      <th>glove_vec</th>\n",
       "      <th>has_glove_vec</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>964</td>\n",
       "      <td>2959</td>\n",
       "      <td>philosophy</td>\n",
       "      <td>2010-09-20 22:33:29</td>\n",
       "      <td>philosophy</td>\n",
       "      <td>[ 0.046143   0.049765   0.76812    0.25986    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>964</td>\n",
       "      <td>260</td>\n",
       "      <td>action</td>\n",
       "      <td>2010-05-30 03:36:40</td>\n",
       "      <td>action</td>\n",
       "      <td>[ 2.0240e-02  8.4992e-01 -7.8150e-01 -8.2769e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>964</td>\n",
       "      <td>1197</td>\n",
       "      <td>revenge</td>\n",
       "      <td>2010-10-09 17:10:30</td>\n",
       "      <td>revenge</td>\n",
       "      <td>[-0.10463    0.92201   -0.17947   -0.37589   -...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>964</td>\n",
       "      <td>2959</td>\n",
       "      <td>psychology</td>\n",
       "      <td>2010-09-20 22:33:28</td>\n",
       "      <td>psychology</td>\n",
       "      <td>[ 0.0061765  0.21331    0.67127    0.17676    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>964</td>\n",
       "      <td>1197</td>\n",
       "      <td>funny</td>\n",
       "      <td>2010-10-09 17:10:18</td>\n",
       "      <td>funny</td>\n",
       "      <td>[ 3.9595e-01 -8.3109e-02 -2.8795e-01 -2.9139e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7928</th>\n",
       "      <td>138200</td>\n",
       "      <td>49272</td>\n",
       "      <td>poker</td>\n",
       "      <td>2006-12-17 20:45:04</td>\n",
       "      <td>poker</td>\n",
       "      <td>[ 0.42254    0.24923   -0.15362   -0.73099    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7929</th>\n",
       "      <td>138209</td>\n",
       "      <td>31</td>\n",
       "      <td>inspirational</td>\n",
       "      <td>2014-08-09 06:21:24</td>\n",
       "      <td>inspirational</td>\n",
       "      <td>[-0.32464    0.054312   0.39712    0.23142    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7930</th>\n",
       "      <td>138209</td>\n",
       "      <td>2692</td>\n",
       "      <td>nonlinear</td>\n",
       "      <td>2014-08-09 06:17:27</td>\n",
       "      <td>nonlinear</td>\n",
       "      <td>[ 0.070842   0.46296    0.6481    -0.31865    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7931</th>\n",
       "      <td>138209</td>\n",
       "      <td>7323</td>\n",
       "      <td>historical</td>\n",
       "      <td>2014-08-09 06:22:12</td>\n",
       "      <td>historical</td>\n",
       "      <td>[ 4.5563e-01  2.7829e-01  6.0843e-01 -4.3774e-...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7932</th>\n",
       "      <td>138209</td>\n",
       "      <td>1238</td>\n",
       "      <td>heartwarming</td>\n",
       "      <td>2014-08-09 06:22:58</td>\n",
       "      <td>heartwarming</td>\n",
       "      <td>[ 0.34303    0.26155    0.31698   -0.30175    ...</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>7933 rows × 7 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      userId  movieId            tag            timestamp  un-lemmatised  \\\n",
       "0        964     2959     philosophy  2010-09-20 22:33:29     philosophy   \n",
       "1        964      260         action  2010-05-30 03:36:40         action   \n",
       "2        964     1197        revenge  2010-10-09 17:10:30        revenge   \n",
       "3        964     2959     psychology  2010-09-20 22:33:28     psychology   \n",
       "4        964     1197          funny  2010-10-09 17:10:18          funny   \n",
       "...      ...      ...            ...                  ...            ...   \n",
       "7928  138200    49272          poker  2006-12-17 20:45:04          poker   \n",
       "7929  138209       31  inspirational  2014-08-09 06:21:24  inspirational   \n",
       "7930  138209     2692      nonlinear  2014-08-09 06:17:27      nonlinear   \n",
       "7931  138209     7323     historical  2014-08-09 06:22:12     historical   \n",
       "7932  138209     1238   heartwarming  2014-08-09 06:22:58   heartwarming   \n",
       "\n",
       "                                              glove_vec  has_glove_vec  \n",
       "0     [ 0.046143   0.049765   0.76812    0.25986    ...           True  \n",
       "1     [ 2.0240e-02  8.4992e-01 -7.8150e-01 -8.2769e-...           True  \n",
       "2     [-0.10463    0.92201   -0.17947   -0.37589   -...           True  \n",
       "3     [ 0.0061765  0.21331    0.67127    0.17676    ...           True  \n",
       "4     [ 3.9595e-01 -8.3109e-02 -2.8795e-01 -2.9139e-...           True  \n",
       "...                                                 ...            ...  \n",
       "7928  [ 0.42254    0.24923   -0.15362   -0.73099    ...           True  \n",
       "7929  [-0.32464    0.054312   0.39712    0.23142    ...           True  \n",
       "7930  [ 0.070842   0.46296    0.6481    -0.31865    ...           True  \n",
       "7931  [ 4.5563e-01  2.7829e-01  6.0843e-01 -4.3774e-...           True  \n",
       "7932  [ 0.34303    0.26155    0.31698   -0.30175    ...           True  \n",
       "\n",
       "[7933 rows x 7 columns]"
      ]
     },
     "execution_count": 71,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_data"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### GRAPHING ALL RESULTS \n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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bW3N3LlzadOmDffu3Yt7vx49ekSlSpV4+fIlffv2pUiRIjx8+JANGzYQHh6OiYkJ4eHh1KpVi4cPH9KvXz/y5s3L0aNHGT16NI8fP2b27NmJuledOnVi3Lhx+Pj4xCXkq1evpl69ejg5Ob21/9OnT6lcuXJckuro6MiOHTvo3bs3wcHBDBs2jKJFi/L999/z3Xff0bdvX2rUqAFA1apV48p5/vw5TZo0oUOHDnTp0uWdv+OxsbE0b96cvXv30qFDB4YOHUpISAi7d+/m0qVL5M+fn927d9OxY0fq1avHtGnTALh69SpHjhx57+dNiFSjCCHSxJEjR5Q2bdoov/zyi7JlyxZlypQpioODg2JmZqacPXs2UWUACT6WL1+uKIqizJ49WwGUlStXxh0TFRWlVKlSRbGyslKCg4PjlTV27Ni4n1u1aqWYmZkpd+/ejdt25coVRafTKR/6U7FlyxYFUGbNmpWo61AURfn0008VMzMzJSgoKG7btWvXFEAZPXr0B48fO3asAijXr19XAgICFD8/P2XJkiWKqampkiNHDiUsLEw5dOiQAiirVq2Kd6y3t/db211dXRVA8fb2futctWrVUooXLx5v2+bNmxVAmThxYrztbdu2VTQajXLz5s24bYCi1WqVy5cvx9t3+fLlCqA0atRI0ev1cdurVKmiaDQapX///nHbYmJilDx58ii1atWKV0Z4eHi8n6OiopQSJUoodevWjbcdUExMTOLFdf78eQVQ5s2bF7etW7duilarVU6dOvXW+/AmxgkTJiiWlpbKjRs34r0+atQoRafTKffu3Xvr2H/79/tZoUIFpXfv3oqiKMqLFy8UExMTZcWKFcr+/fsVQFm/fn3ccb1791Zy5sypPHv2LF55HTp0UGxtbePei1OnTsX7XPz33ICyePHiBF/79/u7bNkyBVBmzpz5zvdi6NChio2NjRITE/PeaxYirUhTrBBppGrVqmzYsIFevXrRokULRo0axfHjx9FoNIwePTrR5bRs2ZLdu3fHezRq1AiA7du34+zsTMeOHeP2NzY2ZsiQIYSGhnLgwIEEy4yNjWXnzp20atWKvHnzxm0vWrRoXNnv82YUamJq697o0qULERERcaNlQa2tAZLUDFu4cGEcHR1xd3enX79+FChQgG3btmFhYcH69euxtbWlQYMGPHv2LO5Rvnx5rKys2L9/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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "(0.8202, 0.8291999999999999, 0.8246026407799283)"
      ]
     },
     "execution_count": 54,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.metrics import f1_score\n",
    "\n",
    "# Data from the folds\n",
    "data = {\n",
    "    'Fold Number': [1, 2, 3, 4, 5],\n",
    "    'Precision': [0.827, 0.823, 0.804, 0.830, 0.817],\n",
    "    'Recall': [0.849, 0.827, 0.835, 0.830, 0.805]\n",
    "}\n",
    "\n",
    "# Create a DataFrame\n",
    "df = pd.DataFrame(data)\n",
    "\n",
    "# Calculate F1 scores for each fold\n",
    "df['F1 Score'] = 2 * (df['Precision'] * df['Recall']) / (df['Precision'] + df['Recall'])\n",
    "\n",
    "# Calculate average precision, recall, and F1 score across the folds\n",
    "average_precision = df['Precision'].mean()\n",
    "average_recall = df['Recall'].mean()\n",
    "average_f1_score = df['F1 Score'].mean()\n",
    "\n",
    "# Create a graph for the results\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "# Plotting each metric\n",
    "ax.plot(df['Fold Number'], df['Precision'], label='Precision', marker='o')\n",
    "ax.plot(df['Fold Number'], df['Recall'], label='Recall', marker='o')\n",
    "ax.plot(df['Fold Number'], df['F1 Score'], label='F1 Score', marker='o')\n",
    "\n",
    "# Formatting the graph\n",
    "ax.set_title('5-Fold CV Performance Metrics')\n",
    "ax.set_xlabel('Fold Number')\n",
    "ax.set_ylabel('Scores')\n",
    "ax.set_xticks(df['Fold Number'])\n",
    "ax.legend()\n",
    "plt.grid(True)\n",
    "plt.tight_layout()\n",
    "\n",
    "\n",
    "\n",
    "# Display the graph\n",
    "plt.show()\n",
    "\n",
    "# Return the averages\n",
    "average_precision, average_recall, average_f1_score\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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VqvV6NixoyHJ8PX1Nfr27WtMmTLFrr/n9evXz3BycjK+/fZbh/sxDMMYPny4Icnu58upU6eMOnXqGP7+/kZRUZFd3+6++2678261Wo169eoZISEhxd4TderUMbp06XLFfQNQupgWCOCmNW/ePPn6+uqBBx6Q9Nd0vT59+mj+/Pm2aUgPPvigvL29lZycbNvujz/+0Nq1a9WnTx9b2cKFC9WwYUM1aNBA2dnZtseDDz4oSVq/fr3dsTt27KhGjRoVa9OF05D++OMP5eTkqEOHDkpLS7OVn59C+K9//ctu22HDhtk9NwxDn376qUJDQ2UYhl27QkJClJOTY7ffi/niiy/k4+MjHx8fNW3aVAsXLlR4eLj+/e9/29Xr1auXfHx8bM9PnDihdevW6cknn7SNEmRnZ+v3339XSEiI9u/fr4yMDEnSp59+qqZNmxb7C7yki67S5u7uLhcXF23YsMHhNLmLWbVqlapVq6a+ffvaysqWLavnn39ep0+f1saNG+3q9+nTx25EqUOHDpL+mqZVUhee04CAAH388ccaMGCA3nrrLVudhQsXysvLS126dLH7twsMDFSFChVs76m1a9fq1KlTiomJKXZN2oXn7sL3Vl5enrKzs9W2bVsZhqHvv/++xH25nKs97t+v4+vQoYPduV61apXKlCljG8mS/ppq9/f3/+WMGTNGa9eutXtUq1btqvZxMRaLRWvWrNHrr7+uSpUq6ZNPPlFkZKRq166tPn362KYwWq1WLV26VKGhoWrRooXD/Uh/9blVq1Zq37697bUKFSpoyJAhOnz4sG0K7nkRERF2533Hjh3av3+/wsLC9Pvvv9veS3l5eercubO++uorWa1WU/oO4PpiWiCAm1JRUZHmz5+vBx54wHbtkCQFBQXpP//5j1JSUtS1a1eVKVNGvXr1UlJSkgoKCuTq6qrFixfr7NmzduFq//792rNnj124uNDx48ftntepU8dhvRUrVuj111/Xjh077K7VuvBL8s8//ywnJ6di+/j7KodZWVk6efKk3nvvPb333ntX1C5HgoKC9Prrr8tisahcuXJq2LChKlasWKze39uTnp4uwzAUFxenuLi4ix6/Ro0aOnDggHr16nXZtlzI1dVV//73vzVy5Ej5+vqqdevWeuSRR9SvX79Lfkn++eefVa9evWLTvxo2bGh7/UK1atWye34+aF1NoPu78+e0qKhIu3bt0uuvv64//vjDburp/v37lZOTo6pVqzrcx/l/u/PX99x7772XPOaRI0c0ZswYLVu2rFjbc3JyStyXy7ma47q5uRX7DFWqVMluu59//lnVq1dXhQoV7OrVr1//qtoVEBCg4ODgq9rmari6umr06NEaPXq0jh49qo0bN2ry5MlasGCBypYtq7lz5yorK0u5ubmX/bf7+eefHd4q4sL37IX7+Ptncf/+/ZJ0yamTOTk5xaalArj5EK4A3JTWrVuno0ePav78+Zo/f36x1+fNm6euXbtKkp566inNmDFDn3/+uXr27KkFCxaoQYMGatq0qa2+1WpVQECAJk6c6PB4fn5+ds8dXSj/9ddf69FHH9X999+vqVOnqnr16ipbtqxmzZpltzDBlTr/l+h//vOfF/1S1aRJk8vux9vb+4q+hP69T+eP/+KLLyokJMThNte67P3w4cMVGhqqpUuXas2aNYqLi1NCQoLWrVun5s2bX9O+z3N2dnZYbhhGifd54TkNCQlRgwYN9Mgjj2jy5MmKjo6W9Nf5q1q1qt0iKxe6WJB3pKioSF26dNGJEyf08ssvq0GDBipfvrwyMjLUv3//6zZqcbXHvdi5vtVVr15dTz31lHr16qXGjRtrwYIF1/Vmxxf7LL711ltq1qyZw23+HlYB3JwIVwBuSvPmzVPVqlU1ZcqUYq8tXrxYS5Ys0fTp0+Xu7q77779f1atXV3Jystq3b69169Zp9OjRdtvUrVtXO3fuVOfOna/6ZqPnffrpp3Jzc9OaNWvk6upqK581a5Zdvdq1a8tqterQoUOqV6+erTw9Pd2uno+Pjzw8PFRUVHRd/0J/MXfffbekv6bcXe74devW1a5du0p0nLp162rkyJEaOXKk9u/fr2bNmuk///mP5s6d67B+7dq19b///U9Wq9Vu9Or8jV3PL0ZwIz388MPq2LGjJkyYoGeffVbly5dX3bp19eWXX6pdu3aXXLWubt26kqRdu3ZdNKz+8MMP+umnnzRnzhz169fPVr527VpzO3IDjlu7dm2lpKTo9OnTdoFg375919TWG6Fs2bJq0qSJ9u/fr+zsbFWtWlWenp6Xfe/Xrl3bYf+u9D17/j3i6elZKj8LAJiHa64A3HT+/PNPLV68WI888oh69+5d7BEVFaVTp07Zlgt3cnJS7969tXz5cn388cc6d+6c3ZRASXryySeVkZGh999/3+Hx8vLyLtsuZ2dnWSwWu2WnDx8+XGylwfOjQFOnTrUrf+edd4rtr1evXvr0008dfnnLysq6bJuuRdWqVdWpUyfNmDFDR48eveTxe/XqpZ07d2rJkiXF6l1shCg/P19nzpyxK6tbt648PDyKLX9/oe7du+vYsWN219GdO3dO77zzjipUqKCOHTtetm/Xw8svv6zff//d9h568sknVVRUpHHjxhWre+7cOdt1O127dpWHh4cSEhKKnY/z5+78iNCF59IwDE2ePPl6dMXmehy3e/fuOnfunKZNm2YrKyoqKvb+L0379+/XkSNHipWfPHlSW7duVaVKleTj4yMnJyf17NlTy5cv13fffVes/vnz1r17d23fvl1bt261vZaXl6f33ntP/v7+Dq/fvFBgYKDq1q2rt99+W6dPny72+vX+WQDAPIxcAbjpLFu2TKdOndKjjz7q8PXWrVvLx8dH8+bNs4WoPn366J133lF8fLwCAgJs1zqcFx4ergULFmjo0KFav3692rVrp6KiIu3du1cLFizQmjVrHF6wfqGHH35YEydO1EMPPaSwsDAdP35cU6ZM0T333KP//e9/tnqBgYHq1auXEhMT9fvvv9uWYj9/k9MLR87eeOMNrV+/XkFBQRo8eLAaNWqkEydOKC0tTV9++aVOnDhRonN4paZMmaL27dsrICBAgwcP1t13363MzExt3bpVv/76q3bu3ClJ+n//7/9p0aJFeuKJJ/TMM88oMDBQJ06c0LJlyzR9+nS7KZjn/fTTT+rcubOefPJJNWrUSGXKlNGSJUuUmZlpWyLfkSFDhmjGjBnq37+/UlNT5e/vr0WLFmnz5s1KTEyUh4fHVffz8OHDqlOnjiIiIko83atbt2669957NXHiREVGRqpjx4569tlnlZCQoB07dqhr164qW7as9u/fr4ULF2ry5Mnq3bu3PD09NWnSJA0aNEgtW7ZUWFiYKlWqpJ07dyo/P19z5sxRgwYNVLduXb344ovKyMiQp6enPv3002u6buz8UvcX3lPs767HcUNDQ9WuXTvFxMTo8OHDatSokRYvXmz6dWM///yzPv74Y0myBZ/XX39d0l8jReHh4RfddufOnQoLC1O3bt3UoUMHVa5cWRkZGZozZ45+++03JSYm2oLnhAkT9MUXX6hjx4622zgcPXpU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rl27Ki8vr9j+EhMTZbFYHB5r4sSJGj16tGJiYrR79259+eWXCgkJMafjuCVYDMMwrnaj/Px8DRs2THPmzJEk/fTTT7r77rs1bNgw1ahRQzExMaY39EbKzc2Vl5eXcnJy5OnpWdrNAXAnSXL8CxvA/y/sqr+24DYTFBSkli1b6t1335UkWa1W+fn5adiwYQ6/g0ZFRWnPnj1KSUmxlY0cOVLbtm3Tpk2bHB4jKytLVatW1caNG3X//ffbynfs2KFHHnlE3333napXr64lS5aoZ8+ekqQ//vhDNWrU0PLly9W5c2cTe4zSdjXZoEQjV6NGjdLOnTu1YcMGubm52cqDg4OVnJxckl0CAAAAl1RYWKjU1FQFBwfbypycnBQcHKytW7c63KZt27ZKTU21TR08ePCgVq1ape7du1/0ODk5OZKkypUr28ry8/MVFhamKVOmqFq1asW2Wbt2raxWqzIyMtSwYUPVrFlTTz75pH755ZcS9RW3pjIl2Wjp0qVKTk5W69at7YZFGzdurAMHDpjWOAAAAOC87OxsFRUVydfX167c19dXe/fudbhNWFiYsrOz1b59exmGoXPnzmno0KF20wIvZLVaNXz4cLVr10733nuvrXzEiBFq27atevTo4XC7gwcPymq1asKECZo8ebK8vLwUGxurLl266H//+59cXFxK2GvcSko0cnV+qPTv8vLyLjoHFQAAALjRNmzYoAkTJmjq1KlKS0vT4sWLtXLlSo0bN85h/cjISO3atUvz58+3lS1btkzr1q1TYmLiRY9jtVp19uxZ/fe//1VISIhat26tTz75RPv379f69evN7hZuUiUKVy1atNDKlSttz88Hqg8++EBt2rQxp2UAAADABby9veXs7KzMzEy78szMTIdT9SQpLi5O4eHhGjRokAICAvTYY49pwoQJSkhIkNVqtasbFRWlFStWaP369apZs6atfN26dTpw4IAqVqyoMmXKqEyZvyZ/9erVS506dZIkVa9eXZLUqFEj23Y+Pj7y9vbWkSNHrrnvuDWUaFrghAkT1K1bN/344486d+6cJk+erB9//FFbtmzRxo0bzW4jAAAAIBcXFwUGBiolJcW2kITValVKSoqioqIcbpOfny8nJ/vxBGdnZ0l/Lat+/r/Dhg3TkiVLtGHDBtWpU8eufkxMjAYNGmRXFhAQoEmTJik0NFSS1K5d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k6T169frwIEDWr9+vebMmaPZs2dr9uzZpp0f4E6za9cubdmyxfbX44SEBH300UeaPn26du/erREjRuif//ynNm7cKEnKyMjQ/fffL1dXV61bt06pqal65plnbNONT506pYiICG3atEnffPON6tWrp+7du+vUqVOl1kcAl1etWjWtW7dOWVlZF60zatQovfHGG4qLi9OPP/6opKQk+fr6Srry3+Ml+e6B24gB3MIiIiKMHj16GIZhGFar1Vi7dq3h6upqvPjii0ZERITh6+trFBQU2Op//PHHRv369Q2r1WorKygoMNzd3Y01a9YYhmEYd911lzF69OiLHlOSsWTJEsMwDGPYsGHGgw8+aLe/i9V97733jEqVKhmnT5+2vb5y5UrDycnJOHbsmK0/tWvXNs6dO2er88QTTxh9+vS58pMC3OEiIiIMZ2dno3z58oarq6shyXBycjIWLVpknDlzxihXrpyxZcsWu20GDhxo9O3b1zAMwxg1apRRp04do7Cw8IqOV1RUZHh4eBjLly+3lV342T906JAhyfj+++9N6R9wJ7jwc3z+0bt3b4d1L/y8Xcru3buNhg0bGk5OTkZAQIDx7LPPGqtWrbK9npuba7i6uhrvv/++w+2v9Pd4Sb574PbBNVe45a1YsUIVKlTQ2bNnZbVaFRYWpldffVWRkZEKCAiwm+u8c+dOpaeny8PDw24fZ86c0YEDB3T8+HH99ttv6ty58xUdu3///urSpYvq16+vhx56SI888oi6du3qsO6ePXvUtGlTlS9f3lbWrl07Wa1W7du3z/aXscaNG9umPUhS9erV9cMPP1zx+QAgPfDAA5o2bZry8vI0adIklSlTRr169dLu3buVn5+vLl262NUvLCxU8+bNJUk7duxQhw4dVLZsWYf7zszMVGxsrDZs2KDjx4+rqKhI+fn5OnLkyHXvF3AnOf85Pu/C358l0ahRI+3atUupqanavHmzbVGM/v3764MPPtCePXtUUFBw0e8AV/p7/Gq/e+D2QrjCLe/8D18XFxfdddddKlPm/97Wf/9BfPr0aQUGBmrevHnF9uPj4yMnp6ubKXvffffp0KFD+vzzz/Xll1/qySefVHBwcLHrN67G37/QWSwWWa3WEu8PuBOVL1/eNp33ww8/VNOmTTVz5kzde++9kqSVK1eqRo0adtu4urpK+mtq8aVERETo999/1+TJk1W7dm25urqqTZs2TO8BTHbh59gsTk5OatmypVq2bKnhw4dr7ty5Cg8P1+jRoy/72b9SV/vdA7cXwhVueVfzw/e+++5TcnKyqlatKk9PT4d1/P39lZKSogceeOCK9unp6ak+ffqoT58+6t27tx566CGdOHFClStXtqvXsGFDzZ49W3l5ebYfvJs3b5aTk5PtglcA5nNyctIrr7yi6Oho/fTTT3J1ddWRI0fUsWNHh/WbNGmiOXPm6OzZsw5HrzZv3qypU6eqe/fukv66UD07O/u69gHA9dGoUSNJf11PVa9ePbm7uyslJUWDBg0qVrekv8ev5LsHbh8saIE7ytNPPy1vb2/16NFDX3/9tQ4dOqQNGzbo+eef16+//ipJevXVV/Wf//xH//3vf7V//36lpaXpnXfecbi/iRMn6pNPPtHevXv1008/aeHChapWrZoqVqzo8Nhubm6KiIjQrl27tH79eg0bNkzh4eG2qQQAro8nnnhCzs7OmjFjhl588UWNGDFCc+bM0YEDB2yf8Tlz5kiSoqKilJubq6eeekrfffed9u/fr48//lj79u2TJNWrV08ff/yx9uzZo23btunpp5827S/eAK7M6dOntWPHDtvNuQ8dOqQdO3Zccnpu7969NWnSJG3btk0///yzNmzYoMjISP3jH/9QgwYN5ObmppdfflkvvfSSPvroIx04cEDffPONZs6cKankv8ev5LsHbh+EK9xRypUrp6+++kq1atXS448/roYNG2rgwIE6c+aM7a9JERERSkxM1NSpU9W4cWM98sgj2r9/v8P9eXh46M0331SLFi3UsmVLHT58WKtWrXI4vbBcuXJas2aNTpw4oZYtW6p3797q3Lmz3n333evaZwBSmTJlFBUVpTfffFOjRo1SXFycEhIS1LBhQz300ENauXKl6tSpI0mqUqWK1q1bp9OnT6tjx44KDAzU+++/bxvFmjlzpv744w/dd999Cg8P1/PPP6+qVauWZveAO853332n5s2b266VjI6OVvPmzTVmzJiLbhMSEqLly5crNDRU//jHPxQREaEGDRroiy++sF1SEBcXp5EjR2rMmDFq2LCh+vTpo+PHj0sq+e/xK/nugduHxTAMo7QbAQAAAAC3OkauAAAAAMAEhCsAAAAAMAHhCgAAAABMQLgCAAAAABMQrgAAAADABIQrAAAAADAB4QoAAAAATEC4AgAAAAATEK4AAAAAwASEKwAAAAAwAeEKAAAAAExAuAIAAAAAE/x/ngQ1DQdTqdgAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Python code to create a bar chart for the average precision, recall, and F1 score\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Average scores from the previous output\n",
    "average_precision = 0.8202\n",
    "average_recall = 0.8292\n",
    "average_f1_score = 0.8246\n",
    "\n",
    "# Data\n",
    "metrics = ['Precision', 'Recall', 'F1 Score']\n",
    "average_scores = [average_precision, average_recall, average_f1_score]\n",
    "\n",
    "# Create bar chart\n",
    "plt.figure(figsize=(10, 6))\n",
    "bars = plt.bar(metrics, average_scores, color=['blue', 'orange', 'green'])\n",
    "\n",
    "# Add the data values on the bars\n",
    "for bar in bars:\n",
    "    yval = bar.get_height()\n",
    "    plt.text(bar.get_x() + bar.get_width()/2, yval + 0.001, round(yval, 4), ha='center', va='bottom')\n",
    "\n",
    "# Title and labels\n",
    "plt.title('Average Precision, Recall, and F1 Score')\n",
    "plt.ylabel('Score')\n",
    "plt.ylim([0.8, 0.85])  # Set y limit to make the chart clearer\n",
    "\n",
    "# Display the bar chart\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAArwAAAIQCAYAAABjZL3WAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy89olMNAAAACXBIWXMAAA9hAAAPYQGoP6dpAABOG0lEQVR4nO3deVxV1eL///cBZVABBxAcUMy8joiGimNWkqZFWVomfRDMNLuQKfntQopkpnSrS3i7Dg1ON/WKlpapaYZDpZaF6dVSE4csUpRUUEgQ2L8/+nmuR44DCB7avZ6Px3nUWXutvdfansN5s1hnb4thGIYAAAAAk3JydAcAAACAykTgBQAAgKkReAEAAGBqBF4AAACYGoEXAAAApkbgBQAAgKkReAEAAGBqBF4AAACYGoEXAAAApkbgBQA7jhw5IovFovnz55ep3R133KE77rijUvpkRi+88IIsFotNWUBAgKKiohzToetU3tcHAMcg8AI32cyZM2WxWBQSEuLorlQ5AQEBslgs1kf9+vXVq1cvrVixwtFd+8O6/JzWrFlTXbp00b///W9Hd+1PYdOmTTbn/9LHo48+aq23fft2/fWvf1VwcLCqV69e6peAayksLNT06dPVsWNHeXp6qnbt2mrbtq1GjRqlffv2VfSwgD+cao7uAPBns2jRIgUEBGj79u3KyMjQrbfe6uguVSkdOnTQs88+K0n65Zdf9Oabb+qhhx7SrFmzNHr06JvWj6ZNm+q3335T9erVy9Tuk08+qaQeld+l5/TYsWN65513FBkZqYKCAo0cOdLBvftzGDNmjDp37mxTFhAQYP3/NWvW6J133lH79u11yy236IcffijT/gcNGqSPP/5YQ4cO1ciRI3XhwgXt27dPq1atUvfu3dWqVauKGAbwx2UAuGkOHTpkSDKWL19u+Pj4GC+88MJN70NxcbHx22+/3fTjXo+mTZsa9957r03ZsWPHjJo1axp/+ctfrtjuwoULRkFBQWV37w/J3jk9ceKEUatWLaN169YO6tX/JCYmGpd/FDVt2tSIjIx0TIeu0+HDhw1Jxrx5865ab+PGjYYkY9myZVetd/z4cSM/P98wDMOIjo4udU6uZvv27YYkY+rUqaW2FRUVGdnZ2de9rxv122+/GcXFxTfteMD1YkkDcBMtWrRIderU0b333qvBgwdr0aJF1m0XLlxQ3bp1NXz48FLtcnNz5ebmpvHjx1vLCgoKlJiYqFtvvVWurq7y9/fXc889p4KCApu2FotFMTExWrRokdq2bStXV1etXbtWkvTaa6+pe/fuqlevntzd3RUcHKz33nuv1PF/++03jRkzRt7e3vLw8ND999+vzMxMWSwWvfDCCzZ1MzMz9fjjj8vX11eurq5q27at5s6dW+5z5ufnp9atW+vw4cOS/rd28rXXXlNKSoqaN28uV1dXff/995Kkffv2afDgwapbt67c3NzUqVMnrVy5stR+z5w5o3HjxikgIECurq5q3Lixhg0bpuzsbJvjXLpG8/jx4xo+fLgaN24sV1dXNWjQQA888ICOHDlirWNvDe+JEyc0YsQI+fr6ys3NTUFBQVqwYIFNnUvH9dZbb1nH1blzZ3399dflPn/2+Pj4qFWrVjp48KBNeUlJiVJSUtS2bVu5ubnJ19dXTz75pE6fPl1qHx9//LF69+4tDw8PeXp6qnPnzlq8eLF1++eff66HH35YTZo0sb4+x40bp99++61Cx3K56z1uVFSUatWqpczMTA0cOFC1atWSj4+Pxo8fr+LiYpu6Z86cUVRUlLy8vFS7dm1FRkbqzJkzFdpvX19fubu7l6vtxX/HHj16lNrm7OysevXq2ZRlZmZqxIgRatiwoVxdXdWsWTM99dRTKiwstNY5dOiQHn74YdWtW1c1atRQ165dtXr1apv9XFyusWTJEk2cOFGNGjVSjRo1lJubK0n66quvdM8998jLy0s1atRQ7969tWXLlnKNEbhRLGkAbqJFixbpoYcekouLi4YOHapZs2bp66+/VufOnVW9enU9+OCDWr58ud588025uLhY233wwQcqKCiwrvkrKSnR/fffry+++EKjRo1S69attXv3br3++uv64Ycf9MEHH9gcd8OGDVq6dKliYmLk7e1t/VPq9OnTdf/99+uxxx5TYWGhlixZoocfflirVq3Svffea20fFRWlpUuXKiIiQl27dtXmzZtttl+UlZWlrl27WkO2j4+PPv74Y40YMUK5ubkaO3Zsmc/ZhQsX9NNPP5X60J43b57Onz+vUaNGydXVVXXr1tV3332nHj16qFGjRoqLi1PNmjW1dOlSDRw4UO+//74efPBBSdK5c+fUq1cv7d27V48//rhuu+02ZWdna+XKlfr555/l7e1tty+DBg3Sd999p6effloBAQE6ceKE1q9fr6NHj9r8efpSv/32m+644w5lZGQoJiZGzZo107JlyxQVFaUzZ87omWeesam/ePFinT17Vk8++aQsFoteeeUVPfTQQzp06FCZl1dcSVFRkX7++WfVqVPHpvzJJ5/U/PnzNXz4cI0ZM0aHDx/Wv/71L3377bfasmWL9fjz58/X448/rrZt2yo+Pl61a9fWt99+q7Vr1yo8PFyStGzZMuXn5+upp55SvXr1tH37dr3xxhv6+eeftWzZsgoZhz1lOW5xcbH69eunkJAQvfbaa/r000/1j3/8Q82bN9dTTz0lSTIMQw888IC++OILjR49Wq1bt9aKFSsUGRlZpn6dPXvW+svURXXr1pWT043POzVt2lTS7z9fevTooWrVrvzR/ssvv6hLly46c+aMRo0apVatWikzM1Pvvfee8vPz5eLioqysLHXv3l35+fkaM2aM6tWrpwULFuj+++/Xe++9Z30fXTRlyhS5uLho/PjxKigokIuLizZs2KD+/fsrODhYiYmJcnJy0rx583TXXXfp888/V5cuXW543ECZOHqKGfiz+OabbwxJxvr16w3DMIySkhKjcePGxjPPPGOts27dOkOS8dFHH9m0HTBggHHLLbdYn7/77ruGk5OT8fnnn9vUmz17tiHJ2LJli7VMkuHk5GR89913pfp08U+oFxUWFhrt2rUz7rrrLmtZenq6IckYO3asTd2oqChDkpGYmGgtGzFihNGgQYNSf0J99NFHDS8vr1LHu1zTpk2Nvn37GidPnjROnjxp7Nq1y3j00UcNScbTTz9tGMb//pTs6elpnDhxwqZ9nz59jMDAQOP8+fPWspKSEqN79+5GixYtrGWTJk2yLi25XElJic1xLv7J+vTp04Yk49VXX73qGHr37m307t3b+jwlJcWQZCxcuNBaVlhYaHTr1s2oVauWkZuba3O8evXqGadOnbLW/fDDD+2+Jq7X5ed09+7dRkREhCHJiI6Ottb7/PPPDUnGokWLbNqvXbvWpvzMmTOGh4eHERISUmppzMVzZxilX1uGYRhJSUmGxWIxfvzxR2tZRS9puN7jRkZGGpKMF1980aZux44djeDgYOvzDz74wJBkvPLKK9ayoqIio1evXmVa0mDvcfjwYbttyrqkoaSkxOjdu7chyfD19TWGDh1qzJgxw2a8Fw0bNsxwcnIyvv76a7v7MQzDGDt2rCHJ5ufL2bNnjWbNmhkBAQHWJQsXx3bLLbfYnPeSkhKjRYsWRr9+/Uq9Jpo1a2bcfffd1z02oKKwpAG4SRYtWiRfX1/deeedkn5fajBkyBAtWbLE+ifUu+66S97e3kpNTbW2O336tNavX68hQ4ZYy5YtW6bWrVurVatWys7Otj7uuusuSdLGjRttjt27d2+1adOmVJ8u/RPq6dOnlZOTo169emnHjh3W8ovLH/7617/atH366adtnhuGoffff19hYWEyDMOmX/369VNOTo7Nfq/kk08+kY+Pj3x8fBQUFKRly5YpIiJCf//7323qDRo0SD4+Ptbnp06d0oYNG/TII49YZ9Oys7P166+/ql+/fjpw4IAyMzMlSe+//76CgoJKzVRJuuK3493d3eXi4qJNmzbZ/RP/laxZs0Z+fn4aOnSotax69eoaM2aMzp07p82bN9vUHzJkiM3Ma69evST9/ifm8rr0nAYGBurdd9/V8OHD9eqrr1rrLFu2TF5eXrr77rtt/u2Cg4NVq1Yt62tq/fr1Onv2rOLi4uTm5mZznEvP3aWvrby8PGVnZ6t79+4yDEPffvttucdyLWU97uVfhOzVq5fNuV6zZo2qVatmnfGVfl8mcPnr/1omTZqk9evX2zz8/PzKtI8rsVgsWrdunV566SXVqVNH//nPfxQdHa2mTZtqyJAh1uUXJSUl+uCDDxQWFqZOnTrZ3Y/0+5i7dOminj17WrfVqlVLo0aN0pEjR6zLhy6KjIy0Oe87d+7UgQMHFB4erl9//dX6WsrLy1OfPn302WefqaSkpELGDlwvljQAN0FxcbGWLFmiO++807oWVZJCQkL0j3/8Q2lpaerbt6+qVaumQYMGafHixSooKJCrq6uWL1+uCxcu2ATeAwcOaO/evTaB71InTpywed6sWTO79VatWqWXXnpJO3futFn7e2lw+fHHH+Xk5FRqH5dfXeLkyZM6c+aM3nrrLb311lvX1S97QkJC9NJLL8lisahGjRpq3bq1ateuXare5f3JyMiQYRhKSEhQQkLCFY/fqFEjHTx4UIMGDbpmXy7l6uqqv//973r22Wfl6+urrl276r777tOwYcOuGlx+/PFHtWjRotSfrlu3bm3dfqkmTZrYPL8YfssSsi938ZwWFxdrz549eumll3T69GmbZTMHDhxQTk6O6tevb3cfF//tLq4Xbdeu3VWPefToUU2aNEkrV64s1fecnJxyj+VaynJcNze3Uu+hOnXq2LT78ccf1aBBA9WqVcumXsuWLcvUr8DAQIWGhpapTVm4urpqwoQJmjBhgo4dO6bNmzdr+vTpWrp0qapXr66FCxfq5MmTys3Nvea/3Y8//mj3somXvmYv3cfl78UDBw5I0lWXfeTk5JRaUgNUJgIvcBNs2LBBx44d05IlS7RkyZJS2xctWqS+fftKkh599FG9+eab+vjjjzVw4EAtXbpUrVq1UlBQkLV+SUmJAgMDlZycbPd4/v7+Ns/tfRnm888/1/3336/bb79dM2fOVIMGDVS9enXNmzfP5stH1+vijM3//d//XfGDrn379tfcj7e393UFg8vHdPH448ePV79+/ey2udFLwI0dO1ZhYWH64IMPtG7dOiUkJCgpKUkbNmxQx44db2jfFzk7O9stNwyj3Pu89Jz269dPrVq10n333afp06crNjZW0u/nr379+jZfpLzUlX65sqe4uFh33323Tp06pb/97W9q1aqVatasqczMTEVFRVXa7F5Zj3ulc/1H16BBAz366KMaNGiQ2rZtq6VLl1bqDTKu9F589dVX1aFDB7ttLv8FAqhsBF7gJli0aJHq16+vGTNmlNq2fPlyrVixQrNnz5a7u7tuv/12NWjQQKmpqerZs6c2bNigCRMm2LRp3ry5du3apT59+pT5AvUXvf/++3Jzc9O6devk6upqLZ83b55NvaZNm6qkpESHDx9WixYtrOUZGRk29Xx8fOTh4aHi4uJKncm6kltuuUXS78sFrnX85s2ba8+ePeU6TvPmzfXss8/q2Wef1YEDB9ShQwf94x//0MKFC+3Wb9q0qf773/+qpKTEZpb34s0ALn7h6Ga699571bt3b02bNk1PPvmkatasqebNm+vTTz9Vjx49rnq1gObNm0uS9uzZc8VfIHbv3q0ffvhBCxYs0LBhw6zl69evr9iB3ITjNm3aVGlpaTp37pxNSNu/f/8N9fVmqF69utq3b68DBw4oOztb9evXl6en5zVf+02bNrU7vut9zV58jXh6ejrkZwFgD2t4gUr222+/afny5brvvvs0ePDgUo+YmBidPXvWeuksJycnDR48WB999JHeffddFRUV2SxnkKRHHnlEmZmZevvtt+0eLy8v75r9cnZ2lsVisbkE05EjR0pd4eHibOnMmTNtyt94441S+xs0aJDef/99ux+oJ0+evGafbkT9+vV1xx136M0339SxY8euevxBgwZp165ddu/gdqWZ1Pz8fJ0/f96mrHnz5vLw8Ch1KbhLDRgwQMePH7dZl11UVKQ33nhDtWrVUu/eva85tsrwt7/9Tb/++qv1NfTII4+ouLhYU6ZMKVW3qKjIug60b9++8vDwUFJSUqnzcfHcXZw5vfRcGoah6dOnV8ZQrCrjuAMGDFBRUZFmzZplLSsuLi71+nekAwcO6OjRo6XKz5w5o23btqlOnTry8fGRk5OTBg4cqI8++kjffPNNqfoXz9uAAQO0fft2bdu2zbotLy9Pb731lgICAux+H+BSwcHBat68uV577TWdO3eu1PbK/lkA2MMML1DJVq5cqbNnz+r++++3u71r167y8fHRokWLrMF2yJAheuONN5SYmKjAwEDr2rmLIiIitHTpUo0ePVobN25Ujx49VFxcrH379mnp0qVat26d3S+lXOree+9VcnKy7rnnHoWHh+vEiROaMWOGbr31Vv33v/+11gsODtagQYOUkpKiX3/91XpZsot3grp0hvnll1/Wxo0bFRISopEjR6pNmzY6deqUduzYoU8//VSnTp0q1zm8XjNmzFDPnj0VGBiokSNH6pZbblFWVpa2bdumn3/+Wbt27ZIk/b//9//03nvv6eGHH9bjjz+u4OBgnTp1SitXrtTs2bNtlo9c9MMPP6hPnz565JFH1KZNG1WrVk0rVqxQVlaWzS1iLzdq1Ci9+eabioqKUnp6ugICAvTee+9py5YtSklJkYeHR5nHeeTIETVr1kyRkZHl/lN1//791a5dOyUnJys6Olq9e/fWk08+qaSkJO3cuVN9+/ZV9erVdeDAAS1btkzTp0/X4MGD5enpqddff11PPPGEOnfurPDwcNWpU0e7du1Sfn6+FixYoFatWql58+YaP368MjMz5enpqffff/+G1iFfvOzbpdc8vlxlHDcsLEw9evRQXFycjhw5ojZt2mj58uUVvg75xx9/1LvvvitJ1jD60ksvSfp9RjUiIuKKbXft2qXw8HD1799fvXr1Ut26dZWZmakFCxbol19+UUpKivWXgWnTpumTTz5R7969rZc0PHbsmJYtW6YvvvhCtWvXVlxcnP7zn/+of//+GjNmjOrWrasFCxbo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Xy/p9ztJJiUlqVmzZnJ3d1dQUJDee+89m/bfffed7rvvPnl6esrDw0O9evXSwYMHJUlff/217r77bnl7e8vLy0u9e/fWjh07bvoYAXsuvvYvfVy8yVT//v310ksv6cEHH7zu/a1cuVJ//etf9fDDD6tZs2YKCgrSiBEjNH78eGudkpISvfLKK7r11lvl6uqqJk2a2Fzr/3o/M8rzOYfKQ+DFTeHu7q7CwkJJUlpamvbv36/169dr1apVunDhgvr16ycPDw99/vnn2rJli2rVqqV77rnH2mbWrFmKjo7WqFGjtHv3bq1cuVK33nqr3WP985//1MqVK7V06VLt379fixYtUkBAgN26eXl56tevn+rUqaOvv/5ay5Yt06effmoTpiVp48aNOnjwoDZu3KgFCxZo/vz5mj9/foWdH+B67dmzR1u3brXOGCUlJenf//63Zs+ere+++07jxo3T//3f/2nz5s2SpMzMTN1+++1ydXXVhg0blJ6erscff9y6xOjs2bOKjIzUF198oS+//FItWrTQgAEDdPbsWYeNEagsfn5+2rBhg06ePHnFOvHx8Xr55ZeVkJCg77//XosXL7beuOp6PzPK8zmHSmYAFSwyMtJ44IEHDMMwjJKSEmP9+vWGq6urMX78eCMyMtLw9fU1CgoKrPXfffddo2XLlkZJSYm1rKCgwHB3dzfWrVtnGIZhNGzY0JgwYcIVjynJWLFihWEYhvH0008bd911l83+rlT3rbfeMurUqWOcO3fOun316tWGk5OTcfz4cet4mjZtahQVFVnrPPzww8aQIUOu/6QA5RQZGWk4OzsbNWvWNFxdXQ1JhpOTk/Hee+8Z58+fN2rUqGFs3brVps2IESOMoUOHGoZhGPHx8UazZs2MwsLC6zpecXGx4eHhYXz00UfWskvfM4cPHzYkGd9++22FjA+4kktf+xcfgwcPtlv30tfo1Xz33XdG69atDScnJyMwMNB48sknjTVr1li35+bmGq6ursbbb79tt/31fmaU53MOlYs1vKgUq1atUq1atXThwgWVlJQoPDxcL7zwgqKjoxUYGGiznmnXrl3KyMiQh4eHzT7Onz+vgwcP6sSJE/rll1/Up0+f6zp2VFSU7r77brVs2VL33HOP7rvvPvXt29du3b179yooKEg1a9a0lvXo0UMlJSXav3+/9bf6tm3bWv+MJkkNGjTQ7t27r/t8ADfizjvv1KxZs5SXl6fXX39d1apV06BBg/Tdd98pPz9fd999t039wsJCdezYUZK0c+dO9erVS9WrV7e776ysLE2cOFGbNm3SiRMnVFxcrPz8fB09erTSxwVcy8XX/kWX/qwujzZt2mjPnj1KT0/Xli1brF98i4qK0jvvvKO9e/eqoKDgip831/uZUdbPOVQ+Ai8qxcUfUi4uLmrYsKGqVfvfS+3yH1jnzp1TcHCwFi1aVGo/Pj4+cnIq28qb2267TYcPH9bHH3+sTz/9VI888ohCQ0NLrWssi8vDgsViUUlJSbn3B5RFzZo1rUt45s6dq6CgIM2ZM0ft2rWTJK1evVqNGjWyaePq6irp9+VEVxMZGalff/1V06dPV9OmTeXq6qpu3brxZ1ZUCZe+9iuKk5OTOnfurM6dO2vs2LFauHChIiIiNGHChGu+X65XWT/nUPkIvKgUZfkhddtttyk1NVX169eXp6en3ToBAQFKS0vTnXfeeV379PT01JAhQzRkyBANHjxY99xzj06dOqW6deva1GvdurXmz5+vvLw86w+oLVu2yMnJyfpFA6AqcXJy0vPPP6/Y2Fj98MMPcnV11dGjR9W7d2+79du3b68FCxbowoULdmd5t2zZopkzZ2rAgAGSfv9iTXZ2dqWOAahK2rRpI+n39bktWrSQu7u70tLS9MQTT5SqW97PjOv5nEPl4ktrcLjHHntM3t7eeuCBB/T555/r8OHD2rRpk8aMGaOff/5ZkvTCCy/oH//4h/75z3/qwIED2rFjh9544w27+0tOTtZ//vMf7du3Tz/88IOWLVsmPz8/1a5d2+6x3dzcFBkZqT179mjjxo16+umnFRERYf3TFFDVPPzww3J2dtabb76p8ePHa9y4cVqwYIEOHjxofW8sWLBAkhQTE6Pc3Fw9+uij+uabb3TgwAG9++672r9/vySpRYsWevfdd7V371599dVXeuyxxypslguoTOfOndPOnTutN0E5fPiwdu7cedXlOIMHD9brr7+ur776Sj/++KM2bdqk6Oho/eUvf1GrVq3k5uamv/3tb3ruuef073//WwcPHtSXX36pOXPmSCr/Z8b1fM6hchF44XA1atTQZ599piZNmuihhx5S69atNWLECJ0/f976m3BkZKRSUlI0c+ZMtW3bVvfdd58OHDhgd38eHh565ZVX1KlTJ3Xu3FlHjhzRmjVr7C6NqFGjhtatW6dTp06pc+fOGjx4sPr06aN//etflTpm4EZUq1ZNMTExeuWVVxQfH6+EhAQlJSWpdevWuueee7R69Wo1a9ZMklSvXj1t2LBB586dU+/evRUcHKy3337bOts7Z84cnT59WrfddpsiIiI0ZswY1a9f35HDA67LN998o44dO1rXq8fGxqpjx46aNGnSFdv069dPH330kcLCwvSXv/xFkZGRatWqlT755BPr0ruEhAQ9++yzmjRpklq3bq0hQ4boxIkTksr/mXE9n3OoXBbDMAxHdwIAAACoLMzwAgAAwNQIvAAAADA1Ai8AAABMjcALAAAAUyPwAgAAwNQIvAAAADA1Ai8AAABMjcALAAAAUyPwAgAAwNQIvAAAADA1Ai8AAABMjcALAAAAU/v/AC9HVELzGEtaAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Adjusting the bar chart to display data values with 3 decimal points\n",
    "\n",
    "# Create bar chart with softer colors and adjusted data label precision\n",
    "plt.figure(figsize=(8, 6))\n",
    "bars = plt.bar(metrics, average_scores, color=['lightblue', 'lightcoral', 'lightgreen'])\n",
    "\n",
    "# Add the data values on the bars with 3 decimal points\n",
    "for bar in bars:\n",
    "    yval = bar.get_height()\n",
    "    plt.text(bar.get_x() + bar.get_width()/2, yval + 0.001, f\"{yval:.3f}\", ha='center', va='bottom')\n",
    "\n",
    "# Title and labels\n",
    "plt.title('Average Precision, Recall, and F1 Score')\n",
    "plt.ylabel('Score')\n",
    "plt.ylim([0.8, 0.85])  # Set y limit to make the chart clearer\n",
    "\n",
    "# Display the bar chart\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA1cAAAIQCAYAAABt6JSQAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy89olMNAAAACXBIWXMAAA9hAAAPYQGoP6dpAABjFUlEQVR4nO3deVhV1eL/8Q+gDMngwGRKouZ1DgyQ1FJLktRQy8rSFCg1u2ApdQsTpLKk+nYJrznVTfOqXMkcMqcyTEszLUjLHHIqzQQkCxQTlLN/f/TzXE+gAm49Ku/X85ynzjprr73W5njgc9beazsYhmEIAAAAAHBRHO3dAQAAAAC4FhCuAAAAAMAEhCsAAAAAMAHhCgAAAABMQLgCAAAAABMQrgAAAADABIQrAAAAADAB4QoAAAAATEC4AgAAAAATEK4A4Ar1448/ysHBQe+++26Vtuvevbu6d+9+Sfp0LXr++efl4OBgUxYYGKiYmBj7dAiXXUxMjAIDA01rb+3atXJwcNDatWtNa/Pdd9+Vg4ODfvzxR2vZpfi3Xt3PHQB/IlwBNdDUqVPl4OCg8PBwe3flihMYGCgHBwfrw9fXV7fddpsWL15s765dtf56TOvUqaOOHTvqP//5j727dknExMTYjPfsx6pVq6z1pk2bpvvvv1833HCDHBwcqhzmfvzxR8XGxqp58+ZydXWVv7+/unbtqpSUFJNHhDMsFov+85//KDw8XPXr15eHh4f+9re/aejQofryyy/t3b1LZsWKFXr++eft3Q3gqlDL3h0AcPnNmzdPgYGB2rx5s/bs2aMbb7zR3l26ogQHB+upp56SJP3yyy+aMWOG7r33Xk2bNk0jR468bP1o0qSJ/vjjD9WuXbtK23388ceXqEfVd/YxPXz4sP79738rOjpaJSUlGj58uJ17Zz4XFxf9+9//LlceFBRk/f9XX31Vx44dU8eOHXX48OEqtb9nzx6FhYXJzc1NjzzyiAIDA3X48GHl5OTo1Vdf1QsvvHDRY0B5TzzxhKZMmaJ+/fpp8ODBqlWrlnbt2qWVK1eqWbNmuuWWWyRJXbt21R9//CFnZ2fT9j1kyBA9+OCDcnFxMa3NilT0ubNixQpNmTKFgAVUAuEKqGH279+vL774QosWLdJjjz2mefPmXfZvui0Wi0pLS+Xq6npZ91tZjRo10sMPP2x9PnToUN1444164403zhmuTp8+LYvFYuofUw4ODtU6Rmb2wSx/PaYxMTFq1qyZ3njjjWsyXNWqVctmvBVZt26dddbK3d29Su2/8cYbOn78uLZs2aImTZrYvJafn1/l/l6M4uJi1alT57Lu0x7y8vI0depUDR8+XG+99ZbNa+np6Tpy5Ij1uaOjo+mfb05OTnJycjK1zbOd/Rl2pX42A1cDTgsEaph58+apXr166tOnj+677z7NmzfP+tqpU6dUv359xcbGltuuqKhIrq6uevrpp61lJSUlSklJ0Y033igXFxcFBATomWeeUUlJic22Dg4Oio+P17x589S2bVu5uLhYT496/fXX1blzZzVo0EBubm4KCQnR+++/X27/f/zxh5544gl5e3vLw8NDffv21aFDh+Tg4FDu29RDhw7pkUcekZ+fn1xcXNS2bVvNnDmz2sfM399frVu31v79+yX975qE119/Xenp6WrevLlcXFy0fft2SdLOnTt13333qX79+nJ1dVVoaKiWLl1art3ff/9dY8aMUWBgoFxcXNS4cWMNHTpUBQUFNvs5+9qH3NxcxcbGqnHjxnJxcVHDhg3Vr1+/C16HkZ+fr0cffVR+fn5ydXVVUFCQZs+ebVPn7HG99dZb1nGFhYXpq6++qvbxq4iPj49atWqlvXv32pRbLBalp6erbdu2cnV1lZ+fnx577DH99ttv5dpYuXKlunXrJg8PD3l6eiosLEwZGRnW1z///HPraXdn3p9jxozRH3/8YepYqqtJkyblrvWqrL1796px48blgpUk+fr6liu70LGSpAULFigkJERubm7y9vbWww8/rEOHDtnUiYmJkbu7u/bu3avevXvLw8NDgwcPllS1n11llJaWavz48QoJCZGXl5fq1Kmj2267TZ9++qlNvaq+b5csWaJ27drJ1dVV7dq1q/Qpv/v375dhGOrSpUu5186cQnxGRddcde/eXe3atdO3336rbt266brrrtONN95o/bxbt26dwsPD5ebmppYtW+qTTz6x2UdF11z9VXWO2V8/w/76uRMTE6MpU6ZYx3nmYRiGAgMD1a9fv3L9OHnypLy8vPTYY4+d95gC1yJmroAaZt68ebr33nvl7Oyshx56SNOmTdNXX32lsLAw1a5dW/fcc48WLVqkGTNm2MyALFmyRCUlJXrwwQcl/fmHVN++fbV+/XqNGDFCrVu31nfffac33nhDP/zwg5YsWWKz3zVr1ui9995TfHy8vL29rRePT5o0SX379tXgwYNVWlqq+fPn6/7779eyZcvUp08f6/YxMTF67733NGTIEN1yyy1at26dzetn5OXl6ZZbbrEGOh8fH61cuVKPPvqoioqKNHr06Cofs1OnTungwYNq0KCBTfmsWbN08uRJjRgxQi4uLqpfv76+//57denSRY0aNVJiYqLq1Kmj9957T/3799fChQt1zz33SJKOHz+u2267TTt27NAjjzyim2++WQUFBVq6dKl+/vlneXt7V9iXAQMG6Pvvv9eoUaMUGBio/Px8rV69WgcOHDjnBfl//PGHunfvrj179ig+Pl5NmzbVggULFBMTo99//11PPvmkTf2MjAwdO3ZMjz32mBwcHPTaa6/p3nvv1b59+6p8iuK5nD59Wj///LPq1atnU/7YY4/p3XffVWxsrJ544gnt379fb775pr755htt2LDBuv93331XjzzyiNq2bauxY8eqbt26+uabb7Rq1SoNGjRI0p9h4cSJE3r88cfVoEEDbd68WZMnT9bPP/+sBQsWmDKO8zkTks+oXbu2vLy8TGm7SZMm+uSTT7RmzRrdcccd561bmWN15piHhYUpNTVVeXl5mjRpkjZs2KBvvvlGdevWtbZ3+vRpRUZG6tZbb9Xrr7+u6667TlLlf3aVVVRUpH//+9966KGHNHz4cB07dkzvvPOOIiMjtXnzZgUHB9vUr8z79uOPP9aAAQPUpk0bpaam6tdff7V+WXEhZ4LsggULdP/991vHXRW//fab7r77bj344IO6//77NW3aND344IOaN2+eRo8erZEjR2rQoEH6v//7P9133306ePCgPDw8Kt1+VY9ZRZ9hFovFps5jjz2mX375RatXr9acOXOs5Q4ODnr44Yf12muv6ejRo6pfv771tQ8//FBFRUUXnL0FrkkGgBrj66+/NiQZq1evNgzDMCwWi9G4cWPjySeftNb56KOPDEnGhx9+aLNt7969jWbNmlmfz5kzx3B0dDQ+//xzm3rTp083JBkbNmywlkkyHB0dje+//75cn06cOGHzvLS01GjXrp1xxx13WMuys7MNScbo0aNt6sbExBiSjJSUFGvZo48+ajRs2NAoKCiwqfvggw8aXl5e5fb3V02aNDF69uxpHDlyxDhy5IixdetW48EHHzQk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X2WOVWhoqHx9fTV9+nSb99HKlSu1Y8eOClfl/KvK/uyqoqKf4aZNm7Rx48YqtyVJDRs2VHBwsGbPnm1zWujq1autt1E4n9zc3ArrlZaWKisrS46Ojna/IbvZx+yMM/cxO9fPcciQIdq+fbv+8Y9/yMnJyea6MqCmYeYKqAGWLl2qY8eOqW/fvhW+fsstt8jHx0fz5s2zhqiBAwdq8uTJSklJUfv27a3X55wxZMgQvffeexo5cqQ+/fRTdenSRWVlZdq5c6fee+89ffTRR9Zv0c+lT58+SktL01133aVBgwYpPz9fU6ZM0Y033qhvv/3WWi8kJEQDBgxQenq6fv31V+tS7D/88IMk229VX3nlFX366acKDw/X8OHD1aZNGx09elQ5OTn65JNPdPTo0Wodw8qaMmWKbr31VrVv317Dhw9Xs2bNlJeXp40bN+rnn3/W1q1bJUn/+Mc/9P777+v+++/XI488opCQEB09elRLly7V9OnTbU7BPOOHH35Qjx499MADD6hNmzaqVauWFi9erLy8vPP+MTNixAjNmDFDMTExys7OVmBgoN5//33rN8xVWer5jB9//FFNmzZVdHS0zX24qqJXr15q166d0tLSFBcXp27duumxxx5TamqqtmzZop49e6p27dravXu3FixYoEmTJum+++6Tp6en3njjDQ0bNkxhYWEaNGiQ6tWrp61bt+rEiROaPXu2WrVqpebNm+vpp5/WoUOH5OnpqYULF17UdWNnlro/332GquLDDz+0vh9OnTqlb7/9Vi+99JIkqW/fvuc9hfXVV19Vdna27r33Xmu9nJwc/ec//1H9+vWttxyozLGqXbu2Xn31VcXGxqpbt2566KGHrEuxBwYGasyYMRccS2V/dtL/ln2fNWuWYmJiztnm3XffrUWLFumee+5Rnz59tH//fk2fPl1t2rTR8ePHK3OIy0lNTVWfPn1066236pFHHtHRo0c1efJktW3b9oJt/vzzz+rYsaPuuOMO9ejRQ/7+/srPz9d///tfbd26VaNHjz7nLRQul0txzKQ/P4Ml6YknnlBkZGS5ANWnTx81aNBACxYsUK9evc557R1QI9hjiUIAl1dUVJTh6upabpnms8XExBi1a9e2LmFusViMgIAAQ5Lx0ksvVbhNaWmp8eqrrxpt27Y1XFxcjHr16hkhISHGCy+8YBQWFlrr6S9L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SEiI5s6da2ZfAAAAAOCqVa2ZqxUrVuijjz4qV/7RRx9p5cqVF90pAAAAALjaVCtcJSYmqqysrFy5YRhKTEy86E4BAAAAwNWmWuFq9+7datOmTbnyVq1aac+ePRfdKQAAAAC42lQrXHl5eWnfvn3lyvfs2aM6depcdKcAAAAA4GpTrXDVr18/jR49Wnv37rWW7dmzR0899ZT69u1rWucAAAAA4GpRrXD12muvqU6dOmrVqpWaNm2qpk2bqlWrVmrQoIFef/11s/sIAAAAAFe8ai3F7uXlpS+++EKrV6/W1q1b5ebmpqCgIN12221m9w8AAAAArgpVmrnauHGjli1bJklycHBQz5495evrq9dff10DBgzQiBEjVFJSckk6CgAAAABXsiqFqxdffFHff/+99fl3332n4cOH684771RiYqI+/PBDpaammt5JAAAAALjSVSlcbdmyRT169LA+nz9/vjp27Ki3335bCQkJ+te//qX33nvP9E4CAAAAwJWuSuHqt99+k5+fn/X5unXr1KtXL+vzsLAwHTx40LzeAQAAAMBVokrhys/PT/v375cklZaWKicnR7fccov19WPHjql27drm9hAAAAAArgJVCle9e/dWYmKiPv/8c40dO1bXXXedzQqB3377rZo3b256JwEAAADgSlelpdgnTJige++9V926dZO7u7tmz54tZ2dn6+szZ85Uz549Te8kAAAAAFzpqhSuvL299dlnn6mwsFDu7u5ycnKyeX3BggVyd3c3tYMAAAAAcDWo9k2EK1K/fv2L6gwAAAAAXK2qdM0VAAAAAKBihCsAAAAAMAHhCgAAAABMQLgCAAAAABMQrgAAAADABIQrAAAAADAB4QoAAAAATEC4AgAAAAATEK4AAAAAwASEKwAAAAAwAeEKAAAAAExAuAIAAAAAExCuAAAAAMAEhCsAAAAAMAHhCgAAAABMQLgCAAAAABMQrgAAAADABIQrAAAAADAB4QoAAAAATEC4AgAAAAAT2D1cTZkyRYGBgXJ1dVV4eLg2b9583vrp6elq2bKl3NzcFBAQoDFjxujkyZM2dQ4dOqSHH35YDRo0kJubm9q3b6+vv/76Ug4DAAAAQA1Xy547z8zMVEJCgqZPn67w8HClp6crMjJSu3btkq+vb7n6GRkZSkxM1MyZM9W5c2f98MMPiomJkYODg9LS0iRJv/32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unXrppycnMs+Rlybzrx3z344OTlJknr16qWXXnpJ99xzT6XbW7p0qf7+97/r/vvvV9OmTRUUFKRHH31UTz/9tLWOxWLRa6+9phtvvFEuLi664YYbbO5nWdnP7Or8nkHN8Pvvv+vzzz/Xq6++qttvv11NmjRRx44dNXbsWPXt21dSxadTv/fee7rtttvk5uamsLAw/fDDD/rqq68UGhoqd3d39erVS0eOHLHu50IzSnPmzFFoaKg8PDzk7++vQYMGKT8/3/r62rVr5eDgoJUrVyokJEQuLi5av369zWmBzz//vGbPnq0PPvjAOru8du1a3XHHHTZ/J0l/ztY5OzvbzHrBXIQrXDZubm4qLS2VJGVlZWnXrl1avXq1li1bplOnTikyMlIeHh76/PPPtWHDBrm7u+uuu+6ybjNt2jTFxcVpxIgR+u6777R06VLdeOONFe7rX//6l5YuXar33ntPu3bt0rx58xQYGFhh3eLiYkVGRqpevXr66quvtGDBAn3yySflPpA+/fRT7d27V59++qlmz56td99995JM9ePat23bNn3xxRfWb9JTU1P1n//8R9OnT9f333+vMWPG6OGHH9a6deskSYcOHVLXrl3l4uKiNWvWKDs7W4888oj1NNtjx44pOjpa69ev15dffqkWLVqod+/eOnbsmN3GCJyLv7+/1qxZY/MH6F+NHTtWr7zyipKTk7V9+3ZlZGTIz89PUuU/s6vzewY1x5mZnyVLlqikpKTS26WkpCgpKUk5OTmqVauWBg0apGeeeUaTJk3S559/rj179mj8+PGVbu/UqVOaMGGCtm7dqiVLlujHH39UTExMuXqJiYl65ZVXtGPHDt100002rz399NN64IEHdNddd+nw4cM6fPiwOnfurGHDhikjI8NmfHPnzlWjRo10xx13VLqPqCIDuASio6ONfv36GYZhGBaLxVi9erXh4uJiPP3000Z0dLTh5+dnlJSUWOvPmTPHaNmypWGxWKxlJSUlhpubm/HRRx8ZhmEY119/vTFu3Lhz7lOSsXjxYsMwDGPUqFHGHXfcYdPeueq+9dZbRr169Yzjx49bX1++fLnh6Oho5ObmWsfTpEkT4/Tp09Y6999/vzFw4MDKHxTUWNHR0YaTk5NRp04dw8XFxZBkODo6Gu+//75x8uRJ47rrrjO++OILm20effRR46GHHjIMwzDG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",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "### Including the similarity score\n",
    "# Adding 'Average Similarity' to the bar chart with softer colors and three decimal points precision\n",
    "\n",
    "# Updated data including Average Similarity\n",
    "average_similarity = 0.925  # Updated value for average similarity\n",
    "metrics = ['Precision', 'Recall', 'F1 Score', 'Similarity']\n",
    "average_scores = [average_precision, average_recall, average_f1_score, average_similarity]\n",
    "\n",
    "# Create bar chart with updated data and softer colors\n",
    "plt.figure(figsize=(10, 6))\n",
    "bars = plt.bar(metrics, average_scores, color=['lightblue', 'lightcoral', 'lightgreen', 'lightpink'])\n",
    "\n",
    "# Add the data values on the bars with 3 decimal points\n",
    "for bar in bars:\n",
    "    yval = bar.get_height()\n",
    "    plt.text(bar.get_x() + bar.get_width()/2, yval + 0.001, f\"{yval:.3f}\", ha='center', va='bottom')\n",
    "\n",
    "# Title and labels\n",
    "plt.title('Average Precision, Recall, F1 Score, and Similarity')\n",
    "plt.ylabel('Score')\n",
    "plt.ylim([0.8, 0.95])  # Adjusted y limit to accommodate the new data\n",
    "\n",
    "# Display the bar chart\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Comparison with baselines:\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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3Rrp6elo3LgxTExM0LdvX332jYiIiKjCKjXn5u7duxg1ahTMzMzQokULXL58GQAwbtw4zJs3T68dJCIiIqqISoWbqKgoHD9+HCkpKVoTiP39/ZGQkKC3zhERERFVVKUuS23fvh0JCQno0KEDFAqFVN6iRQtcvHhRb50jIiIiqqhKjdzk5OSgbt26pcrz8/O1wg4RERFRVatUuPH29sbOnTul9yWBZs2aNfD19dVPz4iIiIgqoVKXpebOnYugoCD88ccfKCoqwuLFi/HHH3/g4MGD+Pnnn/XdRyIiIqJyq9TITefOnXH8+HEUFRWhVatW+OGHH1C3bl2kpqbCy8tL330kIiIiKrcKj9zcv38fb731FqZNm4bVq1c/iz4RERERVVqFR25q1KiBr7/++ln0hYiIiOipVeqy1MCBA7F9+3Y9d4WIiIjo6VVqQnGTJk0wa9YsHDhwAF5eXjA3N9daPn78eL10joiIiKiiKhVu4uLiYGVlhSNHjuDIkSNayxQKBcMNERERGUylwk16erq++0FERESkF5Wac/MwIQSEEProCxEREdFTq3S4+eKLL9CqVSuYmprC1NQUrVu3xoYNG/TZNyIiIqIKq9RlqdjYWEybNg0RERHo1KkTAGD//v14++23cf36dbz77rt67SQRERFReVUq3Hz++edYvnw5QkJCpLKXXnoJLVq0wIwZMxhuiIiIyGAqdVnq2rVr6NixY6nyjh074tq1a0/dKSIiIqLKqlS4cXV1xVdffVWqPCEhAU2aNHnqThERERFVVqUuS82cORPBwcHYu3evNOfmwIEDSEpK0hl6iIiIiKpKpUZuXnnlFfz666+wsbHB9u3bsX37dtjY2ODQoUMYNGiQvvtIREREVG6VGrkBAC8vL2zcuFGffSEiIiJ6apUaudm1axd2795dqnz37t3473//+9SdIiIiIqqsSoWbyZMno7i4uFS5EAKTJ09+6k4RERERVValws358+fh7u5eqtzNzQ0XLlyocHtLly6Fi4sL1Go12rdvj0OHDpVrvS1btkChUGDgwIEV3iYRERHJU6XCjaWlJf78889S5RcuXIC5uXmF2kpISEBkZCSio6Nx9OhReHh4ICAgANnZ2Y9dLyMjA++//z66dOlSoe0RERGRvFUq3AwYMAATJ07ExYsXpbILFy7gvffew0svvVShtmJjYxEeHo6w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02t7RFR5Br8stXTpUri4uECtVqN9+/Y4dOhQmXVPnTqFV155BS4uLlAoFFi0aFHVdZSIiIieCwYNNwkJCYiMjER0dDSOHj0KDw8PBAQEIDs7W2f9u3fvolGjRpg3bx7s7e2ruLdERET0PDBouImNjUV4eDjCwsLg7u6OFStWwMzMDPHx8Trrt2vXDp988glee+01qFSqKu4tERERPQ8MFm4KCwtx5MgR+Pv7/68zRkbw9/dHamqq3rZTUFCAvLw8rRcRERHJl8HCzfXr11FcXAw7Ozutcjs7O2RmZuptOzExMbC0tJReTk5OemubiIiIqh+DTyh+1qKiopCbmyu9rly5YuguERER0TNksFvBbWxsYGxsjKysLK3yrKwsvU4WVqlUnJ9DRET0AjHYyI1SqYSXlxeSkpKkMo1Gg6SkJPj6+hqqW0RERPScM+hD/CIjIxEaGgpvb2/4+Phg0aJFyM/PR1hYGAAgJCQEjo6OiImJAfBgEvIff/wh/f/ff/+NY8eOwcLCAq6urgbbDyIiIqo+DBpugoODkZOTg+nTpyMzMxOenp5ITEyUJhlfvnwZRkb/G1y6evUq2rRpI71fsGABFixYAD8/P6SkpFR194mIiKgaMvjXL0RERCAiIkLnskcDi4uLC4QQVdArIiIiel7J/m4pIiIierEw3BAREZGsMNwQERGRrDDcEBERkawYfEIxEVG5zLDUb3sNG+i3PSKqNjhyQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESywnBDREREssJwQ0RERLLCcENERESyUi3CzdKlS+Hi4gK1Wo327dvj0KFDj62/detWuLm5Qa1Wo1WrVti1a1cV9ZSIiIiqO4OHm4SEBERGRiI6OhpHjx6Fh4cHAgICkJ2drbP+wYMHMXToUIwaNQq///47Bg4ciIEDB+LkyZNV3HMiIiKqjgwebmJjYxEeHo6wsDC4u7tjxYoVMDMzQ3x8vM76ixcvRmBgIP7zn/+gefPmmD17Ntq2bYslS5ZUcc+J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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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sbGxMXco4g7JOazc5PxVfnIOK7/Kfg7vu8bXQgghhBBFkRojIYQQQog8khgJIYQQQuSRxEgIIYQQIo8kRkIIIYQQeSQxEkIIIYTIU6UTozFjxjB48GCT9bt370aj0fD5559jb2/PyZMnjbZfuHCBGjVq8MEHHwAQHx/P5MmTadSoETY2Nnh5eTFw4EB27txptN++ffvo168fNWrUwNbWljZt2vDee++Rm5trVE6j0aDRaNi/f7/R+szMTFxdXdFoNOzevdukvEajwdLSknr16jF9+nQyMzPv4t2p2Er7ni9cuBALCwuWLFlicozg4GA0Gg19+vQxWp+cnFzoe2xra8uZM2eMyg4ePJgxY8YY/j9mzBij8+Hq6kqfPn2IjIw02k8pxZo1a+jYsSMODg5Ur16d9u3bs3z5cjIyMgB44403jI6V//j111/v5C2rVLp37860adNM1gcHB1O9evUyf/5t27bRvXt3nJ2dcXBwoG3btsyfP5+kpCRDHIWdm08++aTMY6ssCn6/FnU+y5KcQ2P5303PP/+8ybaJEyei0WiMvstK8x3boEGDQq9V06ZNo3v37ob/53+X3frcERERaDQaTp8+XWTc+dfj5OTkQrcX/J60tLTEzc2Nrl27snz58iKvgc899xwWFhZ89dVXRT5vcap0YlSSgQMHEhgYyJgxY9DpdIb148ePp127dkycOJHTp0/Trl07fvvtN5YsWUJUVBQhISH06NGDiRMnGvb59ttv6datG3Xr1mXXrl0cO3aMqVOnsmDBAp544gmT2YC9vLzYsGGD0bpvv/0WBweHQmPdsGEDFy9eJC4ujtWrV/P555+zYMGCe/huVBylfc8B1q9fz6uvvsr69esLPZalpSW//voru3btKvF5NRoNc+bMKbFcnz59uHjxIhcvXmTnzp1YWloyYMAAozJPP/0006ZNY9CgQezatYuIiAhmz57N999/z88//2wo16pVK8Ox8h9du3YtMQZx+7KzswGYOXMmw4cPp0OHDvzf//0ff/31F++++y5Hjx7l888/N5R3cnIyOTdPPfWUucIXBcg5LJyXlxdbtmzh+vXrhnU3btxg06ZN1KtXz7Dudr5jbW1tee2110p8bltbW9atW0dsbOy9e0F58r8nz549y65duxg6dCgLFy6kS5cuhonh82VkZLBly5ZirwslUlXY6NGj1aBBg0zW79q1SwHq6tWrKiEhQbm7u6slS5YopZTasGGDcnZ2VmfPnlVKKdW3b19Vp04dlZ6ebnKcq1evKqWUSk9PV66urmrIkCEmZX744QcFqC1bthjWAWrWrFnKyclJZWRkGNb36tVLzZ49WwFq165dRuW//fZbo+M+88wzql+/fqV9KyqV0rznSim1e/duVadOHZWVlaVq166t/vzzT6Oy+edy/PjxKiAgwOgYhb3HL7/8stJqtSoqKsqwftCgQWr06NGG/xf2mdq7d68CVEJCglJKqa1btypAfffddybx63Q6lZycrJRSau7cucrHx6ekt6NK6tatm5o6darJ+vxzppT+77RDhw7Kzs5OOTs7qy5duqjTp08byn733XfKz89P2djYqIYNG6o33nhDZWdnG7YDavXq1WrgwIHKzs5OzZ07Vx04cEABavny5YXGlf/5KhiHKFz+38Lo0aMVYPSIi4tTSikVFRWl+vTpo+zt7ZWHh4caOXKkunz5suEY3bp1U5MmTVJTp05V1atXVx4eHmrNmjUqPT1djRkzRjk4OKjGjRur7du3G/aRc1i4/PPRunVr9cUXXxjWb9y4UbVt29bou6y037H169dXU6ZMUdbW1uqnn34yrJ86darq1q2b4f/532W9evVSQ4cONawPDw83+jwUpuD1uDBFfU/GxMQoa2trNXPmTKP1wcHBqlOnTio5OVnZ2dkZruW3476uMQJwd3dnzZo1zJ49m19++YUXX3yRFStW4OXlRVJSEiEhIUycOBF7e3uTffOr/H/++WcSExN5+eWXTcoMHDgQb29vNm/ebLS+Xbt2NGjQgG3btgFw9uxZ9uzZw9NPP11izCdOnOC3336jY8eOd/CKK7bSvucA69atY8SIEVhZWTFixAjWrVtX6DHfeOMNoqKi+Prrr4t97gceeIABAwYwY8aMUsebnp7OF198QZMmTXB1dQVg48aNNGvWjEGDBpmU12g05TIJYmWXk5PD4MGD6datG5GRkYSGhvLss8+i0WgA2Lt3L6NGjWLq1Kn8/ffffPzxxwQHB/PWW28ZHeeNN97gscceIyoqinHjxrFx40YcHBx44YUXCn3e8riNV9WsWLGCzp07M378eEOtjJeXF8nJyTz88MP4+flx+PBhQkJCuHTpEsOGDTPa/9NPP8XNzY2DBw8yefJkJkyYwNChQ+nSpQth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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "# User provided results\n",
    "user_results = {\n",
    "    'Precision': 0.82,\n",
    "    'Recall': 0.83,\n",
    "    'F1 Score': 0.82\n",
    "}\n",
    "\n",
    "# Baseline methods results\n",
    "baseline_results = {\n",
    "    'CANNBCF': {'Precision': 0.53, 'Recall': 0.53, 'F1 Score': 0.53},\n",
    "    'UserCF': {'Precision': 0.235, 'Recall': 0.074},  # F1 Score needs to be calculated\n",
    "    'ItemCF': {'Precision': 0.357, 'Recall': 0.113},  # F1 Score needs to be calculated\n",
    "    'MCNN-LDA': {'Precision': 0.6753, 'Recall': 0.6238, 'F1 Score': 0.6485}\n",
    "}\n",
    "\n",
    "# Function to calculate F1 Score\n",
    "def calculate_f1_score(precision, recall):\n",
    "    return 2 * (precision * recall) / (precision + recall) if (precision + recall) != 0 else 0\n",
    "\n",
    "# Calculate missing F1 Scores\n",
    "baseline_results['UserCF']['F1 Score'] = calculate_f1_score(baseline_results['UserCF']['Precision'], baseline_results['UserCF']['Recall'])\n",
    "baseline_results['ItemCF']['F1 Score'] = calculate_f1_score(baseline_results['ItemCF']['Precision'], baseline_results['ItemCF']['Recall'])\n",
    "\n",
    "# Data for plotting\n",
    "labels = ['HYCOMB', 'CANNBCF', 'UserCF', 'ItemCF', 'MCNN-LDA']\n",
    "precision_scores = [user_results['Precision']] + [results['Precision'] for results in baseline_results.values()]\n",
    "recall_scores = [user_results['Recall']] + [results['Recall'] for results in baseline_results.values()]\n",
    "f1_scores = [user_results['F1 Score']] + [results['F1 Score'] for results in baseline_results.values()]\n",
    "\n",
    "x = np.arange(len(labels))  # the label locations\n",
    "\n",
    "# Bar chart\n",
    "fig, ax = plt.subplots()\n",
    "rects1 = ax.bar(x - 0.2, precision_scores, 0.2, label='Precision')\n",
    "rects2 = ax.bar(x, recall_scores, 0.2, label='Recall')\n",
    "rects3 = ax.bar(x + 0.2, f1_scores, 0.2, label='F1 Score')\n",
    "\n",
    "# Add some text for labels, title and custom x-axis tick labels, etc.\n",
    "ax.set_ylabel('Scores')\n",
    "ax.set_title('Scores by group and metric')\n",
    "ax.set_xticks(x)\n",
    "ax.set_xticklabels(labels)\n",
    "ax.legend()\n",
    "\n",
    "# Line graph\n",
    "fig2, ax2 = plt.subplots()\n",
    "ax2.plot(labels, precision_scores, marker='o', label='Precision')\n",
    "ax2.plot(labels, recall_scores, marker='s', label='Recall')\n",
    "ax2.plot(labels, f1_scores, marker='^', label='F1 Score')\n",
    "\n",
    "# Add some text for labels, title and custom x-axis tick labels, etc.\n",
    "ax2.set_ylabel('Scores')\n",
    "ax2.set_title('Scores by group and metric')\n",
    "ax2.set_xticks(x)\n",
    "ax2.set_xticklabels(labels)\n",
    "ax2.legend()\n",
    "\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Baseline - Thesis"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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WT344IMKDw/P8HXtrIg777xTNptNv//+e7bXUbRoUXXp0kWxsbE6cuSI2rVrp/HjxyslJSXT+WbdVwAAwHzogW+ssPXAvr6+io6O1q5du/Tpp59Kkv3TZ35+fpn2uuHh4fL09FTp0qXl5+d3yz8ALF26VM2bN9ecOXPUtWtXtWrVSuHh4Rlu3AagYCC0BeAUL7zwgooWLaonnnhCJ0+ezPD4wYMHNXXqVElS27ZtJV29S+v1rp1t2a5dO6fXN23aNPu/DcPQtGnT5OnpqQcffFDS1b/eWywWh48YHTp0SCtWrMjxOtPT05WYmOgwVqZMGZUrV87+0bMGDRqoTJkymjVrlsPH0b788kvt2bPHafsiPDxcXl5eevfddx3OwpgzZ44SExNzZZ9nRefOnXXs2DF98MEHGR77559/lJycLEmKjIyUm5ubxo0bl+EsgpudVXLmzBmH7728vFSzZk0ZhmG/W/C/mXVfAQAA86EHzqgw98A9evRQhQoVNHHiRElSaGio7rzzTr311lu6ePFihvkJCQmSrl7KIjIyUp9//rl++umnDPOu1e7u7p6h912yZImOHTvm1O0AYA5cHgGAU9x5551auHChunTpoho1aqh3796qXbu20tLS9N1332nJkiXq06ePJKlu3bqKiorS+++/r/PnzyssLEzbtm3T/PnzFRkZqebNmzu1Nm9vb61Zs0ZRUVFq1KiRvvzyS61evVovv/yy/dpY7dq109tvv63WrVure/fuOnXqlKZPn64qVark+NqkFy5cUIUKFfTYY4+pbt268vX11fr16/Xjjz9q8uTJkiRPT09NnDhRffv2VVhYmLp166aTJ09q6tSpCgkJ0dChQ52yD0qXLq2RI0dq7Nixat26tR566CHt27dPM2bM0L333utwI6281KtXL3366acaMGCANm7cqCZNmig9PV179+7Vp59+qq+++koNGjRQlSpV9Morr+i1115T06ZN9eijj8pqterHH39UuXLlFBMTk+nzt2rVSkFBQWrSpIkCAwO1Z88eTZs2Te3atbvhTUPMuq8AAID50ANnVJh7YE9PTw0ZMkTPP/+81qxZo9atW+vDDz9UmzZtVKtWLfXt21fly5fXsWPHtHHjRvn5+enzzz+XdPXSB2vXrlVYWJiefPJJ1ahRQ8ePH9eSJUu0ZcsWBQQEqH379ho3bpz69u2r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xcTEZDpXknbv3q0WLVrIx8dHJUuW1JNPPqmLFy/aH79W81tvvaWyZcuqZMmSGjRo0G3dRRcAAACFz7UeOTg4WJGRkQoPD9e6deskSTabTTExMapUqZJ8fHxUt25dLV261GH53377Te3bt5efn5+KFSumpk2b6uDBg5KkH3/8US1btlSpUqXk7++vsLAw7dixI8+38d8IbQEAAEzMx8dHaWlpkqS4uDjt27dP69at06pVq3T58mVFRESoWLFi2rx5s7799lv5+vqqdevW9mVmzpypQYMG6cknn9Tu3bu1cuVKValSJdN1vfvuu1q5cqU+/fRT7du3TwsWLFBISEimc5OTkxUREaHixYvrxx9/1JIlS7R+/XqHQFiSNm7cqIMHD2rjxo2aP3++5s2bp3nz5jlt/wAAAKBw+fXXX/Xdd9/ZP3UWExOjjz76SLNmzdJvv/2moUOHqmfPnvr6668lSceOHVOzZs1ktVq1YcMGbd++Xf369bNfguzChQuKiorSli1b9P3336tq1apq27atLly44LJtlLg8AgAAgCkZhqG4uDh99dVXeuaZZ5SQkKCiRYvqww8/tDeo//3vf2Wz2fThhx/K8v+vDxYbG6uAgABt2rRJrVq10uuvv67hw4dryJAh9ue+9957M13nkSNHVLVqVf3nP/+RxWJRxYoVb1jfwoULlZKSoo8++khFixaVJE2bNk0dOnTQxIkTFRgYKEkqXry4pk2bJnd3d1WvXl3t2rVTXFyc+vfv75T9BAAAgIJv1apV8vX11ZUrV5Samio3NzdNmzZNqampmjBhgtavX6/GjRtLkipXrqwtW7Zo9uzZCgsL0/Tp0+Xv769FixbJ09NTknTXXXfZn7tFixYO63r//fcVEBCgr7/+Wu3bt8+7jfwXQlsAAAATudaQXr58WTabTd27d9eYMWM0aNAg1alTx+E6tj///LP++OMPFStWzOE5UlJSdPDgQZ06dUp///23HnzwwSytu0+fPmrZsqWqVaum1q1bq3379mrVqlWmc/fs2aO6devaA1tJatKkiWw2m/bt22cPbWvVqiV3d3f7nLJly2r37t1Z3h8AAABA8+bNNXPmTCUnJ+udd96Rh4eHOnbsqN9++02XLl1Sy5YtHeanpaWpfv36kqRdu3apadOm9sD2306ePKlXX31VmzZt0qlTp5Senq5Lly7pyJEjub5dN0NoCwAAYCLXGlIvLy+VK1dOHh7/a9euD0gl6eLFiwoNDdWCBQsyPE/p0qXl5pa9K2Hdc889io+P15dffqn169erc+fOCg8Pz3BNsOz4d3NssVhks9ly/HwAAAAofIoWLWq/xNfcuXNVt25dzZkzR7Vr15YkrV69WuXLl3dYxmq1Srp6ubGbiYqK0pkzZzR16lRVrFhRVqtVjRs3tl9uzFUIbQEAAEzk+ob0Vu655x4tXrxYZcqUkZ+fX6ZzQkJCFBcXp+bNm2fpOf38/NSlSxd16dJFjz32mFq3bq2zZ8+qRIkSDvNq1KihefPmKTk52R4mf/vtt3Jzc7PfJA0AAABwNjc3N7388ssaNmyY9u/fL6vVqiNHjigsLCzT+Xfffbfmz5+vy5cvZ3q27bfffqsZM2aobdu2kq7e6Pf06dO5ug1ZwY3IAAAA8qkePXqoVKlSevjhh7V582bFx8dr06ZNevbZZ/XXX39JksaMGaPJkyfr3Xff1YEDB7Rjxw699957mT7f22+/rU8++UR79+7V/v37tWTJEgUFBSkgICDTdXt7eysqKkq//vqrNm7cqGeeeUa9evWyXxoBAAAAyA2dOnWSu7u7Zs+erREjRmjo0KGaP3++Dh48aO9358+fL0kaPHiwkpKS1LVrV/300086cOCAPv74Y+3bt0+SVLVqVX388cfas2ePfvjhB/Xo0eOWZ+fmBUJbAACAfKpIkSL65ptvdMcdd+jRRx9VjRo19PjjjyslJcV+5m1UVJSmTJmiGTNmqFatWmrfvr0OHDiQ6fMVK1ZMkyZNUoMGDXTvvffq0KFD+uKLLzK9zEKRIkX01Vdf6ezZs7r33nv12GOP6cEHH9S0adNydZsBAAAADw8PDR48WJMmTdLIkSM1atQoxcTEqEaNGmrdurVWr16tSpUqSZJKliypDRs26OLFiwoLC1NoaKg++OAD+1m3c+bM0blz53TPPfeoV69eevbZZ1WmTBlXbp4kyWIYhuHqIvJSUlKS/P39lZiYeMOPEQIAgPwtJSVF8fHxqlSpkry9vV1dDrLpZsePXu4q9gMAAMgueuS844x+ljNtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAQIFlGIarS0AO2Gw2V5cAAABQYNEj5z5n9LMeTqgDAADAVDw9PWWxWJSQkKDSpUvLYrG4uiRkgWEYSktLU0JCgtzc3OTl5eXqkgAAAAoMeuTc58x+ltAWAAAUOO7u7qpQoYL++usvHTp0yNXlIJuKFCmiO+64Q25ufCgMAADAWeiR844z+llCWwAAUCD5+vqqatWqunz5sqtLQTa4u7vLw8ODMz8AAAByAT1y7nNWP0toCwAACix3d3e5u7u7ugwAAADANOiR8wc+cwYAAAAAAAAAJkJoCwAAAAAAAAAmQmgLAAAAAAAAACZCaAsAAAAAAAAAJkJoCwAAAAAAAAAmQmgLAAAAAAAAACZCaAsAAAAAAAAAJkJoCwAAAAAAAAAmQmgLAAAAAAAAACZCaAsAAAAAAAAAJkJoCwAAAAAAAAAmQmgLAAAAAAAAACZCaAsAAAAAAAAAJkJoCwAAAAAAAAAmQmgLAAAAAAAAACZCaAsAAAAAAAAAJkJoCwAAAAAAAAAmQmgLAAAAAAAAACZCaAsAAAAAAAAAJkJoCwAAAAAAAAAmQmgLAAAAAAAAACZCaAsAAAAAAAAAJkJoCwAAAAAAAAAmQmgLAAAAAAAAACZCaAsAAAAAAAAAJkJoCwAAAAAAAAAmQmgLAAAAAAAAACZCaAsAAAAAAAAAJkJoCwAAAAAAAAAmQmgLAAAAAAAAACZCaAsAAAAAAAAAJkJoCwAAAAAAAAAmQmgLAAAAAAAAACZCaAsAAAAAAAAAJuLh6gIAAAAAAAAAU7NYXF0BcpNhuLqCDDjTFgAAAAAAAABMhNAWAAAAAAAAAEyE0BYAAAAAAAAATIRr2gIAgHyPS4y5jgkv/wUAAADke5xpCwAAAAAAAAAmQmgLAAAAAAAAACZCaAsAAAAAAAAAJuLy0Hb69OkKCQmRt7e3GjVqpG3btt10/pQpU1StWjX5+PgoODhYQ4cOVUpKSh5VCwAAAGRETwsAAABncmlou3jxYg0bNkzR0dHasWOH6tatq4iICJ06dSrT+QsXLtRLL72k6Oho7dmzR3PmzNHixYv18ssv53HlAAAAwFX0tAAAAHA2l4a2b7/9tvr376++ffuqZs2amjVrlooUKaK5c+dmOv+7775TkyZN1L17d4WEhKhVq1bq1q3bLc9kAAAAAHILPS0AAACczWWhbVpamrZv367w8PD/FePmpvDwcG3dujXTZe6//35t377d3tD++eef+uKLL9S2bdsbric1NVVJSUkOXwAAAIAz0NMCAAAgN3i4asWnT59Wenq6AgMDHcYDAwO1d+/eTJfp3r27Tp8+rf/85z8yDENXrlzRgAEDbvpRspiYGI0dO9aptQMAAAASPS0AAAByh8tvRJYdmzZt0oQJEzRjxgzt2LFDy5cv1+rVq/Xaa6/dcJmRI0cqMTHR/nX06NE8rBgAAABwRE8LAACAW3HZmbalSpWSu7u7Tp486TB+8uRJBQUFZbrMqFGj1KtXLz3xxBOSpDp16ig5OVlPPvmkXnnlFbm5ZcygrVarrFar8zcAAAAAhR49LQAAAHKDy8609fLyUmhoqOLi4uxjNptNcXFxaty4cabLXLp0KUMT6+7uLkkyDCP3igUAAAAyQU8LAACA3OCyM20ladiwYYqKilKDBg3UsGFDTZkyRcnJyerbt68kqXfv3ipfvrxiYmIkSR06dNDbb7+t+vXrq1GjRvrjjz80atQodejQwd7oAgAAAHmJnhYAAADO5tLQtkuXLkpISNDo0aN14sQJ1atXT2vWrLHfyOHIkSMOZyG8+uqrslgsevXVV3Xs2DGVLl1aHTp00Pjx4121CQAAACjk6GkBAADgbBajkH0GKykpSf7+/kpMTJSfn5+rywEAAE5gsbi6gsIrrztJermr2A8AAOQxGs6CLQ+b2qz2cS67pi0AAAAAAAAAICNCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBFCWwAAAAAAAAAwEUJbAAAAAAAAADARQlsAAAAAAAAAMBGXh7bTp09XSEiIvL291ahRI23btu2m88+fP69BgwapbNmyslqtuuuuu/TFF1/kUbUAAABARvS0AAAAcCYPV6588eLFGjZsmGbNmqVGjRppypQpioiI0L59+1SmTJkM89PS0tSyZUuVKVNGS5cuVfny5XX48GEFBATkffEAAACA6GkBAADgfBbDMAxXrbxRo0a69957NW3aNEmSzWZTcHCwnnnmGb300ksZ5s+aNUtvvvmm9u7dK09PzxytMykpSf7+/kpMTJSfn99t1Q8AAMzBYnF1BYVXXneSZuzl6GkBACgEaDgLtjxsarPax7ns8ghpaWnavn27wsPD/1eMm5vCw8O1devWTJdZuXKlGjdurEGDBikwMFC1a9fWhAkTlJ6efsP1pKamKikpyeELAAAAcAZ6WgAAAOQGl4W2p0+fVnp6ugIDAx3GAwMDdeLEiUyX+fPPP7V06VKlp6friy++0KhRozR58mS9/vrrN1xPTEyM/P397V/BwcFO3Q4AAAAUXvS0AAAAyA0uvxFZdthsNpUpU0bvv/++QkND1aVLF73yyiuaNWvWDZcZOXKkEhMT7V9Hjx7Nw4oBAAAAR/S0AAAAuBWX3YisVKlScnd318mTJx3GT548qaCgoEyXKVu2rDw9PeXu7m4fq1Gjhk6cOKG0tDR5eXllWMZqtcpqtTq3eAAAAED0tAAAAMgdLjvT1svLS6GhoYqLi7OP2Ww2xcXFqXHjxpku06RJE/3xxx+y2Wz2sf3796ts2bKZNrcAAABAbqKnBQAAQG5w6eURhg0bpg8++EDz58/Xnj17NHDgQCUnJ6tv376SpN69e2vkyJH2+QMHDtTZs2c1ZMgQ7d+/X6tXr9aECRM0aNAgV20CAAAACjl6WgAAADibyy6PIEldunRRQkKCRo8erRMnTqhevXpas2aN/UYOR44ckZvb/3Ll4OBgffXVVxo6dKjuvvtulS9fXkOGDNGLL77oqk0AAABAIUdPCwAAAGezGIZhuLqIvJSUlCR/f38lJibKz8/P1eUAAAAnsFhcXUHhldedJL3cVewHAADyGA1nwZaHTW1W+ziXXh4BAAAAAAAAAOCI0BYAAAAAAAAATITQFgAAAAAAAABMhNAWAAAAAAAAAEyE0BYAAAAAAAAATITQFgAAAAAAAABMxCMnC6Wnp2vevHmKi4vTqVOnZLPZHB7fsGGDU4oDAAAAAAAAgMImR6HtkCFDNG/ePLVr1061a9eWxWJxdl0AAAAAAAAAUCjlKLRdtGiRPv30U7Vt29bZ9QAAAAAAAABAoZaja9p6eXmpSpUqzq4FAAAAAAAAAAq9HIW2w4cP19SpU2UYhrPrAQAAAAAAAIBCLUeXR9iyZYs2btyoL7/8UrVq1ZKnp6fD48uXL3dKcQAAAAAAAABQ2OQotA0ICNAjjzzi7FoAAAAAAAAAoNDLUWgbGxvr7DoAAAAAAAAAAMphaHtNQkKC9u3bJ0mqVq2aSpcu7ZSiAAAAAAAAAKCwytGNyJKTk9WvXz+VLVtWzZo1U7NmzVSuXDk9/vjjunTpkrNrBAAAAAAAAIBCI0dn2g4bNkxff/21Pv/8czVp0kTS1ZuTPfvssxo+fLhmzpzp1CIBAAAAZ/jll1+yPPfuu+/OxUoAAACAG8tRaLts2TItXbpUDzzwgH2sbdu28vHxUefOnQltAQAAYEr16tWTxWKRYRiZPn7tMYvFovT09DyuDgAAALgqR6HtpUuXFBgYmGG8TJkyXB4BAAAAphUfH+/qEgAAAIBbylFo27hxY0VHR+ujjz6St7e3JOmff/7R2LFj1bhxY6cWCAAAADhLxYoVXV0CAAAAcEs5Cm2nTp2qiIgIVahQQXXr1pUk/fzzz/L29tZXX33l1AIBAAAAZ1m5cmWW5z700EO5WAkAAABwYzkKbWvXrq0DBw5owYIF2rt3rySpW7du6tGjh3x8fJxaIAAAAOAskZGRWZrHNW0BAADgSjkKbSWpSJEi6t+/vzNrAQAAAHKVzWZzdQkAAADALWU5tF25cqXatGkjT0/PW36sjI+SAQAAAAAAAEDOZDm0jYyM1IkTJ1SmTJmbfqyMj5IBAAAgv0hOTtbXX3+tI0eOKC0tzeGxZ5991kVVAQAAoLDLcmh7/UfJ+FgZAAAA8rudO3eqbdu2unTpkpKTk1WiRAmdPn1aRYoUUZkyZQhtAQAA4DJuznqi8+fPO+upAAAAgFw3dOhQdejQQefOnZOPj4++//57HT58WKGhoXrrrbdcXR4AAAAKsRyFthMnTtTixYvt33fq1EklSpRQ+fLl9fPPPzutOAAAACC37Nq1S8OHD5ebm5vc3d2Vmpqq4OBgTZo0SS+//LKrywMAAEAhlqPQdtasWQoODpYkrVu3TuvXr9eaNWvUpk0bPf/8804tEAAAAMgNnp6ecnO72g6XKVNGR44ckST5+/vr6NGjriwNAAAAhVyWr2l7vRMnTthD21WrVqlz585q1aqVQkJC1KhRI6cWCAAAAOSG+vXr68cff1TVqlUVFham0aNH6/Tp0/r4449Vu3ZtV5cHAACAQixHZ9oWL17cfvbBmjVrFB4eLkkyDEPp6enOqw4AAADIJRMmTFDZsmUlSePHj1fx4sU1cOBAJSQkaPbs2S6uDgAAAIVZjs60ffTRR9W9e3dVrVpVZ86cUZs2bSRdvQNvlSpVnFogAAAAkBsaNGhg/3eZMmW0Zs0aF1YDAAAA/E+OQtt33nlHISEhOnr0qCZNmiRfX19J0vHjx/X00087tUAAAAAgN8THx+vKlSuqWrWqw/iBAwfk6empkJAQ1xQGAACAQi9Hoa2np6dGjBiRYXzo0KG3XRAAAACQF/r06aN+/fplCG1/+OEHffjhh9q0aZNrCgMAAEChl+XQduXKlWrTpo08PT21cuXKm8596KGHbrswAAAAIDft3LlTTZo0yTB+3333afDgwS6oCAAAALgqy6FtZGSkTpw4oTJlyigyMvKG8ywWCzcjAwAAgOlZLBZduHAhw3hiYiL9LAAAAFzKLasTbTabypQpY//3jb5ocAEAAJAfNGvWTDExMQ79a3p6umJiYvSf//zHhZUBAACgsMvRNW0BAACA/G7ixIlq1qyZqlWrpqZNm0qSNm/erKSkJG3YsMHF1QEAAKAwy/KZttd79tln9e6772YYnzZtmp577rnbrQkAAADIdTVr1tQvv/yizp0769SpU7pw4YJ69+6tvXv3qnbt2q4uDwAAAIWYxTAMI7sLlS9fXitXrlRoaKjD+I4dO/TQQw/pr7/+clqBzpaUlCR/f38lJibKz8/P1eUAAAAnsFhcXUHhlf1O8vbQy13FfgAAII/RcBZsedjUZrWPy9GZtmfOnJG/v3+GcT8/P50+fTonTwkAAADkuc2bN6tnz566//77dezYMUnSxx9/rC1btri4MgAAABRmOQptq1SpojVr1mQY//LLL1W5cuXbLgoAAADIbcuWLVNERIR8fHy0Y8cOpaamSpISExM1YcIEF1cHAACAwixHNyIbNmyYBg8erISEBLVo0UKSFBcXp8mTJ2vKlCnOrA8AAADIFa+//rpmzZql3r17a9GiRfbxJk2a6PXXX3dhZQAAACjschTa9uvXT6mpqRo/frxee+01SVJISIhmzpyp3r17O7VAAAAAIDfs27dPzZo1yzDu7++v8+fP531BAAAAwP+Xo9BWkgYOHKiBAwcqISFBPj4+8vX1dWZdAAAAQK4KCgrSH3/8oZCQEIfxLVu2cMkvAAAAuFSOrmkrSVeuXNH69eu1fPlyGf//Dmt///23Ll686LTiAAAAgNzSv39/DRkyRD/88IMsFov+/vtvLViwQMOHD9fAgQNdXR4AAAAKsRydaXv48GG1bt1aR44cUWpqqlq2bKlixYpp4sSJSk1N1axZs5xdJwAAAOBUL730kmw2mx588EFdunRJzZo1k9Vq1fPPP68nnnjC1eUBAACgEMvRmbZDhgxRgwYNdO7cOfn4+NjHH3nkEcXFxTmtOAAAACC3WCwWvfLKKzp79qx+/fVXff/990pISJC/v78qVark6vIAAABQiOXoTNvNmzfru+++k5eXl8N4SEiIjh075pTCAAAAgNyQmpqqMWPGaN26dfYzayMjIxUbG6tHHnlE7u7uGjp0qKvLBAAAQCGWo9DWZrMpPT09w/hff/2lYsWK3XZRAAAAQG4ZPXq0Zs+erfDwcH333Xfq1KmT+vbtq++//16TJ09Wp06d5O7u7uoyAQAAUIjl6PIIrVq10pQpU+zfWywWXbx4UdHR0Wrbtq2zagMAAACcbsmSJfroo4+0dOlSrV27Vunp6bpy5Yp+/vlnde3alcAWAAAALpejM23feusttW7dWjVr1lRKSoq6d++uAwcOqFSpUvrkk0+cXSMAAADgNH/99ZdCQ0MlSbVr15bVatXQoUNlsVhcXBkAAABwVY5C2+DgYP38889avHixfv75Z128eFGPP/64evTo4XBjMgAAAMBs0tPTHe7N4OHhIV9fXxdWBAAAADjKdmh7+fJlVa9eXatWrVKPHj3Uo0eP3KgLAAAAyBWGYahPnz6yWq2SpJSUFA0YMEBFixZ1mLd8+XJXlAcAAABkP7T19PRUSkpKbtQCAAAA5LqoqCiH73v27OmiSgAAAIDM5ejyCIMGDdLEiRP14YcfysMjR08BAAAAuERsbKyrSwAAAABuKkeJ648//qi4uDitXbtWderU4aNkAAAAAAAAAOAkOQptAwIC1LFjR2fXAgAAAAAAAACFXrZCW5vNpjfffFP79+9XWlqaWrRooTFjxsjHxye36gMAAAAAAACAQsUtO5PHjx+vl19+Wb6+vipfvrzeffddDRo0KLdqAwAAAAAAAIBCJ1uh7UcffaQZM2boq6++0ooVK/T5559rwYIFstlsuVUfAAAAAAAAABQq2Qptjxw5orZt29q/Dw8Pl8Vi0d9//+30wgAAAAAAAACgMMpWaHvlyhV5e3s7jHl6eury5ctOLQoAAAAAAAAACqts3YjMMAz16dNHVqvVPpaSkqIBAwaoaNGi9rHly5c7r0IAAAAAAAAAKESyFdpGRUVlGOvZs6fTigEAAAAAAACAwi5boW1sbGxu1QEAAAAAAAAAUDavaQsAAAAAAAAAyF2EtgAAAAAAAABgIoS2AAAAAAAAAGAipghtp0+frpCQEHl7e6tRo0batm1blpZbtGiRLBaLIiMjc7dAAAAA4CboZwEAAOBMLg9tFy9erGHDhik6Olo7duxQ3bp1FRERoVOnTt10uUOHDmnEiBFq2rRpHlUKAAAAZEQ/CwAAAGdzeWj79ttvq3///urbt69q1qypWbNmqUiRIpo7d+4Nl0lPT1ePHj00duxYVa5cOQ+rBQAAABzRzwIAAMDZXBrapqWlafv27QoPD7ePubm5KTw8XFu3br3hcuPGjVOZMmX0+OOP50WZAAAAQKboZwEAAJAbPFy58tOnTys9PV2BgYEO44GBgdq7d2+my2zZskVz5szRrl27srSO1NRUpaam2r9PSkrKcb0AAADA9fKin5XoaQEAAAobl18eITsuXLigXr166YMPPlCpUqWytExMTIz8/f3tX8HBwblcZeYsFr5c9QUAAGAWOelnJfP0tAAAAMgbLj3TtlSpUnJ3d9fJkycdxk+ePKmgoKAM8w8ePKhDhw6pQ4cO9jGbzSZJ8vDw0L59+3TnnXc6LDNy5EgNGzbM/n1SUhJNLgAAAJwiL/pZiZ4WAACgsHFpaOvl5aXQ0FDFxcUpMjJS0tWmNS4uToMHD84wv3r16tq9e7fD2KuvvqoLFy5o6tSpmTauVqtVVqs1V+oHAABA4ZYX/axETwsAAFDYuDS0laRhw4YpKipKDRo0UMOGDTVlyhQlJyerb9++kqTevXurfPnyiomJkbe3t2rXru2wfEBAgCRlGAcAAADyAv0sAAAAnM3loW2XLl2UkJCg0aNH68SJE6pXr57WrFljv5nDkSNH5OaWry69CwAAgEKEfhYAAADOZjEMw3B1EXkpKSlJ/v7+SkxMlJ+fX56tlxtiuU7heoUDQOHE71nXyevfs67q5cyG/QAAQB6j4SzY8rCpzWofx5/8AQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQ8XF0AAAB5yWJxdQWFk2G4ugIAAAAAyD840xYAAAAAAAAATITQFgAAAAAAAABMhNAWAAAAAAAAAEyE0BYAAAAAAAAATITQFgAAAAAAAABMhNAWAAAAAAAAAEyE0BYAAAAAAAAATITQFgAAAAAAAABMhNAWAAAAAAAAAEyE0BYAAAAAAAAATITQFgAAAAAAAABMhNAWAAAAAAAAAEyE0BYAAAAAAAAATITQFgAAAAAAAABMhNAWAAAAAAAAAEyE0BYAAAAAAAAATITQFgAAAAAAAABMhNAWAAAAAAAAAEyE0BYAAAAAAAAATITQFgAAAAAAAABMxMPVBQD5mcXi6goKL8NwdQUAAAAAAAC5gzNtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBETBHaTp8+XSEhIfL29lajRo20bdu2G8794IMP1LRpUxUvXlzFixdXeHj4TecDAAAAuY1+FgAAAM7k8tB28eLFGjZsmKKjo7Vjxw7VrVtXEREROnXqVKbzN23apG7dumnjxo3aunWrgoOD1apVKx07diyPKwcAAADoZwEAAOB8FsMwDFcW0KhRI917772aNm2aJMlmsyk4OFjPPPOMXnrppVsun56eruLFi2vatGnq3bv3LecnJSXJ399fiYmJ8vPzu+36s8piybNV4V9y8xXOcXUd175zIT/j59Y1cvtnluPqOnn9fuyqXu5m8rqflcy5HwAAKNBoOAu2PGxqs9rHufRM27S0NG3fvl3h4eH2MTc3N4WHh2vr1q1Zeo5Lly7p8uXLKlGiRG6VCQAAAGSKfhYAAAC5wcOVKz99+rTS09MVGBjoMB4YGKi9e/dm6TlefPFFlStXzqFRvl5qaqpSU1Pt3yclJeW8YAAAAOA6edHPSvS0AAAAhY3Lr2l7O9544w0tWrRIn332mby9vTOdExMTI39/f/tXcHBwHlcJAAAAZC4r/axETwsAAFDYuDS0LVWqlNzd3XXy5EmH8ZMnTyooKOimy7711lt64403tHbtWt199903nDdy5EglJibav44ePeqU2gEAAIC86GcleloAAIDCxqWhrZeXl0JDQxUXF2cfs9lsiouLU+PGjW+43KRJk/Taa69pzZo1atCgwU3XYbVa5efn5/AFAAAAOENe9LMSPS0AAEBh49Jr2krSsGHDFBUVpQYNGqhhw4aaMmWKkpOT1bdvX0lS7969Vb58ecXExEiSJk6cqNGjR2vhwoUKCQnRiRMnJEm+vr7y9fV12XYAAACgcKKfBQAAgLO5PLTt0qWLEhISNHr0aJ04cUL16tXTmjVr7DdzOHLkiNzc/ndC8MyZM5WWlqbHHnvM4Xmio6M1ZsyYvCwdAAAAoJ8FAACA01kMwzBcXUReSkpKkr+/vxITE/P0Y2UWS56tCv+Sm69wjqvrFK53LjgTP7eukds/sxxX18nr92NX9XJmw34AACCP0XAWbHnY1Ga1j3PpNW0BAAAAAAAAAI4IbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBEPFxdAAAAAIB8wGJxdQXITYbh6goAAMB1ONMWAAAAAAAAAEyE0BYAAAAAAAAATITQFgAAAAAAAABMhNAWAAAAAAAAAEyE0BYAAAAAAAAATITQFgAAAAAAAABMhNAWAAAAAAAAAEyE0BYAAAAAAAAATITQFgAAAAAAAABMhNAWAAAAAAAAAEyE0BYAAAAAAAAATITQFgAAAAAAAABMhNAWAAAAAAAAAEyE0BYAAAAAAAAATITQFgAAAAAAAABMhNAWAAAAAAAAAEyE0BYAAAAAAAAATITQFgAAAAAAAABMhNAWAAAAAAAAAEyE0BYAAAAAAAAATITQFgAAAAAAAABMhNAWAAAAAAAAAEyE0BYAAAAAAAAATITQFgAAAAAAAABMhNAWAAAAAAAAAEyE0BYAAAAAAAAATITQFgAAAAAAAABMhNAWAAAAAAAAAEyE0BYAAAAAAAAATITQFgAAAAAAAABMhNAWAAAAAAAAAEyE0BYAAAAAAAAATITQFgAAAAAAAABMhNAWAAAAAAAAAEyE0BYAAAAAAAAATITQFgAAAAAAAABMxMPVBQAAAAAAADiNxeLqCpCbDMPVFQB5gjNtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQIbQEAAAAAAADARAhtAQAAAAAAAMBECG0BAAAAAAAAwEQ8XF0AAJiRxeLqCgovw3B1BQAAAAAAuBZn2gIAAAAAAACAiRDaAgAAAAAAAICJENoCAAAAAAAAgIkQ2gIAAAAAAACAiRDaAgAAAAAAAICJENoCAAAAAAAAgIkQ2gIAAAAAAACAiRDaAgAAAAAAAICJmCK0nT59ukJCQuTt7a1GjRpp27ZtN52/ZMkSVa9eXd7e3qpTp46++OKLPKoUAAAAyIh+FgAAAM7k8tB28eLFGjZsmKKjo7Vjxw7VrVtXEREROnXqVKbzv/vuO3Xr1k2PP/64du7cqcjISEVGRurXX3/N48oBAAAA+lkAAAA4n8UwDMOVBTRq1Ej33nuvpk2bJkmy2WwKDg7WM888o5deeinD/C5duig5OVmrVq2yj913332qV6+eZs2adcv1JSUlyd/fX4mJifLz83PehtyCxZJnq8K/5OYrnOPqOrn9zsWxdR2ObcHEcS248rqTdFUvdzN53c9KLtoP/KAVbK79byHgXLxfFWyuer/idVWw5eHrKqt9nEvPtE1LS9P27dsVHh5uH3Nzc1N4eLi2bt2a6TJbt251mC9JERERN5wPAAAA5Bb6WQAAAOQGD1eu/PTp00pPT1dgYKDDeGBgoPbu3ZvpMidOnMh0/okTJzKdn5qaqtTUVPv3iYmJkq6m2igcONQFE8e14OLYFkwc14Irr4/ttR7OxR8Ws8uLflaip0Ue4LUEIL/g/Qq5IQ9fV1ntZ10a2uaFmJgYjR07NsN4cHCwC6qBK/j7u7oC5AaOa8HFsS2YOK4Fl6uO7YULF+RfiF5Y9LTIdYXo5wlAPsf7FXKDC15Xt+pnXRralipVSu7u7jp58qTD+MmTJxUUFJTpMkFBQdmaP3LkSA0bNsz+vc1m09mzZ1WyZElZuB7JLSUlJSk4OFhHjx41zXXj4Bwc24KJ41pwcWwLLo5t9hiGoQsXLqhcuXKuLkVS3vSzEj1tXuPnErmB1xVyA68r5AZeV7krq/2sS0NbLy8vhYaGKi4uTpGRkZKuNqBxcXEaPHhwpss0btxYcXFxeu655+xj69atU+PGjTOdb7VaZbVaHcYCAgKcUX6h4ufnxw9qAcWxLZg4rgUXx7bg4thmnZnOsM2Lflaip3UVfi6RG3hdITfwukJu4HWVe7LSz7r88gjDhg1TVFSUGjRooIYNG2rKlClKTk5W3759JUm9e/dW+fLlFRMTI0kaMmSIwsLCNHnyZLVr106LFi3STz/9pPfff9+VmwEAAIBCin4WAAAAzuby0LZLly5KSEjQ6NGjdeLECdWrV09r1qyx35zhyJEjcnNzs8+///77tXDhQr366qt6+eWXVbVqVa1YsUK1a9d21SYAAACgEKOfBQAAgLO5PLSVpMGDB9/w42ObNm3KMNapUyd16tQpl6uCdPWjeNHR0Rk+jof8j2NbMHFcCy6ObcHFsS0Y6GcLFn4ukRt4XSE38LpCbuB1ZQ4WwzAMVxcBAAAAAAAAALjK7dZTAAAAAAAAAAB5hdAWAAAAAAAAAEyE0BYAAAAAAAAATITQNp/r06ePLBaL3njjDYfxFStWyGKxSLp68wuLxaLz589n+hxjxoyRxWKRxWKRh4eHQkJCNHToUF28ePGW6z906JAsFovc3d117Ngxh8eOHz8uDw8PWSwWHTp0yGH+rl27sr2tBV1CQoIGDhyoO+64Q1arVUFBQYqIiNDXX3+toKAgTZgwIcMynTt31n333af09HT7cRwwYIDDnF27djkcgxu5/nVwo69rPvnkE7m7u2vQoEGZPldSUpJGjRqlWrVqycfHRyVLltS9996rSZMm6dy5c9nfOQXcrfb7mDFj7D87175KlCihsLAwbd682eG5/v3zXKpUKTVr1kxTpkxRamqqw9wHHngg0/cPSWrXrp193cie7BzP698LL1y4oObNm6tmzZr666+/7OPLli1TixYtVLx4cfn4+KhatWrq16+fdu7cmWHd//zzj0qUKKFSpUrZj/e8efNuWdOt3h8Kmz59+igyMjLD+LXfpx9//LGKFi2qP/74w+Hxv//+W8WLF9e0adMkSSdOnNAzzzyjypUry2q1Kjg4WB06dFBcXJzDct99953atm2r4sWLy9vbW3Xq1NHbb7+t9PR0h3nXjtf333/vMJ6amqqSJUvKYrE43PDq+mPs4eGhO+64Q8OGDcvwXgDkB/RJcBX6NDgLPSJuB/1p4URoWwB4e3tr4sSJt9Xk1apVS8ePH9ehQ4c0ceJEvf/++xo+fHiWly9fvrw++ugjh7H58+erfPnyOa6psOnYsaN27typ+fPna//+/Vq5cqUeeOABJSYm6v3339fYsWO1e/du+/wlS5Zo1apVmj9/vtzd3SVdfS3MmTNHBw4cyPb6R4wYoePHj9u/KlSooHHjxjmMXTNnzhy98MIL+uSTT5SSkuLwPGfPntV9992n2NhYjRgxQj/88IN27Nih8ePHa+fOnVq4cGEO91DBdf0+njJlivz8/BzGRowYYZ+7fv16HT9+XN98843KlSun9u3b6+TJkw7Pd+3n+ciRI9q4caM6deqkmJgY3X///bpw4YLD3ODgYM2bN89h7NixY4qLi1PZsmVzbZsLsuwcz2sSEhLUvHlzJScna/PmzapQoYIk6cUXX1SXLl1Ur149rVy5Uvv27dPChQtVuXJljRw5MsPzLFu2TLVq1VL16tW1YsUKSVKXLl0c1t+4cWP179/fYSw4ODhX90lB06FDB0VERKhPnz6y2Wz28f79+ys0NFSDBg3SoUOHFBoaqg0bNujNN9/U7t27tWbNGjVv3twhyPnss88UFhamChUqaOPGjdq7d6+GDBmi119/XV27dtW/7xcbHBys2NhYh7HPPvtMvr6+mdYaGxur48ePKz4+XjNmzNDHH3+s119/3Yl7A8gb9ElwFfo0OAs9InIT/WkBZSBfi4qKMtq3b29Ur17deP755+3jn332mXHt8G7cuNGQZJw7dy7T54iOjjbq1q3rMNa/f38jKCjoluuPj483JBmvvvqqUbVqVYfH7rrrLmPUqFGGJCM+Pt5h/s6dO7O8jYXBuXPnDEnGpk2bbjinT58+Rv369Y20tDTj1KlTRunSpY2pU6faH792HFu2bGl06tTJPr5z506HY5BVFStWNN55550M43/++afh4+NjnD9/3mjUqJGxYMECh8efeuopo2jRosaxY8cyfV6bzZatOgqb2NhYw9/fP8N4Zj87v/zyiyHJ+L//+z/7WGY/z4ZhGHv27DG8vLyMV155xT4WFhZmDBw40ChZsqSxZcsW+/j48eONDh06GHXr1jWio6OdsVmFVlaO55EjR4xq1aoZLVq0MC5cuGCfs3XrVkOSw8/59TL7WXrggQeMWbNmGTNnzjRatmyZ6XJhYWHGkCFDcrQ9hUVUVJTx8MMPZxi//vfptffhN9980zCM/x3rI0eOGIZhGG3atDHKly9vXLx4McPzXPt9fPHiRaNkyZLGo48+mmHOypUrDUnGokWL7GPXft/6+fkZly5dso+3bNnS/vt248aNDvM/++wzh+d9/PHHjbZt22Z1VwCmQJ8Es6BPg7PQIyK76E8LJ860LQDc3d01YcIEvffeew4fl7gdPj4+SktLy/L8hx56SOfOndOWLVskSVu2bNG5c+fUoUMHp9RT0Pn6+srX11crVqy44ccCpk6dqjNnzui1117T008/rdq1a+uZZ57JMO+NN97QsmXL9NNPP+VKrbGxsWrXrp38/f3Vs2dPzZkzx/6YzWbT4sWL1bNnT5UrVy7T5a//+CBy7p9//rGf3e7l5XXL+dWrV1ebNm20fPlyh3EvLy/16NHD4S+j8+bNU79+/ZxbMDK1b98+NWnSRDVr1tQXX3zh8NfoTz75RL6+vnr66aczXfbfP0sHDx7U1q1b1blzZ3Xu3FmbN2/W4cOHc7X+wqx06dJ6//33NWrUKK1bt05Dhw7V1KlTFRwcrLNnz2rNmjUaNGiQihYtmmHZgIAASdLatWt15syZTM+s6dChg+666y598sknDuOhoaEKCQnRsmXLJElHjhzRN998o169et2y5v3792vDhg1q1KhRDrYYcB36JOQ39Gm4XfSIyAn604KH0LaAeOSRR1SvXj1FR0ff9nNt375dCxcuVIsWLbK8jKenp3r27Km5c+dKkubOnauePXvK09PztuspDDw8PDRv3jzNnz9fAQEBatKkiV5++WX98ssv9jl+fn6KjY3VhAkTtHbtWsXGxmba2N9zzz3q3LmzXnzxRafXabPZNG/ePPXs2VOS1LVrV23ZskXx8fGSrn585/z586pWrZrDcqGhofb/cHXr1s3pdRUm999/v3x9fVW0aFG99dZbCg0N1YMPPpilZatXr57pdan69eunTz/9VMnJyfrmm2+UmJio9u3bO7lyZKZ3796qUqWKlixZIqvV6vDY/v37VblyZXl4eNjH3n77bfvPkq+vrxITE+2PzZ07V23atFHx4sVVokQJRUREZPiYErJu1apVDvva19dXbdq0cZgTGRmpzp07q3Xr1goLC1NUVJQk6Y8//pBhGKpevfpN17F//35JUo0aNTJ9vHr16vY51+vXr5/99+28efPUtm1blS5dOtPn6Natm3x9feXt7a1q1aqpVq1amX5sEjAz+iTkF/RpcBZ6RGSG/rTwIbQtQCZOnKj58+drz5492V529+7d8vX1lY+Pjxo2bKjGjRvbL1SdVf369dOSJUt04sQJLVmyhL8AZ1PHjh31999/a+XKlWrdurU2bdqke+65x+E6Vi1atNB9992nXr16qWLFijd8rtdff12bN2/W2rVrnVrjunXrlJycrLZt20qSSpUqpZYtW9rfnG/ks88+065duxQREaF//vnHqTUVNosXL9bOnTu1bNkyValSRfPmzcvyH0cMw8j0P7B169ZV1apVtXTpUs2dO1e9evVyaAKRex566CFt3rw5w5k1N9KvXz/t2rVLs2fPVnJysv16Uunp6Zo/f749KJCknj17at68eQ7XtELWNW/eXLt27XL4+vDDDzPMGzVqlGw2m1599VX7mPGv63zdSnbn9+zZU1u3btWff/55yzOu3nnnHe3atUs///yzVq1apf3792fprAfAbOiTkB/Qp8FZ6BGRGfrTwod3+wKkWbNmioiI0MiRI9WnT59sLVutWjWtXLlSHh4eKleuXJY+xvNvderUUfXq1dWtWzfVqFFDtWvXdrjrJW7N29tbLVu2VMuWLTVq1Cg98cQTio6OdjieHh4et2zU7rzzTvXv318vvfSSw8fybtecOXN09uxZ+fj42MdsNpt++eUXjR07VqVLl1ZAQID27dvnsNwdd9whSSpWrJjOnz/vtHoKo+DgYFWtWlVVq1bVlStX9Mgjj+jXX3/N8Bf4zOzZs0eVKlXK9LF+/fpp+vTp+v3337Vt2zZnl40beOWVV3T33Xere/fuMgxDnTt3tj9WtWpVbdmyRZcvX7b/hy8gIEABAQEZLoXz1Vdf6dixY+rSpYvDeHp6uuLi4tSyZcvc35gCpmjRoqpSpYrDWGaXILr2fnz9+3LVqlVlsVi0d+/em67jrrvuknT1Z/P+++/P8PiePXtUs2bNDOMlS5ZU+/bt9fjjjyslJUVt2rTJcPOaa4KCguzbUa1aNV24cEHdunXT66+/nmH7ALOjT4LZ0afBWegRkRn608KHM20LmDfeeEOff/65tm7dmq3lvLy8VKVKFYWEhOQosL2mX79+2rRpE2fZOknNmjWVnJyco2VHjx6t/fv3a9GiRU6p5cyZM/q///s/LVq0yOEvezt37tS5c+e0du1aubm5qXPnzvrvf/+rv//+2ynrxY099thj8vDw0IwZM245d+/evVqzZo06duyY6ePdu3fX7t27Vbt27Ux/CSP3jBo1SmPGjFGPHj20ePFi+3i3bt108eLFLB3fOXPmqGvXrhn+8t61a1enBhLImmsfPZw+fXqm7+HXQplWrVqpRIkSmjx5coY5K1eu1IEDB274Uelrv2979+4td3f3LNd2bS5n86EgoE+CmdGn4XbRI8KZ6E/zJ860LWDq1KmjHj166N13383w2O7du1WsWDH79xaLRXXr1nXq+vv3769OnTrZL2J9I/8+w0CSatWqVWivgXvmzBl16tRJ/fr10913361ixYrpp59+0qRJk/Twww/n6DkDAwM1bNgwvfnmm06p8eOPP1bJkiXVuXPnDB/datu2rebMmaPWrVtrwoQJ2rRpkxo2bKhx48apQYMGKlq0qH755Rdt3bpVtWvXdko9uPoz/Oyzz2rMmDF66qmnVKRIEUnSlStXdOLECdlsNp05c0abNm3S66+/rnr16un555/P9LmKFy+u48ePF9qfQVd75ZVX5O7urh49eshms6lbt25q3Lixhg8fruHDh+vw4cN69NFHFRwcrOPHj2vOnDmyWCxyc3NTQkKCPv/8c61cuTLDz1fv3r31yCOP6OzZsypRooSLtq5wmj59upo0aWJ/L7z77rt15coVrVu3TjNnztSePXtUtGhRzZ49W127dtWTTz6pwYMHy8/PT3FxcXr++ef12GOPOZxZc73WrVsrISFBfn5+N63j/Pnz9veDAwcOaNy4cbrrrrtueJ0ywIzok5Af0afBGegR4Uz0p/kPoW0BNG7cOIe/xF3TrFkzh+/d3d115coVp67bw8NDpUqVuuW8rl27Zhg7evSoKlSo4NR68gtfX181atRI77zzjg4ePKjLly8rODhY/fv318svv5zj5x0xYoRmzpyplJSU265x7ty5euSRRzK91lbHjh3Vq1cvnT59WqVKldK2bds0ceJEvfnmm4qPj5ebm5uqVq2qLl266LnnnrvtWvA/UVFReuWVVzRt2jS98MILkqTffvtNZcuWlbu7u/z9/VWzZk2NHDlSAwcOvOnH8271xxbkrpdeeklubm7q1auXDMNQ9+7d9dZbb6lhw4aaOXOm5s6dq0uXLikwMFDNmjXT1q1b5efnp8mTJ6to0aKZ3ujkwQcflI+Pj/773//q2WefdcFWFV6VK1fWjh07NH78eA0fPlzHjx9X6dKlFRoaqpkzZ9rnPfbYY9q4caPGjx+vpk2bKiUlRVWrVtUrr7yi55577oZ3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",
      "text/plain": [
       "<Figure size 1400x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Adjusting the data to remove F1-Scores for the baseline comparison\n",
    "baseline_data_adjusted = {\n",
    "    \"Method\": [\"NLP_ML\", \"SYN_TAG\", \"TRDM\", \"TKGAT\", \"HYCOMB\"],\n",
    "    \"Precision\": [0.4, 0.314, 0.035, 0.3646, 0.8202],\n",
    "    \"Recall\": [None, 0.162, None, 0.0718, 0.8292],\n",
    "}\n",
    "\n",
    "# Create a DataFrame for adjusted baseline methods\n",
    "baseline_df_adjusted = pd.DataFrame(baseline_data_adjusted)\n",
    "\n",
    "# Plotting\n",
    "fig, ax = plt.subplots(1, 2, figsize=(14, 5), dpi=100)\n",
    "\n",
    "# Bar chart for Precision\n",
    "ax[0].bar(baseline_df_adjusted['Method'], baseline_df_adjusted['Precision'], color='b', label='Precision')\n",
    "\n",
    "# Bar chart for Recall\n",
    "ax[1].bar(baseline_df_adjusted['Method'], baseline_df_adjusted['Recall'], color='r', label='Recall')\n",
    "\n",
    "# Adding labels and titles\n",
    "ax[0].set_title('Comparison of Precision')\n",
    "ax[0].set_xlabel('Methods')\n",
    "ax[0].set_ylabel('Precision')\n",
    "ax[0].set_ylim(0, 1)\n",
    "\n",
    "ax[1].set_title('Comparison of Recall')\n",
    "ax[1].set_xlabel('Methods')\n",
    "ax[1].set_ylabel('Recall')\n",
    "ax[1].set_ylim(0, 1)\n",
    "\n",
    "# Adding legends\n",
    "ax[0].legend()\n",
    "ax[1].legend()\n",
    "\n",
    "# Show plot\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Precision of Baseline Methods and Our Approach')"
      ]
     },
     "execution_count": 81,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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l+zfpB944AEtWLBACQkJeuSRR7Rr1y698sor2rJli77++mv73r0FCxZo8ODBat68ucaOHaugoCBt2bJFq1evVv/+/Z3WsWbNGvXr10+33Xabpk6dKknatm2bvv76a40YMaLU+ovrueGGG5ScnKysrCzNmDFDX3/9tbZs2eKwR66oqEhxcXGKiYnRSy+9pLVr12ratGlq2LChhg4detb1NHHiRE2aNEmxsbEaOnSotm/frlmzZuk///mPfdlTUlL05ptvauXKlfZDvNddd905t8GRI0ck/RWy9+3bp2eeeUY+Pj4OgSYvL09vvPGG+vXrp8TERB07dkxz585VXFycw2HjsqzHkydPqn379tq3b58eeOABXXXVVfrmm280duxYHThwQCkpKees+Uw7d+5Ur169NGTIEMXHx2vevHkaNGiQoqKi1Lx58wqdb//+/TVx4kSlp6fbv8QsXrxYt912m+rVq1eif1ZWlm688Ua5ublp+PDhqlu3rj755BMNGTJEeXl5evTRR9WsWTNNnjxZ48eP1/3336+bb75ZktS2bVv7dI4ePapOnTrp73//u3r37q1ly5bpiSeeUMuWLdW5c2dJ0h9//KEOHTpo586dGj58uK655hotXbpUgwYNUk5Ojn0bWJalO++8U+vXr9eDDz6oZs2aaeXKlU73QN1111366aef9PDDDys8PFwHDx7UmjVrtHfv3rNeXLVmzRr99ttvSkhIUEhIiH766SfNmTNHP/30k/71r3/Jzc3NoX/v3r11zTXXKDk5WZs3b9Ybb7yhevXq2Z9H0l9HD95++231799fbdu21eeff66uXbuWabt98MEHkqSBAwc6HR4YGKg777xTCxcu1M6dO8t8OsXpDh8+rM6dO6tv374aMGCAgoODz9o/Pz9fy5cv16hRoyT99QUjISFBmZmZ9i9jp3vuuefk5uamJ554QgcPHlRKSopiY2O1detW+fr62vsdPXpUXbp0Ue/evdWvXz+9++67Gjp0qLy8vDR48GCHaT7zzDPy8vLS6NGjlZ+fLy8vrzK/r5V1G+/fv1+tW7dWTk6O7r//fjVt2lT79u3TsmXLdPLkSYdTbB5++GHVrFlTEyZM0O7du5WSkqLhw4crNTX1vLcHKogFXKD58+dbkqy1a9da2dnZVkZGhrVkyRKrdu3alq+vr/X7779blmVZ8fHxliRrzJgxDuN/9dVXliRr0aJFDu2rV692aM/JybFq1KhhxcTEWH/88YdDX5vNZv9/fHy8dfXVV9v/HjFihBUQEGAVFhaWugzr1q2zJFnr1q2zLMuyCgoKrHr16lktWrRwmNeHH35oSbLGjx/vMD9J1uTJkx2mef3111tRUVGlztOyLOvgwYOWl5eXdfvtt1tFRUX29ldeecWSZM2bN8/eNmHCBEuSlZ2dfdZpnt73zEdQUJC1evVqh76FhYVWfn6+Q9vRo0et4OBga/Dgwfa2sqzHZ555xvLz87N27Njh0D5mzBjLw8PD2rt3r71NkjVhwgT738XPo127dtnbrr76akuS9eWXX9rbDh48aHl7e1ujRo0q13ydad++vdW8eXPLsiwrOjraGjJkiH09eHl5WQsXLrQ/R5YuXWofb8iQIVb9+vWtQ4cOOUyvb9++VmBgoHXy5EnLsizrP//5jyXJmj9/vtN5S7LefPNNe1t+fr4VEhJi3XXXXfa2lJQUS5L19ttv29sKCgqsNm3aWP7+/lZeXp5lWZb13nvvWZKsF154wd6vsLDQuvnmmx1qOHr0qCXJevHFF8+6bpwpXq7TvfPOOyW2VfHz8PTnkWVZVs+ePa3atWvb/966daslyXrooYcc+vXv37/E88SZyMhIKzAw8Kx9pk+fbkmyVq1aZVmW8+ebZZV8L7Cs/22j2bNnn3Uep1u2bJklyfrll18sy7KsvLw8y8fHx3r55Zedzi80NNS+DS3Lst59911LkjVjxowSdUybNs3elp+fb0VGRlr16tWzCgoKHKbZoEEDh211Pu9rZd3GAwcOtNzd3a3//Oc/JfoXvy8Xr+vY2FiH9+qRI0daHh4eVk5OTilrEZWNw8GoMLGxsapbt67CwsLUt29f+fv7a+XKlQoNDXXod+aesaVLlyowMFAdO3bUoUOH7I+oqCj5+/vbD0uuWbNGx44d05gxY0qcv3fmnofTBQUF6cSJE1qzZk2Zl+Xbb7/VwYMH9dBDDznMq2vXrmratKk++uijEuM8+OCDDn/ffPPN+u233846n7Vr16qgoECPPvqow7k6iYmJCggIcDqf87F8+XKtWbNGn332mebPn69rr71Wd911l7755ht7Hw8PD/u3dZvNpiNHjqiwsFDR0dHavHmzvV9Z1uPSpUt18803q2bNmg7bMjY2VkVFRfryyy/PexkiIiLse8+kvw6HN2nSxGHdVuR8+/fvrxUrVqigoEDLli2Th4eHevbsWaKfZVlavny5unfvLsuyHOYbFxen3Nxch/V3Nv7+/howYID9by8vL7Vu3dphGT/++GOFhIQ4nF9brVo1PfLIIzp+/Li++OILez9PT0+H15mHh4cefvhhh3n6+vrKy8tL6enpTk+7OJvT90ydOnVKhw4d0o033ihJTpfZ2Wvj8OHD9sOTH3/8sSTpkUcecej36KOPlqmeslxwUTy8eJ7ny9vbWwkJCWXuv2jRIkVHR9v3OtaoUUNdu3Z1ekhY+msv5unL0KtXL9WvX9++bop5enrqgQcesP/t5eWlBx54QAcPHtSmTZsc+sbHxztsq/N5XyvLNrbZbHrvvffUvXt3+/ngpzvzffn+++93aLv55ptVVFSkPXv2OF0nqHwcDkaFmTlzpq699lp5enoqODhYTZo0KXESsqenp6688kqHtl9++UW5ublOD7dJ/7sgovjw8vneU+2hhx7Su+++q86dOys0NFS33367evfurU6dOpU6TvGbUpMmTUoMa9q0qdavX+/Q5uPjo7p16zq01axZ85wfrqXNx8vLSw0aNLjgN8d27do5XBjSq1cvNW7cWA8//LDDB8bChQs1bdo0/fzzz/rzzz/t7ddcc439/2VZj7/88ou+//77EuuiWPG2PB9XXXVVibYz121Fzrdv374aPXq0PvnkEy1atEjdunVzGjCys7OVk5OjOXPmlHq7nrLO98orryzxgVmzZk19//339r/37Nmjxo0bl3hNNWvWzD68+N/69evL39/fod+ZzzFvb29NnTpVo0aNUnBwsG688UZ169ZNAwcOdHq48nRHjhzRpEmTtGTJkhLLmJubW6L/mduwZs2akv46tBkQEKA9e/bI3d1dDRs2PGvNpalRo4YOHTp01j7Hjh2z9y2P0NDQMt89ICcnRx9//LGGDx+unTt32ttvuukmLV++XDt27NC1117rMM6Ztydyc3NTo0aNSpyzeMUVV5S4mK54Wrt377YHNcnx9Sud3/taWbZxdna28vLyyvyefLbnAVyDEIgK07p1a6ffBk/n7e1d4kPMZrOpXr16pX5DLu2Dvazq1aunrVu36tNPP9Unn3yiTz75RPPnz9fAgQOdnlRfHq68qvV8+Pv7KyYmRu+//779yuy3335bgwYNUo8ePfTYY4+pXr168vDwUHJysj14S2VbjzabTR07dtTjjz/udP5nfvCVRWnr1rIs+/8rcr7169dXhw4dNG3aNH399delXhFcfPHIgAEDSr3isyznbUplW8bK8Oijj6p79+5677339Omnn2rcuHFKTk7W559/ruuvv77U8Xr37q1vvvlGjz32mCIjI+23IerUqZPTC3Eqe/maNWumrVu3au/evU6/NEiyB+qIiAhJpR89KO1irtP3jJ3L0qVLlZ+fr2nTpmnatGklhi9atEiTJk0q8/TK63xqPtP5buOycNXzHKUjBMLlGjZsqLVr1+qmm24665tW8V6CH3/88bxP7Pby8lL37t3VvXt32Ww2PfTQQ3rttdc0btw4p9O6+uqrJf1177HiCwSKbd++3T78Qp0+nwYNGtjbCwoKtGvXLsXGxlbIfE5XWFgoSTp+/Lj8/Py0bNkyNWjQQCtWrHD4YCy+Gvl051qPDRs21PHjxyul7rOp6Pn2799f9913n4KCgtSlSxenfYqvYi0qKjrnfM92ukJZXX311fr+++9ls9kcvkj9/PPP9uHF/6alpen48eMOewO3b9/udLoNGzbUqFGjNGrUKP3yyy+KjIzUtGnT9Pbbbzvtf/ToUaWlpWnSpEkaP368vf2XX365oGWz2Wz69ddfHfZSlVbzmbp166Z33nlHb775pp5++ukSw/Py8vT++++radOm9td78V6oM6+arohDk4sWLVKLFi2cvoZee+01LV68uEQIPHP9WZalnTt3lvgisX///hK31tqxY4cknfOXksr6vlbWbVy3bl0FBAToxx9/POt8ceninEC4XO/evVVUVKRnnnmmxLDCwkL7m/Ttt9+uGjVqKDk5ucRNe8/2TfLMWxq4u7vb31jz8/OdjhMdHa169epp9uzZDn0++eQTbdu2rcxXLZ5LbGysvLy89I9//MNhGebOnavc3NwKm0+xI0eO6JtvvlFISIj98Hvxt/PT5//vf/9bGzZscBi3LOuxd+/e2rBhgz799NMS887JybEH0IpW0fPt1auXJkyYoFdffbXUQ4AeHh6666677LcnOdPpt74o/sB2dpuWsurSpYsyMzMdrqQsLCzUP//5T/n7+6t9+/b2foWFhZo1a5a9X1FRkf75z386TO/kyZMlXkcNGzZUjRo1Sn1dSM6fL5LKdeV3seIroP/xj3+Ua5q9evVS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avXq1ercubMee+yxCi0QAAAAFa9ct4jJzMy0h8APP/xQvXv31u23367w8HDFxMRUaIEAAACoeOXaE1izZk1lZGRIklavXq3Y2FhJkmVZXBkMAABQBZRrT+Df//539e/fX40bN9bhw4fVuXNnSdKWLVvUqFGjCi0QAAAAFa9cIfDll19WeHi4MjIy9MILL8jf31+SdODAAT300EMVWiAAAAAqXrlCYLVq1TR69OgS7SNHjrzgggAAAFD5+Nk4AAAAA/GzcQAAAAbiZ+MAAAAMVGE/GwcAAICqo1wh8JFHHtE//vGPEu2vvPKKHn300QutCQAAAJWsXCFw+fLluummm0q0t23bVsuWLbvgogAAAFC5yhUCDx8+rMDAwBLtAQEBOnTo0AUXBQAAgMpVrhDYqFEjrV69ukT7J598ogYNGlxwUQAAAKhc5bpZdFJSkoYPH67s7GzdeuutkqS0tDRNmzZNKSkpFVkfAAAAKkG5QuDgwYOVn5+v5557Ts8884wkKTw8XLNmzdLAgQMrtEAAAABUvHKFQEkaOnSohg4dquzsbPn6+tp/PxgAAACXvnLfJ7CwsFBr167VihUrZFmWJGn//v06fvx4hRUHAACAylGuPYF79uxRp06dtHfvXuXn56tjx46qUaOGpk6dqvz8fM2ePbui6wQAAEAFKteewBEjRig6OlpHjx6Vr6+vvb1nz55KS0ursOIAAABQOcq1J/Crr77SN998Iy8vL4f28PBw7du3r0IKAwAAQOUp155Am82moqKiEu2///67atSoccFFAQAAoHKVKwTefvvtDvcDdHNz0/HjxzVhwgR16dKlomoDAABAJSlXCHzppZf09ddfKyIiQqdOnVL//v3th4KnTp163tObOXOmwsPD5ePjo5iYGG3cuLFM4y1ZskRubm7q0aPHec8TAADAZOU6JzAsLEzfffedUlNT9d133+n48eMaMmSI7rnnHocLRcoiNTVVSUlJmj17tmJiYpSSkqK4uDht375d9erVK3W83bt3a/To0br55pvLswgAAABGc7OKb/JXRn/++aeaNm2qDz/8UM2aNbvgAmJiYnTDDTfolVdekfTX+YZhYWF6+OGHNWbMGKfjFBUVqV27dho8eLC++uor5eTk6L333ivT/PLy8hQYGKjc3FwFBARccP0AAFxuCl+f4+oSLkueifdX+jzOJ+ec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zKUXhnh5eSkqKkppaWn2NpvNprS0NLVp08bpOG3atHHoL0lr1qwptT8AAABKcvnh4KSkJMXHxys6OlqtW7dWSkqKTpw4oYSEBEnSwIEDFRoaquTkZEnSiBEj1L59e02bNk1du3bVkiVL9O2332rOnDmuXAwAAIAqxeUhsE+fPsrOztb48eOVmZmpyMhIrV692n7xx969e+Xu/r8dlm3bttXixYv19NNP68knn1Tjxo313nvvqUWLFq5ahCrP29tbEyZMKHHYHJcmtlfVwvaqWtheVQvb68K4WWW5hhgAAACXFZffLBoAAAAXHyEQAADAQIRAAAAAAxECAQAADEQIrAIGDRokNzc3Pf/88w7t7733nv1XT9LT0+Xm5qacnByn05g4caLc3Nzk5uYmT09PhYeHa+TIkTp+/Pg557979265ubnJw8ND+/btcxh24MABeXp6ys3NTbt373bov3Xr1vNe1qooOztbQ4cO1VVXXSVvb2+FhIQoLi5OX3zxhUJCQjRlypQS4/Tu3Vs33nijioqK7NvmwQcfdOizdetWh/VamtO3bWmPYu+88448PDw0bNgwp9PKy8vTuHHj1Lx5c/n6+qp27dq64YYb9MILL+jo0aPnv3KqqHOtz4kTJ9qf58WPWrVqqX379vrqq68cpnXma69OnTpq166dUlJSHH7XXJI6dOjg9LUuSV27drXPG385n+10+vvRsWPHdMsttygiIkK///67vX358uW69dZbVbNmTfn6+qpJkyYaPHiwtmzZUmLef/zxh2rVqqU6derYt+OCBQvOWdO5Xs9V3aBBg9SjR48S7cWfUW+99Zb8/Py0c+dOh+H79+9XzZo19corr0j66ydiH374YTVo0EDe3t4KCwtT9+7dS9wn+JtvvlGXLl1Us2ZN+fj4qGXLlpo+fbqKihx/q7p4/f/rX/9yaM/Pz7f/glh6enqJ/sWv26uuukpJSUklXrNVHSGwivDx8dHUqVMv6IO4efPmOnDggHbv3q2pU6dqzpw5GjVqVJnHDw0N1ZtvvunQtnDhQoWGhpa7psvBXXfdpS1btmjhwoXasWOHVq1apQ4dOig3N1dz5szRpEmT9MMPP9j7L126VB9++KEWLlwoDw8PSX9t37lz5+qXX3457/mPHj1aBw4csD+uvPJKTZ482aGt2Ny5c/X444/rnXfe0alTpxymc+TIEd14442aP3++Ro8erX//+9/avHmznnvuOW3ZskWLFy8u5xqqek5fdykpKQoICHBoGz16tL3v2rVrdeDAAX355Ze64oor1K1btxK/alT82tu7d6/WrVunu+++W8nJyWrbtq2OHTvm0DcsLEwLFixwaNu3b5/S0tJUv379Slvmquh8tlOx7Oxs3XLLLTpx4oS++uorXXnllZKkJ554Qn369FFkZKRWrVql7du3a/HixWrQoIHGjh1bYjrLly9X8+bN1bRpU7333nuS/rrl2enzb9OmjRITEx3aTP/d+u7duysuLk6DBg2SzWaztycmJioqKkrDhg3T7t27FRUVpc8//1wvvviifvjhB61evVq33HKLwxfYlStXqn379rryyiu1bt06/fzzzxoxYoSeffZZ9e3bV2fe/CQsLEzz5893aFu5cqX8/f2d1jp//nwdOHBAu3bt0quvvqq33npLzz77bAWujUuAhUtefHy81a1bN6tp06bWY489Zm9fuXKlVbwJ161bZ0myjh496nQaEyZMsFq1auXQlpiYaIWEhJxz/rt27bIkWU8//bTVuHFjh2HXXnutNW7cOEuStWvXLof+W7ZsKfMyVlVHjx61JFnp6eml9hk0aJB1/fXXWwUFBdbBgwetunXrWjNmzLAPL942HTt2tO6++257+5YtWxzWa1ldffXV1ssvv1yi/bfffrN8fX2tnJwcKyYmxlq0aJHD8AceeMDy8/Oz9u3b53S6NpvtvOq4XMyfP98KDAws0e7sef79999bkqz333/f3ubstWdZlrVt2zbLy8vLeuqpp+xt7du3t4YOHWrVrl3bWr9+vb39ueees7p37261atXKmjBhQkUs1mWnLNtp7969VpMmTaxbb73VOnbsmL3Phg0bLEkOr8vTOXvud+jQwZo9e7Y1a9Ysq2PHjk7Ha9++vTVixIhyLU9VFR8fb915550l2k//jCp+H3zxxRcty/rfttu7d69lWZbVuXNnKzQ01Dp+/HiJ6RR/xh0/ftyqXbu29fe//71En1WrVlmSrCVLltjbij/DAgICrJMnT9rbO3bsaP8MW7dunUP/lStXOkx3yJAhVpcuXcq6KqoE9gRWER4eHpoyZYr++c9/Ohy+uBC+vr4qKCgoc/877rhDR48e1fr16yVJ69ev19GjR9W9e/cKqacq8vf3l7+/v957771SDxPMmDFDhw8f1jPPPKOHHnpILVq00MMPP1yi3/PPP6/ly5fr22+/rZRa58+fr65duyowMFADBgzQ3Llz7cNsNptSU1M1YMCAUn90/PTDyijpjz/+sO8p9/LyOmf/pk2bqnPnzlqxYoVDu5eXl+655x6HPRYLFizQ4MGDK7Zgw2zfvl033XSTIiIi9PHHHzvs/XnnnXfk7++vhx56yOm4Zz73f/31V23YsEG9e/dW79699dVXX2nPnj2VWv/lpG7dupozZ47GjRunNWvWaOTIkZoxY4bCwsJ05MgRrV69WsOGDZOfn1+JcYOCgiRJn332mQ4fPux0b2/37t117bXX6p133nFoj4qKUnh4uJYvXy7prx+j+PLLL3Xvvfees+YdO3bo888/V0xMTDmW+NJFCKxCevbsqcjISE2YMOGCp7Vp0yYtXrxYt956a5nHqVatmgYMGKB58+ZJkubNm6cBAwaoWrVqF1xPVeXp6akFCxZo4cKFCgoK0k033aQnn3xS33//vb1PQECA5s+frylTpuizzz7T/PnznQaqv/3tb+rdu7eeeOKJCq/TZrNpwYIFGjBggCSpb9++Wr9+vXbt2iXpr0NkOTk5atKkicN4UVFR9qDbr1+/Cq/rctC2bVv5+/vLz89PL730kqKionTbbbeVadymTZs6PUds8ODBevfdd3XixAl9+eWXys3NVbdu3Sq4crMMHDhQjRo10tKlS0v8usSOHTvUoEEDeXr+70e0pk+fbn/u+/v7Kzc31z5s3rx56ty5s2rWrKlatWopLi6uxGFGk3344YcO687f31+dO3d26NOjRw/17t1bnTp1Uvv27RUfHy9J2rlzpyzLUtOmTc86jx07dkiSmjVr5nR406ZN7X1ON3jwYPtn2IIFC9SlSxfVrVvX6TT69esnf39/+fj4qEmTJmrevLnTUwOqMkJgFTN16lQtXLhQ27ZtO+9xf/jhB/n7+8vX11etW7dWmzZt7CfhltXgwYO1dOlSZWZmaunSpeyd0F/nBO7fv1+rVq1Sp06dlJ6err/97W8O53XdeuutuvHGG3Xvvffq6quvLnVazz77rL766it99tlnFVrjmjVrdOLECXXp0kWSVKdOHXXs2NH+ZlialStXauvWrYqLi9Mff/xRoTVdLlJTU7VlyxYtX75cjRo10oIFC8r8xciyLKdfCFq1aqXGjRtr2bJlmjdvnu69916HgILzd8cdd+irr74qsee1NIMHD9bWrVv12muv6cSJE/bzy4qKirRw4UL7FypJGjBggBYsWOBwjpvJbrnlFm3dutXh8cYbb5ToN27cONlsNj399NP2Nus8f8TsfPsPGDBAGzZs0G+//XbOPewvv/yytm7dqu+++04ffvihduzYUaa9hlUJ7ypVTLt27RQXF6exY8dq0KBB5zVukyZNtGrVKnl6euqKK64o0yGrM7Vs2VJNmzZVv3791KxZM7Vo0cKYq4DPxsfHRx07dlTHjh01btw43XfffZowYYLDNvL09DznB3nDhg2VmJioMWPGOByuvVBz587VkSNH5Ovra2+z2Wz6/vvvNWnSJNWtW1dBQUHavn27w3hXXXWVJKlGjRqlXnluurCwMDVu3FiNGzdWYWGhevbsqR9//LFMv2W6bds2XXPNNU6HDR48WDNnztR///tfbdy4saLLNs5TTz2l6667Tv3795dlWerdu7d9WOPGjbV+/Xr9+eef9gAfFBSkoKCgEqfffPrpp9q3b5/69Onj0F5UVKS0tDR17Nix8hfmEufn56dGjRo5tDk7jan4/fD098XGjRvLzc1NP//881nnce2110r66zXUtm3bEsO3bdumiIiIEu21a9dWt27dNGTIEJ06dUqdO3cucXFWsZCQEPtyNGnSRMeOHVO/fv307LPPlli+qoo9gVXQ888/rw8++EAbNmw4r/G8vLzUqFEjhYeHlysAFhs8eLDS09PZC3gWEREROnHiRLnGHT9+vHbs2KElS5ZUSC2HDx/W+++/ryVLljh8M9+yZYuOHj2qzz77TO7u7urdu7fefvtt7d+/v0Lma6JevXrJ09NTr7766jn7/vzzz1q9erXuuusup8P79++vH374QS1atHD6YYbzN27cOE2cOFH33HOPUlNT7e39+vXT8ePHy7Td5s6dq759+5bY09W3b98K/eJmquLD6zNnznT6Hlr8ZfT2229XrVq1NG3atBJ9Vq1apV9++aXUU1iKP8MGDhxov0NDWRT3vZyOirAnsApq2bKl7rnnHv3jH/8oMeyHH35QjRo17H+7ubmpVatWFTr/xMRE3X333fYTdEtz5l4l6a9bZVxO5xAePnxYd999twYPHqzrrrtONWrU0LfffqsXXnhBd955Z7mmGRwcrKSkJL344osVUuNbb72l2rVrq3fv3iUOPXbp0kVz585Vp06dNGXKFKWnp6t169aaPHmyoqOj5efnp++//14bNmxQixYtKqSey5mbm5seeeQRTZw4UQ888ICqV68uSSosLFRmZqZsNpsOHz6s9PR0Pfvss4qMjNRjjz3mdFo1a9bUgQMHLqvXy6XgqaeekoeHh+655x7ZbDb169dPbdq00ahRozRq1Cjt2bNHf//73xUWFqYDBw5o7ty5cnNzk7u7u7Kzs/XBBx9o1apVJV4PAwcOVM+ePXXkyBHVqlXLRUt3eZg5c6Zuuukm+3vRddddp8LCQq1Zs0azZs3Stm3b5Ofnp9dee019+/bV/fffr+HDhysgIEBpaWl67LHH1KtXL4e9vafr1KmTsrOzFRAQcNY6cnJy7K/bX375RZMnT9a1115b6nmIVREhsIqaPHmywzfZYu3atXP428PDQ4WFhRU67+Ib3p5L3759S7RlZGTY78t1OfD391dMTIxefvll/frrr/rzzz8VFhamxMREPfnkk+We7ujRozVr1qwS9/Irj3nz5qlnz55Ozz276667dO+99+rQoUOqU6eONm7cqKlTp+rFF1/Url275O7ursaNG6tPnz569NFHL7gWE8THx+upp57SK6+8oscff1yS9NNPP6l+/fry8PBQYGCgIiIiNHbsWA0dOvSsh43P9UUL5TNmzBi5u7vr3nvvlWVZ6t+/v1566SW1bt1as2bN0rx583Ty5EkFBwerXbt22rBhgwICAjRt2jT5+fk5vfDntttuk6+vr95++2098sgjLliqy0eDBg3s9ygdNWqUDhw4oLp16yoqKkqzZs2y9+vVq5fWrVun5557TjfffLNOnTqlxo0b66mnntKjjz5a6h0N3NzcyvQZlpCQYO8fEhKidu3aacqUKZfV+blu1vmeVQkAAIAqj3MCAQAADEQIhB588MES93Qqfpz5e7ZwDbYRAKCicTgYOnjwoPLy8pwOCwgIUL169S5yRTgT2wgAUNEIgQAAAAbicDAAAICBCIEAAAAGIgQCAAAYiBAIAABgIEIgAFwEHTp0qJRfXZk4caIiIyMrfLoALn+EQADGGzRokNzc3Jzec3HYsGFyc3PToEGDyjSt9PR0ubm52X/oHgAuVYRAAJAUFhamJUuW6I8//rC3nTp1SosXL9ZVV13lwsoAoHIQAgFA0t/+9jeFhYVpxYoV9rYVK1boqquu0vXXX29vs9lsSk5O1jXXXCNfX1+1atVKy5YtkyTt3r1bt9xyiySpZs2aJfYg2mw2Pf7446pVq5ZCQkI0ceJEhxr27t2rO++8U/7+/goICFDv3r2VlZXl0Of5559XcHCwatSooSFDhujUqVMVvCYAmIIQCAD/3+DBgzV//nz73/PmzVNCQoJDn+TkZL355puaPXu2fvrpJ40cOVIDBgzQF198obCwMC1fvlyStH37dh04cEAzZsywj7tw4UL5+fnp3//+t1544QVNnjxZa9askfRXQLzzzjt15MgRffHFF1qzZo1+++039enTxz7+u+++q4kTJ2rKlCn69ttvVb9+fb366quVuUoAXMb4xRAAxhs0aJBycnL0+uuvKywsTNu3b5ckNW3aVBkZGbrvvvsUFBSk1157TbVq1dLatWvVpk0b+/j33XefTp48qcWLFys9PV233HKLjh49qqCgIHufDh06qKioSF999ZW9rXXr1rr11lv1/PPPa82aNercubN27dqlsLAwSdJ///tfNW/eXBs3btQNN9ygtm3b6vrrr9fMmTPt07jxxht16tQpbd26tXJXEoDLjqerCwCAS0XdunXVtWtXLViwQJZlqWvXrqpTp459+M6dO3Xy5El17NjRYbyCggKHQ8alue666xz+rl+/vg4ePChJ2rZtm8LCwuwBUJIiIiIUFBSkbdu26YYbbtC2bdtKXLzSpk0brVu37ryXFQAIgQBwmsGDB2v48OGS5LDHTZKOHz8uSfroo48UGhrqMMzb2/uc065WrZrD325ubrLZbBdSLgCUG+cEAsBpOnXqpIKCAv3555+Ki4tzGBYRESFvb2/t3btXjRo1cngU78Hz8vKSJBUVFZ3XfJs1a6aMjAxlZGTY2/773/8qJydHERER9j7//ve/Hcb717/+dd7LCAASewIBwIGHh4e2bdtm///patSoodGjR2vkyJGy2Wz6v//7P+Xm5urrr79WQECA4uPjdfXVV8vNzU0ffvihunTpIl9fX/n7+59zvrGxsWrZsqXuuecepaSkqLCwUA899JDat2+v6OhoSdKIESM0aNAgRUdH66abbtKiRYv0008/qUGDBhW/IgBc9tgTCABnCAgIUEBAgNNhzzzzjMaNG6fk5GQ1a9ZMnTp10kcffaRrrrlGkhQaGqpJkyZpzJgxCg4Oth9aPhc3Nze9//77qlmzptq1a6fY2Fg1aNBAqamp9j59+vTRuHHj9PjjjysqKkp79uzR0KFDL3yBARiJq4MBAAAMxJ5AAAAAAxECAQAADEQIBAAAMBAhEAAAwECEQAAAAAMRAgEAAAxECAQAADAQIRAAAMBAhEAAAAADEQIBAAAMRAgEAAAw0P8DGj2UnR6ecbsAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 2500x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(25, 8))\n",
    "\n",
    "# Precision Bar Chart\n",
    "plt.subplot(1, 3, 1)\n",
    "plt.bar(df_precision['Method'], df_precision['Precision'], color=plt.cm.Paired(range(len(df_precision))))\n",
    "plt.xlabel('Method')\n",
    "plt.ylabel('Precision')\n",
    "plt.title('Precision of Baseline Methods and Our Approach')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Recall of Different Methods')"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAoEAAAK9CAYAAABb67ZuAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy89olMNAAAACXBIWXMAAA9hAAAPYQGoP6dpAABJXUlEQVR4nO3de1iUZeL/8c+AMigIYigYkeQhk1IxUELzUGKk5mbruVUOKllrJylbrTyUm1Sm0bW6qa2oaydLrWzzaxlpW0lZHnItj6ViKggeADEhmef3Rz+nJlBRgRHv9+u65vou99zP89wzTn7fPjPzYLMsyxIAAACM4uHuBQAAAKD6EYEAAAAGIgIBAAAMRAQCAAAYiAgEAAAwEBEIAABgICIQAADAQEQgAACAgYhAAAAAAxGBACqFzWbT5MmTnT8vWLBANptNe/bsqbRjfP311+rYsaN8fHxks9m0adOmStv3mdY7bdo0NW3aVJ6enoqIiJAknTp1So899phCQ0Pl4eGhvn37Vto6TNatWzfdcMMNVX6cPXv2yGazacGCBVV+LOBSRgQCNcDpQDl9q1WrlkJCQpSYmKj9+/e7e3nV4pdfftGAAQN05MgRvfjii1q0aJGaNGlS7tw1a9a4PF92u11BQUHq1q2bpk6dqtzc3Aod86OPPtJjjz2mTp06af78+Zo6daokKT09XdOmTVP//v21cOFCjRkzptIeZ2VbsWKFS5yfS7du3WSz2dSiRYty71+1apXzeV2yZMl5r+fAgQOaPHlypQY8gAtTy90LAFBxTz/9tK655hqdPHlSX375pRYsWKDPP/9cW7Zskbe3t7uXV6V++OEH7d27V6+88opGjhxZoW0efPBBtW/fXqWlpcrNzdXatWs1adIkzZgxQ2+99ZZuvfVW59xhw4Zp8ODBstvtzrFPPvlEHh4emjdvnry8vFzGQ0JC9OKLL1beA6wiK1as0KxZs84rBL29vbVr1y6tW7dOHTp0cLnvtddek7e3t06ePHlB6zlw4ICeeuophYWFOc+sAnAPIhCoQXr27KmoqChJ0siRIxUYGKjnnntOy5cv18CBA928uqp16NAhSVL9+vUrvE3nzp3Vv39/l7Fvv/1Wt912m/r166fvv/9ejRs3liR5enrK09OzzDHr1KnjEoCnx89nHediWZZOnjypOnXqVNo+L0azZs106tQpvfHGGy4RePLkSb3zzjvq3bu3li5d6sYVAqgMvB0M1GCdO3eW9OtZst/btm2b+vfvrwYNGsjb21tRUVFavnx5me2PHTumMWPGKCwsTHa7XVdddZXi4+OVl5cnSSopKdHEiRMVGRkpf39/+fj4qHPnzlq9enWlPo5PPvlEnTt3lo+Pj+rXr68777xTW7dudd6fmJiorl27SpIGDBggm82mbt26XdCx2rZtq7S0NB07dkwzZ850jv/xM4E2m03z589XUVGR8+3P03NWr16t7777zjm+Zs0aSZLD4VBaWpquv/56eXt7KygoSKNGjdLRo0dd1hAWFqY77rhDH374oaKiolSnTh3NmTNH0q9/Jg8//LBCQ0Nlt9vVvHlzPffcc3I4HM7tT3+m7YUXXtDcuXPVrFkz2e12tW/fXl9//bXL8zZr1izn4zl9q4ghQ4Zo8eLFLsd9//33deLEiTP+g2P//v0aPny4goKCZLfbdf311ys9Pd15/5o1a9S+fXtJUlJSksvz+nvff/+9brnlFtWtW1chISF6/vnnyxzr0KFDGjFihIKCguTt7a22bdtq4cKFZeYdO3ZMiYmJ8vf3V/369ZWQkKBjx46VmZedna2kpCRdddVVstvtaty4se68885K/UwrcKnhTCBQg53+f1ABAQHOse+++06dOnVSSEiIxo0bJx8fH7311lvq27evli5dqrvuukuSdPz4cXXu3Flbt27V8OHDdeONNyovL0/Lly/XTz/9pMDAQBUUFOhf//qXhgwZouTkZBUWFmrevHmKi4vTunXrKuXtvI8//lg9e/ZU06ZNNXnyZP3888/6xz/+oU6dOmnDhg0KCwvTqFGjFBISoqlTpzrf4g0KCrrgY/bv318jRozQRx99pGeeeabcOYsWLdLcuXO1bt06/etf/5IktWvXTosWLdIzzzyj48ePKzU1VZLUqlUrSdKoUaO0YMECJSUl6cEHH9Tu3bs1c+ZMbdy4UV988YVq167t3P/27ds1ZMgQjRo1SsnJyWrZsqVOnDihrl27av/+/Ro1apSuvvpqrV27VuPHj9fBgweVlpbmssbXX39dhYWFGjVqlGw2m55//nn9+c9/1o8//qjatWtr1KhROnDggFatWqVFixad13N09913a/LkyVqzZo3zbfPXX39d3bt3V6NGjcrMz8nJ0U033SSbzab7779fDRs21P/93/9pxIgRKigo0MMPP6xWrVrp6aef1sSJE3XPPfc4/xHTsWNH536OHj2q22+/XX/+8581cOBALVmyRH/729/UunVr9ezZU5L0888/q1u3btq1a5fuv/9+XXPNNXr77beVmJioY8eO6aGHHpL06xnWO++8U59//rnuvfdetWrVSu+8844SEhLKrL9fv3767rvv9MADDygsLEyHDh3SqlWrlJWVpbCwsPN67oAawwJwyZs/f74lyfr444+t3Nxca9++fdaSJUushg0bWna73dq3b59zbvfu3a3WrVtbJ0+edI45HA6rY8eOVosWLZxjEydOtCRZy5YtK3M8h8NhWZZlnTp1yiouLna57+jRo1ZQUJA1fPhwl3FJ1qRJk8qseffu3Wd9bBEREVajRo2sw4cPO8e+/fZby8PDw4qPj3eOrV692pJkvf3222fdX0Xntm3b1goICDjrehMSEiwfH58y23bt2tW6/vrrXcY+++wzS5L12muvuYyvXLmyzHiTJk0sSdbKlStd5k6ZMsXy8fGxduzY4TI+btw4y9PT08rKyrIsy7J2795tSbKuuOIK68iRI8557733niXJev/9951jo0ePts7nr/rfP7aoqChrxIgRlmX9+ufu5eVlLVy4sNznd8SIEVbjxo2tvLw8l/0NHjzY8vf3t06cOGFZlmV9/fXXliRr/vz55R5bkvXvf//bOVZcXGwFBwdb/fr1c46lpaVZkqxXX33VOVZSUmLFxMRYvr6+VkFBgWVZlvXuu+9akqznn3/eOe/UqVNW586dXdZw9OhRS5I1bdq0Cj9PwOWAt4OBGiQ2NlYNGzZUaGio+vfvLx8fHy1fvlxXXXWVJOnIkSP65JNPNHDgQBUWFiovL095eXk6fPiw4uLitHPnTue3iZcuXaq2bds6zwz+3um3DD09PZ2fh3M4HDpy5IhOnTqlqKgobdiw4aIfz8GDB7Vp0yYlJiaqQYMGzvE2bdqoR48eWrFixUUf40x8fX1VWFhYaft7++235e/vrx49ejif97y8PEVGRsrX17fMW+jXXHON4uLiyuyjc+fOCggIcNlHbGysSktL9d///tdl/qBBg1zOAp8+s/bjjz9WymO6++67tWzZMpWUlGjJkiXy9PQs9/ViWZaWLl2qPn36yLIsl7XHxcUpPz+/wq8XX19fDR061Pmzl5eXOnTo4PKYVqxYoeDgYA0ZMsQ5Vrt2bT344IM6fvy4Pv30U+e8WrVq6b777nPO8/T01AMPPOByzNOf+1yzZk2Zt+6ByxlvBwM1yKxZs3TttdcqPz9f6enp+u9//+vybdZdu3bJsixNmDBBEyZMKHcfhw4dUkhIiH744Qf169fvnMdcuHChpk+frm3btumXX35xjl9zzTUX/Xj27t0rSWrZsmWZ+1q1aqUPP/xQRUVF8vHxuehj/dHx48dVr169Stvfzp07lZ+fX+5bpdJvX2w5rbznb+fOndq8ebMaNmxYoX1cffXVLj+fDsLKCpnBgwfr0Ucf1f/93//ptdde0x133FHuc5abm6tjx45p7ty5mjt3boXWfiZXXXVVmc8tBgQEaPPmzc6f9+7dqxYtWsjDw/U8xum35U+/rvbu3avGjRvL19fXZd4fX292u13PPfecHnnkEQUFBemmm27SHXfcofj4eAUHB1do3UBNRAQCNUiHDh2c3w7u27evbr75Zt19993avn27fH19nR/if/TRR8ucZTqtefPmFT7eq6++qsTERPXt21djx45Vo0aN5OnpqdTU1DJfRqlJfvnlF+3YsaNSL0zscDjUqFEjvfbaa+Xe/8ewK++bwA6HQz169NBjjz1W7j6uvfZal5//+G3m0yzLqsiSz6lx48bq1q2bpk+fri+++OKM3wg+/bobOnRouZ+3k349u1sRVf2YzuThhx9Wnz599O677+rDDz/UhAkTlJqaqk8++UTt2rWr0mMD7kIEAjXU6Ri75ZZbNHPmTI0bN05NmzaV9OtbY7GxsWfdvlmzZtqyZctZ5yxZskRNmzbVsmXLXM7OTJo06eIfgOS82PP27dvL3Ldt2zYFBgZWyVnAJUuW6Oeffz5jKF+IZs2a6eOPP1anTp0u+FIvzZo10/Hjx8/5Z3c+Kvpt4DO5++67NXLkSNWvX1+9evUqd07Dhg1Vr149lZaWnnPtF7se6dfXzebNm+VwOFzOBm7bts15/+n/m5GRoePHj7ucDSzv9Sb9+vw/8sgjeuSRR7Rz505FRERo+vTpevXVVy96zcCliM8EAjVYt27d1KFDB6WlpenkyZNq1KiRunXrpjlz5ujgwYNl5v/+N2X069dP3377rd55550y806fdTl9Vub3Z2G++uorZWZmVsr6GzdurIiICC1cuNDlsh1btmzRRx99dMbouBjffvutHn74YQUEBGj06NGVtt+BAweqtLRUU6ZMKXPfqVOnyr0sSXn7yMzM1IcffljmvmPHjunUqVPnva7TEV2R45enf//+mjRpkv75z3+WuV7iaZ6enurXr5+WLl1a7j8sfv+6u9j1SFKvXr2UnZ2txYsXO8dOnTqlf/zjH/L19XVeTqhXr146deqUXn75Zee80tJS/eMf/3DZ34kTJ8pc/LpZs2aqV6+eiouLL3idwKWOM4FADTd27FgNGDBACxYs0L333qtZs2bp5ptvVuvWrZWcnKymTZsqJydHmZmZ+umnn/Ttt986t1uyZIkGDBig4cOHKzIyUkeOHNHy5cs1e/ZstW3bVnfccYeWLVumu+66S71799bu3bs1e/ZshYeH6/jx45Wy/mnTpqlnz56KiYnRiBEjnJeI8ff3P6/fclGezz77TCdPnlRpaakOHz6sL774QsuXL5e/v7/eeeedSv28V9euXTVq1CilpqZq06ZNuu2221S7dm3t3LlTb7/9tl566aUyF67+o7Fjx2r58uW64447lJiYqMjISBUVFel///uflixZoj179igwMPC81hUZGSnp19+eEhcXJ09PTw0ePLjC21f0z+HZZ5/V6tWrFR0dreTkZIWHh+vIkSPasGGDPv74Yx05ckTSr3FVv359zZ49W/Xq1ZOPj4+io6PP6zOm99xzj+bMmaPExEStX79eYWFhWrJkib744gulpaU5P7fYp08fderUSePGjdOePXsUHh6uZcuWKT8/32V/O3bsUPfu3TVw4ECFh4erVq1aeuedd5STk3NezxVQ47jxm8kAKuj05Uu+/vrrMveVlpZazZo1s5o1a2adOnXKsizL+uGHH6z4+HgrODjYql27thUSEmLdcccd1pIlS1y2PXz4sHX//fdbISEhlpeXl3XVVVdZCQkJzst8OBwOa+rUqVaTJk0su91utWvXzvrPf/5jJSQkWE2aNHHZly7wEjGWZVkff/yx1alTJ6tOnTqWn5+f1adPH+v77793mXMhl4g5fatdu7bVsGFDq0uXLtYzzzxjHTp0qMw2F3uJmNPmzp1rRUZGWnXq1LHq1atntW7d2nrsscesAwcOOOc0adLE6t27d7nbFxYWWuPHj7eaN29ueXl5WYGBgVbHjh2tF154wSopKbEs67dLxJR3SZM//jmcOnXKeuCBB6yGDRtaNpvt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4zJfklatWnXG+QAAACjL7W8Hp6SkKCEhQVFRUerQoYPS0tJUVFSkpKQkSVJ8fLxCQkKUmpoqSXrooYfUtWtXTZ8+Xb1799abb76pb775RnPnznXnwwAAAKhR3B6BgwYNUm5uriZOnKjs7GxFRERo5cqVzi9/ZGVlycPjtxOWHTt21Ouvv64nn3xSjz/+uFq0aKF3331XN9xwg7seAi6C3W7XpEmTyrxlD1wueI3jcsdrvOayWRX5DjEAAAAuK26/WDQAAACqHxEIAABgICIQAADAQEQgAACAgYhAuMjNzdV9992nq6++Wna7XcHBwYqLi9Onn36q4OBgTZ06tcw2AwcO1E033aTS0lJNnjxZNptN9957r8ucTZs2yWazac+ePWc9/untz3Y77Y033pCnp6dGjx5d7r4KCgo0YcIEXX/99apTp46uuOIKtW/fXs8//7yOHj16/k8OLnvneu1NnjxZe/bskc1m06ZNm5zbFRYW6pZbblF4eLh++ukn5/jSpUt16623KiAgQHXq1FHLli01fPhwbdy4scyxf/75ZzVo0ECBgYHO33e+YMGCc67pXP9NwTyJiYnq27dvmfE1a9bIZrNp0aJF8vHx0a5du1zuP3DggAICAjRz5kxJv/6a1gceeEBNmzaV3W5XaGio+vTpU+ZavWvXrlWvXr0UEBAgb29vtW7dWjNmzFBpaanLvNOv2S+//NJlvLi42PlbvNasWVNmvs1mU61atXT11VcrJSXF+d8HKoEF/E7nzp2t6Oho65NPPrH27NljffXVV9bUqVOt9957z3rvvfcsLy8va/Pmzc75b731llWnTh1r27ZtlmVZ1qRJkyxvb2+rVq1a1o4dO5zzNm7caEmydu/efdbjFxYWWgcPHnTerrrqKuvpp592GTute/fu1rhx46yAgADr559/dtnP4cOHrVatWlkhISFWenq69e2331p79uyxPvzwQ2vw4MHWzJkzK+HZwuXm96+ztLQ0y8/Pz2WssLDQ2r17tyXJ2rhxo2VZlnXo0CErMjLSat++vZWXl+fc12OPPWZ5enpaY8aMsf773/9ae/futb755htrypQpVlxcXJljL1q0yLr55putTp06WW+++aZlWZZ14sQJl+PHxMRYycnJLmOnTp2qlucGNUdCQoJ15513lhlfvXq1Jck6evSoddddd1mdOnWySktLnff36tXL6t69u+VwOKzdu3dbV155pRUeHm4tWbLE2r59u7VlyxZr+vTpVsuWLZ3bLFu2zKpVq5aVnJxsbdy40dq9e7f1yiuvWAEBAVb//v0th8PhnCvJCg0Nte655x6Xdb3xxhvW1VdfbUmyVq9e7TJ//vz51sGDB62srCzr/ffftwIDA60nn3yy8p4swxGBcDp69KglyVqzZs0Z5yQmJlrt2rWzSkpKrEOHDlkNGza0XnrpJef9kyZNstq2bWv16NHDGjBggHO8ohH4R02aNLFefPHFMuM//vijVadOHevYsWNWdHS09dprr7ncP2rUKMvHx8fav39/ufv9/V9MQHnmz59v+fv7lxn/fQRmZWVZLVu2tG699VarsLDQOSczM9OS5PLfxu+V9/rr1q2bNXv2bOvll1+2evToUe52Xbt2tR566KELejwwR0Ui8PTf39OmTbMs67fXe1ZWlmVZltWzZ08rJCTEOn78eJn9HD161LIsyzp+/Lh1xRVXWH/+85/LzFm+fLklyfkPGsv6NeqefPJJy8/Pzzpx4oRzvEePHtaECRPKjcB33nnHZb8jRoywevXqVdGnAufA28Fw8vX1la+vr959990znm5/6aWXdPjwYU2ZMkV//etfdcMNN+iBBx4oM+/ZZ5/V0qVL9c0331TJWufPn6/evXvL399fQ4cO1bx585z3ORwOLV68WEOHDj3jL9D+/dvKwIXYvn27OnXqpPDwcK1YsUK+vr7O+9544w35+vrqr3/9a7nb/vH198MPPygzM1MDBw7UwIED9dlnn2nv3r1Vun6YrWHDhpo7d64mTJigVatWacyYMXrppZcUGhqqI0eOaOXKlRo9erR8fHzKbFu/fn1J0kcffaTDhw/r0UcfLTOnT58+uvbaa/XGG2+4jEdGRiosLExLly6V9OsvhPjvf/+rYcOGnXPNO3bs0CeffKLo6OgLeMQoDxEIp1q1amnBggVauHCh6tevr06dOunxxx/X5s2bnXP8/Pw0f/58TZ06VR999JHmz59fblDdeOONGjhwoP72t79V+jodDocWLFigoUOHSpIGDx6szz//XLt375b06+cajx07ppYtW7psFxkZ6QzdIUOGVPq6YJb4+Hg1b95cb7/9dpnflLBjxw41bdpUtWr99kuZZsyY4Xz9+fr6Kj8/33lfenq6evbsqYCAADVo0EBxcXGaP39+tT0WXH7+85//uLzefH191bNnT5c5ffv21cCBA3X77bera9euSkhIkCTt2rVLlmXpuuuuO+sxduzYIUlq1apVufdfd911zjm/N3z4cKWnp0v69XOvvXr1UsOGDcvdx5AhQ+Tr6ytvb2+1bNlS119/vcaPH3/2B48KIwLhol+/fjpw4ICWL1+u22+/XWvWrNGNN96oBQsWOOfceuutuummmzRs2DA1adLkjPv6+9//rs8++0wfffRRpa5x1apVKioqUq9evSRJgYGB6tGjh/MvlTN55513tGnTJsXFxennn3+u1DXBPH/605/02WefadmyZRWaP3z4cG3atElz5sxRUVGRrP//y5pKS0u1cOFC5z9qJGno0KFasGCBHA5Hlawdl79bbrlFmzZtcrn961//KjNvwoQJcjgcevLJJ51j1nn+IrHznT906FBlZmbqxx9/1IIFCzR8+PAzzn3xxRe1adMmffvtt/rPf/6jHTt2VOisISrG7b87GJceb29v9ejRQz169NCECRM0cuRITZo0SYmJic45tWrVcjnLUZ5mzZopOTlZ48aNc3m79mLNmzdPR44cUZ06dZxjDodDmzdv1lNPPaWGDRuqfv362r59u8t2V199tSSpXr16OnbsWKWtB2Z64okn1KZNG919992yLEsDBw503teiRQt9/vnn+uWXX1S7dm1Jv76FVr9+fZdvD0vShx9+qP3792vQoEEu46WlpcrIyFCPHj2q/sHgsuPj46PmzZu7jP3xtSfJ+ff47/8+b9GihWw2m7Zt23bWY1x77bWSpK1bt6pjx45l7t+6davCw8PLjF9xxRW64447NGLECJ08eVI9e/ZUYWFhuccIDg52Po6WLVuqsLBQQ4YM0d///vcyjw/njzOBOKfw8HAVFRVd0LYTJ07Ujh079Oabb1bKWg4fPqz33ntPb775psu/cDdu3KijR4/qo48+koeHhwYOHKhXX31VBw4cqJTjAuWZMGGCJk+erL/85S9avHixc3zIkCE6fvy4/vnPf55zH/PmzdPgwYPLnLUZPHhwpf7jCaio0x9JmDVrVrl/95/+R/Rtt92mBg0aaPr06WXmLF++XDt37jzjR2+GDx+uNWvWKD4+Xp6enhVe2+m5vJtTOTgTCKfDhw9rwIABGj58uNq0aaN69erpm2++0fPPP68777zzgvYZFBSklJQU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",
      "text/plain": [
       "<Figure size 2500x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Recall Bar Chart\n",
    "plt.figure(figsize=(25, 8))\n",
    "\n",
    "plt.subplot(1, 3, 2)\n",
    "plt.bar(df_recall['Method'], df_recall['Recall'], color=plt.cm.Paired(range(len(df_recall))))\n",
    "plt.xlabel('Method')\n",
    "plt.ylabel('Recall')\n",
    "plt.title('Recall of Different Methods')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x2958fbb50>"
      ]
     },
     "execution_count": 85,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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oUOLrD+/nubNmyspKUnp6emaPHmyvv76a23atMllD0deXp5iY2PVsmVLvfTSS1qxYoVefvll1a5dWw8++OAZ36eZM2fK399fCQkJ8vf318qVKzV69GhlZWXpxRdfdOn7559/qmPHjrrjjjvUs2dPLVy4UE888YQaNWqkTp06SZL++usvtW/fXnv27NEjjzyiK664QrNnz9bKlSvPWMfZ5AeCihUrOtu2bt2q1q1bKywsTCNGjJCfn5/ef/99devWTR988IFuv/12SX+fMN+mTRtt27ZNAwYM0LXXXquDBw9q8eLF2rdvn4KDg5WVlaW3335bffr00aBBg3T06FFNnz5dsbGxWrdunZo0aXJe9T/11FOqV6+e3nzzTefhytq1a0ty77Muahs+F/fcc4+efPJJff755xo0aFCB16tUqaLZs2fr2Wef1bFjx5SUlCRJatCggWbPnq1hw4apevXqeuyxx5z9HQ6Hbr31Vq1Zs0b33XefGjRooB9//FGvvPKKduzYoY8++shlGStXrtT777+vIUOGKDg4WBEREUpPT9d1113nDHVVqlTRZ599pnvvvVdZWVkFDnE+99xz8vDw0PDhw5WZmakXXnhBd999t7777jvne5+Zmal9+/Y5D/H6+/sX6z266667dPPNN2vnzp3Oz2vu3Lnq0aOH8/fC6YqzTd5444165JFH9Oqrr+rJJ59UgwYNnO9rvl9//VU9evTQvffeq7i4OCUnJ6t///6KiopSw4YNJUnp6em6/vrrdfz4cT3yyCOqXLmyZs2apVtvvVULFy50bv/F/U7m5uYqNjZWOTk5evjhhxUaGqr9+/frk08+0ZEjRxQYGFis9wwGs4ALbMaMGZYka8WKFdaBAwesvXv3WvPmzbMqV65s+fj4WPv27bMsy7Li4uIsSdaIESNcxn/11VeWJGvOnDku7UuXLnVpP3LkiFWhQgWrZcuW1l9//eXS1+FwOP8dFxdn1ahRw/nz0KFDrYCAAOvUqVNFrsOqVassSdaqVassy7Ks3Nxcq2rVqtbVV1/tsqxPPvnEkmSNHj3aZXmSrHHjxrnMs2nTplZUVFSRy8x3/PjxAm3333+/5evra504ccLZFh0dbUmy3nnnHWdbTk6OFRoaanXv3t3ZNmnSJEuS9f777zvbsrOzrTp16risY1EK+zwXLlxoValSxbLb7dbevXudfdu3b281atTIpU6Hw2Fdf/31Vt26dZ1to0ePtiRZixYtKrC8/M/u1KlTVk5Ojstrf/75pxUSEmINGDDApV2SlZiYWKDm1NTUYq3b//73P2fbuXzW/96G3VnevwUGBlpNmzZ1/pyYmGj9+1d3dHS01bBhwwJja9SoYXXp0sWlbfbs2ZaHh4f11VdfubRPmzbNkmR9/fXXzjZJloeHh7V161aXvvfee69VrVo16+DBgy7tvXv3tgIDA53bbP73pkGDBi6f3eTJky1J1o8//uhs69Kli8v38mzy1+3UqVNWaGioNX78eMuyLOunn36yJFlffPFFoe9vcbfJBQsWFPl9qFGjhiXJ+vLLL51tGRkZlt1utx577DFn26OPPmpJcnmvjx49atWsWdOKiIiw8vLyLMsq/ndy06ZNliRrwYIFxX6fcHnh8CgumpiYGFWpUkXh4eHq3bu3/P399eGHHyosLMyl37/3PC1YsECBgYHq0KGDDh486JyioqLk7+/vPDy2fPlyHT16VCNGjChwzs+/b5FwuqCgIGVnZ2v58uXFXpf169crIyNDDz30kMuyunTpovr16xd6+OOBBx5w+blNmzb67bffzrosHx8f57+PHj2qgwcPqk2bNjp+/Lh+/vlnl77+/v7q27ev82cvLy+1aNHCZTmffvqpqlWrph49ejjbfH19dd999521ltOd/nn26NFDfn5+Wrx4sapXry5JOnz4sFauXKmePXs66z548KAOHTqk2NhY/fLLL87Dix988IEaN27s3PNwuvzPztPT03khiMPh0OHDh3Xq1Ck1a9ZMGzdudKt2d5zLZ322vafu8Pf3L/ZVpMWxYMECNWjQQPXr13f5PuWfrvDvw83R0dGKjIx0/mxZlj744AN17dpVlmW5zCM2NlaZmZkFPo/4+HiXi3jyD6UXZ/s/G09PT/Xs2VPvvfeepL8vQAgPD3cu43TubJNnExkZ6bKMKlWqqF69egW+ay1atNANN9zgbPP399d9992nXbt26aeffnL2K853Mn9P2rJly3T8+PFi1YnLC4dHcdFMmTJFV111lcqVK6eQkBDVq1evwIn95cqVc/6nn++XX35RZmamqlatWuh8808ezz/cevXVV7tV10MPPaT3339fnTp1UlhYmG6++Wb17NlTHTt2LHLM7t27JUn16tUr8Fr9+vW1Zs0alzZvb29VqVLFpa1ixYqFnpP3b1u3btXTTz+tlStXKisry+W1f5/HUr169QIBtWLFivrhhx9caq9Tp06BfoWty5nkf56ZmZlKTk7Wl19+6XKBx6+//irLsjRq1CiNGjWq0HlkZGQoLCxMO3fuVPfu3c+6zFmzZunll1/Wzz//rJMnTzrba9as6Vbt7nD3sy5sGz4fx44dK3LbPxe//PKLtm3bVmB7zJf/fcr37/f2wIEDOnLkiN588029+eabxZrHlVde6fJz/iH04mz/xXHXXXfp1Vdf1ffff6+5c+eqd+/ehf6h5s42eTb/Xiep4Hd69+7datmyZYF++YdZd+/erauvvrrY38maNWsqISFBEydO1Jw5c9SmTRvdeuut6tu3L4dGywhCGy6aFi1aqFmzZmfsY7fbCwQ5h8OhqlWras6cOYWOKeo/n+KqWrWqNm/erGXLlumzzz7TZ599phkzZqhfv36aNWvWec07n6en5zmNO3LkiKKjoxUQEKBx48apdu3a8vb21saNG/XEE08UuHVJUcuxLOucln8mp3+e3bp10w033KC77rpL27dvl7+/v7O24cOHF3lCeJ06dYq9vHfffVf9+/dXt27d9J///EdVq1aVp6enkpKSClz8UJoK24bP1b59+5SZmenW+3Q2DodDjRo10sSJEwt9PTw83OXn0/f05o+XpL59+zov3Pi3029RIl347bJly5aqXbu284r0os5fLclt8mJ+10738ssvq3///vr444/1+eef65FHHlFSUpK+/fbbEv1jAZcmQhsuebVr19aKFSvUunXrAv+B/LufJG3ZssXt/+S8vLzUtWtXde3aVQ6HQw899JDeeOMNjRo1qtB51ahRQ5K0fft252GlfNu3b3e+fr5Wr16tQ4cOadGiRbrxxhud7flX3J6LGjVqaMuWLbIsy+Uv++3bt5/zPPPDU7t27fTaa69pxIgRqlWrlqS/b7Fytnue1a5dW1u2bDljn4ULF6pWrVpatGiRS90X+h5kF+uzLszs2bMlqciAcS5q166t77//Xu3btz/jaQNFqVKliipUqKC8vLwSvZfdudRyuj59+uiZZ55RgwYNirwoxZ1t8nzrkf7edgr7XuWf1pC/7bj7nWzUqJEaNWqkp59+Wt98841at26tadOm6ZlnnjnvmnFp45w2XPJ69uypvLw8jR8/vsBrp06dcj5m6Oabb1aFChWUlJRU4F5SZ/rr99ChQy4/e3h4OPcUFHUbjGbNmqlq1aqaNm2aS5/PPvtM27ZtK7H7Q+X/NX96/bm5uXr99dfPeZ6dO3fW77//roULFzrbjh8/XuShruJq27atWrRooUmTJunEiROqWrWq2rZtqzfeeEN//PFHgf4HDhxw/rt79+76/vvv9eGHHxbol7/uhb0X3333ndauXXtedZ/Nxfqs/23lypUaP368atasec63DSlMz549tX//fr311lsFXvvrr7/Oel85T09Pde/eXR988EGhQfv0z9Udfn5+53XbioEDByoxMVEvv/xykX3c2Sbzn4RxPo8x69y5s9atW+eyjWZnZ+vNN99URESE81zB4n4ns7KydOrUKZe2Ro0aycPD47xv2QMzsKcNl7zo6Gjdf//9SkpK0ubNm3XzzTerfPny+uWXX7RgwQJNnjxZPXr0UEBAgF555RUNHDhQzZs311133aWKFSvq+++/1/Hjx4s81Dlw4EAdPnxYN910k6pXr67du3frv//9r5o0aeJyif/pypcvr+eff17x8fGKjo5Wnz59nLeBiIiIcD5G6Hxdf/31qlixouLi4vTII4/IZrNp9uzZ53UIZtCgQXrttdfUr18/bdiwQdWqVdPs2bNL5KkU//nPf3TnnXdq5syZeuCBBzRlyhTdcMMNatSokQYNGqRatWopPT1da9eu1b59+/T99987xy1cuFB33nmnBgwYoKioKB0+fFiLFy/WtGnT1LhxY91yyy1atGiRbr/9dnXp0kWpqamaNm2aIiMjdezYsfOuvSgX47P+7LPP9PPPP+vUqVNKT0/XypUrtXz5ctWoUUOLFy8u0SdM3HPPPXr//ff1wAMPaNWqVWrdurXy8vL0888/6/3339eyZcvOehrDc889p1WrVqlly5YaNGiQIiMjdfjwYW3cuFErVqzQ4cOH3a4rKipK8+fPV0JCgpo3by5/f3917dq12ONr1Kjh8rzZohR3m2zSpIk8PT31/PPPKzMzU3a7XTfddJNb5xeOGDFC7733njp16qRHHnlElSpV0qxZs5SamqoPPvjAeRi9uN/JlStXasiQIbrzzjt11VVX6dSpU5o9e7YzSKMMKI1LVlG2FOe2Bpb19+0S/Pz8inz9zTfftKKioiwfHx+rQoUKVqNGjazHH3/c+v333136LV682Lr++ust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/eXt7a169eqpYcOGGjly5JlXHsVCaLsMdO/eXb///rsWL16sjh07avXq1br22ms1c+ZMZ5+bbrpJ1113ne655x7VqFGjyHk988wz+uqrr/T555+XaI3Lly9Xdna2OnfuLEkKDg5Whw4dnL8EivLhhx9q8+bNio2N1V9//VWiNaFsufXWW/XVV19p0aJFxeo/YMAAbd68WW+88Yays7Nl/f+Hx+Tl5WnWrFnOP0AkqW/fvpo5c6YcDscFqR1lQ7t27bR582aX6e233y7Qb9SoUXI4HHr66aedbZabDzdyt3/fvn21du1a/fbbb5o5c6YGDBhQZN9XXnlFmzdv1vfff69PPvlEO3bsKNZeOZyd288exaXJ29tbHTp0UIcOHTRq1CgNHDhQiYmJ6t+/v7NPuXLlXPYkFKZ27doaNGiQRowY4XL48nxNnz5dhw8flo+Pj7PN4XDohx9+0NixY1WlShUFBQVp+/btLuOuvPJKSVKFChV05MiREqsHZc9TTz2la665RnfddZcsy1LPnj2dr9WtW1dr1qzRyZMnVb58eUl/H04KCgpyubpUkpYtW6b9+/erV69eLu15eXlKSUlRhw4dLvzK4LLk5+enOnXquLT9e/uT5Pw9fvrv87p168pms+nnn38+4zKuuuoqSdK2bdt0/fXXF3h927ZtioyMLNBeuXJl3XLLLbr33nt14sQJderUSUePHi10GaGhoc71qFevno4ePao+ffromWeeKbB+cA972i5TkZGRys7OPqexo0eP1o4dOzRv3rwSqeXQoUP6+OOPNW/ePJe/IDdt2qQ///xTn3/+uTw8PNSzZ0+9++67+v3330tkucC/jRo1SmPGjNHdd9+t+fPnO9v79OmjY8eO6fXXXz/rPKZPn67evXsX2CPSu3fvEv1DB3BH/mH6KVOmFPq7P/+P3ptvvlmVKlXSyy+/XKDP4sWL9csvvxR5KsqAAQO0evVq9evXT56ensWuLb8vR0vOH3vaDHfo0CHdeeedGjBggK655hpVqFBB69ev1wsvvKDbbrvtnOYZEhKihIQEvfjiiyVS4+zZs1W5cmX17NmzwLl0nTt31vTp09WxY0dNmDBBq1evVosWLTRu3Dg1a9ZMfn5++uGHH7R27VpdffXVJVIPyrannnpKnp6euvvuu+VwONSnTx+1atVKjz32mB577DHt3r1bd9xxh8LDw/XHH39o+vTpstls8vDw0IEDB/R///d/Wrx4cYHtsV+/frr99tt1+PBhVapUqZTWDmXZlClT1Lp1a+fv0GuuuUanTp3S8uXLNXXqVG3btk1+fn5644031Lt3b913330aMmSIAgIClJKSov/85z/q0aOHy17o03Xs2FEHDhxQQEDAGes4cuSI0tLS5HA49Msvv2jcuHG66qqrijyPDsVHaDOcv7+/WrZsqVdeeUU7d+7UyZMnFR4erkGDBunJJ5885/kOHz5cU6dO1YkTJ867xuTkZN1+++2FXvzQvXt33XPPPTp48KCCg4O1bt06Pf/883rxxReVmpoqDw8P1a1bV7169dKjjz563rUAkjRixAh5eHjonnvukWVZuuuuu/TSSy+pRYsWmjp1qpKTk3X8+HGFhIToxhtv1Nq1axUQEKCXX35Zfn5+at++fYF5tm/fXj4+Pnr33Xf1yCOPlMJaoayrVauWNm7cqGeffVaPPfaY/vjjD1WpUkVRUVGaOnWqs1+PHj20atUqPfvss2rTpo1OnDihunXr6qmnntKjjz5a5JX6NptNwcHBZ60jPj7e2T80NFQ33nijJkyYcNbTc3B2NsvdsxEBAABw0XFOGwAAgAEIbSiWBx54oMD9g/Knfz+zFAAAlDwOj6JYMjIylJWVVehrAQEBqlq16kWuCACAsoXQBgAAYAAOjwIAABiA0AYAAGAAQhsAAIABCG0AAAAGILQBQCHatm17QZ7CMWbMGDVp0qTE5wvg8kdoA2Cc/v37y2azFXqPwMGDB8tms6l///7Fmtfq1atls9mcD9QGgEsVoQ2AkcLDwzVv3jz99ddfzrYTJ05o7ty5uvLKK0uxMgC4MAhtAIx07bXXKjw8XIsWLXK2LVq0SFdeeaWaNm3qbHM4HEpKSlLNmjXl4+Ojxo0ba+HChZKkXbt2qV27dpKkihUrFthD53A49Pjjj6tSpUoKDQ3VmDFjXGrYs2ePbrvtNvn7+ysgIEA9e/ZUenq6S5/nnntOISEhqlChgu69916dOHGihN8JAGUFoQ2AsQYMGKAZM2Y4f05OTlZ8fLxLn6SkJL3zzjuaNm2atm7dqmHDhqlv37764osvFB4erg8++ECStH37dv3xxx+aPHmyc+ysWbPk5+en7777Ti+88ILGjRun5cuXS/o70N122206fPiwvvjiCy1fvly//fabevXq5Rz//vvva8yYMZowYYLWr1+vatWq6fXXX7+QbwmAyxhPRABgnP79++vIkSN66623FB4eru3bt0uS6tevr71792rgwIEKCgrSG2+8oUqVKmnFihVq1aqVc/zAgQN1/PhxzZ07V6tXr1a7du30559/KigoyNmnbdu2ysvL01dffeVsa9GihW666SY999xzWr58uTp16qTU1FSFh4dLkn766Sc1bNhQ69atU/PmzXX99deradOmmjJlinMe1113nU6cOKHNmzdf2DcJwGWnXGkXAADnqkqVKurSpYtmzpwpy7LUpUsXBQcHO1//9ddfdfz4cXXo0MFlXG5urssh1KJcc801Lj9Xq1ZNGRkZkqRt27YpPDzcGdgkKTIyUkFBQdq2bZuaN2+ubdu2FbhYolWrVlq1apXb6woAhDYARhswYICGDBkiSS57tCTp2LFjkqQlS5YoLCzM5TW73X7WeZcvX97lZ5vNJofDcT7lAsA545w2AEbr2LGjcnNzdfLkScXGxrq8FhkZKbvdrj179qhOnTouU/4eMi8vL0lSXl6eW8tt0KCB9u7dq7179zrbfvrpJx05ckSRkZHOPt99953LuG+//dbtdQQAiT1tAAzn6empbdu2Of99ugoVKmj48OEaNmyYHA6HbrjhBmVmZurrr79WQECA4uLiVKNGDdlsNn3yySfq3LmzfHx85O/vf9blxsTEqFGjRrr77rs1adIknTp1Sg899JCio6PVrFkzSdLQoUPVv39/NWvWTK1bt9acOXO0detW1apVq+TfCACXPfa0ATBeQECAAgICCn1t/PjxGjVqlJKSktSgQQN17NhRS5YsUc2aNSVJYWFhGjt2rEaMGKGQkBDnodazsdls+vjjj1WxYkXdeOONiomJUa1atTR//nxnn169emnUqFF6/PHHFRUVpd27d+vBBx88/xUGUCZx9SgAAIAB2NMGAABgAEIbAACAAQhtAAAABiC0AQAAGIDQBgAAYABCGwAAgAEIbQAAAAYgtAEAABiA0AYAAGAAQhsAAIABCG0AAAAG+H+aQvz+YdEnyAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 2500x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "# Combined Precision and Recall Bar Chart with bars plotted one after the other in pink and purple\n",
    "\n",
    "plt.figure(figsize=(25, 8))\n",
    "plt.subplot(1, 3, 3)\n",
    "pos = list(range(len(df_combined['Method'])))\n",
    "width = 0.4\n",
    "\n",
    "# Plotting the bars in pink (for precision) and purple (for recall)\n",
    "for i, p in enumerate(pos):\n",
    "    plt.bar(p, df_combined.iloc[i]['Precision'], width, color='pink', label='Precision' if i == 0 else \"\")\n",
    "    plt.bar(p + width, df_combined.iloc[i]['Recall'], width, color='purple', label='Recall' if i == 0 else \"\")\n",
    "\n",
    "plt.xlabel('Method')\n",
    "plt.title('Precision and Recall for Different Methods')\n",
    "plt.xticks([p + width/2 for p in pos], df_combined['Method'])\n",
    "plt.legend()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
