{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "5125b1f4-34fe-4f08-b7f6-7f9c6f28ae48",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b3960d83-1962-4f28-bdbc-4ebf6caf3927",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys; sys.path.append(\"../src/\")\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import kernel\n",
    "from tqdm import tqdm\n",
    "import seaborn as sns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "bd160d24-7d86-46fa-82dc-1bf2866efd7f",
   "metadata": {},
   "outputs": [],
   "source": [
    "rng = np.random.default_rng(1234)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6052c3a0-7564-4c91-809f-c85037c92be7",
   "metadata": {},
   "source": [
    "The parameters are as follows."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "id": "f5b8073a-563d-4eb3-ac2a-5c4bd3fd6ccd",
   "metadata": {},
   "outputs": [],
   "source": [
    "n=1000\n",
    "d=1\n",
    "reps = 1000"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "id": "08fce12a-67c9-4bac-b60c-40dbbf96594e",
   "metadata": {},
   "outputs": [],
   "source": [
    "X = rng.normal(size=(n,d))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "id": "413ee3f3-1925-45f2-a7cf-c84ef984f767",
   "metadata": {},
   "outputs": [],
   "source": [
    "gamma = kernel.Gauss.est_gamma(X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "id": "eff2d2e1-b697-48a9-a52f-cef87e62e97a",
   "metadata": {},
   "outputs": [],
   "source": [
    "alpha=.01"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "id": "0c19d67e-07a4-4e3e-8443-c4f1d2ad3b9c",
   "metadata": {},
   "outputs": [],
   "source": [
    "gauss = kernel.Gauss(gamma=gamma)\n",
    "\n",
    "rffmmd = kernel.RFFMMD(kernel=gauss,num_omegas=1000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "id": "81f2bec4-3ca2-470d-89b7-426d1d4fd7b9",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Actual $H_0$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "e749dcb6-d4e4-428b-8272-0c7f1968b7d3",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████| 1000/1000 [01:26<00:00, 11.58it/s]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "H0_statistics_rff = []\n",
    "for _ in tqdm(range(reps)):\n",
    "    X = rng.normal(size=(n,d))\n",
    "    Y = rng.normal(size=(n,d))\n",
    "    H0_statistics_rff.append(rffmmd.mmd(X,Y))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "7ddd400f-967a-4bc1-983b-dc3b6bd9542f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# MC / permutation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "id": "fb8053e3-722d-4d31-8506-c4947919718e",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████| 1000/1000 [01:32<00:00, 10.78it/s]\n"
     ]
    }
   ],
   "source": [
    "MC_statistics_rff = []\n",
    "\n",
    "s = rng.normal(size=(2*n,d))\n",
    "for _ in tqdm(range(reps)):\n",
    "    mask = np.ones(len(s), dtype=bool)\n",
    "    mask[rng.choice(len(s), n, replace=False)] = False\n",
    "    X = s[mask]\n",
    "    Y = s[~mask]\n",
    "    MC_statistics_rff.append(rffmmd.mmd(X,Y))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "id": "f6c59ee4-afe2-493b-9bf5-a66b4baf4b84",
   "metadata": {},
   "outputs": [],
   "source": [
    "# McDiarmid from Lemma 5\n",
    "eps = np.sqrt(2*np.log(1/alpha))\n",
    "diarmid_threshold = np.sqrt(2/n) * (np.sqrt(2) + eps)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "id": "c5a21d2b-b7a9-4765-9409-e3f2bea0c504",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Bernstein (Lemma 6)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "id": "66aad1ee-3d2b-443b-afa9-2d015b5cd4ae",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Estimate sigma\n",
    "gram = kernel.Gauss(gamma=gamma).eval(X,X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "a50be49e-b35b-41d7-9966-555071deaadc",
   "metadata": {},
   "outputs": [],
   "source": [
    "EXX = np.mean(np.diag(gram))\n",
    "np.fill_diagonal(gram,0)\n",
    "EXY = np.sum(gram)/((n*(n-1)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "id": "2cbcb741-8abf-4514-8e22-e534c9850721",
   "metadata": {},
   "outputs": [],
   "source": [
    "sigma2 = 2*EXX - EXY"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "id": "91ae6348-a72c-451b-b5a8-42257bf5ddf4",
   "metadata": {},
   "outputs": [],
   "source": [
    "bernstein_threshold = 4*np.sqrt(2)*np.log(2/alpha)/n+np.sqrt(2*sigma2*np.log(2/alpha)/n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 121,
   "id": "e21e8c58-e5c9-46cd-af09-7423b71dbc99",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x250 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1,1,figsize=(5,2.5),constrained_layout=True)\n",
    "sns.histplot(MC_statistics_rff, label=\"Permutation-based\")\n",
    "ax.axvline(np.quantile(MC_statistics_rff,1-alpha), label=\"Permutation 1-$\\\\alpha$ quantile\")\n",
    "\n",
    "sns.histplot(H0_statistics_rff, label=\"Resampling-based\")\n",
    "ax.axvline(np.quantile(H0_statistics_rff,1-alpha),  label=\"Resampling 1-$\\\\alpha$ quantile\", c=\"orange\")\n",
    "\n",
    "ax.axvline(diarmid_threshold, c=\"red\", label=\"Distribution-free level $\\\\alpha$\")\n",
    "\n",
    "ax.axvline(bernstein_threshold, c=\"green\", label=\"Bernstein-bound level $\\\\alpha$\")\n",
    "\n",
    "\n",
    "line, labels = ax.get_legend_handles_labels()\n",
    "\n",
    "fig.legend(line, labels, loc=\"upper center\", bbox_to_anchor=(0.52, 1.25), ncol=3)\n",
    "plt.savefig(\"../figures/compare-tresholds-static.pdf\", bbox_inches=None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9eeaee1b-fc10-4f5a-a4ad-9899d4d541dc",
   "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.12.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
