{
 "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": "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": 3,
   "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",
    "    \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-h/graphs/npy/E_ver20201207_stat\",\n",
    "    \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-h/graphs/npy/OE_ver20201207_stat\",\n",
    "    \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-h/graphs/npy/LOE_ver20201207_stat\",\n",
    "    \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-h/graphs/npy/LE_ver20201207_stat\",\n",
    "]\n",
    "labels_plot = [\n",
    "    \"TANDEMwO mult+SLEL\",\n",
    "    \"TANDEM   mult\",\n",
    "    \"TANDEMwO mult\",\n",
    "    \"TANDEM   mult+SLEL\",\n",
    "    \"TANDEM     SLEL\",\n",
    "    \"TANDEMwO   SLEL\",\n",
    "    \"TANDEM   mult+LSEL\",\n",
    "    \"TANDEMwO mult+LSEL\",\n",
    "    \"TANDEMwO   LSEL\",\n",
    "    \"TANDEM     LSEL\",\n",
    "]\n",
    "colors_plot = [\n",
    "    'mediumblue', \n",
    "    'deepskyblue', \n",
    "    'mediumseagreen',\n",
    "    'purple',\n",
    "    None, \n",
    "    None,\n",
    "    None,\n",
    "    'darkorange', \n",
    "    'red',\n",
    "    'magenta',#None,\n",
    "#   'blue',#None,\n",
    "]\n",
    "\n",
    "  #######################################\n",
    " #             NP test                 #\n",
    "#######################################\n",
    "labels_plot_NPT = [v + \" NPT\" for v in labels_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-h/graphs/npy/LSTMs_ver20200809_stat\",\n",
    "    \"/data/t-miyagawa/sprt_rankingmcc/nosaic_mnist-h/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-2_ver20200821_stat\", \n",
    "]\n",
    "labels_plot_EARLIEST = [\n",
    "    \"EARLIEST Lam=1e-2\",\n",
    "]\n",
    "colors_plot_EARLIEST = [\n",
    "    #'brown', \n",
    "    #'black',\n",
    "    \"navy\",\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Minor parameters\n",
    "duration = 20\n",
    "num_classes = 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "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": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "It may take a few minutes...\n",
      "SPRT & NPT\n",
      "1 / 10: TANDEMwO mult+SLEL\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 / 10: 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 / 10: 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 / 10: TANDEM   mult+SLEL\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 / 10: TANDEM     SLEL\n",
      "... wait...\n",
      "6 / 10: TANDEMwO   SLEL\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",
      "7 / 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",
      "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",
      "8 / 10: TANDEMwO 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",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 1.0\n",
      "9 / 10: TANDEMwO   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",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 1.0\n",
      "10 / 10: TANDEM     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",
      "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(\"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": 7,
   "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": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "EARLIEST\n",
      "1 / 1: EARLIEST Lam=1e-2\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": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(<mpl_toolkits.axes_grid1.inset_locator.BboxPatch at 0x7f113b5dc128>,\n",
       " <mpl_toolkits.axes_grid1.inset_locator.BboxConnector at 0x7f113b5e9c18>,\n",
       " <mpl_toolkits.axes_grid1.inset_locator.BboxConnector at 0x7f113b5dc8d0>)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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xnz8+HGRmpoqfH19BQBhb28vHBwcpGOaNm0qEhISDMYbHx8vunbtqve5bNSokd7n4LXXXjP5/HV9+umnAoDw8vIq87gjR46INm3a6P1or0vz5s2lbdrPjYODg96xH3/8sVSX9j2Wy+XS97XkZ1AI/e/YG2+8IZ27SqUSCoVCzJ8/X6qzTZs20nthb28vXFxc9L6HLVq0EBcvXjR4btqyK1asED4+PgavT7NmzcT169fF1atXRdu2bQUA4ejoKJRKpXRMx44dRUZGhsHXOHXqlGjZsqXe75sGDRroXdNFixaVKnfjxg3RunVr6Ti5XC6dv3abv7+/0es2adIkAUC89NJLZV5fIrIuTACJyCroJoBCCPGvf/3L4E11dna2cHZ2FnK5XCQmJpabAI4dO1YAEO3atRObNm2SbsAePnwofvzxR9GuXTsBQAwfPrxU2bVr14r58+eLuLg4kZeXJ4QQQqPRiGvXronZs2cLmUwmFAqFOHnypNHzady4sZDL5eLtt98Wd+/eFUIIkZGRId5//30p7vXr11f4/dImHSqVSiiVSrF8+XLp3FJTU8XkyZOl+qOjo42WLytp0b2BNkRbf0xMjNFjTE0AVSqVGDZsmLhw4YIQQoi8vDzx3XffSTfBr776aqm6r169KhwdHQUA0b17dxEXFyeEKL5Ge/bsEW3atBEqlarCCaCWboJRFlPey8aNG4vHHntMbN26VeTn5wuNRiN+//136fP39NNPixEjRggPDw8RGRkpioqKRFFRkdi7d69wdXUVAMSYMWNK1Z+dnS06deokAIiAgAARGxsrcnNzhRBC3L9/XyxfvlxKrFesWFHh90D7xxND778u3WtZmR9DnzVt4vX1118bfE3t9dGe31tvvSXu3LkjhBAiNzdXxMfHS8eOGzdORERE6CXReXl5Yu/evaJ3797SZ8gQbRyNGzcWHh4eIioqShQVFYnCwkIRFRUlXZ+XXnpJ9O7dW3Tr1k0cOXJECCFEfn6++O6776TP6bvvvluq/lu3bommTZsKAOKFF14QcXFxIj8/XwghREpKinjvvfekP4j88MMPemW1CZyHh4fYu3ev9MekwsJCER8fL1avXi3eeustI1dNiHXr1gkAwt3d3egxRGR9mAASkVUomQAmJiYKuVwunJycRFZWlnTcV199JQCIZ599VgghykwADxw4ILWeaFsN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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,1,2,3,4,5,6,7,8,]\n",
    "indices = [0,1,2,6,7,8]\n",
    "indices = [0,1,2,7]\n",
    "\n",
    "#indices_NPT = [0,1,2,3,4,5,6,7,8]\n",
    "indices_NPT = []\n",
    "indices_LSTMsm = [0,1]\n",
    "indices_EARLIEST = [0]\n",
    "\n",
    "# 1. Initialize figure\n",
    "############################\n",
    "title = \"NMNIST-Hard 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",
    "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([2.0, 3.0, 4.0, 5.0, 6.0, 7.0,]) ############ full magnif\n",
    "ax.set_yticks([2.0, 10.0, 20.0, 30.0, 40.0, 50.0, 60.0 ]) ############ full \n",
    "#ax.set_yticks(minor_ticks, minor=True)\n",
    "#ax.set_yticklabels(['0, 10, 20, 30, 40, 50'])\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=1, fontsize='15')\n",
    "plt.title(title)\n",
    "plt.xlim(0.95, duration + 0.3) # full\n",
    "#plt.ylim(1.9, 8.)\n",
    "plt.tight_layout()\n",
    "\n",
    "\n",
    "# 3. Inset\n",
    "# ############$$$\n",
    "axins = ax.inset_axes([0.08, 0.07, 0.45, 0.5]) #########################\n",
    "#axins = ax.inset_axes([0.08, 0.5, 0.45, 0.45]) # full magnif #####################\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, 20]) # major grid\n",
    "#axins.set_xticks(minor_ticks, minor=True) # minor grid\n",
    "\n",
    "axins.set_xlim(11.8, 20.2) # full, full magnif #############\n",
    "axins.set_ylim(1.91, 2.02) # full, full magnif #############\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": "markdown",
   "metadata": {},
   "source": [
    "### OE, OM, M, ODが強い?"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "15 th frame:\n",
      "[0.98061864] TANDEMwO mult+SLEL\n",
      "[0.98067193] TANDEM   mult\n",
      "[0.98067477] TANDEMwO mult\n",
      "[0.98021656] TANDEM   mult+SLEL\n",
      "[0.98051155] TANDEM     SLEL\n",
      "[0.98050988] TANDEMwO   SLEL\n",
      "[0.98067746] TANDEM   mult+LSEL\n",
      "[0.9807389] TANDEMwO mult+LSEL\n",
      "[0.98072309] TANDEMwO   LSEL\n",
      "[0.98063797] TANDEM     LSEL\n"
     ]
    }
   ],
   "source": [
    "frame = 15\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": []
  },
  {
   "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": "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
}
