{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "a68eebe4-b99b-4e8b-bd09-97aa103f17cf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n",
      "mark\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "pde loss: 2.26e-01 | bc loss: 6.44e-02 | init loss : 1.94e-01 : 100%|█| 1/1 [00:00<00:00, 44.83it/s]\n",
      "pde loss: 1.67e-01 | bc loss: 6.72e-02 | init loss : 1.82e-01 : 100%|█| 1/1 [00:00<00:00, 49.00it/s]\n",
      "pde loss: 1.63e-01 | bc loss: 5.82e-02 | init loss : 1.80e-01 : 100%|█| 1/1 [00:00<00:00, 50.07it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n",
      "mark\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "pde loss: 2.26e-01 | bc loss: 6.44e-02 | init loss : 5.23e-04 : 100%|█| 1/1 [00:00<00:00, 47.78it/s]\n",
      "pde loss: 1.38e-01 | bc loss: 2.41e-01 | init loss : 2.02e-04 : 100%|█| 1/1 [00:00<00:00, 48.57it/s]\n",
      "pde loss: 1.31e-01 | bc loss: 1.93e-01 | init loss : 1.86e-04 : 100%|█| 1/1 [00:00<00:00, 48.49it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n",
      "mark\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "pde loss: 2.26e-01 | bc loss: 6.44e-02 | init loss : 2.21e-04 : 100%|█| 1/1 [00:00<00:00, 47.91it/s]\n",
      "pde loss: 1.40e-01 | bc loss: 2.53e-01 | init loss : 1.11e-04 : 100%|█| 1/1 [00:00<00:00, 48.15it/s]\n",
      "pde loss: 1.33e-01 | bc loss: 2.02e-01 | init loss : 1.08e-04 : 100%|█| 1/1 [00:00<00:00, 48.51it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n",
      "mark\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "pde loss: 2.26e-01 | bc loss: 6.44e-02 | init loss : 1.98e-04 : 100%|█| 1/1 [00:00<00:00, 47.29it/s]\n",
      "pde loss: 1.40e-01 | bc loss: 2.56e-01 | init loss : 1.11e-04 : 100%|█| 1/1 [00:00<00:00, 48.57it/s]\n",
      "pde loss: 1.34e-01 | bc loss: 2.05e-01 | init loss : 1.10e-04 : 100%|█| 1/1 [00:00<00:00, 47.15it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n",
      "mark\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "pde loss: 2.26e-01 | bc loss: 6.44e-02 | init loss : 1.92e-04 : 100%|█| 1/1 [00:00<00:00, 48.17it/s]\n",
      "pde loss: 1.40e-01 | bc loss: 2.56e-01 | init loss : 1.12e-04 : 100%|█| 1/1 [00:00<00:00, 47.66it/s]\n",
      "pde loss: 1.34e-01 | bc loss: 2.05e-01 | init loss : 1.11e-04 : 100%|█| 1/1 [00:00<00:00, 48.25it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n",
      "mark\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "pde loss: 2.26e-01 | bc loss: 6.44e-02 | init loss : 1.92e-04 : 100%|█| 1/1 [00:00<00:00, 42.20it/s]\n",
      "pde loss: 1.40e-01 | bc loss: 2.56e-01 | init loss : 1.12e-04 : 100%|█| 1/1 [00:00<00:00, 47.35it/s]\n",
      "pde loss: 1.34e-01 | bc loss: 2.05e-01 | init loss : 1.11e-04 : 100%|█| 1/1 [00:00<00:00, 48.61it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n",
      "mark\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "pde loss: 2.26e-01 | bc loss: 6.44e-02 | init loss : 1.92e-04 : 100%|█| 1/1 [00:00<00:00, 48.27it/s]\n",
      "pde loss: 1.40e-01 | bc loss: 2.56e-01 | init loss : 1.12e-04 : 100%|█| 1/1 [00:00<00:00, 48.58it/s]\n",
      "pde loss: 1.34e-01 | bc loss: 2.05e-01 | init loss : 1.11e-04 : 100%|█| 1/1 [00:00<00:00, 47.33it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n",
      "mark\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "pde loss: 2.26e-01 | bc loss: 6.44e-02 | init loss : 1.92e-04 : 100%|█| 1/1 [00:00<00:00, 46.73it/s]\n",
      "pde loss: 1.40e-01 | bc loss: 2.56e-01 | init loss : 1.12e-04 : 100%|█| 1/1 [00:00<00:00, 45.48it/s]\n",
      "pde loss: 1.34e-01 | bc loss: 2.05e-01 | init loss : 1.11e-04 : 100%|█| 1/1 [00:00<00:00, 47.75it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n",
      "mark\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "pde loss: 2.26e-01 | bc loss: 6.44e-02 | init loss : 1.92e-04 : 100%|█| 1/1 [00:00<00:00, 47.15it/s]\n",
      "pde loss: 1.40e-01 | bc loss: 2.56e-01 | init loss : 1.12e-04 : 100%|█| 1/1 [00:00<00:00, 48.01it/s]\n",
      "pde loss: 1.34e-01 | bc loss: 2.05e-01 | init loss : 1.11e-04 : 100%|█| 1/1 [00:00<00:00, 48.34it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n",
      "mark\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "pde loss: 2.26e-01 | bc loss: 6.44e-02 | init loss : 1.92e-04 : 100%|█| 1/1 [00:00<00:00, 47.70it/s]\n",
      "pde loss: 1.40e-01 | bc loss: 2.56e-01 | init loss : 1.12e-04 : 100%|█| 1/1 [00:00<00:00, 48.89it/s]\n",
      "pde loss: 1.34e-01 | bc loss: 2.05e-01 | init loss : 1.11e-04 : 100%|█| 1/1 [00:00<00:00, 49.21it/s]\n"
     ]
    }
   ],
   "source": [
    "from kan import *\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "from torch import autograd\n",
    "from tqdm import tqdm\n",
    "from experiments.baselines.MLP import MLP, MLP_RFF\n",
    "\n",
    "\n",
    "# implement Allen Cahn 1D,  2D input (x, t)\n",
    "N_deltat = 10\n",
    "steps = 1 #10000\n",
    "\n",
    "for i_deltat in range(N_deltat):\n",
    "\n",
    "    device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "    print(device)\n",
    "\n",
    "    dim = 2\n",
    "    np_i = 51 # number of interior points (along each dimension)\n",
    "    np_t = 51\n",
    "\n",
    "\n",
    "    def batch_jacobian(func, x, create_graph=False):\n",
    "        # x in shape (Batch, Length)\n",
    "        def _func_sum(x):\n",
    "            return func(x).sum(dim=0)\n",
    "        return autograd.functional.jacobian(_func_sum, x, create_graph=create_graph).permute(1,0,2)\n",
    "\n",
    "\n",
    "    print('mark')\n",
    "    # interior\n",
    "    sampling_mode = 'mesh' # 'radnom' or 'mesh'\n",
    "\n",
    "    x_mesh = torch.linspace(-1,1,steps=np_i).to(device)\n",
    "    t_mesh = torch.linspace(0.,0.1,steps=np_t).to(device)\n",
    "    X, T = torch.meshgrid(x_mesh, t_mesh, indexing='ij')\n",
    "\n",
    "    if sampling_mode == 'mesh':\n",
    "        #mesh\n",
    "        x_i = torch.stack([X.reshape(-1,), T.reshape(-1,)]).permute(1,0)\n",
    "    else:\n",
    "        #random\n",
    "        x_i = torch.rand((np_i*np_t,2))\n",
    "\n",
    "    x_i = x_i.to(device)\n",
    "\n",
    "    # boundary, 4 sides\n",
    "    helper = lambda X, Y: torch.stack([X.reshape(-1,), Y.reshape(-1,)]).permute(1,0)\n",
    "    x_left = helper(X[0,:], T[0,:])\n",
    "    x_right = helper(X[-1,:], T[0,:])\n",
    "\n",
    "    x_init = helper(X[:,0], T[:,0])\n",
    "\n",
    "\n",
    "    pde_losses = []\n",
    "    bc_losses = []\n",
    "    init_losses = []\n",
    "\n",
    "    lamb_r = 1\n",
    "    lamb_b = 1\n",
    "    lamb_i = 100\n",
    "\n",
    "    log = 1\n",
    "\n",
    "\n",
    "    if i_deltat == 0:\n",
    "        def u0_true(x):\n",
    "            x1 = x[:,[0]]\n",
    "            return x1**2 * torch.cos(torch.pi*x1)\n",
    "            #return torch.cos(torch.pi*x1)\n",
    "\n",
    "        model = MLP_RFF(width=[2,128,128,128,1], act='silu', seed=1, device=device, s=30)\n",
    "    else:\n",
    "        model_init = MLP_RFF(width=[2,128,128,128,1], act='silu', seed=1, device=device, s=30)\n",
    "        model_init.load_state_dict(model.state_dict())\n",
    "        \n",
    "        def u0_true(x):\n",
    "            x1 = x[:,[0]]\n",
    "            t = x1 * 0. + 0.1\n",
    "            x = torch.cat([x1, t], dim=1)\n",
    "            return model_init(x)\n",
    "            \n",
    "        model = MLP_RFF(width=[2,128,128,128,1], act='silu', seed=1, device=device, s=30)\n",
    "        #u0_true = MLP(width=[2,128,128,128,1], act='silu', seed=1, device=device).load_state_dict(model.state_dict())\n",
    "\n",
    "\n",
    "    def train():\n",
    "\n",
    "        for i in range(3):\n",
    "            #optimizer = LBFGS(model.parameters(), lr=1, history_size=10, line_search_fn=\"strong_wolfe\", tolerance_grad=1e-32, tolerance_change=1e-32, tolerance_ys=1e-32)\n",
    "            if i == 0:\n",
    "                optimizer = torch.optim.Adam(model.parameters(), lr=1e-3)\n",
    "            else:\n",
    "                for g in optimizer.param_groups:\n",
    "                    g['lr'] *= 0.1\n",
    "            #optimizer = torch.optim.LBFGS(model.parameters(), lr=1, history_size=10, line_search_fn=\"strong_wolfe\")\n",
    "\n",
    "            pbar = tqdm(range(steps), desc='description', ncols=100)\n",
    "\n",
    "            for _ in pbar:\n",
    "                def closure():\n",
    "                    global pde_loss, bc_loss, init_loss\n",
    "                    optimizer.zero_grad()\n",
    "                    # interior loss\n",
    "                    #sol = sol_fun(x_i)\n",
    "                    u = model(x_i)\n",
    "                    sol_D1_fun = lambda x: batch_jacobian(model, x, create_graph=True)[:,0,:]\n",
    "                    sol_D1 = sol_D1_fun(x_i)\n",
    "\n",
    "                    ut = sol_D1[:,[1]]\n",
    "                    sol_D2 = batch_jacobian(sol_D1_fun, x_i, create_graph=True)[:,:,:]\n",
    "                    lap = torch.sum(torch.diagonal(sol_D2, dim1=1, dim2=2)[:,:1], dim=1, keepdim=True)\n",
    "\n",
    "                    pde = ut - 0.0001*lap + 5*(u**3 - u)\n",
    "\n",
    "                    # pde loss\n",
    "                    pde_loss = torch.mean(pde**2)\n",
    "\n",
    "                    # neuman boundary loss\n",
    "                    bc_pred_left = model(x_left)\n",
    "                    bc_pred_right = model(x_right)\n",
    "                    bcd_pred_left = sol_D1_fun(x_left)[:,[0]]\n",
    "                    bcd_pred_right = sol_D1_fun(x_right)[:,[0]]\n",
    "                    bc_loss = (torch.mean((bc_pred_left-bc_pred_right)**2) + torch.mean((bcd_pred_left-bcd_pred_right)**2))/2\n",
    "\n",
    "                    # initial loss\n",
    "                    pred_init = model(x_init)\n",
    "                    true_init = u0_true(x_init)\n",
    "                    init_loss = torch.mean((true_init-pred_init)**2)\n",
    "\n",
    "                    loss = lamb_r * pde_loss + lamb_b * bc_loss + lamb_i * init_loss\n",
    "                    loss.backward()\n",
    "                    return loss\n",
    "\n",
    "                optimizer.step(closure)\n",
    "                #sol = sol_fun(x_i)\n",
    "                loss = lamb_r * pde_loss + lamb_b * bc_loss + lamb_i * init_loss\n",
    "                #l2 = torch.mean((model(x_i) - sol)**2)\n",
    "\n",
    "                if _ % log == 0:\n",
    "                    pbar.set_description(\"pde loss: %.2e | bc loss: %.2e | init loss : %.2e \" % (pde_loss.cpu().detach().numpy(), bc_loss.cpu().detach().numpy(), init_loss.cpu().detach().numpy()))\n",
    "\n",
    "                pde_losses.append(pde_loss.cpu().detach().numpy())\n",
    "                bc_losses.append(bc_loss.cpu().detach().numpy())\n",
    "                init_losses.append(init_loss.cpu().detach().numpy())\n",
    "\n",
    "\n",
    "    train()\n",
    "    np_i_test = 1001\n",
    "    np_t_test = 2\n",
    "    x_mesh = torch.linspace(-1,1,steps=np_i_test).to(device)\n",
    "    t_mesh = torch.linspace(0,2,steps=np_t_test).to(device)\n",
    "    X, T = torch.meshgrid(x_mesh, t_mesh, indexing='ij')\n",
    "\n",
    "    \n",
    "    if i_deltat == 0:\n",
    "        x_init = helper(X[:,0], T[:,0])\n",
    "        np.savetxt('./results/mlprff_t_0_width_[2,128,128,128,1]_steps_%d.txt'%steps, model(x_init).cpu().detach().numpy())\n",
    "    \n",
    "    x_init = helper(X[:,0], T[:,0]+0.1)\n",
    "    np.savetxt('./results/mlprff_t_%.1f_width_[2,128,128,128,1]_steps_%d.txt'%(0.1*(i_deltat+1), steps), model(x_init).cpu().detach().numpy())\n",
    "\n",
    "    #plt.plot(x_mesh.cpu().detach().numpy(), u0_true(x_init).cpu().detach().numpy())\n",
    "    #plt.plot(x_mesh.cpu().detach().numpy(), model(x_init).cpu().detach().numpy())\n",
    "    #plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c910f717-ae2d-4318-9537-bdcae0afe78a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "MLP_RFF(\n",
       "  (linears): ModuleList(\n",
       "    (0): Linear(in_features=102, out_features=128, bias=True)\n",
       "    (1-2): 2 x Linear(in_features=128, out_features=128, bias=True)\n",
       "    (3): Linear(in_features=128, out_features=1, bias=True)\n",
       "  )\n",
       "  (act_fun): SiLU()\n",
       ")"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model_init"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "87da8f76-767d-41e0-817b-4ef799587fd9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f8faf419a00>]"
      ]
     },
     "execution_count": 30,
     "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": [
    "np_i_test = 101\n",
    "np_t_test = 2\n",
    "x_mesh = torch.linspace(-1,1,steps=np_i_test).to(device)\n",
    "t_mesh = torch.linspace(0,2,steps=np_t_test).to(device)\n",
    "X, T = torch.meshgrid(x_mesh, t_mesh, indexing='ij')\n",
    "\n",
    "x_init = helper(X[:,0], T[:,0]+0.3)\n",
    "\n",
    "plt.plot(x_mesh.cpu().detach().numpy(), u0_true(x_init).cpu().detach().numpy())\n",
    "plt.plot(x_mesh.cpu().detach().numpy(), model(x_init).cpu().detach().numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "82ce102e-d9f2-4ed4-8499-41aa859886cd",
   "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
}
