{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import trainer.glue_base as glue_base\n",
    "import models.sparse_token as sparse\n",
    "import pickle, importlib\n",
    "import torch\n",
    "from matplotlib import pyplot as plt\n",
    "importlib.reload(glue_base)\n",
    "importlib.reload(sparse)\n",
    "sparse.set_update_input_mask_accumulate_indices(True)\n",
    "\n",
    "Glue = glue_base.GlueAttentionApproxTrainer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trainer: mrpc\n",
      "Trainer: Checkpoint path saves/glue-mrpc-16.pth\n"
     ]
    }
   ],
   "source": [
    "trainer = Glue('mrpc', 16, batch_size=1, wiki_train=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_iter = iter(trainer.test_dataloader)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "batch = next(data_iter)\n",
    "batch = {k: v.to(trainer.device) for k, v in batch.items()}\n",
    "labels = batch['labels']\n",
    "del batch['labels']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "importlib.reload(glue_base)\n",
    "importlib.reload(sparse)\n",
    "sparse.set_update_input_mask_accumulate_indices(True)\n",
    "def create_model(trainer, ks):\n",
    "    wrapped_bert = sparse.ApproxSparseBertModel(\n",
    "        trainer.model_bert, \n",
    "        approx_bert=trainer.approx_bert, \n",
    "        ks=ks)\n",
    "    wrapped_bert.use_forward_sparse = False\n",
    "    sparse_cls_bert = glue_base.berts.BertForSequenceClassification(trainer.model_bert.config)\n",
    "    sparse_cls_bert.load_state_dict(trainer.model.state_dict())\n",
    "    sparse_cls_bert.bert = wrapped_bert\n",
    "    sparse_cls_bert.to(trainer.device).eval()\n",
    "\n",
    "    return sparse_cls_bert\n",
    "\n",
    "model = create_model(trainer, 0.1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_grid(tensor): plt.imshow(tensor.cpu().detach().numpy())\n",
    "plt.rcParams[\"figure.figsize\"] = (14,4)\n",
    "TOKEN_LEN = torch.sum(batch['attention_mask'][0]).item() + 5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAuIAAADtCAYAAAD6KhDDAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAAdUklEQVR4nO3dfZBl9V3n8fdnep54CMPDkIQnhcgkimuM60iieTSYZAgRUiVRklXRogq3Sty46irZrU2UdbeSLStoVdjS2YBidCUpTHSSIIRA1KwVkYFgkoEAE4IwSCQDhMcwM9393T/uIWl7m7nndN++t8/M+1V1au4993t/5wun753v/Pr3kKpCkiRJ0nitmnQCkiRJ0sHIQlySJEmaAAtxSZIkaQIsxCVJkqQJsBCXJEmSJmD1pBOQJEmSFutNP3pYPfzITKvYW76w57qq2rLMKbVmIS5JkqTe2v3IDDddd2Kr2DXHfWXjMqfTiYW4JEmSeqyYqdlJJ7EoFuKSJEnqrQJm6ecGlRbikiRJ6rVZ7BGXJEmSxqoo9jk0RZIkSRqvAmYcmiJJkiSNn2PEJUmSpDErYKYsxCVJkqSx6+cIcbe4lyRJUo8VxUzLY5gkW5LcmWRnkosXeP01SW5NMp3k3DnnX5bkc0l2JPlCkp9qk7s94pIkSeqtKtg3gpEpSaaAy4A3ALuAm5Nsq6rb54TdB/wc8Gvz3v408LNVdXeS44FbklxXVd/Y3zUtxCVJktRjYYaMoqHTgZ1VdQ9AkquAc4BvFeJVdW/z2r8aDVNVd815/M9JHgKOBb6xvwtaiEuSJKm3Cpht3yO+Mcn2Oc+3VtXW5vEJwP1zXtsFvLxrPklOB9YCXxkWayEuSZKkXuvQI767qjYvVx5JjgM+BJxfNXyXIQtxSZIk9dZgQ5+RDE15ADhpzvMTm3OtJDkC+CTwX6rq79u8x0JckiRJvVXAvhrJQoA3A5uSnMKgAD8PeEebNyZZC3wM+OOqurrtBV2+UJIkSb1VhBlWtTr2207VNHARcB1wB/CRqtqR5JIkZwMk+aEku4C3AX+QZEfz9p8EXgP8XJLbmuNlw3JP9XQnIkmSJOl7Xrqu/ujjx7eKfcXJ996ynGPEu3JoiiRJknprhGPEx85CXJIkST0WZkYzRnzsLMQlSZLUWwXM9nTao4W4JEmSeqsq7K2pSaexKBbikiRJ6rVZx4hLkiRJ4zWYrOnQFEmSJGnMnKwpSZIkjZ2TNSVJkqQJmSnHiEuSJEljVYR91c+Stp9ZS5IkSThZU5IkSZqIIg5NkSRJkibByZqSJEnSmFXh8oWSJEnSuA0ma7rFvSRJkjR2TtaUJEmSxqwIs07WlCRJksbPHnFJkiRpzAqYdbKmJEmSNG5hBoemSJIkSWNV4KopbRx21No68vhDW8c/cXs/f80gtTW7aW3r2FV3713GTDp68Zrla/uufZ3Cp17S/mts5s7prtksnxX0/1BaDqs6fDYBZmbb/52fjt+H6fh5W5XZ1rEzd850aruvnuDR3VV17KTzWEhVHJrSxpHHH8ovfPjVreM/+9L1y5iNNHlPfeBFrWMP23LPMmbS0e+fuHxtn7GrU/jzLt/YOvaJV+/ums2ymf39kzrFr6LaB3f8fygth3X/+4Wd4h/f0/7v/HVvvLdT21Nbj+8Uf/iaPa1jH3vVw53a7qtP19X/NOkc9qevG/osKeskW5LcmWRnkotHlZQkSZLURgGzpNWx0iy6RzzJFHAZ8AZgF3Bzkm1VdfuokpMkSZL2Lwdlj/jpwM6quqeq9gJXAeeMJi1JkiRpuMHyhWl1DDNstEeS1yS5Ncl0knPnvXZ+krub4/w2uS9ljPgJwP1znu8CXr5AwhcCFwJsOO6QJVxOkiRJ+teKjGTVlJajPe4Dfg74tXnvPRp4D7CZwb8Nbmne++j+rrns/fhVtbWqNlfV5sOOar9ChCRJktTGLKtaHUMMHe1RVfdW1ReA+UvrvAm4vqoeaYrv64Etwy64lB7xB4C50/5PbM5JkiRJY1EFMy2GnTQ2Jtk+5/nWqtraPG412uM5LPTeE4a9aSmF+M3ApiSnMCjAzwPesYT2JEmSpM7ajP9u7K6qzcuZSxeLHppSVdPARcB1wB3AR6pqx6gSkyRJkoYpBhv6tDmGWMpoj0W9d0kb+lTVNcA1S2lDkiRJWqzBFvcjmfa4lNEe1wH/I8lRzfM3Au8a9qZ+LrooSZIkAYyoR/y5RnskuSTJ2QBJfijJLuBtwB8k2dG89xHgvzEo5m8GLmnO7dd4t7ifepqfOOLW1vGf5UeWMRtp8lbUtvUdfHN6zbK1PXX9d3aKf+LV7Xddnv70d3Rqe/WP3dcpvotVZ9w/PGiuG05cnkSkDvZ2+Xy+ttuO6GtuOGl4UOOpa1/Uqe3Dq/2W9QCP713fKV6TN6pdMxca7VFV757z+GYGw04Weu8VwBVdrjfWQlySJEkapY6rpqwoFuKSJEnqtRYTMVckC3FJkiT11mDVFHvEJUmSpLEqYNoecUmSJGn8HJoiSZIkjVs5NEWSJEkau2J0yxeOm4W4JEmSes0ecUmSJGnMCgtxSZIkaeyKMD3rZM2hCthHP/9HSfq2Q9701U7xez51cuvYValObXfZ6rqmOzXN4d3Cl9WGdd9sHfvYMuahg9vaN7Tftv6b153Sqe3Zfe17NFevmu3U9p6ZbuXOCw59onXso51a1nJxjLgkSZI0btXfoSmL7p5OclKSzyS5PcmOJO8cZWKSJEnSMM+OEW9zrDRL6RGfBn61qm5N8jzgliTXV9XtI8pNkiRJGmolFtltLLoQr6oHgQebx08kuQM4AbAQlyRJ0lgUYeZgnqyZ5GTgB4CbRtGeJEmS1NZBO1kzyeHAnwO/XFWPL/D6hcCFAMedMLXUy0mSJEnfUgfjZE2AJGsYFOF/WlUfXSimqrZW1eaq2nzk0f38tYEkSZJWrqq0OlaaRfeIJwlwOXBHVb1/dClJkiRJba3MFVHaWEoX9SuBnwFen+S25njziPKSJEmSWjnoesSr6v9CT0fGS5Ik6YBQBTOz/SxJ3VlTkiRJvXbQrprSxROz67nxqe8e5yUlLYM9nzq5W/xM+xWTDl0126ntmQ6/ajzizK90ansleekRD7SO/SzrlzETHcyeuvZFrWOrurXdZYzvYW+8t1PbXfIGeNGhu1vH3rK0dS80AgUrcthJG/aIS5Ikqcf6O1nTQlySJEm91vU3MCuFv0+RJElSr41q1ZQkW5LcmWRnkosXeH1dkg83r9/U7C5PkjVJrkzyxSR3JHlXm7wtxCVJktRbg1VTVrU69ifJFHAZcCZwGvD2JKfNC7sAeLSqTgUuBd7XnH8bsK6qvg/4QeAXni3S98dCXJIkSb1W1e4Y4nRgZ1XdU1V7gauAc+bFnANc2Ty+Gjij2eSygMOSrAYOAfYCjw+7oIW4JEmSeq3D0JSNSbbPOS6c08wJwP1znu9qzrFQTFVNA48BxzAoyp8CHgTuA36nqh4ZlreTNSVJktRbRaddM3dX1eZlSON0YAY4HjgK+GyST1fVPft7kz3ikiRJ6rVqeQzxAHDSnOcnNucWjGmGoWwAHgbeAVxbVfuq6iHg74ChBb+FuCRJkvqroGbT6hjiZmBTklOSrAXOA7bNi9kGnN88Phe4saqKwXCU1wMkOQx4BfDlYRd0aIokSZJ6bRQ7a1bVdJKLgOuAKeCKqtqR5BJge1VtAy4HPpRkJ/AIg2IdBqut/GGSHUCAP6yqLwy75lgL8Uf3HspHd/1A6/hD+OoyZiNpsdZ13F766U9uah27Z7rb11KXL99HO+QBcNRZd3eKX04/ueGW1rF/+Ymf79T20W+5q2s6Okh12TNl2FJx8214885uyXQw07FI27JhaP30Lbfwso7ZaDmMakOfqroGuGbeuXfPefwMg6UK57/vyYXOD2OPuCRJknqrGE2P+CRYiEuSJKm/CuhpIb7kyZpJppJ8PsknRpGQJEmS1MWINvQZu1H0iL8TuAM4YgRtSZIkSR20WhFlRVpSj3iSE4GzgA+OJh1JkiSpoxEtJD5uS+0R/13g14HnPVdAs3XohQDrnm+nuSRJkkao+jtZc9E94kneAjxUVftdU6uqtlbV5qravHrDIYu9nCRJkrSwg7BH/JXA2UneDKwHjkjyJ1X106NJTZIkSWrjIOsRr6p3VdWJVXUyg12FbrQIlyRJ0tjNtjxWGNcRlyRJUn/1eB3xkRTiVfXXwF+Poi1JkiSpi5W4RngbY+0RL8LemanW8cs5tfNrf/E9rWNf+NY7ljET6cDXZTb7nuluX0tJ+2/fo866u1PbK8kpq9e3jp2eWfJebdKCZmbb/2zNLmMP5SOfeHGn+KPPvKtT/Mn3PdkpXiuAhbgkSZI0AQfz0BRJkiRpUjr8cnRFsRCXJElSf1Wgp1vcW4hLkiSp3+wRlyRJkibAQlySJEmaAAtxSZIkacwO9g19JEmSpElx1RRJkiRpEizEJUmSpPGzR7yFqbv3sOHNO1vHd9mGviu3rT9wdP058d6P39rV08vW9uFb7lm2tpdT15/bWW5uHfv8c77cNR2plS7b1k+tmu3U9u6Pt9+2fuNbum1Z39X69HO88UHNMeKSJEnSmBUOTZEkSZImoqeF+KqlvDnJkUmuTvLlJHck+eFRJSZJkiS1kdl2x9B2ki1J7kyyM8nFC7y+LsmHm9dvSnLynNdemuRzSXYk+WKS9cOut6RCHPg94Nqq+m7g+wEH30qSJGm8quWxH0mmgMuAM4HTgLcnOW1e2AXAo1V1KnAp8L7mvauBPwH+fVV9L/A6YN+wtBddiCfZALwGuBygqvZW1TcW254kSZLUVar9McTpwM6quqeq9gJXAefMizkHuLJ5fDVwRpIAbwS+UFX/CFBVD1fVzLALLqVH/BTg68AfJvl8kg8mOWx+UJILk2xPsn0fe5ZwOUmSJGkBlXYHbHy2Lm2OC+e0cgJw/5znu5pzLBRTVdPAY8AxwIuBSnJdkluT/HqbtJcyWXM18G+BX6qqm5L8HnAx8F/nBlXVVmArwBE5uqdD6SVJkrRita8wd1fV5mXIYDXwKuCHgKeBG5LcUlU37O9NS+kR3wXsqqqbmudXMyjMJUmSpLEZ0dCUB4CT5jw/sTm3YEwzLnwD8DCDuvhvq2p3VT0NXEOLunjRhXhVfQ24P8lLmlNnALcvtj1JkiSpsxrZqik3A5uSnJJkLXAesG1ezDbg/ObxucCNVVXAdcD3JTm0KdBfS4u6eKnriP8S8KdNsvcAP7/E9iRJkqRuRjD4uaqmk1zEoKieAq6oqh1JLgG2V9U2BouUfCjJTuARBsU6VfVokvczKOYLuKaqPjnsmksqxKvqNmA5xtlIkiRJ7YxoFmJVXcNgWMncc++e8/gZ4G3P8d4/YbCEYWsremfN1VNDV335lhrMhG3t69teMjyocezZd3ZqW+P1wre6fP1Kt29mqnXs9Ey3EXPPfPzFrWM3/vhdndpeTl1/bh+5z1WnNHlTq1rsiNKYme32We7y+Xz0k5s6tX3UWXd3ij88azrFa/JajP9ekZa6oY8kSZKkRVjRPeKSJEnSUD3tEbcQlyRJUn9VqxVRViQLcUmSJPWbPeKSJEnSeIX+Tta0EJckSVK/WYhLkiRJY9Zu+/oVyUJckiRJ/eZkTUmSJGn87BGXJEmSJsFCXJIkSRqzwkJ8OaxfM906Nh3b3jsz1fEdkhbrqLPubh27++Mv7tT2xh+/q3Xs17e9pFPbx559Z6f45XTc6sMnnYJEVfu/bWdmu/3N/Mgn2n/2jz6r/eceun+vbN97W6d4TZ5DUyRJkqRJ6Gkhvmopb07yH5PsSPKlJH+WZP2oEpMkSZLayGy7Y6VZdCGe5ATgPwCbq+rfAFPAeaNKTJIkSRqqOhwrzFKHpqwGDkmyDzgU+OelpyRJkiS1E7rPFVwpFt0jXlUPAL8D3Ac8CDxWVZ+aH5fkwiTbk2zfx57FZypJkiQtpKc94ksZmnIUcA5wCnA8cFiSn54fV1Vbq2pzVW1ew7rFZypJkiQtINXuWGmWMlnzx4CvVtXXq2of8FHgR0aTliRJktRST3vElzJG/D7gFUkOBb4JnAFsH0lWkiRJUhu1MldEaWMpY8RvAq4GbgW+2LS1dUR5SZIkSe0chD3iVNV7gPeMKBdJkiSps5U4/ruNse6sObtpLU994EWt4zese6Z17KqOd+DxPe49JK1EXbasB3j8r76rdeyxZy7flvVf+4vv6RTf9Tvrrn1/1yleWg4b3ryzdWyXLesBjn5Lt89+FxsPfbpT/Oee2rRMmWjZWIhLkiRJ49fXHvElbXEvSZIkTVQBsy2PIZJsSXJnkp1JLl7g9XVJPty8flOSk+e9/h1Jnkzya21StxCXJElSb4XRrCOeZAq4DDgTOA14e5LT5oVdADxaVacClwLvm/f6+4G/apu7hbgkSZL6bTSrppwO7Kyqe6pqL3AVg80r5zoHuLJ5fDVwRpIAJHkr8FVgR9u0LcQlSZLUa6lqdQAbk2yfc1w4p5kTgPvnPN/VnGOhmKqaBh4DjklyOPAbwG91ydvJmpIkSeqvbmuE766qzcuQxW8Cl1bVk00HeSsW4pIkSeq1Ea2a8gBw0pznJzbnForZlWQ1sAF4GHg5cG6S/wkcCcwmeaaqPrC/C1qIS5IkqddGtMX9zcCmJKcwKLjPA94xL2YbcD7wOeBc4MaqKuDV38ol+U3gyWFFOFiIS5Ikqe9G0CNeVdNJLgKuA6aAK6pqR5JLgO1VtQ24HPhQkp3AIwyK9UWzEJckSVJ/tViasHVTVdcA18w79+45j58B3jakjd9sez0LcUmSJPVbT3fWHGshnsC61dOt449Y+0zr2Mf3ru+Uy+Fr97SOnenUsqRxOuLMr7SOffLaF3Vq+/At97SOPWTtvk5tr17VbUDjr3z13A7RD3ZqWzrQPbVvbaf4c4/4fOvYG3lV13Q0Ys9u6NNH9ohLkiSp1zLbz0p86IY+Sa5I8lCSL805d3SS65Pc3fx51PKmKUmSJC2g7a6aK7BWb7Oz5h8BW+aduxi4oao2ATc0zyVJkqSxy2y7Y6UZWohX1d8yWJ5lrnOAK5vHVwJvHW1akiRJUks97RFf7BjxF1TVs7OBvga84LkCk1wIXAiw7vnPW+TlJEmSpIX1dbJmm6Ep+9XsJvSc//lVtbWqNlfV5jVHHrrUy0mSJEnfVkBVu2OFWWwh/i9JjgNo/nxodClJkiRJ7R2wY8Sfwzbg/Obx+cBfjiYdSZIkqb1n1xFvc6w0bZYv/DPgc8BLkuxKcgHwXuANSe4Gfqx5LkmSJI1X22EpK3BoytDJmlX19ud46YwR5yJJkiR1thJ7u9sY686aU5nlsDV7W8c/Pd1+S9pVy3gH3OJeWrnW/PVxrWOPydOd2p7+zPGtYzfmqU5t73tdt23oV/3NCzvFS5N27GFPdopfzr9rD9tyT6f4X/2bn+gQ/S/dktHysBCXJEmSxs8ecUmSJGncCpjpZyVuIS5JkqRes0dckiRJmoQVuCJKGxbikiRJ6jV7xCVJkqRxK1w1RZIkSRq3AHGypiRJkjR+cYy4JEmSNGYOTZEkSZImoVw1RZIkSZoEV01p4bE7v777k6/5wD8t8NJGYPc4c9Gy8V4eWFb+/XztpBMYk9eMpJWVfz/Vxcq+n6+bdAJLMJrPWxcr+14OfOekE9gve8SHq6pjFzqfZHtVbR5nLloe3ssDi/fzwOL9PLB4Pw8c3sslqtGtmpJkC/B7wBTwwap677zX1wF/DPwg8DDwU1V1b5I3AO8F1gJ7gf9UVTcOu96qkWQtSZIkTUq1PPYjyRRwGXAmcBrw9iSnzQu7AHi0qk4FLgXe15zfDfx4VX0fcD7woTZpW4hLkiSp11LV6hjidGBnVd1TVXuBq4Bz5sWcA1zZPL4aOCNJqurzVfXPzfkdwCFN7/l+rZRCfOukE9DIeC8PLN7PA4v388Di/TxweC+XqqrdsX8nAPfPeb6rObdgTFVNA48Bx8yL+Qng1qraM+yCK2LVlKryB/AA4b08sHg/DyzezwOL9/PA4b1cogJmW0dvTLJ9zvOto/z/n+R7GQxXeWOb+BVRiEuSJEmLEVoNO3nW7v1MjH0AOGnO8xObcwvF7EqyGtjAYNImSU4EPgb8bFV9pU0yEx2akmRLkjuT7Exy8SRzUXdJrkjyUJIvzTl3dJLrk9zd/HnUJHNUe0lOSvKZJLcn2ZHknc1572nPJFmf5B+S/GNzL3+rOX9Kkpua79wPJ1k76VzVXpKpJJ9P8onmufezp5Lcm+SLSW57tnfW79olmp1td+zfzcCm5rO1FjgP2DYvZhuDyZgA5wI3VlUlORL4JHBxVf1d27QnVoi3nJmqle2PgC3zzl0M3FBVm4Abmufqh2ngV6vqNOAVwC82n0nvaf/sAV5fVd8PvAzYkuQVDH5demkz2/9RBrP/1R/vBO6Y89z72W8/WlUvm9M763ftYj07NKXNsb9mBmO+LwKuY/BZ+0hV7UhySZKzm7DLgWOS7AR+hW/fp4uAU4F3N//Aui3J84elPske8TYzU7WCVdXfAo/MOz13NvGVwFvHmZMWr6oerKpbm8dPMPgSOgHvae/UwJPN0zXNUcDrGczyB+9lrzS/8j4L+GDzPHg/DzR+1y7BiFZNoaquqaoXV9V3VdV/b869u6q2NY+fqaq3VdWpVXV6Vd3TnP/tqjqs+cfVs8dDw643yUK8zcxU9c8LqurB5vHXgBdMMhktTpKTgR8AbsJ72kvNMIbbgIeA64GvAN9oenzA79y++V3g1/l2n94xeD/7rIBPJbklyYXNOb9rl2I0q6aMnZM1tWyaMVMr76de+5XkcODPgV+uqscHHW8D3tP+qKoZ4GXNuMWPAd892Yy0WEneAjxUVbcked2E09FovKqqHmiGLlyf5MtzX/S7tquVWWS3MclCvM3MVPXPvyQ5rqoeTHIcg9449USSNQyK8D+tqo82p72nPVZV30jyGeCHgSOTrG56Uf3O7Y9XAmcneTOwHjiCwRbc3s+eqqoHmj8fSvIxBsN1/a5drAJGtMX9uE1yaEqbmanqn7mzic8H/nKCuaiDZszp5cAdVfX+OS95T3smybFNTzhJDgHewGDM/2cYzPIH72VvVNW7qurEqjqZwd+VN1bVv8P72UtJDkvyvGcfM1hv+kv4XbskoxojPm4T6xGvqukkz85MnQKuqKodk8pH3SX5M+B1DBbH3wW8B3gv8JEkFwD/BPzk5DJUR68Efgb4YjO2GOA/4z3to+OAK5vVqVYxmPn/iSS3A1cl+W3g8wz+4aX++g28n330AuBjzbC/1cD/qaprk9yM37WLtwKL7DZSPU1ckiRJ2rD+uPqR7zx/eCBw7V3vu2U/G/qMnZM1JUmS1GNO1pQkSZImw0JckiRJGrMCZoZuX78iWYhLkiSpxwrKQlySJEkaP4emSJIkSWNWwKyFuCRJkjR+9ohLkiRJE2AhLkmSJI1ZFczMTDqLRbEQlyRJUr/ZIy5JkiRNgIW4JEmSNG7lqimSJEnS2BWUG/pIkiRJE+AW95IkSdKYVcGshbgkSZI0fk7WlCRJksav7BGXJEmSxq3sEZckSZLGrnD5QkmSJGncCqiebnG/atIJSJIkSYtWBTXb7hgiyZYkdybZmeTiBV5fl+TDzes3JTl5zmvvas7fmeRNbVK3EJckSVKv1Wy1OvYnyRRwGXAmcBrw9iSnzQu7AHi0qk4FLgXe17z3NOA84HuBLcD/atrbLwtxSZIk9dtoesRPB3ZW1T1VtRe4CjhnXsw5wJXN46uBM5KkOX9VVe2pqq8CO5v29ssx4pIkSeqtJ3j0uk/X1Rtbhq9Psn3O861VtbV5fAJw/5zXdgEvn/f+b8VU1XSSx4BjmvN/P++9JwxLxkJckiRJvVVVWyadw2I5NEWSJEmCB4CT5jw/sTm3YEyS1cAG4OGW7/3/WIhLkiRJcDOwKckpSdYymHy5bV7MNuD85vG5wI1VVc3585pVVU4BNgH/MOyCDk2RJEnSQa8Z830RcB0wBVxRVTuSXAJsr6ptwOXAh5LsBB5hUKzTxH0EuB2YBn6xqoYubp7q6ZagkiRJUp85NEWSJEmaAAtxSZIkaQIsxCVJkqQJsBCXJEmSJsBCXJIkSZoAC3FJkiRpAizEJUmSpAn4f3fJBAYAXCApAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1008x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1008x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1008x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1008x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "(tensor([0.7176, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000,\n",
       "         0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000,\n",
       "         0.0000, 0.0000, 0.0000, 0.9857, 1.2437, 1.0928, 0.0000, 1.1326, 0.0000,\n",
       "         0.0000, 0.0000, 0.5186, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000,\n",
       "         0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.9347, 0.0000,\n",
       "         0.8133, 0.1785, 0.4809, 0.1737, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000],\n",
       "        device='cuda:0'),\n",
       " tensor([0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "         0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "         0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.],\n",
       "        device='cuda:0'))"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "batch['output_attentions'] = True\n",
    "model.bert.ks = [0.1 for x in range(12)]\n",
    "#model.bert.ks[0] = 0.9999\n",
    "model.bert.use_forward_sparse = False\n",
    "model.bert.run_original_attention = True\n",
    "sparse.set_output_masking(model.bert.sparse_bert, True)\n",
    "sparse.set_backup_last_inputs(model.bert.sparse_bert, True)\n",
    "sparse.set_print(model.bert.sparse_bert, False)\n",
    "sparse.set_update_input_mask_accumulate_indices(False)\n",
    "output = model(**batch)\n",
    "sparse.set_update_input_mask_accumulate_indices(True)\n",
    "sparse.set_backup_last_inputs(model.bert.sparse_bert, False)\n",
    "sparse.set_print(model.bert.sparse_bert, False)\n",
    "attentions = [\n",
    "    layer.attention.self.last_attention_probs\n",
    "    for layer in model.bert.sparse_bert.encoder.layer\n",
    "]\n",
    "head_reduced_attentions = [torch.mean(att[0], dim=0) for att in attentions]\n",
    "token_reduced_attentions = [torch.mean(att, dim=0) for att in head_reduced_attentions]\n",
    "lprobs = torch.stack(token_reduced_attentions, dim=0)\n",
    "lprobs = lprobs[:,:TOKEN_LEN]\n",
    "plot_grid(lprobs)\n",
    "plt.colorbar()\n",
    "plt.show()\n",
    "\n",
    "attentions = [\n",
    "    layer.attention.self.last_approx_attention_probs\n",
    "    for layer in model.bert.sparse_bert.encoder.layer\n",
    "]\n",
    "head_reduced_attentions = [torch.mean(att[0], dim=0) for att in attentions]\n",
    "token_reduced_attentions = [torch.mean(att, dim=0) for att in head_reduced_attentions]\n",
    "lprobs = torch.stack(token_reduced_attentions, dim=0)\n",
    "lprobs = lprobs[:,:TOKEN_LEN]\n",
    "plot_grid(lprobs)\n",
    "plt.colorbar()\n",
    "plt.show()\n",
    "\n",
    "# print(torch.sum(torch.mean(head_reduced_attentions[1], dim=0)))\n",
    "\n",
    "# plot_grid(torch.sum(lprobs, dim=1, keepdim=True))\n",
    "# print(torch.sum(lprobs, dim=1, keepdim=True))\n",
    "# plt.colorbar()\n",
    "# plt.show()\n",
    "\n",
    "input_masks = [\n",
    "    layer.attention.self.input_mask[0]\n",
    "    for layer in model.bert.sparse_bert.encoder.layer\n",
    "]\n",
    "input_masks = torch.stack(input_masks, dim=0)\n",
    "input_masks = input_masks[:,:TOKEN_LEN]\n",
    "plot_grid(input_masks)\n",
    "plt.colorbar()\n",
    "plt.show()\n",
    "\n",
    "attentions = [\n",
    "    layer.attention.self.last_attention_scores\n",
    "    for layer in model.bert.sparse_bert.encoder.layer\n",
    "]\n",
    "head_reduced_attentions = [torch.mean(att[0], dim=0) for att in attentions]\n",
    "token_reduced_attentions = [torch.mean(att, dim=0) for att in head_reduced_attentions]\n",
    "lprobs = torch.stack(token_reduced_attentions, dim=0)\n",
    "lprobs = lprobs[:-1,:TOKEN_LEN]\n",
    "plot_grid(lprobs)\n",
    "plt.colorbar()\n",
    "plt.show()\n",
    "\n",
    "lq = model.bert.sparse_bert.encoder.layer[0].attention.self.last_query\n",
    "lk = model.bert.sparse_bert.encoder.layer[0].attention.self.last_key\n",
    "\n",
    "model.bert.sparse_bert.encoder.layer[0].attention.self.last_query[0,0,:TOKEN_LEN,0],\\\n",
    "model.bert.sparse_bert.encoder.layer[0].attention.self.last_key[0][0,1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAuIAAADtCAYAAAD6KhDDAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAAdNklEQVR4nO3df5Bld1nn8fdnejL5/YsMxmQSSbYSsOLiog4BxGWBiA7oErYMbmDVuJXdrFVmF3e1NGhV0Ky1JbsWwarNrpki0Sy4BipKOaVZRiCouxrDTAICkxgYIiQTosMkAYGQzHT3s3/cE2w6nb7n9L197z3T71fVqbnnnO8555k+fU4//e3vj1QVkiRJkiZr07QDkCRJkjYiE3FJkiRpCkzEJUmSpCkwEZckSZKmwERckiRJmoLN0w5AkiRJWqsffNWJ9ehjC63K3v2Jp3ZX1Y51Dqk1E3FJkiT11qHHFrhr9zmtyh5z1me3rnM4nZiIS5IkqceKhVqcdhBrYiIuSZKk3ipgkX5OUGkiLkmSpF5bxBpxSZIkaaKK4ohNUyRJkqTJKmDBpimSJEnS5NlGXJIkSZqwAhbKRFySJEmauH62EDcRlyRJUo8VZRtxSZIkadKq4Eg/83ATcUmSJPVZWCDTDmJNNk07AEmSJGmtClisdsswSXYkuT/J/iTXrLD/FUnuSTKf5LIl21+U5M4k+5J8Ism/bBO7NeKSJEnqtXHUiCeZA24AXgMcAPYk2VVV9y4p9iDwk8DPLTv8CeAnquozSc4G7k6yu6q+tNo1TcQlSZLUW4MJfcbSNOViYH9VPQCQ5FbgUuAbiXhVfa7Z900DtVTVp5d8/kKSg8BzgS+tdkETcUmSJPVWAUeqdWvrrUn2LlnfWVU7m8/bgIeW7DsAvKRrPEkuBrYAnx1W1kRckiRJvVWEhfbdHg9V1fb1iiXJWcC7gSuqaujw5ibikiRJ6rXFGkvTlIeBc5esn9NsayXJKcAfAb9UVX/Z5hgTcUmSJPXWGNuI7wEuTHI+gwT8cuDNbQ5MsgV4P/C/quq2thd0+EJJkiT1WFioTa2W1VTVPHA1sBu4D3hfVe1Lcl2S1wMkeXGSA8AbgRuT7GsO/1HgFcBPJvl4s7xoaORVPZ2KSJIkSRveC77zuNq569talX3l+Z+5ez3biHdl0xRJkiT1VlU4XHPTDmNNTMQlSZLUa4s9neLeRFySJEm9Neis2c9ujybikiRJ6rEM7Yg5q0zEJUmS1FsFLFojLkmSJE3ewngm9Jk4E3FJkiT1VhGOVD9T2n5GLUmSJGFnTUmSJGkqitg0RZIkSZoGO2tKkiRJE1aFwxdKkiRJkzborOkU95IkSdLE2VlTkiRJmrAiLNpZU5IkSZo8a8QlSZKkCStg0c6akiRJ0qSFBWyaIkmSJE1UgaOmtDF30om1+YzT25d/ssNvN4trCKilzYe+tn4n18jmt57Yqbz3c3Tzz+32Ne9kPSs1Or4nuvylM13fQR3/n+sZy+Yvboxnosu7wvfEytb12a/1O3VXXZ63Yw5ujO+Vr/D4oap67rTjWElVbJrS6mJnnM63vvUtrcufdm/78Oae6vgEdyh+xrvu7HZuTdShH3lZp/Jbd3o/R/XFy7p9zbsknYubu2Wo6fAsd31PHDmhfSzHPNHt3Isd374Lx7WPZe7r3WJ57m9ujGfi0X/R/vvW9/7Kurxvuz7Lc0+uXybetbJ0vsOz/63v/IuO0fTTh+q2z087htX0dUKfkaJOsiPJ/Un2J7lmXEFJkiRJbRSwSFots2bNNeJJ5oAbgNcAB4A9SXZV1b3jCk6SJElaXTZkjfjFwP6qeqCqDgO3ApeOJyxJkiRpuMHwhWm1zJpR2ohvAx5asn4AeMnyQkmuAq4CmHvOaSNcTpIkSfpmRXo7asq61+NX1c6q2l5V2+dOWsfe1pIkSdqQFtnUahlmWP/HJK9Ick+S+SSXLdt3RZLPNMsVbeIepUb8YeDcJevnNNskSZKkiaiChTE0O2nZ//FB4CeBn1t27HOAtwHbGbSWubs59vHVrjlKjfge4MIk5yfZAlwO7BrhfJIkSVJnY2ojPrT/Y1V9rqo+wTNnpvhB4INV9ViTfH8Q2DHsgmuuEa+q+SRXA7uBOeDmqtq31vNJkiRJXRWdJvTZmmTvkvWdVbWz+dyq/+OzWOnYbcMOGmlCn6q6Hbh9lHNIkiRJazWY4r51In6oqravYzid9HPQRUmSJAmgqRFvswwxSv/HNR070SnuTzj+MN/zwgdal//c3Re2LrtpYS0R6WiQ5a20tO66TCsPPLMl3So2H+l48g7FF4/pdurNHaaK79pPaNN8t/JHOozMteVwt3NvGLM3hHD/dHje5p7q9ixXl4yk42ti8ZhuNz/mFL0zplkzv9H/kUESfTnw5pbH7gb+S5LTm/UfAN467CBrxCVJktRbT4+a0mZZ/Tw1Dzzd//E+4H1VtS/JdUleD5DkxUkOAG8Ebkyyrzn2MeA/M0jm9wDXNdtWNdEacUmSJGncOnTWXNVK/R+r6toln/cwaHay0rE3Azd3uZ6JuCRJknprMGpKP9uemYhLkiSptwqYH1ON+KSZiEuSJKnXxtU0ZdJMxCVJktRf7WbNnEkm4pIkSeqtYmzDF06cibgkSZJ6zRpxSZIkacIKE3FJkiRp4oowv2hnzaEWKzwxv6V1+S7TaC92mP4Zuk91rdm16K+TE7f1xjs7lX/037ysddmFY7tORd3+RdHlnQLdpsXeNN/t5PMd/5+HT2t//mO+2unUG0bXnxN6pi7P0Ho+y12bA1fHe3/4lG7lNX22EZckSZImrfrbNGXN9fhJzk3ykST3JtmX5C3jDEySJEka5uk24m2WWTNKjfg88LNVdU+Sk4G7k3ywqu4dU2ySJEnSULOYZLex5kS8qh4BHmk+fyXJfcA2wERckiRJE1GEhY3cWTPJecB3AXeN43ySJElSWxu2s2aSk4DfA36mqv5+hf1XAVcBHHfmyaNeTpIkSfqG2oidNQGSHMMgCf+dqvr9lcpU1c6q2l5V27ecevwol5MkSZKeoSqtllmz5hrxJAFuAu6rqneMLyRJkiSprdkcEaWNUWrEXw78OPDqJB9vlteNKS5JkiSplQ1XI15V/4/Oc1tJkiRJ41MFC4v9TEmdWVOSJEm9tmFHTeniySObuf/Ama3Ln97la9rx679pvlt5zS7v5eyrfg7vuq5xzx2uTuUPf+uR1mVPeuiYruFsCFmcdgQbSxa7fY+nW/Fu5+74c+LrZ/uDpU8KZrLZSRvWiEuSJKnH+ttZ00RckiRJvVbr+BeV9WQiLkmSpF6zaYokSZI0YYNRU/rZGamfUUuSJEmNqnbLMEl2JLk/yf4k16yw/9gk723235XkvGb7MUluSfLJJPcleWubuE3EJUmS1GvjmNAnyRxwA/Ba4CLgTUkuWlbsSuDxqroAuB54e7P9jcCxVfVC4HuAf/d0kr4aE3FJkiT1VtEuCW/RjvxiYH9VPVBVh4FbgUuXlbkUuKX5fBtwSZIwGEXxxCSbgeOBw8DfD7ugibgkSZJ6rVouwNYke5csVy05zTbgoSXrB5ptrFSmquaBLwNnMEjKvwY8AjwI/HpVPTYsbjtrSpIkqb8Kqv0U94eqavs6RHExsACcDZwO/N8kH6qqB1Y7yBpxSZIk9dqYmqY8DJy7ZP2cZtuKZZpmKKcCjwJvBj5QVUeq6iDw58DQhH+iNeJzX9vEyR89vnX5LtPjdp0at69TbuuZ5o/v59ihG0mX5zMLHR/mDrc/C91OPffU7LyDznveF1uX/dI9y/+SKvBdMQ6dvm+7PsqL3cp3sanjbC+nbRvatFczZkwT+uwBLkxyPoOE+3IGCfZSu4ArgDuBy4A7qqqSPAi8Gnh3khOBlwLvHHZBm6ZIkiSpt4rxTOhTVfNJrgZ2A3PAzVW1L8l1wN6q2gXcxCDZ3g88xiBZh8FoK7+VZB+DKqLfqqpPDLumibgkSZL6q4AxzaxZVbcDty/bdu2Sz08yGKpw+XFfXWn7MCM30Egyl+RjSf5w1HNJkiRJXY1rQp9JG0eN+FuA+4BTxnAuSZIkqYN0GTVlpoxUI57kHOCHgHeNJxxJkiSpow4Dic+SUWvE3wn8PHDysxVoBkq/CuCYk08f8XKSJEnSEjWezprTsOYa8SQ/DBysqrtXK1dVO6tqe1Vt33z8iWu9nCRJkrSyDVgj/nLg9UleBxwHnJLkPVX1Y+MJTZIkSWpjg9WIV9Vbq+qcqjqPwRiKd5iES5IkaeIWWy4zxnHEJUmS1F9jHEd80saSiFfVnwB/Mo5zSZIkSV3M4hjhbUy2RnwR5p5q/5WqLg1nOt6AmutWXrNr7nBPn74NpMuzXJu61WpkscP97/qt0iGUTu8rYHGu2/9zYbH9BTYt+EysJDP4Z+m+6fQsp2MN5Xz779uFLd3O7c+JDaCnt9imKZIkSeq3jdw0RZIkSZqWWCMuSZIkTVgFejrFvYm4JEmS+s0acUmSJGkKTMQlSZKkKTARlyRJkiZso0/oI0mSJE2Lo6ZIkiRJ02AiLkmSJE2eNeJtbILFDtPSpsN0t5JmV5fpqGuu27nTYezY6vrG6zAleqrb+6prLCdteap12eNvvLPbyTcIp7gfXW1q/7wtdn3e0iE/WOyYH3RsPnzyce2fN80I24hLkiRJE1bYNEWSJEmaip4m4ptGOTjJaUluS/LXSe5L8rJxBSZJkiS1kcV2y6wZtUb8N4APVNVlSbYAJ4whJkmSJKm9jVYjnuRU4BXATQBVdbiqvjSmuCRJkqShUu2XoedKdiS5P8n+JNessP/YJO9t9t+V5Lwl+74zyZ1J9iX5ZJLjhl1vlKYp5wNfBH4ryceSvCvJiSsEfFWSvUn2zn/9ayNcTpIkSVpBpd2yiiRzwA3Aa4GLgDcluWhZsSuBx6vqAuB64O3NsZuB9wA/VVXfAbwSODIs7FES8c3AdwP/s6q+C/ga8IzfHKpqZ1Vtr6rtm49/Rp4uSZIkjaZaLqu7GNhfVQ9U1WHgVuDSZWUuBW5pPt8GXJIkwA8An6iqvwKoqkeramHYBUdJxA8AB6rqriXBfPcI55MkSZI669A0ZevTLTWa5aolp9kGPLRk/UCzjZXKVNU88GXgDOD5QCXZneSeJD/fJu41d9asqr9N8lCSF1TV/cAlwL1rPZ8kSZLUWXUaEeVQVW1fhyg2A98HvBh4Avhwkrur6sPDDhrFvwd+pxkx5QHgX494PkmSJKmb8Yya8jBw7pL1c5ptK5U50LQLPxV4lEHt+Z9V1SGAJLczaCmyaiI+0jjiVfXxpv33d1bVG6rq8VHOJ0mSJHU2njbie4ALk5zfVDJfDuxaVmYXcEXz+TLgjqoqYDfwwiQnNAn6P6NFS5GJzqxZgYVjOxywZfXerd+kQ1GAmutWXrNr6413TjsEDbEwdACnJbo+y11eE+s5zuxit8AXj+l2+hM2H25d9ivdTr1hfMsNfzHtEHrvyEnty2ZoN7Vv1unncro9b11jecFpB1uXfbDbqbVOxvF+r6r5JFczSKrngJural+S64C9VbWLwbDd706yH3iMQbJOVT2e5B0MkvkCbq+qPxp2Tae4lyRJkoCquh24fdm2a5d8fhJ447Mc+x4GQxi2ZiIuSZKkfuvpzJom4pIkSeqvbqOmzBQTcUmSJPWbNeKSJEnSZIV17oy/jkzEJUmS1G8m4pIkSdKElTXikiRJ0nTYWVOSJEmaPGvEJUmSpGkwEZckSZImrDARb6M2wZGTOpSfa/9VzWI6xtLTOyb10Nn/7S9al/38dS/rdO4uz37n5746vFc6/l00C93eWd996kOty/4px3c6t9TWkVM6/Fye7/Y93sXz3tb+nQLw+V/53k7lH37i1A6lv9bp3FofNk2RJEmSpqGnifimUQ5O8h+T7EvyqSS/m+S4cQUmSZIktZHFdsusWXMinmQb8B+A7VX1j4E54PJxBSZJkiQNVR2WGTNq05TNwPFJjgAnAF8YPSRJkiSpnTRLH625RryqHgZ+HXgQeAT4clX98fJySa5KsjfJ3oUn7NAgSZKkMetpjfgoTVNOBy4FzgfOBk5M8mPLy1XVzqraXlXb5044ce2RSpIkSStItVtmzSidNb8f+Juq+mJVHQF+H+g2PpAkSZI0qp7WiI/SRvxB4KVJTgC+DlwC7B1LVJIkSVIbNZsjorQxShvxu4DbgHuATzbn2jmmuCRJkqR2NmCNOFX1NuBtY4pFkiRJ6mwW23+3Mdkp7rcUT559pP0BHaa4p+N00aNNZSRpvTzv2js7lf/0jS9uXTbz3R782tThHbTOY2f94tb7W5f9U160foFoQzvvl9o/n5/+zYs7nfv5P/XRruG09tSZ853KP/+Ug63L3tc1GK0PE3FJkiRp8qwRlyRJkiatgI3WWVOSJEmatjC+ccST7Ehyf5L9Sa5ZYf+xSd7b7L8ryXnL9n9bkq8m+bk2sZuIS5Ikqd/GMGpKkjngBuC1wEXAm5JctKzYlcDjVXUBcD3w9mX73wH8n7Zhm4hLkiSp11LVahniYmB/VT1QVYeBWxnMIr/UpcAtzefbgEuSBCDJG4C/Afa1jdtEXJIkSf3VtjZ8kIdvTbJ3yXLVkjNtAx5asn6g2cZKZapqHvgycEaSk4BfAH6lS+h21pQkSVKvdRg15VBVbV+HEH4ZuL6qvtpUkLdiIi5JkqReG9MU9w8D5y5ZP6fZtlKZA0k2A6cCjwIvAS5L8l+B04DFJE9W1X9f7YIm4pIkSeq38Ywjvge4MMn5DBLuy4E3LyuzC7gCuBO4DLijqgr4p08XSPLLwFeHJeFgIi5JkqQ+azk04dDTVM0nuRrYDcwBN1fVviTXAXurahdwE/DuJPuBxxgk62tmIi5JkqR+G9PMmlV1O3D7sm3XLvn8JPDGIef45bbXm3wi3mGclk3HLrQuu3hkrlMYmevpFEySvtnm9m/f6jr1WpdxpdZ5euXLPvv9HUofWrc4pNZmac7xuW6xvObUT7Uuex/f3jUajdnTE/r0kTXikiRJ6rUs9jMTH1rfk+TmJAeTfGrJtuck+WCSzzT/nr6+YUqSJEkr6DaO+Exp84fX3wZ2LNt2DfDhqroQ+HCzLkmSJE1cFtsts2ZoIl5Vf8agV+hSS6f3vAV4w3jDkiRJklrqaY34WtuIn1lVjzSf/xY489kKNlOHXgUw95zT1ng5SZIkaWV97azZZUyAFTWDmD/rf7+qdlbV9qraPnfyiaNeTpIkSfoHBVS1W2bMWhPxv0tyFkDz78HxhSRJkiS1d9S2EX8WT0/vSfPvH4wnHEmSJKm9p8cRb7PMmjbDF/4ucCfwgiQHklwJ/BrwmiSfAb6/WZckSZImq22zlBlsmjK0s2ZVvelZdl0y5lgkSZKkzmaxtruNic6seeyxR3j+P3pkeMFGOnxVq7KWkCT13AvOb/9O6fqeWNd30CUHOhV/4iNndzu/NGXPv6D9s7nenv9v93Qqf8NHXt2h9Be6BaP1YSIuSZIkTZ414pIkSdKkFbDQz0zcRFySJEm9Zo24JEmSNA0zOCJKGybikiRJ6jVrxCVJkqRJKxw1RZIkSZq0ALGzpiRJkjR5sY24JEmSNGE2TZEkSZKmoRw1RZIkSZoGR01p4SufPnjoQ69+5+dX2LUVODTJWLRuvJdHl9m/n6+adgAT8sqxnGX276e6mO37+eppBzCCV078irN9LweeN+0AVmWN+HBV9dyVtifZW1XbJxmL1of38uji/Ty6eD+PLt7Po4f3ckTV31FTNk07AEmSJGkk1XIZIsmOJPcn2Z/kmhX2H5vkvc3+u5Kc12x/TZK7k3yy+bfV34RMxCVJktRrqWq1rHqOZA64AXgtcBHwpiQXLSt2JfB4VV0AXA+8vdl+CPjnVfVC4Arg3W3inpVEfOe0A9DYeC+PLt7Po4v38+ji/Tx6eC9HVdVuWd3FwP6qeqCqDgO3ApcuK3MpcEvz+TbgkiSpqo9V1Rea7fuA45McO+yCM5GIV5XfgEcJ7+XRxft5dPF+Hl28n0cP7+WIClhsucDWJHuXLFctOdM24KEl6weabaxUpqrmgS8DZywr8yPAPVX11LDQHb5QkiRJvRWGNztZ4tB6doxN8h0Mmqv8QJvyU60RH9YgXrMtyc1JDib51JJtz0nywSSfaf49fZoxqr0k5yb5SJJ7k+xL8pZmu/e0Z5Icl+SjSf6quZe/0mw/v+lctL/pbLRl2rGqvSRzST6W5A+bde9nTyX5XNOp7+NJ9jbbfNeOYnGx3bK6h4Fzl6yf02xbsUySzcCpwKPN+jnA+4GfqKrPtgl7aol4ywbxmm2/DexYtu0a4MNVdSHw4WZd/TAP/GxVXQS8FPjp5pn0nvbPU8Crq+qfAC8CdiR5KYNamuubTkaPM+h0pP54C3DfknXvZ7+9qqpetKR21nftWnVrmrKaPcCFzS+5W4DLgV3Lyuxi0BkT4DLgjqqqJKcBfwRcU1V/3jb0adaIt2kQrxlWVX8GPLZs89JODLcAb5hkTFq7qnqkqu5pPn+FwQ/8bXhPe6cGvtqsHtMsxWCKldua7d7LHmlq2n4IeFezHryfRxvftSMYx6gpTZvvq4HdDH4Gvq+q9iW5Lsnrm2I3AWck2Q/8J/7hF6argQuAa5u/dHw8ybcMi3uabcRXahD/kinFovE5s6oeaT7/LXDmNIPR2jTjon4XcBfe015q/up4N4MfDDcAnwW+1PyggZU7IWl2vRP4eeDkZv0MvJ99VsAfJyngxqazpu/aUYxpZs2quh24fdm2a5d8fhJ44wrH/Srwq12vZ2dNrZvmTzX9nOpqA0tyEvB7wM9U1d8PKt4GvKf9UVULwIuaP5e+H/j26UaktUryw8DBqro7ySunHI7G4/uq6uGmxvSDSf566U7ftV21GppwJk0zEW/TIF7983dJzqqqR5KcBRycdkBqL8kxDJLw36mq3282e097rKq+lOQjwMuA05JsbmpRfef2x8uB1yd5HXAccArwG3g/e6uqHm7+PZjk/Qya6/quXasCnOK+szYN4tU/SzsxXAH8wRRjUQdNm9ObgPuq6h1LdnlPeybJc5uacJIcD7yGQXvHjzDoXATey96oqrdW1TlVdR6Dn5V3VNW/wvvZS0lOTHLy058ZDHP3KXzXjmQcbcSnYWo14lU1n+TpBvFzwM1VtW9a8ai7JL8LvJLB4PgHgLcBvwa8L8mVwOeBH51ehOro5cCPA59M8vFm2y/iPe2js4Bbmnbimxh0OPrDJPcCtyb5VeBjDH7xUn/9At7PPjoTeH/T7G8z8L+r6gNJ9uC7du1mMMluI9XTwCVJkqRTjzurvvd5VwwvCHzg02+/ez0n9OnKzpqSJEnqMTtrSpIkSdNhIi5JkiRNWAELw6fNnEUm4pIkSeqxgjIRlyRJkibPpimSJEnShBWwaCIuSZIkTZ414pIkSdIUmIhLkiRJE1YFCwvTjmJNTMQlSZLUb9aIS5IkSVNgIi5JkiRNWjlqiiRJkjRxBeWEPpIkSdIUOMW9JEmSNGFVsGgiLkmSJE2enTUlSZKkyStrxCVJkqRJK2vEJUmSpIkrHL5QkiRJmrQCqqdT3G+adgCSJEnSmlVBLbZbhkiyI8n9SfYnuWaF/ccmeW+z/64k5y3Z99Zm+/1JfrBN6CbikiRJ6rVarFbLapLMATcArwUuAt6U5KJlxa4EHq+qC4Drgbc3x14EXA58B7AD+B/N+VZlIi5JkqR+G0+N+MXA/qp6oKoOA7cCly4rcylwS/P5NuCSJGm231pVT1XV3wD7m/OtyjbikiRJ6q2v8PjuD9VtW1sWPy7J3iXrO6tqZ/N5G/DQkn0HgJcsO/4bZapqPsmXgTOa7X+57Nhtw4IxEZckSVJvVdWOacewVjZNkSRJkuBh4Nwl6+c021Ysk2QzcCrwaMtjn8FEXJIkSYI9wIVJzk+yhUHny13LyuwCrmg+XwbcUVXVbL+8GVXlfOBC4KPDLmjTFEmSJG14TZvvq4HdwBxwc1XtS3IdsLeqdgE3Ae9Osh94jEGyTlPufcC9wDzw01U1dHDzVE+nBJUkSZL6zKYpkiRJ0hSYiEuSJElTYCIuSZIkTYGJuCRJkjQFJuKSJEnSFJiIS5IkSVNgIi5JkiRNwf8H9+Twei12hioAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1008x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1008x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1008x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1008x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "(tensor([0.7176, 0.7990, 1.2183, 1.1011, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000,\n",
       "         0.0000, 0.0000, 0.0000, 0.0000, 0.7432, 0.0000, 0.0000, 0.0000, 0.0000,\n",
       "         0.0000, 0.0000, 0.0000, 0.9857, 1.2437, 1.0928, 1.1536, 1.1326, 0.8876,\n",
       "         0.4806, 0.8889, 0.5186, 0.2215, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000,\n",
       "         0.4742, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.9347, 0.6029,\n",
       "         0.8133, 0.1785, 0.4809, 0.1737, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000],\n",
       "        device='cuda:0'),\n",
       " tensor([ 0.8267,  0.1549, -0.2156, -0.7234, -1.3104, -0.3582, -0.0156,  0.3393,\n",
       "          0.6420,  0.0986,  0.5138,  0.2057,  1.5941, -0.9830, -0.6241,  0.5809,\n",
       "          0.8626, -1.2559, -0.1151, -1.8818,  0.2564, -0.0360, -0.3248, -0.7375,\n",
       "          1.1127, -0.7124, -0.4161, -0.0033, -0.2881, -2.2785,  1.0957,  0.6665,\n",
       "          0.1348, -0.1413,  0.3093,  0.4727, -1.2287,  0.6152,  0.5025, -0.6066,\n",
       "         -0.6124,  0.2445,  0.5721, -2.3833,  0.0989, -0.4551,  1.2341,  1.3362,\n",
       "         -0.0574,  0.2977, -0.6198, -0.3196,  0.0872,  1.3868,  0.3311, -0.1105,\n",
       "         -0.1735, -0.2520, -0.2225, -0.4136, -1.2305, -0.1286, -1.3723,  0.5435],\n",
       "        device='cuda:0'))"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "batch['output_attentions'] = True\n",
    "model.bert.ks = [0.1 for x in range(12)]\n",
    "#model.bert.ks[0] = 0.9999\n",
    "model.bert.use_forward_sparse = False\n",
    "model.bert.run_original_attention = True\n",
    "sparse.set_output_masking(model.bert.sparse_bert, True)\n",
    "sparse.set_backup_last_inputs(model.bert.sparse_bert, True)\n",
    "sparse.set_print(model.bert.sparse_bert, False)\n",
    "output = model(**batch)\n",
    "sparse.set_backup_last_inputs(model.bert.sparse_bert, False)\n",
    "sparse.set_print(model.bert.sparse_bert, False)\n",
    "attentions = [\n",
    "    layer.attention.self.last_attention_probs\n",
    "    for layer in model.bert.sparse_bert.encoder.layer\n",
    "]\n",
    "head_reduced_attentions = [torch.mean(att[0], dim=0) for att in attentions]\n",
    "token_reduced_attentions = [torch.mean(att, dim=0) for att in head_reduced_attentions]\n",
    "lprobs = torch.stack(token_reduced_attentions, dim=0)\n",
    "lprobs = lprobs[:,:TOKEN_LEN]\n",
    "plot_grid(lprobs)\n",
    "plt.colorbar()\n",
    "plt.show()\n",
    "\n",
    "attentions = [\n",
    "    layer.attention.self.last_approx_attention_probs\n",
    "    for layer in model.bert.sparse_bert.encoder.layer\n",
    "]\n",
    "head_reduced_attentions = [torch.mean(att[0], dim=0) for att in attentions]\n",
    "token_reduced_attentions = [torch.mean(att, dim=0) for att in head_reduced_attentions]\n",
    "lprobs = torch.stack(token_reduced_attentions, dim=0)\n",
    "lprobs = lprobs[:,:TOKEN_LEN]\n",
    "plot_grid(lprobs)\n",
    "plt.colorbar()\n",
    "plt.show()\n",
    "\n",
    "# print(torch.sum(torch.mean(head_reduced_attentions[1], dim=0)))\n",
    "\n",
    "# plot_grid(torch.sum(lprobs, dim=1, keepdim=True))\n",
    "# print(torch.sum(lprobs, dim=1, keepdim=True))\n",
    "# plt.colorbar()\n",
    "# plt.show()\n",
    "\n",
    "input_masks = [\n",
    "    layer.attention.self.input_mask[0]\n",
    "    for layer in model.bert.sparse_bert.encoder.layer\n",
    "]\n",
    "input_masks = torch.stack(input_masks, dim=0)\n",
    "input_masks = input_masks[:,:TOKEN_LEN]\n",
    "plot_grid(input_masks)\n",
    "plt.colorbar()\n",
    "plt.show()\n",
    "\n",
    "attentions = [\n",
    "    layer.attention.self.last_attention_scores\n",
    "    for layer in model.bert.sparse_bert.encoder.layer\n",
    "]\n",
    "head_reduced_attentions = [torch.mean(att[0], dim=0) for att in attentions]\n",
    "token_reduced_attentions = [torch.mean(att, dim=0) for att in head_reduced_attentions]\n",
    "lprobs = torch.stack(token_reduced_attentions, dim=0)\n",
    "lprobs = lprobs[:-1,:TOKEN_LEN]\n",
    "plot_grid(lprobs)\n",
    "plt.colorbar()\n",
    "plt.show()\n",
    "\n",
    "lq = model.bert.sparse_bert.encoder.layer[0].attention.self.last_query\n",
    "lk = model.bert.sparse_bert.encoder.layer[0].attention.self.last_key\n",
    "\n",
    "model.bert.sparse_bert.encoder.layer[0].attention.self.last_query[0,0,:TOKEN_LEN,0],\\\n",
    "model.bert.sparse_bert.encoder.layer[0].attention.self.last_key[0][0,1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x7fe1350e8160>"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1008x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "batch['output_attentions'] = True\n",
    "model.bert.ks = [0.9999 for _ in range(12)]\n",
    "model.bert.use_forward_sparse = False\n",
    "output = model(**batch)\n",
    "head_reduced_attentions = [torch.mean(att[0], dim=0) for att in output.attentions]\n",
    "token_reduced_attentions = [torch.mean(att, dim=0) for att in head_reduced_attentions]\n",
    "lprobs = torch.stack(token_reduced_attentions, dim=0)\n",
    "lprobs = lprobs[:,:TOKEN_LEN]\n",
    "plot_grid(lprobs)\n",
    "plt.colorbar()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1008x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1008x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "(tensor([ 0.7176,  0.7990,  1.2183,  1.1011,  0.1575,  0.1614,  0.1766,  0.7791,\n",
       "          0.3523,  1.0252,  1.3391,  0.8296,  1.0164,  0.7432,  0.5464,  1.4789,\n",
       "          1.0512,  0.9598,  0.3206,  1.3642,  0.3494,  0.9857,  1.2437,  1.0928,\n",
       "          1.1536,  1.1326,  0.8876,  0.4806,  0.8889,  0.5186,  0.2215, -0.0961,\n",
       "          0.3898, -0.1045,  0.8652,  0.4584,  0.4742,  0.2094,  0.0578,  1.1016,\n",
       "          0.0305,  0.0755,  1.0107,  0.9347,  0.6029,  0.8133,  0.1785,  0.4809,\n",
       "          0.1737,  0.4557,  0.4847,  0.5119,  0.3969,  0.4312], device='cuda:0'),\n",
       " tensor([ 0.8267,  0.1549, -0.2156, -0.7234, -1.3104, -0.3582, -0.0156,  0.3393,\n",
       "          0.6420,  0.0986,  0.5138,  0.2057,  1.5941, -0.9830, -0.6241,  0.5809,\n",
       "          0.8626, -1.2559, -0.1151, -1.8818,  0.2564, -0.0360, -0.3248, -0.7375,\n",
       "          1.1127, -0.7124, -0.4161, -0.0033, -0.2881, -2.2785,  1.0957,  0.6665,\n",
       "          0.1348, -0.1413,  0.3093,  0.4727, -1.2287,  0.6152,  0.5025, -0.6066,\n",
       "         -0.6124,  0.2445,  0.5721, -2.3833,  0.0989, -0.4551,  1.2341,  1.3362,\n",
       "         -0.0574,  0.2977, -0.6198, -0.3196,  0.0872,  1.3868,  0.3311, -0.1105,\n",
       "         -0.1735, -0.2520, -0.2225, -0.4136, -1.2305, -0.1286, -1.3723,  0.5435],\n",
       "        device='cuda:0'),\n",
       " tensor(1.6892, device='cuda:0'))"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "batch['output_attentions'] = True\n",
    "#model.bert.ks = [0.1 for _ in range(12)]\n",
    "target_ks = 0.1\n",
    "if target_ks <= 0.666:\n",
    "    ks = [target_ks*0.5+((1-x/11.0)**1.0) * target_ks for x in range(12)]\n",
    "else:\n",
    "    ks = [(1-x/11.0)*(2-2*target_ks)+(2*target_ks-1) for x in range(12)]\n",
    "model.bert.ks = ks\n",
    "model.bert.use_forward_sparse = True\n",
    "output = model(**batch)\n",
    "head_reduced_attentions = [torch.mean(att[0], dim=0) for att in output.attentions]\n",
    "token_reduced_attentions = [torch.mean(att, dim=0) for att in head_reduced_attentions]\n",
    "lprobs = torch.stack(token_reduced_attentions, dim=0)\n",
    "lprobs = lprobs[:,:TOKEN_LEN]\n",
    "plot_grid(lprobs)\n",
    "plt.colorbar()\n",
    "plt.show()\n",
    "\n",
    "# input_masks = [\n",
    "#     layer.attention.self.input_mask[0]\n",
    "#     for layer in model.bert.sparse_bert.encoder.layer\n",
    "# ]\n",
    "# input_masks = torch.stack(input_masks, dim=0)\n",
    "# input_masks = input_masks[:,:TOKEN_LEN]\n",
    "# plot_grid(input_masks)\n",
    "# plt.colorbar()\n",
    "# plt.show()\n",
    "\n",
    "attentions = [\n",
    "    layer.attention.self.last_attention_scores\n",
    "    for layer in model.bert.sparse_bert.encoder.layer\n",
    "]\n",
    "head_reduced_attentions = [torch.mean(att[0], dim=0) for att in attentions]\n",
    "token_reduced_attentions = [torch.mean(att, dim=0) for att in head_reduced_attentions]\n",
    "lprobs = torch.stack(token_reduced_attentions, dim=0)\n",
    "lprobs = lprobs[:,:TOKEN_LEN]\n",
    "plot_grid(lprobs)\n",
    "plt.colorbar()\n",
    "plt.show()\n",
    "\n",
    "lq_ = model.bert.sparse_bert.encoder.layer[0].attention.self.last_query\n",
    "lk_ = model.bert.sparse_bert.encoder.layer[0].attention.self.last_key\n",
    "\n",
    "model.bert.sparse_bert.encoder.layer[0].attention.self.last_query[0,0,:TOKEN_LEN,0],\\\n",
    "model.bert.sparse_bert.encoder.layer[0].attention.self.last_key[0][0,1],\\\n",
    "torch.mean(torch.square(lq-lq_)+torch.square(lk-lk_))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "eval: 100%|██████████| 1725/1725 [01:26<00:00, 20.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "metric score {'accuracy': 0.37681159420289856, 'f1': 0.12244897959183673}\n",
      "avg occupy 0.5389886924669531\n",
      "mask_occupy 0.10702613208048004\n"
     ]
    }
   ],
   "source": [
    "ks = [0.05 for _ in range(12)]\n",
    "#ks = [0.07 * (x/11) + 0.05 for x in range(12)]\n",
    "#ks = [0.1*(x/11) + 0.05 for x in range(12)]\n",
    "#model.bert.ks[0] = 0.9999\n",
    "sparse.benchmark_reset()\n",
    "trainer.set_batch_size(1)\n",
    "trainer.eval_sparse_model(ks=ks, run_original_attention=True)\n",
    "print('mask_occupy', sparse.benchmark_get_average('mask_occupy'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GlueAttentionApproxTrainer: update batch size 8\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "eval: 100%|██████████| 216/216 [01:39<00:00,  2.18it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "metric score {'accuracy': 0.383768115942029, 'f1': 0.17788089713843774}\n",
      "avg occupy 0.5389877772690274\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "{'accuracy': 0.383768115942029, 'f1': 0.17788089713843774}"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "target_ks = sparse.benchmark_get_average('mask_occupy')\n",
    "ksx = [target_ks*0.5+((1-x/11.0)**2) * target_ks for x in range(12)]\n",
    "trainer.set_batch_size(8)\n",
    "#'accuracy': 0.5692753623188406, 'f1': 0.558001189767995\n",
    "trainer.eval_sparse_model(ks=ksx, use_forward=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(tensor([[0, 1, 2, 2],\n",
       "         [1, 1, 1, 2]]),\n",
       " tensor([0, 2, 1, 3]),\n",
       " tensor([1, 1, 1, 1]))"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "a = torch.arange(0,6).unsqueeze(0).repeat(2,1)\n",
    "b = torch.tensor([[0,2,1,2],[1,1,1,2]])\n",
    "b = torch.unique(b, dim=1, return_counts=True, return_inverse=True)\n",
    "#a.gather(dim=1, index=b)\n",
    "b"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "58c896f8fe28377dc6f47dbc9814b9367447c8ff4b1090ace6962dd6db7d2533"
  },
  "kernelspec": {
   "display_name": "Python 3.8.12 ('torch')",
   "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.8.12"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
