{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/lukeh/miniconda3/envs/LSTANN/lib/python3.9/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import torch\n",
    "import lstnn.transformer_main as transformer_main\n",
    "\n",
    "model_label = 'Transformer'\n",
    "nblocks = 4\n",
    "hidden_size = 160\n",
    "curriculum = 'All'\n",
    "seeds = [42, 88, 1031989, 26011990, 1052022, 2235,\n",
    "         6312, 6068, 9742, 8880, 2197, 669, 6256, \n",
    "         3309, 2541, 8643, 7785, 195, 6914, 29]\n",
    "#seeds = [6914, 29]\n",
    "device = 'cpu'\n",
    "\n",
    "# learning rates and cutoff to stop training\n",
    "learning_rate = 0.00001\n",
    "training_acc_cutoff = 0.99\n",
    "cutoff_length = 20  # how many epochs must the model sustain the accuracy cutoff?\n",
    "dropout = 0.0\n",
    "\n",
    "# load results and model\n",
    "df = pd.DataFrame()\n",
    "models = {}\n",
    "for seed in seeds:\n",
    "      out = f\"../results/model-{model_label}_\" \\\n",
    "                  f\"nl-{nblocks}_\" \\\n",
    "                  f\"do-{dropout}_\" \\\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",
    "                  f\"s-{seed}\"\n",
    "      _df = pd.read_csv(out+'.csv')\n",
    "      _df['seed'] = seed\n",
    "      df = pd.concat([df, _df])\n",
    "\n",
    "      model = transformer_main.Transformer(\n",
    "                  nblocks=nblocks,\n",
    "                  embedding_dim=hidden_size,\n",
    "                  positional_encoding='absolute')\n",
    "      model.load_state_dict(torch.load(out+'.pt'))\n",
    "      models[seed] = model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "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)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# downsample the dataframe to plot things quicker\n",
    "import numpy as np\n",
    "\n",
    "df_ds = pd.DataFrame()\n",
    "ds_size = 10\n",
    "# get max epoch\n",
    "for i in np.arange(df.epoch.min(), df.epoch.max(), ds_size):\n",
    "    data = df[df.epoch == i]\n",
    "    df_ds = pd.concat([df_ds, data])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "findfont: Font family ['Arial'] not found. Falling back to DejaVu Sans.\n",
      "findfont: Font family ['Arial'] not found. Falling back to DejaVu Sans.\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x180 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "# generate basic figure\n",
    "plt.figure(figsize=(6, 2.5))\n",
    "\n",
    "plt.subplot(131)\n",
    "plot_df = df_ds.loc[(df_ds['phase'] == 'train') & (df_ds['condition'] != 'average')].reset_index()\n",
    "sns.lineplot(data=plot_df,\n",
    "             x='epoch', y='accuracy', hue='condition', \n",
    "             legend=False, palette='rocket', alpha=0.75,\n",
    "             hue_order=['binary', 'ternary', 'quaternary'])\n",
    "plt.title('Training', fontsize=12, fontname='Arial')\n",
    "plt.xlabel('Epoch', fontsize=10, fontname='Arial')\n",
    "plt.ylabel('Accuracy', fontsize=10, fontname='Arial')\n",
    "plt.xticks(fontsize=8)\n",
    "plt.yticks(fontsize=8)\n",
    "plt.ylim([0.0, 1.0])\n",
    "sns.despine()\n",
    "\n",
    "plt.subplot(132)\n",
    "plot_df = df_ds.loc[(df_ds['phase'] == 'test') & (df_ds['condition'] != 'average')].reset_index()\n",
    "g = sns.lineplot(data=plot_df,\n",
    "                 x='epoch', y='accuracy', hue='condition', alpha=0.75,\n",
    "                 palette='rocket', hue_order=['binary', 'ternary', 'quaternary'])\n",
    "g.legend(fontsize=8)\n",
    "plt.title('Test', fontsize=12, fontname='Arial')\n",
    "plt.xlabel('Epoch', fontsize=10, fontname='Arial')\n",
    "plt.ylabel('')\n",
    "plt.xticks(fontsize=8)\n",
    "plt.yticks(fontsize=8)\n",
    "plt.ylim([0.0, 1.0])\n",
    "sns.despine()\n",
    "\n",
    "plt.subplot(133)\n",
    "plot_df = df_ds.loc[(df_ds['phase'] == 'validation') & (df_ds['condition'] != 'average')].reset_index()\n",
    "g = sns.lineplot(data=plot_df,alpha=0.75,\n",
    "                 x='epoch', y='accuracy', hue='condition',legend=False,\n",
    "                 palette='rocket', hue_order=['binary', 'ternary', 'quaternary'])\n",
    "plt.title('Validation (fMRI)', fontsize=12, fontname='Arial')\n",
    "plt.xlabel('epoch', fontsize=10, fontname='Arial')\n",
    "plt.ylabel('')\n",
    "plt.xticks(fontsize=8)\n",
    "plt.yticks(fontsize=8)\n",
    "plt.ylim([0.0, 1.0])\n",
    "sns.despine()\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "No artists with labels found to put in legend.  Note that artists whose label start with an underscore are ignored when legend() is called with no argument.\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x180 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# generate basic figure\n",
    "plt.figure(figsize=(6, 2.5))\n",
    "\n",
    "plt.subplot(131)\n",
    "plot_df = pd.DataFrame()\n",
    "for s in df.seed.unique():\n",
    "    pdf = df.loc[df.seed == s]\n",
    "    max_epoch = pdf.epoch.max()\n",
    "\n",
    "    pdf = pdf.loc[(pdf['phase'] == 'test') & (pdf['condition'] != 'average')& (pdf['epoch'] > max_epoch-20)].reset_index()\n",
    "    plot_df = pd.concat([plot_df, pdf])\n",
    "\n",
    "plot_df = plot_df.groupby(['seed', 'condition'], as_index=False).mean()\n",
    "\n",
    "# g = sns.swarmplot(data=plot_df,\n",
    "#                  x='condition', y='accuracy', alpha=0.75, size=3,\n",
    "#                  palette='rocket', order=['binary', 'ternary', 'quaternary'])\n",
    "g = sns.boxplot(data=plot_df,\n",
    "                 x='condition', y='accuracy',\n",
    "                 palette='rocket', order=['binary', 'ternary', 'quaternary'])\n",
    "\n",
    "g.legend(fontsize=8)\n",
    "plt.title('ANN Test', fontsize=12, fontname='Arial')\n",
    "plt.xlabel('Condition', fontsize=10, fontname='Arial')\n",
    "plt.ylabel('')\n",
    "plt.xticks(fontsize=8)\n",
    "plt.yticks(fontsize=8)\n",
    "plt.ylim([0.0, 1.0])\n",
    "plt.legend([],[], frameon=False)\n",
    "\n",
    "sns.despine()\n",
    "\n",
    "plt.subplot(132)\n",
    "plot_df = pd.DataFrame()\n",
    "for s in df.seed.unique():\n",
    "    pdf = df.loc[df.seed == s]\n",
    "    max_epoch = pdf.epoch.max()\n",
    "\n",
    "    pdf = pdf.loc[(pdf['phase'] == 'validation') & (pdf['condition'] != 'average')& (pdf['epoch'] > max_epoch-20)].reset_index()\n",
    "    plot_df = pd.concat([plot_df, pdf])\n",
    "\n",
    "plot_df = plot_df.groupby(['seed', 'condition'], as_index=False).mean()\n",
    "# g = sns.swarmplot(data=plot_df,\n",
    "#                  x='condition', y='accuracy', alpha=0.75, size=3,\n",
    "#                  palette='rocket', order=['binary', 'ternary', 'quaternary'])\n",
    "\n",
    "g = sns.boxplot(data=plot_df,\n",
    "                 x='condition', y='accuracy',\n",
    "                 palette='rocket', order=['binary', 'ternary', 'quaternary'])\n",
    "plt.title('ANN Validation', fontsize=12, fontname='Arial')\n",
    "plt.xlabel('Condition', fontsize=10, fontname='Arial')\n",
    "plt.ylabel('')\n",
    "plt.xticks(fontsize=8)\n",
    "plt.yticks(fontsize=8)\n",
    "plt.ylim([0.0, 1.0])\n",
    "plt.legend([],[], frameon=False)\n",
    "\n",
    "plt.subplot(133)\n",
    "pdf = human_df.loc[human_df.trial_type != \"Null\"]\n",
    "pdf = pdf.groupby(['subject', 'trial_type'], as_index=False).mean()\n",
    "# sns.swarmplot(data=pdf,\n",
    "#                  x='trial_type', y='accuracy',alpha=0.75, size=3,\n",
    "#                  palette='rocket', order=['Binary', 'Ternary', 'Quaternary'])\n",
    "sns.boxplot(data=pdf,\n",
    "                 x='trial_type', y='accuracy',\n",
    "                 palette='rocket', order=['Binary', 'Ternary', 'Quaternary'])\n",
    "plt.title('Human Behaviour', fontsize=12, fontname='Arial')\n",
    "plt.xlabel('Condition', fontsize=10, fontname='Arial')\n",
    "plt.ylabel('')\n",
    "plt.xticks(fontsize=8)\n",
    "plt.yticks(fontsize=8)\n",
    "plt.ylim([0.0, 1.0])\n",
    "plt.legend([],[], frameon=False)\n",
    "\n",
    "sns.despine()\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Compare errors between humans and ANN\n",
    "I think we could consider using a different analysis rather than correlating means"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/lukeh/miniconda3/envs/LSTANN/lib/python3.9/site-packages/torch/utils/checkpoint.py:31: UserWarning: None of the inputs have requires_grad=True. Gradients will be None\n",
      "  warnings.warn(\"None of the inputs have requires_grad=True. Gradients will be None\")\n"
     ]
    }
   ],
   "source": [
    "import torchlens as tl\n",
    "from lstnn.dataset import get_dataset\n",
    "import numpy as np\n",
    "\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)))\n",
    "for s, seed in enumerate(seeds):\n",
    "    model = models[seed]\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",
    "\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.numpy() * 1.0\n",
    "            ann_accuracy[:, s] = accuracy.copy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7fb5ba9b4250>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "a = human_df.groupby(by='LST_id')['accuracy'].mean().values[0:108]\n",
    "b = np.mean(ann_accuracy, axis=1)\n",
    "\n",
    "plt.scatter(a, b)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "# do the actual errors, e.g., a \"2\" instead of a \"4\" the same?"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "numpy.ndarray"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "type(accuracy)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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
}
