{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c92a03d7-4df3-4fab-a7df-453e0cdbaf32",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-08-03 20:28:38.897620: 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-08-03 20:28:38.901884: 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-08-03 20:28:38.914314: 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:1754245718.936080   46927 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:1754245718.942448   46927 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:1754245718.958771   46927 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1754245718.958796   46927 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1754245718.958798   46927 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1754245718.958800   46927 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "2025-08-03 20:28:38.963821: 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": 2,
   "id": "eb07fb3a-ac8a-4472-a361-e21fc5750207",
   "metadata": {},
   "outputs": [],
   "source": [
    "hasc = data.HASC()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f27f9ba6-82f2-422e-9d56-2212c2ecd8e3",
   "metadata": {},
   "outputs": [],
   "source": [
    "alpha = 0.25"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "269677db-116b-4c5e-b02b-43567d4674df",
   "metadata": {},
   "outputs": [],
   "source": [
    "config = {\n",
    "    \"window_length\" : 10,\n",
    "    \"lag\" : 0,\n",
    "    \"n_windows\" : 30,\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": 4,
   "id": "001fb6d4-ac56-433c-b17d-3c47d92b7dea",
   "metadata": {},
   "outputs": [],
   "source": [
    "len_ref = 14*114 # based on the discussion in the appendix of Online kernel CUSUM; used here for comparability"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "65e52032-d9a5-45fd-a90e-26bc4d16916a",
   "metadata": {},
   "outputs": [],
   "source": [
    "changes = np.array([91, 109,  98,  60,  99, 100,  97,  60,  82,  96])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "441ffa6e-d2df-49eb-bcfe-9ae3261df775",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(39.2)"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(changes +50-100)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d96251f4-b98a-4c80-872c-c8380bd12505",
   "metadata": {},
   "source": [
    "## Try to understand the behavior of RuLSIF as the length of the post-change distribution increases"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "b8bfe518-0cde-47e2-92d2-e5aa63e0418a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Axes: >"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAhQAAAGbCAYAAACcdAl1AAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAQQpJREFUeJzt3Xl0W9d9J/DvA0CAGxbuEkVKImVttmRbpCQ38ZLYppLU2TNi1CTTaVo30rSTNjNNRgqTzsm0k1ZDd5mkTdpSaSdN4yyKFCeTJrVjQk7jJV5k0rZsazWhhZREUVwAkASJ9c0fD+8RIAkSK9+C7+ccHpskSFwcAE9f/u7v3iuIoiiCiIiIKAcmtQdARERE+sdAQURERDljoCAiIqKcMVAQERFRzhgoiIiIKGcMFERERJQzBgoiIiLKmWWl7igWi+HatWuw2+0QBGGl7paIiIhyIIoiJicn0djYCJMpdR1ixQLFtWvX0NzcvFJ3R0RERHk0ODiIpqamlN9fsUBht9uVATkcjpW6WyIiIsqB3+9Hc3Oz8u94KisWKORpDofDwUBBRESkM8u1K7Apk4iIiHLGQEFEREQ5y2jKo7+/H0ePHkVNTQ1OnjyJ7u5utLa2FmpsREREpBMZBYoHH3wQExMTAAC3240DBw6gt7e3IAMjIiIi/Uh7ysPr9SofAFBdXV2oMREREZHOpB0oXC4X2tra0NnZCa/Xi8OHD+PQoUMpbx8MBuH3+5M+iIiIyJgyaso8ceIEPB4PqqqqsG/fPnR0dKS87eHDh+F0OpUPbmpFRERkXBkFivHxcXR0dKCjowOdnZ3o7+9Peduuri74fD7lY3BwMOfBEhERkTZl1JS5Z88e9PX1weVyobOzM6lJcz6bzQabzZaXQRIREZG2pV2h8Hg8GB8fh8vlAgB84xvfSGrSJCIiouKVdqBobW2F1+uFx+NRvuZyuZSAQURERMUroymP3t5edHd3o729HX19fThx4kShxkVEREQ6IoiiKK7EHfn9fjidTvh8Ph4ORkREpBPp/vu9YqeNEpF2/OiVIXzVfQF331KLzp3NuKPJuexJgkRES+HhYERFJhYT8VdPnselsQC+8+IVfOjrz+FvTryl9rCISOcYKIiKzMlL4xiamEGlzYIHttQDAJ6+cFPlURGR3jFQEBWZH71yFQDw0PZV+G8dmwAAl8cCag6JiAyAgYKoiMyGo/jZ69cBAB/e0YS1NeUAgNGpIKaDETWHRkQ6x0BBVEROnBnB5GwEa1xluKulGs6yErjKSwAAgxOsUhBR9hgoiIrIY/1DAIAP7WiEySSt6lhbLVUpOO1BRLlgoCAqErPhKJ65MAoA+OCda5Svy4FicJyBgoiyx0BBVCReueJFKBpDg8OGjfWVytdZoSCifGCgICoSL14cAwDc1VKTtInVunhj5mVWKIgoBwwUREXiBU88ULRWJ319bXUFAE55EFFuGCiIikAwEsUrV7wApApFInnp6NBEANHYihztQ0QGxEBBVAReG/QhGImhttKGDXUVSd9b5SiF1WxCOCrium9GpRESkd4xUBAZzOWxaXzvpSsIRWLK116UpztaqhccAmY2CWiqKgMAXGFjJhFliYGCyEDC0Rh+559Pouux1/G/fnpa+fqLF8cBLOyfkK1lYyYR5YiBgshAHn3hMgZuTgMAvv3CZfz01DX4AmH0XZ4AAPxaa82iP7cuvnT0CgMFEWXJovYAiCg/JqZD+Ir7AgBg+xonXr/qw6HjpyAIAmbCUdTZk/efSNQsBwpOeRBRllihIDKIr564AN9MGFtW2XH8996GneuqMB2KYioYwZZVdvzdJ9oW9E/I1tVIjZqXx6dXcshEZCCsUBAZQDgaw3dfugIA+OP33gqbxYy//4/t+KdnL2Lnuio8uLU+ZZgAEnbLHA1AFMUlb0tEtBgGCiIDuDIeQCgSQ4XVjLtvkfok6uw2fP7Xt6T18+try2E2CZgMRjDsn8VqZ1khh0tEBsQpDyID8MQbMVvqKrKqLtgsZrTWStMeZ4cn8zo2IioODBREBuC5OQUAaKldvOkyHZtX2QEAZ68zUBBR5hgoiAxArlDIVYZsbIkHinPD/ryMiYiKCwMFkQF4RqUKRWtdLoHCAYBTHkSUHQYKIgOQKxQb6nKf8hi4OYVwNLbMrYmIkjFQEOmcLxDG2HQIANCSw5RHU1UZKm0WhKOiElCIiNLFQEGkcwPx6Y5VjlJU2LJfCS4IAjY1SBWOs+yjIKIMMVAQ6ZyyZDSH6oRsy2qpj+Ic+yiIKEMMFEQ6dzEPDZmyuZUeDBRElBkGCiKdU5aM5tCQKdvcEN+LgoGCiDLEQEGkc3OBIh8VCmnK46p3Bv7ZcM6/j4iKBwMFkY5FYyIujsWXjOawS6bMWV6CVY5SAMCFG6xSEFH60m4J93q9qKqqWvD1iYkJuFyufI6JiJZxZSyAr5w4j0AwilAkBqvFhDVV+TnQq7WuAsP+WVwaDaB9XXVeficRGV/aFYof/OAH6OvrgyiKEEURExMTaGtrY5ggUsGf/9sZPNZ/FU+8OQxA6n0wm/Jz5Pi6Gmnq5PIY96IgovSlXaHYv39/0udutxsdHR15HxARLW1wPIAnT0tB4rN7NqHEYkLH1vq8/f71NeUAgEtjgbz9TiIyvqx3wTl69Ci6urpSfj8YDCIYDCqf+/3cKIcoH779wmXEROCeW2rxBw9uzPvvZ4WCiLKRdVNmf38/2traUn7/8OHDcDqdykdzc3O2d0VEcdPBCL730hUAwG/fvb4g97G+lhUKIspcVoEinemOrq4u+Hw+5WNwcDCrARLRnMf6hzA5G8H6mnLcvzl/0xyJ1lVLFQrfTBjeQKgg90FExpPVlEdvby/27Nmz5G1sNhtsNltWgyKihWbDUfQ87QEAfPLt62HKUxPmfGVWM1Y5SjHsn8XF0WnsWGstyP0QkbFkVaE4fvw49u7dm++xENESvvWrSxiamEGDw4aP7irsFOK6eGPmZU57EFGaMg4UHo8Hra2thRgLEaUwNhXE1556CwDw39+9BeXW7E8VTcf6eGPmJTZmElGaMg4Ux48fR2dnZyHGQkQpfMV9AZPBCG5rdOAjO9YU/P7W1bJCQUSZyfjPnIMHDxZiHESUgvv0DXznxcsAgC++d2vBeicSsUJBRJniWR5EGvb6kA9/8L1XEBOBj+1uxts31K7I/bKHgogyxUBBpFHeQAi/862TmAlHce/GWvzpB7et2H3Lm1uNT4fgm+Gpo0S0PAYKIo167q0x3JwMoqmqDF//RBtKzCv3dq20WVBnl5Z9c8dMIkoHAwWRRk0HIwCATQ12OEpLVvz+eaYHEWWCgYJIo6bigaLcalbl/tfGd8y8wgoFEaWBgYJIowIhKVBUFHjPiVRWO0sBADf8wWVuSUTEQEGkWdOhKACg3KZOhaLeIfVQjEzOqnL/RKQvDBREGhUIqluhqLfLgYIVCiJaHgMFkUapXaGQV3ncZKAgojQwUBBplNxDUWlTq0Ih9VCMTAYhiqIqYyAi/WCgINKo6WC8QqHSlIdcoQhFYvDPRFQZAxHpBwMFkUbNrfJQZ8qjtMQMR6kUZtiYSUTLYaAg0qgpuUKh0pQHANQ75qY9iIiWwkBBpFFqVyiAxJUerFAQ0dIYKIg0Su0eCiAhUHBzKyJaBgMFkUapvcoD4JQHEaWPgYJIg2IxEQGV96EAuLkVEaWPgYJIg2bCUeX/1dopE5hbOjriZw8FES2NgYJIg6bj0x2CAJSWqPc2VXbLnGKFgoiWxkBBpEGBeENmhdUCQRBUG4e8W+ZNNmUS0TIYKIg0aCp+MFi5iktGgbkTRyeDEcyEosvcmoiKGQMFkQbJDZkVKq7wAAC7zaJMuXAvCiJaCgMFkQbJPRQVKq7wAABBEJIOCSMiSoWBgkiDAhrY1ErGza2IKB0MFEQaNK2Bbbdlch8FpzyIaCkMFEQaFJCbMlXuoQDAKQ8iSgsDBZEGTctNmRqoUNRxyoOI0sBAQaRB08qyUfUrFHKguO6bUXkkRKRlDBREGiQvG1XzYDDZnc0uAMDJS+OYmA6pOxgi0iwGCiINUioUKi8bBYBNDXbcutqBcFTET1+/rvZwiEijGCiINEjZ2EoDUx4A8JG2NQCAH/UPqTwSItIqBgoiDZKXjaq99bbsA3c0wiQA/Ve8uDQ6rfZwiEiDsg4U/f39cLvd+RwLEcUph4NpoIcCAOodpbhnYx0A4EevXFV5NESkRRkHiv7+fuzZswfj4+Po6OgoxJiIip7WKhQA8JEd0rTHj1+9ClEUVR4NEWlNRn/+9Pf348EHH0RfXx9aW1sLNSaioqeVw8ESveu2BpgE4PJYACOTQTQ4StUeEhFpSEYVis7OTnR1daUVJoLBIPx+f9IHEaVHPr5cK02ZgLQnxvqaCgDA+RuTKo+GiLQm7UDhdrvh8XgwMDCAzs5ObNiwAUeOHEl5+8OHD8PpdCofzc3NeRkwUTGQt95W+7TR+TY12AEA529MqTwSItKatANFf38/Wltb0dPTg2PHjuHYsWM4cOAAPB7Porfv6uqCz+dTPgYHB/M2aCIji8VEBMLaOW000aaGSgDA+WFWKIgoWUZTHi6XS/n/trY2uFyulCs9bDYbHA5H0gcRLW82EoXc86i5CsWqeIVihIGCiJKlHSja2toWVCOqq6tRXV2d90ERFbPp+JJRQQBKLRoLFPEpjws3prjSg4iSpB0oOjo6UF1djf7+fuVrXDpKlH8BecloiRkmk6DyaJKtr6lAiVnAVDCCa75ZtYdDRBqS0QRtb28vDh06hD179mBgYAAnTpxImgYhotzJFYpyDS0ZlVktJrTUVuD8jSmcH57EGleZ2kMiIo3I6IrV2tqKY8eOFWosRIS5Ta20cNLoYjY12KVAcWMS92+pV3s4RKQRPMuDSGOUk0Y1tEtmIrmP4hz3oiCiBAwURBqjtZNG55OXjl7gXhRElICBgkhjlAqFxpaMypSVHiOTiMW40oOIJAwURBqj9QrFupoKWC0mzIZjGJwIqD0cItIIBgoijdHiSaOJzCYBG+ulaY9TQz6VR0NEWsFAQaQxgaD2Thqd722tNQCAZy7cVHkkRKQVDBREGjM2HQKgvW23E923qQ4A8PT5Ue6YSUQAGCiINOXi6DQe6x8CAGxrdKo8mtR2t1TDZjFh2D+LCyNc7UFEDBREmhGLifj8D08hGInh3o21eM+2VWoPKaXSEjPuik97PH2e0x5ExEBBpBnfPzmIFy+Oo6zEjD//8HYIgrbO8Zjvvo21AIBfMlAQERgoiDTBGwih+4mzAIDPvXszmqvLVR7R8uQ+ipcujmM2HFV5NESkNgYKIg346okL8M2EsWWVHZ98+3q1h5OWjfWVWOUoRTASw4sXx9UeDhGpjIGCSGWem1P49vOXAQB//N5bYdbYkeWpCIKA+zZJ0x7PD4ypPBoiUhsDBZHK/vfjZxGJibh/cx3uifcl6MWWVQ4AwOA4d8wkKnYMFEQqujIWwJOnb8BsEvCFh7aqPZyMrakqAwAMcQtuoqLHQEGkohcuSlMFO5pd2Bg/dEtPmpRAMaPySIhIbQwURCo6GW9m3NVSrfJIstNUJa1GGZsOIRA/g4SIihMDBZGKTl6SAsXu9foMFM6yEtjjZ45c87JKQVTMGCiIVDLin8WlsQAEAWhbV6X2cLIm91EMctqDqKgxUBCp5KV4dWLLKgecZSUqjyZ78rQH+yiIihsDBZFK5P6Ju3TaPyGTGzOvMlAQFTUGCiKVvHRpAgCwS6f9E7ImLh0lIjBQEKnCNxPG2WE/AGBXi377J4CFS0fD0RiiMVHNIRGRChgoiFTw0sVxiCKwvqYc9fZStYeTk8Qeikg0hg9+7Tk88Ff/jmCEB4YRFRMGCqIVEkv4q/3/PnsRAPDOzfVqDSdv1rikCsXoVBDPvDWK09f9uDwWwIUbUyqPjIhWEgMF0QrY/y8v4+7up/DWyBReujiO5z1jKDEL+NR9rWoPLWeu8hJUWM0A5oISAJwbnlRrSESkAovaAyAyuhH/LJ48fQMA8MlvvoQGhzTF0bmzWfnrXs8EQUBTVTnO3ZjEMxdGla+fv8FAQVRMWKEgKrDnBub+kR2amEHf5QmUmAX8/js3qDiq/JI3t0p0joGCqKgwUBAVmPxX+3u3r4arXNrAam97k9LMaARNCYFibbX0uM5zyoOoqDBQEBWQKIp47i0pUHz8rrV49OG78PA9LTj47i0qjyy/EgPFf7lfqrxc883CPxtWa0hEtMIYKIgK6K2RKdzwB2GzmNC+rgrb1jjxP953K6oqrGoPLa/WuKSqRGmJCe+/oxGrnVKfyAVOexAVjZwChdfrzdMwiIzp2Xh1YndLNUpLzCqPpnDu2ViLO5td+PT9t6DcasGmBjsA4Nwwl44SFYuMA8WGDRsgCAIEQUBnZ2chxkRkGPJ0xz231Ko8ksJylpXgx//lbnz6gY0AgM2rpEDBlR5ExSOjZaNutxvd3d3o6OgAALhcrkKMicgQwtEYXvBIB4DdbfBAMd9chYKBgqhYZFSh6OnpgcfjgcfjYZggWsYrV7yYCkZQXWHFrasdag9nRW1uYIWCqNhkFCi8Xi8OHTqE9vZ2HDhwYMnbBoNB+P3+pA+iYvKLcyMAgHdsqoPJJKg8mpV1S30lBAEYmw5hdCqo9nCIaAVkFCh6e3shiiJ6enpw5MgRPPLIIylve/jwYTidTuWjubk558ES6ckvzkqB4p2b61Qeycors5qxLr4fxVNnRlQeDRGthKxWeezfvx/d3d04evRoytt0dXXB5/MpH4ODg1kPkkhvrnlncHZ4EiYBuG9j8QUKYO7gs0OPncLXnroAUeSR5kRGlvWy0b179y65bNRms8HhcCR9EBWLfz93EwCwY22V4facSNcXHtqK//hrayGKwF8+eR5f+NEbDBVEBpbTPhRtbW35GgeRocj9Ew9s0f/x5NmyWkz48oe2488/vB0mAfjeS1fwFz8/p/awiKhA0g4UHo8Hbrdb+bynpwddXV0FGRSRngUjUWX/iWLsn5jv43etxZ99eDsA4O/+fQDffO7iMj9BRHqUUaDo7OxEZ2cnjhw5gn379rFCQbSIZy+MIhCKot5uK7rloql8bPdaHHzPZgDAV9wXEItx6oPIaNLe2KqjowMTExOFHAuR7p257sfnjr0GAHj3basgCMW1XHQp++9txdefegu+mTDO3ZjEVoYtIkPh4WBEeXJueBKf+McXMREI445mF/57/C9ykljMJrSvrwYAvHRxXOXREFG+MVAQ5cH5G5P4+DdewPh0CLc3OfEvv7MbjtIStYelOXe1SIHixYtjSV8PR2P42anruO6bUWNYRJQHGZ3lQUQLXYiHibHpELatceDbv3MXnGUME4vZ3TJXoRBFUZkS+smr1/DZY6+h3GrG5961Gb/19vUwF9nuokR6xwoFUQ5EUcSBb/dhdCqEW1c78OjDd8FZzjCRyu1NTtgsJoxOheAZnVa+fmrICwAIhKL405+exn89+qo6AySirDFQEOXAGwgr/zD+y8O74Sovzk2s0mWzmLFjrQtAch/FufghYh1bGwAAPz11DcFIdMXHR0TZY6AgysHgRAAAUG+3obbSpvJo9GF3Sw2AuUAhiqJyzPlnHtyICqsZoggMjrOfgkhPGCiIcnBlXAoUzfGDsGh5SmOmZwyiKGJ0KoSJQBiCIJ1Suq6mAgBweWx6qV9DRBrDQEGUA/mv6OaqMpVHoh871rpgMQm45pvF4PgMLsSnO9ZVl6PMasb6WimcXRoLqDlMIsoQAwVRDuQpj7WsUKSt3GpB29oqAMDTF24q/RObGuwAwAoFkU4xUBDlYDA+5dHEQJGR+zbVAgCePn8T5+OBYvMqKVCsr2GFgkiPGCiIciAHiuYqBopMvGOTdArrrwbG8OY1PwBWKIj0joGCKEvRmIir3ngPRTV7KDJxW6MDNRVWTAUjODXkAzBXoWiplQLF0MQMwtGYamMkoswwUBBladg/i3BUhMUkYLWTgSITJpOAezbWKp+XmAWsj1cm6u02lJaYpMA2waWjRHrBQEGUJXm6Y01VGbeJzsJ9G+uU/2+trYTVIl2OBGEuXFzitAeRbjBQEGWJ/RO5uXfTXIViU3y6Q7Yu3ph5mY2ZRLrBQEGUpUFuapWTenspbl3tAABsbqhM+p4RKxS9p2/gM99/BZOzYbWHQlQQDBREWRqcYENmrv7bnk3Ytb4KH25rSvr63EoP41Qo/rr3PP7fq9fw7IVRtYdCVBA8vpwoS5zyyN2eWxuw59aGBV+f24vCGBWKcDSGt0ak/TYmgxGVR0NUGKxQEGWJ53gUzrr40tHB8QCiMVHl0eTOc3Ma4aj0OGZCPEWVjImBgigLs+EoRiaDALjtdiGsdpTCajEhHBXx1siU2sPJ2dlhv/L/0yFWKMiYGCiIsjBwU/pHrsJqRlV5icqjMR6TSUDbWhcA4Pe/04fx6ZC6A8rR2fjx7AAQCLJCQcbEQEGUoYGbUzjw7T4AwG1rnBAE7kFRCH/90TvR6CzFwM1pfPKbL2FKx70H5xICBSsUZFQMFEQZODvsx96//xWGJmawvqYcf7H3drWHZFiNrjL8y8N3obrCilNDPhw8/hpEUZ/9FImBgj0UZFQMFEQZ+LOfncFEIIw7mpw4/ntvV5Y3UmHcUl+Jf/ytnbCYBPzb68N49IXLag8pY76ZsHLmCwBMM1CQQTFQEKXplSsTeObCKMwmAV/7eBtqK21qD6kotK2twud/fQsA4H/99AzevOZTeUSZkY9nlwV0PHVDtBQGCqI0ff0XbwEAPrxjDZeKrrCH72nBg1vqEYrG8OnvvqKrfoqz16UVHnKrDXsoyKgYKIjS8OY1H9xnRmASgN9/5wa1h1N0BEHAX3begUZnKS6OTuMLj72um34KeYXHpnrpvBL2UJBRMVAQzSOKIk6cuYHrvhnl87968jwA4H23N6K1rnKpH6cCqaqw4m8/vgNmk4CfvHYN3z85qPaQ0iI3ZLatqwLAHgoyLgYKonl+/uYwHv7Wy/jg157D0EQAR08O4qmzIygxC/iDB25Re3hFrX1dNT73rs0AgC//9DSCEe394xyLibg5GUT/lQk88sRZvH5V6vmQ99VgDwUZFc/yIJrn0ReuAABGJoP4zX96CcO+WQDA5961GRsb7Ev9KK2AA/e14p+e9WB0KoRTQz7sWl+9IvcriiJGp0Kos0vNuNGYiI8deQHVFVb8w2+2AwB+cXYEn/5u/4IqRFNVGbY3OQGwQkHGxQoFUYLLY9N49q1RCAJQb7fh4ug0ZsJRvH1DDT51b6vawyNIu2jubpFCxEsXx1fsfv/hlx7s+jM3fv7mMABgaCKAly6N44k3hzEblkLCk6eHMR2KQhCAOrsN77ltFf7mYzvw8/96H5xl0o6q7KEgo2KgIEpwND4vf+/GOjz6u9KmSvV2G/7qo3fAZOKOmFqxO16VeHEFA4W8XPXVQS8A4Gb8LBcAGJ0Kxr8mbRH+5Q9tw8kvduAffrMdH7ijERU2C8qtUkE4FI0hFIkl/e5h36yynTuRXmUdKNrb2+H1evM4FCJ1RGMihn2zCEdjONY3BAD42K5mbGqw47lDD+Cpz70Tq51lKo+SEu1uqQEA9F0aRyQaW+bW+SFXFuQgkRgoxqakIDE2LX1tsT1Kyq3mBb9L9tGe5/HQV5+Bfzac30ETraCseiiOHDmC/v7+fI+FSBWf/m4/Hn9jGHabBZPBCGorrXhwawMAoCzhHwHSjs2r7HCUWuCfjeD0dT9ub3IV/D4D8RAgnzIrVyUS/18OFrWV1gU/X2I2wWo2IRSNYToUgTN+qFw0JuLKeED63f5ZOEp52BzpU8YVClYlyGjkefjJePf9vl3NsFo4G6hlZpOgNGOuVB9FIL4h1VIVCjlY1FQsvotquc0c/11zFYrETbqmeRIp6VjGV83Dhw9j//79y94uGAzC7/cnfRBpTTASxVj8aOx//u1d+NrHd+APH9yo8qgoHXJj5kr1UQSUKQ9p1c/NhArFzakgAqGIcpta++KBoiLeRxFI2C0zKVBwF03SsYwChdvtxr59+9K67eHDh+F0OpWP5ubmrAZIVEgjfukfBavFhHdsqsP7bm+EzcJpDj2QA8XJS+OIxQq/a6YcFsamQ4hEY0oDJiBVKOQqhc1iQkWKqTJ5Ci2xEjE1OxciAqxQkI5lFCh6e3vR1taW1m27urrg8/mUj8FBfexqR8Vl2C/9tdngsEEQuIpDT7atcaLcaoY3EMa5eQdwFYJcVRBFYHw6lFShGJ0KKtMdtZWpX0ty0EiuUMw1YrJCQXqWdqB45JFH0NXVlfYvttlscDgcSR9EWiNvWrXKUarySChTJWYT3tYqrfb4yWvXCn5/iX0PI5NBjCb2UEwHl2zIlMlLR6eTeijm/p89FKRnaQeKo0ePoqWlBVVVVaiqkvakb2lpwSOPPFKwwREV2g2lQsFAoUd725sAAD/sGyro8tFoTEQwYe+IkcnZpArF2FRoriFziWPtK+JNmTOJFYrEKQ9WKEjH0l422tfXl/S5IAi4ePEiXC5XvsdEtGLkCsVqJwOFHj24tQHVFVaMTAbxy/M3leW++Tb/H3rPzemkzalGp4JKc+9SFYoyuUKR2EOROOXBCgXpGNfGUVEbZoVC16wWEz68Yw0A4AcvF65Pa/5GVKevSavW5FaJ8ekQRuKvpSUrFIv0UEyyQkEGkXWgEEWR1QnSPXnKYxUrFLq1b5e0guzEmZGkvSHyKTA/UFyXAkVTVRkEAYiJwFvxrbMX2yVTtngPxeJLSIn0hhUKKmpyhYJNmfq1qcGOO5tdiMRE/PiVqwW5j/mrL94akcLDakcZqsqlKY5zw9JKk6WmPOZ6KFIsG+XBYaRjDBRUtERRxA2f9Bctpzz07aM7pSrF0ZcHIYr535Ni/pRHJL7vRZ3dhpoKKUCMxld5pNolE0ioUKSoSkyzQkE6xkBBRWt8OoRQfGUAA4W+vf+O1SgtMeGtkSm8Ej8NNJ9SVQ5qK62omVeRqLUvtWx06a23WaEgPWOgoKIlT3fUVFh5dofO2UtL8ND21QCAH5zMf3Om3Cw5vz+izm5b8LWlKxTxnTK59TYZEK+iVHSGJgIIRWLcg8Jg9sWnPf71tWt5Xy0hVw7W1ZQnfX1+oBAEoLpiqR4K+SyPxXsoOOVBesZAQUXlRc8Y7un+Bb70kzcwHO+f4AoPY9jdUo31NeWYDkXxs1PX8/q7lUO/Kq2otM1t31NbOddDAQDV5VaYTam3cC9fdOttnjZKxsBAQUXlF+duAgAe67+KgfgyPwYKYxAEAZ3xKkU+9qQY9s1iclbadEoOAOVWC+oSThKts9uSThad308xn9yUmXgIGPehIKNgoKCi8sZVHwAgGInheN8QAC4ZNZK97U0wmwScvDSBt0ayPzBsYjqEd/7lL/AbR14AMFehKLOaFwSKxArFUntQAOn0ULBCQfrFQEFFQxRFvHHNp3zum5H++mSgMI4GRyke2FIPAPjeS9lXKTyjU5gNx3BueBKiKCrLRivmBYqaClvSzphL7ZIJLOyhEEUxKVCEIjGEC3gmCVEhMVBQ0RiamIE3EMb8Ke4GTnkYysd3rwUAPNY/hNlwdn/x35yU9pSIxKR/8OWKQpnVgrp4aHCVl8BqMSmfA0tvagUkbr0dhShKB45FY8n7ZgTYR0E6xUBBhjY+HcLF0WkAc9MdtzY6cHuTU7kNKxTGct+mOjQ6SzERCOPnbw5n9TsSTxL1BsJKRaHcaka9QwoQcpBI7JtYbsqjLB4o5NNL5f4JQQAs8aTLpaOkVwwUZGgPf+sk3v2Vp3HhxqQy3bGt0YkP3NGo3IaBwljMJgEfjZ/v8b2XrmT1OxLPBPEGwklTHo3OMgBzzbzlVjNKS6RLac0SS0al286tEAmEosp0R6XVkjAdwkBB+sRAQYZ2aVQ6ZvrbL1zG61elA522rZECRaXNgrXV5XCUWZb5LaQ3H93ZDJMAvOAZx4UbmTdnJgaKiUBIaZYss1rwrtsacOC+Vnz2XZsBSKtL5MrEchUKs0lQwkcgFFH2oKgstSjLUbl0lPSKgYIMLRyV5qcf67+KU0NeAMD2NU7UO0rx+GfuxfH//DYIQup9A0ifGl1l6NjaAAD41vOXMv75pArFTBgzyrJRM8qtFnQ9tBV3NruU27x3+2qscZVhx1oXllNhnWvMnAxKjcGVNsuiK0CI9ISBggxNPqtjKhiBNxCGxSRg8yo7AKC5uhz1nO4wrE/evR4A8MO+q8qKnnQl91CEknooFtP10FY8e+j+ZVd5AHN9FNPB5ApFOSsUpHMMFGRYoiguWIK3scGO0pLF/1EgY3lbaw02N9gxE47iWIYbXY1OpmrKTD09lm6lK7FCofRQ2CwJK0BYoSB9YqAgw4rGRMgnWctLRbc1OtQbEK0oQRDw2/Eqxbeev7RgeWYqoigmVSgmAqGEnTJzD6PltrkKhXx2h73UknC0OSsUpE8MFGRYcv8EAHxoxxoAwD0ba9UaDqngg3eugau8BIPjM+g9fSOtn/HPRhCKzFW25i8bzZVcoZgJRzEZDxQVVgsqbaxQkL4xUJBhhRKmO/7sQ9vxr5++J2m5KBlfmdWMT9wlbXT1978cgCguX6VIbMgE5ArF8lMemYwJkCoR7KEgI2GgIMNK7J8oLTFhe5OTKzqK0G/f3QKbxYTXBr14fmBs2dvPDxQ3J4PKdElZXioUc5UIuYfCntBDwVUepFcMFGRYcqCwmk0MEkWsttKGffGNrv7+lwPL3l7unygxS6+Za94Z5Xv56aGYq0QkVSiUHgoGCtInBgoyLHkeXP6HgYrXp+5thdkk4JkLo3h9yLfg+zOhKE5eGocoisoKj9baSgDAREBacmo1m1Bizv2SqVQowhGlh6LSVqJsbBXgiaOkUwwUZFhyhaLEwpd5sWuuLlf6Z/6P+/yC7//h919B5z88j8ffGFYqFBsbKpNuk4/pDmDuxNHxqdC8Hoq51R9EesQrLRlWKCLNe+fjr0rSvz944BaYTQKeOjuS1EtxasirrAB56uyI0kNxS31yoKjIU6C4rVE6mK7v8oTSL1FpMyftT0GkR7zSkmEl9lAQtdZVKkebH378DGLxRsu/OfGWcpuTl8aVQNHoKlOmIYD8VSh2t1TDJACe0Wlcip+EW2krUfozplihIJ3ilZYMS5nyYA8Fxf3hgxtRYTXj1JAPR18exBtXfXCfuQGTIB0hfnksgNPXpUPk6uw2OMtKlJ/Nx5JRAHCWlShVCv9swk6ZPG2UdI6BggwrpAQKvsxJUme34cA7NgAAuh57HR/42rMAgPff0Yitq6RdVOUKRV2lDVUViYEif1u2v21DTdLn9tK5QMF9KEiveKUlw5J3ymSgoESfurcVH2lbgwqrGTFRqmB9+v5bsLulOul2dXYbqsqtyud5DRStyYGCZ3mQEeSnhkekQeEIV3nQQmVWM/76o3ci/B9ieP2qD+VWMzY22LG7pRr//KtLAKTpj+oKa0GmPABg5/oqmE2CsmFWhc2CQFiqTEyzKZN0ildaMqy5pkz2UNBCJWYT2tZWYUt8qmPX+rkKRXW5FSVmU8EqFPbSEmxbI/VRWC0mWC0mpUIRisQWnJJLpAcMFGRY7KGgTNTZbWitrVD+HwBc5YXpoQDmpj3s8d6JxApIgH0UpEO80pJhsYeCMiX3UcwFirkKRVkepzwA4O5bpEBRXSHdh9ViUpY48zwP0qOMrrT9/f1ob2+HIAjo7Ows1JiI8iLMCgVl6N3bVgEA7mx2AQBcCT0U+drYSnbPLbX44kNb8acf3KZ8rZxHmJOOpR25vV4v3G43+vr64PV60dLSgiNHjmD//v2FHB9R1pQeCgt7KCg992+ux8kvdqC2UqoaJC4bzdfGVjJBEPCp+1qTvlZhtcAbCHPpKOlSRjW8gwcPAgBcLhc6OjpQXV29zE8QqWfucDBWKCh98nQHkDzlkc9VHqnIfRo8z4P0KO13iMvlUv7f6/Wiuroae/fuTXn7YDCIYDCofO73+7MbIVGW2ENBuUqa8rDlt0KxGGVzKy4dJR3K+Ep7/PhxtLe3w+12w+PxpLzd4cOH4XQ6lY/m5uacBkqUKfZQUK4Sl42WlaxEoGAPBelXxlfavXv34tixYwCAAwcOpLxdV1cXfD6f8jE4OJj9KImywH0oKFeOshII8ZfPSkx51NtLAQBnrk8W/L6I8i2rP93a2trQ09ODl19+OeVtbDYbHA5H0gfRSgopTZmsUFB2zCYBjlJp2qN8BaY8HthSDwB44o3rEEWx4PdHlE9ZX2l37tyJ1tbW5W9IpJJwhD0UlLt7N9aizm7DhrrKgt/X/VvqYbWYcGksgLPDrFKQvqR9pfV6vUk9E263G11dXQUZFFE+sIeC8uFvP7YDz3/+gaRzPQql0mbBfRvrAACPvzFc8Psjyqe0r7Qejwd79uzBgQMHcPz4cbhcriVXeRCpLcwpD8oDQRBgWcFQ+uvxzbWeeOP6it0nUT6k3WXU1taGgYGBQo6FKK/mzvJgUybpR8fWBlhMAs7fmMLAzakVmWohygf+6UaGxX0oSI+c5SW4+5ZaAMATnPYgHeGVlgwrzJ0ySafkaY/HOe1BOsIrLRnW3D4UfJmTvuy5tQEmAXjjqh+D4wG1h0OUFl5pybCUHgoeDkY6U1Npw10t0vHmnPYgvWCgIMPislHSs1/fzmkP0hdeacmw2JRJevbu26RA0X/Fi2HfrMqjIVoer7RkWOyhID1rcJSifV0VAODnb3Lag7SPV1oyrBBXeZDOyas9/rr3PD749efwhR+9jliMZ3yQNvFKS4YV5sZWpHMPbV8Nm8UE30wYrw168d0Xr/CMD9IsBgoyLKWHgltvk041usrwi8+9E9/93bvQ4LABAAKhiMqjIlpc2ltvE+kNeyjICBpdZWh0laGq3Iob/iBmwlG1h0S0KF5pybC4bJSMpLTEDACYDcdUHgnR4nilJcOaa8pkDwXpX1k8ULBCQVrFQEGGxX0oyEjKrPEKRYiBgrSJV1oyLKWHgk2ZZACsUJDW8UpLhhSLiYjEWKEg47CVSK9jBgrSKl5pyZDCsbnGNfZQkBEoFQpOeZBGMVCQIcn9EwArFGQMcqCYjTBQkDbxSkuGFI4kVij4Mif9Y1MmaR2vtGRIckOm2STAbOKUB+lfKZsySeMYKMiQQjzHgwxmLlBwYyvSJgYKMiTuQUFGw6ZM0jpebcmQeI4HGU2ZVXotB9mUSRrFqy0Z0ty223yJkzGwQkFax6stGZLSQ2FhDwUZA5sySesYKMiQwqxQkMFw623SOl5tyZDkpkz2UJBRKMeXc8qDNIpXWzKkcJQVCjIWeWMrVihIq3i1JUPiPhRkNMrW29yHgjSKgYIMiRUKMprEpkxRFJe5NdHK49WWDEnZh8LClzgZgzzlAQDBCKsUpD282pIhhSPcKZOMpTQhHHMvCtKijK62brcbGzZsgCAI6OzsLNSYiHLGHgoyGovZpLye2ZhJWpR2oPB6vTh27Bh6e3vR19cHt9uNAwcOFHJsRFljDwUZkbJ0lIGCNMiS7g3dbjd6enqUz7u6unD06NGCDIooVzzLg4yorMSMydkIKxSkSWkHir179yZ97nK50NramvL2wWAQwWBQ+dzv92cxPKLs8LRRMiK5MZMVCtKirK+2vb29S055HD58GE6nU/lobm7O9q6IMqYcDsazPMhA5g4I4yoP0p6sAoXH40F1dTU6OjpS3qarqws+n0/5GBwczHqQRJliDwUZkY3neZCGpT3lkai7uzupn2IxNpsNNpstq0ER5Yo9FGREZSXS65mBgrQo46vtkSNHcOjQoUKMhShv2ENBRlTGVR6kYRldbY8fP46dO3cqzZgejwdut7sgAyPKRYhTHmRAbMokLcto2ehim1lxT3nSojCbMsmAlPM8uFMmaVDagaKjo4PhgXSDPRRkRKVsyiQN49WWDIk9FGREZQwUpGG82pIhsYeCjEgOFMEw96Eg7eHVlgwpzMPByIDkpkz2UJAWMVCQISk9FBa+xMk42ENBWsarLRlSOCL1ULApk4yklBtbkYbxakuGxB4KMiJubEVaxqstGZLSQ8EpDzIQBgrSMl5tyZDYlElGVGplDwVpFwMFGZK8DwV7KMhIyrhTJmkYr7ZkSKEIeyjIeOamPLgPBWkPr7ZkSGE2ZZIB5XPZ6Gw4iifeGMZUMJLz7yICGCjIoOb2oWAPBRlHPqc8vvPiFfznR/tw5JcDOf8uIoCBggyKZ3mQEZVapdfzbCSa82GNg+MBAMCQdybncREBDBRkUNyHgoxIrlCIIhCM5NZH4Z8NS/+d4ZQH5QevtmQ4oiiyh4IMSe6hAHLfi0IOEpPxYEGUK15tyXCiMRFyNZjLRslISswmWExSX1CujZlKhWKWFQrKD15tyXDk/gkAKGFTJhlMvhoz/TNSoGCFgvKFgYIMR+6fADjlQcYj75aZ614Uk7ORpP8S5YpXWzKccEKgkMvDREZRlqe9KHwJFYpcV4wQAQwUZEDKHhRmEwSBgYKMJR8HhEWiMWVDq5gITHMrb8oDBgrSralgZNF55HBE3oOCYYKMRzkgLIcQMH93TLmfgigXFrUHQJSJ2XAUPb/04KlzI3h9yIvqChtO/NE74CwvUW4jl3J5dDkZUWn8dZ3LlMf8vSfYR0H5wEBBunFxdBq//51+nLnuV742OhXEE29ex75dawEA08EIDv3wFABgc4NdlXESFVJZHo4w989b2TH/c6Js8E840oWzw3584G+fxZnrftRUWNH9H7bjU/e2AAD+9bXrAKT9Jz7z/Vdw+roftZVW/GXnHWoOmagg5B6KYE4ViuQAwaWjlA8MFKQLP+wbwmQwgu1rnPjZH96LfbvW4jd/bT0A4FcDoxiZnMU3nvHAfWYEVosJR/7TTjRXl6s7aKICqKm0AgCO9w1l3Zi5oELB7bcpDxgoSBeuxA8y2tvehFXOUgDA2ppy3NHsQkwE/vGZi/iq+wIA4Msf3Ia2tVWqjZWokPbfuwGu8hK8NuTDF3/0RlZLPhf2ULBCQbljoCBduDIunYi4dl7V4f23rwYAHHnag5lwFLtbqtG5s2nFx0e0UtbWlOPrH2+D2STgh/1DOPK0J+Pf4ZuZ30PBCgXljoGCNE8URQzFKxTN1WVJ33vf7Y2Qt5qwmAR8+UPbuPcEGd7dt9Tij9+7FQBw+PGz+O6LVzL6eTZlUiEwUJDmeQNhTMbXzTdVJVcoVjlL8WstNQCAh+9twSau7KAi8cm3r8eBd7QCAL7449fx/169mvbPyk2Z8kayXDZK+cBAQZo3OCFVJ+rttqTjm2V/0Xk7/vdHtuOzezav9NCIVCMIAj7/ni34rbetgygCX/rJm2n3U8hTHKscUj8SN7aifGCgIM2TGzLn90/ImqrK8Ru718LKjayoyAiCgM++WwrS3kAYwUh6B4bJAWJNlTSFyAoF5QOvwKR5ywUKomJWYZ3bn3A6mF4wkHsm5ClE9lBQPmQUKI4fP4729nZ4vd4CDYdoocH4Co8mBgqiBcwmAeXx3TOng+ntSyEvG13jYoWC8iejQNHR0YH+/v5CjYVoUYOsUBAtqcImVSkmg+lVGuRlo03xKQ/2UFA+ZBQoXC5XgYZBlJrclNlcVbbMLYmKU2U8UKRdoZhlDwXlX8EOBwsGgwgGg8rnfr9/iVsTLS4SjeHqRHxTqxpWKIgWMxcolg8G4WgMgfjR53IPxUw4inA0hhIz2+ooewV79Rw+fBhOp1P5aG5uLtRdkYFd980iEhNhNZvQYC9VezhEmlRhk3ooptIIFInViEZX6aJfJ8pGwQJFV1cXfD6f8jE4OFiouyIDk6c7mqrKYDJxB0yixcgVinQChdwvUWmzwGYxKw2dPM+DclWwKQ+bzQabzVaoX09FYlDZcpvTHUSpVGQw5SH3TzhKLfH/liAQivLEUcoZJ8xI0+Qlo/PP8CCiORUZVSik2zjKSgAA9niwYIWCcpVRoJD3nxgfHy/EWIgW4KZWRMuzZ1ChkJeMOkqlQCEHC25uRblKO1B4vV4cOXIEgLTBFTe3okJ7/PXreOKNYQDALfWVKo+GSLvmKhTLLxtVpjzKpJ+RKxQ8wpxylXYPhcvlwsGDB3Hw4MFCjocIAPCDk4P4/GOnEBOB99y2Cu/YVK/2kIg0K7Mpj3kVivh/ubkV5Yo9FKQ549MhfPHHryMmAh/b3Yyvf6INZq7wIEqp0iZvvZ1BU+aCHgpWKCg3BVvlQZStE2duIBwVsWWVHX/+4e0QBIYJoqVU2qRwkFFTprzKgz0UlCesUJDmPHn6BgDgPdtWMUwQpaGCFQrSAAYK0pSZUBTPXLgJAHjXratUHg2RPmSzsZUcKOQeCi4bpVwxUJCmPH3hJmbDMTRVlWHrarvawyHShUw2thqKn43jnFeh4MZWlCsGCtKUJ9+UpjvedSunO4jSlW6F4uywHxdGplBiFrB7fTWAuUpFukefE6XCQEGaEYnGcOJsPFDc1qDyaIj0Qw4Us+EYItFYytv9qP8qAOD+zfWoqrACmJvy8AYYKCg3DBSkGa8OeuENhFFVXoKd66rUHg6RbshTHgAwnWJzq2hMxI9flQLFR9qalK9XlTNQUH4wUJBmeEanAQDb1jhhMfOlSZQuq8UEa/w9MxVafNrjVwOjuOEPwllWgvu31Clfr45XKqaCEYQiqasbRMvhVZs044ZvFgDQ6ORBYESZWm7p6GPx6Y7337EaNotZ+bqjtATyvnHemVBhB0mGxkBBmnHdLwWKVc5SlUdCpD+VpakbM32BsHIuTuJ0BwCYTIKy4mNimtMelD0GCtKM4XiFYjUDBVHGKqzxQLHIBlWPvngZM+EoNjfYsaPZteD7coPmRIAVCsoeAwVpxnUfKxRE2apMsRfFbDiKbz53EQBw4B2tiy7HriqPB4ppBgrKHgMFacawT9pwh4GCKHOpThz9Yf8QRqdCaHSW4v13NC76s0qg4EoPygEDBWnCbDiqXMxWO9iUSZQpuYcisUIRjYn4xtMeAMDD97aiJMXqKXnpKKc8KBcMFKQJN+INmWUlZjjKeAguUaYqrQsrFL8aGMWlsQCcZSX4jV3NKX9W6aHglAflgIGCNOF6QkMmt9wmytzclMfcxlavXvECAN65uS5p86v5OOVB+cBAQZogr/BocLB/gigblYvsQ/HmNT8AYFujc8mfndstkxUKyh4DBWnCdS4ZJcrJYieOvnndBwC4rdGx5M+64hWKcQYKygEDBWkCV3gQ5UZuypyMBwpfIIzBcel9desygULefpvneVAuGChIE1ihIMrN/H0o5OrEGleZUoFIRZ7yGGdTJuWAgYI0YVjZdptLRomyIe+UKQeK03L/xJqlqxPA3CoP/2wY0ZhYoBGS0TFQkCbITZmr2JRJlJX5G1vJDZm3LdOQCQCu+Fkeogj4ZjjtQdlhoCDVhaMx3JwKAmAPBVG27PMOB3vjanoNmQBgMZuUn+e0B2WLgYJUNzIZhCgCJWYBNRVLz/US0eLmVnlEMROKYuDmFID0KhRAYmMmAwVlh4GCVCev8GhwlMJk4qZWRNmokPehCEVwZtiPmAjUVlrR4LCl9fPK0lFWKChLDBSkOq7wIMqdvMpDFIGXL40DAG5tdKa982y1srkVeygoOwwUpDrukkmUu7ISM+QC3zefuwQAuKMpvekOIHH7bVYoKDsMFKS6y2MBAKxQEOVCEASlj+K6bxYNDhv+09vWp/3z3C2TcsVAQaoSRRH/fn4EANC+rlrl0RDpmzztYTEJ+LtPtKHOnl7/BABUV8SnPKY55UHZYaAgVV0YmcLg+AysFhPu3Vir9nCIdK2pStoY7o/fuzXjgO7ilAflKPV5tkQroPf0DQDA3RtqljxemYiW93/23YnLYwG8fUNNxj/LHgrKVUZXcI/Hg+7ubrS3t2NgYADd3d2FGhcVCTlQdNzaoPJIiPSvqaocTVXlWf1sVXzKY4KrPChLGQWKPXv24NixY2hra4Pb7caePXvQ29tbqLGRwY1MzuLVQS8A4MEtDBREalIqFNyHgrKUdg+F2+3G+Pg42traAAAdHR1wu93weDwFGxwZ21NnpGbM25uc3HKbSGXKTpkzYYgiDwijzKVdoejv78fOnTuTvtba2gq32439+/cvuH0wGEQwGFQ+9/v9OQwztYe++gwGxwMF+d1UWLORKABgz1ZWJ4jU5opvbBWNidj+P58E96zVp3/7zL1ors5u2itXaQeKgYEBuFyupK+5XC4MDAwsevvDhw/jT/7kT3IaXDoCoQgm44fhkP7YLCa8745GtYdBVPRsFjNub3Li1JBPOWCM9CemYnWpYG31XV1d+KM/+iPlc7/fj+bm5rzfz6O/exciUZbn9Kqqwgpn/OhkIlLXD3/v7bg6MaP2MCgHja4y1e477UCxYcOGBf0SXq8Xu3btWvT2NpsNNlv6m6pkK9uOZiIiSlZiNmF9bYXawyCdSrsps62tbUGg8Hg8SpMmERERFa+0A0VHRwcAKKHC7Xajra0Nra2thRkZERER6UZGPRS9vb3KxlZ9fX04ceJEocZFREREOiKIK7Tg2O/3w+l0wufzweFwrMRdEhERUY7S/febh4MRERFRzhgoiIiIKGcMFERERJQzBgoiIiLKGQMFERER5YyBgoiIiHLGQEFEREQ5Y6AgIiKinDFQEBERUc4Kdnz5fPKGnH6/f6XukoiIiHIk/7u93MbaKxYoJicnAQDNzc0rdZdERESUJ5OTk3A6nSm/v2JnecRiMVy7dg12ux2CIOTt9/r9fjQ3N2NwcNCwZ4QY/TEa/fEBfIxGYPTHB/AxGkEhHp8oipicnERjYyNMptSdEitWoTCZTGhqairY73c4HIZ8cSQy+mM0+uMD+BiNwOiPD+BjNIJ8P76lKhMyNmUSERFRzhgoiIiIKGe6DxQ2mw1f+tKXYLPZ1B5KwRj9MRr98QF8jEZg9McH8DEagZqPb8WaMomIiMi4dF+hICIiIvUxUBAREVHOGCh0zOv1qj2EvDDK48hGMT92IzLK82mUx5GNYn7sudJ1oPB4PDhw4ACOHDmCQ4cOqT2cvHC73diwYQMEQUBnZ+eC78vfS/V9vUj1OPT+nHq9XuVxJX4kXqT0+BweP34c7e3tCy62Sz1fensuUz1GI70nUz1GwBjvycUen9Hek0u9HlV/P4o61traKvb19YmiKIq9vb1iR0eHyiPKzcTEhLh//35xYGBA7OvrE10ul7h//37l+729veKxY8fEiYkJcWJiQr2B5mipx6H357Snp0cZvyhKz2lbW5vyuV6fw4mJCRFARs+X3p7LxR6j0d6TqZ5Ho7wnF3t8RnpPLvd6VPv9qNtA0dvbK7pcrqSvARAHBgZUGlHujh07lvR5d3d30gt/7969Ynd3d9KbQ49SPQ6jPqcHDx5UPtfzczj/Qr3U86XX53L+YzTie3KxQGGk9+Rijy+Rnt+TS70etfB+1O2UR39/P3bu3Jn0tdbWVrjdbpVGlLu9e/cmfe5yudDa2qp87vV6cejQIbS3t+PAgQMrPby8SfU4jPicHj16FPv27VM+N8pzCCz9fBnlueR70hjPYyI9vyeXej1q4f2o20AxMDAAl8uV9DWXy4WBgQF1BlQAvb29SS/w3t5eiKKInp4eHDlyBI888oiKo8teqsdhxOe0v78fbW1tyudGeQ6BpZ8vIz6XAN+TgP6fRyO9JxNfj1p4P+o2UBidx+NBdXU1Ojo6Fnxv//796O7uxtGjR1UYWf4Y5XGk4na7F33+AOM/diPie1L/jPSeXOr1qBbdBooNGzYs6FT2er3YtWuXOgPKs+7ubvT09KT8/t69ew2xvCnxcRjtOe3t7cWePXtSfl/vz+FSz5fRnkuA70mZnp9HI70n578etfB+1G2gaGtrg8fjSfqax+NJKmXpVbrLeozwWIG5x2G05/T48eML5jzn0+tjA5Z+voz2XPI9OUfPz6NR3pOLvR418X7Ma4vnCmttbVW6VHt7e5O6r/Xq2LFjSd3Gcoeu/F/ZwYMHddGVPN9yj8Moz+nAwMCCZVl6fg7l5Xjzu8KXer709lymeoxGek8u9hiN9J5M9RyKonHek6lej6Ko/vtR14FiYGBA3L9/v9jT0yPu379f82uIl9Pb2ysCWPAhf8/lcol79+5dsK5aT5Z7HEZ5Tru7u8Wenp6kr+n1OZyYmBC7u7tFAGJ3d3fSc7LU86Wn5zLVYzTSe3Kpx2iE9+RSr1NRNMZ7cqnXoyiq/37kaaNERESUM932UBAREZF2MFAQERFRzhgoiIiIKGcMFERERJQzBgoiIiLKGQMFERER5YyBgoiIiHLGQEFEREQ5Y6AgIiKinDFQEBERUc4YKIiIiChn/x+Lo89QKWBV3gAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "detector = RuLSIF(**config)\n",
    "signal = np.linalg.norm(hasc.change(num=0,h0_offset=len_ref,len_pre_change=100,len_post_change=100),axis=1)\n",
    "scores = detector.transform(signal)\n",
    "sns.lineplot(scores)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "f164326e-aa32-4a05-b47a-574114777fea",
   "metadata": {},
   "outputs": [],
   "source": [
    "changes = []\n",
    "for i in range(10):\n",
    "    detector = RuLSIF(**config)\n",
    "    signal = np.linalg.norm(hasc.change(num=i,h0_offset=len_ref,len_pre_change=100,len_post_change=100),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": 47,
   "id": "3f1722c7-5ab1-455e-aaae-c78822abafb8",
   "metadata": {},
   "outputs": [],
   "source": [
    "changes = np.array(changes)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "e69c8699-9529-4f71-a79a-60d471461944",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Too early:  9\n",
      "Average:  11.0\n"
     ]
    }
   ],
   "source": [
    "print(\"Too early: \", np.sum(changes<100))\n",
    "print(\"Average: \", np.mean(changes[changes>=100])-100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "f152c314-7ffc-4887-946f-961ac654a1df",
   "metadata": {},
   "outputs": [],
   "source": [
    "changes += config[\"n_windows\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "7c9df15c-3a34-4ff0-b294-6dbca7a12f76",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([122, 141, 105, 129,  77, 102, 126,  96, 112, 126])"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "changes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "69c79eb5-174f-43f1-a7ae-a2fde33933e4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Too early:  2\n",
      "Average:  20.375\n"
     ]
    }
   ],
   "source": [
    "print(\"Too early: \", np.sum(changes<100))\n",
    "print(\"Average: \", np.mean(changes[changes>=100])-100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "47c1c436-3329-4ff3-bc39-ddb3e12c4545",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Axes: >"
      ]
     },
     "execution_count": 12,
     "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
}
