{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# In this document, we present some key sections of the code along with some experimental results"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Code"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Calculate self-information"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "shift_logits = output.logits[..., :-1, :].contiguous()\n",
    "shift_labels = entry.input_ids[..., 1:].contiguous()\n",
    "# pad_token_id = self.dataset_reader.tokenizer.pad_token_id\n",
    "\n",
    "# entry.labels is already padded with pad_token_id, we further pad it to full length\n",
    "pad_mask = torch.nn.functional.pad(entry.labels,\n",
    "                            (shift_labels.shape[-1] - entry.labels.shape[-1], 0),\n",
    "                            value=pad_token_id)\n",
    "\n",
    "loss_wo_pad = loss_fct(shift_logits.view(-1, shift_logits.size(-1)),\n",
    "                        shift_labels.view(-1)).view(shift_labels.size())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Slide windows"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "def calculate_snr(window):\n",
    "    signal_mean = np.mean(window)\n",
    "    noise_std = np.std(window)\n",
    "    if noise_std == 0:\n",
    "        return 0\n",
    "    return signal_mean / noise_std\n",
    "\n",
    "def find_window_above_threshold(arr, window_size = 20, step_size = 10, threshold = 3):\n",
    "    num_elements = len(arr)\n",
    "    window_count = 0\n",
    "    for start in range(num_elements - window_size, -1, -step_size):\n",
    "        window_count += 1\n",
    "        window = arr[start:start + window_size]\n",
    "        snr_value = calculate_snr(window)\n",
    "        if snr_value  > threshold:\n",
    "            return window_count - 1\n",
    "    return 0\n",
    "\n",
    "def average_of_last_n_numbers(array, n):\n",
    "    last_n_numbers = array[-n:]\n",
    "    return np.mean(last_n_numbers)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Figure 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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TUt7FQBeTy7YJ6b/jj04u/Z9oWE6dg8wb1VdsZcjIiIiIiJnIAX7GSC2qZuee1896nHDU0nPva9SO+d1lLHppA30xsqyTNrPa6T9vEY690V45YmD7Hg+TGh3hNDuzQSqvax4QyvLL2nFF3Bm0e96qZPf/2QHQ/2JUfcqr/Jw0V/ML/zs8TYAlETzPHCC/atPdxBWAz0RERERESkSBfsSZ2dt+h/YdcznjFyjvP7QZfiM72JEJibYH6lhbpArP7CMNe9YwObfHWLT7w4x2Jdg/S9389xDe1l8QSPVzeX88Wc7j/n6of4k+zb3sOBsJ9AXduyT3di2XfgM01X+nH14b4RMJnvMSgUREREREZHJNG1SyL/+679iGAY33nhj4bF4PM4NN9xAbW0tgUCAa665hnA4POp1+/fvZ926dfj9fhoaGvjEJz5BOp0edc2TTz7JOeecg9frZeHChdx9991T8ImmRmLPQK78/vgyST+J7HKnM/4kKa/0csFb5nPdly/mivcvpX5OBZlUli1/7DhuqM/7w/07yGadMXoej1PObtsp0un+SVvvRKlu8uP1u0gns/QcHCz2ckRERERE5Aw0LYL9c889x3e/+11WrVo16vGbbrqJBx54gJ/+9Kc89dRTHD58mHe84x2F5zOZDOvWrSOZTPL0009zzz33cPfdd/O5z32ucM2ePXtYt24dl112GRs2bODGG2/kQx/6EI888siUfb7JlI2eONQXrqP6lJvnjYflNllyUTPvuuU83v6P59DSXnnS1wz2JejY0Q+AaXpwu6sBSJTAOXvDNGhsy8+zVwM9ERERERGZekUP9oODg/zN3/wN3/ve96iuri48PjAwwJ133snXv/51Lr/8cs4991zuuusunn76adavXw/Ao48+ypYtW7j33ntZvXo1V199Nbfeeit33HEHyaQTeL/zne/Q1tbG1772NZYuXcpHP/pR3vnOd3L77bcX5fNONLNibCPWTPqc5nlTxDAMWhZWsfz1rWO6figycvY+v2tfCp3x4ch59jpnLyIiIiIiU6/owf6GG25g3bp1XHnllaMef+GFF0ilUqMeX7JkCXPmzOGZZ54B4JlnnmHlypU0NjYWrlm7di2RSITNmzcXrnntvdeuXVu4x7EkEgkikcioP9OVt60Sq/JE4d7GChh4zc0T1jxvPMqDY5txf+R1Xk+ugV4J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exEREREREZFRTIm9iIiIiIiIyCimxF5ERERERERkFFNiLyIiIiIiIjKKKbEXERERERERGcWU2IuIiIiIiIiMYkrsRUREREREREYxJfYiIiIiIiIio5gSexEREREREZFRzOd1AKOB4zgAtLa2ehyJiIiIiIiIHA+688/ufHQwSuwPQ1tbGwA1NTUeRyIiIiIiIiLHk7a2NiKRyKDnGM7hpP/HOdu22bt3L+FwGMMwvA5nUK2trdTU1LBr1y4KCgq8Dkck6+g1IjI4vUZEhqbXicjg9Bo5OhzHoa2tjaqqKkxz8FX0qtgfBtM0GTt2rNdhvCUFBQV6EYkMQq8RkcHpNSIyNL1ORAan18iRG6pS303D80RERERERERGMSX2IiIiIiIiIqOYEvtjTDAY5JZbbiEYDHodikhW0mtEZHB6jYgMTa8TkcHpNTLyNDxPREREREREZBRTxV5ERERERERkFFNiLyIiIiIiIjKKKbEXERERERERGcWU2IuIiIiIiIiMYkrsjyF33303EyZMICcnh4ULF/LSSy95HZJI1rj11lsxDKPPnxkzZngdlohnnn76aS655BKqqqowDIOHH364z+WO43DzzTczZswYcnNzWbx4MZs2bfImWBEPDPUa+chHPnLI+8rSpUu9CVbEA7fffjsLFiwgHA5TXl7OpZdeyoYNG/qcE41GufrqqykpKSE/P5/3ve991NXVeRTxsU2J/THid7/7Hddffz233HILr7zyCvPmzWPJkiXU19d7HZpI1pg1axb79u3L/Hn22We9DknEMx0dHcybN4+7776738u/+93vcscdd3DPPfewYsUKQqEQS5YsIRqNjnCkIt4Y6jUCsHTp0j7vKw8++OAIRijireXLl3P11Vfz4osv8thjj5FIJLjwwgvp6OjInHPdddfxl7/8hT/84Q8sX76cvXv38i//8i8eRn3s0nZ3x4iFCxeyYMEC7rrrLgBs26ampoZrr72Wm266yePoRLx366238vDDD7N69WqvQxHJOoZh8Mc//pFLL70UcKv1VVVVfP7zn+eGG24AoKWlhYqKCu677z4uu+wyD6MVGXkHv0bArdg3NzcfUskXOV7t37+f8vJyli9fztlnn01LSwtlZWU88MADvP/97wdg/fr1zJw5kxdeeIHTTjvN44iPLarYHwPi8TirVq1i8eLFmWOmabJ48WJeeOEFDyMTyS6bNm2iqqqKSZMm8eEPf5idO3d6HZJIVtq2bRu1tbV93lcikQgLFy7U+4pIL0899RTl5eVMnz6dz3zmMzQ0NHgdkohnWlpaACguLgZg1apVJBKJPu8lM2bMYNy4cXovGQZK7I8BBw4cIJVKUVFR0ed4RUUFtbW1HkUlkl0WLlzIfffdxyOPPMJPf/pTtm3bxllnnUVbW5vXoYlkne73Dr2viAxs6dKl3H///SxbtozvfOc7LF++nIsuuohUKuV1aCIjzrZtPve5z3HGGWcwe/ZswH0vCQQCFBYW9jlX7yXDw+d1ACIiI+Giiy7K/Hvu3LksXLiQ8ePH8/vf/56rrrrKw8hERGQ06r0kZc6cOcydO5fJkyfz1FNPccEFF3gYmcjIu/rqq1m7dq3mF3lIFftjQGlpKZZlHTJhsq6ujsrKSo+iEsluhYWFTJs2jc2bN3sdikjW6X7v0PuKyOGbNGkSpaWlel+R484111zDX//6V5588knGjh2bOV5ZWUk8Hqe5ubnP+XovGR5K7I8BgUCAk08+mWXLlmWO2bbNsmXLWLRokYeRiWSv9vZ2tmzZwpgxY7wORSTrTJw4kcrKyj7vK62traxYsULvKyID2L17Nw0NDXpfkeOG4zhcc801/PGPf+SJJ55g4sSJfS4/+eST8fv9fd5LNmzYwM6dO/VeMgzUin+MuP7667nyyis55ZRTOPXUU/nxj39MR0cHH/3oR70OTSQr3HDDDVxyySWMHz+evXv3csstt2BZFpdffrnXoYl4or29vU9lcdu2baxevZri4mLGjRvH5z73Ob7xjW8wdepUJk6cyFe/+lWqqqr6TAUXOZYN9hopLi7ma1/7Gu973/uorKxky5YtfOELX2DKlCksWbLEw6hFRs7VV1/NAw88wJ/+9CfC4XBm3XwkEiE3N5dIJMJVV13F9ddfT3FxMQUFBVx77bUsWrRIE/GHgba7O4bcddddfO9736O2tpYTTzyRO+64g4ULF3odlkhWuOyyy3j66adpaGigrKyMM888k29+85tMnjzZ69BEPPHUU09x3nnnHXL8yiuv5L777sNxHG655RZ+/vOf09zczJlnnsl///d/M23aNA+iFRl5g71GfvrTn3LppZfy6quv0tzcTFVVFRdeeCFf//rXDxk6KXKsMgyj3+P33nsvH/nIRwCIRqN8/vOf58EHHyQWi7FkyRL++7//W634w0CJvYiIiIiIiMgopjX2IiIiIiIiIqOYEnsRERERERGRUUyJvYiIiIiIiMgopsReREREREREZBRTYi8iIiIiIiIyiimxFxERERERERnFlNiLiIiIiIiIjGJK7EVERKSPc889l8997nNeh8FTTz2FYRg0Nzd7HYqIiEhWU2IvIiIinsuWDxNERERGIyX2IiIiIiIiIqOYEnsREREZUCwW44YbbqC6uppQKMTChQt56qmnMpffd999FBYW8s9//pOZM2eSn5/P0qVL2bdvX+acZDLJZz/7WQoLCykpKeHGG2/kyiuv5NJLLwXgIx/5CMuXL+cnP/kJhmFgGAbbt2/PXH/VqlWccsop5OXlcfrpp7Nhw4YR+u5FRERGByX2IiIiMqBrrrmGF154gYceeojXX3+df/3Xf2Xp0qVs2rQpc05nZyff//73+c1vfsPTTz/Nzp07ueGGGzKXf+c73+G3v/0t9957L8899xytra08/PDDmct/8pOfsGjRIj7xiU+wb98+9u3bR01NTebyL3/5y/zgBz9g5cqV+Hw+Pvaxj43I9y4iIjJa+LwOQERERLLTzp07uffee9m5cydVVVUA3HDDDTzyyCPce++9fOtb3wIgkUhwzz33MHnyZMD9MOC2227L3M6dd97JF7/4Rd773vcCcNddd/H3v/89c3kkEiEQCJCXl0dlZeUhcXzzm9/knHPOAeCmm27i4osvJhqNkpOTMzzfuIiIyCijxF5ERET6tWbNGlKpFNOmTetzPBaLUVJSkvk6Ly8vk9QDjBkzhvr6egBaWlqoq6vj1FNPzVxuWRYnn3wytm0fVhxz587tc9sA9fX1jBs37q1/UyIiIscgJfYiIiLSr/b2dizLYtWqVViW1eey/Pz8zL/9fn+fywzDwHGcoxZH79s3DAPgsD8UEBEROR5ojb2IiIj0a/78+aRSKerr65kyZUqfP/21zPcnEolQUVHByy+/nDmWSqV45ZVX+pwXCARIpVJHNX4REZHjhSr2IiIi0q9p06bx4Q9/mCuuuIIf/OAHzJ8/n/3797Ns2TLmzp3LxRdffFi3c+2113L77bczZcoUZsyYwZ133klTU1Om+g4wYcIEVqxYwfbt28nPz6e4uHi4vi0REZFjjir2IiIiMqB7772XK664gs9//vNMnz6dSy+9lJdffvktrW+/8cYbufzyy7niiitYtGgR+fn5LFmypM/wuxtuuAHLsjjhhBMoKytj586dw/HtiIiIHJMM52gughMREREZgm3bzJw5kw984AN8/etf9zocERGRUU+t+CIiIjKsduzYwaOPPso555xDLBbjrrvuYtu2bXzoQx/yOjQREZFjglrxRUREZFiZpsl9993HggULOOOMM1izZg2PP/44M2fO9Do0ERGRY4Ja8UVERERERERGMVXsRUREREREREYxJfYiIiIiIiIio5gSexEREREREZFRTIm9iIiIiIiIyCimxF5ERERERERkFFNiLyIiIiIiIjKKKbEXERERERERGcWU2IuIiIiIiIiMYkrsRUREREREREax/x//2m+Hmfu/fgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1200x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import json\n",
    "import glob\n",
    "import matplotlib.pyplot as plt\n",
    "data = []\n",
    "for i, path in enumerate(glob.glob(\"YOUR_DATA_PATH\")):\n",
    "    with open(path) as f:\n",
    "        one_device = json.load(f)\n",
    "        data.extend(one_device)\n",
    "\n",
    "snr_datas = []\n",
    "window_size = 10\n",
    "for d in data[:100]:\n",
    "    snr = []\n",
    "    for i in range(0, len(d), window_size):\n",
    "        window = d[i:i + window_size]\n",
    "        snr_value = calculate_snr(window)\n",
    "        snr.append(snr_value)\n",
    "    snr_datas.append(snr)\n",
    "\n",
    "\n",
    "plt.figure(figsize=(12, 6))\n",
    "for i, subarray in enumerate(snr_datas[:100]):\n",
    "    x = range(len(subarray))\n",
    "    y = subarray\n",
    "    plt.plot(x, y, marker='o', label=f'Subarray {i+1}')\n",
    "\n",
    "plt.xlabel('length')\n",
    "plt.ylabel('SNR')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Result"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### 2wikimqa ( llama2-7b-chat-hf )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "from datasets import Dataset\n",
    "import json\n",
    "from langchain_text_splitters import CharacterTextSplitter\n",
    "from torch.utils.data import DataLoader\n",
    "from transformers import AutoTokenizer\n",
    "\n",
    "model_name = \"llama2-7b-chat-hf\"\n",
    "\n",
    "tokenizer = AutoTokenizer.from_pretrained(model_name)\n",
    "\n",
    "def load_jsonl(file_path):\n",
    "    data = []\n",
    "    with open(file_path, 'r', encoding='utf-8') as f:\n",
    "        for line in f:\n",
    "            data.append(json.loads(line))  # 使用 json.loads 解析 JSONL 中的每一行\n",
    "    return data\n",
    "\n",
    "data_name = '2wikimqa'\n",
    "jsonl_data = load_jsonl(f\"/data/{data_name}.jsonl\")\n",
    "\n",
    "data_input = [d['input'] for d in jsonl_data]\n",
    "data_context = [d['context'] for d in jsonl_data]\n",
    "data_answers = [d['answers'] for d in jsonl_data]\n",
    "data_length = [d['length'] for d in jsonl_data]\n",
    "data_allclass = [d['all_classes'] for d in jsonl_data]\n",
    "\n",
    "data = Dataset.from_dict({'input':data_input,\n",
    "                         'context':data_context,\n",
    "                         'answers':data_answers,\n",
    "                         'length':data_length,\n",
    "                         'all_classes':data_allclass},)\n",
    "\n",
    "dataloader = DataLoader(data, batch_size=16, shuffle=False)\n",
    "\n",
    "text_splitter = CharacterTextSplitter(\n",
    "    separator=\"\",\n",
    "    chunk_size=300,\n",
    "    chunk_overlap=0,\n",
    "    length_function=len,\n",
    "    is_separator_regex=False,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from vllm import LLM, SamplingParams\n",
    "llm = LLM(model=model_name,tensor_parallel_size=1, trust_remote_code=True, gpu_memory_utilization=0.9)\n",
    "\n",
    "stop_tokens = [\"Question:\", \"Question\", \"USER:\", \"USER\", \"ASSISTANT:\", \"ASSISTANT\", \"Instruction:\", \"Instruction\", \"Response:\", \"Response\"]\n",
    "sampling_params = SamplingParams(temperature=0.0, top_p=1, max_tokens=512, stop=stop_tokens)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.88it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.35it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.02it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.64it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.51it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.21it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.28it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.41it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  1.95it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.23it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.24it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.10it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.86it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.48it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.28it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.43it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.34it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.18it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.21it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.84it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.67it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.75it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.64it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.49it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.66it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.35it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.20it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.94it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.93it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.82it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  1.42it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.52it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.39it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.44it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.84it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.84it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.26it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.20it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.04it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.51it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.57it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.35it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.43it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.45it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.88it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.04it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.56it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.23it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.91it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.44it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.29it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.39it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.64it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.33it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.23it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.10it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.47it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.79it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.74it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.37it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.65it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.15it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.22it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.96it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.19it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.25it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.40it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.42it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.48it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.26it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.15it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.29it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.80it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  5.12it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.86it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.63it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.05it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.23it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.66it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.20it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.38it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.26it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.86it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  1.76it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.53it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.48it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.34it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.26it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.72it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.21it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.49it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.35it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.01it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.98it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.15it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.47it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.78it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.52it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.50it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.90it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.23it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.02it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.67it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.50it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.97it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  1.95it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.90it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.25it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.64it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.34it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.22it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.00it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.22it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.24it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.99it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.51it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.84it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.82it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.38it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  5.03it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.01it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.46it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.16it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.83it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.68it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.15it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.21it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.23it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.62it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.89it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.68it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.20it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.62it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.50it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.37it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.70it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.53it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.11it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.32it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.98it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.39it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.90it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.99it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.66it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.07it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.03it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.91it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.00it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.17it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.55it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.63it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  1.68it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.21it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.41it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.13it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.49it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.34it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.80it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.35it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.90it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.53it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.37it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.50it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.38it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.50it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  1.71it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.46it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.34it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.51it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.83it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  1.50it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.71it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.02it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.59it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.67it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.33it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.96it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.21it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.38it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.23it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.35it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.82it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.83it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.31it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.83it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.45it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.12it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.29it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.00it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.42it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.10it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.79it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.38it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  1.69it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.70it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.78it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.68it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.52it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  4.18it/s]\n",
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  3.94it/s]\n"
     ]
    }
   ],
   "source": [
    "with open(\"IDs_FILE\", 'r', encoding='latin-1') as file:\n",
    "            content = file.read()\n",
    "ids = eval(content)\n",
    "outputs = []\n",
    "for i in range(len(data)):\n",
    "    d_doc = text_splitter.split_text(data[i]['context'])\n",
    "    d_doc_text = [d_doc[index] for index in ids[i][:30]]\n",
    "    prompt = '\\n'.join(d_doc_text)\n",
    "    promtp_ids = tokenizer.encode_plus(prompt, return_tensors=\"pt\")\n",
    "\n",
    "    prompt = f\"Answer the question based on the given passages. Only give me the answer and do not output any other words.\\n\\nThe following are given passages.\\n{prompt}\\n\\nAnswer the question based on the given passages. Only give me the answer and do not output any other words.\\n\\nQuestion: {data[i]['input']}\\nAnswer:\",\n",
    "\n",
    "    completions = llm.generate(prompt, sampling_params)\n",
    "    outputs.append(completions[0].outputs[0].text)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Score: 0.37266774891774884\n"
     ]
    }
   ],
   "source": [
    "from metrics import (\n",
    "    qa_f1_score,\n",
    "    rouge_zh_score,\n",
    "    qa_f1_zh_score,\n",
    "    rouge_score,\n",
    "    classification_score,\n",
    "    retrieval_score,\n",
    "    retrieval_zh_score,\n",
    "    count_score,\n",
    "    code_sim_score,\n",
    ")\n",
    "sum_score = 0\n",
    "for i in range(len(outputs)):\n",
    "    sum_score += qa_f1_score(outputs[i].lstrip('\\n').split('\\n')[0], data[i]['answers'][0])\n",
    "\n",
    "print(f\"Score: {sum_score/len(outputs)}\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "lora",
   "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.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
