{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "4cc129ee-bfd6-4ab3-b809-1bc99e6d2225",
   "metadata": {},
   "source": [
    "## Will no sparsity loss lead to redundant neurons?"
   ]
  },
  {
   "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 ($\\lambda=0$)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "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.40e-03 | test_loss: 2.74e-03 | reg: 1.74e+01 | : 100%|█| 50/50 [00:11<00:00,  4.26it"
     ]
    },
    {
     "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.00);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "6fa03398-fff9-4ab0-ae25-2c7472edfcce",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 22 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model.plot()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e5f210da-d254-49ab-8bab-35f98e51b51f",
   "metadata": {},
   "source": [
    "### Two-layer KAN ($\\lambda=0.001$)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "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.76e-03 | test_loss: 8.48e-03 | reg: 9.70e+00 | : 100%|█| 50/50 [00:15<00:00,  3.24it"
     ]
    },
    {
     "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.001);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "id": "f82505ab-2b82-435d-8f18-ead1232e3c92",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 22 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model.plot()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "edbf9825-daf6-45c6-9b78-c2df8930254a",
   "metadata": {},
   "source": [
    "### Two-layer KAN ($\\lambda=0.01$)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "7265d743-15bd-4160-a9d1-2bef734adc7b",
   "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: 3.37e-02 | test_loss: 3.28e-02 | reg: 5.75e+00 | : 100%|█| 50/50 [00:18<00:00,  2.75it"
     ]
    },
    {
     "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": 72,
   "id": "3f9a4476-a59c-4319-a7c7-7e18f1fc0c58",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 22 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model.plot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "37ce0c71-16d5-40cb-a7e1-d53f49864ade",
   "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
}
