{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "31e0858d-12e5-4eaf-8cc3-f461d2aff756",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "974ba093-b42b-4ee9-a8c0-cd79d161435c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "8c2f5efb-631c-4083-84ae-dc219c6a75a1",
   "metadata": {},
   "outputs": [],
   "source": [
    "# from diffusers.utils import randn_tensor"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fde1d3d3-3ae3-4194-b2e8-596809be9636",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9e3a5e70-ec86-4af6-ad75-bdc4351b4d40",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "723df846-36f4-433c-99cf-044b96c870ec",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cf1854ba-184b-4c9f-9a5c-9158e786e404",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c4cadde9-8859-435a-b6ba-09aa42bb468d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "\n",
    "os.environ[\"CUDA_DEVICE_ORDER\"]=\"PCI_BUS_ID\"   \n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"]='0'\n",
    "\n",
    "os.environ[\"HF_HOME\"]=\"~/codes/.cache/huggingface\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "2f7cd96b-ca27-4ce1-ac2d-c3dd67e069b7",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import random\n",
    "import numpy as np\n",
    "\n",
    "def set_seeds(seed):\n",
    "    random.seed(seed)\n",
    "    np.random.seed(seed)\n",
    "    torch.manual_seed(seed)\n",
    "    torch.backends.cudnn.deterministic = True\n",
    "    torch.backends.cudnn.benchmark = False\n",
    "    \n",
    "set_seeds(42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "4ff495b8-8df0-49e8-a409-4ed9601c8143",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "def show_images(images, scores, test_artist, train_artists):\n",
    "    n: int = len(images)\n",
    "    f = plt.figure(figsize=(16, 2))\n",
    "    for i in range(n):\n",
    "        # Debug, plot figure\n",
    "        ax = f.add_subplot(1, n, i + 1)\n",
    "        if i==0:\n",
    "            pass\n",
    "            ax.title.set_text(test_artist)\n",
    "        else:\n",
    "            ax.title.set_text(str(np.round(scores[i-1], 4))+'\\n'+train_artists[i-1])\n",
    "            ax.axis('off')\n",
    "        if images[i]==None:\n",
    "            pass\n",
    "        else:\n",
    "            plt.imshow(images[i])\n",
    "\n",
    "    plt.show(block=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "c4e89a09-d6ff-46a1-8a9e-9c6f9c167114",
   "metadata": {},
   "outputs": [],
   "source": [
    "from datasets import load_dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2682e2c4-9275-4bae-a732-74b981a358d2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "fb2dc562-293c-4e74-8e97-141fc7465938",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "bda41875-8976-4852-823a-91dc1f42aebf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5000"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open('../../data/indices/5000-0.5/idx-train.pkl', 'rb')  as handle:\n",
    "    idx_train = pickle.load(handle)\n",
    "len(idx_train)   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "773b1a12-d60d-4ed8-8f61-b03a3af61e71",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "40c86797-31d5-45d0-b46f-52f8c84dd130",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'load_dataset' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[1], line 3\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;66;03m# from datasets import load_dataset\u001b[39;00m\n\u001b[0;32m----> 3\u001b[0m dataset \u001b[38;5;241m=\u001b[39m \u001b[43mload_dataset\u001b[49m(\n\u001b[1;32m      4\u001b[0m     \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mcifar10\u001b[39m\u001b[38;5;124m'\u001b[39m,\n\u001b[1;32m      5\u001b[0m     \u001b[38;5;66;03m# args.dataset_config_name,\u001b[39;00m\n\u001b[1;32m      6\u001b[0m     \u001b[38;5;66;03m# cache_dir=args.cache_dir,\u001b[39;00m\n\u001b[1;32m      7\u001b[0m     \u001b[38;5;66;03m# split=\"train\",\u001b[39;00m\n\u001b[1;32m      8\u001b[0m )\n",
      "\u001b[0;31mNameError\u001b[0m: name 'load_dataset' is not defined"
     ]
    }
   ],
   "source": [
    "from datasets import load_dataset\n",
    "\n",
    "dataset = load_dataset(\n",
    "    'cifar10',\n",
    "    # args.dataset_config_name,\n",
    "    # cache_dir=args.cache_dir,\n",
    "    # split=\"train\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c6632d56-9134-4720-99a9-1853fe349039",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5df420e1-7166-4e5b-baa3-a012fe7e32e1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "f2ce6b6b-ff45-4156-9606-7c87046e751a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<PIL.PngImagePlugin.PngImageFile image mode=RGB size=32x32>"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from datasets import DatasetDict, Dataset, load_dataset, Image\n",
    "\n",
    "train_dataset = dataset['train'].select(idx_train)\n",
    "train_dataset[0][\"img\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "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": 13,
   "id": "f2babffa-91ab-43ed-8312-2ef606f611bf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<PIL.PngImagePlugin.PngImageFile image mode=RGB size=32x32>"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "val_dataset[0]['img']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "a17ef712-5e24-4c38-bd27-fbf34ece6446",
   "metadata": {},
   "outputs": [],
   "source": [
    "# val_dataset =  dataset['test'].select(idx_val)\n",
    "# val_dataset[0][\"img\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "e16837b7-8ddd-46ab-9d0a-c988f2ca9514",
   "metadata": {},
   "outputs": [],
   "source": [
    "# idx_val[0:5]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8c2e0980-d551-48f4-8b1f-3f9d4ac788cb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "317f972c-b763-40d3-8186-759118c12237",
   "metadata": {},
   "outputs": [],
   "source": [
    "class Args():\n",
    "            \n",
    "    dataset_name=\"cifar10\"\n",
    "\n",
    "    output_dir=\"../../saved/5000-0.5/retrain\"\n",
    "    \n",
    "    project_dim=65536\n",
    "\n",
    "    used_dim=32768\n",
    "\n",
    "    strategy='uniform'\n",
    "    # strategy='cumulative'\n",
    "   \n",
    "args = Args()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "bb9d8f5f-5370-4157-be84-f77949771866",
   "metadata": {},
   "outputs": [],
   "source": [
    "import diffusers\n",
    "from diffusers import DDPMPipeline, DDPMScheduler, UNet2DModel\n",
    "from diffusers.optimization import get_scheduler"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "32c7cc29-8267-4fc3-915f-2628006b3af9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5396c1cc-03c9-407d-b4ba-d16f4b56bc25",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "c37c6ab7-8c07-416a-b7b1-4b2c03a82cfa",
   "metadata": {},
   "outputs": [],
   "source": [
    "# load ground truth\n",
    "my_list = [\n",
    "    0,1,2,3,\n",
    "    4,5,6,7,\n",
    "    8,9,10,11,\n",
    "    12,13,14,15,\n",
    "    16,17,18,19,\n",
    "    20,21,22,23,\n",
    "    24,25,26,27,\n",
    "    28,29,30,31,\n",
    "    32,33,34,35,\n",
    "    36,37,38,39,\n",
    "    40,41,42,43,\n",
    "    44,45,46,47,\n",
    "    48,49,50,51,\n",
    "    52,53,54,55,\n",
    "    56,57,58,59,\n",
    "    60,61,62,63,\n",
    "          ]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "7e5b270b-c5df-4b5d-a8fd-2a924a6edad6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000, 1000)"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "loss_array_list = []\n",
    "\n",
    "for i in my_list:\n",
    "    for seed in [\n",
    "        0,\n",
    "                 1,\n",
    "                 2,\n",
    "                 # 3,\n",
    "                 # 4,\n",
    "                ]:\n",
    "        for e_seed in [\n",
    "            0, \n",
    "                       1, \n",
    "                       2\n",
    "                      ]:\n",
    "            with open('../../saved/5000-0.5/lds-val/ddpm-sub-{}-{}/e-{}-gen.pkl'.format(i, seed, e_seed), 'rb')  as handle:\n",
    "                loss_list = pickle.load(handle)\n",
    "            margins = np.concatenate(loss_list, axis=-1) # -logp\n",
    "            ####\n",
    "            if (seed==0) and (e_seed)==0:\n",
    "                loss_array = margins\n",
    "            else:\n",
    "                loss_array += margins\n",
    "            \n",
    "    loss_array = loss_array/(3*3)\n",
    "    \n",
    "    loss_array_list.append(loss_array)\n",
    "lds_loss_array = np.stack(loss_array_list)\n",
    "lds_loss_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "d823ef7b-9d53-4f31-ab11-864274554493",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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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": 21,
   "id": "874a332c-29b1-46fe-bf83-12e7c8f64e28",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 5000)"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mask_array_list = []\n",
    "\n",
    "for i in my_list:\n",
    "    # print(i)\n",
    "    with open('../../data/indices/5000-0.5/lds-val/sub-idx-{}.pkl'.format(i), 'rb')  as handle:\n",
    "        sub_idx_train = pickle.load(handle)\n",
    "    # print(len(sub_idx_train))\n",
    "    mask_array = np.in1d(idx_train, sub_idx_train)\n",
    "        \n",
    "    mask_array_list.append(mask_array)\n",
    "    \n",
    "lds_mask_array = np.stack(mask_array_list)\n",
    "lds_mask_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "41ebfcfb-5789-44f0-99d0-0dddc7c6f32f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000)"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "lds_testset_correctness = lds_loss_array.mean(axis=1)\n",
    "lds_testset_correctness.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "46afee77-65eb-4023-8077-d11ed785d406",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for j in range(4):\n",
    "    plt.plot(lds_testset_correctness[:, j], color=\"C{}\".format(j))\n",
    "    # break\n",
    "# plt.ylim(0.15, 0.2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8d92c4b4-5b21-434f-b6cc-96e968cbe495",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "8fa5fded-088f-45ea-9b39-f7e8657a2a77",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "27\n"
     ]
    }
   ],
   "source": [
    "from scipy.stats import spearmanr, pearsonr\n",
    "f_name_list = [\n",
    "    'loss', \n",
    "    ####\n",
    "    # 'mean',\n",
    "    'mean-squared-l2-norm', \n",
    "    ####\n",
    "    # 'l1_norm',\n",
    "    # 'l2_norm',\n",
    "    # 'linf_norm'\n",
    "    ####\n",
    "]\n",
    "\n",
    "lamb_list = [\n",
    "\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",
    "\n",
    "print(len(lamb_list))\n",
    "\n",
    "\n",
    "ckpt_list = [\n",
    "    0, 1, \n",
    "    2, 3, 4, 5, 6, 7, \n",
    "    # 8\n",
    "            ]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "45989db6-7d72-4cd8-923a-bbc516a41805",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1\n",
      "loss\n",
      "0\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(55.5753, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.000 (avg p value 0.495841)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(51.5467, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.501511)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.6873, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.154 (avg p value 0.305954)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5628, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.156 (avg p value 0.300974)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2526, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.156 (avg p value 0.300370)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.157 (avg p value 0.298693)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8524, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.158 (avg p value 0.295944)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4284, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.160 (avg p value 0.292460)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1736, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.164 (avg p value 0.285041)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0882, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.169 (avg p value 0.275854)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0450, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.174 (avg p value 0.267232)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0186, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.178 (avg p value 0.261479)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.177 (avg p value 0.270382)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0048, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.172 (avg p value 0.286902)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.159 (avg p value 0.315278)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.146 (avg p value 0.335602)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.132 (avg p value 0.357321)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.114 (avg p value 0.387689)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9781e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.103 (avg p value 0.404159)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9936e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.092 (avg p value 0.420873)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9987e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.077 (avg p value 0.441382)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9963e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.067 (avg p value 0.455877)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.059 (avg p value 0.468110)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.478340)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9992e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.045 (avg p value 0.480932)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.043 (avg p value 0.481758)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.042 (avg p value 0.482326)\n",
      "1\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(60.0032, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.490653)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(49.7194, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.479448)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.6346, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.156 (avg p value 0.306146)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5575, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.158 (avg p value 0.302765)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2521, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.158 (avg p value 0.303068)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7006, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.159 (avg p value 0.301493)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8524, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.160 (avg p value 0.299924)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4284, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.162 (avg p value 0.296507)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1736, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.167 (avg p value 0.287968)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0882, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.172 (avg p value 0.278511)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0450, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.178 (avg p value 0.269160)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0186, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.182 (avg p value 0.261930)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.181 (avg p value 0.267035)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0048, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.176 (avg p value 0.278922)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.162 (avg p value 0.308076)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.148 (avg p value 0.330754)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.134 (avg p value 0.353305)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.117 (avg p value 0.377837)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9780e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.106 (avg p value 0.392016)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9936e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.095 (avg p value 0.412024)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9987e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.081 (avg p value 0.433163)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9963e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.070 (avg p value 0.449112)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.061 (avg p value 0.466123)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.052 (avg p value 0.477595)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9992e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.048 (avg p value 0.482854)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.045 (avg p value 0.484432)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.044 (avg p value 0.485449)\n",
      "2\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(59.4196, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.496043)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(47.8189, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.492426)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.7325, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.158 (avg p value 0.306134)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5673, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.160 (avg p value 0.304256)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2533, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.160 (avg p value 0.303352)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7006, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.302228)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8525, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.162 (avg p value 0.301497)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4284, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.164 (avg p value 0.297699)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1736, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.168 (avg p value 0.290991)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0882, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.172 (avg p value 0.283065)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0450, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.177 (avg p value 0.272611)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0186, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.179 (avg p value 0.264778)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.178 (avg p value 0.269895)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0048, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.172 (avg p value 0.284471)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.158 (avg p value 0.312917)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.145 (avg p value 0.341195)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.131 (avg p value 0.362306)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.113 (avg p value 0.391454)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9781e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.102 (avg p value 0.406493)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9936e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.092 (avg p value 0.419418)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9987e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.079 (avg p value 0.436098)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9963e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.069 (avg p value 0.446914)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.061 (avg p value 0.465824)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.052 (avg p value 0.478419)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9992e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.048 (avg p value 0.482640)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.045 (avg p value 0.484504)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.043 (avg p value 0.485938)\n",
      "3\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(58.0403, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.496385)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(50.2044, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.490558)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.7211, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.159 (avg p value 0.295818)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5662, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.296067)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2531, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.297037)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7006, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.296326)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8524, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.162 (avg p value 0.294776)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4284, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.164 (avg p value 0.291677)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1736, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.169 (avg p value 0.282301)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0882, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.173 (avg p value 0.273675)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0450, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.178 (avg p value 0.265741)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0186, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.181 (avg p value 0.266112)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.180 (avg p value 0.271214)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0048, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.174 (avg p value 0.285982)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.159 (avg p value 0.314978)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.145 (avg p value 0.340760)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.131 (avg p value 0.365106)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.113 (avg p value 0.392827)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9780e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.103 (avg p value 0.402742)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9935e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.093 (avg p value 0.419543)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9987e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.079 (avg p value 0.430370)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9962e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.069 (avg p value 0.447393)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9988e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.060 (avg p value 0.465553)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9997e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.479050)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9992e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.046 (avg p value 0.481904)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.044 (avg p value 0.483055)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.042 (avg p value 0.484271)\n",
      "4\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(58.4195, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.497730)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(47.8368, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.506858)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.6688, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.156 (avg p value 0.313147)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5610, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.158 (avg p value 0.307772)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2525, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.159 (avg p value 0.305359)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7006, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.160 (avg p value 0.303699)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8524, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.301555)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4284, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.162 (avg p value 0.297988)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1736, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.166 (avg p value 0.290550)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0882, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.171 (avg p value 0.281763)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0450, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.176 (avg p value 0.274664)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0186, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.179 (avg p value 0.269436)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.177 (avg p value 0.273895)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0048, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.172 (avg p value 0.284900)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.159 (avg p value 0.314163)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.145 (avg p value 0.337855)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.131 (avg p value 0.358978)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.113 (avg p value 0.384342)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9782e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.103 (avg p value 0.401273)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9936e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.093 (avg p value 0.413331)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9987e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.080 (avg p value 0.424863)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9963e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.069 (avg p value 0.437710)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.060 (avg p value 0.458002)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.472379)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9992e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.046 (avg p value 0.478392)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.044 (avg p value 0.480110)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.042 (avg p value 0.480804)\n",
      "5\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(60.7891, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.499362)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(49.0912, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.008 (avg p value 0.489185)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.6261, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.153 (avg p value 0.302102)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5567, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.155 (avg p value 0.299248)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2520, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.155 (avg p value 0.299433)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7006, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.156 (avg p value 0.298457)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8525, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.157 (avg p value 0.296365)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4285, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.159 (avg p value 0.293490)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1737, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.164 (avg p value 0.283998)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0882, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.169 (avg p value 0.276051)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0450, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.174 (avg p value 0.267219)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0186, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.178 (avg p value 0.259336)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.177 (avg p value 0.261047)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0048, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.171 (avg p value 0.276905)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.157 (avg p value 0.311252)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.144 (avg p value 0.335709)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.130 (avg p value 0.360454)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.113 (avg p value 0.384811)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9784e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.102 (avg p value 0.400472)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9937e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.092 (avg p value 0.410907)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9988e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.079 (avg p value 0.427142)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9963e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.068 (avg p value 0.444681)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.059 (avg p value 0.466466)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.476626)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9992e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.045 (avg p value 0.481811)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.043 (avg p value 0.482859)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.042 (avg p value 0.483721)\n",
      "6\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(58.0059, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.490336)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(48.5743, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.494481)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.6848, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.156 (avg p value 0.304231)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5627, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.159 (avg p value 0.298571)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2528, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.160 (avg p value 0.297557)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7007, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.296438)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8525, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.162 (avg p value 0.293979)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4285, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.164 (avg p value 0.290821)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1736, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.169 (avg p value 0.282139)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0882, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.174 (avg p value 0.274855)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0450, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.179 (avg p value 0.266066)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0186, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.183 (avg p value 0.261173)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.181 (avg p value 0.266684)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0048, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.175 (avg p value 0.280555)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.311971)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.146 (avg p value 0.333348)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.132 (avg p value 0.355670)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.114 (avg p value 0.384800)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9782e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.103 (avg p value 0.398060)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9936e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.093 (avg p value 0.413751)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9987e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.079 (avg p value 0.429273)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9963e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.068 (avg p value 0.444447)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.059 (avg p value 0.462761)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.478455)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9992e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.045 (avg p value 0.481450)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.043 (avg p value 0.483800)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.041 (avg p value 0.484652)\n",
      "7\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(60.1515, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.013 (avg p value 0.487586)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(50.7932, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.506467)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.6363, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.159 (avg p value 0.300942)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5576, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.160 (avg p value 0.297628)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2520, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.160 (avg p value 0.296418)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.161 (avg p value 0.296213)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8524, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.162 (avg p value 0.293460)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4284, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.164 (avg p value 0.290379)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1736, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.168 (avg p value 0.281797)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0882, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.173 (avg p value 0.272634)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0450, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.178 (avg p value 0.263874)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0186, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.181 (avg p value 0.257924)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.179 (avg p value 0.262532)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0048, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.173 (avg p value 0.274897)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.159 (avg p value 0.300579)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.145 (avg p value 0.326682)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.130 (avg p value 0.355528)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.112 (avg p value 0.386961)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9780e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.101 (avg p value 0.399131)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9936e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.091 (avg p value 0.418086)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9987e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.078 (avg p value 0.436027)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9963e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.068 (avg p value 0.448514)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.059 (avg p value 0.465559)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.475538)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9992e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.046 (avg p value 0.480742)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.043 (avg p value 0.482382)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.042 (avg p value 0.482891)\n",
      "mean-squared-l2-norm\n",
      "0\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(-0.0004, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.486331)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0050, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.500395)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0131, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.010 (avg p value 0.506180)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0304, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.481736)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0423, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.000 (avg p value 0.502264)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0618, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.504497)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0494, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.515712)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0578, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.505625)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0436, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.014 (avg p value 0.514340)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0330, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.501579)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0246, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.518446)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0164, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.507316)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0097, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.011 (avg p value 0.491696)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0046, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.232 (avg p value 0.181473)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.246 (avg p value 0.159275)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.252 (avg p value 0.152133)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.253 (avg p value 0.151865)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.246 (avg p value 0.162272)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8234e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.237 (avg p value 0.174549)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9428e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.224 (avg p value 0.189930)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9873e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.207 (avg p value 0.215368)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9599e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.192 (avg p value 0.239643)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9873e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.177 (avg p value 0.264631)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9972e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.156 (avg p value 0.303204)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9910e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.140 (avg p value 0.336517)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9970e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.124 (avg p value 0.364687)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9993e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.106 (avg p value 0.392670)\n",
      "1\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(-0.0061, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.481960)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0100, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.482902)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0109, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.010 (avg p value 0.504631)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0344, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.004 (avg p value 0.499700)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0622, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.000 (avg p value 0.502304)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0642, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.501458)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0772, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.010 (avg p value 0.511856)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0593, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.491390)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0442, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.482258)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0338, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.015 (avg p value 0.509869)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0237, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.505188)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0147, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.000 (avg p value 0.494784)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0098, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.018 (avg p value 0.493349)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0046, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.234 (avg p value 0.170378)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.248 (avg p value 0.151482)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.254 (avg p value 0.147026)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.253 (avg p value 0.146557)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.247 (avg p value 0.158346)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8207e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.238 (avg p value 0.173617)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9418e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.227 (avg p value 0.193045)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9871e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.209 (avg p value 0.220900)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9592e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.194 (avg p value 0.244682)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9871e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.178 (avg p value 0.271317)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9971e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.156 (avg p value 0.309855)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9908e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.139 (avg p value 0.338800)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9970e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.124 (avg p value 0.366336)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9993e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.106 (avg p value 0.393465)\n",
      "2\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0062, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.498634)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0108, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.013 (avg p value 0.482603)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0233, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.000 (avg p value 0.499701)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(-0.0170, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.521901)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0257, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.493843)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0606, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.500281)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0688, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.489965)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0572, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.481836)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0431, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.484037)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0335, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.503740)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0251, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.497240)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0154, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.507035)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0090, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.492727)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0046, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.236 (avg p value 0.171280)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.249 (avg p value 0.154982)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.255 (avg p value 0.148458)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.255 (avg p value 0.148206)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.248 (avg p value 0.159451)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8246e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.239 (avg p value 0.173252)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9431e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.226 (avg p value 0.192285)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9874e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.207 (avg p value 0.219105)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9599e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.192 (avg p value 0.240859)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9873e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.177 (avg p value 0.264780)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9972e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.155 (avg p value 0.306507)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9909e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.139 (avg p value 0.336226)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9970e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.124 (avg p value 0.364851)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9993e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.107 (avg p value 0.393285)\n",
      "3\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0075, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.523427)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0087, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.503993)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0183, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.000 (avg p value 0.515473)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0317, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.532543)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0470, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.494085)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0714, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.507344)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0641, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.479641)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0562, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.006 (avg p value 0.497800)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0435, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.514027)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0335, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.011 (avg p value 0.492913)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0233, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.017 (avg p value 0.499389)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0150, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.507173)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0096, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.027 (avg p value 0.508420)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0046, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.232 (avg p value 0.180550)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.245 (avg p value 0.162663)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.249 (avg p value 0.157461)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.249 (avg p value 0.158249)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.242 (avg p value 0.171062)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8241e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.233 (avg p value 0.185215)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9429e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.221 (avg p value 0.199440)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9874e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.204 (avg p value 0.223832)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9600e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.190 (avg p value 0.248727)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9873e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.175 (avg p value 0.273404)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9972e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.154 (avg p value 0.315874)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9910e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.138 (avg p value 0.344054)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9970e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.123 (avg p value 0.366319)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9993e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.106 (avg p value 0.395528)\n",
      "4\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0717, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.012 (avg p value 0.494912)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0153, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.009 (avg p value 0.507764)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(-0.0365, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.509460)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0791, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.499400)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0402, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.498510)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0667, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.488267)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0691, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.492116)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0608, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.499980)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0450, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.506574)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0344, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.489686)\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.499730)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0154, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.503624)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0096, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.014 (avg p value 0.492109)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0046, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.228 (avg p value 0.185312)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.242 (avg p value 0.163814)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.248 (avg p value 0.155402)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.249 (avg p value 0.156234)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.244 (avg p value 0.166001)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8235e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.234 (avg p value 0.183777)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9428e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.222 (avg p value 0.201613)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9873e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.204 (avg p value 0.226779)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9599e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.190 (avg p value 0.248519)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9873e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.175 (avg p value 0.276185)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9972e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.153 (avg p value 0.317169)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9909e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.137 (avg p value 0.344630)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9970e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.122 (avg p value 0.368465)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9993e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.105 (avg p value 0.394666)\n",
      "5\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(-0.0054, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.506860)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0096, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.004 (avg p value 0.503481)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0055, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.515827)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0213, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.500625)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0803, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.491099)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0633, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.500695)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0630, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.012 (avg p value 0.501711)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0582, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.502158)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0406, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.514986)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0286, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.507700)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0246, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.494682)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0157, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.503258)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0097, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.015 (avg p value 0.497617)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0046, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.232 (avg p value 0.174800)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.247 (avg p value 0.155491)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.253 (avg p value 0.148539)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.253 (avg p value 0.149772)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.246 (avg p value 0.160861)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8242e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.236 (avg p value 0.174570)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9429e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.224 (avg p value 0.195851)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9873e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.204 (avg p value 0.225722)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9598e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.189 (avg p value 0.252826)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9872e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.174 (avg p value 0.280319)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9972e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.153 (avg p value 0.319517)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9909e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.137 (avg p value 0.343952)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9970e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.122 (avg p value 0.369058)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9993e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.105 (avg p value 0.395353)\n",
      "6\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.506919)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0101, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.500386)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0007, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.494997)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0222, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.495089)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0497, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.495219)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0566, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.014 (avg p value 0.489262)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0657, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.503047)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0584, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.489828)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0433, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.506438)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0336, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.013 (avg p value 0.483708)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0253, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.010 (avg p value 0.489050)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0155, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.507747)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0097, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.024 (avg p value 0.502901)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0046, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.236 (avg p value 0.173853)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.248 (avg p value 0.157722)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.253 (avg p value 0.148128)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.253 (avg p value 0.147766)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.245 (avg p value 0.160110)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8279e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.234 (avg p value 0.177121)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9441e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.223 (avg p value 0.195569)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9876e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.205 (avg p value 0.222990)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9608e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.191 (avg p value 0.244835)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9876e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.175 (avg p value 0.272131)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9972e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.153 (avg p value 0.314295)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9911e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.137 (avg p value 0.345788)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9971e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.122 (avg p value 0.368602)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9993e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.106 (avg p value 0.396783)\n",
      "7\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0038, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.500586)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0024, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.491538)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0232, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.014 (avg p value 0.497846)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0289, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.498435)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0461, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.506019)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.3783, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.009 (avg p value 0.483635)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0721, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.004 (avg p value 0.494826)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0573, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.502356)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0444, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.503338)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0345, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.493951)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0250, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.490800)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0153, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.012 (avg p value 0.506398)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0097, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.025 (avg p value 0.490297)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0046, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.234 (avg p value 0.176494)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.249 (avg p value 0.158063)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.254 (avg p value 0.151471)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.254 (avg p value 0.151381)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.246 (avg p value 0.162774)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8282e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.236 (avg p value 0.181036)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9443e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.225 (avg p value 0.199708)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9877e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.207 (avg p value 0.225668)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9609e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.192 (avg p value 0.244376)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9876e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.176 (avg p value 0.270185)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9973e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.155 (avg p value 0.310763)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9911e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.138 (avg p value 0.340123)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9971e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.124 (avg p value 0.365015)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9993e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.106 (avg p value 0.394008)\n"
     ]
    }
   ],
   "source": [
    "# for loop over functions\n",
    "seed_lds_list = []\n",
    "\n",
    "seed_score_list = []\n",
    "\n",
    "for num_seed in [\n",
    "    1, \n",
    "    # 2, 3, 4, 5\n",
    "]:\n",
    "    print(num_seed)\n",
    "    f_lds_list = []\n",
    "\n",
    "    f_score_list = []\n",
    "    \n",
    "    for f in f_name_list:\n",
    "        ####\n",
    "        print(f)\n",
    "        \n",
    "        lds_list = []\n",
    "        \n",
    "        score_list = []\n",
    "        \n",
    "        K = 100\n",
    "        for ckpt in ckpt_list:\n",
    "            print(ckpt)\n",
    "            ####\n",
    "            dstore_keys_list = []\n",
    "            for split in range(5):\n",
    "                tmp = None\n",
    "                for e_seed in range(num_seed):\n",
    "                    dstore_keys = np.memmap('{}/ddpm-sub-{}-0/features-{}/ddpm-train-keys-{}-{}-{}-{}-{}.npy'.format(\n",
    "                        args.output_dir, ckpt, e_seed,\n",
    "                        split, K, args.project_dim, f, args.strategy), \n",
    "                                        dtype=np.float32, \n",
    "                                        mode='r',\n",
    "                                        shape=(1000, args.project_dim))\n",
    "                    dstore_keys = dstore_keys[:, :args.used_dim]\n",
    "                    if e_seed==0:\n",
    "                        tmp = dstore_keys.copy()\n",
    "                    else:\n",
    "                        tmp += dstore_keys\n",
    "                tmp = tmp/num_seed\n",
    "                dstore_keys_list.append(tmp) \n",
    "            \n",
    "            dstore_keys = np.vstack(dstore_keys_list)\n",
    "            print(dstore_keys.shape)  \n",
    "            \n",
    "            if f=='l1_norm':\n",
    "                dstore_keys = dstore_keys / 3072\n",
    "            elif f=='l2_norm':\n",
    "                dstore_keys = dstore_keys / (3072**0.5)\n",
    "            ####    \n",
    "            tmp = None\n",
    "            for e_seed in range(num_seed):\n",
    "                gen_dstore_keys = np.memmap('{}/ddpm-sub-{}-0/features-{}/ddpm-gen-keys-{}-{}-{}-{}-{}.npy'.format(\n",
    "                       args.output_dir, ckpt, e_seed, \n",
    "                    0, K, args.project_dim, f, args.strategy), \n",
    "                                    dtype=np.float32, \n",
    "                                    mode='r',\n",
    "                                    shape=(1000, args.project_dim))\n",
    "                gen_dstore_keys = gen_dstore_keys[:, :args.used_dim]\n",
    "                if e_seed==0:\n",
    "                    tmp = gen_dstore_keys.copy()\n",
    "                else:\n",
    "                    tmp += gen_dstore_keys\n",
    "            tmp = tmp/num_seed\n",
    "            gen_dstore_keys = tmp\n",
    "            print(gen_dstore_keys.shape)\n",
    "            if f=='l1_norm':\n",
    "                gen_dstore_keys = gen_dstore_keys / 3072\n",
    "            elif f=='l2_norm':\n",
    "                gen_dstore_keys = gen_dstore_keys / (3072**0.5)\n",
    "            ####\n",
    "            dstore_keys = torch.from_numpy(dstore_keys).cuda()\n",
    "            gen_dstore_keys = torch.from_numpy(gen_dstore_keys).cuda()\n",
    "            ####\n",
    "            # if f=='l1_norm':\n",
    "            #     dstore_keys = dstore_keys/3072\n",
    "            #     gen_dstore_keys = gen_dstore_keys/3072\n",
    "            ####\n",
    "            kernel = dstore_keys.T@dstore_keys\n",
    "            ####\n",
    "            rs_list = []\n",
    "            ps_list = []\n",
    "\n",
    "            best_scores = None\n",
    "            best_lds = -np.inf\n",
    "            for lamb in lamb_list:\n",
    "                print(lamb)\n",
    "                # kernel_ = kernel + lamb*np.eye(kernel.shape[0])\n",
    "                kernel_ = kernel + lamb*torch.eye(kernel.shape[0]).cuda()\n",
    "                # kernel_ = torch.from_numpy(kernel_).cuda()\n",
    "                ####\n",
    "                kernel_ = torch.linalg.inv(kernel_)  \n",
    "                # kernel_ = kernel_.cpu().numpy()\n",
    "                ####\n",
    "                print(kernel_.shape)\n",
    "                print(torch.mean(kernel_.diagonal()))\n",
    "                ####\n",
    "                # scores = gen_dstore_keys.dot((dstore_keys@kernel_).T)\n",
    "                scores = gen_dstore_keys@((dstore_keys@kernel_).T)\n",
    "                print(scores.size())\n",
    "                scores = scores.cpu().numpy()\n",
    "    \n",
    "                # compute lds\n",
    "                margins = lds_testset_correctness\n",
    "                infl_est_ = -scores\n",
    "                preds = lds_mask_array @ infl_est_.T\n",
    "                ####\n",
    "                rs = []\n",
    "                ps = []\n",
    "    \n",
    "                for ind in range(1000):\n",
    "                   r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "                   # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "                   rs.append(r)\n",
    "                   ps.append(p)\n",
    "        \n",
    "                rs, ps = np.array(rs), np.array(ps)\n",
    "                print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "    \n",
    "                rs_list.append(rs.mean())   \n",
    "                ps_list.append(ps.mean())\n",
    "                \n",
    "                if rs.mean()>best_lds:\n",
    "                    best_scores = scores\n",
    "                    best_lds = rs.mean()\n",
    "                    \n",
    "            lds_list.append((rs_list, ps_list))\n",
    "            score_list.append(best_scores)\n",
    "            \n",
    "        f_lds_list.append(lds_list)\n",
    "        f_score_list.append(score_list)\n",
    "    seed_lds_list.append(f_lds_list)\n",
    "    seed_score_list.append(f_score_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8970c9b6-4694-4c06-b9a9-ec38f5f6b55e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "73ae9625-b9dc-432c-94b6-6cfcdc726a94",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e8258b5b-5a58-45b1-a727-0a8a0a94fc81",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "c08f885c-95db-4cfb-a235-b8ddddcd3a50",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[[[-7.27791586e-05,  3.76488080e-03,  1.53668232e-01,\n",
       "           1.55550558e-01,  1.55773178e-01,  1.56630228e-01,\n",
       "           1.57918804e-01,  1.59681556e-01,  1.64149620e-01,\n",
       "           1.69085448e-01,  1.73844192e-01,  1.77819265e-01,\n",
       "           1.77008704e-01,  1.71809618e-01,  1.58998717e-01,\n",
       "           1.46255811e-01,  1.32011691e-01,  1.14419016e-01,\n",
       "           1.02994041e-01,  9.21118722e-02,  7.73388177e-02,\n",
       "           6.67373067e-02,  5.87878574e-02,  4.97846735e-02,\n",
       "           4.52649162e-02,  4.33485245e-02,  4.18082776e-02],\n",
       "         [ 4.95841314e-01,  5.01511402e-01,  3.05953969e-01,\n",
       "           3.00974407e-01,  3.00370348e-01,  2.98692746e-01,\n",
       "           2.95944256e-01,  2.92460456e-01,  2.85041038e-01,\n",
       "           2.75853927e-01,  2.67231792e-01,  2.61478940e-01,\n",
       "           2.70382065e-01,  2.86901510e-01,  3.15278157e-01,\n",
       "           3.35602105e-01,  3.57321363e-01,  3.87689177e-01,\n",
       "           4.04158686e-01,  4.20873251e-01,  4.41381980e-01,\n",
       "           4.55876557e-01,  4.68109928e-01,  4.78339795e-01,\n",
       "           4.80931799e-01,  4.81757887e-01,  4.82325674e-01]],\n",
       "\n",
       "        [[ 7.82133507e-03,  5.49329351e-03,  1.55574911e-01,\n",
       "           1.57731595e-01,  1.58168111e-01,  1.59030107e-01,\n",
       "           1.60056115e-01,  1.61925140e-01,  1.66974843e-01,\n",
       "           1.72249433e-01,  1.77893940e-01,  1.82245865e-01,\n",
       "           1.80694836e-01,  1.75603123e-01,  1.61863719e-01,\n",
       "           1.48459846e-01,  1.34127652e-01,  1.16948231e-01,\n",
       "           1.05568835e-01,  9.47228668e-02,  8.12235710e-02,\n",
       "           7.03006992e-02,  6.10672280e-02,  5.19286963e-02,\n",
       "           4.78354299e-02,  4.54262693e-02,  4.39393420e-02],\n",
       "         [ 4.90653497e-01,  4.79447612e-01,  3.06146040e-01,\n",
       "           3.02765121e-01,  3.03068362e-01,  3.01493192e-01,\n",
       "           2.99923752e-01,  2.96506967e-01,  2.87968282e-01,\n",
       "           2.78510526e-01,  2.69160318e-01,  2.61930470e-01,\n",
       "           2.67035352e-01,  2.78921536e-01,  3.08076424e-01,\n",
       "           3.30753533e-01,  3.53305262e-01,  3.77837006e-01,\n",
       "           3.92015617e-01,  4.12024083e-01,  4.33163202e-01,\n",
       "           4.49111957e-01,  4.66123490e-01,  4.77594917e-01,\n",
       "           4.82854073e-01,  4.84431579e-01,  4.85449089e-01]],\n",
       "\n",
       "        [[-3.05075444e-03,  8.74207850e-03,  1.57813906e-01,\n",
       "           1.59999370e-01,  1.60252254e-01,  1.61132153e-01,\n",
       "           1.62009420e-01,  1.63993119e-01,  1.67769196e-01,\n",
       "           1.72065991e-01,  1.76634994e-01,  1.79414091e-01,\n",
       "           1.77673178e-01,  1.71543689e-01,  1.58365003e-01,\n",
       "           1.45123145e-01,  1.31152311e-01,  1.13418174e-01,\n",
       "           1.02287950e-01,  9.23077077e-02,  7.90358660e-02,\n",
       "           6.92349273e-02,  6.06255173e-02,  5.19022332e-02,\n",
       "           4.77751495e-02,  4.50435560e-02,  4.33193341e-02],\n",
       "         [ 4.96043068e-01,  4.92425586e-01,  3.06134167e-01,\n",
       "           3.04256161e-01,  3.03351715e-01,  3.02228365e-01,\n",
       "           3.01497415e-01,  2.97699277e-01,  2.90990733e-01,\n",
       "           2.83065359e-01,  2.72611049e-01,  2.64778252e-01,\n",
       "           2.69895452e-01,  2.84471473e-01,  3.12916671e-01,\n",
       "           3.41194826e-01,  3.62306413e-01,  3.91454131e-01,\n",
       "           4.06492999e-01,  4.19418136e-01,  4.36097635e-01,\n",
       "           4.46913949e-01,  4.65824347e-01,  4.78419197e-01,\n",
       "           4.82640403e-01,  4.84503595e-01,  4.85938020e-01]],\n",
       "\n",
       "        [[ 3.07135419e-03,  1.29960642e-03,  1.59466993e-01,\n",
       "           1.60946479e-01,  1.60815735e-01,  1.61474043e-01,\n",
       "           1.62386406e-01,  1.64192152e-01,  1.68735467e-01,\n",
       "           1.73132858e-01,  1.78231187e-01,  1.81461682e-01,\n",
       "           1.80354927e-01,  1.73562937e-01,  1.59059705e-01,\n",
       "           1.45112175e-01,  1.30731339e-01,  1.13190286e-01,\n",
       "           1.03011369e-01,  9.25575933e-02,  7.92059439e-02,\n",
       "           6.88688551e-02,  5.95590325e-02,  5.05043840e-02,\n",
       "           4.60598090e-02,  4.36792917e-02,  4.23819471e-02],\n",
       "         [ 4.96384931e-01,  4.90557511e-01,  2.95818162e-01,\n",
       "           2.96067243e-01,  2.97037423e-01,  2.96325985e-01,\n",
       "           2.94776089e-01,  2.91676981e-01,  2.82301031e-01,\n",
       "           2.73674773e-01,  2.65740996e-01,  2.66112309e-01,\n",
       "           2.71214482e-01,  2.85982437e-01,  3.14978373e-01,\n",
       "           3.40759718e-01,  3.65106317e-01,  3.92826627e-01,\n",
       "           4.02741687e-01,  4.19543077e-01,  4.30370098e-01,\n",
       "           4.47392518e-01,  4.65552940e-01,  4.79050149e-01,\n",
       "           4.81904110e-01,  4.83054683e-01,  4.84270996e-01]],\n",
       "\n",
       "        [[ 1.13396040e-03,  2.73562371e-03,  1.55641124e-01,\n",
       "           1.57966193e-01,  1.58979449e-01,  1.59652961e-01,\n",
       "           1.60646437e-01,  1.62300146e-01,  1.66160357e-01,\n",
       "           1.71131101e-01,  1.76149348e-01,  1.78657155e-01,\n",
       "           1.77066379e-01,  1.72023978e-01,  1.58606459e-01,\n",
       "           1.45131547e-01,  1.30943975e-01,  1.13306725e-01,\n",
       "           1.03029504e-01,  9.31230695e-02,  7.95177580e-02,\n",
       "           6.89305542e-02,  5.96235711e-02,  5.02221276e-02,\n",
       "           4.59915871e-02,  4.36256983e-02,  4.23191731e-02],\n",
       "         [ 4.97730114e-01,  5.06857563e-01,  3.13146890e-01,\n",
       "           3.07772049e-01,  3.05359013e-01,  3.03698540e-01,\n",
       "           3.01555092e-01,  2.97987899e-01,  2.90549651e-01,\n",
       "           2.81762567e-01,  2.74663756e-01,  2.69435945e-01,\n",
       "           2.73895208e-01,  2.84899826e-01,  3.14163033e-01,\n",
       "           3.37855373e-01,  3.58977836e-01,  3.84342366e-01,\n",
       "           4.01272545e-01,  4.13330999e-01,  4.24862897e-01,\n",
       "           4.37710141e-01,  4.58002285e-01,  4.72379420e-01,\n",
       "           4.78392094e-01,  4.80110180e-01,  4.80803920e-01]],\n",
       "\n",
       "        [[ 3.98418479e-03, -8.07190908e-03,  1.53371843e-01,\n",
       "           1.54980638e-01,  1.55161267e-01,  1.55619028e-01,\n",
       "           1.56795837e-01,  1.58825004e-01,  1.63753851e-01,\n",
       "           1.68809874e-01,  1.74177686e-01,  1.77861019e-01,\n",
       "           1.76865895e-01,  1.71119327e-01,  1.57214927e-01,\n",
       "           1.44184821e-01,  1.30295963e-01,  1.13309766e-01,\n",
       "           1.01966912e-01,  9.18305547e-02,  7.86507490e-02,\n",
       "           6.81580262e-02,  5.87661067e-02,  4.99893422e-02,\n",
       "           4.54532376e-02,  4.31418369e-02,  4.16759032e-02],\n",
       "         [ 4.99361625e-01,  4.89184842e-01,  3.02102293e-01,\n",
       "           2.99248422e-01,  2.99433157e-01,  2.98457162e-01,\n",
       "           2.96364533e-01,  2.93490318e-01,  2.83998367e-01,\n",
       "           2.76051378e-01,  2.67218793e-01,  2.59335758e-01,\n",
       "           2.61046684e-01,  2.76905103e-01,  3.11251816e-01,\n",
       "           3.35709239e-01,  3.60453784e-01,  3.84810718e-01,\n",
       "           4.00472153e-01,  4.10906807e-01,  4.27141979e-01,\n",
       "           4.44681493e-01,  4.66466248e-01,  4.76625703e-01,\n",
       "           4.81811280e-01,  4.82858833e-01,  4.83720700e-01]],\n",
       "\n",
       "        [[-2.78752102e-03,  7.32804449e-03,  1.55984457e-01,\n",
       "           1.59309184e-01,  1.59916990e-01,  1.61078598e-01,\n",
       "           1.62313099e-01,  1.64221296e-01,  1.68913169e-01,\n",
       "           1.73589567e-01,  1.79013102e-01,  1.83285331e-01,\n",
       "           1.81104607e-01,  1.74967770e-01,  1.60585394e-01,\n",
       "           1.46499745e-01,  1.32001435e-01,  1.14137972e-01,\n",
       "           1.03176299e-01,  9.31337836e-02,  7.91205956e-02,\n",
       "           6.81477485e-02,  5.90047052e-02,  4.95056440e-02,\n",
       "           4.52067429e-02,  4.26944949e-02,  4.11397785e-02],\n",
       "         [ 4.90335728e-01,  4.94481210e-01,  3.04231371e-01,\n",
       "           2.98571250e-01,  2.97556986e-01,  2.96438294e-01,\n",
       "           2.93978748e-01,  2.90821179e-01,  2.82138927e-01,\n",
       "           2.74855428e-01,  2.66066181e-01,  2.61173204e-01,\n",
       "           2.66683804e-01,  2.80554573e-01,  3.11970711e-01,\n",
       "           3.33347831e-01,  3.55670405e-01,  3.84799615e-01,\n",
       "           3.98060118e-01,  4.13750504e-01,  4.29272907e-01,\n",
       "           4.44446575e-01,  4.62761211e-01,  4.78455490e-01,\n",
       "           4.81449554e-01,  4.83800325e-01,  4.84651602e-01]],\n",
       "\n",
       "        [[ 1.33725062e-02,  1.48151591e-03,  1.58603759e-01,\n",
       "           1.59904081e-01,  1.60083935e-01,  1.60721137e-01,\n",
       "           1.61841215e-01,  1.63761179e-01,  1.68345062e-01,\n",
       "           1.73211317e-01,  1.77846871e-01,  1.81115943e-01,\n",
       "           1.79276358e-01,  1.72868730e-01,  1.58675412e-01,\n",
       "           1.44654690e-01,  1.30129251e-01,  1.11896031e-01,\n",
       "           1.00920734e-01,  9.08120114e-02,  7.75667733e-02,\n",
       "           6.78982057e-02,  5.91924345e-02,  5.02941044e-02,\n",
       "           4.58821993e-02,  4.34154184e-02,  4.17817186e-02],\n",
       "         [ 4.87586203e-01,  5.06466517e-01,  3.00941980e-01,\n",
       "           2.97627948e-01,  2.96418319e-01,  2.96213049e-01,\n",
       "           2.93459873e-01,  2.90379442e-01,  2.81797495e-01,\n",
       "           2.72633923e-01,  2.63874461e-01,  2.57923671e-01,\n",
       "           2.62531862e-01,  2.74896556e-01,  3.00579464e-01,\n",
       "           3.26681979e-01,  3.55528450e-01,  3.86961335e-01,\n",
       "           3.99130893e-01,  4.18086477e-01,  4.36026785e-01,\n",
       "           4.48514278e-01,  4.65559451e-01,  4.75538448e-01,\n",
       "           4.80742479e-01,  4.82382075e-01,  4.82891318e-01]]],\n",
       "\n",
       "\n",
       "       [[[-4.65711391e-03,  1.98270974e-03,  9.99867220e-03,\n",
       "           7.79494520e-03, -5.86817556e-05,  5.22828244e-03,\n",
       "           3.34381687e-03, -4.74583355e-03,  1.36045356e-02,\n",
       "           6.44940304e-03,  4.33057021e-03,  2.61177506e-03,\n",
       "           1.09106978e-02,  2.31745962e-01,  2.46204712e-01,\n",
       "           2.52289127e-01,  2.53019435e-01,  2.46256502e-01,\n",
       "           2.36576595e-01,  2.24474554e-01,  2.07080345e-01,\n",
       "           1.92411154e-01,  1.76903231e-01,  1.55693476e-01,\n",
       "           1.39583907e-01,  1.23930222e-01,  1.06462657e-01],\n",
       "         [ 4.86331138e-01,  5.00394921e-01,  5.06180177e-01,\n",
       "           4.81736177e-01,  5.02263982e-01,  5.04496924e-01,\n",
       "           5.15711599e-01,  5.05625041e-01,  5.14340345e-01,\n",
       "           5.01579331e-01,  5.18446205e-01,  5.07315526e-01,\n",
       "           4.91695904e-01,  1.81473497e-01,  1.59274572e-01,\n",
       "           1.52133498e-01,  1.51864739e-01,  1.62271956e-01,\n",
       "           1.74549150e-01,  1.89929765e-01,  2.15367512e-01,\n",
       "           2.39643375e-01,  2.64630862e-01,  3.03203625e-01,\n",
       "           3.36517466e-01,  3.64686875e-01,  3.92669731e-01]],\n",
       "\n",
       "        [[ 2.53460177e-03,  8.57416599e-03, -9.71259640e-03,\n",
       "          -4.32701019e-03, -4.76672420e-04, -1.78117318e-03,\n",
       "           9.50520590e-03,  8.57827388e-03,  9.13239054e-03,\n",
       "           1.47292962e-02,  1.57678691e-03, -7.43535490e-05,\n",
       "           1.79319618e-02,  2.33859108e-01,  2.48350160e-01,\n",
       "           2.53586264e-01,  2.53162870e-01,  2.46823486e-01,\n",
       "           2.38008032e-01,  2.26795001e-01,  2.08765117e-01,\n",
       "           1.93542384e-01,  1.77734733e-01,  1.55737504e-01,\n",
       "           1.38957440e-01,  1.23607141e-01,  1.06267648e-01],\n",
       "         [ 4.81960433e-01,  4.82901681e-01,  5.04630700e-01,\n",
       "           4.99699543e-01,  5.02303864e-01,  5.01457923e-01,\n",
       "           5.11855747e-01,  4.91389876e-01,  4.82258336e-01,\n",
       "           5.09869017e-01,  5.05188449e-01,  4.94784023e-01,\n",
       "           4.93348995e-01,  1.70378422e-01,  1.51481572e-01,\n",
       "           1.47025648e-01,  1.46556918e-01,  1.58345728e-01,\n",
       "           1.73617105e-01,  1.93045096e-01,  2.20899538e-01,\n",
       "           2.44681967e-01,  2.71316810e-01,  3.09854744e-01,\n",
       "           3.38800358e-01,  3.66336026e-01,  3.93465298e-01]],\n",
       "\n",
       "        [[ 2.75622620e-03,  1.31910229e-02, -3.63362926e-04,\n",
       "           4.52457057e-03,  5.34688846e-03,  2.09793911e-03,\n",
       "          -1.43277939e-03,  3.49764149e-03,  5.36623321e-03,\n",
       "           1.42699305e-03,  1.61842463e-03,  2.09388422e-03,\n",
       "           4.85679761e-03,  2.35754690e-01,  2.49390842e-01,\n",
       "           2.54512248e-01,  2.55074610e-01,  2.48187541e-01,\n",
       "           2.38665605e-01,  2.26038609e-01,  2.07143733e-01,\n",
       "           1.92105085e-01,  1.76634639e-01,  1.55224842e-01,\n",
       "           1.38879952e-01,  1.23537135e-01,  1.06782256e-01],\n",
       "         [ 4.98633882e-01,  4.82603193e-01,  4.99700954e-01,\n",
       "           5.21900886e-01,  4.93843116e-01,  5.00280982e-01,\n",
       "           4.89965185e-01,  4.81835518e-01,  4.84036868e-01,\n",
       "           5.03739673e-01,  4.97240109e-01,  5.07035193e-01,\n",
       "           4.92726729e-01,  1.71280105e-01,  1.54982057e-01,\n",
       "           1.48458362e-01,  1.48205841e-01,  1.59450795e-01,\n",
       "           1.73251807e-01,  1.92284972e-01,  2.19104994e-01,\n",
       "           2.40858675e-01,  2.64780069e-01,  3.06507279e-01,\n",
       "           3.36226392e-01,  3.64850723e-01,  3.93285462e-01]],\n",
       "\n",
       "        [[ 9.17569009e-03,  9.43321459e-03, -2.67377352e-04,\n",
       "           3.65707886e-03,  8.78141120e-04,  4.31556792e-03,\n",
       "           7.87202920e-03, -5.72876161e-03,  6.43203581e-03,\n",
       "           1.08102443e-02,  1.66298398e-02,  6.27225829e-04,\n",
       "           2.68621840e-02,  2.32106062e-01,  2.45180697e-01,\n",
       "           2.49392260e-01,  2.49400960e-01,  2.42080331e-01,\n",
       "           2.32530946e-01,  2.21039711e-01,  2.03616152e-01,\n",
       "           1.89738308e-01,  1.74728676e-01,  1.54139520e-01,\n",
       "           1.38124543e-01,  1.23293546e-01,  1.05685213e-01],\n",
       "         [ 5.23427043e-01,  5.03993020e-01,  5.15473178e-01,\n",
       "           5.32543114e-01,  4.94084673e-01,  5.07344074e-01,\n",
       "           4.79640594e-01,  4.97799905e-01,  5.14027104e-01,\n",
       "           4.92913453e-01,  4.99389195e-01,  5.07173223e-01,\n",
       "           5.08420205e-01,  1.80550185e-01,  1.62663134e-01,\n",
       "           1.57461310e-01,  1.58248515e-01,  1.71061870e-01,\n",
       "           1.85215328e-01,  1.99439837e-01,  2.23832020e-01,\n",
       "           2.48726724e-01,  2.73403550e-01,  3.15874205e-01,\n",
       "           3.44053539e-01,  3.66318840e-01,  3.95527719e-01]],\n",
       "\n",
       "        [[-1.22082714e-02, -8.97107606e-03,  2.29124728e-04,\n",
       "           4.17732638e-03,  5.00920389e-03,  4.16827530e-03,\n",
       "          -1.56934699e-03, -6.93271464e-04, -1.85600843e-03,\n",
       "          -5.13066054e-03,  5.85410218e-03,  7.99711780e-03,\n",
       "           1.38482713e-02,  2.27698228e-01,  2.42398804e-01,\n",
       "           2.48399423e-01,  2.49467601e-01,  2.43584380e-01,\n",
       "           2.34177577e-01,  2.22463907e-01,  2.04288697e-01,\n",
       "           1.90264085e-01,  1.74624754e-01,  1.53098330e-01,\n",
       "           1.36941781e-01,  1.21966989e-01,  1.05358924e-01],\n",
       "         [ 4.94912242e-01,  5.07764020e-01,  5.09459667e-01,\n",
       "           4.99399805e-01,  4.98509585e-01,  4.88266521e-01,\n",
       "           4.92115935e-01,  4.99980365e-01,  5.06574428e-01,\n",
       "           4.89686275e-01,  4.99730447e-01,  5.03624127e-01,\n",
       "           4.92108505e-01,  1.85312265e-01,  1.63813898e-01,\n",
       "           1.55402220e-01,  1.56234086e-01,  1.66000844e-01,\n",
       "           1.83777153e-01,  2.01612761e-01,  2.26779012e-01,\n",
       "           2.48518637e-01,  2.76184619e-01,  3.17169497e-01,\n",
       "           3.44630309e-01,  3.68464612e-01,  3.94666308e-01]],\n",
       "\n",
       "        [[ 1.10093843e-03, -4.49001137e-03,  8.03481990e-03,\n",
       "           4.63063655e-03,  4.15073072e-03, -2.67974421e-03,\n",
       "           1.23230224e-02,  3.10711058e-03, -5.09663416e-03,\n",
       "           4.68753438e-03,  8.37989322e-03,  5.77538580e-03,\n",
       "           1.47943888e-02,  2.31847109e-01,  2.46542098e-01,\n",
       "           2.52731935e-01,  2.53114260e-01,  2.45668561e-01,\n",
       "           2.36143857e-01,  2.23719541e-01,  2.04439568e-01,\n",
       "           1.89424113e-01,  1.74146319e-01,  1.52563994e-01,\n",
       "           1.36598993e-01,  1.21733126e-01,  1.05380998e-01],\n",
       "         [ 5.06860401e-01,  5.03480651e-01,  5.15827393e-01,\n",
       "           5.00624996e-01,  4.91099418e-01,  5.00694790e-01,\n",
       "           5.01710584e-01,  5.02157773e-01,  5.14986222e-01,\n",
       "           5.07700325e-01,  4.94682027e-01,  5.03258445e-01,\n",
       "           4.97616793e-01,  1.74799597e-01,  1.55490511e-01,\n",
       "           1.48539139e-01,  1.49771982e-01,  1.60860565e-01,\n",
       "           1.74569598e-01,  1.95851393e-01,  2.25721539e-01,\n",
       "           2.52826390e-01,  2.80318930e-01,  3.19516536e-01,\n",
       "           3.43952272e-01,  3.69057598e-01,  3.95353204e-01]],\n",
       "\n",
       "        [[-2.82337231e-03, -4.87862639e-03,  2.81820662e-04,\n",
       "           4.30273379e-04,  5.62284650e-03,  1.43079470e-02,\n",
       "           7.07793257e-03,  5.27122204e-03,  8.85053837e-03,\n",
       "           1.25420700e-02, -9.70451079e-03,  8.11107061e-03,\n",
       "           2.37043824e-02,  2.35758903e-01,  2.47876969e-01,\n",
       "           2.52850712e-01,  2.52926216e-01,  2.44540520e-01,\n",
       "           2.34423986e-01,  2.22926481e-01,  2.05285471e-01,\n",
       "           1.91124135e-01,  1.75203552e-01,  1.53480566e-01,\n",
       "           1.36735530e-01,  1.22037726e-01,  1.05943228e-01],\n",
       "         [ 5.06919218e-01,  5.00386319e-01,  4.94996959e-01,\n",
       "           4.95089018e-01,  4.95218876e-01,  4.89262278e-01,\n",
       "           5.03046576e-01,  4.89828019e-01,  5.06437568e-01,\n",
       "           4.83708093e-01,  4.89049591e-01,  5.07746847e-01,\n",
       "           5.02901218e-01,  1.73853294e-01,  1.57722299e-01,\n",
       "           1.48128205e-01,  1.47765761e-01,  1.60110134e-01,\n",
       "           1.77121327e-01,  1.95569323e-01,  2.22990377e-01,\n",
       "           2.44834624e-01,  2.72131063e-01,  3.14295174e-01,\n",
       "           3.45787605e-01,  3.68601535e-01,  3.96782606e-01]],\n",
       "\n",
       "        [[ 3.48701078e-04, -3.45507914e-03,  1.43283376e-02,\n",
       "           3.48090519e-03, -4.71936433e-03, -8.69840202e-03,\n",
       "          -4.01793141e-03,  1.31016680e-03,  4.71942139e-03,\n",
       "           3.25388416e-03,  7.31178669e-03,  1.24425171e-02,\n",
       "           2.46205946e-02,  2.34039491e-01,  2.48527153e-01,\n",
       "           2.53668591e-01,  2.53628937e-01,  2.45870258e-01,\n",
       "           2.35858532e-01,  2.24691724e-01,  2.06991340e-01,\n",
       "           1.92341996e-01,  1.76005271e-01,  1.54522720e-01,\n",
       "           1.38460029e-01,  1.23824706e-01,  1.06439125e-01],\n",
       "         [ 5.00585944e-01,  4.91537938e-01,  4.97846030e-01,\n",
       "           4.98435451e-01,  5.06019443e-01,  4.83634673e-01,\n",
       "           4.94826210e-01,  5.02356481e-01,  5.03338499e-01,\n",
       "           4.93950547e-01,  4.90799815e-01,  5.06398142e-01,\n",
       "           4.90297026e-01,  1.76493683e-01,  1.58062510e-01,\n",
       "           1.51470668e-01,  1.51380693e-01,  1.62774033e-01,\n",
       "           1.81035674e-01,  1.99707631e-01,  2.25668385e-01,\n",
       "           2.44376316e-01,  2.70185230e-01,  3.10762539e-01,\n",
       "           3.40122803e-01,  3.65015163e-01,  3.94008137e-01]]]])"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_lds_array = np.array(seed_lds_list)\n",
    "seed_lds_array[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "1c1d75dc-93fa-4af9-a3b7-d8a10e56feb5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1, 2, 8, 2, 27)"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_lds_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "018c6e64-d424-4018-a711-eee95131a802",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "100"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "K"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "fde83272-f2b9-4e41-a9e2-0d7b19810784",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('./gen_5000_0.5_ckpt_{}.pkl'.format(K), 'wb') as handle:\n",
    "    pickle.dump(seed_lds_array, handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fb08a31e-97fe-4d9c-b426-370507cadf5b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c4d858e4-8104-45cc-a9bb-36e64765a662",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "00a7858a-30f7-4cc0-a3a7-d132143254e0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "8b050b5f-b8cf-421b-bb44-956399f61fed",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(1):\n",
    "    for j in range(2):\n",
    "        for k in range(seed_lds_array.shape[2]):\n",
    "            plt.plot(seed_lds_array[i, j, k, 0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4e079f7d-ad04-4caf-9d6d-140b77f4cbe3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9a1e074c-e43e-4e35-8ae5-2ba488e82406",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "ea85a313-addc-42eb-91ad-e671e3e13104",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[[0.17781926, 0.18224587, 0.17941409, 0.18146168, 0.17865716,\n",
       "         0.17786102, 0.18328533, 0.18111594],\n",
       "        [0.25301944, 0.25358626, 0.25507461, 0.24940096, 0.2494676 ,\n",
       "         0.25311426, 0.25292622, 0.25366859]]])"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_lds_array[:, :, :, 0].max(axis=-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fc8c05e8-c12d-4187-832b-7e4af09239c5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "c180a94c-6b0d-48bc-baaa-64ac650c7964",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1, 2, 8)"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_lds = seed_lds_array[:, :, :, 0].max(axis=-1)[:, :]\n",
    "seed_lds.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d5b54efc-5829-41cb-b173-ee03d7aa9db9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "82fd4e87-cd7c-4df7-9e2a-bee0c2ad414d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d8daccc6-b205-4e9e-86cc-8a9c393fbd99",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "70fb08b2-f74f-4492-b47a-b0bbc9b041e0",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('./gen_5000_0.5_scores_{}.pkl'.format(K), 'wb') as handle:\n",
    "    pickle.dump(seed_score_list, handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bc3e10d6-8634-4088-8791-b05a1bd4a2c3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "abb6edb1-a3ee-4e14-86e7-443c46c8078d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "1607c463-df77-4f5c-bc18-866080849dd4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(seed_score_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "fc70e90a-ac36-48b0-82ed-6a3b9aa6a95f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(seed_score_list[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "45b82a31-0e5d-4292-9018-29364865a6ae",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "8"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(seed_score_list[0][0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "13219d07-cb2b-4c6b-a14c-f1f8642ffd3d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1000, 5000)"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_score_list[0][0][0].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "b012a62f-d6b4-4da4-97dd-196dad83b36f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1000, 5000)"
      ]
     },
     "execution_count": 39,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.stack(seed_score_list[0][0]).mean(axis=0).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2e7ddf24-c529-483e-9f4f-893f43015630",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "134a59cf-e751-49b5-a5aa-8d1a0de4450c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.210 (avg p value 0.211566)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -np.stack(seed_score_list[0][0])[0:8].mean(axis=0)\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fafb0087-3122-46ad-94e2-8919881a0817",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "e7105050-c8e3-47e1-a532-c4111d35421e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.281 (avg p value 0.115952)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -np.stack(seed_score_list[0][1])[0:8].mean(axis=0)\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0140df1a-5afa-4de1-b947-16ea11e30cd1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "020bbe8e-abe2-46bd-92de-0931bfbe35e9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8099d9d1-2798-4ca9-9ea7-d718fdb55151",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7a67fa8f-3fb1-4653-bebd-6ed286bf6556",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6ab11441-2f5d-42c5-b3be-b67c34e87d9c",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
