{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import os\n",
    "from matplotlib.colors import LinearSegmentedColormap"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "colors = [\"red\", \"yellow\", \"green\"]\n",
    "cmap = LinearSegmentedColormap.from_list(\"score_cmap\", colors, N=256)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "import ast\n",
    "import re\n",
    "def parse_score(score_str):\n",
    "    match = re.search(r\"recall=(\\d+\\.\\d+)\", score_str)\n",
    "    if match:\n",
    "        return float(match.group(1))\n",
    "    else:\n",
    "        return pd.NA\n",
    "\n",
    "def evaluate_question_recall(output_file, title):\n",
    "    df = pd.read_csv(output_file, index_col=0)\n",
    "    df['recall'] = df['new_score'].apply(parse_score)\n",
    "    average_score = df['recall'].mean()\n",
    "    pivot_table = df.pivot(index=\"depth_percent\", columns=\"context_length\", values=\"recall\")\n",
    "   \n",
    "    fig, ax = plt.subplots(figsize=(10, 8))\n",
    "    cax = ax.pcolor(pivot_table, edgecolors='k', linewidths=1, cmap=cmap, vmin=0, vmax=1)\n",
    "    fig.colorbar(cax)\n",
    "\n",
    "    ax.xaxis.set_ticks_position('bottom')\n",
    "    ax.xaxis.set_label_position('bottom')\n",
    "\n",
    "    ax.set_xticks(range(len(pivot_table.columns)))\n",
    "    ax.set_xticklabels(pivot_table.columns)\n",
    "    ax.set_yticks(range(len(pivot_table.index)))\n",
    "    ax.set_yticklabels(pivot_table.index)\n",
    "\n",
    "    ax.set_xlabel('Context Length')\n",
    "    ax.set_ylabel('Depth Percent')\n",
    "\n",
    "    ax.invert_yaxis()\n",
    "    ax.set_title(f'{title}\\naverage score:{average_score}')\n",
    "\n",
    "    plt.xticks(rotation=45)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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a5fh8wOQvZBwAE7as2ePHnzwQXXt2lURERHKkyePvvvuO504ccLmE6Fr1qypDz74QK+//rrKlSunIkWK3HIBb5s2bfTZZ58pMDBQERERWrt2rZYuXapChQo5Hffs2bNVvHjxW35CdnJysvX57d69W++//74aNmzo0j/0n376qd5//3117NhR4eHhunjxoj766CMFBARYKyt+fn6KiIjQnDlzVKFCBQUFBalq1aq3nA/+xBNP6JtvvlGLFi3UtWtX7d+/X59//rnCw8Nt+vXq1UuzZs3SkCFDtH79ej3wwANKSEjQ0qVL9fTTT6t9+/ZZjqFbt2569NFH9f777ysqKirdgv2SJUtq0KBBeuutt3TlyhXVrl1b8+fP1+rVqzV79myb6SwjRozQp59+qoMHDyosLEyS1LNnT61fv159+vTRzp07bT57I1++fOkSnKx67LHHNHfuXD355JNasWKFGjRooJSUFO3atUtz587V4sWLVatWLYWHh+v111/XiBEjdOjQIXXo0EH58+fXwYMH9d1336lfv356/vnn5eXlpddff139+/dX06ZN1a1bNx08eFAzZsy4ZQItSVOmTFHDhg1VrVo19e3bV2XLltWJEye0du1a/fXXX/rjjz9uy/N2hCtfw9dr3ry5vL291bZtW/Xv31/x8fH66KOPVKRIEetUvOsFBwerRYsW+vrrr1WgQAG1bt3a5vFXX31Vq1atUuvWrVW6dGmdPHlS77//vkqWLGmtnoaHh6tAgQKaOnWq8ufPL39/f9WtW1eVKlVSeHi4nn/+eR07dkwBAQGaN29ehmvh/vOf/6hhw4a677771K9fP5UpU0aHDh3SwoULtWXLlnT9PTw89Pnnn6tDhw7WhDezF0IA4EZ38pJYQHZw/SUWrxcdHW38/f3T9Y+MjDRVqlSx3r/xcpynT582AwYMMJUqVTL+/v4mMDDQ1K1b18ydO9dmP7GxsaZ169Ymf/78Npf4TLsUZ0aXgD137pyJiYkxhQsXNvny5TNRUVFm165d6S7t6uhlcXft2mUkmSFDhtjtkxbXf//7X9OvXz9TsGBBky9fPtOzZ09z5syZTB3H3mVxb3yuN8a/efNm06NHD1OqVCnj4+NjihQpYtq0aWM2btxos92aNWtMzZo1jbe3t83lae39LNO8/fbbpkSJEsbHx8c0aNDAbNy4Md1lcY25dmnPl19+2ZQpU8Z4eXmZokWLmocfftjs37//ljHcTFxcnPHz8zOSzOeff55hn5SUFDN+/HhTunRp4+3tbapUqZJh37RLAGd0KdeMbqVLl75lfDeO+euPdeP2ycnJZuLEiaZKlSrGx8fHFCxY0NSsWdOMHTvWXLhwwabvvHnzTMOGDY2/v7/x9/c3lSpVMgMGDDC7d++26ff++++bMmXKGB8fH1OrVi2zatWqdD+fjC6La4wx+/fvN7169TJFixY1Xl5epkSJEqZNmzbmm2++ueXztndZ3NatW2d4jjK6zPWNMvsatsfe76uMYv3hhx9M9erVja+vrwkLCzMTJ060Xt75+n5p5s6dm+4S4WmWLVtm2rdvb4oXL268vb1N8eLFTY8ePcyePXts+n3//fcmIiLC5MmTx+bnsWPHDtOsWTOTL18+U7hwYdO3b1/zxx9/ZPgz+/PPP03Hjh1NgQIFjK+vr6lYsaIZOXLkTc/BpUuXTGRkpMmXL5/57bffbnkeAbiXxZhbrIYFAAB3ne+//14dOnTQqlWrbC77CwC3GwkHAAC5UJs2bbRz507t27cvyxdhAIDMYA0HAAC5yFdffaWtW7dq4cKFeuedd0g2ALgcFQ4AAHIRi8WifPnyqVu3bpo6dWqWPtwSABzBbxkAAHIR/s8I4E5L/zG8AAAAAHCbkHAAAAAAcBkSDgAAAAAuQ8IBALilY8eOqWvXripQoIACAgLUvn17HThwIFPbXrlyRWPHjlXZsmXl4+OjsmXL6vXXX9fVq1dt+vXu3VsWi8Xu7dixYzb9k5OTNX78eFWqVEm+vr4KCQlR69at9ddff1n7rFy50u7+fvvtt3SxZmafGzZs0MCBA1WlShX5+/urVKlS6tq1q/bs2ZNuf/aeU6VKlTJ17gDgbsCicQDATcXHx6tJkya6cOGCXnrpJXl5eenf//63IiMjtWXLFhUqVOim2z/66KP6+uuv1adPH9WqVUu//fabRo4cqSNHjmjatGnWfv3791ezZs1stjXG6Mknn1RYWJhKlChhbb9y5Ypat26tNWvWqG/fvqpevbrOnTundevW6cKFCypZsqTNfp599lnVrl3bpq1cuXI29zO7z4kTJ+rXX39Vly5dVL16dcXGxuq9997Tfffdp99++01Vq1a12a+Pj4+mT59u0xYYGHjTcwYAdxX3fcg5ADjv8uXLJiUlxd1hZEu369xMnDjRSDLr16+3tu3cudN4enqaESNG3HTb9evXG0lm5MiRNu1Dhw41FovF/PHHHzfdfvXq1UaSGTduXLqYvLy8zLp16266/YoVK4wk8/XXX9+0nyP7/PXXX01SUpJN2549e4yPj4/p2bOnTXt0dLTx9/e/5bEB4G7GlCoADjt8+LCefvppVaxYUX5+fipUqJC6dOmiQ4cOWfts3LhRFotFn376abrtFy9eLIvFogULFljbjh07pj59+igkJEQ+Pj6qUqWKPvnkE5vt0qbHfPXVV3rllVdUokQJ5c2bV3FxcTp79qyef/55VatWTfny5VNAQIBatmypP/74I8P427VrJ39/fxUpUkSDBw+2xrRy5UqbvuvWrVOLFi0UGBiovHnzKjIyUr/++mumztO7776rKlWqKG/evCpYsKBq1aqlL774wqbPsWPH9Pjjj6t48eLy8fFRmTJl9NRTTyk5Odna58CBA+rSpYuCgoKUN29e3X///Vq4cGGmz40jz2PXrl06cuSITds333yj2rVr21QIKlWqpAcffFBz58696TlYvXq1JKl79+427d27d5cxRnPmzLnp9l988YUsFoseeeQRa1tqaqreeecddezYUXXq1NHVq1d16dKlm+5Hki5evJhuGldW9lm/fn15e3vbtJUvX15VqlTRzp07M9wmJSXF+rMAgNyGhAOAwzZs2KA1a9aoe/fu+s9//qMnn3xSy5YtU+PGja1v0mrVqqWyZctm+IZ0zpw5KliwoKKioiRJJ06c0P3336+lS5dq4MCBeuedd1SuXDk9/vjjmjx5crrtX3vtNS1cuFDPP/+8xo8fL29vbx04cEDz589XmzZtNGnSJL3wwgvatm2bIiMj9ffff1u3TUhIUNOmTbV06VI9++yzevnll7VmzRoNGzYs3XGWL1+uRo0aKS4uTqNHj9b48eN1/vx5NW3aVOvXr7/pOfroo4/07LPPKiIiQpMnT9bYsWNVo0YNrVu3ztrn77//Vp06dfTVV1+pW7du+s9//qPHHntM//3vf63n8cSJE6pfv74WL16sp59+WuPGjVNiYqLatWun7777LlPnxpHnUblyZfXq1ct6PzU1VVu3blWtWrXSHatOnTrav3+/Ll68aPc8JCUlSZL8/Pxs2vPmzStJ2rRpk91tr1y5orlz56p+/foKCwuztu/Y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3rwM33yfOnUqyzF9/fXX6d5ARkVF6dixY/rhhx+sbYmJifroo49s+tWsWVPh4eH617/+leEVhW4V15kzZ2zue3t7KyIiQsYYXblyRR4eHurQoYN+/PHHDN/Mpz2XVq1aaf369Vq7dq31sYSEBE2bNk1hYWG3fKPr6PPI6LK4Dz/8sDZs2GAT5+7du7V8+XJ16dLlltvf6PLlyxo5cqSKFSumHj16ZBjT0qVL1bFjR+vVrK6XP39+tWrVSmvWrLEmXpK0c+dOrVmzRg899JDd5ydJf/zxh3744Qc1b95cHh4eDu8zJSVF3bp109q1a/X111+rXr16GT7PxMTEDK/g9dprr8kYoxYtWmS4HQDcbahwAHBYmzZt9NlnnykwMFARERFau3atli5davcTp7t166ZRo0bJ19dXjz/+uPVNXpo33nhDK1asUN26ddW3b19FRETo7Nmz2rx5s5YuXZqpqSdt2rTRq6++qpiYGNWvX1/btm3T7NmzVbZsWZt+/fv313vvvacePXroueeeU7FixTR79mz5+vpKkrXq4eHhoenTp6tly5aqUqWKYmJiVKJECR07dkwrVqxQQECAfvzxR7vxNG/eXEWLFlWDBg0UEhKinTt36r333lPr1q2tFYHx48fr559/VmRkpPr166fKlSvr+PHj+vrrr/XLL7+oQIECGj58uL788ku1bNlSzz77rIKCgvTpp5/q4MGDmjdvXrpzeSNHn0flypUVGRlp83kkTz/9tD766CO1bt1azz//vLy8vDRp0iSFhIRo6NChNsfLaPuuXbuqePHiioiIUFxcnD755BMdOHBACxcuzLA6MmfOHF29ejXD6VRpxo8fr2XLlqlp06Z69tlnJUn/+c9/FBQUpJdeesnar1u3bvLz81P9+vVVpEgR7dixQ9OmTVPevHn1xhtvZGmfQ4cO1Q8//KC2bdvq7Nmz+vzzz2328+ijj0q6tr7j3nvvVY8ePVSpUiVJ1z6DZtGiRWrRooXat29v9/kBwF3FnSvWAeRM586dMzExMaZw4cImX758JioqyuzatcuULl3aREdHp+u/d+9eI8nmilM3OnHihBkwYIAJDQ01Xl5epmjRoubBBx8006ZNs/a52adGJyYmmqFDh5pixYoZPz8/06BBA7N27VoTGRlpc5lXY4w5cOCAad26tfHz8zPBwcFm6NCh1su3/vbb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vLxsHm/Xrt1tCw4AAABAzuZwwtG3b19J0quvvpruMYvFopSUFOejAgAAAHIQplTZ53DCceNlcAEAAADAHocTjuslJibK19f3dsUCAAAA5EhUOOxzeNF4SkqKXnvtNZUoUUL58uXTgQMHJEkjR47Uxx9/fNsDBAAAAJBzOZxwjBs3TjNnztSbb74pb29va3vVqlU1ffr02xocAAAAkBOkVTju9C0ncDjhmDVrlqZNm6aePXvK09PT2n7PPfdo165dtzU4AAAAADmbwwnHsWPHVK5cuXTtqampunLlym0JCgAAAMDdweGEIyIiQqtXr07X/s033+jee++9LUEBAAAAOQlTquxz+CpVo0aNUnR0tI4dO6bU1FR9++232r17t2bNmqUFCxa4IkYAAAAAOZTDFY727dvrxx9/1NKlS+Xv769Ro0Zp586d+vHHH/XQQw+5IkYAAAAgW6PCYV+WPofjgQce0JIlS253LAAAAADuMg5XODZs2KB169ala1+3bp02btx4W4ICAAAAcHdwOOEYMGCAjh49mq792LFjGjBgwG0JCgAAAMhJmFJln8MJx44dO3Tfffela7/33nu1Y8eO2xIUAAAAgLuDwwmHj4+PTpw4ka79+PHjypMnS0tCAAAAgBzN4obqhuVurXA0b95cI0aM0IULF6xt58+f10svvcRVqgAAAADYcLgk8dZbbykyMlKlS5e2ftDfli1bFBISos8+++y2BwgAAABkd+5YU5FT1nA4nHCULFlSW7du1ezZs/XHH3/Iz89PMTEx6tGjh7y8vFwRIwAAAIAcyqGE48qVK6pUqZIWLFigfv36uSomAAAAAHcJhxIOLy8vJSYmuioWAAAAIEdiSpV9WfocjokTJ+rq1auuiAcAAADAXcThNRwbNmzQsmXL9PPPP6tatWry9/e3efzbb7+9bcEBAAAAOQEVDvscTjgKFCigzp07uyIWAAAAAHcZhxOOGTNmuCIOAAAAAHchh9dwSNLVq1e1dOlSffjhh7p48aIk6e+//1Z8fPxtDQ4AAADICe70p4y7YwpXVjlc4Th8+LBatGihI0eOKCkpSQ899JDy58+viRMnKikpSVOnTnVFnAAAAAByIIcrHM8995xq1aqlc+fOyc/Pz9resWNHLVu27LYGBwAAAOQEVDjsc7jCsXr1aq1Zs0be3t427WFhYTp27NhtCwwAAABAzudwwpGamqqUlJR07X/99Zfy589/W4ICAAAAchIui2ufw1OqmjdvrsmTJ1vvWywWxcfHa/To0WrVqtXtjA0AAABADudwhePtt99WVFSUIiIilJiYqEceeUR79+5V4cKF9eWXX7oiRgAAAAA5lMMJR8mSJfXHH39ozpw5+uOPPxQfH6/HH39cPXv2tFlEDgAAAOQWTKmyz6GE47ffftOPP/6o5ORkNW3aVG+++aar4pIkjRkzRmPHjrVpq1ixonbt2qVDhw6pTJkyGW43d+5cdenSxaWxAQAAALi1TCcc33zzjbp16yY/Pz95eXlp0qRJmjhxop5//nlXxqcqVapo6dKl1vt58lwLOTQ0VMePH7fpO23aNL311ltq2bKlS2MCAAAArkeFw75MJxwTJkxQ3759NWXKFHl6emrChAkaP368yxOOPHnyqGjRounaPT0907V/99136tq1q/Lly5e1g52T5H3LXpCkK5KuSjrj7kBykEv/fL0ozpsjGGuOY6xlDWPNcYy1rGGsOS7Z3QHAGRZjjMlMx3z58mnLli0qV66cJCk5OVn+/v46duyYihQp4pLgxowZo7feekuBgYHy9fVVvXr1NGHCBJUqVSpd302bNqlWrVr69ddfVb9+/ZvuNykpSUlJSdb7cXFxCg0Nve3xA+lYJGXqFQc4ibGGO4WxhjvswoULCggIcHcYVnFxcQoMDNT5C9KdDisuTioQmP3OyY0yXeG4dOmSzRPx9vaWr6+v4uPjXZZw1K1bVzNnzlTFihV1/PhxjR07Vg888ID+/PPPdJ/58fHHH6ty5cq3TDaka9WaG9eGSJI6SfK6TcHf7X7Wtf82tHF3IDlIoqTvJd0vqbSbY8lJGGuOY6xlDWPNcYy1rPlZKnJJmnqfuwPJORJTpEfWuzuKm7OYa7c7fcycwKFF49OnT7eZrnT16lXNnDlThQsXtrY9++yzty2469diVK9eXXXr1lXp0qU1d+5cPf7449bHLl++rC+++EIjR47M1H5HjBihIUOGWO9bKxwVJPnetvDvbqv/+VrZrVHkLPH/fC0hzpsjGGuOY6xlDWPNcYy1rFkt+SdLHUu4O5CcI+GquyOAMzKdcJQqVUofffSRTVvRokX12WefWe9bLJbbmnDcqECBAqpQoYL27dtn0/7NN9/o0qVL6tWrV6b24+PjIx8fH1eECAAAgNwo9Z/bnT5mDpDphOPQoUMuDCNz4uPjtX//fj322GM27R9//LHatWun4OBgN0UGAAAAICMOf/DfnfT888+rbdu2Kl26tP7++2+NHj1anp6e6tGjh7XPvn37tGrVKi1atMiNkQIAACBXo8JhV7ZOOP766y/16NFDZ86cUXBwsBo2bKjffvvNppLxySefqGTJkmrevLkbIwUAAACQkWydcHz11Ve37DN+/HiNHz/+DkQDAAAAwFHZOuEAAAAAcgSmVNnl4e4AAAAAANy9slThSE1N1b59+3Ty5EmlptqmVo0aNbotgQEAAAA5BhUOuxxOOH777Tc98sgjOnz4sIyx/XhDi8WilJSU2xYcAAAAgJzN4YTjySefVK1atbRw4UIVK1ZMFovFFXEBAAAAuAs4nHDs3btX33zzjcqVK+eKeAAAAICchylVdjm8aLxu3brat2+fK2IBAAAAcJfJVIVj69at1u+feeYZDR06VLGxsapWrZq8vLxs+lavXv32RggAAABkd1Q47MpUwlGjRg1ZLBabReJ9+vSxfp/2GIvGAQAAAFwvUwnHwYMHXR0HAAAAkHNR4bArUwlH6dKlrd+vWrVK9evXV548tptevXpVa9assekLAAAAIHdzeNF4kyZNdPbs2XTtFy5cUJMmTW5LUAAAAADuDg5fFjdtrcaNzpw5I39//9sSFAAAAJCjMKXKrkwnHJ06dZJ0bYF479695ePjY30sJSVFW7duVf369W9/hAAAAAByrEwnHIGBgZKuVTjy588vPz8/62Pe3t66//771bdv39sfIQAAAJDdGd35ioO5dZfsINMJx4wZMyRJYWFhev7555k+BQAAAOCWHF7DMXr0aEnSyZMntXv3bklSxYoVVaRIkdsbGQAAAIAcz+GrVF28eFGPPfaYSpQoocjISEVGRqpEiRJ69NFHdeHCBVfECAAAAGRvqW665QAOJxxPPPGE1q1bpwULFuj8+fM6f/68FixYoI0bN6p///6uiBEAAABADuXwlKoFCxZo8eLFatiwobUtKipKH330kVq0aHFbgwMAAAByBC6La5fDFY5ChQpZr1h1vcDAQBUsWPC2BAUAAADg7uBwwvHKK69oyJAhio2NtbbFxsbqhRde0MiRI29rcAAAAECOwBoOuxyeUvXBBx9o3759KlWqlEqVKiVJOnLkiHx8fHTq1Cl9+OGH1r6bN2++fZECAAAAyHEcTjg6dOjggjAAAAAA3I2y/DkcAAAAAP7BonG7HF7DIUnnz5/X9OnTNWLECJ09e1bStelTx44du63BAQAAAMjZHK5wbN26Vc2aNVNgYKAOHTqkvn37KigoSN9++62OHDmiWbNmuSJOAAAAIPuiwmGXwxWOIUOGqHfv3tq7d698fX2t7a1atdKqVatua3AAAAAAcjaHE44NGzZk+IniJUqUsLlULgAAAAA4PKXKx8dHcXFx6dr37Nmj4ODg2xIUAAAAkKMwpcouhysc7dq106uvvqorV65IkiwWi44cOaJhw4apc+fOtz1AAAAAADmXwwnH22+/rfj4eBUpUkSXL19WZGSkypUrp/z582vcuHGuiBEAAADI3vikcbscnlIVGBioJUuW6JdfftHWrVsVHx+v++67T82aNXNFfAAAAAByMIcTjjQNGzZUw4YNb2csAAAAAO4yDiUcqampmjlzpr799lsdOnRIFotFZcqU0cMPP6zHHntMFovFVXECAAAA2ReLxu3K9BoOY4zatWunJ554QseOHVO1atVUpUoVHT58WL1791bHjh1dGScAAACAHCjTFY6ZM2dq1apVWrZsmZo0aWLz2PLly9WhQwfNmjVLvXr1uu1BAgAAANma0Z2vOJg7fLwsynSF48svv9RLL72ULtmQpKZNm2r48OGaPXv2bQ0OAAAAQM6W6YRj69atatGihd3HW7ZsqT/++OO2BAUAAADkKFwW165MJxxnz55VSEiI3cdDQkJ07ty52xIUAAAAgLtDphOOlJQU5cljf8mHp6enrl69eluCAgAAAHB3yPSicWOMevfuLR8fnwwfT0pKum1BAQAAADkKl8W1K9MJR3R09C37cIUqAAAAANfLdMIxY8YMV8YBAAAA5FxUOOzK9BoOAAAAAHAUCQcAAAAAl8n0lCoAAAAAdjClyi4qHAAAAABchgoHAAAA4CwqHHZR4QAAAADgMiQcAAAAgLNS3XTLgilTpigsLEy+vr6qW7eu1q9fn6ntvvrqK1ksFnXo0MGh45FwAAAAALnEnDlzNGTIEI0ePVqbN2/WPffco6ioKJ08efKm2x06dEjPP/+8HnjgAYePScIBAAAA5BKTJk1S3759FRMTo4iICE2dOlV58+bVJ598YneblJQU9ezZU2PHjlXZsmUdPiYJBwAAAOAsN06p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Pn366OrVq7wZvIk///xTnTp1UqNGjdSxY0cNHTpUkuTp6enmyLK3LVu2qFGjRjp58qS++uorJSYm8sfFQdu2bVNUVJT+7//+T2fOnHF3ODnCtm3b1KBBA+3atUuenp4kHZmwfft2derUSY0bN1bLli312Wef8VrNhKNHj2rNmjXWBBeZc+7cOf3111/666+/eO+BHI+EIwOHDx/Wgw8+qHr16umtt95Sly5d9Msvv+i+++7Tvn373B1etrRnzx41btxYERERGjlypOrVq6cvv/xSDz30kE6fPi1JSk1NdXOU2c8ff/yhevXqaeDAgXrrrbf03Xff6dKlS1TTHLB7925FRkaqQYMGeuSRR1SoUCGbxzmPGZswYYI2bNig1q1ba8eOHfL09OQN4U38+eefatSokSpWrKhx48apcOHC+vDDD5WUlOTu0LK1Xbt2qUKFCurZs6d+++03/g5k0rZt21S/fn21aNFC4eHheuKJJ7Ro0SLr4/xeQ07DJ41n4Ntvv9WECRO0bNkyBQQESJIOHDigRx55RHFxcVq5cqWKFCmi1NRUm49+z61SU1P10ksv6cyZM/roo48kSVeuXFHv3r315Zdfqm7dulq9erXy5MnDObvO77//rtq1a2vYsGEaN26ckpKSVLlyZbVt21bvvPOOu8PL9owxSk1N1TPPPKOkpCR9/PHHSk1N1Q8//KD4+HgFBASoXbt27g4z23r++ed14sQJeXh4aNmyZfq///s/VatWTdK1c8t/VP/n+PHjat68uVq0aKG33npLkrR161a9+OKLmjJligoWLKiAgADlyZPHzZFmL2fPnlWPHj0UEhKi3bt36/Tp05o5c6YaNGjA34Gb+Pvvv1W7dm1169ZNjzzyiHbv3q0ZM2bowoULevLJJ/X444+7O0TAYbziM3D8+HEdOnTImmykpqaqbNmy+u677+Tt7a1OnTpJEr8w/+Hh4aH9+/db17oYY+Tl5aX69eurf//+OnXqlHr27Gnti2trXaZMmaLnn39e48aNs77Ba9OmjTZs2GCdFsT/A+yzWCzy9PTUX3/9pTp16sgYo8jISI0fP16jR49Wt27dFB0dbf2PKufSVu3ateXp6akXX3xRERERat26tU6cOKEpU6ZozZo17g4vWzlw4IA6dOigAQMGWNvmzp2r9evXq3HjxmrVqpWio6OVmJjoxiizn+PHj6tChQrq27ev1q1bp6JFi6p379769ddfqXTcxLZt2xQcHKwxY8aoVq1a6tmzp/71r3+pZs2amjRpkj7//HN3hwg4jHd/10l7Q9K2bVv5+PjojTfekHTtTXJqaqqKFSum999/XydOnNCcOXPcGWq2kZKSopSUFFWoUEEJCQlat26dLBaLDh06pFGjRumee+7R8OHDtWvXLv3999/uDjfb8PPz06uvvmodY5Lk7e2tJ598Ups3b9bXX38tSfyX+SZSU1OVmpqqM2fO6NSpU/rkk0/k7++vhQsX6pdfftGiRYs0f/5861oizqUtf39/7d27V1WqVNE777yj2rVrq0yZMho2bJiqVavGG8Lr1K5dW9HR0QoLC5MkTZw4UePHj9e///1vzZ8/X71799b27dv15ZdfujfQbCJtmll4eLiefPJJNWjQQJL066+/KiQkJF3SkfZ3BNd4eXnp8OHD2rt3r7WtRo0aeu6551S3bl3NnDlT27dvd2OEgONIOPS/X45p85cLFCigLl26aNGiRdY/IGn/ma9atar1P/q5WVpy5uHhIU9PT3Xp0kWxsbHq27evGjVqpIiICHXp0kVPPvmkWrVqpZ07d9r88sytDh06pLVr10qSihcvbm23WCxKTU1VRESEHn/8cX3xxRc6fvy4u8LMETw8POTh4aHHHntMCxYs0KxZsxQZGang4GAVK1ZMTZo00TvvvKOFCxfqyJEjVDhu0LhxY+vvtcqVKyspKUkeHh7Kly+fTp48KQ8Pj1z9JjA2Ntb6vbe3t8qVK2e9X7NmTS1evFjR0dGqWbOm+vTpo4sXL2rPnj3uCDVb2b17tx566CHt3btXvr6+qlKlijw8PKxXLlyzZo1N0nH58mWNGzdO//73v90cefZRrFgxFS9eXEuWLLGeN+na67Rv377avn27tmzZ4r4AgSzI9QnH9u3b1aNHDz300ENq27at/vvf/yogIECDBw9WQECAPvzwQ82YMcPaPyAgQGXLlpWPj4+k3DlNY9++fRo7dqxiYmL05ptv6u+//1aNGjX05Zdfql+/fmrWrJmmT5+uqVOnyhijEydOqEqVKgoNDXV36G61ZcsW1ahRw26ymvbmr3HjxtqyZYv1Eq/8p/l//v77by1fvtxaAZKuvfkLCAjQ6tWrlZCQYNM/ICBAvr6+yp8/f66vcNyYPHh4eOjs2bPaunWr+vXrp82bN2v69Olq0KCBqlevrt27d+faK8zt379fxYsXV6tWraxtaf+QMsaoWbNmeuihhyRde30mJSUpIiJClStXdku82cWWLVt0//3365dfftHWrVsl/W/ceXt7W89hWtLxxBNPqGvXrnrttdfUsmVLt8XtbpcvX9b58+et56dy5crq0aOHRo4cqfnz59v0rVevnqpXr64lS5a4IVLACSYX27NnjwkICDD9+vUzL7zwgnn44YeNxWIxr7zyiklISDAHDx40Xbt2NdWqVTOPPvqo+eyzz8yTTz5pAgICzJ49e9wdvlts3brVFC5c2DzyyCOmUaNGpkGDBqZLly7mwoULdrd58cUXTfXq1c2pU6fuYKTZy5YtW4y/v78ZPHiw3T6pqanW71u2bGkaNWpkEhMT70R4OcLWrVtNhQoVTNWqVU3+/PlN/fr1rY/93//9n4mIiDABAQFm1qxZxhhjrl69akaNGmWaNGlizp8/766w3Wrnzp2mb9++Ji4uzhhz7ZwYY0xKSooxxphevXqZ0qVLm9KlS5s//vjDGGPMxo0bTffu3XPt7zhjjFmzZo0JDQ015cuXN1FRUdb2tPN3o5EjR5rw8HBz8ODBOxRh9rNlyxbj5+dnXn/9ddO1a1dTs2bNDPtduXLFGHNtDObNm9cUKlTI/P7773cw0uxl27Ztpnnz5qZy5cqmVatW5pVXXrE+9vTTTxtfX18zY8YMc+7cOWt7q1atzMiRI90QLZB1uTrheOWVV0zz5s1t2v7zn/+YoKAg8/zzz5vk5GTz999/m+nTp5v77rvP1K5d2zRp0sRs2bLFTRG719GjR02VKlXM8OHDrW0zZ840VatWNfv27TPG/O+NjDHGbN682fTq1csUKFAgV/9B2bVrl/H39zcvvviiMebaH9wFCxaYTz/91MybN8+mb9r5mzBhgqldu7Y5e/bsHY83Ozpw4IApVqyYGTt2rDlw4ID55ZdfTMmSJc26deusfZYuXWrat29vfH19zb333msaNWpkgoKCcu3rdd++faZEiRLG19fXdO7cOV3SYYwx7733nqlUqZLZvHmzzba5OdFNTU01a9euNZUrVzZffPGFqVChgmnVqpX18b///tv6/erVq82QIUNy/e+433//3Xh7e1v/NixfvtyULl3afPXVVxn2v3z5svXN9J9//nknQ81W9u/fb4KCgsyAAQPM1KlTzZNPPmnCw8PNAw88YP1bMGTIEOPn52d69uxphg4dap566ikTEBBgduzY4eboAcfk6oRj6NCh1oQj7b8uxhgzdepUkzdvXjNlyhSb/pcvXzaXL1++ozFmF6mpqWb27NmmRYsW5tChQ9ZfhpcvXzYlS5Y08+fPt+mfkpJiduzYYZ599lmzbds2d4ScLaSkpJiYmBgTFBRkFi1aZFJTU02rVq3MfffdZ0qWLGl8fX1Nhw4dzKFDh6z9jTEmISHBHDlyxJ2hZytTp041zZs3N0lJScaYa6/Xxo0bm7lz55oPPvjAxMbGGmOuvRlcunSpefHFF817772Xa/9LHxcXZ3r27GkefvhhM3nyZHP//feb9u3bW5OO5ORka98zZ85Yv7++ypabJSQkmM6dO5tjx46Z7777zpQrV8507NjRxMTEmNGjR5v4+HiTkJBgXnnlFdO6dWuzdetWd4fsNmfOnDG1atWy+UfUqVOnzL333msee+yxDLc5fvy46dSpk80/DHKj6dOnm8aNG1t/ryUnJ5vly5eb8PBwU7duXWu/Tz/91PTv39/cf//9pnv37tZqJJCT5OqE45133jH58+c3x44dM8YY64veGGPGjh1r/P39zeHDh90VXrazfPly8/HHH1vvX7161SQmJprw8PAM/5N19epVm0Qutzpy5Ijp3LmzeeCBB0z58uVNixYtzI4dO0xsbKx1itr1f5ivrxLhmpdfftmUKlXKev+tt94y3t7epn79+qZs2bImJCTEbNiwwY0RZj/jx483n332mbl69ar57LPPbpp0wFZiYqK59957zYIFC4wx1373FShQwFgsFpvkIj4+3maqS261fv166/dpFbRvv/3W+Pr6mpUrV2a4TW6uoqUZPXq0KV26tE1bWoWtbNmypkOHDtb2lJQUc/XqVZv3KUBOkqsTjqSkJNOoUSNz//33m9OnTxtjjLWCcfz4cRMaGmq+/fZbd4bodnFxcSY+Pt4YY/tG+Prv77//fvPll19a70+bNs389ddfdy7IbCjt/KR9PXLkiGnTpo1p1qyZ2bt3r03fb7/91uTLl8/s2LGD/zDfIO38/fHHH6Zo0aImPDzcdOnSxXh5eZnFixdb1w41adLENGrUyJ2hZgunT582x48fT9eelJRkZs2alS7puHz58k3XX+UW1/8+S3sNRkdHm++++84YY0yP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",
      "text/plain": [
       "<Figure size 1000x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# set your model\n",
    "model = \"<your model name>\"\n",
    "output_dir = \"<your path>/needle-in-the-haystack-test/output/<your model name>\"\n",
    "\n",
    "min_len, max_len = 1000, 32000\n",
    "depth_n = 8\n",
    "len_n = 8\n",
    "\n",
    "sf = \"SFquestion_default\"\n",
    "output_file = os.path.join(output_dir, sf, f\"{min_len}_{max_len}_{len_n}_{depth_n}\", \"rouge_results.csv\")\n",
    "title = f\"{model} needle-in-a-haystack\"\n",
    "evaluate_question_recall(output_file, title)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "llicl",
   "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.9.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
