{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "31e0858d-12e5-4eaf-8cc3-f461d2aff756",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "974ba093-b42b-4ee9-a8c0-cd79d161435c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "8c2f5efb-631c-4083-84ae-dc219c6a75a1",
   "metadata": {},
   "outputs": [],
   "source": [
    "# from diffusers.utils import randn_tensor"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fde1d3d3-3ae3-4194-b2e8-596809be9636",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9e3a5e70-ec86-4af6-ad75-bdc4351b4d40",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "723df846-36f4-433c-99cf-044b96c870ec",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cf1854ba-184b-4c9f-9a5c-9158e786e404",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c4cadde9-8859-435a-b6ba-09aa42bb468d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "\n",
    "os.environ[\"CUDA_DEVICE_ORDER\"]=\"PCI_BUS_ID\"   \n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"]='0'\n",
    "\n",
    "os.environ[\"HF_HOME\"]=\"~/codes/.cache/huggingface\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "2f7cd96b-ca27-4ce1-ac2d-c3dd67e069b7",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import random\n",
    "import numpy as np\n",
    "\n",
    "def set_seeds(seed):\n",
    "    random.seed(seed)\n",
    "    np.random.seed(seed)\n",
    "    torch.manual_seed(seed)\n",
    "    torch.backends.cudnn.deterministic = True\n",
    "    torch.backends.cudnn.benchmark = False\n",
    "    \n",
    "set_seeds(42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "4ff495b8-8df0-49e8-a409-4ed9601c8143",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "def show_images(images, scores, test_artist, train_artists):\n",
    "    n: int = len(images)\n",
    "    f = plt.figure(figsize=(16, 2))\n",
    "    for i in range(n):\n",
    "        # Debug, plot figure\n",
    "        ax = f.add_subplot(1, n, i + 1)\n",
    "        if i==0:\n",
    "            pass\n",
    "            ax.title.set_text(test_artist)\n",
    "        else:\n",
    "            ax.title.set_text(str(np.round(scores[i-1], 4))+'\\n'+train_artists[i-1])\n",
    "            ax.axis('off')\n",
    "        if images[i]==None:\n",
    "            pass\n",
    "        else:\n",
    "            plt.imshow(images[i])\n",
    "\n",
    "    plt.show(block=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "c4e89a09-d6ff-46a1-8a9e-9c6f9c167114",
   "metadata": {},
   "outputs": [],
   "source": [
    "from datasets import load_dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2682e2c4-9275-4bae-a732-74b981a358d2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "fb2dc562-293c-4e74-8e97-141fc7465938",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "bda41875-8976-4852-823a-91dc1f42aebf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5000"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open('../../data/indices/5000-0.5/idx-train.pkl', 'rb')  as handle:\n",
    "    idx_train = pickle.load(handle)\n",
    "len(idx_train)   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "5ffbb813-1636-44e3-b943-400824fde5e7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1000"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open('../../data/indices/5000-0.5/idx-val.pkl', 'rb')  as handle:\n",
    "    idx_val = pickle.load(handle)\n",
    "len(idx_val)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "773b1a12-d60d-4ed8-8f61-b03a3af61e71",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "40c86797-31d5-45d0-b46f-52f8c84dd130",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'load_dataset' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[1], line 3\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;66;03m# from datasets import load_dataset\u001b[39;00m\n\u001b[0;32m----> 3\u001b[0m dataset \u001b[38;5;241m=\u001b[39m \u001b[43mload_dataset\u001b[49m(\n\u001b[1;32m      4\u001b[0m     \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mcifar10\u001b[39m\u001b[38;5;124m'\u001b[39m,\n\u001b[1;32m      5\u001b[0m     \u001b[38;5;66;03m# args.dataset_config_name,\u001b[39;00m\n\u001b[1;32m      6\u001b[0m     \u001b[38;5;66;03m# cache_dir=args.cache_dir,\u001b[39;00m\n\u001b[1;32m      7\u001b[0m     \u001b[38;5;66;03m# split=\"train\",\u001b[39;00m\n\u001b[1;32m      8\u001b[0m )\n",
      "\u001b[0;31mNameError\u001b[0m: name 'load_dataset' is not defined"
     ]
    }
   ],
   "source": [
    "from datasets import load_dataset\n",
    "\n",
    "dataset = load_dataset(\n",
    "    'cifar10',\n",
    "    # args.dataset_config_name,\n",
    "    # cache_dir=args.cache_dir,\n",
    "    # split=\"train\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c6632d56-9134-4720-99a9-1853fe349039",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5df420e1-7166-4e5b-baa3-a012fe7e32e1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "f2ce6b6b-ff45-4156-9606-7c87046e751a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<PIL.PngImagePlugin.PngImageFile image mode=RGB size=32x32>"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from datasets import DatasetDict, Dataset, load_dataset, Image\n",
    "\n",
    "train_dataset = dataset['train'].select(idx_train)\n",
    "train_dataset[0][\"img\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "a17ef712-5e24-4c38-bd27-fbf34ece6446",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<PIL.PngImagePlugin.PngImageFile image mode=RGB size=32x32>"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "val_dataset =  dataset['test'].select(idx_val)\n",
    "val_dataset[0][\"img\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "e16837b7-8ddd-46ab-9d0a-c988f2ca9514",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[7405, 5226, 1363, 6615, 7612]"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "idx_val[0:5]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8c2e0980-d551-48f4-8b1f-3f9d4ac788cb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "317f972c-b763-40d3-8186-759118c12237",
   "metadata": {},
   "outputs": [],
   "source": [
    "class Args():\n",
    "            \n",
    "    dataset_name=\"cifar10\"\n",
    "\n",
    "    output_dir=\"../../saved/5000-0.5/retrain\"\n",
    "    \n",
    "    project_dim=65536\n",
    "\n",
    "    used_dim=32768\n",
    "\n",
    "    strategy='uniform'\n",
    "    # strategy='cumulative'\n",
    "   \n",
    "args = Args()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "bb9d8f5f-5370-4157-be84-f77949771866",
   "metadata": {},
   "outputs": [],
   "source": [
    "import diffusers\n",
    "from diffusers import DDPMPipeline, DDPMScheduler, UNet2DModel\n",
    "from diffusers.optimization import get_scheduler"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "32c7cc29-8267-4fc3-915f-2628006b3af9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5396c1cc-03c9-407d-b4ba-d16f4b56bc25",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "c37c6ab7-8c07-416a-b7b1-4b2c03a82cfa",
   "metadata": {},
   "outputs": [],
   "source": [
    "# load ground truth\n",
    "my_list = [\n",
    "    0,1,2,3,\n",
    "    4,5,6,7,\n",
    "    8,9,10,11,\n",
    "    12,13,14,15,\n",
    "    16,17,18,19,\n",
    "    20,21,22,23,\n",
    "    24,25,26,27,\n",
    "    28,29,30,31,\n",
    "    32,33,34,35,\n",
    "    36,37,38,39,\n",
    "    40,41,42,43,\n",
    "    44,45,46,47,\n",
    "    48,49,50,51,\n",
    "    52,53,54,55,\n",
    "    56,57,58,59,\n",
    "    60,61,62,63,\n",
    "          ]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "7e5b270b-c5df-4b5d-a8fd-2a924a6edad6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000, 1000)"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "loss_array_list = []\n",
    "\n",
    "for i in my_list:\n",
    "    for seed in [\n",
    "        0,\n",
    "                 1,\n",
    "                 2,\n",
    "                 # 3,\n",
    "                 # 4,\n",
    "                ]:\n",
    "        for e_seed in [\n",
    "            0, \n",
    "                       1, \n",
    "                       2\n",
    "                      ]:\n",
    "            with open('../../saved/5000-0.5/lds-val/ddpm-sub-{}-{}/e-{}-val.pkl'.format(i, seed, e_seed), 'rb')  as handle:\n",
    "                loss_list = pickle.load(handle)\n",
    "            margins = np.concatenate(loss_list, axis=-1) # -logp\n",
    "            ####\n",
    "            if (seed==0) and (e_seed)==0:\n",
    "                loss_array = margins\n",
    "            else:\n",
    "                loss_array += margins\n",
    "            \n",
    "    loss_array = loss_array/(3*3)\n",
    "    \n",
    "    loss_array_list.append(loss_array)\n",
    "lds_loss_array = np.stack(loss_array_list)\n",
    "lds_loss_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "d823ef7b-9d53-4f31-ab11-864274554493",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiMAAAGdCAYAAADAAnMpAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABW3klEQVR4nO3deZxVdeH/8dc5d519YZgZGIZFRRFQQBDELSuS0my1r5mlUVmZfr8WfSvJ1DZFW8wWizT91u+rpl/L1NQwxS0TRUFEQFkFhmU2Zrmz3LnLOZ/fH+fOHa6AMjgzV7jv5+MxD+4953PO+ZwTMW8/57NYxhiDiIiISJbY2a6AiIiI5DaFEREREckqhRERERHJKoURERERySqFEREREckqhRERERHJKoURERERySqFEREREckqf7YrcCBc12Xnzp0UFRVhWVa2qyMiIiIHwBhDR0cHI0eOxLb33/5xSISRnTt3Ultbm+1qiIiIyEGoq6tj1KhR+91/SISRoqIiwLuZ4uLiLNdGREREDkQkEqG2tjb9e3x/Dokw0vtqpri4WGFERETkEPN2XSzUgVVERESySmFEREREskphRERERLJKYURERESySmFEREREskphRERERLJKYURERESySmFEREREskphRERERLJKYURERESySmFEREREskphRERERLLqkFgob7Asf/gB2hvrOf79c6kYPTbb1REREclJOd0ysm7pM7y8+O+0NdRnuyoiIiI5K6fDiGX7ADCum+WaiIiI5K6cDiO27d2+qzAiIiKSNTkdRqxUGDGuk+WaiIiI5C6FEfSaRkREJJtyO4xYFqDXNCIiItmU02Gkt8+IMSbLNREREcldOR1G9JpGREQk+3I8jGhor4iISLbldBjR0F4REZHsy+kwoqG9IiIi2ZfbYaTTmwbedO7Ock1ERERyV06HEbt5HQBuZGeWayIiIpK7cjqM9M4zYhy9phEREcmW3A4jdu+kZwojIiIi2ZLbYaS3ZURhREREJGsOKozcfPPNjB07lnA4zKxZs1i2bNlblr/ppps45phjyMvLo7a2lm984xv09PQcVIUHUqphBONqBlYREZFs6XcYueeee5g/fz7XXHMNK1asYMqUKcydO5fGxsZ9lr/rrru44ooruOaaa3jttde47bbbuOeee/jud7/7jiv/Tmlor4iISPb1O4zceOON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Hdu2bUs/49mzZ/Pqq69m/OV/7LHHKC4u3uuXQq56//vfz6uvvsrKlSvTPzNmzOCCCy5If9ZzHhinnHLKXsPT169fz5gxYwAYN24c1dXVGc86EonwwgsvZDzrtrY2li9fni7zxBNP4Lous2bNGoK7ePfr7u7GtjN/9fh8PlzXBfScB8tAPdfZs2fzzDPPkEgk0mUee+wxjjnmmIN+RQPk9tDeUChk/vjHP5q1a9eaL3/5y6a0tDRjxIHs3yWXXGJKSkrMU089ZXbt2pX+6e7uTpf56le/akaPHm2eeOIJ89JLL5nZs2eb2bNnp/f3Djk988wzzcqVK83ixYvN8OHDNeT0bew5msYYPeeBsmzZMuP3+821115rNmzYYO68806Tn59v7rjjjnSZ66+/3pSWlpoHHnjArFq1ynz0ox/d59DIadOmmRdeeME8++yzZvz48Tk/5HRPF110kampqUkP7b3vvvtMRUWF+fa3v50uo+d8cDo6OszLL79sXn75ZQOYG2+80bz88stm69atxpiBea5tbW2mqqrKfO5znzOrV682d999t8nPz9fQ3nfi17/+tRk9erQJBoNm5syZ5vnnn892lQ4ZwD5//ud//iddJhqNmq997WumrKzM5Ofnm49//ONm165dGefZsmWL+dCHPmTy8vJMRUWF+eY3v2kSicQQ382h5c1hRM954Pz97383kydPNqFQyEyYMMHccsstGftd1zVXXXWVqaqqMqFQyLz//e8369atyyize/duc/7555vCwkJTXFxs5s2bZzo6OobyNt7VIpGIufzyy83o0aNNOBw2RxxxhLnyyiszhorqOR+cJ598cp//Ll900UXGmIF7rq+88oo59dRTTSgUMjU1Neb6669/x3W3jNlj2jsRERGRIZaTfUZERETk3UNhRERERLJKYURERESySmFEREREskphRERERLJKYURERESySmFEREREskphRERERLJKYURERESySmFEREREskphRERERLJKYURERESy6v8Duli93/0DsWIAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(1):\n",
    "    for j in range(8):\n",
    "        plt.plot(lds_loss_array[i, :, j], color=\"C{}\".format(j))\n",
    "    # break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "874a332c-29b1-46fe-bf83-12e7c8f64e28",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 5000)"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mask_array_list = []\n",
    "\n",
    "for i in my_list:\n",
    "    # print(i)\n",
    "    with open('../../data/indices/5000-0.5/lds-val/sub-idx-{}.pkl'.format(i), 'rb')  as handle:\n",
    "        sub_idx_train = pickle.load(handle)\n",
    "    # print(len(sub_idx_train))\n",
    "    mask_array = np.in1d(idx_train, sub_idx_train)\n",
    "        \n",
    "    mask_array_list.append(mask_array)\n",
    "    \n",
    "lds_mask_array = np.stack(mask_array_list)\n",
    "lds_mask_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "41ebfcfb-5789-44f0-99d0-0dddc7c6f32f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000)"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "lds_testset_correctness = lds_loss_array.mean(axis=1)\n",
    "lds_testset_correctness.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "46afee77-65eb-4023-8077-d11ed785d406",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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r77KyZMnbY8JEybYxhkMBoYMGULz5s1JSkpixowZTJs2jblz59Z3EYUQQghxA6r3HZljY2Pp2bMns2bNAsBqtRIREcGECROYNGnSBeVHjx5NaWkpy5Ytsw3r3bs3MTExzJkzp9p5bN++nV69enH06FGaNWsGqC09zz77LM8++2y17/n444/517/+RU5ODnq9erOtSZMm8dNPP7F///46LZvckVkIIYS4/tR1/12vlp7KykqSkpKIj48/NwGtlvj4eDZv3lztezZv3mxXHiAhIaHG8gBFRUVoNBp8fX3thr/xxhv4+/vTtWtXZsyYgdlstpvPzTffbAs8VfNJT0+nsLCw2vkYjUYMBoPdQwghhBA3pnrdkbmgoACLxUJwcLDd8ODg4BpbU3Jycqotn5OTU235iooKXnzxRcaMGWOX1p5++mm6detGkyZN2LRpE5MnT+bkyZO88847tvm0aNHigvlUjfPz87tgXtOnT+eVV165yFILIYQQ4kZwTf0Mhclk4t5770VRFD7++GO7cRMnTrS97tKlC3q9nscee4zp06fj4uLSoPlNnjzZbroGg4GIiIiGVV4IIYQQ17R6hZ6AgACcnJzIzc21G56bm0tISEi17wkJCalT+arAc/ToUdauXXvRPjWxsbGYzWYyMzNp165djfOpqkN1XFxcGhyYhBBCCHF9qVefHr1eT/fu3VmzZo1tmNVqZc2aNcTFxVX7nri4OLvyAImJiXblqwLPwYMHWb16Nf7+/hetS2pqKlqtlqCgINt8NmzYgMlksptPu3btqj21JYQQQgjHUu/TWxMnTmTs2LH06NGDXr168d5771FaWsrDDz8MwEMPPUR4eDjTp08H4JlnnqF///7MnDmTYcOGsWDBAnbs2GG7lNxkMjFq1CiSk5NZtmwZFovF1t+nSZMm6PV6Nm/ezNatWxk4cCBeXl5s3ryZf/zjHzzwwAO2QHPffffxyiuvMG7cOF588UXS0tJ4//33effdd+u8bFUXskmHZiGEEOL6UbXfvugF6UoDfPjhh0qzZs0UvV6v9OrVS9myZYttXP/+/ZWxY8falV+0aJHStm1bRa/XKx07dlSWL19uG3fkyBEFqPaxbt06RVEUJSkpSYmNjVV8fHwUV1dXpX379srrr7+uVFRU2M1n586dSt++fRUXFxclPDxceeONN+q1XMePH6+xLvKQ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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for j in range(4):\n",
    "    plt.plot(lds_testset_correctness[:, j], color=\"C{}\".format(j))\n",
    "    # break\n",
    "# plt.ylim(0.15, 0.2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8d92c4b4-5b21-434f-b6cc-96e968cbe495",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "8fa5fded-088f-45ea-9b39-f7e8657a2a77",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "27\n"
     ]
    }
   ],
   "source": [
    "from scipy.stats import spearmanr, pearsonr\n",
    "f_name_list = [\n",
    "    'loss', \n",
    "    ####\n",
    "    # 'mean',\n",
    "    'mean-squared-l2-norm', \n",
    "    ####\n",
    "    # 'l1_norm',\n",
    "    # 'l2_norm',\n",
    "    # 'linf_norm'\n",
    "    ####\n",
    "]\n",
    "\n",
    "lamb_list = [\n",
    "\n",
    "        1e-2, 2e-2, 5e-2,\n",
    "        1e-1, 2e-1, 5e-1,\n",
    "        1e0, 2e0, 5e0,\n",
    "        1e1, 2e1, 5e1,\n",
    "        1e2, 2e2, 5e2,\n",
    "        1e3, 2e3, 5e3, \n",
    "        1e4, 2e4, 5e4, \n",
    "        1e5, 2e5, 5e5, \n",
    "        1e6, 2e6, 5e6, \n",
    "    ]\n",
    "\n",
    "print(len(lamb_list))\n",
    "\n",
    "\n",
    "ckpt_list = [\n",
    "    0, 1, \n",
    "    2, 3, 4, 5, 6, 7,\n",
    "            ]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "45989db6-7d72-4cd8-923a-bbc516a41805",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1\n",
      "loss\n",
      "0\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(28.9364, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.010 (avg p value 0.508424)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(28.7215, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.010 (avg p value 0.506979)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(20.9553, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.060 (avg p value 0.472684)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.7562, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.097 (avg p value 0.402503)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2710, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.097 (avg p value 0.404703)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.6977, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.097 (avg p value 0.406824)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8483, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.096 (avg p value 0.406811)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4244, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.097 (avg p value 0.406500)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1701, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.097 (avg p value 0.405832)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0853, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.098 (avg p value 0.404251)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0429, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.100 (avg p value 0.401971)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0174, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.103 (avg p value 0.399556)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0089, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.108 (avg p value 0.394405)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.114 (avg p value 0.390971)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.121 (avg p value 0.380811)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.126 (avg p value 0.374845)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.128 (avg p value 0.371515)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.130 (avg p value 0.368955)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8877e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.130 (avg p value 0.366724)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9660e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.129 (avg p value 0.370557)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9932e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.122 (avg p value 0.382132)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9802e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.115 (avg p value 0.394337)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9943e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.104 (avg p value 0.411094)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.088 (avg p value 0.429653)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9969e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.078 (avg p value 0.441159)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9991e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.071 (avg p value 0.450582)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.065 (avg p value 0.457157)\n",
      "1\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(31.2960, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.487912)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(42.3364, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.000 (avg p value 0.496888)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(20.4210, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.069 (avg p value 0.451389)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.7528, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.096 (avg p value 0.424314)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2706, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.095 (avg p value 0.423847)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.6977, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.095 (avg p value 0.425924)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8483, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.095 (avg p value 0.425151)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4244, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.096 (avg p value 0.424906)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1701, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.096 (avg p value 0.424162)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0853, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.097 (avg p value 0.422834)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0429, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.099 (avg p value 0.419399)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0174, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.103 (avg p value 0.410079)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0089, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.109 (avg p value 0.399993)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.114 (avg p value 0.387645)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.122 (avg p value 0.379138)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.126 (avg p value 0.375032)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.128 (avg p value 0.373681)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.129 (avg p value 0.367574)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8871e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.128 (avg p value 0.368195)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9657e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.125 (avg p value 0.369455)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9931e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.119 (avg p value 0.378209)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9800e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.111 (avg p value 0.389984)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9943e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.102 (avg p value 0.407437)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.086 (avg p value 0.436507)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9969e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.077 (avg p value 0.450459)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9991e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.070 (avg p value 0.457541)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.064 (avg p value 0.461382)\n",
      "2\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(28.4250, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.487621)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(33.0335, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.000 (avg p value 0.499561)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(20.9993, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.037 (avg p value 0.486626)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.7752, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.098 (avg p value 0.404526)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2730, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.098 (avg p value 0.403129)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.6978, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.098 (avg p value 0.403642)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8484, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.098 (avg p value 0.403175)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4244, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.098 (avg p value 0.403568)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1701, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.098 (avg p value 0.403051)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0853, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.099 (avg p value 0.403028)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0429, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.100 (avg p value 0.401783)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0174, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.104 (avg p value 0.400379)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0089, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.108 (avg p value 0.398381)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.113 (avg p value 0.391888)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.120 (avg p value 0.382001)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.123 (avg p value 0.374045)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.126 (avg p value 0.368216)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.128 (avg p value 0.363898)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8881e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.127 (avg p value 0.367369)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9661e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.125 (avg p value 0.370268)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9932e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.119 (avg p value 0.377962)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9803e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.113 (avg p value 0.387771)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9943e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.104 (avg p value 0.402583)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.089 (avg p value 0.426445)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9969e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.079 (avg p value 0.438838)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9991e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.071 (avg p value 0.448754)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.066 (avg p value 0.454463)\n",
      "3\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(30.2309, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.493156)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(24.3328, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.514298)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(25.6897, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.491728)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.7633, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.098 (avg p value 0.410088)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2718, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.099 (avg p value 0.408625)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.6978, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.100 (avg p value 0.407756)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8484, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.100 (avg p value 0.407945)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4244, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.100 (avg p value 0.406956)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1701, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.100 (avg p value 0.406256)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0853, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.101 (avg p value 0.405145)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0429, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.103 (avg p value 0.401531)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0174, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.107 (avg p value 0.392907)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0089, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.112 (avg p value 0.385883)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.117 (avg p value 0.378916)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.123 (avg p value 0.372316)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.126 (avg p value 0.367421)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.128 (avg p value 0.365934)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.128 (avg p value 0.363008)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8886e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.128 (avg p value 0.363449)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9662e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.126 (avg p value 0.365258)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9932e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.121 (avg p value 0.372880)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9803e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.114 (avg p value 0.384143)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9943e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.105 (avg p value 0.399054)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.091 (avg p value 0.425094)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9969e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.080 (avg p value 0.439961)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9991e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.073 (avg p value 0.447674)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.068 (avg p value 0.454982)\n",
      "4\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(28.7528, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.509408)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(56.6365, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.000 (avg p value 0.497846)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(20.7909, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.069 (avg p value 0.443115)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.7599, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.095 (avg p value 0.427125)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2714, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.094 (avg p value 0.426748)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.6977, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.094 (avg p value 0.427585)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8484, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.094 (avg p value 0.427160)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4244, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.094 (avg p value 0.427129)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1701, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.095 (avg p value 0.426733)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0853, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.096 (avg p value 0.425183)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0429, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.097 (avg p value 0.422964)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0174, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.101 (avg p value 0.416394)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0089, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.105 (avg p value 0.409618)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.110 (avg p value 0.401945)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.118 (avg p value 0.390532)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.123 (avg p value 0.380484)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.126 (avg p value 0.369324)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.128 (avg p value 0.362908)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8882e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.128 (avg p value 0.361594)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9661e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.126 (avg p value 0.364010)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9932e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.121 (avg p value 0.379621)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9803e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.113 (avg p value 0.392242)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9943e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.104 (avg p value 0.410006)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.089 (avg p value 0.427885)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9969e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.079 (avg p value 0.440638)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9991e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.072 (avg p value 0.449965)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.066 (avg p value 0.457612)\n",
      "5\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(28.8217, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.512365)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(45.4210, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.494222)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(20.5871, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.070 (avg p value 0.447125)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.7512, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.096 (avg p value 0.416224)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2704, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.097 (avg p value 0.415398)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.6977, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.096 (avg p value 0.416149)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8484, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.097 (avg p value 0.415307)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4244, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.097 (avg p value 0.414703)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1701, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.098 (avg p value 0.414744)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0853, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.099 (avg p value 0.413320)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0429, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.100 (avg p value 0.411456)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0174, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.104 (avg p value 0.405902)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0089, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.109 (avg p value 0.398881)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.114 (avg p value 0.390771)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.121 (avg p value 0.377195)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.125 (avg p value 0.373850)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.127 (avg p value 0.374610)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.128 (avg p value 0.375949)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8892e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.126 (avg p value 0.373997)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9664e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.125 (avg p value 0.374537)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9933e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.120 (avg p value 0.381702)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9805e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.112 (avg p value 0.395047)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9944e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.102 (avg p value 0.413362)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.088 (avg p value 0.436863)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9969e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.078 (avg p value 0.446767)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9991e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.071 (avg p value 0.454037)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.066 (avg p value 0.462016)\n",
      "6\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(30.8320, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.494893)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(34.7769, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.518711)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(19.4885, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.019 (avg p value 0.496736)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.7489, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.096 (avg p value 0.414558)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2701, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.096 (avg p value 0.417362)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.6977, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.097 (avg p value 0.415170)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8484, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.097 (avg p value 0.415876)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4244, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.097 (avg p value 0.415926)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1701, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.098 (avg p value 0.414384)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0853, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.099 (avg p value 0.412530)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0429, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.100 (avg p value 0.411886)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0174, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.104 (avg p value 0.406790)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0089, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.108 (avg p value 0.398803)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.113 (avg p value 0.390830)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.119 (avg p value 0.383818)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.124 (avg p value 0.375270)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.127 (avg p value 0.367125)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.128 (avg p value 0.364377)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8882e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.128 (avg p value 0.364407)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9661e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.126 (avg p value 0.366928)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9932e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.121 (avg p value 0.376125)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9803e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.112 (avg p value 0.391368)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9943e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.103 (avg p value 0.407894)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.088 (avg p value 0.432400)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9969e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.078 (avg p value 0.449070)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9991e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.071 (avg p value 0.457509)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.065 (avg p value 0.464840)\n",
      "7\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(28.0931, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.010 (avg p value 0.520736)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(32.8406, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.497848)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(44.4298, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.491723)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.7665, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.099 (avg p value 0.403725)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2720, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.100 (avg p value 0.404420)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.6978, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.100 (avg p value 0.404970)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8483, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.100 (avg p value 0.405124)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4244, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.100 (avg p value 0.404555)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1701, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.101 (avg p value 0.403201)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0853, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.102 (avg p value 0.400561)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0429, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.103 (avg p value 0.397945)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0174, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.107 (avg p value 0.391813)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0089, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.112 (avg p value 0.383452)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.116 (avg p value 0.374946)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.122 (avg p value 0.367308)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.127 (avg p value 0.361353)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.129 (avg p value 0.354667)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.131 (avg p value 0.350418)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8860e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.131 (avg p value 0.350295)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9654e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.129 (avg p value 0.355130)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9931e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.122 (avg p value 0.371983)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9799e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.116 (avg p value 0.388386)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9942e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.105 (avg p value 0.402559)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9989e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.090 (avg p value 0.423074)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9968e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.080 (avg p value 0.440138)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9991e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.073 (avg p value 0.451901)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.067 (avg p value 0.458832)\n",
      "mean-squared-l2-norm\n",
      "0\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0088, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.499649)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(-0.0035, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.497776)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0034, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.503317)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0278, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.503251)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0519, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.509764)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0549, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.508908)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0682, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.488208)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0621, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.014 (avg p value 0.501129)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0493, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.496298)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0358, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.499332)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0265, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.004 (avg p value 0.493934)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0162, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.505770)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0096, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.024 (avg p value 0.472707)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.214 (avg p value 0.220894)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.229 (avg p value 0.198030)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.242 (avg p value 0.180498)\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.168453)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.261 (avg p value 0.160185)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.7129e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.261 (avg p value 0.163669)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9049e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.257 (avg p value 0.170940)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9786e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.248 (avg p value 0.180628)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9317e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.240 (avg p value 0.189705)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9785e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.232 (avg p value 0.202227)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9954e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.219 (avg p value 0.219615)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9855e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.206 (avg p value 0.239888)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9955e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.191 (avg p value 0.261076)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9990e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.170 (avg p value 0.295153)\n",
      "1\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0055, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.497099)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(-0.0296, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.004 (avg p value 0.487936)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0168, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.495646)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0330, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.011 (avg p value 0.493568)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0512, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.492482)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0740, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.501726)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0773, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.004 (avg p value 0.506212)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0602, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.490658)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0461, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.495744)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0366, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.000 (avg p value 0.500208)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0261, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.012 (avg p value 0.502841)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0158, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.486437)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0096, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.013 (avg p value 0.498278)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.223 (avg p value 0.203308)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.238 (avg p value 0.180765)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.250 (avg p value 0.166512)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.260 (avg p value 0.157819)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.266 (avg p value 0.155440)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.7111e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.265 (avg p value 0.156380)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9042e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.260 (avg p value 0.162057)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9784e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.250 (avg p value 0.174439)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9309e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.242 (avg p value 0.185272)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9782e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.233 (avg p value 0.196765)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9953e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.219 (avg p value 0.220726)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9852e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.206 (avg p value 0.239445)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9954e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.191 (avg p value 0.260468)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9990e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.171 (avg p value 0.292703)\n",
      "2\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0021, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.515210)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0074, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.491428)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0157, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.505731)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0539, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.010 (avg p value 0.485370)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0506, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.496009)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0956, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.492257)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0730, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.000 (avg p value 0.487509)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0699, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.509106)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0487, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.006 (avg p value 0.503286)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0362, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.515760)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0261, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.494594)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0157, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.483043)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0097, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.016 (avg p value 0.481521)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.214 (avg p value 0.219749)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.232 (avg p value 0.194588)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.245 (avg p value 0.178328)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.256 (avg p value 0.166383)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.264 (avg p value 0.157741)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.7224e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.264 (avg p value 0.161381)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9080e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.260 (avg p value 0.166715)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9792e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.251 (avg p value 0.173969)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9336e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.243 (avg p value 0.183900)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9790e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.234 (avg p value 0.197400)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9955e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.219 (avg p value 0.217749)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9858e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.205 (avg p value 0.236979)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9956e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.190 (avg p value 0.262018)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9990e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.170 (avg p value 0.295651)\n",
      "3\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.502746)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(-0.0066, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.481001)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0092, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.010 (avg p value 0.503854)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0389, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.486617)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0573, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.010 (avg p value 0.506812)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0761, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.505726)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0706, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.012 (avg p value 0.494411)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0643, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.000 (avg p value 0.501487)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0473, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.495259)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0366, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.494334)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0262, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.499982)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0161, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.018 (avg p value 0.493147)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0086, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.011 (avg p value 0.495870)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.221 (avg p value 0.204749)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.237 (avg p value 0.184245)\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.171649)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.259 (avg p value 0.161388)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.264 (avg p value 0.158085)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.7221e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.263 (avg p value 0.160777)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9080e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.258 (avg p value 0.171239)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9793e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.247 (avg p value 0.188620)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9338e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.238 (avg p value 0.198447)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9791e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.229 (avg p value 0.208376)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9955e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.216 (avg p value 0.229696)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9859e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.203 (avg p value 0.250336)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9956e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.188 (avg p value 0.273049)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9990e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.168 (avg p value 0.303087)\n",
      "4\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0037, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.483955)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0125, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.510454)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0264, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.503624)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0352, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.497076)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0535, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.000 (avg p value 0.504941)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0708, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.513682)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0732, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.506956)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0608, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.503474)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0464, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.497363)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0362, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.499602)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0264, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.491230)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0141, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.502117)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0095, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.020 (avg p value 0.495456)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.219 (avg p value 0.208964)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.234 (avg p value 0.191134)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.247 (avg p value 0.176515)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.257 (avg p value 0.164769)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.264 (avg p value 0.159985)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.7177e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.264 (avg p value 0.161877)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9065e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.259 (avg p value 0.168456)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9789e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.248 (avg p value 0.182199)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9326e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.239 (avg p value 0.194330)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9787e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.230 (avg p value 0.206082)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9954e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.215 (avg p value 0.230252)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9856e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.203 (avg p value 0.248511)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9955e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.189 (avg p value 0.268231)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9990e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.169 (avg p value 0.297884)\n",
      "5\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0090, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.513013)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0222, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.502733)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0141, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.514326)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0327, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.504307)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0588, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.012 (avg p value 0.518021)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0243, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.498166)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(-0.0037, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.496848)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0633, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.497170)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0472, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.489035)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0357, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.509662)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0260, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.502629)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0157, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.007 (avg p value 0.484764)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0094, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.019 (avg p value 0.500215)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.216 (avg p value 0.212680)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.232 (avg p value 0.187230)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.244 (avg p value 0.171360)\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.159575)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.262 (avg p value 0.159041)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.7177e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.263 (avg p value 0.161394)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9064e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.260 (avg p value 0.170805)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9789e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.251 (avg p value 0.182359)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9325e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.243 (avg p value 0.191529)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9787e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.233 (avg p value 0.205349)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9954e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.219 (avg p value 0.225908)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9856e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.206 (avg p value 0.245067)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9955e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.191 (avg p value 0.263202)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9990e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.171 (avg p value 0.293070)\n",
      "6\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0156, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.495899)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0128, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.504106)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0177, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.489804)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0260, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.506413)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0580, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.012 (avg p value 0.491466)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0733, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.500341)\n",
      "1.0\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.500663)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0630, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.511570)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0482, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.002 (avg p value 0.492679)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0342, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.497695)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0262, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.483742)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0160, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.487485)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0099, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.012 (avg p value 0.524928)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.222 (avg p value 0.200439)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.236 (avg p value 0.180441)\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.169082)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.257 (avg p value 0.162920)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.263 (avg p value 0.160134)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.7235e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.262 (avg p value 0.167149)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9085e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.256 (avg p value 0.176545)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9793e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.246 (avg p value 0.189741)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9340e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.237 (avg p value 0.199652)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9792e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.229 (avg p value 0.211645)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9955e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.215 (avg p value 0.231687)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9859e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.201 (avg p value 0.249770)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9956e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.187 (avg p value 0.270665)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9990e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.167 (avg p value 0.303079)\n",
      "7\n",
      "(5000, 32768)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0046, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.498524)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0097, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.511948)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0301, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.004 (avg p value 0.508424)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0348, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.511234)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0035, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.492825)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0743, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.006 (avg p value 0.499182)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0801, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.494908)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0752, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.001 (avg p value 0.494907)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0484, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.483307)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0284, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.486179)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0265, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.000 (avg p value 0.500080)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0159, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.506505)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0094, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.011 (avg p value 0.476791)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.219 (avg p value 0.208611)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.234 (avg p value 0.185467)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.246 (avg p value 0.170102)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.256 (avg p value 0.159554)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.263 (avg p value 0.159939)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.7227e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.262 (avg p value 0.161281)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9082e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.258 (avg p value 0.168288)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9793e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.249 (avg p value 0.179823)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9340e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.242 (avg p value 0.190418)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9792e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.233 (avg p value 0.204017)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9955e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.217 (avg p value 0.227540)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9859e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.204 (avg p value 0.246300)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9956e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.190 (avg p value 0.267023)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9990e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.170 (avg p value 0.296096)\n"
     ]
    }
   ],
   "source": [
    "# for loop over functions\n",
    "seed_lds_list = []\n",
    "\n",
    "seed_score_list = []\n",
    "\n",
    "for num_seed in [\n",
    "    1, \n",
    "    # 2, 3, 4, 5\n",
    "]:\n",
    "    print(num_seed)\n",
    "    f_lds_list = []\n",
    "\n",
    "    f_score_list = []\n",
    "    \n",
    "    for f in f_name_list:\n",
    "        ####\n",
    "        print(f)\n",
    "        \n",
    "        lds_list = []\n",
    "        \n",
    "        score_list = []\n",
    "        \n",
    "        K = 10\n",
    "        for ckpt in ckpt_list:\n",
    "            print(ckpt)\n",
    "            ####\n",
    "            dstore_keys_list = []\n",
    "            for split in range(5):\n",
    "                tmp = None\n",
    "                for e_seed in range(num_seed):\n",
    "                    dstore_keys = np.memmap('{}/ddpm-sub-{}-0/features-{}/ddpm-train-keys-{}-{}-{}-{}-{}.npy'.format(\n",
    "                        args.output_dir, ckpt, e_seed,\n",
    "                        split, K, args.project_dim, f, args.strategy), \n",
    "                                        dtype=np.float32, \n",
    "                                        mode='r',\n",
    "                                        shape=(1000, args.project_dim))\n",
    "                    dstore_keys = dstore_keys[:, :args.used_dim]\n",
    "                    if e_seed==0:\n",
    "                        tmp = dstore_keys.copy()\n",
    "                    else:\n",
    "                        tmp += dstore_keys\n",
    "                tmp = tmp/num_seed\n",
    "                dstore_keys_list.append(tmp) \n",
    "            \n",
    "            dstore_keys = np.vstack(dstore_keys_list)\n",
    "            print(dstore_keys.shape)  \n",
    "            \n",
    "            if f=='l1_norm':\n",
    "                dstore_keys = dstore_keys / 3072\n",
    "            elif f=='l2_norm':\n",
    "                dstore_keys = dstore_keys / (3072**0.5)\n",
    "            ####    \n",
    "            tmp = None\n",
    "            for e_seed in range(num_seed):\n",
    "                gen_dstore_keys = np.memmap('{}/ddpm-sub-{}-0/features-{}/ddpm-val-keys-{}-{}-{}-{}-{}.npy'.format(\n",
    "                       args.output_dir, ckpt, e_seed, \n",
    "                    0, K, args.project_dim, f, args.strategy), \n",
    "                                    dtype=np.float32, \n",
    "                                    mode='r',\n",
    "                                    shape=(1000, args.project_dim))\n",
    "                gen_dstore_keys = gen_dstore_keys[:, :args.used_dim]\n",
    "                if e_seed==0:\n",
    "                    tmp = gen_dstore_keys.copy()\n",
    "                else:\n",
    "                    tmp += gen_dstore_keys\n",
    "            tmp = tmp/num_seed\n",
    "            gen_dstore_keys = tmp\n",
    "            print(gen_dstore_keys.shape)\n",
    "            if f=='l1_norm':\n",
    "                gen_dstore_keys = gen_dstore_keys / 3072\n",
    "            elif f=='l2_norm':\n",
    "                gen_dstore_keys = gen_dstore_keys / (3072**0.5)\n",
    "            ####\n",
    "            dstore_keys = torch.from_numpy(dstore_keys).cuda()\n",
    "            gen_dstore_keys = torch.from_numpy(gen_dstore_keys).cuda()\n",
    "            ####\n",
    "            # if f=='l1_norm':\n",
    "            #     dstore_keys = dstore_keys/3072\n",
    "            #     gen_dstore_keys = gen_dstore_keys/3072\n",
    "            ####\n",
    "            kernel = dstore_keys.T@dstore_keys\n",
    "            ####\n",
    "            rs_list = []\n",
    "            ps_list = []\n",
    "\n",
    "            best_scores = None\n",
    "            best_lds = -np.inf\n",
    "            for lamb in lamb_list:\n",
    "                print(lamb)\n",
    "                # kernel_ = kernel + lamb*np.eye(kernel.shape[0])\n",
    "                kernel_ = kernel + lamb*torch.eye(kernel.shape[0]).cuda()\n",
    "                # kernel_ = torch.from_numpy(kernel_).cuda()\n",
    "                ####\n",
    "                kernel_ = torch.linalg.inv(kernel_)  \n",
    "                # kernel_ = kernel_.cpu().numpy()\n",
    "                ####\n",
    "                print(kernel_.shape)\n",
    "                print(torch.mean(kernel_.diagonal()))\n",
    "                ####\n",
    "                # scores = gen_dstore_keys.dot((dstore_keys@kernel_).T)\n",
    "                scores = gen_dstore_keys@((dstore_keys@kernel_).T)\n",
    "                print(scores.size())\n",
    "                scores = scores.cpu().numpy()\n",
    "    \n",
    "                # compute lds\n",
    "                margins = lds_testset_correctness\n",
    "                infl_est_ = -scores\n",
    "                preds = lds_mask_array @ infl_est_.T\n",
    "                ####\n",
    "                rs = []\n",
    "                ps = []\n",
    "    \n",
    "                for ind in range(1000):\n",
    "                   r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "                   # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "                   rs.append(r)\n",
    "                   ps.append(p)\n",
    "        \n",
    "                rs, ps = np.array(rs), np.array(ps)\n",
    "                print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "    \n",
    "                rs_list.append(rs.mean())   \n",
    "                ps_list.append(ps.mean())\n",
    "                \n",
    "                if rs.mean()>best_lds:\n",
    "                    best_scores = scores\n",
    "                    best_lds = rs.mean()\n",
    "                    \n",
    "            lds_list.append((rs_list, ps_list))\n",
    "            score_list.append(best_scores)\n",
    "            \n",
    "        f_lds_list.append(lds_list)\n",
    "        f_score_list.append(score_list)\n",
    "    seed_lds_list.append(f_lds_list)\n",
    "    seed_score_list.append(f_score_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8970c9b6-4694-4c06-b9a9-ec38f5f6b55e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "73ae9625-b9dc-432c-94b6-6cfcdc726a94",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e8258b5b-5a58-45b1-a727-0a8a0a94fc81",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "c08f885c-95db-4cfb-a235-b8ddddcd3a50",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[[[-1.03631478e-02, -9.56186204e-03,  5.99203670e-02,\n",
       "           9.69904889e-02,  9.69172286e-02,  9.65299343e-02,\n",
       "           9.64985696e-02,  9.65486610e-02,  9.72472874e-02,\n",
       "           9.80465782e-02,  9.96633129e-02,  1.03480622e-01,\n",
       "           1.08343168e-01,  1.13971259e-01,  1.21017620e-01,\n",
       "           1.25994797e-01,  1.28403384e-01,  1.30249675e-01,\n",
       "           1.30269295e-01,  1.28968149e-01,  1.22369797e-01,\n",
       "           1.14955328e-01,  1.03879113e-01,  8.80881300e-02,\n",
       "           7.80849685e-02,  7.09924516e-02,  6.53869802e-02],\n",
       "         [ 5.08424033e-01,  5.06978667e-01,  4.72684112e-01,\n",
       "           4.02502546e-01,  4.04702502e-01,  4.06823968e-01,\n",
       "           4.06811422e-01,  4.06499583e-01,  4.05831879e-01,\n",
       "           4.04250793e-01,  4.01970926e-01,  3.99556022e-01,\n",
       "           3.94405056e-01,  3.90971149e-01,  3.80810543e-01,\n",
       "           3.74844644e-01,  3.71515283e-01,  3.68955111e-01,\n",
       "           3.66724142e-01,  3.70556934e-01,  3.82132360e-01,\n",
       "           3.94336825e-01,  4.11093836e-01,  4.29653112e-01,\n",
       "           4.41159201e-01,  4.50582371e-01,  4.57156808e-01]],\n",
       "\n",
       "        [[ 2.07394998e-03, -3.29636761e-04,  6.86019346e-02,\n",
       "           9.57490466e-02,  9.52591189e-02,  9.50538532e-02,\n",
       "           9.52659640e-02,  9.55492060e-02,  9.61226262e-02,\n",
       "           9.70260607e-02,  9.91169036e-02,  1.03429106e-01,\n",
       "           1.08572628e-01,  1.14181123e-01,  1.21753264e-01,\n",
       "           1.26007340e-01,  1.28063385e-01,  1.28741338e-01,\n",
       "           1.27833233e-01,  1.24892115e-01,  1.18783189e-01,\n",
       "           1.11294819e-01,  1.01504704e-01,  8.64407137e-02,\n",
       "           7.68515858e-02,  7.01667425e-02,  6.42499763e-02],\n",
       "         [ 4.87911796e-01,  4.96888452e-01,  4.51388922e-01,\n",
       "           4.24313797e-01,  4.23847368e-01,  4.25923920e-01,\n",
       "           4.25151448e-01,  4.24906284e-01,  4.24161659e-01,\n",
       "           4.22834097e-01,  4.19398668e-01,  4.10079428e-01,\n",
       "           3.99992544e-01,  3.87645263e-01,  3.79137995e-01,\n",
       "           3.75031693e-01,  3.73680930e-01,  3.67573796e-01,\n",
       "           3.68194847e-01,  3.69454619e-01,  3.78208577e-01,\n",
       "           3.89983622e-01,  4.07437272e-01,  4.36506894e-01,\n",
       "           4.50459416e-01,  4.57540852e-01,  4.61381796e-01]],\n",
       "\n",
       "        [[ 3.34832457e-03, -2.78266685e-04,  3.65528655e-02,\n",
       "           9.78968542e-02,  9.77830494e-02,  9.76005403e-02,\n",
       "           9.78319277e-02,  9.80667034e-02,  9.83360484e-02,\n",
       "           9.91353846e-02,  1.00464048e-01,  1.03731951e-01,\n",
       "           1.07624100e-01,  1.13158028e-01,  1.19868400e-01,\n",
       "           1.22981815e-01,  1.25755191e-01,  1.27551321e-01,\n",
       "           1.27418102e-01,  1.24978931e-01,  1.19297611e-01,\n",
       "           1.12723182e-01,  1.03718831e-01,  8.86781695e-02,\n",
       "           7.90174732e-02,  7.13906165e-02,  6.56650434e-02],\n",
       "         [ 4.87620789e-01,  4.99561154e-01,  4.86625789e-01,\n",
       "           4.04525726e-01,  4.03129378e-01,  4.03642441e-01,\n",
       "           4.03175290e-01,  4.03568158e-01,  4.03050655e-01,\n",
       "           4.03028095e-01,  4.01782763e-01,  4.00379172e-01,\n",
       "           3.98381190e-01,  3.91887987e-01,  3.82001263e-01,\n",
       "           3.74045352e-01,  3.68215791e-01,  3.63897867e-01,\n",
       "           3.67368655e-01,  3.70268211e-01,  3.77961931e-01,\n",
       "           3.87770972e-01,  4.02583169e-01,  4.26445485e-01,\n",
       "           4.38838289e-01,  4.48754419e-01,  4.54462532e-01]],\n",
       "\n",
       "        [[-1.15435029e-03,  4.81169548e-03, -6.16146977e-04,\n",
       "           9.82758605e-02,  9.88632463e-02,  9.95466478e-02,\n",
       "           9.96019362e-02,  9.97517302e-02,  1.00329752e-01,\n",
       "           1.01386597e-01,  1.03104249e-01,  1.06884813e-01,\n",
       "           1.11580395e-01,  1.16759379e-01,  1.22749995e-01,\n",
       "           1.26071604e-01,  1.27655147e-01,  1.28193584e-01,\n",
       "           1.27989761e-01,  1.26144112e-01,  1.21146559e-01,\n",
       "           1.13636921e-01,  1.04645185e-01,  9.06310319e-02,\n",
       "           8.02697650e-02,  7.33453359e-02,  6.76357427e-02],\n",
       "         [ 4.93155717e-01,  5.14298476e-01,  4.91727801e-01,\n",
       "           4.10088229e-01,  4.08625204e-01,  4.07755692e-01,\n",
       "           4.07945057e-01,  4.06955534e-01,  4.06256131e-01,\n",
       "           4.05144931e-01,  4.01530778e-01,  3.92906636e-01,\n",
       "           3.85883071e-01,  3.78915891e-01,  3.72316046e-01,\n",
       "           3.67420667e-01,  3.65934453e-01,  3.63008341e-01,\n",
       "           3.63448589e-01,  3.65258243e-01,  3.72879708e-01,\n",
       "           3.84142797e-01,  3.99053528e-01,  4.25094295e-01,\n",
       "           4.39960843e-01,  4.47674477e-01,  4.54981663e-01]],\n",
       "\n",
       "        [[ 1.12566842e-04, -1.33058141e-04,  6.93879945e-02,\n",
       "           9.46507457e-02,  9.39008153e-02,  9.38891394e-02,\n",
       "           9.39510211e-02,  9.41354762e-02,  9.46964881e-02,\n",
       "           9.55697026e-02,  9.67172759e-02,  1.00569635e-01,\n",
       "           1.04685822e-01,  1.10336532e-01,  1.18270714e-01,\n",
       "           1.23095073e-01,  1.26003772e-01,  1.28137632e-01,\n",
       "           1.27872591e-01,  1.25992875e-01,  1.20823896e-01,\n",
       "           1.13085568e-01,  1.03633919e-01,  8.88181634e-02,\n",
       "           7.90522731e-02,  7.22733325e-02,  6.64928841e-02],\n",
       "         [ 5.09408216e-01,  4.97846121e-01,  4.43114595e-01,\n",
       "           4.27125372e-01,  4.26747598e-01,  4.27584601e-01,\n",
       "           4.27159780e-01,  4.27129087e-01,  4.26733014e-01,\n",
       "           4.25182754e-01,  4.22963859e-01,  4.16393572e-01,\n",
       "           4.09617836e-01,  4.01945087e-01,  3.90531915e-01,\n",
       "           3.80484104e-01,  3.69324322e-01,  3.62908134e-01,\n",
       "           3.61594219e-01,  3.64010211e-01,  3.79620662e-01,\n",
       "           3.92241874e-01,  4.10005957e-01,  4.27884795e-01,\n",
       "           4.40637882e-01,  4.49965336e-01,  4.57611705e-01]],\n",
       "\n",
       "        [[ 2.10584649e-03,  2.08139651e-05,  7.01639447e-02,\n",
       "           9.56438107e-02,  9.66659486e-02,  9.64801422e-02,\n",
       "           9.68960076e-02,  9.70780592e-02,  9.78251517e-02,\n",
       "           9.86592636e-02,  1.00420367e-01,  1.04112675e-01,\n",
       "           1.08687699e-01,  1.13948803e-01,  1.20609839e-01,\n",
       "           1.24754893e-01,  1.26812608e-01,  1.27738820e-01,\n",
       "           1.26440423e-01,  1.24669544e-01,  1.19817734e-01,\n",
       "           1.12353058e-01,  1.02353698e-01,  8.77167669e-02,\n",
       "           7.81947619e-02,  7.12800174e-02,  6.57506244e-02],\n",
       "         [ 5.12364876e-01,  4.94221660e-01,  4.47124510e-01,\n",
       "           4.16223600e-01,  4.15398281e-01,  4.16149141e-01,\n",
       "           4.15306976e-01,  4.14702767e-01,  4.14744404e-01,\n",
       "           4.13320379e-01,  4.11455559e-01,  4.05901701e-01,\n",
       "           3.98880622e-01,  3.90771295e-01,  3.77194698e-01,\n",
       "           3.73849510e-01,  3.74610277e-01,  3.75948812e-01,\n",
       "           3.73997131e-01,  3.74536937e-01,  3.81701719e-01,\n",
       "           3.95046817e-01,  4.13361793e-01,  4.36863328e-01,\n",
       "           4.46767159e-01,  4.54037096e-01,  4.62015578e-01]],\n",
       "\n",
       "        [[ 5.72855893e-03,  3.91336078e-04,  1.87728358e-02,\n",
       "           9.64294051e-02,  9.64545428e-02,  9.69560532e-02,\n",
       "           9.69857957e-02,  9.71889292e-02,  9.77736595e-02,\n",
       "           9.87857020e-02,  1.00240876e-01,  1.03826247e-01,\n",
       "           1.08304866e-01,  1.13227463e-01,  1.19227511e-01,\n",
       "           1.23839164e-01,  1.26511165e-01,  1.28373600e-01,\n",
       "           1.28024397e-01,  1.26018307e-01,  1.20583330e-01,\n",
       "           1.12430142e-01,  1.02568421e-01,  8.78258577e-02,\n",
       "           7.77975568e-02,  7.13150456e-02,  6.54105125e-02],\n",
       "         [ 4.94892597e-01,  5.18711047e-01,  4.96736442e-01,\n",
       "           4.14557798e-01,  4.17362349e-01,  4.15170331e-01,\n",
       "           4.15875611e-01,  4.15925571e-01,  4.14384147e-01,\n",
       "           4.12530443e-01,  4.11885547e-01,  4.06790246e-01,\n",
       "           3.98803113e-01,  3.90829707e-01,  3.83818351e-01,\n",
       "           3.75270320e-01,  3.67124829e-01,  3.64376768e-01,\n",
       "           3.64407305e-01,  3.66928239e-01,  3.76124918e-01,\n",
       "           3.91367562e-01,  4.07894403e-01,  4.32399522e-01,\n",
       "           4.49070442e-01,  4.57509308e-01,  4.64839654e-01]],\n",
       "\n",
       "        [[ 9.74509191e-03, -1.52641894e-03,  8.88416216e-04,\n",
       "           9.87441292e-02,  1.00040625e-01,  9.98018661e-02,\n",
       "           9.98358866e-02,  1.00264847e-01,  1.00791610e-01,\n",
       "           1.01815259e-01,  1.03423294e-01,  1.07147150e-01,\n",
       "           1.11609856e-01,  1.16320938e-01,  1.22445365e-01,\n",
       "           1.26854867e-01,  1.29490742e-01,  1.30622335e-01,\n",
       "           1.30740238e-01,  1.29074304e-01,  1.22475930e-01,\n",
       "           1.15526935e-01,  1.04841654e-01,  8.97014303e-02,\n",
       "           7.99253532e-02,  7.28799729e-02,  6.69802930e-02],\n",
       "         [ 5.20735774e-01,  4.97847850e-01,  4.91722854e-01,\n",
       "           4.03724882e-01,  4.04419594e-01,  4.04970065e-01,\n",
       "           4.05124218e-01,  4.04555497e-01,  4.03200963e-01,\n",
       "           4.00560655e-01,  3.97944731e-01,  3.91813433e-01,\n",
       "           3.83452040e-01,  3.74945922e-01,  3.67308455e-01,\n",
       "           3.61353437e-01,  3.54667083e-01,  3.50417810e-01,\n",
       "           3.50295274e-01,  3.55129931e-01,  3.71982713e-01,\n",
       "           3.88386276e-01,  4.02558966e-01,  4.23074013e-01,\n",
       "           4.40138354e-01,  4.51901345e-01,  4.58832336e-01]]],\n",
       "\n",
       "\n",
       "       [[[ 6.30436653e-03,  4.09719136e-03,  3.39620412e-03,\n",
       "           5.89281908e-04,  8.30752282e-05,  2.17997359e-03,\n",
       "           7.10302965e-03,  1.40078398e-02,  1.79846029e-03,\n",
       "           2.76007834e-03, -4.01111456e-03, -9.42268051e-04,\n",
       "           2.39438536e-02,  2.13738483e-01,  2.29358677e-01,\n",
       "           2.42278253e-01,  2.53283110e-01,  2.61141880e-01,\n",
       "           2.61334119e-01,  2.56534255e-01,  2.47871410e-01,\n",
       "           2.40368684e-01,  2.31836424e-01,  2.18553864e-01,\n",
       "           2.05507224e-01,  1.90721300e-01,  1.69875764e-01],\n",
       "         [ 4.99648881e-01,  4.97775518e-01,  5.03317200e-01,\n",
       "           5.03250732e-01,  5.09763987e-01,  5.08907521e-01,\n",
       "           4.88207538e-01,  5.01129185e-01,  4.96297965e-01,\n",
       "           4.99331698e-01,  4.93934431e-01,  5.05770003e-01,\n",
       "           4.72706613e-01,  2.20893597e-01,  1.98030033e-01,\n",
       "           1.80497780e-01,  1.68453182e-01,  1.60184949e-01,\n",
       "           1.63669346e-01,  1.70939988e-01,  1.80628296e-01,\n",
       "           1.89705139e-01,  2.02226845e-01,  2.19614784e-01,\n",
       "           2.39887583e-01,  2.61075603e-01,  2.95152726e-01]],\n",
       "\n",
       "        [[ 6.87671087e-03, -4.13404236e-03, -3.04408975e-03,\n",
       "           1.10521036e-02,  4.70368770e-03,  6.86915910e-04,\n",
       "          -4.37300793e-03, -1.62928314e-03, -1.21966221e-03,\n",
       "          -4.48700987e-04,  1.16106680e-02, -3.21396710e-03,\n",
       "           1.30208016e-02,  2.22589861e-01,  2.37911428e-01,\n",
       "           2.49865989e-01,  2.59505163e-01,  2.66133508e-01,\n",
       "           2.65236849e-01,  2.60466861e-01,  2.50381463e-01,\n",
       "           2.41728120e-01,  2.33228939e-01,  2.18932785e-01,\n",
       "           2.06059387e-01,  1.91451731e-01,  1.71342131e-01],\n",
       "         [ 4.97099428e-01,  4.87936013e-01,  4.95645525e-01,\n",
       "           4.93567910e-01,  4.92482357e-01,  5.01726057e-01,\n",
       "           5.06212004e-01,  4.90658441e-01,  4.95743697e-01,\n",
       "           5.00208409e-01,  5.02840838e-01,  4.86436739e-01,\n",
       "           4.98278244e-01,  2.03307813e-01,  1.80764643e-01,\n",
       "           1.66512290e-01,  1.57818879e-01,  1.55440487e-01,\n",
       "           1.56380467e-01,  1.62056945e-01,  1.74439185e-01,\n",
       "           1.85271555e-01,  1.96765232e-01,  2.20726279e-01,\n",
       "           2.39445177e-01,  2.60467972e-01,  2.92702533e-01]],\n",
       "\n",
       "        [[ 7.19846826e-03,  5.27285135e-03,  3.21902454e-03,\n",
       "           9.54992823e-03,  7.13460630e-03, -1.90962665e-03,\n",
       "          -4.48950632e-04, -1.75817341e-03, -5.56670896e-03,\n",
       "           6.13285139e-03,  4.93976490e-03, -4.96828565e-03,\n",
       "           1.55121330e-02,  2.14282161e-01,  2.32386057e-01,\n",
       "           2.45280659e-01,  2.55659485e-01,  2.64218393e-01,\n",
       "           2.64392662e-01,  2.59707448e-01,  2.50573928e-01,\n",
       "           2.42814425e-01,  2.33745586e-01,  2.19119777e-01,\n",
       "           2.05354431e-01,  1.90345245e-01,  1.69608379e-01],\n",
       "         [ 5.15210389e-01,  4.91427560e-01,  5.05730567e-01,\n",
       "           4.85370254e-01,  4.96008541e-01,  4.92257307e-01,\n",
       "           4.87509265e-01,  5.09106144e-01,  5.03285511e-01,\n",
       "           5.15760149e-01,  4.94593955e-01,  4.83042703e-01,\n",
       "           4.81520744e-01,  2.19749411e-01,  1.94588396e-01,\n",
       "           1.78327858e-01,  1.66383032e-01,  1.57740722e-01,\n",
       "           1.61380726e-01,  1.66715373e-01,  1.73969380e-01,\n",
       "           1.83900054e-01,  1.97400170e-01,  2.17749323e-01,\n",
       "           2.36978771e-01,  2.62017894e-01,  2.95650587e-01]],\n",
       "\n",
       "        [[ 3.70399767e-03,  6.99823616e-03, -1.02312141e-02,\n",
       "           6.57078011e-03,  1.04663253e-02,  2.11524158e-03,\n",
       "           1.24063183e-02, -1.88161107e-04,  6.08041199e-03,\n",
       "           1.20245259e-03,  2.70883393e-03,  1.80961409e-02,\n",
       "           1.10810965e-02,  2.20990885e-01,  2.36841301e-01,\n",
       "           2.48739036e-01,  2.58604514e-01,  2.64172899e-01,\n",
       "           2.63056392e-01,  2.57707628e-01,  2.46863235e-01,\n",
       "           2.37739766e-01,  2.29230630e-01,  2.15566020e-01,\n",
       "           2.02520851e-01,  1.88113058e-01,  1.67601308e-01],\n",
       "         [ 5.02745541e-01,  4.81001170e-01,  5.03853745e-01,\n",
       "           4.86616894e-01,  5.06811574e-01,  5.05726097e-01,\n",
       "           4.94411241e-01,  5.01486892e-01,  4.95259095e-01,\n",
       "           4.94334252e-01,  4.99981786e-01,  4.93147439e-01,\n",
       "           4.95870264e-01,  2.04749058e-01,  1.84245252e-01,\n",
       "           1.71649500e-01,  1.61388169e-01,  1.58085438e-01,\n",
       "           1.60777500e-01,  1.71239467e-01,  1.88620118e-01,\n",
       "           1.98446587e-01,  2.08375819e-01,  2.29696175e-01,\n",
       "           2.50335839e-01,  2.73049270e-01,  3.03086716e-01]],\n",
       "\n",
       "        [[-3.10125985e-03, -4.73384412e-03,  6.92378294e-04,\n",
       "          -3.19497918e-03, -1.69072735e-04,  1.77713201e-03,\n",
       "           7.94904572e-03,  3.48877260e-03,  2.22678440e-03,\n",
       "           8.25261664e-03,  9.22592845e-03, -4.64643557e-03,\n",
       "           2.02991286e-02,  2.19213967e-01,  2.34411795e-01,\n",
       "           2.46881006e-01,  2.57300811e-01,  2.64245845e-01,\n",
       "           2.64225653e-01,  2.58879725e-01,  2.48464959e-01,\n",
       "           2.39333475e-01,  2.29867473e-01,  2.15471312e-01,\n",
       "           2.02864581e-01,  1.89243395e-01,  1.69051497e-01],\n",
       "         [ 4.83954586e-01,  5.10454446e-01,  5.03624018e-01,\n",
       "           4.97075622e-01,  5.04940768e-01,  5.13681901e-01,\n",
       "           5.06956389e-01,  5.03474060e-01,  4.97363212e-01,\n",
       "           4.99602208e-01,  4.91230114e-01,  5.02116898e-01,\n",
       "           4.95455679e-01,  2.08963953e-01,  1.91133678e-01,\n",
       "           1.76514567e-01,  1.64769191e-01,  1.59985452e-01,\n",
       "           1.61876883e-01,  1.68456030e-01,  1.82199222e-01,\n",
       "           1.94330233e-01,  2.06081796e-01,  2.30252268e-01,\n",
       "           2.48510623e-01,  2.68230547e-01,  2.97884124e-01]],\n",
       "\n",
       "        [[-4.67408443e-03,  8.12407685e-04, -2.68855242e-03,\n",
       "           4.05397648e-03,  1.22147412e-02,  1.56774085e-03,\n",
       "           2.66271441e-03,  1.53426818e-03,  3.24286727e-03,\n",
       "           5.33120435e-03,  4.19964181e-03,  7.37945686e-03,\n",
       "           1.88089054e-02,  2.16366345e-01,  2.32444048e-01,\n",
       "           2.44237297e-01,  2.55083362e-01,  2.62175855e-01,\n",
       "           2.63371186e-01,  2.59761593e-01,  2.50954976e-01,\n",
       "           2.42678326e-01,  2.33155497e-01,  2.19445331e-01,\n",
       "           2.05804162e-01,  1.91303856e-01,  1.70904451e-01],\n",
       "         [ 5.13012739e-01,  5.02733053e-01,  5.14326282e-01,\n",
       "           5.04306705e-01,  5.18020607e-01,  4.98166269e-01,\n",
       "           4.96848167e-01,  4.97170256e-01,  4.89034825e-01,\n",
       "           5.09661601e-01,  5.02628743e-01,  4.84764179e-01,\n",
       "           5.00215211e-01,  2.12679547e-01,  1.87229636e-01,\n",
       "           1.71359846e-01,  1.59575184e-01,  1.59041206e-01,\n",
       "           1.61393603e-01,  1.70805322e-01,  1.82358597e-01,\n",
       "           1.91529089e-01,  2.05348532e-01,  2.25907819e-01,\n",
       "           2.45067003e-01,  2.63202424e-01,  2.93070083e-01]],\n",
       "\n",
       "        [[ 1.45056385e-03,  1.37185523e-04,  3.45962329e-05,\n",
       "           5.44619572e-04,  1.23324631e-02, -2.70764681e-03,\n",
       "           3.53378507e-03,  3.03070312e-03, -2.03717749e-03,\n",
       "           2.51152336e-03,  7.54750647e-03,  4.13406531e-03,\n",
       "           1.22866122e-02,  2.21581819e-01,  2.36154488e-01,\n",
       "           2.47797393e-01,  2.56922601e-01,  2.63368139e-01,\n",
       "           2.61785081e-01,  2.55932126e-01,  2.45941967e-01,\n",
       "           2.37225092e-01,  2.28640176e-01,  2.14793928e-01,\n",
       "           2.01435289e-01,  1.86982221e-01,  1.67138721e-01],\n",
       "         [ 4.95899256e-01,  5.04105825e-01,  4.89804491e-01,\n",
       "           5.06412794e-01,  4.91466391e-01,  5.00341367e-01,\n",
       "           5.00662921e-01,  5.11570032e-01,  4.92679416e-01,\n",
       "           4.97695482e-01,  4.83741523e-01,  4.87484521e-01,\n",
       "           5.24928459e-01,  2.00438755e-01,  1.80441488e-01,\n",
       "           1.69081706e-01,  1.62919906e-01,  1.60134121e-01,\n",
       "           1.67148806e-01,  1.76545477e-01,  1.89741141e-01,\n",
       "           1.99652033e-01,  2.11645009e-01,  2.31686645e-01,\n",
       "           2.49770313e-01,  2.70665011e-01,  3.03078793e-01]],\n",
       "\n",
       "        [[ 9.48129853e-03,  2.23816313e-03, -3.55614088e-03,\n",
       "           5.17145466e-04,  4.29595810e-04, -5.95872260e-03,\n",
       "           3.10486235e-03, -1.19697157e-03,  5.27392722e-03,\n",
       "           3.99404572e-03, -2.17695037e-04,  4.90555983e-03,\n",
       "           1.10925555e-02,  2.18642717e-01,  2.34208677e-01,\n",
       "           2.46318135e-01,  2.56310789e-01,  2.62654636e-01,\n",
       "           2.62470798e-01,  2.57949553e-01,  2.49212462e-01,\n",
       "           2.41684117e-01,  2.32626949e-01,  2.17352562e-01,\n",
       "           2.03990696e-01,  1.89501430e-01,  1.69664726e-01],\n",
       "         [ 4.98524090e-01,  5.11947650e-01,  5.08423574e-01,\n",
       "           5.11233671e-01,  4.92825112e-01,  4.99181778e-01,\n",
       "           4.94908001e-01,  4.94907151e-01,  4.83307283e-01,\n",
       "           4.86179479e-01,  5.00080211e-01,  5.06504961e-01,\n",
       "           4.76791407e-01,  2.08610835e-01,  1.85467062e-01,\n",
       "           1.70102197e-01,  1.59553712e-01,  1.59939496e-01,\n",
       "           1.61280781e-01,  1.68288356e-01,  1.79822806e-01,\n",
       "           1.90417539e-01,  2.04017321e-01,  2.27540356e-01,\n",
       "           2.46299694e-01,  2.67022694e-01,  2.96096163e-01]]]])"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_lds_array = np.array(seed_lds_list)\n",
    "seed_lds_array[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "1c1d75dc-93fa-4af9-a3b7-d8a10e56feb5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1, 2, 8, 2, 27)"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_lds_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "018c6e64-d424-4018-a711-eee95131a802",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "10"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "K"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "fde83272-f2b9-4e41-a9e2-0d7b19810784",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('./val_5000_0.5_ckpt_{}.pkl'.format(K), 'wb') as handle:\n",
    "    pickle.dump(seed_lds_array, handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fb08a31e-97fe-4d9c-b426-370507cadf5b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c4d858e4-8104-45cc-a9bb-36e64765a662",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "00a7858a-30f7-4cc0-a3a7-d132143254e0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "8b050b5f-b8cf-421b-bb44-956399f61fed",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(1):\n",
    "    for j in range(2):\n",
    "        for k in range(seed_lds_array.shape[2]):\n",
    "            plt.plot(seed_lds_array[i, j, k, 0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4e079f7d-ad04-4caf-9d6d-140b77f4cbe3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9a1e074c-e43e-4e35-8ae5-2ba488e82406",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "ea85a313-addc-42eb-91ad-e671e3e13104",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[[0.13026929, 0.12874134, 0.12755132, 0.12819358, 0.12813763,\n",
       "         0.12773882, 0.1283736 , 0.13074024],\n",
       "        [0.26133412, 0.26613351, 0.26439266, 0.2641729 , 0.26424585,\n",
       "         0.26337119, 0.26336814, 0.26265464]]])"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_lds_array[:, :, :, 0].max(axis=-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fc8c05e8-c12d-4187-832b-7e4af09239c5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "c180a94c-6b0d-48bc-baaa-64ac650c7964",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1, 2, 8)"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_lds = seed_lds_array[:, :, :, 0].max(axis=-1)[:, :]\n",
    "seed_lds.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d5b54efc-5829-41cb-b173-ee03d7aa9db9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "11421adc-eb0c-4a34-8408-54ea5a2ba6f4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7fc1b4692fa0>"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA50AAAGaCAYAAACMtifbAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACB40lEQVR4nO3dd1QUVxsG8GeX3rEAAqIYBURUJKKIxqgRxRKjJipRo2iUJHZD7FHRxJKCNfYSMYndWBJFjRJ77xURK0lEwQIIKGX3fn8gIwu7wIrrgt/zO2cPzMw7d+7cnZ2dd+bOrEwIIUBERERERESkA3J9V4CIiIiIiIjeXEw6iYiIiIiISGeYdBIREREREZHOMOkkIiIiIiIinWHSSURERERERDrDpJOIiIiIiIh0hkknERERERER6QyTTiIiIiIiItIZJp1ERERERESkM0w6iYiIiIiISGf0nnTOnz8frq6uMDU1hZ+fH06cOFFofFJSEgYNGgRHR0eYmJjA3d0dkZGRr6m2REREREREpA1DfS583bp1CA0NxaJFi+Dn54fZs2cjMDAQMTExsLe3LxCfmZmJVq1awd7eHhs3boSzszPu3LkDW1vb1195IiIiIiIiKpJMCCH0tXA/Pz80aNAA8+bNAwAolUq4uLhgyJAhGDNmTIH4RYsW4ccff8TVq1dhZGT0uqtLREREREREWtJb0pmZmQlzc3Ns3LgRnTp1ksYHBwcjKSkJW7duLTBPu3btUL58eZibm2Pr1q2ws7NDjx49MHr0aBgYGKhdTkZGBjIyMqRhpVKJR48eoUKFCpDJZK98vYiIiIioZIQQePLkCZycnCCX6/1uMCIqIb11r33w4AEUCgUcHBxUxjs4OODq1atq57l58yb+/vtv9OzZE5GRkbh+/ToGDhyIrKwshIWFqZ1n+vTpmDx58iuvPxERERHp1j///IPKlSvruxpEVEJ6vadTW0qlEvb29liyZAkMDAxQv359/Pfff/jxxx81Jp1jx45FaGioNJycnIwqVargn3/+gbW19euqOhEREREVU0pKClxcXGBlZaXvqhDRK6C3pLNixYowMDDA/fv3Vcbfv38flSpVUjuPo6MjjIyMVLrSenp64t69e8jMzISxsXGBeUxMTGBiYlJgvLW1NZNOIiIiolKMt0IRvRn01kne2NgY9evXR1RUlDROqVQiKioK/v7+audp0qQJrl+/DqVSKY27du0aHB0d1SacREREREREpF96vTM7NDQUS5cuxcqVKxEdHY0BAwYgLS0Nffv2BQD07t0bY8eOleIHDBiAR48eYdiwYbh27Rq2b9+OadOmYdCgQfpaBSIiIiIiIiqEXu/pDAoKQmJiIiZOnIh79+6hXr162Llzp/Rwobi4OJUnlrm4uGDXrl348ssvUbduXTg7O2PYsGEYPXq0vlaBiIiIiIiICqHX3+nUh5SUFNjY2CA5OZn3dBIRERGVQjxeI3qz8IePiIiIiIiISGeYdBIREREREZHOMOkkIiIiIiIinWHSSURERERERDrDpJOIiIiIiIh0hkknERERERER6QyTTiIiIiIiItIZJp1ERERERESkM0w6iYiIiIiISGeYdBIREREREZHOMOkkIiIiIiIinWHSSURERERERDrDpJOIiIiIiIh0hkknERERERER6QyTTiIiIiIiItIZJp1ERERERESkM0w6iYiIiIiISGeYdBIREREREZHOMOkkIiIiIiIinWHSSURERERERDrDpJOIiIiIiIh0hkknERERERER6QyTTiIiIiIiItIZJp1ERERERESkM0w6iYiIiIiISGeYdBIREREREZHOMOkkIiIiIiIinWHSSURERERERDrDpJOIiIiIiIh0hkknERERERER6QyTTiIiIiIiItIZJp1ERERERESkM0w6iYiIiIiISGeYdBIREREREZHOMOkkIiIiIiIinWHSSURERERERDrDpJOIiIiIiIh0hkknERERERER6QyTTiIiIiIiItIZJp1ERERERESkM6Ui6Zw/fz5cXV1hamoKPz8/nDhxQmNsREQEZDKZysvU1PQ11paIiIiIiIiKS+9J57p16xAaGoqwsDCcOXMG3t7eCAwMREJCgsZ5rK2tER8fL73u3LnzGmtMRERERERExaX3pHPmzJkICQlB3759UatWLSxatAjm5ub4+eefNc4jk8lQqVIl6eXg4PAaa0xERERERETFZajPhWdmZuL06dMYO3asNE4ulyMgIABHjx7VOF9qaiqqVq0KpVKJt99+G9OmTYOXl5fWy87MzCwwXi6Xw9DQUCVOE5lMBiMjo5eKzcrKghDitcYCgLGx8UvFZmdnQ6lUvpJYIyMjyGQyncYqFAooFIpXEmtoaAi5XF5qYpVKJbKzszXGGhgYwMDAoNTECiGQlZX1SmLzfj51FQsU/lnmPkJ9LPcR3EdwH6F9LPcRmmMLawsiKnv0mnQ+ePAACoWiwJVKBwcHXL16Ve08Hh4e+Pnnn1G3bl0kJycjPDwcjRs3xuXLl1G5cuUC8RkZGcjIyJCGU1JSAAAzZsxQey+om5sbevToIQ2Hh4dr/CKqWrUq+vTpIw3PmTMH6enpamOdnJwQEhIiDc+fPx/JyclqY+3s7DBw4EBpeOnSpUhMTFQba2Njg+HDh0vDERERuHv3rtpYc3NzjBw5UhpetWqVxq7JRkZGGDdunDS8fv16xMbGqo0FgLCwMOn/zZs348qVKxpjx44dK325bNu2DefPn9cYO2LECFhYWAAAdu3ahVOnTmmMHTZsGGxtbQEAUVFRhZ64GDBgAOzt7QEABw8exP79+zXG9u/fH87OzgCAY8eOYc+ePRpjg4OD4erqCgA4ffo0duzYoTG2e/fucHd3BwBcvHgRW7du1RjbpUsX6cRKdHQ0Nm7cqDG2Y8eOqFevHgDg+vXrWLNmjcbYtm3bomHDhgCAuLg4rFy5UmNsQEAAmjRpAgCIj4/HsmXLNMY2a9YMzZs3BwAkJiZi4cKFGmP9/f3RunVrAEBycjLmzJmjMdbX1xft27cHAKSnpyM8PFxjrLe3Nzp16gQg58Bo+vTpGmNr1aqFrl27SsOFxXIfkYP7iBe4j8jBfUQO7iNylHQfcebMGY2xRFT26L17rbb8/f3Ru3dv1KtXD82aNcOmTZtgZ2eHxYsXq42fPn06bGxspJeLi8trrjEREREREdH/L5korF+EjmVmZsLc3BwbN26UzjYCOWeCk5KSCj2rm1fXrl1haGio9mytuiudLi4uSExMhLW1dYF4dotRH8uuc+w6x65z2sdyH/FysdxHlCy2NHzuuY/gPiJ/rLb7iKSkJNjZ2SE5OVnt8RoRlS16TToBwM/PDw0bNsRPP/0EIOeLqkqVKhg8eDDGjBlT5PwKhQJeXl5o164dZs6cWWR8SkoKbGxsuBMjIiIiKqV4vEb0ZtHrPZ0AEBoaiuDgYPj6+qJhw4aYPXs20tLS0LdvXwBA79694ezsLN0/8c0336BRo0aoUaMGkpKS8OOPP+LOnTvo37+/PleDiIiIiIiI1NB70hkUFITExERMnDgR9+7dQ7169bBz507p4UJxcXFSlyEAePz4MUJCQnDv3j2UK1cO9evXx5EjR1CrVi19rQIRERERERFpoPfuta8bu2sQERERlW48XiN6s5S5p9cSERERERFR2cGkk4iIiIiIiHSGSScRERERERHpDJNOIiIiIiIi0hkmnURERERERKQzTDqJiIiIiIhIZ5h0EhERERERkc4w6SQiIiIiIiKdYdJJREREREREOsOkk4iIiIiIiHSGSScRERERERHpDJNOIiIiIiIi0hkmnURERERERKQzTDqJiIiIiIhIZ5h0EhERERERkc4w6SQiIiIiIiKdYdJJREREREREOsOkk4iIiIiIiHSGSScRERERERHpDJNOIiIiIiIi0hkmnURERERERKQzTDqJiIiIiIhIZ5h0EhERERERkc4w6SQiIiIiIiKdYdJJREREREREOsOkk4iIiIiIiHSGSScRERERERHpDJNOIiIiIiIi0hkmnURERERERKQzTDqJiIiIiIhIZ5h0EhERERERkc4w6SQiIiIiIiKdYdJJREREREREOsOkk4iIiIiIiHSGSScRERERERHpDJNOIiIiIiIi0hkmnURERERERKQzTDqJiIiIiIhIZ5h0EhERERERkc4w6SQiIiIiIiKdYdJJREREREREOlMqks758+fD1dUVpqam8PPzw4kTJ4o139q1ayGTydCpUyfdVpCIiIiIiIheit6TznXr1iE0NBRhYWE4c+YMvL29ERgYiISEhELnu337NkaMGIGmTZu+ppoSERERERGRtmRCCKHPCvj5+aFBgwaYN28eAECpVMLFxQVDhgzBmDFj1M6jUCjw7rvv4tNPP8XBgweRlJSELVu2FGt5KSkpsLGxQWJiIqytrQtMl8vlMDQ0lIYzMzM1liWTyWBkZPRSsVlZWdDU9LqKBQBjY+OXis3OzoZSqXwlsUZGRpDJZDqNVSgUUCgUryTW0NAQcrm81MQqlUpkZ2drjDUwMICBgUGpiRVCICsr65XE5v186ioWKPyzzH2E+ljuI7iP4D5C+1juIzTHJiUlwc7ODsnJyWqP14iobDEsOkR3MjMzcfr0aYwdO1YaJ5fLERAQgKNHj2qc75tvvoG9vT369euHgwcPFrqMjIwMZGRkSMMpKSkAgBkzZsDU1LRAvJubG3r06CENh4eHa/wiqlq1Kvr06SMNz5kzB+np6WpjnZycEBISIg3Pnz8fycnJamPt7OwwcOBAaXjp0qVITExUG2tjY4Phw4dLwxEREbh7967aWHNzc4wcOVIaXrVqFe7cuaM21sjICOPGjZOG169fj9jYWLWxABAWFib9v3nzZly5ckVj7NixY6Uvl23btuH8+fMaY0eMGAELCwsAwK5du3Dq1CmNscOGDYOtrS0AICoqqtBtaMCAAbC3twcAHDx4EPv379cY279/fzg7OwMAjh07hj179miMDQ4OhqurKwDg9OnT2LFjh8bY7t27w93dHQBw8eJFbN26VWNsly5d4OXlBQCIjo7Gxo0bNcZ27NgR9erVAwBcv34da9as0Rjbtm1bNGzYEAAQFxeHlStXaowNCAhAkyZNAADx8fFYtmyZxthmzZqhefPmAIDExEQsXLhQY6y/vz9at24NAEhOTsacOXM0xvr6+qJ9+/YAgPT0dISHh2uM9fb2lrreZ2VlYfr06Rpja9Wqha5du0rDhcVyH5GD+4gXuI/IwX1EDu4jcpR0H3HmzBmNsURU9ui1e+2DBw+gUCjg4OCgMt7BwQH37t1TO8+hQ4ewfPlyLF26tFjLmD59OmxsbKSXi4tLietNRERERERExaPX7rV3796Fs7Mzjhw5An9/f2n8qFGjsH//fhw/flwl/smTJ6hbty4WLFiAtm3bAgD69OlTaPdadVc6XVxc2L1Wy1h2nWPXOXad0z6W+4iXi+U+omSxpeFzz30E9xH5Y9m9luj/m16TzszMTJibm2Pjxo0qT6ANDg5GUlJSga5E586dg4+Pj/TlA0DagcnlcsTExKB69eqFLjP3nk7uxIiIiIhKJx6vEb1Z9Nq91tjYGPXr10dUVJQ0TqlUIioqSuXKZ66aNWvi4sWLOHfunPT64IMP0KJFC5w7d45dZ4mIiIiIiEoZvT5ICABCQ0MRHBwMX19fNGzYELNnz0ZaWhr69u0LAOjduzecnZ0xffp0mJqaonbt2irz5z4UIv94IiIiIiIi0j+9J51BQUFITEzExIkTce/ePdSrVw87d+6UHi4UFxcn3adCREREREREZYvef6fzdeM9AkRERESlG4/XiN4svIRIREREREREOsOkk4iIiIiIiHSGSScRERERERHpDJNOIiIiIiIi0hkmnURERERERKQzTDqJiIiIiIhIZ5h0EhERERERkc4w6SQiIiIiIiKdYdJJREREREREOsOkk4iIiIiIiHSGSScRERER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FB4erjHW29sbnTp1ApBzYDR9+nSNsbVq1ULXrl2l4cJiuY/IwX3EC9xH5OA+Igf3ETlKuo84c+aMxlgiKnv0fk9nSXz33XdYu3YtNm/erDaBBHK+GGxsbKSXi4vLa64lERERERHR/y+93tOZmZkJc3NzbNy4UTrbCOScCU5KSir0rG54eDimTJmCPXv2wNfXV2OcuiudLi4uSExMVHuPALvFqI9l1zl2nWPXOe1juY94uVjuI0oWWxo+99xHcB+RP1bbfURSUhLs7Ox4TyfRG6JUPEioYcOG+OmnnwDkfFFVqVIFgwcP1vggoR9++AFTp07Frl270KhRI62WxxvTiYiIiEo3Hq8RvVn0ek8nAISGhiI4OBi+vr5o2LAhZs+ejbS0NPTt2xcA0Lt3bzg7O0v3T3z//feYOHEiVq9eDVdXV9y7dw8AYGlpCUtLS72tBxERERERERWk96QzKCgIiYmJmDhxIu7du4d69eph586d0sOF4uLipC5DALBw4UJkZmaiS5cuKuWEhYVh0qRJr7PqREREREREVAS9d6993dhdg4iIiKh04/Ea0ZulTD+9loiIiIiIiEo3Jp1ERERERESkM0w6iYiIiIiISGeYdBIREREREZHOMOkkIiIiIiIinWHSSURERERERDrDpJOIiIiIiIh0hkknERERERER6QyTTiIiIiIiItIZJp1ERERERESkM0w6iYiIiIiISGeYdBIREREREZHOMOkkIiIiIiIinWHSSURERERERDrDpJOIiIiIiIh0hkknERERERER6QyTTiIiIiIiItIZJp1ERERERESkM0w6iYiIiIiISGeYdBIREREREZHOMOkkIiIiIiIinWHSSURERERERDrDpJOIiIiIiIh0hkknERERERER6QyTTiIiIiIiItIZJp1ERERERESkM0w6iYiIiKhQD1MzcOm/ZDxMzdB3VYioDDLUdwXedA9TMxCf/AyONqaoYGmi7+qUSWxDIiIi/dl7NQEzd8cgNUMBSxMDhLbyQIua9vquFhGVIUw6dWjv1QRMjYxGytMsmBkZoJOPE7xdbCGTySCXySCXAXKZDDIZIIMMBvKc/+UyFIgBkGe6rECMDDLI5bnjXpQrfx4jAyDPN3/eZasMP19eacAvupJj0l5ybMOSYxuWDNuv5EpjGwohoFAKKISAUgkong+rG69U5oxTipyX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D+PHj3/JVsm5h3Lu3LlYvHgxnJyc0LFjR7VxxsbGGDt2LOrWrYt3330XBgYGWLt2baFl9O/fH8uWLcOKFStQp04dNGvWDBEREQWudBa2zoUtl4iIiMommcjbb4uIiF6L27dvo1q1ajh79izq1aun7+q8Fv+P60xERES80klEREREREQ6xKSTiIiIiIiIdIbda4mIiIiIiEhneKWTiIiIiIiIdIZJJxEREREREekMk04iojdAREQEbG1tC42ZNGmSylNj+/Tpg06dOum0XkRERERMOomoUEIILFmyBH5+frC0tIStrS18fX0xe/ZspKenAyiYzEyaNAkymazAa8+ePVLMmjVrYGBggEGDBhVY5r59+1Tms7OzQ7t27XDx4kWVuOnTp6NBgwawsrKCvb09OnXqhJiYmGKt17///gtjY2PUrl37JVqleEleaTNixAhERUWVqAylUonRo0fDyckJZmZmqFu3LrZu3VogrrD2kclk2LJlS4nqoSvXr1/Hp59+iipVqsDExATOzs5o2bIlVq1ahezsbH1Xj4iIqExi0klEherVqxeGDx+Ojh07Yu/evTh37hwmTJiArVu34q+//tI4n5eXF+Lj41Ve7777rjR9+fLlGDVqFNasWYNnz56pLSMmJgbx8fHYtWsXMjIy0L59e2RmZkrT9+/fj0GDBuHYsWPYvXs3srKy0Lp1a6SlpRW5XhEREejWrRtSUlJw/PhxLVqk7LK0tESFChVKVMZvv/2GWbNmYebMmYiOjsbMmTNhYWHximpYPHm3gVfpxIkTePvttxEdHY358+fj0qVL2LdvH/r374+FCxfi8uXLOlkuERHRG08QEWmwbt06AUBs2bKlwDSlUimSkpKEEEKEhYUJb29vaVr+4fxu3rwpzMzMRFJSkvDz8xOrVq1Smb53714BQDx+/Fga98cffwgA4vz58xrLTUhIEADE/v37C10vpVIp3nrrLbFz504xevRoERISUuTyz549KwCIW7duSdPzvsLCwoQQQjx69Ej06tVL2NraCjMzM9GmTRtx7do1qZwVK1YIGxsb8eeffwp3d3dhZmYmPvroI5GWliYiIiJE1apVha2trRgyZIjIzs6W5ituuZs3bxY1atQQJiYmonXr1iIuLk6Kyf++BAcHi44dO0rDCoVCTJs2Tbi6ugpTU1NRt25dsWHDBpW2+fXXX4WT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",
      "text/plain": [
       "<Figure size 800x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(8,4))\n",
    "\n",
    "for idx, f in enumerate(f_name_list):\n",
    "    plt.plot(ckpt_list, seed_lds[0, idx], label=f, marker='.', alpha=0.75)\n",
    "\n",
    "plt.xlabel('checkpoint steps \\n CIFAR2 Automobile&Horse Gen \\n (train examples N=5000, uniform timesteps K=10, dimensions proj_dim=32768)')\n",
    "plt.ylabel('LDS')\n",
    "plt.xticks(ticks=ckpt_list, labels=ckpt_list, rotation=60)\n",
    "plt.ylim(0, 0.6)\n",
    "\n",
    "plt.axhline(y=0.5, color='gray', linestyle='dashed')\n",
    "plt.axhline(y=0.4, color='gray', linestyle='dashed')\n",
    "plt.axhline(y=0.3, color='gray', linestyle='dashed')\n",
    "plt.axhline(y=0.2, color='gray', linestyle='dashed')\n",
    "plt.axhline(y=0.1, color='gray', linestyle='dashed')\n",
    "\n",
    "plt.legend(loc=(1.04, 0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "82fd4e87-cd7c-4df7-9e2a-bee0c2ad414d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d8daccc6-b205-4e9e-86cc-8a9c393fbd99",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "70fb08b2-f74f-4492-b47a-b0bbc9b041e0",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('./val_5000_0.5_scores_{}.pkl'.format(K), 'wb') as handle:\n",
    "    pickle.dump(seed_score_list, handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bc3e10d6-8634-4088-8791-b05a1bd4a2c3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "abb6edb1-a3ee-4e14-86e7-443c46c8078d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "1607c463-df77-4f5c-bc18-866080849dd4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(seed_score_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "fc70e90a-ac36-48b0-82ed-6a3b9aa6a95f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(seed_score_list[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "45b82a31-0e5d-4292-9018-29364865a6ae",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "8"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(seed_score_list[0][0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "13219d07-cb2b-4c6b-a14c-f1f8642ffd3d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1000, 5000)"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed_score_list[0][0][0].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "b012a62f-d6b4-4da4-97dd-196dad83b36f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1000, 5000)"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.stack(seed_score_list[0][0]).mean(axis=0).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2e7ddf24-c529-483e-9f4f-893f43015630",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "134a59cf-e751-49b5-a5aa-8d1a0de4450c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.135 (avg p value 0.354702)\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": 39,
   "id": "e7105050-c8e3-47e1-a532-c4111d35421e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.285 (avg p value 0.134676)\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": []
  }
 ],
 "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
}
