{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import evaluation.evaluate as evaluate\n",
    "import matplotlib.pyplot as plt\n",
    "import math_utils.matrix_utils as matrix_utils\n",
    "import models.regression_models as reg_models\n",
    "import models.PLDS as PLDS\n",
    "import numpy as np\n",
    "import os\n",
    "import PGLDSID.PGLDSID as PGLDSID\n",
    "import PGLDSID.SDP_optimize as SDP_optimize\n",
    "import visualization.visualization as viz_utils"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = np.load(os.path.join(os.getcwd(), 'sample_data', 'sample_sys.npz'), allow_pickle=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "### Prepare the data.\n",
    "Y, Z, params = data['Y'], data['Z'], data['params'][()]\n",
    "Ytrain, Ztrain = Y[:int(1e6), :].astype('float64'), Z[:int(1e6), :]\n",
    "Ytest, Ztest = Y[-int(1e6):, :].astype('float64'), Z[-int(1e6):, :]\n",
    "\n",
    "##### Without loss of generality, demean the Gaussian observations.\n",
    "Zmean = np.mean(Ztrain, axis=0, keepdims=True)\n",
    "Ztrain -= Zmean\n",
    "Ztest -= Zmean"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The optimal value is 46.354467039999236 with status: optimal\n",
      "The optimal value is 6.152844128904793 with status: optimal\n"
     ]
    }
   ],
   "source": [
    "n1 = nx = 4\n",
    "i = 10 # horizon\n",
    "\n",
    "### PG-LDS-ID Stage 1 only.\n",
    "pgldsid_params = PGLDSID.PGLDSID(i, nx, Ytrain.T, Z=Ztrain.T, n1=n1, Z_horizon=i)\n",
    "pgldsid_params = SDP_optimize.optimize(pgldsid_params)\n",
    "\n",
    "### PLDSID.\n",
    "pldsid_params = PGLDSID.PGLDSID(i, nx, Ytrain.T, n1=0)\n",
    "pldsid_params = SDP_optimize.optimize(pldsid_params)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "### Extracting shared and disjoint modes in Y, as well as the unencoded (i.e., disjoint) modes in Z.\n",
    "shared_eigs = np.linalg.eigvals(matrix_utils.extract_block(params['A'], params['rev_statesz']))\n",
    "disjoint_dims = np.delete(params['rev_statesy'], params['rev_statesz'])\n",
    "y_only_eigs = np.linalg.eigvals(matrix_utils.extract_block(params['A'], disjoint_dims))\n",
    "z_only_eigs = np.linalg.eigvals(params['eps_sysz']['A'])\n",
    "\n",
    "pgldsid_eigs = np.linalg.eigvals(pgldsid_params['A'])\n",
    "pldsid_eigs = np.linalg.eigvals(pldsid_params['A'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "### Visualizing the identified modes by both learning algorithms vs. ground truth modes.\n",
    "colors = { # Colors for visualizing the modes.\n",
    "  'shared': '#39b54a', 'y only': '#e5542c', 'z only': '#0071bd', 'pgldsid': '#39b54a', 'pldsid': '#e5542c'}\n",
    "\n",
    "viz_utils.plot_eigenvalues(\n",
    "  [shared_eigs, y_only_eigs, z_only_eigs, pgldsid_eigs, pldsid_eigs],\n",
    "  'n1=nx=4', labels=['shared', 'y only', 'z only', 'pgldsid', 'pldsid'],\n",
    "   markers=['o', 'o', 'o', 'x', 'x'],\n",
    "   edgecolors=[colors['shared'], colors['y only'], colors['z only'], None, None],\n",
    "   facecolors=['None', 'None', 'None', colors['pgldsid'], colors['pldsid']],\n",
    "   alpha_vals=[0.4, 0.4, 0.4, 0.8, 0.8],\n",
    "   bound_lims_to_circle=False, show_legend=True, legend_location='upper left', fig=None, ax=None)\n",
    "plt.xlim([0.8, 1.0])\n",
    "plt.ylim([-0.35, 0.35])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "### Demonstarting decoding performance. This block will take some time to run as we're testing on 1e6 contiguous\n",
    "### samples and the point-process filter runs recursively.\n",
    "\n",
    "#### PG-LDS-ID\n",
    "pgldsid_sys = PLDS.update_missing_params_and_construct_PLDS(pgldsid_params)\n",
    "\n",
    "other_out = {'Z': pgldsid_params['Cz']}\n",
    "pgldsid_y_pred, _, other_est = pgldsid_sys.predict(Ytest, other_out)\n",
    "pgldsid_z_pred = other_est['Z']\n",
    "pgldsid_z_evalres = evaluate.evaluate_results(Ztest, pgldsid_z_pred, ['CC'])['CC']\n",
    "\n",
    "#### Handle prediction covariances to compute AUC.\n",
    "Pp = other_est.get('Pp', None) # Prediction error covariance.\n",
    "assert (Pp is not None)\n",
    "log_rate_covariances = Pp @ pgldsid_params['C'].T # (time, nx, nr)\n",
    "log_rate_covariances = np.transpose(log_rate_covariances, (0, 2, 1)) @ pgldsid_params['C'].T # (time, nr, nr)\n",
    "pgldsid_y_evalres = evaluate.evaluate_results(\n",
    "                      Ytest, pgldsid_y_pred, ['AUC'], predicted_covariances=log_rate_covariances)['AUC']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "#### PLDSID\n",
    "pldsid_sys = PLDS.update_missing_params_and_construct_PLDS(pldsid_params)\n",
    "\n",
    "##### First fit Cz.\n",
    "_, x_pred, _ = pldsid_sys.predict(Ytrain, {}) # predict xTrain\n",
    "reg_kwargs = {'fit_intercept': True}\n",
    "regression = reg_models.RegressionModel(reg_models.RegressionMethod.OLS_REG)\n",
    "## Must be (num_samples, num_features)\n",
    "regression.fit(x_pred, Ztrain, **reg_kwargs)\n",
    "reg_weights, reg_intercept = regression.weights()\n",
    "pldsid_params['Cz'] = reg_weights\n",
    "\n",
    "##### Now predict test data.\n",
    "other_out = {'Z': pldsid_params['Cz']}\n",
    "pldsid_y_pred, _, other_est = pldsid_sys.predict(Ytest, other_out)\n",
    "pldsid_z_pred = other_est['Z']\n",
    "\n",
    "pldsid_z_evalres = evaluate.evaluate_results(Ztest, pldsid_z_pred, ['CC'])['CC']\n",
    "\n",
    "#### Handle prediction covariances to compute AUC.\n",
    "Pp = other_est.get('Pp', None) # Prediction error covariance.\n",
    "assert (Pp is not None)\n",
    "log_rate_covariances = Pp @ pldsid_params['C'].T # (time, nx, nr)\n",
    "log_rate_covariances = np.transpose(log_rate_covariances, (0, 2, 1)) @ pldsid_params['C'].T # (time, nr, nr)\n",
    "pldsid_y_evalres = evaluate.evaluate_results(\n",
    "                    Ytest, pldsid_y_pred, ['AUC'], predicted_covariances=log_rate_covariances)['AUC']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "PG-LDS-ID Z prediction CC 0.46216264610684094, PLDSID Z prediction CC 0.4096154663324887\n",
      "PG-LDS-ID Y prediction AUC 0.5447589112937984, PLDSID Y prediction AUC 0.5592364736580343\n"
     ]
    }
   ],
   "source": [
    "print(f'PG-LDS-ID Z prediction CC {pgldsid_z_evalres.mean()}, PLDSID Z prediction CC {pldsid_z_evalres.mean()}')\n",
    "print(f'PG-LDS-ID Y prediction AUC {pgldsid_y_evalres.mean()}, PLDSID Y prediction AUC {pldsid_y_evalres.mean()}')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Including stage 2 and using the true shared and disjoint latent state dimensions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The optimal value is 6.034638926762543 with status: optimal\n",
      "The optimal value is 2.548239739182338 with status: optimal\n"
     ]
    }
   ],
   "source": [
    "n1 = 4; nx = 8\n",
    "i = 10 # horizon\n",
    "\n",
    "# PG-LDS-ID Stage 1 + 2 only.\n",
    "pgldsid_params = PGLDSID.PGLDSID(i, nx, Ytrain.T, Z=Ztrain.T, n1=n1, Z_horizon=i)\n",
    "pgldsid_params = SDP_optimize.optimize(pgldsid_params)\n",
    "\n",
    "# PLDSID.\n",
    "pldsid_params = PGLDSID.PGLDSID(i, nx, Ytrain.T, n1=0)\n",
    "pldsid_params = SDP_optimize.optimize(pldsid_params)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAVsAAAF2CAYAAADA/TsFAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABT3ElEQVR4nO3dd3hUVf4/8PedPpNpmfRAQkIIkFAC0sQCqFFc0F3UFVBEOiqCSlxXUGkWwP3RVqSIBVBEEBW+LCKKlEUFAROQklBCS0gyaZMpmV7u7w/MLGMmIWUmycx8Xs8zzwP3nnvvmRl45+Tcc89hWJZlQQghxK84rV0BQggJBRS2hBDSAihsCSGkBVDYEkJIC6CwJYSQFkBhSwghLYDClhBCWgCFLSGEtAAKW0IIaQEUtoQQ0gIobInf/PDDD5g0aRK6d+8OLpeLpKQkv17vnXfeAcMw6N69u1+v01K2bt2Kp556CqmpqWAYBkOGDKm3fE5ODv76179CpVJBIpGge/fueO+991qmsuSWeK1dARK8Nm/ejK1bt+K2225DfHy8X691/fp1LFy4EGFhYX69Tktas2YNsrOz0a9fP1RWVtZb9ocffsDDDz+M3r17Y86cOZBKpbh06RKuX7/eQrUlt8LQRDTEX4qLixEVFQU+n4+HHnoIZ86cwdWrV/1yrdGjR6O8vBxOpxMVFRU4c+aMX67TkgoLC9GuXTtwOBx0794dkZGROHjwYK1yer0enTt3xh133IGvvvoKHA79wtoW0bdCGmX+/PlgGAb5+fkYP348lEolFAoFJkyYAJPJ5FE2Pj4efD7f73U6dOgQvvrqK6xYsaLZ59qwYQMYhsEvv/yCrKwsREVFISwsDI888gjKy8vd5fbv3w8Oh4O5c+d6HL9582YwDIM1a9Y0uy4JCQkNCs7NmzejtLQU77zzDjgcDoxGI1wuV7OvT3yLuhFIk4wcORLJyclYtGgRcnJy8NFHHyE6Ohrvvvtuo8/lcrmg0WgaVFahUHgEuNPpxIwZMzB58mT06NGj0deuy4wZMxAeHo558+bh6tWrWLFiBaZPn46tW7cCAO69915MmzYNixYtwogRI3DbbbehpKQEM2bMQGZmJp599ln3uXQ6Hex2+y2vKRKJIJVKG13XH3/8EXK5HEVFRRgxYgQuXLiAsLAwjB07FsuXL4dIJGr0OYkfsIQ0wrx581gA7MSJEz22P/LII2xERESdxw0fPpzt0KGD131XrlxhATTodeDAAY9j33//fVahULBlZWUsy7Ls4MGD2W7dujX5/a1fv54FwGZmZrIul8u9febMmSyXy2W1Wq17m9FoZDt16sR269aNtVgs7PDhw1m5XM5eu3bN45yDBw9u0HsbN25cnfXq1q0bO3jwYK/7evbsyUokElYikbAzZsxgv/76a3bGjBksAHb06NFN/iyIb1HLljTJzS03ALj77ruxfft26PV6yOXyRp0rNjYWe/fubVDZjIwM958rKysxd+5czJkzB1FRUY265q1MnToVDMO4/3733Xdj+fLluHbtGnr27AkAkEgk2LBhAwYNGoRBgwbh2LFj+Pjjj5GYmOhxrqVLl6KqquqW12zqTcTq6mqYTCY8++yz7tEHjz76KGw2Gz744AO8+eabSE1NbdK5ie9Q2JIm+XOghIeHAwCqqqoaHbYikQiZmZmNrsMbb7wBlUqFGTNmNPrYW6nv/d3szjvvxHPPPYdVq1Zh6NChmDhxYq1z9enTx+f1u5lYLAYAPPHEEx7bn3zySXzwwQc4cuQIhW0bQGFLmoTL5XrdzjZhcIvT6fS4+VQflUoFgUCAixcvYt26dVixYgWKi4vd+y0WC+x2O65evQq5XA6VStXo+gANf39Wq9U9QuDSpUswmUyQSCQeZTQaDWw22y2vKRaLoVAoGl3X+Ph4nD17FjExMR7bo6OjAdT+AUFaB41GIK2usLAQcXFxDXodPnwYAFBUVASXy4UXXngBycnJ7tfRo0dx4cIFJCcn48033/R73efNm4e8vDwsWbIEV65cwaxZs2qVefTRRxv03l588cUm1aGm5VxUVOSxveaHkK+7WEjTUMuWtLqm9Nl2794d27dvr7X/jTfegMFgwL///W+kpKT4tJ5/dvToUSxZsgQvvfQSXn75ZVRUVODdd9/FY489hsGDB7vL+bvPduTIkVi8eDE+/vhj3Hvvve7tH330EXg83i2fPCMtg8KW+M2pU6ewc+dOAEB+fj50Oh3efvttADdC8+GHHwbQtD7byMhIjBgxotb2mrG2f943f/58LFiwAAcOHPBJ+FgsFowbNw6pqal45513AAALFizAf/7zH0yYMAGnT592P83W1D7bQ4cO4dChQwCA8vJyGI1G9+dXc1MOAHr37o2JEyfik08+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",
      "text/plain": [
       "<Figure size 800x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "### Visualizing the identified modes by both learning algorithms vs. ground truth modes.\n",
    "\n",
    "pgldsid_eigs = np.linalg.eigvals(pgldsid_params['A'])\n",
    "pldsid_eigs = np.linalg.eigvals(pldsid_params['A'])\n",
    "\n",
    "viz_utils.plot_eigenvalues(\n",
    "  [shared_eigs, y_only_eigs, z_only_eigs, pgldsid_eigs, pldsid_eigs],\n",
    "  'n1=4, nx=16', labels=['shared', 'y only', 'z only', 'pgldsid', 'pldsid'],\n",
    "   markers=['o', 'o', 'o', 'x', 'x'],\n",
    "   edgecolors=[colors['shared'], colors['y only'], colors['z only'], None, None],\n",
    "   facecolors=['None', 'None', 'None', colors['pgldsid'], colors['pldsid']],\n",
    "   alpha_vals=[0.4, 0.4, 0.4, 0.8, 0.8],\n",
    "   bound_lims_to_circle=False, show_legend=True, legend_location='upper left', fig=None, ax=None)\n",
    "plt.xlim([0.8, 1.0])\n",
    "plt.ylim([-0.35, 0.35])\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "pgldsid_demo",
   "language": "python",
   "name": "pgldsid_demo"
  },
  "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.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
