{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# <u> Plot the Speed-Accuracy Tradeoff Curves </u>\n",
    "\n",
    "See `save_SATC_materials_as_npy_nmnist.py` in each subproject directory (Note: each subproject has different `save_SATC_materials_as_npy_nmnist.py` for each) for npy filenaming rules and formats."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from __future__ import absolute_import, division, print_function\n",
    "\n",
    "import os, sys, glob, copy, pdb\n",
    "from itertools import zip_longest\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.ticker as ticker\n",
    "import numpy as np\n",
    "import scipy.io\n",
    "import tensorflow as tf\n",
    "from mpl_toolkits.axes_grid1.inset_locator import mark_inset\n",
    "from matplotlib.ticker import LogFormatter, ScalarFormatter, NullFormatter"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Subfunctions\n",
    "def interp(ht, list_x, list_y):\n",
    "    \"\"\"\n",
    "    Args:\n",
    "        ht: An integer, a target hitting time\n",
    "        list_x: A list. Sorted mean hitting times of a single model with various thresholds.\n",
    "        list_y: A list. Correspoinding balanced accuracies.\n",
    "    Returns:\n",
    "        y: A float. Interpolated value of balanced accuracy at hitting time = ht.\n",
    "    \"\"\"\n",
    "    assert list_x[0] <= ht <= list_x[-1]\n",
    "    \n",
    "    if list_x[0] <= ht < list_x[-1]:\n",
    "        for iter_idx in range(len(list_x - 1)):\n",
    "            if (list_x[iter_idx] <= ht) and (ht < list_x[iter_idx + 1]):\n",
    "                grad = (list_y[iter_idx + 1] - list_y[iter_idx])/(list_x[iter_idx + 1] - list_x[iter_idx])\n",
    "                x = ht\n",
    "                y = grad * (x - list_x[iter_idx]) + list_y[iter_idx]\n",
    "\n",
    "    elif ht == list_x[-1]:\n",
    "        y = list_y[-1]\n",
    "        \n",
    "    else:\n",
    "        raise ValueError\n",
    "        \n",
    "    return y\n",
    "\n",
    "\n",
    "def plot_SPRT(paths_sns, paths_mhts, target_hts, num_classes):\n",
    "    \"\"\" Processes subproject-wise npys.\n",
    "    Args:\n",
    "        paths_sns: A list of paths to *sns.npy files of a single subproject.\n",
    "            len = num of trials in the subproject.\n",
    "        paths_mhts: A list of paths to *mht.npy files of a single subproject.\n",
    "            len = num of trials in the subproject.\n",
    "        target_hts: A list of floats. 0 < values =< duration.\n",
    "    Returns:\n",
    "        xs_subproj: A list with shape (num classes + 1, ? variable for each dim)\n",
    "        ys_subproj: A list with shape (num classes + 2, ? variable for each dim)\n",
    "        yerrs_subproj: A list with shape (num classes + 2, ? variable for each dim)\n",
    "    \"\"\"\n",
    "    # Load npy\n",
    "    npys_sns = []\n",
    "    npys_mht = []\n",
    "    for path_sns, path_mht in zip(paths_sns, paths_mht): # model (trial) loop\n",
    "        npys_sns.append(np.load(path_sns))\n",
    "        npys_mht.append(np.load(path_mht))\n",
    "    npys_sns = np.array(npys_sns)\n",
    "        # (num of trials, num of thresh, num of classes + 2)\n",
    "    npys_mht = np.array(npys_mht)\n",
    "        # (num of trials, num of thresh, num of classes + 1)\n",
    "        \n",
    "    # Remove target hitting times that needs extrapolation\n",
    "    min_last_mhts = np.min(npys_mht[:, -1, :], axis=0)\n",
    "        # (num cls + 1)\n",
    "    max_first_mhts = np.max(npys_mht[:, 0, :], axis=0)\n",
    "        # (num cls + 1)\n",
    "\n",
    "    xs_subproject = []\n",
    "    for itr_first, itr_last in zip(max_first_mhts, min_last_mhts): # class + 1 loop\n",
    "        possible_target_hts = copy.deepcopy(target_hts)\n",
    "        for iter_ht in target_hts:\n",
    "            if not (itr_first <= iter_ht <= itr_last):\n",
    "                try:\n",
    "                    possible_target_hts.remove(iter_ht)\n",
    "                except ValueError as e:\n",
    "                    pass\n",
    "                else:\n",
    "                    print(\"Extrapolation is not supported.\")\n",
    "                    print(\"Skip target hitting time:\", iter_ht)\n",
    "\n",
    "        xs_subproject.append(possible_target_hts) # ===================> That's it!!\n",
    "            # (num cls + 1, ? and is variable =< num_target_hits)\n",
    "            # Thus cannot execute, e.g., np.array(classwise_target_hts) in general.\n",
    "            \n",
    "    # Calc errorbars\n",
    "    ys_subproject = []\n",
    "    yerrs_subproject = []\n",
    "    for itr_cls in range(len(xs_subproject)+1): # class + 2 loop\n",
    "        itr_target_hits = xs_subproject[np.min([itr_cls, num_classes])]\n",
    "            # variable lengths\n",
    "        \n",
    "        # Calc mean and standard error\n",
    "        ys_cls = []\n",
    "        yerrs_cls = []\n",
    "        for itr_ht in itr_target_hits:\n",
    "            ys = [\n",
    "                interp(\n",
    "                    itr_ht, \n",
    "                    npys_mht[i, :, np.min([itr_cls, num_classes])], \n",
    "                    npys_sns[i, :, itr_cls]\n",
    "                ) for i in range(len(npys_mht))\n",
    "            ]\n",
    "                # (num of trials,)\n",
    "                            \n",
    "            y = np.mean(ys)\n",
    "            yerr = np.sqrt(np.var(ys) / len(ys))\n",
    "\n",
    "            ys_cls.append(y)\n",
    "            yerrs_cls.append(yerr)\n",
    "                # to be (? and is variable)\n",
    "\n",
    "        ys_subproject.append(ys_cls) # =========================> That's it!!\n",
    "        yerrs_subproject.append(yerrs_cls) # ===================> That's it!!\n",
    "            # to be (num cls + 2, ? and is variable)\n",
    "            \n",
    "    return xs_subproject, ys_subproject, yerrs_subproject\n",
    "\n",
    "\n",
    "def plot_NPT(paths_snsNPT, duration, num_classes):\n",
    "    \"\"\" Processes subproject-wise npys.\n",
    "    Args:\n",
    "        paths_snsNPT: A list of paths to *sns.npy files of a single subproject.\n",
    "            len = num of trials in the subproject.\n",
    "    Returns:\n",
    "        xs_subproj: A list with shape (num classes + 1, duration)\n",
    "        ys_subproj: A list with shape (num classes + 2, duration)\n",
    "        yerrs_subproj: A list with shape (num classes + 2, duration)\n",
    "    \"\"\"\n",
    "    # Load npy\n",
    "    npys_sns = []\n",
    "    for path_sns in paths_snsNPT: # model (trial) loop\n",
    "        npys_sns.append(np.load(path_sns))\n",
    "    npys_sns = np.array(npys_sns)\n",
    "        # (num of trials, duration, num of classes + 2)\n",
    "\n",
    "    xs_subproj = np.array([i + 1 for i in range(duration)])\n",
    "    xs_subproj = np.tile(xs_subproj, (num_classes + 1, 1))    # ===================> That's it!!\n",
    "        # (num cls + 1, duration)\n",
    "    ys_subproj = np.mean(npys_sns, axis=0)\n",
    "    ys_subproj = np.transpose(ys_subproj)    # ===================> That's it!!\n",
    "        # (num cls + 2, duration)\n",
    "    yerrs_subproj = np.sqrt(np.var(npys_sns, axis=0) / npys_sns.shape[0])\n",
    "    yerrs_subproj = np.transpose(yerrs_subproj)    # ===================> That's it!!\n",
    "        # (num cls + 2, duration)\n",
    "            \n",
    "    return xs_subproj, ys_subproj, yerrs_subproj\n",
    "\n",
    "\n",
    "def plot_LSTMsm(paths_sns, paths_mhts):\n",
    "    \"\"\" Processes subproject-wise npys.\n",
    "    Args:\n",
    "        paths_sns: A list of paths to *sns.npy files of a single subproject.\n",
    "            len = num of trials in the subproject.\n",
    "        paths_mhts: A list of paths to *mht.npy files of a single subproject.\n",
    "            len = num of trials in the subproject.\n",
    "    Returns:\n",
    "        xs_subproj: A list with shape (num classes + 1, duration)\n",
    "        ys_subproj: A list with shape (num classes + 2, duration)\n",
    "        yerrs_subproj: A list with shape (num classes + 2, duration)\n",
    "    \"\"\"\n",
    "    # Load npy\n",
    "    npys_sns = []\n",
    "    npys_mht = []\n",
    "    for path_sns, path_mht in zip(paths_sns, paths_mht): # model (trial) loop\n",
    "        npys_sns.append(np.load(path_sns))\n",
    "        npys_mht.append(np.load(path_mht))\n",
    "    npys_sns = np.array(npys_sns)\n",
    "        # (num of trials, duration, num of classes + 2)\n",
    "    npys_mht = np.array(npys_mht)\n",
    "        # (num of trials, duration, num of classes + 1)\n",
    "\n",
    "    xs_subproj = np.mean(npys_mht, axis=0) \n",
    "    xs_subproj = np.transpose(xs_subproj)    # ===================> That's it!!\n",
    "        # (num cls + 1, duration)\n",
    "    ys_subproj = np.mean(npys_sns, axis=0)\n",
    "    ys_subproj = np.transpose(ys_subproj)    # ===================> That's it!!\n",
    "        # (num cls + 2, duration)\n",
    "    yerrs_subproj = np.sqrt(np.var(npys_sns, axis=0) / npys_sns.shape[0])\n",
    "    yerrs_subproj = np.transpose(yerrs_subproj)    # ===================> That's it!!\n",
    "        # (num cls + 2, duration)\n",
    "            \n",
    "    return xs_subproj, ys_subproj, yerrs_subproj\n",
    "\n",
    "\n",
    "def plot_SATcurve(x_, y_, err_, label_, color_, inset=False):\n",
    "    if inset:\n",
    "        for plot_x, plot_y, plot_err, label, color in zip(\n",
    "            x_, y_, err_, label_, color_):\n",
    "            axins.errorbar(\n",
    "                plot_x, 100 * np.array(plot_y), 100 * np.array(plot_err),\n",
    "                fmt=\"x\", \n",
    "                markersize=3, \n",
    "                markeredgewidth=2,\n",
    "                capsize=5,\n",
    "                linewidth=1,\n",
    "                markeredgecolor=color,\n",
    "                markerfacecolor=color,\n",
    "                ecolor=color,\n",
    "                label=label,\n",
    "                )\n",
    "    else:\n",
    "        for plot_x, plot_y, plot_err, label, color in zip(\n",
    "            x_, y_, err_, label_, color_):\n",
    "            plt.errorbar(\n",
    "                    plot_x, 100 * np.array(plot_y), 100 * np.array(plot_err),\n",
    "                    fmt=\"x\", \n",
    "                    markersize=3, \n",
    "                    markeredgewidth=2,\n",
    "                    capsize=5,\n",
    "                    linewidth=1,\n",
    "                    markeredgecolor=color,\n",
    "                    markerfacecolor=color,\n",
    "                    ecolor=color,\n",
    "                    label=label,\n",
    "                    )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 1. User-defined Parameters 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 193,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Major parameters\n",
    "num_target_hts = 100 # How many points plotted.\n",
    "    # Note: target_hts = list(np.linspace(1, duration, num_target_hts))\n",
    "append_target_hits = [\n",
    "    #4.372728443145752, # to compare with EARLIEST\n",
    "    #19.660273065933815,\n",
    "] # to compare with EARLIEST\n",
    "\n",
    "  #########################################\n",
    " #            MSPRT TANDEM(wO)           #\n",
    "#########################################\n",
    "allpaths_subproj= [\n",
    "    \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-1000f/graphs/npy/100f15p_M_ver20201115_stat\",\n",
    "    \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-1000f/graphs/npy/100f15p_MO_ver20201115_stat\",\n",
    "    \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-1000f/graphs/npy/100f15p_LD_ver20201115_stat\",\n",
    "    \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-1000f/graphs/npy/100f15p_LOD_ver20201115_stat\",\n",
    "    \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-1000f/graphs/npy/100f15p_D_ver20201115_stat\",\n",
    "    \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-1000f/graphs/npy/100f15p_E_ver20201207_stat\",\n",
    "    \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-1000f/graphs/npy/100f15p_OE_ver20201207_stat\",\n",
    "    \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-1000f/graphs/npy/100f15p_OD_ver20201115_stat\",\n",
    "    \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-1000f/graphs/npy/100f15p_LOE_ver20201207_stat\",\n",
    "    \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-1000f/graphs/npy/100f15p_LE_ver20201207_stat\",\n",
    "]\n",
    "labels_plot = [\n",
    "    \"TANDEM      mult\",\n",
    "    \"TANDEMwO mult\",\n",
    "    \"TANDEM      SLEL\",\n",
    "    \"TANDEMwO SLEL\",\n",
    "    \"TANDEM      mult+SLEL\",\n",
    "    \"TANDEM      mult+LSEL\",\n",
    "    \"TANDEMwO mult+LSEL\",\n",
    "    \"TANDEMwO mult+SLEL\",\n",
    "    \"TANDEMwO LSEL\",\n",
    "    \"TANDEM      LSEL\",\n",
    "]\n",
    "colors_plot = [\n",
    "    'mediumblue', \n",
    "    'deepskyblue', \n",
    "    'mediumseagreen',\n",
    "    'purple',\n",
    "    'blue',#None,\n",
    "    'red',\n",
    "    'darkorange', \n",
    "    'magenta',#None,\n",
    "    None,\n",
    "    None,\n",
    "    #None,\n",
    "]\n",
    "\n",
    "  #######################################\n",
    " #             NP test                 #\n",
    "#######################################\n",
    "labels_plot_NPT = [v + \" NPT\" for v in labels_plot]\n",
    "colors_plot_NPT = [\"blue\"] * len(colors_plot)\n",
    "#colors_plot_NPT = colors_plot\n",
    "\n",
    "  #######################################\n",
    " #             LSTM-s/m                #\n",
    "#######################################\n",
    "allpaths_subproj_LSTMsm= [\n",
    "    \"/data/t-miyagawa/sprt_rankingmcc/nosaic_mnist-1000f/graphs/npy/LSTMs_ver20201204_stat\", \n",
    "    \"/data/t-miyagawa/sprt_rankingmcc/nosaic_mnist-1000f/graphs/npy/LSTMm_ver20201204_stat\", \n",
    "]\n",
    "labels_plot_LSTMsm = [\n",
    "    \"LSTM-s\",\n",
    "    \"LSTM-m\"\n",
    "]\n",
    "colors_plot_LSTMsm = [\n",
    "    'brown', \n",
    "    'black', \n",
    "]\n",
    "\n",
    "  #######################################\n",
    " #             EARLIEST                #\n",
    "#######################################\n",
    "allpaths_subproj_EARLIEST= [\n",
    "    \"/data/t-miyagawa/sprt_earliestmcc/nosaic_mnist-1000f/graphs/npy/Lam1e-2_ver20201204_stat\",\n",
    "    \"/data/t-miyagawa/sprt_earliestmcc/nosaic_mnist-1000f/graphs/npy/Lam1e-4_ver20201204_stat\",\n",
    "]\n",
    "labels_plot_EARLIEST = [\n",
    "    \"EARLIEST Lam=1e-2\",\n",
    "    \"EARLIEST Lam=1e-4\",\n",
    "]\n",
    "colors_plot_EARLIEST = [\n",
    "    'brown', \n",
    "    'black',\n",
    "    #\"navy\",\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 177,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Minor parameters\n",
    "duration = 100\n",
    "num_classes = 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 194,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Automatically fixed parameters\n",
    "# SPRT\n",
    "allpaths_sns = [glob.glob(allpath_subproj + \"/*sns.npy\") for allpath_subproj in allpaths_subproj]\n",
    "allpaths_mht = [glob.glob(allpath_subproj + \"/*mht.npy\") for allpath_subproj in allpaths_subproj]\n",
    "allpaths_snsNPT = [glob.glob(allpath_subproj + \"/*snsNPT.npy\") for allpath_subproj in allpaths_subproj]\n",
    "target_hts = list(np.linspace(1, duration, num_target_hts))\n",
    "for i in append_target_hits:\n",
    "    target_hts.append(i)\n",
    "\n",
    "# LSTM-s/m\n",
    "allpaths_sns_LSTMsm = [glob.glob(allpath_subproj_LSTMsm + \"/*sns.npy\") for allpath_subproj_LSTMsm in allpaths_subproj_LSTMsm]\n",
    "allpaths_mht_LSTMsm = [glob.glob(allpath_subproj_LSTMsm + \"/*mht.npy\") for allpath_subproj_LSTMsm in allpaths_subproj_LSTMsm]\n",
    "\n",
    "# EARLIEST\n",
    "allpaths_sns_EARLIEST = [glob.glob(allpath_subproj_EARLIEST + \"/*sns.npy\") for allpath_subproj_EARLIEST in allpaths_subproj_EARLIEST]\n",
    "allpaths_mht_EARLIEST = [glob.glob(allpath_subproj_EARLIEST + \"/*mht.npy\") for allpath_subproj_EARLIEST in allpaths_subproj_EARLIEST]\n",
    "\n",
    "\n",
    "# Assertion checks\n",
    "for paths_sns, paths_mht, paths_snsNPT, path_subproj in zip(\n",
    "    allpaths_sns, allpaths_mht, allpaths_snsNPT, allpaths_subproj):\n",
    "    assert len(paths_sns) != 0, \"No *_sns.npy found under {}.\\n Typo? Make sure the last slash is removed.\".format(path_subproj)\n",
    "    assert len(paths_mht) != 0, \"No *_mht.npy found under {}.\\n Typo? Make sure the last slash is removed.\".format(path_subproj)\n",
    "    assert len(paths_snsNPT) != 0, \"No *_snsNPT.npy found under {}.\\n Typo? Make sure the last slash is removed.\".format(path_subproj)\n",
    "assert len(allpaths_subproj) == len(labels_plot)\n",
    "assert len(allpaths_subproj) == len(colors_plot)\n",
    "\n",
    "for paths_sns, paths_mht, path_subproj in zip(\n",
    "    allpaths_sns_LSTMsm, allpaths_mht_LSTMsm, allpaths_subproj_LSTMsm):\n",
    "    assert len(paths_sns) != 0, \"No *_sns.npy found under {}.\\n Typo? Make sure the last slash is removed.\".format(path_subproj)\n",
    "    assert len(paths_mht) != 0, \"No *_mht.npy found under {}.\\n Typo? Make sure the last slash is removed.\".format(path_subproj)\n",
    "    assert len(paths_snsNPT) != 0, \"No *_snsNPT.npy found under {}.\\n Typo? Make sure the last slash is removed.\".format(path_subproj)\n",
    "assert len(allpaths_subproj_LSTMsm) == len(labels_plot_LSTMsm)\n",
    "assert len(allpaths_subproj_LSTMsm) == len(colors_plot_LSTMsm)\n",
    "\n",
    "for paths_sns, paths_mht, path_subproj in zip(\n",
    "    allpaths_sns_EARLIEST, allpaths_mht_EARLIEST, allpaths_subproj_EARLIEST):\n",
    "    assert len(paths_sns) != 0, \"No *_sns.npy found under {}.\\n Typo? Make sure the last slash is removed.\".format(path_subproj)\n",
    "    assert len(paths_mht) != 0, \"No *_mht.npy found under {}.\\n Typo? Make sure the last slash is removed.\".format(path_subproj)\n",
    "    assert len(paths_snsNPT) != 0, \"No *_snsNPT.npy found under {}.\\n Typo? Make sure the last slash is removed.\".format(path_subproj)\n",
    "assert len(allpaths_subproj_EARLIEST) == len(labels_plot_EARLIEST)\n",
    "assert len(allpaths_subproj_EARLIEST) == len(colors_plot_EARLIEST)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 2. Calculate\n",
    "`allpaths_sns` etc.: all subprojects, all models\n",
    "\n",
    "`paths_sns` etc.: all models of a subproject"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "It may take a few minutes...\n",
      "SPRT & NPT\n",
      "1 / 10: TANDEM   mult\n",
      "... wait...\n",
      "2 / 10: TANDEMwO mult\n",
      "... wait...\n",
      "3 / 10: TANDEM        SLEL\n",
      "... wait...\n",
      "4 / 10: TANDEMwO      SLEL\n",
      "... wait...\n",
      "5 / 10: TANDEM   mult+SLEL\n",
      "... wait...\n",
      "6 / 10: TANDEM   mult+LSEL\n",
      "... wait...\n",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 1.0\n",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 1.0\n",
      "7 / 10: TANDEMwO mult+LSEL\n",
      "... wait...\n",
      "8 / 10: TANDEMwO mult+SLEL\n",
      "... wait...\n",
      "9 / 10: TANDEMwO      LSEL\n",
      "... wait...\n",
      "10 / 10: TANDEM        LSEL\n",
      "... wait...\n",
      "Done.\n"
     ]
    }
   ],
   "source": [
    "# Calculate values in advance\n",
    "allxs = []\n",
    "    # to be (num subproj, num cls + 1, ?)\n",
    "allys = []\n",
    "    # to be (num subproj, num cls + 2, ?)\n",
    "allyerrs = []\n",
    "    # to be (num subproj, num cls + 2, ?)\n",
    "\n",
    "allxs_NPT = []\n",
    "allys_NPT = []\n",
    "allyerrs_NPT = []\n",
    "\n",
    "# Subproject loop\n",
    "cnt = 1\n",
    "print(\"It may take a few minutes...\")\n",
    "print(\"SPRT & NPT\")\n",
    "for paths_sns, paths_mht, paths_snsNPT, label in zip(\n",
    "    allpaths_sns, allpaths_mht, allpaths_snsNPT, labels_plot):\n",
    "    print(\"{} / {}: {}\\n... wait...\".format(cnt, len(allpaths_sns), label))\n",
    "    \n",
    "    xs_subproj, ys_subproj, yerrs_subproj = plot_SPRT(\n",
    "        paths_sns, \n",
    "        paths_mht, \n",
    "        target_hts,\n",
    "        num_classes)\n",
    "    allxs.append(xs_subproj)\n",
    "    allys.append(ys_subproj)\n",
    "    allyerrs.append(yerrs_subproj)\n",
    "    \n",
    "    xs_subproj, ys_subproj, yerrs_subproj = plot_NPT(\n",
    "        paths_snsNPT,\n",
    "        duration, \n",
    "        num_classes)\n",
    "    allxs_NPT.append(xs_subproj)\n",
    "    allys_NPT.append(ys_subproj)\n",
    "    allyerrs_NPT.append(yerrs_subproj)\n",
    "\n",
    "    cnt += 1\n",
    "\n",
    "print(\"Done.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 188,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "LSTM-s/m\n",
      "1 / 2: LSTM-s\n",
      "...wait...\n",
      "2 / 2: LSTM-m\n",
      "...wait...\n",
      "Done.\n"
     ]
    }
   ],
   "source": [
    "allxs_LSTMsm = []\n",
    "allys_LSTMsm = []\n",
    "allyerrs_LSTMsm = []\n",
    "\n",
    "cnt = 1\n",
    "print(\"LSTM-s/m\")\n",
    "for paths_sns, paths_mht, label in zip(\n",
    "    allpaths_sns_LSTMsm, allpaths_mht_LSTMsm, labels_plot_LSTMsm):\n",
    "    print(\"{} / {}: {}\\n...wait...\".format(cnt, len(allpaths_sns_LSTMsm), label))\n",
    "    \n",
    "    xs_subproj, ys_subproj, yerrs_subproj = plot_LSTMsm(\n",
    "        paths_sns, \n",
    "        paths_mht)\n",
    "    allxs_LSTMsm.append(xs_subproj)\n",
    "    allys_LSTMsm.append(ys_subproj)\n",
    "    allyerrs_LSTMsm.append(yerrs_subproj)\n",
    "    \n",
    "    cnt += 1    \n",
    "\n",
    "print(\"Done.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 195,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "EARLIEST\n",
      "1 / 2: EARLIEST Lam=1e-2\n",
      "...wait...\n",
      "2 / 2: EARLIEST Lam=1e-4\n",
      "...wait...\n",
      "Done.\n"
     ]
    }
   ],
   "source": [
    "allxs_EARLIEST = []\n",
    "allys_EARLIEST = []\n",
    "allyerrs_EARLIEST = []\n",
    "\n",
    "cnt = 1\n",
    "print(\"EARLIEST\")\n",
    "for paths_sns, paths_mht, label in zip(\n",
    "    allpaths_sns_EARLIEST, allpaths_mht_EARLIEST, labels_plot_EARLIEST):\n",
    "    print(\"{} / {}: {}\\n...wait...\".format(cnt, len(allpaths_sns_EARLIEST), label))\n",
    "    \n",
    "    xs_subproj, ys_subproj, yerrs_subproj = plot_LSTMsm(\n",
    "        paths_sns, \n",
    "        paths_mht)\n",
    "    allxs_EARLIEST.append(xs_subproj)\n",
    "    allys_EARLIEST.append(ys_subproj)\n",
    "    allyerrs_EARLIEST.append(yerrs_subproj)\n",
    "    \n",
    "    cnt += 1    \n",
    "    \n",
    "print(\"Done.\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 3. Plot (includes user-defined parameters 2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 202,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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jKHcTwFVxMTEBAsWLAAASKVSREZGiufs7OwAQNwAXpni88XxREREREREb7rXsgAEgNq1a8PZ2RkAcOfOHfF41apVAQDPnj0TVwNV5MGDB3LxREREREREb7rXtgBURnblT9kVQV9VfK5BgwZGz4mIiIiIiKg8eG0LwNu3byMtLQ0A4OXlJR7/4IMPxNU/9+/fr7DtvXv3cP36dQBAx44djZwpERERERFR+VAuC0BBzcKkgiBg4sSJAIo+D9i1a1fxXKVKldCrVy8AwK+//or09PQS7efOnQug6PN/PXr0MFTaRERERERE5Vq5LADv3buH5s2bY+XKlbhz545YEEqlUpw5cwadO3fG77//DgAYMWIE6tWrJ9d+1qxZqFSpElJSUtCtWzckJCQAALKzszFr1iysWLECADB16lQ4ODiU4p0RERERERGVHbOyTkCZuLg4xMXFAQAsLS1hZ2eHzMxMuT37hgwZgl9++aVEWy8vL2zbtg19+vTByZMnUbduXdjb2yMrK0vcd2PIkCHiKCIREREREVFFUC4LQFdXVyxZsgSnT5/GxYsXkZqaimfPnsHKygpeXl54//33MXToULRq1UppH5988gkuX76MuXPn4tChQ0hJSYGDgwN8fX0xYsQIcZooERERERFRRVEuC0Bra2uMHj0ao0eP1quft99+G6tWrTJQVkRERERERK+3cvkZQCIiIiIiIjI8FoBEREREREQVBAtAIiIiIiKiCoIFIBERERERUQXBApCIiIiIiKiCYAFIRERERERUQbAAJCIiIiIiqiBYABIREREREVUQLACJiIiIiIgqCBaAREREREREFQQLQCIiIiIiogqCBSAREREREVEFwQKQiIiIiIiogjDTp7EgCEhLS0Nqairy8vLg5OQEFxcX2NjYGCo/IiIiIiIiMhCtC8Do6Gjs378fx48fR1xcHF6+fFkiplq1amjTpg3atGmDgIAAODg4GCRZIiIiIiIi0p1GBWBmZibWrVuHVatW4fr16wCKRv+USUpKwqZNmxAeHo4xY8agT58+GDlyJFq0aGGYrImIiIiIiEhrKgvAwsJCrFixArNmzUJaWhoEQUClSpXQtGlT+Pn5wdfXF87OznB0dIS1tTWePn2Kp0+fIjExEbGxsYiNjcXt27exceNGbNq0CV27dsX8+fNRt25dnZL98ccf8c0334ivVRWh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kZycDD8/v6pOhYiIiMzM4A6gNt7e3vAuN7scERERERERVQ8GPwNIRERERERENRM7gERERERERHWEziGgMTExkpwoKIgrShEREREREVUlnR3AESNGiAu+G0smk7EDSEREREREVMX0ngTGlDWhuJ4UERERERFR1dP7GcDmzZsjPDwcV65cQWFhocEbERFVT5GRwJUr9REZWdWZEBERkbnp7AAuWrQILVu2xJUrVzB//ny0bNkSgwYNws6dO1FSUgJLS0u9NiIiqh5kMtUtLAwYM6YrwsJUy4mIiKj20dkBnDlzJs6fP48DBw4gJCQEdnZ2+OmnnxAYGAg3NzdMnjwZx48fr4xciYiIiIiIyAR6DwH19fXFunXr8M8//+A///kPunfvjszMTHz99dfo0qULOnfujK+//hp37941Z75ERGQiQXi8KRSqdQrF4zoiIiKqfQxeB7B+/foYPXo0Dhw4gAsXLmDGjBlwd3fHiRMn8P7778PDwwPDhg3DsWPHzJEvERFJKDT0Uadv3boUKBSP9omIiKj2Mmkh+JYtWyIiIgJXr17F7t278cYbb0AQBOzYsQNbtmyRKkciIjKj0FCgefM8dv6IiIjqAJM6gKUePnyIW7du4fbt25zxk4iIiIiIqJrSex1ATQ4dOoTo6Ghs27YNubm5EAQBDRo0wJtvvokxY8ZIlSMRERERERFJwOAOYEZGBjZu3Ij169fj4sWLEAQBFhYWCAgIwOjRozFkyBDY2tqaI1ciIiIiIiIygV4dwMLCQuzatQvr1q1DYmIiSkpKIAgCnn76aYwaNQohISFo0qSJuXMlIiIiIiIiE+jsAL733nuIiYnBvXv3IAgC5HI53njjDYwZMwa9evWqjByJiKgGivH21lxebj/o7FnzJ0NEREQA9OgAKhQKyGQyNGvWDCEhIRg2bBgcHR0BPBoOqi93d3fjsyQiohonODVVfN3H2RnutrbwksuRplQiIz8fiffuAQCCqipBIiKiOkjvZwDT09MRHh6O8PBwg08ik8lQVFRk8HFERLWWTKZW5KcprpasyJ5y/z6y/tfhA4AGVibNQUZERERG0msZCEEQTN6IiKju8pLLte4TERFR5dD5FWxiYmJl5EFEVLeU/WLszBmgffvH+6dPA+3aVX5OEiv75V9kZCQOh4WJ+8EREfiNK88TERFVOp0dQH9//8rIg4iobtEwBFRUtjNYS0ZQhP6vsyeXy6FUKsV9IiIiqlx8CIOIiCpFaGgokpOT4efnV9WpEBER1Vl6PQNIREQSEwS1LTkpSb2ciIiISEJaO4APHz40y0nN1S4RERERERFVTGsH8Omnn8aKFSuQn58vyclOnDiBwYMHY9myZZK0R0RERERERPrT2gHMy8vDlClT8PTTT2POnDlIS0sz+AQPHjxATEwM+vfvDx8fH8THx4sLyRMREREREVHl0ToJzKVLlzB37lysXbsWixcvxuLFi9GhQwf07NkTzz33HDp27Ignn3wSDRs2hI2NDbKyspCZmYm//voLf/zxB44cOYKkpCTk5eVBEAQ888wzWLJkCV599dXKen9ERFRFNE906qdWwkcdiYiIKo/WDuCTTz6JlStXYvLkyVi+fDm2bNmCkydP4tSpU4iMjNTZeOkaUJ07d0ZoaChGjhwJS0tLaTInIiIiIiIig+g1C2ibNm2wdu1aZGRk4JtvvsGgQYPg7OwMQRA0bjKZDM8++yw++OADpKSk4OjRoxg9ejQ7f0RERERERFXIoHUAHRwc8M477+Cdd94BAFy8eBEZGRn4999/8fDhQ7i4uODJJ5/EM888AwcHB7MkTERENUPZoZ2RkUBY2ON9hQKQci34CzExKPzfz9ZBQdI1TEREVMuYtBB8q1at0KpVK6lyISKiWqq0syeXp0Cp7Gpy5y/G21tlPyEzE15yOTYrlei7aJFYHnT2rGknIiIiqmVM6gASERHpKzQUSE7Og5+f6W0Fp6aKrxtYWSGrqEjc33XnjrjPe4FERESq9HoGkIiIqLryksu17hMREdFj7AASEVGNdjgnR+s+ERERPcYhoEREVOMI5RYPjIyMhFwuh1KpRKiUs8sQERHVMuwAEhFRjRcaGork5GT4SfGAIRERUS3GIaBERERERER1BDuAREREREREdQQ7gERERERERHUEO4BERERERER1BDuAREREREREdYTWWUAzMjIkO5G7u7tkbREREREREZHhtHYAmzRpIslJZDIZioqKJGmLiIiIiIiIjKN1CKggCJJsJSUllfV+iIioDoqMBK5cqY/ISGnauxATg8KMDFyIiZGmQSIiompC6x3AixcvVlYeRERUWWQytSI/TXGCYO5MjKbhLQDoCgAIC3tcou9biPH2VtlPyMyEl1yOzUol+i5aJJYHnT1r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\n",
      "text/plain": [
       "<Figure size 936x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# 0. User-defined parameters 2 are here!\n",
    "########################################\n",
    "class_plot = 10 # 0, 1, 2, ...,9, 10 (macroave),11 (microave=ACC) for NMNIST\n",
    "indices = []\n",
    "#indices = [0,1,2,3,4,5,6,7,8,9] all\n",
    "#indices = [0,1,4,5,6] good fellows\n",
    "#indices = [2,3] # 1: TANDEM vs TANDEMwO (SLEL): tradeoff. TANDEM is better at later steps.\n",
    "#indices = [8,9] # 2: TANDEM vs TANDEMwO (LSEL): tradeoff. TANDEM is better at later steps.\n",
    "#indices = [2,9] # 3-1: LSEL vs SLEL (TANDEM): LSEL is better.\n",
    "#indices = [3,8] # 4-1: LSEL vs SLEL (TANDEMwO): LSEL is better.\n",
    "#indices = [4,5] # 3-2: Combo(LSEL) vs Combo(SLEL) (TANDEM): LSEL is better.\n",
    "#indices = [6,7] # 4-2: Combo(LSEL) vs Combo(SLEL) (TANDEMwO): Almost the same. LSEL looks slightly better.\n",
    "#indices = [0,5,9] # 5-1: Xent vs LSEL vs Combo(LSEL). (TANDEM): Combo. is the strongest indomitable powerhouse!\n",
    "#indices = [5,9] # 5-2: LSEL vs Combo(LSEL). (TANDEM): same as above.\n",
    "#indices = [1,6,8] # 6-1: Xent vs LSEL vs Combo(LSEL). (TANDEMwO): Combo.= Xent > LSEL. A SATC bounce at later steps, BECAUSE of the Oblivion!\n",
    "#indices = [6,8] # 6-2: LSEL vs Combo(LSEL). (TANDEMwO): same as above.\n",
    "indices = [5] # 7: Combo(LSEL) for NPT: Temporal instability observed.\n",
    "\n",
    "#indices_NPT = [0,1,2,3,4,5,6,7,8,9] # 8:all\n",
    "indices_NPT = [5]# 7: Combo(LSEL) for NPT.\n",
    "#indices_NPT = [] # default\n",
    "\n",
    "indices_LSTMsm = [0,1]\n",
    "indices_EARLIEST = [0,1]\n",
    "\n",
    "# 1. Initialize figure\n",
    "############################\n",
    "title = \"NMNIST-100frames SAT curve\"\n",
    "xlabel = \"Mean hitting time (#frames)\"\n",
    "if class_plot < num_classes:\n",
    "    _tmp = \"(Class={})\".format(class_plot)\n",
    "elif class_plot == num_classes:\n",
    "    _tmp = \"(Mac-ave)\"\n",
    "elif class_plot == num_classes + 1:\n",
    "    _tmp = \"(Mic-ave)\"\n",
    "else:\n",
    "    raise ValueError\n",
    "ylabel = \"100 - Recall {} (%)\".format(_tmp)\n",
    "plt.rcParams[\"font.size\"] = 25\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(13,8)) ###\n",
    "#fig, ax = plt.subplots(figsize=(11,8)) ###\n",
    "#fig, ax = plt.subplots(figsize=(10,8)) ###\n",
    "fig.patch.set_facecolor('white')\n",
    "\n",
    "# 2. Main plot\n",
    "################\n",
    "# Scale\n",
    "ax.set_xscale('log')\n",
    "ax.set_yscale('log')\n",
    "\n",
    "# Ticks\n",
    "#major_ticks = np.arange(0, duration + 1, 10)\n",
    "#major_ticks[0] += 1\n",
    "major_ticks = np.array([1,10, 20, 30, 40, 50, 100])\n",
    "minor_ticks = np.arange(0, duration + 1, 1)\n",
    "ax.set_xticks(major_ticks)\n",
    "ax.set_xticks(minor_ticks, minor=True)\n",
    "#ax.set_xticklabels(['0, 10, 20, 30, 40, 50'])\n",
    "\n",
    "ax.set_yticks([1,5,10,20,30,40,50])\n",
    "#ax.set_yticks(minor_ticks, minor=True)\n",
    "#ax.set_yticklabels(['1, 2, 3, 9, 10'])\n",
    "\n",
    "for axis in [ax.xaxis, ax.yaxis]: # ?\n",
    "    axis.set_major_formatter(ScalarFormatter())\n",
    "    axis.set_minor_formatter(NullFormatter())\n",
    "\n",
    "# Plot\n",
    "if indices:\n",
    "    plot_SATcurve([allxs[i][np.min([num_classes, class_plot])] for i in indices],\n",
    "                  [1. - np.array(allys[i][class_plot]) for i in indices],\n",
    "                  [allyerrs[i][class_plot] for i in indices],\n",
    "                  [labels_plot[i] for i in indices],\n",
    "                  [colors_plot[i] for i in indices])\n",
    "    \n",
    "if indices_NPT:\n",
    "    plot_SATcurve([allxs_NPT[i][np.min([num_classes, class_plot])] for i in indices_NPT],\n",
    "                  [1. - np.array(allys_NPT[i][class_plot]) for i in indices_NPT],\n",
    "                  [allyerrs_NPT[i][class_plot] for i in indices_NPT],\n",
    "                  [labels_plot_NPT[i] for i in indices_NPT],\n",
    "                  [colors_plot_NPT[i] for i in indices_NPT])\n",
    "\n",
    "if indices_LSTMsm:\n",
    "    plot_SATcurve([allxs_LSTMsm[i][np.min([num_classes, class_plot])] for i in indices_LSTMsm],\n",
    "                  [1. - np.array(allys_LSTMsm[i][class_plot]) for i in indices_LSTMsm],\n",
    "                  [allyerrs_LSTMsm[i][class_plot] for i in indices_LSTMsm],\n",
    "                  [labels_plot_LSTMsm[i] for i in indices_LSTMsm],\n",
    "                  [colors_plot_LSTMsm[i] for i in indices_LSTMsm])\n",
    "\n",
    "if indices_EARLIEST:\n",
    "    plot_SATcurve([allxs_EARLIEST[i][np.min([num_classes, class_plot])] for i in indices_EARLIEST],\n",
    "                  [1. - np.array(allys_EARLIEST[i][class_plot]) for i in indices_EARLIEST],\n",
    "                  [allyerrs_EARLIEST[i][class_plot] for i in indices_EARLIEST],\n",
    "                  [labels_plot_EARLIEST[i] for i in indices_EARLIEST],\n",
    "                  [colors_plot_EARLIEST[i] for i in indices_EARLIEST])\n",
    "\n",
    "# Others\n",
    "plt.ylabel(ylabel)        \n",
    "plt.xlabel(xlabel)\n",
    "plt.grid(which='both')\n",
    "plt.legend(loc=3, fontsize='15')\n",
    "plt.title(title)\n",
    "plt.xlim(0.95, duration + 0.3) # default\n",
    "plt.ylim(3.9, 60.) # default\n",
    "plt.tight_layout()\n",
    "\n",
    "\n",
    "# # # 3. Inset\n",
    "# # ############\n",
    "#axins = ax.inset_axes([0.55, 0.07, 0.45, 0.5]) \n",
    "# axins = ax.inset_axes([0.55, 0.55, 0.45, 0.45]) \n",
    "#     # (pos x, pos y, width, height)\n",
    "\n",
    "# if indices:\n",
    "#     plot_SATcurve([allxs[i][np.min([num_classes, class_plot])] for i in indices],\n",
    "#                   [1. - np.array(allys[i][class_plot]) for i in indices],\n",
    "#                   [allyerrs[i][class_plot] for i in indices],\n",
    "#                   [labels_plot[i] for i in indices],\n",
    "#                   [colors_plot[i] for i in indices], inset=True)\n",
    "\n",
    "# if indices_NPT:\n",
    "#     plot_SATcurve([allxs_NPT[i][np.min([num_classes, class_plot])] for i in indices_NPT],\n",
    "#                   [1. - np.array(allys_NPT[i][class_plot]) for i in indices_NPT],\n",
    "#                   [allyerrs_NPT[i][class_plot] for i in indices_NPT],\n",
    "#                   [labels_plot_NPT[i] for i in indices_NPT],\n",
    "#                   [colors_plot_NPT[i] for i in indices_NPT], inset=True)\n",
    "    \n",
    "# if indices_LSTMsm:\n",
    "#     plot_SATcurve([allxs_LSTMsm[i][np.min([num_classes, class_plot])] for i in indices_LSTMsm],\n",
    "#                   [1. - np.array(allys_LSTMsm[i][class_plot]) for i in indices_LSTMsm],\n",
    "#                   [allyerrs_LSTMsm[i][class_plot] for i in indices_LSTMsm],\n",
    "#                   [labels_plot_LSTMsm[i] for i in indices_LSTMsm],\n",
    "#                   [colors_plot_LSTMsm[i] for i in indices_LSTMsm], inset=True)\n",
    "\n",
    "# if indices_EARLIEST:\n",
    "#     plot_SATcurve([allxs_EARLIEST[i][np.min([num_classes, class_plot])] for i in indices_EARLIEST],\n",
    "#                   [1. - np.array(allys_EARLIEST[i][class_plot]) for i in indices_EARLIEST],\n",
    "#                   [allyerrs_EARLIEST[i][class_plot] for i in indices_EARLIEST],\n",
    "#                   [labels_plot_EARLIEST[i] for i in indices_EARLIEST],\n",
    "#                   [colors_plot_EARLIEST[i] for i in indices_EARLIEST], inset=True)\n",
    "\n",
    "# # Inset range\n",
    "# axins.set_xticks([40,50,60,70,80,90]) # major grid\n",
    "# #axins.set_xticks(minor_ticks, minor=True) # minor grid\n",
    "\n",
    "# axins.set_xlim(30, 100.) # default\n",
    "# axins.set_ylim(4.0, 4.7) # default\n",
    "# axins.set_ylim(4.05, 5.5) # default\n",
    "\n",
    "# axins.grid(which='both')\n",
    "# mark_inset(ax, axins, loc1=2, loc2=4, fc='none', ec='0.25')\n",
    "\n",
    "#Save figure \n",
    "# plt.savefig(\n",
    "#     \"./traj_order{}.svg\".format(order_sprt), \n",
    "#     format=\"svg\", \n",
    "#     dpi=1200)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 200,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "90 th frame:\n",
      "[0.95834515] TANDEM      mult\n",
      "[0.95366212] TANDEMwO mult\n",
      "[0.9532414] TANDEM      SLEL\n",
      "[0.94780294] TANDEMwO SLEL\n",
      "[0.95830547] TANDEM      mult+SLEL\n",
      "[0.9589072] TANDEM      mult+LSEL\n",
      "[0.95365825] TANDEMwO mult+LSEL\n",
      "[0.9533095] TANDEMwO mult+SLEL\n",
      "[0.94988456] TANDEMwO LSEL\n",
      "[0.95436087] TANDEM      LSEL\n"
     ]
    }
   ],
   "source": [
    "frame = 90\n",
    "print(frame, \"th frame:\")\n",
    "for xi, yi, lb in zip(allxs, allys, labels_plot):\n",
    "    ai = xi[-1]\n",
    "    bi = yi[-2]\n",
    "    a = np.array(bi)[np.where(np.array(ai) == frame)]\n",
    "    if not a.size > 0:\n",
    "        print(\"not in target_hits\", lb)\n",
    "    else:\n",
    "        print(a, lb)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "60 th frame:\n",
    "5[0.95836928] TANDEM   mult\n",
    "6[0.95392924] TANDEMwO mult\n",
    "1,3,4[0.95313722] TANDEM       SLEL\n",
    "1,[0.94819025] TANDEMwO      SLEL\n",
    "[0.95832868] TANDEM   mult+SLEL\n",
    "4,5[0.95892418] TANDEM   mult+LSEL\n",
    "6[0.95393694] TANDEMwO mult+LSEL\n",
    "[0.95356046] TANDEMwO mult+SLEL\n",
    "2,6[0.95024618] TANDEMwO      LSEL\n",
    "2,3,4,5[0.95428164] TANDEM        LSEL\n",
    "\n",
    "NPT\n",
    "[] TANDEM mult + LSEL\n",
    "\n",
    "LSTM-s/m\n",
    "[] vs TANDEM mult + LSEL\n",
    "\n",
    "EARLIEST\n",
    "[] vs TANDEM mult + LSEL"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 183,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[array([[0.88097959],\n",
       "        [0.94655507],\n",
       "        [0.79310078],\n",
       "        [0.77176238],\n",
       "        [0.75268839],\n",
       "        [0.72087444],\n",
       "        [0.84722338],\n",
       "        [0.79682879],\n",
       "        [0.72437372],\n",
       "        [0.76116947],\n",
       "        [0.7995556 ],\n",
       "        [0.802216  ]])]"
      ]
     },
     "execution_count": 183,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "allys_EARLIEST"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 0. User-defined parameters 2 are here!\n",
    "########################################\n",
    "class_plot = 10 # 0, 1, 2, ...,9, 10 (macroave),11 (microave=ACC) for NMNIST\n",
    "indices = [0,2,3,4,5,6,7,8,9,10] # indices of paths_subproj. Only these subprojects are to be plotted.\n",
    "#indices = [2,3,4,5,6,7,8,9,10] # indices of paths_subproj. Only these subprojects are to be plotted.\n",
    "indices = [0,2,5,6] # indices of paths_subproj. Only these subprojects are to be plotted.\n",
    "indices = [0,1]\n",
    "\n",
    "indices_LSTMsm = [0,1]\n",
    "indices_EARLIEST = []\n",
    "\n",
    "# 1. Initialize figure\n",
    "############################\n",
    "title = \"NMNIST SAT curve\"\n",
    "xlabel = \"Mean hitting time (#frames)\"\n",
    "ylabel = \"Recall (class={}) (%)\".format(class_plot)\n",
    "plt.rcParams[\"font.size\"] = 25\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(13,8)) ###\n",
    "#fig, ax = plt.subplots(figsize=(11,8)) ###\n",
    "#fig, ax = plt.subplots(figsize=(10,8)) ###\n",
    "fig.patch.set_facecolor('white')\n",
    "\n",
    "# 2. Main plot\n",
    "################\n",
    "# Scale\n",
    "ax.set_xscale('log')\n",
    "# Grid\n",
    "major_ticks = np.arange(0, duration + 1, 10)\n",
    "major_ticks[0] += 1\n",
    "minor_ticks = np.arange(0, duration + 1, 1)\n",
    "ax.set_xticks(major_ticks)\n",
    "ax.set_xticks(minor_ticks, minor=True)\n",
    "ax.set_xticklabels(['0, 10, 20, 30, 40, 50'])\n",
    "for axis in [ax.xaxis, ax.yaxis]: # ?\n",
    "    axis.set_major_formatter(ScalarFormatter())\n",
    "    axis.set_minor_formatter(NullFormatter())\n",
    "\n",
    "# Plot\n",
    "if indices:\n",
    "    plot_SATcurve([allxs[i][np.min([num_classes, class_plot])] for i in indices],\n",
    "                  [allys[i][class_plot] for i in indices],\n",
    "                  [allyerrs[i][class_plot] for i in indices],\n",
    "                  [labels_plot[i] for i in indices],\n",
    "                  [colors_plot[i] for i in indices])\n",
    "\n",
    "if indices_LSTMsm:\n",
    "    plot_SATcurve([allxs_LSTMsm[i][np.min([num_classes, class_plot])] for i in indices_LSTMsm],\n",
    "                  [allys_LSTMsm[i][class_plot] for i in indices_LSTMsm],\n",
    "                  [allyerrs_LSTMsm[i][class_plot] for i in indices_LSTMsm],\n",
    "                  [labels_plot_LSTMsm[i] for i in indices_LSTMsm],\n",
    "                  [colors_plot_LSTMsm[i] for i in indices_LSTMsm])\n",
    "\n",
    "if indices_EARLIEST:\n",
    "    plot_SATcurve([allxs_EARLIEST[i][np.min([num_classes, class_plot])] for i in indices_EARLIEST],\n",
    "                  [allys_EARLIEST[i][class_plot] for i in indices_EARLIEST],\n",
    "                  [allyerrs_EARLIEST[i][class_plot] for i in indices_EARLIEST],\n",
    "                  [labels_plot_EARLIEST[i] for i in indices_EARLIEST],\n",
    "                  [colors_plot_EARLIEST[i] for i in indices_EARLIEST])\n",
    "  \n",
    "# Others\n",
    "plt.ylabel(ylabel)        \n",
    "plt.xlabel(xlabel)\n",
    "plt.grid(which='both')\n",
    "plt.legend(loc=2, fontsize='15')\n",
    "plt.title(title)\n",
    "plt.xlim(0.95, duration + 0.3) # full\n",
    "#plt.xlim(3.9, duration+0.3)\n",
    "#plt.ylim(65,70)\n",
    "#plt.ylim(98.5, 99.5)\n",
    "plt.ylim(88., 99.7) # v1 # full\n",
    "#plt.ylim(95, 99.7) # v2\n",
    "#plt.ylim(98.8, 99.9) # no inset\n",
    "#plt.ylim(99.3, 99.5) # no inset class 10\n",
    "plt.tight_layout()\n",
    "\n",
    "\n",
    "# 3. Inset\n",
    "############\n",
    "axins = ax.inset_axes([0.55, 0.07, 0.45, 0.5]) \n",
    "    # (pos x, pos y, width, height)\n",
    "\n",
    "    \n",
    "if indices:\n",
    "    plot_SATcurve([allxs[i][np.min([num_classes, class_plot])] for i in indices],\n",
    "                  [allys[i][class_plot] for i in indices],\n",
    "                  [allyerrs[i][class_plot] for i in indices],\n",
    "                  [labels_plot[i] for i in indices],\n",
    "                  [colors_plot[i] for i in indices], inset=True)\n",
    "\n",
    "if indices_LSTMsm:\n",
    "    plot_SATcurve([allxs_LSTMsm[i][np.min([num_classes, class_plot])] for i in indices_LSTMsm],\n",
    "                  [allys_LSTMsm[i][class_plot] for i in indices_LSTMsm],\n",
    "                  [allyerrs_LSTMsm[i][class_plot] for i in indices_LSTMsm],\n",
    "                  [labels_plot_LSTMsm[i] for i in indices_LSTMsm],\n",
    "                  [colors_plot_LSTMsm[i] for i in indices_LSTMsm], inset=True)\n",
    "\n",
    "if indices_EARLIEST:\n",
    "    plot_SATcurve([allxs_EARLIEST[i][np.min([num_classes, class_plot])] for i in indices_EARLIEST],\n",
    "                  [allys_EARLIEST[i][class_plot] for i in indices_EARLIEST],\n",
    "                  [allyerrs_EARLIEST[i][class_plot] for i in indices_EARLIEST],\n",
    "                  [labels_plot_EARLIEST[i] for i in indices_EARLIEST],\n",
    "                  [colors_plot_EARLIEST[i] for i in indices_EARLIEST], inset=True)\n",
    "\n",
    "# Inset range\n",
    "axins.set_xticks([10, 15]) # major grid\n",
    "#axins.set_xticks(minor_ticks, minor=True) # minor grid\n",
    "#axins.set_xlim(9.7, 20.1)\n",
    "axins.set_xlim(6.5, 19.8) # full\n",
    "#axins.set_ylim(99.32, 99.47)\n",
    "#axins.set_ylim(99.4, 99.47) # full\n",
    "#axins.set_ylim(99.465, 99.525) # v1\n",
    "#axins.set_ylim(99.48, 99.525) # v2\n",
    "axins.set_ylim(99.26, 99.57)\n",
    "axins.grid(which='both')\n",
    "mark_inset(ax, axins, loc1=2, loc2=4, fc='none', ec='0.25')\n",
    "\n",
    "#Save figure \n",
    "# plt.savefig(\n",
    "#     \"./traj_order{}.svg\".format(order_sprt), \n",
    "#     format=\"svg\", \n",
    "#     dpi=1200)"
   ]
  }
 ],
 "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.5.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
