{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2024-10-09 15:27:23.610611: I tensorflow/core/platform/cpu_feature_guard.cc:193] This TensorFlow binary is optimized with oneAPI Deep Neural Network Library (oneDNN) to use the following CPU instructions in performance-critical operations:  AVX2 AVX512F AVX512_VNNI FMA\n",
      "To enable them in other operations, rebuild TensorFlow with the appropriate compiler flags.\n",
      "2024-10-09 15:27:23.921590: I tensorflow/core/util/port.cc:104] oneDNN custom operations are on. You may see slightly different numerical results due to floating-point round-off errors from different computation orders. To turn them off, set the environment variable `TF_ENABLE_ONEDNN_OPTS=0`.\n",
      "2024-10-09 15:27:23.961912: W tensorflow/compiler/xla/stream_executor/platform/default/dso_loader.cc:64] Could not load dynamic library 'libcudart.so.11.0'; dlerror: libcudart.so.11.0: cannot open shared object file: No such file or directory\n",
      "2024-10-09 15:27:23.961934: I tensorflow/compiler/xla/stream_executor/cuda/cudart_stub.cc:29] Ignore above cudart dlerror if you do not have a GPU set up on your machine.\n",
      "2024-10-09 15:27:24.954816: W tensorflow/compiler/xla/stream_executor/platform/default/dso_loader.cc:64] Could not load dynamic library 'libnvinfer.so.7'; dlerror: libnvinfer.so.7: cannot open shared object file: No such file or directory\n",
      "2024-10-09 15:27:24.954983: W tensorflow/compiler/xla/stream_executor/platform/default/dso_loader.cc:64] Could not load dynamic library 'libnvinfer_plugin.so.7'; dlerror: libnvinfer_plugin.so.7: cannot open shared object file: No such file or directory\n",
      "2024-10-09 15:27:24.954996: W tensorflow/compiler/tf2tensorrt/utils/py_utils.cc:38] TF-TRT Warning: Cannot dlopen some TensorRT libraries. If you would like to use Nvidia GPU with TensorRT, please make sure the missing libraries mentioned above are installed properly.\n"
     ]
    }
   ],
   "source": [
    "import torch_geometric.transforms as T\n",
    "import os.path as osp\n",
    "from sklearn.manifold import TSNE\n",
    "import torch\n",
    "import umap\n",
    "\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "from embedding_functions import *\n",
    "from experiment_setup import *\n",
    "from functions_for_bootstrap import *\n",
    "import numba as nb\n",
    "from scipy.stats import wasserstein_distance\n",
    "from tqdm import tqdm\n",
    "import random\n",
    "from scipy.integrate import simps\n",
    "from matplotlib import cm\n",
    "from matplotlib.patches import Ellipse\n",
    "import seaborn as sns\n",
    "from scipy.spatial.distance import cdist\n",
    "from numpy.linalg import LinAlgError\n",
    "import re\n",
    "\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "from sklearn.covariance import LedoitWolf  # Import Ledoit-Wolf estimator\n",
    "from sklearn.covariance import shrunk_covariance, EmpiricalCovariance\n",
    "from matplotlib.colors import LinearSegmentedColormap\n",
    "from scipy.spatial.distance import mahalanobis\n",
    "from matplotlib.lines import Line2D\n",
    "import re"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Read in data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of time windows: 18\n",
      "Number of nodes: 242\n"
     ]
    }
   ],
   "source": [
    "window = 60 * 60\n",
    "\n",
    "day_1_start = (8 * 60 + 30) * 60\n",
    "day_1_end = (17 * 60 + 30) * 60\n",
    "day_2_start = ((24 + 8) * 60 + 30) * 60\n",
    "day_2_end = ((24 + 17) * 60 + 30) * 60\n",
    "\n",
    "T1 = int((day_1_end - day_1_start) // window)\n",
    "T2 = int((day_2_end - day_2_start) // window)\n",
    "T = T1 + T2\n",
    "\n",
    "print(f\"Number of time windows: {T}\")\n",
    "\n",
    "# %%\n",
    "fname = \"ia-primary-school-proximity-attr.edges\"\n",
    "file = open(fname)\n",
    "\n",
    "label_dict = {\n",
    "    \"1A\": 0,\n",
    "    \"1B\": 1,\n",
    "    \"2A\": 2,\n",
    "    \"2B\": 3,\n",
    "    \"3A\": 4,\n",
    "    \"3B\": 5,\n",
    "    \"4A\": 6,\n",
    "    \"4B\": 7,\n",
    "    \"5A\": 8,\n",
    "    \"5B\": 9,\n",
    "    \"Teachers\": 10,\n",
    "}\n",
    "num_classes = 10\n",
    "\n",
    "nodes = []\n",
    "node_labels = []\n",
    "edge_tuples = []\n",
    "\n",
    "for line in file:\n",
    "    node_i, node_j, time, id_i, id_j = line.strip(\"\\n\").split(\",\")\n",
    "\n",
    "    if day_1_start <= int(time) < day_1_end:\n",
    "        t = (int(time) - day_1_start) // window\n",
    "    elif day_2_start <= int(time) < day_2_end:\n",
    "        t = T1 + (int(time) - day_2_start) // window\n",
    "    else:\n",
    "        continue\n",
    "\n",
    "    if node_i not in nodes:\n",
    "        nodes.append(node_i)\n",
    "        node_labels.append(label_dict[id_i])\n",
    "\n",
    "    if node_j not in nodes:\n",
    "        nodes.append(node_j)\n",
    "        node_labels.append(label_dict[id_j])\n",
    "\n",
    "    edge_tuples.append([t, node_i, node_j])\n",
    "\n",
    "edge_tuples = np.unique(edge_tuples, axis=0)\n",
    "nodes = np.array(nodes)\n",
    "\n",
    "n = len(nodes)\n",
    "print(f\"Number of nodes: {n}\")\n",
    "\n",
    "node_dict = dict(zip(nodes[np.argsort(node_labels)], range(n)))\n",
    "node_labels = np.sort(node_labels)\n",
    "\n",
    "# %% [markdown]\n",
    "# Create a list of adjacency matrices.\n",
    "\n",
    "# %%\n",
    "As = np.zeros((T, n, n))\n",
    "\n",
    "for m in range(len(edge_tuples)):\n",
    "    t, i, j = edge_tuples[m]\n",
    "    As[int(t), node_dict[i], node_dict[j]] = 1\n",
    "    As[int(t), node_dict[j], node_dict[i]] = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Format the data to work with existing code\n",
    "labels = node_labels\n",
    "\n",
    "# just look at first (whatever is specified) timepoint\n",
    "dense_adj = As[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# just 4 classes!\n",
    "startnode = 142 \n",
    "endnode = 231\n",
    "\n",
    "dense_adj = dense_adj[startnode:endnode+1, startnode:endnode+1]\n",
    "\n",
    "dense_adj = np.matrix(dense_adj)\n",
    "\n",
    "node_labels = node_labels[startnode:endnode+1]\n",
    "labels = node_labels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "k = 3\n",
    "B = 30\n",
    "d = 2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Standardise so plots are mean 0, sd 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 30/30 [00:05<00:00,  5.19it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "B=30, d=2, k=3\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# obs_adj is the observed adjacency matrix\n",
    "# for each of the true draws from the model, create a bootstrap and perform a test with Q permutations\n",
    "random.seed(100)\n",
    "np.random.seed(100)\n",
    "\n",
    "p_vals = []\n",
    "A_boots_list = []\n",
    "\n",
    "for b in tqdm(range(B)):\n",
    "    p_val, A_boots = create_single_kNN_bootstrap(dense_adj, d=d, Q=1000, n_neighbors=k)\n",
    "    p_vals.append(p_val)\n",
    "    A_boots_list.append(A_boots)\n",
    "\n",
    "print(f\"B={B}, d={d}, k={k}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "A_list = [dense_adj] + A_boots_list\n",
    "len(A_list)\n",
    "\n",
    "yhat = UASE(A_list, d=d, sparse_matrix=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "yadf = pd.DataFrame(yhat)\n",
    "\n",
    "# rename the columns - this is called a list comprehension\n",
    "yadf.columns = [\"Dimension_{}\".format(i+1) for i in range(yadf.shape[1])] \n",
    "\n",
    "# repeats tau list the len of A_true_boots_list times\n",
    "yadf[\"tau\"] = np.tile(node_labels, B + 1)\n",
    "\n",
    "# add column for the matrix it is\n",
    "yadf[\"Matrix\"] = np.repeat(range(B+1), len(labels))\n",
    "\n",
    "# repeat range(len(node_labels)) B+1 times to give each node a unique number\n",
    "yadf['NodeNumber'] = list(range(len(node_labels)))*(B+1)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### B=20 and perplexity=30 make plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 360x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Create a figure and axis object\n",
    "fig, ax = plt.subplots(figsize=(5,5))\n",
    "\n",
    "yhat_A = UASE([dense_adj], d=d, sparse_matrix=False)\n",
    "yadf_A = pd.DataFrame(yhat_A)\n",
    "\n",
    "# rename the columns - this is called a list comprehension\n",
    "yadf_A.columns = [\"Dimension_{}\".format(i+1) for i in range(yadf_A.shape[1])] \n",
    "\n",
    "# repeats tau list the len of A_true_boots_list times\n",
    "yadf_A[\"tau\"] = np.tile(node_labels, 1)\n",
    "\n",
    "# repeat range(len(node_labels)) B+1 times to give each node a unique number\n",
    "yadf_A['NodeNumber'] = list(range(len(node_labels)))\n",
    "\n",
    "# Standardize the data in the Dimension_1 and Dimension_2 columns - so Dimension_1 and Dimension_2 have mean 0 and standard deviation 1\n",
    "scaler = StandardScaler()\n",
    "# Fit the scaler on the Dimension columns and transform them\n",
    "# Aobs_yadf[[\"Dimension_1\", \"Dimension_2\"]] = scaler.fit_transform(Aobs_yadf[[\"Dimension_1\", \"Dimension_2\"]])\n",
    "yadf_A[[\"Dimension_1\", \"Dimension_2\"]] = scaler.fit_transform(yadf_A[[\"Dimension_1\", \"Dimension_2\"]])\n",
    "\n",
    "# Plot the scatter plot\n",
    "scatter = ax.scatter(yadf_A[\"Dimension_1\"], yadf_A[\"Dimension_2\"], c=yadf_A[\"tau\"], cmap='tab10')\n",
    "# plot tau=7 in red\n",
    "ax.scatter(yadf_A[yadf_A[\"tau\"] == 7][\"Dimension_1\"], yadf_A[yadf_A[\"tau\"] == 7][\"Dimension_2\"], c='#d62728', label='tau=7')\n",
    "\n",
    "ax.set_xlabel(\"Dimension 1\")\n",
    "ax.set_ylabel(\"Dimension 2\")\n",
    "\n",
    "# Add legend for classes, mapping the integer labels back to the label_dict keys\n",
    "handles, labels_legend = scatter.legend_elements()\n",
    "label_dict_inv = {v: k for k, v in label_dict.items()}  # Inverse mapping\n",
    "mapped_labels = []\n",
    "for label in labels_legend:\n",
    "    match = re.search(r'\\d+', label)\n",
    "    if match:\n",
    "        numeric_label = int(match.group(0))\n",
    "        mapped_labels.append(label_dict_inv.get(numeric_label, \"Unknown\"))\n",
    "\n",
    "# Add the legend with the mapped labels\n",
    "fig.legend(handles, mapped_labels, title=\"Classes\", loc=\"lower right\", bbox_to_anchor=(0.96, 0.12))\n",
    "\n",
    "# Adjust layout to make room for titles and labels\n",
    "plt.tight_layout()\n",
    "\n",
    "# plt.savefig(\"figs/school_A1_embed_A_sd1mean0_4classes.png\", bbox_inches='tight', facecolor='white')\n",
    "\n",
    "# Show the combined plot\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "pick out a node and show knn of it"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Node 13.0: [-0.1590071  -0.27928045]\n",
      "Node 12.0: [-0.17861409 -0.34423443]\n",
      "Node 6.0: [-0.11871598 -0.30329837]\n"
     ]
    },
    {
     "data": {
      "image/png": "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pzuPHDmy8OjRo+dnzpyZPXfu3KCa+0lLS5MMGjQoytPTU//bb79dPnDgwMXw8HDN0KFDIzMzM2+r9Ttw4MCy5ORkRUJCgpMgCLhx44Zk+/btbvfee29xc/clCALefPNNv9WrV6f++uuvl27evCkdPXp05wULFvivWLEi9bfffruUlZUlff7556s/1Hfu3Ok0YcKEsNGjRxccO3bs/NatW5PS0tJkI0eODBeEvxsbZ86ccThx4oRq9+7dV9auXZu8fft2jyFDhoQfOnTIISEh4eqaNWuub9u2zeOjjz7yrFnT7t273QoKCiS//fbb5TVr1iTv2bPHdfr06dVddbNmzfJbuXKlz8KFCzMSExPPLVmyJG3jxo1ec+bMqXUub/369T7e3t6G/fv3X/ziiy9SzD3/I0eOKP/1r3+F33nnnWVHjhy5sHr16uu//faby8SJE4MBYMGCBdkbNmy4BgB//vnnhdTU1MSwsDCduX2NGzcu5IsvvvB+6aWXMk+dOnX+66+/vta5c2dtQ6+9VqtlL730Utbhw4cvJiQkXBGJRBg5cmT139mXX37pumLFik5Lliy5cf78+XO7du26MnTo0Orf8dSpU4NLS0vFu3btunLmzJlzq1atSgkICDDbm1AlLS1NMnXq1NDPP/88xdfX19jQdp999pnXo48+mi+VSvHPf/4zf926dV6N7Ze0Ljr/QVrc8OHDy+67776iOXPmBB49evRy3fs///xzj8LCQsmJEycudurUyQAA//3vf5MjIiJ6rF271v3555/PX7JkiW9sbGz5ypUrMwAgNjZWm5GRIX3llVeqA/GDDz7w9vf3127evPlG1W1ffPFFWnBwsMvatWvdX3/99ZxbfQ5PPfVUYVFRkXjs2LHher2eGY1GNmjQoOJvvvkmpbn74pzjww8/vNG/f381AEycODH3rbfeCti/f//FgQMHVgDAk08+mfvhhx9Wn7t86623/J566qmcV155pfo5bNq0KaVLly7dDx8+rKzal0wmE7Zs2ZKqUCh4XFycZs2aNSWJiYkOmZmZZ5RKJY+Li9N8/vnnxXv37nWaN29ebtW+XFxcDJs2bUqVSCSIi4vTZGZmZrzyyitBH3zwQQZjDKtWrfL56quvro0ZM6YEAKKionS5ubmZ8+fPD/zoo48yq/bTvXv38uXLl1f/bM4777zj27Vr14p169al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7NmzDhs2bHA1d78gCBg6dGj4+fPnVV999VXyiRMnzk+ePDlnypQpnXfs2FH92imVSuHTTz9NPX369PnPPvvs+qFDh5ymTp0aWHdfL7/8csCSJUvSEhMTz911110VEyZMCE5ISHD95JNPUhMTE8/Nmzcvc9GiRQEffPCBJwAcOHBANXfu3OBZs2Zlnz179twvv/xyecKECfkAcP/995e9/fbbNwAgNTU1MTU1NXHNmjW1lrCqq3v37urRo0fnzZ8/P8BoNP/y7Ny502nChAlho0ePLjh27Nj5rVu3JqWlpclGjhwZ3tAXli+//NJ10aJFgc8//3z20aNHL/zjH/8oWLhwYb0vGVWvwfLly9MOHjx40cPDwzBhwoQwvb72alrz588PfPnllzMPHTp0oVevXmXjxo0LT01NlQLAjRs3JKNGjerSqVMn3f79+y9u3bo16fLly8pRo0Y1GBINMfc7mTp1anBpaal4165dV86cOXNu1apVKQEBAQ0u95Wbmyu+cuWK8s4776y19uDHH3/sMWfOnODp06dnnzp16tzatWuv79+/33nixInBADBkyJDy2bNnZ06fPj3k6tWrsszMTMnkyZNDp0yZkjN69OgSAPjPf/7j9+abbwZMnjw55/jx4+d37tx5tWfPnmbX4LTU22+/7b1mzRqfhQsXph8+fPhCr169ypctW+Zn6WvV0O/u+vXr0n/+85/hvXr1Kj948OCFpUuXpr344ouBTewWTb3eTb1H6vrhhx+Spk6detPPz0+XmpqaeOzYsYtV9911113leXl50pMnTyoserHqoIm6O6Cagej33rvJANCWQbh69Wr3WbNmBb///vupzz77bPW6bSEhIbqjR49eaOyxMpms3ppiI0eODP31119dNRqNqFevXuW//PLLVUvqiI6O1j7xxBO5CxYsCBg/fnxx3XUAf/zxR6fTp087ZmZmJlaFa7du3fKOHDni+Mknn3hXrWm3ZMmSrKrHREZG6oqLizOmTJnS2Wg0plStbcg5x9KlS9OGDx9eBgCXLl2Sbdu2zePEiRPnq1Zzj4qK0l2+fFnx2Wefef/nP//Ju379ukypVBonTJhQWLVqep8+faq74qpWQQ8KCrK4S2vJkiWZXbt2jVmxYoXHjBkz8uve/9Zbb/k99dRTOVWruAPApk2bUrp06dL98OHDyv79+9frCvzoo498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",
      "text/plain": [
       "<Figure size 396x280.8 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Create a figure and axis object\n",
    "fig, ax = plt.subplots(figsize=(5.5,3.9))\n",
    "\n",
    "Aobs_yadf = yadf[yadf[\"Matrix\"] == 0]\n",
    "# first two dimensions in an array\n",
    "Aobs_array = Aobs_yadf.iloc[:, 0:2].to_numpy()\n",
    "\n",
    "node_number = 18\n",
    "k = 3\n",
    "Aobs_yadf_node = Aobs_yadf[Aobs_yadf[\"NodeNumber\"] == node_number]\n",
    "\n",
    "# Filter data for node number and select the relevant dimensions\n",
    "data_d_dim = yadf[yadf[\"NodeNumber\"] == node_number].iloc[:, 0:d].to_numpy()\n",
    "\n",
    "# Plot the scatter plot\n",
    "scatter = ax.scatter(Aobs_yadf[\"Dimension_1\"], Aobs_yadf[\"Dimension_2\"], c=Aobs_yadf[\"tau\"], cmap='tab10')\n",
    "ax.set_xlabel(\"Dimension 1\", fontsize=14)\n",
    "ax.set_ylabel(\"Dimension 2\", fontsize=14)\n",
    "\n",
    "# no ticks\n",
    "ax.set_xticks([])\n",
    "ax.set_yticks([])\n",
    "\n",
    "# Find the k-nearest neighbors\n",
    "nbrs = NearestNeighbors(n_neighbors=k+1).fit(Aobs_array)  # +1 to include the node itself\n",
    "distances, indices = nbrs.kneighbors(data_d_dim[:, :2])\n",
    "\n",
    "# Get the k-nearest neighbors excluding the node itself\n",
    "nearest_neighbors = indices[0][1:]\n",
    "\n",
    "# Output the k-nearest neighbors\n",
    "# print(f\"{k} nearest neighbors of node {node_number}:\")\n",
    "\n",
    "for idx in nearest_neighbors:\n",
    "    point = Aobs_array[idx]\n",
    "    node = Aobs_yadf.iloc[idx][\"NodeNumber\"]\n",
    "    print(f\"Node {node}: {point}\")\n",
    "    # Plot the point with an 'x' marker\n",
    "    ax.scatter(point[0], point[1], color='red', marker='x', s=180)\n",
    "    # Annotate the point with the node number, rounded to integers\n",
    "    # ax.annotate(str(int(node)), (point[0], point[1]), textcoords=\"offset points\", xytext=(5,5), ha='center')\n",
    "\n",
    "# Create custom second legend\n",
    "legend_elements = [\n",
    "    Line2D([0], [0], color='#1f77b4',  marker='s', lw=0, label=f'Node {node_number}, member of class 4A', markerfacecolor='#1f77b4', markersize=10),  \n",
    "    Line2D([0], [0], color='#d62728', marker='x', lw=0, label=f'k={k} Nearest Neighbours (excluding self)', markersize=13, markerfacecolor='#e377c2')  \n",
    "]\n",
    "\n",
    "fig.legend(handles=legend_elements, loc='upper right', bbox_to_anchor=(1.15,0.), fontsize='x-large', ncol=1)\n",
    "\n",
    "# plot the point for node with node_number in blue\n",
    "ax.scatter(Aobs_yadf_node[\"Dimension_1\"], Aobs_yadf_node[\"Dimension_2\"], color='#1f77b4', label=f'Node {node_number}, member of class 4A', marker='s', s=100)\n",
    "\n",
    "# plot the class 4B in red\n",
    "ax.scatter(Aobs_yadf[Aobs_yadf[\"tau\"] == 7][\"Dimension_1\"], Aobs_yadf[Aobs_yadf[\"tau\"] == 7][\"Dimension_2\"], c='#d62728', label='tau=7')\n",
    "\n",
    "#invert x axis\n",
    "ax.invert_xaxis()\n",
    "\n",
    "# # get rid of box around plot\n",
    "# ax.spines['top'].set_visible(False)\n",
    "# ax.spines['right'].set_visible(False)\n",
    "\n",
    "# Adjust layout to make room for titles and labels\n",
    "plt.tight_layout()\n",
    "\n",
    "# plt.savefig(f\"figs/school_A1_embedA_viaUASE_sd1mean0_4classes_node{node_number}_knn{k}_noaxes.png\", bbox_inches='tight', facecolor='white')\n",
    "\n",
    "# Show the combined plot\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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KAKAqVOn1g0ePLj+zjvvDPjggw9yNRqN9ZVXXvE0Go2iBQsWlAHAwoULS7/44gu32267zf+ll14qqqyslDz22GO+8fHx2okTJ2oBICAgwFReXi759ddfbSIjI422trbCgQMHlL/88ovdpEmTan18fMzp6enyzMxM5axZs8oBICgoyCQSifDTTz/ZOzg4VCoUCu7k5NTusmEXFxerRqOxfP755y5hYWHG0tJSyaJFi7zlcnmbbp1du3Y5vPXWWy5Tp06t/d///me/ZcsWx5UrV7bpibqU+fPnl8ydOzfgueeeK3nooYcqPvnkE7cJEyYEv/baawWRkZGGgoIC6Y4dO9QRERGGu+++u/rFF1908/T0NCcmJupsbW2F1atXO4rFYkRGRhoAYNCgQYbvvvvOcdy4cVqLxYIXXnjB60p6pa7kvqOiooy33XZb+eOPP+5XWVl5fsyYMfV1dXWigwcPqsrKyqRvvvlm8dq1ax2ys7Nl119/vdbd3d3y559/qoqLi2URERHdVu6i0x+NOefWVkkWOOc5nPPS7gqGEDLwieRiSOzllGRdw5YvX96rlblTUlJs/fz8Yvz8/GKGDRsWsWnTJs3SpUtz582bVwk09Dht2rQpOygoyDBjxozgUaNGRZSWlko3b9582sPDwwIAPj4+lo0bN54uKiqSjRo1KuLWW28NCg0N1W/cuLHpj/idd95ZPWnSpKoZM2YEe3p6xrz88svuGo3GeujQIZvbb789KDIyMurhhx/2v/nmmyvfeeedosZ2n3322fMrVqxw9/X1jZk0aVJQR/chFouxZs2a7NzcXHliYmLkAw88MOixxx4rcXFxMbc+96mnnirctWuXXVJSUsT777/v/sILL5xvPZG+M2bPnl3t5eVlfPbZZz1VKhX//fffT8XExNT/85//9I+Kioq64447ApOTk20CAgKMAGBnZ2f96KOP3MaOHRseFxcXuXnzZs3q1auzY2JijACwcuXKHEEQ2OjRo8Nvu+22oPHjx9cMHjy42zpkunrf69aty33ooYdK3nvvPY/Y2NjIyZMnh3z99dfOgYGBRgBwcnKybN261WHatGnBUVFRUS+++KL3k08+WTR//vxumxbFOL90fTTGmALAE2iYn+WKVgka5zz6Yq9PSEjgycnJVxAmIYQAOquADSVVOFxTj2CVHDM9nOAs69Z5q9cExlgK5zyh8XFaWlpOTExM9/1hYSyec57SXe2Rlhhj8R9//PG5xkTyWtGf7zstLc05JibGv73nOvsO9QmAmwF8D2A/2q44J4SQHlVusmBiciYqzVboBAEKEcP7uSXYEBuEKDVVnyeE9E+dTbRuAnAb5/zXHoyFEEI69PbZQhSbzE2LGg0ChwEcT5zKw87EsL4NjhBCOtDZREsHIL8nAyGEkIvZVl7TvHJEk9P1RtSYLbCX0hAiuTZcq8OyA/W+OzsZ/l0ACxhrr/QzIWSg4RYBuuPl0O4rgCm/7tIv6AcuVtZCQm9NfWLBggWejfv+Nf8CGubTtP5q3BuQkGtJZz8C3ghgFICJjLF0AC1WQHDOp3V3YISQnmEu06Hs/46BmwVwqwDGGOSB9nC6OwJM3D9rdAHALA9HfJJXCoPwV7eWBMBIjS1sJLS3fV9YtmxZYXtlHPrbZPjKykrRzJkzBx04cECt1WrFp06dOt64XU5vmjFjhn9RUZFs//79p3v72qTvdPZdtRzABgC7ABQDqGj1RQgZICq/PgWh3gxutAIWDm4WYMyugfbPor4O7aKe8HPDUHsbKEUMKhGDrVgEX6UcH4T59nVopJ9bunSp65EjR2x37tyZmZubmxYYGNgmycrMzJQxxuJtbGxi8/PzW3RCzJw50y8pKSm09yK+uLlz5/pER0eHKZXKWIlEEt/eOenp6bKJEycGODo6xiiVytjw8PCIzz77rP8X5LsKdbZg6ZyeDoQQ0vMs1UaYy/Vt1g1zs4D6Q8VQX+fVN4F1glwkwvohQUir0+FknR4+ChlGamwhomFDcglZWVny4OBgfWc2C7ZarWzRokWe69aty+uN2C6H1WrFbbfdVpmfny9buXJlu/sNT5s2LdjR0dGycePGM05OTpZVq1Y5/fOf/wwYNGjQqRtvvLG+t2O+lnVpnIAxlsAYm8kYs7nw2IYxRjNQCRkorAI6zEuEgVG1JUatwmxPJ4xyVFOSRWA0Gtm8efO8XF1do6VSaVxgYGDkp59+6tj4vJeX1+DvvvvO+cCBA2rGWPyleqbuv//+ku+++84lNTW1w93QBUHASy+95Obt7T1YKpXG+fj4RL322muuzc8pKSkR//3vfw9QKpWxTk5OMY8//rhne3Ur33zzTddBgwZFyuXyOD8/v6hFixa5m81t6pO28OWXX+a/+OKLpVFRUe0mjuXl5eLs7GzFk08+WTxq1ChdRESEacmSJUV2dnbWAwcO2Fy0cdLtOpVoMcbcGGMH0LCv4ToAjRn0MgBLeyg2Qkg3EzsqILKVtn1CwqAa4tL7ARFyhR5//HGvdevWuSxevDg/JSXl5G233VYxb968QRs3blQDwOHDhzMmT55cFR8fr83NzU3btGlT1sXamzZtWk1iYmLdwoULvTs655133nF59913vZ588smi1NTUk4899ljJm2++6b18+XLnxnPuuusu/+PHj6vWr1+ftX379szc3Fz5L7/80mLobsGCBZ4ff/yx26uvvlqQlpZ24t13383/6quvXBYuXHhFiwacnZ2twcHB+nXr1jlVVFSIrVYrPvvsM43BYBBNnDix9kraJl3X2d6o5QBKADgBaN6d+j2AD7s7KEJIz2CMwWl2OMr+cxxc4IBFAJOJIHFWwnZ0h39XCOmS+fPn98qEv7q6OtGqVatcX3vttfy5c+dWAUB0dHRxSkqKzdtvv+0xffr0Ok9PT4tCoRBkMhn39fXtcKPk5t577738UaNGRWzatEk9derUNstyV6xY4XHfffeVLly4sBwABg8eXJaZmalYunSpx/z588tPnDgh//XXXx1+/PHHM9OmTasDgPXr1+f4+voObh77v//9b7c1a9Zk33rrrbUAEBYWZiorKyt89tlnfVasWHFFe0Xu3Lnz9C233BLo7Ow8RCwWc6VSKXz55ZfZiYmJ3baHH+mczg4d3gDg+dZ7HQLIBkAzUQkZQGQ+argvSoT9RD/YXucJx9tD4fpILEQyWrlHukdvbSidnp4uN5vN7IYbbmiRDI0aNaruzJkzysttd+TIkfrp06dXPPvss96tN0SurKwUlZSUSMeMGdPimmPHjq0rLCyU1dXVidLS0hQAcMMNN2gbn1coFDw6OrppblRqaqrCYDCI7r777kCVShXb+LVw4UI/rVYrLiwsvOxpOYIg4MEHH/QVi8V88+bNmXv37s24//77S++///6A33//nbZR6GWd/YdUAmhvKawLgGs2O7YKHHtOl+JsWT1C3NS4LsgZItpIlwwAYhsp1NdRDxYhHVmyZEnB4MGDo5rP9+pOVquVAcDq1avPRkZGtvk76urq2qnet/Zs3rxZvX37dk1ubm5aYy/eiBEj9AcPHrR977333EaNGnXu8iMnXdXZHq29AO5r9pgzxsQAFgHY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xuIvlH5qV2fuoaqqSjR79mw/jUYTI5PJ4qKiosJ//PHHFgvt/vzzT2VsbGyYTCaL8/Pzi/r88881ra91uffa0zo7R4t0g1tivSCXtP2Ru9jK4etIvVmEENIVJSUl4j179tjPnTu31MnJqU2PkVwu53Z2dgIAPP74417r1q1zWbx4cX5KSsrJ2267rWLevHmDNm7cqAaA++67r+LAgQN2OTk5TeOMubm50v3799vde++9FQBQW1srHjt2bO3GjRvPJCcnp997773lTzzxxKBNmzapm1/3559/diwrK5Ns27bt9JYtW063F3tdXZ3oH//4R+nevXszfvvtt1MBAQGGm266KaS4uLjF6qglS5Z4jho1qu7QoUPpTz75ZNHixYu9GmMGgJkzZ/qvWrXK9Zlnnik8cuTIyW+++SY7ICDACACCIGD8+PFBJ0+eVK1Zs+ZsSkrKyfvvv7/0gQceCGjeRmvffvut/ZNPPul/++23V6SkpJx844038levXu26cOFCTwD47LPP8l977bV8sViM3NzctNzc3LSL/Ttd6h5mz57tv2fPHrvPP//83IEDB9ITExO1M2fODDpy5IgCALRaLZs+fXqwnZ2dZc+ePRlffPHFuffff9+9srKyaVTucu+1N3Q4dMgY+wDAs5zz+gvfd4hz/ni3R3YVuv+6APxysgTZZVrUm6xQSEWQiET4cHYcWAebVRNCCGlfenq6XBAEREZGXnRosK6uTrRq1SrX1157LX/u3LlVABAdHV2ckpJi8/bbb3tMnz69bvr06bVOTk7mL774wvH1118vAYAvvvjC0cnJyTx9+vRaAEhKStInJSU1XSsyMrJ0165d6q+//tpx6tSpTauaXFxczGvWrMkTizteUX7PPfdUN3+8bt26XI1Go9mwYYP9ww8/XNl4fOrUqZVPPfVU+YXrlf3nP/9x/eWXX+ymT59ed+LECfmGDRucVq5ceXbOnDlVF84x3nDDDfUAsGXLFvXRo0dtCwsL0xoT0YiIiPKDBw/afvjhh67Tp09vdyXWkiVL3CdMmFD19ttvF1/4WRmLi4ulb775pvc777xT5OTkZLW3t7cCgK+vr+ViP/vO3MO2bds03377bdaMGTNqAWDVqlX5Bw8etH3rrbfcv//++5zPPvvMSavVin/44YdzLi4u1gvnnEtKSopsvMbl3mtvuNgcrcEApM2+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69988821N998c1OPUGRkpNHGxiZ31KhR4ampqcqkpKR2t6mLj483NN9HMTg42HTixInSJUuWeHb65gFs3rzZTqlUWtesWZPXeCwsLMw0derUutbn2tvbW319fS2N15s4caI2LCzM8Oyzz/rOmDGj6u9//7sWAJ555hn3tWvXupSWlkptbGyskZGRum3btmXZ2tr26ebMAxX99RyALFYBq/fnYM2BXBjMVkyIdMeTfwuBo83lTdSur69HRkYGTp06BXt7e0RERMDPz4+Sqy6SSqXw9/eHv78/0tPTUVFRgby8POTm5uK5556DSqXCzz//3KlJ+oSQzqmrqxP94x//KE1MTNSZzWa2ZMkSt5tuuikkMzPzuLu7u/Xw4cMZvr6+MS+//HL+vffeW3npFq9cZWWlGABsbGw6vXdhVlaW9KefftIMGzasTYJ0MR4eHua6ujrJd999Z3c5Q4ALFy4se+utt7zWr1/v+Pe//1375ZdfOnz00Ucen3322dnExER9WVmZ+Ndff1V3tV3yF/pLOgA98e1R7DxVAoO54Xf4m4N52JlRgh0LxkAl6/w/aUVFBVJTU1FYWIigoCD8/e9/h0aj6ZGYWw+ZXe1DaYwxODs7w9nZGXFxcVi6dCnq6+vxww8/wNPTE5GRkfDw8KCJ9IRcoXvuuae6+eN169blajQazYYNG+wffvjhSk9PTwvQsjenJ9XU1IiefvppnwkTJlRFRkZeco+92NjYsIyMDJXRaGTXX3999Y8//ni2K9ebO3du1a+//lp+xx13BP/jH/+wDh48uH706NF1c+bMqQgKCrrk3okSiQSDBg0y5ObmygAgJydH5uzsbJ4xY0atXC7nwcHBGDFiRLu9cqRzqFLjAJNVqsXOjL+SLAAwCxyV9Wb8mHq+U21UVVXh119/xdatW+Hm5obZs2dj5MiRPZZkkYY3M3t7e8yePRuenp7Yt28ffvjhB5w8eRImk6mvwyNkwDp16pTspptuGuTr6xtla2sbq1arY7VarbgxcehNtbW1ogkTJgRJJBL+9ddf53bmNd9//332/v3701evXp197tw5xT333ON36Vf9RSwWY/369bk5OTlp77zzTl5oaKj+yy+/dImOjo7avHlzp3qiOOdNH/ruueeeKrPZzHx8fAbPmDHD/+OPP3asqqqiXOEKUI/WAHO8oBpiUdteEL3ZioPn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",
      "text/plain": [
       "<Figure size 396x280.8 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Create a figure and axis object\n",
    "fig, ax = plt.subplots(figsize=(5.5, 3.9))\n",
    "\n",
    "Aobs_yadf = yadf[yadf[\"Matrix\"] == 0]\n",
    "# first two dimensions in an array\n",
    "Aobs_array = Aobs_yadf.iloc[:, 0:2].to_numpy()\n",
    "\n",
    "node_number = 18\n",
    "\n",
    "Aobs_yadf_node = Aobs_yadf[Aobs_yadf[\"NodeNumber\"] == node_number]\n",
    "\n",
    "# Filter data for node number and select the relevant dimensions\n",
    "data_d_dim = yadf[yadf[\"NodeNumber\"] == node_number].iloc[:, 0:d].to_numpy()\n",
    "\n",
    "# Calculate the covariance considering all d dimensions\n",
    "cov_d_dim = np.cov(data_d_dim, rowvar=False)\n",
    "\n",
    "# plot the covariance ellipse with the same color as the point\n",
    "plot_ellipse_3mahals(ax, data_d_dim[0, 0:2], cov_d_dim[0:2, 0:2], color='#808080', lw=1)\n",
    "\n",
    "# Plot the scatter plot\n",
    "scatter = ax.scatter(Aobs_yadf[\"Dimension_1\"], Aobs_yadf[\"Dimension_2\"], c=Aobs_yadf[\"tau\"], cmap='tab10')\n",
    "ax.set_xlabel(\"Dimension 1\", fontsize=14)\n",
    "ax.set_ylabel(\"Dimension 2\", fontsize=14)\n",
    "\n",
    "#no ticks\n",
    "ax.set_xticks([])\n",
    "ax.set_yticks([])\n",
    "\n",
    "# Plot the bootstrap points\n",
    "ax.scatter(data_d_dim[:, 0], data_d_dim[:, 1], color='black', alpha=1, marker='+', s=100)\n",
    "\n",
    "# Create custom second legend\n",
    "legend_elements = [\n",
    "    Line2D([0], [0], color='#1f77b4', marker='s', lw=0, label=f'Node {node_number}, member \\nof class 4A', markersize=12, markerfacecolor='#1f77b4'),\n",
    "    Line2D([0], [0], color='black', marker='+', lw=0, label=f'Bootstrap Resamples \\nof Node {node_number}', markersize=12, markerfacecolor='#e377c2'),\n",
    "    Line2D([0], [0], color='#808080', lw=2, label='Covariance of node \\nat 1,2,3, SDs', linestyle='-')\n",
    "]\n",
    "fig.legend(handles=legend_elements, loc='upper right', bbox_to_anchor=(1.53, 0.75), fontsize='x-large', ncol=1, title_fontsize='large')\n",
    "\n",
    "# plot the point for node with node_number in blue square\n",
    "ax.scatter(Aobs_yadf_node[\"Dimension_1\"], Aobs_yadf_node[\"Dimension_2\"], color='#1f77b4', label=f'Node {node_number}, member of class 4A', marker='s', s=130)  # Increase marker size\n",
    "\n",
    "# plot the class 4B in red\n",
    "ax.scatter(Aobs_yadf[Aobs_yadf[\"tau\"] == 7][\"Dimension_1\"], Aobs_yadf[Aobs_yadf[\"tau\"] == 7][\"Dimension_2\"], c='#d62728', label='tau=7')\n",
    "\n",
    "# invert x axis\n",
    "ax.invert_xaxis()\n",
    "\n",
    "# Adjust layout to make room for titles and labels\n",
    "plt.tight_layout()\n",
    "\n",
    "plt.savefig(f\"figs/school_A1_embedA_viaUASE_sd1mean0_4classes_node{node_number}_boostraps_3mahals_noaxes.png\", bbox_inches='tight', facecolor='white')\n",
    "\n",
    "# Show the combined plot\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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vHnzePXVV/Hy8sLLy6vN5//TTz8xdOhQzMzM8Pb25m9/+xtCCMNzeOedd9i+fTuKohAbG9vmcfbu3cvUqVOxsrLCzs6OqVOncvbs2Va3XbduHZMmTcLBwQFHR0dmzZpFWlpai21efPFFfH19MTMzw83Njdtvv92wbvv27YwdOxZra2vs7OwYPXo0R460P757VlYWDz/8MF9//TUajabVbfbs2UNRURHPP/88FhYWrF27tt1jSpIkdZaZiZr3bh3Jmocncds4XyYGOTMzbBCDbM07tb9WJ7A277mWeTIB7KdUKhWvvPIKH374IRkZGa1uk5OTw5w5c4iMjOTQoUN88sknfPPNNzz55JOGbR5//HE2btzIjz/+yObNmzl06BDbt29vcZw77riDbdu28fXXX3PkyBEWL17M/PnzSUpKuqLnMHHiRFatWsXp06eBpoQsMTGR2bNnX/Kx/vrXv3LTTTeRlJREVFQUN910E3fddRcPPPAAhw4dwsPDgyVLlhi2T05OZubMmVx99dUkJSXx008/kZiYyJ133tniuP/73/+wsbFh3759LF++nEceeYSFCxcSEhJCQkICixcv5u677yY3t2UPryeeeII//elPJCYmMmPGDBYsWGCYGSI3N5fJkycTERHB/v372bRpE1VVVSxYsAC9/veeZtu2bePw4cOsW7eOzZs3t/q8Dxw4wPXXX88111xDcnIyr7zyCi+//DL/+te/gKbk8I477mDcuHHk5uby008/tXqcpKQkpkyZQlBQELt27WLv3r3ceOONNDY2trp9dXU1jzzyCPv37ycuLg47Ozvmz59v+HHx448/8vrrr/P+++9z4sQJVq9ezejRTW1fGhsbWbBgARMnTiQpKYl9+/bxyCOPtFsy2djYyM0338xf/vIXQkND29zu448/5qabbkKj0fCHP/yBjz/+uM1tJUmSLkegizXPzQ/nq7vH8NHtUdwxwQ9zTcfpVpCrNc7WZj0Q4TlCiAF7GzVqlGhPampqu+vb47tsdadvXW3x4sVi7ty5QgghYmNjxY033iiEEGLr1q0CEIWFhUIIIZ566ikRFBQkdDqdYd9PP/1UmJqaiurqalFZWSlMTU3FV199ZVhfWVkp7OzsxOLFi4UQQqSnpwtFUURWVlaLGBYsWCDuv//+TsVrZWUlPv3004uW19fXiyVLlghAmJiYCBMT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nK1bt5KZmcmUKVMAcHFxQVEUlixZAjSV9tx///08/vjjuLi4MGHCBADefPNNhg0bhpWVFZ6entx9992UlZUZYvjss8+wtrZm1apVhISEYG5uzpQpUzh58mSH18jGxgY3Nzf8/Py4++67GTZsGBs2bDCsb2hoYNmyZXh5eWFpaUl0dDTr1683rNdqtfzpT3/Cw8MDMzMzvL29Wb58uWH9V199RXR0NDY2Nri6unL99deTk5NjWN9cGrp27VpGjRqFhYUFkyZN4syZM2zbto3hw4djbW3NvHnzKC4uNuzXXL3717/+lUGDBmFtbc0dd9zR4rW9kBCCf/zjHwQGBmJhYcHQoUP56quvWmzz4osv4uvra3jvtJXsNNu+fTtjxozB3NycQYMG8eijjxoS9yVLlvDoo4+SnZ2Noihtlpo1+9Of/sQ777zT4vpcqL6+nkceeYRBgwZhbm7O2LFj2blzZ4tt1q1bx5AhQzA3N2fSpEmtlsDt3r2bmJgYLC0t8fT05P7776eioqLd+P75z3/y0EMPERIS0ur6AwcOoNVqefnllwkKCmLEiBE8+eSTZGRkGL20W5IkqTUyARwAKisrWbFiBUOHDsXCwgKA6upqZs2ahbW1Nfv372flypXs3r2bO++807DfO++8w2uvvcarr75KcnIyixYt4pprriExMRGA/fv3A01furm5ufz0008A3HLLLbi7u7N//34SExN5/vnnMTc3x9vbmx9//BGAlJQUcnNzeeeddwzn++qrrxBCsGPHDr744gsAVCoVb7/9NikpKXz99dfs37+fhx56qMXzq6+v54UXXuDTTz9lz5496HQ6rrnmmk5X5wohiIuLIy0tDY1GY1h+xx13sG3bNr7++muOHDnC4sWLmT9/PklJSQC8++67rFy5km+//ZYTJ06wYsUKBg8ebNi/oaGBF154gaSkJFavXk1RURE333zzRed/7rnnePvtt9m3bx+lpaXceOONvPjii3z00UfExcWRkpLC888/32Kfbdu2kZSUxObNm/nxxx/ZsGEDy5Yta/M5/uUvf+GTTz7hvffeIzU1lSeffJJ7772XNWvWAPDjjz/y+uuv8/7773PixAlWr17N6NGj2zxeTk4Oc+bMITIykkOHDvHJJ5/wzTff8OSTTwJN751nn30WLy8vcnNziY+Pb/c1uP766xk6dCjPPvtsm9s8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m2++4fjx4zz77LPs2LGDxx9/HABXV1csLCxYv349+fn5lJeXU1tby9KlS4mLiyMzM5N9+/a1SBp9fX1RFIU1a9ZQWFhIVVVVm88hODgYvV7P22+/zalTp/jmm294++23L9rOxMSERx55hD179pCYmMjixYsJDw9n+vTpl3TNHnjgAY4dO8b3339PSEgIt956K0uWLOGHH37g5MmTJCQk8Prrrxs6u7z55pt88803pKWlkZ6eztdff42trS1eXl74+PhgZmbGv/71L06ePMmaNWt45plnLime9jQ2NnLnnXeSkpLCxo0bWb58OX/84x9bLa2zsbHh8ccf5/HHH+e///0v6enpJCYm8uGHHxqGvfnss8/4+OOPSU5O5tSpU3z66adoNBqCg4PbvFZnz57lgQceIC0tjTVr1rB8+XIefPBBLC0tr+i5vfjiiyQmJrJv3z7DMisrK+6//36WLVvGb7/9RlpaGvfffz/5+fk88MADANx3331kZmbyyCOPcOzYMX744Qc+/PDDFsdetmwZ+/fv57777uPQoUOkp6ezevVq7r333nZjar5mZ8+epaGhwdC8ork0d+7cuRw8eJAXX3yREydOcPDgQe644w68vb1bbdogSZJkdK01DBwot+7sBNKa7ujw0ZrFixcLwHCzsbER0dHR4ocffmix3eHDh8XUqVOFubm5sLe3F4sXLxZlZWWG9TqdTrz44ovCy8tLaDQaERERIVauXNniGP/5z3+Et7e3UKlUIiYmRtTX14ubb77Z0MnC3d1d/PGPfxTl5eWGfV588UXh5uYmFEURixcvFkK0bPB/vnfeeUd4eHgIc3NzMXXqVLFixYoWjfo//fRTYWVlJX7++WcRFBQkTE1NxeTJkw0dWdri6+srXnvttYuW//GPfxShoaFCp9OJhoYG8dxzzwl/f3+h0WjEoEGDxPz580VCQoIQoqkjTWRkpLC2thY2NjZi8uTJhk4kQgjx7bffioCAAGFmZiaio6PFunXrBCC2bt0qhGi9Q8z3338vmv4tf/fBBx8IJycnw+PmDh4vvPCCcHFxEVZWVuL22283dL44f5tmer1evPvuuyI0NFSYmpoKZ2dnMX36dLFhwwYhhBArV64UY8eOFXZ2dsLS0lJERUWJVatWtXsNt23bJkaPHi1MTU2Fq6ureOSRR0RdXZ1h/aV2AjnfE088IYAW74m6ujrx8MMPC1dXV2FqairGjBkjduzY0WK/1atXi5CQEGFmZibGjx8vvvrqqxbvFyGEiI+PF7NmzRI2NjbC0tJSREREiGeeeabdOGNiYlr8TzXfzj/uN998I0aOHCmsrKyEs7OzmDdvnkhJSWn3uLITiCRdviM5ZeLZn5PFXZ/tF3/+PlHsTi/qdKe8gYQ2OoEoQnRuqIz+KCoqSrQ3i0VaWtolVSNKPe+zzz7jwQcfbLcksb9ZsmQJRUVFrF692tihSFdIfsZI0qUrr9Xyxy8SSD5TRn2jHr0ABbAwVeNma84Xd43Gy+HKaiL6E0VRDgghoi5cLquAJUmSJEnqE7Q6PTd/tJfE7DJqtU3JHzQVydc06MgqrmHR+7spre7+2aT6OpkASpIkSZLUJ6w7kkdmcTUNutY7V+mEoLxWy6e7T/VwZH2PTAClPm3JkiUDqvoXmqq9ZfWvJEkD0UfbT1LT0P4oEg2Nej7fncVAbuLWGTIBlCRJkiSpT8gsqu54I6C6vpGq+sZujqZvkwmgJEmSJEl9glrduYHf9UKgUcsUpz3y6kiSJEmS1CdMCHRG1YkcMMjVGnONuuMNBzCZAEqSJEmS1Cf8cXIApibtpy4WGjX3x17+jEQDhUwAJUmSJEnqE0Z427N4nB8WbZTuWWhUTAxyYsHwy5/be6AwMXYAkiRJkiRJnbV8zhB8HC15a9Nxaht0KIpC00iACndO8Ofh6cGoOlNPPMDJBFAyitjYWCIiIvjXv/5l7FCu2NGjR7njjjs4dOgQbm5uZGZm9ti5ExISiI6O5tSpU/j5+fXYeSVJkoxFURRuHevLzaN9OJhdSmFlPbYWGqL9HDusHpZ+1yuulKIojoqibFQU5cS5vw6tbDNCUZQ9iqKkKIpyWFGUG89b568oyj5FUdIVRVmhKIppzz6D3ic/P5+HH36YwMBAzMzM8PT0ZM6cOfz222/GDg2An376iZdfftnYYXSJv/zlL1haWnL06FHi4+ONHU63WLJkCfPmzetwu5SUFK677joCAgJQFIXnn3++w32SkpK4+eab8fb2xsLCgsGDB/OPf/wDvb71gV6bPfPMMwwZMgQrKyscHByYNm0au3fv7uxTanH+BQsW4Obmhrm5OT4+Plx77bVkZWUZtlEUxXCztLQkICCAW265hR07dlzy+SRJ6hoqlUKUnyNzhrozIchZJn+XqLdcreXAZiFEMLD53OML1QC3CyHCgdnA24qi2J9b9yrwlhAiCCgF7ur+kHuvzMxMRo4cyfr163n55Zc5fPgwmzZtYu7cudx3331Gja2hoWl6HkdHR2xsbIwaS1dJT09n4sSJ+Pn54eLiYuxwjKqmpgY/Pz/++te/4u/v36l9Dhw4gIuLC19++SUpKSm88MILvPTSS7zyyivt7jd48GDee+89kpOT2blzJ/7+/syePZv8/PxOx1tYWMi0adOwtrZmzZo1HD16lC+//JLAwEAqKipabPuf//yH3Nxc0tLS+OSTTzA1NSUmJobXXnut0+eTJEnqNYQQRr8BxwD3c/fdgWOd2CcJCKZpDugiwOTc8nHA+s6cd9SoUaI9qamp7a7vrebMmSM8PDxEZWXlRetKS0sN97OyssTChQuFtbW1sLa2FosWLRKnT58WQghx7NgxAYjDhw+32P/f//63cHJyEg0NDaKxsVHceeedws/PT5ibm4ugoCDx6quvCp1OZ9h+8eLFYu7cueKVV14Rnp6ewsXFRQghRExMjFi6dKlhuy+//FJERUUJa2tr4eLiIq677jpx5swZw/qtW7cKQGzatEmMHj1aWFhYiFGjRokDBw60iG/Pnj1iypQpwtLSUtja2oopU6aInJwcIYQQer1evPrqqyIgIECYm5uLiIgI8eWXX7Z7LXU6nXjxxReFl5eXMDU1FREREeLnn382rKep4Ynh9txzz7V6nObr8PbbbwsPDw9hb28vlixZIqqrqw3b1NXViYcffli4uroKMzMzMWbMGLFjx44Wx1m7dq0YPHiwMDMzExMnThT/+9//BCBOnTpl2GbXrl1i8uTJwsLCQnh4eIj77rtPlJeXt/kcO3odn3vuuYue59atW9u9bkIIER4e3ub16Mif//xnMXLkyEvap7y8XABi3bp1nd5n5cqVQqVSifr6+na3A8T3339/0fInn3xSqNVqceLECSGEEA0NDeKhhx4S7u7uwtTUVHh5eYlly5a1edy++hkjSVLfASSIVnKg3lICOEgIkXvufh4wqL2NFUUZDZgCGYATUCaEaB7y+wwwYLv/lJSUsG7dOpYuXYq1tfVF6+3t7QHQ6/UsWLCA/Px8tm7dytatWzl79iwLFy5ECEFISAjR0dH873//a7H///73P2644QY0Gg16vR5PT0++++470tLS+Nvf/sbf//53Pv300xb7bNu2jcOHD7Nu3To2b97catwNDQ288MILJCUlsXr1aoqKirj55psv2u7JJ5/klVde4eDBgzg5OXHrrbcapvtJSkpiypQpBAUFsWvXLvbu3cuNN95IY2PTW+Mvf/kLn3zyCe+99x6pqak8+eST3HvvvaxZs6bN6/nOO+/w2muv8eqrr5KcnMyiRYu45pprSExMBCA3N5fBgwfz2GOPkZuby+OPP97msXbs2MGRI0fYtGkTK1asYOXKlbzzzjuG9U888QQrVqzgv//9L4cOHWLo0KHMnj2b3Nymf43Tp0+zcOFCZsyYQWJiIg899BBPPPFEi3MkJyczc+ZMrr76apKSkvjpp59ITEzkzjvvbDOujl7Hxx9/nBtuuIHp06eTm5tLbm4u48ePb/N4XaGiogIHh4tagrSpoaGBjz76CFtbW0aMGNHp/dzc3NDr9fzwww+XNW3UY489hl6v5+effwbg3XffZeXKlXz77becOHGCFStWMHjw4Es+riRJUnfrsU4giqJsAtxaWfX0+Q+EEEJRlDY/iRVFcQe+BBYLIfRNvX8uKY57gHsAfHx8LmnfZi+88MJl7XclnnvuuU5tl56ejhCC0NDQdrfbvHkzhw8fJiMjw9B54OuvvyYoKIjNmzczffp0/vCHP/DGG2/w8ssvoygK2dnZ7Nixw9B2T6PR8OKLLxqO6efnx8GDB/nmm2+4667fa+HNzc3573//i5mZWZvxnJ+gBAQE8MEHHxAaGsqZM2fw8vIyrHvppZeYMmUKAM8++ywTJ04kJycHLy8v/vGPfzBixAg++ugjw/bN16G6upo333yTDRs2MGnSJAD8/f3Zv38/7733HnPnzm01rtdff53HH3+cW265BYAXX3yR7du38/rrr/PVV1/h5uaGiYkJ1tbWuLm19vb+na2tLR9++CFqtZrQ0FCuv/56Nm/ezJNPPkl1dTUffPABH3/8sSGWDz/8kC1btvDee+/x17/+lQ8++AAfHx/effddFEVhyJAhHD9+nGeeecZwjtdee40bb7yRxx57zLDsgw8+IDIykoKCAlxdXS+Kq6PX0draGgsLC8zMzDp8jl3h4MGDfPbZZxf9+GjN6tWruemmm6ipqcHd3Z2NGzcyaFC7vx9bGDt2LE899RSLFy9m6dKlREdHExsby6233oqvr2+H+zs5OeHq6srJkycByMrKIiQkhEmTJqEoCj4+Pt2eLEuSJF2OHksAhRDT21qnKEq+oijuQojccwleQRvb2QJrgKeFEHvPLS4G7BVFMTlXCugF5LQTx0fARwBRUVGXNVN0Z5MxY+hsKUZaWhoeHh4teo4GBATg4eFBamoq06dP56abbuKxxx5jx44dTJ48mW+++QZ/f/8WX2gffvghH3/8MVlZWdTW1qLVai/64oyIiGg3+YOmL/0XXniBxMRESkpKDM8jOzu7RQI4bNgww30PDw8ACgoK8PLy4tChQyxatKjV46emplJXV8fs2bM5/0eDVqtts/dsRUUFZ8+eZcKECS2WT5w48bI604SFhaFW/z52lYeHB/v27QMgIyMDrVbb4lxqtZpx48aRmpoKNL1mY8eObRH/uHHjWpzjwIEDpKens2LFCsOy5muZkZHRagIInXsde8KxY8eYO3cujzzyCNdee22H20+ZMoXExESKior4z3/+ww033MCePXtwd3fv9Dn/9re/8X//939s2bKFvXv38sknn/C3v/2NX3/9lWnTpnW4vxDC8JosWbKEGTNmEBISwsyZM7nqqquYM2cOKlVvqWyRJElq0ls+lX4FFp+7vxj45cINzvXsXQl8IYT4oXn5ufrtrcB17e0/UAQHB6MoCmlpaZd9jOYvM1dXV2bMmGEoifnf//7HrbfeathuxYoVPPLIIyxZsoT169eTmJjIAw88YOjo0czKyqrd81VXVzNr1iwsLS358ssviY+PZ926dQAXHUuj0VwUZ0e9Rc/fZtWqVSQmJhpuKSkpbNiwocP9L3SpJc/QMvbmY3Qm9ks5l16v5+67727xHJOSkjhx4kSbVaOdfR2729GjR4mNjeWmm27qsANIMysrK4KCghg7diyffPIJGo2Gjz/++JLP7eTkxPXXX88bb7xBWloafn5+vPTSSx3uV1RURGFhIQEBAQCMHDmSzMxMXn75ZfR6PYsXL2bGjBmdep0lSZJ6Um9JAF8BZiiKcgKYfu4xiqJEKYrS/Gl+AzAZWKIoSuK524hz65YB/6coSjpNbQI/6dHoexFHR0dmzZrFv/71L6qqqi5aX1ZWBjRVjZ49e7bFmHUnT57k7NmzhIWFGZb94Q9/4Pvvv+fAgQMkJyfzhz/8wbBu586djBkzhgcffJCRI0cSFBRERkbGJcd89OhRioqK+Pvf/87kyZMZMmQIBQWtFgK3KzIyki1btrS6LiwsDDMzM7KysggKCmpxa6uky9bWFg8PD3bt2tVi+c6dO1tco64QGBiIqalpi3PpdDr27NljOFdoaCj79u1rUcq7d+/eFscZOXIkKSkpFz3HoKAgLCwsWj13Z15HU1NTdDpdVz3di6SmphIbG8v111/PW2+9ddnH0ev11NfXX1EspqamBAYGtvr/c6E33ngDlUrFwoULDctsbGy47rrr+OCDD1izZg1btmwhPT39imKSJEnqar1iIGghRDFwUV2LECIBuPvc/a+Ar9rY/yQwujtj7Evee+89JkyYQFRUFC+99BLDhg1DCMHWrVt5+eWXyc7OZvr06QwbNoxbb73V0BHhoYceYuTIkUydOtVwrIULF3Lvvfdy1113ER0dTUhIiGFdSEgIn332GWvXriUoKIhvv/2Wbdu2XVLjfWhqi2lmZsa//vUvli5dSlpaWot2bZ315z//mbFjx3LPPfewdOlSzM3N2bFjBzNnzsTHx4fHH3+cxx9/HCEEkydPpqqqir1796JSqbjnnnvaPOazzz5LcHAwo0aN4quvvmLHjh0cPHjwkuNrj5WVFffffz/Lli3D2dkZf39/3nrrLfLz83nggQcAuO+++3jjjTd45JFHeOCBB0hOTubDDz9scZxly5YxduxY7rvvPu69915sbGw4evQoq1at4t///ner5+7M6+jn58fatWs5duwYTk5O2NnZXVSiCU0lts1V1nV1deTl5ZGYmIi1tTVBQUGtnj8lJYWpU6cyZcoUnnrqKfLy8gzr2mpzWFFRwT/+8Q/mz5+Pu7s7hYWFvPfee5w5c4YbbrihnSvd0urVq/n222+56aabCAkJQQjBqlWr+O233y5q61tWVkZeXh4NDQ1kZGTw+eef88UXX/CPf/yDwMCmeUfffPNN3N3dGTFiBBqNhq+//hpbW9sWzRgkSZJ6hda6Bg+UW38dBkYIIc6ePSsefPBB4e/vL0xNTYW7u7uYPXu2WLt2rWGbrKwssWDBAsMwMAsXLjQMA3O+2267TQDinXfeabG8vr5e3HnnncLe3l7Y2dmJO++8U7zwwgvC19fXsE3z8CcXunAYmG+//VYEBAQIMzMzER0dLdatW9diuJHmYWAKCwsN+5w6dUoAIj4+3rBsx44dYtKkScLc3FzY2dmJadOmibNnzwohmoaBeffdd0VoaKgwNTUVzs7OYvr06WLDhg1tXsfzh4HRaDQiIiJCrFy5ssU2nRnupLXr8Nxzz4nw8HDD4/OHgTE1NW11GJjVq1eLkJAQYWZmJsaPHy+++uqri4aBiY+PF7NmzRI2NjbC0tJSREREiGeeeabN2DrzOhYUFIgZM2YIa2vrdoeBaX5NLrzFxMQYtvn0009bxNzaMDPNt/Nx3jA71dXVYuHChYbhVtzd3cXVV18t9u7de9F1P/95XCgjI0Pce++9YvDgwYahg4YPHy7eeustodfrW5y7+WZmZib8/PzETTfdJLZt29bieB999JGIjIwU1tbWwsbGRkyePFns2rWrzfP35c8YSZL6BtoYBkYRlzH0QX8RFRUlEhIS2lyflpbWYW9aSZIuzXPPPccPP/xAUlISJiadq4Q4deoUgYGB7Nix46JOOe2JiYlhyJAhbZZ+Gpv8jJEkqbspinJACBF14fJeUQUsSdLA8dtvv/Hee+91Ovlr3uf222+/pOSvvLycY8eO8dNPP11OmJIkSf2aTAAlSepRlzNf8tKlSy95Hzs7uxbtCSVJkqTf9ZZewJIkSZIkSVIPkQmgJEmSJEnSACMTwA7IAVwlSeoO8rNFkiRjkglgO6ysrMjJyaGhoeGyJoqXJEm6kBCChoYGcnJyOpwlR5IkqbvITiDt8PLyoqioiKysLBobG40djiRJ/YSJiQl2dnY4OzsbOxRJkgYomQC2Q6VS4erqiqurq7FDkSRJkiRJ6jKyCliSJEmSJGmAkQmgJEmSJEnSACMTQEmSJEmSpAFGJoCSJEmSJEkDjEwAJUmSJEmSBhiZAEqSJEmSJA0wMgGUJEmSJEkaYOQ4gJIkSecIIdDpdAghUBQFwPD3/PutLZMkSepLZAIoSVKfJISgvr6euro66uvraWxspLGxEa1Wi1arbfH4/L9t3ddqteh0OlQqFYqitJj+sfl+a8uatZUoqlQqTE1N0Wg0LW7nL7twfVuPVSpZaSNJUteQCaAkSb2GTqejtraW6upqampqqK2tpba2lrq6OsPf5vv19fVoNBrMzc0xMzPDxMQEExMTNBrNRfctLCxaPG5tm+a/l1qi11GieH5S2nxraGi46H5NTU2r689fZmJigqWlpeFmZWXV6n2NRtM1L4gkSf2WTAAlSeoROp2OqqoqysvLqaysNCR5598aGhqwsLBokeSYm5tjZ2fHoEGDsLCwwNzc3HBTq9XGflodVger1WrMzMyu+DxCCEOieP61q66upqCgoMVjtVrdZqLY/Nja2lqWKErSACYTQEmSukxjYyMVFRWGW3l5ueF+TU0NVlZW2NraYmNjg7W1Ne7u7hcle7JNXesURcHU1BRTU1Ps7e3b3E4IQUNDQ4uEsKamhsrKSvLy8lok3NbW1tjZ2WFvb2/4a29vL18HSRoAZAIoSdIlaWhoaDXBq6iooK6uDhsbG2xtbbGzs8PR0RE/Pz9D0idLnLqfoiiYmZlhZmaGg4NDm9vpdDoqKiooKyujvLyc/Px8jh8/TllZGUKIFknh+X97Q6mrJElXTiaAkiS1qrGxkZKSEoqLiykqKqKkpISKigq0Wi22traGJM/V1ZWgoCBsbW2xtraWJUd9hFqtxsHB4aIkUQhBXV0d5eXlhuTwxIkThqp7S0vLFkmhk5MTTk5OmJjIrxNJ6kvkf6wkSdTX11NUVERRURHFxcUUFxdTWVmJnZ0dzs7OODk5ERQUhJ2dHRYWFjLJ68cURcHCwgILCwvc3NxarNPr9VRWVlJWVkZZWRmFhYUcO3aM0tJSw48BFxcXXFxccHBwkCW+ktSLyQRQkgYQIQRVVVWGJK854auvrzeU5Hh6ejJ8+HDs7e1ldZ/Ugkqlws7ODjs7O3x9fQ3LdTodxcXFFBQUkJuby+HDh6mursbR0dGQFLq6umJjYyN/PEhSL6FcOJbVQBIVFSUSEhKMHYYkdQshBOXl5RQWFrZI9tRqNU5OToaSPScnJ2xtbeUXs9SlGhoaKCwsNNwKCgpobGw0lBA2J4aWlpbGDlWS+jVFUQ4IIaIuXC5LACWpnxBCUFpaSm5uruGmVqtxdXXFycmJ4cOH4+TkJL9wpR5hamqKp6cnnp6ehmU1NTWGZDAlJYXCwkJMTEwYNGgQnp6eeHl5YWNjY8SoJWngkAmgJPVRQgiKiorIy8vj7Nmz5OXlYW5ujpubGz4+PowZM0Z+mUq9iqWlJb6+vobqYyGEYXiaM2fOkJCQYEgcvby88PDwwNTU1MhRS1L/JKuAZRWw1AmxsbEAxMXFGS0GvV5PYWGhoXQvPz8fKysr3Nzc8PDwwM3NDSsrK6PFJ0lXSghBSUkJZ86c4cyZMxQUFODo6IiXlxdeXl64uLjIjiWSdIlkFbAk9TE6nc7QqD43N5eCggJsbW1xd3dnyJAhxMbGYmFhYewwJanLKIpiaJc6fPhwGhsbycvLIycnh507d1JZWYmHh4ehhFC2XZWkyycTQEnqRSorK8nKyiIrK4uCggIcHBxwd3cnIiICNze3LplSTJL6ChMTE0Pp35gxY6itrSUnJ4czZ86QmJiISqUyJINeXl6yuliSLoFMACXJiIQQFBYWGpK+2tpavL29CQsLY+bMmWg0GmOHKEm9hoWFBUFBQQQFBSGEoKysjDNnznDs2DG2b9+Ou7s7AQEB+Pj4yB9LktQB2QZQtgGUWtHc5q/Ztm3bAIiJiWmx/HLaBGq1WnJycsjKyiI7Oxtzc3NDw3hXV1dZpSVJl6GhoYGsrCxOnjzJ2bNncXd3x9/fHz8/P5kMSgOabAMoSUZUXV1NdnY2WVlZ5Obm4uLigq+vL5GRkdja2ho7PEnq80xNTQkODiY4OJiGhgays7M5efIke/bsYdCgQQQGBuLv7y9L1SXpHFkCKEsApU641F7Azb0ZMzMzyc7OpqKiAi8vL/z8/PDy8pIlEpLUQ7RaLVlZWaSnp5OXl4e3tzdBQUF4eXnJmW6kAUGWAEpSDygpKeHEiRNkZGSgUqnw9fVlzJgxuLm5yeErJMkINBqNod1gXV0dJ0+eJCkpiW3btuHv709QUBBubm6y6YU04MgEUJKuUG1tLenp6Zw4cYLa2lqCg4OZM2cO9vb28ktFknoRc3NzwsLCCAsLo7KykvT0dHbu3EljYyNhYWEMGTJEls5LA4ZMACXpMuh0OrKysjh+/Dj5+fmGkj4PDw+Z9ElSH2BjY0NkZCQjRoygsLCQlJQUvv32W/z9/YmIiMDR0dHYIUpSt5JtAGUbQKmThBDk5+dz4sQJTp48ibOzMyEhIfj5+cmG5ZLUD9TW1pKWlkZaWhq2trZERETg6+srm29IfVpbbQBlAigTQKkDFRUVnDhxghMnTqBWqw09DeW0a1Jf0BumMexr9Ho9p06d4siRI1RXVxMaGkpoaCjm5ubGDk2SLpnsBCJJl6ChoYGTJ09y/PhxysvLCQgIYNq0aTg7O8sqXknq51QqFYGBgQQGBlJUVERKSgorVqzA19eXiIgInJ2djR2iJF0xmQBK0nlKS0tJTk7m5MmTeHp6Mnz4cDlchCQNYM7OzsTExDBmzBiOHj3Khg0bsLKyIiIiAn9/f1k9LPVZHSaAiqJMABYCpcCXQojT561zAH4UQkzttgglqZsJIcjJyeHw4cOUlJQQFhbGjTfeiIWFhbFDkySplzA3N2fEiBEMGzaMrKwsjhw5wt69e4mMjGTIkCF9KhFMOl3GnpPFNOr0BA+yYeoQVzTqvhO/1DXabQOoKMp8YCVwALABPIGbhRC/nVs/CDgrhOiTxSOyDeDAptPpOHHiBMnJySiKwtChQwkKCpKlfVKf1p3TGEotFRYWsn//fiorKxk1ahRBQUG9uonI0bwKHvz6IDmldWh1evRCYGGqRq1SeGF+OItGehk7RKkbXG4bwKeBF4UQL547yFLgO0VRbhNCrOyGOCWp29XW1pKamkpqairOzs6MHz9eDt8iSdIlc3FxYe7cuZw9e5b4+HiSkpKIjo7Gx8en132epBdUcu0Hu6mp13F+sU91vQ6Ap1YeoUEnuDHa2zgBSj2uoxLACmCEEOLkecuuBb4Abgd2IksApT6ipKSE5ORkMjMzCQgIYOjQodjb2xs7LEnqVrIXcM8QQpCdnU18fDwajYbo6Gg8PDyMHZbB9R/uJiGzlPbG/TDXqDjwlxlYmcnuAf3J5ZYA1gGOgCEBFEL8qDT9tPkCWN5FwTkCKwA/IBO4QQhResE2I4APAFtAB/xNCLHi3LrPgBig/NzmS4QQiV0Rm9S3CSE4c+YMhw8fprS0lPDwcG688UY5nIMkSV1KURR8fX3x8fEhPT2d7du3Y2Njw+jRo3FxcTFqbKdLajh8przd5A9ApSj8fCiHW8f69khcknF1lAAeAqYCLYrJhBA/KIqiAr7qojiWA5uFEK8oirL83ONlF2xTA9wuhDihKIoHcEBRlPVCiLJz6/8shPihi+KR+ji9Xs+xY8dITk5GrVYzbNgwAgICZPs+SZK6laIoBAcHExgYaOg17OrqSlRUFA4ODkaJ6fCZcjRqFfWN+na3q2nQsfdUiUwAB4iOEsAPaSpZu4gQ4rtzSeC9XRDHAiD23P3PgTguSACFEMfPu39WUZQCwAUo64LzS/2EEIKMjAwSEhKwtbVl4sSJuLu797r2OJJxCCHQ6/VotVoaGxsNf5tver3e8F45/z3T1jJFUVCr1Wg0GkxNTdFoNGg0Gvl+k1CpVISFhRESEkJKSgqrV6/G29ubqKgorK2tjR2eJLWfAJ7r6NFmZw8hxLfAt10QxyAhRO65+3nAoPY2VhRlNGAKZJy3+G+KojwLbAaWCyHquyAuqY9orurdv38/arWayZMn96r2N1LXamxspKamhtraWmpra6mrq7vo74VJXvNflUqFiYkJJiYmaDQaw30TE5MWiVtz++jz20lfuEwIgU6no6GhAa1WazhH87GbE0MTExNDgmhqaoqFhQVWVlZYWloa/pqbm3dL4ijb/hmXiYkJw4cPJzQ0lKSkJH766SdGjhxJeHh4j/1QGOZlh1bXfukfgKWpmrH+cg7kgaLHWnoqirIJcGtl1dPnPxBCCEVR2myqoCiKO/AlsFgI0fyOfpKmxNEU+Iim0sMX29j/HuAeAB8fn0t8FlJvlJ+fz/79+6mtrSU6Oho/Pz9ZAtOHCSGorq6moqLCcKuurqampsZwa2xsxMLCwpA4WVhYYG5ujqWlJU5OTpibmxsSr/OTPI1G0+3jtQkhaGxsbJEUXni/pqaG/Px8w/Oprq6moaGhRWLYfLOyssLGxgY7OzssLS3le7uPMjU1JTo6muDgYLZt20ZGRgYxMTE90hHN29GS4d72xJ8qabcdoF4IFkZ6dns8Uu/QK+YCVhTlGBArhMg9l+DFCSEGt7KdLU3Vw39vq72foiixwONCiHkdnVf2Au7bSktLiY+Pp7CwkKioKIKDg/vUYKwDmV6vp6qqioqKCsrLy1skexUVFZiZmWFra2u4WVlZtUiMzMzM+l0ipNPpqK2tvSjZbU6Gy8vLaWxsxN7eHjs7O+zs7LC3tzc8NjGRPTf7CiEEqampHDhwgKFDhzJ8+PBu/+xKL6hi4Xu7qK5vbDUJtNCoeXFBONdHyWFg+pu2egH3lgTwNaD4vE4gjkKIJy7YxhRYC6wSQrx9wTr3c8mjArwF1AkhOuyhLBPAvqmqqooDBw6QnZ3NsGHDCA8Pl19+vZQQgqqqKoqKiiguLqa4uJiysjKqqqqwsLDA1tYWOzu7Fsmera0tGo3G2KH3SvX19ZSVlVFeXt7ib0VFBRYWFoak0NHREVdXVxwcHOSPol6ssrKS7du3U19fz+TJk7t9juFjeZUs/frARQNBm6hUvHB1uCz966d6ewLoBHwH+ABZNA0DU6IoShRwnxDibkVR/gB8CqSct+sSIUSioihbaOoQogCJ5/ap6ui8MgHsW+rq6jh06BDHjx8nLCyMYcOGYWZmZuywpHP0ej1lZWWGZK+oqIiSkhLUajVOTk44Ozvj5OSEg4MDtra2skd2FxJCUFlZaUgIi4uLKSwspKqqCkdHR1xcXHB1dcXFxQVbW9t+V3ralwkhOH78OPv372fIkCGMHDmy2/83mqeC0+kFwa7WTB3iiomcCq7f6tUJoLHIBLBv0Gq1JCcnc+TIEQICAhg5ciSWlpbGDmtAE0JQVlZGXl4ehYWFFBcXU1paipWVlSHRa0765JzKxtPQ0EBRURGFhYUUFBRQWFiIVqvF2dnZkBC6urrK/6deoKamhl27dlFaWkpMTAyDBrXbF1KSOu2KE0BFUcYA0wBXoMVPBSHEn7oiyJ4mE8DeLzMzk927dzNo0CCioqKws7MzdkgDkhCC4uJicnNzyc3NJS8vD1NTU9zc3HBxccHZ2RlHR0dZddsH1NbWGpLB5sTQ0tIST09PvLy8cHd3l6+jEZ08eZLdu3cTEBBAdHS0fC2kK3ZFCaCiKI8D/wDSgbPQog2pEEJM7apAe5JMAHuvqqoqdu/eTWlpKRMnTsTTU7ZN6Ul6vZ6ioiJDwpefn4+FhQXu7u64u7vj5uYmxzLrJ4QQFBUVcebMGXJycigsLMTZ2RkvLy88PT1xcXGRVcY9rK6ujj179lBQUMDMmTONNoC01D9caQJ4GnhVCPGv7gjOWGQC2Pvo9XpSUlI4dOgQ4eHhjBgxQrYV6wHNVbpZWVnk5ORQUFCAra0tbm5uhqRPVuUODFqtlry8PM6cOcOZM2eoqanBw8MDLy8vvLy8sLGxMXaIA8axY8fYv38/MTExctgy6bJdaQJYDkQKIU52uHEfIhPA3qWwsJAdO3ZgamrKxIkTe2R8rIFMr9eTm5tLVlYWWVlZCCHw9fXF09MTd3d32cFGAqC6upqcnBxDCaGlpSUBAQEEBATIJhk9ID8/n02bNhEeHs7w4cNlaax0ya40AfwQOCyEeL87gjMWmQD2DjqdjgMHDnDs2DHGjBlDcHCw/JDrJvX19Zw+fZqsrCzOnDmDnZ0dPj4++Pr64ujoKK+71C4hBHl5eZw8eZJTp05hbm5OQEAAgYGBMhnsRtXV1WzYsAFbW1tiYmJ6dNir1LMVfBufzemSGhytTFkU6cX4QCdUKvlZ0VdcaQL4NPAIsAE4DGjPXy+EeLNrwuxZMgE0vsLCQuLi4rCzs2PixImyN2I3KC8vN5TyFRUV4eHhga+vLz4+PvJ6S5dNCEF+fj4ZGRmcPHkSa2trgoKCCAwMlO+rbtDY2Mj27dspKytj5syZ3d4Gt7JOyz1fHODQ6VIaGvXoz6UKlqZqnK3N+PKu0fg6WXVrDFLXuNIE8FQ7q4UQIuBKgjMWmQAaj06nIyEhgePHjzN+/HgCAgJk6VMXqqurIyMjgxMnTlBZWYmvr6+helcOmi11Nb1ez9mzZzlx4gTZ2dm4uLgwePBg/P395UDUXUgIweHDh0lOTmbGjBndNlRMo07PNe/v5mheBQ26i3MElQL2lqasf2QyLjayqUhv11YC2KlvAiGEf9eHJA1UzaV+9vb2XHfddbJzQRfR6XScPn2a48ePc/bsWby9vRk1ahSenp7yS1jqViqVytBJpLGxkaysLFJTU9m7dy+hoaGEhobK//MuoCgKw4cPx8HBgQ0bNhAdHc2QIUO6/Dyb0gpIL6xqNfkD0IumEsKPd5zkyatCu/z8Us+45IGgFUWxpqnUr7p7Quo5sgSwZwkhOHr0KAkJCbLUr4s0D+Fx/PhxMjIysLe3JyQkhICAAExNTY0dnjTAFRcXk5KSwqlTp/Dx8SE8PBxXV1djh9UvlJWVsX79ery8vBg3blyX/si79v3dHMgu7XA7azMTkp6biVq2B+zVumIg6KXAMqB5QLYzNA0N02c7hsgEsOc0Njaya9cuw7hWssH4lamurubEiROcOHECnU5HcHAwwcHB2NraGjs0SbpIfX09R48eJTU1FQsLC8LDwwkICJBDPF2h+vp6Nm3ahIWFBVOmTOmyH9SRL26gtEbb4XZmJip2L5+Kk7WsBu7NrqgKWFGUp4AngdeBnecWTwJeURTFVgjxSpdFKvU7lZWVbNy4ETs7OxYuXChHtr8ChYWFJCcnc/r0aQICApg8eTKurq6yJFXq1czMzBg+fDjDhg0jOzubI0eOsHfvXsLCwhg6dKgsrb5MZmZmzJo1i3Xr1rF9+3YmT57cJZ8FnZ0XWKcXaExk85K+qrOdQLKBZUKIby5YfivwdyGEbzfF161kCWD3O3PmDFu3bmXEiBFERETIROUyCCHIysoiOTmZyspKwsPDGTJkyIAZpy82NhaAuLg4o8Yhda3S0lKSkpI4ffo0w4YNIzw8XHZQukxarZa1a9fi4ODAxIkTr/hz9rHvEvk58Sw6ffv5gZ+zJXGPT7mic0nd74pKAGma/ze+leX7ATljtXQRIQSJiYmkpKQwbdo0PDw8jB1Sn6PVajl27BhHjhzB3NycoUOHyl6VUr/h4OBAbGwspaWlJCQkcOTIEUaOHMngwYPle/wSaTQaZs+ezW+//caePXsYN27cFSWBd08KYE1ybrsJoIVGzQMxQZd9Dsn4Ovtfdhy4pZXltwDHui4cqT9oaGhg48aNZGdns2jRIpn8XaKqqir27dvHN998Q25uLlOmTGHBggUEBgbKL0ap33FwcGDGjBnMnDmTU6dO8d1335Gens6ldlAc6ExNTZkzZw75+fns37//iq5fqLst98UEYqFpvY2mhUbFmABHrh3lddnnkIyvsyWAzwPfKYoyGdh1btkEIAa4vhvikvqo0tJSNm7ciLu7O9OmTZONvC9BVVUVBw4cIDMzk5CQEBYtWiTnXZUGDBcXF6666irOnj1LfHw8iYmJREdH4+PjI5uOdJKZmRlXXXUVq1evRqVSER0dfdnHemR6CF72Fry24RhVdY0tXoMl4/14ZHqw7P3bx11KL+BRwKNA86A/acAbQohD3RRbt5NtALvWyZMn2blzJ2PGjGHw4MHGDqfPqKur49ChQxw/fpywsDCGDRs2YNr3taa5zV+zbdu2ARATE9NiuWwT2H8JIcjOziY+Ph4rKysmTZrU7TNf9Ce1tbWsXr2asLAwwsPDr+hYQggOnS6joKIeW3MTovwcMZUdP/qUK20DiBDiAPCHLo1K6jeSk5NJTk5mzpw5uLi4GDucPkGr1ZKcnMyRI0cICAjg+uuvl1No9TGyg0r3UBQFX19fvL29SUpK4qeffmLUqFGEhYXJ0sBOsLCwYNasWfzyyy/Y29vj6enZ8U5tUBSFkT4OXRid1Fu0mQAqiuIohChpvt/eQZq3kwampKQk0tLSuPrqqwfcr/TLSQB0Oh1Hjx7l0KFDeHh4sHDhQjl+33kuvJYyyRq4VCoVkZGR+Pn5sX37djIyMoiJiZHjiHaCra0t06ZNY/PmzVx99dXymkkXaa8EsFBRFHchRAFQBLRWV6ycWy4beg1QzVWX8+fPx8pKTgzeHiEE6enpJCQkYG9vz5w5c3BycjJ2WJLU6zk4OHD11Vdz5MgRfvnlF4YPH87QoUNlp6gOeHh4MGrUKDZs2MCCBQvkeItSC+0lgFOB5pI9OdCPdJEDBw6QkZHBvHnzZPLXgaKiInbs2IGiKMTGxuLu7m7skCSpT1EUhaFDhxpKA0+ePElMTAyOju1WUA14YWFhlJSUsHXrVmbOnCmr0CWDNhNAIcS21u5LkhCChIQEMjMzmT9/vpzkvR1arZaEhATS09MZPXo0ISEh8gO4D2urg8qFy2V1dfexsbHhqquu4tixY6xevZoJEyYQGBho7LB6tXHjxvHzzz9z9OhRQkNDO95BGhA6OxVcGKATQhw793gGsBhIAf4hhNB1X4hSbyKEYP/+/Zw+fZp58+YNuOTvUhKArKwsdu3ahbu7O9ddd92Au1ZdpS8kU9UNjZxIPQLAiBEjjBvMAKAoCkOGDMHFxYUNGzZQUlJCVFSU/HHVBrVazdSpU1m1ahUeHh6yPaAEdH4g6P8CkQCKongDvwCOwFLgr90TmtTbCCHYu3cvZ86cGZDJX2fp9Xq2bt3Knj17iImJYcqUKfJa9RNxcXHExcXx1crfGHbvW1j4DMXSdyi1M55Ba++DvXcwv67baOwwBwwnJycWLlxIbm4uGzZsoKGhwdgh9VoODg6MGjWKrVu3otfrjR2O1At0dhiYIcDBc/evA/YJIa5SFGUK8CnwZHcEJ/UeQgj27NlDfn4+8+bNG7Dj1HXUQzUrK4udO3diZmbGtddei0aj6dkApW6XUVjFNe/vprJOi14IEFBV34hOLyioqGfeuzv59cEJ2Fte3OBe9mjuehYWFsydO5fdu3fzyy+/MHPmTFnC1YawsDCys7M5dOgQo0aNMnY4kpF1tgRQDTT/tJoG/HbufgZyLuB+TwjB7t27KSgo4KqrrhqwyV97Ghsb2bZtG3v27GHq1KmMHz9eJn/9QGxsbIvqfSEEd30WT0WdltamSdULQW55LU/8eLjngpRQq9VMmjSJ8PBwfv31V3JycowdUq+kKAqTJ08mJSWF8vJyY4cjGVlnSwCPAPcrirKapgSwucTPk6YhYqR+7MiRI+Tl5TF//nw5jEArdDodv/76K3Z2drLUr5dpbGykvr6euro66urqDPfr6+vR6/WGNmPntx07f1lVVRUAhw8fRlEUssu1aCuLsUJFxtfP0VBwEoC8r5dTf7qpDeDpL5fxlaKQ8pE9GrVKlvb1oLCwMBwcHNi0aROTJk3Cz8/P2CH1OlZWVgwfPpy9e/cya9YsY4cjGVFnE8BlwM/A48DnQojkc8uvBvZ3Q1xSL5GTk0NiYiILFy6UyV8r6uvrKSsrIzg4mIiICNkIvYfV1NRQXFxMVVUVVVVV1NTUGP5WV1ej0+kwMzPD3Nzc8Lf5/vmvVfOUmOdPjSmEMLSVqq6uRgjBwdTT+IoizDWNlKhqwM0NgYJe1FFwbj8LpREUhZLKGpxtZNvPnubu7s7s2bNZt24dJiYmeHl5GTukXiciIoKjR49y+vRpvL29jR2OZCSXMhewGrAVQpSet8wPqDk3WHSfI+cCbl9lZSU///wzU6dOvaKphPojIQSJiYmkpKQwbdo0Oa5fNxNCUFFRQVFREcXFxYa/QgicnJywsbHBysrqopupqekVJeUXttl76qdkvt6fbVivRoe50og5jaR//Twq9Iy/7c9Yq3WM9bHmo9dfAkCj0WBqasqBAwcAOa9xT8jLy2PDhg3MnDkTNzc3Y4fT62RnZ7Nnzx6uu+461Go5l0N/1hVzAeuA0guWZV55aFJvpNVq2bBhAyNGjJDJ3wUaGhrYunUrdXV1LFq0SA6C3cV0Oh2lpaUtkr2SkhLMzc1xcnLCycmJ8PBwnJycsLKy6tJS146G+cktr6OgpAbXm19uihU11UJNNWbUCzWgJqXRDSu1mgcnj+KXLz9Cp9PR0NCAVqs1HLegoABTU1M0Gg0ajYbGxkZMTDr9cSx1gpubG1OnTmXjxo3Mnj1bzlF+AR8fH1JSUjh69Cjh4eHGDkcygs6OA2gOPExT+z9XLug8IoQY1vWhScYihGDbtm04OTkRERFh7HB6ldLSUjZs2ICnpyfTp0+Xv5y7SGVlJVlZWWRlZZGfn4+NjQ3Ozs44OTnh7++Pk5NTr+h85GJtxumSmg63MzdRMz7Quc1e4ytXrqSgoIDCwkIKCwv54osvsLOzw9vbG39/f5ydnWVzgi7g5eXFpEmTWLduHXPnzpWzhlxg5MiRbNmyhdDQUDmt3gDU2Z+c7wOLgO+B3bQ+L7DUTyQmJlJVVcX8+fPll9B5iouLWbt2LdHR0QwePNjY4fRpQggKCgrIysoiOzub2tpafHx8CA8PZ+bMmUbrSNPRMD8AL65K4Zv9p6nVtj7+vYVGzZNXhaJWtf2/4+DggIODg+F9pNPpKCoqIisri61bt6LVavHz88Pf3x83Nzf55XwF/Pz8aGxsZO3atVx99dXY2NgYO6ReY9CgQVhbW5ORkUFwcLCxw5F6WGcTwIXA9UKITd0Yi9QL5OTkkJqaysKFC2Xp1nkKCwtZt24dEydOxN/f39jh9ElarZYzZ86QnZ1NdnY2FhYW+Pj4MGnSJFxdXfvMj42n54ZR3aDjl8QctDo9On1TL2CVouB926s8NjOE60ZdWscDtVrNoEGDGDRoEKNHj6a0tJTMzEz27dtHVVUVgYGBBAcHy5LByxQUFERVVRVxcXHMmzdPXsPzjBgxgr179xIUFCSvywDT2QSwBjjdnYFIxtfQ0MC2bduIiYmR7drOU1BQwPr16+WwEpdBp9Nx8uRJ0tPTycvLw9XVFV9fX0aOHNlnS2LUKoVXrx3G3RP9+XRXJomny6g0M8HeQkPcn2Nxt7vynr/NJYSRkZGUl5eTnp7Opk2bMDMzIzw8nKCgIPkD7RINHz6c06dPk5SUJKfrO4+XlxdqtZrs7Gx8fX2NHY7UgzrVC1hRlD8B4cB9orPdhvsA2Qu4pbi4OMOAqgNBUVU9aw7nUlhZj72lhquGuuNh3/LLOz8/nw0bNjB58mT54XgJampqSEtLIy0tDQcHB4YMGYK3t3efG0qoszN39MQMH0IITp8+zZEjRyguLmbw4MGEh4fLH2uXoKqqipUrVzJnzhycnZ2NHU6vcezYMTIzM+W4gP3UlfYCngFMAmYripIKaM9fKYS4+spDlIwpKyuLvLw8rr32WmOH0u3qG3U89VMyqw/nogB1jXpMTVS8tv4Yk0NceOvGEVibmZCbm8umTZuIjY2VY2V1UmFhIUeOHCE7O5uAgACuuuqqPt3wvjcNz6IoCj4+Pvj4+FBWVkZKSgo//PADwcHBREZGyvmmO8Ha2ppx48axZcsWrrnmGtnz+hx/f3/27NlDXV0d5ubmxg5H6iGdLQH8tL31Qog7uiyiHiRLAJvU1dXxww8/DIjx7HR6weL/7ichs4S6xosnRDdVKwS62vDv6wKJ27yJqVOnyoFkOyCE4OTJkxw5coSamhrCwsIYMmRIr+i1213aGi6mp8f3q62t5eDBg6SnpxMWFsbw4cP7XCmrMWzevBlzc3MmTJhg7FB6jc2bN+Pm5iaHhOmHrqgEsK8meFLnxMfH4+/v3++TP4BNafkczC5tNfkDaNAJcovK+HblGm66epZM/trRXCUZHx+PiYkJw4cPx9fXVzYk70EWFhZMmDCBYcOGceDAAVasWMHYsWNlg/4OTJw4kR9//JGAgIAB8bnXGcHBwRw6dEgmgAPIJZV/K4oSBQQCq4UQ1YqiWAH1QojGbolO6nbFxcVkZmZyww03GDuUHvHvbRnUNLQ+fAeACj0RZJFQ7sgTPj49GFnfkpeXx/79+6mvryc6OnrAJX6dGS6mJ9nY2BAbG0thYSHbtm0jIyODSZMmyfaBbTAzM2PUqFEcPHiQuXPnGjucXsHLy4tt27ZRWVnZZztoSZemU4NLKYoySFGUvTTN+/s1MOjcqjeBN7opNqmbCSHYs2cPI0eO7NfVdec7mlfZ7vpwk3zqhQkJVbZoda2XEg5k1dXVbNq0iS1btjB48GCuu+46/Pz8BlTy15u5uLiwaNEiXFxc+PHHHzl27JixQ+q1goKCKCsro7Cw0Nih9AoqlQpPT0/OnDlj7FCkHtLZ0UXfAvIBJ5qGhGn2PTCzq4OSekZWVha1tbWEhoYaO5RewVtVhouqmkONHghkQnM+IQSpqan8+OOP2NnZccMNNzB48GCZ+HWj2NjYi9oadoZarWbUqFHMmzePxMREdu3ahV4vf8xcSK1WM2zYMBITE40dSq/h5eUlE8ABpLMJ4DTgaSFE6QXLMwBZT9YH6fV69u3bx9ixYwfULAMRnnatLrdTagkzyWe/1ptG1Pg6WqJRD5zr0p7KykrWrFnD8ePHmT9/PtHR0bL3ZB/g6OjIwoULqaio4LfffqOurs7YIfU6Q4YMIS8vj7KyMmOH0iu4u7uTl5dHPxrtTWpHZ7/hLICGVpa7APJTpQ86efIkFhYWA254k/tiArA0bTmArgk6ojRnONzoTpUww0Kj5r6YQCNF2LucPn2an3/+GS8vLxYsWICDg4OxQ+oyl1vC1pq4uLheNWRMMzMzM2bPno2Liwu//PILNTUdz2M8kGg0GsLCwkhKSjJ2KL2CjY0NarWaiooKY4ci9YDOJoDbgSXnPRaKoqiBZcDmrg5K6l5CiAE7Gn5siCvjA50w1/z+1g9WF1GstyJXb4uZiYoh7jZcM3Jg9/4VQnDw4EG2bdvG9OnTGTFihKzu7aMURWHMmDEEBwfLksBWREREkJmZSW1trbFD6RVcXFwoKioydhhSD+hsPc4TwDZFUaIBM5o6foQDdoAcSKmPOXPmDEKIAVf6B6BSKXz4h1H8dXUa38RnY61qwE8pY7c+GDMTFXMi3Hjl2mGYmgzc6t/GxkY2b95MXV0dixYtkj1Je0hbYwteuPxySxojIyPRarWsXbuWuXPnyvECzzEzM8PT05Ps7GwGDx5s7HCMzs7OjvLycmOHIfWATn3LCSFSgaHAbmADYE5TB5BIIURG94UndYfExESGDx8+YEt0TNQqnl8QTvxfpnNHsI7gIeE8OX84u5dP5e2bIjHXDNw5VrVaLevWrUOj0TBv3jyZ/PUjiqIwevRonJyc2LZtm2zndR5vb2+ys7ONHUavIBPAgaPTLbmFEHnAc90Yi9QDiouLqaioIDBQtnGrKinEyaSeG25YgFo9cJO+Zs3Jn42NDTExMf3uB0J3l7BdqZ4YW1BRFCZMmMDKlSs5ceIEISEhXXbsvszHx4c9e/ag1+sHVKe41tjb25OWlmbsMKQe0OkEUFEUUyACcOWCkkMhxG9dHJfUTU6cOEFwcPCA/5BrHgNxzJgxMvkDdDoda9euxd7enkmTJvW75E/6nVqtZsqUKaxZswZ3d3c56C9NM6pYWVlRWlqKk5OTscMxKlkCOHB0KgFUFGUG8CVNyd+FBHDF36CKojgCKwA/IBO44cJhZxRF8QVW0pSAaoB/CiE+PLduFPAZTT2WfwMeFrKOowUhBOnp6XLke+DYsWNoNBr8/f2NHUqvsHv3biwsLPps8teZ0rLeNnuHMTk5OREREUF8fDxTp041dji9gqurK/n5+QM+ATQzM6OhoQEhRJ/8LJA6r7PFQO8BqwF/wJKmJKv5ZtlFsSwHNgshgmnqWby8lW1ygXFCiBHAGGC5oige59Z9APwRCD53m91FcfUbOTk5WFlZ9auhPC5XamoqI0eOlB9wwNGjR8nNzSU2NlZejwEkIiKC06dP9+khP47klLPy0BlWJZ0lr/zKeje7urpSUFDQRZH1XYqiYGJiQmOjnOG1v+tsFbA78HchRFY3xrIAiD13/3MgjqZhZgyEEOePRWjGuQRWURR3wFYIsffc4y+AhcDaboy3z2mu/h3oSktLqa2txdPT09ihGF1JSQnx8fHMnz8fjUZj7HCk83R3yaSpqSmhoaEcPnyYiRMnduu5utrek8U8vTKZs2V1qBRAgUadYIy/I69eNwx3O4tLPqa1tTWnTp3q+mD7IBMTE7RarfxM6Oc6WwK4GhjfnYEAg4QQuefu5/H7fMMtKIrirSjKYeA08KoQ4izgCZw/f82Zc8ta2/8eRVESFEVJGEhzQAohOH36NH5+fsYOxeiOHz9OUFDQgC/tEkKwa9cuRo4cib29vbHDka7A5Q5qHRERQXp6OjqdruuD6iZxxwpY8ul+MgqrqdXqqG7QUV2vo75Rz66MYua9u5Pc8ksf00+j0aDVarsh4r5HlgAODJ0tAbwP+N+5dnZHgBb/JUKILzpzEEVRNgFurax6+oLjCUVRWm2/J4Q4DQw7V/X7s6IoP3Tm3Oft/xHwEUBUVNSAaSNYUlKCmZkZ1tbWxg7FqJrbQc6ZM8fYoRhdZmYm9fX1fXIu6K7o0TsQ2/5dyNLSEnt7e/Lz8/Hw8Oh4ByOrb9Tx0NeHqNO2PrexTi8oq2ng6Z+O8N87oi/p2DLp+Z2JiUmf+lEgXZ7OJoCzaJoP+CqghqaOH80E0KkEUAgxva11iqLkK4riLoTIPVel225jDCHEWUVRjgCTgF3A+VM3eAE5nYlpoDhz5oys8gTOnj2Lubk5jo6Oxg7FqIQQ7Nu3j0mTJg2IHuHhz62jur7zX2hWZmpSXhgYzYjd3Nz6TAK47kge+g769ukE7MwooqCiDldb804fW6PRyATwnIaGBjnf9wDQ2Vf4deBfwPNCiOpuiuVXYDHwyrm/v1y4gaIoXkCxEKJWURQHYCLw1rmksUJRlLHAPuB24J/dFGefdPbsWYYMGWLsMIxOjn3WJCcnxzADQl90qT16LyX5u5zt+zInJ6c+Mwhy3LFCqhs6fm1M1SoOZJUyZ6h7p4/d3O5NakoA5Uwx/V9nE0B74MNuTP6gKfH7TlGUu4As4AYARVGigPuEEHcDocAb56qHFeB1IUTyuf0f4PdhYNYiO4AYCCHIy8uTwz0Aubm5REZGGjsMo5Mdgvq2rhzU2tTUtM+UfGl1rVf9tuaJO67lVWvTTlf1yzaATYQQNDY2ygRwAOhsAvgjMB3otmnfhBDFNFUzX7g8Abj73P2NwLA29k+gaaBq6QKVlZWYmZlhZmZm7FCMSqvVUltbi62trbFDMarGxkaysrIYO3assUOReoG+VPI13MueTWn5bbYBbNao12Nn2jQ8bZ1Wx5ajBeSW12FjZsKUIa642Fz8WajVamW1J79fh4HeSW4g6Oy7/STwN0VRJgOHubgTyJtdHZjUdcrKymQvT6C8vBxbW9t++8HW2YGNS0pKsLW1xcLi0ofKkHqHrh7Uuq+MmX/dKC9e33Csw+38na2oNVWTU1bLyJc2oiigbRSYqBWe+eUI00MH8ep1w7A2+/0rUH5ONqmursbSsquG95V6s84mgHcClTQNBXPhcDACkAlgL1ZaWioHf6bpOsgP+J75ouvpWTZkj97L1/zDqC9wsDLlwSlBvB+XQa229baAFho1f10YwTX/qaawsh7X89oMNt/dmJpH+vtV/Lx0AhbnSgplAthEXoeBo1MJoBBCzpfVh5WVleHq2tosfgOL/GBrIhNh6XxlZWV96gfig1ODUBT455Z0VArUnqsOLvz2SRQUQgZZc98mheyUBADyvm45qZTbLa/QoBNkFVfz6a5TPDAlCJA/lJvJz8mBo/+P/yBRWVnZZ37hd6e+9kXXXYzZwPtyByyWuk9hYWGf+r9QFIUHpwaz/6np/HnWEK6J9OTGaG8CXawZ5euArYWG3E5MC1fXqOeTnafQ65uqv+UPoybyOgwcbZYAKoryLvCkEKL63P02CSH+1OWRSV1GdulvUlNTg5WVlbHD6DKX2xNUDnjb93RUpX65VeCVlZWUl5f3iTEAL2RnqeHOib9XTr167W7D/bF/30zRh48ATSV+bamqb6Soqh5XW3P5A/GcsrIyIiJkf8qBoL0q4KGA5rz7bekbrYcHMJkANlGr1XJ0e7qn12dnk1Gpd0lPTycgIAC1Wm3sULqU6OTXkqKAXkBFRQVCiAHf+aGhoYHy8nKcnJyMHYrUA9pMAIUQU1q7L/U9MgFs0t/G+brcnqBWVlacPXu2e4LqIT3dyaQ/0ul0HDt2jClT+t/H+1BPO5I6sZ2pWoWztSlJiSkEBgb22xECOis3NxdXV9d+94NAap0c9GgAkAlgE1n12cTV1ZXExMQuPWZbyeiFrmTAYqlrpaamYmdnx6BBg4wdSpe7Z3Ig36gUdPq2SwJNTVTcNs4XtUohPT29XybCl0pOGTqwdJgAKopiATwBXAsE0FTlexL4HnhDCFHbrRFKVyQ2Npbc3FzuuOMOY4didP2tBPByOTg40NjYSHl5OXZ2dsYOp0dYmakveS5gY+rKmT5aU1tby6FDh7j66qsva//eLtrPgdte+pS44wWtDhptolJwtjLlnkmBFBQ0TTvv4uLS02H2OmfPnpXNNgaQdhNARVFMgC3ASGAdsIamKdjCgGeBOYqixAghZLFKL6YoClqtdsAX68sSwCaKouDv78+xY8cYPXp0t56rqwcsvlwpL8zu0fP1ZkII9u7dS1BQUL/t7akoCv+6JZJnf0nhx4NnUGjq9atWgUalItzTjg//MAo7Sw3JB5umRRzo1b+VlZXU1tbi7Oxs7FCkHtJRCeA9QBAwUgiRcv4KRVEigK3AH4EPuic8qSsoiiITH5rmPK2r63h4iL7qUpKqoUOHsnLlSkaMGNEnmgd0d4lYb9OdiXNaWhrFxcUsWLDgio/Vm5moVfz9mqE8NjOEVUlnOVNai62FhjkRbgQPsgGa2kGePHmSRYsWGTla40tPT8ff33/AJ8IDSUcJ4HXA3y5M/gCEEEcURXkZuB6ZAPZqKpVKVn0Czs7OpKWlGTuMXsHW1hZvb29SU1MZMWJElx+/vyRi/U1+fj4HDhzg6quvRqPRdLxDP+BkbcaSCa3PZZCRkYGDgwM2NjY9HFXvIoTgxIkTxMTEGDsUqQd1lACGA4+0s34TsLyd9VIPa6ukZO7cuS1KegbiF7Srqyvbtm1DCCF/5QKRkZGsWrWKwMDAXv8F2FuqkvuysrIyNm3aRExMzIBp+9kerVZLfHw806dPN3YoRldUVIQQQs4YNcB0NBOIA1DYzvpCwL7LopG6jRz/DiwtLTE1NaWsrMzYofQKDg4ODB8+nK1btyJEzwznGRcX1yNJm5xxpKXS0lLWrFlDdHQ0Pj4+xg6nV0hKSsLd3b1f9oK+VMePHycoKEj+MB5gOioBVAPtNR7Tn9tG6iVaKymprKzk/fffZ9SoUcYJqhfx9PTkzJkzcsT/c4YNG0Z2djaJiYlERkYaO5wBqTOlmVeSNBcXF7N27VrGjBlDcHDwZR+nP6mqqiIlJYVrr73W2KEYXUNDA+np6VxzzTXGDkXqYR0lgArwlaIo9W2sN+vieKRuYGJiQnl5ubHD6BV8fHxISUlh6ND2JrcZOBRFYcqUKfzyyy9YW1vLBKGfyc7OZtu2bYwfP57AwEBjh9Nr7Nu3j4iICKytrY0ditGlpqbi4+PT65uBSF2vowTw804c44uuCETqPjIB/J2npydbt26lvr4eMzP5+wXA2tqaq666ijVr1mBiYoK/f+sN5nsT2favfUIIDh48yNGjR5kxYwZubm7GDqnXyM/PJy8vj8mTJxs7FKPT6XQcOXKEq666ytihSEbQbgIohJCjB/cDJiYmlJWVodfrUak6avbZv2k0Gvz9/UlJSWHkyJHGDqfXcHBwYPbs2axduxagTySB5xtow8S0p76+nq1bt9LQ0MCiRYsG/Py252tsbGTnzp2MHj16wPSCbs/x48dxdnbG0dHR2KFIRiCngutGdVodhZX1mGlUuFibGaWBbfMX3g8//EBxcbEc7R4YMWIEq1atYujQofJL4DzOzs7Mnj2bDRs2UFJSwsiRI2Wj8G7QnclqVlYWO3fuJCAggDFjxgz4H3znE0KwY8cOHBwcCAoKMnY4RqfT6UhKSpKdpQYwmQB2g+ziGt7dcoLVSWdRFAWdELjZmnN/bCA3RnmjUvX8l6qbmxtnz56VCSBgb2+Pm5sbR48elW0BL+Di4sKiRYvYuHEjJSUlxMbG9okkeaAPE1NTU8OePXsoLCxk6tSpuLu7GzukXic1NZWSkhIWLFggf9gAKSkp2NnZyeYBA5hMALvYkZxybvxoD3UNOnTnjayRXVLDi6tS2ZJWwIe3jULdw0mgp6cnaWlpDB8+vEfP21uNGDGCjRs3EhYW1uumyDN28mJpacm8efPYuXMnP/30E5MnT5YJRRfqymRVp9ORmppKYmIiISEhxMTEYGIiP9YvlJeXx8GDB1mwYIG8PjTNBZ2YmNhv54KWOkfWD3Sh+kYdt32yj+r6lslfs1qtjp3phfxnx8kej83Dw4P8/Hw5Jdw5Li4u2NnZkZ6ebuxQeiW1Wk1MTAxjxoxhy5Yt7Ny5U84m04sIITh+/DjfffcdOTk5zJ07lzFjxsjkphXV1dVs3ryZ2NhYbG1tjR1Or5CQkNCv54KWOkd+WnShdUfyaGjUt7tNrVbPR9tP8sdJAT1aCmhmZoarqytp6Sc5UKxhRfxpKuoacbEx4/Zxvlw11B1zTe8qCetuI0aMYOfOnQQFBfW6UsDews/PD3d3d/bu3cv333/PmDFjCAgI6DNVaMYuTe1qQgiysrKIj4/H1NSUKVOmyCq8duh0OjZt2kRoaCje3t7GDqdXKC4uJjMzkxtuuMHYoUhGJhPALvTTwRyqGzqecaO+UUfK2XKGedl3f1DnUezceOXbrRzU+VKrbYozp6yW4/mVvLL2KN/dOw4/Z6sejcmYPDw8cHJyYv/+/YwbN87Y4fRaZmZmxMTEcPbsWfbv309iYiLR0dF4e3v32kSwOeHrLw3cGxoaOH78OCkpKWg0GkaPHo2Pj0+vvf69gV6vJy4uDnNzcznI+Tl6vZ4dO3YQFRUlh8GSZALYlSrqOldFplIUqup7tir2dEkNyzfkMZ4qdNp6zn/paxp01Gp1XP/hHrb+ORZrs4HxtlAUhUmTJvHDDz/g7e2Nl5eXUeLoK0OYeHh4sGDBArKysti3bx+HDh1i1KhReHp6ykTkCrT3upaVlZGSkkJ6ejpeXl7Exsbi6uoqr3cH9Ho9mzdvprGxkRkzZsjrdU5SUhIajYYhQ4YYOxSpFxgY3/Q9xMfRksTTZXQ0rapWp8fdzqJngjrn39szqGlUKFBZ46GuIFPXctwnIaCqvpEfD5xh8Xi/Ho3NmMzMzIiNjSUuLo5rr70Wc3NzY4fUqymKgp+fH76+vqSnp7N37170ej3h4eGEhIT0iR7DvZ0QgjNnznDkyBGKiooYMmQI1113HVZWA6d0/krodDo2b96MXq9n5syZsnnHOcXFxRw5coRFixbJhFgCZALYpW4f58vG1HxqOqgG9neywr8Hq1r1esGPB3Jo1AtOY0+ouoBMnQNNM/39rlar47PdpwZUAghNPaQDAgLYsWMH06dP7/EPx744hImiKAQHBxMUFEReXh5HjhwxNCx/4okn0Gg0Rom/r5SmXqixsZGcnBwyMzPJzs7GysqK8PBwmcBcgur6Rr7bn8mObXFU1TeSJLwZk5PAfTGBjA9yNnZ4RqXT6YiLi2P06NFy+jvJQCaAXWikjwODB9lw5Gw52ta6AQPmGhXL5vRs8XtVQyON+qbOKYV6K8LVAhelmkJx8QdBQUVb0z73b6NHj2blypUcP36cwYMHGzucPkNRFNzd3XF3d6eqqoq0tDRKS0tRFIWDBw/i7++Pvb29LHFoRXV1NdnZ2WRlZZGbm4uLiwu+vr5ERkbK3qqXqKCijmve24lvXTr1OoUDjV4IYPuJIuIzS7k+yosXrg4fsO/DhIQErKysCAkJMXYoUi8iE8AupCgKn905mlv+s5dTRdUtSgI1agWVovD8/HBiB7v2aFwWGjV6Q+dkhXSdE8EmRRRqL04AB1pP4GZqtZqpU6eyevVqHBwccHXt2deoP7C2tiY6OhpXV1caGhqora3lt99+M8wv7Ofnh4uLS7d+Cffm0lQhBCUlJWRlZZGVlUVFRQVeXl4EBQUxZcoU2Sj/MgkhuP3j3XjXnqBWr+JQoyfivNqNWq2O7xPOEOxqw23jfI0YqXFkZGRw8uRJFi5cOGATYKl1MgHsYnYWGn59cCJbjxbw8c6TZBbVYGqiYlb4IG4f54e3Y8/Py6lRqxjt78iek8UA5OjtGGxSiINSQ6n4PR4TlcLcYQN3wF9HR0diYmJYv349V111FU5OTsYOqc8yNTVlwoQJjB8/nqKiIk6dOkVcXBxarRZXV1dcXV1xcXHBxcWl37Yb1Gq1lJSUUFRURFFRETk5OahUKnx9fRkzZgxubm5yqrYusO1INh7lqRTrzTjc6N4i+WtWq9Xx7uYT3DrGxygzMRlLcXExu3btYu7cuVhY9Gy7c6n3kwlgN1CrFKaHDWJ62CBjh2KwdEoQiafLqNXqEChkNDaVAu7X+hi2MVEr3DHB34hRGp+vry/jx49n7dq1zJs3zygDpfaG0qpLcSnt7srLyykoKKCwsJDMzEyKi4uxsbExJIOurq44Ojr2uXZvtbW1FBcXU1RUZPhbXV2Ng4MDTk5OODs7M2zYsAFXHV5eoyXueAFV9Y2425kzKdgFjbrrkt7s7Gw2rV/DqUY7TrXSrvl8NQ2NJJ0pI9LHocvO35vV1dWxYcMGJkyYIH/MSq2SCeAAMTHYmT9O8uc/O05Rq9WRrbcn0KQYJ6WaYmGFuUbF3xcN7dHOKV2tq6r7AgMDaWxs5LfffmP+/PnY2NhceXASAHZ2dtjZ2REcHAw0DddRUlJCYWEhBQUFpKWlUVFRYaiGd3BwwMrKCktLS6ysrLCwsDBaAiWEoKamhurqaqqqqiguLjbcGhsbcXR0xNnZGR8fHyIjI7G3tx+wJXw1DY088/MRVh/OxUStoNcL1KqmZjAPTw/hzgl+V/Q6CiE4ePAgR48eJccqiFNFHQ/BpVIplFQ3XPY5+xK9Xs+mTZsICAggMDDQ2OFIvZRMAAeQ/5s5mAhPO97dfILj+VWcxJ3hmnzqvKJ4dOZgov0cOz7IADF48GAaGxtZs2YN8+fPl0NwtONK2t2pVCqcnZ1xdnYmNDQUaKo6LS4upqCggKKiIrKzsw2JV319Pebm5oak8Pxbc4KoUqkMycXKlSsBKC0tBTAsvzD5qK+vp76+nrq6Ourq6gz3a2trqa6uprq6mtraWszMzLC2tsbKygpHR0cGDx6Ms7Mz1tbWA6pkrz11Wh03/HsPJ/KrqG/Uc+GQp6+vP0Z+RR1PXRV6Wcevr69n69atNDQ0sGjRIhJWHUfJyqGD0bfQ6wUOVqaXdc6+Zu/evajVakaPHm3sUKReTCaAA8zMcDdmhrtRWFlPRW0DSbu3MjjYlnCZ/F0kPDwcrVbLb7/9xlVXXdXnksDe1AHiUmg0Gtzc3Fqd4kyv11NbW2tICJv/FhQUUFNTQ21tLXq9HnHeYJyduW9mZoaZmRnm5uaGvw4ODnh4eGBlZWVIOAdqid6l+Gx3JukFTclfa2q1Or7Yk8miSE9C3S+tt3NxcTEbN27Ex8eHsWPHolKpuD7Ki/UpeR0Ov2VhqmZED8++ZAzHjx/n9OnTstOH1CGZAA5QLjZmuNiY4TB5ImvWrCEwMFAOgtyKESNGAPDzzz8zY8YM2TvYyFQqlSEhc3FxMXY40gX0esEnO05Rp21/TnStTvDxjpO8ccOITh1XCMHRo0eJj49n3LhxhiYEAOMCnPCwM+dUcQ06fevlgBYaNQ9OCeqWDiB6veg1HUuaZ+mZN2+e7FUudUgmgAOco6MjgYGB7NmzhylTphg7nEvSU4P+jhgxAgcHB9avX8/YsWNbfPlIkvS7oqr6Tk2JqdML9mQUd+qYlZWVbNu2Da1Wy/z583FwaNmJQ1EUvrp7LNe8v4uSmoaLkk8LjZprRnp26QD3abkVfLgtg3VH8qhv1GNtZsJ1o7y4e5I/Xg49P9IDwKlTp9i5cyezZ8++6BpJUmtkAigRHR3NTz/9REZGhmww3AZfX1/mzZvH+vXrKS4uZsyYMbJ6pQ19rcq5L+nt1fo6Iejsv0UbhXUGQgjS0tJISEhg2LBhDBs2rM0qeDc7c9Y/OpkV8af5ZOcp8irqUCsKo/0duTcmkMnBzl32//rjgTM8/XMy2kaB7lwzgqr6Rv63L4vvEk7z6ZJoxgT0bK/bjIwMdu/ezZw5c3B2Htiznkidp4iOJq7tx6KiokRCQoKxw+gVCgsLWbduHddcc02fa+vWrCe+HOvr69m0aRMqlYqpU6f2qmqWtkpEY2JiWizvrcmD1LHengBqdXoiX9xI1YU9Py6gAFMGu/LfO6JbXV9aWsqOHTvQ6/XExMRccomWEKJbfqAdPlPGDf/e024Vt5WZmq2Px+Jq0zNNaprn5J4zZ44c7kVqlaIoB4QQURculy2aJQBcXFyIiIhg69atDOQfBR0xMzNjzpw52NnZ8fPPPxt6l0qXR6cXbEzN54kfknjo64P8a8sJCirqjB2WdJk0ahW3jPZBo24/+bIwVfPHyQEXLW9sbCQ+Pp5Vq1YRGBjIggULLqs6s7tK5/+1Nb3Nzi3NGnWCb/Zld8v5L3T8+HH27dvH3LlzZfInXTJZBSwZDB8+nOzsbJKSkgydH6SLqVQqxo8fz7Fjx1i1ahVDhw5l+PDhRu8h2punQWtN0uky7vo8ntoGHdXnenBuSM3n3S3p3Dzam2fnhaPuJY3rpc67LzaQnxNzKK5uaLVThrlGxdgAJ8YG/D7ygBCC7Oxs9uzZg7OzM9dee22vq4nQ6vRsSSugo9/H9Y16vo0/zcPTu3fe3WPHjpGQkMDcuXONMmC91PfJBFAyUKlUTJs2jZ9//hlHR0d8fHw63mkAGzx4MB4eHuzYsYOTJ08SExMj29900vH8Sm7+z96Lhu5oLl35Lv4MjTrB3xYNNUZ4vUZPdXTqSo5Wpvzy4ATu+iyBU0XV1Dfq0AswNVGhAFcNdeeVa4YZSulyc3PZv38/Wq2WCRMm4O3tbdwn0Iaaeh2d/T3SmY4wVyItLY1Dhw4xb9487OzsuvVcUv8lE0CpBWtra2bMmMGGDRuYN29en+pNZowvQRsbG+bMmcOJEydYu3YtgwcPZtSoUX1uKrOe9tfVqdS2M25brVbHDwfOcM/kAHydeldJkNQxdzsLfnt4EslnylmTnEt5rRYfRwsWRXrhZtfUNq64uJj9+/dTVlZGVFQUQUFBvbpjlZWZusPBppvZW3TfgNMpKSkcPnyYefPmYWt7aeMoStL5ZAIoXWTQoEGMHj2aDRs2sHDhwl7V0aE3UhSFkJAQvLy82LVrFz/++COTJ09udSBjCQoq6th3qqTjmRuE4Is9WTwzL6xH4uqN+lq1/oWGetkx1KtlCVVFRQUJCQnk5OQQGRnJzJkz+8QPJhO1ihmhg1iXktduD2YzExU3j+76UkwhBIcPHyY1NZV58+bJKSqlKyYTQKlVgwcPpqSkhE2bNjF79uw+8QFtbJaWlsyYMYNTp06xadMm/P39GTVqlNEG2O6tSUJ6YRWmJqoOG9NrdYKk02U9E9Rl6msJmTHV1NRw6NAh0tPTiYiIYNKkSWg0GmOHdUmWTg1iy7GCdnsBa9Qqbh7dtc1ntFotO3bsoLS0lPnz52Ntbd2lx5cGJtkLWGrT2LFjMTU1ZfPmzej17X9ZS7/z9/fn+uuvRwjBihUrOHDgAA0NA2MS+s7QqDv/sXMp216u2NjYi9rUSV2nsrKSvXv38v3336NSqbjhhhsYNWpUn0v+AMI97Hj9uuFYaFRc+NY0NVFhbWbCF3eNxsm662pNysvL+eWXX1AUhQULFsjkT+oyMgGU2qQoClOnTkWv17NlyxaZBF4CMzMzJk6cyKJFi6ioqGDFihUcPnyYxsb2x0cbCMLcbWnUddyaykKjZlqonHqvr8rPz2fTpk389NNPCCG49tprGTduHBYWFsYO7YrMG+7BqocmcUOUD9ZmJqhVCo6WGu6e6M/mx2IY6dN17aazs7P59ddfCQ0NJTY2FhMTWWkndR35bpLaVKfVEXeskCK7ECrSD6DbvJWZ06f26obavY2trS1TpkyhpKSE+Ph4kpOTGTlyJIMHDzb6sDHGYmVmwsJIT344cBptO4mgEILro3pnj1Bj6e1VzXq9nszMTJKTk6mpqSEiIoLJkydjatp9nSKMIcjVmpevGcrL13RPL3UhBAcPHuTo0aPMnDmTQYMGdct5pIGtVySAiqI4AisAPyATuEEIUXrBNr7ASppKLTXAP4UQH55bFwe4A7XnNp8phCjoidj7I71e8ObGY/x3VyYqBRr1Ao3KmuHpx9h7qoQn77wGUxPZJvBSODo6MmvWLAoKCti/fz+HDx8mKiqKgICAAZlQL58zhJ3pheSV17WaBJprVLx6zTDsLHpXNWFfHJalJzQ0NHD06FFSUlKwtLRk2LBh+Pn5Dcj39pWqr69ny5YtaLVaFi1ahKWlceYWlvq/XjEVnKIo/wBKhBCvKIqyHHAQQiy7YBtTmuKtVxTFGjgCjBdCnD2XAD4uhLiked3kVHAXE0Lwp28PsSm1gFpty2E61OiYYHYaO3tH3vrTjZj0QPus/ionJ4f4+Hjq6+sJCwtj8ODB/a6UpCPlNVqe/jmZjan5aNQqhBAIwNnajOevDmPqkO4p9biSKfPkdHstlZWVkZaWxvHjx/Hy8mLo0KG4uspq+8tVXFzMxo0b8fHxYezYsQO2lkDqWm1NBdcrSgCBBUDsufufA3FAiwRQCHF+K3ozZPvFbrHteCGb0y5O/gB0qNld783EstN8unI9d187W/7Cv0yenp54eHiQn59PSkoKBw8eJDAwkPDw8D419uKVsLPU8K9bRlJa3cC+U8XUN+rxc7JimJddr31f9fVhWbpCXV0dGRkZHD9+nOrqaoKDg7n22mtl54QrdOLECfbs2cP48eMJCgoydjjSANBbEsBBQojcc/fzgFZ/+iuK4g2sAYKAPwshzp63+lNFUXTAj8BfRRtFm4qi3APcA8iZLlrx720nL5qd4XyNqNlV743V8Ww2bdpEbGxsn+zN1xsoioKbmxtubm5UV1eTlpbG6tWrcXR0JCIiAh8fn16bCHUlBytTZke499j5ZBJ36XQ6HdnZ2Zw4cYKzZ8/i7e1NVFQUnp6espTqCul0Ovbt20d2djbz5s3D0dGx450kqQv0WAKoKMomoLWRcZ8+/4EQQiiK0mryJoQ4DQxTFMUD+FlRlB+EEPnArUKIHEVRbGhKAG8DvmjjGB8BH0FTFfBlP6F+KrET465pUbOuwoPrNab88ssvzJo1Sw5KeoWsrKyIiooiMjKSkydPcujQIXbv3k1YWBhDhgyRg3FLPU4IQWFhISdOnCAjIwMHBwdCQkKIjY0dcM0VuktRURFxcXHY2NiwaNEi+X8u9ageSwCFENPbWqcoSr6iKO5CiFxFUdyBdjtwnGv3dwSYBPwghMg5t7xSUZSvgdG0kQBK7dN3sk2oXlExYeJEjh1N4+eff2batGl4eHh0c3T9n1qtJjg4mODgYAoKCkhJSeGbb77B09OToKAgfHx85KDcUrcRQlBaWkpmZibp6ekIIQgODmbRokXyR14X0ul0hl6+Y8eO7fXT4En9U2+pAv4VWAy8cu7vLxduoCiKF1AshKhVFMUBmAi8pSiKCWAvhChSFEUDzAM29Vzo/UugizWpuRUdbudhZ4HGRE1ERAQODg5s3ryZkSNHEhYWJj/Iuoirqyuurq7U19dz6tQpjhw5wvbt2/Hz8yM4OBh3d3d5rY2sP1Qb63Q68vLyyMrKIisrC2hqHhMTE4Orq6t8j3WxwsJCtm3bho2NDddee63s5SsZTW/pBewEfAf4AFk0DQNToihKFHCfEOJuRVFmAG8AAlCAfwkhPlIUxQrYTtPQMGqakr//E0K03ZDtHNkL+GK/JObw5E/J7bYDNNeoWD57CEsm+BuWVVRUsH79+v9v797jo67u/I+/PslM7snkficXIKACAQmCgmiLBaqu1x/WR3+IttvqVgu225+tYv3Z9dLitdWtdq2XRdqf7rbrz6Ur2lIFWZQV5U5UJCSBxAwJJIFcyG0mM2f/mMlsCBMSIMlMMp/n4/F9zMz3Mt8zOQx553zPOV8yMzOZO3eutlINk7a2NsrLy6moqKCtrY2CggLGjx9PVlaW9sVSg9bV1UV1dTVVVVXY7XZsNhv5+fnk5+eTlJSkoW8Y9G71u+SSS5gwYYL+nNWI6G8UcFAEwEDRAHgqp8vNkn/6L/bVteLwc69Wa7iQlxzDuhXziY44OeQ5nU42btxIV1cXCxcuHPUz/ge7lpYWKisrOXjwIK2trRQUFDBu3Diys7O1L5E6iTGGlpYWXytfQ0MD2dnZ5Ofnk5eXp61Qw8xut/Phhx+SnJzMvHnz9OetRpQGQD80APrX1tXNitd3saWiAbcxOF2G8DCwhoUxPS+R395SQmKM/07gxhh27NjBgQMHWLRoESkpKSNc+tDU2trKwYMHqamp4ciRIyQnJ5OTk0Nubi7p6enaOhhijDE0NzdTW1vrW8BzaTcvL4+cnBy9rdgI6OjoYOvWrdTW1jJv3jzy8/MDXSQVgjQA+qEB8PSqGttYu+swdS2dpMVFcO2MbCamD64jeGVlJVu2bGH27NlMmjRJL3WMoJ4+XTU1NdTU1NDa2kpWVha5ubnk5uaSkJCg9THGGGM4duwYdXV1HD58mLq6OiwWC5mZmWRlZZGVlaX1PoKMMezfv59t27ZRVFRESUmJTpelAkYDoB8aAIdXY2MjmzZtIiYmhvnz5+tEsQHS0dGB3W6npqYGu91OWFgYOTk5ZGRkkJ6eTmJiogaDUcblcnHs2DFf615dXR1RUVFkZmaSnZ1NZmamjtoNkMbGRrZs2YLb7Wb+/Pl6FUQFnAZAPzQADj+3282ePXsoLS2lpKRERwkHmDGGpqYm7HY7R48epb6+nvb2dlJTU0lLSyM9PZ20tDTi4uK0noJEV1cXjY2NNDY20tDQQGNjI83NzdhsNl8LX2ZmJrGxsYEuakhraWlh+/bt2O12SkpKOP/88/U7pIKCBkA/NACOnOPHj7N582ZEhMsvvxybzRboIimvrq4u6uvrqa+v94VCYwypqam+QJiamkp0dLT+QhtGxhja29t9Ia8n8HV2dpKcnExKSgqpqamkpKSQnJysI+2DRHt7O7t27aK8vJypU6dSXFysl3tVUNEA6IcGwJFljPHd97a4uJji4mIdnBCEeoJITxisr6+nsbERt9tNYmIiNpvtlEcNI4PX1dVFS0vLSUtzczPNzc0ApKSknBT2bLbgvTdyKHM4HOzZs4fPP/+cSZMmMWPGDJ35QAUlDYB+aAAMjNbWVjZv3ozD4eCyyy7TPjKjRGdnJ83NzTQ1NfmW5uZmWltbiYmJ8QXCxMREEhISiI2NJSYmhoiIiJAKMMYYOjs7Twl4Pc9dLhcJCQm+xWaz+R5jYmJC6mc1GrlcLj777DP27NnDuHHjKCkp0f6WKqhpAPRDA2DgGGMoKyvjk08+4bzzzmPmzJnaijRKud1uWltbfYGwqamJlpYW2tvbaW9vx+Vy+cJgTEzMSc97v7ZarUEbfowxOBwOOjs76ezspKOjw7f0fM6epaOjA4vF0m/Ii4qKCtrPqfrndrspKytjx44dpKamMnv2bJKSkgJdLKUGpAHQDw2AgdfW1saWLVtobm5m/vz5ZGZmBrpIaog5nc6TAlJbW5vf593d3VitVr9LRESE3+eAL0z1DlX9rTPG0N3d7VucTudpH3ued3Z2Eh4eTnR0NNHR0URFRREVFUV0dPQpgTYmJkb/mBlDjDEcOnSIbdu2ER0dzezZs8nIyAh0sZQaNA2AfmgADA7GGCorK/n4449JTk7moosu0svCIcjtduN0Ok9ZHA6H3+dOp5Pe/3/1PB9oncViwWq1nvR4unVWq5WoqCgNdSHGGMPhw4fZtm0bLpeL2bNnk5ubq623atTpLwDqVPAq4ESECRMmUFBQwL59+3jnnXfIzs5m1qxZOlo4hISFhREZGam3sVMB5XK5qKyspLS0FKfTSUlJid63V41JGgBV0AgPD2fq1KlMnjyZTz/9lD/96U8UFhYyc+ZMneNMKTWsurq6+Pzzz/n888+x2WyUlJSQl5enwU+NWXoJWC8BB62uri52797NF198weTJk5kxYwZRUVFn9V5HWjrZUXUcp8vNpIx4zs9KGOLSKqVGo+bmZkpLS6moqCAvL4/i4mLtgqLGFO0D6IcGwNGhra2NXbt2UVlZyZQpU85ootW65k5WvrmXLRWNRISHYTC43Ia85Bh+fsM0LipIHubSK6WCjTGG2tpa9u7dS319Peeddx5TpkwhJiYm0EVTashpAPRDA+Do0tLSwo4dO6ipqWH69OlMmTLltB3z65o7ufofP6Cp3YHLzz/zKGsYL906i/lFacNYaqVUsHC5XFRUVFBaWorL5WLatGkUFRVhsWhvKDV2aQD0QwPg6HTs2DG2bdtGQ0MD06ZNY/LkyX4HDnx79SdsLqv3G/56JERZ2P7AQiIsekcSpcaqzs5OX/++pKQkiouLdUSvChk6CliNGcnJySxevJj6+npKS0vZtWsX48ePZ8qUKSQney7pHmnpZEtF42nDH4DLbVj/WR3XTM8egZIrpUaKMYa6ujrKyso4dOgQBQUFXHXVVb7/I5QKdRoA1aiVlpbGggULaG9v900fY7PZmDp1Kp+3RhARHoaj233a92hzuNi0/6gGQKXGiJaWFg4cOEBZWRkWi4WioiK+8Y1v6H16xyi3201NTQ1tbW2BLkrAWa1W0tPTSUgY3CBHDYBq1IuJiaGkpIQZM2Zw6NAh9u7dS2VtI/lYOUACjgH+mTsGaiZUSgW1rq4uKisrKSsro6WlhQkTJrBw4UJSUlL0Mu8Y19DQgIgwefJkwsJCtyuPMYaOjg7sdjvAoEKgBkA1ZoSHhzNhwgQmTJjAx/sOseVf3mNBRAW17ngOupJpMadOIRNlDWN6rk42rdRo09PyU1ZWRk1NDTk5OcyYMYNx48aFdBAINU1NTRQUFIR8nYsIMTEx5OTkcPjwYQ2AKnTNOb+A1qQi9h5pIi+8idnWL+kwVg66kqh1J2DwtAoYA0tKcgNcWqXUYDU2NlJWVkZ5eTkJCQkUFRUxf/58vYNMiHK5XIOeFiwUREdH43Q6B7WvBkA1Zj16wzSWvfIx5c5UKlwpZIa1Uhh+jCmWI3zpSqQhLIlbvzKFxJiIQBdVKXUa7e3tlJeXc+DAARwOBxMnTuTaa6/VW0UqAL3M38uZ/Cw0AKox66KCZF66dRZ3vbYTt9tQ60ig1p1AqtVBdngTN6QeJafJxZ497UycOFFvN6dUEGltbaWqqoqqqioaGhooKChg7ty5ZGZm6i98pYaABkA1ps0vSmPHAwtZ/1kdm/YfxekyFOfaWFKSiy3ayuHDhykvL+eNN94gJSWFiRMnUlhYqJeTlBphxhiOHj1KVVUV1dXVdHR0kJeXxwUXXMC4ceN0smalhph+o9SYF2EJ45rp2X6nesnJySEnJ4dLL72U6upqDhw4wNatW8nKyqKwsJD8/HwNg0oNE6fTid1u94W+qKgo8vPzmT9/Punp6drSp0ZMQUEBy5cv55577gl0UUaMBkCl8IwgLiwspLCwEIfDQVVVFZWVlWzZsoXMzEzGjx9PQUGBhkGlzlFbW5vv0m5dXR3p6enk5eVx4YUXDnr+MqXO1JEjR/jFL37BunXrqKmpITU1leLiYlasWMFVV10V6OIFhAZApfqIiIigqKiIoqIiHA4H1dXVVFZW8tFHH5GRkUFhYSG5ubnExcUFuqhqmBhjqKhv40RXN5kJUWTaTp1CSA2OMYbGxkZf6GttbWXcuHFMmjSJK664gogIHYSlhtehQ4eYN28e8fHxrFq1iunTp+N2u9mwYQPf+973qK6uDnQRA0IDoFKnERERwcSJE5k4cSJOp5Pq6moOHTrEJ598QlRUFDk5OeTm5pKdna1TEYwBxhhe21rN85vKaWp3YgkXHN1uLshO4N6vn8fF41MCXcRRobW1ldraWmpra6mpqcFisZCfn88ll1xCRkZGyM/ZpkbWXXfdBcD27dtP+sP9/PPP55ZbbvF7zC9/+UteffVVKioqSExM5Morr+Spp54iMTERgObmZpYvX8769etpaWkhOzubu+++mx/+8IcA/Pa3v+Xpp5+murqauLg4SkpKePvtt319WVevXs2TTz5JZWUleXl53HnnnfzgBz/wfTcGOn4oaABUapCsVqtvomljDA0NDdjtdkpLS9m4cSMpKSnk5uaSm5tLWlqa9l8aZYwx/P0fdrP+syN0OF2eld7ptHZVN/Gt1Z+w6oZp3DBT543szRhDS0uLL/DV1tbicrnIysoiKyuL6dOn+35pKjXSjh07xl/+8hceffRRv1dt+vu3GRYWxjPPPMP48eOpqqpixYoVrFixgt///vcAPPDAA5SWlrJu3ToyMjI4ePAg9fX1gCdofv/732fNmjVceumlNDU1sXHjRt97v/TSSzz44IP8+te/pqSkhE8//ZTbb78dq9XK8uXLBzx+qGgAVOosiAhpaWmkpaUxY8YMnE4ndXV11NTUsHnzZtra2sjOzvYFwvj4+EAXWQ1g7W77yeGvj06nm5X/Xsqc8SlkJ4bufWWNMRw/ftwX9urq6ggLCyMrK4vMzEwuvPBCbDab/gGkgkJ5eTnGGM4///wzOq6nJQ88A0SeeOIJrrvuOtasWUNYWBhVVVXMnDmT2bNnA5Cfn+/bv7q6mtjYWK699lri4+PJz89n+vTpvu2PPPIITzzxBEuWLAGgsLCQ++67j9/85jcsX758wOOHigZApYaA1Wpl3LhxjBs3DvB0dLfb7djtdrZv347VaiU3N5ecnByys7N1MEkQem5jeb/hr4fbDb//qIp7rzxvhEoVeD19+HoHvoiICLKyssjLy2POnDnExcVp4FNByZizu9f7xo0bWbVqFfv27aO5uRmXy4XD4aCuro7s7GzuvPNOlixZwo4dO1i4cCHXXHMNl19+OQALFy4kPz+fwsJCFi9ezKJFi7jxxhuJj4+nvr6eL7/8kr/7u7/jzjvv9J2vu7vbV9bTHT+UNAAqNQxiY2OZNGkSkyZNwhjDsWPHqKmpYd++fWzatAmbzUZaWhrp6emkpaWRlJSkv0ADqPFEF18e6xhwP4fLzdulh8d0AOzq6qKxsZH6+noOHz7MkSNHiI2N9Y2Gnzdvnk6arkaNoqIiRIR9+/Zxww03DOqYqqoqrr76am6//XYefvhhUlJS2LlzJ9/85jdxOBwAXHnllVRVVfHnP/+ZDRs2cPXVV3PTTTexevVq4uPj2blzJ5s3b+bdd99l1apV3H///Wzbto3w8HAAXnjhBebOnev3/Kc7Pjv71OnMzpYGQKWGmYiQkpJCSkoK06dPx+Vy0dDQQH19PXa7nd27d9Pe3k5KSoovEKalpREfH6+hcIR0OF2EhwmcvgEQ8FwKHguMMbS1tdHY2EhDQwONjY00NjbS2dlJcnIyaWlpnHfeeXzlK18hOjp0L3mr0S05OZnFixfz3HPPcffdd5/SD7CpqemUfoDbt2/H4XDwq1/9yhfY1q1bd8p7p6amsmzZMpYtW8aVV17JN7/5TV544QUiIyOxWCwsWLCABQsW8NBDD5Gens66deu44447yM7OpqKigltvvbXfcp/u+KGiAVCpERYeHk5GRgYZGRm+dV1dXTQ0NHD06FEqKirYunUrLpfLFwZ7Wgv1F/HwSI2LxD3IS0XjkmKGuTRDzxhDU1OTL+T1BL6eP05SU1OZMGECc+bMISEhQf/wUGPK888/z7x585g1axaPPPIIxcXFGGN4//33WbVq1SnTwBQVFeF2u3nmmWe48cYb2bp1K88888xJ+zz44IPMnDmTKVOm0N3dzZtvvsn48eOJjIxk3bp1VFRUcNlll5GcnMz7779Pa2urrx/iQw89xIoVK0hMTOSqq67C6XSyc+dO7HY7K1euHPD4oaIBUKkgEBkZ6bsrSY+2tjbq6+upr6/n008/paGhAavVSniMjb0NhrJmodsSzaXnZ7Ps4gLSE3SuurMVZQ3nqmlZ/Mfuw7hOEwRjIsL5zvzCESzZmevu7ub48eM0NDT4gt7x48eJjo72hb1p06aRkpJCTEyMhj015o0fP56dO3fyi1/8gnvvvRe73e67IvPiiy+esn9xcTHPPvssjz/+OA888ABz587lqaee4uabb/btExkZyU9/+lMOHjxIVFQUF198MW+99RbgGVm8du1aHn74Ydrb25kwYQIvv/wy8+fPB+C73/0usbGxPPnkk6xcuZLo6GimTJnC8uXLB3X8UJGz7SA5FsyaNcts37490MVQalCc3S5W/uFjduyvIs7dTrx0EicOrGJoI4ILJ2Rz6ZR8EhMTsdls2Gw2nZvwDBxsaOPqf/yAdof/68CWMKEgNZY//2A+1vDAzmPndrtpbW2lpaXFtzQ3N9PS0sKJEyew2Wy+bgepqamkpKTohMtqTNq3b9+Qt4yNdn1/JiKywxgzq+9+2gKo1CjxD299zttfNNPhTAD+55ZZFlzEiYPq8i7i448z7tgxmpubaW5uJioqyhcIez/qqM1TFabG8vvvzOFbqz/B5TYnBcHYiHByk2J47fY5Ixb+XC6X34DX0tJCW1sbMTExJCQk+JasrCwSEhKw2Wy+fktKKdUfDYBKjQJHWzr5tx01OLpPHYDQTThNJpomRzQv7hM+WnkFIoIxhhMnTtDU1ORbDh06RHNzM11dXb5WQpvNRkxMDLGxsb7H6OjokLxbQ0l+Eh/ffwVv7TnMH7fXcKKzm9ykaG6bW8ClE1MJCxu60GyMoaOjg/b2dlpbW08KeC0tLXR0dBAXF+cLeImJieTl5WGz2YiLi9OQp5Q6JxoAlRoF/rj9SwYTPVo7nWw7dJzZhcmICPHx8cTHx/vmJ+zhdDppamrytRT2TFPT3t5OW1sbnZ2dREZGEhMTc1I47Pt8LAbFmAgLN1+Ux80X5Z3V8U6nk87OTjo6OnwBr2dpa2vzrevo6CAiIoLY2Fji4uKw2Wy+wRgJCQnExsaOuZ+tUip4aABUahSoqD9Bl5/Wv74MUH2sndmFyafdz2q1+kYX+30fb+tUW1vbSQGmoaGB6upqX5jp6uoiKirKFwijoqKIiIjAarX6lt6v+26zWq1BdSna7XbT3d2N0+mku7v7pOe91zkcDl/A6+zs9AW+zs5OjDFER0cTHR3t+9nExsaSkpLCuHHjTgrP2oqnlAoUDYBKjQJxkYMbzBEmEG0991AhIr6gcjput9vXotUTCB0OB06nk66uLlpbW3E6nSctPdt7ApXFYjkpIFosFiIiIggPDz8pHPY8P5t14OlT5y/M9X7udrt95en92LP0vI6IiCA6OpqkpCRf0Ot5tFgsQRVqlVLKHw2ASo0Ci6Zk8ObOGtr6GaHaw+kyzJ2QMkKl8twwPTY2ltjY2H5bE0/HGNNvQHS5XL5bI/WereBs1/UNcb3DXc/zvqFTKaXGKg2ASo0C8yakYoux0u5w0d/ETRHhYSyakkFS7OiZ7kNEiIiI0ClKlFJqhGkPY6VGgbAwYfW3ZhMbacHfQNQISxg5SdH8/IZpI184pZRSo44GQKVGicmZ8bx996VcOTWLSEsY8VEW4iItxEaGc+sl+by14lISonTiZ6WUUgPTS8BKjSL5KbE8v3Qmze1ODjW2ER4mTEyPI2oIBn4opZQKHdoCqNQoZIuxMn1cIlNzbBr+lFJqFFu1ahUi4rsXcG9vvvkm4eHhLF26dMjPGzQBUESSReRdETngfUw6zb4JIlIjIs/1WlciIqUiUi4i/yg6lE8ppZRSA1i7y868xzZSeN/bzHtsI2t32Ufs3Fu3buXFF1+kuLjY7/aXX36Zn/zkJ6xdu5bjx48P6bmDJgAC9wEbjDFFwAbv6/48Amzus+6fgNuBIu/y9eEopDpVV7eLd0pref79cl7+oJKyI62BLpJSSik1oLW77Kx8sxR7UwcGsDd1sPLN0hEJgc3NzSxdupR//ud/Jinp1Davmpoa3n//fe655x4uvvhiXnvttSE9fzAFwOuANd7na4Dr/e0kIiVABvDXXuuygARjzFbjmfTrd/0dr4bW7z46RMkj7/HjN/bw9F/38/hfvuDaX3/Itc99yJfH2gNdPKWUUqpfT67fT4fz5PlVO5wunly/f9jPfccdd7BkyRK++tWv+t2+evVqFi1aREpKCsuWLeOVV14Z0vMHUwDMMMbUep/X4Ql5JxGRMOBp4J4+m3KAml6va7zrTiEid4jIdhHZXl9ff+6lDmEv/Gc5q975ghNd3bR1uXAbz0TEnd1uPrU3c+1zH1Lb3BHoYiqllFJ+HW7y/zuqv/VD5aWXXqK8vJxHH33U73ZjDKtXr2bZsmUALFmyhLKyMrZv3z5kZRjRACgi74nIp36W63rv523F8zff7V3AO8aYGj/bBsUY86IxZpYxZtbZ3LlAeRxt6eRX7x445S+nHm4DLR1OHl23b4RLppRSSg1OdmL0Ga0fCvv37+f+++/n9ddfx2r1P3XXhg0bOH78ONdccw0AcXFxXH/99UPaCjii08AYY77W3zYROSIiWcaYWu8l3aN+drsEmC8idwFxQISInACeBXJ77ZcLjFwvzhD02sfVA+7jMvDeviM0tTtIjNE7PSillAouP148mZVvlp7UmBFtDefHiycP2zk/+ugjGhoamDJlim+dy+Vi8+bNvPDCC7S1tfHyyy/T1NREbGysbx9jDPHx8Tz99NMD3qd9MIJpHsD/AG4DHvM+/qnvDsYY3zhoEfkWMMsYc5/3dYuIXAx8DNwK/HoEyhyyPqpspKvbPeB+EZYw9te1Mmf8yN2fVimllBqM6y/09BZ7cv1+Djd1kJ0YzY8XT/atH5ZzXn89s2bNOmndt7/9bYqKirj//vs5ceIEa9euZc2aNcycOfOk/a644greeOMNbr311nMuRzAFwMeAP4rId4Aq4BsAIjIL+J4x5rsDHH8X8CoQDfzZu6hA6+/GtUoppVQQuP7CnGENfH0lJiaSmJh40rrY2FiSk5OZOnUqzz77LAkJCSxdupTw8JPneb3xxht5+eWXhyQABs0gEGNMozHmCmNMkTHma8aYY9712/2FP2PMq8aY5b1ebzfGTDXGTDDGLPf2I1TDZE5hMhGWgf/5dLncTMqIH4ESKaWUUqPfK6+8wvXXX39K+AO46aab+OCDDygrKzvn8wRTC6AaRW65OJ/fbq487T5hAlecl05SrPb/U0oppfqzadMm3/O9e/f2u9+CBQsYqvatoGkBVKNLRkIUK746keh+bkMWJpAQZeWBv7lghEumlFJKqYFoC6A6ayuuKCI20sJTf92PAO0OF5ZwITxMmJAWxz8tLSFnGIfSK6WUUursaABU5+RvLy3kf8/JY/1ndVQ1thNpCWN+URoXZCcEumhKKaWU6ocGQHXOoqzhXDdj5EZQKaWUUurcaB9ApZRSSo1aOunH/3C7B56ft4cGQKWUUkqNSlFRUTQ2NoZ8CDTG4HA4sNvtJ9095HT0ErBSSimlRqXc3Fxqamqor68PdFECzmKxYLPZSE1NHdz+w1wepZRSSqlhYbVaKSwsDHQxRiW9BKyUUkopFWI0ACqllFJKhRgNgEoppZRSIUZCeeSMiNQDVYEuxwhIBRoCXQg1LLRuxy6t27FL63ZsC7b6zTfGpPVdGdIBMFSIyHZjzKxAl0MNPa3bsUvrduzSuh3bRkv96iVgpZRSSqkQowFQKaWUUirEaAAMDS8GugBq2Gjdjl1at2OX1u3YNirqV/sAKqWUUkqFGG0BVEoppZQKMRoAlVJKKaVCjAbAMUJEkkXkXRE54H1M8rPPDBH5SEQ+E5G9InJzr22vishBEdntXWaM6AdQ/RqCui0UkY9FpFxE/iAiESP7CVR/BlO33v3+IiJNIrKuz3r93gapIahb/d4GqTOo29u8+xwQkdt6rd8kIvt7fW/TR670/0MD4NhxH7DBGFMEbPC+7qsduNUYMwX4OvCMiCT22v5jY8wM77J7uAusBu1c6/Zx4FfGmInAceA7w19kNUiDqVuAJ4Fl/WzT721wOte61e9t8BqwbkUkGfgZMAeYDfysT1Bc2ut7e3QkCt2XBsCx4zpgjff5GuD6vjsYY8qMMQe8zw8DR4FTZgdXQees61ZEBFgAvHG641XADFi3AMaYDUDrCJVJDY2zrlv93ga9wdTtYuBdY8wxY8xx4F08f5wHDQ2AY0eGMabW+7wOyDjdziIyG4gAKnqt/rn38uGvRCRymMqpzty51G0K0GSM6fZurgFyhqug6oydUd32Q7+3welc6la/t8FtMHWbA3zZ63XfOlztvfz7f72Bf8RZAnFSdXZE5D0g08+mn/Z+YYwxItLv/D4ikgX8HrjNGOP2rl6J5x9yBJ45jO4FHh6KcquBDVfdBuj/FdXLUNVtP/R7G0DDXLcqgIa5bpcaY+wiEg/8fzxdAH53diU9exoARxFjzNf62yYiR0QkyxhT6w0BfvsUiEgC8DbwU2PM1l7v3fPXTJeIrAbuGcKiqwEMY902AokiYvG2JuQC9iEuvjqNoajb07y3fm8DaBjrVr+3ATYEdWsHvtLrdS6wyfvedu9jq4i8jqeP4IgHQL0EPHb8B9Azyug24E99d/COIvt34HfGmDf6bMvyPgqe/gyfDmdh1Rk567o1npne3weWnO54FTAD1u3p6Pc2qJ113er3NugNpm7XA4tEJMk7+GMRsF5ELCKSCiAiVuBvCND3Vu8EMkaISArwRyAPqAK+YYw5JiKzgO8ZY74rIrcAq4HPeh36LWPMbhHZiGdAiAC7vcecGNEPofwagrodD/wrkAzsAm4xxnSN7KdQ/gymbr37fQCcB8ThaR36jjFmvX5vg9cQ1K1+b4PUGdTt3wL3ew/7uTFmtYjEApsBKxAOvAf8yBjjGvHPoQFQKaWUUiq06CVgpZRSSqkQowFQKaWUUirEaABUSimllAoxGgCVUkoppUKMBkCllFJKqRCjAVApFTJEZJOIPBfocgxERL4iIqZnvjCllBpqGgCVUqOaiLzqDUtGRJwiclRE3heR73snWu3tRjy3Twt2/wVk4ZkXbtiISJaIvC4iX4iIS0ReHc7zKaWChwZApdRY8B6ewFSAZ8b9t4CHgA+8E68CYIw5ZoxpDUgJz4AxxmGMqTPDP1FrJNAAPAZ8PMznUkoFEQ2ASqmxoMsbmOzGmN3GmF/iuQ/nTOAnPTv1vQQsIodE5EFvK2KriHwpIjeLSKKI/KuInBCRAyKyqPfJROQCEXnbe8xREfkXEcnstf1VEVknIj8QEbuIHBeR1SIS02ufy0Rkq/cczSLyiYhM9W475RKwiNwoIqUi0uUt50+9t4Dr/VkeEJHfikiLiNSIyI9P90MzxhwyxtxtjHkVOHbmP3al1GilAVApNSYZYz4F/gL8rwF2/SHwCZ6w+EdgDfA68A4wA89tm/6fiESB7/67m/Hcv3M28DU8t/H6k4j0/j91PjDVu/1m4AbgB973sOC5f+iHwHRgDvAM4Pd2UCJSAvwb8CYwDbgPz6Xs5X12/Xug1PtZHgeeEJFLBvj8SqkQpAFQKTWWfQ6MH2Cf9caY3xhjDgA/w3NZtNwY8ztjTDnwCJ777U717n8nsMcYc68xZp8xZi9wK54wOKvX+7bguS/oPmPMX/EEuCu82xKAROAtY0yFMeYLY8zrxph9/ZTxR8B/GmN+ZowpM8a8BjwF3Ntnv78aY54zxpQbY34NlPc6p1JK+WgAVEqNZQIM1I9ub88TY8wJoB1PK1qPI97HdO9jCXCZ99LtCRE5AXzp3Tah13Gf97nB++Ge9zDGHANeBdZ7LyX/SETyTlPG84EtfdZ9COSISIK/z9L3nEop1ZsGQKXUWHYBUDnAPs4+r02fdT0BMqzX49t4Lg/3XoqAdQO8r+//XGPMt/Fc+t0MXAvsF5HFA5TVn94B97TnVEqpHpZAF0AppYaDd0DF14FHh/itdwLfAKqMMX0D1xkxxuwB9gCPi8ifgduA9X523QfM67PuUqBmNIxqVkoFH/3LUCk1FkSKSKaIZIvIdBH5EbAJ2IGnr9xQeh6wAX8QkTkiMl5EviYiL4pI/GDeQEQKReQxEZkrIvki8lWgGE+fRX+eBi4XkX8QkUkishT4P8AT5/phRGSGiMzA0y8x2fv6gnN9X6VUcNMWQKXUWPA1oBbPKNomPCN0/wF40RjjGMoTGWMOi8g8YBWeUcZRQDXwV6BrkG/TDkzCMzAkFU8/w9fwjNz1d86dInITnrkN7/fu/xgwFHc12dXn9TVAFZ45FZVSY5QM/zyjSimllFIqmOglYKWUUkqpEKMBUCmllFIqxGgAVEoppZQKMRoAlVJKKaVCjAZApZRSSqkQowFQKaWUUirEaABUSimllAoxGgCVUkoppULMfwNKuAxPp+UZ6gAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 648x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Create a figure and axis object\n",
    "fig, ax = plt.subplots(figsize=(9,5))  # Increase figure size for better readability\n",
    "\n",
    "Aobs_yadf = yadf[yadf[\"Matrix\"] == 0]\n",
    "# first two dimensions in an array\n",
    "Aobs_array = Aobs_yadf.iloc[:, 0:2].to_numpy()\n",
    "\n",
    "node_number = 18\n",
    "zoom_range = 0.15  # Define the range around node 18 for zooming in\n",
    "\n",
    "Aobs_yadf_node = Aobs_yadf[Aobs_yadf[\"NodeNumber\"] == node_number]\n",
    "node_18_coords = Aobs_yadf_node.iloc[0, 0:2].to_numpy()\n",
    "\n",
    "# Filter data to include only points within the zoom range around node 18\n",
    "zoom_mask = np.all(np.abs(Aobs_array - node_18_coords) <= zoom_range, axis=1)\n",
    "Aobs_yadf_zoom = Aobs_yadf[zoom_mask]\n",
    "Aobs_array_zoom = Aobs_array[zoom_mask]\n",
    "\n",
    "# Plot the scatter plot for the zoomed-in data\n",
    "scatter = ax.scatter(Aobs_yadf_zoom[\"Dimension_1\"], Aobs_yadf_zoom[\"Dimension_2\"], c=Aobs_yadf_zoom[\"tau\"], cmap='tab10', s=100)  # Increase marker size\n",
    "ax.set_xlabel(\"Dimension 1\", fontsize=14)  # Increase font size\n",
    "ax.set_ylabel(\"Dimension 2\", fontsize=14)  # Increase font size\n",
    "\n",
    "# plot the covariance ellipse with the same color as the point\n",
    "plot_ellipse_3mahals(ax, data_d_dim[0, 0:2], cov_d_dim[0:2, 0:2], color='#808080', lw=1)\n",
    "\n",
    "\n",
    "# Plot the bootstrap points\n",
    "ax.scatter(data_d_dim[:, 0], data_d_dim[:, 1], color='black', alpha=1, marker='+', s=100)  # Increase marker size\n",
    "\n",
    "# Add legend for classes, mapping the integer labels back to the label_dict keys\n",
    "handles, labels_legend = scatter.legend_elements()\n",
    "label_dict_inv = {v: k for k, v in label_dict.items()}  # Inverse mapping\n",
    "mapped_labels = []\n",
    "for label in labels_legend:\n",
    "    match = re.search(r'\\d+', label)\n",
    "    if match:\n",
    "        numeric_label = int(match.group(0))\n",
    "        mapped_labels.append(label_dict_inv.get(numeric_label, \"Unknown\"))\n",
    "\n",
    "# Add the legend with the mapped labels\n",
    "fig.legend(handles, mapped_labels, title=\"Classes\", loc=\"lower left\", bbox_to_anchor=(0.86, 0.12), ncols=1, fontsize=14, title_fontsize=14)  # Increase font size\n",
    "\n",
    "# Create custom second legend\n",
    "legend_elements = [\n",
    "    Line2D([0], [0], color='#1f77b4', marker='s', lw=0, label=f'Node {node_number}, member of class 4A', markersize=10, markerfacecolor='#1f77b4'),\n",
    "    Line2D([0], [0], color='#d62728', marker='+', lw=0, label=f'Bootstrap Resamples of Node {node_number}', markersize=10, markerfacecolor='#e377c2'),\n",
    "    Line2D([0], [0], color='#808080', lw=1, label='Covariance of node at 1,2,3, SDs', linestyle='-')\n",
    "]\n",
    "fig.legend(handles=legend_elements, loc='upper right', bbox_to_anchor=(0.56, 0.965), fontsize=14, title_fontsize=14)  # Increase font size\n",
    "\n",
    "# plot the point for node with node_number in blue square\n",
    "ax.scatter(Aobs_yadf_node[\"Dimension_1\"], Aobs_yadf_node[\"Dimension_2\"], color='#1f77b4', label=f'Node {node_number}, member of class 4A', marker='s', s=150)  # Increase marker size\n",
    "\n",
    "# plot the class 4B in red\n",
    "ax.scatter(Aobs_yadf_zoom[Aobs_yadf_zoom[\"tau\"] == 7][\"Dimension_1\"], Aobs_yadf_zoom[Aobs_yadf_zoom[\"tau\"] == 7][\"Dimension_2\"], c='#d62728', label='tau=7', s=100)  # Increase marker size\n",
    "\n",
    "# Adjust layout to make room for titles and labels\n",
    "plt.tight_layout()\n",
    "\n",
    "# plt.savefig(f\"figs/school_A1_embedA_viaUASE_sd1mean0_4classes_node{node_number}_boostraps_3mahals_zoom.png\", bbox_inches='tight', facecolor='white')\n",
    "\n",
    "# Show the combined plot\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Plot A[1] adjacency matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 182,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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3nvvbXrzzTf/uXv37isef/zxePFnmpqawqZNmzYkKipqXFxc3Og//vGPceL3V65cOSAlJWVkRERERu/evcdee+21aUeOHOklPuakSZOGRUdHj+vbt++YqVOnDhH/47Rs2bKkQYMGpZeUlPRNTk4eGRERkfnkk0/G9ezZM1O8HyKikpKSvlFRUeO+++67HkREx48fD5s1a9bgvn37jomJiRmXkZExvKKiwi3+THl5eWxqauqIiIiIjNTU1BHl5eWGrr6DTchf8bhcLnrqqae+3rx5c7+PPvooWmqblpYW1/Tp01Pb2tp6bN26tW7r1q11Z8+e7fHTn/50mNaritra2uidO3fGbtq06fB77713qK6uLmrp0qVXExHdfffd3/3ud79rjI+Pv/jll1/u+/LLL/fl5+c3EhHl5uZes3nz5j6rV6/+ct++ffv/4z/+o/7RRx+96plnnunS+KxYsSJp4sSJLZ9++uk/CgsLvyEiioqK6li7du2Xe/fu/XzdunVHd+/eHbtgwYKr/Z/5+9//Hjl16tS0Pn36tG/ZsqVuz549B5YsWXKio6ODWabu7r333oGlpaVXFhYWHq+urv589uzZTb///e+TN23a1OVH8/TTTydlZWU1f/bZZwfuu+++hsLCwoHdtxF75ZVX+kdGRnY8/PDDJ7u/N2XKlLMTJkxofvPNN7s0cCtWrEi66aabmvfs2XNg6dKljR6P5+qNGzf2IfI1Kg8++OA1y5Yta6ytrd3/wQcf1OXm5jb5P1tdXR05bdq0tPHjx5/dtWvXP7Zu3XqoZ8+e3qlTp6aeO3eu8/v+9ttvexUXF8e9/PLLx2pqavbfc889TQMGDLi4fv36/uKybNy4sf+tt956pl+/fh0tLS2u7OzstJaWlp6bNm06vGfPngO33XbbmRkzZqTW1NREEhEdO3as1y9/+cuho0ePPvfJJ58cePLJJ7/Oy8u7mhxE1bNawe72229vmTJlypkHHnjg6s8++6yu+/slJSX9T58+HVZdXf2PxMTEdiKit99++4thw4aNfumll/otWbKk6fK9SuvVq5f3zTffPBYVFeUlIrrrrru+LS4ujiMicrvdXrfb3dGzZ0/voEGDOq/bDx48GP7Xv/61f3V19efjxo1rJSIaPnz4hbq6ush169bF3X///af8206dOvX0H/7wh2/Fx3zqqaca/H9PS0u78P33338zf/78lEuXLh3r2bMnPfbYY4mDBg1qe++994727Om7EBo1alSb/zNSZequubm5x4YNG+IeffTR43ffffdpIqLRo0c3VldXx/zpT39KnDFjRrN/25ycnO/y8vJOERGNHDny25KSkrj//u//vkK8jdg///nPiEGDBrX5Y9ZdWlra+b/85S9dGuCbb775e39DNXr06JOfffZZzDPPPBP/L//yL2eOHj0aHhUVdSk3N/e0v6s4fvz48/7PPvHEEwm33HLL988880y9/7V33333aL9+/ca+8847vX/zm9+cISJqa2vrUVpaenTYsGEX/NvNmjWr6c033+z/+OOPNxL5rm527drV+y9/+cthIqL169f3a2lp6bl58+YjvXr5LoyefPLJxp07d16xZs2aK9evX3985cqVV/bt27e9rKzsWK9evSgzM7O1tbX1m9zc3KFy8Q81jmh4iIiKioq+zsjIGPn666/3njBhwjnxe59//nnkkCFDWv2NDhHR1Vdf3T548ODWzz//PFLLcVJSUlrFP6CkpKQLTU1NvVif+eSTT2K8Xi9NmjTpJ+LXL1265Oo+efO666472/3zr776ap/Vq1fHf/XVVxEtLS09vV4vXbx40XX8+PFegwcPvlhbWxt98803f+9vdPQ4cOBAxMWLF11Tpkzp0nhkZWU1P/vss4ni18aOHdslvvHx8RdPnjzJjIFWEyZMaBH//w033NBSWFg4kIhoxowZP/zpT3+6kJKSMvrGG2/8ITs7+4df//rXZ/zf7759+2K++uqriOjo6HHifbS1tfU4dOhQZ/e6f//+F8WNDhHR/Pnzm1544YWEjz/+OPrGG2889/LLL/fv16/fxRkzZvxARPQ///M/MU1NTb169+7dZd8XLlxwRUZGdhARHTx4MGrMmDFn/Q0TEdFtt93WpT6hzjENz+jRo9tyc3NPPfLII1dVVFQctuo44eHhXRoKl8tFSg/iXrp0iYiIPvzww4MxMTFdbua6XF17et3f37FjR8zdd989ZPHixQ1PPfXU1wMGDGj/6KOP3EuXLh0cqNEgqRh0dMjfox4yZEjbZ599Fnvu3DlXdHT0ZcGqq6uLSk5OVv3YTu/evTtqa2sPfPDBB+6tW7desX79+is9Hs9VW7ZsOZSVlXWuo6ODfvaznzU98sgjl3Up4+PjO//xiYqKuqzQGRkZrSNHjjy3fv36/jfeeOO5N954o//Pf/7z78LCfD+ljo4OSklJOf/uu+8e6f5Zt9vN5UZ9MNDU8CQPiKy2qiA8FBYW1qelpaWvXr36SvHrI0eObH399devbGhoCPP/q3j8+PGwY8eORaanp0ve79ArPDy849KlS10ahIkTJ54jIvriiy/C586d+72W/e3cudPdp0+f9ueee66z21BaWtpXvM2oUaPOVVVVXXHp0iWSuuqRKlN3I0aMaAsPD/du37499rrrrutsBKqqqmJTU1PPsz6r5N/+7d+aNmzYEPf444/H+7swfjt27Ij59NNPY/Pz878Wv75nz54YIurscu7evds9dOjQznKEhYXR9OnTW6ZPn97S0dFRP3To0JF//vOf+2VlZZ0bPXr0uQMHDkSPGDGirUcP7bc5c3NzTxUVFSV9/PHHTXV1dVGvvfbaF/73rr322nPvvvtu/759+14aOHCgZNd1+PDh599+++3+7e3t5G+wtm3b5pbaNlSF/M1lsaSkpPYlS5Y0vvzyy11GQBYsWNDUt2/f9p///OcpH3/8cXRVVVX0L37xi5S4uLgLv/3tb0+bWYaUlJQLp06dCtu2bVtMQ0NDWHNzc4/09PS22bNnn7r33nuvef755/vt378/Yvfu3VGrVq3q//DDDzNHhIYPH956+vTpsGeeeWbAgQMHwtesWdN/w4YNXer3hz/8ofGrr76KmDlzZvJHH30U/fnnn0esX7++77Zt22LkytT9OLGxsR3z5s07WVhYOHD9+vV9/+///i9i+fLlCdu3b++zfPnyhu7bazF58uRzS5YsaXzyySeTli1bllRdXR1ZV1cX/txzz/WfPXv20IkTJzY/9NBDXW4879ixo88TTzxxZW1tbcTjjz8et2XLln7//u//foKIaOPGjX08Hk9cVVVV9OHDh8M3btzYp7GxMXzEiBGtRET/9V//1fDFF19Ezpw5M/nDDz+MPnjwYHh5eXnsvHnzrj5w4IDitIu77777ux9++KHnggULBo8YMeKcuCFetGhR01VXXXVh2rRpw959990r6urqwnfs2BHz0EMPJbz22mt9iIjuv//+b0+fPh2Wm5t7TU1NTeSmTZtiCwoKmKOuocZRDQ8R0SOPPHKiT58+Xf4lcrvd3oqKikPh4eEdU6dOTZs2bVpadHR0x5YtWw5HRkaa+oDsr3/96zPTp08/PWvWrGFJSUlj8vPzE4iISktLv1y0aNGJFStWJI4bN27kT3/609TXX399wJAhQ9pY+5s7d+73S5cubXjssccGZmZmjnzrrbf6Pvroo12uDsaPH39+y5YtdU1NTb1+HM0Z8eyzz8b37NnTyypTd88+++w3ubm53y5fvvzqH4/Vf+3atUflbhprsXr16m+Ki4uPfvTRR7E33XTTT0aPHp2+evXqhHvuuefEjh07DkdERHT5HvLy8up37Nhxxfjx40esWrUq4T//8z+//td//dczRET9+/dvr6io6HPnnXcOS09PT3/kkUeuuu+++xr8N+kzMjJaP/zww4Nnz57tMWPGjNSxY8emL168+JrW1tYe/fv3v6RU1oSEhEvZ2dnfHzx4MGrOnDldBh6io6O9VVVVB8eMGXP2nnvuGZyenp4+Z86cIX//+99jUlJS2oiIkpOTL77xxhv/3Lt3b8yECRNGPPDAA4OeeuopbhM17UAxEdi+ffuOjRkz5hRzIwCw3L59+waMGTNmcKDLYQbHXfEAQOCh4QEA7tDwAAB3aHgAgDs0PADAHRoeAOAODQ8AcIeGBwC4Q8MDANyh4QliSMbOV6jWKxBCuuFBMnZzIRk7mCWkG55AQzJ2fpCMPbhoanhcLk+mHf7orSySsSMZOxGSsduB4654kIwdydiRjD3wHJP61A/J2JGMHcnYA89xDQ+SsSMZO5KxB57jGh4kY0cydiRjDzxNDY/Xmx/Uyd7VQDL2yyEZu/OSsVvNcTeXlSAZ++WQjN15ydithoanGyRjl4Zk7M5Kxm41JHsHCBJI9g4AYAAaHgDgDg0PAHCHhgcAuFPT8HR0dHQg7QFAAP34GwyZCY6KDY/L5Wo8f/58JI/CAIC08+fPR7pcLsmHg4ORYsPT3t7uOXbsWPjZs2ejcOUDwFdHR4fr7NmzUceOHQtvb2/3BLo8ZlGcx0NEVFNTMy0sLCzf6/UmEO4LAfDU4XK5Gtvb2z0ZGRlbA10Ys6hqeAAAzISrFwDgDg0PAHCHhgcAuEPDAwDcoeEBAO7+H1b+zBP87b8GAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 360x360 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Define blue hex codes for the colormap\n",
    "blue_colors = [\"#f0f8ff\", \"#add8e6\", \"#87ceeb\", \"#4682b4\", \n",
    "               \"#4169e1\", \"#0000ff\", \"#0000cd\",  \"#000080\"]\n",
    "\n",
    "# Create a custom colormap\n",
    "blues_cmap = LinearSegmentedColormap.from_list(\"blues_cmap\", blue_colors)\n",
    "\n",
    "\n",
    "# Replace labels using label_dict_inv\n",
    "mapped_labels = [label_dict_inv[label] for label in labels]\n",
    "\n",
    "# Initialize a list to store the positions where the value changes\n",
    "change_positions = [0]\n",
    "\n",
    "# Loop through the list and find where the value changes\n",
    "for i in range(1, len(mapped_labels)):\n",
    "    if mapped_labels[i] != mapped_labels[i-1]:\n",
    "        change_positions.append(i)  # Store the position of the change\n",
    "\n",
    "# add on the last place for a change position - so that the teachers will get a label\n",
    "change_positions.append(len(labels)-1)\n",
    "\n",
    "# Get the corresponding labels for those positions\n",
    "change_labels = [mapped_labels[i] for i in change_positions]\n",
    "\n",
    "# Get the corresponding labels for the middle of each section\n",
    "middle_positions = [(change_positions[i] + change_positions[i+1]) / 2 for i in range(len(change_positions) - 1)]\n",
    "middle_labels = [mapped_labels[change_positions[i]] for i in range(len(change_positions) - 1)]\n",
    "\n",
    "plt.figure(figsize=(5,5))  \n",
    "\n",
    "# Plot heatmap with the updated labels\n",
    "sns.heatmap(dense_adj, square=True, cmap=blues_cmap, cbar=False) # \"Blues\"\n",
    "\n",
    "# Add gridlines at the change positions\n",
    "for pos in change_positions[:-1]:\n",
    "    plt.axvline(x=pos, color='grey', linestyle='--', linewidth=1)  # Vertical gridlines\n",
    "    plt.axhline(y=pos, color='grey', linestyle='--', linewidth=1)  # Horizontal gridlines\n",
    "# at end of plot too\n",
    "plt.axvline(x=90, color='grey', linestyle='--', linewidth=2)  # Vertical gridlines\n",
    "plt.axhline(y=90, color='grey', linestyle='--', linewidth=2)  # Horizontal gridlines\n",
    "\n",
    "# remove all ticks\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "\n",
    "# Create a custom legend\n",
    "legend_labels = ['No Interaction Observed', 'Interaction Observed']\n",
    "legend_colors = ['#deebf7', '#000080']  # Colors corresponding to 0 (white) and 1 (blue)\n",
    "\n",
    "# Add the legend to the plot\n",
    "for color, label in zip(legend_colors, legend_labels):\n",
    "    plt.plot([], [], color=color, label=label, linewidth=5)  # Add an empty plot for legend entries\n",
    "# Adjust the position of the legend below the plot\n",
    "plt.legend(\n",
    "    # title='Connection Status', \n",
    "    loc='center', bbox_to_anchor=(0.42, -0.28), ncol=1, fontsize='x-large', frameon=True)\n",
    "\n",
    "# plt.title('Adjacency Matrix of Primary School Interaction \\n Network at 9:00-10:00 of Day 1', fontsize=12, pad=10)\n",
    "\n",
    "# plt.savefig('figs/adjacency_matrix_A1_heatmap_blueCustom_4classes_noaxes.png', dpi=300, bbox_inches='tight', facecolor='white')\n",
    "\n",
    "# Show the plot\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### plot $\\hat{P}$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 129,
   "metadata": {},
   "outputs": [],
   "source": [
    "n = dense_adj.shape[0]\n",
    "A_obs = dense_adj.copy()\n",
    "\n",
    "d=12\n",
    "k=3\n",
    "\n",
    "# Embed the graphs -------------------------------\n",
    "yhat = UASE([A_obs], d=d, flat=True)\n",
    "\n",
    "# run a k-NN on the embedding yhat\n",
    "# Here we use Minkowski distance, with p=2 (these are the defaults),\n",
    "# which corresponds to Euclidean distance\n",
    "from sklearn.neighbors import NearestNeighbors\n",
    "\n",
    "nbrs = NearestNeighbors(\n",
    "    n_neighbors=k, algorithm=\"ball_tree\", metric=\"minkowski\", p=2\n",
    ").fit(yhat)\n",
    "distances, indices = nbrs.kneighbors(yhat)\n",
    "\n",
    "# Estimate the P matrix -------------------------------\n",
    "P_est = P_est_from_A_obs(n, A_obs, n_neighbors=k, indices=indices)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 152,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 360x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(5,5))  \n",
    "\n",
    "# Plot heatmap with the updated labels\n",
    "sns.heatmap(P_est, square=True, cmap=blues_cmap, cbar=True, cbar_kws={\"shrink\": 0.8})\n",
    "\n",
    "# Add gridlines at the change positions\n",
    "for pos in change_positions[:-1]:\n",
    "    plt.axvline(x=pos, color='grey', linestyle='--', linewidth=1)  # Vertical gridlines\n",
    "    plt.axhline(y=pos, color='grey', linestyle='--', linewidth=1)  # Horizontal gridlines\n",
    "plt.axvline(x=90, color='grey', linestyle='--', linewidth=2)  # Vertical gridlines\n",
    "plt.axhline(y=90, color='grey', linestyle='--', linewidth=2)  # Horizontal gridlines\n",
    "\n",
    "# Set the xticks and yticks to the middle of the gridlines\n",
    "plt.xticks(middle_positions, middle_labels, rotation=90, fontsize=12)\n",
    "plt.yticks(middle_positions, middle_labels, rotation=0, fontsize=12)\n",
    "\n",
    "plt.ylabel('Class', labelpad=0, fontsize=12)\n",
    "plt.xlabel('Class', labelpad=0, fontsize=12)\n",
    "\n",
    "# plt.title('Adjacency Matrix of Primary School Interaction \\n Network at 9:00-10:00 of Day 1', fontsize=12, pad=10)\n",
    "\n",
    "# plt.savefig('figs/Phat_matrix_A1_heatmap_blueCustom_4classes.png', dpi=300, bbox_inches='tight', facecolor='white')\n",
    "\n",
    "# Show the plot\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Embed the 4 class data into 2-D via t-SNE"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "90"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "n=dense_adj.shape[0]\n",
    "n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 20/20 [00:00<00:00, 95.80it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYQAAAERCAYAAAB7FtAjAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAAsTAAALEwEAmpwYAACpI0lEQVR4nOy9d1hc6X3o/zlnKjNDG8rQu+gCgRBCqHet2sq769jZdRw7TuI4zWlOv0lukpv4l3tTnJs4N3GJs3Z2bW/TqveCBEKILhAg0XvvwzD1/P4YGIEEEpJQ2z2f55lHoznnvOc9w5n3e75dkCQJGRkZGRkZ8XlPQEZGRkbmxUAWCDIyMjIygCwQZGRkZGRmkAWCjIyMjAwgCwQZGRkZmRlkgSAjIyMjA8gCQUZGRkZmBlkgyDxzBEFoFQTBIgjCpCAII4IgHBcEIfIxxvmGIAg1giBMCILQIgjCN+7ZHiMIwkVBEKYEQagXBGHH8l3F80UQhD8TBEGae02CIGgEQfi+IAjjgiD0CoLwO89zjjIvH7JAkHleHJAkyQCEAn3A/32MMQTgi4A/sAf4dUEQPj9n+7tABRAA/AnwviAIQU8060edoCAon8KY8cBngZ57Nv0FsAKIBrYCvy8Iwp7lPr/MJxdZIMg8VyRJmgbeB1If49i/kySpXJIkhyRJDcDHwHoAQRASgWzgzyVJskiS9AFwE3h9KWPPaDF/JAjCrRkt5j8FQdDO2b5fEIRKQRBGBUEoEgQh455j/0AQhGrALAiC8mHjPSL/CvwBYLvn858H/kqSpBFJkuqA7wBfesxzyHwKkQWCzHNFEAQd8DmgeM5nfziz0C74WmQcAdgI1M58lAY0S5I0MWe3qpnPl8pbwG4gHkgE/nTmXFnA94Gv4tY+/h04IgiCZs6xPwvsA/wkSXI8ZLyoB12vIAhvzrnOzwJWSZJO3HP9/ri1raonuF6ZTzmyQJB5XhyeWdzHgJ3A/57dIEnSNyVJ8lvstch4f4H7fv7Pmf8bZsaeyxjg/Qhz/BdJkjokSRoG/hfuRR7gl4F/lyTpuiRJTkmS/guwAnlzjv3nmWMtDxtPkqT2B12vJEnvAAiC4A38DfD1BeZqmHONj3u9Mp9yZIEg87w4NLO4a4FfBy4LghDyOAMJgvDruH0J+yRJss58PAn43LOrDzDB0umY874NCJt5Hw387j1aS+Sc7fce+7DxlspfAD+UJKl1gW2TM//OveZHvV6ZTzmyQJB5rsw8YX8IOIENAIIg/PFMBNKCr7nHC4LwC8AfAtslSeqcs6kWiJt5qp4lk7smpaUwN/IpCuieed8B/K97nuJ1kiS9O/fSljrejMlo0esVBOGtmWO2A785E0HUOzPeTwVB+ANJkkZwO5kzn+B6ZT7tSJIkv+TXM30BrcCOmfcC8CrgANIecZy3gF4gZZHtxcD/wa2FfAYYBYJmtm1x3/4PnONNIAIwAleBv5nZloNbKKydmb8et7/A+97rW8p4j3C9AUDInFcH7mgjw8z2bwKXcUddJeMWEHue999bfr08r2UPiZORWSJHBUFw4n6SbgN+XpKkR32a/Wvci+QNt08ZgB9JkvQrM+8/D/wAGAHagTckSRqY2RYJFD1k/HeAM7hNOx/PnA9JkkoFQfgl4F9wh3lacC/wBY8z3lKRJGlo7v9nvr8RSZJmtaY/B/4N9/dpAf4/SZJOPco5ZD7dCJIkN8iR+fQhCMJ3gfckSTq9yPZW4BclSTq3TOdb1vFkZJ4GsoYg86lEkqRffN5zkJF50ZCdyjIyMjIygGwykpGRkZGZQdYQZGRkZGQAWSDIyMjIyMzw1J3KgYGBUkxMzNM+jYyMjIzMEikrKxuUJOm+yr9PXSDExMRQWlr6tE8jIyMjI7NEBEFoW+hz2WQkIyMjIwPIAkFGRkZGZgZZIMjIyMjIAHKmsoyMzEuMZLHhaBvC1T8BAojBPiijAxC0quc9tZcSWSDIyMi8lDgHJrBXtIFL8hQbd04N4mwbQp0Tg2jUP98JvoTIJiMZGZmXDsnqcAsDpzS/84RLAqcLW2krksP53Ob3siILBBkZmZcOR8fwwi2IZpEknF0jz2w+nxRkgSAj85LikiT6LFY6zdNM2B3PezrPFNfQpFsbmKGm9Q4NHS1zdpBwDZmfw8xebmQfgozMS8idMTM3Bsc9a6ILiQCNik0h/nirPvk/a0EU5ikIAgInrl8iMSIGT7MkUVjwWJnFkTUEGZmXjIYxM9cGxrG6JOyS++WUYGDaztH2AaY+BbZzRagfKO4u+CvCo3E4XTT3dMzsIKII9X0+k3uJkQWCjMwy4ZIkOs3TNIyZ6ZicxvkUSss7XRI3BscXHFsC7C6JmpHJ+w/8hCGG+oJS4fm/WqUiPiyK8ju3cLgcCGoFYpDPc5zhy8knX7eUkXkGdExOc6VvBJfkNt+ICCBAfpAvcT66ZTtPt8X6QGeqC7gzPkVu0Cf76VhQiKjz4rGVNIPNCU4XEUEmJqwWbnY3k/eFgwiyyeiRkQWCjMwT0jNl5WLvMM45C7UTdzjk1f5RVKJIpEG7LOeyOl0PDK4Bt5bwaUDUqdFsTsI1OIlrcIIITRJd06N0W8aYctnQ82TJaZLFhqNrBGnKhuClRhnhj+ClXqbZv5jIJiMZmSekZHBsnjCYi1OC64NjLFdnQm+V4qH76JQP3+eTgiAIKIK8UaWEEbkxkyHbJLm5uZSUlDzRuPY7fVgLbuNsGsDVNYqzqR9rwW3s9T3L9rd8EZEFgozME2BxOBm1PTjkc8rhZNy+PI7eYK0ajWLxn61CgDS/T2eGrkqlQhAETCYTVquV/v7+xxrH0TGMs2XAHdY6q21JgEvC2T6Es314+Sb9giELBBmZJ8DumvEXPABRELC7XMtyPkEQ2BLij1K4/5wKAfzVKpJ9P50CASA0NJTe3l7y8vIoLi5e0jGS3YnLbEWyO5EkCUdjHw9S+RyNfZ9YLUEWCDIyT8BSzDMuSVrW3IBgLzX7IwOJ0msRAAHQiAIZ/t68EhGI4lPsTA0LC6O7uxs/Pz8CAwNpbGxcdF/XlA1baSvWC3XYChuxnq/Ddr0ZrHc1PpfLxf/4z3+aLwCcLiSz9WlexnNDdirLyDwBSlEgwduL2+NTLKQDiECUXvtAM8/j4K9RsT3MiEuScEoSSkG4m5D1KcZkMnk6NK5evZpjx44RExODUjl/qXNN2bAV3gHH7F/NveBLI1Pu7S4XTd3tfFR4lh+e/Zgv7jzEioiYmX2FB5fNeImRNQQZmSckJ8gHH7Vybp4U4Dbh6JQK8oL9ntq5RUFAJYqyMJhBpVIhiiI2mw2NRkNSUhLV1dX37eeo654jDO7icrlo6Gjh46LzdA/1c6erjc9s2Mn7Bafn7SfoPpnRRrJAkJF5QlSiyP7IQLKM3uiVCkQBdAqRTKM3r0YFoV1m7UDmwYSEhNDT0wNAamoqra2tmM136xpJdieuwfnJe06nk7r2Jg4XnWPSMsXunA3UtjayIjyaLZlrsTls3O5sAVFAERWA8An9m34yr0pG5hmjEkVWGr35mVgTP58QxufiQsg0eqP+hC4cLzJhYWEegSCKImvWrJkXhirZHDBHo7I77AS/kU9ZQy37125ldWIaxfVVWJ024sOiCPTzZ0f2ej4qOo9o1KNMND3za3pWyHerjIzMJwqTyURvb6/n/5GRkUxPT3vCUAW1EuY4ia/WlhMTEsb7Bae4crOU252tVDXVk7d3O3Epiej8fYhMikcR5sdtL/MnOgNaFggyMjKfKOb6EWaZG4YqqBQIM93UhsZHae5uZ1V8CinRcZwpK+QfP/gBEdFROL3VJO3bgO+6JJwrAvjsF9/ko48+ei7X9KyQBYKMjMwnjrl+BAB/f38CAgI8YaiqlDAkhcC1WxVEBIWi1+r4/JZ9tPZ2ggRWo4bq6mr8/f3R6XRYLBaSkpJQKpXcvHnziecnWWzYG3qxFjVivd6Mo2MYaQEn97NGFggyMjKfOGbzEeayevVqqqqqcDgciAYNTfppggOCsNps6DRaxqYmCfT1I2FVKnZRQq/Xc/LkSSRJwmKxAPDGG288sZbg6Bl1l8VoHUQasyANm3HU9WC93IBryvbwAZ4iskCQkZH5xGEymejr65v3mVar9YShTg2PcfP0VVZGxQMwap7AYp0ma0U6roEJmLSh1WpJSUnh6tWrtLS4u7GtWLECtUbL8cJiLveOUNA7QuuEBdcSM5ddZiuO6s75ZTEAnC6wObCXND/XLGhZIMjIyHzimPUjWK3zM4pnw1DPvXuY7LgURiYn0KjVDE+MArA3dxMxQWFUF5awfv16bt68yb59+2hubqagoID+ySk0uZv43k/ep2l8iqYJC1f6RnmvpY/xh9S0AnC2DM5zaN+LZHO624M+J2SBICMj84lktq7RXERRJCIigtqKaqJNYXQN9tLa24mvzhu1UkVYQDBxYVHoNFoG27pJT0+nqKiIlJQUAoKD+du330XU6VF6edF2y+1LcEgSU04XJzsHH9oUyTk0OS/L+Wv/9Od8cOXMnB1cuIafXy9oWSDIyLyASJJEr8XKxZ5hjrT3c657iC7z9Ce2qNrTIDQ09D4/gtPppKOtndjQCPpHh7hYeZ3shFSu1pTRMdDDseKLFNWWY/DSc/HSJcxmM2FhYZSXlyMEhZGybgNNFWWExMZTee4MrjlFC20uifbJ6QfOaTZgtXuon//70dscuXaB0Ymx5b70x0auZSQj84IhSRKXe0foMFtxzAiAIauDnikbJi8128OMKORSFQ8lJCTEU9dolqqqKhISVxAshvHjc0exOxy0D/TwSu4mvrjrM0xbrfx04iSbE3K5PNLIiRMnyMrKYmhoiL/8n39OUFI6Gp2O0f5+bhVdRa3TsfeXfhVwawqtkxZivb0WndOIxsH1giuYp6c4V36N1YlpGH397u6gEFA8x9afsoYgI/OCUTM6Sbt52iMMZnHMaA3lg+PPaWYvF0qlcp4fYXx8nPb2dlauXIkU4kPf2DAW6zQGLz2RwaEADE2MEh8WRebKDHLy15KZmUlQUBCvv/46eTv3oNJqiUxNxzsgAPPEGNUFF3E57/a6WEyBm5iY4MKFC5T1NJEUHc/lqhukxyaSHp3I1LQ7ggkBBL0GwW9xgfK0kQWCjMwLhEuSuDlsfmAHtvqxKRyfkjaZT0poaKgnH6GwsJB169Zht9sp6qwjLjKKKes0WqUKo7e7B3VrXxex4VGoMiPJyclhamqK1tZWHA4HWcmJaL20XHr3h/S2tpL/6mtEJ6fQVFUOuBfTcL1m3vktFgtFRUVcuHCBpKQktr+yi/caCvH19mHVilQCff2ZmJoChYig16DOiX2uhQplgSAj8wIx5XDikCR37PvkBINdnXTdaZi3jyDAqM3+nGb4cjFb16ipqQmDwYDJZOLy5cuYwkIY8hF4/bXXKW26hY/egAQMOM1E7V2L6OOFt7c3JpOJcN9Aai5ep//ERcyjY0SsSKK1uoK8g28QlbqSm5cv4HQ4cAETdnekkd1up6ysjJMnT2IymTh48CAmk4m3336bCfs0e77yeeLXZqAL8kM06hAywlBvWIGgeb5WfNmHICPzACSXhKtv3B0KKIAY7IMYaFi2pzhJkpicnGRkZISRkRG6Bwcpu92G0+lCo9ej9/VDP9fGjNssIco+hCVhMpkoKiqiq6uLAwcOUF1djcvlYmBggNj4OLJ2beVSYyVSYhCjGQGE6dNR+uoAkJwu0hz+vHfiQ7qaWlBMWNnxy7/EByc+JCotneHuTrQ6PX6mEG6XXiclbz01wxMouttoun2b1NRUDh06hCiKuFwuPvroIzo7O9mzZw+Tk5Mkrs6mYbgLhULBpMpFwAvwN5UFgozMIrgmprGVNLvtNE53NImzaxRBq0SdG4egVT3SeHMX/uHhYUZHR3E6nRgMBoxGI/7+/qwJD2c8OoWpB1iERAH81PJPdykolUqam5vZv38/IyMjNDS4ta2NGzdSWlpKX18fmzZv4tq1a8S0tRIbG+s5drqijZqqaobHRlmbkklHfy/X6qqwmCfZ+ubP01FXw82C8xz8jW9w4UffxzcomP7GOwStSuXVV19Fpbp7f5w7d47GxkYSEhJIS0ujqqoKSXJnQyuVSkZGRggICHjm38+9yHeVjMwCSHanu52i3Tl/g9OFNGXDdr0Z9abEBTWFqakphoeHPYv/yMgIDocDvV7vWfjT09Px8/O7r5MXwGq1mWv9YzgWEApKQSDD6C1rCEtkYGAAjUaDUqnkypUruFwuNm7cyPT0NCEhIXR1dbFmzRouXbpEXV0deXl5APS1d3HpyBHiQiL4lf0/y48uHCHYz8jZk0fI2rWPttpqaq4WUHrmFAk5eVjMZm4WXGTnWz9PcqRpnjC4fv06tbW1hIaGsmPHDhobG0lOTsZsNmMwGFCpVIyMjDyvr2geskCQkVkAZ9cIuBYpNiaBZHVg7hhgXOmYt/jb7XZ0Oh3+/v4YjUZSUlLw8/Obt0A8jAQfPRN2FzdHJpAkcOF29gkCrPDxIt1PvyzX+ElHkiSKiorYuXMnx44dIyIigpUrVxIWFkZxcTFhYWG0trbi5+dHeHg43d3duFwubty4QW99C1uy1uKrdX/XgT7+/J+ffg9XmInK86cJTUjA5XSSnLuO4a5O9nzlV7j047cRBAF/zd2/9c2bNykrKyMyMpLQ0FCCg4MpKioiPz+fsrIy9Ho9arVaFggyMi8yzp4x5ob6dPT3MDg+wpR1mtHJcWx2O7rGQIKzVuDv709SUhJ+fn6o1cvTWjErwJsVPjrujJsZtzsxKBWs8NHhI5uKlkxtbS3h4eGYzWY6OjrIy8sjNTUVgP7+fqKiojxmmsnJSYKDg/mP//gPNm/ezL7tu3Dc6sFutVLTeoe6ljt09Hfz2Y3bGTH5o1Jr6ai/xY4vfhmDnxGbZYrwhGSarl3BmPpzADQ2NnLjxg1CQ0NxOp3k5ubS3NxMbKw7kmhWQxAE4b4EuueFfHfJyCzEnIDygbFhzpUXkRa9gvjQKPy9fdCo1IjhfqgzIp/aFAwqBVkBzy9J6WVmamqK27dvk5OTw9mzZ/Hx8SE7OxtwZys7HA4GBgYIDw/H4XBQXV3NwYMHsdlsJCUl4ZqycbOpntKGmzidTgJ8jeSlZqEdnyAo1MS1K5dYs2cvESuS8Q4IpOr8aVZv2Ur9T/4Li8XC0NAQxcXFGAwGRFEkLy8PlUpFQ0MDW7duBdxCKCQkhMnJSRQKBQ6HY0ET4rNEFggyMgsgBhhwTkzT0ddD2e0aPrv5FQxeurs7KEQUAYbnN0GZB1JUVER6ejoXLlxAp9OxZ88e+vr6iImJYWBggKCgILq6ukhMTORHP/oRRqOR1157jZqaGg4fPszIyAhTLd3EBppYGZPId068R0RQCEYfP4ItEt0qL1R2OwHBwWhVKrauWU2gbRz/NTm8++676HQ6FAoFUVFRuFwuQkNDGR0dRaVSYTC47xur1Yper2dsbAw/Pz/Gxsaeu2NZzkOQkVkAZXQAjV1tVDXVsWfNxvnCAEAUEEN8n8/kZB5IR0cHLpeLmzdvYrfb2bt3LzExMR6zTF9fH76+vpSXl9PY2Eh8fDxpaWk0NDRQXFzMiRMnCA4O5vNf/2VCI8K5XFPK0PgIf/Azv0h4YDBHiy/wa2/9HP5To3w+JpjPxYXw2tpsRgb6yc7O5uOPP8bhcJCZmUl3dze5ubkA1NXVkZyc7JmnJEmekFR/f/8Xwo8gCwQZmQW4ebuONp2VPWs3odVq724QBVCKqNfEIijkn8+LhsPhoKSkBLVaTXt7O/v27cPX15fg4GBPf4SamhouXbpEQkICu3fvprq6moqKCo4fP05cXBy/9Vu/xdjYGFeuFaJaFUXMukzS0tMJiongzkQfG/fvpGagjby8PK5duwaAIAikp6fz3//936xatYq2tjZaWlpYv349SqUSp9NJV1cXUVFRANhsNjQazTyBMDw8/Ny+t1nkO1pGZg6SJFFcXMzw8DCv/Mwh9FvTUMQEInhrEXy8UKwwodmchOj7/OrNyCxORUUFvr6+FBcXs2vXLsLCwgB3PoIkSZw5c4b6+nqysrIIDw/nH//xHykrKyMsLIyvfOUrJCYm0tjYyNDQEHl5ecTHxzPsnCIiN42xeG+GsbI6by06nQ61Wo3NZqOzsxObzUZNTQ0+Pj6eMdRqNSaTCYDW1laio6MRRfeSOzk5iV6vR6FQ4HQ68ff3Z3R09Hl9bR5kH4KMzAwul4tLly5hMBjYsmWL+0MvEVVSCCSFPNe5yTyc0dFRmpqa6OjoIDc3l7S0NM+21tZW7ty5w8qVK0lKSuKdd94hNDSUoKAgvv71r1NdXc3ly5cJDAxk9+7dWK1WCgsLMRgMJCYm0tfXx09+8hPeeOMNBgcHMRgMOBwOEhMTuXbtGiqViqioKCYmJpAkibCwMDo6Ojznr6+vZ+PGjZ7/m81m9Hq9R0MwGAxMTj6/xjizyBqCzKces8NJzeAo//H+YZS+/qxZs+Z5T0nmMSgoKKC7u5uwsDC2bNmCy2xlorqVU//+Drcvl7Ihdx0ffPABV65cISwsjN/7vd/DYDDQ3t5Oa2srGzZsYNOmTZ4EQoVCQVNTEzqdjoGBAcxmM5s2bcLLywuHw8HWrVupqKhgZGSE0dFRWlpaOHjwIF1dXezbt4+GhgaGhoYYGxtDEAR8fO5GjE1OTmIwGDwagiAIiKKIw/HwrmtPE1lDkPnU4nRJXO0f5c7gMDVXC4hITKbNN4Sh9gF2hBnxVsk/j5eF27dv09jYCMDrr7+Os76XxpIqKu7cIioolMqaarpO9+GwmvmF3/kNHA4HFy9epLm5ma997WuIooiv7/wgAafTiSiKdHZ2cuPGDX7pl34JhUKBVqtlZGQEg8GAzWYD3BrIgQMHaG9vZ926dfT09LBjxw4++OADMjMz5zmTwa0hBAUFeTQEAD8/P0ZHRwkMDHwG39jCyBqCzKeWy30j1Pf0U3npIlHpmQRERuOQJMZsDo51DGJ1LpKpLPPccU3ZcI1OIU3bsVqtnDhxgsHBQb7yla9gbe7jzMfHqG5qoH9kiGPFl4gPi+IPP//LGEUvSs4V0NTUhFKp5POf/zzBwcEIgjCvG11vby8ajYY1a9bw4x//mMjISM+i7nK5PNVMo6KimJqaIj09nVu3btHQ0MD69euJj48nMDCQ5uZmbt68SUxMzLz5z2oIcwXCi+BHkB+BZD6VjNkc1HV0c6vkGklr1uFtNHq2SYDdJXF73MxKf+/nN8lHQJIkpNEpnF2jSHYHgo8Xygjjcy+nvNy4RszYa7uRzFZ3xJdL4mRNMXW3avmDP/kj+nr7uPSfP2VgaJAx8yRbV+XxC3veQBQFym7XMjAyhKGli1//49/jxIkTREdHL3ie0tJS1q9fz/T0NNXV1XzjG9/wbBsbc7e8bG5uJiMjg8TERMxmM/39/WRkZKBQKFi5ciWHDx/2FLKbdSbPMutDkCQJ50yDHX9///t6QD9rZA1B5lNJye0m6kqKSVu/CW+jEafDgW22cxXglCQaxy0PGOHFQXK6sN1owXajFWfHMK7ecZyN/Vgv1ePoev6x7cuFa8SMraQFaWIaXBI4XHT39/He8Y85uGItNwqL+c6//Tv1LU1krUjjz37u19icsYZf+daf84PTHzI6OcGeNRvRq7RMj06gUqk8IcVzNYT29na8vb3x9fXl6NGjrFy5kvb2dgBGRkawWNz3hU6no66ujl27dmEwGNBoNJ4sZYVCQWZmJj09PQiCQGdn57xrmZ6eRqvVztMQjEbjc89FkAWCzKeOxsZGqivKWbl5K14GtwYwOTJM+62aefu9LF3J7Dc7kUamPCW6AfeC6ZJw1HThGjE/v8ktI/aaLvd1zeByufjfP/0u4YHBfHzlLOePnGTXtm385Vd+i22r8lAqlIxPTXKp8jofFZ7j3QtHuVR1ndrWO3x05GOcTic9PT2eBV6aaUxUXl7O6tWrqampobe3l71792I2mxkcHKSyspLR0VFeffVVLl68yNatW5mYmMBqtZKenk5YWBhXr17F5XIRHBzM+Pg4e/bs4b333lvwmmadygB6vf65Rxp9svRJGZk5SJJ0X3nqmzdv0tnZyYF9+ygZNmOfeSpUqFQ47PO7kBk1j9bv4HkgTdtx9Y3PWyjn4ZKwN/ajWRO78PaXBJfZijRlm/fZP7z3n1y9WUZqbAJvbTvA9tX5eO1Iw3apwSMc73S18asH32TUPMG4eRJvnZ5ph41rpSWsW7eO8nJ3+8tr164xMTGB3W7H4XDQ0dHB8ePHSUtLIywsjNjYWE6ePEl9fT1f+9rXKCoqYu3atVgsFq5fv87GjRvx9vbm6NGjmEwmqqurcTgc7Nu3j/HxcUZHR2lubiYuLg6r1YpG4261OVdDEAThudc0kjUEmU8UktWO/VY302drsZ6qYfr8Lex3+nDZHVy/fp3BwUF2795NvL83c2WFSq3BYbu74CgEgZX+L36tItewmbkXMjw6zN/9+Dvz9pGGPwEagtXh9hnMMDo6yt+8++98ZsNOvvvbf82unA0oFAoEl4QiOgBEAZfLRcdAD2uTM4kLjUCpVOKt1xMYE0F4eDgbN25Er9djsVjw9fUlOTkZi8XCmjVrOH/+PH19fTQ1NXH9+nUKCgooKCjAZrNRXl5OaGgoa9eu5dSpU0RGRhIQEIBarSY/P9+z+NfW1pKbm4soiqxfv573338fwFPlFO4KBEmS6LNYaXWK/KSmkQvdw/RMWec5up8FskCQ+cQgWWxYr97B2T4Ejhnzic2JvbGPs//6Di67gy1btiCKIgpBYHuYEaUgIDCrIbgFglIQSPPTE+y1PKWsnyr3LBg9I4N8/9QH/Ol//iP9I0Mz+zyHeS03WtU8LcjPz48//cLXiAuL5MSNAjoHZ5yxKgXKFSbEAAMdQ72EBZjw8/Yh0NuI0ccXh1okc2MuFouFuro6srKyeO2114iIiKC0tJTR0VGqqqro7u7mK1/5Cjk5ORw6dAiz2cxnPvMZOjo6uH37Nt3d3Zw7d46jR48yMTHBzZs36ejowGAwEBAQ4KmmKooia9euZWpqiunpaRoaGjxZyrNIkkRB7whnuoYZU3nRMTBIm3mac93DnO8exvUMhYIsEGQ+Mdhudro7nM35/dgdds7euIpRoycnIHaeCSnES8OrUUGs8NGh12jA6STES822UH9WB74cZacFf/08oWDQ6fnMxl30DQ/yDx/8gDM3rmJWv/zhs6JOjeCtnffZqvhkbA47m1au4U5nK2ebKxibGEcQBVSro2nUTpGSnYGvKRCbQYkz0MCWnznAjRs3SExMZPXq1Vy8eJHy8nIMBgNqtZrf+I3fYHx8HF9fX5qbmzl9+jQ/+clPWLVqFWq1mtjYWDZt2sS+ffswGo28+eabBAQEoNFo6Onp4dq1a3R2dvLee+9hNpt5//33GRgYQKvVkpWV5fl8rkBon5ym3TyNQ5LQ+/phnolickgS3RYr5UPjz+x7ln0IMp8IpGm727E6RxhM26ycKy8iJSqe+LAonB0jKJNCEeaYHnzUStab/FhvAm2IP69EPL+koMdB1KkRjHqkoUmQYMw8SXRwKBvTV1Pb1khtRyNDtwRS9RaysrKWrYHP80C1MgLbtSaPfyDAxx+700lrXydbczcwmuBNQUEBAQEBJCcn4/JSYtqSgWZ0lO6m60SuiMFisbBixQoaGxvR6/UcPHiQ2tpajhw5woEDB6irq8PlcvHFL37R090sPT2dpqYmfvCDH/DlL3+ZqqoqLBYLMTExGI1Gurq6WLdunWeeZrMZi8WCIAgMDg7S19eHKIpcvXqV9vZ2JiYmWLt2LQA+vr40jYzhN3Pf6n396Gm64xnLKUH96BRZRh8U4tNvmyprCDKfCKQp2zwbs8vl4kxpIasSUogPi5rZSQL78y0N8DRQr4pC0GtAITI+NYnR24+c5HQigkMwJcag9NUzNDTEkSNHqKmp8TgxXzZEby3q/HjEIG8QBPz9/DD6+NJuHUVaHUFIdAQHDx7EZDLx/e9/H3DfB97e3p4eCG1tbaSmppKdne2x6a9YsYLAwECmpqZ4++23CQsLIyQkhBMnThAbF8eKteupGBwjLDcfZ3gMZruTb3/72wwPD2O322lra5tn629oaCAvL4/09HRiY2MZHx9n165dfOELX+Bzn/scXV1dJCUlIQgC9c3NdNy+zY2TRyk+8hHXPv6Aj7/9j/f5Dsae0X0rCwSZTwYqxTztQBRF9qzZSETgnKJ0kgQPKFl9b7bqy4KgUqBevwJVZgQTSifBEaGIoX6sfn0XsTnpaDQaJEnC39+fqakpDh8+THNz8/Oe9mMhGrSoc2LQbE8hZFc2U4lGVh/aTmXd3ZDh+Ph4oqKiCAkJ4fDhw9TX1+NwODCZTOh0OiYmJsjLywOgsLCQyspKkpKS0Gg0hIaGMjExwY9+9COsdjuTYTF89/gZJhVqvKMTGNb50SQpyd6xm9DQUIaHh7nVcJv//d3/5IOiG1R393OnsYm4uDgyMzOx2WzY7Xbu3LlDWloa09PT2Gw2qqur3dFHwyOMDQ/S29JMY8UNqi+fRxTm36MS8PR1AzeyyUjmE4Fg0LiFwpxYfPU9je0Fox5BqVh0jNlyxrMhgS8TgiigMPniivIjJD4eq7c36bGxHDlyhDVr1lBeXk5ISAgdHR2sX7+eO3fueKJgZks0v0wIKgXeQUYmp8zEx8dTU1PjKQfR1dVFWFgYa9asIS0tjcOHD9Pe3u7pOzC7n4+PDxaLhZKSEkJCQujt7WXjxo2o1WrKysoobGoDH398goLx8vbB4OdPa+1NAiKi0IeGcb3mFmlbd+C/DXqaGrGOTHD6yjsM9/WCtzeJISb8/f05e/YsBQUFZGdnY7FYcDgcfPDBB+zfvx+NRkOgyYQxIpKo1HQG2tuISkmb5+tSCOD7jHppyxqCzCcCQRBQpobOMxvNQyGgSgp94BizAuFlxel0olAoPKWUZ8Mda2tr2bRpE21tbWRlZXH16lWioqLYuHEjlZWVnD17lvHxZ+e4XC4EQfA0n8nOzqasrAxwl5pOSUkB3NnE0dHRREVFce3aNQYHB1mxYgW1tbUef0pAQACFhYUolUoMBgMDAwN87otfAm9fWm/dBEliqKsDhUrF2GA/EUkpePn6cWfawbGLV5icmKSpuorhnm562tvwDgzkfE0DZwquUlVVhclk8pSl8PHxQaPREBUVRXh4OHFxcRgFiYz1m5AkF8HRMQSER9y9RiDN34AoPBsdQRYIMp8YlCZflBkRbk1BId59aVWoc2If2tRGo9FgtVqf0WyXn4mJCXx8fObV1g8KCvK0Z1y3bh0VFRXs2LGDmpoaGhsb2bVrF+np6Vy8eJGioiKmp6ef81U8GrMVQqOiohgfH6e3t5fJycl5FUN7e3sJDw/HZDKxdu1aGhoauHr1KgqFgra2NlJSUjwhoi0tLWzfvp2O0XE66uvY/ytfxz8kjJtXC/j2178KgkjFudOUnj7O2MQkN69dRXI6CYmNwxgaTmx6Bps++yaZ23fjk5pJTEwMGo2G3t5e6urqGB8fJycnh5CQEL797W/j7e3Nrg35+E+N4RcYjMNmwzcwaN413hoxM2Z7Nj4E2WQk84lCGeqHIsTXnbBldSB4qRH8vO7LWF6Il11DGBsbw8fHB29v73klENasWeOJolm9ejWXL19mz549VFVVcerUKbZt28bBgwdpamri+PHjJCQkkJ6ejkKxuHntRWG29WRgYCBr1qzh448/nteIxm63MzIyQnR0NC0tLWRkZJCens6JEyd4++23yc3Npbm5mYiICKqqqviDP/gDBEGg6NIFQmPi0Pv6MtTTxcTQINYpM2Fx8QSER6KYySQOjoxGcrmITs/g7NvfIy59FaWnj6PVGwgICeOtzZvx8fbGbDZz5MgRmpqa6Orqwm63o9PpKC4uxm63441AZHIWI329KOdEgknAtMvF6a4hPhsTvKT7+EmQBYLMJw5BEFAEPHqW8SdFIOh0Oszmu9nJarWarKwsrl+/zqZNm7Db7Zw9e5bdu3fT1dXFsWPH2Lx5MwkJCcTGxlJbW8vhw4fJzMwkPj7+qS9CT8Js2CdASEgInZ2d8/oa9Pf3ezqSzc0OXrNmDQUFBZSVlREQEMD09DRf//rXKS4uRq/XkxwVye0pO8N9vZz63r+Rtn4jdmsurbdqCIqKAdzmnPDEZCrOnsLpclJ75RI7v/iLBISGISoUCIBO7z6nSqVCqVTS1tZGcnIyX/3qV3nnnXcoKCjAbDaTvHk7Y4MFKNXqBUuuWJ0uuqasROjn52IsN7LJSEZmhpfdZDSbULXQAh4fH8/k5CR9fX3ExcWRkJDAuXPniIyMZMeOHVy5coWGhgYUCgUZGRns27ePgYEBjhw5Qnd393O4mqUxtzl9b28vOTk5VFVVebb39fV5SkPMCgSAsrIy1q1bhyAICIJASEgIt2/fxtvbmxs3bhAWHITeNs3FH36f2PRMQmLjiUpJR6FU0dlQh4hbIIiiiN7Pj5JjH7N61z6CIiIRZzQrnVKBQnCHoR45coRVq1axbt06bDYbY2NjZGVloVQqCQ0NJXnrLpx2O9PmScpOH+f2jetY5mh5Dkmi1/L0701ZIMjIzPCyawizAgHcTeXt9xTrW79+PUVFRbhcLpKSkoiIiODChQv4+Phw4MABurq6KCgowOl0otVqWbduHVu3buXWrVucPn36uTdvWQi9Xs/U1BTgdiavXbsWrVbr0Rra29vx8/PDYrF4soM7OztRqVRMT0/T3t7O7t272bp1K76+vly8eJGVK1fyr//6r/SUX+fAz3weU2QU05OThMTF4+Pny2BHG+kaCNVpmBweoqW6Et/AQLwD7votlAKEO6c4evQoIyMjHDx4kBUrVpCUlIROp+Py5ct4e3vj7+9PZ2cnLpcLUaEge+crZO/aiykmFsU9EXHCMwg+lQWCjMwML7uGYLFYPPX9F2ra7uvrS3R0NDU17pj99PR0AgICKCgoQKFQsG3bNgICAjh27JjnWB8fH3bs2MGqVau4cuUKV65c8SzALwoqlYrJyUmGh4cJCQkhJyeH0tJSJEmiq6sLg8FAREQEWq0Wi8XiiUZqaGhgx44ddHd3Y7FYaG1t5Q//8A8ZHh6mqKgIk8nEtigTO5PiifDWkRETRaB9mt89tJee6nKy9AoaCi/hGxhIXGY2kyNDOGw2XDYrwzUVjNTXsnHjRvLy8jwRTXa7nW3btjE8PMyHH37IW2+9hV6vp63wEgpRRKFUutt5BgWj1t4NglAKAhH6px8OLQsEGZkZXmYNweVyzevKtZBAAMjMzKSxsdGzLSsrC61Wy7Vr1wBIS0sjLy+PU6dOzWvqYjKZOHDgABEREZw6dYry8vLn3hB+Fn9/fyoqKkhISADcQiwgIIDKykrsdneLzbi4OHx9fbl58yYqlYqCggL8/f35+te/zq1btygpKSErK4sLFy4wOjrKV77yFaKjo/n7v/97lDYLGxOi2RkZxAqjDyajP76+vrz79tvkBvuzPiWRzNWr8fX1pa3wMraKa+xfmcz+/fvx9/efN9fJyUkSExOxWCyIokhISAiRkZHcvHweH3/jQpeHAPioFARrn37ZEVkgyMjM8DILhImJCby977b7XEwgKBQK1q5dS1FRkeeztWvX4nK5KC0tBdyL/759+6isrKSiomJe9nZsbCyHDh1CrVZ7soCfd3a3v78/VVVVrFixwvNZdnY2V65cweFw4HK5CAoKwmAwUFJSQmlpKZGRkWzduhUfHx8cDgdTU1PcuHGD3t5e3nzzTYxGI1/5ylcICgriypUr1NfXMzY2RmhoKN3d3YyNjTE6OkpwYCA+9mkOJcWwQiMitd3my2+8Rnx8/IJztVqt3Llzh7y8PI/JLi0tDYUg4DvYiVoUUM7xASkFAV+1kl3hAc/EuS8LBBmZGV5mk9HY2Ni86JrFBAJAeHg4SqWS1tZWz2fr169nfHzc45D18vJi7969WK1Wzp49O09QiqJIeno6Bw8eZHx8nMOHD9/XIvJZ43K58PK6a2LR6XTY7XYmJiaIiHAneg0NDXH79m18fX0JDAwkPT2dmpoaIiMjqaqqYnJyktdee21epFZObi6iRktwaBiXLl2iq6uL48ePYzKZCA0Npa2tjfb2dmpra9m8eTMbNmygvr5+0XlOTk7S2NhIfn4+O3fuZGhoyJM3cedmNQdM3uQF+RLv7UWij47tYUYORQXh9YAM++VEFggyMjO8zBrC+Pg4Pj53S3Y/SCAArFu3jtLSUo/jWRAEtmzZQl9fH3V1dYB74c/LyyMhIYFjx455onlmUavV5ObmsnPnTu7cucOJEycYGhp6Clf3YPr6+uYJw1kEQWBgYICoqCgcDgdXr15laGjIU9yut7eXa9euodFoUKlUxMTEYDKZGB0dReftw4cVtdxEy6B3AGfbehgJjWXUaqOoqIj6+nqCgoK4fv06kZGR7Nmzh+DgYCIjI2lubl7Qz2I2m7lz5w6bNm1CoVBgMplYs2YN1dXVxMTEEBAQwPGjR1nhq2NTiD/rTX6E6TTPNOxXFggyMoBrzIJ0q5ep6jas15txdo8iOV+eqqCPoiGAWwNITU31tJAEtwDYvn07LS0tNDY2ej6Pi4tj27ZtXL58ed7nc8+1detWcnNzKS4u5tKlS/PyIJ4mDoeDkZGRef0FwO1gN5vNhISEMDQ0xKlTpxgdHSUjIwObzUZgYCDvvvsuWq2WwMBAUlNTGR4exuFw0DswSJnFRW1rO15+/ii1WtI2bObCieNc7xkkeVU2Z8+epa6ujlWrVgEwNTWFl5cXNpuN7Oxsj/ltLlevXiU+Ph6j8a6vIDc3F0EQ6OvrY+vWrVy8ePG5lhGRBYLMpx777T5sxU24ukeRLHakYTP2mk5shY1Iz6hkwJNyr4agVqvvCzu9l5SUFPr6+uY9+SsUCnbt2kVdXd08k5Kfnx/79++ntbWVwsLCBUtoBwYGsm/fPuLi4jh9+jQ3btx46hrXbJ9irVY7z9zX29uLxWJh06ZNXLlyhZMnT7JhwwbGxsbIzs7mn//5nwkJCUGr1bJ7924CAgIIDQ2lvr6eG+1dKA0+TIwMI0kS3sYAps1mFGoV7fV1XLxRxle/+lW2b9+O90wW8smTJ/Hy8vL0SZiYmGBwcNAzn66uLnp7e0lPT583f1EUiY2NxWazodfrCQ4O5sMPP3yq39mDkAWCzKcaZ/84ztaB+5vUOyWkKSu2yvbnM7FHZGpqCp1Od9/nD3L4CoLA+vXrKSwsnLefUqlk9+7dVFZWeuL5wR3euWPHDry9vTl+/PiiWkBUVBSHDh3CYDBw5MgRbt269dR6MDQ0NJCYmOip1zTL7du33ZVEAwNpampCo9EQHx+PTqfje9/7HpGRkWi1Wnbs2IHRaCQgIAAfHx/q6uqo6+xFEkBr8GZyZASlSk3hR++hUmuJWZmJ3hjAqNVOZ2cnb775Jnv37uX27dscO3bMk6uRl5dHcXEx4HYkFxcXk56ePi85bhaHw8H27du5cuWKRxO71zz3rJAFgsynGkdjv7st1QzzeiJIII1M4Zp6sf0K94aczqLT6R6aMxAQEEBgYCANDQ3zPler1ezZs4fr16/T19c3b1tGRgY5OTmcOnVq0SxmURRJSUnh1Vdf9fRgmKtxLAejo6OoVCoMBsO8jGVwJ6mpVCoqKys91UYrKiro6upCp9Oh0+nYvn27Jyw0KCiI4eFhYuLi6e9sZ2JkBH9TCBPDQ1QXXCA6bSXZu19BcjrZ8JnP8uGHH+Lt7e0ROr/zO7/D5OQkFy9epLKyEj8/P3x8fGhpaeHKlSusXr0al8t1n2lramoKjUbDypUrCQsLo6Ojg8jISH784x8v63e1VGSBIPOpRhq3zPu/WqnC5phjahEEpNEXKxHrXmbr+9/Lw/wIs+Tk5FBTU3NfpdNZc8rVq1fnmT8AQkNDeeWVVygrK6O6unrRsVUqFTk5OezZs4f29naOHTvGwMDAEq/swdTX15OcnAy4axrNaghOp5Pbt297spMNBgPR0dFcvnwZf39/lEolO3fuxM/PzzOW0WhkYGCAxIR4JoYGGentwS/YxPTkBPu++hukrttA281qolLTiViRhOhyMjg46Hl40Gg0vPrqq+j1ekRR5PDhw54kP4VCQUxMzIJ/p+7ubkwmEy6Xi4MHD9Ld3c3q1aspLi6mv79/Wb6nR0EWCDKfbu6J4MhekYbi3qftF7e2G3C/Q3mWpQoElUrlWYTuRa/Xs3PnTi5fvnxf6QqdTse+ffuYnJzk3LlzD/RZ6HQ6Nm3aRH5+PqWlpVy4cIGJiYmHX9wiuFwuOjs7iYpyt0edqyHUNDVTUlsHKav4adENLIGhFJbcQKlU4ufnR2Zm5jx/C7g1GrVazeDgICsTE+lpvINSrUGt9UIURcaHBpk2TxIcFYPS6SAmPAxvb2+uX7/uGSMmJgZBEPD19WXfvn10dnZSWVnpSeAzm833aQhzBcJsCZHq6mri4uJ4++23H/v7eVweKhAEQdAJgpAlCIL3AtvWP51pycg8G8R7qqKa/ANQKuYUAZak+/Z50bjXoTzLUgUCuBPOpqenFzQB+fj4sG3bNs6fP3/fIi6KIvn5+cTExHD06NGH1jsyGo288sorJCYmcv78eYqLix8r96O1tZWoqCiPqWw2h6RlzMxf/tv3UBuDGBoawup0cr20jEG1juDYOGJjYxfMsBYEAZPJRGNjI5szUrFNjjE+OIC3MQBJkmiqKCMhOweFIBA2OUR2djYhISFYLBZPKRBwO+pnhYTVauX3fu/3uHz5MidPnmR0dPS+bnwDAwMEBgbidDoBdzmRuLg4jEYj5eXl83w4z4IHCgRBEHKBNuAS0CcIwu/fs8vJpzQvGZlngjIhePEua6KAGOqH8IzaFz4uT6ohzLJ+/XqKi4sXdAD7+/uzefNmzp49u6BfIiEhgS1btnDhwoUl9WuOiIjg1VdfxWg0cvToUW7evOlZFJdCfX09SUlJ8z4T1Wr++ScfMD4yRERiMlUXzmGKjmVieAit3pvYAz+DpFTS09Nz33iCIBAcHExTUxNKAT6zLhdzYz0+AQH0N93BPziYiKAAdocbGeloZd26dfT09LB582ba29tpaWkB3PWiUlJS+OEPf0hERAQpKSn84i/+Imazmaqqqnm5H5OTk+h0OpRK5bzv/DOf+Qyjo6PExMTwve99b8nfyXLwMA3h74E/liTJF8gHviAIwv+bs/0FV6ZlZB6M6Kdzd1kThfmCQRQQAw2o0sKe3+SWyGIawr2Nch6Gt7c3cXFx88pHzyUwMJD8/HxOnz69YGc1o9HI/v37aWxsXFSwzEUQBBITEzl06BAOh4PDhw8vSZhMTEzgcrk8QnDa6aK4f5QjlXUgikwMD9F26yZxq7Lob29FoVaz8bM/i0anw5i08j4H+tzr6+rqwmw2s2v7NpztjXwuKZqQsT5+Z+8OXo0KRpwcx2Aw4Ofnh91uR5IkduzYQVVVFb29vWi1WlQqFT09PQQFuTufxcTEoFAoWLVqFTqdjo8//piGhgZP72dRFOd9Vzqdjs997nO4XC5u3rzpETbPgocJhHTguwCSJFUCG4BkQRDeFgRB9j/IvDRINgf2pgGs15qwXmvC3jKAZHc/kSpD/dBsS0GZFIIY7o8iNhD1unjUq2MQFC/+bb5YyOlSoozuJSMjg5aWlkWTo0JCQlizZg2nT59eMMdArVazc+dOtFotJ06cWNL5lUolWVlZ7N27l+7ubo4cOUJvb++i+zc0NHicydNOJ0faBzhzrQS1Tg+CQE9TI3ofX+yWaeqvX+PA134TjZcXTgkcPn6oVCra2+eHE8/2RZAkicnJSYKCgtDr9Vw6d5at6/Lw9XKbeurq6jz9moODgxkYGECtVrNr1y4KCwuZnp7mypUrfPWrX6WkpMSjDaSnp9Pe3k5qaioHDx5kZGSE9957D1EUUSgU92lHSUlJZGZm4u/vz7/927899DtcLh52t08BngafkiSNA3uAYOB9ZA1B5iXANWLGeqkBZ2Mf0ugU0ugUztt9WC/V45qJIBJUCpQxgagzIlAlhyL6PLj/8ovCbJTLQuUN5oXQLhFRFFm3bh2FhYWL7hMREUFGRgZnzpxZ1B6/atUqsrKyOHny5AMX97l4eXmxYcMGNm3aRHV1NWfOnGFsbGzePpIk0draSmxsLAA3BsdpamhgbHiIyJRUrh1+H6VKxYqctXgHBrBmz34m5oSjKkWBnJwcCgoK7puz1Wr11EOamJggNDSU27dvexzXdrudgYEBwsLcWuNsoTtwC99t27Zx5MgRQkNDMZlMpKenU1JSArgFZUBAAK2trajVavLy8oiKiqK7u5vCwsIFBfDrr79OUFAQN2/e9JQTedo8TCBcBt6c+4EkSdPAQUAFvBy/GplPLZLdie1GKzhd85PPXBI4XNhutCA5lm67ftFYLOR0loUa5TyM0NBQdDrdA803sbGxJCYmcvbs2UVt/+Hh4ezevZuSkpJ5jteH4efnx65du1i5ciWXLl3yPHkDdHR0EBYWhkKhwOGSKKm7TW97C4ERkfQ03WGgqxOdjzeB4eHkHXiN/M+8QUddLUPdXSgFgQRvHREREZ4opbmMjY1hMBgQRZG+vj4GBwfZvHmz53toamqa11I0NDR0nrAbHR0lKSmJpqYmbDYbSUlJjI2N0dvbi9lsZs2aNZSVleF0OhkfHyc4OJjdu3eTkpJCcXExxcXF87QutVrNl7/8ZQwGA9/61reW/P09CQ8TCF8HPr73Q0mSbMBngK1PY1IyMsuFo3MEd6vyRZAknF2jz2o6y85sH+XFeFTH8ixr166lvLz8gcIkMTGRqKgoLly4sKi/wGAwsG/fPkZHR7lw4cIj9VAIDQ3l4MGDhISEcPz4cSorK6mtrfWYi9q6uuioq8UvMJj+1haytu+m63Y9K3LWYbdaablZSW9zE8FR0dwqLKC3oZYAwYm3tzfR0dGeJjrg1hBGR0dRKpVIkkRxcTFpaWnk5+dTXV2NJEmerOhZdDodFosFl8uF2WymvLyc/fv3ExUVxblz53C5XGzcuJGioiJGR0cJDAwkPj6empoauru752kamzZtwmg0cuTIEWpraz3fZ0JCAq+99hpVVVXcuHEDyWLDNW7xmDuXmweGT0iSNAAsmEUiSZIDKFhom4zMi4JrcGJeJvJ9OCX3PtEBz25Sy4QkSYyNjC5JINzbqOVhaLVaVq5cSWlpKevWrVt0v7S0NOx2OwUFBWzevHlB05VCoWDDhg3cvn2bo0ePsm3btgWjohZCEATi4+OJiYmhtLSUS5cukZCQgCRJlBQVovLSYZ22kL5pK6Io8r9OX0Hv7Y192oLNOo3dasU5PU1iUiLm8mscHu5BFEXu3LmDWq2mv7+f2NhYWltbGR4exmq1IooiNTU1/Mmf/AmiKBIUFERFRQVeXl73+WoCAwMZGBjw9GjWaDQYjUaMRiMFBQVs2bKFpKQkLl++THJyMmFhYRw+fBidTseaNWsAt5lOkiQSExOJi4ujsrKSw4cPk5OTQ1RUFJ/97Gc59uHH/K/f/RN+/Cf/4A5+cEmIgd6o0sIQtKpH+Ms+mBffYyYj8wQsqXLwMywvvBy4JqaxlbViPV3D4LlKtDcHsDcNIC3wlP64GgK4NYChoaH7spTvZTZ6Zm7TncXG27RpE+fOnVtyGQuXJDFmczDplFCp1bz11lu0t7fzt3/7t4yNjBAXFkLSmjxPPoIxOBiNlxcGfyPGkDCi4+L56o6N/OHrB/ij3/99fHx8yM/PZ9WqVfz2b/82/v7+xGdkQUAwbUOjBIeH09XV5cl2vnDhAu3t7fz93/89ra2tHD9+nAsXLlBUVERFRQVTU1N88MEHCIKAwWBAqVRisVhYuXIlGo2GGzdukJqa6im2p1AoPNVQAwLcDyGiKHrMbkqlkpycHHbt2kVTUxMnTpxgpKWb/7H/SzS2t3C+tAgcbvOnq38ca1EjknX5CjC+2AHWMjJPiGjyxTU85fYhLIRCRBGytKfVFwHXiBnbjRaP1jNunsRHpcXZ2IdrYBx1bhzCnPBZg8FwXy2ipSIIAvn5+Vy9epUDBw48sC5/bm4uhYWFlJSUkJubu+h+AQEB7N+/n4sXL9Lf38+aNWsWHFeSJGpGzdwcnvAoeGVFZXzuwF56qquJj4/HYDCgsU4yND6Gxuf+v6FCgC0h/gTOtJ7UaDTs2bOHkydP0tfXh6RS0+7lR1PlLaYFNW2j4wT4BGELmmJFQADbtm0D3MXnmpqa2LlzJ2FhYVgsFqanp7FYLAwODlJRUeFxIJvNZoqKijzRVQ0NDdy6dQtBEPjpT3/K3r17cTqdmM1mOjo6iIiIQKFQ3Gdymy0p3tfXR8F3P8RX7cUbm3fzP3/4r2zPnqOx2Rw4mvpRpS5PeLQsEGQ+0SjC/HDc7oXFTK5KEdG0uMnlRUKSJGwV7fNMYOZpC3qtF7gkpHELzs5hlFF3zV8Gg4GmpqbHPqfRaCQkJIS6ujpSU1MfuG9+fj6XL1+msrLS0ydgITQaDbt376aiooKTJ0+ybds2tFrtvH0K+8donrDgnLHxj/T1ovbx5T9/8j6+OPnGz79FcHAw/f39nL1ylRangpCUdLQ6HZIEWoXIepMfoTrNfefes2cPf/lXf8V3rpTgG7uCigtn8AkyMTU5yWBXN6HxSTTcuIYkSQiCQHNzM1u3bqW6uprY2FhPtrHD4aCyspINGzawceNGj2BzOp289tprHt/C0aNH8fLyIiEhgcrKSgDCwsL4wQ9+QEZGBiMjI3R1dTE0NISXlxdeXl5otVq8vLzQ2CErLpn+wQGigsMYM4/zb0fe4WsHZ2J9JHB2jqBMCV2WRjqPbDISBEGc+3riGSwTkiTheIkamsg8GwSFiHptHKiVMDenQCGCRol6bdxLkWsA4Bo2u80FM9wXcuqUcLbMN+88icloluzsbOrq6h6aUyAIAps2bWJgYIDa2tqH7pudnc3KlSs5fvz4vEJuQ1Y7zRNTHmEA0NN4m86GeiyTkyTs3IfC1+0TCQ4O5q3XX+MLuZmob5Xh39PCDpMPb8QEE3aPMJhFq9WSlLeempLrjA0PYoqJo6O+FuvUJGEJK7BaLCh9jbQNjwLup/ysrCz8/f3p6OjwjFNSUkJSUhJRUVGLlqvWaDRs3bqVoaEhEhISmJ6eZnJyks2bN5OQkIC3tzeJiYmEhIQQHByMKIoMDw/T2NjI9evXOX7iBO9eOMax65eob2smKiiMb/74P+afxOmCZeprvSQNQRCEbOBfgQxgVpQLuMM3nk2zz0Wo7hzlH87c5sqdQVySRJRRx9e2xPMzOZGIi5UkkPlUIRq0aLYm4eodxzngrsWjCPZBNPnMM6+86Ehm27wffntfN2fLCokJCSfEP4ggX38U0/OjgpbSKOdhKJVK1qxZQ3FxsceMshiiKLJt2zbOnDmDSqWaF5WzEJGRkfj5+XH+/HmSkpJISUmhYdQ8L0LYZp2m9MxJwlcksuln3kSlVlM/ama9yc+zT0xMDFFRUdTV1VF4+iTp6ekkJSUt+tQ8qdETmZZO681qIlPSaK4sw2F3oPfzp7m6Em9/I0cvFrAmwkRnZye3b9/G6XTyzjvveMpWNDY2kpWVRUtLC1VVVZ58hRs3buBwOFCr1SiVSsxmM0ajkffee4/U1FQ+/vhjVq5cSXx8PNeuXWPdunVotVrCwsJQKpWoVCqUSiVKpRKF2Y6rogOFJCyuAShEhAXKnz8OSzUZ/RdwFPgF3MlqLwQX6/v52n+XYbW7PIGFbcNT/M+jtyhqGuJbn1/lSc55ln1JZV48BFFEEeaHIszveU/lsRHUihkHuPtujw4JJz81G51GS1NPO8V1lai9NEQFTHuSo5RK90/8SX8DUVFR1NfX09XVRXh4+AP3VSgU7Ny5k1OnTqFSqTxJZIvh7e3N/v37KSwspK+vj6mY5HmBwm//2R9RX1KEKTqGpqpytDo9rgA/4lxRGAwGT8lpURRJS0tjxYoVnkid1atXexbquagNBhy9/azctIWbBZdQqjX4h4Yz2NHG5MgwgWERdHd20mwzk5KSgp+fH0FBQYyMjKDT6bBarfzyL/8yPj4+mM1mysrK2Llzp+d61q5d64n+amtrIz4+ntjYWI4fP05OTg4ajYbMzEw0Gg1TU1OEhIQsOE/JIGH16gfLIkJdAEXko0WQPYilCoRo4E+kR017fIpM2538xrsVTNvvNxNZ7E7O1Pby6r8Wcqt7HKckEReo59e3JXBoVbgsHGReSsQgb+7NqUiMjEGjUrM+LRtEAXuonkFv9yJ048YNRFGko6ODhoYG4uLiUKvVj33+/Px8zpw5w6uvvopC8WDDgFKpZNeuXZw8eRKVSkVERMRD99+8eTP19fV8dOk8fpk5aA3uAstf+eY/UHv1MteOfEBfeyvJOWuJMqTS0tLC5OQkZrMZl8vlaZZjMBjw9vYmJSWF6upqqqqqWLduHYGBgZ7zRQUGcudOIyqNlpWbtgAQszIDtUaLw+Egbe06hgov4BIVrF2/AS+Ve6k0GAz88z//M1/60pc8tYo0Gs28jGovLy+mp6c9AsFsNmMwGAgICCAiIoLR0VEaGxuJjo5m5cqV/PjHP8bb+75i0oDbtKbOiHQHEtzb1U8ANCqU8cEP/G4fhaUKhI+AXcDpZTvzE3LmVt8D0/KnHS6qO+/+kZoGzPzxhzUUNw3zzddXykJB5qVDUIgoE004bvd5HMuxIRHUtNwm2hQOShFDUiTeGqXnqdxms3H06FFaWlpoaGhAkiRMJhOhoaGensJLxWAweByjq1evfuj+arWa3bt3c/LkSZRKJSEhIQ89Jjk5mdcMPvzL4eNEr1xFQJj7AS594xZi0jMoP3ea/o42qrpaCN6ymW3btnlyA+x2O5OTk0xMTHj+1el0dHd38w//8A94eXmRkZFBcHAwOqWKgY42IobT0Op1Hk1B5+PrLnktiNR09xMal8BPW/sJ0KpYE+jLSG8vvr6+qFTzY//9/PwYGRnB39/f01t5lsnJSUJDQwG3w3k2J+Py5cvsO3CA0OQ0Tp04zpoduwnxUt+3NolGPercOOz13Ujj024tUZIQTb6oUkKXtRrvUkfSAh8JgnAVmFeYRJKkLy7bbB6BlgEzZtvd0BHbUBfWjptoY1ah9AlCEO9/grHYnRyt7mZ/ZigbVwTdt11G5kVHGRMEguiOnJIgMCCAkdoJnAY1upxYBM38n7RarSY+Ph5vb2/i4+Ox2+309/fT09PDzZs3sdvtBAcHExoa6ilZ8SDS09M5cuQICQkJS0oum+26durUKTZt2jTvKX0xkiLCOHTgACfOnmVieIjoNPcDnMHfyKZDrzNaU0GKjxcDAwP81V/9FZmZmezYsYPAwED8/f0XTcJrbW2lqKiI4eFhoqOjMbps9DY2MGU247DZcNjtXH3/XZLW5uNyOBjo7sAYHsmU2YxT0vFRfTOKukrefPNNbty44VnkwZ1t3NPTs6BAmG2MI0kSY2Nj7Ny5E1EUOXqpgLrTlwmJjuN23xAf32rCz2hkU4j/fQ5x0V+HZl0CktWOZHchaJUIyuV33y5VINyaeb0w+OlUaJUi0zNRF47hTrTRGbgs40z1NSFqDaj8QlB4B84TDlM2J98paJYFgsxLizI6AEWkEWnEjORwEavJpT9CTazXwuaguZFGKpWK8PBwjx/A6XR6BERDQwMWi4WgoCBCQkIICwu7r07SbEOcwsJC9u7du6T56nQ6du7cyZkzZ9i2bduSsqa3RZkIeu0QH1++St3Vy6SszUer1bAyNID0lEPcvHkTm83G17/+da5fv863vvUtoqKi2LFjh6dz2b3MOp5v375NTU0N8YFGXtmzncZpJ/3Tboe9VnIyPj3N+PAwGi89vS1NSC4nFrOZ1ptVxCanED9Tkvrq1avExMTg7e3tKUKXmpqKl5fXvEZBs/WmRkZGMBqNAPjFJ2KpbaLm0gU2ftZEUEws9eWlZG7dwbnuYV6JCCBIe//fU9CoEBYOnloWliQQJEn6n09vCo/HKytD+JsT7gqA9pFuRC9vVP7u5AxNaCLOqTEco72MV58Bl4Rx811FpnHgycLwZGSeN4IoIMx0cktQJFFVVbWo8/ZByWkKhcKjHYC7NeXg4CA9PT1cvXqVyclJAgICPPv4+voSHByMt7c3jY2NJCQkLGm+3t7ebN++nfPnz7Nz584HltsAt+08w+hN+qE91DY2U1Fewo5tWwn2d9vaZ00/hYWFrF27ll27dlFUVMQ777yDj48PW7duJTk52eNUn0UURZKTk4mPj+ftt9/m4scfsm3bNnbGx+B0Oin30rF25yucfft7JOasZWywn/SNW2iprsQUFU30iiRMPu7KpdeuXUOlUnlMVIWFhUxMTGCz2RgdHfX4NIaGhpAkydP/QJIkrg+Mk7Amj+GBfkpOHME3MBitXs9gZweBEZGUDo7zSsTDtanlZsnGJ0EQtgBfBMKBLuCHkiRdfDrTejjB3lq+kBfNf19rwdzXjC5hfnakQueLc2oc53APPnmfnbfNZxlrf8jIPG8CAwMZHR3F4XDctwDCo+UiiKJIcHAwwcHBZGZmIkkSw8PD9PT0UFJSwtjYGH5+fgQEBHDlyhUiIyPvawu5GH5+fmzevJlz586xe/fu+/oLLzgfQWDliniiggO5ePEiKSkpnk5pISEh7N27l4sXLxIcHMy2bdtYv3495eXlnDp1irNnz5KXl0dGRsZ951KpVKxZswZJkmhvb6empsaddObrh1KtISAkjLHBfroa6hEEAafDwZpXDqAQRVTevqRFhNLX10dsbCzBwW6n7mx9oomJCY+wGBoaor29nbNnz3L9+nWSkpK4eaeRm2YHKi8dUSnpFB95n+7GO7zxe39MTcFFjKFh9Fts2F0uVMsUTrpUlnQ2QRB+Efgpbv/Bh0AP8K4gCL/0FOf2UP50Xwp7w614m6Lx1uswaJSoFQKCAPaRXiarT6ONzkRjuvvk5KVS8Gbu/eFdMjIvM5GRkfOSpuai1+sfuVHOLIIgEBAQQHp6Ojt37uSNN95g9erVaDQaFAoFf/d3f8eZM2eorq5mcHDwoV3SAgMDWb9+PWfOnFmw69pi+Pr6sn//frq6urhy5Yqn9o+XlxevvPIKACdPujv65ufn85u/+Zts3ryZ0tJSvvvd73LmzBkGBgbuG9Nut7Np0ybWr1/PlStXGGpvo7OhnuDoWDI2byMkPoGe5iZEUcHNyxcY7OxAO7NqZmdnU1FR4RkvJCSE/v5+TCYTer2epKQkUlNTycnJYd++fWRmZvLWW2+Rk7+e0Fh3QmT7rRqsU1NUnj+NUqUiKDKKrjsN7jXs3qiiZ8BSNYTfB3ZKkuTprScIwk+AD4DvPI2JLYWpqSk2hMBf/cJXuNE2gtXhIjXUh2++d4WfXD2PNiINpfFuzLRSFDDq1by++sEhcDIyLxvx8fFUVlYuaDZ6nEY5D2LWcZuamsrx48eJj4/H4XBQU1PD0NAQOp3OY2IKCgryFJ6bxWQykZuby6lTp9i7d++SQ2GVSiXbtm2jtraW48ePs23bNgwGA4LgbnrT0dHB8ePHWb9+PSEhIWRnZ5ORkUFdXR3Xr1+nqakJk8lEVlYWMTEx+Pr60tjY6Lmm5ORk/EUN//2Tn5C4Jg9BFPEyeKPz8SEhOwe1lxcDTXcoPtXGYHw8ycnJSJLE4OAggYGBhIWFUVNTQ1JSkqevwaxDeWhoiICAAHf9o4527lRWgCASviIJBIns3fvoa20hIimF8nOniIiLR/scMuiXKhACuN+p3AAYl3c6j0ZJSQk5OTnotSq2JLnVts7OTsKHynn90AGOXavBLyQKQaHA7pTIivLjn382C71GLuEk88kiICCAsbGxRc1Gs41y7g2XfFLWr1/PpUuXOHjwoMeUMzk5SW9vL7dv36awsBC1Wu0REMHBwSiVSsLDw7Hb7Zw+fZpXXnllwTkvRlpaGoGBgZw+fZq8vDyPgzwyMhJ/f38uXLhATEwMGRkZKJVKVq5cSWpqKg0NDZSXl3PhwgV0Oh0pKSnzSk4MDw+zZfMWyrNW4x8eQcFP3kGl0bDu4OvcKiwgMXs1X9y9nSidmqamJk/HuLNnz/KzP/uzGI1GhoaG5s11cnIStVpNYWEhvb29TExMEBcXx7bt2xmWFNSXXCMmLQNjaBjVly4QGp9AbGo6juYGxLQHJ/Q9DYSlPDkIgvAx0A78gSRJU4Ig6IG/BWIlSTrwoGNzcnKk0tLSZZnsXPr7+ykrK/Ooi+AWBh999BGJiYnuFPimFjAlY3U4yQj3IyrgwSF1j4skSVjsTpSiiFr5ctTFkfnkcePGDQIDAxfUEi5cuOCpx7PclJaWotVqSU9PX3C7xWKhp6eH3t5e+vr6UCgUniim8fFxWltb2b1790OT3RYa9/z584SHh7Nq1SpPZJHL5aK4uBiz2czmzZvnaSAul4vGxkYqKyux2WyUlpbyuc99jqSkJK5cuUJoaCh6Xz9aRC0nT54gOCKKoe5uohNWYBjq5tXtW+flU/T39/P973+fsLAwcnJyaGpqYuvWrZw8eZJVq1Zx8eJFbDYboihy6NAhT1OcKYeT7xaW0dXaQnL+RgBul5YQHB5ObHQ0VBWzacMGT1TSciMIQpkkSTn3fb5EgRAK/ARYBwzj1gyKgJ+VJKn7Qcc+LYFw5MgRNm7c6LnBOzs7OX36NH5+fhw6dIgzZ86wbt06/Pz8lv3cszhdEj+81sr/K2hmYMIKEqyJ9ecbu5NYHf1clSeZTxiS04VrcBLJ7kTUqRH8dfeFVg4NDVFRUcGOHTvuO76kpITQ0FAiIyOXfW4Oh4MjR44s2VFstVrp7e31CImOjg5cLhcHDx4kLCxsyU5qcC/wJSUljI+Ps2XLlnmLf3NzM5WVlWzevNnTe2AWSZJobm7me9/7HmlpaUxMTDA9PY3BYOBLX/oSp06dIj0rC31AEE6blcbqKrq7u5mYmGDfvn3zhEJvby/l5eWEhITw/vvvIwgCFouF119/nenpaVasWEFJSQlvvPGG5xiz2cyREyeIzt9C67QDu0vCaZ7A0nCTr372NUaHhykpKVlyaO+jsphAWGrYaQ+wSRCESCAU6JYkqfMhhz01GhsbPUko4BYGly9fRqfTsXfvXk8q+9MUBi6XxK/+dxkFtwexzGlnV9w8zFvfvc63Pp/F7rSHZ2bKyDwMR9sQjobemXKSEiCASoE6KwrR767WGxAQwPj4+IJmo+WoeroYSqWS3Nxcrl27tqAwuheNRkN0dDTR0dGAO8P44sWLnDx5koiICJxO57xkudnG9wshiiJ5eXk0Nzdz7NgxtmzZ4nmqjouLw2g0eqKTZltvwt1ObK+88gpeXl6eRvc2m41/+Zd/ITo6mqjQULf/Q6smZMMGxsbGuHz5Mt/+9rd56623SEpKwuVy4XA4qKqqYmBggA0bNtDb28vAwADt7e04nU7Cw8M9ZS7ALYwuX77M5vXrCQsLIn/O9ZzqbWF8pt2mXq+nra3N8z09CxbVEARBEGZrFz2ozLUkSQ8MK1huDcHhcHD48GH279+PVquls7OTa9eu4XQ62bVrF0ajkeLiYkwm00OLaj0Jp2p6+Z2fVjJlW7jQvl6toOx/7ESreq7FYGVechztwzjquu+vYwOgEFHnxyMa7pafuHHjBgEBAcTFxc3btb29nb6+Pk/bxqfB+fPnWbFixYJF2pZCaWkp09PT5OXl0d/f79EirFYrgYGBHgFxb7LcLKOjo1y8eJGVK1fOy49wOBxcvXoVgA0bNswTllVVVSg1Gro6OmhpbkYURdrb29mwYQMTExOsWLGC5OTkeVpLU1MT//RP/0RYWJhHsM06jrdu3crhw4cJCwvDaDRy9OhR7HY7iYmJHg2quroai8XC2rVr77uG7u5u7ty5w+bNm5mamuLUqVMcOnToPsf8k7KYhvCgs4zNee8A7Pe8Zj97ZkiSxLsnC6i3GPj4Zj9V9U2UlJSgVCrJz8/HaDTicDjo7Ox86lL1e1ebFxUGs5yu7X3gdhmZByG5JHeJisXCD50uHHfmJ5zFx8fT3Nx8365PU0OYZd26dZ7Sz49DTk4OoihSVlZGWFgY2dnZ7Nu3j0OHDpGUlITZbObKlSt88MEHXLp0iYaGBsbHxz3H+/n5sX//flpbWyksLPSEwCqVSrZs2UJISAjHjh1zO99dEhVD41was/HTWy28X9VAj8ILjY8vX/jCF3A6neh0OiYmJjh27BiFhYW0tLRQXFxMRUUF+/btQ5IkzGYzOp2O9PR0pqammJiYQK121yNSKBTExMSQlpZGfHw858+f5/333+fGjRvk5Ny3FgPuxjkjIyNMTU2h0+mIjY2lpqbmsb7Px+FBJqO0Oe+fvbv7Hhr7J/jyf1yhpeoausQ8pLLLTHXdZlNaJN94NdfzVNLY2EhcXNyyS9R7aRt6cFz3lM1J6+ALUylc5iVEGjHfJwymbVa06rtPq66+8XmlrY1G44Jmo2chEHQ6HcnJyVRUVDy2JrJu3ToKCgqoqKggKysLcJuFTCYTJpOJVatW4XK5PMlyxcXFjI+P4+/v79EgduzYQXV1tSc0ddavkZycTGBgIGfOnmM0JApNSDhKvYHxhnomRoboVYh4RcZgjI4lKSmJ/v5+rly5QmdnJ42NjTgcDiIiIti2bRuRkZFs3LiRkydPMjY2xuHDhwkODqa8vJzQ0FBGR0fR6XTuLnc2G5mZmaSnp/OjH/2IkJAQPv74YxITE0lMTLwv7DY1NZVbt26Rk5NDRkYGhw8fJjEx8ZEKET4uDzIFdcx53zb3BfQDvTPvnzoDE1Ze/7dr3KmthKB4pkYHGWtvwKUPoKh5lB833b2M+vp6UlJSnvqcfL0eHL6nUYkY9XJGtMzjIzlcbr/BDA6ng1M3rjA0PjpnJ+4TGlFRUbS3t8/7bDka5SyF1NRUuru7GRkZeazjZ7uuDQ0NLfpkLIoigYGBrFy5kl27dvH66697hEd5eTnvv/8+vb296PV6fvrTn9LV1eU5NjAwkISNW7l9p5GGshuovXSM9PUy2teHl7cPwXEJnLzTQUVFBYWFhRgMBjZs2EBWVhaZmZlkZ2fT1NTE4cOH6erqYvfu3QwPD5Obm4tarebs2bOYzWbGxsYYHR1lenrak8l8/fp1T5La/v37ATh27BgFBQUMDt7tdBcfH09raysOhwOFQkFWVhazZneHS8LxFBPWltox7f8AP5UkqUQQhH3A+4AkCMLnJEk6+jQmJkkSdT0TDE5aOV3by8TIIJLTAYKArecOqsBo7MOdEJ/D4coufmdnIsL0GD4+Pg90Qi0XP5cXzd+erJ/nUJ4/f9i7MnTBbTIyS0EwaOYt9kqFkm1ZeZwvv8bmzFyM3r6gVtzXAjQuLo7y8vL7/Ajw5I1yHjpnQWD9+vUUFhZ6Fr3HGWNu17XZ/IYH7W80GjEajZ6+z2NjYx7/w7/8y78QFRVFfn4+oaGh1E86SN2wmY76W9wsuEjnnQaQXPgEBFBx/gxqpZKENZns3bt3nu9gdHSUyspKxsfHSUlJYWxsjOrqasLCwigqKmLr1q184Qtf4MSJE3R1d5ORlYXVYiEsLIzOzk7Gx8fJz3e7kNVqNenp6aSnp9PV1UVFRQUWi4WUlBTi4uKIi4ujsbGR5ORk4uLiuFxWSWt1Aw4vdy0nb5WCVUZv4ry9lvXvudRskLeAP5t5/2fAF3D7GP4Rdye1ZaWoaZA/+vAmAxNWFKLAuMWOpaMepX8otp7baMKSsXbV4xWfgyCIiAKcvdVLuKX5oY3Al4s3ciL4XmEL3aMW7M75EttLpeBL62MIMDzFsoQyn3hEvQbBW4s0dreUso/OwNZVa7lYeZ2t2XkEJN5fXG4xs5FOp2NqampJoaFPQmBgIEajkdu3bz+0heZiiKLIjh07PF3XFhJuD8LX1xdfX1+Sk5PZvXs3Fy5coKKigqGhIQpvNaNUq/ELNhEQFk756eOkrNvIYFcX4YlJBIeGERwdel/4q5+fH1u2bGFiYoKqqioGBwfJyMjA4XDQ0tLCd77zHQ698VmcQWEMjk3zztlLSJILQ/Y6HI2lfO7VgwvOdbb6rNlspq6ujo8++giTyURdXR3JycnUjkwyFZ1I4/USMrZsB2Dc7qSof4xhq501QQ8vQ75UlpqHMCZJkq8gCAFAvSRJQTOfj0uS9MCyhY8aZVTcPMSX/rNkXic0+3AXtsEOBFxoY1fjGOtDaTAiat3RBkpR4OtboomcusOhQ4eWfK4nZdhs4/d+WkVh0yBqpehpd/trW+P5lc3xC0puSZKo6BhlYMJKuJ8XaWE+crMemUVxTdmwFTWCwzmvWdqIeZzLtyt55Wtv4evvd99xpaWlGI3GeQvp1atXWbFiBSaT6anP22azceTIEU804JOMc+rUKVatWvXY0UuzNDY2umsuxabiUqgYG+hntL+P3uYm1F4aVGotCpUKBZBkUBPu643RaCQgIACj0Yi/v/88AWs2m6murqanp4f09HTMVht//e/fRetnxGqxYLNOIwgikstFfMYqvvHmG4R5P1wYu1wuWltbee+99wgwmZiIS8M3JIyGkmsERkQRGH639I5CgH2RQQRoHs08/aSJaTeAfwISgCRJkt4UBCEQqJUk6YF316MKhJ3/cJk7/XedX5LLyUTVGRRaA14JuYiq+5+69WoFv52tZkNy2LxY42dF3/g0t3rG0SoVZEf7oVmkccXl2wP84QfVjFvsiIKAU5II8tbwDz+TKSeyySyKNG3H0TKAs2vULRi0KpQxgYzqJS4XFLB79+77QjGHh4fn9fkFqKys9DTKeRY0NzfT2dnJpk2bnmic6elpTp48SV5e3rymNI/D8PAw//HxcRRRCQRG3Y1EtFunGRsYYHSgD/PwIJtDjAQYjXh5eaFUKpmYmGB4eBiXy4WPj49HSAQEBKBQKLh58yYXaxqwGIPoqK+j5WYVnbfrSMxZS0r+BnwDgxltaeQXtuSTnJy8pKCX0dFR/v2Dw0zo/RkZ7MffFMpgZwdr9h7wHC8ACT46Npj8Hul7eKLENOBXgW8BNuArM5/tBs480iweQsugmY6R+ZE5lpZycNgWFQYAOpWIj22IhIQnu/EeF5OPFpPPg5+CihoH+eoPS+/rAd02NMUXvlvCe7+yjvTw5VP9ZD45CFoVqpQwVClh8z4PBDZt2sSZM2fuyxI2Go1MTEzMq1/0LCKN5hIXF0dDQwO9vb1Lap+5GHO7rm3YsMHjpH0cjEYjv/K5N/jmTw8zPjxITEYWoiii0mgJjIjEFBnF2iAfYr1U9PX10dPT48mkDg4OJiQkBL1ej9lsZmBggIaGBiYmJlAqlYyqtIx3dGC1mNHovJgcHcE2NcXk0BBeem9W5G2ka2SY+sOHycnJeajG4+fnB156TPEJRGesoq+thTvlJQx2d7Lvl38NcCuNo7blCxZYUmymJEk3JEnKlyRpiyRJTTOf/bckST+3bDMBhs1WVHMcZC6XA/tAG/rMXYsKA4DJoV6K+yTsrhfX9PJnH9fcJwxmsdid/K/jL1RDOpkHIDldOLtGsNd2YW/owTXHxv+sCQoKYv369Zw+ffq+Etf3Rhs9a4EA7uJ3165de2hZ7Ieh0+nYtWsXV65cmVeQ7nHw03nxx2++QbC3ntrL53FZLagEAY0osi7IhyRfPWq1msjISHJzczl48CD79+8nJiaGkZERbty4QWVlJRaLhbi4OPbs2cOu3XswJSQSmrCCsIRkDH5GBjs6yDlwiJw9+/EyGKgrKWRofJw1a9bQ3NzM8ePH50UXLURKWhpdt+tRqlSExa8gOCqG1HUb5u3jtYxVUZdkMgIQBCEJyATm6aaSJH3/Qcc9ismob3yaTX93Eavj0W4eS9MNvKPTSYgI5sNfzUe3jE2nl4PWQTN7vlUwTyBILue81p4qhUDpn+zEVyeHqr7IuIbN2Mpa3Y9mzpm/pygg+OlQr45+Kn1ul8JsTP4rr7zisdmPjIxQWlrqMRvNdvXavXv3M51beXk5CoWCzMzMJx5rbGyMc+fOsWPHjiX1dH4YDa1tXCosIj8/n7SYKMQl+vOcTicDAwP09PTQ09PD1NQU5VYB76BgfIOC8TJ4e5LLZlEKApmCle479TidTiIiIujs7PQ01lkoA3vIaud/fu+HpG3czGh/P7dvFJO8Np/AiEjPmFtD/YnQP5qf5nEylece/MdAFfC7wM/NeX3hkWbxEEw+WrKj/BEX+ZsoRQGjTsXcv5lr2v3E41B60TJo5tsXm5ZzSsvCqMU+r/OR5LBhaboxbx+VQmR8+pkmfss8Iq4pG7bSFnC47goDAJeENDKFraJ98YOfMqGhoZ4eA1arFXDX+J81G8GTNcp5EjIzM2lqaloW7cTX15ctW7Zw7ty5ZRkvKSaat149QMvNKm7V1i75uNmKrVlZWezdu5fXXnuN/FWZOKxWmirKKD11jLaqcrob7zA17i76oBIFVsZFs2fPHtavX8/ExARWqxWXy8WpU6coKSnx9FGYJUCjYvXKNHoab9NRf4uAsHBUM9FPCgGMGhXhuuWLZlyqrvFbQK4kSWslSdo657Vt2WYywzdfX4m3VnWfUFCJAn46FWabk7lKjW2wA1Wg2zlkdbh4u7h1WZuBLAcR/l5YnfOjppT+8+3BrhkHs8yLi7NlYPEyEpKENGzGNWl9tpOaQ3h4ONnZ2Zw6dcqzsERHR3vMRsvdKGepKBQK8vLyKCwsXJbxAgIC2LhxI2fOnMFieXJzncFgYN++fYyOjnLhwoXHKr0hiiJbk2KJT01j5cYtrN69j8iUNCTJRcvNKspPHcNZW0ZtbS1DQ0P4+vqyYcMG9u3bR0BAAJIk0drayk9/+lNqamrmmdg+n5fNYG013jNF+1RqNSIQo9eyOzxgWaMUlyoQLED9sp31AUQH6Dn+mxt4dVU4aqWISiHgpVLwM2si+bP9qfP6DbgcNqbbKhG97zajHrc4eK+sE4fzyWyWy0mgQUN+XAAK0f2DtI90o/K/Gy2hEgUOZobJhfBecJx94/NCPxfCNTDxbCazCFFRUWRmZnLq1CnsdjtxcXE0Nd3Vmmcb5TxrwsLCUKvVtLa2Lst4wcHB5OXlcfr0aY9G9CQoFAo2bNhAREQER48eZWxs7OEH3YNeqeBAVBAhXmqUooC/0Uh0YjJ5W7byh7/wRfZtXI9CoaCqqooPPviA06dP09DQQFhYGJ/5zGfIzs5Gp9Nx9epV3n77bVpaWnC4XJzuHmHIbEbjpcdus6HUaBAFAZtLWtSa8rgsNez0i8B64C+AedW0nma1U7vTxZTViUGrRCEKlLWN8MXvX8dsvZsdbO2qB4USTcjdBB0vlciqSH/+6xdyX5iGNd2jFg7836sM9XUzPdqHNsJdKkqlEAj21nLsNzbgr19aK0GZ58P0+TqwPeDpUQBlYgjKuKDF93lGNDc3c+vWLfbs2cORI0c4cOAAKpXqqTbKeRgWi4UTJ05w8ODBZevc1tbWRlVVFa+88sqyjTk0NMSlS5dYvXo1MTExjzXGlMPJhN2BRhTxVSsXfIqfmJjw+CAGBwfx8vIiNDQUhUJBc3MzDQ0NDKu80EbHY5kyMzU+gSAIrNq+C1EUUQgCmUYDmUbvR57fE/kQgB8AvwR08gyrnaoUIr46FYoZMZgV6XffU7Q6LAnn5DCOybuRBxa7i4qOEf7lwp2nOb1HIszPi5Nf38g64xQ+IbGIAhg0Sn4+P4YTv7lRFgYvAaL/QzruicK8/gTPk7i4OJKSkjhz5gzh4eG0tbnLjj2PSKNZvLy8SE1NpaysbNnGjI6OJi0tjTNnzuB0Prj68FIJCAhg//791NfXU1JS8lhmNp1SgclLg59GtahJx9vbm8TERDZv3szrr7/O5s2b8fHxYXx8HJfLRWR0NJ0joxz+v/9IR0MDokLBxPCgJwfBKUnUjphxLaMZcKnhOM+92imAKAr8xf40vvFBNdMzNYQEQUAblYGlpQxF/BoEpXthnba7+EFRK7+5fQXK59CseiG8BDtv5Ubyzr592Jwu1ApRzlJ+iVDGBWEbmFjUjyBoVQgPExrPkBUrVuByuaiurmZ4eJiEhITnKhDAXXH06NGjDA8PL1t7yPj4eOx2O+fOnWPnzp3LUulYo9Gwe/duKioqOHnyJNu2bXvq1Ub1ej3x8fGexMG24TGqrGCdsjDY0U7p6eOYh4fY/Lm7sTwOycW004VumaLbltoxrQ08jXJMMx3UngsHVoXhlCT+x+EaJqxu9V1Ua9GErmC6/SZecas9+9qcLgYmrYT6Pv1id0vh1q1bpKamIgjCotnMMi8uop8OZXIojvqe+UJBFECpQJUT+8IJ+KSkJJxOJz/+8Y/Ztm0bBoOBvr6+hx/4lJgtfnf16lUOHDiwbN9XcnKyp/Patm3blmVcQRDIzs6mo6OD48ePs3HjxidKipuLJElYLBbMZjOTk5Pz/jWbzdjtdibsTupvXCchOxdvo5G4VVm019XeMw7L6kdYarVTP+DbwBu4zUR6QRAO4o48+tPlm87SOJQVTnyQgTf+X5EnZ0HpE4yonv905nRJL8zC63Q66ejoeKodq2SePsroAESjHkfrINLIFChEFBF+KML9n1sOwsNITU0lLS2NH//4x+zbt++5agjgNskEBwfT0NCwrKVmVq5cSVlZGVeuXHnichlziYyMxM/Pj/Pnz5OUlPTQ8vpzF/t7F/rJyUnsdjuCIODl5YVer8dgMKDX64mMjESv16PX61GpVDS3tNAiqInJzmV8eIjh3h7e+N0/mncuH7USrWL57rulmoz+HzACRAOzKbXXgL8HnrlAAEgL88Fbq8Q6eTdud7bY3SzxQQaML4htvqmpidjY2KfeuEfm6SN6a1GvjHj4ji8Qu3fv5t1336WsrGxZonKelNWrV/Pxxx8THR29rOXqV69eTXFxMdeuXWPdunXLNq63tzf79+/n6tWrtLe3k5GRgdVqXfJiHx4e7nm/VOd3dVUV+9fnUTtp586N66Tkb5i3figEWB3wwNqij8xSBcJ2IEySJLsgCBKAJEkDgiAsj/70GIiiwDd2J/EXR24t2JNAqxL5w1eefaG7xaivr2f79u3Pexoyn1L8/PwICQnB19eXs2fPLqu55nFQqVTk5ORw/fp1tmzZsqxj5+XlUVBQQFlZGatXr374ATNIksT09PSCZpy5i/3AwAClpaVs2LCBkJCQx1rsH0ZbWxuBgYHkhJu4efIc4Qkr8PbxwSmBQhAAiTWBPkQZltevsVSBMIa7lpbHdyAIQtTc/z8PPrcmipEpG/949g6iIDBtd+KlViBJ8NeH0tmS9Nzk1TwGBgbQ6XRPvQ69jMyDiI6OxsfHB7VazdWrV9m4ceNznU9MTAz19fV0d3cTFhb28AMegY0bN3LhwgWqq6vJyMgAuM9mP/f9bG6GVqv1LO6zT/az7+e2uhwYGKCgoIDY2FgiIpZfW6yoqGDHjh10dXURJjr5/I4NNE9YMDuc+KiUxHl7oXkKwTJLzUP4Q+Ag8CfAR8ArwN8AH0uS9E8POvZJ8hCWytiUneM3e9w9Bvy92LsyZFnrGY1P23mnuI13SzoYn7YTE6DnlzfFsTstBHEJHp3Lly+zYsWKZb/pZWQehdHRUUpKSnC5XKjVarRaLfn5+UguCdfgBNKUDUGtRAz2fmb+kImJCc6ePcurr76K4gls4dPT0/c91Y+Pj1NYWIi/vz8RERH3LfZz39/b13ip57xw4QImk4ns7Oxl07ja2tpob28nNzeXY8eO8corr8yribQcPGk/BAH4TeCruP0I7cC/A9+SHjLAsxAIT5O+8WkO/stVxqbsTM8puqdTK9iUGMS338x+oFCYnp7mxIkTvPbaa89iujIyD+Sjjz7Cz8+P1NRU7ty5g8JsJ0thckdNSRIIAkgSikQTqthnk2BXWVmJJEmevsj3Mnexv/cJf7ZEh1arnbfIz/6r1Wq5cOECycnJT6UPhCRJlJaWMjQ0xNatW+/rsvY4fPzxx2zbto3r168THx9PbOzyR/0/UT+EmUX/WzOvTyQOp4tzdX1cbBgAYEtiEDtTTfzGuxUMTtpw3hN7PmVzcrlhgHdvtPPW2uiFhgTg9u3bD+0JKyPzrIgKCae1uoGRaTVromK5UnyWcnU/2StmW8+673PnnT4EhYgyKuCpzmd6eprw8HA+/PBDj9lmdrG3Wq3uPKOZxX52oQ8NDfW8X8qT/a5duzh58iRKpZLo6MV/q4+DIAisWbOG1tZWjh07xubNmwkMDHz4gYvQ3t6Ov78/fX19KJXKpyIMHsSS7SqCIESzcPnrd5Z7Us+alkEzP/sf15iwOjxlMY5Vd+OlUjBmsd8nDGax2J3826WmRQWCJEncuXOHAwcOPLW5y8gsBUmScDT2E97toLShlXGHFxI+rE/NpqD6BlVN9WTGzwnCcEo4bvehiDAiPGag+6yDdiEn7exir9FoMBgMREdHU1lZySuvvPJIi/1SUKlU7N69m5MnT6JSqZ6K6TYmJgZ/f38uXLhAamrqYz8EVlRUkJubS1FR0XNZN5aah/BHwP/AHXI6t7ygBLzUAmHa7uRn/v0ag5PWeVVUzVYnU9b50UuS04GtvwV1SDzuHD3oGrHgcLoWzIbu7OzEZDIt240tI/O4ODtHcLYM4KfzBklidHIccD/hblyZw+XqEm623GZlbOLdg1wS0tgUgv/9wRBzQy7vNefMmnE0Gs08881st7HFFvvLly9jt9uXLYN5LrOZxydPnnzirmuL4evry4EDBygoKKC/v5/8/PxH8ou0t7fj5+dHeXk5+fn5z2XdWKqG8LtAjiRJn7i2Xidu9jBldbCQJ+TejwSFEkGhYLqlAm10JoJCiSgKnlpL91JbW0tubu7yT1pG5hGQJAnHnT5wuu/ohPBoGjvb2JThTpIURZHNGbmU3q7B6XTicDkxT1uYtE9jq7NgUUkPXexNJpPn/ePa0deuXcuxY8eIiIh4Kouhl5cXu3bt4vTp06zftIl+hZa6UTMWpwuNQiTJR0eav+GJoneUSiXbtm2jtraWY8eOsX379gUb3yxEZWUlQUFBBAYGPnHv6MdlqQJhCGh9ivN4bpy82YvZtvSiWOrgOOyqHixNN/CKzWJrRtSilQwdDsdTedqRkXkUJLMVHHfv8ZTIOP77/BHWJK/EYrVinp7CPG3BarfRPdSPRqVGr/VCr9PjnxaMyej3xIv9UtBqtaxcuZLS0lLy8/OfyjkMBgObtm7j7378IXF5+Wi93V3Xpp0ubo5O0jgxxYHIILyeMMoqLS2NwMBATp06xbp16wgPD3/g/h0dHYiiSF9f33M1MS9VIPwW8B+CIPwT0D93gyRJz69N1DLgWEKvV1GYX7pG5R+KqNLiaKvgy79wn6MegLq6OlJTUxfcJiPzTJEAhNk3GH380Gt0nCsvIiLARGJkHLnJGWjVcxZ7AYQAA5pVz9apmZiY6Ok1/CTO2QfRaBeIWZNHTdFV0jdsQTuTH+SSYMrh4lr/GNvCnvxBzmQysXfvXi5cuEB/fz+rVq3yPDxKksS43YlTkvBWKSgrK2Nqaoo9e/Y8Ufjtk7JU3UgN7AJKcGsKs6+WpzGpZ8nmxCC81Iv/AbxUCvLjA1ArRbxUChQi6DUK/AOD+M4ffYne+lK6u7vnHeN0Omlvb3/sWuoyMsuJoLvf/PK/v/r7/MahnyM/fTVjUxOcKLlMUW0FvcODSAKgUaHOePblOWaL3xUWFj6V7m4Ol0TjhAWdnz+JOWupvXoZ65yuaxLQOTU9r8Phk6DT6di7dy9Wq5WzZ89is9loHp/ivdZ+Pm4f4ETHIP9aWM7VhmaSUlOfu0VhqRrCt4E/Bn7MfKfyS89rqyP4P2duL7pdFOHbX1iNwylxuraXMYs7MW17SjAqhYglNZwfvn+E6yNeXBtUY3O4CHIN82qqH+6nspeDsrYRvnOlmVvd4+g1Cj6/JorXV0dg0Cxfgp/M80FQiCgi/XG2D89TdQVBIMQYSEhAIC5RoHuwjzv9HRQPNxOTnULCRCCBmqfzlP4g/P39CQ0NfSpatmVOzwSfgECiUtN496//nLyDh9B46VBptei8vLgt2og0+uHl5fXEZjJRFMnLy6O5uZn/95P3UaaswsvXDwAncLOoEK2Xng7/UDJdEsrlboP2CCw1Ma0Pdy2jR+5A8TIkppW2DvPz/1mC0yl5ks+0ShGFQuC/vpxLTsziUruyY5Sf/fdCRu6UIer8UJvimbpzHf+EbDamhvONXUkYDZoXul/yN0/W8V9FbUw77var9lIp8PVS8dGv5b8w5cNlHh/J6cJW2oo0NuVxLgOgEBH9dahWx3jCS2cr8zY1NTE2NkZUVBQJCQn4+fk9s/k6HA4+/vjjZc/SnXa6+ElzLy5gcnSEhuvXCI6JxS/IhN1qwTY9jWN6mjw/LQqHHYvF4ikGOFu0bval0+nm/d/Ly+uBPRPsLhffrWygtqiQiOQUTNGxDHS2U3T4fXZ/+asYDAbWBvmQ6Pv0S9w8aabyN3Cbjf7mYZnJ9/IyCASAYbONd0vaOHvL7SLZmRrM59dEEWBYfCF3uSTyv3mB3vFpJEnC2nULl2USlEp0se6iWhqliARkhPvyFwfTSA/3fRaXs2Qu1Pfxa/9dsWCBQIUokBbmw5Ff3/AcZiaz3EiShKt/AkfbIFjsoFO7y3kHeS9adsHhcNDW1kZTUxNTU1PExMQQHx+Pt/ejt218VNrb22lsbGTbtm3LOu7R9gHqm1toq6kmZd16dD7zf5PeKgWvRwff9524XC6mp6exWCxYLBampqbuez9XeGi12nmCo88BtWY7kkJJa00lXgYfGm4Us3LTFmLS3PWW/NVKDkU//RpsTyoQOoAQwIY74siDJElRDzr2ZREIj0Nh4yC//HbpvCilierTCKIKfcomBMV8c4uXSsE7v7SWrKhn3892MV77diHl7aOLbteqRA7/2nqSQ5a3zK7My4fNZqOlpYWmpiYcDgdxcXHExcUte52duZw9e5aUlJRlLSB3vriEEzUNJK3bgEo9/4FPIcDWUCOR+ierIrqQ8KjqHaS6bwjr9DT26WkaK8oY7Ozgl//+/3qO0ypEfjYu5InOvRSeqHQF8IWH7/Lpo7F/Esccm6x1sJOppgp8134GS9MNtLFZiKq7N5bF7uQPPqjmzG9vfh7TXZDa7vEHbheAqo5RWSDIoFarSUpKIikpCYvFQktLC+fPn0cURU/NneUOS83Pz+f06dOe5vNPgtPppKCgAK1azW997nWuDozjdElIuO9zQYD8YN8nFgbg9hvodLp5wlIREsF0/xiOmYfwjC33l8P3es7tfpday+jy057Iy4hBo5yXlCY5rAgCuKYncE1PMlF1Bn3KJpR6P88+7cNTNPZPkBD89FXupaBSiJ6ucwshCgKqF6QntcyLg5eXF6mpqaSmpjI5OUlzczMnT55Eq9USHx9PTEzMsvQG0Ov1rFixgsrKykfqbXAvU1NTnDt3joSEBI+j+vMGL3osNswOJ14KkTCdBvEp9oiIMmgp6h9bdLtSgDT/pSWxPS0W/aULgvAnc97/5WKvZzPNF5MdKSZPnSNJknCO9eIVk4WgUKFL2YgmOJaBw3+L03G3q5tKIdI7tjwdq1wuCavjkf3889ieHDzTcGNhHC6JTYnPpuqlzMuJwWAgIyODQ4cOsW7dOiYmJjh69Cjnzp2jpaUFh8PxROOnpaXR0dHB2Njii+mDGBwc5OTJk+Tk5MyLWhIEgTCdhhU+OiL02qcqDABUosjaIJ8Ff28KAfw1KuK8n28Ax4M0hLlGu8inPZGXEV+dil/cEMv3C1uZGOpFofdDHboC883zeEVnoo1aiSYsCYXybhy4wykR4vtkanVD7wR/f6aBC/X9uCSJAL2Gr2yM5RfWx6JWPtrT/K9tS+DMrb5Fu84dzAwj8AGOdRmZufj6+pKdnU12djbDw8M0NjZSXl6O0WgkISGB8PDwR24jK4oi+fn5FBYWsnfv3kc6tqWlhYqKCnbu3ImPz/M3eyb66tEqFJQOjjHpcCLMhKYn+erIDlhYWDxLFhUIkiR9bc77Lz+b6bx8/N7uJJQKkX/4zzL8IhJxKHWYnQ6c5hFEne99mQgR/l5PZC4qaxvmC98tmRciOjBp5Z/O3eZSfT8//MW1j2TiSTR58x9fXM2v/KgMJDDbnChn6jPtSDHx14dWPvZcZT7dGI1GcnNzyc3Npb+/n8bGRq5fv47JZCI+Pp7Q0NAlN5UJDg7Gx8eHxsZGEhISlnRMeXk5fX197N+//4UqMBll0BJl0GK2O3FIEgalYtF6aM+apVY7TQU2AkZgGLjySSx09zgIgsAv5oUSOZmOYUUu3aPT/GVrKlMdNWjj1oDirh3VS6Xgm69nPPa5XC6JX/3v8gWf5qftLqo6R/lpaccD+zMsxMYVQZT96U5O1vRQ1zOBj1bJvowwYgPllp//f3v3HWZVdS98/LtOL9MrTG8MdWiCNFEECxAF47WRGIWY4k2ied+YnqumvLne98Y3iTFV402umqImFoggXtBBpXeGYZihTe8MM3P6OXvv9f5xDgOjgCXAmcH1eR6emTlnl7UXM/t39iq/pZwfWVlZZGVlIaWkra2NI0eOsGnTJnJzcyktLf1A2UenT5/OqlWryM/PP2fntaZpbNiwAZfLxfXXX/+hn0guFrc1fikqzuacASG2UtpTwN1AM9AK5AI5QohngM9+2HkJl6KamhqmTJxAaelIdENysPFanvjlz7DmjEXEmotykh38+tNTmfxPDDndcuw43uDZ22MDEYPfv33sQwcEAIfVzCen5PHJMy9apSjnhRCCnJwccnJyMAyD5uZmqqurefvtt8nPz6esrOys6RvsdjuTJ09m+/btzJ48HeO4F5CY0hIwJUZHBp3sPC4vL2fMmDFnPI5ydu/3hPAFYB4wU0q5/eSLQojpwF+ILqn52wtWumHgZN6iadOmoRuSW36zid1NvQhHIuGOowhb9Be1tS/IbzYc4XefOXMyvA+ivts/kHnACPmJ9LQAEvvIUznsW3svqcwiyiXMZDJRUFBAQUEBmqbR1NTEzp078Xg8AxPgkpMHTxorLSxm/8oNNLfoZKWcWs1NJDnoy3fz9tZNzJ49O27po4e79wsInwHuPz0YAEgptwsh/hfwHT7mAeHo0aMUFRVhMpn4+84mdjf1AmDPG4+/diPWtFNpb9dWd/B2XRdzP+KonSSbQDvRjL+9CYTAmpqDJWXwJBaVe0gZjk4uF1lcXEw4HKahoYHNmzcTDAYHJsC53W7C244xs3Asb+3Zzg0z5w00Bx2pqWP/+qMsvO8ukpLj33k8XL3f3WMccLY5CBuAZ85vceJP0w0qa7s41OklwW7m+vEjyEo6+0SVmpoaFiyITjD5+bpDA6/bs4rx7FiJNWPwAK3/XFtLotPKS7ua6Q1EmJCTzK3T8kg5Q0bKk9rb26mrq8PT1oEWDOIoqMBke+/wNJvZxG3T1IAwZXiz2WyMGjWKUaNGEQwGOXbsGJWVlWh9fgr9DooyR5Kbkc2BhsOMLxrFrkMH6PH0snDKFbj9EoZWdphh5f0CgllK6TnTG1JKjzi5juQlYmdDD59/eichTScY0bGaTfzo1RpuuyyfHywd/56RAN3d3TidTtyxfOod/cGB94TFhjR0Il0Ng/Y50NbPsie2ENJ0DAlrq9v5f/9Ty09umciNk049Tfh8Pg4dOsTRo0dJS0ujvLycuXPn4s+t59G1te/pWDYLQaLDwj1zL27+ekW5kBwOB2PHjmXs2LH0bq3jyK79rN+9GSFMHG1r4nBrEznpmVwzdTZCCPSWHswjVUT4qN4vIFiFEFdz9jzOl0z7xNEuL595ahv+0/IS6bHFc/6+qwm71cSDNwxOxXvgwAHGjx8/8LPDaiasn+r0TV34FYQWGbSPbkgCxqlzBCPRc3zjb/vISXaQovdSV1eHpmmUl5dz4403Dprxec8VxdjMgp+srcWQ0f+YiG4wLieJx+6Ycl7nDIQ0nZo2D4aUjB2RdM51IxTlQnNZ7YwvGsX4olF4/D68AT+aHuHyMadG7slzzLpX3t85k9sJIep579LCg0gpz/mRdLgkt/v6C3t5cVfzoJXRTme3mNj23WtIdkVvzqFQiFdffZWbb755YJsfrz7Ak299+DWDdH8fWk8zY5MN/u/yBZSXl7+nM+3dIrrB9voefCGdUVkJFJ3HIaKGIfn5ukM8tfHYwCcB3ZAsuzyfby8a+6EnvynK+RA52oV+qIOz/pEKMBdlYB2jOpTfz0dKbielLLpgJRpiXtvfftbfMwCLWVBZ18nSydFmndraWsrLywdt85V5o3hmU8PAmgrnIg2dSHcjWm8bwubCmpZHS2om06dP/0DltZpNzC69MIuXfONve1ld1f6eZqk/b2vkaLePPyyf/oEnFA0VXfWN7DnSTGfWSBCQ1tnJpNx0ckZ/sElOSvxZ8lKjAeFshMBckH7295X3pT7qxYTfZ8k8aUAo1rwjpeTQoUPvCQjJLivrv34VWWdYDCfJacFhfVd1m8w4S6bjLJqMJSkDOQRWWDvY3s+rVW1nnfy27VgPW4/1xKFkH92hbbtZEzTRkldI2GEnbLfTnpfHOhzs27Al3sVTPiBhs2CZlB9d5PzdTALLuBxM5xicoby/S6YP4J81KivhnKmgJTAuJzqcraWlhaysrDNOh89NcbHte9dQ1dzLK3taEQJumJRDqtPGtT87NWBLmMzYMgYvJTEpL/6dYc9tayJ8jiecQFjnmS0NzCwZHp/EfH39bE7ORH/3bFUh0IVgz4h88hqaSCtUo7OGA8uIZExuO9qRLozu6HgXU5obS0kmppQLty7Dx4UKCDFfmlfGN/62d1Cn8kmCaKK3//3cHswmQUnoMF9btuicx6vIS6EiL2XQa9OKUtl2rIeI/t62KafVxP0LRv0zl3BetPUFBzWdRXpakIY+ELwk0NEXPPPOQ1DNrlrIOXubsgSq67uYqwLCsGFKdGCbrP6/LgTVZBSzuGIESybl4HrXSBqLKXrT8AQ1DnV6OdDYySs7G7npqX3sa+79UOf41aemUpTuxn3aOcymaLC5b8Eo5o6Kf5rpkkw3VvOpR3IjHMBkPdUEZhZiWOU4OuFOGvR08NnyPD5bfmp4r2ES9MYWPFeUjzv1hBAjhOCRmyu4bnw2T2w4Sl2nF7tF0OUJA3JgZbRIdyOm1Dy8IY27ntrG1u8twG75YMMxU1w2Vn91Lv9zoIO/bGukLxChIjeZFXOKhsyCOcsuL+Cpd45xcnCZDPsRydkD79ssgrtnF8WncB9Q6NgxPP+zDsPrwTJ7MUgJQvDo8js4eV193d0kZ0Q75S0f+2xcihKlAsJphBDMH5PN/DHRG+Ajq2v4r42nhpFKQ0fr78I1Mtq0E9EN1lS1c9OU3DMe70ysZhOLK0ayuGJoDo3LT3Nx62V5/GVbI7qMPSHE8jE5rWb+ZWouE3Lj39dxJkY4TOvXv4F3wwakroOmMTKtjOZZU/nOkmtoqT04sO3Pv3AXD7+4GothUOzxx7HUijJ0qCajc3jncPeg9n6ttx1LcjYnJ2j7wjqbjxyPV/EuiLfquvj7rhZOditLXUOYrQhgTlk6P7ppQjyLd05t3/s3vG+9hQyFILZKV+g3P+Erc6YMBIOU7GxyysfQUlfDG8/+EbsmsT72CAcnTablgQcIHTkSz0tQlLhSAeEc3r3QjNmdivVdI4MupUlagbDOvz67k0AkuviOlMbAfAMJbDzcfc6RWPFihMOc+Pvf6V+9Ghk81eHdHQ4zc9s7+HuiQdtkseDv95JXVg7CxPr//j2Zz/yZcPUuZChE/5rXOHbLrfiHwURKRbkQLp272QWwZFIOztMWsTDZXYM6WF02MwsnjDjTrsPSP/a1DpqWLsNBhPVUEr2wJnny7aMXv2Dn0PvSSxyaNZuOH/wQ9FMjxNa0tXHlsaNIwCmjMzyS7C4igQDhphZyU9MRXZ185xc/wIilKMEwkIEAzffdh/wn1wFWlOFIBYRzuGVaHnar6YzTxSwmQV6qk9mlw2M8/gexv6Vv0LBbI+wflFVVl5L9LR9tofMLoe+112j/wQ8xfD5kODzw+isnTvBAf7ScLuBkdkaTr59r3E4WtjdS1H+CHr+PoGHwaHfXoOMa4Qjet96+SFehKEOHCgjnkOSw8vwXZ5GZaMdtjz4pCKJPBmVZCfzpczOHXQqHc0l0WDltxClmdyq27JJB27iHyHoLUko6H/mPQU1EAP+3vY1/6+wgEaiw2fAADiAVcJlMjLPb6dQ0vJpGCKgLhfjTiRM809V56tihEOFjQ+tJSFEuhqHx1z2ElWcnsunb81l/sJMtR45jMUcXn7+8OO2SCgYAN0waye/fOYoeS9EhTGYwnWoyc9nM3D59aEwICtXVoXsGZ2a/8fBhjuoaJSYTHqA2HMYO+Il+8imw2ugzJEFp4JUSCYSBm91ubk89tWyjsFoxJQyNYcCKcjGpgPABWMwmrh8/guvHXzr9BWcyZkQSc8oy2Hio+z0J+swmQbLTyic/xBDb800aBr5NmwlW7SPSObiZ53OHDnHE0BktBLrJhF/TSBQmgtIgARhdUEixlIwKhzkWCtGn64y1WjEBJxDYLKf9Keg6idcsuKjXpihDgQoIyiC/+tRUvvG3vbxe3YHZJDBi6dFHZSXy5F3TcNni8ysTOnSIxi98Eb2vL9pMZDKBpqHrOiuamzho6My02ciw29nn9RIGCpHUAMX5+Sy6+y6uHzOGH9x7L7V+P9kWCw9mj+AvvSfYFQxyNBigxOFEOJ2k3H4blvRLp29IUT4oFRCUQRxWM48vm0p7X5C36rqIGAZT8lMHEvvFg3biBPWfvhPD44nOOgYwDHrCYe5qbgLDIMti4cbkFFZ6+mmVkhFmM602G26LhZyiIkKhEH/fsYNAbi5J9fXMcrkpczqZHonQHInweE8PPy8qJvmGT5D+uc/F7VoVJZ5UQFDOaESyg9uGSH9B71//Gp1sdtpiTocCfj7X3EyWxcLliUls8fs4EAxyMBjEAiwqKOSPzU1cN38+kUiEjRs3IoQgubSUuQsWsBjYtH07JdlZXGtI/rBrJ43BAIWr19D3ykqcU6cy4t++h71MrZegfHyoUUbKkNe3clU0IMT8uLWF2xsbybVa+UJ6BvWRCJclJlIVCqIJQUVZGav8PlwuF5FIhEmTJpGcnEx2dja5ubkk5+fjvucebnr5ZQK33IK5qZFc4NHW1oEhrP6tW6m//Q6CdXXxu3BFuchUQFCGPBkODfr5RY+HbJOZ5WnptITDtEXC7HM4aHS5SB45kpzx4+no7CQ3N5eJEyfS2dlJVlYWubm5zJgxg/vvvx+n08nWrVsxr32dRq+XRS43uwMB2k/OZ5ASw+ej/Qc/jMMVK0p8qICgDHmOSZOinchE5x8U2GzclZZGmsWCD4nTZOJ4IIDZZGL0qFG88cYbOJ1OcnJyqKyspLu7m9zcXBobG+no6GDr1q14PB5Kc3Ox1daSKEy0GwbJZjP/1t426NzBqioiHZ1nKpaiXHJUH4Iy5KV/9h68b7yJDAY5HAqRZDaTbrPSp2ts9Xg4Gg5jC4dJNVvo3bKFQDjMoquuojcUori4mPvuu4+2tjYKCgrIysqioqICr9dL8549dBsGupQcC4cIRiJsikTo7OsjKzma0VXYbGhdXVizs+JcC4py4amAoAx5zgnjybjvProefZRNPh9FVhtOk4mmUIjacAQBaECZ1cKeQBA70LtjBzlz5lBcWkpdXR1SSlwuF1VVVTQ3N6NpGv6+Pjp8XjQp6dJ0HFYrV1ut7BaC66RECIEMh7Fkxn/hIkW5GFSTkTIsuKddhrDZ2B8MMtnpxC0Ez/ScIIhEAybZbGSYzXRKA5eUOAyD0M6dpKamUllZycGDB9E0jbS0NILBIFdeeSWXzZxJ2YQJaAIkkuWpqUx3J2AVUBPrxHZMmKCeDpSPDRUQlGEhdPgIGtCla0xyOlnd20eDrmEBRlosmE1mXvZ4EMDVSUnYzWYud7lp2bOH7OxsRo8ezS233MKyZcsIhULU1tbidrtpGTMGabFyucvFaIeTFLOZdIuFTk2j22plxMMPx/nKFeXiUU1GyrBgSkygPhLBIgQpZjNmk2CkyUQYuCohkZ2efrzASCDBbGGU1UKWxcK8y6bRkJtDf38/69evx263s3DhQt566y2qq6vJGzuWkV/+ElP372fP1q1kut306xpXzZ7D3tmzuLyoMM5XrigXjwoIyrCQcMUV7PV4SDObORIO0xKOYAjBFJudLl2jWUoKgM9mZyMQTHY4aAca/T6OHz9OWloaUkquuOIKXnrpJfbt28fVV1+NEIIp8+Yx4aGHqPrpTynPy6fN52XcihW46uvZsGED1113XbwvX1EuCtVkpAwLJpeLw8VFlLjc7PD7qQoFKbXZyLLbOBQIEjAM5iUmkmWxkmwSbAsEOK5FqNN1Pv3pT7Ns2TK8Xi8/+9nP0DSNa665htbWVjIzM5kwIbosaHJ2NnpmBkkjRuD3+ykqKsLtdlNdXR3nq1eUi0MFBGXIk7qOt7WV3pQU0q+Yw/ZgACEESVYrXeEwfmmQb7XiFYKeSIR9wSApDgeTV6zg1jvuIDExkY0bN9LW1obf76e8vJzs7Gx6enqYNm3awHnS0tLo7e0lPT2d7u5uAKakp7Plu99ly6TJHJw0mWO334HnzTfjVRWKckGpgKAMWUY4TOfjj1M3azavXXkVwTcr2bVtG0dsNqZcdhkncnIYtfgTeMxmRlqtlCUmsjEUYnRaGp/6j0fwV1QwYsQIXn75Zaqrq7n66quZMWMGu3fvJhKJsHTpUupOS02RlJRET08PGRkZdHd349u0icY7ljHhYC3buruJBIME9+6l5WsP0PGTR+NYM4pyYag+BGVIkuEwjXfdTfBgDTIYosbjQZOS3S0tuM1m3G432WPG8Ma2bdjT0ljx4IOMT03F8tZbZE6fTu2IESTrOq+++iqapjF//vzoKmudnRiGgRCC2bNn89JLLxEIBHA6nUgpsVgsJCUlUXfgAO6Hv48MBkkSgjK7jd2BANNdLmQgwIk//YnEBfNxTZ0a76pSlPNGPSEoQ1LvSy8RrK1FBqPzAerCYaoDfjQgx2qlfft2vB4PLS0tLF++nDvvvZfNx49z7e23c/X8+TzxxBM0NjZisVhYtGgRVquVmpoapk2bRlpaGoFAAICKigr27dsHQCAQoLCwEI/HQ+fGjcjTsqsW2+zoUtIQy3Ukg0Eal6+g9TvfJXT48MWtHEW5QFRAUIaknj/+NzJ20/boOof8PjoNg3FWGylC4DcMuuvrycrK4vOf/zwNDQ10dXUxYcIEnnvuOWbOnEltbS2zZs1C13V27drFggUL2LhxIzfccAP5+flUV1dTWlpKc3MzoVCIYDBISUkJTU1NmDo6CHq9A+Xp1XUcJhO1wSBeXQeiTzF9K1dy7JZb6V/7elzqSVHOJxUQlCEp0tEx8H1dKMjWcBgbkG6z0qJpJCHYffAg11xzDYFAgN/+9rfk5eXxwgsv0N3dTUlJCQ888ADr169n9erVXH/99ezevZsxY8aQkpLClClTqKurw+/3M378ePbv308kEiEvL4/Ozk4yMrPoPW3N7GSTCTOgI9no9w2sJIeuI4NBWr/5TbRYR7SiDFeqD0EZksxJSWh+PwDVgQDpwNWJSXRqEfyGAUInNTGRO++8k0OHDnHw4EHy8/M5cOAAOTk5WK1W1q9fz549ewDo6uoiEAhw+eWX09zcjN1ux2q18sc//pErr7ySTZs2IYSgo6MDIQS2aZfR9eKLZJlMCCEQQlDhdJJqNrPO62Wz38ccd8KgMp947nkyv/yli1xTinL+qICgDEmpt99O929/iwyF2BYIUORwMNJmpSoYJFEIjoTD3LBgASUlJTzxxBPccccdQLRP4N5778Xv9/Paa6/x8MMPI6XkP//zP1m+fDklJSWEQiHC4TDhcBifz0dXVxe5ubm8/fbb1NfX4/P5aDx+nLasTNpaWiESGSiXRcAIi5lnjvdQHwrx6bTo2ssyFCKwa1dc6kpRzhcVEJQhKfXTn+LE88/T0dZGW0RjtM1KQzhMGInLbCEzI4NxFRV84xvfICUlBbPZjMvlYtasWYRCIdauXcsVV1xBamoqa9as4d5776WqqgqbzUZpaenAeW666Sb+8Y9/sGDBArZv38706dOpqKjgrbfeouCrX2XWvir6V65E6jroOhEpiUhJu6bhFoNbXE0u18WuJkU5r1QfgjIkmZOSKH7heWoKCjCEIGw20yUlY9xujpnNFI8fz9ixYykqKkJKSTAYpKOjg9zcXNauXcv06dPJzs5m3759ZGRkUFxczKJFizh48CAHDx4cOI/D4WDy5Mls2bKFkpISampqSEhIIBgMYrJayXjoQcoq3yTtM3cibDasQuAzDMbYHTgt5oG+BJPbTfLSJfGqLkU5L1RAUIacYF0dbT/8Ia3f+jZvdHaQN7GCY2lpFF41D++ECTgSEhgzZgw1NTUIIXjkkUfIysrCbrfz4x//mJEjR5Kfn09XVxcNDQ0Ds5GtVivXX389DQ0NVFVVDZyvrKyMnp4e0tPTqa2tRdd1Ro4cCUBPTw9S04ic6EXGmo4OhoKMcTjIimVFxWLBkplJwrx5F72uFOV8UgFBGTKklLT94IfU33Y7vc89j+edd9hbU0PP/v24QyFsaans3bePm2++mf7+fqSUXHnllQghCAaDZGVlcd1119HT08Pq1atZs2YN8+bNw2Q69WtusVi49tpr6ezsZNdpbf6TJk3iyJEjFBYWUltbS15eHuFwmLaDtRz75M14Xn0VpKQ3NuQ0xWwm12qlVYBjzBgKn30GYVEtsMrwpgKCMmSc+NOf6Xv5ZWQwCLoeHfNvGByPRMjxetn5xhukp6ej6zrTp09H0zSKi4sHUlFkZmYye/ZsFi5cSDAYJBAIsGvXLjwez6DzmEwm5s+fj8fjYcuWLUA0UJSVlWEYBjU1NWRnZxMMBjn8m1+j9/aCpgFwMBhkjN0BQIbFSm9GJkUvPI8lI+Oi1pWiXAgqIChDgjSM6Kii2GQ0gFd6e/HqOg4J6UBTWxuTKypIT09n6dKl5Ofns2vXLrZu3UpeXh5TpkwB4OjRoyQnJ/PFL36R0tJS1q9fz8aNGwdmJwMIIbjyyisxDIO3336bQCBARUUFbW1tpKamUl9fT1pCAvWbN0PsqcCr6wSkQWbsScAEJHZ20nrgwEWrJ0W5kFRAUIaESGsben//oNde9vSTazYzwm5jfyiEAK6cPJlp06bR3d3NzJkz2bt3L0IIZs6cCYDX62X37t3MnTsXgPz8fJYuXcrIkSNZs2YN27dvJxxLP3Eyn5HT6WTjxo04HA7mzJlDd3d3dF5CIMDRUJh9gQA7/H5+3d3Fj9rb8Z02DDXX7ebI3r0Xp5IU5QJTAUEZEvzbtkHsRg1wXNNwCcGNySl4IxFqwmHmJyXT0NTMwoULOXz4MCdOnBgYRtrT04OUksrKSubMmYPNZhs4lhCCkpISli5ditVq5dlnn2X16tXs27eP7du34/V6qaur47HHHqOyspLGxkaOHDlCl89HRNfxGwa1oSAHgkEWJiayIxQayHOULQTtPt9Fry9FuRBUL5gSd4bPR/uPfjTotV0BP+McDrYFg/RLidNkIt/pZMaC+XTE0lpUVlbyuc99DrfbzRtvvEFmZiZ2ux2/309VVRU+n2/gnxbrA3A4HBQXF9PZ2cmbb77JhAkTmDRpEh6Ph5ycHDo6Ovjyl7/MSy+9RCQSIZKRwd7uLgKGZJTdwb8kpxBAciAUYrzDgau0lJTCQnp7e0lJSbnYVaco55UKCErc9a1ePehnKSWbfT4ihsRqMujSdSY5HMgJ4xmRm8vTTz+Nz+fD6XSyY8cOdF3nwIEDNDQ0cNddd9HX14fb7SYtLQ23243b7cZqtb7nvOFwmKqqKjZs2EBHRweLFy/m6NGjrF27loSEBF568UWSy0fR391FutmM22SiwG7HArzl89FpNnH5ww+huVzU19czefLki1NhinKBqICgxF1w//5Bncm/7OpiZV8fRVYrzcEIOuAVAvukSbS3t9PR0cGsWbOYOXMmxcXF6LqOlJJx48ZRVlZGTk7OBzqvzWbjsssuY/z48fz85z9n5cqVpKWl0dbWRuD4cXK3bWNvWxtJEiJWwWiHA6sQYLMxt7SEPfOuZnp5OQUmE2vXrlUBQRn2VEBQ4s6UmAQmExgGAHMcDv6OAAR+oMxmIyExkcbGRrZv305ZWRnr168fWO6ysbGR0aNHk5eXxyuvvMINN9xASkoKTqcTyweYG+BwOMjKyiISiVBdXU1mZibNv/sdHZ1dZAB7ggH+xZ5CcaxfwmSzUf6Xv5Dq8/Hmm2+yaNEizGYzfr8fl0pfoQxjKiAocZe0aCEnnn02Ov8ACJlMFNpt9Og6JqDA4eDGT34SfcwYkpOTSUxMpKSkBLPZzO7du/H5fHR0dNDY2Eh3dzePPvoo48aNw2QyYbPZcDqdOBwOXC4XTqdz0Fdd16mqqqK+vp6vfe1rJCcns+qxx2jv6qbMamFnOEyPrhMBRsaanaSu0fviS+SsWE57ezs7d+4k2+9n6/33U6Ib2MvKSF22DHtJcfwqVVE+AhUQlLhzjh+Pa9pl+LfvQIZCHAgFsZhMdIXDFJjN9AvB601NfGnpUtxuNz6fjylTptDf38/hw4d58MEHB/oI/H4/q1evJiUlhdTUVPr7++nv7ycQCOD3+7FarVitVqSU1NfX09PTQ2FhIQDr1q2juroaY9MmxphMhIBOTcOjabzW18ftsU5jGQjSv2Y16SuWM3n8eJ6+6Say6+tp8PoY4Xbj376d3uefJ235crL+9/+KT6UqykegAoIyJOT98pe0fuvbeCsrqYlEaNM0LCYTVxQU0FFayshY0rqKigqWLFmCYRhUVlYyd+7cQR3GLpeLJUuWsGrVKmbNmoXb7R54T9M0ent72bNnD3v37mXkyJGMGjWKrq4uzGYztbW1lJSUkN3UhL+2lupwmLA0SDKbCUqD170ekk1mRlitFIaiS3t2/uQnTG5ppbK/H11CWEpsmobUNHqefhp7+SiSP/GJi16fivJRqICgDA1SknzjDTgmT6L5oYfoCgaZftllaGVlTC0sZPLkyWzdupXGxkZqa2sxmUwUFBSQmZn5nkPZbDZmzZrFhg0bWLRoESK28ll7ezvbt28nLy+P+++/fyCQHD16lI6ODq699lpcLheb9+9nezDE5v4+ss0WxjtdTHW5cJtMGFJyTNc56nZT9cwzmJ5+hmzDYLLDyVqPh9ZwmCK7PXpJgQDdj/9SBQRl2FABQYkrKSXHn3qK7l/9GmE2c9Tvo6G5GZvZTFpKComJieTk5GC32ykvL8dqtdLb28umTZv46le/etbj5uTk0NjYSHV1NXl5eWzZsgWbzca1115LQsKplc58Ph9r1qwhMzOT1tZWDMMgbcYMMp9/nqkhBxOcLma53Thiaa+9hoHPaiH51lvpqDvEgWCQjX4/YWnQFA7zttfDkwWFA8cPNzeje72YExLOVExFGVLUTGUlro7/PhoMZCCA4fVS2dmFF7jM7kDbtg2HYZCZmUlfXx/FxcUsXLiQyspKbr/9drZs2cKuXbswYqOT3q2iooJVq1axevVqpk6dyvz58wcFg4aGBn7xi1/Q3d1NQiyltqZpFJSUkHLnnZSlpDDC7SbJbMZmMpHqclGQlMSC3/yGeUuXMqOighKHA4dJ0K5peAyDVJP6k1KGL/WEoMSN4ffT/etfD5qD8OyJHkzAtYmJ7AwF8e3di5w/n3A4zNSpU9m5cyfLly+nrq6OqVOncvz4cf7xj38wb948kpKSANB1nerqag4dOsR1111HU1MTGbFspJqmcezYMbZu3UpNTQ233XYbXq+X9vZ2amtrWbBgAV6vl24pGffgg1yl6QRffx09EiE4eRK+2bPZ3tJCw7//O1oggDXgJ9ls5rrEJKa7XLjeFRBs+fnq6UAZNlRAUOLGt2kTwmRCxn6WUtJqGFzjdJFhtRD264hjxzh+/DijRo2is7MTh8PB+PHjKS0t5fXXX2fs2LHMmjWLdevWMW7cOOx2O7t376akpISbbroJs9mMxWJh/fr1uN1uWltbcTgcCCH4zne+Q3d3N6tWrWLBggXMmjULgL/+9a9kZGRQOHo0bU4njVnR5qRQKISlro6xY8eyYMECAoEAbx47RsHuPeRL+Z7rE04nmfd95SLWqKL8c1RAUOJG93gHksQBrOo9gQO4Oz2dZi2C35AkGBJN0xg1ahS7du3ixhtvBKKTyRYvXsy6devIyclh9uzZPP3005jNZlasWEFaWhqaplFXV0d9fT179+5l8eLFTJw4kYMHD7Jo0SI2b96M2WxmypQpjBkzhtbWVqqrq1mzZg2FhYWkp6cTiURwuVzMmDGDoqIi0tPT8fv9bNy4EYvFwqd/9zu6v/ktfFu2ROdRSAkWC8JsJn3FCpIWL45T7SrKh6cCghI39rLS6A00ZklqGktS09jh99MWjqAh0ZMSKSsrY/fu3Vx55ZWDZh5bLBbmzJnDU089hWEY3HPPPfh8Pl54/HEs9Q1gGIyeO5cFt9/GggULePLJJykpKaGoqIh169ZRXFyMEILKykp8Ph9JSUm89tpr2O12pk+fzsSJEykqKiIxMXHgnLW1tezfv5/LL7+c/Px8APJ+/SuCe/dy4vkX0Lq6sJeUkLrsDmxFRRetLhXlfFABQYkbx4QJWLOzCdfXD3pdR1KvRbBaLLimTsVqtZKXl0d6evrANpqmsXfvXhoaGrj55ptpamrileeeI/zMM9DRwfFgiBFmM8n79tH+5z/T8qV/JRAI8Nprr1FSUkJxcTHhcBibzYbNZsNiseDz+Whvb+fuu+9m0aJFg8rU39/PO++8Q3JyMkuWLBk090EIgXPyZJwql5EyzKkhEUrcCCHIfewxTAkJYDYPvK4ZklZNw5aWRul11xGJRJgwYQIQ7Weoq6vj5ZdfHljQpr6+nra2Nnz/9Qe0llbmWG1cn5iIBP6rqYn/2LOHJ77yFYy2dsqsViamppKVlRXdx+cjIyODJUuW4PF4KCkpYd68eQNlkVJSVVXFunXrmDp1KnPmzDlj5lRFuRSogKDElWN0OSWvvEzSDZ+AWHNQv2HQH9GwCoE83sO8efMQQtDW1sbKlSvp6OigrKyMQ4cOsX//fsrKypiflcW4YICIpvF4dxdveDxYhMBMNP1EniHJXrkSVv2D1x56iMgDX+fa9HRml5aSJgR+r5f169dz66234nQ6Aejp6WHVqlUEg0GWLl3KiBEj4lhTinLhqSYjJe6E04l/85aBn1vDIbzSIPnECYqfeYb+q67i7f4+ent7cbvddHV14XQ6GTt2LD09PWzbto3e557H6fEy2emk3G7nDY+H9f19pFiszHW7MAkTPeEw8xIS8JtcHGpvI+dfv0TEYuG438+vfvIT0kaPZmJFBbqus3v3blpaWrjiiisGNVUpyqVMBQQl7rp+8ThaTw/EVjXbHwyiS8l0h5OW/n4qP3cPuffdR2JiIrquI4Sgvr6exMREXC4XI0eOJCIEnbpGuxbBIgS9WoR2TWeEzU6S2cxUpwsN2Ob3U2iz4RKCI6EQWboOoRCV/X08YLVR/cDXOTLvKkpLS7nxxhsxqYlmyseICghKXElNo+/llweCAUBVMIhLwhs+LyBICQawHzmCVlhIIBAgKSlpYCW0pKQkkpKSyLr+erw1NVhik9zmJ0RHBnVFImwLBHiy5zipZguTHQ56NA2fYdCmBTHjYLvfT6HVSrffx9FVK/nkp5aRPXFiHGpDUeJLBQQlrgyfD3R90Gutuk6ByUTAkOTbrGTaHYxwOMnMzycxMRGr1YrFYsFisWAYBh6PB9PECloiEUzhMOZY34FZCKwmE3Pdbq5wu2kMhagOhcgym+mTBu0RjSOBADsCAW5NSSXZZGaKw4m+chXMmBGfClGUOFIBQYkrk8sFsWykJ+0pLsFmsyGlRAOkw0HuTUuxlJSgaRq6rg/6qmkausVC2oMP0vr976NFItF/UmLAoK9ZVguGBJsU2IXgFY8Xu0nwiaQknLFV2yJNjfGoCkWJOxUQlLgSViuJixbRv2rVwBKatthSlUIIrIB1RDbpU6YMpLE+q7Fjicybx4m//BnPa2uRug4WC5GmpkFNUqdbnpoKcKqvwGTCmpt3Xq5NUYYbIc+Qg+V8mjZtmtyxY8cFPYcyvEVaWzn6yZsxPJ6BoHCScDjI/93vcM+4/CMdW+/t5di/3ILW2YmMRN53e+F0Uvj0f+OsqPhI51OU4UAIsVNKOe3dr6shFErcWXNyKP7bC7hmzEDYbJgSExAOB/bycgp+/+RHDgYA5pQUil/8O6l3fSY6Ac5kiv47bSLcScLpIHHBfBUMlI8t9YSgDClaVxeRtjbMqanYYrmCzhcpZfQpwWym5w9/4PiTv4dIBAkIs5m0FSvI+OIXEGcIFopyKTnbE4IKCMrHltQ0wseOIaXEXlyMUCkplI+JswUE1amsfGwJiwX7qFHxLoaiDBmqD0FRFEUBVEBQFEVRYlRAUBRFUQAVEBRFUZSYCz7KSAjRBTRc0JMoiqIoH0ahlDLz3S9e8ICgKIqiDA+qyUhRFEUBVEBQFEVRYlRAUIYtIcRvhRAPxrscJwkhCoQQXiGEyn2hDEuqD0EZkoQQ9UA2oAE6cAB4GnhCSmmcY9dLkhDiR8BNwFjg/0gpvx/XAimXJPWEoAxlN0opE4FC4D+AbwFPxbdIcXMY+CbwarwLoly6VEBQhjwpZZ+UciVwO3C3EGICgBDij0KI/xP7fp4QolkI8U0hRKcQok0IcZMQYrEQok4I0SOE+O7JYwohTEKIbwshjgghjgshnhdCpMXeKxJCSCHE3UKIRiFEtxDie6fte7kQYocQol8I0SGE+Om79rPEfs4RQqyMnfuwEOLzpx3j+7FzPi2E8AghqoUQ70k2dlod/LeUcg3gOa+VqyinUQFBGTaklNuAZmDuWTYZATiAXOAh4EngTuCy2D4PCiGKY9veR7QJ5iogBzgB/Opdx7sCGA0sAB4SQoyNvf4Y8JiUMgkoBZ4/S3n+GitvDnAL8O9CiPmnvb8ktk0KsBL45VkvXlEuAhUQlOGmFUg7y3sR4MdSygjRG20G0Ru3R0pZTbQfYlJs23uB70kpm6WUIeD7wC0nP93H/EBKGZBS7gX2nrZvBCgTQmRIKb1Syi3vLogQIh+YA3xLShmUUu4Bfg/cddpm70gpV0spdeCZ046vKHGhAoIy3OQCPWd573js5goQiH3tOO39AJAQ+74QeEkI0SuE6AVqiHZeZ5+2fftp3/tP2/ceoBw4KITYLoS44QxlyQF6pJSnN/E0xMp/tuM73hWQFOWiUr98yrAhhJhO9Ib6znk4XBPwWSnlxjOcp+hcO0opDwHLhBAm4Gbgb0KI9Hdt1gqkCSESTwsKBUDLP11yRblA1BOCMuQJIZJin8L/Cjwrpaw6D4f9LfBjIURh7ByZQoilH7A8dwohMmPDX3tjLw8aCiulbAI2AY8IIRxCiIlEnyye/SiFFUJYhRAOon+zltgx1XwH5bxSTwjKULZKCKERvdkeAH5K9EZ+PjwGCOB1IUQO0Ak8B7zyAfZdCPxUCOEi2gx0h5QyIIR493bLYuVtJdpp/bCUct1HLO+TwN2n/fw9YAXwx494PEV5DzUxTVEURQFUk5GiKIoSowKCoiiKAqiAoCiKosSogKAoiqIAKiAoiqIoMSogKIqiKIAKCIqiKEqMCgiKoigKoAKCoiiKEvP/AekJneKIZDi2AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 396x280.8 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Set the perplexity value\n",
    "perp_val = 40\n",
    "\n",
    "# tSNE Aobs\n",
    "tsne = TSNE(n_components=2, perplexity=perp_val, random_state=0)\n",
    "# tSNE the embedding of just the true adjacency matrix\n",
    "A_tsne = tsne.fit_transform(dense_adj)\n",
    "\n",
    "# Convert to DataFrame\n",
    "A_tsne_df = pd.DataFrame(A_tsne)\n",
    "A_tsne_df.columns = [\"Dimension_{}\".format(i+1) for i in range(A_tsne_df.shape[1])]\n",
    "A_tsne_df[\"tau\"] = np.tile(node_labels, 1)\n",
    "\n",
    "# Standardize the data in the Dimension_1 and Dimension_2 columns\n",
    "scaler = StandardScaler()\n",
    "A_tsne_df[[\"Dimension_1\", \"Dimension_2\"]] = scaler.fit_transform(A_tsne_df[[\"Dimension_1\", \"Dimension_2\"]])\n",
    "\n",
    "# Assume B=20 and other required variables like 'yhat', 'node_labels', 'in_cov_friends_symm' are already defined.\n",
    "B = 20\n",
    "\n",
    "A_boots_list = []\n",
    "\n",
    "for b in tqdm(range(B)):\n",
    "    _, A_boots = create_single_kNN_bootstrap(dense_adj, d=d, Q=1000, n_neighbors=k)\n",
    "    A_boots_list.append(A_boots)\n",
    "\n",
    "A_list = [dense_adj] + A_boots_list\n",
    "yhat = UASE(A_list, d=d, sparse_matrix=False)\n",
    "\n",
    "yadf = pd.DataFrame(yhat)\n",
    "\n",
    "# Rename the columns - this is called a list comprehension\n",
    "yadf.columns = [\"Dimension_{}\".format(i+1) for i in range(yadf.shape[1])] \n",
    "\n",
    "# Repeat tau list the length of A_true_boots_list times\n",
    "yadf[\"tau\"] = np.tile(node_labels, B + 1)\n",
    "\n",
    "# Add column for the matrix it is\n",
    "yadf[\"Matrix\"] = np.repeat(range(B+1), len(node_labels))\n",
    "\n",
    "# Repeat range(len(node_labels)) B+1 times to give each node a unique number\n",
    "yadf['NodeNumber'] = list(range(len(node_labels)))*(B+1)\n",
    "\n",
    "\n",
    "\"\"\"\"Create the new uncertainty adjacency matrix using this many B bootstraps\"\"\"\n",
    "in_cov_friends = np.zeros((n, n))\n",
    "\n",
    "for i in range(n):\n",
    "    # Filter data for node number and select the relevant dimensions\n",
    "    node_number = i\n",
    "    data_d_dim = yadf[yadf[\"NodeNumber\"] == node_number].iloc[:, 0:d].to_numpy()\n",
    "\n",
    "    # Calculate the mean and covariance considering all d dimensions\n",
    "    mean_d_dim = np.mean(data_d_dim, axis=0)\n",
    "    cov_d_dim = np.cov(data_d_dim, rowvar=False)\n",
    "\n",
    "    # Use the point corresponding to the specific node_number in matrix 0 as the center\n",
    "    point = data_d_dim[0]\n",
    "    obs_points = yadf[yadf[\"Matrix\"] == 0].iloc[:, 0:d].to_numpy()\n",
    "\n",
    "    # Plotting only the first two dimensions\n",
    "    data_2d = data_d_dim[:, 0:2]\n",
    "    obs_points_2d = obs_points[:, 0:2]\n",
    "\n",
    "    # Filter points within the ellipse\n",
    "    inside_ellipse = points_within_ellipse(obs_points_2d, point[:2], cov_d_dim[:2, :2])\n",
    "\n",
    "    # Extract node numbers for points inside the ellipse\n",
    "    node_numbers_inside_ellipse = yadf[yadf[\"Matrix\"] == 0].iloc[inside_ellipse].index.tolist()\n",
    "\n",
    "    # Set in_cov_friends[i, node_numbers_inside_ellipse] = 1\n",
    "    in_cov_friends[i, node_numbers_inside_ellipse] = 1\n",
    "\n",
    "# Symmetrize the matrix in_cov_friends\n",
    "in_cov_friends_symm = np.minimum(in_cov_friends, in_cov_friends.T)\n",
    "\n",
    "# Plot the scatter plot\n",
    "fig, ax = plt.subplots(figsize=(5.5, 3.9))\n",
    "scatter = ax.scatter(A_tsne_df[\"Dimension_1\"], A_tsne_df[\"Dimension_2\"], c=A_tsne_df[\"tau\"], cmap='tab20', s=70, alpha=1)  # Increase marker size\n",
    "ax.set_xlabel(\"Dimension 1\", fontsize=12)\n",
    "ax.set_ylabel(\"Dimension 2\", fontsize=12)\n",
    "\n",
    "#  no ticks\n",
    "ax.set_xticks([])\n",
    "ax.set_yticks([])\n",
    "\n",
    "# Draw lines between connected nodes based on the F matrix\n",
    "for i in range(len(A_tsne_df)):\n",
    "    for j in range(i + 1, len(A_tsne_df)):\n",
    "        if in_cov_friends_symm[i, j] == 1:  # Check if nodes i and j are connected\n",
    "            ax.plot([A_tsne_df[\"Dimension_1\"].iloc[i], A_tsne_df[\"Dimension_1\"].iloc[j]], \n",
    "                    [A_tsne_df[\"Dimension_2\"].iloc[i], A_tsne_df[\"Dimension_2\"].iloc[j]], \n",
    "                    'k-', lw=0.8, alpha=0.4)  # Draw a line between them\n",
    "            \n",
    "plt.title(f\"B={B}, perp={perp_val}\")\n",
    "\n",
    "plt.tight_layout()\n",
    "\n",
    "plt.savefig(f\"figs/school_A1_tsne_4classes_perp30_B20_plot_tsne(A)_B{B}_perp{perp_val}.png\", bbox_inches='tight', facecolor='white')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 864x216 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "reshaped_A = np.hstack(A_list[0:4])\n",
    "\n",
    "plt.figure(figsize=(12,3))  # Set figure size as needed\n",
    "\n",
    "sns.heatmap(reshaped_A, cmap=blues_cmap, cbar=False) # \"Blues\"\n",
    "\n",
    "matrix_positions = [0, dense_adj.shape[0], 2 * dense_adj.shape[0], 3 * dense_adj.shape[0], 4 * dense_adj.shape[0]]\n",
    "\n",
    "# Add gridlines at the change positions\n",
    "for pos in matrix_positions:\n",
    "    plt.axvline(x=pos, color='grey', linestyle='--', linewidth=2)  # Vertical gridlines\n",
    "    plt.axhline(y=pos, color='grey', linestyle='--', linewidth=2)  # Horizontal gridlines\n",
    "\n",
    "# Disable x and y ticks\n",
    "plt.xticks([])  # Remove x ticks\n",
    "plt.yticks([])  # Remove y ticks\n",
    "\n",
    "# plt.savefig(\"figs/school_A1_Aboots_heatmap_blueCustom_4classes_4mats.png\", dpi=300, bbox_inches='tight', facecolor='white')\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
