{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "cf4f3952-dd30-43c9-882e-73d663caa660",
   "metadata": {},
   "source": [
    "# Hyper-Low-rank-PINN"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f81421aa-9e54-421b-ad93-4d3219003caf",
   "metadata": {},
   "source": [
    "## Libraries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c1f80927-c505-4eb1-8a9a-699a8c210d12",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append(\"../src/\")\n",
    "import torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from models.hyper_lr_pinn import LR_PINN, create_phase2_model\n",
    "from loss_functions.poisson import loss_fn, get_source_function\n",
    "from tools.tools import print_trainable_parameters, sample_parameters_from_folder, plot_parameter_points\n",
    "from tools.train_loops import fine_tune_meta\n",
    "# -- matplotlib styling\n",
    "plt.style.use(\"fast\")\n",
    "plt.rc('text', usetex=True)\n",
    "plt.rc('font', family='serif')\n",
    "plt.rc('font', serif='lmodern')\n",
    "plt.rc('font', size=12)  # Adjust the font size if needed"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4970ec08-a8c0-4cf5-b70e-b1e5fb43bce4",
   "metadata": {},
   "source": [
    "## Load dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "ab3fb202-caeb-4dea-b886-c5281fe96d2a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[Train]  ['test_alpha_0.796.npz', 'test_alpha_1.092.npz', 'test_alpha_1.388.npz', 'test_alpha_1.684.npz', 'test_alpha_1.98.npz', 'test_alpha_2.276.npz', 'test_alpha_2.571.npz', 'test_alpha_2.867.npz', 'test_alpha_3.163.npz', 'test_alpha_3.459.npz', 'test_alpha_3.755.npz', 'test_alpha_4.051.npz', 'test_alpha_4.347.npz', 'test_alpha_4.643.npz', 'test_alpha_4.939.npz']\n",
      "[Train]  ['train_alpha_0.5.npz', 'train_alpha_1.684.npz', 'train_alpha_2.571.npz', 'train_alpha_3.755.npz', 'train_alpha_4.939.npz']\n"
     ]
    }
   ],
   "source": [
    "device = \"cuda\"\n",
    "dataset_path =  \"../dataset/poisson/0\"\n",
    "output_dir = \".\"\n",
    "# -- get testing parameters\n",
    "parameter_test_org, file_test_org  = sample_parameters_from_folder(dataset_path, N=30, idx_start=1, type=\"test\")\n",
    "# -- to get a shorter range\n",
    "mask =  torch.tensor(parameter_test_org) < 5.0 #7.5\n",
    "parameter_test = torch.tensor(parameter_test_org)[mask]\n",
    "file_test = [f for f, m in zip(file_test_org, mask) if m]\n",
    "print(\"[Train] \",file_test)\n",
    "\n",
    "# --\n",
    "parameter_train_org, file_train_org  = sample_parameters_from_folder(dataset_path, N=12, idx_start=0, type=\"train\") \n",
    "mask =  torch.tensor(parameter_train_org) < 5.0 #7.5\n",
    "parameter_train = torch.tensor(parameter_train_org)[mask]\n",
    "file_train = [f for f, m in zip(file_train_org,  mask) if m]\n",
    "print(\"[Train] \",file_train)\n",
    "# -- plot parameters\n",
    "plot_parameter_points(parameter_train, parameter_test, output_dir, \"hyper_lr_pinn/parameter_variation.png\")\n",
    "# -- load the actual data\n",
    "dtype = torch.float32\n",
    "X_train = torch.tensor(np.load(f\"{dataset_path}/{file_train[0]}\")['x'], dtype=dtype).to(device)\n",
    "Y_train = torch.tensor(np.load(f\"{dataset_path}/{file_train[0]}\")['y'], dtype=dtype).to(device)\n",
    "X_test = torch.tensor(np.load(f\"{dataset_path}/{file_test[0]}\")['x'], dtype=dtype).to(device)\n",
    "Y_test = torch.tensor(np.load(f\"{dataset_path}/{file_test[0]}\")['y'], dtype=dtype).to(device)\n",
    "solutions = [torch.tensor(np.load(f\"{dataset_path}/{f}\")['u'], dtype=dtype).to(device) for f in file_test]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ef5d97e7-9e4e-4a2e-ba30-3a38e1155560",
   "metadata": {},
   "source": [
    "### Dataset Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "25cb1a79-5fa5-460c-8971-58d67dbb7d0e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAikAAAG0CAYAAAD3g7ceAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAACYnElEQVR4nO29TWwc2Zbn96e+SCZVZIo9ht80RhhUaukdqwQvPBvjUTBgwDvyVW88CwNNLrww0DMmQbiBqge0QZCYXtgYL8gCZuNNS8ydAQOG8sGb8cKQxJ2XTAEjoKcNT0nBLDFJSpToBSuSETfvxzn3IzIy8/wAosSMjI+MzOL95TnnnjtzfX19DUEQBEEQhJpxZ9QXIAiCIAiCoEMkRRAEQRCEWiKSIgiCIAhCLRFJEQRBEAShloikCIIgCIJQS0RSBEEQBEGoJSIpgiAIgiDUEpEUQRAEQRBqiUiKIAiCIAi1RCRFEAI5Pj7Gs2fP8OjRIxweHla+fyidTgfr6+usfbIsw+bmJra3t7G9vY39/X3t87rd7mB7/twsyyJctSAI08C9UV+AIBTpdrtotVpjdY6VlRW8fPkSjx49Gsn+PmRZhu3tbQA3ksK5H91uF9999x3evHkz2G9/fx/r6+s4OjoqnePg4AB7e3ulfdfX1/Hy5ctIr0QQhElGIilCbTg+Psbx8fHYnmN5eXmk+3NoNps4ODjAwcEBVlZWWPtubm5idXW1JDZbW1tot9ule3t4eIgffvihtG+r1cLKygo6nU7YCxAEYSoQSRFqQxUDlwyO4XQ6HTx9+nTo8VarhefPnw9+Pzk5kfstCEIQIilCLTg+Ph6kH8b5HJNOt9s1bms2m6VIynfffTdUr5JlGY6Pj7G6upr0OgVBmAykJkUYOe12e1CjcHBwMPj33t4ems3m4HnHx8d4/vw5njx5gpOTEzx58gQbGxuD7Z1OB91uF8vLy3j//v2gQDNPRVDOoaNYzPrmzRs8e/YMa2tr1n06nQ729vbw+vVr/Pzzz4PB/ZdffkGWZdbzttvtwfW/evUKP//889Bzfa4pBq7alaLEbGxs4ODgANvb23j+/Dn29vZwdHSEg4MD6zFymczvHQDj/eDe55mZGaytreHp06eDxzc3NwfXKghCzbgWhJoA4Pro6Ei77eXLl9etVqv02MrKyvXBwcH19fX19cnJyfXa2trQPltbW+Rz6Dg6Oho6brPZ1B6j1WoNrqd4vtXV1esPHz6UjtlsNkuP5fuvra1dn5ycDB5bW1u73tjY8L4mCmtra9erq6vk56+srAxd0/X1zWttNpva4wNg3/tms3m9sbHhvB/5uV33+cOHD0P3bWtrS3vNgiDUA0n3CGNBPt21yM7OzmDmSLfbHUpFrK6u4smTJ8HnVgttV1dXybNTms0m1tfXS9/m19bW0Gq1jKmnYrTi6dOn2rqOkGsK5eeff8aLFy9KU4nb7TZWVlaGin/39/fRarXw8uVLtFotrK+vY3Nzk3SePCJGuR+U+/z+/ftSIe/x8TH29/dLM5IEQagXIilC7Tk+Pka328X3339fenxlZWUgJqurq+h2u3j06BE2NzfRbrcBoJQO8mFtbQ0nJycAbuspsizD+/fvycfQzdpZXV3Fixcvhh5XC1J1KaEY1xTCysoK3rx5g93dXRweHuLw8HAgEsWZQnktyt7eHlZXV3FycoKNjQ0cHh4a+6qoUO5Hjus+t1qtUi3M+vo6tra2pD5GEGqM1KQItScXkU6ng9evX5e2FesI3r59i93dXbTbbRweHqLZbOJPf/oTe4qtSrvdxu7uLlqtFjY3N501LBT+7M/+TNvUjHrsFNfEodVqlfqfADfCVIx6HBwcDGSq+Fiz2cTz58+xtbXlPE/o61Lvc7EOBcDQaxAEoV6IpAi15fDwEBsbG4OBb3V11SgceYO2vb097O3tDZqV/eVf/iXevHnjPIdt+/b2dqlx2dHRUXDU4pdffvEegFNdUwhZlqHb7Q4G/263a3x9Ozs7g0hXanT3udPp4PDwsPS5cH0OBEEYDZLuEWqDaVBbWVlBs9kciqIAt31Pjo+PSwNf3qxMrVPhisHm5ib29vZKEYKiDFDa2Ovkod1u4w9/+APrWmJeUwjb29t49uxZ6bHDw8NBDQhwE2kxtb9///59khQL5T5nWYb19XXs7e2VhFeN+AiCUA9EUoTa8P333+PVq1cAbr6JFweyo6OjQYQkJ8uyUrHo7u5u6XhZlg0NhrZzUMjPz1l/Ri3MzCVCl2pQj0s5j881qfubojBZluG7774rCWCWZSVJyaeG59OFc7a3t7VFstvb26XXrjtHcZvt9yKU+/yXf/mXaLVapVRTt9uV9YQEoabMXF9fX4/6IgQBwCBdkA+Aas3C8fExDg4O8OTJk0FEJA/RF3uL5NuyLMPGxkYpeqI7x8zMjPZ6rq+vcXx8jN3dXTx9+nTwzXt1dRXr6+uDepB8jZq8gHRtbW0wMD569Gjw7+XlZXS7XZycnJRqafLXpe6/vb2NdruNbreLtbU17OzsYGVlhXRNrVbL+roADBb7ywfz/F7t7OyU7uG3336Lvb29wb3OU2nF+1rcp0in08HR0ZH1ueo5uPeDep87nQ6ePXuGjY0NfPfdd8iyDCcnJ3jx4gU2NjakPkUQaohIiiAk5NGjR/j5558rabQ2zch9FoTJRNI9giAIgiDUEpEUQUiI1DpUg9xnQZhMRFIEIQGdTgfr6+sAbgp6qc3LBB5ynwVhspGaFEEQBEEQaolEUgRBEARBqCUiKYIgCIIg1JKxaov/9etX/P3f/z2++eYbYw8IQRAEQQBuegL9+uuv+PM//3PcuZPuO/nFxQU+ffoUfJwHDx5gbm4uwhVNDmMlKX//93+Px48fj/oyBEEQhDHi3bt3+Cf/5J8kOfbFxQW+nZ/HP0Q41u9+9zu8fftWRKXAWEnKN998AwD479/9G8wuNkZ8NYJQT87H639rQUjGZa+Pf/34nw/GjhR8+vQJ/wDg3f07WAw4Tg/A43/4B3z69EkkpcBY/TXLUzyziw3MTYCkLFyHhweFcM5mHoz6EqLyFfdHfQmCUCuqKA9YBLAYch6ZaKtlrCSlrohsjDch79+kCU7dOL8W4RoV8zOfR30JgiCSQqHOEtL4Wt9rq4r+ndGJguuzIRJzg8jG+OH7noncCDERSVGoWkhEMsIJuYepBUf3eZpEcamzhPS/Tt79dtG4M7q/K67PgkiMwGHqJSWllNRNQBpf6nU9Nvp3qxlYKO9RbJEpfubGUVhGISTTKBohhN6vlJKj+/yIuAgmplZSYspJFTIyToIRg9DXG1NybO9vqMCMg7CklpK6CUj/Sz2jQo271Q3klPckpsgUP2NjKyxLc8CdgMLZr9fAf+jHu54JYeokJYacxJaSuglI4yrN9fTvVTcYUe9pqMyon4UQack/m3WRlZhyUpWI1FUwYhDjtcUUHdN7GiovEyEsQjSmRlJC5CSGlKQWkVRiEZPY1xhDekzvi6+8xJCWUctKDDmJLSV1l4+zK96f0oV7V4muxA7lPoaKjPreh0jL+fV9ERUL+/v7aDabAIAsy7C1tRW8T5ZlePHiBY6OjvDy5Uvt/gBwcnICADg4OAh4BW6mQlJ8BCVETGIKyTjIx6ig3hsfmdG9hz7ikn+OfGWlSlEJkZNYUpJSRrgikZJU1xJDfmzvgY/AFD8bPsKSfy5FVsrksrCxsQEA6HQ62NzctEqDa5/j42O8fv0aWZbh/fv3Q/tvb29jb29v8Pvm5iaePXumlZlYzFxfj08HmV6vh6WlJfz16d+Rm7lxBcVXTkLEJKWIzF9dJjt2FZzfm0127NBIjG+0hSssXFHpezRz8xWUEDmJKSR1EpBxIFYkJyTq4iMsXFG57J3hb5fWcHp6isXFkH6wZvJx6fQfNbAYUJPS+3qNpf/QJ1/ro0eP8Pbt20FUBLhpWmcb0qn7tNtt7O7u4s2bN4PHsizD+vo6jo6OBvsfHx/ju+++w8nJCVqtFu2FMpno/7M5gsKVE18piSUk4y4fVDivkys0uveCIy7FzwBHWBpfP7FEJXVEhSsovmISKiUpReT8qt7ppCLz98IjCrZ7yREY9T3lSEv+OeLIiqR/buh2u8iyrCQbOZ1OB6urq1H2UXn9+jW63S5WVlYAYCAmWZaxrp/DxEpKKkHhykmIlKQWkYUIq3bG4uxB+CBsul8ceVHfL6q0cIWFmwZKJSqpBcVXTGIJyTjJBxXOa/IRGt29p4pL8f2mCgtXViZdVHq9Xun32dlZzM6W/4Z1u13tvs1m0ygMPvuoz/vw4UPpsU6nAwDJoijAhEoKVVBSyYmPmMQQkjpJBxfOtXOFJkRefKQl/6ykkJWYcASFIyc+YhIiJalFpP+petFpPIgzCNvuDUdg1PeHIi1cYeHISi1FZWkWuHvHf/8vX4H/0Mfjx49LD//444/46aefSIdYXl7W1pLE3idnd3cXBwcH2uhMLCZSUihQBYUqJ1wx8ZWSqkRk9nPcPwCX9+P9obfdA47AqO8BV1pcwsKVFZeoVF1Im0MVFI6c+EhJLBkZhXRw4V6jj9To7idVXIrvH0dYqLIyyo65o+bdu3elmhQ1imLDRzZ8BWV7exs//PDDoAg3FRMnKZQoCkVQYsuJj5TEEJLYsuGL73Vw5cZ0zyjyUnyPOMISS1a4tSohUKIoseWEKyYhUjJKEbn4fFf7+Nz9L8nO6Xq9VIlR7zlFWjjCQpUViqjUMpoSgcXFRWfhrCm9kmWZcZvPPiba7TaePHmSXFCACZQUFy5BochJKjHxlZK6iEgKXK+NKjHqvXVJC0dYOLISKipVRVMogpJCTrhiElNGTHJRt+P7yI7uPlHEhSst+XtNkZUYojKttFotNJtNdLvdIcEwFcD67KMjr0PJBSWfriyzewi4oihVCQpVTrhSElNGFi7qNzvobI4/3Vh3TyjiwpEWqrBQZIUSVUkdUXFFUWIJClVOOGISIiWpJaQqXK+DKjHqveRKi01YKLJCiaq4RGVSoykUdnZ20Ol0BrLQbrdLkY1ut4t2u11q1ubaJ8eUAjo+Psbx8THW1tYGhbimY8Riovqk2CQlVFBiyQlHTHylpI4CEgMficnhpI0oqSFKOsgVWbGJiktSbNEUV5+UUElxCQpFTqhi4iMlMWWkfzG673GNubhdabkRGGqKiJISckVWXFEVm6jYJKXSPilPHmExoHC29+Urlk4+sK51f39/EMF49epVqdHa4eEh9vb2Bp1hKfvkYvP8+XMcHx9ja2sLT58+xdraGrIsw7fffqudCZRSI0RSEC4oLjmhiglXSlLISKMCwekHyIYOrrxQhSWGrKQSFV9JCRGUquSEIyYhQjJKAYlFiMhwpIUiLKGykkJUJl1SpoHx/7/0N1IIShVywhGTECmpQj6oUK+FKjO6+2ITF/Wem6Sl+P6ZhCX/DJhkpXH1yZn+MYlKlYW0QFpBiSknXDFJKSNnAcdeiBApMb02iryo99EmLcX3xiQs+XvsSgOZRIVSp1JrlubCpyALQ0yMpPjgKyihckIVEx8pqZOMhGJ6LRR5Ue8dRVpsEZb8PbXJik1UgLirQFc5HTlEUFxykkJMQqQkRDpSn4sjNbp74BKX4j2mCIuvrPiKihTSTicTLymmKEoKQYkhJxwxCRWS+fP6CM35PKMrrOZ1u8SleF9NwlJ8f1zRFZ2s+EZVqoqm2FI9Pq3uQ6InFDmhiomPlFQpI7GwXTNFYNT7ZJOW/N6HykpsURGmj/H7PzUxJkFJKSdUMfGRkjqJiA3bdVIERr03NmnhCItNVnyjKlxRSY1Pmsc3euKSE4qYcKUkhpD0z6v9U9mY56WCdK/RJS7F+2gSFkp0xSYrtqiKj6iYoinTPMtn0pkISTHVo3CjKLEFJYaccMQklpAsJBSbM0bEJEf3ulziUrxvFGHxkRVXVCWWqFRdm5JTpaDElBMfKalaQly4rociMep9sEkLR1hsssKNqthERRCACZEUDlUISqicUMTEV0hSCkis81NERn39NmmhCAtFVrhRFZuoxCBlXUpMQQmRE4qYcKUkhZCcn9NrZubnwzvP6l6DS1yK94kiLD6y4oqqcESFG00RJpOJlRTW4oFMQfGNntjkJLaYjFpGQtBdu0tcqNKS32cfWXFFVTiiUpe0j08tio7YguKSE6qYhAgJRzxSHpcqNeprtUkLRVgossKNqsQSFWF6mFhJ0cFZyZgrKKnkhComIVLSOBuN0PQX6FEGrrgU75tOWFzRFZescNI/XFHREZryYa14zIyicAUltZxwxSSVjMTCdH0ueaFKi0tYbLLiiqrEEJWxYXEWuBcwBflKpiDrmCpJ0aGLosQSlNRywhWTUcmICdv1UASm+PopwuITXVm4uIwSVeGISlXRFE4UJbWghMoJVUxiCMnZWRqpWVjgpYHU18KRFpew+MhKDFHRXrcmmqJL+Ujx7GQykZKiS/Vwoig6YgmKTU5iiklMIbnneawrRqRERXf9NnGhCIuvrPhGVaiiUieoiwYCPEHxjZ7Y5IQiJj5SkkpCQs5LERiOtOT3LqasmKIqHFEZ+2iKEJ2xlxTXooI2qFEUjqD4RE9cckIRE18p8RWQmMemyoz6Gk3S4hIWiqxwoyrUVvs6UaFGU0Y1y0cXRYkhKKnkhCMmoxISLqbrtMlL8T6YhMUVXXHJCjWqIqIi+DL2kuJLlYKSSk44YpJSRkIxXZtLXoqv3yUsXFnhRlV0omLrpVJHdFGUqgUltZyESMmdioTmKyPtU3w9sYTFJCupRIWCFNBOL1MhKaGpHpWUghJLTIKl5ONF2P46Hs6xnq6+Bpu05PclhaxQoypUUaFGUyj4TkOONatncLyEgmKTkxRiUpWMcM/vkhf1dZqkJb9nNlnhRFVs6R+KqPhGU2Qq8nQwcZJCmXocEkWhCopP9MQmKC458ZKSFCLiez6CwBRfo0lYXNEVH1mpSlRURtmFFqBHUaiCUqWcUMUkhZA0Pmpe+8Pw3ii6a7WJiyvKYpOVWFGVEFEZOr5EU6aSiZOUWFQpKJXISdVCwkV3fRZx4QiLj6zoRAXQp39ipX58oykuKNOPOQWzpf0qFpQYcuIjJjrxSLk/VWqKr4UiLLFkJVRUKIxdbcriLHA/4HPyOVxkJ5GJlxRKqse1qjEQJiix5YQkJiFS8jFh/cpDxuyW4msIEBaXrFBFBdBHVaiiMnQOj9k+VRXPcmpRioQKio+cxBaTUCGJgU80hiIsIbKiExVAn/5xrbjsG00Rpo+JlxQV2wrHOWoUpUpBCZITrpiklBHuOV3yor42g7Tk94gjK6aoSqioqPgU0qZI+fjUo1DTPEPPSSgoLjmhiElMIZknHuvcM/WjXqtNWlzC4iMrtloVl6jELqQdHEPqUiaeqZMUFTWK4lrRGAgTlOhyQhWTUQgJB/X6qNLiKSvUqAq3TqWITzQlVcrHhk+qh9sLpQhVUHyjJy458RETqoDEOhZFZIqvgyIsPrISIioqlLSPGk1RUz6uuhRp6DZ5TL2kuHAtFgikE5RgOfEVk18T1a98w5jdQ5UWR0rIJCu2qAon/VPal5D2GYdpybZFBE1Q0zyhguIrJxwxiSkkvuiuwSYuFGFxyQpHVAB3nQqlPiVGNEWYbMZaUtRGburMHrUeRU31xIiihAhKEjnhiEkqGeGejyIvxdflEhaDrFCjKtT0j2/aZ9xQUz2+aZ4QQUkpJ7GkZOFX2rotZ9/4rdFSvM4QYTHJiimqwk3/lJ5DqE8RBBtjLSmpUaMotm6yOckEJYacVC0lVNTrcklL/lqZshIjquIjKq5oiivlM+qpyC7UKEpVghIiJz5iQpWQ0ONQJIYrLCZZiRFVKYqKT32KGk1xpXyE6WJqJcUVRfFJ84QIipecpBSTXuQalkVGdIEqLRRZiRBVsS1eCNDqU2ISc4aPWo+ipnpcURRKHUpsQalCTmIJiQ+6c9vEhSIsJlnxiaq4FjKk1KeEIP1SpoupkRTKrB4brjRPpYLikhOumMQWEs45KPKSvx4fWfGIqrhExdRHpSgqodGUcUWNolQlKDY5oYhJbClp9G6P11/0S+8UKV4fRVhsshIaVVFFxTQ92Vafwo2mjAWLc8CDgNThJ+mTomNiJSWkFb4rzWNbyXiwT4ig+EZPqHJShZRQUa/FJi3F16cTFpesEKMqvqISk1SzfELa4buiKLYFAwfPIQgKN71jEpQUclKUj9j7UGWGIiw2WfGJqviISlXINOTJZmIlxYZPwaz1eIqQJBGUEDkJlZJeQC3LIm+9ntK1UoSFIyuWqApFVFRc9SmuaEosfNfvcUFp3mZDjaLEFhRfOeGIiY+U+KI7l0tcXMLikhVqVMVUp1K6Vkd9CjeaUjq/1KVMLVMpKRx80jwqQYJSlZyEiIjPcSnyQhEWl6wQoyoUUaHUp3DgTEeuoniWM/XYFUWxrWacQxGUmNETipxUKSUU1OuxSUv++jiyYouquETFp5BWZvsIXCZGUmwLC9rqUXwKZm2oUZQkghJDTlJJCRX1/C5pyV+TTVa4UZUIohIzmlLnuhTKtGPr/koUhbJ6MUdQQuTEV0xiCQ2nZiU/Z4isUKMqvqLCwdbgzVaXIsWz08PESEoKuFGUkQuKS05GLSY2itdmExabrHCjKkRRUYlZn2KLpqTuPmvrNMtJ9biiKBRBUaMoMdI7MeUkZYTFJ81DKcxd+PUOO6oSQ1Qo05JNSHM3QWXqJMW2mCAnikKpQ1EJEpQq5eQsURHaAnHApQiLS1YiigqlPqWIK5pSJZQVkLlQ299TqVpQKMIx6rQPJ81ji65woypUUQnBN+UjdSnTyURKSsjMHuMxCTN6Ss9XhCSJoNjkhCMmqaSEch6XuOSvgysrpqhKJFEJiabESPnEXg3ZVo9iS/WERlEoKxhz0jshchJDTBq9Gev2/uK153HdaR6XrMQUlZjRFN+UT+1YuA88CBhS74uA6ZhISaFim9Vj6y7LTfPUUlCqEhMXxeuwCQtFVqhRFaKohFB1g7c64iMoahQlhqDElhOXiPjuSxEYSpqn0bvDiqqkEhUbUkArUJl4SaE2cbOlerhRFCchghIiJ6FickqMzix5DvYUYbHJSmRRiRlNsaV86rbooK0exZbqoczosVG1oFDlJERKOKjncUmLLXLCjapQRYWDb22K1KXQ2d/fR7PZBABkWYatra3gfSjbc3755Rfs7e35vwAC9ZpvVxMoa/QMnsuNoqQQlN6FXVDOPvEE5fRC/xO6P+cYrms2vd7epf4+6e4nYVkB9f0zrbmkwya3PrPIQtOYIY3ctMezSAk3imJrdZ+jE5SFX+9oBaXRu2OUENu22+fMDH5GBfUaXK9Vh+6e6e6vKorq+6S+j5RZWzpi1zlNA7ksbGxsYGNjAysrK9jc3Azax7V9fX0dzWYTW1tb2NrawpMnT7C9vR37pZWYub6+9kuSjoBer4elpSX89enfYW6xUVoFuTgFufjHvBhJsTVxKw4atlk9tlTPyATFBFVMOPIQG2rUxZYKMqWAdFEVXUGtGlFR0j7qbB+1iFbtnVKMpqgpn2I0pViXUoykqDUpxRk+xV4pxZqUYjO3Pm6PWyycVSWlOLunWJNSjKTYuswWJSW0FsUVRTEJig7ugH27PUxI5j7S9r946P8n1xVdsdWs6Lbp6lTUiIoumqIW0hbTPmrKpxhNUSMpxZRPsS6lGEkp1qQUC2eLU5CLHWfnZ24fv+yd4W+X1nB6eorFxcWh1xGDfFw63fweiwE1Kb1PV1g6eE2+1kePHuHt27eDqAcAzMzMwDaku/axbe92u3jy5Ak+fPhQirQ8evSo9FhspjaSQu0ya/s2TJnRYyVEUGzRE0rkxCe6kQLqNfhGVVQoERVFJkOiKT7YZqDFwjb92ITvt91QQdERU1C4EZO5jzPanyr2d10rN6pCiahQ3o8itmiKT0qwKM1FmS5+hosCnmJGW93odrvIskwrBp1Ox2sfynYApe35v1+/fs19CWSmVlKKUEPvtu6y7ChKqKCYoMqJL7ZUTqzjmrDJV6ioqNjWT1KwySq1nil0aYYQOJ1mczipntK5PARFHTQ5gmIftGly4isjXDjnoMgK9XEfUXGlfYrYPg9FSlG6wOaB40yv1yv9XF4O/w3JhUGl2WwiyzLtNtc+ru2tVgsAtMc37RsDkRQFaj1KcBRFJVRQXNGTWHUlvvv5nNuETVR094ciKo76FE40hbJUAhDe3TgFPuv12L4d+9Yo5FAWCQTMgmJ+Pl1ORgFVWGyyEioqQ/sxIirU952yKOXY8M3cTerZ9+e3VPTjx4+xtLQ0+Nnd3SVfwvLyMt6/f8+6bNc++fZWq4XV1dVSpMYUtYnJBH1C4kP9FhwcRYkhKCaoclBF2qd4DkotSv583XPz16yrVeldDNepmGb+FFFn/Dhm+xShruszysZuXHy+zcaMolDrUDiCQpWTEBqn+nP3l+jt74vk12OrZWn0ZrT1KqbpyLrH1Vk/phb6Oa4pySY4HWinkXfv3pVqUmZn6X8vuIJC2ae4/eXLl9je3sb79++xvLw8iK7k/03BxEkKtWiWC/Xb8RCUNI9KDEGpk5y4zusSltML83POPvmLiqkzLRFqJ9pJ6JliKpi1ERpFUUktKFw5MckI9/lUeXHJSv76VFkxTUc2CUwRVVR8pyWr05EFM4uLi87CWZMUFNMy3H2oxyxOOc5TP99//731ekOYiHSPbXFBHdRZPcb9LcKibdxmQ42iVCEodSmazaFci+05If1fXGkfRm1KEW+pHTN8e6NwoygpBYVcB3J6p/QTC+4xXdfLSf+oj1HSPkVsU8djS6pwS6vVQrPZ1NaCrK6ueu1DOebx8XHp8U6ng7W1tWQze4AJkZQU+KZ6SvikeVRSCAqX00u/H/Z5iLKiQ3c/qPUpDGwSGlqnVJTnKmb4xIaT6ilCSfMM7RNBULhyUgUcYfERFQqqqHBm+1CWOQDKcluMzEnxLJ2dnZ1STUi73cbGxsbg9263W2q8RtnHtX19fb20/eDgQJq5mSj2SEkN9VsxO4qiQh1AfQSFEzkJlY3Q47iuNbaoBERTqNORi9JbjNhRimepXZPrhO1bNKVxWxF10IwlKDZSREy4UM5vEy3da+cWGFOgRlOos3y0x/Eo6J50tra2kGUZ2u022u02Xr16hYODg8H2TqdT+p2yj2v7wcEBjo+PcXh4iO3tbRwcHCStRwHGuJnbn31z+4HnNnKjpHtMDdxsHWZLksKNolDTPFxB4YhJlSwRazRs9SqmbboaFbU+xdXojdHgrViXQm3sxm3qpmvoFtLMzdXIrfgtVu2PYmriVhyEioMTp2DWJ82TQlB8aZw6FhhcCmjk5qhdMdWq6ApqdbUo6mNqozdbkzdqczdTYzffpm6uhm6VNnP7l/8Mi7MBzdwur7D0r/5t0msdRyaucLZKkjb1qkpQqpYT9bwuWbEVzZq26Ypp1UJa12wfx0wfE9RZPnWE8m3V1mXWB26jsND1dqwpEnYhLD+lotuHKi759ZlkZe7jjFZUdDN/KEWzppWTdagzfaaSb2aBuYD/Jy6khkfH2KZ7YkCJolCxpnp8oigqsQUlNJUTC8p12NI/IcW/rrQPkdQdaFPi08hNhymKomJLDbiiKNRURUpBaZzODH5iwT2m7Vo5qZ/h59jvAbVnjY3i5ySG5AqTz9RJCrezpy3VY8RzRsgA12rGOSGCEkKSjrNEWaE+Tq1PsWGZLh5cfxQB7qy2UcApmOUSQ1CodSexxST0PD6iMnQMQlTKNtuHWkBLmeVjKp4VhKmQlBQzJby/PbuiKNQ0j4+g+ERPuCISKi6pRUWFM9uHKJ9FmS1Krql4tmp81u2JAadglhJFUfERFOcxK5ITn/NyRYVSSBsSTeEWRMdgVJ9loTrY8bZ8StPJyQkADFUP7+/vl1ZI3NraYm0fR1ipHi4xBYVK7P4p7E6zjnoVW52KC12TtyJqgze1NsUAtbGbjtnPn0vFs9MIN5VArU3xFZRRiImOxumMtWalcXqHVaNi6kzrfX2ezd2o9D/dLxXPCtMHS1K2t7dLc6I3Nzfx7NkzvHz5EsCtwOTzqjudDjY3Nwci49o+Edi+bftEUajEEJQqW+NTZYU6Cyg/tnpcU0faCNja5Puy8OlTaYZPneDO6rFhSxXEiqJULSiNU9rz+kvc4/7WSdYgKzZRIR1fKaJVf+cU0ApCbMjpnizLcHx8XFoBcXNzs7SE8+7ubqnxy+rqKg4PDwe/u7bHpBa9JaqKooQKyii6z5IXLDRcf0ghrSqDnALa0HqjMSOkPoDa2CtVFEW7b0RBaZyWf3z242C7NtProqZ9OFDfL1NdSki/FGH6YP3f/vr161LL3OLSzd1uF1mWadvj5iJj214XKP1Roszm8ImixK7v8DlmbFKIikpI2/wRMqqusyk6faasV+BEUazHIc+u4QuG61jU48USlaF9HbUp1Hb53PeZM8On9g3dHs7epIp9fwhp5WmELCnNZhMfPnzAysrK4LFcLlqtlrbff75fLjG27TouLy/R6/VKPykIKWIkz/LgTm+lDqzGiELAtN6qCZoVxIws5biiKUU8ImKm4tlRUWzkNmpCUj2UKIpPmoc2oyaenIQc30dUhp4XGE0pHSvC1GSAvnClMF0Eze7Z3d3FwcGBdXGh5eVl61LQtu27u7tYWloa/Dx+/DjkcktQ2pGzSZkK4AzkvjNkqGQX5h9fUk+b5kZTiFJZlFRKhM2nB49ghjrYxhCUqggVFR0+0RQbMXqmCAIFb0nZ3t7GDz/8UKox0WETFNf2nZ0dnJ6eDn7evXvnda0jwfbt25XqCY2ixN6HIyIh0uIrKr7RFF8msC5lVKF0zmAXEkUxHtM5zbdaQSme1/0c/6nVgFvwQtf0EYQYeH0K2+02njx5Upo+bFpkKMsytFot53Yds7OzWFxcLP0Iv+GT5uEO3KHREZ9jpJQLVf5CZlNFgJNmrEUhuAbqej0+uAbJ0CgKRVBGSezz+9TpFPGpS/H9HEhDNyGHLSl5HUoeQcnrTVqtFprNprb2ZHV11bl9ovFstz6g6tqRGHISckyf2UoxoimR61ImFW47c2oxJXUQNBE6CBcZtaDkuK4jdjTFN3pCqUuhTk8XhCKsT+Tx8TGOj4+xsrKCbreLbreLw8NDLC8vA7hJzxRn6rTb7VI6yLU9lOIKyDq4LfEH+xlm9kRpje6b6tERI4oSW058jx+rMd2YkKRGqob4Fll6D54eURRfQWlkM84fr+N6ikoMbPc9pC5FpiELVMiflCzL8Pvf/x5ZlmF7e7u0LU/7bG1tYX9/H+12GwDw6tWrUqM21/Y6wZ6RQa1T4LRhB+JECOoiKMXzND07xlaJ2n12ikkx88I2yMVK9Wj3jTyoc+Sj+Nx+k975tXHq0wRuuMmbaaVkIQIPZ4H5gNquu1IDpIP8lyefguyiWKeytrbG3j4RjCI1EBpdqEpQiudziQq3/T3l+WoHWlebfALFzrMh7fFDWLj+hLOZ+kwzrhpt0zJiyqO8D+O5npGR4v6xRMXVPj8WKbrPnl3cw8LcFW+fq3tYuFfep//1ARp36lm7Jfgj6lZgIqeHUqIoVQtKjPOmavVPjXQRImfkVbOF4HqUGFQpKMXjxDqW9viURRQj1aUIQgrk05gaTtEspR4ldhHtqASFSl0azgVSh4ZuXCZxhkWMVE8KqaAeM0ZBb8wC4ypI0QFZGB9EUkaJawosdYAObRs/SmJLUtL+KOMnGjbOrsajeHG46yyl+RrvTxu5LX3KqEdo+ihRAa1EVoRRIp++aaYuURTXdfi2/h9TfGeh1YVib4yUa/bkUCMDoYN4SkHhUJfp0SrFmVtVvO/CdDD1khKybo8wpozpgoN1htIDgzr9eJq/uSdJJXkUEFOhTEOO0dhPmF7GI94rxKcuUZQqcM36sc3wkWnIEw+pBX1NoigufGf5NHoz6C+Ofmpy/+IeGsyZPrVhYRZoBMywuzO9cm5j4u/KqJa718LtkaKi7ZkyxvUoRaZImiZyFhkTWaDOzLgIkSBUwcRLiiAIaahr19CU6Y26EFqX4qrjmeaUm1Av5JMoCIJgQSIbZUJ62sj6PQIXkRRBEARBEGqJSIowHoxbjY0gCIIQjEiKMB5w1vARBEEQJoJ6Vr4JgiAIwhhx1ZjF1YL/FOQrSO2TDomkCILgRWO+nv0s+ktxV+nlrFQ8KfQXzfcwZBXk+fkv3vsK04lEUsadpdnJaA/flHSOIFDpL4Xtf/Fw+sRrEtnf30ez2QQAZFmGra2t4H0ox9ze3saTJ08AAMvLy1hbW/N/EQ4mXlLO783Wp6Hb4mxYQ7elOXoBKee5QqX052ZHfQkj5/zhl9o0dOsv1Ws9nJDIjU+3WQC16DYLYHy7zY6A/f19AMDGxgYAoNPpYHNzEwcHB977uLZnWYbf//73+NOf/oRms4nj42N89913uL5O9/mZ+nTP2bQOGNMUuXAV3Zpa4gPSEl8AMJ0pHwrnDyV9Myp2d3cHMgEAq6urODw8DNrHtX17exs//PDDINKysrKCly9fhr4UK1MvKUINcAlT7Jk9AcVtgh5KrUGfOKDZ6iFC8I0yDPavQFQo5+CmemLX6HBZWBCRiU2320WWZQNZKNLpdLz2oRzz8PAQa2tr6Ha7g8dWV1e9XwcFkZRRYvsGD4QPzq79xz2asjSZUbCzB+MtUcVB6WsFA1SM+orQGo8YjHu0piihVbzvk0qv1yv9XF4Olwh0u13tvs1mE1mWabe59qFuPz4+RpZlaLVa2NzcNEpRLCa+JmXkfDN3s5IuhYUHwNkn/jnGuXg2tiil7Kfy0F+KzufrJ1QL965wdmX+EzB3/wsuPo++bqS/+LW0lkx/8RqNnn26Zn/pa5I1fPrN6yRt8mMISmikyHjcRJGtSaO/MIt7AVHa/m9TkB8/flx6/Mcff8RPP/1EOsby8jLev3/POm++jy6CUtyeS0qz2cTKygoAYG9vD99++y0+fPjAOicHkZRxI3ZBbHOu3isQV93EbbF+MjENnH3zNWhNGCr9pWs0TvWSQS2gjS0qHEGJkeoZt5k9jQefR30JlfLu3TssLi4Ofp+dpf9N4goKZR91+/fffz/4dx5l6XQ6ydI+IikF+nOzaFxEiEg8nAU+1iSyQZGaUYlKSBSFmupJJTkPb497taC/lrMaRk+EOORiESorsQQlJIqizuypOnKyIDN6SiwuLpYkRUer1dI+nqdhfPbx3d5sNo2pohhITUrVcL+pUwfZ0PqMqutTKOfjCgbl+Wo41lUXxKRvEJbUnM2Mdx1LKLrogKlg1DagsyMVzWuvVI3vfqMmpJFbTBbuDYtN445HqnxMabVaRjkwRTRc+1C2t1qtoe1ZlpWiK7ERSTHAriF46DnYqYMkJaeZYvAGqhOV0PNUVTAr048HpOhfYZu+qn6bH/493QDvU0SbS4dNPCjP8bkmk3SlTvXI9OPRsrOzUypabbfbpenD3W530PeEuo9r+97eHp4/f17avrq6OqhRScFESUr/rn2A9501UQzbF78pm8L8I8M2eHNEJZWscI4dI00zRosSXt6/P+pLqATqNGQfYkVTbrb7X0dRRkLEJMa1OI/tSPWkSv3UdUmFcWJrawtZlqHdbqPdbuPVq1elRm6dTmeosZtrH9f2tbU1PHnyBPv7+9jf38erV6+S90mZuU7ZKi4yvV4PS0tL+OvTv8OffXNbTtP4ehvma3y5+Xfj6vaxYsfZhU83j89+vi3GWijUoRRrUubPC/sV/t04u/33vcK/8bFQ16HWpBRn+KhdZ3tKPYhuho+urkT7mKMWhlN0G6tOhSs9NrkwiZhuH/UxXZSqGMlSU3HFSIo6s8dQk1KU2KLcFiNzxY6zeTPBoqQUZfr83s32/r3bx4oy3r9z8+9iuqeP22OdX9/8u/+1sP1L4Vy/ze45v7p9rP/p9t/F2T39i9v/585++3f//Pax8/Pb556dlWcF3Sn83ih0mlW7zhaLZ4szevS/D9eDzH0cfsw0y8dUQFt+jvMpSXEJSmgUhSspxXRPMZJimn5cnI5e7KVTlJRiTUoxYjd3/+b5xcLZ+Xs3/y6mexp3bx4rpnvmZ24eu+yd4W+X1nB6euqs8/AlH5fe/R8bWAyY3dM7+4TH/8Vh0msdRyYqkjI2uOpSQpqNxUyF5JEP38iKz75VRj9861F8U3sKdep2nP/x51IcbIqDUIwGXrFSPr7RlJvnkE6RBF9BSUWV9Si5oAjC1M7uubx/vxRNiQ5nhs/i3HA0RUU3S8c0c8fWN8V3CnMV9SouQQmJonAh1qPULuU3ZsRew+fi4bU2mmLCNiX59jnVR1SC0k2JoiiCnf7cA9wNmNHXFy/TIpGUmNi+YdepCHNprn71GjEFRYcrOhWhPwo31SMMw/22roumcGpTbrbRIipVRFWo5+GkeVIgRbNCVYikICzs7v1NWh0UKbN8OBEDStqnLqLiKyi+xwN4qZ6ATrN1gTM9M3XzLE7xbMxv96GicvO8NLLCOS43zUOJoriwyWOsYmhZAVnQIZKiUPymW/wGbJrhY6WqwW1cRYUS0eHOWNI9xq3xqUnUKy+anQRsa7mEfiunRlOAOKJy89w4ssI9jr3HS4DARZJBU9GsCU4jN9+6KWG8mVhJKc6GqA3cwY8aTbFBFZUqZYV6vhhTqnWoURROqidS0ey4wC1gjFE8q35r9x1AU4vKzfPLP5zncuXER1BiRFFUfKTSNLNHEFxMrKSMDM4g5kr5cPCZtqs7RkpZ4RzfR1BiRFFULNGwFEWzdV4BuRiOL00b9Rh0YvdLidnczSUE9n3NPyHXY99OFxTt/oxpx0P7Sm2KkJipkJTUYXPrYBWa8uFEU1yiwpWVGNLicxyfadTU47uiKJ6pHlPRLIVpaeQWM+Wji6Zw0z6u9EjVU3x1548tKCk79dreX1+mbXFBYZipnYIcSn9httTUjcw3c+XGbouz5eZuuunICw+GG7wZpx87phjbpicb96kyFeQY4DnXEhpFUfFI9biauI2Cxt3PpYZuKVlY+DLU2I2Cuipyf/HrUDM3KrZpyf2lr8Zmbzfbf1tIkND4LRb0It7wmVDcKApVJkP65HBSjHkjtzpwPj+LewFTkM8lKKVlKiIpRYrhdNM3WErxrJXQugVq2scnogLwoipV4bomWzSGmubhRlEqTvVwybvN1o1i/YENbqqAUptiihTYUh+UwT6PaqSMrnCOb7tmah1KaB8U6vvH7TQrCEWmTlJMhH6zZaV81MGQUrhpigr4igpQD1mhXIM1jeUpKFws4jmqlY9joFtN1gdqXQon5UPpmVKlqNw+N56wcI/lSlOFLCAYEkVJkeoRBEAkJQjr4JQimuIjKnWVFeo5uYJCJSCKYoNbj1InilM8i7UAxfC7qXjWhi30HxpNMT/mJyrsFEpBMmzCQX2e/Vz2a+PUoaTsJhtjSQRByBFJYeI9CPlEU2KIimtb6XmzaYWFc3yXYJm2pYiiKFBTPSk6zbpW+h53KNEU6gDrIyqAn6wMH8NfRrjXc/HwOlhQuFEUn1RPLGJF/4TxYGwlpbjqa2rOiWISXKdA7dfhKyrcGTbqD4eQ/Z01NYGCwo2iRE71FFOLrtWPgZr2/HFgG5zU1IA64MVK+9w8bhaVKmQlBMr5rZEhT0HhQk31hPRHkUZu04vM7ilwNjeLhYubmS/9uVk0LtyzYKyzfB7OAR8LM23URQfVmT46TIsP6mb8AITZPb8NuD6LDKZOCfnKCeAvKExsIjrOqZ4YNOav0D/X/0nxneVjQjfbxzQDqL94jUZPPzuHsiBhURRsM4FiQJUip2AFCEpIFIWa6jEVzZZSizL9WMCESEr/zgM0vtLXJjl78AALn26e77Ma8tn8LBbO9WJytTCLe5ypya4pyYCfqADpZCU2pLqZRIISEEWxQY2+jSONuSv0L27+dCzMXeHsQv9nZH7+C87P9WLydeEL7hSkpf/wCxqF1ZDV1ZHVKclAXFEBQFo9Obaw+ERquNGTm8dp5+Eu8GiLoqRI9dSZ89kHuBuQ1j3/PNq+PHVlIiSlSP/uAzS+3Azc/XsP0Li6+ff5vVnMX3n0NfmN8/lZzBvEJCiaoiOGqADuqEr+nJwqhYVcJ+N4XkgNCrNxmxpFoaZ6JmHl47n7X3DxOSwSEhpNiSEqAKLICuAnGCH4RE9uHjelwtzX71uLoiKt8AVfxrYmpQp8B5ehlID6bdxVRAvQC2kBe9MyViv6iJ1mYxzbFT3hCAolzRMQRaGmekbZxI2LT7idMxhxa1MAeiGtbQB2dV2l1KtUiet6+ovXUQSFm+ZR3z+fVI8guJi4SEooxboU6/MsKR8vdPUp3IgKYI+qALxoiUsmiseKKTU+0ROAJyjMNA8nikJN9dSxHf78vc84v+JdFyflw42mqGkfgBdRAeAVVQHKkQtqdCUW9HV3bPIST1C4UFM90sRNcCGRFNAHC9vgow5a7GgKwIuo+ERVgLiRkqqPZYqeAHEFhYktikKNxo1yYUGfKZ22wSVmNAWgD5g+aQ1bFKJIHs1IFWEpHp9yDtd1hwiKdr+AKAr18xCraHZ+RgpuJ4mplRTqoGAbZNizOWKKCmAXFcq6NalXPaaen3INttcTIig6AqIoNqipntQLYgJ+a55w1lQpon6rVgc0iqiomAZW3/oLqqwAw0LBkQvf/ajX2V/8akx/UQWFW4eivp+2KIpPqqc4/bgo1MXPcOMOfeKEMF5MVbqHWjxrS/lwCmhJM310hbTU1A9gTv8A7hRQjioJqQpofYTIR04AuqAEzuZRRTX2rJ5R90hpPPiM/id3pFFN+dimI1NwzfYBbgdYSuonfxzQp39un+NOA9lIEWmhyJM9WqTfRhEUHZwW+LYoiqR6BApTJSkpUGtTnKKizvYB4ogKEC4rOTaZ4MwW8oUSBeIWyFIERUNIFMUWhfOpRwntNtu48wn9r/GkpzgV2YWrNkWdkgzQRAUw16gApnoUuqzcPK/aehT1/O7nphMUbprHd9qxb5SuTvTnZjETUBjflynIWiZeUorTkG3Y+qVQG7uRCRUVIExWALqwqKRMD4XICRAuKMw0DyeKYkv1jLIeRYeteNY2FZkbTaGIigpHVABzVCXfBthl5eZ55cEjhbRwpOR2H76cAPEExYUaRaGmeqSJm1Bk4iXFRrGp29A2RsqHHU0BwkQFMEdVALesAHGEJRSKlOT4yAkQTVC4TEJvlNjYmrvluJq8AX6iAphlhCort8+3C4VJYnxEZPgY/ksEmOp4KIKiIySKQk31SDt8YSIlpdjQLdoxlWiKrTYFqFBUgDBZAfSykEJcOFKS42rMxomeACRB0RESRVGxpXqoRbP9O3GjLwv3rnB2pf9zYKtLUVM+rmiKz5Rkk6gAINepAHRZsT2HQgwZKR+PuqAiL3oC0AWFm+bhRFEmIdUjpGMiJcWGrXjWp0V+DqVvSrCoAGllpYiPUMSC0jGWGz0ByIISOptHjaL4NnCLUTQ7P/MZ59dx+7HE6D5bxKc+JYcbVQGoNSnlQT1EWnzgLPrnIydAPEHh4lswK6sfTydTOwU5x1YPoA4u6uCjfntWv13rBjdtGkH3Td5U1GmbQrs4ax+88/4qtj4ro4J6XbbX+M1cdEHREXNGzyjrUWzTkDlhdnXQUb81q9+qdWkB17Rk4GYA5fRROfvmq3WQNk3LtT23+BMLn2NTnmuLnvgKio6QKIqK1KMIKhMTSbEtMkgtngXCoimAuz4FCIyoAPaoCuCOrAyepwzSnEhLKFxJcrW158gJQBYUbprHFUWJkeoZBdSpyMb9HWkfHaZCWk76B7CngAD/NE9MUYl5Tm70BKALSuhsHlVobakemyj79PkRxpOJkZRUqAW03NoUIIKoAGllZfB8w0AfIi8hERvKeju2yFJiQQmFE0UJnX5MwVaXoqKmfFy1KToo9Sn5QBma/gHcsgLEq0uJBUeEYskJ4C8oIVGUcefy/n3cC1jq4lJqc7RMpaSodSm2WT6k4zlm+wCBogLEkRWALiyl/StMDVHEBIgmJwBNUHTEjKLUEZ91fIpQpiRTC2lNdSoAWFEVgCYrgF4QUosLNzrjamlva84WIig6XILiiqLYUj1SjzK9TKykhMzwUVM+rmiKjmBRAcyyohMVwC0rwLAE+EhLTKhSkuMjJ0CwoKTuLDt0DYyi2bMZ+nNDGrqpKR9XNEV7DEInWo6oAPaoCuCWFcAtLINzESSCMnsoBMpaO7HkBNALiqsOpUqmuSX+/v4+ms0mACDLMmxtbQXvY9ueZRlevHgBADg5OUG328XPP/88eH4KJlZSVDh1KTp80j5BogL4RVWA8kBuExbALAkp5IUrJDmu9XYiyQngLyjcKIqa6qlzPQoHStqHUp+SD4y69I9JVIDhqArglhVgeOCnSouOFLUqFDEB3G3tUwiKdr/AKIr0R3Gzv78PANjY2AAAdDodbG5u4uDgwHsf1/bt7W1sb2+j1WoBADY3N7G+vo6XL1/GfnkDZq6vr8emF2+v18PS0hL++vTvMLfYwMJ1WTrUwlk1kqJKijoVWU35qAW0anM3XTRFV5+im5qsikqOca0fnawMthGFwiUsdYK0EKBjYE8gKIA7zQOES4oaSSnWpKg9UtRISh/lc6lTkNVISv+Lcm1KXYqa8lELaNXpyLpoiioqumiKqZDW1EfF1p1WJytFbMKiI0RauFCFpIivnAC89I5vHUqopJgWFgSGIynFVZAve2f426U1nJ6eYnFxcei6YpCPS/9793/EAuXvloGzXy/wX7b+B/K1Pnr0CG/fvi1FMWZmZmAb0l37uLY/e/YMz549G0RX9vf3sbu7iw8fPjBeKY+piaTEgJL2CYmoAI6oCmCPrAB2YVH/B6qTtHD+5/aUE4BXfzIqQRm6vgqKZkOgpH2o9SnAsKxw0z+APbIClAd1irDYxMFHYHxERIWyGCBXToB6C4pwQ7fbRZZl2jRLp9PB6uoqe59Wq+U8phoxefXqlfZcMRlrSTmbeVCKptimIetwFdBSpiOHigowHFXJB1K2rAB0YQH0YpBaXHy/aRAWA+TKCRAmKNr9IrTDH/XKxy4o05FD6lO46R/AHFVxyQrAFxaVGMJBgSIlgLulva33CSe9Q6lDkZWO+fR6vdLvs7OzmJ0t/13pdrvafZvNJrIs025z7cM9ZrvdRpZlODo60u4XC5ak5EUzR0dHQ0bV6XRwcHCAZ8+eodVq4eXLl3j69CnW1tYGz/Ep8glBLZ71qUtxFdECYaIC2KMqgKesADxhyQkIV0aHIiaAl5wA9PQO4FeHArijKHVEnYpMmeVD6UJrqk8BhtM/pj4qtqgK4JYVgC4sg2vxEJcYUKUkJ7acADxBcdWhALwZPeNG//59IOD/7/5v9+bx48elx3/88Uf89NNPpGMsLy/j/fv3rPPm+5iKX9Vj5h6QZRnW19eTFs0CDEk5Pj7G69evkWWZ9iZkWYZOp4N2u41Wq4Xt7e0hQQF4RT6jgDIdOVRUgOE6FVNUBbCkgIDyAE0VFoAuLVVClRLAud4OV06AMEHRQZlyXIeC2cbdz0N1Kc59PKMppv4p3PQPoK9VcckKQBeWHJsshAgMV0J0UBYC9JETgJbeGRyHEDGhrNHjSvW4mrgV61HGlXfv3pVqUtQoig2uoFD2Ubc3m83BOH54eKitY4kJWVJWVlawsrKCdrttfI7tQnd3d/H27dvB76urq3j27FnlkqJGU2xr+eTo0j4hogL4R1UAS3EtVVgAsxBUIS8cGSnt547y+MgJwEvvUOpQtOcgfMuyFczGwmcasm80JVRUAHtUBbDLCkAXFoAmLUViiAYHipTkuFrax4ieALQ6FO3xIkRRJnH68eLiorNwNp9do5JlmXGbax/X9izLsLu7i52dncE4v7q6OghQFIMSMamkZN1VsJMSnz/yusFE961YNzDpBjDTYGf65t5fmLUOqFcLs+41Zh7O3f5weDib/od1PbTXYbsntvt5Nj+bRFBSRVFir35sglKsqBtkdN+WdQPWwtyVfnAzDITz81+Mg+fCwhdrRODrwpfBj4t8faDiz6jwuRbXa83vVdWC4hNFEcy0Wi00m01tHYmpkNW1j2t7t9vF/v7+UOoHQNKUT1RJefHiBdrtNg4PD7G9vT143KfIBwAuLy/R6/VKPynQDRYpREU38JkGSYAuKyxh8RGXqmBep+v1u+4fJ70DhAmKTxQlFpQQOGUtFN0gEiIqgGGQm79KIisAT1hydLIQQ2JiHLf4elxpHVdqx5TeMdWfhAgKJYois3rs7OzslL7kt9vtQRoGwEAqOPvYtq+srGBra6sUcXn+/DlWVlaSzvCJNrtnZWUFwG1I6fDwEOvr69bKX1eRz+7uLv74xz+yroMyw0dXQEtJ+5igpn4Ae/oH0PdUKQ60pv4qpHRQEZMAuNJEMQiQJMoqxa6W9jHkBAgTlDrUorjQreWjS/vo6lOoqR+An/4BzPUqQDmNYeqxAgynQ2xpIRtVRls4ckVpZW9rzMatPwkRFEoURRYVLLO1tYX9/f1BCcarV69K5RP5ZJbiBBXXPq7tOzs7JfHJsgx/+tOf0rzA32A3c2u329jd3cWbN2+sz8uyDI8ePcKHDx/w+vVrPHv2bKjJzKNHj7C3t1cyuSKXl5e4vLwdcHu9Hh4/fjxo5gZgqKEbMNzUDXA3dgOGm7sBww3egOEmb4PnGlrlm1ro2xYm1MlK6ZgUEfkNkrTUFIqU5PjKCZBOUACapOiiKLpUpauRGzDczA0YbugGuJu6AcON3YDh5m7AcIO3HN2MH9vUZNOihK5W+q4VlQG7sNjwlZdQOEKSQxETwE9OgOoERRdF0UmKrZEbUG0zt/a7fTQW572P0++dY+3xVtJrHUeiRVLa7XapcCbPUXW7Xa8iH0A/PzwW1GiKbraPqX+KLqIC2KMqgF5WbJEVgBZdydEN9HUUF46Q5FAWAvSRE6A6QakLulk+IdEUwBxRAfSyYouqAGZZsUVWBsdWBnCqtFBlgSozPvJhI4aYAPHkBKDVoIRSt6LZ83uzmAn4f/v8XjX9dsaNKJKSz5c+OTkZSEdea5IX4+QFOaqUpO5WF4NYogLooyoUWQFowgLQoiw2IUgpMD4iUoQiJYBdTIB4cgKEC4pvFGWUhIoKYE//APqoClVWAHd0xVdaTMSWDx1UIcmhrLPjIycAX1BiR1GE6YAtKboakmazOVRQc3h4iLW1tUFEJS/IyVM7asGOL2rXWUBfl6JbFZlTm2ISFWA4/ZMPZpyoCmCXFcAdXRmcw0NaioSKREyoUgK4xQTwkxMgnaDUDWo0xbi/h6gA5qgKYJcVgCYsAF9aioQKDBeujBShiAng7hg7CkERBBWypHS7XbTbbTx//hzHx8fY3t4udZRVC2p++eWXUtGsqyBnVISKChA3qgLQZSWHKy0AX1xSw5GRIhQxAfzlBIgjKMZzj7AFPqdfCjXtA9hFBdDXqdja6NtkBaAJC8CXltI1VBAl8YUqJQCtlb2PnABxBMW3FgWYjEZuwjBjvQpyDrV4FhguoAX0RbSAvpAW0BfTAuaCWsBcVAuYZaV0LQ4RKZ2L8VwXMWTGV0B0UKUEcK+14ysnAF9QTFGU0FQPtXAWoBXPDh4nFtEC+kJawFxMC+hFZbCfY80fk6wMHcdRbKuDIy6jgCMkOaFiAvjJCWCeakxN8wBhklJl4ez/+u//p+DC2f/6H/93UjirMNYLDNrgLDZoWtPHJ6IC6GXFlQLKcUVXALewcCMtNmIKBheOkORQFgFMISdAHEGpM6a0jy2iAuhlxRVVAcyyUhxQbcKiDs4UaXFJQGqJ8ZEQFYqU5ITICcCLnuRw0jxSiyJMrKSY0NWmAPFEBbCvnmyTFcCdCgKGB2KutBSJGXXxwUdEilCkBKCtteNqbe+T3uEKCqdDsi6KwsWU8jGt58MVFcC+zo9tYUKXrAB0YQH8pEUlhkTEhCMkOZR1dnzlBPATFE7jtrrN6hHSMnWS4oNNVAB9+scWVQHosgK400FcaSldR6AkVA1VSnJSyglQjaDUaVYPYBcVQJ/+8Y2qAOUBM5awAOYB3kdeUuMjIzkUKQFo6+3ElhOAl+apM+f3HgAB0dHze/US4LpQv/8bPdDN8AHMKR9uNAWwd6R1RVUAf1kBhgdarrTkcORl1HBlJIciJQBtQUDX+jsxBWWUcKMpgH3GT0hUJSemsORQa1k4QhAqNCHyYYIqJYNriLCC8bQLipCOiZAUH1KICmAuqqXKCmAXFoAvLTmugb8qifEVEB1UKQFoYgKkkRPALihVRFHmZz5ri2dtpBIVwF5Y64quAHRhGVxvgLgYryGBZHDgCglAkxKA1pDNtQaPj6BYz2dI9cjMnsll4iXFVkDrKyqAeeZPqKwAw4MpV1oAurgUiSkPKeAISU4sMQHcU4tjC0qV2KYjh4gKYJ79w5EVgC4sAE1aAPcgHyoxofhIiApVSnJSywlgFxSJoghFJl5SfMkHFZ+oCkCXFcAuLABfWgD7gO4jMFXhIyJFqFIC0MQECJMTwF9QbFGUGEWzHHxFBaDLChBHWAD9wEwVlyIxJKFKuEIC8FrYp5QTwC4oUjA7nUyMpJjqUgC/aMpge0BUBXDLCsATFsBPWor4igBVbkJFgwpHSHKoYgKEywlQ/whKEVdzN5eoAOZeKoBbVgBadAUYHlhd0gLYB3AfgRklPjJSJKaYALRpxakERVI9k814/Z8ZQCpRAXiyAtCFBfCTliJcgbFRlXyo+MhIkZhikhMSPQHcgpJqRo+rLiVEVID4sgK4hQXwk5bS+RiDfiqhCRUPEz6L/VHEBIgjJ4CkeAQzUyMpLvJBwyQrrvQPQJMVgC4sgH6ApYjL4FyEAT6myHAJFRAVjpAMriGSmOSkFpTUqZ5QUQFo6/1QZAUYHjB9pCWHKy/a66lpCihk5WGqlORQG7LFEJRxSfP0797HdUB09PxuPT9Xo2aiJMWW8gFoXWgpURWAJitAXGHJCRWXoWsYUYQkBB8ZyeGsrQPEkxNgdBGUIj6zfFTygSU0qgKUBzyXsAB+0pJDGchjiEwKQiREhSslAK9TbKzoiUtQJNUz+UyUpFCIISoATVYAf2HJCRGXIiESMwpCJESFKyUAb8XiGHJCpaqC2XxwcC1ASI2q5HCEBfCTlhyOvBSJKQN1wEdIAP4qxayusREERZgOJk5SXNEUgC4qgDn9M3geUVYAnrDkhIhLkViDPkV2YgoGBx8ZyeFICcBrykYVlCo7y1KjKZSVkilRlRyOsAB+0jK4Lsvg7CswdcRXQlS4UpITW04AmqBIFGU6mDhJoUJdgJArKwBfWHJCxCXHR2A4jEpAckJEpAhXSgB+t9jYclL1tOMciqgAPFkB+MIC6AdSjrjk+AzsVYlNLOmw4SskgGcTtohyIkwXEykplGgKcDs4xJQVYHgwo0gLECYuOdxBPLXUUIglHiZ8hCTHp409J7UzynV5OLUp1PQPUB6QfIQFoEsLYB9wfQTGRBXyEJMQESniIyUAf8YOR1AkijI9TKSkAHRRAehRFaA8AFGEBeBHWYqYBliuvJhILQhVESIiRXzX1uHWnHDlJFUUhVtES42qDJ7vISyAfmDkiEsOdaCOKTOpiSUfJnylBPCbSsyNnoigTBcTKykAX1QAWlRlsE+gsAz2ZYoLQB+UY8nMqIglHzpCF/vzLYati6Dk+IhKjq+wADxpAcyDp4+8qKQe+OtGiIio+PY48UntiKBMHxMtKQBPVAA/WQH8hGWwr2Ww9BGYIikH+XEh1srDITN0fNM6VdWh+E5L5qSBhvYNlJYcyoAbQ2TGhZgCohKj6Zpv3UndBeX8zgNcB6RvL+5InxQdU/F/LldUgPKgEiIsg2MwxWVwLMIAGyoy40wsAdEeO8K04ZCak6oLZfNBIERWAD9hAcwDoK+8FIk1cKeWnZSCwSF2B9jQgti6C4qQjqmQFMBPVHJChGVwDMOA5ysvpWMHDtSjlJyUkkG+hshr6IQWw45qFk9OaLM3dUDylZbB8QgDZgyRoVAXiQgldRv6WLN0RE6EqZEU4PaPv6+sAMMDkK+0DI7nGCBjSIzzGmogCilJuZBfzNk5o5aTIsXBIbg7rWHACpWX0jk8Bt2qxCYlo17zJtWUYZETIWeqJCUnhqzkmAapUHkZHN9jgK1CbEbBqFcNTjVduE5yoiOmsBSxDXAxBcZ4flnUjkRVvUtETAQdUykpOergEENacmwDWiyBMZ57xIP5uFJlz5K6i4kJdSCJKS1FfAbGKsRmEqhLwzSREoHCVEuKSkppKcIdDFNLzaQyykZpKuMqJS5MA00qebFRl8FXKCMyIoQgkmLBNLCkkhcToxxsg2tuaiQKVTCpMsKFOjCNQmaEOIh8lDmbeYAvAf//X8xMRlF2bERSPKAORFXLTAqmTTJ0iHikI+VAJwJ0g8iEMM6IpCQk5eA2CQIUG5EJoYgMzsKks7+/j2azCQDIsgxbW1vB+4Ruj41IypgiA7IgCML0sr+/DwDY2NgAAHQ6HWxubuLg4MB7n9DtKZi5vr6+Tnb0yPR6PSwtLeGvT/8Oc4uNUV+OIAiCUGM+9D7hb5fWcHp6isXFxSTniDUuXfT6+JulvyBf66NHj/D27dtBVAMAZmZmYBvSXfuEbk/BWEZSznEPXyH5ZkFQaUBSHIKQM4/JLEbtdrvIsqwkCzmdTgerq6vsfVqtVtB23TljMJaSIgiCIAiTSK/XK/0+OzuL2dnyQrHdble7b7PZRJZl2m2ufUK3p0IkRRCEWiNF4tUjNW98QiP8l78Nx48fPy49/uOPP+Knn34iHWN5eRnv379nnTffRxch4WxPhUjKiJFpkqNHZoGkR0RjvAh5v0Rwwnj37l2pJkWNotjwkQXXPqHbQxFJiYTIxvji+96J3NwyThIyqR2c69LTyPVZEImxs7i46CycbbVa2sezLDNuc+0Tuj0VIilExkFCpmXtkrq0P3d9JiZVYkYlJJMqF7GIcX+qEB3d50fEhUer1UKz2US32x0SBFMBK2Wf0O0puJPsyGPM+fX9oZ8q6H99EPQzLYTep6ru1ag+RylYuP40+ElB4+sn50/daHz5FOWnTozqfUj9+ZpEdnZ20Ol0Br+32+1B/xLgplA272tC3Sd0ewrGsk/KvzhtY3ZxIeqxUw8g4yAR/S/VDaKNu/WPMqSO2KSItMScghx7wKhaNOomAKOg6hXRY0diQiMs3N4jPsQaly57Z+yeLvv7+4OoxqtXr7C3tzfYdnh4iL29PZycnJD3ibE9NlMtKbHFpEoRqVIoxoEqpSeFvMQSlhiSEktOUkmJyEcaUghNLGnxlZVJl5RpYCprUmLJSQopEfnwg3PfQoVG976Hikv+mRxlHUuonMSSkqolpHE1ntLTvxf374/tvvsKjPqZ8JWWhetPta9bOb++j68BY8vlGKeDUzJVkhIqJ7GkpCoRObuajLd34V7crpGm+x8iL+pnw1dazq/vj0RUfAUlVExSCMm4SgcX7usMkRrd++QjLsXPC1dYxkFUhPhMxihGwFdQQsUktpBMinhw4LzmEKGJKS/558ZHVqqOqvgIiq+cxJCSUUnI/NVlJec5v0fvi8HBdt98BEZ9L7nSkn+GOLIiojJ9TMWI5yMovnISQ0qqFJHzq9GGGOfvxR2IXffOR2LU95QjLcXPEVdYqoiqcAXFR05CxCS2kFQlGiH4XmOI3JjuM0deiu8zR1i4siKiMl1MvKRwBcVHTnzFJLaMjFo4fPC55hCx0d1zrrgU328fYeHISkpR4QgKV058xCSGkIyDhKSC8tq5IqO+J1Rp8REWjqyIqEwPEy0pHEHhyomPmIRKyThKSApc94ErMSHi4iMs/a8PRt6QLoWgVCkmKWRk4VP9a1nOHoQNzKb7RpUXH2nJPxccWRFREXImWlKocASFIychUhJbSPqfxk9wGg/8Igime8eRl+J7xxUWiqxwoiqjKqZNISc+UhJDSMZBQChQXwdXZtR77CMtLmHhyApVVITJZ2IlhRpFoQoKVU58xCRUSMZRQChQXhdHZHT3mSIuXGHhykrVokKJosQWFI6c+EpJahGZ/ZxeFC/vx/l/2XQvqPLiIy35exxLViiiUqdoyvnXB/gSMNHi09f6N7gcBRMpKRRBGaWc+EpJChm5+Hw3+jE5zN3/ErS/6Z5Q5aX4XsQWFqqs1CH9U4QiKLHlhCsmsYSkCvHgwL0ertTo7htFXIrvj0tYYsqKRFSEiZQUFxRBiS0nXDEJFZJRywcV6nVyZUZ3/1zior5HLmnJ33uKrMQQlRjRFFcUJZagUOSEIyYhUlI3EYmJ7bVRBUa9ty5poQoLR1ZCRKVO0RQhPlMpKS4ogkKRE46Y+EpJVTLSv+B9VBpzcRuw2V4nVWCK95gSacnfvxiyQomq1C2iolK1nHDFJKaMLFzUa5bQ2Rx/erHuflDEpXjfqcISKiuhoiJMLhMnKa5UjyuK4hKUmHLCFZMYQsKVjVGchys4uvviEhf13tukhZoSospKiKiERFNCoiguQYklJxwxCZGSukmIC9f1UiVGvWcuaaEKSwxZcYmKDYmmTC4TJyk2QgQllpxwxMRXSqoSkVTYrp8qMOq940gLRVhcspJSVFKQUlBiyglXTFLISCPBMfsekZIiptfpkheOtFCEhSorPqIi0ZTpZLxHMwVbFCWloMSSE66UxJSRsxGIzYJHSkj3miniUry3VGEJkRVXVIVSp1IHQgTFJSexxSRUSFLIR4pzc4RGvSccaaEIi6+siKgIVCZKUnzxFRSXnMQWE18pGYWAUHBdF1ViuOJCFRaqrPhGVWyiYoumxO6b4r0Oj6egUOQklZiMUkRiYXoNFHnhSEv+HoTKSmxRqSv9L/dxFbAsyqeKFp4dN+o5ekXGFkVJISix5MRHSlILSf/cffzGfJyiWdNrochL8d6FCotLVihRlVFHVLwWETREUVJGTyhywhGTGFIyfz4asTmfZ7aw17xWl7gU76VJWCjRlYVPn7yiKj6iYoqmSF3KZDIVkmLCR1BCoycuOeGISaiQUISjquNyxEb3um3iwhWWEFmJKSpV1KaYoig+Le59oycxxcRHSkYlIS5s10UVGPV+2KQlv8e+0RXfqIpNVARhYiTFVI/is2Cgj6DY5CRW1MRHSlKJSGxs10kRmOK9CRWWEFnxFZVxwRRFSSEoFDHhSkkqIVlgHveMGSVRMb0Ol7wU75dJWDjRFZOsxBKVcUz7CHEZjxEsAaYoSpWCEltMYgnJ+Xm63ivz8/wOs7rXZRMX9Z6ZpCW//yGyYhIVQJ/+MYnKKKIp3CgKV1DqICe+UsKVjpTH5wiN+npt0sIRFpuscKMqMSIqUkA7PUylpMQSlFRyQhUTXylJKSGh56ZKjPraKdKSQlZMogKYoyoxIiqpFh1MLSghckIRE66UpJaRGJiukSIvxftBERYfWfGJqtgKaoeuTaIpU81ESwon1RNLUFLLCUdMRikjvuiumSIuxftiEhZXSogiKyZRAfjpn6HjJCqi9SmaLTJqQXHJCUdMYkhJ4yxBn5QFfvpH91ps4kIRllBZCRUVqU8RVCZaUnRQ1+QBqhMUl5xQxSRESs7OqhWahQV62ocrLhxh4cqKb1Rl6PyMaEqKlI8u1cMplo0lKKnlxEdKUkhI6DmpEqO+XpO0uISFIitViooumqJL+Yxyhk//6i4+MxaaVfl8NX5fKqtg6iRFhy6KEktQfOWEIiY+UlK1jJiwXQdFYIqvnSIsKWSFKiqctE/dmrzpoiipBcUmJ7HFZBRC4oPpOl3yUrwXLmHhyoopqsIVFUGwMRGSopvZo0v16KIo1FWMgXiCEiInHDGJLSR3GMf7yoiUqOiu2yYuFGEJlZVUojIp6ASlSjmhikmIlNyrQGiumGkf9fXYpCW/RylkRScqwHCdik5UQqIpwuTDkpQsy/DixQscHR3h5cuXQ9v39/fRbDYHz93a2mJtrwu6KApHUEYlJ75SwpGP2MekykzxtYUIC0VWqhQVajQlZsqHmuqhRlFSCkoMOeGKSRUy4nNuisAUX6tJWFzRFZesUEUF0EdVqKJCQWb5TD5kSTk+Psbr16+RZRnev38/tH1/fx8AsLGxAQDodDrY3NzEwcEBafsooKZ5UgpKqJxwxCSFjISiuyaXuKiv2SQt+b3jyoopqmJK/5hEZdKok6C45IQqJqMUEi66a7WJC0dYOLJiiqpw61RcSBGtAAAz19fX15wd2u02dnd38ebNm9Ljjx49wtu3bweREgCYmZlBfnjXdgq9Xg9LS0v4F6dtzC4uDB6npHuoqR6qpKQUlFhiEkNKGh/Dj9F/GD6AUyIurloWW+2KKbJimrasi6roREVXSKtL+6jRFF1dii6Sok5DbkBzbGV2DyWSEjuKohOU2HJCEZMgKfl44b8vh4dzXrtRIi2uGhZTKsg0G0gXVdGJik5SdPUpajRFJylqykeNpBQLZy96ffzN0l/g9PQUi4uLQ8eKQT4u/Vf//v/E/cWH3sf53PuI/+0f/+dJr3UciVKT0u12kWVZSUByOp0OWq2Wdfvq6mqMyxhAmXpchaD4RE9sgkKRE66YxJCQkHNQBab4ukzC4koJuSIrpqgKNf2ji6j41qfEKqClTD+mzOoZtaCEyAlbTKqSEe75HfJSfJ0mYcnvlS2yYoqqUNM/phoVStpn6PgSTZl6okmKjmaziSzLnNtNXF5e4vLy9n+8Xq8XdJ1cqhSUEDmhikkVQsJFd00uceEIC0dWTCkgW/rHV1SGrpcwJbmKtXwA+wKCObEFZaRyMmopoaJep0VaXMJikxVTCsiW/vEVFRXf2pQ6cH51H1eOtd1sfA7Yd5JJOrtneXkZ79+/10ZQittN7O7u4o9//GPwdVB6o6hRlNiCEltOKGISKiXzkaTmnJnuUa/bJi35ffCVldCoClVUhs49otk+plb4NlwrGwPVCopNTkhi4islHyuqX3lIHKSLr4MgLD6yQo2q+IqKz7RkdZaPFM9ONkklxSYglO07Ozv4q7/6q8HvvV4Pjx8/Dr4uzrTjnCoFJUROuGISS0R8z0ERmOJrMgmLK7pikhVbVCVEVFQ4jd4G+1TQM8VntWPbmjyD5yQQlCA54YhJVTLCOb9LXAjC4iMrtqiKr6ioqKKiRlO4KZ9RNnSrOz4zbENm7eYzggHg5OQE3W4XP//8szFwoSOKpLRaLe3jWZah1Wo5t5uYnZ3F7Gz60B8liqKSQlCqkJMqpISD7nps4sIRFpOsUKMqtvSPbaVlwC+aUodVktVUj08UJURQuNGTKHIyaimhoF6jTVocwuKSFWpUxVdUfGf7CGH4zLANnbW7vb2N7e3twTi/ubmJ9fV1bQsTE1Fn97x586YkHersHtt2CpTZPT6zelySQomiUAWFGz2xyQlFTEKkZOHXO977Fjn75qv3vpRIi6uGxZQK0smKaQaQKio6SaHM+FGjKWrKxzXLR61Jcc3ucc3scc3qUSVFjaJQ0jwjERSXnPiKya+J61e+8ZjZQ0kPWdJBpiJbnazo0j+6glpVVCgzftS0TzGaokZSqDN8qpzds/ru3wbP7uk8/mfJrtVnhm3orN1nz57h2bNng+jK/v4+dnd38eHDB/J1s0chU4pmZ2cHnU5n8Hu73R7YFWW7L7rpxza4gqKjCkG5c3bXKCiNj3etgjL/8e7gh8LCr3e0P7EwHZ9yDsprcd0P033U3ffz87va90l9P7XvOXH1ahs+qchUUKIoKjEFpXF2qRWUe2eXZkH5eGEWlI+Xtz8ufr3Q/6TG55yU12W5L6Z7qbv3uvdJ936q77trhWsXqjz7pCmnGdcMXJ99KMd8+fJlKf3z6tUr9mxe8l/EbreLdruN58+f4/j4GNvb23j69CnW1tYAAFtbW9jf30e73R5cTDGM5NpeV9QoCmUgogoKN3riipxwpKQuqNdii7oUX58uwpLfH11kxZQC4qR/VHzSPmptiquAVq1Lidp5ltAbpYgrikIZiDiCosMqJyaoUZMqJMQH9bps0Zb8tZqiK/l9UiIrphSQLv1DTf2ouNI+srbPDeos1hhlDz4zbGPP2m2328iyDEdHR6RrziFLSqvVwtbWlrXQprgtlxfO9qrxSfOoqN+oQwTFN7XjkpNQKWn0/PfvL/JSPcVrpQiLj6zoRAXQF9UWRUVXTKuKCqWIdlpQv02HCEoyOfERk16CGpZFxiBUvGaTsFBkxVCvEktUTC30qYzbdOTzz/fxmRCJN3H1+WZfdXLIjz/+iJ9++ink0oy4Ztja9qHO2s2LZ7Msw/r6OqtoFpiQBQaphIbSKWkelVBBqUpOQkTE57gUeaEIi4+s6EQF0EdVYohKaDQlFpzpx9xaFEqaRyWZoLjkhCMmKYSEcx6XvLiExSYrlqiKr6ioqKISUkRrm+UzSdOQ3717V6pJ0UVR8qyGi52dHaysrBi3cwWFso+6vdlsDko7Dg8PtXUsNiZaUij9UUy40jyUOpRUgmKTE6qYpJISKrrz28Qlf12+sqITFYCe/ildp2F6ciw4s3zOr+8PFc/6QGngFoIaRQkSlJRyUpWUUCleD1VYfGQlkqhQ0j42JOUDLC4uOgtn19bWWNkInxm2obN2syzD7u4udnZ2BkKyurqKLMvQ6XTI11+f4oSK8SmYtRFTUEyFoLYCUkohaqN3Z/DjS/EYpp8YxzbhKro13SOT8Onuv/o++RTSqlI7JL2Bn7dRwo2ijFxQXAWovcvbHy69C/8f9rmI12l7vaYCW8191d1/SjGt+n6HFNH6FG8Lw7RaLTSbTW0diamQ1bWPa3u328X+/v5Q6gcAK+UztZLCwRVFca1kDPAERYevnHDlIYaAxBAYyvNdsjJ0TIP8+YpKTHTrRuWERARNcGZHUJq3DY7rMYsjSFBss1qockIhlmjEOiZFWFyyMvTY8Awgqqio2BaJVDGtmu1CZvjwcM2wzaWCs49t+8rKCra2tkoRl+fPn2NlZYU1w4fdJ2WU6PqkUHuk2KYeuwpmuZKiDmghgmKTExscoRg11OJa2/NMaSBTnxVdUa2a+qH0UXH1T1GLaIu1KbaeKbZ+KbZeKbY+KcWaFNvMHls9SuwoSrCg6HCJCYVQAYnJIrF3ii0dZCqwNRXWKukfXS8VNfWj1qeoaR9b7xRbzxRqv5RiTcoo+qT8Z93/G/e+8e+TcvXrR/xfrf806bXu7+8PpOHVq1fY29sbbDs8PMTe3h5OTk7I+7i2Z1mGw8PDwe8nJyfY29tjRVJEUmCXlHETFIp01EFMTFCEJZaspBAVjqQAZVGxNXbzkRRbI7cUkhIjzZNMUChyUicxMUERlliyEllUXA3eiqJikhSgLCoiKZPPRBfOmrCF1inTjnModSgqIYISIic+YtLozbD30dFfpHtw8TpNMpI/R7d94dc7WlGZ/3h3SFRMBbVFUaEU0hYZxynJtqJZW6onuEFXTEEJiZ74yMlZ5FTDArFYtHitJmHJX69OVn69MBfWqqKiFNTqimk5+E5JHpepyBef7+IeY/xQuQrYd5Kp71fqQFLk8SlTjkvPV4QkhaC4ajd4tSQzpZ9YqMelHpvy2nSYalU4BbVFXPUplJqkHJsE2+S5dL6vo5n9YKsdCE3zJBEUV80GtQbk7NPwT2x8ju+6ftNr59SpKKjvk/o+uopoS8+1SC6nDkqYbCZWUqjYZlnYusty0zypBMUERU5SSQkFzrltr8W2zVdUXIs5unDN9KkzVcymoBReRhEUExQ5SSkkFDjSYns9JlEzFdWq95gw68clKqXnWsTEt4BWmGymQlKoTdxs33K5URQXIYLiO2jfbI8nJXMfZzD3MY7cxJAVHbFEJWY0pbQfcSpyaGSQ08gtxzfVQ6lFKTIURQkRFFv0xCUnscTk9EL/E0IMWdHhKSocfKMpggBMYU0KOaSeMIoSKig6KFETDhz5oDz34iGtLqV4naZalkbvjrYexVSroqtT0dWoqLjqU2zr+9jW9VE70I4DnFRPEXaaJ1RQdFCiJhx8hcO23xJxBk/xWk11LL0Lfb1K75JXp1LEUZ+iNnqzdaMNbZdfOtaXT0MrIguTxVREUqqkboJCjZrkUZGY0ZHQ49uunRtVoURUKPUpNmzRFJ+UT6oVkUP7S3CiKMGkFBRq1CRmRCTmOWzXboqqUCMqhIZvxuUKNPh8LoqRvGIa0lTo7RMtFOrPVEsKNdRuS/WENvkKERT7QO2Wk5RS4oJzbtvrSC0qrrSPDZ8UITXSF4vU7fBL5+JGUVIJCldORgFVWFyvxSQqlCnZ1NWjf4NUa+QgVl2KOv1eGF+mWlKK2HqjFLF9W+ZGUUIFxQRVTuoCRVhcURXq45S1jTiFtDE60dalRX7x2yp1dgUn1VOElOZRoQqKrTbDJSepIyY+hMoKtU7Foz7FFk2hFtBKXYpgY+pqUrjEiqJQUgmhgkKREw6N0zgO21+idZQFbq/RVMPS6M1oa1VM9Si6+hW1RoVSn1LE1juFuvjgONWlUL/d2kL67G/Z6uDIERQdFDnhEktkqPUo+flszz/7pK9VMdWpqFDqUyzoFiHMCV18sO6cX9zF3fv+Q+qXC+mTokMiKQxCoigqahQlpaCQ0yqnd0o/sfA5ru2auVEVSp8YbtqniE1Wi5I7TlORTVC/9QZFUShphliCwomapKpN4R7X9TxORMU0PblIomiKIFCYGEkpNrgytcO3tcJPiSvNk0pQuHJSFRxhcaWA9I+77x0l7WPDVpviOx153KAuJhhcq6AOmjEFxcUo0j/Uc9qeY0r/JBKVIj7vd1F+pV+KUGRiJCUEaj1KEdu359BmYLEExXqOBBETHyjX4Iqq6B93vy5VVFJFU6YB6uwNdhTF1u4+hysooQJQJdRrNREiKgyoM32KnxOK5Jpm+AjTw1h/5SsuLpgC6uwM27dqbhSFKiiu9I7xejylpHHKq2fpL/HWrcyvy1a/MvdxRlurYqpTGX6evr9KEU59CnddH5ViXUr/0/3BYoPnV/cHiw2eXd0bWhG57niH+H3TPDpsgmIjVExOHde35FmT4apHsW3X1anoalTUPipqfYpufR8Ctp4pguBirCWlSooh/JRRFBXOwoCU6An5vEwpoexPEReXrHBERScl6mOmBQkHz9csQsil2NgtZMHB/pf7pdWQY2Ka2VMMvdtWPDZhDf27ZvT4pnl8BIUrJy4Z4ezHEZfTC3vhrGk7VVQ4KA3eitgKaGPQuPpUWg1ZmFwk3RNI6iiK9riaKIorekIRlMbpzOAnBZzj266Xk/rxqU/RTQ3PoaZ8xqEuJVaPFO9UT5FYaZ6UgnJ6efsTk+JxKcd2pYBCokGuacmWaBenuZsgUKn/X9IxghNFIfXrIKZ5QtM7qaSEck5bdMUWVQmNqLCu1RJNCU35TBrkVA93PRh18IwhKBw5qZL8fK4Iiy2qottWcTSlSDHlU5yKXGyRv3BxibNI7fJHQf/yHu4ETEH+einDsY6pjKQUZ/aYimZLU0cjfCu2fTsHhoWkCkFJGTWhQrkG0+vgFtOWn5MmmlIVxdlsHEJb4rPO5fvNmpLmoRIiKCmiJhwo5+dGVCiFtJGiKSGzujgzfKr8TAvVM5WSEkIxpM9J9RTxSfPEFJQQOWmcun/8jhtXVIb2Z9T2xKIot5PWL4ULK9XjghpF8RWUUcuJSoio6Ahd5bliqN2Phclkav5apl4Txfbt2hVFUQkdUF2CwjuWz/nLv/eXqPvZU0CN0zvk1A8l7cMpoqUW0NpWRtYxLp1nTUWzXgsK2lI9PlGU2ILCxbcGhNppFnCngEypH1ehbY6a9nHN9ClCTPkIgg8SSUkAZzXd2FGUGIISGhUJPZ7tOjkRFUraxwY15cNZdNBGXdbwyeE21SrWo5BD/TGiKFSsqRFm9CRGkzefY9iukSNmodEU4vtW/BwUPx/RV8sWJpaJlpRUS92H4CqYHa5NCRcU+oyaeGISeg4fUSGdn1D7Y9yXGRETbkg664MaRXEJCoWU3WdZ7fkjiYoKtzbFAPf9pk5nB6Sh2zQy0ZLii6lollqPUoSb6vHFJijufdPLic85uaISI5oS2i4/FjHTk42v9G/NyfP/IakedRDlpHlMcASlCsjr93iIikrM2hTubC0DsiKyoFK/UMOICClmpM72cBXM+kZRQgVllDRO7TUrjdMZVvda09Tk0jEdtSlFuCskA+W6FOqqyFMJN9XjizG6QOxJMgooKx6fXvJqVCj1Ka7alCKeHWgnlf75Pdy5GzAFeQx6K42CenxtHBHF6cexSJkSoM5koTCK6IkJ34gKNe2TKprCrUuhLrNQNTFC6NFXu40VRRlHQeFcQ+gsJG40hZjyEYRYTLWkpMaW6vGJomiP4xFF8Zqxk82wf1jHjygqMWVu6HyRJHRcpyFTZvYUiyXJ9Ql1G/zqICg5vqLCrc2JiKlfCkdmZTVkARBJGRtipXm4guIjHL77htSoOI+tSB+ngLaquiITdSwA9yJS3YKWWFEU38LY7IL+40PKiIoaTXEV0Jpgvr8yw0egMHGS0v9iLzj0neZpKpr1rUdJRSxBCZGTkGP59WWpNpoSmxRpx5gkKWa01aP4pHqoxG7S5iMevsLiI0+poylV1RUJU8vESUpMuO3wfVMBPqke7jRcco+SiHLie2zbtVbVxr8us3wonF/Xq79K5cQaiDn7hERFQo4TYyp1KDVJzcVaIFOoN+Pzl7giYhU3cupRXJBbvwcO4KnkxOc87LQUZSFFR8rHB1PxbDHyJjioatCLMW03lpzojkuFPc2a8HxXyicxnF4p1uMwptsL48GEJLunixRRlKoEpXi+ftMxVdgwPZk6LZkyHbl0XOJqydQW+eNMbYoWfVI9KQZxII2c6I7fDGgxb5uWXHoesV1+jm0qcgUsfPqEswd+i2pWxcXFXczc9f9ycn0hX2x0SCSlAmypA99ZPUPHMc5+IexbsaCkOm9IJ1oXIcWznLRhVa3xU4XKjTN7qEWV3BWPY3RppZBaULjnqtPsoyKF9zlpp2FhapBICuo9HTR1AeioBKV4fltEJTSaMrSfZuFBIYzoPVKqhDLYVykoxXP6RlR00RRK5OTsE7DgEa0gNHVrnF2ivyCN30bN/v4+ms0mACDLMmxtbQXvQznm9vY2njx5AgBYXl7G2toa+ZrrOzpHJPUKyBxSrnA8/FzH9hELShW4Uj62FI9tVWRfzi7uYWFu/DvQBk0fTTkjJHaEYRSCQoWbsuHur3afrYiFi0uczYnQxGZ/fx8AsLGxAQDodDrY3NzEwcGB9z6u7VmW4fe//z3+9Kc/odls4vj4GN999x2ur+lfFCXdEwB1+nFqqprxkgqXLNWlM64wYnynHnOandWJOgtSQLHzWEfexpjd3d2BTADA6uoqDg8Pg/Zxbd/e3sYPP/wwiLSsrKzg5cuXrOsWSWFian8eoxOpbz2K17m8G7TZf6q8Hp2chdalxJjxIzCwDXauGSapJaPOkuBD3aVMSEa320WWZQNZKNLpdLz2oRzz8PAQa2tr6Ha7g8dWV1dZ1y5/kRMQq0NpSD1KiugDRUJCZUUQhAIuUQpZm4gLt6hZ8KLX65V+Li/D73u329U+3mw2kWWZ1z7U7cfHx8iyDK1WC5ubm0YpMjEVNSmhpOp5EeNbu0+qh72uTsY+BRoZ0G/y9zMez7FasiBEZdKiKEJyzs7uYgYBU5B/i9I/fvy49PiPP/6In376KeTSjCwvL+P9+/de++giKMXtuaQ0m02srKwAAPb29vDtt9/iw4cP5POJpCQmZufSlFNsU8AVFUrvFB/U4tkYM3yKvVLunN3F14Xx75uy8Mle8xGr4VYytJ1nx7QepUjITB9h7Hj37h0WFxcHv8/ODhcRt9ttPH/+3HmsnZ2dgSDo4AoKZR91+/fffz/4dx5l6XQ65LSPSIpgJTR1EzuiMnR8z6nIdaB/cQ8N5kyf/pf7aNytSaO12Eg6oXrUGT6+05A9mT+/xPm8zOQpsri4WJIUHWtra6xpvK1WS/t4nobx2cd3e7PZNKaKdIzXV3NBGCGUWiNTYbUgCMKoaLVaRjkwRTRc+1C2t1qtoe1ZlpWiKy6mVlLqvvJsCNYF+hj1KONaAMteNkBm9AjjzDilroSRsbOzUypabbfbpenD3W530PeEuo9r+97eXikt1W63sbq6ak1BqchfZyE54yo7wpQiRbPCBLK1tYUsy9But9Fut/Hq1atSI7dOpzPU2M21j2v72toanjx5gv39fezv7+PVq1fsPilSkyIIgiAIU0CxZb1a07KxsVGKglD2oWzXHZODSIogCEKR5pxEUwQ2d/p3wqYg9+9g/OcIxmdq0z1z9yf341C3fiIpZ/doz7cUd70dQRAEYTRMraRMK5w+JFXLxagwLTCocv7QLbYLE9AvRRgzQhYZFISaI5IiJCW16IxrjxQA7B4pACa3RwoALEq/jMpRBafCHimCQEEkJTFn38RLPYwijVFlNCVFt9lU9AtRlUnoNjsR6CIKSwbxGafowwR3m5VGboILkZQRQk0zWI/hEUngyoCPqPSbcQUnpM6m2BIfQHBL/Enl7IH9W3R/booGlAkWA0EYJ0RSCMzPj9835djFsxzpmJZaFkGYKiQdJ4wAmYKcgPOHX0gt1FX6i9do9G47wl48vMbcR/4qxynJBUTXoC1ETuqS6okR3RIYfDMH/GqY7rs4B/QsU4GX5tJ2W63DVGRXRMeUttKlucYpxTWGNM7uYuZrwBTk87uwNAufWiSSwqQ4e6NYi9AnzPyoE6FSkEdWij+pMEWFdKkumX48wfgWdY5rXYqknARBJKVqQr+p6wZhU12KK+VTm+jFCK+j6sjJgseMnjpS24LH2OJRZ1EIfa2u/Rct27/xP/dZXT87Qi2ZCkmZv2eftukzFVSIg0tQQmtrQopmY87MEgo8rNEgRRnoRyEqIec0RY5c+EaqIr+fZ9NUoC04mQpJqTPqN3l1EFUHWeNxxjCaEnLuqlM9lEZuMWg8GL8+KKRvxg+Jgy63OJMaTfAduHOqFBXKubhRlKpSW4X3+Wrh9p73F0Q8BD9EUiog9jdy7mBcR1GhnLPq9v6pUj+N+fpF6vr37N+aL+/f9ztuYTC6ijEwqSkHyrf9VAN4FaISeo5QGTMx4pk9runxwuQSdXZPvtTzs2fP0Gq18PLlSzx9+rS0MuL+/j6azSYAIMuy0gqKdWBh7gpnF+G3xXeGTwj9pWs0Tv1mA+XS0MjSzyYKFRRqFIUaheJiauRWLKoex2nrI8M2wycmS7PA6aVhG3GmUKoZPxw5iSFhIfUoNaZ/R2Rm0ogqKVmWodPpoN1uo9VqYXt7e0hQgNulmzudDjY3N3FwcBDzMqLRmL9C/5x+i/oPv6BBEJP+4lc0evQglm4qcn/pKxqn9GP0l4AGYX5bv3mdVFSCZxUFtMFXU2m2yInUo4wRqaciq+RCEUtWYglKSBSFU48SUDRrwqdRoCsaWDVzH+/izhf/L6ZfZQqyluh9Ut6+fTuIlKjs7u7i7du3g99XV1fx7NmzSiWl8eAz+p/4oez5+S84P7/5AC4sfMHZ2c2/vy58wZ2zsIiJKi1qvxTWsSzRFI6oAHGjKqyFDZlpniqjKCkIXZF7fiZtHcvZ3CwWLgwRCF8ezgIfDcdcnAV6lvMtPADOPtmPbxKXGNGUnBBZ8UnrxKorqfvUa0EoUFlNSrfbRZZlWoHpdDrRzlPXBdhCv5nrBl1TbYot2sARgH7zOkI/Fd4xuGke8nEds3psUZWqimYnHmrxrIpv6sFnMPbZpzmn/3Fti3ldIb1gXFEUWz1KwMye2k5jF2pF9EjKixcvsLy8jPfv3+Pk5AR7e3sAbiRFR7PZRJZl2m2Xl5e4vLz91tPr9WJfblJsdSnD0ZN40RQX1IjK4PmKZNgiLGEzdmzbTLOX/KIovkWysZr2caa9L9yrT+Ftf24WDUZU5WphFvfOCM8PrUvhREFs0RTusWzEKrRNKSg6fKWQMLNHeqQIXKJGUlZWVrC6uoq1tTVsbGzgyZMnWF9ft+6TC42O3d1dLC0tDX4eP34c83KDw+xVEyuacrPd/zry6Ijux/uYCWfycBcUpEa9uKsf17WR2/k9v4Gj+E24OPhEmW6qfnv3meUD8NrGq/vVIS0S+xpCj5egHsWE7wwzYbKIKimtVgutVmvw+x/+8Ae0221jpASAUVAAYGdnB6enp4Ofd+/exbzcJNi+aXNTPtTBNURUqp7m63MNqaMoMaYem2b21HH6cW2I3dSNPeuFcP5Rigrl3Jwoiu4xVfZUGUyU6hEEKlElpd1ul37P60+63W5JXopkWWbcNjs7i8XFxdJPKorhd8o3XtMaPhx8BktuQSiljmNUokI5L0dQtM9jRlFURlWP4uqSzKFW0zJtdSncb+m6aAp3ui1VVKqUFer5xnVNIgvSbVZQiSYpWZZhfX29VHuSR1DyCEuz2dTWpqyursa6jBIxcvnFb8I+vS9CBzndIMtJ+9xso4lKVbJCPRdXUGJEUWzRrnFbRNKHFE2zvJu6uVI+HGJM3U0tK5zjc6cb+0RRVGwSaahHocCZfuybmqyChY93sPBrwM9H6a2qI9pdaTab2NraKkVFDg8Psba2Noio7OzslGbytNvtQc+USYKT8omZeggVlZvnpREWznH7S9dRBCVlFMU3emajbi3xQ2oCyHUpoSkDajTF9jjAG/RzmYghLNxjLc3ar9WncZuJCF1mTUWzMrNHoBJ1ds/Ozs6gYRsA/PLLLzg6Ohr8vrW1hf39/UFa6NWrV7Vt5MbF1i8ltPusbqaPrsEbYG/ylg/81K60RaHgzAbS7U/fxzZ92j+CAoRFUWyEdJodl+LtYq+U4gyf8/lZzJ/f/PtsfhYL54SZPA/ngI+G2TPqLB+1Z8riHNBT9tX1TTH2SbHM3MkHf9vMH93xVEznDYVS7EslNIoi9ShCRUSVlDyaYqO4vdiNNjXz9z7j/CputXixqRuHs2++YuFX2/Tj4Y60sUTlZju/fX7qVJC7yDdN0TH5eB6pnmKqsFjnJKtuB6ITFR0+ogK4pyhTzhuTkAJfSppHByeK4tv/hois2zPdTGUSrBhWp3yT9alLCa1f0KV9qPUpgHtQt6VUqiZEUKhpHm4UpepUT1X0747mD761TkH9Vq5+a6cMmJy27gCt90iqxfo4VCEo3FofSxQlyqKSTEb1mRaqYSolxQR3ho+KbfBSBz1XbQoHm6jUVVby845CULjYhHNhRMLSuONoC18DrHUpod++dQMrpz7FtW3wnBHISn7OkF4uIdEcVQqJBbMq3CZuxZk90iNFyBFJCcQ2SHGjKZQiWlMaw1aXQUmVUKUhFOo5XIIVIighURQb47bycawF2kxN3VSiR1NiiQpHVlIKC+f4PvJFiaK4olYRalGKnxefhQWF6UIkxQPbYBQSTdERU1TIvUUKwhIqLT7HcslJyEye0KgKNdVjqkcJIeW6VMWpncUagOI32uI33SiDCzeaQq2TMIlKaFRl8NzZONLicxzf1+Gb5mH0rhlFqkeYfKKv3TOpNOav0D/n367+wy9oWGb2uIpozY/p1/YxFdMO9vtNAGyFtcP7VJMOckmUMa1lEBSKkLiiKLFTPcWUYrEeqlgnVWzkVqd1e3zoL8yiQVm7BxheGZmyno+piNa0UrJ1ds9vAzJ33Z4q0kGkaE+goLjSPGoUhZjqSUGsKGBM5n+9g7uf/L/3f7mUmIGOsb4rKZao96lL4QxWlFQCJUVx85g5ouKalsuJrKSGci0xBCV0yrEtijJuqZ6UeKd8dPimfQBzMa2zaLYm6/YAtGuxPcdXUJjY3tdY/VHq3MhNSMfERFIadz6h/9Vu18VpyI0Hn9H/dPPvuftfcPGZN5V4fv4Lzs/1+6g9U9Roito3RY2mAOERFcAdVQH8IisxoAqSNYUVICg6YkVRpnG9nmK/FBVrNEXtmaJGU3SovVMAv4gK4JiKXBjMY6yKzIHc3M3yPO6MpyIVRFGKKUNT0axMP47L/v7+oLlqlmXOliGUfSjbc3755Rfs7e2xrnmsIykmirn7mOFy2+ATOsuD+q3eFFEJiaoAt9GMlBEWzvFd1x0qKNw0j++047qufOwLtS6FFU1RBzxXES0QJ6IC8GQgZYSleHxqasdHUHzSPA6oURRhtOSysLGxgY2NDaysrGBzczNoH9f29fX1Qf+0ra0tPHnyBNvb26zrnrm+vq5HswwCvV4PS0tL+BenbcwuLgAAzq9vrbsYSel/Kdj41W3AqNjQLY+kAChFUvoX5QDTWeF3tS6lGE1RG7upHWjV2hRdF1o1oqJGTtyP2yMnrsiKDV4di5/oONNUlgJZX0EBeJKiCqma6qE2cePWpBTluzgFuZj2bKCw7/XtcxpfC//+Uvj3VeE4V7fRiYVP5ejD7OfCcS9un9co/FuNpKjdZ4vRlHtqZEXtQKuLpujqU9SICmBu9KaLqBQJjZZQ9w8RHde+HDkB9LLHjKKokkJthc+NpBTTPcWalGKflOJimmczD3DR6+Nvlv4Cp6enyRaozcel/+Rf/r+4O+t/ji+XPfw//+o/Tnatjx49wtu3bwdRDwCYmZmBTQFc+9i2d7tdPHnyBB8+fChFWh49elR6zMVERlJC8e0Iqg5e6rdvdeDzrU+xP26OqgC3EQruasrAcLTF9sOFVEdTA0FxQU31mASlLviE2Tn1BuxoChAnouKKqoRES9RoiOkn5Ng2aiYoNmTqcbV0u11kWaYVg+J6epx9KNsBlLbn/379+jX52kVSfoO6hkrsegPKtGSuqNxsc0uIr6zEgipMNvHqL35NKigqrihK6bkesluMolRB8RupT2EiJ+XDnvFB7cnBERXALStAPYpnqWJjez0hghIINdUjTdzK9Hq90s/lZcASDb+RC4NKs9lElmVe+7i254sN645v2lfHVEsK9RusbbBRByluNEWHSVRMg7FvVCWnKAuppYVzHtf1c+SNIig6YkVRfKJzdZ1+fGYRk6jRFIBWnwKYRcUlKy5iREE4cM7lkq1QQYkYRfGZ1WNK9ZD2nam+4Hb+1zto9Px/5n9L9T9+/BhLS0uDn93d3WTXvLy8jPfv30fdJ9/earWwurpaitSYojY2JmZ2DxXqQoONuauh2pTBNqVnim2mjw7XbB9AP+MH0M/wsT1+s+12oHfVrADmuhBOPUuI7LjEyh5B8hcUV5onVhRl1Csf9+8+KNWlULi8f79Ul1I6XmFVZBV1ZWR1ps/Vwmy5PsW2QnKOqX+KbtYPYF+QMB/kXfUqOdRVj32OQ8UlVzYxiyQoKqqg2KIooakeSj3KOPPu3btSTcrs7PD9arfbeP78ufNYOzs7WFlZMW7nCgpln+L2ly9fYnt7G+/fv8fy8vIgupL/l8JUSMrCvatS8awJ21TkhbmrUgGt9XzK6sjqlGQgnagA5qLam+dc//YcfgFtyihLaMdY0+O+gsIl9bTj0G6z/TsPSsWzFM4ePBgqoKVgm45MgjIt2UdUALesAHRhyakqLURavZgRPQFogqKB0+/GFkWxReWmlcXFRWfh7NraGtbW1sjHNElBMS3D3Yd6zOKU4zz18/3331MuG8CUp3tCUAclbtpHh27wPPvmKyv949p2+5xrcjooFZxrcL1eHSGCEhJFUbGleupYNEuBM7i4alO0Ax61kNZUTGsalF0pIOA2jRLSZyQW1Guxva5QQWGmeXyjKFKPko5Wq4Vms6mtBVldXfXah3LM4+Pj0uOdTgdra2vkmT3ABEsK9ZunbZBQB5fQnheU+hRTnYSpj4or9UFpYlaUhZTiwj1Hfv0+MlaloKjC6pvqqbpoVoct928bRNTBx1WDQBIVFdM3fE6dymAbQVaAsiRUIS3c87nkJLGguPDtMCtN3OKzs7NTqglpt9vY2NgY/N7tdkuN1yj7uLavr6+Xth8cHLCbuU1snxTA3CsFMPdLAeg9UwB73xRguHcK4O6fkkPpo1I6jiXNw3kOBTVdFFNsaGJFlxPAX1CAMEmx9UYBzP1RAFqPFIDWJwUw90oB/PqlAOaeKQCvb0qOs38KYO5Ia1vnR5cCKm2P0FGWmiYKlR2KXHHkBCAJCsCPolB7owC0/igAvUcKgEr7pHy/+f/h3gP/c1x96uH1wX+U9Fr39/cHqZhXr16VhOHw8BB7e3s4OTkh7+Pa3ul0cHx8jGaziZOTE2xubrLqUQCRlJvnWSQF4DV3A9yiokoKwBMVIFxWOM+rAurqxLbn1U1QAHoDN8C+sKCPpAC0hm6AWVKAsqjYJAWoUFSANLICxBGW2FDEBLBHj2okKIB96rFISpprHUcmqnDWtn6PrXi2uI4P+5yE1ZGphbTAsKzoCmqB2wHZVFgLuCVEHfCrlBaqlFCea1tSIKWguHBFUcYR2ywfH0irJJtm/JjW+bGtnpwP4jZZUYVgVNJCFRMgnpwAXoLCxVbTZEv11HH145xGbwb3Hvh39L765L/vJDNRkhILdZaPOh1ZnelDmZJMERVgeNYPcDvQmmTFFFUpDu4UATHJQIi8cGSEuy9XTgB/QdHBqUVxUXkTN8s05PN7s0PRFBNnc7OlaIo6HVmd6aNOSQYI05KB24FTlRWbqABhsjJ4rmaQjy0uHCEZ7OMQBVtztgBB0cGNosSgGEURJpeplRRqvxTv4xNFBRhO/+hEBfCLqgyOyRQW076poZzLR06AMEGJmeYBeLN6Qqcfh6JOReZGU6KJCqCPquQDboisADRhGew3om60LjHJSSgoMdM8gL0g26cLsjBZTLSkNO5+LtWlWJ+rpHxCoykATVQAWh+VHFdUZXAeorAAo61N4QiQa6VoTvQEiCcoseF0mi3Wo4TQv/egVJfCwRVN0e5DFBVAU6NiS/8AfrICDAsAR1pSEkNMAJacAH6CEorM6hFUJlpSVKhN3cjHq0BUAH1RrU1WAFp0ZXAejSjEFhffaIxLTAB+9ATwFxQdoVGUOkw9VlFTPq7Gbty0D0ATFYCZ/gHMKSCgPJDbhAUYjbRQhaSIr5wArPQORVBiRlGGzm+pR5mUbrPCMFMlKSpqyocbTdERW1SAOLIyOC9BWoBqUzwqFDEB4skJQBeUmHUoVePTddaETwFtdFEB/KIqORxhAWgCYS3IjRh1oCwGyJQTgC4oOnx7ohiPJ6keAVMuKT640j5AuKgA+mnKIbKSQ00JVQlVSgD3ooC29vaxBUVH6hk96vTjEHzW8LFBSfuEigpgSP8AdlkB4gqLiZgiokJdpdhDTgBaeifHVYcC8KMokuoRdIy9pMzPfC71SgnFFU3REVtUgHBZAXjCUrqmhPLCEZIcymrFseQEoAuKK82jw5XqsfVHSY1al+JK+VCiKbFFBXBEVQBzXxVKdAXQy0CIuPhAFZIcwno7saInMQQllDrO7Jk9m8H9gGnEnz/LFGQdYy8pKmqvFLV4Vq1LoczyoaR9QkUF0HenNaWAALusAMODu0tacnxEIjYUMQH85ASILyg6JqEvigtVVNRoCpBOVABNVAWgywrgFpYcmzT4CAxXQnQEiEkOR1AoNSgAbbqxK4pia+AmTBcTJykxoDR3iy0qgF9UBXDLSo6vtFQBVUoA94rFseQEoAsKJc0zDgWzKtwCWiCNqAD67rRBsgIMD/RUaSkSQzioUMQEiConQJigyErHQggiKfCLpgDhogIMt9B3RVUAt6wAbmEB9GKQWlw4MlLEJSaAe6XpqgRFeyxCXxTO1ONYqHUpPlORdWmf2KICRJAVwC4sgF4CfMQlBlQhGTzfLUu2xmxVCQo3iiJMN1MpKZSpyLpoSmxRAexRFcAuKwBNWACatAD+EpECipgA1cgJQBcUSpqHEkVJUY/iM8OHEk1JISrA8Fo/gL2VvlVWAJ6wDPZxDJq+EsOVEO0xaFGcWHICxBUUCmqqR61HUacf5+v2CJPBVEgKpambLppCXdOHIyrA8KKEpqgKYJcVgCYsgL+0VAVVSHJcYgLYW9tXKSixoigxZ/bYoERTKGkf4/GJogL4RVUAgqwAwwM8VVqGjlPhN3+ilADudva2acWhgqJDJygyo0dwMZGSYltoMMe3sZtptg9VVAB7VAXwkxWALiyAXQpSCgxXRoqEigkQR06AMEGpshblbOZBaSVkXyjr+VCjKYBZVIDhlZNdURXALSuAQ1gAvQD4iksMGEKSQ1lnx0dOAJ6gUOpQdIIiBbOCykRKii/UaApXVACQoyoATVYAurAAbmkpEiISMaFISY6vnADpBIWKLopS6dRjz34pIWkfwNw+3xZVAeyyAtCEBSBIC0AXBa7MeAiICYqYAHHlBOAJCiXNQ6lFqePU45xG7w7u3/Nv3/D5qh59q+rG1EiKLuWji6akEBXAHlUB+LIC0IUF0A/4HHFJDUdIcigrFfvICRBHUFJHUWKt26NDl/LRRVM4ogKAVKMCmKMqgF1WAJqwAJ7SYiKidLigSgng7hTrIycAbxaPpHmEEKZGUkKJJSrAcFQFoMkKQBMWwC0tgF0MYguMj4SoUKQEcK+3E0tOgHBBoUZRonaajdgeH6CLCmAupgUQXVYAurAA5sE/SF4C4MhIEUoLe9fCgDGiJwBdUHRRFEqqR9bsmXwmQlJ0XWd1dSkh0RSALyoAWFEVwC4rgDu6MjiHh7QUiSEVoVClBKAtBOgjJ0AcQak7upQPNZoChIsKEC4rAF1YALe05PjIgio2vsJBgSIlOb5yAqQTFCp1TvUI6ZgISUkBV1QARIuqAHRZyeFKSw5XXlLAkZEiFDEB3GvuVCEo1ChK3eCIig6bqADD6R/AnAIC7LIC0IUF8JcWCqmkhCMkOSFiAthn78QQFN8oijAdTJ2kUKMpAE9UAP+oCuCWFcAsLABfWgbnJwoCV2Z8xcMGVUqAMDEB7A3aYgiK8bwVFczqUj6cAlpqfQpwO2DFiqoAblkBeMIC2AUgpsBQ8JGRHJeU5FQlJ4AIiuDPREsKZSpyTkxRAcxRFcAuK0C4sAD6AZ0qLjpSSIcNjpDkUFYpTiEnAF9QOFGUqvqjmDD1TTGJCgCjrPhEVQC3rAB0YcmhiMvgOhKma0KhSgngFhPAT06AOIJivCZNqkdXjyKN3CaPiZYUE6bmbrFEBbCvnmyTFcAdXQGGB2SXtAD2gT9EYHzxEZEiFCkBaIsBulrb+9SfcAWFE0XhzOzh9EoxRVM4ogLYoyqmlZMpsgLQhAWwSwsQLi5Vw5GRIhQxAdxN2aoQlHGOosz3ZvDgrv9Kxp++yCrIOqZSUnywiQoAdlQFoMsKYBcWwE9aioQKQ2qoQpJDERPAX06AagQlZRQl1iwfH1EB9OkfwC4rAE1YAHqUpXRuwoCeSmR8JUSFKiUArVusj5wA8QRFCmanm4mRFN0MH8Cc8uFGUwD7QoSuqArglhWAJiwAX1oGx2fKS9VwZaRILDEB/OUEiJPiGSXcaApgFxXAnP4B/GUF8BOWHKq4DF1XJJmIAUdIckLFBHA3Z0stKDL1eHqo94iVmBSiAuijKoBbVgB3dGVwjUxpGRyfKAEpZCZEQHRQpQSgiQng7hzrEz0B7IIyiiiKi5iiAtjX+qHKChBHWAbXaxngfQUmFT4ykkNdWwdIJyeArG4s+DEVksIpoM1xiQqAYFkBaNEVgC8tAF1ctOePLBQhcGSkSCwxAfyjJ4CfoFSFT8onRFQAfVQFcMsK4CcsORRxyfGVApfchMgGFY6UALR1dkLkBLALSqwoihTNTiZTISk2bCsk54OLT1QFcMsKQIuuAHxpAdyDe4jExMZXRIpQpQSgr7UTIieAv6DYoig+7fB9Fhq0TUl2iQqAYFkB4ghLjmnw5siLiyokJIcrIzkUKckZhZwAUoci3FKfUSoCproUwB5NsYkKEBZVAXiyksOVFoAmLkViiMGo4AhJTiwxAWi9T+ocQSlii6a4RAWAV1QFcMsK4CcsAE1aclyDfUyJ4eArISocKQFoiwFSOsemEBSpRZk+JkpSXISKCmCPqgA0WQHswgLQUkJDxzcM3Fx5qQs+IlKEuzJxFXICuAVlFLUovqIChEVVAJqsAHRhAcwDM0decmLJQhVwhQSgScng+IFyAoz3NGMbjVPgQUAnh3v1nmA5MsZz9EpEPnj4RlWA8iCWQlhyqOIC8Ab7KoQmVD50cIUkh7rOTgw5AcIFJWTlY5+UT06IqAA8WQF4wgK4pWVwDssg7iMwo8BHRFRiiwkQLieuFI8tiiL1KJPLxEmKLeUD0IpoQ6Mqg2shRFeA4YHSJS2AeVDmyIv2WmqeAvKVkRzu4n/UlvYxBGXUuIpoKaICmNM/QHkgiyUsgH7QpYrL4Jweg3+o2MQQDhccIcnhLARImbWTUlAEOvv7+2g2mwCALMuwtbUVvE+WZXjx4gWOjo7w8uVL7f4AcHJyAgA4ODhgXfPESQqFGKIC8GUFcAsL4CctOZRBPFRkUhIqIUV8ViPmrLND7XtClZOUURQqFFEBECwrAC26AgwPmBRpAcyDM1debFQhGRR8RKQId3Vi6nRiSmpHBKUaclnY2NgAAHQ6HWxublqlwbXP8fExXr9+jSzL8P79+6H9t7e3sbe3N/h9c3MTz54908qMiZnr6+tr8rNHTK/Xw9LSEv7FaRuziwvW59qiKTnUackuWSniEhYVirSY4MjLpOMjJDkcMQGY6+5EEhSAJikNENJShJQPZVoydTFCl6wUoa6urEIVFw4xZSaEUAHRwZUSgLnWDrHuhDKLxyUptlTPRa+Pv1n6C5yenmJxcZF0TVzycem/eZLhwV3/c3z60sO/OWkmu9ZHjx7h7du3g6gIAMzMzMCmANR92u02dnd38ebNm8FjWZZhfX0dR0dHg/2Pj4/x3Xff4eTkBK1Wi3TdUxlJyaH2T6HUquQUBzCKsKgDJEdaXAPzJElMiISocKUE4HeLjSknQDVRlCKU/imUqApQHrCo0ZUcqrSYBt0QeUkhB1XjIyM53OZrnIJY6hRjiaLEodvtIsuykmzkdDodrK6uRtlH5fXr1+h2u1hZWQGAgZhkWUa+9omVFFdtSk4+SMSWFYAvLIB+APWNtvgM7FWITUzhsOEjI0V82thz6k5G1VGWWkBLbfRGlRWAJyyAv7TkuAbpFBGYKgmREBXfjrCjlJNJLJjt9Xql32dnZzE7G5ZW7Ha72sebzaZRGHz2UZ/34cOH0mOdTgcAyFEUYIIlBaCLCsDrSlsciHyEBeClhVyDbUjKSKUqgYhFqIgU8V1bh1sQy5WTFFEUjqgAtPQPR1YAvrAA5oHUN00UOsiHSk5MyeAQ0qLeZwoxpznbuArK/OkMZu/4r2R89+vNvo8fPy49/uOPP+Knn34KuTQjy8vL2lqS2Pvk7O7u4uDgQBudMTHRkgLwRQWg16oAfsIC6AdEbj1LDnWgjikzKYkpHiZCF/vzmanjEzmpOs1jgtM+vzgg+QgLwKtjAeyDrq/AUBiVZLiIuU6Ob18TbtdYSe3c8O7du1JNii6K0m638fz5c+exdnZ2BqkWHT6y4Sso29vb+OGHHwZFuFQmXlIAnqgAfrICDA9cHGkB7AOnr8AUqWLwrxMxVx0OmT7sm9ZJLSjcvimcqMpgHw9hAfQDI1dccrgDdkqpCaGKBfpCG635trPnCkrdoigxWVxcdBbOrq2tYW1tjXxMU3olyzLjNp99TLTbbTx58oQtKMCUSArAFxWgPLhwhQXQD2xcccmhDLgxRGYciCkfOmL1MwmpOakqguK1po+HrADDAxhHWgD7AOorMDomfbXemB1fQ9bY8Y2cTLKgpKLVaqHZbKLb7Q4JhqkA1mcfHXkdSi4o+XRlmd2jwUdUctQBx0daAPMA6CsvRVIM3jHEJ7VU+BK7uVqMQthRpHfyP/q+sgLwhQXQD3BccRkcizjwxpSZupG63XysRf9C0joiKP7s7Oyg0+kMZKHdbpciG91uF+12u9SszbVPjikFdHx8jOPjY6ytrQ0KcU3HMDGxfVJc+MqKCV9pYZ0jgshMC1V0d405OyeWnFD6pNjwbZs/dB0e0mI9nqe8CHxir0Aco9bEV06q7JPy3/6jU8ze8T/H5dce/pf/sJT0Wvf39wcRjFevXpUarR0eHmJvb2/QGZayTy42z58/x/HxMba2tvD06VOsra0hyzJ8++232plAHO2YWkkpEltYilQhLxTGUXDq0kY+5VTh2JGTUEnJiSUrObGlxXgekRkrsQVEe46IBbChkRORlPFnqtI9JooDRWxhcQ1wVUlMXQb8OlJ1v5K6zNixURwcYgiLaeCKLS+hg3DdJacKyaCScjbOOKZ1GqfArP8MZNwdm3BBtYikKOgGkJSRFp8Bsi7RmboxquZoNsZBSFzEFpYiroGuqghMTp0kYNRUPSV4HMVESI9ICgHTQJNSXmzUcTCeZiZBRKjoBpLY4lLEd6CsWm7qTB37j4iQCFQqlxSfpaLrCndwGpXUCHymSTxCMQ04KeXFRR0H5mlEZEQIpVJJ8VkqepIY1cA3znIksjC+cAeoUUqNQEOkQ6iaSiVld3cXb9++Hfy+urqKZ8+eTY2kjAoZ6IVxYNQD4LhI0qjvkyBUSWWSEmPZZ0EQhFTI4C8I9aNSSdFhW/b58vISl5e362icnp7ePN7rR78+QZgE7qCe3X0FYRRkvZvoWBXtwC7RAwJOc4levIuZIEY+u8e27PPu7i7++Mc/Dj3+rx//89SXJQiCIEwIv/76K5aWlpIc+8GDB/jd736H//kfHgcf63e/+x0e1HRl7VExckmxLfu8s7ODv/qrvxr8nmUZ/uk//af4d//u3yX7wE0yvV4Pjx8/HloKXHAj9y4MuX9hyP3z4/r6Gr/++iv+/M//PNk55ubm8PbtW3z6FF7T9ODBA8zNzUW4qsmhMknxWfZ5dnYWs7PDK5IuLS3J/6gBUJYCF/TIvQtD7l8Ycv/4VPGFdm5uTuQiEXeqOlFx2WcVKZoVBEEQBEGlMkkBbpd9zuEu2SwIgiAIwvRQqaRsbW0hyzK022202228evWK1SNldnYWP/74ozYFJLiR++eP3Lsw5P6FIfdPmFZmrquYmyUIgiAIgsCk0kiKIAiCIAgCFZEUQRAEQRBqiUiKIAiCIAi1ZOTN3Kjs7+8P1v3JsgxbW1ujvaAa0+l0cHBwgGfPnqHVauHly5d4+vQp1tbWBs+R+3lDlmV48eIFjo6O8PLly6Htrvs07ffRdv/kc0gjXx3+5OQEAIYmE8hnUJhqrseAvb296729vcHvL1++vN7Y2BjhFdWbo6Oj62azeQ3gutVqXR8cHJS2y/284c2bN9cHBwfXe3t71ysrK0PbXfdp2u+j6/7J59DN1tZW6feNjY3r1dXVwe/yGRSmnbGQlGazef3hw4fSY2PiVyPh6Oho6H4VkftZ5ujoSDvIuu6T3McbTPdPPod2Pnz4cL26ulq6B2/evLkGcH1ycnJ9fS2fQUGofU1Kt9tFlmWDcGaRYmM4gYbcTxqu+yT3MQy5fze8fv261IU7XyIkyzL5DAoCxqAmRddGHwCazSayLKv2YsaIFy9eDFaYPjk5wd7eHgC5n1Rc90nuIw35HJppNpv48OFD6bFcLlqtFl6/fm3cTz6DwrRQe0kxkf/hE4ZZWVkBcPut7PDwEOvr6zg6OjLuI/eTRn6fdN9ei9sF+Rz6sLu7i4ODA+PnC5DPoDBdjK2kyP+EZtRVpf/whz9gc3PT+u1K7icN132S+3iLfA55bG9v44cffnCuZyafQWGaqH1NivqHLifLMuO2aafdbpd+z79xdbtduZ9EXPdJ7qMb+RzSabfbePLkSWn6sHwGBWFMJKXZbGrzr6urqyO4onqTZRnW19dL9yv/5pr/YZP76cZ1n+Q+2pHPIZ28DiWPoOT1JvIZFIQxkBQA2NnZKVWrt9ttZ0h0Wmk2m9ja2ip9kzo8PMTa2trgm6zczzKm8LjrPsl9vEF3/+RzSOP4+BjHx8dYWVlBt9tFt9vF4eEhlpeXAchnUBDGZhXk/f39wR+8V69eDWYJCMNkWYbDw8PB77/88svQ/ZL7eZN2aLfbeP78OY6Pj7G1taXtiGq7T9N8H133Tz6HdrIsw7fffqut0Sn+WZbPoDDNjI2kCIIgCIIwXYxFukcQBEEQhOlDJEUQBEEQhFoikiIIgiAIQi0RSREEQRAEoZaIpAiCIAiCUEtEUgRBEARBqCUiKYIgCIIg1BKRFEEQBEEQaolIiiAIgiAItUQkRRAEQRCEWiKSIgiCIAhCLRFJEQRBEAShlvz/OHsxc5WxRuMAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "idx = 4\n",
    "plt.title(str(file_test[idx]))\n",
    "plt.contourf(solutions[idx].detach().cpu().numpy(), levels=50, cmap='rainbow')\n",
    "plt.colorbar()\n",
    "plt.show()\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ed2539b6-2cac-4511-ad92-7f76f35fb9be",
   "metadata": {},
   "source": [
    "## Evaluate"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "0da65b40-450e-484e-941c-8605dd0271b4",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_67446/718670643.py:17: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  phase1_model.load_state_dict(torch.load('../pre-trained/phase1_weights.pth'))\n"
     ]
    }
   ],
   "source": [
    "torch.manual_seed(3)\n",
    "# ------------ Inputs -------------------------------\n",
    "X = X_test.to(device)\n",
    "Y = Y_test.to(device)\n",
    "solution_shape = X.shape\n",
    "# --\n",
    "x_flat = X.reshape(-1, 1)\n",
    "y_flat = Y.reshape(-1, 1)\n",
    "# --\n",
    "inputs = [x_flat.to(device), y_flat.to(device)]\n",
    "parameters = parameter_test.to(device)[:8] # choose 30 items withing this range\n",
    "source_function = get_source_function(\"desai_song\")\n",
    "# ---------- Model Init -----------------------------\n",
    "hidden_dim = 64\n",
    "rank = 48\n",
    "phase1_model = LR_PINN(hidden_dim=hidden_dim, rank=rank, phase='phase1').to(device)\n",
    "phase1_model.load_state_dict(torch.load('../pre-trained/phase1_weights.pth'))\n",
    "# ---------- Optimization Parameters ----------------\n",
    "lr = 1e-3\n",
    "epochs = 100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "42d9cdcb-d630-42aa-8275-bb1f92cb2c09",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Parameter Name                           Shape                          # of Parameters     \n",
      "------------------------------------------------------------------------------------------\n",
      "alpha_0                                  (48,)                          48                  \n",
      "alpha_1                                  (48,)                          48                  \n",
      "alpha_2                                  (48,)                          48                  \n",
      "start_layer.weight                       (64, 2)                        128                 \n",
      "start_layer.bias                         (64,)                          64                  \n",
      "end_layer.weight                         (1, 64)                        64                  \n",
      "end_layer.bias                           (1,)                           1                   \n",
      "------------------------------------------------------------------------------------------\n",
      "Total Trainable Parameters: 401\n",
      "[Inner Epoch] [100/100], Loss: 0.4499\n",
      "[INFO] target not reached\n",
      "[INFO] time per parameter:  1.4082012176513672\n",
      "[INFO] rmse:  0.4418605864048004\n",
      "[INFO] rl2:  25.34268718989934\n",
      "Parameter Name                           Shape                          # of Parameters     \n",
      "------------------------------------------------------------------------------------------\n",
      "alpha_0                                  (48,)                          48                  \n",
      "alpha_1                                  (48,)                          48                  \n",
      "alpha_2                                  (48,)                          48                  \n",
      "start_layer.weight                       (64, 2)                        128                 \n",
      "start_layer.bias                         (64,)                          64                  \n",
      "end_layer.weight                         (1, 64)                        64                  \n",
      "end_layer.bias                           (1,)                           1                   \n",
      "------------------------------------------------------------------------------------------\n",
      "Total Trainable Parameters: 401\n",
      "[Inner Epoch] [100/100], Loss: 2.1923\n",
      "[INFO] target not reached\n",
      "[INFO] time per parameter:  1.2839345932006836\n",
      "[INFO] rmse:  0.47299858927726746\n",
      "[INFO] rl2:  33.312092040586926\n",
      "Parameter Name                           Shape                          # of Parameters     \n",
      "------------------------------------------------------------------------------------------\n",
      "alpha_0                                  (48,)                          48                  \n",
      "alpha_1                                  (48,)                          48                  \n",
      "alpha_2                                  (48,)                          48                  \n",
      "start_layer.weight                       (64, 2)                        128                 \n",
      "start_layer.bias                         (64,)                          64                  \n",
      "end_layer.weight                         (1, 64)                        64                  \n",
      "end_layer.bias                           (1,)                           1                   \n",
      "------------------------------------------------------------------------------------------\n",
      "Total Trainable Parameters: 401\n",
      "[Inner Epoch] [100/100], Loss: 0.7614\n",
      "[INFO] target not reached\n",
      "[INFO] time per parameter:  1.3147428035736084\n",
      "[INFO] rmse:  0.2993708550930023\n",
      "[INFO] rl2:  34.819952964519736\n",
      "Parameter Name                           Shape                          # of Parameters     \n",
      "------------------------------------------------------------------------------------------\n",
      "alpha_0                                  (48,)                          48                  \n",
      "alpha_1                                  (48,)                          48                  \n",
      "alpha_2                                  (48,)                          48                  \n",
      "start_layer.weight                       (64, 2)                        128                 \n",
      "start_layer.bias                         (64,)                          64                  \n",
      "end_layer.weight                         (1, 64)                        64                  \n",
      "end_layer.bias                           (1,)                           1                   \n",
      "------------------------------------------------------------------------------------------\n",
      "Total Trainable Parameters: 401\n",
      "[INFO] target reached, epochs: 0, time: 0.015042781829833984\n",
      "[Inner Epoch] [100/100], Loss: 0.0104\n",
      "[INFO] time per parameter:  1.717606782913208\n",
      "[INFO] rmse:  0.15207548439502716\n",
      "[INFO] rl2:  23.101299639752742\n",
      "Parameter Name                           Shape                          # of Parameters     \n",
      "------------------------------------------------------------------------------------------\n",
      "alpha_0                                  (48,)                          48                  \n",
      "alpha_1                                  (48,)                          48                  \n",
      "alpha_2                                  (48,)                          48                  \n",
      "start_layer.weight                       (64, 2)                        128                 \n",
      "start_layer.bias                         (64,)                          64                  \n",
      "end_layer.weight                         (1, 64)                        64                  \n",
      "end_layer.bias                           (1,)                           1                   \n",
      "------------------------------------------------------------------------------------------\n",
      "Total Trainable Parameters: 401\n",
      "[Inner Epoch] [100/100], Loss: 0.4439\n",
      "[INFO] target not reached\n",
      "[INFO] time per parameter:  1.721226453781128\n",
      "[INFO] rmse:  0.13313406705856323\n",
      "[INFO] rl2:  21.33091136844658\n",
      "Parameter Name                           Shape                          # of Parameters     \n",
      "------------------------------------------------------------------------------------------\n",
      "alpha_0                                  (48,)                          48                  \n",
      "alpha_1                                  (48,)                          48                  \n",
      "alpha_2                                  (48,)                          48                  \n",
      "start_layer.weight                       (64, 2)                        128                 \n",
      "start_layer.bias                         (64,)                          64                  \n",
      "end_layer.weight                         (1, 64)                        64                  \n",
      "end_layer.bias                           (1,)                           1                   \n",
      "------------------------------------------------------------------------------------------\n",
      "Total Trainable Parameters: 401\n",
      "[Inner Epoch] [100/100], Loss: 0.4842\n",
      "[INFO] target not reached\n",
      "[INFO] time per parameter:  1.8922693729400635\n",
      "[INFO] rmse:  0.1877232789993286\n",
      "[INFO] rl2:  39.434253198864866\n",
      "Parameter Name                           Shape                          # of Parameters     \n",
      "------------------------------------------------------------------------------------------\n",
      "alpha_0                                  (48,)                          48                  \n",
      "alpha_1                                  (48,)                          48                  \n",
      "alpha_2                                  (48,)                          48                  \n",
      "start_layer.weight                       (64, 2)                        128                 \n",
      "start_layer.bias                         (64,)                          64                  \n",
      "end_layer.weight                         (1, 64)                        64                  \n",
      "end_layer.bias                           (1,)                           1                   \n",
      "------------------------------------------------------------------------------------------\n",
      "Total Trainable Parameters: 401\n",
      "[INFO] target reached, epochs: 0, time: 0.026749372482299805\n",
      "[Inner Epoch] [100/100], Loss: 0.0152\n",
      "[INFO] time per parameter:  2.4067301750183105\n",
      "[INFO] rmse:  0.0776248425245285\n",
      "[INFO] rl2:  24.180565633405823\n",
      "Parameter Name                           Shape                          # of Parameters     \n",
      "------------------------------------------------------------------------------------------\n",
      "alpha_0                                  (48,)                          48                  \n",
      "alpha_1                                  (48,)                          48                  \n",
      "alpha_2                                  (48,)                          48                  \n",
      "start_layer.weight                       (64, 2)                        128                 \n",
      "start_layer.bias                         (64,)                          64                  \n",
      "end_layer.weight                         (1, 64)                        64                  \n",
      "end_layer.bias                           (1,)                           1                   \n",
      "------------------------------------------------------------------------------------------\n",
      "Total Trainable Parameters: 401\n",
      "[Inner Epoch] [100/100], Loss: 0.6078\n",
      "[INFO] target not reached\n",
      "[INFO] time per parameter:  2.572313070297241\n",
      "[INFO] rmse:  0.12484820187091827\n",
      "[INFO] rl2:  44.046146011951855\n",
      "Parameter Name                           Shape                          # of Parameters     \n",
      "------------------------------------------------------------------------------------------\n",
      "alpha_0                                  (48,)                          48                  \n",
      "alpha_1                                  (48,)                          48                  \n",
      "alpha_2                                  (48,)                          48                  \n",
      "start_layer.weight                       (64, 2)                        128                 \n",
      "start_layer.bias                         (64,)                          64                  \n",
      "end_layer.weight                         (1, 64)                        64                  \n",
      "end_layer.bias                           (1,)                           1                   \n",
      "------------------------------------------------------------------------------------------\n",
      "Total Trainable Parameters: 401\n"
     ]
    }
   ],
   "source": [
    "model, metrics =  fine_tune_meta(phase1_model, inputs, source_function, loss_fn, parameters, epochs, solutions, solution_shape, lr=lr, output_dir=\"hyper_lr_pinn/\", print_interval=100)\n",
    "#np.savez(\"hyper_lr_pinn/metrics2target.npz\", metrics)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2ddbfbac-471f-4d3b-b385-b1bd101b5a3b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e0fec192-2641-47ca-96ff-4b6b06bf3d1b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1eb20c3c-e8c6-4daa-b410-1a1fa028688d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d733e373-fe82-4c40-9208-1aeddb8c029b",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
