{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 22773,
     "status": "ok",
     "timestamp": 1611607913488,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "-4GgqKUXarDX",
    "outputId": "8bc4724c-5ae9-462d-ba37-edbf06e34378"
   },
   "outputs": [],
   "source": [
    "import autograd.numpy as np\n",
    "from autograd import grad\n",
    "from autograd.numpy import log, sqrt, sin, cos, exp, pi, prod\n",
    "from autograd.numpy.random import normal, uniform\n",
    "from scipy.spatial.distance import pdist, squareform\n",
    "\n",
    "import matplotlib as mpl\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from matplotlib import cm\n",
    "import imageio\n",
    "import os\n",
    "from google.colab import drive\n",
    "drive.mount('/content/drive')\n",
    "\n",
    "path = \"/content/drive/My Drive\"\n",
    "\n",
    "os.chdir(path)\n",
    "os.listdir(path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "bERjdmuWauTq"
   },
   "outputs": [],
   "source": [
    "np.set_printoptions(precision=3)\n",
    "np.set_printoptions(suppress=True)\n",
    "np.random.seed(2021)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "Tw_DqaifawVn"
   },
   "outputs": [],
   "source": [
    "def mixture(x):\n",
    "    energy = ((x[0]**2 + x[1]**2)/10 - (cos(2.0*pi*x[0]) + cos(2.0*pi*x[1]))) / 0.5 # 2\n",
    "    regularizer = ((x[0]**2 + x[1]**2) > 20) * ((x[0]**2 + x[1]**2) - 20)\n",
    "    return -(energy + regularizer)\n",
    "\n",
    "\n",
    "def mixture_expand(x, y): return -mixture([x, y])\n",
    "def function_plot(x, y): return np.exp(mixture([x, y]))\n",
    "\n",
    "lower, upper = -2.5, 2.5\n",
    "axis_x = np.linspace(lower, upper, 500)\n",
    "axis_y = np.linspace(lower, upper, 500)\n",
    "axis_X, axis_Y = np.meshgrid(axis_x, axis_y)\n",
    "\n",
    "energy_grid = mixture_expand(axis_X, axis_Y)\n",
    "prob_grid = function_plot(axis_X, axis_Y)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "QpT1SH6bayKO"
   },
   "source": [
    "# Build SVGD *Sampler*"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "SYAeyQSzc12i"
   },
   "outputs": [],
   "source": [
    "class Sampler:\n",
    "    def __init__(self, f=None, xinit=None, lr=1e-3, alpha = 0.9, debug = False):\n",
    "        self.f = f\n",
    "        self.lr = lr\n",
    "        self.debug = debug\n",
    "        self.alpha = alpha\n",
    "        self.historical_grad = 0\n",
    "      \n",
    "         \n",
    "        # initialization for SGLD\n",
    "        self.x = np.array(xinit)\n",
    "        \n",
    "    def svgd_kernel(self, theta, h = -1):\n",
    "        sq_dist = pdist(theta)\n",
    "        pairwise_dists = squareform(sq_dist)**2\n",
    "        if h < 0: # if h < 0, using median trick\n",
    "            h = np.median(pairwise_dists)  \n",
    "            h = np.sqrt(0.5 * h / np.log(theta.shape[0]+1))\n",
    "\n",
    "        # compute the rbf kernel\n",
    "        Kxy = np.exp( -pairwise_dists / h**2 / 2)\n",
    "\n",
    "        dxkxy = -np.matmul(Kxy, theta)\n",
    "        sumkxy = np.sum(Kxy, axis=1)\n",
    "        for i in range(theta.shape[1]):\n",
    "            dxkxy[:, i] = dxkxy[:,i] + np.multiply(theta[:,i],sumkxy)\n",
    "        dxkxy = dxkxy / (h**2)\n",
    "        return (Kxy, dxkxy)\n",
    "    \n",
    "    def grad(self, beta):  return grad(self.f)(beta)\n",
    "\n",
    "    def svgd_step(self, iter):  \n",
    "        # Check input\n",
    "        if self.x is None or self.f is None:\n",
    "            raise ValueError('x0 or lnprob cannot be None!')\n",
    "        \n",
    "        # adagrad with momentum\n",
    "        fudge_factor = 1e-6\n",
    "        if self.debug and (iter+1) % 1000 == 0:\n",
    "            print('iter ' + str(iter+1))\n",
    "        \n",
    "        lnpgrad = np.array([self.grad(self.x[i]) for i in range(self.x.shape[0])])\n",
    "        \n",
    "        # calculating the kernel matrix\n",
    "        kxy, dxkxy = self.svgd_kernel(self.x, h = -1)  \n",
    "        grad_x = (np.matmul(kxy, lnpgrad) + dxkxy) / self.x.shape[0]  \n",
    "        \n",
    "        # adagrad \n",
    "        if iter == 0:\n",
    "            self.historical_grad = self.historical_grad + grad_x ** 2\n",
    "        else:\n",
    "            self.historical_grad = self.alpha * self.historical_grad + (1 - self.alpha) * (grad_x ** 2)\n",
    "        adj_grad = np.divide(grad_x, fudge_factor+np.sqrt(self.historical_grad))\n",
    "        self.x += self.lr * adj_grad \n",
    "     "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "7oVLJQNXfe22"
   },
   "source": [
    "call our sampler"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "iKpmE9FsfXAv"
   },
   "outputs": [],
   "source": [
    "xinit = np.random.uniform([lower, lower], [upper, upper], [500, 2])\n",
    "sampler = Sampler(f=mixture, xinit=xinit, lr=3e-3, alpha = 0.9)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "krpPIdd_fibA"
   },
   "outputs": [],
   "source": [
    "warm_up = -1\n",
    "svgd_x = np.array([sampler.x])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000,
     "output_embedded_package_id": "1FnjcTrv1E_xypeqUkf20-b09LnCQyXTN"
    },
    "executionInfo": {
     "elapsed": 24930399,
     "status": "ok",
     "timestamp": 1611632914489,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "DTBSjSMAftWl",
    "outputId": "b46fdecf-c8b4-4e3f-f859-9d72c7620e10"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Output hidden; open in https://colab.research.google.com to view."
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "my_images3 = []\n",
    "svgd_x_path = []\n",
    "PATH = 'anonymous/Contour-Stochastic-Gradient-Langevin-Dynamics/SVGD_result/'\n",
    "if not os.path.isdir(PATH):\n",
    "    try:\n",
    "        os.makedirs(PATH)\n",
    "    except OSError as exc:  # Python >2.5\n",
    "        if exc.errno == errno.EEXIST and os.path.isdir(PATH):\n",
    "            pass\n",
    "        else:\n",
    "            raise\n",
    "\n",
    "for iters in range(int(5e4)):\n",
    "    sampler.svgd_step(iters)\n",
    "    if iters > warm_up:\n",
    "        # save the sampels\n",
    "        svgd_x_path.append(sampler.x)\n",
    "        if iters % 1000 == 0:\n",
    "            fig3 = plt.figure(figsize=(4, 4))\n",
    "            plt.contour(axis_X, axis_Y, prob_grid, 10)\n",
    "            plt.yticks([-4, -2, 0, 2, 4]) \n",
    "            plt.scatter(sampler.x[:,0], sampler.x[:,1], marker='.', s=3, color='k', label=\"Iteration=\"+str(iters)) \n",
    "            plt.legend(loc=\"upper left\", prop={'size': 10})\n",
    "            plt.xlim([lower, upper])\n",
    "            plt.ylim([lower, upper])\n",
    "            # plt.tight_layout()\n",
    "            plt.show()\n",
    "            fig3.canvas.draw()\n",
    "            image3 = np.frombuffer(fig3.canvas.tostring_rgb(), dtype='uint8').reshape(fig3.canvas.get_width_height()[::-1] + (3,))\n",
    "            my_images3.append(image3)\n",
    "            plt.close('all')\n",
    "\n",
    "               \n",
    "          \n",
    "\n",
    "imageio.mimsave(PATH+'single_SVGD_contour_'+str(sampler.lr)+'.gif', my_images3, fps=50)      \n",
    "# imageio.mimsave(PATH+'CSGLD_PDF'+str(zeta)+\"_\"+str(psampler.lr)+\"_\"+str(psampler.T)+'.gif', my_images4, fps=50)\n",
    "\n",
    "# save the sampels\n",
    "import pickle\n",
    "f = open(PATH + 'single_SVGD_samples.txt', 'wb')\n",
    "pickle.dump(svgd_x_path, f)\n",
    "f.close()            "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 323
    },
    "executionInfo": {
     "elapsed": 2091,
     "status": "ok",
     "timestamp": 1611633908005,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "gynXQJrFn_6R",
    "outputId": "385e1947-1fb4-4a09-93af-98bc6b8838b3"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.6/dist-packages/seaborn/_decorators.py:43: FutureWarning: Pass the following variable as a keyword arg: y. From version 0.12, the only valid positional argument will be `data`, and passing other arguments without an explicit keyword will result in an error or misinterpretation.\n",
      "  FutureWarning\n",
      "/usr/local/lib/python3.6/dist-packages/seaborn/distributions.py:1657: FutureWarning: The `bw` parameter is deprecated in favor of `bw_method` and `bw_adjust`. Using 0.15 for `bw_method`, but please see the docs for the new parameters and update your code.\n",
      "  warnings.warn(msg, FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 540x226.8 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light",
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(7.5, 3.15))\n",
    "plt.subplot(1, 2, 1).set_title('(a) Ground truth')\n",
    "sns.heatmap(prob_grid, cmap=\"Blues\", cbar=False, xticklabels=False, yticklabels=False).invert_yaxis()\n",
    "\n",
    "warm_sample = 0\n",
    "split_ = 1\n",
    "svgd_x = svgd_x.reshape(-1,2)\n",
    "plt.subplot(1, 2, 2).set_title('(b) SVGD')\n",
    "ax = sns.kdeplot(sampler.x[:,0], sampler.x[:,1],  cmap=\"Blues\", shade=True, thresh=0.05, bw=0.15)\n",
    "ax.set_xlim(lower, upper)\n",
    "ax.set_ylim(lower, upper)\n",
    "plt.savefig(PATH+\"SVGD.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 307
    },
    "executionInfo": {
     "elapsed": 1436,
     "status": "ok",
     "timestamp": 1611634002632,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "rPSrTkq13gfv",
    "outputId": "1ebe84a8-c796-487a-bb99-d68c6dc0c1a2"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.6/dist-packages/seaborn/_decorators.py:43: FutureWarning: Pass the following variable as a keyword arg: y. From version 0.12, the only valid positional argument will be `data`, and passing other arguments without an explicit keyword will result in an error or misinterpretation.\n",
      "  FutureWarning\n",
      "/usr/local/lib/python3.6/dist-packages/seaborn/distributions.py:1657: FutureWarning: The `bw` parameter is deprecated in favor of `bw_method` and `bw_adjust`. Using 0.15 for `bw_method`, but please see the docs for the new parameters and update your code.\n",
      "  warnings.warn(msg, FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 226.8x226.8 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light",
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "PATH = 'anonymous/Contour-Stochastic-Gradient-Langevin-Dynamics/'\n",
    "fig = plt.figure(figsize=(3.15, 3.15))\n",
    "\n",
    "warm_sample = 0\n",
    "split_ = 1\n",
    "svgd_x = svgd_x.reshape(-1,2)\n",
    "plt.subplot(1, 1, 1)\n",
    "ax = sns.kdeplot(sampler.x[:,0], sampler.x[:,1],  cmap=\"Blues\", shade=True, thresh=0.05, bw=0.15)\n",
    "ax.set_xlim(lower, upper)\n",
    "ax.set_ylim(lower, upper)\n",
    "plt.savefig(PATH+\"simulation_figures/single_SVGD.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 265
    },
    "executionInfo": {
     "elapsed": 1488,
     "status": "ok",
     "timestamp": 1611633860462,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "uD_cPedepoDw",
    "outputId": "49b42205-4247-45e2-8d69-54e2213e834c"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light",
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig3 = plt.figure(figsize=(4, 4))\n",
    "#plt.contour(axis_X, axis_Y, prob_grid, 10)\n",
    "plt.yticks([-4, -2, 0, 2, 4]) \n",
    "plt.scatter(sampler.x[:,0], sampler.x[:,1], marker='.', s=3, color='k', label=\"Iteration=\"+str(iters)) \n",
    "plt.legend(loc=\"upper left\", prop={'size': 10})\n",
    "plt.xlim([lower, upper])\n",
    "plt.ylim([lower, upper])\n",
    "# plt.tight_layout()\n",
    "plt.show()\n",
    "fig3.canvas.draw()\n",
    "image3 = np.frombuffer(fig3.canvas.tostring_rgb(), dtype='uint8').reshape(fig3.canvas.get_width_height()[::-1] + (3,))\n",
    "my_images3.append(image3)\n",
    "fig3.savefig(PATH + \"samples.png\")\n",
    "plt.close('all')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "0MI271YgOjju"
   },
   "source": [
    "# Build Parallel Sampler"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "IVOu04zaYQCX"
   },
   "source": [
    "Call our sampler"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "EAE5YTN5YNDJ"
   },
   "outputs": [],
   "source": [
    "psampler = []\n",
    "for i in range(5):\n",
    "    xinit = np.random.uniform([lower, lower], [upper, upper], [100, 2])\n",
    "    psampler.append(Sampler(f=mixture, xinit=xinit, lr=3e-3, alpha=0.9))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "siwAiqY6YT9S"
   },
   "outputs": [],
   "source": [
    "warm_up = -1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000,
     "output_embedded_package_id": "1W4vkbkJBvd4yHNGvq4C_6wq2-gDzkXwE"
    },
    "executionInfo": {
     "elapsed": 4970071,
     "status": "ok",
     "timestamp": 1610596025528,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "dFGXLpqnYtgU",
    "outputId": "a8c7c6a9-5c78-4b7f-d7e9-21077ffac0d9"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Output hidden; open in https://colab.research.google.com to view."
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "my_images3 = []\n",
    "PATH = 'anonymous/Contour-Stochastic-Gradient-Langevin-Dynamics/SVGD_result/'\n",
    "if not os.path.isdir(PATH):\n",
    "    try:\n",
    "        os.makedirs(PATH)\n",
    "    except OSError as exc:  # Python >2.5\n",
    "        if exc.errno == errno.EEXIST and os.path.isdir(PATH):\n",
    "            pass\n",
    "        else:\n",
    "            raise\n",
    "\n",
    "svgd_x_path = []\n",
    "for iters in range(int(1e4)):\n",
    "    for i in range(5):\n",
    "      psampler[i].svgd_step(iters)\n",
    "    if iters > warm_up:\n",
    "        # save the sampels\n",
    "        svgd_x_path.append(np.array([psampler[i].x for i in range(5)]).reshape((-1,2)))\n",
    "        \n",
    "        if iters % 200 == 0:\n",
    "            svgd_x = np.array([psampler[i].x for i in range(5)]).reshape((-1,2))\n",
    "            fig3 = plt.figure(figsize=(4, 4))\n",
    "            plt.contour(axis_X, axis_Y, prob_grid, 10)\n",
    "            plt.yticks([-4, -2, 0, 2, 4]) \n",
    "            plt.scatter(svgd_x[:,0], svgd_x[:,1], marker='.', s=3, color='k', label=\"Iteration=\"+str(iters)) \n",
    "            plt.legend(loc=\"upper left\", prop={'size': 10})\n",
    "            plt.xlim([lower, upper])\n",
    "            plt.ylim([lower, upper])\n",
    "            # plt.tight_layout()\n",
    "            plt.show()\n",
    "            fig3.canvas.draw()\n",
    "            image3 = np.frombuffer(fig3.canvas.tostring_rgb(), dtype='uint8').reshape(fig3.canvas.get_width_height()[::-1] + (3,))\n",
    "            my_images3.append(image3)\n",
    "            plt.close('all')\n",
    "\n",
    "               \n",
    "          \n",
    "\n",
    "imageio.mimsave(PATH+'population_SVGD_contour_'+str(psampler[0].lr)+'.gif', my_images3, fps=50)      \n",
    "# imageio.mimsave(PATH+'CSGLD_PDF'+str(zeta)+\"_\"+str(psampler.lr)+\"_\"+str(psampler.T)+'.gif', my_images4, fps=50)\n",
    "\n",
    "# save the sampels\n",
    "import pickle\n",
    "f = open(PATH + 'population_SVGD_samples.txt', 'wb')\n",
    "pickle.dump(svgd_x_path, f)\n",
    "f.close()            "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 323
    },
    "executionInfo": {
     "elapsed": 4969853,
     "status": "ok",
     "timestamp": 1610596027434,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "l0H68g03vSSf",
    "outputId": "905a1dc7-d794-42a9-ec6c-eedcb818ba7c"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.6/dist-packages/seaborn/_decorators.py:43: FutureWarning: Pass the following variable as a keyword arg: y. From version 0.12, the only valid positional argument will be `data`, and passing other arguments without an explicit keyword will result in an error or misinterpretation.\n",
      "  FutureWarning\n",
      "/usr/local/lib/python3.6/dist-packages/seaborn/distributions.py:1657: FutureWarning: The `bw` parameter is deprecated in favor of `bw_method` and `bw_adjust`. Using 0.15 for `bw_method`, but please see the docs for the new parameters and update your code.\n",
      "  warnings.warn(msg, FutureWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAbAAAADaCAYAAADHVheiAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nOy9e9AlSVYf9juZVffxPbq/7p7ZndkXg4n1GhmFpNUAth67ki1sIwuBHSEHFgZjW9qww/pDCtkOC1sWhGVhyRIhwrIjtDJILGDhEAgFkhZLGMOu1sKg3TUyMo9Ylp0FdofZ6e7p7u91762qPP4jM6uy8mZVZdWte7/bPffMfH1f9fjdk3nPL8/JkyeJmXGQgxzkIAc5yNMm4qYBHOQgBznIQQ4yRA4EdpCDHOQgB3kq5UBgBznIQQ5ykKdSDgR2kIMc5CAHeSrlQGAHOchBDnKQp1IOBHaQgxzkIAd5KuWZJjAi+nYi+uORx/4QEX31tjFtU4joW4no+3Z8z5eIiIko2eV9D3IQK+7vnIh+DxH9esuxf4mI/pPdoTvINuWZJTAieh7ANwH4q5Gn/HkAf7bjmqdE9B1E9AoRXRLRrxLRDxLRV26Kd9vS9cPucZ1XiOj3jYHpIAfZVAb8zv8igG8hoknLNf8jIvpFIjonoteI6MPmt/9fEtFHA8c/R0QrIvoy8/pFIvprRPR5Irogol8hor9BRP+C+dwO+i7M32tE9PeI6Kv6a+DNLc8sgQH4ZgAfZubrmIOZ+WcA3CKil0OfE9EUwP8J4DcD+AMAbgH4UgA/ACDouT1tXsnThvcgB0H/3/mrAH4RwB8MfU5E7wfw5wD8u8x8Cv0b/9/Mx98H4HcQ0Rd7p309gJ9j5n9GRPcA/GMARwB+N4BTAO8F8BEAPkGdMfMJgN8C4McA/DARfXPM9ziIlmeZwL4autMAAIjojhnlvE5Eb5jn7/DO+UkA/2bD9b4RwDsAfB0z/zNmLpj5kpl/kJm/1bkPE9F/SkSfAvAp894fJaJfJqKHRPQjRPQ28/5a+I2IfpKI/oh5/s1E9DEi+osG82fcMCcRfTERfcSMFH8MwHMh4ER0DOBHAbzNGfW9zYQcf5CIvo+IngD4ZjNS/LPOuaXnRkTfC+BdAP6uucZ/4dzmG4xHep+I/qsGHR7kIGNL7XduhYi+xfTFV4joG7yPfxLNv/MvB/BTzPz/AAAzP2Tm72Hmc2b+dehB7Dd653wTgA+Z538CwBMA38jMn2Ytj5j5rzPz/xi6ITP/BjN/J4BvBfDniehZtsujyrOsqN8M4Jec1wLAXwfwRdBG+BrAX/HO+QXo0VBIfh+Af8DMlxH3/joAXwngNxHRvwLg2wH8OwBeBPBZaK8tVr4S+ns8B+AvAPguIiLz2f8K4BPms/8WwL8fuoDB/NUAPs/MJ+bv8+bjrwXwgwDOAHx/GxBm/kYAvwrga8w1/oLz8e8C8B4A/yqA/4aIvrTHdzzIQYaK/zsHgBegfxNvh/5NfJCI3uN83vY7/2kA/zoRfRsR/U4TeXHle+AQmLnub4X+LQLaTvwwM6sB3+VvA3gL9O/oIBHyLBPYGYBz+4KZHzDzDzHzFTOfA/jvALzfO+fcnBeS5wD8hn1BRL+ViB4R0RMi8n9A325GbtcAvgHAdzPzJ5l5CeBPAfiXieilyO/xWWb+a8xcQP94XgTwViJ6F/Ro8U8z85KZPwrg70Ze05WfYua/w8wqNgzTIN/GzNfM/E8B/FM0G4iDHGRMqf3OHbG/i48A+PvQA0grjb9zZv5HAP5t6LDf3wfwwMx7S3PID0P//n6Hef1NAH6UmV83r3078QeNnTgnon/Y8V3soPJux3EHMfIsE9gb0PFnAAARHRHRXyWiz5pw2UcBnDkdE+b4Rw3XewBNHgAAZv5ZZj6D7uz+KO3XnOdvg/a67HkX5lpvj/we5Y+Bma/M0xNz3Tc8j/Cz6C+/1n1IlPyG8/wKGuNBDrJtqf3O7XuB38XbnNdtv3Mw848y89dAE8nXQs+z/RHz2RWAvwXgm0wk5BtQhQ+BdTvxI8ZO/AkAjYkjRqxNeNhx3EGMPMsE9v8C+Oed138S2jX/Sma+BeB95n1yjvlSaO8hJD8O4F8z80ld4pb4/zx02FLfTJ9/D8DnANgf2ZFz/AsR1weAVwHc8fC8KxJT2/uXHXgO2xccZJ/E/50D4d/F553Xbb/zUkxU4seh572+zPnoe6A9uq+CJkM38vHjAL5u4DzWvwXgC1gPiR6kQZ5lAvsw6iHCU+h5r0dEdBfAnwmc837oZIeQfAiaNH6YiL6MiCQRzQAEsxYd+ZsA/gMTcpxCZzj9NDO/YsIOnwPw75nr/YcAviTmyzHzZwF8HMC3EdGEiH4XgK9pOeU1APeI6HbHpX8WwO8nortE9AIAfx3dawD+uRiMBznIDsT/nVuxv4vfDZ01/Leczxp/50T0tUT09Sbpi4joK8zx/7dz2D+C9uA+COAHmHnlfPYdAO4A+F4i+hJzjVPoebKgENFbieiPQdukPzVw/uxNKc8ygX0I2hDPzeu/DGAO4D50Z/zf3YOJ6MsBXJh0+jVh5gWA3wvg56Fj40+gR0pfjnp83T/v/wDwpwH8EDQBfgl02q2VPwrgP4cOPfyL0Cm4sfKHoZM8HkJ3/g81HcjMvwhNpr9iYvJvazj0e6FHp68A+IeoUoitfDuA/9pc4z/rgfUgB9mG+L9zQIez34D2ur4fwH9s+j+I6EUAvwnA32m43hvQv8lPQf/Gvw/A/8DMZYIT600UPwQdWan95pj5PoB/CcACwMeg59t+FnoA7S+gfkRElwB+DsDvB/CHmPm7+3z5N7vQs7yhJRH9OQBfYOa/HHHsDwH4Lmb+8PaRHeQgBxlLev7O/xKATzPz/7x9ZAfZtjzTBHaQgxzkIAd5duVZDiEe5CAHOchBnmE5ENhBDnKQgxzkqZQDgR3kIAc5yEGeSjkQ2EEOcpCDHOSplNbq44v82V206ueuEIWP25W05dLcNDagjm8f8GxTZgn28hs+99xz/NJLL900jI1FjWRVxJZaaRN8Y2IaS0+ubEtn25ZPfOIT95n5ef/9N+X2GSGyYN5fw3zT2Hx93TSeN6u89NJL+PjHP37TMAbL+WI763NPZ+MEksbEtwmmLhzni7zj3u1mfSx9haQL+9B7E1GwTN6bjsDaPJ2bMsz7vJKhCduBxA7SR9oMW5dBBtqN8vlCbZUwhl5zCKYmLDE6Ch0b0pu9x00Qv3vsGPd/UxFYDFHs2jCveTde1JZMNOsmCKNLXwcSe7okxtCMPTrflLhCxzYZ5ZsijCZy7YsphKUJx8WyGd/JtMJjzx9TZ/bcTWUMIt06gYWM4L4YPZcsaA+mPXzysu/dBIm1Eaurq5sksX3uW/sifQ3NmCPkPuQQa5Dt+Zsa5DGIyz9nKKZYLG06ajrO6q4J4xASG9tj3YRIt0ZgXaE64GY8nRBJuO8TaGf41jCFoNHuScxtuyZS1dBuxjvct761r7KpodlkhBzrTcQY5bEN8pjYYrydNkwx5OXjuOgg2RPn/hfLfA3jUBLbdG7Oyphhza0QWJsBvInRexNRWGQuBKbtk8Wafjw8NSPMGh9TnWC3pbcuXWkM5r0dYQrh05huvm/to9z0CDmGIPoY5TEN8hBsbWKPjcEE1A10X/IK6ejRdQYAOJunweNOZskaxiEktk8eqyujEljQuPihKKqHonZtjDnwvjV8RADxdg1ziLwsJpfMDFyNAZo0LJFtS281vTjN575f4vHIdVdtWeKz4Nxjdti39lU2mXPaVqLEJt6Ee4wlsqEGuYu8hmBzMXWRWBOGEJ4m4rKE5Yv/viW0i0UexNiHxPY5FDwagTWRxfqB9RH8tkJ2vjH2ScI1zEQMY49Bhs62YZh9HTFXmPznliAEoYZNwDHUTKPprNSNBljpy4C2r8mSu2FVQVSS/k6I1cG3fuBu+ta+yqaj5LaRsb1+3/BcjDfRZJStuMYYCJNGm9fTjDXe02mSJoIYIm3k5evo1cvrxuu8eDyveWZ9MLptvK25uRiij5VRCCw0cleeQSyFDEls0dsJkZfSFhqKzXPnOHtPooowQobZPXYsTMzrj25oU5DFRRDEUIbEAKM7rrzHMXABVdvVMDltaO8lTCMSGR/WIdZNMMXiMx84wLbft/ZV9iHE00YYQ8nLPSbkVQyVsYk1llRj8PhYXBxtxOUfY4nMJzH3nn29xBjyCg0A/DAwsFlI08rGBNbo6TDXDI01IMRUejzb8HaaiEIp82ieM7hc6U4AhCAI0rY3ZJiHzouFQoZWLy6mQmk8SlUzO6IkLoIUgCJACo3YNdJD9dbUdi6hFsohMqMrIoCIIAlgoeuREQBhtDRGW7aGWrv6FqNsu12FOG9SxkpKiA3xbIRhgFF+8XhenuOTxhDC6CKvGFJ1j2vzcmIwhfD4WFwdfepBu77efW9enhMisbFIto/X6nvP9vwhOFzZiMC6vApLFNarcD0KImgDiHG8nS6iKBSjYEZRMHLFpRGEwSQEQRqikEIbZqlRGDD10XwMvkZM5t6FYuRKQSkgVwq50oRhGUwIghSawFJJELYOjNjMS2wiB9t2mkw1lrzg0mu1BGCJVQmCZKszggKPElIMhQyt3twBid+3iMz9SbddU996FkmsS2Kz/WJCYP7oOHZuaUyPYmzpi82Sqj2nycvpkrHJyx7TRWJ9pS95hZJL7LGx94/xwgYTmE9evldhjaA1PIAN72gjIwQAoUftvuGzx8YamxiiyAplHhl5oVAYgwwYMjVkkUqBFAQJMvg0Ro0Ja1mK9vxWPPqJ8SA0kVrSWuWaxDLzWBT6c4LWUSoFEkFgFkik9nMA4yWKdcKIxeXqyvdSLZHmhUJWMJSqPESrK0uqqRTldccgscZ5Qq6ItLlv2cEIGvvWs0Zi28iqi01GOJ2Jznmmtnv7BBEyztYQ2+M39SjGIlaLpUnG8C58HL5+PvnKo9rr9750VjvW1V0bvr7SJ+TqvjdmyNXKoG8QDj1VZGGNYF5Uno7NYJNCG19p5kmY1g2fm9feZWzaPC+XKCxxrXL9Zz0yAJBESKQmCP1WZZSZADJhO3hhuxCGGjbfg4ANE6Ik01WukBUKi6xAXjCyXCE3F0yFwCRhpJKgGEjt3JJhVmKdEbgJLt9rtsSVG2yrXFVtWbYhIZEExQIMIKmU1EpiQHNbhtrRvm/1VnrRllBVz76F6th9IDEieieADwF4K/Q3/iAzf+cm1+w7R7HJXFKv7LSBXkWXId6GxHiF9jg/vNnPw4gjU6CuI5+4/PctkVnd+cQfwtGX9F2sIbwhCYWAN5XeV2icY7IG0DOClkTYGJFCaUPD0AaEbTixYbTs3hOojE6bN+Fm9RWsjW9WKGS5wiJTWGYFcsVYFvoHmArCJBGYGG+CALAUpZejWCdQuFl/7uLioJ58zwseSSiNZ5kXWGUKV6sC13mByyxHpjSuqZQ4nSSYJxIggCHKZA6ri9I3bCCxLlw2ucWSQm6INSsUlnlFrMtce62CgIkUSKWAYq50JfRnUNAeYwWrpiufyILtWD739OaENa0X3da3NMlrT6wcF/UYHO1AcgB/kpk/SUSnAD5BRD/GzD8fc/IQ78cP94QMyabZdH1kaEhsiPQhjDaMIa8w5t59vQtLpDHktWvpS16t19qgv/U6q2lEj3KUXIWbNGlU4R5mQBBDCgIzgUhogycApQhkwnVNhq8NQ83oaatXhZpKo6ywKjR5XWQ5rvMCq5LABE45gVLVvBNIIVGaXRUziDVDMCov0V9Htoan9E7Nc88QWw9smSs8Xma4yHNcrDIscgVBhFkiSm9WmvmvRAgkgjX5M5mEP8/zisBV1xXKua+KIBjLTOF6VWBRFLjKCh3aJGCeSMyl3nNEmrTNROk5RBL6esISqaOrLu8wnMbvJt845N/Rt6TxuISBwE7bdZH8roSZXwXwqnl+TkS/AODtAKIIrK80TbSPNRpeu27EnM5Q2dZcWExYcwxpyw7dlBA++cqjWjjRl029xE2kb7t1zYNtlsQBG+Jx5yqs0aln2MEcY5gJklkbYLaGy5+wWX+rCwxXT2u47PyO9TCWucKyUFgVBRT052lBZhQvdLIAa+ISllFDXz74dpjl655hfT4nKxQWRYFFXuB8VWCRaW9GMWOWFEiFQK4Yiaq8XVfXRqWlFxaDy0fJ5gjXSywUY6UUFrnGlzNDEkGAIKnATAkzSIBJsKio07bHRhmlqPpNbS7My95k7RzX+pYedFiSNweE9HLzXhgAgIheAvDbAPz0zSLZnWyLHMaSJnxjhzV9om+SffG+XGki20085T4ybA6s00ibuS9V/QHQBlaZdHVDcsK5Zmhc3BWqC2ErR/dcD0Hp+TDGUhVYFQWWhSq/ybRgZELpUT6zJliEiWItOaJBH/7na6RqCcwQxbJQuF4pXGWqzKY7mSgsZWHme9isYTPk38HyXbiMiiqdleRa/WVKIVPae7UElhBhWVBFHj6p+rj6DkZQeWhVyNofAFR9i+0tnL7FtXPC5LUvQkQnAH4IwB9n5ifeZx8A8AEAeNe73nUD6A5ykGGyCxIbVBumiVDIf+H+wVlkag/ZklHxr1vCMO8LULW+ivTCYI3LzihRL9Icco57L5uWXq6vEnouJxEmDAaq6bD8UiPicnVWYXPajFw9ar3dGCmQ80h1nMHD9pu8Umjy+n5m/tv+58z8QWZ+mZlffv75tQ1pRxE/nLSr+a9NZBvhw1jZdVLJ2LKNcLEvLx7Pg+QVare2/taVRr/RfgnkPxoDLERFDjY9Xcrquf1cG+7KyIbsTD9ScIwvVXgsJikIEykwSyTmicTM/B0lCWZSYiYFpNTp6xZbRSz6BuR/aQ9jCG+5YNu5piCU2XwTITCXEseJxO2Z/rs1kziZShylCWaJNHNfGlu1SJfWcTXozsdV5wAqryXMPWybab1IzJMER2li5r8kplJjqrcnmWy/qg18XcWKHVDUyNO2pduvnD/7vtUvGV23YbhJciMiAvBdAH6Bmb9j2/c7mSXrZNW5e+/2jN0QIthFWMrKvhFV27xWzHHbIP2bHEgAPUOIROuT72Qmya2hkMagJoJ0dhozJFVBJd/gUIAgCOZ5pOUj2HkOlBUqrGcjHaJgFpimjFNOMJUCUyeJY55IpIkmuETolHqXvFxy9O8dxAOuzUkxTDYcAUIwJBMSIZBKhkoZt1RqCF+UWYgzKXFrkuA4STBJhE71d0jDd4Ko/Kcbl9WVbRdLXpJ1oghLoJCMImUkIkUqRJmFOJUSEykMJkJiPMZq0FDhaMPThc+eblPkWSvRzJ0KnbjR0rdsn7Sk6upnT+R3AvhGAD9HRD9r3vsWZv7wGBc/mSbBifc20tpH76sPkYxNuF33jiXUGFwns6RXHcaQuORlsXdh3OYgxRWX7MbyAgdfxZJGRRbakAizZoqNpVBMUKKc2i9H64msG5pyxG0P9O8XeG8tk82SFxEEGGxSqi15UTnTBkyUwNzMzQmzgDmRJp0+oZIo1ojWwddmlEtjDJf8uPQKpIBe35WabEzo9PRZLlGwJrCJkJilOr1/mooSozRVQ4QBZNc49cLlED3M4nK7TtoumFapxp9LNguW2QxONI5pYkhsTVdOWwbwtLWlxVd9H9OW6N+37F9Jqh6emw4tMvPHMDKlns6SWuZYE4mFxCevNsPWVfDVvbc1zGfzFI+uM7x4PC+z/d59b96azOESiDXE1hBaIzgG6YawdYlLDD6mLnHbyW8jH4urI0tQbYuYgXXiHUNnLk6XbO21mxI6fC/N1ZGLYyelpNbW71A1YLbVK8y4F0R2IXO1cFQaA+calzKM6Izca+GvjvAPs2eYzRWEhqGxSo0H0BjsGiJA39+GOCdSezprBrnDMwytayo9Q1SYJAAW1vsRlfdKwEQyJokoq0tIQUgTHTq0HlgqDXkJmFBnO3k14jK6EkC5zo0NQaTGewWkycyssv0sLo1N60sKTfhl6M6eT3HtaD+rkZgZHFUkBmdRebhv2fBsI5k6eG6avMaQmEoYQByJDSGvscQaW5fIfAMc4+l0GcAQaYS8nhgSC5GXK5saZl98om8LJ4ZIfyg2f0BUu46nu5hwYh/y2noxX3e0LIhMmEwbGSKAlF6h5Jb7gWNoqrmKyuCVxyHeyFjj54/etR9BpgCuDW8Js15ovRaiHb0n3ujdJYkug+wThouJCFAGD5mMPSQC0iwCLiRj4pRsIuPtSEGYJFQShRQVUfTFZbGtkZghV5cgCAwpgEJV1ToATZyy1JVwyLTelrHkFdKdT2LCALVk5fctfT7VSMx6vj6eZ4G82iRkdPqMuPuQV4hEg/cPeGFAfd1VU7iuzdMZM+Rpsbn39InMJ4RQWCwWUxuhNnmrQHN6fxPpN3mHQ4jVHwzFhj37JgptfT+wGml4hqaclTAY2NteoyQFb7QODDcyITyWVC0OW8VCivVivjazziYwWHwh8hpqjM1lQDDeqqy8UkEBojCeqk1AsUkxQgzzcoK68khMgAFBJryoCT8R9Wr0pW6EJvvKs663ZSyeVnwNfYukTduP61vPKnk1eWFtI+f2643reYW8P58omrydJrIIEUWsMe7ywlxsIQwhPC6m0P36ShfZ95mXG4Pwu8LSfeez+nj7XbKZB+YbmvJ9/YEwtfpq4SuyhrE+p9TXCEfhcQyfrRBBBAhj+BgosxjcjEObIj6UvBox2TkwkAm5QhedpXWiMLctt3kpPVYxPi4AYGITptMfEFcErqusUKkrl8RKTyfgeW1CFk1tafsWTBWSPn3rWSMvK20kBsTtCdYdSmomry4vrIsousKDXUQxRojupuZ0mubCfBID6nqK9QzHmm8KkRjQrzpHiDyHhg6tbNzyIQMNx/shYG2rd3vemOQVxOOQKqC9L2KqwneOCMfojW0AQyHOMpwI2P0fAVhirUKuNpS4qUfYhsvey/dcCQCZRBixRhR1wgp5g5tKsC0H9q1nlbystM2HbWrgYwxK9HxcgCiAMFnEEkUTHiCcZNJGGgCC+Jq+S+31QIKIITErbaS/CbF2bY/j4wxdF6gTWvv6riaPtZ+XP0oAORSSolqadt16UPnPdgyM713AGD+GLhgsjRvhejr2SUkQ5vVY+MrzuQon2rAdwGUBXFtFQt9+e6Tq4wp5O5b0UdZctLgqDNsmi33rW/sssSTS53qbnR9HFEA7WbQRV5cxjgmx+t5ECF8TnhCuIQOGJjx9SdXHF4MrNK8JNJO//qxBN50Di3FD1KPNgIZCUgBA7B/oPt2egXG9C3vf2ryYRrmGYxcGcC1sB4vJeowlgJ15FaGQnSYJx9sBr917F57OvvWtfZaxSGyIMYkJJQJxRNFFEvbaMbhj5wmHzO0Mzd7si2cb80xdbRzr1XeFqONCqcMGS6OuYFsLSdlFqaFjRww1deHxR+8+QVWYmj8bG1Pwvmw9w3oI0ce2E9GMVb+vs53MrjHtW9/aZ9mUxDbxvGKyErdFFH3n6ZqwAd1zO32TIWKyNy0eAGukH4OpCdcm80wxfWmTEPWmXv7oS7B9QwPUi8o2rVPaljSSWPDgOsZtYfO9HaA5LEbek517Og5PrN2TPKw7akt965vvW/ssMQuNdyljEsVQg9knY3Notl7Tfdvejw3V9SfNceaZttWXxlhPuJUaIr6X0TQi3rWBWRu5r02C7X70XsPU5FTscE4nFHoFAITe887bhexr33qWxBqqoQZmKFGU4bIbKGc1dNmBe/7wc7tDdbHYNskm7b72OEQ25kL43fcUI7s0MMHwk35RP+4GvQm/BqADag3brqRNV/bzfZQDeWnZ1NBsSmR9JYa4xsio3IZX2rbjctemjDG4xlgqMFY7DiWybfSjrfXMgxEZKNTw/IZkH0nq0Lfa5XyhRjXS9nr7EI5s80Ri8G3zO2ziwQHawO9qsDCG9MG7re91Yx7YQVqkxUDvwniHEk3WjtlDYjvI9ue8YryyIRia5sJCXtlQb6cNV4h8hiRNNGGL8cKeVonxarflzR8IbN+kY67J1gLcKgQHQ/Pu2/12yj7IdqXbgAzzDtqIQn8ugu/HYugiiaZ5MXutJrLoIz6uPtUlQgt3m7DdNIlti0T66HtsDFsjsK4R/C4McfC+DQbZflZmt+0QX4nJh+ak/B+kkn3tWzclTQakjbSC+4Q1eDtAN5F1ySYk4R/v4mzzxjbF1LdI7cUy78TWZcCH6tOVLn2MRaSbePtjEdlWCKzLwOxauOSHBqIASqLYlWfRhGkth8O+T7sh16D31aCvmyD8fetbNymxxBVLFm2k1kVkbbILouiLzcXk4glhaauJ6B5/MkvWPMbYkGLc/F1cO7rH9fWg464/7vzqUBzAFggsJvzkGj1gu4avL1G4hnlbRjmEib3PKmCGW3n7JNZEXkH+ChDrtqVv33qWvbCQERmDKKyUVTICBhmII4s2PE1YXLJwyyZ1EYW9X7f30Y2pibC6sNrzLb4YEuuSLtLy27gp1Ao0h1tjyWO7CTDDvMJRCSxq9O5VmtimNBGF/75OF9cGz1bq2BaJtWHiAFvYhc0W2y4Iw+JwSdVfMOzqy2La5oBkSN96Vkmsi7zaiCLGOMd6FkDbCD+OvNrw+J9ZQvOJIgZXX+KK3ZUZ0IV17blWd7Ek1iRDk0raCK1tbk6/Pzys2WeOdZPlBr4Qt8RkFnnLhJEnbV7F2k2dJ9tanOvjsa8VcxCbLYtUVlbfAr6QjpQhB7231TpR7GqLkNq9A6Qayi3Z1bYlsV60i22TKiGzZD9nHl9++WX+iY/9TO29GOLyiaDNOPfdlsNK04LbGEwxZNG0A3KfCvU+phAeF0vTxpGuhHY/3nTfsrFDrj6GLhx91nlta/G3T2RE9Almftk/bhQCWxsdt3g6Gkxl9Pz3x5BYonA9BnfrEvf5WPhCOnIx2Y0s/f2tALsXGAAadzsVH5vfdmz2JmvSl90IdNvEWj7fUd/aVwJ7729/mT/yf1UEFiKvLqNsxTfOoU0SfYMM9NsYcYiX4+Jqw9SEqw1bG5424vrkK4/WrvXel85qry3WTUisb8g1ZgsaF0MsjhhpIq4+yyG6MLgktnUC89mc6R0AACAASURBVEfvvqdTbgVfAdrKnmC+MQYMUZgdmBVzRRb2fqjvtzU2WfhGuCRRZhQGS6EcIjPHWoLYxoaWIVxu21ksSunPlHOscEheivH3KfPxjdW3YvE8DQTWRl5DvQlXYjwLYHyyGIrJx2WxtXkvPh4XS4i0msSSWR8SAzbzWmMkhuD7ktjQ0KYrfepbWhLbCoG1jdwtWbjHlR4NuRtI1rehH8Mg+3gUc0kQhTLPHaNMqHY+loIgBY22gWQolGkNcG6wWHyFqsgDQIlHEEFKgiSDTdT1NoT8G71Up+1KXQWIVZMpITEEJong7sqsVUaDSaxv37Lfvalv9Wm7fSewPuQV403U7tHTswCaK6bHkkUXrlhMPi5fYnTUh7hCGPuS2BrGkebmujzVISQWm93qe4tNbRIb1jydifEJLGRg/JG79i64ZmTcreittzNGGKoNT6G4JIu8YORKac+iKkYIaYxxIkSdLBwvqA9ZtHk3yhBVrhh5oVAoxip3CUOfbAlCCkKaCP0oydFdmPzbsIVwAah5p4XSGLNCIVcMpSpPsSJ7QiI1Hvu8RmLAoLaM9QoLtmHY6oTWvtUDy9NCYCHyCnk3Q4yySxoxJObLNj2dNkxNuIaQ10c/8kuteN73/vcE8YWwxRBYrNdqJeS9+mHX2DBwG4nFeF2xGa5Dd7G+NZfjEVgXWbh/ips9nUSImsEZElKMIoqCsSqUfswVMkMaygAjMsQgCZNEYCIFEqnxCVF5F6F5sTYJhb6YgbzQhJDlCkuDZ5UpZAUjK5TGZfQySQRSKTBNBBLzmCaGNAQ1kn8UtoCXWpG81tUqV2YAoEoCk4ZEJ4nBJYy+ZEWsfduyKcvQzhPatqz3rYrAmvpWouOdJSbbdm19ap8J7O/9+D8G0O55xRCEb5x9YwysE0ZfsvBxAZuRaggTEDbSIYnF0kVcvri6C5FYjBc2dsh1SAg4nGY/3tKM8p4DSKyJwHrP4jWRl0sWhdKGOCsMgTkMJoUeqSdSgKWCtMN14cxFMdbWPHXiCuCxhm5VKCyyAlnOWGSFfl4wVqoAAKRCYJZIJJIwTyV4AigmIAEkCBCAtF8AMPt2WcMZtnVN5GXJIC8Yy1zhelVgmSlcLHNc5TkusxyZ0tk/s0TiNE1xlEocTRJMU6tHAWnmNxNhcBFKvQ3HxSgMrrxQuM4KLFbmeVFAsW6TqdQkP5tIKAWkCWNmNCQFQEJf24Zf/QXPne1o8PkhTbdvleFXpc+ghr5FBAhUu0pbtfhh7adZmkbpfQyz/cw1xp985VGNMF69vC5TxpvIYih5NWHzidXF9KkH13j3vXkUrtj5o77kZc+xOH2dhcRfiB1DXk3EZXXp39Pqxl7D1Y9N8/fFTfUf4nW16dhf09fkvfddbtCLwJrnJaqQmDUu7ujdzqMI0qP3RAhMGABEzZAIEBS4RmJAu1cRMsjuaD0rFJaZwmKlsMwKPF5meLTMcJ3nWBTaq5hKgdNJgpM0gVITAIBKBABCKs2IXQDCmMESjUNkDeBqmYaWJLJCe1/XqwIXixwXqxyvXS/weJHh9csci0xBEOF0KvCWkxS3pxO8RU2RK2lIHoAUEAQU7JCrIbEYXH5YrjDhzKxgLLMCy1zhcpnj4WKFq7zAZZYjVwxJwFGa4CiRuFNMoJgxVVJrheyEq0caQNT6taDn5ZBX775lsLCBpkAQHhabAPI0SGEGgqGMw7G8CtcY2+u896WzmkF0xTVGY5OX+1kbsbrSRmJdeIaQV5O4+goRR2j+aJN5TPc9n+DbpKmqSZf0XV/orpOz57u6GLoHXNRZwfAOqkl1d/Ruw2CLTHsWNnwHaCOjQ2JcJTVIApGAIAIEQ3okZo1xyPgF1y25BlkZg5wXuFppoviNqwVePV/iyaLA+VLjOkoF3nKa4O4shWJA0EQ/CgIgIIiNkSMIYiiuFhZDv+0DKx9c8lJsdGQM8PWqwMPrFR4slvj0wwVeu8jw4MkC16sCRMDpPMWLZzO8cKo7yx01KZNMAEAIrbcCvE5iXbg0uJq3mpkQq/W87l8v8drVEg+vcjy4ypEVDCmAs1mCu0fSEJpeMFzDZdqSoEnD6qppQBJa3+UuL7BE1dS3GBqHDv3qvlW1lwCE9qgFmZ4U8PBvgsSI6LsB/AEAX2DmLxtyDddwjBUS80nMlZC3MySM1BdbEybfCwtJDJluSl5N+NpwueLrsClZIyb0GuOltnlBQXwbLo7flnR+g2DIhx0jY45RqkpKyHI9p3O1KnBd5FjmCgqMhASOlMRcak9Czy0JSMUQggFlPR2Uo2c7jG/0KKzR47rRs6P2vNBkcbkq8GiZ4dXzJT7zYInzRYZzo/ijaYKrbIbrE4VUCswTqefFEm18EyYI6ylyaY0tXyAEzSWJklgVSg9slWv9PFgs8bknS3zmwTVef7zAFx5cYrHIIQTh5GRiiG6Gk4nW2XEqsUqUTvBQDEEMKQhsgUTist4Ns06IKMO+pu2erDI8WKzw2TeWuH+Z4eH5Elmh73vneIonyxRSEGZS4swOTJQmjEIwiMlCCWBo9g79gUjZlkqt9a1FUWCRF1XfSiXmSmpvjAgEASk0USliCNZeodVPKLS5YyL7GwD+CoAPbesGY3oVsbKtuSZXYr2wmzCuMWHEJvHxjpEhuam0pcn31a8/8OlDoiFpPdsnL9/7Ko0zKkNjvbFVoXCV57jOC1wXBZgZiagWpiWFQKoYQtl1WQwmS4x27sQxxGFL6D4YYrUkVhnmvGBc5TnOVxkeXOa4f77E46sVLq608uezpMyeu3ec42qaYyIFCiV0OFIxlEkQ8EfrIWguSViid42x9SauixyPlznuX+V4/fEC99+4wuuvX2J5vQQR4fr6CGkqIYhw/9YER6nEIleYF4xC6rT7RFQGvzbH04CrbEen3dhru6VpuwdXGV6/yPDwYonXHy+QZQWkFCgKPfd0NpO4M8sxyyWOzPyUEjbzVHtm7JJ9UzuWbVfhq0jMtKWqh2CvixxXme5bSjESQeV5iRSYeIkebMnL9q4GLDHzrWMJM3+UiF4acm4ofHiQg2xbNvG2tyEb10J0KzRUBsdk2ylGpnSWnTbqCplQyJUo0+v9P/e6fWr+ueusWL9Rm+spFCNTjEXOWOUFFqsCSzOyEIKwygosMp0VmJekirIahb12nVkjsXmhOzakkRWMRa6wyPS802KRY7VYYbVYgYiwnKRYLnP9Wa6wUgoFu9l31iRrQDUD3YHFf88NKeZGVyub9GJ0lWUFkkRgkSX6/VyhUAoFq7VKItxXSU34ynasL0TPCkbOXPYtGO82Z1UmflQDieraT8t8lxUi+gCADwDA29/xrhtGc5CD7JeMurOZXkTqrMchPameCEJCdp0VraWlu3/ltQZmMpfXIJShIpvanZh1VKkUmKYCqfmbpAJpIsz8nD6uvoA5cO0BmMg+J526nwid0ZdKwiQVmEwk0kmq/6Yp0kmCNJUmXV3rUNr1TfYLOrqiCL2FDHipe9N2kvS9UrOsIE0MttT8SfOeFPW0+RHIYe0aZTs6C8sJZT9y+5bGLepLCxBov6dImPmDzPwyM79877nnbhrO3khbiK4rnX7bMjR8+GaQ2EXnsdJ6BaL6iFhXIefqM+g5IXexr10QnEo9J2FJjVkT2lGSYG5S1utVLwjVfz6QJoAoh9cE0hPzdrLeEKjFc5RKHBcJ7h0leHI61WGmRKc+HE0T3Dme4u6RxMkkwVwma/hstr9vBBuhEXTozHhEwmTDlTqShHkicTqVuHeU4O7JVKeJF4zr60k5B/bc7Rnunk5xNtNZkhMpynVYUoTJvwlX5TxWurKkSo6uJqbt7hwluHeUln0gy3Vq+tnxBHeOJ7h7JHGcJphLqReAk67OQQ6pWV1QEygHHHGFj4jLjEsmnZ5v28POU8J8rhhISLex7VuJ0FikqEiPvPs1tttTICez5EbCOTFrrs7m6c7mnvy1YDeJJSQxCRxjy6aL0J8m6fTAgj9oqn9eeV4wRqMyhPNE4ihJ9Fomz8C4FSXIuRYI6wYHQJDiyPFs7DVgPTxjxCRhLiWOEom7RwmeO05x92SKe6f67+7pFM+faHI7SZJyca5dV1Rds/JyggbR8bR8HdY8HGG9L4nTSYq7RxL3TqZ4/tYMd+/Mce/eEe7ePcK9O3ON8yjF2SzBUZJUlTgESk+jvGdIbxQA5OEiGLInSxCEudSEee9Y68vq6d7pFPdOJnj+OMGtqR2MCIOJyn5Q3Tp884ahSs1rctvb1Vsite6OEq2TY9O3ZnK9b4UWoLcOOp5CaTOSTdmEbdK2MNeXk1lS/jXhsuf6nkkfbLHH3pT35eNz9bUJabjXifHs+np/fdPX/e/QR99Nxw5NoQci58BcT8x6YaVxIi6NC2AWAEPo6hsETAqBubPYNJU6pDhJdYWJdU/MMTI1nqpbF9cbtK6FTf0QAoDShg4gTBOJYsK4S3rdUiIIT5Y5rlc6bf5oInB3nuIkTXB3NsEslTrEmFT4bBHdNZIIhbwAJ2FBK8+GVJUhdjAwmwjcKyalF3H3KMHt4wmWNo1+luDFW5osnj+a4vZkgtlEYiK17twBAMgzzh24CNVyBZhEkETqtVOziQQIeJ6nAIA7RznuXSUmjZ5weyZxMpF4fj7D6STFbKLDr7YUVw2T532F2hEwc2a2HY13LwCwWaitWBNr2bcApIowK6r1XomowrGJCc2uefkNfeomyIuI/iaA3wPgOSL6dQB/hpm/q881XA/j3ffm+NSDa7z3pbNaxtr73v+e6Iy/NqLo8r6GeIUx2PqUbAqJ1dGLxzqdPKSnPjpqwxdLIH6hYas7HytQtat//dDaL1fG8r6asFqJ8XL9tmnC0Le4cK9SUmvrwbiqlmATHzJbLSFXWBXVYlNAGwxLCKkUmCR2VG2NceVVlB5Fa9ypjgWo1/RzSyItVnpx7tWywJNVhmVRlOvTUiFwbBbnzqcS84lcK5MUqrpeKtHDGF6fxlW6eq6TD66zAldLXRnkwfUKl3mOx8sMi1xBgHA8Ebg9neAkTXBnNsEsFZhPJWapLOfy1nA52LrWW7mVLtwKF4usKNepXS6LMuMvZ73eai6lrhIyTXBkdZVKTE29RtuWQlAreQXb0dOb35Z9+1Zq5+l6VPHf11JSv+W3/Xb+0Z/4KQA6tblvGakxiCJmDqNrQW5MeasmIo0lrxCZxuhpCIn5BNZWCxEYVvwYGKeMFNC/On4Iq4+3j7TtZtC3lFTvWohNJOamiLv19JSyGWF6LsjO3awVzXUrrANr5BUyNKEF1tbowWRBKtaEYcsjLTK9LixXqjR+kqj0tqaJ8b6kLklkw1Eh8ooyyAESqxGrIYvFSmdrXuV6wTAR9FxUkmCSCO3lyABReJXpo3HpJ2XbuDUGV7led7XM9J8tfWVLSdkw3TStdDUxZC/MXFUbJr8tg8s1nAxS25Z2MXhT3xICjQWZXTJtIy9gfwmsqxbiTVRXb5KhJLYJpiZcfbEM9VZdfH2q0fchMRe3L0ML+QJxdRB9rD7eLtlkk81Ri/kC1Tqn8rljoNkxOHaED2hb5lYMdxMkmkbrMaGdeup2hccfvdtyRLpgrlMI1oSfdIFaM2oXVTZi0+i9VCKtYylfB3TkequZSdu3RFGYQr/WINukDVvU13peIVyu3mJxlUShqrazxY4tvmoLGtOGTjJFKqksfNxGFjFtGRoc+eRvK9FH962GrWfasDwNBAbUSWyXFd83LUrbF9smVehjsWxSn9HF2LeIb4lvpJ2r7b2tDCUvK332/wqR2RhbqQDA1vcDcw2065HV1mVRtRmicLLDmsihz7yET2JueNMaPF0JwxrkykiSM1K3xtgawk3wtWFSjJpnY0OvtrYf4Nb3qwiiKZw5BlFYj6bmSatqOxXbhnYZRDl/GfKix2rLQLhz077VhWWfCaxrOxWgOew0xp5bfYxxn/3AYiSWvDYplDuWZ9h3H7A2vC7mWBlzM8u+uy+3yZDNLIEtERiwbmzc4rXsPK+AVEZuG7syu56hT2LMVU1CxahWuJZGeXv7lGk4dR3ZGoTlHlysidUCI5MZaMNyNllmK6TvhOxK79Xgs4uIy5wZQs0DHHun6DVsRiVj9K0YPPtOYAA6SQzY3jYcMca4z95Wbdi6wmIxu0O7eMba+BNo9gzb9NV3y5KQV9NEZqEklrF2Yg7hdKWNzJrapQ2DS17AFgkMCBvCkki4xhPlk6b5rjGywYKkylwz0DWig8kwROV1jY2viSyUqpOGi8uurat5EwO9ir643LlNX1flMgJD/BgZk4/Nx7ftvvU0EBiwTmJA3EaIQHul8qH7R8UY4m2ExHxcTRJD9n09Q5/w+5KXlV1tGtmFI0ZiK9a3SR/yArZMYEA47MOoG6EKTDUy1g/jkZeLxcXjG+byMyOuAW6aVxrLIDdh8j0Ke88xvIq+uFwPp5HAsD1MPjYXn36+vb71tBAY0E5iQDxh9CWJPsa4LaQYK7HEtQmp9vFY+3qqm4TrhoTq/PvHYDidCZwvVPT1hxBZX+KysjMCA+phH+dB39B7MrbBC2FqGr3XhOqGedvkGkpS8I2yTwy7IAqfJBQ3N+K2MTXic/Bso2/tK4G9/PLL/BMf+5m1911DsskcyjbnTYaExbrWDvXB1aWjsTzDTcirCW+JNZLI+swz6c/CxNGHzOrn9duUsg2Dla0TGNBAYvqFc0f36fYMnosntL7IFyqNHrZGXi6mEpdPrAanBeNi2DZR9NWXH7bbBiYfWw2fwViBcp8Ox7PPBPbxj388aFiaDDQwXqrzGIZ4CLaxQmJDiN4nM7/qSVeW302H64Z6PHUMw4gsVmJwNBHYqAWxiCpDs1Ypwz92BzbC4imxEBq39NiVZ+jqyN7PrY7BHj6fWHeiN6ftXEKvH+M/2R552WvvU9+6SQmFek5nSWnsrAG1RtolgNhU5z4k0RZ6cnHZ6/pVHWKlr2fRhsXVkbvo2d9HrK3GYg1bD/LyDXYbQXQtLm6TMcjLPXYbRNYHR0i2WtGxZmi898vnO7I1a0YZ61FE99ibwMTwDHXAKyzP3QLEELka3o8K1e1S9qlv3YR0kRiwTmRAN2H0JS7/ecjIxeDqg6kLV5s0EWq5vb1HZJ3YRgiVxRBEHyLb1Otrvu64RLYpeQEjb6cCrBuNtUW/OzZ2a0aM6k8J6wa58dwtYyLnc/Le27Wst5unq4bjtin71rduWsLGMFkzYCfTpPwLSdPnbR5Ek/Fpfj/s5cXgGiJtxjGkn/J5H4+wZ7h1DIMdI2NkCbbJGN9jLF3sRKNlOM43OG8ue/N0SlMb7Unbvdn7Vh/CAOqk0UYQseGvMTD1wdVH+pBYDUtDdX3/mL6yqefSh5i6jt32vFaXjHX/rYYQrYRCPQd5yqVhLnHXcuhbzXNQfrgs/no7MQuldIUSQ2TWlem2bQN9schbSaxvJl4b3qEelT2vCcf5Qg3yhMbSrb3OJt7Y1nuqa2Bs0dXyNd/sSHltEaxnlLeFby2rz0s+dOfAboonotLVsd6mu5R97lv7IkNJbBNpMnBdGYlNUiajeEQ2JF27CcvaPSN05pPYxTLv9BxDpNGXvGL05uJoI7K+JLaNgcFQIgW2QGCN6c7ee9bYbNvQNKWG1zHBYKqO3YVR7lqYa3XDWM+e3IbeuojVfZucJ1Zfu2pLfeub71vPqrQRQ5exiSGvocVgQ0Q2hMT6rlED6un1boKHPb5MAnFIrAlbDAnEkr2LN6QrADU8QGixdzeBxBJX08Cge53eMG9sVAJrW8xcClWfb5skutY1+QbPTWnfllEOralqXGBNALiOjWkHemsg1lqb2YcduYj71reeFtkk/NSXxPqSV6yXY8UlCaDbMHdhacPTtvA7RGauNxZDYpviC4n/eZu+QiQG9EvxD+GNPW6ssOZoBNZW8scVctydbY7cQ96ETxRuAKoki12QWIBQQ5U4wICgdWyWxMbE1VgBfq0tq38J28XkY/Px3VTf2jeJDdlZ8UfzTWGvWBLblLhiq4T4ZNaXyIaUuGqqymHXh9njXXwWW18SG6uiio+nD6ZNPa1YGSusOQqBtVWXKN+DXbtj0sS3SBJ9K5lrPAQiBsEU9i3Dd+PgCxGqi8kWzXWPrcKHBEH62wii0QkjpryVxVmm9xtM2DKJ7Vvf2jfpqsphpW3eJBRucq/VRmLNuOJLNwHddRp9r6fJ43Hv3TT/13cDyZC4x7j4XGw+YVhMIQnpa9N9way0YbrpMldtRBpVoWOsavRNXoV5q7qh+WdbdfRCBs+tRm/32/IL57qV3scunNuGyd3fqsTJAUwb7nHVhS1UYNhuQWMJ1spaZfyRMfnYfHzb7lv7XkrKFZ9EhiZK+LJJBfM2YxxjiPtUygf6VaXvUwexT0HfELaYDSS7vMJNt6CJ2VlgjPqWvnRlae7dhpZ+2Mn3KsobGoPibnoY2np+E6KwZFp6W1zfzVd5JOYaYbsxo93nalMSa/QGub7RZrVPmSYygiZRKSpcXbsM98HW5qXaLV6qfcoqYiVD7sLVF21/PzDfcw71LaBqy01I9WkhsL7ktYu6gzHkNWSfMmB9Q0ug375gY1Wib8LlYuu7h1oTti5cdt8yf0PSNlxDajaO0beAYbU2T2difAJrCju5e1vZbejtPeyciWv8rKHelMSaPAlmlLsL2x2GC7PLsN1WRRAgjCFOZUUWm2we2TRv43pceVHhyXKlCa0wBGaMsN2JeZJoPPa1oLre+pBYG6kqqy+DRe9gXScMIfQ+YHb3arvhpt2peewdmcfqW7H96mkgsD7k1aeYr5U+W5aEMIy5gWRo40ig3buwuENewpg7MzdtahnC1UWsu8TVh8Q23VlgjI02b83leAQWGh27ZOFuSW8No7ldSRbW4FljOHR35qYwk7tZZK4YeaGQF4xVrrAqVPmZvX4qNTGkUmCa6OeJ1Jisl2Gx6Yc4GxcywlY3WaGwzDWuZaaQK4Us51JfUhDSRCCRhGkikUrCJBFIpVjX24a42OjJJdbM6KpQdWLVRKqxpVLjK4nfwzSEWH18cX2r8pprbddAqm1Y9p3AYqvRD02WsDJ0361tGGSgH1mEpG2+ayimGFxteozVVV9MPrYhO0b3Ia4+ySVW+pDYaATWNJ/jhpwKVRlB6+kw2DEwxrOQ2uDZsF0ZFgOiSGwNC+phQ2uQs5wNUWjCsGShlD5PCsJEajyzVGJqSCORAkmDJ6Yf2u1ciCQKQxCF0pgWWYEsZ1yvCmSFwlWeIzeu4UQKHKcJUikwmwhMEoFpIkuCXdNbH1z6SS1sqL0txirXntcqU1gYXeWF1iXBkJUh1WkqSmJ1vbE2TH5b+l2waT7OYij7lhmk2GQNrZNA3zKDpthw4tNGYH0SAGJkk12PfQzbMshAPxKLIa82TB/9yC8BAN73/vdE4epDrBZfLC6LpUl8jC6JDQ1xAvF9a8gWND4Gn8SaCKxXCopPGLU5JksWhTYwWaF0WMwQGgDACYmlCWPCAiwJuiSjzmpTdgKeUVvz1MKztRAdO2Rqw3OWKJaZwtUqx5NVpt8rCgBAKgROJwmOkkR7GlOJiTIZMKwfpSAoQ8Julpv+WlTHUr2oeV6W4K1+FqsCl8sCy6zA69dLXOQ5Hi8yLHJ9jdOpxO1piluTBHfUBLNUAsYLSjigNw0LTOu4aticcKYbNtS4GMuswKpQuF4WuFjluMoKXOU5CmYQEeZS4iiVOJkkUJygSIyuEkDCkpfGJFDpqqst/UQgN2RoSWutbxmC8/vWFAIstI5Y6GtuI4Nz17IJeXVlr7mp4V3rm5okhCGGKJqMsm+MP/nKo+B8j4t7bXFxpOcVg8l9z8Xm43r18rrMTvSzJn2J1VUXcbnHNWGzuPpKKBQb27fsZ139a4hEnxkM7zheRRkWy1VpBO3ovShsqI6QSoVECigWxgMQQKJAJMAApD5S/8/NxrjEoZ/UvRwbajLGbpkVuFzmuF4V+ML1Eq9fLfF4UeByVUAxcDIRuHesieKtRzMwgCJlbXglANIGWhABgqs0ewN1rSqEwxPWg7DeQlZoQl3lClerAm9cr/BwucJnH13j9cscX3iyxDIrQEQ4niV4x9kUzx8neOcp42yalvM6nAgIYmOATUp7YB1bQGlrHiGz9r6yQmFlvMFFpvBwoXX1aJHj0SLHMmckgnA2l7g9S/D8fApmYJbKEpfWE5eYGLSW1h7sXw3kZdsyVzr8mxXaM7Sh11ypMhEnlUp70ax7USoFTHK9vqvgIInpvhmE9VRL39Rr17i5RmaM+zdJl1EOeT7WINtsxSaj3CfM1dfLsce04YqRUCbkJuTVhM1e1+Ly27dtcDLWDtZj9y8ggsDawjtszI7NosvsHFOucL3SBHFd5FjmCgqMhASOUom5lGDWRo8BCBIgYj1fIQBhjY49oMkYAzXPi1Glpds5plWucJ0VeLLI8cZyhc88usJnHizx+DrD5UI3wnyS4K23Z3j+ODF4CMwJpIlnClGFNom1J+Yu4m2CxVpJGpOqvJxVrkn1fJHj1ctrfO7JEr/w2hW+8Pgarz+4wmKRg4hwcjLBw+eP8cJt3eiZmum5unJuDiCtMBCXjB+Fy+pKk5fGtcw1OVyvCjxaZvj8xTU+/WCJB1cZHp4vsco1QZwdTXDvZILlXQUBwhmnSMwcGKDbMhGVrkJeaxO4ilx9r1V7XW7fWhQFFnlR9q15InGUyGpwwTDtJnQImDWdmaYLeoW7JjIi+jcAfCf02O1/Yeb/fsh1hqSrhyRkZGK9sKa5N2Dz0GHIIIckxjBuGqKLlb7eTt/1XV3i6qzJC+vjAYXatW0pBLC+1CCkk9AatVhpPbqJvOxnZVKCNTJKT/qvcoWrrMDD5RJXeYHrvAAzkAjCaZFgmSQmRVxbEikIUrEhL4B982KM3zrA6sFNry7JQjFWhZ7zemO5wmuXC3z6TpQaGgAAIABJREFUwRKf/cIFHp0vcHlpCGye4GqZ4/zWDLNU4CiRkERIEz1nl4uKXJmrMF25eHYd0jqhOjrKCj239Gi5wueeLPHpBwt8+vNPcP/+Je6/9giLywVIEE5un2C5zHG1zHE8lRBEOJ0kmKZCZwEKghQMYk1YAh6JteCyjzYjM3fI9ckqwxvLFX710QqfuX+F158s8Maja6xWBZJE4PbtGR5dTSEJOE4liGCSTASE0NcrYBI+4JCGBdHQlq5nWPYvn/hN33q0XOEqz3GZFygUl/OFq6Let3QyB0MwoJggoMOg7sDILwK8KyEiCeB/AvBVAH4dwD8hoh9h5p8PHa88bDHVEPoamLGlzShvQhSxXpiVvvOAsRJLrECg+G/Dom5gM+9rTOkKHfrih2TbvNG2wUbsIutBwUeXMKzBKRM4Ck0al1mOi1WO81WO86UCMyORBJ4zFIBZLjFJBKRgKKnPF0xwpjRqo+UmpnA9nfrIHSWeZa5wvsrw+mWOB08W+MKDSzx+vMTluVb27Ghahr9eP0nx1pNcj+YLiUJW67MsUZBJ5rBzKL7Ns+QA+4i6jrJCk9h5luG1ixz3nyxK8jr//OeA84eAkHh49TbIREIIwhduz3FrKvHW4xy38wlSada2WfJy9AYyOmnyJhxdVaRvPNZC4SLL8XiZ4bWLDK89usbDN67x4P4lslUGmUhkmUKeK5wdTfDCrRTzRCIrqvlO24ZsuBR+6NDF1ugpuinz1YDEJrqcZxkuVgUeLwyBJbpvMTNmJrlEmnMEMViQiRg4c19tOtqNfAWAX2bmXwEAIvoBAF8LIEhgY4lrZPqEu94McpNkAfRfg7ZP0oR9m30sfg6sLfSDikTsguFcMTKlsMgZCzPhPlECi1RhmigUrMoEAhvKYmNRuMmy1JitDWtFGIqBTCksjddzvSqwWORYXK+wvF6CTWLCYpHjepXjOtNGPCssQTgGOYClLRGg5vV44THrHV5nBa5XBa6vMiwuF5q8Lt8AhASmcyyv72CxyLHMClxnCpni8ruVoCK9hkrHLkZLFHWPZ5ErLFcFFssc19cZltfLksCuriaYzRIzV6bbWTm4NHnT2r1rXqHXxG5o038Ox5O184irQmGRq7JvKdZ9ayJ137KL1eGqqbFb3Vjx37cD+DXn9a8D+Er3ACL6AIAPAMA73/mu3SHrKUMrfhzkIJtIdNnfqB84VaWYpEmZT83aoFTaPx3+KueQnL9o6TiWSsT1Cht2fVCSCMhEIkmT6i8RkMKkzzvVLuw1Im7bCtO9BkHPzSRCmD9CkkqkkxSYzoFJ9VdikzpdXZIND1L4Rr0xumu2nIXApFPlk0QgTbWuZCIhE4k0FUiSav2XMGut1nC16MM/jGAxhM6n8jPbt6zeUqExJO5iatu3vPs09bEbIq8oYeYPMvPLzPzyc88/P8o13dHwWCPjMXZQftZkSLbfsyhNfaxtiUFseatBvU4bYT23ABNSE4IglSEKSZgmAkepvjwZT2WSEE5SPdE+T6RTVcIufq2ox5Jb7aY+CK6MlB1cW8ISxOWapJkUOEkT3D0qcOd4ijfO5pBS4HwiwQwcH6e4ezbD3dMp7s4THKUJ5jJBIm2JJJjKF5Wht3hcYiqnePQkWTmyJzNfpjFp/Uyknmt77jjBk9Mp7t6dI88L5Nk7sTq+AwiJo9unuHPvBGdnc5wdTXA217or9Saqxd/lICCACwZbicsULbZKI7s+z6zvmicSt6YJ7h2luHs6Lb2r5XKGJCGcnc1x59YMd48nuDWTOEq0ruzC9PpC5jqetbYMeNRlO1qd2XlSo7uZTdaAbpdCAakknJilEH7fkmZQRT5V3TxvfQ7AO53X7zDvjSYvHs+D81BPe9gwtEC3Tc7madQ82Pve/55eYcTY+S+gey3YNsVN8Xd11YWpqZpJSN59b75RCHTIIKjXGQRt/GDCZsQVWUgisPGwFDNO0gSKGTMpME/0eitJhONUG5lpKpAmVGavydLQVMZG3xPNhsYxfmZWqjSctuySksA0lTibpiiY8eRuoR9PJjg/m2kCmyV4y+053no6wdtuTXB7kmKe6qQEW6FDUPVnPQ3XQLswLVmUpApTfgk68WIiBYqUcTad4O23M+SKcbHIMZ0mmM9TXF/dBQnCrVtTvPjWE7xw5whfdGeCtx5PcGuSmmocVJKYXThcDSzqeGrPDYnBZAdKA9BWISkSxq1Jilwx3nGW4yo7xtE0wclRilWmkEjC2fEUd04meMfZBPdmGpNe/K09StuOlSdE9fs3tKM7GBEgFMzOwnedVMMQOE4lFE8wlQVmiYRiRkKEoyTBkVmIPinx1Ash+wOjG/a+/gmAdxPRF0MT19cD+MM3CShUZ9CVMT2tPmQRSxRjpGYPFZ9Ugf54NiUBV3qRa0S7nswSXCzy1sFA18BobK+0FbX9oa9lZlGVzCCsIZQAIJAmDCJZembHicJKKSjWBGarXMxTWZZHsp4OGU+nDC2ae+mHdUPDxupVmyrqhbPSBEZTSWAQZqnAnekECQmou4xZQni8mOJ8qReFnkwE3nKa4s5crwO7PUsxTYWpMiHqniIC5OWHw4y+BJk0chDsumNLEgzg1jTFC0czpCZH/97pFPfPZrheFSACbs0nePFshhdOU3zR2Rz3ZhMcTUz1i8RUCSEq9VYrxxXA5ZKE1hVDkSbXRBJSs3i7KBhEE+SsIAh4eJLiwdUMWaHT48/mCe4cSbz9ZIbnZlMcTRJMUoGJMyCxnqtLqE1tadvRPli92WUMgMY3YaHPNX3rKJHBvjVLZY3kbSUVG4a0Ohhaq3EsYeaciP4YgH8AnUb/3cz8/21yzZCRsUYjdiEz0FwtoQ8Ge81XL69Lw/zel85qGXYxJNZWWcLF7ZOFi8OVMTCFcPn38LH40kYILqa+XqGPbQxibZImD7/pWP/+m4QPgUgPzCUynTrO1RwDqCQMAJhCQBoLLgUhVwIzk/9LABJpi9OaUbKgslxTFUrsJi/3fSYuScwaQEsWNnypGJBmvuY4TXBdFFjm2jOcSIHTNMVxmuD2LMXRRNbwVR6YDbeVABoUZh7YM8YKkBJIWQAEKCXxFp5qr0EKvOP2BPcvZ7jOFIh0JY63nKS4PUnx/FwTxXyiPQxbg7CplmQXLnugFPo1M8AJQZCAmkrj1c0xFRJvOcpxkeXIWXvaR4kOG96dTXA81d70NJEBj6e5NFhTO1p8ZEYmti0ZwixYrkKKhRJl2S2Cbt9EiKrt7OCIqrmxTQsNjy3M/GEAHx5yrrvfVSjU4xvG2NHv0FJSPoY+YTugucqFK01VOGo4XMwOibXhCZGYj6kNWxtJxA4A2shgqLfatxZiSNx2bRogDR0cufcYIoNrIdbq1Sl2sg+denqFU+4H2mjYEXEqdTFYW9V8aL3BEot+UiuPVGHRGYh2EezVqsBKFVgW2gNLhZ6PmiYSs4nAfKLDhy6BJWZdUQy+pgohNrU/K6pqJVcrXeLqyTLDZabTw1eF0iWbEolbhlhPZwmmicY2TU3yxwC9tVW8sJUtliYT83pVYLFSWBZ6LV+uuPR05lJiNpGYG7KfJo5X2FHFv7MtG/S21re4KlMW7Fum3fpu97LPtRB/4mM/U3tv7F2PXekir9CGkdssTjtWMd8xC/m6uPpUo+/aPqVv2a02UrXYuqrRA/32KrOY+0hocNRVyHf07VSaSKy2FYcxiLZcEWCNTJUVWI6OIwxe0yi5hkU/KQvU2r22cqVKo2crhbg1GoWotgaZpsKsT6sy7BKx7uEMIlZUi6xtjcZlXiAvuCzqmxUKudJzeYn1VKXANJVIEyq9L1nzWofjWiMxv3J/rspFzmxWcduQqtWVrUwfQ15d7VjiM6/X9Ob1Lft5VN/yyL0Jy9NEYEAziQGbb6UCxG2nss1q9EO3UwnJPm2l4pPYNirkx+Lqs0WOxetKF5E1DY5iyAvAuAQGrJOYa2jKjRntPlLOeTYMJ6k+uT5kzy0fi4vHJVVbDNZ6P7ZKviVWS1KiTMl2CcIJGwa8mxC+pgomlizKbV6KCo8tTmurrAN2zy2brm7CrU5YzIY10UNvjbpySMwtzJyZrWf0/lsmm1JU2FKp9dZFXrFhutCAxNfbWt8yIdFQ3xqyKek+E1jMdirAdjazBNrnJzbZD8xKW7HeoRtaNukiBlOIOHx8Q/cBc7GNsW+aj21T8rIy5gCpzxYqlryALRAY0OCJcUVo1SLgygOzhsPdWdhOsNtjNOC2O/fDYw1z015S1ujZ7MWmnY/74oshC0umNVI159mSSHaLkKaNI4fozScKW/UCDKfAr62soathWKYo14o5pFXzUjdsyza99e1bIYLvwrPvBAasV6XX78Vv+d4mfYkrhGHM3Y/bvC5g812Ph2DqwrXJNiWhOpZDdq6OwdW3XX3M5esOIuu7E7NLXsCWCAwIk0ZZRYHrx2gg1Wh4E6+rDx53Ww5LHOXIvcSC0rto8wrHItaqTJLBxFVIzMXlEisR1shrE735RFFWDDGejSV9+351o2rB81pyy5bbckjf0g8UjeVpJTD9ftiQdJFZk6HtkxHm33+sKuZAf6+rSYZgaqsb2YZryCagIVxDivy2hVf7klcILzBsgBQTjvbJC9gigQHNYZ9Q6SKXCMYmryY8vmG2RrmGyxKYMcZ9w069MLn64SrMCQ+bO3dThcLGJYqQt6PYIzSE9RXCBIyjLx9frZA0+vetPlieBgIDmklMf7ZZaae+xq3p3k3zJv6cSchID9kIEWgnilhMmy456PIwQti2ratYTG0y5gAplryALRMY0ExiQTDOkzGNXSMen1AD2FyDNzZ5BTFZPAGycMX1JMbyCJuwNWVPmrdqQtgO0Tdh0xiG9a2+mJ4WArPSRmT683gyizFsrpGJ8QTHzI7sQ1xtmFxcQ7Pqhuws3AeXj60LX2wWaSxxbGuA1KSTJvICmglstGX1RCjXiQGo1mYFD7YP27MTLh6LhQhgEEIm2ScuF99YBrmGCVwz/Apmc0q7ZxXqxNA303AQPr/tXGU4+gp5OtuUTfrW2GS6j3I6E63GZhNvyr9P03v+/f01aoDZS8zbJTl2Qe2QzMh1rPW0f7u+ycXk4gmRRXAN0wbk5R4XWtPXV19D9NREHG39ysccI236aCOvNhm1OJc1NEBFHI3Hjhw2bMPjYqkWPK/vxuvC2BpJBIgVsJtooqpTiG6iGFNvbtuZmzskBrjV5Wv62hFhDO1bbxbpIrFNrz3k/k2EAawb5iYZg7hCx49NFpvisuf4pA/UiT9WYvF0tW3TACV03RCZ9fXo+8qoBOaL9TRC75fPb8DWEEw+HdXfs092ha80xC6R3iBR+B5iSWLO/WtPb9Db2de+dZPSZWw2uebw85tJDOhXpmrMOoxNHqKPySfYYEmogWQRaqeQZ9O0ALoLR188bRIzQBpG2pv1r9EJzB/J+4Zm16PjkFG2D+sHr5+7TUzufZt2K74pG7zebs3H7Ur2rW/tq2zTGxvjvn0qnLffr918xYRW28gViKvWHoOpKfzaN0TXh8THDtndVL9qk83oL1LKEbpnYN5sI+SnUpqZay/k0Le2K2MYrLHm4Hxpm3+xBrqvoe5DEGN4hKcz0YpxqO62Md+0j7KTb9K1m/NBnkLZkyY99K11GXuUfL5QUdeMXZsW8r4uFvna39oxy3zt3CYSc7H0JYh925xz7AHAPnlRm2LZKRWvbWe/57Zn1/j2Uh0doPaFQJ62vrUNiSWabVx/CHm1kVXb531IrEsnoXNjw5uh42IINSRje0WbrgMMX3M7fWuT644+1FhbGOt/Dt7pXEVoDZHzUArZN2n7GNvWNa0ZXqpj26a0tV2bvnYl+9a39kl2uRYs1uDErgUDmtc32UxAe06ZKbjMa57S+SIfxVPpOzfn42jDcr5QjUS1jTVX9rwmLPqzOOKM88DbQrrdfWoIiW/NV14zMI6xcw0N8/bmK9bIwKvkUBObUecZ5W3is2BcPOt6oxqJ6TR72q7eOohVr6dzV4htH1MQX/XGzvvWPknfslLd16vOG6NiQ2yFiZC4x5zN0xqRlVmD0yrhoQ/eTer71TIVPRxtWEKGegh5NRFtKPzZppcu4hhrYBTTp4aQ2KgE1uTtVAc4T2l3hia0PUcNj5u+bjICXXyjYnF15Fa8CFQI0bDYbORIWyWMqHJg1kO1i4qdtWLbJrF97Vs3LX3IK9a78A2xlSGFX8eqh/ji8bw8L0RkfUmsT/WLkLjH9PUKh3iwPsZGXO4ShUA79vHGtlWJowtLHxIbjcBiw2LkeDrl4uItGL5ehWBZ7/RrkK2R2FjY2uoh2ufKURYRQKyrcChDEMJAHDNc1tR2tvp7zWMtdaGPFsYdc/Wz1bZ08LmfAbvrW/sim1SkDxng0DmxRjB0/5gq60B3pfV336t2/A0RWV8Siykp5eMNSSi8ualX2Iav9l4DgQz1DPVnw4i1CeMatkCoFQjVrownsVEIrKngqmLnBaqn2x69N1WkB6NWONetxKGMlyOsmxEgMXvsmJhsDcRaxXxzDsHucWUrvzOUR2LWcxwLF1Av5usWF3Z1QAQIUEms+oPxSWPf+ta+SBd59QmHhT5zvQqgncjaDFrfbUvsflfuvlah4yyRtZGYi9HH7mJ0cbpYu8QlUnuNkDfWh8S25RkCm5FqF7YYaRsYDSWx7W2n4ngV/mJTawC3UTi3jSjsRoh2zy1rpP2q70N3FR6CyW5Z4m7WaI8v97Uiuyt0tZ2Kq8Mxcdm2s0Rvt55hrnRl283dEbppc80xq+QP6ltU/yxGnoZivj6BjWWY2wrCApvtb3WTux83YQzhtBIT3uyzzcsYxYZDOH3ZpKhvX2zl6why3aRO4043tHRH7uwRhTUkpcFrIIohhs/H4+8SbTezXN/Q0u63Zbajb9h7S0OMx9dkhP0NLQuld2fWRGb2BIP2vuzuy/bR4iv1tiVc9rEwm2yyS6xmp2p380+XzDZtyy58sX1raLX8fSewGPLqIi7fOPvbcQDxVeBdiSWvWOLyxRLZGLsgh3C6WK34HmDbvmBDSWzsSvkuliF4unCVrwfMhQ3Z3HJ0AusiC3ezRvcW1qNwt33f1NtpNHiGDDRRKBSKkRWMrFDaECpLYNXuwqkkpLLa/djdtBGR+Nbw6CelEbY6ygvGqlDIDSaNT5kkCU0UidS4ponQ5CUFEjHcS2wjhxKX2R06Kxh5oVCYtrTRVd12WleJFCWptmGKJbG2+Ti3b9nn/hxYSaai2nCzL4ntM4H9xMd+pvZeLHltunkk0G54YjZkbCKvj37kl1rxvO/976m9biOxLqLdh12ZY/crG+oZNu0N1rf48FjbvPg4SgyRpDo6gQXJiyuyKJhRFMYQGoMDaOMhnZCY61W0GWOgH1FYPIUxdFmhkBmiWOYKq1yThUtgaUJIhMAk0X+J1AZalOG7/luarGEyBG/JdJUzlnmBLGcsswKrwmBjPW+TCsIkFUilwCyVSCVhal673s8muEIeYe7pKi/0AMASq5SVrqapJtQ00Y827DkGsQINfct4rLaN9W0i+lakt/o0ElhswgTQbJx9z6IrPBaSPuTVRVy+uEQWIrEuQz02eVnZhMT6kFffnZn77mIdM6fpYvPxxcqQzTZvzeU4+4EF501QkUXN0zHGWCl9jBtq4oTAEJBmnk4KnRAgiNayyNz7BjEFyKs0eMarWWQKWa5wvSpwZcmiUFBgTKXAUZIglQLzidREwwJk8BEB0qBxkztcfEE8rr4cTLkh92Ve4HpZYJkrPF5kuMpznGc5VoUCAZgnErcmKY7TBIViTBNR3rPUh7DJHmG9telqjbwMUS0zrZvFSmGRaXzXRY5cMSQRplJilgjMUwlmidTgQiKQCIB4vS1j2rHE5813NXnRehBSJWpYUvf7liACBEMYFLtYS7cNUZ7uYlKZ+xhm+7k1yK9eXq+N5t1Ehdh7j0Fe9hxLYp985RHe+9IZPvXgusRrkzo2kT7zc5ZEXQyx0jeTr2/Wpj2nT/vFrDnru1O0FReH205Dskhd6UVgTXNeSkEnR5RhJ22cradTFOZEAlITAmMW2kBJgq1o5ZOYm0XWiMkzyJp8qjmvzHgSi1WBRabwxmKFN5YrXGU5rjI9lzBLBW5NUpymCe7wBEACleg5KIbQHo5Yz1C0+BqAlToLYcoKTaYXyxyPlxleu1rg4XWO1y8yXGcKRITbM4kXTlOczVK8wDMcTxLjCRImCYFIlNmAbPQbjQvrnpf2VBmLTGGZF7hY5Hi4WOEiz3GxypEVjEQQjlOJozTBvdkEDGCquPRyrEhRxxSzrs5idsmrcDA29S2GJiK3b+kLCX1HQ6olHveeTxmJhaRP0kSMuAbZGsGQ0VnD0RDyAjYnL/dcP6To4vTxtaWgb5pcYknUnmvT/bsyJLtkU++wq/3K+0RgiiGvGM/QXQZhz990sAH0ILC1uQn7XmmgnfCO0mGnVa5qoURJetSryoQJNgkUDGbSxzQY41ZPxxmxg+vzJNazWOUK11mBx6sMr1+u8HhR4HJVAACOJgL5MaNQChOpQ3SCgFwRiFgTK2swwo7egbWqHQ6w8qEi+0pHudIhzVWucL7K8XiV4TfOV3jtIsfr50tcr3IIIjyepYZYGHMpIYh0iFMJFKrSG8N4XuyQKxqwYV1Xdj7Qtp2L7eFyhceLHA+vcqxyRiI1sZ7NFVKhvTEiIC0ECskgBTBpfflZkra9utrSvrY43QSctr6lFKBk1bcA3XZlwocl0YBXuGsSI6I/BOBbAXwpgK9g5o+Pcd0u8moyzG6Wnz3P9yraSMyfExlKnn3EJZChsklm5FgYgOHLDpqkzSvs40WHZJOwZsgrLHH1IHkrnUcHQz6Ot2ONjBuu03M62sNYFgrXuSYKSYQjJY3R03MlgDBExnqUTPamZs6iy6NwcFpPRxtk1Izx5arAw+USr14s8MrDFR5fZbhY6IY4miY4Xyq85aSAFAIzY5QTqX0bKbhM4hCGMEqD1+LoVCQBk3TgEeqqwMPFEq9erPDL9xe4/2SB1x5eYbHIIQTh+HiCRXaMy9UMs1R7FVMzRydIh+uUMKTApatTeRkBbKV34xGEYhv2ZSyyAufLHPcXS/zqoyVev8jxxuUSWa4gBeH28QT3jlIQARMpQDT5/9v73ldbmuysZ1V17x/33Htz319mJsmMERwCQwgYL6IIBsyAo0RDQgT9IMQIg6CgIATD/AkBvxhBBxS/DIqgEiGEZAbEgDjiGAaZOCZEURyJ3Jh33jf33nPO3ru7lh/qR1fXruqu7t299z739gP3nnP27t317OpiPbVWrVqFlVQoJJmwq3mWZpz4kxGg2zv0+80XL+sh7ivVGlv3dQ3FjIIEHpUSayVdUg5IoVCNqIfP7sJlp74J4CcB/KMxHz5aO8kIJ3YZ5tj+K4suoxO23bcmcor3lcKQMGKXlzgljznuPRZjvbChe9AsfK5d/RF6qT5yw4idV4TiFfW+YrN4KxpVhbuqxn1VQwEoSIcIFev08LIm1MTOm1CsDY00liTl4ASkGlZH3qAJPVUKrw8VXu4rvHhZ4cXv3+Pj13u8vDuAGbjZNt3wbHvAO+sShSBUpYJUZFLItSHUG54boUCEI7uf7IU12fWPFbHbqsZ37g948fKAFx/f4cWHt3jx4jV2d3uQIDx5uoGU+u7f/bjAthB4t1rhUGshqZkh2azrcJPIkeo7n1fLU/U9HPvsDhU+vDvg/7484MOXO/zey3vsDwpSEnYmsePpRuLZqsJGSmxqiZViKOGluHPjGfqTkdRzhMfPhjiVnQCYxKDahF9vzbi6rSo3tmpm1KX2EktFEErohBgFwIY0rWxFuPStz00JZv4WoJNOTsEUB0OObvvEmfw1Ymx6v48+wZ8KPtcpvMChiHlfodDOKerABJU47D6clvdjDM6hZhwUY1crbZCIsJIKB6VcirtNumBuEhOsoaEua9xc6HgAaGb97r564/JBKexqhduDwu1OH9FwZwQMAG43FV7vCr3+Y1LH/SQC5xn0GWLLh49/dx6PTVNXCvcV49Ve4fV9hbu7Cve3O9zf3kMIASkl7u4OuLup8GqvEysOyt8LxS4cBtBxv/Xw8l/zv+vBcLvdK9ztKtzuKtzeHXAwArYuJTalxN1BP8uDUg0Xz7vzOylnMuJTczy9UKcyz7I2/HZK90fNDEWEUihUSpj+9b6X9x0f2noXEX0BwBcA4FOf+vSF2YzDFKLwkDBUvKaYhEwVyuzDHJ7rKZj0EBrfOJD5W0B7VHbvkECwMZja/5rPT2dpXOUIAqRo9lcJQZDS/BPNJmFJpD9jvsgRk4HUmvRt7/Mm+UIQUAjtkUpJEFJAFhJCCv27FJqv8DZVw/YPeb/b2w7vN9fvNkxKaO2Nk4IgpTB9JVyauk1bn/JZHZOzP8itqem0H11Sy/aCcOny+oVwLLa+55lARF8lom9G/v147j2Y+UvM/JyZn7//wQdz0k0iZZCvxfvyZ/hTJAZMwePcOJcHNrR/u/qk616zZCHq5AUztyYbtmqqHgiT8CCNMGwLk3xOOgwniLAp9BpYIYS3j8kKhicc7YZThNy03XKzRkyRNmrSGNttoTPnnm0KvHOzhiC9d4lZr4F9180K7z4qcFMaflbg7GZYHItsJzUCwO3+IiOgWigF1oXA07XEs22BZzdr7CuFw0Hh9nYFIuDp0zXeebLGs0crPNtKPCokVmYPmN5rBWesc3i5ECOTTmJgagmANKK1kgJbKXWyxqOytb5ZmDWwp9sVnm40p7URN+H2y5ETnKO2U7BLeF7/WW72mbpKJFKYLQU6K7NmRkH6GYdjSyT6J8VlSpFj5s9Nd7f50WcEuzY19933oXhhQ7leInQ3tO1wb5qPU06f/uTN9iiMOEbET5kIdX7SLXaHYScvjCagxUISgY2noArCWkkwA6UQ2NcoEjAAAAAf90lEQVQKdh/YVup9Q6tCmEoOTeUEZ2ioMWBoGUE/JOWUy8tWNCnlBFdJoxA6c+9xWaJmxvc8rVAz44lJbWUGHq10uvp7NwWerVe4KaXbzGy52Q2x1stx/AKO4JauNmnupJfNrHiVBeNxWeCdzQr1dwGv9ltsVhKblcTtfQUiwtNHJb7n3Uf45NMVPrhZ4dl6hXUhTbq4cKLT2sjcwcu9ZESMyAi+AKTSk46SCetC4smK8f52hftnCttSYLsucKh0osY72wLvPirwBx6t8HRVYltqYS1MfwuPR6wGYThFadcztO+zmxyxfZaSwCDUSuAxF1gJhVUtomOr8MeW7SPPg4vhoYUXAW2AckNQKeMcM4RhlYtODpsie5H/T/3ID0yWyOHzPsea0xAMKW2V8ww/8952UCJHl5Bc0nPuek5jxDTrE9bbAjxPB3pGbPdtCaFT4AspnAW36dUbxc7IFKaKw7oUrnqDX7KpZWRa4bKAk3mNjWIQN3zICGohCCwFVgVju5IgWkEpLaqvH9e4PSgoZjwqBd7ZlHhclnhvu8J2JbEqhZdS71dzoKi4esT0D7depskJE09VrPdwMQQ2K4n36zUKEsAHwPuPCrx7s8Ldodb7wNYSn3ha4r1tie/ebvBkVWBTCpSFrhLiV5mA5RfwCHlZgbWhUbt3S0qgNPun6hWDqMD7vAYR4dnmgA8eN/vAnq4lbsoC723WeLwudJUQX/BdFuDxRCT1LNlTfjIfEGCwmSGxJLO5HEBpxpYSWNeJsSX1BEl448uJaYTLBcKLPwHg7wP4AMAvEdE3mPnPjL1fSkRCw5cza48Zv1zv69m2xEd3h+jsfAqEe8Bi4cOw2kSrCrrpp5Cn3085XljYj0MEf250VQbx0ScYft/548v2nb3/kDPdLLoquwwpMjy4lFR0M7PiVtmmWjU1/mzJJpu+bEOMVhzszFoKatYygE6Dd8QJjlSrjJSfsn5/0Nl1t/sKr/c1drWuxgFoQbspC11dwnhBpdSG0HpxrQK6Pfxi+9P8ihK2b+4PNW53NXaHGt/Z7fH6UOPl/oBdrbRHUegN1o/LEk83BdaFxKO1xKbUHlgRiFiXx9ri5iWV2GdjQ4S2hJStWnK3r3FX6+oldm/XtpDYSIlHqwLblURZEDbGa5VGSEJOuetksUoc/rMcM7a6ylvFhOtaS0n98B99zv/u3zelpPrKSA3dQ5QqJZUrXnOWkQLSpaRyaiGeUkaqL9tv7ur4c5UCy95YfUIljtwi0VdaC1GhViYbEHCeEbnZsud9iWY9LXeG3Mr0S4iYFdV9pUxVDq+Kg6nNI6mp5bcq9fqKLxCxmoMhv2g/eWJhayH6FfGtsB7sz1pp8VBK77ESQocMC8LWeDnrou25xsQrt+KF6ys0m76dkCm9l29X1a0Nw4Tm2a0K4Wo1rqToFYvUc4w+y4SIuc3p4diCrZLfHltjCgw/NAED8kTMom+fTu5MORb6irXftUk4V8iG1kF8CIV8z1EHMfdEgdw6iD6/kGMfUsV8r7IavTvnyhggoFkPsUYuPE9qiMGLcTni44lqU+29qbDuwqLe7N2Gnnzh6iuYG3JMCWvorVZKYV+Z6hfmZ117x6mIpjxSs66TVzS3j5ffV4zjavR2T9ihbvav2Y/bfrGV+1te9ECxCNEaVzhO8Z9qbHXxuVYBG1LMFxhuAHOq0A/Z9PrR3SG70kVMyGIlo8aKVx9P4HRPZ8xRKkPPccutN+jz6eKUw6uPX4xnjEMfl6s9D8xVo6fA0Bhva4rzwJIi5nkX/lEhKhAwbfjOdB6YF7aralNequaWcbbeqE4iaSrjn/s8sEopU0nES7QgctmUlz4PrGtsvYnngY09TiUXucenxDDHQZY+co5RmeIwy6nWdHLP3ZrylGifSxefPk4hrxi/kGMfxpwDZjGLgAFxEbMzZvc72rNkTaj5e4wRHsKn60Rmn5c1wOc+kdn+dIbZ43XpE5lDT0e3o1ttp6pf14nMNjnFH1u5XK5ZwHIPtATyz2ya4hTmsP3cEF2OkPWdxnxKuM7n6vPNRd96TsgjhdxnGOOZ2k91iniluMU4DsWQk5gtZhMwoMMQemtATYv2x7QGr49P6jRfy8U3fFYYxnpeYzi5Axr1RbZRt/+pnQl5upfTxSsUMaD5qZudx4tOcYvym3FsPTQBA9IGEMifJecI15CDD/sO1hyTFp6z1nSqt+PzjWHswYx9mOL0475nOJSTj1OELDUJyhEvYGYBA47XLnz74jfRzIgxmTj08knM3n1YUYilyQ+ZvQ/lpLgd7gx5He1hmthjPeLl/W25hf0V9aI1ofmfpf5l1rF17QIGoFfEgHGz5FzRiqFPHIYcstmVXDJWvGI8U1xzMDQkloMpnmHI5VROIXLOoetDiktMvIAzCBgQNzRxNvbH+PDXYD7OKAccHaXG0J3NGEc8Cp+Vb4inCmdm8dK/RMN0Dbd0Vubsz9Lwi2KCsfUQBAyIi5h+fdhMecjsuA9TJiUA/YklY0VjKqEIOXTx8I1z6tnFuFn0cRz7HGOi0cWvuWZYn43hYZESsEm3ZBPBlZcC4E4Hjl47s3iFfCwXAW37CE3x4K6Z+9yciM1rMEd9ILFm6HHz7zULL7AWSkPIPU9ut3ku8Qr5AZcfW9eAJxsRNTSxlOgh61inzNSfbArXrm3z1c47YNJsIgbgNhL3IScpYSjnsI9Se8ZSGOLhxAyzfS33+aXa7MIpgtHFL/f+ueji0YfJa4pYQwN4xiZYaA+vnxNJwxxr+wLG2Bpi/3iPlgE+I7eYSPg6Eeuvc4rFtY2ta0BKxPR76SSG1HV9bYVIGeBQPP2KDkBbyHIwNCEh5NrXR2PFPtV+ikfs/VOf3xA+OZxS1+Z4ZUNwinBZTC5gQNvQAGlv5twGxhcxAK1kCf+as3DpENbji9vc5uy38Nkd9ZX/WvC5c+Bax9YlMfdsecxMPeXhhEIGpNedUpunwzZy+Pb1UddG3hSmEoqH4u3k8Jyz/RhmEbAcnNPAhDN3vxBw67oLhZ5awtqRWXdudPWVff8a8TaJl4+u2fzY+53adswbA9phupzismPWmYbwTN03FLRTvNWcz0zt5cyBIWtmUwtWiNkE7GgmvyAPvohdyBAnBf9KsIytNKaYJfv3GfqZHBED4kKWQm5Ib0qPp7l2uIk81ct5CCIWYm6hSuEyrS7oBiEpXtfiXVyr97VA41IGJdVuSgger4ukQKXeu4Zw2kPFQxTHLlwshLgggZ61pjATcBYK4Qbi2DXgRcTeYFhDN7cn1oVXuyoqYC/vq8SGajWY70P0eHL6sHsz9/B+ulbM9i36QjyXCgF1hcP8987JL7m3aQmTRXGtY+uaMJVRntK4p/andYURU+9PsZlW32d68Trlnn37w3K/d9+1D020U5jFA7s2A5K1CZaaa87hWaQ4HeVw2Nep4TWnFxb1vhL95ffVOTzDkN+COKY2TkO9sdz2h2weTnljsban9i5iQtBfCHcYjzEbmy26+sZ+diqP9dowewgxVfECOJ/RCwgd/UpHf5j3Z+J3ZIQDnfA3WHvbw84atusSVtdfdGZOQb+lKoTYa69lvfCc6BOPU/aDnRJWHFvnr5Vuv2un5J8aSjxFNPz3U/12Ko8hFVVir/uilhKyuUTseFvFPEI5uYAdeRbuDTiDB5zH0MSKwVoqHAiZq3jBTZUHW61jNn5BOSn3msef9G7hI09sDl65NQfh9ZUvYmfzwhJjy773NorYKcY4dt3YNZShNRr7ag/677tN0J7HMVbEpuiv8PoUD/1efn/FOMQEKtZ3XYJv7ztVEoyP/onTPII26TfpDYv5e4jPJBKOjycUsUrmjEAsZvLEcmohtktcseNG1Ajs1P0WqxuZ6q/GWSW3iDqnsB7x80ikxtbbJGJDZvD590wbZb/NvkoNUx718uq+GiRiKQztrz7vxv/8EG8sh8fQivR9gh/jeYoXNjZcfYo372MyAesygK3rAGeI55q9p47h8Cu/u/cMhNmAxTCFc2fwxAZXo2fbVwTRFCacXMS6RDU8egbQfKy4qjMJq89P/949ts45QbokTpnBp5ATeuprvwtDzt+y71shGyJiY0XD3rvzO/gbsTM9nKHh3bFnlvl9BWgh61tDnHLNbghOFbJJBKxl4BJehYXdp0tmjkyYb/beOpnZHKNiz97yxYIIYNOuFARlRHVK7yIlXu4cMEb6QEsALHTKKKEtsHPxsv3mc7LtEOCOdZHAkehPLawhv5yxdS7P8NowxBD7YhD7zKmhpyGnRaeq0ttiv76QDRWxITx9rrno83ByMORMtT6kRP8Ur7XNdZ7MzTEidrKAhR6D70n4hs8ix6Ow143l44upFa+a2ycfK4YfC4MgBplG9UGN03gXMSNs+0iphk/zE44YEUEqghAMCQJTI7AxwRjabynxsmJq+THa/UWk2xdCC78gAkSc0yTCarpkyNia2zO8BnSdzAzkrTWFr4drKGMNc5d4DTlOxb7vC1koYqfg1INAc8N0QzBW7C3CvrL36hOxU9YN7f36MPX+tJNGgG9knFExnk6tPK/C+4w+YdjM2hH3KOy9xwqFIdUSr1o1BrlSqnXasD3xWAoGWEAKQBFQCM+7QDvcCfTzS4qXEVDLpVaMqtYctZA1Hk4hNJ9C6p9AWsRy+60rxGpF3v9nhdV+f0GAEATJhEJAP0g1nYjFwtG+F901tub0Vq8JfcakT7zCWXp47VSGucubGXKo5e+8vkuK2FjPYopTrFPe4BAuU4l9eN0nb7YtETsFUyW99IWkh2L0XY5m755h9j0Ka3gs7DH0XbN3YNjaRZZQGIE41IyqVqiNh6E5AVKSFgYJlCB3ErIA+Y7akVgAxxyP+OhfTPiLXduVUthXbH4q1DWjMv0GaKEqJaMQBMVAIYyqIu315PLy+8qKlw1nVka4qlrh4AmrfR5a7AmlJEAKMAOF1N7PKd5hrN9cyDDhRcfGFgOA0M8uxedNEDEfQw+STL3Wt9Y0lEvIw7bnG+NQuMLXrZD5InYqkgkbHWLvIye5ZCiPXPFK9RcQF/0uwT/mk79uGPIfgqmqqYwSsPiifyMW1ghWNbvX7exdGqMrmVBIfZ/Q8A3JAOwK0Vmh8IVrXxmxUPp9AJBEKKRAIa2xFShEszZGAoiFO2McWtwi4S/FaHHaVwqHWuH+UKOqGYdK4aAYREApBFYFo5RawFRhT0HWLgaxEdcTeIVhQytcleG2r1TzLN0zJBSSoFiAARRNJ432DpPJGmG/secZqvTYAnAcckXbi36oItYVOhy78O9fNyZhIoaUQc41xv41oYgNMcq5PEN09Vno2aRCmt1JHXnGf0h/haLfh77kl6lOjh6atZmLwZ9OJiNYA+iM4LGnQ8RQrGfJ+m8jEATIxGzZb9N+Jnwt5OOHNGvWXA61wqFSuD8o7A41KsU4GGKSCOtCao/C8mLhvBxl1+xc9l1jCJP9FHpeCERCaT67qsa+Urjb1bitarw+VDgoBSLCWgo8KUtsCmEyNoVbn7M8DWPNKyJifbxswoYVBStW+1phVzXCuqv0s5SkPa9SCihmLQpSQAjWz1VpT5H9Z4W0dxh9ju73oN8SY4vNuKkVuTArEYzIN140AYMmR3OCiH4ewJ8HsAfw3wH8VWb+aKr7d4lXGIoKvZpTwk5DZuQ54jWWQ/dayzSCn+qnMWI6ldiHCAV/CIaKV19JsNw+GeKFDVoxS83owZ6hMTPjSunw06Ey4mEE5FApPcM3a1JWaGySADeT75Yx8zl0Gj1zHxfGVDZ0qIxRrvHqUOHj3QHf2e3xnd0eH+8PuD1U2FmPI1iPamXime9r241yPAobNt/NN8TWA9sdFD7eH/DRbo/fu9/hxe0Ov3u7w4f3e3y02+PVocL+oHComlBowwlHLHJ4tfuq4aact9pwe7Wv8PFec/lot8fLfYW7gxbefa3cOp57noj3Vd9z9Ih6oUM7QeKjsdVMTLgZV97Y8seXzyfWNxfAVwD8IDP/EIDfAvBzOR/K8b6GiFfqNXfPhCBNVYswF3OJXQy53uo5MfT7p67PXdubUry6rjl1HJ2WxAHPYPFxKMr/Z2fJFlIxaqGPrLdJCy3fwUyZ+zwdn0wjfG1eLuxkjPLtocZdXWNf12AGVlJAmMT+QhJWSuhMNmYIG6Pz2rDeDmIeRsI4tj1DnRRhvYldpfD6UOHlocKHdxXuD9qbOawZUuj1uEdFASkUaiWMqDbG2dKxocQcXjHBs2tgyvNab6sKt4cat1WFSjGEIL0WBdYhTqmfo1IMJRgCADM5ToMScYKJiO9J24nE0LHFTHpdlQmxYXQpL4yZf9X782sAfmruNruEasr1pRhiHsU1IdewhxjrrU41Afj1//kRfvj7n01yr7EYuu1gSozaPZZjpGEMtf0HbkKNbK9lJO40Hq3U6ogRrJlRsUKt9FpTxfafQsXKy27jlheQ9Bb8dpP9ol/3RdWJhvHIKtZhu31lftaMXW0yFFm5jDv7f64n0cXLdJHjZn+67+/6y4QWWYua/dtmBba85hivCR+yG1tgb3ylx1ZrPFwvfgbAL09903N7El1ZfdeCc3uOC+bFKA8sdUrv0USWvH9sNi97E+G5Zr7OQwppkN3kSnqPFZH2smA3VtvN1YQsr89vM9EnOZ+z6d9SkPsHNOn7wmPjfsuk1+cZuuu8+9nP2L4Q1FS4kKbfBJoHeXYHhryfhpcdW+6SM4yzPhDRVwF8IvLWF5n5F801XwRQAfhy4h5fAPAFAPj0pz89E9MFYzFFivopYj/U+5pi79w14aRvE0TSzN4lk34u9CZcY4G1gJn9VsKExeyeMF88jtvItz7W4DLY7aPSfHSbUhBWUmDtp6IDKAVhW0hspICUeoOu5WbT6ckaS994BhxTYmEDauTd0wqBFISVENgWEhUznqwVSqn75mYlsS0k1oVwaf5CmO+EttGOGWm/70KB9Z+dE26zmVuIRkzXUkCxhGKd9i9Ncsm6EGaPmn2eTYq9649IX+VCT0JIc7I87dgyfdeU2/DGFjVjy17bxWFOcWPmz3W9T0Q/DeDHAPwoc9xPZOYvAfgSADx//nzQDOnZtsz2wlLhw5TBm6MgbBdys+qA83M7FY/XxeQea9hfKaG9dF/F2p8tjV5n50VeQ2MopBEsZgJLoas2mA+FXoYw4hIKhM0WyxUvgl3naDwF6znorUpkUuR1WvpTLnEvFDYmC7EQeo2plFrgCqFT6n3xsoY+1naUj3Y5vZqPJhuOoCtrsE7dXxU6XPdUlShIoCByWYgbKfF0VeCmKLAqBEqpBUMaQfb7yv2gPF62r5yIGWNfCKAWAiyBumBsWaIUAqUQqNgKmMRKCqwK3U9F63k2zxI9fPr42Y/7z9IfW4K5ycjE8diyY9KKqt8/lwYRfR7AzwL4EWa+PUebn7zZRtegQvGKGbucDDL/xOXQKFsxTXHogm+MLVfL0Qpsbobb0FOhu+D3ky/0Q/sqB595bzsqkWXOdc2hGLvNoQuj72hFoxELPb8XZs8UG0shBbmNuQQ476uQbUNjw3spIxObKR/NWa14EUGAdXEIASdeBLvgD6yUQG2q+gqh08ILSVgVAquCnHdxJLQevy6j7Hs8jfhx40EI6P1dpXAhz7WU2BQSNWthXQmJTSmwkgKbUqKUgYgZQjbUOIiXJ/QwpaFsCnphlEKVmn8lGaUUei2T4AR+XRgRO+or71lG+HQ9S+dBu++jnyULuN60Y0uxqZ6C+NhyfII2jzzEy+AXAKwBfMWUMPsaM//1KW78eFO4pITQC+szaCmj7GOqWXuOUR7ieZ2Crj6LITd0eGpf+YKfK2KpPhsq9rnI8SBjbU4xjgbf4Wj/DjUTZgkd1jHzXhDZjcyNpZDGwLVnys0sO2aEU4bG59IyzOYO0uwDYgZgvEEizaFViUPAGeFVQaZs07FX0eUZxvY1Oc8QHicAbDdJQzjvVRChqhXWpYBS+ntIIpSFQCEIq1ILRSm1gSYjzn3ileRl+koAbp8bm8lHaZ8FpO4rZZM24J6dIEJZaI9VCi34TViYon3VJRi+d+9PjhoRQ3JsOV6xsSXaE6MrES8w8x+e4j5dXo9FbijxFI9iCEKjDHSXkfI/5/OMGeSpxNW20VeFw+dxChf77KyQpp5Zl4iFfRb2V4gUv75NzDHv0X7vcPwNHTtnrYXYJBSw2ywqAZAx0KR0arzNGnNJHM4LsbPjuHjlGhlr/MLZO0GLKps+0QZfOK+wMZhwazmFCTc6fgMNsv9ayIkIUJ6wGla6goQAakVNySbTL9abKM1PXyhihnkoLydiRlzJKIVee2JdF5L1/j5L2XprhTBrc+Stzw3glOLo+HkiZhNZ7NgSrIW3b2zFnt2lxesUPNmIrGrgvkcBtI2Ybxij4cIO8eozyjFBjRnlMJTY5Wn5XuMUSRMp0Q/7LKe9U4S+L4zoh10BHIl+F8aGWn0ByR1rPoaEcrvazsX4ECKFs/rGQAtid2ZUc01jPHxvK+V5DTUyLREzC/9WVF1ZKJMUIFWzMdm26Rs+69k04TCMMoAhJ8DmHZg7ecV5bUZkS1iNUFheoVfh96Hf5hBeAMDETsTsKQHEJuHE7DvzcwzshMP1F9GRN3iKWMSepXmnGVsMs0fPNIjjsfWmiVcKXQYZON7jlDLKYchwqHh1ISViQP9RKhYxD3EK7yunz44+M1FfdQk+gE7RjyEm9rFQ8KkCYj8/dD1x6qQRSiQ/AQDuq7y88NbeH3+vk7m3fxPfoJwiDl1c3O+GTKySub8/yIoXgHbYaSJ+MU4MuFp+rtJEKBSesDqBmNgwu/1fPi9u+s3fnG7hh1Xn4BRyC/nNPbY2BU5kPg+eP3/OX//61wEMO/3YR9fxKa3XTxSvKesz5oQ2xxjGU88Bi/GYgsspZ4FZxMSrq79OOUZFX9Pdd/2ee7d4EtF/Zubn4euTyKFOQmhm82Qz3IhcOKx1LRrjon9MNzuOhaEEPC7CGkE68sAsp9S60lh+qdCYENrVEEx6LQcMZjr6bJOI4GX5TcDLfvaIF5FZm9PeDnN7x7sfrptrIuJzs21eemxdO8LZPBBZk+gwJHMttKfCdF3rTP777j4Dxcs3ijEjHIbwUn2Wwtz95XuDfX0FjO+vPvHICSWO/d5jT2K2mMyfi4XLrLE5vtj+GBb6OoVPaPg4KHvvG7q5wk59YgEm+PrV51FMxS0WsiPo9UvGcV9pGumszCmfZUz8gcuOrWtAyqikjLKFb5z710PS748Rh1SYbsg6U8g7R7zs3zk8w/vnIrevgHH9ldtX9vrW3xOEWXOq04+95ymYNCAZW1tJXnsGA5MS1VAENJ/2L3PN3LvEAp7H4V/vaM0gXjFeQOBJRyJqfn+dw8u5trF1DegyykA8rHOKaNk2U6+FXLqMMjC8KkROqK7LKI7prz4MEa7w9SH9FfZVTij41P6KYUxix6ltdmHynWXhjDnn2jkRNcxAe/EEOOvMvSVi/obnVJtnCoclvR0gsth0Hk5d/HKufdPRZVDax8WnjXPOrDzH6MS4hOLgG9WpQ3VjOabumeqzS/TXHKHgsULS533nfG4qzFZHJMxSjL1/LhytpdhqD+F1Z5y5Jz2KHqE4J1xfBVz89y+Baxpb14Cc8M651iguFaoblkGXFw4b02dz9dfYvXhT9Ff3/acXpSGYTcCA9ow5fO3cCEWs79pzIEdYj0Kdi6fTavcaxta1YIrwjn+vqXnkeoRdn0u1NwZTruvM2V9ThjYvLThTY1YBs7gWw9I3c7fXnBPXKKx+e9d+FMm1jK1rwdjwTuzzp/KYwyOMtTPVPS7dXykOOaHNqcKaDw1nEbBrQpdRvgbvsOuaa8M1clrQIC/7bT6jNkfmWnjvue/pcz+HAMyRsv4mCpfFWydgQFwwrtkYX5JbLFTnv77g4eBShuxaQnUPoT2/zWvK9rtWdFbiWLBgwfWAiH4XwP+a6HbvA/h/E91ralwrt4XXMEzJ6w8y8wfhi4uALVjwFoKIvh4rzXMNuFZuC69hOAevN9/HXLBgwYIFbyQWAVuwYMGCBQ8Si4AtWPB24kuXJtCBa+W28BqG2Xkta2ALFixYsOBBYvHAFixYsGDBg8QiYAsWvKUgop8nov9GRP+FiP41ET27NCcAIKK/SES/QUSKiC6eXUdEnyei3ySi3yaiv3tpPhZE9E+I6AURffPSXCyI6FNE9G+J6L+aZ/i35mxvEbAFC95efAXADzLzDwH4LQA/d2E+Ft8E8JMAfu3SRIhIAvgHAP4sgM8C+MtE9NnLsnL4pwA+f2kSASoAf4eZPwvgjwP4G3P21yJgCxa8pWDmX2VmW1jvawC+75J8LJj5W8z8m5fmYfDHAPw2M/8PZt4D+OcAfvzCnAAAzPxrAD68NA8fzPw7zPzr5veXAL4F4Hvnam8RsAULFgDAzwD45UuTuEJ8L4D/7f39bcxokN8kENH3A/gjAP7jXG28lbUQFyx4W0BEXwXwichbX2TmXzTXfBE69PPla+K14OGCiB4D+JcA/jYz//5c7SwCtmDBGwxm/lzX+0T00wB+DMCP8hn31PTxuiL8HwCf8v7+PvPaggSIqIQWry8z87+as60lhLhgwVsKIvo8gJ8F8BeY+fbSfK4U/wnAZ4joDxHRCsBfAvBvLszpakFEBOAfA/gWM/+9udtbBGzBgrcXvwDgCYCvENE3iOgfXpoQABDRTxDRtwH8CQC/RES/cikuJsnlbwL4FeiEhH/BzL9xKT4+iOifAfgPAH6AiL5NRH/t0pwA/EkAfwXAnzZj6htE9OfmamypxLFgwYIFCx4kFg9swYIFCxY8SCwCtmDBggULHiQWAVuwYMGCBQ8Si4AtWLBgwYIHiUXAFixYsGDBg8QiYAsWLFiw4EFiEbAFCxYsWPAgsQjYggULFix4kPj/3YHodlGbxYkAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 540x226.8 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light",
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(7.5, 3.15))\n",
    "plt.subplot(1, 2, 1).set_title('(a) Ground truth')\n",
    "sns.heatmap(prob_grid, cmap=\"Blues\", cbar=False, xticklabels=False, yticklabels=False).invert_yaxis()\n",
    "\n",
    "warm_sample = 0\n",
    "split_ = 1\n",
    "svgd_x = svgd_x.reshape(-1,2)\n",
    "plt.subplot(1, 2, 2).set_title('(b) SVGD')\n",
    "ax = sns.kdeplot(svgd_x[:,0], svgd_x[:,1], cmap=\"Blues\", shade=True, thresh=0.05, bw=0.15)\n",
    "ax.set_xlim(lower, upper)\n",
    "ax.set_ylim(lower, upper)\n",
    "plt.savefig(PATH+\"SVGD_\"+str(psampler[0].lr)+\".png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 265
    },
    "executionInfo": {
     "elapsed": 4625765,
     "status": "ok",
     "timestamp": 1610242217675,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "NByp_s4BZSzc",
    "outputId": "d16e5a4d-f232-46cc-d1f2-db65a3cd9910"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light",
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig3 = plt.figure(figsize=(4, 4))\n",
    "# plt.contour(axis_X, axis_Y, prob_grid, 10)\n",
    "plt.yticks([-4, -2, 0, 2, 4]) \n",
    "plt.scatter(svgd_x[:,0], svgd_x[:,1], marker='.', s=3, color='k', label=\"Iteration=\"+str(iters)) \n",
    "plt.legend(loc=\"upper left\", prop={'size': 10})\n",
    "plt.xlim([lower, upper])\n",
    "plt.ylim([lower, upper])\n",
    "# plt.tight_layout()\n",
    "plt.show()\n",
    "fig3.canvas.draw()\n",
    "image3 = np.frombuffer(fig3.canvas.tostring_rgb(), dtype='uint8').reshape(fig3.canvas.get_width_height()[::-1] + (3,))\n",
    "my_images3.append(image3)\n",
    "fig3.savefig(PATH + \"samples.png\")\n",
    "plt.close('all')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "yFqY5YscOJnG"
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "colab": {
   "authorship_tag": "ABX9TyOFhYR/wVUUJFYodlWZ3MlA",
   "name": "SVGD.ipynb",
   "provenance": []
  },
  "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
