{
 "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": [
       "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": 9,
   "id": "40c86797-31d5-45d0-b46f-52f8c84dd130",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>path</th>\n",
       "      <th>split</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>../../../../codes/celeba/data/celeba/img_align...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>../../../../codes/celeba/data/celeba/img_align...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>../../../../codes/celeba/data/celeba/img_align...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>../../../../codes/celeba/data/celeba/img_align...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>../../../../codes/celeba/data/celeba/img_align...</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                path  split\n",
       "0  ../../../../codes/celeba/data/celeba/img_align...      0\n",
       "1  ../../../../codes/celeba/data/celeba/img_align...      0\n",
       "2  ../../../../codes/celeba/data/celeba/img_align...      0\n",
       "3  ../../../../codes/celeba/data/celeba/img_align...      0\n",
       "4  ../../../../codes/celeba/data/celeba/img_align...      0"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "df = pd.read_csv('../../../../codes/celeba/data/celeba/list_eval_partition.txt', delimiter=\" \", \n",
    "                 names=['path', 'split'],\n",
    "                 header=None, skipinitialspace=True)\n",
    "df['path'] = df.apply(lambda x: \"../../../../codes/celeba/data/celeba/img_align_celeba/{}\".format(x['path']), axis=1)\n",
    "df.head()    "
   ]
  },
  {
   "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.JpegImagePlugin.JpegImageFile image mode=RGB size=178x218>"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from datasets import Dataset, load_dataset, Image\n",
    "\n",
    "train_dataset = Dataset.from_dict({\"img\": df.loc[idx_train]['path'].tolist(),\n",
    "                                  }).cast_column(\"img\", Image())\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": "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",
      "text/plain": [
       "<PIL.PngImagePlugin.PngImageFile image mode=RGB size=64x64>"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "df = pd.DataFrame()\n",
    "df['path'] = ['{}/{}.png'.format('../../saved/5000-0.5/gen', i) for i in range(1000)]\n",
    "\n",
    "from datasets import DatasetDict, Dataset, load_dataset, Image\n",
    "dataset = DatasetDict({\n",
    "\"train\": Dataset.from_dict({\n",
    "    \"img\": df['path'].tolist(),\n",
    "}).cast_column(\"img\", Image()),})\n",
    "val_dataset = dataset[\"train\"]\n",
    "val_dataset[0][\"img\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "e16837b7-8ddd-46ab-9d0a-c988f2ca9514",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[167013, 179842, 176165, 167714, 180120]"
      ]
     },
     "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=\"celeba\"\n",
    "\n",
    "    output_dir=\"../../saved/5000-0.5/ddpm/checkpoint-8000\"\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/5000-0.5/lds-val/ddpm-sub-{}-{}/e-{}-gen.pkl'.format(i, seed, e_seed), 'rb')  as handle:\n",
    "                loss_list = pickle.load(handle)\n",
    "            margins = np.concatenate(loss_list, axis=-1) # -logp\n",
    "            ####\n",
    "            if (seed==0) and (e_seed)==0:\n",
    "                loss_array = margins\n",
    "            else:\n",
    "                loss_array += margins\n",
    "            \n",
    "    loss_array = loss_array/(3*3)\n",
    "    \n",
    "    loss_array_list.append(loss_array)\n",
    "lds_loss_array = np.stack(loss_array_list)\n",
    "lds_loss_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "d823ef7b-9d53-4f31-ab11-864274554493",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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J80Y9nr8+rJE3tyIZhJFIhEWLlzImjVr8tt832fNmjUsXbr0oPssXbp0WHuABx544JDtAaLRKPF4fNiPiIiInJhGPEyzcuVKli9fzqJFi1i8eDE333wzvb29rFixAoArrriCyZMns2rVKgCuueYaLrroIr797W9z6aWXcvfdd7Nu3Tp++MMfju6ZiIiIyHFpxGHksssuo7W1leuvv56mpiYWLFjA6tWr85NUd+7cOWwC3Lnnnstdd93FF7/4Rf7t3/6N2bNnc9999x32GiMiIiJyYtNy8CIiIjImDvf7W6vPiIiISKAURkRERCRQCiMiIiISKIURERERCZTCiIiIiARKYUREREQCpTAiIiIigVIYERERkUApjIiIiEigRrwcfBAGF4lNJBIBVyIiIiKHa/B7+60Wez8uwkh3dzcADQ0NAVciIiIiI9Xd3U15efkh3z8unk3j+z579uyhrKwMY8yoHTeRSNDQ0MCuXbv0zJsxpms9PnSdx4eu8/jQdR4/Y3WtrbV0d3czadKkYQ/RfaPjomfEcRymTJkyZsePx+P6gz5OdK3Hh67z+NB1Hh+6zuNnLK71m/WIDNIEVhEREQmUwoiIiIgEqqDDSDQa5YYbbiAajQZdyglP13p86DqPD13n8aHrPH6CvtbHxQRWEREROXEVdM+IiIiIBE9hRERERAKlMCIiIiKBUhgRERGRQBV0GLnllluYPn06sViMJUuW8NRTTwVd0nFj1apVnH322ZSVlVFbW8v73/9+tm7dOqxNMpnkqquuorq6mtLSUj74wQ/S3Nw8rM3OnTu59NJLKS4upra2ln/5l38hm82O56kcV2688UaMMXz2s5/Nb9N1Hj27d+/mb/7mb6iurqaoqIjTTz+ddevW5d+31nL99dczceJEioqKaGxsZNu2bcOO0d7ezuWXX048HqeiooJPfOIT9PT0jPepHLM8z+O6665jxowZFBUVMWvWLL7yla8Me3aJrvORefTRR3nPe97DpEmTMMZw3333DXt/tK7rpk2buOCCC4jFYjQ0NPCNb3zj6Iu3Beruu++2kUjE3nHHHfb555+3V155pa2oqLDNzc1Bl3ZcWLZsmf3JT35iN2/ebDdu3Gjf/e5326lTp9qenp58m0996lO2oaHBrlmzxq5bt86ec8459txzz82/n81m7bx582xjY6N95pln7P33329ramrstddeG8QpHfOeeuopO336dHvGGWfYa665Jr9d13l0tLe322nTptm//du/tU8++aR99dVX7R/+8Af78ssv59vceOONtry83N5333322Wefte9973vtjBkzbH9/f77NO9/5Tjt//nz7xBNP2D/96U/2pJNOsh/96EeDOKVj0le/+lVbXV1tf/e739nt27fbe++915aWltrvfOc7+Ta6zkfm/vvvt1/4whfsL3/5SwvYX/3qV8PeH43r2tXVZevq6uzll19uN2/ebH/xi1/YoqIi+4Mf/OCoai/YMLJ48WJ71VVX5V97nmcnTZpkV61aFWBVx6+WlhYL2EceecRaa21nZ6cNh8P23nvvzbd58cUXLWDXrl1rrc39g+M4jm1qasq3ufXWW208HrepVGp8T+AY193dbWfPnm0feOABe9FFF+XDiK7z6Pnc5z5nzz///EO+7/u+ra+vt9/85jfz2zo7O200GrW/+MUvrLXWvvDCCxawTz/9dL7N73//e2uMsbt37x674o8jl156qf34xz8+bNtf/dVf2csvv9xaq+s8Wt4YRkbrun7/+9+3lZWVw/7u+NznPmdPOeWUo6q3IIdp0uk069evp7GxMb/NcRwaGxtZu3ZtgJUdv7q6ugCoqqoCYP369WQymWHXeM6cOUydOjV/jdeuXcvpp59OXV1dvs2yZctIJBI8//zz41j9se+qq67i0ksvHXY9Qdd5NP3mN79h0aJFfPjDH6a2tpYzzzyT22+/Pf/+9u3baWpqGnaty8vLWbJkybBrXVFRwaJFi/JtGhsbcRyHJ598cvxO5hh27rnnsmbNGl566SUAnn32WR577DHe9a53AbrOY2W0ruvatWu58MILiUQi+TbLli1j69atdHR0HHF9x8WD8kZbW1sbnucN+8sZoK6uji1btgRU1fHL930++9nPct555zFv3jwAmpqaiEQiVFRUDGtbV1dHU1NTvs3B/j8YfE9y7r77bjZs2MDTTz99wHu6zqPn1Vdf5dZbb2XlypX827/9G08//TT/8A//QCQSYfny5flrdbBrOfRa19bWDns/FApRVVWlaz3g85//PIlEgjlz5uC6Lp7n8dWvfpXLL78cQNd5jIzWdW1qamLGjBkHHGPwvcrKyiOqryDDiIyuq666is2bN/PYY48FXcoJZ9euXVxzzTU88MADxGKxoMs5ofm+z6JFi/ja174GwJlnnsnmzZu57bbbWL58ecDVnTj+8z//kzvvvJO77rqL0047jY0bN/LZz36WSZMm6ToXsIIcpqmpqcF13QPuOGhubqa+vj6gqo5PV199Nb/73e946KGHmDJlSn57fX096XSazs7OYe2HXuP6+vqD/n8w+J7khmFaWlo466yzCIVChEIhHnnkEf793/+dUChEXV2drvMomThxInPnzh227dRTT2Xnzp3A/mv1Zn9v1NfX09LSMuz9bDZLe3u7rvWAf/mXf+Hzn/88H/nIRzj99NP52Mc+xj/+4z+yatUqQNd5rIzWdR2rv08KMoxEIhEWLlzImjVr8tt832fNmjUsXbo0wMqOH9Zarr76an71q1/x4IMPHtBtt3DhQsLh8LBrvHXrVnbu3Jm/xkuXLuW5554b9of/gQceIB6PH/ClUKje/va389xzz7Fx48b8z6JFi7j88svzv+s6j47zzjvvgNvTX3rpJaZNmwbAjBkzqK+vH3atE4kETz755LBr3dnZyfr16/NtHnzwQXzfZ8mSJeNwFse+vr4+HGf4V4/ruvi+D+g6j5XRuq5Lly7l0UcfJZPJ5Ns88MADnHLKKUc8RAMU9q290WjU/sd//Id94YUX7Cc/+UlbUVEx7I4DObRPf/rTtry83D788MN27969+Z++vr58m0996lN26tSp9sEHH7Tr1q2zS5cutUuXLs2/P3jL6SWXXGI3btxoV69ebSdMmKBbTt/C0LtprNV1Hi1PPfWUDYVC9qtf/ardtm2bvfPOO21xcbH9+c9/nm9z44032oqKCvvrX//abtq0yb7vfe876K2RZ555pn3yySftY489ZmfPnl3wt5wOtXz5cjt58uT8rb2//OUvbU1Njf3Xf/3XfBtd5yPT3d1tn3nmGfvMM89YwN500032mWeesa+99pq1dnSua2dnp62rq7Mf+9jH7ObNm+3dd99ti4uLdWvv0fjud79rp06daiORiF28eLF94okngi7puAEc9OcnP/lJvk1/f7/9zGc+YysrK21xcbH9wAc+YPfu3TvsODt27LDvete7bFFRka2pqbH/9E//ZDOZzDifzfHljWFE13n0/Pa3v7Xz5s2z0WjUzpkzx/7whz8c9r7v+/a6666zdXV1NhqN2re//e1269atw9rs27fPfvSjH7WlpaU2Ho/bFStW2O7u7vE8jWNaIpGw11xzjZ06daqNxWJ25syZ9gtf+MKwW0V1nY/MQw89dNC/l5cvX26tHb3r+uyzz9rzzz/fRqNRO3nyZHvjjTcede3G2iHL3omIiIiMs4KcMyIiIiLHDoURERERCZTCiIiIiARKYUREREQCpTAiIiIigVIYERERkUApjIiIiEigFEZEREQkUAojIiIiEiiFEREREQmUwoiIiIgESmFEREREAvX/AcGF04X2b46ZAAAAAElFTkSuQmCC",
      "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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",
      "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": [
      "(5000, 65536)\n",
      "(5000, 32768)\n",
      "(1000, 65536)\n",
      "(1000, 32768)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_3133/3459463702.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(106.7808, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: -0.018 (avg p value 0.504683)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(44.9638, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.469888)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.0984, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.052 (avg p value 0.471015)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.4970, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.472652)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2436, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.472445)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.6989, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.051 (avg p value 0.471909)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8512, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.052 (avg p value 0.472207)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4274, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.052 (avg p value 0.474230)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1727, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.053 (avg p value 0.475631)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0875, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.055 (avg p value 0.474583)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0446, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.057 (avg p value 0.474442)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0184, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.060 (avg p value 0.473379)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0094, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.063 (avg p value 0.470978)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0048, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.065 (avg p value 0.470282)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0019, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.068 (avg p value 0.464071)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.069 (avg p value 0.457957)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.069 (avg p value 0.455003)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.068 (avg p value 0.454545)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9639e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.064 (avg p value 0.458367)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9892e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.060 (avg p value 0.460822)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9978e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.054 (avg p value 0.468107)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9937e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.471798)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9982e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.046 (avg p value 0.478083)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9996e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.043 (avg p value 0.486138)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9990e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.041 (avg p value 0.488399)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9997e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.040 (avg p value 0.489012)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.039 (avg p value 0.489439)\n",
      "(5000, 65536)\n",
      "(5000, 32768)\n",
      "(1000, 65536)\n",
      "(1000, 32768)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(90.4109, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.134 (avg p value 0.352443)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(43.0022, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.138 (avg p value 0.345414)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(17.0163, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.138 (avg p value 0.344141)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(8.5083, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.139 (avg p value 0.342521)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.2660, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.140 (avg p value 0.341627)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.7209, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.141 (avg p value 0.338675)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.8705, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.144 (avg p value 0.333918)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.4427, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.146 (avg p value 0.327707)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.1823, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.149 (avg p value 0.322438)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0933, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.149 (avg p value 0.323137)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0476, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.145 (avg p value 0.328207)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0194, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.137 (avg p value 0.339251)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0098, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.127 (avg p value 0.358168)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0049, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.117 (avg p value 0.378760)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0020, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.102 (avg p value 0.401954)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0010, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.093 (avg p value 0.422174)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0005, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.086 (avg p value 0.433351)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(0.0002, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.077 (avg p value 0.447786)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9939e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.071 (avg p value 0.452511)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9982e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.064 (avg p value 0.461358)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9996e-05, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.057 (avg p value 0.466752)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9987e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.053 (avg p value 0.473532)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9996e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.050 (avg p value 0.477597)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(1.9999e-06, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.047 (avg p value 0.480745)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(9.9998e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.046 (avg p value 0.481404)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(4.9999e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.045 (avg p value 0.482181)\n",
      "torch.Size([32768, 32768])\n",
      "tensor(2.0000e-07, device='cuda:0')\n",
      "torch.Size([1000, 5000])\n",
      "Correlation: 0.045 (avg p value 0.481920)\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, 'loss', 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-gen-keys-{}-{}-{}-{}-{}.npy'.format(\n",
    "                args.output_dir, 0, K, args.Z, 'loss', 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",
    "        \n",
    "        scores = scores / torch.norm((dstore_keys@kernel_), dim=1).reshape(1, 5000)\n",
    "        \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('./gen_5000_0.5_{}_{}_{}_{}.pkl'.format('loss', 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.01758918,  0.05140272,  0.05187957,  0.05097705,  0.05119606,\n",
       "         0.05149251,  0.05164159,  0.05219331,  0.05333088,  0.05483358,\n",
       "         0.05721721,  0.06009482,  0.06303106,  0.06528189,  0.06806445,\n",
       "         0.06924558,  0.06890373,  0.06781504,  0.06440348,  0.06040167,\n",
       "         0.05386217,  0.04977199,  0.04627613,  0.04299332,  0.04081343,\n",
       "         0.03990372,  0.03922609],\n",
       "       [ 0.5046833 ,  0.46988823,  0.47101534,  0.47265234,  0.47244541,\n",
       "         0.4719088 ,  0.47220737,  0.47423028,  0.47563057,  0.47458286,\n",
       "         0.47444199,  0.47337856,  0.47097777,  0.47028231,  0.46407101,\n",
       "         0.45795679,  0.45500264,  0.4545449 ,  0.45836741,  0.46082196,\n",
       "         0.46810683,  0.47179846,  0.4780827 ,  0.48613835,  0.48839877,\n",
       "         0.48901199,  0.48943903]])"
      ]
     },
     "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": "66730b4c-038f-4fdb-a21b-ec90ac3ee454",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "8475f30a-6050-46c4-95bc-077cf7761728",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('./gen_5000_0.5_{}.pkl'.format('loss'), 'wb') as handle:\n",
    "    pickle.dump(lds_array, handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c65d8279-c7a4-4d6c-9bb3-3e306c737c53",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "8122043b-7cc0-4d50-a1a5-98e6eed9a4ed",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.06924558, 0.14899976])"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "lds_array[:, 0].max(axis=-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "80995dab-f837-4566-9ea9-ccb5b1c5b0fd",
   "metadata": {},
   "outputs": [],
   "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
}
