{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Whitening (ZCA, PCA)\n",
    "\n",
    "https://jermwatt.github.io/control-notes/posts/zca_sphereing/ZCA_Sphereing.html\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import scipy\n",
    "\n",
    "palette = ['#636EFA', '#EF553B', '#00CC96', '#AB63FA', '#FFA15A', '#19D3F3', '#FF6692', '#B6E880', '#FF97FF', '#FECB52'] #  plotly.colors.qualitative.Plotly\n",
    "# Matching light colors\n",
    "# ['#ccd0ff', '#ffd3cc', '#ccfff2', '#e4ccff', ...]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Eigenvalues:\n",
      " [-0.23606798  4.23606798]\n",
      "Eigenvectors:\n",
      " [[-0.85065081 -0.52573111]\n",
      " [ 0.52573111 -0.85065081]]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.7/site-packages/ipykernel_launcher.py:7: RuntimeWarning: covariance is not positive-semidefinite.\n",
      "  import sys\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.lines.Line2D at 0x7fd52ec59f10>"
      ]
     },
     "execution_count": 66,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# generate 25 random points sampled from a correlated 2d Gaussian\n",
    "np.random.seed(0)\n",
    "n = 25\n",
    "mean = [1, 3]\n",
    "cov = [[1,   2], \n",
    "       [2,   3]]\n",
    "x, y = np.random.multivariate_normal(mean, cov, n).T\n",
    "data = np.vstack((x, y)).T\n",
    "\n",
    "eigval, eigvec = np.linalg.eig(cov)\n",
    "print(\"Eigenvalues:\\n\", eigval)\n",
    "print(\"Eigenvectors:\\n\", eigvec)\n",
    "\n",
    "# Normalizing eigenvectors for plotting\n",
    "for i in range(len(eigval)):\n",
    "    eigvec[:, i] = eigvec[:, i] / np.linalg.norm(eigvec[:, i]) * np.sqrt(np.abs(eigval[i]))\n",
    "\n",
    "c = palette + [palette[0]]* (n - len(palette))\n",
    "plt.scatter(data[:, 0], data[:, 1], c=c)\n",
    "plt.quiver(mean[0], mean[1], eigvec[0, 0], eigvec[1, 0], color='r', scale=7, label='Principal Component 1')\n",
    "plt.quiver(mean[0], mean[1], eigvec[0, 1], eigvec[1, 1], color='b', scale=7, label='Principal Component 2')\n",
    "plt.axis('equal')\n",
    "# remove box and axes\n",
    "plt.axis('off')\n",
    "# add spines\n",
    "plt.axhline(0, color='black',linewidth=0.75)\n",
    "plt.axvline(0, color='black',linewidth=0.75)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.7/site-packages/ipykernel_launcher.py:7: RuntimeWarning: covariance is not positive-semidefinite.\n",
      "  import sys\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7fd52ed2d790>"
      ]
     },
     "execution_count": 67,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# generate 25 random points sampled from a correlated 2d Gaussian\n",
    "np.random.seed(0)\n",
    "n = 25\n",
    "mean = [1, 3]\n",
    "cov = [[1,   2], \n",
    "       [2,   3]]\n",
    "x, y = np.random.multivariate_normal(mean, cov, n).T\n",
    "data = np.vstack((x, y)).T\n",
    "\n",
    "c = palette + [palette[0]]* (n - len(palette))\n",
    "plt.scatter(data[:, 0], data[:, 1], c=c)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABrgAAAEYCAYAAAAH7fbeAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/NK7nSAAAACXBIWXMAAAsTAAALEwEAmpwYAAC47UlEQVR4nOzdd5hU5fn/8fd9ZmZ36b13BSsqKIK9F6xoolHTNIkhzagxiYkpmvj9Jj/NN0UT04gaNTH2qKjYBXsBURFEFEWkCUivuzNz7t8fZxZmd2cb7M7s7H5e1zXX7py29+7Oc8pzP8XcHREREREREREREREREZFiERQ6ABEREREREREREREREZHGUIJLREREREREREREREREiooSXCIiIiIiIiIiIiIiIlJUlOASERERERERERERERGRoqIEl4iIiIiIiIiIiIiIiBQVJbhERERERERERERERESkqCjBVWBm9hMzu7Gpt23AsdzMhjfFsUSkZVN5FxERaTpmdoGZvVDH+kfN7Px8xlQb3QOINJ7KuEjjmNk0M7sw8/0XzOyJJj7+0MxnPd6Ux21qZnaHmZ2R+b7KecTMNprZLpnvbzGz/y1QmDsk+3/cEpnZd83s2kLHIa1Hdjk1s8PNbF4z/Axdw5uIElxNKHMBe9vMNpvZJ2b2VzPrWtc+7v5rd2/QRaIx2+6MzIVrq5ltMLP1Zva6mf3YzEobcQwVUilqZvZ5M5uRuRFdlnmQPawJjvsLM/t3U8TYFFTeRRrPzD4ysy2Z88PyzM1vx6z1J5rZc5lytdLMnjWz06sd46hM2flRPT/rKDMLMz9ro5ktNrO7zezARsTbos47Ig2R53I2z8zOyXp/aGa/6ss2NKRyzd1PcvdbM/vVWVFeSLoHkELIVH5vzPFyM7syazuV8Z2kMt56ZK6JK8ysQ9ayC81sWgHDysndb3f3E/L5M7PuGTaY2Voze8nMvmlmDarztCZIoJnZvsB+wIO51rt7R3f/cEePX8vPrCzjG81sXeacuU8j9m+S8p3195tSbfm/zewXO3v8BvoH8AUz652nn9dmZcrbcTmWH2RmT5rZ6sx1+x4z61fHcSo/v4Oylh1nZh81U+g7zN2fd/fd8/kzdQ1vHCW4moiZfR+4Fvgh0AU4CBgCPGlmJbXs05Jbn1zk7p2AfsD3gXOBKWZmhQ1LpPmZ2WXAdcCvgT7AYOAvwIQChgU023lD5V2k8U5z947A/sAY4GcAZnYWcA9wGzCQ6BxyJXBatf3PB1YDX27Az1qa+VmdiO4v3gWeN7Njm+D3EGnJ8lXOngOOyHp/BFE5q77sZXdP7dBv0nLpHkDyKlP53TH7BVwKLCeqoFQZb1oq461HDLhkZw9ikdZYF3ha5rM+BLgG+BFwUx5//jeA293d8/gzISrjHYHuwDTgX3n++dnGmdkhO3uQHanzcPetwKM07NlKmkc3YBIwlKgcbgD+Wc8+m4CfN8UPN7NYUxynhdE1vIFa40Ut78ysM/BL4Lvu/pi7J939I+BzRAX7i5ntfmFm92ZaMawHLrBqrarN7MtmttDMVpnZz7Mz49nbZrWQON/MPjazT83sp1nHGWtmL2darywzsxtqS7TVxd03ufs04HTgYOCU+o5vZs9ldn8r05LkHDPrZmYPZ7L4azLfD2xsPCLNzcy6AFcD33H3/2bKQNLdH3L3H2a2CTItJz7IlNW7zax7Zl2tZdPMxgM/Ac7JlI23Kn+mmd2UKUtLzOx/Ky/OFrUKfdHM/mBmq4BfmFmpmf02c/zlZvY3M2uX9Tv8MHOspWb21Yb+7irvIo3n7kuIHqZGZm40fw/8j7vf6O7r3D1092fd/euV+1jU+vYs4DvACDMb08Cf5e6+2N2vBG4kalhTeczrzWyRbW/ddXhmeW3nna+Y2VyLWoR9aGbfaJI/iEgzyEM5q175fThR+aq+7LnsnTLX4jVmtsDMTspaPs2ilvV7An8DDs6Uv7WZ9bVexy3qkbLYzL5vUWv9ZWb2laxj6x5AWhUzG03UsOxcd1+mMq4yLrX6P+AHVssoQWZ2iJlNt6gnz3TLSjRkPrO/MrMXgc3ALhY9s37bzN7P3A/+j5ntalHvp/UWPeNWfhYa/H+3rF6NZna5Ve2pmTSzWzLr6noGjmXKwadm9iGZz2tDZM4Zk4FzgPPNbGTmmKeY2RuZ322RVe1ZVPlZX5uJ8+DM3+IZi573PzWz22v722ecBDxb20qrpSeFmXUys6lm9keL7GHbe8HMM7PPNfD3TgN3AntlHbtR5TuzfIKZvZn5O31g0bNEpSEW1U1sMLMnzKxntTB+A/yqjr/B181sfuZ3m2xm/av9fb5jZu8D79v2c+Xltv1ceYaZnWxm72WO8ZNqP2IajfisSNNy90fd/R53X+/um4EbgEPr2e2PwHlmtmuulWa2Z+b8tdbM5lhWT26LRnf4q5lNMbNNwNEW1aH/0MxmmdmmzDmmj0UjMm0ws6fMrFvWMe6xaAS2dRb1gNy7ljiOMrPFme8rn6srX+WW6U1ruoYXjBJcTeMQoAz4b/ZCd98ITAGOz1o8AbgX6Arcnr29me1F1EvkC0TZ2S7AgHp+9mHA7sCxwJUW3WQDpIHvAT2JPvzHAt9u3K9V5Xf5GJhBdONf5/HdvfJBYb9Mq7y7iD5r/yTK4g8GthCd7ERamoOJyvP9dWzzXeAM4EigP7AG+HO1bWqUTXd/jKhX2F2ZsrFfZttbgBQwHBgNnABkD0c6DviQqPXqr4hapO0GjMrsM4CoVWtlZfYPiM47I4AaXcfro/Iu0nAWDalwMvAGUZkfRHSdr8tngI1ErdMfJ2qB3lj/Bfa37UPVTCc6J3QH/gPcY2ZldZx3VgCnAp2BrwB/MLP9dyAOkWaXh3L2HLC3mXW3qFX7GOAuoGvWskOpWvk9DphHdG38DXCTWdXWlO4+F/gmUa+Qju7eNbOq1ut4Rl+2Pwd8Dfhz1sO47gGk1bCosvheomTWtMxilXGVccltBlEF/g+qr7CoseUjRJXFPYiSxI+YWY+szb4ETCQaEWBhZtmJwAFEIwRcTtT74otEZXAkcF5mux36v7v7b7J6au4JrCQqe1D3M/DXie5TRxOV17Pq+1k5fvZrwGK2f9Y3EfXu6UpUOfwty8yXxfZkd9dMvC8DBvw/ouf9PYn+Jr/I9bMy9+PDiM4ZDZb5/zwNvOjuFwPtgSeJ7uV7E/XW+EumrrC+Y5UQ1SW+krW4UeXbzMYS9Zz9IdHf6Qjgo6zjfZ7ouaE3UELNz+JfgN0s9/B1xxD9PT9HVN+5kCghl+0MonNv5e/bl6hupvI8+A+iz+cBRP/Xn5vZsKz95xINEyktwxHAnHq2WUL0f/1l9RVmlgAeAp4g+sx9F7jdzLKHCvw8UR1ZJ6ByuODPEl0ndyPq+f0oUYPPXkTnsouz9n+U6HraG5hJtXr6XNz9rqzzWn+iuro7Mqt1DS8QJbiaRk/g01qGM1iWWV/pZXd/INMKbUu1bc8CHnL3F9y9gqgQ1Ne9+ZfuvsXd3wLeInMyd/fX3f0Vd09lepP9nagyfmcsJao4a/Tx3X2Vu9/n7pvdfQPRCWhn4xFpDj2ovTxX+ibw00xPinKiG92zrGpX+pxlszoz60NUaXdpplXGCuAPRDezlZa6+58yMW0lejD5nruvzpSnX2dt/zngn+4+2903UctNeAOovIvU7QGLWmq/QNRa89dE5w+Irv11OZ8o4ZQmeoA9N3MD3xhLiR68uwK4+78zZS/l7r8DSokqCXNy90fc/QOPPEv04HB4bduLFEheypm7LwQ+JioD+wHvZ+7TX8xaVgK8mrXbQnf/R+b4txJV1vSp7xfKVJDXdR0HSAJXe9SDfApRJf7uDdhX9wBSNDKf59uA2UQJpEoq4yrjUrsrge+aWa9qy08h+lz/K/O/vINoGM7sYT1vcfc5mfXJzLLfeNTbYg5RWXzC3T9093VEFb+jYef/75keDA8A17v7ow14Bv4ccJ27L3L31USJkR2R/Vmf5u5vZ+riZhFVSNf1WZ/v7k+6e7m7ryRKGta2fdfM1w2NiK0/0b3NPe7+s8yyU4GP3P2fmf/TG8B9wNl1HOePmXulDcBFZCUKdqBe8GvAzZnfO3T3Je7+btb6f7r7e5nz591ElfjZthB9Nv43x7G/kDn2zEwdyhVEvV+HZm3z/zLnvsq60iTwq8zn9U6iutXr3X1D5jP7DlXrWTYQNR6QArNoTroriZKl9fl/wGk5ek8dBHQErnH3Cnd/BniY7Yl3gAfd/cXM53VrZtmf3H25RyNAPA+86u5vZNbfT+a8BuDuN2c+T5X1evtZNKpTQ37HgOj+Y5q7/13X8MJqyXNAFZNPgZ5mFvealeL9MusrLarjOP2z17v7ZouGJKvLJ1nfbyYq/JjZbkQX4DFErUDiwOv1HKs+A4CXduT4Ztae6IZlPNG4rACdzCyWeWgQaSlWUXt5rjQEuN/Mwqxlaao+9OYsm7UcKwEsy2oUGlD1XJH9fS+iMvd61vZGNCY7ROeR7LK4kB2j8i5StzPc/ansBVnX7H7Aglw7ZXqiHE30UAfRRNSTiComHmjEzx9A1Ahmbea4PyB6KO2fWd6Zqg1sqsdxEnAVUQuzgKhsv92Iny+SD/ksZ5VDmH1M9DAMUWKtctlrmYffStuu85l7dqj9Wp+tvus4wKpq9yCV9xG6B5DW5EfA3sAB7lXmrFEZVxmXWrj7bDN7GPgxUW+VSv2p+XlYSNURgXLVRS3P+n5Ljvd9oUn+7zcB89y9cnjt+p6Bq9SNsXOf9dWZ32EcUe+KkUQJ7VKiHqA5ZZJw1xMlwTtl4ltTy+ZrM187ETVIbYhTiJLbf8taNoRoHqu1Wcvi1D2v1sXufmNWT9TJZnaku8/agXrBQUSjUNWmIXUcNwI/NLPqcyb2J+ohA0QjXmXu6QawvZdY9c/oqqzPV2XSq/pnNDuGTsC6OuKXPLBoKM5HgUvc/fn6tnf3lWZ2A9FUIX/NWtUfWOTu2fVuTXFeq6w3jxEleM4muv5W/pyeNOxzVNlzrLJHmK7hBaQeXE3jZaCcaJiEbcysI9E4vE9nLa6rR9Yyokl0K/dvx/YWbI31V6IWOyPcvTNRd8wdnoQu8xBxANsfBhp7/O8TtSQfl9m+squkJsaTlqayPJ9RxzaLgJPcvWvWqyzTQqQ+1c8BizI/r2fWsTq7+9617PMp0UV576ztu3jUPRqi88igrO0HNyCmKlTeRXbYPKIy/dk6tvkS0f3XQ2b2CdGQBmU0fpjCM4GZ7r7Jovm2LidqFdbNoyGS1rG9zFU575hZKVFr0N8CfTLbT0FlVIpDc5Wzysrvw9l+/Xs+a9lztexXn+rX/fqu43XRPYC0CmZ2FPBT4Cx3X1tttcq4yrjU7SqiIfyyK3mXEiVHsg0mGv6rUn2jA9Vlh//vZvZjogZVX8taXN8zcFN81g8k+htVDlv2H2AyMMjduxAllnLeK2f8OrN8n8zv/EVq+X0zvTE+IPo9G+ofwGPAlKwhxxcBz1arZ+jo7t+q72CZHizPA/OJhnuExpfvRUDOuZAayqPRqH4J/E+1n1XlM5r5nXvQdJ9RiIaSfGsnjyE7wcyGAE8RDT1cV2K2uv8jarhyQNaypcCgTPK2UlOe1z5PNI3QcUQ9/4ZmljfkvHYuUU+ys3x7j1hdwwtICa4m4FH37V8CfzKz8WaWyHSzvZtozN+GFup7ibplHpIZP/cX7PiHrBOwHthoZnsA9V4QczGz9mZ2JFGruNfY3pqjvuMvB3apFs8Wokk7uxPdlIm0OJnyfCXRWPhnZMpAwsxOMrPK4VP+Bvwqc/HGzHqZ2YQG/ojlwNDKi7S7LyMaGux3ZtbZzAKLJrTN2U0403rlH0Tz5fTO/PwBZnZiZpO7gQvMbK9M64wGlzWVd5Gdk2mBfhnRePBfySrTh5nZpMxm5xPdM4zKen0WONmqzpNQg0UGmNlVRHMUVE6s3IloDoOVQNzMriTqwVWpynmH7a1WVwKpTG+uExApAs1Yzp4jGrLkCKJhyyDq1TiM6IF7Ryu/lwMDM/f2DbmO10r3ANIamFk/oqGmLvVo+K0qVMZVxqVu7j6faB6r7HlkphDNffR5M4ub2TlE8xg93EQ/dof+75l7zIuBMz1rio4GPAPfDVxsZgMtmp/uxw0NNHO8U4nOM/9298oRCjoBq919q0VzTX0+a7eVRL03qn/WNwLrzGwA9Q+1NoXGD/V1EVFS/6FMA/eHif6PX8rUQSTM7EAz27MhBzOzg4n+75XzHjW2fN8EfMXMjs38TwZk9musfxE1OhifteyOzLFHWdTY7tdEQ8d9tAPHr82RRD2HpPklzKws6xXPlJNngBvc/W/1HSBbprHL74gabVZ6lain4OWZsnAU0bCr1edu21GdiBLtq4h6P/26ITuZ2WjgT0QjTaysXK5reGEpwdVE3P03RBVNvyX6cL1K1Prh2GpDHdR1jDlEk+bdSZTZ3Ug0CXyD9q/mB0QX7A1EBeyuujev4QYz20BUGK4jauk9PqtraH3H/wVwq5mtNbPPZY7Rjiij/QpRSxWRFsmj+WsuA35GdLO7iOjm84HMJtcTtf56IlNOXiGaDLUhKodBWGVmlV30v0xU4fwO0bAH9xINy1KbHxG1zHrFzNYTtZDZPRP7o0Tl7ZnMNs80ICaVd5Em4u73AucAXyVqdbacaBz6B83sIKKWi39290+yXpOJyut5tRy2v5ltJLovmA7sAxzl7k9k1j9OVM7eIxrqYCtVh2uoct7xaLzti4lustcQle/JO//bi+RHc5Qzd3+P6Jr/SWWPksx18DWihPFLOxjuM0QVTZ+YWeWw5bVexxtA9wBS7L5ONKz39Wa2sdrrb6AyXtu+KuOS5WqgstcP7r6KaP6m7xNV1l4OnOrun+bevdGuY8f+7+cQDds1t3o5p+5n4H8Q3d++RTSs3X8b8LMeynzWFxH1EP098JWs9d8Grs5scyXRfTAQDUNKNNzYi5nP+kFESfT9iUZFeKQBMUwCvmBmDW6knknoTyRqGP8g0ZxTJxDN2bOUaEjAa4kaptXmhsq/LVFi6WeZcwU0sny7+2tEf7M/EP3ez1KzZ2BDfq800d+4e9ayp4CfE52DlhH1FDs35wF2gJmVEc3rdmtTHVPqNIUoUVL5+gVRA8xdgF9kX9sbcczriab+ALb1BjyNaGS0T4G/AF/2qvPC7YzbiJ6dlxCdh15p4H4TiIb3eyHr96wsc7qGF4h5leGupSWxaIjDtURdDXOOPy4iIiIiIiIiIiKFY2b/Ae529wcKHUtbY2bfJRp+8vJ6NxaRVkcJrhbGookYnyYamvB3RL1C9nf9o0RERERERERERERERAANUdgSTSDqirwUGAGcq+SWiIiIiIiIiIiIiIjIdurBJSKY2UdEY7amgZS7jylsRCIiIiIiIiIiIiIitYsXOgARaTGObsJJaEVEREREREREREREmk2zJLh69uzpQ4cObY5D8/rrr3PAAQc0y7FF8uH111//1N17FTqOHdWc5but0nmtdVEZl0LS+aR5FXv5BpXxYqcy3ryKvYyrfBeWymfLpzIu2VRmW5diL9+gMt7S6BzRstRVxptliMIxY8b4jBkzmvy4AGaGhlWUYmZmr7e0IQDNbAGwBnDg7+4+qdr6icBEgMGDBx+wcOHC/AfZium81rq0xDLeGM15DZfmp/NJ8yr28g0q48VOZbx5FXsZV/kuLJXPlk9lXLKpzLYuxV6+QWW8pdE5omWpq4wH+Q5GRFqkw9x9f+Ak4DtmdkT2Snef5O5j3H1Mr15F3SBGRERERERERERERFoBJbhEBHdfkvm6ArgfGFvYiEREREREREREREREaqcEl0gbZ2YdzKxT5ffACcDswkYlIiIiIiIiIiIiIlK7eKEDEJGC6wPcb2YQnRP+4+6PFTYkEREREREREREREZHaKcEl0sa5+4fAfoWOQ0RERERERERERESkoZTgkpySSeeNt52VnzqDBhgj9zSCwAodloi0MR8vdua8G1JWBmNGBXTqqPOQSFNR+RKRYhCGzuy5zqIlTq+exuh9jERC56uWYOMmZ8YbIZu3wF67G0MHawYEERFpPstXOG/ODgkC2H/fgB7ddT8g+bNylfPGrBCA0fsG9Oqhz19LoQSX1PDpKuf/XZdiazlUVEBJCfTqAT+6JE67MhVeEWl+7s6td6Z57XUnlYZ4DO55IOTbX4sxck9VnojsDJUvESkWW7Y6116fYuWq7c8ld90PV1wap6cqFQpq7nshf/pHGhxSaXj4Cdh/35CvfiGmhpEiItLkHnkizcNPhIQhmMF/Hw4598yAIw+NNdvPNLObgVOBFe4+Msd6A64HTgY2Axe4+8zMuvOBn2U2/V93v7XZApVm99Szae6bHOKZ9/c/HHLcUcaiJTDvfaekBI481Dh9fIx4XPdB+aZaDKnh5v+kWb8BysvBPfr6yQp48NF0oUMTkTbi7Xec6TOdiiSEIVQko9ff/pkmmfT6DyAitZo1R+VLRIrDg1PSfLKi6nPJ+g3R84oUTirl/PXmNBUVbL+WVMAbs6JRQERERJrS0k+ch58ISSYhnYZUCpJJuPO/IWvWNut15xZgfB3rTwJGZF4Tgb8CmFl34CpgHDAWuMrMujVnoNJ8Vn7q3Dc5JJmKPnupFCRT8OhTzpy5TjIFmzbDk9OcSbfqHrUQlOCSKsrLnQ8+dLza9SGVglem62FFRPLjxddCyityrDCYN1/nIpGd8dJ0lS8RKQ6vvu6kUlWXucMHHzrl5TpfFcr8BU6Y489fXgEvvhrmPyAREWnVZrwRks6VNzB48+3mu+64+3PA6jo2mQDc5pFXgK5m1g84EXjS3Ve7+xrgSepOlEkLNnPW9p5b1WUvTyajxtorP9U9ar5piEKpQkVQRFq66gl4EWkklSERKRJ1XfN1KmuZdJ8mIiL5VODLzgBgUdb7xZlltS2vwcwmEvX+YvDgwc0Tpey8Bn7Q4nFY8kk0b2wuGzc5905O8/qb0QEPHG189vQYHdprWMOdoR5cUkVZqbHLUMOqlat4DMYdoMImIvlx8IEBpSU1l7vD7sN1LhLZGbWVL1S+RKSFGbu/Ea82tYYZ7DLUKCvV+apQhg8zcv31S0vg0HGqYhARkaZ1wH5BjfsBABxG7VPc1x13n+TuY9x9TK9evQodjuQwet+gRj15bVJp6Nsr98bptHPNdSlenu5s2QpbtsKLr0XLwlxd46XBivssIM3iq1+I0bED2yq/Skuhdy+YcHLzTdwoIpJtv72N/fczSkqiiqxEAkoS8I3zY5SUqEJLZGfsNzJ3+Zp4foxEQuVLRFqOM06J0bsXlJVG70tLoWMH+MoX9FxSSPG48c2vxCgpia4hZlBSAvvubey/r64jIiLStAb0N046LiCRgFgAsRgk4nD2GQHduxb0urMEGJT1fmBmWW3LpQj17mmccWrm8xeLPoPxODWSrvE4jNjF6Nsn92dy1hxn7TqqDLeZTsOatTDrHSW4doaGKJQaevU0rr0qzutvOZ+ucgYNMPbZy4jF9LAiIvlhZnzti3GOOTxkzrtOu3YwZlRAl846D4nsLJUvESkW7dsZV10e5+13nEVLnJ49jAP2MzV2aQH23iPg2quM6TNDNm2BvXc3hg0xrKFNnEVERBrhtPExxowOeGNWSCwG++8X0KtHwa85k4GLzOxOYBywzt2XmdnjwK/NrFtmuxOAKwoVpOy8E4+OMWrvgJmZOd/23ydgazn86+40Cxc5sRgcfKBx7pm1N8JavNTZWl5zeXlFtG7UyOh9Ou28+bYz592QLl2Mw8YF9Ohe8M96i6YEl+RUUmIcfKAKj4gU1rAhAcOGFDqK4mdmMWAGsMTdTy10PNIyqHyJSDGIxYxR+xij9il0JFJdp47GMUeoN52IiORHvz5Gv+Pzd90xszuAo4CeZrYYuApIALj734ApwMnAfGAz8JXMutVm9j/A9Myhrnb31XkLXJpFn97GScdW/fz97PtxUmknMAiCuuvRe/c0SkuhvFqSq6QkWgeQTDr/d0OaxUudigoA56HHQnYdBt+4IF7oHostVr0JLjPbHbgra9EuwJXufl1zBSUiIiJN6hJgLtC50IGIiIiIiFRyd9zrrxgUEck3dz+vnvUOfKeWdTcDNzdHXNKyxBs44tn++xl3PwjJCqiccssM2pXB6MwQz8++FLJ4iVORrLrvBwvgf3+b4tc/j2se2hzqTXC5+zxgFGxrAb4EuL95wxIREZGmYGYDgVOAXwGXFTgcERERkR2STDkeoiEqW4nNm53/3JdmxhtOOoTdhhtf+lyMvr31/xURkdYnkTB+8r04t96Z5t33owzXnrsZ558bIxGPrn2vvh7WSG5V2rIlWn/kIeo9X11jhyg8FvjA3Rc2RzAiIiLS5K4DLgc61baBmU0EJgIMHjw4P1GJiIiINMCGjc6td6R5+x3HgaGDjAs+H6N/XyVCipW787s/p1i8DNLpaNl7853/94cUv/pZnI4d9L8VEZHWp0d347Jvx0mlogRXPF71epdIGOA5902m4ONFude1dUEjtz8XuCPXCjObaGYzzGzGypUrdz4yERER2Slmdiqwwt1fr2s7d5/k7mPcfUyvXr3yFJ2I1MXMbjazFWY2u5b1R5nZOjN7M/O6Mt8xiog0tzB0rv1jirffiXr5hCF8uNC55roUGzepkqdYzV/gfLJie3ILwB2SSXjx1bBwgTURMxtkZlPN7B0zm2Nml+TYxszsj2Y238xmmdn+hYhVRETyLx63GsktgKMODUjU0h0pkYAB/dQAJJcGJ7jMrAQ4Hbgn13pVjomIiLQ4hwKnm9lHwJ3AMWb278KGJCINdAswvp5tnnf3UZnX1XmISUQkr+bNd9auhXS1nEcqBS+9VvyJkLZq+YrcyyuSsHhpq0hcpoDvu/tewEHAd8xsr2rbnASMyLwmAn/Nb4giItLSHDjaGDcmdxKrtAQOOjB3KieVclavcZKpVnENbbTGDFF4EjDT3Zc3VzAiIiLSdNz9CuAKiHp7AD9w9y8WMiYRaRh3f87MhhY6DhGRQlr5adRrq7qKJCz7pG1W4rQG/fvlHoCppASGDCz+1unuvgxYlvl+g5nNBQYA72RtNgG4zd0deMXMuppZv8y+IiLSBpkZF5wX54hDQv5zb5qPF0f3QXvuZnzxczHat6t6jXR3Hnki5NGnQtzBDI4/OmDCSQFmxX89bajGJLjOo5bhCUVEREREJO8ONrO3gKVECew5uTbSPHsiUqwGDgBy1M+UlMDQIW2n4qa1GTbYGDTAWLjISaWiZYFF/9dDxjV2Jo2WLdNYZTTwarVVA4BFWe8XZ5ZVSXDpGi4i0vbsMiTgZ98PCMOoOUgQ5L7neeb5kClPhVRUbF/2xNSQslIYf2wsH6G2CA26czCzDsDxwH+bNxwRERFpDu4+zd1PLXQcItJkZgJD3H0/4E/AA7VtqKHERaRYDRtsDB1kVeajCAJo3w4OOqB1JULaEjPje9+KcfhBRlkpxOOw797Gzy6L12idXszMrCNwH3Cpu6/fkWPoGi4i0nYFgdWa3AKY8mTV5BZARQU89nTbGsa5QT243H0T0KOZYxERERERkQbIrihz9ylm9hcz6+nunxYyLhGRpmRmXPrNGA8+mubF15x0CkbtY5x1eozS0taTCGmLykqNL5wd5wtnFzqS5mFmCaLk1u3unqux+BJgUNb7gZllIiIiDbJhY+7lGzfBKzPSLFzk9OlljBsT0K6s9d43NWaIQhFppcwsBswAlqiHh4hI67M2Vc6fVr7N5LUf0Svejkt678OJXTTMTTEzs77Acnd3MxtLNDLDqgKHJcLbW1bxm0/e4J2taxjbvjeX9x3NsNLOhQ5LilhJiXH2hDhnTyh0JCINY9HEJzcBc93997VsNhm4yMzuBMYB6zT/loiINEb/vrB4ac3lsQD+dVdIeQWUJJz/Phxy+cUxBvZvnb3fleASEYBLgLmAah9ERFqZ9ekK9p97D8uSm9nqaQCe3biUX/Qbww/7ji5wdFIbM7sDOAroaWaLgauABIC7/w04C/iWmaWALcC5mYnqRQpm6oYlnDp/ClvDNCHOrM2ruH31+7y8x2fYu133QocnIpIvhwJfAt42szczy34CDIZt1/EpwMnAfGAz8JX8hykiIsXsnDNi/OkfaSqS25cFAThQnhm6sCIZvX75mzTnnOkcd2Trm5tLCS6RNs7MBgKnAL8CLitwOCIi0sT+tnIOn2QltwA2hymuXDqdib32okustIDRSW3c/bx61t8A3JCncEQa5FsLn2NzmNr2PoWzMUzy/cUv8dgIDRJQycxuBk4FVrj7yBzrjwIeBBZkFv3X3a/OW4AislPc/QWgzrGgMo1SvpOfiEREpDXac/eA730bHngkZNlyp29v4+MlztatNbd1h/seCunU0RjXyuYxVYJLRK4DLgc61baBmU0EJgIMHqwhrUREislD6z5iS1Zyq1KJxZixaSXHdh5YgKhEpLXZlE4yv3xdjeUOvLBRo25VcwtRgvq2OrZ5XkOHi4iIiEhdRuwS8MPvbk9Yfe+nSXLktwBIJuGhx9OtLsHVun4bEWkUM6tsOfp6Xdu5+yR3H+PuY3r16pWn6EREpD5hWP+IdP0THXI2IU4T0iverumDEpEawtBp7SNIlgYxSiz342VX9RStwt2fA1YXOg4RERERaV0OGWvE6+jStHYtrFvvrF7Tep5P1INLpG07FDjdzE4GyoDOZvZvd/9igeMSEZE6vP5mmnseDPl0NXTqCKecGHDs4bkrli/pvS8Pr1tYZdiwGMawks7sozlxRJrV3PdC7rgvzdJPoF0ZHHdkwGnjA4KgzpGrilLcAs7vsQe3rHq3ypCo7YM43+uzbwEjK1oHm9lbwFLgB+4+J9dGGmmh9auocNZtgK5dIBFvfecOERERaTqnj4/x/gcpPlyYe70DP/plCjPo1hUmfjnG0MHF3QequKMXkZ3i7le4+0B3HwqcCzyj5JaISMv21uyQG/8dJbcANmyE/z4U8sTUMOf2h3Tsy3UDD6VDEKdzkKC9xdmnXXceG3EKZqooE2kuH30c8qdJUXILYMtWePyZkDv/W3PI0NbiD4MO4dQuQyizGF2CEsosxgU9dud7vfcrdGjFZiYwxN33A/4EPFDbhhppofUKQ+eeB1Nc+pMUV12T4tIrUjzyRLrVtLYWERGRpldaalzxvTinnGDEcmR+KioglYqGK1yxEn57Q5oNG4v73kI9uERERESKyP2PpEkmqy6rqICHn8id4AL4eq+9+GKP3Xhz86d0j5eye1m3Zo5SRB56LKSiellNwvMvO2ee6rQra30J5rIgzj27nsiSio18VLGB3cu60lNDoTaau6/P+n6Kmf3FzHq6+6eFjEvy66HHQ6Y+71XOI488GdKxAxx5aKxwgYmIiEiLZmaceUqc4cNCHnw0ZNVqp2sXWL6CGs8n6RBeei3kxGOK995CCS4RAcDdpwHTChyGiIjUY+Wq3MsrKurer10Q5+COfZs+IBHJaeknuVtCxmKweg0M6JfngPJoQElHBpR0LHQYRcvM+gLL3d3NbCzRyCu1nP2lNXJ3npyaI0leESW5lOASERGR+uyzV8A+e0XduKY+n+buB2o2ik0mYdVq9eASERERkTzp2wsWLq65vKw0/7GISO0GDTA+Xe1UH00sHUIPdaJs08zsDuAooKeZLQauAhIA7v434CzgW2aWArYA57rGpWtTUmkor6XhyoYN+Y1FRKStMrPxwPVADLjR3a+ptv4PwNGZt+2B3u7eNbMuDbydWfexu5+el6BFajF0sJFrhoLSUhi+S3HPYqUEl4iIiEgR+cxpMW64seowhSUlMOHkgD9eU/t+IpJfp54YY/bcVJUeGCUJOPpwo6wVDk8oDefu59Wz/gbghjyFIy1QIm706Ma2+TazDeyv84eISHMzsxjwZ+B4YDEw3cwmu/s7ldu4+/eytv8uMDrrEFvcfVSewhWp17AhAbsND5k337fVJcTjUcO7/fct7nuL4k7PiYiIiLQxe+8R8O2vxujXB4IAuneDz3824JjDNVyRSEsyeKBx2XdiDB1sBAF07gSnnxzw2dNUVkWkfud+NkZJouqykgR87gxV44iI5MFYYL67f+juFcCdwIQ6tj8PuCMvkYnsoIu+HmPCSQF9ekGP7nDC0cYV34sTjxd3gks9uERERESKTPZY2iLScg0fFvCz76usikjjjRoZcMk34cFHQ5avcAb2N844OWDYEJ1TRETyYACwKOv9YmBcrg3NbAgwDHgma3GZmc0AUsA17v5ALftOBCYCDB48eOejFqlDPGaMPzbG+GNbV4M7JbhERERERERERFqY3YcHXP5dJbRERFq4c4F73T2dtWyIuy8xs12AZ8zsbXf/oPqO7j4JmAQwZswYzbcpBbV1q3Pfw2leneGEIYze1zh7QozOnVp2Dy/dKYmIiIiIiIiIiIiIRJYAg7LeD8wsy+Vcqg1P6O5LMl8/BKZRdX4ukRYnDJ3f/CnF8y87m7fA1nJ47XXnV79PkUy27NyrenCJiIiItCBz3wuZ+nzIpi1wwH7GYeMCSkpadospkeaUSjkvT3defT2ktBSOPCRgn70MM5ULEREREWkW04ERZjaMKLF1LvD56huZ2R5AN+DlrGXdgM3uXm5mPYFDgd/kJWqRHTTvfWf5Skilti9Lh7Bx7VZenzyHg84cG00C3gIpwSUiIiLSQjz6ZJqHngipqIjeL/jIef7lkJ98L04i0cDK/FVAGugBtK6htaUNSqed3/05zcLFvq1czH0vzdGHGWdP0KNMDQ6sAZJAT3QOEBEREdkB7p4ys4uAx4nuqG529zlmdjUww90nZzY9F7jT3bO7uOwJ/N3MQqLR065x93fyGb9IYy1e5qTTNZeXh2V8/N4qDnr9djjwS/kPrAH0VCgiIiLSAmzY6Ex+LCSZ1WKqIgnLV8IrM5zDD64nwbU68/V+wIgepY4FNFexFLE333Y+zkpuAVRUwDPPOccc7vTorl5c26wDHgU2Ep0DAI4EhhcsIhEREZGi5e5TgCnVll1Z7f0vcuz3ErBPswYn0sR69zTisao9uABKg630LVkC770Eo86GRFlhAqxDg/qVmVlXM7vXzN41s7lmdnBzByYiIiLSlnywwInlaHpUUQFvzArr3jkNVLYhTBH13igHngA2NGWUIvk1a05IeUXN5UEM3p3fsseCzysHHiJKclWeA5JEMz6srn03ERERERGRkXsanTpCwPYMl5EmEVQwtvsrYDHYsqaAEdauoQMnXg885u57APsBc5svJBEREZG2p317okrqasygc6d6dl5ElOSqLgTe3enQRAqmY8fcQ70b0KF93sNpuT4hSmpXP4ekgTn5D0dERERERIpHLGb8+NI4I/t8TECagDS7dXyPn+zxP5TFysFDaN+90GHmVO8QhWbWBTgCuADA3SuAHO0opalt2uwsWOh0aA9DB2sibRHJvzB0FnzsbNkCuw4z2pXpPCTSXIYPM9q1g63lVZcn4nDUYfW0SdpCzuQYIbC5iQIUKYDDD47xzPMpwmqdGGNxGLmHrknbbKlluQOb8hmIiIiItFRh6Hy40Ckvj57vy0p1LyUi23XpbFz8jRJSUy6CdAXxINOKNl4Ke54UfW2BGjIH1zBgJfBPM9sPeB24xN2rPCqZ2URgIsDgwZrsYWc99kyaBx8JicchDKFLZ/jet+P06qGLj4jkxyfLnT/8NcXGzRAYpNLwuTMCjj5MM9aLNIcgML7/7Th/+FuKjZuicpdOw7mfDRg6uJ4EVz9yJ7jiwMBmCFaanZndDJwKrHD3kTnWG9EoCycTpTEvcPeZ+Y2y+fXtbXz1CwG33BESGLhDaSlc8o048bjui7fpQ5TQri6O5uETERERlix1rvtbii1boxEi0mn4/FkBhx2k53sRydJjGPETL4cZ/4bVC6G0E4w8DfY4odCR1aohCa44sD/wXXd/1cyuB34M/Dx7I3efBEwCGDNmjAbE3wlz3wuZ/Gg0yXzlRPMrV8H1f0vxPz+JqyeXiDS7MHR+95cUa9ZWXX7PAyFDBhq7DG3oCLci0hh9+xjXXBnno4+drVth2NAGtqzsCuxWbVkM6A4MbeooJU9uAW4Abqtl/UnAiMxrHPDXzNdW58DRMfbbO+DDhU4iAcMGG0Gg++EqOgD7Am/DtmHzY0Anap4bRESkWTWgkcpRwIPAgsyi/7r71XkLUNqcdDp6vl9fbW7e/9wbMmRQwKABuq8SkSy9d4OTi+ey1JAaysXAYnd/NfP+XqKElzSTp58Nqag2CKQ7rFkLi5cWJCQRaWM+WBANS1hdMgVTX8jVRFxEmoqZMWxIwJ67B40bNuSIzNf+QG/gIOB0okpuKTru/hywuo5NJgC3eeQVoKuZ9ctPdPlXUmLsMSJg16GBklu1GQscCwwAegFjgM/QsCaNIiLSlG4BxtezzfPuPirzKp5aRClK8+Z7jXpGgFQKnn0x10S+IiLFo97HHXf/xMwWmdnu7j6P6LHpneYPre3aWMs4+UEQzcsVTastItJ8Nm8h56nGHTZszHs4ItIQlWX29IJGIfkzAFiU9X5xZtmy6htqKPE2wogGlx9W6EBERNo2d3/OzIYWOg6RSptrmZM31PO9iLQCDR1j6rvA7WY2CxgF/LrZIhJG72skEjWXp8NoSBYRkea26zAjlaq5vKQE9t9PwxOKiBQTd5/k7mPcfUyvXr0KHY6IiIjAwWb2lpk9amZ717aRmU00sxlmNmPlypX5jE9akRG7GukcHbVKS2D0vnq+F5Hi1qCzmLu/mXko3tfdz3D3Nc0dWFt25KEBPbpDSSbJZRZ9f84ZAaWNGapIRGQHdexgnHlKQEnJ9mUlJdC3Nxw8RuchEZEWYAkwKOv9wMwyERERadlmAkPcfT/gT8ADtW2oRirSFLp0Nk45oebzff9+xphRer4XkeKmEdlboLJS4+ffj/P8KyFvzXY6d4JjjojmHBBpamZWBjwHlBKdE+5196sKG5W0BCceE2PYYGPqCyGbNsMB+xkHHxiQSOgGWESkBZgMXGRmdwLjgHXuXmN4QhEREWlZ3H191vdTzOwvZtbT3T8tZFzSup16YoxdhxnTXgzZsgUOHB1w0IFGPK7nexEpbkpwtVClpcZxR8Y47shCRyJtQDlwjLtvNLME8IKZPZqZsF7auN2GB+w2XMl1kUJwdxYsdOYvcLp0NkbvY5SU6AG0rTCzO4CjgJ5mthi4CkgAuPvfgCnAycB8YDPwlcJE2jKl087bc50VK50B/Yw9dzOCQOVHREQKz8z6Asvd3c1sLNHoSqsKHJa0AXvuFrDnbnq+F5HWRQkukTbO3R2onFY0kXl54SISEZF02vnLTWnmvu+EaYjF4T/3wuXfjTOgvyrp2wJ3P6+e9Q58J0/hFJV1651rrkuxYSMkUxCPQ68ecPnFcdq3U/kREZHm1YBGKmcB3zKzFLAFODdzXRcREZFGUoJLRDCzGPA6MBz4s7u/Wm39RGAiwODBg/MfoIhIG/PcSyFz33MqktH7VDrqbvvnm1P86qdxzFRJL1Kbf92dZtUaCMPofToNy5bDvZPTfPkcPf6IiEjzakAjlRuAG/IUjoiISKumJ7w2aNVq5+En0rw33+nWzTj5uIC9dlcX5bbM3dPAKDPrCtxvZiPdfXbW+knAJIAxY8aoZZnstDB0nn855NmXQpIpGHdAwPFHBZRq+DURAJ57OdyW3Mq2di2sWAl9euc9JJGiEIbOrDm+LblVKZ2G12Y6Xz6nMHGJiIiISGTtOufRp9LMnut07mSceEzAqH1ULykiO0YJrjZm5Srn6v9LUV4etWpdvtL5cEGaz5/lHHZQrNDhSYG5+1ozmwqMB2bXt73Ijvr7rWnefsepqIjeP/JEyMy3Qn5yWZx4TEmupmJmg4DbgD5EQ49OcvfrCxuVNET1yvltDNK1rRMR6hrgyVV2RERERApq3Xrnl79JsXlL1ABp+Upn4eI0p493xh+rekkRaTylx9uYhx5Ls3Vr1YqziiTc9UBIKq2OOW2RmfXK9NzCzNoBxwPvFjQoadUWLXHenrM9uQWQTMLylfDmLJ2HmlgK+L677wUcBHzHzPYqcEzSAIeMDUgkai7v0B769cl/PCLFIhYzdh9hVB/FMxbA6H3VgEJaDjO72cxWmFnORmUW+aOZzTezWWa2f75jFBERaWpPTE2zJZPcqlRRAZMfDdlarvoAEWk8JbjamHnzPWfL1jANn67KfzzSIvQDpprZLGA68KS7P1zgmKQV+2BBSK7b1vJymDdfzeubkrsvc/eZme83AHOBAYWNShrimMMDBg8wSkuj94kElJbCNy+Iaf4tkXqcf06MTh2gtCR6X1oKXbrA2RPUKlhalFuIRk2ozUnAiMxrIvDXPMQkIiLSrN6Z56TSNZfHYrBkqRJcItJ4GqKwjenS2Vi1uuYFIx1Cxw4FCEgKzt1nAaMLHYe0HV06G7EAqk8vlIhDt66quG8uZjaUqKy/WuBQpAESCeNHl8SYPdd574OQrl2McQcEdOqoMiJSn549jP93ZZzpbzjLlocMGhBwwCgjEVf5kZbD3Z/LXJtrMwG4zd0deMXMuppZP3dflp8IRUREml73bsaiJTXrJVOpqK5ARKSx1IOrjTn5uICSkqrL4nHYd2+jYwddSESk+e2zl1GSoMbwUUEQDcsmTc/MOgL3AZe6+/oc6yea2Qwzm7Fy5cr8Byg5BYGx794BZ50e57gjY0puiTRCaalx2EEBZ0+Ic9CYQMktKUYDgEVZ7xeToxe2ruEiIlJMTjwmoKTaUOyxGOwy1OjZo2Xdr5nZeDOblxku+Mc51l9gZivN7M3M68Ksdeeb2fuZ1/n5jVykbVFNYhszap+AM08JKC2BstIouTVyT+OrX9CQLSKSH/G4cfnFcfr1yQy7VgJdu8Al34zRtUvLuqFtDcwsQZTcut3d/5trG3ef5O5j3H1Mr1698hugiIiI7DBdw0VEpJjstmvAF84OaFcW1Usm4rDbrsa3vtqy6iXNLAb8mWjI4L2A82qZz/oudx+Ved2Y2bc7cBUwDhgLXGVm3fIUukiboyEKd4K7F+U8GMcfFeOoQwOWr4TOnaBzp+L7HUQkUqznob59jKuvSLDy02j87b69Kcrfo6Wz6I96EzDX3X9f6HhERESkwZYAg7LeD8wsExGRIlCsz+r5cOi4GOMOCPhkRTRdSgtt6DoWmO/uHwKY2Z1Ewwe/04B9TySa3351Zt8niebdvKOZYhVp05TgaqRk0rlncpoXXnGSyagL7RfPjjFoQIs8GdcqkTAG9i90FCKyo96aHXLXA2lWrIROHeHk4wOOOzIouhvoXj2LK94idCjwJeBtM3szs+wn7j6lcCFJpXDdGtKLFxD06kesd79ChyNSKw9D0h/Og1SS2PA9sXii/p1EZGdNBi7KVKiNA9Zp/i0RkZbv5elp/vtwyJq10K0rnHlKwCFjW1bvpJYgHm/x9ZK5hgoel2O7z5rZEcB7wPfcfVEt+9YYZhiioYaBiQCDBw9ugrBF2h4luBrprzenmfuek0xF7z9Y4Fx7fYqrr4jTvZsqakWk+c2dF/L3W9JUJKP3GzbC/Y+EVFTAKSfoxlm2c/cXAF2cWhgPQ7bc/Hsqpk6JxulMJomPPIAO37saK2u308df+mZIrAR67WYEmndIdlJqwXtsuvZH+OaN0eSJZnT47pUkDji00KFJNWHKWfmek66AXrsbiXYq/y2Zmd0BHAX0NLPFREMZJQDc/W/AFOBkYD6wGfhKYSIVEZGGenl6mn/dFW57Vl+zFv59d4gZHHygntVboYeAO9y93My+AdwKHNOYA7j7JGASwJgxY7zpQxRp/ZTgaoTlK5y5729PblVKpuDp59KcPUF/ThFpfvc/sv2GuVJFBTz6VMiJxwbEY6rQEmnJyh+9h4pnH4NkRfQCUrNfZ/NNv6fDd366w8dd8EIagNdujL4GcTjs4hjdd9GUq7JjvKKcTVdfgm/aUGX5pj9cSec/3E7Qq2+BIpPqVn8Y8sIf04SZ5xRPw6gvBAw7TJVpLZW7n1fPege+k6dwRESkCeR8Vk9Gy5XgKjr1DhXs7quy3t4I/CZr36Oq7TutySMUEQBU41HN1q3OnHdDPlgQEoZVE+efrHDiOa5H6TR8vDhPAYpIq+fufLTImT03ZOOmmg14lq/M3agnnYZNm5o7OhHZWeWP3APlW6suTFaQfOkpPJXMvVM91i1x3rw9BCC1NXpVbITnr0uTTqohoOyY5MyX8DBdc0UYUj5NI522FOmk8/x1aSo2bi//6SS8eXvIuiUq/yIiIjtq6SfOrDkha9c17Hq6Zm3u5avXNF1MkjfTgRFmNszMSoBziYYP3sbMsseZPx2Ym/n+ceAEM+tmZt2AEzLLRKQZqMtRlhdeSfOfe0OCGODQrgwu/VacAf2i3hD9+hqpVM394jEYMqjmchGRxlq12vnDX1OsWQtBEPUQPfWEgFNP3J5d79vH+GBBzRvsWDyaoFVEWjbfvDH3itChohx2YH6jBc+nSefIQ3gIy+c4/UepZ6c0nm9cD+mw5opUEl+nmpqWYvlsx3P8m9Jp+OiFNPudo0c+ERGRxti82bl+UppFi51YLHouP+RA44ufixEEtd9Xd+8Gq1bXXN6jWzMGK83C3VNmdhFRYioG3Ozuc8zsamCGu08GLjaz04EUsBq4ILPvajP7H6IkGcDV7p7jkyEiTUFPOxkfL3b+c2+mK3Gm8fTWcvjdn1P89uo4QWD07mnsvYcx592qwxTGE3DMEU3f1XjNWufV10M2bnZG7hGw+3DDTBVUIq3Zn/6RYsXKqJ670pSnQgYPNPbdO+p0e+YpAX/8e7rK0AclJXDK8QGxJh6eMJV23pzlLPg4pHdPY+wBAe3KdB4S2RnxvUeTmvECeNVEddCrL7TbsSx1cjOQo4Ibh4+XOE/PS7FxE4zeN2DMaNNQptIg8b1Gk/ODVdaOxKhcc2xLISS3ArkalodQ0Qw9u9etd557KWThYmfIQOPIQwM6d9I5RUREWo+b/5Nm4cdOKs22OsJXXncG9g/rrP/77KkBt9xRdZjCkgSceWrLGEDL3Xn3fWfOvJCO7Y1xBwR066preG3cfQrRnJjZy67M+v4K4Ipa9r0ZuLlZAxQRoIEJLjP7CNgApIGUu49pzqAK4dkX0zXm1oJoXpt57zt77h6d8L/xlRj3P5zm+Zed8goYsavx+c/G6N7EF4S3Zof8/ZY0oUMqBVOfS7Pn7sa3v1p3axERKV7LlnuN5BZE56Gnnwu3Jbj2GBHw7a/B3Q+k+WQFdO4Ip5wQcNRhTXvTvHmz8/+uS7F6DZRXQEmJc99DIT++NE7/vjoPieyodl/4FhvmzITyckinIIhBIkG7iZfvcEOW/qMCFr9eswvXAofHp4akUlE+bfbcNFOfN3743RjxuMqx1C3WfzAlR5xExfOPbx9Ws7SM2LDdie9/cGGDk21672HkGkkyVgr9RzftvcGy5c6vf58ilYpas8+Z6zw5LeQn34vTt4/OKSIiUvy2bnVmv5NJbmWpqICnnqs7wTX2gGjdfx8JWbUaenSHz5wSbFteSGHo/PmmNO++F9VnxuPO5EdDvvmV2La6BhGRYtSYHlxHu/unzRZJgW3YWKMh9Tabtmz/PhE3PndGnM+d0XyxJJPOP26r2jujvALmznNmvOmM3V8PjyKt0eYtTlDLfWX1ubhG7hkwcs/mvQmd/HialavYNjRrRQVUADf+K8WVP2z8EGoiEon1H0zn3/2L8ofvIvXe2wQDhlJ22rnEBu2yw8fsP8rosWvV+4OwBOaVQqra/cSipc6rM51Dx+p+QurX7us/IL7vgVQ8PRmvKKfk8BMoOepkLCh8RY1E2nUz9jglYN6jIemKaFmsBHrsavTfr2nL+e33pNmSNYVgMgWpNPznvjSXfVuDg0jrtHGTs3Yd9OwBZaW6doq0duUVQC1FfcuW3MuzjT0g1iISWtVNn+nMfc+pyNwrVD7n/+O2NL//lZFQ4zcRKVJ6CskYvW/AnHfT0YUsSzoNu+2a35P8/A8958W0vAJenh4ydn+1rBBpjQYPsJwjDCXisP+++S/302d6znkHlyyLHvQ7dtANsMiOCnr0pt35322y41lgHHZJDL4fJbviZVA+2Eg8HZLaWnXbigqY8UbIoWN1PyH1MzNKDjqKkoOOKnQoUoe9TovRa3djwXNRmR80NmDAAYY14cgP7s68+TXvVNzh3fdraSkoUsRSKee2u9K8NtOJx6IpCccfE3D6SYGmDhBpxTp3gi6da86lFQQwcs/iLfsvTQ+3JbeyOfDBAmePEcX7u4lI29bQmg0HnjCz181sYq4NzGyimc0wsxkrV65sugjz5MDRRv9+RknJ9mUlJXDqifkfU94Cco+jD8RUFyXSaiUSxuc/G1CSgMpn5pIEdO0KRx+e/8Jf13N7bT3NRKRwgsy8WodcFGfshXH67GK19k5v1y6PgckOMbPxZjbPzOab2Y9zrL/AzFaa2ZuZ14WFiFNajl67BYy9MM4hF8UZNDbYdk5oKmZGopbmkbUtFylmdz+QZvobUYOvreWQTEbD/j7/cq5JL0WktTAzLjg3Rkli+3NvIg7t28GZp7S8nlkNVeszvOv5XkSKW0MfRQ5z9yVm1ht40szedffnsjdw90nAJIAxY8YUXRO+eNy4/OIYL093ZrwR0q4dHH1YwB4j8n+WH76LEctxzSwtgcMO0lVHpDU7dFyM/n2Np58LWbce9t3LOPzggLKy/LemOnSs8cRUrzI/oRkMG2K0b6fWXSItxpsfwH0vwsr10fuX5sIhezJ8F6O0NKqUy1ZSAkcdovuJlszMYsCfgeOBxcB0M5vs7u9U2/Qud78o7wFKfrw2Dx54GVZvhB6d4MxDCh0Rh4w1Xni1ag/vRDxaLtKapNLO8684yWTV5RUV8NjTIUccUryV3CJSvz13D/j5D42npkXzXu8+3Dj68IBOHYv3enfEwQHvza85clU8DrsOLd7fS0SkQQkud1+S+brCzO4HxgLP1b1X8UnEjSMONo44uLCVPvGY8Z0LY1z/9zR4NBSCGYw7wNhvpC46Iq3dsCEBF36p8JXPJ58Q4935aRYviSbYTcShrAwu/KIe6EVajFkL4MYnqJKJvmMapNIER4zk0m/G+f1fUtsq6NJpOO2EgN2GF/4cI3UaC8x39w8BzOxOYAJQPcElrdUr78LtU6EiU7Y/XQ+3PlXYmICzJ8RYtjzNgoXRvKFhCLsMNc6aoHsDaV0qyqPPdy7rN+Y3Fik+ZnYzcCqwwt1H5lhvwPXAycBm4AJ3n5nfKKU+/foYXzqn9XRRHrWPceD+xquvO+4Qi0Wzo3znwhixJu71LSKST/Weqc2sAxC4+4bM9ycAVzd7ZG3cbrsG/PZqY+YsZ/NmZ6/dAwb00wVHRPKntMT48SUx3vvAWbjI6dnd2HekEdfNr0jLcf9LVZNbEFWIT34FDt+bQQOM314dZ958Z/OWqPVpMbc8bUMGAIuy3i8GxuXY7rNmdgTwHvA9d1+UYxsyQ4xPBBg8eHAThyrN4oGXtye3KlV/XwClpcYPvxtn0RLnkxVOvz7GwP46p0jr065dNAfP6jU116mngzTALcANwG21rD8JGJF5jQP+Su7rvEiTMTMuOC/O8Uc677wX0qG9sf++VpDRYkREmlJDmiL0Ae7PTKIaB/7j7o81a1QCQLsy41AN9yEiBWRm7D7c2H14oSMRkZxWrsu9fONWSKahJE4sZuy1u+4nWqGHgDvcvdzMvgHcChyTa8NiH0q8zXGHNS27i8igAcagATqvSOtlZnz+rBiTbklTkaxcFs2Pe9bpba/H4patzrMvhrz5ttO5Exx3pHqD18XdnzOzoXVsMgG4zd0deMXMuppZP3dflp8IpS0b0N8Y0L/tncdEpPWqN8GVGRplvzzEIiIiIiKN0aMzfJKjeXmHUkjowbWILQEGZb0fmFm2jbuvynp7I/CbPMQl+WAGXTvA2k2FjkSkTRs1MuCy78Ajj4cs/9QZOtg47cQY/fq0reTulq3O1f+XYu06tg15PHtumrMmOMccrnuNHZSrp/YAQAkuERGRRlKTG5E2zswGmdlUM3vHzOaY2SWFjklERBrozIOjCfKylcThtHFRJbkUq+nACDMbZmYlwLnA5OwNzKxf1tvTgbl5jE+a2+kHRWU5W/X3ItLshg8LuOSbcX79swQTvxxvc8ktgGkvhFWSWwAVSbj3wZCt5eoU3NzMbKKZzTCzGStXrix0OCIiIi2OElwikgK+7+57AQcB3zGzvQock4iINMSoXeGC46BHp+3Lzj4cjtyncDHJTnP3FHAR8DhR4upud59jZleb2emZzS7ONEx5C7gYuKAw0UqzOHQvOO+oqCcXQPeO8IWjCxqSiLRNb84OqyS3KsVi8NHHSnDtoHp7aldy90nuPsbdx/Tq1SsvwYmIiBQTNQMUaeMy43wvy3y/wczmEg2P8E5BAxMRkYYZMyJ6ucOki+GIkYWOSJqAu08BplRbdmXW91cAV+Q7LsmjQ/aMXu7qkSnSAmze4jz/csi8953eveHow2L06dX6y2bnjgbUTGSlQ+jYofX//s1kMnCRmd0JjAPWaf4tERGRHaMEl4hsk5kIdzTwarXlE4GJAIMHD85/YCIiUj9VgIu0TirbIgW3br3zP79NsXlzNDxf7F147qUU3/16jD13a90D4xx7ZMCceWkqKrYvCwx6docB/Wrfry0zszuAo4CeZrYYuApIALj734gasJwMzAc2A18pTKQiIiLFTwkuEQHAzDoC9wGXuvv67HXuPgmYBDBmzBiNQyEiIiIiIm3GQ4+l2bAR0unofTqEdAX88z9prr3KsFaciN5jRMBnTnXueygkHot+957d4dJvxlv1770z3P28etY78J08hSMiItKqKcElIphZgii5dbu7/7fQ8YiIiIiIiLQUb832bcmtbBs2wpq10L1b3kPKq+OOjHHYuICPFjkd2hsD+6PkloiIiLQISnCJtHEWPZncBMx1998XOh4REREREZGWpLQ093IPoaQkv7EUSlmZsccIJbVERESkZWndg0WLSEMcCnwJOMbM3sy8Ti50UCIiIiIiIi3BMUcENRJZsQBGDDc6dlDSR0RERKRQ1INLpI1z9xcAPZWJiBQp9xBo3fN/iLRW0TQsGupLpKU76tCAhYuc1153YvGo51avnvD1L8UKHZqIiDQTMxsPXA/EgBvd/Zpq6y8DLgRSwErgq+6+MLMuDbyd2fRjdz89b4GLtDFKcImIiIgUofXJT5iz/hHWphYTEGdAu/0KHZKINNDG1KfMWf8wq5MfExDQt2wke3UaTyIoK3RokicNqDS7APg/YElm0Q3ufmNeg5RtgsD4yufjnD7e+WiR06MbDBmkxiUiIq2VmcWAPwPHA4uB6WY22d3fydrsDWCMu282s28BvwHOyazb4u6j8hmzSFulBJeIiIhIkdmSXscra/5J2isACEmxZMtbBY5KRBqiItzMy6tvIuVbAQhJs2zrbDalVnJw9wtVYd4GNLDSDOAud78o7wFKrXp0N3p0VxkVEWkDxgLz3f1DADO7E5gAbLtWu/vUrO1fAb6Y1whFBNAcXCIiIiJFZ+Hm1wg9XWVZSAqIeoaISMu1aPNMQk9VWeak2ZhaybrU0gJFJXm2rdLM3SuAykozERERaRkGAIuy3i/OLKvN14BHs96XmdkMM3vFzM6obSczm5jZbsbKlSt3KmCRtkoJLhEREZEisz61HCedc92m1Ko8RyMijbEhtXxbQroKMzYpQd1WNLTS7LNmNsvM7jWzQbkOpIoxERGRwjKzLwJjiIYWrjTE3ccAnweuM7Ndc+3r7pPcfYy7j+nVq1ceohVpfZTgEhERESkyXeL9Ccg9sX3HuB6MRFqyLol+BCRqrnCnY7x3/gOSluohYKi77ws8CdyaayNVjImIiDSLJUB245KBbJ8XcxszOw74KXC6u5dXLnf3JZmvHwLTgNHNGaxIW6YEl4iIiEiRGdL+QAKrOpVqkJlatUO8e43t3dP4upn48in4+rdx97zEKSI1DWw3mpglgO3z+ATE6JLoT5dEv8IF1gR86xJ8xaP4qufw9JZCh9OS1Vtp5u6rsirKbgQOyFNsIiIiAtOBEWY2zMxKgHOBydkbmNlo4O9Eya0VWcu7mVlp5vuewKFkzd0lIk0rXv8mIiIiItKSlMU6cXD3C5m74TFWVXxE3BIMbLd/zm09uQ7e/Skk14CnwWJQ1h/f/Wos1i7PkYtIImjHIT0uZO76x/i04gMCizOgbD9273RcoUPbYe4OH98Enz4dLbAAFk7CR/wM67RHYYNrmbZVmhElts4lGsJoGzPr5+7LMm9PB+bmN8TC8nQ5rH8TwgrovC+W6FLokEREpA1x95SZXQQ8DsSAm919jpldDcxw98lEQxJ2BO4xM4CP3f10YE/g72YWEnUuucbdleASaSZKcImIiIgUoY7xnhzY7Yv1b7jwb1C+Airn7PIkbFkEi2+HIRc2a4wiklv7WDcO6HZeocNoOutmwqpnwCui95WdROf/P3y/m7BAj53ZGlhpdrGZnQ6kgNXABQULOM98/WyYf03lO/A0PvBLWJ9TChqXiIi0Le4+BZhSbdmVWd/nbJ3k7i8B+zRvdCJSqcFPGmYWA2YAS9z91OYLqWUpr3AeeCTNS685qRSM3Ms454wY3btZ/TuLiDSRt2aH3PdQmpWfQo/ucOapMQ7YT6PMikjd3NOw9nW2Jbe2rUjC6ueU4BKRpvHpMxCW11zuadg4Fzqrjqe6BlSaXQFcke+4Cs3T5VFyK6w2xOWSf+Od9sbaDy1IXCIi2dydaS+EPPpUyIZNMHigcc4ZAbsM1TO6iEi+NebMewltbFgEgOv/lmbqC86mzVBeATPfcv73dym2bNXcFSKSH2/ODvn7LWmWfgLJFHyyAm76V5pXX0/Xv7OItG0esr0rRfV1OoeISBPxZB3rdK6RRlg/M/fyMAWfTs1vLM1o9tyQG/6R4v/+lGLqC2mSSdUviBSTyY+G3DM5ZPVaSCbhgwXOb29I8/FilWURkXxrUILLzAYCpxBNbttmfPRxyEeLop5bldxh61Z46bWwcIGJSJtyz4NpKqrVG1Uk4b6HdB4SkbpZkICOewLVe57HoOvYQoQkIq1RjyMhKM2xwqHTnnkPR4pYWE7uhhlhzV5dReqBKWn+cnOaN2c78+Y79zwYcu0f06RSqhgXKQblFc7jz4RUVFRdnkzB5MfUqENEJN8a2oPrOuByoE3Vpi5eWrM6CKKK5QULdfMpIvmx8tPcy1evgTDUuUhE6jH0WxDvuL3yOSiDRFcY9OWChiUirUi3g6DTPtH5BcDiYCUw9LtYzsSXSC0675e7119QBt0Ozn88TWztOuexp6tWjFdUwLJPnBlv6r5epBisWQOWozbVHfXgEhEpgHoTXGZ2KrDC3V+vZ7uJZjbDzGasXLmyyQIspD69ci9PJGBgf83BJSL50a1L7uWdO0EQ6FwkdTOz8WY2z8zmm9mPCx2PNK2VnzpvzApZsrT2h2kr6wf7/AUGXQC9T4HBF8I+f8IS3fIXqDRafWXXzErN7K7M+lfNbGgBwpQdtGp1VHZbS0WYWQyG/xiGXw59ToN+Z8HI67HuBxU6NCkylugGA86DoIRt1RVBWZT46rxfQWNrCu994MRjNZeXV8Cbb7ep9sQiRatrFwhrKa79euv5XEQk3+IN2OZQ4HQzOxkoAzqb2b/d/YvZG7n7JGASwJgxY1rFk9rwXYxePWHZckhnNSJLxOHQcZo4UkTyY8LJAf++O6wyTGFJCZw2XuchqZuZxYA/A8cDi4HpZjbZ3d8pbGRSl9CdKevT3L0miRmc0zXB+M4xAtv+wJxKOzfeluatOVFFWToNQwbV/kBtsfbQ64R8hC9NoIFl92vAGncfbmbnAtcC5+Q/2vwL3Xl4fYp71qQIDM7tlmB8pxhmLb9SKQydW+9I89pMJxaPKsj69zEu/VaMjh1afvx1MbNWk4SQwrK+E/BOI6M5t8LyqIdgl9FYri4TRaZD+9zLzaBTp/zGIiI7pqzMOOwg48VXvOozegJO1TO6iEje1ZvgcvcrgCsAzOwo4AfVk1utlZlx/rkx7nkwzQcfRQ+guw41vnxujE4di/sBVESKx/77Bixe6rz4qrN5S/RgfPpJAUcdqptnqddYYL67fwhgZncCEwAluFood+c7i7fy5Po0mzPNhV7cmGZ85xg3DGq3bbspT4bMmuMkk9HE1gALPm4V7Ysk0pCyOwH4Reb7e4EbzMzcvVV/ENydbyzaytSNaTZnWk+/uCnNqZ3jXDewrLDBNcAzz4VMf8NJpqK5OgAWLXVu/neai7/RkLaHIm2DddgVOuxa6DCa3B4jjJIS2FpedXkiDkcekqNrl4i0OBs3OaNGGuk0vPq6U1EBPXvAeZ+JMWIXPaOLiOSbnqJqsWmz86d/pFm4KGoZbcBxR8LnziiO1qEi0jo8OS3Nfx8OiccglYa+veHSb8bo0V03ztIgA4BFWe8XA+Oqb2RmE4GJWe+bPzJplD9nXg2h/1+r0JCyu20bd0+Z2TqgB1Bj5sa2UMavz7yK2SXfbNh2rfH/J9JSrVvvLF7qdOtq9O+782UvFjO+/5041/8txaYtEFjUkPaLnws0DYJIC+fuPDgl5PFnQuLxaASF/v3g21+N0b2bns9FRAqlUQkud58GTGuWSFqYG/+VZsFCJ53e3jL62Zdg0ADnkLG68RSR5vfu+yH3PxxW6aGxfAX8cVKaX/zIVMElTab6MMMzZswocERt13UrKvjtigqqD+sfAy7vU8J3e5UAcNHlyRqtvwFu+mMJW8tDSkt0fmgOxXrebU1l/LfLy/nDyiTVu6klgB/1KeHbmTLSUl32syTrN9RcHo/DtVfF6dK57s+YmdHKO+kVVLGWcWl67s6d/03z7EtOIh41NBs8wLj4GzE6tN+5z8mAfsa1v4jz0cdOeQUMG2K6brdCZjaeqO1FDLjR3a+ptv4C4P+AJZlFN7j7jXkNUhplxpvOE9PCqr2wl8DNt4f84CIluERECkVn4Bw2bnLmzvMq824BVFTAE1PTuXcSKVJmdrOZrTCz2YWORap66tmq824BhA4rV8HSZYWJSYrOEmBQ1vuBbH+Ilhaocwxy1XGVGHSJbV+x1+5GbfWwM95w/nl7ioceT7N2nSrCi1RDyu62bcwsDnQBVuUlugLqErOcZSRRrYy0VPvuZQQ5nsC6doHOTTj/jrszd17Iv+5K8Z/7Uny0SOcCkcZ44ZWQ519xUinYsjVqbPbRIuemfzVNfYCZMWxIwB4jAiW3WqGsuTRPAvYCzjOzvXJsepe7j8q8lNxq4Z6YGlJRUXVZOg3zF7juuUVECkgJrhy2biXngyfAps35jUUkD24Bxhc6CKlp/YbcN8mxIBpGVaQBpgMjzGyYmZUA5wKTCxyT1GFClwS5qrkMOLXz9o73Z58Ro327aM4OgHgMSjMdV/5zb5oXX3MeeSLkp/+bYv6C6v3BpAg0pOxOBs7PfH8W8Exrn38L4Iyu8VofYE7t0vJHXz/jlBgdO0AiEb2PBVBSAhec13TDoLs7N9+e5oYbo94nU593fnN9iilPqqGeSEM99Wzuiux35rnuw6Uhts2l6e4VQOVcmlLENm2q5fk8Bpu35DkYERHZRgmuHLp3g7Icc1QHAQzsB4uX6oZWWg93fw5YXeg4pKZRI4NtFWDZUinYWu5UVOhcJHVz9xRwEfA4MBe4293nFDYqqUuPuHHT4DI6BdApgI4BdA7gn0PK6B7fXvndq4fxvz+Nc/LxAXvvYRxzhDHugGhdeaZCLpWKvr/xtrSGNCsytZVdM7vazE7PbHYT0MPM5gOXAT8uTLT51SsecGO1MtIlgNuGlBVFD66uXYyrr4hz2olR2T36cOOqy+PsMaLpHsve/8CZ+ZZvOxe4Q0USJj8WsnqNzgUiDVFbw1YLogaxIvXINZfmgBzbfdbMZpnZvWY2KMd6zGyimc0wsxkrV65sjlilgfbZy4jFai6Px6BLJ2fueyEfL3bdd4uI5FnLb+ZYAEFgfPncGJNuSZNMRQ+FlZO/vv8h/PoPKXr3hEu/Gadrl5b/IC0ixenowwOefyVk7brtc3BBNEzhP24LCcOQL34u4OADc9xli2S4+xRgSqHjkIY7qlOct/fowGub0xhwYPsYJUHN+41OHY3Txm8v/z/6ZbLGNgDrNsDqNdCje3NFLM0hV9l19yuzvt8KnJ3vuFqCozvFmbVHB6ZvThMAB3aIkSiiuZM6djBOPj7Gycc3z/Fnzgq3JbeyBQaz5zpHHFI8fyuRQtlnT+PF15ywWifoDu2hW9eChCStz0PAHe5ebmbfAG4Fjqm+UfV5NPMbomQ7+fgY099IsXlL1JDMLBpNYfS+8MOr0sRiUb1h165RfWGvHrreiojkg3pw1WLUyIAfXxpn3AFGvz5QOV7Q1vJoLq6ln8AfJ6UKGqNIvqjVWGG0KzOu/GGcCScF7DosmoAeouFRtmyNemb8665QvUpFWqGSwDisY5xDO8ZzJrdySdTSbMl9+/lDpLUozZSRQzrGiyq5lQ8lJbmHW7eAnD3DRaSm00+K0aH99mtrYFCSgPPPjRE08LosbVq9c2m6+yp3L8+8vRE4IE+xyQ7q0jnqhX3ycdHz+dj9jfPOCnjt9aindOUz+oqV8Ie/ptSTS0QkT5TgqsPggcaFX4rTvZvVaLkVhrBsOSxfoQuWtH7uPsndx7j7mF69ehU6nDalXZkx/tgYZ5wUI56jo1YyBdNe1JwaIgJHHVrzti6w6H6mS2dVxom0FQeNieUcQskd9hupc4FIQ3TrGlVkjz8uYLddjUPGGj+5LM4+e6kKRRqk3rk0zaxf1tvTiYYklhauYwfj9JNiXHFpgq9/Oc7ceU5FtUEU3GHdOli4uDAxioi0NWrP2wAbNtY+kWQ0waweFEWkedU2D4A7bNiQ31hEpGU6+vCo0i2RiBJbZtChA3zjfA1jKtKW9O9rfO6MgLvuD4nFoieV0OFbX4nRvp2eW0QaqlNHY8JJMTip0JFIsXH3lJlVzqUZA26unEsTmOHuk4GLM/NqpojmxL6gYAHLDlu3PvfyIIBNm1RfKCKSD0pwNcCokQFLPwlJVRuR0EMY2F8XKyluZnYHcBTQ08wWA1e5+02FjUqqG7GrkcrRUaukBPYbqZakIm2OO7w/FWY9AFvWQpf+xMZ8AYCfXRZnwcdOt66w526moZREWpJ1S+G122D5XIiXwIijYdTZEGvasQOPPizGmFEBs+c68Xg0n1BZmc4FIiL50oC5NK8Arsh3XNK0Ru9jLFhYsxdXKg3Dhui6K03DPYT1s6JXvDP0OAIr0QTLIpWU4GqAY48MePG1kPUbIJm5aJUk4LzPBpSU6IIlxc3dzyt0DFK/Lp2N8ccGPDE1pCIzcXxJAvr1gQP313lIpM1551F48x5IZ04IaxfB1N8DMKC/MUANcERans1rYMpVkMx0y65IwbtPwPpP4OjLmvzHdepoHHygzgUiIiLN5fCDA6a9FLJqdVZ9YQmceXKgXtPSJDxMwfxfwcb3INwKloBld+O7/hDrMrrQ4Ym0CEpwNUCH9sZVl8eZ9kLIrDlO165w/JEBuw5TrwkRyZ8zTo4xfJgx9YWQLVuixNZh4wIScd04i7QpYRpm/Xd7cqtS9fci0rK8+0SOcpuEpbOiJFfnvoWJS0RERHZIaanxs+/Hef6lkJmznE4d4ZgjAvYYofrC1sDMxgPXEw01eqO7X1NtfSlwG3AAsAo4x90/yqy7AvgakAYudvfHdyiI1c/CxnkQlkfvPQkOfPgHfL+bsUBV+yIqBQ3Uvp1x8vExTj6+0JGISFs2cs+AkXvqZlmkTavYBOlU/duJSMuy6kMIc5TdIA7rlijBJSJRI5Z1SyBeBp16FzoaEWmAslLj+KNjHH90oSORpmRmMeDPwPHAYmC6mU1293eyNvsasMbdh5vZucC1wDlmthdwLrA30B94ysx2c/ccE0/U49Np25Nb2TyEzfOh4x6NPqRIa6MEl4iIiEgxKekAsRiEyfq3FZGWo/uQaO6tsFrdRpiGzv0KE5OItByLZ8KLf48asXgaugyAo74HHXsWOjIRkbZoLDDf3T8EMLM7gQlAdoJrAvCLzPf3AjeYmWWW3+nu5cACM5ufOd7LjY7C6qq6jzX6cCKtkRJcIiIiIsUkiMHep8HbD1Yd7ixWUriYRKR+e5wI856umuCKJaD37tClf+HiEpHCW7cUnv1T1ev6mo/hiV/Bmb8H05DkIiJ5NgBYlPV+MTCutm3cPWVm64AemeWvVNt3QK4fYmYTgYlZ7xsR4u2N2FZ2ROP+H1IoSnCJiIiIFJt9JkQJrdmToXwDdOwNY74A3FLoyESkNh16wPgr4dV/wsr5EIvDrkdkyq6ItGnznqo5hKmHsHU9rHgP+uxemLhERKRZufskYBLAmDFjfMaMGdXXw0c3wOqXAAeLgQUw4kqs44gCRNx2mFn095cWoa5koxJcIiIiIsXGDPY+OXqFIQSam0+kKHQfAif9Iiq3ZuqV0YbtzMT10gpt+jRKaOWydW1eQxEREQCWAIOy3g/MLMu1zWIziwNdiK7ZDdm3QcwMhn0X73M6bJgN8U7QdSwWK9uRw4m0SqoNqU8Y1hwnX0Qkn9wzY/Gr5YiI5KDklkjxCQIlt9qwrInrTwL2As7LTEifbdvE9cAfiCaul9aq/74QK625PExDz+H5j0dEaudes8eltEbTgRFmNszMSoBzgcnVtpkMnJ/5/izgGY+6/EwGzjWzUjMbBowAXtuZYKz9EKzPKViPI5TcEqlGPbhqs3U9vHIzLJoJhNBnLzj4QujUu9CRiUhb4R4NV/LWf6MhyNp1gdHnwPAjCh2ZiIiIiOy4HZ643jVWTuu0y2HwzhTYtBrCZLQsXgrDj4yGNxWRwktXwOt3wPvTIJ2EboPgoK9CLw0T1xpl5tS6CHicqLf1ze4+x8yuBma4+2TgJuBfZjYfWE2UBCOz3d1E1/UU8B13V+8JkWaiBFcuYQiP/RI2rITK88/yd2DKlfCZP0CiXWHjE5G2Yd5TMPMOSJVH77esjebtCOKwyyEFDU1EWpbycmfh4qjO0901Ga5IK7J5s7N4qdOls8p1K7IzE9d/mr3Rzk1OL02t6f/+/wQuaOJjisgOef7PsOStKLkFsOZjePL/wSn/C136FzY2aRbuPgWYUm3ZlVnfbwXOrmXfXwG/atYARQRoQILLzMqA54DSzPb3uvtVzR1Yc0unnbXroEMHKCutdhO6bDZsXrs9uQWZIcIqYMHLsNsxeY1VRFqvDRvraIQ767/bk1uV0hXw5j1KcInINs++mOauB8JtIxVedU2KS74Rp0d3VXKKFDN356HHQx59MiQeh1Tm0WTjJqdjB5VvidQ3OX1LNXtuyF9uSlOR3L6sJAHnfibgiENihQtsJ2gy+pZPCWCpbt36BjYg2bQKFr+1vYdlpXQS5jwCh3y9eQIUEZF6NaQHVzlwjLtvNLME8IKZPerurzRzbM3mhVfS3PNgSDIJocO4A4wvfi5GIp65qK1fmnverVQ5rF2c32BFpFX6dJUz6bY0Hy+KHoJ//uskF34pzpBBmfNQmI6GSs1l86o8RSkiLd38BSF33R9WqSBc+glcc32K/fY2SkvhkANjDOivCh2RYvP6W85jT4ckU5DMmurj77ek+f53dnwgjkVLnJenp0kmYf/9AvYYYar0zb+dmbi+VbjvoarJLYCKJNz/SMjhBwf6TIpIs1m+0vnHbVGd349+maJPL/j6l+MMrOt+ecNyiCVqJrg8hLWLcu8jIiJ5Ue+s5B7ZmHmbyLyKtlnS7Lkh/7k3ZNPm6AY6lYLXZjr/uisrodVtEAQ5Wo3Fy6DH0LzFKiKtUyrtXHt9igULfVtr7GXL4f9uSG3v0RXEoH233Afo1Dc/gYpIi/f0s2GNCkKANWth2ovOk9Oc//19imee15DvIsXmiakhFRU1l7//obNu/Y49jj05Lc2v/5DiyWnO1BecP/0jzU3/TqvXSf7tzMT1rcLyFbmXb9pMzs+9iEhTSCada69LsTDT0DSVgiXL4Dd/TLF5Sx2n2M79aia3ACwGPXZppmhFRKQh6k1wAZhZzMzeBFYAT7r7q80aVTN6+ImaFUHJZJTk2nYx67MXdO4TzXNTyQIoaQ9DDspfsCLSKs2e62zZGo18mi2dhpenh9sXjD4HYiVVN4qVwP7nNn+QIlIU1m+oe30YRvc59zwQ1j0kqoi0OBtrKbOxWJQEaKx16537HopGsai8B6mogJmznHff1/khn9w9BVROXD8XuLty4nozOz2z2U1Aj8zE9ZcBPy5MtM2jZ4/cy8vKoKQk97rWIJly7n4gxUWXJ/n6pUmuuS7FoiUqfyL58uZspyJZ81k8lYbpb9RRFtt3g6EH53g+T8DepzR9oCIi0mANSnC5e9rdRxENnTDWzEZW38bMJprZDDObsXLlyiYOs+msWl3Lg2IAGyr7qZnBCT+D4UdCol10ARsyDk6+GuKt+G5bRPJi9RonnaMzRTIZDV24za6Hw6HfiHpsBXHoMgCO/C4M2j9/wYpIi7bv3kYiUf92QQzmvKsKtGJgZt3N7Ekzez/zNWd3XjNLm9mbmVf1nh/SCozc04jlGFQiFoM+vRp/vNlznViOp7+KCnj9zbDmCmlW7j7F3Xdz910zE9Hj7le6++TM91vd/Wx3H+7uY939w8JG3LTOODlGSbXrV0kJnHZC6x6ecNKtaaa+4GwtjyrY5y+IRnaorZ5CRJrW6jVeZdjfShUVsGp1PdfCgy+EfU6Hss4QJKDv3nDSVdBxBy7KIiLSZBo1eLu7rzWzqcB4YHa1dVUmt22yCJvYrsOM19/0Gq01LIAe2dUHJe3hoK9GLxGRJjR0sGE5KphKS2DXYdVWDD0oeomI5HDkIQHPvhiyZi05H9YrGZDY8Sl7JL9+DDzt7teY2Y8z73+UY7stmQZo0kqdckKM6W+k2LI1GkKpss7/i2cFxGKNTwAkEtuPkc2sdfeYkZZp//0Czk85906OrmEdO8Cp4wOOPbxBbXCL0spVzux3alauJ1Pw5LNpzj1TF2qR5jZ0sBGPUaPBaWkpDBtSz/kniMG+Z0YvERFpMeq9gzKzXkAyk9xqBxwPXNvskTWTCSfFePudFBUV27skl5TAmacExOOtt6WYiLQcwwYbw4cZ73/oJDNDpsbj0K0bHLCfzkMi0nBlZcbPfxhn2gshb8yKWp3G41FleLbQo94gUhQmAEdlvr8VmEbuBJe0cl06G1dfEeepZ0PemRfSo7txIzD2gBzduhpg372sRiM/iJLfBx8YHXPNWmf1GqdvH6NDe50zpHmNOyDGuANipNJR78LW3HMLYPkKJx6v2SAlnYaPFxUmJpG2ZrddjcEDjY8+3n5BjMehV4/oOikiIsWnIc2j+gFTzWwW0WS4T7r7w80bVvPp18f46WVxRu9rdO4EQwbB178U49gjduxBUUSkscyMiyfGOPXEgF6Z+QeOPcL4yffiSrSLSKO1KzNOOi7GTy6Lxno64+SAeI7bmrff0RBkRaKPuy/LfP8J0KeW7coyw4O/YmZn1HXAYhlKXGrq1NE485QYP70swTcv2LneHWVlxre+GqO0BMpKo57j8XjU0K93L7jhxhQ/+Z8U1/0tzQ9+nuLuB1J4royYSBOLx6zVJ7cA+vS2Gg1QIBp2dPCg/Mcj0haZGZd9O8bJx0fVod27wQlHGT++NL5DvaNFRKTw6n1KcvdZwOg8xLLDPExBchXEO2OxdvVu37+v8e2vqvu/iDQtT64FT2MltcyanSUeN045PsYpx8e45io4e4LOSSLSNE44OuDp56IhnypVVMBNt4f06xswoJ8e3gvNzJ4C+uZY9dPsN+7uZlZbhmGIuy8xs12AZ8zsbXf/INeGxTKUuDS/kXsG/O5/jFnvRL3I997D6NrF+OftKebMjYZOq+xdMu1Fp3fPkKMOU0NAkabQq4cxci9j9tztozhA1Ivy+CNVzkTq4+ktkFoHiZ5YsOPPz4mEcdr4qMz95hcNmMxWRERatKKvUfWVT8Li28DT4CHe/TAY8g0saPhFamu5s3kLdO0MQaBKH2l7zGw8cD0QA25092sKHFJR8fJP4IPfw5aFgOGlvWHYpViHXRp8jDB01q6H9mVRC2sRkR01f0F0X1NdKgXTXkjzhbOL/vav6Ln7cbWtM7PlZtbP3ZeZWT9gRS3HWJL5+qGZTSNqkJYzwSWSrazMGLv/9nuNZNJ5dabX6FlSUQGPT1WCS6QpTTw/xv2PpHnuRae8AoYPMz5/Vowe3XX/39rU94xtZqXAbcABwCrgHHf/KN9xFgMPk/DxjbDqWbAALIb3/zzW56Qm/TkbNznpdDREsIiIFI+iruHwtTNg0T8hLN++cPWL0ddhF9W7f0WF8+970rw20wkykyuf+5mAg8boIU7aDjOLAX8mml9vMTDdzCa7+zuFjaw4eJiEd38GybVAplH81iUw70p8379i8U4NOs4ProwmkXeH0fsY558Xo6xUN9Yi0ngbNkCukZ7cYc26/McjjTYZOB+4JvP1weobmFk3YLO7l5tZT+BQ4Dd5jVJajfKsuYmr27Qpv7GItHaJuPG5CXE+N6HQkUhzauAz9teANe4+3MzOJZrr/pz8R1sEPr4JVj0Hntz2yM2Sf+El3bFu43b68CtXOf+4Nc3Hix0M+vSCC78UZ9AAPY+LiBSDhszB1XItu7dqcgvAK2D1C3h6c72733JHmumZ1ooVSdi4CW67M+Td9zVHhbQpY4H57v6hu1cAdxJNcC8NsW4mpLey/U47w9NRC7N6fPBRdL5ZvwGSyaiHxRtvO5NuTTdDsCLSFuw6LPccHyUlsI8mzy4G1wDHm9n7wHGZ95jZGDO7MbPNnsAMM3sLmApco4YpsqM6tI9GsqjODHYbrnOGiMgOaMgz9gTg1sz39wLHWluYjK6RPF0Oq6ZFdX3ZwnJYes9OHz+Vcq69LsWCj51UOnoeX7IMfvPHFJs2a1RnEZFiUNQ9uKhYlXu5BZBaD7H2te66cZMzc1aOoTiS8MgTIXuMKO7cn0gjDAAWZb1fDFRpBmVmE4GJWe/zE1nRu7PBW970x5Iayy75RlPGIiJtRdcuxnFHGFNfiIY/AkgkoGd3OHiM7m9aOndfBRybY/kM4MLM9y8B++Q5NGmlzIwvnRPjLzelSaai3lyxABIlcNZpGtlCRGQH1PuMnb2Nu6fMbB3QA/g0eyM9i9fndzu1dyJR+73xDeobLyJSFIo7wdVxd1jzCjV6TlgMEj3r3HXdeojHyNnC+dNVaqUhkq365PQzZswocEQth298D977Rc3epEEZDP0O1v2QOvf/xbVJfvnjEr52cdUWae3K4HvfirHLUFVGFxs9dEpL8NnTY+wy1Hnm+ZAtW50xowKOPjygpESfTxGpaeSeAT+6xHj06TTLVzi7DjXGHxujZw+dM0RECqmtP4u7p+HNr0J6Y7U1Bl3GYCN+vMPHNjOenJri3ofCnHWDxx9lnHNmcVebtiV6Dhdpu4r7TN3/XFj3RqZiOZOUCkphwBexoO5frVeP3GPNBwEM30UnRWlTlgCDst4PzCyThugwAjruARvmbh82wRJQ0hu6jq1399rON6k09Ourc5GI7BgzY//9jP33U5JcRBpmyCDjmxcU9+OhSEuwumIh8zc+y6b0ajon+jGiw1F0TvQpdFiSXw15xq7cZrGZxYEuQC3DFLVdZjF80Jejebi2NSq1qO5v4Od3+vhDBhuxAKrnt0pLYVc1NhURKQpF/QRj7Qbie14LS++EjfOgpAf0+yzW9cB69y0pMU4bHzD5sZCKyjppg5IEnHqChuKQNmU6MMLMhhHdZJ8L7PydYhthZvjwK2D5w/DpU9HcW90Pi85F9STaAU46NpY5zvake0kJnHB0QLsyJbhERERERIrF8q3v8ua6+wgz1eVby9exqvwDxnW/gC6J/gWOTvKoIc/Yk4HzgZeBs4Bn3HM1wxbreSwe7wrL7oWKldBhNxhwLtZu8E4fe/gwY+hg48OFTjIZLYvHoUc3GLWvnsdFRJraqtXOk8+m+XgRDB4Exx8Zo0f3nTvfFnWCC6IkF7v+YIf2HX9s9Aec8mSadeujnhSfOSVGn965/6hbQmfWlpBOMdizNFD3V2kVMuN9XwQ8DsSAm919ToHDKioWJKDfmdGrkSpP4geONt593+nUMTo3HTSm9vPLe1tD1qSdkWUBHWI6D4mIiIiItATvbHhsW3KrUpok7254gnHdLyhMUJJ3tT1jm9nVwAx3nwzcBPzLzOYDq4mSYFIL63oAdD2g6Y9rxqXfjPHY0yEvvBoShjB2f+PUE2PEG/GsnXTnrS0hCYN9ygIC1ReKiNSwaIlz7fUpkilIp+GDj+CFl1P86JI4gwbs+Hmz6BNcO+vA0QEHjq6/2/G9a5JcsaycAEg79E0Y/xrSjmGl6rIsxc/dpwBTCh1HWzbx/PpPx8uSIV9auJUF5SFxg6TDz/qW8NUeJXmIUERERERE6lIebsi5fF1qWZ4jkULL9Yzt7ldmfb8VODvfcUlNiYRx2vgYp43fsdGcpm5I8e1FW0kTTZ7SKTBuGVLGvu00OlSxMrPuwF3AUOAj4HPuvqbaNqOAvwKdgTTwK3e/K7PuFuBIYF1m8wvc/c3mj1ykZbv9njRby7e/T6ej13/uTfOjS3Y8TaXsTAPM3pLm8qXlbAphQwibHRZUOOd8tIVQPchFJE++tHAr87aGbPHoXLTV4VefVPDSxhwz4oqIiIiISF4F5K7QLrEOeY5ERPJhaTLkwo+3si6EjSFsCuGTlHPOgi1sCVVfWMR+DDzt7iOApzPvq9sMfNnd9wbGA9eZWdes9T9091GZ15vNHbBIMfjgo9znxfkLdu58qQRXA9yyOklFtb+zA2vSzvTNYUFiEpG25b2tIQvKQ9LVlm9x+MeqZEFiEhERERGR7Qa3P5CARJVlMRLs2uGwAkUkIs3p3jXJGs/oACngiQ1qiFrEJgC3Zr6/FTij+gbu/p67v5/5fimwAuiVrwBFilFpLQNQ1ba8oZTgaoCVSSdXGsuA1Wm1yBCR5rcm7cRrGY52RUrnIanJzP7PzN41s1lmdn+11mQiIiIi0sR263gsA9vtR0CcmJUQswS7dDiMge1GFzo0EWkGn6ap0SAeIOWwWs/pxayPu1eOLfsJ0Keujc1sLFACfJC1+FeZZ/E/mFlpM8UpUlSOOMRIVG0HRCIRLd8ZbX4OroY4rlOMFzal2VLt2pR0OLC9coQi0vxGlgXkuj8uNTihk8b2lpyeBK7ITHJ9LXAF8KMCxyQiIiLS7NYuct6+N83qD53SzrD7SQFDDw0wa0AFijvMWwwvvwthCGN3h5FDoAH7Bhawd+dT2L3jcZSHGymLdSZmiXr3E5HidETHGHesSbKpWqt4Aw7toCrXlszMngL65lj10+w37u5mVmu20sz6Af8Cznf3yk/CFUSJsRJgEtFz+NW17D8RmAgwePDgRv4WIsXlzFNjrFyVZvY7TjwOqRTss6dx5qk7V6+ps20DnNUtwT9XJ/mowtmaOaW1M/hWzwQ940pwiUjz6xAzfta3hP/9pGJbsr3UoHfc+EqPnezLK62Suz+R9fYV4KxCxSIiIiKSL+uXOlOvSZHOTGKe3AJv/idk61rYsyEVKPe8AM/PhorM8GJvLYDRu8IFxzUoyQUQD0qJB2qwL9LaHdMxxn5lAW9sCbc9p7c3OK1LnN3KVF/Ykrn7cbWtM7PlZtbP3ZdlElgratmuM/AI8FN3fyXr2JW9v8rN7J/AD+qIYxJREowxY8ao25+0aom48Z2vxfl0lfPJCqdvb6Nnj53rvQVtIMG1KbWa9zdOZXVyIaVBR3btcBh9y/Zq1DHaBcbDu7bnX6uTPLIuRZeY8ZUeCY7p1Or/fCLSBEIPWbj5NRZtmUHaU/Qt24vhHQ4nEbRr1HG+0qOE3UsD/rEqycqUc3ynGBf0KKFzbOcvBtLqfRW4q7aVajUmldJpZ+rzIc+9HJJOw9gDAk48JqCsVOcZEREpDnMfSpOuqLosXQHvTgkZcXxAvK5r2rLV8NzbkMyaVac8CTPnw5H7wC65GvuLSEuzNrmE9zdOY0NqOR1iPRjR8Si6lwxp8p8TmHHHsHbcvSbFvWuTJMz4Yvc4p3VWfWGRmwycD1yT+fpg9Q3MrAS4H7jN3e+ttq4yOWZE83fNbvaIRYpIzx5Nk9iq1KrPuJvTa3hp9SRSXgE45eEGZq17gM3ptezS4ZBGHat9YHyjZwnf6KmeEiLSOG+uu4eV5R8QkgRg4ebXWFE+j8N6fLPRQ5Yc0jHOIR1b9albGqGuYRXc/cHMNj8lmuf49tqOo1ZjUumv/0zzzrtORXS64rGnQma+FfLzH8aJK5kuIiJFYPUChxx3MxbA5lXQuX8dO89ZmHNfKlLw9gIluESKwOqKj5m+5t/bnr/Lww1MX3M7o7ueTe/SEU3+8xJmfKF7gi9013Ckrcg1wN1m9jVgIfA5ADMbA3zT3S/MLDsC6GFmF2T2u8Dd3wRuN7NeRKNVvgl8M6/Ri7QxrbqW9IONz29LblVKk2T+pmkMaX+gxsIWkWa3IbWCleXzCUltW+akKU9vYNnWOQxsN6pwwUnRq2tYBYDMjfapwLHursSV1OnjxV4luQWQTMGnq+CNWc6Bo5XgEhGRlq9DH2PTpzVve8IUlHWtZ+fSBAQ5rnfxAMo05KBIMXh3w+PbkluVQpLM3fBYsyS4pPVx91XAsTmWzwAuzHz/b+Dftex/TLMGKCJVtOoBYVcnF5K7+ZWxObU63+GISBu0NrkEo+ZDcpokqys+yn9A0maY2XjgcuB0d99c6Hik5fvgozDnXVN5Bbw3P8yxRkREGsvMupvZk2b2fuZrt1q2S5vZm5nX5HzHWcz2PCUgVm3glVgCBo8zStrX01hj/+G5l5vBgaoYFykG61PLcy7fnF5N6Omc60REpHjVm+Ays0FmNtXM3jGzOWZ2ST4CawrtYl1zLndPUxLrmN9gRKRNahd0zjkZdUCM9rGc9RkiTeUGoBPwZKZy7G+FDkhatm5djFiOO8NEHHp0V+8tEZEm8mPgaXcfATydeZ/LFncflXmdnr/wil+v3QIO/FpAu64QxKLk1tDDjP2/FKt/5w5l8I2To55cZSXRqyQOFxwP3Ts1e+wisvNKgvY5l8etFGvd7fxFRNqkhgxRmAK+7+4zzawT8LqZPenu7zRzbDtt1w6HsbZiEemsrskBcXqVjqA06FDAyESkrehRMowSa89WT+JZfSPMYgxst38BI5PWzt1raYIsktvIvYzS0qjHVvaAlkEMDhmrygARkSYyATgq8/2twDTgR4UKprUaeECMAfsHJDdBvAyCeCMaaowcAr/9GsxdDB7CHoOiRJeIFIVdOxzOvA1PVqkLjJFgaPuDsRyNT0VEpLjVW1vh7svcfWbm+w3AXGBAcwfWFHqUDGPvzqeSsHbESBAQo3fp7uzb5YxChyYibYRZwLjuF9AlMZCAGAFx2gXdOLDrFymLqRWoiLQc8Zhx+cVxBvaPem2VJKBHd7jsWzE6d1JlgIhIE+nj7ssy338C9KlluzIzm2Fmr5jZGbUdzMwmZrabsXLlyqaOtaiZGSUdrXHJrUolCdhvGIzaVcktkSIzuN0YhnU4lJglMnWBcQa1P5DhHY4odGgiItIMGtKDaxszGwqMBl7NsW4iMBFg8ODBTRFbkxjQbl/6lY1ka7iOhLUjEZQVOiQRaWPaxbpwcPevUh5uIvQUZUFntRwTkRbhvfkh014M2bQZxowKOOhA46rLE6xe66RT0LMHOl+JSIv14cKQZ54LWb8BRu1jHDouoLSk8OcsM3sK6Jtj1U+z37i7m1mu6Q8Bhrj7EjPbBXjGzN529w+qb+Tuk4BJAGPGjKntWCIibYaZMaLjkezS4VDK0xsojXUkZolChyUiIs2kwQkuM+sI3Adc6u7rq69vyTfWgQWa60ZECk5Do4pIS/Lo02keeiykoiJ6//6HaZ572fjRxTG6dy18BXFbZWZnA78A9gTGuvuMWrYbD1wPxIAb3f2avAUp0gI893KaO+8LSaaiYVXnf+hMeyHkJ5fFKSst7DnM3Y+rbZ2ZLTezfu6+zMz6AStqOcaSzNcPzWwaUUPTGgkuERHJLWZx2sdVFygi0to1aEIFM0sQJbdud/f/Nm9IIiIiItKcNmx0HpyyPbkFUFEBS5Y5r81sUe2U2qLZwGeA52rbwMxiwJ+Bk4C9gPPMbK/8hCfy/9u78zi5yjLv/5/rVHV1ZyMLCdn3jYQEAjT7vi8iAQQFFUFxIio64/CMovzGx3EZo+OGyk9BxGVkREdBwqLsyL4kISEJYQlJgISELASydXct53r+OBXT6VSnq9NdVae6v+/Xq15dder0qaurz31Xnfu6l8pranJuvS0kndm5ZmA6A+s3wqNPhpUNrm1zgMvy9y8D7mi5g5n1N7Pa/P2BwDFA7NfAFhEREREptzYTXBbNS/NLYKm7/6D0IYmIiIhIKS1b7iQLjONPp2H+C7FvHO7S3H2pu7/cxm6HA8vcfbm7p4FbgZmlj04kHla+6QQFrmQzGZi/MPZJ+tnAaWb2KnBq/jFmVm9mN+X3mQLMNbOFwMPAbHdXgktEREREpIVipig8BrgUWGRmC/LbvuLu95QsKhEREREpmR49gAJtwGbQW7OpVoPhwJvNHq8Cjmht57iulSuyt3rUGd5KLj7udZi7bwROKbB9LvDJ/P0ngellDk1EREREpOq0meBy98eBsk1ivvEdZ+HiEDM4+MCAfn21BoSIlFcm6yxc7Gx8xxk90pg8wYgGs4qIdA2Txhu1tdDYtOv2miSceExRM1hLB5jZA8CQAk9d6+67TVfWUXFeK1dkb4wcDv36wbr1O6coBEil4OTjVYe110ObV3H9+iVsyjXygX7j+MTAKfQIil6uW7oJd2drCHUB1OjaSIrQ0OjMf8HZts3Zf2LAqBE6b0REpPPF6lvr/Y/kuO3O8B/ptD/+JeQjFwUce2Si8C+sfw9eWQ296uCA0VDTyn4iUlCxC9l3J+s3OLOvy9LUBJksJBMwYphx9WcTpFIFvpBnsrBoJTSkYcpIGNCn7DGLiLRXEBj/+pkkP/xZlsZGwCCXgw+eFzBmlBqHS83dT+3gIVYDI5s9HpHfJtItmBn/8qkkP/j/s2zeCoFFX8nef3rA1Mmqw9pj9pr5fGPtPLaHWQCe2baOmzYs5an9L6BOSS7J+/vWLNesbmJ1xkkYXNQvydeH1lIXKGEhhS1bEfKjn+Vwh2wOEkHIwQcaV3w0QVDseeMOK9+G1Rthv34wcVg03YCIiFSFnDsBlHzQQGy+sa5d59x2V0gmu+v2W/435ID9A/r3a/ZGuMMfH4XHlkQfboFBIgFfOA9GDipr3CJVbsdC9jdUOpC4+MV/59i8ZWdv4FwO3ljl3H1/yPnva5FEX7EWrrsj2tkdcg6nzoDzjy573CIi7TV8qPHdryV5baXT2AgTxhk96tRoUCWeAyaa2ViixNbFwIcrG5JIeQ0aaPznvydZ8bqzdRuMG2P07qU6rD02ZBv4jzVzafTcP7ZtD7O82vQet7zzKlcMnFLB6CQuFjXk+MTrjTTkr4+yDn96N8umnPOLUT0qG5zEUhg619+U22WmgFwOnl/kzF3gHH5IEXV1UwZ+fAe8uT6aVtsMBu4DV18QdXIXEZHYWtKQ45q3mpjfEJIyuLBfkv8YWkvPEnWMiU33tnkLQsJcgScMnm+52PnCFfD4i5DJQToLjRnY1gg/vRNCzboiUqwiF7LvNrZuc15/03eZ6gaiHsFPPtuiHsqFUZ3TkI7qoKZs1DXtoYWw9E1ERKpBEBgTxwVMnxoouRUTZna+ma0CjgLuNrN789uHmdk9AO6eBa4C7gWWAn909yWVilmkUsyMcWMCDjwgUHJrLzy5dS0p271JYFuY5fZNKyoQkcTR9evTNLa4Pmp0eGBLjrczrSyG142Z2QAzu9/MXs3/7N/KfjkzW5C/zSl3nKW04g0nk9l9ezoNjz9d5Dlzx1Owcl10nZ3ORgmvtZvgloc7N1gREelUb2VCzl/RwLyGEAea8h1jLn+9sWSvGZsEV+gF1zoHh7Dl59+ji6MPuJYa0vDGuhJEJ9K9mdksM5trZnPXr19f6XBKqrWmkZZJL5a9FSW0Wkpn4XG1MYpI6axe4/z9iRzPLwrJZtWxp6tx99vdfYS717r7YHc/I7/9LXc/u9l+97j7JHcf7+7fqlzE3VcYOouXhjzyeI4Vr4f4bl8WROKtf6K24DV4gDG4RiNzJPJqU1jwPEkZrM6o3ivgGuBBd58IPJh/XEiDu8/I384tX3ilt1sbXpHP7eKpl3a/3s6FsGB5Ow4iIiLl9uuNGdItqukmh3nbc7zSWJr6OzZTFB4yPeCe+8OCn1MzprfIwxVKbkE0ZLm150S6qc5YyL67LE7fu5cxdAi82WIVk2QSDj+0Reork6XVdFhTge5qIiIdFIbOTb/L8fwLjgFBADU18MXPJxk6WCMXRMpp07vOd36cZevWqL3NDMaPMT7/qQQ1SZVHqQ7H9B5Kv0SKrWFmlwRGXZDg04MOqFhcEi+H9EzwSlOWll370g7jamPTZzpOZgIn5u//BngE+FKlgqmEsaONoMCpkUrB0YcXec7kCk3xRL53fJdtkhARqXpLGkPSBbYnDV5Lh0yq6/zvDrH5NjJ8mHHmyQE1NVGDzY5Gm/PeFzBw3xYXiYdPhFSh3JzD2ELt+CLdl7uf6u7TCtyKSm51N//0sSS9ekZfvgFqa2HwIHj/GS3W35owrHDPsVQSDp9U+kBFpNt58llnwaJoypd0BhqbYMtWuP6mrEaOiJTZL3+X451NUTnMZKJpl5atcO65X73KpXoEZtw/6f2MTvWhd1DDPkGKnpbkRyOOob7XfpUOT2LiqkEpegS7du3rYfCxATX0SyihX8Bgd1+Tv78WGNzKfnX5WVKeNrPzWjtYNc6mkkwYn7o8QSoVdRYFqE3B5AnGES07jrZm2pio90hL44dAIrH7dhERiYUZPQJSBarvjMOkEnWMic0ILoCZZyeonxEwb2GIGdQfHBTukXz0VHj6ZVi1IRopkQii2+WnQY0+6ERk7w0bYsz+v0mene9s2BgydlTAQdOMRMuLt7oUfPRk+O+Hot5loUNtDYwbAodOrEzwItKlPfJEjnSBrlDvbIJ162Gw2iJFyqKh0Xl1ue/WzyWTidYWmXmWrkekekyu68/yaR9h7vb1bM6lOaLXYHonaiodlsTI6FTAneN68M21aZ7ZnqN/wpi1bw0f37f7nid7miWl+QN3dzNrrRfSaHdfbWbjgIfMbJG7v9Zyp2qdTeWA/QO+/e/Gs/NDtmx1pkwK2H+iYYWSVoVcdBy8+hY0pqOZmmqSUXvfpSeXNnAREemQywbU8MuNGTLNlqOqMziud4Lx3SHBBdFIruHDootCd2fDqyFb34Z9RsCAMfk3IZmAqy+AF1bAopWwT084ZioM6lu5wEWqkJmdD/wEGES0kP2CHWt9dGc96owTjjZ2DHJtfM9Z9WJIMgVDphuJHV0RjpgMY/aDJ16EbY1w0DiYNpqC8zGIiHRQdg8zNGc0Q7NI2bQ2axK0Xk5F4szMOCyuI7YceAFYCDQBA4FjgJiG21VNrkvw32O0LtsO7n5qa8+Z2dtmNtTd15jZUKDgQvHuvjr/c7mZPQIcDOyW4KpmffcxTjtx104f7s47K5wtb0GfoTBgXCtJr/694RuXwjMvw8q3Ydi+cPQU6FVXpuhFRGRv7FcTcNf4nnx1TRNPbsvRw+AjA2r4t/1SJXvN2CW4dkhvcx79fpYtb+c3OPQf06ybZCKAg8dHNxHZK+5+O3B7peOIs5f/lmPJX0IssXOGhGM+n2DQpHwSa3B/uOCYygUoIt3GEYcGvL0+JNNimb/aWhimGZpFyqZ3L2PoYFj11q7bEwk4dIam6xLpVE8BLwI7ksdvA3OAC4ABlQpKZI/mAJcBs/M/d1sawMz6A9vdvcnMdqRtv1vWKCsg0+g89oMc763eORCt7zDjuKsT1NQV+PysS8EJ06ObSBmZ2QDgD8AYYCXwQXffVGC/HLAo//ANdz83v30scCuwLzAPuNTdCy1LJNIlTagN+J8ydoyJ7TCD52/JsXk15JrytzS8s6JqRmOLSBfwzoqQF+eEhNmoHso2Rrcnfpwjl1Z9JCLldfLxAcOGRAktiNY0SKVg1mUJgkCN6iLldMVHk/Soi9YMhmhtkf794LyzNT2hSKdJA0vYmdzaIUfUXCgST7OB08zsVeDU/GPMrN7MbsrvMwWYa2YLgYeB2e7+YkWiLaMX/pDj3Td8ZztfE7z7pvPCH/YwNFqkMq4BHnT3icCD+ceFNLj7jPzt3GbbvwP80N0nAJuAK0obrkj3FssRXB46q+Y53uIzLswU3l9EpBRWPhGSa6XeeftFZ5h6aYtIGdWmjC9/IcmCRc7Sl0P69zOOOSKgfz/VRSLlNnK48e2vJnnimZB1653xYwMOO9ioqVF5FOk0m4m65LZs+3ZgQ/nDESmGu28ETimwfS7wyfz9J4FuNyzpjWecsEXCOsxG2w+9rDIxibRiJnBi/v5vgEeALxXzixbNuXky8OFmv/814GedGaCI7BTPBJeDh23vJyJSSrkmdq6I2PI5DS4XkQpIJoz6GUb9jNgOwhfpNnr3Ms44WSO2REqmD9Bau0D/cgYiIp2hZXKrre0iFTTY3dfk768FBreyX52ZzSUaazzb3f9CNC3hu+6+48xeBQxv7YXMbBYwC2DUqFGdELpI9xPL1pEgYew7oUDvR3WIFJEyGn5oQKJ29+1hDvabogpJRERERKRkaoFJ7N4tNwkcWv5wRKRj9ptiu7frGew3VdfWUn5m9oCZLS5wm9l8P3d3Wu36zGh3rycarfUjMxvf3jjc/UZ3r3f3+kGDBrX/DxGReCa4AA79WIKanhDk57VPpKC2d2VjEpHuZeiBxuAptjPJZZCogQMvCqjtoy/hIiIiIiIldRwwDci3C9APOBNQG6BI1Tn4owlSPaP2PYh+pnrCwR/WaGgpP3c/1d2nFbjdAbxtZkMB8j/XtXKM1fmfy4mmMTwY2Aj0M7Md3TNGAKtL/OeIdGuxnKIQYJ+hxpn/mWTl4yHvrXL6jzHGHB3AjyodmYh0FxYYR30mwdrFzur5Ick6GHNMgn4jldwSERERESm5ADgSOIJoukK1g4tUrd6D8u18T4a8+7rTb5Qx5piAVC9dX0vszAEuA2bnf97Rcgcz6w9sd/cmMxsIHAN8193dzB4GLgRube33RaTzxDbBBVDb25h8pr7BikjlWGAMPdAYemBsB7yKiIiIiHRthpJbIl1Aqpcx6TQVZom92cAfzewK4HXggwBmVg9c6e6fBKYAN5hZSNQdY7a7v5j//S8Bt5rZN4HngV+W+w8Q6U5ineASERERERERERERESkHd98InFJg+1zgk/n7TwLTW/n95cDhpYxRRHbSkAQRERERERERERERERGpKm0muMzsZjNbZ2aLyxGQiIiIiIiIiIiIiIiIyJ4UM0Xhr4GfAr8tbSgiIiIi0lENjc5jT4UsXurs2x9OPj7ByOFavFtE4OVlIX9/ImR7Axx2cMARhxrJpOoHERERERGpTm0muNz9UTMbU4ZYRERERKSDvvadLFu2QDoDgcEz87JccWnAoQdpQW+R7uzu+3LcfX9IOh09fuW1HI8+Zfzb5xIkE0pyiYiIiIhI9em0NbjMbJaZzTWzuevXr++sw4qIiIhIO7y3OUpuAYQe3f/trSG5nFc2MBGpmPc2O3fduzO5BZBOw6rVzrznVTeUk5ldZGZLzCw0s/o97Hemmb1sZsvM7JpyxigiIiIiUi06LcHl7je6e7271w8aNKizDisiIiIi7ZDNFtiWgzVvlz8Wab92NH6vNLNFZrbAzOaWM0apPq++5iQKDOJsSsPzi8LyB9S9LQYuAB5tbQczSwDXA2cBU4FLzGxqecITEREREakexazBJSIiIiIl9tZaZ83bztDBxrAhnTtdWJiDHnWdekgpnR2N3zcUse9J7r6hxPF0urVvO6vXOoMHGSOGaWq8cujRo/D2wKBXr/LG0t25+1IAsz2e+4cDy9x9eX7fW4GZwIslD1BEREREpIoowSUiIiJSQU1p56e/yLFshZMIIBfCpPHGZ69IkEq1v/E/lWKXaciCAEYMN/YdoERCNSiy8bsqZbLOz3+V48WXo9FEYQ7GjDI+PytBXV3X+3vjZP+JRk0NNDbtuj2ZhBOO1vp8MTQceLPZ41XAEYV2NLNZwCyAUaNGlT4yEREREZEYaXOKQjP7PfAUMNnMVpnZFaUPq7TCze/SeNtv2fq9a2n4068I332n0iGJSDfjYUhm7uNs+/F/AJBdurDCEYlIpfzvX3IsW+5kMlHjcyYDryxzbrsrt1fHO/lYI5mEujqoTcGQ/eCzV6gBuwty4D4zm5dv4I69OX+NkluZDDQ2RuvDLX/d+f2f9+5cl+IlEsa/fiZJ332grjYa0VlTAxdfEDBqhJKLnc3MHjCzxQVuMzv7tbRUgIhI+3g2S/qJBwDY/ovvkV3+coUjEqmsMHReeS1k3sKQ9zZrbVapPm2O4HL3S8oRSLnk1q5i61dm4U2NkEmTff4pmu66lT7fvIHEiDGVDk9EugF3Z/t1XyMz/0loagRg639eTe37PkSPi/+pwtFJV2NmVwPfAwZV41Rm3cGTzzqZFutmZbLw+NPOxRe0/3gXzkxy2knOyjecvn2N0SO65migamZmDwBDCjx1rbvfUeRhjnX31Wa2H3C/mb3k7gXX9InLCI9Hn4ySW81ls/DMfOeyS5wg0HlaSiOHG//1H0mWrXCammDiONPIuRJx91M7eIjVwMhmj0fkt4mISAd4NsvWr3+e3IpXAUg/MIf03/9Kj8s+R+1p51U2OJEKWLfB+f71WbZtAyz6bn7aicYF5yR0DSlVo80RXF1Nw80/xLdtgUx+7p5MGrZvZ/tN36tsYCIVYGb/ZWYvmdkLZna7mfWrdEzdQXbJfDLzn/pHcguApkaa7vw9uXVrKheYdDlmNhI4HXij0rFIYe67J7d2SGcKby9G332Mg6YFjBlpujCJIXc/1d2nFbgVm9zC3Vfnf64Dbidas6e1fWMxwqO1czqXg1CdRcsiCIxJ4wOmTw2U3Iq354CJZjbWzFLAxcCcCsckIlL1Mk8+QG7FK9DUEG3wENJNNPzmJ/j2rZUNTqTM3J0f35jlnU3RTCKNjVGC66FHnYWL9eVcqke3S3BlF88Hb1lIndzShXgYViQmkQq6H5jm7gcCrwBfrnA83UJm7uM7v1A3Z0Z24TPlD0i6sh8CXySaykxiyMyYMK5wI/PkCWp8lsLMrJeZ9dlxnyiRvbiyUbVtyiSjUL51zEgjmdD5Lt2DmZ1vZquAo4C7zeze/PZhZnYPgLtngauAe4GlwB/dfUmlYhYR6SrSTz28a0fTHRJJLRsg3c5ba+GdTbs3kzel4aHH1EYu1aPbJbioqSm8PVlDwStukS7M3e/LX0ADPE00/YmUmPXoBYkCM8QGAVbXs/wBSZeUX+djtbvrSi3mPnpRgro6SOarhWQyWh/nwxdq3azuqJjGb2Aw8LiZLQSeBe52979VJuLiXXxBIlr7ace5nojWg7r0QzrXpftw99vdfYS717r7YHc/I7/9LXc/u9l+97j7JHcf7+7fqlzEIiJdh/XoBRRq+3Oo61HucEQqqrHJCVrJDGxvUB9ZqR5trsEVR48/neOu+0I2b4aRI4wPzgwYP7a4XF3qhLNJPzhn5xSFAMkaao47XVP4SHf3CeAPhZ6Iy9odcbLmbeePf8nxyjKnrg5OOT7gzFOCotYPSR1/Bk13/h5yu89LVlN/bCnClS5qT+v4AF8hGtVRzHFUxito+FDjm19J8sjjIW+sckaPMk48JqDvPvpe0h25++1EUw623P4WcHb+/nLgoDKH1mH7DTS+eW2Svz8RsuJ1Z8QwOPG4BAP66VwXEZGuwcwuAr4GTAEOd/e5rex3JnAdkABucvfZZQsy5p6Zl2POX0M2vQvDhhoXnhuw/8TO6Z9fe9pMMs89utsoLkvVkZxSdV+tRDpk1AgrONdLTQ3Uz+h+Y2KkelVlgut//hySzuenXlvhfP/6HF/8PIwZ1Xbh6/GRKwlXrSD7yhJIBBCGJMZOouflny9x1CKVUcxC9mZ2LZAFbil0DHe/EbgRoL6+vtt343hnk/OtH2RpzH8nbkrDXfeGvL3e+fiH265WE0NH0uOTV9Nw0/chke+13qMnvf7t21gPjeCS4rW2iL2ZTQfGAgvznTdGAPPN7HB3X1vgOCrjFdavr3He+zSKRbq+ffoY7z9T57qIiHRZi4ELgBta28HMEsD1wGnAKuA5M5vj7i+WJ8T4+vsTOf7wl51tfivfcH58Q45/vhImT+h4g3tyykHUfeAyGv/3V9GGHj2xZIpe134fC/T9RLqXmqTxsQ8F/Pr3IdkchCGkUjBwAJx4rBJcUj3Kl+BqALYBfYFWZglsSzYbtbml07tuT2fg9rtDvvDptguf1dbR+6vXkXt9GblVKwmGjSI5dtLeBSRSBVprAN/BzC4HzgFOcd9tgbquJQQ2AbVA770/zP2P5Mhkdt2WzsAz85zz3+f069t2T/TaE88mdfjxZBbNg9/eT99f3Imlavc+KJFm3H0RsN+Ox2a2Eqh39w0VC0pEREREpItz96VAWzMEHQ4sy4/IxsxuBWYC8UtwbQWagH5EY81KKAyd2+4KC7b53XZnyJe/0DkN7nXnXUrqpHPgfwbQ6wvfIDntUCxZlf3/RTrs8EMTDBsa8PBjOd7dDAceYBxVH5BKaYYFqR6lr8GzwCPACqIVvxyYARxK4Wlv9+C9za0/9+bq9rXLJ0ZPIDF6QvsCEOli8tMifBE4wd23VzqeknoNeJQoyRUCA4kmb+vV/kMtf93J5XbfXpOENWuLS3ABWM/epI44Ibqv5JaIiIiIiEh3MBx4s9njVcARhXas2FTiDcD9wNtEbXkGHANMLuFLNkJjU+HnVq/t3L64Qd/+ANTMKPi2i3QrI4YZl36o9RTBpnedLVth6GCoqVHiS+Kn9Amux4mSW7n8DWAB0Id2fzD22cOIi/0GqYCJ7IWfEo1nuj/fw+xpd7+ysiGVwAbgYaKE+w7rgLuBi2h3sn34EGPF604Y7ro9m4OBA1UXSfy4+5hKxyAiIiIi0hUUswxAZ6nYVOJ/A9YTdQ7d0Zb3GNGsTIX+8k5QVxt1Gi3UmXTggNK8pkghZjaAaI36McBK4IPuvqnFPicBP2y2aX/gYnf/i5n9GjgBeC//3OXuvqC0UXe+bdudn/8qx7LlTiIRjVn54MyAE47RdJ4SL6VNcGWBV9n5Ydh8+/O0O8G1Y3hkqiYaovyP7TUw80zNDSrSXu7ePYYxLmb3esiBzcBGotFc7XD6SQmenpfdZeqEmiRMmWgM2lcJLhERERERka6qrWUAirAaGNns8Yj8tnh4j6iTaIsOnWSBhZQswZVIGGecHPDXB3edpjBVAzPPVoO6lNU1wIPuPtvMrsk//lLzHdz9YaI5ynYkxJYB9zXb5d/c/U/lCbc0fnZzjleXRzMYZfIdxn93e5Zs3wZOmdaBdT9EOllps0LpPTzXsPeHPe3EgLpaCAIY0B+uuDRgymQluESkFVuIElotGdHagO00ZLDxhSsTDBsS1UM1STiy3vjUx/WlW0RERERERPboOWCimY01sxRwMTCnwjHttJ3WWwu3lvalzzkj4H2nBfSoi661++4Dl34o4ODpavOTspoJ/CZ//zfAeW3sfyHw16609Mc7m5zXVuy+PIdnAr5/93p+vn5xZQITKaC0I7h6EE1+Vqh4d6DHx/nnJJh5dkAmA6lUm4t3ikh3NxJYy+6juEJgv7075MTxAV//ckBT2kkmot5mIiIiIiISb01pZ8EiZ/MWZ9L4gNEj9T1eOo+ZnQ/8BBgE3G1mC9z9DDMbBtzk7me7e9bMrgLuBRLAze6+pIJh72pfdh+9BVGkI0r70mbG+05PcNapavOTihrs7mvy99cCg9vY/2LgBy22fcvMvgo8CFzj7q2sMBdPm7dCIrlz5FZzddt78oU372dmv7EMrdmLhe1FOllpE1wGHAs8xM61byz/qh1cxzEIjNrajh1DRLqJKUTTFG5n5xf1JDCNKBHfAbUpfdkWEREREakGb6xyvvfTLLkwWucnCEKmTzU+dVmCIND3euk4d78duL3A9reAs5s9vge4p4yhFS8FHArMZ2dbXpDffmB5QlCbn5TantbSa/7A3d3MWl3/zsyGAtOJEtY7fJkoMZYiWkPvS8DXW/n9WcAsgFGjRrXjLyitoYPZbd15gFyQY/XQ1QQYd777OrMGTS1/cCItlDbBBTCOqAF5PtF6N4OJPij7lvyVRUQitUQDxhcCK/KPpwPjKxmUiIiIiIiUi7tz/U1ZtrdYLmHRi86TzzrHHhnPBFc25zz9nPPUcyGJBBx/dMChB5lGtUhpHQIMABYAjUSzohxMhzuIisTFntbSM7O3zWyou6/JJ7DW7eFQHwRud/dMs2PvGP3VZGa/Av7PHuK4kSgJRn19fauJtHKrTRkXnBNw650ZyETLceSCHOmaNIsOeIHAQP1CJC5Kn+ACGAq8ryyvJCJSWB3RyNEOjh4VEREREZHq89Ya2Fpg/d10Gh57KuTYI+O3xk8YOj++IceyFU46v8b5shU5Fr1ofPzD5WnOkW5sTP4m0v3MAS4DZud/3rGHfS8hGrH1D82SY0a0fldVLlh16gkJGvpu4Ya/vkfd9p6sGvYmL0x7gYaeDfQIExy+ZCwPPpYhl4FRRwRMOCUgWausl5SfvhGJiIiIiIiISJeWC4mWTCj4XGw6ze/ixZed15oltyBKyD073zn9JGf4UDUkioiUwGzgj2Z2BfA60SgtzKweuNLdP5l/PIZofOPfW/z+LWY2iOhTZwFwZXnC7nzvn9GPRYNf4xtr5uE4AUYdCW5+8kJeezFJLg29amHbE86SF3JM/0KCQEkuKTMluERERERERESkSxsxDGpT0NS06/ZUDRx1WPxGbwG8+FJIU7rAEw4vvxoyfGii7DGJiHR17r4ROKXA9rnAJ5s9XgkML7DfyaWMr9y+MvRQPjRgAnPeXUmNBZy5fTyLltSQy8CMUQFjBwbs6CfivwUuAPatZMTS3cTzW5yIiIiIiIiISCcJAuNTlyeoTUFNvqtvbQrGjDJOODqeTSO9exvJAt2SgwT06qUe8iIiUh7ja/vyhcEHcdV+0wlerwOD4f2NMfsGJAKjJhHdghzwVyCeA6Oli9IILhERERERERHp8iZPCPj2V42n54a8t9nZf2LAAfsbQRDPZNFRhwXcdW+42/bAYMb0eMYsIiJdW11fsADGDQxIJnb9LDIMmoCNwMCKhCfdUFEJLjM7E7gOSAA3ufvskkYlItJMOszxjTVzuXHDUhrCLGfsM5LvjTia0bV9Kh2aiIiIiIhUkX36GKefVB1T+/XvZ3z6Ewlu/E0u6gzvkErB5/4pQW1KCa7uanuY4aurn+PXG18m4zlm9hvLd0ccxZCanpUOTUS6gSHTjEQKEq0NfvYQbnsWVi2DEfvCWfUwclBZY5Tupc0El5klgOuB04BVwHNmNsfdXyx1cABzF4Tc+bcc774XTR0gIt3Phcvv5YHNq2jwHAC3vbucR7a8xcvTLmFAsq7kr79+o3PbXTmWvuz06AGnnRBw4rFBbHt6ioiIiIhI1zB9asAPv2WseN1JJKJ2EV2HdF/uzumv3MW87etpzF8f//6dV3l4y2peOuASeiVqKhxh297b7Nx+d46Fi52aGjjhmIAzTt59JIiIxFOQNE78YpI3fxXSL+e7l92mDCyeD2EO1r0Li1bCP8+ECcMqEa50A8VMNH04sMzdl7t7GrgVmFnasCIPPZbj5ltyrF4D27bDkpeiCTzfXK2JPEW6i6UNm3ZJbgGEwLYwwy82lD7P/t5m55vfyzL3eWfrNli/Af50Z8j//DnX9i+LiIiIiIh0UDJpTBwfMG6MOtl1d09ve5sFDRv+kdwCyOJsyjVx66ZlFYysOI2Nzje+l+WpZ50tW+GdTXDXvSE3/FrX1yLVpM8QY+oXE9gg8ES+nT4APAsr74uSWwDukM6y+kePcONvs6x5W2360vmKmaJwOPBms8ergCNa7mRms4BZzR53OLjWjBoRzwVgRaTzLWrYSNIC8F2/8DZ4jqe3vl3y13/g7zma0tFn8g7pNDz+tPP+M5y+++gCU0RERERERErvhYaNhL57A/G2MMuz29ZxxcApFYiqeE88G7K9AXLNlpbLZGDxUuettc6wIbq+FqkaCUhcaLCSKHPQA/jdLdC0ebddh2U28ty8kIWLnGv+JcnI4Srr0nmKWoOrGO5+I3AjQH19vc+dO3fHdla+4azbACOHW9EfVhvfcf7921nS6V23//LHKb5wbZoffDP+w65FCill8rcrGl/bl5Ddv8DXWsC0HgOKPs6Wrc7Lrzp1dbD/JCt6+oNXX4NsdvftNUl4a40SXCIiIiIiIlIe42v7kijQAbSnJTmgrn+nvc677zmvLnd69oD9JxqJTpo+8NXlvls7H0AQwBurlOASqToBMC5/A7g1DU2777adFI7RlIY/3pHj6s90WkpCpKgE12pgZLPHI/Lb2rRtu/OD67OsXQdmUQ+NKZOMz3wiQTK55w+t3r13HTHR3MAB+sAT6S4O6TmQaXUDeL5hA2nf2c0rZQmuHHRAUcf420M57rg7JJEALFoI8wufSTJmZNt1yZDBsPx1CMNdt2dzMEB1kYiIdDIz+y/g/UAaeA34uLu/W2C/M4HrgARwk7vPLmecIiIiUn4n9xnO8JpevNb0Htl8R1ADaoMEl+47uVNe446/5vjrAyHJRPQ4lYKrP5tk+NCOX/8OHWwkk16wE+nAfTt8eBGptJMPgnvnQXpnIW8iyQOJ6f94vGKlpimUzlXMXH/PARPNbKyZpYCLgTnFHPw3t+ZYtQaa0tDYFA07XvqKc/f9YZu/W5syjj3SSBUYqHXOGZqiUKS7MDPunXQOF/QbR8oCEhiH9hzEI5NnMjzVu83ff21lyJx7QjLZqB5qbIzW9PvRz7Jkc21/qJ52YuIfX+x3SCZh/Bhj8CAluEREpNPdD0xz9wOBV4Avt9zBzBLA9cBZwFTgEjObWtYoRWSvmNlFZrbEzEIzq9/DfivNbJGZLTCzueWMUUTiKzDj0ckzObvvaGry18dH9RrME5PPp3+ytsPHX/JSyL0PhWR3XD83weYtcN3Ps4Rhxxuljz8qiDqeNpMIYOCA6BpbRKrc2fVw9BS8JkEDNaRJ8FRiEnclD/3HLr3bbsoTaZc2R3C5e9bMrgLuJeoherO7L2nr9zJZZ+FiJ9dinchMBv7+RMjMsxKFf7GZD52fILAcjz3luENt/rP6wAOU4BLpTvomavn9uNPIeI6sOz2C4ocyP/pElNxqKZuDV5Y5Uyfv+Uv08KHGVf+U4Le35ng3P43wjOnGZRe3XYeJiIi0l7vf1+zh08CFBXY7HFjm7ssBzOxWYCbwYukjFJEOWgxcANxQxL4nufuGEscjIlVmv5qe3DHhLNJhjhCnrh3Xx2155PGw4BSC2xpg5ZvOuNEdS0L172dc/dkEv7olx7p87TZlknHFRxNazkGkKwgCuORE7NwjeeQPm3hgSR/ey+5MvqdScNYpateXzlXUp6C73wPc054D53KtTzGYyRR3jGTCuOQDSS6c6TQ0QO9ecN232xOFiHQlNZagpp3feRsaW6mLHJoKzAtcyNTJAd/+qrF1W/RhXJvSF28RESmLTwB/KLB9ONFSzjusAo5o7SBmNguYBTBq1KjOjE9E2sndl4LW5RWRjksFnd/psqGx8Haz4q+f2zJudMA3vhKwdZuTTEJdrepDkS6nVx2nfWwIa/6Q47n5TiIZ5QpOPzHg+KOV4JLOVbIV3epqjeFD4c0Wq3WZwfSp7fvwqkkaNX06MTgRAcDMvkHU4zsE1gGXu/tblY2qcx06I2DJSzmaWvRCy4UwaULxdZGZ0UfDqEVEpBOY2QPAkAJPXevud+T3uRbIArd09PXc/UbgRoD6+npNei9SHRy4z8wcuCFfjkVESuqwg43lr/tuo7g8hHGdPIVg715KbIl0Zcmk8YmPJPngec6770Xr7LWV0HZ33tj+HCu2P0XGGxmQGs3k3qfSOzmwTFFLNSpZggvg8kuSfPcnWXI5yGYhVRNNM3jhuZraSyQm/svd/x3AzD4PfBW4srIhda76GcajTxkrX3ea0lGSvSYJF84M6NVTX6hFRKT83P3UPT1vZpcD5wCnuBcch7waGNns8Yj8NhGJgWKS2EU41t1Xm9l+wP1m9pK7P1rgtTRCU0Q6zdFHBDz2tLNm7c7r52QSPnJRoJlMRGSv9O5l9O5V3L5Lt9zLmw3zCYmmf1v8ciO3Pf0O4ebejB2d5KJzA/r30wgw2VVJE1yjRxrfujbJI0+ErFnrjBtjHHukGpVF4sLdNzd72Iuop2iXkkgY//rpBM+/4MxbGNKzJxx3VIIxI1UPiYhI/JjZmcAXgRPcfXsruz0HTDSzsUSJrYuBD5cpRBFpQ1tJ7CKPsTr/c52Z3U609t5uCS6N0BSRzlSTNK755wRzFzgLFoX06QMnHJ1gxDBdP4tIaaXD7bzZMI+QLAAvP3UEix85ETwAjPUbnOfm5/jMJ5yDD9TgGdmppAkugH59jfPO1kknEldm9i3gY8B7wEmt7FPVPUMTCaP+YKP+YPXyEBGR2PspUEs0YgPgaXe/0syGATe5+9nunjWzq4B7gQRws7svqVzIItKZzKwXELj7lvz904GvVzgsEekmkknjyHrjyHpdP4tI+WzLbiCwBKFnSTfUseTRE8B3zSm4ww2/Drnu2wG1Wr9P8vRpJdLFmdkDZra4wG0mgLtf6+4jidb4uKrQMdz9Rnevd/f6QYMGlTN8ERGRbsXdJ7j7SHefkb9dmd/+lruf3Wy/e9x9kruPd/dvVS5iEWkPMzvfzFYBRwF3m9m9+e3DzOye/G6DgcfNbCHwLHC3u/+tMhGLiIiIlF5doh+h5wDYuHp4q3NMhQ4vvqxB67JTyUdwiUhltWOKlFuAe4D/W8JwRERERES6LXe/Hbi9wPa3gLPz95cDB5U5NBHpBGZ2EfA1YApwuLvPbWW/lcAWIAdk3b2+XDGKiMRRj8Q+DKwdz4am10jVNQKtj9DKheWLS+JPI7hEujEzm9js4UzgpVK/5sZ3nIWLQ95aq94WIiIdsfbtqD5dv1H1qUhc5XLOS6+GLF4a0pRWWRWRzpPJOktfDnnx5ZBMNv71S27tapoemEP6qYfwdFOlwymlxcAFFFgzr4CT8qO1ldwSEQFm9P0AQ+sOYODwtaTqGig0jCsIYOrk0k5PmFu3Jvq5amVJX0c6h0ZwiXRvs81sMhACrwNXluqFwtC5+ZYc8xY4ySTkcjB6pPG5WQl69tC8uSIixWpqcn56U45lK5xkArJZOGia8cmPac1TkTh5bWXIT27Mkc1F/U/DEC7/cMBhB6usikjHLHkp5Oe/yu3S7Pfpjyc4YP/49WF2dxp/8xOa7v9L1CoZBGABvf+/H5CcMLXS4XU6d18KkF9HU0SqUDtGYp4JXEe0Ju5N7j47v30scCuwLzAPuNTd02UIveolrIYD+57HAfucw7R/zvDt7xtNzd65RAIuuzgoWTui57Js/+k3yTwb9VHYcs0VJCZMpfeXvoP16FmS15SOi9+3HxEpG3f/gLtPc/cD3f397r66VK9138Mh8xc6mSw0NEI6Ayted377h1ypXlJEpEv6/Z9zvLrcyWSi+jSThYVLnLvv0zwNInHRlHZ+9LMcW7dBY2NUVpvScPMtIes2xH+khYjE15atzvW/zNHQGNUvO27X35Rjy9b41S/Z55+m6cE5kElDUyM0bIftW9k2+4t42K2vBR24z8zmmdms1nYys1lmNtfM5q5fv76M4Yl0a22OxDSzBHA9cBYwFbjEzHZk7b8D/NDdJwCbgCtKG27Xk7AkI4b04CffSXDZxQGHHQznnGF889okRx1Wus5ijX/5HZnnHos+swDSTeReWcz2X36/ZK8pHacEl4iUxUOPhaQzu27L5mDBC04mE78LMRGROApD5+l5Tja76/ZMBh55XAkukbhYtMTxAl9vwhCefEZlVUT23twFYaEZm3DguefjV780PTgnSmy14Jk0uVcWVyCijjOzB8xscYHbzHYc5lh3P4SocfyzZnZ8oZ3c/UZ3r3f3+kGDBnVK/CKyZ+6+1N1fbmO3w4Fl7r48PzrrVmCmRcM3Twb+lN/vN8B5JQu2iwuCgOOOSvCpy2s47+wkg/Yt7ejY9L23Q8tpdLMZMk8+hLe8CJfY0BSFIlIWjbtf0wDRhVgmAzU1ZQ1HRKQq5cJoitdCmrr0chYi1WV7Q5TMaimXg23b1bFHRPZeQ0PUUbClbDaqe2Kn1fW2DE9X54xd7n5qJxxjdf7nOjO7naixvJh1u0QkHoYDbzZ7vAo4gmhawnfdPdts+/DWDpIfwTkLYNSoUaWJVIrmjdsLPxHmIJuBpFIpcaQRXCJSFlP3NwpNQz5oX+jZU/OTi4gUoyZpjBy2+3Yz2H+S6lKRuJgyyQqO4KpNwYEH6BJMRPbe1MlGssDsTDU1cMDk+H0XSB13OtTW7f6EhyT3P7D8AcWAmfUysz477gOnE02JJiJl0kkjMTtMozTjJTm9nkKNl8GIsVhdjwpEJMXQ1ZWIlMWF70/QswfU5Ds7JAJIpeCyi7XQuohIe3zs4gS1qWiBXYg6kfWogw+dp/pUJC4GDTROOs5IpXZuq03BhHHGAfvHrwFaRKrHmFEBh84walvULwdPN8aOjl8TT80xp5KcPA12NAwmkpCqpednvoKlaisbXAmY2flmtgo4CrjbzO7Nbx9mZvfkdxsMPG5mC4Fngbvd/W+ViVike3L3U/Nr0re83VHkIVYDI5s9HpHfthHoZ2bJFtulCvS49CqsZ2+oyX/IJpJQ14Oes/6tsoHJHmlcnYiUxcB9o8UgH3osZNlyZ9gQOPn4BIMHqZFHRKQ9xowK+I9rjAcfzbHqLRg3OqpP++6j+lQkTi6amWDqZOexp6J1SI88NKD+YCMIVFZFpGM+8ZEEhxzoPPFMiAPHHB4wY3o86xZLJOn1lR+QXfAMmflPYn36kjrxLBKDW52xq6q5++3A7QW2vwWcnb+/HDiozKGJSOd6DphoZmOJElgXAx92dzezh4ELidblugwoNmkmFZYYMpw+P7yFpr/9Gf7nYVJnXEDt2ReS2K/ANCoSG0pwiUjZ9OltzDxLIwxERDpq4L7Gh87X1ziRODMzpk0xpk2J34gKEaluZsbBBxoHH1gd9YsFATWHHEXNIUdVOhQRkTaZ2fnAT4BBRCMxF7j7GWY2DLjJ3c9296yZXQXcCySAm919Sf4QXwJuNbNvAs8Dv6zAnyF7Keg3gB4X/xNcMouel3++0uFIEdQyIiIi0kWZ2eeAzwI5oqlPvljhkERERERERERiq5iRmPnH9wD3FNhvOXB4KWMUkZ2U4BIREemCzOwkYCZwkLs3mdl+lY5JRERERERERESks1THeHYRERFpr08Ds929CcDd11U4HhERERERERERkU6jBJeIiEjXNAk4zsyeMbO/m9lhre1oZrPMbK6ZzV2/fn0ZQxQREREREREREdk7mqJQRESkSpnZA8CQAk9dS/QZPwA4EjgM+KOZjXN3b7mzu98I3AhQX1+/2/MiIiIiIiIiIiJxowSXiIhIlXL3U1t7zsw+DdyWT2g9a2YhMBDQEC0REREREREREal6VqAjd8cParYeeL3TDxwZCGwo0bFLSXGXV5zjHu3ugyodxN4qcfnuqDj/3/dEcZdXqeOORRk3syuBYe7+VTObBDwIjCo0gqvF7+0o43H8/8YtprjFA4qpGB2JJxbluyM6+XM8bv/bYlVr3FC9sVdL3FVdxmP+Pb2QajkvitXV/h7oen+Tynjnqvbzo9rjB/0NzVV1+Yaiy3g1/s+rMWaozrirMWYoLu5Wy3hJElylZGZz3b2+0nG0l+Iur2qNWzqmWv/viru8qjXu9jKzFHAzMANIA//H3R9qx+/H7n2KW0xxiwcUUzHiFk81q9b3slrjhuqNvVrjltLqaudFV/t7oGv+TdJ5qv38qPb4QX9Dd1SN71c1xgzVGXc1xgwdj1tTFIqIiHRB7p4GPlrpOEREREREREREREohqHQAIiIiIiIiIiIiIiIiIu1RjQmuGysdwF5S3OVVrXFLx1Tr/11xl1e1xl1ucXyf4hZT3OIBxVSMuMVTzar1vazWuKF6Y6/WuKW0utp50dX+Huiaf5N0nmo/P6o9ftDf0B1V4/tVjTFDdcZdjTFDB+OuujW4REREREREREREREREpHurxhFcIiIiIiIiIiIiIiIi0o0pwSUiIiIiIiIiIiIiIiJVpWoSXGZ2ppm9bGbLzOyaSsdTDDMbaWYPm9mLZrbEzP650jG1h5klzOx5M7ur0rEUy8z6mdmfzOwlM1tqZkdVOiYpHzP7r/z//gUzu93M+lU6pj1RvVZ+1VivVZqZfS5frpaY2XcrHc8OZna1mbmZDaxwHLGod+JWn8S5rlA90Hnicv7vDTO7KH9uhmZWX+l42hK3Ml4sM7vZzNaZ2eJKxyLxVG1lsTXVWkZbo7Irxajm8lvtZbbay2icrxXipthyFqdz2swGmNn9ZvZq/mf/VvbLmdmC/G1OueNsFsce3zszqzWzP+Sff8bMxlQgzJYxtRXz5Wa2vtn7+8lKxNkipj3WWxb5cf5vesHMDin22FWR4DKzBHA9cBYwFbjEzKZWNqqiZIGr3X0qcCTw2SqJe4d/BpZWOoh2ug74m7vvDxxE9cUvHXM/MM3dDwReAb5c4XhapXqtYqqxXqsYMzsJmAkc5O4HAN+rcEhAdEEEnA68UelYiEG9E9P6JM51heqBzlPx878DFgMXAI9WOpC2xLSMF+vXwJmVDkJirWrKYmuqvIy25teo7ErbqrL8dpEy+2uqu4zG+VohbtosZzE8p68BHnT3icCD+ceFNLj7jPzt3PKFt1OR790VwCZ3nwD8EPhOeaPcVTv+339o9v7eVNYgC/s1e663zgIm5m+zgJ8Ve+CqSHABhwPL3H25u6eBW4ka3GLN3de4+/z8/S1EjSnDKxtVccxsBPA+IA4FoChm1hc4HvglgLun3f3digYlZeXu97l7Nv/waWBEJeNpg+q1MqvGei0GPg3MdvcmAHdfV+F4dvgh8EXAKx1ITOqd2NUnca0rVA90rpic/3vF3Ze6+8uVjqNIsSvjxXL3R4F3Kh2HxFeVlcXWVG0ZbY3KrhSjistv1ZfZai+jcb1WiKMiy1nczumZwG/y938DnFe5UNpUzHvX/O/5E3CKmVkZY2wpbv/vohRRb80EfuuRp4F+Zja0mGNXS4JrOPBms8erqLKKLz988WDgmQqHUqwfETUehhWOoz3GAuuBX+WnHrrJzHpVOiipmE8Af610EHugeq38fkT11WuVNgk4Lj8M/+9mdlilAzKzmcBqd19Y6VgKqFS9E+v6JGZ1xY9QPVAqcf/crWaxLuMiojIqUmVUZmMkZtcK1Spu5/Rgd1+Tv78WGNzKfnVmNtfMnjaz88oT2m6Kee/+sU++c997wL5lia6wYv/fH8hP9fen/Cw4cbfX53GyJOHILsysN/Bn4F/cfXOl42mLmZ0DrHP3eWZ2YoXDaY8kcAjwOXd/xsyuIxoG+++VDUs6k5k9AAwp8NS17n5Hfp9riYa831LO2LoT1Wtdx57KFFG9OoBo2ojDgD+a2Th3L+nIqTZi+grR9IRlo3pn78WprlA9sHeq+fwvJnYRKT2VRZHqpfIrpRSna4VKqsZy1sY1+z+4u5tZa+0Ho919tZmNAx4ys0Xu/lpnx9pN3Qn83t2bzOxTRCPQTq5wTCVTLQmu1UDzTOOI/LbYM7Maosr6Fne/rdLxFOkY4FwzOxuoA/Yxs9+5+0crHFdbVgGr3H1Hr48/0fo8r1Kl3P3UPT1vZpcD5wCnlLoRvoNUr5VXtdZrJbenMmVmnwZuy5elZ80sBAYSjZYte0xmNp1otO7C/IwAI4D5Zna4u68tdzzN4rqcytY7saxPYlhXqB7YC1Vw/reqrdirSCzLuEixulBZbI3KqHRZXbT8qszGQAyvFSqmE8pZ2c/pNtoR3jazoe6+Jj/FXMGlDtx9df7ncjN7hGgkX7kTXMW8dzv2WWVmSaAvsLE84RXUZszu3jy+m4DvliGujtrr87hapih8DphoZmPNLAVcDMypcExtys/H+Utgqbv/oNLxFMvdv+zuI9x9DNF7/VA1NP7kGzffNLPJ+U2nAC9WMCQpMzM7k2jqqXPdfXul42mD6rUyqtZ6LQb+ApwEYGaTgBSwoVLBuPsid9/P3cfk/5ergENKmdxqS0zqndjVJ3GsK1QPdL6YnP/dQezKuIjsQmVUpLqozFZYHK8Vqlzczuk5wGX5+5cBu41CM7P+Zlabvz+QqDNiJdpwi3nvmv89FxJdR1ayY1+bMbdYu+pconXu4m4O8DGLHAm812yqyz2qigRXfn7Lq4B7if4hf3T3JZWNqijHAJcCJ5vZgvzt7EoH1cV9DrjFzF4AZgD/WdlwpMx+CvQB7s+Xt59XOqDWqF6TKnEzMM7MFhMtXHpZ3EZoxEDF652Y1ieqK7qHip//e8vMzjezVcBRwN1mdm+lY2pNTMt4Uczs98BTwGQzW2VmV1Q6JomXaiqLranmMtoalV0pRrWW365QZrtAGdW1QpFaK2dmNszM7oFYntOzgdPM7FXg1PxjzKzezG7K7zMFmGtmC4GHgdnuXvYEV2vvnZl93czOze/2S2BfM1sG/CsVni2syJg/b2ZL8u/v54HLKxPtToXqLTO70syuzO9yD7AcWAb8AvhM0cdWO5WIiIiIiIiIiIiIiIhUk6oYwSUiIiIiIiIiIiIiIiKygxJcIiIiIiIiIiIiIiIiUlWU4BIREREREREREREREZGqogSXiIiIiIiIiIiIiIiIVBUluERERERERERERERERKSqKMElIiIiIiIiIiIiIiIiVUUJLhEREREREREREREREakq/w9FYGa+W9/5RQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1728x288 with 7 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# zero mean the data (Centering)\n",
    "d_centered = data - np.mean(data, axis=0)\n",
    "# compute the covariance matrix\n",
    "cov = np.cov(d_centered.T)\n",
    "# eigen decomposition\n",
    "eig_vals, eig_vecs = np.linalg.eig(cov)\n",
    "# Features in pca space\n",
    "features = np.dot(d_centered, eig_vecs)\n",
    "# PCA Whitened data\n",
    "eps = 1e-5\n",
    "lmd_t = np.diag((eig_vals+eps)**(-0.5))\n",
    "w_pca = (lmd_t @ eig_vecs.T @ d_centered.T).T\n",
    "\n",
    "# ZCA Whitened data\n",
    "w_zca = (eig_vecs @ lmd_t @ eig_vecs.T @ d_centered.T).T\n",
    "\n",
    "# normalize the data by its standard deviation\n",
    "normed = d_centered / np.std(d_centered, axis=0)\n",
    "\n",
    "# L2 normalize the data\n",
    "l2_normed = d_centered / np.linalg.norm(d_centered, axis=1, keepdims=True)\n",
    "\n",
    "# create subplots to plot hte original, centered, pca space, pca whitened data\n",
    "fig, ax = plt.subplots(1, 7, figsize=(24, 4))\n",
    "ax[0].scatter(data[:, 0], data[:, 1], c=c)\n",
    "ax[0].set_title('Original Data')\n",
    "ax[1].scatter(d_centered[:, 0], d_centered[:, 1], c=c)\n",
    "ax[1].set_title('Centered Data')\n",
    "ax[2].scatter(features[:, 0], features[:, 1], c=c)\n",
    "ax[2].set_title('PCA Data')\n",
    "\n",
    "ax[3].scatter(w_pca[:, 0], w_pca[:, 1], c=c)\n",
    "ax[3].set_title('PCA Whitened Data')\n",
    "\n",
    "ax[4].scatter(w_zca[:, 0], w_zca[:, 1], c=c)\n",
    "ax[4].set_title('ZCA Whitened Data')\n",
    "\n",
    "ax[5].scatter(normed[:, 0], normed[:, 1], c=c)\n",
    "ax[5].set_title('Normalized Data (like BatchNorm)')\n",
    "\n",
    "ax[6].scatter(l2_normed[:, 0], l2_normed[:, 1], c=c)\n",
    "ax[6].set_title('L2 Normalized Data')\n",
    "\n",
    "for a in ax:\n",
    "    a.axhline(0, color='black', lw=1)\n",
    "    a.axvline(0, color='black', lw=1)\n",
    "    a.set_xlim(a.get_ylim())\n",
    "\n",
    "plt.tight_layout()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[-0.85065081 -0.52573111]\n",
      " [ 0.52573111 -0.85065081]] \n",
      " [-0.23606798  4.23606798]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.7/site-packages/ipykernel_launcher.py:7: RuntimeWarning: covariance is not positive-semidefinite.\n",
      "  import sys\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.lines.Line2D at 0x7fd52fbefa50>"
      ]
     },
     "execution_count": 69,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# generate 25 random points sampled from a correlated 2d Gaussian\n",
    "np.random.seed(0)\n",
    "n = 25\n",
    "mean = [1, 3]\n",
    "cov = [[1,   2], \n",
    "       [2,   3]]\n",
    "x, y = np.random.multivariate_normal(mean, cov, n).T\n",
    "data = np.vstack((x, y)).T\n",
    "\n",
    "eigval, eigvec = np.linalg.eig(cov)\n",
    "print(eigvec, \"\\n\",eigval)\n",
    "# eigvec = eigvec * eigval[..., None] \n",
    "# Normalizing eigenvectors for plotting\n",
    "for i in range(len(eigval)):\n",
    "    eigvec[:, i] = eigvec[:, i] / np.linalg.norm(eigvec[:, i]) * np.sqrt(np.abs(eigval[i])) * np.sign(eigval[i])\n",
    "\n",
    "c = palette + [palette[0]]* (n - len(palette))\n",
    "plt.scatter(data[:, 0], data[:, 1], c=c)\n",
    "plt.quiver(mean[0], mean[1], eigvec[0, 0], eigvec[1, 0], color=palette[1], scale=7)\n",
    "plt.quiver(mean[0], mean[1], eigvec[0, 1], eigvec[1, 1], color=palette[2], scale=7)\n",
    "plt.axis('equal')\n",
    "# remove box and axes\n",
    "plt.axis('off')\n",
    "# add spines\n",
    "plt.axhline(0, color='black',linewidth=0.75)\n",
    "plt.axvline(0, color='black',linewidth=0.75)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1728x288 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "lw = 0.01\n",
    "scale = 8\n",
    "c = palette + [palette[0]]* (n - len(palette))\n",
    "# c = palette[0]\n",
    "\n",
    "# zero mean the data (Centering)\n",
    "d_centered = data - np.mean(data, axis=0)\n",
    "# compute the covariance matrix\n",
    "cov = np.cov(d_centered.T)\n",
    "# eigen decomposition\n",
    "eig_vals, eig_vecs = np.linalg.eig(cov)\n",
    "# Features in pca space\n",
    "features = np.dot(d_centered, eig_vecs)\n",
    "# PCA Whitened data\n",
    "eps = 1e-5\n",
    "lmd_t = np.diag((eig_vals+eps)**(-0.5))\n",
    "w_pca = (lmd_t @ eig_vecs.T @ d_centered.T).T\n",
    "\n",
    "# ZCA Whitened data\n",
    "w_zca = (eig_vecs @ lmd_t @ eig_vecs.T @ d_centered.T).T\n",
    "\n",
    "# normalize the data by its standard deviation\n",
    "normed = d_centered / np.std(d_centered, axis=0)\n",
    "\n",
    "# create subplots to plot hte original, centered, pca space, pca whitened data\n",
    "fig, ax = plt.subplots(1, 4, figsize=(24, 4), sharex=True, sharey=True)\n",
    "\n",
    "# Normalizing eigenvectors for plotting\n",
    "ev1 = eig_vecs.copy()\n",
    "for i in range(len(eigval)):\n",
    "    ev1[:, i] = ev1[:, i] / np.linalg.norm(ev1[:, i]) * np.sqrt(np.abs(eig_vals[i])) * np.sign(eig_vals[i])\n",
    "    \n",
    "ax[0].set_title('X_centered')\n",
    "ax[0].scatter(d_centered[:, 0], d_centered[:, 1],c=c)\n",
    "ax[0].quiver(0,0, ev1[0, 0], ev1[1, 0], color=palette[1], scale=scale, width=lw)\n",
    "ax[0].quiver(0,0, ev1[0, 1], ev1[1, 1], color=palette[2], scale=scale, width=lw)\n",
    "\n",
    "ax[1].set_title('PCA Data')\n",
    "ax[1].scatter(features[:, 0], features[:, 1],c=c)\n",
    "ev2 = np.dot(ev1.T, eig_vecs).T\n",
    "ax[1].quiver(0,0, ev2[0, 0], ev2[1, 0], color=palette[1], scale=scale, width=lw)\n",
    "ax[1].quiver(0,0, ev2[0, 1], ev2[1, 1], color=palette[2], scale=scale, width=lw)\n",
    "\n",
    "ax[2].set_title('PCA Whitened Data')\n",
    "ax[2].scatter(w_pca[:, 0], w_pca[:, 1],c=c)\n",
    "ev3 = (lmd_t @ ev2)\n",
    "ax[2].quiver(0,0, ev3[0, 0], ev3[1, 0], color=palette[1], scale=scale, width=lw)\n",
    "ax[2].quiver(0,0, ev3[0, 1], ev3[1, 1], color=palette[2], scale=scale, width=lw)\n",
    "\n",
    "ax[3].set_title('ZCA Whitened Data')\n",
    "ax[3].scatter(w_zca[:, 0], w_zca[:, 1],c=c)\n",
    "ev4 = (eig_vecs @ ev3)\n",
    "ax[3].quiver(0,0, ev4[0, 0], ev4[1, 0], color=palette[1], scale=scale, width=lw)\n",
    "ax[3].quiver(0,0, ev4[0, 1], ev4[1, 1], color=palette[2], scale=scale, width=lw)\n",
    "\n",
    "for a in ax:\n",
    "    a.axhline(0, color='#717E8E', lw=1, zorder=0.1)\n",
    "    a.axvline(0, color='#717E8E', lw=1, zorder=0.1)\n",
    "    a.set_xlim(a.get_ylim())\n",
    "\n",
    "    # remove box and axes\n",
    "    a.axis('off')\n",
    "\n",
    "plt.savefig('whitening.pdf', dpi=600, bbox_inches='tight')\n",
    "# plt.tight_layout()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Iternorm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {},
   "outputs": [],
   "source": [
    "\"\"\"\n",
    "Reference:  Iterative Normalization: Beyond Standardization towards Efficient Whitening, CVPR 2019\n",
    "\n",
    "- Paper:\n",
    "- Code: https://github.com/huangleiBuaa/IterNorm\n",
    "\"\"\"\n",
    "import torch.nn\n",
    "from torch.nn import Parameter\n",
    "\n",
    "# import extension._bcnn as bcnn\n",
    "\n",
    "__all__ = ['iterative_normalization', 'IterNorm']\n",
    "\n",
    "\n",
    "# A wrapper class around the backbone to that adds an extra layer to it and exposes all atributes and methods of the backbone\n",
    "class IterNormBackBoneWrapper(torch.nn.Module):\n",
    "    def __init__(self, backbone):\n",
    "        super().__init__()\n",
    "        self.backbone = backbone\n",
    "        self.iternorm = IterNorm(backbone.num_features)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.backbone(x)\n",
    "        x = self.iternorm(x)\n",
    "        return x\n",
    "\n",
    "    @property\n",
    "    def num_features(self):\n",
    "        return self.backbone.num_features\n",
    "    \n",
    "    # def __getattr__(self, name):\n",
    "    #     return getattr(self.backbone, name)\n",
    "\n",
    "#\n",
    "# class iterative_normalization(torch.autograd.Function):\n",
    "#     @staticmethod\n",
    "#     def forward(ctx, *inputs):\n",
    "#         result = bcnn.iterative_normalization_forward(*inputs)\n",
    "#         ctx.save_for_backward(*result[:-1])\n",
    "#         return result[-1]\n",
    "#\n",
    "#     @staticmethod\n",
    "#     def backward(ctx, *grad_outputs):\n",
    "#         grad, = grad_outputs\n",
    "#         grad_input = bcnn.iterative_normalization_backward(grad, ctx.saved_variables)\n",
    "#         return grad_input, None, None, None, None, None, None, None\n",
    "\n",
    "\n",
    "class iterative_normalization_py(torch.autograd.Function):\n",
    "    @staticmethod\n",
    "    def forward(ctx, *args, **kwargs):\n",
    "        X, running_mean, running_wmat, nc, ctx.T, eps, momentum, training = args\n",
    "        # change NxCxHxW to (G x D) x(NxHxW), i.e., g*d*m\n",
    "        ctx.g = X.size(1) // nc\n",
    "        x = X.transpose(0, 1).contiguous().view(ctx.g, nc, -1)\n",
    "        _, d, m = x.size()\n",
    "        saved = []\n",
    "        if training:\n",
    "            # calculate centered activation by subtracted mini-batch mean\n",
    "            mean = x.mean(-1, keepdim=True)\n",
    "            xc = x - mean\n",
    "            saved.append(xc)\n",
    "            # calculate covariance matrix\n",
    "            P = [None] * (ctx.T + 1)\n",
    "            P[0] = torch.eye(d).to(X).expand(ctx.g, d, d)\n",
    "            Sigma = torch.baddbmm(eps, P[0], 1. / m, xc, xc.transpose(1, 2))\n",
    "            # reciprocal of trace of Sigma: shape [g, 1, 1]\n",
    "            rTr = (Sigma * P[0]).sum((1, 2), keepdim=True).reciprocal_()\n",
    "            saved.append(rTr)\n",
    "            Sigma_N = Sigma * rTr\n",
    "            saved.append(Sigma_N)\n",
    "            for k in range(ctx.T):\n",
    "                P[k + 1] = torch.baddbmm(1.5, P[k], -0.5, torch.matrix_power(P[k], 3), Sigma_N)\n",
    "            saved.extend(P)\n",
    "            wm = P[ctx.T].mul_(rTr.sqrt())  # whiten matrix: the matrix inverse of Sigma, i.e., Sigma^{-1/2}\n",
    "            running_mean.copy_(momentum * mean + (1. - momentum) * running_mean)\n",
    "            running_wmat.copy_(momentum * wm + (1. - momentum) * running_wmat)\n",
    "        else:\n",
    "            xc = x - running_mean\n",
    "            wm = running_wmat\n",
    "        xn = wm.matmul(xc)\n",
    "        Xn = xn.view(X.size(1), X.size(0), *X.size()[2:]).transpose(0, 1).contiguous()\n",
    "        ctx.save_for_backward(*saved)\n",
    "        return Xn\n",
    "\n",
    "    @staticmethod\n",
    "    def backward(ctx, *grad_outputs):\n",
    "        grad, = grad_outputs\n",
    "        saved = ctx.saved_variables\n",
    "        xc = saved[0]  # centered input\n",
    "        rTr = saved[1]  # trace of Sigma\n",
    "        sn = saved[2].transpose(-2, -1)  # normalized Sigma\n",
    "        P = saved[3:]  # middle result matrix,\n",
    "        g, d, m = xc.size()\n",
    "\n",
    "        g_ = grad.transpose(0, 1).contiguous().view_as(xc)\n",
    "        g_wm = g_.matmul(xc.transpose(-2, -1))\n",
    "        g_P = g_wm * rTr.sqrt()\n",
    "        wm = P[ctx.T]\n",
    "        g_sn = 0\n",
    "        for k in range(ctx.T, 1, -1):\n",
    "            P[k - 1].transpose_(-2, -1)\n",
    "            P2 = P[k - 1].matmul(P[k - 1])\n",
    "            g_sn += P2.matmul(P[k - 1]).matmul(g_P)\n",
    "            g_tmp = g_P.matmul(sn)\n",
    "            g_P.baddbmm_(1.5, -0.5, g_tmp, P2)\n",
    "            g_P.baddbmm_(1, -0.5, P2, g_tmp)\n",
    "            g_P.baddbmm_(1, -0.5, P[k - 1].matmul(g_tmp), P[k - 1])\n",
    "        g_sn += g_P\n",
    "        # g_sn = g_sn * rTr.sqrt()\n",
    "        g_tr = ((-sn.matmul(g_sn) + g_wm.transpose(-2, -1).matmul(wm)) * P[0]).sum((1, 2), keepdim=True) * P[0]\n",
    "        g_sigma = (g_sn + g_sn.transpose(-2, -1) + 2. * g_tr) * (-0.5 / m * rTr)\n",
    "        # g_sigma = g_sigma + g_sigma.transpose(-2, -1)\n",
    "        g_x = torch.baddbmm(wm.matmul(g_ - g_.mean(-1, keepdim=True)), g_sigma, xc)\n",
    "        grad_input = g_x.view(grad.size(1), grad.size(0), *grad.size()[2:]).transpose(0, 1).contiguous()\n",
    "        return grad_input, None, None, None, None, None, None, None\n",
    "\n",
    "\n",
    "class IterNorm(torch.nn.Module):\n",
    "    def __init__(self, num_features, num_groups=1, num_channels=None, T=5, dim=4, eps=1e-5, momentum=0.1, affine=True,\n",
    "                 *args, **kwargs):\n",
    "        super(IterNorm, self).__init__()\n",
    "        # assert dim == 4, 'IterNorm is not support 2D'\n",
    "        self.T = T\n",
    "        self.eps = eps\n",
    "        self.momentum = momentum\n",
    "        self.num_features = num_features\n",
    "        self.affine = affine\n",
    "        self.dim = dim\n",
    "        if num_channels is None:\n",
    "            num_channels = (num_features - 1) // num_groups + 1\n",
    "        num_groups = num_features // num_channels\n",
    "        while num_features % num_channels != 0:\n",
    "            num_channels //= 2\n",
    "            num_groups = num_features // num_channels\n",
    "        assert num_groups > 0 and num_features % num_groups == 0, \"num features={}, num groups={}\".format(num_features,\n",
    "            num_groups)\n",
    "        self.num_groups = num_groups\n",
    "        self.num_channels = num_channels\n",
    "        shape = [1] * dim\n",
    "        shape[1] = self.num_features\n",
    "        if self.affine:\n",
    "            self.weight = Parameter(torch.Tensor(*shape))\n",
    "            self.bias = Parameter(torch.Tensor(*shape))\n",
    "        else:\n",
    "            self.register_parameter('weight', None)\n",
    "            self.register_parameter('bias', None)\n",
    "\n",
    "        self.register_buffer('running_mean', torch.zeros(num_groups, num_channels, 1))\n",
    "        # running whiten matrix\n",
    "        self.register_buffer('running_wm', torch.eye(num_channels).expand(num_groups, num_channels, num_channels).clone())\n",
    "        self.reset_parameters()\n",
    "\n",
    "    def reset_parameters(self):\n",
    "        # self.reset_running_stats()\n",
    "        if self.affine:\n",
    "            torch.nn.init.ones_(self.weight)\n",
    "            torch.nn.init.zeros_(self.bias)\n",
    "\n",
    "    def forward(self, X: torch.Tensor):\n",
    "        X_hat = iterative_normalization_py.apply(X, self.running_mean, self.running_wm, self.num_channels, self.T,\n",
    "                                                 self.eps, self.momentum, self.training)\n",
    "        # affine\n",
    "        if self.affine:\n",
    "            return X_hat * self.weight + self.bias\n",
    "        else:\n",
    "            return X_hat\n",
    "\n",
    "    def extra_repr(self):\n",
    "        return '{num_features}, num_channels={num_channels}, T={T}, eps={eps}, ' \\\n",
    "               'momentum={momentum}, affine={affine}'.format(**self.__dict__)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "IterNorm(64, num_channels=8, T=10, eps=1e-05, momentum=1, affine=False)\n",
      "tensor([[ 9.9999e-01,  7.8556e-07, -4.3565e-07,  ...,  1.1553e-01,\n",
      "         -8.5275e-03,  1.0159e-01],\n",
      "        [ 7.8556e-07,  9.9999e-01, -3.8678e-07,  ...,  1.9275e-02,\n",
      "          3.8102e-02, -7.5649e-02],\n",
      "        [-4.3565e-07, -3.8678e-07,  9.9999e-01,  ..., -4.4938e-02,\n",
      "         -1.0736e-01,  1.1400e-02],\n",
      "        ...,\n",
      "        [ 1.1553e-01,  1.9275e-02, -4.4938e-02,  ...,  9.9999e-01,\n",
      "         -1.6817e-07,  1.5840e-06],\n",
      "        [-8.5275e-03,  3.8102e-02, -1.0736e-01,  ..., -1.6817e-07,\n",
      "          9.9999e-01, -1.7159e-06],\n",
      "        [ 1.0159e-01, -7.5649e-02,  1.1400e-02,  ...,  1.5840e-06,\n",
      "         -1.7159e-06,  9.9999e-01]], grad_fn=<DivBackward0>)\n",
      "x grad torch.Size([128, 64])\n",
      "tensor([[ 9.9999e-01,  7.8556e-07, -4.3565e-07,  ...,  1.1553e-01,\n",
      "         -8.5275e-03,  1.0159e-01],\n",
      "        [ 7.8556e-07,  9.9999e-01, -3.8678e-07,  ...,  1.9275e-02,\n",
      "          3.8102e-02, -7.5649e-02],\n",
      "        [-4.3565e-07, -3.8678e-07,  9.9999e-01,  ..., -4.4938e-02,\n",
      "         -1.0736e-01,  1.1400e-02],\n",
      "        ...,\n",
      "        [ 1.1553e-01,  1.9275e-02, -4.4938e-02,  ...,  9.9999e-01,\n",
      "         -1.6817e-07,  1.5840e-06],\n",
      "        [-8.5275e-03,  3.8102e-02, -1.0736e-01,  ..., -1.6817e-07,\n",
      "          9.9999e-01, -1.7159e-06],\n",
      "        [ 1.0159e-01, -7.5649e-02,  1.1400e-02,  ...,  1.5840e-06,\n",
      "         -1.7159e-06,  9.9999e-01]], grad_fn=<DivBackward0>)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.7/site-packages/ipykernel_launcher.py:89: DeprecationWarning: 'saved_variables' is deprecated; use 'saved_tensors'\n"
     ]
    }
   ],
   "source": [
    "ItN = IterNorm(64, num_groups=8, T=10, momentum=1, affine=False)\n",
    "print(ItN)\n",
    "ItN.train()\n",
    "#x = torch.randn(32, 64, 14, 14)\n",
    "x = torch.randn(128, 64)\n",
    "x.requires_grad_()\n",
    "y = ItN(x)\n",
    "z = y.transpose(0, 1).contiguous().view(x.size(1), -1)\n",
    "print(z.matmul(z.t()) / z.size(1))\n",
    "\n",
    "y.sum().backward()\n",
    "print('x grad', x.grad.size())\n",
    "\n",
    "ItN.eval()\n",
    "y = ItN(x)\n",
    "z = y.transpose(0, 1).contiguous().view(x.size(1), -1)\n",
    "print(z.matmul(z.t()) / z.size(1))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
