{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "VSJOwNIG57pB",
    "outputId": "91e17eb0-6756-493e-b376-f4531751481d"
   },
   "source": [
    "# Setup"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "ld7OUnHi4ZHt",
    "outputId": "06063379-9c83-4542-940b-e69a923223a0"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Num GPUs Available:  1\n"
     ]
    }
   ],
   "source": [
    "import time\n",
    "import math\n",
    "import scipy\n",
    "import scipy.signal\n",
    "import scipy.stats\n",
    "from scipy.stats import norm\n",
    "from scipy.stats import laplace\n",
    "from scipy import integrate\n",
    "import argparse\n",
    "import numpy as np\n",
    "import pickle\n",
    "import tensorflow as tf\n",
    "from tqdm import tqdm\n",
    "\n",
    "# local libs\n",
    "import sys\n",
    "sys.path.append(\"..\")\n",
    "import dpdl_privacy\n",
    "from train_tf import *\n",
    "\n",
    "print(\"Num GPUs Available: \", len(tf.config.experimental.list_physical_devices('GPU')))\n",
    "\n",
    "# gpu_devices = tf.config.experimental.list_physical_devices('GPU')\n",
    "# for device in gpu_devices: \n",
    "#     tf.config.experimental.set_memory_growth(device, True)\n",
    "    \n",
    "%matplotlib inline\n",
    "%config InlineBackend.figure_format = 'retina'\n",
    "#%matplotlib widget\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy import integrate\n",
    "matplotlib.rcParams['figure.dpi'] = 100  #Set quality of figures shown inline\n",
    "\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Set Parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "JLdim_list=[1,5,10,20,30]\n",
    "JLdim_list_privacy=[10,20,30]\n",
    "\n",
    "epochs=15 #number of epochs of training\n",
    "\n",
    "batch_size=256\n",
    "\n",
    "sigma=0.6 #noise multiplier\n",
    "clipping_norm = 1\n",
    "delta=1e-5\n",
    "\n",
    "\n",
    "###################################################\n",
    "#Privacy engine parameters\n",
    "mesh_size=1e-4 # Controls accuracy of privacy calculations. If set it to 'None', it will be chosen automatically\n",
    "\n",
    "max_eps=100\n",
    "min_delta=10**(-10)\n",
    "precision=10**(-25)\n",
    "\n",
    "# Hyperparameters for Adam Optimizer\n",
    "lr = 1e-3# learning rate\n",
    "beta1=0.9\n",
    "beta2=0.999"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "Qj3tJcqV01JF"
   },
   "source": [
    "## Load model and data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "jz7KWWcU5NkT",
    "outputId": "3166820f-a710-48c0-92d1-73fa8518c99b"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"my_model\"\n",
      "_________________________________________________________________\n",
      "Layer (type)                 Output Shape              Param #   \n",
      "=================================================================\n",
      "embedding (Embedding)        multiple                  523840    \n",
      "_________________________________________________________________\n",
      "bidirectional (Bidirectional multiple                  66048     \n",
      "_________________________________________________________________\n",
      "dense (Dense)                multiple                  8256      \n",
      "_________________________________________________________________\n",
      "dense_1 (Dense)              multiple                  130       \n",
      "=================================================================\n",
      "Total params: 598,274\n",
      "Trainable params: 598,274\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n",
      "Number of training samples:  25000\n",
      "Number of test samples:  25000\n"
     ]
    }
   ],
   "source": [
    "####################### https://keras.io/examples/nlp/text_classification_from_scratch/#two-options-to-vectorize-the-data\n",
    "import tensorflow as tf\n",
    "from tensorflow.keras.layers import Dense, Embedding,Bidirectional,LSTM\n",
    "from tensorflow.compat.v1.keras.layers import CuDNNLSTM\n",
    "from tensorflow.keras import Model\n",
    "\n",
    "\n",
    "## Training Settings\n",
    "\n",
    "# https://www.tensorflow.org/datasets/catalog/imdb_reviews\n",
    "maxfeature=8185\n",
    "SEQ_LEN=150\n",
    "\n",
    "class MyModel(Model):\n",
    "    def __init__(self, dataset):\n",
    "        super(MyModel, self).__init__()\n",
    "        self.embed=Embedding(maxfeature,64,input_length=SEQ_LEN)\n",
    "        self.blstm1 = Bidirectional(LSTM(64))\n",
    "        #self.blstm1 = Bidirectional(LSTM(64,batch_input_shape=(batch_size,SEQ_LEN,1)))\n",
    "        self.d1 = Dense(64, activation='relu')\n",
    "        self.d2 = Dense(2)\n",
    "                \n",
    "    # Doing this to initialize model.trainable_variables\n",
    "        for text, labels in dataset:\n",
    "            self(text)\n",
    "            break\n",
    "\n",
    "    @tf.function\n",
    "    def call(self, x):\n",
    "        x = self.embed(x)\n",
    "        x = self.blstm1(x)\n",
    "        x = self.d1(x)\n",
    "        x = self.d2(x)\n",
    "        return tf.nn.log_softmax(x)\n",
    "\n",
    "\n",
    "## Load Problems\n",
    "(x_train, y_train), (x_test, y_test) = tf.keras.datasets.imdb.load_data(num_words=maxfeature)\n",
    "x_train=tf.keras.preprocessing.sequence.pad_sequences(x_train,maxlen=SEQ_LEN)\n",
    "x_test=tf.keras.preprocessing.sequence.pad_sequences(x_test,maxlen=SEQ_LEN)\n",
    "train_ds = tf.data.Dataset.from_tensor_slices((x_train, y_train)).shuffle(5000).batch(batch_size)\n",
    "test_ds = tf.data.Dataset.from_tensor_slices((x_test, y_test)).batch(25000)\n",
    "n_train = len(x_train)\n",
    "\n",
    "model=MyModel(train_ds)\n",
    "model.summary()\n",
    "\n",
    "\n",
    "num_samples=len(x_train)\n",
    "print('Number of training samples: ',num_samples)\n",
    "print('Number of test samples: ',len(x_test))\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Packaging privacy parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "privacy_args=dpdl_privacy.privacy_params(num_JL=None,epochs=epochs,sigma=sigma,num_samples=num_samples,batch_size=batch_size,delta=delta,mesh_size=mesh_size,min_delta=min_delta,precision=precision,max_eps=max_eps)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "bPJrfEw35sei"
   },
   "source": [
    "# Non-DP training"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "KGCwypcF9Wrs"
   },
   "source": [
    "## Direct implementation of Adam"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "Bm6qY6ls5Qwx",
    "outputId": "05be29d6-3d5a-4d8f-8a47-34d3a6a6e9fc"
   },
   "outputs": [],
   "source": [
    "# no-dp, only for speed since this is training accuracy\n",
    "\n",
    "model = MyModel(train_ds)\n",
    "\n",
    "loss_obj = tf.keras.losses.SparseCategoricalCrossentropy(from_logits=True, reduction=tf.keras.losses.Reduction.NONE)\n",
    "train_loss = tf.keras.metrics.Mean(name='train_loss')\n",
    "train_accuracy = tf.keras.metrics.SparseCategoricalAccuracy(name='train_accuracy')\n",
    "accuracy_list=[]\n",
    "epochtime_list=[]\n",
    "\n",
    "\n",
    "## Run SGD to train\n",
    "step=0\n",
    "for epoch in range(epochs):\n",
    "    start_time=time.time()\n",
    "    for images, labels in train_ds:\n",
    "        n_images = images.shape[0]\n",
    "   \n",
    "        # Compute the gradient\n",
    "        with tf.GradientTape() as tape:\n",
    "            predictions = model(images, training=True)\n",
    "            loss_ind = loss_obj(labels, predictions)\n",
    "            loss = tf.reduce_mean(loss_ind)\n",
    "            \n",
    "        gradients = tape.gradient(loss, model.trainable_variables)\n",
    "        \n",
    "        if step==0:\n",
    "            m=gradients\n",
    "            #u=[item*item for item in gradients]\n",
    "            u=[tf.convert_to_tensor(item)**2 for item in gradients]\n",
    "        else:\n",
    "            for k in range(len(gradients)):\n",
    "                m[k]=beta1*tf.convert_to_tensor(m[k])+(1-beta1)*tf.convert_to_tensor(gradients[k])\n",
    "                u[k]=beta2*u[k]+(1-beta2)*tf.convert_to_tensor(gradients[k])**2\n",
    "            \n",
    "        # Run the gradient descent\n",
    "        k = 0\n",
    "        for p in model.trainable_variables:\n",
    "            p.assign(p - lr * tf.convert_to_tensor(m[k])/(tf.sqrt(u[k])+1e-8))\n",
    "            # some magic line for potential bug: https://github.com/tensorflow/tensorflow/issues/36236\n",
    "            k = k + 1\n",
    "        \n",
    "        step+=1\n",
    "    epoch_time=time.time()-start_time\n",
    "    print('Per epoch time:', epoch_time)\n",
    "    epochtime_list.append(epoch_time)\n",
    "\n",
    "    for images, labels in test_ds:\n",
    "        predictions = model(images, training=False)\n",
    "        loss = loss_obj(labels, predictions)\n",
    "        train_loss(loss)\n",
    "        train_accuracy(labels, predictions)\n",
    "                                \n",
    "    print('Epoch %i, Loss: %f, Accuracy: %f' %\n",
    "          (epoch + 1, train_loss.result(), train_accuracy.result() * 100))\n",
    "    accuracy_list.append(train_accuracy.result().numpy())\n",
    "        \n",
    "\n",
    "    train_loss.reset_states()\n",
    "    train_accuracy.reset_states()\n",
    "    \n",
    "tf.keras.backend.clear_session()\n",
    "\n",
    "record_dict = {'accuracy':accuracy_list,'time':epochtime_list,'privacy_params':privacy_args}\n",
    "with open('pickles/nonDP_LSTM.pickle','wb') as handle:\n",
    "    pickle.dump(record_dict,handle)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "wl2v0iB29MdN"
   },
   "source": [
    "## Implementation using keras"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "model = MyModel(train_ds)\n",
    "\n",
    "from tensorflow_privacy.privacy.optimizers.dp_optimizer_keras import DPKerasAdamOptimizer\n",
    "from tensorflow_privacy.privacy.optimizers.dp_optimizer_keras import DPKerasSGDOptimizer\n",
    "\n",
    "print(batch_size)\n",
    "optimizer = DPKerasAdamOptimizer(\n",
    "    l2_norm_clip=clipping_norm,\n",
    "    noise_multiplier=sigma,\n",
    "    num_microbatches=batch_size,\n",
    "    learning_rate=lr,\n",
    "    beta_1 = beta1,\n",
    "    beta_2 = beta2,\n",
    "    epsilon = 1e-8)\n",
    "\n",
    "# optimizer = DPKerasSGDOptimizer(\n",
    "#     l2_norm_clip=clipping_norm,\n",
    "#     noise_multiplier=sigma,\n",
    "#     num_microbatches=batch_size,\n",
    "#     learning_rate=lr)\n",
    "\n",
    "model.compile(optimizer='adam',\n",
    "              loss=tf.keras.losses.SparseCategoricalCrossentropy(from_logits=True),\n",
    "              metrics=['accuracy'])\n",
    "\n",
    "model.fit(train_ds, validation_data=test_ds, epochs=epochs,batch_size=batch_size)\n",
    "\n",
    "model.evaluate(test_ds)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# DPVanilla"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting some privacy precomputations...\n",
      "Calculating single iteration privacy curves for DPSGD...\n",
      "t_limit_stdPQ:  100\n",
      "max_t:  100\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  2%|█▎                                                                    | 38423/1999998 [00:00<00:05, 366531.67it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_scales: 8\n",
      "prob_scale: [1.00000000e-02 3.72759372e-08 1.38949549e-13 5.17947468e-19\n",
      " 1.93069773e-24 7.19685673e-30 2.68269580e-35 1.00000000e-40]\n",
      "mesh_scale: [1.00000000e-04 4.69117279e-04 2.20071021e-03 1.03239118e-02\n",
      " 4.84312543e-02 2.27199382e-01 1.06583156e+00 5.00000000e+00]\n",
      "step_scale: [1, 5, 23, 104, 485, 2272, 10659, 50001]\n",
      "t_scale: [0.12558095200187777, 4.300066864373284, 7.910064133130503, 10.64648598637548, 12.936017513796868, 14.943976303882865, 16.75377716252364, 18.414398830750688]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████| 1999998/1999998 [00:06<00:00, 288068.40it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(should be close to 1) sum stdQ_pdf:  0.9999999999998938\n",
      "mean_stdQ=0.0005975850202559302\n",
      "stddev_stdQ=0.03805119776581762\n",
      "Finished calculating privacy curves for single iteration\n",
      "\n",
      "Time:  18.799224853515625\n",
      "Finished privacy precomputations. Increase mesh_size if this is too slow.\n",
      "Finished adding epochs. Time taken: 0.4785730838775635\n",
      "3.8509570761947503\n",
      "Finished adding epochs. Time taken: 1.1702532768249512\n",
      "4.504045729708431\n",
      "Finished adding epochs. Time taken: 1.172119140625\n",
      "5.019329459387753\n",
      "Finished adding epochs. Time taken: 1.1820669174194336\n",
      "5.465600597537084\n",
      "Finished adding epochs. Time taken: 1.174783706665039\n",
      "5.8679007584064165\n",
      "Finished adding epochs. Time taken: 1.1778900623321533\n",
      "6.238944703281215\n",
      "Finished adding epochs. Time taken: 1.1678709983825684\n",
      "6.586265970908018\n",
      "Finished adding epochs. Time taken: 1.3257129192352295\n",
      "6.914765700417232\n",
      "Finished adding epochs. Time taken: 1.194275140762329\n",
      "7.227844716209128\n",
      "Finished adding epochs. Time taken: 1.1853046417236328\n",
      "7.527977881338846\n",
      "Finished adding epochs. Time taken: 1.1754302978515625\n",
      "7.817033587601439\n",
      "Finished adding epochs. Time taken: 1.1862502098083496\n",
      "8.096464144517483\n",
      "Finished adding epochs. Time taken: 1.1721220016479492\n",
      "8.367425571074426\n",
      "Finished adding epochs. Time taken: 1.1841437816619873\n",
      "8.630856333093057\n",
      "Finished adding epochs. Time taken: 1.1787829399108887\n",
      "8.887531008036849\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {
      "image/png": {
       "height": 365,
       "width": 523
      },
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calculting eps vs delta curve...\n",
      "Finished. Time taken: 3.441649913787842\n",
      "Calculting epsilons using GDP...\n",
      "mu_ideal 1.5220991318665378\n",
      "Calculting epsilons using MA...\n"
     ]
    },
    {
     "data": {
      "image/png": "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b8dff/2FwMBAtG7dGtWqVUO5cuVgbW2NSpUqoWnTphg1ahR2796NuLg4jB07VmMPAm0sLCzg7OwMT09PtGvXDhMmTMCBAwcQFRWl97avV6VRo0YIDw/HiBEj4OHhAUtLS7i4uKBp06aYM2cOzp8/n+8WB21sbW2xdetW/PnnnwgICICXlxfKlSsHBwcHeHt7o2fPntiwYYN8u0xBEydOxPXr1/HVV1+hQYMGcHR0hI2NDWrWrIn33nsP8+bNw6ZNmzTWnTRpEsLCwvDZZ5+hVq1aKFeuHOzs7FCvXj2MGTNG7+fFzMwM27Ztw+LFi/H222/Dzs4OdnZ2aNiwIWbMmIFz584ZtA+Kg729vXx+Kf9malMc52hx+eKLL7B9+3Z06NABFStWNOjvelknCUUvAnpNSZJUDUAsAMTGxsrdoIiIiArj9u3b8q0NqvepU+k3ZcoUuUt7Ub7feXp64u7duxg8eLA88CgREZmuwvzfHxcXp/q49epCCO0DyZQi7AFCRERERERERCaPCRAiIiIiIiIiMnlMgBARERERERGRyWMChIiIiIiIiIhMHhMgRERERERERGTymAAhIiIiMgFTpkyBEKJIT4ABgJiYGAgh+AQYIiIyOUyAEBEREREREZHJYwKEiIiIiIiIiEweEyBEREREREREZPKYACEiIiIiIiIik8cECBERERERERGZPCZAiIiIiIiIiMjkMQFCRERERERERCaPCRAiIiIiIiIiMnlMgBARERERERGRyWMChIiIiIiIiIhMHhMgRERERERERGTymAAhIiIiIiIiIpNXJhMgkiQ5SpLUV5KkuZIkhUiS9LckSc8kScqUJClBkqTjkiR9K0mSq442hkiSJAychrzCzSMiIiIiIiKiAixKOoAS0hTARi3LKgDwz5u+kSRpoBDij1cWGREREREREREVuzLZAyRPLIC1AMYA6AmgGYAWAD4GsBVADgA3AHskSWqop62OAHx0TLteQvxERERkAo4fPw5JkuTJwcEB6enpeus9f/4c5cuXz1f3+PHjeuudOnUqX50TJ04Uw1YQERGVfmW1B8gxIUQNHcu3SJLUA8BOAFYAAgH00lE+UggRU4zxERERURmVmpqKXbt2oX///jrL7d69G8nJyUa3v3btWrXXrVu3NrodIiKi102Z7AEihMgxoMwuADfzXvJbAREREb10NjY2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nQ0LCwvUrl27pMMhIiKil6ww//fHxcWhevXqypfVhRBxLy3AYsQeIERERERERERk8pgAISIiIiIiIiKTxwQIEREREREREZk8JkCIiIiIiIiIyOQxAUJEREREREREJo8JECIiIiIiIiIyeUyAEBEREREREZHJYwKEiIiIiIiIiEweEyBEREREREREZPKYACEiIiIiIiIik8cECBERERERERGZPCZAiIiIiIiIiMjkMQFCRERERERERCaPCRAiIiIiIiIiMnlMgBARERERERGRyWMChIiIiIiIiIhMHhMgRERERERERGTymAAhIiIiIiIiIpPHBAgRERERERERmTwmQIiIiIjIJD1+/Bjjx49HvXr1UK5cOUiSBEmSMG/evJIOjYiISgATIEREREQl5Pjx4/JFuaHTV199VdJhvxaePXuGZs2aYe7cubh58yZevHihVmbNmjUa97GlpSXc3NxQq1YtvP/++/juu+9w4MAB5ObmGrRubcfOysoKFStWhL+/P6ZNm4aHDx8W92YTEZEOTIAQERERUYlTJgmmTJlSLO0tXrwYt2/fBgB8++23OHnyJCIiIhAREYGAgACddbOzs/H48WNERUXh6NGjmDVrFjp37gwvLy8sXbq00DFlZWUhMTERJ06cwOTJk+Ht7Y09e/YUuj0qPdq0aQNJktCmTZuSDsVgqgnY48ePl3Q4RK+ERUkHQERERETAF198gZEjR+ot5+bm9gqief0dOXIEAODn54dZs2bpLT99+nR0795dfp2cnIzHjx8jLCwMf/zxB0JDQ3Hv3j2MHDkS+/btw7Zt21CuXDmdbfr5+SEoKEh+nZWVhTt37mDVqlU4ePAgnj17hj59+uDcuXPw9fUt5JYSEZGhmAAhIiIiKgUqVqyIBg0alHQYJuP+/fsAgDp16hhU3t3dXeP+79q1KyZPnozQ0FAMHDgQ0dHR2L9/P4YMGYLNmzfrbNPOzk6tzcaNG6N379748ssvsXDhQmRkZGDatGnYtm2bgVtGRESFxVtgiIiIiMjkZGRkAAAsLS2Lpb3mzZvj/PnzqF69OgBgy5Yt2LVrV6HbmzlzJmxsbAAAhw4dMnh8ESIiKjwmQIiIiIheU0IIdOrUCZIkwdzcHKdOndJadv78+fL9/t9//73a8qioKMydOxddu3aFp6cnypUrh3LlysHDwwMff/wxDh48aHBcV69exejRo+Hj4wNnZ2fY2trijTfeQKdOnbB06VIkJibKZT09PSFJkvz6xx9/VBs8dMiQIQatV3VMg7t37wIAgoOD87VVlDEa3NzcsGzZMvn1//73v0K3ZW9vjzfffBMAkJKSgidPnhjdxtWrVzF9+nR07NgR1apVg7W1Nezt7VG7dm0MHjwYZ8+eNbit06dPY9iwYahbty4cHR1hb28Pb29v9OjRA2vXrkVycrLWujExMZgwYQKaNGkCV1dX2NjYwMvLC23btsXcuXNx7949rXUjIiIwfPhw1K5dG7a2tnBwcMCbb76JsWPHIiYmRms9Y8av0DW+zJQpU+TlAPDixQvMnj0bb731FhwcHODg4ICmTZti0aJFyM7OVqs/ZMgQSJKEkJAQAEBISIja59fT0zNfnbS0NGzevBnDhg1Do0aNUL58eVhaWqJChQrw9/fHnDlzkJqaatQ2XbhwAf369ZM/B+7u7ggICMCNGzfU6sbExECSJLRt21Z+r23btmpxr1mzRmcMRK8lIQSn13gCUA2AACBiY2MFERFRUURGRorr16+LyMjIkg6lTDh27JhQ/j8eGBhYqDbi4+OFm5ubACA8PT3Fs2fP1Mpcu3ZN2NjYCADCz89PZGZm5lseFRUlx6FrGjhwoMjKytIaS3Z2thg7dqwwMzPT2c7gwYPlOh4eHnrXq1peF9X9qW3y9/eXywcFBcnvBwUFGbSO3NxcUbduXbne/fv31cpoWpcm77zzjlz24cOHBq1fyZBtBSC+++47ne2kp6eLfv366W1H2+dz9uzZwtLS0uB9rmrmzJk6PyvW1tYiODhY7/YfO3ZM5zbq2obAwMB8x8DX11drPF27dhU5OTn56g8ePFjvvvPw8MhXx9/fX28dLy8vcePGDYO2aeHChcLCwkJjO7a2tiIkJCRf3ejoaIM+O4aeE/T6K8z//bGxsaqfl2qiFFwbGzJxDBAiIiKi11jlypWxatUqdO/eHTExMRg1ahTWrVsnL8/MzET//v3x4sUL2NraYv369Wq3heTk5MDKygodO3ZE+/btUb9+fbi4uODJkyeIjIzE4sWLce3aNfz222+oWbMmfvzxR42xDB8+HKtXrwYAVKlSBf/5z3/QvHlzlC9fHomJiTh//rzaWBeHDh1CZmYmfHx8AGgeDNbZ2dmgffH2228jIiICANCxY0c8ePAA3bt3x/Tp0+UydnZ2BrWljSRJeO+993Dr1i0AwMmTJ/Hxxx8b3U5WVhZu3rwJALCysoKrq6tR9bOzs2FnZ4cuXbqgXbt28Pb2hqOjIxISEnDt2jUsWLAAd+/exU8//YQ6depg6NCham3k5uaie/fuOHz4MACgdu3aGDlyJPz8/GBra4v4+HiEhoZiy5YtGmOYNm0aJk+eDABwcnLCyJEj0bZtW7i6uiIpKQmXL1/Gzp078/XwUVqyZAkmTZoEAKhQoQImTJiAFi1aICcnB0eOHMHs2bORlpaGIUOGwM3NDZ07dzZq/xRGz549cePGDXz55Zfo2rUrXFxccOvWLUybNg03btzA3r17sWLFCnz++edynRkzZmD8+PEYOnQoLl68qDbwLaA4vqqys7Ph4+ODbt26wc/PD1WrVoUQAnfv3sXOnTuxZcsWREdHo0ePHggPD5dvldLkjz/+wLlz59CwYUOMGTMGPj4+eP78OXbu3In58+cjPT0dAQEBuH37thyHu7s7IiIicOHCBXzyyScAgNWrV+Ptt9/O13a1atWKtD+JSqWSzsBwKtoE9gAhIqJixB4gr5bqr9hffPGFiIiI0DsV7L2hNHz4cLmtjRs3yu+PHz9efv/XX3/VWDc1NVU8ePBAa5y5ubliyJAhAoCws7MTSUlJamV27dolr6dZs2bi6dOnWtvT9J0FKr9oFwdlzxJdvUcK0wNECCFWrlwp15s6daracuUyXT1Afv75Z7lcu3btDF63UmJios59nJGRIdq3by/3QMjOzlYrM2/ePDmGDz/8ULx48UJjWzk5OWo9XS5duiT33qhTp47O76EFlyUkJAhbW1sBQFStWlXcu3dPrc7ly5eFnZ2dACDc3d3VPvcvoweIpaWlxrYeP34sKlWqJACIhg0balyHsleHvl4/Qgi9f18PHz4s79uVK1dqLKOMGYDo3LmzyMjIUCszffp0ucyOHTvUlhuzD8m0laUeIBwDhIiIiEo/IYCbN4HDhxX/Kn4EMClLly6Fj4+P3kn5dJOCfvnlF9StWxeAohfFvXv3cOzYMcydOxcA0K1bNwwfPlxjXTs7O1SpUkVrbJIkYe7cuTA3N0daWpr8iFlVP/30EwDA1tYWW7duhZOTk9b2XvdfllV7azx9+tTgellZWbh16xa++eYbjB8/Xn7/22+/NToGNzc3nfvYysoKs2fPBgDcvXsX4eHh+Zbn5ubKy93d3bF27VpYW1trbMvMzAxVq1bN997s2bORm5sLSZKwadMmnce04LKgoCCkp6cDAObOnSsPLKuqcePGmDhxIgDFE32KMuCsoUaPHq1xjBgXFxe5B81ff/2FZ8+eFWk9tWvX1rn8/fffR7du3QBA73bb2NggKChIrZcJAHz55Zfy+ydPnixktESmhbfAEBERUemWlAQMGADs3//ve507A+vXAzouAMsa5e0tzZo1Q1JSEgYMGIC7d+9CCIHKlStj5cqVBreVlZWFR48eISUlBTk5OfL7rq6uSEhIwJUrV9CrVy/5/cePH+PcuXMAgD59+sDd3b34NqwUsre3l+dTUlK0llMOiKmNJEmYOXMmOnbsWOSYMjIy8OjRI6SmpspPlBEqicIrV66gSZMm8uvw8HA5mfbZZ5/l2yZ9cnNz5UFx/f390bhxY6NiVSbQnJyc8n2OCho2bBj++9//ynU++ugjo9ZjrAEDBmhdprrvoqOj0ahRo2Jbb2JiIpKSkuQnFwGK24IAxXHTpX379qhYsaLGZQ4ODqhduzauXbuGqKioYouX6HXGBAgRERGVXkKoJz8AxesBA4Dffy+ZuF6CwMBAjU+pMEaTJk0wdepUTJw4Md8TYYKCguQLKm2ysrKwfPlyrFu3DmFhYcjMzNRa9p9//sn3Ojw8XL7Ybt26dRG24PWgmvRwdHQ0ur6zszPee+89jBs3Ds2aNSt0HGlpaViwYAE2bdqEa9eu5UtWFVTwmIWFhcnzxh6z6OhoJCUlFaouoHh6DaDo5aHrMcWVKlWCp6cnYmJi5Dovk7e3t9ZlLi4u8ryupJehTp8+jQULFuDIkSM6nwBU8LgVpCtm4N+4iyNmIlPABAgRERGVXrduqSc/lPbvV9wOo+cCoKz59ttvERQUhMjISACKX9E7deqks86TJ0/QoUMHXLp0yaB1PH/+PN9r1Ys0XbfSmArV7VW9MC6o4ICYlpaWKF++PCpXrlzkGGJiYtCuXTtER0cbVL44j1lRj7fygr9SpUp6y1auXBkxMTGFekywsWxtbbUuMzP7d+QAXYkmQ0yZMkXrQMIFFTxuBemKGfg37qLGTGQqOAYIERERlV6xsUVbXgYdPHhQTn4AwKlTp/ReRI0ZM0ZOfvTo0QN79uxBTEwM0tPTkZubKw8epxyrQegYg0XXLR+mQrX3hHLcFU3s7OzQoEEDeapbt26xJD8AICAgANHR0ZAkCZ988gkOHTqE2NhYvHjxQj5eqhe9L+uYvey6uuJ+HR09elROftSsWRNLlizBX3/9haSkJGRnZ8vH7ocffijhSIlME3uAEBERUemlYXBEo5aXMYmJifJjLR0dHZGcnIybN29i/PjxWLx4scY6ycnJ2Lx5MwCgf//+WL9+vdb2tQ346ebmJs8/ePCgsOG/FoQQ+QaBbdmy5SuP4ebNm/ItThMnTsSMGTM0ltM1QGvBY6YrkaOvrrFcXFwQHx+Phw8f6i376NEjuY4q1R4ZyjFPNElLSzM6vpdpxYoVABTjn5w5c0br+B3GDK5LRIZjDxAiIiIqverWVQx4qknnzrz9pYBPP/0Ujx49gpmZGXbt2oW+ffsCAJYsWYIDBw5orHP79m1kZWUBgFxek1u3biE1NVXjssaNG8u/5p84caIom1Dq7d+/H7dv3wYAvPvuu8XWo8MY165dk+d1HbOLFy9qXfbWW2/J88YeMy8vLzg7OxeqLgA0aNAAgKInjfKzp0lCQgLu3r2br46Sg4ODPK8rWXDr1i2j4ysMQ3vCKI9du3bttCY/AN3HrriUhd5aRAUxAUJERESllyQpnvZSMAmifAoMyZYtW4a9e/cCAL7++mu0bdsWS5culW9bGTp0KBITE9XqZWdny/PKR5Nqa18bFxcXNG/eHACwZcuWQvUKsLGxAYB8T8Iobf755x+MGDFCfq18TOurVhzHzNfXV/5srFy5UmtySxMzMzN0zjsnQ0JC8t0SZIj3338fAJCUlITt27drLbdq1Sr5FhhlHSUvLy95XleyYMOGDUbFVliGfn6Vx07XcQsPD8fZs2eLLzgtlDEDpfu8IypOTIAQERFR6ebkpHjay40bwKFDin9//52PwFURGRmJr7/+GoDiwnb69OkAFN3sg4ODYWZmhkePHuGzzz5Tq/vGG2/IvwSvXbtWY/v79u3DwoULdcYwYcIEAIoLu48++gjPnj3TWjYuLk7tPeVgmnfu3NG5npISGhqKpk2byrH369cP3bp1K5FYateuLc8HBwdrLLN06VLs2rVLaxtmZmb45ptvACiOx6BBg7Q++Sc3N1ctqTV+/HiYmZlBCIG+fftqPKZKBZcNHTpUHrzz66+/RqyGsXyuXLmCmTNnAgDc3d3Ro0ePfMudnJzQsGFDAIqnHGkaJPXEiRNYsGCB1riKk/LzGxUVpXPcEuWxO3XqlMZH0yYmJmLgwIEvJ8gCVAewLa3nHVFx4xggRERE9Hrw9jbpW14SEhIMetRnuXLlUKtWLfl1VlYWBgwYgPT0dNjY2GD9+vWwsrKSl7dt2xbjxo3DnDlzsHv3bqxYsSJfIsTV1RWdO3fG77//jv3796NTp074/PPPUaNGDSQkJGD79u1Ys2YNatasiaSkJI29SACga9eu+PTTT7Fq1SqEhoaifv36+M9//oMWLVrA0dER//zzDy5evIgtW7agYcOGWLNmTb76zZs3R3R0NPbs2YNff/0VLVq0kH+hdnR01Hm7QHG4f/9+vv2fkpKCx48fIywsDAcPHkRoaKi87IMPPsDq1atfajy6NG7cGA0aNMDVq1exdOlSJCUlYcCAAahSpQpiY2Px22+/Ydu2bWjRogVOnz6tJvzL8AAAIABJREFUtZ1Ro0Zh7969OHz4MHbu3AkfHx+MHDkSfn5+sLW1xcOHD3H27Fls3LgR/fv3z/eY5kaNGuHHH3/EDz/8gMjISPj4+GDUqFFo27YtXF1dkZSUhPDwcOzYsQPm5uY4duyYXLdChQqYPXs2Ro0ahQcPHsDPzw/fffcdmjdvjpycHBw5cgSzZ89GamoqJEnC8uXLNT4ud+TIkRgxYgQePXqEVq1a4YcffkDdunXx5MkT7Nu3D0uXLoWfnx/OnDlTrPtfk+bNmyMoKAgJCQkYN24cBg4ciPLlywNQPP3Hw8MDADBo0CDs3bsXqamp8Pf3x4QJE9CkSRMIIRAaGoqff/4ZDx8+RLNmzV563DVq1EC1atUQFxeHOXPmwN3dHXXr1oWFheISsVKlSvluNSIyCcqRhjm9nhOAagAEABEbGyuIiIiKIjIyUly/fl1ERkaWdChlwrFjx4Ty/3FDJ19f33xtTJo0SV42f/58jevJyMgQvr6+AoCws7MTt2/fzrf83r17okaNGlrXWaNGDXHt2jXh4eEhAIjBgwdrXE92drb4z3/+IyRJ0rkNmuqHhYUJa2trg8vroy9WIYQICgoyat97eHiIZcuW6V23sry/v7/RcRsqLCxMODs7a43Vx8dHPHjwQH4dGBiosZ20tDTRu3dvvduurf7MmTOFhYWFzrra9sOMGTOEmZmZ1nrW1tYiODhY6z7IyckRPXr00Fq/QYMGevdBYGCgvFwX1XP12LFjastTUlJEzZo1tX5uVA0dOlRrzObm5mLevHl649J3XJT8/f11HoMlS5ZojSUoKEhn22Q6CvN/f2xsrOrnpZooBdfGhky8BYaIiIjoNXXq1Cn89NNPAIAOHTpg9OjRGstZWVlh/fr1sLGxQVpaGgYOHJhvHInq1avj8uXL+Oabb1CnTh1YW1ujfPny8PX1RWBgIMLDw1G/fn298Zibm2PhwoW4ePEihg8fjjp16sDOzg62traoXbs2OnfujBUrVuCXX35Rq9uoUSOcOXMG/fr1Q40aNWBtbV3IvVJ0FhYWcHZ2hqenJ9q1a4cJEybgwIEDiIqKwueff15icalq1KgRwsPDMWLECHh4eMDS0hIuLi5o2rQp5syZg/Pnz+e7xUEbW1tbbN26FX/++ScCAgLg5eWFcuXKwcHBAd7e3ujZsyc2bNgg3y5T0MSJE3H9+nV89dVXaNCgARwdHWFjY4OaNWvivffew7x587Bp0yaNdSdNmoSwsDB89tlnqFWrFsqVKwc7OzvUq1cPY8aMwc2bNzFo0CCtsZuZmWHbtm1YvHgx3n77bdjZ2cHOzg4NGzbEjBkzcO7cOYP2QXGwt7dHaGgoxowZg3r16sm3+GiyevVqrFu3Dq1atYKDgwOsra3h4eGBgIAAuY1X5YsvvsD27dvRoUMHVKxYUe79QWSqpP/P3p3Hx3XX9/5/f7VbsuVN1i5bsZ14i403KXLsxC700rD0trSUH/BrC4U0zW0v98KD9cFyW3rh0QW4QIGy34b20cstlEAoZSm0wYkdOZJtJXG8JI6T2KPd8ipLsqzle/84R+MZeaTRjGbmzDnzej4e5zHnzJz56CPHjj1vfRdrg7W3dq4xxtRLCklSKBRSfX29xx0BAPzs9OnTGh8fV0FBQdQ6AwAAIJiS+bu/s7MzvJCypAZr7cwLAWURRoAAAAAAAIDAIwABAAAAAACBRwACAAAAAAACjwAEAAAAAAAEHgEIAAAAAAAIPAIQAAAAAAAQeAQgAAAAAAAg8AhAAAAAAABA4BGAAAAAAACAwMvJAMQYU26MebMx5jPGmP3GmBeMMVeMMTeMMf3GmF8aYz5gjFk+x3r3GWMeNsZ0GmNG3ceHjTH3pft7AQAAAAAA8RV43YBHmiV9e4bXVkja6x7vN8b8rrX2Z7FuNMYYSV+R9MC0l+okvUHSG4wxX5P0oLXWpqRzAAAAAABSJJc+quZqACJJIUmPSjrinvfIGRFTL+mNkn5LUoWkHxpjmqy1z8So8QndDD86JP21pDOS1kj6gKRt7uvnJX00bd8JAAApkp+fr/HxcU1MTGhyclJ5eTk5WBQAgJwwMTGhiYkJSc6/AYIuVwOQR621K2d5/TvGmN+U9H1JRZL+VNJvR95gjFkrJ+SQpMOS7rXWjrjX7caYH0raL2mnpA8aY/7OWnsmld8EAACpVlJSotHRUVlrde3aNZWXl3vdEgAASJPLly+Hz0tLSz3sJDNy8sc61tqJOdzzA0mn3Mt7Y9zyHt0MkN4VEX5MvX9Y0rvcywJJ706uWwAAMicy8Ojt7dXVq1c1OTnpYUcAACCVrLW6fv26+vv71d/fH35+6dKlHnaVGbk6AmSuhtzHksgn3bU/fsO9PGWtPRTrzdbaQ8aY5yStk/Sbxpj/xlogAIBsVlZWpgULFmhkZEQTExPq6uqSMSYnhsUCAJALJiYmbln3Y/HixSouLvaoo8whAJmBMWaDpK3u5alpL98mZ6FTyZnmMpv9cgKQekmNkl5KUYsAAKScMUYrV67UuXPnNDLiDG601mp8fNzjzgAAQDqsWLFCy5fPaQNU3yMAiWCMKZUTbPy6nPU9pn7c9flpt26IOJ8ejkwX+foGEYAAALJcXl6eVq1apaGhIQ0ODoZHgwAAAP/Ly8tTUVGRysrKtHDhQhUVFXndUsbkfABijHm7pL+b5ZZPS/rHac81RJx3xvkSoRneNyfGmPo4t1QnWhMAgHiMMVq4cKEWLlzodSsAAAApkfMByCyekvSgtfbJGK8tiji/FqfOUMR5Mv+KDMW/BQAAAAAAzCYnd4GZ5geSNrtHs6S3yNn+dqukfzTGvD7GeyIXRb0Rp/5oxPmCefQJAAAAAACSlPMjQKy1lyVdjniqXdL/Ncb8nqRvSXrEGPNOa+1DEfdcjziPN2EqcindkRnvmlm8aTPVcnoGAAAAAAAzyPkAZCbW2n9wR3+8SdIXjTGPWGsvuS8PRtwab1pLWcR5vOkysfqYdY0RZ0deAAAAAAAwG6bAzO4R97FM0msino8MJeItUho5goP1PAAAAAAA8AAByOzOR5yvijg/EXG+Pk6NyNdPzrsjAAAAAACQMAKQ2dVFnEdOX3lJUrd7vjdOjXvdxy5JL6emLQAAAAAAkAgCkNn9TsT5sakTa63Vzekx640xLbHe7D4/NQLkEfd9AAAAAAAgw3IyADHGvN0YUxLnnvdIeq17+bKkA9Nu+Zykcff8C8aYqC1u3esvuJfj7v0AAAAAAMADuboLzJ9J+owx5ntygo0zcqa4LJK0WdL/L2m3e+8NSX9orR2PLGCtfd4Y82lJH5K0U9JBY8xfubXWSPqgpG3u7Z+y1p5O63cEAAAAAABmlKsBiCQtk/SH7jGTTknvsNb+YobXPyKpUtI75IQd/zfGPd+U9NF59AkAAAAAAOYpVwOQV0n6VUm/ImmDpCpJyyVdl9Qn6SlJP5L0HWvt8ExFrLWTkt7pjiR5QFKTpApJA5LaJX3VWvuTNH4fAAAAAABgDnIyALHWnpEzVeWrKar3Y0k/TkUtAAAAAACQejm5CCoAAAAAAMgtBCAAAAAAACDwCEAAAAAAAEDgEYAAAAAAAIDAIwABAAAAAACBRwACAAAAAAACjwAEAAAAAAAEHgEIAAAAAAAIPAIQAAAAAAAQeAQgAAAAAAAg8AhAAAAAAABA4BGAAAAAAACAwCMAAQAAAAAAgUcAAgAAAAAAAo8ABAAAAAAABB4BCAAAAAAACDwCEAAAAAAAEHgEIAAAAAAAIPAIQAAAAAAAQOARgAAAAAAAgMAjAAEAAAAAAIFHAAIAAAAAAAKPAAQAAAAAAAQeAQgAAAAAAAg8AhAAAAAAABB4BCAAAAAAACDwCEAAAAAAAEDgEYAAAAAAAIDAIwABAAAAAACBRwACAAAAAAACjwAEAAAAAAAEHgEIAAAAAAAIPAIQAAAAAAAQeAQgAAAAAAAg8AhAAAAAAABA4BGAAAAAAACAwCMAAQAAAAAAgUcAAgAAAAAAAo8ABAAAAAAABB4BCAAAAAAACDwCEAAAAAAAEHgEIAAAAAAAIPAIQAAAAAAAQOARgAAAAAAAgMAjAAEAAAAAAIFHAAIAAAAAAAKPAAQAAAAAAAQeAQgAAAAAAAg8AhAAAAAAABB4BCAAAAAAACDwCEAAAAAAAEDgEYAAAAAAAIDAIwABAAAAAACBl7MBiDFmuzHmw8aYnxhjQsaYUWPMNWPM88aYh4wx98yhxtuNMXaOx9sz8G0BAAAAAIAYCrxuwAvGmP2S7o3xUpGk293jbcaYf5B0v7X2Rib7AwAAAAAAqZWTAYikOvexW9J3JT0u6ZykfEm7JL3Xvef35PwavXUONX/NrTeTzmSbBQAAAAAA85OrAcgpSR+W9D1r7cS01w65Iz8OSrpD0luMMV+21j4ep+bz1tqXU98qAAAAAACYr5xcA8Ra+3pr7XdihB9Trw/IGQUy5Y2Z6QwAAAAAAKRDTgYgc/TLiPM1XjUBAAAAAADmjwBkZkUR55OedQEAAAAAAOaNAGRmeyPOT83h/oeMMX3GmBvGmAFjzCFjzCeMMXXx3woAAAAAANIpVxdBnZUxJk/ShyKe+s4c3hYZmCx3j7skvdcY825r7VeT7KU+zi3VydQFAAAAACCXEIDE9h5Jze759621h2e590VJD0tqlRRyn1st6bflLJ5aIukrxhhrrf1aEr2E4t8CAAAAAABmY6y1XveQVYwxeyX9Qk441C9pi7W2b4Z7F0u6amf4RTTGvF5OOFIoaVjSGmttb4L9zPk/UCgUUn19vAEjAAAAAAAkr7OzUw0NDVOXDdbaTi/7mSvWAIlgjNkk6ftywo9RSW+aKfyQJGvtlZnCD/f1H0n6uHtZKumdSbTVEOdoSqImAAAAAAA5hQDEZYy5TdK/SVoqaULSW6y1+1NQ+uuSpkKSvbPdGIu1tnO2Q1JCI0oAAAAAAMhFBCCSjDG1cqa91MoJK95hrf1+Kmpba/slDbiX7AgDAAAAAIAHcj4AMcZUSPq5nIVLJeld1tq/T/WXSXE9AAAAAACQgJwOQNxFTH8maaP71IestV9K8deolLMlriR1p7I2AAAAAACYm5wNQIwxpZL+VdJ296lPWmv/Kg1f6gHdHAGSijVFAAAAAABAgnIyADHGFMnZ7WW3+9TnrbUfTbBGozFmW5x7Xi/pY+7ldUl/l2ivAAAAAABg/gq8bsAj35b0avf8PyR90xhz5yz337DWPj/tuUZJjxpjWiX9i6SnJPXLGe2xWtIb3WNq9Mf7rLVdqWkfAAAAAAAkIlcDkN+KOH+lpGfi3H9WTuARyy73mMmwpPdYa7825+4AAAAAAEBK5WoAkgpHJP2unPBjp6QaSRVyfk0vSTou6d8lfcPdChcAAAAAAHgkJwMQa+28t6W11g5K+kf3AAAAAAAAWSwnF0EFAAAAAAC5hQAEAAAAAAAEHgEIAAAAAAAIPAIQAAAAAAAQeAQgAAAAAAAg8AhAAAAAAABA4BGAAAAAAACAwCMAAQAAAAAAgUcAAgAAAAAAAo8ABAAAAAAABB4BCAAAAAAACDwCEAAAAAAAEHgEIAAAAAAAIPAIQAAAAAAAQOARgAAAAAAAgMAjAAEAAAAAAIFHAAIAAAAAAAKPAAQAAAAAAAQeAQgAAAAAAAg8AhAAAAAAABB4BCAAAAAAACDwCEAAAAAAAEDgEYAAAAAAAIDAIwABAAAAAACBRwACAAAAAAACjwAEAAAAAAAEHgEIAAAAAAAIPAIQAAAAAAAQeAQgAAAAAAAg8AhAAAAAAABA4BGAAAAAAACAwCMAAQAAAAAAgUcAAgAAAAAAAo8ABAAAAAAABB4BCAAAAAAACDwCEAAAAAAAEHgEIAAAAAAAIPAIQAAAAAAAQOARgAAAAAAAgMAjAAEAAAAAAIFHAAIAAAAAAAKPAAQAAAAAAAQeAQgAAAAAAAg8AhAAAAAAABB4GQ9AjDGlxpjSWV5/lzHmcWPMSWPMj40xr89kfwAAAAAAIHgyGoAYY35d0qCkbmPMohiv/29Jn5N0t6R1kn5N0iPGmA9ksk8AAAAAABAsmR4B8muSjKQfWGsHI18wxuyR9Hb3clhSh6Tr7v2fMMZsymCfAAAAAAAgQDIdgLRIspIejfHaA+5jt6QN1todktZLCknKl/RHGekQAAAAAAAETqYDkEr38XSM1+6TE458wVrbKUnW2pCkL8gZBbI3Ix0CAAAAAIDAyXQAssJ9vBb5pDFmo6QK9/KH095z2H1sTF9bAAAAAAAgyDIdgEy4j8umPX+P+3jeWntq2muX3MeStHUFAAAAAAACLdMBSJf7uHXa86+TM/3l8RjvWew+DqSrKQAAAAAAEGyZDkAel7Oex381xlRIkjGmSc76H5L0sxjv2eA+9qa/PQAAAAAAEESZDkD+VtKkpNskvWiMOSxpv6QCOVNd/inGe14pZ3TIU5lqEgAAAAAABEtGAxBr7VFJ75cTaCyUtF3O2h5jkv7QWjsYeb8xZrGc6TGS9PNU9mKM2W6M+bAx5ifGmJAxZtQYc80Y87wx5iFjzD3xq0TVu88Y87AxptOt1ele3xf/3QAAAAAAIJ0KMv0FrbWfNcb8QtIbJVVL6pH0bWvtczFu3yep3T3/Rap6MMbsl3RvjJeKJN3uHm8zxvyDpPuttTdmqWUkfUXSA9NeqpP0BklvMMZ8TdKD1lqbiv4BAAAAAEBiMh6ASJK19pikY3O47xFJj6ShhTr3sVvSd+WsTXJOUr6kXZLe697ze3J+jd46S61P6Gb40SHpryWdkbRG0gckbXNfPy/po6n8JgAAAAAAwNyYXByUYIz5kaS/l/Q9a+1EjNcrJB2UdIf71L3W2lt2qDHGrJV0Uk5Icti9byTi9VI5a5zslDQuab219kyKv5d6SSFJCoVCqq+vT2V5AAAAAACidHZ2qqGhYeqywVrb6WU/c5XpRVBvYRxrjDFN7rHGnVaSNtba11trvxMr/HBfH5AzCmTKG2co9R7dHEXzrsjww60zLOld7mWBpHcn3zUAAAAAAEiWZwGIMeY1xph/kXRV0vOSDrnH85KuGmP+xRjzGq/6k/TLiPM10190Q5rfcC9PWWsPxSriPj+1vslvpjvcAQAAAAAAt8p4AGKMKTPG/EDSjyS9VlKZJDPtKHNf+5Ex5vvGmLJM9ylnQdQpkzFev0031xLZH6fW1Ov1khrn1xYAAAAAAEhURhdBNcbkSfqJpN1ygo4xSf8mqU1Sn/tcpaQmSa+WE0L8Z0k/Nsbsy/AuKnsjzk/FeH1DnNc1w+sbJL2UbFMAAAAAACBxmd4F5kFJeyRZST+Ts8VsV6wbjTF1kr4u6T73PQ9K+nImmnSDmg9FPPWdGLc1RJzHW/AlNMP75tJLvFVNqxOpBwAAAABALsp0APL77mO7pNdZa2NNLZEkWWu7jDG/Lmc3lmZJb1OGAhA5i5s2u+fft9YejnHPoojza3HqDUWcL0ywl1D8WwAAAAAAwGwyvQbIBjmjPz47W/gxxd2l5X9FvDftjDF7Jf2le9kv6b/McGtJxPmNOGVHI84XJNkaAAAAAABIUqZHgEyt4fF8Au85Pe29aWOM2STp+3J+XUYlvcla2zfD7dcjzotmuGdKccT5yIx3xRZvyky1nBE1AAAAAABgBpkOQM5I2ipnodO5mrr3TOrbuckYc5ucBVmXSpqQ9BZr7Wy7uwxGnMeb1hK5i0286TJRrLWzri/CrroAAAAAAMSX6Skw35az08vvx7sxwu/LGf3xT2npSJIxplbSLyTVul/rHdba78d5W2QwEW+h0shRHKzpAQAAAABAhmU6APkbSUclvdkY84F4Nxtj3i/pLZI6JH0uHQ0ZYyok/VzSavepd1lr/34Obz0Rcb4+zr2Rr59MoD0AAAAAAJACmZ4CUy3pfklflfQXxpi3SPqWnDUs+uWMvqiS1CTp9+RMl2mX9ICk6pmme1hrzyXTjDFmsZzteDe6T33IWvulOb79JUndckaN7I1z773uY5eklxNsEwAAAAAAzFOmA5CXFb2Y6RZJn4nznp1yRo3MxCqJ78MYUyrpXyVtd5/6pLX2r+b6fmutNcY8ImeXmPXGmBZr7aEYX6dFN0eAPGKtTftirgAAAAAAIFqmp8BIzhogqT4Sa8CYIjm7vex2n/q8tfajSXwvn5M07p5/wRgTtcWte/0F93JcaZrGAwAAAAAAZpfpESB/kOGvN5NvS3q1e/4fkr5pjLlzlvtvWGtv2brXWvu8MebTkj4kZ6TKQWPMX8nZsWaNpA9K2ube/ilr7enpNQAAAAAAQPqZXJyRYYxJ9Js+a61tnKFWnqSvS3rHLO//pqQHrLWTCX7duIwx9XJ3lgmFQqqvj7chDQAAAAAAyevs7FRDQ3iz0wZrbeds92cLL6bABIq1dtJa+05Jr5P0iJyFUW+4j49Ieq219v50hB8AAAAAAGBuMj0FJswdObFP0i45u8OUSvqotbYn4p4iOT1OWGtHU/W1rbUJrxsyh5o/lvTjVNcFAAAAAADz50kAYox5naS/kdQ47aXPSOqJuH6npC9KumaMqbXWDmWmQwAAAAAAECQZnwJjjLlf0g8l3SZnB5cLmnknl29KuixpoaQ3ZKRBAAAAAAAQOBkNQIwxayV9yb38D0kbrbWVM91vrb0h6XtyApJXz3QfAAAAAADAbDI9AuTdkgolHZezOOipObzncfdxa9q6AgAAAAAAgZbpAORVkqykz7mjO+bijPu4Mj0tAQAAAACAoMt0ADK1UfBTCbxnauHT0hT3AgAAAAAAckSmAxDrPiayDe0K9/FqinsBAAAAAAA5ItMBSLf7eEcC79nrPr6c2lYAAAAAAECuyHQA8pic0R9vncvNxpgKSX8kZ+TIf6SxLwAAAAAAEGCZDkC+5j6+1hjzB7PdaIypl/RjSRWSJiLeCwAAAAAAkJCMBiDW2nZJX5EzCuQbxpjvGmPeFHHLFmPM/2eM+aak5yTtkDP64zPW2hcy2SsAAAAAAAiOAg++5rsklUn6PUm/5R5Ti6P+Y8R9UwulPiTpw5lqDgAAAAAABE+mp8DIWjthrX2bpN+R1CEn6Ih1nJD0VmvtO6y1dqZ6AAAAAAAA8XgxAkSSZK39nqTvGWNqJe2UVCkpX9IFSR3W2jNe9QYAAAAAAILFswBkirW2W9IPve4DAAAAAAAEV8anwAAAAAAAAGQaAQgAAAAAAAg8ApAA+ci/f0QPPfWQjvcf18TkhNftAAAAAACQNQwbrPibMaZeUkiS9B5Ji53nFxYt1I6aHWqqbVJTXZOaapvUuKRRxpgZawEAAAAAEE9nZ6caGhqmLhustZ1e9jNXni+CivS4duOa9p/dr/1n94efqyit0M7anWqubQ6HIlULqzzsEgAAAACAzCAAySEDwwP66Qs/1U9f+Gn4uYbyBjXVNYVDkR01O7S4ZLGHXQIAAAAAkHoEIAFy3+336fj14wpdDc35PaGrIYWuhvTwyYfDz61bvi48QqS5rllbq7eqpKAkHS0DAAAAAJARrAHic5FrgIRCIdXX16vvWp/au9vV3tWutu42tXe168LIhaS/RkFegTZXbo5aT2RT5SYV5JGfAQAAAECu8esaIAQgPhcrAJnOWquXL78cFYoc6T6iobGhpL/ugoIF2l6zPSoUWbtsLYusAgAAAEDAEYDAE3MJQGKZmJzQqYFT4VCkvbtdT/U+pbHJsaR7WVqyVDtrd0aFInXldUnXAwAAAABkHwIQeCLZACSW0fFRPdP3jBOKuMHIifMnZJX875GahTVqrmsOhyI7a3dq2YJlSdcDAAAAAHiLAASeSGUAEsvg6KCO9hyNCkVeuvzSvGquWbomaueZbdXbVFZUlqKOAQAAAADpRAACT6Q7AIllYHggPG1mKhTpG+pLul6eydOmFZvCo0Sa65q1uXKzCvMLU9g1AAAAACAVCEDgCS8CkOmsteq82qn27na1dbWpvbtdh7sP6+ro1aRrFucXa2v11qj1RNZVrFOeyUth5wAAAACARBGAwBPZEIDEMmkndfrC6aidZzp6OjQ6MZp0zfLicu2o2REViqxcvJKdZwAAAAAggwhA4IlsDUBiGZsY07P9z0aFIsf7j2vCTiRdc0Xpiqj1RJpqm7SibEUKuwYAAAAARCIAgSf8FIDEMjw2rI6ejqj1RE5fPD2vmqsWrwqHIc11zdpRs0OLihelqGMAAAAAyG0EIPCE3wOQWC6NXNLh7sNRoUjXYFfS9YyM1lesD4ciTbVNekX1K1RSUJLCrgEAAAAgNxCAwBNBDEBi6R7svmXnmUvXLyVdrzCvUFuqtkStJ7JxxUbl5+WnsGsAAAAACB4CEHgiVwKQ6ay1evHSi1E7zxztOarhseGka5YWlmp7zfao9URWL13NIqsAAAAAEIEABJ7I1QAklvHJcZ08fzIqFHmm7xmNT44nXXPZgmXaWbszPHWmua5ZNYtqUtg1AAAAAPgLAQg8QQAyu+vj1/V079PhqTNtXW16buA5WSX/+75uUV3UeiI7a3dq6YKlKewaAAAAALIXAQg8QQCSuKujV3Wk+0hUKHLuyrl51bx92e1Roci2mm0qLSxNUccAAAAAkD0IQOAJApDU6B/qv2WR1fPD55Oul2/ytalyU9R6IndW3qnC/MIUdg0AAAAAmUcAAk8QgKSHtVbnrpwLryXS3t2uI91HNHhjMOmaJQUl2lq9NbyWSFNtk25ffrvyTF4KOwcAAACA9CIAgScIQDJn0k7quYHnokKRp3qf0o2JG0nXXFy8WDtqd0SFIvXl9ew8AwAAACBrEYDAEwQg3roxcUPH+o6Fp820dbfpxPkTmrSTSdesKquKWk+kqa5JFaUVKewaAAAAAJJHAAJPEIBkn2s3rqmjpyNqkdUXL704r5q3LbktKhTZUbtDC4sWpqhjAAAAAJg7AhBHW0hmAAAgAElEQVR4ggDEHy4MX9Dh7sNRoUjvtd6k6+WZPG2o2BAVimyp2qLiguIUdg0AAAAAtyIAgScIQPzJWquuwa6onWcOdx/W5euXk65ZlF+kV1S9Ijxtpqm2Sesr1is/Lz+FnQMAAADIdQQg8AQBSHBM2kmduXgmPEKkvbtdHT0dGhkfSbrmwqKF2lGzIyoUaVzSyCKrAAAAAJJGAAJPEIAE2/jkuI73H49aZPVY3zFN2Imka1aUVmhn7U411zaHQ5GqhVUp7BoAAABAkBGAwBMEILlnZGxET/U+FZ46097VrucuPDevmg3lDWqqawqHIjtqdmhxyeIUdQwAAAAgSAhA4AkCEEjS5euXdaT7SFQoEroamlfNdcvXhUeINNc1a2v1VpUUlKSoYwAAAAB+RQACTxCAYCa913qjFllt72rXhZELSdcryCvQ5srNUeuJbKrcpIK8ghR2DQAAACDbEYDAEwQgmCtrrV6+/HLUeiJHuo9oaGwo6ZoLChZoe832qFBk7bK1LLIKAAAABBgBCDxBAIL5mJic0KmBU1GhyNO9T2tscizpmktLlmpn7c6oUKSuvC6FXQMAAADwEgEIPEEAglQbHR/VM33PRE2dOXH+hKyS/39FzcIaNdc1h0ORnbU7tWzBshR2DQAAACBTCEDgiagARFJU/PGv/yq99rVetIWAGRwd1NGeo1GhyEuXX5pXzTVL10TtPLOtepvKispS1DEAAACAdCEA8RljTKWkZvdoco/l7svfsta+fQ413i7p7+b4Jf/AWvtQwo3G72HmAGQmoZDESBHM08DwwC2LrPYN9SVdL8/kadOKTeFRIs11zdpcuVmF+YUp7BoAAADAfBGA+IwxZrZvPNgBSCz/8A/S7/5uqtpCDrLWqvNqp9q62sKhyOHuw7o6ejXpmsX5xdpavTUqFLlj+R3KM3kp7BwAAABAIghAfGZaABKSdFLSq93rZAKQX5PUPcvtndbay4l3GreH1AQgMzl3Trr5GxtIyKSd1OkLp9Xe3R4ORjp6OjQ6MZp0zfLicu2o2REVijSUN7DzDAAAAJAhBCA+Y4z5uKR2Se3W2j5jTKOkqUUNkglAbrPWvpzyRuP3kN4AJJaHH5be8IZMfCUE0NjEmJ7tfzZq55nj/cc1YSeSrllVVhVeZLW5zllThEVWAQAAgPQgAPE5ApB52rVLOnBAymNqAhI3PDasjp6O8NSZtq42vXDxhXnVXLtsbVQosq16mxYULkhRxwAAAEDu8msAUuB1AwiI1lYpP//W50+ckDZsyHw/8JXSwlLtXrlbu1fuDj93aeSSDncfjlpktWuwa841X7j4gl64+IL+z7H/I0kqyCvQ5srNUaHIxhUblZ8X4/ctAAAAgMBhBIiLESAZ9KMfSa97ndddwIe6B7tv2Xnm0vVLSdcrKyzTjtod4UCkua5ZqxavYj0RAAAAYBZ+HQFCAOJKQQCyX9IGSUslXZX0gqRfSPqytXbuP7a+9WvEyzSq5axl4p8AJJYvfUn64z/2ugv4jLVWZy6dUVtXW3iR1aM9R3V9/HrSNVeUrgiHIVMLrVaUVqSwawAAAMDfCEB8LgUByEyuS3q3tfarSfY15/9AoVBI9UHasaW6WursjD21BpjB1CKrkaHI8fPHNWknk665eunqqKkz22u2q7SwNIVdAwAAAP5BAOJz8whAPibpYUmtcqeiSFot6bclvVHS1Fj6P7LWfi2JvhILQOpnGAMSpCH9vb1SVZXXXcBHrt24pqM9R6NCkZcvv5x0vXyTrzsr74wKRTZVblJBHssqAQAAIPgIQHwuyQBksaSrdoZfRGPM6+WEI4WShiWtsdb2JtjX3KfAzBaAxC6eSCvZ7dQpad06r7uAj/QP9Tvb8Ha1qa27Te1d7bowciHpegsKFtyynshtS25jPREAAAAEDgGIzyUTgMyx7kckfcK9/Ki19pOpqBtR/+YiqIkGIDMXnX+NbNDWJjU1ed0FfMJaq5cuvxQeJdLW1aajPUc1Mj6SdM3lC5ZHjRJpqmtSZVllCrsGAAAAMo8AxOfSGIBUSuqVMxXm59baV6eibkT91Acgsb9Qeupm2v790r33et0FfGJ8clzH+4/fDEW62/Rs/7PzWk+kcUljVCiyo2aHyorKUtg1AAAAkF4EID6XrgDErd0vaYWkE9baTamq69bOTAAycwOZ/Xrp8POfS7/6q153AZ8YujGkjt6OqJEiL11+Kf4bZ5Bv8rWlaot21e9SS32LWupbtHbZWqbOAAAAIGsRgPhcmgOQ85IqFMQAJJYgfHD72c+kV6d0sA4CbGB4IGo9kbauNg0MDyRdb/mC5eEwpKW+Rc11zSovLk9hxwAAAEDyCEB8LkNTYH5hrf1PqagbUT/7ApBYghCK/OQn0n33ed0FfMBaq7NXzkaNEjnSc0TDY8NJ1TMy2lS5SS11LdrV4IwUWV+xXnkmL8WdAwAAAPH5NQBhz8b0e0A3t8Ld72UjnooVtBUWSuPjme8lWa95za3P/du/Sf8ppZkWAsAYo8YljWpc0qg3bXqTJGc9kZPnT0atJ3Ks75gm7ETcelZWz/Y/q2f7n9U3Or4hSVpcvFh31d+lljpnlMhd9Xdp2YJlaf2+AAAAAD9jBIgr0REg7v1LrbUds9zzeknfk1Qk6bqktdbarvl3G/U1/DECJBF+Hy3y6KPSvn1edwEfGLoxpMPdh3Wo85AOdR1Sa6hVfUN9Sddbt3ydWupbwuuJbKrcpII8cm4AAACkll9HgORsAGKM2SNpbcRTFZI+5Z4flPSNyPuttQ9Ne/8+SY9KapX0L5KektQvZ7THaklvdI+pT/P/1Vr7pVR+D24fwQtAYvF7KNLaKrW0eN0FstzU1JlDnYd0qPOQWjtb1dHTobHJsaTqlRWWqbmuOWo9EbbhBQAAwHwRgPiMMeYhSW+b6/3W2qhP4BEBSDzDkt5jrf1aIv3NVc4EILH4PRTp6JC2bvW6C2S56+PX1dHTodbO1nAwEroaSrre6qWrnTDEXU9kS9UWFeUXpbBjAAAABB0BiM+kIABZJOk/S9olaaekGjmjSAokXZJ0XNK/S/qGtbY/NV3fKqcDkFj8HoqcPi2tXRv/PuS0rqtdUaNEjvQc0fXx60nVKiko0Y6aHVHb8NaV16W4YwAAAAQJAQg8QQAyB34PRfr6pEqmLWBmNyZu6Jm+Z9QaatWhLicYefHSi0nXqy+vjwpEttdsV0lBSQo7BgAAgJ8RgMATBCBJ8nsoMjoqFTFtATPrH+oPjxI51HlIbV1tGhobSqpWYV6httVsi9qGd9XiVTJ+/3MEAACApBCAwBMEICnk5w9zH/+49D/+h9ddIIuNT47reP/x8LSZQ52H9NyF55KuV1VW5YQh7ja8O2t3qqyoLIUdAwAAIFsRgMATBCBp5udQ5ItflP7kT7zuAlns4shFPdn5ZHgb3ic7n9SV0StJ1co3+dpStSVqG961y9YySgQAACCACEDgCQIQD/j5A90//ZP0pjd53QWy1KSd1KmBU1ELrB7vPy6r5P6eWL5gue6qvysciDTXNau8uDzFXQMAACDTCEDgCQKQLOHnUOTRR6V9+7zuAlnq6uhVtXe1R23De2HkQlK1jIw2VW4KT5vZ1bBL6yvWK8/kpbhrAAAApBMBCDxBAJLF/ByKnDghbdjgdRfIQtZavXDxBbV2turJzifV2tmqZ/qe0YSdSKpeeXG57qq7Kzx15q76u7RswbIUdw0AAIBUIgCBJwhAfMbPocilS9KSJV53gSw0dGNIR3qOhKfNtIZa1TfUl3S9O5bfEbUN752Vd6ogryCFHQMAAGA+CEDgCQKQAPBrKPJnfyb96Z963QWykLVW566ci5o2c7TnqMYmx5KqV1ZYpqa6pvDUmZb6FlUtrEpx1wAAAJgrAhB4ggAkoPwainz969L993vdBbLQ9fHr6ujpCO840xpqVehqKOl6ty25LWrHmVdUv0JF+UUp7BgAAAAzIQCBJwhAcohfQ5Gf/ES67z6vu0AW6rrapSe7ngxPnTncfVjXx68nVaukoEQ7anaER4jsqt+luvK6FHcMAAAAiQAEHiEAyWGbN0vPPut1F8k5flzauNHrLpBlxibG9EzfM1FTZ85cOpN0vfryeicQqXN2nNles10lBSUp7BgAACA3EYDAEwQgiOLXUSKSNDQklZZ63QWyzPmh8+Ew5FDXIbV1tenajWtJ1SrMK9TW6q1RC6w2LmmU8fOfGwAAAA8QgMATBCCIy68f7j71Kel97/O6C2SZickJHT9/PByKtHa26tTAqaTrVZVVhcOQlvoWNdU2qayoLIUdAwAABA8BCDxBAIKk+DUU+e53pTe+0esukGUujVxSW1dbOBB5sutJXb5+Oala+SZfm6s2h6fNtNS36PZltzNKBAAAIAIBCDxBAIKU8esHvKNHpW3bvO4CWWTSTur5C8+rNdQanjrzbP+zmrSTSdVbtmBZeC2RlvoWNdc1a3HJ4hR3DQAA4B8EIPAEAQjSyq+hyNWr0qJFXneBLDI4Oqj27vaoqTMDwwNJ1TIy2rhiY9TUmY0rNirP5KW4awAAgOxEAAJPEIAgo/y68wzriWAaa61evPRiVCDydN/TGp8cT6peeXG5muuaw1Nn7qq7S8tLl6e4awAAgOxAAAJPEIDAc34dJfKDH0i/8Rted4EsMjw2rKM9R52pM12H1BpqVc+1nqTr3b7sdmcdEXfqzOaqzSrIK0hhxwAAAN4gAIEnCECQlfwaipw8Ka1f73UXyBLWWoWuhm5uw9t5SEd6jujGxI2k6pUWlqqptilq6kz1wuoUdw0AAJB+BCDwBAEIfMOPoch73yt9+tNed4EsMjo+qqd6nwpPmznUeUhnr5xNul7jkka11LdoV72z48zW6q0qyi9KYccAAACpRwACTxCAwNf8GIp8/evS/fd73QWySM9gz81RIl2H1N7VrpHxkaRqFecXa3vN9nAg0lLfoobFDfHfCAAAkEEEIPAEAQgCJT9fmkxuq1JPHTwo3X23110gS4xNjOlY/7GoBVZfuPhC0vXqFtVFTZvZUbNDCwoXpLBjAACAxBCAwBMEIAg8P44SkaQrV6Tycq+7QJYYGB7Qk51PhqfNtHW1afDGYFK1CvIKtLV6q3bV79LdDXdrV/0urVy8Usavf1YAAIDvEIDAEwQgyEl+/KD3uc9J//2/e90FssTE5IROnD8RNXXmxPkTSderXVQbDkPubrhb26q3qbigOIUdAwAA3EQAAk8QgAAuP4Yiv/iF9KpXed0FssTl65fV1tUWtcDq5euXk6pVnF+sHbU7okaJ1CyqSXHHAAAgVxGAwBMEIMAM8vIkP/7/rb9fWrHC6y6QBSbtpE5fOB0OQw51HtKx/mOatMmtk9O4pDFqlMiWqi0qyCtIcdcAACAXEIDAEwQgQAL8OErkU5+S3vc+r7tAlhgcHVR7d7sOdR7SE6En1NrZqosjF5OqVVpYqua6Zt1df7d2NezSrvpdWl66PMUdAwCAICIAgScIQIB58mMo8vOfS7/6q153gSxgrdXzF55Xa2drOBA53n9cVsn93b5u+TrtatgVDkU2rtioPJOX4q4BAIDfEYDAEwQgQIqdOiVt2OB1F4kbGJCW89N7OGuJTO0480ToCT3Z9aSujl5Nqtbi4sVqqW8JT5u5q/4ulRezuxEAALmOAASeIAABMsCPo0Q++1np3e/2ugtkgakdZ6ZGiDwRekKnL55OqpaR0Z2Vd4YDkbsb7tbaZWvZghcAgBxDAAJPEIAAHvHjB77HH5f27PG6C2SB80Pnw7vNPBF6Qm1dbRoZH0mqVkVphXbV7wqHIk11TSotLE1xxwAAIJsQgMATBCBAFvFjKDIyIpWUeN0FPDY2MaZn+p6JGiVy9srZpGoV5BXoFVWviNpxZuXilYwSAQAgQAhA4AkCECCL+fED3ze+Ib3znV53gSzQPdit1tDNxVWP9BzRjYkbSdWqWVgTnjKzq36XttdsV3FBcYo7BgAAmUIAAk8QgAA+48dQ5JlnpM2bve4CHhsdH9XRnqPhQORg6KB6r/UmVas4v1hNdU3a07BHu1fu1t0Nd2vZgmUp7hgAAKQLAQg8QQACBIDfQpEPf1j65Ce97gIes9bq7JWzUaNEnup9ShN2Iql6m1Zs0p6Ve7Rn5R7tbtitxiWNTJsBACBLEYDAEwQgQAD58UPfD38o/fqve90FPDZ0Y0jt3e1OKNL5hFpDrbowciGpWrWLap1ApMEJRTZXbVZBXkGKOwYAAMkgAIEnCECAHOHHUOT8eamiwusu4CFrrU5fPB01SuTZ/mdllfi/PRYWLdSu+l3hUSJ31d2lsqKyNHQNAADiIQCBJwhAgBzmt1DkS1+S/viPve4CHrty/Yqzhsi5gzoQOqAnO59MagvefJOv7TXbtbthtzNtZuVuVS+sTkPHAABgOgIQeIIABECY3wIRSXr6aWnLFq+7gIduTNxQR0+HDpw7oAOhAzpw7oAGhgeSqrV22drwGiJ7Vu7RuuXrWEcEAIA0IACBJwhAAMzKbx/+PvYx6c//3Osu4KGpaTMHzh0IH6cvnk6qVkVpRTgM2bNyj7bXbFdRflGKOwYAIPcQgMATBCAAEua3UORnP5Ne/Wqvu4CH+q716WDoYHjazNGeoxqfHE+4TklBiZrrmsMLq+5q2KUlJUvS0DEAAMFGAAJPEIAAmDe/BSKSdP26VFzsdRfwyNCNIbV1tYWnzbSGWjV4YzDhOkZGd1beGR4hsmflHq1cvDINHQMAECwEIPAEAQiAtPBbKPLtb0tvfrPXXcAjE5MTOtZ/LDxl5vFzj6t7sDupWg3lDdq9cnd4lMidlXcqPy8/xR0DAOBvBCDwBAEIgIy44w7pdHLrMHimp0eqZleQXGSt1dkrZ50pM+4okWf7n02qVnlxue5uuFt7GpydZprrmlVaWJrijgEA8BcCEHiCAASAZ/w2SuTLX5YefNDrLuCRiyMX1RpqDQci7V3tGp0YTbhOQV6BdtTsCO82s3vlblWWVaahYwAAshcBCDxBAAIgq/gtFHn+een2273uAh4YHR/VkZ4j4WkzB0MHdXHkYlK17lh+R3jKzO6Vu3X7stvZfhcAEGgEIPAEAQiArOa3D4Gf/rT03vd63QU8MGkn9dzAc+ERIgfOHdCLl15MqtaK0hVRC6tuq96mwvzCFHcMAIB3CEDgCQIQAL7jt1Dk6aelLVu87gIe6B7sDq8jcjB0UB29HZq0kwnXWVCwQC31LdrdsDu8/W55cXkaOgYAIDMIQOAJAhAAvldZKZ0/73UXc/eJT0gf+YjXXcADg6ODOtR5SAdDTihyqPOQhsaGEq6TZ/K0pWpLOBDZs3KP6sv5+xsA4B8EIPAEAQiAQPLbKJHDh6UdO7zuAhk2Pjmup3ufjpo203utN6laqxavCochuxt2a1PlJuWZvBR3DABAahCAwBMEIAByhp9CkT//c+ljH/O6C2SYtVYvXnoxPELkwLkDOjlwMqlaS0qWhLff3bNyj5rqmlRSUJLijgEASA4BCDxBAAIgZ/kpEJEYJZKjBoYH9EToifA6Iu1d7RqbHEu4TmFeoXbW7gyPErm74W5VlFakoWMAAOIjAIEnCEAAIIKfQhFGieSkkbERHe4+HJ4280ToCV2+fjmpWhsqNkStI7J66Wq23wUAZAQBiM8YYyolNbtHk3ssd1/+lrX27QnWu0/SA269FZLOS2qT9DVr7U9T1HasrxsOQH7+85Be8Yp6LV8u5TFtGAD8FYhIUkeHtHWr110ggybtpE6cPxGeMnPg3AGdvXI2qVrVC6vDa4jsWblHW6u3qiCvIMUdAwBAAOI7xpjZvvE5ByDG+VHLV+SEHzP5mqQHbRp+sSMDEOehXvn50ooVUlVV/KOiQirg30YAcomfQpG//Evpgx/0ugtkWOfVzvD2uwdCB/R079OySvyfEGWFZWqpbwmHIi31LVpUvCgNHQMAcg0BiM9MC0BCkk5KerV7nUgA8klJH3YvOyT9taQzktZI+oCkbe5rn7TWfnSebcf6+rcEIIm93wlBZgtJqqudxxUrpMLCVH8HAOAxPwUiknTypLR+vdddIIOuXL9yy/a7I+MjCdfJM3naWr1V96y8R3tX7dU9q+5hHREAQFIIQHzGGPNxSe2S2q21fcaYRkkvuS/PKQAxxqyVE5wUSDos6V5r7UjE66WS9kvaKWlc0npr7ZkUfhvzDkAStXx5dCgyPSSZOiorCUsA+JifQpG/+RvpXe/yugtk0NjEmDp6O8ILqx44d0D9Q/1J1dq4YqPuXXmv9jbu1b2r7lXtotoUdwsACCICEJ9LMgD5kqQ/di93WWsPxbinRVKre/lFa21K/5Wa6QAkEdPDksiQJPK5FSuYhgMgy+XlSX76+zIUklgUO2dYa/XCxRduriMSOqDnLzyfVK01S9do7yonDLl31b1qXNLIwqoAgFsQgPhcogGIu/ZHSFKdpFPW2g2z3HtK0jpJnZJWpnItkMgA5MyZkIqL69XXp7jHwED2/Ft+ahrO9KCkuvrW5yoqWOAVQJbw04fCb31L+v3f97oLZFD/UH94+90D5w7oSM8RjU+OJ1ynvrw+KhBZt3wdgQgAgADE75IIQFbLWetDkr5qrX1wlnu/qpuLpK621r40072JSnYb3PFxJwSJF5T09krnz0uTk6nqeH7y853pNbGCkunXS5b46/MJAJ8rKJAmJrzuYu6GhqTSUq+7QIYMjw2rratNj599XI+de0xPhJ7Q8NhwwnUqyyqdMGSlE4hsrtqsPMNPJgAg1/g1AGHiQfIiR3ycinNv5OsbdDNo8UxBwc2gIJ6JCenChZkDksjr/v70/vt/YkLq6XGOeIqKYocksQ4+AwCYt/EYP13P5hS2rCz6+kc/kl73Om96QdqVFpZqX+M+7WvcJ8lZR+RIzxE9dvYxPXb2MR04d0BXRq/ErdM/1K9/PvHP+ucT/yxJWlKyRPesvCc8QmRb9TYV5rMIGAAgOzECxJXECJAHJX3Zvfwda+0/z3LvGyV917180Fr71QT6ijeko1rOYq4JjQBJl8lJJyyZHoxEXk+d9/dnz8iSRYvihyQ1NaxXAmCe8vOz53988bz//dJf/7XXXSBDJiYndKz/mPa/vF+PnXNCkYHhgYTrlBWWaffK3eERIk11TSopKElDxwAAL/l1BAgBiCuJAOT9cra8laTXWGt/Osu9r5H0Y/fyfdbazyTQ15z/A2VDAJKIqZElU4FIb2/0eV+fM9Jjas2SbGCME4JMD0ZinZeXZ/cPfwFkCT/9j+LwYWnHDq+7QAZYa3Vq4JT2n92vx84+pv1n96t7sDvhOsX5xWqpbwmPENlVv0tlRWXx3wgAyGp+DUD4WXbyIn+ccSPOvaMR5wvS0IsvTa3nUVkZ/96xMWctklhByfTzy5fT17O1zsiV/n7pmWdmv3fBgvhBSU0NWwYDOW/6DyKyORDZuTP6+rOfld79bm96QVoZY7RhxQZtWLFBD+58UNZavXT5pagRIi9eejFundGJUe0/u1/7z+6XJBXkFWhn7c7wCJHdK3drScmSdH87AABIYgRIWBaPAPHVFJhscP26E1BMBSK9vTdHkkQGJT090siI191G74IzPRyZepw6X7Qouz8bAUgTP/3B7+ubW7IN3wtdCenxc4+H1xE5OXAy4RpGRlurt4ZHiNyz8h6tKFuRhm4BAKnECJDcMxhxvjDOvZFjPa8l8kXi/UZiK7pblZRIK1c6x2ysla5duzUkibyOHGGSrmn71jqjW86fl44dm/3e0tLYwcjU+dTBdsFAwPhplEhVVfT1ww9Lb3iDN70grRoWN+itm9+qt25+qyRngdTHz7qByLnH9HTv07Ka/QdtVlYdvR3q6O3Q55/8vCRp44qN4REi9666V3XldWn/XgAAuYERIK4kRoC8XtK/uJfvsdZ+bpZ73yPpf7mXr7PW/nimexOV7Da4SEzkeiWRwUis6yvxF9FPu4KCm7vfTA9HIo+qKme3HAABkM2hSKT3vU/61Ke87gIZcGnkkg6GDoZHiBzuPqwJm/hWcWuWrgmHIXtX7VXjkkZ+AAQAHvPrCBACEFcSAchqSWfcy69aax+c5d6vSnrAvVxtrU3ZNrgEINlneDh6EddYQcnUaJNYu2ZmWkVF9EiS2trokGTqegGr1wD+4qcPiMeOSXfe6XUXSLNrN66pNdQaHiHyZOeTGp0Yjf/GaRrKG8Jb+u5r3KfbltxGIAIAGUYA4nNJBCBGUqekWkmnrLUbZrn3pKT1krrk/OZI2S86AYh/RW4ZPBWOzPR49arX3UqLF8cOSKY/t2iR150CmJFfPiR+/evS/fd73QXS7Pr4dbV1tYVHiBwMHdTw2HDCdRrKG7S3ca/2rXICkdVLVxOIAECaEYD4XKIBiPuev5X0X9zLXdbaQzHuaZHU6l7+rbX2T+bdbHR9ApAcMDQUPXokMiCJPM6fv3WpgEwrK7sZiEQ+Tn+OBV2BLOCXP4T19dLZsyxuFHBjE2M62nM0PELk8bOP68po4vNK68vrta9xn/au2qt9jfu0ZukaAhEASDECEJ9LMgC5Q9JxOYvJHpZ0r7V2JOL1BZIek7RT0rikjdba0ynumwAEYePjzg44kaFIrKCkp8fZWthLZWXxQ5LaWoISIKPuuEM6ndK/ptLn0CHprru87gJpNDE5oWP9x8IjRB47+5jOD59PuE7dorqoKTMEIgAwfwQgPmOM2SNpbcRTFZKmVmU7KOkbkfdbax+aoc5fSPqQe9kh6a/krA2yRtIHJW1zX/sLa+2HU9H7tK9PAIKEWStdvHhrKNLdfetzw4mPRk6p6SNKZjrKyuLXApAEv3xQ/OIXpT9J6SBLZBlrrU4OnNQvX/5l+EgmEKldVOuEIe6UmbXL1hKIAECCCEB8xhjzkKS3zfV+a23MvxmNMXmSvi7pHZ/EBBwAACAASURBVLO8/ZuSHrDWpnwjVQIQpJO10uDgzCFJ5LnX65SUl88ekEyFKCUl3vYJ+J6fPiiOjrLVVYBZa3Vq4JQThpx1ApH+of6E69Quqg1Pl9nXuE+3L7udQAQA4iAA8ZlUBSAR9V4rZ6eXJjmjSQYktcvZIeYnyXc6OwIQZIuhoVuDkViPXm8TvGyZE4bU1d0akEw9V1XlbCUMYI788mGxtVVqafG6C6RJZCCy/+x+/fLlX6pvqC/hOjULa6IWVb1j+R0EIgAwDQEIPEEAAr+Z2iY4MhSZfu51UJKX54Qg04ORyPO6OidM4d/EQAx++YPx5S9LD864iz18zlqr5y48F54us//sfvVe6024TvXC6qhFVdctX0cgAiDnEYDAEwQgCKrh4Vun20QeU895OfWmuDh2MDL1OHVeWupdj0BWqKtz/sBmuwcfdEIRBJK1Vs9feD5qykwygUhVWVXUoqoEIgByEQEIPEEAglx37VrsgCTy6OqSRkbi10qXJUtuBiLTA5Kpo7KSHT6RY/zygfHYMenOO73uAmlgrdXpi6ejFlXtudaTcJ2qsqqoKTPrK9YTiAAIPAIQeIIABIjPWmekyFQYEisgmTofH/emx4ICZ5HW6cHI9IPRJAgsv3xg/Pa3pTe/2esukAaRgcj+s/v16EuPJhWIVJZVRi2quqFiA4EIgMAhAIEnCECA1JmclAYGYgcjU9ddXdL5806o4oXpo0nq6qT6+ujHigr/fJYEZuWH38gf/aj0P/+n110gDay1euHiC1FTZroHE5/KtaJ0RXgNkV+57VcIRAAEAgEIPEEAAmTe2JizkOtUIBIZlkQ+NzjoTX9FRTOHI1OPNTVSYaE3/QFJ88uHxgsXnFWSESjWWp25dCZqykzXYFfCdaoXVuuVt71Sr2x8pV61+lVqXNKY+mYBIM0IQOAJAhAgew0O3hqSTD96e6WJicz3Zoyz002sgGTqYMoNsp5fApEDB6Tdu73uAilmrdWLl14MjxB59KVHkwpEVi9dHQ5DfqXxV1S1sCoN3QJAahGAwBMEIIC/TUxIfX2xw5HIw6vRJMuWRQcikQHJ1FFe7k1vQEx+CEW++U3pHe/wugukWGQgsv/sfj368qPqvJr454E7K+8MByJ7V+3V4pLFaegWAOaHAASeIAABckPkaJJYR2enM5rk/7V352FWVXe+xt/FPAgKCiKIzIoD4gAOoIIgKKgRMpkEO8YkN2Mn8WpH86Rz+/btvp1oEtvMSSedRHO1o0knEhNxxFkcQFFBmScZBXFipqpY9499aqCo4VTVObVPnfN+nmc/+wxr7/0D1qmnzpe110rjR3qPHnUHI5XbwIHJ3CVt4XupilBb6Hg33gg33ZR2FcqxGCNr3l1TdbtMcwKRdqEdY/qPYfKQyUwaMonxA8fTtWPXPFUsSdkzAFEqDEAkVSovT0KQDRsODkZq7/fta/3aunWrOxipue/du218V1Ub11Y62TvvJMmhikblpKqPrnmUuWvm8uiaR9m+Z3uTztGpfSfGDRxXFYiM7T+Wju2d0ElS6zMAUSoMQCQ1RYzw9ttJEFIzFKn9/P33W7+2rl3rDkZq7nv1ajvfX9VG/Md/wBe+kHYVjZs/H8aMSbsK5dCBeIBFby6qCkOeWPcEO/fvbNI5Dut0GBMGTWDSkElMHjKZUUePol1ol6eKJamaAYhSYQAiKR8qb7mpHYysX1/9+K23Wr+uypEkNUOR2o8PP9yQRC3UFjrQH/4AH/lI2lUoh8oqyliwaQFz18xl7pq5zFs/j/0V+5t0jqO6HcWFgy+sGiEyvPdwl9yVlBcGIEqFAYiktOzde+gIktohyZtvtv68JIcdVh2G1N6OOy7Zu7qNmqQtfIG8+Wa44Ya0q1AO7SnbwzPrn6m6ZWbBpgUciAeadI6BPQdWjQ6ZNGQSA3oOyFO1kkqNAYhSYQAiqZDt358sAVxXSFK5T2Py1t696w9HjjsuWfGmo7fVqz7t2qUz43BTfPnL8JOfpF2Fcui9ve/xxLonqgKRxVsXN/kcJxx5QlUYcuGQC+ndtXceKpVUCgxAlAoDEEltXVlZdUhSMxip+bi1R5KEAMccc2gwUrk/7jjo06dtDAxQK2kLnWHbNjjqqLSrUI68ufNNHlv7GHNXz+XRtY+y+p3VTTo+EDit32lVgcj5g87nsE6H5alaScXGAESpMACRVAoqR5LUDEVqBiXr18PWra1bU+fOBwciNR9XPu/evXVrUgFpC4HIwoVw2mlpV6EcWfvu2oNWmNmyc0uTju/QrgPnHHsOkwZPYvLQyZw94Gw6d+icp2oltXUGIEqFAYgkJSrnJKkZitTe3nmndWvq3fvgUKT21q8ftG/fujUpJW0hELnvPpg+Pe0qlAMxRpa8taRqdMjjax/n3b3vNukcXTt05fxB51cFIqf3O5327fyBJSlhAKJUGIBIUvZ27qweOfLGGweHI5XPd+9uvXo6dDh05MigQQc/dxRJkerUKbn/q5D9+tfw6U+nXYVyoOJABQu3LKwKRJ5a9xR7yvc06RxHdDmCCwdfyJShU5gybArDeg1zhRmphBmAKBUGIJKUOzEmo0Qqw5C69hs3QkVF69V05JEHByO19337to3BBcpCof9D/tu/wTe/mXYVyoF95ft4fuPzVYHIcxueo/xAeZPOMfiIwUkYMnQKk4dOdkJVqcQYgCgVBiCS1LoqKmDz5rrDkcpt+/bWq6dz5+pApHKr+fzYY13Rps0q9EDka1+DH/wg7SqUAzv37+SpdU9VzSHy8paXiWT/HSEQOLP/mVWByLiB45w/RCpyBiBKhQGIJBWe3bsPDUVqbuvXw759rVNLu3bQv//BAUntrVu31qlFLVTogQhAebkT2xSB7bu38/jax6sCkWXblzXp+G4du3HBoAuqApFT+p7i7TJSkTEAUSoMQCSp7TlwIFmR9I03YN26g8ORyudvvdV69fTpUx2GDB588H7QIDj88NarRU3QFr5QuvRuUdjw/gbmrp7Lw6sf5pHVj/DmrjebdHy/w/px0dCLmDJ0ChcNvYj+PfrnqVJJrcUARKkwAJGk4rRrV/UokspQpOZ+w4bkP9tbwxFHVIciNQOSyse9erWN7+JFb9QoWLw47SoatmwZHH982lWoBWKMLNq6iIdXPczDqx/myXVPNnlC1ZP7nFw1meqEQRPo3snZnqW2xgBEqTAAkaTSVHMuknXr6t527WqdWnr0ODQYqbn17m1AkppC/4ufPx/GjEm7CrXA3vK9zFs/ryoQeWnzS02aP6Rju46MGziuKhA585gzXW5XagMMQJQKAxBJUl0qV7SpKxhZuzbZt9ZkrZUBSV3bkCHJCJNC/55eNAr9L/rRR+HCC9OuQi2wffd25q6ZWxWIrHtvXZOO79WlF5OGTKoKRIb2GpqnSiW1hAGIUmEAIklqrp07q0eQVIYiNUOSzZtbp46ePavDkJrBSOW+Z8/WqaMkFXog8te/wmWXpV2FminGyMq3V/Lw6iQMeXTNo7y/7/0mnWNor6FVk6lOGjKJXl175alaSU1hAKJUGIBIkvJl375kHpLKcKTmfu1a2LgxmdA133r1SoKQyq0yGKl83LVr/msoGYUeiNx9N3z0o2lXoWYqP1DO/I3zqwKR5zY8R/mB7CczahfaMab/mKpA5NyB59Kpfac8ViypPgYgSoUBiCQpLWVlyWSslYFI5VYZkqxf3zoBSb9+BwckNbeBA6FDh/zXULQKPRC5/Xb45CfTrkLNtGPfDh5f+3hVILL0raVNOr57x+5MGDyhKhA5qc9JLrcrtRIDEKXCAESSVKjqC0jWrKleySbfAUn79nDccdWByNChB+/79Cn87/gF5bDDWm923eb41a/gs59Nuwo104b3N1TNHfLI6kfYtntbk47v36P/Qcvt9jusX54qlWQAolQYgEiS2qqysupbbNasOTggWbMmmYMk37+mdO9+cDhScxs8GLp1y+/1i0IhJ0i/+AV8/vNpV6FmOBAP8Oqbr1YFIk+98RR7y/c26Ryj+o6qmkz1gkEX0K2jH2gpVwxAlAoDEElSsdq3r/p2mspQpDIoWbMGtjXtP4eb5Zhj6g5Hhg5N3mvXLv81tDmFHIj89KfwpS+lXYWaYW/5Xp5+4+mqQGThloVNOr5T+05MGDSBacOnMX3EdI4/8nhvl5FawABEqTAAkSSVqp07Dw1Ham47duT3+l26HBqODBtWfXuNo0cyCvlLpoFIm7Vt17aDlttd//76Jh0/tNfQqjBk4uCJjg6RmsgARKkwAJEk6VAxwttvJ0HI6tXVoUjl47VroTz7xSea5ZhjqgORmvthw0p87pFC/oP//OfwhS+kXYWaKMbI8u3LqyZTfWzNY+zYn30C2qVDFyYOnsj04dOZNmIaw3sPz2O1UnEwAFEqDEAkSWq6iopkGd/KQGTVqoMDkjffzO/1Dzvs4EBk2DAYPjzZl9zKNYUciDipaptUVlHGCxtfqApEnt/wPBWxIuvjR/QewfQR05k2fBoTBk+gS4cueaxWapsMQJQKAxBJknJv166DA5HVqw8OSfY2bS7GJunQIZmAtXYwMnx4Epp0KfbvYoUciNx2G1x9ddpVqIne2/sej6x+hPtX3s+cFXPYvHNz1sd269iNSUMmMW34NKYNn8aQXkPyWKnUdhiAKBUGIJIkta4DB2DLliQIqbmtWpVs+R49cuyx1YFI5Vb5vEeP/F47FYUciNx1F1x5ZdpVqAlijLzy5ivcv+J+5qycw7Prn23S6JCRR41k+vDpTB8xnfOOO4/OHTrnsVqpcBmAKBUGIJIkFZbK0SOVgUjNcGTt2mT533zp2/fgYKTm1qtX/q7bqgo5ELn3Xrj88rSrUBO8s+cdHl79MHNWzOGBlQ/w5q7sE8zuHbtz0dCLktEhI6Zx3OHH5bFSqbAYgCgVBiCSJLUdFRWwYUN1IFJ7e//9/F27d28YMSIJQyr3lY97987fdfOukAORRx+FCy9Muwpl6UA8wMLNC5mzYg73r7yf5zY8RyT770qn9D2lamWZ8QPH07F9xzxWK6XLAESpMACRJKk4xAhvvXVoKLJyZf5vrenVqzoMqb21uZEjhRyILFgAZ56ZdhXK0vbd23lo1UPMWZmMDnlr91tZH9uzc08uGnpR1coy/Xv0z2OlUuszAFEqDEAkSSoNO3ZU305TGYpU7t94IwlQ8uHIIw8NRY4/Ptm3iTlHCjkQWbUqmdlWBa/iQAUvbn6xanTI/I3zmzQ6ZPTRo6tWljl34Ll0aFdKSz2pGBmAKBUGIJIkae/eZH6RlSsP3dauTW69yYejj64OQ2oGI8OHQ9eu+blmixVyIPLuu3D44WlXoSxs3bWVB1c+yP0r7+eBlQ/wzt53sj72iC5HMHXYVKYNn8Ylwy+h32H98liplB8GIEqFAYgkSWpIWVl1OLJiRXUwsmJFMllrPsKREGDgwCQQqb0NGpQs9VswCjUQmTUL7rgj7SqUhYoDFbyw8QXmrJjDnJVzeGnzS006/oxjzqhaWeasAWfRvl37PFUq5Y4BiFJhACJJkpqrrAzWrasORlasqN7yNXKkY8dk2d7KQOSEE6r3ffsWQB6RegH1uO46uOWWtKtQFrbs3MIDKx/g/pX38+DKB3lv33tZH9u7a28uHnYx00dM5+JhF9One588Vio1nwGIUmEAIkmS8qFy5EjNUKRmOJKPXyF79qwORCpDkcrn3brl/npZKdRA5Pvfh+uvT7sKNaL8QDnPrn+W+1fez5wVc3jlzVeyPjYQGDtgLNOGT+PSEZcypv8YQqH2R5UcAxClwgBEkiS1tn37kglZV6yA5cur98uXw6ZN+bnmwIHVgUjNbeBAaNcuP9esU6F+Ab3rLrjyyrSrUCM2vr+RB1Y+wJyVc3h41cPs2L8j62MH9BjAjJEzmDlyJhcMusBldpUqAxClwgBEkiQVkp07k9tpagcjy5bBO9nPE5m1rl2rw5CRI5OtctRI9+65v94hCjUQefZZOOectKtQA/ZX7Gfe+nncv+J+5qycw+Kti7M+tleXXlx2/GXMHDmTi4dfTLeOaQ2RUqkyAFEqDEAkSVJbsX17EoTUDEUqg5J9+3J/vYEDq0ORyu3EE6FfvzzmFoUaiGzZkizbo4L1xntvJKNDVszhkdWPsKtsV1bHde3QlYuHX8zMkTO57PjL6N21d54rlQxAlBIDEEmS1NZVVMD69dWBSM39G2/k/no9e9YdjAwblkzSmlOFGIh88pNw++1pV6EG7Cvfx9NvPM2cFXP424q/sXz78qyOax/aM2HwBGaOnMmMkTM4tqffDZQfBiBKhQGIJEkqZrt3JyNEli07dNuR/fQJWenQAYYPT8KQmtvIkTm8naYQA5F/+zf45jfTrkINWLJtCfcsvYd7lt7Dgk0Lsj5ubP+xVWHIiX1OzGOFKjUGIEqFAYgkSSpFMSZ3dSxbBkuXJlvl43Xrcr9KzcCBcNJJSSBSc9+7pXcbFGIg8uc/w8yZaVeheqx/bz1/WfYX7ll6D0+sfYKKmN161ScceQIzR85k5okzGdN/DO1Ca84erGJjAKJUGIBIkiQdbM+eZNTI0qWwZMnBIcmePbm91tFHHxqKnHRS8nqTs43LLoP77sttgbmwbFkyq6wKzvbd2/nb8r9xz9J7eHDVg+wt35vVcQN6DOCKE65g5okzmTBogivKqMkMQJQKAxBJkqTsHDiQzDVSGYZUBiRLlsDWrbm9Vu/e1WHIySdXPz7mmCYEI4U4OuTKK5Mld1Vwdu3fxUOrHuKepffw1+V/5d2972Z1XM0VZaYOm0r3Tq2xfJLaOgMQpcIARJIkqeXefvvgQKRyW7s2t7fTHHHEwcFI5ZZVMFKIgcjNN8MNN6RdhWopqyjjiXVPcM+Se5i9bDabdmzK6riuHboyddhUZo6cyeUnXO6KMqqXAYhSYQAiSZKUP3v2JCvSvP56dSjy+uvJLTZlZbm7Tq9eB4cip5yS7Pv2bSD3KMRA5NFH4cIL065CNRyIB1iwaQH3LEkmUV22fVlWx1WuKDPjhBnMGDmDgYcPbPwglQwDEKXCAESSJKn1lZXBqlXVgciSJfDaa8kokr3ZTcOQlaOOSsKQyq0yIOnVq47GhRiI7NoF3bqlXYVqaO6KMmP6j0kmUR050xVlZABSqkII2f4FPhFjnJiH6xuASJIkFYiKimQVmtdfTwKR11+vDkh27crddQYMqA5FRo1K9iedBF271mhUaIHIt74F//qvaVehGlqyosyMkTOYOXImYweMdUWZEmQAUqIMQCRJktSYyglYX3vt4O3112H37txco107GD784FBk1KjktfbH9IVt23JzoVx56CGYMiXtKpRRuaLM7GWzeXDlg+wpz27JpP49+jPjhBmuKFNiDEBKVI0A5OfAzxpouivGuCYP1zcAkSRJaqMOHDh4xEjNYCRXS/Z26ZLcNjNqVLKdeiqMmnI0R5PjpW9aqqwMOnRIuwrR/BVljuhyRNWKMhcPu9gVZYqYAUiJqhGA/J8Y4z+ncH0DEEmSpCJTUZGsQLN48cHbsmW5m3y1b98aocgPrmE0r3ASr9OFfbm5QEvcdBPceGPaVYhkRZkn1z3JPUvvYfbS2WzcsTGr47p06MLFwy5mxsgZfOCED7iiTJExAClRBiCSJElqLWVlyQo0ixfDokXV+9Wrc7Ncb/v2cMIJcOrrv+dUXmU0r3AqrzKAjaQ6o8jLL8Po0WlWIJq/okzHdh2ZPmI6s0bN4rLjL6Nrx66NH6SCZgBSogxAJEmSlLZdu5LbZmqGIosXw5YtuTl/b7ZXBSKn8XLVaJHO7M/NBZriM5+B//zP1r+uDrH0raVVYcj8TfOzOqZn55586MQPMWvULCYOnkj7du3zXKXywQCkRBmASJIkqVBt25aEIYsWwauvVgcjuZhfpANlnMiSg0KR03iZo9je8pM3xb33wuWXt+41dYgN729g9tLZzF46m8fXPp7VijL9e/TnYyd/jKtOvYrT+p1GKLSVi1QvA5ASVSMAeR3oABwHlANbgHnAbTHGx1pw/sYSjX7AfDAAkSRJUuMqKpJbZioDkVdfTbZVq3Jz/gFs4HQWchovcxovczoLGcKa1rmFZto0mDOnNa6kBry9523+tvxv3LP0Hu5fcT/7KhqfV+bEo05k1qhZfGLUJxjSa0grVKmWMAApUVkugzsb+FSM8b08nR8wAJEkSVLz7dx5cCDyyivJfseOlp+7J+8dFIiczkJO4nU6Ut7ykzfkN7+Ba67J7zXUoPf2vseflvyJOxfdyWNrHiPS+Neb8QPHM2vULD568kc5stuRrVClmsoApESFEHYB9wJzgaXATqAPMAH4AlD5iX0CmBJjbNK83QYgkiRJSkuMyTK9r7ySbC+/nOxXr275uTuxj1Es4gxe4nQWcgYvcSqv0pW9LT95ffbuhc6d83d+NWjj+xu5a/Fd3LHoDl7e8nKj7Tu068C04dOYNWoWl59wOd06dmuFKpUNA5ASFUI4IsZY58LYIYSjgfuB0zMvfS3G+KMmnt9bYCRJklRQ3n+/epRIZSiyaFGSL7REe8oZyVLO4KWq7XQW0oOduSm8pv/4D/jc53J/XmXl9W2vc+erd3LnojtZ9966Rtsf1ukwPnjiB7lq1FVMGjLJyVNTZgCiOoUQhgJLgE7AyhjjiByf30lQJUmSlLrycli+PAlEFi6s3m9v4ZyogQMcz3LO4CXO5EXO5EVOZyGH835uCq+0fz907Jjbc6pRB+IB5q2fx52v3skfXv8Db+95u9Fj+h3Wr2ry1DOOOcPJU1NgAKJ6hRD+BlyaeTogxrgph+c2AJEkSVJBihE2bjw4EFm4ENaubfm5h7OCMSyo2k5nIT3JwYQlALfdBldfnZtzKWv7K/bzwMoHuHPRndy77F72ljc+pOiEI09g1qhZzDp1FkN7DW2FKgUGIGpACOG7wNczT8+KMWa3SHZ25zYAkSRJUpvy9tvVgchLLyXbsmVJYNJcgQOcwLKDQpHTeJnu7G5ZsdOnw333tewcarL3973PPUvu4Y5Fd/Domkc5EA80esy5x55bNXlqn+59WqHK0mUAonqFEL4H/EPmqQGIJEmSVMvOncm8Ii+9lAQjL74Ir72W3FrTXO2o4CRe5yxeYCzzGct8RrGITjRpXYKD3X8/XHJJ849Xk23esblq8tSXNr/UaPsO7TowddhUrhp1FR844QN079S9FaosLQYgqlcI4T5geubpsTHGjTk8twGIJEmSitLevcnkqi++mGwvvZQ8L2tBftGZvZzGy1WByFjmcwLLaJfF8qyH+NznkslU1WqWvrW0avLUNe+uabR9947dmXniTK4adRWTh06mQ7sOrVBl8TMAUZ0yk6AuBToCq2OMw3J8fgMQSZIklYx9+5KRIQsWJKHIgr9u4tXNfSin+ROY9uQ9xjKfs3iBs3mes3mefrzZ9BOtWgVDnYeiNcQYeXbDs9z56p3c/drdbN/T+Gy7fbv35WMnf4xZp85ibP+xTp7aAgYgJSiEcDlwf4yxzoF5dSyDe32M8d9zXIMBiCRJkkpa5UiRBQtgwZd+zQLG8BonU0Hz/7f/ONZxNs9XhSJn8iLd2JP9CX78Y/j7v2/29ZW9sooyHlr1EHcsuoO/LP0Le8ob/3ca0XtE1eSpw3sPb4Uqi4sBSAkKIawlGdnxJ+BZYC2wBzgKmAh8ATgy0/xp4KIY474c12AAIkmSJNWye3cy0er88V9jPmN5gbNYwfHNPl97yhnNK5zDc5zLs5zDcwxjFVmNIbj8crj33mZfW9nbsW8Hs5fO5o5Fd/DI6keymjz1rAFnMWvULK48+UqOPuzoVqiy7TMAKUGZAGRQFk3/BHw2xvhuHmowAJEkSZKy8E7oxYucyQucVRWKbGJAs893FNs4h+eqQpGxzKcHOxs/8JVX4NRTm31dZWfLzi3cvfhu7lx0J/M3Nb4ORfvQninDpjBr1CxmjJzBYZ0Oa4Uq2yYDkBIUQpgATADOBYaSjPzoCewkCSXmAbfHGJ/NYw0GIJIkSVJzhMBG+vMCZ2Vm/jibBYxhJz2adbp2VDCKRYxjXtU2hDUNjxL50Y/gK19p1vWUveXbl1dNnrrqnVWNtu/WsRszRs5g1qhZTB021clTazEAUSoMQCRJkqQcyEyIWUE7lnBiVSDyPGezmFM4QPtmnfZothwUiJzBS3Shnrvir7wS7rqruX8CZSHGyAsbX+COV+/g7tfuZtvubY0eM+SIIXx93Nf51GmfomvHrq1QZeEzAFEqDEAkSZKkHDv+eFixourpTrrzImfyLOfyHOfwLOeylebNFdGJfYxlPufxNOfxNOOYR2/eqbvxtm1w1FHNuo4aV1ZRxiOrH+GORXcwe+lsdpftbrB93+59ufbsa/ni2C9yRJcjWqnKwmQAolQYgEiSJEl5Vmu51AisZXBm9o8kEFnI6c1eivdkFlcFIufxNINYd+htMw88ABdf3Kzzq3E79+/kL0v/wp2L7uShVQ9RESvqbdujUw++MOYLXHvOtfTv0b8VqywcBiBKhQGIJEmS1IpC3TN67KELL3JmjZtdxrGNvs26xAA2cD5PcQFPcgFPciJLaEeN72033ww33NCsc6txW3dt5e7Fd3PbK7fx0uaX6m3XqX0nrh59NV8f93VGHDmiFStMnwGIUmEAIkmSJKWonkAkAqsYxjzG8Qzjmcc4XuNkIu2afIkjeYvzeaoqFDmNl+lAZoTCJz8Jt9/egj+A6hNj5LG1j3HT0zfx8OqH620XCHz4pA9z4/gbObP/ma1YYXoMQJQKAxBJkiSpQNQThlR6l8N5jnOqbnZ5nrPZS9Mn1TyMHYznGSbwBBN5nDEsoCPlcM458GzeFqAsaS9uepHvzvsuf3ztj0Tq/w49ZegUbhx/I5OGTCI00h/aMgMQpcIARJIkSSpAnTpBWVmDhRjXgQAAIABJREFUTfbTkYWcXmP2j/N4iz5NvlR3dnIeTzORx5nI45zJi0kgsmkTHHNMc/8EqsOK7Sv4/rzvc9srt7G/Yn+97cb0H8M3xn+DGSNn0L5d81YQKmQGIEqFAYgkSZLUBmQxGiACyzmepzmPJ5jAk1zAOgY3+VI1A5ELeYwzeZEOLzwLY8c2vW7VafOOzfzguR/w8wU/Z8f+HfW2O/7I47lh3A1cdepVdO7QuRUrzC8DEKXCAESSJElqY5pwa8QbDOQpzs9Mh3oBSzmxyZfryXtM4AkmM5fJzOXkv3yH8IHLm3weHerdve/yiwW/4NbnbmXrrq31tuvfoz//85z/yefP/Dw9OvdoxQrzwwBEqTAAkSRJktqwJs4T8SZ9eZrzeJyJPMEEFnFqky/ZlzeZxKNMZi6TbrqYoTd+pMnn0MH2lO3h9ldu53vzvsfqd1bX2+6ILkfw5bFf5qtnf5W+3Zu3SlAhMABRKgxAJEmSpCLSxEBkG0fxJBdkZv+YyGJGNfmSg1nDVB5iytUDmPTvl9G7d5NPoYzyA+X89+v/zc3P3MzLW16ut12XDl34zOmf4fpzr2dIryGtWGFuGIAoFQYgkiRJUpFqxioiW+lTFYg8yiSWcFKTjm9HBWNYwNQLy5nyz+M555xkPlc1TYyRh1Y9xE3P3MTjax+vt1370J4rT7mSG8ffyKlHN300T1oMQJQKAxBJkiSpBDRzSdXN9ONRJvEok5jL5CZPqtqdnVx4/CamfPl4LrkERoxodikl67kNz3HzMzcze+nsBttNHzGdb4z/Bucdd17BL6FrAKJUGIBIkiRJJaaZX44jsJqhVWHIo0xiG02bh2Jor3eY9oleXHIJXHghdO/erFJK0pJtS/jevO/x/179f5QfKK+33bnHnss3zvsGlx1/Ge1Cu1asMHsGIEqFAYgkSZJUws46C+bPb9ahBwgs5hQeZgoPMZUnuYC9dM36+E7ty7ngwg5MmwaXXAInnujokGysf289tz53K7988ZfsKttVb7uT+pzEjeNv5OOnfJyO7Tu2YoWNMwBRKgxAJEmSJFVpQQKxl848zXk8zBQeZgoLOaNJxx93HFx6KVx2WTI6pGv2WUpJenvP2/z0hZ/yw+d/yPY92+ttN7DnQK4/93o+e8Zn6d6pMIbcGIAoFQYgkiRJkurUwuEYW+nDXCbzEFN5kIvZTP+sj+3aFS66KAlDLr0UBgxoUSlFbdf+Xfxm4W/4/rPf54333qi33ZFdj+QrZ32Fvz/r7zmy25GtWOGhDECUCgMQSZIkSY1qYRgSgVcYzQNcwv1MYx7jKCf72zJOPz0JQy67DMaMgXaFObVFqsoqyrhr8V3c/MzNvLbttXrbdevYjc+d8TmuO/c6Bh4+sN52+WQAolQYgEiSJElqkhxM1PEePZnL5KpAZAPZfxE/5hi44gqYMSO5VcZldg92IB5gzoo5fOfp7zBv/bx623Vo14FZo2Zxw/gbOKlP05Y7bikDEKXCAESSJElSs+UgDInAa5zMHKbzVy5nHuM4QPusju3ZE6ZPT8KQadOS56r29BtPc9PTN3HfivsabHfFCVfwjfO+wTnHntMqdRmAKBUGIJIkSZJyIkdLuGynNw9wCX/jMh7gEt6lV1bHdewIkycnYcgVV0C/fjkppygsenMR3533XX6/6PdUxIp6200YNIEbx9/IJcMvIeRxSR4DEKXCAESSJElSzuXoy3MZHZjHOP7GZfyVy1nGyKwvf/758OEPw4c+BP2zn3+1qK19dy23zLuF/1z4n+wt31tvu9FHj+bG8TfykZM/Qod2HXJehwGIUmEAIkmSJCmvcjiSYBnH8xeuYDYzeJZxWV9+/PgkDPnwh11RBmDrrq38+Pkf85P5P+Hdve/W227IEUP4+riv86nTPkXXjrlbl9gARKkwAJEkSZLUanIYhmymH/fyAWYzg7lMpozsZkMdNw4+8pEkDCn1rz879u3gVy/9iluevYVNOzbV2+5fL/xXvnXBt3J2XQMQpcIARJIkSVIqchiGvE8P7mca9zCT+7iUnfTI6vIXXACf+EQShvTunbNy2px95fu4c9GdfPeZ77Js+7KD3uvaoSvrrl1Hn+59cna9thqAuPqyJEmSJKnpYqzeWqgnO7iSP3AXH2cbfZjNFcziDnrwfoOXf+IJ+PznkwlTP/ABuOsu2L27xeW0OZ07dObTp3+a17/8On/+6J8Z239s1XufPeOzOQ0/2jJHgLRxjgCRJEmSVFByODJkH514iKn8kY/wF67gfQ5v9Jju3WHmzGRkyEUXJavLlJoYI4+vfZzvzvsuv7j0Fww6YlBOz99WR4AYgLRxBiCSJEmSClaOw5BHuIg/8hFmM4P3OKLRY/r0gVmz4Jpr4NRTc1ZKyWurAYi3wEiSJEmS8qPyFplevVp8qs7s51LmcBvXsIV+/JmZfJg/0pn6l4Pdtg1+8AMYPRrOOAN+/GPYvr3FpaiNMgCRJEmSJOXX22/nbL4QgC7sYyaz+SMfZSt9uY2rmcqDtKOi3mMWLoSvfhWOOSaZNPW++6C8PCflqI0wAJEkSZIktZ4cTp4KyQSqV/M7HuQSNtGfH/EVzuHZetuXlcGf/gSXXQYDB8INN8CKFTkpRQXOAESSJEmSlI4chyFHs5Wv8BOeZRzLGcE3+TeOTaZMrNOWLfC978Hxx8OUKUkwUlaWk1JUgAxAJEmSJEnpqwxCJkzIyelGsJJ/41usZTAPMpWP8fsG5wt55JHk1phBg+Cf/gnW15+bqI1yFZg2zlVgJEmSJBWtHK4iA/Auh3MXH+O3XMMLnN1g23btkttkvvhFmDo1ea6Eq8BIkiRJkpRLOb5F5gje4wv8B89zDq9xEtdxC72pe1mYAwfg3nth2jQYPhz+/d/h/fdzUoZSYgAiSZIkSSp8lUFI9+45Od1JLOEW/oENHMvv+DvG8Uy9bdesgeuvh2OPTfbr1uWkBLUyAxBJkiRJUtuxc2dOR4V0ZS9/xx08w3m8zGi+yM84jB11tt2xIxkJMmwYfOxj8MILOSlBrcQARJIkSZLUNuX4FpnRvMrP+DKb6M8v+DyjebnOdhUVcPfdcPbZcP75cM89yWsqbAYgkiRJkqS2L4dBSA928nl+yUJO52nG80H+ROBAnW2ffho++EE44QT4xS9g376clKA8MACRJEmSJBWPHI4KCcB45vEnPswKRvBVfkh3dtbZdtWqZMWY4cPhZz8zCClEBiCSJEmSpOKUw1Ehw1jND7mW9QzkZm5gAHWv/LphA3z5y8k8IT/5Cezdm5PLKwcMQCRJkiRJxS2Ho0J68S438D3WMIQ7mMXpvFRnu40b4StfSYKQH/0I9uxp8aXVQgYgkiRJkqTSkaMgpCPlzOK/eJEzmcskJvB4ne02bYKvfS0JQn74Q4OQNBmASJIkSZJKTw7nCZnEYzzOhTzGRCbyWJ3tNm+Ga6+FESPgd7+DA3XPqao8MgCRJEmSJJWuHN4eM5EneIxJPMEFTGJunW02boSrr4axY+HJJ1t8STWBAYgkSZIkSZCzIOQCnmIuF/EU53ERD9fZ5qWXYMIE+NCHYOXKFl9SWTAAkSRJkiSpphwFIefxDA8zlacZz2QeqbPNn/8MJ50E118P777b4kuqAQYgkiRJkiTVJUdByHjm8TBTuI/pjGTJIe+XlcG//zsMH54snVtW1uJLqg4GIJIkSZIkNSQH84QEYDr38yqn8hO+zJG8dUib7duTpXNHj4Z581pQr+pkACJJkiRJUrZaGIR0pJwv8zNWMpzr+T4d2X9ImyVL4Lzz4LrrYPfulhSrmgxAJEmSJElqqhYGIUfwHt/n6yzhRD7Ef9d5+ltvTUaDPPVUSwpVJQMQSZIkSZKaq4VByDBW8998hCc5nzN48ZD3V65MVov56ldh166WFCoDEEmSJEmSWqqFQcj5PM3znM3N3EBn9h5y6h//GE49FR5/vIV1ljADEEmSJEmScqUFQUgHKriB7/Eyp3Euh86Cuno1XHghfOlLsGNHSwstPQYgORRCOC6E8P0QwpIQwq4QwtshhBdCCP8QQuiWdn2SJEmSpFbSgiBkJMt4ivO5hevowp5D3v/5z2HUKHj++ZYWWVoMQHIkhHAp8CpwPTAS6Ab0AsYC3wNeCiEMTa9CSZIkSVKra2YQ0p4DXMetvMqpnMehs6CuWwcXXAC3356LIkuDAUgOhBBGA38ADgd2Av8IjAMmA7/KNDsBuC+EcFgqRUqSJEmS0tPMIGQEK3mCCfyIr9CNg2dB3b8fPvWpZLnc8vIc1VnEDEBy4wckIz7Kgakxxm/HGJ+NMT4aY/wccEOm3UjgurSKlCRJkiSlLEbo0qVJh7Qj8hV+wiJGcQFPHPL+rbfC9Onwzju5KrI4GYC0UAhhLDAx8/TXMcZn62h2C7Ak8/jaEELH1qhNkiRJklSA9uxp1miQoaxhLpP5Gj845L2HH4azzoLXX89FgcXJAKTlZtR4/Nu6GsQYDwC/yzztRXVgIkmSJEkqVc24LaYDFfyA/8lvuIZO7DvovZUr4Zxz4K9/zWWRxcMApOXOz+x3AS820K7mOKXz8leOJEmSJKlNaUYQcg238TgTOZotB72+YwdccQV8+9vNXoSmaBmAtNyJmf3KGGND084sreMYSZIkSZISTUwszuU5FjCGMcw/5DT/+I/w8Y/D7t25LLBt65B2AW1ZCKELcFTm6YaG2sYY3wkh7AK6AwObcI1jG2kyoPLB5s2bsz2tJEmSJKkQrV+f7Adm+7VxI//F+dzId7mHDx70zt13w+LF8Otfw4AB9RzeDLW+e7bP3ZnzK0THxDRbCKEPsDXz9O4Y48caaf8m0BdYHGMcleU1/AeSJEmSJBWqsTHGBWkXkQ1vgWmZmmsX7c+ifeUMNV3zUIskSZIkSa2tb9oFZMtbYFpmb43HnbJo3zmz39OEazQ27uk44JnM43OAjU04t9RW9IOqGxvHQq2ZnqTiYD9XKbCfqxTYz1UKBgDPZR4vbahhITEAaZkdNR4flkX77pn9zmwvEGNscG6REELNpxsbay+1RbX6+Rb7uYqR/VylwH6uUmA/Vymo1c+zuRuiIHgLTAvEGPcCb2WeNjhZaQihF9UByPp81iVJkiRJkg5mANJySzL74SGEhkbUjKzjGEmSJEmS1AoMQFru6cy+O3BmA+0m1Hj8TL2tJEmSJElSzhmAtNzsGo+vqatBCKEd8MnM03eBx/JdlCRJkiRJqmYA0kIxxheApzJPPxNCOLeOZtcDJ2Ye/zDGWNYqxUmSJEmSJMBVYHLlayS3tXQFHgohfJtklEdX4GPA5zLtlgO3pFKhJEmSJEklzAAkB2KMC0MIVwJ3AD2Bb9fRbDlwaYxxRx3vSZIkSZKkPAoxxrRrKBohhEEko0EuJVkWdz+wEvgj8JMY4+4Uy5MkSZIkqWQZgEiSJEmSpKLnJKiSJEmSJKnoGYBIkiRJkqSiZwAiSZIkSZKKngGIJEmSJEkqegYgkiRJkiSp6BmAiBDCVSGE/wghLAgh7AshxBDCp7I4bmwIYU4I4Z0Qwq4QwgshhE+0QslSzoTEB0MIj4UQNocQdocQlmU+E0PTrk/KpRDCzBDCwyGE7SGEPSGENSGE34cQBqZdm5RrIYQbMr/TxBDCOWnXI+VCCGFACOHaEMJDIYQ3Qgj7QwhbQgh/CiGcnXZ9UrbS+i7ZId8XUJvwf4FBwFvA5szjBoUQJgIPAvuBu4D3gA8Cd4YQBscYv523aqXc+j5wHUnfnw28D4wG/gfw8RDCuBjj4hTrk1oshBCAXwCfA1aR/NzeAfQHJpD83F+fWoFSjoUQTgT+BdgFdE+5HCmXvgLcSPKz/GFgKzACmAHMCCF8PMb4hxTrkxqV5nfJEGPM17nVRoQQLgJWxBjXhRC+AXwHuCbGeFs97TsAS4FjgXNjjAszr/cAngVOAE6KMa5ojfql5goh9AM2Am8Ao2OM79d471rgVuC3McZPp1SilBMhhK8CPwR+CnwtxlhR6/0OMcbyVIqTciyE0J7k95EILAeuIvl95blUC5NyIITwQWBbjPGpWq+fD8wlE27HGPelUZ/UmLS/S3oLjIgxPhJjXNeEQyYBw4D/quywmfPsAP6VZGTRNbmtUsqLwSQ/B5+pGX5k3JfZ923ViqQcCyF0Bf43sBq4tnb4AWD4oSJzI8lIvk8Dh/R3qS2LMf65dviRef0p4DGgNzCq1QuTspfqd0kDkBYIIfQNIVwWQviXEML9IYS3atxrelsTz3VcCOH7IYQlmXug3s7cB/UPIYRuefojNNfEzP6hOt6rfG1C65SitBRJ/19BMvRufCZ1rml6Zv9oHq+vAlck/XwKyS/Es4H2mTlvvhFC+EIIYXger6s2okj6eeX1TyEJ/P5vjPG1fF9PbUsx9fV6lGX2htqqU4F8BiZm9ql8l3QOkJZ5MxcnCSFcCtwJHF7j5W7A2Mz22RDC9Bjj6lxcLwdGZPaHDEuKMb4TQnirRhsVrzbf/2OM20MI/wh8D1gSQriXZOjoKOAi4JfAj3N9XbUpbb6fA2My+3LgFZKhpZUOhBBujTH+Qx6uq7ajGPp55bDq24AlwE35uIbavKLo6/XUdBzJ7y5bgEWtdV21OYXwGUj1u6QjQHJnPXWnWA0KIYwG/kDSeXYC/wiMAyYDv8o0OwG4L4RwWG5KbbHKjv5ePe+/z8EfBhW/Ntv/Y4zfB2ZlavgicAMwDZgP3BFjLGvgcJWWttrPK2/jup7k5/NZQA/gApL5Ea4PIXwxD9dV29RW+znAN8nc+uLPbmWhLff12jV1BP4f0Bm4oa5bHaU6pPUZSPe7ZIzRrZkb8H+Ay4CjM88Hk0y4FYHbsjzHY5n2ZSSTwNR+/+s1zvlP9ZzjrRptstkmNlDPNzJtPtVAm4cybYbX8/4qYF/a/z5u+d2Kpf8D3yK5DeabJJMxdQfGA8+T/I/5B9P+u3ZLbyuGfk4ykikCu0kmxqt53pNJ5khYmfbftVt6W5H089GZn+XfqXXO2zJtz0n779kt/a0Y+nod52pHEn5E4Jdp/x27FfZWCJ8BUv4u6S0wLRBj/N8tOT6EMJbqe6B+HWN8to5mt5BMAnMicG0I4Tvx0P/V+D3J/+Zla0tTa62lMq2rL5nrSf2JnopEMfT/EMIkksmWbo0HL7f1TAjhMpJJI28F/tyE86uIFEM/p/rn8YIY46aajWKMr4UQVgPDQwhHxBjfbcI1VCSKpJ/fTvJL8z834XiVmCLp6zXrCST/434VcAfwhSacUyWoQD4DqX6XNABJ14waj39bV4MY44EQwu9IlqbtRdLhHq7V5iv5KrAelfdrjQBerPlGCKEXcBQwr5VrUttTCP3/0sz+sTquvS2EsAg4N4RwVIzxrRZcR6WrEPr5ssy+vnCj8vWuDbSRGlII/Xx0Zr83+U54iGczr8+MMc5uwXVU2gqhrwMQQmgH/CfJF83fk4zePtDS80qNyMVnINXvks4Bkq7zM/td1PrHr+WJGo/Py185WausZ2od702t1UaqTyH0/06ZfZ963q98fV+Or6vSUQj9vDLgO7H2G5n7xoeT1Lctx9dV6SiEfv7rerbKX7TvzTxfm+PrqrQUQl+vHX7cDfxddN4PtY5cfAZS/S5pAJKuyl9GV8YYG1quamkdx6RpLsmtAZ8IIZxW+WJIlhH9XyTzJtyWTmlqQwqh/z+T2V8XQjhoGF4I4WqSL4YvxmRdcqk5Uu/nMcZVJPfbDg8hfLbW298AjgDuaaQ+qSGF0M8/W9dG9f8ififz2su5vK5KTup9PRN+/Jok/PgjcJXhh1pRLj4DqX6X9BaYlIQQupAM7wHY0FDbmCwHtItkcsaBeajls1Qnc6My+8+GECZmHs+uOVw0xlieOeZB4KkQwu9JZuv9IDAE+FaMcXmu61TxKKD+/0fg8yRD81ZklsF9h2Qo9RSSkR/X5viaKhEF1M8BvkTyRfBXIYQZJL+YnA5MAtaRTFgmNVmB9XMpbwqor/8T8CmS1TeWA9+q47av2YZ9yrVcfQbS/i5pAJKemhMf7cyifWUHysdyWucBV9d6bXxmg2S46EH3y8YYHwshnEcyk/BHSW4leA34XzHGO/NQo4pLQfT/GGNFCOES4GvAlcDHSfrym8B/kfyP4eJcXlMlpSD6OSSjQEIIY4B/AS4hGWK6Bfgp8C8xxq25vqZKRsH0cynPCqWvD87sDyNZfrQuawEDEOVazj4DaX6XNABJT5caj/dn0b5yDoKuuS4kxvgpkiS5qce9AEzLdT0qCYXU//cB381sUi4VTD8HiDGuJxkyLeVSQfXz2pr7O45Uh4Lo6/ZppSinn4G0vks6B0h69tZ43KneVtU6Z/Z78lCL1Nrs/yoF9nOVAvu5SoV9XaWuKD4DBiDpqTmpYjZD47pn9tkMN5IKnf1fpcB+rlJgP1epsK+r1BXFZ8AAJCUxxr3AW5mnxzbUNrMecmUHWp/PuqTWYP9XKbCfqxTYz1Uq7OsqdcXyGTAASdeSzH54CKGh+VhG1nGM1NbZ/1UK7OcqBfZzlQr7ukpdm/8MGICk6+nMvjtwZgPtJtR4/Ez+ypFalf1fpcB+rlJgP1epsK+r1LX5z4ABSLpqLi1b58z8IYR2wCczT98FHst3UVIrsf+rFNjPVQrs5yoV9nWVujb/GTAASVFm6Z+nMk8/E0I4t45m1wMnZh7/MMZY1irFSXlm/1cpsJ+rFNjPVSrs6yp1xfAZCDHGtGtos0II5wHDa7x0FPC9zONngP+s2T7GeFsd5zg907YryQy53yZJyboCHwM+l2m6HBgTY9xR+xxSGuz/KgX2c5UC+7lKhX1dpc7PgAFIi4QQbgOuzrZ9jDHUc57LgTuAnvUcuhy4NMa4sqk1Svli/1cpsJ+rFNjPVSrs6yp1fga8BaYgxBj/CpwK3ErSWXaT3C+1ALgROL0QO4+UC/Z/lQL7uUqB/Vylwr6uUteWPwOOAJEkSZIkSUXPESCSJEmSJKnoGYBIkiRJkqSiZwAiSZIkSZKKngGIJEmSJEkqegYgkiRJkiSp6BmASJIkSZKkomcAIkmSJEmSip4BiCRJkiRJKnoGIJIkSZIkqegZgEiSJEmSpKJnACJJkiRJkoqeAYgkSZIkSSp6BiCSJEmSJKnoGYBIkiRJkqSiZwAiSZIkSZKKngGIJEmSJEkqegYgkiRJkiSp6BmASJKkghdC+FQIIWa2wXk4/22Zc6/N9bklSVJhMACRJEmSJElFzwBEkiSpESGEtZkRIrelXYskSWoeAxBJkiRJklT0DEAkSZIkSVLRMwCRJEmSJElFzwBEkiSlLoTQK4RwUwhhaQhhTwhhawjhkRDCR5pwjg4hhM+EEOaEEDaFEPaFEN4KITwZQrg2hNClGXU9HkKIwKDMS1fXWI2mcnu8jj/LNSGEO0IIr4cQdoYQ9ocQtoQQHgwhfC6E0KmptUiSpJbpkHYBkiSptIUQTgIeAY6p8XIXYDIwOYTwG+CpRs4xDLgXOKnWW0cC52e2L4UQLo0xrshV7fVYSHVgUtPRwNTM9oUQwvQY45Y81yJJkjIMQCRJUmpCCIcDD1IdftwN3A5sBY4HrgM+DYxq4BzHAM+QBAw7gF+SBCpvAoeTBA5fA0YAD4QQzogxvpdlidcA3TM19gf+AnyrVptdtZ63B54H/kYShrwJdAKGAFcBlwCnA3cBE7OsQ5IktZABiCRJStM/AcdmHn8zxvidGu+9GEL4b5IgYWoD5/glSfixHpgYY1xd6/3HQwh/JBlFMhT4B+B/ZVNcjHENQAihLPPSuzHGxY0cNqmeUSbzgDtDCNcAvwEmhBAmxxjnZlOLJElqGecAkSRJqQghdCYZYQHwKnBz7TYxxjLgM0BZ7fcy5zgFuCzz9O/rCD8qz7MQ+Gnm6adbUHajGrvFJsb4W5KRIQAz8lmLJEmqZgAiSZLScibQK/P49hjjgboaxRg3AA/Vc44rMvvdwH2NXO/JzL5/CGFgUwptrpDoF0I4PoRwSuUGbMo0Gd0adUiSJG+BkSRJ6ak5r8f8Rtq+AFxax+tjMvtuQHkIIdtr9yO5ZSYvQgiXAl8ELgB6NND0qHzVIEmSDmYAIkmS0tKrxuOtjbR9s57X+zbz2t2aeVyDQpLA/Irktp1sdM1HHZIk6VAGIJIkKS01h2vEJrStqX1mvwb4QBOuvaYJbZvi01SHHy8DPyBZEWYjsDvGWAEQQvgd8HfU/+eSJEk5ZgAiSZLS8naNx0cDyxtoW99Ij+01jl8aYyzPRWEt8D8y+1XAuBjjnnra9arndUmSlCdOgipJktKyqMbjsY20re/9ytVUugHjW1xR/RoboVLp5Mz+L/WFH5nbZM7ISVWSJClrBiCSJCktLwLvZB7/XahnBtMQwgBgaj3n+EuNxzfksLba9mb2nRtpVzm6tqE5Rj4A9G9xRZIkqUkMQCRJUipijPuA32aengZ8vXabEEIHkklFO9VzjvlUL5E7PYTwfxq6ZghhcAjh480od3NmP6yRdisy+8tDCIfc5hJCGAb8rBnXlyRJLWQAIkmS0vQvwIbM45tDCP8VQrgkhHBGCOFjwDxgGg0vk3sN1QHFP4UQngshfC6EcG4I4fQQwkUhhOtCCA8BK4EPNaPOeZn92BDCN0IIo0MIwzPbgBrtfpfZDwDmhRCuCSGcFUK4IITwzySjXnoDLzWjBkmS1AIhxmxvaZUkScq9EMLJwCNAv3qa/BZ4kurRIkNijGtrnWMQ8Ecan0sE4Lcxxk/XOv424GpgXYxxcB01DgBeJQkvansixjgx064j8Dfqv2VnT+Y6lzZ0PUmSlHuOAJEkSamKMb5GMnnod0luIdkHvAU8BnyidlhRzznWAWcDM4G7SJa53Q2UAdtIRnDcAkygepnaptS4ETgL+DXJKJK99bQrIwk3vgosyNSwJ3PML4AzYox/bOr1JUlSyzmSCGTEAAAA90lEQVQCRJIkSZIkFT1HgEiSJEmSpKJnACJJkiRJkoqeAYgkSZIkSSp6BiCSJEmSJKnoGYBIkiRJkqSiZwAiSZIkSZKKngGIJEmSJEkqegYgkiRJkiSp6BmASJIkSZKkomcAIkmSJEmSip4BiCRJkiRJKnoGIJIkSZIkqegZgEiSJEmSpKJnACJJkiRJkoqeAYgkSZIkSSp6BiCSJEmSJKnoGYBIkiRJkqSiZwAiSZIkSZKKngGIJEmSJEkqegYgkiRJkiSp6BmASJIkSZKkomcAIkmSJEmSip4BiCRJkiRJKnoGIJIkSZIkqegZgEiSJEmSpKL3/wFcpNUczo/jlAAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {
      "image/png": {
       "height": 371,
       "width": 544
      },
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Expected: mean stdQ_T=0.8784499797762173\n",
      "Expected: stddev stdQ_T=1.4589049549499942\n",
      "Convolution:  mean stdQ_T=0.8784499788798927\n",
      "Convolution:  stddev stdQ_T=1.4589049505415703\n",
      "1-total mass of stdQ_pdf: 6.780309647069771e-11\n"
     ]
    }
   ],
   "source": [
    "privacy_args.num_JL=None\n",
    "privacy_engine=dpdl_privacy.privacy_engine_dpdl(privacy_args,verbose=True,interpolate_flag=True)\n",
    "\n",
    "\n",
    "####################### These accuracy numbers and running time per epoch are obtained by running DPVanilla_LSTM.py #########################\n",
    "accuracy_list=[0.522,0.53,0.513,0.571,0.596,0.576,0.589,0.618,0.644,0.66,0.677,0.685,0.700,0.705,0.708]\n",
    "\n",
    "epochtime_list = epochs*[19317]\n",
    "\n",
    "#############################################################################################################################################\n",
    "# eps_list=dpdl_privacy.calculate_eps_vs_epoch(privacy_engine,epochs)\n",
    "# plt.plot(eps_list)\n",
    "\n",
    "epsilon_list=[]\n",
    "for i in range(epochs):\n",
    "    privacy_engine.add_epochs(1)\n",
    "    eps=privacy_engine.calculate_eps()\n",
    "    print(eps)\n",
    "    epsilon_list.append(eps)\n",
    "\n",
    "plt.plot(epsilon_list)\n",
    "plt.xlabel('epochs')\n",
    "plt.ylabel('eps')\n",
    "plt.show()\n",
    "\n",
    "\n",
    "privacy_engine.plot_eps_delta_curve(max_eps=40,min_delta=10**(-10),CLT_approx_DPSGD=True,MA=True)\n",
    "privacy_engine.print_stdQ_stats()\n",
    "print('1-total mass of stdQ_pdf:', 1-np.sum(privacy_engine.stdQ_pdf))\n",
    "\n",
    "\n",
    "\n",
    "record_dict = {'accuracy':accuracy_list,'time':epochtime_list,'privacy_params':privacy_args,'epsilon':epsilon_list}\n",
    "with open(f'pickles/DPVanilla_LSTM.pickle','wb') as handle:\n",
    "    pickle.dump(record_dict,handle)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "1M0DqJKq7Jrz"
   },
   "source": [
    "# DPJL"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Privacy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "JL_dim: 20\n",
      "Starting some privacy precomputations...\n",
      "Calculting single iteration privacy curves for DPSGD_JL with JLdim=20 ...\n",
      "Calculting privacy curves for single iteration...\n",
      "t_limit_stdPQ:  700\n",
      "max_t:  700\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|▏                                                                    | 38359/13999998 [00:00<00:36, 382981.33it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "num_scales: 8\n",
      "prob_scale: [1.00000000e-02 4.33328444e-06 1.87773541e-09 8.13676162e-13\n",
      " 3.52589025e-16 1.52786854e-19 6.62068896e-23 2.86893285e-26]\n",
      "mesh_scale: [1.00000000e-04 4.69117279e-04 2.20071021e-03 1.03239118e-02\n",
      " 4.84312543e-02 2.27199382e-01 1.06583156e+00 5.00000000e+00]\n",
      "step_scale: [1, 5, 23, 104, 485, 2272, 10659, 50001]\n",
      "t_scale: [0.1287669203453061, 5.017852733516069, 15.2173409404078, 33.68409312953553, 71.29433246254062, 151.38015537413662, 324.2971811286221, 698.9999999999998]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████| 13999998/13999998 [19:13<00:00, 12136.43it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(should be close to 1) sum stdQ_pdf:  0.9999999999987694\n",
      "mean_stdQ=0.0009383547539927791, stddev_stdQ=0.05291422054458898\n",
      "Finished calculating privacy curves for single iteration\n",
      "\n",
      "Time:  1246.286446094513\n",
      "Finished privacy precomputations. Increase mesh_size if this is too slow.\n",
      "Starting epoch 1....\n",
      "Finished adding epochs. Time taken: 3.0917177200317383\n",
      "epsilon:  8.916144518551443\n",
      "Starting epoch 2....\n",
      "Finished adding epochs. Time taken: 8.890362024307251\n",
      "epsilon:  10.11658869202296\n",
      "Starting epoch 3....\n",
      "Finished adding epochs. Time taken: 9.042536973953247\n",
      "epsilon:  10.953582595329166\n",
      "Starting epoch 4....\n",
      "Finished adding epochs. Time taken: 9.002395629882812\n",
      "epsilon:  11.634022523083004\n",
      "Starting epoch 5....\n",
      "Finished adding epochs. Time taken: 9.006680250167847\n",
      "epsilon:  12.22513337466703\n",
      "Starting epoch 6....\n",
      "Finished adding epochs. Time taken: 9.015887975692749\n",
      "epsilon:  12.757698890291984\n",
      "Starting epoch 7....\n",
      "Finished adding epochs. Time taken: 9.071788311004639\n",
      "epsilon:  13.248529402102992\n",
      "Starting epoch 8....\n",
      "Finished adding epochs. Time taken: 9.0366530418396\n",
      "epsilon:  13.707869898513673\n",
      "Starting epoch 9....\n",
      "Finished adding epochs. Time taken: 9.085975170135498\n",
      "epsilon:  14.142455068207418\n",
      "Starting epoch 10....\n",
      "Finished adding epochs. Time taken: 9.030085325241089\n",
      "epsilon:  14.556965112152142\n",
      "Starting epoch 11....\n",
      "Finished adding epochs. Time taken: 9.064910411834717\n",
      "epsilon:  14.954794279428711\n",
      "Starting epoch 12....\n",
      "Finished adding epochs. Time taken: 9.054837942123413\n",
      "epsilon:  15.338488952108877\n",
      "Starting epoch 13....\n",
      "Finished adding epochs. Time taken: 9.067852020263672\n",
      "epsilon:  15.710012767661858\n",
      "Starting epoch 14....\n",
      "Finished adding epochs. Time taken: 9.0878324508667\n",
      "epsilon:  16.070915003068162\n",
      "Starting epoch 15....\n",
      "Finished adding epochs. Time taken: 9.14916181564331\n",
      "epsilon:  16.42244182364232\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {
      "image/png": {
       "height": 365,
       "width": 531
      },
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calculting eps vs delta curve...\n",
      "Finished. Time taken: 24.442718982696533\n"
     ]
    },
    {
     "data": {
      "image/png": "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C7dMJwABAAAAAACuRwACAAAAAABcjwAEAAAAAAC4HgEIAAAAAABwPQIQAAAAAADgegQgAAAAALLOpk2bNHbsWHXv3l2NGzeWMUbGGD3wwAOZLg1AjiIAAQAAABLw0UcfBX4pj/Xr2muvzXTZOWHLli066qijNGnSJC1evFg7d+7cp80zzzwT8nvcoEEDtW7dWgcddJBOOOEE3XzzzZo5c2bgNtHRhPvs8vPz1bZtW/Xv319333231q1b5/TbBpBiBCAAAAAAklITEtx5552OjPfwww9r2bJlkqQbb7xRn3zyiRYsWKAFCxZo2LBhEftWVVVp06ZNWr58uf7xj3/oT3/6kwYPHqyOHTtqypQpCde0Z88ebdy4UR9//LHuuOMOdevWTW+99VbC4yF7DBgwQMYYDRgwINOlxCw4gP3oo48yXU7OqJ/pAgAAAIBcd8UVV2j06NFR27Vu3ToN1eS+Dz/8UJLUt29f/elPf4rafvz48Tr99NMD51u3btWmTZs0b948/f3vf9ecOXO0atUqjR49Wu+8845eeeUVNW7cOOKYffv21dSpUwPne/bs0ffff6+nnnpK7733nrZs2aLf/va3+vLLL9WrV68E3ymAdCIAAQAAAJLUtm1b9ejRI9NluMbq1aslSV26dImpfXFxccjv/5AhQ3THHXdozpw5uuCCC7RixQrNmDFDI0aM0EsvvRRxzMLCwn3G7NOnj8466yxdffXVmjx5snbt2qW7775br7zySozvDEAmsQQGAAAAQFbZtWuXJKlBgwaOjNevXz999dVXKi0tlSS9/PLLeuONNxIeb8KECWrUqJEk6f333495fxEAmUUAAgAAAGSAtVaDBg2SMUb16tXTp59+Grbtgw8+GFjv/4c//GGf68uXL9ekSZM0ZMgQdejQQY0bN1bjxo3Vvn17nXPOOXrvvfdirus///mPxowZo549e6pFixYqKCjQwQcfrEGDBmnKlCnauHFjoG2HDh1kjAmc33XXXftsHjpixIiYXjd4T4MffvhBkjRt2rRaYyWzR0Pr1q316KOPBs7/93//N+GxmjRpol/84heSpG3btmnz5s1xj/Gf//xH48eP18knn6ySkhI1bNhQTZo0UefOnXXhhRfqiy++iHmszz77TJdeeqm6du2qoqIiNWnSRN26ddPQoUP17LPPauvWrWH7rly5UjfddJMOO+wwtWrVSo0aNVLHjh01cOBATZo0SatWrQrbd8GCBRo5cqQ6d+6sgoICNW3aVL/4xS903XXXaeXKlWH7xbN/RaT9Ze68887AdUnauXOnJk6cqF/+8pdq2rSpmjZtqiOOOEJ/+ctfVFVVtU//ESNGyBij2bNnS5Jmz569z89vhw4davWprKzUSy+9pEsvvVS9e/dWs2bN1KBBA7Vp00b9+/fXfffdp+3bt8f1nr7++mude+65gZ+D4uJiDRs2TIsWLdqn78qVK2WM0cCBAwPPDRw4cJ+6n3nmmYg1eJa1lq8c/pJUIslKsmVlZRYAAHjX0qVL7XfffWeXLl2a6VI8YdasWbbm72Hjxo1LaIy1a9fa1q1bW0m2Q4cOdsuWLfu0WbhwoW3UqJGVZPv27Wt3795d6/ry5csDdUT6uuCCC+yePXvC1lJVVWWvu+46m5eXF3GcCy+8MNCnffv2UV83uH0kwd/PcF/9+/cPtJ86dWrg+alTp8b0Gnv37rVdu3YN9Fu9evU+bUK9Vii/+tWvAm3XrVsX0+vXiOW9SrI333xzxHF27Nhhzz333KjjhPv5nDhxom3QoEHM3/NgEyZMiPiz0rBhQztt2rSo73/WrFkR32Ok9zBu3Lhan0GvXr3C1jNkyBBbXV1dq/+FF14Y9XvXvn37Wn369+8ftU/Hjh3tokWLYnpPkydPtvXr1w85TkFBgZ09e3atvitWrIjpZyfW/yasTezPjrKysuDXK7FZ8LtxLF/sAQIAAABkSLt27fTUU0/p9NNP18qVK3XllVfqueeeC1zfvXu3zjvvPO3cuVMFBQWaPn36PstCqqurlZ+fr5NPPlknnniiDjnkELVs2VKbN2/W0qVL9fDDD2vhwoX661//qk6dOumuu+4KWcvIkSP19NNPS5L2339/XXXVVerXr5+aNWumjRs36quvvtpnr4v3339fu3fvVs+ePSWF3gy2RYsWMX0vDj/8cC1YsECSdPLJJ2vNmjU6/fTTNX78+ECbwsLCmMYKxxij448/XkuWLJEkffLJJzrnnHPiHmfPnj1avHixJCk/P1+tWrWKq39VVZUKCwt1yimn6LjjjlO3bt1UVFSkDRs2aOHChXrooYf0ww8/6N5771WXLl100UUX7TPG3r17dfrpp+uDDz6QJHXu3FmjR49W3759VVBQoLVr12rOnDl6+eWXQ9Zw991364477pAkNW/eXKNHj9bAgQPVqlUrVVRU6JtvvtHrr79ea4ZPjUceeUS33nqrJKlNmza66aabdPTRR6u6uloffvihJk6cqMrKSo0YMUKtW7fW4MGD4/r+JOLMM8/UokWLdPXVV2vIkCFq2bKllixZorvvvluLFi3S22+/rSeeeEKXX355oM8999yjsWPH6qKLLtLcuXP32fhW8n2+waqqqtSzZ0+ddtpp6tu3rw444ABZa/XDDz/o9ddf18svv6wVK1Zo6NChmj9/fmCpVCh///vf9eWXX+rQQw/VNddco549e+qnn37S66+/rgcffFA7duzQsGHDtGzZskAdxcXFWrBggb7++mtdfPHFkqSnn35ahx9+eK2xS0pKkvp+ulamExi+kvsSM0AAAIAfM0DSK/hfsa+44gq7YMGCqF91Z2/UGDlyZGCsF154IfD82LFjA88/9thjIftu377drlmzJmyde/futSNGjLCSbGFhoa2oqNinzRtvvBF4naOOOsr+97//DTteqL9zKuhftJ1QM7Mk0uyRRGaAWGvtk08+Gej3xz/+cZ/rNdcizQD585//HGh33HHHxfzaNTZu3Bjxe7xr1y574oknBmYgVFVV7dPmgQceCNRwxhln2J07d4Ycq7q6ep+ZLv/6178Csze6dOkS8feIutc2bNhgCwoKrCR7wAEH2FWrVu3T55tvvrGFhYVWki0uLt7n5z4VM0AaNGgQcqxNmzbZ/fbbz0qyhx56aMjXqJnVEW3Wj7U26v9fP/jgg8D39sknnwzZpqZmSXbw4MF2165d+7QZP358oM1rr722z/V4vofReGkGCHuAAAAAILWslRYvlj74wPfo+0ccV5kyZYp69uwZ9avm7iZ13X///eratask3yyKVatWadasWZo0aZIk6bTTTtPIkSND9i0sLNT+++8ftjZjjCZNmqR69eqpsrIycIvZYPfee68kqaCgQH/729/UvHnzsOPl+r8sB8/W+O9//xtzvz179mjJkiW64YYbNHbs2MDzN954Y9w1tG7dOuL3OD8/XxMnTpQk/fDDD5o/f36t63v37g1cLy4u1rPPPquGDRuGHCsvL08HHHBArecmTpyovXv3yhijF198MeJnWvfa1KlTtWPHDknSpEmTAhvLBuvTp49uueUWSb47+iSz4WysxowZE3KPmJYtWwZm0Pz73//W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2Gbrf3fZiD1AAAAAkHrdurl6ycuGDRtiutVn48aNddBBBwXO9+zZo/PPP187duxQo0aNNH36dOXn5weuDxw4UNdff73uu+8+vfnmm3riiSdqBSGtWrXS4MGD9e6772rGjBkaNGiQLr/8ch144IHasGGDXn31VT3zzDPq1KmTKioqQs4ikaQhQ4bokksu0VNPPaU5c+bokEMO0VVXXaWjjz5aRUVF+vHHHzV37ly9/PLLOvTQQ/XMM8/U6t+vXz+tWLFCb731lh577DEdffTRgX+hLioqirhcwAmrV6+u9f3ftm2bNm3apHnz5um9997TnDlzAtdOPfVUPf300ymtJ5I+ffqoR48e+s9//qMpU6aooqJC559/vvbff3+VlZXpr3/9q1555RUdffTR+uyzz8KOc+WVV+rtt9/WBx98oNdff109e/bU6NGj1bdvXxUUFGjdunX64osv9MILL+i8886rdZvm3r1766677tLtt9+upUuXqmfPnrryyis1cOBAtWrVShUVFZo/f75ee+011atXT7NmzQr0bdOmjSZOnKgrr7xSa9asUd++fXXzzTerX79+qq6u1ocffqiJEydq+/btMsbo8ccfD3m73NGjR2vUqFFav369fv3rX+v2229X165dtXnzZr3zzjuaMmWK+vbtq88//9zR738o/fr109SpU7VhwwZdf/31uuCCC9SsWTNJvrv/tG/fXpI0fPhwvf3229q+fbv69++vm266SYcddpistZozZ47+/Oc/a926dTrqqKNSXveBBx6okpISlZeX67777lNxcbG6du2q+vV9v+Lvt99+tZYawa9mp1q+cvNLUokkK8mWlZVZAADgXUuXLrXfffedXbp0aaZL8YRZs2bZmr+HxfrVq1evWmPceuutgWsPPvhgyNfZtWuX7dWrl5VkCwsL7bJly2pdX7VqlT3wwAPDvuaBBx5oFy5caNu3b28l2QsvvDDk61RVVdmrrrrKGmMivodQ/efNm2cbNmwYc/tootVqrbVTp06N63vfvn17++ijj0Z97Zr2/fv3j7vuWM2bN8+2aNEibK09e/a0a9asCZyPGzcu5DiVlZX2rLPOivrew/WfMGGCrV+/fsS+4b4P99xzj83Lywvbr2HDhnbatGlhvwfV1dV26NChYfv36NEj6vdg3LhxgeuRBP+3OmvWrH2ub9u2zXbq1Cnsz02wiy66KGzN9erVsw888EDUuqJ9LjX69+8f8TN45JFHwtYyderUiGMHS+TPjrKysuDXK7FZ8LtxLF8sgQEAAAAy4NNPP9W9994rSTrppJM0ZsyYkO3y8/M1ffp0NWrUSJWVlbrgggtq7SNRWlqqb775RjfccIO6dOmihg0bqlmzZurVq5fGjRun+fPn65BDDolaT7169TR58mTNnTtXI0eOVJcuXVRYWKiCggJ17txZgwcP1hNPPKH7779/n769e/fW559/rnPPPVcHHnigGjZsmOB3JXn169dXixYt1KFDBx133HG66aabNHPmTC1fvlyXX355xuoK1rt3b82fP1+jRo1S+/bt1aBBA7Vs2VJHHHGE7rvvPn311Ve1ljiEU1BQoL/97W/65z//qWHDhqljx45q3LixmjZtqm7duunMM8/U888/H1guU9ctt9yi7777Ttdee6169OihoqIiNWrUSJ06ddLxxx+vBx54QC+++GLIvrfeeqvmzZunyy67TAcddJAaN26swsJCde/eXddcc40WL16s4cOHh609Ly9Pr7zyih5++GEdfvjhKiwsVGFhoQ499FDdc889+vLLL2P6HjihSZMmmjNnjq655hp17949sMQnlKefflrPPfecfv3rX6tp06Zq2LCh2rdvr2HDhgXGSJcrrrhCr776qk466SS1bds2MPsD4Rlr3XVvZq8xxpRIKpOksrIylZSUZLgiAACQKcuWLVNVVZXq169fa58BAADCSeTPjvLy8sBGvJJKrbXhN5LJIswAAQAAAAAArkcAAgAAAAAAXI8ABAAAAAAAuB4BCAAAAAAAcD0CEAAAAAAA4HoEIAAAAAAAwPUIQAAAAAAAgOsRgAAAAAAAANcjAAEAAAAAAK5HAAIAAAAAAFyPAAQAAAAAALgeAQgAAIBL5OX5/mpXXV0ta22GqwEAZDtrraqrqyVJ9erVy3A1qUcAAgAA4BL5+fmSfH+h3bVrV4arAQBkux07dgQC85o/Q9yMAAQAAMAlCgsLA8dbt27NYCUAgGxnrdXmzZsD50VFRRmsJj0IQAAAAFyiSZMmgeNNmzZp06ZNganNAABIvuCjsrJS5eXl2r59uyTJGFPrzxC3qp/pAgAAAOCM/Px8tWnTRhs3bpQkbdiwQRs2bFC9evVkjMlwdQCAbFB3nyhjjIqLiwP7SLkZAQgAAICL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\n",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {
      "image/png": {
       "height": 371,
       "width": 544
      },
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Expected: mean stdQ_T=1.3793814883693853\n",
      "Expected: stddev stdQ_T=2.0287618543552277\n",
      "Convolution:  mean stdQ_T=1.3793814883551736\n",
      "Convolution:  stddev stdQ_T=2.0287619587325425\n",
      "1-total mass of stdQ_pdf: -2.3239188351453777e-12\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "\n",
    "for JL_dim in JLdim_list_privacy:\n",
    "\n",
    "#     tf.random.set_seed(1)\n",
    "#     np.random.seed(1)\n",
    "    \n",
    "    privacy_args.num_JL=JL_dim\n",
    "    print('JL_dim:',privacy_args.num_JL)\n",
    "    privacy_engine=dpdl_privacy.privacy_engine_dpdl(privacy_args,verbose=True,interpolate_flag=True)\n",
    "\n",
    "    \n",
    "\n",
    "    \n",
    "    epsilon_list=[]\n",
    "\n",
    "    for i in range(epochs):\n",
    "        \n",
    "        print(f'Starting epoch {i+1}....')\n",
    "        privacy_engine.add_epochs(1)\n",
    "        eps=privacy_engine.calculate_eps()\n",
    "        print('epsilon: ',eps)\n",
    "        epsilon_list.append(eps)\n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "    record_dict = {'epsilon':epsilon_list,'privacy_params':privacy_args}\n",
    "    with open(f'pickles/DPJL{JL_dim}_LSTM_epsilons.pickle','wb') as handle:\n",
    "        pickle.dump(record_dict,handle)\n",
    "        \n",
    "\n",
    "\n",
    "    plt.plot(range(1,epochs+1),epsilon_list)\n",
    "    plt.xlabel('epochs')\n",
    "    plt.ylabel('eps')\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "    privacy_engine.plot_eps_delta_curve(max_eps=50,min_delta=10**(-10))\n",
    "    privacy_engine.print_stdQ_stats()\n",
    "    print('1-total mass of stdQ_pdf:', 1-np.sum(privacy_engine.stdQ_pdf))\n",
    "    \n",
    "    \n",
    "        \n",
    "    \n",
    "    print('\\n\\n\\n\\n\\n')\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "id": "bxY6ZNin5XIa"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "JL_dim: 20\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 99%|█████████████████████████████████████████████████████████████████████████████████▏| 97/98 [07:02<00:04,  4.29s/it]C:\\Anaconda\\lib\\site-packages\\tensorflow\\python\\framework\\indexed_slices.py:437: UserWarning: Converting sparse IndexedSlices(IndexedSlices(indices=Tensor(\"gradients/gradient_tape/gradient_tape/GatherV2_grad/Reshape_1:0\", shape=(25200,), dtype=int32), values=Tensor(\"gradients/gradient_tape/gradient_tape/GatherV2_grad/Reshape:0\", shape=(25200, None), dtype=float32), dense_shape=Tensor(\"gradients/gradient_tape/gradient_tape/GatherV2_grad/Cast:0\", shape=(2,), dtype=int32))) to a dense Tensor of unknown shape. This may consume a large amount of memory.\n",
      "  \"shape. This may consume a large amount of memory.\" % value)\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [07:51<00:00,  4.81s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.694850, Accuracy: 50.000000\n",
      "Per epoch time: 471.664302110672\n",
      "Total per epoch JL time:  438.6570453643799\n",
      "Total per epoch JL time per JL projection:  21.932852268218994\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [07:23<00:00,  4.52s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.689970, Accuracy: 53.035999\n",
      "Per epoch time: 443.4417357444763\n",
      "Total per epoch JL time:  426.3833281993866\n",
      "Total per epoch JL time per JL projection:  21.31916640996933\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [07:22<00:00,  4.52s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.684084, Accuracy: 54.592003\n",
      "Per epoch time: 442.9255123138428\n",
      "Total per epoch JL time:  426.1329219341278\n",
      "Total per epoch JL time per JL projection:  21.30664609670639\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [07:23<00:00,  4.52s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 1.104021, Accuracy: 57.415997\n",
      "Per epoch time: 443.3558838367462\n",
      "Total per epoch JL time:  426.3817820549011\n",
      "Total per epoch JL time per JL projection:  21.319089102745057\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [07:24<00:00,  4.54s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 1.305135, Accuracy: 60.008003\n",
      "Per epoch time: 444.70903277397156\n",
      "Total per epoch JL time:  427.7110364437103\n",
      "Total per epoch JL time per JL projection:  21.385551822185516\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [07:24<00:00,  4.54s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 1.097837, Accuracy: 64.875999\n",
      "Per epoch time: 444.53807497024536\n",
      "Total per epoch JL time:  427.34962701797485\n",
      "Total per epoch JL time per JL projection:  21.367481350898743\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [07:24<00:00,  4.54s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 1.398835, Accuracy: 64.223999\n",
      "Per epoch time: 444.6317310333252\n",
      "Total per epoch JL time:  427.57270336151123\n",
      "Total per epoch JL time per JL projection:  21.37863516807556\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [07:23<00:00,  4.53s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 1.255718, Accuracy: 66.052002\n",
      "Per epoch time: 443.66928458213806\n",
      "Total per epoch JL time:  426.6253502368927\n",
      "Total per epoch JL time per JL projection:  21.331267511844636\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [07:23<00:00,  4.53s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 1.245023, Accuracy: 68.176003\n",
      "Per epoch time: 443.71180391311646\n",
      "Total per epoch JL time:  426.733989238739\n",
      "Total per epoch JL time per JL projection:  21.336699461936952\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [07:24<00:00,  4.53s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 1.232314, Accuracy: 67.024002\n",
      "Per epoch time: 444.2582428455353\n",
      "Total per epoch JL time:  427.29821276664734\n",
      "Total per epoch JL time per JL projection:  21.36491063833237\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [07:26<00:00,  4.56s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 1.304735, Accuracy: 67.820000\n",
      "Per epoch time: 446.95574378967285\n",
      "Total per epoch JL time:  429.86169242858887\n",
      "Total per epoch JL time per JL projection:  21.493084621429443\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [07:23<00:00,  4.53s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 1.157465, Accuracy: 71.559998\n",
      "Per epoch time: 443.6689975261688\n",
      "Total per epoch JL time:  426.56897234916687\n",
      "Total per epoch JL time per JL projection:  21.328448617458342\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [07:25<00:00,  4.55s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 1.413053, Accuracy: 69.400002\n",
      "Per epoch time: 445.68804836273193\n",
      "Total per epoch JL time:  428.5718729496002\n",
      "Total per epoch JL time per JL projection:  21.42859364748001\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [07:25<00:00,  4.55s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 1.300099, Accuracy: 71.372002\n",
      "Per epoch time: 445.9371666908264\n",
      "Total per epoch JL time:  428.78893661499023\n",
      "Total per epoch JL time per JL projection:  21.43944683074951\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [07:24<00:00,  4.54s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 1.174228, Accuracy: 72.655998\n",
      "Per epoch time: 444.5135200023651\n",
      "Total per epoch JL time:  427.3828375339508\n",
      "Total per epoch JL time per JL projection:  21.36914187669754\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "JL_dim: 30\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting epoch 1....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [11:33<00:00,  7.07s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1, Loss: 0.691706, Accuracy: 51.403999\n",
      "Per epoch time: 693.0044872760773\n",
      "Total per epoch JL time:  660.1477065086365\n",
      "Total per epoch JL time per JL projection:  22.00492355028788\n",
      "\n",
      "\n",
      "Starting epoch 2....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [11:06<00:00,  6.80s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2, Loss: 0.691411, Accuracy: 51.484001\n",
      "Per epoch time: 666.346471786499\n",
      "Total per epoch JL time:  649.2016198635101\n",
      "Total per epoch JL time per JL projection:  21.640053995450337\n",
      "\n",
      "\n",
      "Starting epoch 3....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [11:06<00:00,  6.80s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3, Loss: 0.698795, Accuracy: 51.587997\n",
      "Per epoch time: 666.3957693576813\n",
      "Total per epoch JL time:  649.3936214447021\n",
      "Total per epoch JL time per JL projection:  21.646454048156738\n",
      "\n",
      "\n",
      "Starting epoch 4....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [11:10<00:00,  6.84s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4, Loss: 1.081249, Accuracy: 52.455997\n",
      "Per epoch time: 670.1271362304688\n",
      "Total per epoch JL time:  652.9932782649994\n",
      "Total per epoch JL time per JL projection:  21.766442608833312\n",
      "\n",
      "\n",
      "Starting epoch 5....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [11:15<00:00,  6.90s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5, Loss: 1.139050, Accuracy: 60.420002\n",
      "Per epoch time: 675.8984272480011\n",
      "Total per epoch JL time:  658.6670379638672\n",
      "Total per epoch JL time per JL projection:  21.955567932128908\n",
      "\n",
      "\n",
      "Starting epoch 6....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [11:15<00:00,  6.89s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6, Loss: 1.308139, Accuracy: 61.448002\n",
      "Per epoch time: 675.1074187755585\n",
      "Total per epoch JL time:  657.9746148586273\n",
      "Total per epoch JL time per JL projection:  21.932487161954246\n",
      "\n",
      "\n",
      "Starting epoch 7....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [11:16<00:00,  6.91s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7, Loss: 1.257712, Accuracy: 63.612003\n",
      "Per epoch time: 676.7954659461975\n",
      "Total per epoch JL time:  659.6544425487518\n",
      "Total per epoch JL time per JL projection:  21.988481418291727\n",
      "\n",
      "\n",
      "Starting epoch 8....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [11:16<00:00,  6.90s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8, Loss: 1.361526, Accuracy: 64.391998\n",
      "Per epoch time: 676.3070006370544\n",
      "Total per epoch JL time:  659.08513712883\n",
      "Total per epoch JL time per JL projection:  21.969504570961\n",
      "\n",
      "\n",
      "Starting epoch 9....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [11:14<00:00,  6.88s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9, Loss: 1.202026, Accuracy: 66.571999\n",
      "Per epoch time: 674.4237630367279\n",
      "Total per epoch JL time:  657.3962969779968\n",
      "Total per epoch JL time per JL projection:  21.913209899266562\n",
      "\n",
      "\n",
      "Starting epoch 10....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [11:16<00:00,  6.90s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10, Loss: 1.367251, Accuracy: 65.075996\n",
      "Per epoch time: 676.1898565292358\n",
      "Total per epoch JL time:  658.9262089729309\n",
      "Total per epoch JL time per JL projection:  21.964206965764365\n",
      "\n",
      "\n",
      "Starting epoch 11....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [11:13<00:00,  6.87s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11, Loss: 0.891737, Accuracy: 70.776001\n",
      "Per epoch time: 673.519180059433\n",
      "Total per epoch JL time:  656.2726786136627\n",
      "Total per epoch JL time per JL projection:  21.875755953788758\n",
      "\n",
      "\n",
      "Starting epoch 12....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [11:15<00:00,  6.89s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12, Loss: 1.201269, Accuracy: 69.232002\n",
      "Per epoch time: 675.6901385784149\n",
      "Total per epoch JL time:  658.7434754371643\n",
      "Total per epoch JL time per JL projection:  21.95811584790548\n",
      "\n",
      "\n",
      "Starting epoch 13....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [11:14<00:00,  6.88s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13, Loss: 1.142120, Accuracy: 69.704002\n",
      "Per epoch time: 674.6484758853912\n",
      "Total per epoch JL time:  657.6243107318878\n",
      "Total per epoch JL time per JL projection:  21.920810357729593\n",
      "\n",
      "\n",
      "Starting epoch 14....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [11:13<00:00,  6.87s/it]\n",
      "  0%|                                                                                           | 0/98 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14, Loss: 1.106126, Accuracy: 71.804001\n",
      "Per epoch time: 673.5062327384949\n",
      "Total per epoch JL time:  656.5308516025543\n",
      "Total per epoch JL time per JL projection:  21.884361720085145\n",
      "\n",
      "\n",
      "Starting epoch 15....\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 98/98 [11:17<00:00,  6.91s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15, Loss: 1.152925, Accuracy: 71.504005\n",
      "Per epoch time: 677.1462213993073\n",
      "Total per epoch JL time:  659.7518210411072\n",
      "Total per epoch JL time per JL projection:  21.991727368036905\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "\n",
    "for JL_dim in JLdim_list:\n",
    "\n",
    "#     tf.random.set_seed(1)\n",
    "#     np.random.seed(1)\n",
    "    \n",
    "    privacy_args.num_JL=JL_dim\n",
    "    print('JL_dim:',privacy_args.num_JL)\n",
    "#     privacy_engine=dpdl_privacy.privacy_engine_dpdl(privacy_args,verbose=True,interpolate_flag=True)\n",
    "\n",
    "    \n",
    "\n",
    "    model = MyModel(train_ds)\n",
    "\n",
    "\n",
    "    loss_obj = tf.keras.losses.SparseCategoricalCrossentropy(from_logits=True, reduction=tf.keras.losses.Reduction.NONE)\n",
    "    test_loss = tf.keras.metrics.Mean(name='test_loss')\n",
    "    test_accuracy = tf.keras.metrics.SparseCategoricalAccuracy(name='test_accuracy')\n",
    "    \n",
    "    accuracy_list=[]\n",
    "    epochtime_list=[]\n",
    "    epochJLtime_list=[]\n",
    "    #epsilon_list=[]\n",
    "\n",
    "    step=0\n",
    "    for i in range(epochs):\n",
    "        \n",
    "        print(f'Starting epoch {i+1}....')\n",
    "#         privacy_engine.add_epochs(1)\n",
    "#         eps=privacy_engine.calculate_eps()\n",
    "#         print('epsilon: ',eps)\n",
    "#         epsilon_list.append(eps)\n",
    "        \n",
    "        \n",
    "        \n",
    "        epochJL_time=0\n",
    "        epoch_start_time=time.time()\n",
    "        for images, labels in tqdm(train_ds):\n",
    "    \n",
    "            n_images = images.shape[0]\n",
    "            \n",
    "\n",
    "            # Compute the mask\n",
    "            JL_start_time=time.time()\n",
    "            grad_norm = approximate_grad_norm(images, labels, model, loss_obj, JL_dim)\n",
    "            epochJL_time+=(time.time()-JL_start_time)\n",
    "            mask = tf.math.minimum(1.0, clipping_norm / grad_norm)\n",
    "\n",
    "\n",
    "            # Compute the gradient\n",
    "            with tf.GradientTape() as tape:\n",
    "                predictions = model(images, training=True)\n",
    "                loss_ind = loss_obj(labels, predictions)\n",
    "                loss = tf.reduce_sum(mask * loss_ind) / batch_size\n",
    "            gradients = tape.gradient(loss, model.trainable_variables)\n",
    "\n",
    "            # Add the noise into the gradient\n",
    "            if sigma > 0.0:\n",
    "                noise_level = sigma * clipping_norm / batch_size\n",
    "                for k in range(len(gradients)):\n",
    "                    gradients[k] += noise_level * (tf.random.normal(gradients[k].shape, dtype=tf.float32))\n",
    "\n",
    "            if step==0:\n",
    "                m=gradients\n",
    "                u=[item*item for item in gradients]\n",
    "            else:\n",
    "                for k in range(len(gradients)):\n",
    "                    m[k]=beta1*m[k]+(1-beta1)*gradients[k]\n",
    "                    u[k]=beta2*u[k]+(1-beta2)*gradients[k]*gradients[k]\n",
    "\n",
    "            # Run the gradient descent\n",
    "            k = 0\n",
    "            for p in model.trainable_variables:\n",
    "                p.assign(p - lr * m[k]/(tf.sqrt(u[k])+1e-8))\n",
    "                # some magic line for potential bug: https://github.com/tensorflow/tensorflow/issues/36236\n",
    "                k = k + 1\n",
    "        \n",
    "            step+=1\n",
    "\n",
    "        epoch_time = time.time()-epoch_start_time\n",
    "        epochtime_list.append(epoch_time)\n",
    "        epochJLtime_list.append(epochJL_time)\n",
    "        # Record the result\n",
    "        for images, labels in test_ds:\n",
    "            predictions = model(images, training=False)\n",
    "            loss = loss_obj(labels, predictions)\n",
    "            test_loss(loss)\n",
    "            test_accuracy(labels, predictions)\n",
    "\n",
    "\n",
    "        print('Epoch %i, Loss: %f, Accuracy: %f' % \n",
    "              (i + 1, test_loss.result(), test_accuracy.result() * 100))\n",
    "        accuracy_list.append(test_accuracy.result().numpy())\n",
    "\n",
    "\n",
    "        test_loss.reset_states()\n",
    "        test_accuracy.reset_states()\n",
    "        print('Per epoch time:', epoch_time)\n",
    "        print('Total per epoch JL time: ',epochJL_time)\n",
    "        print('Total per epoch JL time per JL projection: ',epochJL_time/JL_dim)\n",
    "        print('\\n')\n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "    tf.keras.backend.clear_session()\n",
    "    \n",
    "    record_dict = {'accuracy':accuracy_list,'time':epochtime_list,\n",
    "                   'JLtime':epochJLtime_list,'privacy_params':privacy_args}\n",
    "    with open(f'pickles/DPJL{JL_dim}_LSTM.pickle','wb') as handle:\n",
    "        pickle.dump(record_dict,handle)\n",
    "        \n",
    "        \n",
    "\n",
    "    print('\\n\\n\\n\\n\\n')\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "collapsed_sections": [],
   "name": "DPJLembedding.ipynb",
   "provenance": [],
   "toc_visible": true
  },
  "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.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
