{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 135,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.colors as mcolors\n",
    "\n",
    "import os"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 136,
   "metadata": {},
   "outputs": [],
   "source": [
    "# set your baseline and recall results directory\n",
    "baseline_dir = \"<your path>/output/default/baseline/<your model name>/ntask_nshot\"\n",
    "recall_dir = \"<your path>/output/default/recall/<your model name>\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 137,
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.stats import ttest_ind, ttest_rel\n",
    "sign = lambda x: (1, -1)[x<0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 138,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_loc(perm_id, permutations, task_name):\n",
    "    perm_row = permutations.iloc[perm_id]\n",
    "    column_number = [i for i, value in enumerate(perm_row) if value == task_name]\n",
    "    return column_number[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 139,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_one_matrix(baseline_dir, recall_dir, n_task, n_shot):\n",
    "    # return an 8x8 matrix of needle-in-a-task-haystack test...\n",
    "    baseline_df = pd.read_csv(os.path.join(baseline_dir, \"results.csv\"), index_col=0)\n",
    "    baseline_df[baseline_df[\"n_shot_per_class\"] == n_shot]\n",
    "\n",
    "    recall_df = pd.read_csv(os.path.join(recall_dir, \"results.csv\"), index_col=0)\n",
    "\n",
    "    permutations = pd.read_csv(os.path.join(recall_dir, \"permutations.csv\"), index_col=0)\n",
    "\n",
    "    task_list = recall_df[\"task_name\"].unique().tolist()\n",
    "\n",
    "    agg = {task_name: [[] for _ in range(len(task_list))] for task_name in task_list}\n",
    "    for index, row in recall_df.iterrows():\n",
    "        task_name = row[\"task_name\"]\n",
    "        loc = get_loc(row[\"permutation_id\"], permutations, task_name)\n",
    "        agg[task_name][loc].append(row[\"accuracy\"])\n",
    "\n",
    "    final_agg = {task_name: [[] for _ in range(len(task_list))] for task_name in task_list}\n",
    "    episode_agg = {idx: [0.0 for _ in range(len(task_list))] for idx in range(5)}\n",
    "\n",
    "    for perm_id in range(5):\n",
    "        for task_name in task_list:\n",
    "            sub_df = recall_df[(recall_df[\"task_name\"] == task_name) & (recall_df[\"permutation_id\"] == perm_id)]\n",
    "            baseline_sub_df = baseline_df[(baseline_df[\"task_name\"] == task_name) & (baseline_df[\"n_shot_per_class\"] == n_shot)]\n",
    "            loc = get_loc(perm_id, permutations, task_name)\n",
    "            t, p = ttest_rel(sub_df['accuracy'], baseline_sub_df['accuracy'])\n",
    "            pass_or_not = sign(t) * int(p < 0.05) # 1: pass; -1: not pass\n",
    "            final_agg[task_name][loc].append(pass_or_not)\n",
    "            episode_agg[perm_id][loc] = pass_or_not\n",
    "\n",
    "    for task in task_list:\n",
    "        for j in range(len(task_list)):\n",
    "            final_agg[task][j] = np.mean(final_agg[task][j]) if len(final_agg[task][j])>0 else np.nan\n",
    "\n",
    "    matrix = np.array([episode_agg[key] for key in episode_agg])\n",
    "    avg_for_idx = np.mean(matrix, axis=0)\n",
    "\n",
    "    chunks = np.array_split(avg_for_idx, 8)\n",
    "    averages = np.array([np.mean(chunk) for chunk in chunks])\n",
    "    \n",
    "    return averages\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 140,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_35920/1580894248.py:2: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  sign = lambda x: (1, -1)[x<0]\n",
      "/tmp/ipykernel_35920/1580894248.py:2: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  sign = lambda x: (1, -1)[x<0]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_35920/1580894248.py:2: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  sign = lambda x: (1, -1)[x<0]\n",
      "/tmp/ipykernel_35920/1580894248.py:2: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  sign = lambda x: (1, -1)[x<0]\n",
      "/tmp/ipykernel_35920/1580894248.py:2: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  sign = lambda x: (1, -1)[x<0]\n",
      "/tmp/ipykernel_35920/1580894248.py:2: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  sign = lambda x: (1, -1)[x<0]\n",
      "/tmp/ipykernel_35920/1580894248.py:2: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  sign = lambda x: (1, -1)[x<0]\n",
      "/tmp/ipykernel_35920/1580894248.py:2: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  sign = lambda x: (1, -1)[x<0]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "n_shot = 2\n",
    "all_avgs = []\n",
    "for n_task in [8, 16, 24, 32, 40, 48, 56, 64]:\n",
    "    _recall_dir = os.path.join(recall_dir, f\"ntask{n_task}_nshot{n_shot}\")\n",
    "\n",
    "    avg = get_one_matrix(baseline_dir, _recall_dir, n_task=n_task, n_shot=n_shot)\n",
    "    all_avgs.append(avg)\n",
    "\n",
    "all_avgs = np.array(all_avgs)\n",
    "scale_n_task_results = all_avgs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 141,
   "metadata": {},
   "outputs": [],
   "source": [
    "def truncate_colormap(cmap, min_val=0.0, max_val=1.0, n=100):\n",
    "    new_cmap = mcolors.LinearSegmentedColormap.from_list(\n",
    "        'truncated({},{:.2f},{:.2f})'.format(cmap.name, min_val, max_val),\n",
    "        cmap(np.linspace(min_val, max_val, n)))\n",
    "    return new_cmap\n",
    "cmap = truncate_colormap(plt.cm.RdBu, 0.1, 0.9)\n",
    "cmap.set_bad(color='lightgrey')  # You can set this to any color you like"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 142,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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jEqeDJXkWEtLy2L/YD9+/DiA/6YqyB9PUtRdrvOlp6dj5MiRGDduXIFt1atX1zrOfExSiIiIJCCTyXRqsdF3a09MTAwmTpyIVatW4ddff0VQUBD2798PIyMjNGrUCPfv30d0dHShrSnNmjXD1atX9d5jwWnxiYiIKons7Gw8fPhQZYmPj4dCocB7772Hbt26YdiwYVi9ejUuXbqERYsWAQD8/PzQvn179OvXD5GRkbhz5w52796tnF9lypQpOH78OMaMGYOoqCjcvHkTW7duxZgxY3SKly0pREREEpAZPV90OV5be/bsgZubm8q6unXr4t1338U///yDHTt2AADc3NywcuVKDBw4EF27dkXjxo2xadMmfPzxxxg4cCAyMjKUlyADQKNGjXD48GFMmzYN7dq1gxAC3t7eGDBgQMkrCCYpREREkpDJZDDSoctGaHnsmjVrsGbNmiK3f/755yqP33zzTWRnZysfOzg44Mcffyzy+FdffRX79u0rcntsbKzGseZjdw8REREZJLakEBERScDQBs4aIiYpREREEpDJdByTUvFzFHb3EBERkWFiSwoREZEE2N2jHpMUIiIiCTBJUY/dPURERGSQ2JJCREQkASnu3VPeMEkhIiKSgEym2xU6laC3h0kKERGRFNiSoh7HpBAREZFBYksKERGRBHh1j3oG35Ly77//4r333oOjoyMsLCzQsGFDnD17VuqwiIiIdJLf3aPLUtEZdEtKUlIS2rRpg44dO2L37t1wdnbGzZs3YW9vL3VoREREVMoMOkmZP38+PD09sXr1auW6mjVrFntMdna2yq2lU1NTSy0+IiKikjIyAox0aA0RBt8XojuDruK2bdvQokULvP3223BxcUHTpk2xatWqYo8JCwuDra2tcvH09CyjaImIiDTH7h71DDpJuX37NlasWIHatWtj7969GD16NMaNG4effvqpyGNCQkKQkpKiXO7du1eGERMREZG+GHR3T15eHlq0aIG5c+cCAJo2bYq///4b3377LYKCggo9Ri6XQy6Xl2WYREREWuNkbuoZdEuKm5sbGjRooLKufv36uHv3rkQRERER6YdMpmN3TyXIUgw6SWnTpg1u3Lihsi46OhpeXl4SRURERERlxaC7eyZOnIjWrVtj7ty56N+/P06fPo2VK1di5cqVUodGRESkE07mpp5Bt6S8+uqr+OOP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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "im = ax.imshow(scale_n_task_results.transpose(), cmap=cmap, aspect='auto', vmin=-1, vmax=1)\n",
    "\n",
    "# Add a color bar for reference\n",
    "cbar = plt.colorbar(im, ax=ax, ticks=[-1, 0, 1])\n",
    "cbar.set_ticklabels(['Fail', 'Pass', 'Excel'])\n",
    "\n",
    "# Add labels and title for clarity\n",
    "plt.xlabel('Context Length')\n",
    "plt.xticks(ticks=range(8),labels=[\"4k\", \"8k\", \"12k\", \"15k\", \"18k\", \"21k\", \"23k\", \"25k\"])\n",
    "\n",
    "interval = 100 / 16\n",
    "points = np.arange(0, 100, interval)\n",
    "odd_points = points[1::2] \n",
    "\n",
    "plt.ylabel('Position in Task Haystack (%)')\n",
    "plt.yticks(ticks=range(8), labels=[round(k) for k in odd_points])\n",
    "plt.suptitle('Task Haystack (Scale-Task)')\n",
    "plt.title(\"Model=Mistral 7b, N_shot=2, N_task=(8,16,18,32,40,48,56,64)\", fontsize=10)\n",
    "\n",
    "ax.set_xticks([x-0.5 for x in range(8)], minor=True)\n",
    "ax.set_yticks([y-0.5 for y in range(len(scale_n_task_results))], minor=True)\n",
    "\n",
    "ax.grid(True, which='minor', color='grey', linestyle='-', linewidth=1)\n",
    "\n",
    "# Show the plot\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 143,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_35920/1580894248.py:2: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  sign = lambda x: (1, -1)[x<0]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_35920/1580894248.py:2: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  sign = lambda x: (1, -1)[x<0]\n",
      "/tmp/ipykernel_35920/1580894248.py:2: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  sign = lambda x: (1, -1)[x<0]\n",
      "/tmp/ipykernel_35920/1580894248.py:2: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  sign = lambda x: (1, -1)[x<0]\n",
      "/tmp/ipykernel_35920/1580894248.py:2: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  sign = lambda x: (1, -1)[x<0]\n",
      "/tmp/ipykernel_35920/1580894248.py:2: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  sign = lambda x: (1, -1)[x<0]\n",
      "/tmp/ipykernel_35920/1580894248.py:2: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  sign = lambda x: (1, -1)[x<0]\n",
      "/tmp/ipykernel_35920/1580894248.py:2: DeprecationWarning: In future, it will be an error for 'np.bool_' scalars to be interpreted as an index\n",
      "  sign = lambda x: (1, -1)[x<0]\n"
     ]
    }
   ],
   "source": [
    "n_task = 16\n",
    "all_avgs = []\n",
    "for n_shot in [1,2,3,4,5,6,7,8]:\n",
    "    _recall_dir = os.path.join(recall_dir, f\"ntask{n_task}_nshot{n_shot}\")\n",
    "\n",
    "    avg = get_one_matrix(baseline_dir, _recall_dir, n_task=n_task, n_shot=n_shot)\n",
    "    all_avgs.append(avg)\n",
    "\n",
    "all_avgs = np.array(all_avgs)\n",
    "scale_n_shot_results = all_avgs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 144,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "im = ax.imshow(scale_n_shot_results.transpose(), cmap=cmap, aspect='auto', vmin=-1, vmax=1)\n",
    "\n",
    "# Add a color bar for reference\n",
    "cbar = plt.colorbar(im, ax=ax, ticks=[-1, 0, 1])\n",
    "cbar.set_ticklabels(['Fail', 'Pass', 'Excel'])\n",
    "\n",
    "# Add labels and title for clarity\n",
    "plt.xlabel('Context Length')\n",
    "plt.xticks(ticks=range(8),labels=[\"{}k\".format((item+1)*4) for item in range(8)])\n",
    "\n",
    "interval = 100 / 16\n",
    "points = np.arange(0, 100, interval)\n",
    "odd_points = points[1::2] \n",
    "\n",
    "plt.ylabel('Position in Task Haystack (%)')\n",
    "plt.yticks(ticks=range(8), labels=[round(k) for k in odd_points])\n",
    "plt.suptitle('Task Haystack (Scale-Shot)')\n",
    "plt.title(\"Model=Mistral 7b, N_task=16, N_shot=(1,2,3,4,5,6,7,8)\", fontsize=10)\n",
    "\n",
    "ax.set_xticks([x-0.5 for x in range(8)], minor=True)\n",
    "ax.set_yticks([y-0.5 for y in range(len(scale_n_task_results))], minor=True)\n",
    "ax.grid(True, which='minor', color='grey', linestyle='-', linewidth=1)\n",
    "\n",
    "\n",
    "# Show the plot\n",
    "plt.show()"
   ]
  }
 ],
 "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
}
