{
 "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": 1,
   "id": "c4cadde9-8859-435a-b6ba-09aa42bb468d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "\n",
    "os.environ[\"CUDA_DEVICE_ORDER\"]=\"PCI_BUS_ID\"   \n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"]='0'\n",
    "\n",
    "os.environ[\"HF_HOME\"]=\"~/codes/.cache/huggingface\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "2f7cd96b-ca27-4ce1-ac2d-c3dd67e069b7",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import random\n",
    "import numpy as np\n",
    "\n",
    "def set_seeds(seed):\n",
    "    random.seed(seed)\n",
    "    np.random.seed(seed)\n",
    "    torch.manual_seed(seed)\n",
    "    torch.backends.cudnn.deterministic = True\n",
    "    torch.backends.cudnn.benchmark = False\n",
    "    \n",
    "set_seeds(42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "4ff495b8-8df0-49e8-a409-4ed9601c8143",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "def show_images(images, scores, test_artist, train_artists):\n",
    "    n: int = len(images)\n",
    "    f = plt.figure(figsize=(16, 2))\n",
    "    for i in range(n):\n",
    "        # Debug, plot figure\n",
    "        ax = f.add_subplot(1, n, i + 1)\n",
    "        if i==0:\n",
    "            pass\n",
    "            ax.title.set_text(test_artist)\n",
    "        else:\n",
    "            ax.title.set_text(str(np.round(scores[i-1], 4))+'\\n'+train_artists[i-1])\n",
    "            ax.axis('off')\n",
    "        if images[i]==None:\n",
    "            pass\n",
    "        else:\n",
    "            plt.imshow(images[i])\n",
    "\n",
    "    plt.show(block=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "c4e89a09-d6ff-46a1-8a9e-9c6f9c167114",
   "metadata": {},
   "outputs": [],
   "source": [
    "from datasets import load_dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2682e2c4-9275-4bae-a732-74b981a358d2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "fb2dc562-293c-4e74-8e97-141fc7465938",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "bda41875-8976-4852-823a-91dc1f42aebf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5000"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open('../../data/indices/5000-0.5/idx-train.pkl', 'rb')  as handle:\n",
    "    idx_train = pickle.load(handle)\n",
    "len(idx_train)   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "773b1a12-d60d-4ed8-8f61-b03a3af61e71",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "40c86797-31d5-45d0-b46f-52f8c84dd130",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'load_dataset' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[1], line 3\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;66;03m# from datasets import load_dataset\u001b[39;00m\n\u001b[0;32m----> 3\u001b[0m dataset \u001b[38;5;241m=\u001b[39m \u001b[43mload_dataset\u001b[49m(\n\u001b[1;32m      4\u001b[0m     \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mcifar10\u001b[39m\u001b[38;5;124m'\u001b[39m,\n\u001b[1;32m      5\u001b[0m     \u001b[38;5;66;03m# args.dataset_config_name,\u001b[39;00m\n\u001b[1;32m      6\u001b[0m     \u001b[38;5;66;03m# cache_dir=args.cache_dir,\u001b[39;00m\n\u001b[1;32m      7\u001b[0m     \u001b[38;5;66;03m# split=\"train\",\u001b[39;00m\n\u001b[1;32m      8\u001b[0m )\n",
      "\u001b[0;31mNameError\u001b[0m: name 'load_dataset' is not defined"
     ]
    }
   ],
   "source": [
    "from datasets import load_dataset\n",
    "\n",
    "dataset = load_dataset(\n",
    "    'cifar10',\n",
    "    # args.dataset_config_name,\n",
    "    # cache_dir=args.cache_dir,\n",
    "    # split=\"train\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c6632d56-9134-4720-99a9-1853fe349039",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5df420e1-7166-4e5b-baa3-a012fe7e32e1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "f2ce6b6b-ff45-4156-9606-7c87046e751a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<PIL.PngImagePlugin.PngImageFile image mode=RGB size=32x32>"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from datasets import DatasetDict, Dataset, load_dataset, Image\n",
    "\n",
    "train_dataset = dataset['train'].select(idx_train)\n",
    "train_dataset[0][\"img\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "087ea1db-01c9-4e6a-a402-8b8a9aa93e8b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "df = pd.DataFrame()\n",
    "df['path'] = ['{}/{}.png'.format('../../saved/5000-0.5/gen', i) for i in range(1000)]\n",
    "\n",
    "from datasets import DatasetDict, Dataset, load_dataset, Image\n",
    "dataset = DatasetDict({\n",
    "\"train\": Dataset.from_dict({\n",
    "    \"img\": df['path'].tolist(),\n",
    "}).cast_column(\"img\", Image()),})\n",
    "val_dataset = dataset[\"train\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "f2babffa-91ab-43ed-8312-2ef606f611bf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<PIL.PngImagePlugin.PngImageFile image mode=RGB size=32x32>"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "val_dataset[0]['img']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "a17ef712-5e24-4c38-bd27-fbf34ece6446",
   "metadata": {},
   "outputs": [],
   "source": [
    "# val_dataset =  dataset['test'].select(idx_val)\n",
    "# val_dataset[0][\"img\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "e16837b7-8ddd-46ab-9d0a-c988f2ca9514",
   "metadata": {},
   "outputs": [],
   "source": [
    "# idx_val[0:5]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8c2e0980-d551-48f4-8b1f-3f9d4ac788cb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "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": 16,
   "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": 17,
   "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": 18,
   "id": "7e5b270b-c5df-4b5d-a8fd-2a924a6edad6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000, 1000)"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "loss_array_list = []\n",
    "\n",
    "for i in my_list:\n",
    "    for seed in [\n",
    "        0,\n",
    "                 1,\n",
    "                 2,\n",
    "                 # 3,\n",
    "                 # 4,\n",
    "                ]:\n",
    "        for e_seed in [\n",
    "            0, \n",
    "                       1, \n",
    "                       2\n",
    "                      ]:\n",
    "            with open('../../saved/5000-0.5/lds-val/ddpm-sub-{}-{}/e-{}-gen.pkl'.format(i, seed, e_seed), 'rb')  as handle:\n",
    "                loss_list = pickle.load(handle)\n",
    "            margins = np.concatenate(loss_list, axis=-1) # -logp\n",
    "            ####\n",
    "            if (seed==0) and (e_seed)==0:\n",
    "                loss_array = margins\n",
    "            else:\n",
    "                loss_array += margins\n",
    "            \n",
    "    loss_array = loss_array/(3*3)\n",
    "    \n",
    "    loss_array_list.append(loss_array)\n",
    "lds_loss_array = np.stack(loss_array_list)\n",
    "lds_loss_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "d823ef7b-9d53-4f31-ab11-864274554493",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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RgKBALfffjuBQCDZpRz3dK77hs5z39B57hs6z30n2ef6mBjAKiIiIsevlO4ZERERkeRTGBEREZGkUhgRERGRpFIYERERkaRK6TAyb948SkpKCAaDTJ06lWXLliW7pGPG3LlzOf3008nKymLAgAFceumlrF+/PqFNS0sLN954I/369SMzM5PLLruMysrKhDbbtm3jkksuIT09nQEDBvDtb3+baDTal1/lmHLnnXdiWRbf+MY34tt0nnvOjh07+PKXv0y/fv1IS0vj1FNP5e23347vN8Zw2223MXDgQNLS0igtLWXDhg0J77F3716uvPJKsrOzyc3N5dprr6WhoaGvv8pRy3Ecbr31VoYPH05aWhojR47kRz/6UcK9S3SeD8+//vUvPv3pTzNo0CAsy+Kpp55K2N9T5/Xdd9/l7LPPJhgMUlxczE9/+tMjL96kqEcffdT4/X6zYMECs2bNGnPdddeZ3NxcU1lZmezSjgnTp083f/jDH8zq1avNqlWrzMUXX2yGDh1qGhoa4m2++tWvmuLiYlNWVmbefvttc8YZZ5gzzzwzvj8ajZqxY8ea0tJSs3LlSvPss8+agoICM2fOnGR8paPesmXLTElJiRk3bpy5+eab49t1nnvG3r17zbBhw8w111xjli5dajZt2mSef/55s3HjxnibO++80+Tk5JinnnrKvPPOO+Yzn/mMGT58uGlubo63+eQnP2nGjx9v3nzzTfPvf//bnHDCCeaLX/xiMr7SUemOO+4w/fr1M88884zZvHmzeeyxx0xmZqb51a9+FW+j83x4nn32WfO9733PPPHEEwYwTz75ZML+njivtbW1prCw0Fx55ZVm9erV5i9/+YtJS0szv/vd746o9pQNI1OmTDE33nhj/LXjOGbQoEFm7ty5Sazq2FVVVWUA8+qrrxpjjKmpqTE+n8889thj8TZr1641gFmyZIkxJvb/OLZtm4qKinibe++912RnZ5tQKNS3X+AoV19fb0aNGmVefPFFc+6558bDiM5zz/nOd75jPvaxj+13v+u6pqioyPzsZz+Lb6upqTGBQMD85S9/McYY8/777xvAvPXWW/E2zz33nLEsy+zYsaP3ij+GXHLJJeb//b//l7Dt85//vLnyyiuNMTrPPeWjYaSnzutvf/tbk5eXl/Bvx3e+8x1z0kknHVG9KXmZJhwOs3z5ckpLS+Pb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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(1):\n",
    "    for j in range(8):\n",
    "        plt.plot(lds_loss_array[i, :, j], color=\"C{}\".format(j))\n",
    "    # break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "874a332c-29b1-46fe-bf83-12e7c8f64e28",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 5000)"
      ]
     },
     "execution_count": 20,
     "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": 21,
   "id": "41ebfcfb-5789-44f0-99d0-0dddc7c6f32f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000)"
      ]
     },
     "execution_count": 21,
     "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": 22,
   "id": "46afee77-65eb-4023-8077-d11ed785d406",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for j in range(4):\n",
    "    plt.plot(lds_testset_correctness[:, j], color=\"C{}\".format(j))\n",
    "    # break\n",
    "# plt.ylim(0.15, 0.2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8d92c4b4-5b21-434f-b6cc-96e968cbe495",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "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",
    "\n",
    "lamb_list = [\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",
    "\n",
    "ckpt_list = [\n",
    "    0, 1, \n",
    "    2, 3, 4, 5, 6, 7, \n",
    "    # 8\n",
    "            ]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "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(28.9364, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.495878)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(28.7215, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.499699)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(20.9553, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.032 (avg p value 0.500743)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.7562, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.476384)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2710, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.474547)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.6977, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.052 (avg p value 0.475062)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8483, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.052 (avg p value 0.474250)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4244, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.052 (avg p value 0.474451)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1701, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.052 (avg p value 0.474179)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0853, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.053 (avg p value 0.472783)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0429, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.054 (avg p value 0.468642)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0174, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.057 (avg p value 0.465142)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0089, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.060 (avg p value 0.459958)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.063 (avg p value 0.455082)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.067 (avg p value 0.446339)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.069 (avg p value 0.446244)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.070 (avg p value 0.444327)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.071 (avg p value 0.449515)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8877e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.070 (avg p value 0.450829)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9660e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.067 (avg p value 0.454940)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9932e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.063 (avg p value 0.464836)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9802e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.058 (avg p value 0.479400)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9943e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.053 (avg p value 0.489331)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.046 (avg p value 0.486149)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9969e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.042 (avg p value 0.487788)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9991e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.039 (avg p value 0.486731)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.037 (avg p value 0.488454)\n",
      "1\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(31.2960, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.500149)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(42.3364, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.510201)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(20.4210, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.034 (avg p value 0.490787)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.7528, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.471473)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2706, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.469311)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.6977, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.468234)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8483, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.467046)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4244, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.467023)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1701, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.466698)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0853, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.052 (avg p value 0.466473)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0429, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.053 (avg p value 0.465891)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0174, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.054 (avg p value 0.462691)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0089, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.056 (avg p value 0.458509)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.059 (avg p value 0.452944)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.062 (avg p value 0.451691)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.065 (avg p value 0.452740)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.068 (avg p value 0.453774)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.068 (avg p value 0.454811)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8871e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.067 (avg p value 0.458283)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9657e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.065 (avg p value 0.466576)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9931e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.061 (avg p value 0.473151)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9800e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.057 (avg p value 0.483322)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9943e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.052 (avg p value 0.488667)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.046 (avg p value 0.485158)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9969e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.042 (avg p value 0.488628)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9991e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.039 (avg p value 0.487875)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.037 (avg p value 0.486458)\n",
      "2\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(28.4250, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.498803)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(33.0335, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.516094)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(20.9993, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.021 (avg p value 0.480870)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.7752, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.471132)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2730, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.470896)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.6978, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.470644)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8484, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.470942)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4244, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.471010)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1701, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.471108)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0853, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.052 (avg p value 0.470176)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0429, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.053 (avg p value 0.469905)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0174, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.055 (avg p value 0.467243)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0089, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.058 (avg p value 0.460856)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.061 (avg p value 0.458302)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.064 (avg p value 0.451565)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.066 (avg p value 0.451709)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.068 (avg p value 0.449965)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.066 (avg p value 0.448341)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8881e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.065 (avg p value 0.450878)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9661e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.063 (avg p value 0.452421)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9932e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.059 (avg p value 0.462980)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9803e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.056 (avg p value 0.472548)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9943e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.052 (avg p value 0.482509)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.046 (avg p value 0.484318)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9969e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.043 (avg p value 0.487099)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9991e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.040 (avg p value 0.486815)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.038 (avg p value 0.486422)\n",
      "3\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(30.2309, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.007 (avg p value 0.487386)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(24.3328, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.508522)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(25.6897, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.494848)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.7633, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.058 (avg p value 0.462814)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2718, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.058 (avg p value 0.462138)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.6978, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.059 (avg p value 0.460743)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8484, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.058 (avg p value 0.459929)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4244, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.058 (avg p value 0.460783)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1701, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.059 (avg p value 0.459551)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0853, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.059 (avg p value 0.458575)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0429, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.060 (avg p value 0.458353)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0174, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.061 (avg p value 0.455966)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0089, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.063 (avg p value 0.453016)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.066 (avg p value 0.447916)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.068 (avg p value 0.442349)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.070 (avg p value 0.441725)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.071 (avg p value 0.442383)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.072 (avg p value 0.453964)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8886e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.070 (avg p value 0.453289)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9662e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.068 (avg p value 0.461175)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9932e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.064 (avg p value 0.471006)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9803e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.061 (avg p value 0.477642)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9943e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.056 (avg p value 0.483610)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.049 (avg p value 0.484440)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9969e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.045 (avg p value 0.484453)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9991e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.042 (avg p value 0.482864)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.039 (avg p value 0.480959)\n",
      "4\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(28.7528, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.502893)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(56.6365, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.004 (avg p value 0.488830)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(20.7909, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.037 (avg p value 0.476791)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.7599, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.484180)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2714, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.049 (avg p value 0.484400)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.6977, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.049 (avg p value 0.483082)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8484, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.049 (avg p value 0.483475)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4244, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.049 (avg p value 0.483402)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1701, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.049 (avg p value 0.483572)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0853, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.484768)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0429, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.483814)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0174, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.053 (avg p value 0.481307)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0089, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.055 (avg p value 0.477868)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.058 (avg p value 0.473132)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.063 (avg p value 0.465299)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.065 (avg p value 0.463162)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.067 (avg p value 0.459594)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.068 (avg p value 0.457025)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8882e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.067 (avg p value 0.459098)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9661e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.065 (avg p value 0.454895)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9932e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.062 (avg p value 0.460440)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9803e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.058 (avg p value 0.469748)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9943e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.053 (avg p value 0.474275)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.048 (avg p value 0.478682)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9969e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.043 (avg p value 0.480665)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9991e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.041 (avg p value 0.484169)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.038 (avg p value 0.483579)\n",
      "5\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(28.8217, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.000 (avg p value 0.500262)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(45.4210, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.502730)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(20.5871, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.026 (avg p value 0.488500)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.7512, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.048 (avg p value 0.475693)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2704, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.049 (avg p value 0.479779)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.6977, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.049 (avg p value 0.480169)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8484, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.049 (avg p value 0.480296)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4244, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.049 (avg p value 0.479895)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1701, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.479759)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0853, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.477775)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0429, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.477925)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0174, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.053 (avg p value 0.472568)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0089, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.056 (avg p value 0.465945)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.059 (avg p value 0.464271)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.063 (avg p value 0.457494)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.066 (avg p value 0.451013)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.068 (avg p value 0.450944)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.069 (avg p value 0.457158)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8892e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.069 (avg p value 0.457534)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9664e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.067 (avg p value 0.463515)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9933e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.063 (avg p value 0.475112)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9805e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.059 (avg p value 0.478467)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9944e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.054 (avg p value 0.479092)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.047 (avg p value 0.478021)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9969e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.043 (avg p value 0.480557)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9991e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.040 (avg p value 0.481938)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.038 (avg p value 0.479819)\n",
      "6\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(30.8320, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.487553)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(34.7769, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.511136)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(19.4885, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.017 (avg p value 0.474428)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.7489, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.057 (avg p value 0.471712)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2701, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.057 (avg p value 0.467647)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.6977, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.058 (avg p value 0.467196)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8484, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.058 (avg p value 0.467121)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4244, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.058 (avg p value 0.466501)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1701, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.058 (avg p value 0.465824)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0853, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.059 (avg p value 0.465021)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0429, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.059 (avg p value 0.463929)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0174, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.061 (avg p value 0.463978)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0089, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.063 (avg p value 0.463735)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.065 (avg p value 0.460456)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.067 (avg p value 0.453453)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.069 (avg p value 0.448577)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.070 (avg p value 0.445920)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.070 (avg p value 0.448927)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8882e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.069 (avg p value 0.450458)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9661e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.067 (avg p value 0.453179)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9932e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.062 (avg p value 0.464502)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9803e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.058 (avg p value 0.479274)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9943e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.053 (avg p value 0.482110)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.047 (avg p value 0.480135)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9969e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.044 (avg p value 0.480640)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9991e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.041 (avg p value 0.480411)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.039 (avg p value 0.481064)\n",
      "7\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(28.0931, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.495397)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(32.8406, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.004 (avg p value 0.490843)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(44.4298, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.012 (avg p value 0.493317)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.7665, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.472819)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2720, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.470810)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.6978, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.469338)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8483, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.469958)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4244, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.469895)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1701, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.469691)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0853, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.052 (avg p value 0.469029)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0429, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.052 (avg p value 0.467730)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0174, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.054 (avg p value 0.464415)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0089, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.056 (avg p value 0.465014)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.058 (avg p value 0.457843)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.061 (avg p value 0.449998)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.063 (avg p value 0.442438)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.064 (avg p value 0.444199)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.064 (avg p value 0.448707)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8860e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.063 (avg p value 0.451154)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9654e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.062 (avg p value 0.452387)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9931e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.058 (avg p value 0.465735)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9799e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.055 (avg p value 0.479217)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9942e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.487009)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.045 (avg p value 0.490866)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9968e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.042 (avg p value 0.492138)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9991e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.040 (avg p value 0.490620)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.037 (avg p value 0.489738)\n",
      "mean-squared-l2-norm\n",
      "0\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0088, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.502996)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(-0.0035, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.504399)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0034, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.490746)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0278, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.485972)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0519, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.509630)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0549, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.492107)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0682, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.497558)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0621, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.509936)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0493, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.501593)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0358, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.494868)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0265, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.494745)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0162, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.496475)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0096, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.019 (avg p value 0.482433)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.165 (avg p value 0.289213)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.176 (avg p value 0.271526)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.184 (avg p value 0.257679)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.190 (avg p value 0.248713)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.192 (avg p value 0.247782)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.7129e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.190 (avg p value 0.254699)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9049e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.184 (avg p value 0.262098)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9786e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.174 (avg p value 0.277629)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9317e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.166 (avg p value 0.288061)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9785e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.157 (avg p value 0.303579)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9954e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.144 (avg p value 0.322705)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9855e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.134 (avg p value 0.340841)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9955e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.123 (avg p value 0.357916)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9990e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.109 (avg p value 0.383210)\n",
      "1\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0055, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.508446)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(-0.0296, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.477730)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0168, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.499998)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0330, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.500347)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0512, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.497008)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0740, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.492917)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0773, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.504432)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0602, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.499862)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0461, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.007 (avg p value 0.492364)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0366, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.513732)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0261, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.491525)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0158, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.506265)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0096, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.015 (avg p value 0.506698)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.168 (avg p value 0.274556)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.179 (avg p value 0.257821)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.186 (avg p value 0.249985)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.192 (avg p value 0.242394)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.194 (avg p value 0.243239)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.7111e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.192 (avg p value 0.248224)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9042e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.185 (avg p value 0.261950)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9784e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.173 (avg p value 0.279747)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9309e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.164 (avg p value 0.293395)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9782e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.156 (avg p value 0.305064)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9953e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.143 (avg p value 0.331490)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9852e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.133 (avg p value 0.350759)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9954e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.123 (avg p value 0.368809)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9990e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.109 (avg p value 0.383720)\n",
      "2\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0021, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.504191)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0074, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.500811)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0157, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.502944)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0539, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.011 (avg p value 0.497492)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0506, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.512244)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0956, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.489628)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0730, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.496650)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0699, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.497740)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0487, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.505654)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0362, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.010 (avg p value 0.493374)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0261, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.505169)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0157, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.009 (avg p value 0.493863)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0097, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.014 (avg p value 0.493937)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.171 (avg p value 0.282376)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.182 (avg p value 0.261567)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.190 (avg p value 0.252227)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.195 (avg p value 0.244989)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.195 (avg p value 0.248003)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.7224e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.191 (avg p value 0.254971)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9080e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.183 (avg p value 0.264173)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9792e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.172 (avg p value 0.280756)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9336e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.163 (avg p value 0.296132)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9790e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.154 (avg p value 0.309398)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9955e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.142 (avg p value 0.331524)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9858e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.132 (avg p value 0.350519)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9956e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.122 (avg p value 0.367707)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9990e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.108 (avg p value 0.386965)\n",
      "3\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.519870)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(-0.0066, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.504088)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0092, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.008 (avg p value 0.500894)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0389, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.509199)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0573, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.491703)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0761, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.505760)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0706, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.018 (avg p value 0.494117)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0643, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.015 (avg p value 0.498827)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0473, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.509462)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0366, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.004 (avg p value 0.480769)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0262, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.493512)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0161, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.016 (avg p value 0.508286)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0086, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.501214)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.170 (avg p value 0.279187)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.180 (avg p value 0.261574)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.187 (avg p value 0.250725)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.191 (avg p value 0.247192)\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.251568)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.7221e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.187 (avg p value 0.255758)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9080e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.180 (avg p value 0.267729)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9793e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.169 (avg p value 0.288043)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9338e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.160 (avg p value 0.304180)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9791e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.152 (avg p value 0.316824)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9955e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.140 (avg p value 0.338107)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9859e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.130 (avg p value 0.357924)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9956e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.120 (avg p value 0.375715)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9990e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.107 (avg p value 0.389951)\n",
      "4\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0037, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.000 (avg p value 0.484761)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0125, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.507637)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0264, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.506544)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0352, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.006 (avg p value 0.494245)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0535, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.007 (avg p value 0.500121)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0708, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.520447)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0732, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.496883)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0608, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.496552)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0464, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.000 (avg p value 0.512142)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0362, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.011 (avg p value 0.490243)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0264, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.012 (avg p value 0.519224)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0141, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.011 (avg p value 0.494624)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.514275)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.305472)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.171 (avg p value 0.287118)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.180 (avg p value 0.272931)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.187 (avg p value 0.259298)\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.250625)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.7177e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.187 (avg p value 0.254550)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9065e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.180 (avg p value 0.262824)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9789e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.170 (avg p value 0.280813)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9326e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.296941)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9787e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.153 (avg p value 0.311589)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9954e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.141 (avg p value 0.329678)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9856e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.131 (avg p value 0.346797)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9955e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.121 (avg p value 0.365437)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9990e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.107 (avg p value 0.383768)\n",
      "5\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0090, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.497377)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0222, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.495377)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0141, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.511494)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0327, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.497750)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0588, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.492677)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0243, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.512779)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(-0.0037, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.485160)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0633, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.011 (avg p value 0.501353)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0472, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.008 (avg p value 0.495052)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0357, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.502500)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0260, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.486692)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0157, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.017 (avg p value 0.489307)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0094, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.012 (avg p value 0.494293)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.290421)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.172 (avg p value 0.271077)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.180 (avg p value 0.261643)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.187 (avg p value 0.255766)\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.255211)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.7177e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.188 (avg p value 0.261596)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9064e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.182 (avg p value 0.271422)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9789e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.171 (avg p value 0.288278)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9325e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.162 (avg p value 0.299188)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9787e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.153 (avg p value 0.309165)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9954e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.141 (avg p value 0.328634)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9856e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.132 (avg p value 0.348645)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9955e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.122 (avg p value 0.364449)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9990e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.109 (avg p value 0.383521)\n",
      "6\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0156, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.004 (avg p value 0.496517)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0128, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.495536)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0177, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.484481)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0260, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.496335)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0580, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.510754)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0733, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.490831)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0714, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.481388)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0630, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.011 (avg p value 0.492375)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0482, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.506700)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0342, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.502113)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0262, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.508798)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0160, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.010 (avg p value 0.500651)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0099, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.498755)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.167 (avg p value 0.284179)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.179 (avg p value 0.264529)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.186 (avg p value 0.253954)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.191 (avg p value 0.244576)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.192 (avg p value 0.241828)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.7235e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.187 (avg p value 0.248785)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9085e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.180 (avg p value 0.262793)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9793e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.169 (avg p value 0.286939)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9340e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.302551)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9792e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.152 (avg p value 0.313621)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9955e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.140 (avg p value 0.334304)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9859e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.131 (avg p value 0.352022)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9956e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.121 (avg p value 0.366860)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9990e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.108 (avg p value 0.383242)\n",
      "7\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0046, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.513881)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0097, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.506243)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0301, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.006 (avg p value 0.496162)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0348, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.500167)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0035, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.004 (avg p value 0.492933)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0743, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.511852)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0801, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.507930)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0752, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.004 (avg p value 0.498284)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0484, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.498737)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0284, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.512724)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0265, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.487279)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0159, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.014 (avg p value 0.491356)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0094, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.509728)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.170 (avg p value 0.279473)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.181 (avg p value 0.258838)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.189 (avg p value 0.247655)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.195 (avg p value 0.242234)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.196 (avg p value 0.243322)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.7227e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.193 (avg p value 0.249468)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9082e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.186 (avg p value 0.260582)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9793e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.175 (avg p value 0.280386)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9340e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.166 (avg p value 0.295296)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9792e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.157 (avg p value 0.307829)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9955e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.144 (avg p value 0.326204)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9859e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.134 (avg p value 0.341675)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9956e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.124 (avg p value 0.359134)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9990e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.110 (avg p value 0.379635)\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 = 10\n",
    "        for ckpt in ckpt_list:\n",
    "            print(ckpt)\n",
    "            ####\n",
    "            dstore_keys_list = []\n",
    "            for split in range(5):\n",
    "                tmp = None\n",
    "                for e_seed in range(num_seed):\n",
    "                    dstore_keys = np.memmap('{}/ddpm-sub-{}-0/features-{}/ddpm-train-keys-{}-{}-{}-{}-{}.npy'.format(\n",
    "                        args.output_dir, ckpt, e_seed,\n",
    "                        split, K, args.project_dim, f, args.strategy), \n",
    "                                        dtype=np.float32, \n",
    "                                        mode='r',\n",
    "                                        shape=(1000, args.project_dim))\n",
    "                    dstore_keys = dstore_keys[:, :args.used_dim]\n",
    "                    if e_seed==0:\n",
    "                        tmp = dstore_keys.copy()\n",
    "                    else:\n",
    "                        tmp += dstore_keys\n",
    "                tmp = tmp/num_seed\n",
    "                dstore_keys_list.append(tmp) \n",
    "            \n",
    "            dstore_keys = np.vstack(dstore_keys_list)\n",
    "            print(dstore_keys.shape)  \n",
    "            \n",
    "            if f=='l1_norm':\n",
    "                dstore_keys = dstore_keys / 3072\n",
    "            elif f=='l2_norm':\n",
    "                dstore_keys = dstore_keys / (3072**0.5)\n",
    "            ####    \n",
    "            tmp = None\n",
    "            for e_seed in range(num_seed):\n",
    "                gen_dstore_keys = np.memmap('{}/ddpm-sub-{}-0/features-{}/ddpm-gen-keys-{}-{}-{}-{}-{}.npy'.format(\n",
    "                       args.output_dir, ckpt, e_seed, \n",
    "                    0, K, args.project_dim, f, args.strategy), \n",
    "                                    dtype=np.float32, \n",
    "                                    mode='r',\n",
    "                                    shape=(1000, args.project_dim))\n",
    "                gen_dstore_keys = gen_dstore_keys[:, :args.used_dim]\n",
    "                if e_seed==0:\n",
    "                    tmp = gen_dstore_keys.copy()\n",
    "                else:\n",
    "                    tmp += gen_dstore_keys\n",
    "            tmp = tmp/num_seed\n",
    "            gen_dstore_keys = tmp\n",
    "            print(gen_dstore_keys.shape)\n",
    "            if f=='l1_norm':\n",
    "                gen_dstore_keys = gen_dstore_keys / 3072\n",
    "            elif f=='l2_norm':\n",
    "                gen_dstore_keys = gen_dstore_keys / (3072**0.5)\n",
    "            ####\n",
    "            dstore_keys = torch.from_numpy(dstore_keys).cuda()\n",
    "            gen_dstore_keys = torch.from_numpy(gen_dstore_keys).cuda()\n",
    "            ####\n",
    "            # if f=='l1_norm':\n",
    "            #     dstore_keys = dstore_keys/3072\n",
    "            #     gen_dstore_keys = gen_dstore_keys/3072\n",
    "            ####\n",
    "            kernel = dstore_keys.T@dstore_keys\n",
    "            ####\n",
    "            rs_list = []\n",
    "            ps_list = []\n",
    "\n",
    "            best_scores = None\n",
    "            best_lds = -np.inf\n",
    "            for lamb in lamb_list:\n",
    "                print(lamb)\n",
    "                # kernel_ = kernel + lamb*np.eye(kernel.shape[0])\n",
    "                kernel_ = kernel + lamb*torch.eye(kernel.shape[0]).cuda()\n",
    "                # kernel_ = torch.from_numpy(kernel_).cuda()\n",
    "                ####\n",
    "                kernel_ = torch.linalg.inv(kernel_)  \n",
    "                # kernel_ = kernel_.cpu().numpy()\n",
    "                ####\n",
    "                print(kernel_.shape)\n",
    "                print(torch.mean(kernel_.diagonal()))\n",
    "                ####\n",
    "                # scores = gen_dstore_keys.dot((dstore_keys@kernel_).T)\n",
    "                scores = gen_dstore_keys@((dstore_keys@kernel_).T)\n",
    "                print(scores.size())\n",
    "                scores = scores.cpu().numpy()\n",
    "    \n",
    "                # compute lds\n",
    "                margins = lds_testset_correctness\n",
    "                infl_est_ = -scores\n",
    "                preds = lds_mask_array @ infl_est_.T\n",
    "                ####\n",
    "                rs = []\n",
    "                ps = []\n",
    "    \n",
    "                for ind in range(1000):\n",
    "                   r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "                   # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "                   rs.append(r)\n",
    "                   ps.append(p)\n",
    "        \n",
    "                rs, ps = np.array(rs), np.array(ps)\n",
    "                print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "    \n",
    "                rs_list.append(rs.mean())   \n",
    "                ps_list.append(ps.mean())\n",
    "                \n",
    "                if rs.mean()>best_lds:\n",
    "                    best_scores = scores\n",
    "                    best_lds = rs.mean()\n",
    "                    \n",
    "            lds_list.append((rs_list, ps_list))\n",
    "            score_list.append(best_scores)\n",
    "            \n",
    "        f_lds_list.append(lds_list)\n",
    "        f_score_list.append(score_list)\n",
    "    seed_lds_list.append(f_lds_list)\n",
    "    seed_score_list.append(f_score_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8970c9b6-4694-4c06-b9a9-ec38f5f6b55e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "73ae9625-b9dc-432c-94b6-6cfcdc726a94",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e8258b5b-5a58-45b1-a727-0a8a0a94fc81",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "c08f885c-95db-4cfb-a235-b8ddddcd3a50",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[[[ 5.24517419e-03, -1.90544438e-03,  3.16139259e-02,\n",
       "           5.02636044e-02,  5.12598033e-02,  5.16648173e-02,\n",
       "           5.17271372e-02,  5.19398862e-02,  5.23693049e-02,\n",
       "           5.30767458e-02,  5.42897497e-02,  5.69606299e-02,\n",
       "           5.97021836e-02,  6.28317633e-02,  6.69961401e-02,\n",
       "           6.91703381e-02,  7.04045642e-02,  7.06641558e-02,\n",
       "           6.98096687e-02,  6.71422479e-02,  6.30044508e-02,\n",
       "           5.78074731e-02,  5.26386782e-02,  4.62936235e-02,\n",
       "           4.23544468e-02,  3.90523838e-02,  3.66486985e-02],\n",
       "         [ 4.95878222e-01,  4.99698944e-01,  5.00742661e-01,\n",
       "           4.76383737e-01,  4.74546534e-01,  4.75061767e-01,\n",
       "           4.74249898e-01,  4.74450995e-01,  4.74179361e-01,\n",
       "           4.72782750e-01,  4.68641546e-01,  4.65142095e-01,\n",
       "           4.59958197e-01,  4.55082171e-01,  4.46339292e-01,\n",
       "           4.46244327e-01,  4.44327042e-01,  4.49514556e-01,\n",
       "           4.50829257e-01,  4.54940231e-01,  4.64836081e-01,\n",
       "           4.79399541e-01,  4.89331002e-01,  4.86149001e-01,\n",
       "           4.87788319e-01,  4.86730832e-01,  4.88453975e-01]],\n",
       "\n",
       "        [[-4.70132708e-03,  8.28086379e-03,  3.40514066e-02,\n",
       "           4.98591094e-02,  5.00747911e-02,  5.05547136e-02,\n",
       "           5.06550342e-02,  5.06964032e-02,  5.11685186e-02,\n",
       "           5.15935644e-02,  5.26713124e-02,  5.44878652e-02,\n",
       "           5.62914842e-02,  5.85105336e-02,  6.24293102e-02,\n",
       "           6.51120270e-02,  6.75352886e-02,  6.84387456e-02,\n",
       "           6.70341203e-02,  6.49561253e-02,  6.14761779e-02,\n",
       "           5.69621439e-02,  5.19007645e-02,  4.60770217e-02,\n",
       "           4.23647465e-02,  3.94525475e-02,  3.74528187e-02],\n",
       "         [ 5.00149424e-01,  5.10201210e-01,  4.90787203e-01,\n",
       "           4.71473138e-01,  4.69311158e-01,  4.68233996e-01,\n",
       "           4.67045693e-01,  4.67023128e-01,  4.66697851e-01,\n",
       "           4.66472842e-01,  4.65891482e-01,  4.62691432e-01,\n",
       "           4.58509311e-01,  4.52944446e-01,  4.51690964e-01,\n",
       "           4.52740141e-01,  4.53774111e-01,  4.54811306e-01,\n",
       "           4.58282527e-01,  4.66576146e-01,  4.73151252e-01,\n",
       "           4.83321671e-01,  4.88666545e-01,  4.85157579e-01,\n",
       "           4.88627893e-01,  4.87874845e-01,  4.86458349e-01]],\n",
       "\n",
       "        [[ 1.97595774e-03,  4.85045366e-03,  2.12718011e-02,\n",
       "           5.12873874e-02,  5.09546944e-02,  5.09378680e-02,\n",
       "           5.08690259e-02,  5.09184766e-02,  5.13065262e-02,\n",
       "           5.18487193e-02,  5.28135777e-02,  5.52050160e-02,\n",
       "           5.79378915e-02,  6.07700578e-02,  6.41833608e-02,\n",
       "           6.63241124e-02,  6.76226474e-02,  6.64257620e-02,\n",
       "           6.50800669e-02,  6.33521603e-02,  5.94746424e-02,\n",
       "           5.60382640e-02,  5.15706791e-02,  4.62825621e-02,\n",
       "           4.26014703e-02,  4.04813690e-02,  3.78735613e-02],\n",
       "         [ 4.98802792e-01,  5.16094177e-01,  4.80869569e-01,\n",
       "           4.71132287e-01,  4.70895645e-01,  4.70644097e-01,\n",
       "           4.70942373e-01,  4.71009674e-01,  4.71107648e-01,\n",
       "           4.70175948e-01,  4.69905476e-01,  4.67242727e-01,\n",
       "           4.60856122e-01,  4.58302476e-01,  4.51564790e-01,\n",
       "           4.51708631e-01,  4.49964986e-01,  4.48341484e-01,\n",
       "           4.50878447e-01,  4.52420638e-01,  4.62979985e-01,\n",
       "           4.72547971e-01,  4.82508885e-01,  4.84317648e-01,\n",
       "           4.87099440e-01,  4.86814550e-01,  4.86421725e-01]],\n",
       "\n",
       "        [[-7.27829473e-03,  8.11163439e-03,  5.50473413e-03,\n",
       "           5.82064142e-02,  5.83982401e-02,  5.85008509e-02,\n",
       "           5.84433417e-02,  5.84687998e-02,  5.89013093e-02,\n",
       "           5.91814608e-02,  5.98579948e-02,  6.14102641e-02,\n",
       "           6.34760591e-02,  6.57618665e-02,  6.84178191e-02,\n",
       "           6.97056631e-02,  7.10829987e-02,  7.15893415e-02,\n",
       "           7.02524832e-02,  6.81362520e-02,  6.42969907e-02,\n",
       "           6.08999654e-02,  5.58394335e-02,  4.93655313e-02,\n",
       "           4.53232445e-02,  4.17284164e-02,  3.90436627e-02],\n",
       "         [ 4.87385696e-01,  5.08521780e-01,  4.94848009e-01,\n",
       "           4.62813808e-01,  4.62138138e-01,  4.60742904e-01,\n",
       "           4.59928902e-01,  4.60783354e-01,  4.59551250e-01,\n",
       "           4.58575312e-01,  4.58352620e-01,  4.55966215e-01,\n",
       "           4.53016202e-01,  4.47916032e-01,  4.42348693e-01,\n",
       "           4.41725207e-01,  4.42382562e-01,  4.53963625e-01,\n",
       "           4.53288748e-01,  4.61175321e-01,  4.71005856e-01,\n",
       "           4.77642169e-01,  4.83610348e-01,  4.84440411e-01,\n",
       "           4.84453435e-01,  4.82864099e-01,  4.80958535e-01]],\n",
       "\n",
       "        [[ 5.44980376e-03, -4.26201416e-03,  3.67102347e-02,\n",
       "           4.98560742e-02,  4.91234958e-02,  4.86066685e-02,\n",
       "           4.86413065e-02,  4.87417187e-02,  4.90781428e-02,\n",
       "           4.95403452e-02,  5.05056844e-02,  5.26301608e-02,\n",
       "           5.51107228e-02,  5.77316937e-02,  6.25075898e-02,\n",
       "           6.46906238e-02,  6.66669512e-02,  6.77196761e-02,\n",
       "           6.65867321e-02,  6.51074778e-02,  6.21772575e-02,\n",
       "           5.76623535e-02,  5.32023247e-02,  4.78702023e-02,\n",
       "           4.33699489e-02,  4.05868424e-02,  3.83443711e-02],\n",
       "         [ 5.02892704e-01,  4.88830444e-01,  4.76790645e-01,\n",
       "           4.84180117e-01,  4.84400313e-01,  4.83081654e-01,\n",
       "           4.83474728e-01,  4.83401901e-01,  4.83571735e-01,\n",
       "           4.84768426e-01,  4.83814237e-01,  4.81306649e-01,\n",
       "           4.77867512e-01,  4.73132070e-01,  4.65298924e-01,\n",
       "           4.63162289e-01,  4.59594191e-01,  4.57024530e-01,\n",
       "           4.59098361e-01,  4.54895397e-01,  4.60439825e-01,\n",
       "           4.69747742e-01,  4.74275313e-01,  4.78682209e-01,\n",
       "           4.80665214e-01,  4.84168885e-01,  4.83578776e-01]],\n",
       "\n",
       "        [[-2.58217950e-04, -2.12206351e-03,  2.62176037e-02,\n",
       "           4.82391498e-02,  4.86541443e-02,  4.91456966e-02,\n",
       "           4.91968643e-02,  4.93156830e-02,  4.95237185e-02,\n",
       "           5.03933614e-02,  5.07814340e-02,  5.32704229e-02,\n",
       "           5.58201941e-02,  5.86253702e-02,  6.29235175e-02,\n",
       "           6.60192835e-02,  6.78973286e-02,  6.90397980e-02,\n",
       "           6.85127151e-02,  6.67849688e-02,  6.29535357e-02,\n",
       "           5.89016818e-02,  5.37779167e-02,  4.68595776e-02,\n",
       "           4.30006485e-02,  3.99123676e-02,  3.78343212e-02],\n",
       "         [ 5.00261574e-01,  5.02730369e-01,  4.88499944e-01,\n",
       "           4.75693207e-01,  4.79778876e-01,  4.80169054e-01,\n",
       "           4.80296049e-01,  4.79894519e-01,  4.79759283e-01,\n",
       "           4.77774701e-01,  4.77924865e-01,  4.72567548e-01,\n",
       "           4.65945484e-01,  4.64271208e-01,  4.57493918e-01,\n",
       "           4.51012632e-01,  4.50943840e-01,  4.57158239e-01,\n",
       "           4.57534172e-01,  4.63515230e-01,  4.75111518e-01,\n",
       "           4.78467332e-01,  4.79092293e-01,  4.78021002e-01,\n",
       "           4.80556598e-01,  4.81937646e-01,  4.79818696e-01]],\n",
       "\n",
       "        [[ 3.51800265e-03,  2.31772899e-04,  1.68888468e-02,\n",
       "           5.73437287e-02,  5.70918291e-02,  5.75494762e-02,\n",
       "           5.76866100e-02,  5.77316423e-02,  5.82558640e-02,\n",
       "           5.85101909e-02,  5.91967523e-02,  6.06656860e-02,\n",
       "           6.27427704e-02,  6.49207466e-02,  6.74252588e-02,\n",
       "           6.91833184e-02,  6.98583884e-02,  7.04879009e-02,\n",
       "           6.91251261e-02,  6.66169544e-02,  6.21216026e-02,\n",
       "           5.77622388e-02,  5.34795232e-02,  4.68945619e-02,\n",
       "           4.42104258e-02,  4.12535571e-02,  3.87821036e-02],\n",
       "         [ 4.87552593e-01,  5.11136361e-01,  4.74428256e-01,\n",
       "           4.71712300e-01,  4.67646663e-01,  4.67195709e-01,\n",
       "           4.67121182e-01,  4.66501417e-01,  4.65823858e-01,\n",
       "           4.65021132e-01,  4.63929406e-01,  4.63977794e-01,\n",
       "           4.63734513e-01,  4.60456491e-01,  4.53453411e-01,\n",
       "           4.48577150e-01,  4.45920336e-01,  4.48927334e-01,\n",
       "           4.50457955e-01,  4.53178890e-01,  4.64502198e-01,\n",
       "           4.79273686e-01,  4.82109857e-01,  4.80134596e-01,\n",
       "           4.80640124e-01,  4.80411137e-01,  4.81064416e-01]],\n",
       "\n",
       "        [[ 1.33696839e-03, -4.24364174e-03,  1.18814329e-02,\n",
       "           5.02354456e-02,  5.10205644e-02,  5.08519063e-02,\n",
       "           5.07532800e-02,  5.10136050e-02,  5.12603315e-02,\n",
       "           5.16378956e-02,  5.23024333e-02,  5.39362943e-02,\n",
       "           5.55981757e-02,  5.77534879e-02,  6.11806646e-02,\n",
       "           6.30871217e-02,  6.43895255e-02,  6.43320131e-02,\n",
       "           6.34733853e-02,  6.15952718e-02,  5.79841923e-02,\n",
       "           5.51183505e-02,  5.12349039e-02,  4.52350592e-02,\n",
       "           4.20799586e-02,  3.98492755e-02,  3.70363168e-02],\n",
       "         [ 4.95397226e-01,  4.90843065e-01,  4.93317440e-01,\n",
       "           4.72819305e-01,  4.70810086e-01,  4.69338404e-01,\n",
       "           4.69957625e-01,  4.69895483e-01,  4.69691449e-01,\n",
       "           4.69029164e-01,  4.67729914e-01,  4.64414750e-01,\n",
       "           4.65013963e-01,  4.57843066e-01,  4.49997751e-01,\n",
       "           4.42437940e-01,  4.44199357e-01,  4.48706690e-01,\n",
       "           4.51153520e-01,  4.52386993e-01,  4.65734716e-01,\n",
       "           4.79217034e-01,  4.87008651e-01,  4.90866289e-01,\n",
       "           4.92137907e-01,  4.90619611e-01,  4.89738165e-01]]],\n",
       "\n",
       "\n",
       "       [[[-1.57080928e-03, -2.83180085e-03,  5.54783935e-03,\n",
       "           7.72804478e-04,  3.42559188e-03,  2.85621061e-03,\n",
       "           9.00457628e-03,  5.06084313e-03,  6.67919165e-03,\n",
       "           4.60725551e-03, -4.81426767e-03,  5.47629301e-03,\n",
       "           1.86771554e-02,  1.65296343e-01,  1.76168234e-01,\n",
       "           1.83834832e-01,  1.89850722e-01,  1.92348319e-01,\n",
       "           1.89658872e-01,  1.84121443e-01,  1.73661044e-01,\n",
       "           1.65990874e-01,  1.57011707e-01,  1.44418480e-01,\n",
       "           1.34276855e-01,  1.23383654e-01,  1.09170280e-01],\n",
       "         [ 5.02996237e-01,  5.04398864e-01,  4.90745615e-01,\n",
       "           4.85971971e-01,  5.09629846e-01,  4.92106584e-01,\n",
       "           4.97557771e-01,  5.09936207e-01,  5.01592789e-01,\n",
       "           4.94868336e-01,  4.94744944e-01,  4.96475455e-01,\n",
       "           4.82432893e-01,  2.89212815e-01,  2.71525670e-01,\n",
       "           2.57679050e-01,  2.48713307e-01,  2.47782176e-01,\n",
       "           2.54699475e-01,  2.62098338e-01,  2.77629111e-01,\n",
       "           2.88061200e-01,  3.03579486e-01,  3.22704946e-01,\n",
       "           3.40840829e-01,  3.57916072e-01,  3.83210466e-01]],\n",
       "\n",
       "        [[-6.86811752e-04, -2.95074042e-03,  3.18330660e-03,\n",
       "          -4.78497882e-03,  4.73787519e-04,  1.89931223e-03,\n",
       "           1.13787149e-03, -5.49947716e-03, -6.98509911e-03,\n",
       "          -5.47328400e-03,  3.81061752e-03,  7.37065976e-03,\n",
       "           1.50252406e-02,  1.68196319e-01,  1.78546961e-01,\n",
       "           1.85936203e-01,  1.91978536e-01,  1.94099509e-01,\n",
       "           1.91802623e-01,  1.84601825e-01,  1.73148772e-01,\n",
       "           1.64031530e-01,  1.55699435e-01,  1.43052521e-01,\n",
       "           1.32663877e-01,  1.22560988e-01,  1.09004691e-01],\n",
       "         [ 5.08446423e-01,  4.77730119e-01,  4.99998380e-01,\n",
       "           5.00346505e-01,  4.97008160e-01,  4.92916600e-01,\n",
       "           5.04432007e-01,  4.99861830e-01,  4.92363989e-01,\n",
       "           5.13731897e-01,  4.91524536e-01,  5.06265317e-01,\n",
       "           5.06697662e-01,  2.74556334e-01,  2.57820971e-01,\n",
       "           2.49985497e-01,  2.42393714e-01,  2.43239103e-01,\n",
       "           2.48223762e-01,  2.61950381e-01,  2.79747443e-01,\n",
       "           2.93395371e-01,  3.05063683e-01,  3.31490147e-01,\n",
       "           3.50758624e-01,  3.68809326e-01,  3.83720464e-01]],\n",
       "\n",
       "        [[ 1.56640958e-03,  3.42072522e-03, -1.34407193e-03,\n",
       "           1.07465771e-02,  2.10060041e-05,  5.00107863e-03,\n",
       "           6.18463730e-03,  4.04252472e-03,  2.78087760e-04,\n",
       "           9.92436367e-03,  5.59140855e-03, -8.73775301e-03,\n",
       "           1.36716594e-02,  1.70764315e-01,  1.82299640e-01,\n",
       "           1.89521276e-01,  1.94598520e-01,  1.95429200e-01,\n",
       "           1.91002277e-01,  1.83218508e-01,  1.71816009e-01,\n",
       "           1.62559504e-01,  1.53776400e-01,  1.42171185e-01,\n",
       "           1.31778616e-01,  1.21642219e-01,  1.07738253e-01],\n",
       "         [ 5.04191244e-01,  5.00811027e-01,  5.02943789e-01,\n",
       "           4.97491532e-01,  5.12244423e-01,  4.89628160e-01,\n",
       "           4.96649796e-01,  4.97740285e-01,  5.05654432e-01,\n",
       "           4.93374252e-01,  5.05169235e-01,  4.93863173e-01,\n",
       "           4.93937082e-01,  2.82376240e-01,  2.61567316e-01,\n",
       "           2.52226700e-01,  2.44988931e-01,  2.48003486e-01,\n",
       "           2.54971292e-01,  2.64172646e-01,  2.80756338e-01,\n",
       "           2.96131507e-01,  3.09397524e-01,  3.31524186e-01,\n",
       "           3.50518648e-01,  3.67706564e-01,  3.86965383e-01]],\n",
       "\n",
       "        [[ 1.80096528e-03, -3.18351346e-03, -7.76577221e-03,\n",
       "          -1.39414457e-03,  4.46874897e-03,  8.78398245e-03,\n",
       "           1.80559619e-02,  1.53429466e-02, -1.41158252e-03,\n",
       "          -3.98532560e-03,  9.14054169e-03,  1.57598286e-02,\n",
       "           9.30242537e-03,  1.69862344e-01,  1.80015759e-01,\n",
       "           1.86822147e-01,  1.90867937e-01,  1.91321991e-01,\n",
       "           1.87108186e-01,  1.79899969e-01,  1.69222562e-01,\n",
       "           1.60110861e-01,  1.51926747e-01,  1.40090458e-01,\n",
       "           1.29718618e-01,  1.19979809e-01,  1.07146268e-01],\n",
       "         [ 5.19870353e-01,  5.04087544e-01,  5.00893801e-01,\n",
       "           5.09199207e-01,  4.91702712e-01,  5.05760418e-01,\n",
       "           4.94117111e-01,  4.98826596e-01,  5.09461750e-01,\n",
       "           4.80768888e-01,  4.93511892e-01,  5.08286064e-01,\n",
       "           5.01214440e-01,  2.79187363e-01,  2.61574113e-01,\n",
       "           2.50725031e-01,  2.47191591e-01,  2.51567513e-01,\n",
       "           2.55757747e-01,  2.67729153e-01,  2.88043121e-01,\n",
       "           3.04180000e-01,  3.16823671e-01,  3.38107353e-01,\n",
       "           3.57924118e-01,  3.75714845e-01,  3.89950620e-01]],\n",
       "\n",
       "        [[-8.90602662e-05, -5.67691134e-04, -4.66007449e-03,\n",
       "          -6.02811065e-03, -7.08077278e-03,  9.31658919e-04,\n",
       "           7.54784438e-04,  5.27465648e-03, -1.13965054e-04,\n",
       "           1.10417549e-02,  1.19801985e-02, -1.11023172e-02,\n",
       "           5.44962749e-03,  1.60660187e-01,  1.71487571e-01,\n",
       "           1.80083639e-01,  1.86500124e-01,  1.89851616e-01,\n",
       "           1.87217756e-01,  1.80297473e-01,  1.69666059e-01,\n",
       "           1.60981396e-01,  1.52735537e-01,  1.41000398e-01,\n",
       "           1.31128664e-01,  1.20743111e-01,  1.07090407e-01],\n",
       "         [ 4.84761488e-01,  5.07637002e-01,  5.06543810e-01,\n",
       "           4.94244689e-01,  5.00120767e-01,  5.20447060e-01,\n",
       "           4.96882766e-01,  4.96551857e-01,  5.12141781e-01,\n",
       "           4.90243017e-01,  5.19224164e-01,  4.94623695e-01,\n",
       "           5.14275203e-01,  3.05472310e-01,  2.87118107e-01,\n",
       "           2.72930644e-01,  2.59297567e-01,  2.50625032e-01,\n",
       "           2.54549840e-01,  2.62823798e-01,  2.80812598e-01,\n",
       "           2.96940999e-01,  3.11588790e-01,  3.29678384e-01,\n",
       "           3.46797098e-01,  3.65436623e-01,  3.83767761e-01]],\n",
       "\n",
       "        [[ 7.83503017e-03, -1.74433027e-03,  1.22052020e-03,\n",
       "           1.40846911e-03,  2.55991254e-03, -2.89471392e-03,\n",
       "           4.47248255e-03,  1.07651295e-02, -7.81491103e-03,\n",
       "          -3.40265955e-03,  7.75311436e-03,  1.68180807e-02,\n",
       "           1.20017556e-02,  1.60965643e-01,  1.71884144e-01,\n",
       "           1.80300858e-01,  1.86954477e-01,  1.90118214e-01,\n",
       "           1.87809651e-01,  1.81859009e-01,  1.71229749e-01,\n",
       "           1.62013562e-01,  1.53341376e-01,  1.41400873e-01,\n",
       "           1.31936931e-01,  1.21800000e-01,  1.08603114e-01],\n",
       "         [ 4.97376508e-01,  4.95376913e-01,  5.11493666e-01,\n",
       "           4.97749626e-01,  4.92677222e-01,  5.12778778e-01,\n",
       "           4.85159533e-01,  5.01353292e-01,  4.95051895e-01,\n",
       "           5.02499666e-01,  4.86692337e-01,  4.89307238e-01,\n",
       "           4.94292559e-01,  2.90421393e-01,  2.71077128e-01,\n",
       "           2.61642777e-01,  2.55765518e-01,  2.55210776e-01,\n",
       "           2.61595727e-01,  2.71421957e-01,  2.88277748e-01,\n",
       "           2.99187909e-01,  3.09164664e-01,  3.28634357e-01,\n",
       "           3.48645148e-01,  3.64448920e-01,  3.83520551e-01]],\n",
       "\n",
       "        [[-4.45567162e-03,  6.65636720e-03, -1.10696583e-03,\n",
       "           5.05757346e-03,  8.16526895e-03, -5.13535076e-03,\n",
       "          -2.32078753e-03,  1.13089992e-02, -2.21921734e-03,\n",
       "          -2.14542955e-03,  4.12055959e-03,  9.57866110e-03,\n",
       "           3.74716998e-03,  1.67499976e-01,  1.78701604e-01,\n",
       "           1.85866237e-01,  1.90850489e-01,  1.91587282e-01,\n",
       "           1.86888656e-01,  1.79723317e-01,  1.68770293e-01,\n",
       "           1.61122557e-01,  1.52354241e-01,  1.40072073e-01,\n",
       "           1.30815410e-01,  1.21340863e-01,  1.08433195e-01],\n",
       "         [ 4.96516935e-01,  4.95536197e-01,  4.84480749e-01,\n",
       "           4.96335028e-01,  5.10754436e-01,  4.90830944e-01,\n",
       "           4.81388229e-01,  4.92374713e-01,  5.06700012e-01,\n",
       "           5.02113377e-01,  5.08798349e-01,  5.00651293e-01,\n",
       "           4.98754525e-01,  2.84178703e-01,  2.64528609e-01,\n",
       "           2.53953998e-01,  2.44576443e-01,  2.41827807e-01,\n",
       "           2.48785386e-01,  2.62792881e-01,  2.86939450e-01,\n",
       "           3.02550871e-01,  3.13621129e-01,  3.34304233e-01,\n",
       "           3.52022430e-01,  3.66860124e-01,  3.83241794e-01]],\n",
       "\n",
       "        [[-2.28691562e-03,  4.49642430e-03, -6.25711756e-03,\n",
       "           5.44033667e-03, -4.14223978e-03,  4.65906912e-04,\n",
       "           8.52113271e-03, -3.99181779e-03, -2.00274463e-03,\n",
       "          -3.28685865e-03,  6.93265734e-03,  1.41719139e-02,\n",
       "           5.42188698e-03,  1.70013143e-01,  1.80944400e-01,\n",
       "           1.88902509e-01,  1.94898616e-01,  1.96283919e-01,\n",
       "           1.92901181e-01,  1.86474235e-01,  1.74981924e-01,\n",
       "           1.65757495e-01,  1.56626014e-01,  1.43919010e-01,\n",
       "           1.34037090e-01,  1.23631549e-01,  1.09605677e-01],\n",
       "         [ 5.13880647e-01,  5.06242767e-01,  4.96162381e-01,\n",
       "           5.00166822e-01,  4.92933004e-01,  5.11851580e-01,\n",
       "           5.07930108e-01,  4.98283921e-01,  4.98736845e-01,\n",
       "           5.12724439e-01,  4.87279086e-01,  4.91356383e-01,\n",
       "           5.09728336e-01,  2.79473120e-01,  2.58838484e-01,\n",
       "           2.47655405e-01,  2.42233528e-01,  2.43322033e-01,\n",
       "           2.49467823e-01,  2.60581589e-01,  2.80386150e-01,\n",
       "           2.95295894e-01,  3.07828690e-01,  3.26204376e-01,\n",
       "           3.41674832e-01,  3.59134239e-01,  3.79634558e-01]]]])"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_lds_array = np.array(seed_lds_list)\n",
    "seed_lds_array[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "1c1d75dc-93fa-4af9-a3b7-d8a10e56feb5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1, 2, 8, 2, 27)"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_lds_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "018c6e64-d424-4018-a711-eee95131a802",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "10"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "K"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "fde83272-f2b9-4e41-a9e2-0d7b19810784",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('./gen_5000_0.5_ckpt_{}.pkl'.format(K), 'wb') as handle:\n",
    "    pickle.dump(seed_lds_array, handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fb08a31e-97fe-4d9c-b426-370507cadf5b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c4d858e4-8104-45cc-a9bb-36e64765a662",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "00a7858a-30f7-4cc0-a3a7-d132143254e0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "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": 30,
   "id": "ea85a313-addc-42eb-91ad-e671e3e13104",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[[0.07066416, 0.06843875, 0.06762265, 0.07158934, 0.06771968,\n",
       "         0.0690398 , 0.0704879 , 0.06438953],\n",
       "        [0.19234832, 0.19409951, 0.1954292 , 0.19132199, 0.18985162,\n",
       "         0.19011821, 0.19158728, 0.19628392]]])"
      ]
     },
     "execution_count": 30,
     "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": 31,
   "id": "c180a94c-6b0d-48bc-baaa-64ac650c7964",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1, 2, 8)"
      ]
     },
     "execution_count": 31,
     "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": 32,
   "id": "11421adc-eb0c-4a34-8408-54ea5a2ba6f4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f0f033e5940>"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA50AAAGaCAYAAACMtifbAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACFRUlEQVR4nOzdeVwU5R8H8M/usst9eAAiopgK4oUmamimJopH/tS8UlM0pfI2805Fy6MDzzTvxMoz0yzFk9TM+z4Jj1IqUfEABGKX3X1+f6yMLOxyKOuCfd6v1+rOzHeeeWaYnZ3vPM/MyoQQAkREREREREQWILd2BYiIiIiIiOjFxaSTiIiIiIiILIZJJxEREREREVkMk04iIiIiIiKyGCadREREREREZDFMOomIiIiIiMhimHQSERERERGRxTDpJCIiIiIiIoth0klEREREREQWw6STiIiIiIiILMbqSeeiRYvg6+sLOzs7NGrUCMePH88zPikpCUOGDIGXlxdsbW3h5+eH6Ojo51RbIiIiIiIiKgwbay58w4YNGDVqFJYsWYJGjRph3rx5CA0NRVxcHDw8PHLFazQatGrVCh4eHti0aRO8vb1x8+ZNuLm5Pf/KExERERERUb5kQghhrYU3atQIDRo0wMKFCwEAer0ePj4+GDZsGMaPH58rfsmSJfjiiy/w+++/Q6lUPu/qEhERERERUSFZLenUaDRwcHDApk2b0KlTJ2l8WFgYkpKSsHXr1lzztGvXDqVLl4aDgwO2bt0Kd3d39OrVC+PGjYNCoTC5HLVaDbVaLQ3r9Xo8ePAAZcqUgUwmK/L1IiIiIqJnI4TAo0ePUL58ecjlVr8bjIiekdW61967dw86nQ6enp5G4z09PfH777+bnOePP/7AL7/8gt69eyM6OhrXrl3D4MGDkZmZiYiICJPzzJo1C9OmTSvy+hMRERGRZf3111+oUKGCtatBRM/Iqvd0FpZer4eHhweWLVsGhUKB+vXr459//sEXX3xhNumcMGECRo0aJQ0nJyejYsWK+Ouvv+Di4vK8qk5EREREBZSSkgIfHx84OztbuypEVASslnSWLVsWCoUCd+7cMRp/584dlCtXzuQ8Xl5eUCqVRl1pAwICcPv2bWg0GqhUqlzz2NrawtbWNtd4FxcXJp1ERERExRhvhSJ6MVitk7xKpUL9+vURExMjjdPr9YiJiUFwcLDJeZo0aYJr165Br9dL465cuQIvLy+TCScRERERERFZl1XvzB41ahSWL1+O1atXIzY2FoMGDUJaWhr69+8PAOjbty8mTJggxQ8aNAgPHjzAiBEjcOXKFWzfvh0zZ87EkCFDrLUKRERERERElAer3tPZo0cPJCYmYsqUKbh9+zbq1q2LnTt3Sg8Xio+PN3pimY+PD3bt2oUPPvgAderUgbe3N0aMGIFx48ZZaxWIiIiIiIgoD1b9nU5rSElJgaurK5KTk3lPJxEREVExxPM1ohcLf/iIiIiIiIiILIZJJxEREREREVkMk04iIiIiIiKyGCadREREREREZDFMOomIiIiIiMhimHQSERERERGRxTDpJCIiIiIiIoth0klEREREREQWw6STiIiIiIiILIZJJxEREREREVkMk04iIiIiIiKyGCadREREREREZDFMOomIiIiIiMhimHQSERERERGRxTDpJCIiIiIiIoth0klEREREREQWw6STiIiIiIiILIZJJxEREREREVkMk04iIiIiIiKyGCadREREREREZDFMOomIiIiIiMhimHQSERERERGRxTDpJCIiIiIiIoth0klEREREREQWw6STiIiIiIiILIZJJxEREREREVkMk04iIiIiIiKyGCadREREREREZDFMOomIiIiIiMhimHQSERERERGRxTDpJCIiIiIiIoth0klEREREREQWw6STiIiIiIiILIZJJxEREREREVkMk04iIiIiIiKyGCadREREREREZDFMOomIiIiIiMhimHQSERERERGRxTDpJCIiIiIiIoth0klEREREREQWUyySzkWLFsHX1xd2dnZo1KgRjh8/bjY2KioKMpnM6GVnZ/cca0tEREREREQFZfWkc8OGDRg1ahQiIiJw+vRpBAYGIjQ0FHfv3jU7j4uLCxISEqTXzZs3n2ONiYiIiIiIqKCsnnTOmTMH4eHh6N+/P2rUqIElS5bAwcEBX3/9tdl5ZDIZypUrJ708PT2fY42JiIiIiIiooGysuXCNRoNTp05hwoQJ0ji5XI6QkBAcOXLE7HypqamoVKkS9Ho9Xn75ZcycORM1a9Ys9LI1Gk2u8XK5HDY2NkZx5shkMiiVyqeKzczMhBDiucYCgEqleqpYrVYLvV5fJLFKpRIymcyisTqdDjqdrkhibWxsIJfLi02sXq+HVqs1G6tQKKBQKIpNrBACmZmZRRKb/fNpqVgg788yjxGmY3mM4DGCx4jCx/IYYT42r21BRCWPVZPOe/fuQafT5Wqp9PT0xO+//25yHn9/f3z99deoU6cOkpOTERkZicaNG+PSpUuoUKFCrni1Wg21Wi0Np6SkAABmz55t8l7QatWqoVevXtJwZGSk2S+iSpUqoV+/ftLw/PnzkZ6ebjK2fPnyCA8Pl4YXLVqE5ORkk7Hu7u4YPHiwNLx8+XIkJiaajHV1dcXIkSOl4aioKNy6dctkrIODA8aMGSMNr1mzxmzXZKVSiYkTJ0rDGzduxNWrV03GAkBERIT0fsuWLbh8+bLZ2AkTJkhfLtu2bcO5c+fMxo4ePRqOjo4AgF27duHkyZNmY0eMGAE3NzcAQExMTJ4XLgYNGgQPDw8AwMGDB3HgwAGzsQMHDoS3tzcA4OjRo9i7d6/Z2LCwMPj6+gIATp06hR07dpiN7dmzJ/z8/AAAFy5cwNatW83Gdu3aVbqwEhsbi02bNpmN7dixI+rWrQsAuHbtGtatW2c2tm3btmjYsCEAID4+HqtXrzYbGxISgiZNmgAAEhISsGLFCrOxzZo1Q/PmzQEAiYmJWLx4sdnY4OBgtG7dGgCQnJyM+fPnm40NCgpC+/btAQDp6emIjIw0GxsYGIhOnToBMJwYzZo1y2xsjRo10K1bN2k4r1geIwx4jHiCxwgDHiMMeIwweNZjxOnTp83GElHJY/XutYUVHByMvn37om7dumjWrBk2b94Md3d3LF261GT8rFmz4OrqKr18fHyec42JiIiIiIj+u2Qir34RFqbRaODg4IBNmzZJVxsBw5XgpKSkPK/qZtetWzfY2NiYvFprqqXTx8cHiYmJcHFxyRXPbjGmY9l1jl3n2HWu8LE8RjxdLI8RzxZbHD73PEbwGJEztrDHiKSkJLi7uyM5Odnk+RoRlSxWTToBoFGjRmjYsCG+/PJLAIYvqooVK2Lo0KEYP358vvPrdDrUrFkT7dq1w5w5c/KNT0lJgaurKw9iRERERMUUz9eIXixWvacTAEaNGoWwsDAEBQWhYcOGmDdvHtLS0tC/f38AQN++feHt7S3dP/Hxxx/jlVdeQdWqVZGUlIQvvvgCN2/exMCBA625GkRERERERGSC1ZPOHj16IDExEVOmTMHt27dRt25d7Ny5U3q4UHx8vNRlCAAePnyI8PBw3L59G6VKlUL9+vVx+PBh1KhRw1qrQERERERERGZYvXvt88buGkRERETFG8/XiF4sJe7ptURERERERFRyMOkkIiIiIiIii2HSSURERERERBbDpJOIiIiIiIgshkknERERERERWQyTTiIiIiIiIrIYJp1ERERERERkMUw6iYiIiIiIyGKYdBIREREREZHFMOkkIiIiIiIii2HSSURERERERBbDpJOIiIiIiIgshkknERERERERWQyTTiIiIiIiIrIYJp1ERERERERkMUw6iYiIiIiIyGKYdBIREREREZHFMOkkIiIiIiIii2HSSURERERERBbDpJOIiIiIiIgshkknERERERERWQyTTiIiIiIiIrIYJp1ERERERERkMUw6iYiIiIiIyGKYdBIREREREZHFMOkkIiIiIiIii2HSSURERERERBbDpJOIiIiIiIgshkknERERERERWQyTTiIiIiIiIrIYJp1ERERERERkMUw6iYiIiIiIyGKYdBIREREREZHFMOkkIiIiIiIii2HSSURERERERBbDpJOIiIiIiIgshkknERERERERWQyTTiIiIiIiIrIYJp1ERERERERkMUw6iYiIiIiIyGKYdBIREREREZHFFIukc9GiRfD19YWdnR0aNWqE48ePF2i+9evXQyaToVOnTpatIBERERERET0VqyedGzZswKhRoxAREYHTp08jMDAQoaGhuHv3bp7z3bhxA6NHj0bTpk2fU02JiIiIiIiosGRCCGHNCjRq1AgNGjTAwoULAQB6vR4+Pj4YNmwYxo8fb3IenU6H1157De+88w4OHjyIpKQk/PjjjwVaXkpKClxdXZGYmAgXF5dc0+VyOWxsbKRhjUZjtiyZTAalUvlUsZmZmTC36S0VCwAqleqpYrVaLfR6fZHEKpVKyGQyi8bqdDrodLoiibWxsYFcLi82sXq9Hlqt1mysQqGAQqEoNrFCCGRmZhZJbPbPp6Vigbw/yzxGmI7lMYLHCB4jCh/LY4T52KSkJLi7uyM5Odnk+RoRlSw2+YdYjkajwalTpzBhwgRpnFwuR0hICI4cOWJ2vo8//hgeHh4YMGAADh48mOcy1Go11Gq1NJySkgIAmD17Nuzs7HLFV6tWDb169ZKGIyMjzX4RVapUCf369ZOG58+fj/T0dJOx5cuXR3h4uDS8aNEiJCcnm4x1d3fH4MGDpeHly5cjMTHRZKyrqytGjhwpDUdFReHWrVsmYx0cHDBmzBhpeM2aNbh586bJWKVSiYkTJ0rDGzduxNWrV03GAkBERIT0fsuWLbh8+bLZ2AkTJkhfLtu2bcO5c+fMxo4ePRqOjo4AgF27duHkyZNmY0eMGAE3NzcAQExMTJ770KBBg+Dh4QEAOHjwIA4cOGA2duDAgfD29gYAHD16FHv37jUbGxYWBl9fXwDAqVOnsGPHDrOxPXv2hJ+fHwDgwoUL2Lp1q9nYrl27ombNmgCA2NhYbNq0yWxsx44dUbduXQDAtWvXsG7dOrOxbdu2RcOGDQEA8fHxWL16tdnYkJAQNGnSBACQkJCAFStWmI1t1qwZmjdvDgBITEzE4sWLzcYGBwejdevWAIDk5GTMnz/fbGxQUBDat28PAEhPT0dkZKTZ2MDAQKnrfWZmJmbNmmU2tkaNGujWrZs0nFcsjxEGPEY8wWOEAY8RBjxGGDzrMeL06dNmY4mo5LFq99p79+5Bp9PB09PTaLynpydu375tcp7ffvsNK1euxPLlywu0jFmzZsHV1VV6+fj4PHO9iYiIiIiIqGCs2r321q1b8Pb2xuHDhxEcHCyNHzt2LA4cOIBjx44ZxT969Ah16tTBV199hbZt2wIA+vXrl2f3WlMtnT4+PuxeW8hYdp1j1zl2nSt8LI8RTxfLY8SzxRaHzz2PETxG5Ixl91qi/zarJp0ajQYODg7YtGmT0RNow8LCkJSUlKsr0dmzZ1GvXj3pyweAdACTy+WIi4tDlSpV8lxm1j2dPIgRERERFU88XyN6sVi1e61KpUL9+vURExMjjdPr9YiJiTFq+cxSvXp1XLhwAWfPnpVe//vf/9CiRQucPXuWXWeJiIiIiIiKGas+SAgARo0ahbCwMAQFBaFhw4aYN28e0tLS0L9/fwBA37594e3tjVmzZsHOzg61atUymj/roRA5xxMREREREZH1WT3p7NGjBxITEzFlyhTcvn0bdevWxc6dO6WHC8XHx0v3qRAREREREVHJYvXf6XzeeI8AERERUfHG8zWiFwubEImIiIiIiMhimHQSERERERGRxTDpJCIiIiIiIoth0klEREREREQWw6STiIiIiIiILIZJJxEREREREVkMk04iIiIiIiKyGCadREREREREZDFMOomIiIiIiMhimHQSERERERGRxTDpJCIiIiIiIoth0klEREREREQWw6STiIiIiIiILIZJJxEREREREVkMk04iIiIiIiKyGCadREREREREZDFMOomIiIiIiMhimHQSERERERGRxTDpJCIiIiIiIoth0klEREREREQWw6STiIiIiIiILIZJJxEREREREVkMk04iIiIiIiKyGCadREREREREZDFMOomIiIiIiMhimHQSERERERGRxTDpJCIiIiIiIoth0klEREREREQWw6STiIiIiIiILIZJJxEREREREVkMk04iIiIiIiKyGCadREREREREZDFMOomIiIiIiMhimHQSERERERGRxdg8awEZGRnYsGED0tLS0KpVK1SrVq0o6kVEREREREQvgEIlnaNGjUJmZia+/PJLAIBGo0FwcDAuXboEBwcHjB07Fnv27EFwcLBFKktEREREREQlS6G61+7evRutWrWShtesWYObN2/i6tWrePjwIbp164bp06cXeSWJiIiIiIioZCpU0hkfH48aNWpIw7t370bXrl1RqVIlyGQyjBgxAmfOnCnyShIREREREVHJVKikUy6XQwghDR89ehSvvPKKNOzm5oaHDx8WXe2IiIiIiIioRCtU0hkQEICff/4ZAHDp0iXEx8ejRYsW0vSbN2/C09OzaGtIREREREREJVahks6xY8diwoQJaNmyJVq2bIl27dqhcuXK0vTo6Gg0bNiw0JVYtGgRfH19YWdnh0aNGuH48eNmYzdv3oygoCC4ubnB0dERdevWxbffflvoZRIREREREZHlFSrp7Ny5M6Kjo1GnTh188MEH2LBhg9F0BwcHDB48uFAV2LBhA0aNGoWIiAicPn0agYGBCA0Nxd27d03Gly5dGh999BGOHDmC8+fPo3///ujfvz927dpVqOUSERERERGR5clE9ps0raBRo0Zo0KABFi5cCADQ6/Xw8fHBsGHDMH78+AKV8fLLL6N9+/b45JNP8o1NSUmBq6srEhMT4eLikmu6XC6Hjc2TX5LRaDRmy5LJZFAqlU8Vm5mZCXOb3lKxAKBSqZ4qVqvVQq/XF0msUqmETCazaKxOp4NOpyuSWBsbG8jl8mITq9frodVqzcYqFAooFIpiEyuEQGZmZpHEZv98WioWyPuzzGOE6VgeI3iM4DGi8LE8RpiPTUpKgru7O5KTk02erxFRyVKo3+nMcvXqVWzduhU3btyATCZD5cqV0alTJ7z00kuFKkej0eDUqVOYMGGCNE4ulyMkJARHjhzJd34hBH755RfExcXhs88+MxmjVquhVqul4ZSUFADA7NmzYWdnlyu+WrVq6NWrlzQcGRlp9ouoUqVK6NevnzQ8f/58pKenm4wtX748wsPDpeFFixYhOTnZZKy7u7tRi/Hy5cuRmJhoMtbV1RUjR46UhqOionDr1i2TsQ4ODhgzZow0nPWTN6YolUpMnDhRGt64cSOuXr1qMhYAIiIipPdbtmzB5cuXzcZOmDBB+nLZtm0bzp07ZzZ29OjRcHR0BADs2rULJ0+eNBs7YsQIuLm5AQBiYmLy3IcGDRoEDw8PAMDBgwdx4MABs7EDBw6Et7c3AMPDs/bu3Ws2NiwsDL6+vgCAU6dOYceOHWZje/bsCT8/PwDAhQsXsHXrVrOxXbt2Rc2aNQEAsbGx2LRpk9nYjh07om7dugCAa9euYd26dWZj27ZtK3WJj4+Px+rVq83GhoSEoEmTJgCAhIQErFixwmxss2bN0Lx5cwBAYmIiFi9ebDY2ODgYrVu3BgAkJydj/vz5ZmODgoLQvn17AEB6ejoiIyPNxgYGBqJTp04ADCdGs2bNMhtbo0YNdOvWTRrOK5bHCAMeI57gMcKAxwgDHiMMnvUYcfr0abOxRFTyFDrpnDVrFiZPngwhBDw8PCCEQGJiIsaPH4+ZM2di9OjRBS7r3r170Ol0uR4+5Onpid9//93sfMnJyfD29oZarYZCocBXX31l9PuhOes7bdq0AteJiIiIiIiIik6hutfu27cPISEhmDx5MkaMGIFSpUoBAB48eIB58+Zh5syZ+OWXX/Daa68VqLxbt27B29sbhw8fRnBwsDR+7NixOHDgAI4dO2ZyPr1ejz/++AOpqamIiYnBJ598gh9//FG6apqdqZZOHx8fdq8tZCy7zrHrHLvOFT6Wx4ini+Ux4tlii8PnnscIHiNyxrJ7LdF/W6GSzh49esDNzQ1Lly41Of3dd9/Fo0eP8uyqk51Go4GDgwM2bdokdXEBDN2PkpKS8uxKlN3AgQPx119/FehhQln3dPIgRkRERFQ88XyN6MVSqKfXHj9+HH369DE7vU+fPjh69GiBy1OpVKhfvz5iYmKkcXq9HjExMUYtn/nR6/VGrZlERERERERUPBTqns47d+5ID0AwpXLlyrh9+3ahKjBq1CiEhYUhKCgIDRs2xLx585CWlob+/fsDAPr27Qtvb2/ppv1Zs2YhKCgIVapUgVqtRnR0NL799ts8H0JARERERERE1lGopDMjI8Ooz31OSqUyz/sRTOnRowcSExMxZcoU3L59G3Xr1sXOnTulhwvFx8dL96kAQFpaGgYPHoy///4b9vb2qF69Or777jv06NGjUMslIiIiIiIiyyvUPZ1yuRzTp0+Hk5OTyemPHj3ClClT8nzYgbXxHgEiIiKi4o3na0QvlkK1dFasWBHLly/PM6ZSpUrPVCEiIiIiIiJ6cRQq6bxx40ae0//++298/PHHz1IfIiIiIiIieoEU6um1+bl//z5WrlxZlEUSERERERFRCVakSScRERERERFRdkw6iYiIiIiIyGKYdBIREREREZHFFOpBQm+++Wae05OSkp6lLkRERERERPSCKVTS6erqmu/0vn37PlOFiIiIiIiI6MVRqKRz1apVlqoHERERERERvYB4TycRERERERFZDJNOIiIiIiIishgmnURERERERGQxTDqJiIiIiIjIYph0EhERERERkcUw6SQiIiIiIiKLYdJJREREREREFsOkk4iIiIiIiCyGSScRERERERFZDJNOIiIiIiIishgmnURERERERGQxTDqJiIiIiIjIYph0EhERERERkcUw6SQiIiIiIiKLYdJJREREREREFsOkk4iIiIiIiCyGSScRERERERFZDJNOIiIiIiIishgmnURERERERGQxTDqJiIiIiIjIYph0EhERERERkcUw6SQiIiIiIiKLYdJJREREREREFsOkk4iIiIiIiCyGSScRERERERFZDJNOIiIiIiIishgmnURERERERGQxTDqJiIiIiIjIYph0EhERERERkcUw6SQiIiIiIiKLYdJJREREREREFlMsks5FixbB19cXdnZ2aNSoEY4fP242dvny5WjatClKlSqFUqVKISQkJM94IiIiIiIish6rJ50bNmzAqFGjEBERgdOnTyMwMBChoaG4e/euyfj9+/ejZ8+e2LdvH44cOQIfHx+0bt0a//zzz3OuOREREREREeVHJoQQ1qxAo0aN0KBBAyxcuBAAoNfr4ePjg2HDhmH8+PH5zq/T6VCqVCksXLgQffv2zTc+JSUFrq6uSE5OhouLyzPXn4iIiIiKFs/XiF4sNtZcuEajwalTpzBhwgRpnFwuR0hICI4c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ERERkcUw6SQiIiIiIiKLYdJJREREREREFsOkk4iIiIiIiCyGSScRERERERFZDJNOIiIiIiIishgmnURERERERGQxTDqJiIiIiIjIYph0EhERERERkcUw6SQiIiIiIiKLYdJJREREREREFsOkk4iIiIiIiCyGSScRERERERFZDJNOIiIiIiIishgmnURERERERGQxTDqJiIiIiIjIYph0EhERERERkcUw6SQiIiIiIiKLYdJJREREREREFsOkk4iIiIiIiCyGSScRERERERFZDJNOIiIiIiIishgmnURERERERGQxTDqJiIiIiIjIYph0EhERERERkcUw6SQiIiIiIiKLYdJJREREREREFsOkk4iIiIiIiCyGSScRERERERFZDJNOIiIiIiIishgmnURERERERGQxTDqJiIiIiIjIYph0EhERERERkcUw6SQiIiIiIiKLYdJJREREREREFsOkk4iIiIiIiCzG6knnokWL4OvrCzs7OzRq1AjHjx83G3vp0iV06dIFvr6+kMlkmDdv3vOrKBERERERERWaVZPODRs2YNSoUYiIiMDp06cRGBiI0NBQ3L1712R8eno6XnrpJXz66acoV67cc64tERERERERFZZMCCGstfBGjRqhQYMGWLhwIQBAr9fDx8cHw4YNw/jx4/Oc19fXFyNHjsTIkSMLtcyUlBS4uroiMTERLi4uuabL5XLY2NhIwxqNxmxZMpkMSqXyqWIzMzNhbtNbKhYAVCrVU8VqtVro9foiiVUqlZDJZBaN1el00Ol0RRJrY2MDuVxebGL1ej20Wq3ZWIVCAYVCUWxihRDIzMwsktjsn09LxQJ5f5Z5jDAdy2MEjxE8RhQ+lscI87FJSUlwd3dHcnKyyfM1IipZbPIPsQyNRoNTp05hwoQJ0ji5XI6QkBAcOXKkyJajVquhVqul4ZSUFADA7NmzYWdnlyu+WrVq6NWrlzQcGRlp9ouoUqVK6NevnzQ8f/58pKenm4wtX748wsPDpeFFixYhOTnZZKy7uzsGDx4sDS9fvhyJiYkmY11dXY0S76ioKNy6dctkrIODA8aMGSMNr1mzBjdv3jQZq1QqMXHiRGl448aNuHr1qslYAIiIiJDeb9myBZcvXzYbO2HCBOnLZdu2bTh37pzZ2NGjR8PR0REAsGvXLpw8edJs7IgRI+Dm5gYAiImJyXM/GjRo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unfvjh49eqBnz56YOXMmTp48iZs3b2Lbtm0ICQnBvn37ClXet99+izJlyqB79+6oVauW9AoMDES7du3yfKCQg4MDwsPDERERIbVADhkyBN999x3Wrl0LZ2dn3L59G7dv38a///5rsoyzZ8/i9OnTGDhwoNHya9WqhZ49e2L16tXQarVScjJ16lRcvXoV27dvx+zZs43K8vX1RWpqKmJiYnDv3j2kp6ejWrVq6NixI8LDw/Hbb7/h3LlzePvtt+Ht7W3yYUwFVdBylUolhg0bhmPHjuHUqVPo168fXnnllXy71gKGlsPRo0fjgw8+wOrVq3H9+nWcPn0aX375JVavXg0AGDBgAHQ6Hf73v//h8OHDiIuLw65du5CamgoHB4d8HwhlSu/evWFnZ4ewsDBcvHgR+/btw7Bhw9CnTx+pa60p27Ztw4IFC3D27FncvHkT33zzDfR6Pfz9/Qu0LjnJZDKsWrUKcXFxaNKkCX766SdcvXoVly9fxpIlS5CYmCh1le3duzfKli2Ljh074uDBg/jzzz+xf/9+DB8+HH///XehtwEREdGLjkknEZklk8mwdu1azJkzBz/++COaNWuGOnXqYOrUqejYsSNCQ0MLVd7XX3+Nzp07S08Bza5Lly746aefcO/ePbPzDx06FLGxsfj+++8BAIsXL0ZycjKaN28OLy8v6bVhwwaT869cuRI1atRA9erVc03r3Lkz7t69i+joaCiVSqxbtw6///476tSpg88++yxXK17jxo3x/vvvo0ePHnB3d8fnn38OwPBk3vr16+ONN95AcHAwhBBSmc+iIOU6ODhg3Lhx6NWrF5o0aQInJyez28KUTz75BJMnT8asWbMQEBCANm3aYPv27VILcvny5XH8+HGULVsWb775JurVq4dvvvkG33zzDbZv345ly5Zhzpw5hVovBwcH7Nq1Cw8ePECDBg3QtWtXtGzZEgsXLsxzPjc3N2zevBmvv/46AgICsGTJEqxbtw41a9Ys0LqY8sorr+DUqVPw9/fHkCFDUKNGDTRu3Bjr1q3D3LlzMWjQIKnOv/76KypWrIg333wTAQEBGDBgADIyMuDi4lKo9SciIvovkIlneVIIERERERERUR7Y0klEREREREQWw6STiIiIiIiILIZJJxEREREREVkMk04iIiIiIiKyGCadVtSnTx/MnDnTYuXLZDL8+OOP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I0qVKiU8PT1FRESENF2v14uIiAjh4+MjVCqV8PLyEsOGDTO7LbM+c0uWLBEVKlQQ9vb2olu3biIpKUmKydpXpk+fLry8vISvr68QQojz58+LFi1aCDs7O1G6dGkRHh4uHj16lKvsgtBqteKDDz4Qrq6uonTp0mLMmDGib9++0j6ate45/8aF/T4qCqVKlRIrVqwwO33jxo1CpVIZ/d2yu3v3rlAqlUbHxB07dghXV1dx//59s+UOGTJEvP7660bjRo0aJZo0aWI0btq0aeLVV18tyKoQEZnEpNMKTp8+LQAYnSTdv39fVKhQQXz88cciISFBJCQkCCEMJ1pKpVI0btxYHDp0SPz+++8iLS1NxMTEiG+//VbExsaKy5cviwEDBghPT0+RkpIilWkq6axevbrYtm2biIuLE127dhWVKlUy+yUmhBAhISGiQ4cO4sSJE+LKlSviww8/FGXKlJG+xLZv3y6USqU4ceKESElJES+99JL44IMPpPnPnj0rlixZIi5cuCCuXLkiJk2aJOzs7MTNmzelmEqVKonSpUuLJUuWiCtXrohBgwYJFxcX0aZNG7Fx40YRFxcnOnXqJAICAoRerzfaLkFBQeLw4cPi5MmTomHDhqJx48ZSuTlPTr777jvh5eUlfvjhB/HHH3+IH374QZQuXVpERUUJIYT44osvhI+Pj/j111/FjRs3xMGDB8XatWvNbpus8k+dOiXkcrl0EmIq6XR0dMzz9d5770mxq1atEgqFQlSsWFFUqFBB/O9//xMXL16Upl+/fj3XSaUQQrz22mti+PDhQgghVq5cKdzc3IymZ2ZmCoVCISUBffr0MTr5EkKIX375RQAQDx48MLveORU06cxr38ueUKSnp4u9e/cKAOL48eMiISFBaLVasXnzZqFUKsWiRYtEXFycmD17tlAoFOKXX34xqouHh4f4+uuvxfXr18XNmzdFRESEcHJyEl27dhWXLl0SP/30k1CpVCI0NFQMGzZM/P777+Lrr78WAMTRo0dNruOjR49E9+7dRZs2baTPp1qtNpt0vvLKK+K3334Tp0+fFlWrVhXNmjUTrVu3FqdPnxa//vqrKFOmjPj000+l8qdPny6qV68udu7cKa5fvy5WrVolbG1tpQRwyJAhom7duuLEiRPizz//FHv27BE//fSTEEKI48ePCwBi7969IiEhQfps5re/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",
      "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": 33,
   "id": "70fb08b2-f74f-4492-b47a-b0bbc9b041e0",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('./gen_5000_0.5_scores_{}.pkl'.format(K), 'wb') as handle:\n",
    "    pickle.dump(seed_score_list, handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "abb6edb1-a3ee-4e14-86e7-443c46c8078d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49b3fe81-e15e-478d-94e9-d974edfdae5d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "43f7ca3a-0865-4299-bb7a-9fffe59af590",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "1607c463-df77-4f5c-bc18-866080849dd4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(seed_score_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "fc70e90a-ac36-48b0-82ed-6a3b9aa6a95f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(seed_score_list[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "45b82a31-0e5d-4292-9018-29364865a6ae",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "8"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(seed_score_list[0][0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "13219d07-cb2b-4c6b-a14c-f1f8642ffd3d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1000, 5000)"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_score_list[0][0][0].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "b012a62f-d6b4-4da4-97dd-196dad83b36f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1000, 5000)"
      ]
     },
     "execution_count": 38,
     "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": 39,
   "id": "134a59cf-e751-49b5-a5aa-8d1a0de4450c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.073 (avg p value 0.444913)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -np.stack(seed_score_list[0][0])[0:8].mean(axis=0)\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fafb0087-3122-46ad-94e2-8919881a0817",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "e7105050-c8e3-47e1-a532-c4111d35421e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.212 (avg p value 0.219691)\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": "7707dc06-bf82-46f3-b2a0-f8d5394f8c36",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9c3b6505-9c73-4bbd-9f66-ef8d8507f6ff",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a87d5928-f137-4a95-a402-d5a6c6097be6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "47bbc2ad-f41b-45c8-bc15-56ceda7e282a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "01f7a61c-2e11-4dad-a8bd-31217d033267",
   "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
}
