{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "b89a761c-c29d-4a1c-962a-8620fb17627b",
   "metadata": {},
   "source": [
    "We are comparing the McDiarmid-based threshold for a fixed level $\\alpha$ to the $1-\\alpha$ quantile of the actual null distribution of $\\mathcal N(0,1)$ distributed data with a Gaussian kernel with parameter $\\gamma=1$."
   ]
  },
  {
   "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"
   ]
  },
  {
   "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": 4,
   "id": "90139263-063f-422f-a630-b0750fb46fae",
   "metadata": {},
   "outputs": [],
   "source": [
    "gamma = 1\n",
    "alpha = .01\n",
    "n, m = 100,100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "0c19d67e-07a4-4e3e-8443-c4f1d2ad3b9c",
   "metadata": {},
   "outputs": [],
   "source": [
    "gauss = kernel.Gauss(gamma=gamma)\n",
    "\n",
    "quadmmd = kernel.BiasedMMD(kernel=gauss)\n",
    "rffmmd = kernel.RFFMMD(kernel=gauss,num_omegas=100)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "178fdf43-90c0-474d-a3fe-5306fa64c0ed",
   "metadata": {},
   "source": [
    "Simulating data from the null for $500$ repetitions."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "e749dcb6-d4e4-428b-8272-0c7f1968b7d3",
   "metadata": {},
   "outputs": [],
   "source": [
    "reps = 500\n",
    "\n",
    "statistics_quad = []\n",
    "statistics_rff = []\n",
    "for _ in range(reps):\n",
    "    X = rng.normal(size=(n,20))\n",
    "    Y = rng.normal(size=(m,20))\n",
    "    statistics_quad.append(quadmmd.mmd(X,Y))\n",
    "    statistics_rff.append(rffmmd.mmd(X,Y))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "58470500-3f2f-4580-8246-e420e13d9d16",
   "metadata": {},
   "source": [
    "Plotting the respective values."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "82d402ec-f576-48bd-b973-5980b13399c8",
   "metadata": {},
   "outputs": [],
   "source": [
    "limits = { \"ymin\": 0, \n",
    "           \"ymax\": 150 }"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "0457eff1-1536-4c35-8442-17ad1378f509",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiIAAAGbCAYAAAD5mfsKAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAL45JREFUeJzt3c9u41iC7/mfK/9Edt1bNmUDjapExyIo9GwuMAtKfoBCim9AZTxBSOvbCwnuTVfPoj3UZtZivMC1qTcgA3Xv3GVYXAwwvRhADDQCqAaykRbt7MyKiK5K3oWHLEmWZMl/dPzn+wEEWCJFHh7b4k/nHB5u5XmeCwAAwIBfmC4AAAB4uggiAADAGIIIAAAwhiACAACMIYgAAABjCCIAAMAYgggAADDmc9MFWObnn3/WH/7wB/3qV7/S1taW6eIAAIAV5HmuH374QV9//bV+8YvlbR73Ooj84Q9/0PPnz00XAwAAXMP79+/1N3/zN0vXuddB5Fe/+pWkiwPZ3t42XBoAALCK8/NzPX/+vDyPL3Ovg0jRHbO9vU0QAQDggVllWAWDVQEAgDEEEQAAYAxBBAAAGHOvx4gAwFV+/vlnffr0yXQxgCfniy++0GeffXbj7RBEADxYnz590rt37/Tzzz+bLgrwJFmWpV//+tc3muuLIALgQcrzXP/6r/+qzz77TM+fP79y0iQAtyfPc/3000/67rvvJEm/+c1vrr0tggiAB+lPf/qTfvrpJ3399df65S9/abo4wJPzV3/1V5Kk7777Tn/913997W4avkIAeJD+/Oc/S5K+/PJLwyUBnq7iS8B//Md/XHsbBBEADxr3oQLMuY3/P4IIAAAwhjEiAB6V/yv6/za6v//q/m8rrzsYDPTq1Svt7u5qNBqVr6dpqm63qyRJ1O/31Wg0lm4nTVNlWSbHceY+X0cQBJIk3/c1HA5lWdba27iObrerOI41HA5vvC3XddVut+V5ntFtLBLHsdrtttI01Wg0km3bU8uzLFOlUpFlWXr9+rUsy7r2+p1OR9LF34Rt2/J9/9aP57bRIgIAG+J5nlqtltI0VbvdLl+3bVsHBwfyPO/KEJIkiVzX1dHR0dzn6xgMBhoOh2q1WgrDcGMhRJL29/eVZdm13pskydR7u93ulfV2F9tYVaPRKANOv9+/tPz4+FiWZaler5d/A+uu32g0yuDh+77CMJQkVSoVJUlyJ8d1WwgiALBBe3t7sixLQRBoMBiUr1uWpb29vSvf7zjOVMvH7PN1vH37tgwf193GdV039GRZpmazOfVao9FYa3u3sY117e3tyfO8sgVqUhRFqtfrN1p/Xtl931e9Xr90rPcNQQQANqz4ttpsNpWm6aXlQRBoa2tLaZoqTVO5rivXda+1ryRJ1Ov1FATB1P4Gg4HiOFYcx+r1enNbJ5IkUbfbVRAEarfb5QntqvL1ej0NBgO12231er1L2+v1elPf9AeDgVzX1WAwULVaLd8zbztxHCtNUx0eHipJEiVJomazOXXCLo651+up2WxeOrarthHHsWq1moIgULfbVbVaVRAEiuNYzWbzUitDUYdF984i7XZbWZZdKqvrunODxLrrL9pnmqb3ulWEIAIAG1av1xVFkSTNDRitVqv82bbta3+jzbJM33zzjTqdjlqtltrttmq1mqSLbqJ6va56va5Op3PpxJZlmV69eiXf99VqtVSr1cqT2bLyFSd4z/Pk+7663W65rNhep9PR/v5++Xqj0VAcx3r79q2iKFKj0Vi4naLL4uDgoGwNKsbIFOXudrvqdDrqdDpK01THx8dTx3bVNhqNhrIs02g0ku/76vf7arfb2t3dVRiGarVaZZBK01RRFKnT6SiKIh0fH0+1dE2q1+tqNBpTIazf70/V503Wn6do6To5OVn5PZtGEAEAAxqNhnzfvzRe5DYFQTDVhF+MgVh0olz23tkBk4vYtl0OQC1OfsW3+sntTXYFFSHo5cuXsm1bjuMs3M6ifU6WezLcFWNgVin3JMuyyrBUlLsoc7VanWpZStO0bIE5ODhYWlfFoOTZMSq3tf4iu7u7137vXeOqGQAwpNPp6O3btwqCQNVq9da3P3llTsG27bndQfPee9NxHLOB4Da2c5XRaHQndblsf67rrtxKUQwqPTw8vLIr5zrrzyp+16sGSRNoEQGADfr++++nnodhKMdxprow5jk9PV17X5Pf3CetOjB1nXEFRfnSNFWz2Sy7MAqWZa0UgAqLtjO7v1mWZZXdXoVFLQnXqdN5+yvG/BTm1dvk773dbmswGCiKooW/i3XXX6T4+9r0YOR1EEQAYMNmT4Bv3ry51PpgWVZ5QouiSEmSrNSlMqm4VLjYTpZlyrJspctUXddVHMdTZVilfHEcl+tMBo/Z7SVJsjQILNpOYTJcTP788uVLxXFcDvAcDAYLx0cs2sa857OvFWWft79Fx1W8XgSryZaeeftbZ/157w+CQMfHx3r9+vXc8twXBBEA2JA4jjUYDOT7/tSJw7KsS2HE9329evWq7JooLi9NkqS82qUIGZPPJ1mWpeFwqMPDQwVBoCAIyi6SyffN+wZfzHlSq9XUbDYvXVq8qHzffvutJJWDWx3H0atXr8oxMc1mU81mU6PRSPV6vawT6WIgZlEvi7YjXZyYX716VZb95OREURSVk7r1+311u11VKhWdnp7ODV7LtlHU5dHR0dRVK0EQKMsyhWFY1r3jOOVg2kX7K46x2+0qyzJZlqVWq1UGjCIsnZyclGFunfWL32UxMV6321W73dZwONS7d+/udWuIJG3leZ6bLsQi5+fn2tnZ0dnZmba3t00XB8A98uHDB717904vXrzQV199Zbo4j14xO+i8cSd4uhb9H65z/qZFBABwpSzLbmVMBTCLIAIAWCpN07Lb5D5PjIWHict3AQBL2bZ9abAqcFtoEQEAAMYQRAAAgDEEEQAAYAxBBAAAGEMQAQAAxnDVDIDH5feHm93fbw82uz/gkaFFBAA2ZDAYqFKpXLo7bHGDt2q1OnWPlUUm7x8z7/k6iqnfq9Xq1LTzcRyrWq1qa2urnDLcdd2p+93EcaxKpaJKpVJOLd7tdlWr1dTtdq9cPmlyf4vuLbO1taVKpVJOg37d9YtyNJvNK282iLtHEAGADSnu35Km6dTt3G3b1sHBgTzPu/KGdEmSyHVdHR0dzX2+jsFgoOFwqFarpTAMp+5102g0ylvQ+76vfr9f3iumCEuz6xSP4XCovb29K5dPajQa8jxP0sU9Z2YdHx/LsizV6/WyntZdf7YsxV1zK5UKE7UZRBABgA3a29uTZVkKgmCqdcGyrEsn53lmb+l+k1u8v337tgwfi7YxGU6KdVaZ3KzT6ay9fG9vT57nlTeZmxRFker1+o3Wn73DsXRx8756va5ms7m0vLg7BBEA2LDim3iz2ZzbrRAEQdnlkKapXNedugX8OpIkUa/XUxAEU/sruiviOFav15t7G/lZRXDa399fut68YLDq8na7PXXH2+IYXNedGyTWXX/RPm/SvYWbYbAqAGxYvV5XFEVlwJi9o22r1Sq7bmzbVrPZLMPLOrIs0zfffKPxeFxuq1araTwey/O8smVjWetF0Y10cnKiJEnUarXKLpHJdYpb1p+enmp3d3et5ZPq9boajYb6/X552/t+v69+vz+3JWbd9ecpWnpOTk6u3bqE66NFBAAMaDQa8n3/0niR2xQEwVT3RDH+ZLJLaBXValVJkigMw7njMWbHkcy2RFy1fFa321WSJEqSZKWWmnXXX2RZQMLdoUUEAAzpdDp6+/ZtedXKbZttaZEuQsG87qBFbNtWp9PRaDTSq1ev1Gg0lgYJ27aXBqurlksqB5UeHh7Kdd1bX39WUR+2ba/1PtwOWkQAYIO+//77qedhGMpxnCsvIz09PV17X9VqdW7ouE73Q7/f1+7urr755psr173qhL5o+WTdtNttDQYDRVG0sLzrrr9I8TugW8YMgggAbNhsqHjz5s2lVgbLssrBk1EUKUmStbtUikuFi+1kWaYsy668RHjSZFdHGIZKkuRO594o6qYY7zE5SHdet8s66897fxAEOj4+1uvXr29SbNwAXTMAHpd7PNNpHMcaDAbKsmxqrIRlWXrz5o1OTk7KdX3f16tXr3R0dCTXdZVlWRlO4jguu1iyLJt6PtnaYFmWhsNh2WWRZZmGw6Ekldspfp5tDSiWp2mqwWAgz/PkOI5831e329Xe3p4cx1Ecx8qyrFxn9niXLZ9XN2ma6vXr17IsS61WqwwYg8GgrJ/BYCDLstZa37bt8niKIFUEk3fv3q18hQ1u31ae57npQixyfn6unZ0dnZ2daXt723RxANwjHz580Lt37/TixQt99dVXposDPEmL/g/XOX/TNQMAAIy5dhCp1WpT/W3FJWhBEFzqP1y2DAAAPF3XGiMSBMGlGehc1y1HHsdxLNd1y8lkli0DAABP19otIvNGHcdxrNPT03KwU6PRKAcFLVsGAACetrWDyOHhYTkquZAkyaWbCxUjlJctm/Xx40edn59PPQAAwOO1VhCJ41gvX7689PpoNJp7DfxoNFq6bNbh4aF2dnbKx/Pnz9cpHgAAeGDWCiLXmbFuHQcHBzo7Oysf79+/v7N9AQAA81YerNrr9XRwMH+ioHnTCGdZpv39/fI21vOWzXr27JmePXu2apEAAMADt3KLyNHRkV68eKFKpaJKpSJJevHihXq9nhzHuRQ20jQt5+5ftAwAADxtKweR4XCo8XhcPqSLaXE7nU5534IicMRxLMdxZNv20mUA8NQMBoNL8zA9Na7rTt03Z/J+OPdBt9tVrVZbad3ZY7lNcRyrWq1qa2tr7pWmWZZpa2tLlUpFg8HgRut3u111u101m82Nz/d1azOrRlEk3/cVBIHCMNSbN29WWgYAT0mj0bhXJ91NSJJkKnh1u93yS2qSJHJdV0dHR4ZKd9n+/v7CoLjsWG5bo9Eo78/T7/cvLT8+PpZlWarX6/I871rrNxoN2bYt3/fl+77CMJQkVSqVjf2dXvumd7O3qLFte+6BX7UMAG7Tp0+b3d+XX663/lO7uVqWZWo2m+XN9iRNnbiLLvz7ZNHv6KpjuQt7e3vyPE9BEMj3/allURRdmh5j3fXnHavv+0qSRM1mc+4VrreNu+8CeFT+6Z82u7/f/W6z+5snyzK9evVKu7u7Oj091evXr5Wm6dITSZIkOjo6UrVa1XA41OnpqcIwVBAEarfb5fva7bYklbNh93o92batKIpUrVbV6XQUx7G63a4ODg50dHSkOI4VhuHUBJaHh4fl9A/F3YBn56QqFHNQRVG08IvsbZZ/cnt7e3t6+/btwnItO5aiHor9DwYDdbvd8hjiONabN2/K4LXKcRbHMBgMFARBWWdFS1IURZdab9Zdf9E+m83m3Dsz3zZuegcAD1iWZarVanr58qX6/b5839fh4WF5Qlz0nlevXsn3fbVaLdVqtbIZfjIc2LatZrNZPi9Owp7nyff9cixB0d2UpqnCMFSr1SqXFV0FBwcHUxcwLDoZpmmqKIrU6XQURZGOj48vjcG47fJLKrfX6XTmXtW5yrE0Gg1lWabRaCTf99Xv99Vut7W7u1vWSxE2VjnOQr1eV6PRmAoq/X5/YZBbd/15ivBxcnKy8nuuixYRAI/K3/+96RJs1uHhoaS/nCRt29ZgMNDp6enCe3oFQTDVRL/qxQO2bZfdEsUJKssyWZYly7LKk9f+/v7SAZzL9jcYDJSmqXq9nqSLk/7s+rdd/uPj46ntrdMCMLtvy7LKIFNss9hetVotx2CscpyTut2uXNdVkiQrHe+66y+yu7t77feuiiAC4FFZd8zGfRMEwdJ+edd1p8YlDAaDueMUZscHTJo34/WqinESrusuXOcm42BGo9HSbptindss/+SYj01Z5TgnFYNKi66gRa1d111/VnHVzSaucCWIAMA9sk7zuSSdnp5OnZSLb9qtVqtsrZhnnSsiTk9PJenSuJN1Tm6z5VzEsqyyG2OyrLOtFLdZfsuy1t7eTQcdr3qc33//fflzu90uu5MW/Z2su/4iYRhubCAxY0QAYIOK8QTFyfGm6vV6+e01y7LyctLBYFB228xyXbccKCnpUhfO5Ik5iiIlSVLOO1FYdgf1eeM/Jl9bNljy5cuXiuNYQRBIUtnNdJfln91ekiRLfz/LjuWqYy+2u8pxzr6nCBOTrTnz9rfO+vPeHwSBjo+P9fr167nluXX5PXZ2dpZLys/OzkwXBcA988c//jH/53/+5/yPf/yj6aKsbDwe577v55Jy3/fz8Xh8422ORqPccZy80+nkrVYrHw6H+XA4zCXlYRgufF+r1col5Z7n5b7v57Ztl8v6/X5uWVbueV7e7/fzRqORR1GUj8fj3Lbt3HGcPAzD3HGc3PO8PIqiXFLearXy8Xice56XS8qHw2G5L8dx8iiK8uFwmFuWlTcajXw8HpfPHcfJR6NRnud57vt+bllWbllW3u/377z8xT5t2849z8tbrVb5nnn7XXQsRT14njf3d91oNHLLssp6ueo4oygqy1T8rbRarXJ5GIbl+8MwXHv94XCY27adS8o7nU75N1T8Hlex6P9wnfP3Vp7PTAhyj5yfn2tnZ0dnZ2fa3t42XRwA98iHDx/07t07vXjxQl999ZXp4jxocRxPXfL60Dz08j9ki/4P1zl/0zUDAE9clmW31lVkwkMv/1NHEAGAJyxNU/X7fWVZ9iCnnn/o5QdXzQDAk1bMMvpQPfTygxYRAABgEEEEAAAYQxABAADGEEQAAIAxBBEAAGAMQQQANmgwGKhWqy2d5vyxc1136u68aZqudeltHMeqVqva2tpSt9tVu92+tM04jlWpVFSpVNTtdstHrVZTt9u9cvmi/c2b2j7LMm1tbalSqZRTyV93/aIczWbzUjkerZXmcDWEKd4BLPIQp3jP84tp3iXdyvTuD8VwOJw63mK69WKZbdt5p9NZa5utVmtqWvdiWvvJadk9z8sdx7n0Xt/3V1o+qdPplFOhzyqmlG80Gtdef/Z4im1MTgl/H93GFO+0iADABt30rq0PTZZlajabU681Go2yHm5yh9fJuiy2scqcIp1OZ+3le3t78jyvvEndpCiKVK/Xb7T+vL8L3/dVr9cv1d9jQxAB8Lj8+dNmH/dAcbJvt9tqNpvlLKPVanXhe5IkUbfbVRAE5fukizuvFl0KaZrKdd2pu7f2ej0NBgO12231ej1JF10XtVpNg8FAzWZTlUqlvNNtHMdK01SHh4dKkkRJkqjZbM49QRfiOFav15Prumq32yvVQdEts7+/v3S9Zfu9anm73VaWZVPrJEki13XnBol111+0z3W7rh4aZlYF8Lj8v/+02f3977/b7P5mZFmmWq0m3/fled7USX/RSTzLMr169UrD4VDSxcnX931JF7eOL95n27aazabCMJSkctvj8ViNRkOVSkWdTkeNRkNJkihNU4VhWI5zGA6H8jxPknRwcFCefNM0XThGJk1TRVEk3/fV6XRUqVTkum65ndl12+22Tk5OlCSJWq3WpfXSNFW32y3vR7O7u7vW8kn1el2NRkP9fl+tVkuS1O/31e/357bErLv+PEVLz8nJybVbju47gggAPGCHh4eSVJ6AbdvWYDDQ6enpwpNdEARTXQO2ba+0L9u2y/BycnIi6SLUWJYly7LKE+X+/v7UwNF521lkMBgoTdOyteXg4GDp+tVqVUEQKAzDuWHFtu0yZBX3pVln+axutyvXdZUkyUr1tu76iywLSA8dQQTA4/Jf/t50CW4kCIKlt7N3XVeNRqN8PhgMpp4XipPrPKPR6NpjVYpuoMnumlk3GQczGo3kum7ZgrCMbdvqdDoajUZ69erV1NiTResv6+q5arl0Mb7Ftm0dHh6u1HW07vqziqtubhJi7juCCIDH5bMvTZfgRlY5AU86PT2dOvkWLQqtVqtsrZhnnTEHp6enki5Ois1mswxK65xUZ8u5iGVZCsNwqh6SJFnaLdHv9xXHsb755puyxWaRq07oi5Z///335c/tdru8tHbR72vd9RcJw/BGA3ofAgarAsAGFWMjipP7TdXr9fJbc5Zl6na7ajQaGgwGZbfNLNd1FcdxGUZmu3Asy5paliRJOd9FYd78GIV54z8mX1s2h8rLly8Vx3E5wLPoZrpqP2EYlgNw70pRjiJMTLYKzTumddaf9/4gCHR8fKzXr1/fpNj3311dW3wbmEcEwCIPcR6R8Xic+76fS8p937+VuURGo1HuOE7e6XTyVquVD4fDck6NMAwXvq/VauWScs/zct/3p+awKOa58Dwv7/f7eaPRKOf+sG07dxwnD8Mwdxwn9zwvj6Iol5S3Wq18PB7nnuflksr5L1qtVu44Th5FUT4cDss5NMbjcfnccZx8NBrleX4xj4dlWbllWXm/379U9mLukdljnKzbKIpyy7IW1sNVy2fXtW079zyv/J21Wq1yeRiGZXnDMFx7/cnj6XQ65e+yqM/77DbmEdnK8zw3E4Gudn5+rp2dHZ2dnWl7e9t0cQDcIx8+fNC7d+/04sULffXVV6aL86DFcax2u710bAowz6L/w3XO33TNAMATV1y6CphAEAGAJ6y4ZLWYBA3YNK6aAYAnzLbtlSfXAu4CLSIAAMAYgggAADCGIAIAAIwhiAAAAGMIIgAAwBiCCAAAMIYgAgAbEsexqtWqtra25t6rJcsybW1tqVKpaDAYrLSdbrerbrerZrM59z4rrusu3dZtWbafbrerWq228L1BEKhSqSy9B81tuqo8hcFgoEqlsvS+Otd1k22nabpwzpdVj+0+IYgAwIY0Gg15nifp4o6xs46Pj2VZlur1erneou0Ut5f3fV++7ysMQ0lSpVKZOkkVN8G7a8v2s7+/vzRkfPvttxsLIVeVJ0mScpnneXdWrutuO0kSua6ro6Ojucuvquv7iAnNADwuP/642f39p/+01up7e3vyPE9BEMj3/allURSpXq+vtB3Lsi695vu+kiRRs9ks7xuziRBy1X7mlXWd5bdt0f6yLFOz2dRwONxoedbhOI4cx1m4fNN1eRtoEQHwuPzn/7zZxzW0221lWVbe6l76yzfd2RNJkiTq9Xrq9XpqNptXftttt9tl030RSib30+v1NBgM1G631ev1JF10ExRdK9VqVb1eT3Ecq1arKQgCdbtdVatVBUGgOI7VbDanWl7m7SdJEnW7XfV6vbmtP/McHx+rVqtd6pqaV2bpohUmCAK5rqs4jiVddFv1ej25rqt2u71WeeI4VpqmOjw8nGpVKo5vslzz6mzZ/ueVddG2i9d7vZ6CIFCz2VzahXOdur5X7ubGwLdjndsIA3haFt1+PJc2+1iT7/v5eDzOG41G7jhO+Xpxm3jP8/JGo5HneV6uV3AcJ+/3+3me53mn08lt2760/dFolEsq13McJ/d9v1xmWVa57eIUUPzc6XTy0WiUD4fDPM/z3LbtvNPp5Hme51EU5ZLKZcWt6ifLVuyneD55zPPKOmmyzL7v55Ly8Xi8sMzD4TD3PK98PQzDfDQaleXN8zy3LCsPw3Ct8hT7XVSuYjvz6mzR/ueV9aptF8ec5xd1P/nc87yp/axb17dp0f/hOudvWkQAPC7//u+bfVxTt9stWy0WtXIU36ALw+FQrVZrpe3v7u5KuriXTMG27bLb4eTkRNJFd0TRCvPy5UvZtl02/VuWpf39fUkqu4yKZdVqdepb+uR+giCY6mJa1pUw6dtvv5UkdTodWZalOI4Xltm2bQ0GAwVBIMuy5HmeBoOB0jQtW5AODg5k2/a1y1Moup0cxymPeV6dLdr/vLIu2/ZseYt15g0Gvumx3QeMEQHwuKw5ZsOUYrDp4eHhpWb8wmg0UrVaXWu7xclsMhhMKsZBTAac27ZsjMXk2BjLshaua9u2Tk9PJc0vs2VZ6vf7arfb6vf7evPmjUajkVzXvRTWNtVdsWj/RRkmy7psLEcxvmeSbdtzu2fu83iWVdEiAgAb9P3335c/t9ttDQYDRVE095usZVmX7ox71RiRMAwXDmhM01TNZlNhGK7csnIdlmUtHNPQarU0Go00Go2WnkSzLFO9Xl9Y5izLym1JFy1MlmWVVw8VkiRZWp55igC0rkX7n1fWZWZbmwqL/kbu4vLiTSKIAMCGFSe64sQ6+U1/Mmi8fPlScRyXg0AHg8FU98SsIAh0fHys169fz93e5CDJVU5e8/Yx+drkCXvy9WJA5uRg1nVO7kXXi+M4C8t8cnKiJEnKS5jTNJ1bX6enp2uX57qXvy7a/7yyLtNqtabmCsmyTFmWzb0y6aZ1fS/c1QCW28BgVQCLLByseo9FUZTbtp17nlcOiJwc8BmGYW5Z1tQgy36/X75WDGwcDoe5bdvlYMli4Gir1ZoaaDkcDnPLsvJGo5GPx+N8PB7ntm3njuPkYRjmjuPknuflYRjmkqbeXwxOLcpaDCCdHGxrWVY+HA4v7SfP/zJo0vO8vNVq5Y1GI4+iaGHdtFqt3PO8vN/vl/vI83xhmaMoyhuNRh6GYd7pdMpBtL7vX6qvdcrTarVyx3HyKIryfr9f1vF4PM5brVYuKY+iaG6dLdr/vLIu23bxu5tXH0VdO46Tj0aja9X1bbqNwapbeZ7nhjLQlc7Pz7Wzs6OzszNtb2+bLg6Ae+TDhw969+6dXrx4oa+++sp0cYAnadH/4Trnb7pmAACAMQQRAABgDEEEAAAYQxABAADGEEQAPGj3eLw98Ojdxv8fQQTAg/TZZ59Jkj59+mS4JMDT9dNPP0mSvvjii2tvgyneATxIn3/+uX75y1/q3/7t3/TFF1/oF7/gexWwKXme66efftJ3330ny7LKLwbXQRAB8CBtbW3pN7/5jd69e6d/+Zd/MV0c4EmyLEu//vWvb7QNggiAB+vLL7/U3/7t39I9AxjwxRdf3KglpEAQAfCg/eIXv2BmVeABo1MVAAAYQxABAADGEEQAAIAxBBEAAGAMQQQAABhDEAEAAMYQRAAAgDEEEQAAYAxBBAAAGEMQAQAAxhBEAACAMQQRAABgzFpBJEkS1Wo1bW1tqdlsTi1L01TtdltBEKjb7a68DAAAPF0rB5EsyxTHsYbDocbjseI4VhAE5XLXddVut9VqteS6rlzXXWkZAAB4urbyPM9XWTHLMlmWVT5vNpt6+fKlPM9THMdqNpsaj8d/2fDWlkajkdI0XbjMtu2l+zw/P9fOzo7Ozs60vb295qEBAAAT1jl/r9wiMhlCsizT7u6uPM+TdNFlU6/Xp9a3bVtxHC9dNuvjx486Pz+fegAAgMdr7cGqg8FAtVpNcRwrTVNJ0mg0mgoq0kVwGY1GS5fNOjw81M7OTvl4/vz5usUDAAAPyNpBxPM8hWEoSWq327damIODA52dnZWP9+/f3+r2AQDA/XKty3cdx1G/39fJyYkkqVqtKsuyqXWyLNP+/v7SZbOePXum7e3tqQcAAHi8rj2PSL1eLwebOo5TdtMU0jSV4zhLlwEAgKdtrct3JwNFHMc6ODiQJDUaDUkql8dxLMdxZNv20mUAAOBp+3zVFYvLcBuNhlzXlWVZZciQpCiK5Pu+arWahsOh3rx5s9IyAADwdK08j4gJzCMCAMDDcyfziAAAANw2gggAADCGIAIAAIwhiAAAAGMIIgAAwBiCCAAAMIYgAgAAjCGIAAAAYwgiAADAGIIIAAAwhiACAACMIYgAAABjCCIAAMAYgggAADCGIAIAAIwhiAAAAGMIIgAAwBiCCAAAMIYgAgAAjCGIAAAAYwgiAADAGIIIAAAwhiACAACMIYgAAABjCCIAAMAYgggAADCGIAIAAIwhiAAAAGMIIgAAwBiCCAAAMIYgAgAAjCGIAAAAYwgiAADAGIIIAAAwhiACAACMIYgAAABjCCIAAMAYgggAADCGIAIAAIwhiAAAAGMIIgAAwBiCCAAAMIYgAgAAjCGIAAAAYwgiAADAGIIIAAAwhiACAACMIYgAAABjCCIAAMAYgggAADCGIAIAAIwhiAAAAGMIIgAAwBiCCAAAMIYgAgAAjCGIAAAAYwgiAADAGIIIAAAwhiACAACMIYgAAABjCCIAAMAYgggAADCGIAIAAIwhiAAAAGMIIgAAwBiCCAAAMIYgAgAAjCGIAAAAYwgiAADAmLWCSBzHqlar2traUrPZnFqWpqna7baCIFC32115GQAAeLpWDiJZlikMQ0VRpOFwqDiO1W63y+Wu66rdbqvVasl1Xbmuu9IyAADwdG3leZ6vsuJgMJDneeXzXq+no6OjMpQ0m02Nx+O/bHhrS6PRSGmaLlxm2/bSfZ6fn2tnZ0dnZ2fa3t5e99gAAIAB65y/V24RmQwhkmRZVhkkkiRRvV6fWm7btuI4XroMAAA8bZ9f941RFJVdM6PRSJZlTS23LEuj0UhZli1cNuvjx4/6+PFj+fz8/Py6xQMAAA/Ata6aSdNUu7u7ajQat1qYw8ND7ezslI/nz5/f6vYBAMD9cq0g4vu++v1++bxarSrLsql1sizT/v7+0mWzDg4OdHZ2Vj7ev39/neIBAIAHYu0gMu8SXMdxlKbp1GtpmspxnKXLZj179kzb29tTDwAA8HitFUQGg4Hq9Xo5SDVNU8VxXHbRFIEjjmM5jiPbtpcuAwAAT9vKg1WLS3RnFVf/RlEk3/dVq9U0HA715s2bcp1lywAAwNO18jwiJjCPCAAAD8+dzCMCAABw2wgiAADAGIIIAAAwhiACAACMIYgAAABjCCIAAMAYgggAADCGIAIAAIwhiAAAAGMIIgAAwBiCCAAAMIYgAgAAjCGIAAAAYwgiAADAGIIIAAAwhiACAACMIYgAAABjCCIAAMAYgggAADCGIAIAAIwhiAAAAGMIIgAAwBiCCAAAMIYgAgAAjCGIAAAAYwgiAADAGIIIAAAwhiACAACMIYgAAABjCCIAAMAYgggAADCGIAIAAIwhiAAAAGMIIgAAwBiCyDV9+iT97ncXj0+frrGBP3+S/p/fXTz+fJ0NAABwAz/+KG1tXTx+/NFYMQgiAADAGIIIAAAwhiACAACMIYgAAABjCCIAAMAYgggAADCGIAIAAIwhiAAAAGMIIgAAwBiCCAAAMIYgAgAAjCGIAAAAYwgiAADAGIIIAAAwhiACAACMIYgAAABjCCIAAMAYgggAADCGIAIAAIwhiAAAAGMIIgAAwBiCCAAAMIYgAgAAjCGIAAAAYwgiAADAGIIIAAAwhiACAACMIYgAAABjCCIAAMAYgggAADCGIHJd/92X3v3Pi8d/902XBgCAB4kgAgAAjCGIAAAAYwgiAADAmLWCyGAwUK1WU5ZlU6+naap2u60gCNTtdldeBgAAnra1gkij0VCSJJded11X7XZbrVZLruvKdd2VlgEAgKdtrSBiWdal1+I41unpqRzHkXQRVuI4VpqmS5cBAADceIxIkiSq1+tTr9m2rTiOly4DAAD4/KYbGI1Gl1pKLMvSaDRSlmULl83z8eNHffz4sXx+fn5+0+IBAIB77F5dNXN4eKidnZ3y8fz5c9NFAgAAd+jGQaRarV66iibLMu3v7y9dNs/BwYHOzs7Kx/v3729aPAAAcI/dOIg4jnNp8GmapnIcZ+myeZ49e6bt7e2pBwAAeLzWCiJF68bp6Wn5WqPRkKQycMRxLMdxZNv20mUAAAArD1bNskxBEEi6mNis1WqVA1GjKJLv+6rVahoOh3rz5k35vmXLAADA07ZyELEsS51OR51O59Iy27bV7/fnvm/ZMgAA8LTd+PLdJ+P3hzMv3KsLjgAAeJA4mwIAAGNoEbktky0mvz0wVw4AAB4QWkQAAIAxBBEAAGAMQQQAABhDEAEAAMYQRAAAgDEEEQAAYAxBBAAAGEMQAQAAxhBEAACAMQQRAABgDEEEAAAYQxABAADGEEQAAIAxBBEAAGAMQQQAABhDEAEAAMYQRAAAgDEEEQAAYAxBBAAAGEMQAQAAxnxuugCP0u8Pp5//9sBMOQAAuOdoEQEAAMYQRAAAgDEEEQAAYAxjRBaZHecBAABuHS0iAADAGIIIAAAwhiACAACMIYgAAABjCCIAAMAYgggAADCGIAIAAIwhiAAAAGMIIgAAwBiCCAAAMIYgAgAAjCGIAAAAYwgiAADAGIIIAAAwhiACAACMIYgAAABjCCIAAMCYz00X4F75/aHpEgAA8KTQIgIAAIwhiAAAAGMIIgAAwBiCCAAAMIYgAgAAjCGIAAAAYwgiAADAGOYR2YTZ+Ul+e2CmHAAA3DO0iAAAAGMIIgAAwBiCCAAAMIYgAgAAjCGIAAAAYwgiAADAGIIIAAAwhiACAACMIYgAAABjCCIAAMAYgggAADCGIAIAAIzhpncm/P5Qyv8k/fv/vHj+X8wWBwAAU552EJm9Ky4AANgoumYAAIAxGwkiaZqq3W4rCAJ1u91N7BIAADwAG+macV1XYRjKcRzFcSzXdRVF0SZ2DQAA7rE7DyJxHOv09FSO40iSGo2GXNdVmqaybfuud/8w/A9f2vr/fxW/PTBbFgAANujOu2aSJFG9Xp96zbZtxXF817sGAAD33J23iIxGI1mWNfWaZVkajUaX1v348aM+fvxYPj87O5MknZ+f303hfvxw7bd++o9f6OOnHyVJ5z9+0Jdf/LzeBvI/ST/96eLnrQ9/aRG5q2MFAGDSjz/+5efzc+nPf761TRfn7TzPr1z3Xl2+e3h4qH/8x3+89Prz588NlGZ1/+d/u+kW/u+Jn/+Pm24MAID1fP31nWz2hx9+0M7OztJ17jyIVKtVpWk69VqWZdrf37+07sHBgf7u7/6ufP7zzz/r9PRUe3t7+uGHH/T8+XO9f/9e29vbd13sJ+n8/Jw6vmPU8d2jju8edXz3Hnod53muH374QV+vEHDuPIg4jqN+vz/1Wpqm5eDVSc+ePdOzZ8+mXiu6dba2tiRJ29vbD/KX8pBQx3ePOr571PHdo47v3kOu46taQgp3Pli10WhIUtkqEsexHMfhihkAALCZMSJRFMn3fdVqNQ2HQ71582YTuwUAAPfcRoKIbduXumfW9ezZM/3DP/zDpa4b3B7q+O5Rx3ePOr571PHde0p1vJWvcm0NAADAHeCmdwAAwBiCCAAAMIYgAgC4VVmWmS4CHpB7FUTSNFW73VYQBOp2u1euPxgMVKvV+KNfwzp1HMexqtWqtra21Gw2N1TCh2+dOk6SRLVajTpe07qfFQU+L1a3bh0XnxX8La/uun/HSZI8rvu15feIbdv5cDjM8zzPoyjKG43G0vXH43EuKR+Pxxso3eOwah2Px+O81Wrlo9EoHw6HuWVZeavV2mRRH6x16tj3/fJny7Lyfr+/sXI+ZOt+VuR5nvf7fT4v1rBOHUdRlIdhmI/HY+p3Dev+HQ+Hw7zRaORRFG2ieBtzb4JIFEW5ZVlTr0nKR6PR0vfxwbK6deo4DMOp577v547j3Gn5HoN16nj279bzvEv1jsuu81kxHo8JImtYt449z8t93y9PqrjaunVcfCG86pz4EN2brpkkSVSv16des237cTU/GbZOHXueN/Xcsixmw13BOnU8eVfqLMu0u7t7qd5x2XU+Kw4PD9Vqte66aI/GunWcZZm63a5qtZra7fYmivjgrVvHzWZTBwcHj/Jz+N4EkdFoNPXBLF18UI9GIzMFeoRuUsdRFPEBs4Lr1HEx1imO40s3iMRl69ZxHMd6+fLlBkr2eKxbx1EUKc9z9ft9BUGgXq+3gVI+bOvUcfHZMBqN1Gw2Va1WFQTBhkp69+5NEMH9laapdnd3y/sG4XZ5nqcwDCWJsHcHoiiae5NN3L5WqyXf93V0dGS6KI9KkiTlDOVhGCoMQ7Xb7UfzxeXeBJFqtXppNHuWZdrf3zdToEfounXs+/6Np+h/Kq5bx8Vdqk9OTu6wdI/DOnXc6/V0cHCwoZI9Hjf5PPY8jyuTVrBuHU+2njiOI8uyHs3QhXsTRBzHuZTu0jTlm8wtuk4dr3tZ2VN3k7/jer3+KPt/b9s6dXx0dKQXL16oUqmoUqlIkl68eEHXwRVu+nnM5/bV1qnjeevu7u5qd3f3Tsu4MaZHy06ybbscERxF0dRVGsPh8NJo4eLy3cc4iviurFPHYRhOjYIfjUaP7rKxu7BqHY/H40v1zVUzq1n3s6IgrppZ2ap1PPu50Ol0uHpmRev8HU9e6pvneW5Z1qP5W75XQWQ0GuWtVivv9/t5q9WaquTi8rBCMQeDpNz3/UfzC7lrq9ZxFEW5pEsPXG3VOh4Oh7lt23mr1crDMCTkrWGdz4pJBJHVrfNZYVlW7nle3u/3CSFrWOfveDQalXX82MIed98FAADG3JsxIgAA4OkhiAAAAGMIIgAAwBiCCAAAMIYgAgAAjCGIAAAAYwgiAADAGIIIAAAwhiACAACMIYgAAABjCCIAAMCY/wX2oMd+m7vH5AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(statistics_quad, alpha=0.5, label=\"Null of quadratic time MMD\")\n",
    "plt.hist(statistics_rff, alpha=0.5, label=\"Null of RFF MMD\")\n",
    "plt.vlines(np.quantile(statistics_quad,1-alpha),**limits,color=\"blue\", alpha=.5, label=\"$1-\\\\alpha$ quantile quad time MMD\")\n",
    "plt.vlines(np.quantile(statistics_rff,1-alpha),**limits,color=\"orange\", alpha=.5, label=\"$1-\\\\alpha$ quantile RFF MMD\")\n",
    "plt.vlines(quadmmd.threshold(n=n,m=m,alpha=alpha),**limits,color=\"red\", label=\"McDiarmid-based threshold\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "104522a6-2223-47fb-8467-55c05adedf0c",
   "metadata": {},
   "source": [
    "The figure shows that the McDiarmid-based threshold is very conservative, while, as expected, the simulated quantiles of the quadratic time estimator and the RFF-based estimator match relatively well."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "78787d43-a909-4589-ba98-a1a3a1f42931",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.18584610944249194)"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.sqrt(3/(4*n)*np.log(1/alpha))"
   ]
  },
  {
   "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
}
