{
 "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",
    "import csv\n",
    "import keras.utils\n",
    "from tensorflow.keras import backend as K\n",
    "from tensorflow.keras.datasets import mnist\n",
    "from tensorflow.keras.models import save_model,load_model,Model\n",
    "from tensorflow.keras.optimizers import Adam, RMSprop\n",
    "from tensorflow.keras.layers import Conv2D, UpSampling2D, AveragePooling2D, MaxPooling2D, Dense,Input, Dropout\n",
    "from tensorflow.keras.layers import LeakyReLU,Reshape,BatchNormalization, Flatten\n",
    "from tensorflow.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",
    "from PIL import Image\n",
    "from sklearn.cluster import KMeans\n",
    "from tensorflow.keras import regularizers\n",
    "from tensorflow.keras.applications.resnet50 import ResNet50\n",
    "from tensorflow.keras.preprocessing import image\n",
    "from tensorflow.keras.applications.resnet50 import preprocess_input, decode_predictions\n",
    "\n",
    "from tensorflow.keras.layers import Input, Conv2D, Activation, BatchNormalization, GlobalAveragePooling2D, Dense, Dropout\n",
    "#from tensorflow.keras.layers.merge import add\n",
    "from tensorflow.keras.activations import relu, softmax\n",
    "from tensorflow.keras.models import Model\n",
    "from tensorflow.keras import regularizers\n",
    "\n",
    "from tensorflow.keras.models import Sequential\n",
    "from tensorflow.keras.layers import Dense, Dropout, Flatten\n",
    "from tensorflow.keras.applications.resnet50 import ResNet50\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import tensorflow.keras.layers as layers\n",
    "from tensorflow.keras.models import Model\n",
    "from tensorflow.keras.preprocessing import image\n",
    "from tensorflow.keras.initializers import glorot_uniform\n",
    "from tensorflow.keras.optimizers import SGD\n",
    "from array import array \n",
    "import json\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import os\n",
    "# os.environ[\"CUDA_VISIBLE_DEVICES\"] = \"2\"\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\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "zdim=100 # 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": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def MgGMMfit(encoderX,dataX_train,labelX_train,nofclasses):\n",
    "    gmmX = encoderX.predict(dataX_train)\n",
    "    \n",
    "    gmmY = np.argmax(labelX_train,axis=1)\n",
    "    yper = classifier.predict(encoderX.predict(dataX_train))\n",
    "    yper = np.argmax(yper, axis=1)\n",
    "    gmmX = gmmX[gmmY==yper,:]\n",
    "    gmmY = gmmY[gmmY==yper]\n",
    "    gmmModel =  GaussianMixture(n_components=nofclasses,covariance_type='full', init_params='kmeans', tol=1e-04) \n",
    "    gmmModel.fit(gmmX,gmmY)\n",
    "    gmmModelSingle =  GaussianMixture(n_components=1,covariance_type='full') \n",
    "\n",
    "    for i in range(nofclasses):\n",
    "        a= gmmX[gmmY==i,:]\n",
    "        gmmModelSingle.fit(a)\n",
    "        gmmModel.weights_[i] = 1/float(nofclasses)#gmmY[gmmY==i].shape[0]/gmmY.shape[0]\n",
    "        gmmModel.covariances_[i] = gmmModelSingle.covariances_[0]\n",
    "        gmmModel.means_[i] = gmmModelSingle.means_[0]\n",
    "\n",
    "        gmmModel.precisions_cholesky_[i] = gmmModelSingle.precisions_cholesky_[0]\n",
    "        gmmModel.precisions_[i] = gmmModelSingle.precisions_[0]\n",
    "        \n",
    "    return gmmModel\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Data Generation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Read Fashion-MNIST\n",
    "(x_train, y_train), (x_test, y_test) = 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": 7,
   "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": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(60000, 784)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataX_train1.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7fde48c69f90>"
      ]
     },
     "execution_count": 9,
     "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": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:From /nas/home/mrostami/.local/lib/python3.7/site-packages/tensorflow/python/compat/v2_compat.py:96: disable_resource_variables (from tensorflow.python.ops.variable_scope) is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "non-resource variables are not supported in the long term\n"
     ]
    }
   ],
   "source": [
    "import tensorflow.compat.v1 as tf\n",
    "tf.disable_v2_behavior()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    " \n",
    "imgX=Input(((28*28),)) #Input image \n",
    "\n",
    "\n",
    " \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": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "def encoderXNN(imgX):\n",
    "\n",
    "\n",
    "\n",
    "    hidden_size = 100\n",
    "    x=Dense(hidden_size,activation = 'relu')(imgX)\n",
    "\n",
    "    #x=Dense(int(hidden_size),activation = 'relu')(x)\n",
    "    #x=Dense(hidden_size/32,activation = 'sigmoid')(x)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "    encodedX=Dense(zdim)(x)\n",
    "\n",
    "    encoderX=Model(inputs=[imgX],outputs=[encodedX])\n",
    "\n",
    "\n",
    "\n",
    "    return encoderX\n",
    "    #encoderX.summary()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "def decoderXNN(yin):\n",
    "    hidden_size = 100\n",
    "\n",
    "    x=Dense(int(hidden_size),activation = 'relu')(yin)\n",
    "    #x=Dense(hidden_size/2,activation = 'sigmoid')(x)\n",
    "    #x=Dense(hidden_size,activation = 'relu')(x)\n",
    "    #x=Dense(hidden_size,activation = 'sigmoid')(x)\n",
    "\n",
    "\n",
    "    decodedX=Dense(28*28,activation = 'sigmoid')(x)\n",
    "\n",
    "\n",
    "    decoderX=Model(inputs=[yin],outputs=[decodedX])\n",
    "\n",
    "    \n",
    "    return decoderX\n",
    "\n",
    "    #decoderX.summary()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    " "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "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",
    "    \n",
    "    \n",
    "    probX=Dense(nofclasses,activation='softmax')(yin)\n",
    "    classifier=Model(inputs=[yin],outputs=[probX])\n",
    "    return classifier\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "thres = .9\n",
    "lamda=1e1\n",
    "Classifier = []\n",
    "Encoder = []\n",
    "Decoder = []\n",
    "GMMs = []\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": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "encoderX = encoderXNN(imgX)\n",
    "yin =  Input(shape=(zdim,) )\n",
    "\n",
    "decoderX = decoderXNN(yin)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "epochs = 200   * 100\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    " "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training on Task 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    " "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAlYAAAI/CAYAAAC1XpeNAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAABgcklEQVR4nO3deZxkdXX//9eprffp6dmHGWYBERwVAUfUqAmKCxAFjFHRb5Qk+sNtjMYYHVEWcQlqYjRiUBKJ6FdBo4KYkK8hiOJKGBCBYViGERiG2bfeu5Z7fn/U7aFuVXfP9MztvtVV7+fjMXR9bt26dW5fqu+pzz338zF3R0RERESOXCrpAEREREQahRIrERERkZgosRIRERGJiRIrERERkZgosRIRERGJiRIrERERkZhkkg4AYN68eb5ixYqkwxARERE5qDvvvHOXu88f67m6SKxWrFjBunXrkg5DRERE5KDM7LHxntOlQBEREZGYKLESERERiUlTJFZr3vUaPv6PF7HohO6kQxEREZEGVhc1VlOt9Xl/wJUrz+StH2xLOhQRERFpYE3RYzXn8e0AfOPYsxKORERERBpZUyRWF176hQOPdTlQREREpkpTJFaV3v7eDyQdgoiIiDSopkmsXr3zZwCsX7404UhERESkUTVNYrXyvk0ArG8/NuFIREREpFE1TWL10cu+CECvzU42EBEREWlYTZNYiYiIiEw1JVYiIiIiMWmqxOqo0hYA3D3hSERERKQRNVVi9dzdDwNw8YfelXAkIiIi0oiaKrHaOHsRAJkl8xOORERERBrRpBMrMzvDzB40s41mtnaM5z9gZveb2T1mdouZLY8n1CO3YHg/APtmdyYciYiIiDSiSSVWZpYGvgycCawC3mRmq6pW+y2w2t1PBL4HfDaOQONw7JM7AMgWSglHIiIiIo1osj1WpwIb3X2Tu+eB64BzKldw91vdfTBs/gaom6HOO3r7AXBLOBARERFpSJNNrJYAmyvaT4TLxvM24L8mG9RUSRUCAO5dcnTCkYiIiEgjykzVhs3sz4DVwB+N8/wFwAUAy5Ytm6owInxoGICHW1ZMy/uJiIhIc5lsj9UWoLK7Z2m4LMLMXg58FDjb3UfG2pC7X+Xuq9199fz503OX3pN7HgVghNZpeT8RERFpLpNNrO4AjjOzlWaWA84DbqxcwcxOBr5KOanaEU+Y8bjiyh+R9TynDvwu6VBERESkAU0qsXL3IrAG+DGwAfiuu683s8vM7Oxwtc8BncC/m9ndZnbjOJtLRMFy/KpzddJhiIiISAOadI2Vu98E3FS17OKKxy+PIS4RERGRGWfKitfr1XGFjRgBcFLSoYiIiEiDaaopbQCyXqBg2aTDEBERkQbUdD1W9+eekXQIIiIi0qCarsdKREREZKoosRIRERGJSfMmVu5JRyAiIiINpukSqzN2/xyANe8++yBrioiIiExO0yVWhXS5Xn9O99KEIxEREZFG03SJ1W3dzwUgO39OwpGIiIhIo2m6xOq0fXcAkM4XEo5EREREGk3TJVbZUgmAfHtLwpGIiIhIo2m6xGrxrn0ApErJxiEiIiKNp+kSq3SxnFEVWtIJRyIiIiKNpukSq8cXzwPgJ08/MeFIREREpNE0XWJ17KNbAXjG3s0JRyIiIiKNpukSq+GOVgD+Y/4fJRyJiIiINJqmS6w6tu0E4JV7f5lwJCIiItJomi6xKoyUx69qz+cTjkREREQaTdMlVoMMAPA/C1YnHImIiIg0mqZLrK654UYA+q0r4UhERESk0TRdYrXtgf0AdHh/wpGIiIhIo2m6xGrUgHUmHYKIiIg0mKZNrBYG25IOQURERBpM0yZWO2xB0iGIiIhIg2naxMqtaXddREREpoiyCxEREZGYNGVi1e4DSYcgIiIiDagpE6tB60g6BBEREWlATZlYiYiIiEyFpkysThn6HQAeBAlHIiIiIo2kKROru9qeA8DiVT0JRyIiIiKNpCkTqxMKDwJw/rlnJxyJiIiINJKmTKzai8MAdLfNTTgSERERaSRNmViNXgrct0Sjr4uIiEh8mjKxavVBADzhOERERKSxNGVi1REmVg8tXpRwJCIiItJImjKxOuPxdQAc/+S2hCMRERGRRtKUidXuWZ0AfONpZyUciYiIiDSSSSdWZnaGmT1oZhvNbO0Yz/+hmd1lZkUz+9N4wozXlg6NXyUiIiLxm1RiZWZp4MvAmcAq4E1mtqpqtceBPwe+HUeAU+G5jz+adAgiIiLSgDKTXP9UYKO7bwIws+uAc4D7R1dw90fD5+p2vpiWoZGkQxAREZEGNNlLgUuAzRXtJ8JlM0puWImViIiIxC+x4nUzu8DM1pnZup07d07re3/p374yre8nIiIizWGyidUW4OiK9tJw2aS5+1XuvtrdV8+fP/9wNnHYtj2wf1rfT0RERJrDZBOrO4DjzGylmeWA84Ab4w9LREREZOaZVGLl7kVgDfBjYAPwXXdfb2aXmdnZAGb2PDN7Ang98FUzWx930CIiIiL1aLJ3BeLuNwE3VS27uOLxHZQvEYqIiIg0laYceV1ERERkKjR9YvXpi96bdAgiIiLSIJo+sdpywoqkQxAREZEG0fSJ1ZPd3UmHICIiIg2iaROruUF5UNJfd6xOOBIRERFpFE2bWJ3x+J1JhyAiIiINpmkTqznb9yYdgoiIiDSYpk2sevc9mXQIIiIi0mCaNrG65gbNxCMiIiLxatrEqnIi5g9e/XcJRiIiIiKNomkTq0r/d+WZSYcgIiIiDUCJlYiIiEhMmjqxSnkp6RBERESkgTR1YvW2//qXA4/X/N+/TzASERERaQRNnVh94nNfOfD4e0tezqITNL2NiIiIHL6mTqxqXPmzpCMQERGRGSyTdABJm+172Wc9B9qLbr2bNXdcR37Pfi67/MoEIxMREZGZpukTq33vPremp+qK550HQN/XP8uCR5/kI5d+YfoDExERkRnH3D3pGFi9erWvW7cusfdfdOvdEz7f6oOsGnmYrvwQJ9+9gbWXfHF6AhMREZG6Y2Z3uvvqMZ9TYgUfe9eb+dc3fGjSrzMv8d6ffZ0ntz3GFV/VFDkiIiLNQInVIXjhzdfz+8zKw379i/rv4Ll3bcA8ICgW+OgnvxxjdCIiIlIvlFgdgkUndPPGCz/Kd45+ZSzbW1Z6jP99+TmxbEtERETqx0SJVdMXr48anZR54UXvpTBnNr94xgnc2/LMw97e4+nlB2q3npF/gJf//OeUMNLt7Xz0ws/GEfKM9/EvXASBc8kHPpl0KCIiIrFQj9UhOO+05zH7nW/mhoUvjWV7b7//h7QMjpAqlfjS179yIKlrNqOJp3mJrS97brLBiIiIHCJdCozZxe95IwCtC5fwTy95a2zbPWPPL+geGGTBxi2MLOjhsjWXxrbtelR9N+afXnexbgIQEZG6p8Rqip132vPYtfavua9l1ZS/11/d9nXuufWX/HTbQ5y26Olc99M7pvw9p8p4w1y8497rad3Xx0cu/vz0BiQiInIIlFhNo4+9683cf9bLWL57D9cuj6cQ/nC9857vEzz0EEMnP4eu/f0UNz1CpqOLiz/7rwB8+pMfpH9uN59+10WJxHew8cNG/cnWW/jnN//N1AYjIiJyiJRYJWTRCd2877y/4H9XP5tfd9R3DVG793Pm1ttZvGUX24+ay7z7NnHvi05m5Y5dfO5tH2HRCd28963viBTeX/LFi9n9wG+54sofHdZ7HmpiVW2W7+fVj/+auU/uASBoyXLR33zqsLYlIiIyWUqs6sinPvNhBro7ufr41yQdyrR44+b/Zn97Gw91L+HMe+6kmEnz1Su/yLYH9nP8T37KfpvNcYWHeTh7XGzvuSDYzil7H2LW0DCLHtvOhR/7+9i2LSIiosSqji06oZs//aM/oqdnPpue/1yOfWI7Vz3rtUmHNa22vfSksEfsAtavOoafdL9wWt//XXd/j6GONtr7hwjSKXJ79mKWZnBgGO/v5ZNXfnta4xERkfqmxGqG+vTH3ou3t7FvYQ+FTJpts2dRMuPnXc8n63kKlks6xFhse+lJYy7/9GV/zebjjub6RS+b3oAm6S2P3MRvlh3HnEIfK3ft4rG5c9jRMoc//sWtDC2Yy7986R+bdkgNEZFGpMSqgV30t++kraudCyvuoPv0R9+Lz2on39pCbqTA/z7zOHoz7WzInZBgpOMbL7Gq9om/v5Dfr1jET+asZtjapzaoOvOSvttZ3/E09qTmAvDu336PfEuG1j395LdtZk9xiF0PbuWZr34F2xfPgdtu44qv3shlH1tDOpVm685Nh10LJyIiUUqsZFIu+9DbSedasFwLQ32DtLVmIZdhuKcbKwVsWTyXZU/sYqCrlf1d7dwx7zi2pRZRssMbyP9QE6vxLDqhm7963VvZt3IxLcN5fnvMChb37WNr12zWtR3ZtpvVBetvYOSJR/jM5d9MOhQRkbqjxEoS8+G1b+GaG248cCns0i9eRGrnXi7+5BVc/KVL8C1P8InLv5ZojBe/54209MzDOjrYP6+b4ZYsv1u0nNZSnrtbn51obPXqtdt+wn8sfDFv/92PKDz0CLmu9gPDeBzMohO6dWlURGY0JVYi02DRCd28/aV/TPvcuQwVB3n4N/dw3f/7Hz71xU/zyLFLaM0XWLRtL/cfs5TWYoH/N/clSYdct54zfB+/a30WAK/Z8VN+tOA0Xtx3B2kPADjxgU3sWDyXrr4hCps30p2dTWBpLJcmVSzxkUu/wGUfejueypHtaOGfvnW1kjkRiY0SK5EG9snLP8JwVyute/oI+vaRmjsPw8m3tYI76WKRR5cvYlt7N8/ZvJnHF8yla2SYzsFhvrXilbilk96FpjM32Mnu1HwAnlbYyEC6nc7SIKv2bCYdBJhDplTi4XkLWTDYy9M2PMbwk0/qDlWROqHESkQm5aK1b4NSlsJxS9kzq4MH5yxhb7qbHamFSYcmk3BC/kEwOPnJR8kWSvRs3YV5iaAYsL+wj46gBU9lyLW3M7R9C3uKQwBc8dUbWfOOs9n14NYZPW2WyFRRYiUi02bNO85myeJj2LJ1Ez098w/U0F32sTVkOtopDgyy92lHs6erg01dixhJZXk8vRyAZaXHeTy9LMnwpQGcOHIfRUuTtyxtwQibcsvI08KzRzZwV+tzOGn4Xk557FEeWziP7qFBFu7Yx0BHK/ctXcopmx6ltW8YgMzIIAFGfnYXLX3D5Pv7SOdaoT0Hg3luedELIndbzw12kaXAttRiun0fR+efZEd2LscOPcHKXTtxjH2d7XQODbNwyx6Gutto29VL0N5KZmiYYu8+PJVh6JijGcll6Nm4mXRrC6liCS+UCGZ1UNq7jz17n6S1p5vex7dw5bd/wnvf9UaOWriYQrFIoTjEwM5BPv+1a7nob9/JJz73lQPxXbT2bQzu2sM//Ov1Nb+zD7/rPD5z5XWsXXs+XflFfPTznxnzd3vZh95OfmSET34xemPLxR+8oPz83191xMdvJog1sTKzM4AvAmngX9398qrnW4BvAM8FdgNvdPdHJ9qmEisRqRd/d+n7+d1PfzlmT40HTuDOJWv+jFxXO/m+QT555bf59CXvpTB7NtmBco+PFYv0LZpLy9AI+dYcrQPDpAKHIGD7UfPo2dvH5qPmgUFrvkB/aytPtvdQshRLB3azuaN8Obdeh0gRqWfXr2rjhQuPn9L3iC2xMrM08BDwCuAJ4A7gTe5+f8U67wZOdPd3mtl5wGvd/Y0TbVeJlYjI4bnob99Je0cr+eE82Wwa72xn39xublv+TFYMbmVD50pdwpWmc6TD+BzMRInVZAceOhXY6O6bwg1fB5wD3F+xzjnApeHj7wFXmJl5PVxzFBFpMJWXehqNu2NmB9ofXvsWZuXm8NHLvnhgWWUt2PGnL+KtL3wdQ7v30jZ/PkM7dwKQSpUAaJ23gHt+9Rue/fxT8c5ZWDFP//weOrbswlpzeCrN7kU9tA8NU8hk6N7bx765s0iXAjr6BkmN5Ml3trNtwWzunbuclz/wOy5778cjsczvWcoll/8zrz73BP7jhgc457WreP6zTqc4MkSmYxaFoUEys2bhw3ny+RHa23IE+YCRhXMA2NvTSSll5AoBbSN5dnd30DE8Qi5fZGfPLDqHhvnO0a/kpOF76RnpZ19LB0OpFh7IlXtoenwPe628rcoZOhppto6DWf+iZyX6/pPtsfpT4Ax3f3vYfgvwfHdfU7HOfeE6T4TtR8J1do23XfVYiYiIyEwxUY9VarqDGWVmF5jZOjNbtzP8ViEiIiIyk002sdoCHF3RXhouG3MdM8sA3ZSL2CPc/Sp3X+3uq+fPnz/JMERERETqz2QTqzuA48xspZnlgPOAG6vWuRE4P3z8p8BPVF8lIiIizeBwhls4C/gC5eEWrnb3T5nZZcA6d7/RzFqBbwInA3uA80aL3SfY5k7gscOIfzLmAePWeUlidFzqj45JfdJxqT86JvVpOo7Lcncf83JbXQwQOh3MbN14hWaSHB2X+qNjUp90XOqPjkl9Svq4JFa8LiIiItJolFiJiIiIxKSZEqvmmMBo5tFxqT86JvVJx6X+6JjUp0SPS9PUWImIiIhMtWbqsRIRERGZUk2RWJnZGWb2oJltNLO1ScfTaMzsaDO71czuN7P1Zva+cPkcM7vZzB4Of/aEy83M/ik8HveY2SkV2zo/XP9hMzu/Yvlzzeze8DX/ZJUTiMm4zCxtZr81s/8I2yvN7Pbw9/idcDw6zKwlbG8Mn19RsY2PhMsfNLNXVSzX5+owmNlsM/uemT1gZhvM7IX6rCTLzP46/Nt1n5lda2at+qxMPzO72sx2WHlqvNFlU/7ZGO89Dpu7N/Q/yuNtPQIcA+SA3wGrko6rkf4Bi4FTwsddwEPAKuCzwNpw+VrgM+Hjs4D/Agx4AXB7uHwOsCn82RM+7gmf+99wXQtfe2bS+z0T/gEfAL4N/EfY/i7lseUAvgK8K3z8buAr4ePzgO+Ej1eFn5kWYGX4WUrrc3VEx+Qa4O3h4xwwW5+VRI/HEuD3QFvY/i7w5/qsJHIs/hA4BbivYtmUfzbGe4/D/dcMPVanAhvdfZO754HrgHMSjqmhuPtWd78rfNwHbKD8x+ocyicRwp/nho/PAb7hZb8BZpvZYuBVwM3uvsfd9wI3A2eEz81y9994+f/8b1RsS8ZhZkuBPwb+NWwb8DLge+Eq1cdk9Fh9Dzg9XP8c4Dp3H3H33wMbKX+m9Lk6DGbWTfnk8TUAd8+7+z70WUlaBmiz8jRs7cBW9FmZdu5+G+WBxStNx2djvPc4LM2QWC0BNle0nwiXyRQIu8VPBm4HFrr71vCpbcDC8PF4x2Si5U+MsVwm9gXgQ0AQtucC+9y9GLYrf48Hfvfh8/vD9Sd7rGRiK4GdwL+Fl2j/1cw60GclMe6+Bfh74HHKCdV+4E70WakX0/HZGO89DkszJFYyTcysE/g+8H537618LvyGoFtQp4mZvRrY4e53Jh2LRGQoX+q40t1PBgYoX3o4QJ+V6RXW05xDOek9CugAzkg0KBnTdHw24niPZkistgBHV7SXhsskRmaWpZxUfcvdfxAu3h52vxL+3BEuH++YTLR86RjLZXwvAs42s0cpX3p4GfBFyt3lmXCdyt/jgd99+Hw3sJvJHyuZ2BPAE+5+e9j+HuVES5+V5Lwc+L2773T3AvADyp8ffVbqw3R8NsZ7j8PSDInVHcBx4R0eOcrFhjcmHFNDCesLvgZscPfPVzx1IzB6R8b5wA8rlr81vKvjBcD+sBv2x8Arzawn/Bb5SuDH4XO9ZvaC8L3eWrEtGYO7f8Tdl7r7Csr/z//E3f8PcCvwp+Fq1cdk9Fj9abi+h8vPC++EWgkcR7kAVJ+rw+Du24DNZnZ8uOh04H70WUnS48ALzKw9/J2NHhN9VurDdHw2xnuPwxNXNX89/6N898BDlO/M+GjS8TTaP+DFlLtO7wHuDv+dRbnu4BbgYeB/gDnh+gZ8OTwe9wKrK7b1l5SLPjcCf1GxfDVwX/iaKwgHt9W/Qzo+p/HUXYHHUP5jvxH4d6AlXN4atjeGzx9T8fqPhr/3B6m4w0yfq8M+HicB68LPyw2U71zSZyXZY/Jx4IHw9/ZNynf26bMy/cfhWsp1bgXKvbtvm47Pxnjvcbj/NPK6iIiISEya4VKgiIiIyLRQYiUiIiISEyVWIiIiIjFRYiUiIiISEyVWIiIiIjFRYiUiIiISEyVWIiIiIjFRYiUiIiISk8zBV5l68+bN8xUrViQdhoiIiMhB3Xnnnbvcff5Yzx00sTKzq4FXAzvc/VnhsjnAd4AVwKPAG9x9bzj/zhcpD98/CPy5u991sPdYsWIF69atO7S9EREREUmQmT023nOHcinw68AZVcvWAre4+3GU59dZGy4/k/LEk8cBFwBXTjZYERERkZnqoImVu98G7KlafA5wTfj4GuDciuXf8LLfALPNbHFMsYqIiIjUtcOtsVro7lvDx9uAheHjJcDmivWeCJdtpQ4EpRKf+Oh7ybVlKaWykMtQaG8hMCuvYBCdktrG3ZanJniu6nVWsVU3q1q3Yr0JnvOat7MJnht7G9Wvq969mnUj8Yw+a4DX7EdkOxXPTbTNdCmg8+HHuOTyr4y7LRERkZnkiIvX3d3NrPb8fRBmdgHly4UsW7bsSMM4qA9/6C2sO/0s1r/qgil/Lzl0r2/5n6RDEBERic3hJlbbzWyxu28NL/XtCJdvAY6uWG9puKyGu18FXAWwevXqSSdmkzX0rBNZn3sGf9T7Gxb29pEpBWQKRdqG8qSCoCq4cRuYW2RZpMep+k0jL42+h1Wt7e4Vz1VvpzqG8d/Tq9aNrBBUrW2V71n1urGaHm6v6j1SkRUm7vWz8Hddasnx5dVvoJjWiB8iItI4DjexuhE4H7g8/PnDiuVrzOw64PnA/opLhon6/dx5zA128bMPf5htD+xPOpym96mL3zft7+nuNZdbR0ZG2FPYw9zMfHKth/dxKBVKpFKGVSSJHgRgVvN+R2Ks+OPYxlTEKiLSrA5luIVrgdOAeWb2BHAJ5YTqu2b2NuAx4A3h6jdRHmphI+XhFv5iCmI+LDtzPSwo7mK9kqq6UApKwFg1YGMbTQhGCkWWP3su7zr3TWTb2/GWLKVslv6uNgrZLKW0kc+kGc7lGM5kyKcy9GbbKVqagXQ7KS9RtAxFy5C3HEXSDNFOGw+T8QIpAgwnhZP1AmlKBKQISFGyNI5RIkVgaRzIepG85ch4gSxF0l4i4yWKlqZgWbpLfaS9RJqg/FxQophKk63e/zCnqazPq67VG0y34lgYkxGE956k8HKEHpDy0ccVPz0gsBQlSzGcytFeGsGBfCpLPpUlwBhJ5Uh7QE+xlxX7dnHlmz5weAdWRKTJHTSxcvc3jfPU6WOs68B7jjSoqdCfamdBvvrmRkmKF4vlBwfpJfn0ZR9gy7FHsWnOAgbSbexOzyb9z7dwpR1a71K799MT7CPjJWYXe3GMjJfIBkUyHhCYUbQ0bcU8pZThGIGVfxZSGUqWIu1BRZLiBxIYgHw6Q8odwylZiqKlKVoagFxQoD/TTiGVYZg0BctQsCw5z1MM46+8BGvVl3yJXqrNeImsFxiyFnJeIB1eXg4wCpbBrZz0uaXKPzFKlqZE6kBiV7QMOzMpshTIBXlyXsCAnmIvBcvw29YTWb9w+JB+tyIiUqsuRl6fDoPWTlsxn3QYUmW8HqvLPraGB5/7TG598f8hsDRZz7O8+DgrR7Ywd+hB2goF2oYLZItFMsUSHb2D2PAImFMcKbBj92N879bbGAQ21VEvZalUIp1OH9E2juSSoLvjpYBUZuwY3nzDlfxq1klHEF3jK+RLZHNpSu6kxzgONcfH/aBfIESkcTRFYnXeac9j6OKv0lYoJB2KHDB+0fqnP/lBvv/SV7M9tYgXDtzJSQ/9nsLDm/jkP39rUieoK+IIM2ZHmlRB7bAck32tjZNUQfl+hupLkNMhCAL27NrJpZe8naPmrqCIkzGDlhY8lSLIZvB0iv6udjLFEi0jedwMN6OQzYDBcGuW/tYWADJBQCGdJp/JUEiny+1UipQ7hXSakXSWwXQLjtFWGjlwqXQg3UZgRntpmIyXL9e2lAr0Z9rIeYGhVAtbswvJhD2GOS+El3pLB3o2y5eKU6Q8IOtFRlI5OkpDpD1gJJUtr+dhD2eq3JPZWRwiFxQYSreQIiAgRT6Vpas4SMZLtBXzPPveh/nox/5h2o+NiExOUyRWq178fH5qKVpHLz9J4krj9FX93aXv57qXnMmAtfOO+67n4+/9+DRH1uzivUH3Y+96M60rljHS2cpILkd/Rwv9ra305VoZSucYTucYTLUxaG0MWjuDb/hErO9vXsIoX0rNUiDAyFIgS4E2LydP27LzyFAi7SXag2GyXmR/posi5Tq5EmlaGKFEmqwXWJbfQi4o/y3JpzKULE0QXnYdsVy5Pi8oULIU/el20h6wMzsH8/L4b1kvUiJFxktkKJLxEruysxmxHLmwzi/tAVkv8ETLQgpk2ZOaS8+xg7H+bkRkajRFYpUJv+GnS8FB1pTp4qXaoRnWvONs1v3pX7LPZvP2u/+Diz8Q70lWDs2RpFZ9u3fzpSv/jq3LF/LQvMU8+Po1DFt7ZJ20F5nl+2n3IVp9hO5iH4tKu2gv5mkrFGgtFCik0+SKxXL9WuC05osUMmnm7txHkEpRaMlgXq5LSxfKPUvZwWEK/YOUcFrTGfaX9nHNDTfyyLrNHLP6aDbf+SSlbJZsLocHAY5jlpqwB9DdCUol0pnMgaFMJttjGASOBwHpTBovFLBsdsJ1UymLXE78+Np3c+WrLphwUN44uAfgARbemGFmBEFAKpUiCIJy2wOKI3myLWlSqVz5+cIApXQH6UyKoBQQeEAmk2Fg3wBPO/MoXnfSH9LRPZsWOmnJ5TAPIJulMDhIJpPGSDFcLJLGsCDPjr7t3HDvL9h4y+8JSllSqTSplJFKZykFAeAEI8O0dnSGMebZM9zLvPZ5eBAQlAqsOmM5mPHAzU9GjtfofpgZBAGkDm+4F91JKxNpisSKTPkPWap6jCdJTNZqi9dTL3oJj2ZW8JZHblJSlajJnSwu+tt3EhxzFBuPWsADnSvY/qI/A2BesJPn9d/Hip27aR8YJjs0AgPD3HfbL/nWLbeRSrVO+YnpM5eXf44OsTJ6GrVU6pD20sxIZzIHHh+OVMogVb78OlFSdWDdcd7riP56ubPmneew6NhV7J/bTZAyds/qZDCbpWhphjNZBtOtDFkLLZ4/cAfsUKoVgCFroz0YpGgZ9tgc5vpuWoNhBlLt7LfZdDBAezBIYCkGrIOc5xmyVvzTP+N7hxFu9vV5TvjlBopkwrt0A9KUMALAKJAlR54WHynf7UobWe4vX4YlRfDRGyiQ4+hb19HKMK0+RM7LpSAjlqPF87QHQwd6M0cvgFt4I8rojSOVywCKlqYlKFC0NCkClu/fxVVveJ8SLIlojsQqvHvKAiVW9Wb0iKx5x9n89xs/wHGFjXzz7z/D595+YaJxNavJzqHwqc9+hOvPeB27UvPJ+TBPz2/ixbvvY/HmHVzx9a/y73V048BMNd5l8wlfky/yd5+/kCeWL+KJ7jnszXax5Y1ra3oPAWb7XtJeomQp5pb2EpAq9wRSorM0QFdxkNZSgYFMKyVL0Z3qI+NFDGdhfi/thU0MZnMUUuXTSWdhMyPpDG3FPO2FQvku2sCfuqs2CAhSKQKzco9kWPfmZgQpYzBTHvrDzcgEQXkAFDMCg8DKl1wzQYkgZYyks2FK5LSUiqQ9wNwJzGgrFAhSKQYzWXa1dNMa5BlJZeksDrEnNwu3FCkvQphKBdiBqcpG06vRx3nLYjg5L7AjMxcwdqfmsX5+UUmV1GiOxMrK31PTSqzqRiEVPRYLjn8OvTabcx/7FT/XyThRh1q8fsk/XcI1q19DC3nO3/if8MgDfObybx54/mNrPztVITaV0cvmhyIoBVx2xSX8eNUp/P75bwbKPYezgj5O7b+Xxfv2s2Db3nJS0zfA+993Ce1zngPuDA/009rZBe5YeIls9FJgJB533L1meT0bvcR6JHdoBqU8KcuQd8gXA95x01X8vPu5MUcqjaApEqsgTKwM1VjVizzRoS8eXzoPgNlP1MVA/U2rZmqjcVz6xYu4+tmvYZ7v4vW/upkLL/rHKY6seY1eNj/Ykbl47bv43Uuex+0nvo6eYDev3vkzjnngMdZe+FlSmYP8qTejrWvWgcejxkqebAbWFo1eYj2SYS9S6RwAOSCXTiV2B63Uv6ZIrCxd/p8/pR6rutHSV06sRgtyN85exNLSZi78+JeSDKvplS+qTHyyWPOOs/n16y+g2/fzup/9Nxde9oVpia3pTZAUfHztu7n1ZS9jY+YYXrXnFyy/Yz2XXX7lNAbXfA71S4g0n6ZIrAjncJts/YhMjzXvOJtH3vgxXtJ7Z9KhyCGwF7+ELemlnL/xP/mYkqopV33ZvJq7c/eLn8vGzDH82e//m8+97SPwumkKTpqWu5MvFCEo8NVPfJ6dpd/TmmnFcuWx5DxlpEgRpKDY1ooFjgUBnk4RpFOU0qkDX6w9ZZTSKUqpFAPtLRRTqbCdpmgpSqmnvlSMzozho7ceGOBh2wzLZHj7yS/hjMUrE/itlDVFYuUeJlbqsaobQfDUIJWLlj6dguVYuK8vwYhk1EQ9Vh9715v58evfwdMLD3PNP3yWz/x/H53GyJrT6GXz8f56XfzPH+fXq87ljD2/KCdVMi0OpXe3Hg3n81z03jV0zc+R6myn0NZKMZehmElTyKYZzmUZyWYZymbpzbUxnModmKprdFqu8r8MBXLlUeFOPwu3+GvuzEvlOVgpVdypWXnnZvVtBuXHvx/ojT2WyWiKxGr0HmsNt1A/9gX9ALhBfnYHALP6BpIMSaBc3DvR0yeeQK9187pNt3GbbjKYFqOXzcfi7vzqacfT43tYeMft8Lo10xiZ1FNi5e5c/JG309ozj5GONvo72+hra2F/Wxu92XZ2Z7vpTc2in06CN74Dt4lngcj5MLN9P23B8IGBbFtLg2S9SDYI51sNSmRLAdmgRKZUIlsqkSkG4Y1io8mP0TKcL882kE6RKjnpUol0KQg7O8o9WRaAlZzUQD+pVJqFS5Zy9rnn0z13DplwxoqxbqaoR02RWI3eQqvEqo4cuLxh9HWVbwFv2a/EKmkH+xZ+37KltHs/waMPTV9QAjDmAKGf/sxa1j//TZy167bIHZkyDRI8n3x47VtoX7ic/lkdbJk7m83t89ifnsWuV76boCph6vB+uoP9zCnuZ1lhOx2FcpLTUijQNThM2+AImXyRdKFIqlCEkREGd+/msiv+b90lMfUWz3iaI7Ea7aLUpcC648DeznbMSwxueTLpcJreRN+/L/vQ2/ndGW/jlIH1OolPo8rL5tWeWL4QgKdteHSaopEkrHnX61i0/OlsWzqX9fOX8sgr15C3ci1T1vMsCraxbGQrJw89zPz9fXT0D5PrH2R4bx8X/92XyU4wP6jErzkSq9FLgYGGW6gXuzZsO/C4v6WVLvr45JXfTjAiGTXe14+B41YybG08+9HN0xpPsxu9bD6WR3oWsDDYxoUXf34aIxKY+hqrYlDk7/7hYtatehr3v/599Fl5OIzFwZOcOnAPx27bQdfefvKPbeKyL39nyuKQyWuSxCqcJkKXAuvGT7eFl5IMerNtzApUuF4XvFwTMZbN8+eQ8xF233/X9MYkQLkesdqT2QWsGFFPbxKmsrrqk59dy3+fdAoPrX4DLT7MSUP3c+yOHczZvocLP/BxUrm2KXx3OVLNkViNDhCqxKpubHtgP4tuvRvH6Et30FVSfVW9e7J9DktKT3LFlT9KOpTmUlGPWOmiv30nu8+8gOcPPDD9MQlwhPM3juGiv30nj7zoOdy6+vV0MsBrdvyUlfc8woWf0vh+M0lzJFajPVaqsao7DvSlOpif35d0KBIa67bpRSd00/nP/8FzdBKfdpWXzSvlFs7BLcVcDVOSjAl6dw/HRV++lBvO+BN2phbw4r7/5ZQ77uXCT3wJ3hjbW8g0aYrEKjCNvF7Pem0WXflHkg5DGP808Vdvfhv/ZF0s6tUQC9Nt9LJ59V+v3p4uAGbtHr8GS6ZWXGM3XXjlJ/i3Z7yGBb6TC+67no+vuRQ7u36GcpDJOez/K8zseDO7u+Jfr5m938wuNbMtFcvPijPgwzHaY5Xk7bFSyzygkE6Tt1Y68iNJhyM8NU3HohO6I8sH55bb83ardyQxVefZPbPKw5T07XsigWAkrrTno1dexjeOP4NlpSf4k5tv4LL3fnzGzcUoUYedWLn7g+5+krufBDwXGASuD5/+x9Hn3P2mGOI8IqPjv2gcq3rjjKTLnaa5YjHhWAQYt2hk19zyHUktO/ZMYzAC5XpEqL0DrT/XQof3a+iLGeyTn13LNcefyZLSk5zzs//hksu/knRIEoO4Rts6HXjE3R+LaXuxCkZ7rHQpsK4YkA8Tq2yhlGwwEnHaoqdH2vta22jzQS78pIpo60V/to0uVw9iUkZ7d19+9rGH9fqPvevN/OjkF9LGIOf+8lZ9thpIXInVecC1Fe01ZnaPmV1tZj0xvcdh800P8r6ffZ2RTY8mHYpUyaeyAGSLSqzqwWifyLxnLIos39/STk+wd/oDEqB82bz6a2Ffpk130ybpCL+nbz/tVB7LLOdPHvkFH7n0C7GEJPXhiIvXzSwHnA2Mzv55JfAJyv/bfQL4B+Avx3jdBcAFAMuWLTvSMCakrvL6ZDgjo4lVQZcC68PYZ4t9mS66S+odqSf9qQ4WFnYnHUbTWxDMmfRrPnXx+7j5tPM4afheTWTegOLosToTuMvdtwO4+3Z3L7l7APwLcOpYL3L3q9x9tbuvnj9/fgxhyEyUT+UASKvHqr4ET9Xz+Eg/e9PdzC7o7rPkOFQVNPeluugsDCUUj4wejTlHL5pwvbFsfsZyhq2NF63fEG9QUhfiSKzeRMVlQDNbXPHca4H7YngPaUCGM2LlHquMaqzqgoUdVrNTnQeWvfev3sx+uuke1kk8KdX3iC06oZt+OugoFBKJR+BA724wuTv41rzjbH6+4ESOKzzMRR/89BTEJUk7osTKzDqAVwA/qFj8WTO718zuAV4K/PWRvIc0tpFwItGU7gqsK6nUU4nuUUuPxS3NrMHhBCNqboZHLtK+++zX45bW3bQJssOssZp1yqnsTs3jxb9/MN6ApG4cUY2Vuw8Ac6uWveWIIpKmUe6xKl8KZEQniHow1rRPxY5y71XngBKrJFUemVRr+ZhklVglrrJ391Dcv2QxHd5P+u77pygiSVpcdwWKHJYRWgFIl3SCqCcjXbkDjwe6yseovW8wqXAEIjVWlksDkNMl9MRV9u4ezJp3nc369uN45tDDfPLKb09hVJIkJVaSmHKPVfmkPTSskdfrSY6nEqu+jvIxol81Vkmxqrs1PathSpI22rtb+SXkYOYfdyJ9Novjt26dqrCkDiixkrrw0G/WJR2C8FSRdLaiIHd/WxtZz3PFd/8tmaCkJrEKMqMD66qndyZ5/Oj5mAd0P74j6VBkCimxkgSVTxZZz3PdT+9IOBYBxpxPszfXRo/vPTC1iiSj8siUsuVLgRqmJHmVvbsH81D3Eo4ONvOxy74wdQFJ4pRYSWIO9I6gW8brTcGfuq9lX7aL7lJvgtEIROcKLGTLx0fDlCRnrN7diXx87TvZlFnBCb2aNLvRKbGSxIxe3kijyxn1YvQUYemnThZ707M0OGjCqi8FFjPlHqtUXolVYsbo3Z3IyPIllCzDyi26DNjolFhJ4jLo5FCvFp3QzT7rYfaI7ghMluMVHSOFA5cC9aUkaZW9uxN5cv5sUl4ieHz7FEckSVNiJQkKe6xcJ4d6kw77rv7qjW+laFlmDWkMq3oymlh5QcclKWP17k5kc9c8jgqe5BOf+8rUBSV1QYmVJGb0z5F6rOrHU6eIAIBSVxcAXRocNFFW8V+AfLqcWA0Nqj4xaemaCYdqvfZPnsXj2SUsG1JvVTNQYiWJOVBj5Uqs6kZYN2Lh7fzD4RhW7RrDKlHVNVb5TAbzgH/50bXjvEKm2mRmCFx9yqvos1ks2bd3yuKR+qHEShKXUWJVN6pPFn2dbQBk+gemPxipUFVjlc6QI68hMOpCcNA1ehfOAWD+Dh2vZqDEShJU/hauS4H1J50qX2rqa2vFPODJLY8kHJFUGkmnaUGzFSSqqnd3IlvndJP2IgM7H5vqqKQOKLGSxIx+AdelwDoUlG8oGMpmaWOQK756Y8IBNTcjOkBoPp0h50qsknTg71f4JWQiWzt6WBRs4zOXf3Nqg5K6oMRKEqQaq3ozOv+ZeflPw1AmR7urvippNTVWqSwtnk8oGpmsHdm5LMzvTjoMmSZKrCQxB+4KVGJVt4bSOdqUWNUBj4y8nk9lyLnuCKwLwcTDxVz8njey0+azYKhvmgKSpCmxksSl/eDFnzLNwnP4UKqVtkBDLdSFiuL1kVQLrYEuBSapund3PC3LVhBYmrm9mr2gWSixksSMXt5Qj1X9sNErTuFJfDDVSntJJ/CkVd+tOWQttATqsZoJ+rs7AZi1V4lVs1BiJQkarbFSj1X9eKqWx90ZsjbaSqrlSZ5HqqxGrIVWHZf6cJABrfbMLidW2d0aaqFZHNokR+Mws0eBPqAEFN19tZnNAb4DrAAeBd7g7hoVTWocuKsmUGJVbwJLU+wdYNDaaCvqBF4fnjqDD1krrSX1WCWpund3PLs6Ouny/Vz4qS9NeUxSH+LosXqpu5/k7qvD9lrgFnc/DrglbIuMS3cF1o/Rc0TKSvz1h97MsLXTWtAJPGkGBwYIXXRCN0O00aoJmBNWzqwCm3i4hT25LuaV9kxHQFInpuJS4DnANeHja4Bzp+A9pCGENVbqsaof4bdwszRHzV8OoMSqDlQOt3DBuW/GLU2LjkuiDnVKmz2Z2fQUeqc0FqkvR5pYOfDfZnanmV0QLlvo7lvDx9uAhUf4HtKgnroU6BOuJ9MncrJobSn/yKtnJHlP1Vi1tpenGWop6LjUg5SN3+N+zmufwR6bQ8+IpoRqJkdUYwW82N23mNkC4GYze6DySXd3MxvzrBkmYhcALFu27AjDkJnoqbsC1WNVb9xSlFpzALSOqGekPpTTXs9lAWhRwpusit7d8Tz/xJdzu+WYPTg4TUFJPTiiHit33xL+3AFcD5wKbDezxQDhzx3jvPYqd1/t7qvnz59/JGHIDDU64GFKlwLrRzg2T4oSxZbyCTyrxCpxlVPalLLlE3kur+OSpEO5FFiaNQuA7n6NBddMDjuxMrMOM+safQy8ErgPuBE4P1ztfOCHRxqkNKYS5ROE7gqsH5Uni5GWco9Vdlh3BSbvqY7/UthjlSnopo964Db+aXSgq3zZtq1PPVbN5EguBS4Erjez0e18293/n5ndAXzXzN4GPAa84cjDlEakxKp+BZZmJFf+82B5JVZJs4r/5kcTK/VYJauid3c8vZ3lxCq9X9PZNJPDTqzcfRPwnDGW7wZOP5KgpDkosapDox0jHjAcXgpEtTz1IexOHE14UzouiRrt3Z1ouIX9be3kfJjb77tleoKSuqCR1yUxxTCvT5d0V2C9sKcqchnKZjEPuPe2XyUblGAVdwXmR3sSRzQ5dqIO4c/W3tZ25voefnj9/VMfj9QNJVaSmNFveuqxqk/D2SxtDHLdT+9IOhSpOIuPZMqJ1f6RfQnFIhET3NW8NzOLnqKmsmk2SqwkcUqs6pDBUCZHu6tXpB6U7wosX3wazOXIep7L/+4byQbV5Cp7d8ezO93D7LzGsGo2SqwkcamSEqt6MTrqnLkxlM7RpsSq7gxkW+jyPmyCE7pMo3EOw2Ufeju9Nps5Q0qsmo0SK0lcRiOv143RxMqBoVQrbYHG36kL7gfmCuzPtNHp/cnGI4w99PVT0nPnAjC7X0MtNBslVpI406XAOvLU2WIw1Up7aSTBWGRUZadIf7qdzpJO1vXCfOwuq8FZHQB09epYNRslVpK4tC4F1h1PGUPWRpsSq7pQrucpn8D7Ux10FnWJNmmVvbtjGR3DKqsxrJqOEitJnGqs6k+KFIPWRltRg1DWi9ETeJ910VlQwpu8ia8F7utoJ+MFNtz162mKR+qFEitJnCmxqhujdzoFKRi2dloLSqzqg+NmXPahtzNirXSMKLGqF54a+1Lg7tZO5vpuvvnD26c5IkmaEitJnCZhrj/F1hYA2kc0nU09GD11ZzrLk/p2aP7GupEa5zS6J9vN3OLeaY5G6oESK0mcFXVXYP0on8JH2sPESifwOlH+jJTaWwEdl3ow2rtb8rH/fu1Oz2HOiO7ebEZKrCRxKR9/ElOZZuFJYqg1B0DbkC451QsHRtrKCW/LoI5L8sYfR+zja99Nn83SGFZNSomVJM5LSqzqxeipYiBMrLI6gdcFC/870FHuscoM6Bb+ejFWiVV6djcA3X06Ts1IiZUkzjRAaN0ZaCn3jKRUY1UXRi879YaJVW//jiTDETjQu+up2tPoUHd5qIWuXg2L0YyUWEnydOdZ3bDwZNGfK5/AB7duSzIcqeBAb0sbXd7LZy7/ZtLhNL2nOqpqvxjun9UOQKZPlwKbkRIrSVxxnOJPSU5/po12H+DjV2ii33qyP9dOd7A/6TCEp76EjGVvewc5H+GXv/3PaYxI6oUSK0lcQaNI153+VDud3k86nUk6FKF8KdDN2J/uZHZRI3nXk7Emw97T2sFc381/3vBgAhFJ0pRYSeL27le9SL0YnaajP9VBZ6DLGPVmf7qbWQUVRNeTYIzi9d3ZbuYU1bPYrJRYSeKuuPJHSYcgVXptlib6rSOGU7IU+5nFrBH18NYDm6CCYU9qDj0j6llsVoedWJnZ0WZ2q5ndb2brzex94fJLzWyLmd0d/jsrvnBFZEqFdSMFy9FZGE44GKm0IzsHtzTzejXoZD2xqvGsLl77Lvqti54hfTFpVkdSQFEE/sbd7zKzLuBOM7s5fO4f3f3vjzw8EUlKhyb6rRuGsyW9FIDuPeoJqStVlwJzPeUxrGb3q2exWR12YuXuW4Gt4eM+M9sALIkrMBGZfpXniI68xrCqR4Vdmn+uLoxzV+BQONRCZ696rJpVLDVWZrYCOBkYncZ7jZndY2ZXm1lPHO8hItOg4lzRPqweq3ozJ9jNZZdfmXQYwvgT2vR2lgcHzfbpkm2zOuLEysw6ge8D73f3XuBK4FjgJMo9Wv8wzusuMLN1ZrZu586dRxqGiMTiqcyqdUgDt9aL0TGTFhR3JRyJVPOqFGtvRwcZL7Dhzl8lFJEk7YgSKzPLUk6qvuXuPwBw9+3uXnL3APgX4NSxXuvuV7n7andfPX/+/CMJQ0SmQIsmYK4780Z6kw5BRo1+B/FoYrW7rZN5votv/vD22tdIUziSuwIN+Bqwwd0/X7F8ccVqrwXuO/zwRGQ6VZ4isoO6K7BejFh5Uuw5g7q8VD/CzCoVrbXalZ3NvILq4JrZkfRYvQh4C/CyqqEVPmtm95rZPcBLgb+OI1BpPM8Zvo+X9OlbXb0q9OskXi92p8q9+rP7dKdZvRirxuqPz306u1Lz1LPY5I7krsBfMPb/WzcdfjjSTH585p8lHYJM4MobruWSy7+SdBhSoaNPd5rVnYoOqxeeeBZ3WjtzBjRrQTPTyOsickDlaNLbHtCUHPUmPaDLs/Wmcq7A0uxOAGZrqIWmpsRKRCpMME+HJC4YUWJVL8aa0qa/uwOA9n1KrJqZEisROWD0ZNHlqhGpR//8vW8mHYJUqcyv9naVBwcd2a3i9WamxEpEanS6CtfrkS7P1pNySuUVlwJ3dnTR43v4xOdUm9jMlFiJyAGjp4iOki5liEzkwKXAilu4duVmM1+DuDY9JVYickAQniRmlXRXk8hEqm+Jd3d2pOexYES9is1OiZWIHDBr2x5OHr6HP7j3gaRDkQrPH7yL03p/k3QYMoFPX7SGPpvF3AFdRm92hz2OlYg0ngsvDidRODPZOCTqh3/8l0mHIFU8nL+RsMaq1NMDwJz96u1tduqxEhERmaTqS4F9s8tDLXTsVWLV7JRYiYiIHCYP7w7cM6sD84CRfTsSjkiSpsRKRERkkmz0UmB4Gt3Z3skc38MnLv9ackFJXVBiJSIiMkkWlBOr/u7yoKA7cz3ML+5OMiSpE0qsREREJim1eRs5H2bTwvkA7EjPY56GWhCUWImIiEzaZZdfyYri42xtncOnP/ZeBqyLeRpqQVBiJSIiclh6Cv3sS3VTmDe73NZQC4ISKxERkcMye3iQvdbDhhVLSHuRri26I1CUWImIiByW7sEhAkvz0+4X8OyRDVz4iS8lHZLUASVWIiIih6Gzf/jA42dtfSLBSKSeKLESERE5DO29T9VUzX18e4KRSD2ZksTKzM4wswfNbKOZrZ2K9xAREUmS9fUdePyRS7+QXCBSV2KfhNnM0sCXgVcATwB3mNmN7n5/3O8lIiKSlAs/cQW7r/kMPTt74aUnJR2O1InYEyvgVGCju28CMLPrgHMAJVYiItIwzIzP/7kuykjUVFwKXAJsrmg/ES4TERERaWiJFa+b2QVmts7M1u3cuTOpMERERERiMxWJ1Rbg6Ir20nBZhLtf5e6r3X31/PnzpyAMERERkell7h7vBs0ywEPA6ZQTqjuAN7v7+glesxN4LNZAas0Ddk3xe9SzZt7/Zt53aO79b+Z9h+be/2bed2ju/Z+OfV/u7mP2CsVevO7uRTNbA/wYSANXT5RUha+Z8i4rM1vn7qun+n3qVTPvfzPvOzT3/jfzvkNz738z7zs09/4nve9TcVcg7n4TcNNUbFtERESkXmnkdREREZGYNFNidVXSASSsmfe/mfcdmnv/m3nfobn3v5n3HZp7/xPd99iL10VERESaVTP1WImIiIhMqaZIrBp9UmgzO9rMbjWz+81svZm9L1x+qZltMbO7w39nVbzmI+Hv40Eze1Vy0cfDzB41s3vD/VwXLptjZjeb2cPhz55wuZnZP4X7f4+ZnZJs9IfPzI6vOL53m1mvmb2/kY+9mV1tZjvM7L6KZZM+1mZ2frj+w2Z2fhL7Mlnj7PvnzOyBcP+uN7PZ4fIVZjZU8f/AVype89zw87Ix/P1YArszaePs/6T/X5+J54Rx9v07Ffv9qJndHS5vqGM/wTmuPj/37t7Q/ygP+fAIcAyQA34HrEo6rpj3cTFwSvi4i/I4YquAS4EPjrH+qvD30AKsDH8/6aT34wh/B48C86qWfRZYGz5eC3wmfHwW8F+AAS8Abk86/ph+B2lgG7C8kY898IfAKcB9h3usgTnApvBnT/i4J+l9O8x9fyWQCR9/pmLfV1SuV7Wd/w1/Hxb+fs5Met+OYP8n9f/6TD0njLXvVc//A3BxIx77Cc5xdfm5b4YeqwOTQrt7HhidFLphuPtWd78rfNwHbGDi+RnPAa5z9xF3/z2wkfLvqdGcA1wTPr4GOLdi+Te87DfAbDNbnEB8cTsdeMTdJxpsd8Yfe3e/DdhTtXiyx/pVwM3uvsfd9wI3A2dMefBHaKx9d/f/dvdi2PwN5dkuxhXu/yx3/42Xzzbf4KnfV10b59iPZ7z/12fkOWGifQ97nd4AXDvRNmbqsZ/gHFeXn/tmSKyaalJoM1sBnAzcHi5aE3aFXj3aTUpj/k4c+G8zu9PMLgiXLXT3reHjbcDC8HEj7j/AeUT/sDbLsYfJH+tG/T38JeVv6qNWmtlvzexnZvaScNkSyvs7qhH2fTL/rzfisX8JsN3dH65Y1pDHvuocV5ef+2ZIrJqGmXUC3wfe7+69wJXAscBJwFbKXcWN6sXufgpwJvAeM/vDyifDb2cNewusmeWAs4F/Dxc107GPaPRjPR4z+yhQBL4VLtoKLHP3k4EPAN82s1lJxTeFmvb/9QpvIvqlqiGP/RjnuAPq6XPfDInVIU0KPdOZWZby/3DfcvcfALj7dncvuXsA/AtPXfJpuN+Ju28Jf+4Arqe8r9tHL/GFP3eEqzfc/lNOKO9y9+3QXMc+NNlj3VC/BzP7c+DVwP8JTzCEl8B2h4/vpFxX9HTK+1l5uXBG7/th/L/eaMc+A/wJ8J3RZY147Mc6x1Gnn/tmSKzuAI4zs5Xht/rzgBsTjilW4fX1rwEb3P3zFcsr64ZeC4zeTXIjcJ6ZtZjZSuA4ygWNM5KZdZhZ1+hjysW891Hez9G7Ps4Hfhg+vhF4a3jnyAuA/RXdyTNV5Btrsxz7CpM91j8GXmlmPeGlo1eGy2YcMzsD+BBwtrsPViyfb2bp8PExlI/1pnD/e83sBeHfjrfy1O9rxjmM/9cb7ZzwcuABdz9wia/Rjv145zjq9XMfdzV8Pf6jfIfAQ5Sz9o8mHc8U7N+LKXeB3gPcHf47C/gmcG+4/EZgccVrPhr+Ph5kBtwVcpD9P4bynT2/A9aPHmNgLnAL8DDwP8CccLkBXw73/15gddL7cIT73wHsBrorljXssaecQG4FCpRrJN52OMeacj3SxvDfXyS9X0ew7xsp142Mfva/Eq77uvDzcDdwF/Caiu2sppyAPAJcQThYdL3/G2f/J/3/+kw8J4y17+HyrwPvrFq3oY4945/j6vJzr5HXRURERGLSDJcCRURERKaFEisRERGRmCixEhEREYmJEisRERGRmCixEhEREYmJEisRERGRmCixEpnhzOwMM3vQzDaa2dqk4xERaWYax0pkBgtHV34IeAXlQQPvAN7k7vcnGpiISJPKJB2AiByRU4GN7r4JwMyuA84Bxk2sctbirXRMU3gyXYYZIO8jlnQcIs1OiZXIzLaE8nQmo54Anj/RC1rp4Pl2+pQGJdPvdr8l6RBEBCVWIk3BzC4ALgBopT3haEREGpeK10Vmti3A0RXtpeGyCHe/yt1Xu/vqLC3TFpyISLNRYiUys90BHGdmK80sB5wH3JhwTCIiTUuXAkVmMHcvmtka4MdAGrja3dcnHJaISNNSYiUyw7n7TcBNScchIiK6FCgiIiISGyVWIiIiIjFRYiUiIiISEyVWIiIiIjFRYiUiIiISEyVWIiIiIjFRYiUiIiISEyVWIiIiIjFRYiUiIiISE428LiL1wSzadp+a14iITCH1WImIiIjERImViIiISEyUWImIiIjERDVWIjI9quqhLJ2eeP2xng+qaqg8iDZLparnVXMlItNLPVYiIiIiMVFiJSIiIhITJVYiIiIiMVGNlYgcuerxpMZapapmynK5aHvl0ZF2sbu1ZhuZ3QPRBft6I81g955Iu6bmCqam7ipVtW9V++qFfPzvKSJ1ST1WIiIiIjFRYiUiIiISEyVWIiIiIjFRYiUiIiISExWvi8hBWTZaaE6qarDPqkL0VPesmm2MHLcw0t5zQkukvf9Fw5F25ve1xettOzoi7QV3RtvZtqrXpGq/Owaz2iNtK0QL3K03WiDvbdE4y8FVFadXvU+qfzDSLm3ZVrMJFbSLNCb1WImIiIjERImViIiISEyUWImIiIjERDVWIhKRnlVbH2Xz5kTa3pKNtHe+cF6kvedZtYNwHv2saJ3R54+9MdKen47WNl1/4sk12/jFrmMj7YePiQ4qmlsanZR5dme01gngDxY8EGmnLBrrr3asjLS3bu+u2YYPRP90tuyMtpfcFq39ah1jUNLSlq3RbRaLNeuIyMyjHisRERGRmCixEhEREYmJEisRERGRmKjGSkQiSr29Ncse/+tnRdr52dFapuefGq1bOr5ze802/qLnfyPtZZnOSHswiI4N9equ39VsY3+xLdJe/qLopMuzMtGxsE6fdX/NNo7JRl/TF0TrxU6btSHS3rxsbm0cpehYWOv7F0faDz7yzEi75b6Rmm1g+l4r0oj0yRYRERGJiRIrERERkZgosRKZAczsajPbYWb3VSybY2Y3m9nD4c+eJGMUERHVWInMFF8HrgC+UbFsLXCLu19uZmvD9oen4s1HjonWLq1aHh2D6Yy590baT8/V1lgtTI8x516Ffi9E2t/d98Kada5/4DmRdrArus1lJ0Tfd8vQ7JptbNofrZl6wcJHo9v06DyIf9C1sWYbf9T+cKTdV4rOUfi7ORPPpQjgpVLNMhGZ+dRjJTIDuPttwJ6qxecA14SPrwHOnc6YRESklhIrkZlrobuPdh1tAxYmGYyIiCixEmkI7u5A7bwpITO7wMzWmdm6AmPc+i8iIrFQYiUyc203s8UA4c8d463o7le5+2p3X51l4lonERE5fCpeF5m5bgTOBy4Pf/5wqt6o+3+jxdmtx0QLzQeDaLK2MD1Us40M0UE1Sx4dZPQ7vasi7e/+5A9qttH1SPS7YGYo2kk3tC46UOeTu+bXxtEe3caPn7Ug0vZVfZH2q06JFuYDdKSise/MRwc7rRrHFNJjfIet2n8RaQzqsRKZAczsWuDXwPFm9oSZvY1yQvUKM3sYeHnYFhGRBKnHSmQGcPc3jfPU6dMaiIiITEg9ViIiIiIxUY+ViBzU/LsGIu3HzpwTaW+f1R1pD3p0QmWAfo/ejXhfPlqXddVDL4q0V95Ye/dibvPe6AKvuhFyKDqQqXdG67oAvDX6vn1Lo/syb87+SHtJOtoG6KqaQPlZHU9G2g/eHZ202ttqbxhId8+KtEv7at9HRGYe9ViJiIiIxESJlYiIiEhMlFiJiIiIxEQ1ViJyUNlt+yLtkVuXRNq/OOvYSPsZbVtqtlEiOkHyxZvOjbRTP50daVs+WtcFQKEYafr+3ujz6ararkJ0vC2AVHu07qplb0+k3ZWN1nYtTI+xDYu+z3/teGakXew4+HfWYKB2rC8RmfnUYyUiIiISEyVWIiIiIjFRYiUiIiISE9VYichBBbv2RNrpkWiNVaEUrTn6xpO18/wt64iOQbV5XXQbx/wqOkdfajBfG8fuaBzBcLQeKtUWndPQsrV/4rwrWmM1PNci7dcs+F2k3efR5wF2FqPLNjy4NNJeNlw1vlaq9jusl0o1y0Rk5lOPlYiIiEhMlFiJiIiIxESJlYiIiEhMlFiJiIiIxETF6yJyUEFftLB88bUPRNpb0idE2o+fXDuB8sbHV0Ta3Y9Gny+1RAvgU49GC9UBPB8taLfqAUGrCsKtq7NmG/3Hzo62lweR9gkt0QmVnyx21Wzje3ueF2nPeiD6p7S9KnbbF/39QW2hfTAwxoCoIjLjqMdKREREJCZKrERERERiosRKREREJCaqsRKRSQuqJj9ectO2SLt4R21dUrEzOqhm2/poLZNX1Rh51YTLY0pVDd5ZNRCnDw/XvqQQHbxz2TOisT8wclSkXfCqOi7gpvXPirSXPxCdqNme2BqNI6gaMBQIhmpjE5GZTz1WIiIiIjFRYiUiIiISEyVWIiIiIjFRjZWITFr1BMK+OVovldnZUvOajEW/xwVDQ9FteLQOyax28uOaWqWgqg6r6vnUrNpar93PzEbax7RE49hVNW7V9ZufU7ON+T/JRdpt6x6KxpmP1lxV72t5pdq6KxGZ+dRjJSIiIhITJVYiIiIiMVFiJSIiIhIT1ViJyORV1QcFI1VzA1a3D4FlorVPQekQxrGq3ka66rtie1vNOsPzorGf2vNopN2dHoy0+4dr68UWPxYdg8pHonMY1sxpWLVvAF4sVC1QzZVII1CPlYiIiEhMlFiJiIiIxESJlYiIiEhMlFiJiIiIxETF6yJy5A6l8HqMAT8jm6gq5rZ07eTH1QOEpnLRonBrjRaa7z95Yc025p+8PdI+vjU6YfJvB5dH2tlbumu2kXvwkUi7VD3YadUAqtgYvx8Vq4s0JPVYiYiIiMREiZXIDGBmR5vZrWZ2v5mtN7P3hcvnmNnNZvZw+LMn6VhFRJqZEiuRmaEI/I27rwJeALzHzFYBa4Fb3P044JawLSIiCVGNlcgM4O5bga3h4z4z2wAsAc4BTgtXuwb4KfDhBEI8uOqaolRtDdXBpKpqqKylavDO+XMizZ0n1353PG3O1pplla69d3WkvWLDGIOdtkQnYcaq36eqxsqDCd9TRBqHeqxEZhgzWwGcDNwOLAyTLoBtQG21toiITBslViIziJl1At8H3u/uvZXPubsDY95qZmYXmNk6M1tXYPLTzYiIyKFRYiUyQ5hZlnJS9S13/0G4eLuZLQ6fXwzsGOu17n6Vu69299VZaue+ExGReKjGSmQGMDMDvgZscPfPVzx1I3A+cHn484cJhHd4quuOquuUxhjHqkYqOjZWYfGsSDu/sHYi52IQ3e43t74w0m5bH5242YLohMsA3j8QbVePW1XzAo1ZJdIslFiJzAwvAt4C3Gtmd4fLLqScUH3XzN4GPAa8IZnwREQElFiJzAju/gtgvKHLT5/OWEREZHyqsRIRERGJiXqsRKQuWFW9FGPULVXXMllba6Q9PCc6vlTLk7V1WuuXLIq0d+7uirQ7q0qqbKz6KNVUicg41GMlIiIiEhMlViIiIiIxUWIlIiIiEhMlViIiIiIxUfG6iMwYlosWp1tnR6QdVP1FG1mar9lG/3B05PlMLlqIXohukkJ77Z/JbBAtTq8uvNecyyLNSz1WIiIiIjFRYiUiIiISEyVWIiIiIjFRjZWITA8bb0aeMq+qW0pVDf4JYIsXRNqFBdFJl/c9rWpAUK8dyPNpc3dF2g9sj24ziJZxke+uHWS0Y25PNNaqGqtgYCgaRqG21ktEGpN6rERERERiosRKREREJCZKrERERERiohorEUmEpaO1S9bWFmmnOtprXuPZ6J+snSdFB50aXF6MtJcvi9ZTAWwbiE66nE5HB50a7o62M8O1g1INPCNal9X+cNW+5LdF2qqxEmke6rESERERiYkSKxEREZGYKLESERERiYlqrERkenh0nKrqcau8ry/STlXNAwjQ+8w50QXVXw1T0W1u29dFtdmd0TGmhp7sjLRbd0Y32ndU7ffPo67fFGkHe/dF28PDNa8RkeagHisRERGRmCixEhEREYmJEisRERGRmCixEhEREYmJitdFJBlB7QTJlYpbt9Us6/hedNmseXMj7cX/Hh2os7R9x0HDmPXCaJG8p6MTKqd+cXdtbAfdqog0K/VYiYiIiMREiZWIiIhITJRYiYiIiMTEvGrQPhFpbGa2E3gMmAfUzlJcf2ZKnJBsrMvdfX5C7y0iISVWIk3KzNa5++qk4ziYmRInzKxYRWRq6FKgiIiISEyUWImIiIjERImVSPO6KukADtFMiRNmVqwiMgVUYyUiIiISE/VYiYiIiMREiZVIEzKzM8zsQTPbaGZrk45nlJldbWY7zOy+imVzzOxmM3s4/NmTZIxhTEeb2a1mdr+ZrTez99VrrCIyvZRYiTQZM0sDXwbOBFYBbzKzVclGdcDXgTOqlq0FbnH344BbwnbSisDfuPsq4AXAe8LfYT3GKiLTSImVSPM5Fdjo7pvcPQ9cB5yTcEwAuPttwJ6qxecA14SPrwHOnc6YxuLuW939rvBxH7ABWEIdxioi00uJlUjzWQJsrmg/ES6rVwvdfWv4eBuwMMlgqpnZCuBk4HbqPFYRmXpKrERkxvDybcx1cyuzmXUC3wfe7+69lc/VW6wiMj2UWIk0ny3A0RXtpeGyerXdzBYDhD93JBwPAGaWpZxUfcvdfxAurstYRWT6KLESaT53AMeZ2UozywHnATcmHNNEbgTODx+fD/wwwVgAMDMDvgZscPfPVzxVd7GKyPTSAKEiTcjMzgK+AKSBq939U8lGVGZm1wKnAfOA7cAlwA3Ad4FlwGPAG9y9usB9WpnZi4GfA/cCQbj4Qsp1VnUVq4hMLyVWIiIiIjHRpUARERGRmCixEhEREYmJEisRERGRmCixEhEREYmJEisRERGRmCixEhEREYmJEiuRGc7MzjCzB81so5mtTToeEZFmpnGsRGYwM0sDDwGvoDyZ8h3Am9z9/kQDExFpUpmkAxCRI3IqsNHdNwGY2XXAOcC4iVXOWryVjmkKT6bLMAPkfcSSjkOk2SmxEpnZlgCbK9pPAM+f6AWtdPB8O31Kg5Lpd7vfknQIIoISK5GmYGYXABcAtNKecDQiIo1LxesiM9sW4OiK9tJwWYS7X+Xuq919dZaWaQtORKTZKLESmdnuAI4zs5VmlgPOA25MOCYRkaalS4EiM5i7F81sDfBjIA1c7e7rEw5LRKRpKbESmeHc/SbgpqTjEBERXQoUERERiY0SKxEREZGYKLESERERiYkSKxEREZGYKLESERERiYkSKxEREZGYKLESERERiYkSKxEREZGYKLESERERiYlGXheRZJhVtau+53kw+W26H348IiIxUI+ViIiISEyUWImIiIjERImViIiISExUYyUi06OqpspyuWg7nZ5wfQAvFqPtQrFqhdLhx3ckqmOtrvUaY19qqD5MpCGox0pEREQkJkqsRERERGKixEpEREQkJqqxEpEjZpmD/ympqanKZSPt/EnHRtqpkdp6qczu/kjbt+6ItIP+6PPTVrdUNQZXqq0lGkY+f9BNeKlqf1VzJTIjqcdKREREJCZKrERERERiosRKREREJCZKrERERERiouJ1ETkoy0YLz1NtrdHnO9ojbe+MtgF6T5wfaQ8sig4Iuu+kQqTd8mT0PQC6H4lud95t0dccShE9VetYJj3OiqOB5GoWeUdbpJ1f0BHdZu9IpJ16dGvtNgYGo+3q4nURmZHUYyUiIiISEyVWIiIiIjFRYiUiIiISE9VYiUhEdT0VgD3zaZG2B0GkveuUnkh793NqB7dc/IzoYJ4fXPmzSPuEXLQO6YH84ppt/NfuZ0fav3re8ZF2bu+SSDuIjkEKQKE7Wstk7VW1Tf1VNVizawf3TKWi+1cciNZpzf/lrEi7ZXlnzTa6bn0o+j7VE0xXtUVkZlCPlYiIiEhMlFiJiIiIxESJlYiIiEhMVGMlIhFeqK0p2vSG7ki7sDi6zp+ceHukvXU4uj7AJ5b+KNJenI7WcqXNIu1jMptrtrEiuzPSPvOV90bavx+JjpW1NLenZht5j/7Z21XoirRbU9GxsRZm99dsY18pOp7WzTtXRdr37V8ZaT/t2qrJoamdmFk1VSKNQT1WIiIiIjFRYiUiIiISEyVWIjOAmV1tZjvM7L6KZXPM7GYzezj82TPRNkREZOqpxkpkZvg6cAXwjYpla4Fb3P1yM1sbtj88FW9emBet/+nqic5zd3z7tkj7Vd3R2ieAhenon5v2VLTGquDR8aT2VY2VBfBIfkGk/a+PvSTSPq47WoP1P9tOqNlGMYh+n8ymo+87t3Ug0n7DwjtqtnFWx4ZI+5Zd0ffJ9h78O6tqqkQak3qsRGYAd78NqK7EPge4Jnx8DXDudMYkIiK1lFiJzFwL3X10uPJtwMIkgxERESVWIg3B3R2onUcmZGYXmNk6M1tXYGQaIxMRaS5KrERmru1mthgg/LljvBXd/Sp3X+3uq7O0TFuAIiLNRsXrIjPXjcD5wOXhzx9O1Rst+ml0kuHn/vWmSHtrfnakfVZHdIJhgKxNnNANenTAzN/lF9Wsc9Wjfxhpb78nevVz8KHoa3L9tZ14rbuiA4BuPzUa1+ZnDkXaa476Sc02CljNskqpqrr0fE9rzTq5UqlmmYjMfOqxEpkBzOxa4NfA8Wb2hJm9jXJC9Qozexh4edgWEZEEqcdKZAZw9zeN89Tp0xqIiIhMSD1WIiIiIjFRj5WIHFTPnbsi7Z9uflqkfeaK+yPt2qE9YdijhUeDQbTW6efD8yLtD974ZzXbWP6f0dc8bfe+SDu1Pzq4J6XaSIK5syLtXG+0xmrRwt2R9vx01TaBLovWbh3V1htpP7p33Bs0n4q1syMa6r7ayZ5FZOZRj5WIiIhITJRYiYiIiMREiZWIiIhITFRjJSIHty9aQ9Rxw7GR9r1/flSk/fOO5TWbeHbLlkh7U2F+pP2BX74x0j72htoR4nObo/VPvmdfpB14tLbJ0rXfHW04ut1i6+xI+/QFD0ba89O1dVqpqnGsHh2YE2kPLImuv+in0d8fQDA0XBVY1dhYfvA6LRGpP+qxEhEREYmJEisRERGRmCixEhEREYmJaqxE5KCC3Xsi7WJrtMaqEETnErx266k12/h3i9YqbdgWnefv6VdEa59Sj22v2Ub1WE9eNd9eKpeNtIN8bZ2SLT+qZlmlVW3RWrDSGLVOvxqJzkl4/33LIu3Z0U3guTH+1AZV21VNlUhDUI+ViIiISEyUWImIiIjERImViIiISEyUWImIiIjERMXrInJQXoxOoLzg2vsi7W25Z0favcfUDqrZuTn6PW7Fr/sj7fT2fZH2WJMSe7FQs2yiOC1T+yeu1JGLtAdWRAvg2y1aRP/z4arRPoHrtkWL87seiRbvt++IbnMs1YOX+sS7JiIzhHqsRERERGKixEpEREQkJkqsRERERGKiGisRmbxCtCBo/m8HI+2562u/s2X2RWuX7MHfR9qlqsE+8do6rYOpHjAUG2MS5mJ0u6k50bjuGz460n58JDrBMsBv718ZaS9+MrrN7ru2RV9QPeEyUCpNfv9EpP6px0pEREQkJkqsRERERGKixEpEREQkJqqxEpFJqx4vKnPvpugK6ei4TuUXRWuKSsNVNVcpq1r9ECYlrp642KLbqB4rCmBwcVuk3d21L9LuK7VG2j/e9IyabXRuiv7pnH33jmhYg0ORdvUk1jBGPZiINAT1WImIiIjERImViIiISEyUWImIiIjERDVWIjJp1TVWpf6BQ3jRQcZtSkfn8KOUP/g2a2qqorVdqYXza16y+5nRP3vnLH0g+nyhI9IuFmrrxRbdUzWx39ZojVUwEq0fG2s8LayqPsxVcyXSCNRjJSIiIhITJVYiIiIiMVFiJSIiIhITJVYiIiIiMVHxuogcueAwCq9T0aJwL0QL4qsL0aF20NBUW3QwT+uMFp5vf8XSmm1kTt0baZ/YvjnSHvZspH3br59Xs432ex+NtEtVxeqeryq8H6t4/XB+ZyJS99RjJSIiIhITJVYiM4CZHW1mt5rZ/Wa23szeFy6fY2Y3m9nD4c+epGMVEWlmSqxEZoYi8Dfuvgp4AfAeM1sFrAVucffjgFvCtoiIJEQ1ViIzgLtvBbaGj/vMbAOwBDgHOC1c7Rrgp8CHpz3AqoE6ayZHPpRNHMIkzJaN/smqrqnqf+GKSHvfy6KTIQO8ZeXvIu2jstGaq0seOSfS7tw6Ri1U9QTK1bHW7P9BBkcVkYahHiuRGcbMVgAnA7cDC8OkC2AbsDCpuERERImVyIxiZp3A94H3u3tv5XPu7sCYXUVmdoGZrTOzdQVGxlpFRERioMRKZIYwsyzlpOpb7v6DcPF2M1scPr8Y2DHWa939Kndf7e6rs7RMT8AiIk1INVYiM4CZGfA1YIO7f77iqRuB84HLw58/TCC8WtU1V1Bbd1Q1jpMTHbequp6qvNmq7c6eFWn2Hh19zcI5u2q2sbfYHmn/05aXR9pbf31UpL1oMDq+FoCPRMep8mKhZp3oCpOvORORmUmJlcjM8CLgLcC9ZnZ3uOxCygnVd83sbcBjwBuSCU9ERECJlciM4O6/AMboBgLg9OmMRURExqcaKxEREZGYqMdKRI5cdQ3RWDVWYy2rfLpqHKuaeiqAVPS7oA1XzdFXNb3gjrtrR5/4yQnR4v2+3dGxsHqerHrLYm19lBer6q5UQyUiIfVYiYiIiMREiZWIiIhITJRYiYiIiMREiZWIiIhITFS8LiLxs4N/Z6sZALRqYmMfoyA8lctG1+loi7TbdkUnOx6eX1sA37ejM7ogqJr8uaqIPrezdiLn6sJ6y0T3paa4XUSahnqsRERERGKixEpEREQkJkqsRERERGKiGisROXLVg3lWTbAMtXVIBNEaKsvlou2uqloooLQ8OuDnvhOi6+xdFV2/eFR0AFGApy3ZGWn3jUQHDN23Y36kvefE6ETPAPPyi6OxPvpEzTqVVHMl0jzUYyUiIiISEyVWIiIiIjFRYiUiIiISE9VYiciRO4RJiL26pqpqwmSrGqPKUrXf+6wQHaeqd0W0tit1TF+kvWrBrppt9OejNVVdLdE6rB090ffI9ddsgp2nzom05+/YE2kHg4O1LxKRpqAeKxEREZGYKLESERERiYkSKxEREZGYqMZKRKZH9dhWVXPylfbtj7TT6aoiLGD4qPZI2zPRuq1UKtp+ZOe82m3sa420bTD6Pm3bot83+5bVbIKj/vXeSLvU11e7kog0JfVYiYiIiMREiZWIiIhITJRYiYiIiMREiZWIiIhITFS8LiKJONjExKXde2qWtfxndNmK/4kO9lk9kXNwCEXlmRVjVKdXKD76eM2yYIz1RERAPVYiIiIisVFiJSIiIhITJVYiIiIiMTE/hMlTRaRxmNlO4DFgHlA7S3H9mSlxQrKxLnf3+Qm9t4iElFiJNCkzW+fuq5OO42BmSpwws2IVkamhS4EiIiIiMVFiJSIiIhITJVYizeuqpAM4RDMlTphZsYrIFFCNlYiIiEhM1GMlIiIiEhMlViJNyMzOMLMHzWyjma1NOp5RZna1me0ws/sqls0xs5vN7OHwZ0+SMYYxHW1mt5rZ/Wa23szeV6+xisj0UmIl0mTMLA18GTgTWAW8ycxWJRvVAV8Hzqhatha4xd2PA24J20krAn/j7quAFwDvCX+H9RiriEwjJVYizedUYKO7b3L3PHAdcE7CMQHg7rcB1bMvnwNcEz6+Bjh3OmMai7tvdfe7wsd9wAZgCXUYq4hMLyVWIs1nCbC5ov1EuKxeLXT3reHjbcDCJIOpZmYrgJOB26nzWEVk6imxEpEZw8u3MdfNrcxm1gl8H3i/u/dWPldvsYrI9FBiJdJ8tgBHV7SXhsvq1XYzWwwQ/tyRcDwAmFmWclL1LXf/Qbi4LmMVkemjxEqk+dwBHGdmK80sB5wH3JhwTBO5ETg/fHw+8MMEYwHAzAz4GrDB3T9f8VTdxSoi00sDhIo0ITM7C/gCkAaudvdPJRtRmZldC5wGzAO2A5cANwDfBZYBjwFvcPfqAvdpZWYvBn4O3AsE4eILKddZ1VWsIjK9lFiJiIiIxESXAkVERERiosRKREREJCZKrERERERiosRKREREJCZKrERERERiosRKREREJCZKrERERERiosRKREREJCb/P+3kRJEWDMAnAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 720x720 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x720 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig=plt.figure(figsize=(10,10))\n",
    "LR = 3e-5\n",
    " \n",
    "XreptrainlabelonehotTot  = []\n",
    "XreptrainDataTot = []\n",
    "\n",
    "\n",
    "for cl in range(5):\n",
    "    #epochs = int(epochs/(cl+1))\n",
    "    # extract the dataset\n",
    "    #for jj in range(cl+1):\n",
    "    classifier = classifierNN(2*cl+2,yin)\n",
    "    if cl == 0:\n",
    "        indCL = 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[indCL,:2*cl+2] \n",
    "        dataX_train1CL =  dataX_train1[indCL,:] \n",
    "    else:\n",
    "        indCL = 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",
    "         \n",
    "        \n",
    "        xreptrainlabelonehotExtended = labelX_train[indCL,:2*cl+2] \n",
    "        extended_memory_label = np.concatenate([xreptrainlabelonehot,np.zeros([xreptrainlabelonehot.shape[0],2])],axis=1)\n",
    "        labelX_trainCL = np.concatenate([xreptrainlabelonehotExtended,extended_memory_label],axis=0)\n",
    "        dataX_train1CL =np.concatenate([ dataX_train1[indCL,:],xreptrainData ],axis=0)\n",
    "\n",
    "        \n",
    "\n",
    "    labelX=K.placeholder(shape=(None,2*cl+2),dtype='float32') #labels of input images oneHot\n",
    "    theta=K.variable(generateTheta(nofprojections,zdim),)#Define a Keras Variable for \\theta_ls\n",
    "    #swLoss=sWasserstein(encoderX(imgY),encoderX(imgZ),theta,Cp=labelX,Cq=labelZ)\n",
    "    \n",
    "\n",
    "    #autorec = K.mean(K.square(imgX-decoderX(encoderX(imgX))))\n",
    "    autorec = K.mean(K.square((imgX-decoderX(encoderX(imgX)))))\n",
    "    #autorec = K.mean(K.binary_crossentropy(imgX,decoderX(encoderX(imgX))))\n",
    "    \n",
    "    \n",
    "\n",
    "\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",
    "\n",
    "     \n",
    "    myLoss=  discriminationLoss+lamda*autorec\n",
    "    params=encoderX.weights + decoderX.weights + classifier.weights\n",
    "\n",
    "    \n",
    "    \n",
    "    #loss=[]\n",
    "    \n",
    "    \n",
    "    if cl == 0:\n",
    "        opt = Adam(lr=1e-5,decay = 1e-5,amsgrad=True)\n",
    "        updates = opt.get_updates(myLoss,params)\n",
    "        train = K.function(inputs=[imgX,labelX],outputs=[autorec],updates=updates)\n",
    "        LR=1e-5\n",
    "        \n",
    "    if cl >= 1:\n",
    "        LR = LR#/3\n",
    "        opt = Adam(lr=LR,decay = 1e-5,amsgrad=True) \n",
    "        #opt = Adam(lr=1e-5,decay = 1e-3,amsgrad=True) # very important\n",
    "        updates = opt.get_updates(myLoss,params)\n",
    "        train = K.function(inputs=[imgX,labelX],outputs=[autorec],updates=updates)\n",
    "        #train = K.function(inputs=[imgX,imgY,imgZ,labelX,labelY,labelZ,theta],outputs=[lamda*autorec,discriminationLoss,swLoss],updates=updatesT)\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",
    "        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_test1[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(4, 1, 1)\n",
    "            plt.plot(np.asarray(loss))\n",
    "            \n",
    "            plt.subplot(4, 1, 2)\n",
    "            plt.plot(np.asarray(testXperf))\n",
    "            \n",
    "            imageind = np.random.randint(trainDataX.shape[0])\n",
    "            \n",
    "            plt.subplot(4, 1, 3)\n",
    "            plt.imshow(np.reshape(decoderX.predict(encoderX.predict(trainDataX[imageind:imageind+1,:])),[28,28]))\n",
    "\n",
    "            plt.subplot(4, 1, 4)\n",
    "            plt.imshow(np.reshape(trainDataX[imageind,:],[28,28]))\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",
    "        ### pseudo-datapoints\n",
    "    if cl<4:\n",
    "        labelX_train_EXP = np.argmax(np.squeeze(labelX_trainCL),axis=1)   \n",
    "        tempvar = labelX_trainCL\n",
    "        \n",
    "        \n",
    "        gmm = MgGMMfit(encoderX,dataX_train1CL,labelX_trainCL,2*cl+2)\n",
    "        \n",
    "\n",
    "        GMMs.append(gmm)\n",
    "\n",
    "  \n",
    "  \n",
    "        # GMM is used as a generative model so task 1 data is not saved\n",
    "        xnofsample = (2*cl+1)*4000\n",
    "        xreptrainDataencoded, xreptrainlabel = gmm.sample(xnofsample)\n",
    "\n",
    "\n",
    "\n",
    "        xtemper = np.zeros([xreptrainDataencoded.shape[0], xreptrainDataencoded.shape[1]])\n",
    "        xtemper  = xreptrainDataencoded\n",
    "\n",
    "\n",
    "        xreptrainData = decoderX.predict(xtemper)\n",
    "\n",
    "        xreptrainData = xreptrainData.clip(min=0)\n",
    "        xreptrainData = xreptrainData.clip(max=1)\n",
    "        \n",
    "#         xreptrainData[xreptrainData>.5]=1\n",
    "#         xreptrainData[xreptrainData<.4]=0\n",
    "\n",
    " \n",
    "        xreptrainlabelonehot = keras.utils.to_categorical(xreptrainlabel)\n",
    "\n",
    "        xnofsampletest =  (2*cl+2)*1000\n",
    "        xreptestDataencoded, xreptestlabel = gmm.sample(xnofsampletest)\n",
    "\n",
    "        xtemper1 = np.zeros([xreptestDataencoded.shape[0],xreptestDataencoded.shape[1]])\n",
    "        xtemper1 = xreptestDataencoded\n",
    "\n",
    "        xreptestData = decoderX.predict(xtemper1)\n",
    "\n",
    "        xreptestData = xreptestData.clip(min=0)\n",
    "        xreptestData = xreptestData.clip(max=1)\n",
    "\n",
    "\n",
    "  \n",
    "        xreptestlabelonehot = keras.utils.to_categorical(xreptestlabel)\n",
    "    \n",
    "    \n",
    "        XreptrainlabelonehotTot.append(xreptrainlabelonehot)  \n",
    "        XreptrainDataTot.append(xreptrainData)  \n",
    "\n",
    "        # model perforamnce on generated dataset\n",
    "        perd_label_Sample = classifier.predict(encoderX.predict(xreptestData))\n",
    "        print('model perforamnce on generated dataset')\n",
    "        print(100*float(sum(1*(np.argmax(perd_label_Sample,axis=1)==np.argmax(np.squeeze(xreptestlabelonehot),axis=1))))/perd_label_Sample.shape[0])\n",
    "\n",
    "\n",
    "\n",
    "                                              "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7fdd982aa250>]"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXcAAAD4CAYAAAAXUaZHAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAAAot0lEQVR4nO2deXRkV33nP7/atC+9qPdu92K3jY1XGrBj8EBMwDgkdiAhJBxwiIMnCSRhyABOmBkyhzPnQCaTnSHHARJnhiEYh4ydDeM4BjJJMLTttt3utt3ttk23rJbUm7Yqqareu/PHe0+qlqVu1SJVvff7fc7RUemppPq99+791q++93fvFecchmEYRrJINTsAwzAMo/GYuBuGYSQQE3fDMIwEYuJuGIaRQEzcDcMwEkim2QEArF271m3fvr3ZYRiGYcSKRx999IRzbmCh37WEuG/fvp29e/c2OwzDMIxYISIvLfY7s2UMwzASiIm7YRhGAjFxNwzDSCAm7oZhGAnExN0wDCOBnFfcReRLIjIiIvsrjq0WkQdF5FD4fVV4XETkD0XksIg8KSLXLGfwhmEYxsIsJXP/c+CmecfuBB5yzl0EPBT+DPB24KLw6w7g840J0zAMw6iG89a5O+e+IyLb5x2+BXhT+Phu4FvAJ8Ljf+GCdYS/KyL9IrLROTfUsIgX4dRUkSOjk4xMzFD2HZ7vU/Ycnu8oej4nJmaWO4QV47pda7lu15pmh2EYRgtT6ySm9RWCfRxYHz7eDByteN6x8NgrxF1E7iDI7tm2bVuNYcB3j5zkV7/yOCNLEG+Rml+mZXAOvnPoBP/3Q9c3OxTDMFqYumeoOueciFS944dz7i7gLoA9e/bUvGPIH/3TIUqez2/efAm7BrrZvKqDTCpFJiWkU0ImLaRFWNPdRjoVf3X/wJ99j5NTxWaHYRhGi1OruA9HdouIbARGwuODwNaK520Jjy0bzx6f4EcuXc8dN+xazpcxDMOIFbWWQt4P3BY+vg24r+L4+8OqmWuBseX028uez4nJIpv7O5frJQzDMGLJeTN3EfkKweDpWhE5BnwK+Axwj4jcDrwEvDt8+t8DNwOHgTzwgWWIeZai5wPQltVVrm/b3hqGcT6WUi3zM4v86sYFnuuAD9Ub1FKZKYXintEl7o2iWPY5ODTOoZFJ3nDhWjpyadqzKZwL3kDKvs9M2afk+aRFyKRTzJQ9utoyZFJCeyZNahnHMTzfJWKcxDCaQUss+VsrM+VI3NNNjmTlkCpLfg4OjbPv6Bn2vniaw6OTFIplnhuebFg8bZkUqzpzbOhrp6stzZHRKXYOdNGRzXBwaJw13TnaM2mOnJjiTL5IezZNJi2zA97D4zOkBK7Ztoq+jiwPPTNCRzZNJiVMzJTpyKbZvKqDT978Kt58ybqGxW0YSSfW4l4MxT1nmTsAvu/49nOj3LdvkOdHpxgaK3Bi8uzKmo5smqu39bOqM0cunSKbSVEolvl3uweYKfuMFUqczhdpz6RZ39tOezZFOpXi2ePjnCmUWN/bzr89f5KdA120Z9K8cHKKI6NTnJoqcjoPQ2PT5IsevR0ZBs8UODE5w2Wbepkpeexe38Nlm3oRCe6d7+DIieCNZmhsmqGxaQAKJY9rd65mZGKGrlyGpwbH+PN/fdHE3TCqINbiPlP2AH22jOOVpvs9e4/y8XufnP35yq39rO1u4x1XbGL7mk429ndw0bpudqztqjr7bzbv+KN/JmP2jGFURczF3Tx3gAMvj88K+y+9aRcffvOFdLXF+tYahlEnsVaAGYW2zEL566f/9gAA93/4eq7Y0r+i8RiG0ZrEXNwjW0bPgOp8vv/iKf7tyEn+04++KtHC3szqz6hqp1D0eOLYGcYKJfo6shwaCcYLXrWhhw197QyPT/PksTH+Yf9xfmjXGlKh/fXE0TNct2sNG/raeflMgXU97azqyrG2O8cTR8fIpIVNfR2UPJ+2bIpMKsVF67pZ1ZVr4lkbcSfW4q51QLWyzv3uf32R1V05fvb1ta/P0+rIgp9XamNypsyx03m62zLsO3qGF0anODw6yaUbezkyOkV/Z5bBMwW+eWCYV23s5cjIJBMz5apf53svnDrr54eeGVnkmYvzyZtfxQdv2Fn13xkGxFzcS16gcrm0LnGPKHk+335ulJtfvZHOXKxv5bJRLPv89ePH+NreY7x4Ms+JyYUXmLtv38uzj3vbM7x6Uy+Fks9V2/opFD3W97Zz4bpujp0ucNW2fgTo78yye30PL53MMzRWYFVnjumSx+t3rGFdbxue7yh5PvsHx+nvzDI6OcPI+DQHXh6npz07Wzk00NPGvxw+iXNw5dY+Tk4W+fWvPTFbSWQYtRBrRfDDFDZmxR91UXmue188zcR02UoE5/Hc8AR3fecIzx6f4KnBsdnjr9uxmvddewGru3MMj00zeKbAhr523nn1ZtIpQUQY6GmjM1vd5Kzd63vO+fs3XLT2vP/jNResPuvnz37jmSW/vmEsRKzFPbInNIl7JQ8/O0IunVqSeMQdt8Q1F+7bN8hH73kCz3dcuaWP9117AZdv7uPHrtxER07v2Iyhj1iLezTMllKm7pHOPfrSaa7c2kd3wssel3J7Pd/xsa89wdcfH+TyzX187mevYduaeC8o18g1hJxzDJ4psL63ndP5IsdOF7hicx/PDU8yXfZ49vgEuXSK1V05DgyNMz5dYmNvO/925CR7LlhNb0eGras7yYYW6MR0iVWdObat7iSTSjFZLHN8bJqpmTLt2TS713fPfhqq9pOQ0RhirQq+4szd9x0Hh8Z5956t539ywhmfLvGzf/pd9g+O86E37+Ijb9k9K0JxpZo27fuO50cn+dzDh/m7p4Zmx6I29LZzfHyaXDo1u8heLTzw9HDNfxuREuhpz1L2fKaKQZXbNdv6efb4BAM9bbx4Ms/qrhz/+/bXc+mm3rpfz4i5uM/aMg2spmh9gnN9eaxAvuhx8YZz+71Jx/MdH7x7LweHJvjY2y7ml9+0K3YzcOvh0ZdO85GvPs7RU4VX/G7zqg7SKeH1O1eTEuHeR48BcMPuAdZ05ejryDJd8tjQ186WVZ1k08KqzhyjEzNcta2fjmyapwbHEOD50SkuWtfNVLHM86NT9LRlOJ0vcnKyyMHj41x/4Vq2rwky+1wmxd89OcSJyRk83/HYD87Q15FlQ18HJydnmCp6XLW1HwdMFT36wqq3U1NF/vbJl03cG0S8xR19A6oRw+PBOiwb+9qbHElz+dazIzzywik+fctlvO+67c0OZ8V44cQUH71nH4//4AwAu9d3c+fbL+G121eTy6QWnPvxOz91ZdWvs6m/o6b43nHFpqqeP13yuOQ/f4NMzD9xtRLxFvfZzF0XDhgeD0r61vfqEPfF7OcvP/ID1vW08Z7XJa/OfzHP/eDQOO/6/L9S8nx+es9Wfv2tu1kX83bQnrXB7kYTb3EPv2vM3EfCzH1dT1uTI1l+Fru9R0/lefjZEX7lzRfG3mOfz2JWo+87PnbvE+SLHt/4yBu5ZINZGMbCxLpHzJXH6VH36I1sZGJm1iPVyt88+TLOwU8nMGtfjK89epT9g+N89l2XJ1PYbZuxhhFrcY/QmLkPj88w0N2musTsXw6f4JINPWyu0ReOG57v+OOHD3Pllj5+6jXJq5LS2I+Xk1iLezRDVV+du2N0coYBBZZMxPyEzjnHE0fHeO321Qv/QQJ55MhJjp4q8MEbdqp+UzeWRqzFXeuAKsB4oUSfFktmgTfvl8emmZwpszvBpaDzN2X55oFh2rMpbrxkfZMiMuJEvAdUFU5iik51Yrqkxo5YiOeGJwDYva67yZEsDwu16UdeOMVrLliV6GUUkuS4F4oe49MlRsZnKJQ8imWfoufh+eD5fvDdOa7Y3Mf2tV0Nf/14i3v4XdckpoCJ6TI97bG+fXVxKBL38yzalRQmpks8c3ycX/3hi5odyrLRir247Pm8fGaaQsljuuRxcGicQsnD8x0vnJjiTL7EQE8bJc9neHyGE5Mz5ItlZso+L53ML+k1Pn3rq03c5+MUrgoZoU3c52d0h4YnWdvdpmZDi2eOT+AcXLGlr9mhJBLngiUcDgxN8L0XTvLMUJA8PDU4Nrvj22K0Z1N0t2Xo78yxsa+dDb3tpFPCO6/ewpruHGu6crRlU+TSaXraM6RTQkqEdEpIp2Cge3nmKMRaHZL0Ea4ayr6jUPLobss2O5QVYaH37udGJtm9PpmWTETlIPKBl8cBuGyTiXu9FMs+33/xFIeGJzhyYorvPDfK0Nj0rIh35tKs6c6xsbeDd16zhVdv7qW7LUM2PbdDVjadIpdOtbRFFmtxR6PnLoGXB0Ej1IhzjsPDE/xUghdNm9+kj4xO0tOWYX1vsiuklqvM3fMd+46e5ivfO8oD+4/P7q6VTQuv3b6aK7b085oLVnHl1n4uWtediA3mY30GTumSv1GG0ZaNdbFTzYxOBItP7RpovE/Zqrx4Ms+2NZ2JXhRtOc7tmePjfOGfX+DBA8OMFUp0ZNO844qN/NCFa7hsUx8XrOlM7B7MsRZ3rUv+zpSijcGVinu4Vd5AT7zXU6mG42PTsV+ffiU5PDLBf/2bA/zzoRO0Z1P86OWbePMlA7zxwgH6OnXYmbEWd51L/s5l7poWW6rcienEZBGAtd3JHkytdChO54tctbW/WaHEBt93fP7bz/M733wWgLdeup5P3/pqNQvsVRJvcVe45K8gsxsvaMnc59/fk2HmvjrBlTKVFoVzjjP5Ev1dOjLOWil7Ph+/90m+/vggN1++gY/+yMVcmNB5EEsh3uKueIYqkFiv8HycyZeAZIt7JfmiR9HzVSwSN39W7lIZHp/m5/7s+xwcGueX37SLj73t4kSPTyyFeIt79EDpPdSSuc9nrBCIe0+7jkz2dD6woVYl3CuutRsXih6/cPdeXjo5xf987zXcfPnGhsYVV2It7lHqrs1zj9BaLTM+XaKnLZgMkmSiT6bRJ5V+BZl7LXzq/v08NTjGF96/h7dcauvuRNSlDiLyH0TkaRHZLyJfEZF2EdkhIo+IyGER+aqILFuL1LhZR+W5arFl5t/esUKJ3o5kZ7GVRJ9U+hSd81LZPzjGPXuP8d7XbzNhn0fN4i4im4FfBfY4514NpIH3AJ8Ffs85dyFwGri9EYEuRJTZaKtzj9Bqy4wXyqrEPa9o0lq1k5h+/x8P0due4RNvv2R5Aoox9apDBugQkQzQCQwBPwzcG/7+buDWOl9jUfxZW0YnWjL3+YwXSvQqWlcnXwxmUyZd3KvN0R77wWn+8eAwH3zjTnqVjL9UQ83i7pwbBH4H+AGBqI8BjwJnnHPl8GnHgM0L/b2I3CEie0Vk7+joaI0xRP+rpj+PPZo898qMbny6pMKiiCpH5pab0POGthQ+8/fPMNDTxs+/YUezQ2lJ6rFlVgG3ADuATUAXcNNS/945d5dzbo9zbs/AwEBNMWhc8vdsz12HuM8vadPguVeesiZbZqk8PzrJ9148xb+/YWci1oFZDupRh7cALzjnRp1zJeDrwPVAf2jTAGwBBuuMcVGc8kJ3zbaMhsw9ohAuN9HKKxA2iqVa7g88fRzAyh7PQT3i/gPgWhHplCC1uhE4ADwM/GT4nNuA++oL8fxotWVySjL3Skqez1TRU+Wx5otl0ikhl072/a7mE/gD+49z5dZ+Ninejex81OO5P0IwcPoY8FT4v+4CPgF8VEQOA2uALzYgzkViCL4r1fbE13kvxMR0MJzT16Hgo3jYvvNFj85sWv2My4jBMwWeODbGTZdtaHYoLU1dPcQ59yngU/MOHwFeV8//XfLrK1zyN8puMsqEPbrX40pmp1Y26ULRU2HJLJUH9geWzNsus7r2cxHrz3lal/wFSCkS98oz1Ti4mC96as53KXXuDx4Y5uL1Pewc0Lso2FKItbhv7Gvn9TtWq8rcI7Rl7hHT5UDcNS13nC96dGgog1xCkw52VDrDdbvWLH88MSfWLeaWqzZzy1ULltEnnrTCNzSA6ZIecY+S2JLnqxw8X4jnRycplDwu32x7yZ4PazFxI9T0dFqXuEcf12dK0UYlyW66lZUjnu/UflKbz/7BMQAu32Lifj6S3UMSjKbMvfJUNWXuEWXfV1MZdb713A+NTJJJCTvW6tk/t1ZM3GOKls4+H42eu5bMfSlneGR0km1rOskmvOa/EdgViilqxV2JLQNzM7DLvlN7v+dzZHSKnWutSmYpJL+HJIyoi2vr7JHnPmvLJHzphUorSkvmfj483/HSyTy7BsySWQom7jFFk7hXDi4WNHruniOdsq46eLpA0fPZaeK+JKzFxBRN4l5JZMtoWRETlGXu5xhPff7EJIBNXloienpIwtBULVPJTMkjl0mpmKEb6VzZ91WUvp6vSb8wOgVglTJLxMQ9ZkSLR+nN3D3aFWTtlXdXVeZ+DobHp2nLpFjTZRuFL4Xk95KEok3co/rn6ZKvym8Hq5aJGJ2YYaCnzVbHXCIm7jFFVSZXOYmp7KkTd02Z+7mmMI1OBuJuLA0T95iiwXNeiOmSR4cycQ8y9+R31fNt1jEyPsNAt4n7Ukl+i0kYUfPXksnNJ7BldDTbqLa/7Plq73cllrlXh45ekkC0LXNcOYmpTUHmXukrm+cerIx5aqpo4l4FJu4xJaOgNC6i8kyny/oGVFV57ovs1nFysghg4l4FJu4xRVvmHjGjpBSykrLv1Ne5j07MAJjnXgW6ekkCiDqA1o/p0yU91TJRDqspc1+M0clpwDL3ajBxjylaZ6hqGVCN7q5zDk9Jtcy5mM3cTdyXjO4WE2O0TeSIstiCoswdgqwd9FRHLbZBdiTua82WWTIm7jFFSV8HXrkTkyZxL4firsGGO9cZnpgs0t2WUXXv68XEPWZEHUDjgKpzjpmyr2ZANbJkALIKBlTPxVihRH9nttlhxAodvSSBaLRgZ8rhcr8asrdQy+cyd4U3vAIT9+rR3WJijDbPHadzc2xtnvtinMkX6e+w1SCrwcQ9pmiyZaI1R6KNOjStLVP2g3PW4LnD4guHnSmU6LPMvSpM3GNGlLEr6etnMZe562i2Dl2Z+7k+jY7lS/R3mLhXg45ekkA0Ze4R02U9tkx0d8uenmqZxXDOBZm7iXtVmLjHFG3a7nCztoyWzB0qMnfF1TL5oofnO3pN3KtCTy9JGJoy9+hUZ0Jbpi2T/Mw9Qlu1zEKTmCamywD0tGdWOJp4U1eLEZF+EblXRJ4RkYMicp2IrBaRB0XkUPh9VaOCNSrr3JsaRlMoekHmnlNS545T5rkvcnx8ugRAb7tl7tVQby/5A+AbzrlLgCuBg8CdwEPOuYuAh8KfjQZzvl1rkkgxrHPPpZMv7tHgorZqmYWYCMXdMvfqqLmXiEgfcAPwRQDnXNE5dwa4Bbg7fNrdwK31hWgshJJP6WcxK+5aMnd0Ze6LMT5ry1jmXg319JIdwCjwZyLyuIh8QUS6gPXOuaHwOceB9Qv9sYjcISJ7RWTv6OhoHWHoRNskJucqZqgqEndNa8tAMHA+n/FCkLn3dVjmXg319JIMcA3weefc1cAU8ywYF2yrsuC8BOfcXc65Pc65PQMDA3WEoYywjyvp68DcgKq2zN3hKjJ3Bee8SJuesMy9JuppMceAY865R8Kf7yUQ+2ER2QgQfh+pL0RjITRVy0TMKBpQtTr3OaxapjZq7iXOuePAURG5ODx0I3AAuB+4LTx2G3BfXREaC6JR3KPMvS2tpxTS6tyDaplMSlQtO9EI6n0r/BXgyyKSA44AHyB4w7hHRG4HXgLeXedrGAugTdsdMBPOUG1TNIlJW7XMwnXuJXraM+rGmeqlLnF3zu0D9izwqxvr+b/G4kQlkJoy9+icNZVCQiB0mqplFjvDiemy+e01oKOXJBAFff0VFMs+mZSQUnDy0Xt3VC2j6c18PhPTZXqtUqZqTNxjisbOXiz7KgZTK4kGVLNKPq0sxMR0ie42E/dq0dtiYo42/zHaYk9TjTvMee6aB1TzRY+unIl7tejqKQlAlNe5a8rcnZvL3DV47otRKHp05KxSplr09JSEodKW8fSIezSIPFcKmfzzXuzT6FSxTKeJe9Ukv8UkFI2JXLHsq6mUiShFtozGGx6SL3p0mi1TNbp6SoLQ5rlDkLlrG1jUVAq5GGbL1IaunpIAokke2myZaD9RTeLucJQ8RWvLEAycV1Is+5R9R6fNTq0aHS0mQUSNX2MiV/J8NTM1o/duT1G1zEL5SqEYzEq2zL16TNxjhh+JuxKRq6TsObIKRK6SkvKFw/KlYNEw89yrx8Q9ZoQWrLq1ZSCwZbSJXOS5a7KjKsmHmbtVy1SPzhYTYyJHUts2e84FlSOaRC6ocw9sGS3vafPXDTNbpnb09JSE4Cv03KPKIM936qpGyn5gRWmojlroDKPM3WaoVo+Je9xQWi0Dgf+cVlI1ElFWaEVVki8Gnrtl7tWjq6ckgChzV6jteL6vbkC17Dmyyt7QKimY514zeltNTNFc51729GWxZd8nregNbf5mHZEtY7swVY+Je8xQ6bmH39UNqBLYMlomMC00rlAoWeZeKzpaTYKISiE11rl7ijL3SOjKnq9uELmS6VDc203cq8bEPWa4Wc9dX4cv+fomMZV9p2J26mIUzJapGRP3mBFZkhqTOU+RRRFR9nSVf7p5le6FkkcmJarsuEZhVyxmzHnuejo8AM6pWlsG5jbI1rCWOyxc514oeZa114iOVpMgZj13PRo3t1m0orVlZgeRzXM3v71GTNxjhmbPPVhbRleT9cxzt8y9RnT1lASgtc4dolJIXeddUviGVonZMrWjt9XEFI117gCeczinZ9OKABfMylV0s+dPYiqUfLNlakRTT0kEGgdUhcBvBx2bVsDcOENJVW3/K49Nlzw6siZTtWBXLWZoXc+9rHQv0bLnq3lDW4hps2VqxsQ9bij13KN1zbVksRElz5FTUgq5ELY5du3obTUxRaMtA3PbzWmazOIczJQ92jJ6xO0Vm3WUPNotc68JPT0lIWgcUBURyr6uzD167y6WfXIZLd30lffWbJna0dJqEoNaz302c9d14rrE/ZVYnXvt6G01MWV2D1Vl6l6a9dx1Ndmi59OmVNydc0Gdu3nuNVF3qxGRtIg8LiJ/G/68Q0QeEZHDIvJVEcnVH6Yxi3LPXVMW64CZkq7MvbLOvej5+A7z3GukEa3m14CDFT9/Fvg959yFwGng9ga8hhGicW0ZCDo6oKZyREL/ecbTI+7z85XpYnDPzZapjbpajYhsAX4U+EL4swA/DNwbPuVu4NZ6XsM4G43VMkKwxgpALqPnvJ1zFMs+bUre0OYT7cJkmXtt1Ntqfh/4OOCHP68BzjjnyuHPx4DNC/2hiNwhIntFZO/o6GidYejBKR1Qjcil9XT0aOJWm1Jxi8S9I6fzza1ear5qIvIOYMQ592gtf++cu8s5t8c5t2dgYKDWMNShMXOvRFO1zExJlxUVMGe62y5M9ZGp42+vB35cRG4G2oFe4A+AfhHJhNn7FmCw/jCNCM2rQoKeAVWRYAITKDrneT+bLVMfNbca59xvOOe2OOe2A+8B/sk5917gYeAnw6fdBtxXd5TGLDonMc091jRDdaYcZu5KxH0+0ebYlrnXxnK0mk8AHxWRwwQe/BeX4TXUorXOPUJTzXdUIaTpnCuZtWWszr0m6rFlZnHOfQv4Vvj4CPC6Rvxf45VozNwrUZW5l3Rn7gXL3OtCZ6uJMbOeu1J11yJ0QoUto+gNrXISk3nu9aGn1SQEnZn73MlqytyL4YCqllLIV0xiKpktUw96ekpCmKtzV6Xus2jJ3EHfrNz5WClkfehsNTFGe527JqHTXi1jtkx96Gw1McYpXVsmQo3Qiczea03VMvM991wmpWYN/0ajp9UkBM2Ze0r0bNZRiRZxl3nTmKaLHu1Kzn05sCsXMzSuLROdq5qsfR5azztf9OjMNaRaWyU6W02M0Zy5a6qUqUStuJc8OtvMb68Vna0mxmjdZg/02BNw9jorujbIPnvhsE4rg6wZPb0lMVjmrg0tmfv8Jj01U6Yza7ZMrehoNQlCY7VMdKpaRG4+mso/KymYLVMXOltNjIk8d42TmLRm7prWsK8kb7ZMXejsLTHGV7yeu6YMNrq9bZmUqjfys+rcix4dZsvUjJ7ekhB0ri0TkFVoy3S16RG3+U16qli2zL0O9PWWmKN5JyaNG0V3Kfac80Xz3OtBX2+JOW7Wc29yICtIdK7ZjKKTDulSOomn7PkUy75Vy9SBiXvMMM9dF5psmUry4aJhZsvUjr7eEnNshqoOorurTdyi8dRouV+zZWpHT29JCBrXlonQWOeuyZaprArKFy1zrxd9vSXmRJm7ptURo9UCzZbRQ75YBrBSyDrQ11tiTjk03dMKU3eVmbtSWyLK3LWefyPQ11sSQlrhrEVVnnv45q1tydvIdjRbpn709JaEYZl7simF+6d2K81cC2bL1I2e3pIwVHnuUZ27osx9aiYQN22Ze8TUjGXu9aKntyQMTeIefVTXlLlr95xn69yVnn8j0NNbEoYmWyYaRM4pGmeIMndt1TLRZh2RLaP1k0sjMHGPKSlFmXsx9J9VZu6KxK0yX4nOvyNrmXut6OktRmwplQNx1+S5R59WtHrO+aJHezalyn5sNHp6ixFbSgoz94gOteJeNkumTvT1FiN2ROKuKXOP0LQ5NjC7uEy+6JklUyf6ekvM+e2fvILrL1zT7DBWlJnQlmlTmLlr+rRS6bkXbIu9uqm55YjIVhF5WEQOiMjTIvJr4fHVIvKgiBwKv69qXLjGu/ds5cu/cG2zw1hRNGfumsS9kqmiR6eySqFGU0/LKQO/7py7FLgW+JCIXArcCTzknLsIeCj82TBqpuRFpZD6hE7jOUNQCtlptkxd1NxynHNDzrnHwscTwEFgM3ALcHf4tLuBW+uM0VDObOauMIvVlrlH67nnzZapm4a0HBHZDlwNPAKsd84Nhb86Dqxf5G/uEJG9IrJ3dHS0EWEYCaUYeu4as1hN4wzC2eu5my1TH3W3HBHpBv4K+Ihzbrzydy7Y8NMt9HfOubucc3ucc3sGBgbqDcNIMHOTmPTVPGt8Q4OwFNJsmbqoq+WISJZA2L/snPt6eHhYRDaGv98IjNQXoqGd2Tr3tL7OrmkmciX5oqe2xr9R1FMtI8AXgYPOud+t+NX9wG3h49uA+2oPzzDmBlSzCjN3jTjnrBSyAdRjal0PvA94SkT2hcd+E/gMcI+I3A68BLy7rggN9Xi+3moZbTjnKHo+Zd+pWzSt0dR89Zxz/w9YLJW6sdb/axiLobHOXRPRJKaCLRrWEKy3GLFBU+WIZmyLvcZgvcWIDZa562BW3M2WqQvrLUZs0DahRyOOoAwSsFLIOrHeYsQGy9yTTTSAZ7ZMY7DeYrQ8t161CYCsom32NFMwW6Yh2NUzWp7/9hOX8xs3vwpRtG/s137xutmNwbUxNbt/qmXu9WDibrQ8XW0ZdTXPr92+utkhNAXnbP/URmG2jGEYLUH0yaxgnntDMHE3DKOliDJ3bZ/WGo2Ju2EYLUW+WEbEJq3Vi109wzBahqDO3aMzm1Y1gL4cmLgbhtESVNa5Wxlk/Zi4G4bRUuSLZRtMbQAm7oZhtBT5omdlkA3AxN0wjJbBNupoHGZsGYbREqzpznH0dIG0WBlkI7DM3TCMlmDb6i5Gx6fNlmkQ9vZoGEZLsKozy+l8iUw6ZbZMA7DM3TCMlqAzl6ZQ8hifLtHbkW12OLHHxN0wjJagLbRizuRL9LSbqVAvJu6GYbQElT57b7tl7vVi4m4YRkvQXinuZsvUjYm7YRgtQUduTo76TNzrxsTdMIyWoD0zl7nvHOhqYiTJwMTdMIyWoL2i/HFjb0cTI0kGJu6GYbQElZl7b4dVy9SLibthGC1BR0Xmbmu514+Ju2EYLUF71uSokdjVNAyjJbD1ZBqLibthGC1BVOe+uivX5EiSgY1aGIbREqzraeOX3rSLd12zpdmhJAITd8MwWgIR4RM3XdLsMBLDstgyInKTiDwrIodF5M7leA3DMAxjcRou7iKSBj4HvB24FPgZEbm00a9jGIZhLM5yZO6vAw47544454rAXwK3LMPrGIZhGIuwHOK+GTha8fOx8NhZiMgdIrJXRPaOjo4uQxiGYRh6aVoppHPuLufcHufcnoGBgWaFYRiGkUiWQ9wHga0VP28JjxmGYRgrxHKI+/eBi0Rkh4jkgPcA9y/D6xiGYRiL0PA6d+dcWUQ+DDwApIEvOeeebvTrGIZhGIsjzrlmx4CIjAIv1fjna4ETDQynUVhc1dGqcUHrxmZxVUcS47rAObfgoGVLiHs9iMhe59yeZscxH4urOlo1Lmjd2Cyu6tAWly0cZhiGkUBM3A3DMBJIEsT9rmYHsAgWV3W0alzQurFZXNWhKq7Ye+6GYRjGK0lC5m4YhmHMw8TdMAwjgcRa3Ju5bryIbBWRh0XkgIg8LSK/Fh7/LREZFJF94dfNFX/zG2Gsz4rI25YxthdF5Knw9feGx1aLyIMicij8vio8LiLyh2FcT4rINcsU08UV12SfiIyLyEeacb1E5EsiMiIi+yuOVX19ROS28PmHROS2ZYrrv4vIM+Fr/7WI9IfHt4tIoeK6/UnF37wmvP+Hw9hlGeKq+r41ur8uEtdXK2J6UUT2hcdX8notpg0r28acc7H8Ipj9+jywE8gBTwCXruDrbwSuCR/3AM8RrF//W8B/XOD5l4YxtgE7wtjTyxTbi8Daecd+G7gzfHwn8Nnw8c3APwACXAs8skL37jhwQTOuF3ADcA2wv9brA6wGjoTfV4WPVy1DXG8FMuHjz1bEtb3yefP+z/fCWCWM/e3LEFdV9205+utCcc37/f8A/ksTrtdi2rCibSzOmXtT1413zg055x4LH08AB1lgaeMKbgH+0jk345x7AThMcA4rxS3A3eHju4FbK47/hQv4LtAvIhuXOZYbgeedc+ealbxs18s59x3g1AKvV831eRvwoHPulHPuNPAgcFOj43LOfdM5Vw5//C7BQnyLEsbW65z7rgsU4i8qzqVhcZ2Dxe5bw/vrueIKs+93A1851/9Ypuu1mDasaBuLs7gvad34lUBEtgNXA4+Ehz4cfrz6UvTRi5WN1wHfFJFHReSO8Nh659xQ+Pg4sL4JcUW8h7M7XbOvF1R/fZpx3X6eIMOL2CEij4vIt0XkjeGxzWEsKxFXNfdtpa/XG4Fh59yhimMrfr3macOKtrE4i3tLICLdwF8BH3HOjQOfB3YBVwFDBB8NV5o3OOeuIdjq8EMickPlL8MMpSk1sBKsFPrjwNfCQ61wvc6imddnMUTkk0AZ+HJ4aAjY5py7Gvgo8H9EpHcFQ2q5+zaPn+HsBGLFr9cC2jDLSrSxOIt709eNF5Eswc37snPu6wDOuWHnnOec84E/Zc5KWLF4nXOD4fcR4K/DGIYjuyX8PrLScYW8HXjMOTccxtj06xVS7fVZsfhE5OeAdwDvDUWB0PY4GT5+lMDP3h3GUGndLEtcNdy3lbxeGeCdwFcr4l3R67WQNrDCbSzO4t7UdeNDT++LwEHn3O9WHK/0q38CiEby7wfeIyJtIrIDuIhgIKfRcXWJSE/0mGBAbn/4+tFo+23AfRVxvT8csb8WGKv46LgcnJVRNft6VVDt9XkAeKuIrAotibeGxxqKiNwEfBz4cedcvuL4gASb0SMiOwmuz5EwtnERuTZso++vOJdGxlXtfVvJ/voW4Bnn3KzdspLXazFtYKXbWD2jws3+Ihhlfo7gXfiTK/zabyD4WPUksC/8uhn4X8BT4fH7gY0Vf/PJMNZnqXNE/hxx7SSoRHgCeDq6LsAa4CHgEPCPwOrwuACfC+N6CtizjNesCzgJ9FUcW/HrRfDmMgSUCHzM22u5PgQe+OHw6wPLFNdhAt81amN/Ej73XeH93Qc8BvxYxf/ZQyC2zwN/TDgTvcFxVX3fGt1fF4orPP7nwC/Oe+5KXq/FtGFF25gtP2AYhpFA4mzLGIZhGItg4m4YhpFATNwNwzASiIm7YRhGAjFxNwzDSCAm7oZhGAnExN0wDCOB/H9v4ZjNw8ZmdgAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(testXperf)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 170,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x2ba9a1bd8890>"
      ]
     },
     "execution_count": 170,
     "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": [
    "plt.imshow(np.reshape(a,[28,28]))"
   ]
  },
  {
   "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": [
    "# first   tasks 99.9, , 98.3 , 95.7 , 91.3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2000"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(testXperf)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import json\n",
    "# with open('resultsforMNIST5Tasks.json', 'w') as f:\n",
    "#     json.dump(testXperf, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
