{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b3960d83-1962-4f28-bdbc-4ebf6caf3927",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from online_rff_mmd import kernel\n",
    "from tqdm import tqdm\n",
    "import seaborn as sns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "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": 3,
   "id": "f5b8073a-563d-4eb3-ac2a-5c4bd3fd6ccd",
   "metadata": {},
   "outputs": [],
   "source": [
    "n=1000\n",
    "d=1\n",
    "reps = 1000"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "08fce12a-67c9-4bac-b60c-40dbbf96594e",
   "metadata": {},
   "outputs": [],
   "source": [
    "X = rng.normal(size=(n,d))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "413ee3f3-1925-45f2-a7cf-c84ef984f767",
   "metadata": {},
   "outputs": [],
   "source": [
    "gamma = kernel.Gauss.est_gamma(X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "eff2d2e1-b697-48a9-a52f-cef87e62e97a",
   "metadata": {},
   "outputs": [],
   "source": [
    "alpha=.01"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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": 8,
   "id": "81f2bec4-3ca2-470d-89b7-426d1d4fd7b9",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Actual $H_0$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "e749dcb6-d4e4-428b-8272-0c7f1968b7d3",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1000/1000 [01:34<00:00, 10.60it/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": 10,
   "id": "7ddd400f-967a-4bc1-983b-dc3b6bd9542f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# MC / permutation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "fb8053e3-722d-4d31-8506-c4947919718e",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1000/1000 [01:41<00:00,  9.86it/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": 12,
   "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": 13,
   "id": "c5a21d2b-b7a9-4765-9409-e3f2bea0c504",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Bernstein (Lemma 6)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "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": 15,
   "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": 16,
   "id": "2cbcb741-8abf-4514-8e22-e534c9850721",
   "metadata": {},
   "outputs": [],
   "source": [
    "sigma2 = 2*EXX - EXY"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "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": 18,
   "id": "e21e8c58-e5c9-46cd-af09-7423b71dbc99",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7c5236603470>"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "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
}
