{
 "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": [
    {
     "data": {
      "text/plain": [
       "1000"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "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": 1,
   "id": "40c86797-31d5-45d0-b46f-52f8c84dd130",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'load_dataset' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[1], line 3\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;66;03m# from datasets import load_dataset\u001b[39;00m\n\u001b[0;32m----> 3\u001b[0m dataset \u001b[38;5;241m=\u001b[39m \u001b[43mload_dataset\u001b[49m(\n\u001b[1;32m      4\u001b[0m     \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mcifar10\u001b[39m\u001b[38;5;124m'\u001b[39m,\n\u001b[1;32m      5\u001b[0m     \u001b[38;5;66;03m# args.dataset_config_name,\u001b[39;00m\n\u001b[1;32m      6\u001b[0m     \u001b[38;5;66;03m# cache_dir=args.cache_dir,\u001b[39;00m\n\u001b[1;32m      7\u001b[0m     \u001b[38;5;66;03m# split=\"train\",\u001b[39;00m\n\u001b[1;32m      8\u001b[0m )\n",
      "\u001b[0;31mNameError\u001b[0m: name 'load_dataset' is not defined"
     ]
    }
   ],
   "source": [
    "from datasets import load_dataset\n",
    "\n",
    "dataset = load_dataset(\n",
    "    'cifar10',\n",
    "    # args.dataset_config_name,\n",
    "    # cache_dir=args.cache_dir,\n",
    "    # split=\"train\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c6632d56-9134-4720-99a9-1853fe349039",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "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": "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",
      "text/plain": [
       "<PIL.PngImagePlugin.PngImageFile image mode=RGB size=32x32>"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from datasets import DatasetDict, Dataset, load_dataset, Image\n",
    "\n",
    "train_dataset = dataset['train'].select(idx_train)\n",
    "train_dataset[0][\"img\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "a17ef712-5e24-4c38-bd27-fbf34ece6446",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAIAAAD8GO2jAAAJjUlEQVR4nCXHyXNcx30A4N673zIrBoOdEEjQlGkuMi2JkiwpcTlOjjmlKmUf7Cr/Vz7lkEtOuaRSLpcX2VFki0UttEwSJAGI5GCbATBvZt7Sr193/zqHfLcP717fZoxtbKyXZbHIZ8aY4XCYqPRf/+UXP/nHfy4q/W///qvf/Po/m8Zsb2+Px2NOaKfbHawsG2f/7sN/iuXy3Xvvz/L5f/33f8zmr1eGazffvH/vzseUcUChCZ5orQkh3nvvnWkMYwwhlM2m+wfPvfecR/3eUCnFOdda11pzztbWVpM4KYtSl/nNG9c6imTH+zGx/Xa7yGYP/vfP2eWlheCBffHgSwIAWuuzs3Fd1wFASiml5Bydjg8ePPy00gvKCABYZ8fjcUAoBHR6evbs+fPz8/Mvv/lqNH79+z/9ev/ga4JcNx0wyqrycu/5FyZUlLNuJ8Zr64MokkmSRFE0zaZxrJI0IbiJJG+3N75/7/1Hf310uL/nvIuUcs4xSjEhPgRAobM0uH3rLVvpyclh8D5JW2lLtlppwNHmd+5vre0KBnh1vZemSikZgJVlzQRaGnTiiHtTdzrdJElOT8e6AvBACMEEOxQIIRgTqSTGKJJSEDLs9XavvrGzfeXp02dx1JpcZi9GRzJOklbCMEKEUM5ZUWhGkRKcBIwDcQ7KskIIgfeEYISQ95ZimkRRAKi0znXZbbeGqyv333l3bbh6cT5pGt9u97W2t2/defziSW3mRSUYpUxJaZ2jxIcAFDGGqaAy7kXWuVo7KRNCXAjBOauU4oTOs5kk5NqNG+++/f3bt24RIv7y+ZeHhwdLg1671f3tH/74s5/+dGt9/dvXL4XgDAJY5zAOFMPa+vLm5s6773zwg3feSdutk5Pjzz777IuHD2ezS0xw2oqddaFxOxvrf/+jH3304YfBm6dPnpyMZ/svDrPFItfllSs8aXeevTi4ce3m0etTZxDeujLo9lLG8Xt37/zy57/Y3L7qHeZSCClUFFvvX7569eDPnz7f2yvKcjhYvvfWvTu3b/UH/RfPnx0+3/vmb4+pSGe5GR0dUYoEV/v7B42x//Djn+TF4sneEyZ5xLDghH78wcffvXbjcpGfnJ0TQijB21d3+8PVW7ff/t6b31ss5mVRdLrdJEkQuCw7b/c627u7QEVZ2/O//q1qKlNVZVVNs0vK+KuzY0JxgyzbWOtLyZVSmJBnBwezRXnwcsQofe/d+2mrGwIFD4iI9tJKu7/ivXdW27rEAbXSxDf+5s3O7z755Ph4ZF1tcQPUiYRhQh49+SpOolYrZh9/9N35LMeYjkav5rMiEP7w60etJProo/cpCx4MpTIAeOsa0xRFjl1DMCAM1tqqMnt7Lx58/rnzpt9LwUvvU4SWCGEX04WKVKeTsqaigvZbaXf0enJ1t72yvnLjzZvHR4fzxfj8QjAZMyapx+B9Ns0m5xOlIqWEEJRL2ustnZz8zyJfbO1sDnrtUOvB8nK/19O1yUujdSUkY5nW3gXv4Wx8knTSqjaTyfz46OyTP376wQ/f6/VXmhp56/LF4vHjxxcX59ev71y/vtsw6byfzspvXx0stcV31ga9tB0aRyXnCCFKuu2kv7NlbMNEygJC9WKel9NXo5dHowc4iGl2eT49yqtqfXWboGgyHk/OJ5eXl7Yxb+xsmabZ2zs4PHh5PJ5OTo5/fO/6/SubImAuxfl0CsGmnRiKUukFwpidTk4RQtwCVWheLmrnbZMbqPrDjacvnnzz5Gms+tiBcw4AKl0++ubx6OT0xfNvZ9micVjhsLO+MlREYoRFwFFgnPU6CkcUe8AIM6qobRyiSKWi21vR9eXJyWhje/nNO9ta58dHkyw/JpYQjEMIVV09/PqrJGkhxExtrTfJsti7+PY084orKpVvXBpFXWckwQxQyhWrtfbOR0IJRhHBGBPCyMaVJY9zHvmd6ytV7qqsqsrKOhvT4EFxrpwL88U0akF/c+kEipG3wWooKEWYLWbheNRJEuKA+cBaLFGKInDGo/HZNMuyXi8hDJ2enUOAEJBgQrV41OswSr0PqVgZvcoO9l+XxWLz2lrUipz3mHJKCCHAKCUEg2cFtiIWjTFsPi8v6mp1eWm+0JeXRinV68bTi1LGwjnkvAvQYAjD5eUo4pwL79Esm5dFISWNI1WXNec0NI5SjFAAHgLGGGPAoYZaKskWpbW6iePGe2atpsQhRAmKcIh0Oa+NN3WNHOjiQkrZ7XYTCdY6CCFRoswLD3ow6EulvG9CCJgSQgjG2KMAAGVRsrNxJhgOZ9P5vBwMVr23o9fHTDBtNcY4imNwAI0ryynGeDKeXr1yFSPmvRMyEoz7xoMNVFJrQwjgkaeCEkItWISRtZZ1OoJihIKTEet1Y/BNpAiToqqoMU0kWdJrUwIeXLfTwgRxKsbnF1zRuC17S11dFbPZLC9ySmCp1+aUIu+FFISQoiiwB3b3zhZG2DRmsdBtxUITVISBICmlMQGg4ZwpIQLC7Q4hBNXGtPsykEgl1CM9XO0RSgACRRBLzjkPIVS1JoylSjnrmBTBOZcmjHNVzxdba2+MTrKLfEYlqp1njAVCCeGcKd8wKsVSr+Utrqt5v9/udZTgAXwTR4pgzgglhCCEOOM8kpRSjDEjgDmmBBGPXCz5zpWti8tFeVQ1FhVFhRAKMMW4kULGUTpYXr57d8ObKQE27A3TGNW6IJg60yCERNpyzllrPUA1rznnaZoyAhwguMZTLNtp+9XhfrvFfvDWLlicZRlCqLHu+OyiLE02LbOp5kiEQOaXev/pKIp8pxNHUUwppQwbYwCAUkoZq6vm/8uqXHMupFQUh1goHDyGgFDgEU1lKqVkQm6/sVbXzWKeA8DG2iql6uRkdHB4NCuytJ2kadrtdldXusPlxNS1EKLb63DfAEDjGpa2kqqqPJBYSnANxriTtBlnCKEKV7WpccC9SMhukidMCIGCnS8Wb791LRCV5XmhC/C+aczFZOKMRAgRQvKiIJwUZcEoY8ZUSnEuaJLGVhsAqHTFHZdS6lo756SQAnDQTUIEw8x63U15p8Uwl5trqfOuLEspBOG0trX3Hrz3EJwnToeqKVmrFVHGMULGGE5pkiQA0DTNbDYDgCRJlJJOG0IICkhrHWjwGHxwDAUCKDjfTkUcxx7A2QrACUalVDJubawNjTHMgrPGee+98amMPQoYoRAC5cwDBISEkE0IURQTQvI8X1SlRUAFtd5xTAG8Mb7x3lrLGB0sLTlnvYfGFFJJKfD/AenmvEAf3YYuAAAAAElFTkSuQmCC",
      "text/plain": [
       "<PIL.PngImagePlugin.PngImageFile image mode=RGB size=32x32>"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "val_dataset =  dataset['test'].select(idx_val)\n",
    "val_dataset[0][\"img\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "e16837b7-8ddd-46ab-9d0a-c988f2ca9514",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[7405, 5226, 1363, 6615, 7612]"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "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": 14,
   "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=65536\n",
    "\n",
    "    used_dim=32768\n",
    "\n",
    "    strategy='uniform'\n",
    "    # strategy='cumulative'\n",
    "   \n",
    "args = Args()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "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": 16,
   "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": 17,
   "id": "7e5b270b-c5df-4b5d-a8fd-2a924a6edad6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000, 1000)"
      ]
     },
     "execution_count": 17,
     "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-{}-val.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": 18,
   "id": "d823ef7b-9d53-4f31-ab11-864274554493",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiMAAAGdCAYAAADAAnMpAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABW3klEQVR4nO3deZxVdeH/8dc5d519YZgZGIZFRRFQQBDELSuS0my1r5mlUVmZfr8WfSvJ1DZFW8wWizT91u+rpl/L1NQwxS0TRUFEQFkFhmU2Zrmz3LnLOZ/fH+fOHa6AMjgzV7jv5+MxD+4953PO+ZwTMW8/57NYxhiDiIiISJbY2a6AiIiI5DaFEREREckqhRERERHJKoURERERySqFEREREckqhRERERHJKoURERERySqFEREREckqf7YrcCBc12Xnzp0UFRVhWVa2qyMiIiIHwBhDR0cHI0eOxLb33/5xSISRnTt3Ultbm+1qiIiIyEGoq6tj1KhR+91/SISRoqIiwLuZ4uLiLNdGREREDkQkEqG2tjb9e3x/Dokw0vtqpri4WGFERETkEPN2XSzUgVVERESySmFEREREskphRERERLJKYURERESySmFEREREskphRERERLJKYURERESySmFEREREskphRERERLJKYURERESySmFEREREskphRERERLLqkFgob7Asf/gB2hvrOf79c6kYPTbb1REREclJOd0ysm7pM7y8+O+0NdRnuyoiIiI5K6fDiGX7ADCum+WaiIiI5K6cDiO27d2+qzAiIiKSNTkdRqxUGDGuk+WaiIiI5C6FEfSaRkREJJtyO4xYFqDXNCIiItmU02Gkt8+IMSbLNREREcldOR1G9JpGREQk+3I8jGhor4iISLbldBjR0F4REZHsy+kwoqG9IiIi2ZfbYaTTmwbedO7Ock1ERERyV06HEbt5HQBuZGeWayIiIpK7cjqM9M4zYhy9phEREcmW3A4jdu+kZwojIiIi2ZLbYaS3ZURhREREJGsOKozcfPPNjB07lnA4zKxZs1i2bNlblr/ppps45phjyMvLo7a2lm984xv09PQcVIUHUqphBONqBlYREZFs6XcYueeee5g/fz7XXHMNK1asYMqUKcydO5fGxsZ9lr/rrru44ooruOaaa3jttde47bbbuOeee/jud7/7jiv/Tmlor4iISPb1O4zceOON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Hdu2bUs/49mzZ/Pqq69m/OV/7LHHKC4u3uuXQq56//vfz6uvvsrKlSvTPzNmzOCCCy5If9ZzHhinnHLKXsPT169fz5gxYwAYN24c1dXVGc86EonwwgsvZDzrtrY2li9fni7zxBNP4Lous2bNGoK7ePfr7u7GtjN/9fh8PlzXBfScB8tAPdfZs2fzzDPPkEgk0mUee+wxjjnmmIN+RQPk9tDeUChk/vjHP5q1a9eaL3/5y6a0tDRjxIHs3yWXXGJKSkrMU089ZXbt2pX+6e7uTpf56le/akaPHm2eeOIJ89JLL5nZs2eb2bNnp/f3Djk988wzzcqVK83ixYvN8OHDNeT0bew5msYYPeeBsmzZMuP3+821115rNmzYYO68806Tn59v7rjjjnSZ66+/3pSWlpoHHnjArFq1ynz0ox/d59DIadOmmRdeeME8++yzZvz48Tk/5HRPF110kampqUkP7b3vvvtMRUWF+fa3v50uo+d8cDo6OszLL79sXn75ZQOYG2+80bz88stm69atxpiBea5tbW2mqqrKfO5znzOrV682d999t8nPz9fQ3nfi17/+tRk9erQJBoNm5syZ5vnnn892lQ4ZwD5//ud//iddJhqNmq997WumrKzM5Ofnm49//ONm165dGefZsmWL+dCHPmTy8vJMRUWF+eY3v2kSicQQ382h5c1hRM954Pz97383kydPNqFQyEyYMMHccsstGftd1zVXXXWVqaqqMqFQyLz//e8369atyyize/duc/7555vCwkJTXFxs5s2bZzo6OobyNt7VIpGIufzyy83o0aNNOBw2RxxxhLnyyiszhorqOR+cJ598cp//Ll900UXGmIF7rq+88oo59dRTTSgUMjU1Neb6669/x3W3jNlj2jsRERGRIZaTfUZERETk3UNhRERERLJKYURERESySmFEREREskphRERERLJKYURERESySmFEREREskphRERERLJKYURERESySmFEREREskphRERERLJKYURERESy6v8Duli93/0DsWIAAAAASUVORK5CYII=",
      "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": 19,
   "id": "874a332c-29b1-46fe-bf83-12e7c8f64e28",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 5000)"
      ]
     },
     "execution_count": 19,
     "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": 20,
   "id": "41ebfcfb-5789-44f0-99d0-0dddc7c6f32f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000)"
      ]
     },
     "execution_count": 20,
     "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": 21,
   "id": "46afee77-65eb-4023-8077-d11ed785d406",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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r77KyZMnbY8JEybYxhkMBoYMGULz5s1JSkpixowZTJs2jblz59Z3EYUQQghxA6r3HZljY2Pp2bMns2bNAsBqtRIREcGECROYNGnSBeVHjx5NaWkpy5Ytsw3r3bs3MTExzJkzp9p5bN++nV69enH06FGaNWsGqC09zz77LM8++2y17/n444/517/+RU5ODnq9erOtSZMm8dNPP7F///46LZvckVkIIYS4/tR1/12vlp7KykqSkpKIj48/NwGtlvj4eDZv3lztezZv3mxXHiAhIaHG8gBFRUVoNBp8fX3thr/xxhv4+/vTtWtXZsyYgdlstpvPzTffbAs8VfNJT0+nsLCw2vkYjUYMBoPdQwghhBA3pnrdkbmgoACLxUJwcLDd8ODg4BpbU3Jycqotn5OTU235iooKXnzxRcaMGWOX1p5++mm6detGkyZN2LRpE5MnT+bkyZO88847tvm0aNHigvlUjfPz87tgXtOnT+eVV165yFILIYQQ4kZwTf0Mhclk4t5770VRFD7++GO7cRMnTrS97tKlC3q9nscee4zp06fj4uLSoPlNnjzZbroGg4GIiIiGVV4IIYQQ17R6hZ6AgACcnJzIzc21G56bm0tISEi17wkJCalT+arAc/ToUdauXXvRPjWxsbGYzWYyMzNp165djfOpqkN1XFxcGhyYhBBCCHF9qVefHr1eT/fu3VmzZo1tmNVqZc2aNcTFxVX7nri4OLvyAImJiXblqwLPwYMHWb16Nf7+/hetS2pqKlqtlqCgINt8NmzYgMlksptPu3btqj21JYQQQgjHUu/TWxMnTmTs2LH06NGDXr168d5771FaWsrDDz8MwEMPPUR4eDjTp08H4JlnnqF///7MnDmTYcOGsWDBAnbs2GG7lNxkMjFq1CiSk5NZtmwZFovF1t+nSZMm6PV6Nm/ezNatWxk4cCBeXl5s3ryZf/zjHzzwwAO2QHPffffxyiuvMG7cOF588UXS0tJ4//33effdd+u8bFUXskmHZiGEEOL6UbXfvugF6UoDfPjhh0qzZs0UvV6v9OrVS9myZYttXP/+/ZWxY8falV+0aJHStm1bRa/XKx07dlSWL19uG3fkyBEFqPaxbt06RVEUJSkpSYmNjVV8fHwUV1dXpX379srrr7+uVFRU2M1n586dSt++fRUXFxclPDxceeONN+q1XMePH6+xLvKQ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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": 22,
   "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",
    "\n",
    "print(len(lamb_list))\n",
    "\n",
    "ckpt_list = [\n",
    "    0, 1, \n",
    "    2, 3, 4, 5, 6, 7,\n",
    "            ]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "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(55.5753, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.489551)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(51.5467, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.504498)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.6873, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.210 (avg p value 0.218188)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5628, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.213 (avg p value 0.212859)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2526, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.213 (avg p value 0.212732)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.215 (avg p value 0.210734)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8524, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.216 (avg p value 0.208210)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4284, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.219 (avg p value 0.204411)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1736, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.226 (avg p value 0.194419)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0882, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.234 (avg p value 0.182180)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0450, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.244 (avg p value 0.168957)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0186, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.255 (avg p value 0.155725)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.259 (avg p value 0.152472)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0048, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.258 (avg p value 0.154517)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.248 (avg p value 0.171590)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.233 (avg p value 0.194234)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.216 (avg p value 0.220193)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.191 (avg p value 0.255362)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9781e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.173 (avg p value 0.283174)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9936e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.154 (avg p value 0.313924)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9987e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.128 (avg p value 0.352614)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9963e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.109 (avg p value 0.380795)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.090 (avg p value 0.403056)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.072 (avg p value 0.422734)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9992e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.064 (avg p value 0.432741)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.060 (avg p value 0.438197)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.057 (avg p value 0.441946)\n",
      "1\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(60.0032, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.498581)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(49.7194, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.520385)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.6346, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.213 (avg p value 0.211702)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5575, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.215 (avg p value 0.208145)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2521, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.215 (avg p value 0.207998)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7006, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.216 (avg p value 0.205101)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8524, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.218 (avg p value 0.202331)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4284, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.221 (avg p value 0.197546)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1736, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.228 (avg p value 0.186536)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0882, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.237 (avg p value 0.173457)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0450, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.247 (avg p value 0.161482)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0186, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.258 (avg p value 0.148942)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.262 (avg p value 0.146463)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0048, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.260 (avg p value 0.154606)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.249 (avg p value 0.171885)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.233 (avg p value 0.192353)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.217 (avg p value 0.215958)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.191 (avg p value 0.255787)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9780e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.172 (avg p value 0.288251)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9936e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.152 (avg p value 0.321459)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9987e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.127 (avg p value 0.352161)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9963e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.108 (avg p value 0.377844)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.090 (avg p value 0.399112)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.072 (avg p value 0.421521)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9992e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.064 (avg p value 0.430889)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.060 (avg p value 0.436956)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.057 (avg p value 0.439743)\n",
      "2\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(59.4196, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.500525)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(47.8189, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.499242)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.7325, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.209 (avg p value 0.220022)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5673, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.211 (avg p value 0.214731)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2533, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.212 (avg p value 0.213915)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7006, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.213 (avg p value 0.212331)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8525, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.215 (avg p value 0.209820)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4284, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.218 (avg p value 0.205846)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1736, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.225 (avg p value 0.195774)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0882, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.233 (avg p value 0.184264)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0450, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.242 (avg p value 0.173405)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0186, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.252 (avg p value 0.160456)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.256 (avg p value 0.158077)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0048, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.254 (avg p value 0.160668)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.243 (avg p value 0.178556)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.230 (avg p value 0.196663)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.212 (avg p value 0.221961)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.187 (avg p value 0.259860)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9781e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.167 (avg p value 0.289752)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9936e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.148 (avg p value 0.319729)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9987e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.123 (avg p value 0.358021)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9963e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.104 (avg p value 0.385099)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.087 (avg p value 0.405311)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.071 (avg p value 0.422330)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9992e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.063 (avg p value 0.431742)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.059 (avg p value 0.437199)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.056 (avg p value 0.439845)\n",
      "3\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(58.0403, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.503959)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(50.2044, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.494643)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.7211, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.213 (avg p value 0.219173)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5662, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.215 (avg p value 0.213825)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2531, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.216 (avg p value 0.213517)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7006, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.217 (avg p value 0.211811)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8524, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.219 (avg p value 0.209576)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4284, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.222 (avg p value 0.205128)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1736, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.229 (avg p value 0.196381)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0882, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.236 (avg p value 0.185841)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0450, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.246 (avg p value 0.172760)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0186, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.256 (avg p value 0.162098)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.260 (avg p value 0.158001)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0048, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.258 (avg p value 0.161681)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.246 (avg p value 0.178431)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.232 (avg p value 0.198430)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.214 (avg p value 0.222356)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.190 (avg p value 0.258562)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9780e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.170 (avg p value 0.290067)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9935e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.152 (avg p value 0.316474)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9987e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.126 (avg p value 0.351215)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9962e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.107 (avg p value 0.381947)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9988e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.089 (avg p value 0.403933)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9997e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.071 (avg p value 0.422028)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9992e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.063 (avg p value 0.431628)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.059 (avg p value 0.438861)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.056 (avg p value 0.443768)\n",
      "4\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(58.4195, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.492117)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(47.8368, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.495052)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.6688, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.212 (avg p value 0.223163)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5610, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.214 (avg p value 0.218718)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2525, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.215 (avg p value 0.216174)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7006, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.216 (avg p value 0.214782)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8524, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.217 (avg p value 0.212459)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4284, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.220 (avg p value 0.207915)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1736, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.228 (avg p value 0.198163)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0882, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.236 (avg p value 0.186060)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0450, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.246 (avg p value 0.172626)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0186, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.257 (avg p value 0.160493)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.260 (avg p value 0.156523)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0048, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.258 (avg p value 0.161253)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.246 (avg p value 0.178885)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.231 (avg p value 0.202311)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.213 (avg p value 0.230776)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.188 (avg p value 0.262130)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9782e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.169 (avg p value 0.289641)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9936e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.151 (avg p value 0.317261)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9987e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.126 (avg p value 0.354988)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9963e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.106 (avg p value 0.378375)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.089 (avg p value 0.399569)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.071 (avg p value 0.424492)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9992e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.064 (avg p value 0.435623)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.059 (avg p value 0.442266)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.057 (avg p value 0.445337)\n",
      "5\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(60.7891, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.492451)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(49.0912, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.506798)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.6261, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.216 (avg p value 0.205739)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5567, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.218 (avg p value 0.203116)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2520, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.219 (avg p value 0.201431)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7006, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.220 (avg p value 0.200560)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8525, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.222 (avg p value 0.198450)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4285, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.225 (avg p value 0.194637)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1737, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.232 (avg p value 0.186253)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0882, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.239 (avg p value 0.177138)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0450, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.248 (avg p value 0.167719)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0186, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.258 (avg p value 0.155532)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.261 (avg p value 0.153113)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0048, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.259 (avg p value 0.154646)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.247 (avg p value 0.170885)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.233 (avg p value 0.187952)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.215 (avg p value 0.215079)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.191 (avg p value 0.251198)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9784e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.171 (avg p value 0.281831)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9937e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.152 (avg p value 0.316069)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9988e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.125 (avg p value 0.358031)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9963e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.105 (avg p value 0.386670)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.087 (avg p value 0.405512)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.070 (avg p value 0.424910)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9992e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.063 (avg p value 0.431940)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.058 (avg p value 0.436725)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.056 (avg p value 0.440057)\n",
      "6\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(58.0059, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.509798)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(48.5743, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.010 (avg p value 0.487554)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.6848, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.212 (avg p value 0.215398)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5627, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.215 (avg p value 0.211558)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2528, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.216 (avg p value 0.210006)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7007, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.217 (avg p value 0.208354)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8525, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.219 (avg p value 0.205659)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4285, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.222 (avg p value 0.201331)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1736, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.229 (avg p value 0.192065)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0882, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.237 (avg p value 0.181409)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0450, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.247 (avg p value 0.167553)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0186, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.258 (avg p value 0.154987)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.262 (avg p value 0.152038)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0048, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.260 (avg p value 0.156246)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.249 (avg p value 0.170204)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.235 (avg p value 0.189014)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.216 (avg p value 0.215459)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.191 (avg p value 0.252197)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9782e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.171 (avg p value 0.282898)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9936e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.152 (avg p value 0.315106)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9987e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.126 (avg p value 0.352456)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9963e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.106 (avg p value 0.380752)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.088 (avg p value 0.399367)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.071 (avg p value 0.423960)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9992e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.063 (avg p value 0.431798)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.059 (avg p value 0.437979)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.056 (avg p value 0.439992)\n",
      "7\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(60.1515, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.498448)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(50.7932, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.489096)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.6363, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.209 (avg p value 0.222567)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5576, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.211 (avg p value 0.220835)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2520, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.213 (avg p value 0.217971)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.214 (avg p value 0.215945)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8524, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.215 (avg p value 0.214181)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4284, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.218 (avg p value 0.210055)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1736, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.225 (avg p value 0.201021)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0882, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.234 (avg p value 0.190979)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0450, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.243 (avg p value 0.179273)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0186, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.254 (avg p value 0.167071)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.258 (avg p value 0.161688)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0048, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.257 (avg p value 0.164035)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.245 (avg p value 0.180986)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.230 (avg p value 0.198911)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.212 (avg p value 0.218905)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.187 (avg p value 0.257257)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9780e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.168 (avg p value 0.293120)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9936e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.150 (avg p value 0.322603)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9987e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.125 (avg p value 0.359005)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9963e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.106 (avg p value 0.381194)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.089 (avg p value 0.399740)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.073 (avg p value 0.419426)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9992e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.066 (avg p value 0.427604)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.062 (avg p value 0.433202)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.059 (avg p value 0.436598)\n",
      "mean-squared-l2-norm\n",
      "0\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(-0.0004, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.494939)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0050, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.510608)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0131, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.507356)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0304, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.011 (avg p value 0.502387)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0423, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.502825)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0618, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.505076)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0494, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.486038)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0578, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.498329)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0436, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.010 (avg p value 0.504498)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0330, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.511826)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0246, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.012 (avg p value 0.498868)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0164, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.484546)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0097, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.475595)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0046, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.290 (avg p value 0.117203)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.312 (avg p value 0.096573)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.323 (avg p value 0.087100)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.327 (avg p value 0.083636)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.326 (avg p value 0.086632)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8234e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.319 (avg p value 0.093772)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9428e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.309 (avg p value 0.101330)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9873e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.293 (avg p value 0.118521)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9599e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.277 (avg p value 0.137865)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9873e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.259 (avg p value 0.160806)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9972e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.233 (avg p value 0.193795)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9910e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.211 (avg p value 0.224409)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9970e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.190 (avg p value 0.258726)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9993e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.165 (avg p value 0.305498)\n",
      "1\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(-0.0061, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.492135)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0100, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.495785)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0109, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.517681)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0344, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.511864)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0622, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.501138)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0642, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.496943)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0772, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.506514)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0593, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.013 (avg p value 0.499794)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0442, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.011 (avg p value 0.497735)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0338, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.505472)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0237, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.502364)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0147, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.518039)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0098, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.496949)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0046, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.292 (avg p value 0.110024)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.314 (avg p value 0.091057)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.324 (avg p value 0.083038)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.329 (avg p value 0.082226)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.327 (avg p value 0.087435)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8207e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.321 (avg p value 0.094231)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9418e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.311 (avg p value 0.102139)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9871e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.294 (avg p value 0.117632)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9592e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.278 (avg p value 0.134567)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9871e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.260 (avg p value 0.159121)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9971e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.233 (avg p value 0.194598)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9908e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.212 (avg p value 0.224426)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9970e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.192 (avg p value 0.256509)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9993e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.167 (avg p value 0.302228)\n",
      "2\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0062, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.476015)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0108, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.015 (avg p value 0.496353)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0233, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.497432)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(-0.0170, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.507939)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0257, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.011 (avg p value 0.500467)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0606, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.516489)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0688, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.499405)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0572, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.481080)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0431, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.502856)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0335, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.010 (avg p value 0.515989)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0251, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.490604)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0154, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.019 (avg p value 0.492775)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0090, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.016 (avg p value 0.503298)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0046, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.287 (avg p value 0.119552)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.310 (avg p value 0.095609)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.321 (avg p value 0.086571)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.327 (avg p value 0.083875)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.325 (avg p value 0.089657)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8246e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.319 (avg p value 0.097337)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9431e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.310 (avg p value 0.104899)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9874e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.293 (avg p value 0.118587)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9599e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.277 (avg p value 0.134491)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9873e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.259 (avg p value 0.157642)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9972e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.232 (avg p value 0.194029)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9909e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.211 (avg p value 0.224748)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9970e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.190 (avg p value 0.256930)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9993e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.166 (avg p value 0.303784)\n",
      "3\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0075, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.523555)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0087, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.010 (avg p value 0.501162)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0183, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.503820)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0317, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.512210)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0470, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.504359)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0714, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.511292)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0641, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.491592)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0562, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.007 (avg p value 0.478266)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0435, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.495686)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0335, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.518813)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0233, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.505212)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0150, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.515745)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0096, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.028 (avg p value 0.495834)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0046, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.289 (avg p value 0.122758)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.310 (avg p value 0.101110)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.321 (avg p value 0.091746)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.326 (avg p value 0.089225)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.324 (avg p value 0.094886)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8241e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.318 (avg p value 0.101016)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9429e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.308 (avg p value 0.108849)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9874e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.291 (avg p value 0.122537)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9600e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.276 (avg p value 0.141793)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9873e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.258 (avg p value 0.163140)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9972e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.231 (avg p value 0.198336)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9910e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.210 (avg p value 0.228654)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9970e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.189 (avg p value 0.261952)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9993e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.164 (avg p value 0.308506)\n",
      "4\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0717, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.501191)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0153, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.500440)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(-0.0365, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.487143)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0791, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.496354)\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.494345)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0667, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.000 (avg p value 0.507189)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0691, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.499588)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0608, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.522097)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0450, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.506137)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0344, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.496933)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0261, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.508867)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0154, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.012 (avg p value 0.506080)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0096, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.024 (avg p value 0.499522)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0046, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.290 (avg p value 0.117171)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.312 (avg p value 0.096466)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.323 (avg p value 0.087612)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.328 (avg p value 0.083696)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.327 (avg p value 0.087865)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8235e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.320 (avg p value 0.092976)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9428e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.311 (avg p value 0.099824)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9873e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.294 (avg p value 0.114616)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9599e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.278 (avg p value 0.134304)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9873e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.259 (avg p value 0.158586)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9972e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.232 (avg p value 0.193449)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9909e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.211 (avg p value 0.224971)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9970e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.190 (avg p value 0.258512)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9993e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.166 (avg p value 0.302173)\n",
      "5\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(-0.0054, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.010 (avg p value 0.487648)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0096, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.503963)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0055, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.011 (avg p value 0.501706)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0213, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.503100)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0803, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.502215)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0633, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.014 (avg p value 0.497936)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0630, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.013 (avg p value 0.490544)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0582, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.480476)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0406, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.499282)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0286, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.497965)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0246, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.013 (avg p value 0.483066)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0157, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.502492)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0097, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.026 (avg p value 0.477929)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0046, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.293 (avg p value 0.109533)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.314 (avg p value 0.091255)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.324 (avg p value 0.084712)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.330 (avg p value 0.081271)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.329 (avg p value 0.084865)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8242e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.322 (avg p value 0.092212)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9429e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.312 (avg p value 0.102512)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9873e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.294 (avg p value 0.118299)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9598e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.278 (avg p value 0.138291)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9872e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.259 (avg p value 0.163258)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9972e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.232 (avg p value 0.199464)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9909e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.211 (avg p value 0.228195)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9970e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.190 (avg p value 0.258484)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9993e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.165 (avg p value 0.303255)\n",
      "6\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.490306)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0101, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.008 (avg p value 0.496940)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0007, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.516699)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0222, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.493852)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0497, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.493473)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0566, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.487041)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0657, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.004 (avg p value 0.504283)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0584, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.012 (avg p value 0.483788)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0433, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.515926)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0336, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.014 (avg p value 0.511862)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0253, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.505739)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0155, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.495613)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0097, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.025 (avg p value 0.489926)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0046, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.295 (avg p value 0.111591)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.316 (avg p value 0.092292)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.325 (avg p value 0.086645)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.329 (avg p value 0.088005)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.325 (avg p value 0.093462)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8279e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.318 (avg p value 0.101342)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9441e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.308 (avg p value 0.109249)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9876e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.290 (avg p value 0.123553)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9608e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.273 (avg p value 0.143348)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9876e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.255 (avg p value 0.166714)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9972e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.228 (avg p value 0.198904)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9911e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.207 (avg p value 0.230162)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9971e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.187 (avg p value 0.263854)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9993e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.163 (avg p value 0.310077)\n",
      "7\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0038, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.512667)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0024, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.010 (avg p value 0.495869)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0232, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.012 (avg p value 0.498913)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0289, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.490854)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0461, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.004 (avg p value 0.504381)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.3783, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.008 (avg p value 0.503640)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0721, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.499145)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0573, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.489634)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0444, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.010 (avg p value 0.492539)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0345, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.511463)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0250, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.492774)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0153, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.499606)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0097, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.034 (avg p value 0.480159)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0046, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.293 (avg p value 0.115329)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.313 (avg p value 0.096628)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.322 (avg p value 0.088644)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.326 (avg p value 0.087267)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.325 (avg p value 0.092011)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8282e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.318 (avg p value 0.098879)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9443e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.309 (avg p value 0.107749)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9877e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.293 (avg p value 0.121657)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9609e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.277 (avg p value 0.138732)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9876e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.258 (avg p value 0.161985)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9973e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.230 (avg p value 0.198878)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9911e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.209 (avg p value 0.228259)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9971e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.189 (avg p value 0.259972)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9993e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.164 (avg p value 0.307923)\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-val-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": 24,
   "id": "c08f885c-95db-4cfb-a235-b8ddddcd3a50",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[[[ 6.42719584e-03,  2.79571650e-03,  2.10085474e-01,\n",
       "           2.13106490e-01,  2.13405688e-01,  2.14540738e-01,\n",
       "           2.16160976e-01,  2.19101614e-01,  2.25672609e-01,\n",
       "           2.33932482e-01,  2.43680402e-01,  2.55176122e-01,\n",
       "           2.59435418e-01,  2.58240523e-01,  2.47643818e-01,\n",
       "           2.33438599e-01,  2.16164485e-01,  1.91436784e-01,\n",
       "           1.72777206e-01,  1.54219327e-01,  1.28430539e-01,\n",
       "           1.08946902e-01,  8.96077268e-02,  7.20236809e-02,\n",
       "           6.42779379e-02,  5.98441690e-02,  5.67704948e-02],\n",
       "         [ 4.89551070e-01,  5.04497622e-01,  2.18188048e-01,\n",
       "           2.12859008e-01,  2.12732401e-01,  2.10733871e-01,\n",
       "           2.08209904e-01,  2.04410639e-01,  1.94418665e-01,\n",
       "           1.82179936e-01,  1.68956849e-01,  1.55725370e-01,\n",
       "           1.52471802e-01,  1.54517094e-01,  1.71589709e-01,\n",
       "           1.94234187e-01,  2.20193315e-01,  2.55362395e-01,\n",
       "           2.83174003e-01,  3.13924156e-01,  3.52614364e-01,\n",
       "           3.80794920e-01,  4.03056359e-01,  4.22734253e-01,\n",
       "           4.32740603e-01,  4.38197488e-01,  4.41946203e-01]],\n",
       "\n",
       "        [[-2.26579634e-03,  6.96367348e-03,  2.13344227e-01,\n",
       "           2.14619044e-01,  2.14847501e-01,  2.16010484e-01,\n",
       "           2.17744914e-01,  2.20735070e-01,  2.27990133e-01,\n",
       "           2.36764812e-01,  2.46504671e-01,  2.58365935e-01,\n",
       "           2.62377198e-01,  2.60407462e-01,  2.48661006e-01,\n",
       "           2.33372293e-01,  2.16673088e-01,  1.91070840e-01,\n",
       "           1.71651336e-01,  1.52107056e-01,  1.27147046e-01,\n",
       "           1.07522017e-01,  8.95493709e-02,  7.20610664e-02,\n",
       "           6.43680251e-02,  6.00019754e-02,  5.72198780e-02],\n",
       "         [ 4.98581107e-01,  5.20384878e-01,  2.11702488e-01,\n",
       "           2.08145101e-01,  2.07997559e-01,  2.05101350e-01,\n",
       "           2.02330503e-01,  1.97545761e-01,  1.86536120e-01,\n",
       "           1.73457110e-01,  1.61481821e-01,  1.48941514e-01,\n",
       "           1.46463394e-01,  1.54605976e-01,  1.71884682e-01,\n",
       "           1.92353326e-01,  2.15958125e-01,  2.55786941e-01,\n",
       "           2.88250903e-01,  3.21459130e-01,  3.52161443e-01,\n",
       "           3.77843756e-01,  3.99111760e-01,  4.21520516e-01,\n",
       "           4.30888682e-01,  4.36956173e-01,  4.39743319e-01]],\n",
       "\n",
       "        [[-4.95252899e-03,  7.38473272e-03,  2.09285588e-01,\n",
       "           2.11473522e-01,  2.12152185e-01,  2.13368806e-01,\n",
       "           2.15194017e-01,  2.18223112e-01,  2.24933255e-01,\n",
       "           2.33211232e-01,  2.42398230e-01,  2.52177444e-01,\n",
       "           2.55826185e-01,  2.54015952e-01,  2.43035616e-01,\n",
       "           2.29925998e-01,  2.12178765e-01,  1.86780644e-01,\n",
       "           1.66940985e-01,  1.48026422e-01,  1.23333515e-01,\n",
       "           1.03888092e-01,  8.66099726e-02,  7.06505594e-02,\n",
       "           6.27350364e-02,  5.89570820e-02,  5.61614998e-02],\n",
       "         [ 5.00524726e-01,  4.99242323e-01,  2.20021809e-01,\n",
       "           2.14730757e-01,  2.13914840e-01,  2.12330570e-01,\n",
       "           2.09820000e-01,  2.05846107e-01,  1.95773814e-01,\n",
       "           1.84264193e-01,  1.73405230e-01,  1.60455617e-01,\n",
       "           1.58077245e-01,  1.60667964e-01,  1.78555521e-01,\n",
       "           1.96663408e-01,  2.21961295e-01,  2.59859589e-01,\n",
       "           2.89752462e-01,  3.19729383e-01,  3.58021171e-01,\n",
       "           3.85099306e-01,  4.05311274e-01,  4.22329745e-01,\n",
       "           4.31742153e-01,  4.37198567e-01,  4.39845161e-01]],\n",
       "\n",
       "        [[ 1.06712003e-03, -2.20725468e-03,  2.12629316e-01,\n",
       "           2.15434422e-01,  2.16169679e-01,  2.17435201e-01,\n",
       "           2.19006332e-01,  2.21832546e-01,  2.28746466e-01,\n",
       "           2.36484199e-01,  2.45668996e-01,  2.55550087e-01,\n",
       "           2.59670463e-01,  2.57529390e-01,  2.45897065e-01,\n",
       "           2.31569564e-01,  2.14013587e-01,  1.89618328e-01,\n",
       "           1.70245954e-01,  1.51761041e-01,  1.26471337e-01,\n",
       "           1.06808556e-01,  8.87884764e-02,  7.11935537e-02,\n",
       "           6.34910118e-02,  5.88057550e-02,  5.62830897e-02],\n",
       "         [ 5.03958683e-01,  4.94642703e-01,  2.19172782e-01,\n",
       "           2.13825108e-01,  2.13516740e-01,  2.11811149e-01,\n",
       "           2.09575601e-01,  2.05127697e-01,  1.96381206e-01,\n",
       "           1.85841318e-01,  1.72760176e-01,  1.62098363e-01,\n",
       "           1.58001122e-01,  1.61681487e-01,  1.78431355e-01,\n",
       "           1.98430222e-01,  2.22355643e-01,  2.58561987e-01,\n",
       "           2.90066816e-01,  3.16474291e-01,  3.51214741e-01,\n",
       "           3.81946753e-01,  4.03932772e-01,  4.22027721e-01,\n",
       "           4.31628367e-01,  4.38860758e-01,  4.43768276e-01]],\n",
       "\n",
       "        [[ 4.00802825e-03,  4.67014201e-03,  2.11704847e-01,\n",
       "           2.13608716e-01,  2.14528955e-01,  2.15620072e-01,\n",
       "           2.17349606e-01,  2.20479299e-01,  2.27833422e-01,\n",
       "           2.36021199e-01,  2.45867034e-01,  2.56637961e-01,\n",
       "           2.60458039e-01,  2.57910876e-01,  2.46261079e-01,\n",
       "           2.31160595e-01,  2.12850540e-01,  1.88403671e-01,\n",
       "           1.69348060e-01,  1.51313647e-01,  1.26278912e-01,\n",
       "           1.06280717e-01,  8.85691522e-02,  7.14740023e-02,\n",
       "           6.36726041e-02,  5.92899565e-02,  5.67647041e-02],\n",
       "         [ 4.92116914e-01,  4.95051905e-01,  2.23162845e-01,\n",
       "           2.18717839e-01,  2.16173613e-01,  2.14781960e-01,\n",
       "           2.12458790e-01,  2.07915345e-01,  1.98162687e-01,\n",
       "           1.86060307e-01,  1.72626167e-01,  1.60492698e-01,\n",
       "           1.56523056e-01,  1.61252914e-01,  1.78885114e-01,\n",
       "           2.02310879e-01,  2.30775815e-01,  2.62129668e-01,\n",
       "           2.89641409e-01,  3.17260783e-01,  3.54988037e-01,\n",
       "           3.78375227e-01,  3.99569191e-01,  4.24492008e-01,\n",
       "           4.35623353e-01,  4.42266175e-01,  4.45337045e-01]],\n",
       "\n",
       "        [[ 4.75583302e-03, -4.75531962e-03,  2.15725266e-01,\n",
       "           2.18377852e-01,  2.19013246e-01,  2.20030005e-01,\n",
       "           2.21836919e-01,  2.24705579e-01,  2.31623117e-01,\n",
       "           2.39207115e-01,  2.48484132e-01,  2.58201122e-01,\n",
       "           2.61189263e-01,  2.59077449e-01,  2.47173117e-01,\n",
       "           2.33298757e-01,  2.15312351e-01,  1.90850650e-01,\n",
       "           1.71387734e-01,  1.52077294e-01,  1.25295100e-01,\n",
       "           1.05375198e-01,  8.72805518e-02,  7.00511313e-02,\n",
       "           6.26851963e-02,  5.83510392e-02,  5.57678179e-02],\n",
       "         [ 4.92451331e-01,  5.06798443e-01,  2.05739069e-01,\n",
       "           2.03116469e-01,  2.01430551e-01,  2.00560066e-01,\n",
       "           1.98449663e-01,  1.94636754e-01,  1.86253473e-01,\n",
       "           1.77138408e-01,  1.67718961e-01,  1.55532165e-01,\n",
       "           1.53113166e-01,  1.54646129e-01,  1.70884817e-01,\n",
       "           1.87951661e-01,  2.15078797e-01,  2.51198254e-01,\n",
       "           2.81830731e-01,  3.16068687e-01,  3.58031408e-01,\n",
       "           3.86669823e-01,  4.05512438e-01,  4.24910223e-01,\n",
       "           4.31939874e-01,  4.36725394e-01,  4.40056532e-01]],\n",
       "\n",
       "        [[ 1.13186667e-03,  1.01386336e-02,  2.12360890e-01,\n",
       "           2.15025864e-01,  2.15930420e-01,  2.17149490e-01,\n",
       "           2.18910778e-01,  2.22030970e-01,  2.29373875e-01,\n",
       "           2.37219984e-01,  2.46805722e-01,  2.58370516e-01,\n",
       "           2.62208357e-01,  2.60154579e-01,  2.48799059e-01,\n",
       "           2.34587317e-01,  2.16326249e-01,  1.90596780e-01,\n",
       "           1.71320837e-01,  1.51503686e-01,  1.25500134e-01,\n",
       "           1.05550586e-01,  8.82370529e-02,  7.05900966e-02,\n",
       "           6.31794035e-02,  5.89394541e-02,  5.62723519e-02],\n",
       "         [ 5.09798025e-01,  4.87554225e-01,  2.15397788e-01,\n",
       "           2.11557768e-01,  2.10005718e-01,  2.08354361e-01,\n",
       "           2.05659237e-01,  2.01330993e-01,  1.92064951e-01,\n",
       "           1.81409000e-01,  1.67553271e-01,  1.54986681e-01,\n",
       "           1.52038336e-01,  1.56245521e-01,  1.70204420e-01,\n",
       "           1.89013610e-01,  2.15458858e-01,  2.52197300e-01,\n",
       "           2.82898467e-01,  3.15106139e-01,  3.52455718e-01,\n",
       "           3.80751533e-01,  3.99367068e-01,  4.23959867e-01,\n",
       "           4.31798011e-01,  4.37978713e-01,  4.39992182e-01]],\n",
       "\n",
       "        [[ 4.66522051e-03,  9.05222732e-03,  2.09306391e-01,\n",
       "           2.11242816e-01,  2.12562826e-01,  2.13873906e-01,\n",
       "           2.15395129e-01,  2.18480111e-01,  2.25364980e-01,\n",
       "           2.33541218e-01,  2.43267551e-01,  2.53531836e-01,\n",
       "           2.57850840e-01,  2.56594816e-01,  2.44724598e-01,\n",
       "           2.30312187e-01,  2.12445428e-01,  1.86677363e-01,\n",
       "           1.67508292e-01,  1.50079330e-01,  1.24732964e-01,\n",
       "           1.06248509e-01,  8.88996232e-02,  7.26797730e-02,\n",
       "           6.57267055e-02,  6.17334801e-02,  5.90628984e-02],\n",
       "         [ 4.98448241e-01,  4.89096453e-01,  2.22567286e-01,\n",
       "           2.20834993e-01,  2.17970760e-01,  2.15945242e-01,\n",
       "           2.14180523e-01,  2.10054940e-01,  2.01020964e-01,\n",
       "           1.90978531e-01,  1.79272958e-01,  1.67070709e-01,\n",
       "           1.61687982e-01,  1.64035450e-01,  1.80986309e-01,\n",
       "           1.98910948e-01,  2.18905382e-01,  2.57256735e-01,\n",
       "           2.93120341e-01,  3.22603499e-01,  3.59005343e-01,\n",
       "           3.81193664e-01,  3.99739587e-01,  4.19425874e-01,\n",
       "           4.27603610e-01,  4.33202286e-01,  4.36598351e-01]]],\n",
       "\n",
       "\n",
       "       [[[ 5.07012302e-03,  1.88575610e-03,  7.33722209e-04,\n",
       "           1.11253861e-02,  6.12977339e-04, -9.71918010e-04,\n",
       "           4.61161101e-03,  2.42628902e-03,  1.02763778e-02,\n",
       "          -3.22420470e-03,  1.17774745e-02,  7.21886424e-03,\n",
       "           4.61381812e-03,  2.89993972e-01,  3.11558651e-01,\n",
       "           3.22532485e-01,  3.27273603e-01,  3.25593290e-01,\n",
       "           3.19014991e-01,  3.09304736e-01,  2.92712305e-01,\n",
       "           2.76748313e-01,  2.58885754e-01,  2.32711744e-01,\n",
       "           2.11368606e-01,  1.90452409e-01,  1.64711136e-01],\n",
       "         [ 4.94939291e-01,  5.10608130e-01,  5.07355854e-01,\n",
       "           5.02387315e-01,  5.02824868e-01,  5.05076202e-01,\n",
       "           4.86038427e-01,  4.98328853e-01,  5.04498335e-01,\n",
       "           5.11825727e-01,  4.98867984e-01,  4.84546452e-01,\n",
       "           4.75595233e-01,  1.17202752e-01,  9.65733673e-02,\n",
       "           8.70999510e-02,  8.36360434e-02,  8.66318476e-02,\n",
       "           9.37721297e-02,  1.01329955e-01,  1.18521467e-01,\n",
       "           1.37864917e-01,  1.60806019e-01,  1.93794947e-01,\n",
       "           2.24409054e-01,  2.58725786e-01,  3.05497628e-01]],\n",
       "\n",
       "        [[ 4.60019948e-03,  8.91976866e-03,  4.43734385e-04,\n",
       "          -5.47073997e-03,  8.94998632e-03,  9.17068798e-03,\n",
       "           6.27282359e-03,  1.33870821e-02,  1.13751422e-02,\n",
       "           8.67225443e-03,  3.02953251e-03,  2.09570525e-03,\n",
       "           5.83588956e-03,  2.91692414e-01,  3.13556198e-01,\n",
       "           3.24258626e-01,  3.29376278e-01,  3.27206977e-01,\n",
       "           3.20611532e-01,  3.11381089e-01,  2.93714365e-01,\n",
       "           2.78083133e-01,  2.59653367e-01,  2.33173417e-01,\n",
       "           2.11964207e-01,  1.91555455e-01,  1.66755153e-01],\n",
       "         [ 4.92134666e-01,  4.95785185e-01,  5.17680911e-01,\n",
       "           5.11864014e-01,  5.01137604e-01,  4.96942946e-01,\n",
       "           5.06514175e-01,  4.99793718e-01,  4.97734782e-01,\n",
       "           5.05472036e-01,  5.02363820e-01,  5.18039315e-01,\n",
       "           4.96949126e-01,  1.10023728e-01,  9.10570635e-02,\n",
       "           8.30384635e-02,  8.22258379e-02,  8.74354529e-02,\n",
       "           9.42311901e-02,  1.02138575e-01,  1.17631660e-01,\n",
       "           1.34566917e-01,  1.59121238e-01,  1.94597662e-01,\n",
       "           2.24425590e-01,  2.56508513e-01,  3.02228314e-01]],\n",
       "\n",
       "        [[ 2.24024933e-03,  1.46058582e-02, -1.72297100e-03,\n",
       "           7.15547782e-03,  1.13755777e-02,  8.21974121e-03,\n",
       "           7.73380380e-03,  3.06436541e-03,  8.15937276e-04,\n",
       "           1.04849879e-02,  1.45805563e-03,  1.91108941e-02,\n",
       "           1.63399923e-02,  2.87372425e-01,  3.09662998e-01,\n",
       "           3.21327724e-01,  3.26898395e-01,  3.25216807e-01,\n",
       "           3.18790470e-01,  3.10175655e-01,  2.92970110e-01,\n",
       "           2.77376195e-01,  2.59213785e-01,  2.32325663e-01,\n",
       "           2.11247172e-01,  1.90471709e-01,  1.65539266e-01],\n",
       "         [ 4.76015457e-01,  4.96353358e-01,  4.97432193e-01,\n",
       "           5.07939279e-01,  5.00466610e-01,  5.16489418e-01,\n",
       "           4.99405463e-01,  4.81080376e-01,  5.02856250e-01,\n",
       "           5.15989116e-01,  4.90604227e-01,  4.92775020e-01,\n",
       "           5.03298300e-01,  1.19552206e-01,  9.56088729e-02,\n",
       "           8.65711136e-02,  8.38754676e-02,  8.96565525e-02,\n",
       "           9.73369570e-02,  1.04899474e-01,  1.18587212e-01,\n",
       "           1.34491459e-01,  1.57642215e-01,  1.94028789e-01,\n",
       "           2.24747992e-01,  2.56930095e-01,  3.03784273e-01]],\n",
       "\n",
       "        [[ 8.38586629e-03,  9.81392452e-03, -1.31920189e-03,\n",
       "           5.27067876e-03,  8.47401348e-03,  3.77860517e-04,\n",
       "           4.93889785e-03, -7.07263735e-03,  2.43931594e-04,\n",
       "           8.39102709e-03, -1.06646924e-03,  2.71444056e-03,\n",
       "           2.83259427e-02,  2.88665235e-01,  3.09805535e-01,\n",
       "           3.20616683e-01,  3.26385161e-01,  3.24416917e-01,\n",
       "           3.17795164e-01,  3.07638639e-01,  2.91346900e-01,\n",
       "           2.75839018e-01,  2.58066647e-01,  2.30643221e-01,\n",
       "           2.09645525e-01,  1.88958888e-01,  1.63653576e-01],\n",
       "         [ 5.23555415e-01,  5.01162272e-01,  5.03820034e-01,\n",
       "           5.12209731e-01,  5.04359326e-01,  5.11291715e-01,\n",
       "           4.91591812e-01,  4.78266490e-01,  4.95685951e-01,\n",
       "           5.18813239e-01,  5.05211958e-01,  5.15744727e-01,\n",
       "           4.95834448e-01,  1.22757749e-01,  1.01109795e-01,\n",
       "           9.17462650e-02,  8.92249266e-02,  9.48856090e-02,\n",
       "           1.01015716e-01,  1.08848921e-01,  1.22537119e-01,\n",
       "           1.41793320e-01,  1.63140260e-01,  1.98335757e-01,\n",
       "           2.28653744e-01,  2.61951954e-01,  3.08505651e-01]],\n",
       "\n",
       "        [[ 2.27399183e-03, -2.42610688e-03,  6.34483892e-04,\n",
       "           1.82911511e-03, -3.28421158e-03, -1.48472901e-04,\n",
       "           3.22167234e-03,  2.90547758e-03,  6.03810134e-03,\n",
       "           2.88967484e-03,  3.30163531e-03,  1.18126392e-02,\n",
       "           2.36291945e-02,  2.90408466e-01,  3.11508241e-01,\n",
       "           3.22954612e-01,  3.27864354e-01,  3.26510620e-01,\n",
       "           3.20378763e-01,  3.10743583e-01,  2.94112609e-01,\n",
       "           2.77643552e-01,  2.58809141e-01,  2.31883214e-01,\n",
       "           2.10761503e-01,  1.90043761e-01,  1.65611064e-01],\n",
       "         [ 5.01190697e-01,  5.00440473e-01,  4.87143168e-01,\n",
       "           4.96354047e-01,  4.94345451e-01,  5.07188705e-01,\n",
       "           4.99588482e-01,  5.22097405e-01,  5.06136787e-01,\n",
       "           4.96932991e-01,  5.08866859e-01,  5.06080266e-01,\n",
       "           4.99522223e-01,  1.17171298e-01,  9.64662917e-02,\n",
       "           8.76119892e-02,  8.36956026e-02,  8.78647353e-02,\n",
       "           9.29758869e-02,  9.98239840e-02,  1.14615518e-01,\n",
       "           1.34303963e-01,  1.58585739e-01,  1.93448816e-01,\n",
       "           2.24970522e-01,  2.58511705e-01,  3.02172707e-01]],\n",
       "\n",
       "        [[ 1.03194918e-02,  3.68857656e-03,  1.14060929e-02,\n",
       "           1.94138079e-03, -1.92070911e-03,  1.36226734e-02,\n",
       "           1.26987671e-02,  6.07066353e-03,  9.30281910e-03,\n",
       "           4.22111412e-03,  1.30211973e-02,  1.73329592e-03,\n",
       "           2.63518431e-02,  2.92522313e-01,  3.14008929e-01,\n",
       "           3.24109521e-01,  3.30203433e-01,  3.28602356e-01,\n",
       "           3.21506109e-01,  3.11738867e-01,  2.94464851e-01,\n",
       "           2.77858113e-01,  2.59170171e-01,  2.31728452e-01,\n",
       "           2.10752373e-01,  1.90058524e-01,  1.64701037e-01],\n",
       "         [ 4.87648196e-01,  5.03962882e-01,  5.01706141e-01,\n",
       "           5.03100187e-01,  5.02215049e-01,  4.97935712e-01,\n",
       "           4.90543837e-01,  4.80476194e-01,  4.99282422e-01,\n",
       "           4.97964572e-01,  4.83066420e-01,  5.02491769e-01,\n",
       "           4.77928617e-01,  1.09533299e-01,  9.12550262e-02,\n",
       "           8.47123766e-02,  8.12709597e-02,  8.48645704e-02,\n",
       "           9.22121350e-02,  1.02511790e-01,  1.18299091e-01,\n",
       "           1.38290608e-01,  1.63258493e-01,  1.99464117e-01,\n",
       "           2.28194634e-01,  2.58483913e-01,  3.03254664e-01]],\n",
       "\n",
       "        [[ 4.22470100e-03, -7.73368145e-03, -2.85470528e-03,\n",
       "           3.55512265e-04,  8.56094686e-03,  1.79895611e-03,\n",
       "          -3.58649548e-03,  1.19759650e-02, -9.98727204e-04,\n",
       "           1.38446936e-02,  3.70874795e-03, -1.24028566e-03,\n",
       "           2.50093037e-02,  2.95070798e-01,  3.15866546e-01,\n",
       "           3.24852537e-01,  3.28666228e-01,  3.24998439e-01,\n",
       "           3.17941500e-01,  3.07672060e-01,  2.89597931e-01,\n",
       "           2.73035079e-01,  2.55186928e-01,  2.28181883e-01,\n",
       "           2.07445161e-01,  1.87192175e-01,  1.62663896e-01],\n",
       "         [ 4.90306304e-01,  4.96940264e-01,  5.16698929e-01,\n",
       "           4.93851663e-01,  4.93472850e-01,  4.87040944e-01,\n",
       "           5.04282682e-01,  4.83788058e-01,  5.15926441e-01,\n",
       "           5.11861655e-01,  5.05738870e-01,  4.95613040e-01,\n",
       "           4.89926464e-01,  1.11591087e-01,  9.22918288e-02,\n",
       "           8.66452222e-02,  8.80046317e-02,  9.34622954e-02,\n",
       "           1.01342443e-01,  1.09248805e-01,  1.23552695e-01,\n",
       "           1.43348421e-01,  1.66713614e-01,  1.98904333e-01,\n",
       "           2.30161783e-01,  2.63853763e-01,  3.10076975e-01]],\n",
       "\n",
       "        [[ 5.31244974e-03, -1.02754134e-02,  1.24478853e-02,\n",
       "           6.67658381e-03, -3.69743897e-03, -7.83729471e-03,\n",
       "          -1.99227995e-03,  8.28855322e-03,  1.04437163e-02,\n",
       "           3.61595941e-03,  4.84028353e-03,  7.41506495e-03,\n",
       "           3.44862709e-02,  2.92721718e-01,  3.12684635e-01,\n",
       "           3.22000827e-01,  3.26371770e-01,  3.24595165e-01,\n",
       "           3.18006916e-01,  3.09459249e-01,  2.92542686e-01,\n",
       "           2.76637691e-01,  2.57848151e-01,  2.30259815e-01,\n",
       "           2.09295344e-01,  1.89214407e-01,  1.64320015e-01],\n",
       "         [ 5.12667346e-01,  4.95868772e-01,  4.98912778e-01,\n",
       "           4.90853683e-01,  5.04381114e-01,  5.03639917e-01,\n",
       "           4.99145107e-01,  4.89634212e-01,  4.92538627e-01,\n",
       "           5.11463143e-01,  4.92773902e-01,  4.99606254e-01,\n",
       "           4.80158707e-01,  1.15329227e-01,  9.66281234e-02,\n",
       "           8.86441500e-02,  8.72674668e-02,  9.20107471e-02,\n",
       "           9.88786322e-02,  1.07748524e-01,  1.21656932e-01,\n",
       "           1.38731871e-01,  1.61984580e-01,  1.98877552e-01,\n",
       "           2.28259017e-01,  2.59971699e-01,  3.07922649e-01]]]])"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_lds_array = np.array(seed_lds_list)\n",
    "seed_lds_array[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "1c1d75dc-93fa-4af9-a3b7-d8a10e56feb5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1, 2, 8, 2, 27)"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_lds_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "018c6e64-d424-4018-a711-eee95131a802",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "100"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "K"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "fde83272-f2b9-4e41-a9e2-0d7b19810784",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('./val_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": 28,
   "id": "8b050b5f-b8cf-421b-bb44-956399f61fed",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(1):\n",
    "    for j in range(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": 29,
   "id": "ea85a313-addc-42eb-91ad-e671e3e13104",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[[0.25943542, 0.2623772 , 0.25582618, 0.25967046, 0.26045804,\n",
       "         0.26118926, 0.26220836, 0.25785084],\n",
       "        [0.3272736 , 0.32937628, 0.32689839, 0.32638516, 0.32786435,\n",
       "         0.33020343, 0.32866623, 0.32637177]]])"
      ]
     },
     "execution_count": 29,
     "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": 30,
   "id": "c180a94c-6b0d-48bc-baaa-64ac650c7964",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1, 2, 8)"
      ]
     },
     "execution_count": 30,
     "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": 31,
   "id": "11421adc-eb0c-4a34-8408-54ea5a2ba6f4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7faa40582eb0>"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA50AAAGaCAYAAACMtifbAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACD1ElEQVR4nO3deVwU5R8H8M/ustyXByAgiikgXmiihGZqonhkWnmkpmhK5W3knYqWRweeeR+JlWf+PEpRU1Lzvq+U8JZKFDwAAWHZ3ef3BzKysMshrgv2eb/cl8zMd555Znb22fnOPDMrE0IIEBERERERERmB3NQVICIiIiIiopcXk04iIiIiIiIyGiadREREREREZDRMOomIiIiIiMhomHQSERERERGR0TDpJCIiIiIiIqNh0klERERERERGw6STiIiIiIiIjIZJJxERERERERkNk04iIiIiIiIyGpMnnQsWLICnpycsLS0REBCA48ePFxiflJSEwYMHw9XVFRYWFvD29kZUVNQLqi0REREREREVh5kpF75+/XqEhYVh8eLFCAgIwJw5cxAcHIzY2Fg4Ozvni1epVGjdujWcnZ2xceNGuLu749atW3B0dHzxlSciIiIiIqJCyYQQwlQLDwgIQKNGjTB//nwAgFarhYeHB4YOHYqxY8fmi1+8eDG+/fZb/PXXX1AqlS+6ukRERERERFRMJks6VSoVrK2tsXHjRnTu3FkaHxISgqSkJGzdujXfPO3bt0f58uVhbW2NrVu3wsnJCT179sSYMWOgUCj0LiczMxOZmZnSsFarxYMHD1ChQgXIZLLnvl5EREREVDJCCDx69Ahubm6Qy01+NxgRlZDJutfeu3cPGo0GLi4uOuNdXFzw119/6Z3n+vXr+P3339GrVy9ERUXh6tWrGDRoELKyshAeHq53nhkzZmDKlCnPvf5EREREZFx///03KleubOpqEFEJmfSezuLSarVwdnbG0qVLoVAo0LBhQ/z777/49ttvDSad48aNQ1hYmDScnJyMKlWq4O+//4a9vf2LqjoRERERFVFKSgo8PDxgZ2dn6qoQ0XNgsqSzYsWKUCgUuHv3rs74u3fvolKlSnrncXV1hVKp1OlK6+vrizt37kClUsHc3DzfPBYWFrCwsMg33t7enkknERERUSnGW6GIXg4m6yRvbm6Ohg0bIjo6Whqn1WoRHR2NwMBAvfM0bdoUV69ehVarlcZdvnwZrq6uehNOIiIiIiIiMi2T3pkdFhaGZcuWYdWqVYiJicHAgQORlpaGfv36AQD69OmDcePGSfEDBw7EgwcPMHz4cFy+fBnbt2/H9OnTMXjwYFOtAhERERERERXApPd0du/eHYmJiZg0aRLu3LmD+vXrY+fOndLDheLi4nSeWObh4YFdu3bh008/Rb169eDu7o7hw4djzJgxploFIiIiIiIiKoBJf6fTFFJSUuDg4IDk5GTe00lERERUCvF4jejlwh8+IiIiIiIiIqNh0klERERERERGw6STiIiIiIiIjIZJJxERERERERkNk04iIiIiIiIyGiadREREREREZDRMOomIiIiIiMhomHQSERERERGR0TDpJCIiIiIiIqNh0klERERERERGw6STiIiIiIiIjIZJJxERERERERkNk04iIiIiIiIyGiadREREREREZDRMOomIiIiIiMhomHQSERERERGR0TDpJCIiIiIiIqNh0klERERERERGw6STiIiIiIiIjIZJJxERERERERkNk04iIiIiIiIyGiadREREREREZDRMOomIiIiIiMhomHQSERERERGR0TDpJCIiIiIiIqNh0klERERERERGw6STiIiIiIiIjIZJJxERERERERkNk04iIiIiIiIyGiadREREREREZDRMOomIiIiIiMhomHQSERERERGR0TDpJCIiIiIiIqNh0klERERERERGw6STiIiIiIiIjIZJJxERERERERkNk04iIiIiIiIyGiadREREREREZDRMOomIiIiIiMhomHQSERERERGR0ZSKpHPBggXw9PSEpaUlAgICcPz4cYOxkZGRkMlkOi9LS8sXWFsiIiIiIiIqKpMnnevXr0dYWBjCw8Nx+vRp+Pn5ITg4GAkJCQbnsbe3R3x8vPS6devWC6wxERERERERFZXJk85Zs2YhNDQU/fr1Q61atbB48WJYW1vj+++/NziPTCZDpUqVpJeLi8sLrDEREREREREVlZkpF65SqXDq1CmMGzdOGieXyxEUFIQjR44YnC81NRVVq1aFVqvFq6++iunTp6N27drFXrZKpco3Xi6Xw8zMTCfOEJlMBqVS+UyxWVlZEEK80FgAMDc3f6ZYtVoNrVb7XGKVSiVkMplRYzUaDTQazXOJNTMzg1wuLzWxWq0WarXaYKxCoYBCoSg1sUIIZGVlPZfY3J9PY8UCBX+W2Uboj2UbwTaCbUTxY9lGGI4taFsQUdlj0qTz3r170Gg0+a5Uuri44K+//tI7j4+PD77//nvUq1cPycnJiIiIQJMmTXDx4kVUrlw5X3xmZiYyMzOl4ZSUFADAzJkz9d4L6uXlhZ49e0rDERERBr+Iqlatir59+0rDc+fORXp6ut5YNzc3hIaGSsMLFixAcnKy3lgnJycMGjRIGl62bBkSExP1xjo4OGDEiBHScGRkJG7fvq031traGqNGjZKGV69ebbBrslKpxPjx46XhDRs24MqVK3pjASA8PFz6e/Pmzbh06ZLB2HHjxklfLtu2bcO5c+cMxo4cORI2NjYAgF27duHkyZMGY4cPHw5HR0cAQHR0dIEnLgYOHAhnZ2cAwIEDB7B//36DsQMGDIC7uzsA4OjRo9izZ4/B2JCQEHh6egIATp06hR07dhiM7dGjB7y9vQEAFy5cwNatWw3GdunSRTqxEhMTg40bNxqM7dSpE+rXrw8AuHr1KtauXWswtl27dmjcuDEAIC4uDqtWrTIYGxQUhKZNmwIA4uPjsXz5coOxzZs3R4sWLQAAiYmJWLRokcHYwMBAtGnTBgCQnJyMuXPnGoz19/dHhw4dAADp6emIiIgwGOvn54fOnTsDyD4wmjFjhsHYWrVqoWvXrtJwQbFsI7KxjXiKbUQ2thHZ2EZkK2kbcfr0aYOxRFT2mLx7bXEFBgaiT58+qF+/Ppo3b45NmzbByckJS5Ys0Rs/Y8YMODg4SC8PD48XXGMiIiIiIqL/LpkoqF+EkalUKlhbW2Pjxo3S2UYg+0xwUlJSgWd1c+vatSvMzMz0nq3Vd6XTw8MDiYmJsLe3zxfPbjH6Y9l1jl3n2HWu+LFsI54tlm1EyWJLw+eebQTbiLyxxW0jkpKS4OTkhOTkZL3Ha0RUtpg06QSAgIAANG7cGN999x2A7C+qKlWqYMiQIRg7dmyh82s0GtSuXRvt27fHrFmzCo1PSUmBg4MDGzEiIiKiUorHa0QvF5Pe0wkAYWFhCAkJgb+/Pxo3bow5c+YgLS0N/fr1AwD06dMH7u7u0v0TX3zxBV577TXUqFEDSUlJ+Pbbb3Hr1i0MGDDAlKtBREREREREepg86ezevTsSExMxadIk3LlzB/Xr18fOnTulhwvFxcVJXYYA4OHDhwgNDcWdO3dQrlw5NGzYEIcPH0atWrVMtQpERERERERkgMm7175o7K5BREREVLrxeI3o5VLmnl5LREREREREZQeTTiIiIiIiIjIaJp1ERERERERkNEw6iYiIiIiIyGiYdBIREREREZHRMOkkIiIiIiIio2HSSUREREREREbDpJOIiIiIiIiMhkknERERERERGQ2TTiIiIiIiIjIaJp1ERERERERkNEw6iYiIiIiIyGiYdBIREREREZHRMOkkIiIiIiIio2HSSUREREREREbDpJOIiIiIiIiMhkknERERERERGQ2TTiIiIiIiIjIaJp1ERERERERkNEw6iYiIiIiIyGiYdBIREREREZHRMOkkIiIiIiIio2HSSUREREREREbDpJOIiIiIiIiMhkknERERERERGQ2TTiIiIiIiIjIaJp1ERERERERkNEw6iYiIiIiIyGiYdBIREREREZHRMOkkIiIiIiIio2HSSUREREREREbDpJOIiIiIiIiMhkknERERERERGQ2TTiIiIiIiIjIaJp1ERERERERkNEw6iYiIiIiIyGiYdBIREREREZHRMOkkIiIiIiIio2HSSUREREREREbDpJOIiIiIiIiMhkknERERERERGU2pSDoXLFgAT09PWFpaIiAgAMePHy/SfOvWrYNMJkPnzp2NW0EiIiIiIiJ6JiZPOtevX4+wsDCEh4fj9OnT8PPzQ3BwMBISEgqc7+bNmxg5ciSaNWv2gmpKRERERERExSUTQghTViAgIACNGjXC/PnzAQBarRYeHh4YOnQoxo4dq3cejUaDN954Ax9++CEOHDiApKQkbNmypUjLS0lJgYODAxITE2Fvb59vulwuh5mZmTSsUqkMliWTyaBUKp8pNisrC4Y2vbFiAcDc3PyZYtVqNbRa7XOJVSqVkMlkRo3VaDTQaDTPJdbMzAxyubzUxGq1WqjVaoOxCoUCCoWi1MQKIZCVlfVcYnN/Po0VCxT8WWYboT+WbQTbCLYRxY9lG2E4NikpCU5OTkhOTtZ7vEZEZYtZ4SHGo1KpcOrUKYwbN04aJ5fLERQUhCNHjhic74svvoCzszP69++PAwcOFLiMzMxMZGZmSsMpKSkAgJkzZ8LS0jJfvJeXF3r27CkNR0REGPwiqlq1Kvr27SsNz507F+np6Xpj3dzcEBoaKg0vWLAAycnJemOdnJwwaNAgaXjZsmVITEzUG+vg4IARI0ZIw5GRkbh9+7beWGtra4waNUoaXr16NW7duqU3VqlUYvz48dLwhg0bcOXKFb2xABAeHi79vXnzZly6dMlg7Lhx46Qvl23btuHcuXMGY0eOHAkbGxsAwK5du3Dy5EmDscOHD4ejoyMAIDo6usB9aODAgXB2dgYAHDhwAPv37zcYO2DAALi7uwMAjh49ij179hiMDQkJgaenJwDg1KlT2LFjh8HYHj16wNvbGwBw4cIFbN261WBsly5dULt2bQBATEwMNm7caDC2U6dOqF+/PgDg6tWrWLt2rcHYdu3aoXHjxgCAuLg4rFq1ymBsUFAQmjZtCgCIj4/H8uXLDcY2b94cLVq0AAAkJiZi0aJFBmMDAwPRpk0bAEBycjLmzp1rMNbf3x8dOnQAAKSnpyMiIsJgrJ+fn9T1PisrCzNmzDAYW6tWLXTt2lUaLiiWbUQ2thFPsY3IxjYiG9uIbCVtI06fPm0wlojKHpN2r7137x40Gg1cXFx0xru4uODOnTt65zl48CBWrFiBZcuWFWkZM2bMgIODg/Ty8PAocb2JiIiIiIioaEzavfb27dtwd3fH4cOHERgYKI0fPXo09u/fj2PHjunEP3r0CPXq1cPChQvRrl07AEDfvn0L7F6r70qnh4cHu9cWM5Zd59h1jl3nih/LNuLZYtlGlCy2NHzu2Uawjcgby+61RP9tJk06VSoVrK2tsXHjRp0n0IaEhCApKSlfV6KzZ8+iQYMG0pcPAKkBk8vliI2NRfXq1QtcZs49nWzEiIiIiEonHq8RvVxM2r3W3NwcDRs2RHR0tDROq9UiOjpa58pnjpo1a+LChQs4e/as9Hr77bfRsmVLnD17ll1niYiIiIiIShmTPkgIAMLCwhASEgJ/f380btwYc+bMQVpaGvr16wcA6NOnD9zd3TFjxgxYWlqiTp06OvPnPBQi73giIiIiIiIyPZMnnd27d0diYiImTZqEO3fuoH79+ti5c6f0cKG4uDjpPhUiIiIiIiIqW0z+O50vGu8RICIiIirdeLxG9HLhJUQiIiIiIiIyGiadREREREREZDRMOomIiIiIiMhomHQSERERERGR0TDpJCIiIiIiIqNh0klERERERERGw6STiIiIiIiIjIZJJxERERERERkNk04iIiIiIiIyGiadREREREREZDRMOomIiIiIiMhomHQSERERERGR0TDpJCIiIiIiIqNh0klERERERERGw6STiIiIiIiIjIZJJxERERERERkNk04iIiIiIiIyGiadREREREREZDRMOomIiIiIiMhomHQSERERERGR0TDpJCIiIiIiIqNh0klERERERERGw6STiIiIiIiIjIZJJxERERERERkNk04iIiIiIiIyGiadREREREREZDRMOqn0S7sHxJ/L/p+I6L+I7SAREZVhZqauwEsv7R6Q8i9g7w7YVDR1bcqey78Be6cBmY8ACzug5eeAdxtT14qIiottYfEJAQgtcHknsO8rIDMVsLAFWowFvIIBmRyQybJfVDjug0REJiMTQghTV+JFSklJgYODA5KTk2Fvb2/chZW2hEkIQKvJPogROf9rn457EdO0emIMTct8BJyKBNSPAXMbQJUOKK0A//6ApT0gVwAyRZ7/5SYaX4oP+nigVXLchiVTnLYwJ9HSarLbBp3/hZ5x2gLi845/0t5otXrG6WmzCiwrpxwDsUVadiH1FALQqIC7FwGtGlAoAU0WIDcDXGoDCvOn201KQJ+0RzJ5nleecZBlt12QGYgxVJasgPlzxxRUlyedrAzOn7suhubPvXxDdci1/L+PA6dWAlnp2d8njT8GPJsZbtdlckAu1237df4uxW2+sbzgdvCFHq8RkdEx6TSWtHvAT+8BqXcBuTmgSgWUlkDDEEBpreegJW/y9azTCkgCy5rMVCAxJvtASybPXg9NFuDkm322v7QpcpKa6+BFblb02GcZH38OuLAByMrITtjr9wQq+z+pcM4VkicHT/n+1hOTO07noEv2JKSkZRmaP29ZKFlZ+epeQFnX9gIHZwGqtOyD1aYjgGpvPP1sQeT6LGqfJk0i7/i8sbnjNLrxeHKCCKLgOCke+cfpixNCT33zli301KG4cTkvZB/kX9+bnTwpLAB1RvZnunLj7P0/bwJGuspaO1gaFTVxL64C2/w8bbFMlj+uoLa8sPh83xd6hguLL+jkat5pN/YDB+dkt4OWDi/kJDqTTqKXC7vXGkvKv9ln9eVKIDMp+0AhPQ34a0fpPFCQzhTn+cKSvviKMy33F5aeL1690/TMp0oHjszPPmi1sAMyUgCrckC9boC5dQFXHwoYX5xYfeMLOkej1QDQAKXluDnvgdbjB8DB2SU/0PovybsNH8UD20ZwGxZHZiqQ9Th7+wlN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qHfv3hgxYgQ6deqEvXv34uzZs5g4cSK2bt2K3377zeB8tWvXRnx8vM7rjTfekKavWLECo0ePxtq1a5GRkaG3jNjYWMTHx2PXrl3IzMxEhw4doFKppOn79+/H4MGDcfToUezevRtZWVlo06YN0tLSCl2vyMhIdOvWDSkpKTh27FgxtkjZZWtriwoVKpSojJ9++gmzZ8/GrFmzEBMTg1mzZsHGxuY51bBocu8Dz9Px48fx6quvIiYmBgsWLMCff/6Jffv2YcCAAVi0aBEuXrxolOUSERG99AQRkQHr168XAMSWLVvyTdNqtSIpKUkIIUR4eLjw8/OTpuUdzuv69evCyspKJCUliYCAALF69Wqd6Xv37hUAxMOHD6Vxv/zyiwAgzp07Z7DchIQEAUDs37+/wPXSarXilVdeETt37hRjxowRoaGhhS7/zJkzAoC4ceOGND33Kzw8XAghxIMHD0Tv3r2Fo6OjsLKyEm3bthWXL1+Wylm5cqVwcHAQv/76q/D29hZWVlbivffeE2lpaSIyMlJUrVpVODo6iqFDhwq1Wi3NV9RyN2/eLGrUqCEsLCxEmzZtRFxcnBST930JCQkRnTp1koY1Go2YPn268PT0FJaWlqJevXri559/1tk2P/74o3Bzcytw++aujz4AxObNm6Xh8+fPi5YtWwpLS0tRvnx5ERoaKh49epSvnlOnThWurq7C09NTCCHEggULpHV1dnYW7733XrHWJTetVit8fX1Fw4YNhUajMRiTIy4uTnTt2lU4ODiIcuXKibffflvcuHEjX52//fZbUalSJVG+fHkxaNAgoVKpCtpsRERELyVe6SQig1avXg0fHx906tQp3zSZTAYHB4dnKnflypXo0KEDHBwc8MEHH2DFihUFxicnJ2PdunUAAHNz8wLjAKB8+fIFlrd3716kp6cjKCgIH3zwAdatW1ekq6M5mjRpgjlz5sDe3l66ijty5EgA2fdJnjx5Er/88guOHDkCIQTat2+PrKwsaf709HTMmzcP69atw86dO7Fv3z688847iIqKQlRUFH788UcsWbIEGzdulOYparnTpk3DDz/8gEOHDiEpKQnvv/9+kddrxowZ+OGHH7B48WJcvHgRn376KT744APs379fimnVqhWSk5MxceLEIpdbkLS0NAQHB6NcuXI4ceIEfv75Z+zZswdDhgzRiYuOjkZs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7dWrFypWrIhOnTrhwIEDuHHjBvbt24dhw4bhn3/+KfY2ICIietkx6SQig2QyGdasWYNZs2Zhy5YtaN68OerVq4fJkyejU6dOCA4OLlZ533//Pd555x3pKaC5vffee/jll19w7949g/MPGTIEMTEx+PnnnwEAixYtQnJyMlq0aAFXV1fptX79er3zr1ixArVq1ULNmjXzTXvnnXeQkJCAqKgoKJVKrF27Fn/99Rfq1auHr7/+Ot9VvCZNmuCTTz5B9+7d4eTkhG+++QZA9pN5GzZsiLfeeguBgYEQQkhllkRRyrW2tsaYMWPQs2dPNG3aFLa2tga3hT5ffvklJk6ciBkzZsDX1xdt27bF9u3bpSvIbm5uOH78OCpWrIh3330XDRo0wA8//IAffvgB27dvx9KlSzFr1qxirZe1tTV27dqFBw8eoFGjRujSpQtatWqF+fPnFzifo6MjNm3ahDfffBO+vr5YvHgx1q5di9q1axdpXfR57bXXcOrUKfj4+GDw4MGoVasWmjRpgrVr12L27NkYOHCgVOc//vgDVapUwbvvvgtfX1/0798fGRkZsLe3L9b6ExER/RfIREmeFEJERERERERUAF7pJCIiIiIiIqNh0klERERERERGw6STiIiIiIiIjIZJJxERERERERkNk04T6t27N6ZPn2608mUyGbZs2WK08ku7yZMno379+qauBhVBZGQkHB0ddcYtXboUHh4ekMvlmDNnjknqVZibN29CJpPl+w1Pejm0aNECI0aMkIY9PT1L7b6Y42XfJ0varvft2xedO3eWhvO+x5Tf+++/n+8no4iIiotJp4mcO3cOUVFRGDZsmDTueR/QxMfHo127ds+tPNI1efJkyGQyfPLJJzrjz549C5lMhps3bz5TuZGRkZDJZDovS0tLnRghBCZNmgRXV1dYWVkhKCgIV65c0Yl58OABevXqBXt7ezg6OqJ///5ITU3ViTl//jyaNWsGS0tLeHh4SD/78aJ1794dly9floZTUlIwZMgQjBkzBv/++y8++ugjk9Qrt7wHqwDg4eGB+Ph41KlTxzSVQulKMvRto40bN8LS0vKZD1qnTZuGJk2awNraOt+JiRxxcXHo0KEDrK2t4ezsjFGjRkGtVj/T8gpy4sSJUrEvFqQ07JPGNHLkSERHRz+38jZt2oQvv/zyuZVXFIsWLUK9evVgb28P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iMuXL4sJEyYIS0tLcevWLSmmatWqonz58mLx4sXi8uXLYuDAgcLe3l60bdtWbNiwQcTGxorOnTsLX19fodVqdbaLv7+/OHz4sDh58qRo3LixaNKkiVRu3oOTn376Sbi6uor//e9/4vr16+J///ufKF++vIiMjBRCCPHtt98KDw8P8ccff4ibN2+KAwcOiDVr1hjcNjnlnzp1SsjlcukgRF/SaWNjU+Dr448/lmJXrlwpFAqFqFKliqhcubJ4++23xZ9//ilNv3btWr6DSiGEeOONN8SwYcOEEEKsWLFCODo66kzPysoSCoVCSgJ69+6tc/AlhBC///67ACAePHhgcL3zKmrSWdC+lzuhSE9PF3v27BEAxPHjx0V8fLxQq9Vi06ZNQqlUigULFojY2Fgxc+ZMoVAoxO+//65TF2dnZ/H999+La9euiVu3bonw8HBha2srunTpIi5evCh++eUXYW5uLoKDg8XQoUPFX3/9Jb7//nsBQBw9elTvOj569Eh069ZNtG3bVvp8ZmZmGkw6X3vtNXHw4EFx+vRpUaNGDdG8eXPRpk0bcfr0afHHH3+IChUqiK+++koqf+rUqaJmzZpi586d4tq1a2LlypXCwsJCSgAHDx4s6tevL06cOCFu3Lghdu/eLX755RchhBDHjx8XAMSePXtEfHy89NksbH/PqXvlypXFxo0bxaVLl8SAAQOEnZ2duHfvXqHL1ScnkRg9erSwtbWVTj7lNm3atEI/D7nbhxyGks6JEyfmS0KuX78uAIjTp08brGteAwcOFFWqVBF79uwR58+fF2+99Zaws7MrNOl0d3cX69evl9opT09P8eabb4qdO3eKS5cuiddee020bdtWmuePP/4Q9vb2IjIyUly7dk389ttvwtPTU0yePFmn3MqVK4s1a9aIK1euiGHDhglbW1vpvS3ofcm7T/7zzz/C2tpaDBo0SMTExIjNmzeLihUr6iSVzZs3F/b29mLy5Mni8uXLYtWqVUImk4nffvtNCCHEzz//LOzt7UVUVJS4deuWOHbsmFi6dKnBbRkeHi5sbGzEm2++Kc6cOSP2798vatSoIXr27CnFhISECFtbW9G7d2/x559/ij///FOkpqYKV1dX8e6774oLFy6I6OhoUa1aNRESEqJTdlGTzq+//lqUK1dO/O9//5O+J+3s7ApNOov7fXTr1q1C9+ncJ2dzU6vVYu3atcLc3FxcvHjR4LosW7ZMVKxY0eD0iIgI4eDgINLT06VxAwcOFK1atRJjxowRbm5uwsvLS3z22Wc6MatXrxYODg7i2LFjQojs75eaNWvmq++OHTuEubm5yMjIMFgHIqKCMOk0gc2bNwuFQiF9YeXIe0AjxNOrPjlXFw3RaDTCzs5O/Prrr9I4fUln7jOpFy9eFABETEyM3jIPHDgg7O3t833JVK9eXSxZskQaHjRokPD29hY9e/YUdevWLfRLqXbt2uK7777TWe8PPvhAGo6PjxcAxMSJE6VxR44cEQB0kvG8SUJMTIwAIH155j04qV69er4k8ssvvxSBgYFCCCGGDh0q3nzzzXzviyG5y3///fels8X6ks4rV64U+Lp7964Ue/jwYbFq1Spx5swZsW/fPvHWW28Je3t78ffffwshsq8mAxC3b9/WqU/Xrl1Ft27dhBDZB/be3t756uzk5CQWLlwohBCidevW4qOPPtKZnrNPXLp0qUjbQIiiJ50F7Xt5Ewp927BJkyYiNDQ03zq3b99epy4jRozQiQkPDxfW1tY6J2SCg4OFp6en0Gg00jgfHx8xY8YMg+uZ+ypeDkNJZ+5ka8aMGQKAuHbtmjTu448/FsHBwUIIITIyMoS1tXW+Xgf9+/cXPXr0EEII0bFjR9GvXz+99dJ3ZUuIwvf3nPlyJ79ZWVmicuXK4uuvvy50ufqEhIQIc3NzAUBER0frjbl//36hnwd9J8IMJZ2hoaGiTZs2OuPS0tIEABEVFVWkej969EiYm5uLDRs26NTTysqq0KRzwoQJ0nBOO7VixQpp3Nq1a4WlpaU03KpVq3w9KH788Ufh6upqsNzU1FQBQOzYsUMIUbz9Yfz48cLHx0enXVuwYIGwtbWV9v/mzZvnu4rVqFEjMWbMGCGEEDNnzhTe3t5CpVLpXWZe4eHhQqFQiH/++Ucat2PHDiGXy6U2PCQkRLi4uOhcjV66dKkoV66cSE1NlcZt375d50p2cZJOV1dX8c0330jDOft3YUlncb+PsrKyCt2n815tPH/+vLCxsREKhUI4ODiI7du3G1yPxMREUaVKFTF+/HiDMb6+vmLgwIE644KDg4WFhYXo0KGDOHbsmNi+fbuoWrWq6Nu3r07c3LlzhVKpFGZmZgKA+OSTT/KVf+7cOQFA3Lx502AdiIgKwns6TeDx48ewsLDId5+eIebm5qhXr57OuLt372LChAnYt28fEhISoNFokJ6ejri4uALLyl1Ozr1yCQkJqFmzZr7Yc+fOITU1FRUqVMhX/2vXrknDERERqFOnDn7++WecOnUKFhYW0rTU1FRMnjwZ27dvR3x8PNRqNR4/fpyvnrnr5eLiAgCoW7duvnEJCQnS/UpmZmZo1KiRFFOzZk04OjoiJiYGjRs31ik/LS0N165dQ//+/REaGiqNV6vVcHBwAJB9P0zr1q3h4+ODtm3b4q233kKbNm3yb0Q9pk6dCl9fX/z2228699PkqFGjRpHKAYDAwEAEBgZKw02aNIGvry+WLFnywh948TwVZ9/TJyYmJt+9pk2bNsXcuXN1xvn7++eb19PTE3Z2dtKwi4sLFAqFzr3RLi4uOg/gKIm8+7O1tTVeeeUVnXHHjx8HAFy9ehXp6elo3bq1ThkqlQoNGjQAAAwcOBDvvfceTp8+jTZt2qBz585o0qSJweUXZX/PkXtfMzMzg7+/P2JiYp5puTnrfu/ePYSHh6Nx48b57r8rX768Se6jK8i1a9egUqkQEBAgjStfvjx8fHwKnbcobVdGRgZSUlJgb2+Pc+fO4dChQ5g2bZoUo9FokJGRgfT0dFhbW+cr18bGBvb29tL+WZz3JSYmBoGBgTrfN02bNkVqair++ecfVKlSJd/ygOzPaM7yunbtijlz5uCVV15B27Zt0b59e3Ts2BFmZoYPIapUqQJ3d3dpODAwEFqtFrGxsVIbXrduXZ37OGNiYuDn5wcbGxuduubMl7N9iyI5ORnx8fE672nO/i2EKHDe4n4fmZmZFauNBwAfHx+cPXsWycnJ2LhxI0JCQrB//37UqlVLJy4lJQUdOnRArVq1MHnyZL1lHTlyBDExMfjxxx91xmu1WshkMqxevVr63M+aNQtdunTBwoULYWVlhX379mH69OlYuHAhAgICcPXqVQwfPhxffvklJk6cKJWVc899enp6sdaTiCgHk04TqFixItLT04v84AQrK6t8CWpISAju37+PuXPnSk+lCwwMhEqlKrCs3A9VySkz90MFcktNTYWrqyv27duXb1rup0heu3YNt2/fhlarxc2bN3W+nEeOHIndu3cjIiICNWrUgJWVFbp06ZKvnvrqVZy6Fibnqa3Lli3TOQgBsh+8AQCvvvoqbty4gR07dmDPnj3o1q0bgoKCpAc3FKR69eoIDQ3F2LFj9T7spLAHX3zwwQdYvHix3mlKpRINGjTA1atXATx9QNTdu3d1HrJz9+5d6acEKlWqlC+BUqvVePDggTR/pUqVcPfuXZ2YnOHiPIhEJpPlO4jLysrSux655wGe/f0sSO4DVn3Lzlm+vnHPqz5517WgZeXsm9u3b9c5SAcgncBp164dbt26haioKOzevRutWrXC4MGDERERoXf5Rdnfi6K4ywUAd3d3bNy4ES1btkTbtm2xY8cOnYR/+vTphT7g59KlS1IyVJhKlSpJCXyOZ9mPn1Vx267U1FRMmTIF7777br6ycj+luqB95lnel+KsR97leXh4IDY2Fnv27MHu3bsxaNAgfPvtt9i/f3+JHtSl77NaGhT3PY2Li8uXLOY1fvx4jB8/Xho2NzeXEtWGDRvixIkTmDt3LpYsWSLFPHr0CG3btoWdnR02b95scFsvX74c9evXR8OGDXXGu7q6wt3dXedEk6+vL4QQ+Oeff+Dl5YWJEyeid+/eGDBgAIDs5DotLQ0fffQRPv/8c+nE3IMHDwCUjYdpEVHpxKTTBHISg0uXLun83pi5uTk0Gk2Ryjh06BAWLlyI9u3bAwD+/vtv3Lt377nW89VXX8WdO3dgZmYGT09PvTEqlQoffPABunfvDh8fHwwYMAAXLlyQrvYdOnQIffv2xTvvvAMg+4DrWX9KJC+1Wo2TJ09KVzVjY2ORlJQEX1/ffLEuLi5wc3PD9evX0atXL4Nl2tvbo3v37ujevTu6dOmCtm3b4sGDB0W6MjNp0iRUr14d69atyzetsJ+zsLe3NzhNo9HgwoUL0ntdrVo1VKpUCdHR0dL+k5KSgmPHjmHgwIEAsq8qJCUl4dSpU9KByO+//w6tVislIYGBgfj88891nvC6e/du+Pj4oFy5coWubw4nJyfEx8dLw1euXDHK2XBfX18cOnQIISEh0rhDhw4VerD3vBTn81kctWrVgoWFBeLi4tC8eXODcU5OTggJCUFISAiaNWuGUaNGISIiQjpxlbtuRd3fAeDo0aN44403AGR/pk6dOoUhQ4YUutyCVK1aFfv375cSz507d0qJ5yeffIJu3boVOL+bm1uB03MLDAzEtGnTkJCQILU7u3fvhr29fZH3jerVq0OpVOLYsWNSsvvw4UNcvny5wPfkWbz66quIjY0t9pWxvIr6vvj6+uJ///sfhBBSsnTo0CHY2dmhcuXKRV6elZUVOnbsiI4dO2Lw4MGoWbMmLly4gFdffVVvfFxcHG7fvi29l0ePHoVcLi/w6rGvry8iIyORlpYmJaSHDh0qdD59HBwc4OrqimPHjuXbvw3V+Vm5ubkV2sYX9h2i1WqRmZkpDaekpCA4OBgWFhb45Zdf8v1sVo7U1FRs2LABM2bMyDetadOm+Pnnn5Gamiqd+Lx8+TLkcrn03qenp+d7Gn7OiancJxP//PNPVK5cGRUrVixwPYiIDGHSaQJOTk549dVXcfDgQZ2k09PTE3/88Qfef/99WFhYFNi4e3l54ccff4S/vz9SUlIwatQonZ+ceB6CgoIQGBiIzp0745tvvoG3tzdu376N7du345133oG/vz8+//xzJCcnY968ebC1tUVUVBQ+/PBDbNu2Tarnpk2b0LFjR8hkMkycOPG5Xk0aOnQo5s2bBzMzMwwZMgSvvfZavq61OaZMmYJhw4bBwcEBbdu2RWZmJk6ePImHDx8iLCwMs2bNgqurKxo0aAC5XI6ff/4ZlSpVMvjbgHm5uLggLCwM3377bb5pxTnA/OKLL/Daa6+hRo0aSEpKwrfffotbt25JZ6JlMhlGjBiBqVOnwsvLS/rJFDc3N+k3En19fdG2bVuEhoZi8eLFyMrKwpAhQ/D+++9LB4E9e/bElClT0L9/f4wZMwZ//vkn5s6di9mzZxe5rgDw5ptvYv78+QgMDIRGo8GYMWOM8jMlo0aNQrdu3dCgQQMEBQXh119/xaZNm7Bnz57nvix9PD09sWvXLsTGxqJChQr5uqk+Kzs7O4wcORKffvoptFotXn/9dSQnJ+PQoUOwt7dHSEgIJk2ahIYNG6J27drIzMzEtm3bpJMrzs7OsLKyws6dO1G5cmVYWlrCwcGh0P09x4IFC+Dl5QVfX1/Mnj0bDx8+xIcffggABS63MB4eHti3bx9atmyJ4OBg7Ny5E/b29sXuXhsXF4cHDx4gLi4OGo1GOrivUaMGbG1t0aZNG9SqVQu9e/fGN998gzt37mDChAkYPHiwTlf/gtja2qJ///4YNWoUKlSoAGdnZ52rPM/TpEmT8NZbb6FKlSro0qUL5HI5zp07hz///BNTp04tchlFfV8GDRqEOXPmYOjQoRgyZAhiY2MRHh6OsLCwIq9fZGQkNBoNAgICYG1tjZ9++glWVlaoWrWqwXksLS0REhKCiIgIpKSkYNiwYejWrVuBV5979eqF8PBwhISEYPLkyUhMTMTQoUPRu3fvYnWtzTF8+HDpp0lq1qyJWbNmISkpqdjlFKa43WvHjRuHdu3aoUqVKnj06BHWrFmDffv2YdeuXQCe/pxVeno6fvrpJ6SkpCAlJQVA9vFD7t4K69evh1qtxgcffJBvOT179sSXX36Jfv36YcqUKbh37x5GjRqFDz/8UDpe6NixI2bNmoUGDRpI3WsnTpyIjh076iznwIEDRb7dhIhIn+f/jUpFMmDAAKxevVpn3BdffIGbN2+ievXqhXZhWbFiBR4+fIhXX30VvXv3xrBhw/TeS1gSMpkMUVFReOONN9CvXz94e3vj/fffx61bt+Di4oJ9+/Zhzpw5+PHHH2Fvbw+5XI4ff/wRBw4cwKJFiwBk3z9Srlw5NGnSBB07dkRwcPBzO8tsbW2NMWPGoGfPnmjatClsbW2xfv16g/EDBgzA8uXLsXLlStStWxfNmzdHZGQkqlWrBiD74P+bb76Bv78/GjVqhJs3byIqKqpYB54jR44s8W/IPXz4EKGhofD19UX79u2RkpKCw4cP61y1GT16NIYOHYqPPvoIjRo1QmpqKnbu3KlzNnz16tWoWbMmWrVqhfbt2+P111/H0qVLpekODg747bffcOPGDTRs2BCfffYZJk2apHPf5L59+yCTyQq8Oj1z5kx4eHigWbNm6NmzJ0aOHCndl/Y8de7cGXPnzkVERARq166NJUuWYOXKlWjRosVzX5Y+oaGh8PHxgb+/P5ycnHDo0KHnVnbO/VMzZsyQThhs375d2jfNzc0xbtw41KtXD2+88QYUCoV0Rd3MzAzz5s3DkiVL4Obmhk6dOgEofH/P8dVXX+Grr76Cn58fDh48iF9++UU64VXQcouicuXK2LdvH+7du4fg4GDpwLk4Jk2ahAYNGiA8PBypqalo0KABGjRogJMnTwLIviqzbds2KBQKBAYG4oMPPkCfPn3wxRdfSGXcvHkTMplM760COb799ls0a9YMHTt2RFBQEF5//fV83RWfh+DgYGzbtg2//fYbGjVqhNdeew2zZ88uMIHLqzjvi7u7O6KionD8+HH4+fnhk08+Qf/+/TFhwoQiL8/R0RHLli1D06ZNUa9ePezZswe//vprvvv9c6tRowbeffddtG/fHm3atEG9evWwcOHCApdjbW2NXbt24cGDB2jUqBG6dOmCVq1aYf78+UWua26fffYZevfujZCQEAQGBsLOzk7qdWNKCQkJ6NOnD3x8fNCqVSucOHECu3btku7rPn36NI4dO4YLFy6gRo0acHV1lV5///23TlkrVqzAu+++q/fkqK2tLXbv3o2kpCT4+/ujV69e6NixI+bNmyfFTJgwAZ999hkmTJiAWrVqoX///ggODtbp5puRkYEtW7bo3B9ORFRcMlHYHfVkFI8fP4aPjw/Wr1+v8yAPKprIyEiMGDHCKGet6amVK1di+vTpuHTpklGuXpLp3Lx5E9WqVcOZM2d0ely8jPbu3Yt3330X169fL1bXcXo2kydPxpYtWwrtcvosxo0bhwMHDuDgwYPPvWzSb9GiRdi8eTN+++03U1eFiMowXuk0ESsrK/zwww/P/T5MoucpKioK06dPZ8JJZVpUVBTGjx/PhLMME0Lg2rVriI6ORu3atU1dnf8UpVKJ7777ztTVIKIyjvd0mtCL6hZI9Kx+/vlnU1eBqMT03WdNZUtycjJq1aqFRo0aSU+BLehWhh07dqBZs2YvqnovtZznCRARlQS71xIREVGZk/MzUvq4u7s/94frERHRs2PSSUREREREREbDezqJiIiIiIjIaJh0EhERERERkdEw6SQiIiIiIiKjYdJJRERERERERsOkk4iIiIiIiIyGSScREREREREZDZNOIiIiIiIiMhomnURERERERGQ0/wclJMSgGo0xvQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(8,4))\n",
    "\n",
    "for idx, f in enumerate(f_name_list):\n",
    "    plt.plot(ckpt_list, seed_lds[0, idx], label=f, marker='.', alpha=0.75)\n",
    "\n",
    "plt.xlabel('checkpoint steps \\n CIFAR2 Automobile&Horse Gen \\n (train examples N=5000, uniform timesteps K=10, dimensions proj_dim=32768)')\n",
    "plt.ylabel('LDS')\n",
    "plt.xticks(ticks=ckpt_list, labels=ckpt_list, rotation=60)\n",
    "plt.ylim(0, 0.6)\n",
    "\n",
    "plt.axhline(y=0.5, color='gray', linestyle='dashed')\n",
    "plt.axhline(y=0.4, color='gray', linestyle='dashed')\n",
    "plt.axhline(y=0.3, color='gray', linestyle='dashed')\n",
    "plt.axhline(y=0.2, color='gray', linestyle='dashed')\n",
    "plt.axhline(y=0.1, color='gray', linestyle='dashed')\n",
    "\n",
    "plt.legend(loc=(1.04, 0))"
   ]
  },
  {
   "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": 32,
   "id": "70fb08b2-f74f-4492-b47a-b0bbc9b041e0",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('./val_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": 33,
   "id": "1607c463-df77-4f5c-bc18-866080849dd4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(seed_score_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "fc70e90a-ac36-48b0-82ed-6a3b9aa6a95f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(seed_score_list[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "45b82a31-0e5d-4292-9018-29364865a6ae",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "8"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(seed_score_list[0][0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "13219d07-cb2b-4c6b-a14c-f1f8642ffd3d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1000, 5000)"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_score_list[0][0][0].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "b012a62f-d6b4-4da4-97dd-196dad83b36f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1000, 5000)"
      ]
     },
     "execution_count": 37,
     "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": 38,
   "id": "134a59cf-e751-49b5-a5aa-8d1a0de4450c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.259 (avg p value 0.152472)\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:1].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": 39,
   "id": "e7105050-c8e3-47e1-a532-c4111d35421e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.359 (avg p value 0.060159)\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": "c8d57e50-2f80-47d9-a465-0de105add7ba",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a56d7737-81fb-4e52-9397-40d5b52d630e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f61dacbd-538e-4bea-8469-ff50ae689ac0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "51696270-ce20-439b-bb64-9842b750df34",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "113cb8fd-cd32-465f-bdb6-c4b5f50677d0",
   "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
}
