{
 "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": 35,
   "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "bd160d24-7d86-46fa-82dc-1bf2866efd7f",
   "metadata": {},
   "outputs": [],
   "source": [
    "rng = np.random.default_rng(1234)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "7f7b3495-c152-419e-9449-88f95c805e0c",
   "metadata": {},
   "outputs": [],
   "source": [
    "d=1\n",
    "gamma = kernel.Gauss.est_gamma(X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "0c19d67e-07a4-4e3e-8443-c4f1d2ad3b9c",
   "metadata": {},
   "outputs": [],
   "source": [
    "gauss = kernel.Gauss(gamma=gamma)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "id": "189bd7b4-1029-4594-a7be-aed5cb6fb5cd",
   "metadata": {},
   "outputs": [],
   "source": [
    "alpha2arl = { np.round(k,2) : [] for k in np.linspace(0.81,0.99,4)}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "id": "481813ee-3779-44b6-8158-578998206310",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{np.float64(0.81): [],\n",
       " np.float64(0.87): [],\n",
       " np.float64(0.93): [],\n",
       " np.float64(0.99): []}"
      ]
     },
     "execution_count": 69,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "alpha2arl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eba56446-4779-4118-a8c9-25b268d1a879",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|                                                    | 0/50 [00:00<?, ?it/s]"
     ]
    }
   ],
   "source": [
    "for _ in tqdm(range(50)):\n",
    "    for alpha in alpha2arl.keys():\n",
    "        X = rng.normal(size=(2**17,d))   \n",
    "        cd = kernel.StreamingRFFMMD(gauss,d=d,num_omegas=10)\n",
    "        for i, elem in enumerate(X):\n",
    "            cd.insert(elem)\n",
    "            if cd.has_change(alpha=alpha):\n",
    "                alpha2arl[alpha] += [i]\n",
    "                break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "id": "8a1c980d-74c8-448f-8e49-effae319df09",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{np.float64(0.81): np.float64(2099.0),\n",
       " np.float64(0.87): np.float64(773.0),\n",
       " np.float64(0.93): np.float64(2303.0),\n",
       " np.float64(0.99): np.float64(159.0)}"
      ]
     },
     "execution_count": 73,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "{ k: np.median(v) for k,v in alpha2arl.items()}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "id": "6fbf3ae8-f400-4391-b1e1-9b8fa964fddd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{np.float64(0.81): [39, 4159],\n",
       " np.float64(0.87): [1031, 515],\n",
       " np.float64(0.93): [16895, 2303, 259],\n",
       " np.float64(0.99): [159, 33, 1039, 319, 8]}"
      ]
     },
     "execution_count": 72,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "alpha2arl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0442b383-f1a5-4c5b-8bfa-2f1480c3224c",
   "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
}
