{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c92a03d7-4df3-4fab-a7df-453e0cdbaf32",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-07-30 07:47:34.857694: 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 07:47:34.862770: 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 07:47:34.876584: 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:1753854454.897808 1518246 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:1753854454.903943 1518246 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:1753854454.921362 1518246 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1753854454.921386 1518246 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1753854454.921391 1518246 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1753854454.921395 1518246 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "2025-07-30 07:47:34.927291: 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": 4,
   "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": 5,
   "id": "4dfe1411-570f-4e74-a88b-35e59bdfda0f",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████| 1/1 [01:29<00:00, 89.33s/it]\n"
     ]
    }
   ],
   "source": [
    "stats = []\n",
    "for i in tqdm([0]):\n",
    "    detector = RuLSIF(**config)\n",
    "    signal = np.linalg.norm(hasc.h0(num=i),axis=1)\n",
    "    stats += [detector.transform(signal)] "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "67f502a7-3a5a-44f4-9f77-2ec856566555",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(4.9253558231657095)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "merged = list(itertools.chain(*stats))\n",
    "threshold = np.quantile(merged, 1-alpha)\n",
    "threshold"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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": 17,
   "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": 18,
   "id": "3f1722c7-5ab1-455e-aaae-c78822abafb8",
   "metadata": {},
   "outputs": [],
   "source": [
    "changes = np.array(changes)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "f152c314-7ffc-4887-946f-961ac654a1df",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 91, 109,  98,  60,  99, 100,  97,  60,  82,  96])"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "changes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "69c79eb5-174f-43f1-a7ae-a2fde33933e4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Too early:  8\n",
      "Average:  4.5\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": "iVBORw0KGgoAAAANSUhEUgAAAhQAAAGbCAYAAACcdAl1AAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAPkJJREFUeJzt3Xl0m/d95/sPNoI7IVKiJErUQi22LK+UFNtJbCc1lbRpk7SplbS5k+Qm7ZUynXPbND03qjp3mpPpnNHIc09vz+0qZbJNmzaqnDTTLG1Cuo4d24kX0ZtkS7ZJLZSolSQIruCC5/4BPA/BHQRAPHie5/06h8ciCAI/GAT44ff3/f1+PsMwDAEAAOTAb/cAAACA8xEoAABAzggUAAAgZwQKAACQMwIFAADIGYECAADkjEABAAByFizUHSUSCXV3d6uqqko+n69QdwsAAHJgGIYGBgbU0NAgv3/+OkTBAkV3d7caGxsLdXcAACCPurq6tH79+nm/XrBAUVVVZQ2ourq6UHcLAAByEIvF1NjYaP0en0/BAoU5zVFdXU2gAADAYRZrV6ApEwAA5IxAAQAAckagAAAAOSNQAACAnBEoAABAzggUAAAgZ0taNtre3q7jx4+rrq5OL7zwgo4cOaKmpqblGhsAAHCIJQWKhx9+WH19fZKktrY2HThwQK2trcsyMAAA4BwZT3lEo1HrQ5Jqa2uXa0wAAMBhMg4UkUhEzc3N2rdvn6LRqA4fPqyDBw8u59gAAIBDLGnK4/HHH9euXbu0YsUKnThxQi0tLfNeNx6PKx6PW5/HYrHsRwkAAIraklZ59Pb2qqWlRS0tLdq3b5/a29vnve7hw4dVU1NjfXDSKAAA7uUzDMPI9MpbtmzRyZMnFYlEtG/fPrW1tVlNmjPNVaFobGxUf38/h4MBAOAQsVhMNTU1i/7+zrhC0dnZqd7eXkUiEUnSl7/85WlNmjOFw2HrZFFOGAWc60r/iD78F0/rH56/aPdQABSxjANFU1OTotGoOjs7rcsikYgVMAC40/EXuvTKpX4df6HL7qEAKGJLaspsbW3VkSNHtGvXLp08eVKPP/74co0LQJF44sx1SVJsZNzmkQAoZksKFGZDJgBvuDEQ1yuX+iVJ/QQKAAvgLA8A83ri7HXr39GRcS2hhxuAxxAoAMzLnO6QpMmEoaGxSRtHA6CYESgAzGlsIqGfvnVz2mVMewCYD4ECwJxePN+rwfiEVlaWqK6iRJLUP0ygADA3AgWAOT2emu54zy31ipSHJFGhADA/AgWAWQzD0I9OX5UkteyoV00ZgQLAwggUAGZ5/UpMl/pGFA769eD2VWmBYszmkQEoVgQKALP86PQ1SdJD21epvCRIhQLAoggUAGb5cWq64/0710iSIuWppkwCBYB5ECgATHOhZ0hnrg4o4Pfp4R31kqRqKhQAFkGgADCN2Yx5X1OtVZmYmvKYsG1cAIobgQLAND9O9U+Y0x3SVKCIDtOUCWBuBAoAluGxCb3cFZUkvfeWeutyM1CYJ46evNCrP3/8LU1MJgo+RgDFaUmnjQJwt5cuRjWRMNRQU6rG2nLr8pmrPP74f53W6e6Ymjeu0Lu2rrRlrACKCxUKAJbnz/VKkvZsrp12efpOmYZh6NzNIUnSzcF4YQcIoGgRKABYXjifChSbpgcKa8pjdEI9Q2MaTp06yqoPACYCBQBJ0vhkQi9djEqS3rF57kAxmTB05sqAdXmMQAEghUABQJJ06nK/RsYnFSkPaeuqymlfKw0FVBJMvl2c6u63Lo+NsowUQBKBAoCkqemO3Rtr5ff7Zn3drFKcujwVKDjOHICJQAFAkvT8uT5J0js2r5jz62agON0dsy6LjRIoACQRKAAokTD04oW5GzJNkVSgMFd4SDRlAphCoACgy9ERRYfHVRLw6/Z1NXNex6xQpKNCAcBEoACggVRzZXVZSKHA3G8LcwYKzvYAkEKgAKDhsWQwqAgH5r1O9RyBgikPACYCBQANpTaqqiiZfzf+9ApFZTh5vYHRcSUSxvIODoAjECgAaDi+eIUiPVDctrZakpQwpMExpj0AECgASBpMBYryBSoU5nkekrR1daW10RW7ZQKQCBQAJOtsjkwrFI0rytOONKdCAYBAAUDS0NjiFYppgaK2TNWlyevSmAlAIlAAkDQcT1YozGbLuaQHig21aRUK9qIAIAIFAKVXKBaY8iifPuVhLiOlQgFAkub/cwSAZwxZqzzmf0tYVRnW+25brfKSgCLlIVWXmj0UBAoABAoAmtqHYqEKhc/n07FP7rY+n5ryoCkTAFMeAJS+D0Xmf2NUlyWvS4UCgESgAKDMdsqcaWrZKIECAIECgKbO8ihfYB+KmcweCpoyAUgECgCShuJLr1BUs2wUQBoCBQBrlcdCTZkzsVMmgHQECgDW1tsLbWw1E1MeANIRKACPMwxjamOrJfRQsFMmgHQECsDjRscTMozkv5fWQ5G87vDYpMYnE8sxNAAOQqAAPM48ulySykKZVyiqSqe24mbpKAACBeBxw2nnePj9voy/L+D3qSrVc8FumQAIFIDHWUtGl9CQaeKAMAAmAgXgcWaFomIJS0ZN1eyWCSCFQAF43NTBYFlUKEqT30OFAgCBAvC4qaPLc6hQsHQU8DwCBeBxQ1mcNGpit0wAJgIF4HHDWZw0ajJ3y4wOj+V1TACch0ABeNzQ2NLP8TBtrCuXJL11fTCvYwLgPAQKwOOGc1g2evu6aknS6e7+vI4JgPMQKACPG8zipFHTrWuq5fNJ12JxXR8YzffQADgIgQLwOGsfiiwqFBXhoJpWVkiSTnfH8jouAM5CoAA8bshqylx6hUKSbl9XI0k6fZlpD8DLCBSAxw2bUx5ZVCgkaWeD2UdBhQLwMgIF4HFDOSwblaTbG5IVilM0ZgKeRqAAPC6XnTIlaWcqUHT1jqh/mB0zAa8iUAAeZ21sleWUR015SI21ZZJYPgp4GYEC8LihHJaNmnauZdoD8DoCBeBxuWy9bZra4IrGTMCrCBSAhxmGMbX1dpY9FNLU0tH2i30yDCMvYwPgLAQKwMNGxidl/v6vzLKHQpJ2b6pVKOBTV++IzvcM52l0AJyEQAF42FDqHA+fTyoNZl+hqAwHtXtjrSTpqTdv5GVsAJyFQAF4mLntdnkoIL/fl9NtPbh9lSTpSQIF4EkECsDDzApFtrtkpnsoFSh+1tGj+MRkzrcHwFkIFICHmQ2Z2Z7jkW7H2iqtqgprZHxSL57vy/n2ADgLgQLwsKldMnOvUPh8Pj24LVmloI8C8B4CBeBh+diDIt1Dt9BHAXgVgQLwMGuXzBz2oEj3wNaV8vmkM1cH1HljMC+3CcAZCBSAh/zJ91/Xx7/8c6tp8mr/qCSpriKcl9tfUVGi995SL0n6u59fzMttAnAGAgXgId987oKe7ejRqcvJMzfMTag2ryzP23188v6NkqQTJ7usCggA98s6ULS3t6utrS2fYwGwjEbHJzU6npAkddwYkiSd70n+d2NdRd7u58Ftq7SprlwDoxP67suX83a7AIrbkgNFe3u79u7dq97eXrW0tCzHmAAsg77hMevfHan+hgupQLF5Zf4Chd/v0yfu3yRJ+p/PXuBsD8AjlhQo2tvb9fDDD+vo0aOECcBh+obGrX933hjSwOi4bg4mQ8bGuvxNeUjSI7vWqywU0NlrA3qBPSkAT1hSoNi3b58OHTqkpqamRa8bj8cVi8WmfQCwT3RkqkLReWNQF1L9EysrS1RVGsrrfdWUhfSBO9ZKkv711NW83jaA4pRxoGhra1NnZ6c6Ojq0b98+bdmyRceOHZv3+ocPH1ZNTY310djYmJcBA8hOdHiqQnGhZ1hvX09Oe+SzfyLd3tuSqz0eP3ONaQ/AAzIOFO3t7WpqatLRo0d14sQJnThxQgcOHFBnZ+ec1z906JD6+/utj66urrwNGsDSpfdQTCQM/fStm5KkTcsUKB7YtkolAb8u9AxbPRsA3GtJUx6RSMT6d3NzsyKRyLwrPcLhsKqrq6d9ALBPeoVCkn5y9rokaVOe+ydMFeGg7ttSJ0l6/I3ry3IfAIpHxoGiubl5VjWitrZWtbW1eR8UgPyLplUoJKlnKPn5pjyu8Jjp4VtT0x4ECsD1Mg4ULS0tqq2tVXt7u3UZS0cB5+hLVSjKQtO32V6uKQ9JenhHMlC8eKFXfUNji1wbgJMt6USg1tZWHTx4UHv37lVHR4cef/zxadMgAIqXWaG4q7FGP+/stS7fmMddMmdav6Jct66p0pmrA/rJm9f1a/esX7b7AmCvJQWKpqYmnThxYrnGAmAZmT0UzRtWWIGirqJE1XleMjrTwzvqdebqgJ44c4NAAbgYZ3kAHmGu8mjesMK6bDn7J0wPbkseaf7M2zeVSLB8FHArAgXgEWaFYt2KMq2pLpWU/x0y53LPhhUqLwmoZ2hMb1xlgzvArQgUgAcYhqHoSDJQrCgv0Zb6ZGVi8zI2ZJpKgn7d15RcPvp0au8LAO5DoAA8YCA+ocnUdEOkPKSP7m7U1vpKvW/nmoLc/7u2rpQkPf02gQJwqyU1ZQJwpmjqYLDSkF+loYA+fPc6ffjudQW7/we2JQPF8+d6NTo+qVOX+9U7NFawQANg+REoAA8wGzJXlJfYcv/b6itVXxXW9YG4/vuPzuobz57XRMLQN3/7Xqt6AcDZmPIAPMDsn4jYFCh8Pp/enQoOX3n6nCZS0y//9YdvsPIDcAkCBeABUatCsbx7Tizk3dumKhG/cGu9qsJBne6O6bsvX7ZtTADyh0ABeIC57XXExkDx8I7V2r66Ur9851r99b9r1r9/7xZJ0v/zo7MaHZ+0bVwA8oNAAXiAeY6HXVMeklRTFtKPf/8h/eXHmxUOBvSZd21WQ02puvtH9Y1nz9s2LgD5QaAAPKDf2oPCvgrFTKWhgD63d7sk6W+e7NBgfMLmEQHIBYECcKmxiYT++ZVuDcYnrFUekTL7KhRz+cg967R5ZYX6hsf19WfO2T0cADkgUAAu9Z32S/rdf3hJ/+m7p9KmPIqnQiFJwYBfn2vZJkk69lSnVUkB4DwECsCluvqGJUn/cuqKuqMjkuzbh2Ihv3Jng7avrlRsdEJffZoqBeBUBArApQZGkz0Jo+MJvX19UJK0oqK4KhSSFPD79B/eu1WS9N2XL8sw2JcCcCICBeBSsTmmD2qKrIfC9PCO1SoJ+nWhZ1hvpcIPAGchUAAuZVYo0hXTKo90leGgtZNm6+vXbB4NgGwQKACXio3OVaEozkAhSXtvWy1J+vHpqzaPBEA2CBSAS5kVindtrZMkVZUGFQwU70v+4R318vmkVy7160r/iN3DAbBExfvuAiAnZg/FJ+/fpJWVJbqvqc7mES2svqpUzRtWSJLamPYAHIdAAbiUWaHYVl+ppw/+go59YpfNI1qcNe1BoAAch0ABuFAiYWhwLBkoqstCKg0F5PP5bB7V4t6/c40k6dmOHl2Ljdo8GgBLQaAAXGJ0fNI6D2MgPiFzO4eq0qCNo1qazSsrtGfTCk0mDB1/ocvu4QBYAgIF4BIf+oun9Z7//hONjk9qILXCIxz0KxwM2Dyypfn4vRskSd96/qImE2xyBTgFgQJwgYnJhN68Nqibg3Fdjo4oNpKsVFSVFu8y0fn80u1rFSkPqbt/VE++ed3u4QDIEIECcIGxyYT1757BMatCUe2g6Q5TaSigR5rXS5K++fOLNo8GQKYIFIALxMfTA0VcsdQKj6oi3shqIb+ZmvZ44ux19qQAHIJAAbhAfGIqUNwccnaFQpK2rKpU84aIEob0k7M37B4OgAwQKAAXiE9MWv/uGYxbm1pVO7CHwvTQ9npJ0lNvEigAJyBQAC6QXqFI9lCYTZnOrFBI0oPbk4eFPf32TU2k9YgAKE4ECsAFpvVQDMU1EJ/a1Mqp7lwfUU1ZSAOjE3rlUr/dwwGwCAIF4ALpUx43B8esKY+qsHMrFAG/zzrSnGkPoPgRKAAXmD7lEbemPJxcoZCmpj2eeotAARQ7AgXgAtOaMofGFEut8nByD4UkPbBtlSTpla6o+ofHbR4NgIUQKAAXSO+hiA6Pq3doTJKzV3lIUkOkTFvrK5Uwks2ZAIoXgQJwgfQpD0m60DMsyfkVCkl6+Nbk8tHHTnJYGFDMCBSAC6RPeUiyTh114lkeM/3mOzbI55OeOHtD524O2T0cAPMgUAAuMLNCYaouc36FYtPKCr33lmSV4hvPnrd3MADmRaAAXCC9hyKdGyoUkvS/v3OTJOmxk5esbcUBFBcCBeACM6c8JMnnc/Y+FOke2LZSW1ZVaDA+oW+fvGT3cADMgUABuMDoHBWKypKg/H6fDaPJP5/PZ1Up/uF5mjOBYkSgAFzArFD40vKD0ze1mulDd61TScCvs9cGdOZqzO7hAJiBQAG4gNmUWV8Vti5zw5LRdDXlIb3nluRGV//8crfNowEwE4ECcAGzKbMhUmZd5vRNreby4bvXSZL+18vdMgwj59s79lSHfuebJ/XUmzfycnuAlxEoABcwpzzSA4XbKhSS9PCOelWUBHQ5OqL2i3053dbYREJH/vWsfvjaVX3yq8/rV//yGfUMxvM0UsB7CBSAC5hTHutcHihKQwG9//Y1kpJVilxc7B3SZMJQKOBTWSigVy716xs/u5CPYQKeRKAAXGCuQOG2pkyTOe3xg1evaHxy7v03MtFxI7nr5q1rqvWlD+2UJD159nruAwQ8ikABuIA55REpD6ksFJDkzgqFJL1rS53qKkrUMzSW04FhnalA0bSqQg+lmj1fvdzPtAeQJQIF4AJmU2Y4GFBdZYkkdzZlSlIw4Nev3LlWUm6rPTpvDEqSmlZWanV1qXasrZZhSE+9dSMv4wS8hkABuIA55REO+VVXmVw66pZtt+fyodS0x49OX9XI2OxdQjPReXOqQiHJWpL6k7MECiAbBArABcwpj3DQr7vX18jnk3asrbJ5VMuneUNE61eUaXhsUm1vXMvqNqwKRSpQmAeQPfXmDU0mWEIKLBWBAnABq0IRDOiLH9yp5/+oRfdsWGHzqJaPz+fTh+9ukJTdao++oTH1DScPGdu8MhkomjdEVFUaVN/wuF69FM3bWAGvIFAALjDVQ+GX3+/TqrQdM93KXO3x5JvXFR0eW9L3dt5MVicaakpVXpJsXg0G/Hpg20pJ0hNMewBLRqAAXMCc8igNeeclvX11lW5dU6XxSUPff/XKkr63w1rhUTnt8pYdqyVJf//cRQ2PTeRnoIBHeOfdB3Cx9CkPL/n15vWSpO+0L+1I8/Qlo+l+5c4Gbagt183BuL7+7Pm8jBHwCgIF4AJTgcJbL+kP390gv09qvxi1miwzMbVkdHqgKAn69ft7t0mS/uYnHeofGc/fYAGX89a7D+BCE5MJa1WC1yoU9dWlenB7crnnP710OePv67BWeFTO+tqH7lqn7asrFRud0P/4aWd+Bgp4AIECcDizOiEl96Hwmo9Y0x6XlchguefEZEIXe4clzZ7ykKSA36c/eN8tkqSvPXM+630uAK/x3rsP4DLpgaIk4L2X9PtuW62q0qAuR0f03LneRa/f1Tei8UlDpSG/GmrK5rzO3h2rtaG2XIPxCf3o9NV8DxlwJe+9+wAuY67wKAkkl4x6TWkoYG3F/Xc/X/y00Fe6opKkW1ZXzfv/y+/3WQ2fj51cWsMn4FUECsDh0veg8KpPvXOTJOlfTl3RhZ6hBa/7884eSdJ9TXULXu8jzcl9Lp7puKnL0ZHcBwm4nHffgQCXSD/Hw6tuXVOt99yySglD+vIijZSZBorG2nLd31Qnw5C+Q5UCWJR334EAl5g6x8NbKzxm+uxDWyRJJ168pJvzHEF+pX9E53uG5fdJuzctvjX5I7tS0x7tl2QYnO8BLIRAATicV/egmOnezbW6qzGi+ERCX3/m/JzXea4z2bR5x7qajE5j/aU71qiiJKALPcN6+u2b+Rwu4DrefgcCXMDsoSjxeKDw+Xz67INNkqTjL3bNeWLozzoym+4wlZcE9dE9jZKkv3qiI08jBdzJ2+9AgAtYUx4hb095SNLDO1arujSoGwNxvXB+9hLSn59bWqCQpP/jgSaFAj79rLNHJy/05W2sgNsQKACHG2WVh6Uk6Nf7d66RJP1gxoFh3dERXVhC/4SpIVKmX7snueLjr3/ydv4GC7gM70CAw001ZfJylqRfTu1J8S+nrkyb9jCnOzLtn0j32Ye2yOeT2t64rjNXY/kbLOAivAMBDufVk0bn866tKxUpD+nm4JieSy0RNQxDf5va9Mo8+2MpmlZV6gN3JIPKX/+EXgpgLgQKwOHi42YPBS9nSQoF/PrF1LTH919LTns8/fZNvdwVVWnIr0/evymr2/33qWWp33ule9HNswAvyvodaNeuXYpGo3kcCoBssGx0NnPa44evXdFb1wb0548nex9+8x0btKoqnNVt3r6uxto862+e5BRSYKas3oGOHTum9vb2fI8FQBaY8pjt/qY6Na2sUHR4XL/850/r+fO9Kgn4deDBLTnd7n9471ZJ0rdPXtK12Gg+hgq4xpIDBVUJoLjQlDlbMODXP372fj2wbaXGUoFr3+71WlNTmtPt7tlUqz2bVmhsMqGvPH0uH0MFXGPJ70CHDx/W/v37l2MsALJgHQ5GD8U0KyvD+san36E/+sCt+sWda/S5lu15ud3fevdmSVLbG9fycnuAWwSXcuW2tjZ97GMfy+i68Xhc8fjUfvqxGEutgOVgTnmUMuUxi9/v0/4cpzlmur9ppSSp88aQegbjqqvMricDcJsl/UnT2tqq5ubmjK57+PBh1dTUWB+NjY1ZDRDAwqZ2yqRCUQg15SHdsrpKkvQiO2cClozfgR599FEdOnQo4xs+dOiQ+vv7rY+urq6sBghgYTRlFp650+aLc2zvDXhVxoHi+PHj2rx5s1asWKEVK5Ivps2bN+vRRx+d8/rhcFjV1dXTPgDkh2EY6rgxqETCmOqhoCmzYPZsqpUkvXCeCgVgyriH4uTJk9M+9/l8OnfunCKRSL7HBGARf//8Rf3Hfzql//uXd7DKwwZmheLU5X6NjE2qrITqEMA7EOBAb14dkCS91BWdmvLgtNGCWRcp09qaUk0kDL3cFbV7OEBRyDpQGIZBdQKwSXRkXJLU1TvMTpk28Pl82m1Ne9BHAUhUKABH6k8Fiou9w0x52GRPatqDQAEkLWkfCgDFwQwU0eFxK0iwyqOwdm9MViheuhjVZMJQwO+zeUSAvfiTBnCg/uFx69/XYskN5NiHorBuWVOl0pBfg/EJnef0UYBAATiRWaFIx5RHYQX8Pt22Nrkc/tTlfptHA9iPdyDAYQzDmCdQMOVRaLevq5Ekne7maAGAQAE4zPDYpCYSxqzLqVAU3u0NyUBBhQIgUACOE52jOiHRQ2GHneumpjwMY3bIA7yEdyDAYdIbMtMx5VF42+qrVBLwKzY6oUt9I3YPB7AVgQJwGLN/onzGds9MeRReSdCvW9YkTx5l2gNexzsQ4DD9I2OSpG2rqxRM2/uAQGGP281pj24CBbyNdyDAYcwKRV1FiRoiZZKSfyn7fGysZIedVmMmKz3gbQQKwGHMQFFTFtKG2nJJVCfsZC4dpTETXse7EOAw0eGpQNFoBQoaMu1y65oqBfw+9QyNWbuWAl5EoAAchgpFcSkNBbSxLvk8dN4ctHk0gH04HAxwmPRAsbq6VBJ7UNitLJSsEI2ljpIHvIh3IcBhzEARKQ9pz+YVWllZoge3rbJ5VN4WCiTfSicm6aGAd1GhABwmvUJRX1Wq5/+oRX6OzrZVKJD8/z+RoEIB76JCAThMeqCQRJgoAkF/8q10jAoFPIxAATjMzEAB+wXNCsUkFQp4F4ECcJBEYuro8ppyAkWxKKGHAiBQAE4yEJ+QuXcSFYriYVYoxumhgIcRKAAHiaWqE6UhP5tZFZFgqkIxzrJReBiBAnAQc5fMSFmJzSNBOmvKI8GUB7yLQAE4CA2Zxck89XWcHgp4GIECcBACRXGypjxY5QEPI1AADhIdGZPECo9iE2LZKECgAJyECkVxMrfeHqeHAh5GoAAchEBRnNjYCiBQAI7SP0ygKEYhv9lDQYUC3kWgABwk/aRRFA9rYysqFPAwAgXgIEx5FCeOLwcIFICjXOkflSTVVYRtHgnShdh6GyBQAE4xMDquczeHJEk71lbZPBqkC9JDARAoAKd4vTsmSWqoKVVdJRWKYsI+FACBAnCMU6lAsXNdjc0jwUzWPhRUKOBhBArAIU5f7pck3d5AoCg2bL0NECgAx3jNDBTrqm0eCWaypjxoyoSHESgABxgem1DHjUFJ0h1MeRQdmjIBAgXgCG9cGVDCkFZVhVVfXWr3cDADTZkAgQJwhNPdZv8E0x3FiKZMgEABOMJrl5KBgumO4sTW2wCBAnAElowWN2vrbY4vh4cRKIAiNzaR0FvXBiRJO5nyKEr0UAAECqDo9Q2PaSJhKOD3aV2kzO7hYA6s8gAIFEDRM08YrS4Nyufz2TwazIUeCoBAARQ9jiwvfiX0UAAECqDY9Q8TKIqdtfX2BBUKeBeBAihy1pQHgaJoBf2pKQ+23oaHESiAIkegKH7WslGaMuFhBAqgyNFDUfymDgczZBiECngTgQIocgSK4mf2UEgsHYV3ESiAIhcjUBQ9s0IhcYQ5vItAARQ5KhTFz9zYSqJCAe8iUABFLjZKoCh20yoUbG4FjyJQAEWOCkXx8/l8U0tHqVDAowgUQJEjUDgD22/D6wgUQJEjUDhDyM/22/A2AgVQxOITkxodT/7Fy8ZWxS0UNE8cpUIBbyJQAEXMrE74fFJVOGjzaLCQqR4KAgW8iUABFLGYdXR5SH4/R5cXM7bfhtcRKIACar/Yp98//rKuxUYzuj79E84xtf02FQp4E4ECKKCvPXNe//TSZX3vle6Mrj91MBjTHcXO3H57bIIKBbyJQAEUkDmFER0ez+j6VCicw+yhoEIBryJQAAU0GJ+QNBUUFtM/TKBwCnoo4HUECqCAhpYaKEaS1ydQFL8QG1vB4wgUQAEtuUJh9VAQKIqd2UPB1tvwKgIFUEBLrVBwMJhzsMoDXkegAApoKD4paSooLIamTOcwjzCnQgGvIlAABRKfmNRYan49tsQpDwJF8ZtqyqRCAW8iUAAFYlYnpGRQMIzF/5KNESgcg6ZMeB2BAigQs39CSpbFR8YnF7h2EhUK56ApE163pEDR1tamLVu2yOfzad++fcs1JsCVBtMChZRZYyaBwjlCbGwFj8s4UESjUZ04cUKtra06efKk2tradODAgeUcG+AqMwNFbGRinmsmjU8mNDyWrGIQKIpfiAoFPC7jAwLa2tp09OhR6/NDhw7p+PHjyzIowI2WWqFI/3pVKYGi2AXpoYDHZRwoHnnkkWmfRyIRNTU1zXv9eDyueDxufR6LxbIYHuAeQ1kGiqpwUAGOLi96bL0Nr8u6KbO1tXXBKY/Dhw+rpqbG+mhsbMz2rgBXyDZQsEumM5iHg43TQwGPyipQdHZ2qra2Vi0tLfNe59ChQ+rv77c+urq6sh4k4AaD8emrOjINFPRPOEMomOqh4PhyeFTGUx7pjhw5Mq2fYi7hcFjhcDirQQFuNDi6tArFa5f6JUmNtWXLNibkD6s84HVLrlAcO3ZMBw8eXI6xAK42NDZzlcfCgeLHr1+VJD186+plGxPyh30o4HVLChSPPfaYdu/ebTVjdnZ2qq2tbVkGBriNucqjvCQgaeFA0R0d0anLMfl90sM76gsyPuSGrbfhdUtaNjrXZlaZbB8MFKPXLvWrrCSgrfWVBbk/sylzXaRMb10fXHDKo/X1a5Kk3RtrVVfJ1KETsPU2vC7jCkVLS4sMw5j1ARSzly726fuvds+6vHdoTL/+18/qN7/884L9HJuBYm0k2ROxUKAwpzv23sZ0h1NMrfLgfRHelFVTJuAUv3/8ZZ3vGVZtRYneuWWldfnp7n6NTSZ0YyCuwfhEQTaOGhg1KxSlkuYPFP3D43qus1cSgcJJgkx5wOM4HAyudnNwTJL0reenL1s+e3Vg1nWWm9mU2VCzcIXiibPXNZEwtH11pTatrCjI2JC7Epoy4XEECriaeaLnv566qr6hqeBwZlqgiM/6vuVgHl/ekJryiI3OHSiY7nAmtt6G1xEo4FrjkwlNpuazxyYT+s5Ll62vpVcoegoUKMxVHmagGB1PKD4xfbOr0fFJPXn2hiTp/TvXFGRcyI8gW2/D4wgUcC2zOmE6/sJFGYahyYSht65PBYobBZryMDe2WlNTKl/qaI6Z0x4/6+jR0Nik1lSX6o51NQUZF/KDja3gdQQKuNZo6uhvn08qDfn15rVBtV+M6mLvsEbHp970bw4sf4ViMmFYAaeqNKiqcLIfeuZeFOnTHT4fB4I5ibkPxRgVCngUgQKuZf4CLw8F9IE71kqSvt1+SWevTj/5thA9FOm7ZFaGg6opT64qSa9QJBKGWl+/Lkl63076J5zG7KFglQe8ikAB1zKrEGUlAX3knvWSpB++dkWnLicDhXkkeE9qymMyYejt64PLsi+FuQdF0O9TOOi3DvxKDxQvdUV1czCuqtKg7t1cl/cxYHlxfDm8jkAB1zIrFKWhgO7fUqf6qrCiw+P6++cvSpLuXJ/sUTArFF9/9rxa/vRJnXjxUt7HYgaKinBQPp/PChSxkanKhTnd8d5b6lUS5KXpNBxfDq/jXQuuNTI2FSgCfp8+eFeDpOQumZL07q3Jja7MQPHzzh5JUtsb1/I+FnNTq8pU70R16fQKhWEY+vHp5P0y3eFM1vHlTHnAowgUcK3RVIWiLJQ8jOtX71437evvsgJFMmBc7BmWJL1yKZr3sZh7UFSEk2OZOeXRcWNQ524OqSTg10PbV+X9/rH8Qn6mPOBtBAq41sxAcfu6ajWldp6MlId0W0O1pOT+ECNjk7rQOyRJuhaL62r/aF7HYu5BYVYoZgaKH6cOA7t/S11BtgFH/k1tbEWggDcRKOBaVg9F6rhwn8+nD6eqFLeuqVJVOGj1Krx+JTZtKenLXdG8jiW9h0KSqmcGCqY7HI/TRuF1HA6GopRIGJo0DKtzPhtWoEhrcPytBzarf2RcH7xrrXw+n1ZWlKi7f1TtF/qmfe8rl6L6xdvzt1OluWx0ZoXizWsDuto/agWYvTsIFE4V4nAweByBAkVnMmHol/+/n2oiYegHv/tuhYOBrG7HbMosK5n6/spwUH/8wdusz1dWhdXdP6oXL/RO+95X8lyhMJsyzQrFQ9tXqSwU0KuX+rX/b1+UJN2zIaL66tK83i8Kx9x6m+PL4VVMecB2Nwfj+srT5xQdTjZHdkdHdObqgN6+Pqjnz/Uu8t3zm9lDMZeVlWFJ0skLUUnSro0rJEmvXepXIo+/GIZm9FA01pbri6lg8+qlfkkcBuZ01tbbVCjgUQQK2O6rT5/Tn3z/dX31mfOSpIu9w9bXHn/jeta3a/ZElC4YKEokTS0dbdmxWqUhvwbiE+q8OZT1fc80M1BI0sf2NOp9aSHifbdxGJiTmVMeCUPWoXSAlxAoYDtzX4gzV5I7WJ7vmfpF/m9nrme9c2X6xlbzqUtVKExbVlVYh3Llc9pj0Fo2OhUofD6f/tuv36nb1lbr/TtXa2t9Zd7uD4VnrvKQaMyENxEoYDvzF79ZEbjQM1WhuNg7rI4b2VUKRpYw5WHaWFehu9ZHJOV3P4qpCsX0sdRWlOiHv/eAjn5id97uC/ZIbyCeoEIBDyJQwHZm8+SFniFNTCZ0oWd6gHjiTHbTHqNWU+b8P+bmlIdpQ2257myMSJJeu9yf1f3OZXDGslG4j7n1tkQfBbyJQAHbmZWE8UlDXX0jVoXC3DHy8TPZbYU9OrF4hWJVWoVidXVYZSUBbUtNPZzLYw8FgcL9An6fzBPnxwgU8CACBWwXT9tQ6u3rg1ag+PS7NkmSXjzfN+1Uzkyln+Uxn/Qeio21yV00N9Ul/xsdHldfqr8jV+aURxWBwrV8Ph/bb8PTCBSwnVmhkKTnOns0Mj4pv09655aValpVoYmEoRfPL335aCZNmelTHhvryiUl961oqEnuB5GvlR4zd8qEO5mNmQQKeBGBArZLDxT/djbZL9EQKVNJ0K+tq5LTD91ZnK0xkqp8LDTlsaK8RIHU3LcZKCRp86pklSJf0x7WaaOlBAo3M/somPKAFxEoYDtzakKSOlMrOsxph/rq5JTEjdjSA8XoHDtlzuT3+1RbkaxSbEzdpyRtXmkGisEl3+9M45MJDaQqFCvKSxa5NpzMPBtmIkGggPcQKGC70bQKhcmsFqyqTE49XB+IL/12Jxaf8pCkexojKgn4dc+GiHXZ5pX5a8yMpfV/VFOhcLUgPRTwMN7dYLuRBQKFWaHIJlBMNWUunJv/6n9r1mB8QpG06oF5zHlnlntgpIumAkVVadA67wHuFOTEUXgY726wlWEYVqAIp50Kak4/1FeZgSKbHorFl41KyUOdIjOmIjalAsWFnuGcz/SIDicDRaQ8lNPtoPiZm1uNU6GABxEoYKv4RELmztq3rq22LrcqFFWpKY9YFlMe44v3UMxn/YoyBf0+jYxP6loWYSZd/0hy6WmkjP4JtwsFOCAM3kWggK3S+yd2NkwFig2106c8bg7Gl3Tg0sRkwvorcbEKxVxCAb81hnM5TntQofAOs4eCI8zhRQQK2Mqclgj6fdqe2qGyviqs8pJke09dRYl8vuQJjj1DmVcpRiem/kJcrClzPuZKj1z3ojADRU0ZgcLtqFDAywgUsJXZOFkWCmj3plpJ0t2pszSkZH9DXUWqj2IJ0x7pS1HTezOWYmrpaI6BYoQKhVcErR4KAgW8h1UesJW1m2VJQLevq1Hb5x9SQ6R02nXqq8K6ORjXjSWs9BhNa8j0+XyLXHtu+drcqn+YHgqvCFmrPJjygPdQoYCtRmesxNhaX2lNd5isza2yCRRZNGSaqFBgqcxVHmxsBS8iUMBWI2OLb4+dzdJRq/KR5XSHNBUounqHNTaR/S8Ieii8w9x6mwoFvIhAAVuNpk15zMdaOrqECoW1qVUOFYo11aWqCgc1kTDUmcMW3FMVCqY83C5EDwU8jEABW01tPjX/j6K1W+ZSmjIz3NRqIT6fTztSe2O83h3L+nasHgqmPFzPmvKgQgEPIlDAVpn84s9mymNmb0a2dqytkiS9cSX7QGFVKJjycD223oaXEShgq0yaJ1dlMeUxah5dnsOUhySrQvHGlYGsvj+RMKzDwWqoULietbEVFQp4EIECtpo6wCuTCkVchpHZG/XU+SD5ChSxjO873UB8QuamiTRlul9J0HkbWxmGoW89f1GnLvfbPRQ4HIECtspkymNVKlCMTSQUG5nI7HbHcl82Kkm3rKmS3yf1DI0tadmqqT+1wqO8JJBzuEHxc+LW269d7tcffuc1Hfz2q3YPBQ5HoICtMgkUpaGAqkuTe1Nk2keRSbNnJkpDATWtSm4JfjqLPoqodTAY1QkvWJGa1vr2yUs5719SKGZQvhbL7RA8gEABW41mWEmor15aH0U8T02Z0vRpj6Wy9qBgyagn/Lv7N6ppZYUuR0f00aM/09mr2fXeFNJgPFn16x8Zz2paDzARKGArawOqRX7xL3WlR6a3m4mplR5L/+XACg9vqa8q1fED9+vWNVW6MRDXJ7/6nK72F/df/gOjyUAxPmlYzcxANggUsNXI+OI7ZUppgSLDvSjyGyiyr1CwB4X3rKoK61v779P21ZW6Fovrt77xgobHMuv9scNQfGps/akADGSDQAFbZdo8aU55ZDovbW3pnWNTpiTdlgoUnTcGrWWumTKnPAgU3hIpL9FXPrVHtRUlOt0d0+e+9bImi7RRc5BAgTwhUMBW1tbbizRPvnNLnSTpO+2XdT6DUDE6kb8eivqqsOoqSpQwpO++dHlJ88zmlEcNJ416TmNtuY59YpdKAn79+PVr+o//9JoMw9DJC7360vdOq6t32O4hSpqa8pAIFMgNgQK2ynSL7Ie2r9ID21ZqbDKh//KDNxa93dGxzIJKJnw+n957a70k6Q+/85o+/fUX9NO3bmR0YBgVCm/bvalWf/Ybd8vvk771Qpd+9a+e1a//9c/0tWfO67/96xm7hyeJCgXyJ7j4VYDlM5phr4PP59MXP3ibfvHPfqq2N67pqTdv6MHtq+a9fj57KCTpv/zq7WqoKdXfPNmpn5y9oZ+cvaHKcFCNteUKB/26Z0NEf/wrt8nn8037vn6WjXreB+5Yq8MfuUMHv/2aXumKWpc/8/ZNTSYMBfy++b+5AAapUCBPqFDAVks5xGtrfZU+ef8mSdIX//n0tGayXG43E6WhgD7/vlv0L597QL/5jkatqgprMD6hN67E9HJXVF975rzeuj77RFIqFJCkj+3ZoEd//U617KjXt/bfp6pwUNHh8aLYnXJojECB/CBQwFaZ7kNh+r2WbVpbU6pzN4f0n7/3+rzXy9dOmTNtWVWpwx+5U88delg/+N13639+5h3WKpDT3bN/OdBDAdNH9zTqf3xqj+5rqtM7tyZ7gp5++6bNo6KHAvlDoICtllpJqCkL6U8/erd8Pun4i136watX5rxePNXfkK8pj5n8fp92NtTowe2rdO/mWknSqcuzl5VSocBc3r0tOV331Js3bB7J9B6KGIECOSBQwFbZ9Drcv6VOv/OeLZKkP/zOq3r7+uwNp6wKxTIFinS3r6uRpFnla8MwpnooCBRI8+C2lZKk9ot9C07dFUJ6DwWBArkgUMA2iYSR9THjn2vZrl0bV2hgdEKf+uoLs3bQzHdT5kJuX5ec8ni9O6ZE2l4Dw2OT1jHWEaY8kGZjXYU21JZrfNLQc+d6bB0LqzyQLwQK2CaetuxyqZWEUMCvY5/YpU115bocHdFnvv7CtDdGayolzz0Uc9m6qlLhoF8D8QldTNtbwOyfKAn687J8Fe7y7lSV4qk37eujSCQMmjKRN7zLwTYjabtOZlNJqKsM6xufeYfqKkp06nJMn/7a8xqMTyiRMKw9Igox5REM+HVrqjHzVKox0zAMHXuyQ5K0prp01nJSwJz2+OFrVzQwas8v8uHxSaXv00agQC4IFLCNGShKgv6s1+JvrKvQ1z/9DlWVBvXC+T59+mvPq2dozPp6oSoDtzekAkWqMfMrT5/TN352QT6f9Ie/dGtBxgBnec8t9dpQW67rA3H91x/as8lVev+ERKBAbggUsE2+GifvWF+jv/ute61Q8YmvPGd9rTS4/BUKSdrZkGzMPN3drx+dvmrt5vlHv7RDH7hjbUHGAGcpDQX06CN3SpL+4fmLevqtwk99DManBwgCBXJBoIBtRvO4+dRdjRH97W/dq5qykM5cTa76CAf98hdoF0KzMfOli1H9wT++Ikn65P0b9dsPbC7I/cOZ7muq06fu3yhJOvjtVzPazj2fBuPJ12BVaXLT5PhEYskH4AEmAgVsk+/GybsbIzrx2fu1JnUyaSEaMk3bV1cp6PdpMD6hwfiE7t1cq/80x1bcwExf+MVbVVMW0uXoiM5cnb2XyXIypzzW1pTK/FGN2dTPAecjUMA2I2P5X9q5fXWVvv0779S7t67UJ+7bmLfbXUxpKKBtq6skJZsw/+LjzQoFeHlhcRXhoG5LNfW+eW329u3LyZzyqC4Nqbo0uVcKe1EgW7zjwTZTu2Tm98dwXaRMf/fb9+oP3ndLXm93MZ+4b6O2r67U0U/s0qqqcEHvG862fXWlJOmta7M3aVtO5rbbFeGgalIH2NFHgWxx2ihsM1rAvSIK4eP3btDH791g9zDgQGZ162yBA4W5d0tlKYECuaNCAdtYR5cXaCUGUKxuWZMMFG8VeMrD3Pa7igoF8oBAAdtYPRQuqVAA2dpenwwUl6MjBd3kasCsUISDqi5LFqz7hwkUyA6BArYZGS/cbpZAMaspD6k+1Xfz1vXCVSnMVR7pUx6xUXsPK4NzEShgm6UeXQ642dS0R+H6KAanVSiY8kBuCBSwjduaMoFcbEtNexRy6ahVoaCHAnnAKg/YZjn2oQCcylw6+qYdFYrSoCZTp4QRKJAtAgVsw5QHMMVcOmpLoAhP/SogUCBbS5ry6Ozs1IEDB3Ts2DEdPHhwucYEj1iuja0AJzIrFNdi8YKttDADRVVpkJ0ykbMlvZPv3btXBw4c0P79+7V3717t3bt3ucYFDxgdo4cCMFWVhtRQkzyH5s3rhalSTPVQhOihQM4yDhRtbW3q7e1Vc3OzJKmlpUVtbW3q7OxctsHB3cwKBT0UQNKO1Jke333pckHuz9yHoiIcIFAgZxn3ULS3t2v37t3TLmtqalJbW5v279+f94Fl6npsVBMJw7b7R/bMUw3poQCSfvuBJj1+5rq++dxF/do967R7U+2y3dfYRMI6Lr0qHFIi1ZQ5PDaprt5hBfyclOtE9VVhBW06mDDjQNHR0aFIJDLtskgkoo6OjjmvH4/HFY/Hrc9jseU5lvejR3+m8z3Dy3LbKAwqFEDS/Vvq9NHd6/WPL17Soe+8ph/87gMqCS7PLwdz220pWaHw+aYCxAOPPrEs94nl9+T/9R5trKuw5b6XbZXH4cOH9aUvfWm5bt4SCviX7QWH5bd+RZnuWh+xexhA0fijD+zQv525rreuD+ovnnhbn9+7fVnux2zILAsFrL9of/XuBv3w1NVluT8Uhk/2VZYyDhRbtmyZ1S8RjUa1Z8+eOa9/6NAhff7zn7c+j8ViamxszHKY82v9/EN5v00AsEukvERf/OBO/Z//8JL+4t/e0n1NtXrnlpXquDGo3qEx7cnTNMhA2rbbpj/7jXv0Z3m5dXhRxn/aNzc3zwoUnZ2dVpPmTOFwWNXV1dM+AACL++BdDdq3a70ShvR733pZf/L91/W+//cpffToz9R5Iz87ac61BwWQi4wDRUtLiyRZoaKtrU3Nzc1qampanpEBgIf95w/fru2rK3VjIK6vPH1OkwlDhiE9f643L7c/RKBAni2p+aC1tVVHjhzRsWPHdOLECT3++OPLNS4A8LSykoD+8uPNWlGe3J/igW0rJUkvd0XzcvsDBArk2ZJ+kpqamnT06NHlGgsAIM221VV69g8fVjjoV9sb1/TTt27qpYvRvNz24Bw9FEAuWB4BAEWsrCQgv9+nuzdEJCV30RxMW/KZrYHUPjBVVCiQJwQKAHCA+qpSrYuUyTCkV3OY9rjaP6ovfe+0/rT1TUlSdWqHTCBXRFMAcIh7NkR0OTqil7qieufWlRl/n2EYevVSv77+7Hl975Vua3fhXRtX6FPv3LRMo4XXECgAwCHubozo+69eyaiPYjJh6I0rMT399k39U/tlnU07Fv0dm2v1u7+wTe/aWjdth0wgFwQKAHCIezaskCS93NUnwzCmhYHR8Umd7o6p/UKfft7Zo+fP91qbV0lSOOjXB+5Yq8+8a7PuWF9T8LHD/QgUAOAQOxuqFQr4dHNwTE+cva6r/XG9eimqVy/1681rA7MOSqwMB7Vn0wq13LZav3Jng3WiKLAcCBQA4BCloYBuW1utVy716zNff3HW11dWluiu9RHd21Sr+5rqdNvaattOnoT3ECgAwEF+6Y61euVSv6pKg7pzfY3uXB/RXetrdMf6iBpqSumJgG0IFADgIJ99aIt+Y0+jqktD8vsJDygeBAoAcJhIeYndQwBmYXINAADkjEABAAByRqAAAAA5I1AAAICcESgAAEDOCBQAACBnBAoAAJAzAgUAAMgZgQIAAOSMQAEAAHJGoAAAADkjUAAAgJwRKAAAQM4KdtqoYRiSpFgsVqi7BAAAOTJ/b5u/x+dTsEAxMDAgSWpsbCzUXQIAgDwZGBhQTU3NvF/3GYtFjjxJJBLq7u5WVVWVfD5f3m43FoupsbFRXV1dqq6uztvtFhO3P0a3Pz6Jx+gGbn98Eo/RDZbj8RmGoYGBATU0NMjvn79TomAVCr/fr/Xr1y/b7VdXV7vyhyOd2x+j2x+fxGN0A7c/PonH6Ab5fnwLVSZMNGUCAICcESgAAEDOHB8owuGwvvjFLyocDts9lGXj9sfo9scn8RjdwO2PT+IxuoGdj69gTZkAAMC9HF+hAAAA9iNQAACAnBEoHCwajdo9hLxwy+PIhpcfuxu55fl0y+PIhpcfe64cHSg6Ozt14MABHTt2TAcPHrR7OHnR1tamLVu2yOfzad++fbO+bn5tvq87xXyPw+nPaTQatR5X+kf6m5QTn8PHHntMu3btmvVmu9Dz5bTncr7H6KbX5HyPUXLHa3Kux+e21+RCP4+2vx4NB2tqajJOnjxpGIZhtLa2Gi0tLTaPKDd9fX3G/v37jY6ODuPkyZNGJBIx9u/fb329tbXVOHHihNHX12f09fXZN9AcLfQ4nP6cHj161Bq/YSSf0+bmZutzpz6HfX19hqQlPV9Oey7neoxue03O9zy65TU51+Nz02tysZ9Hu1+Pjg0Ura2tRiQSmXaZJKOjo8OmEeXuxIkT0z4/cuTItB/8Rx55xDhy5Mi0F4cTzfc43PqcfuELX7A+d/JzOPONeqHny6nP5czH6MbX5FyBwk2vybkeXzonvyYX+nkshtejY6c82tvbtXv37mmXNTU1qa2tzaYR5e6RRx6Z9nkkElFTU5P1eTQa1cGDB7Vr1y4dOHCg0MPLm/kehxuf0+PHj+tjH/uY9blbnkNp4efLLc8lr0l3PI/pnPyaXOjnsRhej44NFB0dHYpEItMui0Qi6ujosGdAy6C1tXXaD3hra6sMw9DRo0d17NgxPfroozaOLnvzPQ43Pqft7e1qbm62PnfLcygt/Hy58bmUeE1Kzn8e3fSaTP95LIbXo2MDhdt1dnaqtrZWLS0ts762f/9+HTlyRMePH7dhZPnjlscxn7a2tjmfP8n9j92NeE06n5tekwv9PNrFsYFiy5YtszqVo9Go9uzZY8+A8uzIkSM6evTovF9/5JFHXLG8Kf1xuO05bW1t1d69e+f9utOfw4WeL7c9lxKvSZOTn0c3vSZn/jwWw+vRsYGiublZnZ2d0y7r7OycVspyqkyX9bjhsUpTj8Ntz+ljjz02a85zJqc+Nmnh58ttzyWvySlOfh7d8pqc6+exKF6PeW3xLLCmpiarS7W1tXVa97VTnThxYlq3sdmha/7X9IUvfMERXckzLfY43PKcdnR0zFqW5eTn0FyON7MrfKHny2nP5XyP0U2vybkeo5tek/M9h4bhntfkfD+PhmH/69HRgaKjo8PYv3+/cfToUWP//v1Fv4Z4Ma2trYakWR/m1yKRiPHII4/MWlftJIs9Drc8p0eOHDGOHj067TKnPod9fX3GkSNHDEnGkSNHpj0nCz1fTnou53uMbnpNLvQY3fCaXOjn1DDc8Zpc6OfRMOx/PXLaKAAAyJljeygAAEDxIFAAAICcESgAAEDOCBQAACBnBAoAAJAzAgUAAMgZgQIAAOSMQAEAAHJGoAAAADkjUAAAgJwRKAAAQM7+f653UwiqV22mAAAAAElFTkSuQmCC",
      "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
}
