{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "28957320-6da2-4e9e-9962-d0f264623905",
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.metrics.pairwise import rbf_kernel\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from mmdew.fast_rbf_kernel import est_gamma\n",
    "from mmdew.mmdew import MMDEW\n",
    "from tqdm import tqdm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c42ddd39-b9c3-4eb7-8c66-9637b3419a71",
   "metadata": {},
   "outputs": [],
   "source": [
    "rng = np.random.default_rng()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f2643bff-2b1a-4337-b075-39b8ade478f3",
   "metadata": {},
   "outputs": [],
   "source": [
    "d=20"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "6cd32cc5-113e-4101-a652-a7c5d1ccbef3",
   "metadata": {},
   "outputs": [],
   "source": [
    "ref_size=1000\n",
    "reps=25\n",
    "target_arl=25000"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "35de9712-e704-4e9e-8cc1-59ba3a99ab08",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████| 25/25 [2:57:26<00:00, 425.84s/it]\n"
     ]
    }
   ],
   "source": [
    "statistics = []\n",
    "\n",
    "for _ in tqdm(range(reps)):\n",
    "    ref = rng.normal(size=(ref_size,d))\n",
    "    gamma = est_gamma(ref)\n",
    "    detector = MMDEW(gamma=gamma)\n",
    "    \n",
    "    data = rng.normal(size=(target_arl*10,d))\n",
    "    \n",
    "    for elem in data:\n",
    "        detector.insert(elem.reshape(1,-1))\n",
    "    statistics += detector.stats[64:] # the first few have large variance"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "55136c65-b9cc-4eca-8ab0-eb24fd3fed0a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7cd786944ec0>]"
      ]
     },
     "execution_count": 61,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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REREAMzIGenVqxckyXBpFH3VVXv16oWDBw8qPRURERFVAXY5m4aIiIgqlpF+BptjMEJERESQBBaEZzBCREREQjEYISIiIqEYjBAREZFQDEaIiIgIAlNGGIwQERGRWAxGiIiISCgGI0RERCQUgxEiIiISisEIERERicxfZTBCREREYjEYISIiIqEYjBAREZFQDEaIiIhIKAYjREREBIkVWImIiKiqYjBCREREQjEYISIiIqEYjBAREZFQDEaIiIgIksAarAxGiIiIiLNpiIiIqOpiMEJERERCMRghIiIioRiMEBERkcD0VQYjREREBEASmMHKYISIiIiEYjBCREREQjEYISIiIqEYjBARERETWImIiKjqYjBCREREQjEYISIiIqEYjBAREZFQDEaIiIhIaAYrgxEiIiISisEIERERCcVghIiIiIRiMEJERESAStypGYwQERERE1iJiIio6mIwQkREREIxGCEiIiKhGIwQERGRUAxGiIiICJLADFYGI0RERASJs2mIiIioqmIwQkREREIxGCEiIiIO0xAREZFYAmMRBiNEREQESAK7RhiMEBERkVAMRoiIiEgoBiNERETkeDkjc+fORVBQENzd3REeHo6EhASj+8+ZMwetWrWCh4cHAgICMGnSJNy5c8esBhMREVHlojgYWbVqFaKjozFt2jQcOHAAwcHBGDBgAK5du6Z3/+XLl+Odd97BtGnTcOLECSxatAirVq3Cu+++a3HjiYiIyPEpDkZmz56N8ePHY+zYsWjbti1iY2NRvXp1LF68WO/+u3fvRvfu3fHss88iKCgI/fv3xzPPPGOyN4WIiIiqBkXBSGFhIRITExEZGXn/AE5OiIyMRHx8vN7ndOvWDYmJiZrg4/z589iwYQMeeeQRg+cpKChATk6Ozg8RERFVTi5Kds7MzERxcTH8/Px0tvv5+eHkyZN6n/Pss88iMzMTPXr0gCRJKCoqwssvv2x0mCYmJgbTp09X0jQiIiKyQKWuwLp9+3bMnDkT3377LQ4cOIDffvsN69evx0cffWTwOZMnT0Z2drbmJzU11dbNJCIiIkEU9Yz4+PjA2dkZ6enpOtvT09NRv359vc+ZMmUKRo0ahXHjxgEA2rdvj/z8fLz44ot477334ORUPh5yc3ODm5ubkqYRERGRg1LUM+Lq6orQ0FDExcVptqnVasTFxSEiIkLvc27dulUu4HB2dgYgtvQsERER2QdFPSMAEB0djTFjxiAsLAxdunTBnDlzkJ+fj7FjxwIARo8ejYYNGyImJgYAMHjwYMyePRshISEIDw/H2bNnMWXKFAwePFgTlBAREVHVpTgYGT58ODIyMjB16lSkpaWhY8eO2LhxoyapNSUlRacn5P3334dKpcL777+Py5cvo169ehg8eDA+/vhj6/0VREREZCFxoxUqyQHGSnJycuDl5YXs7Gx4enpa7bhB76y32rGIiIgc2bwRnTCwfQOrHlPu9Ztr0xAREZFQDEaIiIhIKAYjREREJBSDESIiIhKYvspghIiIiARjMEJERERCMRghIiIioRiMEBERUeVetZeIiIjsnyQwhZXBCBEREQnFYISIiIiEYjBCREREQjEYISIiIqEYjBARERFn0xAREVHVxWCEiIiIhGIwQkRERFwoj4iIiKouBiNEREQESWAGK4MRIiIiEorBCBEREQnFYISIiIiEYjBCREREQjEYISIiIqEYjBAREZFQDEaIiIhIKAYjREREJBSDESIiIhKKwQgRERFBYAFWBiNEREQkFoMRIiIiEorBCBEREUECF8ojIiKiKorBCBERETGBlYiIiKouBiNEREQkFIMRIiIiEorBCBERETFnhIiIiMQSGIswGCEiIiKxGIwQERGRUAxGiIiISCgGI0RERARJYAYrgxEiIiISisEIERERCcVghIiIiIRiMEJERERCMRghIiIiFj0jIiIiwVgOnoiIiKoqBiNEREQkFIMRIiIiEorBCBEREUESmDTCYISIiIiEYjBCREREQjEYISIiIghcJ8+8YGTu3LkICgqCu7s7wsPDkZCQYHT/mzdvIioqCg0aNICbmxtatmyJDRs2mNVgIiIisj6RRc9clD5h1apViI6ORmxsLMLDwzFnzhwMGDAAp06dgq+vb7n9CwsL0a9fP/j6+uKXX35Bw4YNcfHiRdSuXdsa7SciIiIrENkzojgYmT17NsaPH4+xY8cCAGJjY7F+/XosXrwY77zzTrn9Fy9ejKysLOzevRvVqlUDAAQFBVnWaiIiIqo0FA3TFBYWIjExEZGRkfcP4OSEyMhIxMfH633OH3/8gYiICERFRcHPzw/t2rXDzJkzUVxcbPA8BQUFyMnJ0fkhIiKiyklRMJKZmYni4mL4+fnpbPfz80NaWpre55w/fx6/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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(statistics)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "e36dd8c0-ab20-4fa0-a906-d8003c0e8955",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.11409939373247)"
      ]
     },
     "execution_count": 62,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.std(statistics)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "e800730e-934f-4632-93f1-544b198afeaa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.11409939373247)"
      ]
     },
     "execution_count": 63,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.std(statistics)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "4b66d407-4272-43ad-9d1d-82f4fd40157c",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "2f0b065e-6f78-4255-8d30-9d530edeb86c",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('mmdew-statistics.pickle', 'wb') as handle:\n",
    "    pickle.dump(statistics, handle, protocol=pickle.HIGHEST_PROTOCOL)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "acd8cf9c-7361-4c18-9361-2dfd170bae54",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('mmdew-statistics.pickle', 'rb') as handle:\n",
    "    b = pickle.load(handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "c372d216-e14c-48a9-a64d-273cf9ef5aea",
   "metadata": {},
   "outputs": [],
   "source": [
    "threshold = np.quantile(statistics, 1-(1/target_arl))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "id": "b599adc0-b961-4bc1-bd86-fe91b31d1946",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(1.0721815770388703)"
      ]
     },
     "execution_count": 68,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "threshold"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "id": "d0f2276a-999b-4bf4-a4ff-240a657b60ea",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.int64(12)"
      ]
     },
     "execution_count": 69,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.sum(detector.stats > threshold) # arl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "7818e5fb-10b1-4bde-8c3e-1e0068657b39",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(1.0721815770388703)"
      ]
     },
     "execution_count": 70,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "threshold #somewhat lower than the one given in their article's Figure 3 but we also have lower values of the test statistic for Figure 1. Might be due to a slight difference in the median heuristic."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "46c65ce3-f5d9-437e-8922-f1762920b44e",
   "metadata": {},
   "outputs": [],
   "source": [
    "target_arls_log = np.arange(3,5.1,.25)\n",
    "\n",
    "arl2thresh = { i : np.quantile(statistics, 1-(1/10**i)) for i in target_arls_log}"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2bf683d1-f6e0-4d0e-9173-a6be40c9a320",
   "metadata": {},
   "source": [
    "# q = N(0,2^2) or N(0,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "a7167fcf-ffbf-4ca2-bf64-0670f9f74eb6",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:39<00:00,  1.01it/s]\n"
     ]
    }
   ],
   "source": [
    "h1_stats = []\n",
    "\n",
    "for _ in tqdm(range(100)):\n",
    "    ref = rng.normal(size=(10000,d))\n",
    "    gamma = est_gamma(ref)\n",
    "    detector = MMDEW(gamma=gamma)\n",
    "    for elem in ref[:64]:\n",
    "        detector.insert(elem.reshape(1,-1))\n",
    "\n",
    "    q = np.where((rng.uniform(size=500)>0.9).reshape(-1,1), rng.normal(scale=2,size=(500,d)), rng.normal(size=(500,d)))\n",
    "\n",
    "    for elem in q:\n",
    "        detector.insert(elem.reshape(1,-1))\n",
    "    h1_stats += [detector.stats[64:]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "d4ddda08-7a7c-41f2-bb56-2aac8d8b901e",
   "metadata": {},
   "outputs": [],
   "source": [
    "arl2edd = {}\n",
    "for arl, thresh in arl2thresh.items():\n",
    "    edd = [np.argmax(s>thresh) for s in h1_stats]\n",
    "    arl2edd[arl] = np.mean(edd)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "e5e13721-9d02-4f38-8482-2766063b0847",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{np.float64(3.0): np.float64(10.33),\n",
       " np.float64(3.25): np.float64(10.48),\n",
       " np.float64(3.5): np.float64(10.48),\n",
       " np.float64(3.75): np.float64(10.56),\n",
       " np.float64(4.0): np.float64(10.65),\n",
       " np.float64(4.25): np.float64(10.65),\n",
       " np.float64(4.5): np.float64(10.71),\n",
       " np.float64(4.75): np.float64(10.87),\n",
       " np.float64(5.0): np.float64(10.87)}"
      ]
     },
     "execution_count": 56,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "arl2edd"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "edce8f2c-5f2c-4d04-9b55-244da3f9ffb1",
   "metadata": {},
   "source": [
    "# q = Laplace"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "dad282c8-1b87-4a94-a271-6d626a181e82",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:05<00:00,  1.52it/s]\n"
     ]
    }
   ],
   "source": [
    "h1_stats = []\n",
    "\n",
    "for _ in tqdm(range(100)):\n",
    "    ref = rng.normal(size=(10000,d))\n",
    "    gamma = est_gamma(ref)\n",
    "    detector = MMDEW(gamma=gamma)\n",
    "    for elem in ref[:64]:\n",
    "        detector.insert(elem.reshape(1,-1))\n",
    "\n",
    "    q = rng.laplace(scale=np.sqrt(2),size=(50,d))\n",
    "\n",
    "    for elem in q:\n",
    "        detector.insert(elem.reshape(1,-1))\n",
    "    h1_stats += [detector.stats[64:]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "91349812-0077-42b8-8758-532ec1861154",
   "metadata": {},
   "outputs": [],
   "source": [
    "arl2edd = {}\n",
    "for arl, thresh in arl2thresh.items():\n",
    "    edd = [np.argmax(s>thresh) for s in h1_stats]\n",
    "    arl2edd[arl] = np.mean(edd)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "570df76d-b10e-48fa-8dcb-62ace620fd9f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{np.float64(3.0): np.float64(0.22),\n",
       " np.float64(3.25): np.float64(0.23),\n",
       " np.float64(3.5): np.float64(0.26),\n",
       " np.float64(3.75): np.float64(0.3),\n",
       " np.float64(4.0): np.float64(0.36),\n",
       " np.float64(4.25): np.float64(0.42),\n",
       " np.float64(4.5): np.float64(0.42),\n",
       " np.float64(4.75): np.float64(0.47),\n",
       " np.float64(5.0): np.float64(0.47)}"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "arl2edd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4cbbd7d0-8ff8-47cc-9108-e0a1d0bab18e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "6d5e12c6-e740-4c24-99aa-037f9123bae5",
   "metadata": {},
   "source": [
    "# q = Uniform"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "a21deb90-26c5-48b8-b9da-267322144e17",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:05<00:00,  1.52it/s]\n"
     ]
    }
   ],
   "source": [
    "h1_stats = []\n",
    "\n",
    "for _ in tqdm(range(100)):\n",
    "    ref = rng.normal(size=(10000,d))\n",
    "    gamma = est_gamma(ref)\n",
    "    detector = MMDEW(gamma=gamma)\n",
    "    for elem in ref[:64]:\n",
    "        detector.insert(elem.reshape(1,-1))\n",
    "\n",
    "    q = rng.uniform(-1,1,size=(50,d))*np.sqrt(2)\n",
    "\n",
    "    for elem in q:\n",
    "        detector.insert(elem.reshape(1,-1))\n",
    "    h1_stats += [detector.stats[64:]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "1e5fb345-da75-45b2-aeb1-bbb5e8299f6d",
   "metadata": {},
   "outputs": [],
   "source": [
    "arl2edd = {}\n",
    "for arl, thresh in arl2thresh.items():\n",
    "    edd = [np.argmax(s>thresh) for s in h1_stats]\n",
    "    arl2edd[arl] = np.mean(edd)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "34bc5821-f3e3-4a98-9f3f-83bdc167c495",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{np.float64(3.0): np.float64(0.0),\n",
       " np.float64(3.25): np.float64(0.0),\n",
       " np.float64(3.5): np.float64(0.0),\n",
       " np.float64(3.75): np.float64(0.0),\n",
       " np.float64(4.0): np.float64(0.0),\n",
       " np.float64(4.25): np.float64(0.0),\n",
       " np.float64(4.5): np.float64(0.0),\n",
       " np.float64(4.75): np.float64(0.0),\n",
       " np.float64(5.0): np.float64(0.0)}"
      ]
     },
     "execution_count": 43,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "arl2edd"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f6db49f1-91ab-477e-b829-4387cc4f9eb4",
   "metadata": {},
   "source": [
    "# q = p"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "id": "cfd3aaee-2aeb-40b2-868d-8169c1be6635",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████| 100/100 [2:03:03<00:00, 73.83s/it]\n"
     ]
    }
   ],
   "source": [
    "h1_stats = []\n",
    "\n",
    "for _ in tqdm(range(100)):\n",
    "    ref = rng.normal(size=(10000,d))\n",
    "    gamma = est_gamma(ref)\n",
    "    detector = MMDEW(gamma=gamma)\n",
    "\n",
    "    q = rng.normal(size=(50000,d))\n",
    "\n",
    "    for elem in ref[:64]:\n",
    "        detector.insert(elem.reshape(1,-1))\n",
    "\n",
    "    for elem in q:\n",
    "        detector.insert(elem.reshape(1,-1))\n",
    "    h1_stats += [detector.stats[64:]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "id": "abc79f55-50eb-43a8-bcbf-329198f934e0",
   "metadata": {},
   "outputs": [],
   "source": [
    "arl2edd = {}\n",
    "for arl, thresh in arl2thresh.items():\n",
    "    edd = [np.argmax(s + [np.inf]>thresh) for s in h1_stats]\n",
    "    arl2edd[arl] = np.mean(edd)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "e42ae6ac-c626-4110-86f8-42d166e7e7ec",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{np.float64(3.0): np.float64(414.03),\n",
       " np.float64(3.25): np.float64(931.76),\n",
       " np.float64(3.5): np.float64(2015.29),\n",
       " np.float64(3.75): np.float64(3830.94),\n",
       " np.float64(4.0): np.float64(7430.41),\n",
       " np.float64(4.25): np.float64(13616.92),\n",
       " np.float64(4.5): np.float64(20712.46),\n",
       " np.float64(4.75): np.float64(28514.02),\n",
       " np.float64(5.0): np.float64(36807.7)}"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "arl2edd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d3cb7288-e11e-4988-b9ea-934d06434c06",
   "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
}
