{
 "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": 1,
   "id": "8c2f5efb-631c-4083-84ae-dc219c6a75a1",
   "metadata": {},
   "outputs": [],
   "source": [
    "# from diffusers.utils import randn_tensor"
   ]
  },
  {
   "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": 2,
   "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": 3,
   "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": 4,
   "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": 5,
   "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": 7,
   "id": "fb2dc562-293c-4e74-8e97-141fc7465938",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "bda41875-8976-4852-823a-91dc1f42aebf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5000"
      ]
     },
     "execution_count": 8,
     "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": 9,
   "id": "5ffbb813-1636-44e3-b943-400824fde5e7",
   "metadata": {},
   "outputs": [],
   "source": [
    "# with open('./data/indices/5000-0.5/idx-val.pkl', 'rb')  as handle:\n",
    "#     idx_val = pickle.load(handle)\n",
    "# len(idx_val)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "773b1a12-d60d-4ed8-8f61-b03a3af61e71",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "40c86797-31d5-45d0-b46f-52f8c84dd130",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>path</th>\n",
       "      <th>split</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>../../../../codes/celeba/data/celeba/img_align...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>../../../../codes/celeba/data/celeba/img_align...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>../../../../codes/celeba/data/celeba/img_align...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>../../../../codes/celeba/data/celeba/img_align...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>../../../../codes/celeba/data/celeba/img_align...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                path  split\n",
       "0  ../../../../codes/celeba/data/celeba/img_align...      0\n",
       "1  ../../../../codes/celeba/data/celeba/img_align...      0\n",
       "2  ../../../../codes/celeba/data/celeba/img_align...      0\n",
       "3  ../../../../codes/celeba/data/celeba/img_align...      0\n",
       "4  ../../../../codes/celeba/data/celeba/img_align...      0"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "df = pd.read_csv('../../../../codes/celeba/data/celeba/list_eval_partition.txt', delimiter=\" \", \n",
    "                 names=['path', 'split'],\n",
    "                 header=None, skipinitialspace=True)\n",
    "df['path'] = df.apply(lambda x: \"../../../../codes/celeba/data/celeba/img_align_celeba/{}\".format(x['path']), axis=1)\n",
    "df.head()    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c6632d56-9134-4720-99a9-1853fe349039",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5df420e1-7166-4e5b-baa3-a012fe7e32e1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "f2ce6b6b-ff45-4156-9606-7c87046e751a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAALIAAADaCAIAAACNT48IAACXdklEQVR4nOT96bMky3EfiPoWEZlZVWfp7S4AAQHcRFI2ZmNjppn//+vTvPfmjaSRSIokCNyt13NOLZkZEe7+PkRWdfUKdKOB26D8XmurU5WVlZnh4bv/HP/Lf/7/uruqujsiMjMz05H4SIiIiABQa3X3Uso0TdM0zfPcvmtmiNhetNftDBcXFzHGvu9TSkQEAO4OAO0YAGj/tjfbv43OPz2nN498F51/148EamZWTEsptVZVrabu3u4aidq32jFmFkIax7E9GVVth03TlFJS1XaGGGPXde3hdF2nqppLeyxEJLQ8UmaOIYgIMwMAmrs7ynL77XG112bWXr/1fs/fOT0lM3vrc/utz/mtj5d+68P9XR76u87+/nc+Ezpx/Ed8EV593P9m6CPZAs/o9M5rx5wYc9mmnwedrvmjuaHR+WY93V2Tl39CW+Jd9HtJizef7GvvvPaMPsOn89GccWKLt0qLtz6cPyH6faXFa++cH+NvEHw2nPH+K/9d6DV2P3HJa+bRu+THZ04fzBbnu+RE7xGbr7HFj06fSom8drY32eI1qfl7/tAfmeT3+fJre+5dh33ODwUR4aOurjluJ554K9//T6dE4N0O5Ine1B2fD3/8jgz9cac9t0b/REmav0tEZtYCGCe90Fzednt0dOiZuR3ZfP0W0jhffkQkovbO6cjXDmgnPL3fTv5BrHN66B/KaqcraXECM3NbruHNY9rrEEKttdbaLlJVQwjtNk/RgnZJRKSqcAwktE9bBOfc/mhECO6urqcfag8f3rBRXrvft25IZvZj0Oh0MeeK8k2j513PBz5CibzpevzWr5w/4h99Dx1N5bc/l3NTmt7Lb6cgXluG0wZY2MvtpX4BP+0xVW0HIGL7AHj53d/zvl4TUedy6yPo422L167gXXTOEx/9W5+QTmzR/jwXZssmPooNtNeZ+HybvvV2zrfyuW0LR+F0/t3GFucM+kn2zCc5ye9lcv4u9Fm5IfBGkO1Ep+D9awe3h3y+cidl2hToSWCcq4kmaRqHMRIRtdi/HHMLcJRGhq8EreG3bfT3C//TLfyerPYxSuR8H/zuhufnxhnv+uikFJpeOP/0FRXzquY2s1pre01EzZ5oX2k5kWaOnLJNcGILX0yB00/8nnd3nnj6aPpjKJE37c0fl062RUtfOcLJuD5ni3dxMx5zaa+93w5esmL0Mt14SpWd2OgVJUJv8YnelFtvHvPmr7/1DO8//l30MWzxppB4v7T4Xa7jj0bNKWA4Uwr20qHwV/n4zft6TZsQkYiYmYgsKoOZmSNL44PGFu1H4VUF8drz+FQC4/c0Nhv9wW0L+GwYotHiKx5jWIgIhifjwMzUva0YA0ILdi1vIAGSA7UtAShISMiA7h5CWNLl58UJR5l0cmXPF7y9dnhdT33cfZ1M5tMZTnb0R5xNROQkOf2sEuIkKl8zrc930ume2/t4dOVPEhgAVFVVT3oaj/5008Svsfb5Xf2edB6HgPPHTQTudHyIzByOJme7EgMHc4Pl+nPOAPTm/pGUlguOcr4eKfYv7+X0u+70Zoa5GbPNQz29eWQSRIYPoaaj2lfbmc6DJW8SIp00++n5IKK7QbtbfBudXehbzK7zT88teUQ854AT38BxL54Y6IPu+T30obrz/P3zi2l73d3J3dH59LzC239XRODsab5UrKeTf9TtfCYk587ViX3eI39eexCnIq7zA9qfTZCGEGKMrSTptAyfUK18BFucf9S2FB4js+cHtH/b8r/n188fCAC4/0HC6n8Iem2Lnl+tvOZzn7a+yEvZ+Fbh0ZY/xggAraDt/IBmizXHTEQaZ5w/xNPxfyD6XTjvdDHwRi709PXXlNGJTu7oG7/4yfTgJ6F3XcxbN+fpIch56K2xyKnwEM5SIY3OhcrpMBFpBsT5Y21s0bYan8Vw3n+tH0FvOorvp9ek4JtX8juquXcdcJI6nz+dr9drm19SSu2t03qfh2nPBcZJ/r+mj0825vl58GiQ11pPNunpoz/CfvrQdf1dbJFzepcUOT/z58AfH/ocFmkRY8SznCecpRbfPMW5ZXBa3RMPnZb/lMQ7MdBJN8EbjPl70oee6s3j37N47zGD3qpY4VWe+LRW1Kel1+y8kxRYLCo8y8Ce2OJkNr5mhZ2fEc7u/DXLBc/8kWZpwhvP7lM9r49mi9dsiPfo4Le+/9YoJwC8W4j8KZG8GUI/7enz417Tx6/tiXMh8ebxJ348d1g+lD502d5Fb7J4o1OdxLl4O+fscw3o7i3e48eakvPzv/Yr75eO7/rI/ZW6iteY+D3n+a1Hnh8Gb6zUokTe/+V/e/TWTNK5IwZnERdEbO1Sr53kfKVfixq9/3H/0ej3lMf/07HFa7bza8t5YouT3X2SCqfD2tdfE42nVTd7PZlyrrz/CHRuLnw0Z3wytvj9Tb8/DrXaO3iVD97cze7eIhPN/T61T570yLnSeZUtXhbe/SFMzvc/t9cY4qMf8v900uI1N+rc0D4dc2oubdyQczazGGMI4RSme7O38zVNdKI/5gb4JKIC/oSkxafadie36zU90izHFoOptbbGZTOb53maJjNbrVbDMLSILby6L09fdPdj6u2lffp+k/ND6T2nequo+Ljn9j+dtDiT9mZmpwRvEw+llJxze92Wdp7n/X6vqo0/Wry/73s8VvGcKi1O5z9ni1MxzodGYz/u1j6JqID/CdniXDbUI6nqNE0ndIbmfZxyvznnnDMANHtCRBpsgYikI51ygYiLQXoyR/CN1oGPI3L4rWmkT2XNyIfm9T9V/ODd9PbHd24NwJmpGEJopgCcKYi2U3PORNR1HSJO06SqIoJMxypNL1r3h30pBQB2u52ZTdO02+1KKc2GAIAoklJkpmkax/HQ9/0wrHLOrVvE3VV1HOcmOYhgtVm3eH/TNeN80L23THIIIcauXVitNYTQdXEcR8DFTKGzbLwgQqvQeenxAr7r6bzPoHnn83z707djvcWfNJ129rkKb6+bYTjPc2OUdkyp9QTYcjgcDodD690ws5bPOyG0NIuhltLejzHmnOd5ZpbWq3NCgEE8wcKYxFaHEU5aiSnEGE99JXCM7NVat9uSUoDTFn/HPj9fQHKwP7wJ+yfPFm1R25KfV4U1re9HoB8iqrVO07Td7w6Hw36/H8dxnueccwtOTNPUUv/t4FaorapuBgAhhKY4mq6BYx9eEwyNb5riCHdNLigillJUNcU+hFBKaVWf7dq6rmvXAwDg1ERC44qljuucRU6v/1g+zWfHFu8Sbu9SmSchYUcCACLKObfkcNuytdbb29sXL17c7bbTNOWcTydsW7/xRLNARaSViYjIuN83nZJSgqNwanZDc1iaIGm7v9a63W5DCDGmdoCZ5bnO83x3d7darWLs3D3GeHFxEUJ4875eei76duH/oaLi4zzEz44tPpTOwwZNOJ8s/1rrPM+3t7f7/f5wODx79uzp06e5lra0LQ5xUjfNFGhmSgthtdoigmYKKFErGcFSyn6/77qulNI0VIO6al4MMqpqrXoKik9jbrpMVUOYG9up6vX1dUqptYucWxXHmwE49pL4Hy/wsdBnxxYfIS3aYzwvNm6GwuFweP78+bNnz3a73TiOu91umiYSPpmrTcU0AbPdbums/bpJlGmari+vSimNRUSkWYvjOD58+LCpJziWMZdSmlhCxCbu28U0aRFjLKXUusiz9t3Ly8uQBBFb00DjMHgVUu2P/zzhM2SLD6UmvU8mRSllHMdxHHPONzc3z58/H8exWX9EtNlsiKjZm2DuagjASIiIDidnsokcVytIh+0BEY1sW7YnTeXuQ+rMzMGYGQiJiBGYaZ5nIkKkFhQBAFNoPk4pxX1Jstzc3Nze3l5cXFzduw4hpJS6rlukl6MDgRMcvYhXGeQPHv+AfxtscVqqto+fP39+e3v75MmTm5ubcRxjjKeC0wZJYGallObcnsyIUwCjvX/6yjzOJxe3lHIKSzx79gwRWSil1EwTAGDEPM0hBCI+RTuYQnNwdrsdAK1WK0Tc7/dNx3333Xcppc1ms9lshmGIMTY2/XGfKn77za8/yYneJfQ+/A7fvhtCCOM4unvXdUR0VNUvrTZVvbm5+eabb548edJUQAsxNYPfzNpi393dnZTOuZnZOKb5DqcQuJl1oRv30zzPMcp6vQ4hTPPhcDhcXV22KymluGsLaiHT1b0HQFhKrbU2jwOBW6CsxS1O/lE7fzUd1uvmEl+s1w8fPry4uEBERgIAqwtmaGPceZ5j+tCd/DHS5U9GWozjmFJiXh5x26CNP5rDudvtmtY4HA7u3hzO5iwOw9DMw/1+36JJLR7VEhzNjzjFr1oooh0ACk7QdV2MsdZ6d3enqkiOiLvd7mg8lpMThExpHIHQzE82RHM4m3xyX1KvjZVJ+KJbIXOLiORpaqIoxpjCkplrDNT4OKX0O4Q6PwH9ybDFKWPZnm9zFxtD3N3dPXv27Obm5u7u7nA4NHvzFGxum+xwODSDA80bi7Smh77vm1I/8YSporkgMSMwzfMsEpuF2vY3I4YQGvOFwG3ZpvkQ58gSJXbIdGoLKKUwQVvpxQI9+sZEBIQla7dKw9D1/YqIqsGL57eqenl5udls1qsVE9da1QEdEV/vXP0Dkfzoaux3pL7vm5BHxNVqxcw3NzePHz9+8eLF4XC4u7tr7kZjGlXdbDYtOL3dbpsz0gIMZZqbWD51jeacSyld150SGa1mvQVBXLUl1hE9pR7Rm9PRhIpqqbWWOiNijDGmFPaJODDLic8Il8D8KR0DxzpqEp5KDpqaVXH0XHJTl0SUYmyOtJmZmmoREcA/uNX5JyMtUkq73a69AICnT59+9913Nzc3T548aWqlLd6pMrlZFfM8j+MIAH3fN5WB/XAeFT2Zqy0C1uIQjWNKKTnXFAYGYGIAAwetteRcNSNCrupH55SZBUGZx3EkriHEZsGUUhCWHhlEZA50RFIXEYmBHQ38brd1d0ZqTNCtBjMbx/GOuamwEAIw+R/DCwEAwO+/++YP+wOfyORsfn9byydPnvzLv/zL8+fPAWC73arqyVZo9kcLHzWtISKr1aqFn6dpCsRNnLQwgx1bZ1uUovFQy4iaWc1KLkO/7vpoZtN0KKUwY4i83+9LyWoFcYGWSylI6pyFOHRd3wxSdwenZnsyM/PLxnYiQqbUrxyP2BhIKaW+72OMSQIAIEAIYbPZNER9d7daPlBa/Js2Oadpaov37NmzX/3qV9999908z8zckhotr9Hcgbbqd3d3J43Q4tBt1Q9VW7yobXMAaIaFqSKAMKtqydmOBmmdrdaaM5yiZDFKTDLPc62lfT3G2EIaOedZJ5ZothRbqCo4tchEu8gWa19Y2e1udwixG4ah7/sggojzXHKusrlYHCL1GErtLQjiH6vb4DNkCwKwV/8FAGjm3osXL371q189fvy4/dnSXc2bOD3xU0BzGIZmMTx9+rSV0hCRVxWRGEIT44swF7nYXDlozrlFyptBmlIartbjOE/T5K4hBGY0s/1+Pww9gJeKKYUUYrWSp1LLnKuSmBDXEJi5VgUAQtxtt13fMy+N2ksRkNtvvv0+pRnBmAjhZUhte9hHlnaFRGReq2avfh4H+MNZheL+YQ7PhwdlP8h0phDjPM+qFgIzB9ViS6EUPn36/Ntf/+uLp880F1ADUwa8WK1VPXLsu76U8uTJk5xzCGG9vmhhJXeNqUcSIhJGAGdmdK+l1dREM5vmPI11v9+WUro+Xq437tZM1HGeUKBfJzMDNQclxiQRzFf9UCpP01TGvURmFHXFooEtglMtJc/TlNWNaf/1118HEQLUsnQYzLnOebzcrEQEXbfb2+0WJKRhGPp+mHORQdx9mg5MsBoixqC1ch/MlhZfV5vnucXf2uN7LQUPAPaOepr3V+t8btLCVJ1IEB2gFd0TgDY50cKXLbocY9TluU/37z/s+/7u7m673TJzCwcV0yarY4zrzaaluXOZwAzQStassxUDyLVaztnVmHm1WqWU0LUUbemPbrVCYGxpr9piUEvp7zzPh/12v9+3WFkLSa36TmLoYui6iMhD1wHJAu/qr4BEECIC1zKhG4SI6I7NKspmnlKac6lUyS1FUVUCY0EAUHA/NoIDtTDKJy4x/9zYAlrZUlvF9vhUdb/fP3/+/O7urnkKy6ifkhGx69I8j4fDbpomIhqGzhAOh0NKSSTEGJsRWmvNRVU1heDuxm2akJ/cxVLqZrPZbFYAUPPUhIq7397etvxqOObaWz2vllpKAUKJwWoBaB5sMHBHUAczYCIgDCHGGKsudq6qUhESNgVYYiGAaoiojmZQ1czsyy+/nOdZmMgNXIeu76KELsGCLbBA/hIR/gEiGZ9d3MLPupmboj0cDi0+0bTDqTLqNCLqxYsXpZT1ep1SmqZprkvJ3Xq9btGO29vb29vbXAsAzAukAjZH1N0pkLuHS2nW/jyPjL5arZjJzB41+99MVa3UeZ7neSqlpBBZcLVarddrq2Wp84uhmp4a16q3fGkBgBA7OMbimEOw0LySe/fuIToiI4khmVkutRnI7u5BAAC2e5HnMcl1EJHW0+uncrI/CFt8+lP+foRnbc3Nkt9ut99///3hcGiCupW07Pd7rQURb54/dcQ0dMB4u7ub5/ni4uLRo0eIyEzjeNjtdre3t6ei7eYoxphEhJzcEZyICNxjFHcHsD6FrusQoZQy13rqD9CcTxPORt2bGQEivGzZdfcYOyDikDikdv3moAa9RER0BVMD1UCBGZGYAAGBiFiEQmRmBzSzu7u7EEKMQVWnaXz2rAYhYr64unRCPmtrwA8H+fit9NlJi1P1W9OX0zQ112BJdSLM89xiEggeUqy19qsVIm63W0R88ODB1dVVk/e3t7e3L16M8xyYr66uuhjhiJEYYwohoHGtFYFFBJcKjBpjDMTEkPM8z/Pjx0+amUJE6ZhDAfOb2+fMrCW3SvGTC5pzdsTWI7J4HE5mZRxHInKFqioUAMCqAnlGMwAiATogiRMicYuZImKrwMml7Pd7Vyu1IlPsuz4mfBUn4tOu4+coLU59fLXWw+FQSokxDsOgqvN4aOlQIgI3Ve37BGg158B4dXX14ME9RNzt7ph5HvdWSwq86ofYJVfLZb672wGAcBARMK61hpC6rnt0/8E8z7VkIqhoeT9N05hrub6+auLhlNUsda61djGllMo8zuPoWmKf+hTUsWhRsxZNWW4EBBn2210IIVAABDTXUnPR4mVY9yzCLI5Q1VQBGxo0SYu2BeE2RXGcp5ubu2H9/OL6KvKCOOXu+AdwVD87tmjU7vmkYlsSZBzH29vb3W7XCmtrqTVnR/NaV6vVvXv3Qgjb7VZLjTE+ffyki/H68jLGFqCc9vv9NE0ckpkZqBOBQyDuY9qs1iIyHfY1F0CrNY+HvaoS87O7p20vNjlB6FbVSg3EQxcL4367A9MupsCieb662BQ1dw8SWySNWYTjbrdjiFECByFcEvpQbXu7S31M/YolCiEziUSJQURKKQA6DMMwDCklN+MgN9u70KXNsGoJejxrkviE9PGDI06lb7/j8a/dwLu+2FIGLabZ933O+fnz5zHGZlsMw9AMheZiuLtIcFAmyHMzJHZWagjBzdAlCgem/eGwffECAC4363HORJCn6bDdpdg/fPDgwf37q9Vqnue+60xVtThSmebD4bBa9eN2F7rUdR2477a3mouIdClst1utOaX0xcP7fqwvH7p+nuYQo4TgDqqFUMxrNUeAadyXae6H4fLyuvWlVVtLioCIEtRsvz8cxsN6fXF1fb/rOqKbaTpM01QI3XVI3Xoz9Ou+5WxXq1UL1BKLHwdWnHPH8fVvR/M5p7Yun520aAriVKZ7Kocxs5ubm+3NixbAmecZ3Nw1pgGNwWHaH/I0l5wBgABX/XCx3jDg88dP5nEaUgKAcbdfrdfqMEQYhvXV5fUwrMs0P/nu2+fPb5jRVAEMEdxqQAD3zXowhbwf3V0CDX0fmRDRS3UkJzQXdEBzBECEgEBuZI4IYcHxBXDvhBFFOHLgWuaDKzMj8jAMTsgSnJCI6RBK0e+///6rr77S6g08HhHclyrA8TA7aOSllEREhJdU7SdchY9kC3/Z6vSJAymnQAIeK+6baheR3W7Xer+W+k0zEfaqCJ5z3m63eZ6ZedX1ZNQH8ZJ3h8P2xXMCXKUoIlapE+5X677vwUnr/OLJ/nAYD4fD9ma7Xg+AnvNEgGBFa84H7dJg7EIiIpvVOsa42989e/as5hnd2AyDtVRFew6RyM0YtCkCImnDkT1gDF2MCQi1ulkloRDFzFgCM1OQ1PWpG57d3L64ubm8vMxaAUDBTdv4AaOZrvq+6suRNi3xdppe86nog9niTSb4tIqtOaiN2+Z5bl2ErXD3WOB0RCIgArPbFzdBKOe8u7lV1Yv1JhIHYsvl6dNn8zgxcxeCTjl0dP/ymoQCQRkPd7e77d2dVheJIhIZV12nVsqkjBSYOQRV7VJo2XAR2QwrZpx223KYuhCEJRLLEeO/xTAJ3Koye4SYWACpurmjIwiBkDsSBkCkECWlMOdCRE4G5CHEdDEgsjfcTwRENAUtpZTsFlr2vzUnvixzf2+l+PuVxbuO/+yUSKuObAX4jRWadfbkyZOW7z45hOA2TYc87nQRHhqJuhhSCES0vbut08zukYjdoVYoBXOhEG9vnt++uJumKcVuvdpEllpttOo6e6lQC6c4DJ17VPX1sCaSJsDzNDJzJ+HRveu2MML0EjNOzazm6WC1AjNKJGZHYEcnUrXqk2pBCdIqgNBVC6IgsJlrzkAypHh9fZ1W691uZ2juLc/rhmDu1fTJkyepC5frTTNoACAcS34+IX2ktDjnwfdLiw9VMSetdEqQNhCBUkpLOrS67eag5pwDMbizw5C6FGIfEwKQeR6ny82FIO13u1zqeliB+fNnT/oyVNPIFIY+hS4Ku5vpHAmhljJPVoqkEBhdHQnqNMdE675HIq15nmd0u1hvfOkmBTlOlFFUNySiDIDgwc3yXE0dmWMKQYqbqQkRUwiBkdHBYhRmBofiNs8zhbhed1dXKzNTcLOa8+SgRNRgyPmInvBSfQB+LtLiD+ca+VEkNm5oqBJ3d3etabPOC8pAztlNXa3rYx4PZjWl1PeJGb2Wat4Jx5aMQiDCKIQIBGildn1cDys3dFU3NzNBjKuBGAth38X1sIohZJvRFUAJfehSvxrG/SFPMwKklLyquyMCH2uDzSpUXPFmnmcFDyLqlqsiO2EkMEZ0QmIgAhbkwIiBOZgDIjKxuo/jyBx64SWXhhxCQHJm9lpVy72reywvEcqbzq21tg6GT0WfmxIhcAVzAiRAq1rzUrF979697c3tbndnWgEg51I1s7t0MedqpUiKHTVhrYQ4pDTttmDep15EwFxI7l9fx6E/TPtpO4rI1dXVql+3cAg5OGhiktRfX25ijAfeZbXN+trdWRC8ljqXOiUJ96+vt9stACCYiCQJiGheXSurTfFgCsg0lZzLjIAdw/awByaSSMRYK9UaOFAkRVM15CAS3LHUvJ/2GCRrbfEqRGYKxDCVWoupQ53Kdj+uVlPfp5SSEJt94i72d7LFu8TAu/Aw8FV4aHgJJ3U6VWsgXqId78Lo9KopcJ9SnqZxvy/z3IXu+uJ6d3s3HnZlHN1qYEqEpKZ5Hm/97tnTvuvGF+XhajVP09VmhQ63L56repA4rOTi4oopVLOqerg9pNXq+osH5FBr3d/e1TmLuhAWdVIXQTA3LSnGTUocOYTAwPv97XTYCtUYpdb9eh3MLEkHADlnIg7EY5kQsO9WLae27tKDq8vDOD59+rTrusCsrvvbF/M2yrX3HIAoDEmGSCS5Vp3V3OZ5rKrry4sXL17UWq+urtbDend3q6W6w9Pnt33frSsU9Y3EJlYJHe28boYAQIEAAD8QnPozjVsIsarmaZ7HqbkkTUhOhzFJSJuLedrN+52adl1c37/aP30REFYpdiEkxFzmeWtWdYgBAGIYVimKIwJE5NAFSR0JWrGcZzQXppR6T3GapiAxMnGgPggQtngaEBChawU3QmNCd1OtjdWXIUOttAexhgBFRSQwBmJED4TrLtHD+zlXisGc0HDK9bDdkaOsVijMDCISkxhgmbPWXLTivlWIsuYyuorEq6srdRvn4ojjON1u75KE1TpFFmDGsw7338Wa+5E9kddMkPMEz1up+SD78XC32zaP9NTsJcRgpqWM4wimQYgAmGjo+yGlFMXVwKzmgq5p6AglxsAIVrOWIhIlpH7oi9dpnK0WMGdkI0JTcosiUSK2IjkwRAxErRi/uDFgkiBIzMyA5At6SWtNa71MpgqkgUUIUkq15lahc9V32+3eCB3YAHM9jOPe3TuC0CcPIYgBL5jabmCAt7e3wzAI0m63Uyt93w9dChKKurm2guRSCmKHiGafrKl9YYs/Wgb1lOt7/2HqC+bhdrsAUZRSCPxiPYz7/eHudjzsGk94ybsXLzZdTxZiYALP04ER+hT6tGl10ogOpgrgjo5oFUsGA2fXKMxEkcnds+UUJcQIACIcU6wta4ooSMUU1ARp6Hs4Fm2rqp/h/baCUG/RLQchQMR5hgbOFIhEpNRqoCFw10Udzayqqrg3E8qFzJABOSWSUF7clVIMsJTSknNackjRj6AHjRdDCASYc018vsMRAPA0De1t9K6F+OMpkWNVwPL6PdcEAKqKhKXMu93d4XCY51lLFhEzdbOSJ9cSCDvhiEjuDBqF2C0yWy1DDEOX1utVCCHPVdVbyaw5AFStMNcZmQgwIKUY+i4CQCkiRMisqhxoNfRZa9HKCHXOVqqXKo5RIjMD01IH5EaIfiwDEBGPkQW0VEAj5g47AMhlqppjlKpqWjnEVZ+AUNVNa4M3aelZRzRyA3D39Xo9jmN1H4bBPI7jOE2TI8RuMFwKx88Rwz7VYrUo8zulxacKab/1/O+5jVZyPc/zbreb57l1eEahb7594rUwoAFYntUq9/1q6PJun1Y9AQ5dzJMPfR+IBSkAKbq5gjbIAnNH5BL6DsBULatqndH6EAK69mkA8lIcW9oTsJiaVcjuVckcmQILNV8UPUQupvgq9OISwWA2dwALIbCgzDTPc0vsUQFHZBFgmqdyqFpyptrFQaRLVEHHOedcdE7d0NoSV6tVTB0ATId9rTW1+G+et1u7W91dXA5haEXCrzxgOEqLd63iu5bA/miQaufmhf/WKRtMhrCfxrv9TrW0rYAG424f0MhN3M0UFNgtIBB7H4QAuxAglyFGM0NwKxXMGcHAtOS5KCJLCMI9IqJDrdlyncHBEjEQOjG6k6FXzXOeq2oKgYlJyI6pXUBUN3cIKYJWEm5dae2mVBWJOQhUK2UG4tQFRgIwEVqteilhylXdkohF47nm8UCpq7WyBjxzM8dxbEJIVRFD13WqZZqmWIqhgrXulXxCG+ZP1EPymQa/Tz1h8zwDQBDK6ObW9wlKdqtMGLqhCxSZsJTNMKy6rpTCgOAeiB0pSdBqLZxQ3faq6EqMIXIeD60fPHIiwNZxxMzMGFOKMc5aT+VhKUQhYQdYmPM4TRlciAEAmY1fTmxUVUaSwG5QSlGYWXohZiQz6+LSgW7FiKkLYTafai05T+MIAIqCACnEkPj2dhtjbFFdd++6rta8Gw/TNHGkJNKyp41vcs4hdR/0nN+vd8TewK6GVyPcb7z/+hjW8+NfC4q/eczpo1PeHM60o7ur2d3d3Q+PHxPRXMfxcBhSd7PbPbh/vX/xompOq/4idQzqWsh0SLGLMnQxT2MXIiP1Q+/uw3pt7vM851zX6+HRoweGMB7m1HfL9iIMIQxdTCmKSOpXU55LKa31L4SAx5Fb6NDEsiMSUQoChI6YgjihwQLj17D0RKidn4i0lN1uN3T9aj20ok4WX636oGHO1SynKCBDJQJzQnTEWgoghdSllOoRyMvMbm9vx3G/Xq8JhSPhsY782Oj2zhDnh5odn4u0eIV1AG7ubu/u7sZxPIzjOB7yOJKalUxmgUliGAInYXZHYGRKISA6mDNgYIkxdjEBICASQAgBhTmIpLj4kyGZGZgjYgohpbTg5KkCQOvjMnBSBQDiwAanCTPMTK3wmhCImghR8BadozO+JyJmdCUAM18QTtwd3RGcwYXRhZJzcWdABiQiR2LA6u5VY4x4BBmGpQV3NrPUBQ6EaEh2CiGaGfCPmlj/VPRWgeTuqmXMo4GeGnDNTBjrnBNTHPohcEIkQ1RCMNdas6OhqkZJREzEAASI5haCdDGQoCEQUdf3OddWRE9E0poDnMDJrCJikMgxACJrVTcEFgRrNZaEJEuUwhEccdEsbgRoL6vODI+DHcHMrJpZrXn5FBwACSEQQmCAkKtUFmYOLIwyQ9FSzGeOKYhMiKWUcmx9GPOcYg/qqNZcoFNk+dPSZyQt2h02wNv2fggBYtWc0dyrBpF14EFYvJI6EiL6PM/VnYFFYowpSCISa41WCCwh9QmI5jIBYoxxnsupWAGaPwyq4ABAKCiMRE7MRGAG7kiE7g7WGsybtDjNYffTUCpzOBqehkitJTqwqiOYWW0+CgE5GDgYeCAGDpECkUiLaKIws+dstbojx9Ccsobe16K9u8NeArEBCzQlAh+uKX4r/chscTJTTsl0Q2gAJvM8W6211sPdHWuOAEGoSzESSFV0RjBEqswonCSl1G9Wm67rmAMatOwRIhOKoyOyu6lbQx5a2MIQEJ2YiQERWQDJDAwciIAR1AARhAmhpa0MABtQ5vGyGdofBAhOqMcgNBEhMyKAK4IhIpC7ObiZ26KU0OmIGEkOKBxC6FSLwzjNQwytPrnVEhTTFugzJzZggxN65L8ptnjNU23SYpqmu922FVi4qmrJ49QxSIhdiFGCuBIgITBxK0Qg5hi7LvXC0R1VHZyQhBhIxJCQQGJopTQcpIFgtrqmdhmNJ5AZiLS14jAxsqOpVgwchA0BHewlS+C5BuRlPABmAncHqwaGhsRAxq1JuKkQaLBa7sDceltNtc65lBIkHTGpAWDBUmo5xaU5IIRxymYA6kh4Qn9z90/bFfAZSYtGDY27BQn0CFBxcbES0xiFGbEaoDMBO6hCEKEQKAgwGXiupcFeiQQUQiZoEx5CrGY5Z4alDUNVzQ0AzJGRwZGIiYOzkTCHAMS15jqpiAixgWupZoYIxw4/b13hi4Jo3R1Jaq01u1k9v01VQ0QHM69mDd1AkKiPKc9qZiVnoFxLLaUUh6Y+5pzdPWBoNa2tqU6N2MCBTnixn5x+fNviNdrv93la5jBYzugujBebtY1jEGEAWGbEMYIDQN/3GCTGEGMgp7btQwxERDEgYgVlCqnvgpk6BCBmbjveTR2Bg3CQXFWYUDggcxAOwZEQXeeJmUNI5mrq7tZUU8kVCczQwdwAl3J87GOP2HrhSwUEJwBHQ60oBOith5kcoVV197EfPZeqVdXyOGcb5ymbd/3qMI273Y6ZnbDWUosFgXF/SKFZyqyqYA6IhPQadxh+IILEq/Qy+P1aXOH0+o333xKNeE9S9D3B1xa26vu+CcOY0vbZs/1+ZA632+deCpmS2eVqyPv9KoZ133OttczCAawChNV6ONTMAM0mdXQWQFTAXBUglxhjTB0z51xbLIGRVRWARKIEVHBC4Ri66CiM4Gpqc601u2NRReSqZl4QnSQEJjNQ025YAZg6Aho4ecNqBDCVxIFXA6d+mg4lz+hVwMlnrKaq0QhA69J1biHFFccpl2ye5zkbVrNStY6HaS4AVB32+xHAmNlq7UO0mknwanNxfXXVML5YEIlff+wfpVbal340aWFngHNwxGCfpumw3ZVpXsqNzAlaNAkYvBluuKAQkoIaUkoJhYMEIuTWsksOzXEQJKKlxA0bO3P11glMKAwArq1wT91dbCmUQ0ThCISsOk2TKrhWR0BsPSxoQI4IwAjuyICAbf40MLq0NUGKLAYAqEJekcAxU5saY6ZugO6sqIoiHXVQ9TDnogv7EjPRguCJiO5YawUlQcIG2XmEoBcRJH8ls/57K5aPYYvX8hofp97aLSG+LEusxwEwLXLX3MejX34cTNoqC44/qGZmiuBoyMxOAABEjGYtTPmWQWJmLWZB2Aacmrt7NRFBYiJxd2QiDogITiks/qfjkhZhZmSqtWq78SNMFhEJCiqqmx+HhqihlUIFrJopGRbHBuuoDu7BdJ5xkBijkc65glVEFBZHdF/wVRzd3UG1ghJi3/WterR1xoqIeYVPSh9T+f2mvnh/Zc276Nw1bS/qcfRoF1PNc0N4b0DrTgjNTWzTQ2CJHMzzDJWUNISAYcFrPj8/HHFCjhb7Efp9KbF3RGTCkLr23aoL0zUjX4jdnRBaQAyZGAkAwRxhiVoIEbS55EgNc8rRUJiQxKECmFcnr25q1qKi1dTRyb3WHGrnbMwYlglb4OCqC+obER07UZabas1k7laPE50/7vm/hz5SWsCrocmPOMmJJ5o5fbZ+S47mlK8SPmF9ALSYASE6wtE/9FfP2cjM8OWACFOwJhlExAAdsZrXqmYgwsyBUJDaPCkHAFsgjeqShCMiQFBTMzNv4S8DNzNAMHNGdDU/9hw6IpIjgRsgAzNXADMrpo6goNUrQCBaJmfVWo2oldXMuU4lm7e5NZmZAwERoQgTgdZF8+LLeFrruvuIVXgXffy5fn/X6JwVGn+0xGlzxk6SQ0hIyJfGDABoGxcXWz7IMWqurZPdHZCo6wZcJtW1nMEiKtQXpBJ0dEcDB2SmoG4NacLdnZCW0hhxmwEbGC8CQOOMRY02iYUAAK6moC2X5tiyFaZqbrocQ2ig6oaArf4D3EIbfOFaawWRJsZa3xRxqLWesCIRMcbYpaR5bmqx8RDAy6DWJ6SPVCLn+xs+ikXOw3NtUdtUwZMvzkvwgdjRTP0Y2rA2zQvRCZ1ekTF2pGVSy5n14+AtbFVrJQlEjChIAOaO5EiIDEDg6AZg3thDa0UANAU3P9q7TACAqkoIgGAAjABurq7kiOKEDl7N1IprZjcBIOF2tYZu4LVWQC+mmnNFRkYGABLyxYKpS5M0gntTJcLYddGYwBURu65r0MTwMfCHv4V+5FTZeW6i9YOICAFiCAROiOwVitZaLbxy57YkqnABxQVk5oacGkKEM4u4reVS2MhUaxZjBGZmdSNbRkc149SPEeXGXZoLa1FXO15tMznbAqO3mFQrhQJzR3Pg9qPg5qVW0xrBEY0Zkag5+L5MWQbRMh12IF2IiExNO4bAfZe2u5EBDeF48FIXyCw5TwDQJtO0FNonBz55J1ucP9bTvwBA9MolvPbpB/ywSDPgW0MpMz958gQRL9ab29tbACDAaZq8TAEJ8ryKg4HHGMCi5TmwoOs4T671hOkMAKoq4iISY+dEtVYHIxQSQkRr9lqMHIRFOuEQgitY1XF/aA8dAdxMVb15N9WZKDQHBLH1AVvRVqiNgAi4oDObVTeHbERAAGQhMnjgWtFcVQGbUMzFNHXRhN196HsPHXFwwCnnwzTnUpvnFZmTLBDEJyXbSei67jQqZdEgaO/qu/k4+jGlxSkv/DKwfyx/Il9iFM2uNITaMD58GUJZwdFNVeXYqgTH3XwSP9aKW0hY2k5FbzDvIsTHQXHH8u3li+am2hBViUiIKr4SL8TjwVPJJ+FxknkGZI5IAOTUUq8GAICmi5d7InAC9EWHqhtam2VHzYt2ZkSShgDfNg8AeFWQBZn1lPA7PaVPSD8mW5xT4/qTv0pEDenMjMmhlVKiMLOYirkSIi71MWpmCkpEwHDyYvi48K1HlGIAAHBAYkJAN4CWy2yIsEDYqjfMarVaAABR0MFdzd3AqlU4TTpaeJraWDE+1qYBmDuQy1LNBagOrqaqrgZq5hWsgi+fMywKBcDUAZ2oGa3N3ZAFI1wIMjoRtBj36RHJcYL3j88Wn8o/Po8uwKumxpKSZlIRM0G1FvJq21SFvZIjYKtoUjWz2goa2tK7a63MwQDAFY/jiptcAgFvJrOraxM9Bc0DceMzMAdzNAdXB2+u4Emk6dHEFhGgl4708rsOMQ5gDvzyI60VSgGtbubagmOwXCioewVjg+axtIJIJzd0aNKlPSI+DvJsMRg/G4nyfrZ413q930v40aTFSQC2G2urLsd6FEJAcBFRZQQ0opxzKTHjMu2HEBjdTAMRAJKfSVQARCylGCMTomrOGVzdvaqGDrkltQFdq1WttYJ5irGFjQicwMzUwKoDBzJ0BEAAOj0vWrBZsDlETRW6ubW1NiQ0r6bVaq5l9lJIVbVg47m26kpWFah6CIjkaooOJAyIiDEGA3dQtcVHhWY5LRthCXu3u/7kWdRPJi0+1Ec9CQA4a2tu1QZBBBTg6BEuT98WcWJtJaClMlGE0YGBT/HNdjwRc+AYOgxCRHbccwDmTqCmy27WZVNqtaaHTF2rq5s5MKjXlopfbAhemC/n7HQs80K0JWwG5OBkruimrrrM2lT1qmiODgxoiK7qoIbFsHBIDNi6y0AWeSkpqLnBy0BAc1ONzay2YqLTjnqPJ/InJi1OVgWexToBgI/s7+4GXt3YzFuFZCufbPZdA0RlcndCIlymCdVaARpToDQI1ShuCASIGBZk54aNbG6KYFGYiJp8Mi1aq9aMhtS6ja0iIQBTq+wFM3NDcPIWPUFGRODWGs7EytDQ2o9RtAWp/wRNDNjUkmpRJKXCyyapVhVAgZi5zfBdxi8umR0zJm6Sw96omP9Uyr3Rj++JHPWlvRrgQjNzNdBFQxcttVbT0rC3wasTkWlFQhYnXeYQmpqDSKw+dywclCurq6oTcyBq0Ke1WrNUqZXtirR8lIEVrdUUHRBZSGIIyIgsLIvLo6rmTsit/tvRwf0oLZw5uCOAoQK4ogM6IGI97gEgBzMEc1VDNC3k0FI0ZgZWm0TK8+TEIabAQkSBxdWIaMqzmbkbAhMgeks0EgD6sSgal3/fNlz3dyN519dei0+cL+cH/cC7eBiPwUpolZAtnFercASAnLOAd7Ef59kdLtebu+dPwB3UwJUJhQIBGjiiOdQKju6IbA5gWrUM/YWz5KJoc+jSZrVi5qx1ykqtlp+9hYEMoKhu1pfjOE657WB2MxYKqx4lADa7om13R6rNlzFwNQdEQULCVpU5zdPC0OjowIgAUFVFZEYoUBVq1nmeZyQPQVIU1IpuXQwOMJZSVIGFkJiFAb1U5hQ5ueuhjGbWDT0z53kmpz72WWu1gszexm0AoBs5sAM4vat+6/3S5UeOcvpZKH0J+hYNxMriTTyYuVnOOcgxZ7BM5QBYHEJ3UDNscUwirKh8nGVtgKBVwYk5pYRLsR0RIRHoIiEQAaeS51rmWloCInQp9B0Kq4G3/BlCq/d2R7fjn+RoUMlan6C7x75TVS/FrEI5JtfMQF29tpw7AKCrGaBVAnStZZ4M0M0IEZiQRYCAm3IkRhQid4gSilWr1d3IlExRDZuPBeBAx/AHwDJmxvRjpcWPQycmPvfBQgh13ocQNNRpnhYARtVctY/xVEaLTK1ij0iEnBEQpfVnnM7Z2MUNzEzBOZAECpQAgMAIiYSKq6ohIFPr9THXYrXGGPsUUmAzy3npCgcAR3BfSkAk0ClSQq8kvoEInahlr04crzmfEloG0KLaoDAddiYmSUkii3QhZESDpbDEwMG1WHFzdAfVPoZcJlPynMs0allJFEBWeAmHYwjY6vY+lj6XWk5EbCD70/4QJVQaS8nTdIBa2d3dY0zHqIYQNsxKJwdhIHBEcgJTNwczU9ecM7txax7XMoKhQ9cpU3IHRCIkQzJXBCDAKEFL27tGgEJsVecy5gqAfAwpejMBHJQsNDv1XNq1QLWZLclbUFg6A0LB3DpZnYhNELgFT29f3GDMaVgN66sYk4moWqlVkQSAjzkwM/OqVXNAsMPemOu4298+Xw9xHS+JcDLFNwWDf2S65LNoCGiiIsbY9/1eti323HLrS48h4sn/bLoGGgzEUuWFQLhMvFMwMyef55FtmQZlZlWzljlPabO+JhJ0Y2bXarUQEQdhhOaati4z16pm8zQ7CLA18PYmM4jdnVXVXXGpDH0ZdDmyCLi3aVEtbYJEBERtnYmIhJtDHglMXac8096JMC4NaqoqAVr9EXpL01QtWQ8j5EMaVmx5vLuZ18Mw9AUdAwMaIBgCGy3NBx8rMH40tngZkDiGL2OMQ+qEONtYSgGAyGKgzBSlZarYvXmJUGsFNYQqSYAwhMAkAFKOyYdWV92CY2ZWylxmtaoBEyCnECWGmsuU5yjBJJRxHveHfJg4CDuWOWupqgXIAQMAEKIwAzWzH6oVIjIEswal9TJkwrDgzmnFxaUyY2bmoKoGiuRIjAAicn25ygWnWvM0VUcegFInIe73B+LixKAAam5Vc9E8dp5XIdzbrBl8vHk+X16w35/NIDYdes4ITXj8Sc1BPUUk4ai5mxIBNM1FSw0hUN/X2RgxsBCzQSufcVWd8lzmjK4IXYIoEWMMTEkATVsUqMESIhGBK7SpYKqH7Z0haUySouYylQwxpS5ALfvd3TyOg6zB6ngY65yNGNAwKIMvux2xFdMu1ZSmbdayu4cYY6hEGIiFXzYNq6qZIiEQtkLUthPaZugoBQJgKkDOhATMjCG06FlD8fWq4ApujHaZ0jriwPjkyQ+Pnz6LMXz9Z1+HGNSBEJp50fwlc6KP4gn40ZXI6QUdwWndvZRspjGwU5x0BlUkJxJsLqJhdchzmadZNbvlQQdkJg4hAgAogRshwCkf7VbLNJeSARA7BiBQSw05ZJ4Z0EoFojrnekyCT/vDPM+SojqxBUIkBkZ3Z2ytydUNfCr5cDiM46iqEkKMsQ8hhJCiIGJLz7eABZ3iMYAGaK2DFrnkCTCsUlQJFgcN0UUMcb1es0QnrHlSNwamGKLiijSCz9vtb/7pn/7pX/91WK//+j/8bYwXunBAS68fLRJo5sUHM8enhFQ795DPdcRbDz6PYrXXDT1Oc2lIucw8zaOZBeYW+OqH3ksex4OZOaG5MweKEZCzOVctOJv6VGrJuh4GV0Pz4nka99P+gOApdkNnbl7z7FpLKTlnMA1MKSVGcK3b25va90GEUpxLRQk1z9tpfvFCAYCEOQYOcnlxNc7TzfbucDiwSAMZ3u12D6+vD+MusPR9j1rHcSTTlBIRSAhtwmJRdSCRICKuigDuVk21ZEd0jk2SMrfR7sIIQgDmZE7V+si/efz942+/u3dx9WdffR1Y4NMh7TX6XDwROPb6hiCpC0FICCyzMglL4MU+LUXHOc/jOI1TnjIzzmVKKcWi4TADEgA1x+H2u23NE5gnCZGb6y+C9M0331xsrkIIu91uu932ff/Tn/704uKi7/sXL17c3d21UT8N4Q8IXzy/rbbMxWRmIDJwBf/v+7/fXF606e2t4KopwZubm3HaW9UUYmAEgFWKIYScaylV1QwIiAHdjw0/Qm7MQlxxqRJlEQAkZgcl8BYZczcoRQj2d9t5P15tLjbX91JKZhZbCfEbrEEfZ1l8DnGLk7G25H4cAguR4FLJsuTDGmJQNW0o4HPJ6kYkqkiOqJBr3k/zNOZqCgDTdiT0iBwDByQBDyxdiMAkIra3J0+eTNP01VdfsSAxsGDqgoPe3D530M1mg+T7w6g1j+O83++nPKtqMc1F51oePHooUfq+lyCl1lKKITF4GceSJwI0FkNU1V2uOecYY61ZwZFYGNwRHA2QCVgQGfVlko+IKAAZQBubxUSMUMuIANNhnJ7fzIfp3vX1g6++6rpOVR1fVgqdXpD/CXoiJ7PrxB8tLVRKMavM3Pp4VRUCUxsFaF5KmXKu1dyQUEjCsN5wijF2alBwPMw3d7v9NE3j3W7ou00/mNmUK7gOIVlXKcjt7e1+v3f36+vrzWYTQmjYZNfX1/v9/u///u+32+3Pf/5zRPzh+2/HKR/mabc77A+HeZ4dAUha+9DNzc3Tp8/Wlxf9MIQQFNBr6UPrOwJVRYdSylgq7eH63qUBIHMQRGGrSwFOFxkMVIs2WI3AjmjLZGZgwCCSGMl0ruCA2+d3ZT8ySr/aXKwvU+rdoVYDFnB6iy75cMMCfnS2OP2JR9BTtWJmTtT6veAY1ai1mtsJA0RErKob7sZiuRJmZCpVC0IFnKpe3LtvqtvdvkyTTxlNxR3Qrq6unj17oqo/+clPLi83w9AhOjOWki8uLq6uLkLgx48f15oR8enTp0+ePScR5lBN1Soxd33s+t6QTkVDx9I9JuF1308jjvvdbjeCmbsLcQihGhCBiMQY2c0Aa62GJiKaS62qjBTJZZkx07qYkJgZ2LHmuexHO4yHw7TphhASdZ1IjCGFGNXdluGYZ/RRDNHoxwdJOikRZjbmGGMJgdDRCc/6+3zp2YEQUujQ1cb9LlfdXF8ecp5zrgWAEEO3WiNLjBLG7W4/Z53mTeqvhlUU0pLVioisVqv79++3KXC11hZ3b+Ntvvjii+12++tf/9rMYoyXl5er1arvVlnr3W67Pxys1Amn6wcP+9VwcXkV+85Ud/MsqVt1KYQQw8XlZl1rzdM0TVOb4m1mLZRCQQRcTB0AvRJBJfeT+3q0sahh7IFahWku8/5uvLvzw9yn4eryOqU0avWl3j2hxOynEGezKH6vFoEf37Y4UeOMYRh0nvzYofuygPasVCdGyTmP87TdH/7bP/3LmMt+GnPR6qa21G0//eHxpu82qR9EYKirlO5fP1wPvVMdxwdEdHV9HbskMZCwuomEcRyB8MGjh1OeDbyUcnFx8fD+I4nB3V/c3uZabu/uxnFf3J7d3AIhS6Ag4IRMw2Z9tVlvhnT/+urLR19sNhsfhv1+v9/uGj43ALQJJEwo0lqbQF1FODEDUDbTWiVgjFGNaq1oqqo2z9M4aqkB6f79q3W3QsRSCJHVQQFJuDVu+0t0TgMg/Fjz4vPyRIgopp5iKnNLCmLLj4JankctdR6neZ4JbDqMNzd3z57f/I9/+Y0iqTVg3lpVW/vZ5bD567/6yz//sz/zXG+ePDZTcFyv1/06Hg67cRwbhzVhYGbzPCNiCMkdv/rqJxcXV61HDZyK6X6/H8d5HrNVB0MG6iR9/8OTb3/4fj/NTkgcOIYU+N7F5qdffvnLX/7yiy8fbYY+hBBiF1M/Hg5IXg0ciRazkhBYq0aJiaOZT8W01gCWUioVAMArgimas4EID4GuLzZgOGlRskp2qLmvpaMBHMhf6VU3NMCPbF7/ZGzxpmcBSzvX24lFTl8AgAZNhCEO11f7eS4OnpGaJkaquaxT/3z3tIxTmef97d3z58+//fbb589uWcO623AM03y4u7szl8vL9eXl5uc///nXX37x6P49cpgePChzDkjqkHPebDYteTEMa+ZgBuv1RTMApzGb5iDp6jKZWdb6/Pbu7m67349VMYb+crDNF5dffvF1Glb/6f/9f96+2CN0EGVWI+Gu30CV3/zzi+9/839++dXDv/3bv/rln/+7ruvGOa9W14aglfa7SQK3AGnJ0/2Le5rrPM3FqYsd9pGEreowbJ7f3pVcI0Cdaz4cNlG+vH+96gM4eoWb7Xio4/UqxMsh14okYicmMACoDaLnA/miVR58RtKiEcfkQupWalH1JVnuutseUG3VD1F458AIKcT1sPri0c/Wq+vVaiBh1SIiFxfri8t1YLm42Kz6lOfxEMTVhr4furA/vGDGE9hljLGl02qx1q8KDWoHEdEF6cuvf3pxb5x34zSO29vduNun0F2sL6vpw3sP/+7f/10lVvSbcVSz9bD+qz/7i5unT548+X6/2/3jP/5TqfOf/fzn9+7dK6UFvsmswd1XJA8h5FxqsaKmXgGJRFwyUmj9S4jcAl21FPVap9EkVMTqyp3IxRA3K0rB5gIA6IBHwBNdLFCzD+cM+AzZou9ilIAOrhXAuFVvVwe1LoZeZM6YxykFvn91ee/y6v69R6vhYrPZhC41LIB+1fd9v1mtUxdAbbe9bTVdfd93MSKVWnOrjmwTZlsurZVWn2gp3QUeLtfDui+rfNjt+9TVyysCZA7E4a+67i//w9+k1bq63R1GF7pYX16ni9tnT588/f727uk4bmst293dMAwxdsfku4MrmLIwC7s6koOau5sVrwVrAcoRMQUulTTn/e3N7ePHGqh3D0DGrEFSSnG97vueiKrbp13Iz44tYowiLAQFMIoQOHtVrV0KUEvVWuZJ6xSjrIfrYbjo0ibFvutS7FKMkSPHGCVy6pgZVds4dffq4zTN89R3XMYFnuzkDTXhcQrYw1LjQw5ea0UiJ1c3ZurWAzOrOoeU1kPou7RaVberUjjFy80Vz3C56n/y00cO+W77/PHj76aSd/vt/ZREWCQimTsACZGxoBc2VAewWgzMrKJVcmWCPkUxePH82Q/fffv4V7+6nzhajSxhGOLlVYxdCAkAtLrpMRnyieizYwswZ0QCZHQFYAIqlsusRDpPZR61zCmwXG7W/bDZXNashBbZIlsMkLoQ+yQiDrXUMuWplAzgFBgA3LUU3e/3pZSu65prQ0SqyhRO3rKfYDYI3fVY2FsMlGMXYzTzvl85MYeAQdwqG5qWw+7mIl2YZ0Adhtj191ns7u7O3bVkRuAQgiy4KUhKhONU3A2aD7HAQSEjacnCAZhqnm6fPX/++IfuYsj3r+d5xq5bhUBdB0St6ufYsX50Q15WqX4kfV5sgWBWC5hSa/KzCmpg7lrNwLUI0+XFivkKGaKklNLubosIiLObm1otyuIAgZlL0Wkap5JFOIXIzGB1f/dimiZocODH7Har34SjpWxHBAvAs4BVZHdv2BUciASJWZJQ5ICBI88lW9Wqk1l1yIj9ap0k3F+tUs51t50QHRGIoVV1NVt7zqMbqlvVasjkiuTEUMaROxJwAQgIQ0jrYXW13nRdl/o+DT2lVJmtzWOWd5Zqfxx9XmwBAIwUl74IB6sIzoxRQiBDSkSQoghHRyNgFrx/vWmra0DOSEJE1rSHeQWwELgLcYEfKqWUUuacUmoWDJijQ+szRcTWaehq2KA3EVXVBVIfL3EzH+Zaq4EyhpubFyGmUBLFwCECUwisUN1rt04sISWOAUNchSjzlIdhDQDohKiArua1lKoZwJCo2RZuWmvFXFAqcfBaGHHo+of37w91/sm9zaMHD4fLS+x7EgbC1ssEDSHIoZ3/pZzwj2eUz44tQghRQhvBhQ5C1LFQH6O7aW69D2pFtSByUERw5pZpaA2HSmjEWLUSQddHQkmS3P3u7m6327VOrzaA2Y8t0WYGru2dpTq4SQ5EM2OUhjEypXnc7c0gBDHoOARkrFoMLXIXYsAUPFsKgmSl7vNcmVFE+qF78OAi5zqPU85TVVPVMo9TyV1auSPVWsy9qpWqeQaZh/WaiMRxNXSPHjyYyb5Y9xfroVtfzIzm6NaaVqEaVFU5Ahmgg7dmFARf6r8/mD4eUu2khuGNBAecBzF/t2a35ZywiNY2Wr3veyy5lFkQSs6Ejght4GcURpYoTOApJQ7SMlhIXB1ymadcEBoiuwMGZmIid5/neb1eNyztBhvS5tkMqw5aM6MZADW1QszIAE7VIDDFLjUcTDO7GC4aQ6EbENRa3I2Iay6mFAKSILO4q1lF5N321g3RMIoEhsBeBXqt4HyYs6oKkjHOBqoKqq5mpLV6IP7p1z+JX9zvNauWYhrXa4rxtmRSGYah7/vDzY1wPNMjrXMOPtrC+NykBZk5wqkl8GXdMzMzGSGSG9JSJcvMVouqAqGpoxGxNxlNDiQsEiMLM7fpy/M0tR71E7TG0WnEFpxudcXN3mwmhS9YnMvIbGXmhtZlyAAKHgCWljKg1k7N5NAAmzSb19ap0MXh5V2esC4azI4uzR3uoKo6F/AxhLlWZQMvlcZR6yykJKKqgjzXUk07CQZUzVLq32pbfHTP8ufGFgAAzCwcAVDV2QGAFFCImpoAAAdfUD+IDKjBv6srmLG3slsHgEDcxSQUzKDONY85T0UAoY11ccAGjYfObeqtNXCLCmqISA7kYN7wbghZEFA4tAaFlsgNRzTIU2soiSA6QjUvrc8VnaDhJ7Xg9HHKhCuYASEzgxkEtApGZtVday1a1RDVIWcfpzmP0vGmSw14cF9zNt2kBISlFElRs2JrcW3kf5oZ1HcRU4gxhZDUoGhFQEImInMlIPMjbFXbbO4sgZgNyd0AGIAIxUkZnFHQCdTKXKbDWKdMDkitcZlPTkczKUSk1X6e6ghbu4eBY2sONQOSI2qXvYqb8BJPEpFbwAqdycUBCRiB3V5JWy1sVBWZXU2rF1V1aJMuFIiQnRAVq1lVi27IMaTeQzSEw5QzQd/3InHMOUkAAMdXxMNHl2bB58gWQVI3hNQ5sVYDARExEzCH1tFHAADIzRRn4cgU3B3buHsRIiYMWKs7ai7mVMaSpwJmgUXLCLi0IJyy9i1F8ppmOS48ITI4WptPioDugLCkoVox0bLpBdraLCA64G4O0NjCDNGpNaahIzmhAahPOc+ljtM8lVyJIHQmcZmzSOJo1YCEh/5ic7kaNhfPx/Gw2263u3C5SSmJiOWsqrjAzp/RRxX3Nvrs2AKRU+q7YRUkzRI4IOEyJwyRCR3dkByJSBruRGqIzIRqQISyuGrIoGDghEYAdMS4KaWILGOrGxxua/uZprmNoWsBrvY+chBGIiEiBPLWd9r+OwMfbsLi1JAIYE0FGaItYCjAEI5ShcwatgqCOyi6es0l5woxxj5K6pViqSYCtZQpzysJl9cXV9cXIfDd48fzjjP6uu84iJ2QQvxdYc6PkRqfGVs4mQHH1AzsvI9BALUUNeHl9pZaleUVVbVleouBAag6AKguQKzEkkIUqCOPXq3MlZGEOcWYYhTiFrQwB6tqVV1tsSZgsReABYBaFT96AwZuMGlERA0omhDcHc0NW5e0E8PSRobsCgCMyOANp16xYSgtyC6EwERCpMghhoSpKxByrUBxKnW7H0Mf02rNKU3TWIpm0NW9qwcPHrSitWOIs9HHtwyd02fGFq3JrmU2uxS7ROBmpagKooA39H90QIZW16pe23gOU1BQ9wVEhVAYXUS6rjOp2zs20zmPm3XXBeklBo6EaNXVa6uHav+3coCWOTNT4N40uzbQBIZFTSC/JEQHtdqAb1qtFyISCoWOzYEckepkgIsGcXIHbDCxWWs1VTd1aMYsqhqYUIpQpjqWcae8QsSqfrPbeegAfXN9fX3vAUmYtHobzImtIutY/t0GcQL8yA7quysr3k5v709BiylM467r4oMvHty9+GE/Hi5SHC43hxcvIgM5M5EAQnEotWDtV4NpdgTzNpDHrWXjCZ2IEnPirONYDxlGEeiD9BIThmAQjZnDXDTnPJdCRITUBhIrWowunbjPVjIFHOIGOc5zUTdGyXNhdgrAxsjgAEYEiIkEHcDAwBqPgpqDAoJqsVLNq6pmLVPVuWpWm7Xu5zyWvOn7LkVnzYfJfZx3YIfDl5fDz7/6upOw3e5n453B8ODB6t4jTCsKHbsWb4OyGqzbYnVS4w//yAaSz05aILoEEpTVahVSOuzvxmwE4ITekmeG3nYgkoDXXBzNMRwHG3ubhnlqZW5jZFULEWDkEEKQEGMUEUQ2BCIWCVUBAKpVraZmIsJBYoyTzQCo85RZUqQuimMARDyi4SAjERgSaAG1l+6GLzYpQLNV1cANTc0VVMHNQc3V3RFIJIAjYq1ZZ5/2u0BJiKJqIEK3Wus0l8NcKPVxvYn9GliqQwP+tRY0gQVNsoE/NjnRgp4fSp8dW5RS3IyCNCUy51w0d7Tku929urmBQKt9w1IKNDhGpgVWi4F8mTlupY5FD7t9zRkAQgggDFEgigrNYNiANAPjAiZvxdXBgZBFJEaYCwFY1Wk/mVK/WkURJ0QnAzdQcKQllIvqJy/U2sr4af6LORyHV6A5HBGkG2gYozOSq83jeJjy3d3dqlvHGMFPYyJc1dRsdXVxcXk5bNYt8YvChKim+EkBnj8ZW7xdKcCH1RL6AvSB1S2ldHV19bTrDreHTBAQAcjaOAj1ZtEhEJo7YAOOcjdkAm2Ti8zd55K11t3tXR4LOqFQQWeGzEAOptWJoU0EEHZwMzRCdzJGQzJARBQJAJTnXIqaOayQJQpJsQLmgBVJ0KGaeVU4QxV2dwdzq36Kh7QA6+mFu9WqDVTJas3zgv48zaMzInahDzFSwwBlSil1l5fX19fr9VrBixkDU4N3fUMq4Ac+/HP67KRFkORYADzE7uEXX93d3nxfMuQJVM2rtefs1gaEuTvzAnZs5oTupov3Xq3lo+Zxmg6jqwYKLFzRK0ElqHwsjUZ0ZCB3IDBB0ZbjqaZjnq0YCBKhm03jXHP16v16FUOH4OwAjqjuaNQQkEz9CMcDtgDCuXubGQMtLrYESFra1tEVl0B4BQMEiCEQYGDpui7Gzh3yXMwxdt3lvethsw4pai3wcpYGAAD6RybG3qQ/vLT4QFPU3Z2wFCXGi4uL+/fv3z754VBnVWcAd2yodg2bEQ3bdCAAJCA3cDCvDgBGpZYyTYc8TloKN+hvEiMwYkAmZokdIoKzu2upLRBBJO6KSGaGBUtRgBxCIBT0Oh3GJWWTAAWZmYDB1dXIPCDVI6Kvu8NL+VC1VtXiqm289hL2ABBiR1MwIVIHBIsSRCRId3FxMfQXMcZcSymFgPsuXVxdxhgdXsZV3azF8u3oui8ZlvY8/22YnLmWFMUAstY+yLBahRRh23IIjgiAQIDuDRLJFduMOzRXAHLwFuybD/t5ng+HQ55nAAgsYOiqkMTbuGThGCMze8Vaq5q6gpuBGjY0C8CG6D2P2RW6ocfU3c13h/2W0EucU9d1Xeei7l5smaGEDRTL7TQhxk3dzUpdwCrc2kArbHtp6QezttdNjRgkhMurq6urq67fmFnJtar3fbq8d3+1XlemWqsTMLO6my3pa/p0M3I/O7YAgJh6APAyt4kQKSUJIc9zK2xuj97OElTo1FCqWiq5xR3ncZryPO0POWcR4URtwoAkaajs5CTEwkHNFJa0GRS1qoIkgoLMRBQp51yLCgpGQsR5nA4ONWZ3ZQJ2UdVSKyESMzAtcySWaLo2sHrzevzTT2jM6OD1CPALy4xtg4KIwzAMq03XDXOpxWdQTathc/+au5irqhsRE5GponuDXPqEEM8fD+58fhmICwb26YCTzfWh4PUhxWmatJbIst0fQtf98s//8tkP34tEQWM3m0vOGdX7FEIUre6quABDowFozXMpaJinGQ2HNLh7HrOkOGzWtRRFzFzmOHlxMxeUGDomwhBQTXOZy2TKqG5BxnliEXe8vb3t+/7BvfvPnj/99vtvHz58GKLUIKVkkdB3HZhPeTZ7mbJyr27mdeloQkRG8mYkI4oQuriyg6oujfkORCGyxK7rYoyh72YYx21GCZv79zfXV7NWY0JABfc2VBHRjiqJlhqtD13V1+lzkxbkht4cxFbx0AYKdWnOuaXDFhhDQgVXdTJ0MzqDBa61ain77UHNRCIRzfO8O4yhVCSedApDZCN2ojWth42q393eovk4jnmaRWQ1DCLiWsb9IXR9MS1lRsQ2zKbrulU/3N7etl/suq75Fq90TDkA2jHL69CAcVzBj0C7iC8TckuGxRGsRV+IqOsiBZlK3u52IOHewwcXD+97EH8rjsUnFBQA8PmxBZyeLzAhM5OHLvV9n7e71kbj6oRIAKaQvbAKAjggGRqaVa251FxA6zCsNutLR3j8+MnNzd3hcJDIX/z0i9RHV7u7uc1j9ktzx7u7u3E/5ZxVi7uXOtdahy5tLq/KzV3bi+vNcEkXsUu9DeuLzXfffeOuAAZwkVLvWoUDx6BWANHR3Jb4hLubm1V112V6jhu4N+gOImjHNVZpmHwUBJmK1t003x52q8t79758tLq+nLVqkNd44NPPB/jc2MLbzEEEOAKgtuyDhOCEXgxUwayNhTH3khWRCBiIFBzMGyK4lbrb7YhI+7WBH6b89PmzH75/MuXxyc2zr37y5RcPvxSRLRzu7naIXGuNHO9222fPnjx+9vTJ9z/c3d2sVquHDx9+/bNfDMNwfX19dXWVUh9jVOvW62Gz2eScD4dDjFEkAoCCkkvzO5uoQHvFqjCzNkqEjniy5vVUUurY8HqRCFppoBpm8269uXr0YLi+xhTzdPjUA2XeTp8XW5yTOerSPUdEAo6txxvBHQkczaqZEwXBJVSx1LZ4dVjmgpZSSHi1Wn311VcxdON8+Pbpt4cyHg7Tw4cPu7Taj4dqAEDzPD99+vTu7g4ZHv706y/lJ4jIFLphtbm8vPfwwdX9e7HvDAGZu9Xw6NGjFy+ejeM8jmOMXYtIes6K5uRkAE1ImLUZR3g0ld3V2qVaaUA2xbSatfoPbVMQmHI1ZN9cXFw8eHDx8GHsuwwG0gIlyyM6lxPn3PL7i4/Pki0IzRbANcdlQMRxsgY3M16XCjgwM0NUNF82pLbIwcOHD4EJkAxwtVn/rB++/snPq9eH3//qhyff/+u33/z6u29THHApL6dnz55dXF/99Kc//dnPfvbll4/WFxsRQifPPnT9MAypEyQvJZvXGCVcbnKe5rnM8zyOIyI6g2mRLpotPcLnMU1chmgt2NBLYAPArKoWtcJBkE+Ds6Ga9iFd3L++/+Wj2G9m0LmqvxSjf1j67NjCwHmJPC6DZIg5hOANxJAJgUyd3NEJEGtdploTulVtwBgOUN2gmppVcwNEEmQJRD//xb8LfZhL/c1vfrM7fCciLB0RPfziy7/8m7/5u7/726t71wCGTByIQb78+uHiVkCtNdc2PArAENKQ+jGN4zxNU4yRkBWM1aAViB5N4LOY5kIEBgiIpIw5T0VrVY3trgEa41CQzdXl5fUVMo81K4IDFPPAAK/amG/BRYJ2wR9PnxtbWCt18ePoISIEEeHojuhMZGAMUBfuIS+mAOyA5OZWzQqAO3g2DSGELrJjNQRkQ3K0aZ7/7Bd//uirn/3mN7/54ekzN0TmWuvf/Yf/5Re/+MWXP/myxQBClxChTHlWg6ruemwFEzNzh1JNpOv7Vc7V1VyNAiKRux4RWhTOHPUmN9xb6IURW/WGWkutujuCE4KaI1T0brW+eHB/fXV9KDaW3A0DB/G5wB/A7zinBYz2U53u1RqhlygXH3QL6EBQGVhB56l2Ephwe7fbXN6bsq1iOuwPqLqO0Tyr5ZpLos6tAjAF0oK1Ggfu+2RIyEGJTcGh5VsRIAisnLp7jx7+7Jd/FWKnqvtpnqaJOFzce8BprWbFaq0oIXCKbhSFAK3WWsqsaggJydVAJA49zIdS5tnmytEkxINmA6c28sEAydVcW68PAAC4Y9YW10IDd47VQGIqZQYi6XsD7zfr4d49GoaD4QQoqa/qXqcg4q1y8IzO/zhPQTSAWHX7iFEBn5m0wDa9w2kZ3uFuxBxi7MAZgGLsoGYzM6uAGGNE9WXEk2n1aghEboyOZOyA6G3eFCEgI1BE7rvVenW1GlbMPJcscyGU5lZITCFFZnFHMyTw6g6gLXykSEaMYERoDSCRJXYJzMy01sqBkF92UjkoHFF+3M3tPNCHSy+btUS+C0KbYuaISkDCzmzE4GhABK2JzMDe3kJ4EkvvSk59EH1mbPESao0Qyd0dnIT71cBBzCyE4GCaZzcjwBijTwpo1awNdAEwZIFWC+wO4IANkoAAGRGTU8cUAdiNDNA0MkEMNU9lPJTU9SlyCGqG7syECAYG4AYt4+lo4OgYyd0gSloPZpbnacwzREI5mx8GACd8hNbJeHanZqZuurSc46mRqX3Kx7Fq3obbtIC6mr3s1ntHG9/x0+Ud/Bil85mxhS91vKf0YAVjCn23Wq/Xu5vnR0vdGwAjgAGaN91u1d1JmIIgkRlUdcNKjG6t3r8KCrtBrXUaixsyEUAnnCSU8eC11GkPuWdCM0VEpigiDg3F14Hcl+ScpVXSkqGCUMI8zVPRalC5S935lj1FM9v8ZH+V2iRoM2vbYGEgQPIFd2VxWI6+bjUDfLlkr3HGW//0jzI9PzO2aBrRABDw+IKIMIZ79+/fPH1MAGSG7jHFopM38YC+PEAEZuJW8gqetbqjAAFx9VZmXZPE4B4QIxG3aSPg5tAHKaZecp1GdlNTajjOpNrmIJoamKEZmoN2IbSCOUDEQC4wW8EyksoJrxOPA1DcvYHtnPxSOA3PbWMKmahhIwCesKTd3Y41w4auqs0pP+e507/06gDRlx99VAbts2OL0xZxBGRyhxa6uPfwwT/8d69mrCoAMXZ1mt2diQip1eUAODCpmdYyF5/nYo4dsMeo1d1dGANhIOwDDUOMXXLDwzzNJQ99dCBmJjSoRQgZgVXn/VygLleEaK251OrWK1hFB7AKAePQl3leCiPOBte2mzqGKBY6f9+stSDgaS1PvFJrNVhaVxhBSzUEh7et/dnTO8mn32cVPke2aGhirQwbAdSNwC+uLpGYANDQbekJE+QgwIBoxWDBKqm15loOUz2MMwC5Q2fcMLbdwUPNRfcHcHIgZw6AZlYBrEsphGDg4CbA5G5l0jpX1zYeBgAUvNZarZZSUpAuxsAUJdBmGNG3223L47dVaSvUeguWaPcRUOWkJdGWNiQCPBkljTO01DboExEBoY05gpeQri856W0661iE8VH88TmyBZxh/NqxqKVLAwmzE4BareBEKCFIQEBEURTVrNXBc61jnrfb3WGayYOQkAcAYiBzqOxzKdvtXXfYXebrfr1CJmLYbg+t6aNWM5sbwEapc0hipXopVUs1LaY556J5v99vNhtaDdR1XZ+6ONhctra0LJ+u31/6pa8EN1+/a3+5+5tp2Yo0FFRVqRLy0YJuzayv0kmYnf48V2EfsQofg29xvn6vmTm/P7kCo5AAAKgBHmMAHMP19fV8u615JuJaqzCnlMo4hUApJUT0eTqM4/6w30/j48dP9vtxPpQU0vXVw6uL60BitX6P2a04QOy79cXl5vJytVlLDDcvbr/9/hsi2m8PKaUvv/jCSkWHwOiqQIiCyKQl7+/utvvdr37z65/+9Ovw9U+4WnXs+36I/WbYmNnSqHi2cVtnEQC0IdgAkHNuNd+11tVqpXkWkauLy2e3d+Nh4lWZpqk3z3nejeNmswGgnDNza9h/3bxoZ24vzhkCEU9myukJ/y7s8tlJi9eozfZkh9R39x48+H63B1gSjNye6WbdFIfCXGod5+luv7u7u9vv9/Nh3t3tX4z5u3/5BhSseq358rJXr4AYutTYYlivQoqEXGtFgCc/PNasD+7dDyFs+s7nLEQhMAZR8N14eH57s93vvvnm1y9++LlN+S//8i9lcyGOJJGv7724u22gjqdN3FrNTnGFkyA59byjLmvWqgznuaRS8jznnB1Dm+nqBoIUQxjn2o5+jTMa251EBRxjGCeJdS7AzsXYaxu7/fn5sUXLhiLA0plvrQ2HhR9+8eV3v/q1OcYY6zwF4SOENpuQhJqS9WpzLWa26lY167Qd757dvnjyfLfb5nFS1b9/8ZgABKBfpX5z16+ecQgkPI7TdBgji5Z6sbqwKT978vRwd/tgtQFXADBCDExBQJiE/4//7X83s/Hu8Oz7p2zU972ISAxd10mMLYkDLXfX2OJY1ntarVaD0ywJZhbmUso4jrm0SfFgZhxZRLRUUxc8Gl5vkxbnL47YH60/9qiYzrD3T90sJy55eQZ3+BzZ4lVyJHQwMK12eXnZpCJzLI4xdEwwldqxhNgpeFXvTDd+2cc07ifsTGN/welC0q5flSmr6p9H6dbdvXv3rh7c31xdhy4Bk7trtXEc+5QC8mbYROJ/+O9///jbby66vhVNOVPs0nCxubh/3a1Xj7784te/+c333z9+/PhxjN0wDH2/AnIHlBgbBKzrS6fjvHwLzkS9lmpmfZdijLmUWqs7ljnvdju/uRkumSW4u2pF8DYrz8+imacXZi/rvk5GDCIq0WvSAt4wUU9mzemwz50t7JhKrm6x64b1at7etrb0Jiq1OlIQiVQ157v9OGspYOhWqQK5DTGky81VSHWubVJYv14/uLh/7+rh5f3rfrUKKSFzjJ2VGkSe//Bk+/xun/cX3F///C+8lq5P/XoVukRBMAVOkVIY+vVXX/0EOW4P26pmgGo+59ytu7MA5eIREFFdzEA6rR8cMZmAIMaIiNM41pyr0e3t7X/6T/9pfe/RT3/xl1/97GfdMIQQyLSU8hou62vLeSI/Qoue6y84Y4tzExXPoiyfqRKhZarl67H/EIJWefjw4XTzIu/2AbGFjRGiG7YOdkdGZAQmxqvNhc/FxupQmINH0znXrM4iMUQOtp/2cFOn3PVDjHGfb8dxDEi7F7f5kDsJa46rdR+6EFIIXeIYUBiiUAwYhUS++OrrzfX1r7/9ZrfbPb+5NSIRPlkM535H+5eZCaEpiGZz5JzNLIgQ0TRNd3d3OecKsr+5+b///v8D/fov/ua7//U//sef/bt/d33vUkTKXIB+C1zvKUayhNFejaHBWQQZjkLr5NAiYitf+uzY4k0yBHKQGOa9P3r06Pm33zx7/qLvOzPT6l2KAKLqRNJ1nYNWYc0z1ALEjtURCJwIMQTjsFptgASJFUAPeZzrHGcRMbPDdjfEIVH48ov7l+vNvJuQATtUciM0BALkhriZ4lgyp8ip21xcGRJKSN1wfX05lgOcMumqDUqlea1ExPSyDuPEFgBgZvO43263xNLF7m47Hg6Hb37z3eMX20n1brf763//l18+uA+nEuI3n9KZEDotPDboBHvV5AQARENDREMjIid3cqTWGaPwWbKFAS6G53KjzQglLtXWm8vYDUWVY3BVIOhXwwniKDArSzHL09QxAxHG0J6GCEUWoYDIMXap6yiEpYqaEJFTSuXqerNa17mCOQqni35zcTHi7IE4RhYBwgJWVOeSV6uVuQPZ1b3L2KXduHt++3zMh+t7l3Bki6Jeas21zqVEkTbHGUwBEBq+d9FqHhzMbJ7nOufV5RDW67sCX379k189vfvnf/2Gh/8HOV2s1xdDLyJISwrOAbDFR5fu05cOhTugt+m6DojkL1XMyQ05d1NPsg1gEWbvZIt3BSRec3jef/BHUcOagWViRGs8d6qKse83mw1GuXxwb7ffsZU+DTd3L+7de3CxWavG3RY0zx0H7gcrFVohXUSSoE4ZsAJ7VaWaBrm4vEbEnHOK8eLyap5nILTjLzaROgp5vDAyc8ruDSrAEQQZ3bVWNEophMtN6GSeZ0Crc7YzF6OoGaDE0A0DMZs5sZjXqqWUagYhrQzgyZPnNY8XFxeGWIv9/Oe/6B787P/1X3+9vkq32/yv//p9kv+7I/rbf//XU1V1W616Q9hv97Hrhj7d7XdL3MJPJoK3fd9Agl4hBwBgYgDwlq03Q0c0RMSWUfrMpEXLbCxJP1suzxuSgEtIc5m++PKr59994+SORMxksOC0a4VWoe/acJwXnEMCRyZAR2ZAJ8gEs+vkmUGqKWqd8pRVtZqCo7CkDoNAqxgNaE5upqakDgB8LC2ipSMRly4yaLl9I0AgOB9dbEDFFBEJUB1bvmMBmtYiIg3urU8JQ/Ru060uf3K5/vkv/uK//fNvym588uTZEMM3Xzx8cO/+gy8eZa2lqAillBCs1toF0dN2woat5vDe1kM7djSdQqLn8uNj2OJcCsEfIND5VjKzFMI873/6sz/7h//6/5t33pxABtaa5wnhmBNx91qzWQUAQibEpbnd3QwCk4JPtcg8BY7qmqvrdGCWrLU6CKK7Mbi7z1ZxNj2W6YovgFltSyEuyXA48xJVlQDx+Isv7X81w5ZAR1Wd53me55yzVXQ3Aexjv+4HC8HS0KX+/qOf/M3f/M1/+cdfmfrddvfd4yf/8D9+tVqv1/fucSAzq9VCCKXMh3kahkHL/PoyvTd1emKLc68EPpotzgNk73/zY2ipt3gLnzloS5deXl7eu37w9Ntvw9Ad5mklME2jWSEGMBcCZHD3tnIEDACuoAaqBmrIwcygzDBzFxp8otU89f2gBOaYwaxk92pm1U1HAwBqMSIWbnY7YjUDQkBsLcYNRWtBEOeFKfQ4s/MUacbW+FQXttBSETlASEwNsyADmSMip371s5/9O+YASCihVPv2yePVP2++/NnPvv7Jl40hRBCAaqm11g9F1Hst1nmiFi39mDzKefTj/PUfio7gkjnnGLpq9sVXXzqCOuwO+3kep3E7jfs8ja4zERAhCRm5t0pxJhImYWIG4QpYAWe1sdTR6gxWEIv7WHIFpyAuNGnZz9NUVQHdnRDb/NIYIwfxY7D5PGrZDmgK3o8p0JYKQXc+woDiMhK8zNNU54yuwSwCJAldTMIBgIhikD7G7v79hxcXF9Dqf5jv9vNvvv/+H//5X3aHiUNwwurGITSgWQB4dTURgN6zvm8Gshq11P/H2xZ/HN1x/nPFtJMwTeXhl19dP3y0v73J5vM8grK7mjNBgGP0t5ZCtIgNpCACJku0YIk6A6gZSwOQp6nmwKkBL1U3dOAgIQTGJMzMLCIMzb08TnZhAlpwOaOIQzAztFaWsWB2nYD3RIQA0V1LzfOcx6mUQuruhT0lCSkkCj2hp2Fzff9+3w2XF1c//9kvnv5f/9c05fV6nQ3u9tO//OpfHz56NAxDQ4dl5q6jUvJLcFan91sVp+f52r+NmnL5YGmBb0RP4ROzyCs8flKQ7s6Mcy3qvrrY/Plf/NVUNaRYTNVK69CqtVbNDgpH8GVgAiYUZpGQYkqp67rVMPRdF0QIiIDakhO2SS1E2DIbQxdTlLAahtY8zsztbMsJY5AYmPk00/YEyHjqH2xBzGbTCTEc8d2maRrHseaCAOwuTF1KqVtL7DkNw8X1vYdfkYRuWP3t3/5tSilXNSDiVBS+/+HZf/6v//VffvXromaOpVoThwAATh86Q+Q8gXdOn3JkzSchOzrl0Mqdj2+7q4jknEkCh/jVn/2sOEjXnYY8unuxpTTS3U/j6Zb88pFvU4x9TH1MSYIQISIjEVGKMRADABN1IQ4hBRZ0OGUjm3QFACLiIByEmJFfImU1OkWRT7VYJ/OiWRU1lzrnMmevC/5CkhBiF+IAoUfppd8MF9dzcRH55S9/eXFxISIkgiEpyu12/z/+8Z9/9etfz7maQc5VqxPx7yIhzuk8AntOy12852vtxbn68Zc9Uq9Ul5yH2N7682/Sb7vsl9N/8dj8P+WZgxj4rDZcXPxv//H/eHGzO0z59m6HJA5Q1VK/kthJ7Byg1LoMZEciB0RMKZECV4goQ+j61CWWlnOPkrrYr2KXJAiwAPcUV6nzqq3glplbHLApHUBc1IS1AFcBgK7rKIjTS1+jVasPw9CK+VT12bNnTx8/0VxSjDHGYRiGzbpbX86Ao2J//eDq4deKAZgdebNe/82///ellGnMMXQSOiC62x/+y//zD//5v/73aS4x9dV0znkJuhyzpM1fRnvncz6lWF+zMNrqfGZxizN6DVAypcTYI1ibBZdSun746Prho/GH7+rsakAczNs+LLa0AlODJURyRmYOMQTSNoeEkRqkKzIHJCKRJloICYAQkNr/HBssM0ArAHcAQFhAm05P3d1VDQByzrXW5nwiYrNDGckbjM5ub7UyYDGrubBBFUmrVX95WSsixO7yfry4donViIj6vr9cry9W6y4lRAb3IGk85B++f/Lf/tvfr9fDX/3Fn/dDLKUNYXmlyuvj3EP8PFNl5/UWsMAVGwDsdmOMkQnyNAWkzarfXN/78s9+/g/f/bC/2wvHzWYTIpszkQyDjLs9ERAsLSLEGAJHlthHQUIOzUlBYeFIwsWUmJkDLmkDaG1oFAKQG4L70isIDe4KvBWCAKKruTvYMnci5zyOY601xND3fQqxLdV+v7+5uWnJcVV1sBDC/YeP+otrDbE4xvX9e1//vL+8Pxar6sxhPfT3rq+vLi9Sasn6Wh2AaLvf//0//A8SZOa/+OXPh1WvJQNQa30WFEJybJHBD+OMPxJbfCprtJXlMWPsOihaHNZX9/7qb//u8f/459unz5/fHcxpc7ESMXOMEpCzgGEDSUVjJDYAUkR2QkJEJmAi5pYODSCISCQntsAWkziSv4TfwGZSIMApUW5mrmpmHASOCcw24awBtmuph91+v93madZatdSUuvV6/fNf/mICuZ2LxfW9L39y8cXXiuHu9rERMXBKaT3066FDDoyERONYJMSIPE3T3//3fwQwFvqbv/pLMyACRFYtCnoamPJvpE/kVXppskiSaZoQJYQw1jrv9pHj9f1Hv/zzv949vb27fXHIylMlIstFiyEyEWADmNIKCKak5pM7SRABJEdkAXI3A4upNzzVSRIAkIOCHYG7X2YgkfGEyYrnnceqqorgpRRzb5EMETG1Usq03+/3+3EctdTmJK9WqwePHmLX5f9/c2/+JNeRnAm6e0S8I4/KzDpQVThJAgSvvnWsrWSrWY1sbf7hGRvbNdnuD7KRqW0k9cEmQIAAARQKVag7z3fE4b4/xHuvEiDZre611UwaWFbMzHqZL8Ij3OPzzz93jKY3vnFnvH9bknxZ1BZIGe2dVyKJplQZIdIEAWLHHVFGAySLxerJk296Wa413bm1nykTG9mJDyJCf5JOTrTy/2G7xR/r9uKhTkyilCLUAcWDEGDl2HooHQe2sUUIBFZIihBBIQYAARYlgCxevDIaFaHRlBqlNaUGtAGtxKj4nZAIIzbKUdqR36n+RUQE7ChPLDHB4b1n75l5tVo65wJzhLa89662VVUtptPFYlFVFQVRSHl/sDmZTMZb08USN0Z7+x+Mb9+H3ua0tMvKUZpRIPR1CA44aAJRKrayTLKsLAvnvNJARq9Wq2fPnvlQp3/111vbk/FwoJQKnTITCNH3aG39wcf/nLvFezhucyxM01TpxLEAoUmT2Wxx+uL1P/7TLw+fvSDgPDPBW6O0IdZIIKKJIsQTAS5CCSKkFSZaZYnOUkpSZTRohYqEqOk6EbtWAUpACWJIA3IAkfCOrrYgsEgQ9s7FrJcEJyJFUSCiNiZyOMqyrIqyKIqry8v5fF6tilSbYS8fDYbj8TjLsiozoxu7O7dv4WA4tb7wHFCRIqXEFcDMgKJjaIwYmIkIFbFnCECoSKfL5fL58+ejwfCj+x+oe3ezLPv/MvT/biHn9VFz7cP5O/KyzdsEAcCvPd/8lXMBkcqins1mwTlE/Obp81/+w397/JvfLs7OJ6PhqN+zHCDRuaI6MaNBrhQSECIjESqlkFjYem90cE2PgdiUkEHAIII0R2EmREAGBEGVGGx1XD0LADMCxa8pQbzj4Nh78EG8iAgyqkSlSWI0URBfV3a5tEVRLpa2KOvKmZ4xWT/f2NK9Ua3S8f7djb17ujeZ12FZecREa3S2zhSxYAAEJGUSQRVJEc6FLMk0qaoqgnCSpkhYFv7RoydKmfHGZHszHqlAESF7RmyzqX8gp9rMzB80C/kOrwIA6I9BwBgASbVABQIwUpNs1ImqqiqEYHSKqKz1AJAkWhuwvvG+Wmlnw3w+Xy6L2Wwxm80uzq9Wq7Isy+l0dnx8fH5+flKu8snwuCqOl9PNcrDgam8y3s0nOaFCAZAQnPNeSDyS85xlQy+gGZQyqckaLXmhcrWKaY9I6nHAqFDppLbeaFJGMYtyLviaJYiAAhVsbUvrSudrDpWrC1+4mnoqyRNDiitbu8pXdVguw3K5eHu6KqveYLy9e1v3BpceB/2tD378i80PHxagCi8MkGqPwYUgSnFZrHrD4dXV1fmssEIIQBDb56CtnPdeU5YoUoqCd97zYukfP3oGov78z35289ae93ZVFUqjRgVNZ5MQE6WxjKWtdbsGluIZkPDfJbZwNiAikmDT/g+iq3bOinAblyXGcF055+okTzVQCGGxWJyfXbx58+bg4PDi4ur87LKqqrp2REqRcc5Np9Or+cyCkKKgNSDoQQ/SdFpWq8ODe7t7434+TBJUBAwMIgqNTlk8MHFwITh2Kioro1AvMcpopQlALPsQAosQIlTBKyQCoRAkIDAJQwAX38PeOWdL56vAQbTWSZooQHaWOGBgX1Xzs4uzszMOYWtzR+fDeVHn6fDew0/ufvJZOt4tIa1BefABPAIoYUQWkaAUAKyqqrQWdTNNxihwIRApMoAsghxi2+jU1nxxNX/y5Bsiqp29eXMv6+XWVtZaY5QxCcXGn9475+q6bnlZ16UDwigisfrhjzaLP60LVmcQERSVVuhUKW1rX5Y1ojI6TbVZLWfzxezN4dGLFy9evHj15s3x1dVVWdRJksQKiSRJEpN1NTlKGQLyglqZ4WC0tbVVzmYXZ+d9k4J3ejTMDQUQ6xwBGEMoQuIJPLKFEMEuRFSNuLMPIsLeBe8FAZl0IAjQ6OcpRDQuQBBf1zaEUNeuqMqyssGFaOGIjWSzratqtVzO5rPlsnJuuLGZDoZBp6DS7f3bH3/2xc17H1mdLD0H/B5MWWtd1/XV1dVisYjPOOdMksT+yhgL2CXEk7BS2tva2nBychZCkxK6cWObKCEVEMH70AhDImrdVDd1ddINh158CEGTIvkTdosuTYf8h38CmCQq+LNIgKiHJwwA3nutNbM4H+lwsFzNV6vVo6+/Ojs7efny4OXLl2enF3Vda62NSbVOlJJo3d77sixXq9Vqter3h0qhSElKj8fbu/u35iZZzabnl1O2JTFPhr1UqyDMwRvns5SItCKxGoVdXC8qMcvCkdHGmIhqR2E/Qa3EsJfADhSRRi9sA1fO1tbFap+yLK3zCom0oCFblxhUkLCaL6YX5+VyhajGW7uD0XhWOaXTDx9+9vAnP9++fZeTHFB76xnhvZJlAFBKFUVxfn6+XC7jYnLOaWNIITGKsAiJD9h0dyYmjagI/Hy+fPzoSVmW9+9/tLOzNR4NY1vh5sqIgBSv32UtpONesChCwD/RiXDTvPsP/wREAZA2kcLYtK5saAdR3Z5IzWbzR48ePXr09bPnz1ercj6fl2UpIsakRCQCRVESEaFGxBBCWZbW2hBEkUFARWkv740m25uTG64sUJuL04vVQorl6s7eje3xMFUU4uh7IdLsLbPXWgOh1tr4pKoqZYw3JtalMEZOnqlsLV68ABKBUT6EZV2u6soFX9qyLFeOnVKKEsWGvVj0rqqKuq5Xy3lRVC6wNkZpUwQwveHuh/c//fmf3/zoYVC6CICGWFDgut6L2qMvIk6n09lsFkKIU4iIAtzEZyIQpMXnmwSH9xYQgufT08vLy+nb49M7d29tTSbD4XB7Z3M8HmdZEhdkVdksy0IIgT0AaB2ZAwqVgiD4J8UW/G//KQht+Up8hpAgFsDleS+EsFwu3759++rl6+fPnz9//uL4+KS2wdnQpLi0iSMSgkNQCIj6uoLKGDMkHQIrpdKkNx5tT8Y7eW+odKZNxkCX01m5WAoHCH7YT1OtJU29Z43EAEJC3iBKkmRA4pyL5eGMIXjx4om0IWNYAyOgIm0gSOVDUbpVZYuqrFzpfI0YMEeR4AOjSCq0Wizn83kIgZRKtHFBFtblmbr/8aef/eIvdu586HVaM3idABCjjwbRBfjY8A796enpYrGIhRsRM409uFmYOQCCUkjUrLEsyxYL50MwJkXB1Wr18uXBdDrPs2RjY2N3d2d3d3d7e2s0GvUHeZrmGLsggI7bfxP5AQDCn2IWf2zbkhACKsL2fOUDB2tFQlFUs9ns9evXX3/99ePHTw4PD733ickUZUrFtunBWk8UedTK+2a7895XVVXXdQgBgAylwsroZDgajSabw9F4+8ZNW9UEcHr4ajU9Pzk/h+CHvWQ4yMf9jZQyTSoR8sCKAijIQLGm2geQABC8t9Z6zy4Wl/SSPpFWZNAHZigrP18uiqKonBVkUqwUiPVObCBgALZSlaVzjgEVaUrS/kau88Gdjx5+9PmP9z54EEy2cswqCUQhAJLGVhdq3Y8sl8s3b95Es4hZtzRNi6rgVv4XUREZpRAAmRlIJ0mCbIwxiIionKtn02WR6Ols9fbkbDA42Nqa7O3t7e3fGI9HaWrSzOR5rjUBcMzzEaKGfwfcQghVk5UGaMLgqqqcc48fP3706NFXX311dXUFALHynxmqsjQmNSbVWiI3GsDHKzCTSFOQE89XShmEpkDZ6DzNe4PxljFmPNxACb625Wq5KC2H86mh8cbQb0rPeKVM5tl4H1kzeQAb6yOoieziN4xTVWRBKaNVgqhtzctFuZguFsWql2ZJqkymtBJxzjsb2zoXsxIYtclrHxbWpTrZ3N6//dH9H//iL1V/FJSuGVglDlUU/EywWaiyxrMFgOVyeX5+vlqtBoOBcy62dg4hxHaIzEwERNHDNl41z/NEae+dd14pQ6Sdq7O0H4KrK1+WF1dXs+Pjk43ng14/u3v3zmg03NnZ2RgNjFHRuZMiCAjww6Q9IuqIJ9d5FxHrbEdDAoBGy4c5TdOYFoC1cDrCFbb2Ig4RrbVHR0dPnjw5ODj45S9/yW1fP2lJLiEErXMQdLZBtJRSIsTMxjQdzyP5tk2dY2pMsar7WW+yua10tiqrLOnt3ur3er3dnRu/yZKnj768nM1HgzyE6cnJ2d72rTzvDwaDfNCPjSCW1slsnmVZaevIsdNai4BzznrXR2EgEnKWF7NiOS/ES6KNGRjgYItKFGsDRGJDvXLOWdFJKogeaDDZvnP/wcMvfrJ3915vc9uRqVE5UF7IC3gAVBhYMLJqibrxdM49efKkLMvIKur3+2VZzudzYwxLCBCFideqTwW1MlVVOcDYIDywi5GZSGwGrmPgGYLM58VyWVxdzvJeOpmM9/d3b968ubU9yXMdvCjSKKh/T26iO7qss2+Gg5HztbPB2hKElEatEpVisaqQRJFRGhGUD9bW3npXFi7e0uXl9OTk5ODg4ODg9dnZWTSIKGjXRVsATczFQWKL0O5rdBXfHf+q40FBg82hCApoAcWkJju7k/F4MhoPBoNvHv22XEytrWxVOz5NkqzfG/YHea8/zPM0STKtaVFaz04CCDIKMQT24jEcXpxa59gLBJCAinWe5ikmV5fn7H0/05PJRqa0dSXbQKDz4WC2XK3qcrK1/fGPfvr5z/9s5+ZtSDJHxmMSkLwQr6GNRLGPL8VVEVfgbDY7Pz93zkWCWUfef3deYvK2QVxjbyVsAlYg1KgCthJNEAuKmpSeIDU5pqIo5vPF2dnFzs7O1tZkOBhsbYxVpIl+7yM27+6GvtvilsslEBLpxGhEJRKc57K2ed53ri5rW05Xq1U5m13N58uyLE/enhW1nc1mZ6fnZ2cX0+m0qmwIodfrRT4bIhBFvQJgERJhDoElBNcNARFFQcp2c4rjqZVSwEIILWsXRdADJqBYZGt7d9jLna+B/dHLF7OL86p0y9Jqx2XtF+XKXM21UYQKCRbzpc5MplMm8ZWrgwUvgUQSKW3pKidOxAMFTNGkJtncGO1sbW6N9zRRXdrArCjFNHt1ejHY3H7w4O4HDx48+OTT3bt3ddavgnghixREdatQCYiAIgwS13EIIaRpaq09ODg4Pj52zkU6QQzAlVIsTKi1itjsNRVRKSNNmcy11Ek0EBe6J6NgrEBgCKKUsoGreXFxNXv95rjf708mo9FweHt/X3ethX9oq+g+oFmdRFonLnhb+7g3kAIEpZQ5PTmfL6anJ+dvT47OTi8ur84X81Vd1xfTWfBsra+qylqPoPJskKZpLM1joVj2wxFHYiZxcRdpExTIzCIqLpo4do1RaK21liCIsasYAUBgUUJMpvb1fFUlSLdufxQq28vyg2+fqyS9vLwUDsIOPDJz6UB88MIQeCM1JtHe+2VdLhaLuq6tuEW5ZGCFKtNGodaiSJuEeDDY3d7eHGz0bV0zc38wQMR5bbPxzkdf/PQXf/6Xtz64q9PMAhQ2sFKMxEgMDc8IY6WtsMi1I47L7+rq6smTJ/P5PBL+ur7tRGStTVOlMRGRqOYgDESaiJQ23nsCVkphnPyGSUlR1ZJQxbxhdNpJokUYkINIXfmqnF1dzQypw4M3v88sOvfRbdqIiEFCEEDSWiGKtX52fnV+fjmbXT1//mKxmF1cXF1eni8Wq6oqvGcRATLMHIIIK60UkRZWdRUQDUL0CxyxRgBB9M7XGPktkcwsHEdOKezgF4xFvsoo0s55RImjxghBkIEAqTcYe1sqUls39gmkKopiWaZpOp1OIXgW9sImzdI0MWkKhEbpjY2NNE2Xy2WxJE0YCIVh0h+GEFCCQkq0Hvb7NyZbW5ub9z/6mBkcO8qTfq+f57lnyFz43/72Pw23d7Zu7Eg28NowESCwgG8bDokEYmxFhlkR+VYURWtdluXR0dHBwQG33QXiSojnC+99kmiBRucZhLukBimKK4OIEIEaaQ0JPgBgVNpoEnwCAlhHVXmiJEmzLGdm55x17vJqgSg/GFtYazv7iNQBZg4sLFiV1XK5mk6vzs7OX7+OscLpalWE4J3zIfhIXCJSDBACcCCQOHNaGL1n712SpMwgghhvA5vbsK5CCnStVYsAInDdhuN6J4NOIUqURlAIUfkcRFABEqBSSZJnOoy2xps3buzORsO+LZbFaracL+q6rtgJpxDFa8AEXzExsu2lKt3cAIAQwqC/sVgslouZ966XJTe2t+59cGdvb0+RKcoqH/S3tveEjPVh/8b+vYefbn/wEEwKhCUDW1apQiJp+g01is/YCHhHqJKMMZEAjIgnJyfffvvtcrk0xsTqo44+jYggGIIECLFnG8k1xZwAQwiAEourFTSQRu2qdUQEGsaIQqA4oQhKkTGaEAxinSgCFP1DpO2oEgoAcfe21q5Wq+WqZFEHh28eP37y7bfPLi+nztWRHlHXLmrXEBGRBoh+gL33LCgCJKQAlNKJIpPEXUcAQSIDCoWFQYQIABs7QIwyA9QB+HHbigS6JhCG0H5ox80nQSiq2hByAO8gzwZ3730IwZ8dv/z4wQfF4vLi4mKxWDjnEJFAEMMgz8fDbLIxItpqQUNfFfVyXvSRqjTJsmR7e3N3b2dnZ2sw2nhzfLaxtTHZutGf7DAmKsk+vP/Jnc9//PZ0nvTyJEP24FxwjoEBFUmEjGJjYwFsVFrBe68SE4X36rp+/vz58+fPY9wdHXdssB5zH3HPkICtJ9XxgNptKkjAzHjdi4aRRAAEGRAB1RrhWzXUMgAXOPZ8F9COAxFoZl7Pxnc/jTHWueC4trWr7cXV5fGbo/PLq1//5neLVRnHNFoAM4QgSpn2y4mI7bzPYDhiZu+Ds8Faq5QYnRhjCAOzDiH6VAnOM4fANtGGG6nchiqlVNTTjSyZSIq4rgMWoE4sW5pcXEBE0korYoE6yHhjfHs4WJX26PgwSfvEXpPZ3txRIIqoUcAMYffGzu7ufq/X01o7584vL85PL+7evFMVpUgYjze2JhMyVFb2arq8+8GDdLjhQJUBt/b3HnzyeboxOj69zEdbQlh5YAalldYQGJwPClXH8hJgQUBkRqrrupc0Q7dard68efP27dvxeOyci7FFpII2XDqtURO2h/MIZkQfjQJIAk3dm4TAIoERlGqC3JhkiAgQEa1WZSyliaeVEAIIKkWL2UIb0gIQhIEFCAkUULNsvQ/Lory6mJ6cnr49Pj54/fr1wcH5xZWgBmhsuSl9FELEurYRpYgfjwhACoHjriNBFFHDOxPvnaRG2eDZV4iitQJFdV0752sbJTBRESFGrT2SpgICGIILARGV0mRUACCVFkWVDzcmm1vOuTT1/X7OwWmlEZUossyz2mcm2b738V8Ohr/+b/8nK81hGmrbz9LxYGAInbV5mg02+jd29kbjsQ08W8zzbPjRhw/SRBeLpXMuSTICrGpP2oyzLTIbLuTJeLJzY2+0e1OG40obPe5baSiUsRqZA5BAQiQcX5DIBJTYmRlAJaaqa5Mk5Xz+1aNHh2/emCRx3pskSePxSiRJU2b2IepVNL3b8FppmlmYBLhpoQgGNSkDoiEEZ6vmNKcoplDikS/RKjEaEWyL1iRJRgQwHAKAdoFFAgCRIKO42pZlWVfu4ODg4uLi9evXx8cns9ksMtwRiUWkLcSW5oAkbRAQ415cZ2SFwC39WFraLAhwFaJiN4iIt47FgojRGsREKmWDXYlAzAR4BgCWtq5LKVSkAK0TQUK4Fi+jbiUZTYABgEkHbXQ+zEfuJz/7i1fffFVXPjWcKCoL6xEG/d5Gf9hLM6MSFBJmQpWmOu/nRoPW5FyoKns1Xa4K2x+MJpNt3euno63R7l5/50Yy3BBjLGAA1vgOBaph2bbU/Ea4A9tOazG2JrLWnp2dHR8fx2RKDADXPWOTKyHUSgE3zYgVUhdbxGxqsxsJRO2FEEIHZL13tugCNbiWMwgi1KjhBC+AgICBparKiDidnp6/ePFiuVxOp9PVqohvRUQQIpO8ZxYdcAvtml5/RB9Ba+VrcT+s69IYoxVGPDESdLXWwusK6tCGC51qJHS/N4G6C4YayFURqTV1fmxx5WYHTpMEh3vjH8VD/2o6DXXlvEdCRpwXhRNWaS5ELoS6rskkEiQQLpbVclkwC6ikP+rlw5Hu5ZO9veHmjdGNPTMceqIyMAIopO8Zgt/7iEO3XC5fvnz56tWroigiorWOGHUjgO/2HrhObyFCDDnfzc5D4ztw/cl1WDl+Vvd8CE1HSK11slzOp9P51dXVxcXF4eHhy5cvT05Oi6IAAASlVZKYLLoM75nXiw1/gMDXhb4RruqmB9o13ZkRvKub3175/ZGVVq8ivKNt4r0P3tOgn8ezUrOLROQnxufU8E2898ZEkjfcuf9AJ8nzp0+v3r41WhmBpa03eokow6QgditSWkR8kFVZLJZlWVqT5sONSW9jlA1Gpj/YuX3X9Aaq1wsiZe0dCxljNHj3x1WDMnNVVaenpwcHB5eXlw15HSBJEljTROhWdghBWtoOr41zI7zRsHJUO7xNJ5T3bKIb1WuDawe/MYvj47dHR2+ePXv++vXrq6ur1WpVFEVV2qhDG5qGHdFClTGq9q6bdZD3S9e/OySNUTRmcV3enqapiMSQk4gAFQA45+KZdd3e1+8h3gWRIlJBOPLM8jzPs0wRxUwNsijAzt00uDIzeC8gyxBGo619kzkmQFpOp76qgve1oCtKD1jWFQM555RSLAgA/eHWxqYWpUCn1BuO9vcnu/tpbxiUqaNjj3mr77HnP/xAxMVicXR0dHZ25pzLskzrWBGD772tM6MuiR2bJcZXo+vBtc2ViEQohPAeMtW5JHj3zdCCyACg/8t//q/T6fTk5GQ+nzvn2gWtmCHmqJjjCAcAABTU/9bKxsaKiQCkc7jdbqaaxsDN6lfUSMmAcMv6bF0JAEDD2wjQBBBaawLhACFwr9fLsozaLh7x68XfqY3amjFFEpWUAU1/4/bDT1WSfvv08fL8PE3M0fFRqCtDNBwM+v1+lmX9wUDphHSKSqPRKs/TwcZga2tjdzcfb1YBBImBAJXRMQKA4AD+yCo6ETk/P3/z5s18Psc2+8PMdV13i/jaMtZ0jJqwqx1S35oFtG76u9HD+lCsBy7dpEQ/AgD6l//8Lx2irJQWRh+89wzA8TyDigSh5U6GjNLvVithk6m6fv4901lHRxQ0Sg/v+KN2voWlowG3G8S1lqVgNG1NpIUZICiEfmsWhpSOwumd05FIPm+kCIFQjK44BKB0MN7/4D4ofXLwcjm9UFezACgISb8/2trq9/u9Xi/L+8vCIhiT5IPJ9ub+/nB7GxKzCAyoAJVgI9gbh6QRr/tjDGO1Wh0dHR0eHi6XSwCIUErEvNdn63qHvh7w670JW84btkoKnT3F2KI7l7ab7jsq8et2gw2TVCUcbPA+Mgyi8IsxSUzC+jagiGIg2lAI9j2D+KHtbt1E2u1OEDHiDB1c1k49Nysbm4NM92q0neaW4Hr3i9ZMpOL5+73hgDUdo+vvqZQNkqSZDd5WdjjYuP/ZF2maPv3db/PxRFVJQtifbGbDMSAtCjsrnIjZ2d+99cHd4c627vWcAsvgALQ2jCSM6MWJaKREg9ZQVH+ETQDAYrE4Ozu7uLiIPXZj1jTPc2ttt9V1SyieLxCvaQ/dBKdp2oWcXU6DY7cevI66oI1X4l/FIfruXqKXRSEiDEBaRyuKkvyBGYBImUSZaF4sYl1AYKSWMgrXNFFrnVJKqQYmlwahS1ARc+fPFCISUHw1IlbNFbCJOo1OuyC0Kf8kJMK6skmSJCYFgODFIyOpNE1d7ROlE6UVNBtsy+jhiPYopWKhWCzdrX0goSTNyZhAHAB3bt8aDvtf/fY3Z8dHV2enx5eXq9rmaZYkiTbZjb2bex/c37l9y5EULpBO4kA5YGm6JpIGJABmcO4Hpz9Nabms45xxy7eu6/rk5OT169fT6XQ9h97xN7nlu8SbEmp6K7ViWfD+GhCJv2OrrNg1G4hpWG47XsWKGGNMrBnpdIab2KKTCu8+JoYSiAqu22J1CF2s3e++zfubG3fl29fLFLjtOd5sDO+6oCbewVi2ICy+LQZuXpX2JKKUItWqAUWU03Fm0qghEY2g23Jp7VjWRTRENByOUAEHBkBt0jxLIDVE9Nd/+7fPv3ny+Msvz9+eTFclmPTGjd39m3dv7H9gsr4FDEhotBdEpMRoG0LnLQSAGyUNYBT8vqMI83Xfl3gyZOaiKCIMX9d13OQbO26d5vooAYAQOuc8R4+vEK/3VIn5tjVbiRfRWsfEerxO5yaaU+Vau2/E62SkXudT4Ro28J4ba6+L6zHDuk1EXy5rYkIYlWS973CLxq013bkak2r2LoxftyEVIkVQJn6dhiD/nllEHzfsDVKTpCYxSiskhddK99hqZ0X5xO78bpQCElvZZVEJ+0yT6eckMr6x++EnfrS1VSxXWZZt3ry5e++eyjZqD9ZznvUTQ3UIkVWKkeIXE3nYkMV/T7gZQjNETUs6pay10+n0+Ph4sVhIh8URdXv7e+Mcbct7H7syE1HUcGoH9TrAjL90e3Y8pnZTTN/pb01rndWaA+q6a2nNIgoTr5tqZx+IRIDXbTI6i1Eq/tW76FOj9ICtV2uOtRJTYt01EVuzaDbA5qUmrdokhbuTRVNRjiE432lkNXbTzj2tPbA1CyLi4DwwCSulsiTLUuVsuVwVR4cHXFsrQlkfAzApr4zXpvQeKdEmsQDghRkAYzrvupIqiABKYyg/aBbhGoZCJKKqqiKyaa1N0zRJkm45NYf2tYe0YadSCoRbJ36NJcpaorUbfJHYO+16iuHd8L8zx/fNIgATRnWdZvcTCAIia2vueguSiDG8Y8LtrdI6ctL+1ftoibRoR8uyaQ3oerwgwuTdPTatEgS1TpROtdZaJ0RUW6dJa1JaNf/WTUEIQa3XzDSPhJCDZ5E01YNeVlXF10+fPH70u3/95/9eFEWxXC7ni7IsN/qDTz755MGnX/zVf/g/tnb20n5a22CL0hiTZQkhBEZGEAmCwAiBJJr297uQd4crTvx8Po9wReSqxUy6iMTwuVse710kSRIXrgOLblXDu8TxbmC990pht2a6v2oD9uuVE68ZwTTdvbXzTO9O9jumF0DUdaJS4B3nd71PdAYoEtZvKcY7CtR3bzg+OkNubridTCJSlBhjYr+nNM211onziTEaGppWd+fdhrF+F90XC9b1ezkiXl1dfPXlrx49/upf/uW/P3nyuKoq7+omGAQ1WxWVyNF0UWD2xY9++uknn/TSNM37qQEUqAubpgkKC2KIiA6gEIfGnL+n5UcX58eooizLiGwuFosYJgNACCFpG1rFIoD3xl/g+mApLQNn3eze+5PusW4W6wd4aLeuzhnFA6lOknUmzvUgcogfE1dtBzAwM0r7v8LXzI54dlpvadMFGfEOQgjehy4Ib25jzWjiFeEdOFxplWDHu2k/q8meAHIIuTJ5kkbdmTXQt70sXJfvMwIBOFtXAMvl/MnTx//66395+vTJm+PD1WrlvS9trZQaDoeDfICIpXWHb9/W//RPl8vSufDw4/s74w2jwFmAwCSAAqGVRhVkBkBQP9TT3BiytqEbxsLr4+PjV69edUuokfxFhIj2rs0ZtLu9CFtrw1px3vVaWssedLFFF1Ks/965p/jOBhpu483mJJInuVzHvRgPkYKq5mtp8bUPi/9FI5DWRxBGMSIRkfdzPDGc4FZFKAbhItFNsESFE2EGhFayLBI4mIWIPQYjjRqVF4YQQpAQQuzgJYwmz5RJtUqUTqLyVQRqr80cmqiQBBAhNcnbN4dPv/n61asXSuRnP/rsx58/WK1WZxcXr1+/fnN8ZMvKqmQ4HPUGg15/A0ifnp4+ffo0S1IDdzcGg0RBfyNjJ6K6/ZKBARSiCP0AmNXEyi0AUxTF5eXlxcXFYLgh1KR4utNpWZZJkqzv8M0UisxXS4gYrtJNToGlgcEj9WvNODr7gHa37sKvdSyxM53IDgQAzR4QCQJxCIhKJ0YhBeE80cxsvRcIsdUEsxcBpbSIdHBZiy5AF2hG4DZujEmSWGuBxQXnXAChNEm1TtrRCQAgECA0NiYNVq+QAmHk7uqIcQUQrVTU5WQB1AZFMbgs72e9vmdROlE6sd5laRqCT3XqvbeuIqM3+gOVmNVqdXE1ffTllxenJ68Pvs3TJEtVVdXjjcF4Mvrkzq3w05+enJ1//ezZ2fnU5L2N4USZfLy1NxhslKvq5bffaoL93b3+IO/388Au8kcCe0XKpAmzlGVtdLoOAnfRelF4Y7RzTS769evXL1++7A8HXhoFGDI6MdoLi7NpL8fYaV1EEXEI0acYY3pZ6pzj4CWQ1loIPUII3pjI5fEi3G4knVl0CLcSQWt9RyWP5Zzt1tIsSADQEFgbg0Y5ABckuACqyeHG9tSBQwxlW88UDxTdP+zso7PuaJ7e+1gcFBlWjW5ykihlWnuiEJwwBuHOeFOVEkrT9kGhauOl0AB2iohANap4hBq1IWWQojQzYGxiD8nh4eGdO3c2NiaxRKyqqmfPnv3m178Kzt/a31H0QbWaawgW/OLq8uLi7MFH95Ne/7OPH/zFX/4v55fzr599ezVfpPlw0B8NNzaJYLVaHRwcWlvt7++neZrkSbxlo7S1djlfaK0Hee7t9yeMiCjunFVVXVxcHB0dRTFGZRLCRp153Z4i6kWt94w0KmOMCDOGyP8DlmtRwLhbNAXsjX+J8FS3ea/DXNTC4euBF7W8XV3VK1K9xKRKiY/Lt0GoAQKgCEYBwy4xH757y9dnqu5jQkPfi/l7bEAHiofJjt4XmNfyHS1C111z/X5IJfierjah1jrP8yzLYvS+Dpns7u4WReFc3ev1yrL8zW9+8/d///e//tW//vX/+leb48FsNjs/Pd4cD8Yb/b29Gw8ePjw7ObmaTVWa3bh772cf3N+5dfubFy+nV0sOShF476dXs4uz86M3r/b39+/du/v555+y+DhVWikVydPW4/fFmwBgTFxUqqqqk5OTo6Oj1WqlteaWsImI7EOHYvmmQR+0dVYNAtYJ2XSD806stgZ+8NqRNS7paBbUgmbr87UeEQKAns8vQ6h7vZ5SRmtFpISB2Uvg2JB+Ldx750S6bhMiolsV3PjkeoTcxUdKXRtyk8oKKBBkrYCsjUkbMB8R+d0YO95SfMYYMxwO8zxvuK8tmEZE0TcD8OHh4T/+4z/+wz/8Q1mWn3/xxU9//pN+L/vd7377+NHv+qlOjL57++Znn31y695dz+BY3p6e5MPx5198cfvDj16/Pn705dO6rmezWVmuqqpYvlg+e/bs+fP9LMt2drZG42G8xzTV3stqVaZJ/r1mEecIESPgfXp66pzrDweVddfxI18LTgTvY6wQT63x3kMIsXliFzRICwm+B0t2Q9HZAXTq/60VvhMCvrss9Xx+bu2ytsN+f9DvDROTusCucigooQn741wHkBCY1trkddcCaDp5QhsAw1ozxa7neDTTGFfidw5RzZuVwSaDEVUPMKzhY/idI0maptEmoM04x0UQcf7Dw4Nf/epX33zzza1btx4+fPjhhx88+Pgj9u7p06+fPX8yXS7m04tXr18+f/HiP/zt//75j764eftuYX1tbWnrra2tjY2xxuTJk2+Ojg6Xy6W11dnZmQ+2KFZfffXVvXt3Pn54f3NzwhyWyxIA0jT9IcpFPIWFEK6urt68eXNxcRFJvN30rM9oCMHEdFfU++2w/7VsFrRRZGc03aRw2znRex9zH+uAVbxUB3uvz6OINE6kKKfOG+tL722TmgMUaYgQLYU8opNCcr3JdxeK/9vx1tfNggi0Vlrrlj2llUIOjc/jWNnZfN02IwyCEfqWBibnGMCr6yFoFgojtqjc+thFr+yce/r06fPn3yil/u7v/m5/fz/Pc5FI06LRZLwxGed5urk1hhCcr/+v//v/WVb1fxxv3rv/ICDVtj6/ujQm/fFPvnDOvXr16ujoMHKUSIFz/uXLV2/evDk6OvqzP//5rVu3ENF7b8w7yYH1R5yJuq4vLi7evn1bVVX8nvH7d76P2mJUE1kNawnPdsmFrhmFXB8huz3p3fP/On9xzfi+axDrdgkAWsB6z1IyB8fimTlNegopAEVlQmHm2BMSUIjk+9wErJ2C5LsDgyzCLQQSP15CcF1Wt/MXiI0kYkMXRYEILQMozd0QNNETECHG5ubxyh1cU9f15dtzZv70009v3rzZ6/WWy2UIYTAYFnVxdTU9v7iorXXeDXrZZDIJwZdl9ebk5J9//SvT63/08JO+0mVhQxCl6MN7dw7vf3h48PJ0sQCRJMl8bWeXV2manBydPH38FALv7u7mSeqtI518v10AOOcWi8Xbt2/Pzs6YeTAYkFKolDRYpIr98OLdOXAAQC1bPw5UCGE9wRFX4Hv+t3Mr3SbKbRq2wydCI7P3zmbTXRMAdNMCgbkorDAS0WiD0iTH5pOCCGHs+EuN0PV7ZhEfXZTbvdqeR4QUgMQTUWzY2oQ/LI1QTrQJUoBAWikAYvYiEnEzag38PS8owoSU53mXTYhDEJXY0zTd29vr9bI4BFtbW9775XIxHo/fHL1aLBZ5f6CUCijD0WRze7K5uf369etvX7wKqOsAHz34uD/ssZfz8/PNzc1PPvn4d7/77fHxMTSqVlVV2Z/+9Ke3b9++uDj/8suvROTevTta0w9JzlVVtVwuLy8vT09PLy8vI0LAIEopz03pGCnd+XtYC7q79RZCU5r7HiT13s7dun4iopiZi/FWN/FRuGx9BuNLnYPWHDwiEipUqrbl7OpSqyzLMvTBKA2Nxa31Cv++LQHXjLr70iISggcEkSbeCcHG1vIhBKUROcah2CZug4hwaEiq8aQiItBCs7ExByJmWea9L1b1/p27Gxsb0YPmeZ6madQ46/V6k82RMaZxf9elzKp0q83NzdlyYa01aTKZTAbDUZLmRVnf/+RTZialnr349uJq+rNf/PzmzR1X2C+//G3ceJ48+UZEQOju3dt/8zd/s7U1SdP0xo0bgHx+fs7sb968HRt6x/0PYhp4zYsfHx9//fXXxpjRaFRVVd7vFWVp0iQ6lAhOxKFu9g+tqS1mj84lSUwXGyJiC1c0+GkXUrQRfZAmidp4/6aN0tqpBLqSgthiuIGz2GNcrYKxzDn24gJAAG54aD/kMP+tj/eXUBciXL+EjO/S/v7tj/eW1O9/s24fpGPMY5TRWieoVZZlSmulVGVDWVcnJyfOOR20dRWhThKzsbFhjDE6vX3r7mQyGY0mSmFZSm1LayulMMt6k62d7/3c5XJZxE3G2u7U0CUm/v97fO+A/MFR+n8BrKlMF423yEEAAAAASUVORK5CYII=",
      "text/plain": [
       "<PIL.JpegImagePlugin.JpegImageFile image mode=RGB size=178x218>"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from datasets import Dataset, load_dataset, Image\n",
    "\n",
    "train_dataset = Dataset.from_dict({\"img\": df.loc[idx_train]['path'].tolist(),\n",
    "                                  }).cast_column(\"img\", Image())\n",
    "train_dataset[0][\"img\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "087ea1db-01c9-4e6a-a402-8b8a9aa93e8b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<PIL.PngImagePlugin.PngImageFile image mode=RGB size=64x64>"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "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\"]\n",
    "val_dataset[0][\"img\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "f2babffa-91ab-43ed-8312-2ef606f611bf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<PIL.PngImagePlugin.PngImageFile image mode=RGB size=64x64>"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "val_dataset[0]['img']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "a17ef712-5e24-4c38-bd27-fbf34ece6446",
   "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": "8c2e0980-d551-48f4-8b1f-3f9d4ac788cb",
   "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/5000-0.5/retrain\"\n",
    "    \n",
    "    # project_dim=3584\n",
    "    project_dim=65536\n",
    "\n",
    "    # used_dim=3584\n",
    "    # used_dim=16384\n",
    "    used_dim=32768\n",
    "\n",
    "    strategy='uniform'\n",
    "    # strategy='cumulative'\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": "32c7cc29-8267-4fc3-915f-2628006b3af9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5396c1cc-03c9-407d-b4ba-d16f4b56bc25",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "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": 19,
   "id": "7e5b270b-c5df-4b5d-a8fd-2a924a6edad6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000, 1000)"
      ]
     },
     "execution_count": 19,
     "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": 20,
   "id": "d823ef7b-9d53-4f31-ab11-864274554493",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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J80Y9nr8+rJE3tyIZhJFIhEWLlzImjVr8tt832fNmjUsXbr0oPssXbp0WHuABx544JDtAaLRKPF4fNiPiIiInJhGPEyzcuVKli9fzqJFi1i8eDE333wzvb29rFixAoArrriCyZMns2rVKgCuueYaLrroIr797W9z6aWXcvfdd7Nu3Tp++MMfju6ZiIiIyHFpxGHksssuo7W1leuvv56mpiYWLFjA6tWr85NUd+7cOWwC3Lnnnstdd93FF7/4Rf7t3/6N2bNnc9999x32GiMiIiJyYtNy8CIiIjImDvf7W6vPiIiISKAURkRERCRQCiMiIiISKIURERERCZTCiIiIiARKYUREREQCpTAiIiIigVIYERERkUApjIiIiEigRrwcfBAGF4lNJBIBVyIiIiKHa/B7+60Wez8uwkh3dzcADQ0NAVciIiIiI9Xd3U15efkh3z8unk3j+z579uyhrKwMY8yoHTeRSNDQ0MCuXbv0zJsxpms9PnSdx4eu8/jQdR4/Y3WtrbV0d3czadKkYQ/RfaPjomfEcRymTJkyZsePx+P6gz5OdK3Hh67z+NB1Hh+6zuNnLK71m/WIDNIEVhEREQmUwoiIiIgEqqDDSDQa5YYbbiAajQZdyglP13p86DqPD13n8aHrPH6CvtbHxQRWEREROXEVdM+IiIiIBE9hRERERAKlMCIiIiKBUhgRERGRQBV0GLnllluYPn06sViMJUuW8NRTTwVd0nFj1apVnH322ZSVlVFbW8v73/9+tm7dOqxNMpnkqquuorq6mtLSUj74wQ/S3Nw8rM3OnTu59NJLKS4upra2ln/5l38hm82O56kcV2688UaMMXz2s5/Nb9N1Hj27d+/mb/7mb6iurqaoqIjTTz+ddevW5d+31nL99dczceJEioqKaGxsZNu2bcOO0d7ezuWXX048HqeiooJPfOIT9PT0jPepHLM8z+O6665jxowZFBUVMWvWLL7yla8Me3aJrvORefTRR3nPe97DpEmTMMZw3333DXt/tK7rpk2buOCCC4jFYjQ0NPCNb3zj6Iu3Beruu++2kUjE3nHHHfb555+3V155pa2oqLDNzc1Bl3ZcWLZsmf3JT35iN2/ebDdu3Gjf/e5326lTp9qenp58m0996lO2oaHBrlmzxq5bt86ec8459txzz82/n81m7bx582xjY6N95pln7P33329ramrstddeG8QpHfOeeuopO336dHvGGWfYa665Jr9d13l0tLe322nTptm//du/tU8++aR99dVX7R/+8Af78ssv59vceOONtry83N5333322Wefte9973vtjBkzbH9/f77NO9/5Tjt//nz7xBNP2D/96U/2pJNOsh/96EeDOKVj0le/+lVbXV1tf/e739nt27fbe++915aWltrvfOc7+Ta6zkfm/vvvt1/4whfsL3/5SwvYX/3qV8PeH43r2tXVZevq6uzll19uN2/ebH/xi1/YoqIi+4Mf/OCoai/YMLJ48WJ71VVX5V97nmcnTZpkV61aFWBVx6+WlhYL2EceecRaa21nZ6cNh8P23nvvzbd58cUXLWDXrl1rrc39g+M4jm1qasq3ufXWW208HrepVGp8T+AY193dbWfPnm0feOABe9FFF+XDiK7z6Pnc5z5nzz///EO+7/u+ra+vt9/85jfz2zo7O200GrW/+MUvrLXWvvDCCxawTz/9dL7N73//e2uMsbt37x674o8jl156qf34xz8+bNtf/dVf2csvv9xaq+s8Wt4YRkbrun7/+9+3lZWVw/7u+NznPmdPOeWUo6q3IIdp0uk069evp7GxMb/NcRwaGxtZu3ZtgJUdv7q6ugCoqqoCYP369WQymWHXeM6cOUydOjV/jdeuXcvpp59OXV1dvs2yZctIJBI8//zz41j9se+qq67i0ksvHXY9Qdd5NP3mN79h0aJFfPjDH6a2tpYzzzyT22+/Pf/+9u3baWpqGnaty8vLWbJkybBrXVFRwaJFi/JtGhsbcRyHJ598cvxO5hh27rnnsmbNGl566SUAnn32WR577DHe9a53AbrOY2W0ruvatWu58MILiUQi+TbLli1j69atdHR0HHF9x8WD8kZbW1sbnucN+8sZoK6uji1btgRU1fHL930++9nPct555zFv3jwAmpqaiEQiVFRUDGtbV1dHU1NTvs3B/j8YfE9y7r77bjZs2MDTTz99wHu6zqPn1Vdf5dZbb2XlypX827/9G08//TT/8A//QCQSYfny5flrdbBrOfRa19bWDns/FApRVVWlaz3g85//PIlEgjlz5uC6Lp7n8dWvfpXLL78cQNd5jIzWdW1qamLGjBkHHGPwvcrKyiOqryDDiIyuq666is2bN/PYY48FXcoJZ9euXVxzzTU88MADxGKxoMs5ofm+z6JFi/ja174GwJlnnsnmzZu57bbbWL58ecDVnTj+8z//kzvvvJO77rqL0047jY0bN/LZz36WSZMm6ToXsIIcpqmpqcF13QPuOGhubqa+vj6gqo5PV199Nb/73e946KGHmDJlSn57fX096XSazs7OYe2HXuP6+vqD/n8w+J7khmFaWlo466yzCIVChEIhHnnkEf793/+dUChEXV2drvMomThxInPnzh227dRTT2Xnzp3A/mv1Zn9v1NfX09LSMuz9bDZLe3u7rvWAf/mXf+Hzn/88H/nIRzj99NP52Mc+xj/+4z+yatUqQNd5rIzWdR2rv08KMoxEIhEWLlzImjVr8tt832fNmjUsXbo0wMqOH9Zarr76an71q1/x4IMPHtBtt3DhQsLh8LBrvHXrVnbu3Jm/xkuXLuW5554b9of/gQceIB6PH/ClUKje/va389xzz7Fx48b8z6JFi7j88svzv+s6j47zzjvvgNvTX3rpJaZNmwbAjBkzqK+vH3atE4kETz755LBr3dnZyfr16/NtHnzwQXzfZ8mSJeNwFse+vr4+HGf4V4/ruvi+D+g6j5XRuq5Lly7l0UcfJZPJ5Ns88MADnHLKKUc8RAMU9q290WjU/sd//Id94YUX7Cc/+UlbUVEx7I4DObRPf/rTtry83D788MN27969+Z++vr58m0996lN26tSp9sEHH7Tr1q2zS5cutUuXLs2/P3jL6SWXXGI3btxoV69ebSdMmKBbTt/C0LtprNV1Hi1PPfWUDYVC9qtf/ardtm2bvfPOO21xcbH9+c9/nm9z44032oqKCvvrX//abtq0yb7vfe876K2RZ555pn3yySftY489ZmfPnl3wt5wOtXz5cjt58uT8rb2//OUvbU1Njf3Xf/3XfBtd5yPT3d1tn3nmGfvMM89YwN500032mWeesa+99pq1dnSua2dnp62rq7Mf+9jH7ObNm+3dd99ti4uLdWvv0fjud79rp06daiORiF28eLF94okngi7puAEc9OcnP/lJvk1/f7/9zGc+YysrK21xcbH9wAc+YPfu3TvsODt27LDvete7bFFRka2pqbH/9E//ZDOZzDifzfHljWFE13n0/Pa3v7Xz5s2z0WjUzpkzx/7whz8c9r7v+/a6666zdXV1NhqN2re//e1269atw9rs27fPfvSjH7WlpaU2Ho/bFStW2O7u7vE8jWNaIpGw11xzjZ06daqNxWJ25syZ9gtf+MKwW0V1nY/MQw89dNC/l5cvX26tHb3r+uyzz9rzzz/fRqNRO3nyZHvjjTcede3G2iHL3omIiIiMs4KcMyIiIiLHDoURERERCZTCiIiIiARKYUREREQCpTAiIiIigVIYERERkUApjIiIiEigFEZEREQkUAojIiIiEiiFEREREQmUwoiIiIgESmFEREREAvX/AcGF04X2b46ZAAAAAElFTkSuQmCC",
      "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": 21,
   "id": "874a332c-29b1-46fe-bf83-12e7c8f64e28",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 5000)"
      ]
     },
     "execution_count": 21,
     "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": 22,
   "id": "41ebfcfb-5789-44f0-99d0-0dddc7c6f32f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000)"
      ]
     },
     "execution_count": 22,
     "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": 23,
   "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": 24,
   "id": "8fa5fded-088f-45ea-9b39-f7e8657a2a77",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "27\n"
     ]
    }
   ],
   "source": [
    "from scipy.stats import spearmanr, pearsonr\n",
    "f_name_list = [\n",
    "    'loss', \n",
    "    ####\n",
    "    # 'mean',\n",
    "    'mean-squared-l2-norm', \n",
    "    ####\n",
    "    # 'l1_norm',\n",
    "    # 'l2_norm',\n",
    "    # 'linf_norm'\n",
    "    ####\n",
    "]\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",
    "print(len(lamb_list))\n",
    "\n",
    "\n",
    "ckpt_list = [\n",
    "    0, 1, \n",
    "    2, 3, 4, 5, 6, 7, \n",
    "    # 8\n",
    "            ]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "45989db6-7d72-4cd8-923a-bbc516a41805",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1\n",
      "loss\n",
      "0\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(93.4443, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.140 (avg p value 0.333492)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(43.2329, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.145 (avg p value 0.322351)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.0217, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.146 (avg p value 0.320414)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5015, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.146 (avg p value 0.319585)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2581, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.147 (avg p value 0.318383)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7138, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.149 (avg p value 0.315003)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8646, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.152 (avg p value 0.310966)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4384, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.156 (avg p value 0.302739)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1800, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.162 (avg p value 0.289531)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0921, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.166 (avg p value 0.285341)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0471, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.167 (avg p value 0.282425)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0193, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.163 (avg p value 0.291814)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0098, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.156 (avg p value 0.304993)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0049, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.146 (avg p value 0.324695)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.130 (avg p value 0.356817)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.117 (avg p value 0.383094)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.105 (avg p value 0.404402)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.091 (avg p value 0.423593)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9912e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.084 (avg p value 0.435340)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9974e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.076 (avg p value 0.447408)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9994e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.067 (avg p value 0.456006)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9983e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.061 (avg p value 0.459162)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9995e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.056 (avg p value 0.468875)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9999e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.473158)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9997e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.474781)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9999e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.048 (avg p value 0.476043)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.048 (avg p value 0.476260)\n",
      "1\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(92.6400, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.132 (avg p value 0.345439)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(43.1762, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.136 (avg p value 0.335885)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.0188, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.137 (avg p value 0.332547)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5015, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.138 (avg p value 0.331243)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2583, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.139 (avg p value 0.330069)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7140, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.140 (avg p value 0.327270)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8649, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.144 (avg p value 0.321804)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4386, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.148 (avg p value 0.317032)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1801, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.155 (avg p value 0.307127)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0922, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.159 (avg p value 0.301814)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0471, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.160 (avg p value 0.305182)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0193, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.156 (avg p value 0.310583)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0098, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.149 (avg p value 0.319846)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0049, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.139 (avg p value 0.340017)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.124 (avg p value 0.371720)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.112 (avg p value 0.397259)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.100 (avg p value 0.419439)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.087 (avg p value 0.437332)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9911e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.080 (avg p value 0.444956)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9973e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.073 (avg p value 0.450560)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9994e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.065 (avg p value 0.460810)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9983e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.059 (avg p value 0.466873)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9995e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.055 (avg p value 0.471242)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9999e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.471874)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9997e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.472438)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9999e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.049 (avg p value 0.471632)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.048 (avg p value 0.472414)\n",
      "2\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(93.1774, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.142 (avg p value 0.326562)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(43.2109, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.148 (avg p value 0.315005)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.0207, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.149 (avg p value 0.315575)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.149 (avg p value 0.315238)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2584, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.150 (avg p value 0.315174)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7141, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.151 (avg p value 0.311004)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8649, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.154 (avg p value 0.306375)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4387, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.157 (avg p value 0.298835)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1802, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.162 (avg p value 0.289620)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0922, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.165 (avg p value 0.284949)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0471, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.165 (avg p value 0.284989)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0193, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.160 (avg p value 0.297092)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0098, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.153 (avg p value 0.313433)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0049, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.142 (avg p value 0.332961)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.126 (avg p value 0.364295)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.114 (avg p value 0.394237)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.101 (avg p value 0.418656)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.087 (avg p value 0.442506)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9913e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.078 (avg p value 0.448729)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9974e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.072 (avg p value 0.453582)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9995e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.063 (avg p value 0.463522)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9983e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.058 (avg p value 0.468646)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9995e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.054 (avg p value 0.472998)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9999e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.472986)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9997e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.049 (avg p value 0.475077)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9999e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.049 (avg p value 0.476959)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.048 (avg p value 0.477750)\n",
      "3\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(92.5124, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.136 (avg p value 0.339904)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(43.1686, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.138 (avg p value 0.336793)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.0183, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.139 (avg p value 0.334938)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5014, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.140 (avg p value 0.334215)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2583, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.141 (avg p value 0.332212)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7141, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.143 (avg p value 0.328071)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8649, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.146 (avg p value 0.322768)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4386, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.150 (avg p value 0.315743)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1801, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.156 (avg p value 0.303514)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0922, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.295708)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0471, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.163 (avg p value 0.294340)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0193, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.297191)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0098, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.155 (avg p value 0.309962)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0049, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.147 (avg p value 0.324052)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.131 (avg p value 0.358957)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.118 (avg p value 0.386883)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.105 (avg p value 0.408028)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.091 (avg p value 0.428407)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9912e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.083 (avg p value 0.435004)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9974e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.075 (avg p value 0.446812)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9995e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.066 (avg p value 0.454030)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9983e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.060 (avg p value 0.459141)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9995e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.055 (avg p value 0.463982)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9999e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.052 (avg p value 0.468669)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9997e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.469955)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9999e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.470895)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.049 (avg p value 0.471583)\n",
      "4\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(92.8348, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.137 (avg p value 0.336950)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(43.1921, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.139 (avg p value 0.331298)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.0199, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.141 (avg p value 0.329943)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.141 (avg p value 0.329832)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2586, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.142 (avg p value 0.327835)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7142, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.144 (avg p value 0.324139)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8650, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.147 (avg p value 0.318940)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4387, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.151 (avg p value 0.312041)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1802, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.156 (avg p value 0.303697)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0922, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.159 (avg p value 0.296086)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0471, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.159 (avg p value 0.294784)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0193, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.154 (avg p value 0.306297)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0098, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.147 (avg p value 0.319256)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0049, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.136 (avg p value 0.335373)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.119 (avg p value 0.368600)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.106 (avg p value 0.399872)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.094 (avg p value 0.424014)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.082 (avg p value 0.445118)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9911e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.075 (avg p value 0.451183)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9973e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.070 (avg p value 0.452849)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9994e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.063 (avg p value 0.457732)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9982e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.058 (avg p value 0.459503)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9995e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.054 (avg p value 0.463163)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9999e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.465123)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9997e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.465405)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9999e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.049 (avg p value 0.465792)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.049 (avg p value 0.465260)\n",
      "5\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(92.7987, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.141 (avg p value 0.340925)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(43.1847, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.144 (avg p value 0.329522)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.0192, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.145 (avg p value 0.325683)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5015, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.145 (avg p value 0.326480)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2584, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.146 (avg p value 0.325022)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7141, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.148 (avg p value 0.320351)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8649, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.151 (avg p value 0.315186)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4386, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.156 (avg p value 0.306039)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1801, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.162 (avg p value 0.295122)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0922, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.164 (avg p value 0.287443)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0471, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.164 (avg p value 0.289406)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0193, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.159 (avg p value 0.304503)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0098, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.151 (avg p value 0.314476)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0049, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.141 (avg p value 0.333320)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.126 (avg p value 0.365121)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.111 (avg p value 0.397017)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.099 (avg p value 0.423745)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.087 (avg p value 0.442398)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9910e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.080 (avg p value 0.448270)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9973e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.073 (avg p value 0.453242)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9994e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.066 (avg p value 0.461444)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9983e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.060 (avg p value 0.464515)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9995e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.056 (avg p value 0.467251)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9999e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.052 (avg p value 0.467395)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9997e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.469160)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9999e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.049 (avg p value 0.470375)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.048 (avg p value 0.470823)\n",
      "6\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(92.8785, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.133 (avg p value 0.340343)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(43.1932, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.138 (avg p value 0.330414)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.0197, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.139 (avg p value 0.327697)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5016, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.140 (avg p value 0.326640)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2583, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.141 (avg p value 0.325300)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7140, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.142 (avg p value 0.322661)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8648, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.145 (avg p value 0.318325)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4386, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.149 (avg p value 0.309539)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1801, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.154 (avg p value 0.296526)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0921, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.158 (avg p value 0.290424)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0471, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.159 (avg p value 0.290389)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0193, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.156 (avg p value 0.299971)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0098, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.150 (avg p value 0.312535)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0049, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.140 (avg p value 0.333180)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.125 (avg p value 0.365957)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.112 (avg p value 0.393349)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.099 (avg p value 0.416887)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.086 (avg p value 0.437126)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9912e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.078 (avg p value 0.440917)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9974e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.072 (avg p value 0.446089)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9994e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.064 (avg p value 0.451532)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9983e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.058 (avg p value 0.459458)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9995e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.055 (avg p value 0.465836)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9999e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.469146)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9997e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.471424)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9999e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.049 (avg p value 0.472558)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.048 (avg p value 0.473294)\n",
      "7\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(92.4547, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.140 (avg p value 0.332869)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(43.1611, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.143 (avg p value 0.328547)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.0177, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.143 (avg p value 0.328313)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5013, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.144 (avg p value 0.327638)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2583, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.145 (avg p value 0.325884)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7140, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.147 (avg p value 0.321133)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8648, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.150 (avg p value 0.316575)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4386, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.154 (avg p value 0.307661)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1801, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.295626)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0922, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.165 (avg p value 0.290857)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0471, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.166 (avg p value 0.289852)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0193, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.162 (avg p value 0.296943)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0098, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.154 (avg p value 0.309604)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0049, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.144 (avg p value 0.328029)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.127 (avg p value 0.359923)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.114 (avg p value 0.388431)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.100 (avg p value 0.414668)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.085 (avg p value 0.433640)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9912e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.079 (avg p value 0.443787)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9974e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.072 (avg p value 0.455636)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9994e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.065 (avg p value 0.459734)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9983e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.059 (avg p value 0.463585)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9995e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.055 (avg p value 0.465518)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9999e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.052 (avg p value 0.467470)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9997e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.467405)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9999e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.468544)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.049 (avg p value 0.468761)\n",
      "mean-squared-l2-norm\n",
      "0\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0131, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.000 (avg p value 0.501049)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0210, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.011 (avg p value 0.485224)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0257, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.479826)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0271, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.490641)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0475, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.498587)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0653, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.505075)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0603, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.499251)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0564, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.491210)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0470, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.508208)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0322, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.488907)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0239, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.507452)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0148, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.016 (avg p value 0.516957)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.020 (avg p value 0.502422)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0050, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.205 (avg p value 0.215788)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.212 (avg p value 0.206084)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.209 (avg p value 0.212798)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.204 (avg p value 0.221181)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.197 (avg p value 0.234281)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9253e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.191 (avg p value 0.243208)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9757e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.186 (avg p value 0.252866)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9945e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.177 (avg p value 0.267684)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9821e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.170 (avg p value 0.281650)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9941e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.300682)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9986e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.148 (avg p value 0.323013)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9954e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.138 (avg p value 0.341618)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9985e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.128 (avg p value 0.357659)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9996e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.116 (avg p value 0.376457)\n",
      "1\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0153, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.010 (avg p value 0.492218)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0160, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.004 (avg p value 0.504995)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0243, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.006 (avg p value 0.498999)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0342, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.008 (avg p value 0.504636)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0426, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.506426)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0631, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.011 (avg p value 0.511729)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0692, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.502197)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0547, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.500683)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0418, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.519190)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0320, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.016 (avg p value 0.494417)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0239, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.010 (avg p value 0.503317)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0149, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.475817)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0096, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.506558)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0050, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.207 (avg p value 0.214896)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.211 (avg p value 0.213066)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.209 (avg p value 0.218320)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.205 (avg p value 0.221451)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.197 (avg p value 0.233240)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9252e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.192 (avg p value 0.243162)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9756e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.187 (avg p value 0.254831)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9945e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.179 (avg p value 0.268843)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9820e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.171 (avg p value 0.282193)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9941e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.162 (avg p value 0.298528)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9986e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.150 (avg p value 0.318243)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9954e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.140 (avg p value 0.339590)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9984e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.130 (avg p value 0.355010)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9996e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.117 (avg p value 0.373777)\n",
      "2\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0187, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.499912)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0168, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.013 (avg p value 0.496565)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0216, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.505845)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0368, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.011 (avg p value 0.507232)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0494, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.014 (avg p value 0.487232)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0503, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.010 (avg p value 0.482455)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0546, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.012 (avg p value 0.487007)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0569, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.500160)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0426, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.499487)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0319, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.500555)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0235, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.498622)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0149, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.509379)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0096, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.015 (avg p value 0.506904)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0050, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.204 (avg p value 0.216973)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.210 (avg p value 0.211660)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.208 (avg p value 0.220566)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.203 (avg p value 0.228411)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.195 (avg p value 0.240048)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9268e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.190 (avg p value 0.250911)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9762e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.185 (avg p value 0.261022)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9946e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.176 (avg p value 0.274706)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9824e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.169 (avg p value 0.286840)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9942e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.160 (avg p value 0.302890)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9987e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.147 (avg p value 0.325123)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9955e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.138 (avg p value 0.343681)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9985e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.128 (avg p value 0.358892)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9996e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.116 (avg p value 0.375944)\n",
      "3\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0151, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.488371)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0055, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.004 (avg p value 0.494252)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0332, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.010 (avg p value 0.472420)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0438, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.508310)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0402, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.502545)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0596, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.011 (avg p value 0.508340)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0462, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.500003)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0529, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.004 (avg p value 0.479377)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0440, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.491110)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0338, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.503015)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0228, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.011 (avg p value 0.490810)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0148, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.011 (avg p value 0.505417)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0098, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.502333)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0050, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.208 (avg p value 0.217877)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.215 (avg p value 0.203502)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.213 (avg p value 0.207366)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.207 (avg p value 0.217225)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.198 (avg p value 0.233262)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9283e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.192 (avg p value 0.243864)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9767e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.187 (avg p value 0.252345)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9947e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.178 (avg p value 0.268126)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9828e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.170 (avg p value 0.284655)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9943e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.302340)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9987e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.148 (avg p value 0.324221)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9956e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.138 (avg p value 0.342430)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9985e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.129 (avg p value 0.358423)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9996e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.116 (avg p value 0.377754)\n",
      "4\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0271, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.500864)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0173, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.010 (avg p value 0.500871)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0272, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.010 (avg p value 0.490703)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0314, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.483740)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0888, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.497806)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0673, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.499722)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0617, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.501036)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0591, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.015 (avg p value 0.476251)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0425, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.513939)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0329, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.500727)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0240, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.489120)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0151, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.506624)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0096, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.021 (avg p value 0.503870)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0050, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.208 (avg p value 0.212769)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.212 (avg p value 0.208299)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.209 (avg p value 0.214503)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.203 (avg p value 0.224294)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.196 (avg p value 0.238886)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9276e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.191 (avg p value 0.249528)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9764e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.185 (avg p value 0.261086)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9947e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.178 (avg p value 0.276191)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9826e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.170 (avg p value 0.289784)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9943e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.300408)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9987e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.148 (avg p value 0.322289)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9955e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.138 (avg p value 0.341230)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9985e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.128 (avg p value 0.358252)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9996e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.116 (avg p value 0.375532)\n",
      "5\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0213, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.514591)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0127, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.515831)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0209, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.512372)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0434, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.504553)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0481, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.492800)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0651, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.506976)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0676, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.006 (avg p value 0.495245)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0565, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.511916)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0383, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.499997)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0320, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.501233)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0243, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.506931)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0147, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.011 (avg p value 0.504799)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0096, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.016 (avg p value 0.490961)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0050, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.200 (avg p value 0.223878)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.210 (avg p value 0.210403)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.209 (avg p value 0.215624)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.204 (avg p value 0.224772)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.196 (avg p value 0.239118)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9254e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.190 (avg p value 0.251420)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9757e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.184 (avg p value 0.260549)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9945e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.176 (avg p value 0.273526)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9821e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.169 (avg p value 0.287886)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9941e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.301804)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9986e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.148 (avg p value 0.321837)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9954e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.138 (avg p value 0.340461)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9984e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.128 (avg p value 0.357977)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9996e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.116 (avg p value 0.374840)\n",
      "6\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0167, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.015 (avg p value 0.481211)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0136, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.499832)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0249, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.495641)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0477, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.509666)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0474, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.503541)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0641, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.010 (avg p value 0.509087)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0637, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.488732)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0523, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.004 (avg p value 0.497798)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0426, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.502779)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0330, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.521190)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0239, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.495509)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0147, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.484341)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0096, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.026 (avg p value 0.477296)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0050, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.207 (avg p value 0.214120)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.213 (avg p value 0.203992)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.209 (avg p value 0.216131)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.204 (avg p value 0.228501)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.196 (avg p value 0.241748)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9263e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.191 (avg p value 0.251428)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9760e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.186 (avg p value 0.261995)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9946e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.178 (avg p value 0.274846)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9823e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.171 (avg p value 0.289187)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9942e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.304566)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9987e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.149 (avg p value 0.324632)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9955e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.139 (avg p value 0.341369)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9985e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.129 (avg p value 0.357611)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9996e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.116 (avg p value 0.374607)\n",
      "7\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0383, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.016 (avg p value 0.490862)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0111, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.486563)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0265, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.501248)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0422, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.507960)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0463, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.488964)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0642, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.503482)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0602, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.512700)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0555, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.496091)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0437, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.006 (avg p value 0.497754)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0328, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.008 (avg p value 0.509735)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0239, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.498464)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0310, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.491226)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0096, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.010 (avg p value 0.491633)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0050, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.202 (avg p value 0.226651)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.210 (avg p value 0.212190)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.208 (avg p value 0.212797)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.204 (avg p value 0.220797)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.196 (avg p value 0.233924)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9265e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.191 (avg p value 0.239586)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9761e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.187 (avg p value 0.249328)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9946e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.178 (avg p value 0.267595)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9824e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.170 (avg p value 0.284595)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9942e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.301685)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9987e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.148 (avg p value 0.322677)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9955e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.138 (avg p value 0.341194)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9985e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.129 (avg p value 0.356675)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9996e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.116 (avg p value 0.375245)\n"
     ]
    }
   ],
   "source": [
    "# for loop over functions\n",
    "seed_lds_list = []\n",
    "\n",
    "seed_score_list = []\n",
    "\n",
    "for num_seed in [\n",
    "    1, \n",
    "    # 2, 3, 4, 5\n",
    "]:\n",
    "    print(num_seed)\n",
    "    f_lds_list = []\n",
    "\n",
    "    f_score_list = []\n",
    "    \n",
    "    for f in f_name_list:\n",
    "        ####\n",
    "        print(f)\n",
    "        \n",
    "        lds_list = []\n",
    "        \n",
    "        score_list = []\n",
    "        \n",
    "        K = 100\n",
    "        for ckpt in ckpt_list:\n",
    "            print(ckpt)\n",
    "            ####\n",
    "            dstore_keys_list = []\n",
    "            for split in range(5):\n",
    "                tmp = None\n",
    "                for e_seed in range(num_seed):\n",
    "                    dstore_keys = np.memmap('{}/ddpm-sub-{}-0/features-{}/ddpm-train-keys-{}-{}-{}-{}-{}.npy'.format(\n",
    "                        args.output_dir, ckpt, e_seed,\n",
    "                        split, K, args.project_dim, f, args.strategy), \n",
    "                                        dtype=np.float32, \n",
    "                                        mode='r',\n",
    "                                        shape=(1000, args.project_dim))\n",
    "                    dstore_keys = dstore_keys[:, :args.used_dim]\n",
    "                    if e_seed==0:\n",
    "                        tmp = dstore_keys.copy()\n",
    "                    else:\n",
    "                        tmp += dstore_keys\n",
    "                tmp = tmp/num_seed\n",
    "                dstore_keys_list.append(tmp) \n",
    "            \n",
    "            dstore_keys = np.vstack(dstore_keys_list)\n",
    "            print(dstore_keys.shape)  \n",
    "            \n",
    "            if f=='l1_norm':\n",
    "                dstore_keys = dstore_keys / 3072\n",
    "            elif f=='l2_norm':\n",
    "                dstore_keys = dstore_keys / (3072**0.5)\n",
    "            ####    \n",
    "            tmp = None\n",
    "            for e_seed in range(num_seed):\n",
    "                gen_dstore_keys = np.memmap('{}/ddpm-sub-{}-0/features-{}/ddpm-gen-keys-{}-{}-{}-{}-{}.npy'.format(\n",
    "                       args.output_dir, ckpt, e_seed, \n",
    "                    0, K, args.project_dim, f, args.strategy), \n",
    "                                    dtype=np.float32, \n",
    "                                    mode='r',\n",
    "                                    shape=(1000, args.project_dim))\n",
    "                gen_dstore_keys = gen_dstore_keys[:, :args.used_dim]\n",
    "                if e_seed==0:\n",
    "                    tmp = gen_dstore_keys.copy()\n",
    "                else:\n",
    "                    tmp += gen_dstore_keys\n",
    "            tmp = tmp/num_seed\n",
    "            gen_dstore_keys = tmp\n",
    "            print(gen_dstore_keys.shape)\n",
    "            if f=='l1_norm':\n",
    "                gen_dstore_keys = gen_dstore_keys / 3072\n",
    "            elif f=='l2_norm':\n",
    "                gen_dstore_keys = gen_dstore_keys / (3072**0.5)\n",
    "            ####\n",
    "            dstore_keys = torch.from_numpy(dstore_keys).cuda()\n",
    "            gen_dstore_keys = torch.from_numpy(gen_dstore_keys).cuda()\n",
    "            ####\n",
    "            # if f=='l1_norm':\n",
    "            #     dstore_keys = dstore_keys/3072\n",
    "            #     gen_dstore_keys = gen_dstore_keys/3072\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",
    "                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",
    "            lds_list.append((rs_list, ps_list))\n",
    "            score_list.append(best_scores)\n",
    "            \n",
    "        f_lds_list.append(lds_list)\n",
    "        f_score_list.append(score_list)\n",
    "    seed_lds_list.append(f_lds_list)\n",
    "    seed_score_list.append(f_score_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8970c9b6-4694-4c06-b9a9-ec38f5f6b55e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "73ae9625-b9dc-432c-94b6-6cfcdc726a94",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e8258b5b-5a58-45b1-a727-0a8a0a94fc81",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "c08f885c-95db-4cfb-a235-b8ddddcd3a50",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[[[ 1.40099996e-01,  1.45402630e-01,  1.45839764e-01,\n",
       "           1.46363597e-01,  1.46943565e-01,  1.49365247e-01,\n",
       "           1.52195582e-01,  1.56140205e-01,  1.62456485e-01,\n",
       "           1.66062371e-01,  1.67464618e-01,  1.62903470e-01,\n",
       "           1.55694172e-01,  1.46009439e-01,  1.29801585e-01,\n",
       "           1.16992784e-01,  1.04814550e-01,  9.14529595e-02,\n",
       "           8.35874332e-02,  7.59526085e-02,  6.67463552e-02,\n",
       "           6.11347683e-02,  5.60570432e-02,  5.13959620e-02,\n",
       "           4.95937180e-02,  4.84850618e-02,  4.79795695e-02],\n",
       "         [ 3.33492107e-01,  3.22351213e-01,  3.20414311e-01,\n",
       "           3.19584772e-01,  3.18383144e-01,  3.15002691e-01,\n",
       "           3.10966476e-01,  3.02739075e-01,  2.89530719e-01,\n",
       "           2.85340878e-01,  2.82425356e-01,  2.91813628e-01,\n",
       "           3.04993218e-01,  3.24694637e-01,  3.56817189e-01,\n",
       "           3.83094215e-01,  4.04402266e-01,  4.23592828e-01,\n",
       "           4.35339678e-01,  4.47408248e-01,  4.56006296e-01,\n",
       "           4.59161628e-01,  4.68874898e-01,  4.73157733e-01,\n",
       "           4.74781158e-01,  4.76042690e-01,  4.76259536e-01]],\n",
       "\n",
       "        [[ 1.31754833e-01,  1.35731596e-01,  1.36865800e-01,\n",
       "           1.37783291e-01,  1.38590461e-01,  1.40449409e-01,\n",
       "           1.43546526e-01,  1.48094468e-01,  1.55490099e-01,\n",
       "           1.59471762e-01,  1.60244222e-01,  1.55609125e-01,\n",
       "           1.48879270e-01,  1.39148451e-01,  1.23588025e-01,\n",
       "           1.11678128e-01,  1.00079405e-01,  8.74777052e-02,\n",
       "           7.98454906e-02,  7.32299433e-02,  6.45238952e-02,\n",
       "           5.93655608e-02,  5.52005880e-02,  5.14276239e-02,\n",
       "           4.99327534e-02,  4.92135449e-02,  4.84902616e-02],\n",
       "         [ 3.45439499e-01,  3.35884597e-01,  3.32547183e-01,\n",
       "           3.31243085e-01,  3.30069013e-01,  3.27269550e-01,\n",
       "           3.21804385e-01,  3.17031517e-01,  3.07127057e-01,\n",
       "           3.01814068e-01,  3.05182470e-01,  3.10582905e-01,\n",
       "           3.19846461e-01,  3.40017247e-01,  3.71719612e-01,\n",
       "           3.97258916e-01,  4.19439260e-01,  4.37331630e-01,\n",
       "           4.44955971e-01,  4.50559659e-01,  4.60809808e-01,\n",
       "           4.66872676e-01,  4.71242217e-01,  4.71874010e-01,\n",
       "           4.72437778e-01,  4.71631831e-01,  4.72413808e-01]],\n",
       "\n",
       "        [[ 1.41924995e-01,  1.48072525e-01,  1.48784589e-01,\n",
       "           1.48958925e-01,  1.49555124e-01,  1.51420303e-01,\n",
       "           1.53986559e-01,  1.57334822e-01,  1.62072783e-01,\n",
       "           1.64545268e-01,  1.65099024e-01,  1.60243575e-01,\n",
       "           1.52706575e-01,  1.42451031e-01,  1.26350473e-01,\n",
       "           1.13710837e-01,  1.00990797e-01,  8.68660203e-02,\n",
       "           7.83359830e-02,  7.15944290e-02,  6.33931921e-02,\n",
       "           5.84591945e-02,  5.44738007e-02,  5.07486396e-02,\n",
       "           4.93171831e-02,  4.86213959e-02,  4.81941750e-02],\n",
       "         [ 3.26561534e-01,  3.15005017e-01,  3.15574592e-01,\n",
       "           3.15237710e-01,  3.15174499e-01,  3.11003719e-01,\n",
       "           3.06375409e-01,  2.98835232e-01,  2.89619937e-01,\n",
       "           2.84949036e-01,  2.84988609e-01,  2.97092372e-01,\n",
       "           3.13433492e-01,  3.32960959e-01,  3.64294658e-01,\n",
       "           3.94236971e-01,  4.18656497e-01,  4.42505794e-01,\n",
       "           4.48728755e-01,  4.53582056e-01,  4.63522476e-01,\n",
       "           4.68646038e-01,  4.72998433e-01,  4.72986049e-01,\n",
       "           4.75077117e-01,  4.76959258e-01,  4.77750097e-01]],\n",
       "\n",
       "        [[ 1.36131787e-01,  1.38376387e-01,  1.39074716e-01,\n",
       "           1.39512491e-01,  1.40541452e-01,  1.42558486e-01,\n",
       "           1.45609701e-01,  1.49631932e-01,  1.56477976e-01,\n",
       "           1.60692654e-01,  1.62812002e-01,  1.60978464e-01,\n",
       "           1.55044833e-01,  1.46742172e-01,  1.31151506e-01,\n",
       "           1.18362535e-01,  1.05271091e-01,  9.07774957e-02,\n",
       "           8.28751342e-02,  7.48852302e-02,  6.56765721e-02,\n",
       "           5.95124677e-02,  5.54652384e-02,  5.19716713e-02,\n",
       "           5.04179855e-02,  4.95208013e-02,  4.88681224e-02],\n",
       "         [ 3.39903764e-01,  3.36793297e-01,  3.34938064e-01,\n",
       "           3.34214604e-01,  3.32212429e-01,  3.28071075e-01,\n",
       "           3.22768032e-01,  3.15742990e-01,  3.03513828e-01,\n",
       "           2.95708386e-01,  2.94340319e-01,  2.97191309e-01,\n",
       "           3.09961584e-01,  3.24052238e-01,  3.58957377e-01,\n",
       "           3.86883028e-01,  4.08027617e-01,  4.28406587e-01,\n",
       "           4.35004048e-01,  4.46811782e-01,  4.54030372e-01,\n",
       "           4.59141263e-01,  4.63981520e-01,  4.68669078e-01,\n",
       "           4.69954762e-01,  4.70895357e-01,  4.71583040e-01]],\n",
       "\n",
       "        [[ 1.36734849e-01,  1.39446317e-01,  1.40643823e-01,\n",
       "           1.40674363e-01,  1.41677408e-01,  1.44000577e-01,\n",
       "           1.46674273e-01,  1.50528601e-01,  1.55579152e-01,\n",
       "           1.59308938e-01,  1.59246920e-01,  1.53857999e-01,\n",
       "           1.46552730e-01,  1.35937384e-01,  1.19051548e-01,\n",
       "           1.05736294e-01,  9.37535044e-02,  8.18448022e-02,\n",
       "           7.54055144e-02,  7.01441788e-02,  6.29067220e-02,\n",
       "           5.82539743e-02,  5.43022567e-02,  5.13800270e-02,\n",
       "           5.00316982e-02,  4.93450680e-02,  4.89250585e-02],\n",
       "         [ 3.36949608e-01,  3.31297727e-01,  3.29942598e-01,\n",
       "           3.29832361e-01,  3.27835340e-01,  3.24139308e-01,\n",
       "           3.18940143e-01,  3.12041275e-01,  3.03696539e-01,\n",
       "           2.96086048e-01,  2.94783644e-01,  3.06296955e-01,\n",
       "           3.19255872e-01,  3.35372820e-01,  3.68599833e-01,\n",
       "           3.99872251e-01,  4.24014130e-01,  4.45118043e-01,\n",
       "           4.51183393e-01,  4.52849046e-01,  4.57732193e-01,\n",
       "           4.59502647e-01,  4.63163122e-01,  4.65122529e-01,\n",
       "           4.65404951e-01,  4.65792217e-01,  4.65259730e-01]],\n",
       "\n",
       "        [[ 1.40766418e-01,  1.44016857e-01,  1.45100191e-01,\n",
       "           1.45272718e-01,  1.46199115e-01,  1.48424299e-01,\n",
       "           1.51461207e-01,  1.56116310e-01,  1.61612534e-01,\n",
       "           1.64417114e-01,  1.63992139e-01,  1.58809606e-01,\n",
       "           1.51446371e-01,  1.41123932e-01,  1.25520929e-01,\n",
       "           1.11386990e-01,  9.91307586e-02,  8.65641309e-02,\n",
       "           7.97018592e-02,  7.30415946e-02,  6.55917290e-02,\n",
       "           6.03580497e-02,  5.57418623e-02,  5.18819030e-02,\n",
       "           5.01495076e-02,  4.90409680e-02,  4.82923417e-02],\n",
       "         [ 3.40925494e-01,  3.29522151e-01,  3.25683467e-01,\n",
       "           3.26480356e-01,  3.25021548e-01,  3.20351488e-01,\n",
       "           3.15185638e-01,  3.06038996e-01,  2.95122127e-01,\n",
       "           2.87443468e-01,  2.89405656e-01,  3.04503168e-01,\n",
       "           3.14476454e-01,  3.33320179e-01,  3.65121238e-01,\n",
       "           3.97016672e-01,  4.23744511e-01,  4.42398197e-01,\n",
       "           4.48269559e-01,  4.53242355e-01,  4.61443656e-01,\n",
       "           4.64515373e-01,  4.67250505e-01,  4.67395134e-01,\n",
       "           4.69159615e-01,  4.70375234e-01,  4.70822962e-01]],\n",
       "\n",
       "        [[ 1.32608604e-01,  1.38123167e-01,  1.39347802e-01,\n",
       "           1.39703090e-01,  1.40619551e-01,  1.42431113e-01,\n",
       "           1.44706847e-01,  1.48831093e-01,  1.54437229e-01,\n",
       "           1.58030385e-01,  1.59184031e-01,  1.56161247e-01,\n",
       "           1.49794327e-01,  1.40171682e-01,  1.24921565e-01,\n",
       "           1.11762052e-01,  9.90657140e-02,  8.60048959e-02,\n",
       "           7.84926445e-02,  7.20330053e-02,  6.35978599e-02,\n",
       "           5.84343293e-02,  5.45468515e-02,  5.08294751e-02,\n",
       "           4.96675246e-02,  4.87941273e-02,  4.83501260e-02],\n",
       "         [ 3.40342899e-01,  3.30414152e-01,  3.27697391e-01,\n",
       "           3.26639926e-01,  3.25300321e-01,  3.22660901e-01,\n",
       "           3.18325055e-01,  3.09538743e-01,  2.96526284e-01,\n",
       "           2.90424409e-01,  2.90388780e-01,  2.99971388e-01,\n",
       "           3.12535435e-01,  3.33179979e-01,  3.65956960e-01,\n",
       "           3.93349061e-01,  4.16887291e-01,  4.37125537e-01,\n",
       "           4.40917108e-01,  4.46088967e-01,  4.51532345e-01,\n",
       "           4.59457793e-01,  4.65835736e-01,  4.69145571e-01,\n",
       "           4.71424421e-01,  4.72557824e-01,  4.73294374e-01]],\n",
       "\n",
       "        [[ 1.39569964e-01,  1.42852266e-01,  1.43294597e-01,\n",
       "           1.43757624e-01,  1.44512065e-01,  1.46835738e-01,\n",
       "           1.49769896e-01,  1.54015318e-01,  1.60807169e-01,\n",
       "           1.64802249e-01,  1.65850282e-01,  1.61572832e-01,\n",
       "           1.54306964e-01,  1.43681778e-01,  1.27087357e-01,\n",
       "           1.13832131e-01,  1.00065208e-01,  8.54637839e-02,\n",
       "           7.86413881e-02,  7.20324799e-02,  6.48857303e-02,\n",
       "           5.94641599e-02,  5.50566480e-02,  5.19943994e-02,\n",
       "           5.06128077e-02,  4.98224212e-02,  4.92277098e-02],\n",
       "         [ 3.32868958e-01,  3.28546854e-01,  3.28312817e-01,\n",
       "           3.27638109e-01,  3.25883727e-01,  3.21132764e-01,\n",
       "           3.16574967e-01,  3.07661410e-01,  2.95625547e-01,\n",
       "           2.90856669e-01,  2.89852014e-01,  2.96943187e-01,\n",
       "           3.09604499e-01,  3.28028778e-01,  3.59922865e-01,\n",
       "           3.88430846e-01,  4.14667993e-01,  4.33639841e-01,\n",
       "           4.43786706e-01,  4.55636414e-01,  4.59733580e-01,\n",
       "           4.63585006e-01,  4.65517806e-01,  4.67470415e-01,\n",
       "           4.67404615e-01,  4.68543926e-01,  4.68760816e-01]]],\n",
       "\n",
       "\n",
       "       [[[-2.58097319e-04, -1.10914210e-02,  6.87198197e-03,\n",
       "           2.86557196e-03, -1.17791177e-03,  2.68621951e-03,\n",
       "          -3.29687812e-03,  7.89678049e-03,  2.99837226e-03,\n",
       "           2.64897695e-03,  4.87354189e-03,  1.55483222e-02,\n",
       "           1.97689175e-02,  2.05487201e-01,  2.11605059e-01,\n",
       "           2.08773120e-01,  2.03592784e-01,  1.96524671e-01,\n",
       "           1.90890854e-01,  1.85736570e-01,  1.77218937e-01,\n",
       "           1.69805448e-01,  1.60909017e-01,  1.48073667e-01,\n",
       "           1.38267962e-01,  1.28262741e-01,  1.15916149e-01],\n",
       "         [ 5.01049113e-01,  4.85223546e-01,  4.79826087e-01,\n",
       "           4.90640579e-01,  4.98586667e-01,  5.05075483e-01,\n",
       "           4.99251046e-01,  4.91210202e-01,  5.08208105e-01,\n",
       "           4.88907390e-01,  5.07452497e-01,  5.16957000e-01,\n",
       "           5.02422263e-01,  2.15787881e-01,  2.06083957e-01,\n",
       "           2.12798020e-01,  2.21181062e-01,  2.34280689e-01,\n",
       "           2.43207945e-01,  2.52866292e-01,  2.67684080e-01,\n",
       "           2.81649675e-01,  3.00681809e-01,  3.23012898e-01,\n",
       "           3.41618471e-01,  3.57659182e-01,  3.76456537e-01]],\n",
       "\n",
       "        [[-1.00348173e-02, -3.59500396e-03, -6.12823737e-03,\n",
       "          -7.98848058e-03,  5.08317305e-03,  1.14920010e-02,\n",
       "           4.63263843e-03,  7.29530338e-03,  2.92022212e-04,\n",
       "           1.58458027e-02, -1.04674422e-02,  6.48574076e-03,\n",
       "           4.96891516e-03,  2.06654960e-01,  2.11045762e-01,\n",
       "           2.09034866e-01,  2.04874380e-01,  1.97491843e-01,\n",
       "           1.92399256e-01,  1.86969696e-01,  1.79187776e-01,\n",
       "           1.71204531e-01,  1.62310413e-01,  1.49648527e-01,\n",
       "           1.39600386e-01,  1.29670967e-01,  1.17203289e-01],\n",
       "         [ 4.92218138e-01,  5.04995047e-01,  4.98999111e-01,\n",
       "           5.04636107e-01,  5.06426320e-01,  5.11728637e-01,\n",
       "           5.02197146e-01,  5.00682799e-01,  5.19190022e-01,\n",
       "           4.94417150e-01,  5.03316919e-01,  4.75816885e-01,\n",
       "           5.06558138e-01,  2.14896228e-01,  2.13066479e-01,\n",
       "           2.18319602e-01,  2.21450951e-01,  2.33239899e-01,\n",
       "           2.43162035e-01,  2.54830519e-01,  2.68842671e-01,\n",
       "           2.82193012e-01,  2.98528311e-01,  3.18242900e-01,\n",
       "           3.39589846e-01,  3.55009535e-01,  3.73777199e-01]],\n",
       "\n",
       "        [[-1.11427391e-03, -1.26976559e-02,  5.86024658e-04,\n",
       "           1.09929594e-02,  1.37322695e-02, -9.78948166e-03,\n",
       "           1.22793194e-02,  6.06327855e-03,  3.99307096e-03,\n",
       "           5.97751141e-04, -5.26625117e-03,  9.46964772e-03,\n",
       "           1.46215003e-02,  2.03673116e-01,  2.10380764e-01,\n",
       "           2.07866021e-01,  2.02659651e-01,  1.95101245e-01,\n",
       "           1.90121504e-01,  1.85175118e-01,  1.76360813e-01,\n",
       "           1.69231618e-01,  1.60077447e-01,  1.47061649e-01,\n",
       "           1.37564489e-01,  1.28156954e-01,  1.16155369e-01],\n",
       "         [ 4.99911757e-01,  4.96565339e-01,  5.05844710e-01,\n",
       "           5.07232479e-01,  4.87231558e-01,  4.82455447e-01,\n",
       "           4.87007038e-01,  5.00159548e-01,  4.99487044e-01,\n",
       "           5.00554947e-01,  4.98621851e-01,  5.09379269e-01,\n",
       "           5.06903785e-01,  2.16973076e-01,  2.11659527e-01,\n",
       "           2.20565910e-01,  2.28411105e-01,  2.40048498e-01,\n",
       "           2.50910840e-01,  2.61021879e-01,  2.74705853e-01,\n",
       "           2.86839880e-01,  3.02889668e-01,  3.25123417e-01,\n",
       "           3.43680599e-01,  3.58891920e-01,  3.75943576e-01]],\n",
       "\n",
       "        [[ 9.34958127e-04, -3.92466884e-03, -1.02900737e-02,\n",
       "          -2.65247337e-03, -3.25510826e-03, -1.11203522e-02,\n",
       "           2.22342140e-03, -3.86939857e-03,  9.46151343e-03,\n",
       "          -1.50113839e-03,  1.06596618e-02,  1.14322337e-02,\n",
       "           9.08345044e-03,  2.08298980e-01,  2.15498642e-01,\n",
       "           2.12605121e-01,  2.06860319e-01,  1.98310179e-01,\n",
       "           1.92273066e-01,  1.86661157e-01,  1.78307654e-01,\n",
       "           1.69898672e-01,  1.60683149e-01,  1.47757284e-01,\n",
       "           1.38246767e-01,  1.28501753e-01,  1.16224533e-01],\n",
       "         [ 4.88370996e-01,  4.94251608e-01,  4.72420269e-01,\n",
       "           5.08310051e-01,  5.02545439e-01,  5.08339713e-01,\n",
       "           5.00003181e-01,  4.79377021e-01,  4.91110088e-01,\n",
       "           5.03014722e-01,  4.90809669e-01,  5.05416633e-01,\n",
       "           5.02333429e-01,  2.17876995e-01,  2.03501550e-01,\n",
       "           2.07365633e-01,  2.17225415e-01,  2.33262055e-01,\n",
       "           2.43863805e-01,  2.52345146e-01,  2.68125875e-01,\n",
       "           2.84654991e-01,  3.02339831e-01,  3.24220804e-01,\n",
       "           3.42430306e-01,  3.58423126e-01,  3.77753729e-01]],\n",
       "\n",
       "        [[ 4.48139112e-03, -1.02303230e-02, -9.76564924e-03,\n",
       "          -4.81560620e-03,  2.49651683e-03, -4.98046201e-03,\n",
       "           2.16683543e-03, -1.46790987e-02,  6.18506021e-03,\n",
       "           6.95298254e-03,  1.98437483e-03,  7.98808069e-03,\n",
       "           2.13101040e-02,  2.08404730e-01,  2.11965173e-01,\n",
       "           2.09251322e-01,  2.03498116e-01,  1.95552462e-01,\n",
       "           1.90822399e-01,  1.85496940e-01,  1.77523169e-01,\n",
       "           1.70033034e-01,  1.61426186e-01,  1.48402832e-01,\n",
       "           1.38294798e-01,  1.28450996e-01,  1.16398314e-01],\n",
       "         [ 5.00864450e-01,  5.00871169e-01,  4.90703070e-01,\n",
       "           4.83740145e-01,  4.97806461e-01,  4.99721855e-01,\n",
       "           5.01036379e-01,  4.76250804e-01,  5.13938741e-01,\n",
       "           5.00727009e-01,  4.89119997e-01,  5.06624265e-01,\n",
       "           5.03870262e-01,  2.12768522e-01,  2.08298630e-01,\n",
       "           2.14503487e-01,  2.24294316e-01,  2.38885882e-01,\n",
       "           2.49528301e-01,  2.61085727e-01,  2.76190952e-01,\n",
       "           2.89783656e-01,  3.00407901e-01,  3.22288600e-01,\n",
       "           3.41230083e-01,  3.58252156e-01,  3.75531759e-01]],\n",
       "\n",
       "        [[-6.45242103e-04,  2.36632307e-03,  5.07189351e-03,\n",
       "          -5.03260340e-03,  3.41447292e-03, -2.59440747e-03,\n",
       "          -6.46087845e-03,  1.24534657e-03,  1.78533437e-03,\n",
       "           5.17458204e-03,  6.16264951e-04,  1.13312609e-02,\n",
       "           1.63518612e-02,  2.00096077e-01,  2.10478271e-01,\n",
       "           2.08861829e-01,  2.04297678e-01,  1.95912511e-01,\n",
       "           1.89942295e-01,  1.84289014e-01,  1.76356821e-01,\n",
       "           1.68945990e-01,  1.60851989e-01,  1.48195273e-01,\n",
       "           1.38114159e-01,  1.28251569e-01,  1.16249421e-01],\n",
       "         [ 5.14590539e-01,  5.15830917e-01,  5.12372304e-01,\n",
       "           5.04553324e-01,  4.92800080e-01,  5.06976294e-01,\n",
       "           4.95244605e-01,  5.11916469e-01,  4.99997282e-01,\n",
       "           5.01233157e-01,  5.06931179e-01,  5.04799084e-01,\n",
       "           4.90960575e-01,  2.23877837e-01,  2.10403142e-01,\n",
       "           2.15623635e-01,  2.24771562e-01,  2.39118417e-01,\n",
       "           2.51419778e-01,  2.60549367e-01,  2.73525998e-01,\n",
       "           2.87886061e-01,  3.01803833e-01,  3.21837377e-01,\n",
       "           3.40461074e-01,  3.57977303e-01,  3.74839594e-01]],\n",
       "\n",
       "        [[ 1.45469709e-02,  7.37152643e-03,  7.26575785e-03,\n",
       "          -2.04989923e-03,  3.36987066e-03, -1.02055876e-02,\n",
       "           5.91398277e-03, -4.36475971e-03,  4.85384698e-03,\n",
       "           7.53650115e-03, -5.91920857e-04,  6.27827184e-03,\n",
       "           2.58959541e-02,  2.06812915e-01,  2.13324198e-01,\n",
       "           2.09325659e-01,  2.03663297e-01,  1.96021555e-01,\n",
       "           1.91050444e-01,  1.85881920e-01,  1.78005935e-01,\n",
       "           1.70600939e-01,  1.61141252e-01,  1.48849354e-01,\n",
       "           1.38906335e-01,  1.29068922e-01,  1.16452138e-01],\n",
       "         [ 4.81211459e-01,  4.99832377e-01,  4.95641162e-01,\n",
       "           5.09665567e-01,  5.03540832e-01,  5.09087497e-01,\n",
       "           4.88732031e-01,  4.97798482e-01,  5.02778739e-01,\n",
       "           5.21189614e-01,  4.95508567e-01,  4.84341127e-01,\n",
       "           4.77295659e-01,  2.14120144e-01,  2.03991521e-01,\n",
       "           2.16130690e-01,  2.28500915e-01,  2.41747965e-01,\n",
       "           2.51427530e-01,  2.61995251e-01,  2.74845591e-01,\n",
       "           2.89187378e-01,  3.04565768e-01,  3.24632232e-01,\n",
       "           3.41369196e-01,  3.57611290e-01,  3.74607385e-01]],\n",
       "\n",
       "        [[-1.55642434e-02,  6.87030656e-03,  4.55971154e-03,\n",
       "           6.53677876e-03,  2.24815891e-03, -1.68389363e-03,\n",
       "          -1.46430247e-03,  6.80048459e-03, -6.00770156e-03,\n",
       "          -7.69639090e-03,  3.32142812e-03,  9.00183218e-03,\n",
       "          -1.03512449e-02,  2.02193838e-01,  2.09514095e-01,\n",
       "           2.08211414e-01,  2.03760954e-01,  1.95908181e-01,\n",
       "           1.91420179e-01,  1.86607289e-01,  1.78473785e-01,\n",
       "           1.70033376e-01,  1.61009859e-01,  1.48168996e-01,\n",
       "           1.38274669e-01,  1.28922587e-01,  1.16288453e-01],\n",
       "         [ 4.90862177e-01,  4.86562994e-01,  5.01247797e-01,\n",
       "           5.07959918e-01,  4.88963593e-01,  5.03481818e-01,\n",
       "           5.12700299e-01,  4.96091160e-01,  4.97753853e-01,\n",
       "           5.09734678e-01,  4.98463670e-01,  4.91225742e-01,\n",
       "           4.91633234e-01,  2.26651061e-01,  2.12190043e-01,\n",
       "           2.12796956e-01,  2.20796718e-01,  2.33924158e-01,\n",
       "           2.39586333e-01,  2.49328175e-01,  2.67595118e-01,\n",
       "           2.84594984e-01,  3.01685379e-01,  3.22676723e-01,\n",
       "           3.41194435e-01,  3.56674990e-01,  3.75245382e-01]]]])"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_lds_array = np.array(seed_lds_list)\n",
    "seed_lds_array[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "1c1d75dc-93fa-4af9-a3b7-d8a10e56feb5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1, 2, 8, 2, 27)"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_lds_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "018c6e64-d424-4018-a711-eee95131a802",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "100"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "K"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "fde83272-f2b9-4e41-a9e2-0d7b19810784",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('./gen_5000_0.5_ckpt_{}.pkl'.format(K), 'wb') as handle:\n",
    "    pickle.dump(seed_lds_array, handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fb08a31e-97fe-4d9c-b426-370507cadf5b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c4d858e4-8104-45cc-a9bb-36e64765a662",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "00a7858a-30f7-4cc0-a3a7-d132143254e0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "8b050b5f-b8cf-421b-bb44-956399f61fed",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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oc0TgeVPvP3226SkpKDT6ejbty8bNmxo7SKd1Z555hkkSWry1aFDh9Yu1lnp119/5aKLLiIuLg5Jkpg/f36T52VZ5qmnniI2Nha9Xs+IESPIzc1tncKeZf7s2l5//fXH3MejR49uncKeRaZNm0bv3r0JCgoiKiqK8ePHs2/fvib7OBwO7rzzTsLDwwkMDGTixImUl5e3UonPHidzbYcNG3bMfXvbbbe1UombTwSWE5g1axZTp07l6aefZsuWLXTr1o1Ro0ZRUVHR2kU7q3Xu3JnS0tLGr1WrVrV2kc5KVquVbt268fbbbx/3+enTp/PGG2/wzjvvsH79egICAhg1ahQOh+MMl/Ts82fXFmD06NFN7uOvvvrqDJbw7LRixQruvPNO1q1bx+LFi3G73YwcORKr1dq4z/3338/333/PnDlzWLFiBSUlJUyYMKEVS312OJlrC3DLLbc0uW+nT5/eSiU+BbLwh/r06SPfeeedjd97vV45Li5OnjZtWiuW6uz29NNPy926dWvtYpxzAHnevHmN3/t8PjkmJkZ++eWXG7fV1dXJWq1W/uqrr1qhhGev319bWZbl6667Tr7kkktapTznkoqKChmQV6xYIcuy/x5Vq9XynDlzGvfZs2ePDMhr165trWKelX5/bWVZlocOHSrfe++9rVeov0jUsPwBl8vF5s2bGTFiROM2hULBiBEjWLt2bSuW7OyXm5tLXFwcaWlpXH311RQWFrZ2kc45hw4doqysrMn9azQa6du3r7h/T5Ply5cTFRVF+/btuf3226murm7tIp116uvrAQgLCwNg8+bNuN3uJvdthw4dSEpKEvdtM/3+2h7x5ZdfEhERQZcuXXjsscew2WytUbxTck4sftgSqqqq8Hq9REdHN9keHR3N3r17W6lUZ7++ffvyySef0L59e0pLS3n22WcZPHgwu3btIigoqLWLd84oKysDOO79e+Q54dSNHj2aCRMmkJqaSl5eHo8//jgXXngha9euRalUtnbxzgo+n4/77ruPgQMH0qVLF8B/32o0GkJCQprsK+7b5jnetQW46qqrSE5OJi4ujh07dvDII4+wb98+5s6d24qlPXkisAhn1IUXXtj476ysLPr27UtycjKzZ8/mpptuasWSCcLJmzx5cuO/u3btSlZWFunp6Sxfvpzhw4e3YsnOHnfeeSe7du0SfdhawB9d21tvvbXx3127diU2Npbhw4eTl5dHenr6mS5ms4kmoT8QERGBUqk8pnd6eXk5MTExrVSqc09ISAjt2rXjwIEDrV2Uc8qRe1Tcv2dGWloaERER4j4+SXfddRc//PADy5YtIyEhoXF7TEwMLpeLurq6JvuL+/bk/dG1PZ6+ffsCnDX3rQgsf0Cj0dCzZ0+WLl3auM3n87F06VL69+/fiiU7t1gsFvLy8oiNjW3topxTUlNTiYmJaXL/mkwm1q9fL+7fFlBcXEx1dbW4j/+ELMvcddddzJs3j19++YXU1NQmz/fs2RO1Wt3kvt23bx+FhYXivv0Tf3Ztj2fbtm0AZ819K5qETmDq1Klcd9119OrViz59+vD6669jtVq54YYbWrtoZ60HH3yQiy66iOTkZEpKSnj66adRKpVceeWVrV20s47FYmnyl9GhQ4fYtm0bYWFhJCUlcd999/H888+TmZlJamoqTz75JHFxcYwfP771Cn2WONG1DQsL49lnn2XixInExMSQl5fHww8/TEZGBqNGjWrFUrd9d955JzNmzODbb78lKCiosV+K0WhEr9djNBq56aabmDp1KmFhYQQHB3P33XfTv39/+vXr18qlb9v+7Nrm5eUxY8YMxowZQ3h4ODt27OD+++9nyJAhZGVltXLpT1JrD1Nq69588005KSlJ1mg0cp8+feR169a1dpHOapMmTZJjY2NljUYjx8fHy5MmTZIPHDjQ2sU6Ky1btkwGjvm67rrrZFn2D21+8skn5ejoaFmr1crDhw+X9+3b17qFPkuc6NrabDZ55MiRcmRkpKxWq+Xk5GT5lltukcvKylq72G3e8a4pIH/88ceN+9jtdvmOO+6QQ0NDZYPBIF966aVyaWlp6xX6LPFn17awsFAeMmSIHBYWJmu1WjkjI0N+6KGH5Pr6+tYteDNIsizLZzIgCYIgCIIgNJfowyIIgiAIQpsnAosgCIIgCG2eCCyCIAiCILR5IrAIgiAIgtDmicAiCIIgCEKbJwKLIAiCIAhtnggsgiAIgiC0eSKwCIIgCILQ5onAIgiCIAhCmycCiyAIgiAIbZ4ILIIgCIIgtHkisAiCIAiC0Ob9P1iIgEwIBEo/AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(1):\n",
    "    for j in range(2):\n",
    "        for k in range(seed_lds_array.shape[2]):\n",
    "            plt.plot(seed_lds_array[i, j, k, 0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4e079f7d-ad04-4caf-9d6d-140b77f4cbe3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9a1e074c-e43e-4e35-8ae5-2ba488e82406",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "ea85a313-addc-42eb-91ad-e671e3e13104",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[[0.16746462, 0.16024422, 0.16509902, 0.162812  , 0.15930894,\n",
       "         0.16441711, 0.15918403, 0.16585028],\n",
       "        [0.21160506, 0.21104576, 0.21038076, 0.21549864, 0.21196517,\n",
       "         0.21047827, 0.2133242 , 0.2095141 ]]])"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_lds_array[:, :, :, 0].max(axis=-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fc8c05e8-c12d-4187-832b-7e4af09239c5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "c180a94c-6b0d-48bc-baaa-64ac650c7964",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1, 2, 8)"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_lds = seed_lds_array[:, :, :, 0].max(axis=-1)[:, :]\n",
    "seed_lds.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d5b54efc-5829-41cb-b173-ee03d7aa9db9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "82fd4e87-cd7c-4df7-9e2a-bee0c2ad414d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d8daccc6-b205-4e9e-86cc-8a9c393fbd99",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "70fb08b2-f74f-4492-b47a-b0bbc9b041e0",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('./gen_5000_0.5_scores_{}.pkl'.format(K), 'wb') as handle:\n",
    "    pickle.dump(seed_score_list, handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bc3e10d6-8634-4088-8791-b05a1bd4a2c3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "abb6edb1-a3ee-4e14-86e7-443c46c8078d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "1607c463-df77-4f5c-bc18-866080849dd4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(seed_score_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "fc70e90a-ac36-48b0-82ed-6a3b9aa6a95f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(seed_score_list[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "45b82a31-0e5d-4292-9018-29364865a6ae",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "8"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(seed_score_list[0][0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "13219d07-cb2b-4c6b-a14c-f1f8642ffd3d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1000, 5000)"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_score_list[0][0][0].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "b012a62f-d6b4-4da4-97dd-196dad83b36f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1000, 5000)"
      ]
     },
     "execution_count": 39,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.stack(seed_score_list[0][0]).mean(axis=0).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2e7ddf24-c529-483e-9f4f-893f43015630",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "134a59cf-e751-49b5-a5aa-8d1a0de4450c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.185 (avg p value 0.252808)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -np.stack(seed_score_list[0][0])[0:8].mean(axis=0)\n",
    "# infl_est_ = -tmp\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})')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fafb0087-3122-46ad-94e2-8919881a0817",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "e7105050-c8e3-47e1-a532-c4111d35421e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.229 (avg p value 0.182597)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -np.stack(seed_score_list[0][1])[0:8].mean(axis=0)\n",
    "# infl_est_ = -tmp\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})')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0140df1a-5afa-4de1-b947-16ea11e30cd1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "020bbe8e-abe2-46bd-92de-0931bfbe35e9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8099d9d1-2798-4ca9-9ea7-d718fdb55151",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7a67fa8f-3fb1-4653-bebd-6ed286bf6556",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6ab11441-2f5d-42c5-b3be-b67c34e87d9c",
   "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
}
