{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "4cc129ee-bfd6-4ab3-b809-1bc99e6d2225",
   "metadata": {},
   "source": [
    "## Why not have large grid size from scratch?"
   ]
  },
  {
   "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": "code",
   "execution_count": 10,
   "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.86e-01 | test_loss: 4.71e-01 | reg: 8.05e+00 | : 100%|█| 200/200 [00:20<00:00,  9.59\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "saving model version 0.1\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=20, k=3, seed=0, device=device, base_fun='silu')\n",
    "results = model.fit(dataset, opt=\"LBFGS\", steps=200, stop_grid_update_step=20, lamb=0.00);\n",
    "train_rmse = results['train_loss']\n",
    "test_rmse = results['test_loss']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "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": "code",
   "execution_count": 8,
   "id": "0224d8ff-0066-434c-894d-78d56f0130f3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "checkpoint directory created: ./model\n",
      "saving model version 0.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "| train_loss: 1.31e-02 | test_loss: 1.35e-02 | reg: 9.90e+00 | : 100%|█| 50/50 [00:08<00:00,  5.89it\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "saving model version 0.1\n",
      "1\n",
      "saving model version 0.2\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "| train_loss: 7.27e-03 | test_loss: 7.20e-03 | reg: 9.94e+00 | : 100%|█| 50/50 [00:05<00:00,  8.57it\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "saving model version 0.3\n",
      "2\n",
      "saving model version 0.4\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "| train_loss: 4.68e-04 | test_loss: 4.89e-04 | reg: 9.94e+00 | : 100%|█| 50/50 [00:05<00:00,  9.25it\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "saving model version 0.5\n",
      "3\n",
      "saving model version 0.6\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "| train_loss: 3.93e-05 | test_loss: 5.54e-05 | reg: 9.94e+00 | : 100%|█| 50/50 [00:05<00:00,  9.65it"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "saving model version 0.7\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "grids = [3,5,10,20]\n",
    "\n",
    "train_rmse_ge = []\n",
    "test_rmse_ge = []\n",
    "\n",
    "for i in range(len(grids)):\n",
    "    print(i)\n",
    "    if i == 0:\n",
    "        model = KAN(width=[2,1,1], grid=grids[i], k=3, seed=0, device=device)\n",
    "    else:\n",
    "        model = model.refine(new_grid=grids[i])\n",
    "    results = model.fit(dataset, opt=\"LBFGS\", steps=50, stop_grid_update_step=20);\n",
    "    train_rmse_ge += results['train_loss']\n",
    "    test_rmse_ge += results['test_loss']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "46da8188-a255-4753-b4f3-b08360a13cb2",
   "metadata": {},
   "outputs": [],
   "source": [
    "model.plot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ff07b937-fd8f-4f35-8239-184a9f2d8fb3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "ec73926c-92b9-4241-9f6a-5da5065aacb9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'RMSE')"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(train_rmse, color='red', ls='--')\n",
    "plt.plot(test_rmse, color='red')\n",
    "\n",
    "plt.plot(train_rmse_ge, color='green', ls='--')\n",
    "plt.plot(test_rmse_ge, color='green')\n",
    "plt.yscale('log')\n",
    "\n",
    "plt.legend(['no grid extension (train)', 'no grid extension (test)','grid extension (train)', 'grid extension (test)'])\n",
    "plt.xlabel('steps', fontsize=15)\n",
    "plt.ylabel('RMSE', fontsize=15)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4c1cf272-3e39-44bb-b4cf-c32717055049",
   "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
}
