{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "e0aac4f9",
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import numpy as np\n",
    "import re\n",
    "from BT import *\n",
    "from eigentrust import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "004c511e",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_path = '20250513_224000'\n",
    "data = []\n",
    "filepath = f'transcript/{data_path}/evaluations_cleaned.json'\n",
    "with open(filepath, 'r') as file:\n",
    "    data.extend(json.load(file))\n",
    "comparisons=[]\n",
    "for i, item in enumerate(data):\n",
    "    response = item['judge response']\n",
    "    eval1_response = item['eval1 response']\n",
    "    eval2_response = item['eval2 response']\n",
    "\n",
    "    if \"Error in \" in response or \"Error in \" in eval1_response or \"Error in \" in eval2_response:\n",
    "        print(f\"Error in {i}th API call\")\n",
    "        continue\n",
    "    m = re.search(r'<choice>(.)</choice>', response)\n",
    "    if m:\n",
    "        score = int(m.group(1))\n",
    "        comparisons.append([item['judge'], item['eval1'], item['eval2'], score])\n",
    "    else:\n",
    "        print(f\"No <choice>…</choice> match found in the {i}th judge response\")\n",
    "\n",
    "func = {'(0, 0)': 0,\n",
    "        '(0, 1)': 1,\n",
    "        '(0, 2)': 2,\n",
    "        '(0, 3)': 3,\n",
    "        '(0, 4)': 4,\n",
    "        '(1, 0)': 5,\n",
    "        '(1, 1)': 6,\n",
    "        '(1, 2)': 7,\n",
    "        '(1, 3)': 8,\n",
    "        '(1, 4)': 9,\n",
    "        '(2, 0)': 10,\n",
    "        '(2, 1)': 11,\n",
    "        '(2, 2)': 12,\n",
    "        '(2, 3)': 13,\n",
    "        '(2, 4)': 14,\n",
    "        '(3, 0)': 15,\n",
    "        '(3, 1)': 16,\n",
    "        '(3, 2)': 17,\n",
    "        '(3, 3)': 18,\n",
    "        '(3, 4)': 19,\n",
    "        '(4, 0)': 20,\n",
    "        '(4, 1)': 21,\n",
    "        '(4, 2)': 22,\n",
    "        '(4, 3)': 23,\n",
    "        '(4, 4)': 24,}\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "7ba01c6c",
   "metadata": {},
   "outputs": [],
   "source": [
    "mapped_comparisons = []\n",
    "for item in comparisons:\n",
    "    l = [func[x] for x in item[:3]]\n",
    "    l.append(item[3])\n",
    "    mapped_comparisons.append(l)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "a071a31f",
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.model_selection import train_test_split\n",
    "train_comps, test_comps = train_test_split(\n",
    "    mapped_comparisons,\n",
    "    test_size=0.2,\n",
    "    random_state=42,\n",
    "    shuffle=True\n",
    ")\n",
    "train_loader = DataLoader(PairwiseDataset(train_comps), batch_size=32, shuffle=True)\n",
    "test_loader  = DataLoader(PairwiseDataset(test_comps),  batch_size=32, shuffle=False)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "79e80518",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Now training\n",
      "Epoch  10, Loss = 0.6844\n",
      "Epoch  20, Loss = 0.6402\n",
      "Epoch  30, Loss = 0.5978\n",
      "Epoch  40, Loss = 0.5761\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[5], line 11\u001b[0m\n\u001b[1;32m      8\u001b[0m model \u001b[38;5;241m=\u001b[39m VectorBT(num_models, d)\n\u001b[1;32m     10\u001b[0m \u001b[38;5;28mprint\u001b[39m(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mNow training\u001b[39m\u001b[38;5;124m'\u001b[39m)\n\u001b[0;32m---> 11\u001b[0m loss_history \u001b[38;5;241m=\u001b[39m \u001b[43mtrain_vector_bt\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m     12\u001b[0m \u001b[43m    \u001b[49m\u001b[43mmodel\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\n\u001b[1;32m     13\u001b[0m \u001b[43m    \u001b[49m\u001b[43mtrain_loader\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m     14\u001b[0m \u001b[43m    \u001b[49m\u001b[43mlr\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mlr\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\n\u001b[1;32m     15\u001b[0m \u001b[43m    \u001b[49m\u001b[43mweight_decay\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mweight_decay\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m     16\u001b[0m \u001b[43m    \u001b[49m\u001b[43mmax_epochs\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mmax_epochs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\n\u001b[1;32m     17\u001b[0m \u001b[43m    \u001b[49m\u001b[43mdevice\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mmps\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m     18\u001b[0m \u001b[43m)\u001b[49m\n\u001b[1;32m     20\u001b[0m avg_train_loss \u001b[38;5;241m=\u001b[39m loss_history[\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m]\n\u001b[1;32m     21\u001b[0m \u001b[38;5;28mprint\u001b[39m(\u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mFinal average TRAIN loss = \u001b[39m\u001b[38;5;132;01m{\u001b[39;00mavg_train_loss\u001b[38;5;132;01m:\u001b[39;00m\u001b[38;5;124m.4f\u001b[39m\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m\"\u001b[39m)\n",
      "File \u001b[0;32m~/Documents/GitHub/EigenBench/BT.py:66\u001b[0m, in \u001b[0;36mtrain_vector_bt\u001b[0;34m(model, dataloader, lr, weight_decay, max_epochs, device, save_path)\u001b[0m\n\u001b[1;32m     63\u001b[0m total_loss \u001b[38;5;241m=\u001b[39m \u001b[38;5;241m0.0\u001b[39m\n\u001b[1;32m     64\u001b[0m model\u001b[38;5;241m.\u001b[39mtrain()\n\u001b[0;32m---> 66\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m i_idx, j_idx, k_idx, r \u001b[38;5;129;01min\u001b[39;00m dataloader:\n\u001b[1;32m     67\u001b[0m     i_idx \u001b[38;5;241m=\u001b[39m i_idx\u001b[38;5;241m.\u001b[39mto(device)\n\u001b[1;32m     68\u001b[0m     j_idx \u001b[38;5;241m=\u001b[39m j_idx\u001b[38;5;241m.\u001b[39mto(device)\n",
      "File \u001b[0;32m~/miniforge3/envs/tftest/lib/python3.10/site-packages/torch/utils/data/dataloader.py:633\u001b[0m, in \u001b[0;36m_BaseDataLoaderIter.__next__\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    630\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_sampler_iter \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m    631\u001b[0m     \u001b[38;5;66;03m# TODO(https://github.com/pytorch/pytorch/issues/76750)\u001b[39;00m\n\u001b[1;32m    632\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_reset()  \u001b[38;5;66;03m# type: ignore[call-arg]\u001b[39;00m\n\u001b[0;32m--> 633\u001b[0m data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_next_data\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    634\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_num_yielded \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;241m1\u001b[39m\n\u001b[1;32m    635\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_dataset_kind \u001b[38;5;241m==\u001b[39m _DatasetKind\u001b[38;5;241m.\u001b[39mIterable \u001b[38;5;129;01mand\u001b[39;00m \\\n\u001b[1;32m    636\u001b[0m         \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_IterableDataset_len_called \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m \u001b[38;5;129;01mand\u001b[39;00m \\\n\u001b[1;32m    637\u001b[0m         \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_num_yielded \u001b[38;5;241m>\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_IterableDataset_len_called:\n",
      "File \u001b[0;32m~/miniforge3/envs/tftest/lib/python3.10/site-packages/torch/utils/data/dataloader.py:677\u001b[0m, in \u001b[0;36m_SingleProcessDataLoaderIter._next_data\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    675\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m_next_data\u001b[39m(\u001b[38;5;28mself\u001b[39m):\n\u001b[1;32m    676\u001b[0m     index \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_next_index()  \u001b[38;5;66;03m# may raise StopIteration\u001b[39;00m\n\u001b[0;32m--> 677\u001b[0m     data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_dataset_fetcher\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mfetch\u001b[49m\u001b[43m(\u001b[49m\u001b[43mindex\u001b[49m\u001b[43m)\u001b[49m  \u001b[38;5;66;03m# may raise StopIteration\u001b[39;00m\n\u001b[1;32m    678\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_pin_memory:\n\u001b[1;32m    679\u001b[0m         data \u001b[38;5;241m=\u001b[39m _utils\u001b[38;5;241m.\u001b[39mpin_memory\u001b[38;5;241m.\u001b[39mpin_memory(data, \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_pin_memory_device)\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "num_models = 25\n",
    "d = 1\n",
    "\n",
    "lr = 1e-4\n",
    "weight_decay = 0\n",
    "max_epochs = 200\n",
    "\n",
    "model = VectorBT(num_models, d)\n",
    "\n",
    "print('Now training')\n",
    "loss_history = train_vector_bt(\n",
    "    model, \n",
    "    train_loader,\n",
    "    lr=lr, \n",
    "    weight_decay=weight_decay,\n",
    "    max_epochs=max_epochs, \n",
    "    device='mps',\n",
    ")\n",
    "\n",
    "avg_train_loss = loss_history[-1]\n",
    "print(f\"Final average TRAIN loss = {avg_train_loss:.4f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "70b1991b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Now testing on holdout set for n=1\n",
      "Test  BCE Loss = 0.5626\n",
      "Now testing on holdout set for n=2\n",
      "Test  BCE Loss = 0.5472\n",
      "Now testing on holdout set for n=3\n",
      "Test  BCE Loss = 0.5415\n",
      "Now testing on holdout set for n=4\n",
      "Test  BCE Loss = 0.5419\n",
      "Now testing on holdout set for n=5\n",
      "Test  BCE Loss = 0.5431\n",
      "Now testing on holdout set for n=6\n",
      "Test  BCE Loss = 0.5445\n",
      "Now testing on holdout set for n=7\n",
      "Test  BCE Loss = 0.5486\n",
      "Now testing on holdout set for n=8\n",
      "Test  BCE Loss = 0.5496\n",
      "Now testing on holdout set for n=9\n",
      "Test  BCE Loss = 0.5495\n",
      "Now testing on holdout set for n=10\n",
      "Test  BCE Loss = 0.5510\n",
      "Now testing on holdout set for n=11\n",
      "Test  BCE Loss = 0.5522\n",
      "Now testing on holdout set for n=12\n",
      "Test  BCE Loss = 0.5525\n",
      "Now testing on holdout set for n=13\n",
      "Test  BCE Loss = 0.5537\n",
      "Now testing on holdout set for n=14\n",
      "Test  BCE Loss = 0.5543\n",
      "Now testing on holdout set for n=15\n",
      "Test  BCE Loss = 0.5549\n",
      "Now testing on holdout set for n=16\n",
      "Test  BCE Loss = 0.5558\n",
      "Now testing on holdout set for n=17\n",
      "Test  BCE Loss = 0.5567\n",
      "Now testing on holdout set for n=18\n",
      "Test  BCE Loss = 0.5569\n",
      "Now testing on holdout set for n=19\n",
      "Test  BCE Loss = 0.5569\n",
      "Now testing on holdout set for n=20\n",
      "Test  BCE Loss = 0.5567\n",
      "Now testing on holdout set for n=21\n",
      "Test  BCE Loss = 0.5570\n",
      "Now testing on holdout set for n=22\n",
      "Test  BCE Loss = 0.5572\n",
      "Now testing on holdout set for n=23\n",
      "Test  BCE Loss = 0.5571\n",
      "Now testing on holdout set for n=24\n",
      "Test  BCE Loss = 0.5570\n",
      "Now testing on holdout set for n=25\n",
      "Test  BCE Loss = 0.5574\n",
      "Now testing on holdout set for n=26\n",
      "Test  BCE Loss = 0.5574\n",
      "Now testing on holdout set for n=27\n",
      "Test  BCE Loss = 0.5572\n",
      "Now testing on holdout set for n=28\n",
      "Test  BCE Loss = 0.5573\n",
      "Now testing on holdout set for n=29\n",
      "Test  BCE Loss = 0.5572\n"
     ]
    }
   ],
   "source": [
    "test_losses=[]\n",
    "train_losses=[]\n",
    "for n in range(1,30):\n",
    "    filepath = f'figures/dimensionality/models_mn_by_d/'\n",
    "    with open(filepath+f'loss_history_{n}.json', 'r') as file:\n",
    "        loss_history = json.load(file)\n",
    "\n",
    "    model_path = filepath+f'model__{n}.pth'\n",
    "    num_models=25\n",
    "    d=n\n",
    "    device='mps'\n",
    "    \n",
    "    model = load_vector_bt(model_path, num_models, d, device)\n",
    "\n",
    "    print(f'Now testing on holdout set for n={n}')\n",
    "\n",
    "    model.eval()\n",
    "    loss_fn = nn.BCELoss()\n",
    "    total_test_loss = 0.0\n",
    "\n",
    "    with torch.no_grad():\n",
    "        for i_idx, j_idx, k_idx, r in test_loader:\n",
    "            i_idx, j_idx, k_idx = i_idx.to(device), j_idx.to(device), k_idx.to(device)\n",
    "            r = (2 - r.to(device))             # {1,2}→{1,0}\n",
    "            preds = model(i_idx, j_idx, k_idx)\n",
    "            loss  = loss_fn(preds, r)\n",
    "            total_test_loss += loss.item() * r.size(0)\n",
    "\n",
    "    avg_test_loss = total_test_loss / len(test_loader.dataset)\n",
    "    print(f\"Test  BCE Loss = {avg_test_loss:.4f}\")\n",
    "\n",
    "    test_losses.append([n, avg_test_loss])\n",
    "    train_losses.append([n, min(loss_history)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6ac3fe7b",
   "metadata": {},
   "outputs": [],
   "source": [
    "filepath = f'figures/dimensionality/models_mn_by_d/'\n",
    "with open(filepath+f'train_losses.json', 'w') as file:\n",
    "    json.dump(train_losses, file, indent=4)\n",
    "with open(filepath+f'test_losses.json', 'w') as file:\n",
    "    json.dump(test_losses,file,indent=4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "d1cb577c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAJOCAYAAACqS2TfAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAADAT0lEQVR4nOzdeXiU1dnH8e/MZCUrZA+EkLAHBGQVEWWJAmosWBERlcVqi1gXatW2bwW1RW3rUpWCtSoqKijuFSObQBGUXcVAgBD27IGsZJt53j+GBGISMlknCb/Pdc2VzJnznOeeZ2YC95zNZBiGgYiIiIiIiIg0OrOzAxARERERERFpq5R0i4iIiIiIiDQRJd0iIiIiIiIiTURJt4iIiIiIiEgTUdItIiIiIiIi0kSUdIuIiIiIiIg0ESXdIiIiIiIiIk1ESbeIiIiIiIhIE1HSLSIiIiIiItJElHSLiIiIiIiINBEl3SIiIiIiIiJNREm3iEgNlixZgslk4vDhw84ORcQh27Zt4/LLL8fLywuTycTu3budHVIVreVz1RKv5fz58zGZTGRmZjbbuepTr7W8xuVaW7w1aYnPwzAMvL29eeSRR5wdiohTKekWkVbDZDI5dFu/fr2zQ20RnHW9Nm/ezPz58zl9+rRD9cv/o7h9+/ZGjeNiU1payuTJk8nOzub555/n7bffJjIy0mnx1PV90JLU5VqWv39run377bfNHP3F7eevh4eHB+Hh4YwbN44XX3yRvLw8Z4d4UTl8+DAFBQVccsklzg5FxKlcnB2AiIij3n777Ur333rrLVavXl2lvHfv3o1yvttvv51bbrkFd3f3RmmvuTX39Sq3efNmHn/8cWbMmIG/v3+jti01S0pK4siRI7z66qv86le/cnY4Nb4PWsPnqj7X8oknniAqKqpKebdu3Ro7vBavJbzG5a9HaWkpqamprF+/ngceeIDnnnuOzz77jH79+rWoeBtDS3weP/30E4CSbrnoKekWkVbjtttuq3T/22+/ZfXq1VXKa1JQUICXl5fD57NYLFgsljrF2JI09HpJ65Keng7Q4r/oaA2fq/pcywkTJjB48OAmiqh1aQmv8c9fjz/84Q+sW7eO66+/nhtuuIG9e/fi6ekJtIx4G0NLfB4//fQTLi4ujf7lrkhro+HlItImlc8zTEhI4NZbb6V9+/ZcccUVHDlyhHvuuYeePXvi6elJQEAAkydPrnYO3M/nx5W3efDgwYreOz8/P2bOnElhYeEF41mxYgUmk4kNGzZUeeyVV17BZDKxZ88eAPLy8njggQfo0qUL7u7uBAcHc/XVV7Nz584GX5cLOXHiBLNmzSIkJAR3d3f69OnD66+/XqXeheKbP38+v//97wGIioqqGOLZGHMMd+3axYQJE/D19cXb25uxY8dWGbrryLWr7/V19L3T1O1XZ8aMGVx11VUATJ48GZPJxKhRoyoe69KlS5Vjfj4Xt67v7xMnTnDnnXcSHh6Ou7s7UVFRzJ49m5KSkgu+D2qad+rI69uQz6Cj57nQtWyo8vj379/Pbbfdhp+fH0FBQfz5z3/GMAyOHTvGL37xC3x9fQkNDeXZZ5+ttp3MzExuvvlmfH19CQgI4P7776eoqKhSHUc/zwCbNm1iyJAheHh40LVrV1555ZUG1Wvo387169czePDgSudxdI75hYwZM4Y///nPHDlyhKVLl9Yab0NeJ0evv6PXxpG/K9V9thz5XNUljgtZvnw5AwYMwMPDg0GDBrF161Z++uknevTogZubm0NtiLRV6ukWkTZt8uTJdO/enQULFmAYBtu2bWPz5s3ccsstdOrUicOHD7No0SJGjRpFQkIC7dq1q7XNm2++maioKJ566il27tzJf/7zH4KDg3nmmWdqPOa6667D29ub999/v+I/9OWWL19Onz596Nu3LwC/+c1vWLFiBffeey8xMTFkZWWxadMm9u7dy8CBAxt2QWqQlpbGZZddhslk4t577yUoKIgvv/ySO++8k9zcXB544IGKuheK78Ybb2T//v289957PP/88wQGBgIQFBTUoPh++uknRo4cia+vLw8//DCurq688sorjBo1ig0bNjBs2LBaYyu/dvW9vo6+d5q6/er8+te/pmPHjixYsID77ruPIUOGEBISUp9L7dD7++TJkwwdOpTTp09z991306tXL06cOMGKFSsoLCys8/vA0de3LjHW9zz1vZY5OTlVFjgzmUwEBARUqTtlyhR69+7N008/zRdffMFf/vIXOnTowCuvvMKYMWN45plneOedd3jooYcYMmQIV155ZZXn36VLF5566im+/fZbXnzxRU6dOsVbb70F1O3z/OOPP3LNNdcQFBTE/PnzKSsrY968eVWes6P1LsSR123Xrl2MHz+esLAwHn/8caxWK0888USD/4aUu/322/njH//IqlWruOuuuy5Yt76vU12uv6PXpj5/V+r6uXIkjpo8//zzzJ07l4kTJ3LPPffwww8/cP311+Pv799k/26JtCqGiEgrNWfOHKOmP2Pz5s0zAGPq1KmVygsLC6vU3bJliwEYb731VqXyN954wwCM5OTkSm3OmjWrUr1JkyYZAQEBtcY7depUIzg42CgrK6soS0lJMcxms/HEE09UlPn5+Rlz5syptb26utD1uvPOO42wsDAjMzOzUvktt9xi+Pn5VbputcX397//vdJ1q035dd62bVuNdSZOnGi4ubkZSUlJFWUnT540fHx8jCuvvNLh2BytUx1H3ztN3X5Nvv76awMwPvjgg0rl06dPNyIjI6vUL38///y+I+/vO+64wzCbzdW+ZjabzTCMmt8HP/9cGYbjr29DP4OOnqema1md8udT3c3d3b1S3fL477777oqysrIyo1OnTobJZDKefvrpivJTp04Znp6exvTp06scf8MNN1Rq95577jEA4/vvvzcMo26f54kTJxoeHh7GkSNHKsoSEhIMi8VS6f3haL3zr0l9/nbGxcUZ7dq1M06cOFFRduDAAcPFxaXGv1/VnftCf0/8/PyMSy+9tNZ46/s61eX6O3ptHPm78vPn4ej7vS5xVGfXrl2Gi4uL8cc//rFS+ezZsw3AePLJJy94vMjFQMPLRaRN+81vflPpfvkcPrCvUJyVlUW3bt3w9/d3ePj2z9scOXIkWVlZ5ObmXvC4KVOmkJ6eXmm18BUrVmCz2ZgyZUpFmb+/P9999x0nT550KJ6GMgyDDz/8kLi4OAzDIDMzs+I2btw4cnJyKl2b5o7ParWyatUqJk6cSHR0dEV5WFgYt956K5s2baq49o7EVt/4HX3vNHX7Ta2297fNZuOTTz4hLi6u2jnMdR0CXJfX19EYG+s8dbFw4UJWr15d6fbll19WW/f8xdksFguDBw/GMAzuvPPOinJ/f3969uzJoUOHqhw/Z86cSvd/+9vfArBy5co6fZ6tVitfffUVEydOpHPnzhXt9e7dm3HjxlXcd7RebWp73axWK2vWrGHixImEh4dX1OvWrRsTJkxw+Dy18fb2dmgV8/q8TnX9e1qutmtT178r9X2/1+ez9de//hU/Pz/+9Kc/VSovH9WlRdRENKdbRNq4n68mfObMGR577DEi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IygoyHB3dzeio6ONOXPmGMXFxRV1qnsf1NReba9vfWKsjiPnaawtwwDjjTfeqDX+6dOnG15eXlXavuqqq4w+ffpUOT4hIcG46aabDB8fH6N9+/bGvffea5w5c6bSsY58nstt2LDBGDRokOHm5mZER0cbixcvrvL+qEu9hv7tXLt2rXHppZcabm5uRteuXY3//Oc/xu9+9zvDw8OjSuw/9/PXw83NzQgNDTWuvvpq45///KeRm5tb4zG1xevo62QYjl9/R66No39XqruejrzfHY2jJikpKcYNN9xg+Pj4GAEBAcaUKVOMd955xwCMtWvX1nicyMXEZBitZNUREREREbkoTZw4kZ9++qnaeeUiIi2d5nSLiIiISItx5syZSvcPHDjAypUrGTVqlHMCEhFpIPV0twKTJk1i/fr1jB07lhUrVjg7HBEREZEmExYWxowZM4iOjubIkSMsWrSI4uJidu3aVe1e4SIiLZ2S7lZg/fr15OXl8eabbyrpFhERkTZt5syZfP3116SmpuLu7s7w4cNZsGABAwcOdHZoIiL1otXLW4FRo0axfv16Z4chIiIi0uTeeOMNZ4cgItKonD6ne/78+ZhMpkq3Xr161XrciRMnuO222wgICMDT05NLLrmk0n6h9W23LjZu3EhcXBzh4eGYTCY++eSTaustXLiQLl264OHhwbBhw9i6dWujxiEiIiIiIiItU4vo6e7Tpw9r1qypuO/icuGwTp06xYgRIxg9ejRffvklQUFBHDhwgPbt29e73W+++YahQ4fi6upaqTwhIYGAgABCQkKqHFNQUED//v2ZNWsWN954Y7XtLl++nLlz57J48WKGDRvGCy+8wLhx40hMTCQ4OBiAAQMGUFZWVuXYVatWER4eXvOFEBERERERkRatRSTdLi4uhIaGOlz/mWeeISIiotLwo6ioqHq3a7PZmDNnDt27d2fZsmVYLBYAEhMTGTNmDHPnzuXhhx+uctyECROYMGHCBdt+7rnnuOuuu5g5cyYAixcv5osvvuD111/n0UcfBWD37t21xlgXNpuNkydP4uPjg8lkatS2RUREREREBAzDIC8vj/DwcMzmmgeRt4ik+8CBA4SHh+Ph4cHw4cN56qmn6Ny5c431P/vsM8aNG8fkyZPZsGEDHTt25J577uGuu+6qV7tms5mVK1dy5ZVXcscdd/D222+TnJzM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aaVGjRrFAw884OwwqujSpQsvvPCCs8NoMZR0S7OxmE0M7xpI9xAfDtrsi6mRkejcoEREREREamKzQvL/4McV9p82a5OebsaMGZhMJn7zm99UeWzOnDmYTCZmzJhRUfbRRx/x5JNP1vt8JpPpgrf58+fXq91t27Zx99131zsuaLlfKNSHi7MDkItPVKAXSenhjOAnyNzv7HBERERERKpK+AziH4Hcczvu4BsO45+BmBua7LQREREsW7aM559/Hk9PTwCKiop499136dy5c6W6HTo0bDHilJSUit+XL1/OY489RmLiuU4xb2/vit8Nw8BqteLiUnsKGRQU1KC42hr1dEuziw704uDZed1KukVERESkxUn4DN6/o3LCDZCbYi9P+KzJTj1w4EAiIiL46KOPKso++ugjOnfuzKWXXlqp7s97g7t06cKCBQuYNWsWPj4+dO7cmX//+981nis0NLTi5ufnh8lkqri/b98+fHx8+PLLLxk0aBDu7u5s2rSJpKQkfvGLXxASEoK3tzdDhgxhzZo1ldr9+fByk8nEf/7zHyZNmkS7du3o3r07n33WsGv44Ycf0qdPH9zd3enSpQvPPvtspcf/9a9/0b17dzw8PAgJCeGmm26qeGzFihVccskleHp6EhAQQGxsLAUFBQ2K50KUdEuziwryqlhMTUm3iIiIiDQ5w4CSAsduRbnw5cOAUV1D9h/xj9jrOdKeUV07FzZr1izeeOONivuvv/46M2fOdOjYZ599lsGDB7Nr1y7uueceZs+eXan3uq4effRRnn76afbu3Uu/fv3Iz8/n2muvZe3atezatYvx48cTFxfH0aNHL9jO448/zs0338wPP/zAtddey7Rp08jOzq5XTDt27ODmm2/mlltu4ccff2T+/Pn8+c9/ZsmSJQBs376d++67jyeeeILExETi4+O58sorAXvv/tSpU5k1axZ79+5l/fr13HjjjRj1eJ0cpeHl0uyiAr3PzenOToayEnBxc25QIiIiItJ2lRbCgvBGasyw94A/HeFY9T+eBDevOp3htttu4w9/+ANHjhwB4JtvvmHZsmWsX7++1mOvvfZa7rnnHgAeeeQRnn/+eb7++mt69uxZpxjKPfHEE1x99dUV9zt06ED//v0r7j/55JN8/PHHfPbZZ9x77701tjNjxgymTp0KwIIFC3jxxRfZunUr48ePr3NMzz33HGPHjuXPf/4zAD169CAhIYG///3vzJgxg6NHj+Ll5cX111+Pj48PkZGRFaMEUlJSKCsr48YbbyQyMhKASy65pM4x1IV6uqXZRQV4kUZ78gxPMKyQfcjZIYmIiIiItBhBQUFcd911LFmyhDfeeIPrrruOwMBAh47t169fxe/lw8XT09PrHcvgwYMr3c/Pz+ehhx6id+/e+Pv74+3tzd69e2vt6T4/Li8vL3x9fesd1969exkxYkSlshEjRnDgwAGsVitXX301kZGRREdHc/vtt/POO+9QWFgIQP/+/Rk7diyXXHIJkydP5tVXX+XUqVP1isNR6umWZufXzpUAL3eSSsMYYDoEmYkQ3MvZYYmIiIhIW+Xazt7j7Igjm+Gdm2qvN20FRF7u2LnrYdasWRU9xwsXLnT4OFdX10r3TSYTNputXjGAPUE+30MPPcTq1av5xz/+Qbdu3fD09OSmm26ipKSkWeO6EB8fH3bu3Mn69etZtWoVjz32GPPnz2fbtm34+/uzevVqNm/ezKpVq3jppZf405/+xHfffUdUVFSTxKOebnGKqEDN6xYRERGRZmIy2Yd4O3LrOsa+SjmmmhoD3472eo60Z6qpnQsbP348JSUllJaWMm7cuHo/9cb2zTffMGPGDCZNmsQll1xCaGgohw8fbtYYevfuzTfffFMlrh49emCxWABwcXEhNjaWv/3tb/zwww8cPnyYdevWAfaEf8SIETz++OPs2rULNzc3Pv744yaLVz3d4hRRgV4kHe8IFiBDSbeIiIiItBBmi31bsPfvwJ54n7/A1tkEevzT9npNyGKxsHfv3orfW4ru3bvz0UcfERcXh8lk4s9//nOT9VhnZGSwe/fuSmVhYWH87ne/Y8iQITz55JNMmTKFLVu28PLLL/Ovf/0LgP/+978cOnSIK6+8kvbt27Ny5UpsNhs9e/bku+++Y+3atVxzzTUEBwfz3XffkZGRQe/evZvkOYB6usVJooO81dMtIiIiIi1TzA1w81vgG1a53DfcXt6E+3RXOp2vL76+vs1yLkc999xztG/fnssvv5y4uDjGjRvHwIEDm+Rc7777Lpdeemml26uvvsrAgQN5//33WbZsGX379uWxxx7jiSeeYMaMGQD4+/vz0UcfMWbMGHr37s3ixYt577336NOnD76+vmzcuJFrr72WHj168H//9388++yzTJgwoUmeA4DJaMq10cUpcnNz8fPzIycnp8V9SMvF70nl7+98xlr334OrF/zxRL2H3oiIiIiInK+oqIjk5GSioqLw8PCof0M2q32Od34aeIfY53A3cQ+3tCwXei85mndpeLk4RXSQF0eMEEqx4FpaALknwK+Ts8MSERERETnHbIGokc6OQlo5DS8Xp+jcoR1WkwtHbCH2Ag0xFxERERGRNkhJtziFh6uFjv6e5+Z1azE1ERERERFpg5R0i9NEBXpxUIupiYiIiIhIG6akW5wmOtCLJJuSbhERERERabuUdIvT2Hu6O9rvKOkWERERkUbWVPtHy8WjMd5DWr1cnCYqyJtDxtm9D/PT4Mxp8PR3ZkgiIiIi0ga4ublhNps5efIkQUFBuLm5YdL2tFIHhmFQUlJCRkYGZrMZNze3erelpFucJjrQi3zakWp0INSUDZkHIGKIs8MSERERkVbObDYTFRVFSkoKJ0+edHY40oq1a9eOzp07YzbXf5C4km5xmnB/T9wsZg7awgi1ZENmopJuEREREWkUbm5udO7cmbKyMqxWq7PDkVbIYrHg4uLS4FESSrpbgUmTJrF+/XrGjh3LihUrnB1Oo7GYTUQGtONgdkeu4CfN6xYRERGRRmUymXB1dcXV1dXZochFTAuptQL3338/b731lrPDaBJRgV7aq1tERERERNosJd2twKhRo/Dx8XF2GE0iKkgrmIuIiIiISNvV4pPu+fPnYzKZKt169epV63EnTpzgtttuIyAgAE9PTy655BK2b9/eqLFt3LiRuLg4wsPDMZlMfPLJJ1XqLFy4kC5duuDh4cGwYcPYunVro8bQ2lXaq/tUMpQVOzcgERERERGRRtTik26APn36kJKSUnHbtGnTBeufOnWKESNG4OrqypdffklCQgLPPvss7du3r7b+N998Q2lpaZXyhIQE0tLSajxPQUEB/fv3Z+HChdU+vnz5cubOncu8efPYuXMn/fv3Z9y4caSnp1fUGTBgAH379q1yu1hWWYwO8iYdf/JpB4YNsg85OyQREREREZFG0yoWUnNxcSE0NNTh+s888wwRERG88cYbFWVRUVHV1rXZbMyZM4fu3buzbNkyLBYLAImJiYwZM4a5c+fy8MMPV3vshAkTmDBhQo1xPPfcc9x1113MnDkTgMWLF/PFF1/w+uuv8+ijjwKwe/duh59XWxQV6AWYOGgLY4A5CTISIbi3s8MSERERERFpFK2ip/vAgQOEh4cTHR3NtGnTOHr06AXrf/bZZwwePJjJkycTHBzMpZdeyquvvlptXbPZzMqVK9m1axd33HEHNpuNpKQkxowZw8SJE2tMuGtTUlLCjh07iI2NrXSu2NhYtmzZUq82a7Nw4UJiYmIYMqT1bLsV4OWGj4fLefO6Dzg3IBERERERkUbU4pPuYcOGsWTJEuLj41m0aBHJycmMHDmSvLy8Go85dOgQixYtonv37nz11VfMnj2b++67jzfffLPa+uHh4axbt45NmzZx6623MmbMGGJjY1m0aFG9487MzMRqtRISElKpPCQkhNTU1Dq1FRsby+TJk1m5ciWdOnWqMWmfM2cOCQkJbNu2rd5xNzeTyVR5XndmonMDEhERERERaUQtfnj5+cO3+/Xrx7Bhw4iMjOT999/nzjvvrPYYm83G4MGDWbBgAQCXXnope/bsYfHixUyfPr3aYzp37szbb7/NVVddRXR0NK+99lqDN0FvLGvWrHF2CE0qKtCLgyfLk26tYC4iIiIiIm1Hi+/p/jl/f3969OjBwYMHa6wTFhZGTExMpbLevXtfcFh6Wload999N3FxcRQWFvLggw82KM7AwEAsFkuVhdjS0tLqND/9YhAV6H1ur+7MA2CzOTcgERERERGRRtLqku78/HySkpIICwursc6IESNITKw8THn//v1ERkZWWz8zM5OxY8fSu3dvPvroI9auXcvy5ct56KGH6h2nm5sbgwYNYu3atRVlNpuNtWvXMnz48Hq32xZFBXlx1AimDBcoLYTcE84OSUREREREpFG0+KT7oYceYsOGDRw+fJjNmzczadIkLBYLU6dOBeDll19m7NixlY558MEH+fbbb1mwYAEHDx7k3Xff5d///jdz5syp0r7NZmPChAlERkayfPlyXFxciImJYfXq1bzxxhs8//zzNcaWn5/P7t27K1YgT05OZvfu3RU96nPnzuXVV1/lzTffZO/evcyePZuCgoKK1czFLjrQizJcOMrZEQCa1y0iIiIiIm1Ei5/Tffz4caZOnUpWVhZBQUFcccUVfPvttwQFBQH2XuqkpKRKxwwZMoSPP/6YP/zhDzzxxBNERUXxwgsvMG3atCrtm81mFixYwMiRI3Fzc6so79+/P2vWrKk4T3W2b9/O6NGjK+7PnTsXgOnTp7NkyRKmTJlCRkYGjz32GKmpqQwYMID4+Pgqi6td7LoEegGQaA0j2nLcPsS8W2wtR4mIiIiIiLR8JsMwDGcHIY0rNzcXPz8/cnJy8PX1dXY4Dhn61zXcceYt7nX5FAbNhLgXnB2SiIiIiIhIjRzNu1r88HK5OEQFenHQpr26RURERESkbVHSLS1CdJDXeSuYa063iIiIiIi0DUq6pUWICjwv6S7IgMJs5wYkIiIiIiLSCJR0S4sQFehNIR5kmAPtBRpiLiIiIiIibYCSbmkRos6uYL7fWj7EfL8ToxEREREREWkcSrqlRejcoR0Ws4n91jB7geZ1i4iIiIhIG6CkW1oENxczEe09z1tMTcPLRURERESk9VPSLS1GpcXUMtTTLSIiIiIirZ+SbmkxogK9z+3VffoIlBY5NyAREREREZEGUtItLUZUkBcZ+FFo9gLDBtlJzg5JRERERESkQZR0S4sRHegFmEimk71AK5iLiIiIiEgrp6RbWozybcP2lobaCzKUdIuIiIiISOumpFtajFBfDzxczRywaa9uERERERFpG5R0S4thNpvoEnDeCubaq1tERERERFo5Jd3SokQHnZ90HwSbzbkBiYiIiIiINICSbmlRogK9OGoEU2ZygbIzkHPM2SGJiIiIiIjUm5JuaVGiAr2xYiHVUt7bfcC5AYmIiIiIiDSAkm5pUcpXMD+3mJrmdYuIiIiISOvl4uwARM4XfTbp3lMSymgXtIK5iIiIiNSb1WawNTmb9Lwign08GBrVAYvZ1GbOJ62Dkm5pUdp7ueHfzpWDRWd7urVXt4iIiIjUQ/yeFB7/PIGUnKKKsjA/D+bFxTC+b1irP58z6EuF+lHSLS1OdKAXSce0V7eIiIhcfJTUNI74PSnMXroT42flqTlFzF66k0W3DWzURLi5z+cMF8OXCk1FSbe0OFGB3nx59GzSXZgJhdnQroNzgxIRERFpYkpqGofVZvD45wlVEmCgouzPn/xE5w5euFpMmEwmTCYwm0yYz/48d9/++/n3zSYqHWMYBvM/+6nG85mAxz9P4OqY0Eb/AqW5vqRx1pcKbeVLKCXd0uJEB3lRiAenXIJpX5Zu7+3ufJmzwxIREZGLkJKa1sFmMzhx+gyJqXms3ptW6YuL6mTkF3Pti/9rltgMICWniIdXfM+lndsT5ONOoLc7wWd/erpZ6tVuc31JU9uXGE31pUJb+hJKSbe0OOUrmB82d6I96ZCRqKRbREREmp2SmsbX0CTfMAwy80vYn5bHvtQ89qfmkZiWx4G0PApKrHWKxcfdgquLBZthYBhU+mm/2c93/s+G+HDnCT7ceaJKube7y9lE3K0iIQ/ydj/3u487gWcfd3exJ+j1/ZLGMAyKy2wUFJdRUGwlv7iMgpIy+8+zt/xi63m/l3E4s+CCX2KUf6nwx49/5JKOfvi3c8XP0xV/T/taTb6ervi4u2Cuw+vc1obrmwzDaODbR1qa3Nxc/Pz8yMnJwdfX19nh1NnelFwm/PN/LPB4m1v5EobfC+P+6uywREREWoW20nPpbDX9p7/8StblP/2GYZBfXEZmfglZ+cVk5peQmV9M1tmf+9Ny+S75VK3t9A33pVP7dnh7uODj4YKPhyu+5/1e/tPb3eVsuSsermZMpqqvf2M+P0fVNcnPLSrlQFoeian5Z5PsXPan5ZNdUFJt+64WE12DvAnwcuObpKxa43nvrssY3jWgTs+hPPkuT8wNA747lMX0N7bVeuyYXsFYzCYy8orJzC8mI6+Y4jJbnc7v6+FCoLcbx0+docRacxrn4WpmcGR7CkuslZProjLKGvrtQT2YTeDnaU/G/dq5nU3KXSsS9PKbfzs3fDxcuPfdnWTmV/86m4BQPw82PTLG6X/bHM271NMtLU6XAHtP90+lYeAKZB5wbkAiIiKtRGvsuWyJHO157h/hz+nC0orkOfNsQp2VX0xWQeXEuq7JVXX2nMxlz8ncOh3jYjb9LCl3wcvNhc1JmRec8/ynj/fQwcsdb3cXPFzNeLpZ8HS14OFqwd2l+kT+QmrrufzDtb0I9HYnMc3ee70/LZ8Tp89U25bJZP//Yo8Qb3qG+NAj1IdeoT5EBnjhajFjtRlc8cw6UnOKqn2O5Unb0Ki6rxlkMpmwmMDCued/Rfcgwvw8aj3fq3cMrvTZKP8yJiOv+GwiXkJGXtHZn8Vk5J9LzjPziym1GuQWlZFbVFZrnEWlNjYdvPAXD56uFrzcXfB2t/+0/+5yrszN/ntWfjFLvzta6zlH9QjEzcXC6TOl5J4p5XRhKafPlFBUasNmwKnCUk4VlkJWYa1tXUh5z/rW5Ow6f2niLEq6pcXxdLMQ7udBUl75CuaJzg1IRESkAdrynOC2NOfyfFuTsx0aTjv8qXV1atfLzUKAtzsB3m4EetuHCwd6u5N7ppQ3txyp9fg5o7sS6utBbpF92G9eUSl5RWVnb5V/zy8uw2ZAmc04l+zUQVZBCTe/sqXGxz1czRVJePnP8uTcw8WCx9mfnm5m3F3MLN927IJJ/oKV+6o9T5ifBz1CfOgZ6mP/GeJDt2DvC86DtphNzIuLYfbSnZjOOwec68mfFxfTaJ/D+p7PZDKd/TLElegg7wuewzAMcs6UkpFXzKe7T/Dy10m1xjVtWGdGdg86m0hbziXUZ794cfT5W20Ga/el1/qlwmszhlbbZlGpldwzpeScKeX02WQ850wppwtL7Mn5+WVnSjl5+gwZecW1xpWed+F5+y2Jkm5pkaKCvEjM6Wi/c+oIlBaBq4dzgxIREamjtjwnuK0s/JVTWMrBjDwOpOVzIN1+++HYaYePD/Byq0iiA85LpAO8ysvO/WznVv1/va02g1UJabUmNXOv7unwczUMg4ISa7WJ+aYDmSzffsyh52YxmzhTaqW41EaJ9VxvfVGpjaJSG1C3ZP5CeoX6MDSqw7kkO9gHv3au9WprfN8wFt02sMrnL7SJvhRq6vOZTCb827nh386NEd2CHEq6r+8X3ig9wQ39EsPj7Jcywb6O/V9+S1IWU1/9ttZ6wT6tJzdQ0i0tUlSgF98c9KXI4oOHNQ+yDkJoX2eHJSIi4rDGTEptNoPTZ3u5zh9uWj4s9UB6nkM9s93/tBJ3FwtuLmbcXOw9kG4uZtws5/1+9r79cUulsvI6LmYT/9mU3KoW/souKOFAWh4H0vM5mJ7PgXR7op3uQI9aTZbeOZQrugfV+/hyTdEzazKZ8D47XDjMr/Jjgd7uDiXdL986sFLSVma1UVRmo6jUypkSK0WlVopKbZwptf9e/rPi8TIbZ0qs7DmRw9p96bWeb/aorvxiQEeHn2NtxvcN4+qY0Gab/tBc5xsa1cGh4ez1GT5fk+b8EsMZz6+pKemWFikq0BswcdI1gmhrgn3bMCXdIiLSSjja8zy0SwDZhSWVk+j8YjJ/Np8zK7+kURY/shlw5mxy1JTKk/xBT64m1M+DQG93OpztEQ7wcqODl3vF7wFnH/P1cLngPGFHvsQY1yeUjPxiDlb0WtsT64Pp+WTVsPgWQLifB91CfOgW5E33EG+iA724b9ku0nOLL/if/uFdA+tzearVGpIaF4sZb4sZb/e6pRBbkrIcSrqboufSYjY167zf5jhfcw+fL9dcXyo46/k1JSXd0iJFn9027IAtnGjOJt0iIiKthKNzggf+ZXWd2vVv50qQ97lthMq3FMo5U8riDbUPN11460Au6ehHidVKcZmNkrO3it+t55VZyx+zVpSV1zmQlseWQ9m1nu/02TmakFdrXVeLyZ6Yn03Iz/+9fTtX/v5V4gXnBP/2vV14ulouuMhURAdPugf70D3Ym27B3nQP8aFrkBc+HlWHMD9+Qx8lNY103rbYc+lszT18vlxzfYnhrOfXVJR0S4tUvlf390UhjDOjpFtERFqV1JzqV12ujo+HS6X9eM/tz+t29r4HgT72BNTNxVxtG1abwae7T9Sa1Izv2zjDvbckZbHlUO1zLhdM6kvH9u3Iyi8mu6CErIKSit8z80vsZfnFFJRYKbUapOUWk5Zbv+HepVaDUmsZZhNEBnjZk+pge89192AfooO8apxTXR0lNY33/Npiz2VL0NzD55tbW3p+SrqlRerU3hMXs4nEslBwAzKUdIuISMt3MD2fD3YcY/nW2ufLArw5awhX9Qhu8Hlbas/llCGdHTpnUamVrIISsvNLyCqwD6fPLighs6CY7PwSfkrJJcGBrbIeGd+TmSOi8HCteWXrumhL/+mvTnM+v7bWc9lSNPfw+ebWVp6fkm5pkVwsZjoHtONg5tnFNLIOgM0G5uq/4RcREXGW3KJSPv/+JCt2HGfX0dMV5SYTGDVMwy5PSq/o1vBFuMq15p5LD1cLHf096ejvWe3jjq5mPCCifaMl3OXayn/6a9Kcz6+tf4khUhMl3dJiRQd68XVGEFaTK5ayIsg5Cu27ODssERERbDaDb5IyWbHjOPF7Uikus2+lZDGbGN0ziJsGRVBqtXHfe7uAtjcnuPxcLX3hL2l52vqXGCLVUdItLVZ0kDdr9lrIdI8gpOgQZB5Q0i0iIk51JKuAFTuO8+GO45w8L9HsHuzN5MGdmHhpx0orMLtaTG12TjC03YW/REQak5JuabHKF1M7au5ICIcgIxG6X+3kqERE5GJTUFzGFz+msGLHcbYmn1ux29fDhRsGhDN5UAT9OvlVu93VxTCcti0u/CUi0piUdEuLVZ50J5SGMQS0grmIiDQKq82oNQk2DHudD3YcZ+WPKRSW2Pe1NplgZPcgbhrUiWtiQhyaP6zhtI3nYvgSQ0TaHiXd0mKV79W9qzCI6a4o6RYRkQaL35NSpac07Lye0hOnz/DhjuOs2HGco9mFFXW6BLRj8uAIbhzYkTC/6hf7kuahLzFEpLVR0i0tVpCPO15uFg6Unl3BXEm3iIg0QPyeFGYv3VllIa7UnCJ+s3QnvUJ9SEzLq1hx3MvNwvX9wpk8uBODIttXO3xcRESkNkq6pcUymUxEBXmRdCLUXlCYBQVZ4KVvt0VEpG6sNoPHP0+oduXr8rJ9qXkADI8O4KZBnZhwSSjt3PRfJRERaRj9SyItWlSgN3tO5JLnEYZPUYq9t9truLPDEhGRVmZrcnalIeU1efGWAdwwoGMzRCQiIhcLs7MDELmQ8sXUUlwi7AWZiU6MRkREWqu9KbkO1auuJ1xERKQh1NMtLVr5YmoHjI70APte3SIiIg4wDINNBzN5c/Nh1uxNd+iY8/fYFhERaQxKuqVFK+/p/uFMMNeBfa9uERGRCygoLuOjncdZsvkwSRkFFeVuLmZKymzVHmPCvt/z0KgOzRSliIhcLJR0S4vWpXzbsDPB4I5WMBcRkRodzizgzS2HWbH9OHnFZQB4u7tw06BO3D48kgNpecxeuhOoPIy8fE3yeXEx2u9ZREQanZLuVmDSpEmsX7+esWPHsmLFCmeH06z8PF0J9HYjKT/cXnD6KJSeAVftkSoiImCzGWw8kMGbmw/zdWJGRXl0oBd3DI/kl4M64ePhCkDXIG8W3Tawyj7doeft0y0iItLYlHS3Avfffz+zZs3izTffdHYoThEV6MW2/GJKXP1wK82BrIMQeomzwxIRESfKKyrlwx3HeWvLEQ5lnhtCPrpnENMv78KV3YMwV9NrPb5vGFfHhLI1OZv0vCKCfexDytXDLSIiTUVJdyswatQo1q9f7+wwnCYq0Itth0+R6RFJeOkP9nndSrpFRC5KSRn5vLX5MCt2HKegxAqAj7sLkwdHcMfwyIppSRdiMZsY3jWgqUMVEREBWsCWYfPnz8dkMlW69erVq8HH1Kfdutq4cSNxcXGEh4djMpn45JNPqq23cOFCunTpgoeHB8OGDWPr1q2NGkdbFxXoDcARcyd7gVYwFxFpU6w2gy1JWXy6+wRbkrKw2ipv3GWzGazbl8Ydr29l7LMbeHPLEQpKrHQN8uLJX/Rhyx/H8lhcjEMJt4iISHNrET3dffr0Yc2aNRX3XVxqD8uRY+rS7jfffMPQoUNxdXWtVJ6QkEBAQAAhISFVjikoKKB///7MmjWLG2+8sdp2ly9fzty5c1m8eDHDhg3jhRdeYNy4cSQmJhIcHAzAgAEDKCsrq3LsqlWrCA8PrzHmi0V0kP0/UXtLQxkO2qtbRKQNid+TUmWOddjZOdaXdwvkg+3HeXvLYQ5nFQJgMsHYXsFMv7wLV3QLxGTSsHAREWnZWkTS7eLiQmhoaKMf42i7NpuNOXPm0L17d5YtW4bFYgEgMTGRMWPGMHfuXB5++OEqx02YMIEJEyZcsO3nnnuOu+66i5kzZwKwePFivvjiC15//XUeffRRAHbv3l1rjBez8r26txcEM8uEerpFRNqI+D0pzF66E+Nn5Sk5Rfxm6c5KW3z5eLhwy5AIbr+sC50D2jV/sCIiIvXk9OHlAAcOHCA8PJzo6GimTZvG0aNHG+UYR9s1m82sXLmSXbt2cccdd2Cz2UhKSmLMmDFMnDix2oTbESUlJezYsYPY2NhK54qNjWXLli31avNCFi5cSExMDEOGDGn0tp2pc0A7TCbYU3J2tEHmAbBZnRuUiIg0iNVm8PjnCVUS7vOVlNnoHuzFXyf15bs/juVP18Uo4RYRkVbH6Un3sGHDWLJkCfHx8SxatIjk5GRGjhxJXl5eg46pa7vh4eGsW7eOTZs2ceuttzJmzBhiY2NZtGhRvZ9bZmYmVqu1ytD0kJAQUlNTHW4nNjaWyZMns3LlSjp16lRjwj5nzhwSEhLYtm1bvWNuidxdLHRq78lxIwib2Q2sxfatw0REpNXampxVaUh5TZ74RV+mDYuknVuLGJwnIiJSZ07/F+z84dn9+vVj2LBhREZG8v7773PnnXfW+5j6tNu5c2fefvttrrrqKqKjo3nttddaxFyx8+elX6yiAr05ln2GXK9I/PMOQOZ+6BDl7LBERKQOUnLOsPlgFpuTsli7N82hY9Lzips4KhERkabl9KT75/z9/enRowcHDx5s1GMcqZOWlsbdd99NXFwc27Zt48EHH+Sll16qU/znCwwMxGKxkJZW+T8WaWlpdZ7DfrGLDvRi4/4MTrp2xp+zSXePcc4OS0RELiAzv5hvD9mT7C1JWSSft5+2o4J9PJogMhERkebT4pLu/Px8kpKSuP322xv1mNrqZGZmMnbsWHr37s0HH3zA/v37GTVqFO7u7vzjH/+o8/MAcHNzY9CgQaxdu5aJEycC9kXb1q5dy7333luvNi9WUWcXU0uyhRMD9r26RUSkSVhtBluTs0nPKyLYx4OhUR2wmGsf+ZVzppStydlsTspkS1IW+1IrT+kym6BfJ38u7xrAZVEBPPzh96TlFlc7r9sEhPrZzy0iItKaOT3pfuihh4iLiyMyMpKTJ08yb948LBYLU6dOBeDll1/m448/Zu3atQ4f42idcjabjQkTJhAZGcny5ctxcXEhJiaG1atXM2bMGDp27MiDDz5Y5bj8/PxKPefJycns3r2bDh060LlzZwDmzp3L9OnTGTx4MEOHDuWFF16goKCgYjVzcUx50v1DcQhxoBXMRUSayIW28BrfN6xS3cKSMrYfPnW2JzuTH0/k8LMttukd5svlXQO4vGsAQ6I64OtxbmvO+Tf0YfbSnZigUuJdnt7Pi4txKNkXERFpyZyedB8/fpypU6eSlZVFUFAQV1xxBd9++y1BQUGAvQc6KSmpTsc4Wqec2WxmwYIFjBw5Ejc3t4ry/v37s2bNmmqPAdi+fTujR4+uuD937lwApk+fzpIlSwCYMmUKGRkZPPbYY6SmpjJgwADi4+Or3fdbalaedG/NDQRX7Ht1G4Z9w1YREWkUNW3hlZpTxOylO3lx6gCCfTwqhovvOnaKUmvl2tFBXmeT7ECGRXUgwNu9xvON7xvGotsGVknyQ2tI8kVERFojk2EYF9qtQ1qh3Nxc/Pz8yMnJwdfX19nhNAqrzaD3Y/GYy86w12MWJgz4fRJ4BTo7NBGRNsFqM7jimXUOrSh+vo7+nvYku1sAw6MDCfWr+xzs+g5nFxERcSZH8y6n93SLOMJiNtEloB3702wUeXXEs+C4fV63km4RkUaxNTnboYTb18OFq3oGM+Jsb3ZEB88G7/RhMZsY3jWgQW2IiIi0VEq6pdWICvRif1o+WR6RdCo4bl/BvMsIZ4clItJq5ZwpZeeRU2w9nM1Xe1IdOubJX/TlF5d2bOLIRERE2g4l3dJqRAV6A2kcNXeiE9iTbhERcdjJ02fYdjibbYez2X74FIlpedR1klmwr7bwEhERqQsl3dJqRJ9dTG1fWSiXg5JuEblo1GfOs81msD89j22HT7H9bJJ94vSZKvWiA70Y3KU9AyPb8+xX+8nM1xZeIiIijUlJt7QaUUH2pHt7QTCzADKUdItI2+foFl7FZVZ+OJ5T0Yu9/XA2uUVlldqymE30DfdlcJcODOnSnkGRHQjyObe6uL+nq7bwEhERaWRKuqXVKO/p/i4vANyBnKNQUghu7ZwbmIhIE6ltC697RnfFZsD2w9l8fzyHkjJbpXrt3CwM7NyewV3aM6RLBwZE+OPlXvM//drCS0REpPEp6ZZWo4OXG74eLmQV+VLm0R6XolOQdQDC+js7NBGRRme1GTz+eUK1Q73LyxZ+nVSpPNDbjSFdOlT0ZMeE+eJiMdfpvOP7hnF1TKi28BIREWkkSrql1TCZTEQFefP9sdPkeUXRvugUZCrpFpG2ydEtvEb1COTafuEM6dKBLgHtGrx9F2gLLxERkcZUt6+/RZysfIh5iltne0FGohOjERFpOik5VRc9q86kgZ24eXAEUYFejZJwi4iISONS0i2tStTZpDvJFm4v0ArmItLGGIZB/J5U/v6VY18qBvtoCy8REZGWTMPLpVUpT7p/KA4hDpR0i0ibsuNINgtW7mPHkVMAmEzUuI+2tvASERFpHZR0S6tSnnR/lxtoL8g6CDYrmC1OjEpEpGGSMvL5W/w+vvopDQAPVzO/uiKarkFezH3/e0BbeImIiLRWSrqlVSlPuvcU+mF4e2AqK4JThyGgq3MDExGph/S8Iv655gDLth3DajMwm2DKkAgeiO1BiK992Linm0VbeImIiLRiSrqlVfFydyHE15203GKKfKPwzN5rX8FcSbeItCL5xWW8uvEQr/7vEIUlVgBiewfzyPhedA/xqVRXW3iJiIi0bkq6pdWJCvQiLbeYLM8udGIvZCZCz/HODktEpFalVhvLth3jn2v2k5lfAkD/CH/+OKEXw6Jr3qJLW3iJiIi0Xkq6pdWJCvTm20PZHDN1pBNoMTURafEMw+Crn1L5W3wihzILAOgS0I6Hx/diQt9QbfUlIiLShinpllanfK/uvdYwhoN9eLmISAu17XA2T63cy86jpwEI8HLj/tjuTB3aGVeLdu4UERFp65R0S6tTvpjazoIgZgFkJNr31FFPkYi0IAfT83kmfh+rE+wrknu6WvjVyCjuvjIaHw9XJ0cnIiIizUVJt7Q6UUH2pPub0+0xzCZMRaehIBO8g5wbmIhcNKw2o8aFzdJzi3h+zQHe337+iuSdeTC2O8FnVyQXERGRi4eSbml1Itq3w2I2carEgjU4Apfco/bF1JR0i0gziN+TUmULrzA/Dx4e34vkjHxe/V8yZ0rtK5JfHRPCI+N70i3Yp6bmREREpI1T0i2tjpuLmc4d2pGcWUCeTzTtc4/aF1PrcoWzQxORNi5+Twqzl+7E+Fl5Sk4RDy7fXXH/0s7+/PHa3gzp0qFZ4xMREZGWR0m3tEpRgV4kZxaQ6tqZ9gAZWsFc5GJ2oeHejXmOxz9PqJJwn89iNvHilAFc2y9MK5KLiIgIoKRbWqnyxdSSjI70Bm0bJnIRq2m497y4GMb3DatXm4ZhcLqwlNTcIlJzi0jLKWLb4exK56iO1WbQwdtdCbeIiIhUUNItrVJ50v1jcTDXg5JukYtUTcO9U3OKmL10J4tuG1gl8S4ps5GeV0RabhGpOcX2pDq3iNScs7ez94vLbPWKKT3vwom5iIiIXFyUdEurVL5X93d5gfaCnGNQUgBuXk6MSkSa04WGe5eX/f6DH9iwP4OMPHtynZpTTFZBMcaFxoifp4OXGyG+HoT6umMywbp9GbUeE+yjFcpFRETkHCXd0iqVbxu255QLhn8ApsIsyDwA4QOcG5iINJutybUP984rLuO9rceqlLtaTGeTaQ9C/Ow/z/89zM+DYF933F0sFcdYbQZXPLOO1JyiahN9ExDqZ59PLiIiIlJOSbe0SiE+Hni6WjhTaqXYvxseSrpFLjqODuMeFxPClT2D7Em1rwehfh50aOeGuY4LrVnMJubFxTB76U5MUCnxLm9pXlxMoy/gJiIiIq2b2dkBiNSH2Wyiy9kh5lkekfbCzEQnRiQizelQRj7vfnfEobozRkQxbVgkY3uH0LejH4He7nVOuMuN7xvGotsGEupXeQh5qJ9HtfPHRURERNTTLa1WdKAXe1NyOWaJoCNoMTWRi0BabhEvrDnA+9uPYbVdeGJ2Uw33Ht83jKtjQpt8izIRERFpG5R0S6tVvoJ5Ylkol4H26hZpw3LOlLJ4QxJvfJNMUal9VfGxvYIZ3i2Av/53L9C8w70tZhPDuwY0ersiIiLS9ijpllarPOneURjMdIDsJLCWgUVva5G2oqjUypubD/Ov9UnknCkFYFBkex6d0IshXew92J38Pavs0x3awH26RURERBqLshNptcpXMN9+ygtcPKHsDJw+AgFdnRyZiDRUmdXGih3HeWHNAVJz7cl0jxBvfj+uF7G9gzGZzvVea7i3iIiItGRKuqXVKt+r+2RuCbbIbpjTfrTP61bSLdJqGYbBVz+l8vevEknKKAAg3M+DB6/uwY0DO9WYSGu4t4iIiLRUSrql1fJv50b7dq6cKiwlzzsKv7QfISMRek5wdmgiUg9bkrJ4Jn4fu4+dBqB9O1fmjO7GbZdF4uFqufDBIiIiIi2Ukm5p1aICvTh19DSpbp3xA/te3SLSqvx0Moe/xSeyYX8GAJ6uFn41Moq7rozG18PVydGJiIiINIySbmnVooO82Xn0NIeMjvQE7dUt0ooczSrk2dWJfLr7JAAuZhNTh3bmt2O7EezjUcvRIiIiIq2Dkm5p1cpXMN9THMIEsM/pNgwwaQElEWey2owaFzbLyCvm5XUHeHfrUUqt9o2+4vqH87ure9Dl7GdaREREpK1Q0i2tWvlialvzOoDJDEU5kJ8OPiFOjkzk4hW/J6XKFl5hfh48PK4nyZkF/GdTMoUlVgBGdg/kkfG96NvRz1nhioiIiDQpJd3SqpVvG5aYWYLRPhLTqWR7b7eSbhGniN+TwuylOzF+Vp6SU8SD739fcb9/Jz8eGd+Ly7sFNm+AIiIiIs1MSbe0al0C7El3blEZpe274XYq2T6vO2qkkyMTufhYbQaPf55QJeE+n8Vs4sUpA7i2X1ilvbZFRERE2iqzswMQaQgPVwsd/T0ByG7XxV6oFcxFnGJrcnalIeXVsdoMOni7K+EWERGRi4aSbmn1yhdTO2buZC/I0ArmIs6QnnfhhLuu9URERETaAiXd0uqVJ92J1nB7gXq6RZyisKTMoXraDkxEREQuJkq6pdUrT7p3FQbZC3KPQ3G+EyMSubiUlNl4bvV+/u/jPResZ8K+ivnQqA7NE5iIiIhIC6CkW1q98hXMfzplAa+ziXeWertFmsOeEznc8PImXlx7AKsBAyL8AXuCfb7y+/PiYir26xYRERG5GCjpllavfK/u5MwCjIDu9sKM/U6MSKTtKy6z8o+vEvnFwm/Yl5pHBy83Xr71Uj6+53IW3zaQUL/KQ8hD/TxYdNtAxvcNc1LEIiIiIs6hLcOk1evo74mrxURxmY1Cv254sdm+V7eINInvj53m9yu+Z3+afRrHdf3CeOKGPgR4uwMwvm8YV8eEsjU5m/S8IoJ97EPK1cMtIiIiFyMl3a3ApEmTWL9+PWPHjmXFihXODqfFcbGY6dyhHUkZBaS5dSYa7Ht1i0ijKiq18sKaA/x7YxI2AwK93XjyF32ZcEnV3muL2cTwrgFOiFJERESkZdHw8lbg/vvv56233nJ2GC1aVKA3AIfQCuYiTWHn0VNc9+L/WLzBnnD/YkA4qx68qtqEW0RERETOUU93KzBq1CjWr1/v7DBatOggL9gLPxaFEAuQlQTWMrDoLS7SEEWlVp5bvZ///O/Q2d5td/46qS/j+oQ6OzQRERGRVqHF93TPnz8fk8lU6darV69GP6Y+Nm7cSFxcHOHh4ZhMJj755JMqdRYuXEiXLl3w8PBg2LBhbN26tdHjkHOLqX2f6w2u7cBWCqcOOzcokVZu++Fsrv3n//j3RnvCfeOlHVkz90ol3CIiIiJ10Cq6Afv06cOaNWsq7ru41B52XY755ptvGDp0KK6urpXKExISCAgIICQkpNrjCgoK6N+/P7NmzeLGG2+s8vjy5cuZO3cuixcvZtiwYbzwwguMGzeOxMREgoODARgwYABlZWVVjl21ahXh4eG1Pk+xK9+r+1DWGQjoBqk/2Od1B3ZzcmQirc+ZEit//yqRNzYnYxgQ4uvOgkmXMLZ39X8LRURERKRmrSLpdnFxITS0bj0rjh5js9mYM2cO3bt3Z9myZVgsFgASExMZM2YMc+fO5eGHH6722AkTJjBhwoQa237uuee46667mDlzJgCLFy/miy++4PXXX+fRRx8FYPfu3XV6XlK98r26j58qxBrVA0vqD2dXML/OuYGJtDLfHcrikQ9/4HBWIQA3DerEn6+Lwa+day1HioiIiEh1WvzwcoADBw4QHh5OdHQ006ZN4+jRo412jNlsZuXKlezatYs77rgDm81GUlISY8aMYeLEiTUm3LUpKSlhx44dxMbGVjpXbGwsW7ZsqVebtVm4cCExMTEMGTKkSdpvyYK83fF2d8FmwGmvLvZC7dUt4rDCkjLmf/YTU/79LYezCgnz8+CNmUP4x+T+SrhFREREGqDFJ93Dhg1jyZIlxMfHs2jRIpKTkxk5ciR5eXmNdkx4eDjr1q1j06ZN3HrrrYwZM4bY2FgWLVpU77gzMzOxWq1VhqaHhISQmppap7ZiY2OZPHkyK1eupFOnTjUm7XPmzCEhIYFt27bVO+7WymQyVQwxP27uZC/UXt3SglltBluSsvh09wm2JGVhtRlOi2VLUhbjX/gfSzYfBuCWIRF89eCVjO4Z7LSYRERERNqKFj+8/Pzh2/369WPYsGFERkby/vvvc+eddzbaMZ07d+btt9/mqquuIjo6mtdeew2TydS4T6aezp+bLjWLCvTixxM5JFrD6Q/2pNswoIW8jiLl4vek8PjnCaTkFFWUhfl5MC8uhvF9m2YLLqvNYGtyNul5RQT7eDA0qgNnSq08/eVeln5rHwnU0d+Tp268hCt7BDVJDCIiIiIXoxafdP+cv78/PXr04ODBg416TFpaGnfffTdxcXFs27aNBx98kJdeeqnecQYGBmKxWEhLS6tynrrOTxfHlPd0f18YwM0mMxTnQn4a+Oh6S8sRvyeF2Ut38vN+7dScImYv3cmi2wY2euJdXZLfwcsNDMguLAFg2rDOPDqhFz4eGkouIiIi0pha/PDyn8vPzycpKYmwMMf/U1rbMZmZmYwdO5bevXvz0UcfsXbtWpYvX85DDz1U7zjd3NwYNGgQa9eurSiz2WysXbuW4cOH17tdqVn02cXUDmSXQvsu9sKMROcFJPIzVpvB458nVEm4AYyztz9/+hNHsgpIzy3idGEJhSVllFlt9T5neZJ/fsINkF1QQnZhCQFebrz7q2H8ddIlSrhFREREmkCL7+l+6KGHiIuLIzIykpMnTzJv3jwsFgtTp04F4OWXX+bjjz+ulNzWdsz5bDYbEyZMIDIykuXLl+Pi4kJMTAyrV69mzJgxdOzYkQcffLDa2PLz8yv1nicnJ7N79246dOhA586dmTt3LtOnT2fw4MEMHTqUF154gYKCgorVzKVxlfd0J2cWQFQPyD5kH2IefZWTIxOx25qcXSX5/bmMvGKu+vv6KuVmE7hazLi5mHF3MeNmMeN69qebi/3majn3mJuLGReziTV706tN8su5WswMiw5o2BMTERERkRq1+KT7+PHjTJ06laysLIKCgrjiiiv49ttvCQqyzznMzMwkKSmpTsecz2w2s2DBAkaOHImbm1tFef/+/VmzZk21x5Tbvn07o0ePrrg/d+5cAKZPn86SJUuYMmUKGRkZPPbYY6SmpjJgwADi4+Nr3PdbGqbL2aQ7I6+YkvbdcAMtpiYtxpkSK599f8Khuq4WE1abwflrq9kMKC6zUVxmo+ZlJOsuNbeIrcnZDO+qxFtERESkKZgMw3DekrnSJHJzc/Hz8yMnJwdfX19nh9OsBv9lDZn5xWy6+gSd/vd7iB4Fd3zq7LDkInY4s4B3vjvC+9uPk3Om1KFj3rvrMoZ3DaDMaqPEaqO0zKDYaqWkzGa/nS0rsVopPltWajXOPnau3s6jp/l4V+2J/j9vGcAvBnRs6FMVERERuag4mne1+J5ukbqIDvQiM7+YQ6aOdALt1S1OYbUZrE9M560tR9iwP6OivFN7D3LOlJFfVFbtkG8TEOpnX1kcwMVixsVixj5so+7zrbsFZzmUdAf7eNS5bRERERFxjJJuaVOiAr3YejibPcUhXAmQdxKK88Ddx9mhyUXgVEEJy7cf453vjnAs+0xF+aieQdwxPJKregSzOiGV2Ut3YoJKiXf5xnbz4mKwmBtnm7uhUR0I8/MgNafIoSRfRERERBqfkm5pU6LOrmC+77QFvIKhIN0+r7vjICdHJm3Z98dO89aWI3z+w0lKyuwrjft5unLz4E7cdlkkkQFeFXXH9w1j0W0Dq2zhFdoE+3RbzCbmxcU0W5IvIiIiIlUp6ZY2pdIK5oE9zibdB5R0S6MrKrXy3x9SeHvLYb4/nlNR3rejL3dc1oW4/uF4ulmqPXZ83zCujglla3I26XlFBPvYe5ubIvltziRfRERERKpS0i1tStegc0m30aUHpiObtIK5OMRqMxxKgo9lF7L02yO8v/0YpwrtC6O5Wcxc1y+M24dHcmmEPyZT7cmzxWxqthXDmzPJFxEREZHKlHRLmxLRoR1mE+QXl5HvE4kPQNI6iB4NkZeDufqeR7m4xe9JqdITHHZeT7DNZrDhQAZvbznC14nplO/50NHfk1uHdWbKkAgCvd2dFL1jmjPJFxEREZFzlHRLm+LuYqFT+3b0Pr0ejy1v2gtP7oI3rwffcBj/DMTc4NwgpUWJ35PC7KU7qyw0lppTxOylO7lxYEe2HznFkazCisdGdg/kjuFdGNMrWL3FIiIiInJBSrqlzbmp3U7uLXgBU/HPHshNgffvgJvfUuItgH1I+eOfJ1S7snd52Yc77Vtu+Xi4MHlQBLdd1pnoIO9mi1FEREREWjcl3dK22KxMz1kMnFud+RzDXhr/KPS6TkPNha3J2ZWGlNfkrpFRPHh1D9q56U+miIiIiNSN2dkBiDSqI5vxK02n5hG/BuSegCObmzMqaaHS82pPuAH6dvRTwi0iIiIi9aKkW9qW/LTGrSdtWrCPR6PWExERERH5OSXd0rZ4hzRuPWnThkZ1IMyv5oTahH0V86FRHZovKBERERFpU5R0S9sSeTmGbzi26lbGAsAEvh3t24fJRc9iNjEvLqbax8pnKMyLi9EK5SIiIiJSb0q6pW0xWzCNfwaTiZoT7/FPaxE1qRAd5F3NonsQ6ufBotsGMr5vWLPHJCIiIiJth1YGkrYn5gZeCZnPDakvEk72uXKzC9z0hrYLk0qe+XIfBnBNTDAzR0STnldEsI99SLl6uEVERESkoZR0S5uUEzWBK4504//6nmJWLxv890GwlUFYP2eHJi3Id4eyWLsvHYvZxCMTetNV+2+LiIiISCPT8HJpk6ICvbBhZl1RTxg849wc7sQvnRqXtByGYfDUl/sAuGVIhBJuEREREWkSSrqlTYoO9AIgObPAXtDrWvvPfV84KSJpab7ck8ruY6dp52bh/tjuzg5HRERERNooJd3SJkWdTbpPnD5DUakVek6wP3BkM5w55cTIpCUotdr4W7y9l/tXI6O1D7eIiIiINBkl3dImdfByw8/TFYDDWQXQIRqCeoNhhQOrnRydONt7W49yOKuQQG837r4y2tnhiIiIiEgbpqRb2iSTyVTR252ccXaIeXlvd+JKJ0UlLUF+cRn/XHMAgPvGdsfbXetJioiIiEjTUdItbVb5vO5DFfO6r7P/PLAGyoqdFJU42783HiKroIQuAe2YOrSzs8MRERERkTZOSbe0WVE/X0wtfCB4h0BJHhze5MTIxFnS84r4z/8OAfDw+F64WvQnUERERESalv7HKW1WZEA7AHYcOcWWpCysmKDHePuDGmJ+UfrnmgMUllgZEOHPhL6hzg5HRERERC4CSrqlTYrfk8IT/00A7D3dU1/9liueWccOj8vsFRK/BMNwYoTS3JIy8lm27RgAf5jQC5PJ5OSIRERERORioKRb2pz4PSnMXrqTzPySSuWpOUVMW+dJmcUTck9AyvdOilCc4W/x+7DaDMb2CmZYdICzwxERERGRi4SSbmlTrDaDxz9PoLo+bAMoxo1vjEvsBYlfNmdo4kQ7jmTz1U9pmE3wyIRezg5HRERERC4iSrqlTdmanE1KTlGNjxvA58WX2u8kftE8QYlTGYbBUyv3ATB5UAQ9QnycHJGIiIiIXEyUdEubkp5Xc8Jdbp31UgzMkPojnD7WDFGJM61OSGP7kVN4uJp58Ooezg5HRERERC4ySrqlTQn28ai1Tja+5AUPtN/REPM2rcxq45l4ey/3rBFRhPrV/v4QEREREWlMdU664+Pj2bTp3B7HCxcuZMCAAdx6662cOnWqUYMTqauhUR0I8/OgpnWpTUCYnwfe/W6wF2jrsDbt/e3HScoooH07V34zqquzwxERERGRi1Cdk+7f//735ObmAvDjjz/yu9/9jmuvvZbk5GTmzp3b6AGK1IXFbGJeXAxAjYn3vLgYzL2us985vAmKcponOGlWhSVlPL9mPwD3jumOr4erkyMSERERkYtRnZPu5ORkYmLsSc2HH37I9ddfz4IFC1i4cCFffqmhuuJ84/uGsei2gdUOJZ4yNILxfcMgsBsE9gBbKRxc44Qopam99r9kMvKKiejgyW2XdXZ2OCIiIiJykXKp6wFubm4UFhYCsGbNGu644w4AOnToUNEDLuJs4/uGcXVMKFuTs0nPK2LH4VO89e0Rvj+Wg2EYmEwm6DkBMvfDvpXQ95fODlkaUVZ+Ma9sPATAQ9f0xN3F4uSIRERERORiVeee7iuuuIK5c+fy5JNPsnXrVq67zj5Md//+/XTq1KnRAxSpL4vZxPCuAfxiQEfmXtMDNxcze1Ny+eH42eHkPc8OMT+wGqylzgtUGt1L6w6SX1zGJR39iOsX7uxwREREROQiVuek++WXX8bFxYUVK1awaNEiOnbsCMCXX37J+PHjGz1Akcbg386N6y4JA+C9rUfthZ0GQ7tAKM6BI984MTppTIczC1j67REAHp3QC7O5ptn9IiIiIiJNr87Dyzt37sx///vfKuXPP/98owQk0lSmDu3Mx7tO8Nn3J/nTdb3x8XCFnuNh11L71mHRo5wdojSCv69KpMxmcGWPIEZ0C3R2OCIiIiJykatzT/fOnTv58ccfK+5/+umnTJw4kT/+8Y+UlJQ0anAijWlIl/Z0DfKisMTKZ9+ftBf2vNb+c99KMAznBSeN4vtjp/nihxRMJnh0fC9nhyMiIiIiUvek+9e//jX799u34Tl06BC33HIL7dq144MPPuDhhx9u9ABFGovJZGLqUPsq1su2HrMXRo8GFw/IOQppPzkxOmkowzB46su9AEy6tCMx4b5OjkhEREREpB5J9/79+xkwYAAAH3zwAVdeeSXvvvsuS5Ys4cMPP2zs+EQa1Y0DO+FmMfPjiRx+PJ4Dbu3siTdA4krnBicNsj4xg28PZePmYuZ31/R0djgiIiIiIkA9km7DMLDZbIB9y7Brr7UPz42IiCAzM7NxoxNpZB283BjfNxSA97adXVCt19kh5kq6Wy2rzeDpL/cBMOPyLnT093RyRCIiIiIidnVOugcPHsxf/vIX3n77bTZs2FCxZVhycjIhISGNHqBIYysfYv7prhMUFJdBj/GACU7ugtyTzg1O6uXDncdJTMvD18OFe0Z1dXY4IiIiIiIV6px0v/DCC+zcuZN7772XP/3pT3Tr1g2AFStWcPnllzd6gCKN7bLoDkQFelFQYuXz70+CdzB0GmJ/MPFL5wYndVZUauX51fZ1JuaM7oZ/OzcnRyQiIiIick6dtwzr169fpdXLy/3973/HYrE0SlAiTcm+oFoEC1bu472tR7llaGfoOQGOb7UPMR9yp7NDlDp445vDpOQU0dHfk+mXd3F2OCIiIiIildS5p7vcjh07WLp0KUuXLmXnzp14eHjg6uramLGJNJlfDuyEq8XE98dz+OlkDvSyT5MgeSMU5zk3OHHYqYIS/rX+IABzr+6Bh6u++BMRERGRlqXOSXd6ejqjR49myJAh3Hfffdx3330MHjyYsWPHkpGR0RQxijS6AG93ruljX1Bt2dZjENgDOkSDtQQOrnVydOKohV8fJK+ojF6hPky8tKOzwxERERERqaLOSfdvf/tb8vPz+emnn8jOziY7O5s9e/aQm5vLfffd1xQxijSJW88uqPbJrhMUllqhp1Yxb02OZRfy1pYjADw6oRcWs8nJEYmIiIiIVFXnpDs+Pp5//etf9O7du6IsJiaGhQsX8uWXWoRKWo/h0QFEBrQjr7iM//6Qci7p3v8VWMucG5zU6tlViZRYbVzeNYCregQ5OxwRERERkWrVOem22WzVzt12dXWt2L9bGtekSZNo3749N910k7NDaVPMZhO3DLH3dr+39ShEDAPPDlB0Go5ucW5wckF7TuTwyW779m5/mNAbk0m93CIiIiLSMtU56R4zZgz3338/J0+e28/4xIkTPPjgg4wdO7ZRgxO7+++/n7feesvZYbRJNw3qhIvZxK6jp9mbXgg9xtkf0NZhLdoz8fsAuKF/OJd08nNyNCIiIiIiNatz0v3yyy+Tm5tLly5d6Nq1K127diUqKorc3FxefPHFpojxojdq1Ch8fHycHUabFOTjzjV9QgBYtvXoefO6vwDDcGJkUpP/HcjgfwcycbWY+P24ns4OR0RERETkguqcdEdERLBz506++OILHnjgAR544AFWrlzJzp07iYiIqHMA8+fPx2QyVbr16tXL4eOffvppTCYTDzzwQKO264iNGzcSFxdHeHg4JpOJTz75pNp6CxcupEuXLnh4eDBs2DC2bt3aqHFIw0w9u6DaR7tOcKbzVWBxh1OHIWOfcwOTKmw2g6dW2l+X2y6LJKJDOydHJCIiIiJyYS71OchkMnH11Vdz9dVXV5Tt27ePG264gf3799e5vT59+rBmzZpzQbk4Fta2bdt45ZVX6NevX4Pb/eabbxg6dGiV+eoJCQkEBAQQEhJS5ZiCggL69+/PrFmzuPHGG6ttd/ny5cydO5fFixczbNgwXnjhBcaNG0diYiLBwcEADBgwgLKyqgt3rVq1ivDw8BpjlsYxomsgER08OZZ9hi8S87gp+io4sAr2fQHBvWtvQJrNp9+fICElFx93F347pruzwxERERERqVWde7prUlxcTFJSUr2OdXFxITQ0tOIWGBhY6zH5+flMmzaNV199lfbt2zeoXZvNxpw5c7j11luxWq0V5YmJiYwZM4Y333yz2uMmTJjAX/7yFyZNmlRjnM899xx33XUXM2fOJCYmhsWLF9OuXTtef/31ijq7d+9mz549VW5KuJvH+Quq2YeYT7A/oHndLUpRqZV/fGX/Uu83o7rSwcvNyRGJiIiIiNSu0ZLuhjhw4ADh4eFER0czbdo0jh49Wusxc+bM4brrriM2NrbB7ZrNZlauXMmuXbu44447sNlsJCUlMWbMGCZOnMjDDz9cr+dVUlLCjh07KsVoNpuJjY1ly5bGXx174cKFxMTEMGTIkEZvu62bPKgTFrOJ7UdOkdRhpL3wxHbIS3VuYFJh6bdHOHH6DCG+7swaEeXscEREREREHOL0pHvYsGEsWbKE+Ph4Fi1aRHJyMiNHjiQvL6/GY5YtW8bOnTt56qmnGq3d8PBw1q1bx6ZNm7j11lsZM2YMsbGxLFq0qN7PLTMzE6vVWmVoekhICKmpjidzsbGxTJ48mZUrV9KpU6caE/Y5c+aQkJDAtm3b6h3zxSrY14PY3vbh/kt/KoHwgfYH9sc7MSopl3OmlJe/PgjA3Kt74OlmcXJEIiIiIiKOqdec7sY0YcKEit/79evHsGHDiIyM5P333+fOO++sUv/YsWPcf//9rF69Gg8Pj0ZrF6Bz5868/fbbXHXVVURHR/Paa6+1iP1/z5+XLk1n6tDOfPVTGh/tPMEfr5yA68mdsG8lDJrh7NAuSlabwdbkbNLzilizN53ThaV0D/bmlwM7OTs0ERERERGHOZx0t2/f/oIJaHULgdWHv78/PXr04ODBg9U+vmPHDtLT0xk4cGBFmdVqZePGjbz88ssUFxdjsVTtBautXYC0tDTuvvtu4uLi2LZtGw8++CAvvfRSvZ9LYGAgFouFtLS0KucJDQ2td7vSNEZ2D6KjvycnTp9ho3kwYwEOrYeSAnDzcnJ0F5f4PSk8/nkCKTlFlcpje4fgYnH6AB0REREREYc5nHS/8MILTRjGOfn5+SQlJXH77bdX+/jYsWP58ccfK5XNnDmTXr168cgjj1SbcDvSbmZmJmPHjqV379588MEH7N+/n1GjRuHu7s4//vGPej0XNzc3Bg0axNq1a5k4cSJgX7Rt7dq13HvvvfVqU5qOxWziliERPLt6P68keDDWPxJOH4GkddA7ztnhXTTi96Qwe+lOqtslffGGJPpH+DG+b1izxyUiIiIiUh8OJ93Tp09vkgAeeugh4uLiiIyM5OTJk8ybNw+LxcLUqVMBePnll/n4449Zu3YtAD4+PvTt27dSG15eXgQEBFQqr63d89lsNiZMmEBkZCTLly/HxcWFmJgYVq9ezZgxY+jYsSMPPvhglePy8/Mr9ZwnJyeze/duOnToQOfO9tWw586dy/Tp0xk8eDBDhw7lhRdeoKCggJkzZzb84kmjmzw4gufX7GfrkVOcHhqL/+nX7KuYK+luFlabweOfJ1SbcJd7/PMEro4JxWJ2/tQPEREREZHaOH1O9/Hjx5k6dSpZWVkEBQVxxRVX8O233xIUFATYe6DrsxVZbe2ez2w2s2DBAkaOHImb27ltiPr378+aNWuqPQZg+/btjB49uuL+3LlzAfsXFEuWLAFgypQpZGRk8Nhjj5GamsqAAQOIj4+vdt9vcb5QPw/G9Aphzd40Pi+6lNvBvpiazQpmLd7V1LYmZ1cZUn4+A0jJKWJrcjbDuwY0X2AiIiIiIvVkMgzjQp1K0grl5ubi5+dHTk4Ovr6+zg6n1Vm3L41ZS7YT5Gliq/tvMBXlwMx4iBzu7NDavE93n+D+ZbtrrffPWwbwiwEdmz4gEREREZEaOJp3aUUikZ+5qkcwYX4eZJwxOB54ds/uxC+cG9RFoLjMyuakLIfqBvvUvHOBiIiIiEhLoqRb5GcsZhNThkQA8GFBP3th4pdOjKjt+3pfOuOe38jybccuWM8EhPl5MDSqQ/MEJiIiIiLSQEq6Rapx8+AIzCb4T0o0htkVsg5Cxn5nh9XmHMkq4M4l25i5ZBuHswoJ9nFn5ogumLAn2Ocrvz8vLkaLqImIiIhIq+Fw0h0TE0N2dnbF/XvuuYfMzMyK++np6bRr165xoxNxknB/T0b3DCafdiR7n90TPnGlc4NqQwpLyvjHV4lc/dxG1u5Lx8Vs4tdXRrPuoVHMi+vDotsGEupXeQh5qJ8Hi24bqO3CRERERKRVcXghNbPZTGpqKsHBwQD4+vqye/duoqOjAUhLSyMsLAybzdZ00YpDtJBa41idkMZdb23n157r+IPxH4gYBneucnZYrZphGKz8MZW/fpHAybOrlI/sHsi8uD50C/auVNdqM9ianE16XhHBPvYh5erhFhEREZGWwtG8q95bhlWXq5tM+g+xtB2jewYR4uvOZ7n9+YMHcGwr5GeAd/VbyMmF7U/LY/5nP1UsltbR35M/Xx/DuD4h1f7tsJhN2hZMRERERFo9p+/TLdJSuVjMTBkcwYvrikl27UZU6UH7nt0Db3d2aK1KblEpL6w+wJtbDmO1Gbi7mPnNVV2ZPaorHq7a+1xERERE2jaH53SbTKYqvVHq2Za27uYhEZhM8Elhf3uBVjF3mM1msGLHccb8Yz2vf5OM1WYwrk8Ia+ZexYNX91DCLSIiIiIXBYd7ug3DYOzYsbi42A85c+YMcXFxuLm5AVBWVtY0EYo4Uaf27biqRxCr9w/iQT6EpHVQUghuWjTwQn48nsNjn+1h19HTAEQHeTE/rg9X9tDQfBERERG5uDicdM+bN6/S/V/84hdV6vzyl79seEQiLczUoZ35dWI6KQQSVpYJyRug5wRnh9UiZReU8PevElm27SiGAV5uFu4b252ZI6Jwc9EOhSIiIiJy8al30i1ysRjTK5ggHw++OjOQGS6rYN8XF2XSfaHVxK02g3e/O8I/Vu0n50wpABMHhPOHa3sT4utxoWZFRERERNo0h5PuoqIiVq1axejRo/Hx8an0WG5uLuvXr2fcuHG4u7s3epAizuRqMXPz4E6s3jCIGayyL6Zms4H54um5jd+TwuOfJ5BydpsvgDA/D+bFxRDg7c5jn/7E3pRcAHqH+fLEL/owpEsHZ4UrIiIiItJiOJx0v/LKK3z22WfccMMNVR7z9fXlxRdf5OjRo9x7772NGqBIS3DLkM78++ve5Bqe+BZkwIntEDHU2WE1i/g9KcxeupOfbxKYklPEb5burLjv5+nKQ9f04NZhkdpPW0RERETkLIe76t555x0eeOCBGh9/4IEHeOuttxojJpEWJ6JDOy7rHsp62wB7QeJKp8bTXKw2g8c/T6iScP/clCERfP3QKG4f3kUJt4iIiIjIeRxOug8cOED//v1rfLxfv34cOHCgUYISaYluHdqZNdZBABj7Lo6ke2tydqUh5TWZOKAjHbzcmiEiEREREZHWxeGku6ysjIyMjBofz8jI0LZh0qbFxoTwg+dQSg0LpsxEyEpydkhNLj2v9oS7LvVERERERC42Difdffr0Yc2aNTU+vmrVKvr06dMoQYm0RK4WMxOG9OQ7Wy97wUUwxNxscmyoeLCPVigXEREREamOw0n3rFmzePLJJ/nvf/9b5bHPP/+cv/71r8yaNatRgxNpaW4ZEsFq22AAivZU/Sy0FblFpTz95T7mvr/7gvVM2FcxHxqllcpFRERERKrj8Orld999Nxs3buSGG26gV69e9OzZE4B9+/axf/9+br75Zu6+++4mC1SkJYgM8OJ0xFhIfRO3k1uhIAu8ApwdVqMpKbPxzndHeHHtAU4V2vfb7hHizf60fExQaUG18j7weXExWjxNRERERKQGddpoeOnSpSxbtowePXqwf/9+EhMT6dmzJ++99x7vvfdeU8Uo0qJcffkQEmyRmLFhTfzK2eE0CsMwWPljCtc8v4HHP0/gVGEp3YK9eW36YL564EoW3zaQUL/KQ8hD/TxYdNtAxvcNc1LUIiIiIiItn8kwjNp2A5JWJjc3Fz8/P3JycvD19XV2OG1OSZmNN/96F3cZK0jreA0hd33g7JAaZMeRbP76xV52Hj0NQKC3O3Ov7sHNgzvhYjn3vZzVZrA1OZv0vCKCfexDytXDLSIiIiIXK0fzLoeHl5fLysoiIMA+nPbYsWO8+uqrnDlzhri4OK688sr6RyzSSri5mHGJuR5+WoHfyY1QWgSurW8hseTMAp75ch/xP6UC4Olq4e4ro7n7ymi83Kv+abCYTQzv2naG0ouIiIiINAeHk+4ff/yRuLg4jh07Rvfu3Vm2bBnjx4+noKAAs9nM888/z4oVK5g4cWIThivSMlx1VSwpezoQRjaZe1YTeGmcs0NyWFZ+MS+uPcA73x2lzGZgNsGUIRE8GNuDYN/W9+WBiIiIiEhL5vCc7ocffphLLrmEjRs3MmrUKK6//nquu+46cnJyOHXqFL/+9a95+umnmzJWkRYjOtiHPV6XA3Dy24+cHI1jikqtLPz6IKP+vp43txyhzGYwplcw8Q9cyVM39lPCLSIiIiLSBBye0x0YGMi6devo168f+fn5+Pr6sm3bNgYNGgTYVzG/7LLLOH36dFPGKw7QnO7mseWrZQzf8msyaE/7/zuIi0udZ2s0C6vN4ONdJ3h2VSIpOUUA9O3oyx+v7c3lXQOdHJ2IiIiISOvU6HO6s7OzCQ0NBcDb2xsvLy/at29f8Xj79u3Jy8trQMgirculV95AwZb7CeIU275dx5ArrnF2SFX870AGC1buY29KLgAd/T35/bie3NA/HLMWQRMRERERaXJ16pozmUwXvC9yMfHwbEdC++HEnPqatG2fQDMn3RdaTXxvSi5PfbmPjfszAPDxcOHe0d2YfnkXPFwtzRqniIiIiMjFrE5J94wZM3B3dwegqKiI3/zmN3h5eQFQXFzc+NGJtHAdBk6CtV/T/dRGUnOKquxl3VTi96Tw+OcJFcPFAcL8PLhvbHd2HjnFip3HMQxwtZi4/bIu/HZMN9p7uTVLbCIiIiIico7Dc7pnzpzpUINvvPFGgwKShtOc7mZUmI31b12xYGPJ4E+Ycf3oJj9l/J4UZi/dSW0f3Ov6hfHwuJ5EBng1eUwiIiIiIhebRp/TrWRapBrtOpAdOJigzK3k7P4M67WjKoZ4NwWrzeDxzxMumHC7WUy8e9dlDO7SocniEBERERERxzi8ZZiIVM9/wA0ADCn+lo0HMprkHDabwZGsAhZ+fbDSkPLqlFgNSq0ODWAREREREZEm1jL3OBJpRVxjroM1/8dQ8z5+tWYXuWf6VlnYrC5OF5awLzWPxNQ89qXmVvxeWGJ1uI30vAsn5iIiIiIi0jyUdIs0VIdoTnl1pX1BEn4n1nP/sjLAvrDZvLgYxvcNq/awkjIbSRn5JKbmsTc1155kp+SRmlt9wuzmYibcz4PDWYW1hhTs0zwLuomIiIiIyIUp6RZpoPg9KSTl9GWOSxJXW3bwqe0KAFJzipi9dCf/mjaQ/hH+VZLrpIx8ymzVDwPv1N6TXqE+9Ar1pWeoD73DfOgS4IXJZOKKZ9aRmlNU7bxuExDqZ+9lFxERERER51PSLdIA5QubhVgHMcflU8aYdzHJvJEUAtlq64UNM/e8U/NK4z7uLvQK86Hn2QS7d5gPPUJ88PFwrfGc8+JimL10Jyao1K7pvMebcjE3ERERERFxnJJukQbYmpxNSk4R/c1ZWA0T7UwlPO+2GICTRgceL72Dr2xDMZugW7A3PUN9z/Zg+9ArzJdwPw9MprolyOP7hrHotoFV9ukOrWU4u4iIiIiIND8l3SINkJ5XxDjzVv7l+k9+njqHks0i1xeYXfoA1/zyV/xyUESjnXd83zCujglla3I26XlFDVq4TUREREREmo6SbpEGCPZyZZ7rWwD8vMPabAKbAfNc3+aI75xGP7fFbGJ414BGb1dERERERBqPkm6RBhhq2YfFlF3j42YThJNFiGUfENx8gYmIiIiISItgdnYAIq2ZpSC9UeuJiIiIiEjboqRbpCG8Qxq3noiIiIiItClKukUaIvJy8A2HKsuoncfDz15PREREREQuOkq6RRrCbIHxz5y9U0PiXZQDa58Ao6bdukVEREREpK1S0i3SUDE3wM1vge/P9sf27Qj9brb//s0L8Nm9YC1r9vBERERERMR5tHq5SGOIuQF6XQdHNkN+mn0Od+Tl9p7wLiPh8/th11IozIabXgdXT2dHLCIiIiIizUBJt0hjMVsgamTV8oF3QLsA+GAmJK6Et2+Eqe+Bp3+zhygiIiIiIs1Lw8tFmkOv6+D2j8HdF45uhiXXQV6qs6MSEREREZEmpqRbpLl0GQEzV9qHnqftgdeugawkZ0clIiIiIiJNSEl3KzBp0iTat2/PTTfd5OxQpKFCL4FZX0H7KDh9BF4fByd3OzsqERERERFpIkq6W4H777+ft956y9lhSGPpEAV3roLQflCQAUuuh0MbnB2ViIiIiIg0ASXdrcCoUaPw8fFxdhjSmLyDYcYX9pXNS/LgnZsg4VNnRyUiIiIiIo2sxSfd8+fPx2QyVbr16tXL4eOffvppTCYTDzzwQKPHtnHjRuLi4ggPD8dkMvHJJ59UqbNw4UK6dOmCh4cHw4YNY+vWrY0eh7RSHr4wbQX0jgNrCbw/Hba/7uyoRERERESkEbX4pBugT58+pKSkVNw2bdrk0HHbtm3jlVdeoV+/fhes980331BaWlqlPCEhgbS0tBqPKygooH///ixcuLDax5cvX87cuXOZN28eO3fupH///owbN4709PSKOgMGDKBv375VbidPnnToOUor5+oBk9+EQTMAA/77IGz4GxiGsyMTEREREZFG0Cr26XZxcSE0NLROx+Tn5zNt2jReffVV/vKXv9RYz2azMWfOHLp3786yZcuwWCwAJCYmMmbMGObOncvDDz9c7bETJkxgwoQJNbb93HPPcddddzFz5kwAFi9ezBdffMHrr7/Oo48+CsDu3bvr9LykDTJb4PoXwCsYNv4Nvv6rfa73+GfA3Cq+FxMRERERkRq0iv/RHzhwgPDwcKKjo5k2bRpHjx6t9Zg5c+Zw3XXXERsbe8F6ZrOZlStXsmvXLu644w5sNhtJSUmMGTOGiRMn1phw16akpIQdO3ZUOr/ZbCY2NpYtW7bUq83aLFy4kJiYGIYMGdIk7UsTMplgzJ9gwt/s97f+Gz76FZSVODcuERERERFpkBafdA8bNowlS5YQHx/PokWLSE5OZuTIkeTl5dV4zLJly9i5cydPPfWUQ+cIDw9n3bp1bNq0iVtvvZUxY8YQGxvLokWL6h13ZmYmVquVkJCQSuUhISGkpqbWqa3Y2FgmT57MypUr6dSpU41J+5w5c0hISGDbtm31jlucbNiv4ZevgdkV9nwI702B4nxnRyUiIiIiIvXU4oeXnz98u1+/fgwbNozIyEjef/997rzzzir1jx07xv3338/q1avx8PBw+DydO3fm7bff5qqrriI6OprXXnsNk8nUKM+hodasWePsEKQ5XXITeLaH5bdD0jp4M86+4JpXgLMjExERERGROmrxPd0/5+/vT48ePTh48GC1j+/YsYP09HQGDhyIi4sLLi4ubNiwgRdffBEXFxesVmu1x6WlpXH33XcTFxdHYWEhDz74YIPiDAwMxGKxVFmILS0trc7z0+Ui1G0sTP8cPDvAyZ3w+jg4Xfu0ChERERERaVlaXdKdn59PUlISYWFh1T4+duxYfvzxR3bv3l1xGzx4MNOmTWP37t0VC6WdLzMzk7Fjx9K7d28++ugj1q5dy/Lly3nooYfqHaebmxuDBg1i7dq1FWU2m421a9cyfPjwercrF5FOg2DWV+DbCbIOwGvjIH2vs6MSEREREZE6aPFJ90MPPcSGDRs4fPgwmzdvZtKkSVgsFqZOnQrAyy+/zNixYyvq+/j4VNl+y8vLi4CAAPr27VulfZvNxoQJE4iMjGT58uW4uLgQExPD6tWreeONN3j++edrjC0/P78isQdITk5m9+7dFQu9zZ07l1dffZU333yTvXv3Mnv2bAoKCipWMxepVVAPuHMVBPaEvJPw+ng4pr3eRURERERaixY/p/v48eNMnTqVrKwsgoKCuOKKK/j2228JCgoC7L3USUlJ9W7fbDazYMECRo4ciZubW0V5//79WbNmTcV5qrN9+3ZGjx5dcX/u3LkATJ8+nSVLljBlyhQyMjJ47LHHSE1NZcCAAcTHx1dZXE3kgvw6wqx4ePdmOL4N3rwBbn7LPgT9yGbITwPvEIi83L79mIiIiIiItBgmwzAMZwchjSs3Nxc/Pz9ycnLw9fV1djjSWEoK4P3pcHA1YAYPPyg6de5x33D73t4xNzgtRBERERGRi4WjeVeLH14uIme5ecHU9yByBGCrnHAD5KbA+3dAwmdOCU9ERERERKpS0i3SmpjMcCq5hgfPDlqJfxRs1a/SLyIiIiIizUtJt0hrcmQz5J68QAUDck/Y64mIiIiIiNMp6RZpTfLTaq9Tl3oiIiIiItKklHTL/7d35/FR1ff+x98zk4UtAUIgC0gEQSAswSLEIMgWgVQRUCqlFKJytVK0SgSU9rr1tsVrFbWWH/SKslgXFsW2KAiiBGUXiUKFFCIYlCQsSjaWhMz5/XFCyGSdhExOMvN6Ph7nkZlzvnPO54zTKe/5fs/3oDFp4ebM9+62AwAAAOBRhG6gMYkaaM5SLlvlbZq2NtsBAAAAsByhG2hM7A7ztmCSKg3e57Kl/3xYbyUBAAAAqByhG2hsom+T7lwuBUe4rg9uL0UNkuSUVt0lfZNsRXUAAAAASrEZhmFYXQTqlrs3aUcj5ywyZynPyzKv4Y4aKBmGtCpROrhW8m8uJf5T6nC91ZUCAAAAXsfd3EVPN9BY2R1Sp8FS7wnmX7tDcvhJE16TOg+VCvOlv98hZX1tdaUAAACAzyJ0A97GL1Ca+IbUob90/oz0+jjph2+srgoAAADwSYRuwBsFtpAmr5La9TSHny8fK+Uct7oqAAAAwOcQugFv1bS1NGWNFNJZOpMuLR8n5Z+2uioAAADApxC6AW8WFCZNeU8KipROpUp/v106n2N1VQAAAIDPIHQD3q51lDT1PalZGykjRXrr51LhOaurAgAAAHwCoRvwBW27Sb98VwoMlr7dKq1MlIoKra4KAAAA8HqEbsBXRPaVfrFC8msiHfpQWvMr817fAAAAADyG0A34kqiB0sS/S3Y/af870vuPSIZhdVUAAACA1yJ0A76m683S7a9Iskl7lkgfPWV1RQAAAIDXInQDvqjX7dKYl8zHW1+UPp1vaTkAAACAtyJ0A76qX6I08g/m401PS7sXW1sPAAAA4IUI3YAvG/igdNNs8/H7s6SvVlpbDwAAAOBlCN2Arxv2O2nAfZIMac39Uuo6qysCAAAAvAahG/B1Nps0+n+lPj+XjCLzHt5HtlhdFQAAAOAVCN0AJLtdGrtA6naLVHRBemuS9N0eq6sCAAAAGj1CNwCTw0+a8JrU6SapIE964w4p62urqwIAAAAaNUI3gMv8m0g/f1Nqf7107kfp9fHSD99YXRUAAADQaBG6AbgKDJImr5LaRUt5mdLycVJOhtVVAQAAAI0SoRtAec1CpClrpNadpDPfSq+Pk/JOSkc+lfatNv86i6yuEgAAAGjw/KwuAEADFRQuTf2H9Npo6eRBaX4PyVl4eXtwpDnrefRt1tUIAAAANHD0dAOoXOso6caHzMelA7dkDjlfOVX6+p/1XxcAAADQSBC6AVTOWSRte6mSjYb5Z/1jDDUHAAAAKkHoBlC5b7dJOceraGBIOd+b7QAAAACUQ+gGULm8rLptBwAAAPgYQjeAyrUIq9t2AAAAgI8hdAOoXNRAc5Zy2apoZJPO59ZXRQAAAECjQugGUDm7w7wtmKTywfvSc0NaOVnavbgeCwMAAAAaB0I3gKpF3ybduVwKjnBdHxwpTVgqXfdLyXBK7z8ibXhccjotKRMAAABoiPysLgBAIxB9m9T9FnOW8rws8xruqIFmT3jPcVKrq6VP/iBt+4uUfUwat0jyb2J11QAAAIDlCN0A3GN3SJ0Gl19vs0lDZkutOkr/mCH9e42UkyFNektqFlL/dQIAAAANCMPLAdSNmInSlHelwJbSsR3S4njph2+srgoAAACwFKEbQN3pdJM0bYPUsqP0Q5q0+Gbp2G6rqwIAAAAsQ+gGULfadZf+6yMpoq909pS07FbpwL+srgoAAACwBKEbQN0LCpPuel+6drR08by0Yoq0/f9ZXRUAAABQ7wjdADwjsIU08Q3p+mmSDOnDudK6RyVnkdWVAQAAAPWG0A3Acxx+0i3PSzf/3ny+c5HZ611w1tq6AAAAgHpC6AbgWTabdOND0oQlkiNQSn3fvM4776TVlQEAAAAeR+gGUD963S5N/YfUtLX0/R5p8Qjp1CGrqwIAAAA8itANoP5ExUnTPpJaXy2d+da8l/e326yuCgAAAPAYQncjMH78eLVu3VoTJkywuhTgyoV2kf5rk9Shv3T+jLR8rLRvtdVVAQAAAB5B6G4EHnroIS1fvtzqMoC60zxUSvyX1P1WqahAemea9NkLkmFYXRkAAABQpwjdjcDQoUMVFBRkdRlA3fJvKt25XLrh1+bzj56S1s6Uii5aWhYAAABQlywP3U899ZRsNpvL0r179ypfs3DhQvXp00fBwcEKDg5WXFyc1q1bd8X7raktW7ZozJgxioyMlM1m03vvvVdhuwULFujqq69WkyZNFBsbq127dtVpHUCjZXdIo+dJo/9Xkk3as0R66+fShVzzft5HPjWHnh/5lPt7AwAAoFHys7oASerZs6c++uijkud+flWX1aFDBz3zzDPq2rWrDMPQsmXLNHbsWO3du1c9e/as1X63bt2qAQMGyN/f32X9119/rTZt2igsLKzca/Lz8xUTE6N77rlHt99+e4X7XbFihZKSkrRo0SLFxsbqxRdf1KhRo5Samqp27dpJkvr27auLF8v37m3YsEGRkZFVvheAV7jhfqllB+md/5IOb5QW3ihdvCDlZV5uExxphvPo26yrEwAAAKihBhG6/fz8FB4e7nb7MWPGuDz/4x//qIULF2rHjh0uodvd/TqdTs2YMUNdu3bV22+/LYfDIUlKTU3V8OHDlZSUpDlz5pR7XUJCghISEqrc9/z583Xvvffq7rvvliQtWrRI77//vl577TU99thjkqSUlJRqawS8Xo9bpbveNydWO/Nt+e05GdLKqeaQdII3AAAAGgnLh5dL0qFDhxQZGanOnTtr8uTJSk9Pd/u1RUVFevvtt5Wfn6+4uLha7ddut+uDDz7Q3r17NXXqVDmdTqWlpWn48OEaN25chYHbHQUFBdqzZ4/i4+NdjhUfH6/t27fXap9VWbBggaKjo9W/f/863zdQLyL7SgHNKtlYPMna+scYag4AAIBGw/LQHRsbq6VLl2r9+vVauHChjhw5osGDBys3N7fK1+3bt08tWrRQYGCg7r//fq1Zs0bR0dG13m9kZKQ+/vhjffbZZ/rFL36h4cOHKz4+XgsXLqz1uZ06dUpFRUXlhqaHhYUpMzOzkleVFx8fr5/97Gf64IMP1KFDh0oD+4wZM/T1119r9+7dta4ZsNS326S8rCoaGFLO99zbGwAAAI2G5cPLSw/P7tOnj2JjYxUVFaWVK1dq2rRplb6uW7duSklJUXZ2tlavXq3ExEQlJyeXBO/a7Ldjx456/fXXNWTIEHXu3FmvvvqqbDZbHZ1p7ZW+Lh3walUG7lq0AwAAACxmeU93Wa1atdK1116rw4cPV9kuICBAXbp0Ub9+/TRv3jzFxMTopZdeuqL9ZmVl6b777tOYMWN09uxZzZw5s9bnIUmhoaFyOBzKynINCFlZWTW6hh3wGS3KT1hYoRMHJKfTs7UAAAAAdaDBhe68vDylpaUpIiKiRq9zOp26cOFCrfd76tQpjRgxQj169NC7776rTZs2acWKFZo1a1aN6igtICBA/fr106ZNm1zq3LRpU7nrzwFIihpozlKuakaYfPqctHi4dPSzeikLAAAAqC3LQ/esWbOUnJyso0ePatu2bRo/frwcDocmTZokSfrrX/+qESNGuLxm7ty52rJli44ePap9+/Zp7ty52rx5syZPnuz2fktzOp1KSEhQVFSUVqxYIT8/P0VHR2vjxo1asmSJXnjhhQprz8vLU0pKSsns40eOHFFKSorLhG1JSUl65ZVXtGzZMh04cEDTp09Xfn5+yWzmAEqxO4rv2S2VD942c+k1QQpoIR3fKy29RXrrF9KpQ/VcKAAAAOAey6/p/u677zRp0iSdPn1abdu21aBBg7Rjxw61bdtWktkDnZaW5vKaEydOaOrUqcrIyFDLli3Vp08fffjhh7r55pvd3m9pdrtdf/rTnzR48GAFBASUrI+JidFHH31U4Wsk6fPPP9ewYcNKniclJUmSEhMTtXTpUknSxIkTdfLkST3xxBPKzMxU3759tX79+grv+w1A5u3A7lwurX9Uyjl+eX1wpDT6GXN73glp8zPSnqVS6vvSf9ZL198jDX1Mah5qWekAAABAWTbDMAyri0DdysnJUcuWLZWdna3g4GCrywFqx1l0eTbzFmHm0HO7w7XNyVRp45PSf9aZzwOCpMFJ0g3TJf+m9V8zAAAAfIa7uYvQ7YUI3fA5R7ZIG/5byvjSfB7cQRrxhNT7Z5Ld8qtoAAAA4IXczV38axRA49fpJunezdL4/zMDd8530pr7pFeGSkc+tbo6AAAA+DBCNwDvYLdLMROlBz+XRjxpDjXP+FJadqv05s/NoegAAABAPSN0A/Au/k3N67ofSpH63yvZHOY13/8vTlqbJOWdtLpCAAAA+BBCNwDv1DxUuuU5acZOqdstklEkff6q9JfrpC3PSYXnXNs7i8yh6PtWm3+dRdbUDQAAAK/CRGpeiInUgAoc/cycbO34XvN5cHtp+ONSn4nSwbWV3KLsf81blAEAAABlMHu5DyN0A5VwOqX970ibnpayj5nrWkVJZ76toLHN/HPncoI3AAAAymH2cgAoy26X+vxMeuBzKf5pc7K1CgO3JBX/Hrn+MYaaAwAAoNYI3QB8j38TadDD0vi/VdPQkHK+l77dVh9VAQAAwAsRugH4rovnqm8jSXlZnq0DAAAAXsvP6gIAwDItwtxr98mfpNwMqdcd5gRrAAAAgJvo6Qbgu6IGFodoW9XtfkgzZz6fHy0tvVXas1Q6+0N9VAgAAIBGjtANwHfZHeZtwSSVD942cxn7/6Rb5ksdB0oypKOfSv96SHruWumtSdL+d6WCs/VbNwAAABoNbhnmhbhlGFBDX/+zgvt0t5dGP+N6u7Azx8xbju1bLWXtu7w+oIXU/Vap98+kzkMkh3/91Q4AAABLcJ9uH0boBmrBWWTOUp6XZV7rHTXQ7AmvzIkD0r5V5nIm/fL6ZqFSz/FmAL9qgGSrZOh6TY8HAACABoXQ7cMI3UA9Mgzpu91m+N7/rnT21OVtrTpKvSaYATws+vL6CnvWI82h7qV71gEAANBgEbp9GKEbsEjRRenIZnP4+YF/SQV5l7e16yn1niA1bSWtTZJU9qu3uEf8zuUEbwAAgEaA0O3DCN1AA1BwVjr0ofTVKunQBslZ6MaLbGaP98P7GGoOAADQwLmbu7hPNwB4QkAz89runuOlcz+aQ8p3veI6AVs5hpTzvXmtd6fB9VYqAAAAPIdbhgGApzVtLfVLlAY97F77vCyPlgMAAID6Q+gGgPrSIsy9drmZ5gRtAAAAaPQI3QBQX6IGmtdsq5LbiF2y4XfSkgQp7WPCNwAAQCNH6AaA+mJ3mLcFk1Q+eNvMpcvNkiNQSt8uvT5eevVm6dBGwjcAAEAjRegGgPoUfZt5W7DgCNf1wZHm+l+ulh76UoqdLvk1Me8B/sYE6ZXhUup6wjcAAEAjwy3DvBC3DAMaAWeROUt5XpZ5rXfUwPK3CcvNkrb9Rdr9qnTxnLkuvI805FGp+y2SrZph6gAAAPAY7tPtwwjdgJfJOyltf1natVgqzDfXhfWWhsyWuo+R7AxaAgAAqG+Ebh9G6Aa8VP5paccCaef/SQW55rp20dJNs6XoseV7ygEAAOAxhG4fRugGvNzZH6QdC6Wdi6QLOea60G5m+O51O+EbAACgHhC6fRihG/AR585IO/9m9n6fzzbXtelSHL4nSA6/y23duYYcAAAAbiN0+zBCN+BjzmdLu/5P2r5AOvejua51J+mmWVKfiVLqOmn9o1LO8cuvCY40b18WfZs1NQMAADRyhG4fRugGfNSFXGn3Ymnby9LZ0+a6Zm2lsycraFw88/mdywneAAAAteBu7mLKWwDwFoFB0qCZ0kNfSTf/j9QstJLALUnFv7euf8wceg4AAACPIHQDgLcJbCHd+Btp/N+qaWhIOd+b13oDAADAIwjdAOCtzp9xr11elkfLAAAA8GWEbgDwVi3C3GtXVOjZOgAAAHwYoRsAvFXUQHOW8kuTplXmvV9L7z8i5Z+ql7IAAAB8CaEbALyV3WHeFkxS+eBd/DziOklOc9bzl/pKn86XCs/XX40AAABejtANAN4s+jbztmDBEa7rgyOlO1+XfrVZSvyXFBEjFeRKm56W/nq99NUqyem0pGQAAABvwn26vRD36QZQjrPInKU8L8u81jtqoNkTXrLdKX21Qtr0eyn3uLku8ifSqD+abQEAAODC3dxF6PZChG4AtVZwVtqxQPrsRakgz1zX/VYp/mkptIulpQEAADQk7uYuhpcDAC4LaCbdNFv6zV6p392SzS4dXCv9v1hp3aPS2R+srhAAAKBRIXQDAMpr0U4a86I0fZvUdaTkvCjtXGROtrb1L9LFC1ZXCAAA0CgQugEAlWvXQ5q8SprynhTWS7qQLW183Jxsbf87ElcoAQAAVInQDQCo3jXDpF9tkcYukFqES2fSpdX3SK/eLKXvtLo6AACABovQDQBwj90hXfdL6TdfSEN/K/k3k77bLb02Ulo5Vfrhm8ttnUXSkU+lfavNv84i6+oGAACwELOXeyFmLwdQL3IzpY//IO39uyRDsvtLA+6TwntJH/+PlHP8ctvgSGn0/5r3DQcAAPAC3DLMhxG6AdSrzP3mdd5pH1fRyGb+uXM5wRsAAHgFbhkGAKgf4b2kKWukSSslu18ljYp/313/GEPNAQCAT6nsX0cAANRMQDPz1mKVMqSc76W/3yF1jJNCOkmtO0khnaVmIZLNVvtjO4ukb7dJeVlSizApaqB5DToAAIDFCN0AgLqRl+Veu28+MZfSAoOl1lebAbwkjBcH8qBIyV7FwKyv/ymtf5RryAEAQINE6G4Exo8fr82bN2vEiBFavXq11eUAQMVahLnX7ropkgzph6PmjOe5x6ULOVLmV+ZSliNQah1lBvDSYbx1J7P96ntUMnz9kpwMc0Z1riEHAAAWYyK1RmDz5s3Kzc3VsmXL3ArdTKQGwBLOIunFXmbgLRuCJUk2swf64X2uQ78Lz0k/fmsG8B+PSD8cKf77jXk/8CqHrFelkuMBAADUAXdzFz3djcDQoUO1efNmq8sAgKrZHeaQ7pVTZc5WXjp4F1+vPfqZ8gHYv6nUrru5lFV0Ucr5zgzipUP5D0ek04elogtVFFR8Dfm326ROg6/s3AAAAGqpwc9e/tRTT8lms7ks3btX8A+zUhYuXKg+ffooODhYwcHBiouL07p16+q8ti1btmjMmDGKjIyUzWbTe++9V67NggULdPXVV6tJkyaKjY3Vrl276rwOAGgwom8zh3QHR7iuD46s3VBvh595rfc1w6T+06SRf5B+/ob0623S2AXu7WPnIjOkAwAAWKBR9HT37NlTH330UclzP7+qy+7QoYOeeeYZde3aVYZhaNmyZRo7dqz27t2rnj17lmu/detWDRgwQP7+/i7rv/76a7Vp00ZhYRVfp5ifn6+YmBjdc889uv3228ttX7FihZKSkrRo0SLFxsbqxRdf1KhRo5Samqp27dpJkvr27auLF8sPndywYYMiIyOrPE8AaJCib5O63+L52cSDwt1rd3CtuVw9WPrJVKnHGLN3HQAAoB40itDt5+en8HA3/3ElacyYMS7P//jHP2rhwoXasWNHudDtdDo1Y8YMde3aVW+//bYcDvMfhampqRo+fLiSkpI0Z86cCo+TkJCghISESuuYP3++7r33Xt19992SpEWLFun999/Xa6+9pscee0ySlJKS4vZ5AUCjYXd4fkh31ECzB72qa8ibtpYiYqRvNktHPzWXwJZS7wnST6ZIEX2v7FZlAAAA1Wjww8sl6dChQ4qMjFTnzp01efJkpaenu/3aoqIivf3228rPz1dcXFy57Xa7XR988IH27t2rqVOnyul0Ki0tTcOHD9e4ceMqDdzVKSgo0J49exQfH+9yrPj4eG3fvr1W+6zOggULFB0drf79+3tk/wDQoFy6hlxSyTXjJYqfj3lJmvqe9PBX0tC5UsuO0oVs6fNXpf8bKi0aLO1YJJ39of7qBgAAPqXBz16+bt065eXlqVu3bsrIyNDTTz+t77//Xvv371dQUFClr9u3b5/i4uJ0/vx5tWjRQm+++aZ++tOfVto+PT1dgwcPVlxcnLZv366hQ4dq6dKlsrnZA2Kz2bRmzRqNGzdOknT8+HG1b99e27Ztcwn7c+bMUXJysnbu3OneGyApPj5eX375pfLz8xUSEqJVq1ZV+APCJcxeDsCnVHif7vbmpG1lryF3OqUjydLe16UDay9PxOYIkLrfavZ+dxpa9X3BAQAA5EWzl5cevt2nTx/FxsYqKipKK1eu1LRp0yp9Xbdu3ZSSkqLs7GytXr1aiYmJSk5OVnR0dIXtO3bsqNdff11DhgxR586d9eqrr7oduD2t9PXsAIAyanINud1uTsp2zTCzd3vfamnvcilzn/Tvd82l5VVS38nSdZOlVh0rPqazyPPXrAMAAK/Q4EN3Wa1atdK1116rw4cPV9kuICBAXbp0kST169dPu3fv1ksvvaS//e1vFbbPysrSfffdpzFjxmj37t2aOXOmXn755VrXGRoaKofDoaysrHLHqcn16QAAN9TmGvJmIVLsfeaS8aX0xevSvpVS9jEp+Rkp+X+lzkOk66aYveD+TczXVdizHmkOda/p7OwAAMDrNbrxc3l5eUpLS1NERET1jUtxOp26cKHi+7meOnVKI0aMUI8ePfTuu+9q06ZNWrFihWbNmlXrOgMCAtSvXz9t2rTJpYZNmzZVOTQcAGCBiBjpluekR1KlO16VOg2RZJgTsL0zTXq+m/TBbGnry+Z9yEsHbsmczG3lVDOQAwAAlNLge7pnzZqlMWPGKCoqSsePH9eTTz4ph8OhSZMmSZL++te/as2aNS7hdu7cuUpISFDHjh2Vm5urN998U5s3b9aHH35Ybv9Op1MJCQmKiorSihUr5Ofnp+joaG3cuFHDhw9X+/btNXPmzApry8vLc+lxP3LkiFJSUhQSEqKOHTsqKSlJiYmJuv766zVgwAC9+OKLys/PL5nNHADQwPg3NWc27z1B+vGolPKmtPcNKec7adf/VfFCQ5JNWv+YOdSdoeYAAKBYgw/d3333nSZNmqTTp0+rbdu2GjRokHbs2KG2bdtKMnup09LSXF5z4sQJTZ06VRkZGWrZsqX69OmjDz/8UDfffHO5/dvtdv3pT3/S4MGDFRAQULI+JiZGH330UclxKvL5559r2LBhJc+TkpIkSYmJiVq6dKkmTpyokydP6oknnlBmZqb69u2r9evXV3rfbwBAA9L6amnYb6Uhj0rffCJ99oJ09LMqXmBIOd+b13p7+nZpAACg0Wjws5ej5pi9HAA8YN9qc6h5da4eLPW6Q2rfT2oXLTka/O/bAACgFrxm9nIAABqEFm6OUjr6qblIkl9T83rx9j8xQ3j7n0itO0k1vTsGs6UDANBoEboBAHBH1EBzlvKcDJnXcJdlk5q2ln4yVTq+11wu5EjHdpjLJU1bS5GXQnhxEG/RrvLjMls6AACNGsPLvRDDywHAQ77+pzlLuSTX4F3cc33n8stB2OmUfkiTvt9zecncJxUVlN9vy6tK9Yb3M3vHA4NKHa/s/1VXcDwAAFCv3M1dhG4vROgGAA+qsOe5vTT6meoD8MUCKWu/GcCP7zX/nkxVhaE6tJuUnS4Vnq1kZzazx/vhfQw1BwDAAoRuH0boBgAPq8trrM/nSBlfluoR/8K8RZm7EtcyWzoAABZgIjUAADzF7qi7oNsk2NxX6f3lZknbXpa2v1z967c8Z4b/jnFSy/Z1UxMAAKgzhG4AABqaoDDp2lHuhe4jm81Fklp1lDoOlKLizL+hXWs+UzoAAKhThG4AABoid2dL73OnlL5DyvxKOpNuLl+9bTZpFip1vMHcV8c4KbyPe/cN5xZlAADUGUI3AAANkd1h3hZs5VSZs5VXMFv6mJcuT952IVc6tktK3y59u136/nPp7Cnp4FpzkaSAFlKH/pdDeIfrJf+mrsflFmUAANQpJlLzQkykBgBepLazpV+8IB1PkdK3mSE8fYd0Idu1jd1firzu8nD0cz9K700XtygDAKB6zF7uwwjdAOBl6mK4t9Mpnfi6uCd8qxnE8zJrsANuUQYAQGmEbh9G6AYAVMswpB+PFPeCb5MOfyzlHq/+dYOSpO63SG26SE1b1U0tXEMOAGiECN0+jNANAKixfauld6bV7DXN20ptukptrjFnSm/T1fzb+mrJ4e/ePqy4hpyQDwCoA9ynGwAAuK9FmHvtwnpL+SfNoen5J80lfZtrG5vDDN6hXc0e8TZdLofyFu0u38bs638WTxRX5vf/nAxzvSeuIWeiOABAPaOn2wvR0w0AqDFnkfRir6pvUVb6mu4LudLpw9Kpw9LpQ8WPD0mn06TC/MqPExhs9oyHXCMd+tDcT4U8cA15ZSGfieIAALXA8HIfRugGANRKSSiVKrxFmTuh1DDMXuTTxWG8dCg/ky4ZzprVFNxBatLSDN4Of8nuZ8667vK8eCn9vGxbu0PatVgqqMeQDwDwaoRuH0boBgDUWm1vUeaOwvPm5G2nDkn/XiP9+90r258nJK6VOg22ugoAQCNA6PZhhG4AwBWpj4nGjnwqLbu1+naj5kntepg1OQsl50WpqPhv2cdVPT9xQErbVP3xWneSfjJV6jHGvA4dAIBKELp9GKEbANDg1fQa8ivlbsgvLfRaqfut5hJ5nWS3X3kdAACv4W7u4v89AABA/bM7zBnDJZVcM16i+PnoZ+quhz1qoBniyx2r1DGDwqWfPiddM8K8FvzUf6TP5kuLh0sv9JTef0RK+8TsPQcAwE30dHsheroBAI2GJ68hr+hY7k4Ud+6MdPgj6cC/zL8FeZebN2kpXTta6n6L1CVeCmhe9XG5LzgAeCWGl/swQjcAoFGpz1Bam5BfeF46kiwdXCsd/EA6e+ryNr8mUudhUo9bpWsTpOZt3Dge9wUHAG9A6PZhhG4AAKpwJSHfWSQd21UcwNdKPx69vM1mlzoONAN4t59KGV9ac19wetYBoF4Qun0YoRsAgHpgGNKJr6UDxQE88yvX7XZ/c8b1CnnovuD0rANAvSF0+zBCNwAAFvjxWyn1AzOEf7tVFc/KXsaA+6XwXpJ/U/PacP+mkn+zUn+bXd7m8K96XyXXrNdzzzoA+ChCtw8jdAMAYLHPl0hrH67bfdr9KgnkzSS/puZ15xfPV/JiD/WsS94/nN3bzw9Arbmbu/zqsSYAAADf0KaLe+2uHiT5N5cKz0qF54r/Xnp8TirIl4wis63zonQhx1xqzJByvjdvfRZ6rdTqKqlVlNTyquLHHaWgSMlRw38aevtwdm8/PwD1gp5uL0RPNwAAFnMWSS/2knIyVPEwczd7ng3DvC+4Sxg/KxWUeX5ki/TFsiur2eYwa2pZHMJbXVXqcUepZQfJL/Bye6uGs9dXzzPD9QFUg55uAAAAq9gdZm/oyqkyQ1oF9wUf/Uz1YdFmk/wCzKVpq8rbtQhzL3SPmic1bS1lH5POfCudOWY+zv5OKioofnxMSt9WyXHCzTAe3EE6vFEV/6BgmOe4/jHzXuaNcaK4iwXSutmq9/OT6n84u7cfD2gA6On2QvR0AwDQQNTmvuC1caU9606nGYKyj0ln0s0l+9jlUH4m3exRr6mwXmYveZOWpZZWZZ6XWgKDJbu94n3Vpue5qFA6d0Y692MVyw/l153Pdu/82kVLbbtJQRFSUPjlvy3Czb+BQeYPJ+6q7+Hs3n48X+DtP2I08PNjIjUfRugGAKABqffh0FKFPetXMhzaMKSzP0jZxYH8wFpp38orqbYSNjN4lwvjQdLBf5nXuFfGr6l01QDp/BkzOJ/9USrI9UCNNeDf3DWMuzwutS6gef0PZ/f2413izT35VvyI4e3nV0OEbh9G6AYAwEfVV8/6kU+lZbdW3+6mR6XgCLPnuLrl4rm6q6+sJi3NYfXllpCK159MlVb+svr9DnnUbJ+bIeVmlvqbWbMJ7wKCzPN3Xqy8TdPW0k//LPk1kRyB5iUHjoAyjwPM6+7LPi7b214yMuJ4xceq69nu6/t4l3hzT74VP2J4+/nVAqHbhxG6AQDwYfXRE1VXE8WVVnjeDKolQfzM5cdHP5P2v1P9Pvr/l3TtaNcA3aRlzc+/Ls7vQp7536B0EC/3OKN2w/Zryu5fHMD9zZBuOKX8E9W/LrS71CTIHOkgSTKKHxc/v/TYZbvKb7+QZ46SqE6vO8wh+4HBUpNgc4RDyVLquV+T6ofte3NPvhU/Ynj7+dUSoduHEboBAIDHeXI4e1nu9qwnrpU6Da6bY9bH+RmGdCFX2rNM2vjf1bcP7Wb+iFBUYC4XL5jXrRddcH1cVY+5N7D7VxzGLwX1gObSnqXme1uZpiHmyAHJ/BGiysUwg2Bl251F0vaXqz5eQAspZlKZ4xVd3n/Z/ZU9vlFq3dnT0vG91b9PXUdJraNKjXooHhXh16Rm6+x+0uLh5o9FFbKZl0n818eSnMWfw0LJWVjN4wLzs1r28an/uDcxZF3+772WCN0+jNANAADqRWOZKK62GtpwfXdDhtNZHMyLg/jFC66Pj+2WPkiqfj/DfieF9ZRkK9WzfOlx8fNLj0s6nivYnrlf2vC76o/XY5zZs34ht3jJKfW4eKnwvz980h2vSr0nWFoCtwwDAACAZ0XfZt42y9PD2evqFmw1VV/nFzXQ/NGguh8Voga6tz+7XbI3kfybVLw9rKf02XPVH2/wI3VzrlcPlnYsqP54P3ut6uM5nVJhvhm+z+dUEsxzpO/3SIc2VF9XaDcpKMy8R73NXsFic31uL9uuePuPR6UjW6o/XrdbpPBele+/XB22io976pD02fzqj9f3l+acChfPm7fBK7pQ6u+F4tESFW279Ld428XzcvvHDkeAORLBUbyUe+zn2sZe/Lzksb85CWLaR9Ufq0WYezU1AIRuAAAA1J7dUT9DPKNvM4d0VziRUx33PJdWH+dX3z8qNNbj2e2Xh5IHR1be7sin7oXuW56vm/+2Rz51L3TfML1ujucskr56u/ofMW77S938N6zvyzvcHdni7o9QDUAlN0IEAAAAGpjo26SH95v/uL/jVfPvw/saxCzGV+zSjwrBEa7rgyM9M1OzNx/v0siBy2Pey7CZlwnUVWir7+Nd+hHj0r7LHkuq2x9NvP386gHXdHshrukGAABopLz5vtL1ebz6nOjPiuNdOmZ9zDlw6VjefH61xERqPozQDQAAAJ9X36HNipBYnz+aePv51QKh24cRugEAAAB5b0++Vbz9/GqI2csBAAAA+Lb6mujPquPVN28/Pw9hIjUAAAAAADyE0A0AAAAAgIcQugEAAAAA8BBCNwAAAAAAHkLoBgAAAADAQwjdAAAAAAB4CKEbAAAAAAAPIXQDAAAAAOAhhO5GYPz48WrdurUmTJhgdSkAAAAAgBogdDcCDz30kJYvX251GQAAAACAGiJ0NwJDhw5VUFCQ1WUAAAAAAGrI8tD91FNPyWazuSzdu3evtP28efPUv39/BQUFqV27dho3bpxSU1OvaJ+1tWXLFo0ZM0aRkZGy2Wx67733Kmy3YMECXX311WrSpIliY2O1a9euOq8FAAAAANDwWB66Jalnz57KyMgoWT777LNK2yYnJ2vGjBnasWOHNm7cqMLCQo0cOVL5+fm13ufWrVtVWFhYbv3XX3+trKysSl+Xn5+vmJgYLViwoNI2K1asUFJSkp588kl98cUXiomJ0ahRo3TixAlJUt++fdWrV69yy/HjxyvdJwAAAACgcfCzugBJ8vPzU3h4uFtt169f7/J86dKlateunfbs2aObbrqpxvt0Op2aMWOGunbtqrffflsOh0OSlJqaquHDhyspKUlz5syp8LUJCQlKSEiocv/z58/Xvffeq7vvvluStGjRIr3//vt67bXX9NhjjyklJaXaGgEAAAAAjVOD6Ok+dOiQIiMj1blzZ02ePFnp6eluvzY7O1uSFBISUqt92u12ffDBB9q7d6+mTp0qp9OptLQ0DR8+XOPGjas0cLujoKBAe/bsUXx8vMvx4uPjtX379lrvtzILFixQdHS0+vfvX+f7BgAAAADUnM0wDMPKAtatW6e8vDx169ZNGRkZevrpp/X9999r//791U4e5nQ6ddttt+nMmTMuw8drs8/09HQNHjxYcXFx2r59u4YOHaqlS5fKZrO5dR42m01r1qzRuHHjStYdP35c7du317Zt2xQXF1eyfs6cOUpOTtbOnTvd2nd8fLy+/PJL5efnKyQkRKtWrXLZX1nZ2dlq1aqVjh07puDgYLeOAQAAAABwX05Ojq666iqdOXNGLVu2rLyh0cD8+OOPRnBwsLF48eJq295///1GVFSUcezYsTrZZ3JysiHJ6Ny5s1FYWFijuiUZa9ascVn3/fffG5KMbdu2uayfPXu2MWDAgBrtvyaOHTtmSGJhYWFhYWFhYWFhYWHx8FJdHm0Q13SX1qpVK1177bU6fPhwle0eeOABrV27Vlu2bFGHDh2ueJ9ZWVm67777NGbMGO3evVszZ87Uyy+/XKtzuCQ0NFQOh6PcZGxZWVluX8NeG5GRkTp27JiCgoKq7am/9OsMveJwB58X1ASfF9QEnxfUBJ8X1ASfF9RETT4vhmEoNzdXkZGRVbZrcKE7Ly9PaWlpmjJlSoXbDcPQgw8+qDVr1mjz5s3q1KnTFe/z1KlTGjFihHr06KFVq1bpP//5j4YOHarAwEA999xztT6XgIAA9evXT5s2bSoZdu50OrVp0yY98MADtd5vdex2e7U/RJQVHBzMlxDcxucFNcHnBTXB5wU1wecFNcHnBTXh7uelymHlxSyfSG3WrFlKTk7W0aNHtW3bNo0fP14Oh0OTJk2SJP31r3/ViBEjStrPmDFDf//73/Xmm28qKChImZmZyszM1Llz59zeZ2lOp1MJCQmKiorSihUr5Ofnp+joaG3cuFFLlizRCy+8UGnteXl5SklJKZmB/MiRI0pJSXGZtC0pKUmvvPKKli1bpgMHDmj69OnKz88vmc0cAAAAAOC9LO/p/u677zRp0iSdPn1abdu21aBBg7Rjxw61bdtWktkLnZaWVtJ+4cKFkqShQ4e67GfJkiW666673NpnaXa7XX/60580ePBgBQQElKyPiYnRRx99VOFrLvn88881bNiwkudJSUmSpMTERC1dulSSNHHiRJ08eVJPPPGEMjMz1bdvX61fv15hYWHuv0kAAAAAgEbJ8tnLYa0LFy5o3rx5mjt3rgIDA60uBw0cnxfUBJ8X1ASfF9QEnxfUBJ8X1IQnPi+EbgAAAAAAPMTya7oBAAAAAPBWhG4AAAAAADyE0A0AAAAAgIcQun3cggULdPXVV6tJkyaKjY3Vrl27rC4JDdBTTz0lm83msnTv3t3qstBAbNmyRWPGjFFkZKRsNpvee+89l+2GYeiJJ55QRESEmjZtqvj4eB06dMiaYmG56j4vd911V7nvm9GjR1tTLCw1b9489e/fX0FBQWrXrp3GjRun1NRUlzbnz5/XjBkz1KZNG7Vo0UJ33HGHsrKyLKoYVnLn8zJ06NBy3y/333+/RRXDSgsXLlSfPn1K7sUdFxendevWlWyv6+8WQrcPW7FihZKSkvTkk0/qiy++UExMjEaNGqUTJ05YXRoaoJ49eyojI6Nk+eyzz6wuCQ1Efn6+YmJitGDBggq3P/vss/rLX/6iRYsWaefOnWrevLlGjRql8+fP13OlaAiq+7xI0ujRo12+b9566616rBANRXJysmbMmKEdO3Zo48aNKiws1MiRI5Wfn1/SZubMmfrXv/6lVatWKTk5WcePH9ftt99uYdWwijufF0m69957Xb5fnn32WYsqhpU6dOigZ555Rnv27NHnn3+u4cOHa+zYsfr3v/8tyQPfLQZ81oABA4wZM2aUPC8qKjIiIyONefPmWVgVGqInn3zSiImJsboMNAKSjDVr1pQ8dzqdRnh4uPHnP/+5ZN2ZM2eMwMBA46233rKgQjQkZT8vhmEYiYmJxtixYy2pBw3biRMnDElGcnKyYRjmd4m/v7+xatWqkjYHDhwwJBnbt2+3qkw0EGU/L4ZhGEOGDDEeeugh64pCg9a6dWtj8eLFHvluoafbRxUUFGjPnj2Kj48vWWe32xUfH6/t27dbWBkaqkOHDikyMlKdO3fW5MmTlZ6ebnVJaASOHDmizMxMl++ali1bKjY2lu8aVGrz5s1q166dunXrpunTp+v06dNWl4QGIDs7W5IUEhIiSdqzZ48KCwtdvl+6d++ujh078v2Ccp+XS9544w2FhoaqV69emjt3rs6ePWtFeWhAioqK9Pbbbys/P19xcXEe+W7xq6ti0bicOnVKRUVFCgsLc1kfFhamgwcPWlQVGqrY2FgtXbpU3bp1U0ZGhp5++mkNHjxY+/fvV1BQkNXloQHLzMyUpAq/ay5tA0obPXq0br/9dnXq1ElpaWn67W9/q4SEBG3fvl0Oh8Pq8mARp9Ophx9+WDfeeKN69eolyfx+CQgIUKtWrVza8v2Cij4vkvSLX/xCUVFRioyM1FdffaVHH31Uqampevfddy2sFlbZt2+f4uLidP78ebVo0UJr1qxRdHS0UlJS6vy7hdANoFoJCQklj/v06aPY2FhFRUVp5cqVmjZtmoWVAfA2P//5z0se9+7dW3369NE111yjzZs3a8SIERZWBivNmDFD+/fvZz4RuKWyz8t9991X8rh3796KiIjQiBEjlJaWpmuuuaa+y4TFunXrppSUFGVnZ2v16tVKTExUcnKyR47F8HIfFRoaKofDUW4WvqysLIWHh1tUFRqLVq1a6dprr9Xhw4etLgUN3KXvE75rUFudO3dWaGgo3zc+7IEHHtDatWv1ySefqEOHDiXrw8PDVVBQoDNnzri05/vFt1X2ealIbGysJPH94qMCAgLUpUsX9evXT/PmzVNMTIxeeuklj3y3ELp9VEBAgPr166dNmzaVrHM6ndq0aZPi4uIsrAyNQV5entLS0hQREWF1KWjgOnXqpPDwcJfvmpycHO3cuZPvGrjlu+++0+nTp/m+8UGGYeiBBx7QmjVr9PHHH6tTp04u2/v16yd/f3+X75fU1FSlp6fz/eKDqvu8VCQlJUWS+H6BJDMLXbhwwSPfLQwv92FJSUlKTEzU9ddfrwEDBujFF19Ufn6+7r77bqtLQwMza9YsjRkzRlFRUTp+/LiefPJJORwOTZo0yerS0ADk5eW59BIcOXJEKSkpCgkJUceOHfXwww/rD3/4g7p27apOnTrp8ccfV2RkpMaNG2dd0bBMVZ+XkJAQPf3007rjjjsUHh6utLQ0zZkzR126dNGoUaMsrBpWmDFjht5880394x//UFBQUMm1lC1btlTTpk3VsmVLTZs2TUlJSQoJCVFwcLAefPBBxcXF6YYbbrC4etS36j4vaWlpevPNN/XTn/5Ubdq00VdffaWZM2fqpptuUp8+fSyuHvVt7ty5SkhIUMeOHZWbm6s333xTmzdv1ocffuiZ75a6mWAdjdXLL79sdOzY0QgICDAGDBhg7Nixw+qS0ABNnDjRiIiIMAICAoz27dsbEydONA4fPmx1WWggPvnkE0NSuSUxMdEwDPO2YY8//rgRFhZmBAYGGiNGjDBSU1OtLRqWqerzcvbsWWPkyJFG27ZtDX9/fyMqKsq49957jczMTKvLhgUq+pxIMpYsWVLS5ty5c8avf/1ro3Xr1kazZs2M8ePHGxkZGdYVDctU93lJT083brrpJiMkJMQIDAw0unTpYsyePdvIzs62tnBY4p577jGioqKMgIAAo23btsaIESOMDRs2lGyv6+8Wm2EYRm1/IQAAAAAAAJXjmm4AAAAAADyE0A0AAAAAgIcQugEAAAAA8BBCNwAAAAAAHkLoBgAAAADAQwjdAAAAAAB4CKEbAAAAAAAPIXQDAAAAAOAhhG4AAAAAADyE0A0AAAAAgIcQugEAaICGDh2qhx9+2JL9lm3jqVrcUfrYVtZRE1bX+Yc//EE33HCDZccHALjys7oAAAAas7vuukvLli0rt37UqFFav369BRXVvXfffVf+/v5Wl9Fg6qiO1XV++eWX6tu3r2XHBwC4InQDAHCFRo8erSVLlrisCwwMtKiauhcSEmJ1CZIaTh3VsbrOL7/8UklJSZbWAAC4jOHlAABcocDAQIWHh7ssrVu3lmQONX7wwQf18MMPq3Xr1goLC9Mrr7yi/Px83X333QoKClKXLl20bt26cvu9ePGiHnjgAbVs2VKhoaF6/PHHZRhGyXan06l58+apU6dOatq0qWJiYrR69eqS7fn5+Zo6dapatGihiIgIPf/88+WO4U6bioab/+Y3v9GcOXMUEhKi8PBwPfXUUyXbc3NzNXnyZDVv3lwRERF64YUX3BpyXV0tFdVRm/e2uvetuvOTpNWrV6t3795q2rSp2rRpo/j4eOXn51dY54ULF/Sb3/xG7dq1U5MmTTRo0CDt3r273LlVd8yK7NmzRzfddJOaNm2q6667Tjt37lRaWho93QDQgBC6AQDwsGXLlik0NFS7du3Sgw8+qOnTp+tnP/uZBg4cqC+++EIjR47UlClTdPbs2XKv8/Pz065du/TSSy9p/vz5Wrx4ccn2efPmafny5Vq0aJH+/e9/a+bMmfrlL3+p5ORkSdLs2bOVnJysf/zjH9qwYYM2b96sL774wuUY7rSp7JyaN2+unTt36tlnn9Xvf/97bdy4UZKUlJSkrVu36p///Kc2btyoTz/91K191qaW2ry31b1v1Z1fRkaGJk2apHvuuUcHDhzQ5s2bdfvtt7v8IFLanDlz9M4772jZsmX64osv1KVLF40aNUo//PCD2+9pRQ4ePKhhw4ZpyJAh2r9/v/77v/9b48aNkyT16dOnyvcNAFCPDAAAUGuJiYmGw+Ewmjdv7rL88Y9/NAzDMIYMGWIMGjSopP3FixeN5s2bG1OmTClZl5GRYUgytm/fXrJuyJAhRo8ePQyn01my7tFHHzV69OhhGIZhnD9/3mjWrJmxbds2l3qmTZtmTJo0ycjNzTUCAgKMlStXlmw7ffq00bRpU+Ohhx4yDMNwq82lWso+L31OhmEY/fv3Nx599FEjJyfH8Pf3N1atWlWy7cyZM0azZs1c9lGWO7VUV4c7721171t152cYhrFnzx5DknH06NEKz6V0nXl5eYa/v7/xxhtvlGwvKCgwIiMjjWeffbbScyl7zIoMHz7c5VwNwzAmTJhgdOvWrdLXAADqH9d0AwBwhYYNG6aFCxe6rCt9XW/pXkeHw6E2bdqod+/eJevCwsIkSSdOnHDZxw033CCbzVbyPC4uTs8//7yKiop0+PBhnT17VjfffLPLawoKCnTdddcpLS1NBQUFio2NdampW7duJc/daVOZsj2pEREROnHihL755hsVFhZqwIABJdtatmxZ7T5rW0tN39vq3rfqzk+SYmJiNGLECPXu3VujRo3SyJEjNWHChJJLCsqeV2FhoW688caSdf7+/howYIAOHDhQ6bmUPWZZ3377rT7++ONyIwH8/f0ZWg4ADQyhGwCAK9S8eXN16dKl0u1lZ7K22Wwu6y4Fa6fT6fYx8/LyJEnvv/++2rdv77ItMDCw3NDlulbROdWkfk/WUdV7W937VtV+L+3D4XBo48aN2rZtmzZs2KCXX35Zv/vd77Rz50516tSpTs+lsvc0JSVFfn5+Lj8wSNLevXuVmJhY6xoAAHWPa7oBAGigdu7c6fJ8x44d6tq1qxwOh6KjoxUYGKj09HR16dLFZbnqqqt0zTXXyN/f32UfP/74o/7zn/+UPHenTU117txZ/v7+LhOFZWdnV7tPT9RSkereN3fZbDbdeOONevrpp7V3714FBARozZo15dpdc801CggI0NatW0vWFRYWavfu3YqOjq71edjtdjmdThUUFJSs++CDD3Tw4EF6ugGggaGnGwCAK3ThwgVlZma6rPPz81NoaOgV7Tc9PV1JSUn61a9+pS+++EIvv/xyyYzeQUFBmjVrlmbOnCmn06lBgwYpOztbW7duVXBwsBITEzVt2jTNnj1bbdq0Ubt27fS73/1Odvvl39tbtGhRbZuaCgoKUmJiombPnq2QkBC1a9dOTz75pOx2u8tQ+bI8UUtl9VX3vlVn586d2rRpk0aOHKl27dpp586dOnnypHr06FGubfPmzTV9+vSS96Njx4569tlndfbsWU2bNq3W59GvXz/5+/tr9uzZeuSRR7R//35Nnz5dkgjdANDAELoBALhC69evV0REhMu6bt266eDBg1e036lTp+rcuXMaMGCAHA6HHnroId13330l2//nf/5Hbdu21bx58/TNN9+oVatW+slPfqLf/va3kqQ///nPysvL05gxYxQUFKRHHnlE2dnZLsdwp01NzZ8/X/fff79uvfVWBQcHa86cOTp27JiaNGlS5es8UUtFqnvfqhMcHKwtW7boxRdfVE5OjqKiovT8888rISGhwvbPPPOMnE6npkyZotzcXF1//fX68MMPK7wG3F2RkZFavHix5s6dq9dee00DBgzQ1KlTtWTJEoWHh9d6vwCAumczjErubwEAAFAH8vPz1b59ez3//PNX1LsLAEBjRE83AACoU3v37tXBgwc1YMAAZWdn6/e//70kaezYsRZXBgBA/SN0AwCAOvfcc88pNTVVAQEB6tevnz799NMrvsYdAIDGiOHlAAAAAAB4CLcMAwAAAADAQwjdAAAAAAB4CKEbAAAAAAAPIXQDAAAAAOAhhG4AAAAAADyE0A0AAAAAgIcQugEAAAAA8BBCNwAAAAAAHkLoBgAAAADAQwjdAAAAAAB4CKEbAAAAAAAP+f/zDyU7MFwoaQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "ns_test, test_vals  = zip(*test_losses)\n",
    "ns_train, train_vals = zip(*train_losses)\n",
    "\n",
    "plt.figure(figsize=(10,6))\n",
    "# plot test loss\n",
    "plt.plot(ns_test, test_vals,\n",
    "         marker='o', \n",
    "         label='Avg Test Loss')\n",
    "# plot train loss\n",
    "plt.plot(ns_train, train_vals,\n",
    "         marker='o', \n",
    "         label='Min Train Loss')\n",
    "\n",
    "plt.xlabel(r'Embedding dimension $d$')\n",
    "plt.ylabel('BCE Loss')\n",
    "plt.title(r'Train vs. Test Loss as a function of Embedding Dimension $d$')\n",
    "plt.legend()\n",
    "# plt.xscale('log')\n",
    "plt.yscale('log')\n",
    "plt.tight_layout()\n",
    "plt.savefig('figures/dimensionality/models_mn_by_d/plot_log.png', dpi=300)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4d0bce93",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "28df76ba",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "19391a4a",
   "metadata": {},
   "source": [
    "## Checking if n=25 is orthogonal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "a0f516d5",
   "metadata": {},
   "outputs": [],
   "source": [
    "filepath = f'figures/dimensionality/models_mn_by_d/'\n",
    "model_path = filepath+f'model__25.pth'\n",
    "loss_history_path = filepath+'loss_history_25.json'\n",
    "num_models=25\n",
    "d=25\n",
    "device='mps'\n",
    "\n",
    "model = load_vector_bt(model_path, num_models, d, device)\n",
    "with open(loss_history_path, 'r') as file:\n",
    "    loss_history = json.load(file)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "a3399be3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(loss_history)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "a9e6d2a0",
   "metadata": {},
   "outputs": [],
   "source": [
    "u_weights = model.u.weight.detach().cpu().numpy()\n",
    "v_weights = model.v.weight.detach().cpu().numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "63b8e216",
   "metadata": {},
   "outputs": [],
   "source": [
    "U_dot = np.zeros((25,25))\n",
    "for i, u in enumerate(u_weights):\n",
    "    for j, u_ in enumerate(u_weights):\n",
    "        U_dot[i,j] = np.dot(u,u_)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "0733dce3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([2.59635234, 1.82307744, 4.26702976, 2.01703835, 2.05235124,\n",
       "       3.82034445, 3.50831056, 3.45357895, 2.84471035, 2.67349839,\n",
       "       2.97431755, 2.57384157, 5.07617712, 3.32679391, 3.35312557,\n",
       "       1.51384532, 1.78264606, 1.7002635 , 1.4537499 , 1.45870757,\n",
       "       2.82785535, 1.83218586, 2.3016324 , 3.28657794, 2.11030746])"
      ]
     },
     "execution_count": 46,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.diagonal(U_dot)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "cbe91f55",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x143627370>"
      ]
     },
     "execution_count": 47,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(U_dot, cmap='hot', interpolation='nearest')\n",
    "plt.colorbar()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "6c980f2d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 0\n",
      "1 1\n",
      "2 2\n",
      "3 3\n",
      "4 4\n",
      "5 5\n",
      "6 6\n",
      "7 7\n",
      "8 8\n",
      "9 9\n",
      "10 10\n",
      "11 11\n",
      "12 12\n",
      "13 13\n",
      "14 14\n",
      "15 15\n",
      "16 16\n",
      "17 12\n",
      "18 18\n",
      "19 19\n",
      "20 20\n",
      "21 21\n",
      "22 22\n",
      "23 23\n",
      "24 24\n"
     ]
    }
   ],
   "source": [
    "for i in range(25):\n",
    "    print(i, np.argmax(U_dot[i]))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "127a0dd1",
   "metadata": {},
   "source": [
    "### Now let's compare with n=3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "eed17a01",
   "metadata": {},
   "outputs": [],
   "source": [
    "filepath = f'figures/dimensionality/models_mn_by_d/'\n",
    "model_path = filepath+f'model__3.pth'\n",
    "loss_history_path = filepath+'loss_history_3.json'\n",
    "num_models=25\n",
    "d=3\n",
    "device='mps'\n",
    "\n",
    "model = load_vector_bt(model_path, num_models, d, device)\n",
    "with open(loss_history_path, 'r') as file:\n",
    "    loss_history = json.load(file)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "32d03f74",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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XV2dNmzYoLlz52r79u3hbtagUlFRoYULF+qVV15RTExMuJszqN16662+z5MnT1ZOTo5Gjx6tP/zhD4qNjQ1jy87GkNA5JCcny2KxnDUburKyUqmpqWFq1eDSeR/Pd49TU1N14sQJv/1tbW2qqanhz6Eb99xzj/7617/qtdde08iRI33lqampcrvdqq2t9av/+Xvd3Z9F5z60s1qtGjt2rLKzs1VYWKgpU6boN7/5Dfc4iEpKSnTixAldddVVioqKUlRUlLZv367f/va3ioqKksPh4F6HSFJSksaNG6eDBw9G3N9pAss5WK1WZWdnq7i42Ffm9XpVXFys3NzcMLZs8BgzZoxSU1P97nF9fb3efvtt3z3Ozc1VbW2tSkpKfHVeffVVeb1e5eTk9HubI5VhGLrnnnu0ceNGvfrqqxozZozf/uzsbEVHR/vd69LSUpWXl/vd67179/oFxFdeeUWJiYmaOHFi/1zIAOT1euVyubjHQXTjjTdq79692rNnj2+bNm2aZs+e7fvMvQ6NxsZGffLJJ0pLS4u8v9NBncI7yDz//POGzWYznn76aeOjjz4yvve97xlJSUl+s6Fxfg0NDcZ7771nvPfee4YkY9WqVcZ7771nHD582DCM9mXNSUlJxosvvmh88MEHxh133NHtsuYrr7zSePvtt40333zTuPTSS1nW/DkLFiww7Ha78frrr/stTzx9+rSvzve//31j1KhRxquvvmq8++67Rm5urpGbm+vb37k88eabbzb27NljbN261RgxYgTLQM+wePFiY/v27cann35qfPDBB8bixYsNk8lkvPzyy4ZhcI9D6cxVQobBvQ6WH/3oR8brr79ufPrpp8Y//vEPIy8vz0hOTjZOnDhhGEZk3WcCywU8+uijxqhRowyr1WpMnz7deOutt8LdpAHltddeMySdtc2dO9cwjPalzUuXLjUcDodhs9mMG2+80SgtLfU7x8mTJ427777biI+PNxITE4158+YZDQ0NYbiayNXdPZZk/P73v/fVaW5uNn7wgx8YQ4cONYYMGWLcddddxvHjx/3O89lnnxm33nqrERsbayQnJxs/+tGPjNbW1n6+msj1r//6r8bo0aMNq9VqjBgxwrjxxht9YcUwuMeh9PnAwr0OjlmzZhlpaWmG1Wo1MjIyjFmzZhkHDx707Y+k+2wyDMMIbp8NAABAcDGHBQAARDwCCwAAiHgEFgAAEPEILAAAIOIRWAAAQMQjsAAAgIhHYAEAABGPwAIAACIegQUAAEQ8AgsAAIh4BBYAABDx/n820/RUUU/j2QAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(loss_history)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "6a1eead3",
   "metadata": {},
   "outputs": [],
   "source": [
    "u_weights = model.u.weight.detach().cpu().numpy()\n",
    "v_weights = model.v.weight.detach().cpu().numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "b8d45b87",
   "metadata": {},
   "outputs": [],
   "source": [
    "U_dot = np.zeros((25,25))\n",
    "for i, u in enumerate(u_weights):\n",
    "    for j, u_ in enumerate(u_weights):\n",
    "        U_dot[i,j] = np.dot(u,u_)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "6844210d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x14340e2f0>"
      ]
     },
     "execution_count": 52,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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nvx73p0i1XOPtDFjxmjmzJlatGiR1q5dqxMnTqi4uFi33npr8Er5Tz75RNdee62eeeYZTZ06Vfv27dP69et1/fXX6/zzz9fbb7+tu+66S1deeaUmTJgQXgOcGFNXV+fo68+bjY2Njc3DW11dXbfViuPHjzt+vz8i7fT7/c7x48cj3sbDhw87c+bMcfr27ev4fD5nwYIFztGjR4Nf379/vyPJee211xzHcZza2lrnyiuvdFJTU52kpCRnxIgRzr333us0NDSEnTvBcc7Af63C0N7ergMHDqhfv35KSDj1/2ONjY3Kyso65eIHhOJz6ho+p87xGXUNn9M3HMfR0aNHlZmZqR49uu+O6+bmZrW22owbfS0xMVHJyckRaFHsiLlh+R49emjw4MGdHtfVix/OdnxOXcPn1Dk+o67hc/paSkpKt+dITk6Ou6IcKTzEBgCAOENxBwAgzniuuCclJWn58uUdPmAAX+Nz6ho+p87xGXUNnxNiScxdUAcAAOx4rucOAABOj+IOAECcobgDABBnKO4AAMQZTxX31atXa9iwYUpOTlZOTo7eeOONaDcpptx///1KSEgI2UaPHh3tZkXdtm3bNGvWLGVmZiohIUGbN28O+brjOFq2bJkyMjLUu3dv5eXl6YMPPohOY6Oos8/ptttuO+X8mjlzZnQaG0WlpaWaMmWK+vXrp7S0NBUWFqqmpibkmObmZhUVFen8889X3759dfPNN6u+vj5KLcbZyDPF/bnnnlNJSYmWL1+uN998UxMnTlR+fv4pS+qd7S666CIdPHgwuL3++uvRblLUNTU1aeLEiVq9erXr1x966CH96le/0tq1a7Vz506de+65ys/PV3OzzTJE3tPZ5yRJM2fODDm/fv/735/BFsaGyspKFRUVaceOHSorK9OJEyc0Y8YMNTV9s4TUXXfdpT/+8Y/auHGjKisrdeDAAd10001RbDXOOvaPxj8zpk6d6hQVFQVft7W1OZmZmU5paWkUWxVbli9f7kycODHazYhpkpxNmzYFX7e3tzt+v9/55S9/Gdx35MgRJykpyfn9738fhRbGhr//nBzHcebPn+/ceOONUWlPLDt06JAjyamsrHQc5+vzp1evXs7GjRuDx7z33nuOJKeqqipazcRZxhM999bWVu3evVt5eXnBfT169FBeXp6qqqqi2LLY88EHHygzM1PDhw/X3LlzVVtbG+0mxbT9+/crEAiEnFspKSnKycnh3HJRUVGhtLQ0jRo1St///vd1+PDhaDcp6hoaGiRJqampkqTdu3frxIkTIefU6NGjNWTIEM4pnDGeKO6fffaZ2tralJ6eHrI/PT1dgUAgSq2KPTk5OVq3bp22bNmiNWvWaP/+/briiit09Gg0Vm/3hpPnD+dW52bOnKlnnnlG5eXlevDBB1VZWamCggK1tdkscO5t7e3tWrx4sS6//HKNGzdO0tfnVGJiovr37x9yLOcUzqSYWxUO5goKCoL/njBhgnJycjR06FA9//zzWrhwYRRbhnhw6623Bv89fvx4TZgwQRdccIEqKip07bXXRrFl0VNUVKQ9e/ZwbQtijid67gMGDFDPnj1Pudq0vr5efr8/Sq2Kff3799eFF16ovXv3RrspMevk+cO5Fb7hw4drwIABZ+35VVxcrJdeekmvvfZayDLVfr9fra2tOnLkSMjxnFM4kzxR3BMTEzVp0iSVl5cH97W3t6u8vFy5ublRbFlsO3bsmPbt26eMjIxoNyVmZWdny+/3h5xbjY2N2rlzJ+dWJz7++GMdPnz4rDu/HMdRcXGxNm3apK1btyo7Ozvk65MmTVKvXr1CzqmamhrV1tZyTuGM8cywfElJiebPn6/Jkydr6tSpWrVqlZqamrRgwYJoNy1m3HPPPZo1a5aGDh2qAwcOaPny5erZs6fmzJkT7aZF1bFjx0J6l/v371d1dbVSU1M1ZMgQLV68WD//+c81cuRIZWdn67777lNmZqYKCwuj1+goON3nlJqaqp/97Ge6+eab5ff7tW/fPi1ZskQjRoxQfn5+FFt95hUVFWn9+vV68cUX1a9fv+A8ekpKinr37q2UlBQtXLhQJSUlSk1Nlc/n0w9/+EPl5ubqsssui3LrcdaI9uX64fj1r3/tDBkyxElMTHSmTp3q7NixI9pNiim33HKLk5GR4SQmJjqDBg1ybrnlFmfv3r3RblbUvfbaa46kU7b58+c7jvP17XD33Xefk56e7iQlJTnXXnutU1NTE91GR8HpPqcvv/zSmTFjhjNw4ECnV69eztChQ51FixY5gUAg2s0+49w+I0nO008/HTzm+PHjzg9+8APnvPPOc/r06eN8+9vfdg4ePBi9RuOsw5KvAADEGU/MuQMAgK6juAMAEGco7gAAxBmKOwAAcYbiDgBAnKG4AwAQZyjuAADEGYo7AABxhuIOAECcobgDABBnKO4AAMQZijsAAHHm/we0xQ9bHiSkOwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(U_dot, cmap='hot', interpolation='nearest')\n",
    "plt.colorbar()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "1c5294eb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1.25924933, 1.13391507, 2.98010778, 1.07991409, 0.94638759,\n",
       "       2.24290419, 2.23420978, 2.35434651, 1.79148936, 1.65432394,\n",
       "       1.71100211, 1.39665985, 3.30346084, 2.03392386, 2.22452402,\n",
       "       0.54627174, 0.56482619, 1.09418678, 0.67699981, 0.54452229,\n",
       "       1.35391688, 0.91854268, 1.5208869 , 1.85783219, 1.31924438])"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.diagonal(U_dot)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "d4f3d852",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 12\n",
      "1 12\n",
      "2 2\n",
      "3 12\n",
      "4 2\n",
      "5 7\n",
      "6 6\n",
      "7 7\n",
      "8 12\n",
      "9 7\n",
      "10 10\n",
      "11 13\n",
      "12 12\n",
      "13 13\n",
      "14 14\n",
      "15 10\n",
      "16 13\n",
      "17 12\n",
      "18 13\n",
      "19 14\n",
      "20 13\n",
      "21 13\n",
      "22 12\n",
      "23 5\n",
      "24 13\n"
     ]
    }
   ],
   "source": [
    "for i in range(25):\n",
    "    print(i, np.argmax(U_dot[i]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "53b92ea9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ca2b557c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "67bb7166",
   "metadata": {},
   "source": [
    "## New plot 8/4"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "d92a398b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Training and Test Loss Data for dimensions d=1 to 25\n",
    "\n",
    "# Dimensions (x-axis)\n",
    "dimensions = list(range(1, 31))\n",
    "\n",
    "# Training losses (minimum train loss for each dimension)\n",
    "train_losses = [\n",
    "    0.8161, 0.8049, 0.7985, 0.7939, 0.7892,\n",
    "    0.7871, 0.7835, 0.7808, 0.7791, 0.7776,\n",
    "    0.7759, 0.7748, 0.7733, 0.7724, 0.7719,\n",
    "    0.7719, 0.7710, 0.7709, 0.7707, 0.7708,\n",
    "    0.7707, 0.7707, 0.7706, 0.7707, 0.7705,\n",
    "    0.7707, 0.7708, 0.7708, 0.7709, 0.7708\n",
    "]\n",
    "\n",
    "# Test losses\n",
    "test_losses = [\n",
    "    0.8187, 0.8095, 0.8028, 0.7990, 0.7947,\n",
    "    0.7935, 0.7894, 0.7867, 0.7854, 0.7841,\n",
    "    0.7820, 0.7815, 0.7795, 0.7791, 0.7783,\n",
    "    0.7782, 0.7776, 0.7773, 0.7764, 0.7762,\n",
    "    0.7771, 0.7766, 0.7768, 0.7760, 0.7768,\n",
    "    0.7764, 0.7766, 0.7767, 0.7773, 0.7768\n",
    "]\n",
    "\n",
    "# Example plotting code using matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.figure(figsize=(5,5))\n",
    "plt.plot(dimensions, train_losses, label='Min Train Loss', marker='o', markersize=4)\n",
    "plt.plot(dimensions, test_losses, label='Avg Test Loss', marker='o', markersize=4)\n",
    "plt.xlabel('Dimension (d)', fontsize=12)\n",
    "plt.ylabel('CE Loss', fontsize=12)\n",
    "plt.title('Train and Test Loss vs Dimension', fontsize=12, pad=10)\n",
    "plt.legend(fontsize=11)\n",
    "# plt.grid(True, alpha=0.3)\n",
    "plt.tight_layout()\n",
    "plt.savefig('figure.png', dpi=500)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a6a8d6e",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "tf-metal",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.23"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
