{
 "cells": [
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Trained results were computed by name, and he sent me the results in a different format on dropbox.   \n",
    "I'm using this notebook to convert them to the format I have so I can plot them with the functions used\n",
    "for the untrained results."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from matplotlib import pyplot as plt\n",
    "saveFolder = '/home3/name/what-is-brainscore/results_all/results_pereira/'\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "across_layer_results_384 = np.clip(np.load(\"/data/LLMs/Pereira/trained_results/GPT2SP_TEST_R2_ACROSS_LAYERS_384.npy\"), 0, np.inf)\n",
    "across_layer_results_243 = np.load(\"/data/LLMs/Pereira/trained_results/GPT2SP_TEST_R2_ACROSS_LAYERS_243.npy\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan,\n",
       "       nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan,\n",
       "       nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan,\n",
       "       nan, nan, nan, nan, nan, nan, nan, nan, nan, nan])"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(across_layer_results_384, axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f445576bb90>]"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(np.nanmean(across_layer_results_384, axis=1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Layers by voxels:  (49, 92540)\n"
     ]
    }
   ],
   "source": [
    "print(\"Layers by voxels: \", across_layer_results_384.shape)\n",
    "# save in the following format: pereira_model-name_layer_{i}_\n",
    "model_name = 'gpt2-xl-sp'\n",
    "layer_name = 'layer'\n",
    "niter = 1\n",
    "exp = '384'\n",
    "\n",
    "for i, layer_res in enumerate(across_layer_results_384):\n",
    "    saveName = f'pereira_{model_name}_layer_{i}_{niter}_{exp}'\n",
    "    results_dict = np.savez(f'{saveFolder}{saveName}', **{'out_of_sample_r2': layer_res})\n",
    "    \n",
    "exp = '243'\n",
    "\n",
    "for i, layer_res in enumerate(across_layer_results_243):\n",
    "    saveName = f'pereira_{model_name}_layer_{i}_{niter}_{exp}'\n",
    "    results_dict = np.savez(f'{saveFolder}{saveName}', **{'out_of_sample_r2': layer_res})\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "metadata": {},
   "outputs": [],
   "source": [
    "all_models_results_384 = np.load(\"/data/LLMs/Pereira/trained_results/WN_POS_WORD_SENSE_SYNT_GPT2SP_OOSR2_384.npy\")\n",
    "all_models_results_243 = np.load(\"/data/LLMs/Pereira/trained_results/WN_POS_WORD_SENSE_SYNT_GPT2SP_OOSR2_243.npy\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "metadata": {},
   "outputs": [],
   "source": [
    "def reformat_r2(model_results, saveName):\n",
    "    \n",
    "    model_names = []\n",
    "    r2_vals = []\n",
    "    for w in range(2):\n",
    "        for p in range(2):\n",
    "            for wo in range(2):\n",
    "                for se in range(2):\n",
    "                    for sy in range(2):\n",
    "                        for c in range(2):\n",
    "                            r2_val = model_results[w, p, wo, se, sy, c]\n",
    "                            mn = ''\n",
    "                            if p:\n",
    "                                mn += 'POS+'\n",
    "                            if w:\n",
    "                                mn += 'SL+'\n",
    "                            if wo:\n",
    "                                mn += 'WORD+'\n",
    "                            if se:\n",
    "                                mn += 'SENSE+'\n",
    "                            if sy:\n",
    "                                mn += 'SYNT+'\n",
    "                            if c:\n",
    "                                mn += 'GPT2-XL'\n",
    "                            mn = mn.rstrip('+')\n",
    "                            if mn == '':\n",
    "                                mn = 'Intercept'\n",
    "                            model_names.append(mn)\n",
    "                            r2_vals.append(r2_val)\n",
    "                            \n",
    "    \n",
    "                            \n",
    "    np.save(f'/data/LLMs/Pereira/trained_results/{saveName}', r2_vals)\n",
    "    np.save(f'/data/LLMs/Pereira/trained_results/{saveName}_model_names', model_names)                    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "metadata": {},
   "outputs": [],
   "source": [
    "reformat_r2(all_models_results_384, 'r2_384_trained')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>model_name</th>\n",
       "      <th>r2_vals</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Intercept</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>GPT2-XL</td>\n",
       "      <td>0.012791</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>SYNT</td>\n",
       "      <td>0.006390</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>SYNT_GPT2-XL</td>\n",
       "      <td>0.011553</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>SENSE</td>\n",
       "      <td>0.008349</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     model_name   r2_vals\n",
       "0     Intercept  0.000000\n",
       "1       GPT2-XL  0.012791\n",
       "2          SYNT  0.006390\n",
       "3  SYNT_GPT2-XL  0.011553\n",
       "4         SENSE  0.008349"
      ]
     },
     "execution_count": 93,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "model_r2 = pd.DataFrame({'model_name': model_names, 'r2_vals': np.nanmean(np.stack(r2_vals), axis=1)})\n",
    "model_r2.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "metadata": {},
   "outputs": [],
   "source": [
    "def find_best(df, model_to_keep, models_to_discard):\n",
    "    \n",
    "    for md in models_to_discard:\n",
    "        df =  df.loc[~df.model_name.str.contains(md)]\n",
    "    if len(model_to_keep) > 0:\n",
    "        df = df.loc[df.model_name.str.contains(model_to_keep)]\n",
    "    \n",
    "    return df\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_POS_SL = find_best(model_r2, '', ['WORD', 'SENSE', 'SYNT', 'GPT2-XL'])\n",
    "df_word = find_best(model_r2, 'WORD', ['SENSE', 'SYNT', 'GPT2-XL'])\n",
    "df_sense = find_best(model_r2, 'SENSE', ['SYNT', 'GPT2-XL'])\n",
    "df_synt = find_best(model_r2, 'SYNT', ['GPT2-XL'])\n",
    "df_synt = find_best(model_r2, 'SYNT', ['GPT2-XL'])\n",
    "df_GPT2 = find_best(model_r2, 'GPT2-XL', [])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>model_name</th>\n",
       "      <th>r2_vals</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Intercept</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>POS</td>\n",
       "      <td>0.005958</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>SL</td>\n",
       "      <td>0.001911</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48</th>\n",
       "      <td>POS_SL</td>\n",
       "      <td>0.006954</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   model_name   r2_vals\n",
       "0   Intercept  0.000000\n",
       "16        POS  0.005958\n",
       "32         SL  0.001911\n",
       "48     POS_SL  0.006954"
      ]
     },
     "execution_count": 89,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_POS_SL.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "llama",
   "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.11.4"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
