{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b94d76f6-988d-4938-a7fc-df484f940628",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Using a slow image processor as `use_fast` is unset and a slow processor was saved with this model. `use_fast=True` will be the default behavior in v4.52, even if the model was saved with a slow processor. This will result in minor differences in outputs. You'll still be able to use a slow processor with `use_fast=False`.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "46cbd3ad92fc469c95ae71ea99282cae",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Loading checkpoint shards:   0%|          | 0/2 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from src.qwen2_5.fa_model import Qwen2_5_VLForConditionalGenerationWithHeatmap\n",
    "from transformers import AutoProcessor\n",
    "\n",
    "\n",
    "model_name = \"AnonResearcher/Qwen2.5-VL\"\n",
    "processor = AutoProcessor.from_pretrained(model_name)\n",
    "\n",
    "base_model_load_kwargs = {\n",
    "        \"torch_dtype\": \"bfloat16\",\n",
    "        \"device_map\": \"cuda\",\n",
    "        \"attn_implementation\": \"flash_attention_2\",\n",
    "        \"trust_remote_code\": True\n",
    "    }\n",
    "local_model = Qwen2_5_VLForConditionalGenerationWithHeatmap.from_pretrained(\n",
    "    model_name, **base_model_load_kwargs\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ca27f416-10c8-44ac-a7b6-537ec55d10dc",
   "metadata": {},
   "source": [
    "## auxillary functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "af7a1ab8-5439-4479-80a4-10a6c8fe2a76",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from transformers import AutoTokenizer, AutoProcessor\n",
    "from qwen_vl_utils import process_vision_info\n",
    "\n",
    "\n",
    "refine_text = lambda text: text[len(\"assistant\\n\"):] if text.startswith(\"assistant\\n\") else text\n",
    "\n",
    "def gen_inputs(inputs, max_new_tokens=1000):\n",
    "    generated_ids = local_model.generate(**inputs, max_new_tokens=max_new_tokens)\n",
    "    generated_ids_trimmed = [\n",
    "        out_ids[len(in_ids) :] for in_ids, out_ids in zip(inputs.input_ids, generated_ids)\n",
    "    ]\n",
    "    output_text = processor.batch_decode(\n",
    "        generated_ids_trimmed, skip_special_tokens=True, clean_up_tokenization_spaces=False\n",
    "    )\n",
    "\n",
    "    output_text = [refine_text(out) for out in output_text]\n",
    "    return output_text, generated_ids, generated_ids_trimmed\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "7d8b39fe-2a99-4f74-8f98-35acca316eab",
   "metadata": {},
   "outputs": [],
   "source": [
    "from vlm_injector import InjectionExperiment\n",
    "from src.common.dataset import DataCollator\n",
    "\n",
    "\n",
    "config = \"/workspace/config/qwen2.5_heat.yaml\"\n",
    "experiment = InjectionExperiment(config)\n",
    "experiment.prepare_dataset()\n",
    "experiment.cfg.dataset.kwargs.calib_prob = 0.0\n",
    "data_collator = DataCollator(processor, **experiment.cfg.dataset.kwargs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "fb0a33a9-c860-448f-aaad-7445960b9144",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "\n",
    "\n",
    "def get_batch_outputs(start=0, batch_size=10):\n",
    "    batch = experiment.eval_dataset.select(range(start, min(start+batch_size, len(experiment.eval_dataset))))\n",
    "    inputs = data_collator.generation_call(batch, True)\n",
    "    \n",
    "    with torch.no_grad():\n",
    "        output_text, _, _ = gen_inputs(inputs.to(\"cuda\"))\n",
    "        del inputs[\"heatmap_flat\"]\n",
    "        pure_output_text, _, _ = gen_inputs(inputs.to(\"cuda\"))\n",
    "    return output_text, pure_output_text\n",
    "\n",
    "# get_batch_outputs()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "4a29cf79-cd40-4301-a57f-6334e0b249e8",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████| 4/4 [00:50<00:00, 12.58s/it]\n"
     ]
    }
   ],
   "source": [
    "from tqdm import tqdm\n",
    "\n",
    "batch_size = 50\n",
    "output_texts, pure_output_texts = [], []\n",
    "\n",
    "for start in tqdm(range(0, len(experiment.eval_dataset), batch_size)):\n",
    "    output_text, pure_output_text = get_batch_outputs(start, batch_size)\n",
    "    output_texts.extend(output_text)\n",
    "    pure_output_texts.extend(pure_output_text)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "96822176-7c7c-4a2f-a6f9-cd7ab52315ad",
   "metadata": {},
   "source": [
    "## calculate metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "8b85207e-668d-4753-890c-8618928f03da",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Hit:1 http://archive.ubuntu.com/ubuntu jammy InRelease\n",
      "Hit:2 https://developer.download.nvidia.com/compute/cuda/repos/ubuntu2204/x86_64  InRelease\n",
      "0% [Waiting for headers] [Connecting to security.ubuntu.com (91.189.91.81)]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "huggingface/tokenizers: The current process just got forked, after parallelism has already been used. Disabling parallelism to avoid deadlocks...\n",
      "To disable this warning, you can either:\n",
      "\t- Avoid using `tokenizers` before the fork if possible\n",
      "\t- Explicitly set the environment variable TOKENIZERS_PARALLELISM=(true | false)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Get:3 http://archive.ubuntu.com/ubuntu jammy-updates InRelease [128 kB]    \n",
      "Get:4 http://security.ubuntu.com/ubuntu jammy-security InRelease [129 kB]  \n",
      "Get:5 http://archive.ubuntu.com/ubuntu jammy-backports InRelease [127 kB]\n",
      "Get:6 http://archive.ubuntu.com/ubuntu jammy-updates/universe amd64 Packages [1552 kB]\n",
      "Get:7 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 Packages [3255 kB]\n",
      "Get:8 http://security.ubuntu.com/ubuntu jammy-security/main amd64 Packages [2944 kB]\n",
      "Get:9 http://security.ubuntu.com/ubuntu jammy-security/universe amd64 Packages [1245 kB]\n",
      "Fetched 9380 kB in 2s (5674 kB/s)                         \n",
      "Reading package lists... Done\n",
      "Reading package lists... 4%"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "huggingface/tokenizers: The current process just got forked, after parallelism has already been used. Disabling parallelism to avoid deadlocks...\n",
      "To disable this warning, you can either:\n",
      "\t- Avoid using `tokenizers` before the fork if possible\n",
      "\t- Explicitly set the environment variable TOKENIZERS_PARALLELISM=(true | false)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Reading package lists... Done\n",
      "Building dependency tree... Done\n",
      "Reading state information... Done\n",
      "The following package was automatically installed and is no longer required:\n",
      "  nsight-compute-2023.1.0\n",
      "Use 'apt autoremove' to remove it.\n",
      "The following additional packages will be installed:\n",
      "  at-spi2-core ca-certificates-java dbus-user-session dconf-gsettings-backend\n",
      "  dconf-service default-jre-headless fonts-dejavu-extra\n",
      "  gsettings-desktop-schemas java-common libatk-bridge2.0-0 libatk-wrapper-java\n",
      "  libatk-wrapper-java-jni libatk1.0-0 libatk1.0-data libatspi2.0-0\n",
      "  libavahi-client3 libavahi-common-data libavahi-common3 libcups2 libdconf1\n",
      "  libfontenc1 libgif7 liblcms2-2 libnspr4 libnss3 libpcsclite1 libxaw7\n",
      "  libxcomposite1 libxft2 libxkbfile1 libxmu6 libxmuu1 libxpm4 libxt6 libxtst6\n",
      "  libxxf86dga1 openjdk-11-jre openjdk-11-jre-headless session-migration\n",
      "  x11-utils\n",
      "Suggested packages:\n",
      "  cups-common liblcms2-utils pcscd libnss-mdns fonts-ipafont-gothic\n",
      "  fonts-ipafont-mincho fonts-wqy-microhei | fonts-wqy-zenhei fonts-indic\n",
      "  mesa-utils\n",
      "The following NEW packages will be installed:\n",
      "  at-spi2-core ca-certificates-java dbus-user-session dconf-gsettings-backend\n",
      "  dconf-service default-jre default-jre-headless fonts-dejavu-extra\n",
      "  gsettings-desktop-schemas java-common libatk-bridge2.0-0 libatk-wrapper-java\n",
      "  libatk-wrapper-java-jni libatk1.0-0 libatk1.0-data libatspi2.0-0\n",
      "  libavahi-client3 libavahi-common-data libavahi-common3 libcups2 libdconf1\n",
      "  libfontenc1 libgif7 liblcms2-2 libnspr4 libnss3 libpcsclite1 libxaw7\n",
      "  libxcomposite1 libxft2 libxkbfile1 libxmu6 libxmuu1 libxpm4 libxt6 libxtst6\n",
      "  libxxf86dga1 openjdk-11-jre openjdk-11-jre-headless session-migration\n",
      "  x11-utils\n",
      "0 upgraded, 41 newly installed, 0 to remove and 74 not upgraded.\n",
      "Need to get 48.2 MB of archives.\n",
      "After this operation, 195 MB of additional disk space will be used.\n",
      "Get:1 http://archive.ubuntu.com/ubuntu jammy/main amd64 libxmuu1 amd64 2:1.1.3-3 [10.2 kB]\n",
      "Get:2 http://archive.ubuntu.com/ubuntu jammy/main amd64 libatspi2.0-0 amd64 2.44.0-3 [80.9 kB]\n",
      "Get:3 http://archive.ubuntu.com/ubuntu jammy/main amd64 libxtst6 amd64 2:1.2.3-1build4 [13.4 kB]\n",
      "Get:4 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 dbus-user-session amd64 1.12.20-2ubuntu4.1 [9442 B]\n",
      "Get:5 http://archive.ubuntu.com/ubuntu jammy/main amd64 libdconf1 amd64 0.40.0-3 [40.5 kB]\n",
      "Get:6 http://archive.ubuntu.com/ubuntu jammy/main amd64 dconf-service amd64 0.40.0-3 [28.5 kB]\n",
      "Get:7 http://archive.ubuntu.com/ubuntu jammy/main amd64 dconf-gsettings-backend amd64 0.40.0-3 [22.8 kB]\n",
      "Get:8 http://archive.ubuntu.com/ubuntu jammy/main amd64 session-migration amd64 0.3.6 [9774 B]\n",
      "Get:9 http://archive.ubuntu.com/ubuntu jammy/main amd64 gsettings-desktop-schemas all 42.0-1ubuntu1 [31.1 kB]\n",
      "Get:10 http://archive.ubuntu.com/ubuntu jammy/main amd64 at-spi2-core amd64 2.44.0-3 [54.4 kB]\n",
      "Get:11 http://archive.ubuntu.com/ubuntu jammy/main amd64 java-common all 0.72build2 [6782 B]\n",
      "Get:12 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 libavahi-common-data amd64 0.8-5ubuntu5.2 [23.8 kB]\n",
      "Get:13 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 libavahi-common3 amd64 0.8-5ubuntu5.2 [23.9 kB]\n",
      "Get:14 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 libavahi-client3 amd64 0.8-5ubuntu5.2 [28.0 kB]\n",
      "Get:15 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 libcups2 amd64 2.4.1op1-1ubuntu4.11 [263 kB]\n",
      "Get:16 http://archive.ubuntu.com/ubuntu jammy/main amd64 liblcms2-2 amd64 2.12~rc1-2build2 [159 kB]\n",
      "Get:17 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 libnspr4 amd64 2:4.35-0ubuntu0.22.04.1 [119 kB]\n",
      "Get:18 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 libnss3 amd64 2:3.98-0ubuntu0.22.04.2 [1347 kB]\n",
      "Get:19 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 libpcsclite1 amd64 1.9.5-3ubuntu1 [19.8 kB]\n",
      "Get:20 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 openjdk-11-jre-headless amd64 11.0.27+6~us1-0ubuntu1~22.04 [42.6 MB]\n",
      "Get:21 http://archive.ubuntu.com/ubuntu jammy/main amd64 default-jre-headless amd64 2:1.11-72build2 [3042 B]\n",
      "Get:22 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 ca-certificates-java all 20190909ubuntu1.2 [12.1 kB]\n",
      "Get:23 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 libgif7 amd64 5.1.9-2ubuntu0.1 [33.9 kB]\n",
      "Get:24 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 openjdk-11-jre amd64 11.0.27+6~us1-0ubuntu1~22.04 [214 kB]\n",
      "Get:25 http://archive.ubuntu.com/ubuntu jammy/main amd64 default-jre amd64 2:1.11-72build2 [896 B]\n",
      "Get:26 http://archive.ubuntu.com/ubuntu jammy/main amd64 fonts-dejavu-extra all 2.37-2build1 [2041 kB]\n",
      "Get:27 http://archive.ubuntu.com/ubuntu jammy/main amd64 libatk1.0-data all 2.36.0-3build1 [2824 B]\n",
      "Get:28 http://archive.ubuntu.com/ubuntu jammy/main amd64 libatk1.0-0 amd64 2.36.0-3build1 [51.9 kB]\n",
      "Get:29 http://archive.ubuntu.com/ubuntu jammy/main amd64 libatk-bridge2.0-0 amd64 2.38.0-3 [66.6 kB]\n",
      "Get:30 http://archive.ubuntu.com/ubuntu jammy/main amd64 libfontenc1 amd64 1:1.1.4-1build3 [14.7 kB]\n",
      "Get:31 http://archive.ubuntu.com/ubuntu jammy/main amd64 libxt6 amd64 1:1.2.1-1 [177 kB]\n",
      "Get:32 http://archive.ubuntu.com/ubuntu jammy/main amd64 libxmu6 amd64 2:1.1.3-3 [49.6 kB]\n",
      "Get:33 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 libxpm4 amd64 1:3.5.12-1ubuntu0.22.04.2 [36.7 kB]\n",
      "Get:34 http://archive.ubuntu.com/ubuntu jammy/main amd64 libxaw7 amd64 2:1.0.14-1 [191 kB]\n",
      "Get:35 http://archive.ubuntu.com/ubuntu jammy/main amd64 libxcomposite1 amd64 1:0.4.5-1build2 [7192 B]\n",
      "Get:36 http://archive.ubuntu.com/ubuntu jammy/main amd64 libxft2 amd64 2.3.4-1 [41.8 kB]\n",
      "Get:37 http://archive.ubuntu.com/ubuntu jammy/main amd64 libxkbfile1 amd64 1:1.1.0-1build3 [71.8 kB]\n",
      "Get:38 http://archive.ubuntu.com/ubuntu jammy/main amd64 libxxf86dga1 amd64 2:1.1.5-0ubuntu3 [12.6 kB]\n",
      "Get:39 http://archive.ubuntu.com/ubuntu jammy/main amd64 x11-utils amd64 7.7+5build2 [206 kB]\n",
      "Get:40 http://archive.ubuntu.com/ubuntu jammy/main amd64 libatk-wrapper-java all 0.38.0-5build1 [53.1 kB]\n",
      "Get:41 http://archive.ubuntu.com/ubuntu jammy/main amd64 libatk-wrapper-java-jni amd64 0.38.0-5build1 [49.0 kB]\n",
      "Fetched 48.2 MB in 5s (10.3 MB/s)                   \n",
      "debconf: delaying package configuration, since apt-utils is not installed\n",
      "Selecting previously unselected package libxmuu1:amd64.\n",
      "(Reading database ... 25836 files and directories currently installed.)\n",
      "Preparing to unpack .../00-libxmuu1_2%3a1.1.3-3_amd64.deb ...\n",
      "Unpacking libxmuu1:amd64 (2:1.1.3-3) ...\n",
      "Selecting previously unselected package libatspi2.0-0:amd64.\n",
      "Preparing to unpack .../01-libatspi2.0-0_2.44.0-3_amd64.deb ...\n",
      "Unpacking libatspi2.0-0:amd64 (2.44.0-3) ...\n",
      "Selecting previously unselected package libxtst6:amd64.\n",
      "Preparing to unpack .../02-libxtst6_2%3a1.2.3-1build4_amd64.deb ...\n",
      "Unpacking libxtst6:amd64 (2:1.2.3-1build4) ...\n",
      "Selecting previously unselected package dbus-user-session.\n",
      "Preparing to unpack .../03-dbus-user-session_1.12.20-2ubuntu4.1_amd64.deb ...\n",
      "Unpacking dbus-user-session (1.12.20-2ubuntu4.1) ...\n",
      "Selecting previously unselected package libdconf1:amd64.\n",
      "Preparing to unpack .../04-libdconf1_0.40.0-3_amd64.deb ...\n",
      "Unpacking libdconf1:amd64 (0.40.0-3) ...\n",
      "Selecting previously unselected package dconf-service.\n",
      "Preparing to unpack .../05-dconf-service_0.40.0-3_amd64.deb ...\n",
      "Unpacking dconf-service (0.40.0-3) ...\n",
      "Selecting previously unselected package dconf-gsettings-backend:amd64.\n",
      "Preparing to unpack .../06-dconf-gsettings-backend_0.40.0-3_amd64.deb ...\n",
      "Unpacking dconf-gsettings-backend:amd64 (0.40.0-3) ...\n",
      "Selecting previously unselected package session-migration.\n",
      "Preparing to unpack .../07-session-migration_0.3.6_amd64.deb ...\n",
      "Unpacking session-migration (0.3.6) ...\n",
      "Selecting previously unselected package gsettings-desktop-schemas.\n",
      "Preparing to unpack .../08-gsettings-desktop-schemas_42.0-1ubuntu1_all.deb ...\n",
      "Unpacking gsettings-desktop-schemas (42.0-1ubuntu1) ...\n",
      "Selecting previously unselected package at-spi2-core.\n",
      "Preparing to unpack .../09-at-spi2-core_2.44.0-3_amd64.deb ...\n",
      "Unpacking at-spi2-core (2.44.0-3) ...\n",
      "Selecting previously unselected package java-common.\n",
      "Preparing to unpack .../10-java-common_0.72build2_all.deb ...\n",
      "Unpacking java-common (0.72build2) ...\n",
      "Selecting previously unselected package libavahi-common-data:amd64.\n",
      "Preparing to unpack .../11-libavahi-common-data_0.8-5ubuntu5.2_amd64.deb ...\n",
      "Unpacking libavahi-common-data:amd64 (0.8-5ubuntu5.2) ...\n",
      "Selecting previously unselected package libavahi-common3:amd64.\n",
      "Preparing to unpack .../12-libavahi-common3_0.8-5ubuntu5.2_amd64.deb ...\n",
      "Unpacking libavahi-common3:amd64 (0.8-5ubuntu5.2) ...\n",
      "Selecting previously unselected package libavahi-client3:amd64.\n",
      "Preparing to unpack .../13-libavahi-client3_0.8-5ubuntu5.2_amd64.deb ...\n",
      "Unpacking libavahi-client3:amd64 (0.8-5ubuntu5.2) ...\n",
      "Selecting previously unselected package libcups2:amd64.\n",
      "Preparing to unpack .../14-libcups2_2.4.1op1-1ubuntu4.11_amd64.deb ...\n",
      "Unpacking libcups2:amd64 (2.4.1op1-1ubuntu4.11) ...\n",
      "Selecting previously unselected package liblcms2-2:amd64.\n",
      "Preparing to unpack .../15-liblcms2-2_2.12~rc1-2build2_amd64.deb ...\n",
      "Unpacking liblcms2-2:amd64 (2.12~rc1-2build2) ...\n",
      "Selecting previously unselected package libnspr4:amd64.\n",
      "Preparing to unpack .../16-libnspr4_2%3a4.35-0ubuntu0.22.04.1_amd64.deb ...\n",
      "Unpacking libnspr4:amd64 (2:4.35-0ubuntu0.22.04.1) ...\n",
      "Selecting previously unselected package libnss3:amd64.\n",
      "Preparing to unpack .../17-libnss3_2%3a3.98-0ubuntu0.22.04.2_amd64.deb ...\n",
      "Unpacking libnss3:amd64 (2:3.98-0ubuntu0.22.04.2) ...\n",
      "Selecting previously unselected package libpcsclite1:amd64.\n",
      "Preparing to unpack .../18-libpcsclite1_1.9.5-3ubuntu1_amd64.deb ...\n",
      "Unpacking libpcsclite1:amd64 (1.9.5-3ubuntu1) ...\n",
      "Selecting previously unselected package openjdk-11-jre-headless:amd64.\n",
      "Preparing to unpack .../19-openjdk-11-jre-headless_11.0.27+6~us1-0ubuntu1~22.04_amd64.deb ...\n",
      "Unpacking openjdk-11-jre-headless:amd64 (11.0.27+6~us1-0ubuntu1~22.04) ...\n",
      "Selecting previously unselected package default-jre-headless.\n",
      "Preparing to unpack .../20-default-jre-headless_2%3a1.11-72build2_amd64.deb ...\n",
      "Unpacking default-jre-headless (2:1.11-72build2) ...\n",
      "Selecting previously unselected package ca-certificates-java.\n",
      "Preparing to unpack .../21-ca-certificates-java_20190909ubuntu1.2_all.deb ...\n",
      "Unpacking ca-certificates-java (20190909ubuntu1.2) ...\n",
      "Selecting previously unselected package libgif7:amd64.\n",
      "Preparing to unpack .../22-libgif7_5.1.9-2ubuntu0.1_amd64.deb ...\n",
      "Unpacking libgif7:amd64 (5.1.9-2ubuntu0.1) ...\n",
      "Selecting previously unselected package openjdk-11-jre:amd64.\n",
      "Preparing to unpack .../23-openjdk-11-jre_11.0.27+6~us1-0ubuntu1~22.04_amd64.deb ...\n",
      "Unpacking openjdk-11-jre:amd64 (11.0.27+6~us1-0ubuntu1~22.04) ...\n",
      "Selecting previously unselected package default-jre.\n",
      "Preparing to unpack .../24-default-jre_2%3a1.11-72build2_amd64.deb ...\n",
      "Unpacking default-jre (2:1.11-72build2) ...\n",
      "Selecting previously unselected package fonts-dejavu-extra.\n",
      "Preparing to unpack .../25-fonts-dejavu-extra_2.37-2build1_all.deb ...\n",
      "Unpacking fonts-dejavu-extra (2.37-2build1) ...\n",
      "Selecting previously unselected package libatk1.0-data.\n",
      "Preparing to unpack .../26-libatk1.0-data_2.36.0-3build1_all.deb ...\n",
      "Unpacking libatk1.0-data (2.36.0-3build1) ...\n",
      "Selecting previously unselected package libatk1.0-0:amd64.\n",
      "Preparing to unpack .../27-libatk1.0-0_2.36.0-3build1_amd64.deb ...\n",
      "Unpacking libatk1.0-0:amd64 (2.36.0-3build1) ...\n",
      "Selecting previously unselected package libatk-bridge2.0-0:amd64.\n",
      "Preparing to unpack .../28-libatk-bridge2.0-0_2.38.0-3_amd64.deb ...\n",
      "Unpacking libatk-bridge2.0-0:amd64 (2.38.0-3) ...\n",
      "Selecting previously unselected package libfontenc1:amd64.\n",
      "Preparing to unpack .../29-libfontenc1_1%3a1.1.4-1build3_amd64.deb ...\n",
      "Unpacking libfontenc1:amd64 (1:1.1.4-1build3) ...\n",
      "Selecting previously unselected package libxt6:amd64.\n",
      "Preparing to unpack .../30-libxt6_1%3a1.2.1-1_amd64.deb ...\n",
      "Unpacking libxt6:amd64 (1:1.2.1-1) ...\n",
      "Selecting previously unselected package libxmu6:amd64.\n",
      "Preparing to unpack .../31-libxmu6_2%3a1.1.3-3_amd64.deb ...\n",
      "Unpacking libxmu6:amd64 (2:1.1.3-3) ...\n",
      "Selecting previously unselected package libxpm4:amd64.\n",
      "Preparing to unpack .../32-libxpm4_1%3a3.5.12-1ubuntu0.22.04.2_amd64.deb ...\n",
      "Unpacking libxpm4:amd64 (1:3.5.12-1ubuntu0.22.04.2) ...\n",
      "Selecting previously unselected package libxaw7:amd64.\n",
      "Preparing to unpack .../33-libxaw7_2%3a1.0.14-1_amd64.deb ...\n",
      "Unpacking libxaw7:amd64 (2:1.0.14-1) ...\n",
      "Selecting previously unselected package libxcomposite1:amd64.\n",
      "Preparing to unpack .../34-libxcomposite1_1%3a0.4.5-1build2_amd64.deb ...\n",
      "Unpacking libxcomposite1:amd64 (1:0.4.5-1build2) ...\n",
      "Selecting previously unselected package libxft2:amd64.\n",
      "Preparing to unpack .../35-libxft2_2.3.4-1_amd64.deb ...\n",
      "Unpacking libxft2:amd64 (2.3.4-1) ...\n",
      "Selecting previously unselected package libxkbfile1:amd64.\n",
      "Preparing to unpack .../36-libxkbfile1_1%3a1.1.0-1build3_amd64.deb ...\n",
      "Unpacking libxkbfile1:amd64 (1:1.1.0-1build3) ...\n",
      "Selecting previously unselected package libxxf86dga1:amd64.\n",
      "Preparing to unpack .../37-libxxf86dga1_2%3a1.1.5-0ubuntu3_amd64.deb ...\n",
      "Unpacking libxxf86dga1:amd64 (2:1.1.5-0ubuntu3) ...\n",
      "Selecting previously unselected package x11-utils.\n",
      "Preparing to unpack .../38-x11-utils_7.7+5build2_amd64.deb ...\n",
      "Unpacking x11-utils (7.7+5build2) ...\n",
      "Selecting previously unselected package libatk-wrapper-java.\n",
      "Preparing to unpack .../39-libatk-wrapper-java_0.38.0-5build1_all.deb ...\n",
      "Unpacking libatk-wrapper-java (0.38.0-5build1) ...\n",
      "Selecting previously unselected package libatk-wrapper-java-jni:amd64.\n",
      "Preparing to unpack .../40-libatk-wrapper-java-jni_0.38.0-5build1_amd64.deb ...\n",
      "Unpacking libatk-wrapper-java-jni:amd64 (0.38.0-5build1) ...\n",
      "Setting up liblcms2-2:amd64 (2.12~rc1-2build2) ...\n",
      "Setting up session-migration (0.3.6) ...\n",
      "Created symlink /etc/systemd/user/graphical-session-pre.target.wants/session-migration.service → /usr/lib/systemd/user/session-migration.service.\n",
      "Setting up libxft2:amd64 (2.3.4-1) ...\n",
      "Setting up libxpm4:amd64 (1:3.5.12-1ubuntu0.22.04.2) ...\n",
      "Setting up java-common (0.72build2) ...\n",
      "Setting up libxtst6:amd64 (2:1.2.3-1build4) ...\n",
      "Setting up libxxf86dga1:amd64 (2:1.1.5-0ubuntu3) ...\n",
      "Setting up libatspi2.0-0:amd64 (2.44.0-3) ...\n",
      "Setting up libdconf1:amd64 (0.40.0-3) ...\n",
      "Setting up dbus-user-session (1.12.20-2ubuntu4.1) ...\n",
      "Setting up libfontenc1:amd64 (1:1.1.4-1build3) ...\n",
      "Setting up libnspr4:amd64 (2:4.35-0ubuntu0.22.04.1) ...\n",
      "Setting up libavahi-common-data:amd64 (0.8-5ubuntu5.2) ...\n",
      "Setting up libpcsclite1:amd64 (1.9.5-3ubuntu1) ...\n",
      "Setting up libxt6:amd64 (1:1.2.1-1) ...\n",
      "Setting up libgif7:amd64 (5.1.9-2ubuntu0.1) ...\n",
      "Setting up libatk1.0-data (2.36.0-3build1) ...\n",
      "Setting up fonts-dejavu-extra (2.37-2build1) ...\n",
      "Setting up libatk1.0-0:amd64 (2.36.0-3build1) ...\n",
      "Setting up libxkbfile1:amd64 (1:1.1.0-1build3) ...\n",
      "Setting up libxcomposite1:amd64 (1:0.4.5-1build2) ...\n",
      "Setting up libxmuu1:amd64 (2:1.1.3-3) ...\n",
      "Setting up libxmu6:amd64 (2:1.1.3-3) ...\n",
      "Setting up libavahi-common3:amd64 (0.8-5ubuntu5.2) ...\n",
      "Setting up dconf-service (0.40.0-3) ...\n",
      "Setting up libnss3:amd64 (2:3.98-0ubuntu0.22.04.2) ...\n",
      "Setting up libxaw7:amd64 (2:1.0.14-1) ...\n",
      "Setting up libatk-bridge2.0-0:amd64 (2.38.0-3) ...\n",
      "Setting up x11-utils (7.7+5build2) ...\n",
      "Setting up libatk-wrapper-java (0.38.0-5build1) ...\n",
      "Setting up libavahi-client3:amd64 (0.8-5ubuntu5.2) ...\n",
      "Setting up dconf-gsettings-backend:amd64 (0.40.0-3) ...\n",
      "Setting up libatk-wrapper-java-jni:amd64 (0.38.0-5build1) ...\n",
      "Setting up libcups2:amd64 (2.4.1op1-1ubuntu4.11) ...\n",
      "Setting up gsettings-desktop-schemas (42.0-1ubuntu1) ...\n",
      "Setting up default-jre-headless (2:1.11-72build2) ...\n",
      "Setting up openjdk-11-jre-headless:amd64 (11.0.27+6~us1-0ubuntu1~22.04) ...\n",
      "update-alternatives: using /usr/lib/jvm/java-11-openjdk-amd64/bin/java to provide /usr/bin/java (java) in auto mode\n",
      "update-alternatives: using /usr/lib/jvm/java-11-openjdk-amd64/bin/jjs to provide /usr/bin/jjs (jjs) in auto mode\n",
      "update-alternatives: using /usr/lib/jvm/java-11-openjdk-amd64/bin/keytool to provide /usr/bin/keytool (keytool) in auto mode\n",
      "update-alternatives: using /usr/lib/jvm/java-11-openjdk-amd64/bin/rmid to provide /usr/bin/rmid (rmid) in auto mode\n",
      "update-alternatives: using /usr/lib/jvm/java-11-openjdk-amd64/bin/rmiregistry to provide /usr/bin/rmiregistry (rmiregistry) in auto mode\n",
      "update-alternatives: using /usr/lib/jvm/java-11-openjdk-amd64/bin/pack200 to provide /usr/bin/pack200 (pack200) in auto mode\n",
      "update-alternatives: using /usr/lib/jvm/java-11-openjdk-amd64/bin/unpack200 to provide /usr/bin/unpack200 (unpack200) in auto mode\n",
      "update-alternatives: using /usr/lib/jvm/java-11-openjdk-amd64/lib/jexec to provide /usr/bin/jexec (jexec) in auto mode\n",
      "Setting up openjdk-11-jre:amd64 (11.0.27+6~us1-0ubuntu1~22.04) ...\n",
      "Setting up default-jre (2:1.11-72build2) ...\n",
      "Setting up ca-certificates-java (20190909ubuntu1.2) ...\n",
      "head: cannot open '/etc/ssl/certs/java/cacerts' for reading: No such file or directory\n",
      "Adding debian:T-TeleSec_GlobalRoot_Class_2.pem\n",
      "Adding debian:SecureTrust_CA.pem\n",
      "Adding debian:emSign_Root_CA_-_G1.pem\n",
      "Adding debian:GlobalSign_Root_CA_-_R6.pem\n",
      "Adding debian:ISRG_Root_X1.pem\n",
      "Adding debian:UCA_Global_G2_Root.pem\n",
      "Adding debian:Secure_Global_CA.pem\n",
      "Adding debian:Trustwave_Global_ECC_P384_Certification_Authority.pem\n",
      "Adding debian:Entrust_Root_Certification_Authority.pem\n",
      "Adding debian:SZAFIR_ROOT_CA2.pem\n",
      "Adding debian:SSL.com_Root_Certification_Authority_RSA.pem\n",
      "Adding debian:Go_Daddy_Root_Certificate_Authority_-_G2.pem\n",
      "Adding debian:certSIGN_Root_CA_G2.pem\n",
      "Adding debian:QuoVadis_Root_CA_2.pem\n",
      "Adding debian:D-TRUST_EV_Root_CA_1_2020.pem\n",
      "Adding debian:emSign_ECC_Root_CA_-_C3.pem\n",
      "Adding debian:ISRG_Root_X2.pem\n",
      "Adding debian:Security_Communication_Root_CA.pem\n",
      "Adding debian:AffirmTrust_Premium_ECC.pem\n",
      "Adding debian:DigiCert_TLS_ECC_P384_Root_G5.pem\n",
      "Adding debian:Amazon_Root_CA_1.pem\n",
      "Adding debian:Security_Communication_RootCA2.pem\n",
      "Adding debian:TunTrust_Root_CA.pem\n",
      "Adding debian:TeliaSonera_Root_CA_v1.pem\n",
      "Adding debian:GTS_Root_R4.pem\n",
      "Adding debian:USERTrust_ECC_Certification_Authority.pem\n",
      "Adding debian:Amazon_Root_CA_3.pem\n",
      "Adding debian:COMODO_ECC_Certification_Authority.pem\n",
      "Adding debian:OISTE_WISeKey_Global_Root_GC_CA.pem\n",
      "Adding debian:GDCA_TrustAUTH_R5_ROOT.pem\n",
      "Adding debian:GlobalSign_Root_CA_-_R3.pem\n",
      "Adding debian:Certum_Trusted_Root_CA.pem\n",
      "Adding debian:TWCA_Root_Certification_Authority.pem\n",
      "Adding debian:NAVER_Global_Root_Certification_Authority.pem\n",
      "Adding debian:DigiCert_High_Assurance_EV_Root_CA.pem\n",
      "Adding debian:Hellenic_Academic_and_Research_Institutions_RootCA_2015.pem\n",
      "Adding debian:GlobalSign_Root_E46.pem\n",
      "Adding debian:GlobalSign_Root_R46.pem\n",
      "Adding debian:Entrust.net_Premium_2048_Secure_Server_CA.pem\n",
      "Adding debian:Certainly_Root_R1.pem\n",
      "Adding debian:Buypass_Class_3_Root_CA.pem\n",
      "Adding debian:Starfield_Class_2_CA.pem\n",
      "Adding debian:DigiCert_Assured_ID_Root_G3.pem\n",
      "Adding debian:Comodo_AAA_Services_root.pem\n",
      "Adding debian:Certum_Trusted_Network_CA_2.pem\n",
      "Adding debian:vTrus_ECC_Root_CA.pem\n",
      "Adding debian:CA_Disig_Root_R2.pem\n",
      "Adding debian:QuoVadis_Root_CA_3.pem\n",
      "Adding debian:Certainly_Root_E1.pem\n",
      "Adding debian:IdenTrust_Public_Sector_Root_CA_1.pem\n",
      "Adding debian:Trustwave_Global_Certification_Authority.pem\n",
      "Adding debian:QuoVadis_Root_CA_2_G3.pem\n",
      "Adding debian:CFCA_EV_ROOT.pem\n",
      "Adding debian:Certigna.pem\n",
      "Adding debian:Certigna_Root_CA.pem\n",
      "Adding debian:vTrus_Root_CA.pem\n",
      "Adding debian:SSL.com_Root_Certification_Authority_ECC.pem\n",
      "Adding debian:GTS_Root_R1.pem\n",
      "Adding debian:Entrust_Root_Certification_Authority_-_G4.pem\n",
      "Adding debian:AC_RAIZ_FNMT-RCM.pem\n",
      "Adding debian:DigiCert_Assured_ID_Root_G2.pem\n",
      "Adding debian:Microsec_e-Szigno_Root_CA_2009.pem\n",
      "Adding debian:OISTE_WISeKey_Global_Root_GB_CA.pem\n",
      "Adding debian:certSIGN_ROOT_CA.pem\n",
      "Adding debian:SSL.com_EV_Root_Certification_Authority_RSA_R2.pem\n",
      "Adding debian:Security_Communication_ECC_RootCA1.pem\n",
      "Adding debian:XRamp_Global_CA_Root.pem\n",
      "Adding debian:DigiCert_Global_Root_G3.pem\n",
      "Adding debian:DigiCert_Assured_ID_Root_CA.pem\n",
      "Adding debian:Hongkong_Post_Root_CA_3.pem\n",
      "Adding debian:GTS_Root_R3.pem\n",
      "Adding debian:Microsoft_ECC_Root_Certificate_Authority_2017.pem\n",
      "Adding debian:Go_Daddy_Class_2_CA.pem\n",
      "Adding debian:Entrust_Root_Certification_Authority_-_G2.pem\n",
      "Adding debian:ePKI_Root_Certification_Authority.pem\n",
      "Adding debian:D-TRUST_Root_Class_3_CA_2_EV_2009.pem\n",
      "Adding debian:TWCA_Global_Root_CA.pem\n",
      "Adding debian:Baltimore_CyberTrust_Root.pem\n",
      "Adding debian:AffirmTrust_Premium.pem\n",
      "Adding debian:AC_RAIZ_FNMT-RCM_SERVIDORES_SEGUROS.pem\n",
      "Adding debian:Security_Communication_RootCA3.pem\n",
      "Adding debian:GTS_Root_R2.pem\n",
      "Adding debian:Actalis_Authentication_Root_CA.pem\n",
      "Adding debian:T-TeleSec_GlobalRoot_Class_3.pem\n",
      "Adding debian:SwissSign_Gold_CA_-_G2.pem\n",
      "Adding debian:D-TRUST_Root_Class_3_CA_2_2009.pem\n",
      "Adding debian:TUBITAK_Kamu_SM_SSL_Kok_Sertifikasi_-_Surum_1.pem\n",
      "Adding debian:e-Szigno_Root_CA_2017.pem\n",
      "Adding debian:HiPKI_Root_CA_-_G1.pem\n",
      "Adding debian:emSign_ECC_Root_CA_-_G3.pem\n",
      "Adding debian:SecureSign_RootCA11.pem\n",
      "Adding debian:Izenpe.com.pem\n",
      "Adding debian:Autoridad_de_Certificacion_Firmaprofesional_CIF_A62634068.pem\n",
      "Adding debian:AffirmTrust_Networking.pem\n",
      "Adding debian:QuoVadis_Root_CA_3_G3.pem\n",
      "Adding debian:UCA_Extended_Validation_Root.pem\n",
      "Adding debian:D-TRUST_BR_Root_CA_1_2020.pem\n",
      "Adding debian:NetLock_Arany_=Class_Gold=_Főtanúsítvány.pem\n",
      "Adding debian:QuoVadis_Root_CA_1_G3.pem\n",
      "Adding debian:DigiCert_TLS_RSA4096_Root_G5.pem\n",
      "Adding debian:Atos_TrustedRoot_2011.pem\n",
      "Adding debian:Amazon_Root_CA_2.pem\n",
      "Adding debian:IdenTrust_Commercial_Root_CA_1.pem\n",
      "Adding debian:Amazon_Root_CA_4.pem\n",
      "Adding debian:DigiCert_Trusted_Root_G4.pem\n",
      "Adding debian:GLOBALTRUST_2020.pem\n",
      "Adding debian:COMODO_Certification_Authority.pem\n",
      "Adding debian:emSign_Root_CA_-_C1.pem\n",
      "Adding debian:Certum_EC-384_CA.pem\n",
      "Adding debian:GlobalSign_Root_CA.pem\n",
      "Adding debian:Certum_Trusted_Network_CA.pem\n",
      "Adding debian:HARICA_TLS_ECC_Root_CA_2021.pem\n",
      "Adding debian:HARICA_TLS_RSA_Root_CA_2021.pem\n",
      "Adding debian:Buypass_Class_2_Root_CA.pem\n",
      "Adding debian:SSL.com_EV_Root_Certification_Authority_ECC.pem\n",
      "Adding debian:Trustwave_Global_ECC_P256_Certification_Authority.pem\n",
      "Adding debian:AffirmTrust_Commercial.pem\n",
      "Adding debian:GlobalSign_ECC_Root_CA_-_R5.pem\n",
      "Adding debian:SwissSign_Silver_CA_-_G2.pem\n",
      "Adding debian:GlobalSign_ECC_Root_CA_-_R4.pem\n",
      "Adding debian:DigiCert_Global_Root_G2.pem\n",
      "Adding debian:Starfield_Services_Root_Certificate_Authority_-_G2.pem\n",
      "Adding debian:Hellenic_Academic_and_Research_Institutions_ECC_RootCA_2015.pem\n",
      "Adding debian:ANF_Secure_Server_Root_CA.pem\n",
      "Adding debian:Starfield_Root_Certificate_Authority_-_G2.pem\n",
      "Adding debian:Telia_Root_CA_v2.pem\n",
      "Adding debian:Entrust_Root_Certification_Authority_-_EC1.pem\n",
      "Adding debian:ACCVRAIZ1.pem\n",
      "Adding debian:USERTrust_RSA_Certification_Authority.pem\n",
      "Adding debian:DigiCert_Global_Root_CA.pem\n",
      "Adding debian:Microsoft_RSA_Root_Certificate_Authority_2017.pem\n",
      "Adding debian:COMODO_RSA_Certification_Authority.pem\n",
      "Adding debian:Sectigo_Public_Server_Authentication_Root_E46.pem\n",
      "Adding debian:CommScope_Public_Trust_RSA_Root-02.pem\n",
      "Adding debian:CommScope_Public_Trust_ECC_Root-02.pem\n",
      "Adding debian:CommScope_Public_Trust_ECC_Root-01.pem\n",
      "Adding debian:CommScope_Public_Trust_RSA_Root-01.pem\n",
      "Adding debian:TrustAsia_Global_Root_CA_G3.pem\n",
      "Adding debian:BJCA_Global_Root_CA1.pem\n",
      "Adding debian:Atos_TrustedRoot_Root_CA_RSA_TLS_2021.pem\n",
      "Adding debian:TrustAsia_Global_Root_CA_G4.pem\n",
      "Adding debian:SSL.com_TLS_ECC_Root_CA_2022.pem\n",
      "Adding debian:Sectigo_Public_Server_Authentication_Root_R46.pem\n",
      "Adding debian:BJCA_Global_Root_CA2.pem\n",
      "Adding debian:Atos_TrustedRoot_Root_CA_ECC_TLS_2021.pem\n",
      "Adding debian:SSL.com_TLS_RSA_Root_CA_2022.pem\n",
      "done.\n",
      "Processing triggers for fontconfig (2.13.1-4.2ubuntu5) ...\n",
      "Processing triggers for libglib2.0-0:amd64 (2.72.4-0ubuntu2.4) ...\n",
      "Processing triggers for libc-bin (2.35-0ubuntu3.8) ...\n",
      "Processing triggers for ca-certificates (20240203~22.04.1) ...\n",
      "Updating certificates in /etc/ssl/certs...\n",
      "0 added, 0 removed; done.\n",
      "Running hooks in /etc/ca-certificates/update.d...\n",
      "\n",
      "done.\n",
      "done.\n",
      "Setting up at-spi2-core (2.44.0-3) ...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "huggingface/tokenizers: The current process just got forked, after parallelism has already been used. Disabling parallelism to avoid deadlocks...\n",
      "To disable this warning, you can either:\n",
      "\t- Avoid using `tokenizers` before the fork if possible\n",
      "\t- Explicitly set the environment variable TOKENIZERS_PARALLELISM=(true | false)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Collecting nltk\n",
      "  Downloading nltk-3.9.1-py3-none-any.whl (1.5 MB)\n",
      "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m1.5/1.5 MB\u001b[0m \u001b[31m32.7 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0ma \u001b[36m0:00:01\u001b[0m\n",
      "\u001b[?25hCollecting joblib\n",
      "  Downloading joblib-1.5.0-py3-none-any.whl (307 kB)\n",
      "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m307.7/307.7 KB\u001b[0m \u001b[31m72.2 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
      "\u001b[?25hRequirement already satisfied: tqdm in /usr/local/lib/python3.10/dist-packages (from nltk) (4.67.1)\n",
      "Requirement already satisfied: click in /usr/local/lib/python3.10/dist-packages (from nltk) (8.1.8)\n",
      "Requirement already satisfied: regex>=2021.8.3 in /usr/local/lib/python3.10/dist-packages (from nltk) (2024.11.6)\n",
      "Installing collected packages: joblib, nltk\n",
      "Successfully installed joblib-1.5.0 nltk-3.9.1\n",
      "\u001b[33mWARNING: Running pip as the 'root' user can result in broken permissions and conflicting behaviour with the system package manager. It is recommended to use a virtual environment instead: https://pip.pypa.io/warnings/venv\u001b[0m\u001b[33m\n",
      "\u001b[0m"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "huggingface/tokenizers: The current process just got forked, after parallelism has already been used. Disabling parallelism to avoid deadlocks...\n",
      "To disable this warning, you can either:\n",
      "\t- Avoid using `tokenizers` before the fork if possible\n",
      "\t- Explicitly set the environment variable TOKENIZERS_PARALLELISM=(true | false)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Requirement already satisfied: nltk in /usr/local/lib/python3.10/dist-packages (3.9.1)\n",
      "Collecting rouge-score\n",
      "  Downloading rouge_score-0.1.2.tar.gz (17 kB)\n",
      "  Preparing metadata (setup.py) ... \u001b[?25ldone\n",
      "\u001b[?25hCollecting bert-score\n",
      "  Downloading bert_score-0.3.13-py3-none-any.whl (61 kB)\n",
      "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m61.1/61.1 KB\u001b[0m \u001b[31m2.6 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
      "\u001b[?25hCollecting pycocoevalcap\n",
      "  Downloading pycocoevalcap-1.2-py3-none-any.whl (104.3 MB)\n",
      "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m104.3/104.3 MB\u001b[0m \u001b[31m38.1 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m00:01\u001b[0m00:01\u001b[0m\n",
      "\u001b[?25hRequirement already satisfied: joblib in /usr/local/lib/python3.10/dist-packages (from nltk) (1.5.0)\n",
      "Requirement already satisfied: click in /usr/local/lib/python3.10/dist-packages (from nltk) (8.1.8)\n",
      "Requirement already satisfied: regex>=2021.8.3 in /usr/local/lib/python3.10/dist-packages (from nltk) (2024.11.6)\n",
      "Requirement already satisfied: tqdm in /usr/local/lib/python3.10/dist-packages (from nltk) (4.67.1)\n",
      "Collecting absl-py\n",
      "  Downloading absl_py-2.2.2-py3-none-any.whl (135 kB)\n",
      "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m135.6/135.6 KB\u001b[0m \u001b[31m34.4 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
      "\u001b[?25hRequirement already satisfied: numpy in /usr/local/lib/python3.10/dist-packages (from rouge-score) (1.26.4)\n",
      "Requirement already satisfied: six>=1.14.0 in /usr/local/lib/python3.10/dist-packages (from rouge-score) (1.17.0)\n",
      "Requirement already satisfied: torch>=1.0.0 in /usr/local/lib/python3.10/dist-packages (from bert-score) (2.5.1+cu121)\n",
      "Requirement already satisfied: requests in /usr/local/lib/python3.10/dist-packages (from bert-score) (2.32.3)\n",
      "Requirement already satisfied: pandas>=1.0.1 in /usr/local/lib/python3.10/dist-packages (from bert-score) (2.2.3)\n",
      "Requirement already satisfied: transformers>=3.0.0 in /usr/local/lib/python3.10/dist-packages (from bert-score) (4.51.3)\n",
      "Requirement already satisfied: packaging>=20.9 in /usr/local/lib/python3.10/dist-packages (from bert-score) (24.2)\n",
      "Requirement already satisfied: matplotlib in /usr/local/lib/python3.10/dist-packages (from bert-score) (3.10.3)\n",
      "Collecting pycocotools>=2.0.2\n",
      "  Downloading pycocotools-2.0.8-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (427 kB)\n",
      "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m427.8/427.8 KB\u001b[0m \u001b[31m84.2 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
      "\u001b[?25hRequirement already satisfied: python-dateutil>=2.8.2 in /usr/local/lib/python3.10/dist-packages (from pandas>=1.0.1->bert-score) (2.9.0.post0)\n",
      "Requirement already satisfied: tzdata>=2022.7 in /usr/local/lib/python3.10/dist-packages (from pandas>=1.0.1->bert-score) (2025.1)\n",
      "Requirement already satisfied: pytz>=2020.1 in /usr/local/lib/python3.10/dist-packages (from pandas>=1.0.1->bert-score) (2025.1)\n",
      "Requirement already satisfied: fonttools>=4.22.0 in /usr/local/lib/python3.10/dist-packages (from matplotlib->bert-score) (4.58.0)\n",
      "Requirement already satisfied: cycler>=0.10 in /usr/local/lib/python3.10/dist-packages (from matplotlib->bert-score) (0.12.1)\n",
      "Requirement already satisfied: kiwisolver>=1.3.1 in /usr/local/lib/python3.10/dist-packages (from matplotlib->bert-score) (1.4.8)\n",
      "Requirement already satisfied: pyparsing>=2.3.1 in /usr/local/lib/python3.10/dist-packages (from matplotlib->bert-score) (3.2.3)\n",
      "Requirement already satisfied: pillow>=8 in /usr/local/lib/python3.10/dist-packages (from matplotlib->bert-score) (10.4.0)\n",
      "Requirement already satisfied: contourpy>=1.0.1 in /usr/local/lib/python3.10/dist-packages (from matplotlib->bert-score) (1.3.2)\n",
      "Requirement already satisfied: nvidia-cuda-cupti-cu12==12.1.105 in /usr/local/lib/python3.10/dist-packages (from torch>=1.0.0->bert-score) (12.1.105)\n",
      "Requirement already satisfied: nvidia-cufft-cu12==11.0.2.54 in /usr/local/lib/python3.10/dist-packages (from torch>=1.0.0->bert-score) (11.0.2.54)\n",
      "Requirement already satisfied: networkx in /usr/local/lib/python3.10/dist-packages (from torch>=1.0.0->bert-score) (3.1)\n",
      "Requirement already satisfied: nvidia-cublas-cu12==12.1.3.1 in /usr/local/lib/python3.10/dist-packages (from torch>=1.0.0->bert-score) (12.1.3.1)\n",
      "Requirement already satisfied: filelock in /usr/local/lib/python3.10/dist-packages (from torch>=1.0.0->bert-score) (3.17.0)\n",
      "Requirement already satisfied: nvidia-curand-cu12==10.3.2.106 in /usr/local/lib/python3.10/dist-packages (from torch>=1.0.0->bert-score) (10.3.2.106)\n",
      "Requirement already satisfied: nvidia-cudnn-cu12==9.1.0.70 in /usr/local/lib/python3.10/dist-packages (from torch>=1.0.0->bert-score) (9.1.0.70)\n",
      "Requirement already satisfied: nvidia-cuda-runtime-cu12==12.1.105 in /usr/local/lib/python3.10/dist-packages (from torch>=1.0.0->bert-score) (12.1.105)\n",
      "Requirement already satisfied: nvidia-nvtx-cu12==12.1.105 in /usr/local/lib/python3.10/dist-packages (from torch>=1.0.0->bert-score) (12.1.105)\n",
      "Requirement already satisfied: triton==3.1.0 in /usr/local/lib/python3.10/dist-packages (from torch>=1.0.0->bert-score) (3.1.0)\n",
      "Requirement already satisfied: sympy==1.13.1 in /usr/local/lib/python3.10/dist-packages (from torch>=1.0.0->bert-score) (1.13.1)\n",
      "Requirement already satisfied: nvidia-nccl-cu12==2.21.5 in /usr/local/lib/python3.10/dist-packages (from torch>=1.0.0->bert-score) (2.21.5)\n",
      "Requirement already satisfied: nvidia-cuda-nvrtc-cu12==12.1.105 in /usr/local/lib/python3.10/dist-packages (from torch>=1.0.0->bert-score) (12.1.105)\n",
      "Requirement already satisfied: typing-extensions>=4.8.0 in /usr/local/lib/python3.10/dist-packages (from torch>=1.0.0->bert-score) (4.12.2)\n",
      "Requirement already satisfied: nvidia-cusolver-cu12==11.4.5.107 in /usr/local/lib/python3.10/dist-packages (from torch>=1.0.0->bert-score) (11.4.5.107)\n",
      "Requirement already satisfied: fsspec in /usr/local/lib/python3.10/dist-packages (from torch>=1.0.0->bert-score) (2024.6.1)\n",
      "Requirement already satisfied: nvidia-cusparse-cu12==12.1.0.106 in /usr/local/lib/python3.10/dist-packages (from torch>=1.0.0->bert-score) (12.1.0.106)\n",
      "Requirement already satisfied: jinja2 in /usr/local/lib/python3.10/dist-packages (from torch>=1.0.0->bert-score) (3.1.4)\n",
      "Requirement already satisfied: nvidia-nvjitlink-cu12 in /usr/local/lib/python3.10/dist-packages (from nvidia-cusolver-cu12==11.4.5.107->torch>=1.0.0->bert-score) (12.1.105)\n",
      "Requirement already satisfied: mpmath<1.4,>=1.1.0 in /usr/local/lib/python3.10/dist-packages (from sympy==1.13.1->torch>=1.0.0->bert-score) (1.3.0)\n",
      "Requirement already satisfied: tokenizers<0.22,>=0.21 in /usr/local/lib/python3.10/dist-packages (from transformers>=3.0.0->bert-score) (0.21.0)\n",
      "Requirement already satisfied: pyyaml>=5.1 in /usr/local/lib/python3.10/dist-packages (from transformers>=3.0.0->bert-score) (6.0.2)\n",
      "Requirement already satisfied: huggingface-hub<1.0,>=0.30.0 in /usr/local/lib/python3.10/dist-packages (from transformers>=3.0.0->bert-score) (0.31.4)\n",
      "Requirement already satisfied: safetensors>=0.4.3 in /usr/local/lib/python3.10/dist-packages (from transformers>=3.0.0->bert-score) (0.5.2)\n",
      "Requirement already satisfied: urllib3<3,>=1.21.1 in /usr/local/lib/python3.10/dist-packages (from requests->bert-score) (2.3.0)\n",
      "Requirement already satisfied: certifi>=2017.4.17 in /usr/local/lib/python3.10/dist-packages (from requests->bert-score) (2025.1.31)\n",
      "Requirement already satisfied: charset-normalizer<4,>=2 in /usr/local/lib/python3.10/dist-packages (from requests->bert-score) (3.4.1)\n",
      "Requirement already satisfied: idna<4,>=2.5 in /usr/local/lib/python3.10/dist-packages (from requests->bert-score) (3.10)\n",
      "Requirement already satisfied: MarkupSafe>=2.0 in /usr/local/lib/python3.10/dist-packages (from jinja2->torch>=1.0.0->bert-score) (2.1.5)\n",
      "Building wheels for collected packages: rouge-score\n",
      "  Building wheel for rouge-score (setup.py) ... \u001b[?25ldone\n",
      "\u001b[?25h  Created wheel for rouge-score: filename=rouge_score-0.1.2-py3-none-any.whl size=24985 sha256=30908ee54a6b479d4594c5d7b01d2a7d574655643bc03d47051bc9c703d4fde6\n",
      "  Stored in directory: /root/.cache/pip/wheels/5f/dd/89/461065a73be61a532ff8599a28e9beef17985c9e9c31e541b4\n",
      "Successfully built rouge-score\n",
      "Installing collected packages: absl-py, rouge-score, pycocotools, pycocoevalcap, bert-score\n",
      "Successfully installed absl-py-2.2.2 bert-score-0.3.13 pycocoevalcap-1.2 pycocotools-2.0.8 rouge-score-0.1.2\n",
      "\u001b[33mWARNING: Running pip as the 'root' user can result in broken permissions and conflicting behaviour with the system package manager. It is recommended to use a virtual environment instead: https://pip.pypa.io/warnings/venv\u001b[0m\u001b[33m\n",
      "\u001b[0m"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "huggingface/tokenizers: The current process just got forked, after parallelism has already been used. Disabling parallelism to avoid deadlocks...\n",
      "To disable this warning, you can either:\n",
      "\t- Avoid using `tokenizers` before the fork if possible\n",
      "\t- Explicitly set the environment variable TOKENIZERS_PARALLELISM=(true | false)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/usr/lib/python3.10/runpy.py:126: RuntimeWarning: 'nltk.downloader' found in sys.modules after import of package 'nltk', but prior to execution of 'nltk.downloader'; this may result in unpredictable behaviour\n",
      "  warn(RuntimeWarning(msg))\n",
      "[nltk_data] Downloading package punkt to /root/nltk_data...\n",
      "[nltk_data]   Unzipping tokenizers/punkt.zip.\n"
     ]
    }
   ],
   "source": [
    "!apt-get update\n",
    "!apt-get install default-jre -y\n",
    "!pip install nltk\n",
    "!pip install nltk rouge-score bert-score pycocoevalcap\n",
    "!python -m nltk.downloader punkt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "b128603a-c0da-4e53-a97f-c5df2849e287",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[nltk_data] Downloading package wordnet to /root/nltk_data...\n",
      "[nltk_data] Downloading package omw-1.4 to /root/nltk_data...\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import nltk\n",
    "nltk.download('wordnet')\n",
    "nltk.download('omw-1.4')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "2387dae4-5211-43ca-a529-379e405eb3dd",
   "metadata": {},
   "outputs": [],
   "source": [
    "from rouge_score import rouge_scorer\n",
    "from bert_score import score\n",
    "\n",
    "def calculate_bert_score(predictions, references):\n",
    "    \"\"\"\n",
    "    predictions: list of predicted text (strings)\n",
    "    references: list of reference texts (strings)\n",
    "    \"\"\"\n",
    "    P, R, F1 = score(predictions, references, lang=\"en\", verbose=False)\n",
    "    \n",
    "    # Convert torch tensors to float\n",
    "    return {\n",
    "        \"bert_score_precision\": P.mean().item(),\n",
    "        \"bert_score_recall\": R.mean().item(),\n",
    "        \"bert_score_f1\": F1.mean().item()\n",
    "    }\n",
    "\n",
    "scorer = rouge_scorer.RougeScorer(['rouge1', 'rouge2', 'rougeL'], use_stemmer=True)\n",
    "\n",
    "def calculate_rouge(predictions, references):\n",
    "    \"\"\"\n",
    "    predictions: list of predicted text (strings)\n",
    "    references: list of reference texts (strings)\n",
    "    \"\"\"    \n",
    "    scores = {\n",
    "        'rouge1': 0.0,\n",
    "        'rouge2': 0.0, \n",
    "        'rougeL': 0.0\n",
    "    }\n",
    "    \n",
    "    for pred, ref in zip(predictions, references):\n",
    "        result = scorer.score(ref, pred)\n",
    "        for key in scores:\n",
    "            scores[key] += result[key].fmeasure\n",
    "    \n",
    "    # Average scores\n",
    "    for key in scores:\n",
    "        scores[key] /= len(predictions)\n",
    "    \n",
    "    return scores\n",
    "\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "bc82d4b9-90b3-4d12-8d47-c22f28ac3149",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "from pycocoevalcap.meteor.meteor import Meteor\n",
    "\n",
    "meteor_scorer = Meteor()\n",
    "\n",
    "def calculate_meteor_simple(predictions, references):\n",
    "    \"\"\"\n",
    "    Simpler interface for METEOR using lists\n",
    "    \n",
    "    Args:\n",
    "        predictions: list of prediction strings\n",
    "        references: list of reference strings or list of lists of reference strings\n",
    "    \n",
    "    Returns:\n",
    "        score: float, the METEOR score\n",
    "    \"\"\"\n",
    "    pred_dict = {i: [p] for i, p in enumerate(predictions)}\n",
    "    if isinstance(references[0], list):\n",
    "        ref_dict = {i: r for i, r in enumerate(references)}\n",
    "    else:\n",
    "        ref_dict = {i: [r] for i, r in enumerate(references)}\n",
    "    \n",
    "    score, _ = meteor_scorer.compute_score(ref_dict, pred_dict)\n",
    "    return score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "5dff772d-b59a-4159-983b-c0e8bb56050f",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "\n",
    "def create_comparison_dataframe(with_injection_outputs, without_injection_outputs, transcribations):\n",
    "    \"\"\"\n",
    "    Create DataFrame comparing metrics for outputs with and without injection.\n",
    "    \n",
    "    Args:\n",
    "        batches: List of batches with reference texts\n",
    "        with_injection_outputs: List of outputs from model with injection\n",
    "        without_injection_outputs: List of outputs from model without injection\n",
    "    \n",
    "    Returns:\n",
    "        DataFrame with comparison metrics\n",
    "    \"\"\"\n",
    "\n",
    "    metrics = {\n",
    "        \"bert\": calculate_bert_score,\n",
    "        \"rouge\": calculate_rouge,\n",
    "        \"meteor\": calculate_meteor_simple\n",
    "    }\n",
    "\n",
    "    results_with = {}\n",
    "    results_wo = {}\n",
    "\n",
    "    for name, metric_func in metrics.items():\n",
    "        with_inj = metric_func(with_injection_outputs, transcribations)\n",
    "        without_inj = metric_func(without_injection_outputs, transcribations)\n",
    "\n",
    "        if name == \"meteor\":\n",
    "            results_with.update({name: with_inj})\n",
    "            results_wo.update({name: without_inj})\n",
    "            continue\n",
    "        \n",
    "        results_with.update(with_inj)\n",
    "        results_wo.update(without_inj)\n",
    "    \n",
    "    return pd.DataFrame([results_with, results_wo])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "d7137e68-8a94-47e2-a409-9dbc1933a3bb",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6a8c88a093e84f9c8c426bac11486331",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "tokenizer_config.json:   0%|          | 0.00/25.0 [00:00<?, ?B/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "94e986993ec14c82af2e4716f3b11669",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "config.json:   0%|          | 0.00/482 [00:00<?, ?B/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "9383dacbf34242dbaf0a891e3ab03bf0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "vocab.json:   0%|          | 0.00/899k [00:00<?, ?B/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "91d47e6cefbe483e8eb1732bdbb7ea00",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "merges.txt:   0%|          | 0.00/456k [00:00<?, ?B/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8126ad3d76944b2baea878526ccd89f8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "tokenizer.json:   0%|          | 0.00/1.36M [00:00<?, ?B/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Xet Storage is enabled for this repo, but the 'hf_xet' package is not installed. Falling back to regular HTTP download. For better performance, install the package with: `pip install huggingface_hub[hf_xet]` or `pip install hf_xet`\n",
      "WARNING:huggingface_hub.file_download:Xet Storage is enabled for this repo, but the 'hf_xet' package is not installed. Falling back to regular HTTP download. For better performance, install the package with: `pip install huggingface_hub[hf_xet]` or `pip install hf_xet`\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7cda348649ff4273b1442a1bac0fe5f8",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "model.safetensors:   0%|          | 0.00/1.42G [00:00<?, ?B/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Some weights of RobertaModel were not initialized from the model checkpoint at roberta-large and are newly initialized: ['pooler.dense.bias', 'pooler.dense.weight']\n",
      "You should probably TRAIN this model on a down-stream task to be able to use it for predictions and inference.\n",
      "Some weights of RobertaModel were not initialized from the model checkpoint at roberta-large and are newly initialized: ['pooler.dense.bias', 'pooler.dense.weight']\n",
      "You should probably TRAIN this model on a down-stream task to be able to use it for predictions and inference.\n"
     ]
    }
   ],
   "source": [
    "out_df = create_comparison_dataframe(output_texts, pure_output_texts, experiment.eval_dataset[\"transcribation\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "1b7cd380-12e8-4fec-a146-62e438c64e55",
   "metadata": {},
   "outputs": [],
   "source": [
    "pick_category = lambda image_name: image_name.split(\"_\")[0]\n",
    "categories = set([pick_category(image_name) for image_name in experiment.eval_dataset[\"image\"]])\n",
    "\n",
    "index_map = {cat:[] for cat in categories}\n",
    "answer_map = {cat:{\"without_injection\": [], \"with_injection\": [], \"transcribation\": []} for cat in categories}\n",
    "\n",
    "for idx, image_name in enumerate(experiment.eval_dataset[\"image\"]):\n",
    "    index_map[pick_category(image_name)].append(idx)\n",
    "\n",
    "\n",
    "def select_by_indices(original_list, indices):\n",
    "    return [original_list[i] for i in indices]\n",
    "\n",
    "for cat in answer_map:\n",
    "    answer_map[cat][\"without_injection\"] = select_by_indices(pure_output_texts, index_map[cat])\n",
    "    answer_map[cat][\"with_injection\"] = select_by_indices(output_texts, index_map[cat])\n",
    "    answer_map[cat][\"transcribation\"] = select_by_indices(experiment.eval_dataset[\"transcribation\"], index_map[cat])\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "35abbfde-668a-4749-84b3-beb5a8ef21c8",
   "metadata": {},
   "source": [
    "### for each category and overall"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "3e56f86c-9dc4-4d1d-b24a-1ccec9c8f888",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Some weights of RobertaModel were not initialized from the model checkpoint at roberta-large and are newly initialized: ['pooler.dense.bias', 'pooler.dense.weight']\n",
      "You should probably TRAIN this model on a down-stream task to be able to use it for predictions and inference.\n",
      "Some weights of RobertaModel were not initialized from the model checkpoint at roberta-large and are newly initialized: ['pooler.dense.bias', 'pooler.dense.weight']\n",
      "You should probably TRAIN this model on a down-stream task to be able to use it for predictions and inference.\n",
      "  0%|            | 0/5 [00:00<?, ?it/s]Some weights of RobertaModel were not initialized from the model checkpoint at roberta-large and are newly initialized: ['pooler.dense.bias', 'pooler.dense.weight']\n",
      "You should probably TRAIN this model on a down-stream task to be able to use it for predictions and inference.\n",
      "Some weights of RobertaModel were not initialized from the model checkpoint at roberta-large and are newly initialized: ['pooler.dense.bias', 'pooler.dense.weight']\n",
      "You should probably TRAIN this model on a down-stream task to be able to use it for predictions and inference.\n",
      " 20%|▊   | 1/5 [00:01<00:06,  1.58s/it]Some weights of RobertaModel were not initialized from the model checkpoint at roberta-large and are newly initialized: ['pooler.dense.bias', 'pooler.dense.weight']\n",
      "You should probably TRAIN this model on a down-stream task to be able to use it for predictions and inference.\n",
      "Some weights of RobertaModel were not initialized from the model checkpoint at roberta-large and are newly initialized: ['pooler.dense.bias', 'pooler.dense.weight']\n",
      "You should probably TRAIN this model on a down-stream task to be able to use it for predictions and inference.\n",
      " 40%|█▌  | 2/5 [00:03<00:04,  1.58s/it]Some weights of RobertaModel were not initialized from the model checkpoint at roberta-large and are newly initialized: ['pooler.dense.bias', 'pooler.dense.weight']\n",
      "You should probably TRAIN this model on a down-stream task to be able to use it for predictions and inference.\n",
      "Some weights of RobertaModel were not initialized from the model checkpoint at roberta-large and are newly initialized: ['pooler.dense.bias', 'pooler.dense.weight']\n",
      "You should probably TRAIN this model on a down-stream task to be able to use it for predictions and inference.\n",
      " 60%|██▍ | 3/5 [00:05<00:03,  1.72s/it]Some weights of RobertaModel were not initialized from the model checkpoint at roberta-large and are newly initialized: ['pooler.dense.bias', 'pooler.dense.weight']\n",
      "You should probably TRAIN this model on a down-stream task to be able to use it for predictions and inference.\n",
      "Some weights of RobertaModel were not initialized from the model checkpoint at roberta-large and are newly initialized: ['pooler.dense.bias', 'pooler.dense.weight']\n",
      "You should probably TRAIN this model on a down-stream task to be able to use it for predictions and inference.\n",
      " 80%|███▏| 4/5 [00:06<00:01,  1.67s/it]Some weights of RobertaModel were not initialized from the model checkpoint at roberta-large and are newly initialized: ['pooler.dense.bias', 'pooler.dense.weight']\n",
      "You should probably TRAIN this model on a down-stream task to be able to use it for predictions and inference.\n",
      "Some weights of RobertaModel were not initialized from the model checkpoint at roberta-large and are newly initialized: ['pooler.dense.bias', 'pooler.dense.weight']\n",
      "You should probably TRAIN this model on a down-stream task to be able to use it for predictions and inference.\n",
      "100%|████| 5/5 [00:08<00:00,  1.64s/it]\n"
     ]
    }
   ],
   "source": [
    "out_df_map = {\"overall\": create_comparison_dataframe(output_texts, pure_output_texts, experiment.eval_dataset[\"transcribation\"])}\n",
    "\n",
    "for cat in tqdm(answer_map):\n",
    "    out_df_map[cat] = create_comparison_dataframe(\n",
    "        answer_map[cat][\"with_injection\"], answer_map[cat][\"without_injection\"], answer_map[cat][\"transcribation\"]\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "8c12d889-041d-461f-bb99-65b6a0f7326d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# 1. Modified show_percentage_change for categories\n",
    "def show_percentage_change_by_category(df_map):\n",
    "    # Create a new DataFrame for comparison\n",
    "    comparison = pd.DataFrame()\n",
    "    \n",
    "    for category, df in df_map.items():\n",
    "        # Calculate percentage change for each column\n",
    "        row_data = {}\n",
    "        for col in df.columns:\n",
    "            base_val = df.iloc[1][col]\n",
    "            new_val = df.iloc[0][col]\n",
    "            pct_change = (new_val - base_val) / base_val * 100\n",
    "            \n",
    "            # Format with + sign for improvements\n",
    "            formatted = f\"+{pct_change:.2f}%\" if pct_change > 0 else f\"{pct_change:.2f}%\"\n",
    "            row_data[col] = formatted\n",
    "        \n",
    "        # Add as a new row with category as index\n",
    "        comparison = pd.concat([comparison, pd.DataFrame(row_data, index=[category])])\n",
    "    \n",
    "    return comparison"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "8dd2dcf5-46ce-4547-a04c-79e37adae476",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import matplotlib.patches as mpatches\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import matplotlib.patches as mpatches\n",
    "\n",
    "def plot_delta_bars_by_category(df_map, category_colors=None):\n",
    "    first_df = next(iter(df_map.values()))\n",
    "    metrics = list(first_df.columns)\n",
    "    categories = list(df_map.keys())\n",
    "    n_metrics = len(metrics)\n",
    "    n_categories = len(categories)\n",
    "    \n",
    "    if category_colors is None:\n",
    "        cmap = plt.get_cmap('tab20')\n",
    "        category_colors = {cat: cmap(i) for i, cat in enumerate(categories)}\n",
    "    \n",
    "    baseline = np.array([df_map[cat].iloc[1].values for cat in categories])\n",
    "    with_injection = np.array([df_map[cat].iloc[0].values for cat in categories])\n",
    "    delta = with_injection - baseline\n",
    "    delta_pct = (delta / baseline) * 100\n",
    "    \n",
    "    fig, ax = plt.subplots(figsize=(12, 6))\n",
    "    bar_height = 0.7\n",
    "    group_gap = 1.0\n",
    "    y_positions = []\n",
    "    for m_idx, metric in enumerate(metrics):\n",
    "        for c_idx, category in enumerate(categories):\n",
    "            y = m_idx * (n_categories + group_gap) + c_idx\n",
    "            y_positions.append(y)\n",
    "            ax.axhspan(y - bar_height/2, y + bar_height/2, color=category_colors[category], alpha=0.15, zorder=0)\n",
    "            ax.barh(y, baseline[c_idx, m_idx], height=bar_height, color='lightgray', zorder=2)\n",
    "            color = 'green' if delta[c_idx, m_idx] >= 0 else 'red'\n",
    "            ax.barh(\n",
    "                y, delta[c_idx, m_idx], left=baseline[c_idx, m_idx], \n",
    "                height=bar_height, color=color, alpha=0.7, zorder=1\n",
    "            )\n",
    "            label = f\"{delta_pct[c_idx, m_idx]:+.1f}%\"\n",
    "            x_pos = baseline[c_idx, m_idx] + delta[c_idx, m_idx]\n",
    "            ha = 'left' if delta[c_idx, m_idx] >= 0 else 'right'\n",
    "            ax.text(\n",
    "                x_pos, y, label, va='center', ha=ha, color=color, fontweight='bold', fontsize=6, zorder=3,\n",
    "                bbox=dict(facecolor='white', edgecolor='none', pad=0.5, alpha=0.7)\n",
    "            )\n",
    "        y_mid = m_idx * (n_categories + group_gap) + n_categories / 2 - 0.5\n",
    "        ax.text(ax.get_xlim()[0], y_mid, metric, va='center', ha='right', fontweight='bold', fontsize=8, color='black', zorder=4)\n",
    "    \n",
    "    ax.set_yticks([])\n",
    "    ax.set_xlabel('Metric Value')\n",
    "    ax.grid(axis='x', linestyle=':', alpha=1, zorder=0)\n",
    "    ax.set_title('Metric Comparison by Category (Higher is better)')\n",
    "    ax.set_xlim(left=0)\n",
    "    ax.set_xticks([0.1*ind for ind in range(10)])\n",
    "    \n",
    "    legend_patches = [mpatches.Patch(color=category_colors[cat], label=cat, alpha=0.4) for cat in categories]\n",
    "    ax.legend(handles=legend_patches, title=\"Category\", loc='upper right')\n",
    "    \n",
    "    fig.tight_layout()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "c666396d-6d29-4626-bbd2-874e016ffde5",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Percentage Change by Category:\n"
     ]
    },
    {
     "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>bert_score_precision</th>\n",
       "      <th>bert_score_recall</th>\n",
       "      <th>bert_score_f1</th>\n",
       "      <th>rouge1</th>\n",
       "      <th>rouge2</th>\n",
       "      <th>rougeL</th>\n",
       "      <th>meteor</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>overall</th>\n",
       "      <td>+7.63%</td>\n",
       "      <td>+1.49%</td>\n",
       "      <td>+4.55%</td>\n",
       "      <td>+136.97%</td>\n",
       "      <td>+391.42%</td>\n",
       "      <td>+161.50%</td>\n",
       "      <td>+29.60%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>abstraction</th>\n",
       "      <td>+7.54%</td>\n",
       "      <td>+1.99%</td>\n",
       "      <td>+4.76%</td>\n",
       "      <td>+207.02%</td>\n",
       "      <td>+1583.26%</td>\n",
       "      <td>+256.56%</td>\n",
       "      <td>+55.87%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>object</th>\n",
       "      <td>+6.71%</td>\n",
       "      <td>-0.30%</td>\n",
       "      <td>+3.18%</td>\n",
       "      <td>+80.82%</td>\n",
       "      <td>+102.22%</td>\n",
       "      <td>+87.39%</td>\n",
       "      <td>-9.46%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>social</th>\n",
       "      <td>+7.11%</td>\n",
       "      <td>+1.06%</td>\n",
       "      <td>+4.08%</td>\n",
       "      <td>+118.50%</td>\n",
       "      <td>+184.91%</td>\n",
       "      <td>+115.56%</td>\n",
       "      <td>+13.39%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>disrupted</th>\n",
       "      <td>+7.49%</td>\n",
       "      <td>+2.07%</td>\n",
       "      <td>+4.77%</td>\n",
       "      <td>+127.83%</td>\n",
       "      <td>+463.54%</td>\n",
       "      <td>+178.01%</td>\n",
       "      <td>+42.13%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>composition</th>\n",
       "      <td>+9.43%</td>\n",
       "      <td>+2.46%</td>\n",
       "      <td>+5.95%</td>\n",
       "      <td>+172.87%</td>\n",
       "      <td>+522.70%</td>\n",
       "      <td>+204.14%</td>\n",
       "      <td>+51.90%</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "            bert_score_precision bert_score_recall bert_score_f1    rouge1  \\\n",
       "overall                   +7.63%            +1.49%        +4.55%  +136.97%   \n",
       "abstraction               +7.54%            +1.99%        +4.76%  +207.02%   \n",
       "object                    +6.71%            -0.30%        +3.18%   +80.82%   \n",
       "social                    +7.11%            +1.06%        +4.08%  +118.50%   \n",
       "disrupted                 +7.49%            +2.07%        +4.77%  +127.83%   \n",
       "composition               +9.43%            +2.46%        +5.95%  +172.87%   \n",
       "\n",
       "                rouge2    rougeL   meteor  \n",
       "overall       +391.42%  +161.50%  +29.60%  \n",
       "abstraction  +1583.26%  +256.56%  +55.87%  \n",
       "object        +102.22%   +87.39%   -9.46%  \n",
       "social        +184.91%  +115.56%  +13.39%  \n",
       "disrupted     +463.54%  +178.01%  +42.13%  \n",
       "composition   +522.70%  +204.14%  +51.90%  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "comparison_by_category = show_percentage_change_by_category(out_df_map)\n",
    "print(\"Percentage Change by Category:\")\n",
    "display(comparison_by_category)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "979b5db3-ab1e-48d8-be8e-f9e7aa6e4fae",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1200x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_delta_bars_by_category(out_df_map)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "febe3ecd",
   "metadata": {},
   "source": [
    "# P-value\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "65d58c7d",
   "metadata": {},
   "outputs": [],
   "source": [
    "def calculate_rouge(predictions, references):\n",
    "    \"\"\"\n",
    "    predictions: list of predicted text (strings)\n",
    "    references: list of reference texts (strings)\n",
    "    \"\"\"    \n",
    "    scores = {\n",
    "        'rouge1': 0.0,\n",
    "        'rouge2': 0.0, \n",
    "        'rougeL': 0.0\n",
    "    }\n",
    "    full_scores = {'rouge1': [], 'rouge2':[], 'rougeL':[]}\n",
    "    for pred, ref in zip(predictions, references):\n",
    "        result = scorer.score(ref, pred)\n",
    "        for key in scores:\n",
    "            scores[key] += result[key].fmeasure\n",
    "            full_scores[key].append(result[key].fmeasure)\n",
    "    \n",
    "    # Average scores\n",
    "    for key in scores:\n",
    "        scores[key] /= len(predictions)\n",
    "    \n",
    "    return scores, full_scores\n",
    "\n",
    "r_answers = {} \n",
    "\n",
    "for pred_texts, key in zip([output_texts, pure_output_texts], [\"with\", \"without\"]):\n",
    "    _, fulls = calculate_rouge(pred_texts, experiment.eval_dataset[\"transcribation\"])\n",
    "    r_answers[key] = fulls"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "2f9b3ee8-2bd1-4769-8473-f062927c1db5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Statistical significance of improvements:\n",
      "----------------------------------------\n",
      "ROUGE-L: p-value = 0.0000000000\n",
      "CS-F1: p-value = 0.0000000000\n",
      "----------------------------------------\n",
      "The improvement in CS-F1 is statistically significant.\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from scipy.stats import ttest_rel\n",
    "\n",
    "\n",
    "answers = {} \n",
    "\n",
    "for pred_texts, key in zip([output_texts, pure_output_texts], [\"with\", \"without\"]):\n",
    "    P, R, F1 = score(pred_texts, experiment.eval_dataset[\"transcribation\"], lang=\"en\", verbose=False)\n",
    "    answers[key] = [P, R, F1]\n",
    "\n",
    "\n",
    "baseline_cs_f1_scores = answers[\"without\"][2].numpy()\n",
    "injected_cs_f1_scores = answers[\"with\"][2].numpy()\n",
    "\n",
    "baseline_rouge_l_scores = np.array(r_answers[\"without\"]['rougeL'])\n",
    "injected_rouge_l_scores = np.array(r_answers[\"with\"]['rougeL'])\n",
    "\n",
    "stat_rouge_l, p_value_rouge_l = ttest_rel(injected_rouge_l_scores, baseline_rouge_l_scores)\n",
    "stat_cs_f1, p_value_cs_f1 = ttest_rel(injected_cs_f1_scores, baseline_cs_f1_scores)\n",
    "\n",
    "\n",
    "\n",
    "print(\"Statistical significance of improvements:\")\n",
    "print(\"-\" * 40)\n",
    "print(f\"ROUGE-L: p-value = {p_value_rouge_l:.10f}\")\n",
    "print(f\"CS-F1: p-value = {p_value_cs_f1:.10f}\")\n",
    "print(\"-\" * 40)\n",
    "\n",
    "# Interpretation\n",
    "if p_value_cs_f1 < 0.00001:\n",
    "    print(\"The improvement in CS-F1 is statistically significant.\")\n",
    "else:\n",
    "    print(\"The improvement in CS-F1 is not statistically significant.\")"
   ]
  }
 ],
 "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.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
