{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "4cc129ee-bfd6-4ab3-b809-1bc99e6d2225",
   "metadata": {},
   "source": [
    "## Will \"continual learning\" persist for deeper KANs?"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "4c1cf272-3e39-44bb-b4cf-c32717055049",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7f0c9ae17520>"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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nnvuOb+vWS9atIiVlpayQ4cOsZ07d7I77riDxcXFeQWporbvT3/6E1u9ejU7cOAAs9vt7NFHH2UA2LvvvusuI9J3qLZ9MjNnzmTjx4/3uU+Rvr+Ghgb3eQ4AW7JkCdu5c6f7TTtRf4NRH4zMmTOHAej174svvnCXAcBeffVV9/9LksSKi4tZdnY2S0xMZFOnTu0VDbe0tLCf//znLDMzkyUlJbFrr72WHT16lFOruqmurma33XYbS0tLY2lpaey2227r9Ypdz/YxxtgLL7zAkpKSfK47cfToUTZ16lSWmZnJEhIS2PDhw9m9997ba60OHqhtX3NzM5s2bRrr378/i4+PZ0OGDGFz5szp9d2I8v0xpr6N5eXlPvu0Z7828jt87rnn2NChQ1lCQgIbO3as10zMnDlz2EUXXeRVft26dez8889nCQkJbNiwYT4D5HfeeYeNGjWKxcfHs7POOsvrRGcEatp40UUX+fyu5syZ4y5z//33syFDhrCEhATWv39/Nm3aNLZ582aOLfJGTfueeeYZNnz4cGa1WllGRga78MIL2YcffthrnyJ9h2r7aG1tLUtKSmIvvviiz/2J9P3JMzj++puov0ETY11PqhAEQRAEQRgArTNCEARBEIShUDBCEARBEIShUDBCEARBEIShUDBCEARBEIShUDBCEARBEIShUDBCEARBEIShUDBCEARBEIShUDBCEARBEIShUDBCEARBEIShUDBCEARBEIShUDBCEARBEIShUDBCEARBEISh/H/8jUceLbfJQQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from kan import *\n",
    "import numpy as np\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "\n",
    "datasets = []\n",
    "\n",
    "n_peak = 5\n",
    "n_num_per_peak = 100\n",
    "n_sample = n_peak * n_num_per_peak\n",
    "\n",
    "x_grid = torch.linspace(-1,1,steps=n_sample)\n",
    "\n",
    "x_centers = 2/n_peak * (np.arange(n_peak) - n_peak/2+0.5)\n",
    "\n",
    "x_sample = torch.stack([torch.linspace(-1/n_peak,1/n_peak,steps=n_num_per_peak)+center for center in x_centers]).reshape(-1,)\n",
    "\n",
    "\n",
    "y = 0.\n",
    "for center in x_centers:\n",
    "    y += torch.exp(-(x_grid-center)**2*300)\n",
    "    \n",
    "y_sample = 0.\n",
    "for center in x_centers:\n",
    "    y_sample += torch.exp(-(x_sample-center)**2*300)\n",
    "    \n",
    "\n",
    "plt.plot(x_grid.detach().numpy(), y.detach().numpy())\n",
    "plt.scatter(x_sample.detach().numpy(), y_sample.detach().numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "10e4b8d6-b6ce-46a0-aaf2-e1770576f30b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1500x200 with 5 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.subplots(1, 5, figsize=(15, 2))\n",
    "plt.subplots_adjust(wspace=0, hspace=0)\n",
    "\n",
    "for i in range(1,6):\n",
    "    plt.subplot(1,5,i)\n",
    "    group_id = i - 1\n",
    "    plt.plot(x_grid.detach().numpy(), y.detach().numpy(), color='black', alpha=0.1)\n",
    "    plt.scatter(x_sample[group_id*n_num_per_peak:(group_id+1)*n_num_per_peak].detach().numpy(), y_sample[group_id*n_num_per_peak:(group_id+1)*n_num_per_peak].detach().numpy(), color=\"black\", s=2)\n",
    "    plt.xlim(-1,1)\n",
    "    plt.ylim(-1,2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "fc30a55b-9c32-4639-9718-58d47db98fd7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "checkpoint directory created: ./model\n",
      "saving model version 0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "| train_loss: 3.39e-01 | test_loss: 3.39e-01 | reg: 1.28e-01 | : 100%|█| 100/100 [00:09<00:00, 10.24\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "saving model version 0.1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "| train_loss: 3.39e-01 | test_loss: 3.39e-01 | reg: 1.64e-11 | : 100%|█| 100/100 [00:09<00:00, 10.17\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "saving model version 0.2\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "| train_loss: 3.39e-01 | test_loss: 3.39e-01 | reg: 1.84e-11 | : 100%|█| 100/100 [00:10<00:00,  9.14\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "saving model version 0.3\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "| train_loss: 3.39e-01 | test_loss: 3.39e-01 | reg: 5.08e-10 | : 100%|█| 100/100 [00:10<00:00,  9.46\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "saving model version 0.4\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "| train_loss: 3.39e-01 | test_loss: 3.39e-01 | reg: 1.02e-10 | : 100%|█| 100/100 [00:09<00:00, 10.29\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "saving model version 0.5\n"
     ]
    }
   ],
   "source": [
    "ys = []\n",
    "\n",
    "# setting bias_trainable=False, sp_trainable=False, sb_trainable=False is important.\n",
    "# otherwise KAN will have random scaling and shift for samples in previous stages\n",
    "\n",
    "model = KAN(width=[1,5,5,1], grid=20, k=3, noise_scale=0.1, sp_trainable=False, sb_trainable=False, base_fun='zero')\n",
    "\n",
    "for group_id in range(n_peak):\n",
    "    dataset = {}\n",
    "    dataset['train_input'] = x_sample[group_id*n_num_per_peak:(group_id+1)*n_num_per_peak][:,None]\n",
    "    dataset['train_label'] = y_sample[group_id*n_num_per_peak:(group_id+1)*n_num_per_peak][:,None]\n",
    "    dataset['test_input'] = x_sample[group_id*n_num_per_peak:(group_id+1)*n_num_per_peak][:,None]\n",
    "    dataset['test_label'] = y_sample[group_id*n_num_per_peak:(group_id+1)*n_num_per_peak][:,None]\n",
    "    model.fit(dataset, opt = 'LBFGS', steps=100, update_grid=False);\n",
    "    y_pred = model(x_grid[:,None])\n",
    "    ys.append(y_pred.detach().numpy()[:,0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "ed0a653a-5ba9-4311-b644-cdb32cfc86d8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 0.98, '[1,5,5,1] KAN')"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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yxeJiIiIKDTG2M2ViIiI/vAOHTqEpKQk9OrVK6T3L1++HAMHDgw5ABXr92/ZsgVJSUkYPHhwSO8nIiIiIt+YCUZEREQxd/DgQRQUFAAA0tLS/pB7TlVWVuL3339X/96pUyc0bNgwhldERERElFgYBCMiIiIiIiIiooQX0eWQr732Gvr374+MjAw0a9YM119/PXbt2hXJH0lERERERERERFRHRINgK1euxIMPPoj169dj8eLFcDgcGDp0KMrLyyP5Y4mIiIiIiIiIiGqJ6nLI/Px8NGvWDCtXrsRFF11U5/vV1dWorq5W/+5yuXDq1Ck0btwYJpMpWpdJRAFyOp3Yu3cvOnfuHNJJbkQUOSyfRMbGMkpkXCyfRMamKApKS0vRqlUrmM3B5XZZI3RNHhUXFwMAGjVq5PH7r732Gl588cVoXhIREREREREREcWZnJwctGnTJqj3RC0TTFEUXHfddSgsLMTq1as9vsY9E6y4uBjt2rVDTk4OGjRoEI3LJKIg5ObmokePHiyjRAbE8klkbCyjRMbF8klkbCUlJWjbti2KioqQmZkZ1Hujlgk2btw4bNu2DWvWrPH6mpSUFKSkpNT5eoMGDVj5EBmQlEuWUSLjYfkkMjaWUSLjYvkkig+hbJsVlSDYQw89hPnz52PVqlVBp6oRERERERERERGFK6JBMEVR8NBDD+Hrr7/GihUr0KFDh0j+OCIiIiIiIiIiIo8iGgR78MEHMWfOHHz77bfIyMhAXl4eACAzMxNpaWmR/NFERERERERERESq4M6SDNJ7772H4uJiXHLJJWjZsqX65/PPP4/kjyUiIiIiIiIiIqol4sshiYiIiIiIiIiIYi2imWBERERERERERERGwCAYERERERERERElPAbBiIiIiIiIiIgo4TEIRkRERERERERECY9BMCIiIiIiIiIiSngMghERERERERERUcJjEIyIiIiIiIiIiBIeg2BERERERERERJTwGAQjIiIiIiIiIqKExyAYERERERERERElPAbBiIiIiIiIiIgo4TEIRkRERERERERECY9BMCIiIiIiIiIiSngMghERERERERERUcJjEIyIiIiIiIiIiBIeg2BERERERERERJTwGAQjIiIiIiIiIqKExyAYERERERERERElPAbBiIiIiIiIiIgo4TEIRkRERERERERECY9BMCIiIiIiIiIiSngMghERERERERERUcJjEIyIiIiIiIiIiBIeg2BERERERERERJTwGAQjIiIiIiIiIqKExyAYERERERERERElPAbBiIiIiIiIiIgo4TEIRkRERERERERECY9BMCIiIiIiIiIiSngMghERERERERERUcJjEIyIiIiIiIiIiBIeg2BERERERERERJTwGAQjIiIiIiIiIqKExyAYERERERERERElPAbBiIiIiIiIiIgo4TEIRkRERERERERECY9BMCIiIiIiIiIiSngMghERERERERERUcJjEIyIiIiIiIiIiBIeg2BERERERERERJTwIhoEW7VqFa655hq0atUKJpMJ33zzTSR/HBERERERERERkUcRDYKVl5ejV69e+Pe//x3JH0NERERERESkq5dffhljxozBPffcg7Fjx2Lx4sWxvqRa9uzZg/Hjx2P06NGYOnVqRH7G2rVr8dhjj+HXX39Vv7ZhwwY88sgj2Lp1a0R+ph4URcHkyZPx5ptvwmazAQAqKirwyiuvYMqUKTG+Ot/mzp2Lp59+GkeOHFG/duDAAfz1r3/FV199FcMrSwwmRVGUqPwgkwlff/01rr/++oDfU1JSgszMTBQXF6NBgwa6Xs/Ro0fx3Xff4brrrkOzZs10/exIq66uhslkQnJycqwvJSgulwvV1dVISUmB2RxfK3Gl4oy3e+50OlFdXY3U1NSI3PPc3Fy0bdtWtzKal5eHnTt3onnz5sjOzoaiKDh48CCOHz+Os88+G02aNNHhqiPr2LFjWL58OYYMGYKmTZvG+nKCwrol+qqrqwEAKSkpun+23uVTy+VyoaqqKmJ1SyTF63N+/PhxLF68GFdeeWVc1IVabEM9i2QZjWTdEkkulws2mw3JyclxVbeUlpbi1VdfRXJyMp5++mmkpqbG+pIClpeXh2XLlmHo0KFxV7dEow11ZzabsW7dOgwYMCDkz9arDV20aBGuu+469T4AQE5ODtq0aRPyZ7rLzc1Fly5dUFFRgczMTPz0009QFAV9+vRBZWUlsrKysH//fjRs2FC3n6mXDz/8EHfeeScA4K9//Stef/11PPDAA/jwww8BIOjYRLTMnTsXt9xyCwCga9eu2LBhA6qrq9GnTx8cPnwYAPDDDz/giiuuiOVl+pWbm4vvv/8e119/fUTiLeHEiqy6X00YqquraxXikpKSiPycvLw89O7dGydOnMCLL76I33//HZmZmRH5WXorLS1FaWkpACAzMxP16tWL8RUFxuVyIT8/H06nExaLBU2bNo2bzk2833OXy2X4e64oCh599FG88847cLlcAIAGDRrAZDKhuLgYAGC1WvHqq6/iiSeeUN+3ZMkSTJ8+He+8844hAk7Hjh1D7969cfz4cbRp0wbbtm0zZKfAk3h+zk+cOBEXz7m7RLnnzZo1g8lkivVlBWT//v2YOHEikpOTMWHCBI8DHCPS1i1t27bFli1b0KhRo1hfVkDi+TmPlzbUXTzf86lTp+K///0vbr75ZowePTpu7vl9992HTz/9FEBNwNroWSYiLy8PvXr1wokTJ9C2bVv88ssvaNy4cawvKyDRes4vvvhiDBkyBADwwQcf4ODBg5g7d27IQTC92lCn04n77rsP1dXVuPTSS3Ho0CHs378fa9euVQMoepg5cyYqKioAAMXFxXjooYdgNptRWVkJACgqKsLHH3+M8ePH6/Yz9TJz5kz1/6dOnYobb7wRs2bNqvV9IwbB/u///k/9/507d2LKlCkoKChQA2AA8NZbbxk6CHb8+HH06dMH+fn5mDhxIrZu3WqoMZGhWpbXXnsNmZmZ6p9IdU5fe+01nDhxAgBw5MgR/OMf/4jIz9Gby+VCWVmZ+veSkhJEKZEvbGVlZXA6nQBqKu3y8vIYX1Fg3O95aWlpXN1zCSgZ/Z4vWLAAkydPhsvlQocOHZCWloaSkhIUFxcjPT0d7du3h8PhwJNPPomffvpJfd+QIUPw2Wef4bHHHovh1Z/2+uuv4/jx4wBqZj8mTZoU4ysKDJ/z6Ivn+vzgwYOYN28e3nvvPXz55Ze1OmVGZrfbceONN2LmzJmYOnUqbr31VvXZMbrXXntNrVtycnLw9ttvx/iKAsO6JfriuW5ZvHgxHnjgASxcuBB33313rfbeyE6cOIF58+apf581a5YanDE67ZgoJycHkydPju0FBSiaz/n8+fMxYcIETJgwARMnTgQArFixIuTPc69btP+OYKxevRqHDh1Cw4YNsWDBAgwdOhQAdF+e+P333wMAHnvsMVitVixevBiLFi2C1WrFmDFjAAALFy7U9WfqoaysDD/++COAmon16upqjB49Gk6nE0lJSQBqJtMdDkcsL7OO3NxcbNiwAWazGU899RSAmoDX+++/DwB44YUXAABLly7FqVOnYnWZfr3yyivIz88HUFO3GG1MZKgg2NNPP43i4mL1T05Oju4/w+VyqTM11157LQDgk08+iYsOQmVlJRRFQVJSEqxWKxRFQVVVVawvKyAyWyDp4fJ3o6uqqoKiKLBarbBarWr6cjyQWZu0tDQAxr7nkpb88MMP49dff8XOnTuxdOlSLF68GDt27MCOHTswfPjwWq/VMsIg3Ol01qlbZs+eHRd1izznUrfE03Mer3VLPNbniqLgjTfeQNeuXfHQQw9h4sSJePDBB9GlSxf861//ivXl+TVv3jxs2bJF/fuPP/6odu6NTFEUfPnllwCAa665BgAwZ86cuKpb2IZGTzzWLUIbgHG5XHETkPnuu+9gt9vRvXt3tGvXDhUVFYbbN8oTRVHw9ddfAwD+9Kc/AeCYyJ++ffsCAHbt2hXyfdKrbpEg8ZAhQ5Cenq5m2egZsK+oqMDGjRsBAHfeeSfuv/9+9Xv33nsv7rvvPgA1e4YZbVJp27ZtcDqdaNWqFZ555hkANZN4APDcc8+hfv36qKiowK5du2J4lXUtXboUANC/f388/vjjaNy4MfLy8lBYWIhWrVrhkUceQdeuXeFyubB69eoYX61nnsZEs2bNMlTdYqggWEpKCho0aFDrj95++eUX5OfnIy0tDTNmzEBSUhIOHjyIffv26f6z9CaVe1pamjrgi4eOjcPhgNPphMlkQlZWFkwmExwOh+Ei757E6z232+1wuVwwmUzqUl/5PURCuLNOmzdvBgB1XwOr1YoBAwZgwIABsFqtqK6uxogRIwDA48ywEZZirV27Fvn5+WjQoAFmzJiB5ORkHDhwADt37oz1pfklz3RqaqraKYuH5zye6xZZ+q+tW7TbAejphx9+0OVz3nzzTfztb3+D3W5Hjx49cOutt6Jr166orq7GX//6V8yYMUOXnxMpn332GQBg/PjxuPfeewEAH330USwvKSBbt27F0aNHkZqaivfffx8pKSnYv38/fv/991hfml9sQ6MvmnWLnk6dOoVly5YBgHqg1sKFC9WAgZFJVtDll1+OSy+9FACwfPnyGF5RYLZu3YqcnBykpqZi2rRpSE5OxsGDB/Hbb7/F+tL8itVz3r59ewA1Wa2hZOG41y3Sbwmlbvnll18AAL179waAiNSxv/76KxwOB5o3b47mzZvjiSeewKRJk/DGG2/gb3/7m7p6o7S0FHv27NHt5+pBJr169uyJ66+/HlZrzS5QJpMJ1113Hc4++2wA+mfOhWvDhg0AgAsuuABmsxmPPvqo+r2nn34aTqcTF198MQBgzZo1MblGfzZt2oSCggLUr18fM2fORHJyMg4dOmSofouhgmDRIDMzgwYNQuPGjdWKY8mSJbG8rIDIxrIpKSnqBpDyNSOTylg2OZUUVKNfu6IoaoOampoaV51J7UahZrNZ3Yw4Utc+atQoVFVVhfT5RUVF6sxMr169am2gLM95dXU1unXrBgDYvXt3nZkEI+wZsnLlSgDAhRdeWKtuCSdlPhq0z3lKSor6rBi9fAKn6xb35zwert1TfR6p8jl8+HBs3boVp06dCnkWbsuWLepM6vPPP48VK1Zgzpw5WLVqFR566CEAwLhx4+pkZS5cuNAQs6ylpaX43//+BwAYOXKkul/K0qVLDR80XbBgAQDg/PPPR4sWLdRMhFWrVsXysvxiGxo4PcuItzbU6JYvXw6bzYZ27dph7NixaNy4MUpLS7F+/fpYX5pPiqKog+3zzz8fgwYNAoBaWadG9c033wAALrroIrRs2RLnnnsugNP9GSOLZhuqlZaWhhYtWgCoOakvWHKN7mOiUK5906ZNACIbBNu2bRuAmv653W6H1WrFuHHjMH78eFgsFrhcLvTq1QvA6aCcUezYsQNAzcbyGRkZmDhxIs466yy89dZbaNKkCbp37w4A2L59eywvsw5JDOjdu7e6hHPevHlYvHgxbrjhBlRXV6v9AKMF8IRMaAwcOBCNGjXCwIEDARgr3hLRkWNZWRm2bNmiNgQHDhzAli1bYrp0SWZmZKbmoosuAmD8Ct9ut0NRFJhMJiQlJakdMqfTafiZSW0nGEDcDFQdDgcURVEbKWmoXC6X4e+5+0lcke4gHD58GGlpaWjcuDG+/fbboN4ry56bNGmC+vXrqzNkycnJSE5OhslkgtPpRPv27WG1WlFeXl7ruGDAfyZYeXk5HnjgATz88MMRS9det24dAKgV/QUXXAAAhk1VFlK3yEAvnuoWbScYiJ+6RTsTLPW5POeRCsicc845aNy4MS699NKQ9qp5/fXX4XK5cO211+Lee+9V6/PU1FQ89dRTGDRoECorK2vt+fDTTz/h6quvRteuXf1+/uzZszFw4MCIZU8sWrQIVVVV6NChA/r374+LLroIWVlZKCwsVPcMMSrpn8h+L1LHGP262YYG7i9/+Ysun6OtW9zbUKPfc8l+OP/882E2m3H++ecDMP5EUlVVFXbv3g0A6NOnjxqQ2Llzp+HvufRbLr/8cgBQg2Br166N2TUFIhZtqFZ2djYA4NChQ0G/173fEmpSQ3FxMfbu3Qvg9BLNSGTy//rrrwCAHj16eB2HShsv5cAoJEgpJ2WOGzcOv/76K+666y4AUPcel4l4I3A6nbUy2BRFgcViwY033qiWU5fLhbPOOguAcYNg0m+ROMt5550HwPNqnliJaBBs48aN6N27t9ogPProo+jduzeef/75SP5YrxRFwc8//wzgdBBM/mv0zqR7h0x7vLvRZ/jsdjsAqB3geMlik+uT65aKX/s9o3J/XqIVHCgvL8edd97p85l0OByYPXu22nmQ0x8bNmzo8TnXDpxat24NAEEHwV555RW89957+Oc//xmRClhRlFodeABqqrLR6xb38qmtW+LlOZdrj9fyGc26ZeXKlXjjjTeCek9VVZWajTR27Nhaz4gMPsaOHQugZt8tyTaTWWp/jhw5glGjRmH9+vV48skng7q2QEkw+sILL1Tv92WXXQbAmBv6Cm2WiWSYSKfS6BkybEMDt2fPHvTq1QtXX311WAMyX3VLuH3Fr776St3jJRIk+6F///4ATg+ajJ5RtWfPHlRVVSE1NRUdO3ZE9+7dYTKZUFBQgNzc3FhfnleKoqiZO3Kvpf8iYyWjimUbCgDNmjUDABQUFAT9Xm91S7DlU8pFu3bt0KRJEwCR2RtVljh26tQJgOdxaIcOHQAYLwgmdWmrVq0A1B2HyteNFATbtWsXKisrUa9ePXXprac29Mwzz4TJZMKJEyeQl5cXs+v1RFEUtX8icRaZvJOxkhFENAh2ySWXQFGUOn88bWwdDYcOHUJRURGsViv69OkD4PQvJScnBydPnozJdQVCBqpS4Wj/X75nRE6nU828cR+oOhwOw22iqOUeHADiI9PE1z3Xfk9PK1aswNatW9GqVSsUFhb63INoypQpGDVqlNpoFhUVAag53lpm8Dzdc7vdjkaNGgFAnX0YfAXBnE5nrb2K9NofSWvfvn3Iz89HUlKSOpMqmWCHDx8OqaMULb7qlnh7zuW646Vu0d5z+TdEoj7ftGkTtm3bho8//hgAMH369KCWRW7atAnl5eVo0aKFuoeGe90ycOBApKam4siRI+rSrkB/B//5z3/U/9+4cWNETjuSjAcZ5Gn/38gDPqk/LBaL2m+RumX//v3qqW5GxDY0ONu2bcPChQvDygrz14aGau7cubjxxhsxcuTIiOyh63A41IwGaUPPOeccAMDvv/9u6PpcMmW6du0Ki8WCevXqqZlCspTMiA4fPoz8/HxYLBb069cPwOm6Zd++fXFRt0SrDXUnQadgx40ul0u3ukUmmSQLDIjMckjJNpOAjKe+ovTnjbQnmKIoanBLMsHc77lMrBspCCbBzV69etV5VoDT99xqteKMM84AYLxssNzcXBQVFcFsNqvPp0zi7du3zzDxlthvpBNFUmGceeaZakXRsGFDNR0y0FnrWPDUmZQN/owcBNNetwQqzGZzXF17vAUepRNstVpr3XOLxQIgMtfeu3dv9OzZUz25TAacnsipJzIIl0ywrKysWtcutM9KKEGw1atX4/jx4+rfI3HqrMxgd+3aVU1Hb9iwIdq1a1fr+0bkqW6JZmcyVPFct3h6ziN5zzt37oyzzz4bt9xyC5KTk5GXlxfUQFY2Se7ZsydMJhMsFkuduiUtLQ09e/as9fpAAm0VFRWYMmVKra8dO3Ys4GsLRGVlpdqxvPDCC9Wvy2B78+bNhh1kS4CuS5cuSE9PBwA0atRIHWQbbQ8WLbahgZs0aRImTpwIk8mEtWvXhrxHmL82NFSRnkg6dOgQTpw4AbPZrAa/ZBXJgQMH1H6CEUl916NHD/Vr8v9G3mBeMjW6du2q1i1NmjRRAxpGHhNFuw1117hxYwDBZ4LJdXtqQ4Hgrl3qfpkcAfQPgjkcDq+BJOD0/Zf2yNOevbFSUFCgnpLZunVrj31FGf8fPXrUMKuqJJuuW7dufttQ2YvNaMF2qfeys7PVZ7Jp06Zq3WKULPY/VBBMBqIyky3k70ZOufZV4Rt5U19PA2zg9L/DqNeuKIrPwKNRrxvw/KwA0XlepPPqq0J238RemwnmKyDjcDjUIFhhYaHPz9SaN29erb9HIitLTjtx3/tIOsJGrVvi+TmP17oFiF19npKSos74+wpUu3N/vt3vufy9c+fOAE534gLpDH/yySc4deoUOnTogDPPPBMAagWt9fDLL7/AbrejadOm6jUCNYPs1NRUFBcXG2oGW0uOppeAgJC6xWgzwCKe65ZYtKF33XUXJkyYgCFDhgCo2cMuFHa7HTabDdu3b8eKFSvw448/YseOHWHtlVRYWFhrM+NIBHakz3DGGWeoAZkWLVqgadOmUBTFcIM8oSiKGrD0FAQz8unQ7puqC6nnjRzAi/WYSDLBgu1Peuu3hHLtMpGl7XfqvSfY4cOH4XA4kJKSgqZNmwLwfM8lQFZUVGSYlQ8SvGvRogVSU1M99hUbNWqE9PR0KIoS0/3KtaQ+OfPMM/22ofK7N1r/RfqMXbp0qfV1qReNckLkHyoIJp1FGagLmb02amdSNpc1mUweZ/eMvMmsvwrfqLPBcj8l60HEwz3314GP5D2XgLKvzpN7wEpmeDMzM9VsDPfn3GQyweVyoWHDhgACzwRzOp348ssvAQB33303gMgEwaSjKydYCqlbZLmE0cizop2JBOLjOZfnOBbPeTi0yyG8PeeRvOcycxjM4EyyJ2U5hLd77r4vSCBBsA8++AAA8NBDD6n7c+i9v4V2AkzbFqWlpambywYTFIwmqUvl9ybkuo1at7ANDc2AAQMAhBaAkKX//fv3R//+/XHppZfiggsuQL9+/XDuuefim2++8XjP/e0fNH/+/FqDc/dJKD3IIE6W9wh5zo06keRwONT6URtgl/8/fPiwYZ9zaQO0wTvt340yUHUX6zYUCH05pJQjk8mE//u//8PQoUMxefLkkLI1Jcgj7TKg/55gEmjr2LEjTCaT13FoSkqKuvLBKPuCyf2R6/I0DjWZTOr3jbIkUu6f1CG+2lDZp81oQTA5ldN9TCSncRqlbvlDBcHkCFQZmAoJihm1M+mtQ6bdIM+oA75YdibD4S14p20AjDqTHcvAowyCjx496rUT4h6wkkywjIwMALXTxOX1cs8bNGgAIPAg2E8//YS8vDxkZmZi+PDhACITBJOZG6nghQxc47FuMfqyQk973wDGzzTRBu+8PeeRvOeSbRXMcivp6GdlZQHwXp+3bNkSwOmDK/wtMayqqlKXdNx4443qsfN6Z4JJFon7YM9kMqlLSSTjymikc+utbjFKZ9Id29DQhBOAeOqppzBhwgQUFBQgKysLXbp0QadOnVC/fn0cO3YMY8eOxeTJk+u8Jz093eeBMZJNLYOySOzZJ4NtbSAJOP3cG2Vg7c7hcKib38uSMKAmaADUBMGM2obKPXWvFyXwKGMmo4l1GwqEtxzS6XTizjvvxJNPPonFixfjkUcewYMPPlgre9af6upqddsAT0EwvTLBZD8weZ59jUPDOTEzEuQ6ZN8vb/0WI50QqSiKWi5lPOWrDTXiXmzA6SCYtwC7UeqWP0wQrKqqSi0Q7r8UyV7Zu3evIfcF8TZQ1X7NiJ1JRVG8XruRrxuI33sOeL/2aFx38+bNYbFY4HQ6vQ5k/QXBfN3zzMxMAIEHwSQD5KKLLlKzTPTekNHlcqkNkHvdIgH2Xbt2GXI22NdzbvTl1nI/WbcER9LTgxlUSpnxVkbl75KpKQMDf5lg27Ztg8PhQNOmTdG2bVv1xC29N2SWLG/3CTDgdDDJiJkmNptNPeLdW90iS92MJtbPeThi2YbK8pZggz6bNm3CW2+9BQB44YUXcOLECezcuRN79+5Ffn4+HnroIQDAM888U2uw9+abbwKoCYZ5UlxcjP/9738AgHvuuQdAZDLB9u/fD6BuJpj8PRKb8euhvLxc7etogxEyOM3NzTXkIRAOh0O9596CYLt27TLM/k5aRqhbQs0Es9vtmDx5Mr799lukpKRgzJgxsFqt+OSTTzBjxoyAr1smmlJTU9VlivJ3QL8gmLQ/3rLAtV+TYJNRlhVKuZTflbf6XO6fEU5YPHbsGMrKymA2m9UMNV/3XAKPR44cQUVFRdSu0x9pv6QuERJvMUrd8ocJgu3evRsulwsZGRlq1Fd07twZSUlJqKysNEwEWyuQgaoRZ5q8LYcATs/gKIoSdx14I99zb2niANTfQSTvucViqZMN4s7bcsj69esDqDvrAZz+t9SrVw8AUFpa6vMzhWS7dO3aVW0IT506peu//9ChQ6ioqIDValWzbMSZZ56JlJQUVFVVqR1OI4nX51y7RNxT3QIYd7lVrDvw0mkKpqMqQWcJQruXUcnelD378vPzAfgPgkn2Vb9+/WAymdQ6QDaz1YPL5fKaBQ6c3g9n27ZthpsE2717NxwOB9LT02sNsAHWLZES6zZUBj4FBQVBDWSnTZsGALjuuuvwyCOP1CqjqampmDhxIgYOHAibzYaZM2fWeb+n3xMALF++HDabDV26dFFPDtQ7E8zpdKrPsPseMvL3gwcPGrI+P3ToEBRFQVpaWq1gRNu2bWGxWGCz2SJyGE+4du/eDbvdjrS0tFoZbEBNUMxisaCkpMQwAQ2tWLehQGiZYDJh+s477wCoKbPTp0/HpEmTAACvvfYa8vLyAnrOZfK4cePGtSaB9d4TTLIcZRLZV30urzHKMyP9ELlH3sahMjbQOwM9FBI8ys7OVsc1vu55gwYN1MlHo0wUHD9+HCdPnoTJZKoTYO/WrRssFgtKS0sN8Zz8YYJg0gk+44wz6gyYk5OT1VkbbQq63W7H8OHD8e9//zt6F+qBESr8UPi6bu3XjdgRjvd77r6kEIjeMhSZDZLG0104mWCyYa57EMxbJpg0KF26dFEH2AB0nTGROqNjx461TnABan4PsrzDiBv7xvtz7um6jb7cKtb3XDawLS4urlOOxHvvvYdrrrkGlZWVUBRFne1u2LCh17rFYrGoQbCCggIoihJwEEyO0JYgt55BsAMHDqCsrAzJycl1Dq4AamYqk5OTUVpaqs56G4W23+J+z7V1ixGXW8f6OQ9VrNvQhg0bqu2ctzbUkxUrVgAAhg0b5nXQJFsCfP/993W+7z5AFLKspX///l5PZw5XVVWVGijylgl26NAhw5zepqXNlNE+L1arVa1rjRikln5L586d64yJUlNT1eVvrFs8k8BJcXFxwGMYh8OBN998Ew6HA1dddRVuu+02AMC4ceNw7rnnorKyEv/85z8DuvaSkhIAp/vNQu89waQOkixtX/fcaEEwCVA2btzY5zhUfpd6Z6CHQrJ0O3XqFPBzLnWkUZZEyn6Wbdq0Uft0IjU1VY23GKFu+cMEwaQhd8/UEPIQyesA4IsvvsAXX3yhppHHihEq/FAEGgSLt2s38iy2t71MRDQH2YEGwdwzwXw959LABxoEk0ywLl26qO8F9JslA04PVL3VLTLwNuLePYlet8RbGY3GPc/IyFAzuryV0QceeAALFizAtGnTUF5erl5zw4YNfd5zGSRXV1ejrKwsqEww4HSQW88gtQSfzzzzTHWWXCstLU3NNpH9yYxC6hb37BghXzfK/hpabENDYzKZ/Lah7goLC9W2rk+fPl7r84EDBwKoWfrrPkj2Vq61E0mScVBUVKRrVtbBgwdht9uRkpKi/ttF+/btYbVaawXKjERWj7hnagKnl0QaYa8hd/7qFum3GHHyLtZtKFDTFkq/M9CgcE5ODhYuXAgAeP3119Wvm0wmvPLKKwCAuXPnqhPDvkgQTPbJFZEKgjVv3hyA776irAIxShBMmwkWSBDMCJlgUldkZ2cH3IbK5vhGCbZLEMzTpKP260YYE/3hgmD+OpPazYJlcB5LTqfTa2q+fM2oywrjNQjmdDo9nsYporEkIlRGuOeSCRbockhp8GXGIJRMME/LISsrK9XGuEuXLjCbzWqmViSCYN4qfNnYVxtgNwJ/z3k81y1G3c/M11Ir7de0r4uEQAfZRUVFahZYcnIy0tLSfAYH0tPT1UBTfn6+z39DRUWF2gmSIJjUAXoGwSSw1a1bN6/3XPat2LRpk24/Vw/aIL4nUucEc9JnNLANDU+wQbANGzYAqAnEeBvwWa1WtG7dGs2aNYPD4VD3yxTeMsHkGTzzzDNrZZ3oNcgGPC8B0l630U6dE06nUw3MScBLS7s5vtGec+1WEZ4Ytd9ilDbUYrHU2QPTnw8//BBOpxPnnXdenaX5l112GTp37oyKigr1IArh6d8hfWD3TDDp40odHA5FUdR+vBxa46uvaLRMMAmCNWrUyGd9LsuYjRQEa9euXcBtqGzxZJTtnKTO8Fe3MAgWRVLhux/XKeTr2iCYETZt03bIvGW7GDXrIdYzqqHSLofwxMjLreKhA+8tE6xBgwawWCweA1qy3EqyxcrKynx+JlCTGqwoCho2bKjO9MgAXc8OvLdjxoV83WgDVe0JS95IGeBzrg9fS62A2vsnGmGQ7b4U0luHDDhdz0uWWVFRUa021L093bhxI1wuF1q0aKF2niXIredySMlkOOuss7y2oTIgMVommLdTZ4VR6xa2oeGRrAsZxPmzdu1aADX72/lqQ61Wq3oa6vr162t939vvSpsJps2m1rMNlRPo3E+GFEZb7iPsdrtah/rKBDt8+LDhnnN/dYt8PZhThKPBKG0ocHpJZKDldMGCBQCA22+/vc73TCaTujzyiy++UL9eUlKC7Oxs3HXXXbVe7y0TTDveCndMWFBQAJvNBpPJhGbNmvkdh0o7XlxcbIgkEm0mmK9xqBGDYBLYCqQNNVoQTPoj/uoWI0xq/CGCYNrT2/z9UozWyPrrkGm/Z7RGNtBsjXgL3gHxe8+NnAnWoEEDn895UlKS143xPTXM2iwK+b7eJ+cApytyb3WLZJnI4RxGEUjdEq9lNF7Lp/Z7kbx26TT5C4K5XC51qYfMevurW6RT7i8ItmjRIgA1M+BSPiORCSZBMDmVyBM5aVFOkTQCRVH89lskCLZ7925DTNoJtqHhkUFZIHvU2O12TJkyBQAwcOBAv/W57L/33//+t9b3PL3v5MmTahBc9o6KRDa1BMHc9wMTEhwzysbPwuFwqHWo++bywOkgWE5OjqHaUEVR/PZbtANVI9UtRmlDgdOTSYEs0y0vL1f3QBoyZIjH1wwbNgwA8NNPP6nla9asWcjJycGMGTNqvVb6wJEMgmn3A0tOTvZ7z+vVq6f2E2KdDVZVVaVOlvtaDpmUlKQeclBUVBTzfQclCCbPViBtqIy5jBIEk7GX+8mQwkh1yx8iCJabm4vKykpYrXVPbxPySzl+/Lh6/HOsfzmAsSr8YGhTcb1Fso26JCJe77n2NDx/HXjtMlu9+QuCaQNW1dXVamPvLwgmjSxQ0wHQlk9fQTBtmdd7vwSpLzydgiK6dOmCpKQkVFRUGGrj7Xh9zgOpW6K1JCJYgQQHorGUM9DOu8vlUgfBWVlZAPzXLbI8o7i4uFYZda/j161bBwC4/PLL1a/pnQmm3ey+V69eXl/Xq1cvmEwm5OXlGWI2GKj53ZSVlcFisfhcDiknLRlpv6R4rVuM0obKJtTegmCHDh1C586d8c9//hO5ubk4fvw4LBYLbrnlFr/3/LrrroPZbMbKlStx7Ngx9Xue6lIJlGg3ONa7DXW5XGoZ9RYEkzbcaCdEaoNg8ZQJlpubq9YtvpYsmUwmFBcXIy8vL8pX6J1R2lDg9O88kODDTz/9BKfTiZYtW6rLZN316NEDzZs3R3V1NX788UcA3gNZ3jbG15Z/vYJgstdXIPW5v/5/tEgWmNVqVVeZeGKxWJCVlaVef6BZfZGgrU/kPgZyz420DPXUqVNqfeFtTNStWzeYTCYUFhbG/DCCP0QQTKLvHTp0QEpKisfXZGVlqSnoRtpkNl6zNQJZxmnUJRHxfs+9LYcAarKwIp0qLuXI22BS+zxoU6br16/vd9ZDOuJOp7PWjI2/TDCh9/HRvk5B0V63bFxphNNQRLwOVAOtW+Q5N2IZDeSeR/K6g1kOqc0E81W3yD33thzSffAq7aw2Q0vvjfEls6tFixbqniaeNGzYUB2YGGVJpOyXkZ2d7bXfkpKSog60pS4yArah4ZFMMG8DsmeeeQb79u3Dww8/rAapJVvDXxvaunVrjxtBe/pdaZdCCr3bUIfDoWY/eAuCydcPHDhgqOelsrJSDST6ygQ7duyYrstHwyV1ha+6JT09Xd2LLV77LZF+VoIJgi1evBgAcO655/qsWy644AIAwLJlywB4r2MCyQQLt34KJggmP1fa2WBOto0E2aetUaNGSEpK8tlXTE5ONsTm+Lm5uXA6nUhJSVEPGQrmnhcVFanB0ViRuqVly5ZqVqC7+vXrq33QWO8L9ocIgvk7GVJIQyudcyNkggWyb4/RB6q+xOu1x+t1a78fqWuXCrmkpMRjR1nbGMlSyIyMDFgsloAzwYDaSyI9dSqkctXuA6j3ckj5Gd4yNYRcQ6wrfK1Ef86NuDm+Ue55oEEw90ywQOoWbSaYNlNG+/+nTp1SO5vaTAQp33plgklAq0ePHn7vuaTuGyUI5u/UWSF1D+uW8BmlDfWXCab9udo9+7TX5ol8T16rPdXOU6aEr2xqvdrQqqoqNYjgbzmk0YJgubm5cLlcSE5OVif/tJo3b46UlBS4XC5DZWpK3eLtfgsjnj5rpLpFgpz+Dg+YOXOmehrkeeed5/O1F154IQDg1Vdfxdy5c73+G2Spn+yTK8xms9of1isTzNem+EK+Z5QgWCAnQwqr1aouiYxlEEwyudq2bevz8Ach30tJSVGvP9ZLIgMdE0mbEuu65Q8RBJNN2vz9UuT7RtlkVruUx9fsnmwQaaRlhUbpTAbL38kzwojLrYxyzzMzM9V9Qzw1KNqAlWSCycDZ3z23WCxqtog2i8x9lsdut6uVsXYZlN4b4/s7BUVIEMwoJy3xOY8+bf0cyD3X43Qnb4LZE0w7yA7knnvbE0zbNklHrXnz5rWWc+idCSYBrbPOOstvGypBMPdT82LF38mQwmgnRLJuCZ+/IJj2+gJdrqz9nrxWGwTz9D5PfWe9l0MeOnQINpsNSUlJar3kLjs7GxaLBVVVVYYJJrlcLrUea9++vceJOLPZrGZTHT582DDPub+TIYX83o3SbzFSGwoA559/PoCapY6+ltE9+OCD6v9fcsklPj9T+/177rnHax1js9kAnD4NUkuvLFv3kyEDGYfKa42yHNLXyZDCarUGfchBJMg9a926ddBtaDBZiZEkQS1/dYsEwWLdb/lDBMGCrfDl9bHOBPN3CoqI5mkogQo2W8Mos3vxfM8DyRrUfj9S161tCD3tJaHtLMr+e5mZmbVmsDyR78sgW3sstfvvas+ePbDZbMjIyKi1TEHvWWx/p84KWRtvlM5kMM95tJYWBMooA9Vgyf0L9DkHInftkglWWFjoM+tKuzF+oJlgUj7d9wTTDgAlOO6ePaH3xvgSBOvZs6ff51yC5UbJBJPOYSLXLWxDPfO3HNJTEKxhw4YB1y0SBJP3AnUzwRRFUfcl6t27t/p1vZdDyqb4HTp08LpvT1JSkjrIM8rhVf72AxPS/zDS5viB1i3yfaOcEGmkNhQAOnXqhO7du8PhcODZZ5/1+jptcNfbPklCe0JqixYtvF6/r73R9BpXaZdDBlqfy9LJeMoES0pKUrNjtXVitEkQTO5hMG2o7CEW6/vu72RIIfGYWNctf4ggmPxSvJ1UIKTC99TIxmIGJ9DBHmDcYFKsO5PBCuaeG/Xafc3WANG5bl/7gmkrdWlwMjIy/F43UHPt0oHXDhDcGwo5ReqMM86o1VmKVBDMX8dG6p5du3bFPLgOJMZzHq91S6DPufY9emvQoIGageWr0+SeCRZI3SJBsMLCQq+ZYJLh4h4Ek0wwu90edltms9nUWUlfm+ILGejv27cv5vtqAPB7MqTQnhBpBIlQt8S6DZVMsLKyMo8BYW9BsEDrFhnwaSep3ANQu3fvxokTJ5CWloZzzz1X/bremWASBNMO/j2R78vrY83fyZBCAmRHjhwxzHPu72RIoT3FzQiM1IaKd955BwAwe/Zsr5M3MtH01Vdfeczc0rJarfj444/V//fWDkYzCNaiRYuAx6ESwDFKJligyyFlDy7t5Hq0uWfeBdOGyub4RgmC+RsTGaVuSfggWEFBgfpQ+/ulyPcPHDgAm83mc1PfaIjXzqT2hKVAO5NGWRIRyMkzwkj3PNA0caD2XkmRCshIJe4vCCZl09/JkMJqtaobb/vKBJPTpmTPBqHncsiSkhIcPXoUgP8Ae5cuXWC1WlFeXh7zdGUgfp/zUOqWSC+JCFQokxqRvOeyTMdXZoWiKEEvh9R2Jv1lgslgX2j3/As3G2zHjh2w2Wxo0KCBejCFL82bN1c78LKhfqxoT1jSHhzgSY8ePWAymXDy5MmYn7QExG/dYqQ2tEGDBupg2VM2mLcgWKBtqEwkaYNg7u+VCZ7u3bvX2jxdz0wwRVGwf/9+AP73p9LuC2aEbT/sdntAQTBtJpgRnnPtfoz+6hbp1xw7dswQEwNGa0MB4LLLLkOTJk1QXl7ucUDvcDjUwxM6dOgQUBsqAY0TJ07Uun5tXRPpIJiiKLUywQKtW4yyJ5i0hY0bNw6orygTA7EMgsl4QvpFwbShRrjvZWVl6s8PtG7JycnRLfM/FAkfBJOTClq1alXnFA137du3R1paGux2e52BQSwar3gNggW6HAIw3pKIeL/n/tLE3V8T6RMiPS2HjGUQTM9MMNlzrGnTpuqmlN6kpKSoA3EjnOIW7895IHVLtJZEBCqUex7JzF7ZoHf16tW1vu6+mb37citfLBaLWhby8/NrDVYDyQRLTk5Wf0a4m+NrN8UPtDNplM3xtf0Wqe+8qVevnrq8lXVL6IzUhppMJp9LIvUKgsngHKibCSYZV+4BZD3bUIfDobbV/oJgsofMgQMHDPO8yP5kvpZDyvdyc3MNcd3B1C2NGzdWn0MjHLxhtDYUqCmrEqCVFQhaBQUFcLlcMJvNaNq0aUBtqOxPVVBQUOsUdG3b7CsIpse/vbi4WG2DgwmCyURSYWFhTIMb0sdo0qRJQONQI2WCSb8omOfcCEEwqSOaNGmi1hveNG/eHFlZWVAUJaab4yd8ECzQkwqAmo6NNLTuRwLHYuYpmBlVIy2HDKah0r4u3q7diPc8kGcFiPzgI9DlkMEGwZKSkjwGwdw7FtI5lWwXoWcHXjqT/k5vE1IHxetA1UjPeaB1i5HKqNEyZC699FIAwLRp02plPmnbOu2eYP46NUJmMfPz82tdv/ZzZeAunX1hMpl02xds3bp1AGr2Awu0DTVKECyYfov2dfFWtxipfBqtDfW1Ob723sr3Aw2Cafe/0QbB3MmA3n2Zop7Z1Ha7HQcPHvT4c9wZ7YRIh8OhDloDyQTLzc01xHUHW7dI/8YIdYvR2lDRsWNHAN6DYEDNvrfajEpfpP+sKEqt8q/9twSSCRbOv12e7YYNGyItLS3gNjQjI0Ntw2O5JFLue6D9FnmdEYJgUvcH04bKe2J5z6WOCKRuMZlM6sRHLPczTfggWKAnFQjZF+z333+vlXoa7RmcYFLzgdOzeEY4ITLUgWqsZ8mCvedGWm4V6Ia+ItIdhECXQ8r3MzMzA+7YSBDM1yku3jJN9OzAh1q3xPpI4GCfc/m9GGHJcqgB9nitWyK5ZPnmm29Gz549UVhYiJtvvlmtQ9yDYHJ4RaCdSSlzJ0+erHXftc+OlD/ZA0xLvhZuJtiqVasAAOeee27AbahsiRDrIFiwdYu8Ltab47MN1Y+vIJi2rZSZ/2D2BPOUCebeb5TvSZah0HMiyWazqdsD+MsEk+8fPHgw5sEkRVFgs9nUAWcgG+MfPXoUdrs95m2o1C2BBsHivW6JZBsqZMWBBHQB4JtvvsH48ePVPm6jRo0CDrCnpqaqgWptUCPYIFg45US7HxgQ+DhUezBWLLOSZHzgvuWCN9K/idXG+Iqi1FkOGcxzLu/JycmJWVsqAXZ/B24II5w+m/BBsEBPKhDyOveBarQDS4GegiK0p7jFesAXzGwNYJyBqly3xWIJ6J4babmV0TJkJCX68OHDdb6n7QRKxlaLFi0CuucWi0VNW9Z24N07lt4awEhkgvnbD0zIADvWRwIH+5wbaclyvNYtwSy1Amr/biJ17cnJyViyZAkaNmyIPXv2qJlT2p8nSzmAwDuT8rqSkpJa2VzaNlTKn6eZcT0ywU6cOKGWs3PPPTfg51w20P/9999rLUOJNukU+tvHVEi/Jd7qFrah3vlaDqlduigDzcaNG4fVhrrff8kAldcKPTfGP3jwIKqqqpCUlFQna9tddnY2zGYzKisrY77ptt1uR15eHhwOR609nDyRpWQOh0N9TywFunG1kCBYrOsWI7ahQto8bQBl2LBheOeddzBp0iQAgWdqAjV1kGwrIIERIDZBsJYtWwY9DjXCCZGS0SUBOX9iHQQrKCiAzWYDUPM8BduGyj0vLy+P2f590m8JdvIulnVLwgfBAj29TciAdseOHbUG1tFuuIJNzQeMN+AzyoxqoIK9bu1rY33tRgsOSDn67bff6gSQtX+XIJivTqQ7ea02wOYeBJPZc/fsFT039Q3m5DngdB0U6xMi4/k5j9e6JdjyCUTn2ps2bYorr7wSALBkyZI6P0/KWOPGjVG/fv2APrNJkybqv1PbCdaWUQkwyYBaSzLBwgmCrVmzBkBNJ8s9G9SXDh06ICsrCw6HI6bZYMEOVI1yQmQ81y1Ga0N9ZYJpf6ZkTAaaqQlAHWB7W64MQM0AlYwUoWcbKv3zzp07+31mkpOT1YwrX4d5RIN2KWTbtm3r7KemZbFY1ACfEU6IDLZukQB7rO+5UdtQ4HR58rSUbu3atQCCywSzWq3qVgGxCoJJ29+qVaug77kEnmIVrHY4HGr9FWgQTPoJ7qdaR4v8nps2bYrk5OSg29C0tDR1wiJWwUdJDDjnnHMCer1kjMWy35LQQbDi4mK1EAaarSEnGuzbt69WIx+rTLBgCoIR9tcINmVZ+7pYL4mI1w689sS8UIIDkbjnnTt3RlpaGioqKtSOrtCWJZmJllmMQLRu3RrA6QCa+2fa7XZ1FttbJli4s9gnT55UG61Ag2Ddu3eHxWJBSUlJTGfI4vU5D6duicaSCF+MfM8HDRoEANiyZQsAz0HqQDfGBWoGqxKolk2v3T9X2lZfQbBwlkMGuxRSJCcnY8CAAQDqHhgQLSUlJUH3W+R1R48eRXFxccSuzR8jP+e+GLENlaCWpyCYpz5eoJmaQN29+IDAg2B6taEul0sd/AS6NE+WRMb6hEjtpvi+9gMTEryL9QmRpaWlat8j2Az2AwcOxDQ71sh1iwTBTp48iTVr1qiHSgBAUVERgNAzwbSTQfPnz8dLL70ERVGiFgRr3bp10OPQWGeCSTDSZDIFPAkmr7PZbCgrK4vYtXkjbX4wy0+FvFb6XbG474WFherPDTQIJgH2ffv2xaxeTOggmMzktmzZMuBZso4dOyI9PR02m63WkkhmggUm2JRlea3MpMUygGfkRtYX7Yl5gd5z7el6kehMWiwWXHjhhQCAzz77rNb3PP08CWwFQmZVS0tL1a9ps0wknVl74ovQazmkbCTeunXrOj/Dm9TUVHXviG3btoX188MRynNuhAB7KHVLpJ/zQBl5FlsGOdLeaX+eNlMz0HtutVrV8qzdKDjQIJgeyyElgHXuuecGfc/PPfdcAKcDadEm+2o0a9bMY7DCk0aNGqmd+FhuYM02VD++MsHc6+HU1NSggmCeBobRzgRzOBxq/RDoHjLazfFj/bwEcjKkMMrm+FK3aE999Kddu3aoX78+nE5nnQnNaDJyGyoBq61bt+LCCy/0uL9ds2bNgmpDPdX9Y8aMwd///ncsXLgw4qdDhpMJJkGwWGWCyeR6VlZWwNdev359dXsGXweGRIrcK7l3obShsQw+yiRq69at1fLgzxlnnIG0tDRUVVXFbF+whA6Cbd68GcDp7K5AmM1mdVZKO1CNVSaYESt8X0K5biB+r90IJ+eFes8jHdgYM2YMAODtt9+utc7evSxplwsEom3btnW+pg2CSXCsfv36dZYp6LUxvgTBAt1rUEjdEsvjxv+odUu8ldFoBR7lGd6/fz+qq6s9/o6DCVIDpzfT1pYzbRmNZCZYcXGx2iEbMGBA0M/5wIEDAdQE0mIROJVrDzQ7RhjhFDe2ofqRwImnwIP7z2vZsiWSk5MD/uzMzMw6wS33bGrJhvCWCRZuEMxut6sZM4E+6xIE279/f8zbIgkSdOrUye/rJVCWm5sb0+uWMVGgSyGB2qe4xVvdEq02NJBBv0yABsr9QAotOWQBiNzpkBLkbd26dchBsFhlguXl5QHwnPHqjXbS3NehW5EiQTCZoAilDZX3xiL4KElHgWaYAjVjP3n9pk2bInJd/iRkEOzjjz/GX/7yF2zYsAFAzRHpwZBZqV9//VX9WjQbLu0pbKFEg7Wp/dEWr0Ew7T0LpZGN5XKrUJbOal8fqXt+8803o1evXigrK8Ps2bPVr7s/m9nZ2Wr2RyCaNWvmswMvGSSeTp7TqwMvncFgOpNA7E+IDPU5N8KS5XAHqrGqW5xOZ1j1eaTrlmbNmiElJQWKouDYsWMe245gg71yZLxWtDbGX7t2LVwuF7Kzs4NaxgnU3PMePXqgXr16KC4ujsmgTzqTgS6zFrE+xY1tqL569+4NoCbrSbKyCgoK8PXXX9eZxGnVqlXQmb3uk0llZWV4/fXXsX37dnUJFwD1JEmh13JIbSZYoBspSz20a9eumAVN5TmXIJinus6dBDRzcnJi2oZKgD3YukUGqrHaJ9HobWggQbBAMga1fAWGk5OTI7ocUlGUkJdDGiEIJidyBrNPInD69+jpVPtICycIJq+N5amckjQUTBAMOB2fkQB9tCVkEGz06NGYM2eOugxLOhOB8tRARDOopO2QSbp9IIxwQmS8BsFCvefa5ROx6pSFsnRW+3o5kURvZrMZo0ePBgD88MMP6tfdy1KXLl2CvufunWZtlol0ziXrS0uvpRwyOA42wB7rEyJDfc6NcIpbuEGwSD3n/miXiBmxbjGZTGqn9dixYx5/v8EOmjztCRHsxvihZoLJUsgBAwaE1Iampqaif//+AGKzJFIGqn379g3qfRJgj1UQjG2ovho2bKhmPrVt2xa///47Lr74Ytxwww2YM2dOrde2adMm6PrcPQj2zTff4Omnn0aPHj3UfeXq1avnNZs63DY0Ly9PzdgIdDmk1EP79++P2d538oxKpkwgGT4SAJGBbqzaUKlb+vTpE9T7ZAwl7482o7ehGRkZfq8rkGCplq+Jp0gHwfLz81FdXQ2TyRR03SLvAWqCSbGo092XFgZKgkjawwiiRXsaZ6jPeSyDjzImCravGOu6JSGDYO6CrfClA6wVzUYr1FlJ7Xs4UA1OqNetfU+sOvBGXMohZF+w9evXqzNx7ic5BtoB1nLvIASbCRbOLLbT6VSXMwZb4cf6hEg9nvN4K6PxWj6174n0tfsLggW60anwNPEUrT3B5GTIYDfFF7HcF8zpdKqdyWCDYNLP+eWXX+K2bom3Mhrp637uuecA1ASEn3jiCa8ZxJ72IPLH16BcAtAZGRl1vqdXJpjM/Hfu3BkNGjQI6D0tWrRA8+bNoShKzLYUsNvtsNls6kA7mEyw3NxcuFyumLSh2n5LqGOiLVu2sG7xwGw2+3yGrVarulw9UF26dPF66qjVao1oEEyywJo1a+axH+1P8+bNkZqaCkVRcOjQoZCuIRwSxAp2Gwd5fSyWE2qDYKE+57EKgrlcLrVtCrav2K9fPwA1K+9iUbckfBCsXr16QVc+/fr1qxOFjWYmmDSQwezxIGK5v4akHGsz0gIlhT5WSzmN3sh6Y/R73qtXLyQnJ6OwsFBtDN1/VrBLCoG6+/wFmgmmx3LIrVu3ory8HPXq1QtpWYHZbEZRUVGt0y2jJZznXOojPufBiYd7LjOgnpZDBnOwjOjcuXOdAXSwp0OGEgRTFEXdxuDss88OuQ2VfcFWrVoV1Y7Z9u3bUVlZibS0tKCXoPbv3x9WqxX5+fkxGXiwDdW/brn99tvx5ZdfAgCWLFni9XWhtKG+ni/ZD8zTNgV6ZILZ7Xa1nAYb7JVB1m+//Raz+jw3NxeKoiA9PT2gAwlat24Ns9kMm82G/Pz8mDznO3bsQEVFBVJTU4N+Xvr06QOLxYKCggL2W7zwFQRr37590MGkevXqeT3Z0G63RzQIdvDgQQA1y6xDaUOTk5PVDEk5ATZaHA6HmmEabBBMTlc8fvx41OuWeA6C/fbbb6isrERqamrQSQ29evWC1WpFUVFRrdPEoyXhg2Ay6AxGRkZGnZm1WGSChVr5ALHJ1pCfGUoBNplMMc00CefaYxkc0OueR+rak5KS1I1j9+zZA6BuECyYgyu8vcdTEMxTp0OPDvz69esB1HTGvc3UeZOWlqYu5ZSMlWgK53mJ1/KpHdzGWxmNVnBAgmDHjx+v09aFMsA2m811OkOBbowvA+9QlkPm5eWhqKgIZrMZnTp1CrkN7dmzJywWC06cOBHVk6LWrl0LoKZ+C7ZuSU9PVwMb8jnRxDY0Mtc+bNgwNG3a1OfnBzv7DvjOYpayV79+/Trf02MiSRsECzYrSa77t99+i9nzIoGgjh07BrRsKSkpSV0ilpOTE5M2VJaJh9JvSU9PV8dE0v+JpnhoQzMzM71+T9rXYJhMJq9BsOrq6oieDinbdYTThsYqCGaz2dQ9vSSoFSgJmh0/fjyqZbSsrEzdhzHUIFhycrL6nBUWFoZ1unawZCzTp0+foCeSUlNT1f3vZB/3aEr4IJik2gXLfTlHtKLCTqczpM1lhVRYDoejzrKzSAsng037vmh3bLT3PJRr1zay8XbPoxHYkM6TNIbuZSmUDnzfvn1rbartaTmkr0ywcJZy/PTTTwA8L5sOhGSZ/PjjjyFfQyjCfc61dUu005bDfc7lWYn24CNe6hbpwJeUlNQpn4MGDQrpM2VJoQh0Y/xwMsFkuU92djZSU1NDbkNTUlLUJUzRXHYlncnzzz8/pPdLfyfaA9V4ec49MXobajKZfG4cf/755wd9kihQ08f1VrYlE8xXECycNtRms6knLAcbBBswYAAA4Oeff45ZfS4b+gdyMqSQZZMHDhyISRsqgXHpfwRLe2puNMVL3eIrE+z+++8P6TPvuOMOj0FWf0GwcA8DkjbvzDPPDLkNlbIR7f1vtUuVfZ2w6Ynsk5iTkxPVcahkbmVkZCAjIyPk5zwjI0OdRIzmks5169YBAM4777yQ3i/9lmiPiYAEDIK5d+CHDh0a0uf8+c9/rvX3aGWCaWc8gtkYT5jN5phlPRi9M+lNuPfcYrGo9zxW1x5ucEA2qo4EWY7sngmWkZGBpUuXhrRvT2ZmJn7++WfccMMNAALPBNNjFluCYKFW+DLAlYYjWvSoW2QGOd6ec3lfJJ9zT+KlbpGli6WlpbXauquuugrjx48P6TNfeuklPP744+rfpYxqJ2j0zgRz77yH04ZKYCGaQTCpE2QvxWBJ4DHe6ha2ob55C4KNGzcOX3zxRUj3PDU1FV999RUmT55c53uRXg65e/du5OTk1Np/L1AXX3wxgJp9NaO9d488KzKhF8xJaJJRK++N9nMudcIFF1wQ0vsvuugiANHPYI+XusVTJljbtm0xe/Zs3HTTTSF95j333IPff/9dnZAR/oJg4fZ3pM3r2rVryG2oTH7v2rUrpGsIVVlZmbqnWbBbIck179+/P6p9RfelkKE+57FaEiljolAn76ROj3aAHUjAIJj7gxvqLPbgwYNr/T1aQTC5/lA7ZNr3RrMQu1wu9R7pka0RzdngcDvB2vdGs2Ojxz3XZt9FambSWybYyy+/HPR+IFrt2rXDkCFDANQOgvnKBAu3A3/48GHs2rULJpMJl112WUifIRX+r7/+ipKSkpA+IxR6POfRGPC5i5fn3JN4qVskCFZWVqbe63bt2uGDDz5AVlZWyJ/5yCOPqDPCUu61z7zee4Jpg2Dh3nPpQEcrCJaXl6dmmMiAM1gy6bd582YUFhbqdm3+xMtz7i5e6hZvQbBevXp5DFQFKiUlxePSuECWQ4aaCeZ0OrFs2TIANf1zT5vv+9KkSRP1VOZo79knz6acwBrMVg7yWgkKRLMNPXbsWNh1yyWXXAIA2LZtW9z1W6JRt3gKgp1zzjm45JJLwqpbMjMz6wS6Kisr1T6vpyCYXEsoJ6g6nU51wjqYIK87qbPks6LB5XJh//79cLlcqFevXtCnQ3bs2BFmsxnl5eXqIRbRoA2ChfucRzsIdvToUfV3HOrknYyltm3bFvVTfxMuCObeMDdp0iSkz3Ffix2t5ZDSMHpaJhKoWAxU5WclJSUFvQebiNVssK+lOYGKReBRrjvcey6d4EhduwwmJQgmDYvFYgn7OZd/t7Z8+soEkwFDWVlZSJ3nH374AUDN4CPYzcJFhw4dkJ2dDYfDoX5eNOjxnMeibomX59yTeKlbZLC7fv16NbtCZhbDrc/lvq9evRrXX389GjdurL7G13LIUDLB5ISiLl26hP2cRzsI9t133wGoyRjR3qNgZGdno1OnTnC5XD43UtdbvDzn7uKlbvEWBLNarWE/556CYL6WQ4Y7kVRdXY2VK1cCCH2lxqWXXgqg5rCAaD8vFRUV6lLOYLZbke0TNmzYAIfDEdXr/u9//wsA6NmzZ8hjouzsbLRr1w4ulwv/+9//9Lw8n+KlbvG0HDItLU2XNtR9tYS2bfQUBGvYsCEAqPtMBePgwYOoqqqq1QaGQjIfjxw5ErUJmerqavV05W7dugWdUZWSkoLOnTsDqNlzMFrjUNljsGXLlmE/59EOgkndcs4554Q8Jmrfvj2ys7PhcrmwdOlSPS/Pr4QLgoWToq3lXniikQnmcDjgdDphMpl0Gaja7faoBe98bXQcjGgPsvW65/LvjuY9l3sU7j3XY4mgL5IJdvDgQTgcDrUsmc3msCt86cAHuieYdADtdntIHYTFixcDAC6//PKg3ytMJhOuuOIKAKcHvpEWibolWrNk8fKcu4unukWyMQ4fPqwu3bBYLLrU51JGn332WXz77bfq9zIzMz0OwCVQHWwmmKIotTLBwn3Otcsho5FtIp3Jq6++OqzPkQBBtALs8fScu4uXusVbEEz2rwtVcnKyxwG6DLI9ZZmFmwl27NgxLF++HEDoz/qIESMAAAsWLIjawRXynK9duxZ2ux1t2rRR9/kKRK9evZCVlYWSkhJs2rQpqm3o999/DwC48sorw/oc6bdo6/FIiqe6RQJPWmlpabq2oUKC1IDnIJhkb4fSx5XNyTt37hz0iZZaLVq0UJdxRmuPyqqqKnXvu1AzHmW58Nq1a6M2DpV909q1axf2cy6b40crCLZo0SIAUFflhEreH626RQS/GY/BaRvmDz74QLfPjUanTK49OTk5pDXBwmw2Izk5GTabDVVVVWGlywdCURRdZmuAmkJcXl6OyspKn6et6EWuOx7vuR5Zg8Dpex6pDnyLFi1gNpvhdDpx4sQJdS+DlJSUsO65xWJRZ/ikfBYXF6uzKt72BMvMzERxcTGOHz/usePiTXl5uTqwdN8zMFh//vOfMXXqVCxatAhOpzPo05qCFYnnvLKyMi7rlmgFweKpbvG0JCncLBOg5p57+7d7y0gINRPs2LFj6smQocwCa5nNZnTt2hVWqxUlJSXIzc1VN82NhKqqKnUG9Lrrrgvrs6699lp88MEHmD9/PhwOR0h7Lu7evRsvvfQS8vLy4HK5fAYBnU4nHA4HzGZzSJsoa0lgQJtBGEk2mw2KooRdRl0uF+x2O0wmU9DLWQKpj9q2bQuz2VwnaJKVlRV2G+qpjPvKBJMBdklJCWw2W1D/XkVR8Pbbb6O6uhq9e/cO6VAcoGbvu549e2Lbtm2YMmUK3njjjZA+JxhVVVWw2+147733AAA33XRTUPfeYrFg2LBhmDlzJiZPnoxPPvkkKm1oVVWVGnQMt99y/fXXY9q0aVi4cGHc9lsi1YZ6yt5NTU3VpQ11r8O1m837CoKFkoG1YsUKADV73oZ7z/v27YuDBw9ixYoVuOqqq0L+rEAoioJTp06pE8uhBmWuvPJKzJgxA3PnzsUTTzwRlXGoTN6dddZZYd9zOZUzGhnslZWV6tL2cCfvhg0bhmnTpmHBggVRqVtEwgXBZsyYAQBo1KgR7rrrrrA+6+GHH1Y3Db3qqqtw7NixkI66DZQEwTxlsAQrNTU1agPVqqoqKIpSKygRKpmZdLlcqK6uDrsB8cdX1lCwon3PXS5XXNxzi8WC5s2b49ixY5gyZYruzzlQ09g/8sgjtTb59dSBB2qWOhcXF+PEiRM+T91y99VXX6GsrAxt27YNeZZJDB48GFlZWTh+/Di+//57XHPNNUF/hmS+nDp1ym+mamFhIZxOJ+rXrx/2zGRlZSXKy8uRlJQU8Q5CdXU1SktLYbFYggpYeqIoCgoLC+FyudCgQYOwy40/Rrjn+fn5Ab3OU1mxWq261C3eOjPegmChZoLJbHPnzp3DflaAmuUtHTp0wJ49e/D7779HNAg2d+5clJWVoUWLFiGf3iauuOIKNGrUCAUFBfjhhx+CHviWlpZi8ODB6mQCxV5SUpLahmrp0R/11A6/9dZbAOBxP8BmzZqhXr16KC8vx8GDB4NaMvXjjz9iypQpAIAXXngh5AGfyWTCk08+iVGjRuGf//wnRo4ciV69eoX0WYHKz8/H3XffjfXr16NevXohHRjyxBNP4LPPPsOqVavw1FNP4e233454X/GLL75ASUkJWrZsGfIeyWLw4MHIzMzEyZMnsXDhwpCCaoqiYO/evSgoKPCbYVtYWAiHw4GMjIyw29CKigq1DQ1mn8sTJ04E9DpP7Vl6eroubah7EGzhwoUAam8hoxVqJpiiKOpEr2QUh2Po0KH48ssv8d1330U8UF1VVYX33nsPRUVF6NixY8hBsGHDhqFDhw44cOAAPvroIzzzzDMRHYfa7XZ1n0A96jDpP2zcuDHiwaR58+ahuLgYrVu3Dnk/MHH55ZejYcOGOHXqVMh1SygSKgi2cuVKvPbaawDCT28HgEmTJmHhwoXqAzpq1Ch8+eWXERn42Ww2OBwOmEwmXYID6enpKC0thc1mg91uD3uG1hcZrISTOivk319eXo7y8vKIVj685zWicc9btmyJY8eO4eWXX1a/pmcQbPfu3eqeY6J9+/Ye39OsWTPs3r0bx48fD+pnvf/++wCA4cOHh7zHg0hNTcXw4cMxdepUTJ06NeggmNPpxIgRIzBv3rywroMI8JwJpkf9ZTKZvGYiNWrUyOPXtfv2BUP2qRk4cKBu9Xn37t2xZ88eLFu2LOylRL5MnToVADB69Oiw65bk5GTccMMN+OCDD/Cf//wn6M7kzJkzkZOTg7Zt22LixIlel8wBNcuVSkpKYDKZws5KAmoyqoqLi6EoCho0aBBSFlugSktLYbfbkZaWpsvzUlFRgaqqKiQnJ3udgPHk5MmTeOCBB/y+zlMQrHXr1kFfpztffWVPy/1MJhM6deqEbdu2Ye/evQEHwSorK3HXXXfB6XRi2LBhuPbaa0O+ZgAYOXIkPvroIyxevBh333031q1bF7HnJS8vDzfddBM2b96MtLQ0fPHFF3VO7AtEt27d8PHHH2P48OH49NNPUVpais8++yyigTBZEXP77beHPSBOTk7GrbfeiilTpuDdd98Num4pKyvDtddeq2amJRJPmWCe9gkLlq/s0tatW3usc0PdE+ynn37CoUOHkJqaGnZGMlATUHrggQfw+++/Y/fu3WHtMebPzp078e677wIAXn/99ZCfdavVimeeeQb33HMP3n77bQwfPhzdu3fX81Jr2bx5M6qqqpCZmanuoxaOPn36qJMUW7duRZ8+fXS4Ss+kbvnLX/6iS91y0003Ydq0aSHVLaFKqCDYl19+qf7/0aNHw/4898pl6dKlePLJJ9UOq55KS0sB1AQGwu1IAjVpkampqaisrERpaanXAUe4bDabuixPj4AMALUAS/p5pIJJkbznZWVlumQjeBKP99zTKS16dFh9Xae3/Tpk9jyYvUSWLVuGNWvWICkpKaABSyDuv/9+TJ06Fd9//z02btwY1Ca7M2bMwLx582AymXDmmWfCarV6fYadTicURYHJZNJtVigSn+lOURR1mategxvtZ1osFl3KvSdGuec2m61OcNgTb5lgevBWRuW0MndyKM3JkycDzkwtLS3F559/DgD405/+pFt9fu211+Lbb7/Fxx9/jL///e8RGawuX74cP/74I8xmM+6//35dPnP8+PGYPn06Fi5ciM2bNwfVEf70008BAE8++SRuv/12n6+V31F6enrIp4i6KywsRGVlJdLS0iLahhYUFACoed70KKMOh0PNGmnatGnAbWhubm5AbYqnQbYe/TpfmSpysqunr2/bts1rGfbkmWeewe7du9GsWTM1GywcJpMJU6dORa9evbBx40a8/vrrePbZZ8P+XHcy4bR582ZkZWXhu+++Cyuj6qabbsLnn3+OkSNHYsGCBRg2bBgWLlwYkXZ02bJlWL16NSwWC+69915dPvOhhx7ClClTsGjRoqD7Lc8//zyWL18Oi8WC9u3b+wz4S3tnNpvDnhgQLpcLLpcrqM90OBw4ePCg39d5Kp96JUx46+d7y06WuvjkyZMoKSkJOBj30UcfAahZEhhMIN+bpk2bYuDAgVizZg0++OADvPnmm2F/pifV1dV48sknUVVVhYsvvljd1zRUd955J6ZMmYJNmzZhwoQJ+OKLLyI2DpWAcL9+/XSpA5KSktC3b1+sWrUKK1eujFgQbNmyZVi1ahUsFgvuueceXT5z/PjxmDZtGhYtWhR0vyVkShS8++67SnZ2tpKSkqL06dNHWbVqVUDvKy4uVgAoxcXFfl/7+eefKwBq/dHDWWedFZHP1aqoqFCOHDmiHDlyRHE4HLp9rt1uVz+3qqpKt88VLpdLOXHihHLkyBGlsLBQ188+deqUcuTIESU/P1/XzxVyz48eParrPbfZbFG750VFRbp+dij3PCcnJ6Ayevfdd9cpR9999124l6wsWrSozufKn9zcXI/vefzxxxUAyvjx4wP6GRUVFUr37t0VAMro0aPDvmatYcOGKQCUAQMGKNXV1QG9x+VyqdczadIkn6+NxnNeWVmp2+cKoz3nwTBS3RJo+SwtLa1Tfm688UY9LlsZNGiQx/L54IMPeny9y+VSUlNTFQDKvn37AvoZ48aNUwAoHTp0UGw2my7XrSiKUlZWprRr104BoDz99NO6fa6oqKhQ+xh61y3XXnutAkDp37+/YrfbA3rPiRMnFJPJpABQcnJyfL7WSM95MIxWtwRaRm+//fZa5ScjIyPcy1UUxXcbevLkSY/veeKJJxQAyl//+teAfsaKFSvU5+qzzz7T5brFu+++qwBQkpKSlE2bNun62YqiKM8++6wCQElLS9P187///nu1nnvqqad0+1xRUVGhnH322QoA5c4779T1s6+//nq13xJo3VJZWanUr19fAaAsWLDA52uNVLcEWj5/+eWXOuXn/fff1+OylbFjx3osn+3bt/f4+uPHj6uvMZlMypIlS/z+jN27d6vP47fffqvLdSuKonz66adqfXX06FHdPle4XC7lww8/VOuA7du36/K5GzduVMxmswJA+fLLL3X5THcVFRVq/+iNN97Q7XOffvppBYByxRVXRKQN1fZbxowZo+tnX3PNNUH3W4KJFbmLeCbY559/jocffhj/+c9/cP7552Pq1Km46qqrsH37drRr106Xn1FRUaHbLIe70aNH44knnqj1tU2bNiEzM1M9StUb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yECTJk3Qrl07dOjQAR06dIDdbsemTZvQunVrnHHGGUhNTYXNZsOGDRtw9OhRnDhxAvn5+SguLkbDhg3Ru3dv3Hvvvbod5OOJy+XC119/jQ8++ABbt25FSUkJMjIy1Ky69u3bo3379liyZAk2btyoZjvKWCgpKUldidK6dWt06tQJl19+OUaNGhXVumXFihXYsWMHTp48qdYt2j/ybzVsEGzt2rUYOHCg+vVXXnkFs2bNws6dO2u93lsmWCj/MCKKvNzc3Lgtow6HI6InBBLFWjyXz3jgPulCFCyWUSLjYvkkMraSkhJkZmaGVEYjGm5v0qQJLBYL8vLyan39xIkT6jHoWjLTS0QUadGabSSixMTgFxEREVH8ieimSMnJyejbty8WL15c6+uLFy/WZVNsIiIiIiIiIiKiQEQ8FeLRRx/Fbbfdhn79+mHgwIF4//33cfjwYd1ObyQiIiIiIiIiIvIn4kGw4cOH4+TJk3jppZdw7NgxnHXWWfj+++/Rvn37SP9oIiIiIiIiIiIiAFEIggHAAw88gAceeCAaP4qIiIiIiIiIiKiOiO4JRkREREREREREZAQMghERERERERERUcJjEIyIiIiIiIiIiBIeg2BERERERERERJTwGAQjIiIiIiIiIqKExyAYERERERERERElPAbBiIiIiIiIiIgo4TEIRkRERERERERECY9BMCIiIiIiIiIiSngMghERERERERERUcJjEIyIiIiIiIiIiBIeg2BERERERERERJTwGAQjIiIiIiIiIqKExyAYERERERERERElPAbBiIiIiIiIiIgo4TEIRkRERERERERECY9BMCIiIiIiIiIiSngMghERERERERERUcJjEIyIiIiIiIiIiBIeg2BERERERERERJTwGAQjIiIiIiIiIqKExyAYERERERERERElPAbBiIiIiIiIiIgo4TEIRkRERERERERECY9BMCIiIiIiIiIiSngMghERERERERERUcJjEIyIiIiIiIiIiBIeg2BERERERERERJTwGAQjIiIiIiIiIqKExyAYERERERERERElPAbBiIiIiIiIiIgo4TEIRkRERERERERECY9BMCIiIiIiIiIiSngMghERERERERERUcJjEIyIiIiIiIiIiBIeg2BERERERERERJTwGAQjIiIiIiIiIqKExyAYERERERERERElPAbBiIiIiIiIiIgo4TEIRkRERERERERECY9BMCIiIiIiIiIiSngRDYK98sorGDRoENLT05GVlRXJH0VERERERERERORVRINgNpsNN998M8aOHRvJH0NEREREREREROSTNZIf/uKLLwIAPvzww4BeX11djerqavXvxcXFAICSkhLdr42Iwidlk2WUyHhYPomMjWWUyLhYPomMTcqmoihBvzeiQbBgvfbaa2rgTKtt27YxuBoiChTLKJFxsXwSGRvLKJFxsXwSGdvJkyeRmZkZ1HsMFQR7+umn8eijj6p/LyoqQvv27XH48OGg/2FkPCUlJWjbti1ycnLQoEGDWF8O6eDw4cM4++yz8euvv6Jdu3axvhwKE8toYmH5TCwsn4mHZTSxsIwmFpbPxMLymXiKi4vRrl07NGrUKOj3Bh0Ee+GFFzxma2lt2LAB/fr1C/piUlJSkJKSUufrmZmZfFgTSIMGDfj7TBBy4EVWVhZ/pwmEZTQxsHwmJpbPxMEymphYRhMDy2diYvlMPGZz8NvcBx0EGzduHEaMGOHzNdnZ2UFfCBERERERERERUaQEHQRr0qQJmjRpEolrISIiIiIiIiIiioiI7gl2+PBhnDp1CocPH4bT6cSWLVsAAJ07d0b9+vX9vj8lJQV///vfPS6RpPjD32fiadCgAS6++GKmFScIltHEwvKZWFg+Ew/LaGJhGU0sLJ+JheUz8YTzOzUpoZwpGaA77rgDH330UZ2vL1++HJdcckmkfiwREREREREREVEtEQ2CERERERERERERGUHwW+kTERERERERERHFGQbBiIiIiIiIiIgo4TEIRkRERERERERECY9BMCIiIiIiIiIiSnhxEwR75ZVXMGjQIKSnpyMrKyvWl0Mh+M9//oMOHTogNTUVffv2xerVq2N9SRSiVatW4ZprrkGrVq1gMpnwzTffsIzGOZbPxMHymZhYRhMHy2jiYflMHCyfiYllNHF4KqPBipsgmM1mw80334yxY8fG+lIoBJ9//jkefvhhTJgwAb/88gsuvPBCXHXVVTh8+HCsL41CUF5ejl69euHf//63+jWW0fjF8plYWD4TD8toYmEZTSwsn4mF5TPxsIwmFk9lNGhKnJk5c6aSmZkZ68ugIA0YMEC5//77a32ta9euyt/+9rcYXRHpBYDy9ddfq39nGY0/LJ+Ji+UzMbCMJi6W0fjH8pm4WD4TA8to4nIvo4GKm0wwil82mw2bNm3C0KFDa3196NChWLt2bYyuiogAlk8io2MZJTIulk8iY2MZJU8YBKOIKygogNPpRPPmzWt9vXnz5sjLy4vRVRERwPJJZHQso0TGxfJJZGwso+RJTINgL7zwAkwmk88/GzdujOUlko5MJlOtvyuKUudrZCyBlFFKDCyf8Yfl84+FZTT+sIz+cbB8xh+Wzz8WllHSssbyh48bNw4jRozw+Zrs7OzoXAxFTJMmTWCxWOpE20+cOFEnKk/GEkgZ7datW5SuhiKB5TN+sXz+MbCMxi+W0cTH8hm/WD7/GFhGyZOYBsGaNGmCJk2axPISKAqSk5PRt29fLF68GMOGDVO/vnjxYlx33XUxvDLyh2U08bF8xi+Wzz8GltH4xTKa+Fg+4xfL5x8Dyyh5EtMgWDAOHz6MU6dO4fDhw3A6ndiyZQsAoHPnzqhfv35sL478evTRR3HbbbehX79+GDhwIN5//30cPnwY999/f6wvjUJQVlaGvXv3qn8/cOAAFi5cCAAso3GI5TOxsHwmHpbRxMIymlhYPhMLy2fiYRlNLJ7K6JYtW9CoUSO0a9cusA/R9YzKCBo9erQCoM6f5cuXx/rSKEDvvvuu0r59eyU5OVnp06ePsnLlylhfEoVo+fLlHssjy2j8YvlMHCyfiYllNHGwjCYels/EwfKZmFhGE4e3Mjp69OiAP8OkKIoSWLiMiIiIiIiIiIgoPsX0dEgiIiIiIiIiIqJoYBCMiIiIiIiIiIgSHoNgRERERERERESU8BgEIyIiIiIiIiKihMcgGBERERERERERJTwGwYiIiIiIiIiIKOExCEZERERERERERAmPQTAiIiIiIiIiIkp4DIIREREREREREVHCYxCMiIiIiIiIiIgSHoNgRERERERERESU8P4f0hO/JHRLVpkAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1500x200 with 5 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.subplots(1, 5, figsize=(15, 2))\n",
    "plt.subplots_adjust(wspace=0, hspace=0)\n",
    "\n",
    "for i in range(1,6):\n",
    "    plt.subplot(1,5,i)\n",
    "    group_id = i - 1\n",
    "    plt.plot(x_grid.detach().numpy(), y.detach().numpy(), color='black', alpha=0.1)\n",
    "    plt.plot(x_grid.detach().numpy(), ys[i-1], color='black')\n",
    "    plt.xlim(-1,1)\n",
    "    plt.ylim(-1,2)\n",
    "    plt.xticks([-1,0,1])\n",
    "    if i > 1:\n",
    "        plt.yticks([])\n",
    "\n",
    "plt.suptitle('[1,5,5,1] KAN')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1a63c018-d267-4874-a258-6c5b6e7acdf5",
   "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.9.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
