{
 "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": 41,
   "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: 8.78e-03 | test_loss: 8.87e-03 | reg: 8.38e+00 | : 100%|█| 10/10 [00:02<00:00,  4.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=5, k=3, seed=0, device=device, base_fun='silu')\n",
    "results_silu = model.fit(dataset, opt=\"LBFGS\", steps=10, stop_grid_update_step=20, lamb=0.00);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "6fa03398-fff9-4ab0-ae25-2c7472edfcce",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "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": 43,
   "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: 8.13e-03 | test_loss: 9.15e-03 | reg: 7.61e+00 | : 100%|█| 10/10 [00:02<00:00,  4.64it"
     ]
    },
    {
     "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=10, stop_grid_update_step=20, lamb=0.00);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "f82505ab-2b82-435d-8f18-ead1232e3c92",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "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": 45,
   "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: 5.05e-01 | test_loss: 5.52e-01 | reg: 1.31e+01 | : 100%|█| 10/10 [00:02<00:00,  4.61it"
     ]
    },
    {
     "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=10, stop_grid_update_step=20, lamb=0.00);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "4c8017c8-93b3-4614-a40c-164fb45c58a2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model.plot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "0155263f-ed96-47b8-aa8f-0d399178f7a8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7fd0688fad90>"
      ]
     },
     "execution_count": 40,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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2QmtwSUi0rC1bt0awzCq/JCaswW7gMrMnDmTsWPHMmXKFAYMGMArr7zC8OHDWbt2LS1btqxw/I8//si1117LM888w3nnnceuXbsYM2YMo0ePZtasWUH4BhU57RYOmJWEnohkNh7YqMHMIiIN1CWXXMK+ffuOesx3333Hjh07aNasWYCqqp9CMvQ8/fTT3HjjjYwePRqAyZMn8/XXX/PSSy8xadKkCsf//PPPtG7dmr///e8AtGnThptuuon//Oc/R/yMoqIiioqKfK+zs7P9/C3K87b0lN6yXjpPD+i2dRGRhu6pp5466v5ffvmFd999F6vVyrvvvhugquqnkOveKi4uZtmyZQwdOrTc9qFDh7Jw4cJK39O/f3927tzJ7NmzMU2TPXv28L///Y9zzz33iJ8zadIkYmNjfY8WLVr49Xv8mdNupQCn98WfWnpAY3pERKSigwcPcvnll1NSUsJDDz3E4MGDg11SnRZyoWffvn243W6SkpLKbU9KSiI9vfJg0L9/f6ZPn87IkSNxOBwkJyfTqFEjnn/++SN+zoQJE8jKyvI9duzY4dfv8WeHj+kxKxvTo9AjIiJ/cuONN7J161ZOO+00HnzwwQr7c3NzmThxIieffDIRERHExMQwePBgPv744wrHbt26FcMwGDJkCNnZ2dx55520adMGu93O2LFjfcetXbuWq666iqZNm+JwOEhJSeHaa69lw4YNtfhNAyMku7eACoO1TNM84gCutWvX8ve//52HHnqIYcOGkZaWxt13382YMWN44403Kn2P0+nE6XT6ve4jcdotFJre7i13cYHvwiv0iIh4maZJgavg2AeGiHBbeK0OLH7++ef56KOPaNKkCdOnT8diKd9OsWfPHk4//XTWrl1LSkoKZ511Fvn5+SxatIiLLrqISZMmcd9991U4b0FBAYMHD2bbtm0MHjyYHj16EBcXB8C3337LeeedR0FBAT169GDIkCGsX7+e//u//2PWrFnMnj2bQYMG1dp3rm0hF3oSEhKwWq0VWnUyMjIqtP6UmTRpEgMGDODuu+8GoGvXrkRGRjJo0CAeffRRmjZtWut1H4vDeuiWdXdxfoXQsyd/z1GDnYhIfVfgKqDPu32CXUaV/XLlL0TYI459YA0sX76cu+++G8MwmDZtWqW/x66//nrWrl3LPffcw6OPPord7v2H9ebNmxk6dCgP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7drFtGnTALjyyiv517/+xfXXX88///lP9u3bx913380NN9xQaddWMDmsFopKb1k3XAVgmnCEbrtg6hDXgfPancenf3zKM8ue4fWhrx+xe1FERKQuqFLoad26dY1/4RmGgctVvbuARo4cyf79+5k4cSJpaWl06dKF2bNn06pVK8C7yOnhQSwqKoq5c+dy++23k5qaSuPGjbnssst49NFHa1RzbbJYDFzWw8YSuYrAHha8go7i1u638uWWL1mcvpiFuxcyIGVAsEsSERGpMcOswvS7FosFwzBo3bo1Doej2h+ybt26GhUXSNnZ2cTGxpKVlXXEwdn+0u2hz1lpucr74t6tEF79CRwD5T9L/sP/rf0/Tow/kZl/mYnFCLkeURERacCq8/u7Si09FosFj8dDVlYWl156KVdffTUDBuhf/TVltTtxuSzYDI93XE9o9cCV89eT/8qsjbNYn7mer7Z8xTltzwl2SSIiIjVSpX+279y5k6eeeopWrVrxyiuvcOqpp9KuXTv+8Y9/sGHDhtqusd4pPytzaN7BVSYuLI7ru1wPwPPLn6fEXRLkikRERGqmSqEnOTmZ8ePHs2zZMtauXcu9996Lx+Phscce46STTiI1NZVnn32WPXv21Ha99UK5O7hCbFbmylzd6WoSwhPYmbuTD37/INjliIiI1Ei1B2iceOKJPP7442zZsoX58+czevRotmzZwrhx42jRogVnn3027733Xm3UWm+Ub+kJ/dATYY9gTFfvnXOvrHqF/BBvnRIREanMcY1KHTRoEK+88grp6el89NFHnHrqqcyZM4c77rjDX/XVS0675dBK667QWoriSC7ucDEto1uSWZjJ22vfDnY5IiIi1Xbct+IUFxfz6aefMm3aNH766ScAwsJC8xbsUFHXWnoA7BY7t/e4HYCpv00lszAzyBWJiIhUT41Dz7x58xg9ejRJSUlcdtllfP7555x22mm88847rF+/3p811jtO22FLUdSRlh6Aoa2GclLjk8h35fPqqleDXY6IiEi1VGvtrVWrVjF9+nRmzJjBrl27ME2T1NRUrr76aq644goSExNrq856xWEL3ZXWj8ZiWBjbYyx/m/s3Zm6YydWdrqZ5dGgt8yEiInIkVQo9//73v5k+fTpr1qzBNE3atm3LAw88wNVXX02HDh1qu8Z6x2k7vHur7oQegH7N+tG3aV9+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r656lfc3vM9fT/4rl594ucYBiYjf1WgQydKlSzn33HPZvn07V155JSeffDIA9913H5deeilxcXEAXH/99Tz00EPVPv/MmTMZO3YsDzzwAMuXL2fQoEEMHz78mPMDZWVlce2113LGGWdU/0sFmNPmvfTFWopCGrBeyb2Yfs50nhnyDK1jWnOw6CBPLn2Sv8z6C59s+gS3xx3sEkWkHqnR3VsjRozg448/5quvvuKss87i+uuvZ9q0abjd3r+gDh48yE033cS8efNYunQpLVq0qNb5+/TpQ48ePXjppZd82zp16sSFF17IpEmTjvi+yy+/nPbt22O1Wvn444+r1dIT6Lu3ft1+gIunLGRZ2C005iCM+RGST671zxUJVS6Pi082fcKUlVPIyPfezXhCoxMY22Msg1sMDnJ1IhKqqvP7u0YtPQsXLuSUU07hrLPOqnR/o0aNmDZtGhaLhQcffLBa5y4uLmbZsmUMHTq03PahQ4eycOHCI77vrbfe4o8//uDhhx+u0ucUFRWRnZ1d7hFIZS09vgkKSzRBoTRsNouNER1G8MVFXzCu5ziiHdFsOriJ2767jffWvxfs8kSkHqhR6MnMzOSEE07wvXY4vL+48/LyfNucTieDBg1i7ty51Tr3vn37cLvdJCUllduelJREenp6pe/ZuHEj9913H9OnT8dmq9owpUmTJhEbG+t7VLc16niVhZ4C36zM6t4SAQizhXFDlxv48uIvGdlxJABPLX2KTQc2BbkyEanrahR6EhMTy7WMJCYmArB58+ZyxxUUFJCVlVWjwv4843PZoOg/c7vdXHnllfzzn/+kQ4cOVT7/hAkTyMrK8j127NhRozprymmzAlBgqqVHpDKxzlge6PMAA1IGUOQu4t4F91LsLg52WSJSh9Uo9Jxwwgnl7trq3bs3pmnyyiuv+LZt2rSJ7777jrZt21br3AkJCVit1gqtOhkZGRVafwBycnJYunQpt912GzabDZvNxsSJE1m5ciU2m43vvvuu0s9xOp3ExMSUewSSo6ylxyxdikItPSIVGIbBowMeJT4snt8P/M6zvz4b7JJEpA6rUeg555xz2LhxI7/99hsAZ599Nq1ateKll16iT58+jBgxgl69elFYWMiNN95YrXM7HA569uxZoVts7ty59O/fv8LxMTExrF69mhUrVvgeY8aMoWPHjqxYsYI+ffrU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evVqVqxY4XukpqZy1VVXsWLFCtq2bavrXEuKiopYt24dTZs2DY0/zwEZLt1Avffee6bdbjffeOMNc+3atebYsWPNyMhIc+vWrcEurU7Lyckxly9fbi5fvtwEzKefftpcvny5uW3bNtM0TfOJJ54wY2NjzY8++shcvXq1ecUVV5hNmzY1s7Ozg1x53XHzzTebsbGx5rx588y0tDTfIz8/33eMrrN/TJgwwfzhhx/MLVu2mKtWrTLvv/9+02KxmHPmzDFNU9e5thx+95Zp6jr7y5133mnOmzfP3Lx5s/nzzz+bf/nLX8zo6Gjf771gX2eFnlr24osvmq1atTIdDofZo0cP3y2/UnPff/+9CVR4jBo1yjRN722RDz/8sJmcnGw6nU7z1FNPNVevXh3couuYyq4vYL711lu+Y3Sd/eOGG27w/R2RmJhonnHGGb7AY5q6zrXlz6FH19k/Ro4caTZt2tS02+1ms2bNzIsvvthcs2aNb3+wr7NhmqYZmDYlERERkeDRmB4RERFpEBR6REREpEFQ6BEREZEGQaFHREREGgSFHhEREWkQFHpERESkQVDoERERkQZBoUdEREQaBIUeERERaRAUekSkTpg3bx6GYXDdddcFuxQRqaMUekRERKRBUOgRERGRBkGhR0SCbt26dVxzzTW0a9eOsLAwEhMT6d69O2PHjiUtLY3rrruO0047DYC3334bwzB8j0ceeaTcubZu3cpNN91E69atcTqdJCYmcskll7Bq1aoKnzt16lTfOX7//XdGjBhB48aNiYyMZMCAAcyePbtG9YpIaLIFuwARadh+/fVXBg4cSGFhIb1796Z3797k5OSwefNmnn32WS688EIGDhxIeno6X3/9Ne3atWPgwIG+93fv3t33/Mcff+Tcc88lOzubzp07c/7557Nr1y4++ugjZs+ezRdffOELT4f7448/6N27N/Hx8QwdOpTdu3ezYMEC/vKXv/Dmm2+WG0dUlXqbNm1am5dMRGrKFBEJolGjRpmA+eGHH1bYt3btWnP37t2maZrm999/bwLmqFGjKj1PVlaWmZycbNrtdvODDz4ot2/u3Lmmw+EwU1JSzKKiIt/2t956ywRMwLz22mvNkpIS377PPvvMtFqtZmRkpK+G6tQrIqFH3VsiElQZGRkAnH766RX2derUqcqtJm+++Sbp6encddddXHLJJeX2nXnmmdxyyy3s2rWLzz//vMJ7o6KimDx5Mjbbocbvv/zlL1xyySXk5eUxdepUv9crIoGn0CMiQdWzZ08Arr32WhYvXozH46nReebOnQvAhRdeWOn+si6xJUuWVNg3dOhQ4uLiKmy/4oorAG+3mb/rFZHAU+gRkaC6++67GTJkCJ999hl9+vQhPj6eYcOG8fzzz5OTk1Pl82zduhWAPn36lBvoXPYoa/3Zt29fhfe2atWq0nO2bt0agN27d/u9XhEJPA1kFpGgiomJ4bvvvuOnn37is88+Y968eXz77bfMmTOHSZMmsWDBAtq1a3fM87jdbgAuvfRSIiIijnhcnz59qlybaZq1Vq+IBJ5Cj4gEnWEYDBw40NcFtXfvXu644w5mzJjB/fffz8yZM495jubNm7NhwwYefPBBunbtWq3P37ZtW6Xbt2/fDkCzZs38Xq+IBJ66t0Qk5CQmJvrm31m9ejUADocDAJfLVel7zjzzTAA+/vjjan/enDlzOHjwYIXtM2bMAGDAgAHVrldEQo9Cj4gE1csvv8yWLVsqbP/yyy8BaNmyJXCotWXDhg2Vnuemm24iMTGRxx9/nLfeeqtC11ReXh7Tpk1j586dFd6bm5vL+PHjywWq2bNn88EHHxAREcGoUaOqXa+IhB7DrKzTWkQkQLp3787KlSs56aST6NSpEzabjQ0bNrBixQrCw8P59ttv6devHwDdunVj1apV9OrVi86dO2O1Wjn//PM5//zzAfjpp584//zzyczMpFWrVnTp0gWn08n27dtZt24deXl5LF++3Deh4dSpU7n++uu56qqr+Pzzz4mPj6dPnz6kpaXxww8/YJomr732GqNHj65RvSISWtTSIyJB9a9//YsbbrgBwzD49ttv+eyzz8jPz+dvf/sbq1atKhcgPvzwQy688EI2b97MtGnTeOONN/j11199+wcMGMDq1au58847CQ8P57vvvmPOnDlkZ2fzl7/8hZkzZ3LSSSdVqOGEE05g0aJFdO3ala+//prFixfTt29fPvvss3KBp7r1ikhoUUuPiDRYZS09Dz/8cIU1vESk/lFLj4iIiDQICj0iIiLSICj0iIiISIOgMT0iIiLSIKilR0RERBoEhR4RERFpEBR6REREpEFQ6BEREZEGQaFHREREGgSFHhEREWkQFHpERESkQVDoERERkQbh/wGJ+qb8eqwwhwAAAABJRU5ErkJggg==",
      "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)\n",
    "plt.legend(['SiLU', 'Linear', 'Zero'], 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
}
