{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from read_results import main as read_results\n",
    "from pathlib import Path\n",
    "import pandas as pd\n",
    "import matplotlib\n",
    "import numpy as np\n",
    "matplotlib.rcParams.update({'font.size': 12})\n",
    "save= False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[20, 20, 20, 20, 19, 18]\n",
      "[20, 20, 20, 20, 19, 18]\n"
     ]
    },
    {
     "data": {
      "image/png": "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C+bMmUMgsO99nz17Nn6/n4kTtfFh8uTJrFixgu++a/gZtaqqCsMwaplWZ82ahd9fPw9q+fLlbN68ueb1F198we7duxk/fny9sQ0xcuRI/v73vxMMBlmzpmF37KpVq7jooou46qqruPjii+ttnzx5MitXrmTYsGGMHTu21tIS31QqEu1j2Wj0LKAhFgG/jY84aYCIni0EvDpCKhEc/EuoKoJFj4IrF464ucUzh2axZ+oqw2KAu0OLDmEYwt7tW/H4A1R5J+Cyt7zjY6IJl71fvaOUpxas5/H563j1681MP7QvZ4zugcOaurInknAEGKEIsEBQxVSuZdq0aTz66KPMmTOHu+6qbfn+85//zKhRozj99NO5+uqr2bp1KzfffDPHH398jV/lwgsv5F//+hfHHXccd955J4MGDWLDhg38+OOP3HfffRx99NEEAgEuvvhiLr30UlauXMn//d//kZubW0+WTp06cfLJJ3PXXXfVRHONHj26Uec7wMSJEznjjDMYPnw4IsIzzzxDRkZGowro9NNPJycnh/POO4/FixfXrO/UqRMDBgzghhtu4KWXXuLoo4/m17/+NT169GDXrl189tlnTJw4sU3k30SrTCxARiPbMoAE3VVTEBHI6gbFm/UNOFFmqEOu0Qpl2Qxw5cH4KxJzHhFddqVij47uamEdLxEd5eW0GZRV+3DbrSnd3zxc9v7bLcU8+dk6HvroJ17+ajOXTOzHqSO7td82uqHM+nANsIBfYYhgNWSfwomCCRMm0LdvXzZu3FjvRjls2DDef/99br31VqZOnUp2djbTpk2r1dfc6XTyySefcMstt3D77bdTWlpK3759ueaaawAYMWIEM2bM4M4772TOnDkcdNBBvP7667Wir8IceuihHHPMMfzud79jz549TJo0iaeffrpZ+WfMmMHGjRuxWCyMGjWK999/n549Gw7d/+knnSd25JFH1lp/0UUXMWPGDDp27MjixYv505/+xPXXX09xcTHdunVj4sSJjBw5svk3NA2IttDjJ4BHKVWv5pWIvA+4lFKT4i9e4mhxoccw3koo2aJ9DzH0Xm8SFYT3b4I178Axd8PIBDq5VRC85ZDTC+z7n5sxY8YMQP94yj1+9pR5sBiC05b6T/pKKZZuLOKJz9axcnspPXJdXHZ4P44f1rVBhbi33MOf5/zAX88YTn5m/EqDRFXo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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from read_logs import read_log\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "pd.options.display.max_colwidth = 200\n",
    "matplotlib.rcParams.update({'font.size': 15})\n",
    "\n",
    "\n",
    "all_n_components = [4, 8, 10, 15, 25, 30]\n",
    "all_probe_dfs = []\n",
    "all_prompt_dfs = []\n",
    "for n_components in all_n_components:\n",
    "    all_res = []\n",
    "    for seed in list(range(1,21)):\n",
    "        try:\n",
    "            all_res += read_log(f'logs/trans0.01_emit0.01_nsym10_NCOM{n_components}_nexamples5000_seed{seed}')[-2:]\n",
    "        except:\n",
    "            print(f\"Skipped: logs/trans0.01_emit0.01_nsym10_NCOM{n_components}_nexamples5000_seed{seed}\")\n",
    "            pass\n",
    "    df = pd.DataFrame(all_res)\n",
    "    prompt_df = df[['prompt_tune' in name for name in df['name']]].reset_index()\n",
    "    probe_df = df[['probe' in name for name in df['name']]].reset_index()\n",
    "    all_prompt_dfs.append(prompt_df)\n",
    "    all_probe_dfs.append(probe_df)\n",
    "\n",
    "head_means = np.asarray([df['test_acc'].mean() for df in all_probe_dfs])\n",
    "head_intervals = np.asarray([df['test_acc'].std() * 1.96 / np.sqrt(len(df)) for df in all_probe_dfs])\n",
    "\n",
    "prompt_means = np.asarray([df['test_acc'].mean() for df in all_prompt_dfs])\n",
    "prompt_intervals = np.asarray([df['test_acc'].std() * 1.96 / np.sqrt(len(df)) for df in all_prompt_dfs])\n",
    "\n",
    "print([len(df) for df in all_probe_dfs])\n",
    "print([len(df) for df in all_prompt_dfs])\n",
    "\n",
    "\n",
    "plt.plot(all_n_components, prompt_means, label='Prompt Tuning', markersize=10, marker='^', color='C0')\n",
    "plt.plot(all_n_components, head_means, label='Head Tuning', markersize=10, marker='o',  color='C1')\n",
    "plt.fill_between(all_n_components, (prompt_means-prompt_intervals), (prompt_means+prompt_intervals), color='C0', alpha=.1)\n",
    "plt.fill_between(all_n_components, (head_means-head_intervals), (head_means+head_intervals), color='C1', alpha=.1)\n",
    "\n",
    "plt.axvline(x=10, label='Vocab size', c='gray', linestyle='dashed')\n",
    "plt.legend(loc='upper right')\n",
    "# plt.legend()\n",
    "plt.xlabel('# of hidden states')\n",
    "plt.ylabel('Test Accuracy')\n",
    "plt.xticks([8, 10, 15, 20, 25, 30])\n",
    "\n",
    "plt.savefig('prompt_vs_head_tuning.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZAAAAEOCAYAAACn00H/AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/Il7ecAAAACXBIWXMAAAsTAAALEwEAmpwYAABeiUlEQVR4nO2deXhU1fnHP++dLZmsQCAhYRNEC1JLLRa0KriBCmq1VdAquxvUimvdWsGFVn+K0CpqVURALSha9w0rIu7gUlEUAZE1K5CQfZbz++PODDPJJJkkM5lJcj7Pc5/M3HPuve+9uXO/95zznvcVpRQajUaj0TQXI94GaDQajaZ9ogVEo9FoNC1CC4hGo9FoWoQWEI1Go9G0CC0gGo1Go2kR1ngb0JZkZWWpfv36xduMiCkpKQGgW7ducbZEo9F0VtavX1+slOoerqxTCUi/fv1Yt25dvM2ImMWLFwMwefLkuNqh0Wg6LyLyU0NlugtLo9FoNC2iU7VA2hsnnHBCvE3QaDSaBtECksD0798/3iZoNBpNg+gurAQmPz+f/Pz8eJuh0Wg0YdECksC88cYbvPHGG/E2Q6PRaMKiBUSj0Wg0LUILiEaj0WhahB5E14Swo2wHT377JK9sfYVKVyVOm5Nx/ccxafAkeqf3jrd5miig/8eaaNGmLRAROUFEXhKRXSKiRGRynXIRkdkisltEqkRktYgcUadOFxFZKiKlvmWpiGTGwt4dZTu48+M7GfH0CI588khGPD2COz++kx1lO2JxuLjz/s73Offlc1m5aSUVrgoUigpXBSs3reTcl8/l/Z3vx9tETSvR/2NNNGnrLqxUYANwFVAVpvwG4FrgSuBooBB4W0TSguo8DRwFnOZbjgKWRtvQRPihnXzyyZx88skxPw6YYnnNe9dQ7a7GrdwhZW7lptpdzTXvXdNhxbMzoP/HmmjTpgKilHpNKXWzUuo5wBtcJiICzAL+rpRaqZTaAEwC0oALfXUGYYrGpUqpj5RSHwGXAeNE5PBo2RnRD231NWwr3YbH68GrvPUWpVTI0hJ69+5N795t06Xw5LdP4va4G63j9rhZ8u2SNrFHE330/1gTbRJpDOQQIAd4y79CKVUlImuAY4FHgGOAcuDDoO0+ACp8db6PhiGR/NBqvbXc/dndnDfwPLyECof/u1Lq4HpUYJ1HeczzI7Q8pL5S1JTU4MWLtasVrzL1Nlx9hblPv1h5lfegDXX3G3TM4PJ3d7wbsKsh3MrNs5ueZfuB7Q3WaUgsFQ2LaN0yQSLbrgXC3Ng2zbGxTmFU99ei84rAvq9Lvg7cRw3hVm5e2PwCv+75a7o4upDpyCTTkUmyNRnzHc8k5HPQ/6vJsuDv0sD6Ot+D99dUmaZtSSQByfH9LaizvgDIC6pTpIJ+YUopJSKFQduHICKXApcC9OnTJyJDXtn6Sr2WR128ysvaXWtZu2ttRPtsCSP3jATgvZ7vRVTfEAMDAxExP/sWQcJ/9tUTpEnx8ONRHvIrGp/cWPdhEFTQ/G2aKGvJPhvdXyOEPKzqPq8bPOWmzyvcw7+xB2NL7BeRJsXDT42nhmtWXxOyzmbYSLenk25PJ8OREfic7gj9m2ZLIzMpkzR7GjbD1mw7wbweLTpHpGHxkoPf69UTCSkLxhCj4X1Q51hSf38ARlBHj0gjNtY9nyiKtCBYjeg/7hNJQGKCUupfwL8Ahg0bFtGrXaWrMqJ9C8LsY2eHPJwtYgl5gAsSeKj7F4ODD3KEQD3/9v4b9cOXzIbWpWdcGigPEQbfvvz7aehmDPeD9B8TzJvxdy/9jkp30+fttDp5bPRjjR6vpTT6Q4jB/qO8+3oPjmhT96HVXE557pSI/sdJliTu+M0dlNWUccB1gAO15lJWW0ZpTSmltaVsKd1CaU0p5a7yBveTYk0h3ZFOpiOTdEc6GfYMMhxBS53vqbbU0Ad2MwluudUV5ZDvdZ4CSqlAeXC95rRWGzt2Y/Ui+X/WraeUCghIY/sIrmeIQW5qbtRFJJEExP9amw0E95FkB5XlA91FRPytEN/YSY+gOq3GaXNS4aposl6yNYmjehwV0T4DIhH0Dw1+iPsFAQgIzueWzwE4JP0QDMP8YdVtvgfvM+QBI6Hf69aty5kDzmTlppWNtrysYuWsAWfR3Rk2NYAmwWnO/3hU71F4lIcadw0ur4taT21I16sgWAwLSikqXZWmuNSWsr9mP2U1B4WmtMZc9lbt5cfSHymtKaXGUxP22AaGKTRB4uIXoAx7RkiZX5SSLEkH7/8I3+xjqPEJS6Qvxc0lkQTkR0wROBX4DEBEkoDjget9dT7C9OQ6hoPjIMcAKYSOi7SKcf3HRfBDs3B691HkJmUjNvMy+h/YIQ/0VvTR+t8W0hxpTdRsPZMGT+LFLS/idjdyzhYrEwdPjLktmtgQ6f948hGTSbImAZBiSwmUeZUXj9eDW7lxe9zUemtxeV0AOKwOuju7B+55i1iwiCXkxchPtbs6RFz8YuMXnv01+ymrLWPHgR2UFptlDXW/2Q17o60av/BkOjIDXW+x6MrprLTplRSRVOBQ31cD6CMiQ4G9SqntIjIfuFlEvgM2AbdiDpo/DaCU2igibwCP+MY2wBxcf0UpFZUBdIjwh2bYuLj3uci+UqzZ2e1+MK93em/mjZzHNe9dg9vjDhFPq1ixWqzMGzlPTzRrx7T2f2yIgWExsGGr9+TweD14lAe3143H66HGW0Otp5ZqTzVe5Q1pCVvEQlZSFtnO7Ijs9iovFa6Keq2acN/zK/Kb7lqzpZgtGN94TkPC4/+cYktpVddaR0Za6mLaooOJjALeDVP0pFJqsq876jZM19wuwCfATJ9Lr38fXYB/Amf5Vr0E/FEptb+p4w8bNkxFmpHw/Z3vN/BDs2A1bPzf0L/ym+7D8VZUYOnaBWtmZkT7bQ7+SLw5OWH9A2LCjrIdLPl2Ca9sfYUKVwUpthTG9R/HxMETtXh0ENr6f+z2uvEqL26vO9AdVuOpCXgO+gm0XAyz9dLaYwbGbBoQG//3spoy9tfsp9ZbG3Zfhhik20NbMRmOjEbHdvwtuHiyu3w3Kzat4J2f3qHKXdXiiAMisl4pNSxsWVsKSLxpjoBA8A/tZSpclTityYzNPZU/9Ps9vZ25gDlQ5a0ox56bi5GcHCvTNZoOh9+l3aM8ZqvFU4PL46LWW4vb6w7U8Tul+IUlFq0BpRTVnmqzG80nLIHxnEaEx0v4rjWHxdFoy6be2I49A4vROtEM5pM9n3D7R7fj8rpCPCyDW5rH9zo+on1pAfHRXAHxo1wuanfuxHCmhC93u1EuF/ZeeYg1er2CW7duBXRiKU3nQymFW7kDXWO17lpqvbWBwXylVMBRJFhY2rKryau8lLvKQ1oxweISzqmgMeecVFtqxGM5GXazay1c1/nu8t1c8tYlVHuqGzxWkjWJ5898PqKWSGMCokeTooBYrSi3G1dREbacnKiNh6xZswbQAqLpfIgINrEF5pI0NJjv8Xqo9RwUl+DBdn+XmCFGwL0+mvi7ttLt6Wa8jAhweV0NtmoCIlRTSlFVEZv3b2Z/zf6Ao0JdLGIJERd/t9rGko0Nerr58UccuGXELc097RC0gEQJIykJb0U5nn37sHbtGm9zNJoOS8hgfh38LRaP8uD2uAOD+TWemrDi0pCnWKywGTa6JXejW3K3iOr7u9aaGscprSllW+k2ympNEWoKt3LzytZXtIAkEuJMwb1/P0ZSEobTGW9zNJpOh8WwYME3lmCFtKCmQbCnmH8w39968XflK1SgxRKNwfzWIiIkW5NJtiaTkxKZM80pz57SeGgbH5HMdWsKLSBRREQwHEm4Cgux5+UhtpaFctBoNNHHLy52iz1kfd3B/FpvLS6PixpPDTXemkCdthjMjwbJ1uSIIg4Edwu2FC0gUUasVpTHc3A8xEjMm0yj0ZiIiOmdhBUs4ORg70G9wXx/q8VTi1u5Q2a8W4yD4y3xFJeT+57Ma1tfazS+nVWsjOs/rtXH0gISAwyHA29VpTke0i2yvs5wjBvX+n+wRqNpOZEM5vtbLzXumgYH8wPdYjEYzK/L+Yedz9vb3sbjaURAohRVQgtIjJCkZDylpYjDgSU1tUX7yMrKirJVGo0mWtQdzG8s7EuN14wp1haD+bmpufz1mL82OQ8kGpNGtYDECBGBpGTchUUYdjtitze9UR2+/96MznL44VHLlaXRaNqAumFfGhrMd3t94uJxBcK+AKExxVowmD+853AeHf0oz216jrd/ejswE/3M/mdGNeKAFpAYIhYL2GzmeEjPns0eD/noo48ALSAaTUci0sH84LAv/sF8P/7BfH/XWDhyU3P501F/4k9H/YlKVyW90np16HDuHRKx283xkL17seouKY1G0wB1B/OD8Q/m+7vGajw1gcH8GnVQXAItlzbyFNMC0gYYyU48ZWXgcGBNi31odo1G07HwD+YDpqeY7aCnmFd5A62W4BwudcdbYoEWkDZCkp14iszxEMPhiLc5Go2mg+CPAdaUp1gs8qDoSQpthBgGYnfgLihANeJep9FoNNHCEAObxRaz8PK6BdKGiM2Gt8qFu6QEa/fuTbrsnXPOOW1kmUaj0TQfLSBtjJHsxFtejsfhwJqR0WjdjCbKNRqNJp7oLqw4IMlOPMUleKsbjtcPsGHDBjZs2NBoHY1Go4kXWkDigBgGkpRkjoc0knd93bp1tCQBlkaj0bQFWkDihFitKAR3URGdKSukRqPpOGgBiSNGUhLeqmo8paXxNkWj0WiajRaQOCNOJ+6SErxVVfE2RaPRaJqFFpA4IyIYScm4CgpRrvC5jzUajSYR0W68CcDBJFTF2HKyA0EXzz///DhbFn3KysooLCzEpcVSo0kIUlJS6NWrF0YLkt9pAUkQDIcDb2UFnn37sXbrCoCzg+VVLysro6CggLy8PJKTk2OeWEej0TSO1+tl165dFBcX06NHj2Zvr7uwEghJduIu3Y+nwkx2/+WXX/Lll1/G16goUlhYSF5eHk6nU4uHRpMAGIZBdnY2pS105NECkkD4x0PchYWo2toOJyAul4vk5OR4m6HRaIKw2Wy4G5mP1hhaQBIMsVjAYsVVVBRvU2KCbnloNIlFa36TWkASEMPhQNXWaq8sjUaT0GgBSVAMZwrK49Gh3zsRkydPZty4cRF/19RHRHjuueca/K6JLlpAEhgxDJTLhbe2Nt6mJAy127ezZ84cvv/VMDYOGsz3vxrGnjlzqN2+PSbHO+usszj55JPDlm3cuBER4a233orKsRYsWMCyZcuisq+GmD17NkOGDKm3vri4GBFh9erVgXUiZnrU999/P6Sux+MhLy+v3sO5X79+iAhLly6tt//hw4cjItx7773RO5kI2LNnD2eeeWabHrMzoQUkgRl/xljGjzlNJ6HyUb5mDVvP/i37n30Ob0UFKIW3ooL9zz7H1rN/S/maNVE/5rRp03j33XfZtm1bvbLHH3+cvn37csopp0TlWBkZGWRmZkZlX9Gid+/eLFq0KGTd66+/jtUafgZAuPr+qNLdunVr1rFXr15Nv379mrVNXXJycnAkQAbQ2g76EqgFJIGx2WzYnU6Ux4O7pKRTB12s3b6dnVfNQlVVQV2PEbcbVVXFzqtmRb0lMnbsWLKzs3niiSdC1rtcLpYuXcrUqVNRSjFt2jQOOeQQkpOTGThwIPfccw9e78F81P7upwULFpCXl0eXLl2YMmUKlZWV9epEyhtvvMHxxx9Ply5d6Nq1K2PGjGHjxo2tP+kgJk+ezLPPPkt5eXlg3eOPP87kyZPD1r/wwgv56KOP2Lp1a0j93//+96SmpkbVtkgIbiVt27YNEWHlypWceuqpOJ1OBg8ezNtvvx2yzbfffsvYsWNJS0ujR48eXHDBBeTn5wfKP/vsM0aPHk1WVhbp6ekcd9xxfPTRR/WO++CDD3LuueeSkpLCzTffHPuTjQNaQBKY9Rs2sH7DhoNJqIJ+xJ2NkieeaNKpQLlclCx+MqrHtVqtTJo0icWLF4cIwssvv0xxcTFTpkzB6/WSl5fHihUr2LhxI3fddRdz586tJzrvv/8+GzZsYNWqVSxfvpwXXniBBQsWtNi2iooKZs2axaeffsrq1avJyMjgzDPPjOrb7pFHHsmgQYNYvnw5YM7lef3115kyZUrY+llZWZx55pmBc6+trWXZsmVMmzYtaja1lltuuYU//elPfPXVVxx99NFMmDAhIJB79uzhhBNOYMiQIXz66aesWrWK8vJyzj777MD//8CBA1x88cW8//77fPrppwwdOpQzzjiDkpKSkOPMmTOHM844g6+//pqZM2e2+Xm2BXomegKzccsWAH41ZIiZhKqoCMNux0iAJnm0yJ87l5qN3zVZr3L9egh6gIfF7Wb/v/9N7Q8/NFrNMehn5DTjjXDatGncfffdrFq1itGjRwPmW/Xo0aPp3bs3ALfffnugfr9+/fj888955plnQh6c6enpPPzww1gsFgYNGsR5553HO++8w0033RSxLcH87ne/C/n+xBNPkJ6ezqeffspxxx3X4HYbN25sVmtg6tSpLFq0iGnTprFkyRKOO+64RruWpk6dymWXXcacOXN46aWXyMzM5IQTToj4eLHm6quvDoyLzJ07lyVLlvDll19y3HHH8dBDD/GLX/yCu+++O1B/yZIldO3alXXr1vHrX/+ak046KWR///znP1m5ciWvv/46F110UWD9+PHjmT59etucVJxIuBaIiKSJyHwR+UlEqkTkQxE5OqhcRGS2iOz2la8WkSPiaXNbIIaB2B2ddzykKfFobr1mMHDgQEaOHBno29+9ezdvvvlmiDg8/PDDDBs2jO7du5Oamsr999/P9jrdaYMHD8ZisQS+5+bmUlhY2GK7tmzZwoUXXsiAAQNIT08nOzsbr9db77h1GTBgQGCSqn959913G6x/4YUX8sUXX/D9998HhKQxxowZg1KKt99+m8cff5ypU6dGdD7bt28nNTU1sJx++un11l1++eUR7asxjjzyyMDn3NxcgMD/Yf369axZsybkmP6XhC2+F7rCwkIuu+wyDjvsMDIyMkhLS6OwsLDedR82bFirbU10ErEF8hhwJDAJ2AlcBKwSkcFKqV3ADcC1wGTge+CvwNsicrhS6kB8TG4bxGbDW+3GXVSENTu7Q0zKi7Ql8P2vhpkD501gpKbSd+mS1ppVj2nTpnHJJZewd+9eFi9eTNeuXTn77LMBWL58ObNmzeLee+/l2GOPJT09nQcffJAXXnghZB82my3ku4iEdIs1l3HjxtGrVy8eeeQR8vLysFqtDB48uMkuLLvdzqGHHhqyrri4uMH6GRkZnHvuuVx++eXk5+dzzjnnNLp/wzCYNGkSc+fO5eOPP+bxxx+P6Hxyc3NDIi988skn/PnPfw7xDEtPT49oX40R/H/w/4b8/wev18vYsWPDeotlZ2cDMGnSJAoKCrj//vvp168fDoeDk08+ud51T0lJabWtiU5CCYiIJAO/A36nlFrtWz1bRM4ErhCRvwCzgL8rpVb6tpkEFAIXAo+0udFtjJGUjLeiAk9ZGdaMjHib02akn3Um+599rv4AejBWK+lnnRWT4//+97/nyiuvZNmyZSxatIiJEycGHkRr165l+PDh/PGPfwzU97+txoqSkhK+++47Fi5cyIknngjA559/3uKQFE0xbdo0TjrpJGbOnElSUlKT9adOncrcuXM544wzAm/5TWG1WkOEbefOnfXWxZqjjjqKFStW0Ldv33qC72ft2rX84x//YOzYsQAUFBSwZ8+eNrMxkUi0LiwrYAGq66yvAo4DDgFygIDjvVKqClgDHNtGNsYdcTpxFxfjra57mTou3aZMQRr4QfsRm41ukyfF5PjJyclceOGFzJ49my1btoR04xx22GF8/vnnvP766/zwww/ccccdvPfeezGxw0+XLl3Iysri0UcfZfPmzbz33ntcfvnlDbrXtpYTTzyRoqIi7rvvvojq9+/fn+LiYp599tmY2BMrZs6cSWlpKePHj+eTTz5h69atrFq1iksvvZQDB8wOjsMOO4xly5bx7bff8tlnnzFhwgTsdnucLY8PCSUgvi6oj4BbRSRPRCwichFwDNATUzwACupsWhBUFoKIXCoi60RkXVE7iy910dlnc5GvmySYQBKq/AJUjN44Ew17nz70WjAfSU6Gug9JqxVJTqbXgvnY+/SJmQ3Tp09n3759HHvssQwaNCiw/rLLLuP888/nwgsv5Oijj2bbtm1ce+21MbMDzG6i5cuX87///Y8hQ4Ywc+ZM7rjjjpjOecjKymrW/rt27drugmfm5ubywQcfYBgGp512GkcccQQzZ87E4XAEzn3RokWUl5fzq1/9igkTJjB16tRWz1dpr0iizS0QkQHAIuAEwAN8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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "matplotlib.rcParams.update({'font.size': 14})\n",
    "\n",
    "\n",
    "all_vanilla_dfs = []\n",
    "all_mem_slots = [2,3,5,7]\n",
    "for n_mem_slots in all_mem_slots:\n",
    "    all_res = []\n",
    "    for seed in [1,2,3,4,5]:\n",
    "        try:\n",
    "            all_res += read_log(f'logs/VANILLA_trans0.01_emit0.01_nsym10_nexamples5000_nhid4_nmem{n_mem_slots}_seed{seed}')\n",
    "        except:\n",
    "            pass\n",
    "    \n",
    "    df = pd.DataFrame(all_res)\n",
    "    probe_df = df[[('memory' not in name and 'probe' in name) for name in df['name']]].reset_index()\n",
    "    all_vanilla_dfs.append(probe_df)\n",
    "\n",
    "head_means = np.asarray([df['test_acc'].mean() for df in all_vanilla_dfs])\n",
    "head_intervals = np.asarray([df['test_acc'].std() * 1.96 / np.sqrt(len(df)) for df in all_vanilla_dfs])\n",
    "\n",
    "\n",
    "all_memory_dfs = []\n",
    "all_mem_slots = [2,3,5,7]\n",
    "for n_mem_slots in all_mem_slots:\n",
    "    all_res = []\n",
    "    for seed in [1,2,3,4,5]:\n",
    "        try:\n",
    "            all_res += read_log(f'logs/MEMORY_trans0.01_emit0.01_nsym10_nexamples5000_nhid4_nmem{n_mem_slots}_seed{seed}')\n",
    "        except:\n",
    "            pass\n",
    "    \n",
    "    df = pd.DataFrame(all_res)\n",
    "    probe_df = df[[('probe' in name) for name in df['name']]].reset_index()\n",
    "    all_memory_dfs.append(probe_df)\n",
    "\n",
    "memory_means = np.asarray([df['test_acc'].mean() for df in all_memory_dfs])\n",
    "memory_intervals = np.asarray([df['test_acc'].std() * 1.96 / np.sqrt(len(df)) for df in all_memory_dfs])\n",
    "\n",
    "\n",
    "    \n",
    "    \n",
    "plt.plot(np.asarray(all_mem_slots)*4, head_means, label='Vanilla HMM + linear', markersize=10, marker='o',  color='C3')\n",
    "plt.fill_between(np.asarray(all_mem_slots)*4, (head_means-head_intervals), (head_means+head_intervals), color='C3', alpha=.1)\n",
    "plt.plot(np.asarray(all_mem_slots)*4, memory_means, label='Memory HMM + attention', markersize=10, marker='o',  color='C2')\n",
    "plt.fill_between(np.asarray(all_mem_slots)*4, (memory_means-memory_intervals), (memory_means+memory_intervals), color='C2', alpha=.1)\n",
    "plt.axvline(x=10, label='Vocab size', c='gray', linestyle='dashed')\n",
    "plt.legend(loc='center right', bbox_to_anchor=(1.0, 0.65))\n",
    "# plt.legend()\n",
    "plt.xlabel('# of hidden states')\n",
    "plt.ylabel('Test Accuracy')\n",
    "# plt.xticks([8, 10, 15, 20, 25, 30])\n",
    "plt.savefig('memory_plot.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.7.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
