{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6b6a28ba-4239-43d4-bdc6-74eb7e81338a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Performing tests for a particular model "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "ed6cfeb1",
   "metadata": {},
   "outputs": [],
   "source": [
    "from collections import OrderedDict\n",
    "import re\n",
    "import os\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import torch\n",
    "from tqdm.notebook import tqdm\n",
    "from tasks import PolynomialRegression, ChebyshevPolynomialRegression\n",
    "import numpy as np\n",
    "from eval import get_run_metrics, read_run_dir, get_model_from_run\n",
    "from plot_utils import basic_plot, collect_results, relevant_model_names\n",
    "from samplers import get_data_sampler\n",
    "from tasks import get_task_sampler\n",
    "import datetime\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "0e8d018b",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "device :  cpu\n"
     ]
    }
   ],
   "source": [
    "directory = \"/.../in-context-learning/\" #Put your own directory\n",
    "run_dir = directory + \"models/\"\n",
    "\n",
    "device = torch.device(\"cpu\")\n",
    "print(\"device : \", device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "a9980951",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1d_tiny64_6l_4ah_deg_1\n"
     ]
    }
   ],
   "source": [
    "n_layer = 6 # You can choose in {1,2,3,6,9,12} according to your models\n",
    "n_ah = 4 # You can choose in {1,2,3,8}\n",
    "n_deg= 1\n",
    "model = \"tiny\" # \"toy\" : for models with layers <= 3, \"tiny\" for 6l and \"standard\" for l = 12\n",
    "n_embed = 64 # 64 for all models except standard 256\n",
    "task = \"polynomial_regression\"\n",
    "\n",
    "run_id = f\"1d_{model}{n_embed}_{n_layer}l_{n_ah}ah_deg_{n_deg}\"\n",
    "#run_id = f\"1dbu_{model}{n_embed}_{n_layer}l_{n_ah}ah_deg_{n_deg}1\" # For uniforme\n",
    "#run_id = f\"1dbg_{model}{n_embed}_{n_layer}l_{n_ah}ah_deg_{n_deg}1\" # For bimodale\n",
    "print(run_id)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "cd8e02c5",
   "metadata": {},
   "outputs": [],
   "source": [
    "run_path = os.path.join(run_dir, task, run_id)\n",
    "#print(\"run_path : \", run_path)\n",
    "model, conf = get_model_from_run(run_path,device=device) #Ici, on a model et conf\n",
    "n_dims = conf.model.n_dims\n",
    "#print(\"n_dims\", n_dims)\n",
    "batch_size = conf.training.batch_size\n",
    "#print(\"batch size\", batch_size)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "31b4ecca",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "data_sampler = get_data_sampler(conf.training.data, n_dims) \n",
    "task_sampler = get_task_sampler(\n",
    "    \"toy_polynomial_regression\",\n",
    "    n_dims,\n",
    "    batch_size,\n",
    "    **conf.training.task_kwargs\n",
    ")\n",
    "task = task_sampler(max_dim=1)\n",
    "\n",
    "xs = data_sampler.sample_xs(b_size=batch_size, n_points=conf.training.curriculum.points.end-1) #torch.Size([64, 40, 1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "beb327ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "# You can uncomment and fix the size of the size of prompts you want to ICL\n",
    "#xs = data_sampler.sample_xs(b_size=batch_size, n_points=100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "03523b06",
   "metadata": {},
   "outputs": [],
   "source": [
    "#Run Here if you want to do the test on a xs in other distribution such as N(0,1) ou U(-1,1)\n",
    "for i in range(xs.shape[0]):      \n",
    "    for j in range(xs.shape[1]):    \n",
    "        for k in range(xs.shape[2]):  \n",
    "            torch.manual_seed(100*i + 10*j +k)\n",
    "            #xs[i, j, k] = -1 + torch.rand(1) * 2 # Random value in U(-1,1)\n",
    "            xs[i, j, k] = torch.randn(1)  # Random value in N(0,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "1d9da7c3",
   "metadata": {},
   "outputs": [],
   "source": [
    "#Uncomment if you want to sort sample data\n",
    "#xs_sorted, _ = torch.sort(xs, dim=1)\n",
    "#xs = xs_sorted"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "cb69ddda",
   "metadata": {},
   "outputs": [],
   "source": [
    "# If you want to evaluate on an other function you can change it in : task.py line 604/605 and put the coefficients you want\n",
    "ys = task.evaluate(xs) #torch.Size([64, 40])\n",
    "with torch.no_grad():\n",
    "    pred = model(xs,ys)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "2aa97fa5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7fe037fd88e0>"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#If you want to plot a specific batch\n",
    "batch2plot = 2 # on a y = f(x) dans chaque batch, donc on choisit un a plot\n",
    "xs_np = xs[batch2plot,:,0].numpy()\n",
    "ys_np = ys[batch2plot,:].numpy()\n",
    "pred_np = pred[batch2plot,:].numpy()\n",
    "plt.plot(xs_np, ys_np, label=\"$f(x)=ax+b$\", color='green')\n",
    "plt.scatter(xs_np, pred_np, label=\"$(x_{n+1}, ?)$\",color='red',marker=\"x\",s=10)\n",
    "plt.xlabel(\"x\")\n",
    "plt.ylabel(\"y\")\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "35d1e360-4847-496c-bf91-ce7daaee2bb6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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XLhwAQkJCZao02np74+lKdJBJwSUZVzQkYiIiO5Pctjp0aMHVqxYgRUrVmDJkiUAAKVSicjISHz66ado2bKl3DU6tXvvfO6ulvyWEREROTWTfnN27doVXbt2RX5+PrKyslC1alW4u7vLXRvh3ltG6OCutmIxREREdsiksJOTk4Pbt2+jZs2aUKlUWLt2La5du4bHHnsMUVFRctfo1NRGdz7nuh0iIiKpJC9QPnbsGDp37ox169YBAObMmYP58+fj+++/x+DBg7Fz507Zi3Rmat4MlIiIyCySw86SJUsQFBSEp59+Gnl5ediyZQuee+45HDhwAP3798eqVassUafT4p3PiYiIzGPSyM7IkSNRt25d7N27FwUFBejTpw8A4PHHH8e5c+dkL9KZGS1Q1jDsEBERSSU57CiVSri5uQEAfv31V/j4+KBZs2YAitfycKGyvEqu2Sko4oUFiYiIpJK8QLlp06bYuHEj3N3dsX37dnTq1AkKhQI3btzARx99dN+rK5Np7j31nIiIiKSRPLIzadIk/P7773j22WehUqkwcuRIAECvXr1w6dIljBs3Tu4anZrRmh1OYxEREUkmeWQnLCwMP//8My5cuIBHHnkEVapUAQDMnDkTLVq0QI0aNWQv0plxgTIREZF5TLrOjpeXF5o3b2607bHHHpOlIDJmdJ0drtkhIiKSTPI0FlUuTmMRERGZh2HHxvGigkREROZh2LFxPBuLiIjIPAw7Ns7oOjuFXLNDREQkFcOOjePIDhERkXkYdmycm5prdoiIiMzBsGPjeJ0dIiIi8zDs2DiVUgGlQgEA0HDNDhERkWQMOzZOoVDATV38NnFkh4iISDqGHTugv9YOww4REZF0DDt2QL9uh2djERERScewYwfULvqRHa7ZISIikophxw7o1+wUaXXQ6YSVqyEiIrIvDDt2gKefExERmY5hxw7wKspERESmY9ixA7zzORERkekYduyAG28GSkREZDKGHTvAkR0iIiLTMezYAa7ZISIiMh3Djh3gyA4REZHpGHbsAE89JyIiMh3Djh0ouUCZdz4nIiKShmHHDnBkh4iIyHQMO3ZAzQXKREREJmPYsQMc2SEiIjIdw44dMAo7Gq7ZISIikoJhxw6oSy5QLuLIDhERkRQMO3aA01hERESmY9ixA0YXFdQw7BAREUnBsGMHeLsIIiIi0zHs2IGSa3YKirhAmYiISAqGHTvgolJCpVQAADScxiIiIpLE6mFHp9Nh6dKliI2NRUREBIYNG4akpKT77n/u3DkMHz4crVu3RkxMDOLi4nDt2rVKrNg69FNZXKBMREQkjdXDTnx8PDZs2IDZs2fjyy+/hE6nw9ChQ6HRaErte/PmTQwZMgTu7u5Yu3YtPvroI2RkZGDo0KEoKCiwQvWVx03NsENERGQKq4YdjUaDhIQExMXFoVOnTggNDcXixYuRkpKCxMTEUvvv2LEDubm5mD9/PoKDg9G0aVMsWLAAFy5cwOHDh63QQeVRuxS/VbwRKBERkTRWDTunT5/G7du3ERMTY9jm4+ODJk2a4ODBg6X2j4mJQXx8PNzd3Q3blMriFrKzsy1fsBVxGouIiMg0LtZ88ZSUFABArVq1jLb7+/sbHiupTp06qFOnjtG21atXw93dHVFRUWbV4uIif+5TqZRG/zWHfhpLqxOAonjRsi2Qs0dbxj4dC/t0LM7QpzP0CFiuT6uGnby8PACAWq022u7m5oasrKxyn7927VqsW7cO06dPh5+fn8l1KJUK+Pp6mvz88vj4eJh9DK8qd/+OPDzd4eXhavYx5SRHj/aAfToW9ulYnKFPZ+gRkL9Pq4Yd/XSURqMxmpoqKCiAh8f9GxVC4IMPPsDKlSsxcuRIvPDCC2bVodMJZGfnmnWMsqhUSvj4eCA7Ow9arXlrbe6ceQ4ASE27hUJvNzOrk4ecPdoy9ulY2KdjcYY+naFHQFqfPj4eFR4BsmrY0U9fpaamol69eobtqampCAkJKfM5hYWFmDZtGn788UdMmzYNL730kiy1FFnwYn1arc7s47uWmGbLzSuEt42N7MjRoz1gn46FfToWZ+jTGXoE5O/TqpN/oaGh8PLywv79+w3bsrOzcfLkyfuuwZk8eTK2b9+ORYsWyRZ07AFvBkpERGQaq47sqNVqDBo0CAsXLoSfnx9q166NBQsWICAgAN27d4dWq0VGRga8vb3h7u6Ob7/9Ftu2bcPkyZMRHR2NtLQ0w7H0+zgq4/tjOX6qJyIikovVl3XHxcWhf//+mD59OgYOHAiVSoU1a9bA1dUVycnJaN++PbZt2wYA+PHHHwEA8+fPR/v27Y3+6PdxVEb3x+LIDhERUYVZdWQHAFQqFSZNmoRJkyaVeqxOnTo4c+aM4fuEhITKLM2mcBqLiIjINFYf2aGKUTPsEBERmYRhx04Yr9lh2CEiIqoohh07YbxmhwuUiYiIKophx05wzQ4REZFpGHbsBKexiIiITMOwYyc4skNERGQahh07oebIDhERkUkYduyEGxcoExERmYRhx04YTWNpOLJDRERUUQw7dsJoGquIYYeIiKiiGHbsBBcoExERmYZhx04olQq4qIrfrgIN1+wQERFVFMOOHdEvUubZWERERBXHsGNH3NTFU1kFXLNDRERUYQw7dkTtUhx2OLJDRERUcQw7dkS/SLlAo4MQwsrVEBER2QeGHTuiX7OjEwJFWoYdIiKiimDYsSNqNa+1Q0REJBXDjh1xc+FVlImIiKRi2LEjal5YkIiISDKGHTviVnIaizcDJSIiqhCGHTuidil553OO7BAREVUEw44dKXl/LF5rh4iIqGIYduxIyWksjuwQERFVDMOOHTEe2eGaHSIioopg2LEjXLNDREQkHcOOHeE0FhERkXQMO3aE19khIiKSjmHHjnDNDhERkXQMO3ZE7co1O0RERFIx7NgRN05jERERScawY0d4UUEiIiLpGHbsCNfsEBERScewY0e4ZoeIiEg6hh07wlPPiYiIpGPYsSNKhcJwFWWGHSIiooph2LEz+tEdLlAmIiKqGIYdO+Pmqh/Z4QJlIiKiimDYsTP6kR1OYxEREVUMw46d0Z9+rtFoIYSwcjVERES2j2HHzujDjgBQpOVUFhERUXkYduyM8ennDDtERETlYdixM24lLyyo4bodIiKi8jDs2BneDJSIiEgahh07o1aXuD9WEcMOERFReRh27IybS4mRHU5jERERlYthx84Y3wyUC5SJiIjKw7BjZ9xKTmNxzQ4REVG5GHbsDBcoExERScOwY2fULhzZISIikoJhx86UnMbimh0iIqLyMezYGaOLCnJkh4iIqFwMO3am5JodTmMRERGVj2HHzqi5QJmIiEgShh07w7BDREQkDcOOnSm5ZkfDBcpERETlYtixMxzZISIikoZhx85wgTIREZE0DDt2Ru2ihOLO1xzZISIiKh/Djp1RKBSGqSyu2SEiIiofw44d0t/5nCM7RERE5WPYsUP6dTsMO0REROVj2LFDDDtEREQVx7Bjh0qu2RFCWLkaIiIi28awY4eMLixYxEXKRERED8KwY4d4YUEiIqKKs3rY0el0WLp0KWJjYxEREYFhw4YhKSnp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eP/9961dumRDhw4V3bt3FwcOHBBnzpwREyZMEFFRUeLff/91mM/ng3p0lM9mWUqeem6J95JhxwKKiorE/PnzRZs2bURERIQYNmyYSEpKsnZZsktLSxNTp04V7dq1E+Hh4eKZZ54RBw8etHZZsrk3BAghxLFjx8TTTz8tmjZtKjp37izWrl1rperkU1af27ZtE08++aRo1qyZaNeunZg3b57Iz8+3UoWmWblypQgODi7zz5QpU4QQQuzZs0f06tVLNG3aVPTo0UNs3brVylVLV5E+161bJ3r27Gn4uV25cqXQarVWrly67Oxs8dZbb4l27dqJZs2aiZdfflmcPXvW8LgjfD7L69ERPptlKRl2hJD/vVQIYUcXlCAiIiKSyL4mpomIiIgkYtghIiIih8awQ0RERA6NYYeIiIgcGsMOEREROTSGHSIiInJoDDtEZFMseTUMXmmDyDkx7BDZid69e+Orr74CAOTk5KBJkyY4ffr0ffcPCQnBsmXLKqs8Wfz5558YPny47MdNSUnB8OHD8e+//8p+bFuzf/9+hISElLqVC5Ez413PiexAdnY2zp8/j5YtWwIAjh49Ck9PTwQHB9/3OV999RUCAgIqq0RZbNy4ERcuXJD9uL///jv27Nkj+3GJyD4w7BDZgSNHjsDHxwdBQUEAikdAIiIiHnjDyoiIiEqqjojItnEai8iGdenSBSEhIRg+fDgyMzMRGhqKkJAQxMfH45dffkFISMh9n1tyGks/tfHHH3/g5ZdfRvPmzdGuXTssWLDA6M7C93P06FG8/PLLaNGiBdq0aYMJEybg+vXrhsdTU1Mxbdo0dOzYEc2aNUP//v2xc+fOUvWsX78eb7zxBqKjoxEZGYnXXnsN6enpAICpU6di8+bN+PfffxESEoJvv/0WAFBQUID58+ejY8eOaNq0KXr37o1t27YZjrtz585SU3YXLlxAs2bN8N///hfffvut4a7fXbt2xdSpU+/bZ2ZmJmbMmIG2bdsiPDwcTz/9tNEdqD///HOj2oDiuzGHhoZixYoVhm0bN25E3759ERERgWbNmqFPnz746aefDI9/++23CA8Px6FDh9CvXz+Eh4fjsccew65du/DPP/9g8ODBaN68Obp164atW7caPS8kJATHjh3DU089hWbNmqF3797Yvn37A9+/s2fPYsSIEWjRogVatGiB0aNHIykp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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "metric = task.get_metric()\n",
    "loss = metric(pred, ys).numpy()  \n",
    "plt.figure()\n",
    "plt.plot(loss.mean(axis=0), lw=2, label=\"Transformer\")\n",
    "plt.xlabel(\"# in-context examples\")\n",
    "plt.ylabel(\"squared error\")\n",
    "plt.legend()\n",
    "plt.show()  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "c3dc9cc8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "scores [0.0002275043516419828, 0.0058739883825182915, 0.560213565826416, 1.9414523839950562, 5.027405261993408, 12.846177101135254, 17.819868087768555, 37.53133773803711, 63.5073356628418, 91.73003387451172]\n",
      "scores vir [0.0, 0.01, 0.56, 1.94, 5.03, 12.85, 17.82, 37.53, 63.51, 91.73]\n",
      "sigmas [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkEAAAHJCAYAAACCD+2FAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAABm6ElEQVR4nO3dd1hT1x8G8PcmIUxRFAVnHS1OQFQUxV2rtlKtq7VuhYqCe+9VUepWwAlqnVWcVatWf9UOK1WsdmlrVbROQEERZCW5vz9SUiOghHUT8n6ex0e4uUm+ycl4OefccwVRFEUQERERmRmZ1AUQERERSYEhiIiIiMwSQxARERGZJYYgIiIiMksMQURERGSWGIKIiIjILDEEERERkVliCCIiIiKzxBAkEa5RScVN6tec1PdPRPSyEhWCpk6ditq1a+f6z9vbu1Dv76effkLt2rXx008/5fk6GRkZWLhwIQ4fPqxXd/v27Qu1toJasmQJmjZtioYNG+LgwYNSl2PW9u/fj9q1a+Pu3bsAgJCQENSuXTvP13/48CGGDRuGe/fuvXK/l1/Pht7Pq0RGRuKzzz7T/f7yY5LS3bt3Ubt2bfTo0QMqlSrb5bm9zzMzM9GjRw/8+OOPum2//fYbBgwYAA8PD7Rs2RLLly9HRkZGgeozts+Hc+fOoVu3bsjMzHztvkePHkW7du3QoEEDzJ49uxiqK1r5ed3m9TpnzpxBr1694ObmhtatW2PBggV4/vy57vL27dtj6tSp+a7dGC1cuDBfnzH5+e7NjaLAt2Bkypcvj9DQ0Bwvs7CwKOZqsouLi8Pnn3+ORYsW6bYFBARg4MCBElal79q1awgPD8eHH36Ibt26oWbNmlKXRC/o3bs3WrVqlef9f/zxR3z77bev3a9+/frYvXs33nzzzYKUl6O1a9eiadOmut/btm2L3bt3o0KFCoV+X/n1xx9/YOPGjRgxYkSe9l+3bh2cnZ3RokULAMCdO3cwZMgQNGzYECtXrsSNGzewYsUKPHnyBPPnz893Xcb2+dC8eXNUrlwZa9aswZgxY1657/z581G9enUEBwfDycmpmCo0Pd988w0CAwPxwQcfYMKECbhx4waWL1+OxMRELFu2TOryisSFCxewdetWqcsoeSFIqVSiYcOGUpdhkGrVqkldgp4nT54AALp06YImTZpIWwxl4+zsDGdn50K/XTs7u2J775QtWxZly5YtlvvKK3t7e4SFhaFDhw546623XrlvXFwcNmzYgF27dum2bdy4Eba2tlizZg2USiXatGkDKysrfPrppxg+fDgqVaqUr7qM7fMBAEaMGIG+ffvi448/fmWQffLkCby9vdGsWbNirM70LFq0CJ06ddL9cdy8eXOo1Wps27YNqampsLa2lrjCwpWSkoJp06bByckJDx8+lLSWEjUcllfr1q1DgwYN8PTpU73tW7ZsQf369fH48WMAwK1btzB69Gh4e3ujYcOGGDBgAC5evJjr7ebUbZ3V1b5//37cvXsXb7/9NgBg2rRpun1fvp5arcaOHTvw/vvvw83NDW3btsXSpUuRnp6ud1+DBw/Gvn370KlTJzRo0ADdunXDd99999rH/9VXX6FHjx7w8PCAt7c3Zs+erXsuQkJCMGDAAADAoEGDXtkN/+TJE8yePRstWrSAq6srPvzwQ5w7d05vn9q1ayM0NBQ9evSAm5sbQkNDsX//ftSrVw+RkZHw9vZG06ZNcf369dfWllXfO++8g9DQUDRt2hQtW7bE06dP8fvvv2PQoEFo3LgxPDw8MHjwYFy+fPmVz0N6ejrCwsLQuXNnuLq6omPHjtiwYQM0Gg2AvL9O7t+/j/Hjx6Np06Zwd3fHoEGDcOXKFd3+Wa+BzZs3o3PnznB3d8e+fftyrEmj0WDNmjVo27Yt3N3dERAQkO3+Xx6m+ueffzB8+HA0a9YM7u7u+Oijj3Q9P/v378e0adMAAG+//bauO719+/ZYuHAhBg0aBDc3N8yYMSPXLuZTp06hU6dOcHV1Re/evfXaOLeu/he77tu3b4979+7hwIEDun1zut7Zs2fRt29fNG7cGM2aNcOECRPw4MEDvfuqV68efvnlF3z00UdwdXVFu3btEBERoXffR44cQdeuXeHm5gYvLy9MnDgRsbGxOT7fL/L394ednR2mTp0KtVr9yn03b96MSpUqoUGDBrptP/zwA9q0aQOlUqnb1rlzZ2g0Gvzwww+53tbrXrsvfz5kZmZi6dKlaN26Ndzc3ODr64uDBw/qPZ9Tp06Fr68vdu/ejQ4dOsDNzQ19+vRBTEwMTp8+jffffx/u7u7o3bs3rl69qldPZGQkevTogYYNG8LNzQ3dunXDsWPH9PZxdXVFpUqVsHnz5hwfU9ZrCQDCwsL0astrO+f0+fCirPfV8ePHERAQgIYNG6JFixZYs2YNkpOTMX36dDRu3BgtWrTAkiVL9OakPXv2DIsWLUKHDh3g6uoKHx8f7N27V+/28/JeBLQ95/7+/mjUqBEaNWqEwMBA3LlzJ8fnJSdXrlzBP//8g/79++ttHzRoEE6dOpVrALp79y4mT56Mli1bon79+mjevDkmT56MxMREAMBnn30GNzc3PHv2TO96a9asQePGjZGampqn+rPa8osvvkC7du3QqFEjnD17FgkJCZgwYQK8vb3h6uqKbt265XnqxOLFi+Ho6IgePXrkePmpU6fQt29feHh4oEGDBujcuTN27NiRbb+bN2/C19cX7u7u8Pb2xtKlS3Mc0n6VEhmCVCpVjv+y3gTvv/8+VCoVvv76a73rHT16FC1btkS5cuVw/fp19OjRA3fv3sXMmTOxdOlSCIKAQYMG4fz58/mqq0KFCrqhuhEjRuQ6bDd79mzdG3Tt2rXo168ftm/fjoCAAL038u+//46IiAiMHj0aYWFhkMvlGDVqVI5v1Cxr1qzB+PHj0bBhQ6xevRqBgYE4ceIEBgwYgLS0NPTu3Vs3dj979uxca0xPT8egQYPwv//9D+PGjUNoaCicnZ3h5+eXLQitW7cO77//PlavXo1OnToB0Aa9TZs2ISgoCNOmTUOtWrVeW1uW+/fv49tvv8WKFSswbdo0yOVy+Pn5wcHBASEhIVixYgVSU1Ph6+ub7QMgiyiKGD58OMLDw9G7d2+sW7cOnTt3xsqVKzFnzhwAeXudJCQkoE+fPvjjjz8wa9YsLFu2DBqNBv369cONGzf0rhcSEoJPPvkEixcvznV+2pIlSxAWFoZevXohNDQUZcqUeWV3uEajgb+/P1JTU7F48WKsWbMGZcqUwYgRI3D79m20bdtWN7wTGhqKgIAA3XV37NgBV1dXrFmzBr169cr1PmbMmIGBAwciJCQEtra2+OSTT/Dbb7/luv/LQkNDUb58ebRp0ybXIbCDBw9i6NChqFixIpYvX45p06bh0qVL+Oijj3RhM+vxjh07Fu+99x42bNiARo0aYfHixfj+++8BABcvXsTkyZPRsWNHbNy4EdOmTUNUVBQmTJjw2jrLli2L2bNn4/fff0d4ePgr9z18+LDutQwAaWlpuHfvHmrUqJHtNu3s7BATE5Pj7SQnJxv82p09ezY+//xz9O/fH2FhYXB0dMSsWbOy7Xfp0iVs374dU6dOxaJFi3Djxg0MGzYMixYtgr+/P5YvX44HDx5g4sSJuuvs2LEDs2fPRocOHbB+/XosXboUSqUSEydOzPYXe+fOnXHkyJEca8waWgWAXr166do9r+2c0+dDbmbOnAkXFxesXbsWzZs3x6pVq9CrVy9YWVkhNDQUHTt2RHh4OI4fPw5A21Z9+/bF4cOH4efnpwsFM2bMwLp163S3m5f3YkxMDPr06YPHjx/js88+Q1BQEO7cuYOPP/5Y7/G8SlYItbS0hL+/P9zc3NC0aVMEBQXlOp8sNTUVAwcOxI0bNzBnzhxERERg4MCBOHr0KFasWKF73tPT03WPO8uhQ4fw3nvvwdra2qD6Q0NDMWXKFMyePRseHh6YNGkSbty4gXnz5mHjxo2oV68epkyZgqioqFc+3rNnz+LQoUNYtGgRZLLsEeTMmTMIDAxE/fr1sWbNGoSEhKBq1aqYP38+fvnlF719Fy1ahMaNG2PdunV49913sXHjRnzxxRevfsJfJpYgU6ZMEV1cXHL9Fx4ertu3f//+4sCBA3W/3759W3RxcRGPHj0qiqIojhkzRmzWrJn47Nkz3T6ZmZlip06dxJ49e4qiKIpRUVGii4uLGBUVpbv/du3a6dV0584d0cXFRdy3b1+Ov798vb///lt0cXER169fr3c7Bw8eFF1cXMQzZ87oPdbbt2/r9jl//rzo4uIiHj9+PMfn58mTJ2KDBg3EWbNm6W2/cOGC6OLiIm7fvj3Hx5WT3bt3iy4uLuLly5d12zQajdivXz+xR48eum0uLi7ioEGD9K67b98+0cXFRTx48KDBta1evVp0cXERL1y4oNvn0qVLoouLi3jx4kXdttu3b4uLFy8WHzx4kGP9Z86cEV1cXMQjR47obQ8LCxNdXFzEa9euiaL4+tfJ8uXLRVdXV/Hu3bu6fdLT08W3335bHDVqlCiK/7X59OnTc6wly9OnT8X69euLS5Ys0dvu6+sruri4iHfu3NF7DkRRFOPi4kQXFxfxyy+/1O2flJQkLly4UPcYsp7vrOuLoii2a9dO7NChg979vNzuWfdz7Ngx3T5paWmit7e37rHldNtZtz9lypRcf3/xemq1WvT29haHDh2qdxu3b98W69evL3722Wd619mzZ49un/T0dNHV1VWcP3++KIqiuH79etHDw0NMT0/X7XPmzBkxJCRE1Gg0Lz/loihmf0+OHDlSbNCgge75e/l5uX79uuji4iKePHlSdxtZ7fBibVlatWolzpw5M8f7zstr98XPh9u3b4u1a9cWN23apHc7Q4cO1WuHrM+H69ev6/aZPXu26OLiIv7444+6bREREaKLi4v49OlTURRFcdGiRdlef7///nuO75WTJ09mu4+Xubi4iKtXrxZFUTS4nV/8fMhJVruNHTtWty0+Pl50cXER+/btq9um0WjERo0aiQsWLBBFURR37Nghuri4iD///LPe7U2fPl10dXUVExMT8/xeHD9+vNiiRQu974nExESxcePGYnBwsN7jefk9kmXDhg2ii4uL2Lp1a3Hx4sXiuXPnxA0bNoiurq7i+PHjdfu9+B66cuWK+PHHH4v//POP3m35+/uLnTp10v3+0Ucfif369dP9fvHiRb3Hnpf6s17/YWFhevfVoEEDce3atbrf1Wq1GBwcrPdafllSUpLYpk0bMSIiQhRF/c+yLBs3btT7rMiq6cXvxayaXmwfjUYjtmnTRgwMDMz1/nNS4nqCypcvj7179+b4r1u3brr9unbtigsXLiA+Ph6A9q97Ozs7Xbfz+fPn0a5dO9jZ2emuo1Ao0KVLF/z+++9ISUkpkvqzepm6dOmit71Lly6Qy+V6QxVly5bVmy+QNU8kq5vzZZcvX0ZGRgZ8fHz0tjdp0gSVK1c2qIfr3LlzKF++POrXr6/raVOr1WjXrh1+//13vd6ounXr5ngbL243tLYXr/vWW2+hbNmyGD58OGbPno2TJ0/C0dERkyZNynXuzPnz56FQKNC5c2e97V27dtVdnvX7q14n586dQ926deHk5KR7HmQyGVq3bq131NCrnocXn4PMzEy0a9dOb/u7776b63UcHR3x5ptvYtasWZgyZQoOHz4MjUaDadOmvXZey+vqAbQHE3Ts2FH3u6WlJVq3bo0LFy689rp5FRMTg/j4+GxtX61aNXh4eGRrew8PD93PSqUSZcuW1R1F4+npidTUVPj4+GDZsmWIjo5Gy5YtMXLkSAiCkKd65s6dCxsbG0ybNi3HYbGsoYIqVarotmUNoeYmt/s29LX7008/QRTFbK/bl587AChdurReD4qjoyMAwN3dXbetTJkyAICkpCQA2mG0iRMnIikpCZcvX8ahQ4d0wxAv90pkPf68HillaDvn5fUJ6L8esh6jm5ubbpsgCChdurSuZ+38+fOoXLmy3vUA7Xs9PT0dv/zyS57fi1FRUWjatCmsrKx07387Ozs0adIk2/s/N1lH2b3zzjuYNGkSvLy88Mknn2DkyJE4cuRIjr2IdevWxc6dO1G5cmXcunUL3377LSIiInDz5k29durZsyeio6N1R4YeOHAANWrU0D12Q+p/uT2aNWuGkJAQjB49GpGRkXj06BGmTJmCRo0a5fpYFy5cCGdnZwwePDjXffz8/BAcHIyUlBT8/vvv+Oqrr7B+/XoA2V+DL85ZFQQBlStX1r2W86pETox2dXV97X6dO3fGp59+imPHjum6ETt16gQrKysAwNOnT3VvqBc5OjpCFEUkJycXeu1Z9wtow9yLFAoFHBwc9LrIXx4rzvqgze0DOeu2c3tcuXW/5+TJkyeIj49H/fr1c7w8Pj4epUuXBgDY2NjkuM+L2w2tzdbWVu/nHTt2YO3atTh27Bh2794NKysrdOvWDTNnztSbo/Hi/Tk4OEAul+ttz3res+7vda+TJ0+e4Pbt27k+Dy8G0tyeh5efAwcHhxxryokgCNi0aRPWrl2LkydP4uDBg7CwsECHDh0wb948XRvk5HX1ZNXycpd1uXLlDP6geZWsifi5tf2L86sA6J77LDKZTDdM7OHhgQ0bNmDLli3YvHkzNmzYAEdHRwwfPlw31+11ypUrh1mzZmHChAmIiIjQCw3Af6+NF99/WX8s5fTHUXJyMkqVKpXjfRn62k1ISNDV+HLNL3vxD7gXvard//nnH8yePRvnzp2DhYUFatasiTp16gDIvs5T1uPP6+eGoe2cl9cnkPPjfNV1nz59muN7KquuF1/br3svPnnyBF999RW++uqrbLeX14n/WZ9lbdu21dveqlUrLFu2DFevXs02zApo56WtW7cOT548gaOjIxo0aABra2u99njvvfewcOFCHDp0CL6+vjh27BiGDRuWr/pffk5XrFiBdevW4dixYzhx4gRkMhlatGiB+fPno3Llytlu7/Tp0zh69Cj27dsHjUaj+wdA98ejTCZDQkIC5syZg1OnTkEQBLzxxhu6sJPbazDLi58FeVXiQlBelSpVCu3bt8exY8fg5eWFv//+W29cvXTp0nj06FG262X1CDg4OODWrVt6lwmCkO0vxxfXeciLrC+t+Ph4vRdSZmYmEhMTs70p83Pbjx49ynbYe3x8PKpWrZrn2ypVqhSqV6+OpUuX5nj5i38lF0dtNWvWxJIlS6BWq/Hrr7/i0KFD2LVrF6pVqwY/P78c7y8xMRFqtVovCMXFxQH478Pvda+TUqVKoWnTppg8eXKOdeUUwHKTdZ+PHz/Wew6yvjxy4+TkhLlz52LOnDn4888/cfz4cWzcuBEODg66+U359ezZM4iiqNeT8ejRI90HZG7B25Ce0qzeiNzeb4a+5lu1aoVWrVohNTUVUVFR2Lp1KxYsWAB3d3e9HoJX8fHxwbFjxxASEqKbWJ4lq54XvyxtbW3h5OSE27dv6+37+PFjpKSkvHJOiyGv3azDzB89eqR3tFlWOCoIjUaDYcOGwcLCAnv37kXdunWhUChw/fp1HDp0KNv+uYX23BR2O+dX6dKls7VTVg2A/uN53XuxVKlSaNGiBYYMGZLt9hSKvH29Vq9eHUD2Xo6sHiJLS8ts1zl8+DCCg4MxadIk9OjRQ/d+HDNmjN58PVtbW3Tu3BnHjh2Di4sLnj9/rjciUpD6S5UqhUmTJmHSpEm4efMm/ve//2HNmjWYN28eNmzYkG3/EydOID09Pcdey/r166N79+4IDg7GxIkTcfPmTWzZsgUeHh5QKpVITU3Fnj17XllPfpW44TBDdOvWDZcvX8auXbtQqVIlvXVMPD09cfr0ab0eH7VajaNHj8LV1TXHLzdbW1skJibqHcX18tFkL/c8vCyrhqNHj+ptP3r0KNRqNRo3bpz3B/gSd3d3KJXKbJMZo6Ojcf/+/Vd2Y+ZU54MHD1CuXDm4urrq/p09exbh4eGvfZyFWdvx48fh5eWF+Ph4yOVyeHh4YO7cubC3t8f9+/dzrV+lUmWbNPjll18CgN7z/KrXSdOmTRETE4MaNWroPQ+HDh3C3r17DXoePDw8YGVlla2m06dP53qdS5cuoUWLFvj1118hCALq1q2LcePGwcXFRffYc5p8mFdZQSJLSkoKzpw5ozvkOeuv8Bcnzd64cSPbl8WraqhRowbKly+fre3v3LmDy5cvG/S6/Oyzz9CzZ0+Ioghra2u0a9cOU6ZMAYBcXwu5mTdvHmxsbLB8+XK97Vnh4+WJwt7e3jhz5ozel9mJEycgl8vh5eWV430Y+tpt3Lgx5HI5Tp48qbf95cn7+ZGYmIiYmBj06tULrq6uui/BrCNOXw66WUfc5fXQ/8Js54Lw9PTEvXv3cOnSJb3tX375JSwsLODm5pbn92LWkWt169bVvfcbNGiALVu2ZGuj3DRp0gQ2NjbZPvO/+eYbKBSKbMN2gPZ7xd7eHn5+froAlJKSgosXL2Zrp169euHatWv4/PPP0aJFC731mvJb/71799CmTRvd81OzZk188sknaNGiRa7vs5EjR2abovLhhx8CAPbu3YuRI0fqHlvHjh3RrFkz3fdsbq/BwlDieoIyMjJeeWh07dq1dV1orVq1QpkyZbB79274+fnp/bU7cuRIfPfddxg4cKDur6Pt27fjzp07uR450q5dO2zbtg0zZszQvfA2b96s90WY1S1+7tw51KpVK1tX+5tvvonu3btj9erVSE1NhaenJ65evYrQ0FA0a9bMoEXyXlamTBkMGzYMYWFhsLCwQLt27XD37l2sWrVKd7951aNHD2zfvh1DhgzB8OHDUbFiRfz444/YuHEj+vfvb/DClAWprVGjRtBoNAgMDMSwYcNga2uLY8eO4dmzZ3rzWV7UunVrNGvWDDNnzkRsbCzq1KmD8+fPY+PGjejevbvegoGvep0MHjwYhw4dwuDBgzF06FA4ODjgq6++wp49e7L1ILyOra0tAgICsHLlSlhbW8PLywvffvvtK0NQvXr1YGVlhcmTJ2PUqFFwdHTEjz/+iKtXr+oW2LO3twcAnDx5Eq1bt35lr8TLLCwsMH36dIwfPx52dnbYsGED0tLSdEeZNWvWDFZWVggODsaYMWOQkpKC1atX6/7qz2Jvb48rV67g/Pnz2XpjZDIZxo8fj2nTpmHChAno2rUrEhMTERoaitKlS+f4V2puvLy8sHnzZkydOhVdu3ZFZmYmwsPDUaZMmVyDSG4cHR0xY8YMTJo0SW97zZo1UalSJVy8eBHvvPOObrufnx+OHj0KPz8/DBkyBLdu3cLy5cvx4Ycf6oJCRkYGrly5olvrydDXbtWqVdGzZ08sX74cmZmZqFOnDk6ePKl7jRQk8JYrVw6VK1fGjh074OzsDHt7e3z//fe6Be1enmt48eJFVKlSJcehmpwUZjsXRI8ePbBz504EBgZi9OjRqFKlCr755hvs27cPI0eO1L1f8vJeDAgIQJ8+feDv74+PP/4YlpaW2L17N06dOoXVq1fnqR5bW1uMHj0awcHBsLe3R8eOHfHzzz8jPDwcAwcOzHFYzc3NDbt27UJwcDDatWuHuLg4RERE4NGjR9mGwBs3bowaNWrg/PnzuiPHClp/5cqV4ezsjAULFiA5ORnVqlXD77//jm+//Rb+/v45XqdKlSrZRgjOnDkDAHpTWNzc3HD48GHUr18fzs7O+Pnnn7FhwwYIgpDrfNeCKHEhKD4+Hh999FGulx88eFA3wStrovO2bdt0E2KzvPXWW9i5c6fuME5BEODm5oatW7fmuoCgt7c3pkyZgm3btuHEiROoX78+QkND0adPH90+dnZ2GDJkCHbv3o1vv/0WZ8+ezXY7QUFBeOONN7Bv3z5s3LgRFSpUwMCBAxEQEFCgDzkAui/K7du3Y/fu3ShTpgw6d+6MsWPH5nkMHtCOD+/YsQPLli3DkiVL8OzZM1SuXBkTJkzA0KFDi7W2ChUqIDw8HKtWrcKMGTOQmpqKt956CyEhIbl+8QmCgPXr12P16tXYsmULEhISUKVKFYwfPz7bh/GrXidOTk744osvsGzZMsydOxfp6emoXr06goKCXnnYeW78/f1hY2ODzz//HJ9//jk8PDwwZcoUzJ07N8f9LS0tsWnTJixbtgxBQUFISkpC9erVMX/+fN0aHM2aNUOLFi2wbNkynDt3Lseu6tyULVsWEyZMwPLlyxEfHw93d3ds375dN0Rgb2+PkJAQLFu2DIGBgahcuTJGjhyZbb2QoUOHYuHChfD19c1xbZkePXrA1tYW69evR2BgIOzs7NCqVSuMHz/+lXOiXtamTRssXboUmzZt0k2Gbty4MbZu3ZotmOVF165dcezYMXzzzTd62zt16oTvvvtO7zQGtWrVwqZNm7B48WKMHj0aDg4OGDx4MEaPHq3bJy4uDh999BFGjhyJUaNG5eu1O2vWLNjY2GDTpk1ITk5G8+bNMWLECISFhRn0Hs7JmjVrEBQUhKlTp0KpVOLNN9/E2rVrsXDhQkRHR+vNq/r++++zTdB+ncJq54KwtrbGtm3bsGzZMqxatQrJycmoWbNmtvdsXt6LderUwY4dO7BixQpMnjwZoijCxcUFYWFhujXh8mLIkCGwt7fH5s2bERkZiQoVKmDUqFH45JNPcty/e/fuuHv3Lvbt24edO3fCyckJbdq0Qd++fTFr1izcuHFD74+dtm3bIiEhAR06dNC7nYLUHxoaiuXLl2PVqlVITExExYoVMXLkSL05R/kRHByMTz/9FJ9++ikA7XDhvHnz8OWXXyI6OrpAt50TQTR0FhERkZmLjY1Fhw4dsGnTJnh6ehp03b179yIhISFfXxZPnjzBd999h1atWunNXfnss8+wf//+QjmXUl5ER0dj6NChOHXqlFGd+oSyE0URXbp0QcuWLTF9+nSpyzE6Ja4niIioqDk5OWHw4MHYuHGjQSEoJSUFu3btyveEdWtrawQFBaFu3boYNGgQbGxscPnyZWzfvj3XYYiiEB4ejkGDBjEAGbHk5GRs2bIFv/32G+7cuZPnoyPNDXuCiIjyISMjA71798akSZPQsmXLPF1HFEVcvXoV9erVy/f9Xr16FStXrsTly5eRmpqKatWqoU+fPujXr1+e10IqiHPnzmHRokXYu3evQUc/UvFSqVRo27atbt2w999/X+qSjBJDEBEREZklsz5EnoiIiMwXQxARERGZJYYgIiIiMksMQURERGSWzPIQeVEUodFwPviryGQCnyMjwvYwLmwP48L2MC5F1R4ymVDoR0CaZQjSaEQkJOT9BI/mRqGQwcHBFklJz6FSFf65WsgwbA/jwvYwLmwP41KU7VG2rC3k8sINQRwOIyIiIrPEEERERERmiSGIiIiIzBJDEBEREZklhiAiIiIySwxBREREZJYYgoiIiMgsMQQRERGRWWIIIiIiIrNklitGExERUeFSq4GoKBmSkwE7Oxk8PTWQy6Wu6tUYgoiIiKhAjhxRYOZMS9y/nzXAZI1KlTRYsCAdPj4qSWt7FQ6HERERUb4dOaKAr68V7t/XP6/XgwcCfH2tcOSI8fa3MAQRERFRvqjVwMyZlhBFANAPQaKo/X3mTEuo1cVfW14wBBEREVG+REXJ/x0Cy/ns7qIo4P59GaKijHNyEEMQERER5UtsbM7hJ7/7FTeGICIiIsoXJyexUPcrbgxBRERElC9eXmpUqqSBIOQccgRBRKVKGnh5GeekIIYgIiIiyhe5HFiwIP3fidH6soLRggXpRrteEEMQERER5VuXLipUr67Jtr1iRREREWlGvU6Q8R68T0REREbv9Gk5bt2Sw9paxIYNaZDLrWFnlwpPT5XR9gBlYQgiIiKifBFFYPlyJQBg0KBMdOmigYMDkJiogcp4O4B0OBxGRERE+fLjj3KcP6+ApaWIgIAMqcsxGEMQERER5UtWL1DfvplwdjbOw+BfhSGIiIiIDHbhggzff6+AQiFi5EjT6wUCGIKIiIgoH1autAQAfPhhJqpWNb1eIIAhiIiIiAz0228ynDypgEwmYvRo0+wFAhiCiIiIyEArVmjnAn3wgQo1a5pmLxDAEEREREQG+PNPGY4csQAAjB1rur1AAEMQERERGWDVKm0vUJcumahTJ/tK0aaEIYiIiIjy5OZNAQcOaNdZHjfOtHuBAIYgIiIiyqOQECU0GgEdOqjg5mbavUAAQxARERHlwd27Anbv1s4FGjcuXeJqCgdDEBEREb1WaKgSKpWAVq1U8PQ0/V4ggCGIiIiIXiM2VsCOHdpeoPHjTX8uUBaGICIiInqlNWuUSE8X0LSpCi1aqKUup9AwBBEREVGuHj8W8Pnn//UCCYLEBRUihiAiIiLK1fr1Fnj+XIC7uxrt2pWcXiCAIYiIiIhy8eQJEB6uXRxx3LiS1QsEMAQRERFRLiIilEhOFlC3rhqdO6ukLqfQMQQRERFRNsnJwIYN2l6gsWMzICuBiaEEPiQiIiIqqC1bLJCYKKBmTQ26di15vUAAQxARERG9JDVVe1g8AIwdmw65XOKCighDEBEREenZscMCjx7JULWqBj17lsxeIIAhiIiIiF6Qnq49RQYAjBqVAQsLiQsqQgxBREREpLNnjwXu35fB2VmDPn0ypS6nSDEEEREREQBApQJWrdL2AgUGZsDKSuKCihhDEBEREQEA9u9X4J9/ZHB01KB//5LdCwQwBBEREREAtfq/XqDhwzNhaytxQcWAIYiIiIhw9KgCf/8tR5kyIoYMyZC6nGLBEERERGTmRBFYvlzbC/TJJxkoVUrigooJQxAREZGZ+/prOa5ckcPOToSfn3n0AgEMQURERGZN2wtkCQAYOjQDDg4SF1SMGIKIiIjM2Jkzcly6JIe1tQh//5J/RNiLJA9BKpUKq1atQrt27eDh4YF+/frh8uXLusuvXr2K/v37o2HDhmjfvj22bt0qXbFEREQlzIoV2rlAAwdmonx5UeJqipfkIWjt2rWIjIzEp59+ioMHD6JGjRrw8/NDXFwcEhMTMWTIEFSrVg379u1DYGAgli5din379kldNhERkck7d06OqCgFlEoRAQHmMxcoi0LqAk6dOgUfHx+0bNkSADB16lRERkbi8uXLiImJgYWFBebPnw+FQoFatWrh9u3b2LBhA3r27Clx5URERKYt64iwjz/ORMWK5tULBBhBCCpXrhxOnz6N/v37o2LFiti9ezeUSiXq1KmDyMhING3aFArFf2V6eXlh/fr1ePToERwdHfN9vwqF5J1gRksul+n9T9JiexgXtodxYXvkX3S0DN9+q4BcLmLcOFWhfC+aWntIHoJmzJiBMWPG4O2334ZcLodMJkNISAiqVauGhw8fwsXFRW//ChUqAAAePHiQ7xAkkwlwcDCDpTALyN7eWuoS6AVsD+PC9jAubA/DhYRo/x8wQIC7u02h3raptIfkIej69esoVaoUwsLC4OTkhMjISEycOBHbt29HWloalEql3v6WltrD+NLT0/N9nxqNiKSk5wWquySTy2Wwt7dGUlIq1GqN1OWYPbaHcWF7GBe2R/789psMhw9bQxBEBASkIjGxcIbCirI97O2tC72HSdIQ9ODBA0yYMAFbtmxBkyZNAACurq64fv06QkJCYGVlhYwM/YlaWeHHxqZgqVWl4pvlddRqDZ8nI8L2MC5sD+PC9jDMsmXaDoYPPlChenU1VKrCvX1TaQ9JB+1++eUXZGZmwtXVVW+7u7s7bt++DWdnZ8TFxeldlvW7k5NTsdVJRERUUly7JsPhw9o+kDFjzO+IsBdJGoKcnZ0BAH/99Zfe9mvXrqF69erw9PTExYsXoVardZdFRUWhRo0aKFeuXLHWSkREVBKsWqWEKAp4991M1Ktn/L01RUnSEOTm5obGjRtjypQpiIqKwq1bt7By5UqcO3cOw4YNQ8+ePZGcnIwZM2bg+vXr2L9/P7Zs2QJ/f38pyyYiIjJJMTEC9u/X9gKNG2fevUCAxHOCZDIZ1q5di5UrV2LatGl4+vQpXFxcsGXLFri7uwMAwsPDERQUhO7du6N8+fKYPHkyunfvLmXZREREJik0VAm1WkD79io0bGjevUAAIIiiaHarI6nVGiQkpEhdhtFSKGRwcLBFYmKKSUxsK+nYHsaF7WFc2B55d++egKZNbZGZKeDw4edo1kz9+isZqCjbo2xZ20I/Osw0VjMiIiKiAgkLUyIzU0DLlqoiCUCmiCGIiIiohIuNFbB9uwUAzgV6EUMQERFRCbd2rRJpaQKaNFGjZUv2AmVhCCIiIirBHj8WsGWLthdo/Ph0CILEBRkRhiAiIqISbONGCzx/LsDVVY2332Yv0IsYgoiIiEqop0+BjRu1p8gYNy6DvUAvYQgiIiIqoTZtUuLZMwG1a6vx3nuFfIKwEoAhiIiIqARKTgbWr9fOBRo7NgMyfuNnw6eEiIioBNq61QIJCTLUqKFBt27sBcoJQxAREVEJk5oKrFmjnQs0Zkw6FJKeJMt4MQQRERGVMDt3WiAuToYqVTTo1Yu9QLlhCCIiIipBMjK0J0oFgJEjM6BUSlyQEWMIIiIiKkEiIy1w754MFSpo0LdvptTlGDWGICIiohJCpQJWrdJ2/QQGZsDKSuKCjBxDEBERUQlx8KACt27JULasBgMHshfodRiCiIiISgCNBli5UtsLNHx4JmxtJS7IBDAEERERlQBHjypw7ZocpUuLGDo0Q+pyTAJDEBERkYkTRWD5cm0vkJ9fBuztJS7IRDAEERERmbiTJ+X44w85bG1FfPIJe4HyiiGIiIjIhIkisGKFJQBgyJAMlC0rcUEmhCGIiIjIhH33nRwXL8phZSVi+HAeEWYIhiAiIiITtmKFdi7QgAGZqFBBlLga08IQREREZKKiouT48UcFLCxEBAZyLpChGIKIiIhMVFYvUJ8+mahUib1AhmIIIiIiMkGXLslw+rQCcrmIUaPYC5QfDEFEREQmKKsXqGdPFapXZy9QfjAEERERmZg//pDh+HELCIKIMWPYC5RfDEFEREQmJutM8V27qvDWWxqJqzFdDEFEREQm5Pp1AYcOKQAAY8eyF6ggGIKIiIhMyKpVlhBFAZ07Z6J+ffYCFQRDEBERkYm4dUvA3r3sBSosDEFEREQmIiRECbVaQNu2KjRqxF6ggmIIIiIiMgH37wv44gsLAMD48ewFKgwMQURERCYgLEyJzEwBzZur4OWllrqcEoEhiIiIyMjFxQnYto29QIWNIYiIiMjIrVtngbQ0AY0bq9G6NXuBCgtDEBERkRFLSAA2b9YujjhuXDoEQeKCShCGICIiIiO2caMSKSkC6tdX45132AtUmBiCiIiIjFRSEhAeru0FGj8+g71AhYwhiIiIyEht3qzE06cCXFzU6NJFJXU5JQ5DEBERkRFKSdFOiAaAMWMyIOM3dqHjU0pERGSEtm2zwOPHMrzxhgbdu7MXqCgwBBERERmZtDTt4oiAthdIoZC4oBKKIYiIiMjI7NplgdhYGSpV0uDDDzOlLqfEYggiIiIyIpmZ2hOlAsCoURlQKiUuqARjCCIiIjIikZEK3L0rQ/nyGvTty16gosQQREREZCRUKmDVKksAQEBABqytJS6ohGMIIiIiMhKHDikQEyODg4OIQYPYC1TUON+ciIhIQmo1EBUlx8OHAhYu1E4A8vfPgJ2dxIWZAYYgIiIiiRw5osDMmZa4f/+/gRlBEFGlikbCqswHQxAREZEEjhxRwNfXCqKov10UgVGjrGBjkwYfHy6SWJQ4J4iIiKiYqdXAzJmW/wagl8+Kqv195kxLqHnS+CLFEERERFTMoqLk/w6B5XxaeFEUcP++DFFR8uItzMwwBBERERWz2Nicw09+96P8YQgiIiIqZk5O4ut3MmA/yh+GICIiomLm5aVGpUoaADmHHEEQUamSBl5enBRUlBiCiIiIiplcDsydm57jZYKgDUYLFqRDzilBRYohiIiISAIJCQIAATKZfm9QxYoiIiJ4eHxx4DpBRERExSwlBVi+XLs69KefpqNePQ1iYwU4OYnw8lKzB6iYMAQREREVs4gIJeLiZKhWTYNBgzKhVEpdkXnicBgREVExevoUCA3Vpp5Jk9IZgCRkFCHo4MGDeO+99+Dq6oouXbrg2LFjusvu3r0Lf39/NGrUCC1btsTKlSuh5hKaRERkosLClHjyRECdOmr06sV5P1KSPAQdOnQIM2bMQL9+/XD06FH4+Phg/PjxuHTpEjIzM+Hr6wsA+OKLLzB37lzs2rULYWFhEldNRERkuNhYARs2aLt+pk7N4NwfiUk6J0gURaxatQoDBw5Ev379AAAjRoxAdHQ0zp8/j3v37uH+/fvYs2cPSpcuDRcXFzx+/BiLFy/G8OHDoWQfIhERmZCVK5V4/lxAo0ZqvPsue4GkJmlPUExMDO7du4f3339fb3tERAT8/f0RHR2N+vXro3Tp0rrLvLy8kJycjKtXrxZ3uURERPn2zz8Ctm61AABMn54OgWfEkJykPUExMTEAgOfPn8PX1xdXrlxBlSpVMGLECLRv3x4PHz6Es7Oz3nUqVKgAAHjw4AHc3d3zfd8KheQjgUZLLpfp/U/SYnsYF7aHcTGl9li2TInMTAFt2qjRvr0II5iRUuhMqT0AiUNQcnIyAGDKlCkYOXIkJk6ciBMnTiAgIACbN29GWloa7O3t9a5jaWkJAEhPz3mlzbyQyQQ4ONjmv3AzYW9vLXUJ9AK2h3FhexgXY2+PK1eA3bu1Py9eLC/x30HG3h5ZJA1BFhbabkFfX190794dAFC3bl1cuXIFmzdvhpWVFTIyMvSukxV+bGxs8n2/Go2IpKTn+b5+SSeXy2Bvb42kpFSo1RqpyzF7bA/jwvYwLqbSHlOmWEKjUcDHR4W33kpHYqLUFRWNomwPe3vrQu9hkjQEOTk5AQBcXFz0tr/55ps4c+YMmjZtimvXruldFhcXp3fd/FKpjPfNYizUag2fJyPC9jAubA/jYszt8fPPMhw5ooAgiJg8Od1o6yxMxtweL5J00K5+/fqwtbXFL7/8orf92rVrqFatGjw9PXHlyhXdsBkAREVFwdbWFnXq1CnucomIiAy2cKF2Gkfv3irUqWP8wcCcSBqCrKys4Ofnh7CwMBw5cgT//PMP1q5di7Nnz2LIkCHo0KEDypcvj7Fjx+LPP//EqVOnsHz5cgwdOpSHxxMRkdH7/ns5vvtOAQsLbS8QGRfJzx0WEBAAa2trrFixArGxsahVqxZCQkLQrFkzAEB4eDjmzZuHDz/8EKVLl0bfvn0REBAgcdVERESvJopAUJC2F2jgwExUqya+5hpU3ARRFM2uVdRqDRISUqQuw2gpFDI4ONgiMTHFJMZ0Szq2h3FhexgXY26Pr75SYPBga9jYiPjppxQ4OZX8r9uibI+yZW0LfWK0aRzIT0REZELUamDRIu20jU8+yTCLAGSKCiUEqVQqPHnypDBuioiIyOTt26fAX3/JUbq0iMDAjNdfgSRhcAhSqVQIDQ3F4cOHAQA//fQTvL290bx5cwwaNAhPnz4t9CKJiIhMRUYGsHixdi7QqFEZKFNG2noodwaHoNWrV2Pt2rVISkoCACxYsABlypTBtGnT8M8//2DZsmWFXiQREZGp2LbNAv/8I0OFChr4+bEXyJgZHIKOHj2K8ePHo1+/frhx4wb+/vtvjBgxAgMHDsS4cePwzTffFEWdRERERi8lBVi+XDsXaPz4DBTg5AZUDAwOQXFxcboTl545cwYymQytW7cGADg7O+PZs2eFWyEREZGJCA9XIj5ehmrVNOjfP1Pqcug1DA5BFSpUwN27dwEA33zzDerWrYuyZcsCAC5dupTtrO9ERETm4MkTIDRU2ws0eXI6uKav8TM4BPn4+GDRokXw9fXFxYsX0bNnTwBAUFAQQkJC8P777xd6kURERMYuLEyJp08F1KmjRs+eKqnLoTwweMXosWPHwsbGBhcuXMCECRPQt29fAMBvv/2GoUOHcjVnIiIyO7GxAjZu1Hb9TJuWAblc4oIoT7hiNGVjzCuwmiO2h3FhexgXY2mPqVMtsWmTEo0bq/HVV88hCJKVIilTWzE6X+cOy8jIwN69e/Hjjz8iPj4eCxcuxPnz51G/fn24ubkVaoFERETG7PZtAdu2WQAApk9PN9sAZIoMjlQJCQno2bMngoKCcPv2bfz6669IS0vD6dOnMWDAAFy6dKko6iQiIjJKS5ZYIjNTQOvWKrRqpZa6HDKAwSFo8eLFSElJwVdffYUDBw4gazQtJCQErq6uWL16daEXSUREZIz+/FOGyEjtoMqMGekSV0OGMjgEnT59GmPGjMEbb7wB4YU+P0tLSwwdOhR//PFHoRZIRERkrBYtUkIUBXTpkgkPD84RMzUGh6D09HSUyeVEKHK5HJmZXByKiIhKvosXZTh2zAIymYipU3l6DFNkcAhydXXFzp07c7zs8OHDaNCgQYGLIiIiMnYLF2pPktq7twq1a7MXyBQZfHTYmDFjMHjwYHTr1g1t2rSBIAg4cuQIQkJC8MMPPyA8PLwo6iQiIjIa330nx/ffK2BhIWLSJM4FMlUG9wQ1adIEmzdvhrW1NcLDwyGKIrZs2YL4+HisX78eXl5eRVEnERGRURDF/3qBBg3KRLVqZrfcXolhcE/QuXPn4OHhgS+++AJpaWl4+vQp7OzsYGtrWxT1ERERGZWvvlLg55/lsLERMXYs5wKZMoN7gkaNGoWvv/4aAGBlZQUnJycGICIiMgtqNRAcrD09hr9/BipUYC+QKTM4BNnb28PKyqooaiEiIjJqkZEK/PWXHGXKiAgIYC+QqTN4OMzf3x8LFixATEwM6tSpAxsbm2z7eHp6FkpxRERExiI9Xbs6NACMHJmB0qUlLogKzOAQNGfOHADAihUrAEBvwURRFCEIAq5evVpI5RERERmH7dstcOeODE5OGvj5sReoJDA4BG3durUo6iAiIjJaKSnA8uXauUDjx2cgh0EQMkEGh6CmTZsWRR1ERERGa+NGJeLjZXjjDQ369eOZEUoKg0MQAMTExGD16tU4f/48kpKS4ODggCZNmiAwMBC1atUq7BqJiIgkk5gIhIZqe4EmT06HUilxQVRoDA5B169fR58+fSCXy9G+fXs4OjoiPj4ep0+fxpkzZxAZGckgREREJUZYmBJJSQLq1lWjRw+V1OVQITI4BC1duhRVqlTBtm3bUKpUKd32Z8+eYdCgQVixYgVCQ0MLtUgiIiIpxMYK2LhR2/UzbVo65HKJC6JCZfA6QRcuXMDw4cP1AhAAlCpVCsOGDcOFCxcKrTgiIiIpLV+uRGqqgCZN1OjUSS11OVTIDA5BCoUClpaWOV6mVCqRkcHDBomIyPTduiVg2zYLAMCMGel4YUUYKiEMDkGurq7YuXMnRFF/qXBRFLFjxw40aNCg0IojIiKSyuLFllCpBLRpo4K3N3uBSiKD5wSNGTMGH3/8Mbp27YrOnTujfPnyiI+Px/HjxxETE4PNmzcXRZ1ERETF5upVGfbt035FzpiRLnE1VFQMDkGurq4IDw/HsmXLEBoaqlslukGDBti4cSNPmUFERCZv0SIlRFGAj08mGjbUSF0OFZF8rRPk5eWFL774AhkZGUhKSoK9vT1UKlW2ydJERESmJjpahuPHLSCTiZg6lfNcSzKD5wRlZmZizpw5+PDDD2FtbQ0nJydcunQJzZs3x2effQaNhomZiIhMkygCCxdqD/756CMVXFz4nVaSGRyCQkJC8OWXX6JLly66bfXq1cPEiROxZ88ehIeHF2qBRERExeXbb+X44QcFlEoREydyLlBJZ/Bw2OHDhzFlyhT06dNHt61MmTIYPHgwFAoFtm7dimHDhhVqkUREREXtxV6gQYMyUbWq+JprkKkzuCcoMTERVatWzfGymjVr4uHDhwUuioiIqLgdParA5cty2NiIGDuWc4HMgcEhqGbNmjhx4kSOl33zzTd44403ClwUERFRcVKrgeBg7ekxhg/PQPny7AUyBwYPhw0cOBBTp07FkydP0KFDB5QrVw4JCQk4ffo0jh07hkWLFhVFnUREREUmMlKBa9fkKFNGREAAe4HMhcEh6IMPPkBKSgrWrFmDr7/+WrfdwcEBs2bNwgcffFCY9RERERWp9HTt6tAAMGpUBuztJS6Iik2+1gnq168f+vbti5iYGDx58gT29vaoWbMmZDKDR9eIiIgktW2bBe7elcHJSQNfX/YCmZN8p5bU1FTUrFkTjRo1wo0bN7B161bcunWrEEsjIiIqWsnJ2jPFA8CECRmwsZG4ICpWBoegmzdv4p133sGGDRsAACtXrsTYsWMRHByMbt264eLFi4VeJBERUVHYuFGJR49kqF5dg379MqUuh4qZwSFo6dKlUCgUePvtt5GRkYGdO3fi3XffRXR0NFq1aoWVK1cWQZlERESFKzERCAvT9gJNmZIOCwuJC6JiZ3AIio6OxoQJE+Dq6orz58/j2bNn+Oijj2BnZ4c+ffrg999/L4o6iYiIClVIiBJJSQLq1lWje3eV1OWQBPJ17jD7f6fOf/fdd7C2tkbjxo0BAGq1GgpFvuZaExERFZuHDwVERGh7gaZPTweP6zFPBje7i4sLvv76a8THx+P48eNo2bIlFAoFMjMzsWPHDri4uBRFnURERIVm+XIlUlMFNGmiRseOaqnLIYkYHIJGjx6NvXv3onXr1nj69Ck++eQTAECnTp0QFRWFwMDAQi+SiIiosMTECNi+XTsBaObMdAiCxAWRZAweu/L29sbhw4fx22+/wd3dHZUrVwYADBo0CF5eXqhdu3ahF0lERFRYFi+2hEoloF07FVq0YC+QOcvXBJ6qVatmO4nqoEGDCqUgIiKionLligz792u/+qZPT5e4GpIap4IREZHZCA5WQhQFvP9+JtzdNVKXQxJjCCIiIrNw4YIMx49bQCYTMXUqT49BDEFERGQGRBFYuFB7ktQ+fTLx1lvsBaJ8hKBz584hLS2tKGohIiIqEmfOyHH2rAJKpYiJE9kLRFoGh6BRo0bh66+/LopaiIiICt2LvUCDB2eiShVR4orIWBgcguzt7WFlZVUUtRARERW6I0cU+OUXOWxsRIwZw14g+o/Bh8j7+/tjwYIFiImJQZ06dWBjY5NtH09Pz0IpjoiIqCBUKu0RYQAwfHgGypdnLxD9x+AQNGfOHADAihUrAADCC0ttiqIIQRBw9erVQiqPiIgo/yIjFfj7bzkcHEQEBLAXiPQZHIK2bt1aFHUQEREVqvR0YMkS7Vyg0aPT8e+5v4l0DA5BTZs2LYo6iIiICtXnn1vg7l0ZnJ01GDo0U+pyyAjla52gmJgYjBs3Dt7e3nB1dUXr1q0xfvx43Lhxo0DFxMTEwMPDA/v379dtu3r1Kvr374+GDRuiffv27IkiIqLXSk4GVq7UzgWaMCED1tYSF0RGyeCeoOvXr6NPnz6Qy+Vo3749HB0dER8fj9OnT+PMmTOIjIxErVq1DC4kMzMTEydOxPPnz3XbEhMTMWTIELRv3x7z5s3D5cuXMW/ePNja2qJnz54G3wcREZmHDRuUePRIhho1NOjbl71AlDODQ9DSpUtRpUoVbNu2DaVKldJtf/bsGQYNGoQVK1YgNDTU4EJCQkJgZ2ent23Pnj2wsLDA/PnzoVAoUKtWLdy+fRsbNmxgCCIiohwlJABhYdpeoClT0mFhIXFBZLQMHg67cOEChg8frheAAKBUqVIYNmwYLly4YHARFy5cwO7duxEcHKy3PTo6Gk2bNoVC8V9W8/Lywq1bt/Do0SOD74eIiEq+kBBLPHsmoF49NT74QCV1OWTEDO4JUigUsLS0zPEypVKJjAzDDkFMSkrC5MmTMXPmTFSsWFHvsocPH8LFxUVvW4UKFQAADx48gKOjo0H39SKFgqdNy41cLtP7n6TF9jAubA/j8nJ73L8vICJC2/Uza1YmlEq2U3EytfeHwSHI1dUVO3fuRNu2bbOtEbRjxw40aNDAoNubO3cuPDw88P7772e7LC0tDUqlUm9bVgBLT083tHQdmUyAg4Ntvq9vLuztOZPQmLA9jAvbw7hktcf06UBaGtCiBfDRR1Z44WuKipGpvD8MDkFjxozBxx9/jK5du6Jz584oX7484uPjcfz4ccTExGDz5s15vq2DBw8iOjoahw8fzvFyKyurbD1LWeEnp5Wq80qjEZGU9Pz1O5opuVwGe3trJCWlQq3mmZalxvYwLmwP4/Jie1y/LiI83BqAgOnTU/HkCdunuBXl+8Pe3rrQe5jy1RMUHh6OZcuWITQ0VLdKdIMGDbBx40aDTpmxb98+PH78GG3bttXbPmfOHHz11VdwdnZGXFyc3mVZvzs5ORlauh6Vim+O11GrNXyejAjbw7iwPYyLWq1BUJASKpWA9u1VaNpUBRWnA0nGVN4fBoegAwcOoEWLFoiMjERqaiqSkpJgb28P63wswrB06VKkpaXpbevYsSNGjx6Nrl274tChQ/jiiy+gVqshl8sBAFFRUahRowbKlStn8P0REVHJ9McfAg4c0H6lTZ+e/+kSZF4M7leaP38+fv31VwCAtbU1nJyc8hWAAG1vzhtvvKH3DwDKlSsHJycn9OzZE8nJyZgxYwauX7+O/fv3Y8uWLfD398/X/RERUcmhVgM//CDDrl3A+PGWEEUBXbtmws3N+HsgyDgY3BPk7OyM5OTkoqglm3LlyiE8PBxBQUHo3r07ypcvj8mTJ6N79+7Fcv9ERGScjhxRYOZMS9y/n/W3vByACC8vjoFR3gmiKIqGXGHLli0IDQ3Fe++9h9q1a8PWNvtRVh988EFh1Vck1GoNEhJSpC7DaCkUMjg42CIxMcUkxnRLOraHcWF7SO/IEQV8fa2g/fZ68fAvEYIARESkwceHYUgKRfn+KFvWttAnRhscgurUqfPqGxQEXL16tUBFFTWGoFfjh7xxYXsYF7aHtNRqoHFjW9y/L0A/AGkJgoiKFUVcvJiCf6eSUjEytRBk8HDY//73v0ItgIiIKK+iouQvDIFlJ4oC7t8XEBUlh7e3uhgrI1NkcAiaPXs2/Pz80Lx586Koh4iIKFexsXlb/TCv+5F5M7hf6eeff9ZbKZqIiKi4ODnlbQZHXvcj82ZwCGrVqhW+/PJLZGZmFkU9REREufLyUsPZWQMg55AjCCIqVdLAy4tDYfR6Bg+HWVpa4ssvv8SxY8dQq1atbKevEAQBn3/+eaEVSERElEUuB+rUUePhQwtog9B/IxOCoA1GCxakc1I05YnBIejhw4fw8PDQ/f7ywWUGHmxGRESUZ6dOyXHmjPYs8eXKiXj8+L8QVLGiiAUL0nl4POWZwSFo27ZtRVEHERHRKz1+LGDsWCsAwLBhGZg3Lx0XLiiQnGwNO7tUeHqq2ANEBjE4BL1Keno6YmJiXruWEBERkSFEEZg40RJxcTK4uKgxY4Z2yKtlSw0cHIDERA1PmEoGy9PE6JYtW2ZbAHHz5s1ISEjQ2/bnn3/ylBZERFTo9uxR4OhRCygUItasSUM+T1lJpCdPIejRo0d6R4Op1WosXrwYDx48KLLCiIiIAODOHQHTp2uHwSZNyuAJUqnQ5Hv9aU6AJiKioqbRAKNHW+HZMwFNmqgxalSG1CVRCVK4J+EgIiIqROvXW+DsWQVsbESEhqZCUagzWcncMQQREZFRunpVhqAgSwDA/PnpqFmTIxBUuBiCiIjI6KSnAwEBVsjIEPDOOyoMGMCzFFDhK1AI4jnEiIioKCxZosQff8hRtqwGy5engV83VBTyPLoaGBgIpVKpt2348OGwsLDQ/Z6RwQlrRERUMFFRcoSEaL9vli5N58lQqcjkKQRx7R8iIioOycnAyJFWEEUBH32UyVNgUJHKUwhatGhRUddBRESEWbMs8c8/MlStqkFQUJrU5VAJx4nRRERkFI4dU2DHDiUEQURISBrs7aWuiEo6hiAiIpJcfLyACRO0h8OPGJGJFi3UEldE5oAhiIiIJCWKwIQJlnj0SIa6ddWYNi1d6pLITDAEERGRpHbutMDx4xZQKrUnR7W0lLoiMhcMQUREJJlbtwTMnKlNPVOmZKB+fZ4clYoPQxAREUlCrdYeDp+SIsDLS4WAAK41R8WLIYiIiCQRFqbE+fMK2NpqjwaTy6WuiMwNQxARERW7336T4bPPtKtCL1yYhjfe4KrQVPwYgoiIqFilpQGBgVbIzBTw7ruZ6NOHq0KTNBiCiIioWC1caIk//5TD0VGDZcvSeXJUkgxDEBERFZsffpBj/XrtibdXrEiDoyOHwUg6DEFERFQskpKAUaO0J0cdMCADnTpxVWiSFkMQEREVi+nTrXDvngxvvKHBvHlcFZqkxxBERERF7vBhBfbssYBMJiI0NA12dlJXRMQQRERERSw2VsDEiVYAgNGjM9CsGYfByDgwBBERUZERRWDsWCskJgpwdVVj4kSuCk3GgyGIiIiKzOefW+B//1PA0lJEWFgalEqpKyL6D0MQEREViZs3Bcydqz056syZ6ahThydHJePCEERERIVOpQICA63x/LmAVq1U+OSTTKlLIsqGIYiIiArdqlVKXLwoh729iFWr0iDjtw0ZIb4siYioUF2+LMOyZdrJP4sWpaFKFa4KTcaJIYiIiArN8+fak6OqVAK6ds1Er148OSoZL4YgIiIqNAsWWOLvv+VwctJg8eI0nhyVjBpDEBERFYozZ+QID9cOg61alYayZSUuiOg1GIKIiKjAEhOB0aO1q0IPGZKB9u25KjQZP4YgIiIqsKlTrfDwoQy1amkwezZPjkqmgSGIiIgKZP9+BQ4csIBcLiIsLBW2tlJXRJQ3DEFERJRv9+8LmDJFOww2blwGGjXiqtBkOhiCiIgoXzQa7Tygp08FeHioMW4cT45KpoUhiIiI8mXTJgt8950C1tbaYTALC6krIjIMQxARERns2jUZ5s/Xnhx19ux0vPkmV4Um08MQREREBsnM1K4KnZYmoG1bFYYO5clRyTQxBBERkUGWLVPil1/kKFNGe3JUrgpNpoohiIiI8iw6WoaVK7WrQi9ZkoaKFTkMRqaLIYiIiPIkJQUIDLSGRiOgR49MdOvGk6OSaWMIIiKiPJk71xIxMTJUqqRBcHCa1OUQFRhDEBERvdapU3J8/rl2GGz16jSUKSNtPUSFgSGIiIhe6fFjAWPHaleFHjYsA61b8+SoVDIwBBERUa5EEZg40RJxcTK4uKgxYwZPjkolB0MQERHlas8eBY4etYBCIWLNmjRYW0tdEVHhYQgiIqIc3bkjYPp07TDYpEkZcHPjyVGpZGEIIiKibLJOjvrsmYAmTdQYNYonR6WSR/IQ9OTJE8yePRutW7dGo0aN8PHHHyM6Olp3+blz59CjRw+4u7ujc+fOOHr0qITVEhGZh/XrLXD2rAI2NiJCQ1OhUEhdEVHhkzwEjR8/HpcuXcLy5cuxb98+1K1bF76+vrh58yZu3LgBf39/tGrVCvv370fv3r0xefJknDt3TuqyiYhKrKtXZQgK0p4cdf78dNSsyVWhqWSSNNvfvn0bZ8+exc6dO9G4cWMAwKxZs/D999/j8OHDePz4MWrXro1x48YBAGrVqoUrV64gPDwczZs3l7J0IqISKT0dCAiwQkaGgHfeUWHAAJ4clUouSXuCHBwcsGHDBri6uuq2CYIAQRCQlJSE6OjobGHHy8sLFy9ehCjyLxMiosK2ZIkSf/whR9myGixfzpOjUskmaU+Qvb092rRpo7ftxIkTuH37NqZPn44DBw7A2dlZ7/IKFSogNTUViYmJKFu2bL7vW6GQfCTQaMnlMr3/SVpsD+NSktsjKkqGkBDtqtArVmSgcmUBgHGnoJLcHqbI1NrDqKa6/fzzz5g2bRo6duyItm3bIi0tDUqlUm+frN8zMvJ/pIJMJsDBwbZAtZoDe3suCGJM2B7GpaS1x7NnQGCgdnHEwYOBgQOtpC7JICWtPUydqbSH0YSgU6dOYeLEiWjUqBGWLl0KALC0tMwWdrJ+ty7Ail0ajYikpOf5L7aEk8tlsLe3RlJSKtRqrgsiNbaHcSmp7TF6tBIxMRaoWlWDuXNTkZgodUV5U1Lbw1QVZXvY21sXeg+TUYSg7du3IygoCJ07d8Znn32m6+2pWLEi4uLi9PaNi4uDjY0NSpUqVaD7VKn4ZnkdtVrD58mIsD2MS0lqj2PHFNi+3QKCICIkJA02NhqoVFJXZZiS1B4lgam0h+QhaOfOnfj0008xYMAAzJgxA8ILs/CaNGmC8+fP6+0fFRWFRo0aQSYzjfFGIiJjo1YDUVFyxMYKsLTUnhsMAAICMtGiBU+OSuZD0hAUExODhQsX4p133oG/vz8ePXqku8zKygoDBgxA9+7dsXTpUnTv3h3ffvstjh8/jvDwcAmrJiIyXUeOKDBzpiXu39f/Q7JyZTWmTuXJUcm8SBqCTpw4gczMTJw8eRInT57Uu6x79+4IDg7GmjVrsGTJEnz++eeoUqUKlixZwjWCiIjy4cgRBXx9rZB9hRER9+7JcPKkAj4+JjYORlQAgmiGC+6o1RokJKRIXYbRUihkcHCwRWJiikmM6ZZ0bA/jYqrtoVYDjRvb4v79nA97FwQRFSuKuHgxBXJ58deXX6baHiVVUbZH2bK2hT4xmhNriIjMQFSU/N8hsJzX/RFFAffvyxAVZUIJiKiAGIKIiEo4lQr43//yFm5iY417cUSiwiT50WFERFT4RBH47TcZIiMtsG+fAo8e5e1vXicns5shQWaMIYiIqAS5d0/Avn0WiIxU4K+//uv9KVdOg7Q0ASkpwKvmBHl58RB5Mh8MQUREJu7ZM+2RX5GRFjh7Vg5R1IYcKysRnTur0Lt3Jtq2VePECe3RYYCo2wfQBiAAWLAg3aQmRRMVFEMQEZEJUqmAM2fkiIy0wPHjCqSm/hdqWrRQoXdvFd5/PxP29v9dx8dHhYiItH/XCfpv/4oVRSxYkM7D48nsMAQREZmIV83zeestNXr3VqFnz0xUrZr7vB4fHxXefVelWzHayUk7BMYeIDJHDEFEREYut3k+jo4adO+uHe5yd9dAyOOBXXI54O3NuT9EDEFEREYor/N8LCwkLpTIhDEEEREZifzM8yGi/GMIIiKSUGHM8yGi/GEIIiKSQGHP8yEiwzEEEREVE87zITIuDEFEREWI83yIjBdDEBFRHqnVQFSUDMnJgJ2dDJ6emhzX1+E8HyLTwBBERJQHR44o/l1pOSvQWKNSJY3eSsuc50NkWhiCiIhe48gR7Tm3xJc6bh48EODra4UhQzJw7Zqc83yITAxDEBHRK6jVwMyZlv8GIP0uHG3gEbFpk6VuG+f5EJkOhiAioleIipK/MASWE20w6tcvA+PHZ3CeD5EJedU7m4jI7MXG5m0CT6tWagYgIhPDEERE9Ar37uUtBDk5MQARmRoOhxER5eDvv2WYM8cSp05lfUyKeHlOEAAIgoiKFUV4efGs7ESmhj1BREQvePJEOxG6TRsbnDqlgEIhomPHTAiCNvC8KOv3BQvSc1wviIiMG0MQERG0KztHRFigWTM7bNighEoloHPnTHz/fQq2b09DREQaKlbUD0EVK4qIiEjTrRNERKaFw2FEZPZOn5Zj9mxL3QKHdeuqMW9eOtq2/W+Iy8dHhXffVeHCBQWSk61hZ5cKT08Ve4CITBhDEBGZrevXBcyZY4WTJ7UfhWXLajBlSgYGDMiEIodPR7kcaNlSAwcHIDFRAxU7gIhMGkMQEZmdJ0+AZcssERFhAZVKgEIhws8vExMmpKN0aamrI6LiwhBERGZDpQI+/9wCixdbIjFRe6RXp04qzJ2bhlq1eIg7kblhCCIis/DyvJ86ddSYP19/3g8RmReGICIq0Qyd90NE5oMfAURUIuU078fXNxMTJ3LeDxFpMQQRUYmiUgFbt1pg8WIlEhK0S6F17KjCvHmc90NE+hiCiKjEyGnez7x56WjXjvN+iCg7hiAiMnnXrwuYO9cKX3/NeT9ElHf8eCAik5XbvJ8JE9JRpozU1RGRsWMIIiKTw3k/RFQYGIKIyKRw3g8RFRaGICIyCTnN+5k8OQMDB3LeDxHlDz86iMiocd4PERUVhiAiMkq5zfuZOzcNb77JeT9EVHAMQURkdM6c0c77+fNP7byf2rW15/nivB8iKkwMQURkNF6e9+PgIGLy5HQMGsR5P0RU+PixQkSS47wfIpICQxARFTm1GoiKkiM2VoCTkwgvLzXk8pzn/bzzjna9H877IaKixhBEREXqyBEFZs60xP37Mt22SpU0+PjjTBw9qtCb9zNvXjrat+e8HyIqHgxBRFRkjhxRwNfXCuJLnTr37wtYtswSAOf9EJF0+JFDREVCrQZmzrT8NwAJL10qABBhawv8+GMyypUr/vqIiGSv34WIyHCnTsn/HQJ7OQBlEZCSIuiGw4iIiht7goiowDQa4MYNGS5ckOHCBTmio+W6c3u9TmxsbiGJiKhoMQQRkcGSk4HLl+W4cEH77+JFORIT8xdmnJx4FBgRSYMhiIheSRSBO3cEXeC5cEGOK1dkUKv1Q4+VlQgPDzU8PbX/GjbUoFMnGzx4IEAUswckQRBRsaL2cHkiIikwBBGRnvR04NdfZXqhJy4u+/TBypU1usDj6alG/foaWFjo77NgQTp8fa0gCKJeEBIEUXe5nFOCiEgiDEFEZi42Vr+X59dfZcjI0O+5UShEuLn9F3qaNFGjUqXXD2P5+KgQEZH27zpB/91mxYoiFixIh4+PqtAfDxFRXjEEEZkRlQq4cuW/Xp7oaDn++Sd7L4+jowZNmqjh6akNPu7ualhb5+8+fXxUePddVY4rRhMRSYkhiMiIaU83IUNyMmBnJ4Onp8ag8JCYCERHa8POhQty/PyzHM+f6/fyCIKIunX1h7aqVxchFOJBW3I54O3NuT9EZFwYgoiMVPbTTVijUiVNrsNIGg3w999Zh6hr///77+yJyd5eROPG/wWeRo3UKFWqiB8MEZERYggiMkK5nW7iwQMBvr5WiIhIQ9u2Kvz883/DWtHRcjx9mr37plYt/V4eFxcNZFwmlYiIIYjI2LzqdBPaI6xE+PtbQaVCtkPPra31D1Nv3FiDcuW4Dg8RUU4YgoiMgEYDJCQIePhQwOnTcr0zrmcnIDNT+1PVqlkTmLX/6tXLfpg6ERHljCGISiTthGLpj0YSReDJE+DhQxkePhQQGyvoftb+LkNsrHZ7ZqZhM5GDg9MwdGhm0RRORGQGGIKoxMk+oRivnFCcH6IIJCVlDzfa///7OTZWQHp63sONo6MGdnYibt16fWKrXVtTkIdARGT2GIIKgbH0OhSGgh6SLbW8TCh+XRBKToYuyLzcY/NiwElNzXu4KVtWAycnEc7OWf80qFDhv5+dnUWULy9CqdS2QePGtjzdBBFRETOJEKTRaBAaGorIyEg8e/YMnp6emD17NqpWrSp1acXS61BcDD0k29i8bkKxIIiYNs0SZcqIiI/XDzQv/pySkvdwU6ZMzoFGG3i0P1eoIMLSMu+PQy7n6SaIiIqDIIov/81sfEJDQ7F9+3YEBwfD2dkZS5Yswd27d3H48GEolUqDb0+t1iAhIaXAden3OmT/ospLr4OxMMbHIopAWhqQmgqkpgp4/lxAairw/LmA58+ztmn/T00Frl6VYedOw18POSlVKnugyerJefH3/K6inBclKWCXJAqFDA4OtkhMTIFKxSFJqbE9jEtRtkfZsraQywt3fQ+jD0EZGRnw8vLCxIkT0bdvXwBAUlISWrVqhaCgIPj4+Bh8m4URgrKGLLTnQ8p9yOLixRSj/4s9v48lMxN6YeTFkJLX4KK/b/bbymk4qKAqVNDgzTez99hof9f26tjZFfrd5otaDVy4oEBysjXs7FLh6aky+tdTSccvXePC9jAuphaCjH447M8//0RKSgqaN2+u22Zvb4969erhwoUL+QpBgLahCiIqSvbKw5hFUcD9+wIGD7ZGxYriv9tef7uv26egl+e0T2yskKfH4uFhCwBISdEGFJWq8ANKbpRKETY22nVwbGwAGxttL8yLPyclASdPvv4lHR6ejpYtc3tz5hwEpaJQAG3aAPb22senVnOVQ6llfQgX9ocx5Q/bw7iYWnsYfQh6+PAhAKBixYp62ytUqKC7zFAymQAHB9sC1ZWcnLf9Tpww+qc4zx4+zPlFLZMBtrbaQJL1/4s/F2Rb1j+FIiuY5B5Q1GqgenXg3r2cw6AgAFWqAO+9Z22SvSn29kU49kYGY3sYF7aHcTGV9jD6b+jU1FQAyDb3x9LSEk+fPs3XbWo0IpKSnheoLjs7GYDXN3Lfvpl4443s38h5PTllcex365aAbdtev8JecHA6mjfXwNpa2/Nia6v9X6nM+/0bSq0Gnj3L+/5BQXIMHmwJQUCuE4qTkkzrqCq5XAZ7e2skJaVCrWZ3v9TYHsaF7WFcirI97O2tzW84zMrKCoB2blDWzwCQnp4O6wLMSi3oWKWnpwaVKmleexjzsmVpRt/roFYD//uf/LWPZdCgjBwfi9qIMsW772oQESH+O6H4v8dSsaKIBQvS8e67KqhMdE6xWq3hnAcjwvYwLmwP42Iq7WH0g3ZZw2BxcXF62+Pi4uDk5CRFSQD+O4wZ+K+XIYupHcZckh4LAPj4qHDxYgoOHHiOdetSceDAc1y8mMIjqoiISI/Rh6A6derAzs4OP/30k25bUlISrly5Ak9PTwkr037ZRkSk6SY+Z6lYUTSpw+OBkvVYAG2w8/ZWo0cPFby9TXfxSiIiKjpGPxymVCrRv39/LF26FGXLlkXlypWxZMkSODs7o2PHjlKXBx8fFd59V1UiVozOeiw8JJuIiMyB0YcgABg9ejRUKhVmzpyJtLQ0eHp6IiIiAhZGcrrsrF6HkkAuB1q21MDBAUhM1Jjs/BkiIqLXMfrFEotCYa0YXVJx8THjwvYwLmwP48L2MC6mtlii0c8JIiIiIioKDEFERERklhiCiIiIyCwxBBEREZFZYggiIiIis8QQRERERGaJIYiIiIjMEkMQERERmSWzXCxRFEVoNGb3sA0il8ugVnPhMWPB9jAubA/jwvYwLkXVHjKZAEEQCvU2zTIEEREREXE4jIiIiMwSQxARERGZJYYgIiIiMksMQURERGSWGIKIiIjILDEEERERkVliCCIiIiKzxBBEREREZokhiIiIiMwSQxARERGZJYYgIiIiMksMQURERGSWGIKIiIjILDEEkc6TJ08we/ZstG7dGo0aNcLHH3+M6OhoqcsiADExMfDw8MD+/fulLsWsHTx4EO+99x5cXV3RpUsXHDt2TOqSzJpKpcKqVavQrl07eHh4oF+/frh8+bLUZZml9evXY8CAAXrbrl69iv79+6Nhw4Zo3749tm7dKlF1uWMIIp3x48fj0qVLWL58Ofbt24e6devC19cXN2/elLo0s5aZmYmJEyfi+fPnUpdi1g4dOoQZM2agX79+OHr0KHx8fHTvGZLG2rVrERkZiU8//RQHDx5EjRo14Ofnh7i4OKlLMys7duzAypUr9bYlJiZiyJAhqFatGvbt24fAwEAsXboU+/btk6bIXDAEEQDg9u3bOHv2LObOnYsmTZqgRo0amDVrFipUqIDDhw9LXZ5ZCwkJgZ2dndRlmDVRFLFq1SoMHDgQ/fr1Q7Vq1TBixAi0aNEC58+fl7o8s3Xq1Cn4+PigZcuWeOONNzB16lQ8e/aMvUHFJDY2FsOHD8fSpUtRvXp1vcv27NkDCwsLzJ8/H7Vq1ULPnj0xePBgbNiwQZpic8EQRAAABwcHbNiwAa6urrptgiBAEAQkJSVJWJl5u3DhAnbv3o3g4GCpSzFrMTExuHfvHt5//3297REREfD395eoKipXrhxOnz6Nu3fvQq1WY/fu3VAqlahTp47UpZmFP/74AxYWFvjyyy/h7u6ud1l0dDSaNm0KhUKh2+bl5YVbt27h0aNHxV1qrhiCCABgb2+PNm3aQKlU6radOHECt2/fRqtWrSSszHwlJSVh8uTJmDlzJipWrCh1OWYtJiYGAPD8+XP4+vqiefPm6N27N7755huJKzNvM2bMgIWFBd5++224urpixYoVWL16NapVqyZ1aWahffv2CAkJQdWqVbNd9vDhQzg7O+ttq1ChAgDgwYMHxVJfXjAEUY5+/vlnTJs2DR07dkTbtm2lLscszZ07Fx4eHtl6H6j4JScnAwCmTJkCHx8fbNq0Cd7e3ggICMC5c+ckrs58Xb9+HaVKlUJYWBh2796NHj16YOLEibh69arUpZm9tLQ0vT+qAcDS0hIAkJ6eLkVJOVK8fhcyN6dOncLEiRPRqFEjLF26VOpyzNLBgwcRHR3N+VhGwsLCAgDg6+uL7t27AwDq1q2LK1euYPPmzWjevLmU5ZmlBw8eYMKECdiyZQuaNGkCAHB1dcX169cREhKCNWvWSFyhebOyskJGRobetqzwY2NjI0VJOWJPEOnZvn07Ro0ahXbt2mHdunW65E7Fa9++fXj8+DHatm0LDw8PeHh4AADmzJkDPz8/iaszP05OTgAAFxcXve1vvvkm7t69K0VJZu+XX35BZmam3jxGAHB3d8ft27clqoqyODs7ZztKL+v3rPeTMWBPEOns3LkTn376KQYMGIAZM2ZAEASpSzJbS5cuRVpamt62jh07YvTo0ejatatEVZmv+vXrw9bWFr/88ouu1wEArl27xvknEsmab/LXX3/Bzc1Nt/3atWvZjlSi4ufp6YkvvvgCarUacrkcABAVFYUaNWqgXLlyElf3H4YgAqCd+Llw4UK888478Pf315u9b2VlhVKlSklYnfnJ7S+lcuXKGdVfUebCysoKfn5+CAsLg5OTE9zc3HD06FGcPXsWW7Zskbo8s+Tm5obGjRtjypQpmDNnDpydnXHw4EGcO3cOu3btkro8s9ezZ0+Eh4djxowZ8PPzw6+//ootW7Zg3rx5UpemhyGIAGiPBMvMzMTJkydx8uRJvcu6d+/OQ7TJ7AUEBMDa2horVqxAbGwsatWqhZCQEDRr1kzq0sySTCbD2rVrsXLlSkybNg1Pnz6Fi4sLtmzZku1wbSp+5cqVQ3h4OIKCgtC9e3eUL18ekydP1s2pMxaCKIqi1EUQERERFTdOjCYiIiKzxBBEREREZokhiIiIiMwSQxARERGZJYYgIiIiMksMQURERGSWGIKIiIjILDEEERERkVniitFEVGyuXbuGtWvX4vz583j69CnKlCmDJk2aYPjw4ahTpw4AYMCAAQCAbdu2SVkqEZkBrhhNRMXi77//xocffoiGDRviww8/RLly5fDw4UNs374df/75J7Zu3YqGDRvi+vXrALRnaCciKkoMQURULKZPn46oqCh8/fXXUCj+64R+/vw5OnfujDp16mDDhg0SVkhE5obDYURULB49egRRFKHRaPS229jYYPr06UhNTQWQfTgsOTkZixcvxsmTJ5GWloa2bdvC3d0dixYtwl9//aW7To0aNeDs7Ixdu3YhKSkJTZs2xaJFi/Dtt99i3bp1ePToEdzd3bFgwQJUqVIFAKBWqxEREYEvv/wS//zzD2QyGerUqYOxY8fCy8sLAJCWlobg4GB88803SEhIQJUqVdC7d2/4+voWy/NGREWHIYiIikXbtm3x7bffok+fPujZsye8vLxQs2ZNCIKAzp0753q9gIAAXL16FePGjUOlSpWwc+dOLFu2LNt+R44cQf369REUFISHDx9i/vz56N+/PywtLTFlyhSkpqZi9uzZmD9/vq7HaenSpdi1axcmTJiA2rVrIzY2FmFhYRgzZgzOnDkDa2trLFy4ED/88AOmTJkCR0dHfPfdd1i8eDHKlCmDnj17FtnzRURFjyGIiIpF3759ER8fj4iICMyfPx8A4ODggJYtW2LgwIFwc3PLdp1z587hp59+QkhICDp27AgAaN26NXx8fHDjxg29fVUqFUJDQ1G6dGkAwNdff43vv/8ep06dQtWqVQEAly9fxqFDh3TXiYuLw7hx43S9TwBgaWmJUaNG4a+//kLDhg1x/vx5eHt7o0uXLgCAZs2awcbGBuXKlSvEZ4eIpMAQRETFZsyYMRg8eDC+//57XcA5fPgwjhw5gunTp2PgwIF6+0dFRcHCwgIdOnTQbZPJZHjvvfcQEhKit2+tWrV0AQgAHB0d4eDgoAtAAFCmTBk8e/ZM93tWj1JCQgJu3ryJ27dv4/Tp0wCAjIwMANrQ88UXX+Dhw4do06YN2rRpg8DAwEJ6RohISlwniIiKVenSpeHj44OgoCCcOnUKBw4cQK1atbBkyRIkJibq7ZuYmIgyZcpAJtP/qMqpF8bOzi7bNhsbm1fW8ttvv6FXr15o3rw5/Pz8sGvXLt19ZR0zMmPGDIwdOxZ3797Fp59+ig4dOqBPnz74888/DXrcRGR8GIKIqMjFxsaiZcuWiIyMzHZZvXr1MG7cOGRkZODOnTt6lzk5OSExMTHbZOrHjx8XuKbk5GT4+fnBxsYGR48exc8//4y9e/dmm+ejVCoxYsQIHDt2DKdPn8bs2bNx584dTJgwocA1EJG0GIKIqMg5OjpCoVBg586dSE9Pz3b5zZs3YWlpiTfeeENve9OmTaFSqfDNN9/otomiiFOnThW4pps3b+LJkycYOHAg3nzzTV0P0HfffQcA0Gg0SEtLQ6dOnbBp0yYAQKVKldCvXz906dIF9+/fL3ANRCQtzgkioiInl8sxd+5cBAYGomfPnujXrx9q1aqF1NRUnD17Fjt27MCYMWP05vQAgKenJ7y9vTFjxgw8evQIlSpVwt69e/HXX39BEIQC1VSjRg3Y2dlh3bp1UCgUUCgUOHHiBPbu3QsASE1NhZWVFerXr4/Q0FBYWFigdu3aiImJwYEDB9CpU6cC3T8RSY8hiIiKRdu2bbFnzx5ERERg3bp1SEhIgFKpRL169bBixQrd0V8vW7FiBYKDg7Fs2TKoVCq8/fbb+Pjjj3Hw4MEC1VOqVCmsWbMGixcvxpgxY2Bra4u6deti+/bt+OSTTxAdHY327dtj/vz5WLlyJTZt2oT4+HiUK1cOvXr1wpgxYwp0/0QkPa4YTURG6969e7h8+TLefvttWFlZ6baPHj0ad+7cwYEDBySsjohMHXuCiMhoyWQyTJ06FW+//TZ69eoFuVyO77//Hl9//TUWLVokdXlEZOLYE0RERi0qKgphYWG4evUqVCoVatWqhSFDhsDHx0fq0ojIxDEEERERkVniIfJERERklhiCiIiIyCwxBBEREZFZYggiIiIis8QQRERERGaJIYiIiIjMEkMQERERmSWGICIiIjJL/weihZNBg8tWxAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "##### Run if you want to calculate the epsilon error on N=100 linear functions of type ax+b with a,b in N(0,1) it may take some time for running\n",
    "scores = []\n",
    "sigmas = []\n",
    "for sigma in range(1, 11):\n",
    "    mean_scores = 0\n",
    "    torch.manual_seed(sigma)\n",
    "    values = torch.randn(200)*sigma\n",
    "    coeff_a = values[:100]\n",
    "    coeff_b = values[100:]\n",
    "\n",
    "    for i in range(len(coeff_a)):\n",
    "        z = coeff_a[i] * xs + coeff_b[i] # torch.Size([64, 40, 1])\n",
    "        z = z[:,:,0] # torch.Size([64, 40])\n",
    "        \n",
    "        #z = z[:,1:,0]\n",
    "        \n",
    "        with torch.no_grad():\n",
    "            p = model(xs,z)\n",
    "        #print(z.shape)\n",
    "        #print(\"z\", z)\n",
    "        #print(\"p\", p)\n",
    "        #p = 0*p\n",
    "        diff = z[:,2:] - p[:,2:]\n",
    "        \n",
    "        #print(\"dif\", diff)\n",
    "        #mi = torch.norm(diff, p=2, dim=1) # Norm 2\n",
    "        #print(\"oldmi\", mi)\n",
    "        #mi = torch.mean(mi)\n",
    "        mi = diff.square().mean()\n",
    "        #print(\"mi\", mi)\n",
    "        #mi = torch.norm(z-p, p=2)\n",
    "        mean_scores = mean_scores + (1/len(coeff_a))* mi\n",
    "    \n",
    "    scores.append(mean_scores)\n",
    "    sigmas.append(sigma)\n",
    "        \n",
    "\n",
    "scores_np = [sss.item() for sss in scores]\n",
    "print(\"scores\",scores_np)\n",
    "print(\"scores vir\", [round(score, 2) for score in scores_np])\n",
    "print(\"sigmas\",sigmas)\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(sigmas, scores_np, marker='o', color='blue', label='Scores en fonction de sigmas')\n",
    "\n",
    "# Ajouter des labels et un titre\n",
    "plt.xlabel('Sigmas')\n",
    "plt.ylabel('Error scores')\n",
    "plt.title(f'Evolution of errors over distributions N(0,sigma) for model {n_layer}layers {n_ah}ah')    \n",
    "plt.savefig(f\"{directory}figures_scores/{run_id}_on_{task.max_dim}.png\")\n",
    "\n",
    "plt.show()"
   ]
  }
 ],
 "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.8.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
