{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/gw2397/.local/lib/python3.8/site-packages/numpy/core/getlimits.py:499: UserWarning: The value of the smallest subnormal for <class 'numpy.float64'> type is zero.\n",
      "  setattr(self, word, getattr(machar, word).flat[0])\n",
      "/home/gw2397/.local/lib/python3.8/site-packages/numpy/core/getlimits.py:89: UserWarning: The value of the smallest subnormal for <class 'numpy.float64'> type is zero.\n",
      "  return self._float_to_str(self.smallest_subnormal)\n",
      "/home/gw2397/.local/lib/python3.8/site-packages/numpy/core/getlimits.py:499: UserWarning: The value of the smallest subnormal for <class 'numpy.float32'> type is zero.\n",
      "  setattr(self, word, getattr(machar, word).flat[0])\n",
      "/home/gw2397/.local/lib/python3.8/site-packages/numpy/core/getlimits.py:89: UserWarning: The value of the smallest subnormal for <class 'numpy.float32'> type is zero.\n",
      "  return self._float_to_str(self.smallest_subnormal)\n"
     ]
    }
   ],
   "source": [
    "from __future__ import division\n",
    "import sys\n",
    "sys.path.insert(0, '/home/gw2397/cluster_new')\n",
    "sys.path.insert(0, '/home/gw2397/pyhsmm-autoregressive-master')\n",
    "sys.path.insert(0, '/home/gw2397/nbRegg_mcmc')\n",
    "\n",
    "import numpy as np\n",
    "from matplotlib import pyplot as plt\n",
    "from scipy.linalg import *\n",
    "from scipy.interpolate import *\n",
    "from cluster_functions import *\n",
    "\n",
    "\n",
    "import pyhsmm\n",
    "from pyhsmm.util.text import progprint_xrange\n",
    "from pyhsmm.util.stats import whiten, cov\n",
    "\n",
    "import autoregressive.models as m\n",
    "import autoregressive.distributions as d\n",
    "\n",
    "from polyagamma import random_polyagamma\n",
    "from pyhmc import hmc\n",
    "import statsmodels.api as sm\n",
    "import statsmodels.formula.api as smf\n",
    "from scipy.special import gamma, digamma\n",
    "from scipy.stats import norm, nbinom, multivariate_normal, poisson\n",
    "from tqdm import tqdm\n",
    "import heapq\n",
    "\n",
    "import numpy.matlib\n",
    "import time\n",
    "from IPython import display\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "import copy\n",
    "\n",
    "import pickle\n",
    "\n",
    "from pymc3_hpd import *\n",
    "from scipy import stats\n",
    "from scipy.linalg import lstsq"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "from __future__ import division\n",
    "import sys\n",
    "sys.path.insert(0, '/home/gw2397/cluster_new')\n",
    "sys.path.insert(0, '/home/gw2397/pyhsmm-autoregressive-master')\n",
    "sys.path.insert(0, '/home/gw2397/nbRegg_mcmc')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Load results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "path = \"/scratch/gw2397/sim_Poi/\"\n",
    "filename = \"Poi_sim\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(path + filename + '_t_fit.pkl', 'rb') as f: t_fit_Poi = pickle.load(f)\n",
    "with open(path + filename + '_states_fit.pkl', 'rb') as f: states_fit_Poi = pickle.load(f)\n",
    "with open(path + filename + '_Z_fit.pkl', 'rb') as f: Z_fit_Poi = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "n_iter = t_fit_Poi.shape[0]\n",
    "iter_use_start = int(n_iter/4)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 1. Similarity Matrices"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 10\n",
    "nClus = 3\n",
    "p = 2\n",
    "T = 500\n",
    "\n",
    "np.random.seed(0)\n",
    "lab_neuron = np.repeat(np.arange(nClus), n)\n",
    "\n",
    "dd = np.random.normal(size = (n*nClus,1))*0.5\n",
    "C_true= np.random.normal(size = (nClus*n,p))*0.5\n",
    "\n",
    "# works well\n",
    "As = [block_diag(0.01*np.eye(p+1), \n",
    "                 0.01*np.eye(p+1), \n",
    "                 0.01*np.eye(p+1)),\n",
    "      block_diag(1.01*random_rotation(p+1, theta= np.pi/20),\n",
    "                 1.01*random_rotation(p+1, theta= np.pi/20),\n",
    "                 1.01*random_rotation(p+1, theta= np.pi/20))]\n",
    "\n",
    "\n",
    "truemodel = m.ARHSMM(\n",
    "        alpha=5.,init_state_concentration=5.,\n",
    "        obs_distns=[d.AutoRegression(A=A,sigma=np.eye(nClus*(p+1))*1e-2) for A in As],\n",
    "        dur_distns=[pyhsmm.basic.distributions.PoissonDuration(alpha_0=100,beta_0=2)\n",
    "            for state in range(len(As))],\n",
    "        )\n",
    "\n",
    "\n",
    "X_all_tmp, lab_t_tmp = truemodel.generate(2*T, keep=True)\n",
    "X_all = X_all_tmp[501:,:].T\n",
    "lab_t = lab_t_tmp[500:]\n",
    "\n",
    "\n",
    "muX_all = []\n",
    "for cc in range(nClus):\n",
    "    muX_all.append(X_all[(cc*(p+1)):((cc+1)*(p+1)),:])\n",
    "    \n",
    "dynm = {}\n",
    "dynm['As'] = np.zeros((2,3*(p+1),3*(p+1)))\n",
    "dynm['bs'] = np.zeros((2,3*(p+1)))\n",
    "dynm['Qs'] = np.zeros((2,3*(p+1),3*(p+1)))\n",
    "dynm['states'] = np.zeros((T,), dtype = int)\n",
    "\n",
    "\n",
    "# muX_b, C_b, delt_b.ravel(), dynamics_b\n",
    "\n",
    "muX_all, C_true, _, _ = constraint(muX_all, C_true,dd.reshape((-1, 1)),dynm, lab_neuron)    \n",
    "X_all = np.zeros_like(X_all)\n",
    "for cc in range(nClus):\n",
    "    X_all[(cc*(p+1)):((cc+1)*(p+1)),:] = muX_all[cc]\n",
    "\n",
    "    \n",
    "C_trans = np.zeros((n*nClus, (p+1)*nClus))\n",
    "for cc in range(nClus):\n",
    "    C_trans[(n*cc):(n*(cc+1)),(cc*(p+1)):((cc+1)*(p+1))] = np.column_stack((np.ones((n,1)), C_true[(n*cc):(n*(cc+1)),:]))    \n",
    "    \n",
    "Lam_true = np.exp(dd + C_trans @ X_all)\n",
    "r_true = np.ones((n*nClus,1))*10\n",
    "p_true = r_true/(r_true+Lam_true)\n",
    "y = np.random.negative_binomial(r_true, p_true, size=None)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 1A. neuron"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "N = Z_fit_Poi.shape[1]\n",
    "simMat_neuron = np.zeros((N,N))\n",
    "count = 0\n",
    "for g in range(iter_use_start, n_iter):\n",
    "    count = count + 1\n",
    "    for k in range(simMat_neuron.shape[0]):\n",
    "        simMat_neuron[k,:] = simMat_neuron[k,:] + (Z_fit_Poi[g,k] == Z_fit_Poi[g,:])\n",
    "simMat_neuron = simMat_neuron/count\n",
    "\n",
    "simMat_neuron_true = np.zeros((N,N))\n",
    "for k in range(simMat_neuron_true.shape[0]):\n",
    "    simMat_neuron_true[k,:] = (lab_neuron[k] == lab_neuron)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x216 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.rcParams['figure.figsize'] = [7, 3]\n",
    "fig, ax = plt.subplots(1, 2)\n",
    "z1 = ax[0].imshow(simMat_neuron, aspect=\"auto\", cmap = 'Greys')\n",
    "ax[0].set_title('samples')\n",
    "plt.colorbar(z1, ax= ax[0])\n",
    "z2 = ax[1].imshow(simMat_neuron_true, aspect=\"auto\", cmap = 'Greys')\n",
    "ax[1].set_title('true')\n",
    "plt.colorbar(z2, ax= ax[1])\n",
    "fig.tight_layout()\n",
    "\n",
    "plt.rcParams['figure.figsize'] = [5, 5]\n",
    "plt.savefig(\"simMat_neuron_poi.svg\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 1B. states"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "simMat_state = np.zeros((T,T))\n",
    "count = 0\n",
    "\n",
    "for g in range(iter_use_start, n_iter):\n",
    "    count = count + 1\n",
    "    for k in range(simMat_state.shape[0]):\n",
    "        simMat_state[k,:] = simMat_state[k,:] + (states_fit_Poi[g,k] == states_fit_Poi[g,:])\n",
    "simMat_state = simMat_state/count\n",
    "\n",
    "simMat_state_true = np.zeros((T,T))\n",
    "for k in range(simMat_state_true.shape[0]):\n",
    "    simMat_state_true[k,:] = (lab_t[k] == lab_t)\n",
    "sim_order = np.append(np.where(lab_t == 0)[0], np.where(lab_t == 1)[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x216 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.rcParams['figure.figsize'] = [7, 3]\n",
    "fig, ax = plt.subplots(1, 2)\n",
    "z1 = ax[0].imshow(simMat_state[np.ix_(sim_order, sim_order)], aspect=\"auto\", cmap = 'Greys')\n",
    "ax[0].set_title('samples')\n",
    "plt.colorbar(z1, ax= ax[0])\n",
    "z2 = ax[1].imshow(simMat_state_true[np.ix_(sim_order, sim_order)], aspect=\"auto\", cmap = 'Greys')\n",
    "ax[1].set_title('true')\n",
    "plt.colorbar(z2, ax= ax[1])\n",
    "fig.tight_layout()\n",
    "\n",
    "plt.rcParams['figure.figsize'] = [5, 5]\n",
    "plt.savefig(\"simMat_states_poi.svg\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 2. maxPEAR of states"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "states_samp_use = states_fit_Poi[iter_use_start:,:]\n",
    "np.savetxt(\"states_samp.csv\", states_samp_use, delimiter=\",\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "states_samp_maxPEAR = np.loadtxt(\"states_samp_maxPEAR.csv\", delimiter=\",\", dtype = int) - 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "473"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.unique(states_samp_maxPEAR) # 2\n",
    "swap = {0: 1, 1:0}\n",
    "states_samp_maxPEAR_swap = np.array([swap[x] for x in states_samp_maxPEAR])\n",
    "\n",
    "sum((states_samp_maxPEAR - lab_t)**2)\n",
    "sum((states_samp_maxPEAR_swap - lab_t)**2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x36 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.rcParams['figure.figsize'] = [6, .5]\n",
    "plt.imshow(states_samp_maxPEAR[None,:], aspect=\"auto\", cmap='Pastel1')\n",
    "plt.xlim([0, T])\n",
    "plt.savefig(\"states_maxPEAR_poi.svg\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.8.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
