{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "31e0858d-12e5-4eaf-8cc3-f461d2aff756",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "974ba093-b42b-4ee9-a8c0-cd79d161435c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8c2f5efb-631c-4083-84ae-dc219c6a75a1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fde1d3d3-3ae3-4194-b2e8-596809be9636",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9e3a5e70-ec86-4af6-ad75-bdc4351b4d40",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "723df846-36f4-433c-99cf-044b96c870ec",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cf1854ba-184b-4c9f-9a5c-9158e786e404",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c4cadde9-8859-435a-b6ba-09aa42bb468d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "\n",
    "os.environ[\"CUDA_DEVICE_ORDER\"]=\"PCI_BUS_ID\"   \n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"]='0'\n",
    "\n",
    "os.environ[\"HF_HOME\"]=\"~/codes/.cache/huggingface\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "2f7cd96b-ca27-4ce1-ac2d-c3dd67e069b7",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import random\n",
    "import numpy as np\n",
    "\n",
    "def set_seeds(seed):\n",
    "    random.seed(seed)\n",
    "    np.random.seed(seed)\n",
    "    torch.manual_seed(seed)\n",
    "    torch.backends.cudnn.deterministic = True\n",
    "    torch.backends.cudnn.benchmark = False\n",
    "    \n",
    "set_seeds(42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "4ff495b8-8df0-49e8-a409-4ed9601c8143",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "def show_images(images, scores, test_artist, train_artists):\n",
    "    n: int = len(images)\n",
    "    f = plt.figure(figsize=(16, 2))\n",
    "    for i in range(n):\n",
    "        # Debug, plot figure\n",
    "        ax = f.add_subplot(1, n, i + 1)\n",
    "        if i==0:\n",
    "            pass\n",
    "            ax.title.set_text(test_artist)\n",
    "        else:\n",
    "            ax.title.set_text(str(np.round(scores[i-1], 4))+'\\n'+train_artists[i-1])\n",
    "            ax.axis('off')\n",
    "        if images[i]==None:\n",
    "            pass\n",
    "        else:\n",
    "            plt.imshow(images[i])\n",
    "\n",
    "    plt.show(block=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "c4e89a09-d6ff-46a1-8a9e-9c6f9c167114",
   "metadata": {},
   "outputs": [],
   "source": [
    "from datasets import load_dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2682e2c4-9275-4bae-a732-74b981a358d2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "fb2dc562-293c-4e74-8e97-141fc7465938",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "bda41875-8976-4852-823a-91dc1f42aebf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5000"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open('../../data/indices/5000-0.5/idx-train.pkl', 'rb')  as handle:\n",
    "    idx_train = pickle.load(handle)\n",
    "len(idx_train)   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "773b1a12-d60d-4ed8-8f61-b03a3af61e71",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "40c86797-31d5-45d0-b46f-52f8c84dd130",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'load_dataset' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[1], line 3\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;66;03m# from datasets import load_dataset\u001b[39;00m\n\u001b[0;32m----> 3\u001b[0m dataset \u001b[38;5;241m=\u001b[39m \u001b[43mload_dataset\u001b[49m(\n\u001b[1;32m      4\u001b[0m     \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mcifar10\u001b[39m\u001b[38;5;124m'\u001b[39m,\n\u001b[1;32m      5\u001b[0m     \u001b[38;5;66;03m# args.dataset_config_name,\u001b[39;00m\n\u001b[1;32m      6\u001b[0m     \u001b[38;5;66;03m# cache_dir=args.cache_dir,\u001b[39;00m\n\u001b[1;32m      7\u001b[0m     \u001b[38;5;66;03m# split=\"train\",\u001b[39;00m\n\u001b[1;32m      8\u001b[0m )\n",
      "\u001b[0;31mNameError\u001b[0m: name 'load_dataset' is not defined"
     ]
    }
   ],
   "source": [
    "from datasets import load_dataset\n",
    "\n",
    "dataset = load_dataset(\n",
    "    'cifar10',\n",
    "    # args.dataset_config_name,\n",
    "    # cache_dir=args.cache_dir,\n",
    "    # split=\"train\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c6632d56-9134-4720-99a9-1853fe349039",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b2e50aae-335f-457d-bfb7-e3991f19fb50",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5df420e1-7166-4e5b-baa3-a012fe7e32e1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "f2ce6b6b-ff45-4156-9606-7c87046e751a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<PIL.PngImagePlugin.PngImageFile image mode=RGB size=32x32>"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from datasets import DatasetDict, Dataset, load_dataset, Image\n",
    "\n",
    "train_dataset = dataset['train'].select(idx_train)\n",
    "train_dataset[0][\"img\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "26b8b800-7147-4c3b-9f62-b99110392974",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "8c2e0980-d551-48f4-8b1f-3f9d4ac788cb",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "df = pd.DataFrame()\n",
    "df['path'] = ['{}/{}.png'.format('../../saved/5000-0.5/gen', i) for i in range(1000)]\n",
    "\n",
    "from datasets import DatasetDict, Dataset, load_dataset, Image\n",
    "dataset = DatasetDict({\n",
    "\"train\": Dataset.from_dict({\n",
    "    \"img\": df['path'].tolist(),\n",
    "}).cast_column(\"img\", Image()),})\n",
    "val_dataset = dataset[\"train\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "5b522cfd-98f6-488c-be5b-4314ff16a91b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<PIL.PngImagePlugin.PngImageFile image mode=RGB size=32x32>"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "val_dataset[0]['img']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "bdada2c1-66b5-4d5e-b959-e80b30420b2f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<PIL.PngImagePlugin.PngImageFile image mode=RGB size=32x32>"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "val_dataset[1]['img']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "087ea1db-01c9-4e6a-a402-8b8a9aa93e8b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# val_dataset =  dataset['test'].select(idx_val)\n",
    "# val_dataset[0][\"img\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "e16837b7-8ddd-46ab-9d0a-c988f2ca9514",
   "metadata": {},
   "outputs": [],
   "source": [
    "# idx_val[0:5]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0dd5e770-1fed-4f65-b4e7-5373e2adcb10",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "04be809b-6fd9-4a8a-9d64-94c6ef3b4f85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ad307d24-057d-43bc-9772-5ae5d62c9fa1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "c37c6ab7-8c07-416a-b7b1-4b2c03a82cfa",
   "metadata": {},
   "outputs": [],
   "source": [
    "# load ground truth\n",
    "my_list = [\n",
    "    0,1,2,3,\n",
    "    4,5,6,7,\n",
    "    8,9,10,11,\n",
    "    12,13,14,15,\n",
    "    16,17,18,19,\n",
    "    20,21,22,23,\n",
    "    24,25,26,27,\n",
    "    28,29,30,31,\n",
    "    32,33,34,35,\n",
    "    36,37,38,39,\n",
    "    40,41,42,43,\n",
    "    44,45,46,47,\n",
    "    48,49,50,51,\n",
    "    52,53,54,55,\n",
    "    56,57,58,59,\n",
    "    60,61,62,63,\n",
    "          ]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "7e5b270b-c5df-4b5d-a8fd-2a924a6edad6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000, 1000)"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "loss_array_list = []\n",
    "\n",
    "for i in my_list:\n",
    "    for seed in [\n",
    "        0,\n",
    "                 1,\n",
    "                 2,\n",
    "                 # 3,\n",
    "                 # 4,\n",
    "                ]:\n",
    "        for e_seed in [\n",
    "            0, \n",
    "                       1, \n",
    "                       2\n",
    "                      ]:\n",
    "            with open('../../saved/5000-0.5/lds-val/ddpm-sub-{}-{}/e-{}-gen.pkl'.format(i, seed, e_seed), 'rb')  as handle:\n",
    "                loss_list = pickle.load(handle)\n",
    "            margins = np.concatenate(loss_list, axis=-1) # -logp\n",
    "            ####\n",
    "            if (seed==0) and (e_seed)==0:\n",
    "                loss_array = margins\n",
    "            else:\n",
    "                loss_array += margins\n",
    "            \n",
    "    loss_array = loss_array/(3*3)\n",
    "    \n",
    "    loss_array_list.append(loss_array)\n",
    "lds_loss_array = np.stack(loss_array_list)\n",
    "lds_loss_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "d823ef7b-9d53-4f31-ab11-864274554493",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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RgKBALfffjuBQCDZpRz3dK77hs5z39B57hs6z30n2ef6mBjAKiIiIsevlO4ZERERkeRTGBEREZGkUhgRERGRpFIYERERkaRK6TAyb948SkpKCAaDTJ06lWXLliW7pGPG3LlzOf3008nKymLAgAFceumlrF+/PqFNS0sLN954I/369SMzM5PLLruMysrKhDbbtm3jkksuIT09nQEDBvDtb3+baDTal1/lmHLnnXdiWRbf+MY34tt0nnvOjh07+PKXv0y/fv1IS0vj1FNP5e23347vN8Zw2223MXDgQNLS0igtLWXDhg0J77F3716uvPJKsrOzyc3N5dprr6WhoaGvv8pRy3Ecbr31VoYPH05aWhojR47kRz/6UcK9S3SeD8+//vUvPv3pTzNo0CAsy+Kpp55K2N9T5/Xdd9/l7LPPJhgMUlxczE9/+tMjL96kqEcffdT4/X6zYMECs2bNGnPdddeZ3NxcU1lZmezSjgnTp083f/jDH8zq1avNqlWrzMUXX2yGDh1qGhoa4m2++tWvmuLiYlNWVmbefvttc8YZZ5gzzzwzvj8ajZqxY8ea0tJSs3LlSvPss8+agoICM2fOnGR8paPesmXLTElJiRk3bpy5+eab49t1nnvG3r17zbBhw8w111xjli5dajZt2mSef/55s3HjxnibO++80+Tk5JinnnrKvPPOO+Yzn/mMGT58uGlubo63+eQnP2nGjx9v3nzzTfPvf//bnHDCCeaLX/xiMr7SUemOO+4w/fr1M88884zZvHmzeeyxx0xmZqb51a9+FW+j83x4nn32WfO9733PPPHEEwYwTz75ZML+njivtbW1prCw0Fx55ZVm9erV5i9/+YtJS0szv/vd746o9pQNI1OmTDE33nhj/LXjOGbQoEFm7ty5Sazq2FVVVWUA8+qrrxpjjKmpqTE+n8889thj8TZr1641gFmyZIkxJvb/OLZtm4qKinibe++912RnZ5tQKNS3X+AoV19fb0aNGmVefPFFc+6558bDiM5zz/nOd75jPvaxj+13v+u6pqioyPzsZz+Lb6upqTGBQMD85S9/McYY8/777xvAvPXWW/E2zz33nLEsy+zYsaP3ij+GXHLJJeb//b//l7Dt85//vLnyyiuNMTrPPeWjYaSnzutvf/tbk5eXl/Bvx3e+8x1z0kknHVG9KXmZJhwOs3z5ckpLS+Pb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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(1):\n",
    "    for j in range(8):\n",
    "        plt.plot(lds_loss_array[i, :, j], color=\"C{}\".format(j))\n",
    "    # break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "874a332c-29b1-46fe-bf83-12e7c8f64e28",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 5000)"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mask_array_list = []\n",
    "\n",
    "for i in my_list:\n",
    "    # print(i)\n",
    "    with open('../../data/indices/5000-0.5/lds-val/sub-idx-{}.pkl'.format(i), 'rb')  as handle:\n",
    "        sub_idx_train = pickle.load(handle)\n",
    "    # print(len(sub_idx_train))\n",
    "    mask_array = np.in1d(idx_train, sub_idx_train)\n",
    "        \n",
    "    mask_array_list.append(mask_array)\n",
    "    \n",
    "lds_mask_array = np.stack(mask_array_list)\n",
    "lds_mask_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "41ebfcfb-5789-44f0-99d0-0dddc7c6f32f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000)"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "lds_testset_correctness = lds_loss_array.mean(axis=1)\n",
    "lds_testset_correctness.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "46afee77-65eb-4023-8077-d11ed785d406",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for j in range(4):\n",
    "    plt.plot(lds_testset_correctness[:, j], color=\"C{}\".format(j))\n",
    "    # break\n",
    "# plt.ylim(0.15, 0.2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8d92c4b4-5b21-434f-b6cc-96e968cbe495",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a3d25153-1e82-49bc-a551-ea14d2040df8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a9c6d79c-2be9-463a-9d20-0de440a29d1b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "b5b49da1-7199-4fa1-bbda-b5c1aad8bd43",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(512, 1000, 1000)"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "loss_array_list = []\n",
    "\n",
    "for i in range(512):\n",
    "    for seed in [\n",
    "        0,\n",
    "                 # 1,\n",
    "                 # 2,\n",
    "                 # 3,\n",
    "                 # 4,\n",
    "                ]:\n",
    "        for e_seed in [\n",
    "            0, \n",
    "                       1, \n",
    "                       2\n",
    "                      ]:\n",
    "            with open('../../saved/5000-0.5/retrain/ddpm-sub-{}-{}/e-{}-gen.pkl'.format(i, seed, e_seed), 'rb')  as handle:\n",
    "                loss_list = pickle.load(handle)\n",
    "            margins = np.concatenate(loss_list, axis=-1) # -logp\n",
    "            ####\n",
    "            if (seed==0) and (e_seed)==0:\n",
    "                loss_array = margins\n",
    "            else:\n",
    "                loss_array += margins\n",
    "            \n",
    "    loss_array = loss_array/(3)\n",
    "    \n",
    "    loss_array_list.append(loss_array)\n",
    "retrain_loss_array = np.stack(loss_array_list)\n",
    "retrain_loss_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "29f67809-fd80-46d1-95c8-fbba23ab4344",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(512, 5000)"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mask_array_list = []\n",
    "\n",
    "for i in range(512):\n",
    "    # print(i)\n",
    "    with open('../../data/indices/5000-0.5/retrain/sub-idx-{}.pkl'.format(i), 'rb')  as handle:\n",
    "        sub_idx_train = pickle.load(handle)\n",
    "    # print(len(sub_idx_train))\n",
    "    mask_array = np.in1d(idx_train, sub_idx_train)\n",
    "        \n",
    "    mask_array_list.append(mask_array)\n",
    "    \n",
    "retrain_mask_array = np.stack(mask_array_list)\n",
    "retrain_mask_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "212b7c27-78ab-4686-bb2b-c2ad62016ffc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(512, 1000)"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "retrain_testset_correctness = retrain_loss_array.mean(axis=1)\n",
    "retrain_testset_correctness.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "4c17b43f-7bb7-4b87-9bc0-776b999ca0ed",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjUAAAGdCAYAAADqsoKGAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACpmUlEQVR4nOzdeVwU9f/A8dfucgkKIih4oHhrapIXapoXqWUWZaZ2aGaHlWVZlpZp3y67LCstsyy1NM0OK1IMj7xAURDvW1REue/lZvf3x4e9YEExzdzf+/l48GB39jMzn5md+cz7c8ysxmg0GhFCCCGEuM5pr3UGhBBCCCGuBAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDsHpWmfg32IwGDh//jx16tRBo9Fc6+wIIYQQ4hIYjUZyc3Np1KgRWm31bTH/b4Ka8+fPExAQcK2zIYQQQojLkJCQQJMmTapN8/8mqKlTpw6gdoqnp+c1zo0QQgghLkVOTg4BAQHm63h1/t8ENaYuJ09PTwlqhBBCiOvMpQwdkYHCQgghhHAIEtQIIYQQwiFIUCOEEEIIhyBBjRBCCCEcwmUFNfPnzycwMBA3NzeCg4OJjo6uNv2qVato164dbm5udOrUiTVr1lSZduLEiWg0GubOnWuedvr0aSZMmEDz5s2pVasWLVu2ZNasWRQXF19O9oUQQgjhgGoc1KxcuZIpU6Ywa9YsYmNj6dy5M0OGDCElJcVu+sjISMaMGcOECRPYs2cPoaGhhIaGcuDAgUppf/31V3bs2EGjRo1sph85cgSDwcCXX37JwYMH+fjjj1mwYAGvvPJKTbMvhBBCCAelMRqNxprMEBwcTPfu3Zk3bx6gntQbEBDAM888w7Rp0yqlHzVqFHq9nrCwMPO0nj17EhQUxIIFC8zTEhMTCQ4OZt26dQwbNoznnnuO5557rsp8fPDBB3zxxRecOnXqkvKdk5ODl5cX2dnZcku3EEIIcZ2oyfW7Ri01xcXFxMTEEBISYlmAVktISAhRUVF254mKirJJDzBkyBCb9AaDgYceeoipU6fSoUOHS8pLdnY29erVq/LzoqIicnJybP6EEEII4bhqFNSkpaVRVlaGn5+fzXQ/Pz+SkpLszpOUlHTR9O+99x5OTk48++yzl5SPEydO8Nlnn/HEE09UmWb27Nl4eXmZ/+QnEoQQQgjHds3vfoqJieGTTz5h8eLFl/S0wMTERIYOHcrIkSN57LHHqkw3ffp0srOzzX8JCQlXMttCCCGE+I+pUVDj6+uLTqcjOTnZZnpycjL+/v525/H39682/datW0lJSaFp06Y4OTnh5OTEmTNneOGFFwgMDLSZ7/z58wwYMIDevXuzcOHCavPq6upq/kkE+WkEIYQQwvHVKKhxcXGha9eubNiwwTzNYDCwYcMGevXqZXeeXr162aQHiIiIMKd/6KGH2LdvH3Fxcea/Ro0aMXXqVNatW2eeJzExkf79+9O1a1e+/fbbi/78uBBCCCH+f6nxD1pOmTKFcePG0a1bN3r06MHcuXPR6/WMHz8egLFjx9K4cWNmz54NwOTJk+nXrx9z5sxh2LBhrFixgt27d5tbWnx8fPDx8bFZh7OzM/7+/rRt2xawBDTNmjXjww8/JDU11Zy2qhYiIYQQwIW9EL8Vej4JWt21zo24EoxGyIyHus3kO62gxkHNqFGjSE1NZebMmSQlJREUFER4eLh5MPDZs2dtWlF69+7N8uXLmTFjBq+88gqtW7dm9erVdOzY8ZLXGRERwYkTJzhx4gRNmjSx+ayGd6RfPfFb4NeJcPuH0O72a50bIYRQvrxF/Xd2g+6PXtu8iCtj34/w6+PQZSzc+dm1zs1/So2fU3O9uurPqZndFIqy1evXs6/88muirBR+fwaa9YYuD13bvIjrS0EmONVSF0DhGF73Uv87joB7v7n66zu1GdZMhTs+gsA+V399/x991AFyzqnX1/p68y+4as+pEdUoquI5OAWZsGwk7P+p8md7vlcFwJVkMMDBX2Dvcvh90pVdtiPZuxJ+fxZKi9U+q05ZKRxcDXn2n5rtMPIz4P0WsLD/tc6JuBqK9f/OepbeCWlHYeld/876/ovKSiH8FTgaXvmzuB9UefJPlBb+s/kdmAQ1V4pTFTXbzR/A8b/g5wm20xNj4LenVQFwMSWFcHoblJVUn+73Z+HjDpB2zDLtXIya/3IYjZB5Rv13NL8+DrFL4K36sHhY9WljvoVV42DJ8CuzboMBlo+C1U9dmeVdKWe2g9EAqYdVoSyuf9bn7r8V1JgYrtIxdGEf/P0ulBRcneVfCftWwI758MMo2+n6NFg9UZUnl1MuF+ao77HsEn730GCA1GOOWX5XQ4KaK8XJxf70PKuHEhZateYkH7K8Li2yvD66Fja8Ydt6sPYldeHd8mH1eYhdArnn4cDPlmlfD1RdURWVFkP0V5B5uurlRX4Gn9wIe3+ofr0myYcg49J+tuKiCrPh2F9X54SsuMyzkVCcX3V60/5MPXJl1p9yCI6FQ9yyyyuY9enwQStY9fA/y0dCNHxzG5zfo95bH4f6VPU+fgsYyqpfzrkYOPDLP8uLqLn0k7DsPrX/q1KcZ//1f9HFWkxNvuwLf89W5dO/Lfkg7F1x8XIpI97+dH2a5XXWmZqtu6QQPmgJH3e0X24YDGpc5+I71HUk4jWY3932enAxRiMc+g1y7T9M93ogQc2VonO1vC7KtbzOz7C8vrDXanq65bWpW8NohB9Gw9Y5cCLC8nnsEvV/y/tVr9/6omysUDjs/7Fy+rDnYc2L9gMeUCdIdPmzgOK3Vr1ek/wM+KIXfHrTpRdOFenTLLXJ7+6G5VbddsfXw/m4y1uuyYV98M1QOPJn5c/y0ypPM3Gy+m4NBjixHrZ8YCnYUo9CUQ0uGIVWfeD6NNv3l2L/KhV0HPy1+tY7o1EVTlUVwMtGqoDO1E2Qe8HyWV6Sal1cMlx1k1bn64Hw03hV4FcnL+XKtBZkn4NdX6vA/HpQrL86wfmGN+D4OrX/q2J9bFmXRf81GfHwfnOImHnp85yPUwHGod8vb52nt1cfENrzRW/49Qk4tq76dNYPki3KU+Vz6lEosPoOMk+r6XE/XFr5kRmvWmgKMsBg57xPOagqoKe3qopwlPp9RrbPtaQxGtX+yqwioIpeCD+OVWVDRdnn4LOusPWji+f1GpKg5kqxruVmnoaCLPU69ahl+vlYqzRWkbwpqLGOju0VQLW8bd+XFKoDbNvHthcUfTqVmGrbMUtg/f8grvxCFb/FNl1ZqeoW+eVRyC5/CnPGycrLO74e5rSHI2vUe+tWDNMAtprIToS5nVS3TGGO6p4D1YybdACWjYCF/f7ZhWzVw3A2ClY+UPkzfWrlaSYaq9Mk+yx8PwI2vqVqQyfWw/xgFSQaDLYBbVWsg4d9K+DdZhdvhasqr+kVvpvjESpfoALCOW1ha4VlJx9Sx2hhlnpvuvDlnLfKYxIc/kO93vllNXmxrnlW89Tu3CT1/X59q6VrKzdZdavW1C9PwJ8vwIb/2U7PuQBrp6mAZ/VTlnPw32AvaEk5rFqw3mmkztGq0l0u0/cHlta2SmmsgprcCzWrcOSch5jFtmXbxVQ8Hi9VzGK1Pds/seyjuOXq+9w211K5sd5/hdkqwPjxocpdOb9Ngnndqw6i9Wmw+HYVEF6sW9+eqHmw/dPKFa1Tf1cOUvKS4Y/JML8H7FtpmZ4Rr/K+eiJsfPPi67xY4GPd6p511vLao4Hl9Z7v1TqrGu9kqsgm7bMsx7SNa6ZC+onK551JaXHNjpWrpMa3dAs7ykosdz4BLOijLoRdxqruIJO45RD8pOqqsj7588qfuGw6kMDSVGzdzFirwg947v/RcoD532g1r50La8YpFeX/UeH3tdx9bd+f3Ki6RaxZ5/XoWnCrq4IMgM3vqlvYrU+o9JNQt6mqDRxdC90ngM65cp5Mjq1TwVlJvqplbLOqCWidbVutzmyDltXUTKtjLzgz0aepi71vG9BVOC2sBwjvtSqUUo+o/GJUQdiWD9T+eHgNNLP/MEr+mmHbbL7xrfL/b8ItL8KZKFUjutFOTcnEOoBNOQQN2qnXZyLLa1hGGLVMtfiZ1tFtArjXU61uS++s3JoHkJNoeX1iveV1veZV58U6aC/RW+Y9sQGCJ4J3MzXtwj41uDHloLoQJUSrABFgXBg072u73LwUOLcL2t5uW+vVp6tjANSFpf90SNqvAv61U22D9NLCy7/bx2i0XS+oC2TKEWjcxfazo2tVwDz8E+g8Wk07vc12rNaG/6lzes/38OgGqFvFb9EV50NZUeUKjD3WAf7+n6DRTZb3yQdVjbt5P8u0smLVQly7/sWXDarys28FoIGu42w/S4hWgdrgt8CnpZq29SP7FzyjEcKnq+MouIrf67NuDU07BvXbwuonbdO0GWI7Tse6az9+i2rRDp6o7vrc852afmI93GDnAp5i1f2fddayDSaFOeo7dq1jmWbdDXt6q/qr1wKeLQ8oo+bDulcqryvtuKW1PGaxZXrmact5Frccbnuv8rzWqqp4GQyg1VY9lMD6vN69qHzdVXSPWVemd36pvjejAR4Jh3O7q8/fsbXqmGs5EB76tfq0V5G01FwJBZmVpxkNlgNY5wLuPuoiGLtEHYTndlnSmoKaC1ZBjelCmn7CeqG260g6YPV6H9VKPgC7v7W8d/Oy5H37p/BOY/i8txokWlF+eRfJ2Z2qe+zboVbLPQgb37a90JqCh+/uhvCX4U1f1c9rb2Bc2glYfh8k7LBMM9VqQW3/yY2W96aWoSvBpTZoywOY3d+q7rO/Xq2czrpQ+Psdq7yEWfKWfU59ZjSo/fNhG/iyn5q+7D514TMYqh8HYDSqeX95VA36PrlRdVlWrKElW33vpzZZaq9rpmI+Rta8aFtLjVumCuU1L9oPaIxG25aaOKtxVNbHd36G5WKacx7Wz7J8pk9X46C+HwE7PlcXuPitKriyHmt14CdLQAOqC8FaWSl8dw+suN9SCO//SQWOR8Js037YRu2zpXdWbnU0jSWornWkrNRysToarlrdFvSFOe3UIEtQx+3Zneoi+/VA2zsZTV3GpYXwx3OWab/ZufNw6xx1rm9623Z69jkVEBTlwVcDVQto5Gf2W2uP/AlRn6t9nW3VIno8wjZd2PPq3DHtP5O/Z6uK0qW02JgufKay5Uyk6vIsyoNFt8LRNZbB7ukn7Qc0G96ED1vDzi9Ul0hVrSLW2zq/h+3xZ70s6zLPumxcPlIdGz9PsN0vmz+APcvUd3ImylIGpVi1LFcMBspK4PNeqjy0bnmw1/KXeVq1Mm/+ADbNtr9t1oGMtVN/W15rdaoVvWJL9JlIVY7Gb606qDFVJqoKarLOWs4B67E+FccR5mfYdo+tfx2MZYARvhkC+pSq503YpfIK4OxuPx//EmmpuRKsx8fY02YoNOmm+ouPrVO1WOtb8kwH64U4q2nlB5D1nUyZZ9SfqfZbk4GrF/apsRgAD/wMLfqrYMNYppp8i/NULTpynu18HvVV/hKibU9CE0Np5bE+6eUXMOuWkdNb1fiNiq0sFQt4k4BgSNgJ6cdtl7PrK7VvbhwFrW6teoC2idGoalAedmqnbW9XLWr7VqhaBkDsd9DhblX7Px+nLqT2glawdJGBql1by0tWf8tHQ/J+NfbBVKOrinUhHbvEMpYq6AEI/bx8uamWbkGA2KVQ21/VgK2DHesuLlABUtPeVR8zecmqcDYpsQqITN2iORfUmCmvJjDud3U8Wwfn+WmWVhRQF+Bjf9lvObRmnW9Qtezk/er1hjegfjvL3YOd71f/W/RXBakpn6aKQUV/zVCta7X94Pb3VS3eJOc8LBwAdfxh3B+V71RZepfa779Nsu1S3fA/VTMuKYA6DS3TjWWW7amqJgyq5v7jWPU02MFvquWf2qQexWCqVPw1QwVlt72vutqMRrh5smrlMpap88C6FTjtKKx7VbWcaDRVD9jfvUj9OblB3xeg5SA48gf0fla15Fkz7dPUo6qStWS4Ot9921jSmI6npP3211ex6/NslNqunk+p1hiTisdr1PzKy4r+EnZfpOUtL9m2gpW8H357SlUOor+EW16Cga/aVt4qflfn4yzfd/Y5SyuOvXF3RoMKaq0rlS51bI95U9lSkXUeCjJVK/ral1X+epePddw2V527JzdC+yrulC3KUy1KVQU1JfmqJbpEb9tlmXVGVbgTY9UzjCqOEyqp5uaJc7tUa+SBn+Cer2FRiOWz2g2qnu9fIEHNlWAKamr7wQ2h6mCt18ISoTe/BQJ6qNdnIisfLHnJqoA8uckyLTdZRf7WgzQNJepupLG/qT7a6u5cqmj/KnVAu3qpC4LOqTxgSbE9Wa2j8Qd+VoWSPhWW3Xvp68o4aX/sS/Y5VVgFBKsgLyMeDq22v4z7lsInQVBaoAoO7+aqNpN+Qo3OP/Sbam0as0JdHLwa21/O0TX2W1/A/slXole1EnsadIBGQaqrL/xl+2kqSrYq7O0V1NYOVzHgMW6ZJag5/Jv6b11wbnnfElj6tlH7y6aFD1VLPV5eaDXuahuQgboQWzfnWzMNNk7Yob6P9ONqgLl1FxWooMi6xaC0ELiE21YvxKlC2xTwWheuhdm2gbbpeOkyTnXlVgxEKjK1jOlTYOWDMGm35eIdPk1tc16SatmoKPc8fBdaeXp2Avz0SOXpZcXw0wQV9FUncbf6A9U1e6r8vK8YGJyPU0Gd6YL5i9XTgE1Bi0YLTXqo7yZqnnrYXb2WlWv1He5RZVD4NPW+tFBVKI7/pS5Qe1eoIKdRF/DvqMZWmMqX1CNqm01dP9YVLV15paLi8VaVFQ+oZ3rt+R5mpKrg8ODqyi1wyVUESfYGyFZUsfscVEAD6jwZ+Koa72SSEa+6nrfPVUGPdWCem2QV1FRRea0Y0LS/49LvGK2otEAFtE17qZY/6/1QVflgGqpgaoVx87KMpXJyU9/1wV9tb1QB9f3+/a46/3LPqzK1Eo06prLOwqCZ6jwpyrF9FImpm9vE49oGNdL9dCWYDnbv5qo2OO4PVds3adEf/DqpsSglelQXgQaGlDdXphxRAZB17fjYWjU+w96g26V32QY0mkv4Gk21++Z9LWNG6vhVnf7eb6F1iIrgayrtuP2aauxS1ef89SAV4Oz43H5XyE0PqdqzaawIqP05cIZtusJs+PY2NSLfNEi1rEQFh8f+UoWDacyKPbX97Lfg2ONSB56KVMFF8BOWMUwNg6BJ90tbxq6vq/88uprPy0pVoLu/vEul30vqolCxAGncDRq0t7y/6UG1naUFaswPQEc7Aer3I+x/F6COyyXDVWudycmNlguaSdz3KmD3Cqi6Vlm7/JhrdwdM3geB5WNpVjxgGXScUl7TbtxV/beu6ZoqBL6toe1QeOAnNe7KrvJxL0EPgHegOk+3f6KChbAptoX4gQoPx6zbzLYV5lId+Mn2bpOL2btS7S9r7Yer7mqM5WO2sOy3iuo0hLvmg2v5U1Z/GK1u463IzUv99tOgCncXmVraci+orsmvB8JbDdS5Y6JPtbS+VqRPUS24lzpA2PSQUkOpuvBnn1PPbDEZscj+fNZjBqvi7KH+VwyQrJnGKlkHNVHzVNfzvpUq6LHu7l58u2VfXKxFHtS4If9O9j9r0sPyutN9ajxjm6H20/42qerArqKiXFUWmgYHWx+3pnFWa6dabg4xid9i6R2ImKkqOjoX6GXVdeoVAA+HweS90OleaNi58vpTDtq+v9QxW1eJBDVXwtny8SDWQUJAT3Vwt+gPPq1UjaSp1eDR2g0srQtntllqUAHBNV9/VRcje1oOsMqD1Y+BNgyyXGBAFeoAPR6Dl8+og1ujreYCYiUzXj0DpyLrropV4y1NyabgDuCFY3DHXPXaugDuEKoCm0m74bU01XxtUlqgWkGMRnVx/C5U9bFHfmYZENi4m/rvYjXwz7MReFQYKF2Rd6AaZHuP1R1AGg08tgmmHFb/TfvKmvXgxLbDbJvsq2LdnVDRr0/AnDaqCw/U/nBygVsrjGNo0F5115jzEWppJTQdJ60GXTwvFZ3eqoJQE6NBtUxotHCX1XSNVg14vPV/0OMJ1a3R4R7L50PegVHfqwuxdzMY84OqDJTkl4/XyLUUzn1frDo/9cprz61vhV5PV/7cpTbcsxBufRPunKdq4KC69L693TLWxN53o3NRLYUVAwBrgX2h9WDL+xYDbD/XOqvg5GL+fse2OxFUi2CDGyzv/TrCyMWW9251La89G4NvK1WRstbsZgixOjZMY+h6Pq2+k4puesiyT+05G6X+N+pS+bOld6nvrqbWvlT5SesBwfbHZNy35OK/cTSkmgqMSUGm6sK37oaxtm9l5bFZkZ+psqXi3X12y0Kj7YBta62sumg63A0vHoP7vrNNYyqnrLumdK6VbxKxln5ClXuGEvBta7se6+PIxLQs6/PZpM8UVQkwMbVmmwbG2ysvK/YYSEvNdS77HOwqLyC7jLVMd3aDidtUV5HpgLDuQ67TUAU+dRqp956NofMYVQhXFPxk5WluddUYiaHvWl00NJXTVdTaqmuljlVQU78ddLK648bb6kJdqy5M3Kqi9ep+EK9+O1UTMhpUnz+oGvkwO881OBetamttboNeT6kCePgnKjA0tSS1HAiPbYTRyy01BN/W6k4q7wp35MQuUa0yxyv0CwMMeBUe2wAvnoDpCerOoJsnQ9vbKrfUBPS0fe/bVv2GTbsKTx3WOamgSKu17W5oPRhG/6DGQji5qeXfNU/d4dO0F2h00PVhS+FlYjoOQAVRd3xs+5Rq65YEzybq7jKAoPthZobqg/cKULUp6/w072d7sXJyKw+yrXqerb/3Bh0sx5N1EG7NunbpFWDb9de8n9pX9VqoVsvBb9rWXD0bqYt9rbrqvWsdyzG1f5Xlbqra/upul6oKcxerC5+9gNFohBvvg5ufVd+Rb2s1vSDTtkW023jb77bbIzD9nOpmvHG0Crgf+hUmrFffWasQtc3DP4Gu48v3QVN1wbWu4XYcoY4B3zaWcUCVtqG2/em+rW1b2zqPVt9F466qRca6xdL047kNO6vvxbcNPLUTxq9Rx4Rp/5n2t7Ob+k6sv/OO96pjdNIuS4tPRaaKm+m4q6i0Bg+RbNRFbU9xnu1Ac1BlknU5Capc9G6uytcxKysHZT2fVmWEddlmzaM+PPynJe/WLTGunurzlhUD/Qpl6ZqpsG665X0tb3WuVeQdqLZt4AzbihfYjid0r6e6063HBOpcK3ejO7mpCsAN1Tx5/pfHLC16/V+GW6aqMubhNfZbkW+8z/Z9/1fUOdj9UTWv9bFX8cnFeVbdmvfbef4ZyJia697JjeqLb9bHzolRgU8ry2vPxuoCPuWQGk/jXEsFPxXvdHkpXp1AO7+wTHP1hPFrwa88Cm83TBVqgX0tD+LybKKaAbs+rMbfmFjfSmoduPh3VCfOprdVQejuY5uPWt7lf3Wr3r4G7VWTqnWfdIv+treVVnTTg+p/n+fsf27qgqjIO9D2fUl+5UGJoArCm8u339Qs2v4O9Qe2gR3AAz+qZ2PsXa7ee15CF0TzvqrLobYf9JsGTcrz/GSkumibxnCMX6taItw8VZfj51atcs/tU4HZmUh10XHxULW5L262vfsKLMs30erUANHB5TXVG0ep2mbLQarQtL5d1ae1Sq9zsYyRsN4HteurQrRhZxX0/fxo5TvrBrxSPu7FqIIX68cCNK0QFILtcW+vG6XjCNXEn7DT8oydBu1VPpvfUvW4K5Pmt6gAodnNKmiK+RZCXrdNU6+F7ftek1Rw0ipE1WbP7Vb7qf90y+3FWq0KuE0e21Bhu1qqgt23tTqvhpQPej+5Sa3fs6EKFPIzLMdT466qG0KrUwHUZ+UtH84e6lw9vUXlyfo7v+khVTaM+0PdjeNaR3X3+He01Ko1Grh/pe2t6Fqd2re7vlKtPdba3m65ccB0wdTqVDpTa6A1UxfDxW41b9ChcneESdPe6ly4ebI6D76/p3IanbNKZ3ruzrCP1Lgjc76HqmA38lP1vrYfDH2n8nKsDX1XjQup3161Ap4s/x5926hKk7O7amH8X13LPLe+oZ7Ia2KqpIG6bXzAq5W7k1sPhts/VPv/lqnqTivr1hDr4N7Fo3I+nWupctvE+tbo2vWrvovKtC2dx8ANd6vjdvgnanpahfPNs4lq2dy5wDItaEzlYPXOz9T4mVvfsJ3e/BZVvns0sD2vrV1ql/5VIkHNP9VlrKVJtuJzLSqyCWoaWuaxrnW61lbpshJU7cl0QRz+CWx+H0YvU7UW6+CiblMVFFhH0R3vtlzk0k+oJtTRFQavdTMVFho18NLNE57eqS54VW1L98fUQ9k63K2CMetAwrOxOllNQc3IJaobxlCqWgbs/RaMXwf767kY66Am6AH1kLOKtcUGHS7eZO1Xof/bzUud5KaL0KWMq2gVAi8cVcGgdc2r4rMvNBq1j8FOl4ezpbZkUstbdW1VDGrqt6dazrVsn89i3VJjarHQOYNpzKV1N6RHfXU8moLMkYtVLdCjvhoPVbepGt8Q2MfynA7rJmlTV5c169qnvaDGs6EqLOM3W44n0wXAOqi552t159HA12znrxsAL51S3QGGUvVMFf8Kff8Vg/R+L1m6ZLwaq3EDl6NNhdYBU2BjzSYQ0MBt76qX1real+htL843PaTGhXUaYTnXXTwsF0PTMiqqeN4OeVsFSxXPs473qCAQo21Qe7Ggxb2eCuR+HGu5g9OziWq18KivAuHfn1XdgtatMF3Hq9ZHU/4MBtWya7p7qstY1RUIqrVh9zfqfLY3PsV6Gyt214e8DpveUd2ca8q7L00tl42CVEuu6aGSno1sn0Pj21bdRdZppPqsKs7u6jy2TtO0NzywqkI6t8rvB76mumsqBpmm5VqfK9Zdfc36qOuC9YBs65sFRiyChnbGHVmXQTc/pwKaii0p9lrfuoy1BNPW+jyvjsf2w1VgY69cr2r8179Egporwd/OAWqPdVBTXR/pY5tU64/1xaLrw+qvOtaBjnW/7qBZqnZR8a4M93qqRmGzjIsUah4+8OR29dpgUC0tnwaVf1bftgZyw13qpNA5q4u49QOvTOyNR7kU1idi3Wbq4lqxhmi6xbY6Wq2qDf45xTK41dOqYLnUwaIVW3wuZb2ejSsHLBXZ6/sPvLlm67Iu2EwP0rMeD2Cd94r94T4tLfO3G2ZpCeg/HcKzVEDp7qtqukZD5W41UAFGk+7qmHetosul00gV1Ji0KG/dC+xjmXbDnVU/lNDcuuJif0xDxcLZFND8G6zXbX0BqK4S5F4Pxv/5z9ft5Fp1+WTvRoGBr6qHXVb1g4m1vFUgNz0R3gtUF9UbR9q2jI3/U5UNpqCm3zQYMN12OVotPPiLuqPHs5HtGDQ3L3j+gLo1216QDKrL7HhE5TFlfZ6HXs+oINEU1Jgu4s37wWarB9zVqRC4jPpetV7dPNlyd5rdfVBX/W/WW50v+hT7LZT23GJnnFj99moMzY332ZY9ja2CGp0TTIhQY5f+nKKmObmA6WuqqnKo0cCwOWowd7+XLRXo2z9U++d2O63b1vNW5ORi+wDFhp0r30lZ1Tn+L5Gg5t9kHaRU99Pxptp8TemcVRdU7gXVvGw9/WK3mV4OrVZdJLs/qm4N7TJWRe4ph1XNzfqkaHCD/aBGe5nDuqxrQfVaqMJt2b1qDI/ORT3zo99Ll7as7hNUd4ep9cQ6kLHXTHylBN2v7khyqlV1Gs/Glv32ZJSqqTW/pWbrsa45mdbVebS668P/RtvtvdidC6bvNPBmNWbM5Nk4FdTYO3ZNBXJ1F/EOd8PvVmNSmpY/T6Z+W9VC4+Jh+9TZ61XFWm2zPqpls2KL4bXi1wGmnlDdW1s+hN6T1B2GJqZKj84JHlmrnkV083OVl6PVqul7f7Ada2jNq7G6I8seD19LYGvPPV+plhx756fOCXReqjumWG8Zf9eku2oNMd1BV7FruX4bFdSBbXAR9IDljrT9P0GPx9X0uk3V8IH0k5W7N036T1cPPOw2wf7nAA/9osrPG0fZBggVg3P3erYVEOuHAWp1VS+/YguwaVqbIZXvvKupnk9ZniH1HyFBzb9Jo1EnWGZ85YGnV8rY8mcZXG6wcDmGzbHtyx/1XeU01rdnmwpy04Xrct23VD1/peM96qR+fLPqltI5q8K4qvE49lg/lM26O/ByW5IuRf/panxUi/5Vpxn2Ifz1mqpl+d1gGUdVExqNato/uVEFUqAGMja4QXUTWP9e1eXeueB9kf10sa5Z19qqgNzxuRpzYv0dVPeTETUx9F11l+HQizyO/mpo1EX99pvpZxRM7l2knujd/T90YXDzUq0EY6y6YE0Px7NuYfbvVPXty6AqGhVbUq4UrfbiFY67F9i+d3JRFYJj4ep9da2wvq0hdIEKIqzvGK3YcqRzti3bKur7gurma2KnBdPEs5GlFd6/kyoT6vjbz1+rEFVxbdpLtUCtebFyd+yl0GiqHvRdEzeEqucCFeWpCk1Vt6j/izRG49X4+dj/npycHLy8vMjOzsbT8zJbQq6E/Az1kKSKgz0dXexSyy+Cv3hCPcW308iad9v8W46vVw8RrOq3aq43hjJVa7XXklKsVz+6CGoszuU8m+hKKC1Wg6VbDaq65vtPGI3qoXX1Wlw8yLrS8jPUbdGth1T+bbH/ulXjVcsnwPjwqn/X7Hpg/Ztc9y21/7tQ11p+hrrryTqwt8doVONz6jb7dyux10BNrt/X2dnlANzrVX4c+f8HrW5V/70DVReH6THg/1WtQ4CQiya7bmh1VXdrWtd4L+WHFK8WJxf1XKSrRaOpPHj73+Je7+q1zl5tzftagprrvewK7KO6eU5uKh8o/R90qftYo6n+x2b/n5KgRvw7PBvCcwds7zYQ/x3DP1E/Fti8/7XOifivsX4op/WD/65Xd5c/SPPfbq0T/woJasS/p+4/HJQmrp6L3Vkn/v/yaaUe619acM0frHZFSDDj0CSoEUIIUTWNBkbY+dkTIf6DHHt0kRBCCCH+35CgRgghhBAOQYIaIYQQQjgECWqEEEII4RAkqBFCCCGEQ5CgRgghhBAOQYIaIYQQQjgECWqEEEII4RAkqBFCCCGEQ5CgRgghhBAO4bKCmvnz5xMYGIibmxvBwcFER0dXm37VqlW0a9cONzc3OnXqxJo1a6pMO3HiRDQaDXPnzrWZnpGRwQMPPICnpyd169ZlwoQJ5OXlXU72hRBCCOGAahzUrFy5kilTpjBr1ixiY2Pp3LkzQ4YMISUlxW76yMhIxowZw4QJE9izZw+hoaGEhoZy4MCBSml//fVXduzYQaNGjSp99sADD3Dw4EEiIiIICwtjy5YtPP744zXNvhBCCCEclMZoNBprMkNwcDDdu3dn3rx5ABgMBgICAnjmmWeYNm1apfSjRo1Cr9cTFhZmntazZ0+CgoJYsGCBeVpiYiLBwcGsW7eOYcOG8dxzz/Hcc88BcPjwYW644QZ27dpFt27dAAgPD+f222/n3LlzdoOginJycvDy8iI7OxtPT8+abLIQQgghrpGaXL9r1FJTXFxMTEwMISEhlgVotYSEhBAVFWV3nqioKJv0AEOGDLFJbzAYeOihh5g6dSodOnSwu4y6deuaAxqAkJAQtFotO3futLveoqIicnJybP6EEEII4bhqFNSkpaVRVlaGn5+fzXQ/Pz+SkpLszpOUlHTR9O+99x5OTk48++yzVS6jQYMGNtOcnJyoV69eleudPXs2Xl5e5r+AgICLbp8QQgghrl/X/O6nmJgYPvnkExYvXoxGo7liy50+fTrZ2dnmv4SEhCu2bCGEEEL899QoqPH19UWn05GcnGwzPTk5GX9/f7vz+Pv7V5t+69atpKSk0LRpU5ycnHBycuLMmTO88MILBAYGmpdRcSByaWkpGRkZVa7X1dUVT09Pmz8hhBBCOK4aBTUuLi507dqVDRs2mKcZDAY2bNhAr1697M7Tq1cvm/QAERER5vQPPfQQ+/btIy4uzvzXqFEjpk6dyrp168zLyMrKIiYmxryMjRs3YjAYCA4OrskmCCGEEMJBOdV0hilTpjBu3Di6detGjx49mDt3Lnq9nvHjxwMwduxYGjduzOzZswGYPHky/fr1Y86cOQwbNowVK1awe/duFi5cCICPjw8+Pj4263B2dsbf35+2bdsC0L59e4YOHcpjjz3GggULKCkpYdKkSYwePfqS7nwSQgghhOOrcVAzatQoUlNTmTlzJklJSQQFBREeHm4eDHz27Fm0WksDUO/evVm+fDkzZszglVdeoXXr1qxevZqOHTvWaL3Lli1j0qRJDBo0CK1Wy4gRI/j0009rmn0hhBBCOKgaP6fmeiXPqRFCCCGuP1ftOTVCCCGEEP9VEtQIIYQQwiFIUCOEEEIIhyBBjRBCCCEcggQ1QgghhHAIEtQIIYQQwiFIUCOEEEIIhyBBjRBCCCEcggQ1QgghhHAIEtQIIYQQwiFIUCOEEEIIhyBBjRBCCCEcggQ1QgghhHAIEtQIIYQQwiFIUCOEEEIIhyBBjRBCCCEcggQ1QgghhHAIEtQIIYQQwiFIUCOEEEIIhyBBjRBCCCEcggQ1QgghhHAIEtQIIYQQwiFIUCOEEEIIhyBBjRBCCCEcggQ1QgghhHAIEtQIIYQQwiFIUCOEEEIIhyBBjRBCCCEcggQ1QgghhHAIEtQIIYQQwiFIUCOEEEIIh3BZQc38+fMJDAzEzc2N4OBgoqOjq02/atUq2rVrh5ubG506dWLNmjU2n7/++uu0a9cODw8PvL29CQkJYefOnTZpjh07xl133YWvry+enp706dOHTZs2XU72hRBCCOGAahzUrFy5kilTpjBr1ixiY2Pp3LkzQ4YMISUlxW76yMhIxowZw4QJE9izZw+hoaGEhoZy4MABc5o2bdowb9489u/fz7Zt2wgMDGTw4MGkpqaa09xxxx2UlpayceNGYmJi6Ny5M3fccQdJSUmXsdlCCCGEcDQao9ForMkMwcHBdO/enXnz5gFgMBgICAjgmWeeYdq0aZXSjxo1Cr1eT1hYmHlaz549CQoKYsGCBXbXkZOTg5eXF+vXr2fQoEGkpaVRv359tmzZQt++fQHIzc3F09OTiIgIQkJCLppv0zKzs7Px9PSsySYLIYQQ4hqpyfW7Ri01xcXFxMTE2AQRWq2WkJAQoqKi7M4TFRVVKegYMmRIlemLi4tZuHAhXl5edO7cGQAfHx/atm3L0qVL0ev1lJaW8uWXX9KgQQO6du1ak00QQgghhINyqknitLQ0ysrK8PPzs5nu5+fHkSNH7M6TlJRkN33FbqOwsDBGjx5Nfn4+DRs2JCIiAl9fXwA0Gg3r168nNDSUOnXqoNVqadCgAeHh4Xh7e9tdb1FREUVFReb3OTk5NdlUIYQQQlxn/jN3Pw0YMIC4uDgiIyMZOnQo9913n3mcjtFo5Omnn6ZBgwZs3bqV6OhoQkNDGT58OBcuXLC7vNmzZ+Pl5WX+CwgI+Dc3RwghhBD/shoFNb6+vuh0OpKTk22mJycn4+/vb3cef3//S0rv4eFBq1at6NmzJ4sWLcLJyYlFixYBsHHjRsLCwlixYgU333wzXbp04fPPP6dWrVosWbLE7nqnT59Odna2+S8hIaEmmyqEEEKI60yNghoXFxe6du3Khg0bzNMMBgMbNmygV69edufp1auXTXqAiIiIKtNbL9fUfZSfn68yq7XNrlarxWAw2J3f1dUVT09Pmz8hhBBCOK4adz9NmTKFr776iiVLlnD48GGefPJJ9Ho948ePB2Ds2LFMnz7dnH7y5MmEh4czZ84cjhw5wuuvv87u3buZNGkSAHq9nldeeYUdO3Zw5swZYmJieOSRR0hMTGTkyJGACoy8vb0ZN24ce/fu5dixY0ydOpX4+HiGDRt2JfaDEEIIIa5zNRooDOoW7dTUVGbOnElSUhJBQUGEh4ebBwOfPXvWpkWld+/eLF++nBkzZvDKK6/QunVrVq9eTceOHQHQ6XQcOXKEJUuWkJaWho+PD927d2fr1q106NABUN1e4eHhvPrqqwwcOJCSkhI6dOjAb7/9Zr5DSgghhBD/v9X4OTXXK3lOjRBCCHH9uWrPqRFCCCGE+K+SoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQLiuomT9/PoGBgbi5uREcHEx0dHS16VetWkW7du1wc3OjU6dOrFmzxubz119/nXbt2uHh4YG3tzchISHs3Lmz0nL+/PNPgoODqVWrFt7e3oSGhl5O9oUQQgjhgGoc1KxcuZIpU6Ywa9YsYmNj6dy5M0OGDCElJcVu+sjISMaMGcOECRPYs2cPoaGhhIaGcuDAAXOaNm3aMG/ePPbv38+2bdsIDAxk8ODBpKammtP8/PPPPPTQQ4wfP569e/eyfft27r///svYZCGEEEI4Io3RaDTWZIbg4GC6d+/OvHnzADAYDAQEBPDMM88wbdq0SulHjRqFXq8nLCzMPK1nz54EBQWxYMECu+vIycnBy8uL9evXM2jQIEpLSwkMDOR///sfEyZMqEl2Ky0zOzsbT0/Py1qGEEIIIf5dNbl+16ilpri4mJiYGEJCQiwL0GoJCQkhKirK7jxRUVE26QGGDBlSZfri4mIWLlyIl5cXnTt3BiA2NpbExES0Wi033XQTDRs25LbbbrNp7amoqKiInJwcmz8hhBBCOK4aBTVpaWmUlZXh5+dnM93Pz4+kpCS78yQlJV1S+rCwMGrXro2bmxsff/wxERER+Pr6AnDq1ClAjb2ZMWMGYWFheHt7079/fzIyMuyud/bs2Xh5eZn/AgICarKpQgghhLjO/GfufhowYABxcXFERkYydOhQ7rvvPvM4HYPBAMCrr77KiBEj6Nq1K99++y0ajYZVq1bZXd706dPJzs42/yUkJPxr2yKEEEKIf1+NghpfX190Oh3Jyck205OTk/H397c7j7+//yWl9/DwoFWrVvTs2ZNFixbh5OTEokWLAGjYsCEAN9xwgzm9q6srLVq04OzZs3bX6+rqiqenp82fEEIIIRxXjYIaFxcXunbtyoYNG8zTDAYDGzZsoFevXnbn6dWrl016gIiIiCrTWy+3qKgIgK5du+Lq6srRo0fNn5eUlHD69GmaNWtWk00QQgghhINyqukMU6ZMYdy4cXTr1o0ePXowd+5c9Ho948ePB2Ds2LE0btyY2bNnAzB58mT69evHnDlzGDZsGCtWrGD37t0sXLgQAL1ez9tvv82dd95Jw4YNSUtLY/78+SQmJjJy5EgAPD09mThxIrNmzSIgIIBmzZrxwQcfAJjTCCGEEOL/txoHNaNGjSI1NZWZM2eSlJREUFAQ4eHh5sHAZ8+eRau1NAD17t2b5cuXM2PGDF555RVat27N6tWr6dixIwA6nY4jR46wZMkS0tLS8PHxoXv37mzdupUOHTqYl/PBBx/g5OTEQw89REFBAcHBwWzcuBFvb+9/ug+EEEII4QBq/Jya65U8p0b8f1dy4QKG/HxcW7a81lkRQohLVpPrd41baoQQ16cTAwYC0Hr7Npx8fK5xbsTVYDQa0Wg01zobQlwz/5lbuoX4rzqVfYohPw3hx6M/XuusmOWEr6Pw6FEMhYXkbd6MsbS02vSG4mLz68IjR6529sxWHVvFlL+nUFxWfPHE16HSjAzOPf88edu3X+usYCwt5fTo0Zx97HH+yw3wxvJHdFzvjAYD2X+EUfwvPS7EWFbG6Qcf5OwTT/ynv99rTYKa60jh4cNkLFt21QuF0owMzjz4EFk//XRV13MlpC9eTOqnn16Rk9xQWGh3Oe9Hv895/Xne3PHmP17H5TIYDWQWZgKQHxND4nPPEX9XKOmLFpHwxEQuzJxV/fxWT9Q25OfbTWMsKSFx6kukzpt/xfL9RtQbRJyJYPWJ1Vdsmf8lqZ9+Su7acBImPHqts0LRyVMU7t2HfutWyrKyrnV27MrbupWj3bqTtXr1tc7KJTHk52MsKbH7Wc6fazg/dSrxd4X+K3kpOnGCgt0x6DdvwaC3fw7XaHmnTpEyZw4Gvf4K5A4Kjx3jzLiHSV/0zRVZ3uWSoOY6En/3PSS/+RbZv66+quvJXLGC/N27uTDjNUqSU/6ztQL9zmhS3n2PtM+/oDj+dJXpjAYDaQsWkL9rV5Vp8rZu5WiXrmQsXlLps/xSVYB45RmvWS3znZ3vcMvKW9iXuo/8mFjz9LTP1G+wZf/yi01rjLXSzExy/vrL/L4sLc1uOn1UFDl//EHavHmU5eZewdxDakHqxRNdh0oSzl3rLJiVnE+0vD6XWE3Kq7DuCxcoTU2lYP8BjvcfQPK779kNBs498yzG/HwuTJtO+qJvOPvIBMryqr6oGo1GUj+bR9YvvwJQlpNDzpo1GMof9/FPGY1G8rZupcTODzKXJCZy7OY+JL70kt159du2AlVXEq60Uqun8JdlpFfOz85ozjw8npQ5H13S8k7dPoz0r74m7cuFVyR/+Tt2kr9zJ/oqfgLp3yJBzVVk0OvtRsFZhVmczzsPQHFCAqfuuYfsP/6gNCMD/c5oAPK2bSc/do/d5eZt3mzzvjQ1lYzvl13WiV585gwpc+bYXMSsC8QT/fqRu27dRZdTlpdH5q+/kBcZWWWaqPNRHMs8VuXnxuLiGgVQqZ9+an5dHK9+SsNQXEzupk3mZRWXFZO7fj2pcz/hzENjq+ymSXjscTAYSHnvPZUXo5GUDz8kefa7aNHQd7+Brz4rI3PZcgxFRRSdisdQWEh+7B6Ky/eX0Wik1CpgMOj1nJ8xg6yffiJj+XJK0ysXRJdq5dGVACxZ/wEFcXHm6RoXF/PriseFsayMgoMHOTN6DMlvWFqZSio8DNOkYN9+8+v8mBj0UVGcHj2GovKfKamKsbiYMquWIGN5cFVYWmiedrndTyXJKXab94vi48n+I6za42VPyh42J2yu8nN7jMaaBa6aWm7m14aCgpqtq7iYjOXLKU5IIH3RIo73H0Dx6dM1WgZA+jffcmLgIPSRlotJSeKlBVulGRnkbd/+jyouZdnZnBgwkFN330P2b79RmpRExuLFJL7wIsayMpu0xkLLMZHywQfoIyPJWrkCo9FI4ZEjnBg4iNMPPkjRqXgACg8cIG3+fC688grGsjKSXv8fiVNe4Ox7b9cojyXnz3P+1VcpPGZb/uRt2kTCY49z5sGHzNNyN24i/euvyQkPx1hQQO7acPtBvsZy+SzNVK2oBXFxZP+hfry5ND2dhKeeJvWzeSRMmnRJ3VTpixeT/vXXdj8rPmN50GzFsqQ0M5OzDz9M/o4dpH/11UUDrZJESxlfdKzqMrkm8nepa5d7jx5XZHmXSwYKXyVlWVmcHD4cQ3YOtQcMwPfpp3Br0waAh9Y+xOmc00TcG0HJ7HcpOnSY81NfwqN3L/SRUTR4+WXzxbXNrmiKT54k+YMPzcsurRCln5v0DAV791J04jgNX38dAENREWmffYbbjTdSfPIk3mPGkOZcRFZRFrWcauHh7IFHQjoJjz5GaUoKOX/9RYPJk/Ho04eCmBib5edt3Yrn0KE204rPnSN17if4PDoBl+bNiR85kpLy1hL/N9/Ae+RIjGVl6HfsQKPVktahEY9HPA7A/nH7qagkOZn4u+/BvUcPmsz9mOWHl7Ng7wIWDl5Iu3rtLPs1T0/WT6vwuuMOCvftM08vOnWKOoMGkfrRx2QsXkz9559nRotYDmccZnn6vZZt2baNA21c+evMXzzX5Tm8XL0oSbatpR3vews+E58g/Wv1ROsbaMPwMHWhS377bbJ++YWiw4fN6TW1atE2NoYLr71G9k8/0/Tbb9jun4Pn3OV4rYsm+6efAdBHRuL30kuUnDuHR+/elfZBdVyLjTTKgPt/jCNPbwnMjFatM7lrw9F5eeFRXqhkLP3OfBxZK01KJjvsT2p1vhEXq99Ey9+92/w68s+vaJrtDHFxZH6/DP+Zr5H9RxhaDw/qDBxgs7wzjzxC0aHDtIz4i/SFX5Hx/ffUe/ABjM+Otyy7pHIhmzLnI7LDwvCdOBGXgCaV9onRYODkbbdhzM+ndeR2NE5OpH2xgLoj7iHh6acpOXOWpLfewrVVK0pTUvDoczP+r76KxskJo9HI2LVjAVhz9xoCPCv/9lvG0qUYS0ow6PNx794Nj169SJ37CRnffkvgqh9xa9vW/pdhncciy/5Pev119DujabZkMaWpqWhcXanVqVOV86Z9/TVpn35GWt265u6itC++oOHbb4NGg0anu+j6DQUFpLz/PgCZ331nnn6p4zzOvzwN/dat+Dw6gTpDhlKrU0fzZwX795P108/Un/Q0TvXrW6bv24dLixboatcGQB+tLmZlaWnkRkSY0+X+9RfZq3+j7oh7AKoMnFI++JCc8HW4tmlNyfnzlJw/z4UZM2i27HtKLlwwpys8eJCcNWtUHpavIm7iPQQ1CALURT179W94Dr4V58aNK60j8aWXVNfN9kha/73JPD0nPByAkrNnVf7Kyjj31FMAuN14ozld/s6d1L7lFnMloqC0gOJUS7lReOAgYFSVI+D81Knmz/I2blT/12/A9+mn8X3qSTAayVkbrs7Bpk2B8grmu+p89bzzTpwbNMBQUEB+TCwevXtRbPX0/LIKv3mYu24dWO3fomPHcG3XDv2OHeg8vXDvcpP5M6PBQHbYn+b3hqJC7CnYu5ecNWuILDmGISmZYW8toexEPK7Nm+NUvz7pixeT/etqmn79FTofH/KjVUu4R7AENQ4pc+WPlKWqWnvuunWUJCRQ//nnKO1yA6dzTgMQeT6SzmfPmOcx1bSsL0R5f/9N0htvYrCqKZResP0x0IK9ewHIWvmjOajJ/P5780UZVH/7HTeup9SoLog3n3Fj8vI88+clZ86SOOUFm+V6DhtGzp9/UlJeQ8j84QeMBgP1HniA1I8+ImfNWnLCwmgw9UVzQAOQ/M471Bk0iAuvziBvkypASlo05ok6ZXx5mxZ9iR4PZw9y//6b1E8/RevqhnNDf8oyMsgND6ck8UWS33wLemt5ZfM0Pv7dG312Op7z3kc7/zuyf/6F9EWLbJq3i0/FYywuJru8rz5ny2a2u6mgJ/n4XmqVp8v+4w8ev1F1xRSVFvFO33fI3bDeZrtLU1PV+ssNX2Jbk7EOaACMBQUcaW/5CY/UX36iaPcavC7YJCNv/QbS9u7CLTWHpou/xaNnTwB2J+3m3eh3mdVrFo1+j6b49Bn8X59lvqiVGEqY8quBm05VX5vOWbOGnDVraLF2Da7Nm9sNaACyV68me/Vq3Hv2pNnibyk4cJD86GgK9lhaBg07YzlXBk2A/NhYCuLizAV1m13R6OrUUdteXEzBbhUEn58+Hf0W1SSfsWQpmh5tqZNvRGOs3P1kNBhI/+orAJJmzQKtllYb1uNc/pMoACUJCRjLa5zHe99syf/vv1NWXlM1ZGebg/CsH1ZwPOsEnd+dh7PWWRXyGg3HMo9VCmpKUlJIfme2zbS60evJ+vJLAFLmzKHhm29yZsz94OSE3/Rp1BlgG8wBlFp1W2T/9jsAiVNeoPDgQQDaxuxG6+FhM48hP58zY8dReOAAgM34l8IjRzl5+zDKsrKo/9xk3Lt2pSw9ncyVP+LSrBmurVvjNfwO83znnn++Up5AtbYaCgvRR0VRu08fNM7OFOzfT97Wrbh36YJHz57sStpF7a3q+0r/ehHpi5fQevPf5jvjLsyaRdGhw+Tv2kXzX35W23X4MKUXLuA5fDiNP1DBVIFVd2hpeSug170jyP7pZzKXLcOtYwfc2ralNLXqLsjC/fsp3G+p7BTExqLfHmnTvXf6vlE283wW+ymfeDyCsayU8y+8iEGvp2DfXhp/8AFlOTk41auntuP0QfMxWlrhh5St7xQrTUkxH1eATaXp3KRnQKvF+/778X5pCnNe7s+I7ZbWyYTHHqty26ylzZ9PaUoyxfGnyd+9G9e2bdF/9QY/nfiZMdGulrycP49zgwakfDiHzGXL8J00iWKra4V1S43RaKw0JOH06DG4tm5N0fHjADR8dzZ1Q0MpPneO+HtG2IyxKzp6jJy//kLj5IRHnz5oywO306NGA2CqUsb3vgUAt44d8X/9dXMAlv7Nt3iF3kVZdjZad3fcrH7O6FqQoOYKKM3MxMnqIYBGo5HMH34AoN6ECWQsWkThoUMkPPY4xeNCoZFKt/KH12h/ovqm7qyff7EJaEA1HZbl5GDIyyPJ6uKL0ciuC9HklehpvmmTzTw5YWE4t9ZR6qZO4rvW51EtrZZ6Yx8i588/KTp5krSvviK1vK/2nDaH/C3r8CpPmlLeivTlbVpu3WOgRVKhzUUIwPlUIoOA34Mh4adltAq5m7QvvqDokAoQCqx62uLvu4+h6UYaZRhYNPgE+VFlaIC940fT4ozqYjMFjCZFJ0+St22b+QJRuH8/TgONlDpp0J61RBfZ0VFQXgFz/3Y1J3/MwnjkRPX7wg6n+vWrLKT1UVG0sj9sBbdUVZhkfLvYHNSMX6daNFbOf4YHVqiLQp07h1O7e3cKjx7j3NwPLxrQWCs6ehTX5s0vmi5/xw4K9u/n9Mj7bKaX6jQEpljV+o4etenq02+PpCw3hzoDBmDIsxxHpoDGxPj0qywCSnSw4vFTlAZlkjRzJrl/byZncHdsnjZhMJCzZg0+EyaQv2cP6YsW4dq6td18l9npxnNt146iI0fwWbubpwKG8shBX77aU8a0h3Wk5CeTExFBrQ4dKNi7l7wtW3Hy9a20jPf/dxuPm/ZBcgrJ8+dRcl51E5/46B1uKg9qjEYjCRMnUpaVRZHVT7eYmAIaUK0YdQYMYFviNpYeWMLrjR/j7K/L8SoPaCqyXp51l6E1nZcnGYuXoK+mq7fk3DnSF35F2uef43bHUPRP3Itu9BNQVoa2Th1ab93C8ncfNm+v2uhSio6fwMnHB6PRaD43i0+d4sKbb5pbHABy/viD2rfcgs7bm6yff7ZZd3odaPzAaLJ/+pnCQ4eIvyuUZsuXY8i7tHFannfcQU5YGFkrV6IrD0zsGfrdMRJibIMJfWQUF16dQfaaNdTu3RuthztZf62rcpxFSeJ58+sDq79l97kd9KlqhQYDmd9/T+bR/YzYlVNVqovKWmW5AaPo6FH+/G0Ov7jEEvxrKaaztuT8eWoFBZG5bBkAafPm4dysqXm+pJmzSF/wJW4dbiA3QlXKNM7OeN5+mzm4NgU0ABdmvAYGI4b8fJuABlSrT+Kzk83vXW9oT92776ky/4UHDnD6Xkvrd07aeXJ2/Q2AW6dOaJyda7A3rjx5+N4/VJKcwqk778Tz9tto8MKLFB7YT8aSpaqFQqcjeulkWj3xEfWsYojRL+vwy4RPFpZVveCLaDh7NunfLKL4uO0FObe8i7+OnRbFjTdqWHC7FjQaPvyqlKZVXHgB/P73Ol5DhnCsZ/W/0WWSUwueeEZHl5NGpv6sAjWjRoNzgwbm2hvAvkANN5424tyoEWW5uZUCtoo+G67lmT+qDvxO+kPLJPuffTlUy3kfDf9bZruf97TQ8PUQLfO/uLT9X6qDmFYago9aThXD8xPQfrzIJt0fQ70ZHp5pfp/vAmme2N/POh27J/ah9tAhzNr+GkZg3hdlNMhWHxc98yBtegzmzMPjoaz6fDr5+9vUQBtMexmnevU4/9LLF902l1YtKT5x0vw+q2NTznsUccNO++NurNXu35/CuwZQ+rztnVebe7jTL9q2uynXXUuDNjfajAeqyLV9e1r8+gsJTz5lbuGrjsbdHe+RI2nwwhQ0Li4sHXkT3fcXEttCQ5fyIDCsu4am7Xtw49KdF11eoTO42b/RhVw3CIrZy9GMo7Qt8eHkwEEXXR6AU8OGBK5cwWtLHqLd1gSCj13Z4rbY3QXdrbeg+822tdHJ35+y7GyM5eN8tt6goe8hy7pdWrak+ORJKvJ/fRY5bkbyp79p051RE5HtNQR+/CnNHn2PknOXNrbHrUMHCg8exLV9exq9+y7xd911Weu+FB89Ug/9DU3pHpfP0O8vPp6k0ZwPyduwAX30rioH2ddUiQ7yvFzwzigmz0NHnnMZ/lmWz+NCO9Bt6juU3nzp+6Heww/j1r4d51+eZjNdV6+eubuqVreu5lYr36eeIu3zz83pNLVqmY+Xmshx15BTy0iTdKg3bix+06fXeBkXXUcNrt8S1PxDmSt/VM3ngK6+r00LgkvLljwyNpcRv6Zya5xlNyfVhWONNdxyUE1LuKUNAVsqn1yuA26haNOWy87bKT9YNkCLexFM+c2IxmAkxQsOB2jod6Dqr/2PHhoe+XILvrV8OdyuvXl67aFDyNwQgXOJCjLOe0Oj8mt4RJCGr25T3SU3njLQ9YSRqPZavr7xnYteXJ0DAtTAtQoDNPNd4e9OGm7fbSSuuYag+Mp5Xt5PS/BRg01gU1Wg4+TnZw6wTge4EJhgGQ+R6QG7W2u4Nc6I8fYBNOxxC8Wnz+Az4RFCwu4gXZvPqM1ljIg04v7yZF5MW8gbi1QB8Huwhq0dtJxpAF9+VoZ3+djwfYEaTjaEu6Ns853jVxvPZBXlGjTqb1sHDf33W9JlDbyJWgYnXP/eRWlDX7b7pJu/s603aOgZfA/O36oacoOpL5pbyy5Frpv9oBfgt54aotppeXfx5QXcpVp4dqKOzz+3zJ/nBrXL16dxdrbpNvyzlwvPvb+eY7f0Q2M00mrzZuJDQynLzKy46EqcP3mToq7taVuvLU5aJ154byCPfmvb55fqCT65oL3MUu6cDzQpbxj68MXm1Dp8hpbOjRi6+srf9ZR9Tz9K9x5EW6c2ZSdP41sh3s9p7Y/nccuBvbarhoibtKR6wXdz1P52atgQQ17eRSsL1oqcoLZfY5vBo5eq1MONrPaN0Bfl0my/arn8NkRL4m1BzK87kcxvvqVwu2UAc5GrljM+BtqUN5Dk1vcgMPR+fJ96kozvvsejVy9qderI6dFjqg2A/6nt7TXcfPjiB4VT/fq02rKZwrJC9i6Zi9cHS82f5blBZtO6/N46h/2BGhbMr/6cabdvL8f7D6AsI4OXxuvQGOG9as6zw02g/SUeZmm33sTPg2tTUKQn9NNYAq2GCbbevo0Tw4ZhzMo2T9t0f3u8R95L98mLKTmbgPdDD+F1112ceehBjAWVC4cCF6h1CWP9nV+bQqsHLq0rriZqcv2Wu5/+Ie9R99F08bc4N2lSuUukmR8ZhRn80E9LeBcNf3bXYAD8szAHNAuHapnZPxm324cAUP85SzPgO0GnK63PuUVz0Nr/2ra317Cqj4avhmjZ/vBNvDlGx/7mWvZ2cCf93n4ANMimUkCz9UYnvhxqWebZ+hqS9ZVr6keeH0Z0K8u8mzpr+eROLbEtNPzY1zL/vhZavh2s40iAhnCj/WZ28/Y0bsyxT59i5zdPUatXT5vP3Iug42m1vi0dNexoa+n/Tq2rpVQLt4+dyYH3xvJ3J0153uGt0To23aih2GqcZUH39hiDO5vfmwKaY41g0WAtH92jY+kgLXPv0vL9HR54jx6N37SXMdarS7pWtTr8fLOWN57w4tPAYxytX0zETRpW99Tw/UAdZ/w0oNFwvLElj2leGlb10bKyr+33teKFIFK7BgLqYutkwBzQ5JffzFRn0x50W9TAu5NT7mL+cMvGhHfV8mewjoibNESMbU+9Rx6pdh9bW9NNw6QndZxuYDXxlmDzy0QfDacaajhW3kVaYrUP9wVqSK9T/fJX3qIlzcv2ibb7Ay3vT9/UkKP3dQPURWFLuzLinbI45ae2/0S/fpRlZmJ01pFZx3Y5H77e0eb9PedfZ/Sfo7ntl9uYGDGRLd6Vb8utn1M5oHntQR1l1Tx0d2cby4ebO2nJdlevJ38cz9N/GuwGND/cYvmODRp4f4SWsgHBldL92V1DQuWeLwBebbCNJ+/L4vnhGZz2q5zBDb6Wc3JXaw3fDtZxrr6GIher/Tu0I2V3VB77A6olynSeWFvVV0u9hx+2nykrTm1bExHiY94/GzpruP/ZUp669Sy/N7N0CSY092Bf2j4eTHmPp4cl8cW9HtR+4RkaTH2RN0dpWDZAR1Jd0LvCVw/Vp8ELU8jXlfFOm8Ns8jjLqexTrHsiiJg+DarICay7Se3HI02sJnp72aT5YFJDNt5o/4uuGNDsszpGk30sB339559Ho9Hw6rZXeTNjmXn6rtYannxax7R7C9h8o5YMTw0rRvhWe34czj1ByvvPcOL9RzntryG+oQZjXdsLdFQ7Sz7sBTQlvpZt/LGPFtc+vfBb8R1PdzvAhowoIvX7eGmCE+/dq45Ht2nPUlDHheW32C4nrNYx3omezcHJt+Ey+XG+uqWI+QVrWf3FfWTaDgEDIHZIcw5VHmtfybzc3y+e6CqTMTVXQFbHAJqvXk3c/aG4H7Mcib8a1AC6PHcN3wxRJ8ofPYw880cZHc4COh053VqjLznBb6MDeOLhlTh3uIHVTgfYeWITO93OV1pXuq6Agv434LdRBQvv3Kel8ykj+wY0ZY+TpaYVwX5AnSCFZYXEDgqg9++WGnNiPVgf7EpWXWeiGxfgWqLhCXUjAEn1NIz+czQ6jY6P7+6N/+oomnw+n4+P/oChnaWGE95VFajbLb87WskHKcv5ruqP0TUL4NXd/6PUUIp7aV0q3iti6ro51lhDTGsNF+oZiGqn5Ywf1HWux8ZeI7ihRM/99/5NvN85DjTTENC4PS3em8AzW2ahL9FT7ARojhOQl8A9FWpoCfU1rOuqCoBAz0AiXU7jl77H/Lj57GJL7abUScOBenoOnI0AjYZt93fkcIbtoOHjjTT0KO9i8GlxA6VOR/i5j4ZRWy2tUOszdxB7s45nU1TgZl2rWtVXy7gNBnRGwAgXvCHGOwsy4JOX2pB35gTHm2g4fuYXGKoDjvPV0hu5fZCWhzdc/Fbk5LoaCtw0pNexjJuZ0Ww3DzWGJmmqaw7gh/5angozsKa7yo/aNpg3XMfozQY6xxvxsWoM2HODK6u6lXKiPKgz1TLXB2m44K2h1xG1roi654hokUjjR3Uke0OJk4ZPYz+lcTMNLZMs30uqexnTH9bhmwM9TzmDRy2ii47w3UAtD200sKqPBqNWrStJn0SSPglcNTY1ynl3aHl0nQGjxraWebQJPPe4jqGxBobtqlxbX3C7ls7xZTiVqYtM92PglQ/OFSrV625Sed7VRsuvvbWs7aZBawTPfHUOPel6kqFFGu6JNHLCH5YP0HKgmQadAe7/28DwaNt1p5df3/JL8yl0oZKz9TWAmue0n+1nb4zR0uo8/NZgI54FMNcVPIpU0G5qFTnWWEOij2UZ0x7W0TzJyJaOGkZ4FpkH0//YR8vRJvDwegN/ddEy4S/1/W+rn8FX3bPx6+tP/4Yvku+8F44tByClrvouDK7OPH3v+zz59zOcyVEDWxNaw4DeDdmTsodjTirdsxNVeejrrgqkP0/9ScSZCCLOWO6eoi/099Li6VyH5zs+Tepb75g/WjRUzX/fljLanVPb80frHIarG7Eoa9aQXXVS2TVMx5JBRsZuNDBob+XvusAFdr5wK5+ziU7xBobGGFkcAsvrvUxRdgaTXH+izvq/2Ja4DZ3VL4ukeKGCSaPloPilTRZhzXV8/6Gatj5IQ0h5C32xEzwYpgY6N65tuTtr76RB+H7xq6oMeGqoXWA0nysm29traJai7n7c2tmZgRvU9IibNHj27MSqw89ixHaemNZa7p+qoZT58MPneDUzMsbq8/Pl2/KjZjfz66dy4ZSlhTOjl5bx6w2k9e/EKveDDEzyofnjz/Jc5FQ+Wlhqbrm0J9I1gVJDKU7aaxdaSFDzDyXkJjDi9xH0a9KPjXdeoNNpLS//VH77r3sxgZ4tSMhNoKz84M/w1PDmGCe2NHgXnacn9zcrJnrTc/xy6jduvXUos9c9zF7nvdDefmvM3O6pJPim8nYMnPPVENdCQ1xLLVB90/HXp38g4n4d3nnG8vQAZeV/Glzda7OnRTb1co2c9C//1FjGc2124jfZndfbuLJj/Q5oq8F16iRqB91EUPo37LxQ/ViFIhcNxxtCs1RwsfOIGL2hkFKD+uC4c3qloAZUd0uKt+lia6lF3d56OE5aJ7xcvVhy5zI+afIJtdIPMbHzRAY1HYSHswdPbXjKnD6hdiGfhOrwql2XjrtUtJTm54afez36NenHC91e4OYfbiY5P5n9aftZfWI1YafC7G6Xm86N5cOWE5Mcw6N/WZ4me8yqpaZ2sxaA/Z8kyPAo4/UHnXAuMbLsQ0vBGNleQ5M0DX0PGrngDZ/foeP0SVX76RV8D5mdM9l7YFGl5a3poSWmtYbPFqhl/dxbQ88jRg61duUe/yHklg8eLCv/6r31lkLweCN4e5SOZm6N0JMKxlIONtPy9NNaMBoZV16IxvtryKqtYcEwHXXyjfTfb+S+LQZcS2Hg9M/o174FQ39Wt/5/dLeO3oeNrA/S0Pq8ZV2Hm2owajScs9whzN/n/qZ9Ky137bTsh82dNBi96hDvnke8fymgIqi/gl040LSE+PJjdP6g+Ty94WnzfCtu0fLwRpg3DLZ21LK3hYZSLdyzU8PwqFJSmtQGTSHJ9WB7ey3Ddql1bu6oumSPNAZ9LQ3TH9bhVgwp3hpSvTS0Kd+GmJYaup5Ur48EaMwXV4BCV/Xd55ePa8sqymJVHy2JPkb2tNCQ564+L9PBn921DNhXZq5kqOmWY+d8PUvwYdKiQ2/4fRsALm3bApbxdAcCtRwIVK+zPeCZiTr67zeys63GPHZsb3MNu9poGLVVw75mcKqhapUDeOnUx3xWvqztN2i44KPhhce0OJUamVD+3MaD7pnUcfHi66HfEOgVyKSS/qw7t56U/BSONYaoYC/uvG0yHZr1592+7zJtq2Vsxyexn5BeaHU1LL/rKK0gjczCzEqVA5O/b9QCenzap9Lx+XsI+PgXlg60lI16DydAdWduu0HL8OjybXVOxtQRUeCm4cvbdaR6GRi9xcCu1hq6H1f7dt5wLQ8OCIVNm9jfXMv+8pG6Jwe25pPYTzicZslXmU5DVDsNQaeMrOluWz7f1OAm9qTsocRZS94bEzmRcpjFXjv4o0cRD2008EtvS/rEPEtZHeZ9hn2PO1HHpQ65xbk0tjNk51BTNQawXi6U6jLNQU12bQ3fHLA8vXd8h/F08O3Ai5tfBFQlzCS7tob3R2h5PNzAwaYa87G2L9Vyh5dJeFcN53y1HGp6iDKdllYP3sukVoN5rjARH+/lkK6i5FU3a7jplJGmqaDp1ZXltQ9QoC3jXO45Ar0CK2/Iv0SCmn8oNjmW4rJiwk+Hg7NqTfi5t5EOZ41EtdMwvvlt/Hz8Z1LyLdXxT0Pm4RWguoP6GUrxreVLWkEao8PULXROWide6v4Sa06tYcUtsYzeYiCyvYbTj4RwIEMNoJz8lAsf9p8Df1tu6QxpGsLbfd5m0KpB5JVUvrvpjJ9GdZMAm+7bRHJ+MnNj5rLjwg6mdJvCG8X/UwmtbnM0aDVcqFXES1tfwoiRhrUb0eJedRH5ytiLAT8OsC2s7Hj9AR1uJfDIXwZzK8kvfZy4Z1spv3S0DCitZfXswICvvyZt/nyOpBzk+4GV+527NOjCY50sfbe+tXx582bbu0Xqu9evOBsAyff2peMu9YTSKaEf8vrAgebPOvh2YG/qXh5Y84DNPB7OHkzoOIFP96i7gNrVa4eT1onghsH8fOfPLD6wmD9O/cEpf0CnhTIDvbuGMiiviL6N+6Kp9yHGjCybZm6AUmctKrBUPhzxDRPqTGDhbUZu8utKfEosYOSmBjdxT+t7+PPUn1QlzVP91SnU8nuwhpX9NNxYvwPP3v4eh8uDGqfyVZ2/pxctPo9iaycdRq2GQlfo3LovDQtS+Dvhb/My3Z09WPtCB1LidhLdRoNWo8VgNJDrruGPYA1/d9LwfuBztO/eF1DBXmFZIdm1Naztrra1UY9+JK3ZSL4rdOx2Gwlnwivl/XBTDbNHajnnq6F2AdTrEMRfQ77g7Z1vszdlLz61fMguymZMuzHMjla3Ynu7enNLk1uYO2Au6QXpLD+8nOBnHyL3xQZs3ayC2V4dbiM6KZrlfdNJ8tSyq00BphbMDn3vIr0sl+U5G9jdWkOij5HcW7uDPoZarVpTy6kWpO236b769C4tn31RhkcRHGlSuWtDg4bXe7/OrEg1zq5Mp2FrR5XOSetkDuAzPDVMnOzC0o8NaIsrR/thPTT4Z1rG3QG8cNcHHJutBu4/MPwV4k7MYXjL4bwb/W6l+YPbhbDRM4r80nxmPaBjnL4za9rspUyn4fDXzzHn4Kc26ZO9IbyLhmJnuOBjdZuzk4bI9hpanTey7QYNA5v0N1+w3J3dWTx0MQk5CXTx64J2rBYXnWpi6tekn83yqysjpm6Zare729q3B74FN6j7jI4sD5jWYxo3NbiJvAbR8Je6tfi0v2X8VrKX2m+m4xXg4JDWvNDmBF2DQ+n54T7Szh3nYFMNXf268mD7B/n+8Pfm9U1cP7FSHu5udTfz7/oNXUkZBa623/2cfnMoKC3AYDQQ6BVId+DmnLMM+3UY74+s+nlD+9JUUNGuXjt2Je0i0VdD/AN9ab7McifhscYa9LU06Mub0mY+qCOjduVl3dXqLlrWbYmrzpVnNj5T6fPdbVTFp56bD1/2nc3rUa9zQa9aaCZ3mYybzo2tiVuJPB/J/uZq+zRo6N2oN1qNlgmdJpD/RhfOPvoozhPHMWR4MHFnojiencHkW2dx6s8xkHGY+Ox4CWquZ3e1uotWdVvxwJoHzK0xK/tZDuKBTQdyY/0beXrD0zxz0zPc0eIO/D38zZ87aZ24s+WdNhH3z8N/pkXdFoxpN4YLvc+xbOlUBg2fxC11G7D6dxXUjGl/PyHNQmju1Zz47Hjzutyd3Xnr5rd47u/nCPQMpNRQyrk8S5fYwx0exs/dD99avvjW8uXLW78kMTeRJnWa4Kpz5ZOYT0gpUAGYj5uPuTDKLlLdMG2825iXpdFoWDV8FXtS9rAraRcrjq6wu486Nu7CnpQ9rLuzEQPxxHPwrcQ3382ErjvJdbc8rfbvTlpuiymjqOsN1O5zM7X73MyyHW+TaWe5i4YsumgTp28t+4MXWt14Cw2mtaEgdg+1+9jewHlz45vZm7rX/H5S0CTWxK/htua38UjHR8xBjZuT5Umybbzb8MxNz+Dn4cc9re/BNWcVRceP4925K3Nd1EWocNENZCxbxnz/1SoPdVvxcf+PaeDegDOzu5qX1d2/O4ObDaa4rJgXu7/I1M1TuaXJLUzsPBEnrZPNsXNz45v5qN9HBC9XYzfKdBrCXu3H9O4vM6NgP98e+Jb72tjerv1A/8mMH3QLbb3bUjjgIGW+JXz2l3pIXX33+uafhAAY33E8Y9qOISE3gQkuanzPmze/yRtRb1BUpiLQG1v34eZBE8zzPNvlWd7f9T7uTu609m6Nv4c/k4ImEfq4erLvjj5vcmvzwczcPpP3b3mf5UeWcyDtAG/0foMP6nxAam4CqXVh2ZAvqONSh3f7Vr5gpxak8vX+r5ndVwU3g5qqO5Hua6u29VSW5ZhqV68dM3rOYG38Wt7WWZ5CO7f/XAY1G4Shj4Enl6qxVqt7a9g07ENGpB+mT2N1XHxz4BvaNdDAC3Pwff45Clw+5cVHdQyvP4DHO/XCz8OPxNxEPtz9IS90e4GBTQcSUCeAVUdXcSBddRHXcqrFGze/wWexn3E2Vz3z6bFOjzGo2SDc175B4b59GJx1PNflOebGzgUgsGF75t15BJ8SHR2OFVFn8GB0devi8+REjMXF+LXrzop26ryoGNS8EvwKY9qNYc7uOSw+uJha3bpyU9/ZlP2sxu0FtetPybHPzOnddG7otDq+GWL/5wrmhlrKs16NbO+GDKgTQECdyoMtarvU5o4Wd1TZ0mlSy6nWRVt7TTRoGNJ1FEMCh9DdvzsAxqHt+fNwLMUBfhjzV3C8kWo9KGvcgIA67nRp0IXfTv4GwBe3fcUfp/5gdNvRuK3UcuZ0BO97eOLl6sWUblPo26QvpYZSc8ufs9aZEoNlUPuL3V9kcpfJ9P+xf6Vt8K3lW+nX0Zt6NuWbId8wN3au3RYRa/7u/iweuphzuee4fdxdHDwxGu1OVQ7VaduBW70aM7PnTL7c9yXf832l+Xc/uBtXnXrOTf+A/jTyaMR5vWpR+eXOXzifd55JGydh1GhYfNsSAr0Cuaf1PcyPm8/AgIHc3+5+3J3defCGBwk7Fcb0rdPp2bAnL3V/idbelkcruHe5iba7otHodLQEghtaxo0FegVyOOMw8TnxDMD+uK5/g9z9dIWczTnL8iPL6ejbkelb1S1trb1b8/Pwn9FoNOSX5OPu7G533uyibAb/NJj80nxGtx3Nqz1frXI98+PmczLrJG/d/Bbuzu6MDhvNwXT1XIwNIzfQwF0NrotLicPP3Y/BPw82zxv7UKx6KFk1Vp9YzWvbXwPUyXAy+yTfHviWQ+mHAHi006NM7jLZ7rw7Luzgsb9U60nj2o1JzEukpVdLfrrzJ87lnsPPw0/VfsvTvhH1Bgm56smnvRr2IupCFH4ZRn56ZCN1vdR2RCZG8sT6JwC4vfntrIlfg7uTOzsfuHhBaDQaeSLiCYrKinDRubDjwg4A/hrxFw1rN7Q7z/HM49zzu3pGQ+9Gvfny1i9tPn9+0/OsP7uerwZ/Rc+GPe0tolpvRL3B1sStLLt9mfm7yglfR+LUqTT55JNKT+ut6EjGEUb+MRKA9/q+x+0tbqfTEtVpd2uzW/mov/3ffcnbupWCPXvwnTQJjdVA85KyErp83wVQ321uca75JxlMT342Go08FvEYWYVZLB+2HA0aig3FbEvcRr8m/WwCPKPRyLbEbXTw7UA9N8szRo5mHMVF50JzL9vn55QZytBoVAvQkoNL+HD3h7Sq24pf7/q1yn1QaiglszCzypa47KJs+qxQQcm0HtN4oL1qddubupfP9nzG4GaDGdlmpPkiNH3rdMJOhdG4dmPCR1RuRQL1Y58aZ2fzvp7eYzr3t7/f/LnpgZImvx7/lZmRMwHYN3YfGo2GhfsWsnDfQpp6NuX7277H3dmd4tOnSfnoY3wef5xaHTvww5EfSMxNZHLXycSlxNGSBrBhG17DhqGrW9du3ob+PNSmS2PpbUu5qcFN5BTnEB4fzrAWw3B3cmfa1mmUGEr4sN+HdF5qGTS/b+w+jBjJLc5ldvRsguoHkV2Uzby4eTzc4WH+PPWn+eGJ1mXMxZSUlXA29yyhv4Xa/fyxTo8xJHAIr257laOZR/F29SazyHLXm7PWmc8GfsazG5/F3dmdNfesoY6L/ZG4xWXFdP2+K01SjQzYZ2Dip39Tx6s+F/QXuHP1nQwIGMAH/T64aJ4NRgOhv4WSkJPAoiGLWHd6HcuPqHFDpvNh+tbprI1fa67EtvVuy093Vv/jv29GvcmqY6u4p/U9/Hxc3bX4cIeHWXxwMQBTuk5hfEfLE7jTF31DygcfgJsrrWJ3mcvtkrISPov7jBvq3UBBaQEzI2fy1s1vcVcr21u/b//ldnPZuvvB3WjQcO8f9+Kmc2PFHSvMLVj5JfnUdqnc7JOSn0L9WvUrBWrV+WLvF3we9zmhrUIrtZr/U3JLtx1XO6gxKTWUctN36pHUL3d/mQdvePCS5juVdYrVJ1YzodMEvFy9Lj5Dub4r+pJVlAXY//mBu3+7mxNZJ/Bz92P9yPWVPq9oy7kt5pqKqTD+/eTvvLpNBVrv3/I+tzW/ze68BqOB96Lfo4NvB4LqB7HowCKe7PykTetCRSuPrORQxiGe7PwkI/8YSXf/7jYX5pKyEkb+MRIDBlbesZKlB5dya7NbaVG3xUW3xdq4teOITYm12S57jEYjXb7rQqmxlDd6v8Hdre+2+VxfoicxL9GmxaqmTIOQL4e+RE/IqhDySvKIfiCaWk612Hh2I0sOLuG9W96rdl9XZVTYKA6lH2LFHSsoLC3k4fCHaeTRiHX3Wn7z65/k+VKVGcr4/eTv9GrU67K2w8RoNHLjUvWExRe7vci4DuOqTV9QWsA3B74hpGkIbetV/9MIMckxbE/czpNBT1ZbQTAYDSw7vIyWdVvSu1HNfhKjppL0ScSlxJGcn0xyfjJTu0296HfVe3lvckvUOCW7P1tSVsLu5N109+/OrqRdbDm3hS5+Xbi12a01ypvRaGRm5ExWn1iNk9aJNt5tCG0VSgP3BvRt3BcXnQslZSX8fvJ3Wnu3tun23TZ6G16uXhzLPEZt59o0qt2o2nWZAs6K26Qv0VPLqRZajf1xihVlFGaQW5xLM89m5BXn8eHuDxnecjhd/SwtqmWGMmZHzyY+O577293PoGbVP7eouKyYjMIM3HRu9F3ZFz93P9aNWMfRzKMk65Pp3bi3uaUF1O+2Zf6wgtp9++DSrFmVy60YTJsM/HGgORA17QtTN9yl7oeaCj8dztTNU+lcvzPf3165NemfkKDGjn8rqAFYf2Y9+9P2MyloEs66q/t0xQ92fcDSQ0sJ9g/m6yGVfwjtaMZRvtz3JZNumkQLr4sHAmWGMj6O+Zgb69/I4EDVylNYWsjgnwaTXZxNWGiY3d/RuRJKDaVoNdpKJ11xWTFajfYfjajfeHYjkzdNZkDAAD4d+Gm1aY9mHGVv6l6b2vx/SWJeIjqN7h9d+K3lFedxQX/B3My8N3UvTWo3waeWz0Xm/O8yXeDe7fsuw1oMu8a5+e+JS4nj1W2vMrX7VPoH9L/q6zuacRQvV6+LHrNVBSaX4p/M+29K0ifhpHWqsnv8SrhY0Ho1pBWksT91P63qtrri1wgJauz4N4Oaf1NBaQHh8eEMDhxsN2K/Uk5kniC9MN2mD/V6czD9IM09m1fZDSgcR8SZCHYn7WZq96nX9PZSUTOmluUbfW9k2bBlF5/ByvUS1Pwb7v39Xo5mqp/ccIR9IUGNHY4a1AghhKNIyElgyaElPNzhYZrUaXLxGaw8uOZB9qbu5aYGN7H0tqUXn8GBHc88zjs73+GpoKfMg6qvZxLU2CFBjRBCOK4kfRIrj65kVNtRV6xrVvw31OT6Le2yQgghrnv+Hv5V3pkp/v+Q334SQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDuGygpr58+cTGBiIm5sbwcHBREdHV5t+1apVtGvXDjc3Nzp16sSaNWtsPn/99ddp164dHh4eeHt7ExISws6dO+0uq6ioiKCgIDQaDXFxcZeTfSGEEEI4oBoHNStXrmTKlCnMmjWL2NhYOnfuzJAhQ0hJSbGbPjIykjFjxjBhwgT27NlDaGgooaGhHDhwwJymTZs2zJs3j/3797Nt2zYCAwMZPHgwqamplZb30ksv0ahRo5pmWwghhBAOrsa/0h0cHEz37t2ZN28eAAaDgYCAAJ555hmmTZtWKf2oUaPQ6/WEhYWZp/Xs2ZOgoCAWLFhgdx2mX+Rcv349gwYNMk9fu3YtU6ZM4eeff6ZDhw7s2bOHoKCgS8q3/Eq3EEIIcf2pyfW7Ri01xcXFxMTEEBISYlmAVktISAhRUVF254mKirJJDzBkyJAq0xcXF7Nw4UK8vLzo3LmzeXpycjKPPfYY3333He7u7hfNa1FRETk5OTZ/QgghhHBcNQpq0tLSKCsrw8/Pz2a6n58fSUlJdudJSkq6pPRhYWHUrl0bNzc3Pv74YyIiIvD19QXAaDTy8MMPM3HiRLp163ZJeZ09ezZeXl7mv4CAgEvdTCGEEEJch/4zdz8NGDCAuLg4IiMjGTp0KPfdd595nM5nn31Gbm4u06dPv+TlTZ8+nezsbPNfQkLC1cq6EEIIIf4DahTU+Pr6otPpSE5OtpmenJyMv7+/3Xn8/f0vKb2HhwetWrWiZ8+eLFq0CCcnJxYtWgTAxo0biYqKwtXVFScnJ1q1agVAt27dGDdunN31urq64unpafMnhBBCCMdVo6DGxcWFrl27smHDBvM0g8HAhg0b6NWrl915evXqZZMeICIiosr01sstKioC4NNPP2Xv3r3ExcURFxdnviV85cqVvP322zXZBCGEEEI4KKeazjBlyhTGjRtHt27d6NGjB3PnzkWv1zN+/HgAxo4dS+PGjZk9ezYAkydPpl+/fsyZM4dhw4axYsUKdu/ezcKFCwHQ6/W8/fbb3HnnnTRs2JC0tDTmz59PYmIiI0eOBKBp06Y2eahduzYALVu2pEmTJpe/9UIIIYRwGDUOakaNGkVqaiozZ84kKSmJoKAgwsPDzYOBz549i1ZraQDq3bs3y5cvZ8aMGbzyyiu0bt2a1atX07FjRwB0Oh1HjhxhyZIlpKWl4ePjQ/fu3dm6dSsdOnS4QpsphBBCCEdX4+fUXK/kOTVCCCHE9eeqPadGCCGEEOK/SoIaIYQQQjgECWqEEEII4RAkqBFCCCGEQ5CgRgghhBAOQYIaIYQQQjgECWqEEEII4RAkqBFCCCGEQ5CgRgghhBAOQYIaIYQQQjgECWqEEEII4RAkqBFCCCGEQ5CgRgghhBAOQYIaIYQQQjgECWqEEEII4RAkqBFCCCGEQ5CgRgghhBAOQYIaIYQQQjgECWqEEEII4RAkqBFCCCGEQ5CgRgghhBAOQYIaIYQQQjgECWqEEEII4RAkqBFCCCGEQ5CgRgghhBAOQYIaIYQQQjgECWqEEEII4RAkqBFCCCGEQ5CgRgghhBAOQYIaIYQQQjgECWqEEEII4RAuK6iZP38+gYGBuLm5ERwcTHR0dLXpV61aRbt27XBzc6NTp06sWbPG5vPXX3+ddu3a4eHhgbe3NyEhIezcudP8+enTp5kwYQLNmzenVq1atGzZklmzZlFcXHw52RdCCCGEA6pxULNy5UqmTJnCrFmziI2NpXPnzgwZMoSUlBS76SMjIxkzZgwTJkxgz549hIaGEhoayoEDB8xp2rRpw7x589i/fz/btm0jMDCQwYMHk5qaCsCRI0cwGAx8+eWXHDx4kI8//pgFCxbwyiuvXOZmCyGEEMLRaIxGo7EmMwQHB9O9e3fmzZsHgMFgICAggGeeeYZp06ZVSj9q1Cj0ej1hYWHmaT179iQoKIgFCxbYXUdOTg5eXl6sX7+eQYMG2U3zwQcf8MUXX3Dq1KlLyrdpmdnZ2Xh6el7SPEIIIYS4tmpy/a5RS01xcTExMTGEhIRYFqDVEhISQlRUlN15oqKibNIDDBkypMr0xcXFLFy4EC8vLzp37lxlXrKzs6lXr16VnxcVFZGTk2PzJ4QQQgjHVaOgJi0tjbKyMvz8/Gym+/n5kZSUZHeepKSkS0ofFhZG7dq1cXNz4+OPPyYiIgJfX1+7yzxx4gSfffYZTzzxRJV5nT17Nl5eXua/gICAS9lEIYQQQlyn/jN3Pw0YMIC4uDgiIyMZOnQo9913n91xOomJiQwdOpSRI0fy2GOPVbm86dOnk52dbf5LSEi4mtkXQgghxDVWo6DG19cXnU5HcnKyzfTk5GT8/f3tzuPv739J6T08PGjVqhU9e/Zk0aJFODk5sWjRIps058+fZ8CAAfTu3ZuFCxdWm1dXV1c8PT1t/oQQQgjhuGoU1Li4uNC1a1c2bNhgnmYwGNiwYQO9evWyO0+vXr1s0gNERERUmd56uUVFReb3iYmJ9O/fn65du/Ltt9+i1f5nGpmEEEII8R/gVNMZpkyZwrhx4+jWrRs9evRg7ty56PV6xo8fD8DYsWNp3Lgxs2fPBmDy5Mn069ePOXPmMGzYMFasWMHu3bvNLS16vZ63336bO++8k4YNG5KWlsb8+fNJTExk5MiRgCWgadasGR9++KH5Vm+gyhYiIYQQQvz/UuOgZtSoUaSmpjJz5kySkpIICgoiPDzcPBj47NmzNq0ovXv3Zvny5cyYMYNXXnmF1q1bs3r1ajp27AiATqfjyJEjLFmyhLS0NHx8fOjevTtbt26lQ4cOgGrZOXHiBCdOnKBJkyY2+anhHelCCCGEcFA1fk7N9UqeUyOEEEJcf67ac2qEEEIIIf6rJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4hMsKaubPn09gYCBubm4EBwcTHR1dbfpVq1bRrl073Nzc6NSpE2vWrLH5/PXXX6ddu3Z4eHjg7e1NSEgIO3futEmTkZHBAw88gKenJ3Xr1mXChAnk5eVdTvaFEEII4YBqHNSsXLmSKVOmMGvWLGJjY+ncuTNDhgwhJSXFbvrIyEjGjBnDhAkT2LNnD6GhoYSGhnLgwAFzmjZt2jBv3jz279/Ptm3bCAwMZPDgwaSmpprTPPDAAxw8eJCIiAjCwsLYsmULjz/++GVsshBCCCEckcZoNBprMkNwcDDdu3dn3rx5ABgMBgICAnjmmWeYNm1apfSjRo1Cr9cTFhZmntazZ0+CgoJYsGCB3XXk5OTg5eXF+vXrGTRoEIcPH+aGG25g165ddOvWDYDw8HBuv/12zp07R6NGjS6ab9Mys7Oz8fT0rMkmCyGEEOIaqcn1u0YtNcXFxcTExBASEmJZgFZLSEgIUVFRdueJioqySQ8wZMiQKtMXFxezcOFCvLy86Ny5s3kZdevWNQc0ACEhIWi12krdVCZFRUXk5OTY/AkhhBDCcdUoqElLS6OsrAw/Pz+b6X5+fiQlJdmdJykp6ZLSh4WFUbt2bdzc3Pj444+JiIjA19fXvIwGDRrYpHdycqJevXpVrnf27Nl4eXmZ/wICAmqyqUIIIYS4zvxn7n4aMGAAcXFxREZGMnToUO67774qx+lciunTp5OdnW3+S0hIuIK5FUIIIcR/TY2CGl9fX3Q6HcnJyTbTk5OT8ff3tzuPv7//JaX38PCgVatW9OzZk0WLFuHk5MSiRYvMy6gY4JSWlpKRkVHlel1dXfH09LT5E0IIIYTjqlFQ4+LiQteuXdmwYYN5msFgYMOGDfTq1cvuPL169bJJDxAREVFleuvlFhUVmZeRlZVFTEyM+fONGzdiMBgIDg6uySYIIYQQwkE51XSGKVOmMG7cOLp160aPHj2YO3cuer2e8ePHAzB27FgaN27M7NmzAZg8eTL9+vVjzpw5DBs2jBUrVrB7924WLlwIgF6v5+233+bOO++kYcOGpKWlMX/+fBITExk5ciQA7du3Z+jQoTz22GMsWLCAkpISJk2axOjRoy/pzichhBBCOL4aBzWjRo0iNTWVmTNnkpSURFBQEOHh4ebBwGfPnkWrtTQA9e7dm+XLlzNjxgxeeeUVWrduzerVq+nYsSMAOp2OI0eOsGTJEtLS0vDx8aF79+5s3bqVDh06mJezbNkyJk2axKBBg9BqtYwYMYJPP/30n26/EEIIIRxEjZ9Tc72S59QIIYQQ15+r9pwaIYQQQoj/KglqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEOQoEYIIYQQDkGCGiGEEEI4BAlqhBBCCOEQJKgRQgghhEO4rKBm/vz5BAYG4ubmRnBwMNHR0dWmX7VqFe3atcPNzY1OnTqxZs0a82clJSW8/PLLdOrUCQ8PDxo1asTYsWM5f/68zTKOHTvGXXfdha+vL56envTp04dNmzZdTvaFEEII4YBqHNSsXLmSKVOmMGvWLGJjY+ncuTNDhgwhJSXFbvrIyEjGjBnDhAkT2LNnD6GhoYSGhnLgwAEA8vPziY2N5bXXXiM2NpZffvmFo0ePcuedd9os54477qC0tJSNGzcSExND586dueOOO0hKSrqMzRZCCCGEo9EYjUZjTWYIDg6me/fuzJs3DwCDwUBAQADPPPMM06ZNq5R+1KhR6PV6wsLCzNN69uxJUFAQCxYssLuOXbt20aNHD86cOUPTpk1JS0ujfv36bNmyhb59+wKQm5uLp6cnERERhISEXDTfOTk5eHl5kZ2djaenZ002WQghhBDXSE2u3zVqqSkuLiYmJsYmiNBqtYSEhBAVFWV3nqioqEpBx5AhQ6pMD5CdnY1Go6Fu3boA+Pj40LZtW5YuXYper6e0tJQvv/ySBg0a0LVrV7vLKCoqIicnx+ZPCCGEEI6rRkFNWloaZWVl+Pn52Uz38/OrshsoKSmpRukLCwt5+eWXGTNmjDki02g0rF+/nj179lCnTh3c3Nz46KOPCA8Px9vb2+5yZs+ejZeXl/kvICCgJpsqhBBCiOvMf+rup5KSEu677z6MRiNffPGFebrRaOTpp5+mQYMGbN26lejoaEJDQxk+fDgXLlywu6zp06eTnZ1t/ktISPi3NkMIIYQQ14BTTRL7+vqi0+lITk62mZ6cnIy/v7/defz9/S8pvSmgOXPmDBs3brTpN9u4cSNhYWFkZmaap3/++edERESwZMkSu2N5XF1dcXV1rcnmCSGEEOI6VqOWGhcXF7p27cqGDRvM0wwGAxs2bKBXr1525+nVq5dNeoCIiAib9KaA5vjx46xfvx4fHx+b9Pn5+SqzWtvsarVaDAZDTTZBCCGEEA6qRi01AFOmTGHcuHF069aNHj16MHfuXPR6PePHjwdg7NixNG7cmNmzZwMwefJk+vXrx5w5cxg2bBgrVqxg9+7dLFy4EFABzb333ktsbCxhYWGUlZWZx9vUq1cPFxcXevXqhbe3N+PGjWPmzJnUqlWLr776ivj4eIYNG3al9oUQQgghrmM1DmpGjRpFamoqM2fOJCkpiaCgIMLDw82Dgc+ePWvTotK7d2+WL1/OjBkzeOWVV2jdujWrV6+mY8eOACQmJvL7778DEBQUZLOuTZs20b9/f3x9fQkPD+fVV19l4MCBlJSU0KFDB3777Tc6d+58udsuhBBCCAdS4+fUXK/kOTVCCCHE9eeqPadGCCGEEOK/SoIaIYQQQjgECWqEEEII4RAkqBFCCCGEQ5CgRgghhBAOQYIaIYQQQjgECWqEEEII4RAkqBFCCCGEQ5CgRgghhBAOQYIaIYQQQjgECWqEEEII4RAkqBFCCCGEQ5CgRgghhBAOQYIaIYQQQjgECWqEEEII4RAkqBFCCCGEQ5CgRgghhBAOQYIaIYQQQjgECWqEEEII4RAkqBFCCCGEQ5CgRgghhBAOQYKaayy7oIT//XGQvQlZ1zorQogqlJQZLpom5kwmb4YdQl9U+i/kSIjKvtkWz9r9F651Nq4pCWqusc82HOfb7ae5a/72a50VcY2UlBnYdy6LMoPxWmcFgNIyA9/vOENCRn616XacSmfS8lhScguvSj5mrz3MrR9tJrugxDzNaPz399GOU+m0nbGW+ZtOVJtuxBeRLNoWz2cbq093pRQUl/H73vM2++dqKTMYeXzpbt5de+Sqr+u/7svNJ3n994PX5FiszpGkHN4IO8STy2L/M2XJtSBBzb8ot7CEHafSMVgdcEeTc2u0jEx9MYlZBVc6a/+qrPxiygxGdp3O4I0/DpFfXLOabVJ2Id9siye38MoX5ln5xWw4nPyvFgrvrT3CnfO288XfV/diuO14GmsuUovLyi/mf38cYsbqAzz+XYzdNEajkW3H0xi9cAdh+y7w3tqjVyO7fLn5FMdT8vg9LhGAmDMZdP7fX3y/48xVWV9Vvt4aj8EIH6w7yoVsde5Fx2cQdTLdbvpDF3L+lXx9+NdRnv1hD8+t2HPRtBn6Ys6mVx+kVic6PoO/DiWzYPNJSi+h1epKOpWaR1J2Ib/FJZr3/7WSXVDC7LVHWBx5+l/7ni9VYqZl35zLrP67Ts0tsrkO1dSes5m8uGovqblFl72Mq0WCmqtk2s/7GP9ttM3F8allsYxeuINf9iSap3nWcja/ztQXX3S5I76I5OZ3N5KUXX3teOvxVE6l5tlM+znmHO+uPXLRGsYP0WeJOZNx0byY/BaXyNC5W3hk8S67BV5OYQkZ5dsWcyaDoDcieHftYUZ9GcU32+P53++HKs2TlV/MXweT7J54D3y9gzfCDvHphuOXnEd7vt56ivfDbffHk9/HMmHJbpbvvDIXzuz8EopKy6rPx7Z4AD7865jdz4tKy5j28z56vL2ekxW+00tVXGrgwUU7eWpZLGfS9YCqfa8/lMyYhTs4k64nU19M3/c38V150HC4ikJ74ZZTPLhop/n9nrOZlfJlMBiJT9NjNBo5l5nPiZSa5Ts73xKwZuaXMHTuFkZ8EUVOYSkzVh+olH7D4WSGfbqVn2PO1Wg91UnNLapUifhh51nS8oq478soxny1w26hbn08JWTkU1Bc/fd/uUzf06ajqRdN+9CinfT/cNNFA5uz6fn0eHs9H0XYHovZBZayKdnONpeWGXj5p30XDTij4zMIfmf9JXeRpOQUctsnW+k5ewOTV8Tx1LLYKtPGnMlk5m8HLtrC+E/sOZtpfp2cU3UZXGYw8sXfJ9lxyjbwLSwp447PtnLP59vNx0XOFaqcnbMKao4n2z/fdp3OYEX0Wbq/vZ45ERevjHwXdZpHl+yq1KW6YPNJfoo5x8pdZ/9Zpq8CCWqugqz8YlbsSmDT0VS2nUgzH7xbj6cB6kAxsT5YLtZqk5VfzKk0ffmyqi7Idp/O4KFF0Qycs5nYs5kUlpRhMBh5YdVeFmw+SXR81QHLnrOZTP9lP48tjblojSw5p5Av/j7Ja6sPcCQpl41HUjianEvMmQxzgLYk8jTd31pPvw82kZxTyDfb1LZ/VV77BfgxJqHSsh/4eiePfxfDT3YuUidT1T7YeCTFZnpiVgHFpZY8/xaXyGcbjrPnbCZr918gu6CEDYeTuWv+dqJOpvPWn4f5/O+TxJzJZEnkaU6m5hFVXggtiVKFc1xCFseTc/lqyylOl+/7S3U6TU+Pd9bz+NIYFm2LNwd2Jqm5RRSWWC54rk6VT8fcwhLGLopmxa4EUnKL+DU20eYz03eUW1hSZRACcDzFcmwdS85j1+kMWr26hkeX7ibqVDoTluxmT0ImuYW2hZd1/gDOZxUwu0IXxKk0PYPmbGZReXAG8PH6Ywz48G9+3J1An/c2EfLRZtLzqq7VGY0qwDIF4mcyLPv6t7hEjiRVfW6cSMljwpLdHDyfYw4Q/6kL2QUMnPM3fd7baLNf9ydm27R2mc7Dii17s9ccZszCHfT7YBNTfoyr8foTMvJtAjt73F10l7Ss1NwiDp7PwWCEP6sIJo4mqfP27TWHSMktqlRhOJ9luYDbCxrCDyaxcncCM1YfMO+LmDMZTP9lP5//fYKC4jKOJ+fy8LfRJOcU8WQ1wYm17SfTKLI6p/eczTK/Xrv/grksjTmTwYgvIlkadYZHl+zmg3VHLqlFKfJkGvHVnNfnMvO59aPNLN+pLt67T1uCmkcW72b5zrOE7TtPVr7tuf1D9FneCz/C6IU7bILc3+ISOZCYQ+zZLNrPDOfuz7dz4+t/mQPUquw/l82K6LPVVkjPWAWsJ+xUfo4n5zJyQRTTftkPwPxNJ+0ub29ClrkV/LXfDrL+cApfbjll/vzwhRxOlZfBcQnZ5umFJWWV9sO14HStM+CIDl+wFMDjvokmKKAuP03sZZ7m5mwpjJJzLAX9seRcerbwsVlWSk4h7649Ql13F7o28zZP/ynmHDc1rUurBnUqrX/LMUvAc8/nkYzp0ZQn+7U0T7tQoZUn8kQaG46kMGlAKw6eVwV4hr6Y6PgMerfyrXI7Ry/cUalAmPPXMTYeSWFIBz++fKgbCzafpKjUQFGpgb8OJWOwcxIZjaqG2NTHnZgzGQTUczfn47e9idzXPcAq75baiJ+nm/n1n/su8MwPsYzo0oR37unED9FnmfnbQZWn8lpn5yZe7D2nTsIxX+0wz3vvgigAGtRxNU/ToJq9Q63GOi2OPM2zg1qxclcCCx7sSgOr9dvz655EikoNbD6WyuZjqfy+9zyrn+qNRqPhaFIuofO323ynddyc2HU6g8TMAkJvaqzWuf00O62C0L+PpeBT24W0vCK+3HyKe7o0ZkSXJkz9aR9nM/JZ8GAX+rauj4erOrULS8rYn5ht02p3LDmX8ANJWH8VJ1Ly+NtOjf9Uqp5Gdd2o6+7CwfPZDPt0W5Xb+2bYIe7t0gQvd2fzuJKXf95v/vzwhVzyizPp1MSL9Lxi2jf0RKfVACp4fHTpbgAWPNiF4jJL5kxBrLW0vCK2Hk/lREoejeu6W60jh+JSAy4VAsR957KY/st+br3Bj0kDWhFxKJmTqXk8PaAVGo3GnK60zEBaXjEfhB+tFOCB6lqynr7lWCr3dGlCplVhfiQp11yBAVh7IImU3EIa1FHHi6l7c3AHf7v78WhSLkPmbqF7oDerJvY2T88uKCGvqJTGdWsBUMtZRxbq4lNQXEatKoKcfeeyzK/jEjIrfW40Ghkyd0ul6ZuOpLBi11neDO1o0wpg/RrUBXflLkvF5ERKHm396/DGH4fM59sXf5+stD9TcgptzqGs/GIWbD7FiC6Nae2nyrW9VhdNa0WlZebA6MYmdVmzP8n82dHkXI4m59Kobi0eCG5md36A+DQ993+lWhyPvXWb+ZgpLTPgpFOvP//7JMdT8njl1/1kF5RUqki98qs6vvu08uX7R4PN03+PO29+HXUqnZMpedzbNYBvt5+2md8UpL22+gChQY3IKyrlyIVcWjWozVdbT3FXUCO6NPVm+Dx13vl7udG/bQPz/NtPpPHt9nhm3tGBs1YVAVPL6NGkXNYfTmZCn+bEnq383R+6kEOHRl7m9+EHLjDx+1gGtWvAwrHdzNPjErJYs/8Cu05n2GzD3nNZGI1GNBoNkSfTeGTxbnq39GH5Yz3t7fJ/hQQ1V8ju0xkcPJ/DXUGNOJJkW2OOS8iyqWmaLiZFpWWkWDVhbjuexthegTbzfv73SXN31TfbLbXQnfGqNebrcd1o3aCOTSFesdD5Ifos9a0u2M+tjFN3aoR2ZN+5LB7+dhfFZQaOJefSzMdygQg/mETvVr6cTtMTl5BF/7b1qevuAqjBrfZqOKaTft3BZM5nFdgEUP/7/SC1nO0XvFuOp+J2WseLq/biZdUl5+6iDtHzWQW4u+iIOWM5MSNPpvP2n4d4ekArnl6uCrhVMedwddby/Y7KzaKmArYqKVbN6jmFJYQfTLL5PDGrwHyRfuXX/Qzv3IjugfWIT9MzddVeXhjclhFdmwDqAnSqwv7Zm6AurB6uTkTHZ1BQUsa2E5aLX0mZkZHlAdYNjTxp41eHXeXb++zAVny68QQHEnM4kGjprvtx9zl+3G1pzZr4fSwNvdx4866O1Kvtwh97z1cqSI8n5+LhWvl7WFreOjWmR1N2xqdzKlXPg4t2kpVfzG9P9+HTjRfv7rvtky08F9LG7mdfbjlpc7F/ffgNjOsdyC+xiazcbbkovr/uKKFBjatdz96ELJ5fuRfAfJE3b19Krk1BXVxqYMqPezmRksfB8zn8sfe8OVDqFljPXJEwGo08vTyWdQeTbZan0cDEfi1ZsPkkyTlFNhWRbSfSMBiMpOdZghp7XVJhey/wSJ/mpOQUMmGJCt52vRpic16eTc/ndLqe38oviLtOZ5ovsPqiUu6ct42k7ELWTu5Li/q1bVrR9p3LokfzeuYAzWAwsmDLScL2XsDV2VI2rDuYzP/+OIibs45hnRrSsbEXmVW0CI1fvAsAFycdxVZdqOcy88kpLOHjiGMcSMxm12nbi+XehCza+NW2CUbtBYgbj6Rwcytf8ovLaOtfh7f+PMxPMec4kJhtDhCsz3eTn2PO2VSOqrrJ4tD5HF5bfYBGdWsR0r4Bb4Qd4pGbmzOgXQPz5ybhB5MY0LY+U37cS+SJNKbd1o4Hezaj0Krr8L3wqgdJbzuRRmFJGQfP5/DXoSSiT1sqIqbAaeXuBI4k5aLVwOLxPRj7TbTNMp75YQ+RJ9NtWpuXRp3hr+dvMb8/fCGX4OY+rIpJoGcLH176aR+JWQXsPZeNt7ul3Fy9J5HxNwdy9+eRFJca+GCd/a6mzcdSbc6VLzarFpkNR1JsWla3HEu1qSybpOYWEXs2i6+2nGL9YXXe+NZ2rZTu36Qx/teGcF8lOTk5eHl5kZ2djaen5xVd9spdZ21qpPY8fksLFpY34TWuW4tFD3dj1Jc7bO5c0Grg3RE3Ep+mZ/+5bDxrOdnUQKrSu6UPI7o04Zc95/h09E2MXriD45cwhiH61UE8tyKOyCoGPDao48ryx3oyckEkmfklOOs09G/bgPuDm1Lb1cl8Aa7Ky0Pb8V74EZy0GkovMigtpL2f+aSoaFS3AH6NS6SFrwc3t/K16eYAGN65EX/sVRcCZ50GD1cnsi7SdF+Rs05DSZltHtv516m22wPAxUlrUwj5eLgw7/4uvLhq7z8a0N23tS+BPh7mZuk/JvXhnTWHzd1jFVm3Ql1M+4ae1HFzqrIb8rsJPfglNpFfrcZ+3XqDHxGH1Pfz6u3teXvN4ZpsTpX6tanPZjuF5cX0bFGPHafs5/+9EZ0Y1b2p+f36Q8nmViB7aXu28GHG6gPkFpYSZ/VohXb+dfjm4e4467TUr+NK/w82cbq8iV+jUd2FhSUGlj7Sg7f/PFxt93GL+h5Mv6090fHpfLVVHb9OWg3/u6sDDwQ3I0NfzJC5WyoFRFtfGkBAPXfe/vOQeT6AB4Kbsmxn5cC9nX8dfnmqN38dTOa5lXFV5gegua8Hm17sz/5z2eaWgCvhjhsb8vqdHej21no0Ggj08bCpALnotBSXGbi3axO2n0jjQnYhCx7swlPLYjEY1X6JnXkrOQUl9Pvgb8oMRu64sSFh+67Mrcqrn76ZoIC6LNoWz5thlgqCq5PWpqurkZcb5y8ydtHapAGtWLQtnoKS6sdQdWzsSdgzfVkSeZpZvx+86HKfuKWFuftneOdGxCVkkpBRQFBAXZvjtaKAerVIyKi+DLorqBGfjL6JJZGnKSxRd9OZWsmXPxrM/V/vrHZ+e6YOacvTA1rVeL7q1OT6LUHNP5SeV8TAOZsvelulj4cL6VZjKhrUcbVpGbi5lQ/bT9i/YNV1d6aJdy0OJF58tP29XZvwc+w5LuVbfXpAS+ZvOolWAw/2bGauqV+Mu4uOrs28bWrd9TxcKo0ZMRUK9wc3RafRXLTf+FK08PWo1AJij1ctZ36a2ItbP67crG7PjGHteevPK3Ohtqdva1+b/VVTx966jbyiUl5bfaDSuIj7ujXh/f9r787jm6rSPoD/sqdbkjZpmi5JF7pRutI1FC3QsiuCoKUy7DKDggMj4wiyqjMWxR0Vx3deYXwVq6iAg8AIZVEUKqWtUJAKAi0CbWXpBi20zXn/SHOb26aVpSU0PN/Pp59Pe+9NevLk5t7nnvOcm3Ex+LmiFkOu4/W2TTIDNS6I93fHZwd+hUAA5C/MwIais7wDvlxiPoGH69ywde69+O74eczJKcT5OvuPoVtE+ipQfKYGWUkGBKid8X/7ShGocUH/YA2ytxzFyChvDI3U4c8ft84WerR/II6cq7GZ2D/aPxCL7ovg/p71UQEX+2CtK/w9nJHbZjjC2luPxCExwAPJL+R22u5fXhiB+Z8fxDob9WMfPZqMfr3USPj7dt7xozNvZsXhu2Pneb1fCrkYnz/WD098XMhL1P+SEYrXtrcWBSudJPBVOd3yzJ6xfc3HIV+VEyJ9FVzv19PDwhGoccHMDw9AIECHx6k3xsci7+RFrM0r44Yzopf9FzU2enys3RvqabNHoa0+Pgru5N3W7yXaTw0N67Dnw8JNJsarmbGYYSOZnpoagKX39wFjDN//cgHeSjkGvbIbAODuLEGsXnVdxd+29DWo8M+JCbh/5R6Ud1LIbOGrcsLS+yM6nOl4M/5nUgIGR3h12fMBN3b+pkLhW/RVSwFqL0+XTrdre0CqbHNFZqu73cNFCh+lHHPSQ/DexAQ82NcX98f44NM/Gdt1uVt8duD6EhrAXCgGAAPDtHhmRG/uOYUCYIjVTunpJsO3fxuIcS1DK1euNePbY+cht+rW7uOjgLilPmJQS/eu5SonOdADz4+OxAtjogAACVZ1JKFernC5zoJHANeV0ADAgDBPBGtdMaVfACam+CMp0INb986EvpiY4o/XM2Ot2q/E6imJCNS48No32eiPtY8m44vH+yEzQY9nR/W57rZaHPvHcKyZmsRbplPIEaJ1va7H6xRySMVCeLhI8faEvhgT17qvZD8YheUPRgMAQr3cMKVfQLvHm3scEvDjkiEYFK7lJTS9PF3wz4nxeGlsNF4cG4WXx8VA7SrDhGQDUoJaY9bQaL6CjdWrAACpwRrkLxp8Xe1vK6O3lvd3uK61LuypoWEI0rjgDykG/H10JLc8K0mPKF8l/jYsjDdkE6hp/dxlJphrrz7+oQzZW47i10v1+PbYeW44x1spx+De/IPtJ/tP8xKaR5INiNWrIBEJ8FCCnrdtX6v9IkDtgntDPTt9ncYgNbwUciQGuHe63Qd7T+HzAnNCkxjgjhFROngpzK+x7OIVlFTU4sLla5BLhLz3HjAnm38dEoowr9YYPv3ZQS75Wv5gFN6Z0Bd75g9CiJdbu/3XOqExBqnxzVMDMTU1oNP2Wiy2SvgAcyIztq/5GGF5Pf5qZwSoW98jf7UzovzMwx1tj1NCATCspc7og72l+KLlOf6cHgIA0Lj9/rDGW4/E4c2sOO7ve0Js1wR2lNB8+7eB+Pe0JLw3MZ63/NCyITj6/DBsf/JeTO8fCB+lHCKhAL4qJ8wa2Atz0kPg5+4EF6kIH0xLQu68tHb7uUWCv/lzJRAIkBqsQZCnK9Ja9qWXH4pBaid1jLb4uTthzdREPD86EmtnpMDTTYbHB/b6/QfCPKT+ewmN5bh+vaw/z/ZANTW3aJIxAHoPZ3g4S/HnnEKUXriCwRFeeDhB3y5L93STQShoLQ62XFkO7ePFjfMCQJxBhZw/pkAm5p/sX304lvt9RJSO1x3d1qBwbbuitvnDw23ePGtCigFyiQhfzk7Fe9+egK/KCVG+ShSUVcHDRYIXxkRB7+GMlx+KQUl5LQ6dMQ9zTOkXCIlIgPf3nMSyUX1QdaURcokQ56oauP/tq3LCiChvAOYThrdKjmBPV3x3/DyWfHkY/xgThXd2HueuTOL93XGg9BIeG9ALq3aZk662QzyWXoPOJAeqIRAIsKzlID7mndZx9xFR3hgR5Y1jVsMFvb3doHKWYmC4FowxfFFwBr/VXcWj/QO5osG+BvPJ6T8/nkV+6SU8nODHq2dpK1DjgqmpAZC0PH7B8HB8mFeK1VMSYfBwwZKNxZ0OE04y+qO8ugFZSQbecuuTRP9gDYRWB50I79armFUT+uL7Xy5gWv9A7uS/Ylw04v++ndvm67+kccW61kM2cokI/56WhK3F5ZiTU8Qtj/ZT2WxrRz2NbnIx3hwfh8c/KkB9YzNWjIvGQwl6GLNzca66ARm9tUgL9cTilqLucfF+XNd1Y7OJm749KsYX2S3JW3KgB9bmncbDCX4Qi4QYu+p7qF2kuC/ah3sea5ZeB51SDiepCH8dEspNn69tmX24+L4IZCXp4SwVo6ahEVWXG2Gwqi8DwEtOAtTOSO+t7XD4IEjjAnVLbcHCkRF4+b8lmJMRgmBPVxSdruLqVQDg2f+Ye8TCdW749E9GCAQCLN1YjH/vLcUb249x9SOJAR54LTMW5dUN3DBknN4dsweFYFZLkf99K/fwhj+MvdTwt9pfkoPU2PREf9y3sv1wU5SfEkpnCcbE+ULhJIGrTIwT5y/jv8XleGxAL2hcZXCWiuDpJoNUJIRQKIDBwxkFZZcwb3AoV/uz6eBZbhjHX+2CAKvE0+DhDB+lnNez6yQRISHAHQPDtBgc4YX/HinnammCPF2Q3HJBIhW1XkQtvT8ChWVV2HfiAiprr0IqEiIzUQ+FXIJRMT5YmXsMxyrrMDcjBGoXKTYUne2wZ8j6eKL3ML/nQ/roML1/IDfU7SY316tYJmZs/cu9EFgtB4C5GSFoNjHueAGY60vOt9SmvPJQDPJLL9rsxVj5SBzOVTUgTOeGhsZmHK+sQ7SfChfqruJYZR0eG9ALw9/4FoD5osBJKuaG3MN1brziYcCcoHaV8Ul6VNc3wVUmwvT+Qch4dXen23d0wX273FRS8/bbb2PFihUoLy9HTEwMVq5ciaSkpA63X7duHRYvXoxTp04hJCQEL774IkaMGAEAaGxsxKJFi7B582acOHECSqUSGRkZWL58OXx8fHjP89VXX+G5557DwYMHIZfLkZaWhg0bNtzMS+hSA1t2qP+dnIAP95VhTnoISq2mPT4/OhKbD57DzAG98EtlHZ7bdAQCAbD8wWgo5BKoXaVwkYkRrHXF8co6PJJkaJfQtGX58AHAmDhfXv0DADz3QB8sGtkbjc0MH+WVYvbAYGgVcvRvuQpYvLGYq7xPCzW3X+0qw4LhvbnnyF+U0e7/huvcuKQmJcgDA8K0mDckjLdNHx8lnnugD/5vbymWjerDndStYzU+yYDxLSfr1GANl9TMGxIKvbszfFVOCPZ0xddHyvHS2Bh8kl+GFzabE7IIbwWaTAwHf61G/2ANV2zby9OFK06M8m0tfrPEqLDMXMBoEax1xehYH7i7SLkCaMB8BWUp+LXlnxPjceHyNWjdZCgoq0KCvzsGhWvx1GcH8cb4WBwtr8Xpi1fw7Kg+vAPcn9J64U9Ws9DkHRRNW4yL97OZRFhP5fVW8mdgBVu9vkG9tRjeklBaqF1lvBOKqJOrMJlYhFExPly9CQBE+/HjunBEb6wvPIM3x8dhS3E5vJVyLNl4GGeq6hHk6YJtLUnTf55IhUQk5E6w701MwLoDp/Hk4FBeYbv1DDSJSIgp/QLw66V63iyxeH8PxPu39iL9a1IC1K5SuLu0voeA+SQyb92P3N8+LQfb2YNCMNEYgNjnvgZj5pqF6f0Due0UcgkUVicrC+uEUSgUwM/dGa4yMepsfC3CX4e2fiZi9SrezJgBYZ6YNzgU23+q4NVBTUsN5Ap9DS1xsh5CsPQ6hHu7cUmNpQdSIBAg0tf8uVtildjp3fmJGQBE+ioRZ1DxpkcD5uFiABCLhBja0mOSGqzBxJSOZxANjvDinaRdZGIMDNNyRfYBamde4ai/2hkCgQDx/u5cjdbqqYm8WZ/p4a31dWNifbmYWBcbT00NxNRU8O4BZH1LhNVTE3HpciOi/JQI9nSDk1SE0bG+OHH+Mj7KK0VyoJpLWN6fnIgP80oxpV/rPgCYe4h++a0OA2z0yNnaPwQCAcQi/udp9ZREzFtXhGdG9MaAMG2HxxWFXAKFzvyccokIy8dGt9tm4YjeOHnhMpbcF4GNRWe4pCbO0L4nsJdnx73AQyK88GBfP8z80HYPTWaCHiUVtVy9Tl1DE1Za9X69ODYKT39+CNkPRmFBy/Twp4eF4+2dxzEwXMu7yLKHG05qPvnkEzz55JN49913kZycjNdffx1Dhw5FSUkJtNr23W3ff/89srKykJ2djfvuuw9r167F6NGjUVBQgMjISFy5cgUFBQVYvHgxYmJicOnSJcyZMwejRo1Cfn5rT8fnn3+OGTNm4IUXXsCgQYPQ1NSE4uL2N+Gyp2CtG9czYG1CkoE7MKSFeiLOoMKVa82IbHPi/WBaEgrKLmFkmxORLeMTDTheWYd7QjzRP1iDB2J98M6uX5B/6iJeGhcDP6uD2XMPtHbjW/7nyqw4LN14GFlJhk5PbG2prCrsrU80bU0yBrSbydUR6wNapK+SO2CMjffjDgLxXJct8NiAYK5I7p4QDca/tw8aVylq6pu4pCZUx/9QT0zxh8ZVhsSA1pOhQCDA6+PjcKPUrjLuKnz7k2nccssU3bZXTR3p7d2+m1btIkVKkBpXm0y8WQnW0ntr8Y/NP0Hv4cRLmgAgTq/CguHh8HV36jAxnpsRgiUbDyOmZSipMwKBADPuCcLnBb+iXy81+vjwx7Nn3BuEGfcGATDXZQHmYbDlW45i9qBgbt9qe+uBKD8lNwyhcpZi1YS+0LjJeNOrAdj8PLWVYXVSnTc4FK9s+xkvjo3CwHAt7+pcZ5UAKp0kyB4ThbqrTbyEpjNikRAPJ/hhQ9FZrvfsrUfiMHXNfsQb3KF2lWJaaiCaTazTWyEIBAI8kR6CGS2TB4y91PBwkfJORJY4S8VCjI71gdpVhkdapidbf7bHtTlJTjIGQC4W4W+fH0R6JyeYpub2XRZt96WbNXdwCBpaZks9EOvLzczUKeRcz8Y/xkQiJUgNN5mY64mxeGlcNF7cchS/Vl3BI8mtvYc1NuoWO5rG7ufuDL+Ww5PSWdLayxekRlaSAT9X1HJJTZzB3eb7pXSStBs2vlFRfkp8/Ze039/wOlg+Z4B5qE8hl8DEzMeDttq+739IMaCPjxIuMjFGxfi0297a/OHhcHeRYuyq73Gg9BLG9OXvY5mJBgyJ0MHdRYqmZhMOn63Bo/cEYnI/f15vmr3ccKFwcnIyEhMT8dZbbwEATCYT9Ho9nnjiCcyfP7/d9pmZmbh8+TI2bdrELUtJSUFsbCzeffddm/9j//79SEpKQmlpKQwGA5qamhAQEIBnn30W06dPv5Hmcrpz9lNHDp+thpNEhKBOsuaudOVaE6quNHJXpN2hsOwSxrzzPYI8XbBj3oAueU7GGN7MPQ6lkxhTUjs+wXx3/DwMHs68Xiprg17exdXcnFo+skva1p1MJoY1359C/xAN3tl5HBuKzrabudOR45W10LjKeD1M14sxhm1HKhDpq+zWfcUemk0M56rruRP/qLf24GBLb8i+Bem8xOZmNDabcK3JxN0HCDB/bYfaVcrrkbxVjDHknbyIYK1ruymyv166giGvfYNB4Vq89Uhfm4/ff+oibwisrQ/2nsKSjYeR0VsLjasM23+qxNa593TbdNxz1fVwloihdG7fw3G9sjf/hH9+cwIDwjxvOdkAzDcGdZKK8HCb2ilHkX/qIl75+me88GAUr/bMYvOhc1i54zjkEiHqGpowJTUAAWoXrqantqERxyvrbPYE3W43dP5mN+Dq1atMJBKx9evX85ZPmjSJjRo1yuZj9Ho9e+2113jLlixZwqKjozv8P9u2bWMCgYBVV1czxhjLy8tjANj777/PYmNjmU6nY8OGDWOHDh3q8DkaGhpYdXU193P69GkGgHtOcvN+PH2J/VbbYO9mtPPJD2XM/+lN7Im1BfZuyg2rv9bEisouMZPJZO+mOJQVW48y/6c3saAFX7GmZseJbUNjE2tsar7px19rama7SipZQ2MTY4yx5h4Qm/prTWzTj2dZdf01ezeF3GbV1dXXff6+oUuL8+fPo7m5GV5e/EInLy8vlJfbvp9KeXn5DW3f0NCAp59+GllZWVxGduKEeY7+smXLsGjRImzatAnu7u4YMGAALl60fa+K7OxsKJVK7kevd8xs3B6i/VR2v8GSLePi/bBhVipeGtd+PPpOJ5eIEKNXtRt+IbfGUoDvr3a+oWHWO51MLLql4SKJSIi0UE9uiNLedRDXQy4RYWS0t816FkIs7D8AZqWxsREPP/wwGGNYtWoVt9xkMlemL1y4EGPHjkV8fDxWr14NgUCAdevW2XyuBQsWoLq6mvs5fbr99wsRxyIUChCrV/1uAS65e8T7u+PdP/TFmzdRO0UI6XluqFBYo9FAJBKhooJ/59eKigrodLa/x0Sn013X9paEprS0FDt27OCNm3l7mwtnIyJa74sgk8kQFBSEsjLb3xIqk8kgk915vQmEkNtrWOTvF94TQhzDDfXUSKVSxMfHIze39Q6ZJpMJubm5MBqNNh9jNBp52wPAtm3beNtbEppjx45h+/btUKv5c+zj4+Mhk8lQUlLCe8ypU6fg79/xdENCCCGE3D1ueEr3k08+icmTJyMhIQFJSUl4/fXXcfnyZUydOhUAMGnSJPj6+iI7OxsAMGfOHKSlpeGVV17ByJEjkZOTg/z8fLz33nsAzMnJuHHjUFBQgE2bNqG5uZmrt/Hw8IBUKoVCocDMmTOxdOlS6PV6+Pv7Y8WKFQCAhx56qEsCQQghhJCe7YaTmszMTPz2229YsmQJysvLERsbi61bt3LFwGVlZRAKWzuA+vXrh7Vr12LRokV45plnEBISgg0bNiAy0nzvlDNnzuDLL78EAMTGxvL+186dOzFgwAAAwIoVKyAWizFx4kTU19cjOTkZO3bsgLu7/aebEUIIIcT+6AstCSGEEHLHoi+0JIQQQshdh5IaQgghhDgESmoIIYQQ4hAoqSGEEEKIQ6CkhhBCCCEOgZIaQgghhDgESmoIIYQQ4hAoqSGEEEKIQ6CkhhBCCCEO4Ya/JqGnstw4uaamxs4tIYQQQsj1spy3r+cLEO6apKa2thYAoNfr7dwSQgghhNyo2tpaKJXKTre5a777yWQy4ezZs3Bzc4NAIOjS566pqYFer8fp06fpe6W6AcW3e1F8uxfFt/tRjLuXvePLGENtbS18fHx4X5hty13TUyMUCuHn59et/0OhUNAHqhtRfLsXxbd7UXy7H8W4e9kzvr/XQ2NBhcKEEEIIcQiU1BBCCCHEIVBS0wVkMhmWLl0KmUxm76Y4JIpv96L4di+Kb/ejGHevnhTfu6ZQmBBCCCGOjXpqCCGEEOIQKKkhhBBCiEOgpIYQQgghDoGSGkIIIYQ4BEpqbtHbb7+NgIAAyOVyJCcn44cffrB3k3qEb775Bvfffz98fHwgEAiwYcMG3nrGGJYsWQJvb284OTkhIyMDx44d421z8eJFTJgwAQqFAiqVCtOnT0ddXd1tfBV3ruzsbCQmJsLNzQ1arRajR49GSUkJb5uGhgbMmjULarUarq6uGDt2LCoqKnjblJWVYeTIkXB2doZWq8VTTz2Fpqam2/lS7kirVq1CdHQ0dzMyo9GILVu2cOsptl1r+fLlEAgEmDt3LreMYnxrli1bBoFAwPsJDw/n1vfY+DJy03JycphUKmXvv/8+O3z4MJsxYwZTqVSsoqLC3k27423evJktXLiQffHFFwwAW79+PW/98uXLmVKpZBs2bGA//vgjGzVqFAsMDGT19fXcNsOGDWMxMTFs37597Ntvv2XBwcEsKyvrNr+SO9PQoUPZ6tWrWXFxMSsqKmIjRoxgBoOB1dXVcdvMnDmT6fV6lpuby/Lz81lKSgrr168ft76pqYlFRkayjIwMVlhYyDZv3sw0Gg1bsGCBPV7SHeXLL79kX331Ffv5559ZSUkJe+aZZ5hEImHFxcWMMYptV/rhhx9YQEAAi46OZnPmzOGWU4xvzdKlS1mfPn3YuXPnuJ/ffvuNW99T40tJzS1ISkpis2bN4v5ubm5mPj4+LDs7246t6nnaJjUmk4npdDq2YsUKbllVVRWTyWTs448/ZowxduTIEQaA7d+/n9tmy5YtTCAQsDNnzty2tvcUlZWVDADbvXs3Y8wcT4lEwtatW8dt89NPPzEAbO/evYwxc+IpFApZeXk5t82qVauYQqFgV69evb0voAdwd3dn//rXvyi2Xai2tpaFhISwbdu2sbS0NC6poRjfuqVLl7KYmBib63pyfGn46SZdu3YNBw4cQEZGBrdMKBQiIyMDe/futWPLer6TJ0+ivLycF1ulUonk5GQutnv37oVKpUJCQgK3TUZGBoRCIfLy8m57m+901dXVAAAPDw8AwIEDB9DY2MiLcXh4OAwGAy/GUVFR8PLy4rYZOnQoampqcPjw4dvY+jtbc3MzcnJycPnyZRiNRoptF5o1axZGjhzJiyVA+29XOXbsGHx8fBAUFIQJEyagrKwMQM+O713zhZZd7fz582hubua9oQDg5eWFo0eP2qlVjqG8vBwAbMbWsq68vBxarZa3XiwWw8PDg9uGmJlMJsydOxepqamIjIwEYI6fVCqFSqXibds2xrbeA8u6u92hQ4dgNBrR0NAAV1dXrF+/HhERESgqKqLYdoGcnBwUFBRg//797dbR/nvrkpOTsWbNGoSFheHcuXN49tlncc8996C4uLhHx5eSGkIc3KxZs1BcXIw9e/bYuykOJSwsDEVFRaiursZnn32GyZMnY/fu3fZulkM4ffo05syZg23btkEul9u7OQ5p+PDh3O/R0dFITk6Gv78/Pv30Uzg5OdmxZbeGhp9ukkajgUgkalcNXlFRAZ1OZ6dWOQZL/DqLrU6nQ2VlJW99U1MTLl68SPG3Mnv2bGzatAk7d+6En58ft1yn0+HatWuoqqribd82xrbeA8u6u51UKkVwcDDi4+ORnZ2NmJgYvPHGGxTbLnDgwAFUVlaib9++EIvFEIvF2L17N958802IxWJ4eXlRjLuYSqVCaGgojh8/3qP3YUpqbpJUKkV8fDxyc3O5ZSaTCbm5uTAajXZsWc8XGBgInU7Hi21NTQ3y8vK42BqNRlRVVeHAgQPcNjt27IDJZEJycvJtb/OdhjGG2bNnY/369dixYwcCAwN56+Pj4yGRSHgxLikpQVlZGS/Ghw4d4iWP27Ztg0KhQERExO15IT2IyWTC1atXKbZdID09HYcOHUJRURH3k5CQgAkTJnC/U4y7Vl1dHX755Rd4e3v37H3YbiXKDiAnJ4fJZDK2Zs0aduTIEfbHP/6RqVQqXjU4sa22tpYVFhaywsJCBoC9+uqrrLCwkJWWljLGzFO6VSoV27hxIzt48CB74IEHbE7pjouLY3l5eWzPnj0sJCSEpnS3eOyxx5hSqWS7du3iTdm8cuUKt83MmTOZwWBgO3bsYPn5+cxoNDKj0citt0zZHDJkCCsqKmJbt25lnp6edp+yeSeYP38+2717Nzt58iQ7ePAgmz9/PhMIBOzrr79mjFFsu4P17CfGKMa3at68eWzXrl3s5MmT7LvvvmMZGRlMo9GwyspKxljPjS8lNbdo5cqVzGAwMKlUypKSkti+ffvs3aQeYefOnQxAu5/JkyczxszTuhcvXsy8vLyYTCZj6enprKSkhPccFy5cYFlZWczV1ZUpFAo2depUVltba4dXc+exFVsAbPXq1dw29fX17PHHH2fu7u7M2dmZjRkzhp07d473PKdOnWLDhw9nTk5OTKPRsHnz5rHGxsbb/GruPNOmTWP+/v5MKpUyT09Plp6eziU0jFFsu0PbpIZifGsyMzOZt7c3k0qlzNfXl2VmZrLjx49z63tqfAWMMWafPiJCCCGEkK5DNTWEEEIIcQiU1BBCCCHEIVBSQwghhBCHQEkNIYQQQhwCJTWEEEIIcQiU1BBCCCHEIVBSQwghhBCHQEkNIYQQQhwCJTWEEEIIcQiU1BBCCCHEIVBSQwghhBCHQEkNIYQQQhzC/wPcIM729X6j4gAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for j in range(4):\n",
    "    plt.plot(retrain_testset_correctness[:, j], color=\"C{}\".format(j))\n",
    "    # break\n",
    "# plt.ylim(0.15, 0.2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "69f9c7e3-fe80-4896-b5e8-b860bf4ebd06",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "213ddc1e-1b37-48f0-906e-0d5f3cf5bfdc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "37e49b04-da8c-4cad-b9d6-d8321caaf448",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d1e15006-57be-466e-8dcb-e6fb4d7833ca",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "992dc09b-d060-4665-8429-334c44f9191a",
   "metadata": {},
   "outputs": [],
   "source": [
    "emp_scores_list = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9ffd055b-961c-4319-8c1a-7dea89e25d9a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bdf0db63-8afc-40d6-92f9-3a18a32633e0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8d2709ed-3499-4651-98eb-0cf583cff5b2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "ffcf2bce-eecd-419b-94d9-7fb8d6475cf4",
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.linear_model import Ridge, Lasso, RidgeCV, LassoCV"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "81d3dd3b-458a-4aec-af5c-9e6880114bb6",
   "metadata": {},
   "outputs": [],
   "source": [
    "import time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3e8b26f1-ed5b-4138-99cd-29759ed761df",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "d24904e0-e1cb-401a-a2f4-433a1ceda1ac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(512, 5000)"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "retrain_mask_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "5f97b0a0-bf4b-49e6-b49e-717e16fd6486",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(512, 1000)"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "retrain_testset_correctness.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "00fabebf-efef-4f43-aed7-5bb83bde0fae",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ad41d851-d6f2-435f-b0df-bb2d0400baf3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9dc78b9d-5b47-4438-8577-0918f3cc3f84",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "caa578c3-ca08-496c-9ade-62b4e58c1e01",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "65.64179158210754\n",
      "(1000, 5000)\n",
      "Correlation: 0.041590465764536934 (avg p value 0.468456)\n",
      "Correlation: 0.042 (avg p value 0.468456)\n",
      "Correlation: 0.0416 (avg p value 0.468456)\n",
      "Correlation: 0.04159 (avg p value 0.468456)\n"
     ]
    }
   ],
   "source": [
    "if True:\n",
    "    s = time.time()\n",
    "    infl_est_ = []\n",
    "    for i in range(1000):\n",
    "        # print(i)\n",
    "        reg = RidgeCV(cv=5, alphas=[0.1, 1.0, 1e1], \n",
    "                      # random_state=42, \n",
    "                      # n_jobs=-1\n",
    "                     ).fit(\n",
    "            retrain_mask_array[0:64], retrain_testset_correctness[0:64, i])\n",
    "        infl_est_.append(reg.coef_)\n",
    "        # break\n",
    "    print(time.time()-s)\n",
    "    \n",
    "    infl_est_ = np.stack(infl_est_)\n",
    "    print(infl_est_.shape)\n",
    "    emp_scores_list.append(infl_est_)\n",
    "\n",
    "    # compute lds\n",
    "    from scipy.stats import spearmanr\n",
    "    ####\n",
    "    margins = lds_testset_correctness[:]\n",
    "    preds = lds_mask_array[:] @ infl_est_.T\n",
    "    ####\n",
    "    rs = []\n",
    "    ps = []\n",
    "    \n",
    "    for ind in range(1000):\n",
    "        r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "        rs.append(r)\n",
    "        ps.append(p)\n",
    "        \n",
    "    rs, ps = np.array(rs), np.array(ps)\n",
    "    \n",
    "    print(f'Correlation: {rs.mean()} (avg p value {ps.mean():.6f})')\n",
    "    print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "    print(f'Correlation: {rs.mean():.4f} (avg p value {ps.mean():.6f})')\n",
    "    print(f'Correlation: {rs.mean():.5f} (avg p value {ps.mean():.6f})')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ec35c03c-1b86-451d-b2cd-ba871e8a7e2d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9974e119-a84e-444a-8807-e5ce9ecc0328",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6238f386-7b27-47df-ac16-4be8c0178f9a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "23572f8d-28c6-4773-afac-270500bb83f8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "358.94524097442627\n",
      "(1000, 5000)\n",
      "Correlation: 0.061770436930650444 (avg p value 0.456383)\n",
      "Correlation: 0.062 (avg p value 0.456383)\n",
      "Correlation: 0.0618 (avg p value 0.456383)\n",
      "Correlation: 0.06177 (avg p value 0.456383)\n"
     ]
    }
   ],
   "source": [
    "if True:\n",
    "    s = time.time()\n",
    "    infl_est_ = []\n",
    "    for i in range(1000):\n",
    "        # print(i)\n",
    "        reg = RidgeCV(cv=5, alphas=[0.1, 1.0, 1e1], \n",
    "                      # random_state=42, \n",
    "                      # n_jobs=-1\n",
    "                     ).fit(\n",
    "            retrain_mask_array[0:128], retrain_testset_correctness[0:128, i])\n",
    "        infl_est_.append(reg.coef_)\n",
    "        # break\n",
    "    print(time.time()-s)\n",
    "    \n",
    "    infl_est_ = np.stack(infl_est_)\n",
    "    print(infl_est_.shape)\n",
    "    emp_scores_list.append(infl_est_)\n",
    "\n",
    "    # compute lds\n",
    "    from scipy.stats import spearmanr\n",
    "    ####\n",
    "    margins = lds_testset_correctness[:]\n",
    "    preds = lds_mask_array[:] @ infl_est_.T\n",
    "    ####\n",
    "    rs = []\n",
    "    ps = []\n",
    "    \n",
    "    for ind in range(1000):\n",
    "        r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "        rs.append(r)\n",
    "        ps.append(p)\n",
    "        \n",
    "    rs, ps = np.array(rs), np.array(ps)\n",
    "    \n",
    "    print(f'Correlation: {rs.mean()} (avg p value {ps.mean():.6f})')\n",
    "    print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "    print(f'Correlation: {rs.mean():.4f} (avg p value {ps.mean():.6f})')\n",
    "    print(f'Correlation: {rs.mean():.5f} (avg p value {ps.mean():.6f})')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "71e72dc0-579f-47d1-87d2-b1da09de43e4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0858899c-8a03-419b-b7d1-e0315940f1d8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d30dcce7-d392-4741-bace-c2e5b11b5ac5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "9200985b-f0f7-46b4-bec0-47ff772713c2",
   "metadata": {},
   "outputs": [],
   "source": [
    "# if True:\n",
    "#     s = time.time()\n",
    "#     infl_est_ = []\n",
    "#     for i in range(1000):\n",
    "#         # print(i)\n",
    "#         reg = RidgeCV(cv=5, alphas=[0.1, 1.0, 1e1], \n",
    "#                       # random_state=42, \n",
    "#                       # n_jobs=-1\n",
    "#                      ).fit(\n",
    "#             retrain_mask_array[0:192], retrain_testset_correctness[0:192, i])\n",
    "#         infl_est_.append(reg.coef_)\n",
    "#         # break\n",
    "#     print(time.time()-s)\n",
    "    \n",
    "#     infl_est_ = np.stack(infl_est_)\n",
    "\n",
    "#     # compute lds\n",
    "#     from scipy.stats import spearmanr\n",
    "#     ####\n",
    "#     margins = lds_testset_correctness[:]\n",
    "#     preds = lds_mask_array[:] @ infl_est_.T\n",
    "#     ####\n",
    "#     rs = []\n",
    "#     ps = []\n",
    "    \n",
    "#     for ind in range(1000):\n",
    "#         r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "#         rs.append(r)\n",
    "#         ps.append(p)\n",
    "        \n",
    "#     rs, ps = np.array(rs), np.array(ps)\n",
    "    \n",
    "#     print(f'Correlation: {rs.mean()} (avg p value {ps.mean():.6f})')\n",
    "#     print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "#     print(f'Correlation: {rs.mean():.4f} (avg p value {ps.mean():.6f})')\n",
    "#     print(f'Correlation: {rs.mean():.5f} (avg p value {ps.mean():.6f})')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ffbe657f-feda-43af-94be-b79e74d7e9fb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ab13bd42-3af2-45dd-83f4-9c7625bcb0b8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "8acd0777-4c4a-41a9-a453-fd1c0e785a59",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "801.1566777229309\n",
      "(1000, 5000)\n",
      "Correlation: 0.09675125795134616 (avg p value 0.411529)\n",
      "Correlation: 0.097 (avg p value 0.411529)\n",
      "Correlation: 0.0968 (avg p value 0.411529)\n",
      "Correlation: 0.09675 (avg p value 0.411529)\n"
     ]
    }
   ],
   "source": [
    "if True:\n",
    "    s = time.time()\n",
    "    infl_est_ = []\n",
    "    for i in range(1000):\n",
    "        # print(i)\n",
    "        reg = RidgeCV(cv=5, alphas=[0.1, 1.0, 1e1], \n",
    "                      # random_state=42, \n",
    "                      # n_jobs=-1\n",
    "                     ).fit(\n",
    "            retrain_mask_array[0:256], retrain_testset_correctness[0:256, i])\n",
    "        infl_est_.append(reg.coef_)\n",
    "        # break\n",
    "    print(time.time()-s)\n",
    "    \n",
    "    infl_est_ = np.stack(infl_est_)\n",
    "    print(infl_est_.shape)\n",
    "    emp_scores_list.append(infl_est_)\n",
    "\n",
    "    # compute lds\n",
    "    from scipy.stats import spearmanr\n",
    "    ####\n",
    "    margins = lds_testset_correctness[:]\n",
    "    preds = lds_mask_array[:] @ infl_est_.T\n",
    "    ####\n",
    "    rs = []\n",
    "    ps = []\n",
    "    \n",
    "    for ind in range(1000):\n",
    "        r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "        rs.append(r)\n",
    "        ps.append(p)\n",
    "        \n",
    "    rs, ps = np.array(rs), np.array(ps)\n",
    "    \n",
    "    print(f'Correlation: {rs.mean()} (avg p value {ps.mean():.6f})')\n",
    "    print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "    print(f'Correlation: {rs.mean():.4f} (avg p value {ps.mean():.6f})')\n",
    "    print(f'Correlation: {rs.mean():.5f} (avg p value {ps.mean():.6f})')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0f245fea-f323-4285-a61a-836d687a9261",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5c207717-6a3f-4399-ba62-fc510553f305",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "9d1256d5-f327-440e-a698-da374f86c30b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2836.0363433361053\n",
      "(1000, 5000)\n",
      "Correlation: 0.13018823130310825 (avg p value 0.362545)\n",
      "Correlation: 0.130 (avg p value 0.362545)\n",
      "Correlation: 0.1302 (avg p value 0.362545)\n",
      "Correlation: 0.13019 (avg p value 0.362545)\n"
     ]
    }
   ],
   "source": [
    "if True:\n",
    "    s = time.time()\n",
    "    infl_est_ = []\n",
    "    for i in range(1000):\n",
    "        # print(i)\n",
    "        reg = RidgeCV(cv=5, alphas=[0.1, 1.0, 1e1], \n",
    "                      # random_state=42, \n",
    "                      # n_jobs=-1\n",
    "                     ).fit(\n",
    "            retrain_mask_array[0:512], retrain_testset_correctness[0:512, i])\n",
    "        infl_est_.append(reg.coef_)\n",
    "        # break\n",
    "    print(time.time()-s)\n",
    "    \n",
    "    infl_est_ = np.stack(infl_est_)\n",
    "    print(infl_est_.shape)\n",
    "    emp_scores_list.append(infl_est_)\n",
    "\n",
    "    # compute lds\n",
    "    from scipy.stats import spearmanr\n",
    "    ####\n",
    "    margins = lds_testset_correctness[:]\n",
    "    preds = lds_mask_array[:] @ infl_est_.T\n",
    "    ####\n",
    "    rs = []\n",
    "    ps = []\n",
    "    \n",
    "    for ind in range(1000):\n",
    "        r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "        rs.append(r)\n",
    "        ps.append(p)\n",
    "        \n",
    "    rs, ps = np.array(rs), np.array(ps)\n",
    "    \n",
    "    print(f'Correlation: {rs.mean()} (avg p value {ps.mean():.6f})')\n",
    "    print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "    print(f'Correlation: {rs.mean():.4f} (avg p value {ps.mean():.6f})')\n",
    "    print(f'Correlation: {rs.mean():.5f} (avg p value {ps.mean():.6f})')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b163b5fa-dc3d-4b5c-b047-47906e9bbab8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f096c9bd-f807-4068-b4a8-44862ced8945",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "be2bd708-dcf1-4e56-afbd-fa199361a364",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('./gen_emp.pkl', 'wb') as handle:\n",
    "    pickle.dump(emp_scores_list, handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "11f5d899-0614-4c74-a0c7-1cbd602e1862",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "39636db8-134e-4855-98e9-b6a95873a254",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5e6a1886-7931-47c6-a7e7-0e08887d8cd2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a6ba53d3-bf8c-4d58-aa81-f9907592302b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a2704ec4-78ed-4a18-83dd-edd141bfdc7d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f9294856-dd53-429b-a966-7b6f3a5652e1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b232286f-2b4d-4f9f-b2d5-83b1bfee9e32",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "68383713-7efc-437d-a733-f308708d263e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "ee94d3e8-94db-4fdd-b169-b6a864a396ff",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "224.11421060562134\n",
      "Correlation: 0.042724889453491094 (avg p value 0.462270)\n",
      "Correlation: 0.043 (avg p value 0.462270)\n",
      "Correlation: 0.0427 (avg p value 0.462270)\n",
      "Correlation: 0.04272 (avg p value 0.462270)\n"
     ]
    }
   ],
   "source": [
    "# if True:\n",
    "#     s = time.time()\n",
    "#     infl_est_ = []\n",
    "#     for i in range(1000):\n",
    "#         # print(i)\n",
    "#         reg = Lasso(\n",
    "#                     alpha=1e-6, # 1e-5 nan 1e-4 nan\n",
    "#                       # random_state=42, \n",
    "#                       # n_jobs=-1\n",
    "#                      ).fit(\n",
    "#             retrain_mask_array[0:192], retrain_testset_correctness[0:192, i])\n",
    "#         infl_est_.append(reg.coef_)\n",
    "#         # break\n",
    "#     print(time.time()-s)\n",
    "    \n",
    "#     infl_est_ = np.stack(infl_est_)\n",
    "\n",
    "#     # compute lds\n",
    "#     from scipy.stats import spearmanr\n",
    "#     ####\n",
    "#     margins = lds_testset_correctness[:]\n",
    "#     preds = lds_mask_array[:] @ infl_est_.T\n",
    "#     ####\n",
    "#     rs = []\n",
    "#     ps = []\n",
    "    \n",
    "#     for ind in range(1000):\n",
    "#         r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "#         rs.append(r)\n",
    "#         ps.append(p)\n",
    "        \n",
    "#     rs, ps = np.array(rs), np.array(ps)\n",
    "    \n",
    "#     print(f'Correlation: {rs.mean()} (avg p value {ps.mean():.6f})')\n",
    "#     print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "#     print(f'Correlation: {rs.mean():.4f} (avg p value {ps.mean():.6f})')\n",
    "#     print(f'Correlation: {rs.mean():.5f} (avg p value {ps.mean():.6f})')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fc389a8e-ebe8-4c52-8847-d0a7a151b182",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1671877e-eb13-48f8-9570-9016a4d1ce91",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9832b48f-6a02-4e18-a571-27cf3f9a2605",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6819e7f2-9018-4d64-8906-d7f552a0ae29",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3846cb22-f582-4c69-aab9-45350bfb272a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "40593257-fe82-402a-b93b-2774a248a0f5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8bfa538b-1b98-421e-9349-b000ee86b52c",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
