{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Advection equation ($\\beta = 10$): Exponential error decay with the network width for Frozen-PINN-elm and Frozen-PINN-swim.  \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": 38,
   "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\n",
    "from utils import update_plot_style, extract_errors, compute_spectral_line, plot_convergence"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Problem setup"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "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": [
    "### Hyper-parameter study: Fit Frozen-PINN-swim and Frozen-PINN-Frozen-PINN-Frozen-PINN-elm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "n_s= 20 , n_b= 2 , reg_const= 1e-07\n",
      "scale_bc= 0.013115723927815756 , domain_boundary_percent= 0.02723042170206706\n",
      "time_elm= 0.17703488519513103 , time_swim= 0.009421308200772196\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.0102082888285319 , domain_boundary_percent= 0.011688629786173502\n",
      "time_elm= 0.2250167677352148 , time_swim= 0.009421308200772196\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.011480013529459635 , domain_boundary_percent= 0.009465694427490234\n",
      "time_elm= 0.07804336306572511 , time_swim= 0.009421308200772196\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.011904398600260416 , domain_boundary_percent= 0.012206951777140299\n",
      "time_elm= 0.07804336306572511 , time_swim= 0.009421308200772196\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.01183017094930013 , domain_boundary_percent= 0.013361851374308268\n",
      "time_elm= 0.07804336306572511 , time_swim= 0.009421308200772196\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.011543830235799154 , domain_boundary_percent= 0.013060887654622396\n",
      "time_elm= 0.07804336306572511 , time_swim= 0.009421308200772196\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.011098861694335938 , domain_boundary_percent= 0.012094338734944662\n",
      "time_elm= 0.0012946439543769308 , time_swim= 0.00026894311115699133\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.012783368428548178 , domain_boundary_percent= 0.010724385579427084\n",
      "time_elm= 0.0006750521543258623 , time_swim= 5.873199979572048e-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.010303497314453125 , domain_boundary_percent= 0.010823329289754232\n",
      "time_elm= 0.0005204928374481912 , time_swim= 1.5368225267567525e-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.19513682e-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.010891119639078775 , domain_boundary_percent= 0.010003964106241861\n",
      "time_elm= 0.0005585065366298464 , time_swim= 5.587788643340099e-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.19513682e-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.013493855794270834 , domain_boundary_percent= 0.012025276819864908\n",
      "time_elm= 0.000320944801976854 , time_swim= 6.731698863233652e-06\n",
      "rmse_swim= [1.60826583e-06 8.73774088e-06 9.84908988e-06] , rmse_elm= [2.94105364e-05 4.90744179e-04 4.42679691e-04]\n",
      "l2_rel_err_swim= [2.44273318e-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.013701597849527994 , domain_boundary_percent= 0.01263896624247233\n",
      "time_elm= 3.56845927523293e-05 , time_swim= 2.8405166230045617e-06\n",
      "rmse_swim= [6.74536089e-07 5.26098584e-07 7.32091520e-06] , rmse_elm= [2.94105364e-05 3.14221002e-05 4.62211417e-05]\n",
      "l2_rel_err_swim= [1.02318143e-06 7.62065829e-07 1.09508793e-05] , l2_rel_err_elm= [4.44375686e-05 4.40365401e-05 7.13003287e-05]\n",
      "n_s= 68 , n_b= 8 , reg_const= 1e-07\n",
      "scale_bc= 0.01200262705485026 , domain_boundary_percent= 0.01624433199564616\n",
      "time_elm= 4.343935141046286e-05 , time_swim= 0.00011169208272070088\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.01329819361368815 , domain_boundary_percent= 0.011966705322265625\n",
      "time_elm= 2.82114139268016e-05 , time_swim= 1.0951551152739447e-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.011432250340779623 , domain_boundary_percent= 0.012344757715861002\n",
      "time_elm= 1.3051329548412633e-06 , time_swim= 6.110427192185811e-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.55329583e-06 1.51156432e-05] , l2_rel_err_elm= [2.28733864e-06 7.60060647e-07 3.26245473e-06]\n",
      "n_s= 68 , n_b= 8 , reg_const= 1e-10\n",
      "scale_bc= 0.012820164362589518 , domain_boundary_percent= 0.010425726572672525\n",
      "time_elm= 8.5253926365026e-07 , time_swim= 4.190550623518253e-07\n",
      "rmse_swim= [1.96093128e-07 6.01860080e-07 4.59211979e-07] , rmse_elm= [5.16588972e-07 1.78035382e-07 1.86299344e-06]\n",
      "l2_rel_err_swim= [2.91615090e-07 8.35806312e-07 6.95678882e-07] , l2_rel_err_elm= [7.20675008e-07 2.41303097e-07 3.26245473e-06]\n",
      "n_s= 68 , n_b= 8 , reg_const= 1e-11\n",
      "scale_bc= 0.013244708379109701 , domain_boundary_percent= 0.01593645413716634\n",
      "time_elm= 2.316123777841538e-05 , time_swim= 3.393988388918619e-07\n",
      "rmse_swim= [1.71586368e-08 6.01860080e-07 3.99177800e-07] , rmse_elm= [1.24678052e-06 1.78035382e-07 6.80588974e-05]\n",
      "l2_rel_err_swim= [2.55855007e-08 8.35806312e-07 6.04698826e-07] , l2_rel_err_elm= [1.90825155e-06 2.41303097e-07 1.01707440e-04]\n",
      "n_s= 68 , n_b= 8 , reg_const= 1e-12\n",
      "scale_bc= 0.011232932408650717 , domain_boundary_percent= 0.010668039321899414\n",
      "time_elm= 1.2397555195395437e-05 , time_swim= 1.0379930337092887e-07\n",
      "rmse_swim= [1.68379003e-08 3.30687593e-08 2.61491251e-07] , rmse_elm= [7.45684316e-06 8.08921225e-07 2.89269012e-05]\n",
      "l2_rel_err_swim= [2.51828230e-08 4.79569406e-08 3.94907948e-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.012686411539713541 , domain_boundary_percent= 0.013329823811848959\n",
      "time_elm= 5.014759150434605e-05 , time_swim= 5.760344217928685e-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.35844400e-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.01383829116821289 , domain_boundary_percent= 0.014438549677530924\n",
      "time_elm= 1.0528206993212338e-05 , time_swim= 8.921727030141488e-06\n",
      "rmse_swim= [3.73864982e-06 2.01318558e-06 2.10133457e-05] , rmse_elm= [3.89404660e-07 4.24946322e-07 3.07702700e-05]\n",
      "l2_rel_err_swim= [5.47393889e-06 2.81242435e-06 3.08088519e-05] , l2_rel_err_elm= [5.71028031e-07 5.94552681e-07 4.32053785e-05]\n",
      "n_s= 93 , n_b= 11 , reg_const= 1e-09\n",
      "scale_bc= 0.012000004450480143 , domain_boundary_percent= 0.012642224629720053\n",
      "time_elm= 2.0012868097022387e-06 , time_swim= 1.9471939196750597e-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.011417865753173828 , domain_boundary_percent= 0.010660886764526367\n",
      "time_elm= 3.7564965683756177e-07 , time_swim= 2.771078822354811e-07\n",
      "rmse_swim= [8.35663539e-08 5.65909134e-08 6.91166379e-07] , rmse_elm= [2.36320182e-08 7.46101786e-08 1.02870677e-06]\n",
      "l2_rel_err_swim= [1.27085068e-07 8.04688303e-08 1.05524092e-06] , l2_rel_err_elm= [3.55820392e-08 1.05763701e-07 1.46617733e-06]\n",
      "n_s= 93 , n_b= 11 , reg_const= 1e-11\n",
      "scale_bc= 0.013237953186035156 , domain_boundary_percent= 0.011837402979532877\n",
      "time_elm= 8.048827355056648e-08 , time_swim= 1.6284102577847898e-07\n",
      "rmse_swim= [3.19310562e-09 3.72146974e-07 1.13182997e-07] , rmse_elm= [9.10304392e-08 4.36785244e-08 1.06755857e-07]\n",
      "l2_rel_err_swim= [4.83850890e-09 5.60345473e-07 1.70495225e-07] , l2_rel_err_elm= [1.40046682e-07 6.25803588e-08 1.64850753e-07]\n",
      "n_s= 93 , n_b= 11 , reg_const= 1e-12\n",
      "scale_bc= 0.012060880661010742 , domain_boundary_percent= 0.013636191685994467\n",
      "time_elm= 5.6601691043082296e-08 , time_swim= 1.6915026120589316e-08\n",
      "rmse_swim= [1.36208160e-08 6.75256325e-09 3.03716991e-08] , rmse_elm= [2.59344787e-08 4.36785244e-08 1.00192070e-07]\n",
      "l2_rel_err_swim= [2.03857324e-08 1.02984899e-08 4.63024783e-08] , l2_rel_err_elm= [3.72438912e-08 6.25803588e-08 1.45659432e-07]\n",
      "n_s= 117 , n_b= 14 , reg_const= 1e-07\n",
      "scale_bc= 0.15029486020406088 , domain_boundary_percent= 0.015167474746704102\n",
      "time_elm= 0.0002255928951957597 , time_swim= 3.7241669207978554e-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.013542493184407553 , domain_boundary_percent= 0.013154029846191406\n",
      "time_elm= 1.0599199115218669e-05 , time_swim= 1.107486918596496e-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.0176392396291097 , domain_boundary_percent= 0.025220155715942383\n",
      "time_elm= 3.192832449324188e-07 , time_swim= 9.660823971974287e-07\n",
      "rmse_swim= [1.21172850e-06 1.06053628e-06 6.25982412e-07] , rmse_elm= [2.31034231e-07 6.00502174e-08 6.66765287e-07]\n",
      "l2_rel_err_swim= [1.73804039e-06 1.50194327e-06 9.40616408e-07] , l2_rel_err_elm= [3.35359094e-07 9.12101610e-08 9.27388018e-07]\n",
      "n_s= 117 , n_b= 14 , reg_const= 1e-10\n",
      "scale_bc= 0.014398654301961264 , domain_boundary_percent= 0.016044457753499348\n",
      "time_elm= 2.0216002185896042e-07 , time_swim= 2.785427487533588e-07\n",
      "rmse_swim= [4.44485694e-07 1.48443698e-07 2.42698854e-07] , rmse_elm= [1.16334002e-07 5.55773070e-08 4.34568757e-07]\n",
      "l2_rel_err_swim= [6.19481556e-07 2.19629454e-07 3.51361526e-07] , l2_rel_err_elm= [1.68672847e-07 8.21007908e-08 6.42497430e-07]\n",
      "n_s= 117 , n_b= 14 , reg_const= 1e-11\n",
      "scale_bc= 0.012001991271972656 , domain_boundary_percent= 0.013789733250935873\n",
      "time_elm= 2.2322763655147025e-07 , time_swim= 2.8030336066852653e-08\n",
      "rmse_swim= [2.03591108e-08 1.86375625e-08 4.50943349e-08] , rmse_elm= [9.76634169e-08 1.18220366e-08 5.60197456e-07]\n",
      "l2_rel_err_swim= [2.91491714e-08 2.70508712e-08 6.66379362e-08] , l2_rel_err_elm= [1.40261264e-07 1.83974993e-08 8.36910045e-07]\n",
      "n_s= 117 , n_b= 14 , reg_const= 1e-12\n",
      "scale_bc= 0.012039264043172201 , domain_boundary_percent= 0.012867371241251627\n",
      "time_elm= 3.003710062264213e-08 , time_swim= 9.583365256302164e-09\n",
      "rmse_swim= [8.47887995e-09 1.01519110e-08 1.01193048e-08] , rmse_elm= [3.24055404e-08 6.47909199e-09 5.12266695e-08]\n",
      "l2_rel_err_swim= [1.26532962e-08 1.53145294e-08 1.42715968e-08] , l2_rel_err_elm= [4.82431829e-08 9.72001635e-09 8.18144094e-08]\n",
      "n_s= 142 , n_b= 17 , reg_const= 1e-07\n",
      "scale_bc= 0.012897332509358725 , domain_boundary_percent= 0.01623702049255371\n",
      "time_elm= 1.1173131473862628e-05 , time_swim= 1.4679666478080122e-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.011843045552571615 , domain_boundary_percent= 0.012132803599039713\n",
      "time_elm= 1.8722285976097959e-06 , time_swim= 6.491909223737387e-06\n",
      "rmse_swim= [1.45896659e-05 3.74249847e-06 1.14356327e-06] , rmse_elm= [2.18431476e-06 5.08581292e-07 2.92378974e-06]\n",
      "l2_rel_err_swim= [2.22359793e-05 5.32201852e-06 1.96087724e-06] , l2_rel_err_elm= [3.00349950e-06 7.11753148e-07 4.06213380e-06]\n",
      "n_s= 142 , n_b= 17 , reg_const= 1e-09\n",
      "scale_bc= 0.013170798619588217 , domain_boundary_percent= 0.012332995732625326\n",
      "time_elm= 2.8931834927645376e-07 , time_swim= 7.464484382637506e-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.012178421020507812 , domain_boundary_percent= 0.01233688990275065\n",
      "time_elm= 1.5811209331597423e-07 , time_swim= 2.3587357391155886e-07\n",
      "rmse_swim= [9.85636035e-08 2.17281377e-07 3.91775741e-07] , rmse_elm= [8.52696418e-09 8.14242286e-09 4.57666893e-07]\n",
      "l2_rel_err_swim= [1.44579275e-07 3.17084198e-07 5.73764071e-07] , l2_rel_err_elm= [1.18493877e-08 1.25336827e-08 6.94198990e-07]\n",
      "n_s= 142 , n_b= 17 , reg_const= 1e-11\n",
      "scale_bc= 0.013008753458658854 , domain_boundary_percent= 0.012173970540364584\n",
      "time_elm= 1.0651362982032521e-08 , time_swim= 1.4282269380318243e-08\n",
      "rmse_swim= [2.20752598e-08 3.25328371e-09 1.75182646e-08] , rmse_elm= [8.83332820e-09 2.03261858e-09 2.10881422e-08]\n",
      "l2_rel_err_swim= [3.37275267e-08 4.84741565e-09 2.43440062e-08] , l2_rel_err_elm= [1.24877792e-08 3.31764383e-09 3.16365112e-08]\n",
      "n_s= 142 , n_b= 17 , reg_const= 1e-12\n",
      "scale_bc= 0.013161182403564453 , domain_boundary_percent= 0.01183787981669108\n",
      "time_elm= 1.412000665373594e-08 , time_swim= 5.289719461160062e-09\n",
      "rmse_swim= [1.10041284e-08 2.06446349e-09 2.80056650e-09] , rmse_elm= [1.04216840e-08 2.62534083e-09 2.93129951e-08]\n",
      "l2_rel_err_swim= [1.68044188e-08 3.02442408e-09 4.01503223e-09] , l2_rel_err_elm= [1.55432115e-08 4.01525520e-09 4.48543704e-08]\n",
      "n_s= 166 , n_b= 20 , reg_const= 1e-07\n",
      "scale_bc= 0.014688650767008463 , domain_boundary_percent= 0.015142679214477539\n",
      "time_elm= 4.185287327176037e-06 , time_swim= 2.3717661330845406e-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.013607978820800781 , domain_boundary_percent= 0.014331897099812826\n",
      "time_elm= 1.1317546274277075e-06 , time_swim= 1.8541721337938475e-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.35741697e-07 1.69649731e-06 2.82470342e-06]\n",
      "n_s= 166 , n_b= 20 , reg_const= 1e-09\n",
      "scale_bc= 0.013767004013061523 , domain_boundary_percent= 0.013871908187866211\n",
      "time_elm= 2.549975880556417e-07 , time_swim= 7.440307877916195e-07\n",
      "rmse_swim= [1.35925623e-06 6.13813292e-07 2.59022840e-07] , rmse_elm= [1.48857190e-07 5.60107532e-07 5.60280416e-08]\n",
      "l2_rel_err_swim= [1.86877319e-06 9.23546603e-07 3.91789102e-07] , l2_rel_err_elm= [2.20449183e-07 8.07840185e-07 8.18802005e-08]\n",
      "n_s= 166 , n_b= 20 , reg_const= 1e-10\n",
      "scale_bc= 0.013051907221476236 , domain_boundary_percent= 0.013738234837849935\n",
      "time_elm= 1.2527730400884729e-08 , time_swim= 1.1340306856827292e-07\n",
      "rmse_swim= [2.29056555e-08 2.09440202e-07 1.07863348e-07] , rmse_elm= [1.19614009e-08 1.98035340e-08 5.81825626e-09]\n",
      "l2_rel_err_swim= [3.12885522e-08 2.95479713e-07 1.58913446e-07] , l2_rel_err_elm= [1.65568880e-08 2.82960219e-08 8.91129051e-09]\n",
      "n_s= 166 , n_b= 20 , reg_const= 1e-11\n",
      "scale_bc= 0.014600515365600586 , domain_boundary_percent= 0.012755552927652994\n",
      "time_elm= 1.1634941733863387e-08 , time_swim= 8.154916228940943e-09\n",
      "rmse_swim= [1.42129342e-08 7.10323915e-09 3.14857535e-09] , rmse_elm= [7.35943445e-09 2.35543506e-08 3.99104014e-09]\n",
      "l2_rel_err_swim= [2.02430489e-08 1.02403053e-08 4.74250347e-09] , l2_rel_err_elm= [1.09890175e-08 3.36410392e-08 5.74736243e-09]\n",
      "n_s= 166 , n_b= 20 , reg_const= 1e-12\n",
      "scale_bc= 0.0136259396870931 , domain_boundary_percent= 0.01527698834737142\n",
      "time_elm= 1.2065158258585705e-08 , time_swim= 3.408683177350307e-09\n",
      "rmse_swim= [2.04249929e-09 5.53971620e-09 2.64383404e-09] , rmse_elm= [1.15050550e-08 2.31045092e-08 1.58591057e-09]\n",
      "l2_rel_err_swim= [2.76786430e-09 8.01068000e-09 3.89869296e-09] , l2_rel_err_elm= [1.58224359e-08 3.31809449e-08 2.24007432e-09]\n",
      "n_s= 191 , n_b= 23 , reg_const= 1e-07\n",
      "scale_bc= 0.03036983807881673 , domain_boundary_percent= 0.022697289784749348\n",
      "time_elm= 1.7485518211598845e-05 , time_swim= 1.0033647686137777e-05\n",
      "rmse_swim= [5.26194949e-06 6.45830066e-06 1.83806929e-05] , rmse_elm= [2.14978042e-06 3.35733511e-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.014356772104899088 , domain_boundary_percent= 0.013906319936116537\n",
      "time_elm= 4.363117652240916e-07 , time_swim= 3.5856840616318416e-06\n",
      "rmse_swim= [4.54086458e-06 5.26662824e-06 9.49559371e-07] , rmse_elm= [8.80031868e-07 2.22581233e-07 2.06322195e-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.98546232e-07]\n",
      "n_s= 191 , n_b= 23 , reg_const= 1e-09\n",
      "scale_bc= 0.016213178634643555 , domain_boundary_percent= 0.01565408706665039\n",
      "time_elm= 6.571722988638314e-08 , time_swim= 4.936315102463431e-07\n",
      "rmse_swim= [3.43278706e-08 1.04031925e-06 4.06247414e-07] , rmse_elm= [9.35136655e-08 2.51782654e-08 7.84597587e-08]\n",
      "l2_rel_err_swim= [5.12304669e-08 1.45372331e-06 6.09239079e-07] , l2_rel_err_elm= [1.46740588e-07 3.47606646e-08 1.15523031e-07]\n",
      "n_s= 191 , n_b= 23 , reg_const= 1e-10\n",
      "scale_bc= 0.015327850977579752 , domain_boundary_percent= 0.014579375584920248\n",
      "time_elm= 3.850573461084955e-08 , time_swim= 8.540444693388696e-08\n",
      "rmse_swim= [4.11798876e-08 1.00249129e-07 1.14784324e-07] , rmse_elm= [1.01508362e-07 3.05241940e-09 1.09564227e-08]\n",
      "l2_rel_err_swim= [6.25202129e-08 1.52779843e-07 1.58359200e-07] , l2_rel_err_elm= [1.56330594e-07 4.81766391e-09 1.65241627e-08]\n",
      "n_s= 191 , n_b= 23 , reg_const= 1e-11\n",
      "scale_bc= 0.014824787775675455 , domain_boundary_percent= 0.012381235758463541\n",
      "time_elm= 8.820570150320969e-09 , time_swim= 1.007664936672305e-08\n",
      "rmse_swim= [1.59713439e-08 1.20554666e-08 2.20313762e-09] , rmse_elm= [1.68494784e-08 6.46777288e-09 3.14445917e-09]\n",
      "l2_rel_err_swim= [2.31557890e-08 1.81515744e-08 3.28818510e-09] , l2_rel_err_elm= [2.55976128e-08 9.08226473e-09 4.40568817e-09]\n",
      "n_s= 191 , n_b= 23 , reg_const= 1e-12\n",
      "scale_bc= 0.013018608093261719 , domain_boundary_percent= 0.015133301417032877\n",
      "time_elm= 5.395706475507049e-09 , time_swim= 5.984930040025419e-09\n",
      "rmse_swim= [3.35020458e-09 1.20339394e-08 2.57064618e-09] , rmse_elm= [6.91791368e-09 4.40200102e-09 4.86720473e-09]\n",
      "l2_rel_err_swim= [4.97682598e-09 1.81170321e-08 3.85288052e-09] , l2_rel_err_elm= [9.88486371e-09 6.44337995e-09 6.73427832e-09]\n",
      "n_s= 215 , n_b= 26 , reg_const= 1e-07\n",
      "scale_bc= 0.08701435724894206 , domain_boundary_percent= 0.020841042200724285\n",
      "time_elm= 1.523322880420901e+36 , time_swim= 7.416092273497465e-06\n",
      "rmse_swim= [1.00041507e-05 9.82055266e-06 2.42357345e-06] , rmse_elm= [2.10472431e+04 4.27969678e+12 4.56996864e+36]\n",
      "l2_rel_err_swim= [1.49242282e-05 1.37896473e-05 3.58407243e-06] , l2_rel_err_elm= [3.58856148e+04 6.27092703e+12 8.88326490e+36]\n",
      "n_s= 215 , n_b= 26 , reg_const= 1e-08\n",
      "scale_bc= 0.06301768620808919 , domain_boundary_percent= 0.018866300582885742\n",
      "time_elm= 0.11086342150140815 , time_swim= 2.186476929033715e-06\n",
      "rmse_swim= [2.90778302e-06 1.27631083e-06 2.37533693e-06] , rmse_elm= [2.61277851e-07 3.83029389e-04 3.32206974e-01]\n",
      "l2_rel_err_swim= [4.37043238e-06 1.94237549e-06 3.56571632e-06] , l2_rel_err_elm= [2.77303384e-07 5.68418013e-04 4.68552808e-01]\n",
      "n_s= 215 , n_b= 26 , reg_const= 1e-09\n",
      "scale_bc= 0.017675161361694336 , domain_boundary_percent= 0.018118937810262043\n",
      "time_elm= 6.438849353472284e-07 , time_swim= 6.390903873622509e-07\n",
      "rmse_swim= [1.17826460e-06 2.89949243e-07 4.49057320e-07] , rmse_elm= [2.91256800e-07 7.36004452e-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.017334858576456707 , domain_boundary_percent= 0.021050294240315754\n",
      "time_elm= 2.6510301195426856e-08 , time_swim= 2.9613546176452574e-08\n",
      "rmse_swim= [1.97038276e-08 3.60012372e-08 3.31355737e-08] , rmse_elm= [2.21906516e-08 1.34299791e-08 4.39102729e-08]\n",
      "l2_rel_err_swim= [2.65964564e-08 5.45904322e-08 4.98980543e-08] , l2_rel_err_elm= [3.20833367e-08 1.95909845e-08 6.32136341e-08]\n",
      "n_s= 215 , n_b= 26 , reg_const= 1e-11\n",
      "scale_bc= 0.015335003534952799 , domain_boundary_percent= 0.016168594360351562\n",
      "time_elm= 5.505752772344335e-09 , time_swim= 1.4510810772195855e-08\n",
      "rmse_swim= [1.41542058e-08 4.06842859e-09 2.53097980e-08] , rmse_elm= [8.54545842e-09 3.14682860e-09 4.82497130e-09]\n",
      "l2_rel_err_swim= [1.96170183e-08 5.77480973e-09 3.84908113e-08] , l2_rel_err_elm= [1.27467233e-08 4.41847457e-09 7.29308827e-09]\n",
      "n_s= 215 , n_b= 26 , reg_const= 1e-12\n",
      "scale_bc= 0.01783863703409831 , domain_boundary_percent= 0.016834259033203125\n",
      "time_elm= 5.524580034130038e-09 , time_swim= 1.3480637229562908e-09\n",
      "rmse_swim= [2.70651395e-09 1.02730812e-09 3.10369097e-10] , rmse_elm= [8.89299305e-09 4.06906411e-09 3.61168294e-09]\n",
      "l2_rel_err_swim= [3.75505400e-09 1.50867046e-09 4.43385859e-10] , l2_rel_err_elm= [1.23658181e-08 5.78274099e-09 5.58279002e-09]\n",
      "n_s= 240 , n_b= 30 , reg_const= 1e-07\n",
      "scale_bc= 0.0689390500386556 , domain_boundary_percent= 0.024917761484781902\n",
      "time_elm= 566615675376909.6 , time_swim= 4.517909179825831e-06\n",
      "rmse_swim= [6.84276498e-06 2.34510626e-06 4.36585630e-06] , rmse_elm= [1.12182122e+05 2.03893809e+02 1.69984703e+15]\n",
      "l2_rel_err_swim= [1.02050859e-05 3.29359385e-06 5.92394951e-06] , l2_rel_err_elm= [1.67363594e+05 3.14807589e+02 3.23162343e+15]\n",
      "n_s= 240 , n_b= 30 , reg_const= 1e-08\n",
      "scale_bc= 0.09967605272928874 , domain_boundary_percent= 0.019995768864949543\n",
      "time_elm= 3.4364272468451907e+45 , time_swim= 3.977722067341054e-06\n",
      "rmse_swim= [4.61713498e-06 3.12261409e-06 4.19341713e-06] , rmse_elm= [1.50962994e+13 3.28076460e+39 1.03092785e+46]\n",
      "l2_rel_err_swim= [6.81385743e-06 4.21803435e-06 5.71481315e-06] , l2_rel_err_elm= [2.93445883e+13 6.37726499e+39 2.00395361e+46]\n",
      "n_s= 240 , n_b= 30 , reg_const= 1e-09\n",
      "scale_bc= 0.043564160664876304 , domain_boundary_percent= 0.020334164301554363\n",
      "time_elm= 0.00015366462461696405 , time_swim= 3.986060287108838e-07\n",
      "rmse_swim= [4.05247003e-07 4.75452965e-08 7.43025787e-07] , rmse_elm= [4.56854796e-04 3.59029283e-06 5.48785042e-07]\n",
      "l2_rel_err_swim= [5.74410345e-07 5.45168179e-08 1.13107857e-06] , l2_rel_err_elm= [6.86474612e-04 5.32421196e-06 7.42307453e-07]\n",
      "n_s= 240 , n_b= 30 , reg_const= 1e-10\n",
      "scale_bc= 0.024022817611694336 , domain_boundary_percent= 0.018996795018513996\n",
      "time_elm= 5.209938138157064e-08 , time_swim= 4.993403893796562e-08\n",
      "rmse_swim= [5.93636264e-08 3.94111196e-08 5.10273708e-08] , rmse_elm= [1.22316019e-07 2.08118006e-08 1.31703243e-08]\n",
      "l2_rel_err_swim= [6.24884476e-08 4.55532267e-08 5.79979970e-08] , l2_rel_err_elm= [1.31223819e-07 2.70794244e-08 1.38584988e-08]\n",
      "n_s= 240 , n_b= 30 , reg_const= 1e-11\n",
      "scale_bc= 0.018010377883911133 , domain_boundary_percent= 0.017995675404866535\n",
      "time_elm= 6.683708866755816e-09 , time_swim= 3.074000897634756e-08\n",
      "rmse_swim= [3.75709575e-08 3.12559993e-08 2.33930701e-08] , rmse_elm= [7.76551296e-09 7.69226445e-09 4.59334919e-09]\n",
      "l2_rel_err_swim= [5.21430945e-08 4.21834474e-08 3.29700649e-08] , l2_rel_err_elm= [8.68425117e-09 1.08063755e-08 6.68412799e-09]\n",
      "n_s= 240 , n_b= 30 , reg_const= 1e-12\n",
      "scale_bc= 0.01900513966878255 , domain_boundary_percent= 0.018004179000854492\n",
      "time_elm= 1.569758934161007e-08 , time_swim= 1.3501443855555482e-08\n",
      "rmse_swim= [2.34414136e-08 1.09107849e-08 6.15213305e-09] , rmse_elm= [1.91175803e-08 2.28358615e-08 5.13932618e-09]\n",
      "l2_rel_err_swim= [3.41256937e-08 1.65340221e-08 9.03256399e-09] , l2_rel_err_elm= [3.10182818e-08 3.14535007e-08 7.09578310e-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",
    "\n",
    "                # Print info\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",
    "                \n",
    "                # Store info\n",
    "                experiments.append(info) \n",
    "                \n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Convergence plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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NDDYT8OGDfVuX+Tatm0bYWFhTJgwQa91zqVLl4D79/kf9nCHIysrK1xdXfWWVa9enYSEBN3zuLg4vToHOzs77OzsdM9ffPFFBgwYgFKpxNHRkSZNmhS5Enbo0KHMmDFD90FfkMIkk1u3buk9d3BwwNramunTp9O7d2/8/Pzw9/cnNDSU5557jqZNm+rKBgcH89VXX3H58mWuXLmCQqGgbdu2BAcHs3fvXsaMGcPevXsJCgoqVMMBLy8vg1gAg+l6HRwc9F57KX8yMVRidhZ2+gsm3sy/sEKl//ydy48o+9A/67gzhS9byh68WiiOiIgIhg4dSteuXZk5c6beOo1Ge+W1atUqatasabCtmZn+v5NKpTIo87DWrVvrzT44depUpk2bpntev359unTpUpRTMJD7QT9y5EjdN/WCFJRM3N3d9Z4vX76ckSNH0qFDB65cucLGjRv5448/+Pbbb/n000/56quveOEF7Vzl7du3B2DPnj1cvXqVli1bYmtrS3BwMJ9//jkpKSmcOHGCDz/8sNDnV9jlQlY+F4pMDFXEvuh9rA9fz7yO8zBTFuJtt7At/M6LUraMeXt7A9o28A9/07948aJuPUB6ejr9+vXD0dGRH374weDbar169QBwc3Mr8Yd1rjVr1pCenq57XrduXaPs92HDhg1j5syZugraghSUTHJbGeVq0uT+XOROTk6MGjWKUaNGkZKSQocOHZg2bZouMXh5eeHl5cXevXu5evUqwcHBAHTo0IG33nqLtWvXolarC1XxLJUOmRiqgHtZ93h3z7vcy7rHuvB1DGo4yNQhlZlWrVrh5ubGV199xfPPP6+7DbN161bOnz/PlClTdGVffvllwsPDOXjwINWrVzfYV0hICPb29syaNYtOnTphbm6utz4uLs7g1lFBgoKCinFWRffgB31hPZhMHpZfYrxz545eiyk7Ozt8fX25ceOGXrng4GD++usvYmNjeeuttwBtv4tq1aoxZ84crK2tCQgIKHSsknHJxFAFVLOoxjut3uFS4iV61Sv422JlYm5uzty5cxk1ahQdO3Zk8ODB3L59mwULFuDj48Obb74JwJYtW/juu+945plnOH36tF47ezs7O/r06YO9vT2LFy/mueeeo2XLlgwaNAhXV1euX7/Oli1bCAoKYtGiRaY61QLl3h56eEiN/KhUKiZNmsSoUaMKfYzG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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYYAAAGGCAYAAAB/gCblAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAACC6klEQVR4nO3dd1xV9f/A8de9lw0CIqCILBXce5ACrtzmzJnmyBz9yjK/lrlnmZlNzdFAU0tz5crUHIXmyr1FBQeiAgqI7Hs/vz+uXL1ekHGBy/g8H4/7sHvO557zPjc973s+UyGEEEiSJEnSE0pTByBJkiQVLTIxSJIkSXpkYpAkSZL0yMQgSZIk6ZGJQZIkSdIjE4MkSZKkRyYGSZIkSY9MDJIkSZIeM1MHUBJpNBru3LlDmTJlUCgUpg5HkiQJIQSPHj2iYsWKKJUvfiaQiaEA3LlzBw8PD1OHIUmSZODWrVtUqlTphWVkYigAZcqUAbT/A+zt7U0cjSRJEsTHx+Ph4aG7P72ITAwFIKP6yN7eXiYGSZKKlJxUb8vGZ0mSJEmPTAySJEmSHpkYJEmSJD0yMUiSJEl6ZGKQJEmS9MjEIEmSJOmRiUGSJEnSIxODJEmSpEcmBkmSJEmPTAySJEmSHpkYijghBBqhMXUYkiSVIjIxFGF3Eu4wavcoVl9cbepQJEkqRWRiKML+vfMvhyIPsfTMUhLTEk0djiQVGQqFghkzZpg6jBJLJoYi7FXfVxlaayirOq3CxtzG1OEUa8uXL0ehUGT6+uijj0wdXr4KDw/Xuz6VSoWnpyc9e/bk1KlTemUVCgXvvPNOpp/dsGGDwbFnzJiBQqEgOjpat23o0KEoFArq1q2LEMLgM8+fQyr65LTbmYiKimLo0KHs37+fSpUq8d133/Hyyy8XehwKhYL/Nf5foZ+3JJs1axY+Pj5622rXrm2iaArWgAED6Ny5M2q1mosXL7J48WJ27NjB4cOHqV+/frafnzVrFr169crxKoRnz55l48aNvPrqq0ZGLpmaTAyZePvtt6lQoQJRUVH89ddf9O3bl9DQUJycnEwa1634WygUCiqVefHqS1LWOnXqROPGjbMtl5ycjIWFRbZLIBZlDRs2ZNCgQbr3AQEBdOvWjcWLF7N06dIXfrZ+/fqcOnWKTZs20atXr2zPZW1tjYeHR66TiVQ0Fd+/9QUkISGB33//nZkzZ2JjY0O3bt2oU6cOmzdvNmlce27uodeWXkw+MFn2Uspn+/fvR6FQsGbNGqZMmYK7uzs2NjbEx8cDsG7dOho1aoS1tTXOzs4MGjSIiIgIg89n9vL29tY7144dOwgKCsLW1pYyZcrQpUsXzp8/r1dm6NCh2NnZERERQY8ePbCzs8PFxYXx48ejVqvzfJ1t2rQBICwsLNuy/fv3x8/Pj1mzZmVaPfQ8pVLJlClTOHPmDJs2bcpzjLGxsYwdOxYPDw8sLS2pWrUq8+bNQ6N58d/5jCquK1euMGjQIBwcHHBxcWHq1KkIIbh16xbdu3fH3t6eChUqsGDBgjzHWBoU+8SQkJDA9OnT6dixI05OTigUCpYvX55p2ZSUFCZMmEDFihWxtrbG39+f3bt365UJDQ3Fzs5Ob03UOnXqGPzjLWzVnaqjUCgwU5rxKPWRSWMpzuLi4oiOjtZ7ZZg9ezbbt29n/PjxfPLJJ1hYWLB8+XL69u2LSqVi7ty5jBgxgo0bNxIYGEhsbCwANWrUYOXKlXqvb7/9FnNzc1xdXXXHX7lyJV26dMHOzo558+YxdepULly4QGBgIOHh4XpxqtVqOnToQLly5fj8889p2bIlCxYsYNmyZXm+9mvXrgFQrly5bMuqVCqmTJnC6dOnc3yjf+211/D19c1xMnleYmIiLVu2ZNWqVQwePJhvvvmGgIAAJk6cyLhx43J0jH79+qHRaPj000/x9/dnzpw5fPXVV7Rr1w53d3fmzZtH1apVGT9+PP/880+uYyw1RDEXFhYmAOHp6SlatWolABEcHJxp2f79+wszMzMxfvx4sXTpUtGsWTNhZmYmQkJCdGX++ecf4eXlpfe5SZMmiVGjRuU4pri4OAGIuLi4vFxSlkIfhAq1Rp2vx3wRjUYjHqekFamXRqPJ07UEBwcLINPXvn37BCAqV64sEhMTdZ9JTU0Vrq6uonbt2iIpKUm3fdu2bQIQ06ZNy/J7e+WVV4SdnZ04f/68EEKIR48eCUdHRzFixAi9snfv3hUODg5624cMGSIAMWvWLL2yDRo0EI0aNcr2WjP+TcycOVNERUWJu3fviv3794sGDRoIQGzYsEFXFhBvv/22wWfnz58v0tPTha+vr6hXr57ue58+fboARFRUlF68tra2QgghVqxYIQCxcePGLM+RldmzZwtbW1tx5coVve0fffSRUKlU4ubNm3rHnD59uu59RlwjR47UbUtPTxeVKlUSCoVCfPrpp7rtDx8+FNbW1mLIkCHZxlSS5Oa+VOzbGNzc3IiMjKRChQr8999/NGnSJNNyR48eZc2aNcyfP5/x48cDMHjwYGrXrs2HH37Iv//+C4CdnZ2uCiFDfHw8dnZ2BXshOVC1bNVCPV9Smpqa03YW6jmzc2FWB2ws8v7XdtGiRfj5+WW6b8iQIVhbW+ve//fff9y/f58ZM2ZgZWWl296lSxeqV6/O9u3bmTlzpsFxZs+ezbZt21i/fj01a9YEYPfu3cTGxjJgwAC9pxSVSoW/vz/79u0zOM7o0aP13gcFBbFy5cocX+v06dOZPn267r29vT3z5s3LUZtBRmxTpkxhyJAh/P777/Ts2TPbzwwcOJA5c+Ywa9YsevTokau2hnXr1hEUFETZsmX1vqO2bdvy6aef8s8//zBw4MAXHuPNN9/Ui79x48bcvn2b4cOH67Y7OjpSrVo1rl+/nuPYSptinxgsLS2pUKFCtuXWr1+PSqVi5MiRum1WVlYMHz6cSZMmcevWLTw8PPD19SUhIYGIiAjc3d0BOHfuHIMHDy6wa8gttUbNzxd+xtbclr7V+po6nGKladOmBo3P+/fvBzDorXTjxg0AqlWrZnCc6tWrc+DAAYPtf/75JzNnzmTixIl6vXNCQ0OBp/X8z7O3t9d7b2VlhYuLi962smXL8vDhQ937qKgovTYHOzs7vR8wI0eOpE+fPiiVShwdHalVqxaWlpaZnj8rAwcOZPbs2bobfXZykkzu3r2r997BwQFra2tCQ0M5c+aMwXVnuH//frbn9/T0NDi2lZUVzs7OBttjYmKyPV5pVewTQ06dPHkSPz8/g3+ATZs2BeDUqVN4eHhgZ2dH9+7dmT59Ot9++y179uzhzJkzdO/e3RRhZ2rXjV18cfwLrM2saVGpBRVss0+MeWFtruLCrA4Fcuy8sjZXFdyxn3layIuwsDAGDhxIu3btmDNnjt6+jMbTlStXZvpDxsxM/5+iSpX9dTZp0kSXvED7hPDsoC9fX1/atm2bm0swkHGjHzp0aI47YGSXTNzc3PTeBwcHM3ToUDQaDe3atePDDz/M9LhZPek9H29OtgF5agcpLUpNYoiMjDT4CwlP/5LeuXNHt+27775jyJAhlCtXjkqVKrF27doXdlVNSUkhJSVF9/75qqj81sG7A3+G/Ukrj1aUtylfYOdRKBRGVdsUd15eXgBcvnzZ4Jf+5cuXdfsBkpKS6NWrF46Ojvz6668G3VyrVKkCgKurq9E36wyrV68mKSlJ975y5cr5ctznDRo0iDlz5jBz5ky6deuWbfnsksnzHT5q1aoFaL+jhISEfPt+pLwrNf/qk5KSMn2Mzqg7fvYfmIuLC3/88UeOjz137txM65oLilKh5Os2Xxfa+Uqrxo0b4+rqypIlS3jjjTd0f3927NjBxYsXmTZtmq7s6NGjuXLlCocOHaJs2bIGx+rQoQP29vZ88skntG7dGnNzc739UVFRWVahZCUgICAPV5V7z97oc+rZZPK8rG78ffv2ZcaMGezcuZMOHfSfVGNjY7GzszN4spIKRqn5lq2trfV+1WdITk7W7c+r57vTxcfH4+Hhkefj5VaaJo2E1ATKWhnekKS8Mzc3Z968eQwbNoyWLVsyYMAA7t27x9dff423tzfvv/8+ANu3b+fnn3/m1Vdf5cyZM5w5c0Z3DDs7O3r06IG9vT2LFy/m9ddfp2HDhvTv3x8XFxdu3rzJ9u3bCQgIYOHChaa61GxlVA89P6VGVlQqFZMnT2bYsGE5PscHH3zAli1beOWVVxg6dCiNGjXi8ePHnD17lvXr1xMeHm7QViAVjFKTGNzc3PQGJWWIjIwEoGLFink+tqWlZa4b9fLL9djrfBTyEXYWdvzQ/geUimI/NKVIGTp0KDY2Nnz66adMmDABW1tbevbsybx583B0dAS0v/YBNmzYYDC/kJeXl66e/bXXXqNixYp8+umnzJ8/n5SUFNzd3QkKCsrVDdQUzMzMmDJlSq7izHhqyBg/kR0bGxv+/vtvPvnkE9atW8fPP/+Mvb09fn5+zJw5EwcHh7yGL+VWwfeeLTzHjh3LchzD+PHjhUqlMujD+/HHHwtAr4+0sQpqHENmbsbdFE1WNREBvwaI8LjwAj+fJEnFU27uS6Xm52Xv3r1Rq9V6I0dTUlIIDg7G39+/UKt+8pOHvQeft/yc37v/jpe9V/YfkCRJykaJqEpauHAhsbGxup5FW7du5fbt2wCMGTMGBwcH/P396dOnDxMnTuT+/ftUrVqVFStWEB4ezo8//mjK8I3WolILU4cgSVIJohCi+Hfm9fb21uvP/aywsDDdRGbJyclMnTqVVatW8fDhQ+rWrcvs2bMNekAYKz4+HgcHB+Li4gzGTRS089HnuZ1wmw7eRWv8gSRJppWb+1KJSAxFjakSw6n7pxj651AsVZZs7L4Rdzv3Qju3JElFW27uSyWiKknSqutSl3ou9ShvUx4bM7nimyRJeSMTQwmiVChZ0m4J1mbGTe0gSVLpVmp6JZUWzyeFdE26iSKRJKm4komhhEpKT+KzY5/x9p635WRhkiTlikwMJVRUYhS/Xf6Nf+/8y7G7x0wdjiRJxYhsYyihPO09mew/mXLW5Wjq1tTU4UiSVIzIxFCC9fTNfsUtSZKk58mqpFIiMS2RE/dOmDoMSTIJb2/vXE0bXtrJxFAK3Em4Q68tvfi/Pf9HZEKkqcMxieXLl6NQKDJ9ffTRR6YOL1+Fh4frXZ9KpcLT05OePXsaTJutUCh45513Mv3s8zPFAsyYMQOFQqG3JvPQoUNRKBTUrVs3044Oz59DKvpkVVIpUN6mPM7WzgghiEmOwc3OcCW70mLWrFkGazvXrl3bRNEUrAEDBtC5c2fUajUXL15k8eLF7Nixg8OHD1O/fv1sPz9r1ix69eqFQqHI0fnOnj3Lxo0b9da6LiouX75ssKqelDWZGEoBlVLF5y0/p4xFGWzNbU0djkl16tSJxo0bZ1suOTkZCwuLYn0zadiwIYMGDdK9DwgIoFu3bixevJilS5e+8LP169fn1KlTbNq0iV69emV7Lmtrazw8PHKdTAqLqdZLKa6K7996KVcq2FYo9UkhK/v370ehULBmzRqmTJmCu7s7NjY2urW7161bR6NGjbC2tsbZ2ZlBgwbpLfqU8fnMXhkTOGbYsWMHQUFB2NraUqZMGbp06cL58+f1ygwdOhQ7OzsiIiLo0aMHdnZ2uLi4MH78eNRqdZ6vM2Pd6rCwsGzL9u/fHz8/P2bNmpWjcTBKpZIpU6Zw5swZNm3alKf40tLSmDlzJr6+vlhZWVGuXDkCAwN1a0Rv2bIFhUKht0Lehg0bUCgUBsmrRo0a9OvXT/f++TaGjKrFAwcO8O677+Li4oKjoyOjRo0iNTWV2NhYBg8eTNmyZSlbtiwffvhhqRoPJBNDKRRyO4SpB6eWqr/oGeLi4oiOjtZ7ZZg9ezbbt29n/PjxfPLJJ1hYWLB8+XL69u2LSqVi7ty5jBgxgo0bNxIYGEhsbCygvQmtXLlS7/Xtt99ibm6Oq6ur7vgrV66kS5cu2NnZMW/ePKZOncqFCxcIDAwkPDxcL061Wk2HDh0oV64cn3/+OS1btmTBggV664nkVsZKauXKlcu2bMY6z6dPn87xjf61117D19c3x8nkeTNmzGDmzJm0bt2ahQsXMnnyZDw9PTlxQttpIjAwEIVCwT///KP7TEhICEqlkgMHDui2RUVFcenSJVq0yH46+jFjxhAaGsrMmTPp1q0by5YtY+rUqXTt2hW1Ws0nn3xCYGAg8+fPZ+XKlbm+pmKroFYLKs0KcwW33IpKjBKNVjYStZfXFtuubcvZh1ISsn6lJuWibKIRZR/n/aKFEMHBwQLI9LVv3z4BiMqVK4vExKfnTU1NFa6urqJ27doiKenpdW7btk0AYtq0aZmeS6PRiFdeeUXY2dmJ8+fPCyGEePTokXB0dBQjRozQK3v37l3h4OCgt33IkCECELNmzdIr26BBA9GoUaNsrzUsLEwAYubMmSIqKkrcvXtX7N+/XzRo0EAAYsOGDbqygHj77bcNPjt//nyRnp4ufH19Rb169YRGoxFCCDF9+nQBiKioKL14bW1thRBCrFixQgBi48aNWZ4jK/Xq1RNdunR5YZlatWqJvn376t43bNhQ9OnTRwDi4sWLQgghNm7cKABx+vRpXTkvLy8xZMgQ3fuMvw8dOnTQXZsQQjRr1kwoFAoxevRo3bb09HRRqVIl0bJly2yvoSjLzX1JtjGUMs7WzoxpMIZ7ifdo49kmZx/65AXrYfu2h4Hrnr6fXxXSEjMv6xUIw7Y/ff9VHUiMybxsxQYwcv/T94v84f2zOYv3BRYtWoSfn1+m+4YMGYK19dO5pv777z/u37/PjBkzsLKy0m3v0qUL1atXZ/v27cycOdPgOLNnz2bbtm2sX7+emjVrArB7925iY2MZMGCA3lOKSqXC39+fffv2GRxn9OjReu+DgoJy9at1+vTpTJ8+Xffe3t6eefPm5ajNICO2KVOmMGTIEH7//Xd69sx+XMzAgQOZM2cOs2bNokePHrlqa3B0dOT8+fOEhobi6+ubaZmgoCA2b94MwKNHjzh9+jTz5s1j3759hISEUL16dUJCQnB0dMxRp4Lhw4frxejv78+hQ4cYPny4bptKpaJx48YcP348x9dS3MnEUAoNqTXE1CGYTNOmTQ0an/fv3w9g0FspY/GnatWqGRynevXqetUXGf78809mzpzJxIkT9XrnhIaGAk/r+Z/3/Pz4VlZWuLi46G0rW7YsDx8+1L2PiorSa3Ows7PDzs5O937kyJH06dMHpVKJo6MjtWrVynUj7MCBA5k9e7buRp+dnCSTu3fv6r13cHDA2tqaWbNm0b17d/z8/KhduzYdO3bk9ddfp27durqyQUFBLFmyhKtXr3Lt2jUUCgXNmjUjKCiIkJAQRowYQUhICAEBATnqOODp6WkQC2Cw1K+Dg4Ped1/SycQgcffxXSrYVsi6wKQ7We9TqPTff3D1BWWf+4c69gVPAM+XfftI1mXzybNPC3kRFhbGwIEDadeuHXPmzNHbp9FoAG07Q4UKht+1mZn+P0WVSmVQ5nlNmjTRW7lw+vTpzJgxQ/fe19eXtm3b5uYSDGTc6IcOHar7pZ6d7JKJm5t+d+ng4GCGDh1KixYtuHbtGps3b2bXrl388MMPfPnllyxZsoQ333wT0LYzAPzzzz9cv36dhg0bYmtrS1BQEN988w0JCQmcPHmSjz/+OMfXl9PtohS1ycnEUIolpiUy49AMDtw+wMbuG7NODha56M1UYGULf+EhLy8vQNsH/vlf+pcvX9btB0hKSqJXr144Ojry66+/GvxarVKlCgCurq5G36wzrF69mqSkJN37ypUr58txnzdo0CDmzJmja6DNTnbJJKOXUYZatWrp/tvJyYlhw4YxbNgwEhISaNGiBTNmzNAlBk9PTzw9PQkJCeH69esEBQUB0KJFC8aNG8e6detQq9U5aniWsiYTQylmqbLk9qPbPE5/zLG7x+hapaupQypSGjdujKurK0uWLOGNN97QVcPs2LGDixcvMm3aNF3Z0aNHc+XKFQ4dOkTZsmUNjtWhQwfs7e355JNPaN26Nebm5nr7o6KiDKqOshMQEJCHq8q9Z2/0OfVsMnleVokxJiZGr8eUnZ0dVatW5datW3rlgoKC2Lt3L/fv32fcuHGAdtxFmTJl+PTTT7G2tqZRo0Y5jlUyJBNDKaZSqpgTOIfEtERqO5fM0b/GMDc3Z968eQwbNoyWLVsyYMAA7t27x9dff423tzfvv/8+ANu3b+fnn3/m1Vdf5cyZM3r97O3s7OjRowf29vYsXryY119/nYYNG9K/f39cXFy4efMm27dvJyAggIULF5rqUrOVUT30/JQaWVGpVEyePJlhw4bl+Bw1a9akVatWNGrUCCcnJ/777z/Wr19vMJ1GUFAQq1evRqFQ6KqWVCoVzZs3Z+fOnbRq1QoLC4scn1cyJBNDERKTkIK1hQobi8L731LZoWCqH0qKoUOHYmNjw6effsqECROwtbWlZ8+ezJs3D0dHR0D7ax+0g62en1/Iy8tLV8/+2muvUbFiRT799FPmz59PSkoK7u7uBAUF5eoGagpmZmZMmTIlV3FmPDVkjJ/IzrvvvsuWLVvYtWsXKSkpeHl5MWfOHD744AO9chnVR9WrV9d7wggKCmLnzp26/VLeKURpalEpJPHx8Tg4OBAXF2fQ2yQr7/56ki2n7/DNgAZ0q/eC7qEFKDopmt+v/s7w2sOL3JQGkiQZJzf3JfnEUES4ltHWXx8IjTJJYkhOT6bf1n7cT7qPq40r3apk38goSVLJJKfEKCICfZ0BOBAabZJucVZmVgyoMYDqTtWpVtaw374kSaWHfGIoIpr6OGGhUnInLpnr0Y+p4mKX/Yfy2dBaQxlSawjmSvPsC0uSVGLJJ4YiwsbCjIZejoD2qcEUzJRmekkhXZNukjgkSTItmRiKkCBfbT/2EBMlhgxCCDaFbuKVTa8QlRhl0lgkSSp8MjEUIYFVte0Mh6/HkK7WmCwOtVCz5vIaIhIiWHmxFE01LEkSINsYipTa7g44WJsTl5TG6duxNPJyMkkcZkoz5gTMISQihME1B5skBkmSTEc+MRQhKqWCgKraATumrk7yLevLG7XfwEwpfztIUmkjE0MRE1hV285gqgbozGiEhn9u/1OqZpeUpNJMJoYiJujJeIaTt2J5lJxm4mi0DdFv73mbt/e8zR9hf5g6HEmSCoFMDEWMh5MNXuVsUGsEh68/MHU4KBQK6rvUx0plRXJ6sqnDkSSpEMjEUARl9E46EFo0uoq+UecNNnbfyKt+r2ZfWJKkYk8mhiIoozop5GrRaGcwV5rjUcYj+4JSkTRjxgw5KaKUKzIxFEHNKjujVMD1qMfciU3K/gOFKDwunDF7xhCdVDSSVk6dPXuW3r174+XlhZWVFe7u7rRr145vv/3W1KGRmJjIjBkzdGtPS5KpycRQBDnYmFOnkiMAB4rIUwNoG6KnHpzK/tv7+fy/z00dTo79+++/NG7cmNOnTzNixAgWLlzIm2++iVKp5OuvvzZ1eCQmJjJz5kyZGKQiQ3ZSL6KCqjpz+lYsB0Kj6du4aFTjKBQKJr80ma9PfM27Dd41dTg59vHHH+Pg4MCxY8d0i+tkuH//vmmCMsLjx4+xtc3FetmlnBCC5ORkrK2tTR1KsSGfGIqojGm4D16NRqMpOuMHqjtVZ3HbxVS0M81iQnlx7do1atWqZZAUAFxdXfXeKxQK3nnnHVavXk21atWwsrKiUaNG/PPPPwafjYiI4I033qB8+fJYWlpSq1YtfvrpJ4NyycnJzJgxAz8/P6ysrHBzc6NXr15cu3aN8PBw3VrPM2fORKFQoFAomDFjBqBdQc7Ozo5r167RuXNnypQpw8CBAwEICQmhT58+eHp6YmlpiYeHB++//z5JSXmvfjxy5AidO3embNmy2NraUrduXYOnqr179xIUFIStrS2Ojo50796dixcv6pXJaNe4evUqQ4cOxdHREQcHB4YNG0ZiYqKuXO3atWndurVBHBqNBnd3d3r37q237auvvqJWrVpYWVlRvnx5Ro0axcOHD/U+6+3tzSuvvMLOnTtp3Lgx1tbWLF26FIAbN27QrVs3bG1tcXV15f3332fnzp0oFAqDJ7YjR47QsWNHHBwcsLGxoWXLlhw8eDBP15lh1apVNG3aFBsbG8qWLUuLFi3YtWuXXpkdO3bovt8yZcrQpUsXzp8/b3CsgiSfGIqohp5lsbFQEfM4lYt346lV0cHUIWUqMiGSCrYVinTjppeXF4cOHeLcuXPUrp392tZ///03a9eu5d1338XS0pLvvvuOjh07cvToUd3n7927x0svvaRLJC4uLuzYsYPhw4cTHx/P2LFjAVCr1bzyyivs2bOH/v3789577/Ho0SN2797NuXPnaNu2LYsXL+att96iZ8+e9OrVC4C6devq4klPT6dDhw4EBgby+eefY2NjA8C6detITEzkrbfeoly5chw9epRvv/2W27dvs27dulx/T7t37+aVV17Bzc2N9957jwoVKnDx4kW2bdvGe++9B8Bff/1Fp06dqFy5MjNmzCApKYlvv/2WgIAATpw4gbe3t94x+/bti4+PD3PnzuXEiRP88MMPuLq6Mm/ePAD69evHjBkzuHv3LhUqVNB97sCBA9y5c4f+/fvrto0aNYrly5czbNgw3n33XcLCwli4cCEnT57k4MGDmJs/nRn48uXLDBgwgFGjRjFixAiqVavG48ePadOmDZGRkbrr++WXX9i3b5/Bd7F37146depEo0aN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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot setup\n",
    "update_plot_style()\n",
    "res = np.vstack(experiments) # All results\n",
    "s_i = 5 # starting index\n",
    "jump = len(reg_OBF) * len(ratios) # Number of hyper-parames for a fixed number of collocation points\n",
    "n_s = np.asarray(n_s) # Number of collocation points\n",
    "end_ind = len(n_s) + 8\n",
    "\n",
    "# Extract error metrics\n",
    "errors = extract_errors(res, n_s, jump, s_i)\n",
    "\n",
    "# Convergence plot: Error vs collocation points\n",
    "pt_1, pt_2 = 0, 5\n",
    "spec_line_fn = compute_spectral_line(\n",
    "    (n_s[pt_1], n_s[pt_2]),\n",
    "    (errors['l2_rel_err_elm'][pt_1], errors['l2_rel_err_elm'][pt_2])\n",
    ")\n",
    "x_spec = n_s[:pt_2 + 2]\n",
    "y_spec = spec_line_fn(x_spec)\n",
    "plot_convergence(\n",
    "    x=n_s[:end_ind],\n",
    "    y1=errors['l2_rel_err_elm'][:end_ind],\n",
    "    y2=errors['l2_rel_err_swim'][:end_ind],\n",
    "    x_spec=x_spec,\n",
    "    y_spec=y_spec,\n",
    "    xlabel='# Collocation points',\n",
    "    ylabel=r'Relative  ' + r'$\\mathbb{L}_{2}$ ' + r'error',\n",
    "    filename='convergence_adv_1.pdf',\n",
    "    legend_labels=[\"Frozen-PINN-elm\", \"Frozen-PINN-swim\", \"Spectral convergence\"]\n",
    ")\n",
    "\n",
    "# Convergence plot: Error vs hidden layer width\n",
    "widths = n_s[:end_ind] // ratios[0]\n",
    "spec_line_fn = compute_spectral_line(\n",
    "    (n_s[pt_1]/ratios[0], n_s[pt_2]/ratios[0]),\n",
    "    (errors['l2_rel_err_elm'][pt_1], errors['l2_rel_err_elm'][pt_2])\n",
    ")\n",
    "x_spec = n_s[:pt_2 + 2] / ratios[0]\n",
    "y_spec = spec_line_fn(x_spec)\n",
    "plot_convergence(\n",
    "    x=widths,\n",
    "    y1=errors['l2_rel_err_elm'][:end_ind],\n",
    "    y2=errors['l2_rel_err_swim'][:end_ind],\n",
    "    x_spec=x_spec,\n",
    "    y_spec=y_spec,\n",
    "    xlabel='Width of hidden layer',\n",
    "    ylabel=r'Relative  ' + r'$\\mathbb{L}_{2}$ ' + r'error',\n",
    "    filename='convergence_adv_2.pdf',\n",
    "    legend_labels=[\"Frozen-PINN-elm\", \"Frozen-PINN-swim\", \"Spectral convergence\"]\n",
    ")\n",
    "\n",
    "# Optional: Save arrays for external plotting if needed\n",
    "# np.save('adv_rel_err_coll_points.npy', np.vstack((n_s[:end_ind], errors['l2_rel_err_elm'][:end_ind], errors['l2_rel_err_swim'][:end_ind])))\n",
    "# np.save('adv_rel_err_width.npy', np.vstack((widths, errors['l2_rel_err_elm'][:end_ind], errors['l2_rel_err_swim'][:end_ind])))\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
}
