{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "6c838b11-e101-45d5-bfd1-d19ad724ae77",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import set_path\n",
    "\n",
    "import os\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from pycocotools.coco import COCO\n",
    "import matplotlib as mpl\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",
    "from sklearn.metrics.pairwise import cosine_similarity\n",
    "from bct.algorithms.modularity import community_louvain\n",
    "\n",
    "from settings import settings\n",
    "from utils import *\n",
    "from filters import filters\n",
    "from funcs import *\n",
    "\n",
    "from datasets_transfer import HCP3TTransferDataset\n",
    "import timm.optim.optim_factory as optim_factory\n",
    "from timm.models.vision_transformer import Block\n",
    "from model_utils import CosineWarmupScheduler\n",
    "from models_autoencoder import fMRIAutoEncoder, fMRIStateTransferModel\n",
    "from models_tsn import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "89d5ea7a-f907-46c0-8885-6fec29c48b5a",
   "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": "de14b5fb-6c92-4731-97f8-f449e4d5dc78",
   "metadata": {},
   "outputs": [],
   "source": [
    "varName = 'TransferredStateModels'\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",
    "    TransferredStateModels = pickle.load(handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "3534582c-9fec-4e53-9cbb-f58974919294",
   "metadata": {},
   "outputs": [],
   "source": [
    "varName = 'CCAModeData'\n",
    "fName = getattr(settings.projectData.files.general_HCP3T, varName)\n",
    "fPath = settings.projectData.dir.general_HCP3T / fName\n",
    "dat = loadmat(fPath)['dat']\n",
    "dat['subjects'] = np.array(dat['subjects']).astype(int)\n",
    "dat['FC_BEH_U'] = np.array(dat['FC_BEH_U'])\n",
    "dat['FC_BEH_V'] = np.array(dat['FC_BEH_V'])\n",
    "CCAMode = pd.DataFrame({'SUBJECT': dat['subjects'],\n",
    "                      'CCA_FC': dat['FC_BEH_U'][:,0],\n",
    "                      'CCA_BEH': dat['FC_BEH_V'][:,0]})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "755a4534-f73f-4ba0-9220-a1eede7cf14e",
   "metadata": {},
   "outputs": [],
   "source": [
    "def evaluation_features(modelInfo, kf_split_id, checkpoint='best'):\n",
    "    args = modelInfo.args\n",
    "    train_dataset = HCP3TTransferDataset(settings, region_roi='Yeo100Parc',\n",
    "                            output_continuous_targets = args.training.output_continuous_targets,\n",
    "                            output_discrete_targets = args.training.output_discrete_targets,\n",
    "                            standardized_output = True,\n",
    "                            fmri_type=args.training.fmri_type, \n",
    "                            kf_split_id=kf_split_id,\n",
    "                            overlapping_segments=args.training.overlapping_segments, \n",
    "                            normalize_fmri=args.training.normalize_fmri)\n",
    "    train_dataset.train()\n",
    "    args.training.sessIDs = [(row.SUBJECT, row.SESSION) for _, row in train_dataset.train_data_infos.iterrows()]\n",
    "\n",
    "    test_dataset = HCP3TTransferDataset(settings, region_roi='Yeo100Parc',\n",
    "                            output_continuous_targets = args.training.output_continuous_targets,\n",
    "                            output_discrete_targets = args.training.output_discrete_targets,\n",
    "                            standardized_output = True,\n",
    "                            output_fmri_size = 830,\n",
    "                            fmri_type=args.training.fmri_type, \n",
    "                            kf_split_id=kf_split_id,\n",
    "                            overlapping_segments=args.training.overlapping_segments, \n",
    "                            normalize_fmri=args.training.normalize_fmri)\n",
    "    test_dataset.test()\n",
    "    test_dataset.tgt_norms = train_dataset.tgt_norms\n",
    "    test_dataloader = DataLoader(test_dataset, batch_size=4, shuffle=False, num_workers=8)\n",
    "\n",
    "    model = fMRIStateTransferModel(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=False)\n",
    "    model = model.to(args.training.device)\n",
    "\n",
    "    model.eval()\n",
    "    feats_all = []\n",
    "\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",
    "            batch = next(dataIter)\n",
    "            batch = {key: item.to(args.training.device) for key, item in batch.items()}\n",
    "\n",
    "            # mask_ratio = np.random.random() * args.training.max_mask_ratio\n",
    "            mask_ratio = 0\n",
    "            feats = model.forward_features(batch['fmri_segs'], mask_ratio=0)\n",
    "            feats_all.append(feats.cpu().numpy())\n",
    "\n",
    "    feats_all = np.concatenate(feats_all, axis=0).squeeze()\n",
    "    test_session_info = test_dataset.test_data_infos.reset_index(names='data_index')\n",
    "    return test_session_info, feats_all[:,0,:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "eafd2217-1f1c-4357-b13f-23bc67ec5c68",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "test epoch [250|250]: 100%|█████████████████████████████████████████████████████████| 170/170 [00:03<00:00, 42.62it/s]\n",
      "test epoch [250|250]: 100%|█████████████████████████████████████████████████████████| 169/169 [00:03<00:00, 42.77it/s]\n",
      "test epoch [250|250]: 100%|█████████████████████████████████████████████████████████| 168/168 [00:03<00:00, 42.93it/s]\n",
      "test epoch [250|250]: 100%|█████████████████████████████████████████████████████████| 170/170 [00:04<00:00, 42.26it/s]\n",
      "test epoch [250|250]: 100%|█████████████████████████████████████████████████████████| 170/170 [00:03<00:00, 44.28it/s]\n"
     ]
    }
   ],
   "source": [
    "feats_all = []\n",
    "sess_info_all = []\n",
    "kf_num_splits = 5\n",
    "checkpoint = 'best'\n",
    "for kf_split_id in range(kf_num_splits):\n",
    "    attr = 'iter{:d}'.format(kf_split_id)\n",
    "    modelInfo = getattr(TransferredStateModels.AE_MaskTSN_TRANSFERv3, attr)\n",
    "    sess_info, test_feats = evaluation_features(modelInfo, kf_split_id, checkpoint)\n",
    "    sess_info = sess_info.merge(CCAMode, on='SUBJECT').sort_values('data_index')\n",
    "    feats_all.append(test_feats)\n",
    "    sess_info_all.append(sess_info)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "86fe2db0-d23d-4ee5-beb8-82ba2312ef90",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "PearsonRResult(statistic=0.5088702082554795, pvalue=6.524047703181595e-44)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from sklearn.decomposition import PCA\n",
    "kf_split_id = 3\n",
    "feats = feats_all[kf_split_id]\n",
    "df = sess_info_all[kf_split_id]\n",
    "idxs = df.data_index.values\n",
    "\n",
    "pca = PCA(n_components=3)\n",
    "pcs = pca.fit_transform(feats)\n",
    "print(stats.pearsonr(pcs[idxs,1], df['CCA_BEH'].values))\n",
    "fig, ax = plt.subplots(1,1,figsize=[2,2])\n",
    "sc = ax.scatter(pcs[idxs,0], pcs[idxs,1], c=-df['CCA_BEH'].values, \n",
    "                alpha=0.8,cmap='bwr', vmin=-1.6, vmax=1.6, s=8,\n",
    "                ec='k', lw=0)\n",
    "ax.set_xticks([])\n",
    "ax.set_yticks([])\n",
    "ax.set_xlabel('PC1')\n",
    "ax.set_ylabel('PC2')\n",
    "cax = ax.inset_axes([0.1,1.1,0.4,0.03],\n",
    "                    transform=ax.transAxes)\n",
    "cbar = plt.colorbar(sc, cax=cax, orientation='horizontal')\n",
    "ax.text(0.2, 1.2, 'CCA mode', transform=ax.transAxes, \n",
    "        ha='center', va='center')\n",
    "\n",
    "fig_dir = settings.results.dir / 'ver.1' / 'figure4'\n",
    "fig.savefig(fig_dir / 'fig4-1.pdf', dpi=250)\n",
    "fig.savefig(fig_dir / 'fig4-1.png')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "f15d1b94-739c-42fc-9138-81bb315a070a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "PearsonRResult(statistic=0.5088702244872866, pvalue=6.524000594467873e-44)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAMMAAADmCAYAAABoHjEvAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAABrBElEQVR4nO2dd5ycVb3/3+d5ptfd2d6yJcmmk0onITSpQREEURR7ReGqF/VaEH+gguXaLtcrKgjivYgVEURApHdSSNu03exme59en/P748zs7GbbbEhIFubzeu1rZ+Ypc+Y853u+/fsVUkpJHnnkgXa0B5BHHscK8sSQRx5p5IkhjzzSyBNDHnmkkSeGPPJII08MeeSRRp4Y8sgjjTwx5JFHGnliyCOPNI45YvD7/XzmM59h6dKlrFixgnXr1vHcc8/lfBxg9+7daJrGnXfeecTHe+edd/KBD3zgiH9PHkcexxQxGIbBhRdeSEFBAZs2bWLTpk3ccsstXHzxxbS1tU17PINf/epXXHrppfzsZz87ir8mj1kHeQzh0UcflfX19TKVSo35/O9//7s8cODAtMellDKZTMrKykq5detWWVlZKTdu3Djue+644w75zne+U55yyimypqZG3njjjfLaa6+Vy5Ytk+vWrZPhcFhKKeWvfvUruWTJErl06VJ59dVXy0AgIKWU8q677pLz58+Xa9askZdeeqm8+uqrpZRSvvzyy/K0006TK1eulGeccYbcsWPHYZ6hPI4kjili+O53vysvv/zyQz4upZQPPPCAXLZsmZRSyuuuu05+7GMfG3fOHXfcIaurq+Xw8LBsaWmRgPz73/8upZRy/fr18s9//rPcsmWLbGhokL29vVJKKT/1qU/JL3zhC7K9vV2WlZXJzs5OmUgk5Nve9jZ59dVXy3g8Lo877jjZ3NwspZTy6aeflqtXrz6UacjjKOGYEpM0TcMwjEM+DkpEuvLKKwG48sor+e1vf0sgEBh33tq1a/F4PNTW1gJw1llnAVBbW8vg4CBPPPEEGzZsoLi4GICPfexjPPbYYzz77LOccsoplJeXYzKZuOqqqwBoampiz549vOMd72DFihV8+tOfprOzk3g8PvOJyOOo4JgihjVr1vDKK68gD4oqv/nmm3nggQemPd7X18cDDzzAf/3Xf1FXV8fll19OLBbj7rvvHvddFotlzHuTyTTm/cFEJ6UkkUgghBjz/WazGYBUKsXcuXNHdJmNGzfywgsvjPuePI5dHFPEsHbtWioqKvja175GMpkE4Mknn+QnP/kJS5Ysmfb43XffzamnnsqBAwdoaWmhpaWFW2+99ZAU6fXr1/OXv/yFvr4+AG6//XZOP/10TjvtNJ577rkRhf53v/sdAAsXLmRgYIAnn3wSgN/+9rds2LDhcExLHm8QTNOf8sZBCMH999/P5z73OZYtW4bZbKagoIA///nP1NfXA0x5/I477uAb3/jGmHt++MMf5hvf+AbPPPMMp556as5jOe644/jKV77CGWecQSKRYOXKlfzsZz/D6/Xy05/+lHPOOQeXy8XixYsBsFqt3HfffVx33XVEIhGcTif33HPPYZubPI48hDxY5sgjj7cojikxKY88jibyxJBHHmnkiSGPPNLIE0MeeaSRJ4Y88kgjTwx55JHGMeVnmAmi0ehbMtTBYrFgs9mO9jDelJiVxBCNRikqqicc7jraQ3nDUV5eTnNzc54gjgBmJTHE43HC4S4++ME2HA4PZjOYTGA2j/0zmXL/XNfBYhl7zuhzRx/TZAoSiexfMgnxuPqfTI49lkqfmzk++prR7+Px7LkHn5O+1h8KUXPPPcTj8TwxHAHMSmLIwGLxYLVmiWH0gj14UZvN2eOTEchU109JDBMt9tELOpFQF070eYbadF19puvZv0RC/RcCNE29z+OIYVYTQzzux2QCw1CbauZ/5i+ZVOsss8Emk7OcM7wFdaQ3ErMyNikajVJfX09XV15nyOPwYVYSA8zMmuT3+6mpqaGtrQ2Px/O6vvdo3ytvTTpymLViks1mm/Gi8Hg8r3sBH+v3yuPQkXe65ZFHGnliyCOPNN4SxGC1WrnhhhuwWq1v2nvl8foxaxXoPPI43HhLcIY88sgFeWLII4808sSQRx5pvOWI4Y477jjkqtn33XcfS5YsYf78+dx4442veyx+v59ly5bR0tLyuu+Vx+vHW4YYotEoX/ziF/nsZz97SNd3dXXxhS98gX/9619s376dp556iocffviQx/Pcc89x6qmn0tTUdMj3yOPw4i1DDI8//jhSSm699dZDuv6RRx7hzDPPpKSkBLPZzPvf/37uvffeQx7Pz3/+c2677TYqKysP+R55HF7M2nCMmeL888/n/PPPP+QGJu3t7VRVVY28r6ys5MCBA4c8njvuuOOQr83jyOBNxxnuu+8+qqurx/ydfPLJr/u+E1X/1rQ33fS9pXFUOINhGHR0dOB2uxFCHNZ7n3vuuWzfvn3c536/H4BIJEIikRh5nyuKiorYsWPHyHX79u2jtLR0xvc5GFJKAoHA675PHhMjM7+VlZXTbl5HxQN94MABampq3uivzeMtjLa2Nqqrq6c856hwBrfbDXBYcgJminvuuYenn36a//7v/57xtX/605+49dZbicViXHDBBdx0002vezzLli3jgQceGGmaksfhRSZnJLPmpsJR4Qx+vx+v18vw8HA+jj+PI4qZrLW8BphHHmnkiSGPPNLIE0MeeaSRJ4Y88kgjTwx55JFGnhjyyCONt0xs0psJUsKjj0JLC6xeDatWHe0RvTmQ5wyzEM8+C7//Pbz8Mvz859DWdrRH9OZAnhhmIXp7s6+lhHTf9jxeJ/LEMAtx0kngcqnXVVWwaNHRHc+bBXmdYRaivBz+3/9THKGiQlUGz+P1I08MaUgpIbwLGWkCKRH2enAuQQj9aA9tQjgcMGfO0R7Fmwt5MQkwhp7E2HE1Ru8flBAuNIyBRzG2X43R/nOkETvaQzzqGBqCzk4IBo/2SI4c3tKcQUoDo/VWMOJoC/4boTvHHZf9D2Hs+DBa3VcQzremcO73Q3d39nVtLbwZq+K/ZTmDlEmMvV9E2Oeh1399HCEACKGhFV+I1vhjjLYfYAw+fhRGevRxcBuMN2sDobckMUiZxNjzRUTBerTSy6Y9X5h9aI0/Rfb8AWPoqTdghMcW3G7VUg6Usu4cv2+8KfCWE5OkEVOE4DsHrfjC6c9P2/FdLiu2+d/HaPok0lKGcDSOnBMOw913Q08PnHUWnHJKDuOQAJI94TZeHN5Ka7STYCqCjobH5KTMWkSDvZpFrnp8Zu+h/+DDAKsV6usVR7BaVf+7NyPeUsQgY50Y+/4DUX41WuH6Kc/NNNr8+c9h40YlI197rZX6ubdi7L4ObeHtCN0OwF/+Aq++qq676y5YsACKiia+bzIJ99wDL+3pY7fzBZZf1MK60mVcXLoel+7AkAbDySCdsT42BXby284HGUj4qbaVcXbRiZxeuAabbjl8k5IjMo0e38x4k/88BWnEkd3/ixx8HK3+BmU2HQXDgAMHIBQCrxe2bYO9e1XzzVdeUaJBNAqPPQYf/WgxovIjGG0/RK/7MgCRyKjvkhCbwvj0ve/BHfcGiOsGF697G5eGzJxYOv68FSwY835/pJN/9D/HB7d+nVp7BVdXXswiV/34C/M4ZLypdQaZDGB0/AJjx4fA5EZb9KtxhADQ36/+olHYt08FwIESC4aHs+f5fOq/VrgeEr3I8C4Azj8fCgvVsfXrYbIieT098PhLfsJGlGJRQstec84Os1p7BR+tfif/u/w7XF15Mb9q/zMffO3rvDD0Wm43yGNavCkLAigi+B8IbUeUXoHwnT2l86yrS9nQQRHEtm1KnAG1yHt6oLQULrlE9YMGkNEDGK23oDf+RL2X2T7TkyEQgNUfeZ66wGrCfjMnnQS33HLoMnhPbIDb2u5lX6SdT9dcwYkFyw7tRm9izGStvenEJGPwCWTHzxFVn0Sb84WcrikuVhwgHIayMuXd3b1bcYK1ayde4MJWDaZCZGg7wrkYIaYPi/Cbe1jz7u2s2nsSPh+8+92vTxkttfr4xrxP0hMf4LbWe/lp6//xoap3cLpvNZp4UzP9I4I3FWcwuu5GBreh1X8Doc/cK2QYWRNiLpDR/RgHfoo+77s5nf/H7sdIyhSXl79txmPLBf3xYX7dcT/PDG7ixIJlvK3oZJa65mHS3qTmnxzwluQMRu/9yPBetLnfPuSSlRlC6OxUYdLFxZPL/wDCVgupMDIxgDD7Jj1vcBCammCzGOSihUfOi11k8fK5uvdxXe17eXl4Ow/2Pc33Wn6NBByalRKLj2JLAUVmL6WWImpsZdQ7qnCmrWJvdbwpiEFGmpH9f0Vb8LPXXbu1v18lzQDs369En5KSyc8XJe9A9v0FUfHBCY8PDcFNN6mYnk2hRZz2JQ8cYbeBJjROKFjKCQVLRz6LpGJ0x/sZSAzTHx+mK97HxsBOmsMHCKYiVNlKOa/4FNYVrsaivTXDYGc9MUgpMfZ/W4lGhyHCNBAY/35KYig4HaPp4zAJMezePSq4LaWzY6vOOUsnPPWIwq5bqbNXUmefmNW1RDr4Z/cr/KT9b1TYSjijahEVzsm53XRIJpV5WghoaJgdPopZMMSpIYeeBOdihDXbOyGZPPTJLytTIk1np1JuJ3OeZSA0C1gqkZEWhL1u3PHaWsVdEgmw6VZc1QPAsdegpM5eyQZnJUmrpCc+wAMtm2i17OC62qsossyclT3/vLLSgfLg5+KVP9qY9SYH2XU3WsWHALWL33kn/PSn8OCDmZCHmcFuVzt5W5vyN/z979NfI4rORw5M3NKqtBT+/d9hwwZ4/ycDyLrdMx/UFGhrg127lINwpgiFYPNmRfyGof5AUGop4uLiM9lQcjqf3vEtft72B5LGzL6gv3/i18cyZjUxyNB2sNUgTMpK8OqrSkYHtUDa2w/tvq2tir0LkXXATQXhORHpf3HS47W1cNFFcNGaKrYEpiYGw1C/YYLeKOOw8R89bPrBY2y641X+9MeZUX4qBf/4B2zZAi++CJs2qYC8DNxuOKFgKb897tu4TQ6u3PIlXhremvP9RxseqqqUJ//22+GPf1S+nGMRs1pMMnp+h1Z25ch7y0EhOwe/zxVz56pFknk9HYRmBlMBMt6LsEyuYJRZi+iKTZ69H43CT36idvvycvjsZ1Wuc7K7H9POrcrcddxxKmYkHMb2x99SG1Ara3cqQXTDiVPmGQQCKh+hrEx510cn6vT1Kf9K5vqMZU0TGldWnM95xafyrX2/5N6uf/Dl+g9PKzqtWaOIANRz+NWv1OvBQXjmGRXQeKxh1hKDNBIQaUE4sjE8q1cr51lfHyxerESUQ8FFF6koTSlhyZLcrhGF65GDjyPKLp/yvDp7Jc3hduodVeOObdyYLfvS1QUPP6wsWwNbwpyx2MW713WoLfz002F4GI8lSkYCKde6sVon/962NrjvPqVPVVbCFVeo+enpUccz7SEm87MUmj18d8G/8fLwdj6x/SYuLj2d91ZcMKlzT4gsd8joDhlkvPvHGmatmCT9zyO8Y3u1WSxw3nlw1VWvr7DW5s3w+OPw2mtTJ7Js3gy/+x288IKyKsmhJ6e993nFp/K33olzIryjNtuMGLN/PyDhxZZSDphqidgKlC5UUkLFijIqK6GsXGPVe5UXfDJs2ZJdhB0d2XDzdevg3HNVpG0uWONdzP8e9x2SMsWVm3MTncrLYeVK9bqwUFX3OBYxeznDwMNoFR857PcdGlILXEq1aJxOeMc7xp/X2qrkX1CxTE6nh0WmONKIIbTJt+jTClfys7b7uKb23eOOLV4MF18MW7eqxbt/v7JqNc4p5spzE+glGpEKH0YYnE4T2lXvpbitTVFRcfGUv2u0VUzXweNRFrdDaRhk0nQ+WPV23l66nlub7+Tujr/x5YYPUWGdXEQ85xxFfMdyT8hZSQxSGhBtm9CUORH6+5WY4HQq1j1VplYsNtYKNTo8ezQGBsa/F/NPRg4/iyg8Y9L7mzUT851z2BrYw1L3vHHHzz4bli+HHTvUQo3HIWW2s+wUG9ZyZSgYsRxZLLkpNcAJJ6j//f2wbNlYZflQ4TN7+U7jtWwL7uULTf/JqQXL+Vj1ZZOGfxzLhACzVUwKbQNnbsJ8UxN85jPwhS/ADTfAH/4w3rE2GmVlcOKJ6rXbDWdMsq4bG7O7rculFpgoPBs58Mi0Y3pvxYX8pvNvkx73eqGgQPknFi+GD38YamqyMtBUusFk0DQlnlx44eEvMbPENZffLLuZInMB793yZZpCLYf3C94gzE7OMPQvtCl239H45S+huVnt9pGIUuba22HhwsmvueQSuOACtfFm5PBgUIlQ5eVKvHA44BOfUMq6z5exwtRArAMpU1N6wxe56mmLdBFMhnGZHOOOWyzKN/HUU0rGXrdOjSOZVIv6WEy7FEJwRcW5rPet4QtNP+CiknVcUXHu0R7WjDArOYMMbAL3ypzOzSjAAwMqceeJJ3JbTFZrlhA6OuBnP1Mpnb/+dfaeFosSu0abM4V7NQRemfb+7yp/G/d2TeyoA6UCXHKJShbSNEXATz6pQhyOZZRZi7hz2TfZHW7lpr23cxSCog8Zs44YZNIPugMhcmNq73qXEmeiURVjVFioQgUOhmEo+/ef/5zNZ85gtFWpu3tqZ54oOg+j/8Fpx3VhyVoe6nsGQ07vXevthdtuU97wX/xCiX7HMnSh89W5H6XCWsyXd/941hDE7CMG//MIT+62uVNPVXVJTzpJ/TmdWUUulcoqo01Nymu9fz88/bTKic5gtKFG15U8PxG2bIG/PzGf7rZ+pJw6fMGsmTitYCWPD7w07W84cEDFNoES9/bvn/aSYwIfrr6Exc4GvrH3Z0d7KDlh9hHD8HMI78yivlauVEpoYSE0NiTZcEaQjrYkTz6p5PLubrXYOjrU664u5QDLYNUqZRZctgwuvzyb7zwaL7wA//VfirPceteHGT4w/SJ/X+VF/KZjckU6g7o6FTMVCim9p6Eh999+tPH+qg14TS5+3vaHoz2UaTH7FOhoC9jqZnzZuefCuWvDSnlISTZtLURaHEihsXevWvAZLuF0KhOr369MnFVVWQvTZNizJ/s6zDzat/8PBTVTc7AiixePyTWpRzqDwsKs/6G0VKWnHi4Eg8oBV1g4MZEfDvxb7VV8ductPDHwMqf71hyZLzkMmFWcQSaGwFRw6Ak8o5wIZm0kTBOzWSnBJ50E8+erxe/1ws03q5iam29WRDEVli3LKty+Yhc1xXuQqUmcFKPw/soNU5pZMzCblQXM51PEcDjE8FAIHnlEhXw8+ujYJiiTQcrcgghHQwjBLY3X8dPWe2mP9hzaYN8AzC5iCLyCcE8cZ5FIKLl/x44poiKtVvoHNf70dzt93Sk8Xo3CQmXLBzjzTDj5ZKVnuN3w3HNKmX7lFeWj+N3vJl8Ixx0HX/oSXH01/Md/gKvmTOTA9PHfqzwLeS2we9oQ6dF6S3ExiIF+5frevTurUMwQPT1KH+nqUlwxU1x4MsTj2bI6M63G7dBt3Np4Hf/e9AMSxrEZnDSrxCQZ3IjmO2/CY6+9lo2bHxpSixqUbf6FF5SsLYSD395lQWCgW0ycbdd417uy9zCZsv6Hf/5TRViGQupv7lx46SWYN2/yuKe6OvUHIJ0XYOy6FkoumfI3CSFYV7iapwZf5Yyi4yc9r6pKhVAYBnhscXgt7TwJh5V5K/PFM8CWLVkfzNCQEgV/9CMVarJqFbznPYyJdxrNkSIR5WuZiVe53lHFpeXn8IOWu/liw8SZgUcTs4ozEN4NjokjykKhiV///OfKP3DLLUrk2bvfRGefBTRtWqvM8uWqM05padbbnGsSjdCdYC1HhvdMe+7Fpeu5v/eJac9zu5X4JqQxVk46lMwelMOwqkqJXm634qz796tbv/IK7Nw59vzRCz+T7zFTXFp2Fh2xnmOy+NmsIQYpJcikyh2YADU1E7/evl093ERCcY7y8qxUkYnXmQgXXKDOXbxYRUx7PLB0qbJMZeTmVGpq2V0rew9G9z3T/rY59nI6oj252+NtNjU4IbKev8kQDKrsnd3jk4rq6tTlBQWKIx5c9+ng1FmXSzkjzWY1HxMSg5Rj/ybA/5v/aW5pvoNg8jBaAg4DZo+YlOgBy+QJCnV1SpY2DPWgMli8WIVaZ6wlp5yizluxYmrJoqYGbr1VyckHJ8xkCCHz2mSaeGEI52KItiJTQYTumvLnLXLVsyPUzGJXjnbTmhq1rU+1RScSymWeSf8791yVdZPG+vWK62maIoZUSklcW7cqZfq3v1V5DxnRUdPGzu045EjMHpOLL9RdzQ17/pvvL/x8Tte8EZg9nCG8B2Gfn30vlcLX3Z19Bi7X+If1sY/B+94H//Efkh/+IMWVVxi84x25idiaNnGHmoOf+VRrQJS+C9lz37TfdaL3OF4e3jb9oA4e4CSEICUkegYxBoeyHzY3j7yMx9XbVErpVZGI4hLvf7+aQ4tF+V1+8YuZDYnOzqysNQVOKVyO2+Tg4b5nZ/gFRw6zhzNE9oI9u2tu356tj1pRMT4jLZVSuoOmwamnSEQqmX1AKX3SAKU//Uk53ObOhfe+d+IqG5qWtSpNJzsL3zkY269Gll01qYgHsMw9jx/v/+3kN5oBpFQ+koFQIUXmQpzxQXQNmDuXVEpZ3IaGFEHEYoooHnskxbvW9VBTq5FKlJDZJzNhKIODak59PtD2NytKKSlR4bsZPPecsjyAsjVffPGU4/xS/Yd575Yvs8az5JAqcBxuzB7OEN2vKtilMdomfnBTcCmVdenVV1WIhd+flV+lVOEWv/vd+BifrVtV/E93Nzz7rArqm2iDE0IRiZ6mqSmJQeiI4guRfX+Z8vdVWUvpiOVg6M8ByaT6/Vt2mHmq/mr2zT9PFXZdtYq+PqVGaJo6LxN2MtfWzsCWA9DayqXH76evT83rhg2qKMK2bUqh3vlSQJnV2ttVCmomTxWUPJrZHbZtm5Y72HQLN8z7OF/Z/ZNjIn5p1hAD8U4YVRtpdHzQwbFCXV3qAQ4NKTNhd092+37hJcFf/qrx0ktwxx1jiWp0imc0qhbKgQMTp34KJFokhAj4py33IEouRfb+CWlMnkP6eisBjkY0ms1tTlqdPBNdPZIElOF0mqZCPKJR6OuT+FI96CaQQKAjyOrVKqe8u1ttEv/6lwpd6egEQ44a62jTXVlZ9nVxcU521+PcjTQ6a/lD96Ov70cfBsweYjDiqmBXGsuWKQ69YIGy8oxGLDZWCpJSjLSe6enLbuWp1NiaPsuXqz8p1XM94QR1zugeDWO+JB5XJ0QiIwnGE3ISzYIouQTZc++UP1EwM4IIh9WiPzgbz+lUXK+1VYmTo+fC58tm+9XWqnRMs0kST+jYjDCB/jid0WxcRiCgChO0tKjw8X+95ETzpI0BdvvYTKELLlBfEI8r2TXHzP/PznkPv+9+lAPRabx+RxizR2c4aOfU9ckztsrL1UIIhZRjqL6eEfa9ag28+LJay+Xl6WOj7vmpT6ln2dGR/TyzwT32GGx+Mcr86igXXXzQ0pWSXbuU2GwyqQy50RZPUXIJxo4PIYs2IMwFr2MiFMJhJftnKocvXqzWZma8H/6wGm9dnSqSMDIOMX7eVs/ppXOvh2jSxM4+jbrTitjztFKiTzpJiYwZ6WfYr8Hb3qaoxOUaq1R1dalB1NerXWbXrqx7fwqYNJ1vzf8MX971Y3697P8dtXL6s4IYlDyZ2665d6/aLX0+tcu7XGN3xupq+OIXFbH4fBP3VLBYFJf3+9WzLihQ8vLvfhODQJCmV6DcPMTx5xaNXCB1E889pziDpimx+u1vz95TCB2t5rMYrd9Fn3vzIc9FBn5/Vok3DLU2M8QAymR6yinqvGBw6iA8GY0jEQzEnAgB582PsPJk+8j+s3SpUgfM5rRnf7I49tch6jU4qjm76ER+3vYHPjHnXdNfcAQwK4iBVBCmsdODUvgy1sNMfzbvBEaKQEBtYpmOPStXjn+OLqfEpUfTWrJFiUqJLNvv7xdZw7sQINViXLAgm6Ms5dj7Cvdq6HsQY/DxCdNWJbkrkW53+mvTxOc6aHpaWtQCBkX4Z545llhGY/XpTp78Yx/xhMaaBQFMRXVj9p7rr1ebgaapQMZJMWeOOqGtTVHjaEtTDnh/5QY+tPUG1ofWsND5xvermyXE4AfT9E1NDo5KOFhkTSaV2XTvXrXGfT5lMozFlD8hGlVhCImEZFVlNx4tHY1WVsaKFW7q5uq8+qIVKTRa+g2C0oErvdqFUAvO71eLprx84jFqc/4do+ljSPs8hK1mzLGZ6AxOJyxapAjb41Hi4GiM1nOSScUdJiOG4vk+3vlZu1I+ChrGKb5CqO+aFkKoKEdQ7Kq7W01sjrHhQgi+03gt1+z4Dvcc9603vDT+7FCgk7lxhpKSbAyR261EotFoaVHWIyHU4ohEsuEFAA89pMKZt2yWPPqsnaaO9Hf6/Vit8J4P2Viy2saqNRqDehEvvjr2YRUVKXG5tnbyChZCt6HN/Q7G3i8j42NtwjPhDKAIorxcEYKUStfJiE7FxYo7SqnmYtr1aLennQi5LYlkUs3lwMBYo4FhQEe7ZPjh55T56ZFHVPJ5jiizFnF15Qa+2/zrnK85XJgdnMEII7Tpu8tomhJ5MguipUXtmgfX18roEeVlkiVz/OgBCV4v/f0i/WAFiaSgrdfO3LIQpnTRVrMZrE4zoIhgusICk4nQwlqJ1nAjxu5r0Rq+ibDnVvtoMhiGsh4Fg4oI3W4VlDg8rLLiPvnJw98fYf/+rEU5GlXGAinh/vth3+4UWmsZFywM0VgypE5uaFBsU8qJZddRuKh0HY/0P8dLw1s53vvGNbOYFcQgjRhMUqXu+eeVbOzzKcue06kW4W23qRBlTYOPflSFJNfVKbFoaEjt3ku87YiONKsoLGTx4lpefBEkgqTVidkRQy8uhMICQD3wtWvVfUtKxpdJnIn+KOxz0eb/J8a+ryHcq0mVvRd9VHmZF15QDkCfT+VITBUTNDSUzS+IxVRhg3BYEW9bm9KNDq6c19enzikuzopY0agKZ7JYpq7NZBhjXSsZ067fn2YCmoahmXmts0QRQ0GBUlw6Oth1wMHWgUpKFxdzyimTM6Jvzvs0H9z6de4+7uY3rM3W7BCTZBzE+JLavb0qIDMWU4rwS+m04/7+bBVtw1AeZ1Ai0KuvqgewdCmIA23IA63Itj3I9p2cfMIwl12m/AuLl+rYfA6e3u6jeX92mk47TZlf3/WuQyvmNRrCUoq24GdgLWdw58fxRPdhDD/P8GCUO+9U5t2tW7NlLCfDwdXGR4tEuj6+el53t+IkbW3Zyh+xmCKqUEhtGFPlCx2ssLvdSmzKBNEiNGRlJanScppLT8BYthz6+ujzm/nL82Xs2WXw7LNKP5sMXrOLa2vfw817ZxocdeiYFZwBmYIJSsNMtRNbLFnPcXm5ylG+4w71vrkZCp3dLO/egkyY0Uxm8AeR+75ORSpAZcMZ7B1+FzvaVJTe4KBaYJNVxXg9EEIgii8m5FiNt+VXENxErO33pPovUtzQ5CU8YEEmyxCmiWtCZkKre3oUB3jnO5Xe2tEBxx+fXbgZ69boioKZID2TSRFCxlXgdoNZT8ubE2zfNTXqPrquOEs4rE676CLl6OvuNhPVK3jmAHS9BCcXOghGokoMNatnOaEzcxRO963hb71P8ezgZk4pXD7TqZ0xZgkxGDCBI6agQIUMbN+uFuvxx6vd/4EH1OLw+dTx88/P7kKlpbB8WYREqIfO5FISgRgWM5Q1lGJq/ADSiCMH/kGs5XZk+GyEvRGEPmU17sOBUCqCy1aFVvUhSqvggvfAQ3+LUeDqZ8PpT2DsexZSIYTnJETJOxGWrCK0dUuKrkd3UKQP0b7LR80HFnLBBdrI7u73q42guVn5y04/XRGOlIponE61cWzcqDiCEOC0p1gwN22eywRhjYKmZUX/0Va84mJVSeSPf8x+3tEBnDCfalsHVW0W2oMebDblB5oOX537UT742g2s8nwbm36IDTdyxOwgBuBgp1tXVzZJ//zzs5ajp55SD9npVLtdJnDyuONUhIDXE8Wq9RDRF7PDGEYfbiUpTXR3FLPSvhvhciIqLqT+NOh8bDfhwScoq5tPcfFYM+jhRsSIYRulF21YeYCTrd34igTmhReD80qkkUAOP4PR/HWwlKHVXIcwefHv6qZEV5WQvYk+/Ht7KViQjRNqbVWiYyqlLGannKIWYiSiFrTJpHQOkykbFb6/ReKyCyorJCKVmtJakCl5mUox0hy+vDxbbK28HNB1THU1vPuTitO63bmJmR6Tiw9Vv53/av0/Pl///kOa21wxi4hhrNlx376sSW/v3iwxeL3ZXJbRRguHA77yFWh/6ReYqq5m206dgZSP+1/00dUS4SsXbqapS7JwYR9oGs7ycs66qJFEtAxT+zehcx6y8hMIIUil1OIxDCVSTNUtJ1ckjCQWTT2OqD/ObT+SdPZXU+hO8ukPtONd04jQzIjC9VC4Hul/GaPp02g11+FwVdHXr5hnSTF4CwVmc7ZPW1+fWoCQjbh1RvtxNu1UHyxZgtvtpaBAiS6dncrn0dMrmFsvOfnkrC5hMinjwWjaEELNQUYME0LVh927VxHK6DpPuj5t9fxxuKB4Lb/reoQD0W6qbWUjqd8Ox+tyeo/D7FCghQDGlqUYrTSOfn3ppSqIb/FildA+Gnr4eWqqgvhK3Pj9Smzo6IA5pVEsZklPT1rPSJtHNA2sDi/avO+B7sbY83mkERuJyzMMtUgy4sDgoIpq3rlz5t1pDIyRmJxtOzQ6+9WPGgyYeGXn+Br6wroMreCbGPvu5r5HouwNlOKPWugW5VirSkYWqMOhrF6LFikR8T3vUeIjW7eqFRUKwbZt6LoyDpx4Yjq5x2HQlxjmiV1d3NryW/6+ayfbB9toHwrQ1zfeHyLE2FwjXVcO6Hnz1Jy2tioL6+gg11whhODLDR/i1uY7icfhnntUwbY77pi8ZcChYEacQUpJMBjEfZB5or29naqqqkmuOhzQlN4wCosXK6VYyrEtCrxeuOwy9ZwPLusiu+5Ca/gmdpOyGOm62jWDwx4G4w5KnWFMVn1c42chBKL8KgxrDcauzyIrfwKMlV+TSWWpyhCBYeQUo5b9DsRITL+3yKR+SDAEukZho2/syYkEbNyIiMchdQnWod28IlcjzAupdsI5B+2WHg9cd91BXzjaU5Z+bTKBVjjAi6bN+Hud1JpKWGqNsb67mj5hkJD99Bnt3O7vQA8NclXlhdTYJnG1j0Jv79hatSOcIpGYODhsAix01qMJjUe3dNLRUQGoZ7dly/QF3nJFzsTw+OOPc+WVVxKPx1m5ciV33303lemwzA0bNvDqwdV6DyeErixKo+BwKD1gIrS0qI1PShUqs3AhyGib8mKbihkcVNzk1FOVQvnggzr9gWWcsC6EVmeb9AFphadjaFasHV8mVXYLhjRhtyuiGhXFDcx8xzILEwmpbjBvHrzzShvbt9uoq4OVBxcuCAZHVpeua5x+UiX3PLIJCtexdm2OIQyLFinLQyYBGniw52l+3/kYnz7rSmxdjciW/SzwDmMWNjx9LYRdZczRLJxceiKbCgb41r5f4sXO54ouodRRDC4Xkmx4SgZZupNYRRxCSRXeOzSkNp7TTsupNPpn51zJd559iHl8aOSzqRrPzBQ5E8O///u/869//YvGxkZuvfVWTj/9dJ555hlKS0uPfJbSBMQwFfbuTcuvSJr3wcKFAtl3P6LkHSQSyqYOavdublacpaREw1fmRprGx8fGYmp3kxKKik7CVhbG3f8VZN136O0V9PUpObiiIi1vC/VsW1uVCTIXudaqW4iNSv45+eRs7adxyFgH0tS37uJSqk6IYovdRvUJ1+Y2SWVlY5JxftH2JzzxEm6t/iomXcc9P4X+3COwYwjcbsxFRbgfuhcRjSAuuogTzz2XE71L6WvZxtb2V+g0e5hTcDy9kcKR22d0tpISxRHcIoTHkYDe4ay5trdXado5dFBpcFQjy9tYdnKA/v1uqqtzb0CZC3ImhmQyycL0DvKlL30JIQTnnXceTz311GHN0poIQpiRMveqcQ4H6EacOYUBbDYBUQcy8DJa1cfRRtFUZ6cKuQclcp12mpKnDw5o6+2FRHs3va91s1Gv4sQLzsTn6KN91w6CxmI0TYllS5YoRf6hh5SCb7OpKhwrVkw/ZrtmJZzKsUGyxaJu2t8PDgeiqIh5ZaWkdt01kh67davikAUFSiScqg3wXR0PEIkneWfhqYDAMCDx3Mvomzdn++Ru3oyWKbn3xz+SWn8WDz4k6GkqZ+3xXiwVbTzV2kp5gQmvyU1vb5YY7Haoq5UwlH6GmqYeUqYXWI6iEsDl5eey2/Mgn1p7Rc7X5IqcFeji4mLuueceomk//Be/+EVOOukkLrjgAvx+/2Ef2BgI04w4w6plCRZ4OvDgp0TrR/r7wFSEQMdEksICA2vMT7J3EJOMjdRBGq0Mj8QmAFpvN+JvD6C99ALznvglL/34GfqNSwhG3PT3JensVA6oTMWOTAhOJKK4Qy5wmxwED6rNaviDyKeeUk6SgxUgh0OxnVGdC7XqT2N03E5/v1Lio4EEXfuj7Noy9r5SqnHt2AH/atvBs4Ob+MScyxjNEzWLSRFBW5vSfA1Dre7CQhCCvz0g+dP9Gs9ttvOjO70UJqqYW1DHy8PbaY92j/XTpVLZmjowUg3NKCgktWiJYqk5Yr1vDU8Nbsz5/JkgZ87wi1/8gmuuuQaTycQVVyiqvO2227jhhhu49dZbj8jgRiBMOXGGTNaXNdBHhW14ZMeRwWGE+2S1OqXEFg5j69rLfKHTOVxNyluK3anj86V30AMHoK8PiUDUzsEX76QtJikKtuCO9WHZH0b8rZfhJRuIRg0MKenvF8Ri2dzijM5wkC4+KTy6i+GkCjCSEqIRiXbnb9AG+tFNoPX3KwVnqmlyLIB4L6lEAFJ2SCixS4bjEGGE5e3fr2qKxY0E/xzq4+aLPofZLEacbybNwLx0gQrE2rpVJWmceCL7f/AH/rB/Dcm5C0g2mTEMkBYHESNJn8nC3AYb9q7VPND7JAPmJhpYly7TkeYAPt+IPTRat5A+9yKkBM9wlotkao9NVnXErJkotRTSFeujHLf6IamUknUPTuqYIXImhrq6Oh544IFxn994441cf/31r2sQ00KYYQpiCIfh979XXtXGRrjoJDPa0JCSU2w2DPkiWul5o0rFpMBmIzpgUFUQwD3fTc1CJ1abQJdJop2DtMUqSEqd4v1hShqqqFrTTqR7OyQEmtOGe6gVhI6UBpHAEBZHIclkNjizo2Nss0RQIn40miWY0Q/boduIpMUkw4BkMErEcBGYswB7zE/5gfac2Lgo3kBx6q/Mq7uUlj3gdaeYXxsDIysnZYL6Ngd2scK5CD2hIvWsVrDqabNYIKAiG9/5zpFIvr8sW8RAqYHbqzO/QYmCiYRgwUIzNfPMWCzQUGfi07Wn84Wm/0TrTvDO2KhsoOHhkXKH/p7swu/vT3u9ndm08kzNqokC+U4rXMnTgxu5rLM4m8Tu9yvifR3IWUxKJpNcd911PPTQQyOfXXbZZVx33XXYJ8saOVzQzGBMTgwbN2aLiTU1weD+YfUAE4m0e3QT2Ed5kG02BgImXmirwFlXhsVpRksl0GUSWlro9VtIxFJIKemNe0hYnTjWn0DB4ko8RWbqnL3Y6sqxWCAcMZNKxigr6sPjUczo+ONVyudJJ6UXfFcXsmkX/vYAsagkEhnfY2G03iUExDQ7vfUnErN6GfbWMNg4jf2wtxeamhDhRciBJ1hxvJl3vC3MGceHsDn0MYpQRQUEjRCRVJT5xcVjA/n27VO7bVubUmz371c2TL8/7UzQKS5WHO+rX4Vrr4VrPhbH4u9T1iEp0Xv6+P5DGsYt36Gzd1QuwyiLUWaRx+PqMQ0PZ73kkN4QJvHVHO9dwiv+7WNDZw/uWXwIyJkYvvrVr9Ld3c2aUeUJf/rTn9LZ2clXv/rV1zWIaSFMICf3Yo2N1ZdYjJgihsLCtGvUQOjpJgxmM9LpYrh8AZWLC3EUmIlEBZ1dMNgVhVAIzW4dMQkJux0RjUBvL3pDHeblS9Aa56MtWsjqRWFOPy3JOW8TrCr8Mgd7yQG1w/b2YiSSyHgcYuoBZh766JKkEvVGkykc1hTa3Hqoq0fMn0eqcQqnRTCoTGiDgyokPViAlFFl4vL5xhVGLSqCZyt+zTnHVbBkyag12t+vQn8HB5WcFwwq8+vmzfDSS1x8Urcqh58uKlBYCPPqk7hIR/5Fo+qaX/8abWcTbw/MYdPt3yRgkep5jJIZCwuzHuSMB//gSNnJ7DK1tkpao92Kc2VOqq9/3e7onMWkBx98kFdeeQXzKM2/vLycO+64g+OPP55vfetbr2sgU2IaMWn1arV59fbCihUCa4EXGRpCANJjh+H0rpgOOIuEweNJYImFsVhMWJJhYnjY1WJhpUVSag/Q3m9DM9uY7/JjiqTlikRipOBvtDfA1uZBEILFJ3sQrtXIwUcQvoPk+rTiq8kUeipBOKlDTIkExqhi2qKrkzOeOAC23VBXh90mqKwUdJkLMZunyVQ7KIpQmBuRwY0Iy6psbIrVSr+hlF/dE2B4dwXdRiX/2K4SotxucG3agS2ZRGRKBlosYxR3X6qP449X4RADA2pMHnMczQBIByVlShmi5PsTjUo+1/9rfr70BqWeJ5MYQkfXBUVFikNkxLZMHkUyqR7VZAlJI1y0okJRtmEclpiYnIlB1/UxhJCBw+HAMpXd7nBAWKYkBpNJNfsOBtNljGQlSVcBDocAOiAytkp1KgXmVBTdLonGkuihYYa6DHxPPIRm6+TBoVN5RTYgnHYuWOPnhNphteuUlqon5nTybFMlg0EzSEng6QTrz7qCROtX0T1noJtGzZPHo/78fhImG7rFBJri6iPTGY8jD7Qzd38Io7cXzW5HlJfj9YDLO2VJVQWvV1FXKARmM6JqETK4BWzZZtdte2J8/zcG0biO57QdzDdOBLu6NBxWlyc1E0mTDbM1qVZkJuArTRDDWuGIUS8cTleLcSbQkimEKV2PyuFQesbtt0Mqhe+Kj9DoamFb/3Ya46V0tMTZ+KrEXFvJRRs0CtwprDKOtNhwOMVIoN90sAgTcSNxWNdezsTgdrvZs2cP8+bNG/P5rl270I90l27NDFNUo8tgxCwqBEmLExwgh/sQlhJCIRXaPTCgjCNrFutoGjhlkOHBMFpTK6WmQbDbefnlAoxaA1KCl3YXcELsafqf2k57shTL2esorKknGMsG2YRiZvr9OiHz9Wj79lJWtzBr1xcCamuRKQkDYkQuHWMpjcchGsWqmYm3NmPLOMOEmNIxOzysRHuTSadu3hKsMoawWsAIIFv+AOaU+sFCsG9fAbGEhpTw4KMJbnxHKUZCSVKZHThWMx9TPIpZeNUk1ddnm6FYrRQUVLB/iyJkkwncfc0Yrb0YNhO6WVeOFpMJli8n+p0f8o9HINBu4vzSKHHTJoKhYqxOE3PrYzzwTIhTVur4XnsCRyikBrJ2bc4d34sthfQnhqiw5miuywE56wxf/vKXedvb3sZdd91FU1MTO3bs4K677uL888/nS1/60mEb0IQQFpXtNg0mDN5LDoOpgFdeyXb13LoVAkk7TTsNHn5I8q/99SxcacfrhZ6Qk+ahArbvtTI8DAVlNlp2RrhXXMHjqXU89lCC9gE7VXPt6ktsNhrma4RjOsJWjRHpwD80notpuhjjzBvT9cbpQOvvwaZZCLU0qYOZYq6TwDCUON/fr8LZd+/RSJhUbIgwF6iKIrt3j+S5yq4eDEOQlEmshSHOOT7MispuiuxhSkoUzRoFRehnnq5MuJnqamYzsrQM6XDgtsSYM0dJivPngzkWREZjyGeegzvvBClHdKAnnjGxc7eJ9nZ4+G8WnEYRMalc/1JK4ikd04GWbOReX5/6ITnCa8qaog8XcuYM559/Pj/72c+4+eabueaaaxBCcPzxx3Pbbbdx7rnnHtZBjYNmzYkz2O1qDWVEaMMgXXPJOSJmGIZ68G0HBLf/voT21iTH9f8L70o/Z51ezZ+2zaOszk5n3EIsphJVnr7rVFJeN7gh4Q/Q3ydZsdLJgpUgkgmsFoPOPhMSDexz0YJPgvc0JbfpuhKTNA2XK2tSzRCCWu8avOMdbK0fIlK6kFOmaj6SRqaUfGbxhULK4FNUlBapJGMsLCccJ+j0RrEbW7l6XhDPUBsen4ZhDBIz1SMtOrb+DjRsUFpKLAaJuMTwRxDRCCZhYO7dj9U7F0uRSdVsCgQRzXugdT+4XIRjOv6MpbNtCGNYQzidpHSNQmsVzckt+AYb2LzPy3nvsOEZSoeylpWNmMFzhUO3EUrm6LHPETkTw/bt2/nSl77Erl27WLduHbfffvsRjlTNQgiNg0O4J0NiMICMJYk5PSSTOg4ZA62Q449Xtv+eHrU2e3vVgjqp448sDz2L9XnoksV0VV2KJSWoNVLYTEksiST2hnJEUxyrZlA/x0Sj3EnP3irqlnlwFphVvFPaPl5YWIO752ZkTwMiM71SjmjAk272moatoppeLbeUOrNZ9SppbVW3N5tVeImUaaNNxuSzfz8IgWNhLVeW7mF7fzNleDD8ATS7Da2rC/vOHWlFSgnryRVriPuqaG0VVHskQkAyBVLYccUHCdhKkBL6tBJKAptIltcSXHkC0aASw8z7d7OsJMn+5nKiQ0GOX++itNzBf+/ZxBUNTt7fWAHbn1axMMGgouQrrxzjTZ8OFmEmMYMQnVyQMzF84hOf4CMf+Qhnnnkmd911F5///Of5v//7v8M6mKmRg9msvx9TexcSMPn7iVXNTe+MAqsVzlkbYbArzr4uBwnMNDZCxasHMJvTOb/+Po47I0pTixUZibHhzDBePUV5sYNgqgBnfIBq2cNPf1lMyIhQ0Ojm+usFra1qE/b5ADSo+gKyazvClQ6rzTG5odDsGVt8t79fyXVlZRNq0A0NSqdvbs5ym2BwlAVz3jyorGQ4qPPIExZWyC62R8w8tmshJzUMUecZpEQPKxGlsxO5ciVSN2MMDIKvingoQdhmwmGAjKdIDQcoWOzB5oZYxCCcTDG4bB3oJiw2MVLmXk9EqG708rH6IaKBJN6FOoGAi3fJy4l29hItBc3iRC8uQ8/8rtEVvHOASegkZxCik9M9cz1xaGiIT33qUwDcfPPNLD249PWxgEAATYOUASIewywSKv1LGhAO4xjuxkhJ5toH2RutZOVKCyJ0PKVPt2K3Q3z+EuoX2bj0shhicBghwB8UDPSmaGmBRZYB2mOCUFQHkWBoSIUNZaIMDEOtXemdh+RppBFWjQ5zDBPwmb1sCaR7r23dqurggFrUa9dO2DPL6VR/Gf/TuJBmh4P/u1txkIinnE177RTYHTzZVsimoJUPLWpB1zSkyUykbhHCYsHwqNiI4lJBZDBBYCiJTYaprLZBQQE6YG/fQyySwmxOoBkJLD4vTnuM4eY+7CUesOgIqwndoiNtNoYGwC1thF1eYroDW3EJSd2E5h9EFBe/7lCKw4GciWG0WVUIceTNqeOQg3fR6cQUCqEZIC0WLC4TMm4FGUNEI1gsEldyiERcx9MdxrWwmsU3rUW21tLTHCJaUEa93k6iNY5ZSyF0HePAILbmOKbEcvb5vZw0L4HDoxMeTiJENso1I79nSqWImrUYHb9Bn/v1KRXhVEpFl0oJBWUF9MWH1IHRrTZ37VLOAF1X1DYqliNtrGJ4OKueHDxfmdCgnf5KXhqM8rYqHxFdx3DpaLZXIaWRuPgSTAVu0DQ0zQARp8QRIbxzJ6ZEBKO0nKCpCK8hCYYE27bYScaSWD0pKpxB7G4nbH0VbzCGVlGGodsxbA4sPi/CmtYxzGZ0QyclDfAWgK8Iijwwp2ZmPXRJZwYe5kTNnInh4JyFIx22PR45fF9JCVitaImEMqDrGlJzKsuKy06qvQe6uig0JMWxbsyRehBnIGrnUKx1ICNDaNEwxAWplIH2/DMk+gXV/THithC9i9djNg1x1mlxBpuHWHqGibmNlQwPpwPc0glqug6aaz4pk0SGN6mCw5Pg5Zez7bgKuovoKxhSb3y+rMNsdCnxjKdu1Pxn6sZOhnXrVFi5lOA44wXmuBqIx+Gss5yImsuhowMhdaQQqriyBDE0QPAfz2Ma6MY6p4xUV4JAFDrjZnZ3ewgmvRAL44nFsVekuVU0ip5KICNRNJMJzePE5LJBumi332+mO+wHPYrTVYVu1hC++umf6wRIyhRm7fCa9HMmhm3bttEwKrO7vb2dhoYGpJQIIdg3g3qah4aJOcOBA2rjLCpSmW9iVOm5YBD6e2twsJ1I1MGB7hrmdm/HMdiBTMYwN2TjlUTAD2blcTUMMIZUebiiomIcHtAK/bhqEtCjUVqUYnlRkEpfHJyVI5UhbLaxTECr+TeM3Z9FW3QHgoMy6NMVBQYGRo130ELYnQ53XbtWbfOJhLL5j9x0Eg/c3r1KEZ0/H2nVlNc+jVNPVSmoUsJnD7zG+4+7MlswqWMQBgYwmUykzFakbkZLxQl1+Qn3BCk0KblcYGCNBxkIJfG4DBy1NsLtEaz+XjCU8xGrFT0WQ/Z1gaMW4clm7Ltc4Ap0ws4XeD65j7kXfBFhOvSdPSlTmCaopfV6kPPddmWyYI4WhAl5UPee4WH4y1+yzjYhsqmgoZAKs0nGqoiFvRRVwHDSxb7Sk1mYfIxu33zMzmqK+yM4i+z0R5xYkikCIQ/dvTo7XrZwacNiHP4enE6Beb6bQZeZVL8JkUrgZRjKlwGTWwSFuRBRchmEmsA5KraoqUlVDgAWOJawBaV/jQnrN5uzbWqlzMphE/XZ3bhR1aME1UttwwlgGZsjUFio6Mp1YBkbB4aYt+WPuKN96r6LFyNMJkwuVzYEI2YBjwfdiKCbBVqBG2mzonld+EjS3w817iFKB/bDAZt6CAsXqoeSMhAOu5LPfL505GEMHn6Y0niMoqEDiNKXVM2aQ0TMiB/2Kt05E0PtwcU632iYCiA5NKYXtN8/toDV6JZUw8PpY7oDKUPE48piFDM8dDaeQdzswJSE0AETxSnY2uUjFEjRM2QlEhE4fEEOVJ9MY0EvWCxYyspYXGEiWFmGY6gTm29NThYQUXwxcugpSA4jTOmg/c2blTNMCOrlNuynL0XKNDG8NtFNpolRyBQoSv9w2b0PoS0hFkxgcZpHaOe116CmeykHBnvoG57P2al9iP5+VUS2sFARmscDhoG7voF443FE25sRdoEpGcUqkxSHW9HicQpNOklrBJctqWTEQABMJgZFIcRCWOJx7JYI2r33KmNAOtTVZLcrnSETkJQrWlvV+NI+mJgRxyKOEjEcdZiLIDEwhhjKytQc9/WpeRotTWRk91TKjEn2YbFUYrFAWZlGuFMnnjCIajasmplITwCfJYLusqFpCaJRaLS047ZC3OIkUVyBo6oEiwl8ZRZw+BSldXUpCpsiK10IAc6lyMArULBe9WAIh0e8ZSIRH8MR3CYngWQIt2kGme41Ndm2nS4XxODl5pX0BmOYC3Qa5moUFUEoKCmSdtAFUWkllQSTzaa4gd+vZKlMNxIDCmwgvHPQujoQEYGIp3AMdZJICHSTjiMWRGoa8e5B5GAIk2ZmqHQVPlMKk5EgubsV8eSzJDFh7WtCi0ahsZGkLmaWvHzfffBougHiJZfAeecRMxJYtcNrxJk1xCDMxchE3xg12mKBd53RS/f+KN56H+4y50iRHqcQHL9iDgMBM+7ee7AsXAaGxBxP4ZcWgp1mDKFjtUKJOUy/1DDp4HUbuPQYBXaJxwVxw0TK0PAHwFMAoqVFsZ2uLoyURDPrKsl4VFhphltl9Adh8SGNEMaBH6PXXKfiGfr6FEEc1J29xlZOa7SLJa4pytQnk8p7mAnQW75cfX8wCAUF9O3fTo/fixSKW8bi6rCvSJDam4KiMuaINkyUKmdFYaHiCPPmEY2qn5eptCctVmQ8gYhEIBZDS6WwxmOABQo97EtVYt/4IIYWxdW9EdNyF8bcUvTIENJigupqtMf/RSoWQUsl4fLL+R17eVvGYRuPK5FRSmUxm8hK+a9/ZV8/8QScdx5RI37Yy03OGmLAUgrxg2JXurowb9tKNcAOExScrFhyOifbFQziWr6cZFwHcxQhLKQSYHdqOFN+dnW60Rx2HPOszKsKsLvHDJpOSYOL6pSJ4HASs0XAzq1oRhJ58ipEIkEylmJ3tJ4wdjypEHO7e9DSxBAMZk2ZhYXZCtha8cWk9nwBGXwVsXy5Mp2aTCNKTjCohl0v57EvfGByYkgm4e67VYSe1ao6t1dXZ6tLhMNY2vwgzKTQkWSD/ZxO6F/xFG+3n0W1VgmmOdm0u7IyQiFVnjNTlv6008DhMEFZCSIeVc6U3t6RKENps9MzYKZKaiAhGtfxmYMYopiExYnQzOhr1iC6uqGnW+0Sf/gDRe+0Z3N0779fVWMAJQq9a4J+bhUV2X7T6ZZIkVQUh3YYShmOwqwhBmEpRw4/N/bDjOkRsr2aQiG6hm209LkoG0pRvxw053yMRCfYGtCsZiI9UR59yUvc5KBtGBx2LwtqTCwrSaK5bZhsJkjOJ9oWQfvr/2Le+AomI45o2gyXXkrY7iOctg75DRdDmgPfqCFJCeb+LmLN/biXlo+EGWh1X8do+iTavNuUrN7aCoODhM+8iJ07VShDQWIZuxJPQikTo6MjuzBiMaU8j25R5HDgdj/JslUXsL/TgjkoiESUl3rvXvCdVkBn36tUt6XjNpYvH3FOZAIZQW3YPT1q6PaCEuVnyuRz7NwJZjMBw05X0odT91Hsb4ZCLyxdiiUVRYtoMDCEsFnRTj8VLRCAbVtB17m6qzrbMXG0vjP69Wh8+tPKNpyJ1UfVprXrr7MnwEGYNcSApRwZ7xz7WXFxVla2WsHjYdBVzV8etajG3f1uzmuGuqJliMGHEZWfRNhtRBxWNI8gs6+0tgmGhl3EYoqmysqgtNRM3GTGvmM3mgaaBLl7DwmzHSHDyoRkMoPNil6m5HvDUJufpXU3vt0vKLFga2ikMrI40IfgfRgPfw19d8VI69hkdx+aKCElBQUmNx1DU9Rg9HjG1Ew62MEgZRK0CLWNNqoa1IL+/e+V+TmRgOX+Kmw7vwfONOfp74eODqTbg+f0dwLO9H2EqrARhcpYMyut2zGbIVZUSWz5OswDXWx90k+dd4jCOg/J5kLMLgc4HCSshZg69mOJBtGMBBR4AQnHHYf0eHA9/zJ0Pq2+v7Q0W+t/soaIhYXjaoUa0hjT3OVwYBYRQxnEe8Z+VlysEo5DIbWFmc30exowimKAAIuFnh6oK52HaP4zWnwf1NRQVm7G61WycUZKSCbVppuxYCYTBgUeSaxxGfqmZ9FMJpLzFqH19aF3D+BL+gg7KyioMuF9/mHo6yNx0jrchTXY+vaiyRRaIqqo4x//UOOMRDAMD02hDYS9NoobSqkrDuLwmigxS7oOJLCYdQKplqwYcTAKCuDd71ZydknJ+EpjsU6wVoz0agcVzREMqpi9qkGN/viQWvPJJPKhhzCqa5F9QxRUvcSZp68lFtcYHIYtW5SG5h5uI+hIZ492tkPjMpJdvVQsLMNOGJevlrDHjt7Via1jL4lFxyEcTkTGQajrKqowHidu1jA93Qu4lJUsHFZNqzMDPYqYNcQghD6u3iowrr9tZSXYvVYiEfUM6utBNO1D+h1IrQMRi6E3LuLSS5UxyOuFvj5Jx+4wUb8Jh9eMMFIkY5AIJwlfcCn6cUvAIvFXL8T92vOApJpWzIke2BZWfgPA9KffY3vbBkxm5aQS0shG0Pn9YDbTGS0g6KxDRrbQYxThszvxelxU9OzGvmMHzt4Wrjb3EOz9Pa4LL5nYpNrQMLa09SjIaCvCVouR9lG63WrPcLnUbz3xysW89F8mUhjoViuG2apiGS0WtOpKHP4unJqGo6SYLel6slGzB5MpgEAiHU6ELjBVlFIYSRCJ2pBRDWe5F0eiE1FWgm4TQEyZ9/r7FSdbtAjcbp7ve5HKVythf1DNS23tNP10J8ZMm0HmgllDDIAqzWIkEFM4WxwOuPxyFeJQVJiiIKBqIKEXkowP8+LWeob2KekiU3zYPXQAw4gwaC4A4USXOuZUEitJXIkAnjPXqDyIfknSW4R5sAfdiIG7RMnt6TZBukxibm4iYDjRbcUYMorHGEavLFcPvaMDgQSnGzxzkVoCUV0JoWFMe3dRPLQXhvuocTsIOu1Yh0OIggJ0fZK0z4EBpTOYTMoSIyWEm8E2R4WEaNkCyAsXZnKG3HR+8r285Hdy0oJzYOMWePIp+r0N9HV6cTg0Kr1BbEN7WLOykQOtBs6aubhtystsVNRh1RLoxR4cyRjOWBJRXYfJPwjL5ymKMwylWwwMqPdprg3w+NArXP6Jj8Jz6RqgZ5+tfksm9W+GMUqHE7OLGGw1EGsD+8S7YgYOR7oy95ZtadtiDJHyciBgMEQBhqFUDasVlsyNYO3ppNEZZv6CHtqG3SQLylRN0EQKmYqTjCjnVVGxIHnSSsztLRjxBCmbHVM4jNA0jJRBt1FCLODBbNXQ3aW0zV1DQ0UYnzWEsNuhpIQKQxA6YCU0WE6R8Shu2/kwEFVWmrTZp7Cqkf6iIjCZRqr9jQ7zaHmln3gC5rU9jhaNKFHsqafSBQ92ID70hZF0ZGMUc8rggtpzuaX5Dk7yXIpxymm0Vp/GX37jx/oPP4tX2xjosbE69CI1F1RT44gq2THmgLIyHGZzVl/RrZgzWXklPlUr/skns2W/q6pob4e9zymxf/ESg23BfSya+wm4eJSfIaOsgXooObQmnUnP7Fwxq4hB2OciI3sR0xADoDTHTZvUzuTxgHSii5cgvIFwMJ12HEoSfm0vVrOEeBxhlsyZI2Chj/6dvVi3voBIJog3N2G5+Cz0p55C7+kh2LAUzUihGwOEbEW4hOC17jJ6vfOoihjEk2C4VEcPSyIErbtHirnq8+axwHMAXAYy7EG2P41oOFvJ/vv3w5w5WItL6PBAqdOBYCxXeOKuFp56Ur1eZCnk0pMjyoQ1PKzY3UA/7AlAcbYA8sGojlpZ1qPh9+ylNzqXoSHojbiwDod54eFhPOYIqy8tyZa1y7TYefZZwmYP0doFRFIWiosFVrdJUVpnpyIEUN71n/yE0Gnn8s+uk0mkTaAbgztZW7lybJBnJtQkg0RiWmKIGwnM2uFfurOLGByNyrzqO2f8Qb9frXCfT+2yd9+txKNYDNavRyxcSKV4gEDEz+5mD4WFUOSOo7f2Is0xhNejtq8FC0hJjf2v9uFpT1LoSuFIDcA99yB37EDOnYf9uX8izVZi3lKkZsIYGCJUvIS9w+X09wkKalzML9KYXzyAKzqY9l6lK5zNm5cVCex14H8YOBujeg6yohq9wI0GdHU9SUeslxp7mdI94knQNLZtTkHarLsjUIUhO9DSFTsAVSPKO0UIa1jpOBfKhbRsfxa31w16KcuO03j11XLsrjCnnhqAGouK33C7lZ1/aAipm2h/oR396d1EsdNbWM6KT6XjizLl7wxDKWOJBDz5BPO6drKj/gJkRTkPtWziZ2sunuDBimzNnBzEpP7EED6zd9rzZopZRQw4FiI77xz/eWurKokIyi6aMT0WFCjboMcDjY1oA+eyKHE/lXOuoqMDLDu2YevZg3BaoL8PzlFEtvF3u9m3M8FKewqMFCYZVwRWUoqIxRCpFFJGMQ33k/IUohlJFpu2s8dcQdRaROOcMLUlMt1wyMhWH/Z61YNPm7KEZsawDpHY9DyhR7eyfz/s8axk4XtWc1zDPH64/y5+uOALEI6MLJbKOgsDm5WLu6LBgXb5u9Q9N29G7t2N1AqUsjoZolGQkkprCTtCzZTbhhhIlKqKIWugpsaBfWAQdqTzSYeHs4QmBObAAJ7WrfTuD+OzAyfblb5SWAgf+pAKmwiFoLYWe3Mzxb19YFnOUE8T6z5VjNecTuJ59VVl7y0tzSYu5Vgnpjc+SKllCoI/RMwqYhC6E1Lh8QdGl7ru7lbl2jNx1U6n0iCFQBScjrHr0xQuukpVc9vZiWW4D6LpylWpFPzylwSeEAwEqvCvcGG3GDiqXZgbauHZ58BhR+o2RDyGHg9jDqbA4aCgwMx7F+wkUVqBtaIYoenK3uH1IqqrlaiRaW9ZUABuNxJB+67zCbzUR6i3EC0xSE3/Zv7619V88YuV9MUHCSaCuGRWrLjw/T7KHhkinoDjLygFW3rxnHACLPVBz/6pJ9HjAbsdEQiwKlLIP5ru4p0XfgNDM6noWymVHTbTwM3lUgvUZkPs2kWxK8rgUBy7R6ei3q6y8axWNcfHH6/+HnwQXn4ZLRykocggZfojraHXOHvB/WoMnZ2qczuoTaawUBFUKqX+JrUYpC+P9VFuyT1fOlfMKmIAwORBJoZUOZQMPB4lEoFi1zU1cNVVylNbU6O4hWEgNCuIYmS0DautBpYthD07lChVXKxctP/3fywxVdJsu5TWQQ/Fi+zYSnV131WroKwU0duLDAQxCooZxo1VRjCl4iQNHWswgBjUoKREycYlJcpDHI+rXbOvTzWdW7GCzg7Y17UUKV5juKCa0tCrJDCPSAqXlZ3D73v+yQd854yIVmanlZMvm7gQgwzvQDgXTngsO38m1RH+zjvxdXRQO7iTttT/kFz5afbskczz9FD1z/uxhIcRVquqxl1ZqRboBRfgOs2Ps/cWRDgEdrOat927lcMsI+tfcIEKxHvhBYafeIjBnqdYe8plaJa07pGp2pFpMRqNZouuZsY4RSvQtmgXc0fXzj1MmHXEIFzLkcFNqutlBkuWqMmLRpUZSdeVnFtRodj8z3+uFqHVilbTgNz3G8R5X1QP8AMfUDJuNAovvgipFKV9W3hvcT/B/gbcnQuJr7oQi9OCmDtXJc5bLCQ9RewOV1C69XGCQ0GEriHcTiJRDU+NF2t5OZhMxFM6qQhYX30ZEQwqEenZZxFVVUQiJQjNjCwMYtfLGI7Po921gHdsUBvjhSVreffmL/L+yovQUka2x+wkkKHtaMXvGPthpuXnaG06lSLR1kWgchENc47jpWAvvqEk5WUafX1WApblzNn7MDI+jM3qxZu5Ll0nSlSUK86h62phO53jZf3aWp6wdeB8qJ0T98TQtvwCdu2D//xPFUc1NKQMBhaLEpMy0Y1DQ8r4MW8eHNQ7MIOWSAdn+g7u7fX6MfuIwb0KY+ARKFyf/VDXx8Zvj8Zzzyl7t9+vJrr4ZAh1Irs7ERVVaucOh5GBAMLrVSHCW7diLi7BUrMA/+JVSHc1DsIqUKG2lmhYEg8lsPUM0G2UYTFZEAI88QgxTwl6cS1Wq4VQKBu2b/LWUZhMKIOgrpPa34q7shApTUiLB98iLyuuqlKhH+l1ZdZMnF10Ig/1P8OFJeumn5zIHnDMJRRSU2KzyvHVfHUd+dRT9C1eS1KYiZbWsrDUy0AsRXeHTiruZl9nAwXFDdhbm/B75jBGVe3oUARgt2fFmpNOGkMMcSPB91vuwrpzL9e1S7RhFTjJM8/AX/8K552niGDuXEWke/cqrtvVBf/7v0pk9XqVDjIBQbRFu3NqrDhTzDpiwLkY2n6U+/kZ1q1pGBICYZ2kWILWu5PCiiqQknDIIGopQysGl7Mfk89HbNUpRL1VGOjokQiJ3k4ItsPq1cSDGhF/ArtVYqlyQlMbXc55DJWXYykpoDyt243UA5YGyUAE48WX0Xu6oKIS9uyjYHGQZSUNxCo1iov3kUgch5TZ3gRCwPsqL+JDW2/gguK1U+ady3SV8r17TXR1qWvnNRiU+cacpP719GKUrkCmQFptWJ1OIr0pEkmVwrt1uIbFdcswLV3CmqtOG/tF5eUjTkZMJmUSHhUB8PTgRn64/x6urtzAhuPOBesns99tNqsYkUBgxIgAZGvYZjoEmUxKCd+/X4l0ByFpJPOmVQAhTKDZkckAwjQxGx2D005Tk97Xx2DNcgKOcoKeUobb+1hUDWazzkDSh1sbBKER29OKyZxAa9lHap6PpNkBQ37sw/0gDLp2DrJ9sIJk0kx1cYwiTxJflZmS0hiReR5cbrUrB4Oj2gVEIujBYTQ9bbcPBkA3IToOYEmZMBdIpM8+cn4m4M9kApfJwdrCVTzY99TU3CG0k5RtMV3puEVpSHpaY5QVjsqZTu/e2pwaHH3dhNzlCKsqgqZrOpqe4sXNEYRXY8571jFnzvj+djgcSgdqalK5GNu2waZN7JtbyM3WZ6ixlfHLJd/IWo2uvx5++EMl+px5purekkiowLuXX1Yi1po1aozV1VkOo2kTZhL2xAYoshRM/9wPAbOOGABEwSnI4WcQRedNf7LNpjqlA93blagrJcSCXRxoGUazeEmJQoI2LxX+PeheFzRtwRIKY195MkkhcAwOYyMMQtDS48BsTiJMOv0BC/OWFmNedS5mIGOM6evLBvxZrWBzgb1jqyr1nkyqHhAWCzISQg4PYersgeqFkF54B3uMP1x9Ce/b8hXOLToV0yQVIeSuJ9FjlVhklKShU9X+Ah4RgJhTWXgyrAbglFMobG3FldIwKl0MDCr3zKZNOibDhnH6n7lX6+Pa4fOwD6lo4BHz6pYtI0FdRksz3cU2duj9OIftfPPdH6fKfZByv3at+uvvH8kzGQmUOuussefOm6eaeB84oF5P0APsZf821nhm0GB7BpidxFB4Fkbrd2ECYpBSceG0rjeCcDgrMRkGONwetNhWhPUEPB6wmMDVUIq5Kwb2FYht2/CKQDoLrA5e7oO2NszmOhLCgsluwllow+IeK7ok09XckQaiuwcCfTjdCTj7LCUzZ5qAaBrayy9hNEoG156JKWihoFiVgDGZxhKDQ7dxSdmZ/KbzAT5Q9fbxE9LcDK81o7lLWKo/RV/BXLx6ALcLJW50dWULCcNIsaWMRb+kRM3Jhg0qmae4+DJ2H9jIpvaX1JzunEd7rAyHG+aEduAINitbf9yENVXLqZ7FWP1haBmAZZOUHC0qGt+dZCI0Nk4eyg08NbiRD1e/Y/LrXwdmJzFYyiAxiExFEfrYiX3hBWVR1XUlzlZUKNfDPfcog1FJiWof0N3twBiMgxGmpMSBy2ZAMB0X4/MhvQWEB2PEE3EsWhJHJIJIpVhkbGKvcw3SbWXeoiwhGEa2/pFJl8hoFBmLYvH3kuwaQC8tQzQ0qB0y3UE9VVmDucyHK9BFxFZBMmHgdE+8819ZcR5Xbv4SF5euH+d9lUNDkA5gdMgQc8oTkHbHGBJCCRuJAbW5T2SxzOTZZ/QVgEZbNY02C8ODEZ7uLsZvidMTTtJXXM/6OT2cMDgHW0OjuumTTyod4t57lZHi4N5qaW6IwzGjNrcHQ0rJ3nDbETGrwgxK0h9rEIVnIQcfHfNZKJRNAkulstmEW7Zkyy/29ipRqa4OSqrLqbb8RlU21DRlM3e7IRYjsr+bQMKOYQiG/YKoyQ21tdi0KNV7/kVKmBgczH73nj2KGEIhSbRrAEugH0dsEKOymmjjcUT9MWTbgWxOZSCA8BWCz4cp5MfRsgf9+WezOaMHQRc6/15/Nd/e96vxB4sBc1p/crlUePeCBVBURLR6PtFCld/g94/voDsynweJZqRSsHs39s4DLPFvZ0FfgqUhF6cVn8T89/8btms/r1jJ8uVqsWcubm4ee+N4XNXsefVVZboe3YdthngtuJslrrlHrIDd7COGTFWJog3IvvvHHLJYxm486SaVY5LBNE05gB0OKOsewH3/g8gHf6/uW1SkzH1eL5GL301fd4rOJj/hrgC62w67dyMHh7Bu30jB43+iuxuSA8PQ2UlkKKb0hHgCYaTQU3F0mcJqFZhFCr2/FxmLKVaVLhNp8g9iaW9GDw9hiw5iiwyO5EZMhOO9SxHAc0Obx06JrRnWrlAmztNPV5PQ0AAnnECidoYJM1IqJ9rmzSrQ0KpREOrAEerB3ddMfXDr2PO9XmUNyqC+fmyjwb6+LAHE02Eth4h7u/7BZeUTxKUdJsw+MSm9tQnNAa6VyHCT6n+MWgNr16qQF7s9a5VbtUptyN3dKmqguBilpD32GCLRgHz6d4jiOSqkIe2sK4zECG7qJxwCtx7EHBpW9nUE+lA/rlefJHba2eivbQMB9VEL2+yrGRwwcAQ6cdJFymIFUQACpMOpBmG2KxaWTMLAAGbAZLJCQZ0a7DQ1bL8696N84LWvc/eym3GalMYtAxvRqj4B1vG290zTUykPapAyGfbuVdG+zz2nLqitpUCEOEm8nC4GtnLs+SYTfOQjqhBDU5P66+hQXmi3O7sjjR7QISCQDNE8VaGEw4DZxRkOqveqFV+G0fHLMZ8VFSldYcUK9ZwMQ4npS5aodrQjSVXpnEhhLgEjhPSPSkYPh9F6u6m1dLLIuo8yfUCVn4zF0F7bjP7Mk1j1FHXB1xCG8px6bHGW1gZpXGqjeq4Nk0xgiQXR/INoyTimwABaaYmyoKxcqVZlJIIsLMRYvAdRVqkIcZrq5h6Ti3+ru4qv77kt+2GsAywTNzgxm9WcFBdPWd4pi1AInn1WtQXasUMt8oKCbL+2icbncKiwl5jqzEMgoCJeQV27eLHyTyxcOKMeDKNxR/tfeF/lhkO6NlfMPs4wCsJSBDKFjOybMMdBShVH1t6unuUJJ2QrqoykTu7bh6g6BaPkKXQuUTv2nj1KZs4QXySirEovv4x49VVMpUV4bHFo36dWW20tmEy4y51gAXwLYOECRCiEuaVFLTCZUlTq8cDFF6uFEY1Cox36h6Fu7bjxT4a1hat4anAjv+96lEtL14EwTSlHz0jEnjMn67XO1GM9/3yleWcU4EzX8syNt2+H//kfpZQ0NiorxWgOV1Y24/4LozGQGOaZwU18Zs6Vh3yPXDC7iCGj5Y30ixVo1ddgtP0neuOPx50ejWarj0ip+n2PEIOuwxVXQDSKsFqh+WvIwCaEeeHYKmAulzIFhkJqIS9alO0dZTIpeayiAqqr8UctRAbBa4tia1blVAgG1aIqL1cL6p57lBhRXQ2XXYbR+WM033nEYtmxVlVNGacGwPV1H+BD225gvpZiqWPmOcSTorAQPvMZ+PGPFVGccUZ2IRuGmof+fnjkETVPa9eqEIpoVD2bffsU0WcidA8D/t/e27m+/oNHvPL77CIGyGZfZd7a68FSjjH8LJp3bCHbjK8ho7+NKtCdRdrmrSpmfx5t4S8QbreyirS3K5ZfV6dCA8xmRSDRqGL/mS4lJhNDQ7C3Q92yMxhjsRHEQkLJJkIoRSYUUoQAcOAActtmsGyGms+xb6fyhYCSNqZKSQAwaTo/Wng9H9n4af6z+nzmTH36zLBgAfzoR0rhHS3j+/1qHl5+OZ1XrsPDD2cVkUxN/vXrD9tQHup9Bq/JyWrvNBNyGDD7iGECaNWfwWj6BNK9WoVpp6Hryriye7faaadaYAIPomMFsuVWxIoPZG3nXV1qt2toUKu0ulqJAXPnql3UZoPBQQKOrLc0FY4RGRzGMrRfEUymUfjcscqfDD2OqLoUIcSIuA3jepxPikKzh+8V1vFvnU/x30XnUWo9jAkvJtPY9MuhIbj5ZsUVurtVJ/rM7vK+9ymO19OjJrm//5B1g9FoDrdzR/ufufu4m1/3vXLB7FKgJ4EwuREVH8CYIIDP41HPbenSaVoMP/kkYp8Dtu5A/u13aptOJNRfRmwyDLWz9/crPcFsBiGQmobTq49Ib6ZkBAchJW8/9hj8859KnFq4UMXhFBcjl81Ful9DFCulcHTx4fJypbb89a+qtOhoQjkYc1I9fHvBF/jk9pvpiB662XJabNmiOEPGNh0IqN909tkqdOL445W+4PfDn/40ztgxU/THh/l80/f54cLrD3uB4cnwpiAGAM13DiT6kP6XD+0GAwMq+d6zGjn4AnLdqerBl5aqeqhdXYoYwmG16+m6sgbF4iSr63EV2Zk7VzGOhVUBzMP9SrE0DCUqNTWpjLwzzkAuW4J87m60x+YjWlRmWlmZyvlZtkyd/uyzyjm4f/9IK4eJIZM0uuby/YWf45od32ZHsHmKkw9CLKa8lK2t0zvDMnpDRo/68IdV2cdlqkfFSAQqKC54cOj4DDCcCPLJ7Tdx0/xrqLSNj086UnjTEAOAVvc1jLb/RCb9M7+4sVGlhpbOgVOuxFiyF/ntb8P3v6/YytBQVt7PVOUqLUWWliJdbrREDLclRpFPYq0oUjvp8LDyKKdSDEoPzzYV8crLKaIP/hxhnYNI2eGBB0aal1tMxkh09GhMtq5koh/MquBxnb2K/1nyNW7a+3Me7H06t9/c2amIOxLJ/rbJsGCB8iecdJJKiDrYxLpyZVaXW7ZsWn/JZOiLD/HRbTfylbkfZbErhyoohxFvCp0hA2Fyo835PEbzDWjzfjAz68PChWr3dzjQauuQCRey+y7EgSXwy18qZdpsVvbZhQvVjr99OyKVQo9EldgEiGS6CkbG6pVKkZQajxW/m/3b3NhoQ1jPZpU5LW7V16tFOTCgzEjV1fh8ijZ37ZrAtN/bqxyGHg/S145wZCM4SyyF3LHsm3xz7//w/NAWvjL3I1OLGKM7vYx+PRkyOc6TzV+6hOSh6gv7I538287vcvP8z7DIVT/9BYcZbyrOACoTTjgWIbt/O7ML77lHeV97epR441iMTPgx/vlfamFnRKMTT1QLoqcH+vsRkQjaC88hgqrtroZUCsD27UrRHBwkvHAVuyKVxAJdDIcL2VN2kTqnqCgbTZoJZkvL2iedpEL+L700W5eXUEjF9xw4oO6/+5Vsr+k0LJqZm+Zfw8kFy3nvlv9ga2DP5L+5pCS7m08QLj1juN2HTAgb/Tv53M7v8eNFXzwqhABvMs6Qgaj8CMauzyBdyxGuHPtVt7UpGbqoCEIhhNWKVnotRuVHMLZtRjiPQxQUqDCFp59WWnnaLCuEQCTi2VInpaXKcuT3IwsK0EPbcGnbCZobMZltFNUAZ12pxKPu7nRMuWNMS1uYoJZWODw20m6oFZwT/77zS05ltXcRX9v9X9Tbq7iu9qrxzT08nmz/5UMp6xiNqnkrLEzHuBwaHup9ht92Psivlt6YTQo6CnjTcQYAITS0hpsw9n87d/3hhBOUheS550b8CELT0K/+JVxxIcbyFmSgX2m2L7wAv/tdNi4/lVJWo9271QouKCC15gQSpQUk5T7sK8ycctYiaubYaGxUXwUoK8yyZUomqqsb22dhIvh8IymW0kjB/j7EP5+atD9aqcXH/yz5Gsvc83jvli/z1OCr408anXSdC6RkpL3PQw+psjC//a1qZn0I+OWBP/Fw/7P8cuk3jiohAAh5cIPnNwB+vx+v18vw8DCeCT1hhwcysBGj8060+T+cXn/IdCdPJNTiHB5Wiz6VglWrkAVReNdlEJKgexFWh/K8NjXBLbeM1PuRN/4HqeJWBgesiM4ElC7H0VCLwzGufXP2e+NxJYLlonSmY7HlH36B7NmF5lqmkhEuu2zKywLJELc038FwMshXGz5KmfUQ/QCxmOJQ4bASK5ua1OvFi0eKsOUCKSXf2vdLdKHxxSPoXZ7JWntTcoYMhHulKi3TddfkJ0mpZPA9e9Rrn08ptk8/DUNDJAYChB59lrBRj9jwMdBckBzEmDtEqvfbpF69ExnrRSZ6kZEDGM/+mJS0IX1nI5ddjCyrHSklOu55G4ayy4fDiivlEuuv61BYiBzYhbCmg/P803M/t8nJTfOv4ePVl3Hdzu/ys9b7SBjJaa8bh4yYZrGosWTiRspzr1aRkimu3/VDyq1FfKnhQ0c8zCJXvCl1htEQFR/E2P1ZpHvlOGUTUEppKN0pJxpVK9bjgViMZDzFsF/H0CUduySN7/s4jrVrlSlyxQpEagBO3QiPtZOMQtLhxXLmN7CU1WEazBpoJo0zytQ0yiCRmDolMg0pJbLBj+hYpsa7enXO87HUPY97jvsWv+9+lCu3fInPzLmS0325Xz+mMkam1IvPp6xJOSBuJLh2562c5TuRy8rPzv173wC8qcWkDGRiCGPXp9EW/Gx8RY1IJFueMpFQiqzbDX19RF7dTsAvGWxYQ7i0biQS42AMbtnPgefbiVXPwzanlMWLs7fT9SmKSkup/BcZgnC5po/QA4zh55D+F9E9H1Dy/iTFtqZDIBniBy13cyDWw1caPkydfZL85YnGneksNINdPZKK8ekd3+Ly8rdxXvGphzTmmWIma+0tQQwAMvAKRtdv0eZ9bzxbHhxUoobVqnZmwwCbjYhwsGtX9rk3Nk5QOgWlN4/O1ly6NMfcAVA3z+gMOeYHp5quQav/msoFPwzYFz7At/b9gmpbGf9W+74josgOJvxcs/3bfLzmXazzrTrs958MM1lrb3oxKQPhXo3wv4jsuRdR9u6xBwsLx/RxzsCOIoBQSC3ucYRgGNDcTHFHkGColHhBKSarnsvmnkWmYliOkKFtYC44bIQA0OCo5hdLv8HTgxv52LZvss63ig9VXXLYumm2RNr5/M4fcMO8j3Oce/LKF0cbbxnOACCloVrP1nwO4ZykHOVMsHs3NDUhN20ibNgYsFVQ9MG34yhJ76yhkDonlVKZYKNzhQ9p/BKj6eNo9TcirBXTX3AIMKTBX3uf5O6OB3hb0clcVXkhDj13Yj0YD/Y+za/b7+cHC79Ale31/f5DQd6aNAmU/+FmjJb/h0xNbJufEUIh6O1FxGI4E8PUtDyDo2lT9nhra7ZFU0tLbiEPU0D23a8sZEeIEAA0ofH20vXcu/wWSiyFfPC1r/Otfb+kLdo1/cWj0BHt5Zrt3+YV/3buPu7mo0IIM8VbRkzKQFiK0Wo+i7Hv62jzvv/6zHrV1apBOCi5P5Ua64k9jCZDGetA9v4RbeEvDts9p4IudC4pO5N3lJ7BC8Ov8d3mX9OfGGa9bw3rClcx3zEHTYzdS+NGgpeGt/H77kcJJIP8W937jmgC/+HGW0pMGg2j8w6QSbTKj76+G0UiKhGouVmFep9yythje/YozlBTc8ghC9KIK/Go7usqs+8oIZKK8eTgKzw7tJk9YVWgSks3GjSQmITOCvcC3l66ngbHNN70Nwh5a1IOkFJi7P0Soug8tMIzjsoYcoGUEmPffyAKz1Q5G3nMCHmdIQcIIdAavonsuhsZ2n60hzMpjLYfIhyNeUJ4A/CWJQYAoVnR5v1ABfRFZpAh9gbBOKBqI2kVHzzKI3lr4C1NDADCXIA273sY+76KjLQc7eEASjRKtX5P6TQ11x3t4bxl8JYnBlBVvbV531cEEdpxVMcijRjG3i8jzCVoNZ89ZoLY3grIE0MawlqO1vgTjNbvYgw8Ov0FRwAy1onR9AlE0bloFVcflTG8lZEnhlEQ5kK0BT9DDj1Jav+tSCPHAkaHAcbgPzH2fhGt7uvHtHXrzYw8MRwEoVnQG76JcC3D2PkRZHDLEf0+mfST2vsfyOHn0BbeflT9CG91vOU80LlCKzof6TkBo/V70P2/aNWfySbTHAZIKZF9f0X2/A6t5lqEZ5KqE3m8YcgTwxQQ5iL0ud9GhrZj7P826C60ig+M9IM4FEgpkf5nke23I7ynoC36FeINqhiXx9TIE0MOEM7F6I0/QYZ3Y3T9BmKtiMKzEL5zcg6llqkQcuBhZO/94Fqm8rLNBUd24HnMCHlimAGEYz56w43IVBQ59C+M1u9DvAdsNQjnIrDOQZh9IMxgRJDxHojsQQY2ARLhOxttwW0I/dC61+RxZJEnhkOA0G2qB3XReUgpIdaODO+EyG4M/xDIBEKzgaVYFTUrf3+eAGYB8sTwOiGEAFs1wnZsRGnmcejIm1bzyCONPDHkkUcaeWLII480jorOkMkn8udQCS6PPF4PMmsslxy2o0IMgUAAgJqamqPx9Xm8BREIBPCmizZPhqOS9mkYBh0dHbjd7nyIch5HFFJKAoEAlZWVaNNUGz8qxJBHHsci8gp0HnmkkSeGPPJII08MeeSRRp4Y8sgjjTwx5JFHGnliyCOPNPLEkEceaeSJ4RhBS0sLFouFFStWsHLlSpYtW8Zpp53G1q1bAXjooYdYu3Yty5cvZ+nSpVx//fUkEokx97jjjjv4wAc+cBRG/yaBzOOYQHNzs6ytrR3z2U9/+lO5YsUK+fe//13W1dXJnTt3SimljEaj8oorrpCf+cxnpJRSRiIRef3110uXyyWvvvrqN3jkbx7kOcMxjDPPPJNdu3Zx0003ccMNN7BggSpEYLVa+dGPfsS5554LwOOPP46UkltvvfVoDnfWI08MxygMw+Cuu+5i7dq1bNy4kRNPPHHM8bKyMi688EIAzj//fG699VbsE3VfzCNn5NM+jyF0dHSwYsUKAGKxGEuXLuX2229nyZIlGKP7RedxRJAnhmMIlZWVbNq0adzna9as4aWXXmLJkiUjn3V2dnLNNddw3333TRuNmUduyM/iLMD111/PjTfeSFNTEwDhcJhrr702p7DkPHJHnjPMApx33nnccsstvOc97yGZTBKPx3n729/OTTfddLSH9qZCPp8hjzzSyPPYPPJII08MeeSRRp4Y8sgjjTwx5JFHGnliyCOPNPLEkEceaeSJIY880sgTQx55pJEnhjzySCNPDHnkkUaeGPLII43/D6hygMM6CFGAAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from sklearn.decomposition import PCA\n",
    "fig, ax = plt.subplots(1,1,figsize=[2,2])\n",
    "kf_split_id = 3\n",
    "df = sess_info_all[kf_split_id]\n",
    "df = pd.DataFrame({'pc1': pcs[idxs,0],\n",
    "      'pc2': pcs[idxs,1],\n",
    "      'cca': -df['CCA_BEH'].values,\n",
    "      'Gender': df.Gender.values})\n",
    "sns.kdeplot(data=df, x='pc1', y='pc2', hue='Gender', bw_method='silverman',\n",
    "            palette=['#FBC622', '#16BE41'], bw_adjust=1.3, thresh=0.06,\n",
    "            levels=3, ax=ax, linewidths=0.5, legend=False)\n",
    "\n",
    "feats = feats_all[kf_split_id]\n",
    "df = sess_info_all[kf_split_id]\n",
    "idxs = df.data_index.values\n",
    "\n",
    "pca = PCA(n_components=3)\n",
    "pcs = pca.fit_transform(feats)\n",
    "print(stats.pearsonr(pcs[idxs,1], df['CCA_BEH'].values))\n",
    "\n",
    "sc = ax.scatter(pcs[idxs,0], pcs[idxs,1], c=-df['CCA_BEH'].values, \n",
    "                alpha=0.6,cmap='bwr', vmin=-1.6, vmax=1.6, s=8,\n",
    "                ec='k', lw=0.0, zorder=10)\n",
    "ax.set_xticks([])\n",
    "ax.set_yticks([])\n",
    "ax.set_xlabel('PC1')\n",
    "ax.set_ylabel('PC2')\n",
    "cax = ax.inset_axes([0.1,1.1,0.4,0.03],\n",
    "                    transform=ax.transAxes)\n",
    "cbar = plt.colorbar(sc, cax=cax, orientation='horizontal')\n",
    "ax.text(0.2, 1.2, 'CCA mode', transform=ax.transAxes, \n",
    "        ha='center', va='center')\n",
    "\n",
    "ax.set_xlim(-12,14)\n",
    "ax.set_ylim(-11.5,15)\n",
    "fig_dir = settings.results.dir / 'ver.1' / 'figure4'\n",
    "fig.savefig(fig_dir / 'fig4-2.pdf', dpi=250)\n",
    "fig.savefig(fig_dir / 'fig4-2.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "7beffaa6-ce59-4a96-98f2-6ac42e326d17",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "PearsonRResult(statistic=-0.5088701831166409, pvalue=6.524120662967347e-44)\n"
     ]
    },
    {
     "data": {
      "image/png": "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+OGHrF27FrvdjkKh4P777+c3v/nNVA/rsvHqq6/y8ssvU1RUBMDevXupqKhg9uzZSCQSHnrooSviflxRm78io9Pe3k5xcXH2dVFREW1tbVM4osvL66+/PuD1lXo/RE01jUilUkPeG090/9XKlXo/pn4EIuOmpKSEzs7O7OvOzk5KSkqmcERTy5V6P0Shmkbcfvvt/PnPf6a7u5t4PM6bb77J+vXrp3pYU8bKlSs5efIkJ06cANLLwyvhfohCNY0oKirixRdf5Pbbb6empoZFixbxuc99bqqHNWWoVCreeustvvjFLzJnzhwSiQSPP/74VA9LjP0TEck1oqYSEckxolCJiOQYUahERHKMKFQiIjlGFCoRkRwjCpWISI65ZoVqcArBSLz77rv8+Mc/HvL+9u3b0ev1LF68mCVLljBv3jzWrVtHR0dH9pg333yTlStXsnjxYhYsWMCPfvSjCY3x3LlzzJ07l2XLluFyuYa9dubcM2fO5JVXXske09vby4MPPkhlZSWLFi3i1ltvZceOHdnPn3nmGZ555pkJjWcstm/fzq233prz7zc3N2fL1j311FNs3rz5oq9xObgmA2p3797NV77ylWwKwWjU1dWN+Nny5cvZvn179vU3v/lNHn/8cX7/+9/z6quv8sorr/DHP/6RwsJC/H4/69evRy6X8+STT45rnNu3b2fx4sW8/fbbY1770KFDrFixgr/9279FqVSyZs0a7rvvPl577TWkUin79+/nzjvv5De/+Q033XTTuK5/JfLcc89N9RDG5JrUVINTCADC4TD33HMPS5YsYenSpfzsZz+joaGBV155hVdeeYX/+3//75jnXbt2LSdPngTgf/7P/8mPf/xjCgsLgXRl09dee43ly5cP+d7Jkye59dZbWbhwIddffz379u3j0KFD/Mu//Atbtmzh4YcfHvPazc3N6HQ6VCoVv/nNb7DZbHznO9/JBpguX76c733ve2MmNvb29nL33XezbNkyli1bxrvvvgukNduDDz7IihUrKC0t5aWXXuLBBx9kzpw53HPPPWRiCPr6+vj0pz/N/Pnzeeihh7IVhT/44AOuu+46li5dymc/+9msRv/ggw+oqalh+fLl/Od//md2HAcPHmTp0qUsXbp0wJgffPBBfvGLX9Dc3MyiRYv48pe/zKJFi1i1ahVNTU0AfPTRRyxatIglS5bw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\n",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1,1,figsize=[2,2])\n",
    "\n",
    "kf_split_id = 3\n",
    "\n",
    "feats = feats_all[kf_split_id]\n",
    "df = sess_info_all[kf_split_id]\n",
    "idxs = df.data_index.values\n",
    "\n",
    "pca = PCA(n_components=3)\n",
    "pcs = pca.fit_transform(feats)\n",
    "print(stats.pearsonr(pcs[idxs,1], -df['CCA_BEH'].values))\n",
    "\n",
    "sc = ax.scatter(pcs[idxs,1], -df['CCA_BEH'].values,\n",
    "                s=8, ec='k', lw=0.15, alpha=0.9, color='#72A2E1')\n",
    "ax.set_xlabel('1st PC of ROI embeddings')\n",
    "ax.set_ylabel('CCA weight')\n",
    "\n",
    "ax.spines['top'].set_visible(False)\n",
    "ax.spines['right'].set_visible(False)\n",
    "fig_dir = settings.results.dir / 'ver.1' / 'figure4'\n",
    "fig.savefig(fig_dir / 'fig4-3.pdf', dpi=250)\n",
    "fig.savefig(fig_dir / 'fig4-3.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "ec3ad6ea-fee4-40a6-81d5-d07a8fc83dd7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1,1,figsize=[2,2])\n",
    "\n",
    "kf_split_id = 3\n",
    "feats = feats_all[kf_split_id]\n",
    "df = sess_info_all[kf_split_id]\n",
    "idxs = df.data_index.values\n",
    "\n",
    "pca = PCA(n_components=10)\n",
    "pcs = pca.fit_transform(feats)\n",
    "ax.scatter(np.arange(10)+1, pca.explained_variance_ratio_*100,\n",
    "           s=15, ec='k', lw=0.3, alpha=0.9, color='#72A2E1', zorder=10)\n",
    "ax.plot(np.arange(10)+1, pca.explained_variance_ratio_*100, color='k', lw=1)\n",
    "ax.set_xticks([1,3,5,7,9])\n",
    "ax.set_xlabel('PC components')\n",
    "ax.set_ylabel('variance explained (%)')\n",
    "ax.spines['top'].set_visible(False)\n",
    "ax.spines['right'].set_visible(False)\n",
    "\n",
    "fig_dir = settings.results.dir / 'ver.1' / 'figure4'\n",
    "fig.savefig(fig_dir / 'fig4-4.pdf', dpi=250)\n",
    "fig.savefig(fig_dir / 'fig4-4.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "d723bfba-e5f3-4895-a3b2-55743a1b6c55",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.5438528"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pca.explained_variance_ratio_[:2].sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 172,
   "id": "7db8bc58-7ed7-481a-838d-5971dcb16a2f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 100x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "d = []\n",
    "for kf_split_id in range(5):\n",
    "    feats = feats_all[kf_split_id]\n",
    "    df = sess_info_all[kf_split_id]\n",
    "    idxs = df.data_index.values\n",
    "\n",
    "    pca = PCA(n_components=3)\n",
    "    embs = pca.fit_transform(feats)\n",
    "    rtns = stats.pearsonr(embs[idxs,1], df['CCA_BEH'].values)\n",
    "    d.append({'rho': rtns.statistic,\n",
    "              'var': pca.explained_variance_ratio_[1]})\n",
    "df = pd.DataFrame(d)\n",
    "\n",
    "fig, ax = plt.subplots(1,1,figsize=[1,2])\n",
    "\n",
    "\n",
    "ax.boxplot([df.rho], vert=True,\n",
    "           positions=[0], whis=4, widths=0.5, patch_artist=True,\n",
    "           boxprops=dict(facecolor='#72A2E1'), zorder=0)\n",
    "\n",
    "ax=sns.swarmplot(data=df, y='rho', color='gray', \n",
    "              ax=ax, marker='o', alpha=0, s=5,\n",
    "              edgecolors='k', linewidths=0.8)\n",
    "coll = ax.collections[0]\n",
    "x, rhos = np.array(coll.get_offsets()).T\n",
    "idx_sorted = np.argsort(df.rho.values)\n",
    "ax.scatter(x, rhos, color='#BFC1C5', alpha=0.9,\n",
    "           s=30, edgecolors='k', linewidths=0.5)\n",
    "ax.set_ylim(0.4,0.55)\n",
    "ax.spines['top'].set_visible(False)\n",
    "ax.spines['right'].set_visible(False)\n",
    "ax.set_xticks([])\n",
    "ax.set_ylabel('correlation')\n",
    "# ax.set_xlim(-0.4,0.4)\n",
    "\n",
    "fig_dir = settings.results.dir / 'ver.1' / 'figure4'\n",
    "fig.savefig(fig_dir / 'fig4-5.pdf', dpi=250)\n",
    "fig.savefig(fig_dir / 'fig4-5.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cde13b5f-3c1d-42f4-9a76-060cab6eb317",
   "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
}
