{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import autograd.numpy as np\n",
    "import autograd.numpy.random as npr\n",
    "npr.seed(0)\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.colors import ListedColormap\n",
    "\n",
    "%matplotlib inline\n",
    "\n",
    "import seaborn as sns\n",
    "\n",
    "sns.set_style(\"white\")\n",
    "sns.set_context(\"talk\")\n",
    "\n",
    "color_names = [\"windows blue\",\n",
    "               \"red\",\n",
    "               \"amber\",\n",
    "               \"faded green\",\n",
    "               \"dusty purple\",\n",
    "               \"orange\",\n",
    "               \"clay\",\n",
    "               \"pink\",\n",
    "               \"greyish\",\n",
    "               \"mint\",\n",
    "               \"cyan\",\n",
    "               \"steel blue\",\n",
    "               \"forest green\",\n",
    "               \"pastel purple\",\n",
    "               \"salmon\",\n",
    "               \"dark brown\"]\n",
    "\n",
    "colors = sns.xkcd_palette(color_names)\n",
    "cmap = ListedColormap(colors)\n",
    "\n",
    "import ssm\n",
    "from ssm.util import random_rotation, find_permutation\n",
    "from ssm.plots import plot_dynamics_2d\n",
    "import ssm.hmm as hmm\n",
    "\n",
    "save_figures = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from scipy import stats\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.decomposition import PCA\n",
    "\n",
    "from NetFormer import tools, data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.rcParams.update({\n",
    "    'axes.titlesize': 14,\n",
    "    'axes.labelsize': 14,\n",
    "    'xtick.labelsize': 14,\n",
    "    'ytick.labelsize': 14,\n",
    "    'font.size': 14\n",
    "})"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Process Neural Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "SB025/2019-10-23\n",
      "no normalization\n",
      "cell_type_order: ['EC', 'IN', 'Lamp5', 'Pvalb', 'Serpinf1', 'Sncg', 'Sst', 'Vip']\n"
     ]
    }
   ],
   "source": [
    "input_mouse = ['SB025']\n",
    "input_sessions = [['2019-10-23']]\n",
    "\n",
    "window_size = 60\n",
    "split_ratio = 0.8\n",
    "\n",
    "directory = '../../data/Mouse/Bugeon/'\n",
    "input_sessions_file_path = []\n",
    "for i in range(len(input_mouse)):\n",
    "    for j in range(len(input_sessions[i])):\n",
    "        input_sessions_file_path.append({'date_exp': input_mouse[i] + '/' + input_sessions[i][j] + '/', 'input_setting': 'Blank/01/'})\n",
    "        print(input_mouse[i] + '/' + input_sessions[i][j])\n",
    "\n",
    "all_sessions_original_UniqueID = []\n",
    "all_sessions_original_cell_type = []\n",
    "\n",
    "all_sessions_acitvity_TRAIN = []   # first 80% of the time\n",
    "all_sessions_acitvity_TEST = []\n",
    "\n",
    "all_sessions_state_TRAIN = []\n",
    "all_sessions_state_TEST = []\n",
    "\n",
    "num_neurons_per_session = []\n",
    "sessions_2_original_cell_type = []\n",
    "all_sessions_activity_flatten = []\n",
    "\n",
    "for i in range(len(input_sessions_file_path)):\n",
    "    date_exp = input_sessions_file_path[i]['date_exp']\n",
    "    input_setting = input_sessions_file_path[i]['input_setting']\n",
    "    activity, frame_states, frame_times, UniqueID, neuron_ttypes = data.load_mouse_data_session(\n",
    "        directory, date_exp, input_setting, normalization=\"no\"\n",
    "    )\n",
    "    frame_states = frame_states.flatten()\n",
    "\n",
    "    all_sessions_original_UniqueID.append(UniqueID)\n",
    "    all_sessions_acitvity_TRAIN.append(activity[:, :int(activity.shape[1]*split_ratio)])\n",
    "    all_sessions_acitvity_TEST.append(activity[:, int(activity.shape[1]*split_ratio):])\n",
    "    all_sessions_state_TRAIN.append(frame_states[:int(activity.shape[1]*split_ratio)])\n",
    "    all_sessions_state_TEST.append(frame_states[int(activity.shape[1]*split_ratio):])\n",
    "    num_neurons_per_session.append(activity.shape[0])\n",
    "    all_sessions_activity_flatten.append(activity.flatten())\n",
    "\n",
    "    # Get the first level of cell types\n",
    "    neuron_types_result = []\n",
    "    for j in range(len(neuron_ttypes)):\n",
    "        # split by \"-\"\n",
    "        neuron_types_result.append(neuron_ttypes[j].split(\"-\")[0])\n",
    "\n",
    "    sessions_2_original_cell_type.append(neuron_types_result)\n",
    "    all_sessions_original_cell_type.append(neuron_types_result)\n",
    "\n",
    "all_sessions_original_UniqueID = np.concatenate(all_sessions_original_UniqueID)\n",
    "all_sessions_original_cell_type = np.concatenate(all_sessions_original_cell_type)\n",
    "all_sessions_activity_flatten = np.concatenate(all_sessions_activity_flatten)\n",
    "mu = np.mean(all_sessions_activity_flatten)\n",
    "std = np.std(all_sessions_activity_flatten)\n",
    "\n",
    "# all_sessions normalization\n",
    "all_sessions_acitvity_TRAIN = [(session - mu) / std for session in all_sessions_acitvity_TRAIN]\n",
    "all_sessions_acitvity_TEST = [(session - mu) / std for session in all_sessions_acitvity_TEST]\n",
    "\n",
    "##############################################\n",
    "# Construct new UniqueID and cell type id\n",
    "##############################################\n",
    "\n",
    "all_sessions_new_UniqueID, num_unqiue_neurons = tools.assign_unique_neuron_ids(all_sessions_original_UniqueID, num_neurons_per_session)\n",
    "all_sessions_new_cell_type_id, cell_type_order = tools.assign_unique_cell_type_ids(all_sessions_original_cell_type, num_neurons_per_session)\n",
    "\n",
    "neuron_id_2_cell_type_id = np.zeros((num_unqiue_neurons,)).astype(int)\n",
    "for i in range(len(all_sessions_new_UniqueID)):\n",
    "    neuron_id_2_cell_type_id[all_sessions_new_UniqueID[i].astype(int)] = all_sessions_new_cell_type_id[i]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "neural_data = all_sessions_acitvity_TRAIN[0]\n",
    "neural_data = neural_data.T\n",
    "\n",
    "state = all_sessions_state_TRAIN[0]\n",
    "state = state.astype(int)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "eval_cell_type_order = ['EC', 'Pvalb', 'Sst', 'Vip']\n",
    "\n",
    "KK_GT = np.zeros((4, 4))\n",
    "KK_GT[0, 0] = 0.11\n",
    "KK_GT[1, 0] = 0.27\n",
    "KK_GT[2, 0] = 0.1\n",
    "KK_GT[3, 0] = 0.45\n",
    "\n",
    "KK_GT[0, 1] = -0.44\n",
    "KK_GT[1, 1] = -0.47\n",
    "KK_GT[2, 1] = -0.44\n",
    "KK_GT[3, 1] = -0.23\n",
    "\n",
    "KK_GT[0, 2] = -0.16\n",
    "KK_GT[1, 2] = -0.18\n",
    "KK_GT[2, 2] = -0.19\n",
    "KK_GT[3, 2] = -0.17\n",
    "\n",
    "KK_GT[0, 3] = -0.06\n",
    "KK_GT[1, 3] = -0.10\n",
    "KK_GT[2, 3] = -0.17\n",
    "KK_GT[3, 3] = -0.10\n",
    "\n",
    "max_abs = np.max(np.abs(KK_GT))\n",
    "vmin_KK = -max_abs\n",
    "vmax_KK = max_abs\n",
    "\n",
    "plt.imshow(KK_GT, cmap='RdBu_r', vmin=vmin_KK, vmax=vmax_KK)\n",
    "plt.colorbar()\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Train arHMM"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set the parameters of the arHMM and SLDS\n",
    "time_bins = 3154    # number of time bins\n",
    "n_disc_states = 3       # number of discrete states\n",
    "latent_dim = 527       # number of latent dimensions\n",
    "emissions_dim = 527      # number of observed dimensions\n",
    "\n",
    "N_iters = 50\n",
    "arhmm = hmm.HMM(\n",
    "    K=n_disc_states, D=latent_dim, observations=\"ar\"\n",
    ")\n",
    "\n",
    "arhmm_lls = arhmm.fit(neural_data, method=\"em\", num_iters=N_iters, init_method=\"kmeans\")\n",
    "most_likely_states = arhmm.most_likely_states(neural_data)\n",
    "\n",
    "arhmm.permute(find_permutation(state, most_likely_states))\n",
    "most_likely_states = arhmm.most_likely_states(neural_data)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Evaluate arHMM"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "arHMM_W = arhmm.observations.As\n",
    "arHMM_state = most_likely_states"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure(figsize=(14, 4))\n",
    "plt.subplot(211)\n",
    "plt.plot(arHMM_state, 'black', linewidth=1)\n",
    "names = ['running', 'stationary sync', 'stationary desync']\n",
    "plt.yticks([0, 1, 2], names, fontsize=12)\n",
    "plt.title('AR-HMM inferred states')\n",
    "\n",
    "plt.subplot(212)\n",
    "plt.plot(state, 'black', linewidth=1)\n",
    "plt.yticks([0, 1, 2], names, fontsize=12)\n",
    "plt.title('true states')\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "corr_strength_KK: 0.16690515261654337\n",
      "spearman_corr_strength_KK: 0.21518107116515492\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "state0_KK_strength = tools.multisession_NN_to_KK(\n",
    "    [arHMM_W[0]],\n",
    "    cell_type_order,\n",
    "    all_sessions_new_cell_type_id,\n",
    ")\n",
    "state0_KK_strength = tools.experiment_KK_to_eval_KK(state0_KK_strength, cell_type_order, eval_cell_type_order)\n",
    "\n",
    "corr_strength_KK = stats.pearsonr(KK_GT.flatten(), state0_KK_strength.flatten())[0]\n",
    "spearman_corr_strength_KK = stats.spearmanr(KK_GT.flatten(), state0_KK_strength.flatten())[0]\n",
    "print('corr_strength_KK:', corr_strength_KK)\n",
    "print('spearman_corr_strength_KK:', spearman_corr_strength_KK)\n",
    "\n",
    "plt.imshow(state0_KK_strength, cmap='RdBu_r', interpolation=\"nearest\", vmin=-np.max(np.abs(state0_KK_strength)), vmax=np.max(np.abs(state0_KK_strength)))\n",
    "plt.colorbar()\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "corr_strength_KK: -0.32502110110587334\n",
      "spearman_corr_strength_KK: -0.20339032753966696\n"
     ]
    },
    {
     "data": {
      "image/png": "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e2PFxsYqKirKL0572v7qq68kSdOnT9fDDz+siooKff3111q4cKGqq6s1atQoVVZWttnX5kgEAADGeCzLyCZJ3bt3l9vt9m0LFiw4Y7sJCQlyOBwBb+25c/4h8PxtkYXbb79dzzzzjC677DIlJCRo+vTpeuSRR1RdXa0VK1YEFZOnBgAAP0gVFRW+u2JJio6OPuO599xzj2prawOOffHFF0v6+934me74a2pq/M47m+axunXr5nesrq5OTU1NfnHa07bb7VZVVZXuuOOOFuePHDlSv/nNb3zDB4EiEQAAGGPyXQMul8svETibRYsWtaut1sbumystLZXT6VRSUlJAsfbs2aPS0tIWiUBr8wHa0/Y111yjqqoqde3atcX53n3ff/99m31tjqEBAIAx3rcP2tpCuLLggAEDFB0drY0bN7Zot7KyUh999JH69++vmJiYNmOlp6dLkgoLC1sc864s6D2nvW0PHjxYkvTJJ5+0aMO778orr2yzr82RCAAAIpbL5dLdd9+tsrIyLV261LffsizNmjVLHo9HDz74oN9nvvvuO+3fv1+HDh3y2z9mzBi53W4tWrRIFRUVvv2VlZV6/vnn1bVrV40ePdpW29nZ2YqOjtaiRYv05Zdf+vbX1tbq17/+ta8fwWBoAABgjGVgQaBQv4b4mWeeUVFRkR566CFt2rRJKSkp2rZtm7Zv366srCxNmDDB7/x3331XmZmZSk9P95t0GB8fr9zcXN13333q16+fxo4dK6fTqfz8fB07dkyvvPKK36qC7Wn7qquu0m9/+1v9/Oc/13XXXaef/vSnio6O1vr163Xw4EFNnjxZQ4YMCer7UxEAABgTji8dSkxM1O7du5Wdna3t27frueee07FjxzR37ly9+eabAb9nQJLGjx+vt99+W6mpqXr55Zf14osv6pprrtGGDRs0fvx4I21Pnz5db731llJTU/X6669rxYoV6tatm1544QUtW7Ys6O/vsAK44jU1NadnKpbukysuLuhGEDzLQY4WclzzkPL8ueU4Ks6dmrrvddG//FzV1dUBT8ALKv7ffieueuAVOTt2thXL0/Cdylfcd876Cn8MDQAAjDH51ABCg0QAAGCMx2NJNn/IQ/nSIZAIAAAMsjxNsjxNtmMgdBgUBQAgglERAAAYQ0Ug/JAIAACMsTweA4mAx1BvEAiGBgAAiGBUBAAA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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "state1_KK_strength = tools.multisession_NN_to_KK(\n",
    "    [arHMM_W[1]],\n",
    "    cell_type_order,\n",
    "    all_sessions_new_cell_type_id,\n",
    ")\n",
    "state1_KK_strength = tools.experiment_KK_to_eval_KK(state1_KK_strength, cell_type_order, eval_cell_type_order)\n",
    "\n",
    "corr_strength_KK = stats.pearsonr(KK_GT.flatten(), state1_KK_strength.flatten())[0]\n",
    "spearman_corr_strength_KK = stats.spearmanr(KK_GT.flatten(), state1_KK_strength.flatten())[0]\n",
    "print('corr_strength_KK:', corr_strength_KK)\n",
    "print('spearman_corr_strength_KK:', spearman_corr_strength_KK)\n",
    "\n",
    "plt.imshow(state1_KK_strength, cmap='RdBu_r', interpolation=\"nearest\", vmin=-np.max(np.abs(state1_KK_strength)), vmax=np.max(np.abs(state1_KK_strength)))\n",
    "plt.colorbar()\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "corr_strength_KK: 0.14295913592141143\n",
      "spearman_corr_strength_KK: 0.14443660941222727\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "state2_KK_strength = tools.multisession_NN_to_KK(\n",
    "    [arHMM_W[2]],\n",
    "    cell_type_order,\n",
    "    all_sessions_new_cell_type_id,\n",
    ")\n",
    "state2_KK_strength = tools.experiment_KK_to_eval_KK(state2_KK_strength, cell_type_order, eval_cell_type_order)\n",
    "\n",
    "corr_strength_KK = stats.pearsonr(KK_GT.flatten(), state2_KK_strength.flatten())[0]\n",
    "spearman_corr_strength_KK = stats.spearmanr(KK_GT.flatten(), state2_KK_strength.flatten())[0]\n",
    "print('corr_strength_KK:', corr_strength_KK)\n",
    "print('spearman_corr_strength_KK:', spearman_corr_strength_KK)\n",
    "\n",
    "plt.imshow(state2_KK_strength, cmap='RdBu_r', interpolation=\"nearest\", vmin=-np.max(np.abs(state2_KK_strength)), vmax=np.max(np.abs(state2_KK_strength)))\n",
    "plt.colorbar()\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# get one vmin and vmax for all states\n",
    "max_abs = np.max(np.abs([state0_KK_strength, state1_KK_strength, state2_KK_strength]))\n",
    "vmin_KK = -max_abs\n",
    "vmax_KK = max_abs\n",
    "\n",
    "plt.imshow(state0_KK_strength, cmap='RdBu_r', vmin=vmin_KK, vmax=vmax_KK)\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "plt.show()\n",
    "plt.imshow(state1_KK_strength, cmap='RdBu_r', vmin=vmin_KK, vmax=vmax_KK)\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "plt.show()\n",
    "plt.imshow(state2_KK_strength, cmap='RdBu_r', vmin=vmin_KK, vmax=vmax_KK)\n",
    "plt.colorbar()\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "NetFormer",
   "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.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
