{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "e824c927-2889-42a6-9825-08bd93ed0c4d",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initializing ... \n",
      "generating json ...\n"
     ]
    }
   ],
   "source": [
    "import set_path\n",
    "\n",
    "import os\n",
    "import numpy as np\n",
    "import matplotlib as mpl\n",
    "import pandas as pd\n",
    "from pycocotools.coco import COCO\n",
    "import skimage.io as io\n",
    "import nibabel as nib\n",
    "import pickle\n",
    "import seaborn as sns\n",
    "import os\n",
    "import re\n",
    "import warnings\n",
    "from tqdm import tqdm\n",
    "import json\n",
    "import random\n",
    "\n",
    "from scipy import signal, stats\n",
    "from scipy.interpolate import interp1d\n",
    "from sklearn.model_selection import KFold\n",
    "\n",
    "import torch\n",
    "from torch import nn, optim\n",
    "from torch.utils.data import Dataset, DataLoader\n",
    "import torch.nn.functional as F\n",
    "import pytorch_lightning as pl\n",
    "\n",
    "from settings import settings\n",
    "from utils import *\n",
    "from filters import filters\n",
    "from funcs import *\n",
    "\n",
    "import timm.optim.optim_factory as optim_factory\n",
    "from datasets_pretrain import HCPAgingPretrainDataset, HCP7TPretrainDataset\n",
    "from model_utils import CosineWarmupScheduler\n",
    "from models_autoencoder import fMRIAutoEncoder\n",
    "\n",
    "from sklearn.metrics import mean_absolute_error\n",
    "from sklearn.metrics import mean_squared_error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "e1b24ca3-4c7d-4217-84af-4bbd17c012ab",
   "metadata": {},
   "outputs": [],
   "source": [
    "mpl.rcParams['pdf.fonttype'] = 42\n",
    "\n",
    "font = {'family' : 'sans-serif',\n",
    "        'sans-serif': 'Arial',\n",
    "        'weight' : 'normal',\n",
    "        'size'   : 8}\n",
    "mpl.rc('font', **font)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "6d287037-8103-4932-940d-fc80a27f61ac",
   "metadata": {},
   "outputs": [],
   "source": [
    "varName = 'PretrainedStateModels'\n",
    "fName = getattr(settings.projectData.files.general_HCP3T, varName)\n",
    "fPath = settings.projectData.dir.general_HCP3T / fName\n",
    "with open(fPath, 'rb') as handle:\n",
    "    PretrainedStateModels = pickle.load(handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ba141de7-1b00-45d6-a79a-d428bf8fccc4",
   "metadata": {},
   "outputs": [],
   "source": [
    "def evaluation_reconstruction(modelInfo, checkpoint='best', mask_ratio=0):\n",
    "    args = modelInfo.args\n",
    "\n",
    "    test_dataset = HCP7TPretrainDataset(settings, region_roi='Yeo100Parc', use_all_data=True,\n",
    "                                fmri_type=args.training.fmri_type,\n",
    "                                overlapping_segments=False,\n",
    "                                output_fmri_size = 900,\n",
    "                                random_seed=42)\n",
    "    test_dataset.train()\n",
    "    test_dataloader = DataLoader(test_dataset, batch_size=args.training.batch_size, shuffle=False, num_workers=4)\n",
    "    \n",
    "    model = fMRIAutoEncoder(args.model)\n",
    "    mdl_path = modelInfo.model_files.set_index('checkpoint').loc[checkpoint].file_path\n",
    "    msg = model.load_state_dict(torch.load(mdl_path), strict=True)\n",
    "    model = model.to(args.training.device)\n",
    "    \n",
    "    model.eval()\n",
    "    tgt_all = []\n",
    "    preds_all = []\n",
    "    with torch.no_grad():\n",
    "        dataIter = iter(test_dataloader)\n",
    "\n",
    "        for i_iter in tqdm(range(len(dataIter)), \n",
    "                desc='test epoch [{:d}|{:d}]'.format(args.training.epoch, args.training.max_epoch)):\n",
    "\n",
    "            sldwins, fmri_segs = next(dataIter)\n",
    "            fmri_segs = fmri_segs.to(args.training.device)\n",
    "\n",
    "            loss, pred, mask, latent, (loss_masked, loss_unmasked) = model(fmri_segs, mask_ratio=mask_ratio)\n",
    "            tgt_all.append(fmri_segs.cpu().numpy())\n",
    "            preds_all.append(pred.cpu().numpy())\n",
    "\n",
    "    tgt_all = np.concatenate(tgt_all, axis=0)\n",
    "    preds_all = np.concatenate(preds_all, axis=0)\n",
    "    \n",
    "    num_samples = tgt_all.shape[0]\n",
    "    tgt_all = tgt_all.reshape(num_samples, -1)\n",
    "    preds_all = preds_all.reshape(num_samples, -1)\n",
    "    \n",
    "    return {'mae': mean_absolute_error(preds_all, tgt_all),\n",
    "            'mse': mean_squared_error(preds_all, tgt_all),\n",
    "            'mask_ratio': mask_ratio}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "2538967e-be22-47d5-8964-ffc3d1dced74",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:06<00:00,  3.65it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.79it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.75it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.72it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.35it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.67it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.81it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.72it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.72it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.85it/s]\n"
     ]
    }
   ],
   "source": [
    "modelInfo = PretrainedStateModels.AE_MaskTSN_PRETRAINv2\n",
    "checkpoint = 'epoch_1000'\n",
    "results = []\n",
    "for mask_ratio in np.arange(0,1,0.1):\n",
    "    d = evaluation_reconstruction(modelInfo, checkpoint=checkpoint, mask_ratio=mask_ratio)\n",
    "    results.append(d)\n",
    "results_AE_MaskTSN_PRETRAINv2 = pd.DataFrame(results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "ecd381f2-6e3e-4666-a6ed-84b7b889a3b6",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.72it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.77it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.77it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.76it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.80it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.83it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.56it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.83it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.78it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.79it/s]\n"
     ]
    }
   ],
   "source": [
    "modelInfo = PretrainedStateModels.AE_DynamicMaskTSN_PRETRAINv2\n",
    "checkpoint = 'epoch_1000'\n",
    "results = []\n",
    "for mask_ratio in np.arange(0,1,0.1):\n",
    "    d = evaluation_reconstruction(modelInfo, checkpoint=checkpoint, mask_ratio=mask_ratio)\n",
    "    results.append(d)\n",
    "results_AE_DynamicMaskTSN_PRETRAINv2 = pd.DataFrame(results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "6d4979e9-fc7a-4009-bb55-853415aa616b",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.88it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.88it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.86it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.37it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.90it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.88it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.89it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.98it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  7.02it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.70it/s]\n"
     ]
    }
   ],
   "source": [
    "modelInfo = PretrainedStateModels.AE_VanillaTSN_PRETRAINv4\n",
    "checkpoint = 'epoch_1000'\n",
    "results = []\n",
    "for mask_ratio in np.arange(0,1,0.1):\n",
    "    d = evaluation_reconstruction(modelInfo, checkpoint=checkpoint, mask_ratio=mask_ratio)\n",
    "    results.append(d)\n",
    "results_AE_VanillaTSN_PRETRAINv4 = pd.DataFrame(results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "76c5fe73-cee4-4205-892d-1ec4557a0561",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.75it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.54it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.57it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.75it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.72it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.67it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.71it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.86it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.67it/s]\n",
      "test epoch [1000|1000]: 100%|█████████████████████████████████████████████████████████| 23/23 [00:03<00:00,  6.69it/s]\n"
     ]
    }
   ],
   "source": [
    "modelInfo = PretrainedStateModels.AE_VanillaTSN_PRETRAINv2\n",
    "checkpoint = 'epoch_1000'\n",
    "results = []\n",
    "for mask_ratio in np.arange(0,1,0.1):\n",
    "    d = evaluation_reconstruction(modelInfo, checkpoint=checkpoint, mask_ratio=mask_ratio)\n",
    "    results.append(d)\n",
    "results_AE_VanillaTSN_PRETRAINv2 = pd.DataFrame(results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "b50f6312-dc10-4e0c-af78-d7f91d675e68",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 200x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1,1,figsize=[2,3])\n",
    "ax.plot(results_AE_MaskTSN_PRETRAINv2.mask_ratio.values, \n",
    "        results_AE_MaskTSN_PRETRAINv2.mse.values, color='#637BD1',\n",
    "        marker='s', alpha=.8, markeredgewidth=0.5, label='SG-MAE',\n",
    "        markersize=8, markeredgecolor='k')\n",
    "\n",
    "ax.plot(results_AE_DynamicMaskTSN_PRETRAINv2.mask_ratio.values, \n",
    "        results_AE_DynamicMaskTSN_PRETRAINv2.mse.values, color='#D1637B',\n",
    "        marker='o', alpha=.7, markeredgewidth=0.5, label='DG-MAE',\n",
    "        markersize=7, markeredgecolor='k')\n",
    "\n",
    "ax.plot(results_AE_VanillaTSN_PRETRAINv4.mask_ratio.values, \n",
    "        results_AE_VanillaTSN_PRETRAINv4.mse.values, color='#7BD163',\n",
    "        marker='^', alpha=.8, markeredgewidth=0.5, label='MAE (without ROI embeedings)',\n",
    "        markersize=8, markeredgecolor='k')\n",
    "\n",
    "# ax.plot(results_AE_VanillaTSN_PRETRAINv2.mask_ratio.values, \n",
    "#         results_AE_VanillaTSN_PRETRAINv2.mse.values, color='#D1B963',\n",
    "#         marker='D', alpha=.8, markeredgewidth=0.5, label='AE (without ROI embeedings)',\n",
    "#         markersize=6, markeredgecolor='k')\n",
    "\n",
    "ax.set_ylabel('reconstruction mean square errors')\n",
    "ax.set_xlabel('mask ratio (%)')\n",
    "ax.legend()\n",
    "ax.set_xticks(np.arange(0,1,0.2,))\n",
    "ax.set_xticklabels(['{:d}'.format(int(x*100)) for x in ax.get_xticks()])\n",
    "ax.invert_yaxis()\n",
    "ax.spines['top'].set_visible(False)\n",
    "ax.spines['right'].set_visible(False)\n",
    "fig_dir = settings.results.dir / 'ver.1' / 'figure2'\n",
    "fig.savefig(fig_dir / 'fig2-2b.pdf', dpi=200)\n",
    "fig.savefig(fig_dir / 'fig2-2b.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "496a3c33-77b8-48af-8caa-a618fc81ce26",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a872c3f-63f3-43d4-9fe7-85f8bd8292fe",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:pyfmri]",
   "language": "python",
   "name": "conda-env-pyfmri-py"
  },
  "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.10.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
