{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import scipy\n",
    "import matplotlib.pyplot as plt\n",
    "import sys\n",
    "import pandas as pd\n",
    "import pickle\n",
    "from glob import glob\n",
    "from tqdm import tqdm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "from utils import apply_df_filters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# # Consolidating fits if run manually\n",
    "# rl = []\n",
    "# fls = glob('soc_ccm_output_path/*.pkl')\n",
    "# for fl in fls:\n",
    "#     with open(fl, 'rb') as f:\n",
    "#         while True:\n",
    "#             try:\n",
    "#                 task = pickle.load(f)\n",
    "#                 nn = pickle.load(f)\n",
    "#                 Upca = pickle.load(f)\n",
    "#                 coef = pickle.load(f)\n",
    "#                 phi = pickle.load(f)\n",
    "#                 scores = pickle.load(f)\n",
    "\n",
    "#                 rep, inner_rep, r = task\n",
    "#                 rep = int(rep)\n",
    "#                 inner_rep = int(inner_rep)\n",
    "\n",
    "#                 rd = {}\n",
    "#                 rd['R'] = r\n",
    "#                 rd['nn'] = nn\n",
    "#                 rd['rep'] = rep\n",
    "#                 rd['inner_rep'] = inner_rep\n",
    "#                 rd['phi'] = phi\n",
    "#                 rl.append(rd)\n",
    "#             except EOFError:\n",
    "#                 break\n",
    "# df = pd.DataFrame(rl)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load results\n",
    "with open('soc_df.pkl', 'rb') as f:\n",
    "    df = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "R = np.unique(df['R'].values)\n",
    "reps = np.unique(df['rep'].values)\n",
    "inner_reps = np.unique(df['inner_rep'].values)\n",
    "\n",
    "# Need to re-run keeping track of T\n",
    "ssa = np.zeros((R.size, reps.size, inner_reps.size))\n",
    "nn = np.zeros((R.size, reps.size, inner_reps.size))\n",
    "for i, r in enumerate(R):\n",
    "    for j, rep in enumerate(reps):\n",
    "        for k, irep in enumerate(inner_reps):\n",
    "            df_ = apply_df_filters(df, R=r, rep = rep, inner_rep=irep)    \n",
    "            assert(df_.shape[0] == 1)\n",
    "            ssa[i, j, k] = df_.iloc[0]['phi']\n",
    "            nn[i, j, k] = df_.iloc[0]['nn']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# ## Consolidating fits if run manually\n",
    "# rl = []\n",
    "# fls = glob('soc_poisson_output_path/*.pkl')\n",
    "# for fl in fls:\n",
    "#     with open(fl, 'rb') as f:\n",
    "#         while True:\n",
    "#             try:\n",
    "#                 elem = pickle.load(f)\n",
    "#                 if isinstance(elem, dict):\n",
    "#                     rl.append(elem)\n",
    "#             except EOFError:\n",
    "#                 break\n",
    "# df_p = pd.DataFrame(rl)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load results\n",
    "with open('soc_poisson_df.pkl', 'rb') as f:\n",
    "    dfp = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "dims = [2]\n",
    "T = [3]\n",
    "R = np.unique(dfp['R'].values)\n",
    "reps = np.unique(dfp['rep'].values)\n",
    "inner_reps = np.unique(dfp['inner_rep'].values)\n",
    "\n",
    "ssa_p = np.zeros((R.size, reps.size, inner_reps.size, len(dims), len(T)))\n",
    "nn_p = np.zeros((R.size, reps.size, inner_reps.size))\n",
    "for i, r in enumerate(R):\n",
    "    for j, rep in enumerate(reps):\n",
    "        for k, irep in enumerate(inner_reps):\n",
    "            df_ = apply_df_filters(dfp, R=r, rep = rep, inner_rep=irep)    \n",
    "            for l, dim in enumerate(dims):\n",
    "                for m, t in enumerate(T):         \n",
    "                    df__ = apply_df_filters(df_, dim=dim, T=t)\n",
    "                    if df_.shape[0] == 0:\n",
    "                        ssa_p[i, j, k, l, m] = np.nan\n",
    "                        nn_p[i, j, k] = np.nan\n",
    "                    else:\n",
    "                        nn_p[i, j, k] = df__.iloc[0]['nn']\n",
    "                        c1 = df__.iloc[0]['pca_coef']\n",
    "                        c2 = df__.iloc[0]['fcca_coef']\n",
    "                        ssa_p[i, j, k, l, m] = np.mean(scipy.linalg.subspace_angles(c1, c2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f3429e648b0>"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(4, 4))\n",
    "ax.plot(np.nanmean(nn, axis=(1, 2)), \n",
    "        np.nanmean(ssa, axis=(1, 2)), color='k', linestyle='-')\n",
    "ax.fill_between(np.nanmean(nn, axis=(1, 2)), \n",
    "                np.nanmean(ssa, axis=(1, 2)) + \\\n",
    "                    np.nanstd(ssa, axis=(1, 2)),\n",
    "                np.nanmean(ssa, axis=(1, 2)) - \\\n",
    "                    np.nanstd(ssa, axis=(1, 2)),\n",
    "                alpha=0.25, color='k')\n",
    "\n",
    "ax.plot(np.nanmean(nn_p, axis=(1, 2)), \n",
    "        np.nanmean(ssa_p[..., 0, 0], axis=(1, 2)), color='b')\n",
    "ax.fill_between(np.nanmean(nn_p, axis=(1, 2)), \n",
    "               np.nanmean(ssa_p[..., 0, 0], axis=(1, 2)) + \\\n",
    "                np.nanstd(ssa_p[..., 0, 0], axis=(1, 2)),\n",
    "               np.nanmean(ssa_p[..., 0, 0], axis=(1, 2)) - \\\n",
    "                np.nanstd(ssa_p[..., 0, 0], axis=(1, 2)),\n",
    "               alpha=0.25, color='b')\n",
    "ax.set_ylim([0, np.pi/2])\n",
    "ax.set_yticks([0, np.pi/8, np.pi/4, 3*np.pi/8, np.pi/2])\n",
    "ax.set_yticklabels([0, r'$\\pi/8$', r'$\\pi/4$', r'$3\\pi`/8$', r'$\\pi/2$'])\n",
    "ax.set_xscale('log')\n",
    "ax.legend(['LDS', 'Count LDS'], loc='lower right')\n",
    "#fig.savefig('soc_ssa_coplot.pdf', bbox_inches='tight', pad_inches=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Switching system plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# # Consolidating if outputs if run manually\n",
    "# rl = []\n",
    "# fls = glob('soc_ns_output_path/*.pkl')\n",
    "# for fl in fls:\n",
    "#     with open(fl, 'rb') as f:\n",
    "#         while True:\n",
    "#             try:\n",
    "#                 elem = pickle.load(f)\n",
    "#                 if isinstance(elem, dict):\n",
    "#                     rl.append(elem)\n",
    "#             except EOFError:\n",
    "#                 break\n",
    "# df = pd.DataFrame(rl)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load results\n",
    "with open('soc_ns_df.pkl', 'rb') as f:\n",
    "    df = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "R = np.unique(df['R'].values)\n",
    "reps = np.unique(df['rep'].values)\n",
    "inner_reps = np.unique(df['inner_rep'].values)\n",
    "\n",
    "ssa = np.zeros((R.size, reps.size, inner_reps.size))\n",
    "nn = np.zeros((R.size, reps.size, inner_reps.size))\n",
    "for i, r in enumerate(R):\n",
    "    for j, rep in enumerate(reps):\n",
    "        for k, irep in enumerate(inner_reps):\n",
    "            df_ = apply_df_filters(df, R=r, rep = rep, inner_rep=irep)    \n",
    "            if df_.shape[0] == 0:\n",
    "                ssa[i, j, k] = np.nan   \n",
    "                nn[i, j, k] = np.nan\n",
    "            else:\n",
    "                nn[i, j, k] = np.mean(df_.iloc[0]['nn'])\n",
    "                c1 = df_.iloc[0]['pca_coef']\n",
    "                c2 = df_.iloc[0]['fcca_coef']\n",
    "                ssa[i, j, k] = np.mean(scipy.linalg.subspace_angles(c1, c2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(4, 4))\n",
    "ax.plot(np.nanmean(nn, axis=(1, 2)), \n",
    "        np.nanmean(ssa, axis=(1, 2)), color='k', linestyle='-')\n",
    "ax.fill_between(np.nanmean(nn, axis=(1, 2)), \n",
    "                np.nanmean(ssa, axis=(1, 2)) + \\\n",
    "                    np.nanstd(ssa, axis=(1, 2)),\n",
    "                np.nanmean(ssa, axis=(1, 2)) - \\\n",
    "                    np.nanstd(ssa, axis=(1, 2)),\n",
    "                alpha=0.25, color='k')\n",
    "\n",
    "ax.set_ylim([0, np.pi/2])\n",
    "ax.set_yticks([0, np.pi/8, np.pi/4, 3*np.pi/8, np.pi/2])\n",
    "ax.set_yticklabels([0, r'$\\pi/8$', r'$\\pi/4$', r'$3\\pi`/8$', r'$\\pi/2$'])\n",
    "ax.set_xscale('log')\n",
    "#fig.savefig('ssa_ns.pdf')"
   ]
  },
  {
   "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.11.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
