{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "4cc129ee-bfd6-4ab3-b809-1bc99e6d2225",
   "metadata": {},
   "source": [
    "## Why skip connections?"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3775807a-de41-43a0-9567-4b266406935f",
   "metadata": {},
   "source": [
    "We consider a 2D symbolic function $f(x,y)={\\rm exp}({\\rm sin}(\\pi x)+y^2)$."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "74204880-fd33-4393-9ea6-93c99c8dcd1f",
   "metadata": {},
   "source": [
    "### SiLU residue"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "e3209e79-7d6d-4566-8a23-ff7c3d0d941a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cpu\n",
      "checkpoint directory created: ./model\n",
      "saving model version 0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "| train_loss: 7.30e-03 | test_loss: 7.24e-03 | reg: 8.41e+00 | : 100%|█| 50/50 [00:06<00:00,  7.20it"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "saving model version 0.1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "from kan import *\n",
    "\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "print(device)\n",
    "\n",
    "# create a KAN: 2D inputs, 1D output, and 5 hidden neurons. cubic spline (k=3), 5 grid intervals (grid=5).\n",
    "f = lambda x: torch.exp(torch.sin(torch.pi*x[:,[0]])+x[:,[1]]**2)\n",
    "dataset = create_dataset(f, n_var=2, train_num=1000, device=device)\n",
    "model = KAN(width=[2,1,1], grid=5, k=3, seed=0, device=device, base_fun='silu')\n",
    "results_silu = model.fit(dataset, opt=\"LBFGS\", steps=50, stop_grid_update_step=20, lamb=0.00);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "6fa03398-fff9-4ab0-ae25-2c7472edfcce",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZcAAAFICAYAAACcDrP3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAuSklEQVR4nO3de1zUdb7H8fd3ZuQygIKIV7wAYoJ44ybeUgrFpIvJbpr16Fh2juumrh33eDxbbWa3rV1XscujTp3do+Vmm2ipGHhSARWNi4KIKCBeFlAhYRQYGGb4/c4fyTykNUX5Db+Z4f18PPynccaP5s/XfH9XIcuyDCIiIgVp1B6AiIicD+NCRESKY1yIiEhxjAsRESmOcSEiIsUxLkREpDjGhYiIFMe4EBGR4hgXIiJSHONCRESKY1yIiEhxjAsRESmOcSEiIsUxLkREpDjGhYiIFKdTewAiRyDLMq5evYqGhgZ4enrC19cXQgi1xyKyW1y5EN2GwWBAUlISgoOD4efnh4CAAPj5+SE4OBhJSUkwGAxqj0hklwSfREl0a2lpaUhMTITRaATw4+qlTduqRa/XIzk5GfHx8arMSGSvGBeiW0hLS0NCQgJkWYYkST/78zQaDYQQSElJYWCIbsK4EP2EwWCAv78/mpqabhuWNhqNBu7u7qioqIC3t7ftByRyADzmQvQTmzZtgtFo7FBYAECSJBiNRmzevNnGkxE5Dq5ciG4iyzKCg4NRXl6Ou9k0hBAIDAxEaWkpzyIjAuNC1M4PP/wAPz+/Tr3f19dXwYmIHBN3ixHdpKGhoVPvr6+vV2gSIsfGuBDdxNPTs1Pv9/LyUmgSIsfGuBDdxNfXF0FBQXd93EQIgaCgIPTu3dtGkxE5FsaF6CZCCCxbtuye3rt8+XIezCe6gQf0iX6C17kQdR5XLkQ/4e3tjeTkZAghoNHcfhNpu0J/+/btDAvRTRgXoluIj49HSkoK3N3dIYT4p91dbf/N3d0de/bswcyZM1WalMg+MS5EPyM+Ph4VFRXYsGEDAgMD270WGBiIDRs2oLKykmEhugUecyHqAFmWceDAATz44IPYt28fYmNjefCe6Da4ciHqACGE9ZiKt7c3w0J0B4wLEREpjnEhIiLFMS5ERKQ4xoWIiBTHuBARkeIYFyIiUhzjQkREimNciIhIcYwLEREpjnEhIiLFMS5ERKQ4xoWIiBTHuBARkeIYFyIiUhzjQkREimNciIhIcYwL0R2YzWZUVlaiuLgYAHD27FnU1tZCkiSVJyOyX3zMMdHPMBgMSE5OxpYtW1BUVIT6+nq0tLTAzc0Nfn5+mDp1KhYtWoTJkydDp9OpPS6RXWFciG7hyJEjePHFF3HixAlERUUhISEBY8aMgaenJwwGA/Ly8rBr1y6UlZVh3rx5eOONN+Dn56f22ER2g3Eh+om9e/di4cKF8PT0xNtvv43Zs2ejpaUFW7duhclkQs+ePTF//nyYzWZs3boVa9aswahRo/DZZ5+hX79+ao9PZBcYF6KblJSUYNasWfDw8MDWrVsRGhoKIQTKy8sRHh6Oa9euISAgAHl5efDx8YEsyzh06BAWLFiA6dOn49NPP4Wrq6vavw0i1fGAPtENra2teOutt1BXV4f333/fGpbbEUJgypQpePfdd/HNN98gNTW1i6Ylsm+MC9ENZWVl2LVrF+bOnYspU6bcMSxthBCYM2cOYmJi8Mknn8Bisdh4UiL7x1NciG7IyspCQ0MDEhMTcf78eTQ2Nlpfq6ioQGtrKwCgpaUFRUVF6Nmzp/X1gQMHYu7cuVizZg0uX74Mf3//Lp+fyJ4wLkQ3nD59Gnq9HoGBgVi8eDEOHz5sfU2WZZhMJgBAVVUVZsyYYX1NCIF169Zh9OjRMBqNqKqqYlyo22NciG5oamqCTqeDq6srTCYTmpubb/nzZFn+p9csFgvc3d3bRYioO2NciG7o27cvmpqaYDAYMGHCBHh4eFhfa2pqQlZWljUikyZNsl44KYTAkCFDUF1dDY1GAx8fH7V+C0R2g3EhuiEiIgJmsxnZ2dl455132r1WXl6OqKgoXLt2Df369cOXX34Jb29v6+tCCPzud79D//79uUuMCDxbjMgqOjoagYGB2LRpExobG6HVatv9aCOEgEajsf53jUaDS5cuYdu2bUhISECvXr1U/F0Q2QfGhegGX19fLF26FMeOHcPGjRs7fEqxyWTC66+/jqamJixevLjDpzATOTPuFiO6ycKFC5GZmYl33nkHer0eS5YsgZubGwBAp9NBp9NZVzGyLKO+vh5vvvkmtm7divXr1+O+++5Tc3wiu8HbvxD9RE1NDV544QXs3r0b8fHxePHFFxESEoIzZ85AkiS4uLhg+PDhyM7Oxp/+9Cfk5+dj7dq1WLJkSbvdZ0TdGeNCdAuNjY345JNPsHHjRly5cgWBgYEIDg6Gl5cX6urqcObMGVRVVSEiIgKvvvoqpk2bBo2Ge5mJ2jAuRLdx+fJl7Nu3DxkZGSgoKEB2djamTp2KyZMnY+bMmZgwYQL0er3aYxLZHcaFqINycnIQHR2NnJwcREZGqj0OkV3jOp6og7RarfU0ZCK6PW4lRESkOMaFiIgUx7gQEZHiGBciIlIc40JERIpjXIiISHGMCxERKY5xISIixTEuRESkOMaFiIgUx7gQEZHiGBciIlIc40JERIpjXIiISHF8ngtRB8myDEmSoNFoIIRQexwiu8aVC9Fd4LNciDpGp/YAREowm824ePEiJElSe5ROE0JgyJAhcHFxUXsUonvGuJBTqKiowK9//WtERERYA+Ooq4y8vDx8+OGHCAoKUnsUonvGuJBTkGUZo0ePRnR0NL744gvMnj0bzzzzjNpj3ZPVq1eDh0LJ0TEu5FR27tyJbdu2wWAw4Mknn3S4XUuMCjkLx9xvQHQLQgg8+uij0Gq1yM3Nxfnz59UeiajbYlzIqUyaNAkDBw6EwWDA3r17uRIgUgnjQk6lT58+eOCBBwAAX3/9Ncxms8oTEXVPjAs5FSEE5s6dC51Oh9zcXJSUlKg9ElG3xLiQ05k0aRKGDRuG+vp67Ny5k7vGiFTAuJDT8fHxQUJCAgBg+/btaGxsVHkiou6HcSGnI4TAL3/5S7i5uaGoqAjZ2dlcvRB1McaFnNK4ceMQHh6OlpYWfPHFF4wLURdjXMgpubm5Yf78+RBCYM+ePaisrFR7JKJuhXEhpySEwCOPPIJ+/frhypUr+Prrr7l6IepCjAs5LX9/fzz88MOQZRmfffYZD+wTdSHGhZyWEAILFy6Eu7s7Tpw4gfT0dK5eiLoI40JOSwiB8PBwTJ06FWazGf/93//NK/aJugjjQk7NxcUF//qv/wqdTocDBw4gLy+PqxeiLsC4kFMTQmDGjBkYN24cjEYjPvzwQ7S2tqo9FpHTY1zI6Xl6emLJkiXQaDTYtWsXCgoKuHohsjHGhZyeEAJz5sxBWFgY6uvrkZSUxNULkY0xLtQt9OrVC8uXL4dWq8U333yDnJwcrl6IbIhxoW6h7Vb848ePR0NDA9599120tLSoPRaR02JcqNvo2bMn/uM//gM9evRAamoqvv32W65eiGyEcaFuQwiBhIQExMXFoaWlBW+88Qbq6urUHovIKTEu1K24ubnhlVdeQa9evZCfn48PPvgAkiSpPRaR02FcqFsRQiAyMhLPP/88ZFnGxo0bcezYMe4eI1IY40LdjlarxcqVKxEWFoba2lr853/+J+rr69Uei8ipMC7ULfXt2xdvvfUW9Ho9MjMzsX79el77QqQgxoW6JSEE4uPj8atf/QqyLGP9+vXYu3cvd48RKYRxoW5Lp9Phv/7rvzB58mTU19djxYoVKCsrY2CIFMC4ULfm4+ODjRs3YtCgQSgrK8OSJUtQW1vLwBB1EuNC3ZoQAmPGjMH69evh4eGB9PR0/Pu//zuMRqPaoxE5NMaFur22G1v+/ve/h06nw9/+9jf8/ve/R3Nzs9qjETksxoUIP56evGzZMixduhQA8P7772Pt2rUwmUwqT0bkmBgXohtcXV2xdu1aPPfcc5AkCevWrcPLL78Mo9HIYzBEd4lxIbqJu7s71q1bh2effRaSJCEpKQlLly5FXV0dA0N0FxgXopsIIeDh4YH169dj2bJlEEJg8+bNmDdvHk9TJroLjAvRT7QF5u2338brr78OvV6P/fv3Y/bs2di5cycsFovaIxLZPcaF6Ge4urpi5cqV+N///V8MHjwY5eXleOqpp/Db3/4Wly9f5iqG6DYYF6Lb0Gq1ePzxx7Fnzx7MmDEDJpMJ7733HuLi4vDVV1+hubmZkSG6BcaF6A6EEAgJCcFXX32Ft956C3369EFxcTGeeeYZJCYmIjMzE2azmZEhugnjQtQBQgh4eXlh5cqV+O6775CYmAiNRoPU1FQkJCRg/vz5SE9P50qG6AbGheguaDQahIWF4fPPP8e2bdswdepUmM1mfP3110hISMDs2bOxZcsWVFdXQ5Ikhoa6LcaF6C4JIeDi4oKHHnoIe/bswRdffIFp06YBADIyMvDss89iwoQJWLp0Kfbt2weDwQBZlhka6lYYF6J7JISAXq/H448/jpSUFOzevRtPPvkkfHx8cPHiRXz88cdISEhAdHQ0nn/+eXz11VcoLy+37jpjbMiZ6dQegMjRCSHg7u6O2NhYTJs2DRcvXsTu3buxfft2HD9+HGfPnsXZs2exadMm9OrVC8OHD0dkZCRiYmIQFhaGIUOGoGfPntDpuDmS8+DfZiKFCCGg1WoREBCApUuX4t/+7d9QXl6O/fv3Y+/evTh27Biqq6uRm5uL3NxcfPTRR3Bzc0OfPn0QGBiIUaNGIS4ujisacgqMC5ENCCHg6uqKkJAQjBw5Er/61a9w9epVFBUV4ejRozh69ChOnTqFy5cvo7KyEhUVFcjMzITJZIKPj4/a4xN1GuNCTscev/lrNBr4+flh+vTpmD59OiRJQkNDAyorK1FcXIzCwkIUFhYiNjYWBQUFao9L1GmMCzkFIQQKCwvx2muvqT3KPRs1ahROnz6NgoICCCHUHoeoU4Rsj1/ziO5SS0sLysvL0draqvYonabRaBAUFAQXFxe1RyG6Z4wLEREpjrvFiDro5u9h3G1FdHu8iJKog44fPw6tVovjx4+rPQqR3WNciIhIcYwLEREpjnEhIiLFMS5ERKQ4xoWIiBTHuBARkeIYFyIiUhzjQkREimNciIhIcYwLEREpjnEhIiLFMS5ERKQ4xoWIiBTHuBARkeIYFyIiUhzjQtQBsiyjrq4OAFBXVwc+wJXo9hgXotswGAxISkpCcHAw4uLiIMsy4uLiEBwcjKSkJBgMBrVHJLJLQuZXMKJbSktLQ2JiIoxGI4BbP+ZYr9cjOTkZ8fHxqsxIZK8YF6JbSEtLQ0JCAmRZhiRJP/vzNBoNhBBISUlhYIhuwrgQ/YTBYIC/vz+amppuG5Y2Go0G7u7uqKiogLe3t+0HJHIAPOZC9BObNm2C0WjsUFgAQJIkGI1GbN682caTETkOrlyIbiLLMoKDg1FeXn5XZ4QJIRAYGIjS0lLr8Rii7oxxIbrJDz/8AD8/v06939fXV8GJiBwTd4sR3aShoaFT76+vr1doEiLHxrgQ3cTT07NT7/fy8lJoEiLHxrgQ3cTX1xdBQUF3fdxECIGgoCD07t3bRpMRORbGhegmQggsW7bsnt67fPlyHswnuoEH9Il+gte5EHUeVy5EP+Ht7Y3k5GQIIaDR3H4TabtCf/v27QwL0U0YF6JbiI+PR0pKCtzd3SGE+KfdXW3/zd3dHXv27MHMmTNVmpTIPjEuRD8jPj4eFRUV2LBhAwIDA9u9FhgYiA0bNqCyspJhIboFHnMh6gBZlnHgwAE8+OCD2LdvH2JjY3nwnug2uHIh6gAhhPWYire3N8NCdAeMCxERKY5xISIixTEuRESkOMaFiIgUx7gQEZHiGBciIlIc40JERIpjXIiISHGMCxERKY5xISIixTEuRESkOMaFiIgUx7gQEZHiGBciIlIc40JERIpjXIiISHGMC9EdmM1mVFZWori4GABw9uxZ1NbWQpIklScjsl98zDHRzzAYDEhOTsaWLVtQVFSE+vp6tLS0wM3NDX5+fpg6dSoWLVqEyZMnQ6fTqT0ukV1hXIhu4ciRI3jxxRdx4sQJREVFISEhAWPGjIGnpycMBgPy8vKwa9culJWVYd68eXjjjTfg5+en9thEdoNxIfqJvXv3YuHChfD09MTbb7+N2bNno6WlBVu3boXJZELPnj0xf/58mM1mbN26FWvWrMGoUaPw2WefoV+/fmqPT2QXGBeim5SUlGDWrFnw8PDA1q1bERoaCiEEysvLER4ejmvXriEgIAB5eXnw8fGBLMs4dOgQFixYgOnTp+PTTz+Fq6ur2r8NItXxgD7RDa2trXjrrbdQV1eH999/3xqW2xFCYMqUKXj33XfxzTffIDU1tYumJbJvjAvRDWVlZdi1axfmzp2LKVOm3DEsbYQQmDNnDmJiYvDJJ5/AYrHYeFIi+8dTXIhuyMrKQkNDAxITE3H+/Hk0NjZaX6uoqEBraysAoKWlBUVFRejZs6f19YEDB2Lu3LlYs2YNLl++DH9//y6fn8ieMC5EN5w+fRp6vR6BgYFYvHgxDh8+bH1NlmWYTCYAQFVVFWbMmGF9TQiBdevWYfTo0TAajaiqqmJcqNtjXIhuaGpqgk6ng6urK0wmE5qbm2/582RZ/qfXLBYL3N3d20WIqDtjXKjbO3fuHNLT03Hw4EEYjUYYDAZMmDABHh4e1p/T1NSErKwsa0QmTZpkvXBSCIEhQ4aguroara2tqKiogMlk4llj1K3xVGTqdi5evIiMjAwcOHAA6enpuHDhAoQQCAgIwLlz5/DBBx/g+eefb/ee8vJyREVF4dq1axg2bBhyc3Ph7e1tfV0Igd/97ndISkpCQEAA3N3dMXbsWERFRSE6OhqjR4+Gi4tLF/9OidTDuJDTq6ysRHp6uvVHeXk5AGDs2LGYNm0aYmNjMXXqVEiShClTpsDHxwepqantDtj/3HUuwI+7yaqqqjBt2jQ88sgjWLx4MXJycpCTk4Pc3FzU19fD1dUV48aNs8YmLCwMPXr0UOXPg6grMC7kdC5fvtwuJqWlpQCAsLAwa0zuv/9++Pr6/tN7P/jgA6xcuRIvv/wyVq9ebd31dbu4NDc3Y8WKFdi1axf279+P++67z/p5kiThzJkzyMnJQXZ2NvLy8tDQ0AA3NzeMHz8e0dHRiI6ORmhoKO9PRk6FcSGHV11djYyMDGtMTp8+DQAICQlpF5O+ffve8bMaGxvx3HPPYc+ePXjttdewZMkSuLm54dy5c4iOjrbuFsvOzoa3tzfq6+vx5ptv4uOPP8b69evx7LPP3vbzW1tbUVxcjOzsbOTk5ODYsWMwGo3Q6/UIDw+3rmxCQkKg1WoV+fMhUgPjQg7nhx9+QGZmpjUmRUVFAIARI0ZYYzJt2jT079//nj6/pqYGL7zwAnbv3o34+Hi8+OKLCAkJwZkzZyBJElxcXDB8+HBkZ2fjT3/6E/Lz87F27VosWbLkroNgsVhw6tSpdrFpbm6Gp6cnwsPDrSub++67DxoNr3kmx8G4kN2rq6tDZmYmDhw4gIyMDJw4cQIAEBQU1C4mgwYNUuzXbGxsxCeffIKNGzfiypUrCAwMRHBwMLy8vFBXV4czZ86gqqoKERERePXVVzFt2jRF/vE3m804efKkdTdafn4+TCYTvLy8EBkZaV3ZBAcHMzZk1xgXsjvXrl3DwYMHrTHJz8+HLMsYNmwYpk+fbv0xePBgm89y+fJl7Nu3DxkZGSgvL0dzczN8fHwQFhaGmTNnYsKECdDr9Tb79VtaWlBYWGiNTUFBAVpaWtCrVy9ERkZaVzZBQUEdvl0NUVdgXEh19fX1OHTokHU317FjxyBJEvz9/TF9+nTExsZi+vTpGDZsmKpztra2QpZlaDQa1VYNJpMJBQUF1ticOHECFosFPj4+iIqKsq5sAgICGBtSFeNCXa6hoQFZWVnWlUlubi5aW1sxcODAdiuTwMBA/gN5B83NzcjPz7fGprCwEK2trfD19bWGJjo6GkOGDOGfJXUpxoVszmg04siRI9aYZGdnw2KxoF+/fu1iEhwczH8AO8loNCI/P996gsDJkychSRL69u3bbjeav78//6zJphgXUlxzczOOHj1qjcnRo0dhNpvh5+eHadOmWWMycuRI/gNnYw0NDdbYZGdno7i4GJIkoX///u1WNgMHDlR7VHIyjAt1mslkwvfff289ZnL06FGYTCb07t27XUxGjRrFmKisvr4eeXl51jsInD59GrIsY+DAge1ic6+ncRO1YVzorrW0tCAnJwfp6ek4cOAAjhw5gubmZnh7e+P++++3xmT06NE8XdbOXbt2DceOHbOubEpKSgAA/v7+1tBERUV16AJUopsxLnRHZrMZeXl51phkZWXBaDSiZ8+emDp1qvU6k7Fjx/KqcgdXV1eHvLw86zGbsrIyAMDQoUOtK5uoqCj06dNH5UnJ3jEu9E8sFguOHz9ujcnhw4fR0NAAT09PTJkyxboyGT9+PO+H5eRqa2uRm5trXdmcO3cOABAQENBuZdN2nzWiNowLobW1FQUFBdaYHDp0CNevX4der8fkyZOtK5OIiAjeybebq6mpscYmJycHFy5cAAAMHz7curKJjIxs9zgC6p4Yl25IkiQUFhZaY3Lw4EEYDAa4ublh0qRJ1phERUXxGSR0W9XV1dZrbLKzs1FRUQHgx/u8ta1sIiIi2j2+gLoHxqUbkGUZRUVF1phkZmaitrYWrq6uiImJscZkwoQJfHoidcqlS5esscnJyUFVVRWEEBg5cqR1ZRMREQFPT0+1RyUbY1yckCzLOH36dLuY1NTUoEePHoiJibEeM4mJiYGbm5va45ITq6ysbLeyuXLlCjQaDUJCQqwrm/Hjx7d7pDQ5B8bFCciyjNLSUmtMMjIycOXKFeh0OkRHR1tjMnHiRJveZJHodmRZRkVFhTU0OTk5qKmpgUajQVhYmHVlM378eLi7u6s9LnUS4+KAZFlGeXl5u5hUVVVBq9UiMjLSerPHiRMncvcD2S1ZlnHx4sV2sbl69Sq0Wi1Gjx5tXdmMHTuWK2wHxLg4iPPnz7eLyT/+8Q9oNBqEh4dbYzJp0iQeOCWHJcsyzp07Zw1NTk4O6urq0KNHD2tsoqKiMHbsWB4bdACMi4MIDQ1FSUkJxo0bZ43J5MmTeconOS1JklBeXm5d2eTm5uLatWv44x//iFmzZqk9Ht0B4+Ig2v438d5c1F3JsoyWlhbodDreCcIBMC5ERKQ43rtDAWazGRcvXoQkSWqP0mlCCAwZMoQXT9JdMZvNuHz5stNsAwMGDODdKDqJcVFARUUFfv3rXyMiIkLtUTotLy8PH374IYKCgtQehRzIlStX8Prrr2PUqFFqj9JpRUVFeOWVVzB48GC1R3FojIsCZFnGmDFj8Oabb3bo51ssFhw9ehQpKSmora1FZGQk5syZAz8/PxtPemerV68G95TSvbjvvvuwfPlyxT+37X5mRUVFuH79Ory9vTF69GhERESgd+/eiv9669ev5zagAMZFYbc74C7LMurr6/HKK6/gf/7nf9DU1AQA+Mtf/oIPP/wQH3/8MaKjo1U7aM8NipSgxN/ftm3lyy+/xN///ndUV1e3+/up0WjQv39/LFiwAImJidDr9Yr9uqQMxqULNTU1YcWKFdi8eTM0Gg0mTJgAf39/pKeno7CwEAsWLMA333zDJzZSt9Z2vcvatWtx/PhxyLKM3r17IzQ0FL6+vqipqUFxcTGqqqrw5z//GVlZWXj55ZcxaNAgbjd2hHHpIpIk4b333sPnn38OnU6HVatWYdWqVdDr9Th69CiefvppnD9/HitWrMD27dt5MSR1S233xVu1ahUuXLgADw8PzJs3D0888QT69esHjUaD1tZWXLp0CVu2bMH27duRlZWFFStW4N1330VAQAADYyf4DNouIMsycnNz8cc//hGSJGHRokV46aWX4OnpCY1Gg4kTJ2Ljxo3Q6/XIyMjApk2buDynbkeWZVy4cAGrV6/GhQsX0LdvX/zhD3/AsmXLMHDgQGi1WgghoNPpMHjwYPz2t7/F66+/Dh8fH5SUlGD16tW4dOkStx07wbh0gebmZqxduxZ1dXUYM2YM1qxZ0+72FUIIzJo1C0899RQkSUJSUhIuXbqk4sREXe/69etYu3Ytzp07hz59+uAPf/gD7r///p+9YFKn02HmzJl488034e3tjdOnT+ONN95AY2NjF09Ot8K42Jgsy0hLS8N3330HFxcXvPrqq7d8/rhWq8XKlSvRt29fnD9/Hp999hm/gVG3YbFY8NFHHyEvLw96vR4vv/wyIiIi7riLSwiBSZMmYdWqVXBzc0NWVhb++te/orW1tYsmp5/DuNhYU1MTkpKSYDabERcXh1mzZt1ygxFCICgoCAsWLIAsy/jrX/+Kq1evqjAxUdeSZRmHDh1CcnIyhBB49tlnMW3atA4fO9FoNJg1axaefPJJyLKMLVu2IDc3l1/OVMa42JAsy8jMzMTRo0fh6uqK3/zmN7e98l2j0WDRokXw9vbG2bNnsWfPHm4g5PTq6urw3nvvobm5GVFRUXj66afv+t5hOp0OixYtwtixY2E0GrFx40bU19fbaGLqCMbFhiwWCz799FO0tLRg8uTJmDJlyh2/jY0YMQIzZ86EJEnYtGkTTCZTF01L1PUkScLWrVtRVlaGnj17YsWKFff8QDsvLy/85je/gYeHB06ePInk5GR+OVMR42JDZ86cwb59+6DVavH888936BkUWq0WCxcuRI8ePZCdnY0TJ050waREXa/t7LAvv/wSsizjiSeeQEhIyD2fSiyEwLhx4/DYY49Zd49VVlYqPDV1FONiI7Is48svv8T169cRFBSEGTNmdGijaTtAGRoaCqPRiK+++orfvsgpSZKEzZs3o66uDkOGDMGTTz4JjaZz/yRptVo888wz6N+/P6qrq/G3v/3NKW6m6YgYFxu5du0aduzYAQBITEyEj49Ph9/r6emJuXPnAgB27dqFuro6m8xIpBZZllFSUoK0tDRoNBo89dRTtzyL8l4MGDAA8+fPhxACKSkpuHDhAr+gqYBxsQFZlnHkyBGUlpbC09MTv/jFL+5qqS+EwJw5c+Dl5YVz587h8OHD3DjIqbQda2loaEBAQABmz56t2JX1Qgg89thjGDx4MOrq6qy73ahrMS42IMsytm3bBovFgoiICISEhNz1Z4wYMQJRUVGwWCw8MElO5/z589i3bx+EEJg3b57itzvq3bu39Utdamoqj72ogHGxgZqaGuzfvx8AMHfu3Ht68FaPHj3w+OOPAwAOHDiA6upqRWckUoskSdixYweuX7+OIUOGYObMmYrfD0wIgdmzZ2PAgAGora3Frl27+AWtizEuCpNlGVlZWaisrIS3tzfi4+PvacMRQmDmzJnw8fFBVVUVDh06xI2DnEJNTQ1SU1MBAI8++uhdHY+8G35+fpg9ezYAYPfu3aitrbXJr0O3xrgoTJZl7Ny5E62trYiKisKwYcPu+bOGDh2K6OhoSJKEr7/+mnEhhyfLMr777jvU1NTA19cXDz30kM3uYiyEwCOPPIJevXqhqqoKmZmZ3Ia6EOOisNraWmRmZgIAHn74Yeh09/5UA51Oh8ceewxCCBw8eBA1NTVKjUmkiqamJusuqtjYWAwcONCmv96QIUMwZcoU6xc0XpTcdRgXheXl5aGiogJeXl544IEHOvWtTAiBBx98EN7e3qiqqkJWVha/eZHDkmUZBQUFKC0thZubGx599FGbP3tFo9Fgzpw56NGjB06dOoXi4mJuQ12EcVFYamoqLBYLwsLCEBgY2OnPGzp0KCIjIyFJEnbu3MkNgxyWJEnYvXs3zGYzQkNDO3U1fkcJITB69GiMGDECJpMJKSkp3Ia6COOioMbGRqSnpwMAZsyY0aHbvdyJTqfDww8/DADIyMiwyUHJpqYmNDc3K/65RDerrq5GVlYWhBBISEi4p7Mo74W7uzseeughAEBmZiYP7HcRxkVBpaWlKC0thYuLC+Li4hT5ViaEQFxcHHr27ImKigpkZ2cr+s1LlmVs3LgR999/P/785z/zVhlkE2231a+trYWvry+mTp3aZY8jFkIgNjYW3t7eqK6uxpEjR7h66QKMi4IyMzPR1NSEoUOHYtSoUYp9bkBAAMaNG4fW1lbs3r1bsc8FALPZjL179yIvLw8XL17k88fJJiwWC9LS0iDLMiZOnIi+fft26a8/YMAAREREQJIkpKWlwWKxdOmv3x0xLgqRJAnZ2dnQaDSYNGmSolccu7i4ICEhAQCwf/9+XLt2TbHPvnTpEgoLC6HRaBAbG8u4kE2cP38eRUVF0Gq1Nrlo8k60Wi1mzZoFjUaD48eP84r9LsC4KESj0WDdunXYsWMHXnjhBUU3HiEEZsyYAQ8PD5w/fx7Hjh1T5HNlWUZOTg7q6urg6+uLiIgIRT6X6GayLCMjIwONjY0YNGgQxo0b1+VxEUIgMjIS/fr1Q319PS9K7gKMi4L69euHhx9+uEPP/r5bI0aMQFhYGMxmM3bv3q3YhvF///d/kCQJY8eORf/+/RX5TKKbmUwmHDhwAAAwZcoUxe8j1lE+Pj6IiYkB8OMeALPZrMoc3QXj4iDc3NysZ7x89913aGho6PRntn2DA4C4uLhOXfBJ9HPKy8tRWloKnU6HBx54QLU52q4b02q1KC4uxj/+8Q/VZukOGBcHIYTArFmz4O7ujrKyMhQUFHT6M0+dOoVz587Bzc0NsbGxCkxJ1F7bWWLNzc0YPHhwl1zb8nOEEBgzZgwGDBiAxsZGXpRsY4yLAwkNDcXIkSNhMpk6vWtMlmXs3bsXJpMJwcHBGDlypIKTEv2opaXFejukiRMnwtPTU9V5evbsiejoaABAeno6zxqzIcbFgej1eutdXlNTU9HY2HjPn2UymZCWlgYAeOCBB+Dh4aHIjEQ3u3jxIsrKyqDT6TB9+nS1x4EQAtOnT7fuGuNZY7bDuDiQtiub3dzcUFJSgvz8/Hv+rNLSUpw8eRI6nc4aLCIltT2R1Wg0YsCAAQgNDVX9VPe228H4+fmhoaEBOTk53DVmI4yLgwkLC0NoaChMJtM932tMlmWkpqaioaEBw4YNs8nZbUQWi8V6wkhkZKTqu8Ta+Pj4YPz48QB+vPC5tbVV5YmcE+PiYPR6PR555BEAQEpKCq5fv37Xn9EWJuDHs8S8vb2VHJEIAHDlyhUUFxdDo9Hg/vvvt5svMEII6zwnT57E1atX1R7JKTEuDqbtAUgeHh44e/Ysvv/++7tevRQVFSE/P7/do5SJlCTLMvLz83H9+nX07t0bo0ePtqu4jBs3Dr169UJdXR0KCwu5a8wGGBcHFBISgvDwcJjNZvz973+/qw1DlmVs374dRqMRI0aMQHR0tN1s9OQ82k5BlmUZo0aNgq+vr9ojtdO3b1+MHDkSkiTh8OHDao/jlBgXB+Tq6opf/vKXEEIgLS0Nly5d6vB7DQYDduzYAQCYM2cOvLy8bDUmdWPXr1+3nnAyefJkaDT29U+NTqfDxIkTAQDHjh3r1JmXdGv29X+cOqTtrLE+ffrg0qVL+Pbbbzu0epFlGfv370dZWRm8vLzwi1/8gqsWsomSkhJUV1dDr9fb5QkjQghER0fD1dUVlZWVKC8vV3skp8O4OKjBgwcjPj4esixj8+bNHXrYl9lsxl/+8he0trZi2rRpCAkJ6YJJqbuRZRnff/89LBYLhg4dCn9/f7VHuqVhw4bB398fLS0tyM3N5XEXhTEuDkqj0eBf/uVf4Orqitzc3DveykKWZWRnZyMzMxM6nQ7PPfcc7yVGNmE2m5GTkwPgx1OQ3dzcVJ7o1vR6vfWU5KNHj/JqfYUxLg5KCIGJEyciKioKJpMJH3300W03DovFgo0bN8JoNCI8PBwPPvig3e2qIOdw5coVnD17FlqtFjExMXb99ywmJgYajQYlJSV8/LHCGBcH5ubmhiVLlkCr1SItLe1nT0uWZRkHDx7Et99+C61Wi2XLlvF2L2QzhYWFaGhogI+Pj13fs04IgVGjRsHLywsGgwGnTp1SeySnwrg4sLYD+xEREWhsbMQ777xzy2Mv9fX1WLt2LYxGI2JiYvDoo4/a9bdJclxtx1tkWcaIESPg4+Oj9ki31bdvXwwfPtz6JFlSDuPi4Dw9PbFq1Sq4uLhg7969+Pzzz9utXiwWC9atW4fDhw/Dw8MDr7zyClctZDNNTU04ceIEACA6OhparVbliW5Pp9NZn8Can58Pk8mk8kTOg3FxcEIIzJ49G4mJibBYLHjppZewZ88etLa2wmQy4eOPP8a6desgyzIWL16M2NhYrlrIZioqKlBZWYkePXogPDzc7v+uCSEQFRUFrVaLCxcu4PLly2qP5DR4upATcHFxwdtvv43i4mLk5+fj6aefxsyZM3H9+nWkp6ejpaUFCQkJeOmll3iGGNlUQUEBmpubMWjQIAQEBKg9TocMHz4cvr6+qKmpQVFRkdrjOA2uXJyAEAL+/v74/PPPMXHiRNTX12Pbtm3Yu3cvZFnGE088gU8//RS9evVSe1RyYrIs49ixYwBgPVDuCHr16oXg4GDIssxb8CuIX2MVpuZfzJEjR2LXrl3YsWMHDh48CHd3dzz00EOYMWMGXF1dVZ+PnJsQAgsXLkRoaCgCAwMhhHCIv29arRaxsbFwc3NDVFQUTp8+rfZIToFxUYAQAoWFhXjttdfUHsVq6NChAIC8vDzk5eV1+H0FBQV2v5+c7FNJSQnc3d0BACdOnLAe2HcEra2tCAoKwoULF1BSUsJtQAFCdoSvFnaupaUF5eXlTvHQIY1Gg6CgILi4uKg9CjkQs9mMiooKp9kGBg8ejB49eqg9ikNjXIiISHE8oO8gZFm2/iDqriRJQnNzMyRJUnsUugPGxUEcP34cOp0Ox48fV3sUItWcOXMGUVFROHPmjNqj0B0wLkREpDjGhYiIFMe4EBGR4hgXIiJSHONCRESKY1yIiEhxjAsRESmOcSEiIsUxLkREpDjGhYiIFMe4EBGR4hgXIiJSHONCRESKY1yIiEhxjAsRESmOcXEAsiyjrq4OAFBXV8cHhlG31LYdmM1mbgcOgHGxYwaDAUlJSQgODkZcXBwkSUJcXByCg4ORlJQEg8Gg9ohENnfzdjB58mScOXMGkydP5nZg54TM/NultLQ0JCYmwmg0AkC7b2lCCACAXq9HcnIy4uPjVZmRyNa4HTguxsUOpaWlISEhAbIs3/ZZ4RqNBkIIpKSkcMMip8PtwLExLnbGYDDA398fTU1Nt92g2mg0Gri7u6OiogLe3t62H5CoC3A7cHw85mJnNm3aBKPR2KENCgAkSYLRaMTmzZttPBlR1+F24Pi4crEjsiwjODgY5eXld3UmjBACgYGBKC0tte6HJnJU3A6cA+NiR3744Qf4+fl16v2+vr4KTkTU9bgdOAfuFrMjDQ0NnXp/fX29QpMQqYfbgXNgXOyIp6dnp97v5eWl0CRE6uF24BwYFzvi6+uLoKCgu95fLIRAUFAQevfubaPJiLoOtwPnwLjYESEEli1bdk/vXb58OQ9iklPgduAceEDfzvD8fiJuB86AKxc74+3tjeTkZAghoNHc/n9P25XJ27dv5wZFToXbgeNjXOxQfHw8UlJS4O7uDiHEPy3z2/6bu7s79uzZg5kzZ6o0KZHtcDtwbIyLnYqPj0dFRQU2bNiAwMDAdq8FBgZiw4YNqKys5AZFTo3bgePiMRcHIMsyamtrUV9fDy8vL/Tu3ZsHLanb4XbgWBgXIiJSHHeLERGR4hgXIiJSHONCRESKY1yIiEhxjAsRESmOcSEiIsUxLkREpDjGhYiIFMe4EBGR4hgXIiJSHONCRESKY1yIiEhxjAsRESmOcSEiIsX9PxQlbsWML4m2AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 500x400 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model.plot()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e5f210da-d254-49ab-8bab-35f98e51b51f",
   "metadata": {},
   "source": [
    "### Linear residue"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "b7f3b9de-5717-4b75-bd89-cb75ff17dd77",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cpu\n",
      "checkpoint directory created: ./model\n",
      "saving model version 0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "| train_loss: 4.67e-04 | test_loss: 4.83e-04 | reg: 7.60e+00 | : 100%|█| 50/50 [00:08<00:00,  5.79it"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "saving model version 0.1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "from kan import *\n",
    "\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "print(device)\n",
    "\n",
    "# create a KAN: 2D inputs, 1D output, and 5 hidden neurons. cubic spline (k=3), 5 grid intervals (grid=5).\n",
    "f = lambda x: torch.exp(torch.sin(torch.pi*x[:,[0]])+x[:,[1]]**2)\n",
    "dataset = create_dataset(f, n_var=2, train_num=1000, device=device)\n",
    "model = KAN(width=[2,1,1], grid=10, k=3, seed=0, device=device, base_fun='identity')\n",
    "results_linear = model.fit(dataset, opt=\"LBFGS\", steps=50, stop_grid_update_step=20, lamb=0.00);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "f82505ab-2b82-435d-8f18-ead1232e3c92",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZcAAAFICAYAAACcDrP3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAuPklEQVR4nO3daVRUd57/8c/vVrEUFgIirriBtBuIyqpo1KhgpI22ZrLY6R5jcsbYiZpMT5v9JDExOXYnozDdTmd0clrTOnYiGqMQMeOCKCqIgooCKi4DiGKkEKiiqOX+H0TqL4lRlAu3qvi8zvFJSoqvhp/vuruQZVkGERGRgiS1ByAiIvfDuBARkeIYFyIiUhzjQkREimNciIhIcYwLEREpjnEhIiLFMS5ERKQ4xoWIiBTHuBARkeIYFyIiUhzjQkREimNciIhIcYwLEREpjnEhIiLFadUegMgVyLKM77//HvX19dDr9QgMDIQQQu2xiJwWt1yI7sFgMCAlJQVhYWEICgrCoEGDEBQUhLCwMKSkpMBgMKg9IpFTEnwSJdHdZWZmYu7cuTAajQB+2Hpp1rzV4uPjg7S0NCQlJakyI5GzYlyI7iIzMxPJycmQZRl2u/1nf58kSRBCID09nYEhugPjQvQjBoMBwcHBMJlM9wxLM0mSoNPpUF5eDn9///YfkMgF8JgL0Y+sX78eRqOxVWEBALvdDqPRiA0bNrTzZESug1suRHeQZRlhYWEoKyvDgywNIQRCQkJw7tw5nkVGBMaFqIUbN24gKCioTV8fGBio4ERErom7xYjuUF9f36avr6urU2gSItfGuBDdQa/Xt+nrfX19FZqEyLUxLkR3CAwMRGho6AMfNxFCIDQ0FN26dWunyYhcC+NCdAchBBYvXvxQX7tkyRIezCe6jQf0iX6E17kQtR23XIh+xN/fH2lpaRBCQJLuvUSar9DfunUrw0J0B8aF6C6SkpKQnp4OnU4HIcRPdnc1/zedToeMjAwkJiaqNCmRc2JciH5GUlISysvLsXr1aoSEhLR4LSQkBKtXr0ZFRQXDQnQXPOZC1AqyLGPfvn2YMmUK9uzZg8mTJ/PgPdE9cMuFqBWEEI5jKv7+/gwL0X0wLkREpDjGhYiIFMe4EBGR4hgXIiJSHONCRESKY1yIiEhxjAsRESmOcSEiIsUxLkREpDjGhYiIFMe4EBGR4hgXIiJSHONCRESKY1yIiEhxjAsRESmOcSEiIsUxLkT3YbFYUFFRgbNnzwIALly4gJs3b8Jut6s8GZHz4mOOiX6GwWBAWloaNm7ciKKiItTV1aGpqQne3t4ICgrChAkT8PzzzyMhIQFarVbtcYmcCuNCdBeHDx/Gq6++ipMnTyImJgbJyckYOXIk9Ho9DAYD8vPzsWPHDpw/fx5PPfUUPvzwQwQFBak9NpHTYFyIfmT37t2YP38+9Ho9Pv74Y8yYMQNNTU3YvHkzzGYzunbtiqeffhoWiwWbN2/Ge++9hxEjRuCLL75Az5491R6fyCkwLkR3KC0txfTp09GlSxds3rwZw4cPhxACZWVlGDNmDGprazFo0CDk5+cjICAAsizj4MGDmDdvHiZNmoR169bBy8tL7T8Gkep4QJ/oNpvNho8++gg1NTX485//7AjLvQghMH78ePzxj3/E9u3bsWvXrg6alsi5MS5Et50/fx47duzAnDlzMH78+PuGpZkQArNnz0Z8fDzWrl0Lq9XazpMSOT+e4kJ0W05ODurr6zF37lxcunQJDQ0NjtfKy8ths9kAAE1NTSgqKkLXrl0dr/fp0wdz5szBe++9h6qqKgQHB3f4/ETOhHEhuq24uBg+Pj4ICQnBwoULcejQIcdrsizDbDYDACorKzFt2jTHa0IIfPrpp4iIiIDRaERlZSXjQp0e40J0m8lkglarhZeXF8xmMxobG+/6+2RZ/slrVqsVOp2uRYSIOjPGhei2Hj16wGQywWAwIC4uDl26dHG8ZjKZkJOT44jIuHHjHBdOCiHQv39/XL9+HZIkISAgQK0/ApHTYFyIbouKioLFYkFubi5WrlzZ4rWysjLExMSgtrYWPXv2xD/+8Q/4+/s7XhdC4M0330SvXr24S4wIPFuMyCE2NhYhISFYv349GhoaoNFoWvxqJoSAJEmO/y5JEq5evYotW7YgOTkZfn5+Kv4piJwD40J0W2BgIF5++WUcP34cqamprT6l2Gw244MPPoDJZMLChQtbfQozkTvjbjGiO8yfPx8HDhzAypUr4ePjg0WLFsHb2xsAoNVqodVqHVsxsiyjrq4OK1aswObNm7Fq1SoMGTJEzfGJnAZv/0L0I9XV1XjppZewc+dOJCUl4dVXX8WwYcNQUlICu90OT09PDB48GLm5ufjkk09QUFCA5cuXY9GiRS12nxF1ZowL0V00NDRg7dq1SE1NxbVr1xASEoKwsDD4+vqipqYGJSUlqKysRFRUFN59911MnDgRksS9zETNGBeie6iqqsKePXuQlZWFwsJC5ObmYsKECUhISEBiYiLi4uLg4+Oj9phETodxIWqlvLw8xMbGIi8vD9HR0WqPQ+TUuB1P1EoajcZxGjIR3RtXCRERKY5xISIixTEuRESkOMaFiIgUx7gQEZHiGBciIlIc40JERIpjXIiISHGMCxERKY5xISIixTEuRESkOMaFiIgUx7gQEZHiGBciIlIcn+dC1EqyLMNut0OSJAgh1B6HyKlxy4XoAfBZLkSto1V7ACIlWCwWXLlyBXa7Xe1R2kwIgf79+8PT01PtUYgeGuNCbqG8vBy/+93vEBUV5QiMq25l5OfnY82aNQgNDVV7FKKHxriQW5BlGREREYiLi8OmTZswY8YM/Pa3v1V7rIfy+uuvg4dCydUxLuRWvv76a2zZsgUGgwHPPPOMy+1aYlTIXbjmfgOiuxBCYPbs2dBoNDh27BguXryo9khEnRbjQm5l7Nix6Nu3LwwGAzIzM7klQKQSxoXcSvfu3TFlyhQAwLZt29DU1KTyRESdE+NCbkUIgSeeeAJarRb5+fkoLi5WeySiTolxIbcTHx+P0NBQNDQ04Ouvv+auMSIVMC7kdvz8/DBz5kwAP+waq6urU3kios6HcSG307xrzMfHB8XFxTh8+DC3Xog6GONCbikiIgIxMTGwWCzYuHGjW9wWhsiVMC7klry8vDBv3jwIIbB7925cvnxZ7ZGIOhXGhdySEALJycno27cvqqurkZaWxl1jRB2IcSG31bNnT/zqV78CAGzcuBG3bt1SeSKizoNxIbclhMBvfvMb6PV6nDlzBt999x23Xog6CONCbksIgZEjR2Ly5Mmw2WxYu3Ytr9gn6iCMC7k1rVaLf/mXf4GHhwcOHjyInJwcbr0QdQDGhdyaEAKTJk1CbGwsGhsbsWbNGlitVrXHInJ7jAu5PZ1Oh5deegkajQaZmZnIy8vj1gtRO2NcyO0JITBjxgyMGTMGDQ0NWL16NbdeiNoZ40Kdgl6vx9KlS6HVapGRkYFDhw5x64WoHTEu1CkIITBz5kzExcXBZDJh5cqVaGxsVHssIrfFuFCn0aVLFyxbtgxeXl7Yt28fduzYwa0XonbCuFCnIYTAtGnT8Nhjj8FisWDFihW4ceOG2mMRuSXGhToVT09PvPXWWwgICEBRURFSU1N5x2SidsC4UKcihMCoUaOwaNEiAMCaNWtw9OhR7h4jUhjjQp2OJElYunQpIiMjYTAY8Prrr6O2tlbtsYjcCuNCnVJgYCA+/vhj6PV6HDp0CJ988glsNpvaYxG5DcaFOiUhBKZMmYKXXnoJAJCamoqMjAzuHiNSCONCnZZGo8GyZcswceJENDQ04JVXXkFxcTEDQ6QAxoU6NT8/P6SmpqJ///64dOkSXnzxRVRXVzMwRG3EuFCnJoTA8OHDkZqaCl9fXxw8eBCLFy9GfX292qMRuTTGhTo9IQSSk5Px4YcfwtPTE1u3bsUf/vAHGI1GtUcjclmMCxF+OD154cKF+MMf/gBJkvD555/jjTfegNFo5C4yoofAuBDd5uHhgTfffNNxBtl//ud/4ve//z3q6+sZGKIHxLgQ3cHb2xsrVqzAyy+/DCEE1q1bhxdeeAHXr19nYIgeAONC9CM6nQ4fffQRXnvtNWi1WmzZsgVPPPEEioqKGBiiVmJciO7C29sb77zzDj799FN07doVOTk5SE5OxldffQWLxcLIEN0H40L0Mzw8PPDiiy9i06ZNCAkJQXl5OZ577jksWbIElZWVDAzRPTAuRPcgSRKmT5+Ob7/9FjNnzoTFYsF//dd/YcqUKdi0aRPPJiP6GYwL0X0IIRAaGoqNGzfik08+Qc+ePXHu3DksWLAAs2bNwv/+7//CbDYzMkR3YFyIWkEIgS5dumDx4sXYs2cPnnrqKWi1WuzduxezZs3C3Llz8e2336KhoYGRIQLjQvRAhBAYOnQo1q9fj6+//hqPPvoo7HY7vv32W8yZMwdTp07FZ599hoqKCtjtdoaGOi3GhegBCSHg4eGBqVOn4ptvvkFaWhqSkpKg1WqRm5uLl19+GbGxsViwYAHS09Nx48YNhoY6Ha3aAxC5KiEEdDodZsyYgWnTpiE/Px9/+9vfkJ6ejqqqKnzxxRfYtGkT+vbti/HjxyMpKQlxcXEIDg6Gt7e34z2I3BHjQtRGQgh4enoiPj4ecXFxuHr1KjIzM/HVV18hNzcXV65cwaZNm/A///M/8PX1RWhoKKKiohAXF4fw8HAMGDAA/v7+8PT0VPuPQqQYxoVIIUIICCHQt29fPPfcc/jNb36Dy5cvIysrC7t27UJeXh6qqqpw4sQJnDhxAuvWrYOnpyf8/f0xcOBAjBo1CsnJybDb7Wr/UYjajHEhagfNx2UGDx6M0NBQzJ8/HzU1NThz5gyOHj2Ko0ePoqioCFevXsWNGzdw/fp15ObmorGxEUFBQWqPT9RmjAu5HWc8cC5JEgIDAzFhwgRMmDABsiyjoaEB165dw7lz51BYWIgjR45gxowZOHbsmNrjErUZ40JuQQiBU6dO4f3331d7lIc2cuRInDx5EoWFhTzQTy5PyM74MY/oATU1NaGsrAw2m03tUdpMkiSEhobyAD+5NMaFiIgUx91iRK105+cw7rYiujdeoU/USidOnIBGo8GJEyfUHoXI6TEuRESkOMaFiIgUx7gQEZHiGBciIlIc40JERIpjXIiISHGMCxERKY5xISIixTEuRESkOMaFiIgUx7gQEZHiGBciIlIc40JERIpjXIiISHGMCxERKY5xIWoFWZZRU1MDAKipqQEf4Ep0b4wL0T0YDAakpKQgLCwMU6dOhSzLmDp1KsLCwpCSkgKDwaD2iEROScj8CEZ0V5mZmZg7dy6MRiOAuz/m2MfHB2lpaUhKSlJlRiJnxbgQ3UVmZiaSk5MhyzLsdvvP/j5JkiCEQHp6OgNDdAfGhehHDAYDgoODYTKZ7hmWZpIkQafToby8HP7+/u0/IJEL4DEXoh9Zv349jEZjq8ICAHa7HUajERs2bGjnyYhcB7dciO4gyzLCwsJQVlb2QGeECSEQEhKCc+fOOY7HEHVmjAvRHW7cuIGgoKA2fX1gYKCCExG5Ju4WI7pDfX19m76+rq5OoUmIXBvjQnQHvV7fpq/39fVVaBIi18a4EN0hMDAQoaGhD3zcRAiB0NBQdOvWrZ0mI3ItjAvRHYQQWLx48UN97ZIlS3gwn+g2HtAn+hFe50LUdtxyIfoRf39/pKWlQQgBSbr3Emm+Qn/r1q0MC9EdGBeiu0hKSkJ6ejp0Oh2EED/Z3dX833Q6HTIyMpCYmKjSpETOiXEh+hlJSUkoLy/H6tWrERIS0uK1kJAQrF69GhUVFQwL0V3wmAtRK8iyjH379mHKlCnYs2cPJk+ezIP3RPfALReiVhBCOI6p+Pv7MyxE98G4EBGR4hgXIiJSHONCRESKY1yIiEhxjAsRESmOcSEiIsUxLkREpDjGhYiIFMe4EBGR4hgXIiJSHONCRESKY1yIiEhxjAsRESmOcSEiIsUxLkREpDjGhYiIFMe4EN2HxWJBRUUFzp49CwC4cOECbt68CbvdrvJkRM6Ljzkm+hkGgwFpaWnYuHEjioqKUFdXh6amJnh7eyMoKAgTJkzA888/j4SEBGi1WrXHJXIqjAvRXRw+fBivvvoqTp48iZiYGCQnJ2PkyJHQ6/UwGAzIz8/Hjh07cP78eTz11FP48MMPERQUpPbYRE6DcSH6kd27d2P+/PnQ6/X4+OOPMWPGDDQ1NWHz5s0wm83o2rUrnn76aVgsFmzevBnvvfceRowYgS+++AI9e/ZUe3wip8C4EN2htLQU06dPR5cuXbB582YMHz4cQgiUlZVhzJgxqK2txaBBg5Cfn4+AgADIsoyDBw9i3rx5mDRpEtatWwcvLy+1/xhEquMBfaLbbDYbPvroI9TU1ODPf/6zIyz3IoTA+PHj8cc//hHbt2/Hrl27OmhaIufGuBDddv78eezYsQNz5szB+PHj7xuWZkIIzJ49G/Hx8Vi7di2sVms7T0rk/HiKC9FtOTk5qK+vx9y5c3Hp0iU0NDQ4XisvL4fNZgMANDU1oaioCF27dnW83qdPH8yZMwfvvfceqqqqEBwc3OHzEzkTxoXotuLiYvj4+CAkJAQLFy7EoUOHHK/Jsgyz2QwAqKysxLRp0xyvCSHw6aefIiIiAkajEZWVlYwLdXqMC9FtJpMJWq0WXl5eMJvNaGxsvOvvk2X5J69ZrVbodLoWESLqzBgX6vQuXryI/fv3Izs7G0ajEQaDAXFxcejSpYvj95hMJuTk5DgiMm7cOMeFk0II9O/fH9evX4fNZkN5eTnMZjPPGqNOjaciU6dz5coVZGVlYd++fdi/fz8uX74MIQQGDRqEixcv4i9/+QteeOGFFl9TVlaGmJgY1NbWYuDAgTh27Bj8/f0drwsh8OabbyIlJQWDBg2CTqdDZGQkYmJiEBsbi4iICHh6enbwn5RIPYwLub2Kigrs37/f8ausrAwAEBkZiYkTJ2Ly5MmYMGEC7HY7xo8fj4CAAOzatavFAfufu84F+GE3WWVlJSZOnIiZM2di4cKFyMvLQ15eHo4dO4a6ujp4eXlh1KhRjtiEh4fDw8NDlb8Poo7AuJDbqaqqahGTc+fOAQDCw8MdMXnkkUcQGBj4k6/9y1/+gt///vd4++238frrrzt2fd0rLo2NjXjllVewY8cO7N27F0OGDHG8n91uR0lJCfLy8pCbm4v8/HzU19fD29sbo0ePRmxsLGJjYzF8+HDen4zcCuNCLu/69evIyspyxKS4uBgAMGzYsBYx6dGjx33fq6GhAQsWLEBGRgbef/99LFq0CN7e3rh48SJiY2Mdu8Vyc3Ph7++Puro6rFixAp999hlWrVqF55577p7vb7PZcPbsWeTm5iIvLw/Hjx+H0WiEj48PxowZ49iyGTZsGDQajSJ/P0RqYFzI5dy4cQMHDhxwxKSoqAgA8Itf/MIRk4kTJ6JXr14P9f7V1dV46aWXsHPnTiQlJeHVV1/FsGHDUFJSArvdDk9PTwwePBi5ubn45JNPUFBQgOXLl2PRokUPHASr1YozZ860iE1jYyP0ej3GjBnj2LIZMmQIJInXPJPrYFzI6dXU1ODAgQPYt28fsrKycPLkSQBAaGhoi5j07dtXse/Z0NCAtWvXIjU1FdeuXUNISAjCwsLg6+uLmpoalJSUoLKyElFRUXj33XcxceJERf7xt1gsOH36tGM3WkFBAcxmM3x9fREdHe3YsgkLC2NsyKkxLuR0amtrkZ2d7YhJQUEBZFnGwIEDMWnSJMevfv36tfssVVVV2LNnD7KyslBWVobGxkYEBAQgPDwciYmJiIuLg4+PT7t9/6amJpw6dcoRm8LCQjQ1NcHPzw/R0dGOLZvQ0NBW366GqCMwLqS6uro6HDx40LGb6/jx47Db7QgODsakSZMwefJkTJo0CQMHDlR1TpvNBlmWIUmSalsNZrMZhYWFjticPHkSVqsVAQEBiImJcWzZDBo0iLEhVTEu1OHq6+uRk5Pj2DI5duwYbDYb+vTp02LLJCQkhP9A3kdjYyMKCgocsTl16hRsNhsCAwMdoYmNjUX//v35d0kdinGhdmc0GnH48GFHTHJzc2G1WtGzZ88WMQkLC+M/gG1kNBpRUFDgOEHg9OnTsNvt6NGjR4vdaMHBwfy7pnbFuJDiGhsbceTIEUdMjhw5AovFgqCgIEycONERk6FDh/IfuHZWX1/viE1ubi7Onj0Lu92OXr16tdiy6dOnj9qjkpthXKjNzGYzjh496jhmcuTIEZjNZnTr1q1FTEaMGMGYqKyurg75+fmOOwgUFxdDlmX06dOnRWwe9jRuomaMCz2wpqYm5OXlYf/+/di3bx8OHz6MxsZG+Pv745FHHnHEJCIigqfLOrna2locP37csWVTWloKAAgODnaEJiYmplUXoBLdiXGh+7JYLMjPz3fEJCcnB0ajEV27dsWECRMc15lERkbyqnIXV1NTg/z8fMcxm/PnzwMABgwY4NiyiYmJQffu3VWelJwd40I/YbVaceLECUdMDh06hPr6euj1eowfP96xZTJ69GjeD8vN3bx5E8eOHXNs2Vy8eBEAMGjQoBZbNs33WSNqxrgQbDYbCgsLHTE5ePAgbt26BR8fHyQkJDi2TKKiongn306uurraEZu8vDxcvnwZADB48GDHlk10dHSLxxFQ58S4dEJ2ux2nTp1yxCQ7OxsGgwHe3t4YN26cIyYxMTF8Bgnd0/Xr1x3X2OTm5qK8vBzAD/d5a96yiYqKavH4AuocGJdOQJZlFBUVOWJy4MAB3Lx5E15eXoiPj3fEJC4ujk9PpDa5evWqIzZ5eXmorKyEEAJDhw51bNlERUVBr9erPSq1M8bFDcmyjOLi4hYxqa6uhoeHB+Lj4x3HTOLj4+Ht7a32uOTGKioqWmzZXLt2DZIkYdiwYY4tm9GjR7d4pDS5B8bFDciyjHPnzjlikpWVhWvXrkGr1SI2NtYRk7Fjx7brTRaJ7kWWZZSXlztCk5eXh+rqakiShPDwcMeWzejRo6HT6dQel9qIcXFBsiyjrKysRUwqKyuh0WgQHR3tuNnj2LFjufuBnJYsy7hy5UqL2Hz//ffQaDSIiIhwbNlERkZyC9sFMS4u4tKlSy1i8n//93+QJAljxoxxxGTcuHE8cEouS5ZlXLx40RGavLw81NTUwMPDwxGbmJgYREZG8tigC2BcXMTw4cNRWlqKUaNGOWKSkJDAUz7JbdntdpSVlTm2bI4dO4ba2lr86U9/wvTp09Uej+6DcXERzf+beG8u6qxkWUZTUxO0Wi3vBOECGBciIlIc792hAIvFgitXrsBut6s9SpsJIdC/f39ePEkPxGKxoKqqym3WQO/evXk3ijZiXBRQXl6O3/3ud4iKilJ7lDbLz8/HmjVrEBoaqvYo5EKuXbuGDz74ACNGjFB7lDYrKirCO++8g379+qk9iktjXBQgyzJGjhyJFStWtOr3W61WHDlyBDt37kRNTQ2io6Mxe/ZsBAUFtfOk9/f666+De0rpYQwZMgRLlixR/H2b72dWVFSEW7duwd/fHxEREYiKikK3bt0U/36rVq3iGlAA46Kwex1wl2UZdXV1eOedd/Df//3fMJlMAIDPP/8ca9aswWeffYbY2FjVDtpzQZESlPj5bV4rmzdvxldffYXr16+3+PmUJAm9evXCM888gyeeeAI+Pj6KfV9SBuPSgUwmE5YuXYovvvgCkiQhLi4OwcHB2LdvH06dOoV58+Zh+/btfGIjdWrN17ssX74cJ06cgCzLCAwMxLBhwxAYGIjq6mqcPXsWlZWVWLVqFQ4fPoy3334bffv25bpxIoxLB7Hb7UhNTcXGjRuh1WqxbNkyLFu2DD4+Pjhy5AieffZZXLp0CUuXLsW2bdt4MSR1SrIs4+zZs3jttddw+fJldOnSBU899RSefPJJ9OzZE5IkwWaz4erVq9i4cSO2bt2KnJwcvPLKK1i5ciVCQkIYGCfBZ9B2AFmWkZeXhz/96U+w2+14/vnn8dZbb0Gv10OSJIwdOxapqanw8fHBgQMHsH79em6eU6cjyzIuXbqEN954A5cvX0aPHj2wcuVKLF68GH369IFGo4EQAlqtFv369cO//du/4YMPPkBAQABKS0vxxhtvoLKykmvHSTAuHaCxsRHLly+HwWBAZGQk3nvvvRa3rxBCYPr06Xj22Wdht9uRkpKCq1evqjgxUceSZRm1tbVYvnw5Ll68iKCgIKxcuRITJkz42QsmtVotEhMTsWLFCvj7+6O4uBgffvghGhoaOnh6uhvGpZ3Jsoxdu3Zhz5498PT0xLvvvnvX549rNBr867/+K3r27IlLly5hw4YN/ARGnYbNZsNf//pXHD9+HD4+Pnj77bcxZsyY++7iEkIgISEBr732Gry9vXH48GF8/vnnsNlsHTQ5/RzGpZ2ZTCakpKTAYrFg2rRpSEpKuuuCEUIgNDQU8+bNgyzL+Nvf/obvv/9ehYmJOpYsy8jOzsbWrVshhMCCBQvwyCOPtPrYiRACSUlJjrWzadMmHDt2jB/OVMa4tCNZlpGVlYWjR4/Cy8sLS5cuveeV75IkYcGCBQgICMCFCxeQnp7OBUJu7+bNm/iP//gPNDY2Ii4uDr/+9a8f+N5hWq0WCxYswKhRo2A0GpGSkoK6urp2mphag3FpR1arFevWrUNTUxPGjx+PhISE+34aGzJkCBITE2G327F+/XqYzeYOmpao49ntdmzevBkXLlyAn58fli5d+tAPtPP19cXSpUuh1+tRVFSEtLQ0fjhTEePSjoqLi7F3715oNBq88MILrXoGhSRJmD9/Pjw8PJCbm4vCwkIuEHJLzWeHffnllwCAJ598EkOHDn3oU4mFEIiMjMSsWbMgyzI2btyIiooKJUemB8C4tBNZlvGPf/wDt27dwuDBgzFt2rRWLRohBMaOHYvhw4fDZDI5Fh6Ru7Hb7diwYQNqamrQv39/PPPMM5Cktv2TpNFo8Nvf/ha9e/fG9evXsXHjRre4maYrYlzaSW1tLbZt2wYAmDt37gM91Euv12Pu3LkA4Lj/GJE7kWUZJSUl2L17NyRJwq9//WsEBgYq8t69evXC008/DSEE0tPTcenSJW79q4BxaQeyLCMnJwfnz5+HXq/HE0888UCb+kIIzJ49G76+vrh48SIOHjzIxUFupflYS319PUJCQvDYY48pdmW9EAKPP/44+vfvD4PBgC+//JLrRwWMSzuQZRlbtmyB1WpFdHQ0hg4d+sDvERYWhtjYWNhsNh6YJLfSfO+wPXv2QJIkPP3004rf7qhbt26OD3XffvstysvLFX1/uj/GpR1UV1dj7969AH7YJfYwD97y8PDAr371KwghsG/fPly/fl3pMYlUIcsytm3bhrq6OvTr16/VxyMfhBACM2bMQO/evVFTU4NvvvmGH9A6GOOiMFmWcfDgQVRUVCAgIACJiYkPtXCEEEhMTERAQACuXr2K7OxsLg5yC9XV1cjMzAQAzJo164GORz6I7t27Izk5GQCQnp6Omzdvtsv3obtjXBQmyzK++eYb2O12xMTEYMCAAQ/9Xv3790dcXBzsdju+/vprnvVCLk+WZXz33Xeorq5G9+7dFT3W8mNCCMycORN+fn6orKxEVlYWP6B1IMZFYTdv3kR2djYA4Je//CW02od/qoFWq8WsWbMghEB2djaqq6uVGpNIFSaTCTt27IAsy5g8eTJ69+7drt+vX79+mDBhAmRZxvbt23lRcgdiXBR27NgxVFRUoGvXrnj00Ufb9KlMCIFHH33UsWvs0KFD/ORFLkuWZRQUFODcuXPw9vbG448/3u7PXpEkCbNmzYKHhwfOnDmDM2fOcA11EMZFYbt27YLVakV4eDhCQkLa/H79+/dHTEwM7Ha74xMfkSuy2+3YuXMnrFYrRowY0aar8VtLCIGIiAgMGTIEZrMZGRkZXEMdhHFRUENDA/bv3w8ASExMfKizxH5Mq9Xil7/8JQDgwIED7XKnZKPRCJPJpPj7Et3p2rVrOHz4MIQQSE5OVmR9tIZOp8Njjz0GAMjKyuLdxjsI46Kg0tJSnD9/Hl5eXpgyZYoin8qEEJgyZQr8/PxQXl6O3NxcRT95ybKM1NRUjB8/3vGkTCKlNZ9FefPmTXTv3h0TJkzosMcRCyEwadIk+Pv7o7q6GocPH+bWSwdgXBSUlZUFk8mEAQMGYMSIEYq976BBgzBq1CjYbDbs2LFDsfcFAIvFgt27d6OgoACVlZV8/ji1i+afM1mWER8fj6CgoA79/n369EF0dDTsdjsyMzNhtVo79Pt3RoyLQux2O/Lz86HRaDBu3Dj4+voq9t4eHh6O8/X37dsHg8Gg2HtXVlbi9OnTkCQJkydPZlyoXVy+fBmnT5+GRqPB9OnTO/znTJIkTJ8+HZIkoaCggHdL7gCMi0IkScKqVauwc+dOLF68WNHF03xBpV6vx+XLl5Gfn6/I+8qyjLy8PNTU1KB79+6IiopS5H2J7iTLMvbv3w+j0Yjg4GBERkZ2eFyEEIiKikLPnj1RV1fH+/V1AMZFQd27d0diYiJGjRql+OIJCwtDeHg4LBaLok+o/O6772C32xEZGYmePXsq8p5EdzKbzY4TXRISEhTdqn8QAQEBiI+PBwDs3bsXFotFlTk6C8bFRXh5eWHGjBkAfgiCEo9wraurw6FDhwAAU6dObdMFn0Q/p6ysDOfOnYOHhwemTJmi2hxCCEydOhUajQZnz57FlStXVJulM2BcXIQQAklJSdDpdLhw4QIKCwvb/J5FRUW4ePEidDodJk+erMCURC3Jsozs7Gw0NjaiX79+GDZsmGrH9ZqveenduzcaGhqQk5PDXWPtiHFxIcOHD8fw4cPR1NSEnTt3tmlhyLKM3bt3w2w2Y/DgwRgyZIiCkxL9wGw248CBAwCAcePGoUuXLqrO07VrV8TFxQH44exOnjXWfhgXF3LnxWC7du1CfX39Q7+X2WzG7t27AQBTpkxRfdGTe7py5QrOnz8PrVaLiRMnqj2O45qX5l1jPGus/TAuLqT5ymadTofS0lIUFBQ89HuVlpbi1KlT8PDwcBzLIVKSLMs4fPgwTCYT+vTpo+ousWZCCISHhyMoKAj19fWKX5RM/x/j4mLCw8Mdu8a2b9/+UAtDlmVkZmaioaEBAwYMwJgxY1Rf9OR+rFar4w7h0dHR0Ov1Kk/0g4CAAIwZMwYAkJ2dDZvNpvJE7olxcTE6nQ4zZ84EAGRkZKC2tvaB38NsNmP79u0AgGnTprXbw5qoc7t27RpKSkogSRIeeeQRp/kAI4RwzHP69Gnea6ydMC4upvkBSF26dMGFCxdw9OjRB956KSoqQmFhoeNRykRKk2UZJ06cwK1btxAYGIiIiAiniktkZCT8/PxQU1ODkydPctdYO2BcXNCwYcMQFRUFq9WKL7/88oEWhizL2Lp1K4xGI37xi18gJibGaRY9uY/mG1XKsowRI0agW7duao/UQo8ePTB06FDY7XbHtV6kLMbFBXl6euKf/umfIITA7t27cfXq1VZ/rcFgwLZt2wAAs2fPVu1qaXJvt27dclyLlZCQAElyrn9qtFotxo0bBwA4fvw4GhoaVJ7I/TjX/3FqleazxoKCgnD16tVWPwBJlmXs2bMH58+fh6+vryNQREorLS3F9evX4ePjg6ioKKf7ORNCIDY2Fl5eXqisrERZWZnaI7kdxsVFBQcHIykpCbIsY8OGDa162FdTUxM+//xz2Gw2TJo0CUOHDu2ASamzkWUZR44cgdVqxcCBAxEcHKz2SHc1YMAABAcHo6mpCXl5eTzuojDGxUVJkoR//ud/hpeXF/Lz8+97K4vmOyAfOHAAWq0WCxYs4L3EqF1YLBbk5eUB+OEUZC8vL5UnujsfHx+MHj0aAHD06FFera8wxsVFCSEQHx+P2NhYmM1mfPbZZ/dcHFarFampqTCZTBgzZgweffRRp9tVQe6hqqoKZWVl0Gg0iI+Pd+qfs7Fjx0KSJJSUlODmzZtqj+NWGBcX5u3tjRdffBEajQa7du362dOSm28emJGRAY1Gg8WLF/N2L9RuTp8+jfr6egQEBDj1PeuEEBg+fDi6du2K2tpanDlzRu2R3Arj4sKaD+xHRUXBaDRi5cqVaGxs/Mnvu3XrFt5//32YTCaMHTsWjz/+uFN/miTXJcuy40POkCFDEBAQoPZI99SjRw+EhobCbrcjNzdX7XHcCuPi4vR6PZYtWwZPT0/s3r0bf//731tsvVitVvz7v/87cnJy0KVLF7zzzjvcaqF2YzKZcPLkSQBAbGwsNBqNyhPdm1arRXR0NADgxIkTMJvNKk/kPhgXFyeEwIwZMzB37lxYrVa89dZbyMjIgM1mg9lsxl//+ld8+umnkGUZCxcuxKRJk7jVQu2mvLwcFRUV8PT0dIl71gkhEB0dDY1GgytXrqCqqkrtkdwGTxdyA56envj4449x9uxZFBQU4Nlnn0ViYiJqa2uRlZWFpqYmJCcn46233uIZYtSuCgsL0djYiODgYAwcOFDtcVpl8ODBCAwMRHV1NYqKitQex21wy8UNCCEQHByMv//97xg7dizq6uqwZcsWfPfdd5BlGU8++STWrVsHPz8/tUclNybLMo4fPw7ghwfbucrdH/z8/BAWFuY4XZ/XuyiDH2MVpuYP5tChQ7Fjxw5s27YN2dnZjoeLTZs2zXGtARcOtRchBJ577jmEh4dj4MCBEEK4xM+bRqPB5MmT4e3tjZiYGBQXF6s9kltgXBQghMCpU6fw/vvvqz2Kw4ABAwAA+fn5yM/Pb/XXFRYWOv1+cnJOpaWl2LNnDwDg5MmTjgP7rsBmsyE0NBSXL19GaWkp14AChOwKHy2cXFNTE8rKytzioUOSJCE0NBSenp5qj0IuxGKxoLy83G3WQL9+/eDh4aH2KC6NcSEiIsXxgL6LkGXZ8Yuos7Lb7WhsbITdbld7FLoPxsVFnDhxAlqtFidOnFB7FCLVlJSUICYmBiUlJWqPQvfBuBARkeIYFyIiUhzjQkREimNciIhIcYwLEREpjnEhIiLFMS5ERKQ4xoWIiBTHuBARkeIYFyIiUhzjQkREimNciIhIcYwLEREpjnEhIiLFMS5ERKQ4xsUFyLKMmpoaAEBNTQ0fGEadUvM6sFgsXAcugHFxYgaDASkpKQgLC8PUqVNht9sxdepUhIWFISUlBQaDQe0RidrdnesgISEBJSUlSEhI4DpwckJm/p1SZmYm5s6dC6PRCAAtPqUJIQAAPj4+SEtLQ1JSkiozErU3rgPXxbg4oczMTCQnJ0OW5Xs+K1ySJAghkJ6ezoVFbofrwLUxLk7GYDAgODgYJpPpnguqmSRJ0Ol0KC8vh7+/f/sPSNQBuA5cH4+5OJn169fDaDS2akEBgN1uh9FoxIYNG9p5MqKOw3Xg+rjl4kRkWUZYWBjKysoe6EwYIQRCQkJw7tw5x35oIlfFdeAeGBcncuPGDQQFBbXp6wMDAxWciKjjcR24B+4WcyL19fVt+vq6ujqFJiFSD9eBe2BcnIher2/T1/v6+io0CZF6uA7cA+PiRAIDAxEaGvrA+4uFEAgNDUW3bt3aaTKijsN14B4YFycihMDixYsf6muXLFnCg5jkFrgO3AMP6DsZnt9PxHXgDrjl4mT8/f2RlpYGIQQk6d7/e5qvTN66dSsXFLkVrgPXx7g4oaSkJKSnp0On00EI8ZPN/Ob/ptPpkJGRgcTERJUmJWo/XAeujXFxUklJSSgvL8fq1asREhLS4rWQkBCsXr0aFRUVXFDk1rgOXBePubgAWZZx8+ZN1NXVwdfXF926deNBS+p0uA5cC+NCRESK424xIiJSHONCRESKY1yIiEhxjAsRESmOcSEiIsUxLkREpDjGhYiIFMe4EBGR4hgXIiJSHONCRESKY1yIiEhxjAsRESmOcSEiIsUxLkREpLj/B/NvYGZ+BclNAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 500x400 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model.plot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "554cdb2d-ce7d-4228-a754-119e383fcdb1",
   "metadata": {},
   "outputs": [],
   "source": [
    "### No residue"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "37ce0c71-16d5-40cb-a7e1-d53f49864ade",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cpu\n",
      "checkpoint directory created: ./model\n",
      "saving model version 0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "| train_loss: 4.30e-02 | test_loss: 4.70e-02 | reg: 1.34e+01 | : 100%|█| 50/50 [00:10<00:00,  4.57it"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "saving model version 0.1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "from kan import *\n",
    "\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "print(device)\n",
    "\n",
    "# create a KAN: 2D inputs, 1D output, and 5 hidden neurons. cubic spline (k=3), 5 grid intervals (grid=5).\n",
    "f = lambda x: torch.exp(torch.sin(torch.pi*x[:,[0]])+x[:,[1]]**2)\n",
    "dataset = create_dataset(f, n_var=2, train_num=1000, device=device)\n",
    "model = KAN(width=[2,1,1], grid=10, k=3, seed=0, device=device, base_fun='zero')\n",
    "results_zero = model.fit(dataset, opt=\"LBFGS\", steps=50, stop_grid_update_step=20, lamb=0.00);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "0155263f-ed96-47b8-aa8f-0d399178f7a8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7fd068b5dc70>]"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiMAAAGdCAYAAADAAnMpAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABOm0lEQVR4nO3deXhU5d3/8feZNQskZIEsEBYFgYIgBGR3F4vWPlafp/SnrbuVuiJuRVu32mJrS9FatyK1Wh7FWrHWgprHBVBA2UU2QcCwJIQkkD2TzMz5/TGZIRMSyDLJyfJ5Xde5ZubkzMw3p1Q+fO/73McwTdNERERExCI2qwsQERGRrk1hRERERCylMCIiIiKWUhgRERERSymMiIiIiKUURkRERMRSCiMiIiJiKYURERERsZTD6gIaw+/3c/DgQbp3745hGFaXIyIiIo1gmiYlJSWkp6djszXc/+gQYeTgwYNkZGRYXYaIiIg0w759++jTp0+DP+8QYaR79+5A4JeJi4uzuBoRERFpjOLiYjIyMkJ/jzekQ4SR4NBMXFycwoiIiEgHc7IpFprAKiIiIpZSGBERERFLKYyIiIiIpRRGRERExFIKIyIiImIphRERERGxlMKIiIiIWEphRERERCylMCIiIiKWanIYWb58OZdeeinp6ekYhsHbb7990vcsW7aMzMxMoqKiOOWUU3j++eebU6uIiIh0Qk0OI2VlZYwcOZJnnnmmUcfv2bOHiy++mClTprBhwwYeeOAB7rjjDv75z382uVgRERHpfJp8b5pp06Yxbdq0Rh///PPP07dvX+bNmwfA0KFDWbt2Lb///e+54oormvr1IiIi0sm0+pyRVatWMXXq1LB9F110EWvXrqW6urre93g8HoqLi8O21vD0G3dw+/zzeeujZ1vl80VEROTkWj2M5ObmkpKSErYvJSUFr9dLfn5+ve+ZM2cO8fHxoS0jI6NVatt0dA2fOPP46sCqVvl8ERERObk2uZqm7q2DTdOsd3/Q7NmzKSoqCm379u1rlboSzCgAjvhbp/MiIiIiJ9fkOSNNlZqaSm5ubti+vLw8HA4HSUlJ9b7H7XbjdrtbuzQSiAbgiL+s1b9LRERE6tfqnZEJEyaQlZUVtu+DDz5gzJgxOJ3O1v76E+phxAJwhHJL6xAREenKmhxGSktL2bhxIxs3bgQCl+5u3LiR7OxsIDDEcvXVV4eOnzFjBt9++y2zZs1i27ZtLFiwgJdeeol77rknMr9BCyQY3QEopNLiSkRERLquJg/TrF27lnPPPTf0etasWQBcc801vPzyy+Tk5ISCCcCAAQNYsmQJd911F3/+859JT0/n6aefbheX9faw9wCgyKim2l+N02Ztp0ZERKQranIYOeecc0ITUOvz8ssvH7fv7LPPZv369U39qlYX64jH4TfxGgaHyw+T3i3d6pJERES6nC59bxq7M5oUrw+A3LLckxwtIiIiraFLhxGc0aR6vYDCiIiIiFW6dBgxXFGk+mo6I+UKIyIiIlbo0mHEps6IiIiI5bp2GHHFklozZ+RQ2SGLqxEREemaunYYcUaHwoiGaURERKzRpcOI3R1Nqk/DNCIiIlbq2mHEFRO6tLewspAqX5XFFYmIiHQ9XTqMOKJi6OH34/YHFnHTvBEREZG217XDiCsGA44N1WjeiIiISJvr0mHEGR24a2+qVmEVERGxTNcOI+4YAFK01oiIiIhlunQYcbsceEzHsbVGyjVnREREpK117TBit+PBpct7RURELNS1w4jTRiUu3blXRETEQl06jLjsNipMl1ZhFRERsVCXDiM2m4HHODZMU+QposJbYXFVIiIiXUuXDiMAVbjo7jeJtrkADdWIiIi0NYURw40B9HR0BxRGRERE2prCiOEGINkWWABNYURERKRtdfkwUl0zPJNsBBZA01ojIiIibUthxIgCIIlAh0SdERERkbbV5cOI1x4IIYl+J6DLe0VERNqawoitZs6I3w7AoTIN04iIiLSlLh9GfLaaYRqfAWiYRkREpK0pjNQM0yT7TABKq0sprSq1siQREZEupcuHEb8jGoCY6mq6u7TWiIiISFtTGKnpjBjeSlJjUwFd3isiItKWunwYMWs6I4avktSYQBhRZ0RERKTtKIw4AhNY7d4KUmJTAF3eKyIi0pa6fBihJozY1BkRERGxhMKIMzBMY/d5QnNGFEZERETaTpcPI0YwjPgrFUZEREQs0OXDSH2dkUPlhzBN08qqREREuowuH0ZsNWHE6feQEhOYwFrhraC4qtjKskRERLoMhRFXTRgxPUQ5okhwJwAaqhEREWkrXT6M2F0xQKAzAmjhMxERkTbW5cOIzR0IIw684PeFhmrUGREREWkbXT6MBDsjAFTXWvhMYURERKRNdPkw4nBH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x8O2bdtIS0trH3+e22SabDv0+uuvm06n03zppZfMrVu3mjNnzjRjY2PNvXv3Wl1ah1VSUmJu2LDB3LBhgwmYc+fONTds2GB+++23pmma5hNPPGHGx8ebb731lrl582bz//2//2empaWZxcXFFlfesfzsZz8z4+PjzU8++cTMyckJbeXl5aFjdK5bbvbs2eby5cvNPXv2mF9++aX5wAMPmDabzfzggw9M09Q5bk21r6YxTZ3rSLj77rvNTz75xNy9e7e5evVq83vf+57ZvXv30N95Vp/jLhtGTNM0//znP5v9+vUzXS6XOXr06NClkdI8H3/8sQkct11zzTWmaQYuH3v44YfN1NRU0+12m2eddZa5efNma4vugOo7x4D517/+NXSMznXLXX/99aH/PvTs2dM8//zzQ0HENHWOW1PdMKJz3XLTp08309LSTKfTaaanp5uXX365uWXLltDPrT7HhmmaZtv0YERERESO1yXnjIiIiEj7oTAiIiIillIYEREREUspjIiIiIilFEZERETEUgojIiIiYimFEREREbGUwoiIiIhYSmFERERELKUwIiIiIpZSGBERERFLKYyIiIiIpf4/IMFGg8hCsPUAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot([1.0] + results_silu['train_loss'])\n",
    "plt.plot([1.0] + results_linear['train_loss'])\n",
    "plt.plot([1.0] + results_zero['train_loss'])\n",
    "plt.xlabel('steps', fontsize=15)\n",
    "plt.ylabel('Train RMSe', fontsize=15)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0224d8ff-0066-434c-894d-78d56f0130f3",
   "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
}
