{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Solve viscous Burgers equation with SWIM-ODE:\n",
    "In this script we show how SWIM-ODE uses resampling of collocation points and data-dependant sampling of weights and biases to solve Burgers equation accurately"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('../../')\n",
    "sys.path.append('../../src')\n",
    "from swimpde import Domain\n",
    "from swimpde import BasicAnsatz\n",
    "from swimpde import BurgersSolver\n",
    "import numpy as np\n",
    "import scipy\n",
    "from sklearn.metrics import mean_squared_error\n",
    "from matplotlib import ticker\n",
    "import time\n",
    "import matplotlib.pyplot as plt\n",
    "plt.rcParams['image.cmap'] = 'jet'"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Load data and reference solution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load and visualize data\n",
    "data = scipy.io.loadmat('../../data/burgers_shock.mat')\n",
    "t_eval = data['t'].flatten()[:,None]\n",
    "x_eval = data['x'].flatten()[:,None]\n",
    "u_exact = np.real(data['usol']).T\n",
    "X, T = np.meshgrid(x_eval,t_eval)\n",
    "X_ = np.hstack((X.flatten()[:,None], T.flatten()[:,None]))\n",
    "\n",
    "# Set ground truth\n",
    "u_true = u_exact.flatten()[:,None]              "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Problem setup"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# initial condition\n",
    "def u0(x):\n",
    "    return -1 * np.sin(np.pi * x)\n",
    "\n",
    "# forcing\n",
    "def forcing(x, t):\n",
    "    return np.zeros(x.shape[0])\n",
    "\n",
    "# boundary condition\n",
    "boundary_condition = \"zero dirichlet\" # \n",
    "\n",
    "# Domain information and spacial points for the first time-block\n",
    "n_points_1d = 4000 # No. of points in space\n",
    "x_lim = [-1, 1] # Domain range\n",
    "\n",
    "# Interior points\n",
    "rng = np.random.default_rng(seed=123)\n",
    "x_space = rng.uniform(x_lim[0], x_lim[1], n_points_1d).reshape((-1, 1)) \n",
    "x_space_inner = x_space[1:-1]\n",
    "interior_points = x_space_inner\n",
    "\n",
    "# Boundary points (excluding corners)\n",
    "left = x_lim[0]\n",
    "right = x_lim[1]\n",
    "boundary_points = np.row_stack([left, right])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Train and evaluate SWIM-ODE network"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\PhD\\Work\\Programming\\swim_pde_paper\\swimpde-paper\\swimpde\\examples\\burgers\\../../src\\swimpde\\Solver\\burgers_solver.py:144: RuntimeWarning: overflow encountered in multiply\n",
      "  non_lin_term =  t1 * t2\n",
      "c:\\PhD\\Work\\Programming\\swim_pde_paper\\swimpde-paper\\swimpde\\examples\\burgers\\../../src\\swimpde\\Solver\\burgers_solver.py:153: RuntimeWarning: invalid value encountered in matmul\n",
      "  c_t = self._A_boundary_inv @ np.concatenate([rhs, self.scale_boundary_correction * boundary_correction])\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "rmse_swim, re_swim\n",
      "0.0006080909977263369 0.0009898321100579146\n",
      "rmse_swim, re_swim\n",
      "4.064199834080494e-06 6.61558140558983e-06\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\PhD\\Work\\Programming\\swim_pde_paper\\swimpde-paper\\swimpde\\examples\\burgers\\../../src\\swimpde\\Solver\\burgers_solver.py:144: RuntimeWarning: overflow encountered in multiply\n",
      "  non_lin_term =  t1 * t2\n",
      "c:\\PhD\\Work\\Programming\\swim_pde_paper\\swimpde-paper\\swimpde\\examples\\burgers\\../../src\\swimpde\\Solver\\burgers_solver.py:153: RuntimeWarning: invalid value encountered in matmul\n",
      "  c_t = self._A_boundary_inv @ np.concatenate([rhs, self.scale_boundary_correction * boundary_correction])\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "rmse_swim, re_swim\n",
      "3.0048800977784118e-06 4.8912528203444845e-06\n"
     ]
    }
   ],
   "source": [
    "# Hyper-parameters\n",
    "n_sample = 3000 # No. of sampling points (for computing gradients)\n",
    "n_col = 800 # No. of collocation points (to be re-sampled)\n",
    "width = 450 # Width\n",
    "reg_const = 1e-7 # Regularization constant\n",
    "svd_cutoff = 1e-9 # SVD threshold\n",
    "seeds = [1,2,3] # Seeds (to compute mean errors)\n",
    "time_blocks = 3 # Number of time-blocks for smapling\n",
    "info = [] # List to store errors and time measurements\n",
    "\n",
    "# Define prob. distribution for (re)-sampling collocation points\n",
    "def collocation_points_probabilities(df_dx):\n",
    "    gradients = np.abs(df_dx)\n",
    "    gradients = gradients + 0.01 * np.max(gradients)\n",
    "    return gradients/np.sum(gradients)\n",
    "\n",
    "# Points where gradient of the solution at the end of a time-block is computed\n",
    "sample_test_points = np.sort(rng.uniform(x_lim[0] + 1e-4, x_lim[1] - 1e-4, n_sample)).reshape((-1, 1)) # This does not include boundary points\n",
    "\n",
    "# Domain\n",
    "domain = Domain(\n",
    "    interior_points=interior_points,\n",
    "    boundary_points=boundary_points,\n",
    "    sample_points = sample_test_points\n",
    ")\n",
    "\n",
    "# Store errors and time required for each seed\n",
    "rel_err_swim = np.ones((len(seeds), ))\n",
    "time_swim = np.ones((len(seeds), ))\n",
    "rmse_swim = np.ones((len(seeds), ))\n",
    "j = 0\n",
    "for seed in seeds: # Run over 3 seeds                                    \n",
    "    # SWIM network ansatz\n",
    "    ansatz_swim = BasicAnsatz(\n",
    "        n_neurons=width,\n",
    "        activation=\"tanh\",\n",
    "        random_state=seed,\n",
    "        regularization_scale=reg_const,\n",
    "        parameter_sampler = \"tanh\" \n",
    "    )\n",
    "    # Burgers equation solver\n",
    "    burgers_solver_swim = BurgersSolver(\n",
    "        domain=domain, \n",
    "        ansatz=ansatz_swim,\n",
    "        u0=u0,\n",
    "        boundary_condition=boundary_condition,\n",
    "        forcing=forcing,\n",
    "        regularization_scale=reg_const,\n",
    "        c=(0.01/np.pi)\n",
    "    )\n",
    "    # SWIM fit\n",
    "    t_swim_start = time.time()\n",
    "    sol_swim, solver_status_swim = burgers_solver_swim.fit_time_blocks(t_span=[0, np.max(t_eval)], rtol=1e-8, atol=1e-8, svd_cutoff=svd_cutoff, time_blocks=time_blocks, prob_distr_resampling = collocation_points_probabilities, n_col=n_col, outer_basis=False);\n",
    "    t_swim_stop = time.time()\n",
    "    time_swim[j] = t_swim_stop - t_swim_start\n",
    "    # Evaluate SWIM\n",
    "    u_swim = (burgers_solver_swim.evaluate_blocks(x_eval= x_eval, t_eval = t_eval, time_blocks = time_blocks, solver_status = solver_status_swim)).T\n",
    "    # Compute metrics\n",
    "    mse_swim = mean_squared_error(u_true, u_swim.flatten()[:,None])  # mean squared error\n",
    "    rmse_swim[j] = np.sqrt(mse_swim)  # Root Mean Squared Error                  \n",
    "    rel_err_swim[j] = np.linalg.norm(u_true-u_swim.flatten()[:,None],2)/np.linalg.norm(u_true,2) # Relative l-2 error\n",
    "    print(\"rmse_swim, re_swim\")\n",
    "    print(rmse_swim[j], rel_err_swim[j])\n",
    "    j += 1\n",
    "\n",
    "# RMSE and relative l-2 errors (mean and std) and time measurements\n",
    "info.append(np.mean(time_swim))\n",
    "info.append(np.mean(rmse_swim))\n",
    "info.append(np.std(rmse_swim))\n",
    "info.append(np.mean(rel_err_swim))\n",
    "info.append(np.std(rel_err_swim))\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Errors and time measurements"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Burgers equation: Errors and time measurements using ODE-SWIM\n",
      "training time for swim =  360.7527981599172\n",
      "rmse swim =  0.00020505335921939863 +- 0.00028499097538871066\n",
      "rel error swim =  0.0003337796480946163 +- 0.0004638996787836397\n"
     ]
    }
   ],
   "source": [
    "# Print errors and time measurements for Burgers with ODE-SWIM\n",
    "res = np.vstack(info).reshape(-1)\n",
    "\n",
    "# Burgers time measurements\n",
    "print('Burgers equation: Errors and time measurements using ODE-SWIM')\n",
    "print('training time for swim = ', res[-5])\n",
    "print('rmse swim = ', res[-4], '+-', res[-3])\n",
    "print('rel error swim = ', res[-2], '+-', res[-1])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Error plots and comparison of solutions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Relative L2 error on the entire spatio-temporal domain: 4.891253e-06\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\chinm\\AppData\\Local\\Temp\\ipykernel_32156\\1003889938.py:82: UserWarning: The figure layout has changed to tight\n",
      "  fig.tight_layout()\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmMAAADSCAYAAAAGwceEAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABfQElEQVR4nO2deXgUVfq2n96zkE5YE5aQyL7IogghCAKKRkEUhQEBFRAQFUQWF9BRQGdENkURBnRGmBFQYX6g8w0IKsoogoogILIZdtGwkz3d6e7z/dFd3VXVVdXVW6qTfu/rqquqzlanup+q961zTp3SMcYYCIIgCIIgCE3Qa10BgiAIgiCIeIacMYIgCIIgCA0hZ4wgCIIgCEJDyBkjCIIgCILQEHLGCIIgCIIgNIScMYIgCIIgCA0hZ4wgCIIgCEJDyBkjCIIgCILQEHLGCIIgCIIgNIScMSJi6HQ6zJ49W+tqyJKdnY27775b62oQBEHg1KlT0Ol0WLhwYZUed/To0cjOzq7SYxKBIWesijl58iQmTZqEVq1aISkpCUlJSWjXrh0mTpyIAwcOaF29qPP7779j9uzZ2LdvX1TKP3ToEGbPno1Tp05FpXwiuvz8888YMmQIsrKykJCQgMaNG+P222/HkiVLAADt2rVDp06d/PJt3LgROp0OvXv39ot77733oNPp8NlnnwEAVq1aBZ1Ohx9//NGbZvbs2dDpdNDr9Th79qxfGUVFRUhMTIROp8OkSZNUnw9jDO+//z5uueUWpKWlISkpCR06dMDLL7+M0tJSv/R9+vSBTqfz1sVqtaJ169Z46KGH8Pnnn0seIzs725tHvNx5552q60pElmXLlkGn0yEnJ0frqkSMzZs3x/QDd3XGqHUF4on//ve/GDZsGIxGI0aOHIlOnTpBr9fjyJEj2LBhA/72t7/h5MmTyMrK0rqqUeP333/HnDlzkJ2djc6dO0e8/EOHDmHOnDno06cPPf1VM3bu3Im+ffuiadOmGD9+PDIyMnD27Fl89913ePPNN/Hkk0+iZ8+e+Mc//oHCwkKkpqZ683777bcwGo3YvXs3KisrYTKZBHEGgwG5ubkB62CxWPDBBx/g2WefFYRv2LAh6PNxOp0YMWIE1q1bh169emH27NlISkrCN998gzlz5mD9+vX44osvkJ6eLsjXpEkTzJ07FwBQWlqK/Px8bNiwAatXr8bQoUOxevVqwfkBQOfOnTF9+nS/OjRq1CjoehORYc2aNcjOzsYPP/yA/Px8tGjRQusqhc3mzZuxdOlScsiiADljVcTx48fxwAMPICsrC9u2bUPDhg0F8fPmzcOyZcug1ys3VpaWliI5OTmaVY0pysrKkJSUpHU1iCrgr3/9K1JTU7F7926kpaUJ4i5cuAAA6NmzJ959913s3LkTd911lzf+22+/xdChQ7F27Vrs2bMH3bt398bt2LEDHTt2REpKSsA69O/fX9IZW7t2LQYMGID/+7//U30+8+fPx7p16/D0009jwYIF3vBHH30UQ4cOxaBBgzB69Gh8+umngnypqal48MEHBWGvvfYaJk+ejGXLliE7Oxvz5s0TxDdu3NgvD6EdJ0+exM6dO7FhwwZMmDABa9aswaxZs7SuVo1EySaGaz8cDgdcLhfMZnPIZaiFuimriPnz56O0tBQrV670c8QAwGg0YvLkycjMzPSGjR49GrVq1cLx48fRv39/pKSkYOTIkQDcApw+fToyMzNhsVjQunVrLFy4EIwxb35uTMKqVav8jice38V10+Tn52P06NFIS0tDamoqxowZg7KyMkFem82GqVOnon79+khJScE999yD3377LeBvsH37dnTt2hUAMGbMGG9XCle/Pn364Prrr8eePXtwyy23ICkpCc8//7xkfTmys7MxevRoAO7upz/96U8AgL59+3rL3759uyDPjh070K1bNyQkJKBZs2b417/+FbDuRPQ5fvw42rdv7+eIAUCDBg0AuJ0xwO18cVRUVGDv3r24//770axZM0HcxYsXcezYMW++QIwYMQL79u3DkSNHvGEFBQX48ssvMWLECNXnUl5ejgULFqBVq1beVi4+AwcOxKhRo7BlyxZ89913AcszGAx466230K5dO7z99tsoLCxUXRei6lmzZg1q166NAQMGYMiQIVizZo1i+jfeeANZWVlITExE7969cfDgQUF8QUEBxowZgyZNmsBisaBhw4a49957/YZjLFu2DO3bt4fFYkGjRo0wceJEXLt2TfHY27dvl7xPiu3H6NGjsXTpUgAQdIVzuFwuLF68GO3bt0dCQgLS09MxYcIEXL16VfH4HEeOHMGQIUNQp04dJCQk4KabbsJ//vMfQRpuiMH//vc/PPHEE2jQoAGaNGkCQNl+XLhwAWPHjkV6ejoS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33m88847fk9voZZPaM9XX30leR1wY2f4zn/Pnj1x8eJFrFy5Ejk5OYKbbI8ePXD06FF88sknqFu3ruBtWrU0b94cixcvxty5cxUfnvr16ydYuJaypKQkPP300zh69CheeOEFv3ybNm3CqlWrkJeXJ5gTTQ6n04nJkyfj8OHDmDx5MqxWa9DnRESX8vJybNiwAXfffTeGDBnit0yaNAnFxcV+0zV8/PHHgjFRP/zwA77//nvvvbasrAwVFRWCPM2bN0dKSgpsNhsAtw7NZjPeeustwTXETZCs9CZwVlYWDAaDKjshd38dOnQonE4nXnnlFb88DodD8X7coEED9OnTBytWrPB7uAbc09OEQ//+/VFQUICPPvpIUKclS5agVq1akl/t0AJqGasiWrZsibVr12L48OFo3bq1dwZ+xhhOnjyJtWvXQq/X+40Pk2LgwIHo27cvXnjhBZw6dQqdOnXCZ599hk8++QRTpkwRjOcaN24cXnvtNYwbNw433XQTvv76axw7dizk8+jcuTOGDx+OZcuWobCwED169MC2bduQn5+vKn/z5s2RlpaG5cuXIyUlBcnJycjJyQnYTz9u3Dg89thjGDx4MG6//Xbs378fW7duRb169fzqZzAYMG/ePBQWFsJiseDWW2+VHctAxA5PPvkkysrKcN9996FNmzaw2+3YuXMnPvroI2RnZwsG5nItQ7t27fKbf6579+7Q6XT47rvvMHDgwJBbS5966qmQzwUAZsyYgZ9++gnz5s3Drl27MHjwYCQmJmLHjh1YvXo12rZt6zfXEQAUFhZi9erVANyGmJuBn5s4WsrgnTt3zpuHT61atWS7SYnI8p///AfFxcW45557JOO7d++O+vXrY82aNYJxjC1atEDPnj3x+OOPw2azYfHixahbt6534uFjx47htttuw9ChQ9GuXTsYjUZs3LgR58+fxwMPPADA3Q04c+ZMzJkzB3feeSfuueceHD16FMuWLUPXrl0VJwROTU3Fn/70JyxZsgQ6nQ7NmzfHf//7X8lxXl26dAHgfoErLy8PBoMBDzzwAHr37o0JEyZg7ty52LdvH+644w6YTCb8+uuvWL9+Pd58800MGTJEtg5Lly5Fz5490aFDB4wfPx7NmjXD+fPnsWvXLvz222/Yv39/4D9AhkcffRQrVqzA6NGjsWfPHmRnZ+Pf//43vv32Wyxe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",
      "text/plain": [
       "<Figure size 600x300 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAk4AAAENCAYAAAD5feqqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABkYklEQVR4nO3dd3hT1RvA8W/SBaWLUSiz7LIpoMhsy0YBQZSpDFEUFFHBAcgQ2QqIIg5EGSpDQcGfKIjQsncpS8CyyixltaUFOs/vj9rQ2pambZKbpO/nefqQ3HHOG3JP8ubcc8/VKaUUQgghhBAiV3qtAxBCCCGEsBWSOAkhhBBCGEkSJyGEEEIII0niJIQQQghhJEmchBBCCCGMJImTEEIIIYSRJHESQgghhDCSJE5CCCGEEEaSxEkIIYQQwkiSOAkhhBBCGEkSJyGEEEIII0niJIQQQghhJEmchBBCCCGMJImTEEIIIYSRJHESQgghhDCSJE5CCCGEEEaSxElYlaCgIHQ6ndZh5MvgwYPR6XScP39e61CEsFvz5s3D2dlZ2lkehYSEoNPpeP/99zMt1+oz97nnnsPX15f79+9bvO6CksTJyoSFhTFs2DDq1KmDh4cHzs7O+Pj40KFDB+bMmcP169e1DtFq5PRBYC/1CfOIj49n+vTpNG7cGDc3N1xcXKhQoQKtW7dm7NixnDlzxrBtrVq10Ol0REZGZiknLCwMnU6HTqdjz549WdbfunULvV5PpUqVDMvef/99dDodK1euzLRt5cqVDWUdO3Ys27hTUlIoX768Ybv8JA7379/nk08+oXXr1pQsWdLw2nv37s2WLVuy3ef8+fOGOtP/XF1dKVeuHO3atWPixImZ/s8ySm8zD/sLCgoyOv7bt28zZcoUhgwZQuXKlfP8+oX1mDhxIpcvX2bevHlah5JnjloHINKkpqbyzjvvMGfOHBwcHAgICKBjx44UK1aMqKgodu/ezVtvvcWkSZM4deoU5cuX1zpkIWzOnTt3aNWqFUeOHKF69eo899xzlCxZkhs3brBv3z5mzpxJtWrVqFatGgBt2rTh1KlThISE0Ldv30xlBQcHA6DT6QgJCaFZs2aZ1m/duhWlFG3atDEqNr0+7Xfst99+y9y5c7Os/+OPP7hy5QqOjo4kJyfn+bWfPn2aLl268M8//1C1alV69+6Nl5cXZ8+eZf369fz000+89NJLLFiwAEfHrF8N1apV47nnngMgISGBqKgo9u3bx5QpU5g+fTrvvPMO06ZNy7b3okmTJnTt2jXbuPKSAH388cfcunWLt99+2+h9xMMtW7aMu3fvWrzemjVr0r17d2bOnMlrr71GsWLFLB5DfkniZCXee+895syZQ+PGjVm1ahXVq1fPsk1oaCjvvvsu9+7d0yBCIWzfvHnzOHLkCC+++CILFy7M8iV/7tw5EhISDM/btGnDl19+SXBwcLaJU5UqVfD09CQ4OJgxY8ZkWh8SEmIowxhOTk4EBATw/fffM2vWLJycnDKt//bbb/H09KRhw4Zs27bN2JcMQExMDJ07d+bMmTNMmDCBSZMm4eDgYFh/5coVevTowcKFC/H09OTDDz/MUkb16tWz7W3dsWMHAwYMYMaMGTg4ODBlypQs2zzyyCMF7qlNTk5m0aJFtGzZ0pDYioLL2CNqac899xw///wzK1eu5IUXXtAsjjxTQnOnTp1SDg4OytvbW0VFReW6fVJSkuHxuXPnFKAGDRqk/v77b9WjRw9VokQJBahz584Ztp8zZ45q0KCBKlKkiPLw8FBBQUHq119/zVL2pEmTFKCCg4OzrFu8eLEC1OLFi7OtPzw8XPXo0UN5eXkpV1dX1a5dOxUWFpbta9i+fbsKCAhQrq6uqkSJEqp3797qwoULKjAwUBlzWKbHmd1f+useNGiQAtSZM2fU7NmzVe3atZWzs7MaNGhQpvXp2z/s/yEv9Z09e1Z98sknys/PTzk7O6tKlSqp999/X6WkpOT6uoR5Pf744wpQhw4dMmr7a9euKUDVrFkz0/KUlBTl5eWlnn/+efXGG2+oYsWKqcTExEzbNGjQQAHq/PnzhmXpx9GKFSsybevr66tcXFzUihUrFKDWrFmTaX1UVJRycnJSw4YNU506dcrxuM3Je++9pwD17LPP5rhNZGSkKlGihNLr9So8PNywPL2Nd+rUKcd9T548qVxcXJSzs7O6cOGCYXlwcLAC1Msvv2x0rDn53//+pwA1b968LOsyfjb9+uuvqkWLFsrNzU35+voatklISFBz5sxRjRo1Uq6ursrNzU21atVKrVu3Lkt50dHRasKECap27dqqWLFiyt3dXVWrVk0NHDgw0/t5+fJlNXHiRPXYY48pb29v5ezsrHx9fdXw4cPVtWvXspSb8TPpo48+UjVq1FBFihRRtWvXNhwTCQkJaty4cYZjon79+ur333/PUlb6Z+W9e/fUu+++qypWrKhcXFxUrVq11KeffqpSU1MzbZ/+XkyaNCnbcnL6/9y4caNq3ry5Klq0qCpRooQaOHCgunHjRtY3SCn15Zdfqjp16igXFxdVoUIF9fbbb6t79+4pQAUGBmbZPiEhQbm6uqpWrVplW561kh4nK7B06VJSUlJ4+eWX8fb2znX77LrRT58+TbNmzahfvz6DBw/m5s2bODs7o5TimWeeYd26ddSsWZNXX32V+Ph4Vq1axZNPPsncuXN58803C/wazp8/T7Nmzahbty5DhgzhzJkzrFu3jjZt2nDixAnKlClj2Hbz5s08/vjj6PV6+vTpQ7ly5di8eTMtW7akePHiRtUXFBTE+fPnWbp0KYGBgZnGSXh5eWXa9rXXXmPPnj106dKFbt26Ubp06Ty/vrzU9/bbb7N161a6du1Kp06dWLt2Le+//z6JiYlMmzYtz3UL0ylZsiQA//zzD/7+/rluX7p0aerWrcvx48e5cuUK5cqVA+DQoUNER0cTFBSEh4cH8+bNY9++fbRs2RKAmzdvcvToUapUqYKvr6/R8T311FMUL16cxYsX07NnT8Py7777jqSkJIYMGcKECRPy8IrTLF68GOCh+5YpU4ahQ4cya9YslixZwtSpU40u38/Pj969e/Pdd9+xdu1aXnvttTzHmJvNmzcDZDklmtFPP/3En3/+SdeuXXnllVeIjY0F0k4tdu7cmZCQEPz9/XnhhRdISkpi/fr1dO/enfnz5zNixAgAlFJ06tSJvXv30rJlSzp37oxeryciIoJff/2VAQMGGN7Tbdu2MWfOHNq1a8djjz2Gk5MThw4d4osvvmDjxo2Ehobi6emZJc5Ro0axd+9eunXrhoODAytXrqR///4UL16c+fPn8/fff9OlSxfu37/P8uXL6d69OydOnMi2p613794cOnSIp59+GoA1a9YwcuRIzp8/z5w5cwr0f/7rr7+yfv16unXrRosWLdi2bRvLli3jzJkz7NixI9O2EydOZMqUKYbjyMnJiR9//JGTJ0/mWL6zszNNmjRh9+7dxMfH287pOq0zN6FUmzZtFKA2b96c533Tfw0CauLEiVnWL1261JDtJyQkGJZHRESoUqVKKUdHR3XmzBnD8vz2OAFq5syZmbYfP368AtSMGTMMy1JSUlTVqlWVTqdT27dvNyxPTU1V/fv3N5RljJx+QaVL/3VXoUIFFRERkeN6Y3qc8lJflSpV1JUrVwzLr1+/rry8vJS7u3um90BY3rp16xSg3N3d1ejRo9XGjRtz/PWcbsSIEQpQP/zwg2HZ7NmzFaAiIiLUjRs3lE6nU1OmTDGsX7NmjQLUkCFDMpWVW49Ten2Ojo7q6tWrhvV169ZV9evXV0qpPPc4nT9/XgGqfPnyuW77559/KkC1bdvWsMyYHiellPrmm28UoAYMGGBYlt5mmjRpoiZNmpTt3+7du416HY8++qjS6/Xq/v37Wdalfzbp9Xq1adOmLOvHjRunADVhwoRMPTGxsbHqkUceUc7Ozury5ctKKaWOHDmiANWjR48s5dy/f1/duXPH8PzatWuZnqdL/9ydOnVqpuXpnxE1a9bMdHZh7969ClBeXl6qVatWKi4uzrBu1apVClCvvfZaprLSe4r8/PxUdHS0YXl0dLTy8/NTOp1O7d+/37A8Pz1Ojo6OaseOHYblycnJKigoSAGZ3rf0sybly5fP1NMWGxur6tSpk2OPk1JKvfnmmwpQW7ZsyXa9NbKJq+oeeQQqVLDev0ceKdjrS79iJ/3XbEYhISG8//77mf7Sx05k5OPjw3vvvZdl+dKlSwH48MMPcXZ2NiyvVKkSb775JsnJyfzwww8FewFAlSpVsgzYTD9nvX//fsOyHTt2cPbsWbp27UqrVq0My3U6HdOnT8807sJU3n77bYuex58wYQJly5Y1PC9VqhTdu3fnzp07nDp1ymJx5NvcucYd+E8+mXXfJ580bt//Dn6+cyd/++XRk08+yZw5c1BKMWfOHDp16kSpUqWoXr06I0aMIDw8PMs+6WOU0geDpz+uUqUKlSpVomTJktSrVy/T+ryOb8poyJAhJCcnG9ru3r17OX78OEOGDMlzWfDg86VixYq5bpu+zdWrV/NcT/rn140bN7KsO3jwIJMnT872L7srErNz6dIlvLy8cHFxyXGb7t270759+0zLUlNT+eKLL6hWrRqTJ0/ONK7N3d2diRMnkpiYyM8//5xpv6JFi2Yp38XFBTc3N8Pz0qVLZ3qebsCAAXh4ePDXX39lG+d7772X6exC06ZNqVq1KtHR0UybNi1Tz8vTTz+Nk5MThw8fzrasCRMmZOrV8vT0ZPz48SilDMdQfvXv39/Qiwrg4ODAoEGDgMyf6ytWrCAlJYXRo0dn6tF3d3dn/PjxD60j/WzEpUuXChSrJdnEqbrISLh8WesotBESEsLkyZOzLP/vJbwNGzbMlBilO3ToEK6urjRt2jTLuvQP9bCwsALH6e/vb7gqKF2FChUAiI6ONixLb/ytW7fOUoavry8VK1Y0+fws2b12c2rSpEmWZdn9X1it2FjjGlx2X8TXrxu377+nUAyUyt9++TBq1CiGDh3Khg0b2LVrFwcOHGDv3r0sWLCAb775xnAaO11gYCA6nc6QGKWkpLB9+3bDqZH0bRYtWkRCQgIuLi4FSpwaNWqEv78/ixcv5t133+Xbb7/F2dnZcEVbdrIbeP3GG29kOY2slZdffpkvv/yyQGXcvHnT0I5ykl1bP3XqFLdv36ZcuXLZfpamT/GSfkqpdu3aNGjQgBUrVnDp0iV69OhBUFBQtp9xAD///DNfffUVoaGh3L59m5SUFMO6K1euZBtndqeJy5Yty9mzZ7Osc3BwoHTp0jmWld1nafqyQ4cOZbuPsYz9LEv/XM/4YzhdxsQrOyVKlACyT7itlU0kTj4+WkfwcAWNr0yZMpw4cYIrV65Qq1atTOvSe5kAVq5cSb9+/XIsIzuxsbE5/tJM7xWJNcGXkYeHR5Zl6WOxMn6QxMTEAOQ4zqhMmTImT5xy+r8xF2P/L6yWhwcYM91FduPxvL2N2/e//0c6Xf72yyd3d3d69epFr169gLTjcty4cXz++ee88MILXL582fBDpGTJktSvX58jR45w6dIlrl69SmxsLIGBgYbyAgMD+eyzz9izZw9169bl2LFj1KxZM9/ThgwZMoSRI0fy119/sXLlSrp160apUqVy3D67hGDw4MF4eXnh8+8H1MWLF3OtN32bjD2mxkr/YjdmnGZ+FC1aNNfJErNr67du3QLg+PHjHD9+PMd94+PjgbS2umXLFt5//33WrFnD6NGjgbTXNWLECN577z1Dz/icOXN466238Pb2pmPHjlSoUMHQUzVv3rxMV2hm9LDPiJzWJSUlGf2a05elf97ml7GfZenfIdl9ruf2+Zt+lbirq2u+47Q0m0icDhzQOgLzatGiBSEhIQQHB9O2bdt8lZHTzK8eHh5ERUVluy69Cz9j40j/RZXdPDEFbYSAoUs5p5iuXbtW4Dr+K6f/G3O/Vps1alTaX378+mv+9nN3Bw276j09Pfnss89Yv349ERERHD16NNOv7TZt2nDkyBGCg4MNp7Ey9vqmJ1HBwcHcuHEjT/M3ZefZZ5/l7bffZvDgwcTGxuZ6qbZSKsd1vr6+lCtXjsuXL3Pq1Cn8/Pxy3DZ9AHbz5s3zHHN6L9ujjz6a532N4e3tnevpnOzaevrn29NPP83q1auNqqtkyZLMnz+fTz/9lJMnT7Jlyxbmz5/PpEmTcHJyYuzYsSQnJzNlyhTKli1LWFhYpqRBKZXtlA7mcO3atSxDEdI/R7MbmG4O6f/HUVFRWS6GyO0zPT2xNVfCbQ42McbJ3g0aNAi9Xs/ChQtN3l3ZqFEj7t69y759+7KsS/+gy9g1nH5V2+VsTpsUtNsX0k4pAmzfvj3LuoiICKN+FadL/9WX316cvL7WgtYnrJtOp8vxqp70JCgkJISQkBAqV66c6QvC29ubOnXqEBwcXKDTdOlKlChBjx49uHz5MuXLl6dTp075LgvSep+Ah17VGRUVxaJFi9Dr9YbtjfXPP//w448/4uLiwlNPPVWASHNWv3597t+/z4ULF/K0X+3atfHw8ODAgQM59trkRKfTUbt2bV599VU2bdoEpF1pBmmnlmJiYmjevHmWnpYDBw5YbL697D5L05c1atTIIjGkf67v3Lkzy7pdu3Y9dN/0cZ/169c3fWBmIomTFahZsybvvPMOUVFRPP7445w+fTrb7fIzPiZ9IN/YsWMzfWhcvHiRuXPn4ujoyLPPPmtYnv5rcdmyZaSmphqW79692ySDyFu1akWVKlX47bffMl3OqpRi3LhxeUpK0s+N5yXZyij9tS5ZsiTT8tWrV7N161aT1ye099VXX2Ua1JrR2rVrOXHiBF5eXtSrVy/TuoCAAPR6PZs3b2bHjh3Z3iYkMDCQPXv2sHHjRiDrOMS8mjlzJr/88gtr167NdmxNXrz99ttUqVKF7777jg8++CBLO4uMjKR79+7cvHmT0aNHZzsBb0527txJp06dSEhIYMyYMWa7q0F6r97evXvztJ+joyPDhw8nIiKCt956K9vk6dixY4Ze8PPnz2c7XCC956RIkSJA2mmpokWLEhoammnm7du3b5tlOoacTJkyJVMPeUxMDFOnTkWn0xk+/82tb9++6PV65syZk+nHf3x8fK5TsOzdu5eyZctSo0YNc4dpMjZxqq4wmDZtGomJicydO5datWoREBBAw4YNcXV1JSoqiiNHjrBv3z7c3NyMmn8m3YABA/j5559Zt24dDRo0oGvXroZ5nG7dusWcOXOoWrWqYftmzZrRsmVLtmzZQvPmzQkICCAiIoJ169bRrVs3fvnllwK9zvSetSeeeIL27dsb5nHasmULV69epUGDBhw5csSosmrVqkW5cuVYuXKl4Z5bOp2O1157zagu6u7du1OtWjWWLFnCxYsXadSoESdOnGDLli088cQT/P777yatT2jvjz/+YNiwYVSvXp2WLVtSrlw54uPjOXToENu3b0ev1/P5559nuXKrePHi+Pv7ExoaCmSfFAUGBvLFF18QHh5OnTp1Cjy2rnLlyia7H5uXlxcbNmygS5cuTJo0iWXLltGpUyc8PT0Nt1yJi4tj6NChTJ8+PdsyTp8+bRhvmZiYaLjlytGjR3FwcGD8+PFMmjQp230PHDiQ48zhRYoUyTLrena6d+/OqFGj2LRpk2FsmrEmT55MaGgon376KevXrycgIIDSpUtz+fJljh49yuHDh9m9ezelS5cmLCyMnj170rRpU+rUqYOPjw+XL182JLDp897p9XpeeeUV5syZQ8OGDenWrRuxsbH88ccfhtOjllCzZk3q1auXaR6nS5cuMWrUKB4p6CXfRvLz82PMmDFMnz6d+vXr07t3bxwdHfn555+pX78+x44dyzb5P3PmDOfOnWP48OEWidNktJwLQWQVGhqqXnrpJVWrVi3l5uamnJycVJkyZVTbtm3VRx99lGU22owzd+ckKSlJzZ49W9WvX1+5uLgod3d3FRgYmO2MuUopdePGDTVw4EBVokQJVbRoUdWsWTO1cePGXGcOzw45zN+xbds2FRAQYJiNtlevXioiIsLomcPT7dmzRwUGBip3d/ccZ/J+2Hw3586dUz169FDu7u6qWLFiql27dmr//v05zmeV3/oeNj+WsJyTJ0+qDz/8UHXo0EFVqVJFFSlSRBUpUkRVq1ZNDRo0SB04cCDHfUePHm14zzPOHp3u6tWrhvWvvvpqtmUYM49TbvIzc3i6u3fvqrlz56oWLVooLy8v5eTkpMqVK6eeeeYZ9ddff2W7T8a52tL/ihYtqsqWLavatGmjJkyYoE6fPp3tvulzBz3sz9PT0+j4H3/8cVW8ePEsczll99n0X8nJyeqrr75SLVu2VB4eHsrFxUVVqlRJde7cWX3xxReGuZMuXryoxowZo5o1a6ZKly5tmP2/Z8+eWeacSkxMVNOmTVM1atQwlDd69Gh1584d5evrm2nmcqUe/hnxsM++7MrKOHP4O++8oypWrKicnZ2Vn5+fSWcO/6+HzWf3+eefG+7QUKFCBfXWW2+pixcvKkB17949y/bvv/++AnK8w4S10in1kFGFQgghhJXYvHkz7du35/vvv880xKAwCgoKMtxI2pr99ddfdOjQgXfeeYdZs2YZlicnJ1OjRg2qVKnCli1bNIww72SMkxBCCJvQrl07OnfuzNSpUzONwRTau379epaxc9HR0YwdOxaAHj16ZFq3dOlSIiIimD17tqVCNBkZ4ySEEMJmfPLJJyxfvpzLly8bNRu6sIwffviB2bNn07ZtW8qVK8fVq1fZsGEDUVFRDB48OMsUFzqdjq+//prGjRtrFHH+yak6IYQQwsZY26m6ffv2MW3aNPbv38+tW7dwcHCgdu3aDB48mFdeeaXAV4ZaE0mchBBCCCGMZD8poBBCCCGEmUniJIQQQghhJEmchBBCCCGMJImTEEIIIYSRJHESQgghhDCSJE5CCCGEEEaSxEkIIYQQwkiSOAkhhBBCGEkSJyGEEEIII0niJIQQQghhJEmchBBCCCGMJImTEEIIIYSRJHESQgghhDCSJE5CCCGEEEaSxEkIIYQQwkiSOAkhhBBCGEkSJyGEEEIII0niJIQQQghhJEmchBBCCCGMJImTEEIIIYSRJHESQgghhDCSJE5CCCGEEEaSxEkIIYQQwkiSOAkhhBBCGEkSJyGEEEIII0niJIQQQghhJEmchBBCCCGMJImTEEIIIYSRJHESQgghhDCSJE4aeO+999DpdOzcudPide/fv58nnngCLy8vihUrRrNmzfjxxx+N3v/y5cvMmzePjh07UqlSJZydnfHx8eHpp59m79692e5TuXJldDpdtn9BQUEmemXCltlym0iXn+PcVHUL+2Sr7WLJkiU5toX0v3bt2mXZz1a+Kxy1DqAwOnjwIHq9Hn9/f4vWGxwcTKdOnShSpAh9+/bF3d2dNWvW0KdPHy5evMjo0aNzLWP+/PnMmjWLatWq0bFjR7y9vQkPD2ft2rWsXbuW5cuX06dPnyz7eXp68sYbb2RZXrlyZRO8MmHrbLlNZJSX49zUdQv7Y6vtwt/fn0mTJmW7bvXq1Rw/fpxOnTplu94mviuUsDhvb2/l5+dn0TqTkpJUtWrVlIuLizp06JBheXR0tKpZs6ZydnZW58+fz7WcNWvWqJCQkCzLt23bppycnFTx4sXV/fv3M63z9fVVvr6+BX0Jwo7ZcptIl5fj3NR1C/tkD+0io4SEBFWyZEnl6OioIiMjs6y3le8KOVVnQW+88QY6nY7r169z6tSpTN2QJ06cMGvdW7Zs4cyZM/Tv3z/TrxdPT0/GjRtHYmIiS5cuzbWcnj17EhgYmGV569atadOmDbdv3+bo0aOmDF3YMXtoE7ZWt7B+9tou1q5dy82bN+natStlypQxUcSWJ6fqLKhp06b06dOHVatW0blzZx577DEAdDodNWvWNGvdISEhAHTs2DHLuvQu061btxaoDicnJwAcHbMeVgkJCSxZsoQrV67g4eHBo48+anj9ovCytzZh7HFuifYobJe9tYt0ixYtAuDFF1/McRtb+K6QxMmC+vfvz+XLl1m1ahUjRoygS5cuD91+3rx5REdHG11+jx49cjwXHh4eDkCNGjWyrPPx8cHNzc2wTX5cuHCBv/76i7Jly1K/fv0s6yMjI3n++eczLXv00UdZsWIF1apVy3e9wrbZW5sw9jg3d3sUts3e2gVAREQEmzdvpkKFCnTu3DnH7Wzhu0ISJwsLDQ0FoFGjRrluO2/ePCIiIowuu3Llyjk2hpiYGCCtuzU7Hh4ehm3yKikpiQEDBpCQkMCsWbNwcHDItP7555+ndevW1KtXDzc3N/755x/mzp3Ld999R7t27Th69Cju7u75qlvYPntpE3k5zs3ZHoV9sJd2kW7x4sWkpqYyePDgLN8R6Wzmu0LrQVaFjZ+fnypdurTF6+3QoYMCVHh4eLbry5Urpzw8PPJcbkpKiurfv78C1NChQ/O074ABAxSg5syZk+d6hf2wtzbxX9kd55aqW9gue2oXKSkpqlKlSkqn06mzZ8/mOSZr+66QweEWFB8fT3h4uMUvLYUHvx5y+qUQGxub4y+MnKSmpjJkyBCWL1/Oc889x5dffpmn/V9++WUATeYoEdbB3tpEdrI7zi1Vt7BN9tYu/vrrLy5cuEDbtm2pUqVKnmOytu8KOVVnQWFhYaSmphrV9QqmPW+dfr46PDycJk2aZFoXGRlJXFwcTZs2Nbqu1NRUnn/+eZYtW0a/fv1YsmQJen3e8vBSpUoBaR8SonCypzaRk+yOc0vVLWyTvbULYwaFP4y1fVdI4mRBR44cATD6V4Qpz1sHBgYyY8YM/vzzT/r27Ztp3caNGw3bGCNj0tSnTx++++67HM9ZP0z6TONWNbGZsCh7aRMPk91xbqm6hW2yp3Zx8+ZN1q1bR4kSJXjqqaeM3i8jq/uu0PpcYWEyZcoUBagNGzZYvO6kpCRVtWrVh05qdu7cuUz7nD59Wp04cUIlJiYalqWkpKhBgwYpQPXq1UslJSU9tN4TJ06o+Pj4bJf7+PgoQG3durVAr03YLntoE0rl/TjPT92i8LCXdqGUUh9//LEC1MiRIx9ary19V0iPkwWld7uOHDmSnj174uLiQps2bSzyy9LR0ZFFixbRqVMnAgICMk2jHxERwezZs7Nk8+3atSMiIoJz584Z1n3wwQcsXboUNzc3atasydSpU7PUlbEbeOXKlcydO5eAgAB8fX0pVqwY//zzD7///jtJSUmMHTuWgIAAM796Ya3soU1A3o/z/NQtCg97aRcA33zzDZD7aTqb+q7QOnMrbGbMmKGqVKmiHB0dFaCWL19u0fr37t2rOnfurDw8PFTRokVV06ZN1cqVK7Pd1tfXVwGZfl2k9zY97G/x4sWG7UNCQlTv3r1VjRo1lIeHh3J0dFQ+Pj6qe/fuauPGjWZ+tcIW2HqbUCr/x3le6haFiz20i7179ypANW3aNNf6bOm7QqeUUhrka0IIIYQQNkemIxBCCCGEMJIkTkIIIYQQRpLESQghhBDCSJI4CSGEEEIYSRInIYQQQggjSeIkhBBCCGEkmQDzX6mpqVy5cgV3d3d0Op3W4QgTUEpx584dypUrl+f76Ik00i7sT2FsF99//z3bt2/n4MGDHD16lMTERBYvXszgwYPzXJa0CfuUl3YhidO/rly5QsWKFbUOQ5jBxYsXqVChgtZh2CRpF/arMLWL8ePHExERQalSpShbtmye7uv2X9Im7Jsx7cJuEqdt27bx0UcfcfDgQa5evcovv/xCjx49jN7f3d0dSPtP8/DwMFOUwpJiY2OpWLGi4b0tbAraJkDahT0qjO1i0aJF1KhRA19fX2bOnMnYsWPzXZa0CfuUl3ZhN4lTfHw8DRs2ZMiQIfTs2TPP+6d3uXp4eEhjsDOFtTu9oG0CpF3Ys8LULtq3b2+ysqRN2Ddj2oXdJE6PP/44jz/+uNZhCGE1pE0IIYTp2U3ilFcJCQkkJCQYnsfGxmoYTd6c/eMUF7/dBKdOgk7PvfpN8ZvyHFWqaB2ZsHW23C7yKyYiGlfvYji5OmkdirBChbFNiIcrHJdUZGPGjBl4enoa/mxhsN+RL3Zy2DOAqk/UInD1awQeXUDgkflc+GEb1avD0KEgbVoUhC22i/w4dgzefBOGl/wRz8rFuVesJPs/+EPrsIQVKixtQhiv0CZOY8eOJSYmxvB38eJFrUPKUeylWHZUG0iDV1rRMHZ7lvXbCCA1FRYtgoAAuH5dgyCFXbCldpEf4eHQuzfUrw/z5sHOW7UA8OAOTnNnaRucsEr23iZE3hXaU3UuLi64uLhoHUau/ll9BJd+PWmVfMaw7KyzHxc6vEiJLs3ROejxj6jFuk8hLg4OH4Y+PRLYsFGHs5uzhpELW2Qr7SKvEuMS2dV1OtO3t2ZTajvD8rPOtSEx7XGl2KOoVIVOX3gGTYvc2WubEPlXaBMnW3Dgi/3UeKU9nqSdf4vBg8P9P6TFNy9QtciDt64+0G0gtG0L6soVpu/qya5ujxMUPEmjyIWwHqd//ZuUPv0Jun+YyvhSn6O4lnZn7FgYNMiJg9U70OTWJkqoW0Qdu0bpBj5ahyyEsGJ2kzjFxcVx+vRpw/Nz584RFhZGiRIlqFSpkoaR5c8vv8BLr9dkE1Xw5zB/uz6C+x8/EhCQ/QhwPz9Y92MC3q2a48sFEkIOcSFkAJWCqlo4cmEt7K1N5Meu11fR4NMXcCMegPJc5vPeW3nqm664uaVtc694ObiV9vjOhduSOAkhHspuxjgdOHCARo0a0ahRIwBGjRpFo0aNmDhxosaR5d2GDdCnD9xI8uRx/uCPSi9TOWIrFXNImtI90tKFc037AuBCIueHzbBEuMJK2VObyKuku0mENBlFi0/7GpKmcJd6nFm+jwGrHiRNAKmOD66mS7mfZOlQhRA2xm56nIKCglBKaR1GgW3fDj17QtK/n98dBpSlw7df4mjkO9Xox7HEVP4ST2JpfmoJ18I+oIx/WfMFLKyWvbSJvIqLjONE/V4E3dhgWLaj6kAa7/0C11KuWXeQxMnuLVq0iB07dgBw9OhRw7KQkBAAWrVqxYsvvqhVeFbpxg1wcYFCNMG80eymx8kenF53nOi2T+Fw7w4AzzwDixdjdNIE4OnrxaFmrwDgRDInxi4zR6hCWKWoI5FcrBrIo/8mTYk4sa3fF7QMX5J90gSkOj24iEISJ/u0Y8cOli5dytKlSwkNDQVg586dhmXpSZWA68ej2F6+L496n6NiRThyROuIrI8kTlbi5qkbOD/TjW7Ja/mL9jzd5hbffw8ODnkvq8q0B7+cfDd/i0otfL0OovD558h97jZpRe17aV+M0Tov/p63iYDlwx5+pZz0ONm9JUuWoJTK8W/JkiVah2gVDn+2nZQG/rS+sopFvEhMjGLFCq2jsj6SOFmBpLtJXGjWi0rJ5wDwKJrM0pUu5PcKWN+21QjzDASgStI/nPnf36YKVQirdOQItGpfhJnJbwFwyaESN9buxP/1wFz3VU4PEqfUBEmcROGTmpxKyBMfUve1NvikXgWgLsepzHnCwzUOzgpJ4mQFdjV7k0bRIQBE6cvgGbyWYqWLFajMmLZPGR5fWrCuQGUJYc1CQ6FNm7SJX79iGDPKf4bjvt1Uf7KOUfvvaTGaypyjPJe4XrOlmaMVwrrcPnOLA+W7E/THuziSAsBBr7Y05DDnqcKpUxoHaIUkcdLYrjd/JPDoAgDu40LUV2sp91jBp/SvNqq74XGJPesLXJ4Q1ujA5hjatoVb/04n0KwZDD/2Kj6NyxldRrJnSSKozBXKk6iTiQ5F4XHih1Di/RrTNOo3AFLREdJ6Av7X/qRIpTKA3IkiO5I4aShi82nqzXswHmnfgPnUe7GZScqu0KoyZ539ACh75x/io+UUhLAvRz7fQdX2VWgT8wsArVvDn3+Cl1feyslwps5wNasQ9m7XyJVUfq4lFVIiALipK0nolN8J2vYBDs4OLL7RjRPUYsONJhpHan0kcdJIQmwCd7v1wYO0K+h2+van9RLTXg67rv1nNOYgPkSy+4Dc+V3Yj6MLd1P11c6U4Dar6MPIxjv444/8XTotiZMoTFJSYMGgfbSY34+i3AfgqFszEnYf4pHxnQ3bVUo+Sy1OUTVFBjn9lyROGtkT+I7h6p9zTjVpsOtLk98jq8yz7TlEY1JxYOtWkxYthGZOrjhEpZcfN0xseaRkW2ZuakKxfA4L9Ll+lJF8wmhm43ruuAkjFcK6xMZC9+4wYllTPmc4ANtrDKHm5ZAsQ0SS9WnTdDin38xRGNjNBJi2ZPOGJAg7BqSNa0r8/kfcy5l+lrFWrR483r/f5MULYXFnfjtBqWc74kkMAKHF21Hv9FqKeBXJd5kVInbyLG8AsCO8FFDXBJEKYV3Cw9OSphMn0p6P0n9ClYFBdP6mV7Y/2lP0aV2xTkg37H9J4mRh0dEweKgTl9nESD7lyWdcaNu7oVnqqlgRSpVKmwE2NBSUAp3c+F3YqIgtZyjWvR2l1A0Ajri3xO/kugIlTQA65wzTESTKl4SwP6GzNjF7yl1OxKddNFS8OPz0kxPt2vXOcZ8Uh7R24UAqKYkpODjnY1JBOyWJk4WNHAmXLgHoOdbuDeauMl9dOh30q7oXzxt/0uj6ISJDP6NsE+OvNhLCWlzZexGHju0Mc8ycKNoY32PrCzxtB4DO5UHipCRxEnZm28CvafHdcBZShKPsRtWtz7p1UK3aw/dL0T+YUT/pbpIkThnIGCcLWrNa8d13aY89PdNup6I38zvQU/cLU5hIT37hwrpQ81YmhBncOHGd+wEdDFf/hLvUpfShjXhW8jRJ+foMPU5I4iTsRGpyKiHNxhDw3Us4koIb8cyq/CW7d+eeNAGkOjxoF4lxMs4pI0mcLOTGietU7teM1mwDYP78tFNp5ub8WCPD43u7D5u/QiFMKD4epvY4QIXEswCcd6qOx55NlPQrZbI6pMdJ2Jt7t+6xt0pfgvbOMiwLaTKKTqc+NfrK04yJU/I9aRcZSeJkIaeeeJMmyfsIIYiPm3zPc89Zpt5SrWsbHjuelSlghe1ISoLeveGTfx7nCX4n3LEWjsF/Uca/rEnrydTjJPMRCBt348R1Tvu2o/mlnwBIQc/WPgsIOjAnT6fbUhwenKqTxCkzSZwsYP8Hf9Dy/A8AxOi8eHZJB4sN0q7Ytobhsdc1SZyEbVAKXnoJfv897fkBz/bc33+MCi19TV6X3kUSJ2Efzv5+kvgGzagftxuAOIoROulXAle+kueyVIabXyfFy6m6jGRwuJnduXKHsh8MMzw/PmQureqVsVj9RUsU5ZJDJSqkXKDC3X9Qqcrk80UJYWqfv3CQJUvSZix2doZ166C+v3kGp0riJOxB2CdbqfxmD7xUNABX9eWIXb6eR/v456u8ndUGsupSCxJx5q2iXiaL0x5Ij5OZhT4xngopF9IeF29Hy4WDLB7DNc+0W694qWhunJAbDwnrtrXXZ7y6+BHGMwUdih9+gMBA89XnUEQSJ2HbfvgBxo++h5tKuxPFqSINYc9e/PKZNAEcq9yVT3iDL3iFxCIeJorUPkjiZEbHFu2h9eH5ANylKCVXf6VJb09ceT/D4yvBcrpOWK/do1fTevVIAKYwkTWvhfDMM2au1MOdU9TkGHWJdfE2c2VCmI5S8NFH8NxzsD6lM6+ygP3ej1PuzHbKPlqhQGU7PxjiRKKcqctEEiczSYxLxGXEi+hRAOzr8gG+bY24BtQcqlc3PLxz5Jw2MQiRi6Nf7aLR3OcMbSakxTie+rSN2etNrNeEWpyiPsfY7D/a7PUJYQqpKYpRo+Cddx4s0w97mUaXfjPJnSjkHo45kzFOZrLrmbkEJaTd9+pE0ca0Wv2GZrEUqVnJ8Dj57AXN4hAiJxFbzlB2eHeKkADA9uqDCdw+1SJ1O2QYOpWaapEqhSiQhNgEDtYbBBcfA94EYOpUGDcOdDrT9Ie4q1gqEo0ziSTfKQ8UNUm59kASJzO4eCIO/40zgbRLQfn6axyLaPdf7d6kJhvpSAS+JDg2IkizSITI6vaZW6Q83sVwK5XQ4u1odnihxU5rZ7zCVRInYe1iL8VyusFTtLi9hRasIkrnQ7tF/RgyxLT1dD4wlZl8BMDho1shKMC0FdiwAn2bBwcHs3nzZnbu3MmlS5e4ceMGrq6ueHt7U79+fQIDA+natSs+Pj6mitcmvP6eG6fYyee8gmrQkKBnG2saT+k2danLRgA6KnhN02jsn7QL4yXGJRLRpCf+iWlj784416baodU4uTrlsqfpZJy9XymLVWtX5Ji3jGthV4lu/jiN76dNZnyXorwxwZ1HTZw0ASinB4OcUu7JIKdMVB7FxcWp6dOnqypVqii9Xq90Op3S6XSqaNGiqnz58qpEiRLKwcHBsNzZ2Vk9/fTTaseOHXmtyqJiYmIUoGJiYgpUzu+/K5X28atUmdKp6nbkfRNFmH+pqUq5uqbFVKuW1tFYjqneU2NIu8i71JRUtb3aQEODua7zVhe2njV5Pbn5e/1Z9Qed1EY6qFXNP7Z4/ZZmqvfUXo/53FjycyWjM7+fVBccKxvay01dCXX0691mqy846H1DXfsm/262eqxFXt7XPCVOX3zxhfLx8VE6nU41bNhQTZs2TW3ZskXFxsZm2i41NVWdOnVKLVu2TD333HPK3d1d6fV69dRTT6mzZy3/wWgMUzSGe/eUqlbtQeK0bJkJAyygWrXSYnJ1TUukCgNLfcBJu8ifT966oK7hrRSouxRRxxaZ70vgYU6tOWpotNv8XtQkBksyxXtqz8d8brRInI4u2qNu6EoajtOLDr7q7O8nzFpncIdphvr2jFtn1rqsgdkSJ0dHRzVgwAB19OjRPAV09+5d9fXXX6uqVauqyZMn52lfSzFFY/h2yHblzH0FSgUEWFeC0rHjv4kTcer61SStw7EIS33ASbvIu+XL047HKpxRx6mtdo36yaTl50X4uuMPEqeaQzSLw1JM8Z7a8zGfG0snTvsm/abicDUcoyeLNFRXD142e73Bj88y1Ln77TVmr09rZkucTp06le+glFIqOTnZan9lFLQxRASfUXcpok5SU3XUb1J5/Dwxu7WN3lfXSfvFcnJVmNbhWISlPuCkXeTN9u1KOTs/6Jn9aFqCycrOj9P/+9sQzPbqgzWNxRJM8Z7a8zGfG0smTsEvr1BJOBiOz1CvNio6Itrs9SqlVHDX2YZ6tfxhYyl5eV/zdN1izZo1CzSeysHBgSpVqhSoDGukUhWRfUZSlPv48Q9jG2+kXj2to8rMs1gypbgJwJ3wSI2jsS/SLox3bm8UT3VPNUyoN3QojB7r/PCdzEznIKPD80qOefP78EMY/lVDYkmbtXtXxd7UifgDz0qelgkgQ7tQySmWqdNGFGjCh82bN5sqDpu2b8L/aBq1Hki7P1CTdRM1jigrXdkHV7PcPy+JkzlJu8heTEQ0KiCABbf6UoR7dOgACxZgsRte50TvmDFxkvkI8kOOedNRCsaMgXffhZPUpiu/sbnxWzQ7uwIXDxfLBaKXCc5yUqDEqWvXrvz000+misUm3Y++T9kP3zA8P/faxyaZtdXUnH0fJE7JF69qGIn9k3aRVfL9ZMKb9KFq4il68xMrPIfz00+ZZyfWSsYeJ518QeSLHPOmkZKYwvChycya9WBZ12ktaHvgo8wJvgXopMcpRwV6J/z8/OjXrx+fffZZjttER0fz7rvvFqQaq7a77zwqJafdxiS0eFuaz+2lcUTZc6te1vBYd016nMxJ2kVWO5u/xSM3/wTghq4UTX6dhKeFzjjkJvOpOkmc8kOO+YJLiE1gX7V+PPbNUHSkotPBF1+kzwauQUAZptRXKdIuMinIYKrY2FjVtm1bpdfr1fjx4zOtu3fvnpo5c6YqXry40uv1BanGIvIz4O9q6BV1h2JKgUpGr06tPmLGCAsmIviMYaDfzop9tA7HIrSab6Wwt4v/2jrga8Oxl4CTCvt0qwkjLLgL288XqrZhjnZhT8d8bszx/3fn6h11oEQHw3H4ke5ttXKlyYrPl2/n3FJ+nFDV+Ud9/7llP0O1YLar6rKTmJio+vXrp3Q6nRo6dKhKSEhQCxcuVOXLl1c6nU6VLFlSffjhhwWtxuzy0xi2VRtsONC31h1uxugKLv56vCHWQ54BWodjEVolTkoV7naRUdinW1UCTg8u9x/4tYkjLLhLuyIeXD1UoZfW4ZidudqFvRzzuTH1/9+t0zfVEbdmhmMwnqJq/5Q/TFJ2QSxc+ODK12++0Toa87No4pRu9OjRSq/XK09PT6XX65WXl5eaPHlylgnRrFVeG8PxJfsMR9VtnZe6cfK6mSMsuGg8lAJ11qmm1qFYhJaJU7rC1i4yurD1rLquK2VoJyH+r5s+QBO4dOy2+pjX1RzeVJ8+ulTrcMzO3O3C1o/53Jjy/+/qwcvqH5e6mb5LDn9uHTOrL1r0IHFauFDraMwvL++rSe48u23bNvbv349SitjYWHx8fDh06BBlypQxRfFWRyn43wehVMcJZ5I43ON9Av1KaR1Wrm45+eCZFEvJJBkcbgmFrV1kdOfKHe53fJKK/96490DJjrTcPVvjqLKnK+7Fm8wDoGdFuZdjQRTmYz6vIjafRt+5AzWSzwMQpS9D9Ko/afBMA20D+5eDXFSXowINDt+7dy8dOnSgTZs27Ny5k4EDBzJ69GgiIyN57rnniIuLM1WcVmXFChhz9mXqcpzlxV+hxfevaB2SUWKLpn14eXCH+7fvaRyN/Sqs7SJdSgoEt5pAjYRjAJxzqkmNg6twLGKS32kml/Emv/IFkT+F/ZjPq39+OkzRjq2o+G/SdMGxCvc27aSmlSRNAJ5R4QxlIcP4Aq9Lx7QOx7oUpGsr/eaNXbt2zTT1/vz585WDg4Nq3LixioyMLEgVFmNsN11cnFLlyz/owtywwUIBmsD7rf9SXflVNWWPunDW/m+7otWpusLYLjIaM0Ypd2LU/+iibuu81NkNBZtl2tyuXXvQnp98UutozM8c7cKejvncFHjc36L9KhpPw0H3j0tdi9xCJa92DPvuwWn2Z+ZrHY7ZWWyMU/PmzdW2bduyXbdq1Srl4uKiqlWrpsLDwwtSjUUY+582YcKDD9kuXSwUnIkMG/Yg9gMHtI7G/LRKnApju0j33YPPWuWkT1Y7Fpn3RqSmcP16esypqluXFK3DMTtztAt7OuZzU5D/v99/V6p8kRvqGHWUAnXErZm6dfqmGaIsuJ0jlj9InHp+onU4ZmexMU67du3KcV3v3r0pWbIkTz31FC1btuTatWsFqcoqXNp1Ad2M7yjCKJIdizJ3rtYR5U3p0g8eR0VpF4e9K2ztIt3evfDiiw+ez5nnQMsXamkXkJEcom+iSBujuH/fE8B6bQOyQYX1mM+LFStg4EBITi5JR/7km/ITaX3wE4qVcdM6tOxlOIct8zhlZtapSNu1a0dISAh6vWVnPDWXC33fYXLyeE5Qm1l9D1HA2zVZXMbE6fp17eIo7OytXQBc3X+J6MAnKZlwGYCXXoIRIzQOykiZb7ki96ozB3s85vPiq/mJPPssJCenPW/ZqzxtznxjvUkT/5kYNkVmDs/I7Edx48aN2blzp7mrMbvDn22nxcVVABTT3eWFqbZ3g8pyxWJozTaeZjXqUJjW4RRq9tIuAO7euEt0YHc6JfyP/TzK802OMH++9vegM1qGL3OdzBxuNvZ0zBtLpSpCOkyjwchAiqp4IO3G1itWgIsFbzuXHzpHuawuJxa5zKVq1aqWqMZsUhJTcH7ndcPzk89OpbWvl3YB5VOV6ENsow0AITvfBvw1jaews/V2AWlfDGGNnqfFvVAAkh2L8NEP5XB21jiwPMjY4ySJk3nZwzFvrNTkVLY99hZBoR8D8AtPsfWd35k609EmflRkuledJE6ZFM5+0zza9dISat87BMCpIg1p8c0LGkeUP25VH5yrc7wlg5xEwYW0n0qLSz8CcAc3Elf/j5I2MKdZRpI4FR779+/niSeewMvLi2LFitGsWTN+/PFHk9eTfD+ZnbVeMCRNAM5dOjJtlm0kTfCfm1/LqbpMrHNiFSsSeymWWsvGGZ7fm/kJDs4OD9nDennV8DY8domVxEkUzO6319AmeCIAqeg4MWE5TbvX1TiqvJPEqXAIDg6mU6dOFClShL59++Lu7s6aNWvo06cPFy9eZPTo0Sap5370fcJq96N15FoAUtCzc+BCgpba1g9uOVWXM7vqcVqwYAGVK1emSJEiPPbYY+zbt6/AZYb2nIq3Sksydpd/Bv/XAwtcplaKVytByr9vebF4GR1eWJijXZxccYgGswcanm97fCZNP+hW4HK1IImT/UtOTmbo0KHo9Xq2bdvGwoULmTNnDocPH6ZmzZqMGzeOiIiIAtcTe/kOJ6o8QbN/k6YEnNn31k8E2FjSBMhVdQ9h1sRp27Zt7Nq1i1QLZKurVq1i1KhRTJo0idDQUBo2bEinTp2IKsB19+c3hdNi/zwA7uNCxZUfmShabTg4O3BLl3YaxSPBvnqcbOliKFtvF1FHInEf0J1i3AVgR9UBBP72tqlCtjh7Tpys5QyLJY/57GzZsoUzZ87Qv39//P39Dcs9PT0ZN24ciYmJLF26tEB13Dh5g4s129IoOhiAOIpxfNZ6mn/Us0DlasbVlQgqcY7K3Hf20DoakypwuzDnhFI6nU7p9XpVtWpV9eWXX6qEhASz1dW0aVP16quvGp6npKSocuXKqRkzZhi1f3aTX+0p86RhArDglu+ZPGYtpN9Q8i5FVGpKqtbhmEzfvkq9/bZS0dEPllnDTX6zY8vt4l70fXXErbmhXRxxa6bu3b5nltgtJTkh2fB6Dru31Dock0m4n6oCA5WaM0ep1AxNXYt2YcljPjtjx45VgFqxYkWWdVevXlWAatu2rVFlZff/dyn0mjrtXMtwHN3UlVBHF+0xWfxa2LTpwWS279nH159SSqnLZ++rhg2V+vXXzMvz0i7M2uMUEBBAq1atiImJYfjw4VSuXNks9SQmJnLw4EHat29vWKbX62nfvj27d+/Odp+EhARiY2Mz/WX054ZUfr/WmLsU5aq+HI+sHmOW2C0trmjaAPGi3Cc+Kl7jaEwjJARWroSPPoKAAOvvfbLVdqEUDBvhyMa4FgBccahAmZ2/UMSriFnitxR77HFSqYrd/sN4bOssRo9WvPuutvFY6pjPSXh4OAA1atTIss7Hxwc3NzfDNv+V23fF5cvQ+sniHE9MK/uqvhy3ftlGvRceM/GrsCx7vIdjxJYzJNSsR/XDq+nVC7ZuzV85Zh0cHhISYnh87NgxduzYYZZ6bty4QUpKSpY7cJcpU4aTJ09mu8+MGTOYPHlyjmWGn9Ez03kSixOfZ9HY83T0sd6JyvLinntpiE57fOtkFG42/rpSUuDNNx88f/11658/yFbbhVJQrqIDbzObcOd6vLm4AbUa+Jg8bkvT6XU8zu+koqeCrxffaB2QCWzr/RmBJxcSCNRyCKder0WaxmOpYz4nMTExQNqpuex4eHgYtvmv3L4rfHzgkeZO9PlpFd+5v0qz3ydSvVXlAsesNQc7Gxv+z+ojePbpRJnUSJbTn+eLl6Bixbb5KqtAPU6nTp1CGfnzvl69egwbNqwg1ZnU2LFjiYmJMfxdvHgx0/pXX4UTJ+DZMZVo/0GARlGaXpLXgyvr7pyx/XFOS5ZAWFja40aNYNAgLaNJY6/tQq+H6dPh+++h4/LB1OrfWMNITetP/eP8SSeOutp2LwHAwQ8303LNg18TNV9uy6OPmrdOWz7mc5Pbd4WDA3z3Hbw0siit/vmWCnaQNEHmHidrGSuXX0cX7qZ070DKpEYCEOFSkznra5HfacUKlDjVqVOHadOmFaQIkyhVqhQODg5Z7oF07do1fHyy/0Xs4uKCh4dHpr//qloVZszIfADZOuVdmmQciKQMMZH3tA6nQGKvxDFz7INfifPmZf6VpBV7bxfPPgtPP22WkDWT3ktp67+sz2+/SNUxvXAk7ZsupNkYWi7ob/Z6reWYz0l6T1NOvUqxsbE59kYZ0yZcXOCTT9J6n+xFsUunWENPfqEHjxy23X7YgzM3UfXl9nipaACOFWtKyaNb8WlcLt9lFiglUErlepXE9u3bWbVqVUGqyZWzszNNmjRh8+bNhmWpqals3ryZ5s2bm7VuWxPe812cSaQskZzwaaN1OAUS+vQ0dl6vwUt8Re+nUwiwko5BaRe2J/3HkbWPj3uY2Fjo+lI5FqqhAOwr3ZXWW6dapG5rOeZzkj62KbtxTJGRkcTFxWU7/qkwc46//W/atA6fG8e0Didfdr+9hvpjuxiuAA4t3pbK4X9RokbJApWb58Rp9+7d3LtnfE/Fli1b6N/f/L94Ro0axddff83SpUs5ceIEw4cPJz4+nueff97sdduSkmWdUf++7bZ8o9+L287RfM9cSnOdTxnJ7Ncv5r6TGUm7sG3t2ExHNlI/1jbvpZaSAv36wfGTDoxhFiPLr6HWwR/MOlmvtR7z2QkMTJt/788//8yybuPGjZm2EWls/Sa/25//lqaze+NMEgB7y/ag7rn1uJV1L3DZeR4c3rJlSxwcHKhRowY6nY69e/eyYcMG/P39s+3+T0hIwNHR/BOU9+nTh+vXrzNx4kQiIyPx9/dnw4YNWQbGFnalH9x1hQJM5aO5S/3fpiKJAOxuNoqg1pU1jUfahW1bk9QNV+5x6lID4LDW4eTZmDHw++9pj0uUgJEhPfGoYN46rfWYz067du2oWrUqy5cvZ+TIkYa5nGJiYpg+fTrOzs4MHDjw4YUUMnqnDEm3jV1tuuK1XfRb8mDS0e3VB9P86Nc4FjHN8ZfnUsaOHUtoaCihoWk39fzjjz/YsGEDAKVLl8bf359GjRrh7+9P8eLF+fnnn6lYsaJJgs3NiBEjGDFihEXqslX2kDiFfbKV5pfXABClL0Pjn8ZqHJG0C1uX+m8vrN7GviAAtg5fybYvqwCP4egIq1dD9ermr9eaj/n/cnR0ZNGiRXTq1ImAgIBMt1yJiIhg9uzZFp8iwdpluledjQz+UwomTIBpnzXnOq8xkvlsbfQGrffNyTTtiAkqyj+dTqf69eunPvroI9W3b19Vq1Yt5eDgYJjsTK/XK51Op2bNmlWQaizCWidLNLVbkQlqNqPUMp5TyyuP1TqcPEtOSFYnizQ0zMy2beDXOW6r1Xsq7cL2xOCuFKhwlzpah5Inhz/foe7jrO7hovrzvfrii9z3Mcd7aivH/N69e1Xnzp2Vh4eHKlq0qGratKlauXJlnsooLG3i5Koww+fs1lovaR1OrlJSlHrllQeTdupIUav6/WL0RM95eV8L1G/1+uuv89hjj9G3b1/Dsrt37xIWFsaRI0e4efMmjRo14oknnihINcKEvLydGMmnOJHMyWv+wHStQ8qTnc8vIuB+2qmUE0Ub0eJr6xurI+3C9qSP+7OlCTAv7Yyg7Ks9cfn3lPVL9XcTOOxZTWKxlWO+adOm/PHHH5rGYCts6VRd0t0kJvQ6yee/1zcs+3S+nt4jepilPp1StnwdiemkX44aExOT7eWm9uSqQ3nKpl7hqr4cZVMuax2O0aLP3SalWg1KqpsAHFmwnQavtMpx+8L0nppLYfk/vK0vQXF1m3NONamSeErrcHIVFxnH5Sot8bt/BIDQ4u2of+kPnFydct23sLyn5lJY/v9O//o31bvXBWB7jSG0/sc6pyS4d+seR2v3onbUVtqyhUMOj7JkCTz3XN7Kycv7akczFAljxTqnTYJZMvU6KtV28ubDT71vSJp2+vZ7aNIkRF6kj3HSYd2/rAFSk1M51niAIWk671SdKvt/NCppEsJYmW5FlGqdV9XFRETzT5WONI1ajztx/MJTrFt1P89JU17lKXHq3Lkz+/fvz1dF8fHxzJw5kwULFuRrf2E6ca5pI8SdSSL2YvYTwlmbE/vjqH14BQB3KUqVVbM0jugBaRe2L9WGTtVtC5pIs6trAYjBk9S1/6N4tRIWjUGOeftn7afqoo5EElkrkIaxabfvuYMbNz7+ni5Pm//emXlKnK5fv06zZs1o06YNixcvznEW1oz27NnDiBEj8PX1ZcqUKXIZtBW47/Hg0rpbJ63/0jql4PX33KjD3yzgFfa0G0+5x7S5Oic70i5sn9L9e1Wdlfc47Xx1OUE702boTkFP+NRVVH2ilsXjkGO+EPD0ZCFD+ZKXOV46f/d0M5eILWe41+TBqerrOm8ufReC/xtBFqk/z2Ocli5dyuTJkzl//jx6vR4/Pz+aNGlCmTJl8PLy4v79+9y6dYtTp05x4MAB7ty5g4ODA3379mXq1KlUqlTJXK+lQArLeWuArY3fJPDQPCD3cULWYN066NEj7bGvb9o9BIsWzX0/S76n0i5sW6RDOXxSr3LJoRIVkiO0Didbxxfvo9qQAIqQAMDWp+YR+PPreS7HVO+pvR7zuSksbeL8eahSJe1x376wYoWm4Ric+vEwxft1onRq2q2kLjn4krT+T6p0qlmgcvP0vubnsr/U1FT122+/qaefflqVLFlS6XS6LH8ODg6qUaNG6oMPPlBXrlzJTzUWVVguMVVKqeCO0w3XbO55Z43W4TzUvXtKVa364BLTn34yfl9Lv6fSLmzXFX05pUBdcqiodSjZunRJqZe9Vqr7OKddHu73otGXWf+XKd9Tezzmc1NY2kRExIPP3d69tY4mTdj8bSoaT0Ng4S511JX9l0xSttmnI9DpdHTp0oUuXboAcOLECS5dusTNmzcpWrQo3t7e1K1bN8ebJgptOZR9cKou4ZJ133dl3fAN3DnbGChNUJB131xW2oXteqzsRS5e1lHeR8clrYP5j7t303pcD0T34QgVmVbqY1oeWIBOr9M6NDnm7Zjeyu64svGHG7R47QnciQPgqFszKoStt/j4PsjHzOHZqV27NrVr1zZFUcICnMt7Gx6nRlrvGKfI0Ct0WfIMnXBkku4DXvhkpOEu9rZA2oXtSJ8l2domSFYKhgyBAwfSnl+t3IJ6+1rg7KZtXDmRY95+OGQYG651u1i6FF54oRQD+YRveYH9pTpT5/hqipUupkk8BZqO4NtvvyU0NJTExERTxSMsoEjdavzMU3zJy5x0bax1ODk63WsMbsTjRQxP1zlJgwZaR2QcaRe2J/3XtdZfEP/15bAwVq1Ke+zmBr/+Ct7eD99HC3LM2x+Hm1HcwY27FOWtPc9oFsfcuTB4cFqv12KG8FHA/2h4bp1mSRMUsMfpxRdfRKfT4ejoiJ+fH/7+/pn+SpSwfBeayJ17s7o8zc8A9CkGwzSOJztHv9pFq7PfAXBbV5x6v0zROCLjSbuwPdaYOO18eRnDFw7iJu8xiQ9YvlxP/fq576cFOebtj95BhxvxADimJFi8fpWq+HLQbkZ/38KwbMQIGP1J10ynEbVQoMRp6dKlhIaGcvDgQcLCwjh27Bjff/89un/Pp5QvX95wo8fJkyebJGBRcBl/sVrjjX6T7yfj/MZww/MjT39AYI2SGkaUN9IubM+wmJk4EAVxRYFpWofD4fnbeHThiwCMZxr1X2xGt25dNY4qZ3LM2x8HpwwTYFp4Hqfk+8ns8h/O8FOL2MH3LOdZJk9Ou4GvVQzXMMlwdJV2dcXJkyfVDz/8oAYMGKA8PT0NV1Xo9XpTVWM2heVKCaWUSk1VqkiRtAsT6tbVOpqsQp6aZ7hq4u+ijVRyQnK+yrGG91TahW0461RDKVC3dMW1DkWd+/MfdVNX4sENVusOz/cVdNkx93tq68d8bgpLm4g+f9twDO4v2cli9d67fU/tLtfTUPd9nNXSqRfMXq/FbvKbkU6nw8/PDz8/P/r378+VK1fo3bs3fn5+DB482FTVCBPQ6aB0abhwAeKvxgLWMxfJtbCrNPplguF5yqef4+Ds8JA9rJu0C9uQPgGmTuNbd94Kv4nq0oUS6hYA+0t1psWBT63iCjpjyTFvH9IvmADL9TjFRERzrmEPmsVsBSARJw6OXMrA96xnwmMw473qypUrx+rVq/nll1+Ijo42VzUin768N5BoPDl3y5N7t+5pHY7B6R5v4cEdALb5vUi9F5tpHJFpSbuwTsoK7lWXGJfIhUd7UiUpHIBwl3r4HVqFYxGT/b7VhBzztinjD1adMv98BFf3XyLKrzX+/yZN8bhydPpvtPikr9nrziuzDrHy8fGhY8eOzJ0715zViHzwLJqEJ7EARO6/qHE0aQ7NDaZlxHIAbulKUHfdDI0jMg9pF9YnVeNbrqhUxb6GQ/GP2QZAlL4MRTf/hkcF6+kNLgg55m1PxoRdn5ps1rpOrzuOat6cGgnHALihK8X5b4NpMrajWevNrwIlTgcOHMj18tPSpUsTGhpakGqEGSSW9TU8vn34goaRpElMhIUfxxNJ2v2rjj03i5J+pTSOKn+kXdgere9VF9JxOq3OLgPSbmJ9/Zv/UaGlby57WQ855u2Pk6uT4bFDivmmmTj82XZKPdWKcilpU89GOFYlftNu6j7f1Gx1FlSB+oCbNm2Kk5MTtWvXpnHjxoY/f39/XF1diYqK4rfffsPV1dVU8QoT0VWuBHvTHsef0D5xmjcPvrzUleWcYkqlrxnx7RCtQ8o3aRe2J/1UnRaJ05pvY2ix+TPD88NvfUfzwY9aPI6CkGPe/ugd9STjgCMpOKQmmaWOn5ffp+lr/fAiGoC/XZvgvXc93vWs+wbQBUqcRo0aRVhYGGFhYRw5coQlS5ag0+nQ6XR4e3tz8+ZNkpOTeemll0wVrzCRojUf3GAz5ay2NzWNiIAPPkh7HKf3pNUvb6G34WEd0i5sj1an6oKDof9wT3zYw2905ebjAwj6yIrvK5QDOebtUyLOOHIPx1TT9zjNnw+vv16EpqxmC235u2QAtY6txs3HSqfFz6BAX0+zZ882PL5w4QKHDh3i0KFDhIWFcerUKUqXLk2HDh1k3g4r5NXgQeLkcEW7HieVqhj2MsTHp1019Mor0Nh6JzM3irQL26PFqbqjR9PuQZeYCBfw5avn9zJ/UVGL1W9Kcszbp5eKfk/8PR3u3sVZZqIyU1Nh3DiYNSvt+V6aMavrdsavapDp9KA10yml8fW3ViI2NhZPT09iYmLw8LCPAZkPE3MhBk9fLwAOeQXR6HawJnHsfOUHrn/xE6+yAF358vz9N5jqv7+wvafmUFj+D4+7NaVu/H5S0aG3wKXXlw9F0aJrCS5cSfvt2qULrF0LjhboaS0s76m5FKb/v1Kl4OZNqFYNTp8ueHmJcYl8324xL+4bajg9Pm4cTJ2q/cSWeXlfbfiEiCgIz0qe3NSVpKS6iU9suCYx3DhxnVpfvk5LbtKGYPZOPoaHh3XN1yEKhxPuj3E53osknOiclJpp1mRTiz53m3vN2/BZQlX6spJ6TYuxapVlkiYh8sLZOe1fU9yCMCYimtONezHk1l/c4AxjdB/y2WdpZxlsjcZ3fBFauuzmB0DZ1MvERcZZvP6TXUZRUt0E4HjFznR8QZImoY3P/ObTiT/pynqSUsz3sXg/+j7nG/WgesLfdOM3VroN5bffoJh29ysVIkdO/545Syrg2PBL289x3a8lTW79BcBrzGfDgjM2mTSBJE6FWkyZmobHl4It2+t0YOoGWp37Hki7iW+N3z+1aP1CZOSUYWhFQb8kcpKanMqhegMMczVd13nTYN2UTPeOFMKaNEgNozXbeOTutnyXceybvbgENqN6wt8A3NSVJPzzv+g4vJqpwrQ4SZwKsbMdh9ONX/HjJIdTLXfb9bjIOHzef9nw/NjgOVZ/+amwb+ZOnFSqYnvjkTS/vBqAOIpxfcnv+La13S8PYf/mRfVnG4H8EJu/G0zveWs11V4Mwlul3U3+nFNN4jbtocHwlqYM0+LkrHoh5tG+Kb99nvb4pAkG/hkrtO1bBKSkXckXWrwtrRYNtlzlQmTD3InT1oAJBB1dAEAyDpyY/BOPDnzE9BUJYULJ+rSG4UTeGoVKVWzt+hFBf7xrWBbmGYjvwZ8pXq2ESWPUgvQ4FWK1aj14fOyYZerc/8EfBJz4Cki7F1HJ1Qtt6gamwj69cOItjlGXU9Qk5dJVk5Yd0uUjgnZOMzzf8/JiHp34uEnrEMIcUvRpo8OdMX50eNLdJHbUeSlT0rSj6kDqXPrTLpImkMSpUKtZE4r+O23MoUPmr+9W+E0qTn7B8Pxg/7lyqkJYhVIJl6jL39QknJT4+yYrd9vArwn6/R3D863PzKfVlwNMVr4Q5pTyb4+TA6mkJuc+TcetW9CzSwLup/YbloW0m0LL8CU4uzmbLU5Lk8SpEHNwgM5+5+jHcoadeYuYCzFmre/nfj/hk5r2a35/qc60/k5mERbWQTk8OFeXfM805+pWrUgl9bsfDM9D2k8l8KcRJilbCEtIydAuku4+vF0cPw5Nm8JvIW505TfOUpVdI5YT9Nd4uzurIGOcCrk3kj4igC8ACPulG/6vB5qlnhUrYOjBYfxOaWbqx1Fx4zd215iE7VKOD74gUu4XPHH67Td4bqAeJ35nDU9T9NH6BG4cV+ByhbCkFIcHvUSJcYm4eLhku93/frpP/yFFiPt3VptE7wpcXfk3Ldtmv72tkx6nQk7X5MH9TaI37X/Ilvl3+jS8/O9FdL/Qk7Dvj+PTuJxZ6hIiP1JNmDj973/QsyckJ8M9XFk35FcC98ySHwrC5qTm0hOrUhUh7adSufejEHcHgEaN4MAB7DZpAkmcCr2yPZsbHhc9kP+5OnKSkAB9+sCdtDbFs89C734OJq9HiAIxUeK0+/2NvNbzsuHKvH79YMFCJ0mahE1KfcipuvioeHb79iFo8wTqc4zveY6+vVPZsQMqVfpvSfZFEqdCrlq3OtzQlQLAL2q7UQMA82J783doELoYUNSsCV98YdLihTAJU5yq2ztuHU0md+PP5DaU5Qr9+8OyZWljCYWwRakZTtUl331wZd3ZP05xpVIzWlz6KW07dHh2bMbyFTpcXS0epsVJ4lTI6fQ6TpcNAMBLRRO+5ojJyt496ifaH/qIxQzha4dh/PQTuLubrHghTEY5FSxx2jvmFxrPeAZnkqhJOF/W+ZSlS+X+c8K2ZTyFnX6qbtebP+L9xCPUSEibwyYWdw5M+JWgjWMLTc+qJE6ChBZtDI+vfv2bSco8tSqMBh8PNjyv2bcJDRqYpGghTC9jj1NCcp523f78tzwy6xmcSNtvZ+Vn6XJomiRNwuYta72IYsThRCI3XMqztcFrtJjXB3fSRoGfdqnDjfX7aPpB/mYWt1WSOAmqj3rS8Lj07nUFLu/6sWu4PfskxbgLwI6qA2i9bGiByxXCbDL0OKUmGN/jFPLEh7Re8gIOpJ3i3lF1AM1OLcXBWc7PCdvnU9WVuxSjEhdIahFA4NHPDOt2VB1A2Qv7qPpErYeUYJ8kcRKUb16JE0UbAVDn7gEubjuX77Lu3bpHZPOnKJ9yEYBjxR7jkYMyO7iwbuf9OjKa2YzkE6J9cv8iSE1OJeSRtzLNjrzV/3VanFoiSZOwGzVqpP3bhmAeYx8A93Fh24CFtAxfSrHSxTSMTjuSOAkArgX0Njw+8963+Soj6W4SR2v3pn7cbgCuOFSg9K61FPEqYpIYhTCXqGotmMto5jOS2BKVH7rtnSt32F/xKYIOzjEsC+k4nYCDH6N3lI9UYT/q1k379xteYD1PEOFYjfPLdxOwbGih/jEsrVwAUHvGQE5QizHM4I1/XuF+Hu86kZKYwt56Q2galTZGKhZ3Ypauo3QDHzNEK4RpGXuT33PnYEbTX3gs8lcg7Ya92wYsLFQDY0Xh4e8Po0ZBnTo69gxbSsmLYdTq10jrsDQniZMAoEyjcox/6m9mMYbDUWVZvNj4fRMTYX3DsbQ69z2Q1pV79uNfqf1s41z2FMI6GJM4rVkDTZrAjMsDWMhQonVeHJ7xBwEyfs+qhYWFMW7cODp16oS3tzc6nY6goCCtw7IJOh3MmZN2O5UpX5TCzcdN65CsgiROwmDcew9+Mb//ftoNG3MTGws9esCIkyO4SAWScOTw2FX4vxFkrjCFMLki6h7luIwv59MO6gzuXLnDSy+k8MwzcPs2gI75NT/j1qZQmozpoEW4Ig/Wrl3LjBkzCAkJwcdHesBFwdlF4jRt2jRatGiBq6srXl5eWodjs5o0gWeeSXscFQXzu/+FSlU5bn/sWNpNHf/4Ay5Sia7Omzj0/q88Nr27hSIWDyPtwnh+h1ZymQqcpwq+O9JuzKtSFTtfXU58RT/0335t2LZXL9i+15mq7apoFa7Ig169enHw4EHi4uLYtGmT1uEIO2AXiVNiYiK9evVi+PDhWodi8+bNg5IeSXzKa0za0YHtdV7ifnTmAU+xl2IJbjmePo3+4dSptGWenjB/Uy2aTnrc8kGLbEm7MJ5rjfKGx7qD+9n+/Lecdm1Ay8+fxSf1KtN4j4quN/n2W1i1CiQPtR1169alcePGOGU8HytEAdjFFG2TJ08GYMmSJdoGYgfKl4df39tLs3cXABBwahEXvf/iTMOe4FUc5/Dj1L/wG22IYy776cwGGjbUsWYNVKumcfAiE2kXxivfqR6MS3vcOnwxhGce5He6TCu2/3wf3xYaBCeEsCp2kTjlR0JCAgkJCYbnsf8Z11CYtXinFbsuLafJ/EG4kEjF5PNUPDg3y3ZtCObjoSd4+ZM6FC2qQaDC5ApruyjjX5ZIfVl8Uq9mWn7UrRn3357IYxOlJ7WwKqxtQuTMLk7V5ceMGTPw9PQ0/FWsWFHrkKxKi0/7ErH6AAdKdsqyLhZ3ttUZxpU/j/PGQkma7ElhbRc6vY6rH/3AIa8gjro1J6TJaI4t2kP9O7t5VJKmQq2wtgmRM51SKufRvxoaM2YMs2bNeug2J06coFatB7P8LlmyhDfeeIPo6Ohcy8/uV0TFihWJiYnBw8Mj33Hbo+vHo7jwaxgpdxNwq+5DjV7+OLla/3iB2NhYPD097eo9lXYhCsoW28Xo0aMzHZe5ef3116mRPu11BpGRkZQtW5bAwEBCQkKMKkvaROGQl3ZhtafqRo8ezeDBgx+6TdWqVfNdvouLCy4uLvnevzDxrlsa77odtQ5DIO1CFE5fffUV8fHxRm//zDPPZJs45Ye0CfFfVps4eXt74+3trXUYQlgVaReiMIqLi9M6BCEMrDZxyosLFy5w69YtLly4QEpKCmFhYQBUr14dNzeZ6VQUTtIuhBDC9OwicZo4cSJLly41PG/UKO1eOsHBwUZPrZ8+1EuumLAf6e+llQ7jMztpFyI7hb1dFJS0CfuUl3ZhtYPDLe3SpUtytYSdunjxIhUqVNA6DJsk7cJ+FZZ2cfLkSWbOnAnAvXv3+PHHHylTpgydO3c2bJOXuc6kTdg3Y9qFJE7/Sk1N5cqVK7i7u6PTpd2zLf3qiYsXL9rV1RP2+Lqye01KKe7cuUO5cuXQ6wvtzBsFUljahT2+JpB2ARASEkKbNm0euk1evgazaxNgn8eQPb4mKHi7sItTdaag1+tzzDI9PDzs6qBJZ4+v67+vydPTU8NobF9haxf2+JqgcLeLoKAgk56WfFibAPs8huzxNUH+24X9/9wQQgghhDARSZyEEEIIIYwkidNDuLi4MGnSJLub/MweX5c9viZrZY//1/b4msB+X5c1ssf/a3t8TVDw1yWDw4UQQgghjCQ9TkIIIYQQRpLESQghhBDCSJI4CSGEEEIYSRInIYQQQggjSeJkpGnTptGiRQtcXV3x8vLSOpx8W7BgAZUrV6ZIkSI89thj7Nu3T+uQCmTbtm1069aNcuXKodPpWLt2rdYhFSrSLqyTtAtthYWFMW7cODp16oS3tzc6nc7o+0Nag/379/PEE0/g5eVFsWLFaNasGT/++KPWYRXI999/z8svv8wjjzyCi4sLOp0uT7fayUgSJyMlJibSq1cvhg8frnUo+bZq1SpGjRrFpEmTCA0NpWHDhnTq1ImoqCitQ8u3+Ph4GjZsyIIFC7QOpVCSdmGdpF1oa+3atcyYMYOQkBB8fHy0DidPgoODadmyJTt27KB3794MGzaMyMhI+vTpw5w5c7QOL9/Gjx/PwoULiYiIoGzZsgUrTIk8Wbx4sfL09NQ6jHxp2rSpevXVVw3PU1JSVLly5dSMGTM0jMp0APXLL79oHUahJO3Cekm7sLxjx46pgwcPqsTERHX16lUFqMDAQK3DylVSUpKqVq2acnFxUYcOHTIsj46OVjVr1lTOzs7q/Pnz2gVYAJs2bTLEPmPGDAWoxYsX56ss6XEqJBITEzl48CDt27c3LNPr9bRv357du3drGJkQ2pF2Icyhbt26NG7cGCcnJ61DyZMtW7Zw5swZ+vfvj7+/v2G5p6cn48aNIzExkaVLl2oXYAG0b98eX19fk5QliVMhcePGDVJSUihTpkym5WXKlCEyMlKjqITQlrQLIR4ICQkBoGPHjlnWderUCYCtW7daMiSrVKgTpzFjxqDT6R76d/LkSa3DFMKipF0IUTiFh4cDUKNGjSzrfHx8cHNzM2xTmDlqHYCWRo8ezeDBgx+6TdWqVS0TjJmVKlUKBwcHrl27lmn5tWvXbG7wojAvaRfSLkThFBMTA6SdmsuOh4eHYZvCrFAnTt7e3nh7e2sdhkU4OzvTpEkTNm/eTI8ePQBITU1l8+bNjBgxQtvghFWRdiHtQqT9gEhISDB6+9dffz3bnhphfwp14pQXFy5c4NatW1y4cIGUlBTCwsIAqF69Om5ubtoGZ6RRo0YxaNAgHnnkEZo2bcq8efOIj4/n+eef1zq0fIuLi+P06dOG5+fOnSMsLIwSJUpQqVIlDSMrHKRdWCdpFwX31VdfER8fb/T2zzzzjM0nTuk9TTn1KsXGxlK8eHFLhmSdTHi1n10bNGiQArL8BQcHax1ansyfP19VqlRJOTs7q6ZNm6o9e/ZoHVKBBAcHZ/u+DBo0SOvQCgVpF9ZJ2oX1sKXpCMaOHasAtWLFiizr0l9H27ZtNYjMtAo6HYFOKaUsl6YJIYQQhUdkZCRly5YlMDDQcNWatdq4cSOdO3fm+eef59tvv820bunSpQwePJjJkyczceJEjSI0jZkzZzJ27FgWL16c63jO7BTqq+qEEEIIkaZdu3ZUrVqV5cuXG067Q9qpu+nTp+Ps7MzAgQO1C9BKyBgnIYQQwoROnjzJzJkzAbh3755hWcbejfzeJ82cHB0dWbRoEZ06dSIgIIC+ffvi7u7OmjVriIiIYPbs2VSuXFnrMPNl0aJF7NixA4CjR48alqX3ArZq1YoXX3zRqLLkVJ0QQghhQiEhIbRp0+ah21jzV+++ffuYNGkSu3btIikpifr16zNq1Cj69OmjdWj5Nnjw4IfOej5o0CCjk1lJnIQQQgghjCRjnIQQQgghjCSJkxBCCCGEkSRxEkIIIYQwkiROQgghhBBGksRJCCGEEMJIkjgJIYQQQhhJEichhBBCCCNJ4lRING/eHJ1Ox+7duzMtj42Nxd/fHxcXFzZt2qRRdEJYnrQJIUR+SOJUSMyaNQuA8ePHG5YlJiby1FNPceTIEZYuXUqHDh20Ck8Ii5M2IYTID0mcComAgAC6dOnCli1bCAkJQSnF4MGD2bJlCx9//DF9+/bVOkQhLErahBAiP+SWK4XI0aNH8ff3p0WLFjRt2pS5c+cyduxYpk+frnVoQmhC2oQQIq8kcSpkBg0axLJlywAYMmQI33zzjcYRCaEtaRNCiLyQU3WFjLe3NwDu7u4sWLBA42iE0J60CSEekIsmcieJUyHy2WefMWfOHMqUKcOdO3dYunSp1iEJoSlpE0JkJhdN5E5O1RUSP/74I/369SMwMJAffviB2rVr4+rqyunTp3F1ddU6PCEsTtqEENnr2rUr69evJzg4mMDAQJ599llWrFjBvHnzeP3117UOT3PS41QIbN68mQEDBlC/fn3Wrl1L2bJlefPNN7l69SqffPKJ1uEJYXHSJoTI2YwZM9Dr9UyYMIG33nqLFStWMHbsWEma/iU9TnYuNDSUoKAgSpYsya5duyhbtiyQdr66SpUqpKSkcPbsWUqUKKFxpEJYhrQJIXInF03kTHqc7NiZM2d44okncHZ2ZsOGDYYvCAAPDw/effddYmJimDFjhoZRCmE50iaEMI5cNJEz6XESQgghhMFnn33Ga6+9RpkyZbh27RpffvklL7/8stZhWQ1JnIQQQggByEUTxpBTdUIIIYSQiyaMJD1OQgghRCEnF00YT3qchBBCiEJMLprIG+lxEkIIIYQwkvQ4CSGEEEIYSRInIYQQQggjSeIkhBBCCGEkSZyEEEIIIYwkiZMQQgghhJEkcRJCCCGEMJIkTkIIIYQQRpLESQghhBDCSJI4CSGEEEIYSRInIYQQQggjSeIkhBBCCGEkSZyEEEIIIYwkiZMQQgghhJH+D+EbekeYorEgAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 600x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# True and model solutions\n",
    "u_true_test = u_exact\n",
    "u_model_test = u_swim\n",
    "\n",
    "# Relative l-2 error\n",
    "error_u = np.linalg.norm(u_true-u_model_test.flatten()[:,None]  ,2)/np.linalg.norm(u_true,2)\n",
    "print('Relative L2 error on the entire spatio-temporal domain: %e' % (error_u))\n",
    "\n",
    "# visualize the solution\n",
    "fontsize = 14\n",
    "fig, ax = plt.subplots(1, 3, figsize=(6, 3), constrained_layout=True)\n",
    "extent = [0 , 1, np.min(x_space), np.max(x_space)]\n",
    "aspect = 0.3\n",
    "sol_img1 = ax[0].imshow(u_true_test.T, extent=extent, origin='lower', aspect=aspect)#, vmin=vlim[0], vmax=vlim[1]\n",
    "sol_img2 = ax[1].imshow(u_model_test.T, extent=extent, origin='lower', aspect=aspect)#, vmin=vlim[0], vmax=vlim[1]\n",
    "error_img = ax[2].imshow(abs(u_model_test - u_true_test).T,  extent=extent, origin='lower', aspect=aspect)\n",
    "\n",
    "ax[0].set_xlabel('t', fontsize = fontsize)\n",
    "ax[1].set_xlabel('t', fontsize = fontsize)\n",
    "ax[2].set_xlabel('t', fontsize = fontsize)\n",
    "ax[0].set_ylabel('x', fontsize = fontsize)\n",
    "\n",
    "ax[0].axvline(x=0.25, color='k', linestyle='--', linewidth=2)\n",
    "ax[0].axvline(x=0.5, color='k', linestyle='--', linewidth=2)\n",
    "ax[0].axvline(x=0.75, color='k', linestyle='--', linewidth=2)\n",
    "\n",
    "ax[1].axvline(x=0.33, color='gray', linestyle='dotted', linewidth=3)\n",
    "ax[1].axvline(x=0.66, color='gray', linestyle='dotted', linewidth=3)\n",
    "\n",
    "cbar_true = fig.colorbar(sol_img1, ax=ax[0], location='bottom')\n",
    "cbar_swim = fig.colorbar(sol_img2, ax=ax[1], location='bottom')\n",
    "cbar_err = fig.colorbar(error_img, ax=ax[2], location='bottom', format='%.0e', fraction=0.046)\n",
    "\n",
    "tick_locator_err = ticker.MaxNLocator(nbins=2)\n",
    "cbar_err.locator = tick_locator_err\n",
    "cbar_err.update_ticks()\n",
    "\n",
    "tick_locator_swim = ticker.MaxNLocator(nbins=2)\n",
    "cbar_swim.locator = tick_locator_swim\n",
    "cbar_swim.update_ticks()\n",
    "\n",
    "tick_locator_true = ticker.MaxNLocator(nbins=2)\n",
    "cbar_true.locator = tick_locator_true\n",
    "cbar_true.update_ticks()\n",
    "ax[0].set_title('Ground truth')\n",
    "ax[1].set_title('SWIM-ODE')\n",
    "ax[2].set_title('Absolute error')\n",
    "fig.savefig(\"burgers_1.pdf\")\n",
    "\n",
    "fig, ax = plt.subplots(1, 3, figsize=(6,3), constrained_layout=True)\n",
    "plt.tick_params(axis='both', labelsize=fontsize)\n",
    "ax[0].plot(x_eval,u_exact[25,:], 'b-', linewidth = 2, label = 'Ground truth')       \n",
    "ax[0].plot(x_eval,u_model_test[25,:], 'r--', linewidth = 2, label = 'SWIM-ODE (resampling)')\n",
    "ax[0].set_xlabel('$x$', fontsize = fontsize)\n",
    "ax[0].set_ylabel('$u(t,x)$', fontsize = fontsize)    \n",
    "ax[0].set_title('$t = 0.25$', fontsize = fontsize)\n",
    "ax[0].axis('square')\n",
    "ax[0].set_xlim([-1.1,1.1])\n",
    "ax[0].set_ylim([-1.1,1.1])\n",
    "plt.tick_params(axis='both', labelsize=fontsize)\n",
    " \n",
    "ax[1].plot(x_eval,u_exact[50,:], 'b-', linewidth = 2, label = 'Ground truth')       \n",
    "ax[1].plot(x_eval,u_model_test[50,:], 'r--', linewidth = 2, label = 'SWIM-ODE (resampling)')\n",
    "ax[1].set_xlabel('$x$', fontsize = fontsize)\n",
    "ax[1].set_ylabel('$u(t,x)$', fontsize = fontsize)\n",
    "ax[1].axis('square')\n",
    "ax[1].set_xlim([-1.1,1.1])\n",
    "ax[1].set_ylim([-1.1,1.1])\n",
    "ax[1].set_title('$t = 0.50$', fontsize = fontsize)\n",
    "    \n",
    "ax[2].plot(x_eval,u_exact[75,:], 'b-', linewidth = 2, label = 'Ground truth')       \n",
    "ax[2].plot(x_eval,u_model_test[75,:], 'r--', linewidth = 2, label = 'SWIM-ODE (resampling)')\n",
    "ax[2].set_xlabel('$x$', fontsize = 14)\n",
    "ax[2].set_ylabel('$u(t,x)$', fontsize = fontsize)\n",
    "ax[2].axis('square')\n",
    "ax[2].set_xlim([-1.1,1.1])\n",
    "ax[2].set_ylim([-1.1,1.1])    \n",
    "ax[2].set_title('$t = 0.75$', fontsize = fontsize)\n",
    "\n",
    "# Create a single legend for all plots\n",
    "fig.legend(*ax[1].get_legend_handles_labels(),loc='upper center', ncol=2, fontsize = fontsize, frameon=False)\n",
    "fig.tight_layout()\n",
    "fig.savefig(\"burgers_2.pdf\", bbox_inches='tight')\n",
    "    "
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
