{
 "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 seaborn as sns\n",
    "import kernel\n",
    "from tqdm import tqdm\n",
    "from itertools import chain\n",
    "import pandas as pd\n",
    "import data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "id": "65c85922-6f76-4f74-842c-056d729c0c34",
   "metadata": {},
   "outputs": [],
   "source": [
    "results = pd.DataFrame()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "id": "bd160d24-7d86-46fa-82dc-1bf2866efd7f",
   "metadata": {},
   "outputs": [],
   "source": [
    "rng = np.random.default_rng(1234)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "id": "1dcf5db1-5f51-4fe1-a772-e8a1c8a47895",
   "metadata": {},
   "outputs": [],
   "source": [
    "d=20"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "id": "db910d84-52b2-41ce-aa54-e0f676a82c94",
   "metadata": {},
   "outputs": [],
   "source": [
    "P = rng.normal(size=(2**13,d))   \n",
    "Q = data.MixedNormal(2**17,d,0.3) # larger last value is more difficut; 1 is H0\n",
    "gamma = 0.025232487341699427 # from ARL computation\n",
    "gauss = kernel.Gauss(gamma=gamma)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "id": "8419aa02-dc35-4cda-9b11-06bbc38b1f90",
   "metadata": {},
   "outputs": [],
   "source": [
    "target_arls = [100,1000,10000]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "id": "f2ff411b-8292-4686-b9a6-c12f102ca4e8",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_omegas = 1000"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "id": "14466b77-9944-4e8a-be6a-58bacdbdb02d",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [02:08<00:00,  1.28s/it]\n"
     ]
    }
   ],
   "source": [
    "runs=100\n",
    "for _ in tqdm(range(runs)):\n",
    "    P = rng.normal(size=(1024,d))   \n",
    "    for target_arl in target_arls:\n",
    "        cd = kernel.StreamingRFFMMD(gauss,d=d,num_omegas=num_omegas)\n",
    "        for i, elem in enumerate(np.concatenate((P,Q.draw()))):\n",
    "            cd.insert(elem)\n",
    "            if cd.has_change(min_arl=target_arl):\n",
    "                results = pd.concat((results,pd.DataFrame({\"num_omegas\" : [num_omegas],\n",
    "                                                           \"target_arl\" : [target_arl],\n",
    "                                                           \"delay\"      : [i-len(P)]})))\n",
    "                break\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "id": "6e54c0a3-36b4-472a-80c6-a73a948ef58e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>delay</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>num_omegas</th>\n",
       "      <th>target_arl</th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">100</th>\n",
       "      <th>100</th>\n",
       "      <td>400.98</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1000</th>\n",
       "      <td>544.27</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10000</th>\n",
       "      <td>720.52</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">1000</th>\n",
       "      <th>100</th>\n",
       "      <td>393.93</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1000</th>\n",
       "      <td>541.45</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10000</th>\n",
       "      <td>717.51</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                        delay\n",
       "num_omegas target_arl        \n",
       "100        100         400.98\n",
       "           1000        544.27\n",
       "           10000       720.52\n",
       "1000       100         393.93\n",
       "           1000        541.45\n",
       "           10000       717.51"
      ]
     },
     "execution_count": 106,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results.groupby([\"num_omegas\", \"target_arl\"]).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eb248311-40bc-4dd1-86fb-f3e1f988f02f",
   "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
}
