{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch\n",
    "import lstnn.transformer_main as transformer_main\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import scipy.stats as stats\n",
    "plt.rcParams['font.sans-serif'] = \"Arial\"\n",
    "sns.set_style(\"ticks\")\n",
    "from lstnn.dataset import get_dataset\n",
    "import numpy as np\n",
    "import os\n",
    "%matplotlib inline\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Experimental parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_label = 'Transformer'\n",
    "curriculum = 'All'\n",
    "seeds = [2235, 6312, 6068, 9742, 8880, 2197, 669, 6256, 3309, 2541, 8643, 7785, 195, 6914, 29]\n",
    "# seeds = [2235, 6312, 6068, 9742, 8880, 2197, 669, 6256, 3309] #, 2541, 8643, 7785, 195, 6914, 29]\n",
    "# seeds = [2235, 6312, 6068, 9742]\n",
    "#seeds = [6914, 29]\n",
    "device = 'mps'\n",
    "\n",
    "# model params\n",
    "nblocks = [4] #, 5]\n",
    "head = 2\n",
    "attnheads = [head] #, 4, 8]\n",
    "# wdecays = [0.0, 0.01, 0.05, 0.1, 0.2] #wdecay = 0.0\n",
    "wdecays = [0.0] #, 0.1] #wdecay = 0.0\n",
    "dropout = 0.0\n",
    "hidden_size = 160 #160\n",
    "learning_rate = 0.0001\n",
    "training_acc_cutoff = 0.0\n",
    "cutoff_length = 0  # how many epochs must the model sustain the accuracy cutoff?\n",
    "last_epoch = 4000\n",
    "checkpoint_freq = 200\n",
    "\n",
    "initializations = [0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, \n",
    "                   1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 1.7, 1.8, 1.9, 2.0]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Measure generalization performance across these models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "df = pd.DataFrame()\n",
    "for init in initializations:\n",
    "      pestr = 'learn'\n",
    "      for epoch in range(0,last_epoch+1,checkpoint_freq):\n",
    "            for layer in nblocks:\n",
    "                  for attnhead in attnheads:\n",
    "                        for wdecay in wdecays:\n",
    "                              resultdir = f\"../results/\"\n",
    "                              modelname = f\"model-{model_label}_\" \\\n",
    "                                          f\"pe-learn-{init}_\" \\\n",
    "                                          f\"nl-{layer}_\" \\\n",
    "                                          f\"do-{dropout}_\" \\\n",
    "                                          f\"wd-{wdecay}_\" \\\n",
    "                                          f\"at-{attnhead}_\" \\\n",
    "                                          f\"hs-{hidden_size}_\" \\\n",
    "                                          f\"curr-{curriculum}_\" \\\n",
    "                                          f\"lr-{learning_rate}_\" \\\n",
    "                                          f\"co-{training_acc_cutoff}_\" \\\n",
    "                                          f\"col-{cutoff_length}/\"\n",
    "                              for seed in seeds:\n",
    "                                    checkpoint = f\"s-{seed}_\" \\\n",
    "                                                f\"e-{epoch}\" \n",
    "\n",
    "\n",
    "                                    try:\n",
    "                                          _df = pd.read_csv(resultdir + modelname + checkpoint +'.csv')\n",
    "                                          _df['seed'] = seed\n",
    "                                          _df['model'] = modelname\n",
    "                                          _df['layer'] = layer\n",
    "                                          _df['heads'] = attnhead\n",
    "                                          _df['wdecay'] = wdecay\n",
    "                                          _df['pe'] = pestr + '-' + str(init)\n",
    "                                          _df = _df.loc[_df.epoch==epoch]\n",
    "\n",
    "                                          df = pd.concat([df, _df])\n",
    "                                    except:\n",
    "                                          # _df = pd.read_csv(resultdir + modelname + checkpoint +'.csv')\n",
    "\n",
    "                                          continue\n",
    "\n",
    "df_ds = df.copy()\n",
    "models = df_ds.model.unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 70x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 70x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 70x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAADwAAABZCAYAAABixUebAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAI6UlEQVR4nO2bXWxUVR7Af3dm7p2PO6UdWofpoqFYYVqmW1cHF3hqaQhEltqURNwNAmpMbIwBq8SPxEiMbJT0gQQ1Mdm39WOXEAXXRELWTeSlG9aWdlBagxbB0k6/7HTaudPOTDtnHyojQwvcmc5IHeeX9OHec+7//H9zztx77ukZSQgh+A1huN0J/NLkhXOdvHCukxfOdfLCuU5eONdZNMKffvopW7duZfPmzbz//vs3rXvo0CFeeuml9BoSi4CBgQFRW1srRkdHhaZpor6+XnzzzTfz1m1tbRXr1q0TL774Ylptpd3DQ0ND7N27l4aGBrxeL263G7fbTUdHR8qxWltbWb9+PQ6HA5vNxpYtWzh16tScemNjYxw+fJimpqZ008aU7oV79+7lwQcf5MiRIwQCATZt2sSxY8e4++67k+pcvnx53uvfffddSktLgdkPz+l0JsqcTifnzp2bc82rr75Kc3Mzfr8/3bTTE+7s7GRiYoI9e/YA4HA4WL58OYFAIKnekSNHdMWLx+NIkpQ4FkIkHQMcO3aM0tJSNmzYwMcff5xO2kCawt3d3VRWViaOJyYm8Pv9VFRUJNXT28Mul4u2trZE2fDwcFKPA3z22WcMDw/T0NBAMBgkHA5z8OBBXnnlldSST+eLf/LkSbFt2zYRiURENBoV+/fvFy0tLWndRISYvWlt3LhRjIyMCE3TxLZt24TP57th/Y8++uiXvWnV1dVRVVVFfX09jzzyCGVlZTQ3N6cTCoBly5bR3NzM7t27aWxs5KGHHqK6uhqAhoYGBgcH0459PZIQ+TWtnCYvnOvkhXMdXcJCCEKhELlwQ9c109I0Da/XS3t7O3a7/aZ1//PXD7n0366MJKeXux5ws/nALl110355mI/pqSgD5y8BUPmndchWJZPh50UyGljxx4pbV/yJjAoPdl0mNhnB6rBz3182Yi26+Wi4HWRUuN/Xw0xsBmf5MsyGaeLjYz8XXvf2k8QNi25yzTVxJYsNyWjUlWNmhTsv8jtllKrAZbSW1kyGvjGShLy+DsvWP+uqnjHh8YFRgn3D3GcZxWyxzp40/AJPvXh89k8nGRPu7+xBmQ5RUBjHpMiY63eCSYakR9kCH2tingMJDCWlukOkLDwxMUEoFEo6Z7FY8Pt6cJjGCaoq8ZLlmB0uJHn2Ll3qcoEQjPw4SiwWS8q8qHAJVqsVLRxmfHwiKa6iKBQvdRCfmWFweHhOLs6SEowGAzE93/WfSFm4vb2d06dPJ52r8lQR+foSd1knOVFcDmPAh/9MlB84cACAf536B1euXEm6trGxkerqarq+Os/JkyeTysrLy3n00UeZjkT429/nLt3u378fVVX50e+nVNX3RND1PhwKhRITj6uzrmsJXhqio+Uo3oILSHeWYGncg2l5WaL86lLOyMjITz38M0VFRbM9rGmMj48nlSmKQnFxMfF4fN5FAKfTidFoJBaLIcuyLuGUe7igoICCgoKkc33//hoHASyKkeJlTqwVHgz2JXOuLSkpuWFcVVVRVXXeMoPBkPjQ5kOvLGTo5cHv6+EOeRzFbMK4YhWSbf7EFwMLFtZGgoR+6GOJKYxilTG6q5EM+iYBt4MFC/f7eiiKjyIrJuRlLozXfHcXIwsX7rxIsWkc2WxEXrkaybb45s/XsiDh+PQMQ19doMioIZtNGFZV6Z7T3i4WJDx84Qo2bQijEczOOzCVrcpUXlljQcL9vh6WSgFkswm53L3ohzMsVPjsBZaaJlDMJkzla5BM+p+Ht4u0hcOBCcQP32EgjuwoxLjKk8m8skbawn7fRRyMYpKNWO6pwKAW3PqiRUDawv2d37LUOI5iMSGv9iTejBY7aQnHZ+Jo53yYmMak2jC6qzOdV9ZIS/jHnn7s4QEkScJ8z2oMBYWZzitrpCXc3/EdDmkMxWzEsub3SIo503lljbSEA+1nUaRpjDYL8pr7Mp1TVklZeCqoYbjyLYg48p1lGAqXZiOvrJGysP/cRRwEMMlG7Pf+AclszUZeWSNl4eH/dWCRIpgsCubqtdnIKaukJCyEINbVObv0WlKKYanzltcsNlISDlwaxD41iATY770XLL+u4QwpCg+2fYWNMLLFhP2BDXN2y/0a0LVqeXUlN9TdgTI9TcRRwpS9kMh1y7W3G1VVb9kJutalBwYGqKmpyVhi2ULPP+x1CcfjcYaGhhBCUFtby+nTp28ZOFVCoRA1NTULiq2nh3UNaYPBgMvlSvzHwW63Z1z4KtmMDfldPLlPSsKKovDMM8+gKJl/2c9m7GvJ76bNdfLCuc5vTlj3DoBoNMq+ffsIBAJs376dHTt2pNSQ3+/nhRdeIBaLUVdXh8Vi4fjx49jtdmpqanjyySc5fPgwZ86cwe1289prrxEIBNi3bx/RaJSmpiZqa2tT9ZuL3l+DHD9+XHzwwQdiZmZGPP7442JqaiqlX5O8+eab4syZM0IIIXbv3i1efvll0d/fnyjv6+sTzz77rBBCiEOHDomzZ8+Kt99+W3zxxRdiampKPPbYYym1dyN0D+nz58/j9XoxGAysXr2anp6elD7Yp556Cq/XC8zOzXt7e3n99dd54okn6O3tpauri/vvvx+AtWvX4vP5Em2azWbsdjvBYDClNudD95DWNA2bzQaA1WolHA6n1FBRUREAR48eZc2aNbhcLnbs2EFvby8tLS3U1dUlxdc0DU3TEhtdrrZZWLiwNXDdwjabjcnJSQAmJyfTmuB/8sknfP7557zzzjtEo1FUVaWiooJAIICqqomtSVfj22w2wuEwqqoyOTl5w10+qaB7SHs8Hr788kuEEHR3d7Ny5cqUGvL5fJw4cYK33noLWZbZtWsXsViM77//nuLiYiorKxM/x2tra8Pj8eDxeGhrayMSiTA2NsaSJXO3QqWK7qllJBLhueeeY2BggO3bt7Nz586UGmpqaqKvry8xtB9++GHee+89LBYLBw8eZMWKFYm7dFlZGW+88QaBQIDnn3+eYDDI008/zaZNm1IWvJ78XDrXyQvnOnnhXCcvnOvkhXOd35zw/wFpfFlcrPpJVQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 70x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAADwAAABZCAYAAABixUebAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAJMElEQVR4nO2bf2wUVR7APzO7s79Lu11syukJAvYHq3i44kFyl7ZIK3qggQjJxYJoTERDwAAx+o/E6EUJf5BAjcb7AxOjxjOGCrkjJprIP14IrewWS7mTgli6XdrS7XZ3ut3ddt/90XZlaZGZ7S701v38sZmZ9+a972fem9333sxKQgjBbwj5dgdwqykI5zsF4XynIJzvFITznYJwvmO83QFMcuzYMd577z1GR0fZsmULjY2NU/Ls2rWL9vZ2LBYLANu3b6e+vl5fRWIWEAgERG1trRgYGBCqqop169aJc+fOTclXX18vgsHgjOrKuEv39vayY8cOnnzySTweD5WVlVRWVnL69GndZX333XesWLECp9OJzWbj0Ucf5auvvkrLMzg4yMDAALt372bdunU0NTUhMpjoZdyld+zYwWOPPcbBgwcJBoOsXr2azz//nIULF6bluXTp0rTnv//++8ybNw8Yv3hlZWWptLKyMtra2tLy9/f3s3LlSl5//XUcDgcvvvgiX3zxBU899ZSuuDMS9nq9hMNhnnnmGQCcTid33nknwWAwLd/Bgwc1lZdMJpEkKbUvhEjbB1i8eDGHDh1K7Tc2NtLc3HxrhDs6Oqiurk7th8Nhenp6qKqqSsuntYXLy8tpaWlJpfX19aW1OMCZM2fo7e3lkUceAWBsbAyDwaA/+Exu/OPHj4u1a9eKWCwm4vG42LNnj9i/f3/GXySBQEDU1dWJ/v5+oaqqWLt2rfD5fGl5vF6vqKurE0NDQyIej4utW7eKY8eO6a4rI+FYLCZeffVV0dDQINavXy+amprE6OhoJkWlOHr0qHj88cdFQ0OD+OCDD1LHn3jiCREIBIQQQhw+fFisWbNG1NfXZ3yBJSEKa1p5TUE43ykI5zuahIUQRCKRjMausw1NIy1VVfF4PLS2tuJwOH417zd/+4Sf/n02K8Fp5ffLK2nYu1lT3qzOh0dH4gTafwKg+i9/RLGasln8tEgGmfkPV9084wRZFb7S8TOJaAyr08Gyv9ZhLfn13nA7yOqXlt/byVhijDsq7pqVspDlFvb7OikyDFMx1sHwhwcAAUggxMT2BBOHx7lmGihNfFw3NZyWiTySLKM8XIux4n5NMWZNOHwlSOhyP25rL3NGTIz9GMhW0TdHNtx6Yb+3EykRxVWcwKhYMXr+hGRUJlpiosVSm5Mbk60uIMkv2zDeK67/GZyu5WUZQ8UDmuPULRwOh4lEImnHLBYLfl8nTuMQIYedZHEZZvdKJLMZIDXR7796lUQiwbXduKSkGKvFgqoOMxQeGj84IWpSFFylpSSTSa709f1S4YR42R13YDAYSCSTaEW3cGtrKydOnEg7dp/7PmJnLjLPGqW5dD6owCefptL37t0LwNF//ovLly+nnbt+/XqWLl3K2f96OX78eFraokWLaGxsZDQW4++HP5wSy549e7BbrFzt6Uld1JuhaT4ciURSA4/JUde1DF3q49S+f7B8zn+Q73JhXrMRZfGSVHqqhfv7J1r4F0pKSrBaraiqytDQUFqayWTC5XKNt/CVK1PiKisrG2/hRAJFUTQJ627hoqIiioqK0o75v2mnhEGsZgOlzmJsy5YjO+ZMOXfu3Lk3LNdut2O326dNk2X5V1tQqyxk6XfY773AXCWMyWzEcPciJNv0gc8GZiysXh0idKkbpzGMyWrEsPg+JDmD1cRbxIyFe3wXKB4bxGQ2oDhLMVxz785GZizc7T2PyxjCZDZiXHAvsr3o5ifdRmYknBwdI9B2nlJjGMVswLCwGimTxfFbyIyE+893Y1V7UWSBubQEQ+XSbMWVM2Yk7PdeoJQgisWIsrBy2p+i2cYMhX/EpYRRzEYMi6qRjLPm+foNyVh4JKSSuPgjRkYxzXFgrNI+gL+dZCzsb7uAUwxgVAyYF1cgFxVnM66ckbnw6fO4DKHx+/deN5KS+/WrbJCRsBCCsK8NkzSKYrNirF6W7bhyRkbCVzt7sKt+JElgWrgIudiZ7bhyRkbCfu95SqUgitmI1f0Aksmc7bhyRkbCAy1ezFICxWpGWfJgtmPKKbqFY5Eo0s/nQCQx/u5uZKcrF3HlDN3CgbYLOAliUAzY/7AMyWzNRVw5Q7dw3ykvVmkExaJgeWB5LmLKKbqEhRDEfjgNQiBc5chzy3MVV87QJRy63I9juAcJcNy/FMyWHIWVO3QJXznVho1hjGYjRSv+POVtuf8HNE1vJldyh35oxTg6ilziYqSomNh1y7W3G7vdftNG0LQuHQgEqKmpyVpguULLA3tNwslkkt7eXoQQ1NbWcuLEiZsWrJdIJEJNTc2MytbSwpq6tCzLlJeXp544OByOrAtPksuyofAWT/6jS9hkMrF9+3ZMpuxP9nNZ9rUU3qbNdwrC+c5vTljzo4J4PM7OnTsJBoNs2LCBTZs26aqop6eHV155hUQiwapVq7BYLBw5cgSHw0FNTQ3PP/88Bw4c4OTJk1RWVvLGG28QDAbZuXMn8Xicbdu2UVtbq9dvKlr/HHHkyBHx8ccfi7GxMfHss8+KkZERXX+ueOedd8TJkyeFEEJs2bJFvPbaa8Lv96fSu7u7xcsvvyyEEGLfvn3i+++/F01NTeLbb78VIyMjYuvWrbrquxGau3R7ezsejwdZlqmoqKCzs1PXhX3hhRfweDzA+Ni8q6uLN998k+eee46uri7Onj3Lgw+OLwg+9NBD+Hy+VJ1msxmHw0EoFNJV53Ro7tKqqmKz2QCwWq0MDw/rqqikpASAzz77jCVLllBeXs6mTZvo6upi//79rFq1Kq18VVVRVTX1ostkncXFM3uko1nYZrMRjUYBiEajGQ3wv/zyS77++mveffdd4vE4drudqqoqgsEgdrs99WrSZPk2m43h4WHsdjvRaPSGb/noQXOXdrvdnDp1CiEEHR0d3HPPPboq8vl8NDc3c+jQIRRFYfPmzSQSCS5evIjL5aK6ujr1d7yWlhbcbjdut5uWlhZisRiDg4PMmTPz58+ah5axWIxdu3YRCATYsGEDTz/9tK6Ktm3bRnd3d6prb9y4kY8++giLxcJbb73F/PnzU9/SCxYs4O233yYYDLJ7925CoRAvvfQSq1ev1i14PYWxdL5TEM53CsL5TkE43ykI5zu/OeH/AYDMN/mx0FddAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 70x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 70x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAADwAAABZCAYAAABixUebAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAIvElEQVR4nO2bW2wTVxqAP3t8t5M4hMSJkhUhlNyXLpjd7b5sLkJbVeWyIBG0AsJFSEQIJU1BSH1atcmKVnmoRFu17xVLqj6kVR9QK1YiD1sEBIjDQlgtCYQQx7kQE2zH8Tj22Yc0Vt2ExuPYJbj+3sbnzH/+z/N75vjMjEoIIfgVoX7RCfzSpIVTnbRwqpMWTnXSwqlOWjjV0bzoBBb45ptv+PTTT5mbm6OxsZEDBw5EtV+4cIHOzs7IttPppLa2lo6ODmUDiVWAy+UStbW1YmpqSvh8PrFjxw5x79695/YfHBwUdXV1wuVyKR4r7iM8Pj5Oe3s7Q0NDPH78GK/XC0BnZyebN29WFOv777/ntddeIzs7G4DXX3+db7/9lrKysiX7v/feezQ3N2Oz2RTnHbdwc3Mzb7zxBufOncPtdrNt2za+/PJLSkpKovoMDQ0tuf9nn31GQUEBMP/l5eXlRdry8vLo6+tbcr9r164xOTnJrl274so7LuHe3l48Hg+HDh0CIDs7m8LCQtxud1S/c+fOxRQvHA6jUqki20KIqO0fc+HCBY4cOfLc9uWIS7i/v5+KiorItsfjYXR0lPLy8qh+sR7h/Px8enp6Im0TExNRR3wBWZa5cuUKbW1t8aQ9TzwnmYsXL4rt27eLQCAgZFkWp0+fFh0dHfGEEkLMn7Tq6urE5OSk8Pl8Yvv27cLhcCzqd/v2bbFv3764xxFCiLiuw/X19VRXV7Njxw727dtHcXExra2tcX/pNpuN1tZWGhsb2b17Nzt37mTTpk0A7Nq1i7GxMQAePXoUqYp4UQmRXtNKadLCqU5aONWJSVgIgdfrJRVO6DHNtHw+H3a7nRs3bmCxWH6277/+8U8eXrmbkORi5Te/L+Mvfz8YU9+E/h+em5Vx3XkIQMWbf0Rr1CUy/JKoJDXr/lC+fMcfSKjwWP8jgv4ARquZzX+rw2j9+Wp4EST0pOXsHSAUDLF2Y9GqlIVECzsGAMgtLUpk2ISSMGHPmJvpx5OoVCqKtrySqLAJJ2G/4dG+QebkILYiC5b+bvx9s9EdhACWuaypVIAqepNl/uhLEppX/4SmZOnloJ+iWNjj8UTWrxYwGAw4ewcIC0Fu1hNGbg1DaC6SrI0gAFNoCEYE5uUzCWEkzAwSHqSouDoE2cwRBibQLsplLUEkIQh4PGQlS/jGjRt0d3dHfVZdXU3wzkNU+hAXjWbAHPVjOVM2v9j23dAUztlg1L5vFmRRlWXk/pSPS+OeqLZik5aGQiuBUJjzg08W5XJyfQ56nYbJolKyYsxfsbDdbl+0muh9/IR/P7tNodHPn0MepIxM9DsPotLOHxXDD6uLf52aIhiMFrZmZqI3GNg0M0OxJ1pYp9Ohz7aiDYc5NjG5KJfMtTlIkoRNwalIsXBGRgYZGRlRn9263E9InmNdgUy+KoR2Yyn6jWWo1NGJ5Jqj94uKa8kkIy9/yTY1UJiZ/dx9lUxvEnKWdjoG0amCWDUzEA4jVdoXya4WVpyVf9rHk4FRcrXT6I0a1Dk2NIXFCUgtOaxYeNQxQEgOUmiV0WjVSCXlYDQnIreksGJhZ+8AOjFLtiGACtBUb1215QwrFBZCMNr3gFztNDqdhDqvACl/9U4rYYXCU4OjzLg92AxedEYtUknFqi5nWKGw0zGALujFagwhaaX5co7zns8vxQqFB1mrfYZOL6G2FSHlLn0dXU3ELSz7Zpn47zB52qfoDBqkDau/nGEFwq7/PEAne8jQh9AadWh/u/rLGVYg7HQMkqN2o9VLSEXFqNcsvr25GolLWAiBs/c+eZqn6PQaNBsqwWBKdG5JIS7hZyOTMOnEKAXRW4xoqu0vRTlDnMJOxyBrxBQanYS2uAS1dW2i80oa8Qnfus9azfR8OW+sBoMx0XklDcXCc4EgM/fuolfJaM0GNFUvTzlDHMJj/Y+wBsdRq1XoXylFbV2TjLyShmLh0d7/kSPNTzb0la+i0r885QxxCD+7eQstQSSTEU2lPRk5JRVFwt7JafQTg4BAv34j6kxrcrJKIoqEx/ruk6Nyo9VKmH63BZXekKy8kkZMq5YLN8LHrl/DFgogTGbkDZWEfrIg/6Ixm83LXjFiek7L5XJRU1OTsMSSRSw37GMSDofDjI+PI4SgtraW7u7uZQMrxev1UlNTs6LYsRzhmEparVaTn58fuadksVgSLrxAMmND+ime1EeRsE6n4+TJk+h0iX9YJZmxf0z6adpUJy2c6vzqhGN+AkCWZVpaWnC73ezZs4eGhgZFA42OjnLmzBmCwSD19fUYDAa6urqwWCzU1NRw7NgxPvzwQ65evUpZWRnvvvsubreblpYWZFmmqamJ2tpapX6LifVtkK6uLnH+/HkRCoXEkSNHxOzsrKK3Sd5//31x9epVIYQQjY2N4p133hFOpzPSPjIyIt566y0hhBAffPCBuHnzpvj444/F5cuXxezsrDh8+LCi8Z5HzCV9584d7HY7arWa0tJSBgYGFH2xx48fx26fXzAIh8MMDw/T1tbG0aNHGR4e5u7du2zZsgWArVu34nA4ImPq9XosFgvT09OKxlyKmEva5/NhMs0vthuNRmZmZhQNZLVaAfjiiy+orKwkPz+fhoYGhoeH6ejooL6+Piq+z+fD5/NhNpujxszKivUBpaWJWdhkMuH3+wHw+/1xTfC//vprLl26xCeffIIsy5jNZsrLy3G73ZjN5sj7SQvxTSYTMzMzmM1m/H5/RH4lxFzSVVVVXL9+HSEE/f39rF+/XtFADoeDr776io8++gitVsvBgwcJBoM8ePCAnJwcKioqIq/j9fT0UFVVRVVVFT09PQQCAZ4+fUpmZqYyuyWIeWoZCAR4++23cblc7Nmzh/379ysaqKmpiZGRkUhp7927l88//xyDwUB7ezvr1q2LnKWLi4s5e/YsbrebU6dOMT09zYkTJ9i2bZtiwZ+SnkunOmnhVCctnOqkhVOdtHCq86sT/j+DJ1Bjui9IWgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 70x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 70x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 70x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 70x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 70x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 70x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 70x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAADwAAABZCAYAAABixUebAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAJcUlEQVR4nO2afWwUZR7HPzOzW7Y7W9rSF7u0XFsqfdcoRQ33kmLTmJgLaSQR7oL4FhMbY0DUGE1UTu0FG/8gQU0Mf5x/GC8QEgp/HCYXz8CFhBQKshraw0tbsbbblsq2dF+6O7Pz3B/bXbq00NntFrh1v8lmZ57nN7/f7zPPM88888xIQgjBr0jynU7gdisDnO7KAKe7MsDprgxwuisDnO66q4C9Xi+bN2/m559/vqVdZ2cnb775ZlIx7hpgl8vF9u3bGRwcvKXd6dOn6erqSjpO0sDj4+Ps3LmTtrY2mpqaqKmpoaamhm+//TYpfwcPHuSdd96huLj4pjaTk5Ps27eP9vb2ZNPGkuyBO3fu5PHHH2f//v14PB5aW1s5fPgwa9eujbO5fPnygsd/9tlnOJ3O2P7evXsXjfnuu++ye/du3G53smknB3zhwgWmp6d55plnAMjPz6e0tBSPxxNnt3///qQTu1GHDx/G6XSyceNGjhw5krSfpID7+vqoq6uL7U9PT+N2u6mtrY2zS6SFF9Px48e5cuUKbW1tTE1N4ff76ejo4O23304o96SA8/PzuXTpEqFQCEmSeP/999m2bRuqqsbZpbKFP//889j2kSNHOHPmTMKwkOSg1dLSQmNjI5s3b2bbtm1UVFSwe/fuZFwtqra2NsbGxlLmT8qsaaW5MsDprgxwussUsBACr9dLOgzopiYePp+PpqYmzp07h8PhuKXtv/76d3483ZuS5MxqzUM1PLZnhynbpB8eFpIe1BjtjUwl6/74CNbsrFS6X1CSIlP+cO3ihrNKKfBY72U0/wzZeSoP/vlRsvNu3RvuhFI6aLm/GyCshSlcV3ZXwsIyAAMUritNpduUKmXAvokpPD+NI0lQuv7eVLlNuVIGPOIaIBzUyV1TTEGl+efc262EB63p6Wm8Xm9cmc1mi1y/wsBWtYorVyfi6qMP+hMTE2iaFleXl5dHdnY2Pp+Pa9euxdVlZWVRUFCAYRgLPiIWFxejKAqapmG1Wk3lnzDwuXPnOHnyZFxZY2Mj+veDhLOgx9tPz4H+uPo9e/YAcOzYsXlLsE888QT3338/Fy9e5Kuvvoqrq6qq4qmnnkLTNA4cODAvl9dffx1VVZmYmDC9emLqedjr9cYmHtFZ11z53ZOc6jiEUCT+8Jc/YV+1Mq7+/7qFc3JyyMnJiStznfoBPaRT0ljB2vpqJEla8NjCwsKb+lVVdd4SUVSyLN+yBc3CQooGLbcrcjsqqi67KezdoiUDB70Brvx3GADnfWsXsb7zWjLw6PeD6EENR1Ee99T/JhU5LauWDDziGsDQwxRWl5Kl2lKR07JqScBCiNnppKBoXVmKUlpeLelp6drwBN5xD7KisGbDuli5MMKg6yBJICsgywkPZkIIEAaIWMHNjWUZSTbXdksCHnENoAd1Cqqc5JYVRfIyDMJDA4hrkyBLwGwysgwWS+QEWCygKIAEYQOM8PVfdF8IxFzgebpeIa1chWVN5e0A7kcIQeG6UmSLEkljehLj6hXkbDXSwsIAw0DoYdCCYIhYWSRbafYnx7al2L98w0U3v5eIgA/0kOmckwbWgxpjvT8BgnvqyyPBdZ3QqX+inz91vQVjeUa35ySdinu2rmN55FEslTWmzJMGHr80RMgXwJajsvqBKgDCA31o3d+ArCAZ4WRdJySh64jJicUNZ5U08MiFfsJaGOd9q7Hn52D4fQT/cRAApawS68PNsxnNuQiXYdXT8HmRnWtM2ycNHLsd1USCBb85ivHLGJKaQ9ZvW8FmB0RkbBGz16sQs9BiDrzJbi9Jkfqo3ey/LCsJ3QGSAvb9cg3P5TFAovTBe9EH/oN+5t+gKFgf3oQI+CE4c31AihJJc39zHM5t+OiJmNczZk9e9GQJMbsrTN+SIElg93cDhEM6uaWF5JetIvi3TjDCKPfWI+UVIOXmI5eUIcnKLGt0FOb6aBwtX6jLx8qiPeSGXiHE7EuBSL1kNb8cnBTwiKsfI2xQVF2Kceo4xsQokpqDpX49kl1FKa1Ayl74US9VSnZ8T3hqKQyD0e8HQQicxTLamRMgSVibfo+UraKUVi477FKUMPAv/W4CHi9ZNoV73GdB11Cq6pCLnCiry5FX5i1DmqlTwsAj3w2gh3QaSrzI3qtIdgdK7YPIzt8grSpajhxTqoSB3a4B8i3TlEjjEA5jeWAjSmk5crHzrl/tgASBQ/4Zrv7wI9XZI6xYIaNUrMNS9wCKc831EfkuV0LAY30/US4uY7eGseblYv3dYyiry5Es5hfR7rRM3ZaiK7mjJ06wiglCsgXtoUeRClcjaTpo3kU83B6pqrroZWVqXXp0dJTm5uaUJbZcMvPC3hSwYRiMj48jhGDTpk2cPHlyUceJyuv10tzcvCTfZlrYVJeWZZmSkpLYGweHw5Fy4KiW0zdkvuJJfyUEnJWVxcsvv0xWVuo/VllO33OV+Zo23ZUBTnf96oBNL/GEQiF27dqFx+Nhy5YtbN26NaFAbrebN954A03TaGlpwWaz0dXVhcPhoLm5mRdeeIF9+/bR3d1NTU0N7733Hh6Ph127dhEKhWhvb2fTpk2J8s2XMKmuri7x5ZdfinA4LJ577jkxMzNj9lAhhBAffvih6O7uFkII8fTTT4u33npLjIyMxOqHh4fFK6+8IoQQorOzU5w/f1588skn4sSJE2JmZkY8++yzCcW7mUx36YsXL9LU1IQsy1RXV9Pf37/4QXP04osv0tTUBETm5kNDQ3zwwQc8//zzDA0N0dvby/r16wHYsGEDLpcrFnPFihU4HA6mpqYSirmQTHdpn8+H3W4HIDs7G7/fn1CgvLw8AA4dOkR9fT0lJSVs3bqVoaEhPvroI1paWuL8+3w+fD5f7EOXaMzc3NyE4t4o08B2u51AIABAIBBIaoJ/7Ngxvv76az799FNCoRCqqlJbW4vH40FV1dinSVH/drsdv9+PqqoEAoGbfuWTiEx36YaGBs6ePYsQgr6+Piorzb2PjcrlcnH06FE+/vhjrFYrO3bsQNM0BgcHKSgooK6ujp6eHgB6enpoaGigoaGBnp4egsEgk5OTrFy5cpEoi8v01DIYDPLqq68yOjrKli1b2L59e0KB2tvbGR4ejnXtJ598ki+++AKbzUZHRwfl5eWxUbqiooK9e/fi8Xh47bXXmJqa4qWXXqK1tTVhwBuVmUunuzLA6a4McLorA5zuygCnu351wP8DTn1c2dzzXH8AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 70x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 70x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 70x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 70x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 70x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 70x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 70x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for init in initializations:\n",
    "    plt.figure(figsize=(0.7, 1))\n",
    "    pestr = f'learn-{init}'\n",
    "    #\n",
    "    df_ds_mod = df_ds.loc[(df_ds.pe==pestr) & \\\n",
    "                            (df_ds.condition=='average') & \\\n",
    "                            (df_ds.heads==head) & \\\n",
    "                            (df_ds.phase!='test')]\n",
    "    # plot_df = df_ds_mod.loc[(df_ds_mod['phase'] == 'train') & (df_ds_mod['condition'] != 'average')].reset_index()\n",
    "    ax = sns.lineplot(data=df_ds_mod,\n",
    "                x='epoch', y='accuracy', hue='phase', \n",
    "                legend=True, palette='rocket', alpha=0.75,\n",
    "                hue_order=['train', 'validation'])\n",
    "    plt.plot(df_ds_mod.epoch.unique(),np.repeat(0.827,len(df_ds_mod.epoch.unique())),\n",
    "                color='grey', linestyle='dashed',linewidth=1, markersize=2)\n",
    "    plt.title(r\"$\\sigma=$\" + str(init) + \"\", fontsize=8, fontname='Arial')\n",
    "    plt.xlabel('', fontsize=8, fontname='Arial')\n",
    "    plt.ylabel('', fontsize=8, fontname='Arial')\n",
    "    plt.yticks([],fontsize=6)\n",
    "    plt.legend(loc=4,prop={'size': 5})\n",
    "    plt.xticks(fontsize=6)\n",
    "    plt.legend().remove()\n",
    "    plt.ylim([0.25, 1.0])\n",
    "    sns.despine()\n",
    "    plt.tight_layout()\n",
    "\n",
    "\n",
    "    outputdir = '../figures/manuscript_figures_v3/appendix/multihead_commonPEs/learnable_pes/'\n",
    "    if not os.path.exists(outputdir):\n",
    "        os.makedirs(outputdir)\n",
    "    plt.savefig(f'{outputdir}training_traj_learnable_{head}head_{init}.pdf',transparent=True,dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 124,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 325x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "i = 1\n",
    "tmpdf = df_ds.loc[(df_ds.epoch==df_ds.epoch.max()) & \\\n",
    "                (df_ds.phase=='validation') & \\\n",
    "                (df_ds.wdecay==0.0) & \\\n",
    "                (df_ds.heads==head) & \\\n",
    "                (df_ds.condition=='average')]\n",
    "plt.figure(figsize=(3.25,1.5))\n",
    "ax = sns.boxplot(data=tmpdf,x=\"pe\",y=\"accuracy\",hue=\"pe\",fliersize=1,palette='rocket',dodge=False)\n",
    "# ax = sns.barplot(data=tmpdf,x=\"pe\",y=\"accuracy\",hue=\"pe\",fliersize=1,palette='rocket')\n",
    "plt.plot(range(len(tmpdf.pe.unique())),np.repeat(0.827,len(tmpdf.pe.unique())),\n",
    "            color='grey', linestyle='dashed',linewidth=1, markersize=2)\n",
    "plt.xticks(np.arange(0.,len(initializations)), initializations, rotation=-90,fontsize=7)\n",
    "plt.xlabel(r\"$\\sigma$ initialization\",fontsize=8)\n",
    "plt.title(f\"Multihead attention performance ({head} heads), learnable PE\",fontsize=8)\n",
    "plt.ylabel('Accuracy', fontsize=8, fontname='Arial')\n",
    "plt.yticks(fontsize=7)\n",
    "# for container in ax.containers:\n",
    "#     # ax.bar_label(container, fmt='%.1f',fontsize=4)\n",
    "#     ax.bar_label(container, fmt='%.4s',fontsize=5)\n",
    "# plt.ylim([0.25,1.25])\n",
    "# mean_val = tmpdf.groupby('pe').mean(numeric_only=True).reset_index()\n",
    "# j = 0\n",
    "# for pe in mean_val.pe.unique():\n",
    "#     value = mean_val.loc[mean_val.pe==pe].accuracy.values[0]\n",
    "#     ax.text(j, 1, f'{value:.2f}', \n",
    "#             horizontalalignment='center', verticalalignment='bottom', \n",
    "#             fontsize=6, color='black', fontweight='bold')\n",
    "#     j += 1\n",
    "sns.despine()\n",
    "plt.tight_layout()\n",
    "i += 1\n",
    "\n",
    "outputdir = '../figures/manuscript_figures_v3/appendix/multihead_commonPEs/'\n",
    "if not os.path.exists(outputdir):\n",
    "    os.makedirs(outputdir)\n",
    "plt.savefig(f'{outputdir}validation_performance_learnablePEs_{head}head.pdf',transparent=True,dpi=300)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Print stats to latex"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{rrrrr}\n",
      "\\toprule\n",
      "PE & Training accuracy & Training SD & Validation accuracy & Validation SD \\\\\n",
      "\\midrule\n",
      "0.100 & 1.000 & 0.000 & 0.925 & 0.083 \\\\\n",
      "0.200 & 1.000 & 0.000 & 0.956 & 0.039 \\\\\n",
      "0.300 & 1.000 & 0.000 & 0.946 & 0.022 \\\\\n",
      "0.400 & 1.000 & 0.000 & 0.929 & 0.048 \\\\\n",
      "0.500 & 1.000 & 0.000 & 0.946 & 0.025 \\\\\n",
      "0.600 & 1.000 & 0.000 & 0.929 & 0.027 \\\\\n",
      "0.700 & 1.000 & 0.000 & 0.926 & 0.027 \\\\\n",
      "0.800 & 1.000 & 0.000 & 0.916 & 0.048 \\\\\n",
      "0.900 & 1.000 & 0.000 & 0.896 & 0.060 \\\\\n",
      "1.000 & 1.000 & 0.000 & 0.894 & 0.043 \\\\\n",
      "1.100 & 1.000 & 0.000 & 0.835 & 0.101 \\\\\n",
      "1.200 & 1.000 & 0.000 & 0.756 & 0.141 \\\\\n",
      "1.300 & 1.000 & 0.000 & 0.702 & 0.126 \\\\\n",
      "1.400 & 1.000 & 0.000 & 0.654 & 0.161 \\\\\n",
      "1.500 & 1.000 & 0.000 & 0.616 & 0.208 \\\\\n",
      "1.600 & 1.000 & 0.000 & 0.582 & 0.168 \\\\\n",
      "1.700 & 1.000 & 0.000 & 0.480 & 0.167 \\\\\n",
      "1.800 & 1.000 & 0.000 & 0.378 & 0.153 \\\\\n",
      "1.900 & 1.000 & 0.000 & 0.406 & 0.161 \\\\\n",
      "2.000 & 1.000 & 0.000 & 0.377 & 0.171 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n",
      "\\begin{tabular}{lrrrrrrrrrrrrrrrrrrrr}\n",
      "\\toprule\n",
      "\\midrule\n",
      "PE & 0.10 & 0.20 & 0.30 & 0.40 & 0.50 & 0.60 & 0.70 & 0.80 & 0.90 & 1.00 & 1.10 & 1.20 & 1.30 & 1.40 & 1.50 & 1.60 & 1.70 & 1.80 & 1.90 & 2.00 \\\\\n",
      "Training accuracy & 1.00 & 1.00 & 1.00 & 1.00 & 1.00 & 1.00 & 1.00 & 1.00 & 1.00 & 1.00 & 1.00 & 1.00 & 1.00 & 1.00 & 1.00 & 1.00 & 1.00 & 1.00 & 1.00 & 1.00 \\\\\n",
      "Training SD & 0.00 & 0.00 & 0.00 & 0.00 & 0.00 & 0.00 & 0.00 & 0.00 & 0.00 & 0.00 & 0.00 & 0.00 & 0.00 & 0.00 & 0.00 & 0.00 & 0.00 & 0.00 & 0.00 & 0.00 \\\\\n",
      "Validation accuracy & 0.92 & 0.96 & 0.95 & 0.93 & 0.95 & 0.93 & 0.93 & 0.92 & 0.90 & 0.89 & 0.84 & 0.76 & 0.70 & 0.65 & 0.62 & 0.58 & 0.48 & 0.38 & 0.41 & 0.38 \\\\\n",
      "Validation SD & 0.08 & 0.04 & 0.02 & 0.05 & 0.03 & 0.03 & 0.03 & 0.05 & 0.06 & 0.04 & 0.10 & 0.14 & 0.13 & 0.16 & 0.21 & 0.17 & 0.17 & 0.15 & 0.16 & 0.17 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "tmpdf = df_ds.loc[(df_ds.epoch==df_ds.epoch.max()) & \\\n",
    "                (df_ds.wdecay==0.0) & \\\n",
    "                (df_ds.heads==head) & \\\n",
    "                (df_ds.condition=='average')]\n",
    "\n",
    "# Get mean and SD\n",
    "meandf = tmpdf.groupby(['pe','phase']).mean(numeric_only=True).reset_index()\n",
    "sddf = tmpdf.groupby(['pe','phase']).std(numeric_only=True).reset_index()\n",
    "\n",
    "df_to_latex = pd.DataFrame()\n",
    "df_to_latex['PE'] = initializations\n",
    "# df_to_latex['Phase'] = meandf.phase.values\n",
    "df_to_latex['Training accuracy'] = meandf.loc[meandf.phase=='train'].accuracy.values\n",
    "df_to_latex['Training SD'] = sddf.loc[sddf.phase=='train'].accuracy.values\n",
    "df_to_latex['Validation accuracy'] = meandf.loc[meandf.phase=='validation'].accuracy.values\n",
    "df_to_latex['Validation SD'] = sddf.loc[sddf.phase=='validation'].accuracy.values\n",
    "\n",
    "# df_to_latex = df_to_latex.sort_values('Accuracy',ascending=False)\n",
    "\n",
    "# df_to_latex = df_to_latex.loc[df_to_latex.PE!='2d-fixed']\n",
    "\n",
    "print(df_to_latex.to_latex(index=False,header=True,float_format=\"{:.3f}\".format))\n",
    "print(df_to_latex.T.to_latex(index=True,header=False,float_format=\"{:.2f}\".format))\n",
    "# df_latex = pd.concat([meandf[['PE','Similarity']],sddf['PE','Similarity']])"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "lstnn",
   "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.18"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
