{
 "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": [
       "50000"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open('../../data/indices/50000-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": "iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAIAAAD8GO2jAAAH8klEQVR4nHVWS68dRxGuqn7MnDkz53UfwdzEQgSEEsdCihSJLRKIn8KGHX8MwYIVGwRS2CQECSlRYsy149j3Xp/HnDNnpqe7q4rFwcaJRKvVqq6u/r6vululxt//7k/wqiEigAIoIsL/b6r6pvFqqqpw6iIiwiLMzJaIVF8hIiIogL4J9x2y18H/2/UGkyqoIiIi6mnRMvO3UfRNQEQUEURQhdMIAIggJ0u/m8fJLaIiIiKqSq/jAABRTzpO0CmlrutOK6/okEWGIfR9fzz2J1nfEvffE1YiOvntKdMxhO1uwyqXF5feOVXNnF/c3kwn1XQ6PVGKyEnp3fpldzwu54tpVTHzawIBUOHNZt227Wp5Nq1rALAIGFP86vGjJ8+eKMBPHzy8uvd9MrTbt4+vr3/8w3dPClSViG5f3qWURCWEYX7/fozx5ubGWnt5cWG9e3l3e3397+1m3ff9Yr56+MHDqqrss2+ePXn29G5zF9MIgI8ePzoej9O62m7XLze3rDzGIAqL+Xw5n68367v1unT22Pfdfj+m+OLutq4bAQlxfPny7vrJ9RizAEyqJKoIiL/+zW9DGIwhBCAkYS58ASCJx8RSWF8V1aEfp5NyNqu37f4YRkIForPlqu9aREC0232bU64mhUEKfRTRh+89WJyvYorWoS4vz/f7w6HrSu+dIeaUUET1rK6naMcshTUied/tvXf3Lt8qCndo2/bQjmFoCgekVenZGlZpJsVbswYFQYbHT764ubuznty0nPSHHoEuzlZ1WW13u8PYHzkNx76oKlHxjqp66r1HkTT2OeiExTuno2HRUUZQEElZ+NALAiDQYRO33X4YBouZU9dbxKauJmVpLBmLZ8V0lotDe2QW620a03DsIBVGdDf0ibn07rKq31mdDSkdlLPw0/bGGgPKN7t2GOOibqbFxBtrl7OaCSbolmXFKQxJQxxZdV6WYkzLXIlNLKEP63RABTfxdVWy5IOIMzQIl0XZxyAMGYA5xZwzS4rReduNo51eXmx3e0WDzk9KNco5hpggsk6c89aiqvXGkt9qQLJNM00xiUIGUZVuHIuiWDT1vXuXSaTdbEi5tCQ577qui9EaY2LOOStLsiSQQ8o8qcpuyDnngjCmXE/L89XCHw5A5nJ19vxuPYY4KSfOmv44kDVIVLnST4rxeDx2R+9NyGlIkJnttmuFREkF9DAMm/WdClRVrIpi1jQiHFPeh3TMrXG2tHa72XLOInI4dMYSEj57/mI2nzEz9zmEITMXgCpCCARgl1VtWLPJRVl4v1yv1zEmhNEZo4UW5SRkHmMOQ7g4XyHQs5vn/RhndV14e2yPfRj6IYjwbFYfDp0hOlvMC+cRAQhE1BpnACFlNlmaabGom+BDymmIQVl8EVXUO9dMJ6W1YewvLs/b/SGEYQhgyNRVUU8nhMQpzZv5crEahmNOUQFzZs7Jqoh3zhAVRQHAhlg4obJB5wtrDQiCSs4x70MvqsZQ6cx2108KX1YVC6eUAYCZc46SYBxH4QxIqmiMtaoQhhhjGsc0nzUqyHlUFbQ29IO8quWqAISoqqDCGQSHkBIfVDTnbIz1zvX9LrMoKPOpPgpntjlxHHMfRj7I7c1huwlZRzTEmoA5s6ScrbOgYJHcGMFiKux0MgVDIYyl9yIqkp2xgFAUJmURlbqqrDEibFVVQdbr7aNHT1WtpXo2nyyWxMIpR0O2JJwVE6eqqnUEX03h6gKNsc6klKqy6IdRBLyzaMBbG8YYwricz+p6IiLWWHP51vl0Wt3erNfb4/lZUcc8bmFx1VTTlSGSIUuI2veJcMCMFs8Wc1Xw3lRlgYgiqgAGEQgRUVQ5Ze+stZaFrYgwc92UH3308JNPPgcXcRh3Ldl68fDBT5ar2X7b/uOzTwOBEIIntrBgRkVni8nEqwIiiQqRQ0RFAQF1zCoCqog25xxjOgaeNtXVvfNP/v6VFW9NefN19/GfH//8lx++98GDt++/k7MoIGv2zs2bGSBaa5ylnKUfxrqaxLE3gFhWzDnHFMZhv9/t91vbdV3f94eud95Yn5u6GHpzdtFcXV3ePh/++Ie/3X93+Ytf/ezsrAYwqgKoCJiFVSAxHA7Dx3/9bHm+yk+ufzRzzQfvm/NzY33tCrLFGNnu2w0irRZNCOH5dlcvidx40/7r6/UX/ZHHMX/6uT6/u/7ww/dnzXTWzJz1dHqCrIf+sNt3L7cvHl8/cuMYbCjbjf/BfWOMsS6zGGOsMdYYMs6eNZdFUTlvRXiz3m7b9ng8Hocxx/zN86f7v2zPV8vFYsGi3jkEUBVCFGGgCGYYS/hnVr/dVqFXAmadNzNrjFUwMcvtNy8AoPKOiJpqagnfefteXTfdoYt53Ky3Ctq1uy+/fLTZ7VarZemcMfTO1dVsVjOPbbsh8kRgEdViVlnv2nldA4Jtuzal1IeBVClZJZI0JNCwH7rjXjgjQDVx1lrvyFpaLabL+dx7r6DWqGgmgu9dniERCDhUIEKlWVO17ZoQbe0Ii/KsqQjAEACSijIqqKoIWUuAqiCqflLOJwXiOQICABIioKg4QPBeVdAaRAhx5BS9AUkRkSykqIgAyKCKqK+/kCcYUAZFBAKE0+8URQFVFE9RqioMCKJCaBANCZOoApAKiNghDsxiyGaNpKAIgOjIEKpotmhz5owyxOTJO2MVGBRUQFAJIQsjIYugmtPNK0hmQQEkEOH/AIgrr0LkBku7AAAAAElFTkSuQmCC",
      "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/50000-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": 16,
   "id": "317f972c-b763-40d3-8186-759118c12237",
   "metadata": {},
   "outputs": [],
   "source": [
    "class Args():\n",
    "            \n",
    "    dataset_name=\"cifar10\"\n",
    "\n",
    "    output_dir=\"../../saved/50000-0.5/ddpm/checkpoint-78200\"\n",
    "    \n",
    "    K=10\n",
    "    # project_dim=3584\n",
    "    Z=65536\n",
    "\n",
    "    # used_dim=4096\n",
    "    # used_dim=16384\n",
    "    used_dim=32768\n",
    "    \n",
    "    t_strategy='uniform'\n",
    "    \n",
    "    # f='mean_squared_l2_norm'\n",
    "    # f='l2_norm'\n",
    "    # f='loss'\n",
    "   \n",
    "args = Args()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "bb9d8f5f-5370-4157-be84-f77949771866",
   "metadata": {},
   "outputs": [],
   "source": [
    "import diffusers\n",
    "from diffusers import DDPMPipeline, DDPMScheduler, UNet2DModel\n",
    "from diffusers.optimization import get_scheduler"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3ffe8c0c-a6df-41e9-8cd9-4dfa6eaa4d89",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "0740ed2c-c98c-494d-bc1f-381653a77964",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2728"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from sklearn.random_projection import johnson_lindenstrauss_min_dim\n",
    "johnson_lindenstrauss_min_dim(n_samples=1e3, eps=0.15)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "58c5c4e8-7171-4847-9fba-51ea76b2c794",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "3002"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from sklearn.random_projection import johnson_lindenstrauss_min_dim\n",
    "johnson_lindenstrauss_min_dim(n_samples=2e3, eps=0.15)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "32c7cc29-8267-4fc3-915f-2628006b3af9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "3364"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from sklearn.random_projection import johnson_lindenstrauss_min_dim\n",
    "johnson_lindenstrauss_min_dim(n_samples=5e3, eps=0.15)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "5396c1cc-03c9-407d-b4ba-d16f4b56bc25",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "3638"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from sklearn.random_projection import johnson_lindenstrauss_min_dim\n",
    "johnson_lindenstrauss_min_dim(n_samples=1e4, eps=0.15)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a8c9ec30-0da2-4b68-9f5f-8e9e0faab1bc",
   "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/50000-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": "iVBORw0KGgoAAAANSUhEUgAAAiMAAAGdCAYAAADAAnMpAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABdYklEQVR4nO3deXxU1cH/8c+9s2ZPSCCBEPZNRAFBEBVXFNeq3bQ/n+LD09rWpbXSRalV2z5VbLU+drHS2lJtXat1r2Jt3CuC7DuILGFLQsi+zXbP749JJhkISDDJAPN9v15TZu499865l5b59pxzz7GMMQYRERGRBLETXQERERFJbgojIiIiklAKIyIiIpJQCiMiIiKSUAojIiIiklAKIyIiIpJQCiMiIiKSUAojIiIiklDuRFfgUDiOw65du8jIyMCyrERXR0RERA6BMYa6ujr69euHbR+4/eOoCCO7du2iqKgo0dUQERGRw7B9+3b69+9/wP1HRRjJyMgAoheTmZmZ4NqIiIjIoaitraWoqCj2O34gR0UYae2ayczMVBgRERE5ynzaEAsNYBUREZGEUhgRERGRhFIYERERkYRSGBEREZGEUhgRERGRhFIYERERkYRSGBEREZGEUhgRERGRhFIYERERkYRSGBEREZGEUhgRERGRhFIYERERkYRK7jCy4Pfw6g+hbG2iayIiIpK0DiuMPPjggwwaNAi/38/kyZNZtGjRQctXV1dzww030LdvX3w+HyNGjODVV189rAp3qTXPwaI/QNWWRNdEREQkabk7e8DTTz/NrFmzmDt3LpMnT+aBBx5g+vTpbNiwgT59+uxXPhgMct5559GnTx+effZZCgsL2bZtG9nZ2V1R/8/GckX/dCKJrYeIiEgS63QYuf/++7n22muZOXMmAHPnzuWf//wn8+bN49Zbb92v/Lx586isrOSDDz7A4/EAMGjQoM9W665it4QRozAiIiKSKJ3qpgkGgyxZsoRp06a1ncC2mTZtGgsWLOjwmJdeeokpU6Zwww03kJ+fz5gxY7j77ruJRI6AAGC1XL5aRkRERBKmUy0jFRUVRCIR8vPz47bn5+ezfv36Do/ZvHkzb775JldffTWvvvoqmzZt4vrrrycUCnHnnXd2eEwgECAQCMQ+19bWdqaahy7WMuJ0z/lFRETkU3X70zSO49CnTx/++Mc/MmHCBK688kpuu+025s6de8Bj5syZQ1ZWVuxVVFTUPZXTmBEREZGE61QYycvLw+VyUVZWFre9rKyMgoKCDo/p27cvI0aMwOVyxbYdd9xxlJaWEgwGOzxm9uzZ1NTUxF7bt2/vTDUPncaMiIiIJFynwojX62XChAkUFxfHtjmOQ3FxMVOmTOnwmNNOO41NmzbhOG1dIRs3bqRv3754vd4Oj/H5fGRmZsa9uoVaRkRERBKu0900s2bN4uGHH+bRRx9l3bp1XHfddTQ0NMSerpkxYwazZ8+Olb/uuuuorKzkpptuYuPGjfzzn//k7rvv5oYbbui6qzhcahkRERFJuE4/2nvllVeyZ88e7rjjDkpLSxk3bhzz58+PDWotKSnBttsyTlFREa+//jo333wzJ554IoWFhdx0003ccsstXXcVh0tP04iIiCScZYwxia7Ep6mtrSUrK4uampqu7bJ55r9hzfNw4S9h8je77rwiIiJyyL/fyb02jcaMiIiIJFxyhxGNGREREUm4To8ZOZZsf3QNTVvz6VewlfRTE10bERGR5JTULSORpjCRgAtzgPlOREREpPsldRih5akfE9F08CIiIomS1GHEsq3omyNh0T4REZEkldRhJNYyoqdpREREEiapw4haRkRERBIvqcNI25gRhREREZFEURgBTXomIiKSQEkdRiw9TSMiIpJwSR1GcKllREREJNGSOoxYVnQAq8aMiIiIJE5Sh5G2MSPqphEREUmUpA4jlkthREREJNGSOoxoOngREZHES+owYqmbRkREJOGSOoxoOngREZHES/Iw4or+qW4aERGRhEnqMNI6gNWom0ZERCRhkjqMxFpGFEZEREQSJqnDiFpGREREEi+pwwiaZ0RERCThkjqMWJYGsIqIiCRaUocRXNEwYozCiIiISKIkdRiJTQcfMYmtiIiISBJL6jDS+jSNWkZEREQSJ6nDiOVqfbRXLSMiIiKJktRhpNLlpSI3l+bkvg0iIiIJldS/wm9a6RSfN43d/pxEV0VERCRpJXUYab149dKIiIgkTlKHEcuyADBYCa6JiIhI8krqMGK3hBEHNY2IiIgkSpKHkeifjknq2yAiIpJQSf0r3NZNIyIiIomS1GEk1k2jNCIiIpIwCiOAowGsIiIiCZPUYcSyopevMCIiIpI4SR1GbLu1ZUREREQSJbnDSEvLiOYZERERSZykDiOW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MzNT/0XvIbrXPUP3uWfoPvcM3eee0x33+mAtIq00gFVEREQSSmFEREREEiqpw4jP5+POO+/E5/MluirHPN3rnqH73DN0n3uG7nPPSfS9PioGsIqIiMixK6lbRkRERCTxFEZEREQkoRRGREREJKEURkRERCShkjqMPPjggwwaNAi/38/kyZNZtGhRoqt01JgzZw4nn3wyGRkZ9OnTh8svv5wNGzbElWlubuaGG24gNzeX9PR0vvCFL1BWVhZXpqSkhIsvvpjU1FT69OnDD37wA8LhcE9eylHlnnvuwbIsvvvd78a26T53nZ07d/Jf//Vf5ObmkpKSwgknnMDixYtj+40x3HHHHfTt25eUlBSmTZvGxx9/HHeOyspKrr76ajIzM8nOzuZrX/sa9fX1PX0pR6xIJMLtt9/O4MGDSUlJYejQofzv//5v3Nolus+H59133+XSSy+lX79+WJbFCy+8ELe/q+7rypUrmTp1Kn6/n6KiIn75y19+9sqbJPXUU08Zr9dr5s2bZ9asWWOuvfZak52dbcrKyhJdtaPC9OnTzV/+8hezevVqs3z5cnPRRReZAQMGmPr6+liZb33rW6aoqMgUFxebxYsXm1NOOcWceuqpsf3hcNiMGTPGTJs2zSxbtsy8+uqrJi8vz8yePTsRl3TEW7RokRk0aJA58cQTzU033RTbrvvcNSorK83AgQPNf//3f5uFCxeazZs3m9dff91s2rQpVuaee+4xWVlZ5oUXXjArVqwwn/vc58zgwYNNU1NTrMwFF1xgxo4daz788EPz3nvvmWHDhpmvfOUribikI9Jdd91lcnNzzSuvvGK2bNlinnnmGZOenm5+/etfx8roPh+eV1991dx2223mueeeM4B5/vnn4/Z3xX2tqakx+fn55uqrrzarV682Tz75pElJSTF/+MMfPlPdkzaMTJo0ydxwww2xz5FIxPTr18/MmTMngbU6epWXlxvAvPPOO8YYY6qrq43H4zHPPPNMrMy6desMYBYsWGCMif4Px7ZtU1paGivz0EMPmczMTBMIBHr2Ao5wdXV1Zvjw4eaNN94wZ555ZiyM6D53nVtuucWcfvrpB9zvOI4pKCgw9957b2xbdXW18fl85sknnzTGGLN27VoDmI8++ihW5rXXXjOWZZmdO3d2X+WPIhdffLH5n//5n7htn//8583VV19tjNF97ir7hpGuuq+///3vTU5OTty/HbfccosZOXLkZ6pvUnbTBINBlixZwrRp02LbbNtm2rRpLFiwIIE1O3rV1NQA0KtXLwCWLFlCKBSKu8ejRo1iwIABsXu8YMECTjjhBPLz82Nlpk+fTm1tLWvWrOnB2h/5brjhBi6++OK4+wm6z13ppZdeYuLEiXzpS1+iT58+jB8/nocffji2f8uWLZSWlsbd66ysLCZPnhx3r7Ozs5k4cWKszLRp07Btm4ULF/bcxRzBTj31VIqLi9m4cSMAK1as4P333+fCCy8EdJ+7S1fd1wULFnDGGWfg9XpjZaZPn86GDRuoqqo67PodFQvldbWKigoikUjcP84A+fn5rF+/PkG1Ono5jsN3v/tdTjvtNMaMGQNAaWkpXq+X7OzsuLL5+fmUlpbGynT0d9C6T6Keeuopli5dykcffbTfPt3nrrN582YeeughZs2axY9+9CM++ugjvvOd7+D1ernmmmti96qje9n+Xvfp0yduv9vtplevXrrXLW699VZqa2sZNWoULpeLSCTCXXfdxdVXXw2g+9xNuuq+lpaWMnjw4P3O0bovJyfnsOqXlGFEutYNN9zA6tWref/99xNdlWPO9u3buemmm3jjjTfw+/2Jrs4xzXEcJk6cyN133w3A+PHjWb16NXPnzuWaa65JcO2OHX//+995/PHHeeKJJzj++ONZvnw53/3ud+nXr5/ucxJLym6avLw8XC7Xfk8clJWVUVBQkKBaHZ1uvPFGXnnlFd566y369+8f215QUEAwGKS6ujqufPt7XFBQ0OHfQes+iXbDlJeXc9JJJ+F2u3G73bzzzjv85je/we12k5+fr/vcRfr27cvo0aPjth133HGUlJQAbffqYP9uFBQUUF5eHrc/HA5TWVmpe93iBz/4AbfeeitXXXUVJ5xwAl/96le5+eabmTNnDqD73F266r52178nSRlGvF4vEyZMoLi4OLbNcRyKi4uZMmVKAmt29DDGcOONN/L888/z5ptv7tdsN2HCBDweT9w93rBhAyUlJbF7PGXKFFatWhX3X/433niDzMzM/X4UktW5557LqlWrWL58eew1ceJErr766th73eeucdppp+33ePrGjRsZOHAgAIMHD6agoCDuXtfW1rJw4cK4e11dXc2SJUtiZd58800cx2Hy5Mk9cBVHvsbGRmw7/qfH5XLhOA6g+9xduuq+TpkyhXfffZdQKBQr88YbbzBy5MjD7qIBkvvRXp/PZx555BGzdu1a841vfMNkZ2fHPXEgB3bdddeZrKws8/bbb5vdu3fHXo2NjbEy3/rWt8yAAQPMm2++aRYvXmymTJlipkyZEtvf+sjp+eefb5YvX27mz59vevfurUdOP0X7p2mM0X3uKosWLTJut9vcdddd5uOPPzaPP/64SU1NNY899liszD333GOys7PNiy++aFauXGkuu+yyDh+NHD9+vFm4cKF5//33zfDhw5P+kdP2rrnmGlNYWBh7tPe5554zeXl55oc//GGsjO7z4amrqzPLli0zy5YtM4C5//77zbJly8y2bduMMV1zX6urq01+fr756le/alavXm2eeuopk5qaqkd7P4vf/va3ZsCAAcbr9ZpJkyaZDz/8MNFVOmoAHb7+8pe/xMo0NTWZ66+/3uTk5JjU1FRzxRVXmN27d8edZ+vWrebCCy80KSkpJi8vz3zve98zoVCoh6/m6LJvGNF97jovv/yyGTNmjPH5fGbUqFHmj3/8Y9x+x3HM7bffbvLz843P5zPnnnuu2bBhQ1yZvXv3mq985SsmPT3dZGZmmpkzZ5q6urqevIwjWm1trbnpppvMgAEDjN/vN0OGDDG33XZb3KOius+H56233urw3+VrrrnGGNN193XFihXm9NNPNz6fzxQWFpp77rnnM9fdMqbdtHciIiIiPSwpx4yIiIjIkUNhRERERBJKYUREREQSSmFEREREEkphRERERBJKYUREREQSSmFEREREEkphRERERBJKYUREREQSSmFEREREEkphRERERBJKYUREREQS6v8D0PSi7P7ISQsAAAAASUVORK5CYII=",
      "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, 50000)"
      ]
     },
     "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/50000-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": "iVBORw0KGgoAAAANSUhEUgAAAjUAAAGdCAYAAADqsoKGAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABk5klEQVR4nO3deXxU5aE//s/sM0lmJvueEPZIgAQChKAISK5YcaFulHoL11Jre9Xay723LkXR+/15sbVWr0JFrFftwgWxrVqKWHalRLYAsu8kIclkz6yZ9ZzfH08yYcxCwmLg8HnzOq+ZnHnOmWeeOfOcz3nOmUEly7IMIiIiomucur8rQERERHQ5MNQQERGRIjDUEBERkSIw1BAREZEiMNQQERGRIjDUEBERkSIw1BAREZEiMNQQERGRImj7uwLfFEmSUF1dDbPZDJVK1d/VISIiol6QZRlOpxPp6elQq3sei7luQk11dTWysrL6uxpERER0ESorK5GZmdljmesm1JjNZgCiUSwWSz/XhoiIiHrD4XAgKysrvB/vyXUTatpPOVksFoYaIiKia0xvLh3hhcJERESkCAw1REREpAgMNURERKQIDDVERESkCAw1REREpAgMNURERKQIDDVERESkCAw1REREpAgMNURERKQIFxVqli5dipycHBiNRhQVFWHnzp09ll+9ejVyc3NhNBoxatQorF27NuLx559/Hrm5uYiOjkZcXBxKSkqwY8eOLtfl8/lQUFAAlUqFffv2XUz1iYiISIH6HGpWrVqFBQsWYNGiRSgrK0N+fj5mzJiBurq6Lstv374dc+bMwfz587F3717MmjULs2bNwsGDB8Nlhg0bhiVLluDAgQPYtm0bcnJycOutt6K+vr7T+n72s58hPT29r9UmIiIihVPJsiz3ZYGioiKMHz8eS5YsAQBIkoSsrCw8/vjjeOqppzqVnz17NtxuN9asWROeN3HiRBQUFGDZsmVdPofD4YDVasWGDRswffr08PxPP/0UCxYswJ/+9Cfk5eVh7969KCgo6FW929dpt9v5fz8RERFdI/qy/+7TSI3f78eePXtQUlLSsQK1GiUlJSgtLe1ymdLS0ojyADBjxoxuy/v9fixfvhxWqxX5+fnh+bW1tXj44Yfx+9//HlFRUResq8/ng8PhiJiI6DrnbgR2vg189QEQCvZ3bYjoMuvT/9Ld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wGq1YsOGDZg+fXqXZV5++WW8+eabOH36dK/q3b5Ou90Oi8XSq2WIiIiof/Vl/92nkRq/3489e/agpKSkYwVqNUpKSlBaWtrlMqWlpRHlAWDGjBndlvf7/Vi+fDmsVivy8/O7rYvdbkd8fHy3j/t8PjgcjoiJiIiIlKtPoaahoQGhUAgpKSkR81NSUmCz2bpcxmaz9ar8mjVrEBMTA6PRiFdffRXr169HYmJil+s8efIk3njjDTzyyCPd1nXx4sWwWq3hKSsrqzcvkYiIiK5RV823n6ZNm4Z9+/Zh+/btuO222/DAAw90eZ1OVVUVbrvtNtx///14+OGHu13f008/DbvdHp4qKyuvZPWJiIion/Up1CQmJkKj0aC2tjZifm1tLVJTU7tcJjU1tVflo6OjMWTIEEycOBHvvPMOtFot3nnnnYgy1dXVmDZtGiZNmoTly5f3WFeDwQCLxRIxERERkXL1KdTo9XoUFhZi48aN4XmSJGHjxo0oLi7ucpni4uKI8gCwfv36bsufv16fzxf+u6qqClOnTkVhYSHeffddqNVXzSATERERXQW0fV1gwYIFmDdvHsaNG4cJEybgtddeg9vtxkMPPQQAmDt3LjIyMrB48WIAwBNPPIEpU6bglVdewcyZM7Fy5Urs3r07PNLidrvx4osv4q677kJaWhoaGhqwdOlSVFVV4f777wfQEWgGDBiAX/3qV+GvegPodoSIiIiIri99DjWzZ89GfX09nnvuOdhsNhQUFGDdunXhi4ErKioiRlEmTZqEFStWYOHChXjmmWcwdOhQfPTRRxg5ciQAQKPR4OjRo3j//ffR0NCAhIQEjB8/Hl988QXy8vIAiJGdkydP4uTJk8jMzIyoTx+/kU5EREQK1effqblW8XdqiIiIrj1X7HdqiIiIiK5WDDVERESkCAw1REREpAgMNURERKQIDDVERESkCAw1REREpAgMNURERKQIDDVERESkCAw1REREpAgMNURERKQIDDVERESkCAw1REREpAgMNURERKQIDDVERESkCAw1REREpAgMNURERKQIDDVERESkCAw1REREpAgMNURERKQIDDVERESkCAw1REREpAgMNURERKQIDDVERESkCAw1REREpAgMNURERKQIDDVERESkCAw1REREpAgMNURERKQIDDVERESkCAw1REREpAgMNURERKQIDDVE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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": 28,
   "id": "649a172c-968c-4aa3-b086-b32d64d22424",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "27"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from scipy.stats import spearmanr, pearsonr\n",
    "\n",
    "lamb_list = [\n",
    "        # 0,\n",
    "\n",
    "        1e-2, 2e-2, 5e-2,\n",
    "        1e-1, 2e-1, 5e-1,\n",
    "        1e0, 2e0, 5e0,\n",
    "        1e1, 2e1, 5e1,\n",
    "        1e2, 2e2, 5e2,\n",
    "        1e3, 2e3, 5e3, \n",
    "        1e4, 2e4, 5e4, \n",
    "        1e5, 2e5, 5e5, \n",
    "        1e6, 2e6, 5e6, \n",
    "    \n",
    "        # 1e7, 2e7, 5e7,\n",
    "        # 1e8, 2e8, 5e8,\n",
    "        # 1e9, 2e9, 5e9,\n",
    "        # 1e10, 2e10, 5e10, \n",
    "        # 1e11, 2e11, 5e11,\n",
    "        # 1e12\n",
    "    ]\n",
    "\n",
    "len(lamb_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "effb0646-37be-44c2-8b2e-7bf3c67ea049",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(50000, 65536)\n",
      "(50000, 32768)\n",
      "(1000, 65536)\n",
      "(1000, 32768)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_3356/2286212090.py:34: UserWarning: The given NumPy array is not writable, and PyTorch does not support non-writable tensors. This means writing to this tensor will result in undefined behavior. You may want to copy the array to protect its data or make it writable before converting it to a tensor. This type of warning will be suppressed for the rest of this program. (Triggered internally at ../torch/csrc/utils/tensor_numpy.cpp:206.)\n",
      "  gen_dstore_keys = torch.from_numpy(gen_dstore_keys).cuda()\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0022, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.004 (avg p value 0.503179)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0023, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.000 (avg p value 0.509236)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0023, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.001 (avg p value 0.484085)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0021, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.004 (avg p value 0.488198)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.002 (avg p value 0.504467)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.002 (avg p value 0.506814)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0024, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.001 (avg p value 0.502962)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0021, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.003 (avg p value 0.490553)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0022, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.001 (avg p value 0.491683)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.002 (avg p value 0.499190)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0004, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.008 (avg p value 0.508046)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.003 (avg p value 0.501412)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.004 (avg p value 0.506984)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0015, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.003 (avg p value 0.519877)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0012, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.001 (avg p value 0.498219)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0008, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.004 (avg p value 0.492899)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0004, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.091 (avg p value 0.423852)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.112 (avg p value 0.384825)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.3549e-05, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.109 (avg p value 0.385124)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.7904e-05, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.104 (avg p value 0.390312)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9537e-05, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.094 (avg p value 0.408119)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8532e-06, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.085 (avg p value 0.419340)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9534e-06, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.077 (avg p value 0.437144)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9897e-06, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.067 (avg p value 0.454312)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9674e-07, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.060 (avg p value 0.466118)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9896e-07, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.054 (avg p value 0.476500)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9977e-07, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.046 (avg p value 0.489027)\n",
      "(50000, 65536)\n",
      "(50000, 32768)\n",
      "(1000, 65536)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0133, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.004 (avg p value 0.496669)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0036, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.005 (avg p value 0.502920)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0026, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.003 (avg p value 0.504669)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0032, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.002 (avg p value 0.484083)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0006, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.004 (avg p value 0.507030)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0029, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.001 (avg p value 0.495401)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0030, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.006 (avg p value 0.498484)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0034, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.006 (avg p value 0.504945)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0031, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.006 (avg p value 0.491559)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0051, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.001 (avg p value 0.493963)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0032, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.009 (avg p value 0.488589)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.005 (avg p value 0.512078)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0029, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.007 (avg p value 0.501894)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.004 (avg p value 0.516721)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0017, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.003 (avg p value 0.493651)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.007 (avg p value 0.497593)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.058 (avg p value 0.467369)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.163 (avg p value 0.298195)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.7221e-05, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.149 (avg p value 0.326572)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9042e-05, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.134 (avg p value 0.348108)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9779e-05, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.116 (avg p value 0.369298)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9282e-06, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.103 (avg p value 0.383766)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9767e-06, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.092 (avg p value 0.398133)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9947e-06, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.078 (avg p value 0.421174)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9823e-07, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.068 (avg p value 0.440773)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9940e-07, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.060 (avg p value 0.455994)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9985e-07, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.052 (avg p value 0.473504)\n"
     ]
    }
   ],
   "source": [
    "# for loop over functions\n",
    "lds_list = []\n",
    "for K in [\n",
    "    10, \n",
    "          100, \n",
    "          # 1000\n",
    "         ]:\n",
    "    ####\n",
    "    ####\n",
    "    dstore_keys_list = []\n",
    "    for split in range(5):\n",
    "        dstore_keys = np.memmap('{}/features-0/ddpm-train-keys-{}-{}-{}-{}-{}.npy'.format(\n",
    "            args.output_dir, split, K, args.Z, 'mean-squared-l2-norm', args.t_strategy), \n",
    "                                dtype=np.float32, \n",
    "                                mode='r',\n",
    "                                shape=(10000, args.Z))\n",
    "        dstore_keys_list.append(dstore_keys) \n",
    "        \n",
    "    dstore_keys = np.vstack(dstore_keys_list)\n",
    "    print(dstore_keys.shape)  \n",
    "    dstore_keys = dstore_keys[:, :args.used_dim]\n",
    "    print(dstore_keys.shape)\n",
    "    ####        \n",
    "    gen_dstore_keys = np.memmap('{}/features-0/ddpm-gen-keys-{}-{}-{}-{}-{}.npy'.format(\n",
    "                args.output_dir, 0, K, args.Z, 'mean-squared-l2-norm', args.t_strategy), \n",
    "                                dtype=np.float32, \n",
    "                                mode='r',\n",
    "                                shape=(1000, args.Z))\n",
    "    print(gen_dstore_keys.shape)    \n",
    "    gen_dstore_keys = gen_dstore_keys[:, :args.used_dim]\n",
    "    print(gen_dstore_keys.shape)\n",
    "    ####\n",
    "    dstore_keys = torch.from_numpy(dstore_keys).cuda()\n",
    "    gen_dstore_keys = torch.from_numpy(gen_dstore_keys).cuda()\n",
    "    # dstore_keys = torch.from_numpy(dstore_keys).cuda() * 1000\n",
    "    # gen_dstore_keys = torch.from_numpy(gen_dstore_keys).cuda() * 1000\n",
    "    ####\n",
    "    kernel = dstore_keys.T@dstore_keys\n",
    "    ####\n",
    "    rs_list = []\n",
    "    ps_list = []\n",
    "\n",
    "    best_scores = None\n",
    "    best_lds = -np.inf\n",
    "    for lamb in lamb_list:\n",
    "        print(lamb)\n",
    "        # kernel_ = kernel + lamb*np.eye(kernel.shape[0])\n",
    "        kernel_ = kernel + lamb*torch.eye(kernel.shape[0]).cuda()\n",
    "        # kernel_ = torch.from_numpy(kernel_).cuda()\n",
    "        ####\n",
    "        kernel_ = torch.linalg.inv(kernel_)  \n",
    "        # kernel_ = kernel_.cpu().numpy()\n",
    "        ####\n",
    "        print(kernel_.shape)\n",
    "        print(torch.mean(kernel_.diagonal()))\n",
    "        ####\n",
    "        # scores = gen_dstore_keys.dot((dstore_keys@kernel_).T)\n",
    "        scores = gen_dstore_keys@((dstore_keys@kernel_).T)\n",
    "        print(scores.size())\n",
    "        scores = scores.cpu().numpy()\n",
    "        \n",
    "        # compute lds\n",
    "\n",
    "        margins = lds_testset_correctness\n",
    "        infl_est_ = -scores\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",
    "           # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "           rs.append(r)\n",
    "           ps.append(p)\n",
    "    \n",
    "        rs, ps = np.array(rs), np.array(ps)\n",
    "        print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "        rs_list.append(rs.mean())   \n",
    "        ps_list.append(ps.mean())\n",
    "\n",
    "        if rs.mean()>best_lds:\n",
    "            best_scores = scores\n",
    "            best_lds = rs.mean()\n",
    "            \n",
    "    with open('./gen_5000_0.5_{}_{}_{}_{}.pkl'.format('mean-squared-l2-norm', K, lamb, best_lds), 'wb') as handle:\n",
    "        pickle.dump(best_scores, handle)\n",
    "            \n",
    "    lds_list.append((rs_list, ps_list))\n",
    "\n",
    "    # break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c3380ec5-8479-45b3-81c8-78d83cb98f3d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "47e17534-05f6-4f8d-a9b8-7ea2c69258fb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "c08ec20a-9e82-4f58-b342-95145208f5b3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[ 3.67675956e-03, -4.25813641e-05,  7.32022325e-04,\n",
       "         4.20757796e-03,  1.82586622e-03,  1.66346708e-03,\n",
       "        -5.65785507e-04, -3.48182413e-03,  1.13512233e-03,\n",
       "         2.30858960e-03, -8.31908802e-03,  3.17286643e-03,\n",
       "         3.50208542e-03,  3.11495169e-03,  1.09648815e-03,\n",
       "         3.53567577e-03,  9.12752827e-02,  1.12110706e-01,\n",
       "         1.08967161e-01,  1.04058827e-01,  9.40096954e-02,\n",
       "         8.50618928e-02,  7.69990030e-02,  6.72275532e-02,\n",
       "         5.99966221e-02,  5.44812399e-02,  4.63280988e-02],\n",
       "       [ 5.03179080e-01,  5.09236315e-01,  4.84084983e-01,\n",
       "         4.88198393e-01,  5.04467378e-01,  5.06814127e-01,\n",
       "         5.02961763e-01,  4.90552517e-01,  4.91682780e-01,\n",
       "         4.99190209e-01,  5.08045781e-01,  5.01412387e-01,\n",
       "         5.06984462e-01,  5.19877329e-01,  4.98218719e-01,\n",
       "         4.92899499e-01,  4.23851604e-01,  3.84825267e-01,\n",
       "         3.85123920e-01,  3.90312215e-01,  4.08118845e-01,\n",
       "         4.19340175e-01,  4.37143608e-01,  4.54311854e-01,\n",
       "         4.66117599e-01,  4.76499905e-01,  4.89027052e-01]])"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "lds_array = np.array(lds_list)\n",
    "lds_array[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "c7d99b73-0b7e-4685-af5e-20038c48751d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(2, 2, 27)"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "lds_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9714982f-8ba0-4545-92cd-54dbf04fc47c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "af3f26cb-2993-45c6-9bfe-dd27b565f8cf",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('./gen_5000_0.5_{}.pkl'.format('mean-squared-l2-norm'), 'wb') as handle:\n",
    "    pickle.dump(lds_array, handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "29f3c665-0577-4b0c-8ded-407a90ae6f2b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "8122043b-7cc0-4d50-a1a5-98e6eed9a4ed",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.11211071, 0.16347542])"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "lds_array[:, 0].max(axis=-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "80995dab-f837-4566-9ea9-ccb5b1c5b0fd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjUAAAGdCAYAAADqsoKGAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABoTklEQVR4nO3dd3hUZd7G8e9MekgjCUkoofcWNEAIorASBawoKiAKIuKq4Cpx3V12VXTLiwURC4qNYkERV1FQWQUFC6GLSpVeUwiQ3mfm/eMkgUAoCVMyk/tzXXPNyZkz5/wyRnLnOU8x2Ww2GyIiIiJuzuzqAkRERETsQaFGREREPIJCjYiIiHgEhRoRERHxCAo1IiIi4hEUakRERMQjKNSIiIiIR1CoEREREY/g7eoCnMVqtXLkyBGCg4MxmUyuLkdEREQugM1mIzc3lyZNmmA2n7stpt6EmiNHjhAbG+vqMkRERKQWDh48SLNmzc55TL0JNcHBwYDxoYSEhLi4GhEREbkQOTk5xMbGVv4eP5d6E2oqbjmFhIQo1IiIiLiZC+k6oo7CIiIi4hEUakRERMQjKNSIiIiIR1CoEREREY+gUCMiIiIeQaFGREREPIJCjYiIiHgEhRoRERHxCAo1IiIi4hEUakRERMQjKNSIiIiIR1CoEREREY+gUCMi4omKc+HHGZB10NWViDiNQo2IiCfa9AEsmwLzh4Ol1NXViDiFQo2IiCfKPmA8Z2yBVS+7thYRJ1GoERHxRPnHTm6vfAaO73FdLSJOolAjIuKJ8o8az94BUFYESyaBzebamkQcTKFGRMQTVYSapCng7Q97VsCvC1xakoijKdSIiHiigvLbT816wYC/GdtLJ1e9LSXiYRRqREQ8jc12sqWmQSQkToTorlB4HL7+h2trE3EghRoREU9Tkm/0owEIjAQvH7j+RcAEv3xg3IoS8UAKNSIinubUTsK+DYztZj2h973G9uKHobTQJaWJOJJCjYiIp8nPNJ4bNAKT6eT+Kx+D4CZwYi+sfNY1tYk4kEKNiIinKagINRFV9/uHwLXTjO1VL0H6FufWJeJgCjUiIp6mspNwozNf63gtdLoerGXw+Z/AanFubSIOpFAjIuJpKm4/BUZW//qQZ8E3GA6vh/WznVeXiIMp1IiIeJrKPjVnCTUhTYxJ+QCWPQXZh51Tl4iDKdSIiHiac91+qtBzHDTrDSW58NVfnFOXiIMp1IiIeJqC87TUAJjNxtw1Zm/YvgS2LXZObSIOpFAjIuJpLqSlBiC6M1z2kLH95aNQlOPYukQcTKFGRMTTnK9PzamueBTCW0NuKiz/p2PrEnEwhRoREU9is51/9NOpfALguhnG9rq34OBah5Um4mgKNSIinqQoG6ylxvaFtNQAtO4PcbcDNlj8EFhKHVaeiCMp1IiIeJKCY8azb5DRCnOhrv43BEZAxlZjtmERN6RQIyLiSSo7CV9gK02FBhEwaKqxveIZOLbbvnWJOIFCjYiIJ7nQkU/V6X4btP4DWIphycNG/xwRN1KrUDNz5kxatmyJv78/CQkJrF179o5lW7ZsYdiwYbRs2RKTycSMGTPOOObJJ5/EZDJVeXTs2LHKMUVFRUyYMIGIiAiCgoIYNmwY6enptSlfRMRz1aST8OlMJrhuOnj7w97v4ZcP7FubiIPVONQsWLCA5ORkpkyZwsaNG4mLi2PQoEFkZGRUe3xBQQGtW7fm6aefJiYm5qzn7dKlC6mpqZWPH3/8scrrkyZNYvHixSxcuJCVK1dy5MgRbr755pqWLyLi2WoynLs64a1hwN+M7f/94+T5RNxAjUPN9OnTGT9+PGPHjqVz587MmjWLwMBAZs+uflG0Xr168dxzzzFixAj8/PzOel5vb29iYmIqH5GRJ/+HzM7O5u2332b69OlceeWVxMfHM2fOHFatWsXq1atr+i2IiHiui7n9VCFxIkR3hcLjRrARcRM1CjUlJSVs2LCBpKSkkycwm0lKSiIlJeWiCtm5cydNmjShdevWjBo1igMHDlS+tmHDBkpLS6tct2PHjjRv3vys1y0uLiYnJ6fKQ0TE413IEgnn4+UD178EmODXD2H3t3YpTcTRahRqMjMzsVgsREdHV9kfHR1NWlparYtISEhg7ty5LF26lNdee429e/dy+eWXk5ubC0BaWhq+vr6EhYVd8HWnTp1KaGho5SM2NrbW9YmIuA17tNQANIuH3vca20smQWnRxZ1PxAnqxOinIUOGcOutt9K9e3cGDRrEl19+SVZWFh999FGtzzl58mSys7MrHwcPHrRjxSIidVR++Tw1gREXf66Bj0NwYzixD1a9fPHnE3GwGoWayMhIvLy8zhh1lJ6efs5OwDUVFhZG+/bt2bVrFwAxMTGUlJSQlZV1wdf18/MjJCSkykNExOPZq6UGwC/YmJQP4IfnIUt/HErdVqNQ4+vrS3x8PMuXL6/cZ7VaWb58OYmJiXYrKi8vj927d9O4cWMA4uPj8fHxqXLdHTt2cODAAbteV0TErVmtJ2cUtkeoAeg6DFpcBmWF8PVj9jmniIN41/QNycnJjBkzhp49e9K7d29mzJhBfn4+Y8eOBWD06NE0bdqUqVONmSlLSkrYunVr5fbhw4fZtGkTQUFBtG3bFoA///nPXH/99bRo0YIjR44wZcoUvLy8GDlyJAChoaGMGzeO5ORkwsPDCQkJ4cEHHyQxMZE+ffrY5YMQEXF7RVlgsxjb9rj9BMbcNUOegdevgK2LYM8KaD3APucWsbMah5rhw4dz9OhRnnjiCdLS0ujRowdLly6t7Dx84MABzOaTDUBHjhzhkksuqfx62rRpTJs2jf79+7NixQoADh06xMiRIzl27BiNGjWiX79+rF69mkaNTv6l8cILL2A2mxk2bBjFxcUMGjSIV199tbbft4iI56m49eQfCt6+9jtvTDfoOQ7WvQlf/RXu+9EYISVSx5hstvoxD3ZOTg6hoaFkZ2erf42IeKZ9P8HcayC8Dfxpo33PXXAcXo435q4ZNBUSH7Dv+UXOoia/v+vE6CcREbEDe3YSPl1gOCRNMbZXTIW86meRF3ElhRoREU9R2xW6L9Qld0LjHlCcA8uedMw1RC6CQo2IiKeoHPnkoFBj9oJrphnbm96Hg+sccx2RWlKoERHxFI68/VQhthfE3W5sf/WoMYxcpI5QqBER8RTOCDUASU+CXwgc+Rl+ftex1xKpAYUaERFPYc8lEs4lOBoG/M3YXv4UFJ5w7PVELpBCjYiIp3BWSw0Yi1026mj04/nu/xx/PZELoFAjIuIpCjKNZ0d1FD6Vl48x0zDAurcgbbPjrylyHgo1IiKewFJmTJAHzmmpAWO5hM43gs0KX/0F6sdcrlKHKdSIiHiCwuOADTBBQLjzrnv1f8A7APb/BJv/67zrilRDoUZExBPkl996CmgIXjVe1q/2wmLh8mRj++vHoDjPedcWOY1CjYiIJ3BmJ+HT9f0ThLWA3FT4YZrzry9STqFGRMQTuDLU+PjD4KeN7VWvQOYu59cggkKNiIhnqFwiwcFz1JxNhyHQNgmspbD0b+o0LC6hUCMi4glc2VIDYDLB4GfA7AO7voHfl7qmDqnXFGpERDxBRUfhQCfMUXM2kW0h8QFje+nfoLTIdbVIvaRQIyLiCSpbalwYagCueBSCG8OJfbDqZdfWIvWOQo2IiCeoaKlx1e2nCn7BcNW/jO0fnoesg66tR+oVhRoREU/gzCUSzqfbLdC8L5QVGnPXiDiJQo2IiCdwdUfhU5lMcM2zYDLD1kWwZ6WrK5J6QqFGRMTdlZVAUbax7cqOwqeK6QY9xxnbX/0FLKWurUfqBYUaERF3VzFHjclsLJNQV/zh78Y6VEe3w9o3XV2N1AMKNSIi7q7i1lNgJJjr0D/rgeEw8Alje8VUyDvq2nrE49Whn34REamVutRJ+HSXjobGcVCcAyka4i2OpVAjIuLu8utwqDF7wYDJxva62VCY5dJyxLMp1IiIuLu6NPKpOu0GQVRnKMmFdepbI46jUCMi4u7qwhIJ52I2Q79Jxvbq16CkwLX1iMdSqBERcXd1vaUGoMvNENbCGKm18R1XVyMeSqFGRMTdVQzpbhDh2jrOxcsbLnvI2F71sjG3joidKdSIiLg7d2ipAegxCoKiIecQ/LbQ1dWIB1KoERFxd+4Sanz8oc8DxvaPL4DV4tp6xOMo1IiIuLv88ttPdbWj8Kl63g3+oXBsJ2xf4upqxMMo1IiIuLPSQmOoNNTNeWpO5x8Cve81tn+YDjaba+sRj6JQIyLiziqGc5t9jBYQd5BwH3gHQOom2POdq6sRD6JQIyLizk5dIsFkcm0tF6pBJMSPMbZ/mO7aWsSjKNSIiLizurxEwrn0fRDM3rDvBzi4ztXViIdQqBERcWd1fTbhswltBt1HGNs/qrVG7EOhRkTEnbnLcO7q9HsYMMGOLyF9q6urEQ9Qq1Azc+ZMWrZsib+/PwkJCaxdu/asx27ZsoVhw4bRsmVLTCYTM2bMOOOYqVOn0qtXL4KDg4mKimLo0KHs2LGjyjEDBgzAZDJVedx33321KV9ExHO4c6iJbAedbzC2f3zBtbWIR6hxqFmwYAHJyclMmTKFjRs3EhcXx6BBg8jIyKj2+IKCAlq3bs3TTz9NTExMtcesXLmSCRMmsHr1ar755htKS0u5+uqryc/Pr3Lc+PHjSU1NrXw8++yzNS1fRMSzuMMSCefSL9l43vxfOLHPpaWI+6txqJk+fTrjx49n7NixdO7cmVmzZhEYGMjs2bOrPb5Xr14899xzjBgxAj8/v2qPWbp0KXfddRddunQhLi6OuXPncuDAATZs2FDluMDAQGJiYiofISEhNS1fRMSzuHNLDUCTHtDmSrBZ4KeXXF2NuLkahZqSkhI2bNhAUlLSyROYzSQlJZGSkmK3orKzswEIDw+vsv/9998nMjKSrl27MnnyZAoKzr58fXFxMTk5OVUeIiIex107Cp+qorXm5/cgN921tYhbq1GoyczMxGKxEB0dXWV/dHQ0aWlpdinIarXy8MMPc9lll9G1a9fK/bfffjvvvfce3333HZMnT+bdd9/ljjvuOOt5pk6dSmhoaOUjNjbWLvWJiNQplUO63bSlBqBlP2jWGyzFsHqmq6sRN+bt6gJON2HCBDZv3syPP/5YZf+9995bud2tWzcaN27MwIED2b17N23atDnjPJMnTyY5Obny65ycHAUbEfE8lbef3LilxmSCy5PhgxGwbrbRchMQ5uqqxA3VqKUmMjISLy8v0tOrNg+mp6eftRNwTUycOJElS5bw3Xff0axZs3Mem5CQAMCuXbuqfd3Pz4+QkJAqDxERj1KSD2WFxrY7hxqAdoMgqrOxjtW6N11djbipGoUaX19f4uPjWb58eeU+q9XK8uXLSUxMrHURNpuNiRMn8umnn/Ltt9/SqlWr875n06ZNADRu3LjW1xURcWsVrTTe/uAb5NpaLpbZDP0mGdurX4OSs/eZFDmbGo9+Sk5O5s0332TevHls27aN+++/n/z8fMaOHQvA6NGjmTx5cuXxJSUlbNq0iU2bNlFSUsLhw4fZtGlTlRaWCRMm8N577zF//nyCg4NJS0sjLS2NwkLjL5Ddu3fzr3/9iw0bNrBv3z4+//xzRo8ezRVXXEH37t0v9jMQEXFPp/ancZd1n86ly80Q1sIYpr7xHVdXI26oxn1qhg8fztGjR3niiSdIS0ujR48eLF26tLLz8IEDBzCbT2alI0eOcMkll1R+PW3aNKZNm0b//v1ZsWIFAK+99hpgTLB3qjlz5nDXXXfh6+vLsmXLmDFjBvn5+cTGxjJs2DAee+yxmpYvIuI5Kkc+uekcNafz8obLHoIvkmHVy9DzbvD2dXVV4kZMNpvN5uoinCEnJ4fQ0FCys7PVv0ZEPMPGd+HzidD2KrjjY1dXYx+lRfBid8hLhxtfhUtGuboicbGa/P7W2k8iIu6qwE1X6D4XH39InGBs//gCWC2urUfcikKNiIi7yvfAUAPGbSf/UDi2E7YvcXU14kYUakRE3JW7L5FwNn7B0Lt8brIfpkP96CUhdqBQIyLirjxhiYSzSbgPvAMgdRPs+c7V1YibUKgREXFXntpSA8Yttfi7jO0fpru0FHEfCjUiIu6qsk+NhwzpPl3fiWD2gX0/wMF1rq5G3IBCjYiIO7LZThn95IEtNQChzaD7cGP7R7XWyPkp1IiIuKPiHLCUGNue2KemQr+HARPs+BLSt7q6GqnjFGpERNxRxa0nnwbgG+jaWhwpsh10vsHY/mmGS0uRuk+hRkTEHXnqHDXV6ZdsPP/2MZzY59JSpG5TqBERcUeePPLpdE16QJsrwWaB76a6uhqpwxRqRETckScukXAuA/4OmODXD2HrZ66uRuoohRoREXdU2VJTT0JNbC/oN8nYXvwQ5BxxbT1SJynUiIi4o/xjxrMnj3w63YDJ0LgHFJ6ARfeD1erqiqSOUagREXFH9alPTQVvXxj2FvgEwp4VsOY1V1ckdYxCjYiIO6qPoQaMId6D/mNsL3sS0ja7tBypWxRqRETcUUH57adzLJFQXGbB5okrXMePhfZDjMkHPxkPpUWurkjqCIUaERF3dJ6Wmu+2Z9Dp8aUMfH4lLy7byb7MfCcW52AmE9zwsvG9Z2yF5U+5uiKpIxRqRETcjdV6yuR71YeaF5fvxGqDPZn5vLDsdwZMW8GNM39izk97OZpb7MRiHSSoEdz4qrG9+lXYtdy19UidoFAjIuJuirKMiegAAs+8/fTLwSw2HczC18vMf27qyhXtG2E2GfufWryVhP9bxp1vr+G/Gw6RV1zm3Nrtqf3V0Gu8sb3ogZMjwqTe8nZ1ASIiUkMVrTR+oeDtd8bL81btA+C67o0ZldCCUQktOJpbzBe/HmHRpiNsOpjFDzsz+WFnJv9Y9BtJnaIZ2qMpV7RvhK+3m/2te9U/Ye9KyPwdljwEt71r3J6SekmhRkTE3VTOJnxmK01mXjFLfk0FYEzflpX7GwX7cddlrbjrslbsy8zns01H+GzTYfZk5rPk11SW/JpKWKAP13RrzNAeTenZoiFmsxuEA99AY5j3mwNh22L4+T249E5XVyUuolAjIuJuztFJ+IM1ByixWOkRG0ZcbFi1b28Z2YCHktrxp4Ft2Xw4h0WbDrP4lyNk5BYzf80B5q85QNOwAK6Pa8LQS5rQMSbEgd+MHTSOgysfg2VT4Ku/Qou+ENHG1VWJC7hZO6OIiJwt1JRarLy3Zj8Ad53SSnM2JpOJbs1Cefy6zqRMHsh74xK4Nb4ZwX7eHM4qZNbK3Qye8QNDZ/7Emj11vL9K3weh5eVQmg+f3AuWUldXJC6gUCMi4m4ql0ioevvpf1vSSM8pJjLIlyHdYmp0Si+ziX7tInnu1jjWPZbEq6Mu5erO0fh6mdl0MIvhb6xm/Dvr2X00z17fhX2ZvWDoa0Y/o8Pr4ftprq5IXEChRkTE3Zylpaaig/DtvZvj5+1V69P7+3hxTbfGvDG6Jz/97Uru6NMcL7OJb7amc/UL3/PEZ5s5llcHh4WHxcJ1043t75+Fg2tdW484nUKNiIi7qWaF7i1Hslm37wTeZhOj+rSw26UaBfvx76Hd+N/Dl5PUKQqL1cY7Kfvp/9wKZn63i6JSi92uZRfdboHuw8FmNWYbLs51dUXiRAo1IiLupnKJhJMtNRWtNIO7xhAd4m/3S7aNCuatMb34YHwfujUNJa+4jOf+t4Mrp63gvxsOYbXWoeUYrnkOQpvDiX1Gx2GpNxRqRETczWktNSfyS/hs0xHgwjoIX4zENhF8NuEyZgzvQdOwAI5kF/HIwl+4/pUfWbUr06HXvmD+oXDz62Ayw6b3YcsiV1ckTqJQIyLibiom3ws0Qs2H6w5SXGalS5MQ4ls0dPjlzWYTQy9pyvJH+vPXwR0J9vNmy5Ecbn9rDXfPXcfO9Dpwy6dFX+g3ydhe/BDkHHFtPeIUCjUiIu7Eaqly+6nMYuW91cYw7jF9W2Jy4my6/j5e3D+gDSseHcBdfVvibTbx7fYMBs34nsmf/EZGrotXzx4wGZpcYiwr8el9xppZ4tEUakRE3EnBcaC8/0pgBMu2ZXA4q5CGgT7cENfEJSVFBPnx5A1d+HrSFQzqEo3VBh+sPcCA51bw4rKdFJS4aH0pLx+4+S3wCTSWUlj9qmvqEKdRqBERcScVSyQENAQv78oOwiN6N8ffp/bDuO2hdaMgXr+zJwvvSyQuNoyCEouxQvhzK/ho/UFsNhd0Jo5sC4P+Y2wvfwrSNju/BnEahRoREXdyyhw1v6fnkrLnGGYT3GHHYdwXq1fLcBY90JeXR15CbHgAGbnF/OXjX5mxbKdrCoofCx2uAUuJMcy71MW3xcRhFGpERNzJKZ2EK1ppru4cQ9OwANfVVA2TycT1cU1YltyfSUntAXhx+U4WrDvgimLghpehQRRkbIVlTzq/BnEKhRoREXdSHmpK/SP4ZONhoOpq3HWNn7cXDyW148Er2wLw9083892ODOcX0iAShpb3qVnzGmz9zPk1iMMp1IiIuJPy20878/0pLLXQITqYPq3DXVzU+SVf1Z6bL22KxWpjwvsb+e1QtvOLaHeVsfAlwKIHIGO782sQh6pVqJk5cyYtW7bE39+fhIQE1q49+/oaW7ZsYdiwYbRsaQw1nDFjRq3OWVRUxIQJE4iIiCAoKIhhw4aRnp5em/JFRNxXeUfhtRnGP9/OHsZdWyaTiadv7s7l7SIpKLEwdu46Dh4vcH4hA580VvMuyYMFo6DIBeFKHKbGoWbBggUkJyczZcoUNm7cSFxcHIMGDSIjo/rmxIKCAlq3bs3TTz9NTEz1q8ZeyDknTZrE4sWLWbhwIStXruTIkSPcfPPNNS1fRMS9lbfU7C4IIMTfm6GXuGYYd234ept5ddSldGocQmZeMWPmrOVEfolzi/DyhlvnQkgzOLbLaLHR/DUeo8ahZvr06YwfP56xY8fSuXNnZs2aRWBgILNnz672+F69evHcc88xYsQI/Pz8anXO7Oxs3n77baZPn86VV15JfHw8c+bMYdWqVaxevbqm34KIiPsq71NzzBbC8F6xBPp6u7igmgn292HOXb1oEurPnqP53PPOeucvitkgEoa/A16+sH0J/PSCc68vDlOjUFNSUsKGDRtISko6eQKzmaSkJFJSUmpVwIWcc8OGDZSWllY5pmPHjjRv3rzW1xURcUclOUYL9nFCuLNPS9cWU0sxof7Mvbs3wf7ebNh/goc/3ITF2QtiNo2Ha6YZ28v/BbuWO/f64hA1CjWZmZlYLBaio6Or7I+OjiYtLa1WBVzIOdPS0vD19SUsLOyCr1tcXExOTk6Vh4iIu7PkGqGmXatWNI8IdHE1tdc+Opg37uyJr5eZpVvS+PcXW51fRPwYuHQMYIP/jjNW9Ra35rGjn6ZOnUpoaGjlIzY21tUliYhclLyCQgIsxmKR1/bp6uJqLl5imwim3RYHwJyf9vHWD3ucX8Q1zxmtNoUnYMEdUFro/BrEbmoUaiIjI/Hy8jpj1FF6evpZOwHb45wxMTGUlJSQlZV1wdedPHky2dnZlY+DBw/Wqj4RkbriyzXGFP8WzCR0buviauzjhrgm/P2ajgD8+4ttLPnVyatpe/vBbe8YK56n/QZLJoErlnMQu6hRqPH19SU+Pp7ly0/ee7RarSxfvpzExMRaFXAh54yPj8fHx6fKMTt27ODAgQNnva6fnx8hISFVHiIi7spqtfH1OiPUlPiGYfJyrw7C5zL+8tbcVT6BYPKCX1iz55hzCwhtBrfOAZMZfvkA1r3l3OuL3dT49lNycjJvvvkm8+bNY9u2bdx///3k5+czduxYAEaPHs3kyZMrjy8pKWHTpk1s2rSJkpISDh8+zKZNm9i1a9cFnzM0NJRx48aRnJzMd999x4YNGxg7diyJiYn06dPnYj8DEZE678ddmRRmGS3aviFRLq7GvkwmE49f15lBXaIpsVgZ/856dqbnOreIVlfAVf80tpf+DQ6sce71xS5qHPWHDx/O0aNHeeKJJ0hLS6NHjx4sXbq0sqPvgQMHMJtPZqUjR45wySWXVH49bdo0pk2bRv/+/VmxYsUFnRPghRdewGw2M2zYMIqLixk0aBCvvqpl5EWkfpi3ah8RGAMevIIaubga+/Mym3hxxCXc/uZqNh7I4q456/jkgb5Eh/g7r4jEiXB4A2z5FD4aDX/8HoKjz/8+qTNMNpesBe98OTk5hIaGkp2drVtRIuJWDhwroP+07xhr/oonfN6FLjcZE8h5oOP5Jdzy2ir2ZObTuXEIH92XSJCfE2+1FefBWwPh6HZonghjFoOXj/OuL2eoye9vjx39JCLiKd5dvQ+bDXpElBk7GnheS02F8Aa+zB3bm8ggX7am5nD/exsotThxxl+/IBj+PviFwIEU+Pox511bLppCjYhIHVZQUsaCdcbozZ6Rnh9qAJpHBPL2mF4E+Hjxw85MJn/yG069qRDZFm563dheMwt+WeC8a8tFUagREanDFv18hJyiMlpEBNLYJ9/YGRjh2qKcIC42jJmjLsFsgo83HOKFZTudW0DHa+CKR43txQ8Zw72lzlOoERGpo2w2G/NW7QPgzj4tMJWv++TpLTUVruwYzb+HdgPgpeU7+XDtAecWMGAytE2CskL4cBQUHHfu9aXGFGpEROqo1XuOsyM9lwAfL27tGVu5Qnd9CTUAtyc058ErjYkG/7FoM8u3pZ/nHXZk9oKb34SwFpC1Hz4ZD1YnL74pNaJQIyJSR1W00tx8aVNCA3ygoHxSugaRrivKBZKvas/NlzbFYrVx//sbWfn7UeddPDAchr8H3v6waxmseNp515YaU6gREamDDmcV8vVWY8HeMX1bQlkxFJcvzFvPQo3JZOKZYd2NyfnKjMn5vndmsGncHa5/ydj+/lnY/qXzri01olAjIlIHvbd6P1Yb9G0TQfvoYKjoT2P2Bv8wl9bmCj5eZl4eeSlXdT4ZbH7cmem8AuKGQ+8/Gtuf/hGO7XbeteWCKdSIiNQxRaWWyk6xY8rXRKrsTxMYCSaTawpzMV9vMzNvv5SkTlEUl1kZN28dq3Y5Mdhc/W+I7WO0mH04ypioT+oUhRoRkTrm81+OcKKglKZhASR1Kp+mv56NfDobX28zM0ddypUdjWBz97x1pOx20gKY3r5w2zwIioaj2+C7/zjnunLBFGpEROqYTzYeAuDOxBZ4mctbZQoqQo3nz1FzPn7eXrx2x6X8oUMjikqt3D13HaudtbJ3cAwMLV93cM0sY60oqTMUakRE6piDxwsB6NP6lABTD4dzn4sRbOLp374RhaUWxs5Zx9q9TppHpm0SdLsNbFb4/CGwlDrnunJeCjUiInWI1WojI7cIgOgQv5MvKNScwd/Hi9fvjOfydpEUllq4a85a1u1zUrAZ9H8Q0BDSf4PVrzrnmnJeCjUiInXIiYISSi02TCaIDDo11JTfXqkHSyTUhL+PF2+O7km/tpEUlFi4a/ZaNux3QrAJamR0HAb4bioc3+v4a8p5KdSIiNQh6TnFAEQ08MXH65R/otVSc1YVweaythHkl1gYM3sdGw+ccPyFe4yClpcbyyh8kQzOXHRTqqVQIyJSh6SX33qKCvav+kJlR+H6NfHehQrw9eKt0b1IbB1BXnEZY95ey8+ODjYmE1w3A7z8YPe38NtCx15PzkuhRkSkDsnIqaY/Dail5gIE+Hrx9l09SWgVTm5xGaPfXssvB7Mce9HIttC/fDXvpX/TopcuplAjIlKHVNx+ig45raUmXy01FyLQ15s5Y3vRuzzY3PH2Gn49lOXYi/Z9CBp1Mtbm+vpxx15LzkmhRkSkDqkY+RR1aqgpyYfSAmM7UKHmfAJ9vZlzVy96tWxIblEZd7y1hs2Hsx13QW9fuOElwASb3oM9Kx13LTknhRoRkTrkZEvNqSOfyltpvPzAL9gFVbmfBn7ezBnbm/gWDckpKmOUo4NNbG/oNc7YXvIwlBY67lpyVgo1IiJ1SEWfmiodhU+99VRP132qjSA/b+aO7cWlzcPILizljrfXsPVIjuMuOPAJCG4Mx/fA99Mcdx05K4UaEZE6pNqWGo18qrVgfx/m3d2bHrFhZBWUMuqt1WxLdVCw8Q+Fa54ztn+aAelbHXMdOSuFGhGROsJitXE0r5qOwhr5dFGC/X14Z1xv4mLDOFFQysg3VztuuHen66HjdWAtg8V/AqvVMdeRainUiIjUEcfyi7FYbZhNxuR7lSpuP6mTcK2F+Pvwzt1GsMkqKOX2N9ewYkeGYy425FnwDYZD62D92465hlRLoUZEpI7IKL/1FBnkh3e1swkr1FyM0AAf5t+TwBXli2DeM289i34+7IALNTX61wAsewpyjtj/GlIthRoRkToivXLivbPNUaPbTxergZ83b43uyY09mlBmtfHwgk289cMe+1+o1zho2hNKcuHLR+1/fqmWQo2ISB2RkVtNJ2FQR2E78/U288JtPbj7slYA/PuLbUz9ahs2e67dZPaC618EszdsXwLbFtvv3HJWCjUiInVERUtN1BktNeoobG9ms4nHr+vEXwZ3AOD1lXt49ONfKbPYsWNvTFfo+ydj+8tHociBw8kFUKgREakzKoZzRwWfvu7TMeNZHYXtymQy8cCAtjw7rDtmE3y84RB/fHcDhSUW+12k/1+gYSvITYXl/7TfeaVaCjUiInVERnV9amw2dRR2sNt6xfL6nT3x8zazfHsGd769hqyCEvuc3CcArp9hbK97Cw6utc95pVoKNSIidUR6bjUrdBfngsVowVGocZyrOkfz3j0JhPh7s37/CW57PYXUbDstddB6AMTdDthg8UNgKbXPeeUMCjUiInXEydtPp7TUVHQS9gkE3wYuqKr+6NUynI/uSyQ6xI/f0/O45bUUdmXk2efkV/8bAiMgYyusesk+55QzKNSIiNQBZRYrmdXOJqyRT87UMSaE/97fl9aNGnA4q5BbZ62yz+zDDSJg0FRje8UzcGz3xZ9TzqBQIyJSB2TmlWCzgZfZdNpswuX9adRJ2GmaNQzk4/v6EtcslBP2nH24+23Q+g/G7cQlDxv9pcSuFGpEROqAjNyK1bn9MJtPWYlbE++5RHgDX+aP78Pl7SLtN/uwyQTXvQDeAbD3e/jlA/sUK5UUakRE6oDK/jSao6bOaODnzdtjenFDnB1nHw5vBQP+amz/7+8nQ6vYhUKNiEgdUDnx3ulz1BSUz1HTIMLJFQkYsw/PGN6DsZe1BIzZh5/+avvFzT6cOBGiu0LhCVj0AFjK7FOsKNSIiNQFJ+eoOX3iPbXUuJrZbOKJ6zpXzj48a+Xui5t92MsHbnwFvP1h5//g8wfBaseZjOuxWoWamTNn0rJlS/z9/UlISGDt2nNPJrRw4UI6duyIv78/3bp148svv6zyuslkqvbx3HPPVR7TsmXLM15/+umna1O+iEidU3H7KTpYt5/qoupmH/77p7/VvsWmySVw61wwecEv82HZE3att76qcahZsGABycnJTJkyhY0bNxIXF8egQYPIyKi+Z/iqVasYOXIk48aN4+eff2bo0KEMHTqUzZs3Vx6Tmppa5TF79mxMJhPDhg2rcq5//vOfVY578MEHa1q+iEiddHLivdNDjZZIqEtu6xXLzNsvxWyCj9YfYtrXO2p/sg5DjBYbgFUvw48z7FJjfVbjUDN9+nTGjx/P2LFj6dy5M7NmzSIwMJDZs2dXe/yLL77I4MGDefTRR+nUqRP/+te/uPTSS3nllVcqj4mJiany+Oyzz/jDH/5A69atq5wrODi4ynENGmgiKhHxDCc7Cp/t9pNCTV0xpFtj/nNTNwBmfrebOT/trf3JetxuTMwHsGwKbHzXDhXWXzUKNSUlJWzYsIGkpKSTJzCbSUpKIiUlpdr3pKSkVDkeYNCgQWc9Pj09nS+++IJx48ad8drTTz9NREQEl1xyCc899xxlZepcJSKe4azrPhVo8r26aGTv5jxyVXsA/rlkK5//cqT2J+v7IFz2sLG9+E+wbcnFF1hPedfk4MzMTCwWC9HR0VX2R0dHs3379mrfk5aWVu3xaWlp1R4/b948goODufnmm6vs/9Of/sSll15KeHg4q1atYvLkyaSmpjJ9+vRqz1NcXExxcXHl1zk5WvJdROqmUouVY/nGAopVQk1RFljL/3jT7ac6Z+KVbcnMK2Zeyn4e+WgTDQN9uLxdLfs+JT1pBNif34OP74Y7/gutLrdrvfVBnRv9NHv2bEaNGoW/f9X7ysnJyQwYMIDu3btz33338fzzz/Pyyy9XCS6nmjp1KqGhoZWP2NhYZ5QvIlJjR3ONf8d8vEw0DPQ5+ULFHCZ+IeDjX807xZVMJhNPXN+Fa7s3ptRi4753N/DroazangyuexE6XmfMOPzBSEj9xa711gc1CjWRkZF4eXmRnp5eZX96ejoxMTHVvicmJuaCj//hhx/YsWMH99xzz3lrSUhIoKysjH379lX7+uTJk8nOzq58HDx48LznFBFxhZNz1PhjMlUzm3Cg5qipq7zMJqbfFsdlbSPIL7Ewds469mbm1/Jk3jDsbWjRD0py4b1hWiOqhmoUanx9fYmPj2f58uWV+6xWK8uXLycxMbHa9yQmJlY5HuCbb76p9vi3336b+Ph44uLizlvLpk2bMJvNREVFVfu6n58fISEhVR4iInXR+TsJazh3Xebn7cWsO+Lp2jSEY/kl3Pn2mso+UjXm4w8j50NMN+O//7tDISfVrvV6shrffkpOTubNN99k3rx5bNu2jfvvv5/8/HzGjh0LwOjRo5k8eXLl8Q899BBLly7l+eefZ/v27Tz55JOsX7+eiRMnVjlvTk4OCxcurLaVJiUlhRkzZvDLL7+wZ88e3n//fSZNmsQdd9xBw4YNa/otiIjUKRXrPmmOGvcV7O/DnLt60yIikEMnChk9ey05RaW1O5l/KNzxCYS3hqwD8N7NxuzDcl41DjXDhw9n2rRpPPHEE/To0YNNmzaxdOnSys7ABw4cIDX1ZKrs27cv8+fP54033iAuLo6PP/6YRYsW0bVr1yrn/fDDD7HZbIwcOfKMa/r5+fHhhx/Sv39/unTpwn/+8x8mTZrEG2+8UdPyRUTqnPSzzSasJRLcSqNgP969O4HIID+2p+Uyft56ikottTtZUBTc+SkExUDGVpg/AkoK7FuwBzLZLmoBC/eRk5NDaGgo2dnZuhUlInXKnxf+wscbDvHooA5M+EPbky98+SisfQMufwQGasZZd7HlSDbDX19NXnEZg7vEMHPUpXiduvJ6TaRvgTlDoCgb2g2CEe8byyzUIzX5/V3nRj+JiNQ36dXNUQOndBTWcG530qVJKG+MjsfXy8zSLWk8/tnm2i+nEN0Fbv/o5DpRn03UOlHnoFAjIuJiFUO6tZil5+jbJpIXR/TAZIL5aw4wY9nO2p+seR+47R1jnahfP4SvHzMmZpQzKNSIiLjYqUO6q8jXbMLubEi3xvzrRqP/6IvLd/Lu6v21P1n7QTD0VWN79Uz4sfqJZ+s7hRoRERcqLrNwosAYJXNmR2GFGnd3R58WPDSwHQBPfLaZL3+7iOHZcSNg0P8Z28v/CRvmXnyBHkahRkTEhTLK56jx9TYTGnBKB1Cr5ZTRT7r95M4eTmrHqITm2Gzw8IebWLU7s/YnS5wA/ZKN7SWTYOvn9inSQyjUiIi4UOUcNSF+VWcTLjwBtvIOoZpR2K2ZTCb+eWNXBneJocRi5d53NrD5cHbtTzjwCbh0jPHz8d9xsPd7+xXr5hRqRERcqGI24TMn3iv/a94/rN4N4fVEXmYTM0b0oE/rcPKKy7hrzjoOHKvlvDMmE1z3AnS6HiwlMH84/P61fQt2Uwo1IiIudPbh3Br55Gn8fbx4Y3RPOjUOITOvmDtnr6kc+VZjZi+4+S1oMxBKC+CDEbDxHfsW7IYUakREXOis6z6pk7BHCvH3Yd7YXsSGB7D/WAG3zFrF7+m5tTuZjz/cvgDibgebBT5/EL77v3o93FuhRkTEhSr61Gg4d/0RFeLPu3cnVAabm2b+xDdb02t3Mi8fY6j3FY8aX698xpigz1LLdafcnEKNiIgLVYx+0sR79UvLyAZ8NqEfia0jyC+xcO+763nl2521m3nYZIIrH4PrZoDJDJveM/rZFNeyBciNKdSIiLiQlkiov8Ib+PLOuN6MSWyBzQbTvv6difN/pqCkrHYn7DkWRnwAPoGweznMuQZy0+xbdB2nUCMi4kJnXaFbLTX1go+Xmadu7MrUm7vh42Xii99SueW1FA6dqOXIqA6DYcwSIwyn/QpvXQVHf7dv0XWYQo2IiIsUlljIKTL+Ko86W0tNA81RUx+M7N2c+eP7EBnky9bUHG585SfW7DlWu5M1i4d7voHw1pB9AN6+Cvan2LfgOkqhRkTERSo6CQf4eBHs5131xcrRT2qpqS96tQzns4n96No0hGP5JYx6aw3v1Xa9qPDWMO4baNoTirLgnRth62d2rbcuUqgREXGR9FM6CVeZTRh0+6meahoWwMI/9uX6uCaUWW08tmgz//j0N0rKrDU/WYNIGLMYOlwDlmL4aAysnmX/ousQhRoRERepXJ379FtPljJjmQRQR+F6KMDXi5dG9OAvgztgMsH7aw5wx9trOJZXi4n6fAPhtneh5zjABkv/Cv/7B1hrEZLcgEKNiIiLZJTPJhsVfPrEexV9KUwQGO7coqROMJlMPDCgLW+N7kmQnzdr9x7nhld+YsuRWqwZ5eUN1z4PA6cYX6e8YqwZVVbL2YzrMIUaEREXyTjfEgmBEcZ0+FJvDewUzaIJfWkZEcjhrEJueS2FL35NrfmJTCa4PBluegPMPrDlE3j35pMtgh5CoUZExEXOOpxbSyTIKdpGBfPZhH5c3i6SwlILE+Zv5Pmvd2C11mKivrjhcMfH4BsM+3+E2YMh66D9i3YRhRoRERc52VH4bMO51UlYDKGBPsy5qxfjL28FwMvf7uLedzeQW1SL5RBaD4C7v4LgxnB0uzHkO+03+xbsIgo1IiIukn6+dZ8CNUeNnOTtZeYf13bm+Vvj8PU2s2xbOje/uor9x/JrfrKYbnDPMmjUCXJTYfYQ2LPS/kU7mUKNiIiLaN0nqY1h8c346I+JRAX7sTMjj2tf+pG5P+3FUtPbUaHN4O6l0KIflOTC+7e4/Vw2CjUiIi6QV1xGXvHZZhNWqJFz6xEbxuIH+9GzRUPyist4cvFWbnr1JzYfruHoqIAwuOO/0Ol6sJTAwrtgw1wHVOwcCjUiIi5QMfKpga8XQWfMJlw+pFtLJMg5RIf4s+CPifxraFeC/b359VA2N7zyI/9cvLUyMF8QH3+4dR5cOgZsVlj8EHw/DWqzYriLKdSIiLhAxRw1Z3QSBsjLMJ418Z6ch5fZxJ19WrD8kf5cH9cEqw1m/7SXq6avZOnmNGwXGkzMXnD9i3D5I8bX3/4Llk52u0n6FGpERFzg5GzCp/Wnsdng2C5ju2FL5xYlbisq2J+XR17CvLt70zw8kNTsIu57bwPj31nP4azCCzuJyQQDn4BBU42v17wGi+4DSy1GWLmIQo2IiAtknG04d14GFB4HTNCog/MLE7fWv30jvp50BRP+0AYfLxPLtmVw1fSVvPn9HsosF9jqkvhA+SR93vDrAvhgJJTUYoSVCyjUiIi4QPrZZhPO2Go8h7cGnwAnVyWewN/Hi0cHdeTLP11Or5YNKSix8J8vt3H9Kz/x84ELnEE4bjiM+AC8A2DXN/DOUCg47tC67UGhRkTEBdLPtu5TxjbjOaqTkysST9MuOpgF9ybyzLBuhAX6sC01h5tfW8XjizaTcyGT9rW/GkYvAv9QOLQW5lwDOUccXvfFUKgREXGB87bURHdxckXiicxmE8N7NWd5cn9uvrQpNhu8u3o/A59fyeJfjpy/I3HzPjB2afnsw9vg7UGQucs5xdeCQo2IiAucdTFLtdSIA0QE+TH9th7MvyeB1pENOJpbzIMf/MyYOes4cKzg3G+O7gx3/w/C20D2AZh9NRz52TmF15BCjYiIk9lstsp1n6rcfrJajbV4AKI6u6Ay8XR920by1cOX83BSO3y9zHz/+1GuemElM7/bde6OxA1bGMGmcZwxj9Lc6+rksgoKNSIiTpZXXEZhqQU4bUh39gEoyQMvX6OjsIgD+Hl78XBSe5Y+fDl920RQXGbluf/t4IH3N1JU/nNZraBGMGYJtLzc+Dmtg8sqKNSIiDhZRStNsL83gb6nzCZccespsj14+bigMqlPWjcK4v17Enjulu74epn5ems6d81Ze+6Vv/1DYNTHVZdVWD/HaTWfj0KNiIiTnb0/TXknYfWnEScxmUzc2jOWuXf3IsjPm9V7jjPyzdVk5hWf/U2nL6uw5GH4/rk6sayCQo2IiJOl51aEGg3nlrqhb5tIPhjfh4gGvmw+nMOts1I4ePwcHYjPWFbh33ViWQWFGhERJ6u4/RQdfLaRT+okLM7XrVkoC+9LpGlYAHsz87ll1ip+T889+xuqW1bh0z+6dFmFWoWamTNn0rJlS/z9/UlISGDt2rXnPH7hwoV07NgRf39/unXrxpdfflnl9bvuuguTyVTlMXjw4CrHHD9+nFGjRhESEkJYWBjjxo0jLy+vNuWLiLjUyXWfTgk1llLI/N3YVkuNuEjrRkH89/6+tIsKIj2nmFtnpbBh/3lmIT51WQUAk5fjCz2LGoeaBQsWkJyczJQpU9i4cSNxcXEMGjSIjIyMao9ftWoVI0eOZNy4cfz8888MHTqUoUOHsnnz5irHDR48mNTU1MrHBx98UOX1UaNGsWXLFr755huWLFnC999/z7333lvT8kVEXC6juuHcx/cYHS99GkBocxdVJgIxof4svC+RS5qHkV1Yyh1vrWHFjup/x1eKGw5jv4Khr4LZdTeBanzl6dOnM378eMaOHUvnzp2ZNWsWgYGBzJ49u9rjX3zxRQYPHsyjjz5Kp06d+Ne//sWll17KK6+8UuU4Pz8/YmJiKh8NGzasfG3btm0sXbqUt956i4SEBPr168fLL7/Mhx9+yJEjdXvKZhGR01U7m3BlJ+GOLv2lIAIQFujL+/ckcEX7RhSWWrhn3no+23T43G+K7e3yUXs1+j+npKSEDRs2kJSUdPIEZjNJSUmkpKRU+56UlJQqxwMMGjTojONXrFhBVFQUHTp04P777+fYsWNVzhEWFkbPnj0r9yUlJWE2m1mzZk211y0uLiYnJ6fKQ0SkLsjIrVih+5SWGnUSljom0Nebt0b35Pq4JpRZbTy8YBPvpOxzdVnnVKNQk5mZicViITo6usr+6Oho0tLSqn1PWlraeY8fPHgw77zzDsuXL+eZZ55h5cqVDBkyBIvFUnmOqKioKufw9vYmPDz8rNedOnUqoaGhlY/Y2NiafKsiIg5hzCZ8rpYadRKWusPX28yLw3swOrEFNhs88dkWXvjm9/OvGeUi3uc/xPFGjBhRud2tWze6d+9OmzZtWLFiBQMHDqzVOSdPnkxycnLl1zk5OQo2IuJyOYVlFJcZw14bBVfXUqNQI3WL2WziqRu6EN7AlxnLdvLi8p2cKCjhyeu7YDabXF1eFTVqqYmMjMTLy4v09PQq+9PT04mJian2PTExMTU6HqB169ZERkaya9euynOc3hG5rKyM48ePn/U8fn5+hISEVHmIiLhaxRw1YYE++PuUjxIpLTQ6CoNCjdRJJpOJh5Pa888bu2AywTsp+3lowSZKylw7L83pahRqfH19iY+PZ/ny5ZX7rFYry5cvJzExsdr3JCYmVjke4Jtvvjnr8QCHDh3i2LFjNG7cuPIcWVlZbNiwofKYb7/9FqvVSkJCQk2+BRERl6q89XTqHDWZvxszswaEQ1DUWd4p4nqjE1syY3gPvM0mFv9yhHveWU9BSZmry6pU4y72ycnJvPnmm8ybN49t27Zx//33k5+fz9ixYwEYPXo0kydPrjz+oYceYunSpTz//PNs376dJ598kvXr1zNx4kQA8vLyePTRR1m9ejX79u1j+fLl3HjjjbRt25ZBgwYB0KlTJwYPHsz48eNZu3YtP/30ExMnTmTEiBE0adLEHp+DiIhTVK7OfWon4fRT+tOY6lZzvsjpbuzRlLfG9CTAx4vvfz/KqLfWkFVQ4uqygFqEmuHDhzNt2jSeeOIJevTowaZNm1i6dGllZ+ADBw6QmppaeXzfvn2ZP38+b7zxBnFxcXz88ccsWrSIrl27AuDl5cWvv/7KDTfcQPv27Rk3bhzx8fH88MMP+Pmd/J/+/fffp2PHjgwcOJBrrrmGfv368cYbb1zs9y8i4lSVE+8FV9dJWCOfxD0M6BDFe/ckEBrgw88Hsrh1Vgpp2UWuLguTra52YbaznJwcQkNDyc7OVv8aEXGZKZ9tZl7Kfh4Y0Ia/DO5o7HzvFtj1DVw7HXqNc22BIjXwe3oud769hvScYpqGBfDuuN60bhRk12vU5Pe3ZngSEXGik3PUnNpSo5FP4p7aRwfz8X19aRXZgMNZhYyevdalnYcVakREnOjkHDXlt9eLsiHnkLEd1dFFVYnUXmx4YOWyCv8e2hVfb9dFizoxT42ISH1xsqNweUtNxnbjObgJBDQ8y7tE6rbIID/+e19fl89bo5YaEREnsdlsZOSeNpuwOgmLh3B1oAGFGhERpzlRUEqpxRib0Sio/PaT1nwSsRuFGhERJ6noTxPRwPdkvwOt+SRiNwo1IiJOUhFqql/zSS01IhdLoUZExEkyck4bzp13FAoyARM00sgnkYulUCMi4iQnOwlX9Kcpv/UU3gp8A11UlYjnUKgREXGS9NNbajTpnohdKdSIiDhJ5bpPlaFmi/Gs/jQidqFQIyLiJOkVSyQEazi3iCMo1IiIOElGzikT79lsuv0kYmcKNSIiTmC12ioXs4wK8YPsg1CSB2YfCG/j4upEPINCjYiIExzLL8FitWEyGevkVLbSRLYDb1/XFifiIRRqRESc4ORswn74eJm15pOIAyjUiIg4wZlz1KiTsIi9KdSIiDjBGbMJa80nEbtTqBERcYKTE+/5gaUMjv5uvKCWGhG7UagREXGC9PLbT1HB/nBiL1iKwScQwlq6tjARD6JQIyLiBFXmqKm49dSoI5j1z7CIvej/JhERJ6i4/RQV7KdJ90QcRKFGRMQJ0qtrqVF/GhG7UqgREXGwMouVzLxTOgprOLeIQyjUiIg42LH8Eqw2MJsgwt8Gx3YbL+j2k4hdKdSIiDhYxRw1jYL98Dq2E2wW8A+D4BjXFibiYRRqREQcrGp/mlM6CZtMLqxKxPMo1IiIOFiVOWrUSVjEYRRqREQcrHI4tzoJiziUQo2IiINVTrwX7K85akQcSKFGRMTBKvrUNA0ohewDxk611IjYnUKNiIiDVdx+amU7aOwIioHAcBdWJOKZFGpERBwso7yjcEzJXmNHtG49iTiCQo2IiAOVWqwcyy8BIDxPk+6JOJJCjYiIA2XmFWOzgbfZhP+JHcZO9acRcQiFGhERBzp1dW6ThnOLOJRCjYiIA1WMfGoTVAz5GcbORh1dWJGI51KoERFxoIo5anr4HjZ2NGwJvg1cV5CIB6tVqJk5cyYtW7bE39+fhIQE1q5de87jFy5cSMeOHfH396dbt258+eWXla+Vlpby17/+lW7dutGgQQOaNGnC6NGjOXLkSJVztGzZEpPJVOXx9NNP16Z8ERGnqbj91MF8yNihTsIiDlPjULNgwQKSk5OZMmUKGzduJC4ujkGDBpGRkVHt8atWrWLkyJGMGzeOn3/+maFDhzJ06FA2b94MQEFBARs3buTxxx9n48aNfPLJJ+zYsYMbbrjhjHP985//JDU1tfLx4IMP1rR8ERGnqrj91NKy39ih/jQiDmOy2Wy2mrwhISGBXr168corrwBgtVqJjY3lwQcf5G9/+9sZxw8fPpz8/HyWLFlSua9Pnz706NGDWbNmVXuNdevW0bt3b/bv30/z5s0Bo6Xm4Ycf5uGHH65JuZVycnIIDQ0lOzubkJCQWp1DRKSmRs9ey/e/H2V942eJPLEJhr0N3W5xdVkibqMmv79r1FJTUlLChg0bSEpKOnkCs5mkpCRSUlKqfU9KSkqV4wEGDRp01uMBsrOzMZlMhIWFVdn/9NNPExERwSWXXMJzzz1HWVnZWc9RXFxMTk5OlYeIiLMZfWpshOXtMnaopUbEYbxrcnBmZiYWi4Xo6Ogq+6Ojo9m+fXu170lLS6v2+LS0tGqPLyoq4q9//SsjR46sksj+9Kc/cemllxIeHs6qVauYPHkyqampTJ8+vdrzTJ06laeeeqom356IiN1l5BbTmON4l+aB2Rsi2rm6JBGPVaNQ42ilpaXcdttt2Gw2XnvttSqvJScnV253794dX19f/vjHPzJ16lT8/PzOONfkyZOrvCcnJ4fY2FjHFS8icpriMgvH80sYYC5f8ymiLXj7urYoEQ9Wo1ATGRmJl5cX6enpVfanp6cTExNT7XtiYmIu6PiKQLN//36+/fbb8943S0hIoKysjH379tGhQ4czXvfz86s27IiIOMvRXGPkUyevipFPuvUk4kg16lPj6+tLfHw8y5cvr9xntVpZvnw5iYmJ1b4nMTGxyvEA33zzTZXjKwLNzp07WbZsGREREeetZdOmTZjNZqKiomryLYiIOE3FcO7uPuVTVER1cWE1Ip6vxrefkpOTGTNmDD179qR3797MmDGD/Px8xo4dC8Do0aNp2rQpU6dOBeChhx6if//+PP/881x77bV8+OGHrF+/njfeeAMwAs0tt9zCxo0bWbJkCRaLpbK/TXh4OL6+vqSkpLBmzRr+8Ic/EBwcTEpKCpMmTeKOO+6gYcOG9vosRETsqmLivfbmQ2BFLTUiDlbjUDN8+HCOHj3KE088QVpaGj169GDp0qWVnYEPHDiA2XyyAahv377Mnz+fxx57jL///e+0a9eORYsW0bVrVwAOHz7M559/DkCPHj2qXOu7775jwIAB+Pn58eGHH/Lkk09SXFxMq1atmDRpUpU+MyIidU16ThFmrMRaDhg7FGpEHKrG89S4K81TIyLO9szS7Xy18kdW+D0C3gHw98Ng9nJ1WSJuxWHz1IiIyIXLyCmmg6m8k3CjDgo0Ig6mUCMi4iAZuUV0MJUP59aaTyIOp1AjIuIg6TlFtK+Yo0b9aUQcTqFGRMRB0k+9/aSWGhGHU6gREXGAolILhYUFtDKlGjvUUiPicAo1IiIOkJFTTGtTKt4mKza/EAhp4uqSRDyeQo2IiAOk5xbRvryTsCmqM5hMLq5IxPMp1IiIOEB6ThEd1ElYxKkUakREHCAjp5j2FZ2Eo7Xmk4gzKNSIiDhAepU5atRSI+IMCjUiIg6QlXWC5uajxheNFGpEnEGhRkTEAXyP/w5AkV8kNIhwcTUi9YNCjYiIA4Tk7gKgqGEHF1ciUn8o1IiIOEB04R5jQ/1pRJxGoUZExM7yi8toZd0PgH/Tri6uRqT+UKgREbGzjNxiOpiN4dx+TRRqRJxFoUZExM6OZxwhypQFgCmqo2uLEalHFGpEROysKHULABle0eAX7OJqROoPhRoREXtL32Y8+bd2cSEi9YtCjYiInfmf2AFATnBbF1ciUr8o1IiI2FlYnjFHTXG4+tOIOJNCjYiIPdlsRBftBcAU3dnFxYjULwo1IiL2lJtKkC2PMpuZwCZqqRFxJoUakfro4FpYPQvyM11diefJ2ArAXltjohqGurgYkfpFoUakvtmfAnOvg6V/hRe6whePwPE9rq7KYxQfMYZz77A1IyrYz8XViNQvCjUi9UnGNvhgOFiKIaAhlBXCurfg5Xj4aDQc2uDqCt1e8ZHNAOwzt6CBn7eLqxGpXxRqROqL7MPw3jAoyoZmvWHSVhizGNomgc0KWz+Dt66EOdfAjqVgtbq6YrdkPmrMUXM0QHPUiDib/owQqQ8Ks+D9WyDnMES2h9sXgG8gtLrCeKRvgVUvw28LYf9PxqNRR+j7IHS7FbwdcBulrATSfoPDG6Bxd2jex/7XcLaSAvyzdgKQE9LOxcWI1D8KNSLOYLNBWZHx7Bvo3GuXFsGHtxsdWINi4I7/QmB41WOiu8BNs+DKx2HNa7B+LhzdDp9NgOX/gj73QfxYCAirfR15GUYH5YNr4NA6OPKz8ZkAePnCXV9AbO/an9+Vju2G9bPh5/fwthRRaPOFhi1dXZVIvWOy2Ww2VxfhDDk5OYSGhpKdnU1ISIiryxFnKS2ENa9D9iEwe4HJC8zm8mevqs8m05n7zF5gMhvPNptxvtKC8kfhmc8lp7522uvYjHP2vheu/hd4+Tj++7daYOFdsO1z8AuBsV9CTLfzv68oGzbMhdWvQW6qsc83GOLHQJ8HILTpud9vKTNCVEWAObgGTuw787iAcCNgHdsFDRrB+O8gLLaG36SLWMrg96Ww/m3Y/W3l7hO+jfln3lCi+o1h8jWdXFigiGeoye9vhRrxXMf3GJ1f035zdSVnatEPbp0LQY0cdw2bDb76C6x9w2gJueO/xq2mmigrMW5JrXoZyvuKYPaGrrcYt6Ziuhr7Co7DofVwqKIlZgOU5p92MhNEdTJaY5r1htgEiGgDJfkwezCk/wbR3eDupeAXdNHfvsPkpsPGd2DDHON2HgAmaHcV9LqHievCWfJbBo9f15lx/Vq5tFQRT6BQUw2Fmnpm2xJY9AAUZ0NgpNHCAEbLhc1idIK1WU75+lz7rcazyQQ+geATcPLZt0H516fs82lw2tfl276BsGclfHoflORCSDMY8R40ucQxn8EP02H5U8b2LbOh67Dan8tmg53fwKqXYN8PJ/c37wsFmZD5+5nv8QuBZj2N8NKsl7Htf5Z5W7IOwpt/gPyj0PE6uO1do0WtrrDZYP8qY6TYts/BWmbsDwiHS0dDz7GVt5tunbWKdftO8Mrtl3Bd9yauq1nEQ9Tk97f61MgZrFYbJhOYTKban2Tfj3Bif3knU1/7FXc+llLjF/mql42vY/vArXMgpI78cul0HUQuN/q4HNtltFBc/yLEjbDvdTZ9cDLQDJp6cYEGjEDX/mrjcXgD/PSS8cv9wKqTx0S0PRlgYhOgUQfjtt2FCIuFEfNh7rWwfQl89x8Y+PjF1WwPRTnw6wJY9/bJliowWpp63QOdbwQf/ypvycgtBiAquOp+EXE8tdTYwY60XNpHB11cCHAxm83Gmr3HWbDuIF/+lkqwvzeXtY3ksraRXN4uksahARd2opJ8+Poxo9MkQEQ7GPIMtB3ouOIr5KTCx3ef/EWbOBGSnnRO35WaKsqGT+41+mQAJNxvv342O5cZc9FYy4xbRFf/++LPWZ3je2Hn1xDWwggyDSIu/py/fAif/tHYvvkt6H7rxZ+zNtK3GEHm1wVQkmfs8wk0QnqvcdA4rtq32Ww2Oj2xlKJSKysfHUCLiAZOLFrEM+n2UzUcFWp2ZeSRNH0lnRuHMDqxBTf2aEqA7wX+dVoHHM0t5r8bD7Fg3UH2Zp7eB+KkNo0acHm7RvRrG0lC63CC/av55XtovfGL+vhu42v/UOOXN0CHa2HQfyDcQX0M9n5vBJr8o8ZtjxtnQucbHHMte7FaYcVU+P5Z4+uWlxv9bBpE1v6chzfA3OuN/izdboObXnfobZziMgv5xRYKSy0UlVooLLFQXGahsMRqfF2+33hYTx5X/nXFa2aziUAfLwJ9vRic9jqJqe9QZvZlecIcCqMuIcDXeC3Q17v82at8nzeBPl6YzXb4g8Jqga2LYO1bp7VAtTNaZeJGnHP018HjBXy7PYMpnxszCm/752C3+rdApK5SqKmGo0LNZ5sO85ePf6W4zJioLMTfm9t6xnJHnxa0jKybf6VZrDa+33mUD9ceYPm2DMqsxo9AoK8XN8Q14daesZRarPy4M5MfdmXy26EsrKf8lHibTfSIDaNfO6MVp3vjBvj8OA1+eN7ohxLSFIa+avQVWfEMrJll7Pfyg8segn6T7Des2WqFH6cbtytsVojuCre9Y3RAdRfbFpf3s8mD0FgY/h406VHz8xzbDW9fbfRxaf0HuP0jh976+2TjIf7x6WYKSy12Pa8JK2/4vMBVXhvIsIVxY/G/SOXcrUB+3mYiGvjSo3kY8S3CiW/RkM6NQ/D1vsBAV3Ac/jvu5Cgmkxd0vNYIM62uMG6/nSavuIyU3cf4/vej/LDzKPuOFVS+1jQsgJ/+duUFf88icnYKNdVw5O2nE/klLNxwkHdX7+fg8cLK/QM6NGJ0Ygv6t4/Cyx5/SV6kQycKWLj+EAvXH+RIdlHl/h6xYYzsHcu13ZsQVM207tkFpaTsyeSHnZn8uCuT/af8493GdJiXfF+ji8lYOyi3/c0E3TQdU0DDkyfI2G6Mwtm70vg6pBkM+jd0HlrtL4sLVnDcCAM7/1f+jdwB104zOua6m4ztRj+b47vB2x9ueBm631blkLziMg4cK+BwViEdY4KJDT8lGOYdhbevghN7Iaa7MXTbL9hh5f56KItbXkuhxGKEeV9vM/7eZgJ8vfD38SLAx3j29zFXbgf4eOFX+Zq5yjEWq42C8pae/GILlqIc/rjrfpoU72GfT1v+FvYsWaU+FJRYyh9lFJZaONe/Xn7eZuJiw4hv0ZD45g2Jb9GQhg2qCXlHNsFHd0LWAfAOgMv+BPF3ndEPy2q1sflINt//fpTvd2aycf+Jyj8IwAj7lzZvyOXtIhl6SdOq/31EpNYUaqrhjNFPFquNlb9n8E7KflbsOFq5PzY8gDv7tOC2nrGEBTqx0yxQUmZl+bZ0Plh3kB92Hq38JRAW6MNNlzRleK9YOsbU7PM4eLyAH3dm4LX+bW44+hr+lJJla8A/SsfxhbUPTUL9uaxtJN1jw/DzMuPtZcLLBM3Sl9P512cIKDCGwWZH9+FgnycpieiIj9k4zttswtvLXP5sIsDHq/rP7PBG+GgMZB8wQsA10+DSOy/243KpsvwTlC4cR8C+5QCsbzySd4PHse9ECQePF3A8v6Ty2IaBPnw2oR/NIwKhOM/oYJu6yejfMu4bCI52WJ1ZBSVc+9KPHM4qJKlTNK/fGe+Y0H5iP7x5pdHy1OkGuHVelVtpNpuNolIrBSVlFJRYOHSikI0HTrBhv/HILiw945StGzUgvnlDerY0Qk7rw59j/iLZmASwYSujlaximDqQml3IDzsz+f73o/y0K5MTBVXP2SIikCvaNeLydpEktomo/rasiFwUh4eamTNn8txzz5GWlkZcXBwvv/wyvXuffSbQhQsX8vjjj7Nv3z7atWvHM888wzXXXFP5us1mY8qUKbz55ptkZWVx2WWX8dprr9Gu3clpxo8fP86DDz7I4sWLMZvNDBs2jBdffJGgoAubz8LZQ7r3Zebz3ur9fLT+IDlFxvBPP28zN/ZowujElnRtepahrXayKyOPj9Yf5L8bDnHslF+GfdtEMLxXLIO6xODvU8v7/TlHjOHSe74DILfpFXzSfDJfHzSzbt8JSsrOvmaQP8Xc572Y+7wW428qpcxm5l3LVbxQdgs5VH+7rnl4IH1ah9OndQSJrcNpvHM+LJ0MlhLjF9Ft7xjT7LuB7MJSDhwr4MBx43HwRAEHy7cPnyjEarUwyftjHvReBMBPli5MLH2QExg/sw0DfTCbTBzLL6FdVBCf/LEXwZ/cAbuXQ2AE3P01RLZ1WP1Wq41x89bx3Y6jNA8PZPGD/QgNcOAv8v0pMO96sJZC/7/CH/5+wXXuycxn4/4TrN9/nA37T7D76Mk+Yz6U8bj3u4z2/gaAfeGXkZH0Cm1bNOO3w9mVt5R+T8+rct4gP2/6tongivZGkFFHYBHHc2ioWbBgAaNHj2bWrFkkJCQwY8YMFi5cyI4dO4iKijrj+FWrVnHFFVcwdepUrrvuOubPn88zzzzDxo0b6drV+IvomWeeYerUqcybN49WrVrx+OOP89tvv7F161b8/Y1hkUOGDCE1NZXXX3+d0tJSxo4dS69evZg/f77dPxR7Kiyx8Nmmw7yTsp+tqTmV+y9pHsaYxJYM6RaDn/fFdSYstVg5nl/C0dxitqXmsHD9IdbuO175eqNgP26Nb8bwXrEX/4/w5v/CkmQoyjKa6q/+l9HvoPw2UmGJhXX7jvPjrkz2ZeZjsdootdoos1gpO+W5YUka9xS8xeVlKQCcIISZXqP4xDqAUpuJMouNMquVUsvJH89AiviPz9vc5PUTAEcaJ+F102tEV/NzV9fsyshl+je/89XmtHPeMvH1MtOsYQA3+W/g3uPP4WctpDCwKUcGv01U+54E+/uQll3EDa/8SEZuEe9HzOWy/G+MkTljlkCzeId+Hy8v38nz3/yOn7eZTx7oS5cmjg3nAPz8Pnz2gLF9EfPtnMgv4eeDJ9j+++8M/O1ROpQaQ7RfKB3GS5absFWzvq/JBHHNwriiXSSXt29Ej9gwfLzq0Pw5IvWAQ0NNQkICvXr14pVXXgHAarUSGxvLgw8+yN/+9rczjh8+fDj5+fksWbKkcl+fPn3o0aMHs2bNwmaz0aRJEx555BH+/Oc/A5CdnU10dDRz585lxIgRbNu2jc6dO7Nu3Tp69uwJwNKlS7nmmms4dOgQTZqcfw4SV0++Z7PZ2LD/BO+k7OerzamVv6wjGvgyoncsoxJa0CQsoPLYvOIyjuWVkJlXTGZeCcfyi8nMLX+u2Ff+XF0zu9kEf+gQxYjezflDh0Z4X+w/xIUn4Is/w+aPja+bXAo3vwGRF7lo3+7v4Ku/QuaO8vNeAkOeg9hegNGPZP2+4/y+ZT2Dt/yV5pYDlNnMPF02krcs1wAmWkYEktgmgj6tjUd0SN2ZH+Tg8QJmLNvJpz8fquxsHRnkR/PwAJqHB9I8PJDYU56jQ/xP3spJ32r0szmx1wiQN74C3W4B4JeDWax+80/80fwZVrww3/6hMYeMA/2w8yijZ6/FZoNnb+nObT2duJzB148Zcw95+xv9hZrWMrzt+8lYNiI/A5tfCPv6z+A766VsOHCCDftOkJZTRONQf65o14gr2jfisrYRTr9lLCJVOSzUlJSUEBgYyMcff8zQoUMr948ZM4asrCw+++yzM97TvHlzkpOTefjhhyv3TZkyhUWLFvHLL7+wZ88e2rRpw88//0yPHj0qj+nfvz89evTgxRdfZPbs2TzyyCOcOHGi8vWysjL8/f1ZuHAhN9100xnXLS4upri4uPLrnJwcYmNj68SMwhm5RSxYe5D31xwgLcfosGs2QYeYEHIKS8nMK64cTXWhvMwmwhv4Eh3ix6DOMdzaM5aYUDv9ct/9nXG7KfeIMSrkikfhij/bb/4XS6kxlf+Kp6G4vDUr7nZjjpngaPjtY/j8T1CajzUomk0JM/hfbitS9hxj8+HsKiOzAFpHNiChdQR9WoeT2DqCKBeEnPScIl7+dicL1h2sDLBXdY7mkavb16wPU+EJ+O89sGuZ8XXiREh6ypgH6KtHAXi09F7ib3yQEb2b2/vbqHQkq5DrXv6R4/klDO8ZyzO3OPl2n9UCH4w0OoUHxcC939VsQkWbzRiF979/GCPxorrA8HfPGCWXU1RKsJ+3W885JeJpHDajcGZmJhaLhejoqp0Qo6Oj2b59e7XvSUtLq/b4tLS0ytcr9p3rmNNvbXl7exMeHl55zOmmTp3KU089dYHfmXNFBfvz4MB23DegDcu2pjMvZR+r9xxn2ym3pwAa+HoREeRHRJAvkUF+RAb5EtGg/DnI7+S+ID/CAnzsM1fHqUoLYdlTxqrNAOFt4OY37X+Lw8sHEicYE5stewo2vQe/zDeGOre6AnZ8YRzX6grMw97m0qAoLi1/a05RKev3HSdl9zFW7znOliPZ7MnMZ09mPh+sPQAYnUP7t2/ENd0aE9+8of0/p1Mczy9h1srdzFu1rzKYXt4ukkeu7kCP2LCanzCgoTE0+9t/G0PXU14xZmtO/QWAn1rcz8Idl/Ppos20jGxAn9Z2mADvNCVlVibM38jx/BK6NAnhqRu72P0a52X2gmFvGUPWj24zWrDu+vLCpgYoyYfFDxlrWIHxc3b9i8YSF6cJUUdfEbfmscskTJ48meTk5MqvK1pq6hIfLzNDujVmSLfG7MrIY/+xfMIbGAEmIsiXQF8X/uc58jN88seTt4V63QNX/bPaXwR2ExQFQ2ca6+h8+Sgc2Xgy0FzxKAyYfMa0+yH+PlzZMZorOxqhOLuwlHV7j7N6zzFS9hxja2oOe47ms+doPnN+2kdUsB9DusYwpFtjerUMt9uondyiUt76YS9v/7iXvGKjY3h8i4b8+eoOJLa5yKBh9oKkKUZn6EUPGKOcAHrdQ98h/8e1H27ii19Tuf+9DSyacJndO6/+35fb+PlAFiH+3rw2Kr72Hcwvln8IjPzAGBF15Gf4bILRx+ZcrSrH98CHd0DGFqOVcdB/IOG+i5tKQETqrBr91oyMjMTLy4v09PQq+9PT04mJian2PTExMec8vuI5PT2dxo0bVzmm4nZUTEwMGRkZVc5RVlbG8ePHz3pdPz8//Pz8Lvybc7G2UUG0jXLxysT5xyBjqzGq6acXjWn2g6LhxlehXZLz6mjWE+5ZDpvehy2fGr+ELrC/SGiAD0mdo0nqXB5yCkpJ2XOMr7ek8c3WdDJyi5mXsp95KfuJDPJlUJcYru3WmN6twmvV76iwxMK8lH3MWrmbrPLhvp0bh/DooA4M6NDIvrcxutwEke1hySSI6gxDnsVkNjPtljgOHi/g10PZjJu3nk8e6Gu3FofPfznC3FX7AJh+Ww9jCLkrhZcPu37nRtjyCTTqCAP+Wv2xv38Nn9xjzGrdIMqYrbnlZU4tV0Scq1YdhXv37s3LLxsLBlqtVpo3b87EiRPP2lG4oKCAxYsXV+7r27cv3bt3r9JR+M9//jOPPPIIYLSqREVFndFReP369cTHG7c+vv76awYPHuw2HYXrlOJcOLrDCDDpW43njG2QXzU40vlGuG4GBIa7pEx7Ky6zsGrXMb74LZWvt6RVDrUHCG/gy6Au0Qzp2pjENhHnHeFSUmblw3UHePnbXRwtX8CwTaMGJF/VgSFdYxx6i6s66TnGiKj0nGL6t2/E22N6XnTn8J3pudw48ycKSiw8MKANfxnc0U7V2sHGd+DzB43tW+caga+C1WosPbHiacBmLD5527y6s6ipiNSIw4d0jxkzhtdff53evXszY8YMPvroI7Zv3050dDSjR4+madOmTJ06FTCGdPfv35+nn36aa6+9lg8//JD/+7//O2NI99NPP11lSPevv/56xpDu9PR0Zs2aVTmku2fPnnV+SLdLlRVD5k4jsGRsKX/easycejYNWxqtAN1ugS43e2wzfUmZlZQ9x/jqt1T+tyWtyqRqoQE+XN05mmu6N+ayNpFVptovs1j55OfDvLhsJ4ezjNmjmzUM4OGk9gzt0eTiR5ldhF8PZXHb6ykUlVq5+7JWPHF951qfK6+4jBtf+ZHdR/Pp2yaCd+7u7dLvrVpL/w6rZxojw+5eaiwtUZhlLIhZsVBor3uMVcqduVK8iNiVwyffe+WVVyon3+vRowcvvfQSCQkJAAwYMICWLVsyd+7cyuMXLlzIY489Vjn53rPPPlvt5HtvvPEGWVlZ9OvXj1dffZX27dtXHnP8+HEmTpxYZfK9l156qc5OvudUVouxYnLGVji63VhhOGMbHNtljPSoTlAMRHUyAkx0Z2M7sgP4ufgWmAuUWays3nOcLzen8r/NaVUmKwz29+aqztFc07UxRWUWpn/zO3vKJ3GLCvbjwSvbMrxX8wtfY8jBvvg1lQnzNwIw9eZujKzFiCibzcaDH/zMkl9TiQ7x44s/XU5kUB28lWspM1Yj37UMgpsYQ96/eKR8CLw/XPcC9Ljd1VWKyEXSMgnVcFioKSsxFiL0D3PoasiAMSw1++DJFpeMbcYj83djmvfq+IWeDC1RncsfnTzmlpK9Waw21u49zlebU/lqc1rlraVThQX68MCANtzZp2WdXIX5xWU7eWHZ73ibTbw7LqHGHZXn/rSXJxdvxdts4sN7+9CzZR3+WSnKhreuOtmhHSCsudHvpnGc6+oSEbtRqKmGw0LN/lUwZwiYvSEwEoIaGZ0Sg6KgQeQp241OPgdGgtc5+mjbbJCXXh5ctp8MMEe3GwGqOt4B0KjDmeElpInH3kJyNIvVmDDxy99SWbo5jaIyC3f1bcm4fq3q9Bo/NpuNP324icW/HCEs0IdFD1x2wSvGb9h/guGvp1BmtfHEdZ25u18rB1drB8f3GCOiCk9Amyth2NsK7SIeRKGmGg4LNduWwIJRNXyTyfhHt0FUeQgqD0KWEiO4ZGw1/oGujtnHGAET1QmiOp4ML2EtzhjuLPZjs9ncakK2olILw19P4ZdD2bRp1IBPJ1x23hFRx/KKufalH0nLKeLa7o15ZeQl7vM9H9sNab9Bp+v1/4GIh1GoqYZD+9SUlRgrCedlQP7R8ucMyM88uZ131HguOAa2C5gt2GQ2Jrs7NbhEdYbw1vabyVc8WkZOETe88hNpOUVc0b4Rs88xIspitTF69hp+2nWM1o0a8PnEfgT5eew0ViLiRhw2o7CchbevcZvnQoaMWi1QcLw86JQHn4ptkwkadSrvtNsefOrOGkbifqJC/HlrTE9umbWK738/yr+/2MaTN1Q/G/CMZb/z065jBPh4MeuOeAUaEXFL+pfL2cxexi2noEYQ7YLp5qVe6do0lBdu68H9729k7qp9tIsOYlRCiyrHfLs9nZe/3QXA08O60T462BWliohctLoxDlVEHGZIt8Y8cpUxPcKUz7awandm5WsHjxcwaYGxjtToxBbc2KOpS2oUEbEHhRqRemDilW25Ia4JZVYb97+3kb2Z+RSVWrj//Q1kF5bSIzaMf1zbydVliohcFN1+EqkHTCYTz97Snf3HC/jlYBbj5q2jR7MwNh/OoWGgDzNHXYqft0YNiYh7U0uNSD3h7+PFm3fG0zjUnz1H8/nk58OYTPDiiEtoGhbg6vJERC6aQo1IPRIV4s+bo3sS4GO0yjw8sD1XtG/k4qpEROxDt59E6pmuTUP55IG+7EjL5YY4rVwtIp5DoUakHurUOIROjT1sYVcRqfd0+0lEREQ8gkKNiIiIeASFGhEREfEICjUiIiLiERRqRERExCMo1IiIiIhHUKgRERERj6BQIyIiIh5BoUZEREQ8gkKNiIiIeASFGhEREfEICjUiIiLiERRqRERExCPUm1W6bTYbADk5OS6uRERERC5Uxe/tit/j51JvQk1ubi4AsbGxLq5EREREaio3N5fQ0NBzHmOyXUj08QBWq5UjR44QHByMyWSy67lzcnKIjY3l4MGDhISE2PXc9Zk+V8fRZ+s4+mwdR5+tY9T1z9Vms5Gbm0uTJk0wm8/da6betNSYzWaaNWvm0GuEhITUyR8Id6fP1XH02TqOPlvH0WfrGHX5cz1fC00FdRQWERERj6BQIyIiIh5BocYO/Pz8mDJlCn5+fq4uxaPoc3UcfbaOo8/WcfTZOoYnfa71pqOwiIiIeDa11IiIiIhHUKgRERERj6BQIyIiIh5BoUZEREQ8gkLNRZo5cyYtW7bE39+fhIQE1q5d6+qS3N6TTz6JyWSq8ujYsaOry3JL33//Pddffz1NmjTBZDKxaNGiKq/bbDaeeOIJGjduTEBAAElJSezcudM1xbqZ8322d9111xk/x4MHD3ZNsW5k6tSp9OrVi+DgYKKiohg6dCg7duyockxRURETJkwgIiKCoKAghg0bRnp6uosqdh8X8tkOGDDgjJ/b++67z0UV15xCzUVYsGABycnJTJkyhY0bNxIXF8egQYPIyMhwdWlur0uXLqSmplY+fvzxR1eX5Jby8/OJi4tj5syZ1b7+7LPP8tJLLzFr1izWrFlDgwYNGDRoEEVFRU6u1P2c77MFGDx4cJWf4w8++MCJFbqnlStXMmHCBFavXs0333xDaWkpV199Nfn5+ZXHTJo0icWLF7Nw4UJWrlzJkSNHuPnmm11YtXu4kM8WYPz48VV+bp999lkXVVwLNqm13r172yZMmFD5tcVisTVp0sQ2depUF1bl/qZMmWKLi4tzdRkeB7B9+umnlV9brVZbTEyM7bnnnqvcl5WVZfPz87N98MEHLqjQfZ3+2dpsNtuYMWNsN954o0vq8SQZGRk2wLZy5UqbzWb8jPr4+NgWLlxYecy2bdtsgC0lJcVVZbql0z9bm81m69+/v+2hhx5yXVEXSS01tVRSUsKGDRtISkqq3Gc2m0lKSiIlJcWFlXmGnTt30qRJE1q3bs2oUaM4cOCAq0vyOHv37iUtLa3Kz3BoaCgJCQn6GbaTFStWEBUVRYcOHbj//vs5duyYq0tyO9nZ2QCEh4cDsGHDBkpLS6v83Hbs2JHmzZvr57aGTv9sK7z//vtERkbStWtXJk+eTEFBgSvKq5V6s6ClvWVmZmKxWIiOjq6yPzo6mu3bt7uoKs+QkJDA3Llz6dChA6mpqTz11FNcfvnlbN68meDgYFeX5zHS0tIAqv0ZrnhNam/w4MHcfPPNtGrVit27d/P3v/+dIUOGkJKSgpeXl6vLcwtWq5WHH36Yyy67jK5duwLGz62vry9hYWFVjtXPbc1U99kC3H777bRo0YImTZrw66+/8te//pUdO3bwySefuLDaC6dQI3XOkCFDKre7d+9OQkICLVq04KOPPmLcuHEurEzkwo0YMaJyu1u3bnTv3p02bdqwYsUKBg4c6MLK3MeECRPYvHmz+tQ5wNk+23vvvbdyu1u3bjRu3JiBAweye/du2rRp4+wya0y3n2opMjISLy+vM3rcp6enExMT46KqPFNYWBjt27dn165dri7Fo1T8nOpn2Dlat25NZGSkfo4v0MSJE1myZAnfffcdzZo1q9wfExNDSUkJWVlZVY7Xz+2FO9tnW52EhAQAt/m5VaipJV9fX+Lj41m+fHnlPqvVyvLly0lMTHRhZZ4nLy+P3bt307hxY1eX4lFatWpFTExMlZ/hnJwc1qxZo59hBzh06BDHjh3Tz/F52Gw2Jk6cyKeffsq3335Lq1atqrweHx+Pj49PlZ/bHTt2cODAAf3cnsf5PtvqbNq0CcBtfm51++kiJCcnM2bMGHr27Env3r2ZMWMG+fn5jB071tWlubU///nPXH/99bRo0YIjR44wZcoUvLy8GDlypKtLczt5eXlV/sLau3cvmzZtIjw8nObNm/Pwww/z73//m3bt2tGqVSsef/xxmjRpwtChQ11XtJs412cbHh7OU089xbBhw4iJiWH37t385S9/oW3btgwaNMiFVdd9EyZMYP78+Xz22WcEBwdX9pMJDQ0lICCA0NBQxo0bR3JyMuHh4YSEhPDggw+SmJhInz59XFx93Xa+z3b37t3Mnz+fa665hoiICH799VcmTZrEFVdcQffu3V1c/QVy9fArd/fyyy/bmjdvbvP19bX17t3btnr1aleX5PaGDx9ua9y4sc3X19fWtGlT2/Dhw227du1ydVlu6bvvvrMBZzzGjBljs9mMYd2PP/64LTo62ubn52cbOHCgbceOHa4t2k2c67MtKCiwXX311bZGjRrZfHx8bC1atLCNHz/elpaW5uqy67zqPlPANmfOnMpjCgsLbQ888ICtYcOGtsDAQNtNN91kS01NdV3RbuJ8n+2BAwdsV1xxhS08PNzm5+dna9u2re3RRx+1ZWdnu7bwGjDZbDabM0OUiIiIiCOoT42IiIh4BIUaERER8QgKNSIiIuIRFGpERETEIyjUiIiIiEdQqBERERGPoFAjIiIiHkGhRkRERDyCQo2IiIh4BIUaERER8QgKNSIiIuIRFGpERETEI/w/wEEe+ho0UssAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for k in range(lds_array.shape[0]):\n",
    "    plt.plot(lds_array[k, 0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "58582fc9-190f-42c7-a62c-1f7b2111d74a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9bb0b736-25aa-4368-a617-ba6efa313cd1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "48b22ec8-2d00-497b-8992-7442d7626802",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "381858e5-e107-480e-a471-60097744cdb7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d86133a7-5da3-4beb-8b47-d599bfce3150",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8d2709ed-3499-4651-98eb-0cf583cff5b2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ffcf2bce-eecd-419b-94d9-7fb8d6475cf4",
   "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
}
