{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Solving non-linear diffusion equation using Frozen-PINNs (Hyper-param study)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Imports\n",
    "import sys\n",
    "data_path = '../../../'\n",
    "sys.path.append(data_path)\n",
    "sys.path.append(data_path + 'src')\n",
    "from sklearn.preprocessing import MinMaxScaler\n",
    "from swimpde import Domain\n",
    "from swimpde import BasicAnsatz\n",
    "from swimpde import Nonlinear_Diffusion_Solver\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.metrics import mean_squared_error\n",
    "import matplotlib.cm as cm\n",
    "np.random.seed(2)\n",
    "import time\n",
    "cmap = cm.jet\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Read and scale data\n",
    "scaler = MinMaxScaler(feature_range=(0.65, 0.9))\n",
    "\n",
    "# Training data\n",
    "data_boundary = np.load(data_path + 'data/nature_inspired_dataset/nature_inspired_boundary_1000.npy')\n",
    "data_interior = np.load(data_path + 'data/nature_inspired_dataset/nature_inspired_interior_1000.npy')\n",
    "\n",
    "data_full = np.vstack((data_boundary, data_interior))\n",
    "data_new = scaler.fit_transform(data_full)\n",
    "data_boundary = data_new[:np.shape(data_boundary)[0], :]\n",
    "data_interior = data_new[np.shape(data_boundary)[0]::, :]\n",
    "\n",
    "# Test data\n",
    "data_eval = np.load(data_path + 'data/nature_inspired_dataset/nature_inspired_eval.npy')\n",
    "x_eval = scaler.fit_transform(data_eval)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Problem setup"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [],
   "source": [
    "import math\n",
    "# initial condition\n",
    "def u0(x):\n",
    "    return np.sin(np.pi * x[:, 0]) * x[:, 1]**-3  \n",
    "\n",
    "# forcing\n",
    "def forcing(x, t):    \n",
    "    return np.exp(-t) * np.sin(np.pi * x[:, 0]) * x[:, 1]**(-3) * (-1. - (-1) * np.exp(-t) * x[:, 1]**(-5) * np.sin(np.pi*x[:, 0]) * (-12 + np.pi**2 * x[:, 1]**2) )\n",
    "\n",
    "# boundary condition\n",
    "boundary_condition = \"dirichlet\"\n",
    "\n",
    "# Analytical solution\n",
    "def analytical_sol(x, t):\n",
    "    return np.exp(-t) * np.sin(np.pi * x[:, 0]) * x[:, 1]**-3  \n",
    "    \n",
    "# Test data\n",
    "t_eval = np.linspace(0, 1, 100).reshape(-1, 1, 1) # time domain\n",
    "x_train = data_interior # space domain\n",
    "u_true =  analytical_sol(x_eval, t_eval)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmIAAADTCAYAAAAiX38fAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAACT70lEQVR4nOydd3gU1d6A35ntLb0BCaE3QVCKoFyKKNhBr4oN5X4WbNi4dgW8FmxgvzZUUCx4bdhBaYqAolSlt1DTe7J95vvj7CbEtN0UsoR5n2eeJDNnz5yZs5nzm1+VVFVV0dDQ0NDQ0NDQOOrILT0ADQ0NDQ0NDY3jFU0Q09DQ0NDQ0NBoITRBTENDQ0NDQ0OjhdAEMQ0NDQ0NDQ2NFkITxDQ0NDQ0NDQ0WghNENPQ0NDQ0NDQaCE0QUxDQ0NDQ0NDo4XQBDENDQ0NDQ0NjRZCE8Q0NDQ0NDQ0NFoITRDT0NBolYwYMQJJklp6GA1i4sSJSJLE3r17W3ooGhoazYwmiGlotFLWr1/PjTfeSK9evYiKisJoNJKSksKZZ57JzJkzycnJaekhRgzLli1DkiSmT5/eKs+noaERuehbegAaGhpNi6Io3HPPPcycOROdTsewYcMYPXo0NpuN7OxsVq1axb///W+mTZvGtm3baNeuXUsPWUNDQ+O4RRPENDRaGQ8++CAzZ87k5JNPZv78+XTp0qVam7Vr13LvvffidDpbYIQaGhoaGkE006SGRiti+/btPPPMMyQmJvL999/XKIQBnHzyyfzwww906NChYt/evXuRJImJEyeyZcsWLrzwQuLj46v4Kvl8PmbNmkXfvn2xWCxER0czcuRIvvrqq2rnmD59OpIksWzZsmrH5syZgyRJzJkzp8bz79y5kwsvvJDY2FhsNhtnnHEGGzZsqPFaVqxYwfDhw7HZbMTHxzN+/Hj2798f8j2bPn06I0eOBOCRRx5BkqSKLXjdQZ+t3bt3M3PmTHr16oXJZGLixIlVjtfk0/X3+xDK+YKoqsqLL75Ijx49MJlMpKen88gjj6AoSsjXp6GhEdloGjENjVbE3Llz8fv9TJo0icTExHrb6/XVHwE7d+5k8ODB9OnTh4kTJ5KXl4fRaERVVS6++GIWLFhAt27duOWWWygrK2P+/PlccMEFzJo1izvvvLPR17B3714GDx7MCSecwP/93/+xa9cuFixYwMiRI9myZQvJyckVbRcvXszZZ5+NLMuMHz+etm3bsnjxYk477TRiY2NDOt+IESPYu3cvc+fOZfjw4YwYMaLiWExMTJW2kydPZvXq1Zx77rmcf/75JCUlhX194Zzv7rvvZvny5Zx33nmMGTOGL774gunTp+PxeHj88cfDPreGhkYEompoaLQaRo4cqQLq4sWLw/7snj17VEAF1KlTp1Y7PnfuXBVQhw8frrrd7or9GRkZakJCgqrX69Vdu3ZV7J82bZoKqEuXLq3W1zvvvKMC6jvvvFPj+Z988skq7R966CEVUGfMmFGxz+/3q506dVIlSVJ//vnniv2KoqhXXHFFRV+hsHTpUhVQp02bVuPxa665RgXU1NRUNSMjo9bje/bsqXaspvsQ6vk6duyoHjp0qGJ/Tk6OGhMTozocjipzoKGhceyimSY1NFoRmZmZALRt27basWXLljF9+vQqW01mw5SUFB588MFq++fOnQvA008/jdForNjfvn177rzzTnw+H++//36jr6Fjx47cfffdVfZde+21AKxZs6Zi34oVK9i9ezfnnXceQ4cOrdgvSRJPPPEEOp2u0WP5O3fffTft27dv8n5r4+GHH6ZNmzYVfyckJDB27FhKSkrYtm3bURuHhoZG86GZJjU0jhOWLVvGI488Um3/kaYxgL59+1YRtIKsW7cOq9XKoEGDqh0L+jytX7++0ePs168fslz1HTE1NRWAwsLCin1Bn7F//OMf1fpIT08nLS2tyfNw1XTtzUn//v2r7avpXmhoaBy7aBoxDY1WRNB/6tChQ9WOTZ8+HVVVUVWVDz/8sN4+/k5xcXGtPlFBrU1xcXG4Q65GVFRUtX1BXza/31+xr6ioCKDWMdV2HY2hOfqsi1DvhYaGxrGLJohpaLQiTj31VACWLl3a4D5qy0YfFRVFdnZ2jceCJtEjBYegVsvn81VrHxSiGkN0dDRArWPKyspq9Dn+Tm33prmvVUNDo/WiCWIaGq2Ia665BlmWeeONN8jNzW3Svk866STKy8v57bffqh0L+pr169evYl8wavHgwYPV2q9bt67R4+nbty8AP//8c7VjGRkZYaWwCPqTNVTLFO61NvZ8GhoarQdNENPQaEV069aNe+65h+zsbM4++2x27txZY7uG+Bddc801ANx///14vd6K/fv372fWrFno9XquvPLKiv0DBw4E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Gblbc82lNp/afGpbZM9nfTidTtUexlhTUlJUp9PZYuNtKiJWI7Zo0SLGjBnDv/71L95+++0qx+bOncvEiRN55JFHmDp1aq197Nq1iy5dujBw4EB+++23KscURSEpKQmn00l2djY2my2kcRUVFRETE8P+/fuJiooK/8I0wqK4uJi0tDQKCwubpeyINp9Hj+aeS9Dm82iizWfr4mjMZyhjiI6O5hGgPj2XC5iG+I4c698NfUsPoDaWLVsGwOjRo6sdGzNmDADLly+vs4/MzEwAOnbsWO2YLMu0b9+edevWsXr1akaNGhXSuILq8aioqGNm8rdsyaF9+2hsNmNLD6XBNJdZ4libT1VV+euvHLp0icNsjth/3zppThPTsTifmzZl07NnAgaDrqWH0yC0+azE71f4889sevdOQqeLeBfsGokEE3AiYKmnjfNoDOQoEbFP8h07dgDQtWvXasdSUlKw2+0VbWojISEBgD179lQ7pigK+/btA2D79u21CmJutxu3213xd3FxcWgXECHMmrWKqVOXEhVlIjHRyjXX9OOEExIZMiSNqChTSw/vqHOsz+eDDy7hxRd/JSHBSlycmQkT+jJgQFv69k3R5pNjaz5VVeWmm75h3ryNtGljJyHByqWXnsBpp6XRo0eiNp8cW/OpKCpXXPEpX3+9g3btHLRt62DcuB6MGtWR9PSY43I+G4oDsNbTJmKFlwYQsddSVFQEUKuKNCoqqqJNbXTr1o1OnTqxZs0avvnmG84999yKY88//zx5eXkAFBYW1trHjBkzeOSRR8IcfWSQlVXK/fcvxuPxU1bm5fDhUqZMWQSAJMGYMZ1JTrbzyivnHNPasnA4ludz69Zcnn12JV6vQllZERkZRaxbJ+ZTr5cYM6YLqalRvPjiWRiNEfuv3aQcy/O5cuV+3nprLT6fys6dBezcWcDq1QcBMBjEfHbtGs/MmaMjQktxNDiW5/Prr7fz6aeb8fthx458duzIZ/nyDACMRpnRozvTv39bpk8f0bIDPQZwAPU5Cx2b+uOaiVgfsdGjR/PDDz+wY8cOunTpUu14u3btKC0trVcYW7hwIeeffz5+v59x48bRuXNnNmzYwKJFi+jTpw+bNm3iySef5N57763x8zW9oaWlpR0Tdmmv14/R+FhIbb/55nLOOadbM48ofII+A011v4/l+SwqchET81RIbVev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YVuOHz8OgN/vj1mG9hw5coSdO3cyatSoc0PmdouHWtqVQ/VUPe3O0B7VM7ocqmcv5/SQXE/T0NBghgwZ0u7CeqWlpeeOl5WVmX379pnq6uo2r1dfX28yMzON1+s1n3zySZdmGD58uAHMr371qxbHq6qqzIgRIwxg3njjjZhmCAaDpqmpqcWx6upqM3XqVEMbCw/aKR5qaWcO1VP1tDuD6ql6ysVTIxYD27dvN16v16Smpppvf/vb5oEHHjB5eXkGMKtWrWrx2gULFhjArF+/vs1rbdq0yQBmzpw5XZ5h69atxuPxGMAUFBSYBx980CxcuNBkZmYawNxyyy0xz7Bx40aTm5trFixYYB5++OEWf/6KFSui+pl0RjzU0q4cqqfqaXcG1dO+HKpn76VGLEbeeecd85WvfMWkpaWZxMREM2nSJPPiiy+2el1Hfzk0P8q8detWRzLs3r3bzJ0712RlZRmPx2NSUlLMxIkTzdNPP20aGxtjnmHv3r1m1qxZJisry3i9XpORkWFmzZpltm/fHvHP4WLFQy3tyqF6qp52ZlA97c2hevZO2vRbRERExCGarC8iIiLiEDViIiIiIg5RIyYiIiLiEDViIiIiIg5RIyYiIiLiEDViIiIiIg5RIyYiIiLiEDViIiIiIg5RIyYiIiLiEDViIiIiIg5RIyYiIiLiEDViIiIiIg5RIyYiIiLiEDViItLtfOtb3yIhIYEDBw60OvfTn/4Uy7LYsmWLA8lERKJjGWOM0yFERKLx6aefMmLECMaNG8f27dvPHS8tLWX06NHceOONbNq0ycGEIiKR0YiYiHQ7/fr14/HHH+fNN99kw4YN544vXrwYr9fLk08+6WA6EZHIaURMRLolYwxTp07lH//4B/v37+eNN95g3rx5PPXUUyxZssTpeCIiEVEjJiLd1t///neuuOIKZs+ezY4dO8jJyeGdd97B5dJgv4h0D2rERKRb+8EPfsBjjz2G2+1m9+7djB8/3ulIIiIR06+NItKtZWRkAJCdnU1+fr7DaUREoqNGTES6raNHj7Js2TLy8/M5evQoTzzxhNORRESiokZMRLqte++9F4Bt27Yxd+5cVq5cyeHDhx1OJSISOTViItItbd68mVdffZUVK1aQk5PD6tWr8fl83HPPPU5HExGJmCbri0i3EwwGGTVqFJmZmezZswe32w3AU089RVFRES+//DJz5851OKWISMfUiIlIt1NUVMSaNWvYtWsXEydOPHc8FAoxadIkKioq2L9/P6mpqQ6mFBHpmG5Niki38t577/HMM8+wePHiFk0YgNvtZu3atVRUVPDII484lFBEJHIaERMRERFxiEbERERERByiRkxERETEIWrERERERByiRkxERETEIWrERERERByiRkxERETEIWrERERERByiRkxERETEIWrERERERByiRkxERETEIWrERERERByiRkxERETEIf8PfkoceyMZDQQAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 600x200 with 5 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Visualize the true solution\n",
    "timesteps = [0, 29, 59, 99] #0'th, 30'th, 60'th, 100th time-step  \n",
    "plot(x=x_eval, u=u_true, timesteps=timesteps, title='Ground truth')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Fit and evaluate SWIM-ODE and ELM-ODE for good hyper-parameters "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "w =  200  reg =  1e-15 seed= 1\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "147.34892058372498 0.000758881574251217 0.0007752630393118071 8.406534910202026 3.4521748360248555e+115 3.5266946074597973e+115\n",
      "w =  200  reg =  1e-15 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "113.2412052154541 0.00013122141976565726 0.00013405400811149123 12.841817617416382 5.829532754852193e+112 5.955370949352307e+112\n",
      "w =  200  reg =  1e-15 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "128.98991632461548 0.00016059999020498895 0.00016406675394987233 16.69520592689514 1.073950112948846e+109 1.0971327501995226e+109\n",
      "w =  200  reg =  1e-15 seed= 1\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "138.3112235069275 0.0007588815742120842 0.0007752630392718296 4.387648820877075 1.230425376509527e+116 1.2569857398110634e+116\n",
      "w =  200  reg =  1e-15 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "91.84240794181824 0.00013122141976988175 0.00013405400811580692 6.660080432891846 2.664195416698758e+114 2.721705607503295e+114\n",
      "w =  200  reg =  1e-15 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "111.4602644443512 0.00016059999020435697 0.0001640667539492267 10.443681478500366 2.0298390961147456e+110 2.0736558645801453e+110\n",
      "w =  300  reg =  1e-15 seed= 1\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "274.2050278186798 1.0206164047810043e+101 1.0426477632201414e+101 73.47455549240112 3.0708893442384e-05 3.137178562746856e-05\n",
      "w =  300  reg =  1e-15 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "215.05168461799622 2.9227160100209142e-05 2.9858067106317784e-05 12.298679828643799 7.62354657307771e+111 7.788110934714606e+111\n",
      "w =  300  reg =  1e-15 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "236.71638870239258 4.969116000574265e-06 5.076380958516806e-06 25.67615008354187 1.717700343411645e+109 1.7547791830025595e+109\n",
      "w =  300  reg =  1e-15 seed= 1\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "229.15286493301392 1.1329419800917393e+102 1.157398035018176e+102 27.148085594177246 3.0708893424643015e-05 3.137178560934461e-05\n",
      "w =  300  reg =  1e-15 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "164.7778675556183 2.922716010565129e-05 2.985806711187741e-05 6.4765784740448 8.218668206163347e+113 8.396079057384356e+113\n",
      "w =  300  reg =  1e-15 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "131.99532198905945 4.96911599786679e-06 5.076380955750887e-06 16.20225954055786 6.853874469816322e+111 7.001824438515653e+111\n",
      "w =  400  reg =  1e-15 seed= 1\n",
      "780.5962524414062 2.8235637861112553e-06 2.884514154492735e-06 89.25479555130005 1.0068034405915961e-05 1.0285366278826521e-05\n",
      "w =  400  reg =  1e-15 seed= 2\n",
      "315.4917416572571 4.444986883009367e-06 4.540937818951706e-06 42.302757024765015 0.001666599116226013 0.0017025748680676686\n",
      "w =  400  reg =  1e-15 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "270.8851716518402 8.077917863934213e-06 8.25229043238262e-06 13.90381932258606 2.968663697027552e+112 3.032746239389294e+112\n",
      "w =  400  reg =  1e-15 seed= 1\n",
      "267.39247703552246 2.823563773864439e-06 2.8845141419815554e-06 33.73771333694458 1.0068034410045884e-05 1.0285366283045594e-05\n",
      "w =  400  reg =  1e-15 seed= 2\n",
      "179.37444758415222 4.444986878873996e-06 4.540937814727067e-06 20.133374214172363 0.0016665991128486076 0.0017025748646173574\n",
      "w =  400  reg =  1e-15 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "153.69999313354492 8.077917865659189e-06 8.252290434144831e-06 7.158454656600952 2.2177404671202163e+114 2.2656133358368312e+114\n",
      "w =  500  reg =  1e-15 seed= 1\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "1436.0064187049866 8.923380221948065e-07 9.116003216481087e-07 18.579162120819092 1.1768200418153747e+109 1.2022232628866233e+109\n",
      "w =  500  reg =  1e-15 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "466.23596262931824 2.960756229436769e-07 3.0246680786252263e-07 10.27763319015503 3.0717053406229705e+112 3.138012173495402e+112\n",
      "w =  500  reg =  1e-15 seed= 3\n",
      "322.0567936897278 4.709183531604359e-06 4.810837502532563e-06 40.632620096206665 0.0014882521032790871 0.0015203779983573428\n",
      "w =  500  reg =  1e-15 seed= 1\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "384.69865560531616 8.923380206058717e-07 9.116003200248746e-07 14.696107864379883 2.4973490981965524e+110 2.5512576899772515e+110\n",
      "w =  500  reg =  1e-15 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "237.43625950813293 2.960756217997641e-07 3.0246680669391696e-07 7.8560707569122314 4.860558857309943e+113 4.965480465367864e+113\n",
      "w =  500  reg =  1e-15 seed= 3\n",
      "219.0534965991974 4.7091835376710395e-06 4.810837508730201e-06 28.153061389923096 0.0014882520981317024 0.001520377993098845\n",
      "w =  200  reg =  1e-12 seed= 1\n",
      "128.37194514274597 0.00719221425646499 0.007347467738099209 18.321160554885864 0.004823742629259338 0.004927869510216304\n",
      "w =  200  reg =  1e-12 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "94.32458353042603 0.00015846170022297039 0.00016188230614320976 7.286837577819824 2.0997127397276077e+109 2.1450378234431565e+109\n",
      "w =  200  reg =  1e-12 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "100.96567726135254 0.0002290485211299718 0.00023399283717793053 10.634925365447998 2.4945827679062485e+105 2.5484316447794647e+105\n",
      "w =  200  reg =  1e-12 seed= 1\n",
      "99.72293519973755 0.0071922142563087856 0.007347467737939634 6.108617067337036 0.004823742628223285 0.004927869509157886\n",
      "w =  200  reg =  1e-12 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "68.0109543800354 0.00015846170021209768 0.00016188230613210235 4.792525291442871 1.5956734476598537e+111 1.6301181748977537e+111\n",
      "w =  200  reg =  1e-12 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "67.132803440094 0.00022904852112211034 0.00023399283716989935 6.012105464935303 2.318366459537461e+107 2.3684114737309203e+107\n",
      "w =  300  reg =  1e-12 seed= 1\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "193.69668674468994 0.0001308843431882487 0.00013370965528919428 19.88597321510315 2.1236209387291658e+101 2.1694621126225424e+101\n",
      "w =  300  reg =  1e-12 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "103.7787778377533 9.407459420123888e-05 9.610531906040727e-05 6.8356688022613525 3.2186041402776595e+109 3.288081978529106e+109\n",
      "w =  300  reg =  1e-12 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "119.67180967330933 0.00027927771365841614 0.0002853062934312363 3.6936614513397217 4.6718635281523205e+115 4.772711897319521e+115\n",
      "w =  300  reg =  1e-12 seed= 1\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "152.8687129020691 0.00013088434319931202 0.0001337096553004964 16.644084453582764 2.328356924216759e+102 2.378617595837722e+102\n",
      "w =  300  reg =  1e-12 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "101.93311047554016 9.407459419772044e-05 9.610531905681287e-05 4.321001768112183 4.80675622820886e+111 4.910516435175107e+111\n",
      "w =  300  reg =  1e-12 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "102.11010003089905 0.00027927771365659457 0.00028530629342937545 2.020404577255249 9.158511771055954e+116 9.35621039186196e+116\n",
      "w =  400  reg =  1e-12 seed= 1\n",
      "201.79065084457397 0.00018075003773067628 0.00018465176697045517 12.268312454223633 0.12200644932731662 0.12464012031714682\n",
      "w =  400  reg =  1e-12 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "144.59486174583435 4.750204071236599e-05 4.852743524906185e-05 14.457441806793213 2.076773797833204e+100 2.121603714070822e+100\n",
      "w =  400  reg =  1e-12 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "136.70534133911133 0.0014514670907872429 0.0014827989325937702 25.348875761032104 1.0466599549004014e+114 1.06925349790273e+114\n",
      "w =  400  reg =  1e-12 seed= 1\n",
      "178.15972876548767 0.0001807500377266368 0.0001846517669663285 7.5790650844573975 0.12200644950433533 0.1246401204979867\n",
      "w =  400  reg =  1e-12 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "128.25441718101501 4.7502040714178814e-05 4.8527435250913807e-05 8.925442218780518 7.790409888622435e+101 7.958576216186869e+101\n",
      "w =  400  reg =  1e-12 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "106.46326184272766 0.0014514670906689822 0.0014827989324729567 22.53571581840515 4.799439704546132e+115 4.9030419746473755e+115\n",
      "w =  500  reg =  1e-12 seed= 1\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "234.46588730812073 4.3680431458410397e-05 4.462333149188858e-05 10.44569993019104 1.3110313588920297e+105 1.3393317092071872e+105\n",
      "w =  500  reg =  1e-12 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "146.2420687675476 3.211555874456319e-05 3.2808815665439794e-05 8.352163314819336 6.204296230833071e+109 6.338224191900285e+109\n",
      "w =  500  reg =  1e-12 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "165.13587021827698 3.342461339451944e-05 3.4146127995827704e-05 12.821279525756836 1.0744292107739124e+103 1.0976221899864288e+103\n",
      "w =  500  reg =  1e-12 seed= 1\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "190.8181083202362 4.3680431468161196e-05 4.4623331501849865e-05 6.02529501914978 3.258977581789883e+106 3.329326934311736e+106\n",
      "w =  500  reg =  1e-12 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "120.79672694206238 3.211555874036574e-05 3.280881566115174e-05 4.111313104629517 4.91407306922065e+111 5.02014985250275e+111\n",
      "w =  500  reg =  1e-12 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "129.1039915084839 3.342461339566885e-05 3.414612799700192e-05 6.872653961181641 2.3267176806627896e+104 2.376942967037996e+104\n",
      "w =  200  reg =  1e-10 seed= 1\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "86.30542492866516 0.005778012102321665 0.00590273815522029 10.61555004119873 1.936098971240632e+109 1.9778922348107974e+109\n",
      "w =  200  reg =  1e-10 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "48.668068408966064 0.0034292639281322916 0.003503289137240406 2.5350544452667236 1.4526452328024792e+114 1.484002506366627e+114\n",
      "w =  200  reg =  1e-10 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "64.5172827243805 0.005362147039932818 0.005477896094020838 5.081485748291016 2.5271634378401925e+110 2.5817156116760476e+110\n",
      "w =  200  reg =  1e-10 seed= 1\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "85.97844314575195 0.005778012102416322 0.00590273815531699 8.53481388092041 2.076678913758728e+110 2.1215067817977817e+110\n",
      "w =  200  reg =  1e-10 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "41.798829555511475 0.0034292639279645196 0.003503289137069012 1.5308825969696045 3.4877568089904463e+115 3.5630446644937062e+115\n",
      "w =  200  reg =  1e-10 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "42.4368257522583 0.005362147040024061 0.005477896094114051 3.492975950241089 1.1022540472037802e+112 1.1260476624064936e+112\n",
      "w =  300  reg =  1e-10 seed= 1\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "105.96767354011536 0.0023295019981308877 0.0023797873876906604 15.440617322921753 3.3899236641504355e+109 3.4630996614951343e+109\n",
      "w =  300  reg =  1e-10 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "82.90751671791077 0.0015884827806210316 0.0016227722877760417 6.936191082000732 4.402868053809103e+109 4.4979097989733966e+109\n",
      "w =  300  reg =  1e-10 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "89.19076347351074 0.0028753163153182873 0.002937383830666787 14.46880054473877 5.8653851541987266e+113 5.991997270279178e+113\n",
      "w =  300  reg =  1e-10 seed= 1\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "100.2761960029602 0.002329501998140735 0.00237978738770072 9.397141456604004 4.3480472938750374e+111 4.4419056602435803e+111\n",
      "w =  300  reg =  1e-10 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "59.53504228591919 0.0015884827807503975 0.0016227722879082 4.123924493789673 1.486373451099735e+112 1.5184587929795983e+112\n",
      "w =  300  reg =  1e-10 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "63.882622957229614 0.002875316315336252 0.0029373838306851396 10.5453360080719 2.636971465879945e+116 2.6938939916069768e+116\n",
      "w =  400  reg =  1e-10 seed= 1\n",
      "115.82345628738403 0.0023844422088890324 0.002435913555748986 5.699997186660767 0.1930332405164306 0.19720011897592207\n",
      "w =  400  reg =  1e-10 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "95.68095326423645 0.0010431375058087607 0.001065655012076663 34.758755922317505 1.959363881983762e+109 2.0016593495016937e+109\n",
      "w =  400  reg =  1e-10 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "111.68448662757874 0.0006901465286344561 0.000705044256592429 3.4475865364074707 2.7349619351453446e+113 2.7939997150872728e+113\n",
      "w =  400  reg =  1e-10 seed= 1\n",
      "114.03789782524109 0.0023844422089551016 0.0024359135558164814 3.4069511890411377 0.1930332391139673 0.19720011754318478\n",
      "w =  400  reg =  1e-10 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "67.65020275115967 0.001043137505828434 0.0010656550120967609 35.078850507736206 2.6655037551822896e+111 2.7230421882078566e+111\n",
      "w =  400  reg =  1e-10 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "80.58508586883545 0.0006901465286464286 0.00070504425660466 2.248216390609741 6.323334100730762e+114 6.459831652064468e+114\n",
      "w =  500  reg =  1e-10 seed= 1\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "132.75766110420227 0.0011979216802088615 0.0012237804081257008 7.637679576873779 6.647124913323674e+110 6.79061191869527e+110\n",
      "w =  500  reg =  1e-10 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "112.70944571495056 0.0007485559367108485 0.0007647145091932879 3.8954226970672607 3.0438998770067764e+110 3.1096064920768825e+110\n",
      "w =  500  reg =  1e-10 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "120.55661964416504 0.0009585967230542127 0.0009792893044249002 19.916678190231323 3.3067737564156487e+109 3.378154852744741e+109\n",
      "w =  500  reg =  1e-10 seed= 1\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "133.29119849205017 0.001197921680103286 0.0012237804080178463 5.2673985958099365 1.1758351757839993e+112 1.2012171372160237e+112\n",
      "w =  500  reg =  1e-10 seed= 2\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "83.81191802024841 0.0007485559367972959 0.0007647145092816015 2.7766005992889404 1.3194548490513237e+112 1.3479370315711555e+112\n",
      "w =  500  reg =  1e-10 seed= 3\n",
      "Integration failed or terminated due to exceeding the maximum absolute value.\n",
      "93.93670701980591 0.0009585967230367005 0.00097928930440701 13.88830018043518 1.396777431729734e+111 1.4269287247267715e+111\n",
      "[147.34892058372498, 0.000758881574251217, 0.0007752630393118071, 8.406534910202026, 3.4521748360248555e+115, 3.5266946074597973e+115, 113.2412052154541, 0.00013122141976565726, 0.00013405400811149123, 12.841817617416382, 5.829532754852193e+112, 5.955370949352307e+112, 128.98991632461548, 0.00016059999020498895, 0.00016406675394987233, 16.69520592689514, 1.073950112948846e+109, 1.0971327501995226e+109, 138.3112235069275, 0.0007588815742120842, 0.0007752630392718296, 4.387648820877075, 1.230425376509527e+116, 1.2569857398110634e+116, 91.84240794181824, 0.00013122141976988175, 0.00013405400811580692, 6.660080432891846, 2.664195416698758e+114, 2.721705607503295e+114, 111.4602644443512, 0.00016059999020435697, 0.0001640667539492267, 10.443681478500366, 2.0298390961147456e+110, 2.0736558645801453e+110, 274.2050278186798, 1.0206164047810043e+101, 1.0426477632201414e+101, 73.47455549240112, 3.0708893442384e-05, 3.137178562746856e-05, 215.05168461799622, 2.9227160100209142e-05, 2.9858067106317784e-05, 12.298679828643799, 7.62354657307771e+111, 7.788110934714606e+111, 236.71638870239258, 4.969116000574265e-06, 5.076380958516806e-06, 25.67615008354187, 1.717700343411645e+109, 1.7547791830025595e+109, 229.15286493301392, 1.1329419800917393e+102, 1.157398035018176e+102, 27.148085594177246, 3.0708893424643015e-05, 3.137178560934461e-05, 164.7778675556183, 2.922716010565129e-05, 2.985806711187741e-05, 6.4765784740448, 8.218668206163347e+113, 8.396079057384356e+113, 131.99532198905945, 4.96911599786679e-06, 5.076380955750887e-06, 16.20225954055786, 6.853874469816322e+111, 7.001824438515653e+111, 780.5962524414062, 2.8235637861112553e-06, 2.884514154492735e-06, 89.25479555130005, 1.0068034405915961e-05, 1.0285366278826521e-05, 315.4917416572571, 4.444986883009367e-06, 4.540937818951706e-06, 42.302757024765015, 0.001666599116226013, 0.0017025748680676686, 270.8851716518402, 8.077917863934213e-06, 8.25229043238262e-06, 13.90381932258606, 2.968663697027552e+112, 3.032746239389294e+112, 267.39247703552246, 2.823563773864439e-06, 2.8845141419815554e-06, 33.73771333694458, 1.0068034410045884e-05, 1.0285366283045594e-05, 179.37444758415222, 4.444986878873996e-06, 4.540937814727067e-06, 20.133374214172363, 0.0016665991128486076, 0.0017025748646173574, 153.69999313354492, 8.077917865659189e-06, 8.252290434144831e-06, 7.158454656600952, 2.2177404671202163e+114, 2.2656133358368312e+114, 1436.0064187049866, 8.923380221948065e-07, 9.116003216481087e-07, 18.579162120819092, 1.1768200418153747e+109, 1.2022232628866233e+109, 466.23596262931824, 2.960756229436769e-07, 3.0246680786252263e-07, 10.27763319015503, 3.0717053406229705e+112, 3.138012173495402e+112, 322.0567936897278, 4.709183531604359e-06, 4.810837502532563e-06, 40.632620096206665, 0.0014882521032790871, 0.0015203779983573428, 384.69865560531616, 8.923380206058717e-07, 9.116003200248746e-07, 14.696107864379883, 2.4973490981965524e+110, 2.5512576899772515e+110, 237.43625950813293, 2.960756217997641e-07, 3.0246680669391696e-07, 7.8560707569122314, 4.860558857309943e+113, 4.965480465367864e+113, 219.0534965991974, 4.7091835376710395e-06, 4.810837508730201e-06, 28.153061389923096, 0.0014882520981317024, 0.001520377993098845, 128.37194514274597, 0.00719221425646499, 0.007347467738099209, 18.321160554885864, 0.004823742629259338, 0.004927869510216304, 94.32458353042603, 0.00015846170022297039, 0.00016188230614320976, 7.286837577819824, 2.0997127397276077e+109, 2.1450378234431565e+109, 100.96567726135254, 0.0002290485211299718, 0.00023399283717793053, 10.634925365447998, 2.4945827679062485e+105, 2.5484316447794647e+105, 99.72293519973755, 0.0071922142563087856, 0.007347467737939634, 6.108617067337036, 0.004823742628223285, 0.004927869509157886, 68.0109543800354, 0.00015846170021209768, 0.00016188230613210235, 4.792525291442871, 1.5956734476598537e+111, 1.6301181748977537e+111, 67.132803440094, 0.00022904852112211034, 0.00023399283716989935, 6.012105464935303, 2.318366459537461e+107, 2.3684114737309203e+107, 193.69668674468994, 0.0001308843431882487, 0.00013370965528919428, 19.88597321510315, 2.1236209387291658e+101, 2.1694621126225424e+101, 103.7787778377533, 9.407459420123888e-05, 9.610531906040727e-05, 6.8356688022613525, 3.2186041402776595e+109, 3.288081978529106e+109, 119.67180967330933, 0.00027927771365841614, 0.0002853062934312363, 3.6936614513397217, 4.6718635281523205e+115, 4.772711897319521e+115, 152.8687129020691, 0.00013088434319931202, 0.0001337096553004964, 16.644084453582764, 2.328356924216759e+102, 2.378617595837722e+102, 101.93311047554016, 9.407459419772044e-05, 9.610531905681287e-05, 4.321001768112183, 4.80675622820886e+111, 4.910516435175107e+111, 102.11010003089905, 0.00027927771365659457, 0.00028530629342937545, 2.020404577255249, 9.158511771055954e+116, 9.35621039186196e+116, 201.79065084457397, 0.00018075003773067628, 0.00018465176697045517, 12.268312454223633, 0.12200644932731662, 0.12464012031714682, 144.59486174583435, 4.750204071236599e-05, 4.852743524906185e-05, 14.457441806793213, 2.076773797833204e+100, 2.121603714070822e+100, 136.70534133911133, 0.0014514670907872429, 0.0014827989325937702, 25.348875761032104, 1.0466599549004014e+114, 1.06925349790273e+114, 178.15972876548767, 0.0001807500377266368, 0.0001846517669663285, 7.5790650844573975, 0.12200644950433533, 0.1246401204979867, 128.25441718101501, 4.7502040714178814e-05, 4.8527435250913807e-05, 8.925442218780518, 7.790409888622435e+101, 7.958576216186869e+101, 106.46326184272766, 0.0014514670906689822, 0.0014827989324729567, 22.53571581840515, 4.799439704546132e+115, 4.9030419746473755e+115, 234.46588730812073, 4.3680431458410397e-05, 4.462333149188858e-05, 10.44569993019104, 1.3110313588920297e+105, 1.3393317092071872e+105, 146.2420687675476, 3.211555874456319e-05, 3.2808815665439794e-05, 8.352163314819336, 6.204296230833071e+109, 6.338224191900285e+109, 165.13587021827698, 3.342461339451944e-05, 3.4146127995827704e-05, 12.821279525756836, 1.0744292107739124e+103, 1.0976221899864288e+103, 190.8181083202362, 4.3680431468161196e-05, 4.4623331501849865e-05, 6.02529501914978, 3.258977581789883e+106, 3.329326934311736e+106, 120.79672694206238, 3.211555874036574e-05, 3.280881566115174e-05, 4.111313104629517, 4.91407306922065e+111, 5.02014985250275e+111, 129.1039915084839, 3.342461339566885e-05, 3.414612799700192e-05, 6.872653961181641, 2.3267176806627896e+104, 2.376942967037996e+104, 86.30542492866516, 0.005778012102321665, 0.00590273815522029, 10.61555004119873, 1.936098971240632e+109, 1.9778922348107974e+109, 48.668068408966064, 0.0034292639281322916, 0.003503289137240406, 2.5350544452667236, 1.4526452328024792e+114, 1.484002506366627e+114, 64.5172827243805, 0.005362147039932818, 0.005477896094020838, 5.081485748291016, 2.5271634378401925e+110, 2.5817156116760476e+110, 85.97844314575195, 0.005778012102416322, 0.00590273815531699, 8.53481388092041, 2.076678913758728e+110, 2.1215067817977817e+110, 41.798829555511475, 0.0034292639279645196, 0.003503289137069012, 1.5308825969696045, 3.4877568089904463e+115, 3.5630446644937062e+115, 42.4368257522583, 0.005362147040024061, 0.005477896094114051, 3.492975950241089, 1.1022540472037802e+112, 1.1260476624064936e+112, 105.96767354011536, 0.0023295019981308877, 0.0023797873876906604, 15.440617322921753, 3.3899236641504355e+109, 3.4630996614951343e+109, 82.90751671791077, 0.0015884827806210316, 0.0016227722877760417, 6.936191082000732, 4.402868053809103e+109, 4.4979097989733966e+109, 89.19076347351074, 0.0028753163153182873, 0.002937383830666787, 14.46880054473877, 5.8653851541987266e+113, 5.991997270279178e+113, 100.2761960029602, 0.002329501998140735, 0.00237978738770072, 9.397141456604004, 4.3480472938750374e+111, 4.4419056602435803e+111, 59.53504228591919, 0.0015884827807503975, 0.0016227722879082, 4.123924493789673, 1.486373451099735e+112, 1.5184587929795983e+112, 63.882622957229614, 0.002875316315336252, 0.0029373838306851396, 10.5453360080719, 2.636971465879945e+116, 2.6938939916069768e+116, 115.82345628738403, 0.0023844422088890324, 0.002435913555748986, 5.699997186660767, 0.1930332405164306, 0.19720011897592207, 95.68095326423645, 0.0010431375058087607, 0.001065655012076663, 34.758755922317505, 1.959363881983762e+109, 2.0016593495016937e+109, 111.68448662757874, 0.0006901465286344561, 0.000705044256592429, 3.4475865364074707, 2.7349619351453446e+113, 2.7939997150872728e+113, 114.03789782524109, 0.0023844422089551016, 0.0024359135558164814, 3.4069511890411377, 0.1930332391139673, 0.19720011754318478, 67.65020275115967, 0.001043137505828434, 0.0010656550120967609, 35.078850507736206, 2.6655037551822896e+111, 2.7230421882078566e+111, 80.58508586883545, 0.0006901465286464286, 0.00070504425660466, 2.248216390609741, 6.323334100730762e+114, 6.459831652064468e+114, 132.75766110420227, 0.0011979216802088615, 0.0012237804081257008, 7.637679576873779, 6.647124913323674e+110, 6.79061191869527e+110, 112.70944571495056, 0.0007485559367108485, 0.0007647145091932879, 3.8954226970672607, 3.0438998770067764e+110, 3.1096064920768825e+110, 120.55661964416504, 0.0009585967230542127, 0.0009792893044249002, 19.916678190231323, 3.3067737564156487e+109, 3.378154852744741e+109, 133.29119849205017, 0.001197921680103286, 0.0012237804080178463, 5.2673985958099365, 1.1758351757839993e+112, 1.2012171372160237e+112, 83.81191802024841, 0.0007485559367972959, 0.0007647145092816015, 2.7766005992889404, 1.3194548490513237e+112, 1.3479370315711555e+112, 93.93670701980591, 0.0009585967230367005, 0.00097928930440701, 13.88830018043518, 1.396777431729734e+111, 1.4269287247267715e+111]\n"
     ]
    }
   ],
   "source": [
    "seeds = [1,2,3]\n",
    "experiments = []\n",
    "\n",
    "# Loop over different seeds\n",
    "info = []\n",
    "widths = [200, 300, 400, 500]\n",
    "reg_consts = [1e-15, 1e-12, 1e-10]\n",
    "tols = [1e-8, 1e-6]\n",
    "rmse_swim = np.ones((len(seeds) * len(widths ) * len(reg_consts)* len(tols), ))\n",
    "rmse_elm = np.ones((len(seeds)* len(widths )* len(reg_consts)* len(tols), ))\n",
    "rel_err_swim = np.ones((len(seeds)* len(widths) * len(reg_consts)* len(tols), ))\n",
    "rel_err_elm = np.ones((len(seeds)* len(widths )* len(reg_consts)* len(tols), ))\n",
    "time_swim = np.ones((len(seeds)* len(widths )* len(reg_consts)* len(tols), ))\n",
    "time_elm = np.ones((len(seeds)* len(widths )* len(reg_consts)* len(tols), ))\n",
    "j = 0\n",
    "for reg in reg_consts:\n",
    "    for w in widths:\n",
    "        for tol in tols:\n",
    "            for seed in seeds:\n",
    "                svd_cutoff = reg\n",
    "                print('w = ', w, ' reg = ', reg, 'seed=', seed)\n",
    "                ansatz_swim = BasicAnsatz(\n",
    "                    n_neurons=w,\n",
    "                    activation=\"tanh\",\n",
    "                    random_state=seed,\n",
    "                    regularization_scale=reg,\n",
    "                    parameter_sampler = \"tanh\" \n",
    "                )\n",
    "                ansatz_elm = BasicAnsatz(\n",
    "                    n_neurons=w,\n",
    "                    activation=\"tanh\",\n",
    "                    random_state=seed,\n",
    "                    regularization_scale=reg,\n",
    "                    parameter_sampler = \"random\" \n",
    "                )\n",
    "                \n",
    "                # Interior points\n",
    "                normal_vectors = data_boundary.copy()\n",
    "                # Domain\n",
    "                domain = Domain(\n",
    "                    interior_points=data_interior,\n",
    "                    boundary_points=data_boundary,\n",
    "                    normal_vectors=normal_vectors\n",
    "                )\n",
    "                \n",
    "                nonlinear_diffusion_solver_swim = Nonlinear_Diffusion_Solver(\n",
    "                    domain=domain, \n",
    "                    ansatz=ansatz_swim,\n",
    "                    u0=u0,\n",
    "                    boundary_condition=boundary_condition,\n",
    "                    forcing=forcing,\n",
    "                    regularization_scale=reg,\n",
    "                    scale_boundary_correction=1.,\n",
    "                    boundary_condition_true=analytical_sol\n",
    "                )\n",
    "\n",
    "                nonlinear_diffusion_solver_elm = Nonlinear_Diffusion_Solver(\n",
    "                    domain=domain, \n",
    "                    ansatz=ansatz_elm,\n",
    "                    u0=u0,\n",
    "                    boundary_condition=boundary_condition,\n",
    "                    forcing=forcing,\n",
    "                    regularization_scale=reg,\n",
    "                    scale_boundary_correction=1.,\n",
    "                    boundary_condition_true=analytical_sol\n",
    "                )\n",
    "                # Compute weights and biases of the SWIM network\n",
    "                time_blocks = 1\n",
    "                ic_eval = u0(domain.interior_points)\n",
    "                t_swim_start = time.time()\n",
    "                sol_swim, solver_status_swim = nonlinear_diffusion_solver_swim.fit(t_span=[0, np.max(t_eval)], \n",
    "                                                                                rtol = tol, atol = tol, svd_cutoff= svd_cutoff,\n",
    "                                                                                    outer_basis=False,\n",
    "                                                                                    init_cond=ic_eval);\n",
    "                t_swim_stop = time.time()\n",
    "                time_swim[j] = t_swim_stop - t_swim_start\n",
    "\n",
    "                t_elm_start = time.time()\n",
    "                sol_elm, solver_status_elm = nonlinear_diffusion_solver_elm.fit(t_span=[0, np.max(t_eval)], \n",
    "                                                                                rtol = tol, atol = tol, svd_cutoff= svd_cutoff,\n",
    "                                                                                    outer_basis=False,\n",
    "                                                                                    init_cond=ic_eval);\n",
    "                t_elm_stop = time.time()\n",
    "                time_elm[j] = t_elm_stop - t_elm_start\n",
    "\n",
    "                # Evaluate on test data\n",
    "                u_swim_test = nonlinear_diffusion_solver_swim.evaluate(x_eval=x_eval, t_eval = t_eval).T #, solver_status=solver_status\n",
    "                u_elm_test = nonlinear_diffusion_solver_elm.evaluate(x_eval=x_eval, t_eval = t_eval).T #, solver_status=solver_status\n",
    "                            \n",
    "                # Compute metrics\n",
    "                rmse_swim[j] = np.sqrt(mean_squared_error(u_true[:, 0, :], u_swim_test))  # mean squared error\n",
    "                rel_err_swim[j] = rmse_swim[j]/np.sqrt(mean_squared_error(u_true[:, 0, :], np.zeros_like(u_true[:, 0, :])))\n",
    "                rmse_elm[j] = np.sqrt(mean_squared_error(u_true[:, 0, :], u_elm_test))\n",
    "                rel_err_elm[j] = rmse_elm[j]/np.sqrt(mean_squared_error(u_true[:, 0, :], np.zeros_like(u_true[:, 0, :])))\n",
    "\n",
    "                info.append(time_swim[j])\n",
    "                info.append(rmse_swim[j])\n",
    "                info.append(rel_err_swim[j])\n",
    "                info.append(time_elm[j])\n",
    "                info.append(rmse_elm[j])\n",
    "                info.append(rel_err_elm[j])\n",
    "                print(time_swim[j],rmse_swim[j], rel_err_swim[j], time_elm[j], rmse_elm[j], rel_err_elm[j])\n",
    "                j += 1\n",
    "\n",
    "print(info)\n",
    "\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "test2",
   "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
}
