{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Using TensorFlow backend.\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from utils import *\n",
    "from keras.datasets import fashion_mnist\n",
    "\n",
    "\n",
    "import keras.utils\n",
    "from keras import backend as K\n",
    "from keras.datasets import mnist\n",
    "from keras.models import save_model,load_model,Model\n",
    "from keras.optimizers import Adam, RMSprop\n",
    "from keras.layers import Conv2D, UpSampling2D, AveragePooling2D, MaxPooling2D, Dense,Input, Dropout\n",
    "from keras.layers import LeakyReLU,Reshape,BatchNormalization, Flatten\n",
    "from keras.models import save_model\n",
    "from tempfile import TemporaryFile\n",
    "import tensorflow as tf\n",
    "import pickle\n",
    "import scipy.io as sio\n",
    "import matplotlib.pyplot as plt\n",
    "from IPython import display\n",
    "import time\n",
    "from sklearn.mixture import GaussianMixture\n",
    "import umap\n",
    "from copy import deepcopy\n",
    "\n",
    "import numpy as np\n",
    "from utils import *\n",
    "\n",
    "import keras.utils\n",
    "from keras import backend as K\n",
    "from keras.datasets import mnist\n",
    "from keras.models import save_model,load_model,Model\n",
    "from keras.optimizers import Adam, RMSprop\n",
    "from keras.layers import Conv2D, UpSampling2D, AveragePooling2D, MaxPooling2D, Dense,Input, Dropout\n",
    "from keras.layers import LeakyReLU,Reshape,BatchNormalization, Flatten\n",
    "from keras.models import save_model\n",
    "from tempfile import TemporaryFile\n",
    "import tensorflow as tf\n",
    "import pickle\n",
    "import scipy.io as sio\n",
    "import matplotlib.pyplot as plt\n",
    "from IPython import display\n",
    "import time\n",
    "from sklearn.mixture import GaussianMixture\n",
    "import umap\n",
    "import scipy.io as sio\n",
    "from copy import deepcopy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"] = \"3\"\n",
    "from keras import backend as K\n",
    "config = tf.ConfigProto()\n",
    "config.gpu_options.allow_growth = True\n",
    "K.tensorflow_backend.set_session(tf.Session(config=config))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# ! pip install umap-learn\n",
    "# ! pip install keras\n",
    "# ! pip install matplotlib\n",
    "# ! pip install np_utils"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "zdim=64 # This is the dimension of intermediate latent variable \n",
    "epochs = 50   * 100\n",
    "epochstep = epochs/100\n",
    "nofclasses=10\n",
    "batchsize=100 \n",
    "nofprojections = 40"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Data Generation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Read MNIST\n",
    "\n",
    "(x_train,y_train),(x_test,y_test)=fashion_mnist.load_data()\n",
    "dataX_train=np.expand_dims(x_train.astype('float32')/255.,3)\n",
    "dataX_test=np.expand_dims(x_test.astype('float32')/255.,3)\n",
    "\n",
    "labelX_train = keras.utils.to_categorical(y_train, nofclasses)\n",
    "labelX_test = keras.utils.to_categorical(y_test, nofclasses)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "numdataTrain = labelX_train.shape[0]\n",
    "numdataTest = labelX_test.shape[0]\n",
    "\n",
    "dataX_train1 = np.reshape(dataX_train,[numdataTrain,28*28]) \n",
    "dataX_test1 = np.reshape(dataX_test,[numdataTest,28*28]) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7f1b14109198>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "iii = 55110\n",
    "trainim = np.reshape(dataX_train1[iii,:],(28,28))\n",
    "plt.imshow(trainim)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "##  X is input and Z the embedding space"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:From /nas/home/mrostami/.local/lib/python3.6/site-packages/keras/backend/tensorflow_backend.py:508: The name tf.placeholder is deprecated. Please use tf.compat.v1.placeholder instead.\n",
      "\n"
     ]
    }
   ],
   "source": [
    "\n",
    " \n",
    "imgX = Input(shape=(28, 28, 1), name=\"input_img\")  # adapt this if using `channels_first` image data format\n",
    "labelX=K.placeholder(shape=(None,nofclasses),dtype='float32') #labels of input images oneHot\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Encoder, Decoder and Classifier NN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "def encoderXNN(imgX,zdim):\n",
    "    x = Conv2D(64, (3, 3), activation='relu', padding='same', name='block1_conv1')(imgX)\n",
    "    x = Conv2D(64, (3, 3), activation='relu', padding='same', name='block1_conv2')(x)\n",
    "    x = MaxPooling2D((3, 3), strides=(2, 2), name='block1_pool')(x)\n",
    "\n",
    "    # Block 2\n",
    "    x = Conv2D(128, (3, 3), activation='relu', padding='same', name='block2_conv1')(x)\n",
    "    x = Conv2D(128, (3, 3), activation='relu', padding='same', name='block2_conv2')(x)\n",
    "    x = MaxPooling2D((3, 3), strides=(2, 2), name='block2_pool')(x)\n",
    "\n",
    "    # Block 3\n",
    "    x = Conv2D(256, (3, 3), activation='relu', padding='same', name='block3_conv1')(x)\n",
    "    x = Conv2D(256, (3, 3), activation='relu', padding='same', name='block3_conv2')(x)\n",
    "    x = Conv2D(256, (3, 3), activation='relu', padding='same', name='block3_conv3')(x)\n",
    "    x = MaxPooling2D((3, 3), strides=(2, 2), name='block3_pool')(x)\n",
    "    '''\n",
    "    # Block 4\n",
    "    x = Conv2D(512, (3, 3), activation='relu', padding='same', name='block4_conv1')(x)\n",
    "    x = Conv2D(512, (3, 3), activation='relu', padding='same', name='block4_conv2')(x)\n",
    "    x = Conv2D(512, (3, 3), activation='relu', padding='same', name='block4_conv3')(x)\n",
    "    x = MaxPooling2D((3, 3), strides=(2, 2), name='block4_pool')(x)\n",
    "    # Block 5\n",
    "    x = Conv2D(512, (2, 2), activation='relu', padding='same', name='block5_conv1')(x)\n",
    "    x = Conv2D(512, (2, 2), activation='relu', padding='same', name='block5_conv2')(x)\n",
    "    x = Conv2D(512, (2, 2), activation='relu', padding='valid', name='block5_conv3')(x)\n",
    "    x = MaxPooling2D((2, 2), strides=(2, 2), name='block5_pool')(x)\n",
    "    '''\n",
    "    # Top layers\n",
    "    x = Flatten(name='flatten')(x)\n",
    "    x = Dense(1024, activation='relu')(x)\n",
    "    x = Dropout(0.5)(x)\n",
    "    x = Dense(1024, activation='relu')(x)\n",
    "    x = Dropout(0.5)(x)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "    embed = Dense(zdim, activation='relu')(x)\n",
    "    encoderX = Model(imgX, embed)\n",
    "\n",
    "    return encoderX\n",
    "\n",
    "    \n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def decoderXNN(yin):\n",
    "\n",
    "    x = Reshape([1,1, 64])(yin)\n",
    "    xx = UpSampling2D((4, 4))(x)\n",
    "\n",
    "    xx = Conv2D(128, (3, 3), activation='relu', padding='same',kernel_initializer='random_normal')(xx)\n",
    "    #encoded = UpSampling2D((2, 2))(yin)\n",
    "\n",
    "    xx = Dropout(0.3)(xx)\n",
    "    #x = UpSampling2D((2, 2))(x)\n",
    "    xx = Conv2D(64, (3, 3), activation='relu', padding='same',kernel_initializer='random_normal')(xx)\n",
    "    xx = Conv2D(64, (3, 3), activation='relu', padding='same',kernel_initializer='random_normal')(xx)\n",
    "    xx = Dropout(0.3)(xx)\n",
    "    xx = UpSampling2D((2, 2))(xx)\n",
    "    xx = Conv2D(32, (3, 3), activation='relu', padding='same',kernel_initializer='random_normal')(xx)\n",
    "    xx = Conv2D(32, (3, 3), activation='relu', padding='same',kernel_initializer='random_normal')(xx)\n",
    "    xx = Dropout(0.3)(xx)\n",
    "    xx = UpSampling2D((2, 2))(xx)\n",
    "    xx = Conv2D(16, (3, 3), activation='relu', padding='same',kernel_initializer='random_normal')(xx)\n",
    "    xx = Conv2D(16, (3, 3), activation='relu')(xx)\n",
    "    xx = UpSampling2D((2, 2))(xx)\n",
    "    decoded = Conv2D(1, (2, 2), activation='sigmoid', padding='same',name=\"decoded\")(xx)\n",
    "\n",
    "    decoderX = Model(yin, decoded)\n",
    "    \n",
    "    return decoderX\n",
    "\n",
    "    #decoderX.summary()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "# def classifierNN(nofclasses,z):\n",
    "#     probX=Dense(nofclasses,activation='softmax')(z)\n",
    "#     classifier=Model(inputs=[z],outputs=[probX])\n",
    "#     return classifier\n",
    "\n",
    "\n",
    "def classifierNN(nofclasses,yin):\n",
    "    interdimX = 32\n",
    "    #y=Flatten()(yin)\n",
    "    #y=LeakyReLU(alpha=0.2)(yin)\n",
    "    #y=Dense(interdimX)(y)\n",
    "    #y=LeakyReLU(alpha=0.2)(y)\n",
    "    #y=BatchNormalization(momentum=0.8)(y)\n",
    "   # y=Dense(zdim)(y)\n",
    "    #y=LeakyReLU(alpha=0.2)(y)\n",
    "\n",
    "    probX=Dense(nofclasses,activation='softmax')(yin)\n",
    "    classifier=Model(inputs=[yin],outputs=[probX])\n",
    "    return classifier"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:From /nas/home/mrostami/.local/lib/python3.6/site-packages/keras/backend/tensorflow_backend.py:3837: The name tf.random_uniform is deprecated. Please use tf.random.uniform instead.\n",
      "\n",
      "WARNING:tensorflow:From /nas/home/mrostami/.local/lib/python3.6/site-packages/keras/backend/tensorflow_backend.py:3661: The name tf.nn.max_pool is deprecated. Please use tf.nn.max_pool2d instead.\n",
      "\n",
      "WARNING:tensorflow:From /nas/home/mrostami/.local/lib/python3.6/site-packages/keras/backend/tensorflow_backend.py:68: The name tf.get_default_graph is deprecated. Please use tf.compat.v1.get_default_graph instead.\n",
      "\n",
      "WARNING:tensorflow:From /nas/home/mrostami/.local/lib/python3.6/site-packages/keras/backend/tensorflow_backend.py:127: The name tf.placeholder_with_default is deprecated. Please use tf.compat.v1.placeholder_with_default instead.\n",
      "\n",
      "WARNING:tensorflow:From /nas/home/mrostami/.local/lib/python3.6/site-packages/keras/backend/tensorflow_backend.py:3144: calling dropout (from tensorflow.python.ops.nn_ops) with keep_prob is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "Please use `rate` instead of `keep_prob`. Rate should be set to `rate = 1 - keep_prob`.\n",
      "WARNING:tensorflow:From /nas/home/mrostami/.local/lib/python3.6/site-packages/keras/backend/tensorflow_backend.py:1944: The name tf.image.resize_nearest_neighbor is deprecated. Please use tf.compat.v1.image.resize_nearest_neighbor instead.\n",
      "\n",
      "WARNING:tensorflow:From /nas/home/mrostami/.local/lib/python3.6/site-packages/keras/backend/tensorflow_backend.py:3814: The name tf.random_normal is deprecated. Please use tf.random.normal instead.\n",
      "\n"
     ]
    }
   ],
   "source": [
    "encoderX = encoderXNN(imgX,zdim)\n",
    "yin =  Input(shape=(zdim,) )\n",
    "\n",
    "decoderX = decoderXNN(yin)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training on Task 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "Classifier = []\n",
    "Encoder = []\n",
    "Decoder = []\n",
    "GMMs = []\n",
    "\n",
    "\n",
    "lamda2=1e-3\n",
    "\n",
    "thres = .95\n",
    "lamda=4e2\n",
    "\n",
    "\n",
    "# reinitLayers(encoderX)\n",
    "# reinitLayers(encoderY)\n",
    "# reinitLayers(classifier)\n",
    "\n",
    "#seed=np.random.randint(0,high=100)\n",
    "loss = []\n",
    "testXperf = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmAAAAI/CAYAAADQs2XyAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nOzdeZwU1b3+8c+3u2dl2DeR3S0uqIjE/RrMYtTE6I1GTeJPY0xQZHGDYdAEERFmcIlBotGbeAPGqIkxxhi9cYnGaNQIRlxwQxEBEVG2gVm7+/z+qJoNZp+e6prp5/16DfRUV1d/e6qXp885dcqcc4iIiIhIcCLpLkBEREQk0yiAiYiIiARMAUxEREQkYApgIiIiIgFTABMREREJmAKYiIiISMBi6S4AYMCAAW7UqFHpLkNERESkRcuXL//MOTewI9sIRQAbNWoUy5YtS3cZIiIiIi0yszUd3Ya6IEVEREQCpgAmIiIiEjAFMBEREZGAKYCJiIiIBEwBTERERCRgCmAiIiIiAVMAExEREQmYApiIiIhIwBTARES6mZLrpjH/p1PTXYaINCMUM+GLiEjqzEws4YPokHSXISLNUAuYiEg3tBcb0l2CiDRDAUxEREQkYApgIiIiIgFTABMREREJmAKYiIiISMAUwEREREQCpgAmIiIiEjAFMBEREZGAKYCJiIiIBEwBTERERCRgCmAiIiIiAVMAExEREQmYApiIiIhIwBTARERERAKmACYiIiISMAUwERERkYApgImIiIgETAFMREREJGAKYCIiIiIBUwATERERCZgCmIiIiEjAFMBEREREAqYAJiIiIhIwBTARERGRgLUpgJnZcDN72sxWmtmbZnZpI+uYmS0ys1Vm9pqZjUtduSIiIiJdX6yN68eBK51zr5hZT2C5mT3hnFtZb52TgX39nyOB2/3/RURERIQ2toA55zY4517xL5cCbwFDd1ntNGCp87wI9DGzISmpVkRERKQbaPcYMDMbBRwGvLTLVUOBtfV+X8fuIU1EREQkY7UrgJlZAfBH4DLn3PZ2bmOimS0zs2WbNm1qzyZEREREuqQ2BzAzy8ILX/c45x5sZJX1wPB6vw/zlzXgnLvTOTfeOTd+4MCBbS1DREREpMtq61GQBvwaeMs5d3MTqz0MnOcfDXkUsM05t6GDdYqIiIh0G209CvJY4P8Br5vZq/6yq4ARAM65XwKPAqcAq4Ay4ILUlCoiIiLSPbQpgDnnngOshXUcMLkjRYmIiIh0Z5oJX0RERCRgCmAiIiIiAVMAExEREQmYApiIiIhIwBTARERERAKmACYiIiISMAUwERERkYApgImIiIgETAFMREREJGAKYCIiIiIBUwATERERCZgCmIiIiEjAFMBEREREAqYAJiIiIhIwBTARERGRgCmAiYiIiARMAUxEREQkYApgIiIiIgFTABMREREJmAKYiIiISMAUwEREREQCpgAmIiIiEjAFMBEREZGAKYCJiIiIBEwBTERERCRgCmAiIiIiAVMAExEREQmYApiIiIhIwBTARERERAKmACYiIiISMAUwERERkYApgImIiIgETAFMREREJGAKYCIiIiIBUwATERERCZgCmIiIiEjAFMBEREREAqYAJiIiIhIwBTARERGRgCmAiYiIiASsTQHMzO4ys0/N7I0mrp9gZtvM7FX/Z3ZqyhQRERHpPmJtXP83wGJgaTPr/NM59812VyQiIiLSzbWpBcw59yywuZNqEREREckInTEG7GgzW2Fmj5nZQZ2wfREREZEura1dkC15BRjpnNthZqcADwH7NraimU0EJgKMGDEixWWIiIiIhFdKW8Ccc9udczv8y48CWWY2oIl173TOjXfOjR84cGAqyxAREREJtZQGMDPbw8zMv3yEv/3PU3kfIiIiIl1dm7ogzexeYAIwwMzWAdcAWQDOuV8CZwKTzCwOlAPnOOdcSisWERER6eLaFMCcc99t4frFeNNUiIiISBOuL5pEdkEWl8+6hVhUc6JnIu11ERGRgB3TYyUz4ksomT0p3aVImiiAiYiIBGxc/F0AIi6a5kokXRTARERERAKmACYiIpIu3sQBkoEUwERERALmUPDKdApgIiIi6WKaqSlTKYCJiIgETC1gogAmIiIiEjAFMBERkTRxpmkoMpUCmIiISMA08ksUwEREREQCpgAmIiKSJmbxdJcgaaIAJiIiEjAdBSkKYCIiIiIBUwATERFJk4iOgsxYCmAiIiIBUxekKICJiIikSdL0MZyptOdFREQCpnnARAFMREREJGAKYCIiImkSJZHuEiRNFMBEREQCp0H4mU4BTERERCRgCmAiIiJpktTHcMbSnhcREQmY5gETBTAREZG00YQUmUoBTEREJGCK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\n",
      "text/plain": [
       "<Figure size 720x720 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-16-93978e78c8ef>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     69\u001b[0m             \u001b[0mdataX_test1CL\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mdataX_test\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mindCLtest\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     70\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 71\u001b[0;31m             \u001b[0mperd_label_X\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mclassifier\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpredict\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mencoderX\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpredict\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdataX_test1CL\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     72\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     73\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.local/lib/python3.6/site-packages/keras/engine/training.py\u001b[0m in \u001b[0;36mpredict\u001b[0;34m(self, x, batch_size, verbose, steps)\u001b[0m\n\u001b[1;32m   1833\u001b[0m         \u001b[0mf\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpredict_function\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1834\u001b[0m         return self._predict_loop(f, ins, batch_size=batch_size,\n\u001b[0;32m-> 1835\u001b[0;31m                                   verbose=verbose, steps=steps)\n\u001b[0m\u001b[1;32m   1836\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1837\u001b[0m     def train_on_batch(self, x, y,\n",
      "\u001b[0;32m~/.local/lib/python3.6/site-packages/keras/engine/training.py\u001b[0m in \u001b[0;36m_predict_loop\u001b[0;34m(self, f, ins, batch_size, verbose, steps)\u001b[0m\n\u001b[1;32m   1329\u001b[0m                     \u001b[0mins_batch\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mins_batch\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtoarray\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1330\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1331\u001b[0;31m                 \u001b[0mbatch_outs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mf\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mins_batch\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1332\u001b[0m                 \u001b[0;32mif\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0misinstance\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mbatch_outs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlist\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1333\u001b[0m                     \u001b[0mbatch_outs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mbatch_outs\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.local/lib/python3.6/site-packages/keras/backend/tensorflow_backend.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, inputs)\u001b[0m\n\u001b[1;32m   2480\u001b[0m         \u001b[0msession\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mget_session\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2481\u001b[0m         updated = session.run(fetches=fetches, feed_dict=feed_dict,\n\u001b[0;32m-> 2482\u001b[0;31m                               **self.session_kwargs)\n\u001b[0m\u001b[1;32m   2483\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mupdated\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0moutputs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2484\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.local/lib/python3.6/site-packages/tensorflow_core/python/client/session.py\u001b[0m in \u001b[0;36mrun\u001b[0;34m(self, fetches, feed_dict, options, run_metadata)\u001b[0m\n\u001b[1;32m    954\u001b[0m     \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    955\u001b[0m       result = self._run(None, fetches, feed_dict, options_ptr,\n\u001b[0;32m--> 956\u001b[0;31m                          run_metadata_ptr)\n\u001b[0m\u001b[1;32m    957\u001b[0m       \u001b[0;32mif\u001b[0m \u001b[0mrun_metadata\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    958\u001b[0m         \u001b[0mproto_data\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtf_session\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mTF_GetBuffer\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrun_metadata_ptr\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.local/lib/python3.6/site-packages/tensorflow_core/python/client/session.py\u001b[0m in \u001b[0;36m_run\u001b[0;34m(self, handle, fetches, feed_dict, options, run_metadata)\u001b[0m\n\u001b[1;32m   1178\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mfinal_fetches\u001b[0m \u001b[0;32mor\u001b[0m \u001b[0mfinal_targets\u001b[0m \u001b[0;32mor\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mhandle\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0mfeed_dict_tensor\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1179\u001b[0m       results = self._do_run(handle, final_targets, final_fetches,\n\u001b[0;32m-> 1180\u001b[0;31m                              feed_dict_tensor, options, run_metadata)\n\u001b[0m\u001b[1;32m   1181\u001b[0m     \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1182\u001b[0m       \u001b[0mresults\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.local/lib/python3.6/site-packages/tensorflow_core/python/client/session.py\u001b[0m in \u001b[0;36m_do_run\u001b[0;34m(self, handle, target_list, fetch_list, feed_dict, options, run_metadata)\u001b[0m\n\u001b[1;32m   1357\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mhandle\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1358\u001b[0m       return self._do_call(_run_fn, feeds, fetches, targets, options,\n\u001b[0;32m-> 1359\u001b[0;31m                            run_metadata)\n\u001b[0m\u001b[1;32m   1360\u001b[0m     \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1361\u001b[0m       \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_do_call\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0m_prun_fn\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mhandle\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfeeds\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfetches\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.local/lib/python3.6/site-packages/tensorflow_core/python/client/session.py\u001b[0m in \u001b[0;36m_do_call\u001b[0;34m(self, fn, *args)\u001b[0m\n\u001b[1;32m   1363\u001b[0m   \u001b[0;32mdef\u001b[0m \u001b[0m_do_call\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfn\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1364\u001b[0m     \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1365\u001b[0;31m       \u001b[0;32mreturn\u001b[0m \u001b[0mfn\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1366\u001b[0m     \u001b[0;32mexcept\u001b[0m \u001b[0merrors\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mOpError\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0me\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1367\u001b[0m       \u001b[0mmessage\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mcompat\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mas_text\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0me\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmessage\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.local/lib/python3.6/site-packages/tensorflow_core/python/client/session.py\u001b[0m in \u001b[0;36m_run_fn\u001b[0;34m(feed_dict, fetch_list, target_list, options, run_metadata)\u001b[0m\n\u001b[1;32m   1348\u001b[0m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_extend_graph\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1349\u001b[0m       return self._call_tf_sessionrun(options, feed_dict, fetch_list,\n\u001b[0;32m-> 1350\u001b[0;31m                                       target_list, run_metadata)\n\u001b[0m\u001b[1;32m   1351\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1352\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_prun_fn\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mhandle\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfeed_dict\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfetch_list\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/.local/lib/python3.6/site-packages/tensorflow_core/python/client/session.py\u001b[0m in \u001b[0;36m_call_tf_sessionrun\u001b[0;34m(self, options, feed_dict, fetch_list, target_list, run_metadata)\u001b[0m\n\u001b[1;32m   1441\u001b[0m     return tf_session.TF_SessionRun_wrapper(self._session, options, feed_dict,\n\u001b[1;32m   1442\u001b[0m                                             \u001b[0mfetch_list\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtarget_list\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1443\u001b[0;31m                                             run_metadata)\n\u001b[0m\u001b[1;32m   1444\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1445\u001b[0m   \u001b[0;32mdef\u001b[0m \u001b[0m_call_tf_sessionprun\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mhandle\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfeed_dict\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfetch_list\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmAAAAI/CAYAAADQs2XyAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nOzdeZwU1b3+8c+3u2dl2DeR3S0uqIjE/RrMYtTE6I1GTeJPY0xQZHGDYdAEERFmcIlBotGbeAPGqIkxxhi9cYnGaNQIRlxwQxEBEVG2gVm7+/z+qJoNZp+e6prp5/16DfRUV1d/e6qXp885dcqcc4iIiIhIcCLpLkBEREQk0yiAiYiIiARMAUxEREQkYApgIiIiIgFTABMREREJmAKYiIiISMBi6S4AYMCAAW7UqFHpLkNERESkRcuXL//MOTewI9sIRQAbNWoUy5YtS3cZIiIiIi0yszUd3Ya6IEVEREQCpgAmIiIiEjAFMBEREZGAKYCJiIiIBEwBTERERCRgCmAiIiIiAVMAExEREQmYApiIiIhIwBTARES6mZLrpjH/p1PTXYaINCMUM+GLiEjqzEws4YPokHSXISLNUAuYiEg3tBcb0l2CiDRDAUxEREQkYApgIiIiIgFTABMREREJmAKYiIiISMAUwEREREQCpgAmIiIiEjAFMBEREZGAKYCJiIiIBEwBTERERCRgCmAiIiIiAVMAExEREQmYApiIiIhIwBTARERERAKmACYiIiISMAUwERERkYApgImIiIgETAFMREREJGAKYCIiIiIBUwATERERCZgCmIiIiEjAFMBEREREAqYAJiIiIhIwBTARERGRgLUpgJnZcDN72sxWmtmbZnZpI+uYmS0ys1Vm9pqZjUtduSIiIiJdX6yN68eBK51zr5hZT2C5mT3hnFtZb52TgX39nyOB2/3/RURERIQ2toA55zY4517xL5cCbwFDd1ntNGCp87wI9DGzISmpVkRERKQbaPcYMDMbBRwGvLTLVUOBtfV+X8fuIU1EREQkY7UrgJlZAfBH4DLn3PZ2bmOimS0zs2WbNm1qzyZEREREuqQ2BzAzy8ILX/c45x5sZJX1wPB6vw/zlzXgnLvTOTfeOTd+4MCBbS1DREREpMtq61GQBvwaeMs5d3MTqz0MnOcfDXkUsM05t6GDdYqIiIh0G209CvJY4P8Br5vZq/6yq4ARAM65XwKPAqcAq4Ay4ILUlCoiIiLSPbQpgDnnngOshXUcMLkjRYmIiIh0Z5oJX0RERCRgCmAiIiIiAVMAExEREQmYApiIiIhIwBTARERERAKmACYiIiISMAUwERERkYApgImIiIgETAFMREREJGAKYCIiIiIBUwATERERCZgCmIiIiEjAFMBEREREAqYAJiIiIhIwBTARERGRgCmAiYiIiARMAUxEREQkYApgIiIiIgFTABMREREJmAKYiIiISMAUwEREREQCpgAmIiIiEjAFMBEREZGAKYCJiIiIBEwBTERERCRgCmAiIiIiAVMAExEREQmYApiIiIhIwBTARERERAKmACYiIiISMAUwERERkYApgImIiIgETAFMREREJGAKYCIiIiIBUwATERERCZgCmIiIiEjAFMBEREREAqYAJiIiIhIwBTARERGRgCmAiYiIiASsTQHMzO4ys0/N7I0mrp9gZtvM7FX/Z3ZqyhQRERHpPmJtXP83wGJgaTPr/NM59812VyQiIiLSzbWpBcw59yywuZNqEREREckInTEG7GgzW2Fmj5nZQZ2wfREREZEura1dkC15BRjpnNthZqcADwH7NraimU0EJgKMGDEixWWIiIiIhFdKW8Ccc9udczv8y48CWWY2oIl173TOjXfOjR84cGAqyxAREREJtZQGMDPbw8zMv3yEv/3PU3kfIiIiIl1dm7ogzexeYAIwwMzWAdcAWQDOuV8CZwKTzCwOlAPnOOdcSisWERER6eLaFMCcc99t4frFeNNUiIiISBOuL5pEdkEWl8+6hVhUc6JnIu11ERGRgB3TYyUz4ksomT0p3aVImiiAiYiIBGxc/F0AIi6a5kokXRTARERERAKmACYiIpIu3sQBkoEUwERERALmUPDKdApgIiIi6WKaqSlTKYCJiIgETC1gogAmIiIiEjAFMBERkTRxpmkoMpUCmIiISMA08ksUwEREREQCpgAmIiKSJmbxdJcgaaIAJiIiEjAdBSkKYCIiIiIBUwATERFJk4iOgsxYCmAiIiIBUxekKICJiIikSdL0MZyptOdFREQCpnnARAFMREREJGAKYCIiImkSJZHuEiRNFMBEREQCp0H4mU4BTERERCRgCmAiIiJpktTHcMbSnhcREQmY5gETBTAREZG00YQUmUoBTEREJGCKXaIAJiIiIhIwBTAREZE00UiwzKUAJiIiIhIwBTAREZE00ViwzKUAJiIikibqgsxcCmAiIiIB0zxgogAmIiIiEjAFMAmNbeXV7KyMp7sMEZHAaAxY5lIAk9DIKx7Mf0q+lO4yREQ6nbogRQFMQiPbEhyXfCPdZYiIBEYfwplL+15ERCRg6noUBTARERGRgCmAiYiIpIlawjKXApiIiEjAnGkQfqZrUwAzs7vM7FMza3SktHkWmdkqM3vNzMalpkwRERGR7qOtLWC/AU5q5vqTgX39n4nA7e0rS0REpPtTS1jmalMAc849C2xuZpXTgKXO8yLQx8yGdKRAERGR7kfBK9OlegzYUGBtvd/X+ctERERExJe2QfhmNtHMlpnZsk2bNqWrDBERkbSJ6Fi4jJXqPb8eGF7v92H+st045+50zo13zo0fOHBgissQEREJL00/IakOYA8D5/lHQx4FbHPObUjxfYiIiHQLSZdMdwmSJrG2rGxm9wITgAFmtg64BsgCcM79EngUOAVYBZQBF6SyWBERke5AJ+OWNgUw59x3W7jeAZM7VJGIiIhIN6fRfyIiImkSUUNYxlIAExERCZgG4YsCmIiIiEjAFMBERETSxKkPMmMpgImIiARMR0GKApiIiIhIwBTARERERAKmACYiIiISMAUwERERkYApgImIiARMg/BFAUxEREQkYApgIiIiaaJ2sMylACYiIpImTgksYymAiYiIBKxmDJjyV+ZSABMREQlY7SB8JbCMpQAmIiISMNfIJcksCmAiIiIBq5uGQh/DmUp7XkREJGC1AUwNYBlLAUxERCRg6oIUBTAREZHA1RwFqQCWqRTAREREAlYXu3QYZKZSABMREQmYzgUpCmAi0moL50/jxblHMbvoh+kuRaRL0zxgogAmIq32ternOSr5Fr165ae7FJEuraYLUqciylyxdBcQhIXzLmXP6Md8XDmIwjm/SHc5It2APjVEOkaD8DNdRrSAxbKqObfycSw7Ix6uSKep6zbRh4ZIR9SNAdOXmUyVEYnEOe9hRiL60BDpCL2CRFJD84BJRgSwZNJv6rVkmisR6SZM39pFOsKZWsAyXUYEMGoDmL5piHSM1ftXRNqr5tNI32UyV0YEsNonOmoBE+mI2iO3nL7MiHREzRgwpy7IjJURAaxmwLDpeF+RDtHkkSKpUtOarNdUpsqMAOZ05JZISqnfRKRDaj+NnHpmMlWGBDDvP823ItIxdd35ei2JdISmoZDMCGDJ2pEraS1DpKtTF6RIamhOPcmMAOY/zIgGDouISAjUfhqpOz9jZUYAc4l0VyAiIrIbxa/MlREBrO6bhlrARDqk9tu6XksiIh2RIQHM+9CI6ENDpEP0ChJJFbV9ZbqMCGDmauYBS3MhIl2cBuGLpIYmNZaMCGCJZM2HhuZbEUkNBTGRjqg7ClKvpUzV5gBmZieZ2TtmtsrMihq5/gdmtsnMXvV/fpSaUtvPEt4g/KgCmEiHaDylSGpoTj1pUwAzsyjwC+Bk4EDgu2Z2YCOr3u+cG+v//CoFdXaIMy94TSz/c5orkdY45fR9012CNEFdkCKpodeStLUF7AhglXPuA+dcFXAfcFrqy0qtRGb0tHYb4/f/crpLEBHpXDqiOOO1NZkMBdbW+32dv2xXZ5jZa2b2gJkNb3d1KeIS8XSXIG2QG9U3w/Dy940+M0Q6RC8h6Yymob8Ao5xzhwBPAEsaW8nMJprZMjNbtmnTpk4ooz61gHUpkax0VyBN0LgVkdTQuSClrclkPVC/RWuYv6yWc+5z51yl/+uvgMMb25Bz7k7n3Hjn3PiBAwe2sYy2ievDokuJRXWwRFhp3IpIauiAFmlrAHsZ2NfMRptZNnAO8HD9FcxsSL1fvwW81bESOy6WrE53CdIm+pAXke5NX2Yk1paVnXNxM5sC/A2IAnc55940s7nAMufcw8A0M/sWEAc2Az9Icc1tFlcPZJeS1BtT6DnNXSTSQRpPmenaFMAAnHOPAo/usmx2vcuzgFkdLy11KqlKdwnSBhENwg+tmm/tGgMm0jEaTykZ0TaUU6ouyC4lojckEenear7MqDU5c2VEANscL0t3CdIGGpMqIt2dWpMlIwJYhjzKbsNF9I0wrDQ+T0QkNTIimny26pN0lyBtoI/48Koyb462iCXSXIlI16ajICUjAtgbtr7llSQ0TCdND62qiHfcTkT7SKRD1PEomRHAHv843SVIG5i6IEOrCq8FLFtHFot0jM4FmfEyIoBJV6M3pLDqmywF4JSy59NciUjXVvMuF1FXZMZSAJPw0WGQofVxbBAAayOD01yJSNdWNwZM73eZSgFMQkeHZYdXWSQXgK2RgjRXItK11Z0LMp1VSDopgEno6EkZXgnz9s6OSH6aKxHp6vyJWNNchaSPPuskdJy6IEPLuSgAUTQNhUhHqAtSFMAkdCJOUxyEVdL/zIg5BTCRjqg7F6RkKgUwCR29IYVfjHi6S5BWmHHJ+ekuQZpQ050fc3otZSoFMAkfUwtY2KkFrGvo279XukuQJnwW6wvA4ZVvprkSSRcFMAmNuPOejhGnMRFhl6UA1iVEonothVUl2QCUWW6aK5F0UQCT0IjjDfA2DcIPPbWAdQ2RLHXoh1XNdDt9/MmNJfMogEloJFALWFehMWBdQ1QtYKG3h9uc7hIkTRTAJDQStS1gal0JuywNHO4a1JoceoPdlnSXIGmiACahEVcLWJeRpXnAugRDB7SEXcySPPC7X6W7DEkDBTAJjTgxACL60Ag9tYB1DVFN8tklvPfmK+kuQdJAAUxCo6YFzNQC1sAtJZO4Yf60dJcB1M3RlqUxYF1CVPupi9DBEpkolu4CRGok/YkJ1QLW0GXlv/MvLUprHfVl64O9S4hoTr0uwXS0akZSC5iERtL/FqgAFn46F2TXoP3UNVhUH8WZSHtdQieqABZ62kfhVum8zo1YUi2VXYGZWsAykQKYhI7pZNyhp4lYw63aH10SUwtYl2ARvedlIgUwCY2a74BqXQk/dROHm/NfTUdU6DyDXYHpkzgjabdL6ETUAhZ6MQWwLuEAPkp3CdIKpulCMpICmISOWsDCT4O7RVLHdLRqRlIAk9CJqgUs9BSSu4ZnIoemuwRphYhOv5aRFMAkdEbHN6S7BGmBAljXEFHXVpegMZWZSQGsnpuKp7BwzuR0l5HxDnXvp7sEaYGOrusasqlOdwnSCvpCk5kyNoBNmXQqB5+4Z4NlV1bcTSG/5W/zvpqmqqTGTcVTuKl4KjOLzk13KdKImCW5+PtfSXcZ0oL9EmvTXYK0gk4ZlZkyLoDdMH8qAIsHP8ttx+3V6Dpfj78cZEnSiCsr7ubKiqUcX7Ap3aVIEw4+dGS6S5AW9LMd6S5BWkHz6mWmjAtgM6qW8vfrJgDwX8nX23z7GxdMoWRewxMjl1w3jXEnDUtFebKLb8RfTHcJ0oSC5M50lyDSLcScWsAyUUaejPvLif/UXn5vzoH8JW8CMYszrZnbAPx+/mlMr3rG/807MfKNxVOZmVhKjxPO7JRapc4dC89ne1UvZvzk1lbfZuG8aVTsqGJ28S87sbKuq2TOFAxH4ZxftPm2GuDdNcy45HxuuG1JusuQJiScqQUsQ2VkAKtvX9ZzRfk9TV4/u+iHkMhi7g13cFZt+KqTa+UATChfxp0l5zFx5tLOKjVj/XH+qby5dSCz8x/ylzQewH62cBLlpTGuuq7u+sL4El7O+4K3H8libvEdzd5XyZwp5OZVc+nM5tdLp3sXfJtsV80ZV/2lw9uayd3+pbYHMHMKYF3BYcPVDRlmUXOMrXw33WVIGmR8AGvJ1JwnGGjbOefEV7jvmKbXG8OHjCn/kHO+/kXu+5vGkKXSGVXPckZ+09cvmD2J/478k8tZy4pY3bi+GxdMYTrwRfcOI3M2Msi2clNxFtWVxkk8z2PVRzFr3m0NtvUdnmSv8g3cUhLhspm3d9IjatyF3zmOgw4/hFdeeZXf/v5fTa733cqnOrWOWxZOojoeY8ZVzbc0DopvBmDS905grzFjWlw/1WZPPpsd8UpuvuOhllfOQNUuSpYl+F7lk5TMmcLMOYsbXa94zhROtBf5mzuGWXMWtXr7JddMITcxjEvnFaWq5Iw1hg/TXYKkgQJYE4rnTKVozq0MtO0AzD+mtMH1N5VMJkac0fH1DZYf8eUvprSOhddPxZwx4yetf2Ps7u6f/99ku2r6J7bx5MY9OWGPT9jfP9rrUPcBAOedfiRLx75de5tBthXwBvc/kP0lxla9zws9vUkqb1wwhdxIBVNm/oq98OYgu6z8dzxy/Wq+Wf0Cv8o7lf7xrSxf15N5t9/boJa5RROZXXxnq2v/3neO5KgvHsLWzxLk5OdjQOGcxSycN40jx+/FxPJ74EC4ccE0ps9q+z6f/9Op9CooZ8rMX7X5tjUuK/udf6n5QHViYhkA4w4dxo/Ll3LjAsf0WYuZMuksRg7do9Oes3MLf0hu7x7MHfh/rLDGD6QRyKo3uaeZUXLdNGb+dPd9MjT3U8ZVvMd/cr/Q6m0vvG4aM+1u7uh5ekpqDbO5RROJRSNcdb2GMUhqKYA1oYilPDN3BRP832s+mGtcWf7bRm9XQOPN/Qt+cgnllQl69s7BJRyF17SutaCwuqZLUwGsxtlVf6+9fPzA19htSqo5vZkzdkiTt0/6JyqeVP4gC68toNB53XCPXL+Ob9Zb75vVLwDwo3Kvq++/B8PtJRcwqfxBnomO5d92KLNz72fRQqiM57DslX9x/wPLm6398MPHM63st/yhzwS+U/VHv967KQTqH4k+wq1pdjtNOT7rFY4rf4OF8/Ip7GAAuql4MlmRaqYV1gXMr5S9tNt6e1Z/CkB/28wdJefzxZHG+RVLWLSwnGmF/9OhGhpzZK+P+Hq118pcE7ibs3DepRzCmzy3fuBuAbojSq6ZQumnn6d0m53lR8kH6ed2wJwl/Cz/e2xaW8r8W733sJrXw9EVr+12u9tLfsC2ip4U7fJ+Fc1KQAIOqlzV+cX7dl4ziBdiY/jqT//e8sopdEXOnymwCqBtAezXxd/nwopHuCn3XK4sarmL//Vrx/JU3tFcVrh7y/vCOZNJWmS3/RB2S391C3vtvT/HnXBSs+vdXDKZ7Ky+TLliXkCVhYMCWDMmJFe0+TYTy/9M8ZwpJBNGRUUVc2/wxhLNit3DB7Eh7FU7y3vTL6RzTv4iU47O5sDEh/Sz9lQuuwbm+uqP5St0dWP2agJXcyaVPwjAhMSrfJg7BOIwrex+78oxwJzeACzO+w7HVLzK6zl7syXSl8rKbCIGWVnehIv9E9uavZ+zqp7hxvlTmV6vW2/hvGkNQtXihRdSVtWjwbJ+Sa/F9gB7j4XXTaOwkRaPxjw/91jWxQbx/Jo4i/zsemWF9wF9w7zc2tasL7Cuwe1umD+V0+Ne6+MFFX8FoMzlgMG0st8DqQ9gh1e/A028LuYWXUxuzxwKq3/DDVnnM+PqRZyU+AeHuNW8Pvz8lNUwY+K3uWHPp3h06JFtvu3C66eRE6vs9HGG/4wcXHukd/3pKC4v+x3/O/QUAGYXXcTc3P8D4MBdTtw9t+hiZuf+ifX0Z7f3K6v5r24c4NWX/4jrf9aw5bXkumnsFV3Dis8GMe/mjj0XelglX000/wWnJQuvvZTqiiRXL2h9kPHCV9tdWPEIABMq/80tCycRj0eZflXj3cAAB7vV7L/zI96f8zSfWW+OvMb7snNLySUUcg/en/pWnrnuS5RbNif/5AkAin8yGYtZk13MAAuvnUqhW8pLtj9PJ4+g6NrUBbmbiy8hkYwx46rd32vOW3cNz358CLQQwK4o/y07ynIBBbBmmdlJwM+BKPAr51zxLtfnAEuBw4HPgbOdcx92vNSu478i/+FY3mBDfj9uWODNOzaD5kMBeN1H0Wzj50d8yuDk1gYfMjOLzqWkuPFWN0mPH1Q81uR1U8r/AMC4ivcaLH/KHQY0PBK3KdOrlsKcuoBYGF/CgqsTzMry76PsAe/CnCU8nHUMX6/6NwXWF4BTq//FqfyLBbOriWXH6JO1lThRjql4jb9F/wtXnWCm3V277WOTb0AVREZOgKqGdcyIL6GpFtgZVbsfdJJvlbWXa7ryJ59/OsOG7sms+bfttn59tyy8mAjJBq1uu3JNpK+F109ldu69VFdFwWBIxHu9Jf3ZdiKRJMzpzW35Z3BJ4V3N1tGUsmsGUUEW2NEAnBLfvUUQvBbvaFa00ZbuwuoleBPUd24AW5c1CCobv+6CikdZce1hzM1tuQVxKJ+zeOGFHFbxNsfOfp7iOVPIz/dm2I+SZMGcaQzK/Zzrez/C+3Oe456KCVRRxbziuzgp+RyHJt5nzcDUhd+WlFwzhZMjz/FEznFcWVQXSornTKGIu/ldr2An2v5C8iMOL6sZZN90SAKv23hvNrC385679y44g8sqn2ywzoTEqw1+vyD6CIPZysvPnMUXJxzPy9cewQt5Y5lWeCf/s+h6KH+b3nkRKIMj3dtszO6XsscGcEWFdxDb7SU7mFT+R546ailfOem02uuPT9a1rP5PyXlsS/ZpdHhFe4NuV9amAGZmUbzDpb4GrANeNrOHnXMr6612IbDFObePmZ0DlABnp6rg9ro57/vNHu2YSscm3wBgiG1mRmXjR0XeuGAa0yuXcHPe98ixKsqqe3BVdKnXndbI50sOPTqxYgnKV1oRvJozK6vxEP6t6n+BwQgaTlw7K/I7r2uzXvfmofH3WZz/HSjffTsTKl9p9Pn31HUn8PTHezBvcNvqLWIpP1sY59ADezGx/B6Kr42y7oN17H9gfyoSuUyvuptf5J/BZD8QXVZW053XdABL7DJ94fNzj6E0kk+hP4Fyzdgnq10/CkDMvNDwnZ1PtO1B1JNvleRTSU4kq3bZz0suoq/bwqtrsrn5dm//XBL9E71dGS2No0unxrpvG44Tqzs9Tm3YB4q4G8q8y0cl3+Io3gL/s3NvNjA7914+c724d8G3OdL5K7rUnWpnzvQfMufGxgP0LSWXMNO81qLB5VuoH3iisQjE4bAAjjhcvPBCpviX2xssFl4/lcLqJ1tcb7A/vvXQp0+HZxJ8Efhi2TvAnUTL3uSHFX/lQ+peuNmumuJrpmGWxLkIRdc23Ur+6rJ/8uSTv2d6UcPn8YvPPcWzf3+Ywtk/r112btmjYPDOm8saBLD6flz+Z/+ShtRA21vAjgBWOee9cs3sPuA0oH4AOw2Y419+AFhsZuZceo9Z//cTL8Nx6aygoemV3rw8V5T/roU1PWfnvtjmAd8iTalpodtVzUEnu/pK4hVWjPp+o6GtJZeX1T3Hv8E/efyAY5lSbwzl5LI/AndxS8kkLvOXVVwzgMKPTmDR/9bVOXvy2ew93DjftjTY/rHJN2nsVHrfr3ycX5WcyyF+FOvpSnd7jHeUnM9F5Q/xqu1NNTGqLMaxs5s+ArVG7xEDaluXLi2/D4Dz6oXT3uYFj5tKJrPtszgFvXM6PCYvCPtH6sZ0ZeflsOtUbzfMn8qMVmxngG1veLRupC7V3zHvFizrFcosj8rKHMbaStZGvsWPrtp9JsaF115KLLeaftEx/MBf9t2CxlsdAS6r9yV7sG3lpuIpJBJG4dW3kpNdAfGG3aZzZ/4Qi+Xy0+t3b5m9rvAi8vvHuNL/ff7VF7d6IP73dv5fk93k99/zK95fuZw9eja/jbrxv/X4QxzAm57nvcq9KPLvJ9saDoZdUnw2P6zwupeHu09r6zkp/jInmfdlxRv/t/vz8tF5J3JK/CXM9mK6+wDmLOXG7P9HIh5h5PD92fejuyh077FwrvPGrwI9/SmZLildBFzHhmtGM8S/zxuuv5QZV9eFtVsWXozhuLTwDm5eMI0rmv9TdFvWllxkZmcCJznnfuT//v+AI51zU+qt84a/zjr/9/f9dT5rarvjx493y5Yta+dDaL2Xrj2SI93bLa8YYs9FxrBfYh1llsOH0SG1byVNdcvsqv6bT2tvE5Sj42/yufViGE0+VSSDPBM5lKTVtXa1ptu2rdtubJsfMpgPons2cqu6GtYykOHsfpqsZ6JjccAJu3QTAbwYOYAyy63dxtPRsZ32Gjw+voI/5J7Aercn06vubvkGu3g+Mqa2JT9Vno6OBeDw+Lv08gNqY9fnu0r6Jkv5ODpgt+62Gs9Ex5LEGJb4lJ2Wx5aIl2aaeo78PXpYg+tq/vb1l/09eliD2zS2rWcjhxAlSYIIcYs2+VibquOZyKG1Y4u3uh70sZ08FR3HVxKvNLmtzlbzd98//hF92MELsYM6/FpbZvsx3jVsaXw6Ona318Wur6Nyl83y6H7kuUr2Tn7Miug+JKzlE/aYGWZR8qNR9urfgwHH/gAO/FaHHkMr7nO5c258R7aRtkH4ZjYRmAgwYsSIQO7zyGteYuG1U/kqLzDOvdfyDULIG5jvDajdmcgDGoaq1nBYm28ThNU2hCfyj+bSwjsomTOFMbH3dCqikLo35yspnY8s6YyINXxODkpubfD7+wxh7xbGUTamwmWR63c/1hic3ILDGr0uz1WyR2Jzs9vcSW6jywcmtjb52uqVLKMXdcFjcGJLo+ulwts2gg2RPZg+czH/W7y59gCJ1hqS/DzlNQ3y/zafWL8Gf4f61wNESLIf68hOVO+2To2D4++z0fox0G1jP9azMtH8eUl33Z+N/e13XacmINXX2+0gSYQsF2/XmSAmJFew0+XQwyrZaDUO7QYAACAASURBVH15MXYQOYdcBq98r83bSpWa/TLEvMff0nO/NfJcw4Gk6xhQu3/rqySrwe95VlX3GWcwOLm5dgxni8yIJYysHblQWdry+iHQ1hawo4E5zrmv+7/PAnDOLai3zt/8dV4wsxjwCTCwuS7IoFrA0s05h9nu33iTySSRSNNPMpdMYs1cL11HMumIRBpv9WjuuqY09ZxqN+cgRdtrT22JZIJopOmWhbBySQdGavdFJ2jv8yXpHJEmbtfh96cUPueC4uJxLNb57Rc1+6st+y2eSBKLNr8/Uv6+0UbNPZ+6ilS0gLX1VfMysK+ZjTazbOAc4OFd1nkYqDnk5Uzg7+ke/xUWTT3hmwtfgMJXN9JcwGpr+IJO+MBP4fbaU1tXDF8AFrHQhy9o//OluQ/LDr8/dYG/266CCF9Qt7/ast9aCl9t3V5n6OrhK1Xa9CxyzsXNbArwN7xpKO5yzr1pZnOBZc65h4FfA3eb2SpgM15IExERERFfm2O8c+5R4NFdls2ud7kC+E7HSxMRERHpntS3JSIiIhIwBTARERGRgCmAiYiIiARMAUxEREQkYApgIiIiIgFTABMREREJWJtmwu+0Isw2AWs6+W4GgE4y2AVoP4Wf9lHXoP0UftpHXUNj+2mkc25gRzYaigAWBDNb1tHTBkjn034KP+2jrkH7Kfy0j7qGztpP6oIUERERCZgCmIiIiEjAMimA3ZnuAqRVtJ/CT/uoa9B+Cj/to66hU/ZTxowBExEREQmLTGoBExEREQmFjAhgZnaSmb1jZqvMrCjd9WQaM/vQzF43s1fNbJm/rJ+ZPWFm7/n/9/WXm5kt8vfVa2Y2rt52zvfXf8/Mzk/X4+kuzOwuM/vUzN6otyxl+8XMDvf3+yr/thbsI+z6mthHc8xsvf96etXMTql33Sz/7/2OmX293vJG3wPNbLSZveQvv9/MsoN7dN2DmQ03s6fNbKWZvWlml/rL9VoKkWb2U/peT865bv0DRIH3gb2AbGAFcGC668qkH+BDYMAuyxYCRf7lIqDEv3wK8BhgwFHAS/7yfsAH/v99/ct90/3YuvIPcDwwDnijM/YL8G9/XfNve3K6H3NX+2liH80Bpjey7oH++1sOMNp/34s29x4I/B44x7/8S2BSuh9zV/sBhgDj/Ms9gXf9faHXUoh+mtlPaXs9ZUIL2BHAKufcB865KuA+4LQ01yTePljiX14CnF5v+VLneRHoY2ZDgK8DTzjnNjvntgBPACcFXXR34px7Fti8y+KU7Bf/ul7OuRed9260tN62pJWa2EdNOQ24zzlX6ZxbDazCe/9r9D3Qb0X5MvCAf/v6+1tayTm3wTn3in+5FHgLGIpeS6HSzH5qSqe/njIhgA0F1tb7fR3N/9El9RzwuJktN7OJ/rLBzrkN/uVPgMH+5ab2l/ZjMFK1X4b6l3ddLqkxxe++uquma4u276P+wFbnXHyX5dJOZjYKOAx4Cb2WQmuX/QRpej1lQgCT9DvOOTcOOBmYbGbH17/S/1anw3FDRvsltG4H9gbGAhuAm9JbjgCYWQHwR+Ay59z2+tfptRQejeyntL2eMiGArQeG1/t9mL9MAuKcW+///ynwJ7wm3I1+0zr+/5/6qze1v7Qfg5Gq/bLev7zrcukg59xG51zCOZcE/gfv9QRt30ef43V/xXZZLm1kZll4H+r3OOce9BfrtRQyje2ndL6eMiGAvQzs6x+dkA2cAzyc5poyhpn1MLOeNZeBE4E38PZBzVE+5wN/9i8/DJznHyl0FLDNb8b/G3CimfX1m4hP9JdJaqVkv/jXbTezo/yxEefV25Z0QM2Huu+/8V5P4O2jc8wsx8xGA/viDd5u9D3Qb5V5GjjTv339/S2t5D+/fw285Zy7ud5Vei2FSFP7Ka2vp3QfmRDED95RJ+/iHblwdbrryaQfvCNFVvg/b9b8/fH6y58C3gOeBPr5yw34hb+vXgfG19vWD/EGQq4CLkj3Y+vqP8C9eE3u1XjjFS5M5X4BxvtvZu8Di/EnftZPh/fR3f4+eM3/kBhSb/2r/b/3O9Q7Uq6p90D/9flvf9/9AchJ92Puaj/AcXjdi68Br/o/p+i1FK6fZvZT2l5PmglfREREJGCZ0AUpIiIiEioKYCIiIiIBUwATERERCZgCmIiIiEjAFMBEREREAqYAJiIiIhIwBTARERGRgCmAiYiIiARMAUxEREQkYApgIiIiIgFTABMREREJmAKYiIiISMAUwEREREQCpgAmIiIiEjAFMBEREZGAKYCJiIiIBEwBTERERCRgCmAiIiIiAVMAExEREQmYApiIiIhIwBTARERERAKmACYiIiISMAUwERERkYApgImIiIgETAFMREREJGAKYCIiIiIBUwATERERCZgCmIiIiEjAFMBEREREAqYAJiIiIhIwBTARERGRgCmAiYiIiARMAUxEREQkYApgIiIiIgGLpbsAgAEDBrhRo0aluwwRERGRFi1fvvwz59zAjmwjFAFs1KhRLFu2LN1liIiIiLTIzNZ0dBvqghQREREJmAKYiIiISMAUwEREREQCpgAmIiIiErAWA5iZ3WVmn5rZG/WW9TOzJ8zsPf//vv5yM7NFZrbKzF4zs3GdWbyIiIhIV9SaFrDfACftsqwIeMo5ty/wlP87wMnAvv7PROD21JQpIiIi0n20GMCcc88Cm3dZfBqwxL+8BDi93vKlzvMi0MfMhqSqWBEREZHuoL1jwAY75zb4lz8BBvuXhwJr6623zl8mu0gmkukuQURERNKkwxOxOuecmbm23s7MJuJ1UzJixIiOltFh8XgpY0/Zjzce31C7bHbRRfTIzWLmnMVMuehU9hw0iquuu5W5RRfTp1+SUdVr+Sg2lE8/i1LQJ5u+sa1sd31I+tlqYGQTw6s3siXak0+iA6kkl3h1lJ7ZO9i/8gNeTowhJy/JvtXvszOSx/ZoAXnJCsCxPjkUM8iP7aRnspR+iW3kJasAqLBsSiP5YGn4Q3USh7EuMYwZP1mU7lJEREQ6nTnXcnYys1HAI865Mf7v7wATnHMb/C7GZ5xzXzCzO/zL9+66XnPbHz9+vAtyJvzZMy5iwEBHgghbNjv694Wzyh4nYRHejo4EoIcr55DE+/SwStbTH4cxxH3OP2JjOSq+knyrZIfLpcAqKHM55Ftlo/f1LsPYw31OLytvsDzpDAdEzfGZ60UO1fS0cipcFhGSJImQa9UAxF2ET6wfpeQD0JMyermdnfcHSoNeVs4fs4/njKv+ku5SREREmmVmy51z4zuyjfa2gD0MnA8U+///ud7yKWZ2H3AksK2l8BWk2UUXcUTPNVyR/xp9yrwAsz63P0PLP+e1yGi2WC+GJzYCsNPyeCznKD6P9mVU9XoKkuW8ERnNl6pX8ET2eN6N7M2yp19i/AlHsk9yNRtjA9hW0YteuaXEiZG0CJXxXGZctYgpk05lxB57EclOkB2tIkGERDzGF9z7vJ81klXvr+ffa1dw0iGn8eiKx/jOkd/iyMhrfJAzjE3l/Vj7yRoW39EwmDjnMOs+TWAbrxlJpBVfBkRERLqDFgOYmd0LTAAGmNk64Bq84PV7M7sQWAOc5a/+KHAKsAooAy7ohJrbbVDfBN8sf4G/Zh3FW7H9iFmcH5T9mUezjuRf6/sz7/Z7GwSbxubQOOjEPXnz8ce8X2a17n4X3954q05jIWqu/391spoJkawmt9mdwhdAkghem6CIiEj312IAc859t4mrvtLIug6Y3NGiOsvYyrdYwyBmPvs6bzz+NwB+Mmkr1916D6fEvOMRWgo2bz7+ccrqae6+spoJX92RAwUwERHJGBkzE/6Cn1zCUYmV/DNnLG/UC1Hzbr8Xi2XMnyG0nKkFTEREMkfGJI+cnhCzJBttj3SXIo1IYt3poE4REZFmZUwAy8M7CrG6Is2FSKO8LkjNjSYiIpmhw/OAdRW9kqVUuhivPv9iukuRRiSJ0PbZ5ERERLqmjGkB65/Yygbrz31PvpzuUqQRDtMYMBERyRgZE8D2SGxmfWRAusuQJjiMiAKYiIhkiIwJYHsmP2dTtG+6y5AmJDFQABMRkQyREQFsdtEPGWRb2Rzrne5SpAkO00z4IiKSMTIigBX0KABgh/VIcyXSFI0BExGRTJIRASyanQCgKpmb5kqkKZoHTEREMklGBDCXjPJU9DASFWphCSuvBUzzgImISGbIiHnAps9aBDRy8koJDacWMBERySAZ0QIm4ZfUNBQiIpJBFMAkFJwZpqMgRUQkQyiASSgkdRSkiIhkEAUwCQkFMBERyRwKYBIKGgMmIiKZRAFMQkGnIhIRkUyiACYhoRYwERHJHApgEgoahC8iIplEAUxCwYGmoRARkYyhACah4CyiLkgREckYCmASCuqCFBGRTJIR54KU8HPQ5gA2t+hixvRaz3uVI5l57eLOKUxERKQTqAVMQsER2e1k3Od+6wimTDq1ydsM7VPKt6ueZXDeZ51bnIiISIqpBUxCwZuINVn7+ymn78dV4wfS060jXp0glhXd7TZD458CUGXZgdUpIiKSCmoBk1Bwu4wB+/rRJ3Bc8g0OdR8w/+of1y4/8fQvUHLdNOJJx97x9QDkusrA6xUREekIBTAJhfoB7Ib5U/lx2Z9qr8vr06P28reO/i+mx5fys+Jp7IsXwAqSZY1uc/bks5lyUdNdmGE2s+hcbi65hIod1ekuRUREOoECmISCAyL+PGATql9iixVwY+55AOTEKmrXO7TybaLmGM2a2mW9Ejt3294N86Zy0cBl/HjP9cwtmti5xXeCoX17cEX5PSy66Yp0lyIiIp1AAUxCwZl3KqIpF53KmORqns0Zy4erP6TSxeif2ALAgqsu4ajESgCOr1wBwEpG0jdZ2mBbNxVP4aLqP5DtqjgouZrDC9ZQFa+qvX7KRadSPGdKQI+sfXIpB8Cydj00QUREugMNwpdQqDkZ98jho8mLP8un0YEsvuMOVs45mOHVGwEY0LuUrPIECWcMsq184vryUdYg9ouva7Ct75c/wifWjwf5Mvtlr+FrlS9z940XsEf8M17a0Iezh27hqMTz3LIwwWWFt6fh0bYsz3mtfhbR3GgiIt2RWsAkJLwWsLwsrzuxojIHgNWxPRmT+IBFC3/MBWWP8Ex0LCsi+wDwfnQopZEe9HPbmTLpVH5TfA43zJvKHraF53MPpWjOYj6K7UlPK+e88sf4RvxFvj54Lf+VfJ2PrT8X7/wDs4suSvkjOfvMsdxccgkXnHF0u7fRI+m1gEUskaqyREQkRBTAJBRqZsLfM/Ep21w+/1j+GAAro/uRTyXTyn7PW5GRPLvzC6yLDQTgo6zB7Ijk08d2cuioPvyg4jGOTL4KQIXlAVBW6k1RkeUHmWOTb3Jf9pf5S96XyLVq8vPaNoXFgqsns2D2pN2Wz558NgvnT6O6ooIjxx/DFeX3cPARh7XvjwEUJLwDC6IkSCQSLLx+Kt87q/2Bbsqkb3NTyWTiW7a0exsiIpI6CmASCjVHQY6q3sDb0ZE8+tB7AMyYdSu35Z/FA9lf4k/lRzC7+E4+jfUH4PNIP8ojXtD6cfnDABQ4r+WoiiwArrruVlYygi2ugKW5J7GSEby7fTBx8+YVi+4+vRjbKrc1Wef43Lf4anT5bsv3Hg6FVUu45cYZDHKbAOjr2h92ejuvJTBKnJtLLqeweinHHH5Qu7e3z+jBXFn+W372i2vavQ0REUkdjQGTUKgZhJ/jqtkW6dHguitm3oZzjjPNG5C+nV4AlCXyyY5VNVh3n+Q6MIi7rNplj+Z8CTPHpRfN48wfHs1Df/olNxVPBsB2+Qqy4OrJXBh7hE04luZ9iyuLGp7iaGjiM0a7Dfzg20fzmwdfqF0+KL4ZgLysMg6sWA3AiOpPWvXY5xZNJCs3FyNJdl6CK668hd7JHQBkEScv8jkAXy5/if939nHcff9zrdruDfOnMZKP+MuKrRw3biQA0ax4q24rIiKdSy1gEgo1LWBG0h+Q35BZ3bLHXniSG7LO56LLbyKerAtaz0fG0Mu8FrBkvG796bMWc2XRL4j17ctDf3rbu7+kd30k0nCMVY9ecQbZVgbaNgbx6W519HWl5FkVBxz2xQbLt0UKABgW/4SDkx8AsG9ibase+0G9NnA2j/Nj9xBXlP+Oc793An2cH8BcNftXrSbhjAP5iMPHHdLkds4/63hcou5sAsNsHWdVPc1BB4yhIOm1qGXb7pPWzv/pVKZ20fnSRES6KrWASSg4IIIjgsO18L3giYferb2c9PPTk9HDqYhkU3M2IxdPNnLLOsmk3wVpCWYWncvoflHWra7i6KGb+cz1oooYfRPbG9zmzDPH8ruDvO7JrOyGE6Tm+0ctnl79HBgst/043L3LdVdfwk+vv63ZWvapXsdebKAmd+631xj68K6/3XLGJd7jz9nHsX/1Gi4u+z03XB9jxtWLqE5U86PvfZVDxo0hWR3l1LF9WHPd/vwh+yRmXLWIQXGvCzQrF/rES2u3V3ztVC6fUUxOfg9+fPbxzN9/NQ/u/eXaepYUn0N+spwnX9sKDvY55FAcRrwiSY+CKi688jYKYo303YqISKspgEkoJIlgfgBrrAWsKVdeWszPbotT+lkle/etC0zbN25u/oZxL7lFiTO4by8uLruHm0d9n6PLnuVf2QezZ/wz+icajgUbd8B/kW1LAejtGoazXvVm43+fIfwzbzyHl71LXkGEG+dPYfv2auYW37FbGd876yh+eUBd+ALI6ZFLbsILeAdWrSbPqliTNYx3q0dRZHfTJ+YFq2XXH8/P9v+IfuWvspIRHMhHAJxW9STxeJwhCe8k5fm2g/5J77EcUvEe491fuWkRXFl0K3vtczADbQWDq+tOaH5+hXcARPzQr5KTrOTb1UuocFnkRquhHOb+xDG7+M7m/74iItIsdUFKKDjD74J0JK31ASxa0IPLC29n9sK72BnJB2Cby2fe7fc2e7t4wruPbKrJxuuWG5lYSz/bwQdZI9gU7cPgZMNB9LHsurqGxDc1uK5ncicVLoutrgcPZn+N8u1GmcvhW5V/Z3rV3ezTp/EB+WMPPLy227Tufuq6RUcnvXFk1fFsVr61ggqXRX6ynJlF53J0ciX9bAfPR8bUhq/19Gek28iPzv0qw/yDAQYktjDAD2Djkt7BDTn+fUbzo/46WwH48fdPZKfzpgD5buWTnF71HI/Fjmhwns6siL63iYh0lN5JJSTM74JM4trQAlZfheUCsNl60buFdT/+bA0MhmxXRRR/iorK18GgsiqHLdGeDK7ezBlnHMof/+jNuh+JOkhAmcvhwPiHnHXmOH7/wCsA9HE7+EfWWO56dQv3P3ArAP9bvIULKh4FYHTVxwDcXvIDylwBiQpHPBEhu0cEKhrWlmt1C3rWjGmrSrL0/n+y4ZrRFCTL6FewJ8RhUf5ZVFTlcWzyDQCeyv0i51X8HweMOYRe8f8AMCz+KYPcFjCImBek8vyjRSMRr6t2UNILYKNH7UUPe4m7cr/BhIpX6Md2Xi3bl8979uHcyse9otoQkEVEpHFqAZNQqJkHzOuCbN/Tsjrpzem1xXq2uO7i2x9mp8shx1XR0x+gvodtIeGMz3ZsYXukJz2sksP3r5t7Kxb1gtpfc45mFBs5Ytyxtdf1cTsojeRz/wN1U1Ss3tqL32efwGs2mv0TayiZM4WLyh7itIqnOIe/cUzWCvIiXtflJ65v7e167XJqJYAtFVv9x1ZAr+ROYjGvlqpEDoU/WcQq9mQlI/g80g+AHlnedre4Ag5KrN6tla3mBOaxqHdU5GDnddnG/HnRSq0n9yW+xp2RM5g1/zb+uWIjd+V9AwAX0duGiEhH6Z1UQqHuKEiHa2cDSyLuPZ23+kcktmQHeeQlK+nlT/kAsNYGUVL8W8rx5heL5eXUXhfzjyBc7UZS6vLY33ndeReccQx92EGZPydZjbnFd3DWVQ/xXN44Btp2RmevJWKOffiYEWxibGIV/RJbKXfZPJ9zcO3tBviD5ze6PgCUujxKin9b+9h6J3eSG/FbxvyDGh/MOpFHsiYQT3iN2iPi6wF4Ieug2vC1ydW1C/b2Q16O8zbQ28qYXXQRsZgXyKoT2Vx13a0UXuO15t1x37NU4v0tzDSVhYhIR3UogJnZ5Wb2ppm9YWb3mlmumY02s5fMbJWZ3W9mbZtqXDKSw4i4mi7I9j0t45Ve99r2XeYRa8oOyyPXVdI3UdfitDo6BIBq5z1t68+blZf0ugY/L93MX3OO5pvVL7C45EL2O2AsUXOUR3Ibv5+4FwjPrPwHKxnJJtebKhelj+3k6MrX+cD25N2y4dyS930AhiS8eb8+jgwAYHO9Fr3tkQL6ulJ6J0qpclE+2uh1bRZe/XMKr76VpP83OKT6fQDetP1rb7syOqr2cs1jrumKBOhRkFM7TUWiqrFzUPrJOJLVyHUiItIW7Q5gZjYUmAaMd86NAaLAOUAJ8DPn3D7AFuDCVBQq3Zur1wXZ3tNPv/36vyl1eWyJtjQCzLPD8shPVtK/3hGN62ODAIj7w7By/AH6c4sm0jtZyna/NWrl9r68GDmAKeUPcEn0TwBU0vh3jY/WrGYVe7LeBvB/ucfxazuNW/O/C8AoNrI8d39mzbuN8p3eIx+e9OYf+yTqdSduaRDA8unrShmQ2MLHNoDFtz/Y4L7WbtxA3EUYxUY+dX2YftXP+QAvVH6Y7f2fcFb7mAvqHb0ZiyUocDtJOqN04+e7PY6alsmaMXMiItJ+He2CjAF5ZhYD8oENwJeBB/zrlwCnd/A+JAPUzgPmku0eA7b0oZe4Less1m7t1ar1d1ouPVw5A91WPmQwAFuiXrfflgqvG7CHf0qg7+Y+x5lV/2Cbea1Zc4vv4k9l+/Cb3JPpbV6IqT/7fn2L7/gLQ65exvA5q7ii6DaK5tzKti3lVDvvCMSNSS/0ba3yWqX6WylbXAE7/S7NrZG6ALbTP/fl8Pgm1vstZA3u6/Y/sgnvMSzL+gJmxh/cV7kj/3Q2JvZgh8vlxehBDHTemLLeiR1U+HVnRarpkyhlE70bPYq05uCItkwTIiIijWt3AHPOrQduBD7CC17bgOXAVudcTb/NOmBoR4uU7s9Z/Raw9n/Az/zJImYX/7JV65ZZHv1cKb2tjOdyD+UP2RPYsd0LIyXFv+VDBtdON7Ev3piq4dRNP1FS/Fs2VAyq/T2ZaPrl1COrYbfo3OK7eNeGs57+/OfVl2u3V+WHss3Wk0rzaql/aqaaIz0P4kM2+i1ku9oY8Qb0f5A1AoCZ1y7mosIlXFn4M2KF63gneyS9rYyZRefSN1nKO5HhAOS7MvontvFJpPHttrdlUkREdteRLsi+wGnAaGBPoAdwUhtuP9HMlpnZsk2bNrV8A+nWGnRBBjTNQVkkh5FuIwBbI734zlV/Zta8ulnrV0WHsY8/mL1mbqw78k7HubooMmvOotrLiWTbXk6P5XyJe3O/we9+/2Ltsh3+4P/N1osq8+5zR70AVkXdQQGfZvVvdLubIl4LWFlFw9AXzYqQ2yOr9mCB/rl96OdK2RDtzybXi4Mr3uOAxBo+iTa+3Zo+SB25IyLScR15L/0qsNo5t8k5Vw08CBwL9PG7JAGGgd90sAvn3J3OufHOufEDBw7sQBnSHTiMCMkmzwXZGSosp3ZerCq3+/itdVmDGO02cN3Vl9DDKvnf3G9w0cwlDc5LCdSOsUpWtO3owOmzFjG96NYGy3ZYTbdjAdX+y6j+0ZVxV3cKoNJ4412t7+WM4tnIIRRe8/NGr6/yw6RlR+jvtrE90oMHe3yZI93b9KOU16MHNlt3WybKFRGRxnVkItaPgKPMLB8oB74CLAOeBs4E7gPOB/7c0SKl+3N4x9h1tAuyLSoidaErkdz9pbAl0peoOXr0BCqgsokDeu/nRAryy7l8cuOBpy12+i1g26IFVPtdkBVW1+qVjNcFsDVrG/1uw6QZ/4NZ0+dqTPqPNRarpndVGTsjPVi7uornh4zhvezhTC9a1ORtASJqAxMR6bB2BzDn3Etm9gDwChAH/gPcCfwVuM/M5vnLfp2KQqW781rAvAgWjCo/UO10OZRv2bn79ZVeABrAZ/76jQ+yr98N2VE7LRecN9g+4byXZ3W9wf3JeicZ3/UIyBrNhS+AZKV3FONwv3u1NFLAvNvvhLLNHJvXt8nb1XUNN3+icxERaVmHTkXknLsGuGaXxR8AR3Rku5J5vJnwIUL7j4Jsq2znnfD6kZxjmX3tXbtd/9Z/Xqbs4By+ULkGgLjr/DN3lfkBrMxyqfbvL15dF8B2btoEA+GB7C9xZjvv45133mHLfgV8qfI/3qmX4n4LW37jg+9r1LRMuoi6IEVEOkp9CRIKNUdBWoCD8D9J7MET0cN5v3xYo9f/5sEX2Gh92SfptRQlk823LKVCmT+ZaxW5LFv+EjfEzmfa5dfXXj/3F/ezoOr7PPqfze2+j1/f+yTvRYYy0LZ7c35tqWrT7RW/REQ6TifjlpCw2hNxBzUGrPBqb8zW15pZ5zPrzWg+AcA1M81EqpT5473iLsq9f1jW6Dqz5t/W6PK2+ChrD46oeod1NoC5N9zRuhvVzMSqBCYi0mFqAZNQSBL8IPzW+Dxad6RhItH5o9MqI14AS8Q7t7VtU9SbxPWDyJ6tvk3tow/P7hER6bLUAiYhEfEH4ROqALat3iz0yQDOQV3hHxiQ6OT72pnMB2B91qAW1qzPdvlfRETaSy1gEgreNBT+ybhDNM9UadSbzDTpjHffbLxLMJU+Tw7gsdgRvPfG8k69n/IdSdbTn09scKtv4/w50zQlvohIx6kFTEIhVaciSrUKvEHxpeTxmwdf6PT7m36VNzHryZ18Pz+9/jbKy8u5Mi+v5ZVrmf+vpqEQEekotYBJKNSejDtkAazSnzV+u/VoYc2uJ69N4at+13B49o+ISFelACah4J2KyBExrssyWgAAIABJREFUF6oerpqZ50vJT3Ml6We7XRARkfZSAJNQcFjteRldiJ6WyWqvu600ogBWMw2FUwATEemw8HzSifjC1AL21uvLibtI7UmyM1nNyC/lLxGRjlMAk1Co3+oVpjFgv3nwBdbZQLZEe7a8soiISCvpKEgJhfqtXmGahgLg/uhJJMsCmASsiwjZ7hER6ZIUwCQU6rd6hakFDGDmTxelu4RQCNt+ERHpytQFKaGjD/qQqmmmdJoHTESkoxTAJBTqdzuGrQtSfJoGTEQkZRTAJBQadkFKKNXMP6GALCLSYQpgEhL1ApgmmgqpmnNBKiKLiHSUApiEQsOPdAWwcPLPBWlAvLLJIParknO5ccG0Tq/GJZsei5ZUSBSRkFMAk1DQGLDwq+km7mnb2X7dSB5YcBqzJ5/dYJ2ZRefyw7JHGO1Wd3o9t954MQ9d/w1cVVWD5Quvm8ZT877CgtmTOr0GEZH2UgCTUHBNXJYQ8VuVBsQ308vKObPqHwwbkVN3dTxJvx79iJijT6K0U0u5/MLvcnLZc5xe/RzF8y6tXT676CKujC/la4nl5PfQ0ZoiEl6aB0zCwYV3HjDx+S2TET8ir2MA3yl7ivk/nUokCkdFX2NA1jBIQP//396dh8lRlYsf/77V3dPL7JnsG0kgskpEuYCIynb9qWyiiKhX4YKXfYesbCGQkEkAISwBVBQUBS4KgujVsCggAoKACQRIWBISskyS2afXqvP7o6qXycwksyQzNen38zx5ppeq6po56a6333POe5ymbh3y/HO+w27jh3P21FsoDwa6tc9Pan/ASbutZrKzFoBoaf7/S80QCLS551dmWjrse1PtedgJi2nX3Nat1+rKnGmn09YcZP7ie/p0HKVU8dIMmPKFdlkvHYTvT14GLOCtCvn72JeplhZi5WlOM09wuP0G34v/BYAa070AbK8J5UxN3s/i+Zd0+zRObnuKLzjLsI2QMgGGORtyz1U7DWSMxSZTwTB7S7v9Ljn9WM5re4jdQx91+7U6M++qC7g69lsmTUj06ThKqeKmAZjyCQ26fM+Lki2vEGvCuAuUD7M3MVLqAYiKOx5rmGngnB8eu91D7pZxs1glJen8y2S2vexTvbjrcv48dixLrd3ZJ/URxnYwjmFUuo5VMoKVgTGMy2wE4Kb5F3D11LMYOX4CEUlTY3cvOOzK2FI34PtUalWfjqOUKm4agClf0EH4g4C4HxfZDJhtu12GIzObAPiAUblNI5Jm3G4Tt3vIKekVAJR63YU3zDqXN+YezMJ5Xc+iHGoaeTB8JGdM+yXLSyawr/MhP77xPN6e8xn2sVfxUWAUa4PDmOCs59bas7kscT+71bQQjHhj2OyGnv7mOXOmnc6J8ecAqAtUdbndZWeexGVnntTr11FK7fo0AFO+0H4QvgZgfpbNgDkpg22E3Ww3I/RayZ7ttguGt92OtbPPZzx1ANRk6iGdoKwqzQFmJWNlDQA3155D7ezzc/vMmXE2ZZKgxSpFRNhoDaNEbL4Zf5p9+YgxbGJtaBibA9VUSwvntT0EwHB7CxHL7TIcbnofgEWryiiXOAAlJt3ldnvtHmXhqKe4af55vX4tpdSuTQMw5RMFF2sdA+ZL2dJa2QyYYGigjPHGDcDWBkYD8IkZAoAV7Ho+65wZZ7JX6AMAmkyMA9IreHPeoRzd9hIAn06+z+21Z3Bp/NeczBKuu+Jc0o4hXFoCQFzc7s9kk/t/ZQL5cWANVhUtlAEQFIc6U8H4zAaq7EYAamjk8rNO7NXfIBpsBSBlAoRNqsvtpiTexRLDBfHfsPD6nV8TTSk1+GgApnyhsG6mlqHwN8sLwAzQIGWUiA1AW5OhxUR4tWQvAMqkmXlXXdDpMT5T/jHHpl7ktyVf4rmSKUxkPVPM++zNahImxD5mFWe2PcpSmcg4s5HPR97hDzccxwG8BUDKcQOxmXPv4D3GALDeVAOQzERINsLTgc+ysORUngkfyB7OmlxXaUAMQ0eN6fS8TCbD9LPO4JIzjuv0+RGZTTSbKCtlLJFtZMCGmwZetPahkTKOyTzLFeed2+W2SqnipAGY8gnNevldNjC2CqLlBnEzTa0mzKy5d3GHfJu307sDcHb8Ub4QerPdMVLxNm6afx7Hpv7Bg5Gj+NasJ9gQqAHgHcax0VTxq9hXscTQSBl/SB/KvbHjONp+jRPTz/MV+1UAnEy+ZMWyEvf1fhU9jp9ET2D1u+8wc96dHHXVs0ydtYi6wBBKJckhmbdJmBAAgZLO/7/devP5XDnySaaNXUbtdR0zV5PSn/CuNY42CRMxyU6PMX3GfzHObGRFyW48Fvsy+7Casqr2r2eM4eoZp2OM1ipTqlhpAKZ8Rwfh+5PkuiDdjJeFockqBfIzE6fPvp1VK97K7fNF+98suDafBfvForO5LPErNlLFqpZhADRb7r5/jn4Ba8ZrrKiH56z9uT92HDOvv5O33k3wq8hXchkuACedD1xWOhP5ReRrfPzuev5n+v3cdt9f2p133IkBUCpJ3rTcYC0Q6Hym5ZTkcuKEiZHgm/ZT/GHuV3n6uiN4bs4X+dn877Ons5oPQ6OJS5iISfHT2v/i5tr22a2ashoCYmi0KkjiFqqVkMXV538X47h/xIXXns/M8BPcuuD8DueglCoOWohV+UK7WZCaDfOnbBmKbBekEZqtGNhuADbW22zxA89Sd804WiXKODYyOrwegPNP/QbTJy7jVfkUf7EPYdZctxjqllX1LNrtO6z4sIGh0aHUzv8VAF/yjnfrvQ9jjOHHC87j0vgDZIzF2o2bcqc17cpFAJzWxWnHG9O0hsPUSznPlRzEwcl3iEg+e2W8jN7Us7/F1SPf5amSA/koOJ7vxP/MlPRKWohi4fClxL9BYF1wBNV2M8Oden4Uf8I7yp3cseAMoiZOqKQSMpDMhAkG3UCvMtrM1Jo/0XztKFZZI6mITSHalmKPzPu9awul1KCnAZjyhcJxX6KDwHzKK8TqdZvZjtBiudmlRiltt+Xi+H+yubGOH46uYHJyNQAT9hzLuNSzPBo9glnT8pXo59zx0HZfWURIthqwYDMVLFr8YLfP+ur5dzHvCtiwpZGQswZGwTdbn+Hm+edy6Yw7WbTgbPZMf8Dh4y0q0nE+Do7h0ul3kmxrIxyL5Y5zw5XnYoWDrH9vNZMmhoja+SBuwfUXMi3zCABvyiQAEq02sXK3k2F8eh0BMfw1dADHp19kTGsdCBycWs6i2rNoi4eYMfv2bv9OSqnBTwMw5RP5rJeOivEnQ/s6YOI4xCUCQKNV1m7bqxfcC8CS647MlakYzxoSJkRjY6hXrz9zzmI+nr2ERillRA/3nTX3rtzt1muGM1LquTTxAM/NWcr59lKaKKVa3Fpkba3u71kYfAHMvP7O3O3fzTuOatOS+287MriejzIjmMAGppgP+JhhXDX3zlw9s5H2ZgDeaBzFfrFRTJJ1AAyTRi6MP8izgc/06PfJOBkCEkBk67FlDsaksaxwF3sqpfxCAzDlD+1KT2gXpC95zRLIzYK0SXgX+mwmbGvNgVKqM01cfNbxXDHydZ4LTuGqa+/sdNvu+H30cAD26/URYHH4ZMQSaqjjuPgLvCvjeSRxKGXVFmFJMGPq9s8vKaFcPTCA8an1lJo4j5UcxnuyO07KMANwvG8To53NJAhx9YJ7+d95JzAptY7nrP35vP0WWyjnCPsNFsy7kGmzFuWOOe+qCwiFhZJQiqFOHeVOGxEnxQR7PRWmlRfDnyZgbCImRdRJMtrZxFjj1lW7u/RbXDTt7j78lZRSO5sGYMoXtPTXYJBdC9IdhG9jkcYtB9EaiHa6R4sVo5oWxk0cx7DE33grPJmv9OEMzp/+0z7s7bp8Vr6r7+JzvkfAiXPT3XdtY4+O0tI+i1dtWqikleZAKdNm5IMoxxvrP4J6NlFJhHy9tGWRyfwjeQBOMsM5gcf4cuYVbrjiPEaVb+agxFvMsD7GyhjIQMKE2EI5CQnzUWAkhmF8PfkPGiijRaK0SZgPA6N4JbgP30k8zRCnvnd/HKVUv9EATPlDYQSmY8B8KVeI1bthbAfbcT9CkkQ63afNihAUh/3Ty2k2UZo3dV28dCDcsvjXvdovXfDR2WBKGWPqKBGbhLT/O6TbWiCGV1ajlOHAuvoW7q/6fzQ2RZh5vRus3bEgyXltj/CZ4ArCiQwvWXtzX8nXaLQqydglrF/dwI2L7wdgknfszJYtjBwypMO5Ja4Zihh9EynldxqAKZ/IXzC0DIU/bV2GImMb7LQ7XireRQCWMu7j/5F5h7cCE3Jjwwa7tJX/6FxljWCKcav6J72MYG67tlJS0QAlYtMkbjdt7fxfdjjemlUJHht9GAZhpZnE1CsXcch2ziHYSfAF7ixi0W8xygfuvf1mNjeu4vKZtyCWfq5vTQMw5Qvtgi69dvhSrhBrdppEIM3FU+9g4U2w8vU3O90nmymqklbWewVXdwUZk//o/CQwlCkZNwDL0L5r8rrbb2PLNb9jCC00S+fj5ABuuOMBbMcmYAW63Ka7HA3AlF+0vMo5qadZ/8lURo0du/3ti4wWYlW+0L72l35T8iNxsmPAvACsuZWSSJCpVyzi7gf/1uk+hRXrtwQqd/o59hdb8gFYXTCfico4HQOobODV0sU4uawdEXwBOFgagClfqHKaKZMES/64/VIzxUgDMOULhSGXFmL1q/ZlKBxn+x8fhRXrW7YqVTGYGZMPlpq8VQAAHLvj36QVN/Bqk20HYDuKQXQMmPKFMrsNgI2b1g7wmfiTdkEqfygYhK/hlz85XuCVDcAa6Hw5n0JbEg1kh4elMrtObSrbuIGWY4SEyQdWTqZjFbtmiYKBuNX5OLkdzUGwNAOmfKDStAJgjPtZcf9PF2Jv+hd7fv5kDv3yiQN5ar6gGTDlC4WXLaPf3n0puwh3dgxYpqV1u/vUzv8VTV6AkvHXBMg+MY77NaGFCI6d/8qQamvrsG2bF3gl+qk4qo4BU/2hds6F3HfXgm1uU+G4nxFiuZ8Z9VtW8t+JP/KPfzyz089vMOhTACYiVSLyiIi8IyLLReTzIjJERJaIyArvZ/X2j6RUAb12+FI2SA4adxbkXb/8Y7f2q5dyEibExx+u3kln1v+yAVizxLDj7rf7hAl1Osuz1QvA0qZ3KwD0lI4BUzvbS88/zbn2wyQbl21zuyrjri5hWe5nRqmXEQtY6Z17goNEXzNgtwL/Z4zZC5gCLAdmAE8bYyYDT3v3leo2LUPhbwEc7B5Uzq2XctbIMO647/c78az6VzZJ20KULRs3Yhuhgc7HuGWXa8psVaJip52bZsAGvUXzr+Lp645g4bwLBvpUOvX6a3+nXOKUOu2z4C3JTLsejGqaAQiK+yWlym4CoIRdKB3eB70OwESkEvgS8DMAY0zKGNMAnADc5212H/CNvp6k2vW1G3ivZfF9ySI/C9LpwUfHc9HP8X+xQ3fWaQ0Ix3bzgS0SY+E9j1BPeYcFybOyXY+Zbkxa2CHnpoPwBy1jDLXXX0g83chR9r8Yam0e6FPqVEvjFgDCpn0m6483fYvH5h0HwMO/vIuIuM+XeNsNyzQAEHUS/XWqvtaXQfgTgTrg5yIyBXgNuAgYYYxZ522zHnq8bq4qRnq98D0bd+ZfABunB1MlLpz2k511SgPGSWcgBK1edmuLdB2AJcXNfBm7f75YOFg6CH+QumPhj5ieeYRfRL4Gdj5j1BP/evov/PmvjzHzmlsguHOyrkYcMO0DsBef/TNfTb5MCJu/PPEga1avyD0XNm7Ga5TjBpRbZ86KVV++kgWBzwKLjTEHAK1s1d1o3Fxkp58EInKmiLwqIq/W1dX14TTULkHrsPqf437YBnCKvlRI25ZGID++66nYIbwUndLptgki2EZw0v3zP9sR7YIcjOZdcQ7ntz0CwG5pN4cx1G7o8XGeeeVxLrceZOGCy/p8Tk/+5QlunH8BDemtZjx7Ve3DToqf1P6Am2vP5e8v/YEKiROVFP9e9gJ2QXAWMQnq1q9ntNkE5AfnF7u+BGBrgDXGmJe9+4/gBmQbRGQUgPdzY2c7G2PuMcYcaIw5cNiwYX04DbVLKCxD0XEmv/IB41V/72kX5K7o+sW/IWUCuRmO5067t8tM38f1CW4O/5Cp07c9Y2xH0TFgg1O0oE7xeHsDACN6sah6NBAnJDafdt7p8zk1vPYLLk/cz08WXtLucbHc/18Rk+J/4o9zafwBasTNbtlG+FxmKVWh/LnHnASP/+5eysTteqx2Wvp8bruCXndBGmPWi8jHIrKnMeZd4Cjgbe/fqcB87+euM/JW7USmi9vKL8RxIOAGYBl2TNX2wez54P6sDY7a7na183/VD2eTp3XABqfhdh1JE8TBYjc2gMBI0/MxYBFvfNXR6VepnX0+02ff3ul2f/zzE9iJOMedcHKH5xbOu5B9nXc4Kv0eCFhW+/9P2QAsapK5x06IP8dyGQ8CR9hvcET8DQAyxqLUSfBew3oAUiZAtdPc499rV9TXQqwXAA+ISAnwAfDfuFm1h0XkDGAV0LF1leognwEzRZ5d8S1vYHdIbOKmf2b0+dlRV/2Vowb6JDrhYOkg/EHoU6nVvG1NoNK0Mgm3C7JC4sy74lxmzb0TjOGGq84nFAxz+eybuzxOmdNGwoQIYjM2vK7L7Sb9YyZpCUInAdjBmdf5kvPv3MdytoxElnjdFJUmn8mKkeRP0S/i2AGW8xHfTD0HwFoZSplpIxRwuzHfk3GMNFu68RfZ9fXpSmeMecPrRtzfGPMNY0y9MWazMeYoY8xkY8zRxuhfWm1fuzFFohcPPzKBfNar2MeA+Zl2QQ4+i264kv2cD3m3ZDxbCpa2AghG3fpxS64/ipnBX3GI9TIvPdV1IdMKp4V1UsOS0IEcl/g7C665qNPt9uJjPm0+pHZ2x1IXG4Pty3eGtiobYYkbkA037hi1x0KHcVvou1w6/U4un3UbyeFH57ZdYw2n3IlTbTaTMRbLwpMYQjPvvL20y9+hWGiqQflCu7Ug9drhS7aT/xasAZh/aRfk4JM0jUQlxQZrBPXWVgFYMM0/ljzNYZml1JlKDnOW8eJrj3R5rCqnhS1SwVvBvaiQOCUxdzB87XUX8tC9iztsPzqyocNjsa3KREQKuhohvxxZlbiD6VeHxjDtykW557/7o3zQVx8op5xW9kl+yFvWBOqtSiwxPPvn33b5OwDcvOBibl5w4Ta3Gew0AFO+YLq8o/zC2PnZET0pQ6H6l1bCH3yigTgAiVQJjQG3oO9ahgJQYiV5/u+/IyopHo0dzkeM4KjESx2WbDPGYIxhiNNEvVVOJuE+XyIJFl57KdPt+/jUxz8FYNmrr+WKKR8V/ycvPf/ndseqdFpZSw33Ro8hZQId6nYFt1oH1jEdRzMtCJ7GrdHv0iYRhplG9nfeZ1nJJFK4dfFa49ue4XlR6y+4tO0+7q49leeefmKb2w5WGoApfyiY+SiOXjz8KGPn26XYZ0H6mdFCrINOjVNPwoQYNWISLVYMgBWBsdSbMvZLrsQqya49WsZfoocwxbzPwnntuxZvmn8R/zf3K4ww9TQGSpkwcV8cI8ScNow3/uoAs5Jbas9lyZ9+Q0AMyxnPaNnCCy+0D3CqnBZWBMZx+vRfs4UKSp14u+eDpn0A1tnKGNOuvJWLpt9F3IoQlRRhybDBGkHGC9ZkG8sR/ezueQS8oShnxR9jj+cu5OFfdD3ubbDq6yB8pXaMdssP6cXdj4KS/8DULkj/0i7IwWdMeiPvyxh+eObFLK79bwAarDIejX6Z0xNPsi7oZsMymQAN6XIyxmJkYH1u/1f/9jxHpl7ks2YFCLRYpZx66jnUXTOPCruFLaEhZJNWu2VW8549EYAXop9hYts6xpm1pOIZguEAliVU0cz71mgAGqWUcqf9IvNbB2DONlZ5qLeqSZkAjZRSERtLQ7Nb9zO0jQAs3vABALeWn41xkpze8hBHfXgzf5j7Z1aXjMeEK7AyrQRLhzB03GS+ftT3CIf7Z7H7HUkDMOULpuCCYYy9jS3VQGm18gNxtQvSvxwEQYvpDSa7O2t5IziZfcmvnNBqxVjfXEVzMMq3E8+AgCSFqXPu4IU5b3BIYhnGGESEv/3jIS4z+crzbd4KDXVSRbXTzAbcAGolo9kts54VoUmQhjaJ8WJwPz6fWsrvfvxt9k5/xKev+hdDTDPNXiauQcqocFr59c9uI173ElvSQxkZah+AZRen78xFl98BcifOJ+s4Y/QonnjkF/BW19XwN69fz16pD6gzFZzxP1dQVlHB4h+XMKH1dQ5Jvc2x6Zfcsu8ATcA6eDAd55QTzu35H36AaapB+YMpLEOh/CjcnP/Gql2Q/mV0KaJBZe4V5zKGzazPZrkcNwBrsyLMmnsnL4b2IygOG0wVU+e4A91Xloxjd/MJtde4g9Rr2NTumCncAGyTVUWN00il00zChHijZDJ7OGtydbxsE+DdkgmMp45TUs8wxXzA7TddTVRSxK0oAE1WKZWmlUzd85yR+AMVJQ2EnPbZK2sbGTCxLESEEWNGIyIc/+3/psGUUunVAiuc3PPCX/+Pt+85iaPt13g6fCBlFRUAnHPJAr525RIily3jd7vX8pNR0/nL53/KzydeCkBy80c9/Kv7g2bAlE/oBcPvGjP5bghHNAPmV47oGLDBpKQsAEloFrcUvpN231sJL4v1bskk/l/mn6yxhuUWVm6QagJiCEbcbUMmTdyUkCFAucRz46zqA+VMTq1haKaBNTKMusBQd7kgyx3TZUyA5kxBCX4gkXSX2Up4QVyLFWNIpokT4s/npquXbLUId2V1z5Z8Xic11NiNPPnoA1QuvZOXQp/j8pmLSDy/gCPtZSyOfZOTz5jfYb+yikq++YOzc/db2prJ1N5CSdP6DtsOBvo1VvmOfnv3J9tbdgd0DJif6RiwwSXsde2nMm69r8un/Zgfx75Lc4N7v6U5jG2E9YGa3D6phJsliwbcQqhhk6aNMCussUB+TFZToIyhNDLG3sQ6q4ZW4y4YP9pb6sjJCMcecxp1piJ/PiG35ESGbFdolKHSRKW4X8AiJtFuEW7bCF/5es/qrW+wqhlh1/PRimc4zFnGvvZybl5wKUfbr/GL6Nc5Z/rPqRm6/aCuLFbOJ1JDdVunKx76ngZgyh8KuyA7mVGjBl66OV/1WseA+ZcWYh1cLLwuOG9YlRUOcMm0u5g1704AZl13G4tj3+Jt61O5fQ4/7Bs0mhgjMm7XY9ikiUuYJeYQHiw5ksrqCQC0SIyQ2OzLR2wMVpNNYu+bcge5G1vY54ADeL4kv5B8tVdcNeMFcfGCL14tJkKpE28XgLUQZbfdd+/R77wpWMVIs5kDEm8DUBesZnxmJQkTIjbmsB4da01gBCPTgzMA0y5I5Q8F1wt7GwM61cC5+1d/gtleN4l+d/MtR8eADS5euQVnG5OPzp/+s3b3DzrqCF7++27skV4DQNhJESfcYd3HpOSDp/pAJTPm3Mbmax5lMmtBwHjjrwJjjmHBJ5OYlrqPMWkvO2a77/GklwlbxgQikqLcaSNikjhGsMTQIlHad2JuX6NVzhBp4VDHDcAiTor/TP6Tp0o+xyk/6Nlg+o0lw/hi26sApOKtlDx/A3zmv2D4Xj08q/6nn6LKJ/IXDHF0BpdfOV52Ursg/cv08yzIrQuCqp4JeH+/nq6Buyo4ksnOGv78h4eJmBRx6bg+a8YJ5W7XZ4YA7tJAlhf0Td7rAABOOO0cSLnv6d3tT7yd3fvZqvdvhifTIGVUOi1ETIoG3O7MVqI9Om9wZ3jmztFYVDitVEobGwJDe3ys5tIR1Egzy958jnULDoIXb4OVT/X4OANBAzDlC4UfPsbS/5Z+le161C5I/+rvMWC3LDyHV649iEVX1vbba+5KcsFyJrPtDbdSFxxCqSR587W/EzFJ4nSsg5Vpg3pTxuLoiUy9wp1Buc4bS9Zmwnzzu2fktj3+xNNJmQAT2EDKBDjwEHep+db0EH4TPoqNzkQarVKqvABsszdpoEV6HoCljXuuaxjKShnDCNtdMjpp9byWl9S44972e/Q4hjib+eBrD8Ch5/f4OANBuyCVPxRczzPpZNfbqQFlcgGYBsl+5XiV8K+68Ick0rBw8f079fVG2nUcZN7lmeDHO/V1dlWWF4D1dAGQuONmoIKRNNFEii1S0WGb6bMX8drzp3DOl7+Qe2xTsAoy0EyUWMG2e02ZwtpHqxjDZt6yJnLkV48H4PIrb8pt89jcY6jOfEizxNxFww20Sc+DpmE1n+KZdQfweuAAvpx+gfHORhBIm9D2d97KpL0PJPVOgPVSw2tfvpETDz62x8cYKBqAKZ/If/pkNLviW9nMl3Y6+ZcRwTIOl1U/xbuB8d3axzFu+VbpRXmR7DqBoYi+b3sjG4BJD99UmRYHglBOM1GTJBHo2AUplnBgQfAF0Gi5gVqLRNl6nmETpYxhM8tLJnBAJ6/ZYsWoooUMARqs0WDni772xA9/dCFwIUcCf5vzJYaLO/DfpucB2CH7H03z7ksZVzaa8YOsPI5+jVX+UPDhE3S6XqJCDSyDjgHzu2wXZJW0crCznPlTr9juPguvv5gPr92b+bN73nUT8wKwsMS3s6XqTLZmW6ysqkf7zbj+DjaYKkZmNhElSVK6F7wkjFffq5OuwxHG7QrcGBje6b5xK0JYMtSYJpoDbv6szep5AFaoraDbsbNFvbfHskJUlo/p1ZeHgaYBmPKHggCscMkb5S/aBel/W5ehsKqbt7tPNJxgEusIRXqe2ywzbm2DCrP911EdBbwyFFP271n5BYCVgTFMyKwjZpK5JYy2J5MKAJ0HYOW4QXSirfNgLumNM4tImoSU0GIiOyAAy+8fDPTtWIONdkEqXyj82A816lqQfqUZMP8zWw3Cr7E2c3PtuQTE5qJpd3e6T8wLooLS8/demXEv2sOZQzH6AAAgAElEQVQzW3pxtsrCkDEWRxz79R7v+0lwGPslXyFMmlQ3A7BhNeOwN0inXYeLot9lpNnI9Bm3drpvivxrpCXE3bGTcFJ9CyMSBWPIqoeM7NOxBhsNwJQvSMEI1AZatrGlGkg6C9L/snXA6kwFw6SJPVMfUW7ilJo4t9f+iInpjznmyj+326fSdrNXIclnn2+aeR3jy19llTWey2fc1uXrVXjB22i7bif8Nru+gHHIEOjVxbjViuYq1Ke62QV5+rlTWT77fuqC1R2eu2zGHdvc17EDudsZCXLZ9G1v3x2FAdihh32lz8cbTLQfQflE/r/iB+veGcDzUNuSC8AG4XiLYpGtA5at3zTRWcdEZx3DTQN7pj7ga+mXWXD9hdxdeyq117mLOQ+x3fX/Skw+AEtaa/l26q+MMuu2+XrZDNgEZwPzrrpgZ/xKuzQLNwDrjXhBFist3Q/hHjNHsCWyf49fr7BIdoPdszFrXckGji0mwuQ999khxxwsNAOmfMEUVIH+42MrBvBM1LZluyD1u5tfGREsx+QCsDFszpV52c3egCWGo+wX+VxmBS0mwg1XZjg25M5Cizj5EjDBaBgyUOp0Pbh+0VW1nG215rJtF1sPMe+KNLPm3rXd86y95nyctMNMb8mdYhUwNnYv30+pgtpfmR4EYDOvXdSr1/vW10/j7qcaaUpVMnVW746xtbQXgDVKKWU75IiDhwZgyhey36tsI738Lqj6g3ZB+l92FqRgWMtQxrAp99wexl2C5nPG/ZJTJgmi5YaRbW6QFjOJ3LaBYAYyULaNAKwh+S4lMZvHI18iI0HOij9GKNq9rrAjrVfYEutYu6rY9CUDlimom9XbY/TEHp/9LHt89r4deszszEe3BEZx0a+xyheyI8B0dp2/GQ3AfC87CzKAw0qr/SXNKig29evw0SRMiNH2JwyTJgBiBcFWWNxsWLnT2uVrlcTcYqBJK0yLKXdfI9i9ZZAmOZ8wPrOhW9tmGWNI2bvWLGnL9D4Ay67XCGAP0q+utnHPu0li29ly16NXO+UL+QBML+x+5ugsSN9zM2AOFoZ1oRrSpvML83prBEutSRyVfC33WGG2q9QbXF9pug7ArJD7/yBNCDvjXk66M5PymqlnUSPNjDQ9mzl57bSzWXPd/txUe16P9vOzIDYZ6V3wZNL5YNc4g/Vy7mbAWiwNwJQaENlp85oB8zfNgPlfNgPmdm0F+UhG8jHDcs9vMm63X6IlwPLwBGrEnQGZNEHKvaALoNJxH+8sAFtw/UXceMP5ZJdtzZggtreUYQnbX0qstNIdu1QtLcyZdjqkE9vZwxWrjDCJdYx2tj0xYDDpSxekKQiuzSDNgAW88hktVs/XlBzs9GqnfMEYvbAPBrk6YKIfHX7liDsGzMLgiPBk9HD+N/oV4sa90D1U+hV+FjmW6bNv4ZPECD5gFAkT4t/W7rmSEgA1GXdmZCVuAHZ77Y+4ufZcAA40b/K9xJOIl+0ytkVrkxuwRU2cq2ecxQM3nMSCLirrBwq6KY8qe5fnbvjPbv1ugaD7euPT67v99/C7oHF63X04/dpbafMWtna61/PrO5VlbjmMNg3AlBoYjjcLUjNg/pYvxKr8KluINYCDQbh4+p1cOv1ONoh7oWtqCHPGjAcIBALMmH0bk2a/wzV1x7AqNLJdBmyYUw9ATJLMmXE2p7U9wbltD7Pg+osYaW9htGwhJm5w5hiL62/+OfWmjFInTmVViO8nlzCNXzJ/dsfSFGHJZ7y+4CzjIHs5V009e7u/W8hys2uT7bW9/wP1o7nTzmL+zIu2uU1fxoAB1Is79s44g/PL6777H0LSBLULUqkB4+jYosFAZ0H6n1uI1cES0+79VCdVtJkwVnpoh31q77yPhBWmglZunHEtACPNFlJeF1f5EHfGZAkZDjRvMty4wdkeqdUAmLT7BWqLlFPhtBKQfDpmaLS+w+uVbtWtGZE0ZZWdV3I3xmCy6yVmq+5Lw6CoOXZabAmnhP+0zW2C2GT6cCmu94o3OJnB+bXooC8ewe2R/2L0qC8O9Kn0Oy1DofzByf7QC7ufOVoHzPeMuBd1AKegq/jj4HDCmRTTF87pdL+EhCkRmyY+Yc6Ms7k60sI7jGMvPmbv1Ps4RvhHYB/2tFcz1Js1+R+Zd0CgNZEGoEHKqXJasMQdENZsonwm8W6H16q2m2gyMSokn3ELl3Q+u3HBtRdwHH/jcTmciaF84BYu7VnAMe+qC5gY+4T3ttRwzcJ7erRvb41hMwAL513YZd2sgHF6PQgfoMEqcz8/7UHaBwlcNrPzpY92dfopqnzBeN+YNQDzNyOaAfM7g0XAuO+n7NhKgDeax/Bk6gtd7pddzLk0EqKy2g1uXom4lcm/lH6Tt6wJfFAyNhdUAFRJKxljMTQ0CXCDgWqnmSBuALYk/B8c4KzghivPbfdaw+x6PrBG0Wjy3U7VTkOn5xWNpdiH1cSiSartJhqMW/ri2MSz3LLgnG78RVwVZXG+m3yK2JDw9jfeAe5ZNC93e1+n69U9gth9KiHRaLkZsLKqIb0+hhoYmgFTvpCtBK1jwPxNF+P2PwO5AMgULBk1Z37nC3FnZYt6BiLCfqn32Giq2GjcxZFjkuTfJZNplHzh1CYTpULivCPjOfsKd0mjRquU/TNNhIybEfvAmkBAnuOk4F+5vfZHNDTWECiJc5ZZxSuhfYiZJCkTpFHKGJtejzGGtqYUpZVhjDHcee1NVETcbFul00SN08g7gfEsDX+Kw+OvcnHbr/nHnDd4IXQgU2d2vV4luJMDAAJWzxccz1p023xaNq5lxpxbsbYzEWVT3TqycdVwu2M3bFYAu09jwFqsGBljcfDnujeRQfmHBmDKF4ydgZBe2P1Oy1D4n4NF0OvT78n7KeNdDi5P3A/Aw+HDySTz3XzrreEYkw867o2diBGoX9fKnIg7g60lEKOaFiImiW2EWHwct8e+zeHxf3J+/H95KbI3VU4LEdIslb1pKCkjiE3USfKl9Jssuf5o9rDX8ghHE4vF+Z75P95JjQdgRGYzw0wDSwO78z/T7+fqqT9it5o4x8VfYLizhJvmXstlV1zjnlw6AcEwFASg2bIaQa97tDeC8fe4yPoD86+GWddtO+ALRgTcOLTd5IYO25ne1wEDWO2M4yexEzn7y8U3hmqw0wBM+UJGL+yDQm4MmC7G7VsGyY0B60kAZieCOEZ4JvhZGgJlfJQej2MDAbdGWOOmDLHS/NI38SaLmXPvaHeMuEQJikO13UgrUc69dhoA18+azl+rNnFG6+NskXLuip3E1OmLSGZswsEA86+9gP3kA47OvEaCEr4vf2SMtzzSoc7bAIzPbGC4aaAh4M76m7PwpwAsqj2LC+MPMtJayi/nn0yd1FBOC+PT61gW3JMDU0t5I3g0n7bdTFp36pRlpdNNBIOliBcg7Z5aTakkuzX+zAoYSMM6M4QKug7AAjgk6HwCQndMvXLHrMmo+p8GYMoXgo77VVG7IP1NM2D+Z6QgAOtBoHz5zIXMvryVa2+8EylxA4KbZ11PxrJ4IzCZOQvv5trpF5GIuEFYjLEdjpEUd3zVqMxmWoiQ7bC8cl4tADdccR7xeAtzZrsLcIeDbmAz45rbuOHKcwlGAkgQDk29yipG5IIvgH1YBQItVmm719y02WFtrIbvJ5cA0GIilHllLuoD5XzZeZOXU/szTNwxZlGn+wHYktqTqLEbOejqlxAR9s18CEC5NwlhW7KZttWBEexnf9DldoE+jgFTg5cGYMoXvFVMcDSz4mtGZ0H6nlOYATPdfz9ZJSXMWfTTdo9dOu9KHp/7dz4Ijedg4JraW1kxewkhMlw0d2aHY6S9cWTjnDoapLTD81tnzNo9d/2dudvGGESE5+ccxhedpXzECCbgrhvZ4pVdyJqz4CfUzj4fCQYQyzA1lV8seky6DoBABEbGt7gLjm9jcfFCd99xE2dlXnbviHDD7AuZ6S1sPia9/TUsg7izOj8JDOVgZzk3XjuNYLSJIU49HzcP5QrvbxE0NhlL30/FSAMw5Q/NrRDRMWB+p3XA/M8ghLIV6nfA8Y6/on0dq1fDexM2KSZ0sq1tu5mc4dLAJ1LT69cU74vYeyW78cXEUl4p2YcJqQ18YoYwLPjpDttPn3177vbLc17hYGc5AHvbbtYsJm3U4GatypyuuwMLNTWuyt1OpG0isRS0QZ2pZK/Mqm3s6Yp4XZ2bgtWQhmC0ifNaHyYkNs+HP00m00wwWE6Q3lfCV4Obht3KFxwnOwtSL+x+ZnQMmO8VBl07Y8mob077NSfOfLzT55xUvhZVq0T6/Fqb7Rr+LRP5KDWW34SP5n45hh9etu2K+c9kDuD26LcBcvXKJqQ/xhL3L1NREID97p5f8pPaH3DjDe4sTuMYrpt6FjdcfQ6j5ZPcdr+8+TQuafsNKRPgL5GDmWjWd1kINlc01okTNyXExZ2gcFzbX6mjkt+Fvsih9jIW33wj4JWh0KW9ipJmwJQvNNAC6Bgwv3O0DIXvFXYP74za6OFA13W02hJt4MVd8R0QgE2ddQsg7N+DgH/mnMXUXn9hu8c+m34PBFImQKXTknt8xYZ/Mt12g8l3Zj/DSLOFq0q9Yq8FQ8X2Sb7PJlPBLyIn4tju3/WA8Dv8fP73KHda+FR6NSFjU22aSUmQeinnK84mtkg5GeNeZiea9fwtOIV1oREE0obWNreeWkADsKKlAZjyhffXvQMjNADzP+2C9LvCYV89GQO2I8yZfy8t1zxJmSSIW30veCq9DEySLYlcIAgwwhuA/76MoYp8ABYOJ6ENVjCGtYGhLA3sTpNVRkpCJCVCiBTntf2WSfY61lpDuXymO+Pw4XmrOTn1LE5aaCHCW4GJxK0w71njCBqbg9JvM1SaeIsJuey+JYbNgUoSxj2xoDfxMYitn3tFSgMw5Qt/emwFzK7UC7vPaQbM/9pPkOj/dtoi5ZSRIC69L63QV1fPv4fWax6jVJKkTYCQ2KxmGG+VTOSryZdz29U49WSMxQPJLzB7/k86HOem+ecBMEq28K6Myz3+XsMIFtWcQmtzgJnX38nnt9rv3vnf4/TEk5SQxrHz47sarXKctNs+waA78zto+laIVQ1eGoAp33CM6CxIn8uPARvgE1FdKlwRcCDG6tVLBeNNHckdkAHrizqpopQNPFnyeb6RfoGHQl+nJrCJMknw+7lf593M7hwi61gpYzoNvoB2wVO2/hjAlQu2vapAXcZd8HwyazGZfOX9uERJx92i09mFxYPY7dbsVMVDW135hoNoZsXntAzFYFA4BmwgAjC3TESK0Ha23Lk2SSUAK8zuzE2fztQrFpH0+iVPSP+dr/I8e9sfsSI0rstjOOl8ONsc6FhWoyvTr1zEY6HDuDV2ChlvoXKApIlwyEHH0GrClHtj0fq6FqQavDQDpnzDIDoWwufyAZjyq3bZyQFIVTYFSsGBlAxsALY5UAkZyKTSXDHXHbuVlvwlb3/zIQisCY7o8hipZAa8RF6rFe3R6x8/6wkssXjqt4+T+vf/UiI2ti0cecKxrHy9hppMI6AZsGLW5wBM3DUaXgXWGmOOFZGJwINADfAa8ANjTKqvr6N2fZoB8z9HBIxOlvCzwnGUA/F+avYq1acHOADbEqggkQ4RK89X7E/Z7ri0RbHvkExFCJWkaapzujoEU/Y6nNQHD1MiNknTs1md2cW6j/7W8dT9u5RhNJFqcbNhG6xqhjnuxIAADra+n4rSjsiAXQQsh9yqE7XAj40xD4rIXcAZwOId8DpqF+dmwDQA8zMdhO9/hW1jpP9zlW1epsgZ4A6W1cnR3BE9hUsuz1fsP/+SG5k/Hy656CbC4e2PUTv+1FOou2Yaw2gkY3ofUDZLKRGT5sob7gJgU6CKg1JusVjNgBWvPrW6iIwFjgF+6t0X4EjgEW+T+4Bv9OU1VPEw6CB8/9NCrH7XLgAbgMxK0uuzs52BHdc0ffbtXDbj9lwmCiASiTBj9u3dCr6ysmPa7Ezvf59mibFehuTuNwXKGEojTz3+R4KiGbBi1ddWvwWYRn7iTQ3QYIzJePfXAGP6+BqqSLhdkPpB5Ge6FJH/FQZgA5AAI2HcDJht7xoDy5u8NS0zya67Krfn9fCneCmyX+6+jUVIbN741zOAdukXq17niEXkWGCjMeY1ETm8F/ufCZwJMH78+N6ehtqFaBek/xntgvS9wuzkgLyfmsawIHYqZ192Y/+/9k7QZJWSyVgMGz2x18c4bcaD7e5nuxyT6VYIoV2QRaovnfRfAI4Xka/j1hyuAG4FqkQk6GXBxgJrO9vZGHMPcA/AgQceqJOqFI4GYL6nsyD9r7+r32/t8nkzBvT1d7TNgUrW2kP5n3Mu3WHHzLaRWO4lWL/QFKdeh93GmJnGmLHGmAnAKcAzxpjvA88CJ3mbnQr8vs9nqYqClqHwP5P7qe00KGik3GcrW8fykHx1hx4zm/EKBtwG0jFgxWlnTFOZDjwoItcDrwM/2wmvoXZB2gXpf7lZkNpMvlXYBamTJfpu5tw7dvgxcxmvgAU2GO2CLEo7JAAzxvwV+Kt3+wPgoB1xXFVcHEQvGD5nxAKjXSZ+1q5tNAPmS9lMv3izJBz9RlOUNOxWvqEZMP/Ld0FqO/mXdHFb+UXu/WNl20fbqRhpAKZ8Q8tQ+J8WYvW/wqSX0QyYL2XrHVqWlwHTLsiipK2ufMNgaQbM57QMhf9p2/hfbqaqON59vRQXI2115RsGvXj4XS4A07F6vqVjwAYDrwwF2QyYvp+KkQZgyjcczYD5nmbA/K9dzKVdW76U7XK0xAa0q7hY6btT+YZBMyt+pwHYYJD/WDd6Zfel7PvHyoXL+n4qRhqAKd8wohkwv9NK+P5n2vVA6vvJj7LvnwBeBkzbqShpAKZ8Q2dB+l82Q6nt5F/tFuPu/frRaqdy3z8B4wZgWtm4OOmnqPINwwAtHqy6zdEMmO8V9jpqO/mT4zWMZsCKmwZgyjccLB0D5nNaiHUwKGgb0RDMn9w2CmoGrKhpAKZ8wyB6Yfe5bNejBsqDhF7YfSn7ORck497XOLkoaQCmfOPJ6Bd5K/ipgT4NtQ2aAfO/wppSemH3Ka9dgsYNwNCxekVphyzGrdSOcP70nw70Kajt0MBrMCgchK8RmB9lM8khLwDTjHJx0gyYUqrb8rMg9YLhWwXdjppY8SkvNZkLwDRVWZQ0AFNKdZsuReR/hZdySy/sPrVVBiyj7VSMNABTSnWb2eqn8jfNgPlTNuMVNmmgsCK+KiYagCmlus3JzoLU2XW+VZid1Au7P2UzydkMmNY/LE4agCmlui0fd+kFw68Kx+fZjubA/Cg7OSKMmwEzGXsgT0cNEA3AlFI9oGPA/K5d7VVbP+L9KPtFJmJSQL4yviou+u5USnWbLkXkf4U5L4NmVvwo24VfkhsDpoqRtrtSqse0DIWf5dsmY2sXpB+J7X6FieBmwEaN22MgT0cNEC3EqpTqtuwgfF3iZnDIaKDsS9lZkBGTwkE47exLB/iM1EDQDJhSSu1K2vUPpwfqLFQ3hEmRJjDQp6EGiAZgSqluc3QQvu+1a5t4auBORHUpm0mOkCatHVFFSwMwpVS35ZciUr5V0D0cT2t2xZcybv2vCCkymgErWhqAKaW6LT/4XjNg/pUPj2tKxw7geaiuZFeIssRoF2QR0wBMKdVtuQBMB+H7mNs2jhFmLJw7wOeiOmMKgmTtgixeGoAppXpMuyD9K5tdsfXj3ccKSoWIZsCKlb5DlVLdpvW/BgFvnJ6uL+hf0Whl7nZGM2BFSwMwpVS3GZ0F6X9O9od+vPvV2Em7527rGLDipe9QpVS3ZYd+aSbMz9w+SM2A+dfJ3/sRjvdm0gxY8dIATCnVbdnAS3QQmG9ls5M6BszfMl776Biw4qXvUKVUt2UDMF1h0MdMtlabZsD8zPa6HrUOWPHSAEwp1W1aB2zw0AyYv2XbJ60ZsKKl71ClVA9o4OV32d5hHYTvb9kATDNgxUvfoUqpbsvVX9UxYL4lOgtyUMhoF2TR03eoUqrbtAzFYKCzIAcDJzcIX2dBFisNwJRS3aYDu/3PeB/rtujHu5/lMmDaTkVLW14p1W2mww3lO14fpHZB+ls2QLa1C7Jo6TtUKdVtOgtyEDC6FNFgYGsdsKKnAZhSqse0K9LHvOykZsD8LZv5sjUAK1q9foeKyDgReVZE3haRt0TkIu/xISKyRERWeD+rd9zpKqUGUnZ8kYZf/pUvQ6Gt5GfZDJjWaytefWn5DHCZMWYf4BDgPBHZB5gBPG2MmQw87d1XSu0Cshd3Y3QQmF8Z220bvbD7m3ZBql6/Q40x64wx//JuNwPLgTHACcB93mb3Ad/o60kqpfwh1/Wo8Zd/6YLpg0K2C9LRQfhFa4d8RRKRCcABwMvACGPMOu+p9cCIHfEaSin/0Dpg/mUZzYANBnZ20XQtQ1G0+tzyIlIG/Ba42BjTVPiccfspOv2uLCJnisirIvJqXV1dX09DKdUPcoGX0QDMr3LdxBqA+VpuEL5mwIpWn96hIhLCDb4eMMb8znt4g4iM8p4fBWzsbF9jzD3GmAONMQcOGzasL6ehlOon2q3lf9k2sjVL6WvZDKVOlihefZkFKcDPgOXGmJsLnnocONW7fSrw+96fnlLKj3QImH9lAzAtQ+FvuQBMB+EXrb4sQvUF4AfAUhF5w3tsFjAfeFhEzgBWASf37RSVUn6RvbhnF3xWPuSkwdIAzO9sscDoWL1i1usAzBjzAl2XAzqqt8dVSvlXfvC95sB8yxEvANOuLT/LzYLUQfhFS1teKdV9JvtDL+6+5WR/aBv5WTZD6eiElqKlAZhSqttygZcO8PYtE9DMymCQLT+h7VS8tOWVUt1mOrml/CWTTgKaAfO77NgvLRdSvLTllVI94F7UdSUi/8roLMhBIZv50u784qXvUKVUD+hSRH4XdNKABmB+Z+sYsKKn71ClVLdlrxXiaATmV3HLBrQL0u8cbxyldkEWL215pVS35cMu/ejwq0BLCtD1Ov0ul6HUDFjR0k9RpVS3mdwYMHuAz0R1JemUANoF6XfZOmA6nrJ49aUSvlKqyCSdCJtMBclkaqBPRXVhSGwMoBXW/c4RHU9Z7DQAU0p123mXLSKR/jFXRkIDfSqqCzNvnAez79AuSJ9z0FmQxU4DMKVUt0VCASIhXTzY72wjOgjf53IZSkfbqVhpjloppXYxDpaOAfM5k60DJtoHWaz0HaqUUrsYB9EuSJ/LdUFqBqxoaQCmlFK7GIN2QfqdnQ2QbWdgT0QNGA3AlFJqF+MGYPrx7mdGB+EXPX2HKqXULsZB9MLuc9kA2dGSekVLAzCllNrFOFj5OlPKl7JdxEYjsKKlAZhSSu1ijGbAfC9phWkzYUpCsYE+FTVANABTSqldTLPEiFuRgT4NtQ1NDWXcFjyFS65aMNCnogaIFmJVSqldzK8Cx2C3an0pP5sxb9FAn4IaYBqAKaXULmb6VXpxV8rvtAtSKaWUUqqfaQCmlFJKKdXPNABTSimllOpnGoAppZRSSvUzDcCUUkoppfqZBmBKKaWUUv1MAzCllFJKqX6mAZhSSimlVD/TAEwppZRSqp+JMQO/XIWI1AGrdvLLDAU27eTXUH2n7eR/2kaDg7aT/2kbDQ6dtdNuxphhfTmoLwKw/iAirxpjDhzo81Dbpu3kf9pGg4O2k/9pGw0OO6udtAtSKaWUUqqfaQCmlFJKKdXPiikAu2egT0B1i7aT/2kbDQ7aTv6nbTQ47JR2KpoxYEoppZRSflFMGTCllFJKKV8oigBMRL4qIu+KyEoRmTHQ51PMROReEdkoIssKHhsiIktEZIX3s9p7XERkkddu/xaRzw7cmRcPERknIs+KyNsi8paIXOQ9ru3kEyISEZFXRORNr42u9R6fKCIve23xkIiUeI+HvfsrvecnDOT5FxMRCYjI6yLyB+++tpHPiMhHIrJURN4QkVe9x3b6590uH4CJSAC4A/gasA/wXRHZZ2DPqqj9AvjqVo/NAJ42xkwGnvbug9tmk71/ZwKL++kci10GuMwYsw9wCHCe957RdvKPJHCkMWYK8BngqyJyCFAL/NgYswdQD5zhbX8GUO89/mNvO9U/LgKWF9zXNvKnI4wxnykoN7HTP+92+QAMOAhYaYz5wBiTAh4EThjgcypaxpjngC1bPXwCcJ93+z7gGwWP329cLwFVIjKqf860eBlj1hlj/uXdbsa9eIxB28k3vL91i3c35P0zwJHAI97jW7dRtu0eAY4SEemn0y1aIjIWOAb4qXdf0DYaLHb6510xBGBjgI8L7q/xHlP+McIYs867vR4Y4d3WthtgXjfIAcDLaDv5ite19QawEVgCvA80GGMy3iaF7ZBrI+/5RqCmf8+4KN0CTAMc734N2kZ+ZIC/iMhrInKm99hO/7wL9mYnpXYWY4wREZ2a6wMiUgb8FrjYGNNU+GVc22ngGWNs4DMiUgU8Cuw1wKekCojIscBGY8xrInL4QJ+P2qbDjDFrRWQ4sERE3il8cmd93hVDBmwtMK7g/ljvMeUfG7IpXO/nRu9xbbsBIiIh3ODrAWPM77yHtZ18yBjTADwLfB63OyT7xbqwHXJt5D1fCWzu51MtNl8AjheRj3CHvhwJ3Iq2ke8YY9Z6Pzfifpk5iH74vCuGAOyfwGRv5kkJcArw+ACfk2rvceBU7/apwO8LHv+hN+vkEKCxICWsdhJv3MnPgOXGmJsLntJ28gkRGeZlvhCRKPCfuGP1ngVO8jbbuo2ybXcS8IzRIpA7lTFmpjFmrDFmAu515xljzPfRNvIVESkVkfLsbeArwDL64fOuKAqxisjXcfviA8C9xpi5A3xKRUtEfgMcjru6/AbgGuAx4GFgPLAKONkYs8ULBG7HnTXZBvy3MebVgTjvYiIihwHPA0vJj12ZhTsOTNvJB0Rkf9yBwX6DrbMAAACdSURBVAHcL9IPG2PmiMgk3GzLEOB14L+MMUkRiQC/xB3PtwU4xRjzwcCcffHxuiAvN8Ycq23kL157POrdDQK/NsbMFZEadvLnXVEEYEoppZRSflIMXZBKKaWUUr6iAZhSSimlVD/TAEwppZRSqp9pAKaUUkop1c80AFNKKaWU6mcagCmllFJK9TMNwJRSSiml+pkGYEoppZRS/ez/A2OizVTWc2kgAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 720x720 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig=plt.figure(figsize=(10,10))\n",
    "\n",
    "for cl in range(5):\n",
    "    # extract the dataset\n",
    "    #for jj in range(cl+1):\n",
    "    classifier = classifierNN(2*cl+2,yin)\n",
    "    if cl == 0:\n",
    "        indCLtot = np.concatenate([np.where(np.argmax(labelX_train,axis=1)==0)[0],np.where(np.argmax(labelX_train,axis=1)==1)[0]])\n",
    "        labelX_trainCL =  labelX_train[indCLtot,:2*cl+2] \n",
    "        dataX_train1CL =  dataX_train[indCLtot,:,:,:] \n",
    "    else:\n",
    "        tempind = np.concatenate([np.where(np.argmax(labelX_train,axis=1)==2*cl)[0],np.where(np.argmax(labelX_train,axis=1)==2*cl+1)[0]])\n",
    "        indCLtot = np.concatenate([indCLtot,np.where(np.argmax(labelX_train,axis=1)==2*cl)[0],np.where(np.argmax(labelX_train,axis=1)==2*cl+1)[0]])\n",
    "                \n",
    "        indCLtot = np.random.permutation(indCLtot)\n",
    "        \n",
    "        indCL = np.concatenate([indCLtot[:50],tempind])\n",
    "        \n",
    "        xreptrainlabelonehotExtended = labelX_train[indCL,:2*cl+2] \n",
    "        labelX_trainCL =  labelX_train[indCL,:2*cl+2] \n",
    "        dataX_train1CL =  dataX_train[indCL,:,:,:] \n",
    "        \n",
    "        \n",
    "    for i in range(len(labelX_trainCL)):\n",
    "        labelX_trainCL[i] = labelX_trainCL[i].astype(int)   \n",
    "        \n",
    "\n",
    "    labelX=K.placeholder(shape=(None,2*cl+2),dtype='float32') #labels of input images oneHot\n",
    "   \n",
    "     \n",
    "    #discriminationLoss=K.mean(K.categorical_crossentropy(labelX,classifier(encoderX(imgX))))\n",
    "    discriminationLoss=K.mean(K.binary_crossentropy(labelX,classifier(encoderX(imgX))))\n",
    "    \n",
    "    myLoss=  discriminationLoss\n",
    "     \n",
    "  \n",
    "    params=encoderX.weights   + classifier.weights\n",
    "\n",
    "    \n",
    "    \n",
    "    #loss=[]\n",
    "    \n",
    "    \n",
    "    \n",
    "    opt = Adam(lr=1e-4)\n",
    "    updates = opt.get_updates(myLoss,params)\n",
    "    train = K.function(inputs=[imgX,labelX],outputs=[discriminationLoss],updates=updates)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "    for itr in range(epochs):\n",
    "        \n",
    "        indTrainDataX,trainLabelX=batchGenerator(labelX_trainCL,batchsize,nofclasses=2*cl+2)\n",
    "        trainDataX=dataX_train1CL[indTrainDataX,...]\n",
    "        \n",
    "        \n",
    "  \n",
    "        loss.append(train(inputs=[trainDataX,trainLabelX]))\n",
    "  \n",
    "        if itr%epochstep==0: \n",
    "\n",
    "            for jj in range(2*cl+2):\n",
    "                if jj == 0:\n",
    "                    indCLtest = np.where(np.argmax(labelX_test,axis=1)==0)[0]\n",
    "                else:\n",
    "                    indCLtest = np.concatenate([indCLtest,np.where(np.argmax(labelX_test,axis=1)==jj)[0]])\n",
    "            labelX_testCL = labelX_test[indCLtest,:]\n",
    "            dataX_test1CL = dataX_test[indCLtest,:,:,:]   \n",
    "\n",
    "            perd_label_X = classifier.predict(encoderX.predict(dataX_test1CL))\n",
    "\n",
    "\n",
    "\n",
    "            \n",
    "            testXperf.append(100*float(sum(1*(np.argmax(perd_label_X,axis=1)==np.argmax(np.squeeze(labelX_testCL),axis=1))))/labelX_testCL.shape[0])\n",
    "            \n",
    "            plt.subplot(2, 1, 1)\n",
    "            plt.plot(np.asarray(loss))\n",
    "            \n",
    "            plt.subplot(2, 1, 2)\n",
    "            plt.plot(np.asarray(testXperf))\n",
    "            \n",
    "            display.clear_output(wait=True)\n",
    "            display.display(plt.gcf()) \n",
    "            time.sleep(1e-3) \n",
    "    Classifier.append(classifier)  \n",
    "    Encoder.append(encoderX)  \n",
    "    Decoder.append(decoderX)  \n",
    "    \n",
    " "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "import json\n",
    " \n",
    "testpermutedperf = testXperf[:400]\n",
    "with open('FMNIST-MB-50.json', 'w') as fp:\n",
    "    json.dump(testpermutedperf, fp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[1, 0, 0, 0],\n",
       "       [1, 0, 0, 0],\n",
       "       [1, 0, 0, 0],\n",
       "       ...,\n",
       "       [0, 0, 0, 1],\n",
       "       [0, 0, 0, 1],\n",
       "       [0, 0, 0, 1]])"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "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": [
    "plt.plot(testXperf)\n",
    "plt.ylim([70,100])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.plot(testXperf)\n",
    "plt.ylim([70,100])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(xreptrainData[3010,:,:,0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "import json\n",
    " \n",
    "testpermutedperf = testXperf\n",
    "with open('MB_Incremental_MNSIT.json', 'w') as fp:\n",
    "    json.dump(testpermutedperf, fp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('MB_Incremental_MNSIT.json', 'r') as fp:\n",
    "    data = json.load(fp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "task = 1\n",
    "numtasks = 9\n",
    "epochs1 = epochs/epochstep\n",
    "fig, ax=plt.subplots(1,1,figsize=(10,10))\n",
    "\n",
    "plt.plot(np.arange(epochs1*(task),epochs1*(numtasks+1)),testpermutedperf,linewidth=4)\n",
    "plt.grid()\n",
    "plt.tick_params(labelsize=20)\n",
    "\n",
    "ax.set_xlabel('Epochs',fontsize=24)\n",
    "ax.set_ylabel('Testing Accuracy',fontsize=24)\n",
    "\n",
    "#ax.set_title('Training loss for the AE tasks',fontsize=14)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "xencoded = encoderX.predict(dataX_train1CL)"
   ]
  },
  {
   "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": [
    "umapperT=umap.UMAP()\n",
    "#xumapT=umapperT.fit_transform(xreptrainDataencoded,xreptrainlabel) \n",
    "xumapT=umapperT.fit_transform(np.concatenate([xencoded[:,0,0,:]],axis=0) )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "vislabel = np.concatenate([np.argmax(labelX_trainCL,axis=1),np.argmax(labelX_test,axis=1)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "labelX_trainCL.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure(figsize=(10,10))\n",
    "\n",
    "plt.scatter(xumapT[:,0],xumapT[:,1],c=vislabel[:],cmap='tab10',linewidth=1,s=1)\n",
    "\n",
    "\n",
    "plt.grid()\n",
    "plt.tick_params(labelsize=20)\n",
    "\n",
    "\n",
    "plt.show()\n"
   ]
  }
 ],
 "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.6.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
