{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Solve viscous Burgers equation with ODE-ELM to show that it fails!"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('../../')\n",
    "sys.path.append('../../src')\n",
    "from swimpde import Domain\n",
    "from swimpde import BasicAnsatz\n",
    "from swimpde import BurgersSolver\n",
    "import numpy as np\n",
    "from sklearn.metrics import mean_squared_error\n",
    "import scipy.io\n",
    "from matplotlib import ticker\n",
    "import time\n",
    "import matplotlib.pyplot as plt\n",
    "plt.rcParams['image.cmap'] = 'jet'"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Load data and reference solution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load and visualize data\n",
    "data = scipy.io.loadmat('../../data/burgers_shock.mat')\n",
    "t_eval = data['t'].flatten()[:,None]\n",
    "x_eval = data['x'].flatten()[:,None]\n",
    "u_exact = np.real(data['usol']).T\n",
    "X, T = np.meshgrid(x_eval,t_eval)\n",
    "X_ = np.hstack((X.flatten()[:,None], T.flatten()[:,None]))\n",
    "\n",
    "# Set ground truth\n",
    "u_true = u_exact.flatten()[:,None]              "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Problem setup"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# initial condition\n",
    "def u0(x):\n",
    "    return -1 * np.sin(np.pi * x)\n",
    "\n",
    "# forcing\n",
    "def forcing(x, t):\n",
    "    return np.zeros(x.shape[0])\n",
    "\n",
    "# boundary condition\n",
    "boundary_condition = \"zero dirichlet\" # \n",
    "\n",
    "# Domain information and spacial points for the first time-block\n",
    "n_points_1d = 4000 # No. of points in space\n",
    "x_lim = [-1, 1] # Domain range\n",
    "\n",
    "# Interior points\n",
    "rng = np.random.default_rng(seed=123)\n",
    "x_space = rng.uniform(x_lim[0], x_lim[1], n_points_1d).reshape((-1, 1)) \n",
    "x_space_inner = x_space[1:-1]\n",
    "interior_points = x_space_inner\n",
    "\n",
    "# Boundary points (excluding corners)\n",
    "left = x_lim[0]\n",
    "right = x_lim[1]\n",
    "boundary_points = np.row_stack([left, right])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Train and evaluate ODE-ELM network"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "rmse_elm, re_elm\n",
      "0.15175027104385325 0.15175027104385325 0.24701449544694037 0.24701449544694037\n",
      "rmse_elm, re_elm\n",
      "0.15173057852918842 0.15173057852918842 0.24698244056795698 0.24698244056795698\n",
      "rmse_elm, re_elm\n",
      "0.15243588299644448 0.15243588299644448 0.24813051381960463 0.24813051381960463\n",
      "[6.187496344248454, 0.15197224418982871, 0.00032794070199099765, 0.24737581661150065, 0.0005338119430140186]\n"
     ]
    }
   ],
   "source": [
    "# Hyper-parameters\n",
    "n_sample = 6000 # No. of sampling points (for computing gradients)\n",
    "n_col = 3000 # No. of collocation points (to be re-sampled)\n",
    "width = 2000 # Width\n",
    "reg_const = 1e-7 # Regularization constant\n",
    "svd_cutoff = 1e-10 # SVD threshold\n",
    "seeds = [1, 2, 3] # Seeds (to compute mean errors)\n",
    "time_blocks = 1 # Number of time-blocks for smapling\n",
    "info = [] # List to store errors and time measurements\n",
    "\n",
    "# Compute prob. distribution for (re)-sampling collocation points\n",
    "def collocation_points_probabilities(df_dx):\n",
    "    gradients = np.abs(df_dx)\n",
    "    gradients = gradients + 0.05 * np.max(gradients)\n",
    "    return gradients/np.sum(gradients)\n",
    "\n",
    "# Points where gradient of the solution at the end of a time-block is computed\n",
    "sample_test_points = np.sort(rng.uniform(x_lim[0] + 1e-4, x_lim[1] - 1e-4, n_sample)).reshape((-1, 1)) # This does not include boundary points\n",
    "\n",
    "# Domain\n",
    "domain = Domain(\n",
    "    interior_points=interior_points,\n",
    "    boundary_points=boundary_points,\n",
    "    sample_points = sample_test_points\n",
    ")\n",
    "\n",
    "# Parameter sampler for sampling of weights and biases using data-agnostic distribution\n",
    "def parameter_sampler_uniform(x, y, rng):\n",
    "    \"\"\"\n",
    "        returns: weights, biases, idx_from, idx_to\n",
    "    \"\"\"\n",
    "    n_dim = 1\n",
    "    x_left = -3\n",
    "    x_right = 3\n",
    "    # Sample weights from a normal distribution\n",
    "    weights = rng.normal(size=(n_dim, width)) #rng.uniform(x_left, x_right, size=(n_dim, n_OBF))\n",
    "    # Sample biases from a uniform distribution\n",
    "    biases = rng.uniform(x_left, x_right, size=(1, width))\n",
    "    idx_from = np.arange(width)\n",
    "    idx_to = np.arange(width)\n",
    "    return weights, biases, idx_from, idx_to\n",
    "\n",
    "# Loop over different seeds\n",
    "rel_err_elm = np.ones((len(seeds), ))\n",
    "time_elm = np.ones((len(seeds), ))\n",
    "rmse_elm = np.ones((len(seeds), ))\n",
    "j = 0\n",
    "\n",
    "# Loop over different seeds\n",
    "for seed in seeds: # Run for 3 seeds \n",
    "    # ODE-ELM network ansatz                     \n",
    "    ansatz_elm = BasicAnsatz(\n",
    "        n_neurons=width,\n",
    "        activation=\"tanh\",\n",
    "        random_state=seed,\n",
    "        regularization_scale=reg_const,\n",
    "        parameter_sampler = parameter_sampler_uniform  \n",
    "    )\n",
    "    # Burger solver\n",
    "    burgers_solver_elm = BurgersSolver(\n",
    "        domain=domain, \n",
    "        ansatz=ansatz_elm,\n",
    "        u0=u0,\n",
    "        boundary_condition=boundary_condition,\n",
    "        forcing=forcing,\n",
    "        regularization_scale=reg_const,\n",
    "        c=(0.01/np.pi)\n",
    "    )\n",
    "    # ELM fit\n",
    "    t_elm_start = time.time()\n",
    "    sol_elm, solver_status_elm = burgers_solver_elm.fit_time_blocks(t_span=[0, np.max(t_eval)], rtol=1e-8, atol=1e-8, svd_cutoff=svd_cutoff, time_blocks=time_blocks, prob_distr_resampling = collocation_points_probabilities, n_col=n_col, outer_basis=False);\n",
    "    t_elm_stop = time.time()\n",
    "    time_elm[j] = t_elm_stop - t_elm_start\n",
    "    # Evaluate ELM-ODE predictions\n",
    "    u_elm = (burgers_solver_elm.evaluate_blocks(x_eval= x_eval, t_eval = t_eval, time_blocks = time_blocks, solver_status = solver_status_elm)).T\n",
    "    # Compute metrics\n",
    "    mse_elm = mean_squared_error(u_true, u_elm.flatten()[:,None])  # mean squared error\n",
    "    rmse_elm[j] = np.sqrt(mse_elm)  # Root Mean Squared Error\n",
    "    rel_err_elm[j] = np.linalg.norm(u_true-u_elm.flatten()[:,None], 2)/np.linalg.norm(u_true,2)\n",
    "    print(\"rmse_elm, re_elm\")\n",
    "    print(rmse_elm[j], rmse_elm[j], rel_err_elm[j], rel_err_elm[j])\n",
    "    j += 1\n",
    "\n",
    "info.append(np.mean(time_elm))\n",
    "info.append(np.mean(rmse_elm))\n",
    "info.append(np.std(rmse_elm))\n",
    "info.append(np.mean(rel_err_elm))\n",
    "info.append(np.std(rel_err_elm))\n",
    "print(info)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Burgers equation: Errors and time measurements using ode-elm\n",
      "training time for ode-elm =  6.187496344248454\n",
      "rmse ode-elm =  0.15197224418982871 +- 0.00032794070199099765\n",
      "rel error ode-elm =  0.24737581661150065 +- 0.0005338119430140186\n"
     ]
    }
   ],
   "source": [
    "# Print errors and time measurements for Burgers with ODE-ELM\n",
    "res = np.vstack(info).reshape(-1)\n",
    "\n",
    "# Burgers time measurements\n",
    "print('Burgers equation: Errors and time measurements using ode-elm')\n",
    "print('training time for ode-elm = ', res[-5])\n",
    "print('rmse ode-elm = ', res[-4], '+-', res[-3])\n",
    "print('rel error ode-elm = ', res[-2], '+-', res[-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Relative L2 error on the entire spatio-temporal domain: 2.481305e-01\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\chinm\\AppData\\Local\\Temp\\ipykernel_14040\\841674867.py:69: UserWarning: The figure layout has changed to tight\n",
      "  fig.tight_layout()\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAf8AAACwCAYAAAABiGezAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABlWElEQVR4nO2deZwUxfn/37Nz7829gAhyiIo3BAISQSGiogmJiqKJYBS88E6MJlE0+tWvV0JUiGi+QvITgkfQGM8giiZqUBG8UCKIIOCCyLHnzOzM1O+Pnp6p7unu6Vl22GW3Pq9Xv+rsqurpZ+o56qlqjxBCoKCgoKCgoNBhUNTaA1BQUFBQUFDYt1DMX0FBQUFBoYNBMX8FBQUFBYUOBsX8FRQUFBQUOhgU81dQUFBQUOhgUMxfQUFBQUGhg0ExfwUFBQUFhQ4GxfwVFBQUFBQ6GBTzV1BQUFBQ6GBQzH8/hcfj4ZZbbmntYdiiX79+nHbaaa09DIVWwvLly/F4PCxfvrxF2502bRr9+vVr0TYVrPHll1/i8Xi4995792m/6h3vG7Rr5r9hwwZmzpzJwQcfTHFxMcXFxRx22GFcfvnlfPjhh609vIJj69at3HLLLaxevbog7a9Zs4ZbbrmFL7/8siDtt0csWLAAj8dje/3nP/9J1/V4PMycOdOxvbFjx+LxeBg0aJBl+dKlS9NtP/XUUy36LIVCoelWQcPcuXPxeDyMGDGitYfSYnjhhRfatFLUluBr7QEUCs899xxnn302Pp+P8847j6OOOoqioiI+++wzlixZwh//+Ec2bNhA3759W3uoBcPWrVu59dZb6devH0cffXSLt79mzRpuvfVWxo4dqyT1PPHb3/6Wgw46KCt/4MCBebcVCoVYt24d77zzDsOHDzeULVy4kFAoRCQSafZY9zWc6PaRRx4hmUy2zsDaGRYuXEi/fv145513WLduXbNor63hhRdeYM6cOUoAcIF2yfzXr1/POeecQ9++fVm2bBk9e/Y0lN91113MnTuXoiJnw0d9fT0lJSWFHGqbQkNDA8XFxa09jA6BU045hWHDhrVIWwMGDCAej/PXv/7VwPwjkQhPP/00EydO5G9/+1uL9NXa8Pv9rT2EdoENGzbw1ltvsWTJEi6++GIWLlzIrFmzWntY7RJOfGRv59x4PE4ymSQQCOR9b7s0+999993U19czf/78LMYP4PP5uPLKK+nTp086b9q0aZSWlrJ+/XpOPfVUysrKOO+88wDt5V133XX06dOHYDDI4MGDuffee5E/iKivjy1YsCCrP/P6/C233ILH42HdunVMmzaNyspKKioquOCCC2hoaDDcG41Gueaaa+jWrRtlZWX84Ac/YPPmzTl/g+XLl/Od73wHgAsuuCBt+tXHN3bsWA4//HBWrlzJ8ccfT3FxMb/61a8sx6ujX79+TJs2DdDM12eddRYAJ5xwQrp98xrvv//9b4YPH04oFKJ///785S9/yTl2hfwxZcoUHn/8cYNW/I9//IOGhgYmT57sup0HHniAIUOGUFxcTKdOnRg2bBiLFi0y1Fm1ahWnnHIK5eXllJaWMm7cOMNyhR1k+pExduxYxo4dC+SmW6v1YDf/T8gsozzzzDMcfvjhBINBhgwZwksvveTux2lHWLhwIZ06dWLixImceeaZLFy40LH+73//e/r27Us4HGbMmDF8/PHHhvLq6mouuOACDjjgAILBID179uSHP/xh1pLg3LlzGTJkCMFgkF69enH55Zeze/dux77t/EfMc+60adOYM2cOgGEpTUcymWT27NkMGTKEUChEjx49uPjii9m1a5dj/zo+++wzzjzzTDp37kwoFGLYsGE8++yzhjr6st7rr7/OZZddRvfu3TnggAMA5zl3+/btXHjhhfTo0YNQKMRRRx3Fn//8Z8vnvffee5k9ezYDBgwgGAyyZs0aV+M3o11q/s899xwDBw7Mey0rHo8zYcIERo8ezb333ktxcTFCCH7wgx/w2muvceGFF3L00Ufz8ssv84tf/IItW7bw+9//vtnjnDx5MgcddBB33nkn77//Pn/605/o3r07d911V7rORRddxGOPPca5557LqFGjePXVV5k4cWLOtg899FB++9vfcvPNNzNjxgy+973vATBq1Kh0nW+//ZZTTjmFc845h5/85Cf06NHD9diPP/54rrzySu6//35+9atfceihh6b71bFu3TrOPPNMLrzwQqZOncqjjz7KtGnTGDp0KEOGDHHdV3vEnj172LFjhyHP4/HQpUuXZrV37rnncsstt7B8+XJOPPFEABYtWsS4cePo3r27qzYeeeQRrrzySs4880yuuuoqIpEIH374IStWrODcc88F4JNPPuF73/se5eXlXH/99fj9fubNm8fYsWN5/fXX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z3/OhAkTLOuYt0naza35zrmFagPaIfMHmDhxIn/6058s9z3ni759+/LKK69QW1tr0C4+++yzdDlktHaz5+reSLR9+/YlmUyyfv16g8S8du1aV/fb/WlyoVOnTlnPEYvF+Prrr1ukfYXC4dxzz+Wiiy6isrKSU089Ne/7S0pKOPvsszn77LOJxWL8+Mc/5n/+53+48cYb6datG8XFxZb099lnn1FUVGTYQWOGFV2B9h+RlxHyoSu3/08FDQsXLqR79+6WS55Llizh6aef5qGHHjIwmM8//zyr7n//+9+sXRcDBgzguuuu47rrruPzzz/n6KOP5r777uOxxx5Lv4e1a9ca3nUsFmPDhg2MHz/edsz5zK12tDNgwABeeeUVjjvuuLyZpz5ev9/vOM7mom/fvnz44Yckk0mD8lloGm53Zn+A66+/nuLiYn72s5+xbdu2rPJ8pPxTTz2VRCLBgw8+aMj//e9/j8fj4ZRTTgGgvLycrl278sYbbxjqzZ07txlPoEFv+/777zfkz54929X9+t7SXFtpzBgwYEDWczz88MNZknZz21coHM4880xmzZrF3Llz817S+fbbbw3pQCDAYYcdhhCCpqYmvF4vJ510En//+98N1rNt27axaNEiRo8eTXl5uW37AwYM4D//+Q+xWCyd99xzz2UtFeRDV27/nwrQ2NjIkiVLOO200zjzzDOzrpkzZ1JbW5u1fe2ZZ54xrGm/8847rFixIv3bNjQ0ZB0iNWDAAMrKyohGo4DmaxEIBLj//vsN8+///d//sWfPHscdTH379sXr9bqaW+1oZ/LkySQSCW677base+LxuCOtde/enbFjxzJv3rwsBQi05bC9wamnnkp1dTWPP/64YUwPPPAApaWljBkzZq/at0O71PwHDRrEokWLmDJlCoMHD06f8CeEYMOGDSxatIiioqKs9X0rnH766Zxwwgn8+te/5ssvv+Soo47in//8J3//+9+5+uqrDevxF110Ef/7v//LRRddxLBhw3jjjTf473//2+znOProo5kyZQpz585lz549jBo1imXLlrFu3TpX9w8YMIDKykoeeughysrKKCkpYcSIETnXjC666CIuueQSzjjjDL7//e/zwQcf8PLLL9O1a9es8Xm9Xu666y727NlDMBjkxBNPdL21rCPjxRdfTEv2MkaNGmXQjN577z1uv/32rHpj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ZDFx4kRD3ogRI8TFF1+cVXfDhg0CEKtWrXJsUwghfvnLX4rRo0c71olEIuK6664TvXr1EsXFxWL48OHitddec7zn+uuvF0OGDDHknX322WLChAmW9QtJvx1K83cjnZpx/vnns3btWp599lk++ugjfvzjHzN58mRWrVrVImPKV4p3I+kWAvmOc9GiRdxwww3MmjWLTz/9lP/7v//j8ccf51e/+lVBx9keEYvFOOuss7j00ktbeyhAy2ueLY19pjm1AmKxGCtXrmT8+PHpvKKiIsaPH8/bb78NwFlnncX27dt58cUXWblyJcceeyzjxo1j5878P1qyYcMGqqurDf1VVFQwYsSIdH9vv/02lZWVDBs2LF1n/PjxFBUVsWLFCst2E4kEixcvpr6+npEjRzZ73G+//bZhbAATJkxIj625ePbZZxk2bBhnnXUW3bt355hjjuGRRx4x1Jk5cyZvv/02ixcv5sMPP+Sss87i5JNPzloS2RfjbRYKIlK0QTRXOi0pKRF/+ctfDHmdO3cWjzzySIuMK5cUb0Y+km5LIt9xXn755eLEE0805F177bXiuOOOK+g42zPmz5/fJjT/fGmhNUE70/y3bNkiAPHWW28Z8n/xi1+I4cOHi3/961+ivLxcRCIRQ/mAAQPEvHnzLNt00vzffPNNAYitW7ca8s866ywxefJkIYQQ//M//yMOPvjgrHu7desm5s6da8j78MMPRUlJifB6vaKioiJttWzOuIUQwu/3i0WLFhny5syZI7p3755VNx/NPxgMimAwKG688Ubx/vvvi3nz5olQKCQWLFgghBBi48aNwuv1ZvGOcePGiRtvvNG23UGDBok77rjDkPf8888LQDQ0NGTVLyT9dhjNvznSKcCoUaN4/PHH2blzJ8lkksWLFxOJRBg7duxej8mNFG/1HPtacmzOOEeNGsXKlSvTjkhffPEFL7zwAqeeemrBxqlQeDSHFhT2HT744APq6uro0qULpaWl6WvDhg2sX78egH/961+GsjvuuIOFCxca8hYuXFiQ8Q0ePJjVq1ezYsUKLr30UqZOncqaNWtyjnvTpk1ZYy4kkskkxx57LHfccQfHHHMMM2bMYPr06Tz00EMAfPTRRyQSCQ4++GDDuF5//fX07yznX3LJJQUdb3PQYU74q66upnv37oY8n89H586dqa6utr3viSee4Oyzz6ZLly74fD6Ki4t5+umnGThw4F6PaceOHSQSCXr06GHI79GjB5999pntc1jVd3qG1hjnueeey44dOxg9ejRCCOLxOJdccoky++/naA4tKLQcunbtitfrZdu2bYb8bdu2UVVVRV1dHT179mT58uVZ91ZWVgIwbNgwg8f7/fffz5YtWwwOcfr7raqqSrffs2dPQ39HH310uo55yScej7Nz5870/ToCgUB67hw6dCjvvvsuf/jDH+jfv7/juCsrKw1j7ty5c7pvu99ib9CzZ08OO+wwQ96hhx7K3/72NwDq6urwer2sXLkSr9drqFdaWgpgGK/+YSm78ZaXlxMOh/dqzPliv9f8b7jhBjwej+O1N5PSTTfdxO7du3nllVd47733uPbaa5k8eTIfffRRCz5F+8Py5cu54447mDt3Lu+//z5Llizh+eef57bb8vyWfTtFoelWoX0iEAgwdOhQli1bls5LJpMsW7aMkSNHcuyxx1JdXY3P52PgwIGGq2vXrgCEw2FDfufOnSkrKzPklZWVAXDQQQdRVVVl6K+mpoYVK1ak1+pHjhzJ7t27WblyZbrOq6++SjKZZMSIEY7Pk0wmiUajOcdtzteZ/8iRIw1jA1i6dGl6bM3Fcccdx9q1aw15//3vf+nbty8AxxxzDIlEgu3bt2eNVxc85Dxd8SzUeJuD/V7zv+666xy3qQD0798/L+lUx/r163nwwQf5+OOPGTJkCABHHXUU//rXv5gzZ07aBNRc5JLirVAoSbelx3nTTTfx05/+lIsuugiAI444gvr6embMmMGvf/1rior2e7lzr+CWbtsamkMLCi2La6+9lqlTpzJs2DCGDx/O7Nmzqa+v54ILLqB79+6MHDmSSZMmcffdd3PwwQezdetWnn/+eX70ox8Zlj3dwOPxcPXVV3P77bczaNAgDjroIG666SZ69erFpEmTAE0jPvnkk9Nm8aamJmbOnMk555xDr1690m3deOONnHLKKRx44IHU1tayaNEili9fzssvv8z48eObNe6rrrqKMWPGcN999zFx4kQWL17Me++9x8MPP5yus3PnTjZt2sTWrVsB0ky9qqrKlmavueYaRo0axR133MHkyZN55513ePjhh9PtHnzwwZx33nmcf/753HfffRxzzDF88803LFu2jCOPPJKJEydatnvJJZfw4IMPcv311/Ozn/2MV199lSeeeILnn38+Xaeuro5169al0xs2bGD16tV07tyZAw88MNcrc4+CeBK0QegOf++991467+WXX3Z0+Pvwww8FINasWWPIP+mkk8T06dNbZFzDhw8XM2fOTKcTiYTo3bu3o8PfaaedZsgbOXLkPnH4y2ecxx57rLj++usNeYsWLRLhcFjE4/GCjrW9oi05/OVDC60J2pnDn44HHnhAHHjggSIQCIjhw4eL//znP+mympoaccUVV4hevXoJv98v+vTpI8477zyxadMmy7acHP6E0Lb73XTTTaJHjx4iGAyKcePGibVr1xrqfPvtt2LKlCmitLRUlJeXiwsuuCBrG/XPfvYz0bdvXxEIBES3bt3EuHHjxD//+c9mj1vHE088IQ4++GARCATEkCFDsrY+z58/XwBZ16xZsxzb/cc//iEOP/xwEQwGxSGHHCIefvhhQ3ksFhM333yz6Nevn/D7/aJnz57iRz/6kfjwww8d233ttdfE0UcfLQKBgOjfv7+YP39+VrnVeJ3eUXPQYZi/EEKcfPLJ4phjjhErVqwQ//73v8WgQYPElClT0uWbN28WgwcPTu9ZjsViYuDAgeJ73/ueWLFihVi3bp249957hcfjabG99YsXLxbBYFAsWLBArFmzRsyYMUNUVlaK6upqIYQQP/3pT8UNN9yQrv/mm28Kn88n7r33XvHpp5+KWbNmCb/fLz766KMWGU9LjXPWrFmirKxM/PWvfxVffPGF+Oc//ykGDBiQ9hBWcI+NGzeKVatWiVtvvVWUlpaKVatWiVWrVuU8o6JQyEULrY3a2tr0bwSI3/3ud2LVqlVi48aNrT00BYU2gw7F/HNJp/pWEPmghv/+97/ixz/+sejevbsoLi4WRx55ZNbWv72FkxQ/ZsyYLIkvl6RbKOQzzqamJnHLLbeIAQMGiFAoJPr06SMuu+wysWvXrn0y1vaEqVOnWmoCuQ4UKSScaKG1sa80JwWF/Rnqk74KCgoKCgodDB3b60pBQUFBQaEDQjF/BQUFBQWFDgbF/BUUFBQUFDoYFPNXUFBQUFDoYFDMX0FBQUFBoYNBMX8FBQUFBYUOBsX8FRQUFBQUOhgU81dQUFBQUOhgUMxfQUFBQUGhg0ExfwUFBQUFhQ4GxfwVFBQUFBQ6GBTzV1BQUFBQ6GD4/zW8BCFjOffcAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 500x400 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAk4AAAEOCAYAAAB/6ZgEAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABy20lEQVR4nO3dd3iTVfvA8W/SXbqglA0te4ksAdkgS4YCDpbKUFARXkBQEfUVURFQUFzoz/HKUNwCioKDKXvvDWWWPToo3ef3x2lWF+lKmvT+XFevPnny5HlO2pzkzhn3MSilFEIIIYQQ4raMzi6AEEIIIYSrkMBJCCGEEMJOEjgJIYQQQthJAichhBBCCDtJ4CSEEEIIYScJnIQQQggh7CSBkxBCCCGEnSRwEkIIIYSwkwROQgghhBB2ksBJCCGEEMJOEjgJIYQQQthJAichhBBCCDtJ4CSEEEIIYScJnIQQQggh7CSBkyh2DAYDr732mrOLka2IiAh69erl7GIIkSvPPPMMXbp0cXYxioQOHTrQoUMH8+2TJ09iMBiYO3duoV73xRdfpEWLFoV6DSGBk8hGZGQko0ePplatWvj7++Pv70+9evUYNWoUe/bscXbxCl1UVBSvvfYau3btKpTzHzhwgNdee42TJ08WyvnF7c2dOxeDwZDtz6ZNm8zHGgwGRo8eneP5OnTogMFgoGbNmlne//fff5vP/dNPP9ldzps3b/LGG29w55134u/vT3BwMG3btmX+/PkopTIdb/0cPD09KVWqFE2bNmXs2LEcOHAg0/GmD/XsfqZPn37bMkZGRvLFF1/w0ksv2f28RMEbN24cu3fv5tdff3V2Udyap7MLIIqepUuX0r9/fzw9PXnkkUdo2LAhRqORQ4cO8csvv/DJJ58QGRlJeHi4s4taaKKiopgyZQoRERE0atSowM9/4MABpkyZQocOHYiIiCjw8wv7vf7661StWjXT/ho1auT6XL6+vhw7dowtW7bQvHlzm/u++eYbfH19SUhIsPt8Fy9epFOnThw8eJABAwYwevRoEhIS+PnnnxkyZAh//PEH33zzDR4eHjaP69KlC4MHD0YpRXR0NLt372bevHnMmTOHGTNmMH78+EzXGjhwID169Mi0v3Hjxrct5/vvv0/VqlXp2LGj3c+tOAkPD+fWrVt4eXkV6nXKlStH7969mTlzJvfff3+hXqs4k8BJ2Dh+/DgDBgwgPDycFStWUL58eZv7Z8yYwZw5czAac26svHnzJiVKlCjMohYp8fHx+Pv7O7sYIg+6d+/OXXfdVSDnql69OikpKXz77bc2gVNCQgKLFi2iZ8+e/Pzzz3afb8iQIRw8eJBFixbZfBCOGTOG559/npkzZ9K4cWMmTpxo87hatWrx6KOP2uybPn069913HxMmTKBOnTqZgqQmTZpkeow9kpOT+eabb3j66adve2xCQgLe3t63ff9wNwaDAV9fX4dcq1+/fjz88MOcOHGCatWqOeSaxU3xevWK23r77be5efMmX331VaagCcDT05MxY8ZQuXJl876hQ4cSEBDA8ePH6dGjB4GBgTzyyCOADqAmTJhA5cqV8fHxoXbt2sycOdOmiyGn/v+M45Fee+01DAYDx44dY+jQoYSEhBAcHMywYcOIj4+3eWxiYiLPPvssYWFhBAYGcv/993P27Nnb/g1Wr15Ns2bNABg2bJi5y8JUvg4dOnDHHXewfft22rVrh7+/v7mLIrvxUxEREQwdOhTQXUQPP/wwAB07djSff/Xq1TaPWbduHc2bN8fX15dq1aoxf/7825ZdON/AgQP5/vvvSUtLM+/77bffiI+Pp1+/fnafZ9OmTfz5558MHTo0y9aDadOmUbNmTWbMmMGtW7due77Q0FC+++47PD09mTp1qt3luJ1169Zx5coVOnfubLN/9erVGAwGvvvuO1555RUqVqyIv78/MTExAGzevJl7772X4OBg/P39ad++PevXr7c5R2xsLOPGjSMiIgIfHx/KlClDly5d2LFjh/mYf//9l4cffpgqVarg4+ND5cqVefbZZzP9TUzvU6dPn6ZXr14EBARQsWJFPv74YwD27t3LPffcQ4kSJQgPD2fhwoU2jzd17a5du5annnqK0NBQgoKCGDx4MNevX8/xb5TVe5ypPOfOnaNPnz4EBAQQFhbGc889R2pqqs3jr169ymOPPUZQUBAhISEMGTKE3bt3Z/m+afo/LFmyJMcyibyTwEnYWLp0KTVq1Mj1AMOUlBS6detGmTJlmDlzJg8++CBKKe6//37ee+897r33Xt59911q167N888/n2VXQW7069eP2NhYpk2bRr9+/Zg7dy5TpkyxOWb48OHMnj2brl27Mn36dLy8vOjZs+dtz123bl1ef/11AJ588kkWLFjAggULaNeunfmYq1ev0r17dxo1asTs2bNz1UXRrl07xowZA8BLL71kPn/dunXNxxw7doyHHnqILl26MGvWLEqWLMnQoUPZv3+/3dcR9omOjubKlSs2P1evXs3z+QYNGsT58+dtAuGFCxfSqVMnypQpY/d5fvvtNwAGDx6c5f2enp4MGjSI69evZwo4slOlShXat2/Ppk2bzAGMSXx8fKa/w5UrV0hJScnxnBs2bMBgMGTbpffGG2/w+++/89xzz/HWW2/h7e3NypUradeuHTExMUyePJm33nqLGzducM8997BlyxbzY59++mk++eQTHnzwQebMmcNzzz2Hn58fBw8eNB/z448/Eh8fz8iRI/nwww/p1q0bH374YZZ/t9TUVLp3707lypV5++23iYiIYPTo0cydO5d7772Xu+66ixkzZhAYGMjgwYOJjIzMdI7Ro0dz8OBBXnvtNQYPHsw333xDnz59shxvdjupqal069aN0NBQZs6cSfv27Zk1axafffaZ+Zi0tDTuu+8+vv32W4YMGcLUqVM5f/48Q4YMyfKcwcHBVK9e3e7XhMgDJQpM06ZKVaxYdH6aNs1d+aOjoxWg+vTpk+m+69evq8uXL5t/4uPjzfcNGTJEAerFF1+0eczixYsVoN58802b/Q899JAyGAzq2LFjSimlIiMjFaC++uqrTNcF1OTJk823J0+erAD1+OOP2xzXt29fFRoaar69a9cuBahnnnnG5rhBgwZlOmdWtm7dmm2Z2rdvrwD16aef3ra8JuHh4WrIkCHm2z/++KMC1KpVq7I8FlBr164177t06ZLy8fFREyZMyLHcDjdrln0vxvvuy/zY++6z77GzZtk+LiYm5/vt9NVXXykgyx8fHx+bYwE1atSoHM/Xvn17Vb9+faWUUnfddZd64oknlFK67nh7e6t58+apVatWKUD9+OOPty1fnz59FKCuX7+e7TG//PKLAtQHH3xgd1nHjh2rALV7926llKX+ZfezcePGHMv56KOP2tQ9E9NzrVatms37RVpamqpZs6bq1q2bSktLM++Pj49XVatWVV26dDHvCw4Ovu3f3frcJtOmTVMGg0GdOnXKvM/0PvXWW2+Z912/fl35+fkpg8GgvvvuO/P+Q4cOZarLptdL06ZNVVJSknn/22+/rQC1ZMkS87727dur9u3bm29n9R5nKs/rr79uU/bG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dHVRMJYtW2ZuBbXWqlUrm7E027Zt480338x0XIcOHWjTpk2m/cHBwfleE3H+/Pl06tSJ3r17M2jQINq2bUtiYiK//PILq1evpn///jz//POZHnfkyBG+/vprlFLExMSwe/dufvzxR+Li4nj33Xe59957Mz1mx44dfP3115n2V69enZYtW2ZbxjZt2hAaGso///zDPffcc9vnZDQa+eKLL+jevTv169dn2LBhVKxYkXPnzrFq1SqCgoL47bffiI2NpVKlSjz00EM0bNiQgIAA/vnnH7Zu3cqsWbMA3dpVvXp1nnvuOc6dO0dQUBA///xzoY4FTEpKolOnTvTr14/Dhw8zZ84c2rRpU2iZuvv06UPz5s2ZMGECx44do06dOvz666/msXEZW6//+ecflFL07t27UMojkHQEImvHjh1TI0eOVDVq1FC+vr7Kz89P1alTRz399NNq165dNscOGTJElShRIsvzxMbGqmeffVZVqFBBeXl5qZo1a6p33nnHZhqyUnpK8RNPPKGCg4NVYGCg6tevn7p06VK26QguX75s83jTVOHIyEjzvlu3bqkxY8ao0NBQVaJECXXfffepM2fO2JWOQCmllixZourVq6c8PT1tpv1aTzvPKDU1VU2cOFGVLl1a+fv7q27duqljx45lSkeglFKff/65qlatmvLw8LBJTRAeHq569uyZ6dwZpziL/MkpHQEZpnnndNwbb7yhlMr5dWGSm3QEJrGxseq1115T9evXV35+fiowMFC1bt1azZ07N1M9ylhWo9GoQkJCVOPGjdXYsWPV/v37Mx1/u3QEGV+3WRkzZoyqUaNGrp7rzp071QMPPKBCQ0OVj4+PCg8PV/369VMrVqxQSimVmJionn/+edWwYUMVGBioSpQooRo2bKjmzJljc54DBw6ozp07q4CAAFW6dGk1YsQItXv37iyn/2f1PpXd/y1jPTS9XtasWaOefPJJVbJkSRUQEKAeeeQRdfXq1UzntCcdQVblMb3HWbt8+bIaNGiQCgwMVMHBwWro0KFq/fr1CrBJo6CUUv3791dt2rTJdF5RcAxKFbXRpkIIIVzJiRMnqFOnDsuWLaNTp07OLk6hmDt3LsOGDWPr1q0FPgszLxYvXkzfvn1Zt26deYzbhQsXqFq1Kt999520OBUiGeMkhBAiX6pVq8YTTzzB9OnTnV0Ut5Rx+ZjU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",
      "text/plain": [
       "<Figure size 600x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# True and model solutions\n",
    "error_u = np.linalg.norm(u_true-u_elm.flatten()[:,None]  ,2)/np.linalg.norm(u_true,2)\n",
    "print('Relative L2 error on the entire spatio-temporal domain: %e' % (error_u))\n",
    "\n",
    "# visualize the solution\n",
    "fig, ax = plt.subplots(1, 3, figsize=(5, 4), constrained_layout=True)\n",
    "fontsize = 14\n",
    "extent = [0 , 1, np.min(x_space), np.max(x_space)]\n",
    "aspect = 0.3\n",
    "sol_img1 = ax[0].imshow(u_exact.T, extent=extent, origin='lower', aspect=aspect)#, vmin=vlim[0], vmax=vlim[1]\n",
    "sol_img2 = ax[1].imshow(u_elm.T, extent=extent, origin='lower', aspect=aspect)#, vmin=vlim[0], vmax=vlim[1]\n",
    "error_img = ax[2].imshow(abs(u_elm - u_exact).T,  extent=extent, origin='lower', aspect=aspect)\n",
    "ax[0].axvline(x=0.25, color='k', linestyle='--', linewidth=2)\n",
    "ax[0].axvline(x=0.5, color='k', linestyle='--', linewidth=2)\n",
    "ax[0].axvline(x=0.75, color='k', linestyle='--', linewidth=2)\n",
    "ax[1].axvline(x=0.33, color='gray', linestyle='dotted', linewidth=3)\n",
    "ax[1].axvline(x=0.66, color='gray', linestyle='dotted', linewidth=3)\n",
    "cbar_true = fig.colorbar(sol_img1, ax=ax[0], location='bottom')\n",
    "cbar_elm = fig.colorbar(sol_img2, ax=ax[1], location='bottom')\n",
    "cbar_err = fig.colorbar(error_img, ax=ax[2], location='bottom', format='%.0e', fraction=0.046)\n",
    "\n",
    "tick_locator_err = ticker.MaxNLocator(nbins=2)\n",
    "cbar_err.locator = tick_locator_err\n",
    "cbar_err.update_ticks()\n",
    "\n",
    "tick_locator_elm = ticker.MaxNLocator(nbins=2)\n",
    "cbar_elm.locator = tick_locator_elm\n",
    "cbar_elm.update_ticks()\n",
    "\n",
    "tick_locator_true = ticker.MaxNLocator(nbins=2)\n",
    "cbar_true.locator = tick_locator_true\n",
    "cbar_true.update_ticks()\n",
    "\n",
    "ax[0].set_title('Ground truth')\n",
    "ax[1].set_title('ELM-ODE')\n",
    "ax[2].set_title('Absolute error')\n",
    "fig.savefig(\"burgers_elm_ode_1.pdf\")\n",
    "\n",
    "fig, ax = plt.subplots(1, 3, figsize=(6,3), constrained_layout=True)\n",
    "ax[0].plot(x_eval,u_exact[25,:], 'b-', linewidth = 2, label = 'Ground truth')       \n",
    "ax[0].plot(x_eval,u_elm[25,:], 'r--', linewidth = 2, label = 'ELM-ODE (resampling)')\n",
    "ax[0].set_xlabel('$x$', fontsize = 14)\n",
    "ax[0].set_ylabel('$u(t,x)$', fontsize = 14)    \n",
    "ax[0].set_title('$t = 0.25$', fontsize = 14)\n",
    "ax[0].axis('square')\n",
    "ax[0].set_xlim([-1.1,1.1])\n",
    "ax[0].set_ylim([-1.1,1.1])\n",
    "    \n",
    "ax[1].plot(x_eval,u_exact[50,:], 'b-', linewidth = 2, label = 'Ground truth')       \n",
    "ax[1].plot(x_eval,u_elm[50,:], 'r--', linewidth = 2, label = 'ELM-ODE (resampling)')\n",
    "ax[1].set_xlabel('$x$', fontsize = 14)\n",
    "ax[1].set_ylabel('$u(t,x)$', fontsize = 14)\n",
    "ax[1].axis('square')\n",
    "ax[1].set_xlim([-1.1,1.1])\n",
    "ax[1].set_ylim([-1.1,1.1])\n",
    "ax[1].set_title('$t = 0.50$', fontsize = 14)\n",
    "    \n",
    "ax[2].plot(x_eval,u_exact[75,:], 'b-', linewidth = 2, label = 'Ground truth')       \n",
    "ax[2].plot(x_eval,u_elm[75,:], 'r--', linewidth = 2, label = 'ELM-ODE (resampling)')\n",
    "ax[2].set_xlabel('$x$', fontsize = 14)\n",
    "ax[2].set_ylabel('$u(t,x)$', fontsize = 14)\n",
    "ax[2].axis('square')\n",
    "ax[2].set_xlim([-1.1,1.1])\n",
    "ax[2].set_ylim([-1.1,1.1])    \n",
    "ax[2].set_title('$t = 0.75$', fontsize = 14)\n",
    "\n",
    "# Create a single legend for all plots\n",
    "fig.legend(*ax[1].get_legend_handles_labels(),loc='upper center', ncol=2, fontsize = 12, frameon=False)\n",
    "fig.tight_layout()\n",
    "fig.savefig(\"burgers_elm_ode_2.pdf\", bbox_inches='tight')\n",
    "    "
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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.12.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
