{
 "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\"]='3'\n",
    "\n",
    "os.environ[\"HF_HOME\"]=\"~/codes/.cache/huggingface\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "2f7cd96b-ca27-4ce1-ac2d-c3dd67e069b7",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import random\n",
    "import numpy as np\n",
    "\n",
    "def set_seeds(seed):\n",
    "    random.seed(seed)\n",
    "    np.random.seed(seed)\n",
    "    torch.manual_seed(seed)\n",
    "    torch.backends.cudnn.deterministic = True\n",
    "    torch.backends.cudnn.benchmark = False\n",
    "    \n",
    "set_seeds(42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "4ff495b8-8df0-49e8-a409-4ed9601c8143",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "def show_images(images, scores, test_artist, train_artists):\n",
    "    n: int = len(images)\n",
    "    f = plt.figure(figsize=(16, 2))\n",
    "    for i in range(n):\n",
    "        # Debug, plot figure\n",
    "        ax = f.add_subplot(1, n, i + 1)\n",
    "        if i==0:\n",
    "            pass\n",
    "            ax.title.set_text(test_artist)\n",
    "        else:\n",
    "            ax.title.set_text(str(np.round(scores[i-1], 4))+'\\n'+train_artists[i-1])\n",
    "            ax.axis('off')\n",
    "        if images[i]==None:\n",
    "            pass\n",
    "        else:\n",
    "            plt.imshow(images[i])\n",
    "\n",
    "    plt.show(block=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "c4e89a09-d6ff-46a1-8a9e-9c6f9c167114",
   "metadata": {},
   "outputs": [],
   "source": [
    "from datasets import load_dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2682e2c4-9275-4bae-a732-74b981a358d2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "fb2dc562-293c-4e74-8e97-141fc7465938",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "bda41875-8976-4852-823a-91dc1f42aebf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5000"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open('../../data/indices/5000-0.5/idx-train.pkl', 'rb')  as handle:\n",
    "    idx_train = pickle.load(handle)\n",
    "len(idx_train)   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 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/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": "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": "iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAIAAAD8GO2jAAAJJElEQVR4nC3VSXNc13XA8XPOHd597/WAbhADCUEUR5GWEVdUkcyykkqqksomLn/ULLxwlbNQKSmnotgmTZEwB5kgZjTQaPTcb7r3npOF8wX+y98fR5NV5BiZyzoopZWiEGOQoDggcx2RCYsqRtBAAhGL0h9eXBY+rvd7Wpnh9WS+LNa3e2udfDZZTObVfBmKAKyVSKTo8fdvzxRR4/2iqJTW1lpEVCQKWRhXdRwtqtm8ZhaGyA0bl62aEAQi1wggYJoQBdkq0FoHprKIRRM9A6E4Y/S702sRFpYmMimltSFCq0QRCaiyiatGfKToGVGQPPMSDRlSFlxR1PPFHFA55xAQBULwkT0AcGRCjIQ6mpxjZBJMFJKKAEE4cOTALOAbCbFiBgABiVpJYjBw8LHiYBKktlOLZcESTObEBw3YSsmwUg0rQK2VriIyIwByAJYAACCCwt5HEFYSSKpWmrdbPZEYylgsl0eHx6PrKyJU2ljnUClJUmV6WmurlEcRBY2Cpq7qgLryUWIUEAaIIgCAACAiQsQRQp3lLs86Z+fXZ+eDkw/Hw/MLXxedliurpY+x0+0oo6umIuZ2q7O+uZO2W7q1lqytK5MRgg4hCDOIyP+HWZAECFgg+I6z7Vbn9GJyM6nKRp1fXqx1k81bWxKbo8MKmHZ2P9OJGU/Gg7PT1fVkXkDwsWB8sPe3nX6vqgoSRmAgFoyCEhAYRIkoitWtzGz2+9OiLIB99Kc/vlMEmNtkY20apRZiVpfD0aqpbbsvpu3FdNY37j59kHftxx/3z4+OpjcT7YxiBhCFDIDEAAJGQpMb6vfak6Ke1pERT44PptdDDVRPynm6urlcSDDiZToq0VYe6mLlleByMVu/3d5Yb58cD9su2XnykEZnB4rrdqa6GSdQ91KdqzKpp7fXOlUTxlVY1nh8cHT0/r1SlikX7K4qx9DFxMVEReuWQeomOp057Zpi2SyL3GSpcVdXowhKf//tb3prrbX1tf56CqAfPnqy0W+LTTnUJ4ObD9fFxeX4+NX3aagXvorZmiM3n87IGqtRKZXkDomUdvl6B2O9rG+OT4aJTpCS8Wg2Ox9pLEZb27ajSw32/uOn9+7fd5mtK1wuuT3n6seb9y/3k7pyCew+vlciTYtCW5caHRbJaFzNZzNKkpLKWDaxLippyCSJrowhQt0pb/RXew/v39359MGTpP9oWcPZ6UywnjfF69fvXr88GAzmDKytGwwH19NXrfXdybISAQXMzEIJaos1iqoxLoIEcj0wuVLe6sZymVc/6q1+vnX30UJvvXhxsioXaZ4eHg5/ePt6Nl9IUEprpUwpjfR2AvPMW047SMKxWM7P0pxUYkBYN6WvLmazVb7dszYr5qc3w3fN9ORO1dZEMpjz9z984KJ8dL87XV7+8dWfmkqjZBEjKgAynhyZjuXKl2OpfFUtq8VQpmc1IpOWGEMg3wyV67Y3fqogRL8Yn7zB+up8sK1vGjd48XJRu3/+x1/cu9v7cHZF9l29qLEeczVFnaS37lSz0fjykMtpU06Ea43BoE+AfGBhJkIBAGm0mOr6h8WA+23dzYLoZFxE3URaFavdnU9ub98WoYuLsggacLUan82vDkG7Tj0rJgOcX7UtiBGtdWp1ajPSSVE1vmlIkYiUdTNZrmblG0QZjMjwgmOYzRfaiu+0W4PR9b//+j+syQ7OJyEqaRZcT7Y3202A+fBjrrnVcyjMQiJRQljWTR0WkRlAYhQS6xLXyxLRrtVtj8Y3UIMoypzVVuvtW63T/UOmpaK16LHfNlfnV70W/vTJ48D4/PlzzU1VlquyjBFERESiiCADAvwV8hDqpnCpffrFg88e3Hv/4cPR+x+C95lV+mJw2YQGV/Nb25/l7czcrMbTm7C6+uJnD7udtN3pzabjVy9fiHANRhSLMAOKEIOICCICoNaqjo1z9sHTRzt37ojCweEbFL61vq73X7+yKrbaa7wYng4G+2//UpazTEOv39vdvW1tqt4feCQGitYIBGFGpMQmSZIiKY4REDXhaj7WWSo26d++8/LPb7LU5Yn54slTvb3eGgwGo+tZfzPMy5LriQ61tvmirDbu7J6dXjQxJllGpLJuHxRJCE1VR9/8ddKhaULwLCH62mVb3d6GSlv3Hj9R5eSTjf7XX/9c//Jf/+nXv/1ucTyezavalxwaEkqSdHvnU5XkWbf3+ZPP//Juv66KaeDac/RBCWsQkSawBxGttVJEIFZZrdLZqr6ZLp49e/bV3tMs7+i/+/JvNnd2//t/97/99n+aWpy2PjYxNPPSj8o4XJQHR2epdp1ckbVkM610nqYEMhwe19Xi2bOvvvnFMw7yh+ev/vT246v91/nldpiPH/7Dz1zWapqgT84vbmaL9V6+vd0dvznf3dleX+8fHB9//HgwqWNdLr2v//6bnzuMy6pA42Lkpm5ms2mep58/uvv4wb1eJ++21/prvePzy5vrQavX3+61E62quopB8Ff/9i9Xw+vpdDFfLEhRYp1ziY/Q3338yf2neZo8//7bZnZtUBpmAQQGQCzLYnw9Yu+7nezupztfffnl3t7ei9dvf/fH/d17D7/ee/TNl18YY5VK9HQVypqZAQHK5XLmJ0RojKOktbPz6en5yeDkCH2ptfaABIAAhMgszmU6BWPVzc3su+/+6/3bt61Od3ejvXf/9k/ufxLqUljSLNGt7mYIqMgSWWsy7wNzFAnT6+EffvefKNh2uUpTRAKdaAQEVkopIuBAKKlLWnl2e+vW3k8+397adHlbEWlkrZUy2hij2+1bGpMynVV56X1gZuYI0JDSxjoEZN+IhMiMZDUKoaRZlrpkc3Ntd+fO9uaWcy5vuUQJITRBFKEirY01NrHW6jztWnLOpU2rCiHEGEEEIRCyIpIYvNeIMU2TbrvXbec7d25vbGy2WjmgD74xShMSIDJHQCKliAiVIpNom1ib6NSmJKQUJImJHIIPAKAAnVWtzKap7XbSXi931vS7fZAIIIioDYcQBRk5KKVRaaMdAERQRGRdqq1LsyxJnDbap4lOVBcVK8V5lrRbbQQymlp5SiQggAhNU3sfRZiZtTGBWesky7O6rkQpJGwiG2NckgGRNkneahGpOob/A/Epv6decUL6AAAAAElFTkSuQmCC",
      "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": "iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAIAAAD8GO2jAAAJjUlEQVR4nCXHyXNcx30A4N673zIrBoOdEEjQlGkuMi2JkiwpcTlOjjmlKmUf7Cr/Vz7lkEtOuaRSLpcX2VFki0UttEwSJAGI5GCbATBvZt7Sr193/zqHfLcP717fZoxtbKyXZbHIZ8aY4XCYqPRf/+UXP/nHfy4q/W///qvf/Po/m8Zsb2+Px2NOaKfbHawsG2f/7sN/iuXy3Xvvz/L5f/33f8zmr1eGazffvH/vzseUcUChCZ5orQkh3nvvnWkMYwwhlM2m+wfPvfecR/3eUCnFOdda11pzztbWVpM4KYtSl/nNG9c6imTH+zGx/Xa7yGYP/vfP2eWlheCBffHgSwIAWuuzs3Fd1wFASiml5Bydjg8ePPy00gvKCABYZ8fjcUAoBHR6evbs+fPz8/Mvv/lqNH79+z/9ev/ga4JcNx0wyqrycu/5FyZUlLNuJ8Zr64MokkmSRFE0zaZxrJI0IbiJJG+3N75/7/1Hf310uL/nvIuUcs4xSjEhPgRAobM0uH3rLVvpyclh8D5JW2lLtlppwNHmd+5vre0KBnh1vZemSikZgJVlzQRaGnTiiHtTdzrdJElOT8e6AvBACMEEOxQIIRgTqSTGKJJSEDLs9XavvrGzfeXp02dx1JpcZi9GRzJOklbCMEKEUM5ZUWhGkRKcBIwDcQ7KskIIgfeEYISQ95ZimkRRAKi0znXZbbeGqyv333l3bbh6cT5pGt9u97W2t2/defziSW3mRSUYpUxJaZ2jxIcAFDGGqaAy7kXWuVo7KRNCXAjBOauU4oTOs5kk5NqNG+++/f3bt24RIv7y+ZeHhwdLg1671f3tH/74s5/+dGt9/dvXL4XgDAJY5zAOFMPa+vLm5s6773zwg3feSdutk5Pjzz777IuHD2ezS0xw2oqddaFxOxvrf/+jH3304YfBm6dPnpyMZ/svDrPFItfllSs8aXeevTi4ce3m0etTZxDeujLo9lLG8Xt37/zy57/Y3L7qHeZSCClUFFvvX7569eDPnz7f2yvKcjhYvvfWvTu3b/UH/RfPnx0+3/vmb4+pSGe5GR0dUYoEV/v7B42x//Djn+TF4sneEyZ5xLDghH78wcffvXbjcpGfnJ0TQijB21d3+8PVW7ff/t6b31ss5mVRdLrdJEkQuCw7b/c627u7QEVZ2/O//q1qKlNVZVVNs0vK+KuzY0JxgyzbWOtLyZVSmJBnBwezRXnwcsQofe/d+2mrGwIFD4iI9tJKu7/ivXdW27rEAbXSxDf+5s3O7z755Ph4ZF1tcQPUiYRhQh49+SpOolYrZh9/9N35LMeYjkav5rMiEP7w60etJProo/cpCx4MpTIAeOsa0xRFjl1DMCAM1tqqMnt7Lx58/rnzpt9LwUvvU4SWCGEX04WKVKeTsqaigvZbaXf0enJ1t72yvnLjzZvHR4fzxfj8QjAZMyapx+B9Ns0m5xOlIqWEEJRL2ustnZz8zyJfbO1sDnrtUOvB8nK/19O1yUujdSUkY5nW3gXv4Wx8knTSqjaTyfz46OyTP376wQ/f6/VXmhp56/LF4vHjxxcX59ev71y/vtsw6byfzspvXx0stcV31ga9tB0aRyXnCCFKuu2kv7NlbMNEygJC9WKel9NXo5dHowc4iGl2eT49yqtqfXWboGgyHk/OJ5eXl7Yxb+xsmabZ2zs4PHh5PJ5OTo5/fO/6/SubImAuxfl0CsGmnRiKUukFwpidTk4RQtwCVWheLmrnbZMbqPrDjacvnnzz5Gms+tiBcw4AKl0++ubx6OT0xfNvZ9micVjhsLO+MlREYoRFwFFgnPU6CkcUe8AIM6qobRyiSKWi21vR9eXJyWhje/nNO9ta58dHkyw/JpYQjEMIVV09/PqrJGkhxExtrTfJsti7+PY084orKpVvXBpFXWckwQxQyhWrtfbOR0IJRhHBGBPCyMaVJY9zHvmd6ytV7qqsqsrKOhvT4EFxrpwL88U0akF/c+kEipG3wWooKEWYLWbheNRJEuKA+cBaLFGKInDGo/HZNMuyXi8hDJ2enUOAEJBgQrV41OswSr0PqVgZvcoO9l+XxWLz2lrUipz3mHJKCCHAKCUEg2cFtiIWjTFsPi8v6mp1eWm+0JeXRinV68bTi1LGwjnkvAvQYAjD5eUo4pwL79Esm5dFISWNI1WXNec0NI5SjFAAHgLGGGPAoYZaKskWpbW6iePGe2atpsQhRAmKcIh0Oa+NN3WNHOjiQkrZ7XYTCdY6CCFRoswLD3ow6EulvG9CCJgSQgjG2KMAAGVRsrNxJhgOZ9P5vBwMVr23o9fHTDBtNcY4imNwAI0ryynGeDKeXr1yFSPmvRMyEoz7xoMNVFJrQwjgkaeCEkItWISRtZZ1OoJihIKTEet1Y/BNpAiToqqoMU0kWdJrUwIeXLfTwgRxKsbnF1zRuC17S11dFbPZLC9ySmCp1+aUIu+FFISQoiiwB3b3zhZG2DRmsdBtxUITVISBICmlMQGg4ZwpIQLC7Q4hBNXGtPsykEgl1CM9XO0RSgACRRBLzjkPIVS1JoylSjnrmBTBOZcmjHNVzxdba2+MTrKLfEYlqp1njAVCCeGcKd8wKsVSr+Utrqt5v9/udZTgAXwTR4pgzgglhCCEOOM8kpRSjDEjgDmmBBGPXCz5zpWti8tFeVQ1FhVFhRAKMMW4kULGUTpYXr57d8ObKQE27A3TGNW6IJg60yCERNpyzllrPUA1rznnaZoyAhwguMZTLNtp+9XhfrvFfvDWLlicZRlCqLHu+OyiLE02LbOp5kiEQOaXev/pKIp8pxNHUUwppQwbYwCAUkoZq6vm/8uqXHMupFQUh1goHDyGgFDgEU1lKqVkQm6/sVbXzWKeA8DG2iql6uRkdHB4NCuytJ2kadrtdldXusPlxNS1EKLb63DfAEDjGpa2kqqqPJBYSnANxriTtBlnCKEKV7WpccC9SMhukidMCIGCnS8Wb791LRCV5XmhC/C+aczFZOKMRAgRQvKiIJwUZcEoY8ZUSnEuaJLGVhsAqHTFHZdS6lo756SQAnDQTUIEw8x63U15p8Uwl5trqfOuLEspBOG0trX3Hrz3EJwnToeqKVmrFVHGMULGGE5pkiQA0DTNbDYDgCRJlJJOG0IICkhrHWjwGHxwDAUCKDjfTkUcxx7A2QrACUalVDJubawNjTHMgrPGee+98amMPQoYoRAC5cwDBISEkE0IURQTQvI8X1SlRUAFtd5xTAG8Mb7x3lrLGB0sLTlnvYfGFFJJKfD/AenmvEAf3YYuAAAAAElFTkSuQmCC",
      "text/plain": [
       "<PIL.PngImagePlugin.PngImageFile image mode=RGB size=32x32>"
      ]
     },
     "execution_count": 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": [
       "[7405, 5226, 1363, 6615, 7612]"
      ]
     },
     "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/5000-0.5/ddpm/checkpoint-8000\"\n",
    "    \n",
    "    K=10\n",
    "    Z=65536\n",
    "\n",
    "    used_dim=32768\n",
    "    \n",
    "    t_strategy='uniform'\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": 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/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": 21,
   "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": 22,
   "id": "874a332c-29b1-46fe-bf83-12e7c8f64e28",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 5000)"
      ]
     },
     "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/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": 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": "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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": 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",
    "\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",
    "len(lamb_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e1b7c56d-0212-4aca-ba16-819db366b19a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "effb0646-37be-44c2-8b2e-7bf3c67ea049",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(5000, 65536)\n",
      "(5000, 32768)\n",
      "(1000, 65536)\n",
      "(1000, 32768)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_5193/284626611.py:32: 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": [
      "torch.Size([32768, 32768])\n",
      "tensor(0.0072, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.490593)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.008 (avg p value 0.525336)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0233, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.005 (avg p value 0.508012)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0431, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.492321)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0529, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.495569)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0769, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.002 (avg p value 0.491886)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0765, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.489301)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0633, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.499009)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0507, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.496202)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0359, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.000 (avg p value 0.482980)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0276, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.003 (avg p value 0.502505)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0162, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.024 (avg p value 0.505183)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0098, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.039 (avg p value 0.471328)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0045, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.224 (avg p value 0.209766)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0018, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.242 (avg p value 0.184121)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.254 (avg p value 0.167763)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.265 (avg p value 0.154574)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.272 (avg p value 0.147011)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.7486e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.272 (avg p value 0.149070)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9169e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.267 (avg p value 0.155134)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9813e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.258 (avg p value 0.165647)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9401e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.251 (avg p value 0.175706)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9811e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.241 (avg p value 0.192428)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9959e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.225 (avg p value 0.214709)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9871e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.211 (avg p value 0.235695)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9959e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.195 (avg p value 0.258919)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9991e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.173 (avg p value 0.294739)\n",
      "(5000, 65536)\n",
      "(5000, 32768)\n",
      "(1000, 65536)\n",
      "(1000, 32768)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0063, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.464012)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0166, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.006 (avg p value 0.492654)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0277, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.001 (avg p value 0.491231)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(-0.0149, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.005 (avg p value 0.510924)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0251, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.006 (avg p value 0.507443)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0682, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.013 (avg p value 0.508995)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0715, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.003 (avg p value 0.491147)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0628, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.008 (avg p value 0.506727)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0442, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.009 (avg p value 0.498180)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0354, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.010 (avg p value 0.495364)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0255, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.004 (avg p value 0.480877)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0157, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.010 (avg p value 0.501969)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0097, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.018 (avg p value 0.494325)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0047, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.310 (avg p value 0.099322)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.331 (avg p value 0.081650)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0009, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.340 (avg p value 0.073152)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.342 (avg p value 0.072119)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.338 (avg p value 0.077673)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.8556e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.331 (avg p value 0.083525)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9531e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.321 (avg p value 0.093837)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9895e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.302 (avg p value 0.112649)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9665e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.284 (avg p value 0.130047)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9893e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.264 (avg p value 0.152977)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9976e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.235 (avg p value 0.191570)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9921e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.212 (avg p value 0.226520)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9974e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.191 (avg p value 0.257952)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9994e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.166 (avg p value 0.302072)\n"
     ]
    }
   ],
   "source": [
    "# for loop over functions\n",
    "lds_list = []\n",
    "for K in [10, 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=(1000, 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",
    "        # 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([[ 8.23217164e-03,  7.70499340e-03,  5.29963089e-03,\n",
       "         4.21043661e-03,  3.33933008e-03,  1.60987014e-03,\n",
       "         1.49845201e-03, -2.61653103e-03,  3.85512761e-03,\n",
       "         1.07504329e-04, -3.10224923e-03,  2.36259576e-02,\n",
       "         3.93982791e-02,  2.24136831e-01,  2.41542215e-01,\n",
       "         2.54086837e-01,  2.64696499e-01,  2.72246705e-01,\n",
       "         2.71678023e-01,  2.67169758e-01,  2.58222371e-01,\n",
       "         2.50644024e-01,  2.41048533e-01,  2.25022320e-01,\n",
       "         2.10590267e-01,  1.94571829e-01,  1.72531767e-01],\n",
       "       [ 4.90593204e-01,  5.25335652e-01,  5.08011964e-01,\n",
       "         4.92321162e-01,  4.95569077e-01,  4.91885813e-01,\n",
       "         4.89301384e-01,  4.99008737e-01,  4.96202340e-01,\n",
       "         4.82980341e-01,  5.02504749e-01,  5.05183450e-01,\n",
       "         4.71327503e-01,  2.09766279e-01,  1.84121281e-01,\n",
       "         1.67763405e-01,  1.54573753e-01,  1.47010866e-01,\n",
       "         1.49070391e-01,  1.55134153e-01,  1.65647130e-01,\n",
       "         1.75706044e-01,  1.92427973e-01,  2.14708816e-01,\n",
       "         2.35694641e-01,  2.58918807e-01,  2.94738571e-01]])"
      ]
     },
     "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": "bb765d6a-70b5-435d-baed-e456e650ea69",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "3798369f-a4c3-41c1-a02e-84ba7c5395c0",
   "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": "af9b280d-3e7b-472f-9a68-8417a27e7bc6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "8122043b-7cc0-4d50-a1a5-98e6eed9a4ed",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.2722467 , 0.34236568])"
      ]
     },
     "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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2rRpw549e5g6dSoOh4PrrrvO6tJ8Tn5+fqX/GW3bto3Vq1cTGRlJ69atufPOO3n00Ufp1KkT7dq1Y/LkycTFxTF8+HDrivYRx3tvIyMjefjhhxkxYgQxMTFs3bqVe++9l44dOzJkyBALq/Z+EyZM4O233+bDDz8kLCysYlxKREQEQUFBREREcMstt5CcnExkZCTh4eHccccd9O/fn7POOsvi6r3bid7brVu38vbbb3PxxRfTrFkz1qxZw1133cWgQYPo0aOHxdXXkNXTlLzds88+a7Ru3doICAgw+vXrZyxbtszqknzayJEjjdjYWCMgIMBo2bKlMXLkSGPLli1Wl+WTFi9ebADH3MaMGWMYhjm1efLkyUZ0dLThdDqNCy64wNi4caO1RfuI4723hYWFxkUXXWQ0b97c8Pf3N9q0aWOMGzfOSE9Pt7psr1fVewoYr776asU5hw4dMm6//XajadOmRnBwsHHllVcae/futa5oH3Gi9zYtLc0YNGiQERkZaTidTqNjx47GPffcY+Tk5FhbuAdshmEYDRmQRERERDylMSwiIiLi9RRYRERExOspsIiIiIjXU2ARERERr6fAIiIiIl5PgUVERES8ngKLiIiIeD0FFhEREfF6CiwiIiLi9RRYRERExOspsIiIiIjXU2ARERERr/f/YkkG4jo/rhYAAAAASUVORK5CYII=",
      "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
}
