{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import sys, os\n",
    "sys.path.append('../')\n",
    "result_dir = os.path.join(os.path.dirname(os.getcwd()), 'result', 'gnk')\n",
    "figure_dir = os.path.join(os.path.dirname(os.getcwd()), 'figure')\n",
    "from torch import nn, Tensor\n",
    "from matplotlib.patches import Patch\n",
    "\n",
    "import seaborn as sns\n",
    "\n",
    "from src.simulator.gnk import gnk\n",
    "import torch\n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "from scipy.stats import entropy, norm\n",
    "import matplotlib\n",
    "\n",
    "plt.rcParams['text.latex.preamble'] = r'\\usepackage{times}'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 500\n",
    "eval_points = 2000\n",
    "x_grid = np.linspace(-30, 30, eval_points)\n",
    "exact_densities = np.load(os.path.join(result_dir, 'g_n_k_exact_densities_NLE.npy'))\n",
    "theta = np.load(os.path.join(result_dir, 'g_n_k_theta_NLE.npy'))\n",
    "t_x_grid = torch.tensor(x_grid, dtype = torch.float32)\n",
    "t_theta = torch.tensor(theta, dtype = torch.float32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/r6/jlzvq0td5mqf05q5jm6fs2vm0000gp/T/ipykernel_52107/2554240195.py:1: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  mlmc_net_1 = torch.load(os.path.join(result_dir, 'gnk_nle_mlmc_n_10000_300.pt'), map_location=torch.device('cpu'))\n",
      "/var/folders/r6/jlzvq0td5mqf05q5jm6fs2vm0000gp/T/ipykernel_52107/2554240195.py:2: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  mlmc_net_2 = torch.load(os.path.join(result_dir, 'gnk_nle_mlmc_n_10000_100.pt'), map_location=torch.device('cpu'))\n",
      "/var/folders/r6/jlzvq0td5mqf05q5jm6fs2vm0000gp/T/ipykernel_52107/2554240195.py:3: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  mlmc_net_3 = torch.load(os.path.join(result_dir, 'gnk_nle_mlmc_n_10000_50.pt'), map_location=torch.device('cpu'))\n",
      "/var/folders/r6/jlzvq0td5mqf05q5jm6fs2vm0000gp/T/ipykernel_52107/2554240195.py:4: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  mc_net_low = torch.load(os.path.join(result_dir, 'gnk_nle_mc_n_10000_low.pt'), map_location=torch.device('cpu'))\n",
      "/var/folders/r6/jlzvq0td5mqf05q5jm6fs2vm0000gp/T/ipykernel_52107/2554240195.py:5: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  mc_net_high = torch.load(os.path.join(result_dir, 'gnk_nle_mc_n_300.pt'), map_location=torch.device('cpu'))\n"
     ]
    }
   ],
   "source": [
    "mlmc_net_1 = torch.load(os.path.join(result_dir, 'gnk_nle_mlmc_n_10000_300.pt'), map_location=torch.device('cpu'))\n",
    "mlmc_net_2 = torch.load(os.path.join(result_dir, 'gnk_nle_mlmc_n_10000_100.pt'), map_location=torch.device('cpu'))\n",
    "mlmc_net_3 = torch.load(os.path.join(result_dir, 'gnk_nle_mlmc_n_10000_50.pt'), map_location=torch.device('cpu'))\n",
    "mc_net_low = torch.load(os.path.join(result_dir, 'gnk_nle_mc_n_10000_low.pt'), map_location=torch.device('cpu'))\n",
    "mc_net_high = torch.load(os.path.join(result_dir, 'gnk_nle_mc_n_300.pt'), map_location=torch.device('cpu'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def obtain_density_over_grid(network: nn.Module, x_grid: Tensor, theta: Tensor, network_type: str = 'nsf'):\n",
    "    \"\"\"\n",
    "    network: nn.Module\n",
    "    Input: x_grid [n_eval_points]\n",
    "    theta: [theta_dim]\n",
    "    \"\"\"\n",
    "\n",
    "    n_eval_points = x_grid.shape[0]\n",
    "    theta = theta.repeat(n_eval_points, 1)    \n",
    "    if network_type == 'nsf':\n",
    "        x_grid = x_grid.view(-1, 1)\n",
    "    \n",
    "    return network.log_prob_unstandardized(x_grid, theta, log = False).detach().numpy()\n",
    "\n",
    "def obtain_density(network: nn.Module, x_test: Tensor, theta_test: Tensor, network_type: str = 'nsf'):\n",
    "    n = theta_test.shape[0]\n",
    "    m = x_test.shape[0]\n",
    "    density = np.zeros((n, m))\n",
    "\n",
    "    for i in range(n):\n",
    "        density[i:,] = obtain_density_over_grid(network, x_test, theta_test[i], network_type)\n",
    "\n",
    "    return density\n",
    "\n",
    "def obtain_kl(approximated_densities, exact_densities, forward = True):\n",
    "    \n",
    "    jitter = 1e-20\n",
    "    exact_densities = np.clip(exact_densities, jitter, None)\n",
    "\n",
    "    kl = np.zeros((approximated_densities.shape[0]))\n",
    "\n",
    "    for i in range(approximated_densities.shape[0]):\n",
    "\n",
    "        if forward:\n",
    "            kl[i] = entropy(exact_densities[i], approximated_densities[i]) # forward KL divergence \n",
    "\n",
    "        else:\n",
    "            kl[i] = entropy(approximated_densities[i], exact_densities[i])\n",
    "\n",
    "    return kl\n",
    "\n",
    "def integrated_squared_error(approximated_densities, exact_densities):\n",
    "    \"\"\"\n",
    "    approximated_densities: [n, m]\n",
    "    exact_densities: [n, m]\n",
    "    \"\"\"\n",
    "    squared_error = np.sum((approximated_densities - exact_densities)**2, axis = 1)\n",
    "\n",
    "    return squared_error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "dense_1 =  obtain_density(mlmc_net_1, t_x_grid, t_theta)\n",
    "dense_2 = obtain_density(mlmc_net_2, t_x_grid, t_theta)\n",
    "dense_3 = obtain_density(mlmc_net_3, t_x_grid, t_theta)\n",
    "dense_low = obtain_density(mc_net_low, t_x_grid, t_theta)\n",
    "dense_high = obtain_density(mc_net_high, t_x_grid, t_theta)\n",
    "\n",
    "kl_1 = obtain_kl(dense_1, exact_densities)\n",
    "kl_2 = obtain_kl(dense_2, exact_densities)\n",
    "kl_3 = obtain_kl(dense_3, exact_densities)\n",
    "kl_low = obtain_kl(dense_low, exact_densities)\n",
    "kl_high = obtain_kl(dense_high, exact_densities)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "ise_1 = integrated_squared_error(dense_1, exact_densities)\n",
    "ise_2 = integrated_squared_error(dense_2, exact_densities)\n",
    "ise_3 = integrated_squared_error(dense_3, exact_densities)\n",
    "ise_low = integrated_squared_error(dense_low, exact_densities)\n",
    "ise_high = integrated_squared_error(dense_high, exact_densities)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 388,
   "metadata": {},
   "outputs": [],
   "source": [
    "def box_plot_gnk(metric_list:list, title:str):\n",
    "\n",
    "    f, ax = plt.subplots(figsize = (3, 3))\n",
    "    colors = [\"#25A986\", \"#0C0C85\", \"#850D0C\", \"#850D0C\", \"#850D0C\", \"#850D0C\", \"#850D0C\"]\n",
    "\n",
    "    sns.boxplot(metric_list, ax = ax, palette = colors,#  orient='h',\n",
    "                flierprops={'marker': '.', 'color': 'black', 'markersize': 5, 'markerfacecolor': 'black', 'markeredgecolor': 'black'})\n",
    "    # sns.violinplot([kl_low, kl_800, kl_300, kl_50, kl_high], ax = ax, palette = colors)\n",
    "    #ax.set_xlabel('KLD', fontsize = 25)\n",
    "    #ax.set_xlabel('KLD', fontsize = 25)\n",
    "    ax.set_ylabel(title, fontsize = 17)\n",
    "    ax.spines['top'].set_visible(False)\n",
    "    ax.spines['right'].set_visible(False)\n",
    "    # ax.set_yticklabels([\"MC(low)\", \"$100:1$\", \"$20:1$\", \"$10:1$\", \"$5:1$\", \"$2:1$\", \"MC(high)\"], fontsize = 25)\n",
    "    ax.set_xticklabels([\"$n = 10^4$\", \"$n = 300$\", \"$n_1 = 50$\", \"$n_1 = 100$\", \"$n_1 = 300$\",\n",
    "                        \"MLMC ($500$)\", \"MLMC ($5000$)\"], fontsize = 14, rotation = 90)\n",
    "    # ax.tick_params(axis='x', labelsize=10)\n",
    "    ax.tick_params(axis='y', labelsize=13)\n",
    "    ax.set_yscale('log')\n",
    "\n",
    "    for patch in ax.patches:\n",
    "        patch.set_alpha(0.5)\n",
    "\n",
    "\n",
    "    # custom_patches = [\n",
    "    # Patch(facecolor=colors[2], label=\"MLMC\", alpha = 0.5, edgecolor='black'),\n",
    "    # Patch(facecolor=colors[0], label=\"MC (low)\", alpha = 0.5, edgecolor='black'),\n",
    "    # Patch(facecolor=colors[1], label=\"MC (high)\", alpha = 0.5, edgecolor='black'),]\n",
    "    # custom_patches = [\n",
    "    # Patch(facecolor=colors[2], label=\"MLMC\", alpha = 0.5, edgecolor='black'),\n",
    "    # Patch(facecolor=colors[0], label=\"MC (low)\", alpha = 0.5, edgecolor='black')]\n",
    "\n",
    "    # f.legend(handles = custom_patches,  loc = 'upper left', fontsize = 12, frameon = False, ncols = 2, bbox_to_anchor=(0.1, 1.04))\n",
    "    f.tight_layout()\n",
    "    return f"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 389,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/r6/jlzvq0td5mqf05q5jm6fs2vm0000gp/T/ipykernel_52107/2403862254.py:6: UserWarning: The palette list has more values (7) than needed (5), which may not be intended.\n",
      "  sns.boxplot(metric_list, ax = ax, palette = colors,#  orient='h',\n",
      "/var/folders/r6/jlzvq0td5mqf05q5jm6fs2vm0000gp/T/ipykernel_52107/2403862254.py:15: UserWarning: FixedFormatter should only be used together with FixedLocator\n",
      "  ax.set_xticklabels([\"$n = 10^4$\", \"$n = 300$\", \"$n_1 = 50$\", \"$n_1 = 100$\", \"$n_1 = 300$\",\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "f = box_plot_gnk([kl_low, kl_high, kl_3, kl_2, kl_1], 'KLD')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 390,
   "metadata": {},
   "outputs": [],
   "source": [
    "f.savefig(os.path.join(figure_dir, 'gnk_kl_NLE.pdf'), bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 396,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/r6/jlzvq0td5mqf05q5jm6fs2vm0000gp/T/ipykernel_52107/2403862254.py:6: UserWarning: The palette list has more values (7) than needed (5), which may not be intended.\n",
      "  sns.boxplot(metric_list, ax = ax, palette = colors,#  orient='h',\n",
      "/var/folders/r6/jlzvq0td5mqf05q5jm6fs2vm0000gp/T/ipykernel_52107/2403862254.py:15: UserWarning: FixedFormatter should only be used together with FixedLocator\n",
      "  ax.set_xticklabels([\"$n = 10^4$\", \"$n = 300$\", \"$n_1 = 50$\", \"$n_1 = 100$\", \"$n_1 = 300$\",\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "f = box_plot_gnk([ise_low, ise_high, ise_3, ise_2, ise_1], 'ISE')\n",
    "f.savefig(os.path.join(figure_dir, 'gnk_ise_NLE.pdf'), bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 291,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_exact_density_and_approximate_density(index: int, network_list: list[nn.Module], network_name: list[str], x_grid: Tensor, theta: Tensor, exact_density: Tensor,\n",
    "                                               network_type_list: list[str], xlim = (-20, 20), add_legend = False): \n",
    "    \n",
    "    colors = [\"#850D0C\", \"#0C0C85\", \"#25A986\"]\n",
    "    fig, ax = plt.subplots(1, 1, figsize = (3., 3))\n",
    "    ax.plot(x_grid, exact_density[index], color = \"black\", ls = \"dashed\", label = \"(Almost) exact\")\n",
    "    for i in range(len(network_list)):\n",
    "        approximated_density = obtain_density_over_grid(network_list[i], x_grid, theta[index], network_type = network_type_list[i])\n",
    "        ax.plot(x_grid, approximated_density, label = network_name[i], color = colors[i])\n",
    "        ax.fill_between(x_grid, approximated_density, alpha = 0.25, color = colors[i])\n",
    "\n",
    "    # ax.hist(x_low[index], bins = 100, density = True, alpha = 0.25, color = \"black\", label = \"Low fidelity data\")\n",
    "    # ax.hist(x_high[index], bins = 100, density = True, alpha = 0.25, color = \"red\", label = \"High fidelity data\")\n",
    "    # ax.legend(prop = {\"size\": 8}, fancybox = False, frameon = False)\n",
    "\n",
    "    if add_legend:\n",
    "        fig.legend(fontsize = 12, frameon = False, loc='upper right', bbox_to_anchor=(1.0, 0.9))\n",
    "    ax.set_xlim(xlim[0], xlim[1])\n",
    "    ax.set_ylabel(\"Density\", fontsize = 17)\n",
    "    ax.set_xlabel(r\"$x$\", fontsize = 17)\n",
    "    ax.tick_params(axis='y', labelsize=13)\n",
    "    ax.tick_params(axis='x', labelsize=13)\n",
    "    ax.spines['top'].set_visible(False)\n",
    "    ax.spines['right'].set_visible(False)\n",
    "    fig.tight_layout()\n",
    "\n",
    "    return fig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 391,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/r6/jlzvq0td5mqf05q5jm6fs2vm0000gp/T/ipykernel_52107/3197939188.py:5: UserWarning: Matplotlib is currently using module://matplotlib_inline.backend_inline, which is a non-GUI backend, so cannot show the figure.\n",
      "  f.show()\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "idx = 9\n",
    "f = plot_exact_density_and_approximate_density(idx, [mlmc_net_1, mc_net_high, mc_net_low], [\"ML-NLE (300)\", \"NLE (high)\", \"NLE (low)\"], \n",
    "                                               t_x_grid, t_theta, exact_densities, network_type_list = [\"nsf\", \"nsf\", \"nsf\"],\n",
    "                                               xlim = (-5, 20), add_legend=True)\n",
    "f.show()\n",
    "f.savefig(os.path.join(figure_dir, 'gnk_density_approximation_comparisoin_NLE.pdf'), bbox_inches = 'tight', dpi = 300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 420,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_exact_density_and_approximate_density_multi(index_list: list, network_list: list[nn.Module], network_name: list[str], x_grid: Tensor, theta: Tensor, exact_density: Tensor,\n",
    "                                               network_type_list: list[str], xlim = (-20, 20), add_legend = False): \n",
    "    \n",
    "    colors = [\"#850D0C\", \"#0C0C85\", \"#25A986\"]\n",
    "    fig, ax = plt.subplots(1, 4, figsize = (8, 2.3))\n",
    "    ax = ax.flatten()\n",
    "\n",
    "    shift = 30\n",
    "\n",
    "    for index in index_list:\n",
    "        ax[index].plot(x_grid, exact_density[index + shift], color = \"black\", ls = \"dashed\", label = \"(Almost) exact\")\n",
    "        for i in range(len(network_list)):\n",
    "            approximated_density = obtain_density_over_grid(network_list[i], x_grid, theta[index + shift], network_type = network_type_list[i])\n",
    "            ax[index].plot(x_grid, approximated_density, label = network_name[i], color = colors[i])\n",
    "            ax[index].fill_between(x_grid, approximated_density, alpha = 0.25, color = colors[i])\n",
    "\n",
    "    # ax.hist(x_low[index], bins = 100, density = True, alpha = 0.25, color = \"black\", label = \"Low fidelity data\")\n",
    "    # ax.hist(x_high[index], bins = 100, density = True, alpha = 0.25, color = \"red\", label = \"High fidelity data\")\n",
    "    # ax.legend(prop = {\"size\": 8}, fancybox = False, frameon = False)\n",
    "\n",
    "        if index == 3:\n",
    "            ax[index].legend(fontsize = 10, frameon = False, loc='upper right', bbox_to_anchor=(1.5, 1.2))\n",
    "\n",
    "        ax[index].set_xlim(xlim[0], xlim[1])\n",
    "\n",
    "        # if index ==  0:\n",
    "            # ax[index].set_ylabel(\"Density\", fontsize = 17)\n",
    "\n",
    "\n",
    "        # if index > 3:\n",
    "        #     ax[index].set_xlabel(r\"$x$\", fontsize = 17)\n",
    "        #     ax[index].tick_params(axis='y', labelsize=13)\n",
    "        #     ax[index].tick_params(axis='x', labelsize=13)\n",
    "        ax[index].spines['top'].set_visible(False)\n",
    "        ax[index].spines['right'].set_visible(False)\n",
    "    fig.tight_layout()\n",
    "\n",
    "    return fig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 421,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAvoAAADHCAYAAABoZPePAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACFw0lEQVR4nO2deXxU1d3/33f2NZmsLAlb2EFEwuZaRYKoVVsQ8OmjFm0r2Frp9lOo9qnt01aWtrbFtk+Btha7IoFWqVYlVK1rWMIishO2BMg+yWQms9/fH3fmzkz2QEK283695pW7njkXztz7ud/zXSRZlmUEAoFAIBAIBAJBn0LT3R0QCAQCgUAgEAgEnY8Q+gKBQCAQCAQCQR9ECH2BQCAQCAQCgaAPIoS+QCAQCAQCgUDQBxFCXyAQCAQCgUAg6IMIoS8QCAQCgUAgEPRBhNAXCAQCgUAgEAj6IELoCwQCgUAgEAgEfRAh9AUCgUAgEAgEgj6IEPoCgUAgEAgEAkEfRAh9gUAgEAgEAoGgDyKEvkAgEAgEAoFA0AcRQl8gEAgEAoFAIOiDCKEvEAgEAoFAIBD0QYTQFwgEAoFAIBAI+iBC6AsEAoFAIBAIOp3169e3uL2goKDZfcXFxRQVFXVlt5qlqKioxT71ZoTQFwgEAoFAIBB0KkuXLmXRokXN7lu9ejXr1q1rsr2oqIg5c+awadOmru6e+n1OpxOA3NxcnE5nt4r9+P50FkLoCwQCgUAgEAg6jfz8fKZOnYrD4Wiyr6ioiNzcXPLz85uI2tzcXHJzc69IH51OJwsXLkzYtmDBAlavXt3pYvtS+9MZCKEvEAgEAoFA0It47rnnyM7ObvNzzz33NDn3nnvuade5zz333CX375FHHmnRmr9u3To2b95MTk4OK1eubLWdgoICpk6dyvr161m+fDkjR45U3X4WLlxISkpKgptPUVERa9asYf369SxcuJDi4mJ13/Lly1m/fj1z5syhoKCAgoICiouLWblyZUIbubm5zbocFRQUsGbNGubMmcPSpUvV70tJSWHq1Kk4nU61r1HWrFlDfn4+S5cuZc2aNU36uWbNGhYuXKjOJDTXn8tGFggEAoFAIBD0Gp555hkZaPNz7bXXNjn32muvbde5zzzzzCX1raamRnY4HC3ue/LJJ2VZluXVq1c3e9yCBQvUY2RZlnNyctT17du3y4C8Z88eWZZl+cknn5SXLFnS7Pdu375dXd+zZ4+8YMEC9bjNmzfLsizLgFxTU5Pw/Zs3b1aPjXLy5MmEPjkcDrWN6Pfs2bNHXr16dcI50e+vqamRo5K7pqZGzsvLU4/Lzc2V161b12J/Lhdd570yCAQCgUAgEAi6mqSkJLKysto8LiMjo9lt7Tk3KSnpkvq2e/duUlNTm923fv161Rq+ZMkSli9fTn5+PgsWLGixPYfDwfTp0wGYNm0agOreM3LkSDZv3qy2Hd0PkJeXByhuRHl5eeTn57N+/XqWLFnS5vc1tqjn5+dTXFysWuW//e1vk5OTo37PtGnTWLhwISdPnlTPycnJYc+ePeq/CSjuOdFZhSjRY7oKIfQFAoFAIBAIehHf/OY3+eY3v3lJ577yyiud3JtEUlNTqa6ubnbf9u3bm4jhdevWtSq820t8u/HtFxcX43A4WLduHUuXLmXdunXs2LGj2fiB1tqeM2cOS5YsaXb/0qVLVVeh6AsAxPzu44X9yZMnGTlyZPsv7DIRPvoCgUAgEAgEgk4hJyen2WDWoqIiFi5cyLp16xI+Ud/0y2XkyJHNthPNprNkyRL1ZWD58uXq/sYvJU6ns0lAsMPhUGcO4q8nyvbt21mwYIE6WwFKmtCFCxeyefPmhBcEh8PB9u3bm3xnS/25XITQFwgEAoFAIBB0Cg6Hg9zc3Caie+XKlU0CdKPuNatXr26xveZeGpoTxkuWLEnIwe90OnE6neTl5bF7926KiorIyclh9erVCX1r3P6uXbsSLPAA9913HwUFBWqgbX5+vvq9a9asYfny5WzYsEEN8gUS0nTGf19zbUVde1q63suiUz3+BQKBQCAQCAT9mu3btycEpm7evFkG1KDTKHv27JEdDocMyNu3b1fXc3Nz5ZMnT6rBtwsWLJBramrk1atXy4C8evVqNag1GggbbW/BggXyunXr1GOi/cnLy5M3b94sP/nkk+rxS5YskXNzc+Xt27erfYoPlI0nGjzscDjU69i+fbucm5urHpObm6v2p6amRs7JyZFzc3PlzZs3y7m5uWqQ77p165q01VJ/LhdJlmW5c18dBAKBQCAQCAT9mfXr15OXl5fgs97TWbNmDQsWLOhVfW4LIfQFAoFAIBAIBJ1OWxl1ehJFRUU4HI4+JfKhFwl9v99PRUUFGRkZGAyG7u6OQNBhxBgW9HbEGBb0dsQYFvQ3ek16zYqKCp5//nkee+yxduV/FfRuNJq+FycuxnD/o6+NYzGG+x9iDAt6O31tDHeUXiP0BQKBQHD5FBYWUlhYiMvlorS0lLy8PObPn9/d3RIIBAJBFyCEvkAgEPQTCgsLOXLkCMuWLQPA5XLxwAMPcPjwYZ5++ulu7p1AIBAIOpv+PZ8hEAgE/YitW7eyePFidd1ut7N48WL+/ve/U1JS0o09EwgEAkFXIIS+QCAQ9BN27NjB2rVrE7ZNmDABgJ07d3ZHlwQCgUDQhQih3w727t3LHXfcwf/93/91d1cEgg4R8vspWLGCP942hyMv/6O7uyPoZmbPnk12dnZ3d6NHsGXLFubOncuOHTu6uyuCfo4cDvPWM9/lT3fczpGXX+7u7gj6GELot0E4HGbhwoW8+eabPP7445w9e7a7uyQQtJv3Vq1k92/+j9KdO/nHQw9xYW9Rd3dJ0I2sXr26SeDtoUOHAJgxY0a72wkEAp3ar+5g0aJFFBQUcNttt3V3VwT9nEP5+RT+4heUfPgh25Y8wkMLFjBkyBDeeeed7u7aJVFQUMDo0aPRarUUFxc32e90OtFqtaSlpZGfn09BQQFpaWlotVrWr1/fru/Iz88nLS2N0aNHJ2wvLi5m0aJFjB49moKCAgoKCkhJSUGSpGbbju5PSUlh+fLl6mfq1KksX7681T7Et1dUVMTUqVORJImFCxc26dPSpUtZv359kzZb2ldUVERBQUG7/i3aQgj9NigpKeHUqVMAyLLcaf/wAkFXEwoE2PeHP8Q2yDKFa5/vtv4IeiYbN27k8ccf75Clf9u2bV3YI4Ggf/HJ5pfU5ZDPx7F/bsPpdLJ3795u7NWlk5eXx7333gvQrLh+6aWXcDgcTJ06lQULFpCXl8fs2bPJzc1lyZIl7fqOBQsW8Mgjj1BcXMyjjz6qbs/JyWHFihXce++95OXlqZ+W2o7uz8nJYfXq1epnz549pKWltfj9S5cuZdGiRYDy4lJQUMCePXuoqamhoKAg4brnzJnD0qVLWbJkCXPmzGHOnDlt7svNzVXbvVyE0G+Dxm+jIu+uoLdw9t3/0FBdnbDt1I4CwsFgN/VI0NNYvnw5M2bMSAjQbQ933313F/VIIOhfyOEwJR99lLBtuFaLx+PBaDR2U68un7S0NO699142bNjQZF9BQQFTp07tlO9wOBxs2LCB/Px8dbvD4WhVpLeXJ598stnt+fn5TJ06FYfD0eRYh8NBXl4eqampgHKt1dXV5ObmAsqLRUFBAcXFxa3uA+VlZvXq1Tidzsu6DiH02+D06dPq8tq1a5k7d273dUYg6ACn3nortiJJAPjq6ijdtaubeiToSWzdupWkpKRLSqup1+u7oEcCQf+jprgYv8uVsG2gRgvEAuV7K0uWLMHpdDZxccnLy0sQyZfDpk2bALjvvvuadRO6VFpzIXrkkUdUaz6QcC1Op5PU1FQWLFgAKNc7bdq0hPNzcnIoKChodV+U3NzcdrsztYTIo98G8W9S6enp3dcRgaCDnN+9R12++oEHOfDHFwE498H7DLnuuu7qlqAHUFBQgMvlShD5LpcLu93ejb26sowePZrjx4+TkpLS3V0R9GOqT5xosi1dI6EDBgwY0Ow5f7jlZtzl5V3cs6ZYMzN56O32xw1MmzaN2bNns2HDBtVtZv369fzmN7/pNDfoadOm8cYbbzB37lzmzp3L8ePHL6md4uJili9fjtPppLq6GqfT2ayrT1QTNveikp+fr/rZFxcXk5OTw8mTJ5sc63A4OHnyJE6ns8V9UaZPn66+zFwqQui3QbzQT05O7r6OCAQdIBwMUrZ/HwDm1FQGT5+uCv0Le/a0cqagr3PkyBHq6uoS3HVcLheFhYXk5eV1Y8+uLNFZib4QWCzovTjjvAaiaCSJARpNi0LfXV6O6/z5Lu5Z5/Dkk08yd+5cioqKyMnJ6ZLvyMvLY9WqVaxYsYJHH320RZeb1oj66IOi+1oKxN29e7fqltOYBQsWkJOTw8KFC1m6dCnbt2/vcD8a43A4KCq6vCQaQui3QW1trbqcnJyMLMsASBFXCIGgJ1J1/DgBjwcAx/ARJA8ditZgIOT3U3bgQDf3TtBdlJSU8MILLzBnzpwEi1phYaEaPNdfMBgMAPj9/m7uiaA/UxNJ9gEwePoMzu9S6lmkaTRMmTKF73//+01iaKyZmVe0j5fzvdFA11WrVpGXl9fuYNt41q9fz49//GNAEb67mnE/feKJJ9i1axcbNmxg5MiRHf6OeBwOR4tCPzU1lepGsW/x5Obmsm7dOjXzzsiRI5u4FDmdTqZPn05xcXGL+zoTIfTbIN6if+ONN2I2mykpKek0/zKBoCuoOnZUXU4ePhyNVotjxAiqjh6lrqQEf309BputG3so6A4efPBBXC5Xs7njL8VXv7cSCATYt28foAh9WZaF8UbQLThPx4T+oClTVKGfopE4cO4cZWVlTc7piPtMd1FVVaUuL1myhBUrVqjLHSGaLrO58+K/A5RsPtOnT2fFihWsWrWqXW23ZJ3PyclR98frvZycnDaDY6dNm6bOXkSFf+Pvzc3NxeFwtLgvitPpTFi/FEQwbhvce++9fO9731PXGxoamv3hCQQ9iapjMT9Fx9ChACRlD1G3Vcf5AAr6D2+99Ra7d+9u9tOfcLvd6vKQIUNaOVIg6FqirjsavZ60cePU7SmSIs9qamq6o1udQtTy/cgjjwAkuAa2N5PMihUrWjWsNraub9++vd2G2OXLl7d67NKlS5v1oc/NzU2wxDudzoT1goICvv3tbwOxa47uLygoIDc3l5ycnFb3Rdm1a1dCOs5LQVj02+Cuu+7irrvuora2lp/97GcAlJWVMXbs2G7umUDQMgkW/REjAEiKSw1beeQIAydPvuL9Egh6AsG4FLNXX321sOYLuo36ixcBMCUnY43zyXdolDHZG4V+QUEBW7Zsobi4mPXr1+NwOHjkkUdUq3x+fj57IrFi+fn5OBwOduzYgdPpVC3/TqeTHTt2MCLy/GrpO5xOJ6tWrVIFucPhYPv27arxIlo0K97vPpqfPprhpvH+aL9aiilYvXo1+fn5aixAcXExCxcuJC8vjzlz5qgpNqNs376d1atXM3XqVPbs2ZMwo9raPlCy9kRjBy4VIfTbycCBA9Xli5EfpkDQU6k6dkxZkCSSIxZLeyOhLxD0V+KFvk4nHoOC7iHo8+GLxAEak5MJaLV4ZRmTJJGi6b0W/by8vCbZb37zm9+oywsWLFDTT0Zp7IZzKd8RJTc3NyE3fVv/hs3tb01c5+Xlqf71OTk55ObmJmTKaUxOTk4TF5327FuzZk2L+zqCcN1pJ5lxQSjl3ZDWSiDoCLVnzgBgTklBG8kuEm/Rrz5xaSnIBIK+gBD6gp5AfIpMY3IyFpOJlMh92iH1Xot+f2DJkiWXnQ2nNYqKitQsPpeLuMO1QUlJCUlJSQlV1jr65ikQXEm8tbV4I/6P5rjaD7ZBg5TCWbJMjfDRF/Rj4oX+li1bcLvdWK3WbuyRoD/iqYgJfXNKClqtluSBA2k4fx6dJGFGCP2eTONZic7kcgNw4xFCvxVkWSYnJ4dQKJSwvbKyspt6JBC0Td25c+qyNSNDXdYaDFgzMnGXl+E8fVpkGhH0W+KFPij3dCH0BVea+rKY0Dc5lMJt5rgsMHaNRgh9wWUjXHdawePxqCJ/+PDh6nYh9AU9mdqzZ9VlW1xsCYB98GAAAh4PXvEAEfRTGgt9UTRL0B0kWPQjAt+cEif0JUkIfcFlI4R+K9TX16vL8UJfuO4IejIJQn9AotC3ZmY0e5xA0J9oLPRF0SxBdxDvo29OTaXkwgWOXLygbkuSJJxOZxOvAoGgIwih3woNDQ3qckZGhlpJUVj0BT2ZBKE/aFDCPktcUHlNM6XXBYL+gBD6gp5AvOuOJS2NfYcP86c331S3/dedd/CHP/wBWZa7o3uCPoLw0W8Fj8ejLlutVn7+859jsVjIzs6m8sgRjr36T4bd9CmyZszoxl4KBInUnj2jLkdddaJYM2JCP74io0DQn2gcm9JY+AsEV4J41x1Tairu4mJc4ZionzhkKHc8+GB3dE3QhxBCvxXihb7FYmHp0qUAuC5c4LczZ+Krq0Wj0/Hg9u0MmtJ5EdICweUQtehLGg3muGxRkBicW3tGuO4I+ieTJ0/ma1/7Gr/4xS8A4aMv6B4Sg3EdNHi9uOKs9/VlomaP4PIRrjutEO+6Y7FY1OWDf/0LvjqlyEU4GOSDn/zkivdNIGgJ1wXFx9OYnIxGq03YF++6U3dOCH1B/yU+f76w6Au6g6hFX2cyoTMacTc0JAh9d1lZd3VN0IcQQr8V4i36ZrNZXT689e8Jx51++23C4kEh6AGEAgE8FRUABI3GJvstaWlIkYqLrvPnr2jfBIKehD5SSA6ERb+zKSkp4Uc/+hEbN25k48aNbN26tV3nPfDAAxQUFOByuXC5XOr5ndF2T6ShuhoAg82mrHu9BAFPROzXXrjAvn37el0CkPz8fNLS0hg9enTC9uLiYhYtWsTo0aMpKCigoKCAtLQ0tFot69evb9JOdH9aWhorVqxQP9OnT2fFihWt9iHaXn5+PikpKRQXFzd73Jw5c8jPz2/XNbXUTlFREQUFBW220V0Iod8KjV13ampq2P3ee5Qf/DjhuIDbzYW9e6909wSCJsRbgPafK2HTq68m7NfodGoaNyH0Bf2ZeKEvLPqdR0lJCQ8++CDLli1j8eLFLF68mJKSkiaCvTmOHDnCihUrmDVrFrNmzaKkpITFixd3Sts9DVmW8dYqngF6i1LDwRPxInCFwwDUXrzI1KlT+de//tU9nbxEFixYwCOPPEJxcTGPPvqouj0nJ4cVK1Zw7733kpeXR15eHrNnzyY3N5clS5Y0aSe6Pycnh1WrVqmfXbt2JRQxbcyjjz7KokWL1L44IwUkm2P58uXk5eW165paaic3Nxen09ljxb7w0W+Fxq47v/jFL/jzs8/yRYti3dfo9YQjlqDTb79F1vTp3dJPQceIPhiys7MBsNvtzJ8/v8PtfOUrX+HXv/51Z3fvsqiKC8R1yWF+9cc/sujOOxOCDy0ZmXgqK/E6nQQ8HvRxbmkCQX9g//79/OAHP1DX4914BJfHxo0bmTdvHna7Xd328MMPM2vWrATR3hzz5s1j/PjxAMyYMUO9R3dG2z0Nv8uFHEmbqbcmCv16WWYAYJAkDEBdXV039fLSSUtLw+FwsGHDBvLy8tQqsg6Ho1WR3l6eeOKJZrfn5+eTm5uLw+FoVzvtEfntYcGCBcyZM4dp06a1+7uvFOLu1gp33nkne/bswePxMGzYMP7+978zSBObBMnJy+NE5E277MCB7uqmoANELUKvvPKK+rBYu3YtGzdu7NCDYuPGjezcubOrunnJ7Hv3PXXZJcuUXLzI6dJSRsQ9MK2ZGVQeVpbrSktJazS9KhD0dc7FVY/+wQ9+wK233tqNvelbFBQU8Pjjjydsi95rCwsLmTlzZovnZmdnt2p0uZy2exoNcYWwDLZEoe+O89O3RnLpx3PzzX+gvNzd9Z1sRGamlXfeeajdx2/atIm5c+dy3333cfz4cXJycjqlH+vXr292BgBg6dKlnDx5ssn2oqIili9fTkFBARs2bGDBggUUFRWxcuVK5syZo7bndDpZuXKl6qKzefPmNtuJkpuby/r163nyySc75To7CyH0W8HhcHDNNdeo62lpaQzSxoT+8FmzOPnmm8ihEJVHjnRDDwUdpTMsQiUlJRw6dKirunhZnDywX13OGpHDW9/9LkMa59JPyLxzRgh9Qb8j3lVHWPM7j6hvfVZWVpN9drudI0eOtCnGXS4Xhw4dIjk5mXHjxnVq2z0Jb5x4j/roe7xeoKnQr424+EQpL3dz/ryr6zt5mUybNo033niDuXPnMnfuXI4fP35J7RQXF7NixQqcTifV1dU4nc5mhX70hag5i3p1dTWbN29mzZo1rFy5kgULFpCbm0txcXHCi9QjjzzC0qVLycvLIyUlhTlz5iS49zTXTpTp06ezadOmS7rGrkT46HeA9PR0UuMs+ik5I0mK3HScp04REgFdPZ6CgoIm08HxFqH2sGPHDubMmdPpfesMLsTdSG+/43aGZWWh0ST+zK2iaJagnyOEftdQWlra4r6kpKQmgrUxhYWFFBYWMmHCBEBxjzwSMaJdbtuN6e4AbK8z3qKvPIOsFgtpDgc+TSxbmq0ZoZ+ZaWXwYPsV/2RmWjt8nXl5eaxataqJv35HiPro/+Y3v2H9+vUtzgzs3r2b1EgMWnP9AFRxH992PPn5+eq2vLw8cnNzE9x7WmoHlBeMoqKiDl5d1yPucB0gPT2d1Iivc0CnR2c0kjxsGLVnzxIOBqkpLiZ97Nhu7qWgJTrDIlRQUMDs2bPVh09Po670PFF7/egJE5s9xpIes+jXxbkwCAT9BSH0uweXq3Ur9FNPPaUaYsaNG8f8+fNZvnw5L7/88mW33Zht27Y1cQO6kiRY9CPGpl/8z/8AcOJf/2LXr38FNO+60xH3mZ7AE088wa5du9iwYQMjR468rLYcDkeLrjGpqalURzIZXU77RUVF5OTkkJOT0ynxBN2NsOi3wkcffcQf//hH8vPzqa6uxmGzYY9YRz165eFgHxwTjTUtpG8S9Awu1yLkcrmoq6trMiPQUbrKkiTLMnJ97GGXPGBAs8dZ0mM3LldpSZf0RSDoycQL/W984xvs2LGjG3vTd7BFXFCaoz0BpY3vrePGjaO0tJTCwsLLbrsxd999d4fP6Uy8cT76xiR7wj5jcrK6bNU0tej3BhqnBH3ppZfIzc1tMy1mlMYuNfHk5OQ0uz8nJ6fVDDvtYceOHaxcuZL169fjdDo75G/vdDrJze15xVOF0G+FP/3pTzz00EPcd999nDp1Cr0nFvxSi2LZtw0cqG6rvkT/M0HPoC2L0NatWy8pO09jtm3bdtltNEd1dTXWSFq2MHDs4kW2vvEGz7/4IoE4YRNv0RcpNgX9kcbpNJsL3hN0nOSIQG3uXupyuRJioxqzdu3aJjOl0fZKS0svq+3miE+v2h3EW/SNSUkJ+0zxQl+SemXWHaCJdX379u3tzkizYsWKVo999NFHm+x3OBzNutS0RuMXg4KCAnbs2MGSJUtYt25du9sB2LVrV4906xVCvxUa59H3lVeo6zURQRUv9GuKxcOiJ3M5FqHOzOjQVZYkm83GkIh/otZq41d/+hP/b+VKfvb731NWERu7BpsNrUEpphWtoisQ9CcaC32RR79zsNvt2O32Fu+nrd1DX3zxxSZJDqKW7KysrMtquyeSIPTtiULf2Ejo9zaLfkFBAVu2bGHNmjUJQtrhcLB9+3b1pS0qqouKitRiWI8++iijR49W89I33r9ixYomhbjiWblyJVu2bFHXo4Wz1q1bh9PpZPPmzWrbRUVF7N69m+3bt6v93LRpEyNGjGDkyJFMnTqV5cuXt9lOlKKiohazAXUnwjmxFRoL/aozp9X1Mr8fSBT6ThHY2KO5HIvQkSNHOi1Pc1dZknQaDcHIAyE5M4PsuLFZWlZGdiT7jiRJWDLScZWWihLrgn6JEPpdR15eHiUliS6B0fXWxPjjjz/eZMZ0586d2O129bxLbbsnEp9e05isCP3Hv/999DodowYOJCWyz9aMj35PJy8vr8UMO7m5uap7S15eXptVf5vbv2rVqla/u7i4mOLiYnJycliyZElCEPC6desSLPU1cf8PTqeT++67jyVLlqjZfXbv3q0K+HgR37idNWvWdHgG4EohLPqtEC/0zWYzzjOxYkTlgQCyLGNOTUUTEW61Z0VgY0/mUi1CW7dupaSkhLVr16qfaNn1aA7+nkC8aDelpJAV56NfcvFiwrGWSIBRwONRqzMKBP2FUKRQUZTuzsDSl1i8eHGTmIetW7fy1FNPqesulyshow4o/vjx1lGXy8XGjRt5+umnO9R2byEhGNdqIxQK8epbb/GP7dv59549SFol887UMWN7bDrnnsqSJUsuKfvNypUrqaqqwuFwkJOTQ25uLqmpqW3m/y8qKmLBggWdViegsxEW/VbwRnLagmLRrz17Vl3/6+9+p1QblSRsAwZQV1JCXWkJsiwnVCEV9CwuxSLUnF/+1q1b2blzJ8uWLev8Tl4i9XFC35yS0sSiH09jP/14n1CBoK8zatQobDYb9fX1gLDodybZ2dmsXr2atWvXMmHCBNW/Pv4+Wltby+HDhxNcUmbOnElhYSFr164FFL/8p556KuG+3J62ewvxwbgGu13NoQ+K3jAlJ9NQXU3QVUdSIx9+QdvE57dvL0uXLmXp0qWMHDlSFfpLly5tM66gJwbgxtNhoV9SUsLGjRvV6Hi73d6uH9kDDzzAQw89pP5ooxbRnly2urFFvz7OKmqNKzpkGziQupISQj4f7rKyBHceQc9i8eLFPPbYYwkCvTlr0/Lly1m2bFlCwZZ4OprK7UrwwRtvqMum1FSS4iz6TYV+urpcV1JCRqTsvEDQH5g7dy5/+ctfuOeeewBh0e9sxo0b1+K9ExTB/tZbbzXZPnPmzDZdcNpqu7cQtehLGg06kwlPnIuKxWTCGBH6XqdTGBCvEDk5OWzfvr27u9HpdEjol5SU8OCDD/LKK6+o/sxR14W2BPuRI0cS0irNmzcvYUquJxIV+kajEa1Wqwp9vcWCNs7P2poZE1S1584Jod+DuVRrU5SSkhK2bt2qTh8vX76cmTNn9giL0pYXNzI5smx0OMiKG4dNXHfihH78TJVA0F+Ij5URQl9wpYkKfb3FgiRJCRZ9s8mEMaLrw4EAvro6MesquGQ6JPQ3btzIvHnzEoIWH374YWbNmtWm0J83bx7jI1bDGTNmXHYu8itBVOibzWZkWVZ9oI1JiT+4xqIpa/r0K9dJQYe5VGtTdN+yZct6lMtOFF9lzCKUNHAQSXY7NquVereb842EvlkIfUE/J75QlnDdEVxpVKFvVarNehoa1H1WiwWTyaiur/ne93j4m99kyJAhV7SPgr5Bh4JxCwoKmgj0qOgvLCxs9dzs7Gzmz5/P/Pnze4XIB2iI/PAsFgu+2lqCkTfuSr+f769dy0d79wJCNAm6H6/XiyY+S1RkTEb99M+XlxOOpIRV9scXzWq5kJhA0FcRFn1BdxEOBvFFkkLoLYrQd8fdv61mc0KKzRd++csWs9gIBG3RbqHvcrlwuVxkZWU12We325sUumipjcLCwnYd2xNITU0lLS2N1NTUhEDHw2UX2bh1KweOHgXA2sjfWSC40pSUlGDXxHw4zZGsOoMzMwEIBINUxgV/xQfj1p0XQl/Qv3j22We55ZZbABg9ejRTp07t3g4J+hXxmc4MEYu+O86ibzGbMSU71PXeWh1X0DNot9AvbcXql5SU1OYgLCwspLCwkAkTJgA0Sa3VXq6k5WXv3r2Ul5ezf//+hNSFLlkGoDoy9RZv0XcJ0SToBs6cOUNSJFhLliSMkZm2YVlZDBk0iJmTJ+P1+dTj44tmuRu59QgEfZ34YPp169Zx3333dWNvBP2NhNSakUKOCa47ZnOT6rhC6AsulU7Lo99WFpKnnnqKvLw87HY748aNY/78+WrFsY6wbdu2S+3iZRFv0XeFI0I/8sOL5iQHJVWhQHClOXv2LPao0DeZkDTKT/t/vvpV3vnrX/nrL37B0MGD1eOjRbMA6i9eRI68vAoE/YF4n/x4X32B4EoQL/T1EaFfH++6Y7EkuO7YJKnN6u0CQUu0W+jbIoOxOdozABv75Y8bN47S0tI2ffsbc/fdd3fo+M4iPrVm1KJfExH6WoMBYyTPrag0KugOzp46hS0i7nWtVPiNJ75olk88RAT9CCH0Bd1JfA59o13RViOys7nv05/mrltvZUR2NiZHTOhbell13Pz8fNLS0hg9enTC9uLiYhYtWsTo0aMpKCigoKCAtLQ0tFot69evb9JOdH9aWhorVqxQP9OnT0/I4tgc8e0VFxdfUgGt5igqKkoo7NYbaPcdLjnydtmc5d7lciVk4mnM2rVrue222xIynUTba80lqDniA6iuJO6yeKGvBDXWxE2lmdPT8dXV4a6oIBwKoYlUtRMIrgTnjx9nRGTZnJLS6rFREopmlZaK9G2CfoMQ+oLuJMF1J6KdZkyezIzJk9Xt8d4Btl7murNgwQJ2797Nj3/8Yx599FF+85vfAEqe+hUrVvDSSy+Rl5cHwOzZszl16hRLlixp0k5eXp66f9WqVQn7fvzjH7f4/Y8++qh6fFFREffddx8LFizolMJWubm55OfnU1BQoF5DT6fdFn273Y7dbm/Ret9akYsXX3yxSQnn6KBtLri3J1BeXs6iRYt46KGH2LBhQ4LrjmwyAzHXHYhZR+VQCE9FxZXtrKDfU3nmjLqcHFfXoTUsCbElwuVM0H+IF/ozZszgi1/8Yjf2RtDfaEiw6Ddf9dYUV421N/rop6Wl4XA42LBhA/n5+ep2h8NBWpy786XyxBNPNLs9Pz+f3NxctZptbm5up1euXbBgAatXr+41sywdMmXk5eVR0iirTHS9NaH/+OOPNykotHPnTux2e5tV8LqL6upqtmzZAij+zHMqY+Jdn5wMbneCRT8hi0lpqSiaJbiiWEIhdTk5kmkHQJZlvvaDH1B68SKOpCR+F2cVEUWzBP2Vxnnz6+vru6kngv5IvEU/6vbbGJ3ZjKTTIQeDWCWJ0rhz7t2xkUrvlR+z6SYbW2a3XjMpnk2bNjF37lzuu+8+jh8/Tk5OTqf0Y/369c3OAAAsXbqUkydPtnp+1P3G4XCwfft2Vq9eTUFBAUuXLmXz5s3k5eUxdepUHA4HO3bswOFwMGfOHJYuXcqCBQsA5QVi/fr1PPnkk51yTV1Jh4T+4sWLeeyxxxKKBW3dupWnnnpKXXe5XCxfvpxly5aprjrjxo1LmOZwuVxs3LixR1fG9cQHxlituA99Aij++PbkZDh/nlqXi2AwiE6nSxRNZ84wWKRrE1xBvrHkEd781rcA1CBbUF5Sdx04QFllJemNXHoS6j+cE0Jf0H9oLPRFHn3BlSTeR9/QgtuzJEmYkpNpqKrCJklUV1er+yq99ZQ19PyX02nTpvHGG28wd+5c5s6de8m1AIqLi1mxYgVOp5Pq6mqcTmezQj9qYXfEzYY0d8zs2bOpifwf5OTkMHXqVGpqali9erV6/urVq1m5cmXCzEBU5ANMnz6dTZs2XdL1XGk6JPSzs7NZvXo1a9euZcKECZSWlpKcnJxgra+treXw4cMJ00wzZ86ksLCQtWvXAopf/lNPPdVjrfkAbrdbXbZYLGowrjEpiZS4QeR0uUhPSUkoQCREk+BKU38hFkMSP7sEMCgjg7LKSipravD5/RgNhshxca47omiWoB8hhL6gO4m36JsiFv2vfu97vFNYiNViYdv69WSkpWFyOGioqsKq0TAmLrA13dRycpSu5FK+Ny8vj1WrVrFixQoeffTRS7KA5+TkqD73TqezxUDc3bt3k5qa2mpb69evZ9q0aQn9A8XlZ8GCBWzatEkV9EVFRRQXF6s1leJxOBydFuDb1XQ4CmncuHEJQbWNyc7O5q233mqyfebMmT1a2Dcm3qJvMRjwRV5cjMnJTBw9mgafj9TkZORItVFzmhBNgu6j/uIFdTlewAMMHjCAfYcPA3CxooJhkbiY+OPqxJgV9CMaC/3G6wJBV9JcMG692427oQF3Q4NqjIkWzdIAP1u5Uj2nI+4zPYEnnniCXbt2sWHDBkaOHHlZbTkcjhZfFlJTUxNmPpqjObeenJwciouLWbp0qdq/7du3s2TJEvLz83E4HAnW/N5Gp+XR72vEC31zXI5xU7KDb3zhC/z5ued4/plnyIi85QnRJOhO4oPFmwj9OJ/9C+Xl6rLBZkNrVIpm1V+4gEDQX3jsscf41a9+pa4LoS+4ksQH40YLZjWujAtgjEux6e5lST6qqqoS1l966SVyc3PbTIsZpbi4uMVg16gwb7w/JyenzQDZkSNHUlxc3GR7bm4uOTk55Obmsnz5cqZOncrChQtZt24dJ0+ebBJf4HQ6Oz3It6sQQr8F4l13zBGrPST+8OKJL5olRJPgSvKXv/yFjz/8UFnRaNSquFEGxQn983FCX5Ik9aVAFM0S9CduvPFGvvCFL6jrQugLriS+WicAGr0ebcR6HxX6RoNBTfkan3nHXd77avQ0tq5v3769Vf/5eFasWNHqsY8++miT/Q6Hg9zc3GaFfJQlS5Yk5NV3Op04nU7VhWfp0qVqsG9eXh7V1dXNzkLs2rWLOXPmtOtauhuRQLgF4i36er9fXY5OpTVGZzJhsNvxu1y44vylBYKuZufOndjq6kCjQWOxqFVxowweEEu3eb5RQTdLWhqu0lK1aJbIpS/oL8Tnzxc++oIrSdSir7dY1G2eiNC3Rqz5kCj063uRrigoKGDLli04nU5WrVqlCvJolpvdu3erx+3YsSPB797pdLJjxw5GjBjR7H6ALVu2MGLEiCbfC7By5Uq2bNmipt+MZtiJzgLk5OSwZ88eVq5cyZw5c3A6nezZs0c9f9GiRQnuPUuWLGHRokVNvqeoqEgN3u3pCKHfAg2RH50u3cHeTAOaqeMYVnSk1WJElrQ0/C4XnsoK5HC4ieASCLqCs6dOMSMy1szNWEAGZcSCcy80mv4VRbME/RWNRoNGoyEcDguLvuCKEvXRjxf67ohx0RIv9OMMi88sf5KnR49mypQpV6SPl0NeXl6LGXbi89rn5eU1cfFpTHP7GxfPavzdxcXFqqjPzc1VM+zE92Hz5s3Nnh/NuBOlOTG/Zs0a1q1b12q/exJCibaA2+3GkJXJ0NVf5T8jHbz95fl8eP/tmFNTOXbqFPcsWcKN993HjzdsUM+JukGEAwE8bQxegaCzKDt1Sl22NfLPhzYs+qJolqAfcvToUfbu3Us44pYpLPqCK0XQ6yUYMSQarFZ1e9R1x9KCRd91sYzz4h7dLpYsWdJlGXGKiopYsGBBp9UEuBIIi34LXHXVVVz1naW4bLEf3bFbcjnsNDNGq+XgsWOAksUkSuPMO9aMxDSHAkFXUHPunLpsTmmaWizN4cCg1+MPBBKCcaFR0ay4dgSCvsyXv/xl3nnnHQB+//vfM3jw4G7ukaC/EJ9xR29VAnFDoRBenw8AW5yVP17o2ySpTeu3IEZXZcnpLQG48Qih3wLZ1+fievtwk+0vJwX5kTlWya46oTpuXC79khIGXnNNl/ZRIKipqUHrcUPECmRpprS4JEl8+f77MZtMamrNKPFFs+qE0Bf0E+JddR544AG0Wm039kbQn0hIrWlTLPrNZdwBIfQFnYMQ+i3wz3OH1OW8tw+yZ2QGNUMGUKwJUGPRqr6dVXG+XwkpNs+KolmCruf06dMkSTEPPHN6U6EP8LWHHmp2u0VUxxX0Q+KFvkbEUgmuIAmpNSMWfU8LQt8YFzNl1UhUVlZegR4K+hpC6DdDWJbZXqoEkugkDSOKjlJfUsJHD9wOwA5fJRmpqZRVVlIW98OLd92pKym5sp0W9EtOnz6NXZLU9cZVcdtC+OgL+iNRoa/T6ZDifj8CQVeTYNFPUlIhJ9vtbHj2WTwNDWTEVXbVaLVorVZCbjc2SQh9waUhTBnNcKKukgpvPQCjktLhQjnDdx9BCimBWx/4qhkY8b+vrKnBHwnkEkWzBFeaM2fOkKSJCRVrXM789hBfNEsI/f7D1q1bWbt2bXd3o1vwuVyMqShnpl5POBhk586dvPfee93dLUE/wRtn0TfaFTdgs8nE7Ouv5+7Zs7m2UVadqFVfCH3BpSIs+s1QVBmzxhe9sJlrnU5Mskzm+UrKhmRyIeRjSM4QOHwYWZapqKoia+DABP9o1wUhmgRdj+K6Eyf0WwkAr3O5OHP+PDarlRHZ2UCsaJartFQtmiUsnH2TkpISNm7cCCj5q+fNm9fNPeoeXv/617iqpoarTEa0wHXXXYder8fr9XZ31wT9gIYEoW9v5UgFa2oqnvPnMUgSlcIYI7gEhEW/GfZUxYS+Z88hiFQMHVoSC4TRjx+uLl+MvGXrLRY1L677Yu8pbiHovdx2220Mj8wkafR69HHp2uLZdeAA19x9N59ZupQ//v3vCfuiM1HBhgZ8ccHlgr5FdnY2Tz/9NE8//TRZjYKy+wv++noOb9kCQNCgY6pesXUFAgFCoVB3dk3QT0iw6Lejbkl87R6nEPqCS0AI/WbYE7Hoh31+zCWxdITDq9zqsmdYzHLaXIrN+rIy5MgLgkDQVdx5551YI7nATQ5Hi9b4oXHpA880ciuzpAk/fUH/4Pye3cgSvL30s/zp109ybOk8zJHfjLDoC64EXme80Fdcd85duMD7e/bw8dGj1NXXJxwfn3nHXV4udIWgwwih34jyhnrOe+oA8J4oIUWvV/cNCmowRzKc1KTEIuPjq41GU2yGfL6EH7RA0BX46+vx1Snj1dRMVdwomWlpmCK++E2EfoaILRH0DyoOHebc1aM5PX0CAMXXXsXAaeOAWDV0gaArSXDdSVIs+q+/8w4PfutbfGbpUt7bvTvheJMjZtH/xpIlYuZJ0GGEj34jjjhjlUN9JyNCPxJsa0hOZpjWwpFgPT69hse/tYwxthQmjR2rnpOQxaT0fLMFjASCzqI+zkWstbEmSRLDsrI4WlzMuQsXCIVCau5wi8gWJeggvbWSbNWxo5y7ZnTCNsv0ibDrsBD6gi7FHw7x5xN7ePmqDHTSLCZs36n66Mdb8e02W8J5pjj3nmsnTkSnE7JN0DGERb8RR2pj1nnfmQskxf2odCnJDNfFqtaNm309n541K8EtIkE0CeuooAupqanh5L596ro5NaXlg0EtlhUIBhMq5MYXzao9c6ZzOynok2zbtq27u3BJ1J07R0VOYnyCPHYYICz6gq7DHw7xpXdfYvWBtzgyJJWDt1/HP7/zBcoMittYvNBPaiz0Uxzqcn2ZiP0TdBwh9BuRYNE/cxF7XMVEfUoKw+KE/seBuibnxxcsqhVFswRdyEsvvcTS++9X1+MFe3MMjwvAPB33EpqYFlZY9AVtc/fdd3d3Fy4J58UL1A5MLCoXyExFMuqF0Bd0Gc9/8h47KxL1gCfFzg/qjuGXw60KfWOyQ112xxloBIL2IoR+I47UKj+kcCCI/3wFtrjgRn2KgyE6s/qPdijganJ+ohvEuS7tq6B/c+zYscQc+m0UyxoWJ/TPtCD0XWIWStAO9HGxS72J8546ZG2jx55GwpA9QAh9QZdw3lPHH47vAkArafjUn98k+bySqe9MqIF/ei62btGPi70qKz7FuXNCVwg6hhD6cXhDAU67lEAZf0kZhMJYiEW461JSMEgasrRKIO6FkI9dJ47yr3fewefzAY2soyVCNAm6jmPHjiXk0Le0kkMfWhb6CUWzLlzo5F4KBD0Df309VaaYK6Y2EFSXjUOF0Bd0DX89WUQgrATQfmrAcHLe3sNNv3tF3f9n9znqAj513d4oRXK8j/5H77zD6tWru7jHgr6GEPpxnHJVE44Ie/8ZxRfOHKmGi0aD1qb8AIfpYhl3Hv7lT3nsmWdUV4gE66hIVSjoQo4dO4Zdiv2ELW1UxY0X+qfigm6jRbMAtWiWQNDXcJ0/jyvDoa4POhJzpbBmZ4r0moJOxxcKkn/qAABaSeJOxzCQZdLPXGTUEcUyXy+HqBurxPmZjEYMjWbLdCaTaoixSRLnha4QdBAh9OModsUKYn3quht45pc/w2EwAKCxWZE0yj/X0Dg/fdPoIYCSBxdAb7WqP8r6i8I6Kuga/H4/p06dSnDdia/M3ByDMjKwmpWX1Hq3O2GfKJrVv3C5XLhcTV0P+zKu86W4MmIB6+HCg+ryrPn3MHfu3O7olqAP8/aFk9T4lZmiSSmDsDX41X3TDsZccELXjgdJwtFCpVxTpGiWTSNxRiRMEHQQkacpjuK6anX5usm5zMwYyjvf/T4A2qTYD3CoNmbRN41ShP7ZyFt21DrqKi3FXRYL7BUIOpPi4mJCoZDqumOw2dC24Tet0WjY8utfkzVgAFaLJWFf46JZreXkF/ROXC4XL7zwAi6Xi9LSUgoKCgClYu7ixYu7uXddj7u8AndakroeOnoaKRRG1mq46KtHoxF2r86ipKSEjRs3kp2dDYDdbmf+/PltnldYWEhhYaE6RvPy8pqc98ADD/DQQw8xc+ZMALZu3QrQI8fw9tJj6vKnBuYQLHWq65kBmRydheKgB+2AVMwTRpDibb7goTklBffFi5gliTMnTyLLcovFEQWCxgihH8ep+pjQH2J1EKyrQ474cWqTYg+IFI0em6SjXg4qQl+SVKEPimXVVVpKwOPBV1eHMe5cQffTlQ+hK8WhQ4fQgCr044uqtMaYESOa3R5fNKu2pISMCRMuu4+CnoXdbmfZsmUAPP30093cmyuPp7KShqSY/3N9VS22qlpcmSlUyH4hnjqJkpISHnzwQV555RXsEQv12rVr2bhxY6tivLCwkCNHjqhj1OVy8cADD3D48OGE8XrkyBFWrFihrs+bN69Hjmd/KMjbF04AYNLqmJyaRe2hmDVea7NxrTGV4qAHAPuN15Cy63SzbZlTYvd3ub6empoaUlNFjR5B+xBCP45TEdcdDRIDzDZ8p+J+lHEWfUmSGKozcyjgQmszox+Yxtm4IEZzemIu/Qwh9HsMXf0QulIcOHAAuyShjQiT+LSul0K8Rb/2zOnLaksg6Ik0VFfhjQh92eujzusnu9KJKzMFr0aiNuDFYTC30YqgLTZu3Mi8efPU+yvAww8/zKxZs1q9x27dujUh0NRut7N48WKeffZZFi9erBpm5s2bx/jx4wGYMWOGur2nsavyHPVBxVVngmMAOo2GYJxbpNZmY4LejgENfsIMuHUGP73jwWbbMse5ZSZpJIqLi4XQF7QbMVcZISzLnHIpFv1knYEDH+3i5M5YKWpdXOQ7NHLfGT2EU3Epr+LTHNaJVFg9ipYeQs8//3yr523dujXhIRV9CP3973+npBuqyR44cABHfGrNNjLutIV1QCyQt6a4+LLaEgh6Ip6qKrx2xWVNrnVTFw5jr3Cq+//xzo5u6lnfoqCgoIn4jt5vCwsLWzxvx44drF27NmHbhMjM4s6dO9Vt2dnZzJ8/n/nz5/dYkQ+wuyL27J+cGilW6IwJfZ3dhkHSMMmgGAK9hDlmDDXbVoLQlzScOnWqK7os6KMIoR/hgqcOb0hx09HVevjqvZ/jl08+pe7XOxoJfV2i0D934YKaYtMal/2kuvhkV3Zb0EG6+iF0pTh16hSOuIw71swB7TovFArx202beGLlSp75+c/V7baBg9RlIfQFfRFXVSW+iNAP1dZTK8vYKp3q/v8c3NtNPes7RIO8s7Kymuyz2+0cOXKkxXNnz57dbuHucrnUWdaeyp6qWArjSSkDAQjEW/Qjz50phpi22OGraLYtS4LQl4TQF3QIIfQjRK35AEZ3AABbnJDSNhL62TozUXuqadQQwuEwxRHrvXVATHQ5xQ+yx3ClHkJXgqKiIn7w//6fum4b0D6hr9VqWffXv7LljTf41zvvqNutmZlqVinn6dOd2leBoCdQ5Y4VJfLX1hMAjJUx4VVNoBt61bcobaXgXlJSErWtZPRavXp1k5inQ4cOAYqLTpRorFTU0PKVr3zlkgR/INB1/9+BcIgD1UrcnsNgJs2kuIwFa+vUY3QRd+CROisWSQtAka8Wvxxu0p45tanrjkDQXoTQjxCfWtNQp6TDii9GZGjkA22StAzQKGk0jcMGIhn0HIsIpHiLfu3ZxLLXgu7jSjyE2kN7HjCeoJ9tZw/x/wq3cd+/X+S//v1Hntr9GtvOHsIfCiJJEpr6WHpE66BBrbSWyJicHAAqa2oor4rEpeh06gtq3blzIpe+oM9R5YullA3WKcvamthvyEmwyTmCzqWjKV03btzI448/nmBkeeqpp8jLy8NutzNu3Djmz5/P8uXLO9yXbdu2dfic9nLYWaZ6CIy0x7RDoKZGXdYmKy47+3btQXtCeTb5CFPkczZpz9zIol9R0bzlXyBoDiH0I8Rb9LU1ykMgPke5vpkc5UMi7juSVsuAyePwRqvjZmRA5CWh9qzw0e8tdMZDqD209oCRZZktpw4w9/X1PLFzG/88d4j91RfYV32erac/5omd27j1X79h86n91MbFfyR1QOhfPXasurz/8GF12TYwMr3s8eCprOzIJQkEPZ6aUKz6aKhWse7r6mPVcN2a5v2jBe3HZrO1uK+urq7Ffc2xfPlyZsyY0SSAt/H9dty4cZSWlrbqetkcd999d4eO7wh7KmNxW2OTY/FT/qqYzoi6Ax8+eJijW95Ut//HFzM6Rol33cmbNo0tW7Z0an8FfRsh9CPEC30qlLdue5xFX99MVpP4wllf/94K7vv0pwHQ6vXqD9N1vmUrsuDKciUeQu2hpQdMfcDH1z96maf3/IsKr7vZYwAqvW7+Z8/rvHDtcHxWE1qDAUMHMjtNjmSsANgXJ/Ttgwary8JPX9CXkMNh6oi5RDiMJobnDMesM6L1KzNsPlPrdSgEbZMcSVrRnNHE5XIlJEFoja1bt5KUlNQko9natWubuOlEv7O1Gdvm0LdRd+RyKIrzzx/viLlVBqojFn2tFk2klklNdTWeAycIe5UMPTt9NYQazajqTCb0VsX9x1ddjUDQEYTQjxB13bHo9HirFReOpIiPvmQwoLE0TbsWH5B7yJ8oFKPuO96aGvzulkWb4MrR1Q+h9tLcA6Y+4OOL777EG6VH1W0THQP41lW38LsbF7HhhoUsnzSLKWmx+IIzOQP551MP4Rs1rEP5v69pQejb4mYFqk+caHd7AkFPx+t00mCL3a8/t/BefvabXzDhuhlYq5V7d8BuEi5rl4ndbsdut7doOIkWuWqNgoICXC5Xwv01es9+8cUXVZfJKFGXy+Zir7oDWZYpilj0TVod2VaHui9q0dfarOo9u6a6BjkQxLNfKa7lkoMcCjT994v66bvLy8U4FXQIIfRRRFa5V5nKzTTZ8NQrwtwecd3RJic1K6QGaIwYIv+ER4P1Cfvis6CIFJs9g65+CF0q7qCfL777EvsjwVtGjY4lY6/lyatv5erUQeg0WgxaHRNSBvJA+jhKn32BkFMZb64Bqbz8pU9zIeht9/cNzMhgYKTWw8dHjhAOK5ZO++CY0K86dqzZcwWC3oinqiqhWFaSpLxsG9LTsEUCcmWDHqe/odnzBe0nLy+vScrh6Hpb99gjR45QV1eXMFMazbAD8PjjjzeJldq5cyd2u71d9+8rwZn6Gqp8ShGsEbZUNBHtIMsygRpF6GvssdnlmoiV37MnNlPxH2/L7jshnw9frbNL+i7omwihT6LbTqbZTr3LhR4wR36gjTPuRNFIkuqnXx0OUBXyq/vi85I7T4vMOz2FrnwIXQphWWbFzldVkW/R6ll+9SxuGNB8BdtPivbh2X8c///8BkepEpDlSrLwRM3BhPHXFldHrPr1Hg8nIwHjiSk2RVpYQd+hoaoKb1LM1dKuVWpF6tNSsVXFgvBLPR1z4RM0ZfHixezYkViTYOvWrTz1VCxdtcvlapItp6SkhBdeeIGkpCQKCgrUz9q1a1W//HHjxlFQUJDQzsaNG3tUZdw9VbHny5g4//xQfT1yQAnQ1cYJ/eoqRegbT5erguwjX3UTq705rkDW8q881mbtF4EgiqiMS6LQH2S2856zNiHjji7F0eK5Q3VmTgaVGYCHf/kT7hk0ii8tWpSQYrNa+Dv3GBYvXsxjjz2mVriF5h9Cy5cvZ9myZYwbNw6IPYTmzJmT8KApLCzk3nvvveT+/OrQ+2w/r1jPTVod35x0MyOT0ls8/uCeIgBSquuY+5M/88b/ux9nVgYVYT/fdR7mp6lXYYqkamuNa8aP58133wWg6OBBRg8frgTjShLIsvDRF/QpPJWVeO0xi75NUh59utQUbEUxoX/OXcNVkZzngksjOzub1atXs3btWiZMmEBpaSnJyckJlvja2loOHz6ckOnswQcfxOVyNXlJAFQhP3PmTAoLC9WaJqWlpTz11FM9xpoPsLeyef/8+EBcrV2JqQoGg9RF/g0cZgs5Oisngm7Kw35OBz2M0MfGbHzmndfz8xl84QKPP/54l12HoO8ghD5wKi61ZpY1GY/brbrtQBtCP65C7gWzxJ6DBxWhH+e64xSiqcfQlQ+hjvJR+Rl+ffh9ACTgi6NnMjqp9Qq3ez/4CIB0jYTZ5WHuT//C66u+Sq1By4mgm1XOY3zXMU6dLm6J6VdfrS5/sHcv9911F1qDAWtmJu6yMmpOnUKW5Q75/gsEPZWG6jjXnbDMD7/5NEajgbvvmIs1zqJ/pk4EOnYG48aNU40kzZGdnc1bb72VsK3xekvMnDmzRwn7xkQt+lpJSkytWR1LrRnNoe+scarbUlJTmKi3cyJiOHzPV5Ug9OMz7yRrJPbs2UMoFEKrbduwI+jfCKEPFMdZ9IdYHPxjzweUbP0HJ779XQB0cVNmjUmokDtqCHvf+DuyLGOPD2wUQr9H0ZUPofZS6/eyYterRCdn78wez4zMoa2eU+es5cj+jwEYnuIATwPmOjcPNNj4rcGHjzAf+mvY5C7lc7bWU35ePW4ct914I9MmTeKm6dPV7clDhuIuKyPo8eAqLSWpBxUJEwguFU9VFd5IVVyDL8AnhxSXkZtu+RT2Oo963PmG+mbPFwjaQ7XPo3oIZFscGLQxieWvihkUtQ7Fol9dGduWkprKBL2dlxsuAvCBr5oHbbFngiWuPo9D0uB2uzl06BCTJk3qmosR9BmEjz5wqj4SIINEptmOJEnIzpiVR5+W0uK5do2eFI0S2GUamU15TQ2nS0uxpKejiWRXEdVxBY35/t43udigBPHm2NO4d/jVbZwBRe9/qAbODjLH/I2HDMriAdsQdX2j+ywH/C0X/wLQ63T85oc/5Ev33cfYSAEtgORhsQdLRQ8uLy8QdAR3Zcyir/PFCtYZTUYccenzSz3OK9wzQV9ib1xazVFJiSm5Eyz6kQxwFeWxwlcZAzJI0RoYrDUBUBz0UBFX+8EWJ/RTIh4HH31UiMcjKjoLWqffC/2QHOaMS/kBppks6DTKP4mvrFw9xpDess80wJCI+47GZMAwJJOd+/YhaTTYByt5yevOnSMcFFUXBQo7K87y2jklraVZq+fL465Dq2n7p7jr3ffVZatXybKjdSSjMRoZq7cxx6S4/cjAj2qPUdOB4NwoSUPihP7Bgx0+XyDoidQ4qwnrFeuq1hsTRgaDgSSDCSmoqP0L9a2/IAsErRFfKGtcnH8+gL8ZoZ+ansYtebOYePVVDIkYWSboY2meP/TGvA2iFv0qOZUSzc2YzY/w5JMVDBr0U55//tITQgj6Pv1e6F/w1OELKyI8wxSLhPfHvWk3VywrngT3ndFD+WjfPgDsg5W8vuFgkNpzZzury4Jezm+Pxm7Ki0ZMJtPcdv5+WZbZ9Z/3ALDp9RCpzaDLiL2EzjZlMEqnWC2d4QDP1h5rUnilLZKHxGYGKg4fauVIgaD3UBmXTUfjixldDEYDxtRUrDXK/rKGy0uVK+jfJAj95MyEfYG4Qlf6SNzf+Inj+dqTX+eHP/kR069VXCgnxgn99yJVcmVZ5r0DHv6sWcx6lnJQczNa7XDCYcWy/73vvcPJkyK+RNA8/V7ox2fcGWi2U3z0GM9953uc2bNX3a5Pbdl1BxIr5JpGZfNBURHhcBh7VqzSaNVxUYBIoBDNsTw6KZ1Zg0a165xTx45Tcuo0ADMmxOILDINiViONJPHf1mzskYwiBwJ1vOROTCXamHA4zL5Dh1i9bh0utzvBJ7/q6NFWzhQIeg/R3xyA5Iu36BtxBkNqLn13OIgr4GtyvkDQFt5QgEM1in99utFKksGUsD/eeNhago/BWhOOiDvwwYCLt/dX8d/fPMDXfnCEs6HBzZ4TDIZ58sntl3kFgr6KEPpxQn+wJYnTx46T/7uN+C5cAEBjs6ExGlttI0trIhr3bho9lIrqaj4+epSkuEp9VUeFv7Mghk7S8IUxM9qd1WboyBzWbv4z8x96gJtyp6jb9QMTUwHaNDr+25pNtNUX3ef4xN9ybvCf/Pa3zP/KV1j317/y9kcfobdYsGQoLkDVJ0+KCoyCPkGCG5s7VlzOYDQQslqwVcdcds67hfuOoON8XH2RgKzEUI1MauoF4Iv3EmglwYckSapVP4TMk/84wifHY0Hi6VQwmwJ0nh9TX/99rJHEPAUFp3jjDWFQFDSl3wv94oTUmg7qamrRgppHX9dKIG4UvaRhUCSAxjA4HY3ZSMH776uuOyAqjQoSmZs1lsGW5guxNYdOp2Pajdfz/1b+gDEDY1Z8U9agJseO1FuZHfHXDwMra4/hCjcfIxKfceeNSF795Iifvt/loj7ywisQ9GZq5dj4l9yx6rcGgwHr4IFYq2Ivw6VC6AsugXi3nbHJTdMk+8rKANBYzGiMBsLhMB63p8lxAJpjMWlmith1BqQbuH9sMV/it8yQdpEquQA/2dmxZB9PPlmAzyfiAQWJ9HuhfyohtWYyNZWVJEuSmodc14Z/fpSo+46k0WAclc17e/Zgj7PoV58UlUYFCikGM/OGXXXJ53tOnSYsS5TLGewrG8ArWyr4w7rz/OYXJfzyp+f45U/PUfKiH1uV4sJTEfazpupYs9b56ZMmkZKkpHp7+6OPaPB6cYwYru4vO3DgkvspEPQEgl4v9cZYmsNQbUxcmUwmkocOwVbpVLeddTsRCDpKUVxF3AmOxJlWWZZV1x2tQzHwlJeVc/+8z/HFzz3M3178KwBeb5jf/qqUl35UQdit3K9NV0ss/PQAfvj10eSONRGdBL5qyAgeeeT/8bWv3cfEicqLxenTTn79691dep2C3ke/z6MfFfoWnR67wURVRQWOuAwohszWCxhFGao180Fk+b4vf5HlI6diMBjQW60E3G5RNEugcteQCei1HfvpybLM6WO1fPRWKf/ekcV5vkkAA/y5AWho9hzNTsj4HmhsEjvDTu55YTczvancMNXB9VNSMBo06HQ6brvpJja9+ioer5fX//MfckeOVNso3b2LUbfffhlXKxB0L42r4gZrYtZ7s8WMKTsLW5xF/5wQ+oIOEpZlNbWmVWdgYKMEC0FnLWG/4j6mdTgAKDmrvBhUV1UTDAYpPeflF2vOcqFUOc73MZivBckMo2aZ0fgl9I6YHpl38x2MuP8rACxdmsrXvvY6sgxr1rzPf/3XRAYNajvJg6B/0K+Ffn3AR7lX8X3LMCoZd6rLK9UctQD69gr9uMw7DYOSMUb8+pOHDKHyyBHqL17EW1uLKbn97hqCvsmo5NbTtcZTdt7Fkw/+HE/9SGrVyaf2jclwDTh/D6nLlHXfbX62/vAiL712EYtZw6empXL37Ezm3TaXTa++CsDm114j78kn1TYu7t3X7r4KBD0RT2UFDUmxhAnXTZnCGHsqDQ0NmC1mdBorliqnur9EuO4IOsjxuko1iHuEPbVJ7FXUbQdigbglZ8+p28LhHL63ohhvg+Ljr9NLjNVbOYuSXe0TYx2j/DZ0KbF7v7fsvLqck5PCHXeM4rXXTuDxBPjOd97id7+7p3MvUtBr6ddCP94/f4BFefutqqhggBRn0R84oMl5zZGmMWCRtHjkEMcCbmRZRpIkHMOHUxkpPFR5+DDZ117biVcg6Ksc3lvJSxsO8UFBCbI8ssl+BzVk2hsYcO0EUjN1OFL0mC1atFqQZfA2hPHUh6iqDHDyoIuGq4JIegnHUpmqH4CnIczr71by+ruVDMowMCD9HsoqX+OjffuoCoXQWywEPB7KD37cDVcvEHQe7opKvEkxi/6tN1yP/sYbE47R1nqQwmFkjYYSl0hTKOgYRXH++aOTmvHPTwjEVeL+ohZ9vf4mtv8rGSKBvGmZOuY/mEnKQD1/lt2EJThidHGPS0afEjMSeS+eI54HHria//znLPX1fvLzD/GFL1zDDTe0Xm1d0D/o10L/aG3sxzckEhhZVV7B2DiLvnFA+4S+JEkM0Zo5GqynXg5yPuQlS2cmadhw9ZiL+/cLoS9oEVmW2fPeRf7y64Mc3F3RaF+Y9MEwLUdmxPvrSZGchGd+Gt1trQeLjwRysfPP4AWqdQH0gyVGfVVP6f8F8USsRxcq/MBMTKYUvN4/8udt27g2J4fygwdxl5XhrqjAmtG+WQSBoKfhqaigIeK6ow+G0UtNQ9NCZjOWGhfutGQuCIu+oIPEB+JOcDTVDPEFOHWq0D+P0bgAvX6KUuUQGDnezLz7MzAalTx+gwJmSg0NuLRBzuu8ZGFGa08h5KrBd1H5ztOnj/Paay8xY8an+Pznr1Z99Jcu/ScffPBFkpJazxoo6Pv062DcY3FCf5gtFVmWqS6vIDXeR39A+wXOiLh8+n88uIuHly/ndwUF6rayA/svs8eCvsrRA1U8+fl/89QX3koQ+eFwHX7/DnTGP7D8F7dww8BzpEhOAKRB2c031ggdGmbVZ6KTlRfY+okBvvC/g/nqA0OZMMqqpuLU6cZgNN7F37Ztwzo0Zgm6GCkAJxD0RjyVFXgjrjvmUPPpYqXUFJLKlcqlHsLU+JqPexEIGiPLMrsqlYKYeo2WHHvTBB7+8pjQN6SnU1nhpeTsLYrIjzDzliTue3iAKvIBhgVimmK/yamcn6FkWgu569j/0b956KG5vPTS7/j73//I3LkjGT9esfqfO1fH8uUx/SHovwihH2G4LQWP2423oYH0iMVH60hGYzK1dHoTRulj08NvXijmncJCtsWJpIpPPrn8Tgv6FBfO1vODx9/l8XvfYP9HMT/O1AEmBuccx+P5CX7/v5mz4NNodTqCp2J5kjXZQ5prslmSw3quc8ceQNscFxg2ycS3vjCC//fF4WgjdwK9fib+4BRO+2J5x0sLRXl1Qe/FWVmB36rEUFlkiarKKny+xKJYpkEDSSqLueycrhfuO4L2UeKupaxBifUbZktBp2kqq+It+qXeFL77xEkkScnKJ0lB7v5cOnmfTmvi2z/cb0GKvJt+bKojjIw+PVY0a6gtmfR0JcPPhx++RUXFBb71reswmxVnjb/85WNeflnU8Onv9FuhL8uy6rpj0xlJNpoJ+gPcM+8erBHXHf2AzNaaaEK21ow58pJgmTQSJAkf4IsE5lYdP44cDnfeRQh6LT5vkBfXHuBLd/yTd1+P+Vo60o0s/Mo4Hnl6CCcP/QkIYbbauOnOe5BlmeBJpR6DbLZASsfcaUb5rYz0KS+jfk2YTcnnCBJm3EgbD82PpYI1GT+NZsgd6vq5Dz+8jCsVCLqXsjqnumyVtHzpv7/Af929iO8++T/q9rQxo0i6GIvZOllXeSW7KOjF7IxY8wHGJDWfaKHhnOJm84k8gZ+sC+CqU9R7OFzDpOmnuDq3+Qw5JllLVkB5SXVpg5zVe1SLPoCv9Ax33XVfpK0Qf/vbOgYOtPHoo1PVY77yldc4cUK8uPZn+q3Qr/C6cfqV6dmBkUDc5NQUvvylh9VjDIMHNntuS2gkiZE6RUgF9FrSJo4C4JRbiZwPuN3Unj3b4vmC/sHBXeUsufM1/vT8QQJ+5cXPYtdz5+dH8u1fXce1eYN55cUNhIJK4ZNbP7sQk8VKuKIcuU7xH5YHZbe7qm4UCYnr3WnYQ4q1p1TvpcCmWJquz03hrlnKi4MMPPuHSk5apwFwcW8R4aAowiLonVQ0xKXTJOYWYTbHMqWljsohOc6if7IuJvoFgtbYVREz1Ex0NK8Z3GfO8Y78KV7hMwQCisgPhU7T0PB/TJzcugvmSH/MU2CvyYk+PSb0PedOMm/e5zGblWNeffUlKivLuPXWEdx0k+J+WV/v57/+K5+6usRZLEH/od8K/aO1sam07LgKpZ7iWJU5w+DBdJTRepu6fMPnPgvAhVDMii/8nQW//mERF84pU70ajcS1cwex4lfXMvuzw9DpNZw68gm73t4OgC3ZwZwF9wMQPHk01kj2sEv6bj0aZtVnoIlMB79nreKYwQXAZ/MymTVTKc0eliHfPZtj8miRfUfQq6n0x1XCjfPRtyXF7tWGARkJrjvFIvOOoJ3srlSEvk7SMKaZiriuGg9/KbmOD7hB3WYwnaCh4feAh6yhOa22P9RvQRuJr/rEVIc2PfYy4Sk5RXJyCp/9rPKMCAT8vPDCz5EkiWXLZjB0qFIM8fjxapYu3UY43HyMiqBv02+Ffrx//lBrLHOJ51RM6BuHZNFRRutib9+MHUL2wIGUhELqpnMfftDMWYL+yJDRdpatnsrCpeOx2vQAhIJB/vTzVeoxn/7vhzFblTEVPBET+tLQEZf8vekhI9M8sTGfn1xKtdaPJEn8992DuCHXAUBY1rCV+RyQJ3Hm3fcu+fsEgu6kmthslM4bUJdttpjQ16WkYHfWowkq9+oz9TVXroOCXssFT51ad2GIzYGhUSHE0jMuvr7wTY7Lyuy+hMxNc5P55vdu5asrvs9nP/cFjG3EAerRMNSvBOV6NWFODTAh6ZTnhbf0DACLFn0Jq1UZz6+99hJHjhzAbNbzne98CqtVH9l+gief3N5shXRB36bfCv1Pai6qyzl2xYoZCoUSLPrmoe0PdoySpjGQolF+WMdCbr752Jc5F+eXf/p9IfT7O2abjnsfHcvXVk1jyMikhH2yLDPlxlvQ6fVk54zm5rvnq/sCR2LB3JrhTXPrd4SJviSy/YrrgkcT4kXHGRqkEBqNxEPzs7hqtOLiIKPhVe5iw4tHW2tOIOiRyLKMUxMTNhpXzLpvs8eEvqTRYMyIWfXPuqoJhGMGGoGgOXZWxFxxG+fP3/vBRZbd+wbnzngAMNHAvHGH+VReKlqtlqxhOcy4aXa7vmdUnPvOLqsTfZqSwtNfcQE5FCQlJZ3Fi5XKiLIs89xz3yEQ8DN4sJ3ly29AE4k73LChiFWrhNGmv9Fvhf6BmgsA6CUNQ+2KdXPJXfM5+e93AJAMBvQZ7a9gGkWSJCboFZ//EDLJ0yZw8803UxUR++WfHCTg9XbGJQh6KYufmMT1t2U162Ov0+u564Ev8p3/e5EvLP8uWp1iIZJ9XtWiH05JQ0pqPX9+W0hI3OxOJznir1+p8/OX5LOEkNFoJGZOribgjwXhbj6WzbJlr+HzCV99Qe/B66zBY4v54vsrnepyalpqwrH6QQNJKVFcOsOScN8RtM27F2OGwUkpiu+8LMtsfeEI3/7CW7hqlexlaVSymI2MGdv+LH7xZAXMWMKK8eW4oR7/cMXdRw4FaTivvGzMn7+Y4cNHA3Ds2EE2blwLQG7uIL7xjZlqW6tWvc/PfvbRJfVD0Dvpl0K/2udRp9sGW5PRShpkWebisRMkR6a1DEOykJpJk9UeJupjVtp3fVX879e/TrlW+ZFqZZmd/9x2mVcg6M1YrG3XqRs0dDhZI0ap64FjRyAaEHuZ1vwoRlnLHNcAjGFlnJ8yeng56TwyMtdNuZ5JYysZG3pLPX7jxgN8+tN/4cIFV6d8v0DQ1bhKz+NxxCz33rJYkG1joW8eNkQV+gD/OSbiUgQtE5LDvFemCH2jRscExwDcLj8/ePw9fvNsEeFIPMjIdBeL2UiqVAPpHcvkF0WDxBifMo5lCY7NHKfuqz95GACdTs9TT/0UrVbHsGGjuPnmWOa0WbNG8Mgjuer69773Nv/7v+8IN55+Qr8U+h9XX1CXh9sUy2hZ6XlS4nIrG4c3H+woyzI+X5jqygBnT3s5fLCevbvr2F1Yx84PavnwXSdlH/kxhBRr7a6GGs5VSIz91D34ZT2yDIa44hkCQTAQ4OPC91s9JnDogLos5YzptO9OCuvJq89Ug3OLzE5et5WBBF++/3GsxiLuYhs6FN/mXbvOc9NNL/DGGydaaVUg6Bm4zp/Hk6zMsEphmdrzsXtvalpiYSPjkCxSz8VqWby6V1g9BS1zsPqimrlvVFI6pw47+cpnXue9N2JZeK67YzCfG7Ybo6RY9s/UOXn+2ad4t+BVXLXODn3fGJ9draD78ZhUIvG51B+PuXSOGXMVq1f/jnXrXmb06IkJ53/mM2N56KHJ6vpPf/oh3/jGGwQCwkWtr9O2abEPsr/6vLo8MpL39tTR42RFqgbJMjRkjGTfbhelJV4qygJUVviprAhQVRHA6207F37yF8FyvYRfI/PF3x7E/8kEYAJ6/Pzzp6V8OekAn/70GFJSLm0qT9A3CIfDvPjcsxTueJ17Pv8Id97/cLMuPYH9e9Rlacz4Tu3DgKCJT7kzeNtaARK8b63CIGuYTSZz718GL/6EdLmSzfJ83FIyFRUeFi3K5+GHr+FHP7oVq9XQqf0RCDoL1/lSGiIWfUsgRE1lyxZ9Q1YWqediLwKHqy8iy3KH09gK+gfvXDypLmuOafn6d98kEFC0gcmiZf7SMUy9aRDVjypWf9lgZPcnBzh/7jTnz50mJS2Dq6bMaPf32cI6sgNmSgwNuEwaSifmkH2wmPrixPipadNuarGNBQsmYDbr+b//2w3ACy/s48SJajZu/CxpaZYWzxP0bvqlRT8+gGZ8UiZnT9TyxtaTVOnu4kX5QZ7jm/zvXzP56bNn+NuLZex4o5r9RfWUnvO1S+QD+PbGls3TYssBDBysTOKxx15j9Oi13HjjWv72t4Mix20/JBwK8cefKSIf4F9/20j5+ZKmx9U6CR5TpmfD6QPQdLBQVnvI8Vu5Ma5y7lu2Ct62VDBq7BQCKZkMki7yJekFCMaqLL7wwj5mzPgt//znMTEFLOiRVJeex2tTBIw1LFFdrfjdGwyGhGBcAGPWIMx1bowuJXgylOngP//5z5XtsKDX8NaF2KxmwZoSVeQPHGZl2appTL1pEGGPm3CFMksUSsvg4D5FYJvMFsZedU2Hv3OsL1ZY69Dt1wPgOdP6/dfjqWfFii9y4MBOAD796dF861vXodMp8u/dd89yyy0b2bmztMP9EfQO+p1Fv7rew75KxaKvqdWw9MbXcbsCgBk001o9V6sFW5IWq12LyarFbNZgsmgwGjRodKDVSmg0gAx+ZE4F6pD1YJ0pMWyPlbqTZ6lq0OFC8eEPBMJ8/LGHpUv/idGoJS8vh/nzx3P77aOw2YSVtC8T8Pv4/ervU/Su4gMvaTR8ccX3GZDVNNOTf+8uZZoJYMyELuvTGL+doFvmI6sihgrs5bi0QSbfMAv/PzdhkRqYHPobhcFrsFjuIRzWUFJSx/33b+W220ayatVsRo5MbeNbBIIrx7mactAo9VCSNTr+d80Pqaqsot7lamKp1xiNGDIzyDh1npKrR6FLsvK/v/o5O26+uTu6LujBFNdVcdipzP74i2XCkWys02YP5N4vjcNgVER06Oxp9ZwyWSbgVwx6U2beiF7f8Wf8kIAZe0iHSxvk/LihVA3JJO1cOf7qCoxpTf3/Gxo8fPvbX2L//p3s2vUuy5Y9w2c+cz+zZg1n4EArP/zhu9TW+jh7tpbbb/8TTzxxPU88cYP6EiDoG/R5oR8IhNi79yLvvHOGd945TVFtCUlfU0RT/f4QbldT/7QkbT0pOelkDNCTOchAWoae1DQ9VpsWSdP+aVxtOMxx6pGNMOthB8PePUn5P9ZxnsEczvo0hef0aDRKsS6fL8Srrx7n1VePYzbruO22kcyfP57bbhuJxaLvnH8MQY+gtqaK3/3kR5w+qljptTodX1zxfabceEuzx/t3xlKyShMnN3tMZzHBl0RIktllUZ5chZZqdn1mJEMHf5bR7+/nmo9P8r57F7fcMpPKyskcOKA87N588yQ7dhRz//1Xs3z5DWRnJ7X2NQLBFeGcqxpQhH6qyYrD4cCR4mjxeHPOCDJOllBytRIIv6eyhLfffptbbrml6zsr6BWcPFnNQxvz4Wpl3bsLbA4D85eMYfK1iWI7ePKYunzwomJglCSJG269g0tBg8RV3iQ+jBhj9tx7K3nPv4S7+GizQl+WZfWFIhQK8rOf/Q9FRR/wjW/8L+PHZ/Dzn89l1ar3OXq0ilBIZtWq93n99ZM899xcpk4d1KQ9Qe+kzwl9WZY5dKiCf//7FP/5z1k++OAc9fV+db99PoAi1n1HwJKkZ0C2gfoD/+A2XRkDKEM3Kw/93EmX3ZdRPivHjUoF1D1mJ+NHTUKSIIvzjE3axfSv3s3PfrYeSRqHTjcJjUaZlmtoCPLyy0d5+eWjWK16br99FLffPopZs4aTkWFt7SsFvYDfr/oep08q0756o5FHv7uSq6Zf1+yxYbcbf1EhALLFhiZnbJf3b5I3GZ0s8ZGlGllSUg2enjGB0zMmYKmuY+qRi/zXp7/AIH0y779/jnXr9lBT4yUUknnxxf387W8HefDBq/nKV6YzapSw8Au6j/PeWIaodGPb907TqBwyd8YC481jh/HVr36VPXv2YDQau6SPgt5BQ0OA5577kJ//vJCk74TQR3TEkFAKn/v5RGxJTS30UZdLgBNuNwATp0wnLWPAJfdjtM9GkdmJTxPm/FU5/O25rzHOeZKbfSMZbxiAXtKqx1osVlat+j3r16/mpZd+B8A77/yLffsKeeSR/8ftty9gzZo8Nm36hL/97RPCYZl9+y4ye/ZGHnroGp5++iahOfoAfULoV1S4eeut0/z736d4663TXLxY3+KxlmkR3xoZlnx+KkMHJvHR9tdoOPAhQ6WI5Xx057hHDAyasIa0uLUhig1uvOlZ6FMHEKguo/7Yx9z2zC8ZOXIcP/zh1zl37jW02uHodJMwGK5GlpXcz253gC1bDrNli3LDmDx5ALNn5zB79ghmzMjCYNC21gVBD8RTr4iP9IGDefSZVQwZObrFY/2F70FAyXgjT7wGSXtl/r/H+5IYErBw2FjHUWM9fo3if+pJTYLrk3im5nWG6BxMvWYIP/i/m/nr8++wZ08ArzeE3x/id7/by+9/v5c77hjFl788nRtvHKoWbREIrgSBhgYqtDHf5XRt264S5lE5ZGzajBQMIeu0mMcNI/Dvj7lw4QLDhw/vwt4KeiqhUJhNmz7h2Wff5dy5OvTDQZ+l3MusbiOPPDalxXMDx5WYpoAsczEcRqPRcNs9911Wf3RoyG1wqFZ9v9XMASsccP4Hs6RnknEwkwyDmGAcSJLGhE6n4ytfeZoJE6bw3HP/Q11dDbW11fzkJ0+Rn/8HvvjFb3DffXlMnTqIn/+8kHPn6pBlJQbrpZc+YcmSqSxbNpPUVHMbPRP0VHql0Pf5gnz0UQn//rci7g8cKGvx2KQkI+PHpzN58gCGT7PzvFYJrsrU2RiWqrjNnDnyCTdEChOF9Hp0w3I6pZ8SEqP8Nvaba5El2Gmu4epxU6j94HUIh6h8703G3r6A9eu3sWHDj/nHP/6Iz3cKn++faLUjcDhuQpLG4PXGHlb795exf38Zzz33IVarnunTs7j++myuu24I06YNFm4+vYRJM2/g4Sf+B2tScqvHef/9hrqsmXptV3crAVtYx/SGVHIbUjgbquL4+X2UXpWDHMlOdS7o5FzQyT/4GP+cMvQZZxjmyeX0u3p8DWFkWSm7/tprJxg+3MF///dVfO5zkxg6tPVrFgg6A+fp07gyHOp68Yd7OXKhgiHDhjA595rmLfRZw6j1J5F0porakZkYsjJ5+Z0dDB+YfeU6LugRyLLMG2+c5Pvff4dDhyrU7dZZMYPFtPSWx0WovIxwmZLKuyQUJgzccMtcMgZcvkvMeF8SyUE9R0+8y7mJwwialLHcIAfY6T3DTu8ZAIbqUrjKOIgJhoHccPNcrr56Os8//7+89darAJw+fYz/+Z8vc9tt83jqqZ/y/PN3sG3bMf70pwP4fCHc7gA/+9lHbNhQxEMPXcOSJbkMG+a47P4Lriy9Tug/+eR2/v3vKjyeQLP7DQYtY8akcc01A5g+fTA5OSlq0NVr7kMQMfbn6GMZRuZddyOud7YDII+ZiKTtvH+WsT47B0yK0P/QUoXz01PRJDmxl9dQ9co6hu5/nyGfuouvfvkp7rhjIb/4xTMcPLiHUOgkVVUnWbPmRUym0RQWlrJ37wXOnq1T23a7A7z99mnefvs0AHq9hmuuGch11w0hN3cQU6YMZNiwZJEerodxz+JHmDr7zjb/X4KnTxI8rBTtCadloh3RsuW/K9EiMUKbzrCdF/BsfJXiaydyevoEKkcMVo8xDBmAYcgA6oCUu72YL+ip26PHuSdIqBJOn3by7LPv8eyz73HdddncddcY7rprDMOHO7rlmgR9n5qTJ3EOVjJUSWGZt/O3UXz0OBqNgxXf+wnOGg0XSn1cPO+nssJPTXUQb0MYWIrtY7BH6tL9sqCI79+ZJiya/YRgMMw//nGEn//8Iz7+OLHmzbipqbhvqCVIGD1aJhsGt9AKBA7EUiKfDAVJzxzEbZ9Z1Gn9HBwyM/DdkwQ3/J3zE3MoWbqY0wYffmJxh2eDNZwN1vCa+xA6NAzXpzLpm19iyn8t4LXf/Joje3cBcMstdwKg02mYN28c1103kC1bjrF9+ymCwTD19X5++cud/PrXu7jzzlF8/vOTufXWEej1wqOgN9DrhP5HH5Xi8SQOriFDkpg0KZMZMwYzefLAZgdfWJZ5v6FYXR+vj/nI+d9/R13WTplJZ2IL6xgWsHDa4MGrCbN3ALDg1oRjjK4zJO39NWmYuGHZYmZ4P88Hr21D5/Ixddr1aDUarr5a6e+2ba9w9Gg9Hs9Ajh2rxen0qu0EAmF27TrPrl2xOgEpKSauuWYgU6Yown/ixEyGD09GqxVR9d3FpBk3tOvlq+HVv8dWrr2p21/YpLsWYvE2MHH7Lq56cyf1qUmcmTqWM1PHUT4qli1IshjxjgTDyBCZiySkOgnP4TD+4+A/Dh9+VMKHH5bw9NP/ZtKkTG67bSQ33zyMmTOzMZl63S1J0EMp+fggtSOUGBFddZhzZz+F1fpfSJKJtWtangUG8B0A+2eV5W2HD/HXrx9hzpwcbr45k4MHX+EnP/khJpOogdKXqKry8Ne/HmT9+j2cOVObsG/YsGQ+//nJlEyo5HWPkqhgrCEDg6bl+5V/z051uViGRQ9/GYOhc+M8pGEj0R3cy9D9xxm67Pt86pbZVF07lbMjMjgt1VMV9qjHBglzIlDJiUAlOEBaMY9pgQWEz1XgmjSYo/4yhuhSsGgM7N79Bm+8sZopU27D75/G4cNBgkGZcFjmn/88zj//eZz0dAv33juee+8dz7Rpg4Wm6MH0yqdqcrKRiRMzyM0dxIwZg0lNbbvQw9FAOeUhxZw/SJtEmk4JMAnXVOP78F0AZJMZzYSrO72/uR4HFVofbm3zFeh8dgsVdgsVwBHqIRl4+FZCwGMVm0nVWkjRWEjVWvnQXUh5wwlCNXUMH53FtYOnkmScQHm5nsOHKykrcye0XVPj5a23TvPWW6fVbWazjjFj0pgwIYNx49IZPz6dcePSyc5OEj/WHkLo4nl8b0dmmYwmNDNv7OYegWQ0Id2/BPm2MuR3Xse65yMmbt/FxO278CRbKZ2YQ8lVIykZP5yQPfablJNkzDMlzJF36LBHJnAGAmfh+JlyDv25nJ8+9yEmo46ZM7O46aZhTJ8+mClTBpKcLMSUoG1CoTDHj1ezb99F9u27yP79F9lXEiL5GeURV3dCg1bbskumTi9htWux2jXYcWE6e4iy2muQkjUYJ4BTG1bd0GQ5hU2bnuT++2eybNmd5OSkXKnLFHQy4bDMe++dZePG/bzyylH8/sRn9NChydx77zhuvXUEtWEvf6z6EFCy31xrGt5yux43/r2K0JetNhZ+6/ukdYLLThMmTIbX/w6hEAQDBAteJ7ngdSZpNFwzbASBqydTOmUspYOSOa/3UxeOGQZloFYfgpxU8t37ISIdMrV2nCll6G6fRlHpUXzn3yXo8ZCZeht+/0T8fsU9uLLSw7p1e1i3bg/p6RZuuy2H228fxac+NVwUAu1h9Dqh/8QT1zFhQk6HrZuvuw+py5MMyg+utroKzat/h2Ak2DH3WiRd5/u4O8IGFtVm45PCuDRBnNoAddoAdZKfer8LtxTAYzVBM8GKIWQqQm4qQm4IVCDNmsSAWUpGID+wHwjVFxOucWG9UcNkyY41nAouC1Vn/Fw85sZ1IUC4DojU+mpoCKq+/vEYDFqGD3eQk+NgxIgUcnKUz4gRKQwZkiQCf68g7r+8AGHlPyx83S3oTT0n84GUMQBpwWLk2+cj7/kA+aP/YKmqYPQHHzP6g48JSxJVwwdybkIOZ0cPoXZUFrIpZsnSWCSM48EYV+A37JUJnguyt/QMuz46Q/DvELoII9NTmT4tiylTBjJhQgbjx2cIF4p+TigU5sQJRdTv3at8Dhwoa+LOab4udr8KRGoBhcNOBgw2MyQnnfRMPemZejIGGLDateozRfY2IH/v53y4R+borVORjBIpN2qpLggCIEla/P7BvPDCOV54YR2ZmUby8kZz003DuPHGoSIGpZfw/PM7+cc/SrlwoWnyjvHj01mwYDwzZmSp42Jz/T58sjIGxuozcWib3ofOnTzGhTOnuDoYjCVRmDC5a0Q+yr2YL32d8Fv/guLjSBEtQzhM6NRJNKdOMuRlGAJIjhT8E8ZTPnkcF4ZlcjHFSLU2SJjEYlvlIReMyiRtVMzzQA6HCZTXoCktRlchE65MQq4eQKhSS6hCEf1/+ctB/vKXg0gSTJyYwQ03DOX664dw7bXZDByYWJxOcGXpdUI/OzupwyL/qL+MQ35F1NokIxMMAwiFgvz+21/jvsoyDICs0aC5+bYu6LGChIRJ1mIKackIxU/fKS45gQof9eeOUHuxmPoGJ/UOK64MB/VpybhTk/BbWxY3WpsZrc2MH1A8Ct3KZzJYAAsSyKDzacClIVAdpqE8RKgWwrUQdkU+9SFOlFVx7GQVNDP5kJlpJSvLHvkkRT7K+uDBdjIzrZjNIhj4cvHv243//bcBZZZJe0vXjcvLQbLZkW6ei/yp26D4GOGij+CTfWg8bjJOXSDj1AVygbBGonrIAMqvGk351WMoz0rD08hFR2OSMIwGQ6MwhFpvNa9frObVox8Teh+ClZAUNDEyNY1JQwcydnQ6w4c7GD7cwdChScJntI8RDIYpLq5h/35F0CvW+rKElMktYRvjByJBiscKcLt3YrZIfPHrv0bbShyWZDIjDxvJqA8/5uitUwGY8GAKd946iX/962M++OAUoVBMuJSX+1SRA8ozasqUmLvkNdcMFC+nPZDNmw9RWRm7X1item64YQh33TWmySzNHu85NcDVgJabzSMT9ldevMDrf9vIe69vQ6vR8MywYUTnxjUzunY2Vho5Fu3IsciBAJw6Rvjwx3DiMJRdRIoT8bKzBv0HH5D1wQdkRbaFjAZcE8dRNT6HymGDqMi0U23VEW4ksSSNBsPANAwD02iOcC0EK2VCVRBywqmaCk7sreCFt/YQqgGHxsiUSYOYMmUwkycPYPz4DIYPd4jCXFeIDgv9kpISNm7cSHa2Em1ut9uZP39+l513ufjkIC/W7VbXZ5iGoNNo2frbXzHjYimGaLadKTMxpDQ/iK8Eer2RlJzJpORMRg4F4ewp5MOfIB8vgpLTBAw63KlJuFOScKcl4U5VXgDiP2FdKyJHgqApDKYwUgZYxrb+shT2yBHxj/q3weXmWL2bI86LyOch/DaEG0D2QNgNshdsVgMZGRYyM61kZFjIyLDGrVtJSTGRkmLG4TDhcJiw2w1X3Pe8J4/hsNtN/fq1sfXb7kFv6dnWEEmSIPqwmf8AFB8lvH83HPsEyVmDJiyTfuYi6WcuMuFVxU2uIclK5dABnBs6gPKhA3ENG0goo6kLhMYkYRgODI/f6uMU5ykOlRKqhtCHEH4NwrUSdoxkmmxkJycz1OFgeHoqQwclM3CgjcGD7aSnW/p9ms/uuhe3hizLnD/v4vDhSj75pIJDh8o5dKiSo0cr8fmad3mMJy3NzLBhDkaNSmHcuHQcZ/7Db8a6cWFECoZwHXoPWQ4wZeYdrYr8KNLVU0l/+W8kXayibmAaJ4OVpI43svzqPEKhEC+99Hfy89/D7U5Hqx2KJMUMHCUldZSU1LFtW6xY0tChyYwdm8bYsWmMGZMe+dt3A3y78h7bmeNXp5MYPz6Dm28exq23DsdgaDo2zgZq2FgX87e/3jwcm9ZIKBTk8J5dfLD9Vfa++zbhsDJOp2g1aMoVw2I4ezi6YSObtNkVSHo9jJmIdsxEQJmZ4mwx4ZPHkM+cRLpQgtTgSThH6/PjKDqAo+gA0V6GJYn6DAfOQenUjsjGOXQQtQNTcaZYCbZgSNEkgyFZghYv1c/H9afZV3ua8H4Ivwe4JZJ1JgbYbGSnOsi0GshOtTF17HCuGjmIJKtw/+ksJFmW5bYPUygpKeHBBx/klVdewW5XijutXbuW5ORkFi9e3OnnxVNaWsrzzz/P9dfPJzk5o13nhOUw62o/oMhXAkC6xsoDtqm88deN+Ddt5CaDklc5aDKjW/5DNFZ7u9q90sg+L5w+TvjUCeSzp5BKziB5GxKPkaDBbsWTYqfBYcOTbKMhOfI3I5U6mxmPzUQg2QatvRBcTj/DMrIXwp6I+I/7G/aA3KC8DIS9yl/ZC1JAwqY3YDcYSTaZSLGYSU2y8IcX5nVJH3vCGM6afgvGJEeT/bIs4/rx/yq581EeEtqvLkfS9E4rtSzLUFmOfOwg8pFP4GxxkwdNPD6zkdpB6dQMSqNsYBo1g9KoH5ROIDMFLuNlMOyWCdcpL6uyW8IY0mGRDdg0RpL1JlKMZjIsVjLtdgYm2xiclsSANBvJyUbsdiN2u+GSZwo0mp5lsbrccRwdw4899hhZWVltHh+PLMtUVzdw8mQNxcU1nDxZTXGxM/K3htpaX7vaSUkxMXy4g1GjUhk7No3x49ObxHK8/ePH+fPnbwAgeOQ0p55Zj1an44n//RnJ7TDoyHVO5B8t5/AtuRTePxeAMYdKufdYAOvIcViyR6DLzOK93e/y8isvcehQGVrtCLTaHAyGYYTD7RsvSUlGhg5NYsiQZIYOTWbIEGU5K8tORoaVzExrt6dM7ugY7sp7bGfeh0Ohadx008RW44CO+cv5P+d71MvKDFJ22MrQokqOFO3i0O5CXLU1CccPNFv4stmELqAcL3/p62jHdE5dnstFlmWocyKXnkEuPYd8/ixSRTlUV8Zcflo7XwKPw059ugNXhgNXukNdrs9IwePoXIOU7JORG2TwhtEGZPQhMKEhw2Zn/IgRpNutDHLYSLdZ8da6cFispNmTSTZbseoMWHR6LDoDGknqcffhK02HhP6PfvQj7HY7y5YtU7e5XC5mzZrF7t27O/28eDoq9F1hLxtrd7Lfr2Sg0aHhVmc6//n1rxhz9BC5euXmKQMs/jLaiS0XvehpqALqXDHy+RLkC6VI5ReQGt10mj1XAp/VgsdhpSHyMtBgNVNvM+O2WwikJCNnpOG1GPGa9Pi7wS9fDsu886nHGTy481+8esIYHnz1dRhT05sUv3L/8bc0/GMToLjsSI+vQJPRd8qQq+P29HHk0yeg5AxUlCEFg62eF9RpqU93UJ+erD5YKtNSqc1Iw5duR7a2XQipw30NyMoLaeQFFb+ELqBFF9JgkHWY0GPW6tWHiUWrx2owYNUbsBmNJJmM2I0mHlk0rdP7djlc7jhuSej7/SGqqxuorPRw8WI9paUuSkvr1L/nz7s4f96Fy9W2y00USYq6CyYxYoRDFfUpKa1bwetPHGLDhxs4dJsS/V3+wjZqX/+QvLsXMPvO9lt+wy/8ksDJw+SveQyfTQkuN7gbMNe5MboaMNV7MHsD2DBglLV4a2qpvHCBceOmkTloMuXVBkrOhTlxuIbTxZVI0qVZKO12gyr6o7OkKSkmkpOVWdHkZKM6QxrdlpRk6LTECh0VSV15j70SWkKWZSpqK3nFuZ/d5ipCEfeXDI0NU34h/9705ybn2JId3DH7dqbs341cfhGA0MRr0C/+Srv61J3I4TDU1ULlReSyC8hV5cg11VBbg1TrhPo6pHbIxKBOiyfFjscR+aTYIn/teJLt1Kck0ZBsQ77SmsIX4tiD37my39nD6JDrTkFBAY8//njCtuhbdWFhITNnNp+a8lLP6yhhOUxpsJZd3rO83XCCBjkamCIj/2UHe19/mzsNepL0MQtJ+M570fcikQ8RV4mMAUogTm5su+xtgIvnkSsuIleWIVeWI1VXQU0lkkcJqZdkMNV7MNV7oKSihW+IEdZI+GwWvDYzXrsFn82Cz2rGbzHit5hosJjwmo34LCbCDjsBmwW/UY/fqCd8iQ8aSSPx4o4iVjx48yWd3xo9YQzXfufraCsrQaMBgwFJbwBZRo5UzJWRkO99AG0fEvnQaNxOV/xW5XBYEf8XzilWprJSqKqEmio0EauYLhjCcbEKx8WqZtsNGA14HDY8DuXFtdaRgtORhtuRRIPDis9hIWQ3IJvb/4CR9BJaPZDwrhkiRIgGAjTQQNuv1fCg95oelTK0s8bxt7+9g/PnoaqqgaoqT7ut8c0hSZCSYmbQIBtDhyYzfHgyo0alMny4A6OxY/92gTonO//yE458QQkklIIh6t8/wNirruGWufd0rF///SX0u99n4t4zFN2kRI77rWYlXqqVn+ZZABSxxwzlzxCvFm2DGxpChBtkgl6JkF9H0K8j5Ncj+yVkP81+/D4/JQE/JdU1yGUgh4AgyEEgBHKg6TYAo1GLxaLHatVjtRqaXbZY9FgsBkwmLQaDDpNJi9Gow2RSPkajls98ZjwdoSvvsZ15H/7ww3/jdNZRW1tFTU0VNW4nlTbwDHVgnjkBbVxc3CBtEp+1TuL05JAq9I0mM1fNuI5rZ97AiMpyfNu2KLPvQDgtA+3Cz7e7L92JpNGAIwUcKUijmv5fy6EQuGrBWY3srEZ21UK9S3le1bvAXY/kqUfrrsdeUUtShbPF75KBoFGP127Ba7fQYLXitKdSY0/DZU+mwW7FbzMTsBoJWXRg1iBZFBfOS8ao5f0Tx7lhVPfUoekJtPsu6nK5cLlczU7X2u12jhw50uyP7FLPa4lXX/4lXtlPQCMR1Ep4zTo8NjOeJDPOASkEzYnWPYPHy5Rfb2HM4dNo4zJ/hHQ6pM9+Dv2Mm9r93T0dyWSG4SORhjd1lJO9DVBbg+ysVn6wtU7kWifU1UBdLZK7HhrcSIHEKTxNWMZc58Zc527SZmvIQMigw2824beY8FlNBEwGAiZj5K+BYORvdJvfaMBvMuE3meCa8GX8SzRPTxnDKuEweL3IXm/i5k/fi37y9I631wuRNBrIHIiUORDirlmWZXC7oKocuaIcuaoCuVYZq2FnNXKdE523AQnQ+/wkl1WTXFbd6neFtBp8VrP64lpvS8JlS8Ztt9Ngs+G1WfCbjQTMBkJmPWGzjrBZC2YNaC/tQbP21fd48t5bLunczqYzx3Hh8XNU1mpBAuygs6Msx/8zSbE/Op2ExQwWY4gkq0ySDRx2SLZJJNtAo6lHluuB8+j0BjxyFodOyciyjAyUl5fi9XoJh8MEAn6CAT/+gJ9g0E+Dux5fbQ1h2Ys5K4Pj999IWK882kZ6LQyYeQt5d93bLt/8eCSjCemG2VyNTLjByVltPb5wAJ9WbtFXuSVCJgMhkwHiwlC0kU9XIAdl5GAIgiH8QS++EFQHATnyUhBGeUkIK8tyGPAA9ZHlUGz77bePbvcLV1feYydMmNCp9+G3Lu6i1qJBHmFHvj4HOTMFDRDvgCKFwky+6Oe60no08nmG+f188fqbGJg1lBSjkdDxwwTX/wJfOPa8CqdnovniMjQ9PLaqvUhaLThSwZFKW3dBORwGnxe8DdDgQW5wQ0MDNLiRG5RtOm8DVm8D1oAf/H6yy2sVo2PAjxTwQ8CvZCwKBAgHQtRjw6W14TIl47IkU2+x4zHbaLBY8VrMBCxGgkY9IaOOsEmHZASNCSQjSCbls/Hkm9zwbSH026S0tLTFfUlJSdTW1ja771LPa4m9N43BaWn79iiFwoz64ABT/v4Oljp3go9vYOQ4tPP+C03mAMLNpZfpi5gMYBoAA5QsP42fySp+P3jqwe1GdrmQ3cobO+568EZ+wL7YXzmyLPl8SAG/2qYE6PxBdP56LLVN05e1RWjlNTD30i61JXrKGA5nDUUy25W0rsGg4h8ZDCLr9XDjbPQ3zu5Qe30RSZLAlgS2JKRho5o9Rg4FwVWnWJfcrsjfesL1dQSdNYTrXRjDocj49KLx+zB4PJjr3G0+sBK+h+hLq5GAyYjPbMRrttBgtNJgMuM3mPAbjfiNRoJGAwGDQX3w1Iwvb7P9K0VnjuOUL0tIlo6//ATRUg20/koG0KivqRqUHGLtJ7lBZqY/E+O993fovMZokMhtSCE3TqUHCeOTwng1IRrCfhoaavEGPPiCXvwhPwE5SEAKE9BKBPRaAgYdAaMev9lAMM7g1FVIOgmpkyaSXtj0Po9+vn2zq115j+30+/DNUwi1oCU0gSAjPzrIVa9/RHJZNfERcTkAH++l8RyWLEmEp16P9u570Zj7hsjvKJJGA2aL8klJ69B9tjk04TCOYABHwA/BEISCas0AQkHkyLOTYBBCPsL+AL7qEF5vSJEr3jAeD2Td27dmxztKp80pu1yuK3pec5idLjJPlDLg+FmG7zqCye0FjYaAXk/IbME9ZhKuidfgTx+gPL3LKjvtu/scOjOkmCEls/3nyDJSwI8mGEAKBtEE/EjBIFIgENkW+RuI7I9uCwSQQkGkUCjyN8jFyvY4RnQuV2oM77v6WpJbc8u52HrVTkEjdCZINkE7g/SRw8qY9PsiHz8avxeNX7Ewyb4GpFAIvUTcOA3iriwDvx/J7UdbV0dSsBpHOIQUDqMJh5Fk5a/JYESn0SCFQhQ/OqJrr70T6cx7cbcSlsmoDjOsysKp8JW6x+vRk4yeRjn0QygFTyITolIwiORrgEADBHzI4QBhOYQcDhEmpCwTJiyFCUsQlmRCWomQRllWtikulbJGIqzVENZokHUaZJ0WWaMhpNMo27VawjotYa2WkF7Zpx4f+YS1kuJC2ApF5z4BOseNsivvsZczfnVeH47SSlLPlZF1sJjBh0+j97UvnsSfnIJr7CTqJk4hkJIOtW7lI+g6JD3o9IpOaQM9cKquYy+BfY12C32breU31Lq6uk4/ryWGnKhisE7CIGkxanRYJD3Jkp5Ug5XMlMEMuHkW6YsGKG+Wgl5LV0TJ95Qx/Pm5t5Kalt7h8wS9j1t60H2oM8dx+iensRIAJIgL1JNAMaJI4HCkoJEkkECSJbwNDTREsy7JkYOQkaJ2P1lGArQ6HQ6HQ9kvKXFFdbVOAoEAEhIajYRGo1X/avV6jHY7DkcaQ7JzmJSURcoIkZpPlmUIh5BDYeSQ8jKRuBxSCisFg4RDIYKy8tcf8FPnqiPg9xMI+Jky+/p2f2dX3mM7+z582zEnjrCEPQiWoIwkWZBMI2D6SJghKbOKkU9sWaOMSUmD1mImeeIkjOntNDAIuo3+rgfbLfSTkxVLRXNvzS6XSw2I6azzWuLnS7/Z4bRureH3+/nDH/7AQw89hMHQ+dk7upveen1dIfR7yhieNmWCGMMdpLdeY09K69aZ43jdsmc6dQxD7/0/bi+99fo6Moa78h7b2ffhpV/+mhjDHaS3Xl9Pug93B+2+ervdjt1ub/HNuaUgmEs970rh9/v57W9/i9/f/rRvvYm+fn0dQYzh3kt/uMauRozj7qWvXx907T22p49f6Pv/x339+voqHXrNycvLo6SkJGFbdL21H9mlnicQdDZiDAv6M2IcC7qarrzHivErEHScDgXjLl68mMceeyyhWMXWrVt56qmn1HWXy8Xy5ctZtmwZ48aNa/d5bRGIpH2sqGg793tHaGhowG63c/HiRczmvleOvLden0ajISMjo9OnB8UY7p301mvsqnF8qVzuOO6qMQy99/+4vfTW6+voGO7Ke2xPvg9D7/0/bi+99fp62n34StOhyrgAR44c4c0332TChAlquqv40tPREtWrVq1KeMNu67y22Lt3L5s2bepIVwW9nMcff7zTfShBjGHBlaWrxvGlcjnjWIzh/klHx3BX3mPFfVhwKfS0+/CVpMNCv7uor6/n+PHjpKSkoI+rbCvou/S1N3AxhvsnfWkcizHcPxFjWNDb6UtjuKP0GqEvEAgEAoFAIBAI2k//zjkkEAgEAoFAIBD0UYTQFwgEAoFAIBAI+iBC6AsEAoFAIBAIBH0QIfQFAoFAIBAIBII+iBD6AoFAIBAIBAJBH0QIfYFAIBAIBAKBoA/Socq4fYmSkhI2btxIdnY2AHa7nfnz53dzrzqXBx54gIceekgtSLJ161agY8VFBD2bvj6OxRju+4gxLOjtiDEs6Mn0yzz60ap8r7zyCna7HYC1a9eSnJzcpwbutGnTEtbnzZvH008/3U29EXQ2/WEcizHctxFjWNDbEWNY0NPpl0L/Rz/6EXa7nWXLlqnbXC4Xs2bNYvfu3d3Ys87lRz/6EePHjwdgxowZqrVB0DfoD+NYjOG+jRjDgt6OGMOCnk6/9NEvKChoMlCjb+KFhYXd0aUuITs7m/nz5zN//nzxw+yD9IdxLMZw30aMYUFvR4xhQU+n3wl9l8uFy+UiKyuryT673c6RI0e6oVddh8vlorCwsM9dV3+nP41jMYb7JmIMC3o7YgwLegP9TuiXlpa2uC8pKYna2tor2JuupbCwkMLCQiZMmADAV77yFfEj7SP0l3EsxnDfRYxhQW9HjGFBb6DfCf22cLlc3d2FTuOpp54iLy8Pu93OuHHjmD9/PsuXL+/ubgmuAH1lHIsx3H8RY1jQ2xFjWNAT6HdC32aztbivrq7uCvak62nsSzdu3DhKS0v7jN9gf6a/jGMxhvsuYgyLMdzbEWNYjOHeQL8T+snJyUDzb9oul0sNountrF27tsnUWvTaW5tuFPQO+sM4FmO4byPGsBjDvR0xhsUY7g30O6Fvt9ux2+0tvm1HC0L0dl588UUOHTqUsC3qL9hc4JCgd9EfxrEYw30bMYbFGO7tiDEsxnBvoN8JfYC8vDxKSkoStkXX+8IPE+Dxxx9vUplv586d2O32PnON/Z2+Po7FGO77iDEs6O2IMSzo6fRLob948WJ27NiRsG3r1q089dRT3dSjzmfcuHEUFBSo6y6Xi40bN4pqdn2Ivj6OxRju+4gxLOjtiDEs6On0y8q4AEeOHOHNN99kwoQJqp9ZXylXHSWaEgsUX7r58+eLN/A+Rl8fx2IM933EGBb0dsQYFvRk+q3QFwgEAoFAIBAI+jL90nVHIBAIBAKBQCDo6wihLxAIBAKBQCAQ9EGE0BcIBAKBQCAQCPogQugLBAKBQCAQCAR9ECH0BQKBQCAQCASCPogQ+gKBQCAQCAQCQR9ECH2BQCAQCAQCgaAPIoS+QCAQCAQCgUDQBxFCXyAQCAQCgUAg6IMIoS8QCAQCgUAgEPRBhNAXCAQCgUAgEAj6IELoCwQCgUAgEAgEfRAh9AUCgUAgEAgEgj7I/wfEhwZRpcLDSgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x230 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "f = plot_exact_density_and_approximate_density_multi(list(range(4)), [mlmc_net_1, mc_net_high, mc_net_low], [\"ML-NLE (300)\", \"NLE (high)\", \"NLE (low)\"], t_x_grid, t_theta, exact_densities, network_type_list = [\"nsf\", \"nsf\", \"nsf\"],\n",
    "                                               xlim = (-2, 9), add_legend=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 422,
   "metadata": {},
   "outputs": [],
   "source": [
    "f.savefig(os.path.join(figure_dir, 'gnk_4_density_mc.pdf'), bbox_inches = 'tight', dpi = 300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 416,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_exact_density_and_approximate_density_multi_mlmc(index_list: list, network_list: list[nn.Module], network_name: list[str], x_grid: Tensor, theta: Tensor, exact_density: Tensor,\n",
    "                                               network_type_list: list[str], xlim = (-20, 20), add_legend = False): \n",
    "    \n",
    "    colors = [\"#850D0C\", \"#850D0C\", \"#850D0C\"]\n",
    "    fig, ax = plt.subplots(1, 4, figsize = (8, 2.3))\n",
    "    ax = ax.flatten()\n",
    "    line_styles = [\"solid\", \"dashed\", \"dotted\"]\n",
    "\n",
    "    shift = 30\n",
    "\n",
    "    for index in index_list:\n",
    "        ax[index].plot(x_grid, exact_density[index + shift], color = \"black\", ls = \"dashed\", label = \"(Almost) exact\")\n",
    "        for i in range(len(network_list)):\n",
    "            approximated_density = obtain_density_over_grid(network_list[i], x_grid, theta[index + shift], network_type = network_type_list[i])\n",
    "            ax[index].plot(x_grid, approximated_density, label = network_name[i], color = colors[i],linestyle =  line_styles[i])\n",
    "            # ax[index].fill_between(x_grid, approximated_density, alpha = 0.25, color = colors[i])\n",
    "\n",
    "\n",
    "    \n",
    "\n",
    "    # ax.hist(x_low[index], bins = 100, density = True, alpha = 0.25, color = \"black\", label = \"Low fidelity data\")\n",
    "    # ax.hist(x_high[index], bins = 100, density = True, alpha = 0.25, color = \"red\", label = \"High fidelity data\")\n",
    "    # ax.legend(prop = {\"size\": 8}, fancybox = False, frameon = False)\n",
    "\n",
    "        if index == 3:\n",
    "            ax[index].legend(fontsize = 10, frameon = False, loc='upper right', bbox_to_anchor=(1.5, 1.2))\n",
    "\n",
    "        ax[index].set_xlim(xlim[0], xlim[1])\n",
    "\n",
    "        # if index ==  0 or index == 4:\n",
    "       \n",
    "        #     ax[index].set_ylabel(\"Density\", fontsize = 17)\n",
    "\n",
    "\n",
    "        ax[index].set_xlabel(r\"$x$\", fontsize = 17)\n",
    "\n",
    "        # if index > 3:\n",
    "        #     ax[index].set_xlabel(r\"$x$\", fontsize = 17)\n",
    "        #     ax[index].tick_params(axis='y', labelsize=13)\n",
    "        #     ax[index].tick_params(axis='x', labelsize=13)\n",
    "        ax[index].spines['top'].set_visible(False)\n",
    "        ax[index].spines['right'].set_visible(False)\n",
    "    fig.tight_layout()\n",
    "\n",
    "    return fig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 417,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x230 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "f = plot_exact_density_and_approximate_density_multi_mlmc(list(range(4)), [mlmc_net_1, mlmc_net_2, mlmc_net_3], [\"ML-NLE (300)\", \"ML-NLE (100)\", \"ML-NLE (50)\"], t_x_grid, t_theta, exact_densities, network_type_list = [\"nsf\", \"nsf\", \"nsf\"],\n",
    "                                               xlim =  (-2, 9), add_legend=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 411,
   "metadata": {},
   "outputs": [],
   "source": [
    "f.savefig(os.path.join(figure_dir, 'gnk_4_density_mlmc.pdf'), bbox_inches = 'tight', dpi = 300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 312,
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 1; m = 1000\n",
    "theta_star = theta[9]\n",
    "\n",
    "simulator = gnk(very_low = False)\n",
    "noise = simulator.noise_generator(n = n, m = m) \n",
    "\n",
    "x_low = simulator.low_simulator(theta = theta_star, noise = noise)\n",
    "x_high = simulator.high_simulator(theta = theta_star, noise = noise)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 423,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x38a5caf40>"
      ]
     },
     "execution_count": 423,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 1, figsize = (3., 3))\n",
    "colors = [\"#850D0C\", \"#0C0C85\", \"#25A986\"]\n",
    "ax.plot(x_grid, exact_densities[9], color = \"black\", ls = \"dashed\", label = \"(Almost) exact\")\n",
    "ax.hist(x_high[0], bins = 100, density = True, alpha = 0.4, color = \"#0C0C85\", label = \"High fidelity\")\n",
    "ax.hist(x_low[0], bins = 100, density = True, alpha = 0.4, color = \"#25A986\", label = \"Low fidelity\")\n",
    "ax.spines['top'].set_visible(False)\n",
    "ax.spines['right'].set_visible(False)\n",
    "ax.set_xlim(-10, 30)\n",
    "ax.set_xlabel(r\"$x$\", fontsize = 17)\n",
    "ax.legend(frameon = False, fontsize = 12, loc='upper right', bbox_to_anchor=(1.1, 1.0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 424,
   "metadata": {},
   "outputs": [],
   "source": [
    "fig.savefig(figure_dir + '/gnk_density_low_high_fidelity.pdf', bbox_inches = 'tight', dpi = 300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "sbi_env",
   "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.9.21"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
