{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "45075a73",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "from tqdm.notebook import tqdm\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# set our device\n",
    "device = torch.device(\"cuda\") if torch.cuda.is_available() else torch.device(\"cpu\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "1eb91469",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c35093636be44a86b87d53839611f7e5",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/10000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# 0. let's try loading 50K entries of the pairwise distances matrix\n",
    "L, B = 50_000, 10_000\n",
    "\n",
    "# 1. set a seed for reproducibility\n",
    "torch.random.manual_seed(858)\n",
    "sigmas = []\n",
    "\n",
    "for b in tqdm(range(B)):\n",
    "\n",
    "    # 2. load in our data + convert into PyTorch tensor\n",
    "    X = torch.tensor(np.load(file=f\"truth/NUTS_blr-gcp_d=24_whiten=True.npy\"))\n",
    "    X = X.to(device)\n",
    "\n",
    "    # 3. compute the pairwise distances\n",
    "    X_dists = torch.cdist(X, X)\n",
    "\n",
    "    # 4. compute sigma using a SAMPLE median (of size L) of the pairwise distances, divide by root-2.\n",
    "    sigma = torch.median(X_dists[\n",
    "        np.random.choice(a=X.shape[0], size=L), \n",
    "        np.random.choice(a=X.shape[0], size=L)]) / (2.0 ** 0.5)\n",
    "\n",
    "    # 5. add to our list\n",
    "    sigmas.append(sigma)\n",
    "    \n",
    "# de-tensorfy\n",
    "sigmas = np.array([sigma.item() for sigma in sigmas])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "92e9fade",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# show what the best sigma for MMD is on whitened GCP BLR.\n",
    "plt.hist(sigmas, bins=30, density=True); plt.axvline(x=sigmas.mean(), linestyle=\"--\", color=\"red\")\n",
    "plt.xlabel(\"$\\sigma$\", fontsize=14); plt.ylabel(\"Frequency\", fontsize=14)\n",
    "plt.title(\"Sampling Distribution of $\\sigma$ for MMD ($L=50K$, $B=10K$)\", fontweight=\"bold\")\n",
    "plt.grid(); plt.tight_layout(); plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "64905831",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.3545334045797586"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# let's use the mean sigma across the 10_000 trials.\n",
    "sigmas.mean()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.10 (Afterburner)",
   "language": "python",
   "name": "afterburner"
  },
  "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.10.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
