{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Error convergence: ELM-ODE, SWIM-ODE \n",
    "In this script, we study how the error decays with the width of the neural network (and collocation points)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Imports\n",
    "import sys\n",
    "sys.path.append('../../')\n",
    "sys.path.append('../../src')\n",
    "from swimpde import Domain\n",
    "from swimpde import BoundaryCompliantAnsatz\n",
    "from swimpde import AdvectionSolver\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.metrics import mean_squared_error\n",
    "import time"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Problem setup"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# List of all hyper-parameters\n",
    "n_s = np.linspace(20, 240, 10, dtype=\"int\") # Root of mean squared error points\n",
    "reg_OBF = [1e-7, 1e-8, 1e-9, 1e-10, 1e-11, 1e-12] \n",
    "reg_pinv_ic = reg_OBF # Regularization const for pseudo-inverse and least squares solution for IC\n",
    "conv_coeff = 10. # convection coefficient\n",
    "ratios = [8] # data_points/outer basis functions\n",
    "n_IBFs_factors = [5]\n",
    "\n",
    "n_test = 256 # Number of test points in space\n",
    "n_t = 256 # Set time domain\n",
    "\n",
    "# Domain: 1-d space with uniform grid\n",
    "x_lim = [0, 2 * np.pi]\n",
    "\n",
    "# initial condition\n",
    "def u0(x):\n",
    "    return np.sin(x)\n",
    "\n",
    "# forcing\n",
    "def forcing(x, t):\n",
    "    return np.zeros(x.shape[0])\n",
    "\n",
    "# Analytical solution\n",
    "def analytical_sol(x, t):\n",
    "    return np.sin(x - conv_coeff * t)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Fit SWIM-ODE and ELM-ODE"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "n_s= 20 , n_b= 2 , reg_const= 1e-07\n",
      "scale_bc= 0.00913381576538086 , domain_boundary_percent= 0.019352833429972332\n",
      "time_elm= 0.17703488519513003 , time_swim= 0.009421308200772355\n",
      "rmse_swim= [0.01172695 0.01193353 0.00460344] , rmse_elm= [0.44387499 0.04260867 0.04462099]\n",
      "l2_rel_err_swim= [0.01714538 0.01846111 0.00668867] , l2_rel_err_elm= [0.66023022 0.06497527 0.06535613]\n",
      "n_s= 20 , n_b= 2 , reg_const= 1e-08\n",
      "scale_bc= 0.008697032928466797 , domain_boundary_percent= 0.010370175043741861\n",
      "time_elm= 0.2250167677351991 , time_swim= 0.009421308200772355\n",
      "rmse_swim= [0.01172695 0.01193353 0.00460344] , rmse_elm= [0.61800432 0.01217538 0.0448706 ]\n",
      "l2_rel_err_swim= [0.01714538 0.01846111 0.00668867] , l2_rel_err_elm= [1.0011059  0.01708148 0.0656898 ]\n",
      "n_s= 20 , n_b= 2 , reg_const= 1e-09\n",
      "scale_bc= 0.009501457214355469 , domain_boundary_percent= 0.009686708450317383\n",
      "time_elm= 0.07804336306573294 , time_swim= 0.009421308200772355\n",
      "rmse_swim= [0.01172695 0.01193353 0.00460344] , rmse_elm= [0.13714384 0.05211565 0.0448706 ]\n",
      "l2_rel_err_swim= [0.01714538 0.01846111 0.00668867] , l2_rel_err_elm= [0.20259281 0.07818831 0.0656898 ]\n",
      "n_s= 20 , n_b= 2 , reg_const= 1e-10\n",
      "scale_bc= 0.010342677434285482 , domain_boundary_percent= 0.010837872823079428\n",
      "time_elm= 0.07804336306573294 , time_swim= 0.009421308200772355\n",
      "rmse_swim= [0.01172695 0.01193353 0.00460344] , rmse_elm= [0.13714384 0.05211565 0.0448706 ]\n",
      "l2_rel_err_swim= [0.01714538 0.01846111 0.00668867] , l2_rel_err_elm= [0.20259281 0.07818831 0.0656898 ]\n",
      "n_s= 20 , n_b= 2 , reg_const= 1e-11\n",
      "scale_bc= 0.010104020436604818 , domain_boundary_percent= 0.011555353800455729\n",
      "time_elm= 0.07804336306573294 , time_swim= 0.009421308200772355\n",
      "rmse_swim= [0.01172695 0.01193353 0.00460344] , rmse_elm= [0.13714384 0.05211565 0.0448706 ]\n",
      "l2_rel_err_swim= [0.01714538 0.01846111 0.00668867] , l2_rel_err_elm= [0.20259281 0.07818831 0.0656898 ]\n",
      "n_s= 20 , n_b= 2 , reg_const= 1e-12\n",
      "scale_bc= 0.008666197458902994 , domain_boundary_percent= 0.010666688283284506\n",
      "time_elm= 0.07804336306573294 , time_swim= 0.009421308200772355\n",
      "rmse_swim= [0.01172695 0.01193353 0.00460344] , rmse_elm= [0.13714384 0.05211565 0.0448706 ]\n",
      "l2_rel_err_swim= [0.01714538 0.01846111 0.00668867] , l2_rel_err_elm= [0.20259281 0.07818831 0.0656898 ]\n",
      "n_s= 44 , n_b= 5 , reg_const= 1e-07\n",
      "scale_bc= 0.010104179382324219 , domain_boundary_percent= 0.010845820109049479\n",
      "time_elm= 0.001294643954376299 , time_swim= 0.00026894311115653136\n",
      "rmse_swim= [0.00012933 0.00019299 0.00048451] , rmse_elm= [0.00030247 0.00155212 0.00202934]\n",
      "l2_rel_err_swim= [0.00018326 0.00027718 0.00073557] , l2_rel_err_elm= [0.00044817 0.0023772  0.00303173]\n",
      "n_s= 44 , n_b= 5 , reg_const= 1e-08\n",
      "scale_bc= 0.009688218434651693 , domain_boundary_percent= 0.009995381037394205\n",
      "time_elm= 0.0006750521543287242 , time_swim= 5.8731999795908915e-05\n",
      "rmse_swim= [3.44127585e-05 1.05943007e-04 3.58402335e-05] , rmse_elm= [0.00014761 0.00136442 0.00051313]\n",
      "l2_rel_err_swim= [5.16932294e-05 1.54128189e-04 5.51310954e-05] , l2_rel_err_elm= [0.00021349 0.00209902 0.00074172]\n",
      "n_s= 44 , n_b= 5 , reg_const= 1e-09\n",
      "scale_bc= 0.010013421376546225 , domain_boundary_percent= 0.011002699534098307\n",
      "time_elm= 0.0005204928374492559 , time_swim= 1.5368225267318033e-05\n",
      "rmse_swim= [3.44127585e-05 4.99960407e-06 6.69231322e-06] , rmse_elm= [0.00037035 0.00099362 0.00019751]\n",
      "l2_rel_err_swim= [5.16932294e-05 7.19513681e-06 1.01555318e-05] , l2_rel_err_elm= [0.00055027 0.00152354 0.00030174]\n",
      "n_s= 44 , n_b= 5 , reg_const= 1e-10\n",
      "scale_bc= 0.00967264175415039 , domain_boundary_percent= 0.009818951288859049\n",
      "time_elm= 0.0005585065366320416 , time_swim= 5.587788643533839e-06\n",
      "rmse_swim= [2.37606513e-06 4.99960407e-06 9.38769673e-06] , rmse_elm= [5.91607301e-05 1.13451599e-03 4.81842886e-04]\n",
      "l2_rel_err_swim= [3.49722936e-06 7.19513681e-06 1.38562245e-05] , l2_rel_err_elm= [8.29517618e-05 1.74382863e-03 7.43955171e-04]\n",
      "n_s= 44 , n_b= 5 , reg_const= 1e-11\n",
      "scale_bc= 0.00983134905497233 , domain_boundary_percent= 0.01017618179321289\n",
      "time_elm= 0.0003209448019819235 , time_swim= 6.731698866814599e-06\n",
      "rmse_swim= [1.60826584e-06 8.73774087e-06 9.84908989e-06] , rmse_elm= [2.94105364e-05 4.90744179e-04 4.42679691e-04]\n",
      "l2_rel_err_swim= [2.44273319e-06 1.31025139e-05 1.45147059e-05] , l2_rel_err_elm= [4.44375686e-05 6.85857619e-04 6.83686965e-04]\n",
      "n_s= 44 , n_b= 5 , reg_const= 1e-12\n",
      "scale_bc= 0.009863138198852539 , domain_boundary_percent= 0.011508782704671225\n",
      "time_elm= 3.568459278602408e-05 , time_swim= 2.840516618666669e-06\n",
      "rmse_swim= [6.74536100e-07 5.26098588e-07 7.32091517e-06] , rmse_elm= [2.94105364e-05 3.14221002e-05 4.62211417e-05]\n",
      "l2_rel_err_swim= [1.02318145e-06 7.62065835e-07 1.09508793e-05] , l2_rel_err_elm= [4.44375686e-05 4.40365401e-05 7.13003288e-05]\n",
      "n_s= 68 , n_b= 8 , reg_const= 1e-07\n",
      "scale_bc= 0.011214971542358398 , domain_boundary_percent= 0.014429966608683268\n",
      "time_elm= 4.343935141139747e-05 , time_swim= 0.0001116920827204479\n",
      "rmse_swim= [4.51006921e-05 1.42950675e-04 1.47024881e-04] , rmse_elm= [3.37080144e-05 1.66028874e-05 8.00071524e-05]\n",
      "l2_rel_err_swim= [6.83337713e-05 1.93633627e-04 2.17175007e-04] , l2_rel_err_elm= [5.10137852e-05 2.53079999e-05 1.22190834e-04]\n",
      "n_s= 68 , n_b= 8 , reg_const= 1e-08\n",
      "scale_bc= 0.010993162790934244 , domain_boundary_percent= 0.010143041610717773\n",
      "time_elm= 2.8211413926848358e-05 , time_swim= 1.0951551153298296e-05\n",
      "rmse_swim= [1.16585965e-05 1.12720518e-05 9.92400511e-06] , rmse_elm= [1.17568357e-06 3.45140579e-06 8.00071524e-05]\n",
      "l2_rel_err_swim= [1.78316827e-05 1.67356143e-05 1.51156432e-05] , l2_rel_err_elm= [1.65410612e-06 4.94932402e-06 1.22190834e-04]\n",
      "n_s= 68 , n_b= 8 , reg_const= 1e-09\n",
      "scale_bc= 0.010405222574869791 , domain_boundary_percent= 0.012486139933268229\n",
      "time_elm= 1.305132954664895e-06 , time_swim= 6.110427192883708e-06\n",
      "rmse_swim= [5.11193660e-06 3.29533987e-06 9.92400511e-06] , rmse_elm= [1.55676374e-06 4.95641691e-07 1.86299344e-06]\n",
      "l2_rel_err_swim= [7.70241994e-06 4.55329584e-06 1.51156432e-05] , l2_rel_err_elm= [2.28733864e-06 7.60060648e-07 3.26245473e-06]\n",
      "n_s= 68 , n_b= 8 , reg_const= 1e-10\n",
      "scale_bc= 0.010356823603312174 , domain_boundary_percent= 0.011207898457845053\n",
      "time_elm= 8.525392634419536e-07 , time_swim= 4.1905506427554875e-07\n",
      "rmse_swim= [1.96093129e-07 6.01860081e-07 4.59211983e-07] , rmse_elm= [5.16588972e-07 1.78035382e-07 1.86299344e-06]\n",
      "l2_rel_err_swim= [2.91615091e-07 8.35806314e-07 6.95678888e-07] , l2_rel_err_elm= [7.20675007e-07 2.41303096e-07 3.26245473e-06]\n",
      "n_s= 68 , n_b= 8 , reg_const= 1e-11\n",
      "scale_bc= 0.010821342468261719 , domain_boundary_percent= 0.010518789291381836\n",
      "time_elm= 2.3161237776403792e-05 , time_swim= 3.393988406518113e-07\n",
      "rmse_swim= [1.71586372e-08 6.01860081e-07 3.99177804e-07] , rmse_elm= [1.24678052e-06 1.78035382e-07 6.80588974e-05]\n",
      "l2_rel_err_swim= [2.55855017e-08 8.35806314e-07 6.04698832e-07] , l2_rel_err_elm= [1.90825155e-06 2.41303096e-07 1.01707440e-04]\n",
      "n_s= 68 , n_b= 8 , reg_const= 1e-12\n",
      "scale_bc= 0.010449886322021484 , domain_boundary_percent= 0.011998971303304037\n",
      "time_elm= 1.239755519443084e-05 , time_swim= 1.0379930388432657e-07\n",
      "rmse_swim= [1.68378997e-08 3.30687598e-08 2.61491252e-07] , rmse_elm= [7.45684316e-06 8.08921224e-07 2.89269012e-05]\n",
      "l2_rel_err_swim= [2.51828220e-08 4.79569413e-08 3.94907951e-07] , l2_rel_err_elm= [1.15305763e-05 1.10870200e-06 4.21512174e-05]\n",
      "n_s= 93 , n_b= 11 , reg_const= 1e-07\n",
      "scale_bc= 0.012324889500935873 , domain_boundary_percent= 0.026540120442708332\n",
      "time_elm= 5.014759150487626e-05 , time_swim= 5.760344217948769e-05\n",
      "rmse_swim= [4.95215566e-06 1.47109903e-04 2.07482680e-05] , rmse_elm= [1.64095476e-05 4.70458538e-05 8.69873731e-05]\n",
      "l2_rel_err_swim= [7.35844401e-06 2.03432838e-04 3.04886993e-05] , l2_rel_err_elm= [2.50576656e-05 6.57978431e-05 1.27223399e-04]\n",
      "n_s= 93 , n_b= 11 , reg_const= 1e-08\n",
      "scale_bc= 0.012013832728068033 , domain_boundary_percent= 0.012194951375325521\n",
      "time_elm= 1.0528206993067753e-05 , time_swim= 8.921727030302975e-06\n",
      "rmse_swim= [3.73864982e-06 2.01318558e-06 2.10133457e-05] , rmse_elm= [3.89404659e-07 4.24946322e-07 3.07702700e-05]\n",
      "l2_rel_err_swim= [5.47393890e-06 2.81242435e-06 3.08088519e-05] , l2_rel_err_elm= [5.71028030e-07 5.94552681e-07 4.32053785e-05]\n",
      "n_s= 93 , n_b= 11 , reg_const= 1e-09\n",
      "scale_bc= 0.011333227157592773 , domain_boundary_percent= 0.011365652084350586\n",
      "time_elm= 2.001286809860345e-06 , time_swim= 1.947193919477169e-06\n",
      "rmse_swim= [1.16243062e-06 2.27398711e-06 2.40516403e-06] , rmse_elm= [3.04848213e-07 2.58007911e-07 5.44100431e-06]\n",
      "l2_rel_err_swim= [1.69976301e-06 3.33309230e-06 3.49797722e-06] , l2_rel_err_elm= [4.50051445e-07 3.51613055e-07 7.82204311e-06]\n",
      "n_s= 93 , n_b= 11 , reg_const= 1e-10\n",
      "scale_bc= 0.011343638102213541 , domain_boundary_percent= 0.011869668960571289\n",
      "time_elm= 3.756496572472323e-07 , time_swim= 2.771078822404043e-07\n",
      "rmse_swim= [8.35663541e-08 5.65909131e-08 6.91166380e-07] , rmse_elm= [2.36320186e-08 7.46101786e-08 1.02870677e-06]\n",
      "l2_rel_err_swim= [1.27085068e-07 8.04688295e-08 1.05524092e-06] , l2_rel_err_elm= [3.55820399e-08 1.05763701e-07 1.46617733e-06]\n",
      "n_s= 93 , n_b= 11 , reg_const= 1e-11\n",
      "scale_bc= 0.011334737141927084 , domain_boundary_percent= 0.011835813522338867\n",
      "time_elm= 8.048827385909966e-08 , time_swim= 1.6284102630911836e-07\n",
      "rmse_swim= [3.19310557e-09 3.72146975e-07 1.13182999e-07] , rmse_elm= [9.10304404e-08 4.36785240e-08 1.06755857e-07]\n",
      "l2_rel_err_swim= [4.83850890e-09 5.60345473e-07 1.70495227e-07] , l2_rel_err_elm= [1.40046684e-07 6.25803582e-08 1.64850754e-07]\n",
      "n_s= 93 , n_b= 11 , reg_const= 1e-12\n",
      "scale_bc= 0.01250926653544108 , domain_boundary_percent= 0.012071530024210611\n",
      "time_elm= 5.660169146177585e-08 , time_swim= 1.691502664821827e-08\n",
      "rmse_swim= [1.36208160e-08 6.75256088e-09 3.03717030e-08] , rmse_elm= [2.59344783e-08 4.36785240e-08 1.00192072e-07]\n",
      "l2_rel_err_swim= [2.03857324e-08 1.02984863e-08 4.63024845e-08] , l2_rel_err_elm= [3.72438908e-08 6.25803582e-08 1.45659435e-07]\n",
      "n_s= 117 , n_b= 14 , reg_const= 1e-07\n",
      "scale_bc= 0.012623786926269531 , domain_boundary_percent= 0.0159298578898112\n",
      "time_elm= 0.00022559289519569724 , time_swim= 3.7241669208275015e-05\n",
      "rmse_swim= [8.26500463e-05 1.81213086e-05 1.09536527e-05] , rmse_elm= [1.86913341e-05 4.98943069e-06 6.53097921e-04]\n",
      "l2_rel_err_swim= [1.17012387e-04 2.52484100e-05 1.60267278e-05] , l2_rel_err_elm= [2.63106949e-05 7.19393479e-06 9.38715642e-04]\n",
      "n_s= 117 , n_b= 14 , reg_const= 1e-08\n",
      "scale_bc= 0.012065410614013672 , domain_boundary_percent= 0.011013189951578775\n",
      "time_elm= 1.059919911541937e-05 , time_swim= 1.1074869185765867e-05\n",
      "rmse_swim= [1.35690491e-05 1.14550901e-05 8.20046835e-06] , rmse_elm= [6.48635062e-06 2.42792261e-06 2.28833241e-05]\n",
      "l2_rel_err_swim= [1.95804705e-05 1.75022979e-05 1.18690310e-05] , l2_rel_err_elm= [8.72701328e-06 3.51169610e-06 3.15755482e-05]\n",
      "n_s= 117 , n_b= 14 , reg_const= 1e-09\n",
      "scale_bc= 0.014904181162516275 , domain_boundary_percent= 0.01449147860209147\n",
      "time_elm= 3.1928324490763773e-07 , time_swim= 9.66082397601571e-07\n",
      "rmse_swim= [1.21172850e-06 1.06053628e-06 6.25982413e-07] , rmse_elm= [2.31034231e-07 6.00502177e-08 6.66765286e-07]\n",
      "l2_rel_err_swim= [1.73804039e-06 1.50194327e-06 9.40616410e-07] , l2_rel_err_elm= [3.35359094e-07 9.12101614e-08 9.27388017e-07]\n",
      "n_s= 117 , n_b= 14 , reg_const= 1e-10\n",
      "scale_bc= 0.013204256693522135 , domain_boundary_percent= 0.012868801752726236\n",
      "time_elm= 2.021600217436251e-07 , time_swim= 2.7854274879889757e-07\n",
      "rmse_swim= [4.44485694e-07 1.48443698e-07 2.42698854e-07] , rmse_elm= [1.16334002e-07 5.55773075e-08 4.34568756e-07]\n",
      "l2_rel_err_swim= [6.19481557e-07 2.19629455e-07 3.51361525e-07] , l2_rel_err_elm= [1.68672846e-07 8.21007914e-08 6.42497430e-07]\n",
      "n_s= 117 , n_b= 14 , reg_const= 1e-11\n",
      "scale_bc= 0.011722326278686523 , domain_boundary_percent= 0.012050469716389975\n",
      "time_elm= 2.2322763680092687e-07 , time_swim= 2.8030336151809617e-08\n",
      "rmse_swim= [2.03591114e-08 1.86375619e-08 4.50943352e-08] , rmse_elm= [9.76634175e-08 1.18220365e-08 5.60197456e-07]\n",
      "l2_rel_err_swim= [2.91491726e-08 2.70508702e-08 6.66379360e-08] , l2_rel_err_elm= [1.40261264e-07 1.83974990e-08 8.36910045e-07]\n",
      "n_s= 117 , n_b= 14 , reg_const= 1e-12\n",
      "scale_bc= 0.011548916498819986 , domain_boundary_percent= 0.013718366622924805\n",
      "time_elm= 3.003710033945134e-08 , time_swim= 9.583364708150943e-09\n",
      "rmse_swim= [8.47887986e-09 1.01519101e-08 1.01193041e-08] , rmse_elm= [3.24055399e-08 6.47909145e-09 5.12266696e-08]\n",
      "l2_rel_err_swim= [1.26532961e-08 1.53145284e-08 1.42715958e-08] , l2_rel_err_elm= [4.82431822e-08 9.72001566e-09 8.18144098e-08]\n",
      "n_s= 142 , n_b= 17 , reg_const= 1e-07\n",
      "scale_bc= 0.015688021977742512 , domain_boundary_percent= 0.01417088508605957\n",
      "time_elm= 1.1173131473482926e-05 , time_swim= 1.4679666477818617e-05\n",
      "rmse_swim= [1.63424428e-05 7.69780110e-06 1.99987556e-05] , rmse_elm= [2.02480481e-06 5.05617222e-06 2.64384174e-05]\n",
      "l2_rel_err_swim= [2.48996042e-05 1.07337288e-05 2.90272129e-05] , l2_rel_err_elm= [2.82773416e-06 7.13096715e-06 3.79320699e-05]\n",
      "n_s= 142 , n_b= 17 , reg_const= 1e-08\n",
      "scale_bc= 0.01300954818725586 , domain_boundary_percent= 0.016013145446777344\n",
      "time_elm= 1.8722285976108248e-06 , time_swim= 6.491909223859612e-06\n",
      "rmse_swim= [1.45896659e-05 3.74249847e-06 1.14356327e-06] , rmse_elm= [2.18431475e-06 5.08581293e-07 2.92378975e-06]\n",
      "l2_rel_err_swim= [2.22359793e-05 5.32201852e-06 1.96087724e-06] , l2_rel_err_elm= [3.00349950e-06 7.11753149e-07 4.06213380e-06]\n",
      "n_s= 142 , n_b= 17 , reg_const= 1e-09\n",
      "scale_bc= 0.012430985768636068 , domain_boundary_percent= 0.014435768127441406\n",
      "time_elm= 2.8931834922665156e-07 , time_swim= 7.46448438347116e-07\n",
      "rmse_swim= [1.58494428e-06 2.45246410e-07 4.09154628e-07] , rmse_elm= [2.14524606e-07 1.84226091e-07 4.69204351e-07]\n",
      "l2_rel_err_swim= [2.20963275e-06 3.68037301e-07 5.97478523e-07] , l2_rel_err_elm= [3.12669979e-07 2.66408366e-07 7.16773446e-07]\n",
      "n_s= 142 , n_b= 17 , reg_const= 1e-10\n",
      "scale_bc= 0.013738791147867838 , domain_boundary_percent= 0.018936951955159504\n",
      "time_elm= 1.5811209379777933e-07 , time_swim= 2.3587357311840268e-07\n",
      "rmse_swim= [9.85636028e-08 2.17281376e-07 3.91775740e-07] , rmse_elm= [8.52696494e-09 8.14242323e-09 4.57666893e-07]\n",
      "l2_rel_err_swim= [1.44579274e-07 3.17084197e-07 5.73764069e-07] , l2_rel_err_elm= [1.18493886e-08 1.25336830e-08 6.94198990e-07]\n",
      "n_s= 142 , n_b= 17 , reg_const= 1e-11\n",
      "scale_bc= 0.013837814331054688 , domain_boundary_percent= 0.013546307881673178\n",
      "time_elm= 1.065136287213845e-08 , time_swim= 1.428226956828621e-08\n",
      "rmse_swim= [2.20752596e-08 3.25328414e-09 1.75182650e-08] , rmse_elm= [8.83332735e-09 2.03261924e-09 2.10881420e-08]\n",
      "l2_rel_err_swim= [3.37275264e-08 4.84741606e-09 2.43440069e-08] , l2_rel_err_elm= [1.2487778e-08 3.3176449e-09 3.1636511e-08]\n",
      "n_s= 142 , n_b= 17 , reg_const= 1e-12\n",
      "scale_bc= 0.01778872807820638 , domain_boundary_percent= 0.015002806981404623\n",
      "time_elm= 1.4120006218334429e-08 , time_swim= 5.289718930830568e-09\n",
      "rmse_swim= [1.10041278e-08 2.06446331e-09 2.80056572e-09] , rmse_elm= [1.04216837e-08 2.62534049e-09 2.93129945e-08]\n",
      "l2_rel_err_swim= [1.68044180e-08 3.02442412e-09 4.01503151e-09] , l2_rel_err_elm= [1.55432110e-08 4.01525469e-09 4.48543695e-08]\n",
      "n_s= 166 , n_b= 20 , reg_const= 1e-07\n",
      "scale_bc= 0.016172250111897785 , domain_boundary_percent= 0.017000913619995117\n",
      "time_elm= 4.1852873266817696e-06 , time_swim= 2.3717661331133187e-05\n",
      "rmse_swim= [2.91146668e-05 1.64458312e-05 2.55924860e-05] , rmse_elm= [2.32307936e-06 4.54230081e-06 5.69048181e-06]\n",
      "l2_rel_err_swim= [4.38727933e-05 2.46906912e-05 3.50184251e-05] , l2_rel_err_elm= [3.17120570e-06 6.44974892e-06 9.17031164e-06]\n",
      "n_s= 166 , n_b= 20 , reg_const= 1e-08\n",
      "scale_bc= 0.014615774154663086 , domain_boundary_percent= 0.016317208607991535\n",
      "time_elm= 1.1317546270444006e-06 , time_swim= 1.8541721338625154e-06\n",
      "rmse_swim= [1.56138371e-06 1.00224148e-06 2.99889122e-06] , rmse_elm= [3.58858973e-07 1.17462362e-06 1.86178129e-06]\n",
      "l2_rel_err_swim= [2.12765966e-06 1.50949573e-06 4.50539876e-06] , l2_rel_err_elm= [5.35741696e-07 1.69649731e-06 2.82470342e-06]\n",
      "n_s= 166 , n_b= 20 , reg_const= 1e-09\n",
      "scale_bc= 0.014519373575846354 , domain_boundary_percent= 0.017006953557332356\n",
      "time_elm= 2.549975883206516e-07 , time_swim= 7.440307884754972e-07\n",
      "rmse_swim= [1.35925623e-06 6.13813292e-07 2.59022841e-07] , rmse_elm= [1.48857191e-07 5.60107532e-07 5.60280420e-08]\n",
      "l2_rel_err_swim= [1.86877319e-06 9.23546603e-07 3.91789103e-07] , l2_rel_err_elm= [2.20449183e-07 8.07840185e-07 8.18802007e-08]\n",
      "n_s= 166 , n_b= 20 , reg_const= 1e-10\n",
      "scale_bc= 0.015043973922729492 , domain_boundary_percent= 0.014140844345092773\n",
      "time_elm= 1.2527730432747041e-08 , time_swim= 1.1340306881472245e-07\n",
      "rmse_swim= [2.29056561e-08 2.09440202e-07 1.07863349e-07] , rmse_elm= [1.19614006e-08 1.98035340e-08 5.81825664e-09]\n",
      "l2_rel_err_swim= [3.12885533e-08 2.95479712e-07 1.58913446e-07] , l2_rel_err_elm= [1.65568875e-08 2.82960219e-08 8.91129088e-09]\n",
      "n_s= 166 , n_b= 20 , reg_const= 1e-11\n",
      "scale_bc= 0.014596144358317057 , domain_boundary_percent= 0.013369878133138021\n",
      "time_elm= 1.163494198138132e-08 , time_swim= 8.154915889551548e-09\n",
      "rmse_swim= [1.42129340e-08 7.10323837e-09 3.14857527e-09] , rmse_elm= [7.35943491e-09 2.35543503e-08 3.99104078e-09]\n",
      "l2_rel_err_swim= [2.02430485e-08 1.02403046e-08 4.74250355e-09] , l2_rel_err_elm= [1.09890184e-08 3.36410386e-08 5.74736319e-09]\n",
      "n_s= 166 , n_b= 20 , reg_const= 1e-12\n",
      "scale_bc= 0.01558224360148112 , domain_boundary_percent= 0.016567468643188477\n",
      "time_elm= 1.2065158260445116e-08 , time_swim= 3.4086832865495896e-09\n",
      "rmse_swim= [2.04249992e-09 5.53971568e-09 2.64383426e-09] , rmse_elm= [1.15050547e-08 2.31045093e-08 1.58591081e-09]\n",
      "l2_rel_err_swim= [2.76786488e-09 8.01067930e-09 3.89869340e-09] , l2_rel_err_elm= [1.58224354e-08 3.31809452e-08 2.24007472e-09]\n",
      "n_s= 191 , n_b= 23 , reg_const= 1e-07\n",
      "scale_bc= 0.02818783124287923 , domain_boundary_percent= 0.02293531099955241\n",
      "time_elm= 1.7485518209544712e-05 , time_swim= 1.0033647686501712e-05\n",
      "rmse_swim= [5.26194949e-06 6.45830066e-06 1.83806929e-05] , rmse_elm= [2.14978042e-06 3.35733510e-05 1.67334232e-05]\n",
      "l2_rel_err_swim= [7.54976201e-06 9.60905420e-06 2.73158019e-05] , l2_rel_err_elm= [3.13771836e-06 3.80987509e-05 2.49626187e-05]\n",
      "n_s= 191 , n_b= 23 , reg_const= 1e-08\n",
      "scale_bc= 0.01643482844034831 , domain_boundary_percent= 0.017740249633789062\n",
      "time_elm= 4.363117649977518e-07 , time_swim= 3.5856840618442694e-06\n",
      "rmse_swim= [4.54086458e-06 5.26662824e-06 9.49559371e-07] , rmse_elm= [8.80031868e-07 2.22581233e-07 2.06322194e-07]\n",
      "l2_rel_err_swim= [6.77012484e-06 8.03555495e-06 1.41206535e-06] , l2_rel_err_elm= [1.28977820e-06 3.33529338e-07 2.98546231e-07]\n",
      "n_s= 191 , n_b= 23 , reg_const= 1e-09\n",
      "scale_bc= 0.013054132461547852 , domain_boundary_percent= 0.01484227180480957\n",
      "time_elm= 6.571723027748908e-08 , time_swim= 4.936315104731269e-07\n",
      "rmse_swim= [3.43278708e-08 1.04031925e-06 4.06247414e-07] , rmse_elm= [9.35136655e-08 2.51782658e-08 7.84597595e-08]\n",
      "l2_rel_err_swim= [5.12304676e-08 1.45372331e-06 6.09239079e-07] , l2_rel_err_elm= [1.46740588e-07 3.47606653e-08 1.15523032e-07]\n",
      "n_s= 191 , n_b= 23 , reg_const= 1e-10\n",
      "scale_bc= 0.016299962997436523 , domain_boundary_percent= 0.017567952473958332\n",
      "time_elm= 3.850573471093099e-08 , time_swim= 8.540444710658819e-08\n",
      "rmse_swim= [4.11798871e-08 1.00249130e-07 1.14784324e-07] , rmse_elm= [1.01508362e-07 3.05241958e-09 1.09564225e-08]\n",
      "l2_rel_err_swim= [6.25202121e-08 1.52779845e-07 1.58359200e-07] , l2_rel_err_elm= [1.56330593e-07 4.81766435e-09 1.65241626e-08]\n",
      "n_s= 191 , n_b= 23 , reg_const= 1e-11\n",
      "scale_bc= 0.015598217646280924 , domain_boundary_percent= 0.016878286997477215\n",
      "time_elm= 8.820570220785607e-09 , time_swim= 1.007664921821296e-08\n",
      "rmse_swim= [1.59713443e-08 1.20554665e-08 2.20313687e-09] , rmse_elm= [1.68494778e-08 6.46777385e-09 3.14445899e-09]\n",
      "l2_rel_err_swim= [2.31557892e-08 1.81515741e-08 3.28818394e-09] , l2_rel_err_elm= [2.55976121e-08 9.08226589e-09 4.40568811e-09]\n",
      "n_s= 191 , n_b= 23 , reg_const= 1e-12\n",
      "scale_bc= 0.014828920364379883 , domain_boundary_percent= 0.016449133555094402\n",
      "time_elm= 5.395706574586724e-09 , time_swim= 5.984929981656359e-09\n",
      "rmse_swim= [3.35020448e-09 1.20339391e-08 2.57064634e-09] , rmse_elm= [6.91791417e-09 4.40200067e-09 4.86720488e-09]\n",
      "l2_rel_err_swim= [4.97682576e-09 1.81170312e-08 3.85288038e-09] , l2_rel_err_elm= [9.88486439e-09 6.44337938e-09 6.73427829e-09]\n",
      "n_s= 215 , n_b= 26 , reg_const= 1e-07\n",
      "scale_bc= 0.08951719601949056 , domain_boundary_percent= 0.018340269724527996\n",
      "time_elm= 1.5234376739429104e+36 , time_swim= 7.416092273493061e-06\n",
      "rmse_swim= [1.00041507e-05 9.82055266e-06 2.42357345e-06] , rmse_elm= [2.10471751e+04 4.27969414e+12 4.57031302e+36]\n",
      "l2_rel_err_swim= [1.49242282e-05 1.37896473e-05 3.58407243e-06] , l2_rel_err_elm= [3.58857073e+04 6.27092272e+12 8.88393432e+36]\n",
      "n_s= 215 , n_b= 26 , reg_const= 1e-08\n",
      "scale_bc= 0.06324338912963867 , domain_boundary_percent= 0.017838716506958008\n",
      "time_elm= 0.11086342149053945 , time_swim= 2.186476929488917e-06\n",
      "rmse_swim= [2.90778302e-06 1.27631083e-06 2.37533693e-06] , rmse_elm= [2.61277776e-07 3.83029390e-04 3.32206974e-01]\n",
      "l2_rel_err_swim= [4.37043238e-06 1.94237549e-06 3.56571632e-06] , l2_rel_err_elm= [2.77303340e-07 5.68418015e-04 4.68552808e-01]\n",
      "n_s= 215 , n_b= 26 , reg_const= 1e-09\n",
      "scale_bc= 0.019674380620320637 , domain_boundary_percent= 0.017339547475179035\n",
      "time_elm= 6.438849343186061e-07 , time_swim= 6.390903869738559e-07\n",
      "rmse_swim= [1.17826460e-06 2.89949244e-07 4.49057320e-07] , rmse_elm= [2.91256800e-07 7.36004449e-07 9.04393554e-07]\n",
      "l2_rel_err_swim= [1.71324913e-06 4.02538764e-07 6.56645044e-07] , l2_rel_err_elm= [4.04287765e-07 9.85316264e-07 1.29908207e-06]\n",
      "n_s= 215 , n_b= 26 , reg_const= 1e-10\n",
      "scale_bc= 0.016893545786539715 , domain_boundary_percent= 0.018002430597941082\n",
      "time_elm= 2.6510301182965678e-08 , time_swim= 2.961354562450547e-08\n",
      "rmse_swim= [1.97038261e-08 3.60012368e-08 3.31355740e-08] , rmse_elm= [2.21906517e-08 1.34299787e-08 4.39102731e-08]\n",
      "l2_rel_err_swim= [2.65964543e-08 5.45904314e-08 4.98980547e-08] , l2_rel_err_elm= [3.20833370e-08 1.95909843e-08 6.32136340e-08]\n",
      "n_s= 215 , n_b= 26 , reg_const= 1e-11\n",
      "scale_bc= 0.015998999277750652 , domain_boundary_percent= 0.020900408426920574\n",
      "time_elm= 5.505752744241019e-09 , time_swim= 1.4510810681302541e-08\n",
      "rmse_swim= [1.41542055e-08 4.06842882e-09 2.53097977e-08] , rmse_elm= [8.54545848e-09 3.14682853e-09 4.82497122e-09]\n",
      "l2_rel_err_swim= [1.96170180e-08 5.77481024e-09 3.84908108e-08] , l2_rel_err_elm= [1.27467232e-08 4.41847432e-09 7.29308834e-09]\n",
      "n_s= 215 , n_b= 26 , reg_const= 1e-12\n",
      "scale_bc= 0.018303394317626953 , domain_boundary_percent= 0.019675016403198242\n",
      "time_elm= 5.524579941972315e-09 , time_swim= 1.3480641300599882e-09\n",
      "rmse_swim= [2.70651371e-09 1.02730898e-09 3.10369696e-10] , rmse_elm= [8.89299291e-09 4.06906458e-09 3.61168234e-09]\n",
      "l2_rel_err_swim= [3.75505394e-09 1.50867169e-09 4.43386528e-10] , l2_rel_err_elm= [1.23658179e-08 5.78274172e-09 5.58278933e-09]\n",
      "n_s= 240 , n_b= 30 , reg_const= 1e-07\n",
      "scale_bc= 0.07705465952555339 , domain_boundary_percent= 0.02066342035929362\n",
      "time_elm= 566629063179895.1 , time_swim= 4.5179091798506455e-06\n",
      "rmse_swim= [6.84276498e-06 2.34510626e-06 4.36585630e-06] , rmse_elm= [1.12182059e+05 2.03922176e+02 1.69988719e+15]\n",
      "l2_rel_err_swim= [1.02050859e-05 3.29359385e-06 5.92394951e-06] , l2_rel_err_elm= [1.67363485e+05 3.14787887e+02 3.23170009e+15]\n",
      "n_s= 240 , n_b= 30 , reg_const= 1e-08\n",
      "scale_bc= 0.11441882451375325 , domain_boundary_percent= 0.022001187006632488\n",
      "time_elm= 3.436432471842919e+45 , time_swim= 3.977722067151217e-06\n",
      "rmse_swim= [4.61713498e-06 3.12261409e-06 4.19341713e-06] , rmse_elm= [1.24821304e+13 3.28076521e+39 1.03092941e+46]\n",
      "l2_rel_err_swim= [6.81385743e-06 4.21803435e-06 5.71481315e-06] , l2_rel_err_elm= [2.42630478e+13 6.37726617e+39 2.00395666e+46]\n",
      "n_s= 240 , n_b= 30 , reg_const= 1e-09\n",
      "scale_bc= 0.053178866704305015 , domain_boundary_percent= 0.020029067993164062\n",
      "time_elm= 0.0001536646215053326 , time_swim= 3.986060303524867e-07\n",
      "rmse_swim= [4.05247004e-07 4.75453003e-08 7.43025787e-07] , rmse_elm= [4.56854787e-04 3.59029283e-06 5.48785062e-07]\n",
      "l2_rel_err_swim= [5.74410346e-07 5.45168172e-08 1.13107857e-06] , l2_rel_err_elm= [6.86474598e-04 5.32421196e-06 7.42307453e-07]\n",
      "n_s= 240 , n_b= 30 , reg_const= 1e-10\n",
      "scale_bc= 0.024847030639648438 , domain_boundary_percent= 0.018900632858276367\n",
      "time_elm= 5.2099443235747045e-08 , time_swim= 4.9934042527861e-08\n",
      "rmse_swim= [5.93636194e-08 3.94111257e-08 5.10273825e-08] , rmse_elm= [1.22316168e-07 2.08118479e-08 1.31703140e-08]\n",
      "l2_rel_err_swim= [6.24884476e-08 4.55532358e-08 5.79979973e-08] , l2_rel_err_elm= [1.31224028e-07 2.70794228e-08 1.38584981e-08]\n",
      "n_s= 240 , n_b= 30 , reg_const= 1e-11\n",
      "scale_bc= 0.0201718012491862 , domain_boundary_percent= 0.02066969871520996\n",
      "time_elm= 6.68372673622384e-09 , time_swim= 3.07400990029874e-08\n",
      "rmse_swim= [3.75709669e-08 3.12559631e-08 2.33933670e-08] , rmse_elm= [7.76556658e-09 7.69226452e-09 4.59334911e-09]\n",
      "l2_rel_err_swim= [5.21431385e-08 4.21833814e-08 3.29705226e-08] , l2_rel_err_elm= [8.68445521e-09 1.08063754e-08 6.68412756e-09]\n",
      "n_s= 240 , n_b= 30 , reg_const= 1e-12\n",
      "scale_bc= 0.019334952036539715 , domain_boundary_percent= 0.019341786702473957\n",
      "time_elm= 1.5763476101321247e-08 , time_swim= 1.3502091878957386e-08\n",
      "rmse_swim= [2.34414302e-08 1.09134615e-08 6.15138394e-09] , rmse_elm= [1.93142982e-08 2.28368057e-08 5.13932442e-09]\n",
      "l2_rel_err_swim= [3.41256995e-08 1.65380091e-08 9.03143412e-09] , l2_rel_err_elm= [3.10493487e-08 3.14551176e-08 7.09578199e-09]\n"
     ]
    }
   ],
   "source": [
    "experiments = []\n",
    "seeds = [1, 2, 3]\n",
    "for n_data in n_s:\n",
    "    for r in ratios: \n",
    "        for reg in reg_OBF:\n",
    "            for n_i in n_IBFs_factors:\n",
    "                info = []\n",
    "                n_OBF = int(n_data//r) #2 # Number of outer basis functions\n",
    "                n_IBF = int(n_i * n_OBF) # Number of inner basis functions\n",
    "                t_eval = np.linspace(0, 1, 100)\n",
    "                x_space = np.linspace(x_lim[0], x_lim[1], n_data).reshape((-1, 1))\n",
    "\n",
    "                # interior points\n",
    "                x_space_inner = x_space[1:-1]\n",
    "                interior_points = x_space_inner\n",
    "\n",
    "                # coordinates of boundary points (excluding corners)\n",
    "                left = x_lim[0]\n",
    "                right = x_lim[1]\n",
    "                boundary_points = np.row_stack([left, right])\n",
    "\n",
    "                # normal vectors on the boundary\n",
    "                normal_vectors = boundary_points.copy()\n",
    "                normal_vectors[0] = 1 #-1\n",
    "                normal_vectors[1] = 1 #1\n",
    "\n",
    "                domain = Domain(\n",
    "                    interior_points=interior_points,\n",
    "                    boundary_points=boundary_points,\n",
    "                    normal_vectors=normal_vectors\n",
    "                )\n",
    "\n",
    "                # Set boundary conditions\n",
    "                boundary_condition = \"periodic\"\n",
    "\n",
    "                # Test Data\n",
    "                x_space_test = np.linspace(np.min(x_space), np.max(x_space), n_test).reshape((-1, 1))\n",
    "                u_true_test = analytical_sol(x_space_test, t_eval).T\n",
    "                \n",
    "                def periodic_outer_basis_sine(x_space, n_outer_basis=None, initial_condition=None):\n",
    "                        return np.column_stack([\n",
    "                            sine_cos(x_space * (i+1))\n",
    "                            for i in range(n_outer_basis//2)\n",
    "                            for sine_cos in [np.sin, np.cos]\n",
    "                        ])\n",
    "                rng = np.random.default_rng(123)\n",
    "                \n",
    "                def sample_parameters_randomly(x, _, rng):\n",
    "                    weights = rng.normal(loc=0, scale=1, size=(x.shape[1], n_IBF))\n",
    "                    biases = rng.uniform(low=-4, high=4, size=(1, n_IBF)) # low=-np.pi, high=np.pi,  2 * np.pi\n",
    "                    idx0 = None\n",
    "                    idx1 = None\n",
    "                    return weights, biases, idx0, idx1\n",
    "                \n",
    "                \n",
    "                # Loop over different seeds\n",
    "                rmse_swim = np.ones((len(seeds), ))\n",
    "                rmse_swim_rs = np.ones((len(seeds), ))\n",
    "                rmse_elm = np.ones((len(seeds), ))\n",
    "                rel_err_swim = np.ones((len(seeds), ))\n",
    "                rel_err_swim_rs = np.ones((len(seeds), ))\n",
    "                rel_err_elm = np.ones((len(seeds), ))\n",
    "                time_swim = np.ones((len(seeds), ))\n",
    "                time_swim_rs = np.ones((len(seeds), ))\n",
    "                time_elm = np.ones((len(seeds), ))\n",
    "                l2_rel_err_elm = np.ones((len(seeds), ))\n",
    "                l2_rel_err_swim = np.ones((len(seeds), ))\n",
    "                j = 0\n",
    "                for s in seeds:\n",
    "                    # ELM ansatz\n",
    "                    ansatz_elm = BoundaryCompliantAnsatz(\n",
    "                        n_outer_basis=n_OBF,\n",
    "                        n_inner_basis=n_IBF,\n",
    "                        activation=\"tanh\",\n",
    "                        target_gen=periodic_outer_basis_sine,\n",
    "                        random_state=s,\n",
    "                        regularization_scale=reg,\n",
    "                        parameter_sampler = sample_parameters_randomly\n",
    "                    )\n",
    "                    # SWIM ansatz\n",
    "                    ansatz_swim = BoundaryCompliantAnsatz(\n",
    "                        n_outer_basis=n_OBF,\n",
    "                        n_inner_basis=n_IBF,\n",
    "                        activation=\"tanh\",\n",
    "                        target_gen=periodic_outer_basis_sine,\n",
    "                        random_state=s,\n",
    "                        regularization_scale=reg,\n",
    "                    )\n",
    "\n",
    "                    # Set advection solver\n",
    "                    adv_solver_elm = AdvectionSolver(\n",
    "                        domain=domain, \n",
    "                        ansatz=ansatz_elm,\n",
    "                        u0=u0,\n",
    "                        boundary_condition=boundary_condition,\n",
    "                        c=conv_coeff,\n",
    "                        forcing=forcing,\n",
    "                        regularization_scale=reg,\n",
    "                    )\n",
    "                    adv_solver_swim = AdvectionSolver(\n",
    "                        domain=domain, \n",
    "                        ansatz=ansatz_swim,\n",
    "                        u0=u0,\n",
    "                        boundary_condition=boundary_condition,\n",
    "                        c=conv_coeff,\n",
    "                        forcing=forcing,\n",
    "                        regularization_scale=reg,\n",
    "                    )\n",
    "\n",
    "                    # Compute weights and biases of the SWIM network\n",
    "                    time_blocks = 1\n",
    "                    t_swim_start = time.time()\n",
    "                    sol, solver_status = adv_solver_swim.fit(t_span=[0, np.max(t_eval)], rtol = 1e-10, atol = 1e-10, svd_cutoff=reg);\n",
    "                    t_swim_stop = time.time()\n",
    "                    time_swim[j] = t_swim_stop - t_swim_start\n",
    "                    \n",
    "                    t_elm_start = time.time()\n",
    "                    adv_solver_elm.fit(t_span=[0, np.max(t_eval)], rtol = 1e-10, atol = 1e-10, svd_cutoff=reg);\n",
    "                    t_elm_stop = time.time()\n",
    "                    time_elm[j] = t_elm_stop - t_elm_start\n",
    "\n",
    "                    # Evaluate solution\n",
    "                    u_elm_test = adv_solver_elm.evaluate(x_eval=x_space_test, t_eval = t_eval).T\n",
    "                    u_swim_test = adv_solver_swim.evaluate(x_eval=x_space_test, t_eval = t_eval).T #, solver_status=solver_status\n",
    "                    \n",
    "                    # Store useful info for plotting\n",
    "                    mse_elm = mean_squared_error(u_true_test, u_elm_test)  # mean squared error\n",
    "                    rmse_elm[j] = np.sqrt(mse_elm)  # Root Mean Squared Error\n",
    "                    mse_swim = mean_squared_error(u_true_test, u_swim_test)  # mean squared error\n",
    "                    rmse_swim[j] = np.sqrt(mse_swim)  # Root Mean Squared Error\n",
    "                    l2_rel_err_elm[j] = np.linalg.norm(u_elm_test - u_true_test, 2)/np.linalg.norm(u_true_test, 2)\n",
    "                    l2_rel_err_swim[j] = np.linalg.norm(u_swim_test - u_true_test, 2)/np.linalg.norm(u_true_test, 2)\n",
    "                    j += 1\n",
    "\n",
    "                info.append(n_data)\n",
    "                info.append(int(n_data//r))\n",
    "                info.append(reg)\n",
    "                info.append(np.mean(time_elm))\n",
    "                info.append(np.mean(time_swim))\n",
    "                info.append(np.mean(rmse_elm)) # 6\n",
    "                info.append(np.mean(rmse_swim))\n",
    "                info.append(np.mean(rel_err_elm))\n",
    "                info.append(np.mean(rel_err_swim))\n",
    "                info.append(np.mean(l2_rel_err_elm))\n",
    "                info.append(np.mean(l2_rel_err_swim))\n",
    "                info.append(np.min(l2_rel_err_elm))\n",
    "                info.append(np.min(l2_rel_err_swim))\n",
    "                print(\"n_s=\", info[0], \", n_b=\", info[1], \", reg_const=\", info[2])\n",
    "                print(\"scale_bc=\", info[3], \", domain_boundary_percent=\", info[4])\n",
    "                print(\"time_elm=\", info[5], \", time_swim=\", info[6])\n",
    "                print(\"rmse_swim=\", rmse_swim,\", rmse_elm=\", rmse_elm)\n",
    "                print(\"l2_rel_err_swim=\", l2_rel_err_swim,\", l2_rel_err_elm=\", l2_rel_err_elm)\n",
    "                experiments.append(info)\n",
    "                \n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Convergence plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 2  5  8 11 14 17 20 23 26 30]\n"
     ]
    },
    {
     "data": {
      "image/png": "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2WCdX39/fx5++GF2795Nu3btsLOzo379+vzvf/+7798gNjYWhULBxx9/zKeffoqfnx/29vZ07tyZEydOGJT/66+/6NSpE46Ojri5uTFgwACDFcSKa2MoSYzLly9n6NChAHTp0kX3Nyq6wjp48CC9evXCw8MDe3t7AgICeOqpp+57jlIJGTGluCTdc32A2x+jRo26Zz1hYWHC3t5e5OXllei406ZNE4Do3r27WLBggRg/frywsrISbdu21ZurftSoUcLPz0/vtYCYNm2a7vmJEyeEo6Oj8Pb2FrNmzRIffPCBCAgIECqVSuzbt09X7ubNmyIkJERYWVmJcePGia+++krMmjVLtG3bVhw5ckQIIcSNGzeEt7e3eO2118RXX30lPvroI9GwYUNhY2OjK5OZmSm++uorAYhBgwaJ7777Tnz33Xfi2LFjeud2u1GjRglADBkyRHzxxRdi5MiRAhADBw7UK+fn5ycaNmwoatWqJSZPniwWLlwoWrVqJRQKhThx4sQ9/6YXL14UgHjggQeEv7+/+PDDD8WMGTOEu7u78PT01FvrYNu2bcLa2loEBweLjz76SMyYMUN4eHiIGjVq6K1/sWzZMoM1MUoS4/nz58XLL78sADF58mTd3+jatWvi+vXrokaNGiI4OFjMnTtXLF68WEyZMkU0btz4nucnlZxMDJJRdu/eLbZt2ybeffddYW1tLTZt2iS2bdsmevfuLdq0aSO2bdsmtm3bJk6ePHnPemrUqCGaN29eomMmJiYKW1tb0bNnT6FWq3XbFy5cKACxdOlS3baSJIaBAwcKW1tbcf78ed22q1evCmdnZ/Hggw/qtk2dOtVgScUiGo1GCKFdsvHO5Jaamipq1aolnnrqKd22GzduGMRR5M7EcPToUQGIp59+Wq/cxIkTBSD++usv3baiRP3PP//otiUmJgqVSiVef/11g2Pdrigx2Nvbi7i4ON32qKgoAYhXX31Vt61FixbCy8tLJCcn67YdO3ZMKJVKMXLkSN22uyWGksS4du1aAYgdO3boxfnzzz8LQBw4cOCe5yOVnbyVJBklPDyc7t27k5mZSdu2bYmIiKB79+5cvnyZhx9+mO7du9O9e/f7LnSekZGBs7NziY65fft28vPzmTBhAkrlrX/C48aNw8XFhd9//73E8avVarZu3crAgQOpX7++bru3tzfDhw9n9+7d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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "res = np.vstack(experiments)\n",
    "rc_fonts = {\n",
    "    \"text.usetex\": False,\n",
    "}\n",
    "plt.rcParams.update(rc_fonts)\n",
    "\n",
    "# Extract the lowest mae, rmse, mse for a fixed number of collocation points\n",
    "mse_elm = np.ones((len(n_s),)) * 1e100\n",
    "rmse_elm = np.ones((len(n_s),)) * 1e100\n",
    "mae_elm = np.ones((len(n_s),)) * 1e100\n",
    "mse_swim = np.ones((len(n_s),)) * 1e100\n",
    "rmse_swim = np.ones((len(n_s),)) * 1e100\n",
    "mae_swim = np.ones((len(n_s),)) * 1e100\n",
    "l2_rel_err_elm = np.ones((len(n_s),)) * 1e100\n",
    "l2_rel_err_swim = np.ones((len(n_s),)) * 1e100\n",
    "l2_rel_err_elm_min = np.ones((len(n_s),)) * 1e100\n",
    "l2_rel_err_swim_min = np.ones((len(n_s),)) * 1e100\n",
    "s_i = 5 # Start index\n",
    "jump = len(reg_OBF) * len(ratios)\n",
    "for i in range(len(n_s)):\n",
    "    rmse_elm[i] = min(res[(i*jump):(i+1)*jump, s_i])\n",
    "    rmse_swim[i] = min(res[(i*jump):(i+1)*jump, s_i + 1])\n",
    "    l2_rel_err_elm[i] = min(res[(i*jump):(i+1)*jump, s_i + 4])\n",
    "    l2_rel_err_swim[i] = min(res[(i*jump):(i+1)*jump, s_i + 5])\n",
    "    l2_rel_err_elm_min[i] = min(res[(i*jump):(i+1)*jump, s_i + 6])\n",
    "    l2_rel_err_swim_min[i] = min(res[(i*jump):(i+1)*jump, s_i + 7])\n",
    "\n",
    "# Spectral convergence line\n",
    "pt_1 = 0\n",
    "pt_2 = 5\n",
    "\n",
    "x1 = n_s[pt_1]\n",
    "x2 = n_s[pt_2]\n",
    "y1 = l2_rel_err_elm[pt_1]\n",
    "y2 = l2_rel_err_elm[pt_2]\n",
    "\n",
    "# Compute the slope and intercept of the line (y = mx + c)\n",
    "m = (np.log(y2) - np.log(y1)) / (x2 - x1)  # Using log to convert to semilogy plot\n",
    "c = np.log(y1) - m * x1 + 3\n",
    "\n",
    "# Define x-values for the line\n",
    "x_values = n_s[:pt_2+2] #np.linspace(x1, x2, 100)\n",
    "\n",
    "# Calculate corresponding y-values using the equation of the line\n",
    "y_values = np.exp(m * x_values + c)  # Exponentiating to revert back from log scale\n",
    "\n",
    "fontsize = 12\n",
    "n_s = np.asarray(n_s)\n",
    "end_ind = len(n_s)\n",
    "\n",
    "fig, ax = plt.subplots(1, 1, figsize=(4, 4), sharey=True)\n",
    "ax = plt.gca()  # or any other way to get an axis object\n",
    "ax.semilogy(n_s[:end_ind], l2_rel_err_elm[:end_ind])\n",
    "ax.semilogy(n_s[:end_ind], l2_rel_err_swim[:end_ind], '--')\n",
    "ax.semilogy(x_values, y_values, ':', label='Spectral convergence')# * 50\n",
    "ax.legend([\"ELM\", \"SWIM\", \"Spectral convergence\"], frameon=False, loc='upper right', fontsize=fontsize)\n",
    "ax.set_xlabel('# Collocation points', fontsize=fontsize)\n",
    "ax.set_ylabel(r'Relative  ' + r'$\\mathbb{L}_{2}$ ' + r'error', fontsize=fontsize)\n",
    "plt.tick_params(axis='both', labelsize=fontsize)\n",
    "fig.tight_layout()\n",
    "plt.savefig('convergence_adv_1.pdf')\n",
    "\n",
    "# Spectral convergence line\n",
    "x1 = n_s[pt_1]/ratios[0]\n",
    "x2 = n_s[pt_2]/ratios[0]\n",
    "y1 = l2_rel_err_elm[pt_1]\n",
    "y2 = l2_rel_err_elm[pt_2]\n",
    "\n",
    "# Compute the slope and intercept of the line (y = mx + c)\n",
    "m = (np.log(y2) - np.log(y1)) / (x2 - x1)  # Using log to convert to semilogy plot\n",
    "c = np.log(y1) - m * x1 + 3\n",
    "\n",
    "# Define x-values for the line\n",
    "x_values = n_s[:pt_2+2]/ratios[0] #np.linspace(x1, x2, 100)\n",
    "\n",
    "# Calculate corresponding y-values using the equation of the line\n",
    "y_values = np.exp(m * x_values + c)  # Exponentiating to revert back from log scale\n",
    "\n",
    "widths = n_s[:end_ind]//ratios[0]\n",
    "\n",
    "# Plot convergence plots\n",
    "fig, ax = plt.subplots(1, 1, figsize=(4, 4), sharey=True)\n",
    "n_s = np.asarray(n_s)\n",
    "ax.semilogy(widths, l2_rel_err_elm[:end_ind])\n",
    "ax.semilogy(widths, l2_rel_err_swim[:end_ind])\n",
    "ax.semilogy(x_values, y_values, ':', label='Spectral convergence')\n",
    "ax.legend([\"ELM\", \"SWIM\", \"Spectral convergence\"], frameon=False, loc='upper right', fontsize=fontsize) \n",
    "ax.set_xlabel('Width of hidden layer', fontsize=fontsize)\n",
    "ax.set_ylabel(r'Relative  ' + r'$\\mathbb{L}_{2}$ ' + r'error', fontsize=fontsize)\n",
    "plt.tick_params(axis='both', labelsize=fontsize)\n",
    "fig.tight_layout()\n",
    "plt.savefig('convergence_adv_2.pdf')\n",
    "\n",
    "# Uncomment the following to store the arrays for plotting\n",
    "# with open('adv_rel_err_width.npy', 'wb') as f:\n",
    "#    np.save(f, np.vstack((widths, l2_rel_err_elm[:end_ind], l2_rel_err_swim[:end_ind])))\n",
    "\n",
    "# Store the arrays for plotting\n",
    "# with open('adv_rel_err_coll_points.npy', 'wb') as f:\n",
    "#     np.save(f, np.vstack((n_s[:end_ind], l2_rel_err_elm[:end_ind], l2_rel_err_swim[:end_ind])))"
   ]
  }
 ],
 "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
}
