{
 "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": null,
   "id": "8c2f5efb-631c-4083-84ae-dc219c6a75a1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fde1d3d3-3ae3-4194-b2e8-596809be9636",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9e3a5e70-ec86-4af6-ad75-bdc4351b4d40",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "723df846-36f4-433c-99cf-044b96c870ec",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cf1854ba-184b-4c9f-9a5c-9158e786e404",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c4cadde9-8859-435a-b6ba-09aa42bb468d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "\n",
    "os.environ[\"CUDA_DEVICE_ORDER\"]=\"PCI_BUS_ID\"   \n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"]='0'\n",
    "\n",
    "os.environ[\"HF_HOME\"]=\"~/codes/.cache/huggingface\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "2f7cd96b-ca27-4ce1-ac2d-c3dd67e069b7",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import random\n",
    "import numpy as np\n",
    "\n",
    "def set_seeds(seed):\n",
    "    random.seed(seed)\n",
    "    np.random.seed(seed)\n",
    "    torch.manual_seed(seed)\n",
    "    torch.backends.cudnn.deterministic = True\n",
    "    torch.backends.cudnn.benchmark = False\n",
    "    \n",
    "set_seeds(42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "4ff495b8-8df0-49e8-a409-4ed9601c8143",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "def show_images(images, scores, test_artist, train_artists):\n",
    "    n: int = len(images)\n",
    "    f = plt.figure(figsize=(16, 2))\n",
    "    for i in range(n):\n",
    "        # Debug, plot figure\n",
    "        ax = f.add_subplot(1, n, i + 1)\n",
    "        if i==0:\n",
    "            pass\n",
    "            ax.title.set_text(test_artist)\n",
    "        else:\n",
    "            ax.title.set_text(str(np.round(scores[i-1], 4))+'\\n'+train_artists[i-1])\n",
    "            ax.axis('off')\n",
    "        if images[i]==None:\n",
    "            pass\n",
    "        else:\n",
    "            plt.imshow(images[i])\n",
    "\n",
    "    plt.show(block=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "c4e89a09-d6ff-46a1-8a9e-9c6f9c167114",
   "metadata": {},
   "outputs": [],
   "source": [
    "from datasets import load_dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2682e2c4-9275-4bae-a732-74b981a358d2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "fb2dc562-293c-4e74-8e97-141fc7465938",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "bda41875-8976-4852-823a-91dc1f42aebf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "50000"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open('../../data/indices/50000-0.5/idx-train.pkl', 'rb')  as handle:\n",
    "    idx_train = pickle.load(handle)\n",
    "len(idx_train)   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "5ffbb813-1636-44e3-b943-400824fde5e7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1000"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open('../../data/indices/50000-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": "b2e50aae-335f-457d-bfb7-e3991f19fb50",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5df420e1-7166-4e5b-baa3-a012fe7e32e1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "f2ce6b6b-ff45-4156-9606-7c87046e751a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<PIL.PngImagePlugin.PngImageFile image mode=RGB size=32x32>"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from datasets import DatasetDict, Dataset, load_dataset, Image\n",
    "\n",
    "train_dataset = dataset['train'].select(idx_train)\n",
    "train_dataset[0][\"img\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "26b8b800-7147-4c3b-9f62-b99110392974",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "087ea1db-01c9-4e6a-a402-8b8a9aa93e8b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAIAAAD8GO2jAAAFOElEQVR4nN1Wy3IbyRHMrO6ZwWMAEFrKJCWSoq1Y+7COsP//J3TUwRE+6MHHhkgQIAbz6O4qHwaAKJKr215cgUAgujGZnZVVNc3z83P8mSF/Kvr/BYEnCcDMnm1tV0iagdwvGwCKmBnMKPLCo49CvPciP+gg4RxFCBhgJEgDDKZCkCBsOCh2vyH8WUiMUVX5/YQA4H2WZZmIDAYD7z3JXqKZOefGZZnnOYAsy5yTnwqA2C6ebDjnnHM9UJ8oca7nmM/neZ6LSJ7nWZbbo3iB4PmSGULozCzLspQSgD6NPYSqhhCccyR7lT3ri+gvEwBQNVLyLBcRJ85U+48I1XSzqcx0NBwOBoVq2pfDi+F7K54oABmjZh6OEmKwGBxxcHgwGA2ur65F1IsNB9lmveqamiDlD8vdP0EHABqpIpK088LhMOva5L07OT6czmaZk8Xi/nZx13VBk4IO/Fkz+edLpAGatMvdoCyHuXchFE5kMh6enhyt7hefP62SEnBGTwrwQyc9OfHLJgOIMa3XVYp6fHRyePhakz4s7+tqVXg3Ho0AGsTEK53tcPfQJEWkr0NeXFw8Jdj+CTD1wmk5Ho9HoWsPpvlsOsoH48Vq85//fmoCxBUAHfoG5BMR/bd3oqQYARCg7bdBwAirmjaoluORiG/qNkRMysn56enl9beYQBHZpaEv1r2Ons9PxznIBAJipIFmZikZDCAMIJVQQkEFU5d8lubT2d3tso4tjHiUmRdMno6HyTRENYrtRKhKPz8oYqoxpRi6mPygKOqm+/Tlaxe0aaP1Dv/YZfuhslMwKkKMtXUhRaNQBJREJjPAvHM+L0LokqYQQ0h5VTff7u4V4lwOCmBAwg4UzwazLwdZTOIF1aZOpnmegy4k7WApJWjKity5oq7rpmkUXD5URnEuNzg1EqDZ42Z+OjezzJlpkecxpaYN3jmf5ZISiLZV0yREkecaQ93F1aqqm0BxBtq25Ix/AN2Pey/ifS6hDQpROnMZnGdSmsLUCTPvvBPvnDjp2g6SsW9dMzLt6vGZz7tEeRFmlFqjhs5CQMyMFkIbQuB24jtVte0TBNhP1j0UH+X8e40CAIT0dduGLtR1PSlHx2VpautNHboupVQUxXQ6NbOmaVJMqkwpPR2OBtD2Cr5zbLtZ/P0mEMhH09PTN5Oy3FTrcP07H6q+M2OMZVnGGNu2a9uuPz6AXgQACnsFj18JJCEU70ScPzx7fzCdeoGluKrbTd0Vo/Jf/z6LMX78+PHr5eXff/11Pp8DfGiWzknf5iKiqj0WbTsntpQkSRMaaTD/9vSv08kkyzyBZlPd3Fw39frw6OjVfJ4Nig8fPiyWy3cX7xS4r1prgplRaKBzHhQaTBMMlN567vw1qBrgp5NpCMEMo9FoflhODn55WC2qh9tvi8Vs/mo6m19dXR2s1vNXrybLTd3ekr3TgDhSCNLkyYggtzcSAP7i4mK1Wi2Xy8Vi4Zw7ODg4PHw9m5X3i7urqyujH4wn17/f/vL6+Pj4ZLWuzMxABXsCGMW0d7S33+xHgrquAZRlOR6PN5vNarUSIUzFFX97/4+3Zxe3325vbm7qJr59e7Zcre6XS4pLoNq2halKQkT29yuSZgoYSV8UhZn1dxAhq6pyzheDIUmI/OXo9dn5+7quLy+/Fl5+++2fn79+qeumS5rUADE1aLK94dyWWUoRMBHxJ2/eqOrnL5/XVdW27WA43GokN3UdQpzNZqPR6Pz83eZhMRrlIlTg9u6+DVGc06imqin1N5r9BSmlBJj37n+v2zva5lpxsAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<PIL.PngImagePlugin.PngImageFile image mode=RGB size=32x32>"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "val_dataset =  dataset['test'].select(idx_val)\n",
    "val_dataset[0][\"img\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "e16837b7-8ddd-46ab-9d0a-c988f2ca9514",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[9128, 5468, 62, 2465, 2810]"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "idx_val[0:5]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0dd5e770-1fed-4f65-b4e7-5373e2adcb10",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "317f972c-b763-40d3-8186-759118c12237",
   "metadata": {},
   "outputs": [],
   "source": [
    "class Args():\n",
    "            \n",
    "    dataset_name=\"cifar10\"\n",
    "\n",
    "    output_dir=\"../../saved/50000-0.5/ddpm/checkpoint-78200\"\n",
    "    \n",
    "    # K=10\n",
    "    # project_dim=3584\n",
    "    Z=65536\n",
    "\n",
    "    # used_dim=4096\n",
    "    # used_dim=16384\n",
    "    used_dim=32768\n",
    "    \n",
    "    t_strategy='uniform'\n",
    "    \n",
    "    # f='mean_squared_l2_norm'\n",
    "    # f='l2_norm'\n",
    "    # f='loss'\n",
    "   \n",
    "args = Args()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "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": "3ffe8c0c-a6df-41e9-8cd9-4dfa6eaa4d89",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "0740ed2c-c98c-494d-bc1f-381653a77964",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2728"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from sklearn.random_projection import johnson_lindenstrauss_min_dim\n",
    "johnson_lindenstrauss_min_dim(n_samples=1e3, eps=0.15)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "58c5c4e8-7171-4847-9fba-51ea76b2c794",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "3002"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from sklearn.random_projection import johnson_lindenstrauss_min_dim\n",
    "johnson_lindenstrauss_min_dim(n_samples=2e3, eps=0.15)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "32c7cc29-8267-4fc3-915f-2628006b3af9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "3364"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from sklearn.random_projection import johnson_lindenstrauss_min_dim\n",
    "johnson_lindenstrauss_min_dim(n_samples=5e3, eps=0.15)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "5396c1cc-03c9-407d-b4ba-d16f4b56bc25",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "3638"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from sklearn.random_projection import johnson_lindenstrauss_min_dim\n",
    "johnson_lindenstrauss_min_dim(n_samples=1e4, eps=0.15)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a8c9ec30-0da2-4b68-9f5f-8e9e0faab1bc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "04be809b-6fd9-4a8a-9d64-94c6ef3b4f85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ad307d24-057d-43bc-9772-5ae5d62c9fa1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "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": 20,
   "id": "7e5b270b-c5df-4b5d-a8fd-2a924a6edad6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000, 1000)"
      ]
     },
     "execution_count": 20,
     "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/50000-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": 21,
   "id": "d823ef7b-9d53-4f31-ab11-864274554493",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiMAAAGdCAYAAADAAnMpAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABlSUlEQVR4nO3deXxdZYH/8c8552652ZcmadO06V5K6UJLS9lEqKIsCuNSHRSmCs4oKNgZFXSEn45aFGSYcRiKDCijIogDqIgFrCwihUIXaIEWSvc2a7MnN3c7z++Pm9z0NkmbtGku7f2+X6/7Ivec55z73FNovjyrZYwxiIiIiKSJne4KiIiISGZTGBEREZG0UhgRERGRtFIYERERkbRSGBEREZG0UhgRERGRtFIYERERkbRSGBEREZG08qS7AoPhui779u0jNzcXy7LSXR0REREZBGMMbW1tjBkzBtseuP3juAgj+/bto7KyMt3VEBERkSOwe/duxo4dO+D54yKM5ObmAokvk5eXl+baiIiIyGC0trZSWVmZ/D0+kCMKI3feeSe33norNTU1zJ49m5/85CcsWLCg37Lnnnsuzz33XJ/jF154IX/84x8H9Xk9XTN5eXkKIyIiIseZww2xGPIA1oceeohly5Zx8803s27dOmbPns0FF1xAXV1dv+UfeeQRqqurk69NmzbhOA6f+MQnhvrRIiIicgIachi5/fbbufrqq1m6dCkzZsxgxYoVBINB7rvvvn7LFxUVUV5ennw9/fTTBINBhREREREBhhhGIpEIa9euZfHixb03sG0WL17M6tWrB3WPe++9l0996lNkZ2cPWCYcDtPa2pryEhERkRPTkMJIQ0MD8XicsrKylONlZWXU1NQc9vo1a9awadMmrrrqqkOWW758Ofn5+cmXZtKIiIicuEZ00bN7772XU045ZcDBrj1uvPFGWlpakq/du3ePUA1FRERkpA1pNk1JSQmO41BbW5tyvLa2lvLy8kNe29HRwYMPPsh3v/vdw36O3+/H7/cPpWoiIiJynBpSy4jP52PevHmsWrUqecx1XVatWsWiRYsOee3DDz9MOBzmM5/5zJHVVERERE5IQ15nZNmyZVx55ZXMnz+fBQsWcMcdd9DR0cHSpUsBuOKKK6ioqGD58uUp1917771ceumlFBcXD0/NRURE5IQw5DCyZMkS6uvruemm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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(1):\n",
    "    for j in range(8):\n",
    "        plt.plot(lds_loss_array[i, :, j], color=\"C{}\".format(j))\n",
    "    # break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "874a332c-29b1-46fe-bf83-12e7c8f64e28",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 50000)"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mask_array_list = []\n",
    "\n",
    "for i in my_list:\n",
    "    # print(i)\n",
    "    with open('../../data/indices/50000-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": 23,
   "id": "41ebfcfb-5789-44f0-99d0-0dddc7c6f32f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000)"
      ]
     },
     "execution_count": 23,
     "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": 24,
   "id": "46afee77-65eb-4023-8077-d11ed785d406",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjUAAAGdCAYAAADqsoKGAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABRwUlEQVR4nO3de3Qc1YEn/m9XP6WWuiW13tbTtmzZli0ZW5ZlCBis4ABJcMIEh4UDQ9hkkgECeM8eID+CyZyTmE2WLMvig0OGSTInsDbOAAsecDCyMSGWn7LxS37KlmS9n91St7q7uqp+f9xWS209LPklu/z9nFOnSt3V1bduVd361q2SZNA0TQMRERHRdU6a7AIQERERXQ4MNURERKQLDDVERESkCww1REREpAsMNURERKQLDDVERESkCww1REREpAsMNURERKQLpskuwNWiqiqampoQHx8Pg8Ew2cUhIiKicdA0Db29vcjMzIQkjd0Xc8OEmqamJmRnZ092MYiIiOgiNDQ0ICsra8x5bphQEx8fD0BUisPhmOTSEBER0Xh4PB5kZ2dHzuNjuWFCzcAtJ4fDwVBDRER0nRnPoyN8UJiIiIh0gaGGiIiIdIGhhoiIiHSBoYaIiIh0gaGGiIiIdIGhhoiIiHSBoYaIiIh0gaGGiIiIdIGhhoiIiHSBoYaIiIh0gaGGiIiIdIGhhoiIiHSBoeYSuQNuPLPtGWw4tgF1njpomjbZRboiFFW5ptZNVmWomjrZxSAiALIi4/2T72NH445rqp24mmRFhjvgvqjPdvu7r0p7pqgKTvecxkenP8KGYxtwuue07rbXDfNfuq+UvS178Vn9Z/is/jMAQLo9HYszFqMsowyLMxYjOSZ5kks4Pvta9+FPR/6Exr5GBJQAAkoAQSUIf8iPoBJESAshwZqAW7NuxR05d6A8oxyx5tgLLrfH34MufxfynHmQDJeWoXv8PdjWsA2f1n2Knc07kWBNQEVOBe7MuxM3pd4Eo2S8pOVfbe6AGzuadiDGFIPyzHJYjdZxfU5WZexs2ommvibMS5mHGYkzxr3umqbBHXDDYDDAZrLBIlnG9Z9vrxSv7MVZz1lMc06DzWS7ot8VVILY2bwT2xu2w2qy4ptTv4lZSbMmdf0nqjfYi4PtB1HdVo39bfvhD/kx1TkV0xOmY1rCNExPmI50e/pVXaedzTvxq12/whn3GQDA/NT5eHL+kyhNL71qZZhM7oAb7x5/F2/XvI1OfyfKMsrw0KyHcGvWrWO2ebIi4691f8U7Ne/gUMchpNvT8c2p38S3pn0LU51TL7lcQSWIM+4zONp5FEc7j6KmqwYnuk+gP9QfNV9abBqWZC7BkswlWJyxGAm2hGHLqffU44znDM64z6CzvxPLcpahNL30mjx2DJreYtooPB4PnE4n3G43HA7HZVtuvacen5z5BLtaduFA2wHIqhz1/vSE6ShOKUa+Mz8yZNozRzwJ+WQfGnobcK73HBp6GyCrMpZkLsFs1+wL7jyyKuPLc1/iw9MfYm/rXhQlF+G7Bd/F0qylMBvNo35uT8sevPHVG9jTsmdC6201WlGeUY7bc27HbVm3wRXjQkd/hzh4OmtQ01WDms4aNHmbAABJtiTcMuUW3JZ1G5ZkLkGcJW5c39PR34Gt9VuxpW4L9rTsgaIpI86XHJOMZTnLsDxv+YQDTl+wDyd7TuJk90m0eFtgkkwwS+bIeGDaYDCgN9iLnkAPegI9cAfckWlv0IupCVOxIG0BFqQtwBzXHFiMlmHf1eptxdaGraisq8Te1r2R9Ykzx+GOnDtwV/5dKMsog1mK3maqpmJf6z58cuYTbKnbgp5AT+Q9h8WBBWkLUJpeikXpi1CQWADJIEHTNLR4W3C08yiOdB5BTVcNjnYeRZe/K/JZAwywGq2wGC2wGW2wmWzIc+ZhXvI8zE2Zi6LkIjgsl+94GdDj78Gfa/6Md469g95gL8ySGfNS5qE0vRSlaaWYlzJvWMiRFRl1njqccp/Cqe5TqO+tR0pMCmYmzcSMxBmY6pw6rM59sg9/b/o7Pqv7DF+c+wJ9cl/U+zMSZ+A707+De6beg0Rb4mVbP0VV0Oxtxhm3OBE0e5sxI3EGbplyC1JiU8a9nBZvCw60HUB1WzWqW6txovsENIzdZNvNdkxzTkOuIxdOqxMOiwMOq0OMw9Px5nhYjBZYjBaYJBMsRkvUvj4erd5W/M+9/xObz24GACRaE+EL+RBQAgCAxRmL8dP5P8XclLnjXt/znes9h1p3LRakLYDdbL/o5YxFURWc6zuH2p5a1LprcdZzFnazHQvTFmJB2oJR94vmvmb8+9F/x3+c/I9hQQEAsuOz8eCsB3HvtHuj2ruO/g5sPLER7x5/Fx39HSMuu8hVhG9N+xbuyr9rxO/vC/ahzdeGVl8rWn2tYto7ZNrXGnWcDxVjisGspFmwGC3Y37Y/sr0A0R7Mcc3BnOQ5kf23sa9xxF6km1Jvwj+X/DMWpS+64uFmIudvhprLqD/Uj/2t+7GzeSd2Nu/Esa5jIzZAFsmCXGcu8h35sJlsaOhtQL2nHp3+zhGXmxqbituzb8fS7KVYlL4o0nBrmoZjXcfw4ekP8fGZj0fciROtifjmtG/iO9O/g4LEgsjndrfsxhtfvYF9rfsAACbJhO9M/w4qcipgM9miTnQDjd+pnlPYWr8V2xq2obGvMfIdBhiQaEsc9SCyGq1RB47JYMKCtAX4WtbXsDhjMUJaCJ39nWLwi3GXvwtNfU042HEw6oCamTgTX8/9Ou7IuQPN3mZ8evZTbG3Yit5gb2Qel82F+anzEW+JjxocFgfizHHoD/VHQszJ7pOR4HU5WY1WzE2ei5vSbkJxSjFOdp9EZX0lDnUcipqvILEAnoAHrb7WyGsJ1gR8Pffr+EbeNxBrjsXHZz7GX8/8FW39bZF5kmxJmJE4A4c6DsEre6OW6bQ6Mc05DWfcZ9Ad6L7kdcl35mNe8jzMS5mHJFsSQmoIsiojpIYQ0kJirIaQaEtEcXIxsuKzRm3k2nxt+Pcj/453T7wbORHEmGKGnRQskgXzUuZhjmsOWnwtON1zGmfdZxHSQqOW02gwIt+Zj4LEAkx1TsXxruP4svFL+BV/ZJ6UmBTckXMH3AE3KusrIxchJsmEpVlLsWL6CiyZsgSqpiKoBBFUgpBVGUElKHov1SD65X74FT/6Q/3wh8S4P9QPT9CDOk8dzrjPoM5TF7XPDzUzcSZumXILbp5yM0pSSyIBVlZkHOs6hgPtB/BV+1c40HYgar8YkBWXhZvSbsL81PlwWBw43XMap3pO4XTPadR56saso/EwSSbMds3GovRFKE0rRUlqSVSvrKzKePvo23jjqzfgC/kgGSSsnLkST8x/Av6QH28efBP/cfI/EFJFOW7Pvh2PlzyOmUkzx/X9iqrgy8YvseH4BnzZ+CU0aLAZbbgj5w58a9q3sDhj8biD1/lCagiHOw5jV/MunOg+gVp3Leo8dcMuRoeanjBdhO30UixIW4B2Xzv+cOQP2Hxmc+SiZEbiDPzjnH9ESUoJNp7ciL+c+EukTbKb7fjO9O/ga1O+hv8885/45Mwnke9LiUnBypkrce/0e3Gw/SA+Ov0Rvmz8MrINTQYTbplyCxxWRySwtPnahh3zo4k3x2OWaxZmJc0SY9cs5MbnRi76/CE/qlursaNpB/7e9Hec6jk14nLizHGRi3LJIOE/a/8zsg43pd6En5T8BGXpZVcs3DDUjOBqhJrz9fh7sKd1D453HRdXbJ4zqHPXIagGR/2Mw+JAdnw2suOzIasydjTtiGrw7WY7bs68GdMTp2NL3Rac7D4Zec9lc+GbU7+JW7NuxY6mHfjw9Ido72+PvF/kKsLyvOXY1rAN1W3VAACzZMZ3C76Lx4oeQ0ZcxrjWS9M0nOg+ga0NW7GtfhtqumoAiHCT78yPHESzXbNRmFQIm8mG/a378cW5L7D93Hac9ZydSDVijmsOvp77dXw99+vIceQMe19WZOxs3olP6z7F1vqt8AQ9E1o+IIJjQWIBsuOyoUGLnLRlRY5MK5oCh9UBp8WJBGsCnFYxTrAmwGqyoqazBvta96G6rXrUgGeAAcUpxajIrcAdOXcgOz4bqqbiQNsBfHLmE3xa9+mon403x6MitwJ35d+F0vRSmCQTQmoINZ012N2yG3ta96C6tTpqfzEZTJiWMA2zXbMjw4zEGTAajAgoAfgVv7jdGBK3HPvkPpzoPoGv2r/CofZDONd3bsJ1mWRLQnFKMYpTilGSWoI5rjno6O/AHw7/Ae+fej/SGM5KmoX/Ove/YlnOMpzrO4c9LXsiw9D9dii72Y5pCdNQkFCAHEcO2nxtON51HCe6T4y63afETUFFTgUqciswL2Ve5JaAO+DGx2c+xgenPsDRzqMTXs8LMUtm5Dpyke/MR2psKr5q+wpHOo9EXejYzXaUppfCHXDjaOfRYUHIaDBiRuKMSIiZnzofqbGpo37n0N6sxt5GeIIeMQQ8UdN9cl8krI11QgfEPlSUXITS9FLkO/Px1qG3cNp9GgBQnFKM/6/s/8Ms16yoz5zrPYc3vnoDm2o3QdVUGGBAeWY5ipKLMCtpFmYmzURWXHT47ezvxPun3sfG4xujLjRSY1PR5hsM9Mkxybg7/258a9q3MDNx5gVPpOd6z2FH0w5UNVVhV/Mu9Mq9w+axGq3Ic+RhqnMq8p356PJ3YW/r3lFP8gPKMsrwgzk/QHlmeVQ5fLIPm2o34c81f47clhtqXso8PFj4IL6e+/VhPemd/Z3YfHYzPjz94Zj7Zbw5HqmxqUizpyEtNi1qemBwWp0TChptvjZUNVXhtPs0suKyIkHGZXNFLafV24p/O/xv+MuJv0TOZ/NT5+MnxT/B4ozFlz3cMNSMYDJCzUgUVUGTtynSLR1UgpEQkxWfBafVGTV/QAlgV/MubGvYhs8bPh/WXWmWzLg9+3bcO/1eLMlcEnUFE1JD2NG0A++dfA/bG7ZHXcFZJAvum3EfflD0A6Tb0y9pnVq8LWj3tWNawrRxPWfT4GnAF41fYHvDdhzsOAi72Q6XzYWkmCS4bC4xxLiQZEvCTWk3YUrclHGXRVZk7GnZg/reevQGe8Ug9w5OB3thkkyYnjAdBYkFKEgoQEFiwbB6vxSapuGM5wyqW6uxr3UfDnccRmZcJpblLMMdOXeM+ZxVSA1hT8sebD67GVvqtiCkhrA0aynuyr8LN0+5ecRbWlHrr8o42nkUZ91nMdU5FTOSZoz7WZ2RdPm7cKj9EA52HMSRjiPwyl6YJFPUYJbMMBqMaPI2oaazZthJ0mQwQYMWuaqdnzofP5z7Q9wy5ZYRGz9N01DfW489LXtwovsEMu2ZIsgkFiAtNm3Uz7T6WnGi+4S4Au+pRbo9HRW5FeN6buZE9wl8cOoD/Gftfw4LlSbJBItkifRYxppiYTPZEGOKgc0YHptssJvtkRCT78hHZtzw28xd/i5xVdz4d+xo2jHsuxKsCcMC4XiOqUuhaRpC2mCAdwfcqG6rjgTMZm/zsM8kWhPxzIJncO/0e8d8bqS2pxZrD6zFp3WfDnsvzhyHmUkzMStpFjr9nZH9HRC9jSumrcD3Zn4POfE5ONxxGB/VfoRPznwSdes135mP1JhUmIxDtpFkgdlohqqp2N+2H3WeuqjvdVgcWJyxGPNS5iHfmY+pzqnIjMsccT26/F3Y17ovUhenek5BMkhYnrsc/1j0j5jtmj1m3aqaiqqmKvy55s841HEIN2fejIdmPTTuW3Kne06jsr4SkkGKBJfU2FSkxaZd8f1iPNp8bfi3w/+Gjcc3RsLNovRF+P2dv7/kZyiHYqgZwbUSai6Fqqk43HEYnzd8jlp3LZZkLsHyvOXjOiF39ndiU+0m/O3c31CQWIB/nPOPSLOnXflC00VTVAUatIvuap8MASWAms6ayO2Tr9q/ivS6LMlcgh/O/SEWpi+c5FKOLqSG4Al6YJbMkedMLmfjPJSqqajprMGelj3i1l1KMXIdudfUw5eapqGxrzFyUq/pqkFpeikeL3l8QhcCp7pPYXfLbhzrOoZjXcdwqufUiD1E85Ln4f6Z92N53vIRHxyXFRlfNn6Jj2o/wucNn1+wlwkQoXpeyrzIw7CzXbMv+pcKuv3idu7lfP5KD9p8bfjD4T9g44mNWDF9BV5Y/MJlXT5DzQj0EGqIrjeapqHZ2wxFVZDtyJ7s4tA1QlZk1LprIyEHAL457ZuY45oz7mW4A+7I7dagOvjsU+SWsRZCYWIhStNLx/2LCXRp2n3tkAwSXDGuy7pchpoRMNQQERFdfyZy/uYf3yMiIiJdYKghIiIiXWCoISIiIl1gqCEiIiJduKhQs3btWuTl5cFms6GsrAy7d+8ec/6NGzeisLAQNpsNc+fOxccffxz1/ksvvYTCwkLY7XYkJiaioqICu3btiponLy8PBoMhanj55ZcvpvhERESkQxMONRs2bMCqVauwevVqVFdXo7i4GMuXL0dbW9uI8+/YsQMPPPAAHnvsMezfvx8rVqzAihUrcPjw4cg8M2bMwOuvv45Dhw7hyy+/RF5eHu688060t0f/VdF/+Zd/QXNzc2R48sknJ1p8IiIi0qkJ/0p3WVkZSktL8frrrwMAVFVFdnY2nnzySTz33HPD5l+5ciW8Xi82bdoUeW3x4sUoKSnBunXrRvyOgV/f+uyzz7Bs2TIAoqfm6aefxtNPPz2R4g5bJn+lm4iI6PpxxX6lOxgMYt++faioqBhcgCShoqICVVVVI36mqqoqan4AWL58+ajzB4NBvPnmm3A6nSguLo567+WXX4bL5cL8+fPxm9/8BqHQ6P+4LRAIwOPxRA1ERESkXxP6++sdHR1QFAVpadF/Xj8tLQ3Hjh0b8TMtLS0jzt/S0hL12qZNm/D9738fPp8PGRkZ2LJlC5KTB/9Hzk9/+lPcdNNNSEpKwo4dO/D888+jubkZv/3tb0f83jVr1uAXv/jFRFaPiIiIrmPXzD+Vuf3223HgwAF0dHTg97//Pe6//37s2rULqaniP9KuWrUqMu+8efNgsVjwT//0T1izZg2s1uH/sO/555+P+ozH40F2Nv9MOxERkV5N6PZTcnIyjEYjWltbo15vbW1FevrI/+k5PT19XPPb7XZMnz4dixcvxltvvQWTyYS33npr1LKUlZUhFArh7NmzI75vtVrhcDiiBiIiItKvCYUai8WCBQsWoLKyMvKaqqqorKxEeXn5iJ8pLy+Pmh8AtmzZMur8Q5cbCARGff/AgQOQJCnSk0NEREQ3tgnfflq1ahUeeeQRLFy4EIsWLcKrr74Kr9eLRx99FADw8MMPY8qUKVizZg0A4KmnnsJtt92GV155Bffccw/Wr1+PvXv34s033wQAeL1e/PKXv8S3v/1tZGRkoKOjA2vXrkVjYyO+973vARAPG+/atQu333474uPjUVVVhWeeeQYPPfQQEhP5L+CJiIjoIkLNypUr0d7ejhdffBEtLS0oKSnB5s2bIw8D19fXQ5IGO4CWLFmCd955By+88AJ+9rOfoaCgAB988AGKiooAAEajEceOHcOf/vQndHR0wOVyobS0FH/7298wZ474N/RWqxXr16/HSy+9hEAggPz8fDzzzDNRz8wQERHRjW3Cf6fmesW/U0NERHT9uWJ/p4aIiIjoWsVQQ0RERLrAUENERES6wFBDREREusBQQ0RERLrAUENERES6wFBDREREusBQQ0RERLrAUENERES6wFBDREREusBQQ0RERLrAUENERES6wFBDREREusBQQ0RERLrAUENERES6wFBDREREusBQQ0RERLrAUENERES6wFBDREREusBQQ0RERLrAUENERES6wFBDREREusBQQ0RERLrAUENERES6wFBDREREusBQQ0RERLrAUENERES6wFBDREREusBQQ0RERLrAUENERES6wFBDREREusBQQ0RERLrAUENERES6wFBDREREusBQQ0RERLrAUENERES6wFBDREREusBQQ0RERLrAUENERES6wFBDREREusBQQ0RERLrAUENERES6wFBDREREusBQQ0RERLrAUENERES6wFBDREREusBQQ0RERLpgmuwC0PVN6fNCbmqE5vfDlJYGU3IyDEbjZBfrqlP7+wEABqsVBunGu1ZQ/X5AkiBZLJNdFCK6gTHUXCK5rQ0NP/wR7IvLEFu2GLGlC2GMj5/sYgEANE0DZBlqUIYmB6EFZWjBAJSuLoQ6OhBq70CovT08LcYwAMa4eEjx8TDGx0GKi4cUHwdjvANaMAC5sQlyc7MYmpqgejzRX2oywZSaAnN6Bszp6TBnZsCUkQFLbh4sebkwZ2Rc9tCjaRrU3l7ITU2Qm5ohNzfB6HAgtqwM5tTUy/pdQwVqz6C38jP0fVaJ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iHr95Zdfhsvlwvz58/Gb3/wGoVBo1GUEAgF4PJ6ogYiIiPTLNJGZOzo6oCgK0tLSol5PS0vDsWPHRvxMS0vLiPO3tLSMOL/f78ezzz6LBx54ICqR/fSnP8VNN92EpKQk7NixA88//zyam5vx29/+dsTlrFmzBr/4xS8msnpERER0HZtQqLnSZFnG/fffD03T8MYbb0S9t2rVqsj0vHnzYLFY8E//9E9Ys2YNrFbrsGU9//zzUZ/xeDzIzs6+coUnIiKiSTWhUJOcnAyj0YjW1tao11tbW5Genj7iZ9LT08c1/0Cgqaurw9atWy9436ysrAyhUAhnz57FzJkzh71vtVpHDDtERESkTxN6psZisWDBggWorKyMvKaqKiorK1FeXj7iZ8rLy6PmB4AtW7ZEzT8QaE6ePInPPvsMLpfrgmU5cOAAJElCamrqRFaBiIiIdGrCt59WrVqFRx55BAsXLsSiRYvw6quvwuv14tFHHwUAPPzww5gyZQrWrFkDAHjqqadw22234ZVXXsE999yD9evXY+/evXjzzTcBiEDzD//wD6iursamTZugKErkeZukpCRYLBZUVVVh165duP322xEfH4+qqio888wzeOihh5CYmHi56oKIiIiuYxMONStXrkR7eztefPFFtLS0oKSkBJs3b448DFxfXw9JGuwAWrJkCd555x288MIL+NnPfoaCggJ88MEHKCoqAgA0Njbiww8/BACUlJREfde2bduwdOlSWK1WrF+/Hi+99BICgQDy8/PxzDPPRD0zQ0RERDe2Cf+dmusV/04NERHR9eeK/Z0aIiIiomsVQw0RERHpAkMNERER6QJDDREREekCQw0RERHpAkMNERER6QJDDREREekCQw0RERHpAkMNERER6QJDDREREekCQw0RERHpAkMNERER6QJDDREREekCQw0RERHpAkMNERER6QJDDREREekCQw0RERHpAkMNERER6QJDDREREekCQw0RERHpAkMNERER6QJDDREREekCQw0RERHpAkMNERER6QJDDREREekCQw0RERHpAkMNERER6QJDDREREekCQw0RERHpAkMNERER6QJDDREREekCQw0RERHpAkMNERER6QJDDREREekCQw0RERHpAkMNERER6QJDDREREekCQw0RERHpAkMNERER6QJDDREREekCQw0RERHpAkMNERER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KCjABx98gKKiosg8H374YSQUAcD3v/99AMDq1avx0ksvwWKx4LPPPosEqOzsbNx333144YUXLnrFiYiISF8m/Hdqrlf8OzVERETXnyv2d2qIiIiIrlUMNURERKQLDDVERESkCww1REREpAsMNURERKQLDDVERESkCww1REREpAsMNURERKQLDDVERESkCww1REREpAsMNURERKQLDDVERESkCww1REREpAsMNURERKQLDDVERESkCww1REREpAsMNURERKQLDDVERESkCww1REREpAsMNURERKQLDDVERESkCww1REREpAsMNURERKQLDDVERESkCww1REREpAsMNURERKQLDDVERESkCww1REREpAsMNURERKQLDDVERESkCww1REREpAsMNURERKQLDDVERESkCww1REREpAsMNURERKQLDDVERESkCww1REREpAsMNURERKQLDDVERESkCww1NGk0TUMgpEx2MQCIsvhlBb1+GZqmTXZxiIjoIpgmuwDXu46+AL5q6EFfIASPP4Q+fwi9fhl9gRB6/WKwmSVMSYhBZkJM1NgRY4LBYICmafD4Q+j2BtHlC4qxN4i+QAiKqolB06CqGhQVUMInXYfNBGeMeXCIHZy2mowwSoYLll9RNfiCIfTLCvqDImBYTBIsRgnm8NhilCBJopyyoqFfVuAPz+8PhceyipCqIqRoCCpiHFJVBEMq/LKC9r4gOvoCaO8dHDr6AgiEVKQ5rJiRFo8ZafGYmRaPGenxKEiNg906uHsGQyrc/TLc/cHwWIY3IMrhD6nwBwemFfQHVciKCkXToGnh+lMBNTwdCCmRbePxy+FpGbIi6tVilOCKs8AVZ0FynBUuuxXJ8RYkxVpgNUkwGSWYjQaYjeFpyQCjZEBfIBQpW2TwyfD4ZVhMEuKtZsTbTHDEiHG8zQyHTewD/bICf1CBL6hE1a8GDTFmI2IsJsRajOFpMbaaJRggtrEhvKkHtriqAYHQwLLENhgYgiEVMRYTHDGDZXDYzJGfB9bRJBnEEF5fkyTBGwihM7x/dnkDYroviM7w/hoIqQjIihiHxHcFwkNIURFStci+ISsaQooKg8GAJLsFyXEWpMRbkRwXHuKtSIq1QIM24n6lqBqMkgEWkwSzUQxi3xXbxm4V6+WMFesYZxV1PcAbCKG+y4f6Lh8awuP6Lh+6fTIQPsYG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5aj6KSwsRE5Ozg1XP4qiYP369fB6vSgvL2fdhD3++OO45557ouoB4L4DACdPnkRmZiamTp2KBx98EPX19QBYNx9++CEWLlyI733ve0hNTcX8+fPx+9//PvK+XttlhpqL1NHRAUVRkJaWFvV6WloaWlpaJqlU16aB+mBdif8W//TTT+Pmm29GUVERAFE/FosFCQkJUfPeSPVz6NAhxMXFwWq14sc//jHef/99zJ49m3UDYP369aiursaaNWuGvXej109ZWRn++Mc/YvPmzXjjjTdw5swZfO1rX0Nvb+8NXze1tbV44403UFBQgL/+9a/4yU9+gp/+9Kf405/+BEC/7fIN81+6ia4Fjz/+OA4fPhx135+AmTNn4sCBA3C73fjLX/6CRx55BNu3b5/sYk26hoYGPPXUU9iyZQtsNttkF+eac9ddd0Wm582bh7KyMuTm5uLdd99FTEzMJJZs8qmqioULF+JXv/oVAGD+/Pk4fPgw1q1bh0ceeWSSS3flsKfmIiUnJ8NoNA57kr61tRXp6emTVKpr00B93Oh19cQTT2DTpk3Ytm0bsrKyIq+np6cjGAyip6cnav4bqX4sFgumT5+OBQsWYM2aNSguLsb//t//+4avm3379qGtrQ033XQTTCYTTCYTtm/fjtdeew0mkwlpaWk3dP2cLyEhATNmzMCpU6du+H0nIyMDs2fPjnpt1qxZkdtzem2XGWouksViwYIFC1BZWRl5TVVVVFZWory8fBJLdu3Jz89Henp6VF15PB7s2rXrhqgrTdPwxBNP4P3338fWrVuRn58f9f6CBQtgNpuj6uf48eOor6+/IepnJKqqIhAI3PB1s2zZMhw6dAgHDhyIDAsXLsSDDz4Ymb6R6+d8fX19OH36NDIyMm74fefmm28e9qcjTpw4gdzcXAA6bpcn+0nl69n69es1q9Wq/fGPf9SOHj2q/ehHP9ISEhK0lpaWyS7aVdfb26vt379f279/vwZA++1vf6vt379fq6ur0zRN015++WUtISFB+3//7/9pBw8e1O69914tPz9f6+/vn+SSX3k/+clPNKfTqX3++edac3NzZPD5fJF5fvzjH2s5OTna1q1btb1792rl5eVaeXn5JJb66nnuuee07du3a2fOnNEOHjyoPffcc5rBYNA+/fRTTdNu7LoZydDfftK0G7t+/tt/+2/a559/rp05c0b7+9//rlVUVGjJyclaW1ubpmk3dt3s3r1bM5lM2i9/+Uvt5MmT2ttvv63FxsZqf/7znyPz6LFdZqi5RP/n//wfLScnR7NYLNqiRYu0nTt3TnaRJsW2bds0AMOGRx55RNM08euDP//5z7W0tDTNarVqy5Yt044fPz65hb5KRqoXANof/vCHyDz9/f3aP//zP2uJiYlabGys9p3vfEdrbm6evEJfRT/4wQ+03NxczWKxaCkpKdqyZcsigUbTbuy6Gcn5oeZGrp+VK1dqGRkZmsVi0aZMmaKtXLlSO3XqVOT9G7luNE3TPvroI62oqEizWq1aYWGh9uabb0a9r8d22aBpmjY5fURERERElw+fqSEiIiJdYKghIiIiXWCoISIiIl1gqCEiIiJdYKghIiIiXWCoISIiIl1gqCEiIiJdYKghIiIiXWCoISIiIl1gqCEiIiJdYKghIiIiXWCoISIiIl34/wGpTrscj/XE8wAAAABJRU5ErkJggg==",
      "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": 25,
   "id": "649a172c-968c-4aa3-b086-b32d64d22424",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "27"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from scipy.stats import spearmanr, pearsonr\n",
    "\n",
    "lamb_list = [\n",
    "        # 0,\n",
    "\n",
    "        1e-2, 2e-2, 5e-2,\n",
    "        1e-1, 2e-1, 5e-1,\n",
    "        1e0, 2e0, 5e0,\n",
    "        1e1, 2e1, 5e1,\n",
    "        1e2, 2e2, 5e2,\n",
    "        1e3, 2e3, 5e3, \n",
    "        1e4, 2e4, 5e4, \n",
    "        1e5, 2e5, 5e5, \n",
    "        1e6, 2e6, 5e6, \n",
    "    \n",
    "        # 1e7, 2e7, 5e7,\n",
    "        # 1e8, 2e8, 5e8,\n",
    "        # 1e9, 2e9, 5e9,\n",
    "        # 1e10, 2e10, 5e10, \n",
    "        # 1e11, 2e11, 5e11,\n",
    "        # 1e12\n",
    "    ]\n",
    "\n",
    "len(lamb_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "effb0646-37be-44c2-8b2e-7bf3c67ea049",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(50000, 65536)\n",
      "(50000, 32768)\n",
      "(1000, 65536)\n",
      "(1000, 32768)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_2851/4092791890.py:34: UserWarning: The given NumPy array is not writable, and PyTorch does not support non-writable tensors. This means writing to this tensor will result in undefined behavior. You may want to copy the array to protect its data or make it writable before converting it to a tensor. This type of warning will be suppressed for the rest of this program. (Triggered internally at ../torch/csrc/utils/tensor_numpy.cpp:206.)\n",
      "  gen_dstore_keys = torch.from_numpy(gen_dstore_keys).cuda()\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0022, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.004 (avg p value 0.516278)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0023, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.002 (avg p value 0.523106)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0023, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.003 (avg p value 0.518931)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0021, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.002 (avg p value 0.509864)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.001 (avg p value 0.505405)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.006 (avg p value 0.501332)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0024, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.008 (avg p value 0.494977)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0021, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.008 (avg p value 0.499843)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0022, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.006 (avg p value 0.509612)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.004 (avg p value 0.495085)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0004, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.003 (avg p value 0.493676)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.001 (avg p value 0.507241)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.004 (avg p value 0.506138)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0015, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.002 (avg p value 0.511752)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0012, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.003 (avg p value 0.493348)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0008, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.005 (avg p value 0.501482)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0004, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.121 (avg p value 0.368703)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.148 (avg p value 0.320247)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.3549e-05, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.146 (avg p value 0.324495)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.7904e-05, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.140 (avg p value 0.337164)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9537e-05, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.127 (avg p value 0.366534)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8532e-06, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.116 (avg p value 0.382159)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9534e-06, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.105 (avg p value 0.397143)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9897e-06, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.092 (avg p value 0.415285)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9674e-07, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.083 (avg p value 0.425375)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9896e-07, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.074 (avg p value 0.436898)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9977e-07, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.062 (avg p value 0.453465)\n",
      "(50000, 65536)\n",
      "(50000, 32768)\n",
      "(1000, 65536)\n",
      "(1000, 32768)\n",
      "0.01\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0133, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.003 (avg p value 0.505183)\n",
      "0.02\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0036, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.001 (avg p value 0.517051)\n",
      "0.05\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0026, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.005 (avg p value 0.501664)\n",
      "0.1\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0032, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.000 (avg p value 0.491227)\n",
      "0.2\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0006, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.005 (avg p value 0.509457)\n",
      "0.5\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0029, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.004 (avg p value 0.507035)\n",
      "1.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0030, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.003 (avg p value 0.492933)\n",
      "2.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0034, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.001 (avg p value 0.490174)\n",
      "5.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0031, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.002 (avg p value 0.500268)\n",
      "10.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0051, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.000 (avg p value 0.496059)\n",
      "20.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0032, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.002 (avg p value 0.502524)\n",
      "50.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.004 (avg p value 0.500955)\n",
      "100.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0029, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: -0.000 (avg p value 0.493354)\n",
      "200.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.003 (avg p value 0.504410)\n",
      "500.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0017, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.011 (avg p value 0.502205)\n",
      "1000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.014 (avg p value 0.492718)\n",
      "2000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.083 (avg p value 0.423593)\n",
      "5000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.208 (avg p value 0.235824)\n",
      "10000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.7221e-05, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.192 (avg p value 0.257908)\n",
      "20000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9042e-05, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.176 (avg p value 0.279403)\n",
      "50000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9779e-05, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.156 (avg p value 0.311763)\n",
      "100000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9282e-06, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.142 (avg p value 0.337667)\n",
      "200000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9767e-06, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.128 (avg p value 0.361464)\n",
      "500000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9947e-06, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.108 (avg p value 0.386977)\n",
      "1000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9823e-07, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.094 (avg p value 0.404236)\n",
      "2000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9940e-07, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.080 (avg p value 0.416632)\n",
      "5000000.0\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9985e-07, device='cuda:0')\n",
      "torch.Size([1000, 50000])\n",
      "Correlation: 0.066 (avg p value 0.434831)\n"
     ]
    }
   ],
   "source": [
    "# for loop over functions\n",
    "lds_list = []\n",
    "for K in [\n",
    "    10, \n",
    "    100, \n",
    "          # 1000\n",
    "         ]:\n",
    "    ####\n",
    "    ####\n",
    "    dstore_keys_list = []\n",
    "    for split in range(5):\n",
    "        dstore_keys = np.memmap('{}/features-0/ddpm-train-keys-{}-{}-{}-{}-{}.npy'.format(\n",
    "            args.output_dir, split, K, args.Z, 'mean-squared-l2-norm', args.t_strategy), \n",
    "                                dtype=np.float32, \n",
    "                                mode='r',\n",
    "                                shape=(10000, args.Z))\n",
    "        dstore_keys_list.append(dstore_keys) \n",
    "        \n",
    "    dstore_keys = np.vstack(dstore_keys_list)\n",
    "    print(dstore_keys.shape)  \n",
    "    dstore_keys = dstore_keys[:, :args.used_dim]\n",
    "    print(dstore_keys.shape)\n",
    "    ####        \n",
    "    gen_dstore_keys = np.memmap('{}/features-0/ddpm-val-keys-{}-{}-{}-{}-{}.npy'.format(\n",
    "                args.output_dir, 0, K, args.Z, 'mean-squared-l2-norm', args.t_strategy), \n",
    "                                dtype=np.float32, \n",
    "                                mode='r',\n",
    "                                shape=(1000, args.Z))\n",
    "    print(gen_dstore_keys.shape)    \n",
    "    gen_dstore_keys = gen_dstore_keys[:, :args.used_dim]\n",
    "    print(gen_dstore_keys.shape)\n",
    "    ####\n",
    "    dstore_keys = torch.from_numpy(dstore_keys).cuda()\n",
    "    gen_dstore_keys = torch.from_numpy(gen_dstore_keys).cuda()\n",
    "    # dstore_keys = torch.from_numpy(dstore_keys).cuda() * 1000\n",
    "    # gen_dstore_keys = torch.from_numpy(gen_dstore_keys).cuda() * 1000\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",
    "\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",
    "    with open('./val_5000_0.5_{}_{}_{}_{}.pkl'.format('mean-squared-l2-norm', K, lamb, best_lds), 'wb') as handle:\n",
    "        pickle.dump(best_scores, handle)\n",
    "            \n",
    "    lds_list.append((rs_list, ps_list))\n",
    "\n",
    "    # break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c3380ec5-8479-45b3-81c8-78d83cb98f3d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "47e17534-05f6-4f8d-a9b8-7ea2c69258fb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "c08ec20a-9e82-4f58-b342-95145208f5b3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[ 0.0039144 , -0.0022227 , -0.00296247, -0.00161288,  0.00141736,\n",
       "         0.00585948,  0.00790343,  0.00769851,  0.00553519, -0.00373208,\n",
       "         0.00334958,  0.00091825,  0.00365082,  0.00165827, -0.00325402,\n",
       "         0.00475002,  0.12096876,  0.14821658,  0.14642919,  0.14027075,\n",
       "         0.12722439,  0.11588195,  0.10452251,  0.09224962,  0.08343766,\n",
       "         0.07447392,  0.06232806],\n",
       "       [ 0.516278  ,  0.52310614,  0.51893121,  0.50986363,  0.50540477,\n",
       "         0.50133203,  0.49497737,  0.49984343,  0.50961233,  0.4950846 ,\n",
       "         0.49367607,  0.5072409 ,  0.50613781,  0.51175162,  0.49334788,\n",
       "         0.50148213,  0.36870279,  0.32024732,  0.32449526,  0.33716379,\n",
       "         0.36653367,  0.38215924,  0.39714346,  0.41528465,  0.42537529,\n",
       "         0.43689805,  0.45346529]])"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "lds_array = np.array(lds_list)\n",
    "lds_array[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "c7d99b73-0b7e-4685-af5e-20038c48751d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(2, 2, 27)"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "lds_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "96d742ec-8738-4383-ad58-23fdeeed79cc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "f8f258c4-267e-41cb-9a6b-f6711f79318b",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('./val_5000_0.5_{}.pkl'.format('mean-squared-l2-norm'), 'wb') as handle:\n",
    "    pickle.dump(lds_array, handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6782edc7-1d3e-45f9-abb1-2a8ca3a347da",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "8122043b-7cc0-4d50-a1a5-98e6eed9a4ed",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.14821658, 0.2076415 ])"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "lds_array[:, 0].max(axis=-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "80995dab-f837-4566-9ea9-ccb5b1c5b0fd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for k in range(lds_array.shape[0]):\n",
    "    plt.plot(lds_array[k, 0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "58582fc9-190f-42c7-a62c-1f7b2111d74a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9bb0b736-25aa-4368-a617-ba6efa313cd1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "48b22ec8-2d00-497b-8992-7442d7626802",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "381858e5-e107-480e-a471-60097744cdb7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d86133a7-5da3-4beb-8b47-d599bfce3150",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8d2709ed-3499-4651-98eb-0cf583cff5b2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ffcf2bce-eecd-419b-94d9-7fb8d6475cf4",
   "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
}
