{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "4cc129ee-bfd6-4ab3-b809-1bc99e6d2225",
   "metadata": {},
   "source": [
    "## What if the KAN network has more layers than needed?"
   ]
  },
  {
   "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)$. We know that a 2 Layer KAN is enough to represent this function."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "74204880-fd33-4393-9ea6-93c99c8dcd1f",
   "metadata": {},
   "source": [
    "### Two-layer KAN"
   ]
  },
  {
   "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: 2.99e-02 | test_loss: 2.95e-02 | reg: 5.70e+00 | : 100%|█| 50/50 [00:16<00:00,  3.08it"
     ]
    },
    {
     "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,5,1], grid=3, k=3, seed=2, device=device)\n",
    "model.fit(dataset, opt=\"LBFGS\", steps=50, stop_grid_update_step=20, lamb=0.01);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "6fa03398-fff9-4ab0-ae25-2c7472edfcce",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZcAAAFICAYAAACcDrP3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAwY0lEQVR4nO3deVhU9f4H8PcZdoEECcs9QPKWaWWaGphSKprd38+Lebu3vLe6lSmCuYYSKCFhorKJWy65lt2r9pRXgco9l7yhpddQBNLEBRcYFGYYhpnv749yfpEbMxzmzPJ+PQ/PU8ziez7M4c33nJkzkhBCgIiISEYqpQMQEZHjYbkQEZHsWC5ERCQ7lgsREcmO5UJERLJjuRARkexYLkREJDuWCxERyY7lQkREsmO5EBGR7FguREQkO5YLERHJjuVCRESyY7kQEZHsWC5ERCQ7V6UDENkDIQSuXr2K6upq+Pj4ICAgAJIkKR2LyGZx5UJ0B2q1GllZWQgNDUVgYCCCgoIQGBiI0NBQZGVlQa1WKx2RyCZJ/CRKolvLz8/HiBEjoNFoAPyyernhxqqlRYsW2LRpEyIjIxXJSGSrWC5Et5Cfn49hw4ZBCAGj0Xjb66lUKkiShK1bt7JgiH6D5UL0O2q1Gu3bt4dWq71jsdygUqng5eWFsrIy+Pn5NX9AIjvAYy5Ev7N69WpoNJpGFQsAGI1GaDQarFmzppmTEdkPrlyIfkMIgdDQUJSWlsKcTUOSJAQHB+PUqVN8FRkRWC5EDVy5cgWBgYFNun1AQICMiYjsE3eLEf1GdXV1k25//fp1mZIQ2TeWC9Fv+Pj4NOn2vr6+MiUhsm8sF6LfCAgIQEhIiNnHTSRJQkhICFq1atVMyYjsC8uF6DckSUJsbKxFtx0/fjwP5hP9igf0iX6H73MhajquXIh+x8/PD5s2bYIkSVCp7ryJ3HiH/ubNm1ksRL/BciG6hcjISGzduhVeXl6QJOmm3V03vufl5YVt27Zh8ODBCiUlsk0sF6LbiIyMRFlZGTIzMxEcHNzgsuDgYGRmZuLcuXMsFqJb4DEXokYQQmDnzp149tlnsX37dkRERPDgPdEdcOVC1AiSJJmOqfj5+bFYiO6C5UJERLJjuRARkexYLkREJDuWCxERyY7lQkREsmO5EBGR7FguREQkO5YLERHJjuVCRESyY7kQEZHsWC5ERCQ7lgsREcmO5UJERLJjuRARkexYLkREJDuWCxERyY7lQnQXer0e586dQ2FhIQCgpKQEFRUVMBqNCicjsl38mGOi21Cr1di0aRPWr1+P48eP4/r166irq4OnpycCAwPRr18/vP766wgLC4Orq6vScYlsCsuF6BYOHDiAiRMn4ujRo+jVqxeGDRuG7t27w8fHB2q1GgUFBdiyZQuKi4vx4osvIiUlBYGBgUrHJrIZLBei3/nyyy/x6quvwsfHB7Nnz8Zzzz2Huro6bNiwATqdDvfccw/+8pe/QK/XY8OGDUhKSkLXrl2xdu1a3HfffUrHJ7IJLBei3ygqKsKQIUPg7e2NDRs24OGHH4YkSSgtLUWPHj1QVVWFoKAgFBQUwN/fH0IIfPPNN3jppZcwYMAALF++HB4eHko/DCLF8YA+0a8MBgNSU1NRWVmJnJwcU7HciSRJCA8PR1paGj7//HPk5eVZKS2RbWO5EP2quLgYW7ZsQVRUFMLDw+9aLDdIkoThw4ejT58+WLZsGerr65s5KZHt40tciH61f/9+VFdXY8SIETh9+jRqampMl5WVlcFgMAAA6urqcPz4cdxzzz2my9u2bYuoqCgkJSXh4sWLaN++vdXzE9kSlgvRr06cOIEWLVogODgYb731Fvbt22e6TAgBnU4HADh//jwGDRpkukySJMyfPx/dunWDRqPB+fPnWS7k9FguRL/SarVwdXWFh4cHdDodamtrb3k9IcRNl9XX18PLy6tBCRE5M5YL0a9at24NrVYLtVqN3r17w9vb23SZVqvF/v37TSXy1FNPmd44KUkSOnbsiEuXLkGlUsHf31+ph0BkM1guRL964oknoNfrcejQIcyZM6fBZaWlpejVqxeqqqpw33334dNPP4Wfn5/pckmSEB8fj/vvv5+7xIjAV4sRmTz55JMIDg7G6tWrUVNTAxcXlwZfN0iSBJVKZfq+SqXChQsX8M9//hNt27aFu7u7go+CyDawXIh+FRAQgJiYGBw+fBjZ2dmNfkmxTqdDcnIyysvLsXfvXnTu3BmZmZnQarXNnJjIdrFciH7j1Vdfxf/+7/9izpw5yM7OhlarxY2TWLi6usLV1dW0ihFC4Nq1a5g5cyY+/fRT5OTk4MSJExg6dCimTp2K4OBgpKenQ6PRKPmQiBTB078Q/c7ly5cxbtw4/Pvf/0ZkZCQmTpyIhx56CCdPnoTRaIS7uzs6d+6MQ4cOYd68efj++++RnJyMsWPHmoqnpKQEs2fPxpo1a9CqVStMnToVY8aMafAiASJHxnIhuoWamhosW7YM2dnZKC8vR3BwMEJDQ+Hr64vKykqcPHkS58+fxxNPPIGZM2eif//+UKlu3hHw008/Yfbs2Vi1ahX8/f0xZcoUREdHs2TI4bFciO7g4sWL2L59O3bv3o3S0lLU1tbC398fjzzyCAYPHozevXujRYsWd72f06dP44MPPsDKlSvh7++PyZMnIzo6Gj4+PlZ4FETWx3IhaiSDwQAhBFQq1S1XKY1x5swZU8m0bNkSkyZNwrhx4+Dr6ytzWiJlsVyIFPDzzz9jzpw5WLFiBXx8fDBp0iTExMQ0OF8ZkT1juRAp6OzZs5gzZw6WL18OHx8fTJw4EbGxsSwZsnssFyIbUFZWhrS0NCxbtgwtWrTAhAkTMH78eLRs2VLpaEQWYbkQ2ZDz588jLS0NS5cuhZeXF95++228/fbbDU41Q2QPWC5ENuj8+fOYO3culi5dCg8PD0yYMIElQ3aF5UJkwy5cuIB58+ZhyZIlcHNzM61kWrVqpXQ0ojtiuRDZgfLycsybNw+LFi2Cq6srxo8fj4kTJ7JkyGaxXIjsSHl5OebPn49FixbBxcUFsbGxmDhxIgICApSORtQAy4XIDl26dAnp6elYuHAhJElCTEwMJk2ahHvvvVfpaEQAWC5Edu3KlStIT09HTk4OhBAYN24cJk+ejMDAQKWjkZNjuRA5gCtXriAjIwMLFiyA0Wg0lUzr1q2VjkZOiuVC5ECuXr2KzMxMZGdnw2AwYOzYsZgyZQruu+8+paORk2G5EDmgiooKZGVlISsrC3q9HmPGjMHUqVNx//33Kx2NnATLhciBVVZWmkpGp9OZSqZNmzZKRyMHx3IhcgJqtdpUMrW1tRg9ejTeeecdtG3bVulo5KBYLkROpKqqCtnZ2cjIyIBWq8Wbb76JuLg4tGvXTulo5GBYLkROqKqqCgsWLEBGRgZqampMJdO+fXulo5GDYLkQObFr164hJycH6enpqK6uxuuvv45p06ahQ4cOSkcjO8dyISJcv34dCxcuxPz583Ht2jVTyXTs2FHpaGSnWC5EZFJdXW0qmaqqKrz22muYPn06OnXqpHQ0sjMsFyK6SXV1NRYvXox58+ahsrISr776KqZPn46goCClo5GdYLkQ0W3V1NSYSqaiogKvvPIKpk+fjuDgYKWjkY1juRDRXWk0GixZsgRz587FlStX8Pe//x3x8fEICQlROhrZKJYLETWaRqPBhx9+iLS0NFy+fBmjRo3Cu+++i86dOysdjWwMy4WIzKbVak0lU15ebiqZ0NBQpaORjWC5EJHFamtrsWzZMsyZMwcXL17ESy+9hHfffRddunRROhopTKV0ACKyX56enoiNjUVxcTGysrKwc+dOdO3aFaNGjcKJEyeUjkcKYrkQUZN5enpi3LhxKC4uRnZ2Nvbs2YOuXbvi5ZdfRmFhodLxSAHcLUZEstPpdPjoo48we/ZsVFVV4dy5c/D29lY6FlkRy4WIGm3z5s2QJKlZ/w29Xg8XFxeMGDGiWf8dal6uSgcgIvtx8OBBpKamNtv9f/fdd4iLi0OvXr1YLnaO5UJEZnF1bb5fGzExMejevXuz3T9ZDw/oE5FNEELgyJEjSEtLUzoKyYDlQkQ2oaKiAgAQEBCgcBKSA8uFiGzCmDFj0K9fv2Z/wQBZB4+5EJHihBD47LPPUFpaqnQUkglXLkSkuIKCAri4uPDjlR0Iy4WIFCWEQFRUFBITE7lLzIGwXIhIUefPn8e5c+cwbdo0paOQjFguRKQYIQSGDBmCN998s1nfP0PWx58mESnm4MGDOHnyJAoKCpSOQjLjyoWIFFFfX49hw4ZhwYIFcHd3VzoOyYzlQkRWJ4TA6NGj0bZtW4wePVrpONQMuFuMiKxu69at+Pjjj/Hzzz/zFWIOiisXIrKq06dPY+TIkVi/fj1at26tdBxqJiwXIrKaiooKhIeHY9y4cYiKilI6DjUjlgsRWUVFRQWefvppPPXUU0hLS+PuMAfHciGiZiWEQElJCfr164cuXbrg448/hkrFXz2Ojj9hImo29fX12LhxI8LCwjBgwAB8+umnfLOkk+BPmYhkZzAYUFBQgNmzZ+O7777D3Llz8fLLL3PF4kT4kyYiWQghoNFokJ+fj5EjRyIqKgodO3bEgQMHMGrUKBaLk+HKhYgsJoSAXq/Hzz//jG3btuHjjz/G1atXMXLkSMyZMwedO3fmgXsnxXIhIrNs3LgR9fX1qKqqQklJCQoKClBaWorOnTtj9OjReP755xEYGMhScXIsFyIyS0ZGBgDAx8cHHTp0wAsvvIC+ffsiJCQEbm5uAACdTqdkRLIBkhBCKB2CiOzDtm3boNFoAAAuLi5QqVTNskJxcXHBsGHDZL9fsh6WCxE1mjV/XXC3mn3jyzeIqNEkSTLrS6vV4siRI9BqtWbfluwby4WIms2JEyfQs2dPnDhxQukoZGUsFyIikh3LhYiIZMdyISIi2bFciIhIdiwXIiKSHcuFiIhkx3IhIiLZsVyIiEh2LBciIpIdy4WIiGTHciEiItmxXIiISHYsFyIikh3LhYiIZMdyISIi2bFciIhIdiwXIiKSHcuFiIhkx3IhIiLZsVyIiEh2LBciIpIdy4WIiGTHciEiItmxXIiISHYsFyIikh3LhYiIZMdyISIi2bFciIhIdiwXIiKSnavSAZpCCIGrV6+iuroaPj4+CAgIgCRJSseyaZyZZTg38wkhUFlZCQCorKyEEIIzawRHea7Z5cpFrVYjKysLoaGhCAwMRFBQEAIDAxEaGoqsrCyo1WqlI9oczswynJv5fjuzgQMHQgiBgQMHcmZ34XDPNWFn8vLyhLe3t5AkSUiSJACYvm58z9vbW+Tl5Skd1WZwZpbh3MzHmVnGEedmV+WSl5cnXFxchEqlajD833+pVCrh4uJiVz+I5sKZWYZzMx9nZhlHnZskhBByr4aag1qtRvv27aHVamE0Gu96fZVKBS8vL5SVlcHPz6/5A9ogzswynJv5ODPLOPLc7OaYy+rVq6HRaBr1AwAAo9EIjUaDNWvWNHMy28WZWYZzMx9nZhlHnptdrFyEEAgNDUVpaSnMiStJEoKDg3Hq1Cm7fLVFU3BmluHczMeZWcbR52YX5XLlyhUEBgY26fYBAQEyJrJ9nJllODfzcWaWcfS52cVuserq6ibd/vr16zIlsR+cmWU4N/NxZpZx9LnZRbn4+Pg06fa+vr4yJbEfnJllODfzcWaWcfS52UW5BAQEICQkxOz9i5IkISQkBK1atWqmZLaLM7MM52Y+zswyjj43uygXSZIQGxtr0W3Hjx9v0we9mgtnZhnOzXycmWUcfW52cUAfcOzXgzcXzswynJv5ODPLOPLc7GLlAgB+fn7YtGkTJEmCSnXn2CqVCpIkYfPmzTb/A2hOnJllODfzcWaWcei5WfuUAE3V2HPw5OfnKx3VZnBmluHczMeZWcYR52Z35SKEEJWVlSIrK0uEhIQ0+CGEhISIrKwsoVarlY5oczgzy3Bu5uPMLONoc7PLcrnBaDSK7du3CwBi+/btwmg0Kh3J5nFmluHczMeZWcZR5mY3x1xuRZIk075HPz8/m3/1hC3gzCzDuZmPM7OMo8zNrsuFiIhsE8uFiIhkx3IhIiLZsVyIiEh2LBciIpIdy4WIiGTHciEiItmxXIiISHYsFyIikh3LhYiIZMdyISIi2bFciIhIdiwXIiKSHcuFiIhkx3IhIiLZsVyIiEh2dlsu1dXVKCoqwrFjxwAAFy9eRF1dncKpbF91dTXOnDkDACgsLMTZs2c5t7vQ6/U4d+4cCgsLAQAlJSWoqKiA0WhUOJlt43PNfI70e00SQgilQ5ijtLQUy5cvxxdffIGzZ89Cr9dDp9PhnnvuweOPP45XXnkFUVFR8PX1VTqqTfnt3M6cOQOtVgt3d3d4e3ujW7dunNstqNVqbNq0CevXr8fx48dx/fp11NXVwdPTE4GBgejXrx9ef/11hIWFwdXVVem4NoPPNfM54u81uykXg8GATz75BPHx8dBqtRg6dCgGDRqEjh07wmg0ori4GLm5udi5cyd69OiBBQsW4OGHH1Y6tuI4N8scOHAAEydOxNGjR9GrVy8MGzYM3bt3h4+PD9RqNQoKCrBlyxYUFxfjxRdfREpKCgIDA5WOrSg+18zn0DMTdsBgMIiFCxcKb29vMXToUPHDDz+I+vp6sX//fpGVlSWysrJEYWGhqKurE7t37xY9e/YUXbp0EceOHVM6uqI4N8vk5+eLNm3aiNDQULFx40ah0WiEWq0WS5YsEVlZWeKjjz4SWq1WXLt2TXz44Yeibdu2YtCgQeLixYtKR1cMn2vmc/SZ2UW57Ny5U/j5+YkXXnhBVFRUCKPRKIQQIiEhQQAQAMTatWuFEEIYjUZx5swZ8dRTT4nw8HBRWVmpYHJlcW7mO3nypAgKChKPPPKI+O9//2uaWUlJiWjZsqUAIIKCgkRFRYUQ4pe57dmzR7Rv316MGjVK1NbWKhlfMXyumc/RZ2bzB/S1Wi2Sk5Nx3333ISMjA35+fpAk6bbXlyQJHTp0wIIFC1BUVIR169ZZMa3t4NzMZzAYkJqaisrKSuTk5ODhhx++48yAX+YWHh6OtLQ0fP7558jLy7NSWtvB55r5nGFmNl8uBQUFOHjwIKKjo9GuXbu7buzALz+Ixx57DH/+85+xatUqaDQaKyS1LZyb+YqLi7FlyxZERUUhPDy8UTMDfpnb8OHD0adPHyxbtgz19fXNnNS28LlmPmeYmc2/xGXXrl3w8PDAwIEDUVhY2GDDLS8vN/33zz//jKNHj5r+38/PD8OHD8e6detw+vRp+zkIJhPOzXz79+9HdXU1RowYgdOnT6OmpsZ0WVlZGQwGAwCgrq4Ox48fxz333GO6vG3btoiKikJSUhIuXryI9u3bWz2/UvhcM59TzEzp/XJ3M2rUKPHggw+KoqIi0bFjR+Hp6Wn6cnV1Ne2bdHNza3DZa6+9Jn766Sdx7733itzcXKUfhtVxbuZ75513hJ+fnygsLBTPPvtsg7l4eHiYZiZJUoPLvLy8xKJFi8TevXuFr6+v+Pbbb5V+KFbF55r5nGFmNr1yEUKgtrYWHh4ecHFxQW1tLWpra295Xb1eD71eb/r/uro6uLu7m27nTDg3y2i1Wri6usLDwwM6ne62j//GfH+rvr4eXl5eEEJAp9NZI65N4HPNfM4yM5suF0mScO+99+LQoUMwGAyIiIiAWq02XX7q1CmUlpYCALp164a2bduaLuvevTvUajV0Oh1atWpl7eiK4tws07p1a2i1WqjVavTu3Rve3t6my7RaLfbv328qkaeeesr0xklJktCxY0dcunQJKpUK/v7+Sj0Eq9Lr9Thw4ABKSkqgVqv5XGskp9k+lVw2NcayZcuEl5eX2LNnj6ivr2/wFR8fb1o+rl69usFlBoNBrFq1Stx///2irKxM6YdhdZyb+bZt2ybc3d3FkiVLbppZUVGR6aXIDzzwgLhy5cpNc4uLixMPPvigXbxM1FJnz54Vy5cvFyNGjBB+fn5CpVIJX19f4enpyeeaGZxh+7T5V4s988wz8PX1xerVqyGEgIuLi+lLpfr/+CqVqsFltbW1WLNmDcLDw3H//fcr+AiUwbmZ78knn0RwcDBWr16NmpqaBnNxcXExXU+SpAZzU6lUuHDhAjZu3Ihhw4ahZcuWCj4KedXV1WHnzp2Ii4vDo48+ik6dOmHMmDEoLy/H5MmT8e233+Lw4cO45557+FwzgzNsnzZfLg888ABefvll/POf/0R+fj5EI85WYzQasWrVKhw5cgSxsbENfjE4C87NfAEBAYiJicHhw4eRnZ3d6JcU63Q6zJo1C1qtFm+99VajX8Jsq86cOYOlS5fiT3/6EwIDAzFw4ECsXbsWPXr0wCeffILy8nLs3bsXCQkJ6NmzJ4KDgy1+rn3zzTfo0aNHg1+ozsAptk/lFk2Nd+HCBdGrVy/RoUMH8fXXXwuDwSCEEGLGjBnC1dVVuLm5iXXr1gmj0Sj0er1Yu3atuPfee0V8fLyor69XOL1yODfzVVdXiz//+c/Cx8dHzJ8/X2g0GmE0GkVJSYkICAgQrq6uonPnzqZ3VFdVVYl33nlHtGzZUqxcuVLp+Bapra0VX331lZg0aZLo2rWrUKlUws3NTfTv31+kpqaKw4cPm547t2Ppc61v376ia9euYuzYsaK8vNwaD9dmOPr2aRflIoQQx48fFz169BCtWrUS7777riguLhZFRUVi165dYteuXeLMmTPi6NGjYsyYMaJly5Zi3LhxoqamRunYiuPczHfp0iUxcuRI4eXlJYYPHy52794tLl26JPbu3St2794tDhw4IC5fviy2bt0qIiIihL+/v1iwYIFdbPA3lJSUiIULF4rnn39e+Pj4CJVKJdq3by/eeOMNsXHjRouOG1n6XNu5c6eIiIgQffr0EZ999pnpNCjOwJG3T7s5KzIAnDt3DrNmzcKnn34KV1dXPPzww+jQoQMMBgNOnz6NkydPIiAgAHFxcfjb3/4GDw8PpSPbBM7NfDU1NVi2bBmys7NRXl6O4OBghIaGwtfXF5WVlTh58iTOnz+PJ554AjNnzkT//v1teteOVqvFnj17kJubi7y8PJw6dQqurq4ICwvD0KFDERkZiW7dujV5l56lz7Vr166ZTqETFhaGpKQkmz+mIBdH3T7tqlyAX87/VFhYiK1bt+LQoUO4dOkS3NzcEBQUhIiICAwePBitW7dWOqbN4dwsc/HiRWzfvh27d+9GaWkpamtr4e/vj0ceeQSDBw9G79690aJFC6Vj3kQIgeLiYuTl5SE3Nxe7d+9GbW0tOnTogCFDhmDo0KGIiIhocJYBuTTlufbNN99g5syZqKmpwZQpUzBixAi7P4bVGI64fdpdufyWEAIGgwGSJNn+wS0bwrlZxmAwQAgBlUplk6uUmpoa7N6927Q6KS0thbu7O8LDwzF06FAMGTIEDz30kFV/WVvyXKuursbcuXOxefNm9O3bF0lJSQ3e6+HoHGX7tOtyIXJmQgicOHECeXl5yMvLw969e6HT6fDAAw+YVicDBgyAj4+P0lEtsm/fPiQlJeHatWuYPHkyXnjhBZssdbo1lguRHamursaOHTtMhXLmzBl4eHigf//+GDJkCIYMGYIHH3zQYXYlVVdXY/78+di4cSOefPJJJCcno127dkrHokZguRDZMCEEjh8/biqTb775Bnq9Hp07dzaVSf/+/W3yuI+cDh48iJkzZ6KyshITJ07Eiy++yFWMjWO5ENmYa9euYfv27cjNzUV+fj7Kysrg5eWFAQMGmAqlc+fOSse0upqaGmRmZmLDhg3o2bMnkpOT0aFDB6Vj0W2wXIgUJoTA0aNHTauTGyfI7NKli+nYSXh4OLy8vJSOahMOHTqEGTNm4MqVK5gwYQJeeuklrmJsEMuFSAFqtRpff/21aXVy4cIFeHt7IyIiwvS+k6CgIKVj2iyNRoOsrCx8/PHH6NGjB5KTk9GpUyelY9FvsFyIrMBoNOL77783rU4OHjwIg8GAhx9+2LQ6CQsLs5s3yNmKgoICJCYm4tKlSxg/fjxGjRrFVYyNYLkQNZOrV6/iq6++Ql5eHr788kuUl5fDx8cHzz77rGl10rFjR6Vj2r3a2lpkZ2dj3bp16N69O2bNmsVVnw1guRDJxGg04rvvvkN+fj7y8vJw6NAhGI1GdO/eHZGRkRg6dCj69u0Ld3d3paM6pCNHjiAxMREXLlxATEwMXnnlFa5iFMRyIWqCy5cv48svvzStTq5cuYKWLVti4MCBGDJkCCIjI/m+DCvS6XTIycnBmjVr0LVrV8yaNQshISFKx3JKLBciMxgMBhw6dAh5eXnIz8/Hd999ByEEHn/8cURGRmLIkCHo06cP3NzclI7q1I4ePYqEhASUlZUhOjoar732ml2fSsUesVyI7uLixYv48ssvkZubi6+++gqVlZXw9/fHoEGDMHToUAwaNAht2rRROib9jk6nw6JFi7Bq1So89NBDSElJccr3BymF5UL0O/X19Th48KDplV1HjhwBAPTs2dP0JsZevXrB1dVV4aTUGMeOHUNiYiLOnDmDMWPG4PXXX+fPzgpYLkT45TM1bqxOvv76a1RVVSEgIACDBw82rU7s7ZTn9P/q6uqwZMkSrFixAl26dMGsWbPQpUsXpWM5NJYLOSW9Xo/9+/ebVidHjx6FJEl48sknTauTJ554gvvpHcyPP/6Id999Fz/99BPeeustvPHGGzw+1kxYLuQ0zp49ayqT7du34/r162jdunWD1UlAQIDSMamZ6fV6fPjhh1i2bBlCQkKQkpKChx56SOlYDoflQg5Lp9Nh3759plOsHD9+HCqVCn379jW9suvxxx/neyGcVGFhIRITE3Hq1Cm8+eabGD16NN+DJCOWCzmU06dPm1YnO3bsQE1NDdq0aWMqk4EDB8Lf31/pmGQj9Ho9VqxYgSVLliAoKAgpKSno2rWr0rEcAsuF7FptbS327t1rWp2cOHECLi4uCAsLM72J8dFHH3WYD8+i5lFUVISEhAScPHkS//jHPzB27FiuYpqI5UJ2p6SkBHl5ecjNzcWuXbug1WrRrl070wkgn3nmGbRs2VLpmGRn6uvrsXLlSixevBidOnXCrFmz0K1bN6Vj2S2WC9k8jUaDPXv2IDc3F3l5eSguLoabmxvCwsIwdOhQDBkyBF27duXqhGRRXFyMhIQEFBYW4tVXX0V0dDTPVm0BlgvZHCEEioqKkJ+fj9zcXOzZswe1tbXo2LGjaXUSEREBX19fpaOSgzIYDFi1ahUWLlyIdu3aISUlBY8++qjSsewKy4VsQk1NDXbu3Gk6GP/TTz/B3d0d/fr1M61O/vCHP3B1QlZVUlKCGTNm4NixY/jb3/6G2NhYeHp6Kh3LLrBcSBFCCBQWFprKZO/evairq0NQUJBpdTJgwAB4e3srHZWcnNFoxJo1a7BgwQK0adMGycnJ6NGjh9KxbB7Lhazm+vXr2LFjh6lQfv75Z3h6eqJ///6md8WHhoZydUI26fTp00hMTMQPP/yAl19+GePHj4eXl5fSsWwWy4WajRAC//3vf01lsm/fPuj1eoSGhprK5Omnn0aLFi2UjkrUKEajEevWrUN2djZat26N5ORk9OzZU+lYNonlQrKqqqrC9u3bTe87OXfuHLy8vBAREWH6aF9+eBPZuzNnzmDGjBk4fPgw/vrXv2LChAn8I+l3WC7UJEII/PDDD6bVyf79+2EwGPCHP/zBdOwkPDycB0HJ4RiNRnzyySfIzMxEQEAA3nvvPfTu3VvpWDaD5UJNcv78eXTo0AHe3t545plnTKuTBx54QOloRFZx9uxZ0yomNzcXbdu2VTqSTWC50E3MfUrcuL4lB+J58J5skSXbQG1trUUH+B11G+DHsdFNPvvsM1me8EajEXV1dbfdJWY0GjFixIgm/ztEctu+fTuA5v3Fr9fr4eLigkGDBjXbv6Eklgvd5ODBg0hNTW3SfVy+fBkxMTE4c+YMRowYgSlTpty0oU6bNo3lQjbphx9+wLlz5xAdHd0su3h//PFHzJ8/H926dWO5kHNpymeMG41GRERE4PHHH0dCQgLeeust6HQ6JCUlyReQqJkZDAakpqZi5cqVst93amqqw79qkp+SRLKbPXs2rl+/jnXr1mH48OHYs2cPUlJScOHCBaWjETXa9OnTUVBQIPv9CiHw448/YtKkSbLfty1huZCsjEYjkpKSkJeXZ/r8+S5duuDVV1/F0KFDFU5H1Hj33XcfhBDQ6/Wy3m9dXR0AoFWrVrLer61huZCs1q5dC19fXzzyyCMNvr9o0SIcO3YM165dUygZkXkkSUKrVq2wYcMGWe933bp1aN26tcO+SuwGlgvJRgiBcePGYdWqVTdtOO7u7ggLC8Mbb7yhUDoi88XHx2PhwoWy3ufSpUvx7rvvynqftojlQrK5du0atFot/vjHP97y8g0bNmDTpk1mv4eASCnPPvssNBoNjEajLPdnNBpRW1uL/v37y3J/tozlQrKJiYlBr169brvcb9OmDVQqFU6dOmXlZESWcXFxgYeHB/bv3y/L/X3zzTfw9PSESuX4v3od/xGSVQgh8Mknn2D9+vW3vY4kSfjLX/6Cv//971ZMRtQ00dHRmDlzpiz3lZSUhLFjx8pyX7aO5UKyqKiogBACwcHBd7xeVlYW/vOf/3DXGNmNUaNG4fLly03eNWY0GnHlyhWMGjVKpmS2jeVCt2VOAURHR6Nv3753fQWMv78/gF9OzU9kD9zc3ODp6Yndu3c36X527doFT09PuLm5yZTMtrFc6JZWrFjR6AIQQmDTpk1Ys2bNXa8rSRIeeughzJgxo6kRiaxm6tSpTX7Ozpw5E++8845MiWwfy4VuKScnB3FxcY26blVVFYQQCAoKatT1Fy1ahAMHDjQlHpFVRUVFoaqqyvQGSHPpdDpUVVXhT3/6k8zJbBfLhW5p5cqV+Oijjxp13QkTJqBHjx6NflNYeHg4du7c2ZR4RFbl4uKCTp06ISMjw6Lbp6enIygoyHTWCmfAcqFbeuyxx2AwGKDT6e54PSEE1q9fj7Vr1zb6vlUqFXx8fJoakciqMjMz8cknn1j0WS+ffvopMjMzmyeYjWK50C1JkoROnTohJSXljterqqqC0WhEly5drJSMSBnBwcFwdXU1+z0vu3btgru7u9N9OivLhW5r/fr1mDt37h3/UhszZkyjXiVGZO8kSUJiYiKmTp3a6NWLEALTp0/He++953TbCMuFbqtPnz7Q6/UoLy+/5eVCCGzcuPGOb5wkciT/8z//A61Wi8OHDzfq+vv27UN9fT2GDBnSzMlsD8uFbkuSJIwYMQIjR4685eVHjhyBSqVCx44drZyMSBmSJCEhIQGxsbF3Xb0YjUZMnjwZKSkpTrdqAVgudBcrVqzA/v37odFoGnxfCIGoqCjEx8c75YZDzisqKgpubm5YsWLFba8jhEBGRgb8/PwQGRlpxXS2g+VCd+Tr64uwsDCMGjWqwV9qZ8+exdmzZ5GQkKBgOiLrkyQJy5cvR05ODoqKim55ncOHD2PdunVYuXKl0/7xxXKhu/r888+xZcsW7Nu3D0IIGAwGDB48GOPGjYOrq6vS8YisrnPnzoiNjcVrr72GoqIi0x9eQggcOXIEY8eORUJCAtq1a6dwUuXwNwPdlb+/PxYvXoznnnsO6enp2L17N/R6PdLT05WORqQISZLwj3/8A1qtFq+//jpGjhyJBx98ED/88AO++OILxMbGIioqSumYimK50C3V1tY2+P9Ro0ZBkiSsXr0a999/P3bs2IH6+nrU19crlJCoed3tDcQA8Oabb+LRRx/F5s2b8e2336Jdu3bIyspCt27dLD5VjKOQBM99Tr+zbdu225aGXq+Hi4uLLB925OLigmHDhjX5fojktnfvXrP+cDIajaipqYGvr69Z/46Liwuefvppc+PZBZYL3cScp4TRaIQQApIkWVQ4znqwk2ybOduAEAKXLl1CVVUVgoKCzD6lvqNuAzygTzeRJKlRX6tXr4aHhwdiYmIafZvffxHZosY+f4UQSEpKwuDBg1FUVAR3d3duA79iuZBFPvroI7zxxhsYPXo0Fi1a5BSfCU70W0ajETNnzsTnn3+O1NRU/PGPf1Q6kk3hbwQy24oVK/DGG2/grbfewsKFC1ks5HSMRiNmzJiBL774ArNnz8bzzz+vdCSbw98KZJZly5Zh9OjRiI6ORk5OjkMv64luxWg0IjExEVu2bMHs2bPx3HPPKR3JJrFcqNE+/PBDjBkzBjExMcjOzmaxkNMxGo1ISEjAv//9b8yZM4fFcgd8nws1ytKlSxEdHY3Y2FhkZGSwWMjpGI1GxMfHIzc3F2lpaU57zrDG4sqF7mrx4sWIjo7G+PHjWSzklAwGA6ZPn47c3FzMnTuXxdIILBe6o0WLFiEmJgYTJkxAeno6i4Wczo1iyc/Px7x58zB48GClI9kFlgvdVk5ODmJjYzFp0iTMmzePxUJOx2AwYNq0afjyyy8xb948DBo0SOlIdoPlQreUnZ2Nt99+G5MnT0ZaWhqLhZxOfX093nnnHXz11VeYP38+Bg4cqHQku8JyoZtkZWVh4sSJmDp1KubMmcNiIadTX1+PuLg47NixAxkZGXj22WeVjmR3WC7UQGZmJiZNmoS4uDjMnj2bxUJO58aKZceOHUhPT0dERITSkewSy4VM0tPTMXnyZEybNg3vv/8+i4Wcjl6vx5QpU7Bz505kZGSwWJqA5UIAgHnz5mHq1KmIj49HSkoKi4Wczo1i2bNnDzIzMzFgwAClI9k1lgth7ty5iIuLQ0JCApKTk1ks5HT0ej0mT56MvXv3IisrC/3791c6kt1juTi5OXPmYNq0aUhMTERSUhKLhZxOXV0dJk2ahH379iE7Oxv9+vVTOpJD4OlfnNjs2bORkJCAmTNnYsaMGUrHIbK6G8Vy4MABZGVlITw8XOlIDoPl4qRSU1NNq5XExESl4xBZXV1dHSZOnIiDBw8iOzsbYWFhSkdyKNwt5oRSUlKQmJiI9957j8VCTkmn02HChAn49ttvsWDBAhZLM+DKxckkJyfjvffew6xZsxAfH690HCKru1Es//nPf5CTk4M+ffooHckhsVycyHvvvYfk5GS8//77mDZtmtJxiKxOp9Ph7bffxnfffYeFCxeid+/eSkdyWCwXJyCEMK1WUlNTERcXp3QkIqvT6XQYP348CgoKWCxWwHJxcEIIzJw5E++//z4++OADTJ06VelIRFan0+kQGxuLI0eOYPHixejVq5fSkRwey8WBCSEwY8YMpKamIi0tDZMnT1Y6EpHV1dbWIjY2Ft9//z0WL16Mnj17Kh3JKbBcHJQQAgkJCfjggw8wd+5cTJo0SelIRFZXW1uLmJgYHD16FEuWLMETTzyhdCSnwXJxQEIIxMfHIy0tDfPnz8eECROUjkRkdVqtFjExMTh27BiWLFmCHj16KB3JqbBcHIwQAtOnT8fcuXORnp6Ot99+W+lIRFan1Woxbtw4HD9+nMWiEJaLAxFCIC4uDvPnz0dmZiZiY2OVjkRkdRqNBtHR0SgsLMSSJUvw+OOPKx3JKbFcHIQQAlOnTkVGRgays7Mxbtw4pSMRWZ1Go8HYsWNx8uRJLF26FI899pjSkZwWy8UBCCEwZcoUZGZmYsGCBYiOjlY6EpHV1dTUIDo62lQsjz76qNKRnBrLxQ4IIXD16lVUV1fDx8cHAQEBplPjCyEwadIkZGdnIycnB2PHjlU4LVHzuNN2UFNTg7Fjx+LUqVP48MMP0b17d4XTEk9cacPUajWysrIQGhqKwMBABAUFITAwEKGhocjKykJlZSUmTpyI7OxsLFq0iMVCDulu20FZWRnGjBnDYrExkhBCKB2Cbpafn48RI0ZAo9EA+OWvthskSYIQAq6urjAajViyZAnefPNNpaISNZvGbAcuLi4IDQ3Fv/71LzzyyCNKRaXf4crFBuXn52PYsGHQarUQQuD3/X/j/+vr6yGEQMeOHZWISdSsGrsdGAwGFBUV4dy5c0rEpNvgysXGqNVqtG/fHlqtFkaj8a7XV6lU8PLyQllZGfz8/Jo/IJEVcDuwf1y52JjVq1dDo9E0aoMCAKPRCI1GgzVr1jRzMiLr4XZg/7hysSFCCISGhqK0tPSmXQB3IkkSgoODcerUKdOrZ4jsFbcDx8BysSFXrlxBYGBgk24fEBAgYyIi6+N24Bi4W8yGVFdXN+n2169flykJkXK4HTgGlosN8fHxadLtfX19ZUpCpBxuB46B5WJDAgICEBISYvb+YkmSEBISglatWjVTMiLr4XbgGFguNkSSJIvPZDx+/HgexCSHwO3AMfCAvo3h6/uJuB04Aq5cbIyfnx82bdoESZKgUt35x6NSqSBJEjZv3swNihwKtwP7x3KxQZGRkdi6dSu8vLwgSdJNy/wb3/Py8sK2bdswePBghZISNR9uB/aN5WKjIiMjUVZWhszMTAQHBze4LDg4GJmZmTh37hw3KHJo3A7sF4+52AEhBCoqKnD9+nX4+vqiVatWPGhJTofbgX1huRARkey4W4yIiGTHciEiItmxXIiISHYsFyIikh3LhYiIZMdyISIi2bFciIhIdiwXIiKSHcuFiIhkx3IhIiLZsVyIiEh2LBciIpIdy4WIiGTHciEiItn9HwwYKNo7SU4OAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 500x400 with 22 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model.plot()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "df8e0cff-dff8-4ec7-ba6f-829ddb5bca5f",
   "metadata": {},
   "source": [
    "### Three-layer KAN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "278dcd6f-538d-4571-a6c0-cf660cb25ff3",
   "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: 6.91e-02 | test_loss: 6.63e-02 | reg: 1.06e+01 | : 100%|█| 50/50 [00:22<00:00,  2.21it"
     ]
    },
    {
     "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,3,3,1], grid=3, k=3, seed=2, device=device)\n",
    "model.fit(dataset, opt=\"LBFGS\", steps=50, stop_grid_update_step=20, lamb=0.01);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "ad235993-ed29-46be-8389-f36a6a8fac0c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x600 with 26 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model.plot()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7de08bbe-8f1f-4cbd-8f0c-28e03915ab37",
   "metadata": {},
   "source": [
    "### Four-layer KAN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "2e561978-72e7-4383-8898-0887c0df21e5",
   "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.76e-02 | test_loss: 5.19e-02 | reg: 2.01e+01 | : 100%|█| 50/50 [00:30<00:00,  1.66it"
     ]
    },
    {
     "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,3,3,3,1], grid=3, k=3, seed=4, device=device, base_fun='identity')\n",
    "model.fit(dataset, opt=\"LBFGS\", steps=50, stop_grid_update_step=20, lamb=0.01, lamb_coef=1.0);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "2b441c6c-11bb-4e0b-8a05-f85958a21dda",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x800 with 38 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model.plot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b7f3b9de-5717-4b75-bd89-cb75ff17dd77",
   "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
}
