{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c92a03d7-4df3-4fab-a7df-453e0cdbaf32",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-07-30 08:33:20.380292: I external/local_xla/xla/tsl/cuda/cudart_stub.cc:32] Could not find cuda drivers on your machine, GPU will not be used.\n",
      "2025-07-30 08:33:20.385045: I external/local_xla/xla/tsl/cuda/cudart_stub.cc:32] Could not find cuda drivers on your machine, GPU will not be used.\n",
      "2025-07-30 08:33:20.398578: E external/local_xla/xla/stream_executor/cuda/cuda_fft.cc:467] Unable to register cuFFT factory: Attempting to register factory for plugin cuFFT when one has already been registered\n",
      "WARNING: All log messages before absl::InitializeLog() is called are written to STDERR\n",
      "E0000 00:00:1753857200.421343 1519624 cuda_dnn.cc:8579] Unable to register cuDNN factory: Attempting to register factory for plugin cuDNN when one has already been registered\n",
      "E0000 00:00:1753857200.427701 1519624 cuda_blas.cc:1407] Unable to register cuBLAS factory: Attempting to register factory for plugin cuBLAS when one has already been registered\n",
      "W0000 00:00:1753857200.445904 1519624 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1753857200.445932 1519624 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1753857200.445936 1519624 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1753857200.445941 1519624 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "2025-07-30 08:33:20.452297: I tensorflow/core/platform/cpu_feature_guard.cc:210] This TensorFlow binary is optimized to use available CPU instructions in performance-critical operations.\n",
      "To enable the following instructions: AVX2 FMA, in other operations, rebuild TensorFlow with the appropriate compiler flags.\n"
     ]
    }
   ],
   "source": [
    "import itertools\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from tqdm import tqdm\n",
    "\n",
    "from changepoynt.algorithms.rulsif import RuLSIF\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "\n",
    "from online_rff_mmd import data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "e27bed55-2424-481f-99b5-440a7ce54605",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_pre = 64\n",
    "n_post = 64"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "4d1bd259-86e4-4f47-a06c-7e77549f4967",
   "metadata": {},
   "outputs": [],
   "source": [
    "d=784\n",
    "P =  data.MNIST(n_pre,digit=0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "269677db-116b-4c5e-b02b-43567d4674df",
   "metadata": {},
   "outputs": [],
   "source": [
    "config = {\n",
    "    \"window_length\" : 10,\n",
    "    \"lag\" : 0,\n",
    "    \"n_windows\" : 50,\n",
    "    \"scoring_step\" : 1,\n",
    "    \"alpha\" : 0.1\n",
    "} # Corresponding to the settings in Section 4 of the RuLSIF article\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "f164326e-aa32-4a05-b47a-574114777fea",
   "metadata": {},
   "outputs": [],
   "source": [
    "changes = []\n",
    "for i in range(1,10):\n",
    "    detector = RuLSIF(**config)\n",
    "    Q = data.MNIST(n_post,digit=i)\n",
    "    signal = np.linalg.norm(np.concatenate((P.draw(),Q.draw())),axis=1)\n",
    "    scores = detector.transform(signal)\n",
    "    changes += [np.argmax(scores)] # as there is only a single change point, we use the location with the highest score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "3f1722c7-5ab1-455e-aaae-c78822abafb8",
   "metadata": {},
   "outputs": [],
   "source": [
    "changes = np.array(changes)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "f152c314-7ffc-4887-946f-961ac654a1df",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([63, 62, 61, 60, 67, 67, 63, 61, 62])"
      ]
     },
     "execution_count": 58,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "changes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "69c79eb5-174f-43f1-a7ae-a2fde33933e4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Too early:  7\n",
      "Average:  3.0\n"
     ]
    }
   ],
   "source": [
    "print(\"Too early: \", np.sum(changes<n_pre))\n",
    "print(\"Average: \", np.mean(changes[changes>=n_pre])-n_pre)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "47c1c436-3329-4ff3-bc39-ddb3e12c4545",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Axes: >"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.lineplot(scores)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fee22823-8411-478b-ace3-9c2a22e48d62",
   "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
}
