{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "from matplotlib import pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# !scp mygpu:TXL/transformer-xl/pytorch/test_res.csv ./test_res_retrieval.csv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# !scp gpu6:bulatov/TXL/_git/test_res.csv ./test_res_synthetic_results.csv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_retrieval = pd.read_csv('test_res_retrieval.csv')\n",
    "df = pd.read_csv('test_res_synthetic_results.csv')\n",
    "# df = pd.concat((df, df_retrieval))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# df = pd.concat([df, df_retrieval])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = df.dropna(subset=['test acc'])\n",
    "df = df.drop('work_dir', axis=1)\n",
    "df = df.drop_duplicates()\n",
    "\n",
    "df_retrieval = df_retrieval.dropna(subset=['test acc'])\n",
    "df_retrieval = df_retrieval.drop('work_dir', axis=1)\n",
    "df_retrieval = df_retrieval.drop_duplicates()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = df[(df.max_step > 450000) | (df.tgt_len >= 24)]\n",
    "# df = df[~((df.tgt_len == 12) & (df.max_step == 700000))]\n",
    "df = df[~((df.tgt_len == 24) & (df.max_step == 300000))]\n",
    "df = df[~((df.tgt_len == 8) & (df.num_mem_tokens == 12))]\n",
    "df = df[~((df.dataset == 'reverse') & (df.max_step == 900000))]\n",
    "\n",
    "df_retrieval = df_retrieval[df_retrieval.mem_backprop_depth == 0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "# res_df = df\n",
    "\n",
    "df = pd.concat((df, df_retrieval[df_retrieval.dataset == 'copy']))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "df['mem_size'] = df.num_mem_tokens + df.mem_len\n",
    "df_retrieval['mem_size'] = df_retrieval.num_mem_tokens + df_retrieval.mem_len\n",
    "\n",
    "reverse = df[df.dataset == 'reverse']\n",
    "copy = df[df.dataset == 'copy']\n",
    "retrieval = df_retrieval[df_retrieval.dataset.apply(lambda x: 'retrieval' in x)]\n",
    "# retrieval = df[df.dataset.apply(lambda x: 'retrieval' in x)]\n",
    "\n",
    "retrieval = retrieval[(retrieval.lr == 0.0001) & (retrieval.tgt_len <= 10) & (retrieval.max_step != 250000)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "copy['n_chunks'] = (copy.tgt_len.max() / copy.tgt_len).astype(int)\n",
    "reverse['n_chunks'] = (reverse.tgt_len.max() / reverse.tgt_len).astype(int)\n",
    "retrieval['n_chunks'] = (10 / retrieval.tgt_len).apply(lambda x: np.ceil(x)).astype(int)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 435,
   "metadata": {},
   "outputs": [],
   "source": [
    "# df.to_csv('copy+reverse.csv', index=False)\n",
    "# retrieval[retrieval.dataset == 'retrieval'].to_csv('retrieval.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 428,
   "metadata": {},
   "outputs": [],
   "source": [
    "# mt.boxplot('test acc', by='num_mem_tokens', figsize=(10, 6), patch_artist=True, fontsize=16)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Accuracy')"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAB04AAAIQCAYAAAAGik0wAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAEAAElEQVR4nOzdd3hb1fkH8O/RsiV57z2wE2eQHQJhhQQohBJoBmWUPUsKlNFCoGWvpGWUlUJSINAyAxRKKPArkEBCGImznD299x6SbY3z++NKtmRL8rY8vp/n0SPr3HPvPRqWr+973/MKKSWIiIiIiIiIiIiIiIiIiEYzlb8HQERERERERERERERERETkbwycEhEREREREREREREREdGox8ApEREREREREREREREREY16DJwSERERERERERERERER0ajHwCkRERERERERERERERERjXoafw+AiIiIaCTLzs4OV6lUV6nV6t9IKaMACH+PiYiIiIhGBSmEqLTZbP+y2+1vzJgxo9bfAyIiIiIa6oSU0t9jICIiIhqRsrOzdRqNZm1ERMSkqKioxsDAwFYhGDclIiIiooEnpURzc7OuoqIiuKamZpfVar1oxowZrf4eFxEREdFQxql6iYiIiAbOpSEhIZOSkpKq9Xo9g6ZERERENGiEENDr9a3JyclVISEhkwBc4u8xEREREQ11DJwSERERDRCtVnteREQEA6ZERERE5DdCCERERLRqtdrz/D0WIiIioqGOgVMiIiKigTPZaDSa/D0IIiIiIhrdjEajGcBkf4+DiIiIaKhj4JSIiIhogEgp9Wq12u7vcRARERHR6KZWq21SSoO/x0FEREQ01Gn8PQAiIiKikaw/p+ndU7An4Vj5sfj+2l56THrJxOSJxf21PSJ/2rOnPuHYsab++/1IN5ZMnBjC3w+iEa7+/fcTmr7+ut++O4xnnlkS8utf87uDhhyWjiAiIiLqHiGl9PcYiIiIiEaknTt35k6ZMqVyMPe5LnvdDAA4f8b52YO5X6LhYN26EuX34/x4/n4QUbeV3HTTDACIf+UVfnfQsLZz586oKVOmpPl7HERERERDGafqJSIiIiIiIiIiIiIiIqJRj1P1EhEREQ1zZrNZvPHGG+GrVq+KO3jwIMwmMwwGw/QxY8c033TjTaVXXnlljV6v5zQjNOpVV5fhuefuwOTJb2hSUlKs/h4PEQ0dibGxU4rLy32fI1m1aoa3RQkxMdaisrKd/T4wIiIiIiIaVAycEhEREQ1jzz77bORjjz+WkpqZivmXzlfdPeNu6A16mE1mkZOdo3/ltVdS7/vTfal//tOf8++4444qf4/XVWJi4qTi4mKda5sQAkaj0Zaent68aNGimnvuuad8uAR9n3/++cjf//73aYsWLar68MMPc53tBw4c0I0bN25SQkJCa1FRUY4fhzjqffjhShw8uAMPP/xIwquv/iPf3+PpSAjhNSjjTcfP23BTUVGhvv322xO/+eab0IqKCq3NZhNnnnlm7VdffXXE32Mbyj788MOQJUuWjAkKCrLt2LFjT0ZGhsVTv4ULF6Z9/PHHkXPmzKnbsGHDYWf7rFmzsrZs2RL03HPP5d52221D6m+DvxSXl2uKb7yx1+snrFrl9/Mrnv6u6nQ6GRERYZk2bVrT7373u/Jf/vKXjZ7WXbx4cdpHH30UCQCTJ09u2rlz535v+3nmmWei7rrrrlTnYylltrf9d+WEE05o/Pnnnw/46uP8O9qxXa1WIyQkxDpx4kTT9ddfX3HVVVfVdnddvV5vT0pKapk7d279n/70p1LnxTS9+R5OSEho7enz7u4xgc1mw1/+8pfot956K+ro0aOBarVajh071nzjjTdW3HTTTdU9HSsRERERdc3vB/ZERERE1Dt3/eGuhPfefy/24ZceVqVlprktCwoJwuy5szF77mxV7uFcPPnHJ1MKiwoDnn7q6WL/jNa7U089tT4mJsYCAFarVRQXF+u2b99uzMnJMX788cfhmzdvPmAwGIZF8JSGrry8PO0336zFY4+9hwceuDjqwQcfKB5qWaeLFi3qFMAqLy/Xbtq0KUSv19vnz59f03H5Kaec4jEIMlxcccUVqV9++WV4YmJi6/z582t0Op2cNm2ayd/jGuoWL15cf/HFF1e+9957Uddcc03ad999d6hjn7feeiv0448/jgwODratWbMmzx/jJP9w/btaW1ur3rt3r+Hzzz8P//zzz8MfeuihggcffLDc1/q7du0ybt++PXDatGnNnpb/61//ivLU/stf/rKmqqrK7TxTU1OT6ssvvwwHPH/HZWVledyHN67baG5uVh09ejRw06ZNIZs2bQr57rvvyl999dWC7qxbXFys27lzp3HVqlWxa9eujfzqq68OTJ8+vbk338MZGRktR44cCejY7gxEn3POOTVGo9HuuiwyMrLLvz9WqxXnnHNOxjfffBMWFBRkO/XUU+tbW1vFDz/8EPLb3/426McffzS+/vrrXp8vEREREfUOA6dEREREw9Czzz4b+d7778Uuf3W5KiwizGfftMw0rHh1hWrZdctikxKTWoZa5uk999xTev755ze4tu3atStgzpw543bu3Gl8+umno++//36fJ3mHsrS0NMu2bdv26HQ6Bn/96OGHH4mfN+8iZGRMwty5Fw3JrFNPmaPr1q0L3rRpU0h4eLh1OGeWetLS0iK++uqrsICAALlr1649ERER9q7XIqeVK1cWfPvttyEbN24MeeaZZ6LuvPPOSueysrIy9e23354KAE888URBWlqax4xUGpk6/l1taWkR1113XfJbb70V/fjjjyddfvnlNd6ylCdOnGjas2ePYfXq1ZErV64s6rh8165dAdu3bzcef/zxpt27dxtcl61ataqwY39Hxmc44Pk7rqc8bWPNmjVh1157bcZrr70Wc/3111fOnj3b3J11jxw5op0/f/6YQ4cO6W+44YbU7OzsA/35PSyEiASA5557rjArK6u1u+s5Pfroo7HffPNNWEZGRvP69esPJCcnWwEgJycnYO7cuePWrFkTc+aZZzZcfvnltT3dNhERERF5p/L3AIiIiIioZ8xms3js8cdS7v3rvV0GTZ3CIsKw7K/LVI89/lhKc3OzGNgR9t3kyZNbrrjiigoA+O6774L9PZ6+CAgIkNOmTWueOHFii7/HMlrl5eVpP/jgw6jFi5cCABYtWio++ODDqPz8fF5I6kf5+flam80mIiMjLQya9lxERIT9pZdeygOABx98MOnw4cNa57Lrr78+pbKyUjt37ty6W265ZUhdLEODLyAgQL788ssFRqPRbrFYxKeffhrire8vf/nLmuDgYNsHH3wQabV2TopctWpVFAD85je/qey00E+uvvrq2mnTpjUCwFdffdXtY4aMjAzLU089VQAA27ZtC8rLy9N2tc5gsVqtePHFF+MA4IUXXshzBk0BYNKkSS0PPvhgIQCsWLEi3l9jJCIiIhqpGDglIiIiGmbefPPN8NTMVKRmpnbd2UVaZhpSM1Lx5ptvhg3MyPpXXFxc2/S9ru3ffPON8aabbko6/vjjx0dGRk7RarXTY2JiJp977rnHff3110ZP27JarfjLX/4SPW3atHHBwcFTtVrt9MjIyCkTJkwYf8MNNyQVFxd3CqDV19er/vznP8cef/zx44OCgqYFBgZOz8zMnHjnnXcm1NXVdfs4+sCBAzohxIzExMRONdaEEDOc9dRWr14dPnXq1HEGg2Ga0WicNnv27LFffvllkLft9tf4RgMl2/TXiIiIBQBERMS2ZZ36eWh9snjx4jQhxIznn38+8qefftLPnz//uKioqClqtXrGI488EgMANTU1qqeeeirqrLPOykhJSTler9dPMxgM08aPHz/hnnvuiWtsbPR4IUVvP5s7d+4MWLRoUVpCQsIkrVY73Wg0TktMTJx09tlnZ6xZsybMdftjx46dBChTZjr3J4SYceDAgbZagfX19ap77rknLisra4Jer5+m1+unjRs3bsKyZcviGhoaOn3O161bFyyEmDFr1qyshoYG1W233ZaQnp4+MTAwcPq4ceMmAMCdd96ZIISYceeddyYcOXJEu3jx4rTo6OjJer1+2oQJE8a//vrr4c7t/d///Z9xzpw5mWFhYVP1ev20E088cey3335r6Lhfp9LSUvVtt92WMHbs2AkGg2Gac5sPP/xwTEtLS6fXujvvoS+LFi2qv+SSSyobGxvVV199dRoAvPHGG2Hr1q2LCA0Ntb3++uucopcAAEFBQTItLa0ZAMrKyrwGCAMCAuQFF1xQXVFRof3444/dAqw2mw1r166NDAkJsV188cW1AzzkHomOjrYAgMVi6dHFYaeeemqT8+fDhw/3qE7pQPr666+DqqurNbGxsZb58+d3mpL96quvrtFoNHL37t2GY8eODZmALxEREdFIwCusiYiIiAbZuux1M/qy/guvvIALL7uwV+ueu+Rc1fOvPH9cwozex4vOn3F+dq9X7oEtW7YYAWDs2LFu9c/+/Oc/J/7888/BGRkZ5ilTpjTpdDr70aNHA7/88svwr776KnzVqlVHr732WrcaZBdffHHaRx99FBkYGGifPn16Y0REhLW6ulqTn58f8I9//CP2kksuqUlISGjL5jhy5Ij2nHPOGXvkyJHA8PBw69SpUxsDAgLsOTk5xmeffTb+s88+C9u0adOB6OhoW38819tvvz3hhRdeiJ8+fXrj3Llz6/bt26f/8ccfgxcsWDD2v//974GzzjqrybX/YI9vMK1bV9Kn34+OqqvLsHbtR3jppfVu7YsWLRW33DIv+owzbo0OD+8yPtVt558fPyi/H642b94c9Mc//jE1Jiam9aSTTmpobGxUGQwGOwD8/PPPhj/+8Y+pERER1vT09ObJkyebqqur1bt27Qr6y1/+kvj555+H/fjjj17rCPfks/nzzz/r582bN66pqUmVnp7ePG/evDohhCwtLdVt2rQppLm5WXX11VfXAkqtQWftw451A0NCQuwAUFJSopkzZ87YQ4cO6UNCQmynnXZaPQD8+OOPwStWrEj8+OOPI7799tsDsbGxnT7nLS0t4uSTT846evRo4AknnNAwYcIEc2trq1tAJS8vTzdr1qwJBoPBduKJJzaWlJRot23bFnTdddcdZ7FYjgYGBsrrrrvuuHHjxplPPfXU+r179+p//vnn4Pnz52f9+OOPeydPnuyWRf7zzz/rzz///DEVFRXa2NhYy4knnthgt9uxc+fOoIceeij5yy+/DPvmm28OBQYGdnqtfb2HXXFO2fv999+HLFu2LG716tWxAPDkk0/mp6amjpopektuuqlfvzsGewzxr7wy4N8dDQ0NagCIjY31+bm44YYbKt96663o119/PWrJkiX1zvaPP/44pLy8XHvFFVdUePoc+0tLS4vYs2ePAQAmTJjQo5qpNTU1aufPgYGBQybzfevWrQYAmDx5cpOn5cHBwfbMzMzm/fv363/66SdDenp63eCOkIiIiGjkYuCUiIiIaJjJPZSLSTM6JS92y6QZk/D8o8/384j6j8ViwdGjR3WrV6+O/OSTTyKDg4Ntd9xxh1t90zvvvLP0xBNPPOo6bR0AvP3226FXXXVVxp133pl60UUX1QUHB9sB4ODBg7qPPvooMi4urvXnn3/e13G9zZs3612DC3a7HUuWLMk4cuRI4JVXXln+0ksvFQYFBUkAaGxsFJdffnnaJ598EvHb3/42ub9qTq5ZsyZmw4YN+0477TQToGT1XH755anvvvtu1AMPPJBw1llnHfLn+IazDz9ciXnzLmrLNnVSsk6X4MMPV+L66x/yz+D6yXvvvRd16623ljz77LPFarXabVlmZmbLJ598cvCXv/xlg+uyyspK9aJFi47buHFjyOOPPx77+OOPl3radk8+m3/9619jm5qaVMuWLSt68skn3bZXV1en2rJli975+MMPP8x11j70VjfwuuuuSzl06JB+xowZjV988cXhqKgoGwBUVFSozznnnDHbt283Xn/99SmffvrpsY7r7tq1yzhu3Djz/v37czr+zjt99NFHkddcc035qlWrCjQa5V/jFStWRC9btizlgQceSDabzapXXnnlmPNCDJvNhgsvvPC4zz77LPyxxx6Le//999uyORsbG8WiRYsyKyoqtPfee2/Rww8/XKrVKklgZWVl6oULFx73ww8/hNx3333xzzzzTHHHsfh6D7sSHh5uX7lyZe7ChQvHrlixIhEAzjrrrNqbb765ukcbohFt69atgUVFRQFarVYuWLCg3lffOXPmmDIzM5u/+uqrsMrKSrXzd+/111+PAoDrr79+SEzTazKZxO7duwMfeuih+MLCwoDx48eblixZ0qMA4rvvvhsOKJm2U6ZM6VHQdSAdO3ZMBwDJyclea6MmJCS07N+/X3/06NEhkylLRERENBJwCi8iIiKiYcZsMkNv0Hfd0QO9UQ9zk7mfR9Q3CxYsGOucolOn080YN27cpKeffjrh1FNPrd+0adO+cePGuZ00XLJkSb2nQMhll11WN3/+/Jq6ujr1Z5991lbjrKSkRAMAEydONHla7+STTzYnJia2tX/wwQchO3bsME6ZMqXptddeK3AGJQFlqsM333wzLyIiwvrJJ59EVFRU9CzC4cXdd99d5AxMAYBarcZf/vKXIgDIzs4Odp3i0x/jG66qq8vwzTdr4axt2tHixUvxzTdrUVNT7nH5cJGent78zDPPeAy4ZWRkWC644IKGjsuioqJsL730Uj4AfPLJJ+GdVnToyWezoqJCAwALFizoFLgIDQ21d8yc9uXgwYO6L774IlylUuHVV1/NdQZuACA6Otq2evXqXJVKhf/+978RrrU9XT3//PN53oKmAJCQkNC6cuXKQmfQFADuuuuuirCwMGtZWZn29NNPr3PNXler1bj33ntLAGDz5s1uU5i+9NJLUUVFRbrzzjuv5oknnmgLmgJAbGys7e23387VaDTy9ddfj7bbOye1+XoPu+NXv/pVw8SJE02Occp//OMf+b3aEI04FRUV6vfffz9kyZIlmXa7HY8++mhBRkZGl5nIl156aWVra6t49dVXIwDlYov//e9/YWPGjDGffvrppq7WHyiu03objcbpJ5544oQvv/wy/Oqrry7fuHHjQdffZ1+OHTumfeyxx2Ief/zxRAC49NJLK1z/nvpbU1OTGgCMRqPXmSOMRqMdaM8kJiIiIqL+wYxTIiIiomFGb9DDbDIjKMRr+UuvzE1m6I29C7oOlFNPPbU+Jiam7SRuVVWVZt++fYaNGzeGLF26NOWdd9451jH4UVJSolm7dm3o7t279XV1dWpnHdQDBw7oHfcBzr6TJ09uNhqN9g0bNoQuW7Ys7tprr60eO3as1wyOzz77LBQALrjgghpPQYyQkBD7pEmTmr799tvQjRs3GhctWuQzc6c7Fi9e3CnQlJycbA0JCbHV19ery8rK1CkpKVZ/jW+48pZt6jRSsk7PPffcWl/BArvdjv/9739B69evDyosLNQ1NzerpJSQUokR5OXlBXhbtyefzRkzZjR9++23oTfffHPqQw89VHzuuec26PX6XgUivvrqqyApJaZOndo0ZcqUlo7LZ8yY0Tx58uSmHTt2GP/3v/8FZ2ZmumVXRkZGWs8++2yfgdqTTz65oeN0oxqNBomJia21tbWac845p9PvzvHHH98CABUVFW7B2i+//DIUAJYsWVLTcR0ASEtLs6SmprYcOXIkcPfu3QEdp/nt6j3sypo1a8KcU5XabDbxr3/9K/xPf/rT8L4igHptwYIFYzu26XQ6uXbt2kOLFy/u1t+E66+/vuqJJ55IfOuttyLvueeeildffTWitbVVXHrppVX9P+LuW7RoUdv+bTabKCsr0+bk5BjfeuutaAB4+eWXCwMCAjx+7zjrNne0YMGC6pUrVxYOzIiJiIiIaLhh4JSIiIhokPW1RujYsWMn5GTn6GfPnd3jdXOyc5A1Nst0/ozz9/VlDP3pnnvuKT3//PMbXNtaWlrE7bffnvDyyy/HnX322WN379691xlU+Otf/xr1wAMPJDc3N3udPaW+vr4tohgeHm5/4YUXcm+99da0FStWJK5YsSIxJibGMn369Mb58+fXXX/99dWu9R2dQaRHH3006dFHH03yNfaysrJ+OZ7OzMz0GMgNCgqy1dfXq81mc9tz9cf4BlN/1QjNy8vTrl///qQXX9wgfPVbvHgpbr11rnz++T/tcgYAh5vU1FSvFwIUFBRoLrzwwszt27cbvfVpbGz0mq3Uk8/mQw89VPbDDz8E//DDD8GLFi0ao9Pp5Lhx40wnn3xywzXXXFM9a9asbqe7FxUVOaep7BQ0dUpJSWnZsWOHsaioqFPGaUJCgtf1nBITEz0+N2dt0ZSUlE7LQ0ND7QDQsV5qfn5+AABce+21x1177bU+91taWqrpGDj19B7ed999cQcOHAjs2N5xWuOSkhLNXXfdlQoAV199dfkbb7wR8/jjjycuXry4tmPG/kjW5xqhq1b1uUbqYNQp7Q7nBUlSSpSXl2u3bt0a3NLSIm688cb0rKys/c4LAHxJSUmxnn766fXr168Pzc7ODvzXv/4VpVar5fXXX+/XwKmnab0rKirUF154YcaaNWti7HY73njjjQJP6zqDrkII6PV6e3p6esuCBQvqTjjhhEGfonfx4sVpHduysrKan3jiiVKgPdPUmXnqSVNTkwoAgoODh109cyIiIqKhbNidSCEiIiIa7W668abSV15/JXX23Nk9LrvwxQdf2H9742891jIcSgICAuSLL75Y9O6770YdOHBA/8EHH4Recskldd9++63hnnvuSVWr1fL+++8vXLx4cW16erolKCjIrlKpcMsttyS+9NJLcVJKt6DGNddcU7NgwYL6d955J2zjxo1BW7ZsCfriiy/Cv/jii/AVK1YkfPvtt/szMzMtgJLBAgAnnHBCo6+gDQAcd9xx/RKU6Mn0nP4Y33D08MOPxM+b92uv2aZOStbpRXj44UcSXn11eE5vqtfrO8/96nDVVVelbd++3Th9+vTG+++/v3jWrFnmyMhIW0BAgGxubhZ6vX66r2335LMZHBxs37x588FvvvnG+Nlnn4X8+OOPQTt27AjatWuX8eWXX4676667ip966qmSHjw1COEz7u1Vx0xST1Qq31+hXS13ZbMpcYszzjijLiIiwmcAPjo6ulOQw9N7+NVXX4Vu2bLF09QCua4PrrvuupTq6mrNueeeW/P6668XWCwW8dZbb0VfffXVaZs3bz7Yk+dBI0PHC5Ly8vK0Z5999phDhw7pL7vssvQdO3bs787n4qqrrqpcv3596B//+Mek3bt3G+bNm1fra/prf4mOjrY9++yzBSeddNKEt956K+aZZ54pjoyM7PR7NpTqfn/00UeRHdtOOOGERmfgNC0trRUACgoKvNYvLSkp0QFAenr6qP1bT0RERDQQGDglIiIiGmauvPLKmvv+dF9q7uFcpGWmdXu93MO5yDuShyuvvLJ2wAbXj9RqdduUmXv37g0EUPfee++FSylxzTXXlD/yyCNlHdc5evSo1ylHo6KibLfeemvVrbfeWgUAe/bsCbjuuutSf/rpp+A77rgj6dNPPz0GtGehLVy4sPree++tGKCn12tDfXxDQV5envaDDz6M6irb1GnRoqXi1lvnRj344APFwzXr1JP6+nrVt99+G6pWq/Hll18edq0TCii/AwOx33nz5jXNmzevCQCam5vFqlWrIu68887UZ555JuGKK66o9jT1bkfOz7kzk9MT57LExMQu6zUOtPj4+Nbc3NzAm266qeKSSy7pNL1xb/z8888Huurz2muvhX/++efh4eHh1ldffTUfAF566aXC9evXh/7000/Bf/3rX6Pvuecefk+McqmpqZb33nvv6KxZsybk5OQYX3755YilS5dWd7XexRdfXHf77bdb169fHwoAV111lV+zTX0ZP358C6BcxLBnz54Af9Zh7Q4ppc/s5BNOOMEEALt27fI4W0BDQ4Pq0KFDegA46aSThvRzJSIiIhpueOkpERER0TCj1+vln//05/zlf1xur62u7dY6tdW1ePKPT9r//Kc/53cnE2sosNlsbdN1BgUF2QGgpqZGAwDJycmdsiuKi4s1mzZtCunu9idOnNhy7733lgDAvn37DM72+fPn1wHAv//974i+PYOBMdTHNxR0N9vUyTXrdICHNqiqq6vVdrsdBoPB1jFoCgBr1qzplPHU3wIDA+Vtt91WNWXKlCYpJbKzsw1drwWcddZZjUII7Ny507hr165OwdNt27YF7tq1y6hSqXD22Wc3eNrGYPrFL35RDwBr164NH6x9FhcXa/7whz+kAMBTTz2Vn5CQYAWU6YRffPHFPAB45JFHkg4ePOg1Y41Gj2nTpjVfccUVFQCwfPnyBIul6+sNAgMD5SWXXFIZFhZmTUlJabn44ov75aKAgbBv376274ng4GCvWfjDxZlnntkYHh5uLSsr037++eedMs/XrFkTbrVaxfHHH29KT0/3+8UjRERERCMJA6dEREREw9Add9xRdfGvLy5bdt0ye+7hXJ99cw/n4p7r7rFf8utLyu64444hmy3iymKx4JZbbkmsra3VaDQaeeGFF9YBSv0vAHj33Xcj6+rq2o5la2pqVJdffnlaQ0NDp3lFv//+e/3q1avDGxsbO2UffvLJJ2EAkJiY2JYBd/nll9dOnDjRtGXLlqDLLrsspaysrNM28/PzNU8//XRUvzzZHhrq4/M3Z7bpokVLezTH66JFS8UHH3wYlZ+fP2Jm5UlKSrKEhITYGhoa1C+//LJboP2DDz4IWb16dfciy920fPny6J07d3YKcu7du1d3+PBhPQCkp6d3mW0KAGPHjm0955xzaux2O2644YbUqqqqts95ZWWl+sYbb0y12+0477zzqp3TbPvTHXfcUREXF9f60UcfRd55550JDQ0Nnf7X3r9/v27lypX9dsHDtddem1JTU6OZP39+zbXXXlvjumzhwoX1F198caXJZFJdc801qf21TxreHnvssRKj0WgvKCgIWLlyZbcunPj73/9eVFNTszMvL293QEDAkLzwqqKiQn377bcnA0BqamrLtGnTBr1maX/TaDS45ZZbSgHg1ltvTS0qKmr725STkxPwyCOPJALAPffc06Ppz4mIiIioayPmpAARERHRaPP0U08XJyUmtTz4uwdTUjNSce6Sc1WTZkyC3qiHucmMnOwcfL72c3v+0Xz8+U9/zh+qQdMVK1bEvf76620ncKurqzV79+41lJeXa1UqFR577LGCrKysVgD43e9+V/nKK6/E7N2715Cenj5p5syZjVJKbNmyJVir1dovuuiiyrVr17oFDI8ePRpw4403HnfbbbfZJ0yYYEpISGi1WCxiz549hsLCwgCj0Wh/9NFHi5391Wo1Pvnkk8Pz588f884770T/5z//iczKyjIlJCS0trS0qI4dOxZ45MiRwIiICOtdd91VOXiv1PAYn7/1NNvUaSTUOu1Io9Hg9ttvL3nkkUeSbr755vRXXnklJikpqSUvLy8gJyfHeMstt5S++OKLcf21vzVr1kTfe++9KUlJSS1jx441G41Ge0VFhTY7OzvIYrGI888/v3ru3LndnlLytddey58zZ07gzz//HJyRkTHpxBNPbACAH3/8Mbi+vl6dlZVl/sc/hsZ7FRoaav/kk08O/+pXv8p89tln41977bWYrKwsU2xsrKWxsVF95MiRwPz8/IDJkyc3dWeK1K6sXr06/MsvvwwPDw+3ensNVq5cWbBhw4bQzZs3hzz99NNRnr4P/vrXv8a/+uqr0d7289JLL+WfeuqpnAZ0hEhISLD+9re/LX366acTnnrqqfilS5dWabVafw+rRxYvXpzm/Nlms4ny8nLtrl27jE1NTarg4GDba6+9dsyPw+tXDzzwQNmmTZuC169fHzpu3LjjZ8+e3WC1WsXmzZtDWlpaxFVXXVV++eWX1/p7nEREREQjDQOnRERERMPYHXfcUfXb3/62+s033wxftXpV7POPPm8wN5lhMBrk2LFjzTffeHPplVdeWTuUp+ftOL2uTqeTMTExrQsXLqy64447yk877bS2k/bR0dG2rVu37vvjH/+Y+N1334Vs2LAhNCIiwnruuefWrFixovi5557rFACYM2dO47333lu0adOm4CNHjgTu3bvXoNFoZHx8fOsNN9xQ9oc//KF87NixblP/ZmRkWHbs2LHvueeei/roo48iDh48qN+1a5cxLCzMGhsba7nhhhvKlixZUtNxX4NlqI/Pn7Zv32HcsWOb+OST1b1ZXUydOt1jPbnh6uGHHy5LT09v+dvf/hZ3+PDhwEOHDunHjBljXrly5bGbb765uj8Dpw8++GDRp59+Grp9+/agbdu2BTU1NakjIyMtJ5xwQsN1111XedVVV/XoMxkfH2/dsmXL/scffzz2448/Dv/uu+9CACAlJaXl5ptvrr7vvvvKQ0JChsyUnLNmzTLn5OTsfeqpp6L/+9//hu3du9ewfft2VXh4uDU+Pr514cKF1Zdeemmffy+Lioo0d999d6cpejuKiIiwP//887kXX3zxmIceeijpwgsvrOuYnVtYWBhQWFjotY5sbW1tp4z2kSohJsaasGpVr8+RJMTEDIv6yPfff3/ZmjVrYgoLCwNefPHFqDvuuGNYXWDz0UcfuWXKGgwGe1JSUsvcuXPrly1bVpaWlub3DPT+otFo8L///e/wihUrot96662ojRs3hqjVakycOLHphhtuqPjtb3/b54swiIiIiKgzIeWQPYdGRERENKzt3Lkzd8qUKYN6QnJd9roZAHD+jPOzB3O/RMPBunUlyu/H+fH8/SCibiu56aYZABD/yiv87qBhbefOnVFTpkxJ8/c4iIiIiIYy1jglIiIiIiIiIiIiIiIiolGPGadEREREA6S/M073FOxJOFZ+LL6/tpcek14yMXlicdc9iYa+PXvqE44da+q/3490Y8nEiSH8/SAa4erffz+h6euv++27w3jmmSUhv/41vztoSGLGKREREVHXGDglIiIiGiD+mKqXiIiIiMgTBk6JiIiIusapeomIiIiIiIiIiIiIiIho1GPglIiIiIiIiIiIiIiIiIhGPQZOiYiIiIiIiIiIiIiIiGjUY+CUiIiIaACxnjwRERER+RuPSYmIiIi6h4FTIiIi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DuBbKeUZfdzWaigH1O9JKS/p++iIiIiIiIiIiIiIiMgTZpwSEQ1RjrqozmDpKl99iYiIiIiIiIiIiIiobxg4JSIagoQQOijF1oOgFFL/potViIiIiIiIiIiIiIioDzT+HgAREbUTQiyBUhw9CkqdAwngLr8OioiIiIiIiIiIiIhoFGDGKRHR0BIEpcC7BsB2AIuklF/5d0hERERERERERERERCOfkFL6ewzDTlRUlExLSxuw7Tc1NcFoNA7Y9sm/+P7SSMHPMo0UA/1Zzs7OrpRSRg/YDqjPBvLYjt+V/sXXn0YrfvZptOJxHfGcHfUW39uRi+/tyMb3d+Ty53Edp+rthbS0NGzdunXAtr9hwwacccYZA7Z98i++vzRS8LNMI8VAf5aFEHkDtnHqFwN5bMfvSv/i60+jFT/7NFrxuI54zo56i+/tyMX3dmTj+zty+fO4jlP1EhEREREREREREREREdGox8ApEREREREREREREREREY16DJwSERERERERERERERER0ajHwCkRERERERERERERERERjXoMnBIRERERERERERERERHRqMfAKRERERERERERERERERGNegycEhEREREREREREREREdGox8ApERERERERERERjXqpiYkQQnS6GYwGaHVazJs3D1qdFgajwWO/1MREfz8F6oWSkhLcffc9KC0t9fdQqJ/xvSWi3tD4ewBEREREREREREQ09AkhsgCcC+AEADMBjAUgAFwkpfygD9u9DMDNACYDUAPYD+B1AH+XUtr7Ou7uyi8uRvGNNwIA3jlwAE9sy0ZqZhrOvewCTJoxCXqDHmaTGTnZOfj8rU+QfyQP902fgUuzsgAACatWDdZQqR8tX74C+/YdwPLlK/C3vz3r7+FQD6UmJiK/uNjjMo1Gh8BAPZKTU2G1tnrsk5KQgLyiooEcIhENMwycEhERERERERERUXfcDOD3/blBIcRLAJYCaAbwNQALgDMBvAjgTCHEksEMngLA0zu2492CPDy0+kmkZaa5LQsKCcLsubMxe+5s5B7OxfI7HkWx2YS7pk4bzCFSPykpKcEbb7yBxx57Hw8+eAmWLbsHcXFx/h4W9YDrBQ+uykwmzPnw33jksffx4H2L8e0lv0aMwdCpHy94IKKOOFUvERERERERERERdcduAH8FcDGATADf9mVjQojFUIKmpQAmSynP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EyciGn25umnt+nXIGHPDrNP2frXrFRERERGR9SvXn8u92+4l4As44ufbz2vSj0iWUOFU1rSakhrHH6F4Ms71vusuZiQiIrdSX5/Hxo3Ojq5dXeNcvBh1KSNZKq1dv37VlTrXnO8d6mUsNuZSNiIiIiIiIu4rCBRw79Z78Xl9jvipa6c02FQkC6hwKmuax+OhvsJ5v7W5p1mzlkREspgxhl27iiku9jviFy5E6epSwWW10tr161MwN0hRXpEj1hHucCkbERERERGR7FCUX8RbtrwFj3GWaI43H6dnsMelrEQEVDiVdaChvAGDyexHx6L0DfW5mJGIiNyK12toagqRk+O8VDlxIsLwsFqur1Zau359UrteERERERGRG5UGSzlwxwHHvWtrLUcuHyEcDbuYmcj6psKprHm5OblUh6odseaeZneSERGRecvL87J/f4kjFotZjhwJE4/fUGcTkSxVG3IWTsPDYUYnRl3KRkREREREJHtUFVexp3GPI5ZIJnjt0msMjQ65lJXI+qbCqawLjRWNjv3OSKdu2ImIrALl5QF27ix0xIaG4rzxxoDarousEvmBfEIFIUdMs05FRERERERSNpRt4K6NdzlisUSMVy6+wsj4iEtZiaxfKpzKulAaLKUwz3njvaWnxaVsRERkITZvLqC2NtcRa28f4+rVYZcyEpGFuqFdb1iFUxERERERkUmbKjextWarIzYeG+fVi68yHht3KSuR9UmFU1kXjDE3zDq91nuNRDLhTkIiIjJvxhh27y6msNDniJ89O0Rvrz48iKwGNaEax/7AyADRsahL2YiIiIiIiGSfbTXbaKhocMSGx4d59eKrxBIxl7ISWX9UOJV1o660Dp936qb7RHyCjnCHixmJiMh8+XweDhwI4fOZTMxaOHYswuioBsGIZLtcfy5lhWWOmNr1ioiIiIiITDHGsGvjLmpDzo49g6ODvH7pdU0CErlNVDiVdcPn9bGxbKMj1tzT7E4yIiKyYMGgj337ShyxiYkkR4+GSSS03qlItpv54b893K61ikVERERERKYxxrC3cS8VRRWOeH+0n2NXjpG0SZcyE1k/VDiVdWVmq4PIcITIcMSdZEREZMGqqnLZti3oiEUiMU6fHnApIxGZr5pQDYapWePRsShDo0MuZiQiIiIiIpJ9PB4PBzYfoKSgxBHvGujijZY3NABVZIWp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",
      "text/plain": [
       "<Figure size 2304x432 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axs = plt.subplots(1, 3, figsize=(32, 6))\n",
    "letters = ('a', 'b', 'c')\n",
    "for i, (plot_df, name, letter) in enumerate(zip([copy, reverse, retrieval], ['Copy', 'Reverse', 'Associative retrieval'], letters)):\n",
    "\n",
    "    fontdict = {'fontsize': 24}\n",
    "    # fontsize = 28\n",
    "    legsize = 22\n",
    "\n",
    "    mt = plot_df[plot_df.num_mem_tokens > 0]\n",
    "    xl = plot_df[plot_df.mem_len > 0]\n",
    "    bl = plot_df[(plot_df.num_mem_tokens == 0) & (plot_df.mem_len == 0)]\n",
    "    mt = pd.concat((mt, bl[bl.n_chunks == 1]))\n",
    "    xl = pd.concat((xl, bl[bl.n_chunks == 1]))\n",
    "\n",
    "\n",
    "\n",
    "    markers = ['s', '^', 'o'][::-1]\n",
    "    dfs = [mt, xl, bl][::-1]\n",
    "    zorders = [100, 50, 0]\n",
    "    colors = [(0.7, 0.8, 0.7), (0.7, 0.7, 0.9), (0.9, 0.4, 0.4)]\n",
    "    for z, d, m, c in zip(zorders, dfs, markers, colors): \n",
    "        # d = d[(d.mem_len != 6) & (d.num_mem_tokens != 6)]   \n",
    "        d = d[(d.mem_size == d.tgt_len) | (d.mem_size == 0)]\n",
    "        gd = d.groupby('n_chunks').agg({'test acc': tuple})\n",
    "        gd['mean'] = d.groupby('n_chunks').mean()['test acc']\n",
    "        gd['std'] = d.groupby('n_chunks').std()['test acc']\n",
    "        gd = gd.reset_index()\n",
    "\n",
    "        axs[i].errorbar(gd.n_chunks, gd['mean'], gd['std'], lw=4, color=c, marker=m, markeredgecolor='k', markersize=16, capsize=10, elinewidth=2, zorder=z)\n",
    "\n",
    "    # axs[i].legend(['Baseline', 'Transformer-XL', 'RMT'], fontsize=legsize)\n",
    "\n",
    "    # for z, d, m, c in zip(zorders, dfs, markers, colors):    \n",
    "    #     d = d[(d.mem_len == 6) | (d.num_mem_tokens == 6)]\n",
    "    #     gd = d.groupby('n_chunks').agg({'test acc': tuple})\n",
    "    #     gd['mean'] = d.groupby('n_chunks').mean()['test acc']\n",
    "    #     gd['std'] = d.groupby('n_chunks').std()['test acc']\n",
    "    #     gd = gd.reset_index()\n",
    "\n",
    "    #     axs[i].errorbar(gd.n_chunks, gd['mean'], gd['std'], lw=4, color=c, marker=m, markeredgecolor='k', markersize=8, capsize=10, elinewidth=2, zorder=z)\n",
    "\n",
    "    axs[i].set_xlabel(f'Number of segments\\n({letter})', fontdict=fontdict)\n",
    "    \n",
    "    ticks = np.unique(mt.n_chunks.astype(int))\n",
    "    axs[i].set_xticks(ticks)\n",
    "    axs[i].set_xticklabels(ticks)\n",
    "    axs[i].set_title(name, fontdict=fontdict)\n",
    "    axs[i].grid()\n",
    "    axs[i].tick_params(labelsize=22)\n",
    "    \n",
    "\n",
    "axs[1].get_shared_x_axes().join(axs[0], axs[1])\n",
    "fig.legend(['Baseline', 'Transformer-XL', 'RMT BPTT-0'], fontsize=legsize, loc='upper center', bbox_to_anchor=(0.5, 1.15), ncol=3, fancybox=True)\n",
    "axs[0].set_ylabel('Accuracy', fontdict=fontdict)\n",
    "# plt.tight_layout()\n",
    "# plt.savefig(f'../../Memory transformer/_figures_paper/res_combined.png', format='png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "fig, axs = plt.subplots(2, 1, figsize=(12, 12))\n",
    "letters = ('a', 'b', 'c')\n",
    "for i, (plot_df, name, letter) in enumerate(zip([copy, reverse], ['Copy', 'Reverse'], letters)):\n",
    "\n",
    "    plot_df = plot_df[(plot_df.mem_size < plot_df.tgt_len) | (plot_df.mem_size == 0)]\n",
    "\n",
    "    fontdict = {'fontsize': 24}\n",
    "    # fontsize = 28\n",
    "    legsize = 22\n",
    "\n",
    "    mt = plot_df[plot_df.num_mem_tokens > 0]\n",
    "    xl = plot_df[plot_df.mem_len > 0]\n",
    "    bl = plot_df[(plot_df.num_mem_tokens == 0) & (plot_df.mem_len == 0)]\n",
    "    mt = pd.concat((mt, bl[bl.n_chunks == 1]))\n",
    "    xl = pd.concat((xl, bl[bl.n_chunks == 1]))\n",
    "\n",
    "\n",
    "\n",
    "    markers = ['^', 's']\n",
    "    dfs = [xl, mt]\n",
    "    zorders = [50, 0]\n",
    "    colors = [ (0.7, 0.7, 0.9), (0.9, 0.4, 0.4)]\n",
    "    for z, d, m, c in zip(zorders, dfs, markers, colors): \n",
    "        gd = d.groupby('n_chunks').agg({'test acc': tuple})\n",
    "        gd['mean'] = d.groupby('n_chunks').mean()['test acc']\n",
    "        gd['std'] = d.groupby('n_chunks').std()['test acc']\n",
    "        gd = gd.reset_index()\n",
    "\n",
    "        axs[i].errorbar(gd.n_chunks, gd['mean'], gd['std'], lw=4, color=c, marker=m, markeredgecolor='k', markersize=16, capsize=10, elinewidth=2, zorder=z)\n",
    "\n",
    "    # axs[i].legend(['Baseline', 'Transformer-XL', 'RMT'], fontsize=legsize)\n",
    "\n",
    "    # for z, d, m, c in zip(zorders, dfs, markers, colors):    \n",
    "    #     d = d[(d.mem_len == 6) | (d.num_mem_tokens == 6)]\n",
    "    #     gd = d.groupby('n_chunks').agg({'test acc': tuple})\n",
    "    #     gd['mean'] = d.groupby('n_chunks').mean()['test acc']\n",
    "    #     gd['std'] = d.groupby('n_chunks').std()['test acc']\n",
    "    #     gd = gd.reset_index()\n",
    "\n",
    "    #     axs[i].errorbar(gd.n_chunks, gd['mean'], gd['std'], lw=4, color=c, marker=m, markeredgecolor='k', markersize=8, capsize=10, elinewidth=2, zorder=z)\n",
    "\n",
    "    \n",
    "    \n",
    "    ticks = np.unique(mt.n_chunks.astype(int))\n",
    "    axs[i].set_xticks(ticks)\n",
    "    axs[i].set_xticklabels(ticks)\n",
    "    axs[i].set_title(name, fontdict=fontdict)\n",
    "    axs[i].grid()\n",
    "    axs[i].tick_params(labelsize=22)\n",
    "    axs[i].set_ylabel('Accuracy', fontdict=fontdict)\n",
    "    \n",
    "\n",
    "axs[0].set_xlabel('(a)', fontdict=fontdict)\n",
    "axs[-1].set_xlabel('Number of segments\\n(b)', fontdict=fontdict)\n",
    "# axs[1].get_shared_y_axes().join(axs[0], axs[1])\n",
    "fig.legend(['Transformer-XL', 'RMT BPTT-0'], fontsize=legsize, loc='upper center', bbox_to_anchor=(0.5, 1.05), ncol=3, fancybox=True)\n",
    "\n",
    "plt.tight_layout()\n",
    "# plt.savefig(f'../../Memory transformer/_figures_paper/res_combined.png', format='png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABDAAAAHTCAYAAADRfOidAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAACMNElEQVR4nOzdeXxcdb3/8fcn+2SStEnapE2TJqGlLS1QStlEBNqCyBWutgVBL/5AQRQErstV0HuVRVBQRHaxCBQveEXAi4oiF2iLICB7WUoXaJKm2Zo2abPv398f5wwNySRN0iQzSV7Px2MeJ3PO95zzmWQy5zuf813MOScAAAAAAIBoFhPpAAAAAAAAAPaFBAYAAAAAAIh6JDAAAAAAAEDUI4EBAAAAAACiHgkMAAAAAAAQ9eIiHQAA9Oe1114zSUvi4uLONLNPOOdSIh0TAADjjDOznZ2dnQ90dXXdv3jx4t2RDggAwjGmUQUQrV577TWLiYm5PBAIXDB16lSXlpbWEBcX12lmkQ4NAIBxwzmnlpaWhOrq6tTa2tq3Ojo6zly8eHFbpOMCgJ7oQgIgmi0JBAIXzJ49uy4zM3NPfHw8yQsAAIaZmSkQCLTl5eXtSktLO0TS2ZGOCQDCIYEBIGrFxcWdOXXqVBcXF9cV6VgAABjvzEwZGRlt8fHx/xLpWAAgHBIYAKKWmX0iLS2tIdJxAAAwUQSDwWZJh0Y6DgAIhwQGgKjlnEuJi4vrjHQcAABMFLGxsZ3OueRIxwEA4TALCYCoNtxjXrz7bl1OUVHj9OE6XmFhsGLBgrTy4ToegOhU9/vf5zQ+88ywfXYEly2rSPvc5/jsQNRhrCkA0YxZSABErfXr1xcvXLhw52if9/HHKxZL0mmnTX9ttM8NYOyq+OpXF0vS9F/9is8OjGnr16+fsnDhwoJIxwEAPdGFBAAAAAAARD26kABADzU1Vbrllm/q0EPvj5s5c2ZHpOMBED1mZGcvLN+xo//606pVi/valJOV1VFWVbV+2AMDAGACIIEBAD08+uid2rz5TV199TU599zz622RjiccM+vzC1JfVqxYsevRRx8tHoFwRkV1dXXsN77xjRlr1qyZVF1dHd/Z2WnLli3b/fTTT38Q6dii2aOPPpp2xhlnHJiSktL55ptvvjtr1qz2cOWWL19e8Nhjj2WecMIJe9atW/d+aP1RRx0195VXXkm55ZZbii+77LJdoxd5dCrfsSOu/MILh7x/zqpVUVH3mjFjxiHl5eUJ3dclJCS4jIyM9kWLFjV+/etf3/HpT3867CxQK1euLPjDH/6QKUmHHnpo4/r16zf2dZ6bbrppyre//e380HPn3Gt9nX9fjjzyyIaXX355U39lNm3alDBv3rxDeq6PjY1VWlpax4IFC5ouuOCC6nPPPXf3QPcNBAJdubm5rUuWLKn7z//8z8pQYnson8M5OTltg33dOTk5bWVlZW/vq1xnZ6d++tOfTn3wwQenbN26NSk2NtbNmTOn+cILL6z+6le/WjPYWAEgGkXFRRQAokVJSUn8mjUP69prH9IPf3jWlCuv/GF5NLbCWLFiRa8vkjt27Ih//vnn0wKBQNepp55a23P7xz/+8TE9Je0Xv/jF/CeffDJ9xowZbaeeemptQkKCW7RoUVOk44p2K1eurDvrrLN2PvTQQ1O+9KUvFfz973/f0rPMgw8+OOmxxx7LTE1N7Vy9enVJJOJEZBx33HF1WVlZ7ZK0e/fu2A0bNiQ/8cQT6U888UT6VVddVXrllVfu6G//t956K/jGG28kLVq0qCXc9gceeGBKuPWf/vSna3ft2vWRemhjY2PMk08+mS6F/4ybO3du2HP0pfsxWlpaYrZu3Zr0/PPPpz3//PNpf//733fcc889pQPZt7y8PGH9+vXBVatWZT/88MOZTz/99KbDDz+8ZSifw7NmzWr94IMPEnuuDyWETjnllNpgMNjVfVtmZuY+r0EdHR065ZRTZq1Zs2ZySkpK53HHHVfX1tZmL774YtrXvva1lJdeeil433339fl6AWCsYBBPAFErEoN4fvnL58/ctSt26le+crV+/esrXWZm185obYXR0+OPP556+umnzxno3bqxpLW11YLB4KK4uDiVl5e/mZGR0bXvvRBSU1MTs2DBggWVlZUJP//5z0u+9a1vffh/VVVVFXvwwQcv2LlzZ/xtt91WfMkll3zkSxktMD7KzBbvZwuMD1shRFKoBcSf//znzaeddlp9aH1ra6udf/75eQ8++ODU+Ph49957773ds9VOqAXGggULmt59993kiy66qPLOO+8s63mOt956K3HhwoUHH3zwwU3vvPNOsqR+X3v3FhBD/R3t6xirV6+e/OUvf3mWc04vvPDCho997GPNA9n3gw8+iD/11FMP3LJlS+Dwww9veO2118K2BBnq53CoNcfGjRvfnjt3bttA9wu58sors6+55prcWbNmtaxdu3ZTXl5ehyS9/fbbiUuWLJm3a9euuP/+7//+4Jxzztk9kOMxiCeAaMUgngDgKykpiX/kkUenrFx5sSRpxYqL7ZFHHp2ybds2WqtF2LZt2+I7OzstMzOzneTF4GVkZHTdcccdJZJ05ZVX5r7//vvxoW0XXHDBzJ07d8YvWbJkT8/kBSaexMREd9ddd5UGg8Gu9vZ2+/Of/5zWV9lPf/rTtampqZ2PPPJIZkdH70YCq1atmiJJ//Zv/zbqs0n15bzzztu9aNGiBkl6+umnUwe636xZs9pvvPHGUkl6/fXXU0pKSuL3tc9o6ejo0O233z5Nkm677baSUPJCkg455JDWK6+8crsk3XDDDcM2DTAARAoJDADwXX31NdOXLv2cMjKyJUkZGdlasuRMXX31NTkRDm2/rVy5ssDMFt96662Z//znPwOnnnrqAVOmTFkYGxu7+JprrsmSpNra2pgbb7xxykknnTRr5syZBwcCgUXJycmLDjrooPmXX375tIaGBgt3bDNbHLp7ePfdd6cfdthh85KTkxcFg8FFH/vYx+Y8+eSTKeH2W79+feKKFSsKcnJyDomPjz88GAwumjFjxiEnn3zyrNWrV0/ufvw5c+YcInlNuUPnM7PFmzZt+rAveV1dXczll18+be7cufMDgcCiQCCwaN68efOvuOKKafX19b2ud48//niqmS0+6qij5tbX18dcdtllOYWFhQuSkpIOnzdv3nxJ+ta3vpVjZou/9a1v5XzwwQfxK1euLJg6deqhgUBg0fz58w+677770kPH+7//+7/gCSecMHvy5MmHBQKBRUcfffScZ599Nrmvv0llZWXsZZddljNnzpz5ycnJi0LHvPrqq7NaW1t7/a4H8jfsz4oVK+rOPvvsnQ0NDbHnnXdegSTdf//9kx9//PGMSZMmdd533310HYEkKSUlxRUUFLRIUlVVVZ9f1BMTE92//uu/1lRXV8c/9thjH0l0dHZ26uGHH85MS0vrPOuss3aPcMiDMnXq1HZJam9vD/uZ1pfjjjuuMfTz+++/P6hxLEbSM888k1JTUxOXnZ3dfuqpp/bqKnjeeefVxsXFuXfeeSe5qKgoahIvADAU3FUEMCY9/njFoAdP609NTZUefvgPuuOOtR9Zv2LFxXbJJUunnnjipVPT0/f5HXHATjttekSakL/wwgsp3/nOd/KzsrLajjnmmPqGhoaY5OTkLkl6+eWXk7/zne/kZ2RkdBQWFrYceuihTTU1NbFvvfVWyk9/+tMZTzzxxOSXXnppU3Jycti+h9/4xjdybrvttumHH354w5IlS/a89957gZdeein19NNPn/PXv/5100knnfRh5f/ll18OLF26dF5jY2NMYWFhy9KlS/eYmausrEx4/vnn01paWmLOO++83ZLXFz3UN75nv/K0tLQuSaqoqIg74YQT5mzZsiWQlpbW+YlPfKJOkl566aXUG264YcZjjz2W8eyzz27Kzs7u7Bl3a2urHXvssXO3bt2adOSRR9bPnz+/ua2t7SNfbEpKShKOOuqo+cnJyZ1HH310Q0VFRfzrr7+ecv755x/Q3t6+NSkpyZ1//vkHzJs3r/m4446r27BhQ+Dll19OPfXUU+e+9NJLGw499NDW7sd7+eWXA6eddtqB1dXV8dnZ2e1HH310fVdXl9avX59y1VVX5T355JOT16xZsyUpKanX77q/v+G+3HnnnaXPPvts2j/+8Y+0K664Ytrdd9+dLUk/+clPtuXn54cd3HO8qfjqV4f1s2O0Y5j+q1+NymdHfX19rCRlZ2f3+774yle+svPBBx+cet99900544wz6kLrH3vssbQdO3bEf/GLX6wO9z6OlNbWVnv33XeTJWn+/PmDGlOjtrY2NvRzUlJS1LQEe/XVV5Mlb0DVcNtTU1O7Zs+e3bJx48bAP//5z+TCwsI9oxshAAwfEhgAIG/mkaVLz/yw9UWI1wrjDD366J264IKrIhPcMHrooYemXHrppRW/+MUvymNjYz+ybfbs2a1//OMfN3/605+u775t586dsStWrDjgueeeS7vuuuuyr7vuuspwx169enXWunXr3vvEJz7RJHl3YM8555z83/3ud1N++MMf5px00kkfDh75s5/9LLuxsTHmiiuuKPvJT37ykePt2bMn5pVXXgmEnj/66KPFft/09PT09I5wM6mcf/75M7ds2RJYvHhxw9/+9rf3p0yZ0il5M5eccsopB77xxhvBCy64YOaf//znop77vvXWW8F58+Y1b9y48e3uTa+7+8Mf/pD5pS99aceqVatK4+K8S+cNN9ww9Yorrpj5wx/+MK+5uTnmV7/6VdGXv/zl2tBr/8xnPnPAX/7yl/Rrr7122u9///sPWzc0NDTYihUrZldXV8d/73vfK7v66qsr4+O9m6JVVVWxy5cvP+DFF19M+/73vz/9pptuKu8ZS39/w31JT0/vuvPOO4uXL18+54YbbpghSSeddNLuiy66iBkK8KFXX301qaysLDE+Pt6dfvrpdf2VPeGEE5pmz57d8vTTT0/euXNnbOh/77777psiSRdccEFUdB9pamqyd955J+mqq66avn379sSDDjqo6YwzzhjUF/nf/e536ZLX8mThwoWDSn6MpKKiogRJysvL63PsjJycnNaNGzcGtm7dGjUtRwBgKOhCAmDCq6mp0po1Dys09kVPK1derDVrHlZtbb+D8Y8JhYWFLTfddFPYL76zZs1q/9d//df6ntumTJnSeccdd2yTpD/+8Y/pvXb0ffe73y0LJS8kb9rCn/70p2WS9Nprr6V27xZRXV0dJ0mnn356ry8QkyZN6ureWmNfNm/enPC3v/0tPSYmRvfcc09x6AuUJE2dOrXz7rvvLo6JidFf//rXjO5jP3R36623lvSVvJC8aQzvvPPO7aHkhSR9+9vfrp48eXJHVVVV/PHHH78nlLwIvfbvfe97FZL0wgsvfKRp/R133DGlrKws4V/+5V9qf/zjH3+YvJCk7Ozszt/+9rfFcXFx7r777pva1dX7Jm9/f8OB+OxnP1u/YMGCJj9O9+tfj41BajHyqqurY3//+9+nnXHGGbO7urr0ox/9qLSvaXe7+/znP7+zra3N7rnnngzJS3o+9dRTkw888MDm448/PmIzBXXvbhYMBg8/+uij5z/55JPp55133o7nnntuc/f/5/4UFRXFX3vttVnXXXfdDEn6/Oc/X52SkhI1rUoaGxtjJSkYDPZqYRYSmtkk1LIGAMYqWmAAmPD6an0RMp5aYXzqU5/a3V+lvaurS0899VTK2rVrU7Zv357Q0tIS45xTaMaqkpKSXtP/haxcubJXMiIvL68jLS2ts66uLraqqio2NCXt4sWLG5999tlJF110Uf5VV11V/qlPfao+EAgM6QvB008/neKc02GHHda4cOHC1p7bFy9e3HLooYc2vvnmm8Gnnnoqdfbs2R9pbZCZmdlx8skn95swOfbYY+t7NoOPi4vTjBkz2nbv3h13yimn9LpLffDBB7dKUnV19UeSJk8++eQkSTrjjDN6TbEoSQUFBe35+fmtH3zwQdI777yT2LP7yb7+hvuyevXqyaEm9J2dnfbAAw+k/+d//ufYz85hSE4//fQ5PdclJCS4hx9+eMvKlSv7bX0RcsEFF+z68Y9/POPBBx/MvPzyy6vvueeejLa2Nvv85z8f0UFhu09z2tnZaVVVVfFvv/128MEHH5wqSXfdddf2xMTEsJ87oXF9ejr99NNr7rzzzu0jEzEAYF9IYAAYk4ZrDImSkpL4tWt/f8jtt6/rdzC3lSsv1qWXLnG33vqfb4W+hI9F+fn5fTYxLi0tjfvMZz4z+4033gj2VaahoaHPu3ezZ88Oe+yUlJTOurq62Obm5g9b/V111VVVL774YuqLL76YumLFigMTEhLcvHnzmo499tj6L33pSzVHHXVUc7hjhVNWVhZqPt0reREyc+bM1jfffDNYVlbWqwVGTk5On/uFzJgxI+xrC409MXPmzF7bJ02a1CVJPcfT2LZtW6IkffnLXz7gy1/+cr/nraysjOuZwAj3N/z+978/bdOmTUk91/fsblNRURH37W9/O1+SzjvvvB33339/1nXXXTdj5cqVu+fNmzfoqRvHov0eQ2LVqv0eQ2O0xrEYiOOOO64uKyur3TmnHTt2xL/66qupra2tduGFFxbOnTt3YygR15+ZM2d2HH/88XVr166d9NprryU98MADU2JjY90FF1wQ0QRGuO5m1dXVsZ/5zGdmrV69Oqurq0v3339/abh9Q8kPM1MgEOgqLCxsPf300/cceeSRo951ZOXKlQU9182dO7flxz/+caW0t+VFqCVGOI2NjTGSlJqa2mcrDQAYC0hgAJjQes480pfuM5Lcc8/YbXIfCAT6HHju3HPPLXjjjTeChx9+eMMPfvCD8qOOOqo5MzOzMzEx0bW0tFggEDi8v2MPpktDampq1wsvvLB5zZo1wb/85S9pL730Usqbb76Z8tZbbwXvuuuuad/+9rfLb7zxxopBvDSZDWpCgQ8NZIDBmJj+e1zua3t3nZ3e94cTTzxxT0ZGRr/JsKlTp/b6shHub/j0009PeuWVV8LN9lLc/cn5558/s6amJu5Tn/pU7X333Vfa3t5uDz744NTzzjuv4IUXXtg8mNeB8eHyyy+vPO200+pDz0tKSuJPPvnkA7ds2RL4whe+UPjmm29uHMj74txzz925du3aSd/5zndy33nnneSlS5fu7q9bVqRMnTq18xe/+EXpMcccM//BBx/Muummm8ozMzN7/Z+FS35Eyh/+8IfMnuuOPPLIhlACo6CgoE2SSktL+xzfoqKiIkGSCgsLJ0SiEsD4RQIDwIRVUlIS/8gjj07ZV+uLkBUrLrZLL10y5corf1g+llthhFNXVxfz7LPPToqNjdWTTz75fvdxJCTp3Xff7bPryP5YunRp49KlSxslqaWlxVatWpXxrW99K/+mm27K+eIXv1gTrktIT6HWEaGWDeGEts2YMSPiM21Mnz69rbi4OOmrX/1q9dlnnz0sswG8/PLLm/ZV5t57701/4okn0tPT0zvuueeebZJ0xx13bF+7du2kf/7zn6k/+9nPpl5++eXVwxEPxq78/Pz2hx56aOtRRx01/+233w7eddddGRdffPE+B3k966yz9nzjG9/oWLt27SRJOvfccyPa+qI/Bx10UKvkJRPffffdxEiO0zEQzrl+W+wceeSRTZI3IHG47fX19TFbtmwJSNIxxxwT1a8VAPaFWy0AJqyBtr4I6d4KY4RDG3U1NTWxXV1dSk5O7uyZvJCk1atX97oDONySkpLcZZddtmvhwoWNzjm99tpryQPZ76STTmowM61fvz741ltv9UpivP7660lvvfVWMCYmRieffHJ9uGOMpk9+8pN1kvTwww/3OSDqcCsvL4/7j//4j5mSdOONN27LycnpkLxuLrfffnuJJF1zzTW5mzdvZoYCaNGiRS1f/OIXqyXp+uuvz2lv33feLykpyZ199tk7J0+e3DFz5szWs846K2qn6nzvvfc+/JxITU2NmulQh2rZsmUN6enpHVVVVfFPPPFEr5ZYq1evTu/o6LCDDz64qbCwMOJJXADYHyQwAExIodYXK1ZcPKh+BytWXGyPPPLolG3bto2rFmy5ubntaWlpnfX19bF33XVXRvdtjzzySNrdd989sCzPAF1//fVT169f3yvZsGHDhoT3338/IEmFhYX7bH0hSXPmzGk75ZRTaru6uvSVr3wlf9euXR/2Zdm5c2fshRdemN/V1aV/+Zd/qZk9e3bEK+/f/OY3q6dNm9b2hz/8IfNb3/pWTn19fa9r8caNGxPuvPPOjHD7D8WXv/zlmbW1tXGnnnpqbffZUiRp+fLldWedddbOpqammC996Uv5w3VOjG3XXnttRTAY7CotLU288847B5TA/OUvf1lWW1u7vqSk5J2+BseMtOrq6thvfOMbeZKUn5/fumjRoqiZDnWo4uLidMkll1RK0qWXXppfVlb24fXp7bffTrzmmmtmSNLll18+qG55ABCNxlUFHAAGarCtL0LGy1gYPcXFxekb3/hGxTXXXJN70UUXFf7qV7/Kys3NbS0pKUl8++23g5dccknl7bffPm24zrd69eqp3/ve92bm5ua2zpkzpzkYDHZVV1fHv/baaynt7e122mmn1SxZsmTATZ3vvffebSeccELSyy+/nDpr1qxDjj766HpJeumll1Lr6upi586d2xwt04VOmjSp649//OP7n/3sZ2f/4he/mH7vvfdmzZ07tyk7O7u9oaEh9oMPPkjatm1b4qGHHto4kKb7+3L33XenP/nkk+np6ekdff0O7rzzztJ169ZNeuGFF9J+/vOfT/n2t7+9s2eZn/3sZ9PvueeeqX2d54477th23HHH0Tx9nMjJyen42te+Vvnzn/8858Ybb5x+8cUX7+o+5e9Y0H3wy87OTtuxY0f8W2+9FWxsbIxJTU3tvPfee4siGN6w+uEPf1j1/PPPp65du3bSvHnzDv7Yxz5W39HRYS+88EJaa2urnXvuuTvOOeec3ZGOEwD2FwkMABPSG2+8GXzzzdftj3+8eyi722GHHd7nTB1j1dVXX11VWFjYevPNN097//33k7Zs2RI48MADm++8886iiy66qGY4ExhXXnll2Z///OdJb7zxRsrrr7+e0tjYGJuZmdl+5JFH1p9//vk7zz333LBTjPZl+vTpHa+88srG6667Lvuxxx5L//vf/54mebOPXHTRRTXf//73d6SlpUVNU/Gjjjqq+e23395w4403Tv3rX/86ecOGDclvvPFGTHp6esf06dPbli9fXvP5z39+UL+DcMrKyuK++93v9uo60lNGRkbXrbfeWnzWWWcdeNVVV+V+5jOf2dOztcr27dsTt2/f3uc4I7t37x74KK5jWE5WVkfOqlVDrj/lZGWNmfFzfvCDH1StXr06a/v27Ym33377lG9+85u9ElvRrOfgl8nJyV25ubmtS5YsqbviiiuqCgoKIt4ia7jExcXpqaeeev+GG26Y+uCDD0557rnn0mJjY7VgwYLGr3zlK9Vf+9rX9jsZCgDRwJyLyhZ+AKD169cXL1y4cNQrzI8/XrFYGr6pWgFMDBVf/epi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",
      "text/plain": [
       "<Figure size 1080x432 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axs = plt.subplots(1, 2, figsize=(15, 6))\n",
    "letters = ('a', 'b', 'c')\n",
    "axes = []\n",
    "for i, (plot_df, name, letter) in enumerate(zip([copy, reverse], ['Copy', 'Reverse'], letters)):\n",
    "\n",
    "    plot_df = plot_df[(plot_df.mem_size < plot_df.tgt_len) | (plot_df.mem_size == 0)]\n",
    "\n",
    "    fontdict = {'fontsize': 24}\n",
    "    # fontsize = 28\n",
    "    legsize = 22\n",
    "\n",
    "    mt = plot_df[plot_df.num_mem_tokens > 0]\n",
    "    xl = plot_df[plot_df.mem_len > 0]\n",
    "    bl = plot_df[(plot_df.num_mem_tokens == 0) & (plot_df.mem_len == 0)]\n",
    "    mt = pd.concat((mt, bl[bl.n_chunks == 1]))\n",
    "    xl = pd.concat((xl, bl[bl.n_chunks == 1]))\n",
    "\n",
    "\n",
    "\n",
    "    markers = ['^', 's']\n",
    "    dfs = [xl, mt]\n",
    "    zorders = [50, 0]\n",
    "    colors = [ (0.7, 0.7, 0.9), (0.9, 0.4, 0.4)]\n",
    "    for z, d, m, c in zip(zorders, dfs, markers, colors): \n",
    "        gd = d.groupby('n_chunks').agg({'test acc': tuple})\n",
    "        gd['mean'] = d.groupby('n_chunks').mean()['test acc']\n",
    "        gd['std'] = d.groupby('n_chunks').std()['test acc']\n",
    "        gd = gd.reset_index()\n",
    "\n",
    "        axs[i].errorbar(gd.n_chunks, gd['mean'], gd['std'], lw=4, color=c, marker=m, markeredgecolor='k', markersize=16, capsize=10, elinewidth=2, zorder=z)\n",
    "        \n",
    "\n",
    "    # axs[i].legend(['Baseline', 'Transformer-XL', 'RMT'], fontsize=legsize)\n",
    "\n",
    "    # for z, d, m, c in zip(zorders, dfs, markers, colors):    \n",
    "    #     d = d[(d.mem_len == 6) | (d.num_mem_tokens == 6)]\n",
    "    #     gd = d.groupby('n_chunks').agg({'test acc': tuple})\n",
    "    #     gd['mean'] = d.groupby('n_chunks').mean()['test acc']\n",
    "    #     gd['std'] = d.groupby('n_chunks').std()['test acc']\n",
    "    #     gd = gd.reset_index()\n",
    "\n",
    "    #     axs[i].errorbar(gd.n_chunks, gd['mean'], gd['std'], lw=4, color=c, marker=m, markeredgecolor='k', markersize=8, capsize=10, elinewidth=2, zorder=z)\n",
    "\n",
    "    \n",
    "    \n",
    "    ticks = np.unique(mt.n_chunks.astype(int))\n",
    "    axs[i].set_xticks(ticks)\n",
    "    axs[i].set_xticklabels(ticks)\n",
    "    axs[i].set_title(name, fontdict=fontdict)\n",
    "    axs[i].grid()\n",
    "    axs[i].tick_params(labelsize=22)\n",
    "    \n",
    "    \n",
    "\n",
    "    # axs[0].set_xlabel('(a)', fontdict=fontdict)\n",
    "    # axs[-1].set_xlabel('Number of segments\\n(b)', fontdict=fontdict)\n",
    "    axs[i].set_xlabel(f'Number of segments\\n({letter})', fontdict=fontdict)\n",
    "# axs[1].get_shared_y_axes().join(axs[0], axs[1])\n",
    "axs[1].sharey(axs[0])\n",
    "axs[0].set_ylabel('Accuracy', fontdict=fontdict)\n",
    "\n",
    "fig.legend(['Transformer-XL', 'RMT BPTT-0'], fontsize=legsize, loc='upper center', bbox_to_anchor=(0.5, 1.1), ncol=3, fancybox=True)\n",
    "\n",
    "plt.tight_layout()\n",
    "# plt.savefig(f'../../Memory transformer/_figures_paper/res_combined.png', format='png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# plot_df = copy\n",
    "\n",
    "# fontdict = {'fontsize': 18}\n",
    "\n",
    "# mt = plot_df[plot_df.num_mem_tokens > 0]\n",
    "# xl = plot_df[plot_df.mem_len > 0]\n",
    "# bl = plot_df[(plot_df.num_mem_tokens == 0) & (plot_df.mem_len == 0)]\n",
    "# mt = pd.concat((mt, bl[bl.n_chunks == 1]))\n",
    "# xl = pd.concat((xl, bl[bl.n_chunks == 1]))\n",
    "\n",
    "\n",
    "# fig = plt.figure(figsize=(8, 5))\n",
    "\n",
    "# markers = ['s', '^', 'o'][::-1]\n",
    "# dfs = [mt, xl, bl][::-1]\n",
    "# zorders = [100, 50, 0]\n",
    "# colors = [(0.9, 0.9, 1), (0.75, 0.4, 0.4), (0.7, 0.7, 1)]\n",
    "# for z, d, m, c in zip(zorders, dfs, markers, colors):\n",
    "#     gd = d.groupby('n_chunks').agg({'test acc': tuple})\n",
    "#     gd['mean'] = d.groupby('n_chunks').mean()['test acc']\n",
    "#     gd['std'] = d.groupby('n_chunks').std()['test acc']\n",
    "#     gd = gd.reset_index()\n",
    "\n",
    "#     plt.errorbar(gd.n_chunks, gd['mean'], gd['std'], lw=4, color=c, marker=m, markeredgecolor='k', markersize=12, capsize=10, elinewidth=2, zorder=z)\n",
    "\n",
    "# plt.legend(['Baseline', 'Transformer-XL', 'RMT'], fontsize=16)\n",
    "\n",
    "# plt.xlabel('Number of segments', fontdict=fontdict)\n",
    "# plt.ylabel('Accuracy', fontdict=fontdict)\n",
    "# ticks = np.unique(mt.n_chunks.astype(int))\n",
    "# plt.xticks(ticks, labels=ticks)\n",
    "# plt.grid()\n",
    "# plt.savefig('../../Memory transformer/_figures_paper/res_copy.png', format='png')\n",
    "# plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 256,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 576x360 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_df = copy\n",
    "\n",
    "fontdict = {'fontsize': 18}\n",
    "\n",
    "mt = plot_df[plot_df.num_mem_tokens > 0]\n",
    "xl = plot_df[plot_df.mem_len > 0]\n",
    "bl = plot_df[(plot_df.num_mem_tokens == 0) & (plot_df.mem_len == 0)]\n",
    "mt = pd.concat((mt, bl[bl.n_chunks == 1]))\n",
    "xl = pd.concat((xl, bl[bl.n_chunks == 1]))\n",
    "\n",
    "\n",
    "fig = plt.figure(figsize=(8, 5))\n",
    "\n",
    "markers = ['s', '^', 'o'][::-1]\n",
    "dfs = [mt, xl, bl][::-1]\n",
    "zorders = [100, 50, 0]\n",
    "colors = [(0.9, 0.9, 1), (0.75, 0.4, 0.4), (0.7, 0.7, 1)]\n",
    "for z, d, m, c in zip(zorders, dfs, markers, colors): \n",
    "    d = d[(d.mem_len != 6) & (d.num_mem_tokens != 6)]   \n",
    "    gd = d.groupby('n_chunks').agg({'test acc': tuple})\n",
    "    gd['mean'] = d.groupby('n_chunks').mean()['test acc']\n",
    "    gd['std'] = d.groupby('n_chunks').std()['test acc']\n",
    "    gd = gd.reset_index()\n",
    "\n",
    "    plt.errorbar(gd.n_chunks, gd['mean'], gd['std'], lw=4, color=c, marker=m, markeredgecolor='k', markersize=16, capsize=10, elinewidth=2, zorder=z)\n",
    "\n",
    "plt.legend(['Baseline', 'Transformer-XL', 'RMT'], fontsize=16)\n",
    "\n",
    "for z, d, m, c in zip(zorders, dfs, markers, colors):    \n",
    "    d = d[(d.mem_len == 6) | (d.num_mem_tokens == 6)]\n",
    "    gd = d.groupby('n_chunks').agg({'test acc': tuple})\n",
    "    gd['mean'] = d.groupby('n_chunks').mean()['test acc']\n",
    "    gd['std'] = d.groupby('n_chunks').std()['test acc']\n",
    "    gd = gd.reset_index()\n",
    "\n",
    "    plt.errorbar(gd.n_chunks, gd['mean'], gd['std'], lw=4, color=c, marker=m, markeredgecolor='k', markersize=8, capsize=10, elinewidth=2, zorder=z)\n",
    "\n",
    "\n",
    "plt.xlabel('Number of segments', fontdict=fontdict)\n",
    "plt.ylabel('Accuracy', fontdict=fontdict)\n",
    "ticks = np.unique(mt.n_chunks.astype(int))\n",
    "plt.xticks(ticks, labels=ticks)\n",
    "plt.grid()\n",
    "plt.savefig('../../Memory transformer/_figures_paper/res_copy.png', format='png')\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 257,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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0myNHz8eQqEQM2bMUFmemZkJoVCIhQsX6qlkTcuVK1ewYsUKCIVCLF26FKtWrULnzp31XaxGLyUlBdHR0UhMTNR3UUgTQ5kPSbN38eJFpKam0iyOOnL58mUAwLJly2BjY6Pn0jQdqampWL9+PVxcXODr66vv4pAmhGoMSLNmbGwMGxsb7N+/X99FabKysrIAgIICQhoJCgxIs8bhcDB8+HD8/PPPkEgkVW535MgRCIVC/PvvvyrLo6OjIRQKkZKSAgD4999/IRQKsW7dOnTv3h09evTA33//jQULFiA4OBiTJk1CQUGB2vFv3bqFUaNGITAwEH369MEPP/yAypKS3rlzB++88w66du2KgIAADBs2DKdOnaq0zPKyPXnyBOvXr0ffvn0REBCA1157Db/99psmX5OCRCLBd999h9deew3+/v549dVXsWjRImRnZ6tsJ/8elPsTyN/Xt4/BnTt3MHv2bLz66qsICAhA7969MX/+fKSnp6tt+/TpUyxYsADdunWDv78/Bg0ahL1791Z63P3796N///4ICAjA0KFDcenSJfTt2xfjx49XbLNw4UL07dsXy5cvR2BgICZMmIC4uDgMHDgQXbt2xaZNm9SOe/r0aYwaNQrBwcHo0KEDpk6dqlb9n5KSAqFQiOjoaOzatQthYWHo0KEDxowZg3v37qls27dvXwiFQsWETp988onKd1tRSkoKFixYgF69ein+zWbPno2kpKSav2zSLFFTAmn2Ro0aha1bt+L06dMYMmSIVo75xx9/YNasWYiOjsbs2bPRu3dvTJ8+HevWrcOBAwcwbdo0le2nTZuGsLAwhIeH4/z58/juu+8gEokwb948xTYxMTGYOnUq7O3tMWXKFFhaWuLPP//E+++/j1WrVuGNN96otCyrV6/G3bt3ERkZCYFAgDt37uDp06d1+lwffvghfv/9d/Tv3x+TJ0/G/fv3sX//fly/fh0///wz+Hw+AMDT0xOrVq0CABw8eBAxMTGK9wDQsWPHOp0/NzcXkydPhqmpKcaPHw+BQID09HScO3cOT548QatWrRTbPnjwAKNHjwaHw8Ho0aPRokULXLt2DV988QXy8vJU5j3Yt28fPv/8cwQEBGDs2LF4/vw55s6dC6lUqtbElJqaColEgrfeegu7du3ClClTMHPmTFy9ehXffvstIiMj4ejoCADYunUrVq1a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",
      "text/plain": [
       "<Figure size 576x360 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_df = reverse\n",
    "\n",
    "fontdict = {'fontsize': 18}\n",
    "\n",
    "mt = plot_df[plot_df.num_mem_tokens > 0]\n",
    "xl = plot_df[plot_df.mem_len > 0]\n",
    "bl = plot_df[(plot_df.num_mem_tokens == 0) & (plot_df.mem_len == 0)]\n",
    "mt = pd.concat((mt, bl[bl.n_chunks == 1]))\n",
    "xl = pd.concat((xl, bl[bl.n_chunks == 1]))\n",
    "\n",
    "\n",
    "fig = plt.figure(figsize=(8, 5))\n",
    "\n",
    "markers = ['s', '^', 'o'][::-1]\n",
    "dfs = [mt, xl, bl][::-1]\n",
    "zorders = [100, 50, 0]\n",
    "colors = [(0.9, 0.9, 1), (0.75, 0.4, 0.4), (0.7, 0.7, 1)]\n",
    "for z, d, m, c in zip(zorders, dfs, markers, colors): \n",
    "    d = d[(d.mem_len != 6) & (d.num_mem_tokens != 6)]   \n",
    "    gd = d.groupby('n_chunks').agg({'test acc': tuple})\n",
    "    gd['mean'] = d.groupby('n_chunks').mean()['test acc']\n",
    "    gd['std'] = d.groupby('n_chunks').std()['test acc']\n",
    "    gd = gd.reset_index()\n",
    "\n",
    "    plt.errorbar(gd.n_chunks, gd['mean'], gd['std'], lw=4, color=c, marker=m, markeredgecolor='k', markersize=16, capsize=10, elinewidth=2, zorder=z)\n",
    "\n",
    "plt.legend(['Baseline', 'Transformer-XL', 'RMT'], fontsize=16)\n",
    "\n",
    "for z, d, m, c in zip(zorders, dfs, markers, colors):    \n",
    "    d = d[(d.mem_len == 6) | (d.num_mem_tokens == 6)]\n",
    "    gd = d.groupby('n_chunks').agg({'test acc': tuple})\n",
    "    gd['mean'] = d.groupby('n_chunks').mean()['test acc']\n",
    "    gd['std'] = d.groupby('n_chunks').std()['test acc']\n",
    "    gd = gd.reset_index()\n",
    "\n",
    "    plt.errorbar(gd.n_chunks, gd['mean'], gd['std'], lw=4, color=c, marker=m, markeredgecolor='k', markersize=8, capsize=10, elinewidth=2, zorder=z)\n",
    "\n",
    "plt.xlabel('Number of segments', fontdict=fontdict)\n",
    "plt.ylabel('Accuracy', fontdict=fontdict)\n",
    "ticks = np.unique(mt.n_chunks.astype(int))\n",
    "plt.xticks(ticks, labels=ticks)\n",
    "plt.grid()\n",
    "plt.savefig('../../Memory transformer/_figures_paper/res_reverse.png', format='png')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 250,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 576x360 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_df = retrieval\n",
    "\n",
    "fontdict = {'fontsize': 18}\n",
    "\n",
    "mt = plot_df[plot_df.num_mem_tokens > 0]\n",
    "xl = plot_df[plot_df.mem_len > 0]\n",
    "bl = plot_df[(plot_df.num_mem_tokens == 0) & (plot_df.mem_len == 0)]\n",
    "mt = pd.concat((mt, bl[bl.n_chunks == 1]))\n",
    "xl = pd.concat((xl, bl[bl.n_chunks == 1]))\n",
    "\n",
    "\n",
    "fig = plt.figure(figsize=(8, 5))\n",
    "\n",
    "markers = ['s', '^', 'o'][::-1]\n",
    "dfs = [mt, xl, bl][::-1]\n",
    "zorders = [100, 50, 0]\n",
    "colors = [(0.9, 0.9, 1), (0.75, 0.4, 0.4), (0.7, 0.7, 1)]\n",
    "for z, d, m, c in zip(zorders, dfs, markers, colors):\n",
    "    gd = d.groupby('n_chunks').agg({'test acc': tuple})\n",
    "    gd['mean'] = d.groupby('n_chunks').mean()['test acc']\n",
    "    gd['std'] = d.groupby('n_chunks').std()['test acc']\n",
    "    gd = gd.reset_index()\n",
    "    plt.errorbar(gd.n_chunks, gd['mean'], gd['std'], lw=4, color=c, marker=m, markeredgecolor='k', markersize=12, capsize=10, elinewidth=2, zorder=z)\n",
    "\n",
    "plt.legend(['Baseline', 'Transformer-XL', 'RMT'], fontsize=16)\n",
    "\n",
    "plt.xlabel('Number of segments', fontdict=fontdict)\n",
    "plt.ylabel('Accuracy', fontdict=fontdict)\n",
    "ticks = np.unique(mt.n_chunks.astype(int))\n",
    "plt.xticks(ticks, labels=ticks)\n",
    "plt.grid()\n",
    "plt.savefig('../../Memory transformer/_figures_paper/res_retrieval.png', format='png')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## scatter"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "# gb_cols = ['dataset', 'tgt_len', 'lr', 'max_step',  'num_mem_tokens', 'mem_len', 'mem_backprop_depth']#, 'seed']\n",
    "# df_ = retrieval\n",
    "# gb = df_.dropna(subset=['test acc']).groupby(gb_cols).agg({'test acc': tuple})\n",
    "# gb['mean acc'] = df_.groupby(gb_cols).mean()['test acc']\n",
    "# gb"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "# gb_cols = ['dataset', 'tgt_len', 'lr', 'max_step',  'num_mem_tokens', 'mem_len', 'mem_backprop_depth']#, 'seed']\n",
    "# df_ = copy\n",
    "# gb = df_.dropna(subset=['test acc']).groupby(gb_cols).agg({'test acc': tuple})\n",
    "# gb['mean acc'] = df_.groupby(gb_cols).mean()['test acc']\n",
    "# gb"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "import seaborn as sns\n",
    "\n",
    "sns.set_theme(style='white', palette='BuPu', font_scale=1.3, font='monospace')\n",
    "# import matplotlib.lines as mlines\n",
    "import matplotlib.patches as mpatches\n",
    "# import matplotlib.pyplot as plt\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "# plot_df = copy\n",
    "# plot_df['n_chunks'] = (plot_df.tgt_len.max() / plot_df.tgt_len).astype(int)\n",
    "# plot_df = plot_df.sort_values('n_chunks')\n",
    "\n",
    "# mt = plot_df[plot_df.num_mem_tokens > 0]\n",
    "# xl = plot_df[plot_df.mem_len > 0]\n",
    "# bl = plot_df[(plot_df.num_mem_tokens == 0) & (plot_df.mem_len == 0)]\n",
    "\n",
    "# plt.scatter(mt.tgt_len, mt['test acc'], edgecolor='grey', c='b', s=60)\n",
    "# plt.scatter(xl.tgt_len, xl['test acc'], edgecolor='grey', c='r', s=60, zorder=0)\n",
    "# plt.scatter(bl.tgt_len, bl['test acc'], edgecolor='grey', c='w', s=60, zorder=0)\n",
    "# plt.legend(['MT', 'XL', 'Baseline'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "# plot_df = copy\n",
    "# plot_df['n_chunks'] = (plot_df.tgt_len.max() / plot_df.tgt_len).astype(int)\n",
    "# plot_df = plot_df.sort_values('n_chunks')\n",
    "# plot_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.06151879596515051"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "sns.stripplot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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dy32++c//6kf/vCHGjp0qG666Sbt37+/2es5OTlau3Zts21jxoxRfn5+09dz587V1KlTtWbNGo0ZM0bDhw/X/fffr9ra2lNmfOutt3TBBRdo9erVTds8Ho+effZZjRkzRhdccIFGjx6tBx98UA0NDe3+MwBgLhQ5AKZXWVmppUuX6qGHHtLjjz+uzz77TIsXL27XOZxOp6ZOnaq3335bM2fO1LJlyzRlyhRt2bKlxb6PP/64pk+frsWLF6usrEzz58/vUO4vv/xSGzdu1Pz58zV79my99957WrFiRZv7v/POO5ozZ44ee+wx3XTTTU3bX3nlFb366qu6/fbbtWLFCj300EOqq6ujyAERIMroAABwpurq6rRo0SINGDBAkrRv3z6tW7euXedYt26dvvjiC/3pT3/SsGHDJEmXX365br755hb73nfffbrqqqskSRUVFXrsscfk8Xhkt9vb9Z4Oh0NLlixRamqqJGn79u368MMP9fOf/7zFvps3b9aDDz6oefPmtci0c+dODR48WLfffnvTthtuuKFdWQCYEyNyAEwvJSWlqcRJUnZ2tsrKytp1jo8++khnnXVWU4lrFBXV8vfd4cOHN3svv9+v8vLydqaW+vfv31TiGs/VWu6///3veuCBB3TJJZfolltuafF6Tk6OPvvsM7344ovatWuX3G53u7MAMCeKHADTS0xMbPa1zWaT1+tt1zkqKyuVkZHR7vezWo//b9Tj8bTr/U4+j9R27u3bt+uaa67Rli1b9P7777d4/e6779aMGTO0ceNGTZo0SZdccomefPJJ+f3+dmcCYC4UOQCQlJqaqtLS0k45l81ma1GiHA5Hh89322236fnnn9fVV1+tRx55RBUVFc1ej42N1QMPPKB33nlH77//viZOnKjf//73evfddzv8ngDMgSIHAJIuvfRSHTp0SNu3b2+2vSMPDHTr1q1ZKSwpKenQpddGjZdfFy5cKI/Hc8qHK3r06KH7779fklRcXNzh9wRgDhQ5AJA0YcIEnXvuufqP//gPrVy5Uh9++KFWr16tGTNmtPtco0aN0tq1a7Vv3z4dPnxYjz/+uKKjo884Y0ZGhubPn6933nlH69evb9r+4IMP6oUXXtDf/vY3bd26VY888ojsdrsuueSSM35PAF0bT60CgI5fnly5cqWef/55vfzyy6qoqFB2dnazaT4CNWvWLM2dO1c33nijunfvrvvuu0979uzplJzXX3+93n33XS1cuFAjR45UVlaWLrroIq1fv14rV66Uz+fTwIED9dJLL+ncc8/tlPcE0HVZ/NwNCwAAYEpcWgUAADApLq0CCFs+n08+n++U+1gsFtlsthAlAoDOxaVVAGFr7ty5p13hYejQoc3WLQUAM6HIAQhbhYWFLeZcO1l8fHyzVSEAwEwocgAAACbFww4AAAAmRZEDAAAwKYocAACASVHkAAAATIoiBwAAYFL/D5nJ1CMisgXZAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot_df = copy\n",
    "# plot_df['n_chunks'] = (plot_df.tgt_len.max() / plot_df.tgt_len).astype(int)\n",
    "# plot_df = plot_df.sort_values('n_chunks')\n",
    "\n",
    "# mt = plot_df[plot_df.num_mem_tokens > 0]\n",
    "# xl = plot_df[plot_df.mem_len > 0]\n",
    "# bl = plot_df[(plot_df.num_mem_tokens == 0) & (plot_df.mem_len == 0)]\n",
    "\n",
    "\n",
    "# plt.figure(figsize=(10, 6))\n",
    "# # xs = mt.n_chunks + np.random.normal(0, 0.2, mt.shape[0])\n",
    "# # plt.scatter(xs, mt['test acc'], edgecolor='grey', c='b', s=60, marker='s')\n",
    "\n",
    "# # xs = xl.n_chunks + np.random.normal(0, 0.2, xl.shape[0])\n",
    "# # plt.scatter(xl.n_chunks, xl['test acc'], edgecolor='grey', c='r', s=60, marker='^', zorder=0)\n",
    "# # plt.scatter(bl.n_chunks, bl['test acc'], edgecolor='grey', c='w', s=60, marker='o', zorder=10)\n",
    "\n",
    "# sns.stripplot(x=bl.n_chunks, y=bl['test acc'], edgecolor='grey', s=50, marker='o')\n",
    "# sns.stripplot(x=mt.n_chunks, y=mt['test acc'], edgecolor='grey', s=10, marker='s')\n",
    "# sns.stripplot(x=xl.n_chunks, y=xl['test acc'], edgecolor='grey', s=10, marker='^')\n",
    "\n",
    "# # sns.scatterplot(bl.n_chunks, bl['test acc'], edgecolor='grey', s=50, marker='o', zorder=0, x_jitter=True)\n",
    "# # sns.scatterplot(xl.n_chunks, xl['test acc'], edgecolor='grey', s=50, marker='^', zorder=0, x_jitter=True)\n",
    "# # sns.scatterplot(mt.n_chunks, mt['test acc'], edgecolor='grey', s=50, marker='s', )\n",
    "\n",
    "# plt.legend(['Baseline', 'XL', 'MT'])\n",
    "# sns.despine()\n",
    "\n",
    "# # MT_marker = mpatches.Patch([], [], color='blue', marker='s',\n",
    "# #                           markersize=15, label='MT')\n",
    "# # XL_marker = mlines.Line2D([], [], color='r', marker='^',\n",
    "# #                           markersize=15, label='XL')                          \n",
    "# # BL_marker = mlines.Line2D([], [], color='w', marker='o',\n",
    "# #                           markersize=15, label='Baseline')\n",
    "\n",
    "# # plt.legend(handles=[MT_marker, XL_marker, BL_marker])\n",
    "# # plt.legend([MT_marker, XL_marker, BL_marker])\n",
    "\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## barplots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 141,
   "metadata": {},
   "outputs": [],
   "source": [
    "# plot_df = copy\n",
    "# plot_df['n_chunks'] = (plot_df.tgt_len.max() / plot_df.tgt_len).astype(int)\n",
    "# plot_df = plot_df.sort_values('n_chunks')\n",
    "\n",
    "# mt = plot_df[plot_df.num_mem_tokens > 0]\n",
    "# xl = plot_df[plot_df.mem_len > 0]\n",
    "# bl = plot_df[(plot_df.num_mem_tokens == 0) & (plot_df.mem_len == 0)]\n",
    "\n",
    "# plt.bar(mt.n_chunks, mt['test acc'], edgecolor='grey', color='b')\n",
    "# plt.bar(xl.n_chunks, xl['test acc'], edgecolor='grey', color='r')\n",
    "# plt.bar(bl.n_chunks, bl['test acc'], edgecolor='grey', color='w')\n",
    "# plt.legend(['MT', 'XL', 'Baseline'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 277,
   "metadata": {},
   "outputs": [],
   "source": [
    "# df = reverse\n",
    "# n_chunks = np.unique(df.n_chunks)\n",
    "# plot_df = pd.DataFrame(index = n_chunks)\n",
    "\n",
    "# plot_df['baseline'] = [(df[(df.num_mem_tokens == 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc']).values for i in n_chunks]\n",
    "# plot_df['MT'] = [(df[(df.num_mem_tokens > 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc']).values for i in n_chunks]\n",
    "# plot_df['TXL'] = [(df[(df.num_mem_tokens == 0) & (df.mem_len > 0) & (df.n_chunks == i)]['test acc']).values for i in n_chunks]\n",
    "# plot_df.loc[1] = [plot_df.baseline.iloc[0]] * 3\n",
    "\n",
    "\n",
    "# plt.figure(figsize=(8, 4))\n",
    "\n",
    "# for i, row in plot_df.iterrows():\n",
    "#     print(row.baseline)\n",
    "#     if len(row.baseline) > 0:\n",
    "#         # plt.axvline(i-0.5, ymin=min(row.baseline)-0.1, ymax=max(row.baseline), lw=50)\n",
    "#         plt.axvspan(xmin=i-0.75, xmax=i-0.25, ymin=min(row.baseline)-0.5, ymax=max(row.baseline), lw=50)\n",
    "\n",
    "\n",
    "# plt.xlabel('Number of segments')\n",
    "# plt.xticks(rotation=0)\n",
    "# plt.yticks([0, 1])\n",
    "# plt.ylabel('accuracy')\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 238,
   "metadata": {},
   "outputs": [],
   "source": [
    "# df = reverse\n",
    "# n_chunks = np.unique(df.n_chunks)\n",
    "# plot_df = pd.DataFrame(index = n_chunks)\n",
    "\n",
    "# plt.figure(figsize=(8, 4))\n",
    "\n",
    "# plot_df['baseline'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].min() for i in n_chunks]\n",
    "# plot_df['MT'] = [df[(df.num_mem_tokens > 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].min() for i in n_chunks]\n",
    "# plot_df['TXL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len > 0) & (df.n_chunks == i)]['test acc'].min() for i in n_chunks]\n",
    "# plot_df.loc[1] = 1\n",
    "\n",
    "# # plot_df.reset_index().plot(x='index', kind='bar', figsize=(12, 8), cmap='BuPu', edgecolor='grey', width=0.7, color=[(0.8, 0.1, 0.1), (0.6, 0.6, 1), 'w'])\n",
    "# width=0.4\n",
    "# xs = np.arange(plot_df.shape[0])\n",
    "# plt.bar(xs-width, plot_df.baseline.values, width=width)\n",
    "# plt.bar(xs, plot_df.MT.values, width=width)\n",
    "# plt.bar(xs+width, plot_df.TXL.values, width=width)\n",
    "\n",
    "# plt.xticks([str(i) for i in np.array(plot_df.index)])\n",
    "\n",
    "# # plot_df['baseline'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].mean() for i in n_chunks]\n",
    "# # plot_df['MT'] = [df[(df.num_mem_tokens > 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].mean() for i in n_chunks]\n",
    "# # plot_df['TXL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len > 0) & (df.n_chunks == i)]['test acc'].mean() for i in n_chunks]\n",
    "# # plot_df.loc[1] = 1\n",
    "\n",
    "# # plot_df.reset_index().plot(x='index', kind='bar', figsize=(12, 8), cmap='BuPu', edgecolor='grey', width=0.7, color=[(0.8, 0.1, 0.1), (0.6, 0.6, 1), 'w'])\n",
    "\n",
    "\n",
    "# plt.xlabel('Number of segments')\n",
    "# # plt.xticks(rotation=0)\n",
    "# plt.yticks([0, 1])\n",
    "# plt.ylabel('accuracy')\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 255,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAtEAAAHrCAYAAAAJwMFRAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAAvx0lEQVR4nO3de1iUdf7/8dcwgqgIiKIImiEamgriWZFc8cBqecwsM9PM0EwL0zRPechKzTyXq2ZZ6q6SIXncQ7nbeS3tm2bpmpoW4gFUUBAQgd8frvNbQm0+BMwAz8d1dSX33Pfcbwcur6e3n7nHkpeXlycAAAAAdnNx9AAAAABAaUNEAwAAAIaIaAAAAMAQEQ0AAAAYquDoAUxkZmbq4MGD8vX1ldVqdfQ4AAAAKKNycnKUlJSkpk2byt3dvcDjpSqiDx48qMGDBzt6DAAAAJQTGzZsUKtWrQpsL1UR7evrK+n6b8bPz8/B0wAAAKCsOnPmjAYPHmzrz18rVRF9YwmHn5+f6tSp4+BpAAAAUNbdagkxbywEAAAADBHRAAAAgCEiGgAAADBERAMAAACGiGgAAADAUKm6OwcAAEBJys3NVXJyslJSUpSTk+PocVCErFarvL29VaNGDbm4mF9XJqIBAABuISEhQRaLRXfeeadcXV1lsVgcPRKKQF5enrKzs3X27FklJCTojjvuMH4OlnMAAADcQnp6ugICAuTm5kZAlyEWi0Vubm4KCAhQenp6oZ6DiAYAALiNwvxTP0qH3/O95acCAAAAMEREAwAAAIZ4YyEAAIChRfPm6VJmZome09PdXeMmTbJ7/+eff16SNHfu3OIa6TetX79eL774oiQpICBAu3fvvuW+CQkJ6tKlizZs2KBWrVqV1IiFRkQDAAAYupSZqftWrSrRc26Pji7R8xWF+++/X1FRUdq5c6feeeed2+5bu3ZtffbZZ/L29i6Z4X4nIhoAAADFolKlSqpUqZKqVq36m/tarVb5+vqWwFRFo8TXRB89elTPPPOMunTpouDgYC1btqykRwAAACgXMjIyNG7cOIWGhioyMlLbtm2zPfbKK68oKipKISEhat++vaZNm6bLly/nO/4f//iHevXqZdtn1KhRysrKsj2em5urFStWqHPnzgoNDdWAAQO0d+9eoxmTkpIUHBxs++9mx0dGRmrVqlV64oknFBoaqnvvvVfffvttvn2OHDmixx9/XM2bN1dERITmzJmjzGJcclPiEZ2eni4/Pz/FxMSoVq1aJX16AACAcuMf//iH6tWrp/j4eA0cOFATJ07U8ePHJUlZWVmaPn26duzYoeXLl2vfvn2aPXu27djk5GSNGzdOXbp00Y4dO/TWW28pLCws3yc3rlixQu+9955mz56t7du3KyoqSiNGjNDp06ftnrF69er67LPP9N577912v3Xr1umhhx5SXFycqlWrpunTp9seS01N1aOPPqr69etry5YtWrZsmfbs2aNXX33V7jlMlXhEh4aGavLkyerVq5cqVqxY0qcHAAAoN+rWrauYmBgFBgZq1KhRCgoKssXqzJkz1bFjR9WtW1ctW7bUww8/rI8//th27JkzZ5Sdna0uXbqobt26aty4sUaOHKnKlStLuh7hq1at0uTJkxUREaG6devqiSeeUN26dfNd8f4tLi4u8vX1lY+Pz23369Wrl7p06aKgoCANGTJER44csV1pXrdunWrWrKmpU6cqMDBQzZs315gxY7R582bl5eWZvmx2YU00AABAGRUcHJzv64YNG+rkyZOSrl+lXrt2rU6ePKn09HRdu3YtX3A2atRIrVu31rBhw9ShQweFhISoZ8+eCggIkCSdPHlSmZmZeu655/J9mmNWVpZ++eWXIv+9BAYG2n59482Hqampcnd315EjR3Ts2DGFhYXZ9snNzVVmZqbOnTtXLKsfiOgi9uL06cqt4Gwvq1VSzm/uVdKs1grKybnm6DHycXV11ZQpUxw9Rpkya9ZLkpzr+3z9jz7nmqlChQqaOnWqo8coU5z1Z2/GDL7PKLzExES7971y5YoyMjL+55jroWuxWLR//36NGzdOzzzzjCIiIlSpUiVt375dr7/+uu34ChUq6N1339WBAwf09ddfa8eOHXrjjTe0efNmBQUF2a4CL126VPXq1ct3bg8Pj9/3G70Jq9VaYNuN6M/IyFCHDh00bdq0AvtUr169yGeRiOgil1uhQonf8ua3bI+OVu3aMxw9RgGnT8/SjBnONdesWbMcPUIZdM3pfv7OnZujHCf7e2Vx/XNj+eZ8P3unT89yyj9nPD09NW7cOEePATu4uvrbva+LS2X99NN/bMdkZyfqxx9/1D333KN9+/bprrvu0hNPPGHb/+zZszd5Dhc1b95czZs319ChQ9W+fXt99tlnCgoK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0apZs6b69OmjPn36KCgoqDhnBQAAAJyC8RsLPTw89MADD2jdunX661//qtq1a2v16tW677779OCDD2r79u3FMScAAADgNAr1sd8//vij4uLitG3bNl24cEERERGKjIzUxx9/rIkTJ+r777/XpEmTinpWAAAAwCnYHdEpKSnatm2btmzZokOHDikgIECDBw9W//79VatWLUnSQw89pHfeeUdLly4logEAAFBm2R3RHTt2lNVqVbdu3TRx4kS1a9fupvs1b95c6enpRTYgAAAA4GzsjujJkyerd+/eqlq16m33Cw0N1eHDh3/3YAAAAICzsjuiBw8eXJxzAAAAAKWG3XfnOHHihLZu3arc3Nx823Nzc7V161adOHGiqGcDAAAAnJLdEf3qq6/qm2++kYtL/kNcXFz0zTffaP78+UU+HAAAAOCM7I7offv2qWPHjjd97J577tG+ffuKbCgAAADAmdkd0ZmZmQWuQv+vq1evFslAAAAAgLOzO6IbNWqkbdu23fSx+Ph4BQcHF9lQAAAAgDOz++4cI0aM0JgxY5Senq5evXqpRo0aSkpKUnx8vL788ku9/vrrxTknAAAA4DTsjuiuXbtq7ty5eu211/TJJ5/YttesWVNz585VZGRksQwIAAAAOBu7I1qS+vbtqz59+uj48eNKSUmRt7e36tevL4vFUlzzAQAAAE7HKKIlyWKxKCgoqDhmAQAAAEoFu99YCAAAAOA6u69E5+TkaNmyZdq6davOnz+vnJycAvscPHiwSIcDAAAAnJHdV6JXrFih9evXq0uXLsrKylKfPn3Uq1cveXh4qEaNGho9enRxzgkAAAA4DbuvRMfHx2vixIm6//77tW7dOj388MNq0qSJ0tPT9fjjjys3N7c45wQAAACcht1Xos+ePav69evLarXKarXaPqGwSpUqevzxxxUbG1tsQwIAAADOxO6I9vb2VkpKiiSpVq1aOnLkiO0xi8WitLS0Ih8OAAAAcEZ2L+do1qyZDhw4oK5du6pr165atmyZ3N3dVbFiRS1ZskQtWrQozjkBAAAAp2F3RA8fPlxHjx6VJI0dO1aJiYmaMmWKcnJyFBoaqpkzZxbXjAAAAIBTsTuiW7VqpVatWkmSqlatquXLl+vq1au6evWqPDw8im1AAAAAwNnYvSb6wIED2rNnT75tbm5uBDQAAADKHbsjevz48fr2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",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "df = copy\n",
    "n_chunks = np.unique(df.n_chunks)\n",
    "plot_df = pd.DataFrame(index = n_chunks)\n",
    "\n",
    "plot_df['baseline'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].max() for i in n_chunks]\n",
    "plot_df['MT'] = [df[(df.num_mem_tokens > 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].max() for i in n_chunks]\n",
    "plot_df['TXL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len > 0) & (df.n_chunks == i)]['test acc'].max() for i in n_chunks]\n",
    "plot_df.loc[1] = 1\n",
    "\n",
    "ax = plot_df.reset_index().plot(x='index', kind='bar', figsize=(12, 8), cmap='BuPu', edgecolor='grey', width=0.7, color=[(0.8, 0.1, 0.1), (0.4, 0.4, 1), (0.9, 0.9, 0.9)], legend=False)\n",
    "\n",
    "plot_df['baseline'] = [df# plot_df = copy[(df.num_mem_tokens == 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].mean() for i in n_chunks]\n",
    "plot_df['MT'] = [df[(df.num_mem_tokens > 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].mean() for i in n_chunks]\n",
    "plot_df['TXL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len > 0) & (df.n_chunks == i)]['test acc'].mean() for i in n_chunks]\n",
    "\n",
    "plot_df.reset_index().plot(x='index', kind='bar', ax=ax, cmap='BuPu', edgecolor='grey', width=0.7, color=[(0.8, 0.1, 0.1), (0.5, 0.5, 1), (0.95, 0.95, 0.95)], legend=False)\n",
    "\n",
    "plot_df['baseline'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].min() for i in n_chunks]\n",
    "plot_df['MT'] = [df[(df.num_mem_tokens > 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].min() for i in n_chunks]\n",
    "plot_df['TXL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len > 0) & (df.n_chunks == i)]['test acc'].min() for i in n_chunks]\n",
    "plot_df.loc[1] = 1\n",
    "\n",
    "plot_df.reset_index().plot(x='index', kind='bar', ax=ax, cmap='BuPu', edgecolor='grey', width=0.7, color=[(0.8, 0.1, 0.1), (0.6, 0.6, 1), 'w'], legend=True)\n",
    "\n",
    "\n",
    "plt.xlabel('Number of segments')\n",
    "plt.xticks(rotation=0)\n",
    "plt.yticks([0, 1])\n",
    "plt.ylabel('accuracy')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 254,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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0qSJoqOjNWfOHId9bj8vX331lTZt2mT/OjY21mG/M2fO6OWXX1aLFi0UERGhuLg4LVmyxPi5BFA0ebl6AAC4F19fX3Xo0EEbNmzIETkmTp8+rebNm6tChQr605/+pB49emj8+PEaM2aM+vTpo/vvv9++71tvvaVhw4apdOnSmjlzpgYNGqQdO3bI09NTkjR06FDt27dPL774omrWrKkdO3bohRde0MaNG1WrVq0cx74d7HPnzlVqaqoSExONZh87dqw+/fRTvfzyywoLC9NHH32koUOHasWKFWratKkkqXv37oqJidGhQ4c0ceJEzZ8/X4GBgZJkvJzj448/1owZMzRkyBA1adJE58+f186dO3X16lUFBARIunXGu2fPnqpWrZqmT5+urKwszZkzR4MHD9aGDRskSdnZ2Ro4cKBu3rypadOmKTMzU5MnT77rMf38/PT8889r9uzZatu2raZPn64RI0Zoz549atWqlS5evKiePXvK29tb48ePV+nSpbVs2TL169dPn3zyiXx8fOyPtX79ej388MOaNWuWdu3apYULF6pp06Zq1qyZJGndunWSpDfffFOBgYEaPHiwJOU4Yz969GglJiZq7NixqlChgo4fP66jR48aPZcAii4iGoDbe/zxx/XUU0/p3LlzuX4MPz8/PfHEEzpy5IhWr16tnj17qnbt2poyZYpOnjzpENHDhw9XfHy8pFsB2qNHD3366aeKi4vT7t279fnnn2vatGnq3LmzJCk6OlqHDx/WkiVLNGvWrBzHjoiI0Ouvv56ruc+cOaNt27Zp+PDheuaZZyRJLVu2VLt27fT+++/bIzooKEhBQUHKyMiQJNWuXVtVq1bN1TG//fZbVaxYUUOHDrVve/TRRx32mT9/vjw9PfXee++pXLlykqQaNWroscce0z/+8Q899NBD2rlzp3744Qf9+c9/VsOGDe33HTlyZI5jPv3007JYLJo9e7a6dOmitm3bqkaNGvrhhx/UqlUrrVixQufOndP27dt13333SZIiIyPVunVrbdy4UT179rQ/VtWqVfXmm29Kklq0aKHt27drz5499oiuX7++JKlMmTIKCAiwf32356FXr17q0KGDJNnvDwASyzkAFAKRkZEKCwvTpk2bcv0Yfn5+kqTSpUtLuhVQt7++evWqw74tWrRwOHapUqV05MgRSdLu3bvl6emptm3bKjMz0/6nQYMGOnTo0F2P3bFjx1zPfejQIdlsNoeZPDw8FB0drf/85z+5ftx7sVqtOnfunCZPnqx9+/bp+vXrOfbZs2ePoqOjVbp0aftzEBYWprJly9qfh++++06lSpVyCOjmzZvf9Zh+fn53/dmkpaXZj1enTh0FBwfbj1e2bFmFhYXleN4bNGhg/2eLxaKQkBCdP38+V89DQkKC1q5dq+PHj8tmsxk/BoCiizPRAAqFbt26ad26dYqKisrV/S0Wy13/18PDQ9nZ2Q77+vv7O3xdrlw5e4SlpqYqKyvLIQxv+7U38AUFBeVqZkm6cuXKXWfy9/fX5cuXc/2499KtWzelpaUpISFBq1evlqenp9q3b6+33npLvr6+km49D9u2bdO2bdty3P/nn3+WdOuTQm6fpb6tbNmydz2mxWK558/m9jKYOnXq5LhvhQoVHL6+HeG3eXp6KjMz8ze/71+aNWuW5syZo7lz5+r8+fMKDAzUyJEj7b+BAFC8EdEACoVOnTpp5syZ+uabbxy2e3nd+mvszrOEdztzauLSpUuqWLGiw9e31xf7+/urbNmyeu+993Lc73b8/dLtGXPjdhCmpqYqNDTUvj01NfVXg/T38vT0VL9+/dSvXz9dvHhR69at06xZs1SnTh316dNH0q3nITo6Wr17985x/9vrpitWrKhLly453Jbb8Pf391dwcLBGjBiR47ZfRnNeqVKliqZOnSpJOnLkiN5++22NGzdOMTExOcIdQPFDRAMoFAICAhQbG5vjM6MDAgJksViUkpJi33Z76UVu7d69W506dZJ0a13stWvXVLt2bUm31sUuW7ZMnp6eevDBB3/XcZxRt25dWSwWffnll6pXr56kW2/Y+/LLL1W3bt18P3758uU1aNAgLV++XKdPn7Zvb9asmY4dO6YHH3zQ/obLX3rwwQd17do17d+/337mfs+ePbmao1mzZkpISFCNGjXsyz5+r9KlS+vatWtO7VurVi09/fTT2rt3r86dO0dEAyCiARQe3bp103PPPeewzdvbW40bN9bq1avVoEEDpaenG3+E3C/Nnj1b2dnZKl26tN555x1Vr15drVu3lnTrTYQxMTEaOHCgBgwYoJo1ayo1NVX/+te/5OHhodGjR/+uY/9S5cqV1b59ey1atEilSpVSWFiYNmzYoJ9++kmTJk3K02PdNnXqVNlsNjVu3FhlypTR9u3bdfnyZUVHR9v3eeGFF9StWzcNGDBA3bt3V7ly5ZSUlKSdO3eqX79+aty4sWJjYxUWFqZRo0Zp5MiRysrK0sKFC3M1U58+fZSQkKBnnnlGzzzzjCpVqqSff/5ZX3zxhVq3bq3HHnvM+DFr1aqlVatW6bPPPlP16tVVokQJ+5sWJalLly7q3LmzatasqbS0NM2dO1fBwcGqUaNGrr4HAEULEQ2g0GjZsqWqVKliX3N724QJEzRmzBi1b99e1apV02uvvaZ//vOfuT7O2LFjNWXKFJ05c0ZRUVGaOHGi/WyrxWLRggULtHDhQn3wwQc6ffq0/P39VbduXftnNOe1t99+WzNmzNDixYt1+fJlhYWFae7cub/6Jr3fKyIiQmvWrFFCQoIyMjJUrVo1TZs2TTExMfZ9atSoofXr12v27Nl6/fXXlZ6eruDgYEVHR6tatWqSbq1pXrJkicaPH69Ro0apSpUqGjNmjAYNGmS8FCUgIEDr16/XrFmzNGXKFF2+fFmVK1dWkyZNcv0bgb59++qHH37Qa6+9ptTUVIWEhGjnzp0Oz8PatWuVnJyskiVLKioqSiNHjlSJEiVydTwARYvFxtuNAQAF5MiRI4qPj9fWrVtVs2ZNV48DALnGmWgAQL5ZsWKFPD09df/99+vKlStatGiRmjVrRkADKPSIaABAvilRooRWrlyp5ORklS9fXtHR0Xm+bhwAXIHlHAAAAIAhrlgIAAAAGCKiAQAAAENENAAAAGCIiAYAAAAMEdEAAACAof8HRWSPfNlGMxYAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "df = reverse\n",
    "n_chunks = np.unique(df.n_chunks)\n",
    "plot_df = pd.DataFrame(index = n_chunks)\n",
    "\n",
    "plot_df['baseline'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].max() for i in n_chunks]\n",
    "plot_df['MT'] = [df[(df.num_mem_tokens > 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].max() for i in n_chunks]\n",
    "plot_df['TXL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len > 0) & (df.n_chunks == i)]['test acc'].max() for i in n_chunks]\n",
    "plot_df.loc[1] = 1\n",
    "\n",
    "ax = plot_df.reset_index().plot(x='index', kind='bar', figsize=(12, 8), cmap='BuPu', edgecolor='k', width=0.7, color=[(0.8, 0.1, 0.1), (0.4, 0.4, 1), (0.9, 0.9, 0.9)], legend=False)\n",
    "\n",
    "plot_df['baseline'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].mean() for i in n_chunks]\n",
    "plot_df['MT'] = [df[(df.num_mem_tokens > 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].mean() for i in n_chunks]\n",
    "plot_df['TXL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len > 0) & (df.n_chunks == i)]['test acc'].mean() for i in n_chunks]\n",
    "\n",
    "plot_df.reset_index().plot(x='index', kind='bar', ax=ax, cmap='BuPu', edgecolor='k', width=0.7, color=[(0.8, 0.1, 0.1), (0.5, 0.5, 1), (0.95, 0.95, 0.95)], legend=False)\n",
    "\n",
    "plot_df['baseline'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].min() for i in n_chunks]\n",
    "plot_df['MT'] = [df[(df.num_mem_tokens > 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].min() for i in n_chunks]\n",
    "plot_df['TXL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len > 0) & (df.n_chunks == i)]['test acc'].min() for i in n_chunks]\n",
    "plot_df.loc[1] = 1\n",
    "\n",
    "plot_df.reset_index().plot(x='index', kind='bar', ax=ax, cmap='BuPu', edgecolor='k', width=0.7, color=[(0.8, 0.1, 0.1), (0.6, 0.6, 1), 'w'], legend=True)\n",
    "\n",
    "\n",
    "plt.xlabel('Number of segments')\n",
    "plt.xticks(rotation=0)\n",
    "plt.yticks([0, 1])\n",
    "plt.ylabel('accuracy')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ayd98/anaconda3/envs/cudaenv/lib/python3.9/site-packages/pandas/plotting/_matplotlib/core.py:244: UserWarning: 'color' and 'colormap' cannot be used simultaneously. Using 'color'\n",
      "  warnings.warn(\n",
      "/home/ayd98/anaconda3/envs/cudaenv/lib/python3.9/site-packages/pandas/plotting/_matplotlib/style.py:123: UserWarning: 'color' and 'colormap' cannot be used simultaneously. Using 'color'\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAscAAAHgCAYAAABJt8A9AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAAdOElEQVR4nO3df5TddX3n8debJCasGHEBCxhIqKvUiC4i6CL4i1YQZRFbrD/A1lqFSlFsT93qdqux52BBW1t/VlDRZVERi7WKitglilhcSAABBcS1BMMPkd8NkhjIZ/+YT9iQUrjA3PlmMo/HOXMy986d7/c9M/ckz3znc7/faq0FAABIthh6AAAA2FSIYwAA6MQxAAB04hgAADpxDAAAnTgGAIBu9tADbGjbbbdtixYtGnoMAAA2Y8uXL7+ptbbd/X1sk4rjRYsWZdmyZUOPAQDAZqyqVvx7H7OsAgAAOnEMAACdOAYAgG6TWnN8f9auXZuVK1dm9erVQ48ybcybNy8LFizInDlzhh4FAGBa2eTjeOXKlXnMYx6TRYsWpaqGHmeT11rLzTffnJUrV2aXXXYZehwAgGllk19WsXr16myzzTbCeERVlW222caRdgCAh2GTj+Mkwvgh8v0CAHh4pkUcD+nqq6/ObrvtNpZtf+tb38pBBx2UJPnyl7+c4447biz7AQBgNJv8muONLdxhh1xzww2Ttr2dt98+K66/ftK293AdfPDBOfjgg4ceAwBgRpt2cXzNDTdk2Y47Ttr29rzuugd9zN13353DDjssF154YZ761Kfm5JNPzl/91V/lK1/5Su6666485znPyQknnJCqygc/+MF87GMfy+zZs7N48eKceuqpufPOO/PmN785l112WdauXZslS5bkZS972X328elPfzrLli3Lhz/84bzuda/L/Pnzs2zZstxwww1573vfm0MPPTRJ8r73vS+nnXZa1qxZk5e//OV597vfPWnfCwCAmc6yihFceeWVOeqoo3L55Zdn/vz5+ehHP5qjjz46F1xwQS677LLcddddOeOMM5Ikxx13XC666KJccskl+djHPpYkOfbYY7Pffvvl/PPPz9KlS/O2t70td9555wPu8/rrr8+5556bM844I29/+9uTJGeddVauuuqqnH/++bn44ouzfPnynHPOOeP94gEAZhBxPIKddtop++yzT5Lk8MMPz7nnnpulS5fm2c9+dp72tKfl7LPPzg9+8IMkydOf/vQcdthhOeWUUzJ79sSB+bPOOivHHXdcdt9997zgBS/I6tWrc8011zzgPg855JBsscUWWbx4cX72s5/du52zzjorz3jGM7LHHnvkiiuuyFVXXTXGrxwAYGaZdssqhrDx2R+qKkcddVSWLVuWnXbaKUuWLLn31Glf/epXc8455+QrX/lKjj322Fx66aVpreX000/Prrvuep/trI/e+zN37tx732+t3fvnO97xjhx55JGT9aUBALABR45HcM011+S8885Lknz2s5/NvvvumyTZdttts2rVqvz93/99kmTdunX56U9/mhe+8IU5/vjjc/vtt2fVqlU54IAD8qEPfejeyL3ooose1hwHHHBATjrppKxatSpJcu211+bGG298pF8eAACdI8cj2HXXXfORj3wkr3/967N48eK86U1vyq233prddtst22+/ffbaa68kyT333JPDDz88t99+e1prectb3pKtt946f/7nf563vvWtefrTn55169Zll112uXeN8kOx//775/LLL8/ee++dJNlqq61yyimn5PGPf/ykfr0AADNVrT+aOekbrjopyUFJbmytjXSi4D333LMtW7bsPvddfvnlecpTnnLv7c31VG6TbePvGwAAE6pqeWttz/v72DiPHH86yYeTnDyZG90cQxYAgE3D2NYct9bOSXLLuLYPAACTzQvyAACgG/wFeVV1RJIjkmTnnXcedJZLvv/9/HLt2infb9UWaW3dpG7zpptuyuLFix/wMVtuuWXuuuuuSd3vKHbeeeesWLFiyve7KXvCExbluuum/nsyb968e09DONX7HeK5t6l61KO2zNq1w/wc/PxhZlu4cOGDXnthHDblFhg8jltrJyY5MZl4Qd6Qs/xy7do8Zc6cKd/v5WvXZrvt7ndN+MO2evXlOeKIB/52nnhi5boRLp892XacxMt/by6uu27Fg/68xuHEEyvjelHuA9n43OEz3dq1q3PCCVP/czjySD//TcVQ/0HecceFufbaq6d8v2w6rrnmGi2wkcHjGABmuiH/gwzc19jiuKo+l+QFSbatqpVJ3tVa++S49jdOW+2+e175kpfkk+95T5Lk7rvvzhNf9KLstdtuedmv/3o++tnPJkmu+MlP8qRFizJriy3yon32yV8cc8yQYzONzJo11z9SMIMN9XfArFlzH/xBMMOMLY5ba68ex3Z32mlRVq6cvF89LViwMD/96dUP+JhHb7llfvjjH+eu1auz5bx5Oft738uO222XJHntIYfktYcckiRZfOCB+drHP55tH/e4SZuPmeGee9ZkyZKpP2q0ZIkgh02BvwMYamkN/9a0W1axcuWKSV2bd+SRo/3FcMC+++bM73wnL3/Ri/KFM8/MKw48MP984YWTNgcAM9fs2XMHCdXZsx053lRYWrPpmHZxPJRDX/zi/OWJJ+bA5z0vl/3oR3nty14mjgGYFHffvWawF2UC9yWOR7Tbk5+ca667Ll/4+tdzwL77Dj0OAMAjNnfu3EHOHDF37qb7Wwtx/BC85PnPz5/9zd/ka5/4RG657bahxwEAeETWrFmTO+64Y8r3O3/+/Cnf56jE8UPwO4ccksc+5jHZ7UlPyjkXXDD0OAAATDKXj34InvArv5KjXvOaoccAAGBMpt2R4wULFk7qCwgWLFj4oI/52Xnn/Zv7nrfXXnneXnvd574ffv3rkzYXAEyFIa5YuClfOhimXRw/2DmJAYDRuXQw3JdlFQAA0E27I8cAAJuboS4hPnfu3EHOHOFUbsADGurqWABsGoa8hHhrU7/fIda6j0ocwybA1bEAYNNgzTEAAHSOHD+Am2+7LQcdcUSS5Gc335xZW2yRbR/3uKz6xS+ybt26fOdzn8t/fOxjc+sdd2TfV70qX/v4x5Mkh77lLbng9NOHHB0AgIdh2h05XrRoUapq0t4WLVr07+5rm623znmnnZbzTjstv3/ooTn68MNz3mmn5dIzzsgbXvGKvPMDH0iSvPMDH8jv/dZvZeETnjBF3wUAAMZh2sXxihUr0lqbtLeHexLyow8/PBdcemk+csopOe+ii3LM7/zOJH+lAABMNcsqHqY5c+bk2D/6oxxy1FH58t/9XebMmTP0SAAAPELT7sjxpuSsc8/N9tttlx/++MdDjwIAwCQQxw/TJVdckbO/970sPfnkfPgzn8kNP//50CMBAPAIieOHobWWt77nPXnv296WnXbYIcf87u/mv7///UOPBQDAIySOH4ZPnX56Fmy/ffbbe+8kyRG//du58l/+Jd9ZtixJctWKFXny/vvf+/bFs84aclwAAEY07V6Qt3Dhwkm95ODChQtHetyfvelN977/+kMPzesPPfTe27Nmzcp3Tz313tu39UgGAGB6mXZxfPXVVw89AgAAmynLKgAAoBPHAADQTYs4bq0NPcK0MnH1v6GnAACYfjb5OJ43b15uvvlmgTyi1lp+8Yubc8st84YeBQBg2tnkX5C3YMGCrFy5Mj+fgots3HTTTfnxrFlj38+/2e8992T16ssnZVutJbfcMi9nn71gUrYHAIzf7Nlzs2TJ5J2Ni4dvk4/jOXPmZJdddpmSfS1evDjLdtxxSva1oQOvuy5HHOHIOADMVHffvSYnnDD1LXDkkYJ8Y5v8sgoAAJgq4hgAADpxDAAAnTgGAIBOHAMAQCeOAQCgE8cAANCJYwAA6MQxAAB04hgAADpxDAAAnTgGAIBOHAMAQCeOAQCgE8cAANCJYwAA6MQxAAB04hgAADpxDAAAnTgGAIBOHAMAQCeOAQCgE8cAANCJYwAA6MQxAAB04hgAADpxDAAAnTgGAIBu9tADAADD2XHHHad8n3Pnzp3yfcKoxDEAzGB33HHHlO9z/vz5U75PGJVlFQAA0IljAADoxDEAAHTiGAAAOnEMAACdOAYAgE4cAwBAJ44BAKATxwAA0IljAADoxDEAAHTiGAAAOnEMAACdOAYAgE4cAwBAJ44BAKATxwAA0IljAADoxDEAAHTiGAAAOnEMAACdOAYAgE4cAwBAJ44BAKATxwAA0IljAADoxDEAAHTiGAAAOnEMAACdOAYAgE4cAwBAJ44BAKATxwAA0IljAADoxDEAAHTiGAAAOnEMAACdOAYAgE4cAwBAJ44BAKATxwAA0IljAADoxDEAAHTiGAAAOnEMAACdOAYAgE4cAwBAJ44BAKATxwAA0IljAADoxDEAAHTiGAAAOnEMAACdOAYAgE4cAwBAJ44BAKATxwAA0IljAADoxDEAAHTiGAAAOnEMAACdOAYAgE4cAwBAJ44BAKATxwAA0IljAADoxDEAAHTiGAAAOnEMAACdOAYAgE4cAwBAJ44BAKATxwAA0M0eegAAYBhz587N/PnzB9kvbKrEMQDMUGvWrElrbcr3W1VTvk8YlWUVAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAN1IcVxVX6yql1aVmAYAYLM1aux+NMlrklxVVcdV1a5jnAkAAAYxUhy31v6ptXZYkj2SXJ3kn6rqn6vq96pqzjgHBACAqTLyMomq2ibJ65K8IclFST6QiVj+5lgmAwCAKTZ7lAdV1T8k2TXJ/0ryX1tr1/cPfb6qlo1rOAAAmEojxXGSD7bWlt7fB1pre07iPAAAMJhRl1Usrqqt19+oqsdV1VHjGQkAAIYxahy/sbV22/obrbVbk7xxLBMBAMBARo3jWVVV629U1awkjxrPSAAAMIxR1xyfmYkX353Qbx/Z7wMAgM3GqHH8p5kI4jf1299M8omxTAQAAAMZKY5ba+uS/F1/AwCAzdKo5zl+UpK/TLI4ybz197fWfnVMcwEAwJQb9QV5n8rEUeO7k7wwyclJThnXUAAAMIRR43jL1tr/TlKttRWttSVJXjq+sQAAYOqN+oK8NVW1RZKrquroJNcm2Wp8YwEAwNQb9cjxMUn+Q5K3JHlmksOT/O64hgIAgCE86JHjfsGPV7bW/iTJqiS/N/apAABgAA965Li1dk+SfadgFgAAGNSoa44vqqovJ/lCkjvX39la++JYpgIAgAGMGsfzktycZL8N7mtJxDEAAJuNUa+QZ50xAACbvVGvkPepTBwpvo/W2usnfSIAABjIqMsqztjg/XlJXp7kuskfBwAAhjPqsorTN7xdVZ9Lcu5YJgIAgIGMehGQjT0pyeMncxAAABjaqGuO/zX3XXN8Q5I/HctEAAAwkFGXVTxm3IMAAMDQRlpWUVUvr6rHbnB766o6ZGxTAQDAAEZdc/yu1trt62+01m5L8q6xTAQAAAMZNY7v73GjngYOAACmhVHjeFlVvb+qntjf3p9k+TgHAwCAqTZqHL85yS+TfD7JqUlWJ/nDcQ0FAABDGPVsFXcmefuYZwEAgEGNeraKb1bV1hvcflxVfWNsUwEAwABGXVaxbT9DRZKktXZrXCEPAIDNzKhxvK6qdl5/o6oW5b5XzAMAgGlv1NOx/VmSc6vq20kqyXOTHDG2qQAAYACjviDvzKraMxNBfFGSLyW5a4xzAQDAlBspjqvqDUmOSbIgycVJ/kuS85LsN7bJAABgio265viYJHslWdFae2GSZyS5bVxDAQDAEEaN49WttdVJUlVzW2tXJNl1fGMBAMDUG/UFeSv7eY6/lOSbVXVrkhXjGgoAAIYw6gvyXt7fXVJVS5M8NsmZY5sKAAAGMOqR43u11r49jkEAAGBoo645BgCAzZ44BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQiWMAAOjEMQAAdOIYAAA6cQwAAJ04BgCAThwDAEAnjgEAoBPHAADQjTWOq+rFVXVlVf24qt4+zn0BAMAjNbY4rqpZST6S5MAki5O8uqoWj2t/AADwSI3zyPGzkvy4tfaT1tovk5ya5GVj3B8AADwi44zjJyT56Qa3V/b7AABgk1SttfFsuOrQJC9urb2h335tkme31o7e6HFHJDmi39w1yZVjGWjztW2Sm4YegkF5Dsxsfv54DuA58NAtbK1td38fmD3GnV6bZKcNbi/o991Ha+3EJCeOcY7NWlUta63tOfQcDMdzYGbz88dzAM+ByTXOZRUXJHlSVe1SVY9K8qokXx7j/gAA4BEZ25Hj1trdVXV0km8kmZXkpNbaD8a1PwAAeKTGuawirbWvJfnaOPeBJSl4Dsxwfv54DuA5MInG9oI8AACYblw+GgAAOnE8TVXVSVV1Y1VdNvQsTL2q2qmqllbVD6vqB1V1zNAzMbWqal5VnV9V3+/PgXcPPRNTr6pmVdVFVXXG0LMwjKq6uqouraqLq2rZ0PNsDiyrmKaq6nlJViU5ubW229DzMLWqaockO7TWLqyqxyRZnuSQ1toPBx6NKVJVleTRrbVVVTUnyblJjmmtfW/g0ZhCVfXHSfZMMr+1dtDQ8zD1qurqJHu21pzneJI4cjxNtdbOSXLL0HMwjNba9a21C/v7/5rk8rgC5YzSJqzqN+f0N0c7ZpCqWpDkpUk+MfQssDkRxzDNVdWiJM9I8n8GHoUp1n+lfnGSG5N8s7XmOTCz/G2S/5Zk3cBzMKyW5KyqWt6vOswjJI5hGquqrZKcnuStrbU7hp6HqdVau6e1tnsmrkD6rKqyxGqGqKqDktzYWls+9CwMbt/W2h5JDkzyh33ZJY+AOIZpqq8zPT3JZ1prXxx6HobTWrstydIkLx54FKbOPkkO7utNT02yX1WdMuxIDKG1dm3/88Yk/5DkWcNONP2JY5iG+ouxPpnk8tba+4eeh6lXVdtV1db9/S2TvCjJFYMOxZRprb2jtbagtbYoyauSnN1aO3zgsZhiVfXo/qLsVNWjk+yfxFmsHiFxPE1V1eeSnJdk16paWVW/P/RMTKl9krw2E0eLLu5vLxl6KKbUDkmWVtUlSS7IxJpjp/OCmeVXkpxbVd9Pcn6Sr7bWzhx4pmnPqdwAAKBz5BgAADpxDAAAnTgGAIBOHAMAQCeOAQCgE8fAjFNVrar+eoPbf1JVSyZp25+uqkMnY1sPsp9XVNXlVbV03PuaTFW1u9MOApsycQzMRGuS/GZVbTv0IBuqqtkP4eG/n+SNrbUXjmueMdk9iTgGNlniGJiJ7k5yYpI/2vgDGx/5rapV/c8XVNW3q+ofq+onVXVcVR1WVedX1aVV9cQNNvMbVbWsqn5UVQf1z59VVe+rqguq6pKqOnKD7X6nqr6c5If3M8+r+/Yvq6rj+33vTLJvkk9W1fs2evwOVXVOvzDMZVX13H7//lV1XlVdWFVfqKqt+v0vqaorqmp5VX2wqs7o9y+pqv/ZZ1tRVb9ZVe/ts5zZL1+eqnpm/74sr6pvVNUO/f5vVdXx/fvzo6p6blU9KslfJHlln++VVfX8DS5kc9H6q30BDEUcAzPVR5IcVlWPfQif85+T/EGSp2TiCoVPbq09K8knkrx5g8ctSvKsJC9N8rGqmpeJI723t9b2SrJXkjdW1S798XskOaa19uQNd1ZVOyY5Psl+mTjiuldVHdJa+4sky5Ic1lp720YzvibJN1pru/d5L+5HyP9Hkt9ore3RP/eP+1wnJDmwtfbMJNtttK0n9n0fnOSUJEtba09LcleSl/ZA/lCSQ/vnn5Tk2A0+f3b//rw1ybtaa79M8s4kn2+t7d5a+3ySP0nyh33e5/ZtAwzmofwKD2Cz0Vq7o6pOTvKWjB5kF7TWrk+Sqvq/Sc7q91+aZMPlDae11tYluaqqfpLk15Lsn+TpGxyVfmySJyX5ZZLzW2v/cj/72yvJt1prP+/7/EyS5yX50gPNmOSkHq5faq1dXFXPT7I4yXerKkkelYnLz/9akp9ssO/PJTlig219vbW2tqouTTIryfrL0l6aif8A7JpktyTf7NudleT6DT7/i/3P5f3x9+e7Sd7fv7YvttZWPsDXBjB24hiYyf42yYVJPrXBfXen/1atqrbIREiut2aD99dtcHtd7vv3adtoPy1JJXlza+0bG36gql6Q5M6HM/z9aa2dU1XPy8RR609X1fuT3Jrkm621V2+0790fZHNr+jbXVdXa1tr6r2v911tJftBa2/uBPj/JPfl3/r1prR1XVV/NxDrk71bVAa21Kx5kLoCxsawCmLFaa7ckOS0TSx7WuzrJM/v7ByeZ8zA2/Yqq2qKvQ/7VJFcm+UaSN22wVvfJVfXoB9nO+UmeX1XbVtWsJK9O8u0H+oSqWpjkZ621j2diucceSb6XZJ+q+k/9MY+uqif3uX61qhb1T3/lQ/w6r0yyXVXt3bc7p6qe+iCf869J7l1XXFVPbK1d2lo7PhNHvX/tIc4AMKnEMTDT/XWSDc9a8fFMBOn3k+ydh3dU95pMhO3Xk/xBa211JkL1h0kurKrLMrHW9wF/e9eXcLw9ydIk30+yvLX2jw+y7xck+X5VXZSJ2P1AX5bxuiSfq6pL0pdUtNbuSnJUkjOrankmwvX2Ub/Ivob40CTH9+/XxUme8yCftjTJ4vUvyEvy1v7CwUuSrM3E9wxgMPX/f0sGwExTVVu11lbVxKLhjyS5qrX2N0PPBTAUR44BZrY3VtXFSX6QiRcJnjDsOADDcuQYAAA6R44BAKATxwAA0IljAADoxDEAAHTiGAAAOnEMAADd/wPjmI57/mRYDgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df = retrieval\n",
    "n_chunks = [1, 2, 3, 4, 5]\n",
    "plot_df = pd.DataFrame(index = n_chunks)\n",
    "\n",
    "plot_df['baseline'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].max() for i in n_chunks]\n",
    "plot_df['MT'] = [df[(df.num_mem_tokens > 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].max() for i in n_chunks]\n",
    "plot_df['TXL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len > 0) & (df.n_chunks == i)]['test acc'].max() for i in n_chunks]\n",
    "plot_df = plot_df.sort_index()\n",
    "plot_df.loc[1] = 1\n",
    "ax = plot_df.reset_index().plot(x='index', kind='bar', figsize=(12, 8), cmap='BuPu', edgecolor='k', width=0.7, color=[(0.8, 0.1, 0.1), (0.4, 0.4, 1), (0.9, 0.9, 0.9)], legend=False)\n",
    "\n",
    "plot_df['baseline'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].mean() for i in n_chunks]\n",
    "plot_df['MT'] = [df[(df.num_mem_tokens > 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].mean() for i in n_chunks]\n",
    "plot_df['TXL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len > 0) & (df.n_chunks == i)]['test acc'].mean() for i in n_chunks]\n",
    "plot_df = plot_df.sort_index()\n",
    "\n",
    "plot_df.reset_index().plot(x='index', kind='bar', ax=ax, cmap='BuPu', edgecolor='k', width=0.7, color=[(0.8, 0.1, 0.1), (0.5, 0.5, 1), (0.95, 0.95, 0.95)], legend=False)\n",
    "\n",
    "plot_df['baseline'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].min() for i in n_chunks]\n",
    "plot_df['MT'] = [df[(df.num_mem_tokens > 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].min() for i in n_chunks]\n",
    "plot_df['TXL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len > 0) & (df.n_chunks == i)]['test acc'].min() for i in n_chunks]\n",
    "plot_df = plot_df.sort_index()\n",
    "\n",
    "\n",
    "plot_df.reset_index().plot(x='index', kind='bar', ax=ax, cmap='BuPu', edgecolor='k', width=0.7, color=[(0.8, 0.1, 0.1), (0.6, 0.6, 1), 'w'], legend=True)\n",
    "\n",
    "\n",
    "plt.xlabel('Number of segments')\n",
    "plt.xticks(rotation=0)\n",
    "plt.yticks([0, 1])\n",
    "plt.ylabel('accuracy')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 237,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAs8AAAHmCAYAAACMOWPUAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAAreElEQVR4nO3de5yXdZ3//yczgKAozrAIctAQbUwBDwSmhCaUpEYZq64tUpQG5MZXzDywmkjR6njKQCusxXYJS3TxBNqmZZpWLtmWaEUppY0IIqNjIIgcfn+0za8JkzeIMxzu99vN223m+ryv63p94HPr9uji+nw+rTZs2LAhAADAJlW09AAAALC9EM8AAFBIPAMAQCHxDAAAhcQzAAAUat3SA5RavXp1Hn/88XTu3DmVlZUtPQ4AADugdevWZdmyZenTp0/atWu30ePbTTw//vjjGTlyZEuPAQDATmDWrFl55zvfudH27SaeO3funOTPT6Rr164tPA0AADuiJUuWZOTIkY3t+be2m3j+y60aXbt2TY8ePVp4GgAAdmR/7zZhbxgEAIBC4hkAAAqJZwAAKCSeAQCg0HbzhkEAgOa0fv361NXVZeXKlS09CltRmzZtstdee2WPPfbYov3FMwDA63jhhRfSqlWr1NTUpKLCP9bvCDZs2JBVq1bl2WefTZItCmivBACA1/HSSy+lS5cuwnkH0qpVq+y6667p3r17nn/++S06hlcDAMDrWLduXdq0adPSY/AWaN++fV577bUt2lc8AwD8Ha1atWrpEXgLvJm/V/EMAACFxDMAwA7mwgsvzIUXXtiiM3zrW99KTU1NampqMmTIkDdcW1dXl5qamvzsZz9rpum2nE/bAAAo9KXa2ry8enWznnOPdu1yzgUXNOs5t4Z//Md/zLBhw3L33XfnP/7jP95w7d57752HHnooe+65Z/MM9yaIZwCAQi+vXp0P3HBDs55z7pgxzXq+raV9+/Zp3759dt99902uraysTOfOnZthqjev6LaNJ598MmeffXaGDh2ampqaTJs2bbNPdP/99+eEE05Inz598oEPfCA/+tGPNvsYAACUWbVqVc4555wccsghGTJkSO66667Gxy677LIMGzYs/fr1y5FHHpmLL744f/rTn5rsf++992b48OGNa8aNG5dXX3218fH169fnq1/9ao499tgccsghOfnkkzf7totly5Y13trx927bGDJkSG644YZ88pOfzCGHHJITTzwxv/jFL5qs+e1vf5szzjgjhx56aAYPHpwpU6Zk9Vv0LwRF8bxy5cp07do1EyZMSJcuXTb7JE8++WTGjx+foUOH5vbbb8/gwYNz1lln5emnn97sYwEAsGn33ntv9t1339x+++059dRTc/7552fRokVJkldffTWf+9znMm/evFx33XV59NFH8/nPf75x3xdeeCHnnHNOhg4dmnnz5mXGjBk57LDDsm7dusY1X/3qV3PLLbfk85//fObOnZthw4blzDPPzHPPPVc8Y6dOnfLQQw/llltuecN1M2fOzGmnnZY5c+akqqoqn/vc5xofa2hoyEc/+tHst99+ue222zJt2rQ88sgjufLKK4vn2BxF8XzIIYdk4sSJGT58eHbZZZfNPsns2bPTvXv3nHvuudl///1zwQUXpEuXLpk9e/ZmHwsAgE3r2bNnJkyYkF69emXcuHHp3bt3Y6Reeumlefe7352ePXumf//++ed//uc88MADjfsuWbIkr732WoYOHZqePXvmHe94R8aOHZtdd901yZ/j+4YbbsjEiRMzePDg9OzZM5/85CfTs2fPJle4N6WioiKdO3dOdXX1G64bPnx4hg4dmt69e2fUqFH57W9/23hleebMmdlrr71y0UUXpVevXjn00EPz6U9/Orfeems2bNiwuX9sm9Qs9zwvWLAgAwcObLJtwIABeeyxx5rj9AAAO52ampomvx9wwAGN/+p/77335pvf/GaefvrprFy5MmvXrm0SmgceeGAGDBiQ0aNH56ijjkq/fv1ywgknpHv37kmSp59+OqtXr855553X5DOTX3311fzxj3/c6s+lV69ejT//5U2FDQ0NadeuXX7729/mqaeeymGHHda4Zv369Vm9enWef/75Lbpr4o00SzzX19enuro69913XyZOnJgZM2akurpaPAMANKNWrVrll7/8Zc4555ycffbZGTx4cNq3b5+5c+fm+uuvb1zXunXr/Od//mcee+yxzJ8/P/PmzctXvvKV3Hrrrendu3fjVd+pU6dm3333bXKODh06bPW5KysrN9r2l9hftWpVjjrqqFx88cUbrenUqdNWn6VZP21jt912y95775327ds352mbRUt8dE2JVq1aZ8OGtS09RhOtW7fJ2rVb9pWYb5WOHTtmwoQJLT3GDuXqq6/NihUNLT1GE157O4dt8bWXJB06dMy5505o6THYTi1evHiz1r/yyiv51a9+lcWLF6eiojJdu3bJ7373uxx99NF59NFH8/a3vz2f/OQnG9cvXbp0o2NUVFTk0EMPzaGHHpqPfexjOfLII/PQQw+ld+/e2W+//dKmTZssXbo0Rx999BvOsuuuu75lb95Lkne84x2ZN29eunfvntat3/q0bZZ4rq6uTn19fY488sjceeedSf7/q9E7ipb46JoSc8eMyd57T2rpMZp47rnJmTRp25pp8uTJLT3CDmfFigavvQJee1vftvjaS/78+oMt1aZNt81aX1GxaxYvXpz//M//yrHHDsztt9+WRYsWZdq0afnDH/6Qp556Kj/4wQ9ywAEH5MEHH8x///d/N9n/sccey4MPPpijjz46nTp1ysMPP5yVK1c23grSoUOHjBo1KldddVV22WWXHHbYYVm6dGm+//3v55hjjsm73vWuxmMdfPDBeemll3LXXXflXe96V9q1a9f48XV/+tOfsnr16tTX1yf5860Yy5YtS5s2bYo/8/kjH/lIvv3tb+e8887LmWeemfbt22fBggX5xS9+8Zb8b/5Wjee6urrssssuG31OX9++fZvchJ4k8+fPz7Bhw7bm6QEA+D/HHHNcnn76qZx55g3p3LlzrrzyyvTq1Su9evXKxz/+8Vx88cV55ZVXGj8Frba2tnHf3XffPb/85S8za9asrFixIt27d8+ll17aJIrPO++8VFVVZerUqVmyZEmqq6vzzne+M926NQ39nj175l//9V9z+eWX54UXXsiHP/zhXH755UmSL37xi7ntttsa15511llJkoEDB2bmzJlFz3PvvffOrFmzctVVV+X0009P8ud7pEeMGLFlf3CbUBTPa9asyVNPPZUkee2117Js2bL8+te/TseOHZv8AQ0dOvR1n+ypp56am266KVdffXVOOumk3HrrrVm6dGlOPfXUrfhUAADeWnu0a9fsX1rSoW27zd7noosub/z5tdcWbxS0EyZM2OiWsY997GONP/fq1Stf//rX3/AcFRUVGTNmTMYU/HmcfvrpjWH71y6//PLGkP57fvCDHzT5/YgjjsjChQubbHv729+eG5rpDoCieH7++edz0kknNf5+88035+abb27y/xzeyP7775+pU6fmqquuyo033pi3ve1tuf766ze6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Psm9996b008/PUcccUT69++fUaNG5Wc/+9kWDQwAAC2lKJ5vueWWTJs2Leeff35mz56dioqKjB07NmvXri06yaOPPpohQ4ZkxowZmT17djp37pwzzzwzv//979/U8AAA0JxalyyaNWtWRowYkeHDhydJpkyZkmOPPTYPP/xwjjnmmE3uf+GFFzb5fdKkSZk3b15+9KMfpVevXlswNgAANL9NXnles2ZNFi5cmAEDBjRu69atW3r06JEFCxZs0UlffvnlJMkee+yxRfsDAEBL2GQ8v/jii1m/fn2qq6tTW1uboUOHZtWqVamurs7y5cu36KRf+tKX0rNnzwwbNmyL9gcAgJZQdNvGX1RVVaVbt26prKzc4hN+/etfz49+9KPcdNNNad++/RYfBwAAmtsmrzxXVVWloqIi9fX1GTNmTGbOnJm2bdumvr4+nTp12qyTzZo1K1/72tfyjW98IwcccMAWDw0AAC1hk/Hctm3b1NTUZP78+Y3bFi9enLq6uvTt27fJ2rq6uixbtux1j3Prrbfmmmuuyde//vUccsghb3JsAABofkW3bYwcOTKTJ0/OgAEDcsABB+SKK65Ir169MmjQoCbrhg4dmoEDB2bmzJlNtt955535whe+kCuvvDI9e/ZsDOxdd901u+2221Z6KgAA/K3KyspMnjy5pcdoomPHjpkwYUJLj7FFiuL5lFNOyfLly1NbW5uGhob0798/06dPT+vWZbdM33LLLVm9enXGjx/fZPunP/3pjbYBALD1rFu3LpMmTWrpMZrY1mJ+cxS/YXDcuHEZN27cG65ZuHDh627/2yvRAACwPSr+em4AANjZiWcAACgkngEAoJB4BgCAQuIZAAAKiWcAACgkngEAoJB4BgCAQuIZAAAKiWcAACgkngEAoJB4BgCAQuIZAAAKiWcAACgkngEAoJB4BgCAQuIZAAAKiWcAACgkngEAoJB4BgCAQuIZAAAKiWcAACgkngEAoJB4BgCAQuIZAAAKiWcAACgkngEAoFDrlh4AePO+VFubl1evbukxAGCHJ55hB/Dy6tX5wA03tPQYTcwdM6alRwCArc5tGwAAUEg8AwBAIfEMAACFxDMAABQSzwAAUEg8AwBAIfEMAACFxDMAABQSzwAAUEg8AwBAIfEMAACFxDMAABQSzwAAUEg8AwBAIfEMAACFxDMAABQSzwAAUEg8AwBAIfEMAACFxDMAABQSzwAAUEg8AwBAIfEMAACFxDMAABQSzwAAUEg8AwBAIfEMAACFxDMAABQSzwAAUEg8AwBAIfEMAACFxDMAABQSzwAAUEg8AwBAIfEMAACFxDMAABQSzwAAUEg8AwBAIfEMAACFxDMAABQSzwAAUEg8AwBAIfEMAACFiuN5+vTpGTx4cPr165fRo0fnmWee2awT3X///TnhhBPSp0+ffOADH8iPfvSjzR4WAABaUlE833LLLZk2bVrOP//8zJ49OxUVFRk7dmzWrl1bdJInn3wy48ePz9ChQ3P77bdn8ODBOeuss/L000+/qeEBAKA5FcXzrFmzMmLEiAwfPjwHHnhgpkyZkkWLFuXhhx8uOsns2bPTvXv3nHvuudl///1zwQUXpEuXLpk9e/abGh4AAJpT600tWLNmTRYuXJgzzjijcVu3bt3So0ePLFiwIMccc8wmT7JgwYIMHDiwybYBAwbkscceKx503bp1SZIlS5YU79OcVqxYkWWtWrX0GBtZsWJFGhrqWnqMJlasWJG6OjNtTdvi689rr8y2ONP2blt87SXb5t/1tjjT9m5bfP1ti3/P2+JMf/GX1vxLe/6tVhs2bNjwRgdYunRpjj766MyYMSMPPfRQvve972Xu3Ln56Ec/mj59+mTSpEmbHGLYsGF5//vfn759+2bixImZMWNGvvvd7+aHP/xh5s2bV/REfvazn2XkyJFFawEA4M2YNWtW3vnOd260fZNXnv9aVVVVunXrlsrKyi0aYrfddsvee++d9u3bb/a+ffr0yaxZs9K5c+ctPj8AALyRdevWZdmyZenTp8/rPr7JeK6qqkpFRUXq6+szZsyYjBkzJklSX1+fTp06FQ1RXV2d+vr6HHnkkbnzzjsb96+uri59HmnXrt3r1j8AAGxN++677999bJNvGGzbtm1qamoyf/78xm2LFy9OXV1d+vbt22RtXV1dli1bttEx+vbtm//5n/9psm3+/Pnp16/fJocHAIBtRdGnbYwcOTJz5szJXXfdld/85je5+OKL06tXrwwaNKjJuqFDh+Yzn/nMRvufeuqpefbZZ3P11VfnqaeeSm1tbZYuXZpTTz116zwLAABoBkX3PJ9yyilZvnx5amtr09DQkP79+2f69Olp3brslun9998/U6dOzVVXXZUbb7wxb3vb23L99de/4SVxAADY1mzy0zYAAIA/K/56bgAA2NmJZwAAKCSeAQCgkHgGAIBCm/UNgwBvtddeey2///3v06NHj+y6665Zs2ZN5s2bl1deeSVHH310evbs2dIjshN47rnnMm/evCxdujRdu3bN8ccfn27durX0WOyg1qxZkwceeCBPPPFE6uvrU1FRkS5duuSII47I4Ycf3tLj8Td82gab7bnnnsvUqVNz2WWXtfQo7GAWLVqUT3ziE1myZEk6deqUb33rW5k4cWJ++9vfplWrVtmwYUNuvPHGHHLIIS09KjuYiRMn5n3ve1+GDBmS+fPn58wzz8wee+yR7t27Z8mSJXnppZdyww03ZODAgS09KjuYp556KmeeeWaee+65tGrVKpWVldl///2zZMmSNDQ0ZNCgQZk6dWp23XXXlh6V/+O2DTZbQ0NDbr/99pYegx3QVVddlX79+uWOO+7IsGHDctZZZ6W6ujqPPPJIHnnkkRx77LGZOnVqS4/JDuj+++9Pr169kiRf+tKXctppp+XBBx/Md77znfzwhz/Mxz/+8Vx55ZUtPCU7oi984Qvp27dvHnnkkTz66KMZOXJkDjrooPzkJz/J1772tSxatCjXXHNNS4/JX3HlmY1cd911b/j4Cy+8kJtvvjm//vWvm2kidhZHHnlkZs6cmf333z8rVqzIO9/5zsyaNSv9+/dPkvzqV7/KGWeckZ/85CctPCk7mkMOOSRz5sxJ7969c9RRR2XGjBk58MADGx9/5pln8qEPfSj/+7//24JTsiM69NBDM2fOnOy3335JkldffTX9+/fPj3/84+yxxx558MEH86//+q956KGHWnhS/sI9z2zkuuuuS9euXdO2bdvXffy1115r5onYWaxevTq77LJLkqRDhw5p37599tprr8bH99hjj7zyyistNR47sJqamsydOzdnn312ampq8vOf/7xJPP/85z9Px44dW3BCdlQdOnTIqlWrGn9/9dVXs3bt2lRU/PnmgP333z8vv/xyS43H6xDPbKRHjx4555xzcuKJJ77u47/+9a8zYsSIZp6KnUG3bt1SV1fX+KbA6dOnp0uXLo2P19XVpVOnTi01Hjuw8ePH51Of+lSeffbZxntMf/7zn+dtb3tb/vjHP+aee+7JuHHjWnpMdkDvete7cskll+RTn/pU2rRpk5kzZ+aggw5Khw4dkiS/+93vsvfee7fwlPw19zyzkT59+uTxxx//u4//5Y1bsLUdf/zxef755xt/HzhwYJN/AbnvvvvSp0+flhiNHdzgwYNz44035vnnn8+Xv/zlvPTSS5k7d26uv/76PPHEEznvvPNy1llntfSY7IAmTpyYjh07Zvz48Rk7dmzq6+tTW1vb+HhVVVWmTJnSghPyt9zzzEaeeuqprFy5Mv369Xvdx1977bU8//zz6d69ezNPxs7ulVdeSevWrf/uLUWwNaxduzYvvvhi1q9fn6qqKq83msXq1auzdu3axivObLvEMwAAFHLbBgAAFBLPAABQSDwDbGOGDBmSadOmbbXjjRo1KhdeeOFWOx7AzsxH1QFsY6677rpUV1e39BgAvA7xDLCNOeigg1p6BAD+DrdtAGwDXn311dTU1DT+97e3bdTV1aWmpibz5s3L2LFjc+ihh+Z973tf7rvvvibrVq5cmYkTJ+bwww/PEUcckeuuu+51z/e73/0u48aNy+GHH57DDjss48ePb/IZ2w899FAOPPDAPPDAA43bVq1alWHDhmX8+PFb8ZkDbF/EM8A2oG3btrn55ptz8803p3Pnzn933ZVXXtkYxfvss0/OP//8rFixovHxL3zhC/nud7+b888/P5dddlnuv//+PPbYY02O8Yc//CEf+chHsmzZslxxxRW5/PLL89RTTzX5EpB3v/vdGTVqVC666KK8+OKLSZLa2tqsWrUqX/jCF7byswfYfrhtA2Ab0KpVqxx66KFJ8oZfynHiiSfmE5/4RJKkZ8+eOe644/LYY4/lqKOOyrJly3LXXXflM5/5TE477bQkSU1NTd773vc2OcZ1112XysrKzJgxIx07dkyS7LfffvnABz6QBx98MEcffXSS5LzzzstPf/rTXHLJJTnllFNy8803Z8aMGdlzzz238rMH2H648gywHTn88MMbf+7Ro0eS5IUXXkiSPPnkk1m7dm2OOOKIxjXdu3fPvvvu2+QYP/nJTzJo0KDstttuWbt2bdauXZtevXpljz32yBNPPNG4rm3btrn66qvzwAMP5Oyzz87o0aNz5JFHvpVPD2Cb58ozwHbkr7+6t7KyMsmfv046Serr65Ok8WryX/ztleKXXnop8+bNy7x58zY6/nPPPdfk97e//e3p06dPHn300Xz4wx9+0/MDbO/EM8AOolOnTkmShoaG9OzZs3H7Sy+91GTdnnvumUGDBmXUqFEbHeNvPyJv1qxZeeKJJ3LooYdm4sSJ+c53vpM2bdps/eEBthNu2wDYQRxwwAFp06ZNHnnkkcZtixcvztNPP91k3bve9a48+eSTOeigg9K3b98m/3Xv3r1x3e9+97tcccUVOffcczN16tTU1dXl2muvba6nA7BNcuUZYBvwzDPPNN52sWbNmixZsiS/+MUvkiT77LNP0TE6deqUD37wg7n++uvToUOHdO7cOV/96lc3egPiv/zLv+Tkk0/OmDFjcsopp6Rjx46pq6vLD37wg3ziE5/IgAEDsmbNmpx77rk57LDDMmrUqLRq1SqTJk3Kueeem3e/+93ufQZ2WuIZYBvwla98Jbfddlvj77feemtuvfXWJMlll12WgQMHFh3noosuyoYNG1JbW5s2bdpk1KhRadeuXZM1++23X2bPnp1rr702l1xySVavXp1u3bpl0KBBjW8uvPLKK/Pcc8/lhhtuSKtWrZIkJ5xwQr7//e/nggsuyB133JGqqqqt8dQBtiutNmzYsKGlhwAAgO2Be54BAKCQeAYAgELiGQAAColnAAAoJJ4BAKCQeAYAgELiGQAAColnAAAoJJ4BAKDQ/wfhIK/nd+HvlQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAtEAAAHrCAYAAAAJwMFRAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAAvXUlEQVR4nO3de1iUdf7/8dcwgqgIiKIImiEamgriWZFc8cBqecjUMjPNCs20cDXN1DxkJaZ5LFfNspTdJEPyuIdyt+20lvbdXEu31DIRNVBBQUCE+f3hOr8l1OZDwAzwfFxX18o99z33m4Frr6e3n5nbYrPZbAIAAADgMDdnDwAAAABUNEQ0AAAAYIiIBgAAAAwR0QAAAIChas4ewERubq4OHjwof39/Wa1WZ48DAACASqqgoEBpaWlq3bq1PD09iz1eoSL64MGDGjlypLPHAAAAQBWRkJCgDh06FNteoSLa399f0tVvJiAgwMnTAAAAoLI6ffq0Ro4cae/Pn6tQEX1tCUdAQIAaNWrk5GkAAABQ2d1oCTFvLAQAAAAMEdEAAACAISIaAAAAMEREAwAAAIaIaAAAAMBQhfp0DgAAgPJUWFio9PR0ZWRkqKCgwNnjoBRZrVb5+vqqXr16cnMzv65MRAMAANxASkqKLBaLbr31Vrm7u8tisTh7JJQCm82m/Px8nTlzRikpKbrllluMn4PlHAAAADeQnZ2toKAgeXh4ENCViMVikYeHh4KCgpSdnV2i5yCiAQAAbqIk/9SPiuHX/Gz5rQAAAAAMEdEAAACAId5YCAAAYGhpfLwu5OaW6zm9PT01efp0h/d/+umnJUkLFy4sq5F+0aZNm/Tcc89JkoKCgrRnz54b7puSkqJevXopISFBHTp0KK8RS4yIBgAAMHQhN1d3rV1brufcERtbrucrDffcc49iYmK0a9cuvfnmmzfdt2HDhvr444/l6+tbPsP9SkQ0AAAAykSNGjVUo0YN1a5d+xf3tVqt8vf3L4epSke5r4k+cuSInnzySfXq1UuhoaFauXJleY8AAABQJeTk5Gjy5MkKDw9XdHS0tm/fbn/sxRdfVExMjMLCwtS1a1fNmjVLFy9eLHL8X//6Vw0YMMC+z/jx45WXl2d/vLCwUKtXr1bPnj0VHh6uoUOHat++fUYzpqWlKTQ01P7f9Y6Pjo7W2rVr9eijjyo8PFx33nmn/vWvfxXZ59tvv9XDDz+stm3bKioqSgsWLFBuGS65KfeIzs7OVkBAgOLi4tSgQYPyPj0AAECV8de//lVNmjRRcnKyhg8frmnTpunYsWOSpLy8PM2ePVs7d+7UqlWrtH//fs2fP99+bHp6uiZPnqxevXpp586dev311xUREVHkzo2rV6/WO++8o/nz52vHjh2KiYnRI488olOnTjk8Y926dfXxxx/rnXfeuel+Gzdu1H333aekpCTVqVNHs2fPtj+WmZmpBx98UE2bNtXWrVu1cuVK7d27Vy+99JLDc5gq94gODw/XjBkzNGDAAFWvXr28Tw8AAFBlNG7cWHFxcQoODtb48eMVEhJij9W5c+eqe/fuaty4sdq3b6/7779fH374of3Y06dPKz8/X7169VLjxo3VsmVLjRs3TjVr1pR0NcLXrl2rGTNmKCoqSo0bN9ajjz6qxo0bF7ni/Uvc3Nzk7+8vPz+/m+43YMAA9erVSyEhIRo1apS+/fZb+5XmjRs3qn79+po5c6aCg4PVtm1bTZw4UVu2bJHNZjN92RzCmmgAAIBKKjQ0tMjXzZs31/HjxyVdvUq9YcMGHT9+XNnZ2bpy5UqR4GzRooU6duyoMWPGqFu3bgoLC1P//v0VFBQkSTp+/Lhyc3P11FNPFbmbY15enk6cOFHq30twcLD9z9fefJiZmSlPT099++23Onr0qCIiIuz7FBYWKjc3Vz/99FOZrH4gokuZMz7y5pdYLNVks11x9hjFVKvmritX8p09RhE+Pj6Ki4tz9hiVypIly5SVlensMYrgd69qcMXfPS8vH02ZEufsMVCBpaamOrzvpUuXlJOTYz/Gzc0q6eotr7/66itNnjxZTz75pKKiolSjRg3t2LFDr7zyiv34atWq6a233tKBAwf0xRdfaOfOnXr11Ve1ZcsWhYSE2K8Cr1ixQk2aNClybi8vr1/7rRZjtVqLbbsW/Tk5OerWrZtmzZpVbJ+6deuW+iwSEV3qnPGRN79kR2ysGjac4+wxijl1ap7mzHGtuebNm+fsESqdrKxMl/v943evanDV3z3g13B3D3R4Xze3mvr++//Yj8nPT9V3332nO+64Q/v379dtt92mRx991L7/mTNnrvMcbmrbtq3atm2r0aNHq2vXrvr4448VEhKipk2byt3dXWfOnNEdd9xx01lq1qxZpm/ya9mypXbu3KmgoCBVq1Y+ecsdCwEAACqp1NQTWr9+pX788Xtt2rRJx44d07BhwxQcHKyjR49qz549OnHihBISEvTnP/+5yLEHDhzQqlWrdODAAZ08eVLJycnKzs62LxHx8vLSqFGjtHjxYm3btk0nTpzQvn37FB8fr3/+859FnqtVq1bKyMjQ9u3blZaWVuRTQC5evKi0tDSdO3dO0tUlGmlpacrIyHD4+xwxYoQuXLigp556Sl9//bWOHTum9957r0wvUHAlGgAAwJC3p2e53/zEy8PT+JgePfrq+PGjGjNmkPz86uill15ScHCwgoOD9dBDD2nWrFm6dOmSoqKiNGHCBMXHx9uPrV27tr766islJCQoKytLQUFBmjt3rrp06WLf56mnnlKdOnW0YsUKnT59Wn5+furQoYMCA4teMW/cuLGeeeYZLVy4UOnp6br77rvtd1J8/vnntXXrVvu+EyZMkCR16tRJGzdudOj7bNiwoRISErR48WI98MADkq6uoR4yZIjxa+aoco/oy5cv6+jRo5Kk/Px8paWl6dChQ/Lx8Sn2ggMAALiiX7r9dmpqqtHSi7Iwc2bR233n56cWaa24uLhi78UYPXq0/c/BwcFat27dTc/h5uam2NhYxTrwF4oHHnjAHrj/a+HChb94a/Kf3y68c+fO+s9//lNk22233aa15bikttwj+qefftLgwYPtX2/evFmbN28u8jcSAAAAwJWVe0Q3atSo2N8cAAAAgIqENxYCAAAAhohoAAAAwBARDQAAABgiogEAAABDRDQAAABgiIgGAAAADBHRAAAAgCFu+w0AAGBoyZJlysrKLNdz1qzpozFj4sr1nLgxIhoAAMBQVlamGjacU67nPHVqntH+u3Yl6YUXZqhTp+56+eX1kqQzZ87oN7/5jQoLC296bFBQULFbbaMoIhoAAKCSslqtOn78mDIyzqlWLWn37t0KCAhQamqqPv74Y/t+cXFx8vf318yZM+3H4eZYEw0AAFCJ9ejRR3/7258kSTt27NBvf/tbSZK/v7/9P3d3d3l6etq/9vPzc+bIFQIRDQAAUIn16nWn3n9/p06ePKns7Gy1aNHC2SNVCkQ0AABAJdaqVbjS039SYmKi+vfv7+xxKg0iGgAAoJLr2fO32rZtGxFdinhjIQAAQCU3ePB9ql/fSyEhITp48KCzx6kUuBINAABQyQUEBGnAgAHOHqNSIaIBAAAAQyznAAAAMOTl5WN885Nfq2ZNn3I9H26OiAYAADA0ZUrcTR9PTU2Vu3tg+QxzA/37D1H//kOKbR80aJAGDRpUZNuGDRvKaarKg+UcAAAAgCEiGgAAADBERAMAAACGiGgAAADAEBENAAAAGCKiAQAAAENENAAAAGCIiAYAAAAMEdEAAACAISIaAAAAMMRtvwEAAAwtW7ZMmZmZ5XrO2rV9NGpUnEP7Pv/809q9e+sNH586darWrFmj3bt3y9/fX5J08eJF9evXT0OHDlVcXJz27t2rBx98UB9++KECAgJK41uoVIhoAAAAQ5mZmZozZ065nnPevHkO7/vkkzM1fvwUSdLf//4XLV06X++++64aNGggSfLx8dGuXbsUHx+vxYsXS5KWLFmiOnXqaMKECaU/fCVERAMAAFQyXl615eVV+79/9pIk+fn52a86S9KCBQs0fPhwDR8+XJ6entqyZYv++Mc/ysPDwykzVzRENAAAQBXUqlUrjR49WvPmzZOHh4ceeughtWnTxtljVRi8sRAAAKCKeuKJJ3Tu3Dmlp6dr0qRJzh6nQiGiAQAAqqi9e/cqKytLFy5c0IEDB5w9ToXCcg4AAIAqKCsrS88++6zGjRunwsJCzZ49W++99x5roh3ElWgAAIAqaOHChfLy8lJsbKxiY2OVl5entWvXOnusCoMr0QAAAFXMp59+qnfffVcJCQn2K8/Tp0/X1KlT1a9fP4WEhNj3PXLkiM6fP1/k+JCQkCp/xZqIBgAAqEKys7M1a9Ys3XfffWrXrp19e0xMjN5++23NmTNHGzdutG9/+OGHiz3HBx98oEaNGpXLvK6KiAYAADDk4+NjdPOT0lC7tk+JjouJGaSYmEHKz0+VJNWqVUt79uy57r5vvPGG/c+dO3fWf/7znxKdsyogogEAAAzFxcXd9PHU1FS5uweWzzBwCt5YCAAAABgiogEAAABDRDQAAABgiIgGAAC4CZvN5uwRUEZ+zc+WiAYAALgBd3d35eTkOHsMlJGcnBy5u7uX6FgiGgAA4Abq16+vkydP6tKlS1yRrkRsNpsuXbqkkydPqn79+iV6Dj7iDgAA4Aa8vb0lXf3Iuvz8fIePy8jIkNWaWVZjlUhBQYYyM11rJmdyd3dXgwYN7D9jU0Q0AADATXh7exuH1rx589Sw4ZwymqhkTp2apzlzXGumiozlHAAAAIAhIhoAAAAwREQDAAAAhohoAAAAwBARDQAAABgiogEAAABDRDQAAABgiIgGAAAADBHRAAAAgCEiGgAAADBERAMAAACGiGgAAADAEBENAAAAGCKiAQAAAENENAAAAGCIiAYAAAAMEdEAAACAISIaAAAAMEREAwAAAIaIaAAAAMAQEQ0AAAAYIqIBAAAAQ0Q0AAAAYIiIBgAAAAwR0QAAAIAhIhoAAAAwREQDAAAAhohoAAAAwBARDQAAABgiogEAAABDRDQAAABgiIgGAAAADBHRAAAAgCEiGgAAADBERAMAAACGiGgAAADAEBENAAAAGCKiAQAAAENENAAAAGCIiAYAAAAMEdEAAACAISIaAAAAMEREAwAAAIaIaAAAAMAQEQ0AAAAYIqIBAAAAQ0Q0AAAAYIiIBgAAAAwR0QAAAIAhIhoAAAAwREQDAAAAhohoAAAAwBARDQAAABgiogEAAABDRDQAAABgiIgGAAAADBHRAAAAgCEiGgAAADBERAMAAACGiGgAAADAEBENAAAAGCKiAQAAAENENAAAAGCIiAYAAAAMEdEAAACAISIaAAAAMEREAwAAAIaIaAAAAMAQEQ0AAAAYIqIBAAAAQ0Q0AAAAYIiIBgAAAAwR0QAAAIAhIhoAAAAwREQDAAAAhohoAAAAwBARDQAAABgiogEAAABDRDQAAABgiIgGAAAADBHRAAAAgCEiGgAAADBERAMAAACGiGgAAADAEBENAAAAGCKiAQAAAENENAAAAGCIiAYAAAAMEdEAAACAISIaAAAAMEREAwAAAIaIaAAAAMAQEQ0AAAAYIqIBAAAAQ0Q0AAAAYIiIBgAAAAwR0QAAAIAhIhoAAAAwREQDAAAAhqo5ewAAAKoKq9WqefPmOXuMYnx8fBQXF+fsMYAKhYgGAKCcFBQUaM6cOc4eoxhXDHvA1bGcAwAAADBERAMAAACGiGgAAADAEBENAAAAGCKiAQAAAEMOR/Q333xTlnMAAAAAFYbDET1kyBANHjxYmzZtUmZmZlnOBAAAALg0hyN63bp1CgkJ0eLFixUVFaW4uDh99NFHstlsZTkfAAAA4HIcvtlKVFSUoqKilJWVpd27d2vbtm2KjY1V/fr1NWjQIA0aNEghISFlOSsAAADgEozfWOjl5aVhw4Zp48aN+tOf/qSGDRtq3bp1uuuuu3Tvvfdqx44dZTEnAAAA4DJKdNvv7777TklJSdq+fbvOnTunqKgoRUdH68MPP9S0adP09ddfa/r06aU9KwAAAOASHI7ojIwMbd++XVu3btWhQ4cUFBSkkSNHasiQIWrQoIEk6b777tObb76pFStWENEAAACotByO6O7du8tqtapPnz6aNm2aunTpct392rZtq+zs7FIbEAAAAHA1Dkf0jBkzNHDgQNWuXfum+4WHh+vw4cO/ejAAAADAVTkc0SNHjizLOQAAAIAKw+FP5/jhhx+0bds2FRYWFtleWFiobdu26Ycffijt2QAAAACX5HBEv/TSS/ryyy/l5lb0EDc3N3355ZdatGhRqQ8HAAAAuCKHI3r//v3q3r37dR+74447tH///lIbCgAAAHBlDkd0bm5usavQ/+vy5culMhAAAADg6hyO6BYtWmj79u3XfSw5OVmhoaGlNhQAAADgyhz+dI5HHnlEEydOVHZ2tgYMGKB69eopLS1NycnJ+uyzz/TKK6+U5ZwAAACAy3A4onv37q2FCxdqyZIl+sc//mHfXr9+fS1cuFDR0dFlMiAAAADgahyOaEkaPHiwBg0apGPHjikjI0O+vr5q2rSpLBZLWc0HAAAAuByjiJYki8WikJCQspgFAAAAqBAcfmMhAAAAgKscvhJdUFCglStXatu2bTp79qwKCgqK7XPw4MFSHQ4AAABwRQ5fiV69erU2bdqkXr16KS8vT4MGDdKAAQPk5eWlevXqacKECWU5JwAAAOAyHL4SnZycrGnTpumee+7Rxo0bdf/996tVq1bKzs7Www8/rMLCwrKcEwAAAHAZDl+JPnPmjJo2bSqr1Sqr1Wq/Q2GtWrX08MMPKzExscyGBAAAAFyJwxHt6+urjIwMSVKDBg307bff2h+zWCzKysoq9eEAAAAAV+Twco42bdrowIED6t27t3r37q2VK1fK09NT1atX1/Lly9WuXbuynBMAAABwGQ5H9NixY3XkyBFJ0qRJk5SamqpnnnlGBQUFCg8P19y5c8tqRgAAAMClOBzRHTp0UIcOHSRJtWvX1qpVq3T58mVdvnxZXl5eZTYgAAAA4GocXhN94MAB7d27t8g2Dw8PAhoAAABVjsMRPWXKFP3rX/8qw1EAAACAisHoI+7CwsLKchYAAACgQnA4ooODg3XixImynAUAAACoEByO6OnTp2vNmjX697//XZbzAAAAAC7P4U/neO2111S9enUNHz5cjRs3VkBAgKpV+/+HWywWrV+/vkyGBAAAAFyJwxGdn5+vunXrqm7dupIkm82m/Pz8MhsMAAAAcFUOR/TGjRvLcg4AAACgwnB4TTQAAACAq4hoAAAAwJDDyzlSU1N/cZ/AwMBfNQwAAABQETgc0dHR0bJYLDfd59ChQ796IAAAAMDVORzRb731VrFtOTk5Onz4sBITEzVp0qRSHQwAAABwVQ5HdKdOna67vUePHgoLC9P69es1ePDg0poLAAAAcFml8sbC0NBQ7d+/vzSeCgAAAHB5Dl+JvpG0tDT9/ve/V/369UtjHgAAAMDlORzRLVq0uOEbC2vWrKlFixaV2lAAAACAK3M4ol944YViEW21WlWvXj2FhYXJy8ur1IcDAAAAXJHDET1kyJCynAMAAACoMLhjIQAAAGDI4YjesGGDHnnkERUWFhbZXlhYqLFjx2rDhg2lPRsAAADgkhyO6MTEREVHR8vNreghbm5u+u1vf6vExMRSHw4AAABwRQ5HdEpKioKDg6/7WOPGjZWSklJqQwEAAACuzOGI9vX11bFjx6772NGjR1WnTp1SGwoAAABwZQ5HdHR0tFatWqUDBw4U2f7ll19q1apVio6OLvXhAAAAAFfk8EfcTZ48Wfv379e9996rW265RfXq1VNaWppOnDihZs2aafLkyWU5JwAAAOAyHI5oHx8fbdmyRUlJSfr888+VkZGhVq1a6eGHH9bgwYNVvXr1spwTAAAAcBkOR7QkVa9eXSNGjNCIESPKah4AAADA5XGzFQAAAMCQwxF94MABrVu37ro3W1m7dm2xNxwCAAAAlZXDEb18+XJlZmZe92YrWVlZWrp0aakPBwAAALgihyP6q6++UseOHa/7WIcOHXTw4MFSGwoAAABwZQ5HtM1mU25u7nUfy8nJKbbMAwAAAKisHI7osLAwvf3227LZbEW2FxYWatOmTQoPDy/14QAAAABX5PBH3D3++OMaM2aMBg4cqDvvvNN+s5Xt27frxx9/1JtvvlmWcwIAAAAuw+GI7tChg1577TW9/PLLWr58uWw2mywWi8LDw7V+/Xq1b9++LOcEAAAAXIbRzVa6dOmixMRE5eTk6MKFC/L29laNGjXKajYAAADAJRlF9DU1atQgngEAAFBlGUf0lStXlJmZqStXrhR7rEGDBqUyFAAAAODKHI7oS5cuac6cOdq9e7cKCgquu8+hQ4dKbTAAAADAVTn8EXfLli3Tvn37NHXqVNlsNo0bN06PP/64mjZtqgYNGui5554ryzkBAAAAl+FwRP/5z3/W5MmTNWrUKElSnz59NHHiRO3YsUMtWrTQ4cOHy2xIAAAAwJU4HNHnzp1TYGCgrFar3N3dlZOTI0myWCy67777tHPnzjIbEgAAAHAlDkd0vXr1dPbsWUlSYGCgDh48aH8sKyvrhuukAQAAgMrG4TcWtmvXTvv27VNMTIwGDBigFStW6NKlS6pevbreeOMNRUZGluWcAAAAgMtwOKLHjx+v48ePS5JiY2N18eJFvf3228rNzVX37t01a9asMhsSAAAAcCUOR3Tz5s3VvHlzSZKHh4dmzJihGTNmlNlgAAAAgKtyeE00AAAAgKuIaAAAAMAQEQ0AAAAYIqIBAAAAQ0Q0AAAAYIiIBgAAAAwR0QAAAIAhIhoAAAAwREQDAAAAhohoAAAAwBARDQAAABgiogEAAABDRDQAAABgiIgGAAAADBHRAAAAgCEiGgAAADBERAMAAACGiGgAAADAEBENAAAAGCKiAQAAAENENAAAAGCIiAYAAAAMEdEAAACAISIaAAAAMEREAwAAAIaIaAAAAMAQEQ0AAAAYIqIBAAAAQ0Q0AAAAYIiIBgAAAAwR0QAAAIAhIhoAAAAwREQDAAAAhohoAAAAwBARDQAAABgiogEAAABDRDQAAABgiIgGAAAADBHRAAAAgCEiGgAAADBERAMAAACGiGgAAADAEBENAAAAGCKiAQAAAENENAAAAGCIiAYAAAAMEdEAAACAISIaAAAAMEREAwAAAIaIaAAAAMAQEQ0AAAAYIqIBAAAAQ0Q0AAAAYIiIBgAAAAwR0QAAAIAhIhoAAAAwREQDAAAAhohoAAAAwBARDQAAABgiogEAAABDRDQAAABgiIgGAAAADBHRAAAAgCEiGgAAADBERAMAAACGiGgAAADAEBENAAAAGCKiAQAAAENENAAAAGCIiAYAAAAMEdEAAACAISIaAAAAMEREAwAAAIaIaAAAAMAQEQ0AAAAYIqIBAAAAQ0Q0AAAAYIiIBgAAAAwR0QAAAIAhIhoAAAAwREQDAAAAhohoAAAAwBARDQAAABgiogEAAABDRDQAAABgiIgGAAAADBHRAAAAgCEiGgAAADBERAMAAACGiGgAAADAEBENAAAAGCKiAQAAAENENAAAAGCIiAYAAAAMEdEAAACAISIaAAAAMEREAwAAAIaIaAAAAMAQEQ0AAAAYqubsAQAAAFD2rFar5s2b5+wxivDx8VFcXJyzxygRIhoAAKAKKCgo0Jw5c5w9RhGuFvUmWM4BAAAAGCKiAQAAAENENAAAAGCIiAYAAAAMEdEAAACAISIaAAAAMEREAwAAAIaIaAAAAMAQEQ0AAAAYIqIBAAAAQ0Q0AAAAYIiIBgAAAAwR0QAAAIAhIhoAAAAwREQDAAAAhohoAAAAwBARDQAAABgiogEAAABDRDQAAABgiIgGAAAADBHRAAAAgCEiGgAAADBERAMAAACGiGgAAADAEBENAAAAGCKiAQAAAENENAAAAGComrMHAFB6lsbH60JurrPHAACg0iOigUrkQm6u7lq71tljFLEjNtbZIwAAUOpYzgEAAAAYIqIBAAAAQ0Q0AAAAYIiIBgAAAAwR0QAAAIAhIhoAAAAwREQDAAAAhohoAAAAwBARDQAAABgiogEAAABDRDQAAABgiIgGAAAADBHRAAAAgCEiGgAAADBERAMAAACGiGgAAADAEBENAAAAGCKiAQAAAENENAAAAGCIiAYAAAAMEdEAAACAISIaAAAAMEREAwAAAIaIaAAAAMAQEQ0AAAAYIqIBAAAAQ0Q0AAAAYIiIBgAAAAwR0QAAAIAhIhoAAAAwREQDAAAAhohoAAAAwBARDQAAABgiogEAAABDRDQAAABgiIgGAAAADBHRAAAAgCEiGgAAADBERAMAAACGiGgAAADAEBENAAAAGCKiAQAAAENENAAAAGCIiAYAAAAMOSWi16xZo6ioKIWFhWnMmDH68ccfnTEGAAAAUCLlHtHvvPOOVq5cqWnTpikxMVFubm4aN26crly5Ut6jAAAAACVSrbxPmJCQoCFDhmjAgAGSpAULFqhnz5765JNP1KNHj5seW1BQIEk6ffp0mc9ZUllZWUqzWJw9RhFZWVnKzExx9hjFZGVlKSXFteZyxZlM8PvnGFf8ObviTBUdv3uOc9W5KjJ+/xzjijNdc603r/Xnz1lsNputvIa5fPmywsPDtWjRIntES1KvXr109913a+LEiTc9ft++fRo5cmRZjwkAAABIunoBuEOHDsW2l+uV6PPnz6uwsFB+fn6Kj4/XX/7yF+3YsUN+fn46e/bsLx7funVrJSQkyN/fX1artRwmBgAAQFVUUFCgtLQ0tW7d+rqPl/tyjmvq1KmjwMBAoxj29PS87t8EAAAAgNLWpEmTGz5Wrm8srFOnjtzc3HTu3DnFxsZq48aN8vDw0Llz51S3bt3yHAUAAAAosXKNaA8PD4WGhuqLL76wb0tNTVVKSoratGlTnqMAAAAAJVbuH3E3cuRIJSUlafv27Tp8+LBmzZql4OBgRUZGlvcoAAAAQImU+5roYcOG6ezZs4qPj1dmZqbat2+vNWvWqFo1py3PBgAAAIyU60fcAQAAAJWBU277DQAAAFRkRDQAAABgiIgGAAAADBHRAAAAgCEiGr/oyJEjevLJJ9WrVy+FhoZq5cqVzh4JVcjKlSvVv39/tW3bVl26dNFjjz2mo0ePOnssVBEfffSRhg0bprCwMHXu3FlPP/20s0dCFZGenq6pU6cqMjJS4eHhGj16tI4cOeLssfA/iGj8ouzsbAUEBCguLk4NGjRw9jioYho3bqxZs2Zp27Zteuutt+Tu7q6xY8fq8uXLzh4NldwXX3yhxx57TN26ddOWLVv0hz/8Qb1793b2WKgipk2bpmPHjmn16tVKSkqSt7e3HnnkEeXm5jp7NPwXH3EHI3369NHAgQM1adIkZ4+CKurw4cMaNGiQ3nvvPbVo0cLZ46ASGz16tOrVq6clS5Y4exRUMTk5OYqIiNCKFSvUt29fSVJGRoY6d+6sFStWKCYmxskTQuJKNIAKJCsrS4mJiapTp44aNWrk7HFQieXn52v//v0KDQ3VmDFj1LVrV40YMUKff/65s0dDFVBQUCCbzSYPDw/7Ng8PD1ksFn3zzTdOnAz/i4gG4PL27t2riIgItW/fXp988okSEhLk5eXl7LFQiZ0/f175+flav369evfurfXr16tNmzZ65JFHdPLkSWePh0rOy8tLt99+uzZu3KjMzEzl5eVp+fLlslqtOnfunLPHw38R0QBcXnh4uJKTk5WQkKDg4GA988wzysvLc/ZYqMSurXSMjIzUAw88oNtvv11PP/20vL29tXPnTidPh6ogPj5eZ8+eVadOndSuXTtduHBBzZo1k8VicfZo+K9qzh4AAH6Jp6enmjRpoiZNmtg/JWHHjh265557nD0aKilfX19ZLBYFBwfbt7m5uSkoKEg//fSTEydDVXHbbbcpOTlZFy5cUGFhoby9vdW1a1f7Gmk4H1eiAVQobm5uslgsysnJcfYoqMSqV6+ukJAQ/fjjj/ZtNptNp0+f5lOKUK68vb3l6+urjz76yP7mQrgGrkTjF12+fNn+ubz5+flKS0vToUOH5OPjo8DAQCdPh8osOztbL7/8snr37q1GjRrp4sWLWr9+vWw2m6Kiopw9Hiq5e++9V4sWLVJkZKQiIiKUnJys8+fPq1+/fs4eDVXAV199pYyMDDVr1kxHjx7V3LlzFRkZqQ4dOjh7NPwXH3GHX5SSkqJevXoV23733Xdr4cKFTpgIVUVeXp6eeuopHThwQGfPnlXNmjXVqlUrTZw4Ue3atXP2eKjkbDabXnnlFSUmJiozM1PNmjXT1KlT1bVrV2ePhirg888/16xZs5SamiofHx/17dtXU6ZM4U3VLoSIBgAAAAyxJhoAAAAwREQDAAAAhohoAAAAwBARDQAAABgiogEAAABDRDQAAABgiIgG4LJCQ0MVGhqqH374wb5t3759Cg0N1d69e0v9fElJSQoNDS315y1v77zzjqKjo9WyZUuFhoYqJSXF2SO5pKSkJL3//vvOHgNABUVEA3B57777rrNHqDDS09M1d+5cxcTEaNOmTdq8ebPq16/v7LFc0tatW4loACVGRANwabfeequ2bt2qgoICZ49SIfzwww+6cuWK7r//frVv315t27aVh4eHs8cCgEqHiAbg0mJiYpSTk6MPP/zwuo+npKRcd3lHaGiokpKSJF39Z/sePXooLi5Obdu21dq1azVjxgxFRERo1qxZxZ7zgw8+UJ8+fRQWFqZRo0bp2LFjRR7Py8vT4sWL9Zvf/EatW7fWgAED9Le//a3Y81xbHnL48GE98cQTioiIUMeOHbVs2TKj1yA3N1cLFixQZGSkWrdurYEDBxa7grpy5UqFhoZq5MiRkqTevXvbl8OUZDnHa6+9pr59+6pNmzbq1q2bJkyYoHPnzhXZ57vvvtP48ePVrl07RUREaNKkSfrpp5+K7HP8+HE9+OCDCgsLU9++ffX3v/+9yM9m7969Cg0N1YsvvqiwsDDNnz9fy5cvV0REhMaPH6/Lly/bn+vUqVOaMmWKOnfurLCwMD300EM6evRokfNFR0dr6dKlev7559WpUydFRkZq+fLlRfa59rp8/vnn2rp1q/3r6OjoIvudOXNGv/vd79StWzeFhYUpJiZGa9asMX4tAVRO1Zw9AADcjKenp+68805t2bKlWOSYOH36tLp27aq6devq5Zdf1vDhwzV79mzNmDFDY8aMUbNmzez7Pvfcc4qLi1OtWrW0ePFijR8/Xrt375bVapUkTZo0Sfv27dMTTzyh5s2ba/fu3Xr88ceVlJSkFi1aFDv3tWBfsWKFMjIydPz4caPZZ86cqffff1+/+93vFBwcrHfffVeTJk3Shg0b1LlzZ0nSsGHDFBUVpa+//lrz58/XqlWr5O/vL0nGyznee+89vfTSS5o4caI6deqks2fPas+ePcrKypKfn5+kq1e8R4wYoSZNmmjRokUqKCjQ8uXLNWHCBG3ZskWSVFhYqHHjxik/P1/x8fG6cuWKnn/++eues3bt2nrssce0bNky9e7dW4sWLdKUKVP02WefqUePHjp//rxGjBghDw8PzZ49W7Vq1dK6des0duxY/eUvf1H16tXtz5WYmKi+fftq6dKl+vjjj/Xqq6+qc+fO6tKliyRp8+bNkqR58+bJ399fEyZMkKRiV+ynT5+u48ePa+bMmapbt66OHj2qb7/91ui1BFB5EdEAXN4999yj+++/X+np6SV+jtq1a+vee+/V4cOHtWnTJo0YMUItW7bUiy++qB9++KFIRE+ePFmDBg2SdDVAhw8frvfff18xMTH69NNP9eGHHyo+Pl6DBw+WJEVGRurQoUNas2aNli5dWuzcYWFhevbZZ0s095kzZ7Rz505NnjxZo0ePliR1795dffr00RtvvGGP6ICAAAUEBCgvL0+S1LJlSzVq1KhE5/zqq69Ur149TZo0yb6tf//+RfZZtWqVrFarXn/9dfn4+EiSmjZtqrvuukv/+Mc/dMcdd2jPnj36/vvv9Yc//EHt27e3Hzt16tRi53zwwQdlsVi0bNky3X333erdu7eaNm2q77//Xj169NCGDRuUnp6uXbt26ZZbbpEkhYeHq2fPnkpKStKIESPsz9WoUSPNmzdPktStWzft2rVLn332mT2i27ZtK0ny8vKSn5+f/evrvQ4jR47UnXfeKUn24wFAYjkHgAogPDxcwcHB2rp1a4mfo3bt2pKkWrVqSboaUNe+zsrKKrJvt27dipy7Zs2aOnz4sCTp008/ldVqVe/evXXlyhX7f+3atdPXX3993XMPGDCgxHN//fXXstlsRWZyc3NTZGSk/v3vf5f4eW8mNDRU6enpev7557Vv3z7l5OQU2+ezzz5TZGSkatWqZX8NgoOD5e3tbX8dvvnmG9WsWbNIQHft2vW656xdu/Z1fzbZ2dn287Vq1UqBgYH283l7eys4OLjY696uXTv7ny0Wi4KCgnT27NkSvQ7Jycl6++23dfToUdlsNuPnAFB5cSUaQIUwdOhQbd68WRERESU63mKxXPd/3dzcVFhYWGRfX1/fIl/7+PjYIywjI0MFBQVFwvCaG72BLyAgoEQzS9LFixevO5Ovr68uXLhQ4ue9maFDhyo7O1vJycnatGmTrFar+vXrp+eee06enp6Srr4OO3fu1M6dO4sdf+rUKUlXPynk2lXqa7y9va97TovFctOfzbVlMK1atSp2bN26dYt8fS3Cr7Farbpy5covft8/t3TpUi1fvlwrVqzQ2bNn5e/vr6lTp9r/BQJA1UZEA6gQBg4cqMWLF+vLL78ssr1atav/N/a/Vwmvd+XURGZmpurVq1fk62vri319feXt7a3XX3+92HHX4u/nrs1YEteCMCMjQ40bN7Zvz8jIuGGQ/lpWq1Vjx47V2LFjdf78eW3evFlLly5Vq1atNGbMGElXX4fIyEiNGjWq2PHX1k3Xq1dPmZmZRR4rafj7+voqMDBQU6ZMKfbYz6O5tDRs2FALFy6UJB0+fFgvvPCCZs2apaioqGLhDqDqIaIBVAh+fn6Kjo4u9pnRfn5+slgsSktLs2+7tvSipD799FMNHDhQ0tV1sZcuXVLLli0lXV0Xu27dOlmtVt1+++2/6jyOaN26tSwWiz755BO1adNG0tU37H3yySdq3bp1mZ+/Tp06Gj9+vNavX6/Tp0/bt3fp0kVHjhzR7bffbn/D5c/dfvvtunTpkvbv32+/cv/ZZ5+VaI4uXbooOTlZTZs2tS/7+LVq1aqlS5cuObRvixYt9OCDD2rv3r1KT08nogEQ0QAqjqFDh+rRRx8tss3Dw0MdO3bUpk2b1K5dO+Xm5hp/hNzPLVu2TIWFhapVq5aWLFmiW2+9VT179pR09U2EUVFRGjdunGJjY9W8eXNlZGTo//7v/+Tm5qbp06f/qnP/XIMGDdSvXz+tXr1aNWvWVHBwsLZs2aKTJ09qwYIFpXquaxYuXCibzaaOHTvKy8tLu3bt0oULFxQZGWnf5/HHH9fQoUMVGxurYcOGycfHRykpKdqzZ4/Gjh2rjh07Kjo6WsHBwZo2bZqmTp2qgoICvfrqqyWaacyYMUpOTtbo0aM1evRo1a9fX6dOndJHH32knj176q677jJ+zhYtWmjjxo364IMPdOutt8rd3d3+pkVJuvvuuzV48GA1b95c2dnZWrFihQIDA9W0adMSfQ8AKhciGkCF0b17dzVs2NC+5vaauXPnasaMGerXr5+aNGmiZ555Rv/85z9LfJ6ZM2fqxRdf1JkzZxQREaH58+fbr7ZaLBa98sorevXVV/Xmm2/q9OnT8vX1VevWre2f0VzaXnjhBb300kv6/e9/rwsXLig4OFgrVqy44Zv0fq2wsDAlJCQoOTlZeXl5atKkieLj4xUVFWXfp2nTpkpMTNSyZcv07LPPKjc3V4GBgYqMjFSTJk0kXV3TvGbNGs2ePVvTpk1Tw4YNNWPGDI0fP954KYqfn58SExO1dOlSvfjii7pw4YIaNGigTp06lfhfBB566CF9//33euaZZ5SRkaGgoCDt2bOnyOvw9ttvKzU1VTVq1FBERISmTp0qd3f3Ep0PQOVisfF2YwBAOTl8+LAGDRqkHTt2qHnz5s4eBwBKjCvRAIAys2HDBlmtVjVr1kwXL17U6tWr1aVLFwIaQIVHRAMAyoy7u7veeustpaamqk6dOoqMjCz1deMA4Aws5wAAAAAMccdCAAAAwBARDQAAABgiogEAAABDRDQAAABgiIgGAAAADP0/90jnHpDHSSEAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "df = copy\n",
    "n_chunks = np.unique(df.n_chunks)\n",
    "plot_df = pd.DataFrame(index = n_chunks)\n",
    "\n",
    "plot_df['baseline'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].mean() for i in n_chunks]\n",
    "plot_df['MT'] = [df[(df.num_mem_tokens > 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].mean() for i in n_chunks]\n",
    "plot_df['TXL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len > 0) & (df.n_chunks == i)]['test acc'].mean() for i in n_chunks]\n",
    "plot_df.loc[1] = 1\n",
    "\n",
    "\n",
    "# plt.figure(figsize=(8, 4))\n",
    "ax = plot_df.reset_index().plot(x='index', kind='bar', figsize=(12, 8), cmap='BuPu', edgecolor='grey', width=0.7, color=[(0.8, 0.1, 0.1), (0.6, 0.6, 1), 'w'])\n",
    "plot_df.reset_index().plot(x='index', kind='bar', figsize=(12, 8), cmap='BuPu', edgecolor='grey', width=0.7, color=[(0.8, 0.1, 0.1), (0.6, 0.6, 1), 'w'])\n",
    "plt.xlabel('Number of segments')\n",
    "plt.xticks(rotation=0)\n",
    "plt.yticks([0, 1])\n",
    "plt.ylabel('accuracy')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 161,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "17     1\n",
       "18     1\n",
       "19     1\n",
       "40     1\n",
       "41     1\n",
       "42     1\n",
       "73     1\n",
       "74     1\n",
       "75     1\n",
       "98     1\n",
       "99     1\n",
       "100    1\n",
       "102    1\n",
       "103    1\n",
       "104    1\n",
       "150    2\n",
       "151    2\n",
       "153    2\n",
       "171    2\n",
       "172    2\n",
       "396    1\n",
       "397    1\n",
       "398    1\n",
       "399    1\n",
       "Name: n_chunks, dtype: int64"
      ]
     },
     "execution_count": 161,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "retrieval.n_chunks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 160,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 576x288 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAtEAAAHrCAYAAAAJwMFRAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAAsGElEQVR4nO3debRXdb3/8dfhCKKAzIMgKZAXTGRQHBG9gkpmiJoTcp0TyaEgTcMhxSFBLRHNMUsF7lUkwAFtkq5lmoWWpEkmDok4gAjIKMP5/eHi/C4BdjZyBvDxWIsl5/vd+7vf53vU9WTz2ftbUlZWVhYAAKDCalX3AAAAsLkR0QAAUJCIBgCAgkQ0AAAUtFV1D1DEsmXL8uKLL6Z58+YpLS2t7nEAANhCrVq1KnPmzEnnzp1Tt27ddZ7frCL6xRdfzMCBA6t7DAAAPifGjRuXHj16rPP4ZhXRzZs3T/LJN9OqVatqngYAgC3Vu+++m4EDB5b357/arCJ6zRKOVq1aZYcddqjmaQAA2NJtaAmxCwsBAKAgEQ0AAAWJaAAAKEhEAwBAQSIaAAAK2qzuzgEAUJVWr16duXPnZv78+Vm1alV1j8MmVFpamkaNGqVZs2apVav4eWURDQCwAbNmzUpJSUl22mmn1K5dOyUlJdU9EptAWVlZVqxYkffeey+zZs3KF77whcKvYTkHAMAGLF68OG3atEmdOnUE9BakpKQkderUSZs2bbJ48eKNeg0RDQDwKTbmr/rZPHyWn61/KwAAoCARDQAABbmwEACgoBtHjszCZcuq9Jjb1a2boRddVOHtv/vd7yZJRowYUVkj/Vtjx47NVVddlSRp06ZNpk6dusFtZ82alT59+mTcuHHp0aNHVY240UQ0AEBBC5cty1fvvLNKj/nooEFVerxN4Wtf+1r69u2bxx57LPfee++nbrv99tvnqaeeSqNGjapmuM9IRAMAUCm22WabbLPNNmnQoMG/3ba0tDTNmzevgqk2jSpfE/3qq6/mW9/6Vvr06ZOOHTvm5ptvruoRAAA+F5YuXZqhQ4ema9eu6d27dx555JHy56699tr07ds3Xbp0yb777ptLL700H3300Vr7/+pXv0q/fv3Ktxk8eHCWL19e/vzq1atz22235aCDDkrXrl1zzDHHZNq0aYVmnDNnTjp27Fj+a3379+7dO3feeWfOPPPMdO3aNYcffnj+8pe/rLXNK6+8kjPOOCPdunVLr169cvXVV2dZJS65qfKIXrx4cVq1apUhQ4akZcuWVX14AIDPjV/96lfZcccdM3ny5Bx33HG58MIL89prryVJli9fnssuuyxTpkzJLbfckueeey5XXnll+b5z587N0KFD06dPn0yZMiU/+clP0r1797U+ufG2227Lgw8+mCuvvDKPPvpo+vbtm69//et55513Kjxj06ZN89RTT+XBBx/81O3GjBmTE044IRMnTkzjxo1z2WWXlT+3YMGCnHzyyWnfvn0mTZqUm2++Oc8++2yuv/76Cs9RVJVHdNeuXTNs2LD069cvW2+9dVUfHgDgc6Nt27YZMmRI2rVrl8GDB6dDhw7lsXrFFVdk//33T9u2bbPHHnvkxBNPzJNPPlm+77vvvpsVK1akT58+adu2bXbZZZecddZZ2XbbbZN8EuF33nlnhg0bll69eqVt27Y588wz07Zt27XOeP87tWrVSvPmzdOkSZNP3a5fv37p06dPOnTokJNOOimvvPJK+ZnmMWPGpEWLFrnkkkvSrl27dOvWLeeee24mTJiQsrKyom9bhVgTDQCwherYseNaX++888558803k3xylvqee+7Jm2++mcWLF2flypVrBWenTp2y55575tRTT81+++2XLl265Ctf+UratGmTJHnzzTezbNmyfOc731nr0xyXL1+et956a5N/L+3atSv//ZqLDxcsWJC6devmlVdeycyZM9O9e/fybVavXp1ly5bl/fffr5TVDyJ6C1cdt+DZXJSUbJWyspXVPUaNtNVWtbNy5YrqHqNGatiwYYYMGVLdYwBstJKSkrzwwgsZOnRovvWtb6VXr17ZZptt8uijj+ZHP/pR+XZbbbVV7rvvvkyfPj1/+tOfMmXKlNx6662ZMGFCOnToUH4WePTo0dlxxx3XOkb9+vU3+dylpaXrPLYm+pcuXZr99tsvl1566TrbNG3adJPPkojoLV513IJnc/HooEHZfvvLq3uMGumdd4bn8su9N+szfPjw6h4BoML+/ve/r/X1P/7xjxxwwAF57rnn8h//8R8588wzy59777331tm/Vq1a6datW7p165ZTTjkl++67b5566ql06NAh7du3T+3atfPee+/lgAMO+NQ5tt1220q9yG+XXXbJlClT0qZNm2y1VdXkrU8sBADYQr311lu5+eab8/rrr+f222/Pa6+9lmOPPTbt2rXLzJkzM3Xq1Lz11lsZN25cfvGLX6y17/Tp03PLLbdk+vTpefvttzN58uQsXry4fIlI/fr1c9JJJ+WGG27Iww8/nLfeeivTpk3LyJEj84c//GGt19p1110zf/78PPLII5kzZ85adwH56KOPMmfOnMybNy/JJ0s05syZk/nz51f4+xwwYEAWLlyY73znO3nppZfy2muv5aGHHqrUEx/ORAMAFLRd3bpV/uEn29WtW3ifQw89NDNnzkz//v3TrFmzXH/99WnXrl3atWuX0047LZdeemmWLFmSXr165eyzz87IkSPL923QoEFeeOGFjBs3LosWLUqbNm1yxRVXZJ999inf5jvf+U4aN26c0aNH5913302TJk3So0ePtG7deq052rZtm4svvjgjRozI3Llzc9RRR5V/kuI111yTSZMmlW979tlnJ0n22muvjBkzpkLf5/bbb59x48blhhtuyH/9138l+WQN9dFHH134PauokrLKumRxAz7++OPMnDkzSfKNb3wjBxxwQAYMGJCGDRuu84b/qzUfB/nEE09khx12qIpxN3vDhw+3nGMDLOfYMMs5Nmz4cO8NfJ68/PLL2WWXXap7DCrRhn7G/647q/xM9Pvvv58jjzyy/OsHHnggDzzwwFp/IgEAgJqsyiN6hx12WGeROwAAbE5cWAgAAAW5sBAA2KKMGjUqCxYs2CSvdeihh2b27Nmb5LVqgtLS0kr54JHPIxENAGxRFixYsMkuAH755Zf/7Y0PNidb0h8IqpvlHAAAUJCIBgCAgkQ0AAAUJKIBAKAgFxYCABT0gx+MyqJFm+YOIBVVv37DnH/+kCo9JhsmogFgM1QdEcf/t2jRgmy//aa5A0hFvfPO8ELbT5w4McOGDcv++++fu+++O0kyd+7c9OnTJ6tXr/7Ufdu0aZOpU6du9KyfByIaADZD1RFxm4uisbklKy0tzWuvvZZ58+alSZMm+c1vfpNWrVpl9uzZeeqpp8q3GzJkSJo3b55LLrmkfD8+nTXRAABbsEMOOSQ///nPkyRTp07Nl7/85SRJ8+bNy3/Vrl07devWLf+6SZMm1TnyZkFEAwBswQ4//PBMmTIl//znP7NkyZJ06tSpukfaIohoAIAtWNeuXfP+++/n7rvvzkEHHVTd42wxRDQAwBbuy1/+cu6//34RvQm5sBAAYAt3wgknZIcddsiOO+6Y999/v7rH2SI4Ew0AsIVr06ZNjj/++OoeY4siogEAoCDLOQAACqpfv2GV34+6fv2GVXo8Pp2IBgAoaHP4+O2jjz46Rx999DqP9+/fP/3791/rsXvuuaeKptpyWM4BAAAFiWgAAChIRAMAQEEiGgAAChLRAABQkIgGAICCRDQAABQkogEAoCARDQAABYloAAAoyMd+AwAUNGrUqCxYsKBKj9mwYcMMGTKkQtt+97vfzaRJkzb4/AUXXJA77rgjjz/+eJo3b54k+eijj3LYYYflmGOOyZAhQ/Lss8/m5JNPzpNPPplWrVptim9hiyKiAQAKWrBgQS6//PIqPebw4cMrvO0ll1yS888/P0nyy1/+MldeeWWeeuqpvPfee2nZsmUaNmyYxx57LCNHjswNN9yQJPnBD36Qxo0b5+yzz66U+bc0IhoAYAvToEGDNGjQIElSv379JEnz5s2zYsWK8jPPV199dY477rgcd9xxqVu3biZMmJD/+Z//SZ06dapt7s2JiAYA+Bzaddddc8opp2T48OGpU6dOTjvttOy2227VPdZmw4WFAACfU9/85jczb968zJ07N+edd151j7NZEdEAAJ9Tzz77bBYtWpSFCxdm+vTp1T3OZsVyDgCAz6FFixble9/7Xs4666ysXr06l112WR566CFroivImWgAgM+hESNGpH79+hk0aFAGDRqU5cuX584776zusTYbzkQDAHzOPP300/nZz36WcePGlZ95vuiii3LBBRfksMMOS4cOHcq3ffXVV/Phhx+utX+HDh0+92esRTQAwOfI4sWLc+mll+aEE07I7rvvXv543759c//99+fyyy/PmDFjyh8/44wz1nmNJ554IjvssEOVzFtTiWgAgIIaNmxY6MNPNtUxN0b//v3Tv3//8q/r1auXqVOnrnfbn/70p+W/33vvvfP3v/99o475eSCiAQAKqujHb7PlcmEhAAAUJKIBAKAgEQ0AAAWJaACAT1FWVlbdI1BJPsvPVkQDAGxA7dq1s3Tp0uoeg0qydOnS1K5de6P2FdEAABvQokWLvP3221myZIkz0luQsrKyLFmyJG+//XZatGixUa/hFncAABuw3XbbJUlmz56dFStWVPM0n938+fOzYMGC6h6jRqhdu3ZatmxZ/jMuSkQDAHyK7bbbbqNDq6YZPnx4Lr/88uoeY4tgOQcAABQkogEAoCARDQAABYloAAAoSEQDAEBBIhoAAAoS0QAAUJCIBgCAgkQ0AAAUJKIBAKAgEQ0AAAWJaAAAKEhEAwBAQSIaAAAKEtEAAFCQiAYAgIJENAAAFCSiAQCgIBENAAAFiWgAAChIRAMAQEEiGgAAChLRAABQkIgGAICCRDQAABQkogEAoCARDQAABYloAAAoSEQDAEBBIhoAAAoS0QAAUJCIBgCAgkQ0AAAUJKIBAKAgEQ0AAAWJaAAAKEhEAwBAQSIaAAAKEtEAAFCQiAYAgIJENAAAFCSiAQCgIBENAAAFiWgAAChIRAMAQEEiGgAAChLRAABQkIgGAICCRDQAABQkogEAoCARDQAABYloAAAoSEQDAEBBIhoAAAoS0QAAUJCIBgCAgkQ0AAAUJKIBAKAgEQ0AAAWJaAAAKEhEAwBAQSIaAAAKEtEAAFCQiAYAgIJENAAAFCSiAQCgIBENAAAFiWgAAChIRAMAQEEiGgAAChLRAABQkIgGAICCRDQAABQkogEAoCARDQAABYloAAAoSEQDAEBBIhoAAAoS0QAAUJCIBgCAgkQ0AAAUJKIBAKAgEQ0AAAWJaAAAKEhEAwBAQSIaAAAKEtEAAFCQiAYAgIJENAAAFCSiAQCgIBENAAAFiWgAAChIRAMAQEEiGgAAChLRAABQkIgGAICCRDQAABQkogEAoCARDQAABYloAAAoSEQDAEBBIhoAAAoS0QAAUJCIBgCAgkQ0AAAUJKIBAKCgCkf03/72t8qcAwAANhsVjuijjz46Rx55ZMaOHZsFCxZU5kwAAFCjVTii77rrrnTo0CE33HBDevXqlSFDhuR3v/tdysrKKnM+AACocbaq6Ia9evVKr169smjRojz++ON5+OGHM2jQoLRo0SL9+/dP//7906FDh8qcFQAAaoTCFxbWr18/xx57bMaMGZOf//zn2X777XPXXXflq1/9ao4//vg8+uijlTEnAADUGBU+E/1//eMf/8jEiRPzyCOPZN68eenVq1d69+6dJ598MhdeeGFeeumlXHTRRZt6VgAAqBEqHNHz58/PI488kkmTJuXll19OmzZtMnDgwBx99NFp2bJlkuSEE07Ivffem9GjR4toAAC2WBWO6P333z+lpaU55JBDcuGFF2afffZZ73bdunXL4sWLN9mAAABQ01Q4oocNG5YjjjgiDRo0+NTtunbtmhkzZnzmwQAAoKaqcEQPHDiwMucAAIDNRoXvzvHGG2/k4YcfzurVq9d6fPXq1Xn44YfzxhtvbOrZAACgRqpwRF9//fV5/vnnU6vW2rvUqlUrzz//fK677rpNPhwAANREFY7o5557Lvvvv/96nzvggAPy3HPPbbKhAACgJqtwRC9btmyds9D/18cff7xJBgIAgJquwhHdqVOnPPLII+t9bvLkyenYseMmGwoAAGqyCt+d4+tf/3rOPffcLF68OP369UuzZs0yZ86cTJ48Oc8880x+9KMfVeacAABQY1Q4og8++OCMGDEiP/jBD/Lb3/62/PEWLVpkxIgR6d27d6UMCAAANU2FIzpJjjzyyPTv3z+vvfZa5s+fn0aNGqV9+/YpKSmprPkAAKDGKRTRSVJSUpIOHTpUxiwAALBZqPCFhQAAwCcqfCZ61apVufnmm/Pwww/ngw8+yKpVq9bZ5sUXX9ykwwEAQE1U4TPRt912W8aOHZs+ffpk+fLl6d+/f/r165f69eunWbNmOfvssytzTgAAqDEqfCZ68uTJufDCC/O1r30tY8aMyYknnphdd901ixcvzhlnnJHVq1dX5pwAAFBjVPhM9HvvvZf27duntLQ0paWl5Z9QWK9evZxxxhkZP358pQ0JAAA1SYUjulGjRpk/f36SpGXLlnnllVfKnyspKcmiRYs2+XAAAFATVXg5x2677Zbp06fn4IMPzsEHH5ybb745devWzdZbb52bbropu+++e2XOCQAANUaFI/r000/Pq6++miQ577zzMnv27Fx88cVZtWpVunbtmiuuuKKyZgQAgBqlwhHdo0eP9OjRI0nSoEGD3HLLLfn444/z8ccfp379+pU2IAAA1DQVXhM9ffr0PPvss2s9VqdOHQENAMDnToUj+vzzz89f/vKXShwFAAA2D4VucdelS5fKnAUAADYLFY7odu3a5a233qrMWQAAYLNQ4Yi+6KKLcscdd+Svf/1rZc4DAAA1XoXvzvHjH/84W2+9dY477ri0bds2rVq1ylZb/f/dS0pKcvfdd1fKkAAAUJNUOKJXrFiRpk2bpmnTpkmSsrKyrFixotIGAwCAmqrCET1mzJjKnAMAADYbFV4TDQAAfEJEAwBAQRVezjF79ux/u03r1q0/0zAAALA5qHBE9+7dOyUlJZ+6zcsvv/yZBwIAgJquwhF93333rfPY0qVLM2PGjIwfPz7nnXfeJh0MAABqqgpH9F577bXexw888MB06dIld999d4488shNNRcAANRYm+TCwo4dO+a5557bFC8FAAA1XoXPRG/InDlzcvvtt6dFixabYh4AAKjxKhzRnTp12uCFhdtuu22uu+66TTYUAADUZBWO6O9///vrRHRpaWmaNWuWLl26pH79+pt8OAAAqIkqHNFHH310Zc4BAACbDZ9YCAAABVU4ou+55558/etfz+rVq9d6fPXq1Tn99NNzzz33bOrZAACgRqpwRI8fPz69e/dOrVpr71KrVq18+ctfzvjx4zf5cAAAUBNVOKJnzZqVdu3arfe5tm3bZtasWZtsKAAAqMkqHNGNGjXKa6+9tt7nZs6cmcaNG2+yoQAAoCarcET37t07t9xyS6ZPn77W488//3xuueWW9O7de5MPBwAANVGFb3E3dOjQPPfcczn++OPzhS98Ic2aNcucOXPy1ltv5Ytf/GKGDh1amXMCAECNUeGIbtiwYSZMmJCJEyfmj3/8Y+bPn59dd901Z5xxRo488shsvfXWlTknAADUGBWO6CTZeuutM2DAgAwYMKCy5gEAgBrPh60AAEBBFY7o6dOn56677lrvh63ceeed61xwCAAAW6oKR/RNN92UBQsWrPfDVhYtWpQbb7xxkw8HAAA1UYUj+oUXXsiee+653ud69OiRF198cZMNBQAANVmFI7qsrCzLli1b73NLly5dZ5kHAABsqSoc0V26dMn999+fsrKytR5fvXp1xo4dm65du27y4QAAoCaq8C3uzjnnnJx66qk54ogjcvjhh5d/2MojjzySf/7zn7n33nsrc04AAKgxKhzRPXr0yI9//OP88Ic/zE033ZSysrKUlJSka9euufvuu7PHHntU5pwAAFBjFPqwlX322Sfjx4/P0qVLs3Dhwmy33XbZZpttKms2AACokQpF9BrbbLONeAYA4HOrcESvXLkyCxYsyMqVK9d5rmXLlptkKAAAqMkqHNFLlizJ5ZdfnscffzyrVq1a7zYvv/zyJhsMAABqqgrf4m7UqFGZNm1aLrjggpSVleWss87KOeeck/bt26dly5a56qqrKnNOAACoMSoc0b/4xS8ydOjQnHTSSUmSQw45JOeee24effTRdOrUKTNmzKi0IQEAoCapcETPmzcv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cyYaAPjMFi5cmCRp0KBBNU8CVUNEAwCfyeLFi3PnnXfm8MMPT5s2bap7HKgSIhoA2GgrV67M+eefn2233TZXXXVVdY8DVWar6h4AANg8rV69OhdddFHeeuutjBkzJvXq1avukaDKiGgAoLCysrJccsklefnll3PfffelSZMm1T0SVCkRDdXo448/zsyZM5MkK1asyJw5c/Lyyy+nYcOGad26dTVPB7Bhl19+eZ555pncfvvtKSsry5w5c5IkDRs2TJ06dap5Oqh8bnEH1WjWrFnp06fPOo8fddRRGTFiRDVMBFAxHTt2XO/j9913X/bee+8qngaqnogGAICC3J0DAAAKEtEAAFCQiAYAgIJENAAAFCSiAQCgIBENAAAFiWigxurYsWM6duyYN954o/yxadOmpWPHjnn22Wc3+fEmTpy4wXvfbk4efPDB9O7dO7vssks6duyYWbNmVfdINdLEiRPz61//urrHADZTIhqo8X72s59V9wibjblz5+aKK65I3759M3bs2DzwwANp0aJFdY9VI02aNElEAxtNRAM12k477ZRJkyZl1apV1T3KZuGNN97IypUrc+KJJ2aPPfZIt27dfAQzQCUQ0UCN1rdv3yxdujRPPvnkep+fNWvWepd3dOzYMRMnTkzyyV/bH3jggRkyZEi6deuWO++8M8OGDUv37t1z6aWXrvOaTzzxRA455JB06dIlJ510Ul577bW1nl++fHluuOGG/Od//mc6d+6cfv365Te/+c06r7NmeciMGTPyzW9+M927d8+ee+6ZUaNGFXoPli1blquvvjo9e/ZM586dc8QRR6xzBvXmm29Ox44dM3DgwCTJwQcfXL4cZmOWc/z4xz/OoYcemt122y377bdfzj777MybN2+tbf7xj39k8ODB2X333dO9e/ecd955ef/999fa5s0338zJJ5+cLl265NBDD83//u//rvWzefbZZ9OxY8dce+216dKlS6688srcdNNN6d69ewYPHpyPP/64/LXeeeednH/++dl7773TpUuXnHbaaZk5c+Zax+vdu3duvPHGXHPNNdlrr73Ss2fP3HTTTWtts+Z9+eMf/5hJkyaVf927d++1tnvvvffy7W9/O/vtt1+6dOmSvn375o477ij8XgJbpq2qewCAT1O3bt0cfvjhmTBhwjqRU8S7776bfffdN02bNs0Pf/jDHHfccbnssssybNiwnHrqqfniF79Yvu1VV12VIUOGpF69ernhhhsyePDgPP744yktLU2SnHfeeZk2bVq++c1vZuedd87jjz+ec845JxMnTkynTp3WOfaaYB89enTmz5+fN998s9Dsl1xySX7961/n29/+dtq1a5ef/exnOe+883LPPfdk7733TpIce+yx6dWrV1566aVceeWVueWWW9K8efMkKbyc46GHHsr111+fc889N3vttVc++OCDTJ06NYsWLUqTJk2SfHLGe8CAAdlxxx1z3XXXZdWqVbnpppty9tlnZ8KECUmS1atX56yzzsqKFSsycuTIrFy5Mtdcc816j9mgQYN84xvfyKhRo3LwwQfnuuuuy/nnn59nnnkmBx54YD788MMMGDAgderUyWWXXZZ69erlrrvuyumnn55f/vKX2Xrrrctfa/z48Tn00ENz44035qmnnsqtt96avffeO/vss0+S5IEHHkiSDB8+PM2bN8/ZZ5+dJOucsb/ooovy5ptv5pJLLknTpk0zc+bMvPLKK4XeS2DLJaKBGu9rX/taTjzxxMydO3ejX6NBgwY5/vjjM2PGjIwdOzYDBgzILrvskmuvvTZvvPHGWhE9dOjQ9O/fP8knAXrcccfl17/+dfr27Zunn346Tz75ZEaOHJkjjzwySdKzZ8+8/PLLueOOO3LjjTeuc+wuXbrke9/73kbN/d5772XKlCkZOnRoTjnllCTJ/vvvn0MOOSQ//elPyyO6VatWadWqVZYvX54k2WWXXbLDDjts1DFfeOGFNGvWLOedd175Y1/5ylfW2uaWW25JaWlpfvKTn6Rhw4ZJkvbt2+erX/1qfvvb3+aAAw7I1KlT8/rrr+e///u/s8cee5Tve8EFF6xzzJNPPjklJSUZNWpUjjrqqBx88MFp3759Xn/99Rx44IG55557Mnfu3Dz22GP5whe+kCTp2rVrDjrooEycODEDBgwof60ddtghw4cPT5Lst99+eeyxx/LMM8+UR3S3bt2SJPXr10+TJk3Kv17f+zBw4MAcfvjhSVK+P0BiOQewGejatWvatWuXSZMmbfRrNGjQIElSr169JJ8E1JqvFy1atNa2++2331rH3nbbbTNjxowkydNPP53S0tIcfPDBWblyZfmv3XffPS+99NJ6j92vX7+Nnvull15KWVnZWjPVqlUrPXv2zF//+teNft1P07Fjx8ydOzfXXHNNpk2blqVLl66zzTPPPJOePXumXr165e9Bu3btst1225W/D3/729+y7bbbrhXQ++6773qP2aBBg/X+bBYvXlx+vF133TWtW7cuP952222Xdu3arfO+77777uW/LykpSZs2bfLBBx9s1PswefLk3H///Zk5c2bKysoKvwaw5XImGtgsHHPMMXnggQfSvXv3jdq/pKRkvf+sVatWVq9evda2jRo1Wuvrhg0blkfY/Pnzs2rVqrXCcI0NXcDXqlWrjZo5ST766KP1ztSoUaMsXLhwo1/30xxzzDFZvHhxJk+enLFjx6a0tDSHHXZYrrrqqtStWzfJJ+/DlClTMmXKlHX2f+edd5J8cqeQNWep19huu+3We8ySkpJP/dmsWQaz6667rrNv06ZN1/p6TYSvUVpampUrV/7b7/tf3XjjjbnpppsyevTofPDBB2nevHkuuOCC8r+BAD7fRDSwWTjiiCNyww035Pnnn1/r8a22+uR/Y//3LOH6zpwWsWDBgjRr1mytr9esL27UqFG22267/OQnP1lnvzXx96/WzLgx1gTh/Pnz07Zt2/LH58+fv8Eg/axKS0tz+umn5/TTT8+HH36YBx54IDfeeGN23XXXnHrqqUk+eR969uyZk046aZ3916ybbtasWRYsWLDWcxsb/o0aNUrr1q1z/vnnr/Pcv0bzprL99ttnxIgRSZIZM2bk+9//fi699NL06tVrnXAHPn9ENLBZaNKkSXr37r3OPaObNGmSkpKSzJkzp/yxNUsvNtbTTz+dI444Iskn62KXLFmSXXbZJckn62LvuuuulJaW5ktf+tJnOk5FdO7cOSUlJfn973+f3XbbLcknF+z9/ve/T+fOnSv9+I0bN87gwYNz991359133y1/fJ999smrr76aL33pS+UXXP6rL33pS1myZEmee+658jP3zzzzzEbNsc8++2Ty5Mlp3759+bKPz6pevXpZsmRJhbbt1KlTTj755Dz77LOZO3euiAZENLD5OOaYY3LmmWeu9VidOnWy5557ZuzYsdl9992zbNmywreQ+1ejRo3K6tWrU69evfzgBz/ITjvtlIMOOijJJxcR9urVK2eddVYGDRqUnXfeOfPnz8+f//zn1KpVKxdddNFnOva/atmyZQ477LDcdttt2XbbbdOuXbtMmDAhb7/9dq6++upNeqw1RowYkbKysuy5556pX79+HnvssSxcuDA9e/Ys3+acc87JMccck0GDBuXYY49Nw4YNM2vWrEydOjWnn3569txzz/Tu3Tvt2rXLhRdemAsuuCCrVq3KrbfeulEznXrqqZk8eXJOOeWUnHLKKWnRokXeeeed/O53v8tBBx2Ur371q4Vfs1OnThkzZkyeeOKJ7LTTTqldu3b5RYtJctRRR+XII4/MzjvvnMWLF2f06NFp3bp12rdvv1HfA7BlEdHAZmP//ffP9ttvX77mdo0rrrgiw4YNy2GHHZYdd9wxF198cf7whz9s9HEuueSSXHvttXnvvffSvXv3XHnlleVnW0tKSvKjH/0ot956a+699968++67adSoUTp37lx+j+ZN7fvf/36uv/763H777Vm4cGHatWuX0aNHb/Aivc+qS5cuGTduXCZPnpzly5dnxx13zMiRI9OrV6/ybdq3b5/x48dn1KhR+d73vpdly5aldevW6dmzZ3bcccckn6xpvuOOO3LZZZflwgsvzPbbb59hw4Zl8ODBhZeiNGnSJOPHj8+NN96Ya6+9NgsXLkzLli2z1157bfTfCJx22ml5/fXXc/HFF2f+/Plp06ZNpk6dutb7cP/992f27NnZZptt0r1791xwwQWpXbv2Rh0P2LKUlLncGIAqMmPGjPTv3z+PPvpodt555+oeB2CjORMNQKW55557Ulpami9+8Yv56KOPctttt2WfffYR0MBmT0QDUGlq166d++67L7Nnz07jxo3Ts2fPTb5uHKA6WM4BAAAF+cRCAAAoSEQDAEBBIhoAAAoS0QAAUJCIBgCAgv4fSfrMkZKmhxEAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "df = retrieval\n",
    "n_chunks = np.unique(df.n_chunks)\n",
    "plot_df = pd.DataFrame(index = n_chunks)\n",
    "\n",
    "plot_df['baseline'] = [df[(df.num_mem_tokens == 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].mean() for i in n_chunks]\n",
    "plot_df['MT'] = [df[(df.num_mem_tokens > 0) & (df.mem_len == 0) & (df.n_chunks == i)]['test acc'].mean() for i in n_chunks]\n",
    "plot_df['TXL'] = [df[(df.num_mem_tokens == 0) & (df.mem_len > 0) & (df.n_chunks == i)]['test acc'].mean() for i in n_chunks]\n",
    "plot_df.loc[1] = 1\n",
    "\n",
    "\n",
    "plt.figure(figsize=(8, 4))\n",
    "plot_df.reset_index().plot(x='index', kind='bar', figsize=(12, 8), cmap='BuPu', edgecolor='grey', width=0.7, color=[(0.8, 0.1, 0.1), (0.6, 0.6, 1), 'w'])\n",
    "plt.xlabel('Number of segments')\n",
    "plt.xticks(rotation=0)\n",
    "plt.yticks([0, 1])\n",
    "plt.ylabel('accuracy')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "for tgt_len in np.unique(plot_df.tgt_len):\n",
    "    n_chunks = int(np.ceil(df.tgt_len.max() / tgt_len))\n",
    "    \n",
    "    slice = df[df.tgt_len == tgt_len]\n",
    "    slice.boxplot('test acc', by='num_mem_tokens', figsize=(10, 6), patch_artist=True, fontsize=16)\n",
    "    plt.xlabel('num MEM', fontdict={'size': 15})\n",
    "    plt.title(f'{n_chunks} Chunks', fontdict={'size': 15})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>test acc</th>\n",
       "      <th>mean acc</th>\n",
       "      <th>med acc</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>dataset</th>\n",
       "      <th>tgt_len</th>\n",
       "      <th>max_step</th>\n",
       "      <th>num_mem_tokens</th>\n",
       "      <th>mem_len</th>\n",
       "      <th>mem_backprop_depth</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"9\" valign=\"top\">reverse</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">8</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">700000</th>\n",
       "      <th>0</th>\n",
       "      <th>8</th>\n",
       "      <th>0</th>\n",
       "      <td>(0.696, 0.627)</td>\n",
       "      <td>0.66150</td>\n",
       "      <td>0.6615</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <th>0</th>\n",
       "      <th>0</th>\n",
       "      <td>(0.701, 1.0, 1.0, 1.0)</td>\n",
       "      <td>0.92525</td>\n",
       "      <td>1.0000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">12</th>\n",
       "      <th rowspan=\"4\" valign=\"top\">850000</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0</th>\n",
       "      <th>6</th>\n",
       "      <th>0</th>\n",
       "      <td>(0.832, 0.8, 0.784, 0.782)</td>\n",
       "      <td>0.79950</td>\n",
       "      <td>0.7920</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <th>0</th>\n",
       "      <td>(0.833,)</td>\n",
       "      <td>0.83300</td>\n",
       "      <td>0.8330</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <th>0</th>\n",
       "      <th>0</th>\n",
       "      <td>(1.0, 1.0, 1.0)</td>\n",
       "      <td>1.00000</td>\n",
       "      <td>1.0000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <th>0</th>\n",
       "      <th>0</th>\n",
       "      <td>(1.0, 1.0, 1.0)</td>\n",
       "      <td>1.00000</td>\n",
       "      <td>1.0000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">24</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">400000</th>\n",
       "      <th>0</th>\n",
       "      <th>24</th>\n",
       "      <th>0</th>\n",
       "      <td>(0.959, 0.394, 0.881, 0.899)</td>\n",
       "      <td>0.78325</td>\n",
       "      <td>0.8900</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <th>0</th>\n",
       "      <th>0</th>\n",
       "      <td>(1.0, 1.0, 1.0, 1.0)</td>\n",
       "      <td>1.00000</td>\n",
       "      <td>1.0000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48</th>\n",
       "      <th>250000</th>\n",
       "      <th>0</th>\n",
       "      <th>0</th>\n",
       "      <th>0</th>\n",
       "      <td>(1.0, 1.0, 1.0)</td>\n",
       "      <td>1.00000</td>\n",
       "      <td>1.0000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                                                        test acc  \\\n",
       "dataset tgt_len max_step num_mem_tokens mem_len mem_backprop_depth                                 \n",
       "reverse 8       700000   0              8       0                                 (0.696, 0.627)   \n",
       "                         8              0       0                         (0.701, 1.0, 1.0, 1.0)   \n",
       "        12      850000   0              6       0                     (0.832, 0.8, 0.784, 0.782)   \n",
       "                                        12      0                                       (0.833,)   \n",
       "                         6              0       0                                (1.0, 1.0, 1.0)   \n",
       "                         12             0       0                                (1.0, 1.0, 1.0)   \n",
       "        24      400000   0              24      0                   (0.959, 0.394, 0.881, 0.899)   \n",
       "                         24             0       0                           (1.0, 1.0, 1.0, 1.0)   \n",
       "        48      250000   0              0       0                                (1.0, 1.0, 1.0)   \n",
       "\n",
       "                                                                    mean acc  \\\n",
       "dataset tgt_len max_step num_mem_tokens mem_len mem_backprop_depth             \n",
       "reverse 8       700000   0              8       0                    0.66150   \n",
       "                         8              0       0                    0.92525   \n",
       "        12      850000   0              6       0                    0.79950   \n",
       "                                        12      0                    0.83300   \n",
       "                         6              0       0                    1.00000   \n",
       "                         12             0       0                    1.00000   \n",
       "        24      400000   0              24      0                    0.78325   \n",
       "                         24             0       0                    1.00000   \n",
       "        48      250000   0              0       0                    1.00000   \n",
       "\n",
       "                                                                    med acc  \n",
       "dataset tgt_len max_step num_mem_tokens mem_len mem_backprop_depth           \n",
       "reverse 8       700000   0              8       0                    0.6615  \n",
       "                         8              0       0                    1.0000  \n",
       "        12      850000   0              6       0                    0.7920  \n",
       "                                        12      0                    0.8330  \n",
       "                         6              0       0                    1.0000  \n",
       "                         12             0       0                    1.0000  \n",
       "        24      400000   0              24      0                    0.8900  \n",
       "                         24             0       0                    1.0000  \n",
       "        48      250000   0              0       0                    1.0000  "
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_ = reverse\n",
    "gb_cols = ['dataset', 'tgt_len', 'max_step',  'num_mem_tokens', 'mem_len', 'mem_backprop_depth']#, 'seed']\n",
    "gb = df_.dropna(subset=['test acc']).groupby(gb_cols).agg({'test acc': tuple})\n",
    "gb['mean acc'] = df_.groupby(gb_cols).mean()['test acc']\n",
    "gb['med acc'] = df_.groupby(gb_cols).median()['test acc']\n",
    "gb['med acc'] = df_.groupby(gb_cols).median()['test acc']\n",
    "gb"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>test acc</th>\n",
       "      <th>mean acc</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>dataset</th>\n",
       "      <th>tgt_len</th>\n",
       "      <th>max_step</th>\n",
       "      <th>num_mem_tokens</th>\n",
       "      <th>mem_len</th>\n",
       "      <th>mem_backprop_depth</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"9\" valign=\"top\">retrieval</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">2</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">1000000</th>\n",
       "      <th>0</th>\n",
       "      <th>2</th>\n",
       "      <th>0</th>\n",
       "      <td>(0.965, 0.999, 0.965, 0.999)</td>\n",
       "      <td>0.982000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <th>0</th>\n",
       "      <th>0</th>\n",
       "      <td>(0.989, 0.922, 0.984, 0.989, 0.922, 0.984)</td>\n",
       "      <td>0.965000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">3</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">1000000</th>\n",
       "      <th>0</th>\n",
       "      <th>3</th>\n",
       "      <th>0</th>\n",
       "      <td>(0.669, 0.905, 0.973, 0.669, 0.905, 0.973)</td>\n",
       "      <td>0.849000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <th>0</th>\n",
       "      <th>0</th>\n",
       "      <td>(0.986, 0.994, 0.996, 0.986, 0.994, 0.996)</td>\n",
       "      <td>0.992000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">4</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">1000000</th>\n",
       "      <th>0</th>\n",
       "      <th>4</th>\n",
       "      <th>0</th>\n",
       "      <td>(1.0, 1.0, 1.0, 1.0, 1.0, 1.0)</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <th>0</th>\n",
       "      <th>0</th>\n",
       "      <td>(0.999, 1.0, 0.999, 0.999, 1.0, 0.999)</td>\n",
       "      <td>0.999333</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">5</th>\n",
       "      <th>700000</th>\n",
       "      <th>5</th>\n",
       "      <th>0</th>\n",
       "      <th>0</th>\n",
       "      <td>(0.963, 0.963, 0.963)</td>\n",
       "      <td>0.963000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">1000000</th>\n",
       "      <th>0</th>\n",
       "      <th>5</th>\n",
       "      <th>0</th>\n",
       "      <td>(1.0, 1.0, 1.0)</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <th>0</th>\n",
       "      <th>0</th>\n",
       "      <td>(0.999, 0.998, 0.999, 0.998, 0.999, 0.998)</td>\n",
       "      <td>0.998500</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                                                                        test acc  \\\n",
       "dataset   tgt_len max_step num_mem_tokens mem_len mem_backprop_depth                                               \n",
       "retrieval 2       1000000  0              2       0                                 (0.965, 0.999, 0.965, 0.999)   \n",
       "                           2              0       0                   (0.989, 0.922, 0.984, 0.989, 0.922, 0.984)   \n",
       "          3       1000000  0              3       0                   (0.669, 0.905, 0.973, 0.669, 0.905, 0.973)   \n",
       "                           3              0       0                   (0.986, 0.994, 0.996, 0.986, 0.994, 0.996)   \n",
       "          4       1000000  0              4       0                               (1.0, 1.0, 1.0, 1.0, 1.0, 1.0)   \n",
       "                           4              0       0                       (0.999, 1.0, 0.999, 0.999, 1.0, 0.999)   \n",
       "          5       700000   5              0       0                                        (0.963, 0.963, 0.963)   \n",
       "                  1000000  0              5       0                                              (1.0, 1.0, 1.0)   \n",
       "                           5              0       0                   (0.999, 0.998, 0.999, 0.998, 0.999, 0.998)   \n",
       "\n",
       "                                                                      mean acc  \n",
       "dataset   tgt_len max_step num_mem_tokens mem_len mem_backprop_depth            \n",
       "retrieval 2       1000000  0              2       0                   0.982000  \n",
       "                           2              0       0                   0.965000  \n",
       "          3       1000000  0              3       0                   0.849000  \n",
       "                           3              0       0                   0.992000  \n",
       "          4       1000000  0              4       0                   1.000000  \n",
       "                           4              0       0                   0.999333  \n",
       "          5       700000   5              0       0                   0.963000  \n",
       "                  1000000  0              5       0                   1.000000  \n",
       "                           5              0       0                   0.998500  "
      ]
     },
     "execution_count": 51,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_ = retrieval[retrieval.lr == 0.0001]\n",
    "gb_cols = ['dataset', 'tgt_len', 'max_step',  'num_mem_tokens', 'mem_len', 'mem_backprop_depth']#, 'seed']\n",
    "gb = df_.dropna(subset=['test acc']).groupby(gb_cols).agg({'test acc': tuple})\n",
    "gb['mean acc'] = df_.groupby(gb_cols).mean()['test acc']\n",
    "gb"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "3ad594eba56fa4d30e478d0eb2c02077805d7e655fd2c7b71fc86bcad8bf7b09"
  },
  "kernelspec": {
   "display_name": "Python 3.9.0 64-bit ('cudaenv': conda)",
   "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.0"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
