{
 "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": 54,
   "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=9,#3, \n",
    "                markeredgewidth=6,#2,\n",
    "                capsize=15,#5,\n",
    "                linewidth=1,\n",
    "                markeredgecolor=color,\n",
    "                markerfacecolor=color,\n",
    "                ecolor=color,\n",
    "                label=label,\n",
    "                alpha=0.8\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=6,#3, \n",
    "                    markeredgewidth=1,#2,\n",
    "                    capsize=10,#5,                    \n",
    "                    linewidth=1,\n",
    "                    markeredgecolor=color,\n",
    "                    markerfacecolor=color,\n",
    "                    ecolor=color,\n",
    "                    label=label,\n",
    "                    alpha=0.8\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": 50,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Major parameters\n",
    "num_target_hts = 20 # 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-h/graphs/npy/bin10thO_ver20201030_stat\",\n",
    "    \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-h/graphs/npy/bin19thO_ver20201030_stat\",\n",
    "]\n",
    "labels_plot = [\n",
    "    \"10th TANDEM\",\n",
    "    \"19th TANDEM\"\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-h/graphs/npy/binLSTMs_ver20200809_stat\",\n",
    "    \"/data/t-miyagawa/sprt_rankingmcc/nosaic_mnist-h/graphs/npy/binLSTMm_ver20200809_stat\",\n",
    "]\n",
    "labels_plot_LSTMsm = [\n",
    "    \"LSTM-s\",\n",
    "    \"LSTM-m\"\n",
    "]\n",
    "colors_plot_LSTMsm = [\n",
    "    \"blue\", #'brown', \n",
    "    'black', \n",
    "]\n",
    "\n",
    "  #######################################\n",
    " #             EARLIEST                #\n",
    "#######################################\n",
    "allpaths_subproj_EARLIEST= [\n",
    "    \"/data/t-miyagawa/sprt_earliestmcc/nosaic_mnist/graphs/npy/Lam1e-3_ver20200819_stat\",\n",
    "    \"/data/t-miyagawa/sprt_earliestmcc/nosaic_mnist/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": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Minor parameters\n",
    "duration = 20\n",
    "num_classes = 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "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": 31,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "This may take a few minutes...\n",
      "SPRT\n",
      "1 / 2: 10th TANDEM\n",
      "... wait...\n",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 1.0\n",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 20.0\n",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 1.0\n",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 20.0\n",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 1.0\n",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 20.0\n",
      "2 / 2: 19th TANDEM\n",
      "... wait...\n",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 1.0\n",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 20.0\n",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 1.0\n",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 20.0\n",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 1.0\n",
      "Extrapolation is not supported.\n",
      "Skip target hitting time: 20.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": 32,
   "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": 58,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Zo1atGihatWq6aabbtJzzz2nhg0b5nkHoJ+fnySpRo0atrb09PRC579639VjAAC4rsTESH/+V+P4+Nx2AEClY6kAHD9+vIKCgvTwww9r9erVMp189+h//vMfbdq0SU888YRuv/121a9fX61atdLkyZP13XffydXVVZIUGBioqlWrSpLq1q1rG19UsXpln7e3d7m/nQQAALs1bSpFRf1RBMbH534uZJVtAMD1zdIiMA0aNNDRo0f16aefauXKlapXr54GDx6sQYMG5Sm8HKl9+/Zq3759gfuu3Afbrl07W9vVK3/+8MMPuu222woce2W10MJeMwEAQIURHZ27FSYtTQoNle3/pgEB0rBhhfePiMjdAADXHUsFYEJCgtauXavo6Gh99tlnOnbsmMaPH69Jkybpvvvu09ChQ9WtWzcZhuGsvDYnTpzQunXrJElhYWG29ltvvdVWqH7++efq3bt3vrFpaWn6+uuvJUn33HOP07MCAOBURRVsP8ZINZtKH8fLJTJSmj1bejhEOrNXuj2s4DEAgOuWpQLQMAzde++9uvfee3Xy5Em9++67euedd3To0CHbVcH69etr0KBBTr0qmJ2drWHDhikjI0OtWrXSvffemydjWFiYJk+erCVLluill17K81oJSZo7d65SU1Pl6uqqxx9/3CkZAQAoNbujc7eCZKZJe49KqyTjr5nSa6OlQ5KaNpC+e63gMXdG5G4AgOuO3S+Cr127tqKionTgwAGtW7dOffr0kZubm44eParx48erYcOGevjhh/X//t//s+tZwcOHD2vs2LHauXOnLl26JEnKycnRN998o3vuuUcff/yxfH19tWDBgnxXHMeMGaM6deooPT1dPXr00I4dOyTlvjvwzTff1EsvvSRJioiI0K233mrvtwAAgPJhq6TZhWzTJb0rqYWknN//++7v7YWN2Vq68QEApcchL4IPDQ1VaGiozpw5o5iYGEVHR2vfvn1auXKl7apgRESEhg4dqpo1axZrzgsXLuiVV17RK6+8Iil3lc/U1FRlZmZKyn0eccWKFQU+4+fj46PPPvtM9957r/bu3auQkBDVqFFDly5dso2/5557NGvWLEecPgAAZauoW0BjYnIXfHGLl/llpBQ6U/pHiLR3rxTGLaAAUNk4pAC84vz58zp58qTOnj0rwzBsV/6OHj2ql156SVOnTtXEiRMV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fHx81LJlS82cOVMZGRklygUAqNhiYqT4+Lxt8fG57QAAXK8sFYC9evWSaZoaP358kbd27tq1S//6179kGIb69+9vVzDTNDVs2DDdc889io2N1dGjR+Xi4iLDMJSQkKD3339fnTt31j//+c8Cxx85ckR33nmnJkyYoB9++EGmaery5cuKj4/XmDFj1KZNG509e9aubACAii8hIUZPPRVvKwLj46WnnopXQgIVIADg+mWpABwyZIiaNm2qDRs2qGvXrvrss8+UnZ0tSTpw4IC++OILPf3002rXrp3Onz+vNm3aqHfv3nYFW7BggebNmycpt/Dcv3+/0tPTlZ6erp9//tm2CumsWbO0YsWKPGOzsrL0wAMP6JdfftFNN92kL774QmlpaUpPT9eSJUtUo0YNfffddxowYIBd2QAAFV+PHk0lRempp+L16ad19dRT8ZKifm8HAOD6ZOk1EG5ublq1apW6deumDRs2KC4uzrYvODjY9rVpmmrWrJk++ugjGYZhV7CY3+/Bady4sT744ANVqfJH1CZNmig2NlbBwcE6fPiwli5dqkceecS2f+HChbbXT3z00Ue2V1K4uLiob9++ysnJ0WOPPabVq1dr/fr1+tvf/mZXRgBA+da6dbTi4wt//6Fppsk0+2n79sclLZZhuKl162GF9g8JidC2bYW8gxEAgArAUgEoSYGBgdqxY4dmzpypd999V0eOHMmzPyAgQEOGDNHo0aNVvXp1u4P9+uuvkqTmzZvnKf6ucHNz01133aXDhw8rNTU1z76FCxdKkrp06WIr/q7Wr18/jR07VgkJCYqJiaEABIDr1KBB0u83qhQoLS1ECQl1lZk5T25u4QoKSlb16j8VOR8AABWZ5QJQkjw9PfXSSy/ppZdeUnJyspKTk5Wdna06deooMDDQIcFuvvlm7du3T7t27VJWVla+IjAzM1Pff/+9JOVZaCY9PV3ffPONJKl79+4Fzm0Yhrp166Y333xTa9eudUheAED5ExERoYiIgq/YXXnm7847o9Shw2PatGmHpKl6440QlXD9MgAAyi1LzwAWpG7dugoJCVHr1q0dVvxJ0vDhwyVJBw8eVP/+/XXw4EHbvn379qlPnz46fPiwGjVqpGeeeca276effrItUHPHHXcUOv+VfcePH9dvv/3msNwAgIph1arcZ/7eeGOqHnzwQb3xxlRJUb+3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6fLfn376CRMmTDBZe0RERETW5m7vp44dO4Zx48ahoKAAAKBUKlFSUoKMjAxkZGRg586d+Oqrr2Bvb2+qkIma5e3tjZqaGum/HR0dYWdnh+vXr+P69ev48ssvMX78eOzcuRNOTk5N6l+5cgUhISHSq21OTk6orKxEZmYmMjMzsXnzZqSmpkKlUhkVT4fuAQwLC4MQAkKIVs2h4eXlhRUrVuD8+fO4c+cObt++jQMHDiA6OtqkyZ+GSqXC2LFjsWDBAmzZsgXe3t4m3wYRERHRvay191NFRUV49NFHUVBQgP79++Po0aMoKSlBWVkZVq5cCTs7O+zZswcxMTFtvAdE2mpqajBixAisWrUKly5dwp07d1BaWoqsrCzMnj0bAPDdd9/h+eef11n3scceQ3Z2Nnx8fPCf//wHZWVlKC8vx9atW9GpUyccP37c4DzpjVnEKKCWoLa2FnK5XGuZWq3GlStXsHTpUj4GSkRERNSMu7mfWrx4Md58800oFAqcPn0avXr10lr/9ttvY9GiRZDL5Thz5gzHgaB2k5aWhtDQUL3rX3jhBXzyyScA6gfA7NGjh7Ru7dq10pOQBw8exMiRI7XqbtmyBc888wyA+qcnx44d22w8HboH0JI0/seKiIiIiFrmbu6nkpOTAQDTpk1rkvwBwNy5c6FUKlFbW4vNmze3ejtELWUo+QMg9QICaDL5+2effSa10Tj5A7Svd81voDlMAImIiIjIov3666/SuBHjx4/XWUapVCIoKAgAsHfv3naLjag5jo6O0vfa2lrpe3l5OX788UcA+q9rmUyGRx55BIDx1zUTQCIiIiKyaKdOnZK+Dx48WG85zbozZ860eUxExkpPT5e+BwQESN/Pnj2Luro6AMZd17m5ubh161az22MCSEREREQW7caNG9L3bt266S2nWVdcXIzS0tI2j4uoOYWFhXj77bcBAEFBQfD395fWtfS6blxHHyaARERERGTRSkpKpO+6htHXta5hHSJzqKurw7PPPovffvsNjo6OWLlypdb6trqumQASERERERG1s3nz5mH37t0AgI8++gj33Xdfu2yXCSARERERWbROnTpJ38vLy/WWa7iuYR2i9jZ//nypx+/9999HVFRUkzJtdV0zASQiIiIii9a1a1fp+/Xr1/WW06xzcXGBUqls87iIdHn55ZexfPlyAEBCQgJiYmJ0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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 = 2 #10 # 0, 1, 2, ...,9, 10 (macroave),11 (microave=ACC) for NMNIST\n",
    "indices = [0,1] # indices of paths_subproj. Only these subprojects are to be plotted.\n",
    "\n",
    "indices_LSTMsm = [0,1]\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 = \"Recall {} (%)\".format(_tmp)\n",
    "ylabel = \"Balanced accuracy (%)\".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(70., 98)\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",
    "#     \"/data/t-miyagawa/sprt_multiclass/nosaic_mnist-h/graphs/binNMNIST-H.svg\", \n",
    "#     format=\"svg\", \n",
    "#     dpi=1200)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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uHFj0/92ADgfCkAAKAJGjhwpDw8P4/2dRuts1ahRIz300EOS7nwb6M391atXV8OGDfN1nqZNm6pFixaSpHXr1unnn3/OV5zc+Pv7y8/PT5KUmpqq//znPw45jyNUq1bNeL9p0ybt2rXLtNiZR/gyFxg33ycnJys6Otq085ll7Nix6t27txISEiRJjRs31scff6zo6GhFRUVp9OjReuaZZ+Tq6lpgo1/Jyclq166d9u/fr6ZNm+pf//qX5s+fr0mTJhn/PjJ/xrlNfHTx4kUtW7ZMkhQSEnLbqPX169fVrl07TZ06VVarVYGBgRo4cKBmzpyp+fPna/z48apTp46kGzPItmjRQikpKWZeMgAnQwEIAEVA5cqV1bt3b0nSsWPHNHXqVNNi9+jRQ5K0dOlSnTt3Lsux8+fPa+nSpVna5de4ceNksVgk3ZjQxhE/2F1cXIzbWiXp7bffVnh4uFatWmVMrlJU1a1bVzVq1JB0o3ht2rSphg4dql27dun69ev5jhsfH288O/rggw9mKeK7detmfCdF7TbQtWvXGrOKent76/vvv9e6des0ePBgdenSRd26ddP777+vVatW6ciRI6ZOkJST//3vf/rjjz80ZcoUrVmzRv369VPnzp311ltvGfm2b99exYoVk3TjOdSczJ8/31hepXv37rcdnzBhgpYsWSLpxrObf/31lz755BOFhYWpc+fO+sc//qGdO3caM/nu3r2bNRcB2IUCEACKiKFDhxo/KseOHWuMitgrLCxMLi4uxpqAmd1c+8/FxUVhYWF2nad+/frq2LGjJGnnzp1auHChXfHuZOzYscZo2vXr1zVz5kw1b95cvr6+qlu3rl5//XVNnz49T7fmFSQXFxd98803xjOW8fHxGjdunOrVqydfX181btxY77zzjr777jtdvnw5z3Gjo6ON4vfWAqNixYrGYvBbtmxRbGysORdjguHDhxuF75dffpnj5EMVKlRQSEhIQaWmrl276s0337zj8WLFihn5HjhwQNu2bbtj25v/5tzc3NS1a9csxxITEzV+/HhJN0brv/7662wnBrJYLJowYYL+9re/SZImTZqU7zU7AYACEACKiDJlyqh///6SpHPnzpn2zFOFChX0zDPPSPq/tf5uunn7Z7NmzfTAAw/Yfa4xY8bI1dVVkvT++++bNqFNZgEBAdqyZYt69OhhnEu6sej97t279fXXX+u1115T1apV9eSTT2rVqlWm55BfjRo10q+//qrGjRtn2Z+YmKgNGzZo4sSJeumll1S2bFm9/PLLOnjwYK4x73T7502ZC/uiMBuqJB0/flwbNmyQJAUHB9v9nw9m69u3b65t8nIb6OHDh41JkVq0aKH7778/y/HFixcbxf7AgQON0drsWCwWdevWTZJ06dIl7dixI9ccASA7FIAAUIQMHjxYpUqVkiR98sknunTpkilxb07usmfPHuPZs507d2rPnj1ZjtsrKCjIuJX0wIEDuS4/kV+lS5dWZGSkjh07pokTJ6pt27by9/e/rd2mTZvUvHnzPC+lUBAeeeQRrVu3Trt27dKwYcPUuHFjeXt7Z2mTmpqq+fPnq06dOvrpp5/uGCs2Nla//vqrpBvFZdWqVW9r07FjRyP+7Nmzi8TEORs3bjTet23bthAzuZ2np6cee+yxXNs1a9ZM5cqVk3RjFDa7/+zIXBhmd/vnzSJYki5cuKAff/wxx9eZM2eM9kVpNBfA3YUCEACKED8/P/3zn/+UJMXFxZn2rE92awLas/ZfTkaMGCFPT09JNxZtv3X6fjMFBgaqf//+WrRokc6fP6+jR48qOjpaYWFhWW6lGzt2rKmzq5qhTp06GjNmjNatW6f4+Hjt3btXU6dO1bPPPmu0SUpKUteuXfXnn39mGyO30T9JKl68uLGA+9mzZ41nPgtT5sXtb85UWlSUKVNGbm5uubZzdXU1buk8d+6cli9fflubm88HZv4OMjt69KjxvlevXmrfvn2Or8yz7dpymzAAZEYBCABFTN++fY3FzSdPnqxTp07ZHTPzmoBz585VYmKi5s2bJyl/a//lpGLFiurTp4+kG7f6ffHFF6bFzk2lSpXUpUsXzZw5U/v3788y4+KoUaMKLA9bubq6qnbt2urdu7eWL1+uNWvWGN9JcnKyPv7449v6ZGRkGEWth4dHlslxbpX5FsuiMBlMfHy88d7Hx6cQM7mdLf8WcroNdOvWrUbh3rFjx2zj2rM0h1kzBQNwPhSAAFDEeHl56f3335d048f/6NGjTYl78zbPCxcuqE+fPnav/ZeT9957z/hhP27cOF29etX0c+SmUqVKWYqdQ4cOGWvlFXVNmzY1ZpyUlO1zjEuXLjVuCUxNTVWpUqWMxcZvfbVq1crot3jx4kJfS+7maLQk0yY7yok9s6zmpE6dOqpdu7Yk6aefflJiYqJxLLe1/6Ssxe+pU6dktVrz/Hr33Xcdck0A7n0UgABQBL322mvGTJfffPON/vrrL7tjZl4T8ObIkT1r/+UkICBA77zzjqQbBednn31m+jnyokGDBrf9yL5b3FxsXMo+7/yO5KWlpeW6dIGjZZ5wKL/Pst28zVjKfTTs5n92OMLNZ/sSExON5TjS09M1f/58STeu9eZMrLcKDAw03me+LRYAHIkCEACKIHd3d2PkLz09PctokD1uXevP3rX/cjJw4ECVLl1akvTpp5869Ef4nVgslizPcxW12w1z4uHhYby/Ne8LFy4oJiZG0o1nOEeMGJHra/DgwUb/wr4N9KmnnjLe37wOW5UoUcJ4n1thv2XLlnydIy+6desmF5cbP6dujvotX77cWHMzNDTUOH6rJk2aGO+ze4YQABwh96ecAQCFomvXrho/frz27Nmj6OhoVapUye6YYWFhWX5wO3L6fV9fXw0ZMkSDBg3S1atXs0xgkV/Xr1/XpUuXsp3xMzsbNmzQlStXJEn33XdftrNkFpQrV67I29s7S2GXk0WLFhnva9asmeXYnDlzjHXgOnXqpJEjR+Yp5ooVK7R7927t2bNHO3fuVL169fKWvMkeeOABNWnSROvWrVNsbKxmzZpl899iyZIlVbZsWZ05c0a//PKLUlJSsl1D79q1a5o2bZpZqd/m5gjf6tWrtWrVKp05cyZPt39K0gsvvKASJUroypUrmjRpknr16qWAgACH5QoAEiOAAFBkWSwWjR07VpJktVo1adIku2NWqFBBv/76q/EyY+2/nERERBi3uX3xxRd2L0GQmpqqypUra+DAgdq/f3+Obfft25dlhLN9+/YqVqyYXee3x6+//qpq1app4sSJuT6D9/3332vcuHHG9q1FROYRvOyWF7iTzHEKexRw1KhRxshYnz599OOPP96x7cmTJ7V9+/bb9t98tjE+Pl5jxoy57XhaWpp69uxpyi3UObn5HWRkZOirr74ylu549NFHjWcEs+Pn56ehQ4dKujFDa6tWrXTkyJEcz7V582YNGTLEpMwBOCNGAAGgCGvTpo0aNmyozZs3Z5lg4m5x3333acSIEerVq5dSUlJMiZmYmKjPPvtMn332mR555BE1atRItWvXlr+/v6xWq06ePKn169frv//9r1Fwli1bNtuZNAvaiRMn9M477+gf//iHGjVqpMcff1wPPvigSpQooWvXrunQoUNaunSpsbafdOM2wddee83Y3rVrl3777TdJNya6uXVR+ZyEhobqH//4hzIyMjR37lx98sknWZ6lK0hNmjTR6NGjNWzYMCUlJal9+/Zq3Lix2rRpo4oVKyojI0NHjx7V+vXrtWrVKo0ZM0YhISFZYvTv319RUVFKT0/XuHHjtG/fPr344ovy9vbWwYMHNXPmTP311196+eWXFR0d7bBr6dixoyIiIpScnKwPPvjAeCYxp9G/mwYOHKjt27dr/vz52rlzp2rUqKF27drpqaeeUtmyZZWWlqbz589rz549WrVqlY4dO6ZatWqZMqIOwDlRAAJAEffhhx9meVbobvPqq69qwoQJOnjwoN2xXF1dVatWLe3bt0/SjYXtby5mfycNGzbUzJkzHT7amZv7779f5cqV0+nTp5Wenq5169Zp3bp1d2xvsVjUo0cPTZ48Wa6ursb+zCN3oaGhslgsec6hbNmyat68uX7++WddunRJixYtUqdOnfJ3QSYYOnSoSpYsqcGDByspKUnr16/X+vXrs22b3XN0jz76qP71r3+pb9++slqt+umnn4zRt5siIiIUERHh0ALQ19dXL774oqKjo43iz9XVVaGhobn2tVgsmjt3rqpXr67x48crNTVV3377rb799ts79insv2UAdzduAQWAIq5x48ZZpvG/27i5uWV7e15+uLu76/fff9eff/6pKVOmKDQ0VHXr1lWpUqXk5uYmT09PBQQEqEGDBoqIiNDq1au1ceNGPfjgg6ac3x716tXTyZMn9csvv2jcuHF64YUXFBQUJF9fX7m6usrb21vly5fXM888o/fff1/79u3TjBkzsty2mpqaqrlz5xrbttz+eVPmUanp06fbd1EmePPNN3Xo0CGNHDlSTzzxhPz9/eXm5qZixYopODhYYWFh+u677zRgwIBs+0dERGjjxo3q2LGjypYtK3d3d5UrV04vvPCCli1bpsmTJ9tUJOfXraN9zzzzjMqVK5envi4uLho9erQOHTqkESNG6Mknn1SZMmXk7u4uLy8vVahQQS1atNCIESO0detWLVu2zBGXAMBJWKxWq7WwkwAAAAAAOB4jgAAAAADgJCgAAQAAAMBJUAACAAAAgJOgAAQAAAAAJ0EBCAAAAABOgnUAiwh/f39VrlzZpj5xcXHy8/NzTEKAgyUmJmaZ3h5FB99N3tzrn9PdfH1FOfeiklth5VGQ53X07yRHXYvZcc2MZ1Yse+MUVv+C7Hfr3+/Ro0d14cIFm8+dLSuKhPr169vcJyYmxgGZAAVjzZo1hZ0C7oDvJm/u9c/pbr6+opx7UcmtsPIoyPM6+neSo67F7LhmxjMrlr1xCqt/Qfa79e83P7XCnXALKAAAAAA4CRaCL2QxMTGKiYnRkiVLFBUVZVNfbgHF3SwhIUE+Pj6FnQaywXeTN/f653Q3X19Rzr2o5FZYeRTkeR39O8lR12J2XDPjmRXL3jiF1b8g+9369zto0CBt377d5nNny7SxRNiFW0DhbIrKbVC4Hd9N3tzrn9PdfH1FOfeikhu3gNqPW0ALLw63gNqHW0ABAAAAwElQAAIAAACAk6AABAAAAAAnQQEIAAAAAE6CAhAAAAAAnAQFIAAAAAA4CQpAAAAAAHASFIAAAAAA4CQoAAEAAADASVAAAgAAAICToAAEAAAAACdBAQgAAAAAToICEAAAAACcBAXgXWpEeLgO79ihEeHhhZ0KAAAAgLuEW2EngLyxWCzG+yAvL+1PTja2FyxYYGxbrdYCzw0AAADA3YERwLvQ5fT0HLcBAAAAIDsUgHcJq9VqvHqHhmY51js01DgGAAAAAHfCLaB3oVGRkZKk0lWq6OKRI8Y2AAAAAOSEEcC71KjISFWtX5/iDwAAAECeUQACAAAAgJOgAAQAAAAAJ0EBCAAAAABOggIQAAAAAJwEBSAAAAAAOAkKQAAAAABwEhSAAAAAAOAkKAABAAAAwElQAAIAAACAk6AABAAAAAAnQQEIAAAAAE6CAhAAAAAAnAQFIAAAAAA4CQpAAAAAAHASFIAAAAAA4CQoAAEAAADASVAAAgAAAICToAAEAAAAACdBAQgAAAAAToICEAAAAACcBAUgAAAAADgJCkAAAAAAcBIUgAAAAADgJCxWq9Va2Ek4s5iYGMXExGjJkiWKioqyqW9cXJz8/PwclBngWAkJCfLx8SnsNJANvpu8udc/p7v5+opy7kUlt8LKoyDP6+jfSY66FrPjmhnPrFj2xims/gXZ79a/30GDBmn79u02nztbVhQJ9evXt7lPTEyMAzIBCsaaNWsKOwXcAd9N3tzrn9PdfH1FOfeiklth5VGQ53X07yRHXYvZcc2MZ1Yse+MUVv+C7Hfr329+aoU74RZQAAVuRHi4/tyyRSPCwws7FQAAAKfiVtgJALj3WSwW432Ql5f2Jycb2wsWLDC2rdyRDgAA4FCMAAIoUJfT03PcBgAAgONQAAJwOKvVarx6h4ZmOdY7NNQ4BgAAAMey6xZQq9WqCxcu6Pz580pJSVHp0qUVEBAgb29vs/IDcI8ZFRkpSQoMDtbJ2FhjGwAAAI5ncwG4adMmLVu2TOvWrdO2bduUmpp6W5sHHnhATZo0UZMmTdShQweVLFnSlGQB3BtGRUZq7dq16vXPfxZ2KgAAAE4lTwXg1atXNWPGDE2bNk2xsbGScp6s4fjx44qKitKcOXPUt29fderUSX369NHjjz9uTtYAAAAAAJvlWABmZGRo6tSpGj16tC5cuCCr1apixYopJCREDRo0UN26deXv769SpUrJy8tLly5d0qVLl3TkyBFt2bJFW7Zs0aFDhzR79mxFRUWpTZs2mjBhgqpXr15Q1wcAAAAA+P9yLABr166tP//8U66urmrdurW6d++uF198Uffdd1+ugfv27StJ2r9/v2bPnq158+YpJiZGS5cu1YwZM9StWzdzrgAAAAAAkCc5zgJ6+PBh9ezZUwcPHlRMTIy6dOmSp+Ivs6CgII0dO9YYCaxWrZoOHTpkV9IAAAAAANvlOAJ44MABVa5c2ZQTWSwWdevWTV27dtXJkydNiQkAAAAAyLscRwDNKv6ynNDFRRUqVDA9LgAAAAAgZywEDwAAAABOwq6F4G915coVHTlyRJJUpUoVlShRwszwAAAAAAA7mDIC+Ntvv+npp5+Wv7+/QkJCFBISIn9/fz399NPavXu3GacAAAAAANjJ7hHAXbt2qUmTJkpISFDJkiVVuXJlJScn6/Dhw1q3bp2efPJJbdiwQXXr1jUjXwAAAABAPtk9AjhkyBAlJSXpyy+/1Llz57Rjxw798ccfOnHihDp16qSkpCS99957ZuQKAAAAALBDrgXgqVOncjy+efNmtWvXTr1795arq6ux39/fX9OnT5ebm5s2bdpkf6YAAAAAALvkWgDWrFlTX3zxxR2PW61WWSyW7IO7uNzxGAAAAACgYOVaAAYEBKhv37564okn9Pvvv992/IknntCiRYsUHR2dZf/Vq1cVERGhtLQ0Pf744+ZlDAAAAADIl1wLwN9//13vvvuudu7cqfr162vIkCFKSUkxjn/wwQdydXVVt27dFBgYqKeeekohISEqX768Zs6cKU9PT40ZM8ahFwGgaLNYdt72evpp39v2AQAAwLFyLQA9PT01duxY7dy5UyEhIRo/frxq166tFStWSJL+9re/ac2aNQoJCdHp06e1adMm7dy5U4mJiapXr55WrlypBg0aOPxCAAAAAAA5y/MsoLVq1dKmTZv0xRdf6OLFi2rVqpW6d++u8+fPq0GDBtqyZYtOnjypDRs2aMOGDTpx4oS2bdumRo0aOTJ/AAAAAEAe2bwMxBtvvKHY2Fh17NhRc+fOVVBQkKZPny5JKleunBo1aqRGjRqpfPnypicL4O5ktdYzXpMnV8hybPLkCsYxAAAAOFa+1gEsW7asFixYoJiYGBUvXlyvv/66nn76af35559m5wfgHhMREaDJkyto+vQETZ5cQRERAYWdEgAAgNOwayH4559/Xn/88YcGDBigjRs36tFHH9Xo0aOVlpZmVn4A7kEREQGqUuU6xR8AAEABy1MBeP36dc2dO1fh4eF6/vnnFR4erjlz5igjI0Pe3t765JNPtHXrVtWuXVsjR47Uo48+qg0bNjg6dwAAAACADXItAJOTk/XMM8/olVde0axZs7R06VLNmjVLYWFhatq0qZKSkiRJdevW1datWzVx4kSdOHFCTZs21euvv67Lly87/CIAAAAAALnLtQAcOXKk1q9frzJlyujTTz/VokWL9Omnn6pcuXLavHmzRo4cabS1WCzq16+f/vjjD7Vp00bffPONgoODNW/ePEdeAwAAAAAgD3ItABcsWCCLxaIlS5ZowIABatOmjQYMGKD//ve/slqtWrBgwW19HnjgAf30009auHChXF1d1b17d4ckDwAAAADIu1wLwFOnTqlYsWKqU6dOlv2PPvqofHx8dPr06Tv27dChg2JjY/Xmm2/anykAAAAAwC5uuTUoU6aMTp48qQMHDqhGjRrG/tjYWCUkJOiBBx7Isb+vr68mTZpkf6YAANNZLJYs20FeXrqcnq6Sbm7an5xs7LdarQWdGgAAcIBcRwA7dOggq9Wq1q1b6+uvv9bq1av11VdfqU2bNrJYLGrfvn1B5AkAcLAgLy/tT07W2bQ07U9OVpCXV2GnBAAATJbrCOCYMWO0adMm7dixQ7179zb2W61W1a1bV2PGjHFoggCAgnE5PT3HbQAAcPfLdQSwePHi2rRpk6ZOnaqOHTuqSZMm6tChg6ZOnarNmzfL19e3IPIEADiA1Wo1Xr1DQ7Mc6x0aahwDAAD3hlxHACXJw8NDvXr1Uq9evRydDwCgkIyKjJQkBQYH62RsrLENAADuHbmOAAIAnMeoyEhVb9CA4g8AgHsUBSAAAAAAOIkcC8B+/frp7Nmzpp7wxx9/1Pz5802NCQAAAADIXY4F4KRJk1S1alUNHDhQBw8ezPdJrl27pujoaNWrV08dO3bUgQMH8h0LAAAAAJA/ORaAX3zxhXx8fDRx4kQFBQXp8ccf17///W/t3LlTGRkZOQbPUV+kAAAgAElEQVQ+deqUfvjhB7366qsqU6aMunXrpt27d+vFF19UWFiYqRcBAAAAAMhdjrOAvvHGG+revbs+/PBDTZkyRVu3btW2bdskSZ6engoODlZAQIBKlSolT09PXb58WZcuXdLhw4d1+vRpSTKmD3/qqac0duxYPfnkkw6+JAAAAABAdnJdBsLHx0djx47V0KFDNXfuXH311Vfavn27UlJStGvXLkmSxWKRpNvWiipdurRefvll9e7dW7Vr13ZA+gAAAACAvMrTOoCS5O3trb///e/6+9//rsuXL2vDhg3asmWLTp06pfPnzyslJUWlS5dWQECAatasqcaNG1P0AQAAAEARkucCMLOSJUvqhRde0AsvvGB2PgAAAAAAB2EdQAAAAABwEhSAAAAAAOAkKAABAAAAwElQAAIAAACAk6AABAAAAAAnQQEIAAAAAE6CAhAAAAAAnAQFIAAAAAA4CQpAAAAAAHASFIAAAAAA4CQoAAEAAADASbjZ2iElJUWbNm3SunXr9Msvv+jUqVM6f/68UlJSVLp0aQUEBCg4OFhNmjRRkyZNVK1aNUfkDQAAAACwUZ4LwD179ug///mP5syZo6tXr0qSrFZrljYJCQk6duyYduzYoaioKEnSY489pt69e+vll1+Wl5eXiakDAAAAAGyRawG4d+9eDR48WCtWrJB0o+jz8PBQnTp1VLduXfn7+6tUqVLy8vLSpUuXdOnSJR05ckRbtmzRqVOntHXrVm3btk2DBg3SsGHD9NZbb8nd3d3hFwYAAAAAyCrHAvC1117TrFmzlJGRoVKlSqlTp04KDQ1VgwYN5OHhkWvwkydPatGiRYqKitIvv/yiQYMGacqUKZo5c6YaNWpk2kUAAAAAAHJnsd56H2cmLi4uqlGjhoYNG6bOnTvbNXJ3+PBhffjhh5o1a5aGDh2q4cOH5zvWvSQmJkYxMTFasmSJcdtsXsXFxcnPz89BmQGOlZCQIB8fn8JOA9ngu8mbe/1zupuvryjnXlRyK6w8CvK8jv6d5KhrMTuumfHMimVvnMLqX5D9bv37HTRokLZv327zubNlzUFUVJQ1IyMjpyY2O3r0qHX9+vWmxrwX1K9f3+Y+MTExDsgEKBhr1qwp7BRwB3w3uRveo4f1Px99ZB3eo0dhp+Iwd/PfQVHOvajkVlh5FOR5Hf07yVHXYnZcM+OZFcveOIXVvyD73fr3m59a4U5yvAW0W7du5lSZmVSqVEmVKlUyPS4AAI5isViM90FeXtqfnGxsL1iwwNi23vmmGgAAigTWAQQAwAaX09Nz3AYAoCijAAQAIBdWq9V49Q4NzXKsd2iocQwAgKLO5oXgbzp9+rQmTpyon3/+WceOHVNycrKuXbtmHL98+bK++uorWSwWvfPOO3J1dTUlYQAACtOoyEhJUmBwsE7GxhrbAADcDfJVAK5evVovvfSS4uLijP/xzPx8hCSVLFlS3377rXbu3Kng4GC1adPG/mwBACgCRkVGau3ater1z38WdioAANjE5ltAT5w4oY4dO+rKlStq3bq1oqOjVbJkyWzb9uzZU1arVf/973/tThQAYD6LZedtr6ef9r1tHwAAuDfYXAB++umniouLU8eOHRUTE6POnTvfcVH4li1bSpK2bt1qX5YAAAAAALvZXAD+/PPPslgs+uCDD3JtW7VqVXl6eurw4cP5Sg4AAAAAYB6bC8Bjx47pvvvuU40aNfLU3sfHR4mJiTYnBgAAAAAwl82TwLi4uCgjIyNPbTMyMhQfH6/ixYvbnBgAwPGs1npZtqdMOS9v71glJQUrIiKgkLICAACOYvMIYMWKFXXt2jUdP34817YbNmxQWlqaHnrooXwlBwAoWBERAapS5TrFHwAA9yibC8DmzZtLkqZNm5Zju/T0dA0bNkwWi0XPPfdc/rIDAAAAAJjG5gJwwIABcnd314QJEzRz5sxs2+zZs0ctW7bU5s2b5ePjo4iICLsTBQAAAADYx+YCsHLlyvrPf/6jtLQ09ezZU+XLl9eVK1ckSY0bN1alSpVUt25drVmzRq6uroqMjJS/v7/piQMAAAAAbGNzAShJPXr00OLFi1W5cmWdOXNG165dk9Vq1caNG3X8+HFZrVZVqVJFS5YsUfv27c3OGQAAAACQDzbPAnrTc889p4MHD2rNmjXatGmTTp06pYyMDJUtW1aNGjVS8+bN5eaW7/AAAAAAAJPZVaG5uLioWbNmatasmVn5AAAAAAAcxOZbQE+fPu2IPAAAAAAADpavdQBbtWqluXPnKjk52RE5AQAAAAAcwOYCMCMjQytWrNArr7yiMmXK6NVXX9Xq1asdkRsAAAAAwEQ2F4A///yzQkND5e3trYSEBM2aNUvPPvusKlasqPfee0+xsbGOyBMAAAAAYCebC8Bnn31Ws2fP1tmzZzVr1iw1a9ZMFotFJ06c0Pjx41W7dm099thjmjx5si5cuOCInAEAAAAA+ZCvdQAlydvbW927d9fy5ct1/Phxffzxx3r44YdltVq1Y8cO9evXT4GBgXrhhRf03XffmZkzAAAAACAf8l0AZlauXDkNGjRIu3fv1m+//aaBAweqXLlySktL0+LFi9WlSxczTgMAAAAAsIMpBWBmDz/8sCZMmKDFixcrJCREkmS1Ws0+DQAAAADARnYtBH+rs2fPas6cOZo9e7b27NnzfydxM/U0AAAAAIB8sLsyS05O1g8//KDZs2dr1apVysjIMEb86tSpo7CwMIWGhtqdKAAAAADAPvkuAFevXq1Zs2bp+++/V2JiolH0lS9fXt26dVNYWJhq1aplWqIAAAAAAPvYXAC+++67mjt3rk6ePCnpxvN9xYoVU/v27RUWFmYsCwEAAO5OU6ZMkbe3t/bt26eIiIjCTgcAYCKbC8CPP/5YkuTi4qKnn35ar7zyijp27KhixYqZnhwAAHC8nP7j9q233jLeM6kbANz9bC4Ag4ODFRYWpu7duyswMNAROQEAgELyhK+vfomPv+M2AODuZnMBuG/fPkfkAQAACsmcmjWN98svXcpS8FX39tZbDzxQGGkBAByA9RkAAHByoZn+czdk7lxp4EAFe3srNilJ7336qaozmzcA3DMoAAEAgKF6aKjek3RMUvv/vw0AuHe45Lfj77//rjfffFOPPPKISpUqJU9PT3l4eGT78vT0NDNnAADgQNVDQ+VevjzFHwDcg/I1Ajh16lT169dP6enpeZoRjGUhAAAAAKDw2TwCuHXrVr311ltKS0tTr169tGjRIklSqVKltGzZMkVGRqp79+5yd3eXv7+/oqKitHz5ctMTBwAAAADYxuYRwM8//1zXr19X37599e9//9vY7+HhoRYtWkiSwsLC1L9/f7Vs2VKjRo3Szp07zcsYAAAAAJAvNo8Abty4URaLRQMGDMiy/9ZbQevVq6dJkybp4MGDxuLxAAAAAIDCY3MBePbsWXl4eKhy5cr/F8TFRSkpKbe17dChg9zd3fX999/blSQAAAAAwH423wLq5eUlV1fXLPuKFy+u+Ph4paamysPDw9jv4eEhb29vHTt2zP5MAQAAAAB2sXkEMDAwUHFxcUpPTzf2VatWTZK0ffv2LG1Pnz6tuLg4Xb9+3c40AQAAAAD2srkADA4OVkZGhn7//XdjX5MmTWS1WjV69Ghdu3ZNkpSWlqb+/ftLkmrXrm1SugAAAACA/LK5AGzRooWsVqsWL15s7IuIiJCnp6dWrFihihUrqkmTJqpQoYIWLlwoi8WiiIgIU5MGAAAAANjO5mcAX3rpJR07dkwBAQHGvqpVq2r27Nnq2bOnzp8/r/Pnz0u6sQD8wIED9corr5iXMQAAAAAgX2wuAEuUKKExY8bctv+ll15S06ZNtXjxYh0/flx+fn5q0aKFgoKCTEkUAAAAAGAfmwvAnPj7+ys8PNzMkAAAAAAAk9j8DCAAAAAA4O5kWgHYpUsXtWzZ0qxwAAAAAACTmXYL6Pr163Xu3DmzwgEAAAAATGbqM4AAANyLLJad2ez1lZR1v9Var0DyAQAgv3gGEAAAAACcBAUgAAAAADgJCkAAAAAAcBKmPQNYrlw5ubu7mxUOAIAi49Zn+6ZMOS9v71glJQUrIiKgkLICAMB2phWAO3dm94A8AAD3noiIAK1du09Nm1L8AQDuLtwCCgAAAABOwuYCMCEhQUuWLNH69etzbbtu3TotWbJEiYmJ+UoOAADAFiPCw/Xnli0aER5e2KkAQJFkcwE4d+5ctW3bVosWLcq17bx589S2bVvNnz8/X8kBAADkxGKxGK9gb2+NnjlTvd99V6NnzlSwt7dxDABwg80F4Pfffy9JCg0NzbVtz549ZbVa9d1339meGQAAgA0up6fnuA0AyEcBeODAAbm7u6tOnTq5tq1fv77c3d114MCBfCUHAACQE6vVarx63/Kf071DQ41jAIAbbJ4F9MyZM/L19ZWLS+61o6urq3x9fXX69Ol8JQcAAJBXoyIjJUmBwcE6GRtrbAMA/o/NI4De3t6Ki4tTRkZGrm0zMjIUHx/P+oAAAKBAjIqMVPUGDSj+AOAObC4AH3zwQaWnp2vNmjW5tl29erXS0tJUrVq1fCUHAAAAADCPzQXgc889J6vVqsGDB+e4vENiYqIGDx4si8Wi1q1b25UkAAAAAMB+NheAffv2lZ+fn/bs2aMGDRooJiZG165dM45fu3ZNixYt0t/+9jft2bNHvr6+evvtt01NGgAAAABgO5sngSldurTmzZun9u3b648//lC7du3k7u6u+++/X5J07tw5paWlyWq1ytPTU9HR0QoICDA9cQAAAACAbWweAZSkVq1aacOGDWrQoIGsVqtSU1N14sQJnThxQqmpqbJarWrYsKE2bdqkli1bmp0zAAAAACAfbB4BvCkkJES//PKL9u/fr82bN+vMmTOyWCwqW7asGjZsqBo1apiZJwAAAADATvkuAG8KCgpSUFCQGbkAAAAAABwoX7eAAgAAAADuPhSAAAAAAOAk8n0L6Pnz5zVjxgxt3LhRJ06cUGJioqxWa7ZtLRaLDhw4kO8kAQAAAAD2y1cBuGjRIoWFhenq1as5Fn03j1kslvxnCAAAAAAwhc0F4P79+9WlSxddu3ZNLVu21PPPP6+3335bfn5+Gj9+vM6cOaOVK1dq48aN8vf31/vvvy9vb29H5A4AAAAAsIHNzwB+9tlnunbtmrp27aqlS5fqrbfekiR5eXmpV69eGj58uNavX6+ffvpJiYmJmjdvnnr06GF64gAAAAAA29hcAK5du1YWi0VDhw7NsV3btm31ySefaMuWLfr3v/+d7wQBAAAAAOawuQA8efKk3NzcVLNmTWOfxWLRtWvXbmvbo0cPubi4aN68efZlCQAAAACwm83PALq5ud32TJ+Pj4/i4uKUkZEhV1dXY7+3t7eKFy+uQ4cO2Z8pAAAAAMAuNo8ABgYGKj4+Psvsn5UqVZLVatVvv/2Wpe2VK1d05cqVbEcHAQAAAAAFy+YC8KGHHlJ6err2799v7GvYsKGkGxPEZDZ8+HBJUvXq1e3JEQAAAABgApsLwGbNmslqtWrZsmXGvj59+shisWjevHl69NFH1aNHD9WtW1dTpkyRxWJReHi4mTkDAAAAAPLB5mcAO3furG3btikxMdHY9+ijj+rTTz/VwIEDtXfvXu3du9c41qlTJ/Xr18+cbAEAAAAA+WZzAVi2bFnNnj37tv39+vVT8+bN9e233+r48ePy8/NTq1at1KJFC1MSBQAAAADYx+YCMCe1atVSrVq1zAwJAABwTxgRHq7A4GCtiYzUqMjIwk4HgJMytQAEAADADRaLxXgf5OWl/cnJxvaCBQuM7cwzqwOAo9k8CQwAAABsczk9PcdtACgouY4Azp0715QThYaGmhIHAADgbjCnZk3j/fJLlzTzzBlju1Xp0mpRqlRhpAXAyeVaAHbv3j3LLQz5YbFYKAABAIBTCd237//eS6r0/58BPBkbyzOAAApNnm8BtVqt+X5dv37dkdcAAABQ5I2KjFT1Bg0o/gAUqjxPAlOlShWFh4crLCxMDzzwgCNzAgAAAAA4QK4jgGPHjtWDDz6oI0eOaOTIkXrwwQfVtm1b/fDDD7p+/bpcXV3z9AIAAAAAFK5cC8AhQ4bowIED2rBhg3r06CEvLy8tW7ZMXbp0Ubly5dSvXz/t2rWrIHIFAAAAANghz88ANmrUSNOnT9fp06f1zTffqGHDhrp06ZImTZqkkJAQ1atXT5MmTdLFixcdmS8AAAAAIJ9sXgewWLFievXVV7Vhwwb9+eefevfdd1W+fHnt3r1b/fv3V2BgoDp37qwdO3Y4Il8AAAAAQD7ZtRD8gw8+qHHjxunYsWNasmSJOnbsKKvVqu+++07z5883K0cAAOBAFsvO215PP+172z4AwN3PrgLwppSUFJ09e1bnzp1TWlqaGSGVlJSkpUuX6oMPPlCHDh1UqVIlWSwWWSwWjRw5Mk8xzp49q4EDB6pGjRry8vJSqVKl9NRTT+nrr7+W1Wq1O8dDhw6pd+/eqlKliu677z4FBASoZcuW+u677+yODQAAAABmy/MyENnZtGmTZsyYoW+//VYJCQmyWq0qUaKEunbtqp49e9qV2NatW9W6det899+xY4datmxpPJPo4+Ojq1evauPGjdq4caMWLlyoRYsWycPDI1/xlyxZok6dOikpKUmS5Ovrq0uXLmn58uVavny5Xn31VX3zzTeyWCz5vgYAAAAAMJPNI4CnTp3SRx99pKCgIDVu3FjTp09XYmKimjdvrrlz5+r06dOaMmWKgoKC7E6uZMmSatasmQYPHqx58+apbNmyeeoXFxenNm3a6OLFiwoKCtK2bdt09epVJSYmavLkyXJ3d9fPP/+s/v375yuvI0eOqHPnzkpKSlKjRo104MABxcXFKS4uTsOHD5ckzZgxQxMmTMhXfAAAAABwhDyNAKalpemnn37S9OnTtWLFCl2/fl1Wq1VVq1ZVeHi4evTooQoVKpia2FNPPaVLly5l2ffuu+/mqe8nn3yiM2fOyMvLS0uWLFGVKlUkSR4eHoqIiFB8fLzee+89TZs2Tf3791f16tVtym348OFKTExU2bJltXjxYpUoUULSjVHGUaNG6cyZM5o2bZrGjh2r119/XSVLlrQpPgAABclqrZdle8qU8/L2jlVSUrAiIgIKKSsAgCPkOgL49ttvq1y5curSpYuWLVsmT09Pde/eXWvWrNFff/2lYcOGmV78SbJr8fhZs2ZJkl5++WWj+Musb9++8vHxUUZGhubMmWNT7MTEROMZvz59+hjFX2ZDhgyRJMXHx+vHH3+0NX0AAApVRESAqlS5TvEHAPegXEcAJ0+eLIvFosqVK6tHjx7q3LmzfH19Jd24HTSvypcvn/8sbXDgwAH973//kyQ999xz2bbx8fHRU089paVLl2r58uUaNWpUnuNv3LhRycnJOcavXLmygoODFRsbazwPCAAAAACFLc+TwBw9elSjRo2yqVi6yWKxKD093eZ++fH7778b72vXrn3HdrVr19bSpUv1xx9/OCx+bGys9u3bZ1N8AAAAAHCUPBWAZiyZUFAyj0oGBgbesd3NY/Hx8UpISJCPj49N8UuWLCkvL69c49sySgoAAAAAjpRrAbhixYqCyMM0V69eNd57e3vfsV3mY1evXs1zAXgzfk6xMx/PnA8AAAAAFKZcC8BmzZoVRB5Oadq0aZo2bZok6cSJE1q7dq1N/TMyMmzuAxQVCQkJ/P0WUXw3eXOvf0538/UV5dyLQm7zJ0xQ8N/+pvkTJqjL4MEFeu6CvH5H/05y1LWYHdfMeGbFsjdOYfUvyH6O/Pu1ayH4oqh48eLG+6SkJGPCmlvdXMD91j55jZ+5f07xc4rdq1cv9erVS5IUEhKipk2b5jkPSVq8eLHNfYCiYu3atfz9FlF8N3lzr39Od/P1FeXcCyM3i8VivA/y8tL+5GRpyZIb+axZc2NbBfPIT0Fev6N/JznqWsyOa2Y8s2LZG6ew+hdkP0f+/dq8EHxRl3m20ZMnT96x3c1jvr6+eb79M3P8y5cvG7OB5hS/oGY/BQAAyM3lWyblu3UbwL0vxwIwJSXFISd1VFwp68ycmWfsvNXNYzVr1nRo/Fq1atkUHwAAwExWq9V49Q4NzXKsd2iocQyAc8ixAKxatao+//xzXbt2zZST7d69W+3atdOECRNMiZed6tWrq2LFipKkZcuWZdsmMTFRGzZskCS1aNHCpvhPPvmkMfvnneIfO3ZMsbGx+YoPAADgKKMiIzW8Rw/956OPNLxHD42KjCzslAAUsBwLwMTERA0YMEBVq1bVsGHDjKLGFsnJyZo7d65atWql+vXrKyYm5o7P5ZnBYrEoLCxMkhQdHa2jR4/e1mbKlClKSEiQq6urunXrZlP8YsWKqWPHjpKkL7/8UnFxcbe1GT9+vKQbz/+1a9fOxisAAABwnFGRkareoAHFH+CkciwA//rrL/Xq1Uvnzp3Thx9+qNq1a6tu3bp6++23FRUVpb179+rMmTNKTU2VJF25ckWHDx/WypUrNW7cOL344osqU6aMXnnlFS1fvlzVq1fXDz/8oH79+uUpucuXL+vChQvG6/r165JuTLCSeX9CQkKWfoMGDVLZsmWVlJSk559/Xjt27JAkpaam6ssvv9T7778v6cYkLNWrV7/tvOHh4bJYLFkems5s9OjRKlasmE6fPq22bdvq4MGDkm4UzKNHj9bUqVMlScOGDVPJkiXzdK0AAAAA4Gg5zgIaEBCgL7/8Uv369dMnn3yi+fPn67ffftOePXs0ZcqUXIPfvJ+8Xr16ioiIUFhYmFxdXfOcXN26dXXs2LHb9k+YMCHLbaQ9evRQZKb/xfLz89PixYvVsmVL/fHHHwoJCVHx4sWVkpKitLQ0STduzZw4cWKec8msSpUqWrBggTp16qQNGzaoevXq8vPzU0JCgjIyMiRJr776qgYX8NTKAAAAAJCTPM0CGhQUpK+//lqnTp3SF198obZt26pkyZJZHirO/LJYLKpbt67eeecdbdu2Tdu3b9err75qU/Fnr/r162vfvn0aMGCAHnroIaWlpalYsWJ68skn9dVXX2np0qXy9PTMd/zWrVtrz549ev3111W5cmWlpKSoZMmSevbZZ7Vw4UJNnz79jiOIAAAAAFAYbFoHsHjx4nrjjTf0xhtvSJIOHjyoU6dO6fz580pJSVHp0qUVEBCgGjVq2LS23p1k9/yeLcqUKaPPPvtMn332mU39IiMjs4wo3km1atWMhdwBAAAAoKizayH4hx56SA899JBZuQAAAAAAHOieWwgeAAAAAJA9CkAAAAAAcBIUgAAAAADgJCgAAQAAAMBJUAACAAAAgJOwWG+u1o5CERMTo5iYGC1ZskRRUVE29Y2Li5Ofn5+DMgMcKyEhQT4+PoWdBrLBd5M39/rndDdfX1HOvajkVlh5FOR5Hf07yVHXYnZcM+OZFcveOIXVvyD73fr3O2jQIG3fvt3mc2fLiiKhfv36NveJiYlxQCZAwVizZk1hp4A74LvJm3v9c7qbr68o515UciusPAryvI7+neSoazE7rpnxzIplb5zC6l+Q/W79+81PrXAn3AIKAAAAAE6CAhAAAAAAnAQFIAAAAAA4CbecDp46dcq0E5UvX960WAAAAAAA2+VYAFaoUMGUk1gsFqWnp5sSCwAAAACQPzkWgFaTVogwKw4AAAAAIP9yLAAPHjxYUHkAAAAAABwsxwKwWrVqBZUHAAAAAMDBmAUUAAAAAJwEBSAAAAAcbkR4uP7cskUjwsMLOxXAqbEMBAAAAExnsViM90FeXtqfnGxsL1iwwNhmskCgYLEMBAAAABzq8i2/A2/dBlBwcrwF1Gq1mvK6fv16QV0PAAAAioDMvwV7h4ZmOdY7NNQ4BqBgsQwEAAAAHGpUZKQkKTA4WCdjY41tAAWPZSAAAADgcKMiI7V27Vr1+uc/CzsVwKkxCygAAAAAOAmLlZuvC1VMTIxiYmK0ZMkSRUVF2dQ3Li5Ofn5+DsoMcKyEhAT5+PgUdhrIBt9N3tzrn9Pdcn1PP+2bp3Zr1sQ7OJO8KSqfa2HlUZDndfTvJEddi9lxzYxnVix74xRW/4Lsd+vf76BBg7R9+3abz50duwvAixcv6uTJk0pMTMzxQd6GDRvac5p7XkhIiM1f6uLFi9WmTRsHZQQ41tq1a9W0adPCTgPZ4LvJm3v9c7pbrs9i2ZmndlZrPQdnkjdF5XMtrDwK8ryO/p3kqGsxO66Z8cyKZW+cwupfkP1u/fvNT61wJzk+A5iTqVOn6vPPP9eBAwdybcsyEAAAwBEyF3a//56shx+ONbb37g1W7dpehZEWABRZ+SoAu3Xrpujo6DxP3ctdpgAAwBFyGgHMXAwWlRFAAChsNk8Cs2DBAs2bN0/FixdXdHS04uLiJElly5ZVSkqKjh49qq+++kpVq1aVv7+/Vq5cqbS0NNMTBwAAAADYxuYCcMaMGbJYLBo9erQ6d+6s4sWLG8c8PDxUsWJFvfbaa9q5c6cCAwPVvn17HTt2zNSkAQAApBsje7e+1qyJv20fAOAGmwvAXbt2SZJeeeWVLPuvX7+eZdvX11eTJ0/W1atXNX78eDtSBAAAAACYweYC8PLly/Lx8VHJkiWNfe7u7kpKSrqtbaNGjeTt7a0VK1bYlyUAAAAAwG42F4ClSpWSi0vWbiVKlFBiYqKuXLmSbZ/Tp0/nLzsAAAAAgGlsLgADAwMVHx+vxMREY19QUJAkad26dVna7tq1S0lJSfL29rYzTQAAAACAvWwuAOvVu/Eg9bZt24x9rVu3ltVq1aBBg7Rr1y5dv35du3fvVnh4uCwWC4vAAwAAAEARYHMB+Pzzz8tqtWrhwoXGvjfffFPlypXT4cOHFRISInd3d9WvX1979+6Vq6ur3nvvPVOTBgAAAADYzuYCsCIBc3oAACAASURBVHXr1lqxYoW6d+9u7CtevLhWrVqlkJAQWa1W4xUYGKiFCxfqiSeeMDVpAAAAAIDt3Gzt4O7urmbNmt22PygoSFu2bNHRo0d1/Phx+fn5qXbt2rdNGAMAAAAAKBw2F4C5qVy5sipXrmx2WAAAAACAnRieAwAAAAAn8f/Yu/O4qKr/f+Cvy86AyCgKogikKeDycU8rE7UsU8vKBVGD1LTCvi1umZVopdXHrX4urUp9SscltTD9pPkBTSMTrQyVjyuikBqyOywC5/eHn7kxzMDMwGwwr+fjMQ/mnnvOue8796Lz5tx7rskJ4KlTpzBu3DgsXLjQYN1XX30V48aNw5kzZ+oVHBEREREREZmPyQngl19+ia+//hrt2rUzWLdly5b4+uuv8eWXX9YrOCIiIiIiU53ZuBGVV6/izMaNtg6FyO6YnADu27cPADBy5EiDdSdMmAAhBL7//nvTIyMiIiIiMoIkSfJrWIsWWDJrFtKXLsWSWbMwrEULeR0R1WMSmMzMTHh7e6NNmzYG6wYGBsLb2xuXL1+uV3BERERERKY4WlSE/Lw8ednXxexzHhI1apIQQpjSwMPDA15eXrhx44ZR9Vu2bImbN2+itLS0XgE2dYmJiUhMTMTu3btNvlS2oKAAzZs3t1BkRJZVXFwMb29vW4dBevDYGKepf06Nef/sOXZ7ic1WcVhqu4MHD5bfD/DxQUphod7lpKQks23TUvti7n7N2Z+5+mpoP7Zqb812Nb/nz549G6mpqSZvWy9hosDAQOHk5CRu3LhhsO6NGzeEk5OTCAgIMHUzDqd3794mt0lMTLRAJETWkZSUZOsQqBY8NsZp6p9TY94/e47dXmKzVRzW2O7q1asFAPm1evVqi2zHUvti7n7N2Z+5+mpoP7Zqb812Nb/n1ydXqI3JY+J9+/ZFYmIivvjiC7z44ot11k1ISIAQAr169apfdkpEREREZIK4uLg6l4kcncmTwERFRUEIgQULFuCHH36otd6+ffvw+uuvQ5IkREdHNyhIIiIiIiJjxcXFITg4mMkfkR4mjwCOHz8ea9asweHDh/HQQw/h0UcfxciRIxEcHAwAuHTpEhITE/Htt9+iqqoK99xzDxNAIiIiIiIiO2ByAihJEnbs2IFRo0bhyJEj2LlzJ3bu3KlTTwiBAQMGYPv27Zx2l4iIiIiIyA6YfAkoAPj5+eHHH3/EunXr0LdvXzg5OUEIASEEnJ2d0a9fP3z88cc4cOAAWrVqZe6YiYiIiIiIqB7q/WAUFxcXzJgxAzNmzEB5eTlycnIgSRL8/Pzg6upqzhiJiIiIiIjIDMzyZEw3NzcEBgaaoysiIiIiIiKykHpdAlpTfn4+srOzzdEVERERERERWUi9E8Dff/8d48aNg1KpRMuWLdG+fXut9Xl5eYiLi8PMmTNRWlra4ECJiIiIiIioYep1CejGjRsxZcoUlJeX11pHqVQiPT0dycnJGDhwIMaPH1/vIImIiIiIiKjhTB4BTE9Pl5O/5557Dj///DP8/Pz01o2JiYEQAnv27GlwoERERERERNQwJo8ArlixAuXl5XjmmWewevVqAICzs7PeukOHDgUAHDt2rAEhEhERERERkTmYPAK4f/9+SJKE+fPnG6zbtm1beHp6IjMzs17BERERERERkfmYnABmZ2fDy8sLQUFBRtVXKBQoKSkxOTAiIiIiIiIyL5MTQHd39zonf6murKwM+fn58PX1NTkwIiIiIiJ7tDA2FmeOHMHC2Fhbh0JkMpPvAQwNDcWJEydw5swZdOrUqc66+/btQ2VlJSIiIuodIBERERGRLUmSJL8P8/REerWr27Zs2SIvCyGsHhuRqUweARw+fDiEEHj//ffrrFdcXIxXXnkFkiRh1KhR9Q6QiIiIiMhe5FVU1LlMZO9MTgBfeukl+Pj44MMPP8SiRYtQVFSktb68vBzffvst7rrrLpw6dQr+/v6YMWOG2QImIiIiIrImIYT8mhEdrbVuRnS0vI6oMTD5EtBWrVph8+bNeOyxx7B48WIsXboUVVVVAID27dvj+vXruHXrFoQQ8PLywtatW+Ht7W32wImIiIiIrG1RQgIAoG14OLJOn5aXiRoLk0cAAeDBBx/ETz/9hHvvvRfl5eWoqKiAEAJXrlxBeXk5hBC499578dNPP+Gee+4xd8xEREREdk+Sjuu8Bg/20SmjxmdRQgI63XUXkz9qlEweAdTo0aMHDhw4gPPnz+Pw4cPIzs5GZWUlAgICcM899yAsLMyccRIREREREVED1TsB1OjQoQM6dOhgjliIiIiImgwhesnv16z5CzNnXpaXV68OQlxcK1uERUQOThJWuGP1jz/+QLdu3Sy9mUYpMTERiYmJ2L17N7788kuT2hYUFKB58+YWiozIsoqLi3l/sJ3isTFOU/+cGvP+2WPsFy86YcqUv2Nav74YoaFVNovHVp+RNbdr6e9JltoXc/drzv7M1VdD+7FVe2u2q3n+zp49G6mpqSZvWy9hQadPnxZjx44VLi4ultxMk9C7d2+T2yQmJlogEiLrSEpKsnUIVAseG+M09c+pMe+fvcQOHDPqZQu2+oysuV1Lf0+y1L6Yu19z9meuvhraj63aW7NdzfO3PrlCbRp8Cag+586dw6JFi6BSqeQZQomIiIiIiMi2jJ4FdMOGDbj33nuhVCrh4+ODHj164IMPPkBlZaVcJycnB88++ywiIiKwceNGVFZWwt/fH++++65FgiciIiKyV0L00nklJRXqlBERWZNRI4AzZszAp59+CgDyQy5PnDiBl156CYcPH8bmzZtx8OBBjB8/HtevX4cQAsHBwZgzZw6mTp0Kd3d3y+0BERERERERGcVgArh371588sknAICWLVvirrvughACv/zyC27cuIFt27bhww8/xNy5c1FcXIwOHTrgtddew6RJk+Ds7GzxHSAiIiIiIiLjGEwAN2zYAAC47777sHPnTvj6+gIA8vLy8Oijj+LQoUOYOXMmhBCIj4/Hq6++ChcXi9xaSERERERERA1g8B7Ao0ePQpIkrFy5Uk7+AECpVGLlypUAbl8WOmfOHLzxxhtM/oiIiIiIiOyUwQTw6tWrcHFxQY8ePXTW9ezZU074pk+fbv7oiIiIiIiIyGwMJoBqtRotW7aEJEm6jZ2c0LJlSwBAcHCw+aMjIiIiIiIiszH6MRCGcMIXIiIiIiIi+2a2BJCIiIiIiIjsm1EztuTm5mLIkCG1rgNQ63oAkCQJ+/fvr0d4RERERERN08YuXbSW9+bmIlyhQIJajWEtWsjl0SdPWjs0asKMSgBv3bqF5OTkOuvoWy9JEoQQeu8fJCIiIiJyZBNPnZLfh3l6Ir2kRF4+UlAgL0dbPTJqygwmgPfddx8TOCIiIiIiC8qrqKhzmchcDCaAhkb+iIiIiIjIdEII+f3C2Fgs/vxzeXlGdDQWJSTYICpq6vjUdiIiIiIiG9Mke23Dw5F1+jSTP7IYzgJKRERERGQHFiUkoNNddzH5I4tiAkhEREREROQgmAASERERERE5CCaAREREREREDoIJIBERERERkYNgAkhEREREROQgmAASERERERE5CCaAREREREREDoIJIBERERERkYMwWwK4YsUKLF682FzdERERERERkZmZLQH85z//iUWLFpmrOyIiIiIiIjIzSQghzNFRmzZtcP36dVRWVpqjO4eRmJiIxMRE7N69G19++aVJbQsKCtC8eXMLRUZkWcXFxfD29rZ1GKQHj41xmvrn1Jj3z55jt5fYbBWHNbdr6e9JltoXc/drzv7M1VdD+7FVe2u2q3n+zp49G6mpqSZvWy9hJgEBAcLJyclc3Tmc3r17m9wmMTHRApEQWUdSUpKtQ6Ba8NgYp6l/To15/+w5dnuJzVZxWHO7lv6eZKl9MXe/5uzPXH01tB9btbdmu5rnb31yhdpwEhgiIiIiIiIHwQSQiIiIiKgJOrNxI25lZ+PMxo22DoXsiIu5OhLmuZWQiIiIiIjqQZIk+f0DSiUC3d0RrlDgK7Ua2TNnYl9eHgB+b3d0ZksAU1NTOQEMERERkZ2RpON6Sn0AaJcL0csq8ZB1HC0qQv7/Ej4A8HUx29d+auTMdglou3btEBwcbK7uiIiIiIionsIVijqXyXHxHkAiIiKiJkyIXvLrjz/Ctdb98Ue4vI4aPyGE/Jq4ZInWuolLlsjryLFxLJiIiIioCdN/Ceht3bqdlt8zCWxa4uLiAAAKhQJqtVpeJmICSERERETUBMXFxSE5ORmRkZG2DoXsCBNAIiIioiZM38gekwIix8V7AImIiIiIiBwEE0AiIiIiIiIHwQSQiIiIiIjIQTABJCIiIiIichBMAImIiIiIiByESbOAFhQUYOfOndi7dy9OnjyJ7OxsFBUVAQCaNWuGwMBAdOnSBcOGDcPo0aPRvHlziwRNREREREREpjN6BHDZsmUICQnBlClToFKpcOLECeTk5KCsrAxlZWXIycnBiRMnoFKpMGXKFAQHB2P58uWWjJ2IiIiIiKxgYWwszhw5goWxsbYOhRrIqBHAadOmYcOGDRBCAADCw8PRtWtXtG3bFgqFAgCgVquRlZWFtLQ0nD59GoWFhZg7dy7S09PxySefWG4PiIiIiIjIrCRJkt+HeXoivaREXt6yZYu8rMkPqPEwmABu374d69evBwBMnz4d8+fPR3BwcJ1tMjMz8c477+Cjjz7C+vXrMWLECIwePdo8ERMRERERkdXkVVTUuUyNi8FLQD/++GNIkoSFCxfiww8/NJj8AUD79u2xdu1aLFy4EEIIfPTRR2YJloiIiIiILE8IIb9mREdrrZsRHS2vo8bH4Ajg8ePH4eTkhDlz5pjc+ezZs/Hmm2/i+PHj9QqOiIiIiIhsa1FCAgCgbXg4sk6flpepcTI4AlhUVARvb2/5Xj9TKBQKeHt7yzOFEhERERFR47MoIQGd7rqLyV8TYDABbNOmDQoLC3H+/HmTOz937hwKCgrQpk2begVHRERERERE5mMwAXzggQcghMCUKVNQWFhodMdFRUWYOnUqJEnCAw880KAgiYiIiIiIqOEMJoDz5s2DQqHAoUOHEB4ejrfffhvHjh1DWVmZTt2ysjIcO3YMb7/9NsLDw3Ho0CEoFArMmzfPIsETERERERGR8QxOAnPHHXdgy5YtGD9+PP7880+88cYbeOONNwAASqVS6zmAeXl5cjshBLy8vLBlyxaEhoZaKHwiIiIiIiIylsERQAB4+OGH8ccff2DixInw8PCQp33Nzc3FlStXcOXKFeTm5srlHh4emDRpEv744w8MHz7c0vtARERERERERjA4AqgREhKCf/3rX/joo49w6NAhpKWlITs7W57hs1mzZggMDETXrl1x77331mvWUCIiIiIiIrIcoxNADYVCgWHDhmHYsGGWiIeIiIiIiJoISZK0lsM8PZFXUQGliwvSS0rkcj5U3nqMugSUiIiIiIioIcI8PZFeUoJrt24hvaQEYZ6etg7JIZk8AlidWq3WugSUl30SEREREZE+eRUVdS6TdZiUAJ47dw5fffUV9u7di1OnTuk8F9DHxwcREREYNmwYJk6ciI4dO5o1WEdWWFiI69ev49atW3JZYGAgTp8+bcOoqClydXVF69at4ePjY+tQiIioEZOk43pKfQBolwvRyyrxkG1Uv7RzYWwsFn/+ubw8IzoaixISbBCVYzMqAayoqMCLL76Ijz/+GJWVlbVeo1tQUICUlBT8/PPPePvttzFjxgysWLECrq6uZg3a0RQWFuLatWto27YtPD095Wup8/Pz4evra+PoqCkRQqCkpARZWVkAwCSQiIiIzEaT7LUND0fW6dNM/mxEEkbccTl8+HDs3bsXQgh4e3tj4MCB6Nq1K9q2bav1HMCsrCykpaXhxx9/RHFxMSRJwoMPPojdu3dbfEcaq8TERCQmJmL37t348ssv9dbx8fFB+/bt4e7urlVeWVkJZ2dna4RJDqasrAyZmZk6o/zmVFxcDG9vb4v1T/XHY2Ocpv45Neb9s+fY7SU2a8QxeLBxf0RMSrLM/zUFBQVo3ry5RfoGLPcZmrtfc/Znrr4a2o+t2luzXc3zd/bs2UhNTTV523oJAz799FMhSZJwc3MTS5cuFcXFxYaaiJs3b4p3331XuLu7CycnJ7F+/XqDbRxd7969a1136tQpUVVVpVOel5dnyZDIgVVVVYlTp05ZdBtJSUkW7Z/qj8fGOE39c2rM+2fPsdtLbNaIAzhm1MtSEhMTLda3EJb7DM3drzn7M1dfDe3HVu2t2a7m+VtXrmAqg5eAfv7555AkCatWrcKzzz5rVFKpUCgwd+5cNGvWDHFxcUhISMBTTz3V4GTVkdWcQpfIkni+ERFRQ9W8t2/Nmr+gUJyGWh2OuLhWNoqKiAwmgCdPnoSLiwuefvppkzufNm0aXnzxRaSlpdUrODIP/Tdh6+JN2ERERGQpcXGtkJx8EpGRTP6IbMngcwBLSkrg4eEBFxfTnxjh6uoKDw8PlJaW1is4IiIiIiIiMh+DCWD79u1RXFyMX3/91eTOjx8/jqKiIgQFBdUrODIPIXrpvPSVW9K5c+cwY8YMdO/eHc7OzoiMjKwlVoElS5YgKCgInp6euO+++/Dbb79p1dmyZQsS9MwaFRkZiTFjxpgUV2RkJCRJqvMVHx+v1ebTTz+FJEmIjY3V2+e9994LSZLwz3/+U2edr68v3nrrLXn5tddek7fj7OwMpVKJfv364fXXX8e1a9e02lZUVNQaY1hYmE6f4eHheuMLDQ2FJElacRARERGRYzCYAI4YMQJCCEyePBmZmZlGd5yZmYknn3wSkiRh5MiRDQqSGr+TJ09i9+7d6Ny5Mzp16lRrvXfeeQdvvvkm5s2bh8TERHh7e+P+++/H1atX5Tq1JYD1sXbtWqSkpMivsLAwPPzww1pl06ZN02qzadMmAMCOHTvqHN1evny5UaPfLVq0QEpKCg4fPgyVSoXRo0cjISEB3bp100l+AWDu3Lla8aWkpGDz5s1adTw9PXHmzBmd9ikpKcjKytKZUZaIiIioMVgYG4szR45gYS1/iCfDDF7XOW/ePHz++ec4ffo0IiIiMGHCBDz00EN1Pgbi3//+N1QqFW7evAk/Pz/MmzfP4jtC9m3UqFF49NFHAQBjxoxBTk6OTp3S0lK88847mD9/PmbOnAkAGDBgAEJCQrB69WqLjFhFRERoLXt5eaFVq1bo37+/3vp//vknkpOTMXToUOzfvx+7d+/G448/rlPv7rvvRmpqKj799FN5X2rj6uqqtb0HH3wQzz77LAYOHIioqCicOnUKTk5//60mNDS01vg0fHx8EBERAZVKhR49esjlKpUKDzzwAA4fPlxneyIiIiJ7UH1iujBPT6SXlMjLW7ZskZeF4Sfb0f8YHAFs3bo1vv/+e7Ru3RpqtRrr16/HuHHjEBERgebNm8PV1RWurq5o3rw5IiIiMG7cOKxfvx43b95EQEAA/v3vf6NVK97s6+iqJzC1+emnn1BYWIhx48bJZV5eXhg1ahT27NkDAIiNjcXXX3+NAwcO1HqJ5saNG9GxY0f4+Phg+PDhuHLlitn2Y8uWLaiqqsK6desQEBAgjwbWFBQUhCeffBLvvfcebt26ZfJ2lEol3nnnHfz3v//Ff/7zn3rFGhUVpTUyWFVVha1btyIqKqpe/RERERHZUl5FRZ3LZBzD38oB9O7dG//973+xYMECBAUFQQhR5ysoKAivvfYa0tPT0asXZ5a0N2vW/KX1016kp6fD2dkZd955p1Z5eHg40tPTAQCvv/46Bg8ejJ49e+q9RPPIkSNYvXo1li9fjo8//hjHjx/H9OnTzRbjpk2b0LdvX9x5550YN24cvvvuOxQVFemt+8orryA7Oxuff/55vbY1ZMgQODs74+eff9Yqr6qqQkVFhdarqqpKp/2YMWOQlZWFlJQUAEBycjLy8vIwevToesVDREREZG3Vc4wZ0dFa62ZER8vryHhGT+3p4+ODN998E2+++SbOnDmDtLQ0ZGdny19+mzVrhsDAQHTt2rXOe7zIttas+QszZ14GAPmnvTyLJy8vD97e3nB2dtYqVyqVUKvVKC8vR4cOHdCiRQtUVVXpvQyysLAQ3333HZRKJQDg6tWreOmll1BSUgJPT88GxXfhwgUcOXIEy5cvBwBMmDABH3zwAXbu3InJkyfr1O/QoQOioqLwzjvv4KmnntLZL0MUCgWUSqXOZDBxcXGIi4vTKps6dSo+/fRTrbIWLVrggQcegEqlwoABA6BSqTBixAg0a9bMpDiIiIiI7MGi/80B0TY8HFmnT8vLZBrTn+0AoFOnTkzyGqlBg7zrXG7s+vbtKyd/wN/3+GVlZaFjx44N6lulUkGSJIwfPx4A0L9/f4SEhGDTpk16E0AAePXVV9G1a1eoVCpMnDjR5G3q+4vW/Pnzde47rO0y66ioKMybNw/vvfcetm/fjg8//NDkGIiIiIjsxaKEBCQnJ2M65xipN6MuAaWm48CB4jqXbUmpVKK4uBiVlZVa5Xl5eVAoFHBzczPYh6+vr9aypo05nkW5adMm9OvXD15eXsjPz0d+fj4eeeQR7Nu3T++kNsDtBPSxxx7D0qVLTb48Qa1WIy8vD/7+/lrl7du3R58+fbRewcHBevsYPXo08vLysGDBApSXl2PEiBEmxUBERERETUu9RgCp8dJc7jlz5mWsXh1kN5d/AkBYWBgqKytx7tw5dO7cWS5PT0/Xes6dLaSlpSEtLQ0AtEYYNbZt24ZnnnlGb9vXXnsNvXr1wo4dO0za5v79+1FVVYUBAwaYHvD/NGvWDA8//DBWrlyJCRMmNPgyWCIiIiJq3Cw6Anjz5k1MmTIFU6dOteRmyESapM+ekj/g9qMTfHx8sHXrVrlMrVYjMTERw4cPl8vc3NzMMqJnik2bNsHFxQV79uxBUlKS1qtLly61zgYKAD179sTDDz+Mt99+2+jt5eXl4ZVXXkHnzp0xePDgBsX+3HPPYdSoUZgxY0aD+iEiIiKixs+iI4ClpaVISEiAJEn47LPPLLkpsnNqtRq7d+8GcPt+vMLCQmzbtg0A8PDDD0OhUMDDwwOvvPIK3nzzTSiVSoSFhWHFihWoqqrC888/L/cVFhaGb775Bjt37kS7du0QGBiIwMBAi8avUqnw0EMP4aGHHtJZ9+STT+KVV17BlStX0K5dO73tFyxYgHvuuUfvulu3bskzfRYWFuLYsWNYt24dysrK8P333+s8QuPixYs6M4M6OTmhX79+evsfOnQohg4danAfiYiIGitJOq6nNBCAdrkQnJ2eiJeAklVcv34dY8eO1SrTLF+8eBEhISEAbj86oaqqCkuXLsWNGzfQp08f7Nu3T+s+uOeeew6//vorpkyZgry8PCxcuFDnWYDmdOTIEVy4cAFLly7Vuz46Ohrz58/H5s2bMWvWLL117r77bgwePBhJSUk663JzczFgwABIkgQfHx907NgRMTExmDlzps79fwDw3nvv4b333tMqc3d3t/qoKBERERE1PkwAySpCQkKMmgRFkiQsWLAACxYsqLWOn5+f3vvpkpOTdcoiIyNNmnwlNTVVp+yuu+6qs4927dppTVxz6NAhvfX0PdD9rbfewltvvWVUbC4uLkbtizF95ufnG7VNIiIioqbkzMaNuPW/n51qPFfQURhMABcvXlzvztVqdb3bkvnovyxCt5yXRRARERFRU7KxSxet5b25uQhXKPCVWo1h1eZniD550tqh2YzBBDA+Ph6SJFkjFiIiIiIik9X8I/aaNX8BOAagt91NekfWNfHUKfm9r4sL8isq5OVvcnLkZUcaCzT6ElB/f3+4u7ub1HlVVRUuX75sclBkXhzZIyIiIkcSF9cKu3ZVYORIJn/0t3CFAimFhbUuOwqDCWD79u1x+fJlrFq1CuPGjTOp85ycHLRu3brewREREREREdVX9fkT1qxZg5SZM+XliUuW4Ke4OFuEZVMGE8DevXvj8uXLOH78uMkJIC8dJSIiIiIiexD3v2RPoVBArVbLy47G4IPge/XqBSEEjh/XP5EIERERERFRYxAXF4fQ0FCHTf4AI0cAAdQrAXR2dkb79u11HmRNRERERERE1mcwARw0aJD88GohhEmXdfr6+iIjI6PewZF51Jz+tjaONP0tERERkbH0P1LLBwAfqUWNj8EE0NPTE4MGDbJGLERERERERGRBvDbTAUSfPKnz0lduafHx8fDz86t1fVpaGkaPHo02bdrA09MToaGhiIqKQlpaGjIyMiBJksFXRkYGEhISIEkSfHx8UFJSorOd+++/H5IkITY21oJ7S0RERERkf4x+DiCR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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 = 2 #10 # 0, 1, 2, ...,9, 10 (macroave),11 (microave=ACC) for NMNIST\n",
    "indices = [0,] # indices of paths_subproj. Only these subprojects are to be plotted.\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",
    "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(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",
    "# 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",
    "#     \"./traj_order{}.svg\".format(order_sprt), \n",
    "#     format=\"svg\", \n",
    "#     dpi=1200)"
   ]
  },
  {
   "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
}
