{
 "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": 2,
   "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",
    "attnheads = [1] #, 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": 3,
   "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": 9,
   "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": "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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": "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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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XXa56mtfenZ2loGBgesWWL1UfmB/LfkCdl2XixcvIiIMDg7yxRdfLOs4qFKpFAMDAz/Jt58M+xrSmqaxdu3ayjCOxWLXHbisevqG5ls8ja9AwJZl8eSTT2IF2GFYCb4Xq/k2baOrCdzouumAfS95bNtmz549xONxRkZG2L59e6CGZmZmeO6553Ach6GhIcLhMOPj48RiMQYGBnjsscc4dOgQx44do7u7m1deeYV4PM6ePXuwbZvR0VEGBweD8i2V+NT4+Lh88MEHUiwW5ZFHHpFcLuf3VBERef311+XYsWMiIvLggw/KCy+8IOfPn68cP3funDz11FMiInLw4EE5fvy4vPXWW/L5559LLpeThx9+OFB7V5PvIT01NUV/fz+apnH77bdz5syZQB37+OOP09/vPeVzXZfp6Wlee+01Hn30Uaanpzl58iR33uk9573rrruYnJystBkKhYjFYiQSiUBtXkm+h3Q6naalpQWASCRCJpMJ1FB7ezsAH330EZs2bWLt2rVs376d6elp3njjDYaGhqr8p9Np0ul05UWXcpttbT9tL803cEtLC9lsFoBsNlvTBP/o0aN89tlnvP3229i2TTQapaenh3g8TjQarbyaVPbf0tJCJpMhGo2SzWav+pZPEPke0n19fXz99deICKdOnWLjxo2BGpqcnOTjjz/mzTffxDRNdu3aheM4nD17ls7OTnp7e5mYmABgYmKCvr4++vr6mJiYIJ/PMzc3R2trazC6K8j31DKfz/P0008zOzvLyMgIO3fuDNTQ6Ogo586dqwzt+++/n/fff59wOMz+/ftZv359pUpv2LCBAwcOEI/HeeaZZ0gkEjzxxBNs3bo1MOCP1ZxLN7qawI2uJnCjqwnc6GoCN7puOuD/AUTPZwBAfKEjAAAAAElFTkSuQmCC",
      "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": [
    "head = 1\n",
    "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/validation_learnablePEs/'\n",
    "    if not os.path.exists(outputdir):\n",
    "        os.makedirs(outputdir)\n",
    "    plt.savefig(f'{outputdir}training_traj_learnable_1head_{init}.pdf',transparent=True,dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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",
    "head = 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\"Generalization performance, 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",
    "outputdir = '../figures/manuscript_figures/validation_learnablePEs/'\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": "LSTANN",
   "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
}
