{
 "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": 2,
   "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": 67,
   "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_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": "markdown",
   "metadata": {},
   "source": [
    "Memo 20200720:\n",
    "- LLLR good or not exps\n",
    "    0. bug?: reproduction in binary classification\n",
    "    1. 1st order show same tendency as 10th order? : order matters?\n",
    "    2. reason = overfitting?: multiplet ascent\n",
    "    3. Is LLLR effective for oblivion?: conflict update in TANDEM formula\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Major parameters\n",
    "num_target_hts = 20 # 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-h/graphs/npy/OD_ver20201030_stat\",\n",
    "    \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-h/graphs/npy/M_ver20201030_stat\",\n",
    "    \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-h/graphs/npy/OM_ver20201030_stat\",\n",
    "    \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-h/graphs/npy/D_ver20201030_stat\",\n",
    "    \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-h/graphs/npy/LD_ver20201030_stat\",\n",
    "    \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-h/graphs/npy/OLD_ver20201030_stat\",\n",
    "]\n",
    "labels_plot = [\n",
    "    \"TANDEMwO mult+LLLR-D\",\n",
    "    \"TANDEM   mult\",\n",
    "    \"TANDEMwO mult\",\n",
    "    \"TANDEM   mult+LLLR-D\",\n",
    "    \"TANDEM        LLLR-D\",\n",
    "    \"TANDEMwO      LLLR-D\",\n",
    "]\n",
    "colors_plot = [\n",
    "     'mediumblue', \n",
    "     'deepskyblue', \n",
    "    'mediumseagreen',\n",
    "    'purple',\n",
    "    'black',#None, \n",
    "    'gray',#None,\n",
    "#     'gold',#None,\n",
    "#     'darkorange', \n",
    "#     'red',\n",
    "#     'magenta',#None,\n",
    "#     'blue',#None,\n",
    "#     'purple',#None,\n",
    "#     None,\n",
    "#     None,\n",
    "#     None,\n",
    "#     None,\n",
    "#     None,\n",
    "]\n",
    "\n",
    "  #######################################\n",
    " #             LSTM-s/m                #\n",
    "#######################################\n",
    "allpaths_subproj_LSTMsm= [\n",
    "    \"/data/t-miyagawa/sprt_rankingmcc/nosaic_mnist/graphs/npy/LSTMs_ver20200809_stat\",\n",
    "    \"/data/t-miyagawa/sprt_rankingmcc/nosaic_mnist/graphs/npy/LSTMm_ver20200809_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-h/graphs/npy/Lam1e-3_ver20200819_stat\",\n",
    "    \"/data/t-miyagawa/sprt_earliestmcc/nosaic_mnist-h/graphs/npy/Lam1e-2_ver20200819_stat\",\n",
    "]\n",
    "labels_plot_EARLIEST = [\n",
    "    \"EARLIEST Lam=1e-3\",\n",
    "    \"EARLIEST Lam=1e-2\"\n",
    "]\n",
    "colors_plot_EARLIEST = [\n",
    "    'brown', \n",
    "    'black', \n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Minor parameters\n",
    "duration = 20\n",
    "num_classes = 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "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": 7,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "This may take a few minutes...\n",
      "SPRT\n",
      "1 / 6: TANDEMwO mult+LLLR-D\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",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 1.0\n",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 1.0\n",
      "2 / 6: TANDEM   mult\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",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 1.0\n",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 1.0\n",
      "3 / 6: TANDEMwO mult\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",
      "4 / 6: TANDEM   mult+LLLR-D\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",
      "5 / 6: TANDEM        LLLR-D\n",
      "... wait...\n",
      "6 / 6: TANDEMwO      LLLR-D\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",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 1.0\n",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 1.0\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(\"This may take a few minutes...\")\n",
    "print(\"SPRT\")\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",
    "#         paths_mht)\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": 84,
   "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": 74,
   "metadata": {
    "collapsed": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "It may take a few minutes...\n",
      "EARLIEST\n"
     ]
    },
    {
     "ename": "NameError",
     "evalue": "name 'allpaths_sns_EARLIEST' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-74-231578b19bd8>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      7\u001b[0m \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"EARLIEST\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      8\u001b[0m for paths_sns, paths_mht, label in zip(\n\u001b[0;32m----> 9\u001b[0;31m     allpaths_sns_EARLIEST, allpaths_mht_EARLIEST, labels_plot_EARLIEST):\n\u001b[0m\u001b[1;32m     10\u001b[0m     \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"{} / {}: {}\\n...wait...\"\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mformat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mcnt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mallpaths_sns_EARLIEST\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabel\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     11\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'allpaths_sns_EARLIEST' is not defined"
     ]
    }
   ],
   "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": 80,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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2/R+586dmjFjhmJiYlSjRg21bNlSq1atcnkN17pp06Zp4sSJCgsLszh+9OhRffPNNxo2bJhatGih8PBwjR8/3uaU5J9//tm8QMq9995baGXWW2+91bx337p168zbeFxp8fHx5pHqoUOHKigo6ApX9I/bbrtNUVFRVtsEBwfroYcekpT3jy6//vprke0KhsOipn8WXLm1e/fuVu8ZERGhunXrSpK+//57q20BwFEEQABuY+jQoQoODpYkjR8/XqmpqS7pN39xl6SkJPMv6tu3b1dSUpLFeWfVqVPHPJX0t99+K7Wl/0NCQjRr1iwdOXJEH3zwgTp27KjQ0NBC7TZs2KD77rtPb7zxRqnU4SwvLy99++23Jfp66623XHZfk8mk2NhYHT16VPPnz9dTTz2l2rVrm6fw5jt+/LiGDh2qu+++2+rPYsFtNoobSc4PHoZhXDWjgOvXrzd///DDD1/BSgrLn+Zpi63FYHJzc83TQ0NDQ9WuXTuL89nZ2frpp58k5QXARYsWacGCBVa/8kdBiwucAOAsNoIH4DYqVKigV155Ra+88orOnj2rd999V++9957T/ebvCXju3DnNmjVLd9xxh1N7/1kzfPhwffbZZ8rMzNTIkSPVo0cP+fj4uKz/gqpUqaJBgwaZR06PHDmin376SUuXLtWXX36pjIwMSXnTRmvXrl3k6IezDh8+bHX5//r165sX4vm3MmXKlHhT89KYepj/PFj+M2Fnz57V1q1btXr1asXFxZmf8UpMTFTPnj313XffFeojKyvLPC2wXLlyxf4sde3aVS+//LKysrI0Z84cjRo1yrz9yZVy/PhxSZKPj495kZerRZUqVUrU7qGHHlJQUJDOnDmj+Ph4/fe//7UI8mvWrDG/zy5dusjLy8vi+r/++sv852T79u12/V2QlZWlv//+W35+fiW+BgBKghFAAG5l4MCB5il0kyZNMu+r5oyCewLGx8crPT3dPCrgyN5/1lSrVk3PP/+8JOnYsWOaMmWKy/q2JTw8XF26dNHs2bO1d+9ei30CR44cWSr3XLZsmR599NFiv77++utSuW9pqFChgu69916NHj1a+/fv13PPPWc+t3TpUm3durXQNYsXL9bp06cl5f1DQ/5zrP8WEhKiBx98UFLez8XKlStL4R3Y59y5c5LyVv682pT0z6SPj4/5z/bhw4ctRjUl29M/nd3WwlUrFgNAQQRAAG7F19dXb775piTp4sWLGjVqlEv6zZ/meerUKT3//PNO7/1nzWuvvWb+pfqdd97R+fPnXX4PW8LDwy2mGh44cKDYza9RmJeXlyZNmmQxelnU85QFP+O5c+daXchmwYIFRV53pQQEBEiSyxZcssWeRXXsUTDYFQx8GRkZ5n+AqFWrlvk5zIIKht+HH35YhmHY9RUYGFgq7wmAeyMAAnA7MTEx5pUuP/nkE+3fv9/pPgvuCZi/6IMze/9ZExYWppdffllSXuB8//33XX6PkmjevLnFL7iuGE39t379+ln9BXnYsGEuv+fl4uXlZfEs2r8/vz/++EPLli1zqO8FCxYoLS3Nqfqclb/wUWZmpsOrxhac3mxrNCz/H11cLTIy0jyFdf78+eY6Fi1aZB7lLPisYEE33HCDPD3znrbJnyoKAFcaARCA2/Hy8jKP/F26dMllC4D8e68/Z/f+s2bw4MEKCQmRJP2///f/Su2XX2tMJpP5l1vp6pzqd7XL32ZAKvz5zZ0717zS67333qvhw4fb/GrTpo2kvNEpW3vXlbaC4TZ/E3t7FRwBs/UPDJs3b3boHiWRH/DOnDljflaz4GhgcQGwbNmyatasmaS81Vyd3Q8SAFyBRWAAuKVu3bpp7NixSkpK0rx58xQeHu50n7169dLixYstXpeWgIAAvfrqqxoyZIjOnz+vMWPGON1nbm6uUlNTi1zxsyjr1q0zjzKVLVvW6p5q7uKvv/7SDTfcUKK2WVlZWr58ufl1vXr1LM4XnMY5duxYRURE2Oxz8+bNuvPOO83X5z8veiVER0frnXfekWEYGjdunHr16mX3VhAFP5PVq1cXu6jPd999p4MHDzpVrzU9evTQ22+/LSkv+EVFRZlHZyMjI63+7Pfu3VsbN25UTk6ORo4ceVmf2wWAojACCMAtmUwmjR49WlLe0vkTJ050us+qVavqp59+Mn+5Yu8/awYMGGBezXDKlCm6dOmSU/1lZWWpevXqGjx4sPbu3Wu17Z49eyxGOB999NFiFyhxJ/369dODDz6oZcuWWd2nMT09XU899ZR5amRgYKA6dOhgPv/TTz+Z/x/UrVu3ROFPypuWmz8VecuWLdqzZ4+jb8Vp9erVU7du3SRJJ06c0EMPPaQ///yz2PbLly83r5iZr3Xr1uYVWj/99NMify737NmjZ555xoWVF3brrbeaR/K+++47TZs2TdnZ2ZKKH/3L99RTT5n39ps6dareeustq39WL1y4oGnTpjk8agoAtjACCMBtdejQQS1atNDGjRuVnp5+pcuxW9myZTV8+HA999xzhX5xdlR6erref/99vf/++7rtttsUGRmpBg0aKDQ0VIZh6MSJE/rxxx/13XffmX+JrVSpkku207geGIahhIQEJSQkqGLFimrdurWaNGmiG2+8UWXLllVqaqp27typr7/+WidPnpSU948REyZMUIUKFcz9FBz9sxUw/q1nz57mac0zZ87U+PHjXfDOHDN16lTt3LlTv/zyizZt2qRatWqpa9euat68uQIDA3X27Fnt3r1bS5Ys0f79+3XmzBmLLTkqVKigZ599VhMnTlR6erruuusu9e/fX40aNdLff/+t9evXKy4uTmXLllX79u2VkJBQau+lZ8+eSkxMNG/BIuVN4c1fJbQ4Xl5eWrhwoVq0aKFTp07p7bff1uzZs/XEE0+oYcOGKl++vM6fP6/Dhw9ry5YtWr16tTIyMlzyj1IAUBQCIAC3NmbMGLVq1epKl+Gwp556SuPGjdPvv//udF8eHh6qX7++edQoKSnJvJl9cVq0aKHZs2eX+mjntaJu3bpaunSpsrOzdfLkSX355Zf68ssvi20fFhamiRMnqkuXLuZjFy9e1BdffCEpLxx2797drhp69Oih4cOHyzAMxcXF6d1337V4VvNyCggI0Pr169W9e3clJCTowoULmjFjhmbMmFFk+4J77OV75513tG3bNm3cuFFpaWl65513LM6HhIRo/vz5WrhwYakGwPy9FrOzs80LwTz00EMKDg62eW2tWrW0detWdevWTZs2bdLRo0etLt7k5eWlihUruqx2ACiIKaAA3FpUVJTatWt3pctwmKenp/nZJGd5eXlp9+7d2rdvnyZPnqzo6GjdcccdCg4Olqenp3x8fBQWFqbmzZtrwIABWr16tdavX69bbrnFJfe/HowZM0YpKSmaP3++Bg4cqKioKFWpUkVly5aVp6enKlSooDp16qhz586aOXOmDhw4YBH+JOmbb74x7x/XsmVLu59PvfnmmxUZGSkp75nEojaYv5yCgoK0dOlSrVq1Sk899ZRq1aolf39/eXp6KjQ0VC1bttTrr7+u3bt3W4yC5vP399cPP/ygDz74QE2bNlX58uXl6+ur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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 = [0, 2,5]#3,4,5] # indices of paths_subproj. Only these subprojects are to be plotted.\n",
    "indices = [1,3,4]\n",
    "\n",
    "indices_LSTMsm = []\n",
    "indices_EARLIEST = []\n",
    "\n",
    "# 1. Initialize figure\n",
    "############################\n",
    "title = \"NMNIST-H 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",
    "# 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",
    "                  [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_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(8.95, duration + 0.3) # full\n",
    "#plt.ylim(0.5, 12.)\n",
    "m = 1.9\n",
    "plt.ylim(m, m + 1)\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_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([10, 15]) # major grid\n",
    "# #axins.set_xticks(minor_ticks, minor=True) # minor grid\n",
    "\n",
    "# #axins.set_xlim(9.7, 20.1)\n",
    "# axins.set_xlim(6.5, 19.8) # full\n",
    "# axins.set_ylim(0.425, 0.72)\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",
    "#     \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-h/graphs/NMNIST-H.svg\",\n",
    "#     format=\"svg\", \n",
    "#     dpi=1200)"
   ]
  },
  {
   "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,1,2,3,4,5] # indices of paths_subproj. Only these subprojects are to be plotted.\n",
    "\n",
    "indices_LSTMsm = []\n",
    "indices_EARLIEST = []\n",
    "\n",
    "# 1. Initialize figure\n",
    "############################\n",
    "title = \"NMNIST-H 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",
    "# 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)"
   ]
  },
  {
   "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": []
  }
 ],
 "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
}
