{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Import Libraries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import torch.autograd as autograd         \n",
    "from torch import Tensor                  \n",
    "import torch.nn as nn                     \n",
    "import torch.optim as optim               \n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.gridspec as gridspec\n",
    "from mpl_toolkits.axes_grid1 import make_axes_locatable\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "import matplotlib.ticker\n",
    "\n",
    "import numpy as np\n",
    "import time\n",
    "from pyDOE import lhs         \n",
    "import scipy.io\n",
    "\n",
    "#Set default dtype to float32\n",
    "torch.set_default_dtype(torch.float)\n",
    "\n",
    "#PyTorch random number generator\n",
    "torch.manual_seed(1234)\n",
    "\n",
    "# Random number generators in other libraries\n",
    "np.random.seed(1234)\n",
    "\n",
    "# Device configuration\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "\n",
    "print(device)\n",
    "\n",
    "if device == 'cuda': \n",
    "    print(torch.cuda.get_device_name()) "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# *Data Prep*\n",
    "\n",
    "Training and Testing data is prepared from the solution file"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = scipy.io.loadmat('Data/burgers_shock_mu_01_pi.mat')  \t\n",
    "x = data['x']                                  \n",
    "t = data['t']                                  \n",
    "usol = data['usol']                             \n",
    "\n",
    "X, T = np.meshgrid(x,t)                         "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Test Data\n",
    "\n",
    "We prepare the test data to compare against the solution produced by the PINN."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {
    "colab": {},
    "colab_type": "code",
    "id": "yddknKA2Xohp"
   },
   "outputs": [],
   "source": [
    "''' X_u_test = [X[i],T[i]] [25600,2] for interpolation'''\n",
    "X_u_test = np.hstack((X.flatten()[:,None], T.flatten()[:,None]))\n",
    "\n",
    "# Domain bounds\n",
    "lb = X_u_test[0]  # [-1. 0.]\n",
    "ub = X_u_test[-1] # [1.  0.99]\n",
    "\n",
    "u_true = usol.flatten('F')[:,None] "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {
    "colab": {},
    "colab_type": "code",
    "id": "8UVJmvZbXjXb"
   },
   "outputs": [],
   "source": [
    "def trainingdata(N_u,N_f):\n",
    "\n",
    "    '''Boundary Conditions'''\n",
    "\n",
    "    #Initial Condition -1 =< x =<1 and t = 0  \n",
    "    leftedge_x = np.hstack((X[0,:][:,None], T[0,:][:,None])) \n",
    "    leftedge_u = usol[:,0][:,None]\n",
    "\n",
    "    #Boundary Condition x = -1 and 0 =< t =<1\n",
    "    bottomedge_x = np.hstack((X[:,0][:,None], T[:,0][:,None])) \n",
    "    bottomedge_u = usol[-1,:][:,None]\n",
    "\n",
    "    #Boundary Condition x = 1 and 0 =< t =<1\n",
    "    topedge_x = np.hstack((X[:,-1][:,None], T[:,0][:,None])) \n",
    "    topedge_u = usol[0,:][:,None]\n",
    "\n",
    "    all_X_u_train = np.vstack([leftedge_x, bottomedge_x, topedge_x]) \n",
    "    all_u_train = np.vstack([leftedge_u, bottomedge_u, topedge_u])  \n",
    "\n",
    "    #choose random N_u points for training\n",
    "    idx = np.random.choice(all_X_u_train.shape[0], N_u, replace=False) \n",
    "\n",
    "    X_u_train = all_X_u_train[idx, :] #choose indices from  set 'idx' (x,t)\n",
    "    u_train = all_u_train[idx,:]      #choose corresponding u\n",
    "\n",
    "    '''Collocation Points'''\n",
    "\n",
    "    # Latin Hypercube sampling for collocation points \n",
    "    # N_f sets of tuples(x,t)\n",
    "    X_f_train = lb + (ub-lb)*lhs(2,N_f) \n",
    "    X_f_train = np.vstack((X_f_train, X_u_train))\n",
    "\n",
    "    return X_f_train, X_u_train, u_train \n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Physics Informed Neural Network"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "    \n",
    "class Sequentialmodel(nn.Module):\n",
    "    \n",
    "    def __init__(self, layers):\n",
    "        super().__init__()\n",
    "    \n",
    "        assert len(layers) == 3, \"Layers must follow [input_dim, m, output_dim] structure\"\n",
    "    \n",
    "        self.activation = nn.Tanh()\n",
    " \n",
    "        self.loss_function = nn.MSELoss(reduction='mean')\n",
    "    \n",
    "        self.w_layer = nn.Linear(layers[0], layers[1], bias=False)\n",
    "    \n",
    "        self.a_layer = nn.Linear(layers[1], layers[2], bias=False)\n",
    "    \n",
    "        self.m = layers[1]\n",
    "        self.scale = 1 / torch.sqrt(torch.tensor(self.m, dtype=torch.float))\n",
    "     \n",
    "        self.w_layer.weight.data.normal_(mean=0.0, std=1.0)  \n",
    "\n",
    "        self.a_layer.weight.data.uniform_(-1.0, 1.0)  \n",
    "    \n",
    "        self.iter = 0\n",
    "\n",
    "    def forward(self, x):\n",
    " \n",
    "        x = self.w_layer(x)        \n",
    "        x = self.activation(x)     \n",
    "        x = self.a_layer(x)         \n",
    "        x = x * self.scale          \n",
    "        return x\n",
    "                       \n",
    "                        \n",
    "    def loss_BC(self,x,y):\n",
    "                \n",
    "        loss_u = self.loss_function(self.forward(x), y)\n",
    "                \n",
    "        return loss_u\n",
    "    \n",
    "    def loss_PDE(self, x_to_train_f):\n",
    "        \n",
    "        nu = 0.01/np.pi\n",
    "                \n",
    "        x_1_f = x_to_train_f[:,[0]]\n",
    "        x_2_f = x_to_train_f[:,[1]]\n",
    "                        \n",
    "        g = x_to_train_f.clone()\n",
    "                        \n",
    "        g.requires_grad = True\n",
    "        \n",
    "        u = self.forward(g)\n",
    "                \n",
    "        u_x_t = autograd.grad(u,g,torch.ones([x_to_train_f.shape[0], 1]).to(device), retain_graph=True, create_graph=True)[0]\n",
    "                                \n",
    "        u_xx_tt = autograd.grad(u_x_t,g,torch.ones(x_to_train_f.shape).to(device), create_graph=True)[0]\n",
    "                                                            \n",
    "        u_x = u_x_t[:,[0]]\n",
    "        \n",
    "        u_t = u_x_t[:,[1]]\n",
    "        \n",
    "        u_xx = u_xx_tt[:,[0]]\n",
    "                                        \n",
    "        f = u_t + (self.forward(g))*(u_x) - (nu)*u_xx \n",
    "        \n",
    "        loss_f = self.loss_function(f,f_hat)\n",
    "                \n",
    "        return loss_f\n",
    "    \n",
    "    def loss(self,x,y,x_to_train_f):\n",
    "\n",
    "        loss_u = self.loss_BC(x,y)\n",
    "        loss_f = self.loss_PDE(x_to_train_f)\n",
    "        \n",
    "        loss_val = loss_u + loss_f\n",
    "        \n",
    "        return loss_val\n",
    "     \n",
    "    'callable for optimizer'                                       \n",
    "    def closure(self):\n",
    "        \n",
    "        optimizer.zero_grad()\n",
    "        \n",
    "        loss = self.loss(X_u_train, u_train, X_f_train)\n",
    "        \n",
    "        loss.backward()\n",
    "                \n",
    "        self.iter += 1\n",
    "        \n",
    "        if self.iter % 100 == 0:\n",
    "\n",
    "            error_vec, _ = PINN.test()\n",
    "        \n",
    "            print(loss,error_vec)\n",
    "\n",
    "        return loss        \n",
    "    \n",
    "    'test neural network'\n",
    "    def test(self):\n",
    "                \n",
    "        u_pred = self.forward(X_u_test_tensor)\n",
    "        \n",
    "        error_vec = torch.linalg.norm((u-u_pred),2)/torch.linalg.norm(u,2)        # Relative L2 Norm of the error (Vector)\n",
    "        \n",
    "        u_pred = u_pred.cpu().detach().numpy()\n",
    "        \n",
    "        u_pred = np.reshape(u_pred,(256,100),order='F')\n",
    "                \n",
    "        return error_vec, u_pred"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "6a9531b7",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "\n",
    "def assign_params(model, param_list):\n",
    "    for p, src in zip(model.parameters(), param_list):\n",
    "        p.data.copy_(src.data)\n",
    "\n",
    "def compute_ntk(PINN,  x_to_train_f):\n",
    "    \n",
    "    PINN.eval()\n",
    "   \n",
    "    nu = 0.01/np.pi\n",
    "                \n",
    "    x_1_f = x_to_train_f[:,[0]]\n",
    "    x_2_f = x_to_train_f[:,[1]]\n",
    "                        \n",
    "    g = x_to_train_f.clone()\n",
    "                        \n",
    "    g.requires_grad = True\n",
    "        \n",
    "    u = PINN.forward(g)\n",
    "                \n",
    "    u_x_t = autograd.grad(u,g,torch.ones([x_to_train_f.shape[0], 1]).to(device), retain_graph=True, create_graph=True)[0]\n",
    "                                \n",
    "    u_xx_tt = autograd.grad(u_x_t,g,torch.ones(x_to_train_f.shape).to(device), create_graph=True)[0]\n",
    "                                                            \n",
    "    u_x = u_x_t[:,[0]]\n",
    "        \n",
    "    u_t = u_x_t[:,[1]]\n",
    "        \n",
    "    u_xx = u_xx_tt[:,[0]]\n",
    "                                        \n",
    "    f = u_t + (PINN.forward(g))*(u_x) - (nu)*u_xx \n",
    "    N= x_to_train_f.shape[0] \n",
    "    J = []\n",
    "    \n",
    "    for i in range(N):\n",
    "        PINN.zero_grad()\n",
    "      \n",
    "        grad_i = torch.autograd.grad(f[i], PINN.a_layer.parameters(), retain_graph=True, allow_unused=False)\n",
    "      \n",
    "        grad_flat = torch.cat([g.flatten() for g in grad_i])\n",
    "        J.append(grad_flat.detach())\n",
    "    \n",
    "    J = torch.stack(J)  \n",
    "    NTK = J @ J.T\n",
    "    return NTK\n",
    "\n",
    "def compute_ntk_linear(PINN, X_u_train):\n",
    " \n",
    "    PINN.eval()\n",
    "                                                     \n",
    "    u = PINN.forward(X_u_train) \n",
    "    N= X_u_train.shape[0] \n",
    "    J = []\n",
    "    \n",
    "    for i in range(N):\n",
    "        PINN.zero_grad()\n",
    "        \n",
    "        grad_i = torch.autograd.grad(u[i], PINN.a_layer.parameters(), retain_graph=True, allow_unused=False)\n",
    "        \n",
    "        grad_flat = torch.cat([g.flatten() for g in grad_i])\n",
    "        J.append(grad_flat.detach())\n",
    "    \n",
    "    J = torch.stack(J) \n",
    "    NTK = J @ J.T\n",
    "    return NTK\n",
    "\n",
    "def IGD_PINN_a(PINN, X_u_train, u_train, X_f_train, theta_init, K0, K1, gamma, eta):\n",
    "    for p in PINN.w_layer.parameters():\n",
    "        p.requires_grad_(False)\n",
    "    for p in PINN.a_layer.parameters():\n",
    "        p.requires_grad_(True)\n",
    "    theta_n = [p.clone() for p in theta_init]\n",
    "    NTK0= compute_ntk(PINN, X_f_train)  \n",
    "    NTK0_norm=torch.norm(NTK0, p='fro')\n",
    "    NTK0_linear=compute_ntk_linear(PINN, X_u_train)\n",
    "    NTK0_linear_norm=torch.norm(NTK0_linear, p='fro')\n",
    "    n = 0\n",
    "    loss_list = []\n",
    "    diff_norm_list=[]\n",
    "    lin_diff_norm_list=[]\n",
    "    while n < K0:\n",
    "        assign_params(PINN, theta_n)\n",
    "   \n",
    "        optimizer_inner = torch.optim.LBFGS(PINN.a_layer.parameters(), \n",
    "                                          lr=gamma,       \n",
    "                                          max_iter=K1,     \n",
    "                                          max_eval=K1*2,   \n",
    "                                          history_size=100)\n",
    "        \n",
    "        def closure():\n",
    "            optimizer_inner.zero_grad()\n",
    "            \n",
    "            param_now = list(PINN.parameters())\n",
    "            loss_quad = 0.5 * sum([(a - b).pow(2).sum() for a, b in zip(param_now, theta_n)])\n",
    "           \n",
    "            loss_main = PINN.loss(X_u_train, u_train, X_f_train)\n",
    "            \n",
    "            total_loss = loss_quad + eta * loss_main\n",
    "            total_loss.backward()\n",
    "            return total_loss\n",
    "        \n",
    "        optimizer_inner.step(closure)\n",
    "        theta_n = [p.clone().detach() for p in PINN.parameters()]\n",
    "        loss = PINN.loss(X_u_train, u_train, X_f_train)\n",
    "        NTK = compute_ntk(PINN, X_f_train)\n",
    "        NTK_linear=compute_ntk_linear(PINN, X_u_train)\n",
    "       \n",
    "        diff_norm = torch.norm(NTK - NTK0, p='fro')/NTK0_norm\n",
    "        lin_diff_norm = torch.norm(NTK_linear - NTK0_linear, p='fro')/NTK0_linear_norm\n",
    "        diff_norm_list.append(diff_norm.item())\n",
    "        lin_diff_norm_list.append(lin_diff_norm.item())\n",
    "        \n",
    "        loss_current = loss.item()\n",
    "        loss_list.append(loss_current)\n",
    "        \n",
    "        if n % 10 == 0:\n",
    "            loss = PINN.loss(X_u_train, u_train, X_f_train)\n",
    "            print(f'Iteration {n}, loss = {loss.item():.8e}, diff_norm = {diff_norm.item():.8e}, lin_diff_norm = {lin_diff_norm.item():.8e}')\n",
    "        \n",
    "        n += 1\n",
    "\n",
    "    assign_params(PINN, theta_n)\n",
    "    return [p.clone().detach() for p in PINN.parameters()], loss_list, diff_norm_list, lin_diff_norm_list"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Main"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sequentialmodel(\n",
      "  (activation): Tanh()\n",
      "  (loss_function): MSELoss()\n",
      "  (w_layer): Linear(in_features=2, out_features=1000, bias=False)\n",
      "  (a_layer): Linear(in_features=1000, out_features=1, bias=False)\n",
      ")\n",
      "Iteration 0, loss = 5.08316457e-01, diff_norm = 5.82173653e-02, lin_diff_norm = 0.00000000e+00\n",
      "Iteration 10, loss = 3.10451746e-01, diff_norm = 3.63071769e-01, lin_diff_norm = 0.00000000e+00\n",
      "Iteration 20, loss = 2.96594530e-01, diff_norm = 4.30609405e-01, lin_diff_norm = 0.00000000e+00\n",
      "Iteration 30, loss = 2.90033996e-01, diff_norm = 4.42348689e-01, lin_diff_norm = 0.00000000e+00\n",
      "Iteration 40, loss = 2.84337640e-01, diff_norm = 4.46129769e-01, lin_diff_norm = 0.00000000e+00\n",
      "Iteration 50, loss = 2.79253840e-01, diff_norm = 4.48785394e-01, lin_diff_norm = 0.00000000e+00\n",
      "Iteration 60, loss = 2.74673522e-01, diff_norm = 4.51203585e-01, lin_diff_norm = 0.00000000e+00\n",
      "Iteration 70, loss = 2.70510316e-01, diff_norm = 4.53490198e-01, lin_diff_norm = 0.00000000e+00\n",
      "Iteration 80, loss = 2.66694307e-01, diff_norm = 4.55653578e-01, lin_diff_norm = 0.00000000e+00\n",
      "Iteration 90, loss = 2.63168931e-01, diff_norm = 4.57693040e-01, lin_diff_norm = 0.00000000e+00\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAloAAAHHCAYAAABnS/bqAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAATV5JREFUeJzt3Xl4VOXd//HPTPZ9X8geNiEsYacoCEIqpRTFpW5UkcdKK1gXatVf+1SsdUOrDyoU7aIoYkWpe90CAhZECKsCsiZAWJKQhOxknfP7I2QkJkASZnKSzPt1XXORnDlz5jvnAuZz3fd9vsdiGIYhAAAAOJzV7AIAAAC6KoIWAACAkxC0AAAAnISgBQAA4CQELQAAACchaAEAADgJQQsAAMBJCFoAAABOQtACAABwEoIWAFPNmjVLP/7xj536Hg8//LAsFotT38NRVq9eLYvFotWrV5tdShOLFy+WxWLRwYMHzS7lnG644QZdd911ZpcBSCJoAV1Ow5fhpk2bzC7lvLKysvSPf/xDv//9780upVX++te/avHixWaXgbN44IEH9O9//1vbt283uxSAoAXAPM8995ySk5N12WWXmV1KqzgzaF166aU6deqULr30Uqcc3xUMHjxYw4YN0zPPPGN2KQBBC4A5ampqtHTp0i4/xVNeXt6q/a1Wq7y9vWW18t9za515rq+77jq98847KisrM7EigKAFuKytW7dq0qRJCgwMlL+/vyZMmKCvv/660T41NTX605/+pF69esnb21thYWEaPXq00tPT7fvk5ORoxowZiouLk5eXl7p166Yrr7zyvOt41q5dq/z8fKWlpTV5Li8vT7fddpuioqLk7e2t1NRUvfrqq432OXjwoCwWi/7yl7/ob3/7m3r06CEvLy8NHz5cGRkZ53zvsWPHKjU1tdnnLrroIk2cOPGsr01KStLOnTu1Zs0aWSwWWSwWjRs3TtL307Zr1qzRrFmzFBkZqbi4OEnSoUOHNGvWLF100UXy8fFRWFiYfv7znzc5T82t0Ro3bpz69++vXbt26bLLLpOvr69iY2P11FNPnfNzNnjllVc0fvx4RUZGysvLSykpKVq0aFGLXns+77//viZPnqyYmBh5eXmpR48e+vOf/6y6ujr7PnPnzpWHh4dOnDjR5PUzZ85UcHCwKisr7ds++eQTjRkzRn5+fgoICNDkyZO1c+fORq+79dZb5e/vrwMHDuinP/2pAgICNG3aNPvzP/7xj1VeXt7o7ypgBnezCwDQ/nbu3KkxY8YoMDBQ999/vzw8PPTSSy9p3LhxWrNmjUaOHCmpfhH5E088oV/+8pcaMWKESkpKtGnTJm3ZssW+gP2aa67Rzp079Zvf/EZJSUnKy8tTenq6Dh8+rKSkpLPW8NVXX8lisWjw4MGNtp86dUrjxo3T/v37deeddyo5OVlvv/22br31VhUVFenuu+9utP8bb7yh0tJS/epXv5LFYtFTTz2lq6++WpmZmfLw8Gj2vW+++Wbdfvvt2rFjh/r372/fnpGRob179+p///d/z1r3/Pnz9Zvf/Eb+/v76wx/+IEmKiopqtM+sWbMUERGhhx56yD7KkpGRoa+++ko33HCD4uLidPDgQS1atEjjxo3Trl275Ovre9b3lKSTJ0/qJz/5ia6++mpdd911Wr58uR544AENGDBAkyZNOudrFy1apH79+umKK66Qu7u7PvzwQ82aNUs2m02zZ88+52vPZ/HixfL399ecOXPk7++vL774Qg899JBKSkr09NNPS6o/34888oiWLVumO++80/7a6upqLV++XNdcc428vb0lSUuWLNH06dM1ceJEzZs3TxUVFVq0aJFGjx6trVu3Nvo7VVtbq4kTJ2r06NH6y1/+0ugcpqSkyMfHR+vWrdNVV111QZ8RuCAGgC7llVdeMSQZGRkZZ91n6tSphqenp3HgwAH7tmPHjhkBAQHGpZdeat+WmppqTJ48+azHOXnypCHJePrpp1td5y9+8QsjLCysyfb58+cbkozXX3/dvq26utoYNWqU4e/vb5SUlBiGYRhZWVmGJCMsLMwoLCy07/v+++8bkowPP/zQvm3u3LnGmf/dFRUVGd7e3sYDDzzQ6L3vuusuw8/PzygrKztn7f369TPGjh3bZHvDuR89erRRW1vb6LmKioom+69fv96QZLz22mv2batWrTIkGatWrbJvGzt2bJP9qqqqjOjoaOOaa645Z61ne++JEyca3bt3P+9rz9Tw+bKyss557F/96leGr6+vUVlZad82atQoY+TIkY32e+eddxp91tLSUiM4ONi4/fbbG+2Xk5NjBAUFNdo+ffp0Q5Lx4IMPnrXe3r17G5MmTWrNRwQcjqlDwMXU1dXp888/19SpU9W9e3f79m7duummm27S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ffZZDRgwQH5+foqPj9esWbNUVlYmSVq9erVmzJih4uJi+/s9/PDDkppOHR4+fFhXXnml/P39FRgYqOuuu065ubn25x9++GENGjRIS5YsUVJSkoKCgnTDDTeotLTUuScNQJsQtAC4nOeee06jRo3S7bffruPHj+v48eOKj49XUVGRxo8fr8GDB2vTpk369NNPlZubq+uuu67R61999VV5enpq3bp1evHFFyVJVqtVzz//vHbu3KlXX31VX3zxhe6//35J0sUXX6z58+crMDDQ/n733Xdfk7psNpuuvPJKFRYWas2aNUpPT1dmZqauv/76RvsdOHBA7733nj766CN99NFHWrNmjZ588kknnS0AF4KpQwAuJygoSJ6envL19VV0dLR9+4IFCzR48GA9/vjj9m0vv/yy4uPjtXfvXvXu3VuS1KtXLz311FONjnnmeq+kpCQ9+uij+vWvf62//vWv8vT0VFBQkCwWS6P3+6GVK1fq22+/VVZWluLj4yVJr732mvr166eMjAwNHz5cUn0gW7x4sQICAiRJN998s1auXKnHHnvswk4MAIdjRAsATtu+fbtWrVolf39/+6NPnz6S6keRGgwdOrTJa1esWKEJEyYoNjZWAQEBuvnmm1VQUKCKiooWv/93332n+Ph4e8iSpJSUFAUHB+u7776zb0tKSrKHLEnq1q2b8vLyWvVZAbQPRrQA4LSysjJNmTJF8+bNa/Jct27d7D/7+fk1eu7gwYP62c9+pjvuuEOPPfaYQkNDtXbtWt12222qrq6Wr6+vQ+v08PBo9LvFYpHNZnPoewBwDIIWAJfk6empurq6RtuGDBmif//730pKSpK7e8v/e9y8ebNsNpueeeYZWa31EwVvvfXWed/vh/r27avs7GxlZ2fbR7V27dqloqIipaSktLgeAB0HU4cAXFJSUpI2bNiggwcPKj8/XzabTbNnz1ZhYaFuvPFGZWRk6MCBA/rss880Y8aMc4aknj17qqamRi+88IIyMzO1ZMkS+yL5M9+vrKxMK1euVH5+frNTimlpaRowYICmTZumLVu2aOPGjbrllls0duxYDRs2zOHnAIDzEbQAuKT77rtPbm5uSklJUUREhA4fPqyYmBitW7dOdXV1uvzyyzVgwADdc889Cg4Oto9UNSc1NVXPPvus5s2bp/79+2vp0qV64oknGu1z8cUX69e//rWuv/56RURENFlML9VPAb7//vsKCQnRpZdeqrS0NHXv3l3Lli1z+OcH0D4shmEYZhcBAADQFTGiBQAA4CQELQAAACchaAEAADgJQQsAAMBJCFoAAABOQtACAABwEoIWAACAkxC0AAAAnISgBQAA4CQELQAAACchaAEAADgJQQsAAMBJ/j+y2jnV702CLAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "'Generate Training data'\n",
    "N_u = 20 #Total number of data points for 'u'\n",
    "N_f = 100 #Total number of collocation points \n",
    "X_f_train_np_array, X_u_train_np_array, u_train_np_array = trainingdata(N_u,N_f)\n",
    "\n",
    "'Convert to tensor and send to GPU'\n",
    "X_f_train = torch.from_numpy(X_f_train_np_array).float().to(device)\n",
    "X_u_train = torch.from_numpy(X_u_train_np_array).float().to(device)\n",
    "u_train = torch.from_numpy(u_train_np_array).float().to(device)\n",
    "X_u_test_tensor = torch.from_numpy(X_u_test).float().to(device)\n",
    "u = torch.from_numpy(u_true).float().to(device)\n",
    "f_hat = torch.zeros(X_f_train.shape[0],1).to(device)\n",
    "\n",
    "layers = np.array([2,1000,1]) \n",
    "\n",
    "PINN = Sequentialmodel(layers)\n",
    "       \n",
    "PINN.to(device)\n",
    "\n",
    "'Neural Network Summary'\n",
    "print(PINN)\n",
    "\n",
    "params = list(PINN.parameters())\n",
    "\n",
    "'''Optimization'''\n",
    "\n",
    "theta_init = [p.data.clone() for p in PINN.parameters()]\n",
    "K0 = 100      \n",
    "K1 = 10      \n",
    "gamma = 0.1 \n",
    "eta = 0.5   \n",
    "\n",
    "final_params, loss_list, diff_norm_list,lin_diff_norm_list = IGD_PINN_a(PINN, X_u_train, u_train, X_f_train, theta_init, K0, K1, gamma, eta)\n",
    "\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(loss_list)\n",
    "plt.yscale('log')\n",
    "plt.xlabel('Iteration')\n",
    "plt.ylabel('Loss')\n",
    "plt.title('Loss (only train a_layer)')\n",
    "plt.show()\n",
    "\n",
    "\n",
    "plt.figure(figsize=(6, 4))\n",
    "plt.plot(diff_norm_list, label='Interior NTK matrix', linewidth=2, color='#0072B2')\n",
    "plt.plot([x + 1e-12 for x in lin_diff_norm_list], label='Boundary NTK matrix', linewidth=2, color='#E69F00')\n",
    "plt.yscale('log')\n",
    "plt.ylim(1e-13, 2.0)  \n",
    "plt.xlabel('Iteration', fontsize=13)\n",
    "plt.ylabel('Relative Frobenius norm', fontsize=13)\n",
    "plt.title('Relative Frobenius norm for two NTK matrices', fontsize=14, pad=8)\n",
    "plt.yticks([1e-12, 1e-4, 1e-3, 1e-2, 1e-1, 1], \n",
    "           ['1e-12', '1e-4', '1e-3', '1e-2', '1e-1', '1'])\n",
    "\n",
    "plt.legend(loc='center right', fontsize=12, frameon=False)\n",
    "plt.grid(which='both', color='#e0e0e0', linestyle='--', linewidth=0.8, alpha=0.7)\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "python_31015",
   "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.10.15"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
