{
 "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": 4,
   "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]\n",
    "outputdir = '../figures/manuscript_figures/human_behav_comparison/'\n",
    "if not os.path.exists(outputdir):\n",
    "    os.makedirs(outputdir)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Load human behavioral data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load human data\n",
    "try:\n",
    "    human_df = pd.read_csv('../results/human_behaviour.csv')\n",
    "\n",
    "except:\n",
    "    from bids import BIDSLayout, BIDSLayoutIndexer\n",
    "    indexer = BIDSLayoutIndexer(validate=False, index_metadata=False)\n",
    "    layout = BIDSLayout('/home/lukeh/hpcworking/shared/projects/LST7T/data/bids/', indexer=indexer)\n",
    "\n",
    "    subject_list = layout.get_subjects()\n",
    "\n",
    "    human_df = pd.DataFrame()\n",
    "    for subject in subject_list:\n",
    "        all_files = layout.get(subject=subject, task='LST',suffix='events', return_type='filename')\n",
    "        if len(all_files) == 3:\n",
    "            _df = pd.concat((pd.read_csv(f, delimiter='\\t') for f in all_files), ignore_index=True)\n",
    "            _df['subject'] = subject\n",
    "            human_df = pd.concat([human_df, _df])\n",
    "    human_df.to_csv('../results/human_behaviour.csv', index=False)\n",
    "\n",
    "from lstnn.verify_LST import verify_LST\n",
    "from lstnn.dataset import get_dataset\n",
    "validation_file = '../data/nn/puzzle_data_original.csv'\n",
    "dataset = get_dataset(validation_file)\n",
    "strat_list = []\n",
    "for i in range(108):\n",
    "    _, _ , strat = verify_LST(dataset.print_puzzle(i)[0].numpy())\n",
    "    strat_list.append(strat)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Load in learnable PE performance data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "inference for epoch 4000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/tito/mambaforge/envs/lstnn/lib/python3.9/site-packages/torch/utils/checkpoint.py:542: UserWarning: torch.utils.checkpoint.checkpoint_sequential: please pass in use_reentrant=True or use_reentrant=False explicitly. The default value of use_reentrant will be updated to be False in the future. To maintain current behavior, pass use_reentrant=True. It is recommended that you use use_reentrant=False. Refer to docs for more details on the differences between the two variants.\n",
      "  warnings.warn(\n",
      "/Users/tito/mambaforge/envs/lstnn/lib/python3.9/site-packages/torch/utils/checkpoint.py:90: UserWarning: None of the inputs have requires_grad=True. Gradients will be None\n",
      "  warnings.warn(\n",
      "/Users/tito/mambaforge/envs/lstnn/lib/python3.9/site-packages/torch/utils/checkpoint.py:542: UserWarning: torch.utils.checkpoint.checkpoint_sequential: please pass in use_reentrant=True or use_reentrant=False explicitly. The default value of use_reentrant will be updated to be False in the future. To maintain current behavior, pass use_reentrant=True. It is recommended that you use use_reentrant=False. Refer to docs for more details on the differences between the two variants.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "inference for epoch 4000\n",
      "inference for epoch 4000\n",
      "inference for epoch 4000\n",
      "inference for epoch 4000\n",
      "inference for epoch 4000\n"
     ]
    }
   ],
   "source": [
    "\n",
    "# load the 108 fMRI trials\n",
    "validation_file = '../data/nn/puzzle_data_original.csv'\n",
    "dataloader = torch.utils.data.DataLoader(\n",
    "    get_dataset(validation_file), batch_size=108, shuffle=False)\n",
    "\n",
    "# ann_accuracy = np.zeros((108, len(seeds), nblocks, attnheads)) # may want to add epochs\n",
    "ann_accuracy = {}\n",
    "ann_accuracy['Accuracy'] = []\n",
    "ann_accuracy['Noise'] = []\n",
    "ann_accuracy['Epoch'] = []\n",
    "ann_accuracy['Seed'] = []\n",
    "ann_accuracy['Layers'] = []\n",
    "ann_accuracy['Heads'] = []\n",
    "ann_accuracy['Dropout'] = []\n",
    "ann_accuracy['Decay'] = []\n",
    "ann_accuracy['Puzzle'] = []\n",
    "ann_accuracy['PE'] = []\n",
    "ann_accuracy['Norm'] = []\n",
    "dropout = 0.0\n",
    "# for epoch in np.arange(0, last_epoch+1, checkpoint_freq):\n",
    "for noise_sd in [0.0, 0.02, 0.04, 0.06, 0.08, 0.1]: #[0.0, 0.05, 0.1, 0.15, 0.2, 0.25, 0.3, 0.35, 0.4]:\n",
    "# for noise_sd in [0.1, 0.2, 0.3]: #, 0.02, 0.04, 0.06, 0.08, 0.1]: #[0.0, 0.05, 0.1, 0.15, 0.2, 0.25, 0.3, 0.35, 0.4]:\n",
    "    for epoch in [4000]:\n",
    "        print('inference for epoch', epoch)\n",
    "        for init in initializations:\n",
    "            pestr = 'learn-' + str(init)\n",
    "            petype = 'learn'\n",
    "            for wdecay in wdecays:\n",
    "                for layer in nblocks:\n",
    "                    for attnhead in [1]: #attnheads:\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",
    "                                try: \n",
    "                                    checkpoint = f\"s-{seed}_\" \\\n",
    "                                                f\"e-{epoch}\" \n",
    "                                    torch.manual_seed(seed)\n",
    "                                    model = transformer_main.Transformer(\n",
    "                                                nblocks=layer,\n",
    "                                                nhead=attnhead,\n",
    "                                                dropout=dropout,\n",
    "                                                embedding_dim=hidden_size,\n",
    "                                                positional_encoding=petype,\n",
    "                                                pe_init=init)\n",
    "                                    model = model.to(device=torch.device('mps'))\n",
    "                                    model.load_state_dict(torch.load(resultdir + modelname + checkpoint +'.pt',map_location=torch.device('mps') ))\n",
    "                                except:\n",
    "                                    continue\n",
    "\n",
    "                                with torch.no_grad():\n",
    "                                    for i, batch in enumerate(dataloader):\n",
    "\n",
    "                                        # get features\n",
    "                                        test_features, test_labels, index = batch[0], batch[1], batch[2]\n",
    "\n",
    "                                        # flatten to accommodate transformer\n",
    "                                        test_features = torch.flatten(test_features,start_dim=1,end_dim=2)\n",
    "                                        test_features = test_features.to(device)\n",
    "                                        test_labels = test_labels.to(device)\n",
    "                                        #model_history = tl.log_forward_pass(model, test_features, vis_opt='none')\n",
    "                                        #model_history = tl.log_forward_pass(model, test_features, vis_opt='rolled', vis_outpath='transformer.svg')\n",
    "\n",
    "                                        # add noise\n",
    "                                        test_features = test_features + torch.empty(test_features.size(),device='mps').normal_(mean=0,std=noise_sd)\n",
    "\n",
    "                                        # calculate norm of learned PEs\n",
    "                                        norm = []\n",
    "                                        for block in model.blocks:\n",
    "                                            norm.append(torch.norm(block.pe.positional_encoding).cpu().item())\n",
    "\n",
    "\n",
    "                                        # Compute prediction and loss\n",
    "                                        out = model(test_features)\n",
    "                                        accuracy = torch.argmax(out, dim=1) == torch.argmax(\n",
    "                                                        test_labels, dim=1)\n",
    "                                        accuracy = accuracy.cpu().numpy() * 1.0\n",
    "                                        ann_accuracy['Accuracy'].extend(accuracy)\n",
    "                                        ann_accuracy['Noise'].extend(np.repeat(noise_sd,len(accuracy)))\n",
    "                                        ann_accuracy['Puzzle'].extend(np.arange(len(accuracy)))\n",
    "                                        ann_accuracy['Seed'].extend(np.repeat(seed,len(accuracy)))\n",
    "                                        ann_accuracy['Epoch'].extend(np.repeat(epoch,len(accuracy)))\n",
    "                                        ann_accuracy['Layers'].extend(np.repeat(layer,len(accuracy)))\n",
    "                                        ann_accuracy['Heads'].extend(np.repeat(attnhead,len(accuracy)))\n",
    "                                        ann_accuracy['Dropout'].extend(np.repeat(dropout,len(accuracy)))\n",
    "                                        ann_accuracy['Decay'].extend(np.repeat(wdecay,len(accuracy)))\n",
    "                                        ann_accuracy['PE'].extend(np.repeat(pestr,len(accuracy)))\n",
    "                                        ann_accuracy['Norm'].extend(np.repeat(np.mean(norm),len(accuracy)))\n",
    "                                    # ann_accuracy[:, s] = accuracy.copy()\n",
    "ann_accuracy = pd.DataFrame(ann_accuracy)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Plotting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 110x110 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 110x110 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 110x110 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 110x110 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "epochs = np.arange(0, last_epoch+1, checkpoint_freq)\n",
    "a = human_df.groupby(by='LST_id')['accuracy'].mean().values[0:108]\n",
    "attnhead = 1\n",
    "layer = 4\n",
    "df_corr_learn = {}\n",
    "df_corr_learn['PE'] = []\n",
    "df_corr_learn['Correlation'] = []\n",
    "df_corr_learn['Cosine'] = []\n",
    "df_corr_learn['P-value'] = []\n",
    "\n",
    "\n",
    "for wdecay in [0.0]: #ann_accuracy.Decay.unique():\n",
    "  for pe in initializations:\n",
    "    pestr = 'learn-' + str(pe)\n",
    "    human_sim = np.zeros((len(nblocks)*len(attnheads),len(epochs),3))\n",
    "    epoch_count = 0\n",
    "    for epoch in [4000]: #epochs:\n",
    "      # print('Epoch', epoch)\n",
    "\n",
    "      tmpdf = ann_accuracy.loc[(ann_accuracy.Layers==layer) & \\\n",
    "                                (ann_accuracy.Heads==attnhead) & \\\n",
    "                                (ann_accuracy.Epoch==epoch) & \\\n",
    "                                (ann_accuracy.Decay==wdecay) & \\\n",
    "                                (ann_accuracy.PE==pestr)].reset_index()\n",
    "      b = tmpdf.groupby('Puzzle').mean(numeric_only=True).Accuracy.values\n",
    "\n",
    "      r1, p1 = stats.spearmanr(a,b)\n",
    "      r2, p2 = stats.pearsonr(a,b)\n",
    "      r3 = torch.nn.functional.cosine_similarity(torch.Tensor(a),torch.Tensor(b),dim=0).item()\n",
    "      # Create the scatterplot\n",
    "      df_corr_learn['PE'].append(pe)\n",
    "      df_corr_learn['Cosine'].append(r3)\n",
    "      df_corr_learn['Correlation'].append(r1)\n",
    "      df_corr_learn['P-value'].append(p1)\n",
    "\n",
    "\n",
    "      if pe in [0.1,0.2,1.0,1.8]:\n",
    "        fig, ax = plt.subplots(figsize=(1.1,1.1))\n",
    "        sns.regplot(x=a, y=b, ax=ax,scatter=True, scatter_kws={'alpha':0.5, 's':2},color='k')\n",
    "\n",
    "        # Calculate and annotate the correlation value\n",
    "        corr = r1\n",
    "        if p1*len(initializations)<0.005:\n",
    "          pval_str = 'p < 0.01'\n",
    "        else:\n",
    "          pval_str = f'p = {p1*len(initializations):.2f}'\n",
    "        ax.annotate(f'r = {corr:.2f}\\n{pval_str}\\ncos = {r3:.2f}', xy=(0.5, 0.07), xycoords='axes fraction',\n",
    "                  fontsize=5, bbox=dict(boxstyle=None, fc='white', pad=0))\n",
    "        # Set the axis labels and title\n",
    "        plt.xticks(fontsize=6)\n",
    "        plt.yticks(fontsize=6)\n",
    "        ax.set_title(f\"PE init {pe}\", fontsize=7, fontname='Arial')\n",
    "        sns.despine()\n",
    "        plt.tight_layout()\n",
    "        plt.savefig(f\"{outputdir}/scatter_learnablePE_{pe}.pdf\",transparent=True)\n",
    "\n",
    "      epoch_count += 1\n",
    "  \n",
    "df_corr_learn = pd.DataFrame(df_corr_learn)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAALgAAAClCAYAAADvezeCAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAe/klEQVR4nO2deXyM1/7H3zPZVBISsfVaUlpEFUEFsUZUikSQ1FZRWnuJXtWI7ZYQXFGK9Cq9r25oVS1RS29trTWhpLaGKhJZmqWEJJNtJjPn90dkfiITZkgiJuf9euX1mjnP95zneyaf58yZ83yf81UIIQQSiZmifNoOSCTliRS4xKyRApeYNVLgErNGClxi1kiBS8waKXCJWSMFLjFrpMAlZk2VFrhKpWLRokX4+Pjg6+vLiBEjOHv27GO1tXr1ag4dOlTGHhaSmprK+PHjjbY/dOgQq1evBqB3794kJiYaXffbb7/l22+/BWD27NkkJSWZ5mwpXLx4kblz5wKwdetW9uzZA0BwcDA7duwok3MYRFRRtFqtGDZsmFi1apXQaDRCCCHOnz8vOnXqJP7666+n7F3Z4eHhIRISEiq87sOYNWuW2L59e4nX5YFl+V06lZuoqChSUlIIDAxEqSz8ImvTpg1hYWH69xs2bCAiIgILCwu6du3KBx98gEajISgoiPj4eNRqNaNHj2b48OEEBwfj5uaGm5sbU6ZMoVWrVvz+++/Y2NiwcuVKGjVqRExMDEuWLCE7Oxt7e3s+/PBDXnzxxWJ+HTp0iPDwcDQaDXXr1iUsLIzc3FxGjx7N4cOHCQ4Oplq1aly5coXU1FTmzJnDDz/8QExMDL1792bu3Lns2LGD06dPs2zZMn27KpWKOXPmkJqayt9//03nzp0JDQ3l9OnTLF++HCEEL7zwAk2aNAHA0tKStLQ0JkyYwNSpU/n888/Ztm0bAP/73/84dOgQYWFh+vZ9fHxYsWIFLVq0YPbs2RQUFBAWFsb169cJDg5m5syZhIeHM2HCBA4fPkxUVBROTk4AHDlyhG+++Ybbt2/zxhtvMGXKlDL7P1fZKcrly5dxcXHRi7mI7t27U69ePY4ePcr+/fvZvn07O3fu5ObNm2zZsoUTJ06g0+mIiIjgiy++IDo6ukTbV69eZeTIkfzwww+0bduWzZs3o9FomDNnDv/+97/ZuXMn06dPJygoqETd8PBwli5dyp49e+jSpQsxMTElbFJTU9myZQvTpk1j9uzZLFiwgF27drF9+3YyMzMN9veXX37BxcWF7777jv3793P27Fl+//13AGJjY/niiy9YuXKl3n7y5MnUrVuXDRs20K9fPzIyMrhx4wYAERERDBkypFj7vXr1IjIyEoBLly5x7tw5AI4dO4aHh0exz7d3794EBgbSs2dPAPLy8ti6dSvbtm1j/fr1qFQqg314HKqswJVKJTY2NqUej4yMxNvbm+eeew5LS0v8/PyIjIzklVde4ffff2fcuHH89NNPBkXq5ORE69atAWjZsiUZGRnExsYSFxfHlClT8PX1JSQkhLS0NNRqdbG6ffr0YdKkSSxatIiXX36Z7t27l2i/V69eADRo0IBmzZrh5OSEnZ0dDg4OpQrc29ubzp078+WXX7Jw4ULS09PJyckBoGnTptSsWbPUz0KhUDB48GB27drFrVu3uHHjBp07dy5m07NnT6KiooiLi6NBgwY4OTlx8+ZNjh07Ru/evUttG8DT0xOlUomTkxO1atUiIyPjofamUGWnKK1bt2bTpk0IIVAoFPryNWvW8Morr6DT6YqVAxQUFFCvXj1+/PFHTpw4wbFjxxg8eDB79+4tZnf/haNQKBBCoNPpaNSoEbt27QJACEFqairW1tbF6r777rv069ePI0eOEBYWxoULF/Dx8SlmY2VlpX9taWncv/Crr75i//79DB8+HHd3d/7880/EvUjp55577pH1hwwZQkBAALVq1cLHx6fEZ9OuXTuuXr3K8ePH6dSpE3fv3uXIkSMkJibi4uLCqVOnSm37/j4UfV5lRZUdwTt06ECdOnX4+OOPKSgoAOD06dNs2bKF5s2b07lzZ3bv3k1ubi4FBQVs376djh07snv3bj788EM8PT2ZN28e1atXJzk5+ZHna9q0KRkZGfp/9O7du5k0aVIJO29vb4QQjB07ljFjxhicojwOkZGRDBs2DB8fH9RqNVeuXEGn0z20joWFBVqtFoD69evTuHFjvvzySwYNGmTQtl27dnz99dd06tSJzp0789lnn9GlS5eHtlveVNkRXKFQsG7dOpYtW4aPjw+WlpbUqFGDdevW0bBhQxo2bMjly5fx9/enoKAAd3d3AgICEEJw6NAhBgwYgJWVFV5eXrRo0eKR57O2tmb16tUsWbKEvLw8qlevzooVK0rY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",
      "text/plain": [
       "<Figure size 200x175 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x175 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x175 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot\n",
    "plt.figure(figsize=(2,1.75))\n",
    "ax = sns.barplot(data=df_corr_learn,x='PE',hue='PE',y='Cosine',palette='Blues_r',legend=False);\n",
    "plt.xticks(np.arange(0,len(initializations),2), initializations[::2], fontsize=7,rotation=90);\n",
    "plt.yticks(fontsize=7);\n",
    "plt.ylabel('Cosine',fontsize=8);\n",
    "plt.title('Cosine similarity with\\nhuman performance',fontsize=8);\n",
    "plt.ylim([0.9,1])\n",
    "plt.xlabel('PE init.',fontsize=8)\n",
    "plt.tight_layout()\n",
    "sns.despine()\n",
    "plt.savefig(f\"{outputdir}/learnablePE_cosine.pdf\",transparent=True)\n",
    "\n",
    "# Plot\n",
    "plt.figure(figsize=(2,1.75))\n",
    "ax = sns.barplot(data=df_corr_learn,x='PE',hue='PE',y='Correlation',palette='Reds_r',legend=False);\n",
    "plt.xticks(np.arange(0,len(initializations),2), initializations[::2], fontsize=7,rotation=90);\n",
    "plt.yticks(fontsize=7);\n",
    "plt.ylabel('Rank correlation',fontsize=8,labelpad=1);\n",
    "plt.xlabel('PE init.',fontsize=8,labelpad=1)\n",
    "plt.title('Rank correlation with\\nhuman performance',fontsize=8);\n",
    "# plt.ylim([0.9,1])\n",
    "plt.tight_layout()\n",
    "sns.despine()\n",
    "plt.savefig(f\"{outputdir}/learnablePE_corr.pdf\",transparent=True)\n",
    "\n",
    "df_corr_learn['Cosine+Corr/2'] = (df_corr_learn.Correlation.values + df_corr_learn.Cosine.values)/2\n",
    "plt.figure(figsize=(2,1.75))\n",
    "ax = sns.barplot(data=df_corr_learn,x='PE',hue='PE',y='Cosine+Corr/2',palette='rocket',legend=False);\n",
    "plt.xticks(np.arange(0,len(initializations),2), initializations[::2], fontsize=7,rotation=90);\n",
    "plt.yticks(fontsize=7);\n",
    "plt.ylabel('Cos+Corr avg',fontsize=8,labelpad=1);\n",
    "plt.xlabel('PE init.',fontsize=8,labelpad=1)\n",
    "plt.title('\\nComposite score',fontsize=8);\n",
    "plt.ylim([0.4,.8])\n",
    "# plt.ylim([0.9,1])\n",
    "sns.despine()\n",
    "plt.tight_layout()\n",
    "plt.savefig(f\"{outputdir}/learnablePE_composite.pdf\",transparent=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Evaluate performance on common PE models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "inference for epoch 4000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/tito/mambaforge/envs/lstnn/lib/python3.9/site-packages/torch/utils/checkpoint.py:542: UserWarning: torch.utils.checkpoint.checkpoint_sequential: please pass in use_reentrant=True or use_reentrant=False explicitly. The default value of use_reentrant will be updated to be False in the future. To maintain current behavior, pass use_reentrant=True. It is recommended that you use use_reentrant=False. Refer to docs for more details on the differences between the two variants.\n",
      "  warnings.warn(\n",
      "/Users/tito/mambaforge/envs/lstnn/lib/python3.9/site-packages/torch/utils/checkpoint.py:90: UserWarning: None of the inputs have requires_grad=True. Gradients will be None\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "inference for epoch 4000\n",
      "inference for epoch 4000\n",
      "inference for epoch 4000\n",
      "inference for epoch 4000\n",
      "inference for epoch 4000\n"
     ]
    }
   ],
   "source": [
    "\n",
    "# load the 108 fMRI trials\n",
    "validation_file = '../data/nn/puzzle_data_original.csv'\n",
    "dataloader = torch.utils.data.DataLoader(\n",
    "    get_dataset(validation_file), batch_size=108, shuffle=False)\n",
    "\n",
    "\n",
    "positional_encodings = {\n",
    "      'pe-1dpe_':'absolute',\n",
    "      'pe-2dpe_':'absolute2d',\n",
    "      'pe-shaw_':'relative',\n",
    "      'pe-rope2_':'rope2',\n",
    "      'pe-learn-0.2_':'learn',\n",
    "      'pe-rndpe_':'rndpe',\n",
    "      'pe-cnope_':'cnope',\n",
    "      'pe-nope_':'nope'\n",
    "}\n",
    "pe_labels = {\n",
    "      'pe-1dpe_':'1d-fixed',\n",
    "      'pe-2dpe_':'2d-fixed',\n",
    "      'pe-shaw_':'relative',\n",
    "      'pe-rope2_':'rope',\n",
    "      'pe-learn-0.2_':'learn-0.2',\n",
    "      'pe-rndpe_':'random',\n",
    "      'pe-cnope_':'c-nope',\n",
    "      'pe-nope_':'nope'\n",
    "}\n",
    "\n",
    "# ann_accuracy = np.zeros((108, len(seeds), nblocks, attnheads)) # may want to add epochs\n",
    "ann_accuracy2 = {}\n",
    "ann_accuracy2['Accuracy'] = []\n",
    "ann_accuracy2['Noise'] = []\n",
    "ann_accuracy2['Epoch'] = []\n",
    "ann_accuracy2['Seed'] = []\n",
    "ann_accuracy2['Layers'] = []\n",
    "ann_accuracy2['Heads'] = []\n",
    "ann_accuracy2['Dropout'] = []\n",
    "ann_accuracy2['Decay'] = []\n",
    "ann_accuracy2['Puzzle'] = []\n",
    "ann_accuracy2['PE'] = []\n",
    "ann_accuracy2['Model'] = []\n",
    "dropout = 0.0\n",
    "# for epoch in np.arange(0, last_epoch+1, checkpoint_freq):\n",
    "for noise_sd in [0.0, 0.02, 0.04, 0.06, 0.08, 0.1]: #[0.0, 0.05, 0.1, 0.15, 0.2, 0.25, 0.3, 0.35, 0.4]:\n",
    "# for noise_sd in [0.1, 0.2, 0.3]: # 0.06, 0.08, 0.1]: #[0.0, 0.05, 0.1, 0.15, 0.2, 0.25, 0.3, 0.35, 0.4]:\n",
    "    for epoch in [4000]:\n",
    "        print('inference for epoch', epoch)\n",
    "        for pe in positional_encodings:\n",
    "            petype = positional_encodings[pe]\n",
    "            pestr = pe_labels[pe]\n",
    "            if pe_labels[pe] == 'learn-0.2':\n",
    "                pe_init = 0.2\n",
    "            else:\n",
    "                pe_init = 1.0\n",
    "            for wdecay in wdecays:\n",
    "                for layer in nblocks:\n",
    "                    for attnhead in [1]: #attnheads:\n",
    "                            resultdir = f\"../results/\"\n",
    "                            modelname = f\"model-{model_label}_\" \\\n",
    "                                        f\"{pe}\" \\\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",
    "                            model_str = pestr + '-' + str(attnhead) + 'H'\n",
    "                            # _df = df_good_models.loc[(df_good_models.epoch==4000) & (df_good_models.pe==pestr) & (df_good_models.heads==attnhead)]\n",
    "                            # if len(_df)<1: continue\n",
    "                            for seed in seeds:\n",
    "                                try: \n",
    "                                    checkpoint = f\"s-{seed}_\" \\\n",
    "                                                f\"e-{epoch}\" \n",
    "                                    torch.manual_seed(seed)\n",
    "                                    model = transformer_main.Transformer(\n",
    "                                                nblocks=layer,\n",
    "                                                nhead=attnhead,\n",
    "                                                dropout=dropout,\n",
    "                                                embedding_dim=hidden_size,\n",
    "                                                positional_encoding=petype,\n",
    "                                                pe_init=pe_init)\n",
    "                                    model = model.to(device=torch.device('mps'))\n",
    "                                    model.load_state_dict(torch.load(resultdir + modelname + checkpoint +'.pt',map_location=torch.device('mps') ))\n",
    "                                except:\n",
    "                                    continue\n",
    "\n",
    "                                with torch.no_grad():\n",
    "                                    for i, batch in enumerate(dataloader):\n",
    "\n",
    "                                        # get features\n",
    "                                        test_features, test_labels, index = batch[0], batch[1], batch[2]\n",
    "\n",
    "                                        # flatten to accommodate transformer\n",
    "                                        test_features = torch.flatten(test_features,start_dim=1,end_dim=2)\n",
    "                                        test_features = test_features.to(device)\n",
    "                                        test_labels = test_labels.to(device)\n",
    "                                        #model_history = tl.log_forward_pass(model, test_features, vis_opt='none')\n",
    "                                        #model_history = tl.log_forward_pass(model, test_features, vis_opt='rolled', vis_outpath='transformer.svg')\n",
    "\n",
    "                                        # add noise\n",
    "                                        test_features = test_features + torch.empty(test_features.size(),device='mps').normal_(mean=0,std=noise_sd)\n",
    "\n",
    "                                        # Compute prediction and loss\n",
    "                                        out = model(test_features)\n",
    "                                        accuracy = torch.argmax(out, dim=1) == torch.argmax(\n",
    "                                                        test_labels, dim=1)\n",
    "                                        accuracy = accuracy.cpu().numpy() * 1.0\n",
    "                                        ann_accuracy2['Accuracy'].extend(accuracy)\n",
    "                                        ann_accuracy2['Model'].extend(np.repeat(model_str,len(accuracy)))\n",
    "                                        ann_accuracy2['Noise'].extend(np.repeat(noise_sd,len(accuracy)))\n",
    "                                        ann_accuracy2['Puzzle'].extend(np.arange(len(accuracy)))\n",
    "                                        ann_accuracy2['Seed'].extend(np.repeat(seed,len(accuracy)))\n",
    "                                        ann_accuracy2['Epoch'].extend(np.repeat(epoch,len(accuracy)))\n",
    "                                        ann_accuracy2['Layers'].extend(np.repeat(layer,len(accuracy)))\n",
    "                                        ann_accuracy2['Heads'].extend(np.repeat(attnhead,len(accuracy)))\n",
    "                                        ann_accuracy2['Dropout'].extend(np.repeat(dropout,len(accuracy)))\n",
    "                                        ann_accuracy2['Decay'].extend(np.repeat(wdecay,len(accuracy)))\n",
    "                                        ann_accuracy2['PE'].extend(np.repeat(pestr,len(accuracy)))\n",
    "                                    # ann_accuracy[:, s] = accuracy.copy()\n",
    "ann_accuracy2 = pd.DataFrame(ann_accuracy2)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Compare common PEs to human data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 197,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 110x110 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 110x110 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 110x110 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 110x110 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "epochs = np.arange(0, last_epoch+1, checkpoint_freq)\n",
    "a = human_df.groupby(by='LST_id')['accuracy'].mean().values[0:108]\n",
    "attnhead = 1\n",
    "layer = 4\n",
    "df_corr_common = {}\n",
    "df_corr_common['PE'] = []\n",
    "df_corr_common['Correlation'] = []\n",
    "df_corr_common['Cosine'] = []\n",
    "df_corr_common['P-value'] = []\n",
    "\n",
    "\n",
    "for wdecay in [0.0]: #ann_accuracy.Decay.unique():\n",
    "  for pe in ann_accuracy2.PE.unique():\n",
    "    human_sim = np.zeros((len(nblocks)*len(attnheads),len(epochs),3))\n",
    "    epoch_count = 0\n",
    "    for epoch in [4000]: #epochs:\n",
    "      # print('Epoch', epoch)\n",
    "\n",
    "      tmpdf = ann_accuracy2.loc[(ann_accuracy2.Layers==layer) & \\\n",
    "                                (ann_accuracy2.Heads==attnhead) & \\\n",
    "                                (ann_accuracy2.Epoch==epoch) & \\\n",
    "                                (ann_accuracy2.Decay==wdecay) & \\\n",
    "                                (ann_accuracy2.PE==pe)].reset_index()\n",
    "      b = tmpdf.groupby('Puzzle').mean(numeric_only=True).Accuracy.values\n",
    "\n",
    "      r1, p1 = stats.spearmanr(a,b)\n",
    "      r2, p2 = stats.pearsonr(a,b)\n",
    "      r3 = torch.nn.functional.cosine_similarity(torch.Tensor(a),torch.Tensor(b),dim=0).item()\n",
    "      # Create the scatterplot\n",
    "      df_corr_common['PE'].append(pe)\n",
    "      df_corr_common['Cosine'].append(r3)\n",
    "      df_corr_common['Correlation'].append(r1)\n",
    "      df_corr_common['P-value'].append(p1)\n",
    "\n",
    "\n",
    "      if pe in ['2d-fixed','1d-fixed','relative','rope']:\n",
    "        fig, ax = plt.subplots(figsize=(1.1,1.1))\n",
    "        sns.regplot(x=a, y=b, ax=ax,scatter=True, scatter_kws={'alpha':0.5, 's':2},color='k')\n",
    "\n",
    "        # Calculate and annotate the correlation value\n",
    "        corr = r1\n",
    "        if p1*len(initializations)<0.005:\n",
    "          pval_str = 'p < 0.01'\n",
    "        else:\n",
    "          pval_str = f'p = {p1*len(initializations):.2f}'\n",
    "        ax.annotate(f'r = {corr:.2f}\\n{pval_str}\\ncos = {r3:.2f}', xy=(0.5, 0.07), xycoords='axes fraction',\n",
    "                  fontsize=5, bbox=dict(boxstyle=None, fc='white', pad=0))\n",
    "        # Set the axis labels and title\n",
    "        # ax.set_xlabel('Human acc',fontsize=7,labelpad=1)\n",
    "        # ax.set_ylabel('Model acc',fontsize=7,labelpad=1)\n",
    "        plt.xticks(fontsize=6)\n",
    "        plt.yticks(fontsize=6)\n",
    "        ax.set_title(f\"{pe}\", fontsize=7, fontname='Arial')\n",
    "        sns.despine()\n",
    "        plt.tight_layout()\n",
    "        plt.savefig(f\"{outputdir}/scatter_commonPE_{pe}.pdf\",transparent=True)\n",
    "\n",
    "      epoch_count += 1\n",
    "  \n",
    "df_corr_common = pd.DataFrame(df_corr_common)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 163,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAL4AAAClCAYAAADiZUfFAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAjm0lEQVR4nO2de1yM6fvHPzPVJJVKaH+K0i7FOsVKxErJsagI2XLYjUi1NpbKOiyFLVusvuuwi0WLry1lLbsitrAltNahiFKEitJhOsxMM/fvD99mmw6aZ5ohM/f79ZrXq3nmua7neqbP3M99uO77ZhFCCCgUFYP9tgOgUN4GVPgUlYQKn6KSUOFTVBIqfIpKQoVPUUmo8CkqCRU+RSWhwqeoJCopfC6Xi40bN8LZ2RnTpk2Dh4cHrl+/LpOv7du3IykpSc4RvqKoqAgLFy6U+vykpCRs374dAGBvb4+CggKpbY8cOYIjR44AAIKDg/HkyRNmwbbArVu3sHr1agDAsWPH8NtvvwEAgoKCcPz4cblcQyaIiiEUCsmsWbNIVFQUEQgEhBBC/vnnHzJ8+HDy9OnTtxyd/Bg7dix5/PjxG7d9HatWrSJxcXFN/n4bqL+9n9zbIS0tDYWFhQgICACb/eqBN3DgQERERIjf79mzBwkJCVBTU4OtrS2+/PJLCAQCrFy5Eo8ePQKfz8fcuXMxe/ZsBAUFwdraGtbW1vD19cWHH36IO3fuQFNTE5GRkejRowcyMzOxadMmVFVVQVdXF+vWrcP7778vEVdSUhKio6MhEAjQrVs3REREoKamBnPnzsX58+cRFBSEDh064O7duygqKkJISAh+/fVXZGZmwt7eHqtXr8bx48eRnp6OLVu2iP1yuVyEhISgqKgIz58/h42NDcLCwpCeno7w8HAQQmBmZoZevXoBANTV1VFcXIxFixbBz88P+/btQ2xsLADgjz/+QFJSEiIiIsT+nZ2dsXXrVlhYWCA4OBh1dXWIiIhATk4OgoKCsGLFCkRHR2PRokU4f/480tLSYGhoCABITk7G4cOHUVJSAnd3d/j6+iruH98IlavqZGVlwdLSUizyekaPHg0jIyOkpKQgMTERcXFxiI+PR35+Po4ePYrLly9DJBIhISEB+/fvR0ZGRhPf2dnZmDNnDn799VcMGjQIP//8MwQCAUJCQvDNN98gPj4en3/+OVauXNnENjo6Gps3b8Zvv/2GESNGIDMzs8k5RUVFOHr0KPz9/REcHIz169fjxIkTiIuLQ0VFRbP3++eff8LS0hL//e9/kZiYiOvXr+POnTsAgIcPH2L//v2IjIwUn79kyRJ069YNe/bswaRJk1BeXo7c3FwAQEJCAtzc3CT829nZITU1FQBw+/Zt3LhxAwBw8eJFjB07VuL7tbe3R0BAAMaMGQMAqK2txbFjxxAbG4vdu3eDy+U2ew+KQOWEz2azoamp2eLnqampcHJygpaWFtTV1TF9+nSkpqaif//+uHPnDry9vXHmzJlmxWtoaIgBAwYAAPr27Yvy8nI8fPgQeXl58PX1xbRp07BhwwYUFxeDz+dL2I4bNw6LFy/Gxo0b0a9fP4wePbqJfzs7OwCAsbExevfuDUNDQ+jo6EBfX79F4Ts5OcHGxgY//fQTvv76a5SWlqK6uhoAYG5uDj09vRa/CxaLBVdXV5w4cQIvXrxAbm4ubGxsJM4ZM2YM0tLSkJeXB2NjYxgaGiI/Px8XL16Evb19i74BwMHBAWw2G4aGhujcuTPKy8tfe748UbmqzoABAxATEwNCCFgslvj4d999h/79+0MkEkkcB4C6ujoYGRnh999/x+XLl3Hx4kW4urri1KlTEuc1/EGxWCwQQiASidCjRw+cOHECAEAIQVFRETgcjoTt0qVLMWnSJCQnJyMiIgI3b96Es7OzxDkaGhriv9XVpfvXHThwAImJiZg9ezZGjhyJ+/fvg/wvE11LS6tVezc3N3h5eaFz585wdnZu8t1YWVkhOzsbly5dwvDhw1FWVobk5GQUFBTA0tISV65cadF3w3uo/77eFCpX4g8dOhRdu3bFtm3bUFdXBwBIT0/H0aNH0adPH9jY2ODkyZOoqalBXV0d4uLiMGzYMJw8eRLr1q2Dg4MDvvrqK3Ts2BHPnj1r9Xrm5uYoLy8XC+DkyZNYvHhxk/OcnJxACMGCBQswf/78Zqs6spCamopZs2bB2dkZfD4fd+/ehUgkeq2NmpoahEIhAOC9995Dz5498dNPP8HFxaXZc62srHDw4EEMHz4cNjY2+OGHHzBixIjX+n3bqFyJz2KxsHPnTmzZsgXOzs5QV1dHp06dsHPnTpiYmMDExARZWVmYMWMG6urqMHLkSHh5eYEQgqSkJEyZMgUaGhqYMGECLCwsWr0eh8PB9u3bsWnTJtTW1qJjx47YunVrk/OWL1+OZcuWQUNDAx06dMD69evlcr/z5s3DmjVrsGvXLujp6WHIkCF4/PgxTE1NW7RxcHDAokWLsGfPHpiamsLJyQnx8fHo0aNHs+fb2dnh4sWLsLS0hEAgQFlZmUT9vp5Ro0YhIiIC2tracrm3tsAib/L5QnnnEIlEWL16NUaMGIGpU6e+7XDkhspVdSjSIxKJYGtri+rqakyePPlthyNXaIlPUUloiU9RSVRa+FeuXIGXl9fbDkPuxMbGYvTo0QgLC3vbobRbVK5XRxU4deoUNm3a1OwgGOUVKi/8ly9fwsfHB48fP4ahoSF27NgBfX19WFhY4N69ewAgkQNjb2+PyZMn46+//oJQKERgYCD27duHhw8fYuXKlXByckJ2djY2btyImpoalJaWwtvbG3PmzMGOHTtQVFSER48e4cmTJ/j444+xbt06iXgKCgrg4+Mjvv57772HrVu3wsDAoMWcHy8vL3Tq1Ak5OTlwcnLCjRs3sGHDBgQFBaFr164IDQ1FbW0tDAwMsGHDBpiamkrYbNmyBYsXL8akSZNw7do1GBgYwMPDA4cOHcKzZ8+wefNm2NjYID09HVFRUeDxeKisrMTKlSvh6OiIoKAg6OrqIjMzE8+ePcPMmTOxePFi8Pl8hIWFIS0tDRoaGvD29oaLi4tUuUsK5+3kxrUP0tLSyODBg0leXh4hhJClS5eSmJgYQgghffr0EZ8XFxdHVq1aRQh5lbm4b98+QsirDEMPDw8iEAhIamoqmTZtGiGEkNDQUHLp0iVCCCEFBQVk8ODBhBBCvvvuO+Lm5kZ4PB7hcrlk1KhR5O7duxIxPX78mPTp04ekpaURQgjZvHkz+frrrwmfzyfTpk0jBQUFhBBCrl27Rtzc3AghhHh6epLIyEixD09PT5KWlkb4fD4ZO3Ys+fvvvwkhhJw+fbpFmz59+pAzZ86IPwsMDCSEEBIbG0t8fX0JIYT4+/uTBw8eEEIIuXLlCnFychJ/D0uWLCFCoZAUFRWRQYMGkfLycrJ//37y+eefE6FQSEpLS8nkyZNJRUVFi/fxJlH5Et/CwkI8mNOnTx+8fPmyVZuGOTNGRkZQV1eHiYmJOF9m1apVSE5Oxu7du3H37l1xbgwAjBgxAhwOBxwOB6amps3mp5iZmWH48OEAABcXF6xYsUIi56ee0tJScc7PkCFDmvjJy8uDrq4uBg8eDACYNGkS1q5di8rKymZtGt7X0KFDAUDivsLDw3H+/Hn8/vvv+Oeff1BVVSW2HT16NNhsNrp16wYDAwNUVlYiLS0N7u7uYLPZMDAwwKlTp5Cdnd3ifTRO41AkKi/8hvkvjfNFyP/yeepTG5qzaS5n5vPPP4e+vj7Gjh2LyZMn4/Tp0+LPmsvnaUxDn4QQsNnsVnN+OnTo0MSPUChskltDCBHfT2ObhsJTU1Nr4s/DwwMjR46EtbU1Ro4ciRUrVrz2vtTU1CSun5eXJ3XukqJR6V6d16Gvr4979+5BJBIxnmGVmpqKgIAAjBs3DpcuXQIARjkqDx8+RFZWFgAgLi4Otra2Uuf8NMTc3BxlZWXiVOHTp0/jvffeg4GBAaP7AYCysjI8evQI/v7++Pjjj3HhwoVW78na2hqnT58GIQQvX77EvHnz0KVLF8b3oQhUvsRviRUrVsDX1xddunTB0KFDpaoC1ePv74/p06dDV1cXlpaWMDExwePHj6W219PTQ3R0NPLy8vDBBx8gLCxM6pyfhnA4HERFRSEsLAw1NTXQ1dVFVFSU1HE0RF9fHzNmzICjoyO0tbUxfPhw1NbWSlR3GuPh4YHc3FxxqkNQUBC6dOnC+D4UAR25bWcUFBSIZ11RFAet6lBUElriU1QSWuJTVBKFCv/cuXMIDg5ucjwqKgru7u7w8vLCo0ePFBkChdIsChP+1q1bsXXr1ib91Ldv30ZWVhZ++eUXrFixQmKpCgrlTaEw4Q8YMKDZ6XMZGRkYOXIkAGDQoEFym1tKoTBBYcKfMGFCk1FD4NUCR7q6uuL3rbWt+Xw+uFyu+FVZWYnS0tI3OiOfony88QEsHR0diUGPxgs7NWb37t2Ijo5ucvz69evQ0dGRe3wU1eCN9+oMHjwYf/31FwDgxo0b+OCDD157vo+PD65fvy5+JScnv4kwKUrOGyvxt2zZAldXVwwcOBAWFhaYOXMmWCwWNm/e/Fq7+kxGRSAUiaDWyhNHnnaU9sM7N4DF5XIxdOhQuVV1gvb9iYeFZVKf3+s9fWz51E78XiQiYLObtmVaQ1a7Fv0RAnYzbSomdqTR6nLSIItNe0Dlk9QeFpYh63GJzPZsNgvhCdfwqKRSapuehrpY6fKRzNdsNg4WC6dv5qOUy5PaprOOJiYP/HdhKRaLhb/zilFZK5DKXreDBqzMujGOtT2g8sKXB49KKpFTKPuCp/J6apRyeSiurJE5DgCorBWgoobf+onvOO+s8IWtrP/4Orv2Vj9ns1nYl5yFZ+XVrZ/8P/5PryM+HdNXgVEpN++s8NXYbPh9m4D7DKopvXsYInq5i+KCagPPyqvxuOTNrQ+v6ryzwgeA+49LcDu38G2HQXkHaV/PfArlDUGFT1FJqPApKgkVPkUlocKnqCRU+BSVhAqfopJQ4VNUEip8ikpChU9RSWQSfuPVgymUdw1Gws/NzcWMGTMwbtw4FBUVwc3NDbm5uYqKjUJRGIyEv2HDBoSEhEBfXx9GRkaYP38+QkJCFBUbhaIwGAm/oqJCYheNqVOnoqambRMfKJS3ASPha2tr49mzZ+I5lunp6RI7YVAo7wqM8vFDQkLg6+uLvLw8TJ06FRUVFdi2bZuCQqNQFAcj4fft2xe//PILHj58CKFQCHNz8ze+dxGFIg8YCf/JkyeIiYlBeXm5xBJ+ra2NQ6G0NxgJPzAwEAMHDsRHH330Tq6lQlE878raPIyEX1tbi9WrVysqFooSwGKxkP+8EjyBdLs8amqowbSrbusnyhlGwu/Xrx8yMzPRr18/RcVDUQJ4AiFq+NJvb/o2YCT8zMxMTJ8+HYaGhtDU1BQ/opjuA0uhvG0YCf/777+X+lyRSITVq1fj4cOH0NHRQXh4ODp37iz+PDQ0FDdv3oSGhgZCQ0PRq1cvJqFQKG1CqgGsCxcuAACuXr3a7Ks5zp49C01NTRw9ehRubm7Ys2eP+LO7d+/i3r17OHbsGJYuXdrs+vcUiiKRqsS/desWxo4dK96GvTEuLi5NjmVkZGDUqFEAgNGjR0sI39jYGBwOBwKBAFVVVdDW1m7x2nw+H3z+v2s5crl0tTFK25FK+AEBAQAk++u5XC6ePXuG3r17N2vD5XLFy3hra2tL7IJCCAGfz8fEiRPB5XJfW4VqaUcUCqUtMKrjHzt2DBkZGVi5ciVcXFygra2NCRMmYNmyZU3ObbjlT1VVlcS+VwkJCejRowcOHDiAFy9eYP78+YiPj28278fHxwcLFiwQv+dyuRgzZgyTsCmUJjBKUjt48CC++OILnDp1Cg4ODjh58iRSUlKaPXfw4MG4fPkyACAlJQVWVlbizzp16gRdXV2w2Wzo6emhrq6uxcktHA4HOjo6Ei8Kpa0wKvE5HA6MjIyQkpKCOXPmQF1dXaL+3ZDx48cjJSUFs2fPhoaGBqKiosTbATk5OeHq1auYPXs2RCIRfH19X1vPp1DkDSPhm5iYwN/fHzk5ORg5ciSCgoJarOOrqak1yeEJCgoS/x0WFiZDuBSKfGAk/IiICFy+fBlr166FpqYmRo0ahfHjxysqNgpFYTCu6hQWFiIhIQECgQDW1tat7lNLobRHGAk/PDwc+fn5mD59OgghOH78OAoKCrBmzRpFxUehKARGwr98+TISEhLEpbydnR2cnZ0VEhiFokgY1VOEQqFEt2NdXR3U1NTkHhSFomgYlfjTpk2Dp6cnnJycwGKxcPLkSTg5OSkqNgpFYUgt/KKiIkybNg19+/ZFamoq0tLSMH36dHzyySeKjI9CUQhSVXUyMjLg6uqKBw8eYPTo0Vi5ciXs7Oywc+dO3Lp1S9ExUihyRyrhf/vtt9i1axdsbW3FxwICAhAZGYnw8HCFBUehKAqphF9dXY2BAwc2OW5tbY2Kigq5B0WhKBqphF9XVweRSNTkuFAohEAgkHtQFIqikUr4w4cPbzYnPjo6utknAYXS3pGqV2fZsmVYuHAhEhISYGlpCU1NTdy+fRtdu3bFzp07FR0jhSJ3pBK+jo4ODh8+jLS0NGRlZYHNZuOTTz7BRx99pOj4KBSFIHU/PovFwogRIzBixAhFxkOhvJHV2BiN3FIobwIWi4VSLg91wqYdKs2hrsZGZx1my9VT4VPaJXVCEQRC0vqJAADpfiANocn0FJWECp+iklDhU1QSKnyKSkKFT1FJqPApKgkVPkUlocKnqCRU+BSVRGEjt63tiBIbG4vY2Fjw+Xx4eHjA3d1dUaFQKE1QWIn/uh1R8vPzER8fj0OHDuHIkSMoLCxUVBgUSrMoTPiNd0RJS0sTf5aamgpzc3MEBgbC29sbo0ePVlQYFEqzKKyq87odUUpLS5GZmYmYmBiUlJRg4cKFOH36dLNppY23AqqsrBT7Fwl4gLD5ZcqbQyTgNdlKSMivBanjSe1DyK9t4qOOVwMRv1ZqH3U8ThMf/Npq1PFqpPbBr2U38cGrqQa/RnofPHXSxEdNdRVqa6T7TjWIoNmtmaqruKjhS5c4RgRscLlNZVjFrYFAJF2SmgabBa7av9uLamtrt5qirDDhv25HFH19fVhbW0NLSwsmJibQ0dFBSUkJunTp0sRPS1sB1e+KwmSbiEcPgKFDtzO7kUbcAjD0yLo2+cgD0MYwAABH5bBkqTKukXH9+vVWNxBRmPDrd0RxcHBosiPKkCFDEBsbK978raKiAgYGBs36abwVkEgkQnl5OfT19Zv9VddvFZScnCzz7inUx7vtQ5pNRhQm/NftiGJpaYnJkydj1qxZAIDg4OAW1+DkcDjgcDgSxzp16tTq9eWxbRD1obw+FCb81nZE8fb2hre3t6IuT6G8FjqARVFJlE74HA4Hfn5+TapH1Af10RAWIUTaiY0UitKgdCU+hSINVPgUlYQKn6KSUOFTVBIq/HZMWVkZ3vW+h7y8PCQnJ+Pp06dtuhcul4u7d+82mxskC3QlNQD29vZgsViora1FdXU1TExM8OTJE3Tp0gWJiYmMfBUVFSE8PBwvX76Eo6MjLC0tJdI1pCE9PR1hYWHg8/mYNGkSjIyMxKPcrXHz5k1s2rQJHA4Hy5Ytw5AhQwC8WvF627ZtjOLIzc1FUlISeLx/k/j8/Pyktj948CAuXryI58+fY8aMGbh//z6+/vprRjEAwB9//IG9e/eitrYWU6ZMQV1dHaM4moUoAWPHjiX29vZk5MiRZPDgwcTJyYlYWVkRR0dHRn6WLVtGiouLCSGElJaWEn9/f8axLFy4kGRkZBBPT0+Sn59P3N3dGfuYM2cOqaysJJ6enoTH4xFXV1epbWfNmkVyc3PJ/fv3iZubG7lw4QIhhBBPT0/GcUyZMoXs37+fHD9+XPxiwpw5cySuPX36dMYxEEKIh4cHEQgEYj9Mvo+WUIoS//z58wCAL774AiEhIejatStevnyJdeuYZVEWFBSga9euAAADAwM8ffqUcSw8Hg9WVlZgsVjo2bMnNDWZLWZaj46ODlgsFjgcjlRJV/Woq6ujV69eAIAffvgB8+fPR+fOnRmvPgwAxsbGmD9/PmO7eup3zGGxWCCEQENDQyY/IpEI6urq4nvo0KGDzDHVoxTCr6etwrW2tsZnn32G/v37459//sHEiRMZx6Crq4vjx4+Dx+Ph3LlzEunY0jJo0CCsWrUKxcXF2LRpEywsLKS27dKlC7Zv345Fixahc+fO+O677+Dr64vq6mrGcTg6OmL58uXiHxLArKrj5eWFGTNm4MWLF/Dw8JC6utaYiRMnYt68eSgoKICfnx/s7Oxk8tMQpRq5jYiIwN27d8XCHTVqFONEuPv37+PBgwcwNTVFv379GMdQUVGB3bt34/79+zA3NxcLkCnJycliH/b29lLb8fl8xMfHw9nZGR07dgTwqt2xa9cuxk/AGTNmwMnJCXp6euJjrq6ujHyUlZXh8ePHMDExaTH1XBoePHiABw8ewMzMDJaWljL7qUephA+0TbjyaJh+8803cHNzQ+/evRnZNeT58+fYt28fcnJy8P7778PHxwf6+voy+wOAly9fMhaet7c3fvzxR5mvee3aNYSHh6O0tBQGBgZYt24d+vfvz9hPTk4Otm/fLv4+vvzyS/To0UPmuAAoR+O2nsLCQhIYGEgWLFhADh8+TDIyMhjZy6NhevbsWeLn50c8PDzI4cOHSWVlJWMfnp6eJD4+nuTk5JC4uDji7e3N2EdjVqxYwdgmICCALFmyhOzYsUP8YoKrqyt59OgRIYSQvLw8MnPmTMYxEEKIu7s7SU9PJzwej6SmpsrUUG+MUvXjr1mzBp6enhAIBLC1tW0yH6A15NEwHTduHHbs2IEdO3YgLS1NPOGeCWw2Gy4uLjA3N4ebm5tEd6KsREREMLaxs7ODo6MjTExMYGxsDGNjY0b2nTp1EpfMpqamMjdKO3bsiGHDhoHD4cDGxqbFSUtMUKrGbVuFK4+G6e3bt3HixAlcv34dtra2SEhIYOyje/fu+OmnnzBs2DDcuXMHHTp0wNWrVwEAw4YNe60tn8/HsWPHcOXKFVRVVUFHRwdDhgyBh4cH4+/DyckJx44dQ3Z2NszMzPDJJ58wsu/UqRN8fX0xbNgw3L59GzweTzx/mkkj2dDQEKGhobC2tsadO3dACBF/ry4uLoxiqkephN9W4W7atAm7d++Gnp4erl27hrCwMMYx7Nq1CzNmzEBwcDDYbNkfqPfu3cO9e/cAvPrHHz9+HEDrwg8KCkLfvn2xdOlS8eoWKSkp+OKLL/D9998zimHt2rXo1q0bHBwccPXqVQQHB+Pbb7+V2n7s2LEAXu1pJcuTr576XqXs7GxoaGhg2LBhKCgokNkfoGSN28Y9Kj4+PowadCkpKfj444/F7w8cOIB58+ZJZXvp0iWMGjUK8fHxTfrMZSmVsrOzxY30Dz/8UGo7T09PxMTENDnu4eGBI0eOMIrBy8sLhw4dktmHQCBo8sSQdRLJn3/+KfYzfvx4mXw0RKlK/Bs3buDLL78Uv2ciXAA4dOgQ0tLS4OXlhTVr1jCq0z5//hwA8OTJE+kDboGDBw/i7NmzGDRoEGJiYjBmzBj4+PhIZaunp4e9e/fC1tYWurq6qKqqwuXLl5tduqU1+Hw+ysrKoK+vj/Lycsa5Nm19YtQTERGBwsJCfPTRRzhz5gzS09Px1VdfMfYjQZubx+0Ib29v8s0335CnT5+Szz77jKxdu5axj8DAQNKvXz8SExMjUwxbtmyReL9u3TrGPmbNmkWEQiEhhJC6ujpGQ/01NTVk3759xM/Pj8yfP5/4+/uTvXv3kqqqKsZxXLp0iYwfP57MnDmTjB8/nly8eJGRfePel9mzZzOOgZBXKQsNkaW3rTFKVeL/8MMPWL58OcaNG4eQkBDGjbE1a9agvLwcP/74IyIjI1FXVyf1E+OXX37Bzp07UVJSIk5sI4TI1N8sFArF7QM1NTVGvRgdOnTAggULxGsR/fzzz4y/h3psbW1x5swZcT8807SHtj4x6hEIBODz+eBwOBKr6rUFpRJ+W4QLAO+//z42btwI4JVgmHQBuru7w93dHXv27MGiRYsYx96Q8ePHw8vLC1ZWVrhx4wYcHR1l9nXmzBnGwvfy8mpR5AcPHpTaT0BAAGbNmgV9fX2UlZVhzRrZln6bO3cupk+fjj59+iA7OxsLFy6UyU9DlEr4sgq3vmGqp6cn0f3IpFFZz7Bhw7B27VoIBAIAQHFxMfbu3cvIx/nz57FhwwY8ePAAU6ZMYZSr0xhZStktW7YAACIjIzF58mQMGTIEt2/fxpkzZxj5afjEkCVto55OnTqha9euSEpKQo8ePRAbG4upU6fK7A9QEuG3Vbi3bt3CqFGj5NIwDQsLg4+PD3777TcMGDBApkczi8XCzp070atXL+Tk5ODs2bMy5583XJ5dWuob9cXFxXBwcADwasVrpr5iY2Oxb98+iQG4pKQkxvFERERgw4YNMDIyYmzbEkoh/LYK988//8SSJUuQn58v0whnQ/T09ODo6IgLFy7A29tbpvq1PDbJiI6ORkxMDLS1tUEIAYvFYiw6bW1t7N69G/3798fff/8tznyVlgMHDmD//v1tFmz37t3FE2rkhVIIv63C7d69O+zs7PDy5UtkZGQAgMxiUVdXx40bN8Dj8XDp0iW8ePGCcTxMMyCb49y5c0hJSWnT4kuRkZGIj4/H2bNnYWZmxvi7NTExkUspraWlBT8/P4mszLbOwFIK4bdVuFFRUQBejdyGhIS0KZb169cjNzcXvr6+2LZtW9unyMlIz5492+xDKBTCwMAAgwYNAovFwsmTJxkNxgmFQri5uUm0UZjmTwGQS/59Y5Rq5FYewgVe9Q7VN5Kl5XWTXrp3797WkBgze/ZsPHnyBGZmZgBetRuY9MgAr3p3zMzMJEptJj/k9PT0Jsesra0ZxaAolEr49cgi3IY0HqqX1qZ+il1DZBGcPLhz506THH6m2ZVz586VS+xt/X8oAqWo6jQmLy+vTfampqaMbRr+UCorK/HkyRPxbi9vg9DQUMa5OY2xtLTE+fPnYWFhIe7Xl+XplZ+f36Y4FIFSCp+pcBtXU3x9fcXHmP6jFbIUhgywWCwEBgaiV69eYtEyjSMrKwtZWVkSPpk8AfLy8nDz5k307NkTERERmDVrllzaHvJAKao6ba1fe3l5AQBKSkpQXV0NS0tL3L9/HwYGBoiNjWUUy5w5c3Dw4EEsWLAAhw4dgpubmzil+E0SHx8v8Z7FYsmcu15PcXExunXrJvX5s2fPxqpVq2BlZYW///4bkZGRjKuQikIpSvxVq1YBkF249f+MJUuWIDIyElpaWuDz+fD392cciyKWwpAFOzs7XL58GXV1dSCEoLi4mLGPbdu2IS4uTrzzpImJCU6ePMnIR/2cZaZzlxWNUghfXsItKioSz1Jis9niVGMmTJgwQe5LYchCQEAALCwskJWVJdNMMgD466+/cP78eYSGhmLRokVYvXo1I/tu3bohOjoaVlZWuHnzpkyp0YpCKYRfT1uF6+rqChcXF/Tu3RvZ2dkyJZslJiYiNDQU2dnZ6NWrl1yWwpAFNTU1fPXVVwgJCUFYWBjmzJnD2Ieuri40NDTA4/FgbGyM2lrp9/IFXq04ceTIESQmJsLc3FymPnxFoVTCd3FxwbRp0xhn8TVcb3Lt2rXgcDjo3r07QkND4ezszCgGFouF//znP+I8m3Pnzr2Vxi0hBGVlZaiurkZtba14Y2wmCAQCHDx4EAYGBggMDGScd6SlpYVPP/2U8XXfBEol/Llz58LNzQ25ubkwNjaGoaGhVHabNm3C5s2bIRQKsWrVKvj7+2PgwIEoKSlhHIM88mzkwZIlS3Dq1ClMnToVDg4OcHJyYuxDIBDAzc0NWlpaSE5OxsCBAxUQ6dtBKYQfHBzc4mfSPF7lud6kPPJs5IGNjQ369++PgoICJCYmyjSewGKxsHbtWnGXaGZm5ltLwZA3SiF8BwcHREZGYv369TLZy3O9yfaCPMYT2svTSyG0efJiO2Hr1q0kMTFRJlsej0eOHj0qMS+1sLCQrF+/Xl7hvXEUsbS2MqEUJT4ALF++XGZbDofTZCVfIyMjxoustifay3hCe0WplhCk/MvEiRMxf/78tz6e0F5RmhKf8or6JfqAV7PBtLS0QAiR2+oEygIVvpLRMPXY2NiYlvQtoBRJahQKU2gdn6KSUOFTVBIqfIpKQoVPUUmo8CkqCRU+RSWhwqeoJFT4FJXk/wE9dAOiWAR6fQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 200x175 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x175 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x175 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot\n",
    "plt.figure(figsize=(2,1.75))\n",
    "ax = sns.barplot(data=df_corr_common,x='PE',hue='PE',y='Cosine',palette='Blues_r',legend=False);\n",
    "plt.xticks(fontsize=7,rotation=90);\n",
    "plt.yticks(fontsize=7);\n",
    "plt.ylabel('Cosine',fontsize=8,labelpad=1);\n",
    "plt.xlabel('',fontsize=8);\n",
    "plt.title('Cosine similarity with\\nhuman performance',fontsize=8);\n",
    "plt.ylim([0.6,1])\n",
    "sns.despine()\n",
    "plt.tight_layout()\n",
    "plt.savefig(f\"{outputdir}/commonPE_cosine.pdf\",transparent=True)\n",
    "\n",
    "# Plot\n",
    "plt.figure(figsize=(2,1.75))\n",
    "ax = sns.barplot(data=df_corr_common,x='PE',hue='PE',y='Correlation',palette='Reds_r',legend=False);\n",
    "plt.xticks(fontsize=7,rotation=90);\n",
    "plt.yticks(fontsize=7);\n",
    "plt.ylabel('Rank correlation',fontsize=8,labelpad=1);\n",
    "plt.xlabel('',fontsize=8);\n",
    "plt.title('Rank correlation with\\nhuman performance',fontsize=8);\n",
    "# plt.ylim([0.9,1])\n",
    "sns.despine()\n",
    "plt.tight_layout()\n",
    "plt.savefig(f\"{outputdir}/commonPE_correlation.pdf\",transparent=True)\n",
    "\n",
    "df_corr_common['Cosine+Corr/2'] = (df_corr_common.Correlation.values + df_corr_common.Cosine.values)/2\n",
    "plt.figure(figsize=(2,1.75))\n",
    "ax = sns.barplot(data=df_corr_common,x='PE',hue='PE',y='Cosine+Corr/2',palette='rocket',legend=False);\n",
    "plt.xticks(fontsize=7,rotation=90);\n",
    "plt.yticks(fontsize=7);\n",
    "plt.ylabel('Cos+Corr average',fontsize=8,labelpad=1);\n",
    "plt.xlabel('',fontsize=8);\n",
    "plt.title('\\nComposite score',fontsize=8);\n",
    "plt.ylim([0.4,.75])\n",
    "# plt.ylim([0.9,1])\n",
    "sns.despine()\n",
    "plt.tight_layout()\n",
    "plt.savefig(f\"{outputdir}/commonPE_composite.pdf\",transparent=True)"
   ]
  }
 ],
 "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"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
