{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "3eed7ee8-71a1-4a57-b34c-d47af54ae77c",
   "metadata": {},
   "source": [
    "## Computing fidelity metrics"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0574ef6f-5a04-405f-81ff-9c2e4700ac91",
   "metadata": {},
   "source": [
    "Benchmark the metrics with the metrics proposed in ERASER."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "e0e1552d-5e19-4168-828d-6b125557cbe2",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f3094ccd-da61-468f-b24c-10be96a7fdd7",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "os.chdir(\"..\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "f0b756bf-7086-4260-9637-621737b06691",
   "metadata": {},
   "outputs": [],
   "source": [
    "from slalom_explanations.transformer_models import DistilBert, GPT2, Bert, Trainer\n",
    "from datasets import load_dataset, Dataset\n",
    "from transformers import AutoTokenizer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fc0a168f-6566-46f2-942f-6863ab411fa7",
   "metadata": {},
   "outputs": [],
   "source": [
    "##Print Metrics for YELP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "31250c07-92b4-4789-b992-cb788c2fd21e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "gpt2 & \\wstd{0.747}{0.024} & \\wstd{0.753}{0.024} & \\wstd{0.726}{0.021} & \\wstd{0.727}{0.021} & \\wstd{0.444}{0.028} & \\wstd{0.849}{0.015} & \\wstd{0.292}{0.026} & \\wstd{0.290}{0.026} & \\wstd{0.740}{0.025}\\\\\n",
      "bert & \\wstd{0.657}{0.038} & \\wstd{0.667}{0.038} & \\wstd{0.865}{0.012} & \\wstd{0.863}{0.013} & \\wstd{0.797}{0.022} & \\wstd{0.859}{0.013} & \\wstd{0.249}{0.028} & \\wstd{0.281}{0.029} & \\wstd{0.855}{0.017}\\\\\n",
      "distilbert & \\wstd{0.645}{0.033} & \\wstd{0.642}{0.033} & \\wstd{0.813}{0.017} & \\wstd{0.813}{0.018} & \\wstd{0.746}{0.025} & \\wstd{0.854}{0.013} & \\wstd{0.201}{0.026} & \\wstd{0.243}{0.028} & \\wstd{0.768}{0.024}\\\\\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_2292435/2289012677.py:13: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  res = torch.load(filename)\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import torch \n",
    "\n",
    "key = \"deletion\"\n",
    "model_names = [\"gpt2\", \"bert\", \"distilbert\"]\n",
    "dataset = \"yelp\"\n",
    "layers=6\n",
    "methods_use = [0,2,3,5,6,7,8,9,10] #[0,2,3,4,5,6,7] #[3,5,6,7,8,9,10] # # #[1,3,4,5,6,7]\n",
    "res_list, res_std_list = [], []\n",
    "for k in model_names:\n",
    "    filename = f\"metrics/100_Transformer_{dataset}_{k}_{layers}_pretrained_r7.pt\"\n",
    "    #print(filename)\n",
    "    res = torch.load(filename)\n",
    "    res_val = res[key]\n",
    "    #print(res_val.shape)\n",
    "    res_val_m = res_val.mean(axis=0)\n",
    "    res_val_std =  res_val.std(axis=0)/np.sqrt(len(res_val))\n",
    "    res_str = \" & \".join([r\"\\wstd{\" + f\"{1-res_val_m[method]:.3f}\" +\"}{\"+ f\"{res_val_std[method]:.3f}\" +\"}\" for method in methods_use])\n",
    "    print(k + \" & \" + res_str +r\"\\\\\")\n",
    "    res_list.append(res_val_m)\n",
    "    res_std_list.append(res_val_std)\n",
    "res_list = np.stack(res_list)\n",
    "res_std_list = np.stack(res_std_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "3346dd17-d0e3-4f0d-96af-8320fa8fdf98",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\wstd{0.683}{0.032} & \\wstd{0.687}{0.032} & \\wstd{0.801}{0.017} & \\wstd{0.801}{0.017} & \\wstd{0.663}{0.025} & \\wstd{0.854}{0.014} & \\wstd{0.247}{0.027} & \\wstd{0.271}{0.028} & \\wstd{0.788}{0.022}\n"
     ]
    }
   ],
   "source": [
    "res_val_m = res_list.mean(axis=0)\n",
    "res_val_std = res_std_list.mean(axis=0)\n",
    "print(\" & \".join([r\"\\wstd{\" + f\"{1-res_val_m[method]:.3f}\" +\"}{\"+ f\"{res_val_std[method]:.3f}\" +\"}\" for method in methods_use]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "0411465f-4fcc-43e3-add9-c7d93120ef7f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.0108)"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res_val_std"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "438a6212-7ec5-47a0-a4dc-f95b2e2818c0",
   "metadata": {},
   "source": [
    "## Analyze Multiremoval data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 245,
   "id": "81a43e78-4748-4b6e-9107-4620499fceb8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(100, 10, 10)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_3020536/3335391140.py:6: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  res = torch.load(f\"metrics/100_Transformer_{dset}_{model}_{layers}_r7.pt\")\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import torch \n",
    "model =\"distilbert\"\n",
    "dset = \"imdb\"\n",
    "layers = 2\n",
    "res = torch.load(f\"metrics/100_Transformer_{dset}_{model}_{layers}_r7.pt\")\n",
    "arr_fix = np.array(res[\"multiremoval_mse\"])\n",
    "print(arr_fix.shape)\n",
    "#if model==\"bert\":\n",
    "#res_append = torch.load(f\"metrics/lrp_Transformer_{dset}_{model}_{layers}_pretrained_r0.pt\")\n",
    "#arr_fix = np.concatenate((arr_fix, np.array(res_append[\"multiremoval_mse\"])), axis=2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 246,
   "id": "3c1d2408-9d5d-4d44-9ba6-bd1efe27447f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(100, 10, 10)"
      ]
     },
     "execution_count": 246,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "arr_fix.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 247,
   "id": "f920edd1-1944-4fe2-bde4-093dfc01b7fe",
   "metadata": {},
   "outputs": [],
   "source": [
    "res_dicts_mean = arr_fix.mean(axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 248,
   "id": "6b73af17-4251-454d-91f5-705eae4afc7d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1.08688894e-01, 3.21568657e+03, 1.76560125e-01, 4.37387785e+01,\n",
       "       1.31439845e-01, 1.83947119e-01, 4.40696683e+01, 5.89227457e+00,\n",
       "       1.44337757e-01, 1.89763825e-01])"
      ]
     },
     "execution_count": 248,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res_dicts_mean[9,:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 249,
   "id": "d7a77862-2156-42dc-bdf0-ef0339a8df09",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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BeuvnQ2L7ZrOlqViJ8ydrQtWeCcjJch79+7N6XmzqbdwNRQVXV1URK6IJPuMpVwJEokSiy/399PU18d7wSAeVeWRigoeq6xEAPd++OG0x11ut7Pa4Sgof+1iuaZXy1KxE+bO1gUrvB6Ph4GB0SFeAwMDoxbVsuGLL75g27ZtANTU1LBx40a2bt1KVVUVN910E6+8/Are8umPE43GeOaZZ4BE+w9N09ILf/fffz8nTpzg8uXLlJSUcNddd6UzXK6//nrcbjfvvPMOkPARnT59mq6uLoqKinjggQc4evQopmnS1tZGRUUFb775JgCNjY2cOXOGjo4O7HY7jzzySPq99fX11NbW8vrrrwNw22230dHRgc/nQ1EUHnvsMZ577jlisRirV6+mvr6e1157DYBbbrmFnp4ezpw5AyTqhr744ouEw2FWrFjBxo0bOXbsGAA333wz/YEApz79lBFJ4o577+Xnv/wlkWCQvqoq3vd4aAkEMIEvOxz8h6Iiynw+tK4u1t97L//41lswRdfcFEYkQuu779LX10dZWRm33XYbL7zwAgCbN2/G4XBw/PhxAO677z7a2tq4dOkSxcXF3HPPPelwwo0bN1JaWspbb70FJFI8P/74Yzo7O3E6nTz88MPp67hhwwaqqqp44403ALjjjjtob2/n/Pnz2Gw2Hn30UZ599lkMw6Curo5Vq1bx85//HEh0m+3q6qK9vR1Zlnn88cd5/vnniUajrFq1ig0bNjA8PMwzzzzDV77yFfr6+vjss88AePzxx3nppZcIhULU1tayadMmXnnlFQC+9KUvEQwG+eijj4DEGsixY8cYGhpi2bJlbN++nR//+McAbNu2jXg8zgcffADAww8/zOuvv87AwADl5eXccsst/OAHPwDgxhtvRJbl9CL2Aw88wLvvvktPTw+lpaXceeedPP/88wBs2rQJl8vFu+++C8C9997L+++/z8WLF3G73dx33308++yzAFx77bVs3rw5/Znu3LmTTz/9lAsXLuBwOPj617/O97//fYQQrF+/nurqan75y18CcPvtt3Pu3DnOnj2LqqrpsFBd11m7di1r1qzhZz/7GQBf/epXuXTpEp9//jmSJPGNb3yDF154gUgkwsqVK7n22mtpaWkB4Nd+7dcYGBjg008/BeCxxx7jJz/5CcFgkOXLl7NlyxZ++tOfAnDTTTcxMjKS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",
      "text/plain": [
       "<Figure size 370x290 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "plt.style.use('figures/matplot.mplstyle')\n",
    "from matplotlib import pyplot\n",
    "\n",
    "res_dicts_mean = arr_fix.mean(axis=0)\n",
    "res_dicts_std = arr_fix.std(axis=0)/10\n",
    "#labels=[\"SLALOM\", \"SHAP\", \"LIME\", \"Constant\", \"SLALOM-i-fix\"]\n",
    "labels = [\"SLALOM-faith\", \"lin\", \"SLALOM-eff\", \"lin2\", \"LIME\", \"SHAP\", \"Grad\", \"IG\", \"LRP\", \"Constant\"]\n",
    "colors=[\"tab:blue\", \"tab:orange\", \"tab:red\", \"tab:purple\", \"tab:brown\", \"tab:green\", \"tab:olive\", \"c\", \"m\", \"k\", \"tab:orange\"]\n",
    "handles =[]\n",
    "ax = plt.gca()\n",
    "for i in range(res_dicts_mean.shape[1]):\n",
    "    if labels[i] in [\"SLALOM-faith\", \"SLALOM-eff\", \"LIME\", \"SHAP\", \"Grad\", \"IG\", \"LRP\", \"Constant\"]:\n",
    "        color_use = colors[i]\n",
    "        if labels[i] != \"Constant\":\n",
    "            plt.fill_between(1+np.arange(res_dicts_mean.shape[0]), res_dicts_mean[:,i]+res_dicts_std[:,i], res_dicts_mean[:,i]-res_dicts_std[:,i], color=color_use, alpha = 0.1)\n",
    "            handles.append(ax.plot(1+np.arange(res_dicts_mean.shape[0]), res_dicts_mean[:,i], \"--\" if \"fix\" in labels[i] else \"-\", label = labels[i], color=color_use, marker=\"s\")[0])\n",
    "        else:\n",
    "            pass\n",
    "            #handles.append(ax.plot(1+np.arange(res_dicts_mean.shape[0]), res_dicts_mean[:,i], \"--\", label = labels[i], color=color_use)[0])  \n",
    "y_lim_low = 0.001\n",
    "diff = (1.0-(res_dicts_mean[9,0]/res_dicts_mean[9,8]))*100\n",
    "plt.annotate(f\"-{int(diff)}\\%\", xy = (10, res_dicts_mean[9,0]), xytext=(9, 2*y_lim_low), arrowprops=dict(facecolor='black', width=1.5, headwidth=5))\n",
    "pyplot.yscale('log')\n",
    "#plt.ylim([0.1, 1])\n",
    "plt.ylim([y_lim_low, 10])\n",
    "#plt.ylim([0.00005, 0.01])\n",
    "plt.xlabel(\"\\# token removals\")\n",
    "plt.ylabel(\"prediction MSE\")\n",
    "#plt.legend(loc = \"center right\",ncol=2) # handles=[handles[0], handles[4], handles[1], handles[2], handles[3]]\n",
    "plt.gcf().set_size_inches(3.7, 2.9)\n",
    "plt.tight_layout()\n",
    "plt.gcf().savefig(f\"figures/multiremoval_{model}.pdf\")\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "transformer",
   "language": "python",
   "name": "transformer"
  },
  "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.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
