{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "7c774498-28ec-44f5-8982-28b28c033c88",
   "metadata": {},
   "source": [
    "# Introduction\n",
    "In this notebook, we show an implementation of the Adjoint method used for the PDE discovery task. This code is used to produce the results in the manuscript titled 'Data-Driven Discovery of PDEs via the Adjoint Method' submitted to ICLR 2025."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "id": "5a5b2ce2-2765-45f9-a86f-7f1e9442f0e7",
   "metadata": {},
   "outputs": [],
   "source": [
    "## Load necessary libraries\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import scipy.integrate as integrate\n",
    "import time\n",
    "size = 6\n",
    "cm = 0.393701"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3d9b204f-d864-42eb-9a3b-e4fa9866f31f",
   "metadata": {},
   "source": [
    "In order to execute cells with PDE-FIND method, please download/clone the PDE-FIND source code from\n",
    "\n",
    "https://github.com/snagcliffs/PDE-FIND\n",
    "\n",
    "in the directory that you are exectuing this jupyter notebook."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "32066b2e-3e7f-46cc-9731-c41c626668e9",
   "metadata": {},
   "source": [
    "# Implementation of adjoint optimization\n",
    "\n",
    "Here, we deploy finite difference to solve the PDE\n",
    "\n",
    "\\begin{flalign}\n",
    "     \\mathcal{L}_i[ \\boldsymbol f]:= \\partial_t f_i + \\sum_{\\boldsymbol d, \\boldsymbol p} \\alpha_{i, \\boldsymbol d,\\boldsymbol p}\n",
    "     \\nabla^{(\\boldsymbol d)}_{{\\boldsymbol x}} [ \\boldsymbol f^{\\boldsymbol p} ]=0\n",
    "\\end{flalign}\n",
    "\n",
    "in $\\texttt{forward\\_m}$ and the adjoint equation\n",
    "\\begin{flalign}\n",
    "    \\frac{\\partial \\lambda_i}{\\partial t} = \\sum_{\\boldsymbol d, \\boldsymbol p} (-1)^{|\\boldsymbol d|} \\alpha_{i, \\boldsymbol d,\\boldsymbol p} \\nabla_{f_i} [\\boldsymbol f^{\\boldsymbol p}]\n",
    "\\nabla^{(\\boldsymbol d)}_{{\\boldsymbol x}}[\\lambda_i]\n",
    "\\end{flalign}\n",
    "\n",
    "in $\\texttt{adjoint\\_eq}$. The training is done in $\\texttt{AdjointFindPDE}$ where once $\\boldsymbol f$ and $\\boldsymbol \\lambda$ are computed, then design paramters $\\alpha$ are updated using the gradient of the objective function with respect to parameters\n",
    "\\begin{flalign}\n",
    "    \\frac{\\partial \\mathcal{C}}{\\partial \\alpha_{i, \\boldsymbol d, \\boldsymbol p}} = (-1)^{|\\boldsymbol d|} \\frac{1}{\\Delta \\boldsymbol x \\Delta t} \\int  \\boldsymbol f^{\\boldsymbol p}\\, \\nabla^{(\\boldsymbol d)}_{{\\boldsymbol x}}[\\lambda_i] d\\boldsymbol x dt + 2 \\epsilon_0 \\alpha_{i, \\boldsymbol d, \\boldsymbol p}~.\n",
    "\\end{flalign}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "id": "0cc0bf60-b586-4c27-a088-37bf330b64c7",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Forward model with an expansion of all possible terms\n",
    "def forward_m(params, ps, ds, f0, dx, dt, Nt):\n",
    "    ## Inputs:\n",
    "    #  params (numPDE, len(ds), P)\n",
    "    #  ps is a list of powers for f\n",
    "    #  e.g. [(0,0), (1,0), (2,1)] is 1, f_0, f_0^2*f_1\n",
    "    #  ds is a list of derivative index tuples.\n",
    "    #  e.g. [(0,0), (1,0), (2,0)] for f, df/dx0, d^2f/dx0^2\n",
    "    #  f0 (numPDE, Nx1, Nx2, ...)\n",
    "    #  dx (dx0, dx1, ...)\n",
    "    ## Output:\n",
    "    #  f (numPDE, Nt, Nx1, Nx2, ...)\n",
    "    numPDE = f0.shape[0]\n",
    "    grid_shape = f0[0,:].shape\n",
    "    f = np.zeros( (numPDE,) + (Nt,) + grid_shape )\n",
    "    f[:,0,:] = f0\n",
    "    for i in range(Nt-1):\n",
    "        f[:,i+1,:] = f[:,i,:]\n",
    "        for i_pde in range(numPDE):\n",
    "            for i_p, p in enumerate(ps):\n",
    "                for i_d, d in enumerate(ds): ## for each d of ds, compute nabla^{d} [f^p] contribution\n",
    "                    temp = np.ones_like(f[0, i, :])\n",
    "                    for i_pi, pi in enumerate(p):\n",
    "                        temp *= f[i_pi, i, :] ** pi\n",
    "                    for i_di, di in enumerate(d): ## for each element di of d=(d0,d1,...)\n",
    "                        for _ in range(1, di+1): ## take di derivatives\n",
    "                            temp = np.gradient(temp, axis=i_di)/dx[i_di]\n",
    "                    # multiply to its parameter, then add to the whole expression\n",
    "                    f[i_pde, i+1,:] -= params[i_pde, i_d, i_p] * temp * dt\n",
    "    return f\n",
    "\n",
    "# Adjoint equation for the Lagarange multiplier\n",
    "def adjoint_eq(params, P, ds, fs, f, dx, dt, Nt):\n",
    "    ## Inputs:\n",
    "    #  params (numPDE, len(ds), P)\n",
    "    #  ps is a list of powers for f\n",
    "    #  e.g. [(0,0), (1,0), (2,1)] is 1, f_0, f_0^2*f_1\n",
    "    #  ds is a list of derivative index tuples.\n",
    "    #  e.g. [(0,0), (1,0), (2,0)] for f, df/dx1, d^2f/dx^2\n",
    "    #  fs (numPDE, Nx1, Nx2, ...)\n",
    "    #  f (numPDE, Nt, Nx1, Nx2, ...)\n",
    "    #  dx (dx0, dx1, ...)\n",
    "    ## Output:\n",
    "    #  lam (numPDE, Nt, Nx0, Nx1, ...)\n",
    "    numPDE = f.shape[0]\n",
    "    lam = np.zeros(f.shape)\n",
    "    lam[:, -1, :] = 2 * (fs[:, :] - f[:, -1, :])\n",
    "    for i in range(Nt - 1, 0, -1):\n",
    "        lam[:, i-1, :] = lam[:, i, :] #+ 1e-10*f[:, i,:] * dt  #+ 2 * (fs[:, i, :] - f[:, i,:]) * dt\n",
    "        for i_pde in range(numPDE):\n",
    "            for i_d, d in enumerate(ds):## for each d of ds, compute nabla^{d}[lambda] contribution\n",
    "                temp = lam[i_pde, i, :]\n",
    "                for i_di, di in enumerate(d): ## for each element di of d=(d0,d1,...)\n",
    "                    for _ in range(1, di+1):\n",
    "                        temp = np.gradient(temp, axis=i_di)/dx[i_di]\n",
    "                temp *= (-1)**(sum(d))\n",
    "                for i_p, p in enumerate(ps):\n",
    "                    tempf = np.ones_like(f[0, i, :])\n",
    "                    for i_pi, pi in enumerate(p):\n",
    "                        if i_pi != i_pde:\n",
    "                            tempf *= f[i_pi, i, :] ** pi\n",
    "                        else:\n",
    "                            if pi>0: # take derivative if f_i has power > 0\n",
    "                                tempf *= pi *  f[i_pi, i, :] ** (pi-1)\n",
    "                            else:\n",
    "                                tempf *= 0. ## set derivative to zero when f^p does not have any term with f_i\n",
    "                    lam[i_pde, i-1,:] -= params[i_pde, i_d, i_p] * tempf * temp * dt\n",
    "    return lam\n",
    "\n",
    "# Finding the parameters of the PDE using adjoint method\n",
    "def AdjointFindPDE(fs, dx, data_dt=1, Nt_fine=2, nt=None, dt=None, avg=False, gamma=1e-3, epochs=100, epthr=50, beta = 0.01, learning_rates=None, ds=np.array([[1], [2], [3]]), ps=np.array([[1], [2], [3]]), V = 1., tol = 1e-12, eps0=1e-12):\n",
    "    if nt is None:\n",
    "        nt = [Nt_fine for _ in range(fs.shape[1])]\n",
    "        dt = [data_dt/(Nt_fine-1) for _ in range(fs.shape[1])]\n",
    "    numPDE = fs.shape[0]\n",
    "    D = np.max(np.sum(ds,axis=1))\n",
    "    P = np.max(np.sum(ps,axis=1))\n",
    "    params = np.zeros((numPDE,len(ds),len(ps)))\n",
    "    if learning_rates is None:\n",
    "        learning_rates = np.ones((numPDE, len(ds),len(ps)))\n",
    "        for i, d in enumerate(ds):\n",
    "            for j, p in enumerate(ps):\n",
    "                learning_rates[:,i,j] = beta * ( min(dx)**(sum(d)-D) )\n",
    "    estimated_params = np.zeros((epochs+1, numPDE, len(ds),len(ps)))\n",
    "    estimated_params[0,:] = params\n",
    "\n",
    "    params0 = params\n",
    "    for ep in range(1, epochs+1):\n",
    "        dC_dparams = np.zeros((numPDE, len(ds),len(ps)))\n",
    "        for i in range(len(nt)-1):\n",
    "            fst = fs[:, i:i+2,:]\n",
    "            ft0 = fst[:, 0, :]\n",
    "    \n",
    "            ft  = forward_m(params, ps, ds, ft0, dx, dt[i], nt[i])\n",
    "            \n",
    "            lam = adjoint_eq(params, ps, ds, fst[:, -1,:], ft, dx, dt[i], nt[i])\n",
    "\n",
    "            if avg is False:\n",
    "                dC_dparams = np.zeros((numPDE, len(ds),len(ps)))\n",
    "            for i_pde in range(numPDE):\n",
    "                for i_d, d in enumerate(ds):\n",
    "                    temp = np.array([lam[i_pde, ii,:] for ii in range(nt[i])])\n",
    "                    for i_di, di in enumerate(d):\n",
    "                        for rep in range(1, di+1):\n",
    "                            temp = np.array([np.gradient(temp[ii,:], axis=i_di) for ii in range(nt[i])] ) / dx[i_di]\n",
    "                    temp *= (-1)**sum(d)\n",
    "                    for i_p, p in enumerate(ps):\n",
    "                        tempf = np.ones_like(ft[0,:]) # (Nt, Nx0, Nx1,...)\n",
    "                        for i_pi, pi in enumerate(p):\n",
    "                            tempf *= ft[i_pi, :]**pi\n",
    "                        integ = np.array( [ tempf[ii,:] * temp[ii,:] for ii in range(nt[i])] )\n",
    "                        for xi in range(len(dx)-1, -1, -1):\n",
    "                            integ = np.array( [integrate.trapezoid(integ[ii,:], x[xi], axis=xi) for ii in range(nt[i])] )\n",
    "                        dC_dparams[i_pde, i_d, i_p] += np.sum(integ) * dt[i] / (nt[i]*dt[i]) / V + 2*eps0*params[i_pde, i_d, i_p]\n",
    "            if avg is False:\n",
    "                # update parameters afte seeing each data points\n",
    "                params = params - dC_dparams * learning_rates\n",
    "            if ep>epthr: # thresholding\n",
    "                params[abs(params)<gamma] = 0.\n",
    "        if avg is True:\n",
    "            # update parameters only after seeing all the data points\n",
    "            params = params - dC_dparams/len(nt) * learning_rates\n",
    "        if ep>epthr:# thresholding\n",
    "            params[abs(params)<gamma] = 0.\n",
    "        estimated_params[ep,:] = params\n",
    "        if np.linalg.norm(params-params0) < tol:\n",
    "            epochs = ep\n",
    "            break\n",
    "        params0 = params\n",
    "    \n",
    "    estimated_params = estimated_params[:epochs,:]\n",
    "    eps = [i for i in range(epochs)]\n",
    "    return estimated_params, eps"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b9649308-6a06-443a-b755-e66947b915bd",
   "metadata": {},
   "source": [
    "# Examples\n",
    "Here, we show how the proposed adjoint method can recover the underlying PDE given data in several examples. "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "555fd6aa-9ced-4c42-b1ac-c44fc5d443a3",
   "metadata": {},
   "source": [
    "## Heat Equation"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "590416c9-5022-425a-b7d7-36592c5bcdb1",
   "metadata": {},
   "source": [
    "Let us consider measured data collected from the solution to the heat equation, i.e.\n",
    "\\begin{flalign}\n",
    "    \\frac{\\partial f}{\\partial t} + D \\,\\frac{\\partial^2 f}{\\partial x^2} = 0,\n",
    "\\end{flalign}\n",
    "with $D = -1$. The data is constructed using the Finite Difference method with initial condition $f(x, 0) = 5\\sin(2 \\pi x)x(x-L)$ and a mesh with $N_x=100$ nodes in $x$ covering the domain $\\Omega = [0,L]$ with $L=1$ and $N_t=100$ steps in $t$ with final time $T=N_t \\Delta t$ where $\\Delta t = 0.05 \\Delta x^2/(1+|D|)$ is the step size and $\\Delta x=L/N_x$ is the mesh size in $x$."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5106f1b1-4681-4c18-b327-812c9375d9e9",
   "metadata": {},
   "source": [
    "### Generate Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "id": "13077084-8329-400e-976c-ed4f35b78d88",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "## generate data\n",
    "# df/dt + D d2f/dx^2 = 0\n",
    "\n",
    "CFL = 0.05\n",
    "def dt_cfl(dx, D_m):\n",
    "    # dt of simulation should be set satisfying CFL condition for stability\n",
    "    return CFL*dx**2/(1.+abs(D_m))\n",
    "    \n",
    "def heat_equation(D_m, f0_m, dx_m, dt_m, Nt_m):\n",
    "    f_m = np.zeros((Nt_m, len(f0_m)))\n",
    "    f_m[0,:] = f0_m\n",
    "    for i in range(Nt_m-1):\n",
    "        f_m[i+1,:] = f_m[i,:] - D_m * np.gradient(np.gradient(f_m[i,:]))/dx_m**2 * dt_m\n",
    "    return f_m\n",
    "\n",
    "L = 1.0  # Length of the domain\n",
    "Nx = 100  # Number of spatial grid points\n",
    "D_ex = -1.0  # Thermal diffusivity\n",
    "\n",
    "dx = L/Nx\n",
    "dt = dt_cfl(dx, D_ex)\n",
    "Nt = 100\n",
    "T = dt*Nt\n",
    "\n",
    "# Initial condition\n",
    "x =  np.linspace(0, L, Nx)\n",
    "f0 = 5.*np.sin(2.* np.pi * x)*x*(x-L)\n",
    "fs = heat_equation(D_ex, f0, dx, dt, Nt) #*np.random.normal(0.,0.001,(Nt,Nx)) # (Nt, Nx)\n",
    "\n",
    "dx = np.array([dx])\n",
    "x = np.array([x])\n",
    "f0 = np.array([f0])\n",
    "fs = np.array([fs])\n",
    "\n",
    "plt.plot(fs[0,0,:])\n",
    "\n",
    "fs0 = fs.copy()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3e38cc56-eaed-410d-a52e-15ba37d00b95",
   "metadata": {},
   "source": [
    "### PDE discovery using Adjoint method"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "id": "534ecdd3-31ce-4575-9979-4bb16ee5d605",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAQkAAAD1CAYAAABDTwCyAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAAArj0lEQVR4nO3de1gTV94H8O8kQLgIBBQICIpWRbRqFSvFtt6gina9VLqtlbrYWm8LqNXdfXHrperui9u61V5cXftutVqtVqsuUu0jaltbFwXBCgpSS61LwUDdlIS7kJz3j5hZIknIDUKG3+d55imZnMn8ZpL+POfMzDkcY4yBEEKMEDk6AEJI10ZJghBiEiUJQohJlCQIISZRkiCEmERJghBiEiUJQohJlCQIISa5ODqArk6j0aCiogLe3t7gOM7R4RBiN4wx1NTUICQkBCKR8foCJYl2VFRUICwszNFhENJhysrKEBoaavR9ShLt8Pb2BqA9kT4+Pg6OhhD7UalUCAsL43/jxlCSaIeuieHj40NJgghSe81oShI2UKuBr78G7twBgoOBJ58ExGJHR0WIfTnd1Y3t27cjPDwc7u7uiI6ORk5Ojsnyhw8fxuDBg+Hu7o5hw4bh5MmTdonj6FEgPByYOBGYO1f73/Bw7XpCBIU5kYMHDzI3Nzf2wQcfsOvXr7OFCxcyqVTKKisrDZa/cOECE4vF7I033mBFRUVszZo1zNXVlRUWFpq9T6VSyQAwpVLJr/v0U8Y4jjFAf+E47fLppzYfKiEdztBv2xCOMecZTyI6OhqPPvoo3nvvPQDay5NhYWFITU1FWlpam/LPP/886urqkJmZya977LHH8Mgjj2Dnzp1m7VOlUsHX1xdKpRI+Pj5Qq7U1hp9+Mlye44DQUODWLeE0PdRqNZqbmx0dBrGQq6srxCZ+hA/+to1xmj6Je/fuIS8vD6tXr+bXiUQixMXFITs72+A22dnZWLlypd66KVOm4Pjx40b309TUhKamJv61SqXSe//rr40nCEBbpygr05abMMF4OWfAGINcLkd1dbWjQyFWkkqlkMlkNt3j4zRJ4u7du1Cr1QgKCtJbHxQUhBs3bhjcRi6XGywvl8uN7ic9PR0bNmww+v6dO+bFa265rkyXIAIDA+Hp6Uk3kzkRxhjq6+tRVVUFAAgODrb6s5wmSXSW1atX69U+dNeSdcw91zZ8J12CWq3mE0TPnj0dHQ6xgoeHBwCgqqoKgYGBJpsepjhNkujVqxfEYjEqKyv11ldWVkImkxncRiaTWVQeACQSCSQSidH3n3xS2+dQXq5tWjxI1yfx5JMmDsYJ6PogPD09HRwJsYXu+2tubrY6STjNJVA3NzdERUXh7Nmz/DqNRoOzZ88iJibG4DYxMTF65QEgKyvLaHlziMXA229r/36w9q17vW2bcDotqYnh3Ozy/XXClRa7OXjwIJNIJGzPnj2sqKiILVq0iEmlUiaXyxljjM2bN4+lpaXx5S9cuMBcXFzYli1bWHFxMVu/fr1dLoEypr3MGRqqfwk0LEw4lz8bGhpYUVERa2hocHQoxAamvkdzL4E6VZJgjLF3332X9enTh7m5ubExY8awixcv8u+NHz+eJSUl6ZX/5JNP2KBBg5ibmxsbOnQo++yzzyzan6kT2dLC2Jgx2gTxP/+jfS0U9kwSLS2MffEFYwcOaP8rpPPU1XXLJNHZ2juRM2dqk8Tf/965cXU0eyUJQzWu0FDh1Li6OnskCafpk+iqXF21/6V7jdo6ehR49tm295WUl2vXd/Qt7Dk5OZgwYQI8PDwwePBgXL58Gbt27cKMGTM6dscC4zRXN7qq7pQkGAPq680rq1YDy5YZvgLEmLaTd/lyIC7OvE5eT8+2HcWmXLx4ERMnTsTGjRvx/vvv4w9/+AM2btyI69ev48iRI+Z/EHGeqxtdlZub9r/dIUnU1wM9epi3+PpqawzGMKatYfj6mvd55iYnnZUrV+LXv/41fv/732PgwIF44YUX8Nlnn2HEiBEYOXKkwW3i4uJw8+ZNi/ZTVlaGCRMmYMiQIRg+fDgOHz5sWaBWeuaZZ+Dn54dnn322w/dFScJGuprEvXuOjYP8108//YTs7GwsWbKEX+fi4gLGmMm7aW/evImHHnrIon25uLhg27ZtKCoqwunTp7FixQrU1dVZHbu5li9fjr1793b4fgBqbtisOzU3PD2B2lrzyp4/D0yb1n65kyeBcePM27e5iouLAQCjRo3i15WUlGDMmDEYNmwYv+769et4+eWX0dDQgOeffx4ymczkWI+GBAcH87c8y2Qy9OrVCwqFAl5eXgbLP/PMM5BIJCgtLYVCocChQ4cwevRoi/YJABMmTMCXX35p8XbWoCRho+6UJDgOMPLbb2PyZPPuTJ082f43nimVSojFYv5GIoVCgS1btmDEiBF8maamJjz//PP4+OOPMWzYMMyaNQvDhw/X+5zo6Gi9h/10Tpw4YXDc07y8PKjVapNjohYUFGDx4sU4ePAg9u/fj7/+9a/4+OOPrd5nZ6AkYSNdnwQ1N/Tp7kx99lltQmidKDr6ztRHHnkEarUab7zxBn79619j+fLlCA8PR1FREW7fvo2+ffvi+PHjGD9+PF+ziIyMREhIiN7nXLp0yex9KhQK/OY3v8H7779vtExtbS0aGxuxatUqfp/79u2zep+dhfokbNSdahKWmj0bOHIE6N1bf31oqHb97Nkds98BAwZg48aNePvttzFy5EiEhITg9OnT6N27N+Lj4wEAhYWFeOSRR/ht8vLyDNYkHnnkkTZLWVmZXrmmpibMmjULaWlpGDt2rNG4CgsLMXToUP4Zivz8fL3mjyX77ExUk7ARJQnTZs8GZs7s/LFA165di7Vr1+qty8vL4//29/fHtWvXAACnT5/GmTNncOjQIb3y5vyrzhjD/PnzMWnSJMybN0/vvdjYWOzduxe972fJgoIC3L59G83NzVCpVHj33Xdx9IGbRbpiTYKShI2oudE+sbjrDcDz4osvYurUqRg5ciQefvhh9O3bF35+fhZ/zoULF3Do0CEMHz6cH8xo3759ePjhh/H999/D39+fL1tQUIBp06YhKioKjDG88cYbFl9N0YmLi8PVq1dRV1eH0NBQHD582KYHF02hJGEjqkk4p8DAQL2ahbWeeOIJaDSaNuuLi4uRkJDAj+kAaJPEgQMHsHXrVpv3e+bMGZs/w1zUJ2EjShLEkMjISLz11lt668rLy51yNjhKEjai5gYx1w8//ODoEKxCScJGVJMgQkdJwkaUJIjQUZKwETU3iNBRkrAR1SSI0FGSsBElCSJ0lCRsRM0NInSUJGxENQkidJQkbERJgggdJQkb0chUROicJkkoFAokJibCx8cHUqkUCxYsQK2JYZIUCgVSU1MREREBDw8P9OnTB8uWLYNSqbRrXN1pjEvSPTlNkkhMTMT169eRlZWFzMxMnD9/HosWLTJavqKiAhUVFdiyZQuuXbuGPXv24PPPP8eCBQvsGhc1N7qu8ePHg+M4cBwHFxcXBAcHY/bs2bh48aKjQ3MuHTIjiJ0VFRUxACw3N5dfd+rUKcZxHCsvLzf7cz755BPm5ubGmpubzd6mvQlMCgu1E84EBJj9kU7B2af502g0zNvbm23evJnduXOH3bp1i507d44lJCQwFxcXdvr0aUeH2Cm6zeQ82dnZkEqlegOGxsXFQSQSWTRIh1KphI+PD1xcjD8h39TUBJVKpbeYQpdAu6abN2+ipqYG48aNg0wmQ3h4OCZOnMiPu/Daa685OkSn4RTjScjlcgQGBuqtc3Fxgb+/P+RyuVmfcffuXWzatMlkEwUA0tPTTQ67/qDu2NwwNWS8WCyGu7u7WWVFIpHeeAvGyhobedqUvLw8iMVivcFvAe0s20899RQ2bdpk8Wd2Vw6tSaSlpfFtRmPLjRs3bN6PSqXC008/jSFDhuD11183WXb16tVQKpX80t7Ygt0xSfTo0cPokpCQoFc2MDDQaNmpU6fqlQ0PDzdYzhr5+fmIiIiAp4Gx+N3c3OCq++JIuxxak1i1ahXmz59vskz//v0hk8lQVVWlt76lpQUKhQIymczk9jU1NYiPj4e3tzeOHTvW7o9DIpFAIpGYFT+gf3VDN30dcbz8/HxERUUZfK+kpASDBw/u5Iicl0OTREBAAAICAtotFxMTg+rqauTl5fFf/Llz56DRaBAdHW10O5VKhSlTpkAikSAjI0OvGmwvrXNOS4v+a6EydelZ/MAItw8m99YenAjnxx9/tCmu1vLz8zF9+vQ26+vq6pCRkYGVK1fabV9C5xR9EpGRkYiPj8fChQuxc+dONDc3IyUlBXPmzOHnSigvL+dHJx4zZgxUKhUmT56M+vp6fPTRR3qdkAEBAW1+zNZqnRSam7tHkrCkj6Cjypryww8/oLq6Wm8GLwBQq9VYsmQJPDw8kJycbJd9dQdOkSQAYP/+/UhJSUFsbCxEIhESEhLwzjvv8O83NzejpKQE9fdnls3Pz+evfAwYMEDvs27duoXw8HC7xKVrbgDaKxyWTEdHOoZugNvg4GDI5XKoVCrk5eXh7bffRllZGTIzM+Hr6+vgKJ2H0yQJf39/HDhwwOj74eHhYK2miZowYYLe647yYE2COF5+fj4AYNCgQRCLxZBKpYiIiMCMGTOwZMkSvWHuSfucJkl0VRynnVdCraYk0VWkp6cjPT3d0WEIhlPcTNXV0Q1VRMgoSdhBd7xXgnQflCTsgJIEETJKEnZAY0oQIaMkYQdCHlOiM64QkY5jj++PkoQdCLG5obt9XXffCXFOuu/PlmdVrLoEunHjRvzud79r8/BMQ0MD3nzzTaxbt87qgJyREJsbuvsLdLdVe3p6gqMHU5wGYwz19fWoqqqCVCq16Q5jjllRHxGLxbhz506bx7f/85//IDAwEGq12uqAuhqVSgVfX19+LApDRowACgqA06eBp57q5AA7EGMMcrkc1dXVjg6FWEkqlUImkxlM8Ob8tgEraxKMMYM7vXr1are8m02IzQ1AO/ZCcHAwAgMD0Sy0g+sGXF1d7fKMkkVJws/Pjx/nYdCgQXqJQq1Wo7a2FkuWLLE5KGcjxOZGa2Kx2G4PxBHnY1GS2LZtGxhjePnll7Fhwwa9h2Tc3NwQHh6OmJgYuwfZ1Qn56gYhFiWJpKQkAEC/fv0wduxYGt3nPqE2NwgBrOyTGD9+PDQaDb777jtUVVVBo9HovT9u3Di7BOcsKEkQIbMqSVy8eBFz587F7du329yswXGcoK5umIMe8CJCZlWSWLJkCUaPHo3PPvsMwcHB3f76OdUkiJBZlSRu3ryJI0eOtBnxqbuiJEGEzKrbsqOjo/H999/bOxanRc0NImRW1SRSU1OxatUqyOVyDBs2rM1VjuHDh9slOGdBNQkiZFYlCd0ELC+//DK/juM4/k7M7tZxSUmCCJlVSeLWrVv2jsOpUXODCJlVSaJv3772jsOpUU2CCJnV40ns27cPjz/+OEJCQnD79m0A2tu2//nPf9otuNYUCgUSExPh4+MDqVSKBQsWmJxJqjXGGKZOnQqO43D8+HG7x0ZJggiZVUlix44dWLlyJaZNm4bq6mq+D0IqlWLbtm32jI+XmJiI69evIysrC5mZmTh//ny7M4TrbNu2rUPv5RD6A16km2NWiIyMZMeOHWOMMdajRw9WWlrKGGOssLCQ9ezZ05qPNKmoqIgBYLm5ufy6U6dOMY7jWHl5ucltr1y5wnr37s3u3LnDAPBxm0upVDIATKlUGi2zaRNjAGMLF1r00YQ4lDm/bcYYs6omcevWLYwcObLNeolEgrq6OpuSliHZ2dmQSqUYPXo0vy4uLg4ikYifys+Q+vp6zJ07F9u3b2939nGdpqYmft7Q1vOHmkLNDSJkViWJfv364dtvv22z/vPPP0dkZKStMbUhl8vbjILl4uICf39/yOVyo9u9+uqrGDt2LGbOnGn2vtLT0+Hr68svYWFh7W5DzQ0iZFYliZUrVyI5ORmHDh0CYww5OTn485//jNWrV+MPf/iD2Z+TlpbGD2JjbLlx44Y1ISIjIwPnzp2zuI9k9erVUCqV/FJWVtbuNjSeBBEyqy6BvvLKK/Dw8MCaNWv4Kn1ISAjefvttzJkzx+zPWbVqFebPn2+yTP/+/SGTyfgBWXVaWlqgUCiMNiPOnTuH0tJSSKVSvfUJCQl48skn8eWXXxrcTiKRQCKRmHsIAKi5QYTN6gmDExMTkZiYiPr6etTW1rZpDpgjICAAAQEB7ZaLiYlBdXU18vLyEBUVBUCbBDQaDaKjow1uk5aWhldeeUVv3bBhw7B161ZMnz7d4lhNoeYGETKbZxX39PRsM7S+vUVGRiI+Ph4LFy7Ezp070dzcjJSUFMyZMwchISEAgPLycsTGxmLv3r0YM2YMZDKZwVpGnz590K9fP7vGR80NImRmJ4lRo0bh7Nmz8PPzw8iRI03ed5Cfn2+X4Frbv38/UlJSEBsbC5FIhISEBLzzzjv8+83NzSgpKXHIZDLU3CBCZnaSmDlzJt9WnzVrVkfFY5S/vz8OHDhg9P3w8PB2pzRr731rUXODCJnZSWL9+vUG/ybU3CDCZtUl0NzcXIM3MV26dAmXL1+2OShnQ80NImRWJYnk5GSD9w+Ul5cjOTnZ5qCcDSUJImRWJYmioiKMGjWqzfqRI0eiqKjI5qCcDY0nQYTMqiQhkUhQWVnZZv2dO3fg4mLzVVWnQzUJImRWJYnJkyfzty/rVFdX449//COeEtK02maiJEGEzKp/9rds2YJx48ahb9++/NOg3377LYKCgrBv3z67BugM6BIoETKrkkTv3r1RUFCA/fv34+rVq/Dw8MBLL72EF154oVvOD0qXQImQWd2B4OXlZfbIUEJHzQ0iZGYniYyMDEydOhWurq7IyMgwWXbGjBk2B+ZMqLlBhIxjZt6rLBKJ+MFfRCLj/Z1Cm3dDpVLB19cXSqUSPj4+BstUVgK6Z8k0GqCbT41KnIQ5v23AgpqERqMx+Df5b00CANRqoBteBSYCZvYlUH9/f9y9exeAduaumpqaDgvK2bROEtTkIEJjdpK4d+8ePyjshx9+iMbGxg4Lytnorm4A1HlJhMfsinFMTAxmzZqFqKgoMMawbNkyeHh4GCz7wQcf2C1AZ9C6JkFJggiN2Unio48+wtatW1FaWgoAUCqVVJu4TyTSLhoNNTeI8Jh9daO1fv364fLly+jZs2dHxNSlmNsD7OEBNDYCP/4I0FSpxBmY+9u2quNy4sSJcGvdECd0QxURLOq4tBO6oYoIFXVc2gk9v0GEyqqOS47jqOPyAdTcIEJldpIICgrC5s2bAWg7Lvft29ctOi7NRc0NIlRWzyquSxCdVZtQKBRITEyEj48PpFIpFixYgNra2na3y87OxqRJk+Dl5QUfHx+MGzcODQ0Ndo+PahJEqKxKEhqNBps2bULv3r3Ro0cP/PDDDwCAtWvX4h//+IddA9RJTEzE9evXkZWVhczMTJw/f77dR9Wzs7MRHx+PyZMnIycnB7m5uUhJSTH5gJq1qE+CCBazwoYNG1j//v3ZRx99xDw8PFhpaSljjLGDBw+yxx57zJqPNKmoqIgBYLm5ufy6U6dOMY7jWHl5udHtoqOj2Zo1a2zat1KpZACYUqk0WW7UKMYAxk6etGl3hHQac3/bVv2TunfvXuzatQuJiYkQi8X8+hEjRuDGjRv2yV6tZGdnQyqVYvTo0fy6uLg4iEQig/N/AEBVVRUuXbqEwMBAjB07FkFBQRg/fjy++eYbk/tqamqCSqXSW8xBfRJEqKxKEuXl5RgwYECb9RqNBs0dUN/WjWPRmouLC/z9/SGXyw1uo2sCvf7661i4cCE+//xzjBo1CrGxsbh586bRfaWnp8PX15dfwsLCzIqRmhtEqKxKEkOGDMHXX3/dZv2RI0f4gXHNkZaWBo7jTC7W1kx0Y14sXrwYL730EkaOHImtW7ciIiLC5H0culHAdYuhSYgMoY5LIlRWDY+ybt06JCUloby8HBqNBkePHkVJSQn27t2LzMxMsz9n1apVmD9/vsky/fv3h0wmQ1VVld76lpYWKBQKyHRDQj0gODgYgDahtRYZGYl///vfRvcnkUj4iZEtQc0NIlRWJYmZM2fixIkT2LhxI7y8vLBu3TqMGjUKJ06csGjejYCAAAQEBLRbLiYmBtXV1cjLy0NUVBQA4Ny5c9BoNIiOjja4TXh4OEJCQlBSUqK3/rvvvsPUqVPNjtFc1NwggtVJHak2i4+PZyNHjmSXLl1i33zzDRs4cCB74YUX+Pd/+uknFhERwS5dusSv27p1K/Px8WGHDx9mN2/eZGvWrGHu7u7s+++/N3u/5vYAz56tvbrxt79ZfmyEOIK5v22bRmPMy8tDcXExAGDo0KEW9UdYav/+/UhJSUFsbCxEIhESEhLwzjvv8O83NzejpKQE9fX1/LoVK1agsbERr776KhQKBUaMGIGsrCw89NBDdo+PmhtEsKzJQJWVlWzixImM4zjm5+fH/Pz8GMdxbNKkSayqqsqqrNZVmZtt583T1iTefLOTAiPERh16n0Rqaipqampw/fp1KBQKKBQKXLt2DSqVCsuWLbNvFnMSdHWDCJVVzY3PP/8cZ86cQWRkJL9uyJAh2L59OyZPnmy34JwJNTeIUFn97IahOT9dXV277ZwcdHWDCJVVSWLSpElYvnw5Kioq+HXl5eV49dVXERsba7fgnAk1N4hQWZUk3nvvPahUKoSHh+Ohhx7CQw89hH79+kGlUuHdd9+1d4xOgZobRKis6pMICwtDfn4+zpw5w982HRkZibi4OLsG50youUGEyqKaxLlz5zBkyBCoVCpwHIennnoKqampSE1NxaOPPoqhQ4cafKajO6DmBhEqi5LEtm3bsHDhQoNj9Pv6+mLx4sV466237BacM6HmBhEqi5LE1atXER8fb/T9yZMnIy8vz+agnBHVJIhQWZQkKisrDV761HFxccHPP/9sc1DOiPokiFBZlCR69+6Na9euGX2/oKCAf0S7u6HmBhEqi5LEtGnTsHbtWoMjZDc0NGD9+vX41a9+ZbfgnAk1N4hQWXQJdM2aNTh69CgGDRqElJQUREREAABu3LiB7du3Q61W47XXXuuQQLs6am4QobIoSQQFBeFf//oXli5ditWrV4Pdn5Cc4zhMmTIF27dvR1BQUIcE2tVRTYIIlcU3U/Xt2xcnT57EL7/8gu+//x6MMQwcOBB+fn4dEZ/ToD4JIlRWDzrj5+eHRx991J6xODVqbhChsv9UVt0UNTeIUFGSsBNqbhChoiRhJ9TcIEJFScJOqLlBhIqShJ1Qc4MIFSUJO6HmBhEqp0kSCoUCiYmJ8PHxgVQqxYIFC1BbW2tyG7lcjnnz5kEmk8HLywujRo3Cp59+2iHxUXODCJXTJInExERcv34dWVlZyMzMxPnz57Fo0SKT2/zmN79BSUkJMjIyUFhYiNmzZ+O5557DlStX7B4fNTeIYHXKLCA2KioqYgBYbm4uv+7UqVOM4zhWXl5udDsvLy+2d+9evXX+/v7s/fffN3vf5k5gcvu2dnIeNzezP5oQh+rQyXk6W3Z2NqRSKUaPHs2vi4uLg0gkwqVLl4xuN3bsWBw6dAgKhQIajQYHDx5EY2MjJkyYYHSbpqYmqFQqvcUcrfsk7j/SQoggOEWSkMvlCAwM1Fvn4uICf39/yOVyo9t98sknaG5uRs+ePSGRSLB48WIcO3YMAwYMMLpNeno6fH19+SUsLMysGHXNDcYAtdqsTQhxCg5NEmlpaeA4zuSiG43bGmvXrkV1dTXOnDmDy5cvY+XKlXjuuedQWFhodJvVq1dDqVTyS1lZmVn7aj1gF3VeEiGxaVZxW61atQrz5883WaZ///6QyWSoqqrSW9/S0gKFQgGZTGZwu9LSUrz33nu4du0ahg4dCgAYMWIEvv76a2zfvh07d+40uJ1EIoFEIrH4WHTNDUCbJDw8LP4IQrokhyaJgIAABAQEtFsuJiYG1dXVyMvLQ1RUFADt8P4ajQbR0dEGt6mvrwcAiET6lSWxWNwhUxG2rknQFQ4iJE7RJxEZGYn4+HgsXLgQOTk5uHDhAlJSUjBnzhyEhIQA0E4zOHjwYOTk5AAABg8ejAEDBmDx4sXIyclBaWkp/vrXvyIrKwuzZs2ye4xiMcBx2r+puUGExCmSBADs378fgwcPRmxsLKZNm4YnnngCu3bt4t9vbm5GSUkJX4NwdXXFyZMnERAQgOnTp2P48OHYu3cvPvzwQ0ybNq1DYqS7LokQcYzRBTtTVCoVfH19oVQqDU5K1Jq3N1BbC9y8CZi4gEJIl2Dub9tpahLOgG7NJkJEScKOqLlBhIiShB1RTYIIESUJO6KHvIgQUZKwI2puECGiJGFH1NwgQkRJwo6ouUGEiJKEHVFNgggRJQk7oj4JIkSUJOyImhtEiChJ2BE1N4gQUZKwI2puECGiJGFH1NwgQkRJwo6ouUGEiJKEHVFzgwgRJQk7ouYGESJKEnZEzQ0iRJQk7IiaG0SIKEnYETU3iBBRkrAjam4QIaIkYUfU3CBC5NDJeYTG3OaGWg18/TVw5w4QHAw8+aR23g57b9PZ29G+nC9Gs3TKHOd28Kc//YnFxMQwDw8P5uvra9Y2Go2GrV27lslkMubu7s5iY2PZd999Z9F+zZ2enTHG/vd/GQMYe+kl42U+/ZSx0FBtOd0SGqpdb89tOns72pfzxWjub9tpksS6devYW2+9xVauXGl2kti8eTPz9fVlx48fZ1evXmUzZsxg/fr1Yw0NDWbv15IksWWL9gt68UXD73/6KWMcp/9lAtp1HGf4S7Vmm87ejvblfDEyJsAkobN7926zkoRGo2EymYy9+eab/Lrq6momkUjYxx9/bPb+dCeyoqKC1dbWtllaJ5z33mMMqGVicS17+uladuBALfvPf7TllMpa1rt3/QNfZq3e0ru3tlxtbS2rr69nLS2t/4Woa1Net41KVacXs0pVx0JC2pbVLnWM4xgLC2OspYWx+vp6/liUyloD27WOt14vxrbbtC7bYPC4dIv+sTUYPTalspZpNBrGmDbe3r0bjRyXdgkN1bCWFu15aGxsNHFctQxQ8/9DhYY2mTiu/5bVLk1Gj0v7Pbe0KWvse265H6z22O61c2zN/LHdu3fPxHHVMqCZ/54bG5sN/nYrKiq6d5IoLS1lANiVK1f01o8bN44tW7bM6HaNjY1MqVTyS1lZGQNgdJk2bRq/7e3bjIlEnibKj3/gf6ReRssGBIxm06e3LtvXaFlv7yFs6VLGL97eQ0zE0Jf/zBkzGAsIGG2ibK8H4h1voqznA2WnmTxvM2a0LvusybKvvFLLli5l97dJMlkWqGIzZmjPw9Chv22n7K1WMfyunbLXWpVd307ZnFZl32jnPHzR6tjea+dzM/ljmzhxdztlP+FjWL/+E5Nl20sSgu24lMvlAICgoCC99UFBQfx7hqSnp2PDhg1W7bNPH8DdHbg/HalNfv4ZOHHCvLI1NcCOHZbvIyPD8m3sxZJ9/9//ddxnO5qlsVpzbL/8Yvk2rTl0LtC0tDT85S9/MVmmuLgYgwcP5l/v2bMHK1asQHV1tcnt/vWvf+Hxxx9HRUUFgoOD+fXPPfccOI7DoUOHDG7X1NSEpqYm/rVKpUJYWBgqKioMzpcoFovh7u7Ov66rq+P/1mgAhQKorATOnAFee00EwKPV1nV40IsvAn37Ahwnwk8/eWDPHt079dAm/rYSEzkMHOjJv755sx779xv7WjkA2rJJSUBoaAMY0wAAfvwROHDgwfJerf5uAKDB3LlAeDgMbNO6bCMANf+q9TYAUF7uhQ8/NFy2tblzgYEDPcFxHG7dAj78sAlAi5FjAwBPJCVx6NcPaGlpgkbTYuS4AO13obsL4B7mzm02clxtywLNBo9Lu507AHGbsg8eV3g44OLiDpFIfP/Ymu+XN0aCpCQX9OsHqNXNKC29Z+S4tGV1Fy/PnGnBY481tSmhUqkQEhLS/jy37dbbO1BVVRUrLi42uTQ1Nelt09HNjQdZ0nFpiq4NbqiTCffbxbp+Alu26eztaF/Od+51qOPyfsflli1b+HVKpdLqjktbkwRj/+2JfvBLNaf32pJtOns72pfzxciYAJPE7du32ZUrV9iGDRtYjx492JUrV9iVK1dYTU0NXyYiIoIdPXqUf71582YmlUrZP//5T1ZQUMBmzpzZoZdAzWHomnZYmOXXwdvbprO3o305X4zm/rYd2idhifnz5+PD/zZieV988QUmTJgAAOA4Drt378b8+fMBAIwxrF+/Hrt27UJ1dTWeeOIJ/O1vf8OgQYPM3q9KpYKvr2/77TYL0F1/tK+uEKO5v22nSRKO0hFJgpCuwNzfNj3gRQgxSbD3SdiLrqKlUqkcHAkh9qX7TbfXmKAk0Y6amhoAQFhYmIMjIaRj1NTUwNfX1+j71CfRDo1Gg4qKCnh7e4PjuDbv6262Kisroz4L0Pl4UFc+H4wx1NTUICQkBCKR8Z4Hqkm0QyQSITQ0tN1yPj4+Xe5H4Eh0PvR11fNhqgahQx2XhBCTKEkQQkyiJGEjiUSC9evXQyKRODqULoHOhz4hnA/quCSEmEQ1CUKISZQkCCEmUZIghJhESYIQYhIlCRtt374d4eHhcHd3R3R0NHJychwdUodLT0/Ho48+Cm9vbwQGBmLWrFkoKSnRK9PY2Ijk5GT07NkTPXr0QEJCAiorKx0UcefavHkzOI7DihUr+HXOfD4oSdjg0KFDWLlyJdavX4/8/HyMGDECU6ZMQVVVlaND61BfffUVkpOTcfHiRWRlZaG5uRmTJ0/WG9/z1VdfxYkTJ3D48GF89dVXqKiowOzZsx0YdefIzc3F3//+dwwfPlxvvVOfD9Nj1xBTxowZw5KTk/nXarWahYSEsPT0dAdG1fmqqqoYAPbVV18xxrTzm7i6urLDhw/zZYqLixkAlp2d7agwO1xNTQ0bOHAgy8rKYuPHj2fLly9njDn/+aCahJXu3buHvLw8xMXF8etEIhHi4uKQnZ3twMg6n1KpBAD4+/sDAPLy8tDc3Kx3bgYPHow+ffoI+twkJyfj6aef1jtuwPnPBz3gZaW7d+9CrVYbnNfjxo0bDoqq82k0GqxYsQKPP/44Hn74YQDaOU/c3NwglUr1yrY354kzO3jwIPLz85Gbm9vmPWc/H5QkiE2Sk5Nx7do1fPPNN44OxWHKysqwfPlyZGVl6c3BIhTU3LBSr169IBaL2/RQV1ZWQiaTOSiqzpWSkoLMzEx88cUXeo/Ty2Qy3Lt3r80ESkI9N3l5eaiqqsKoUaPg4uICFxcXfPXVV3jnnXfg4uKCoKAgpz4flCSs5ObmhqioKJw9e5Zfp9FocPbsWcTExDgwso7HGENKSgqOHTuGc+fOoV+/fnrvR0VFwdXVVe/clJSU4N///rcgz01sbCwKCwvx7bff8svo0aORmJjI/+3U58PRPafO7ODBg0wikbA9e/awoqIitmjRIiaVSplcLnd0aB1q6dKlzNfXl3355Zfszp07/FJfX8+XWbJkCevTpw87d+4cu3z5MouJiWExMTEOjLpztb66wZhznw9KEjZ69913WZ8+fZibmxsbM2YMu3jxoqND6nCA4dmpd+/ezZdpaGhgv/3tb5mfnx/z9PRkzzzzDLtz547jgu5kDyYJZz4f9Kg4IcQk6pMghJhESYIQYhIlCUKISZQkCCEmUZIghJhESYIQYhIlCUKISZQkiFPiOA7Hjx93dBjdAiUJYrH58+eD47g2S3x8vKNDIx2AHhUnVomPj8fu3bv11jnzLFXEOKpJEKtIJBLIZDK9xc/PD4C2KbBjxw5MnToVHh4e6N+/P44cOaK3fWFhISZNmgQPDw/07NkTixYtQm1trV6ZDz74AEOHDoVEIkFwcDBSUlL03r979y6eeeYZeHp6YuDAgcjIyODf++WXX5CYmIiAgAB4eHhg4MCBbZIaMQ8lCdIh1q5di4SEBFy9ehWJiYmYM2cOiouLAQB1dXWYMmUK/Pz8kJubi8OHD+PMmTN6SWDHjh1ITk7GokWLUFhYiIyMDAwYMEBvHxs2bMBzzz2HgoICTJs2DYmJiVAoFPz+i4qKcOrUKRQXF2PHjh3o1atX550AIXH0E2bE+SQlJTGxWMy8vLz0lj//+c+MMe1TokuWLNHbJjo6mi1dupQxxtiuXbuYn58fq62t5d//7LPPmEgk4h+zDwkJYa+99prRGACwNWvW8K9ra2sZAHbq1CnGGGPTp09nL730kn0OuJujPglilYkTJ2LHjh1663QD4QJoM5hKTEwMvv32WwBAcXExRowYAS8vL/79xx9/HBqNBiUlJeA4DhUVFYiNjTUZQ+th6728vODj48NPZ7B06VIkJCQgPz8fkydPxqxZszB27FirjrW7oyRBrOLl5dWm+m8vHh4eZpVzdXXVe81xHDQaDQBg6tSpuH37Nk6ePImsrCzExsYiOTkZW7ZssXu8Qkd9EqRDXLx4sc3ryMhIAEBkZCSuXr2qN5nPhQsXIBKJEBERAW9vb4SHh+sN92aNgIAAJCUl4aOPPsK2bduwa9cumz6vu6KaBLFKU1NTm+HgXVxc+M7Bw4cPY/To0XjiiSewf/9+5OTk4B//+AcAIDExEevXr0dSUhJef/11/Pzzz0hNTcW8efP4KQpef/11LFmyBIGBgZg6dSpqampw4cIFpKammhXfunXrEBUVhaFDh6KpqQmZmZl8kiIWcnSnCHE+SUlJBoevi4iIYIxpOxW3b9/OnnrqKSaRSFh4eDg7dOiQ3mcUFBSwiRMnMnd3d+bv788WLlzIampq9Mrs3LmTRUREMFdXVxYcHMxSU1P59wCwY8eO6ZX39fXlh9DbtGkTi4yMZB4eHszf35/NnDmT/fDDD/Y/Gd0ADV9H7I7jOBw7dgyzZs1ydCjEDqhPghBiEiUJQohJ1HFJ7I5asMJCNQlCiEmUJAghJlGSIISYREmCEGISJQlCiEmUJAghJlGSIISYREmCEGISJQlCiEn/D0mez38npaNdAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Execution time: 6.388177871704102\n",
      "total number of terms: 9\n",
      "3.700910285618246e-12\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "start_time = time.time()\n",
    "\n",
    "problem = \"1D_heat_equation\"\n",
    "numPDE = fs.shape[0]\n",
    "\n",
    "ds = np.array([[1], [2], [3]])\n",
    "ps = np.array([[1], [2], [3]])\n",
    "\n",
    "estimated_params, eps = AdjointFindPDE(fs, dx, data_dt=dt, Nt_fine=2, avg=False, gamma=1e-3, epochs=50, epthr=50, beta = 0.1, ds=ds, ps=ps, V = L, tol = 1e-15, eps0=1e-16)\n",
    "\n",
    "i_pde = 0\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if ( d[0]==2 and p[0]==1 ):\n",
    "            plt.plot(estimated_params[:,i_pde,id,ip], label=r\"$α_{d=\"+str(d[0])+\", p=\"+str(p[0])+\"}$\", color=\"blue\", marker=\"o\", markevery=4)\n",
    "            err_D = estimated_params[-1,i_pde,id,ip]\n",
    "err_D = abs(err_D - D_ex)\n",
    "plt.axhline(D_ex, linestyle = \"--\", color=\"black\", label=r\"$D$\")\n",
    "plt.legend()\n",
    "plt.ylabel(r'Coefficient')\n",
    "plt.xlabel('Epochs')\n",
    "name = problem + \"_\" + \"Dconv\"\n",
    "plt.savefig(name+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "plt.show()\n",
    "\n",
    "end_time = time.time()\n",
    "print(\"Execution time: \"+str(end_time-start_time))\n",
    "\n",
    "i_pde = 0\n",
    "err_other = np.zeros_like(estimated_params[:,0,0,0])\n",
    "count = 0\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if not ( d[0]==2 and p[0]==1 ):\n",
    "            err_other += abs(estimated_params[:,i_pde,id,ip])\n",
    "            count += 1\n",
    "\n",
    "## coeff of u\n",
    "i_pde = 0\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==2 and p[0]==1:\n",
    "            plt.plot(eps[1:], abs(estimated_params[1:,i_pde,id,ip]-D_ex),\n",
    "                     label=r\"$e(D)$\", marker=\"o\", markevery=4, color=\"black\")\n",
    "plt.plot(eps[1:], err_other[1:]/count, marker=\"s\", markevery=4, color=\"blue\", label=r\"$||e(\\mathbf{\\alpha}^*)||_1$\")\n",
    "plt.yscale('log')\n",
    "plt.ylabel(r'Error')\n",
    "plt.xlabel('Epochs')\n",
    "plt.legend()\n",
    "name = problem + \"_\" + \"D\"\n",
    "plt.savefig(name+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "\n",
    "print(\"total number of terms: \"+str(numPDE*len(ds)*len(ps)))\n",
    "print((err_other[-1])+err_D)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bc583cbb-9079-4146-96d0-314cdbdb7b2f",
   "metadata": {},
   "source": [
    "### PDE discovery using PDE-FIND"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "id": "a904ca6c-35d0-4d23-96f8-ef9ebb184449",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['1', 'u_{x}', 'u_{xx}', 'u_{xxx}', 'u', 'u^2', 'u^3', 'uu_{x}', 'u^2u_{x}', 'u^3u_{x}', 'uu_{xx}', 'u^2u_{xx}', 'u^3u_{xx}', 'uu_{xxx}', 'u^2u_{xxx}', 'u^3u_{xxx}']\n",
      "u_t = (1.000000 +0.000000i)u_{xx}\n",
      "   \n",
      "Execution time: 1.1539630889892578\n",
      "[1.]\n",
      "[2.91719982e-10]\n"
     ]
    }
   ],
   "source": [
    "import sys; sys.path.append('PDE-FIND/')\n",
    "from PDE_FIND import *\n",
    "import scipy.io as sio\n",
    "import itertools\n",
    "\n",
    "start_time = time.time()\n",
    "\n",
    "#(numPDE, Nt, Nx0, Nx1, ...)\n",
    "nt = Nt-1\n",
    "\n",
    "# Take up to second order derivatives.\n",
    "u = np.zeros((nt, Nx))\n",
    "ut = np.zeros((nt, Nx))\n",
    "ux = np.zeros((nt, Nx))\n",
    "uxx = np.zeros((nt, Nx))\n",
    "uxxx = np.zeros((nt, Nx))\n",
    "\n",
    "for i in range(nt):\n",
    "    u[i,:] = fs[0, i, :]\n",
    "    ut[i,:] = (fs[0, i+1, :]-fs[0, i, :])/dt\n",
    "    ux[i,:] = np.gradient(u[i,:], axis=0) / dx[0]\n",
    "    uxx[i,:] = np.gradient( np.gradient(u[i,:],axis=0), axis=0) / dx[0]**2\n",
    "    uxxx[i,:] = np.gradient( np.gradient( np.gradient(u[i,:],axis=0), axis=0), axis=0) / dx[0]**3\n",
    "\n",
    "u = u.reshape((nt * Nx, 1))\n",
    "ut = ut.reshape((nt * Nx, 1))\n",
    "ux = ux.reshape((nt * Nx, 1))\n",
    "uxx = uxx.reshape((nt * Nx, 1))\n",
    "uxxx = uxxx.reshape((nt * Nx, 1))\n",
    "\n",
    "num_points = nt * Nx\n",
    "\n",
    "X_data = np.hstack([u])\n",
    "X_ders = np.hstack([np.ones((num_points,1)), ux, uxx, uxxx])\n",
    "X_ders_descr = ['','u_{x}', 'u_{xx}', 'u_{xxx}']\n",
    "X, description = build_Theta(X_data, X_ders, X_ders_descr, 3, data_description = ['u'])\n",
    "print(['1'] + description[1:])\n",
    "\n",
    "c = TrainSTRidge(X,ut,10**-6,0.1)\n",
    "print_pde(c, description)\n",
    "\n",
    "end_time = time.time()\n",
    "print(\"Execution time: \"+str(end_time-start_time))\n",
    "\n",
    "coeff_pdefind = []\n",
    "for i in range(len(c)):\n",
    "        if c[i] != 0:\n",
    "            coeff_pdefind.append( abs(c[i]) )\n",
    "coeff_pdefind = np.array( coeff_pdefind )\n",
    "print(coeff_pdefind[0])\n",
    "print(np.sum(coeff_pdefind[1:]) + abs(-coeff_pdefind[0]-D_ex))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1f76b806-995e-4d33-8947-dd55d14ec6a4",
   "metadata": {},
   "source": [
    "## Burgers' equation"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ee92f342-3c43-4d1d-bd58-03b24006b0c0",
   "metadata": {},
   "source": [
    "As a nonlinear test case, let us consider the data from Burgers' equation given by\n",
    "\\begin{flalign}\n",
    "    \\frac{\\partial f}{\\partial t} + \\frac{\\partial (A f^2)}{\\partial x} = 0\n",
    "\\end{flalign}\n",
    "where $A = -1$. The data is obtained with similar simulation setup as for heat equation except for the time step, i.e. $\\Delta t = 0.05 \\Delta x/(1+|A|)$."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "39e0fc1f-52c5-41ca-8d40-7af03f7d6743",
   "metadata": {},
   "source": [
    "### Generate Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "id": "c9849949-4294-41ff-9026-e2360b6f0b70",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1, 100)\n",
      "(1, 100)\n",
      "(1, 1000, 100)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x19bab0850>]"
      ]
     },
     "execution_count": 97,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "## generate data\n",
    "# df/dt + A*f*df/dx = 0\n",
    "\n",
    "CFL = 0.01\n",
    "def dt_cfl(dx, A_m):\n",
    "    # dt of simulation should be set satisfying CFL condition for stability\n",
    "    return CFL*dx/(1.+abs(A_m)) #CFL*min(dx/abs(A_m+1e-15),dx**2/abs(D_m+1e-15))\n",
    "    \n",
    "def burger_equation(A_m, f0_m, dx_m, dt_m, Nt_m):\n",
    "    f_m = np.zeros((Nt_m, len(f0_m)))\n",
    "    f_m[0,:] = f0_m\n",
    "    for i in range(Nt_m-1):\n",
    "        f_m[i+1,:] = f_m[i,:] - np.gradient( A_m*f_m[i,:]**2)/dx_m * dt_m\n",
    "    return f_m\n",
    "\n",
    "L = 1.0  # Length of the domain\n",
    "Nx = 100  # Number of spatial grid points\n",
    "A_ex = -1.0  # Advection coefficient\n",
    "\n",
    "dx = L/Nx\n",
    "dt = dt_cfl(dx, A_ex)\n",
    "Nt = 1000\n",
    "T = dt*Nt\n",
    "\n",
    "# Initial condition\n",
    "x =  np.linspace(0, L, Nx)\n",
    "f0 = 5.*np.sin(2.* np.pi * x)*x*(x-L)\n",
    "fs = burger_equation(A_ex, f0, dx, dt, Nt)\n",
    "\n",
    "dx = np.array([dx])\n",
    "x = np.array([x])\n",
    "f0 = np.array([f0])\n",
    "fs = np.array([fs])\n",
    "\n",
    "fs0 = fs.copy()\n",
    "\n",
    "print(x.shape)\n",
    "print(f0.shape)\n",
    "print(fs.shape)\n",
    "plt.plot(fs[0,0,:])\n",
    "plt.plot(fs[0,-1,:])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "id": "57472650-dc02-481f-b8de-2dcdab9555dc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "\n",
    "ts = np.array([[i*dt for i in range(Nt)]])\n",
    "\n",
    "X, T = np.meshgrid(x[0], ts[0])\n",
    "fig = plt.figure(figsize=(size*cm, size*cm))\n",
    "ax = fig.add_subplot(111, projection='3d')\n",
    "surf = ax.plot_surface(X, T, fs[0,:,:], rstride=1, cstride=1, cmap='viridis', linewidth=0, antialiased=False)\n",
    "ax.view_init(elev=45, azim=120)\n",
    "plt.xlabel('x')\n",
    "plt.ylabel('t')\n",
    "plt.savefig(\"data_BurgersEq\"+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e0c81fb7-f3f5-43cf-bb75-d6d1e28ec564",
   "metadata": {},
   "source": [
    "### Discover PDE using adjoint method"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "id": "6f9ed5cf-2414-4efb-b1f2-fdfade2ba560",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Execution time: 67.67886114120483\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "total number of terms: 9\n",
      "8.754858773194209e-13\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "problem = \"1D_burgers_eq\"\n",
    "\n",
    "ds = np.array([[1], [2], [3]])\n",
    "ps = np.array([[1], [2], [3]])\n",
    "\n",
    "start_time = time.time()\n",
    "estimated_params, eps = AdjointFindPDE(fs, dx, data_dt=dt, avg=False, gamma=1e-3, epochs=60, epthr=60, beta = 0.0001, ds=ds, ps=ps, V = L, tol = 1e-15, eps0=1e-16)\n",
    "end_time = time.time()\n",
    "print(\"Execution time: \"+str(end_time-start_time))\n",
    "\n",
    "i_pde = 0\n",
    "\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if ( d[0]==1 and p[0]==2 ):\n",
    "            plt.plot(estimated_params[:,i_pde,id,ip], label=r\"$α_{d=\"+str(d[0])+\", p=\"+str(p[0])+\"}$\", color=\"blue\",marker=\"o\", markevery=5)\n",
    "            total_error = estimated_params[-1,i_pde,id,ip]\n",
    "total_error = abs(total_error-A_ex)\n",
    "plt.axhline(A_ex, color=\"black\", linestyle = \"--\", label=r\"$A$\")\n",
    "plt.ylabel('Coefficient')\n",
    "plt.xlabel('Epochs')\n",
    "plt.legend()\n",
    "name = problem + \"_\" + \"Aconv\"\n",
    "plt.savefig(name+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "plt.show()\n",
    "\n",
    "err_other = np.zeros_like(estimated_params[:,0,0,0])\n",
    "count = 0\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if not ( d[0]==1 and p[0]==2 ):\n",
    "            err_other += abs(estimated_params[:,i_pde,id,ip])\n",
    "            count += 1\n",
    "\n",
    "i_pde = 0\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==1 and p[0]==2:\n",
    "            plt.plot(eps[1:], abs(estimated_params[1:,i_pde,id,ip]-A_ex),\n",
    "                     label=r\"$e(A)$\", marker=\"o\", markevery=5, color=\"blue\")\n",
    "plt.plot(eps[1:], err_other[1:]/count, marker=\"s\", markevery=5, color=\"black\", label=r\"$||e(\\mathbf{\\alpha}^*)||_1$\")\n",
    "plt.yscale('log')\n",
    "plt.ylabel(r'Error')\n",
    "plt.xlabel('Epochs')\n",
    "plt.legend()\n",
    "name = problem + \"_\" + \"A\"\n",
    "#plt.savefig(name+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "\n",
    "print(\"total number of terms: \"+str(numPDE*len(ds)*len(ps)))\n",
    "\n",
    "total_error += err_other[-1]\n",
    "print(total_error)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3a6c4da3-3ef8-4b36-a358-922028271ca7",
   "metadata": {},
   "source": [
    "### Discover PDE using PDE-FIND"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "id": "4a69ce11-3518-4e02-a285-c32b31f0df1c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['1', 'u_{x}', 'u_{xx}', 'u_{xxx}', 'u', 'u^2', 'u^3', 'uu_{x}', 'u^2u_{x}', 'u^3u_{x}', 'uu_{xx}', 'u^2u_{xx}', 'u^3u_{xx}', 'uu_{xxx}', 'u^2u_{xxx}', 'u^3u_{xxx}']\n",
      "u_t = (0.001245 +0.000000i)u_{xx}\n",
      "    + (0.229404 +0.000000i)u^3\n",
      "    + (2.021920 +0.000000i)uu_{x}\n",
      "    + (0.003402 +0.000000i)u^2u_{xx}\n",
      "    + (0.000074 +0.000000i)uu_{xxx}\n",
      "   \n",
      "Execution time: 14.072757005691528\n"
     ]
    }
   ],
   "source": [
    "import sys; sys.path.append('PDE-FIND/')\n",
    "from PDE_FIND import *\n",
    "import scipy.io as sio\n",
    "import itertools\n",
    "\n",
    "fs = fs0.copy()\n",
    "\n",
    "start_time = time.time()\n",
    "\n",
    "#(numPDE, Nt, Nx0, Nx1, ...)\n",
    "nt = Nt-1\n",
    "\n",
    "# Take up to second order derivatives.\n",
    "u = np.zeros((nt, Nx))\n",
    "ut = np.zeros((nt, Nx))\n",
    "ux = np.zeros((nt, Nx))\n",
    "uxx = np.zeros((nt, Nx))\n",
    "uxxx = np.zeros((nt, Nx))\n",
    "\n",
    "\n",
    "for i in range(nt):\n",
    "    u[i,:] = fs[0, i, :]\n",
    "    ut[i,:] = (fs[0, i+1, :]-fs[0, i, :])/dt\n",
    "    ux[i,:] = np.gradient(u[i,:], axis=0) / dx[0]\n",
    "    uxx[i,:] = np.gradient( np.gradient(u[i,:],axis=0), axis=0) / dx[0]**2\n",
    "    uxxx[i,:] = np.gradient( np.gradient( np.gradient(u[i,:],axis=0), axis=0), axis=0) / dx[0]**3\n",
    "\n",
    "u = u.reshape((nt * Nx, 1))\n",
    "ut = ut.reshape((nt * Nx, 1))\n",
    "ux = ux.reshape((nt * Nx, 1))\n",
    "uxx = uxx.reshape((nt * Nx, 1))\n",
    "uxxx = uxxx.reshape((nt * Nx, 1))\n",
    "\n",
    "num_points = nt * Nx\n",
    "\n",
    "X_data = np.hstack([u])\n",
    "X_ders = np.hstack([np.ones((num_points,1)), ux, uxx, uxxx])\n",
    "X_ders_descr = ['','u_{x}', 'u_{xx}', 'u_{xxx}']\n",
    "X, description = build_Theta(X_data, X_ders, X_ders_descr, 3, data_description = ['u'])\n",
    "print(['1'] + description[1:])\n",
    "\n",
    "c = TrainSTRidge(X,ut,10**-5,1)\n",
    "print_pde(c, description)\n",
    "\n",
    "end_time = time.time()\n",
    "print(\"Execution time: \"+str(end_time-start_time))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "457ec182-b086-49e7-9fdd-dab2b0fc7f73",
   "metadata": {},
   "source": [
    "## Kuramoto Sivashinsky Equation"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cc856349-20f2-45c8-81cf-726b142a1cb0",
   "metadata": {},
   "source": [
    "As a more challenging test case, let us consider the recovery of the Kuramoto-Sivashinsky (KS) equation given by\n",
    "\\begin{flalign}\n",
    "    \\frac{\\partial f}{\\partial t} + A \\frac{\\partial f^2}{\\partial x} + B \\frac{\\partial^2 f}{\\partial x^2} + C\\frac{\\partial^4 f}{\\partial x^4}= 0\n",
    "\\end{flalign}\n",
    "where $A = -1$, $B = 0.5$ and \n",
    "$C = -0.5$. The data is generated similar to previous sections except for the grid $(N_t,N_x)=(64,256)$ and the time step size $\\Delta t = 0.01 \\Delta x^4/(1+|C|)$."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b8ca948c-c94c-4bc1-b338-9545259dea34",
   "metadata": {},
   "source": [
    "### Generate Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "id": "da36b9ce-4c64-4747-9368-57a3821ecdd5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1, 256)\n",
      "(1, 256)\n",
      "(1, 64, 256)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x198668250>]"
      ]
     },
     "execution_count": 101,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from numpy import gradient as grad\n",
    "# ut + A*uxxxx + B*u*ux + D*uxx = 0\n",
    "def dt_cfl(dx, C_m):\n",
    "    # dt of simulation should be set satisfying CFL condition for stability\n",
    "    CFL = 0.01\n",
    "    return CFL*dx**4/(1.+abs(C_m))\n",
    "    \n",
    "def Kuramoto_Sivashinsky_equation(A_m, B_m, C_m, f0_m, dx_m, dt_m, Nt_m):\n",
    "    f_m = np.zeros((Nt_m, len(f0_m)))\n",
    "    f_m[0,:] = f0_m\n",
    "    for i in range(Nt_m-1):\n",
    "        f_m[i+1,:] = f_m[i,:]\n",
    "        f_m[i+1,:] += - C_m * grad(grad(grad(grad(f_m[i,:]))))/dx_m**4 * dt_m        \n",
    "        f_m[i+1,:] += - A_m * grad(f_m[i,:]**2)/dx_m * dt_m \n",
    "        f_m[i+1,:] += - B_m * grad(grad(f_m[i,:]))/dx_m**2 * dt_m\n",
    "    return f_m\n",
    "\n",
    "L = 1.0  # Length of the domain\n",
    "Nx = 256  # Number of spatial grid points\n",
    "A_ex = -1.0  # Advection coefficient\n",
    "B_ex = 0.5\n",
    "C_ex = -0.5\n",
    "\n",
    "dx = L/Nx\n",
    "dt = dt_cfl(dx, C_ex)\n",
    "Nt = 64\n",
    "T = dt*Nt\n",
    "\n",
    "# Initial condition\n",
    "x =  np.linspace(0, L, Nx)\n",
    "f0 = 5.*np.sin(2.* np.pi * x)*x*(x-L)\n",
    "fs = Kuramoto_Sivashinsky_equation(A_ex, B_ex, C_ex, f0, dx, dt, Nt) #*np.random.normal(0.,0.001,(Nt,Nx)) # (Nt, Nx)\n",
    "\n",
    "dx = np.array([dx])\n",
    "x = np.array([x])\n",
    "f0 = np.array([f0])\n",
    "fs = np.array([fs])\n",
    "\n",
    "fs0 = fs.copy()\n",
    "\n",
    "print(x.shape)\n",
    "print(f0.shape)\n",
    "print(fs.shape)\n",
    "plt.plot(fs[0,0,:])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "12e0bd33-b664-4535-879e-f61386f976b0",
   "metadata": {},
   "source": [
    "### Discover PDE using adjoint method"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "id": "3d0dced9-4695-4e5e-8199-bf7c55519ac2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Execution time: 16.03332805633545\n",
      "total number of terms: 8\n",
      "4.760729865882496e-09\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "thresholding = True\n",
    "problem = \"Kuramoto_Sivashinsky_noise\"\n",
    "noise = 0.0/100. # added noise as standard deviation of the normal distribution\n",
    "fs = fs0.copy()\n",
    "fs = fs*(1+np.random.normal(0.0, noise, fs.shape) )\n",
    "\n",
    "ds = np.array([[1], [2], [3], [4]])\n",
    "ps = np.array([[1], [2]])\n",
    "\n",
    "start_time = time.time()\n",
    "estimated_params, eps = AdjointFindPDE(fs, dx, data_dt=dt, avg=False, gamma=1e-3, epochs=200, epthr=100, beta=50.0, ds=ds, ps=ps, V=L, tol=1e-15, eps0=1e-20)\n",
    "end_time = time.time()\n",
    "\n",
    "numPDE = fs.shape[0]\n",
    "i_pde = 0\n",
    "error = 0.\n",
    "\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==1 and p[0]==2:\n",
    "            error += abs( estimated_params[-1,i_pde,id,ip]-A_ex )\n",
    "            plt.plot(estimated_params[:,i_pde,id,ip], label=r\"$α_{d=\"+str(d[0])+\", p=\"+str(p[0])+\"}$\", color=\"blue\", marker=\">\", markevery=6)\n",
    "\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==2 and p[0]==1:\n",
    "            error += abs( estimated_params[-1,i_pde,id,ip]-B_ex )\n",
    "            plt.plot(estimated_params[:,i_pde,id,ip], label=r\"$α_{d=\"+str(d[0])+\", p=\"+str(p[0])+\"}$\", color=\"green\", marker=\"o\", markevery=6)\n",
    "            \n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==4 and p[0]==1:\n",
    "            error += abs( estimated_params[-1,i_pde,id,ip]-C_ex )\n",
    "            plt.plot(estimated_params[:,i_pde,id,ip], label=r\"$α_{d=\"+str(d[0])+\", p=\"+str(p[0])+\"}$\", color=\"red\", marker=\"d\", markevery=6)\n",
    "\n",
    "plt.axhline(A_ex, color=\"blue\", linestyle = \"--\", label=r\"$A$\")\n",
    "plt.axhline(B_ex, color=\"green\", linestyle = \"--\", label=r\"$B$\")\n",
    "plt.axhline(C_ex, color=\"red\", linestyle = \"--\", label=r\"$C$\")\n",
    "plt.ylabel('Coefficient')\n",
    "plt.xlabel('Epochs')\n",
    "plt.legend(loc='upper center', bbox_to_anchor=(0.5, 1.5), ncol=2, fontsize=9)\n",
    "name = problem + \"_\" + \"coeffconv\"\n",
    "plt.savefig(name+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "plt.show()\n",
    "\n",
    "\n",
    "print(\"Execution time: \"+str(end_time-start_time))\n",
    "\n",
    "err_other = np.zeros_like(estimated_params[:,0,0,0])\n",
    "count = 0\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if not (  (d[0]==4 and p[0]==1) or\n",
    "                  (d[0]==2 and p[0]==1) or\n",
    "                  (d[0]==1 and p[0]==2)    ):\n",
    "            err_other += abs(estimated_params[:,i_pde,id,ip])\n",
    "            count += 1\n",
    "\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==1 and p[0]==2:\n",
    "            plt.plot(eps[1:], abs(estimated_params[1:,i_pde,id,ip]-A_ex),\n",
    "                     label=r\"$e(A)$\", marker=\">\", markevery=20, color=\"blue\")\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==2 and p[0]==1:\n",
    "            plt.plot(eps[1:], abs(estimated_params[1:,i_pde,id,ip]-B_ex),\n",
    "                     label=r\"$e(B)$\", marker=\"o\", markevery=20, color=\"green\")\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==4 and p[0]==1:\n",
    "            plt.plot(eps[1:], abs(estimated_params[1:,i_pde,id,ip]-C_ex),\n",
    "                     label=r\"$e(C)$\", marker=\"d\", markevery=20, color=\"red\")\n",
    "plt.plot(eps[1:], err_other[1:]/count, marker=\"s\", markevery=20, color=\"black\", label=r\"$||e(\\mathbf{\\alpha}^*)||_1$\")\n",
    "plt.yscale('log')\n",
    "plt.ylabel(r'Error')\n",
    "plt.xlabel('Epochs')\n",
    "plt.legend(loc='upper center', bbox_to_anchor=(0.5, 1.4), ncol=2, fontsize=9)\n",
    "name = problem + \"_\" + \"coeff\"\n",
    "plt.savefig(name+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "\n",
    "print(\"total number of terms: \"+str(numPDE*len(ds)*len(ps)))\n",
    "\n",
    "error += err_other[-1]\n",
    "\n",
    "print(error)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b4b4e3d8-7e8e-43be-b71f-24d4d9f28465",
   "metadata": {},
   "source": [
    "### Discover PDE using PDE-FIND"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "id": "b38d55cf-9d06-4f70-9aa0-33ade42bb06c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['1', 'u_{x}', 'u_{xx}', 'u_{xxx}', 'u_{xxxx}', 'u', 'u^2', 'uu_{x}', 'u^2u_{x}', 'uu_{xx}', 'u^2u_{xx}', 'uu_{xxx}', 'u^2u_{xxx}', 'uu_{xxxx}', 'u^2u_{xxxx}']\n",
      "u_t = (-0.500019 +0.000000i)u_{xx}\n",
      "    + (0.500000 +0.000000i)u_{xxxx}\n",
      "    + (0.042182 +0.000000i)u\n",
      "    + (1.972311 +0.000000i)uu_{x}\n",
      "    + (-0.001448 +0.000000i)u^2u_{xx}\n",
      "    + (-0.000331 +0.000000i)uu_{xxx}\n",
      "    + (-0.000021 +0.000000i)u^2u_{xxxx}\n",
      "   \n",
      "Execution time: 1.6387300491333008\n"
     ]
    }
   ],
   "source": [
    "import sys; sys.path.append('PDE-FIND/')\n",
    "from PDE_FIND import *\n",
    "import scipy.io as sio\n",
    "import itertools\n",
    "\n",
    "start_time = time.time()\n",
    "\n",
    "#(numPDE, Nt, Nx0, Nx1, ...)\n",
    "nt = Nt-1\n",
    "\n",
    "# Take up to second order derivatives.\n",
    "u = np.zeros((nt, Nx))\n",
    "ut = np.zeros((nt, Nx))\n",
    "ux = np.zeros((nt, Nx))\n",
    "uxx = np.zeros((nt, Nx))\n",
    "uxxx = np.zeros((nt, Nx))\n",
    "uxxxx = np.zeros((nt, Nx))\n",
    "\n",
    "for i in range(nt):\n",
    "    u[i,:] = fs[0, i, :]\n",
    "    ut[i,:] = (fs[0, i+1, :]-fs[0, i, :])/dt\n",
    "    ux[i,:] = np.gradient(u[i,:], axis=0) / dx[0]\n",
    "    uxx[i,:] = np.gradient( np.gradient(u[i,:],axis=0), axis=0) / dx[0]**2\n",
    "    uxxx[i,:] = np.gradient( np.gradient( np.gradient(u[i,:],axis=0), axis=0), axis=0) / dx[0]**3\n",
    "    uxxxx[i,:] = np.gradient( np.gradient( np.gradient( np.gradient(u[i,:],axis=0), axis=0), axis=0), axis=0) / dx[0]**4\n",
    "\n",
    "u = u.reshape((nt * Nx, 1))\n",
    "ut = ut.reshape((nt * Nx, 1))\n",
    "ux = ux.reshape((nt * Nx, 1))\n",
    "uxx = uxx.reshape((nt * Nx, 1))\n",
    "uxxx = uxxx.reshape((nt * Nx, 1))\n",
    "uxxxx = uxxxx.reshape((nt * Nx, 1))\n",
    "\n",
    "num_points = nt * Nx\n",
    "\n",
    "X_data = np.hstack([u])\n",
    "X_ders = np.hstack([np.ones((num_points,1)), ux, uxx, uxxx, uxxxx])\n",
    "X_ders_descr = ['','u_{x}', 'u_{xx}', 'u_{xxx}', 'u_{xxxx}']\n",
    "X, description = build_Theta(X_data, X_ders, X_ders_descr, 2, data_description = ['u'])\n",
    "print(['1'] + description[1:])\n",
    "\n",
    "c = TrainSTRidge(X,ut,10**-6,1)\n",
    "print_pde(c, description)\n",
    "\n",
    "end_time = time.time()\n",
    "print(\"Execution time: \"+str(end_time-start_time))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "44876e15-8197-4a33-8c20-d8c6870cb335",
   "metadata": {},
   "source": [
    "## Reaction Diffusion Equation"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7ea41747-c869-4c44-ad2e-f556e62ab543",
   "metadata": {},
   "source": [
    "In order to show scalability and accuracy of the adjoint method for a system of PDEs in a higher dimensional space, let us consider a system of PDEs given by\n",
    "\\begin{flalign}\n",
    "    &\\frac{\\partial u}{\\partial t} + c_0^u\\nabla^2_{{x_1}}[u] + c_1^u\\nabla^2_{{x_2}}[u] + R^u(u, v) = 0,\\\\\n",
    "    &\\frac{\\partial v}{\\partial t} + c_0^v\\nabla^2_{{x_1}}[v] + c_1^v\\nabla^2_{{x_2}}[v] + R^v(u, v) = 0\n",
    "  \\end{flalign}\n",
    "  where\n",
    "  \\begin{flalign}\n",
    "    R^u(u, v) &= c^u_2 u + c^u_3 u^3 + c^u_4  uv^2 + c^u_5  u^2v + c^u_6 v^3\n",
    "    \\\\\n",
    "    R^v(u, v) &= c^v_2 v + c^v_3 v^3 + c^v_4  vu^2 + c^v_5  v^2u + c^v_6 u^3\n",
    "\\end{flalign}"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "73e38da0-7c7e-4bbf-84da-ff6abd557fc8",
   "metadata": {},
   "source": [
    "### Generate Data\n",
    "We construct the data set by solving the system of PDEs using a 2nd order Finite Difference scheme with initial values\n",
    "\\begin{flalign}\n",
    "    &u_0 = a \\sin\\left(\\frac{4 \\pi x_1}{L_1}\\right)  \\cos\\left(\\frac{3\\pi x_2}{L_2}\\right) \\left(L_1x_1-x_1^2\\right)  \\left(L_2x_2-x_2^2\\right)\\\\\n",
    "    &v_0 =a \\cos\\left(\\frac{4 \\pi x_1}{L_1}\\right)  \\sin\\left(\\frac{3\\pi x_2}{ L_2}\\right)\\left(L_1x_1-x_1^2\\right)\\left(L_2x_2-x_2^2\\right)\n",
    "\\end{flalign}\n",
    "where $a=100$, and the coefficients\n",
    "\\begin{flalign}\n",
    "    &\\boldsymbol c^u = [c^u_i]_{i=0}^6 = [-0.1, -0.2, -0.3, -0.4, 0.1, 0.2, 0.3]\\\\\n",
    "    &\\boldsymbol c^v = [c^v_i]_{i=0}^6 = [-0.4, -0.3, -0.2, -0.1, 0.3, 0.2, 0.1].\n",
    "\\end{flalign}\n",
    "We generate data by solving the system of PDEs using the Finite Difference method and forward Euler scheme for $N_t=25$ steps with a time step size of $\\Delta t=10^{-6}$, and in the domain $\\Omega=[0,L_1]\\times [0,L_2]$ where $L_1=L_2=1$ which is discretized using a uniform grid with $N_{x_1}\\times N_{x_2}=50^2$ nodes leading to mesh size $\\Delta x_1=\\Delta x_2 = 0.02$."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "id": "5d65cd9e-42ef-4019-8816-97a96ed7c0c2",
   "metadata": {},
   "outputs": [],
   "source": [
    "## 2D, 2PDE Reaction_diffusion_equation\n",
    "\n",
    "# u_t + cu0 * u_xx + cu1 * u_yy + cu2 * u + cu3 * u^3 + cu4 * u*v^2 + cu5 * u^2*v + cu6 * v^3 = 0\n",
    "# v_t + cv0 * v_xx + cv1 * v_yy + cv2 * v + cv3 * v^3 + cv4 * v*u^2 + cv5 * v^2*u + cv6 * u^3 = 0\n",
    "\n",
    "Nx0 = 50  # Number of grid points in x-direction\n",
    "Nx1 = 50  # Number of grid points in y-direction\n",
    "Lx0 = 1.0  # Domain size in x-direction\n",
    "Lx1 = 1.0  # Domain size in y-direction\n",
    "V = Lx0*Lx1\n",
    "dt = 0.000001  # Time step size\n",
    "Nt = 50\n",
    "\n",
    "# Discretize the spatial domain\n",
    "x0 = np.linspace(0, Lx0, Nx0)\n",
    "x1 = np.linspace(0, Lx1, Nx1)\n",
    "x = np.array([x0, x1])\n",
    "dx0 = x0[1] - x0[0]\n",
    "dx1 = x1[1] - x1[0]\n",
    "X0, X1 = np.meshgrid(x0, x1)\n",
    "dx = np.array([dx0, dx1])\n",
    "\n",
    "# Set initial conditions\n",
    "f0 = np.array([np.sin(4*np.pi*X0/Lx0) * np.cos(3*np.pi * X1 / Lx1) * X0 * (Lx0-X0) * X1 * (Lx1-X1) * 100,\n",
    "               np.cos(4*np.pi*X0/Lx0) * np.sin(3*np.pi * X1 / Lx1) * X0 * (Lx0-X0) * X1 * (Lx1-X1) * 100])\n",
    "\n",
    "def Reaction_diffusion_equation(coefu, coefv, u0_m, v0_m, dx_m, dy_m, dt_m, Nt_m):\n",
    "    u_m = np.zeros((Nt_m, u0_m.shape[0], u0_m.shape[1]))# (Nt, Nx, Ny)\n",
    "    v_m = np.zeros((Nt_m, v0_m.shape[0], v0_m.shape[1]))#\n",
    "    u_m[0,:,:] = u0_m\n",
    "    v_m[0,:,:] = v0_m\n",
    "    for i in range(Nt_m-1):\n",
    "        u_m[i+1,:,:] =  u_m[i,:,:]\n",
    "        u_m[i+1,:,:] += - dt_m*coefu[0] * np.gradient( np.gradient(u_m[i,:,:],axis=0), axis=0) / dx_m**2 \n",
    "        u_m[i+1,:,:] += - dt_m*coefu[1] * np.gradient( np.gradient(u_m[i,:,:],axis=1), axis=1) / dy_m**2\n",
    "        u_m[i+1,:,:] += - dt_m*coefu[2] * u_m[i,:,:]\n",
    "        u_m[i+1,:,:] += - dt_m*coefu[3] * u_m[i,:,:]**3\n",
    "        u_m[i+1,:,:] += - dt_m*coefu[4] * u_m[i,:,:]    * v_m[i,:,:]**2\n",
    "        u_m[i+1,:,:] += - dt_m*coefu[5] * u_m[i,:,:]**2 * v_m[i,:,:]\n",
    "        u_m[i+1,:,:] += - dt_m*coefu[6] * v_m[i,:,:]**3\n",
    "        \n",
    "        v_m[i+1,:,:] =  v_m[i,:,:]\n",
    "        v_m[i+1,:,:] += - dt_m*coefv[0] * np.gradient( np.gradient(v_m[i,:,:],axis=0), axis=0) / dx_m**2 \n",
    "        v_m[i+1,:,:] += - dt_m*coefv[1] * np.gradient( np.gradient(v_m[i,:,:],axis=1), axis=1) / dy_m**2\n",
    "        v_m[i+1,:,:] += - dt_m*coefv[2] * v_m[i,:,:]\n",
    "        v_m[i+1,:,:] += - dt_m*coefv[3] * v_m[i,:,:]**3\n",
    "        v_m[i+1,:,:] += - dt_m*coefv[4] * v_m[i,:,:]    * u_m[i,:,:]**2\n",
    "        v_m[i+1,:,:] += - dt_m*coefv[5] * v_m[i,:,:]**2 * u_m[i,:,:]\n",
    "        v_m[i+1,:,:] += - dt_m*coefv[6] * u_m[i,:,:]**3\n",
    "    return u_m, v_m\n",
    "\n",
    "coefu = [-0.1, -0.2, -0.3, -0.4, 0.1, 0.2, 0.3]\n",
    "coefv = [-0.4, -0.3, -0.2, -0.1, 0.3, 0.2, 0.1]\n",
    "coef = np.array([coefu, coefv])\n",
    "# Generate data\n",
    "fs0, fs1 = Reaction_diffusion_equation(coefu, coefv, f0[0,:], f0[1,:], dx0, dx1, dt, Nt)\n",
    "fs = np.array([fs0, fs1])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8f46d1c3-6303-4272-a94b-6ec00f857bff",
   "metadata": {},
   "source": [
    "### Discover PDE using adjoint method"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "id": "47fc3da2-f0d9-40b8-a1d4-ae092ab82b64",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "total number of terms: 80\n",
      "8.889200058668928e-09\n",
      "Execution time: 372.8263478279114\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "ds = np.array([[0,0], [1,0], [0,1], [2,0], [0,2]])\n",
    "ps = np.array([[1,0], [0,1], [2,0], [0,2], [2,1], [1,2], [3,0], [0,3]])\n",
    "\n",
    "beta = 0.004\n",
    "D = 2\n",
    "P = 3\n",
    "numPDE = fs.shape[0]\n",
    "learning_rates = np.ones((numPDE, len(ds),len(ps)))\n",
    "for i, d in enumerate(ds):\n",
    "    for j, p in enumerate(ps):\n",
    "        learning_rates[:,i,j] = beta * ( min(dx)**(sum(d)-D) ) *10**(P-sum(p))\n",
    "        if sum(d) == 0:\n",
    "            learning_rates[:,i,j] *= 70\n",
    "            \n",
    "start_time = time.time()\n",
    "estimated_params, eps = AdjointFindPDE(fs, dx, data_dt=dt, avg=False, gamma=1e-3, epochs=400, epthr=400, learning_rates=learning_rates, ds=ds, ps=ps, V=1, tol=1e-15, eps0=1e-16)\n",
    "end_time = time.time()\n",
    "\n",
    "\n",
    "# u_t + cu0 * u_xx + cu1 * u_yy + cu2 * u + cu3 * u^3 + cu4 * u*v^2 + cu5 * u^2*v + cu6 * v^3 = 0\n",
    "# v_t + cv0 * v_xx + cv1 * v_yy + cv2 * v + cv3 * v^3 + cv4 * v*u^2 + cv5 * v^2*u + cv6 * u^3 = 0\n",
    "problem = \"2D_reaction\"\n",
    "## coeff of u\n",
    "totalerror = 0\n",
    "i_pde = 0\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==2 and p[0]==1 and p[1]==0:\n",
    "            plt.plot(abs(estimated_params[:,i_pde,id,ip]-coefu[0]),#/abs(coefu[0]),\n",
    "                     label=r\"$e(c^u_0)$\", marker=\"o\", markevery=20)\n",
    "            totalerror += abs(estimated_params[-1,i_pde,id,ip]-coefu[0])\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[1]==2 and p[0]==1 and p[1]==0:\n",
    "            plt.plot(abs(estimated_params[:,i_pde,id,ip]-coefu[1]),#/abs(coefu[1]),\n",
    "                     label=r\"$e(c^u_1)$\", marker=\">\", markevery=20)\n",
    "            totalerror += abs(estimated_params[-1,i_pde,id,ip]-coefu[1])\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==0 and d[1]==0 and p[0]==1 and p[1]==0:\n",
    "            plt.plot(abs(estimated_params[:,i_pde,id,ip]-coefu[2]),#/abs(coefu[2]),\n",
    "                     label=r\"$e(c^u_2)$\", marker=\"d\", markevery=20)\n",
    "            totalerror += abs(estimated_params[-1,i_pde,id,ip]-coefu[2])\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==0 and d[1]==0 and p[0]==3 and p[1]==0:\n",
    "            plt.plot(abs(estimated_params[:,i_pde,id,ip]-coefu[3]),#/abs(coefu[3]),\n",
    "                     label=r\"$e(c^u_3)$\", marker=\"^\", markevery=20)\n",
    "            totalerror += abs(estimated_params[-1,i_pde,id,ip]-coefu[3])\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==0 and d[1]==0 and p[0]==1 and p[1]==2:\n",
    "            plt.plot(abs(estimated_params[:,i_pde,id,ip]-coefu[4]),#/abs(coefu[4]),\n",
    "                     label=r\"$e(c^u_4)$\", marker=\"*\", markevery=20)\n",
    "            totalerror += abs(estimated_params[-1,i_pde,id,ip]-coefu[4])\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==0 and d[1]==0 and p[0]==2 and p[1]==1:\n",
    "            plt.plot(abs(estimated_params[:,i_pde,id,ip]-coefu[5]),#/abs(coefu[5]),\n",
    "                     label=r\"$e(c^u_5)$\", marker=\"s\", markevery=20)\n",
    "            totalerror += abs(estimated_params[-1,i_pde,id,ip]-coefu[5])\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==0 and d[1]==0 and p[0]==0 and p[1]==3:\n",
    "            plt.plot(abs(estimated_params[:,i_pde,id,ip]-coefu[6]),#/abs(coefu[6]),\n",
    "                     label=r\"$e(c^u_6)$\", marker=\"<\", markevery=20)\n",
    "            totalerror += abs(estimated_params[-1,i_pde,id,ip]-coefu[6])\n",
    "plt.yscale('log')\n",
    "plt.ylabel(r'$e(\\mathbf{c}^u)$')\n",
    "plt.xlabel('Epochs')\n",
    "#plt.legend(loc='center left', bbox_to_anchor=(1, 0.5))\n",
    "plt.legend(loc='upper center', bbox_to_anchor=(0.5, 1.6), ncol=2, fontsize=9)\n",
    "name = problem + \"_\" + \"c_u\"\n",
    "#plt.savefig(name+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "\n",
    "## other coeff of u\n",
    "i_pde = 0\n",
    "\n",
    "\n",
    "err_otheru = np.zeros_like(estimated_params[:,0,0,0])\n",
    "countu = 0\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if not (   (d[0]==2 and p[0]==1 and p[1]==0)\n",
    "                or (d[1]==2 and p[0]==1 and p[1]==0)\n",
    "                or (d[0]==0 and d[1]==0 and p[0]==1 and p[1]==0)\n",
    "                or (d[0]==0 and d[1]==0 and p[0]==3 and p[1]==0)\n",
    "                or (d[0]==0 and d[1]==0 and p[0]==1 and p[1]==2)\n",
    "                or (d[0]==0 and d[1]==0 and p[0]==2 and p[1]==1)\n",
    "                or (d[0]==0 and d[1]==0 and p[0]==0 and p[1]==3) ) :\n",
    "                    err_otheru += abs(estimated_params[:,i_pde,id,ip])\n",
    "                    countu += 1\n",
    "\n",
    "## coeff of v\n",
    "i_pde = 1\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==2 and p[0]==0 and p[1]==1:\n",
    "            plt.plot(abs(estimated_params[:,i_pde,id,ip]-coefv[0]),#/abs(coefv[0]),\n",
    "                     label=r\"$e(c^v_0)$\", marker=\"o\", markevery=20)\n",
    "            totalerror += abs(estimated_params[-1,i_pde,id,ip]-coefv[0])\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[1]==2 and p[0]==0 and p[1]==1:\n",
    "            plt.plot(abs(estimated_params[:,i_pde,id,ip]-coefv[1]),#/abs(coefv[1]),\n",
    "                     label=r\"$e(c^v_1)$\", marker=\">\", markevery=20)\n",
    "            totalerror += abs(estimated_params[-1,i_pde,id,ip]-coefv[1])\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==0 and d[1]==0 and p[0]==0 and p[1]==1:\n",
    "            plt.plot(abs(estimated_params[:,i_pde,id,ip]-coefv[2]),#/abs(coefv[2]),\n",
    "                     label=r\"$e(c^v_2)$\", marker=\"d\", markevery=20)\n",
    "            totalerror += abs(estimated_params[-1,i_pde,id,ip]-coefv[2])\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==0 and d[1]==0 and p[0]==0 and p[1]==3:\n",
    "            plt.plot(abs(estimated_params[:,i_pde,id,ip]-coefv[3]),#/abs(coefv[3]),\n",
    "                     label=r\"$e(c^v_3)$\", marker=\"^\", markevery=20)\n",
    "            totalerror += abs(estimated_params[-1,i_pde,id,ip]-coefv[3])\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==0 and d[1]==0 and p[0]==2 and p[1]==1:\n",
    "            plt.plot(abs(estimated_params[:,i_pde,id,ip]-coefv[4]),#/abs(coefv[4]),\n",
    "                     label=r\"$e(c^v_4)$\", marker=\"*\", markevery=20)\n",
    "            totalerror += abs(estimated_params[-1,i_pde,id,ip]-coefv[4])\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==0 and d[1]==0 and p[0]==1 and p[1]==2:\n",
    "            plt.plot(abs(estimated_params[:,i_pde,id,ip]-coefv[5]),#/abs(coefv[5]),\n",
    "                     label=r\"$e(c^v_5)$\", marker=\"s\", markevery=20)\n",
    "            totalerror += abs(estimated_params[-1,i_pde,id,ip]-coefv[5])\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==0 and d[1]==0 and p[0]==3 and p[1]==0:\n",
    "            plt.plot(abs(estimated_params[:,i_pde,id,ip]-coefv[6]),#/abs(coefv[6]),\n",
    "                     label=r\"$e(c^v_6)$\", marker=\"<\", markevery=20)\n",
    "            totalerror += abs(estimated_params[-1,i_pde,id,ip]-coefv[6])\n",
    "plt.yscale('log')\n",
    "plt.ylabel(r'$e(\\mathbf{c}^v)$')\n",
    "plt.xlabel('Epochs')\n",
    "#plt.legend(loc='center left', bbox_to_anchor=(1, 0.5))\n",
    "plt.legend(loc='upper center', bbox_to_anchor=(0.5, 1.6), ncol=2, fontsize=9)\n",
    "name = problem + \"_\" + \"c_v\"\n",
    "#plt.savefig(name+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "\n",
    "err_otherv = np.zeros_like(estimated_params[:,1,0,0])\n",
    "countv = 0\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if not (   (d[0]==2 and p[0]==0 and p[1]==1)\n",
    "                or (d[1]==2 and p[0]==0 and p[1]==1)\n",
    "                or (d[0]==0 and d[1]==0 and p[0]==0 and p[1]==1)\n",
    "                or (d[0]==0 and d[1]==0 and p[0]==0 and p[1]==3)\n",
    "                or (d[0]==0 and d[1]==0 and p[0]==2 and p[1]==1)\n",
    "                or (d[0]==0 and d[1]==0 and p[0]==1 and p[1]==2)\n",
    "                or (d[0]==0 and d[1]==0 and p[0]==3 and p[1]==0) ) :\n",
    "                    err_otherv += abs(estimated_params[:,i_pde,id,ip])\n",
    "                    countv += 1\n",
    "            \n",
    "\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "\n",
    "plt.plot(eps[2:], err_otheru[2:]/countu, marker=\"s\", markevery=20, label=r\"PDE on $u$\", color=\"blue\")\n",
    "plt.plot(eps[2:], err_otherv[2:]/countv, marker=\"o\", markevery=20, label=r\"PDE on $v$\", color=\"black\")\n",
    "plt.legend()\n",
    "plt.yscale('log')\n",
    "plt.ylabel(r'$||e(\\mathbf{\\alpha}^*)||_1$')\n",
    "plt.xlabel('Epochs')\n",
    "name = problem + \"_\" + \"other_alphas\"\n",
    "#plt.savefig(name+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "\n",
    "print(\"total number of terms: \"+str(numPDE*len(ds)*len(ps)))\n",
    "\n",
    "totalerror += err_otheru[-1]\n",
    "totalerror += err_otherv[-1]\n",
    "print(totalerror)\n",
    "\n",
    "print(\"Execution time: \"+str(end_time-start_time))\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "aee1ab4f-2aa4-418c-8cb4-f4ef79e7da5e",
   "metadata": {},
   "source": [
    "### Discover PDE using PDE-FIND"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "id": "8dddbe5b-e858-4de5-b533-5ad48fd34bb0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "49\n",
      "50\n",
      "['1', 'u_{x}', 'u_{y}', 'u_{xx}', 'u_{xy}', 'u_{yy}', 'v_{x}', 'v_{y}', 'v_{xx}', 'v_{xy}', 'v_{yy}', 'v', 'u', 'v^2', 'uv', 'u^2', 'v^3', 'uv^2', 'u^2v', 'u^3', 'vu_{x}', 'uu_{x}', 'v^2u_{x}', 'uvu_{x}', 'u^2u_{x}', 'v^3u_{x}', 'uv^2u_{x}', 'u^2vu_{x}', 'u^3u_{x}', 'vu_{y}', 'uu_{y}', 'v^2u_{y}', 'uvu_{y}', 'u^2u_{y}', 'v^3u_{y}', 'uv^2u_{y}', 'u^2vu_{y}', 'u^3u_{y}', 'vu_{xx}', 'uu_{xx}', 'v^2u_{xx}', 'uvu_{xx}', 'u^2u_{xx}', 'v^3u_{xx}', 'uv^2u_{xx}', 'u^2vu_{xx}', 'u^3u_{xx}', 'vu_{xy}', 'uu_{xy}', 'v^2u_{xy}', 'uvu_{xy}', 'u^2u_{xy}', 'v^3u_{xy}', 'uv^2u_{xy}', 'u^2vu_{xy}', 'u^3u_{xy}', 'vu_{yy}', 'uu_{yy}', 'v^2u_{yy}', 'uvu_{yy}', 'u^2u_{yy}', 'v^3u_{yy}', 'uv^2u_{yy}', 'u^2vu_{yy}', 'u^3u_{yy}', 'vv_{x}', 'uv_{x}', 'v^2v_{x}', 'uvv_{x}', 'u^2v_{x}', 'v^3v_{x}', 'uv^2v_{x}', 'u^2vv_{x}', 'u^3v_{x}', 'vv_{y}', 'uv_{y}', 'v^2v_{y}', 'uvv_{y}', 'u^2v_{y}', 'v^3v_{y}', 'uv^2v_{y}', 'u^2vv_{y}', 'u^3v_{y}', 'vv_{xx}', 'uv_{xx}', 'v^2v_{xx}', 'uvv_{xx}', 'u^2v_{xx}', 'v^3v_{xx}', 'uv^2v_{xx}', 'u^2vv_{xx}', 'u^3v_{xx}', 'vv_{xy}', 'uv_{xy}', 'v^2v_{xy}', 'uvv_{xy}', 'u^2v_{xy}', 'v^3v_{xy}', 'uv^2v_{xy}', 'u^2vv_{xy}', 'u^3v_{xy}', 'vv_{yy}', 'uv_{yy}', 'v^2v_{yy}', 'uvv_{yy}', 'u^2v_{yy}', 'v^3v_{yy}', 'uv^2v_{yy}', 'u^2vv_{yy}', 'u^3v_{yy}']\n",
      "time: 114.04069876670837\n",
      "u_t = (0.100000 +0.000000i)u_{xx}\n",
      "    + (0.200000 +0.000000i)u_{yy}\n",
      "    + (0.000000 +0.000000i)v_{xy}\n",
      "    + (0.300000 +0.000000i)u\n",
      "    + (-0.300000 +0.000000i)v^3\n",
      "    + (-0.100000 +0.000000i)uv^2\n",
      "    + (-0.200000 +0.000000i)u^2v\n",
      "    + (0.400000 +0.000000i)u^3\n",
      "    + (-0.000000 +0.000000i)v^2u_{xx}\n",
      "    + (0.000000 +0.000000i)u^2u_{xx}\n",
      "    + (-0.000000 +0.000000i)uv^2u_{xy}\n",
      "    + (-0.000000 +0.000000i)u^3u_{xy}\n",
      "    + (-0.000000 +0.000000i)v^2u_{yy}\n",
      "    + (0.000000 +0.000000i)u^2u_{yy}\n",
      "    + (0.000000 +0.000000i)uv^2v_{xx}\n",
      "    + (0.000000 +0.000000i)u^3v_{xx}\n",
      "    + (0.000000 +0.000000i)v^2v_{xy}\n",
      "    + (-0.000000 +0.000000i)u^2v_{xy}\n",
      "    + (0.000000 +0.000000i)uv^2v_{yy}\n",
      "    + (0.000000 +0.000000i)u^3v_{yy}\n",
      "   \n",
      "time: 143.6644139289856\n",
      "v_t = (-0.000000 +0.000000i)\n",
      "    + (0.000000 +0.000000i)u_{xy}\n",
      "    + (0.400000 +0.000000i)v_{xx}\n",
      "    + (0.300000 +0.000000i)v_{yy}\n",
      "    + (0.200000 +0.000000i)v\n",
      "    + (-0.000000 +0.000000i)v^2\n",
      "    + (-0.000000 +0.000000i)u^2\n",
      "    + (0.100000 +0.000000i)v^3\n",
      "    + (-0.200000 +0.000000i)uv^2\n",
      "    + (-0.300000 +0.000000i)u^2v\n",
      "    + (-0.100000 +0.000000i)u^3\n",
      "    + (0.000000 +0.000000i)uu_{xx}\n",
      "    + (-0.000000 +0.000000i)uvu_{xx}\n",
      "    + (0.000000 +0.000000i)u^2u_{xx}\n",
      "    + (0.000000 +0.000000i)uv^2u_{xx}\n",
      "    + (-0.000000 +0.000000i)u^2vu_{xx}\n",
      "    + (-0.000000 +0.000000i)u^3u_{xx}\n",
      "    + (0.000000 +0.000000i)vu_{xy}\n",
      "    + (-0.000000 +0.000000i)v^2u_{xy}\n",
      "    + (0.000000 +0.000000i)u^2u_{xy}\n",
      "    + (0.000000 +0.000000i)v^3u_{xy}\n",
      "    + (-0.000000 +0.000000i)uv^2u_{xy}\n",
      "    + (0.000000 +0.000000i)u^2vu_{xy}\n",
      "    + (-0.000000 +0.000000i)u^3u_{xy}\n",
      "    + (0.000000 +0.000000i)uu_{yy}\n",
      "    + (-0.000000 +0.000000i)uvu_{yy}\n",
      "    + (0.000000 +0.000000i)u^2u_{yy}\n",
      "    + (0.000000 +0.000000i)uv^2u_{yy}\n",
      "    + (-0.000000 +0.000000i)u^2vu_{yy}\n",
      "    + (-0.000000 +0.000000i)vv_{xx}\n",
      "    + (0.000000 +0.000000i)v^2v_{xx}\n",
      "    + (-0.000000 +0.000000i)u^2v_{xx}\n",
      "    + (-0.000000 +0.000000i)v^3v_{xx}\n",
      "    + (0.000000 +0.000000i)uv^2v_{xx}\n",
      "    + (-0.000000 +0.000000i)u^2vv_{xx}\n",
      "    + (0.000000 +0.000000i)u^3v_{xx}\n",
      "    + (-0.000000 +0.000000i)uv_{xy}\n",
      "    + (0.000000 +0.000000i)uvv_{xy}\n",
      "    + (-0.000000 +0.000000i)u^2v_{xy}\n",
      "    + (-0.000000 +0.000000i)uv^2v_{xy}\n",
      "    + (0.000000 +0.000000i)u^2vv_{xy}\n",
      "    + (0.000000 +0.000000i)u^3v_{xy}\n",
      "    + (-0.000000 +0.000000i)vv_{yy}\n",
      "    + (0.000000 +0.000000i)v^2v_{yy}\n",
      "    + (-0.000000 +0.000000i)u^2v_{yy}\n",
      "    + (-0.000000 +0.000000i)v^3v_{yy}\n",
      "    + (0.000000 +0.000000i)uv^2v_{yy}\n",
      "    + (-0.000000 +0.000000i)u^2vv_{yy}\n",
      "    + (0.000000 +0.000000i)u^3v_{yy}\n",
      "   \n",
      "Execution time: 176.77932977676392\n"
     ]
    }
   ],
   "source": [
    "import sys; sys.path.append('PDE-FIND/')\n",
    "from PDE_FIND import *\n",
    "import scipy.io as sio\n",
    "import itertools\n",
    "\n",
    "start_time = time.time()\n",
    "\n",
    "#(numPDE, Nt, Nx0, Nx1, ...)\n",
    "nt = Nt-1\n",
    "num_points = Nx0*Nx1*nt\n",
    "\n",
    "print(nt)\n",
    "print(Nx0)\n",
    "# Take up to second order derivatives.\n",
    "u = np.zeros((nt, Nx0, Nx1))\n",
    "v = np.zeros((nt, Nx0, Nx1))\n",
    "ut = np.zeros((nt, Nx0, Nx1))\n",
    "vt = np.zeros((nt, Nx0, Nx1))\n",
    "ux = np.zeros((nt, Nx0, Nx1))\n",
    "uy = np.zeros((nt, Nx0, Nx1))\n",
    "uxx = np.zeros((nt, Nx0, Nx1))\n",
    "uxy = np.zeros((nt, Nx0, Nx1))\n",
    "uyy = np.zeros((nt, Nx0, Nx1))\n",
    "vx = np.zeros((nt, Nx0, Nx1))\n",
    "vy = np.zeros((nt, Nx0, Nx1))\n",
    "vxx = np.zeros((nt, Nx0, Nx1))\n",
    "vxy = np.zeros((nt, Nx0, Nx1))\n",
    "vyy = np.zeros((nt, Nx0, Nx1))\n",
    "\n",
    "for i in range(nt):\n",
    "    u[i,:] = fs[0, i, :]\n",
    "    v[i,:] = fs[1, i, :]\n",
    "\n",
    "    ut[i,:] = (fs[0, i+1, :]-fs[0, i, :])/dt\n",
    "    vt[i,:] = (fs[1, i+1, :]-fs[1, i, :])/dt\n",
    "    \n",
    "    ux[i,:] = np.gradient(u[i,:], axis=0) / dx[0]\n",
    "    uy[i,:] = np.gradient(u[i,:], axis=1) / dx[1]\n",
    "    uxx[i,:] = np.gradient( np.gradient(u[i,:],axis=0), axis=0) / dx[0]**2\n",
    "    uyy[i,:] = np.gradient( np.gradient(u[i,:],axis=1), axis=1) / dx[1]**2\n",
    "    uxy[i,:] = np.gradient( np.gradient(u[i,:],axis=0), axis=1) / dx[0]/ dx[1]\n",
    "\n",
    "    vx[i,:] = np.gradient(v[i,:], axis=0) / dx[0]\n",
    "    vy[i,:] = np.gradient(v[i,:], axis=1) / dx[1]\n",
    "    vxx[i,:] = np.gradient( np.gradient(v[i,:],axis=0), axis=0) / dx[0]**2\n",
    "    vyy[i,:] = np.gradient( np.gradient(v[i,:],axis=1), axis=1) / dx[1]**2\n",
    "    vxy[i,:] = np.gradient( np.gradient(v[i,:],axis=0), axis=1) / dx[0]/ dx[1]\n",
    "\n",
    "u = u.reshape((nt * Nx0 * Nx1, 1))\n",
    "v = v.reshape((nt * Nx0 * Nx1, 1))\n",
    "\n",
    "ut = ut.reshape((nt * Nx0 * Nx1, 1))\n",
    "vt = vt.reshape((nt * Nx0 * Nx1, 1))\n",
    "\n",
    "ux = ux.reshape((nt * Nx0 * Nx1, 1))\n",
    "uy = uy.reshape((nt * Nx0 * Nx1, 1))\n",
    "uxx = uxx.reshape((nt * Nx0 * Nx1, 1))\n",
    "uyy = uyy.reshape((nt * Nx0 * Nx1, 1))\n",
    "uxy = uxy.reshape((nt * Nx0 * Nx1, 1))\n",
    "\n",
    "vx = vx.reshape((nt * Nx0 * Nx1, 1))\n",
    "vy = vy.reshape((nt * Nx0 * Nx1, 1))\n",
    "vxx = vxx.reshape((nt * Nx0 * Nx1, 1))\n",
    "vyy = vyy.reshape((nt * Nx0 * Nx1, 1))\n",
    "vxy = vxy.reshape((nt * Nx0 * Nx1, 1))\n",
    "\n",
    "X_data = np.hstack([u,v])\n",
    "X_ders = np.hstack([np.ones((num_points,1)), ux, uy, uxx, uxy, uyy, vx, vy, vxx, vxy, vyy])\n",
    "X_ders_descr = ['','u_{x}', 'u_{y}','u_{xx}','u_{xy}','u_{yy}','v_{x}', 'v_{y}','v_{xx}','v_{xy}','v_{yy}']\n",
    "X, description = build_Theta(X_data, X_ders, X_ders_descr, 3, data_description = ['u','v'])\n",
    "print(['1'] + description[1:])\n",
    "\n",
    "print(\"time: \"+str(time.time()-start_time))\n",
    "\n",
    "cu = TrainSTRidge(X,ut,5*10**-5,1)\n",
    "print_pde(cu, description)\n",
    "\n",
    "print(\"time: \"+str(time.time()-start_time))\n",
    "\n",
    "cv = TrainSTRidge(X,vt,5*10**-5,1)\n",
    "print_pde(cv, description, ut = 'v_t')\n",
    "\n",
    "end_time = time.time()\n",
    "print(\"Execution time: \"+str(end_time-start_time))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ba1d5cb8-295b-419f-8efd-8344fd6f647b",
   "metadata": {},
   "source": [
    "## Random Walk"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "63c84169-63c8-4727-89f4-3c9cd1c25651",
   "metadata": {},
   "source": [
    "Let us consider the recovery of the governing equation on probability density function (PDF) given samples of its underlying stochastic process. As an example, we consider the Ito process\n",
    "\\begin{flalign}\n",
    "    dX = A dt + \\sqrt{2D} dW\n",
    "\\end{flalign}\n",
    "where $A = 1$ is drift and  $D = 0.5$ is the diffusion coefficient, and $W$ denotes the standard Wiener process with $\\mathrm{Var}(dW)=\\Delta t$.  Let us denote the distribution of $X$ by $f$. Ito's lemma gives us the Fokker-Planck equation as the governing equation on the underlying probability density function\n",
    "\\begin{flalign}\n",
    "    \\frac{\\partial f}{\\partial t} + A \\frac{\\partial f}{\\partial x} - D \\frac{\\partial^2 f}{\\partial x^2} = 0~.\n",
    "\\end{flalign}"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b50d76bf-b4d3-42fa-ba46-9037ac8ef92a",
   "metadata": {},
   "source": [
    "### Generate Data\n",
    "We generate the data set by simulating the random walk using Euler-Maruyama scheme starting from $X(t=0)=0$ for $N_t=50$ steps with a time step size of $\\Delta t=0.01$. We estimate the PDF using histogram with $N_x=100$ bins and $N_\\mathrm{s}=1000$ samples."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "id": "88f253a8-4811-4245-b814-0c9df49bd7ea",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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ySefFMPDw0W5XC4+/PDDolqtFn/961+LZrN5wPn+8pe/iNnZ2WJkZKQYEBAgPv744+KPfvQj8f/9v/8nSb2eiPeXHN5Yk79c99/KysoSAYg1NTUuv2YopP585RYhkQ+RegmbiIju4XcREhEREXk5NlhEREREEmODRURERCQxNlhEREREEmODRURERCQxNlhEREREEmODRURERCQxNlhEREREEmODRURERCQxNlhEREREEmODRURERCQxNlhEREREEmODRURERCQx+WgXQETSur71j6NdglOT31w42iUQEXkEV7CIyGdt374dgiCgurra47nPnz+PJUuWIDw8HCEhIUhMTMShQ4eGNEdvby9yc3ORlJSEqKgoBAcHIzIyEvPnz8e+fftgNpvt4t9//30IgvDAR3JyspSXSUTDxBUsIvJZdXV1kMlkSEhI8GjekydPQqPRIDg4GOnp6Rg3bhwOHz4MrVaLa9euYdOmTS7NYzKZ8M4770ClUiE1NRWTJk3C119/jYqKCqxevRoHDx5ERUUFZLJ7PwsnJCQgPz9/wLk++ugjXLp0CRqNRrLrJKLhE0RRFEe7CCJyTW9vLwwGA2JiYhAcHDxgzHdpizAiIgITJkxAU1OTpPM+iMViwbRp03D9+nXU1tbamruuri6oVCq0tbWhpaUF0dHRg85ltVphsVgQGBjokOO5555DVVUVPv30U6Smpj5wnr6+PkRFRaGrqwvXr1/HI488MuzrI/qucuXzdSi4RUhEPmfDhg0QBAE3b95Ec3Oz3RbZlStX3Jq7srISra2tyMjIsFs5CwsLQ15eHvr6+rB//36X5pLJZA7NFQDI5XIsW7YMAHD16tVB5zl69Cg6Ozvx/PPPs7ki8hLcIiQin6NSqaDVaqHT6ZCSkoK5c+cCAARBQHx8vFtzV1VVAQAWL17sMNa/PXfq1KkR5bBarTh27BgAYMaMGYPGl5eXAwBefvnlEeUlIumwwSIin5ORkYH29nbodDqsX79+0C200tJS3Lp1y+X509LSnJ7r0uv1AIC4uDiHscjISISGhtpiXNXX14fCwkKIoojOzk588cUXaGpqwqpVqwY9tG40GvHFF19g8uTJSElJGVJeInIfNlhE5JPq6+sBALNnzx40trS0FEaj0eW5lUql0warq6sLwL0twYEoFApbjKv6+vqwa9cu258FQcDmzZtR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Lj8aGxudzrVo0SIAwIkTJxzGjh8/bhfzIEFBQVizZs2Aj/5/kJYuXYo1a9ZAqVQCAPr6+gA43oqh382bNyGTyRAQEDDset0d7y85vLEmT+Rwd03DeV94K95olMiH8Eaj97zxxhv46U9/imPHjtl+zdtTLBYLpk6divb2dqc3TWxubrb78G9tbYXZbEZsbKxd8+NMdnY29u/f73BDxYMHD+KHP/whnnzySVRXV9ttxbz77rtYt24d5s+fjzNnzgy7XnfH+0sOb6zJX67bGWfvC6lIfaNRbhESkc/p3xrMycnB8uXLERQUBLVa7dLK0UjJ5XKUl5dDo9EgKSnJ7ms/jEYjSkpKHP6hSE5OhtFohMFgGNFP3S+99BLeeecdnD59GvHx8Vi6dCnCw8NRX1+PyspKjB07Fnv27BlRve6O95cc3liTv1y33xCJyGfcuXNHvHz5snjnzp3RLmXUFRUViTExMaJcLhcBiAcOHPBo/nPnzokpKSmiQqEQx44dK6pUKvHgwYMDxkZHR4sARIPB4NLcWVlZIgCxpqbGYay3t1csKioSZ8+eLT700EOiXC4XH3vsMXHlypXi5cuXJanXE/H+ksMba/KX6/5bD3pfSEHqz1duERL5EKmXsImI6B5+FyERERGRl2ODRURERCQxNlhEREREEmODRURERCQxNlhEREREEmODRURERCQxNlhEREREEmODRURERCQxNlhEREREEmODRURERCQxNlhEREREEmODRURERCQxNlhEREREEpOPdgFEJK0vKmNHuwSnkp9tlXS+7du3o7CwEGfOnMH8+fMlnXsw58+fR35+Ps6ePQuz2YyZM2ciNzcXK1asGNG8xcXF2Lp1KwCgpqYGiYmJduNWqxVvv/029u7di6amJsjlciQkJGDz5s1YunTpiHITkXS4gkVEPquurg4ymQwJCQkezXvy5EnMnz8fZ86cwYoVK/Dqq6+io6MDWq0Wb7311rDnvXjxIvLz8xESEjLguCiKWLFiBX784x+ju7sba9asQXp6Opqbm/HCCy/g3/7t34adm4ikJYiiKI52EUTkmt7eXhgMBsTExCA4OHjAmO/SClZERAQmTJiApqYmSed9EIvFgmnTpuH69euora21NXddXV1QqVRoa2tDS0sLoqOjhzSv2WxGYmIiAgICEBcXhw8//NBhBeujjz7CSy+9hPnz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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "Ns = 10000\n",
    "m = 50\n",
    "n = 100\n",
    "length = n*Ns\n",
    "dt = 0.01\n",
    "c = 1.\n",
    "\n",
    "P = {}\n",
    "M = 0\n",
    "\n",
    "np.random.seed(0)\n",
    "pos = np.cumsum(np.sqrt(dt)*np.random.randn(length)) + c*dt*np.arange(length)\n",
    "\n",
    "A_ex = c\n",
    "D_ex = 0.5\n",
    "\n",
    "for i in range(m):\n",
    "    P[i] = []\n",
    "    \n",
    "for i in range(len(pos)-m):\n",
    "    \n",
    "    # center\n",
    "    y = pos[i+1:i+m+1] - pos[i]\n",
    "    M = max([M, max(abs(y))])\n",
    "    \n",
    "    # add to distribution\n",
    "    for j in range(m):\n",
    "        P[j].append(y[j])\n",
    "    \n",
    "bins = np.linspace(-M,M,n+1)\n",
    "x = np.linspace(M*(1/n-1),M*(1-1/n),n)\n",
    "dx = x[2]-x[1]\n",
    "T = np.linspace(0,dt*(m-1),m)\n",
    "U = np.zeros((n,m))\n",
    "for i in range(m):\n",
    "    U[:,i] = plt.hist(P[i],bins,label=r'$t = $' + str(i*dt+dt))[0]/float(dx*(len(pos)-m))\n",
    "\n",
    "plt.xlabel('Location')\n",
    "plt.ylabel(r'$f(x,t)$')\n",
    "plt.title(r'Histograms for $f(x,t)$')\n",
    "plt.legend(loc = 'upper right', fontsize = 14)\n",
    "\n",
    "Nt = U.shape[1]\n",
    "Nx = U.shape[0]\n",
    "L = x[-1]-x[0]\n",
    "fs = U.T\n",
    "\n",
    "fs = np.array([fs])\n",
    "dx = np.array([dx])\n",
    "x = np.array([x])\n",
    "\n",
    "fs0 = fs.copy()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3cf98b6c-9af1-4362-ad26-1bfc7f4f7611",
   "metadata": {},
   "source": [
    "Next, we denoise the data set using Singular Value Decomposition:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 108,
   "id": "441674e8-4340-4b78-b86c-b7bc3b3e23b8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def condition(x): return x < thr\n",
    "\n",
    "ufn,sigmafn,vfn = np.linalg.svd(fs[0,:,:].T, full_matrices=False); vfn = vfn.T\n",
    "\n",
    "plt.figure()\n",
    "plt.semilogy(sigmafn, marker=\"o\")\n",
    "\n",
    "thr = 1e-3\n",
    "\n",
    "dim_f = [idx for idx, element in enumerate(abs(np.diff(sigmafn))) if condition(element)][0]\n",
    "\n",
    "fd = ufn[:,0:dim_f].dot(np.diag(sigmafn[0:dim_f]).dot(vfn[:,0:dim_f].T))\n",
    "fd = (fd.T)[None,:]\n",
    "\n",
    "fd0 = fd.copy()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "27caf997-cfdb-413f-b323-0ca264c670fb",
   "metadata": {},
   "source": [
    "### Discover PDE using adjoint method"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "id": "930e744f-0d1a-40af-a74e-45bc43a2efe6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Execution time: 5.43969988822937\n",
      "1.0215799535306191\n",
      "total number of terms: 3\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fd = fd0.copy()\n",
    "\n",
    "ds = np.array([[1], [2], [3]])\n",
    "ps = np.array([[1]])\n",
    "\n",
    "start_time = time.time()\n",
    "estimated_params, eps = AdjointFindPDE(fd, dx, data_dt=dt, avg=True, gamma=1e-3, epochs=200, epthr=200, beta = 0.05, ds=ds, ps=ps, V = L, tol = 1e-6)\n",
    "end_time = time.time()\n",
    "\n",
    "i_pde =0;\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==1 and p[0]==1:\n",
    "            plt.plot(estimated_params[:,i_pde,id,ip], label=r\"$α_{d=\"+str(d[0])+\", p=\"+str(p[0])+\"}$\", color=\"blue\", marker=\">\", markevery=10)\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==2 and p[0]==1:\n",
    "            plt.plot(-estimated_params[:,i_pde,id,ip], label=r\"$-α_{d=\"+str(d[0])+\", p=\"+str(p[0])+\"}$\", color=\"red\", marker=\"d\", markevery=10)\n",
    "plt.axhline(A_ex,    color=\"blue\", linestyle = \"--\", label=r\"$A$\")\n",
    "plt.axhline(D_ex,    color=\"red\", linestyle = \"--\", label=r\"$D$\")\n",
    "plt.xlabel('Epochs')\n",
    "plt.ylabel('Coefficient')\n",
    "plt.legend(loc='upper center', bbox_to_anchor=(0.5, 1.4), ncol=2, fontsize=10)\n",
    "name = problem + \"_\" + \"coeffconv\"\n",
    "#plt.savefig(name+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "plt.show()\n",
    "\n",
    "end_time = time.time()\n",
    "print(\"Execution time: \"+str(end_time-start_time))\n",
    "\n",
    "i_pde = 0\n",
    "err_other = np.zeros_like(estimated_params[:,0,0,0])\n",
    "count = 0\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if not (  (d[0]==1 and p[0]==1) or\n",
    "                  (d[0]==2 and p[0]==1)    ):\n",
    "            err_other += abs(estimated_params[:,i_pde,id,ip])\n",
    "            count += 1\n",
    "\n",
    "i_pde = 0\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==1 and p[0]==1:\n",
    "            plt.plot(eps[1:], abs(estimated_params[1:,i_pde,id,ip]-A_ex),\n",
    "                     label=r\"$e(A)$\", marker=\">\", markevery=10, color=\"blue\")\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==2 and p[0]==1:\n",
    "            plt.plot(eps[1:], abs(-estimated_params[1:,i_pde,id,ip]-D_ex),\n",
    "                     label=r\"$e(D)$\", marker=\"d\", markevery=10, color=\"red\")\n",
    "plt.plot(eps[1:], err_other[1:]/count, marker=\"s\", markevery=10, color=\"black\", label=r\"$||e(\\mathbf{\\alpha}^*)||_1$\")\n",
    "plt.yscale('log')\n",
    "plt.ylabel(r'Error')\n",
    "plt.xlabel('Epochs')\n",
    "plt.legend(loc='upper center', bbox_to_anchor=(0.5, 1.4), ncol=2, fontsize=10)\n",
    "name = problem + \"_\" + \"coeff\"\n",
    "#plt.savefig(name+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "\n",
    "## compute error:\n",
    "err = 0\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==1 and p[0]==1:\n",
    "            err += abs(estimated_params[-1,i_pde,id,ip]-A_ex)\n",
    "        elif d[0]==2 and p[0]==1:\n",
    "            err += abs(estimated_params[-1,i_pde,id,ip]-D_ex)\n",
    "        else:\n",
    "            err += abs(estimated_params[-1, i_pde, id, ip])\n",
    "print(err)\n",
    "\n",
    "print(\"total number of terms: \"+str(len(ds)*len(ps)))\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "54cfdf12-7394-468e-9a6f-10fca7c6d729",
   "metadata": {},
   "source": [
    "### Discover PDE using PDE-FIND"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 110,
   "id": "65cf5b42-fc53-4282-a51d-b7f8995aa713",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['1', 'u_{x}', 'u_{xx}', 'u_{xxx}']\n",
      "u_t = (-0.818434 +0.000000i)u_{x}\n",
      "    + (0.496322 +0.000000i)u_{xx}\n",
      "   \n",
      "Execution time: 0.027567148208618164\n",
      "1.1778880059719086\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/mohsensadr/Codes/DiscoverPDEAdjoint/PDE-FIND/PDE_FIND.py:653: ComplexWarning: Casting complex values to real discards the imaginary part\n",
      "  w_added[list(F_trial)] = np.linalg.lstsq(X[:, list(F_trial)], y, rcond=None)[0]\n"
     ]
    }
   ],
   "source": [
    "import sys; sys.path.append('PDE-FIND/')\n",
    "from PDE_FIND import *\n",
    "import scipy.io as sio\n",
    "import itertools\n",
    "\n",
    "start_time = time.time()\n",
    "\n",
    "#(numPDE, Nt, Nx0, Nx1, ...)\n",
    "nt = Nt-1\n",
    "\n",
    "# Take up to second order derivatives.\n",
    "u = np.zeros((nt, Nx))\n",
    "ut = np.zeros((nt, Nx))\n",
    "ux = np.zeros((nt, Nx))\n",
    "uxx = np.zeros((nt, Nx))\n",
    "uxxx = np.zeros((nt, Nx))\n",
    "uxxxx = np.zeros((nt, Nx))\n",
    "\n",
    "for i in range(nt):\n",
    "    u[i,:] = fs[0, i, :]\n",
    "    ut[i,:] = (fs[0, i+1, :]-fs[0, i, :])/dt\n",
    "    ux[i,:] = np.gradient(u[i,:], axis=0) / dx[0]\n",
    "    uxx[i,:] = np.gradient( np.gradient(u[i,:],axis=0), axis=0) / dx[0]**2\n",
    "    uxxx[i,:] = np.gradient( np.gradient( np.gradient(u[i,:],axis=0), axis=0), axis=0) / dx[0]**3\n",
    "    uxxxx[i,:] = np.gradient( np.gradient( np.gradient( np.gradient(u[i,:],axis=0), axis=0), axis=0), axis=0) / dx[0]**4\n",
    "\n",
    "u = u.reshape((nt * Nx, 1))\n",
    "ut = ut.reshape((nt * Nx, 1))\n",
    "ux = ux.reshape((nt * Nx, 1))\n",
    "uxx = uxx.reshape((nt * Nx, 1))\n",
    "uxxx = uxxx.reshape((nt * Nx, 1))\n",
    "uxxxx = uxxxx.reshape((nt * Nx, 1))\n",
    "\n",
    "num_points = nt * Nx\n",
    "\n",
    "X_data = np.hstack([u])\n",
    "X_ders = np.hstack([np.ones((num_points,1)), ux, uxx, uxxx])\n",
    "X_ders_descr = ['','u_{x}', 'u_{xx}', 'u_{xxx}']\n",
    "X, description = build_Theta(X_data, X_ders, X_ders_descr, 0, data_description = ['u'])\n",
    "print(['1'] + description[1:])\n",
    "\n",
    "#c = TrainSTRidge(X,ut,10**-6,2)\n",
    "c = FoBaGreedy(X, ut,10)\n",
    "print_pde(c, description)\n",
    "\n",
    "end_time = time.time()\n",
    "print(\"Execution time: \"+str(end_time-start_time))\n",
    "\n",
    "coeff_pdefind = []\n",
    "for i in range(len(c)):\n",
    "        if c[i] != 0:\n",
    "            coeff_pdefind.append( np.real(c[i]) )\n",
    "coeff_pdefind = np.array( coeff_pdefind )[:,0]\n",
    "\n",
    "err = abs(coeff_pdefind[0]+A_ex)\n",
    "err += abs(coeff_pdefind[1]+D_ex)\n",
    "if len(coeff_pdefind)>2:\n",
    "    err += abs(coeff_pdefind[2:])\n",
    "\n",
    "print(err)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3905f8c9-acde-490f-9111-315153b142a3",
   "metadata": {},
   "source": [
    "## Sparsity in time"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ee3aeb32-7176-499b-b155-0f6e53d50e9b",
   "metadata": {},
   "source": [
    "Consider the case that only a fraction of the measured data is available. Here, we test how the adjoint method and PDE-FIND compare in finding the true PDE of the heat equation."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6be8d4b9-5e06-453f-8a33-bd9e7baa6d01",
   "metadata": {},
   "source": [
    "### Revisit Heat Equation"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c5348521-2a06-4ff9-8122-55a8e6108ed0",
   "metadata": {},
   "source": [
    "#### Generate Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 111,
   "id": "f16fae30-9d6a-4b67-986b-c1e533d28111",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x18c3f6390>]"
      ]
     },
     "execution_count": 111,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjgAAAGdCAYAAAAfTAk2AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABdoklEQVR4nO3deVhUZcMG8HsWmGEdQGAGFATcEEVRVEJtMUlcMi1bLM0l07KsTMvlfVPbrTTrq8zKNK0sy7c0l0IRMzcERVFRQFEUFAZEhGEdYOZ8f6BTJCoow5kZ7t91zfV9zpwZ7nN6ZW7Pec7zSARBEEBERERkQ6RiByAiIiJqaiw4REREZHNYcIiIiMjmsOAQERGRzWHBISIiIpvDgkNEREQ2hwWHiIiIbA4LDhEREdkcudgBxGA0GpGTkwMXFxdIJBKx4xAREVEDCIKAkpIS+Pr6Qiq98TmaFllwcnJy4OfnJ3YMIiIiugXZ2dlo06bNDbdpkQXHxcUFQO0BcnV1FTkNERERNYROp4Ofn5/pe/xGWmTBuXpZytXVlQWHiIjIyjRkeAkHGRMREZHNYcEhIiIim8OCQ0RERDaHBYeIiIhsDgsOERER2RwWHCIiIrI5LDhERERkc1hwiIiIyOaw4BAREZHNMWvB2bVrF4YPHw5fX19IJBJs2LDhpu/ZuXMnevbsCYVCgfbt22PVqlXXbLN06VIEBARAqVQiIiICiYmJTR+eiIiIrJZZC05ZWRm6d++OpUuXNmj7zMxMDBs2DAMGDEBycjKmT5+Op59+Glu3bjVt89NPP2HGjBlYsGABDh06hO7duyM6Ohr5+fnm2g0iIiKyMhJBEIRm+UESCdavX4+RI0ded5vZs2djy5YtSElJMT03evRoFBUVISYmBgAQERGB3r1747PPPgMAGI1G+Pn54YUXXsCcOXMalEWn00GlUqG4uJhrUREREVmJxnx/W9Rim/Hx8YiKiqrzXHR0NKZPnw4AqKqqQlJSEubOnWt6XSqVIioqCvHx8df9XL1eD71eb/qzTqdr2uBERC1AZbUB6doSZOSX4mKpHpfLqgAAcpkE7o72aO3mgEAvJ3TwdoFMevPFEInMyaIKjlarhVqtrvOcWq2GTqdDRUUFLl++DIPBUO82aWlp1/3chQsX4o033jBLZiIiW3YqrwTbTuRhe2oejp0vRo3x5if9nRVy9PB3w6AQNaK7aODtqmyGpER1WVTBMZe5c+dixowZpj/rdDr4+fmJmIiIyHJVG4zYfDQH3+/PQtK5y3Ve83CyR7DGBWpXJTyc7CGVANUGAQWlepy/XIFTeSUo1ddg96kC7D5VgPkbj+Pujl6Y0DcAd3XwgpRndqiZWFTB0Wg0yMvLq/NcXl4eXF1d4eDgAJlMBplMVu82Go3mup+rUCigUCjMkpmIyFYYjAJ+S76Aj7efQlZhOQBALpXgro5euC9Ejbs6esFXpYREcv2SYjAKSNeWYE/GRfyRosXhrCLsTL+InekX0VHtjJmDOmFQiPqGn0HUFCyq4ERGRuL333+v81xsbCwiIyMBAPb29ggPD0dcXJxpsLLRaERcXBymTZvW3HGJiGzG0fNFmPvrMRzPqR2j6OmswPjItnist1+jLjHJpBKE+LoixNcVU+5qh3OXyvBt/Dn8fCAbJ/NK8cx3Sejp74a3RnZFF1+VuXaHyLwFp7S0FBkZGaY/Z2ZmIjk5GR4eHvD398fcuXNx4cIFfPvttwCAZ599Fp999hlmzZqFp556Cjt27MDPP/+MLVu2mD5jxowZGD9+PHr16oU+ffrg448/RllZGSZOnGjOXSEiskmV1QYs2pqOb/ZmwigArko5nr2nHSb0DYCj/e1/RbRt5YR594fgxXs74Mtdp/HN3rM4lFWEBz7bi4l9AzBzUCc42MuaYE+I6jLrbeI7d+7EgAEDrnl+/PjxWLVqFSZMmICzZ89i586ddd7z8ssv48SJE2jTpg3mzZuHCRMm1Hn/Z599hkWLFkGr1SIsLAyffPIJIiIiGpyLt4kTEQGnL5bihR8O40Ru7VmbkWG++O+wEHi5mO+Sfp6uEm9uPoEtR3MBAB28nfHpEz0QrOHvYrq5xnx/N9s8OJaEBYeIWrrYE3l4ae1hlFcZ4OFkj8WPdMO9weqbv7GJ/JmWj1m/HMXFEj3s5VLMuz8EYyP8OTaHbqgx399ci4qIqAURBAHLd53BlO8OorzKgMigVvjjpTubtdwAwIBgb8S8dCcGdPJCVY0R8zak4D/rj6GqxtisOch2seAQEbUQBqOA1zak4J3fUyEIwNg7/PHdpD5QizRPTStnBVZO6I3/DA2GRAL8mJiNcSsTTBMIEt0OFhwiohbAYBTw6rojWJOQBakEmH9/CN4a0RVymbhfAxKJBFPuaocV43vByV6G/WcKMeqLfcgtrhA1F1k/FhwiIhtXYzBi+k/J+PXwBcikEnzyeA881T/Qosa73Busxi/P9YWvSokzF8vw8LJ4nLtUJnYssmIsOERENsxoFDDj5yPYdCQHdjIJlj7RE/d38xU7Vr2CNa5YN7UvAlo54kJRBR75Ih6n8krEjkVWigWHiMhGCYKANzefwMYjOZBLJVg2JhyDu15/1ndL0NrNAT8/G4lOahfkl+gx5usEnC3gmRxqPBYcIiIb9fnO01i17ywA4MNHuyMqpHnvlLpV3i5KrJ1yB4I1f5ecC0Uck0ONw4JDRGSDNhy+gEVb0wEA8+4PwYiw1iInahx3J3t8NykCQZ5OuFBUgbFfJ6CgVC92LLIiLDhERDbmSHYRZv1yFADwzF1BmNQ/UOREt8bLRYHvn45AazcHZBaU4enVB1FZbRA7FlkJFhwiIhuSr6vElO8OoqrGiIHB3pg9OFjsSLfF180B307qA5WDHZKzi/DyT8kwGlvcBPx0C1hwiIhsRFWNEc98n4Q8nR7tvZ3x8egwSKWWcyv4rWrn5YyvngyHvUyKP1K0eC8mTexIZAVYcIiIbMSirWk4nFUEV6Ucy8f1govSTuxITSYiqBUWPdINAPDVrjNYm5glciKydCw4REQ2YEdaHpbvzgQALHqkOwI9nURO1PRGhLXGjPs6AgDm/3Ych7Mui5yILBkLDhGRldMWV2Lmz0cAABP6BiC6i2XPdXM7Xri3PaK7qFFlMGLq94dwsYR3VlH9WHCIiKyYwSjgpbWHcbm8Gl18XTF3qHUPKr4ZiUSCxY90RzsvJ2h1lXj+h0OoNnAFcroWCw4RkRX7evcZJGQWwslehs+e6AmFXCZ2JLNzUdrhyyd7wVkhR2JmIT7goGOqBwsOEZGVysgvwYexJwEAC4Z3sclxN9fT3tsZix/pDgBYvjsTO9PzRU5EloYFh4jIChmMAl5ZdxRVNUbc08kLj/RqI3akZje4qwbjItsCAF5ZdwT5JZUiJyJLwoJDRGSFlu8+g+TsIrgo5Vj4UCgkEuuf7+ZW/GdoZwRrXFBQWoWZPx/hJIBkwoJDRGRlMvJLsGRb7aWp+feHwEflIHIi8SjtZPj08R5Q2kmx+1QBvtp9RuxIZCFYcIiIrIggCPjv+hRUGYwY0MkLD4e3vEtT/9ZB7YIFw7sAABZvTUfKhWKRE5ElYMEhIrIivx66gITMQjjYyfDWyK4t9tLUv43u7YchXTWoMQqY8XMy9DVclLOlY8EhIrISReVVePf3VADAiwM7oI27o8iJLIdEIsHbI7uilZM9TuaV4uPtp8SORCJjwSEishLvx6TjUlkVOng7Y1L/QLHjWJxWzgq8+1AoAODLv07jEJdyaNFYcIiIrMChrMv48coCk2+P7Ap7OX991ye6iwYP9mgNowC88vMRVFTxUlVLxb8hREQWzmgU8MbG4wCAUT3bICKolciJLNvrw7tA7arAmYIyLN6WLnYcEgkLDhGRhfvtyAUcOV8MJ3sZZg/pJHYci6dytMN7o7oBAL7Zm4kj2UXiBiJRsOAQEVmwiioDPoipPQvx3ID28HZRipzIOgzo5G26VDXn12NckLMFYsEhIrJgy3efQW5xJVq7OXBgcSO9Nqwz3BztkJqrw8o9mWLHoWbGgkNEZKHydJVYtvM0AGDOkGAo7Wx/pfCm1MpZgf8O7QwA+Gj7SWRdKhc5ETUnFhwiIgu1aGs6KqoNCG/rjvu7+Ygdxyo9HN4GkUGtUFltxH83HIMgcK2qlqJZCs7SpUsREBAApVKJiIgIJCYmXnfbe+65BxKJ5JrHsGHDTNtMmDDhmtcHDx7cHLtCRNQsUnN1+OXQeQC1l1o4Y/GtkUgkePehUNjLa9eq+i05R+xI1EzMXnB++uknzJgxAwsWLMChQ4fQvXt3REdHIz8/v97tf/31V+Tm5poeKSkpkMlkeOSRR+psN3jw4Drb/fjjj+beFSKiZvPhtnQIAnB/Nx/08HcXO45VC/R0wksDOwAA3tp8AsUV1SInouZg9oKzZMkSTJ48GRMnTkRISAi++OILODo6YuXKlfVu7+HhAY1GY3rExsbC0dHxmoKjUCjqbOfuzl8ARGQbks5dxvbUfMikEsy4r6PYcWzC5DuD0N7bGZfKqvBR7Emx41AzMGvBqaqqQlJSEqKiov7+gVIpoqKiEB8f36DPWLFiBUaPHg0nJ6c6z+/cuRPe3t7o1KkTpk6dikuXLl33M/R6PXQ6XZ0HEZElEgQBi7amAQAeCW+DIC9nkRPZBnu5FK9fWXH82/izSM3l94CtM2vBKSgogMFggFqtrvO8Wq2GVqu96fsTExORkpKCp59+us7zgwcPxrfffou4uDi8//77+OuvvzBkyBAYDPVPyb1w4UKoVCrTw8/P79Z3iojIjPZmXML+M4Wwl0nx4pXLKtQ0+nfwxNBQDYwCsGDjcQ44tnEWfRfVihUrEBoaij59+tR5fvTo0XjggQcQGhqKkSNHYvPmzThw4AB27txZ7+fMnTsXxcXFpkd2dnYzpCciapx/nr0Ze0db+Lo5iJzI9vx3WAgc7GRIzCzExiMccGzLzFpwPD09IZPJkJeXV+f5vLw8aDSaG763rKwMa9euxaRJk276c4KCguDp6YmMjIx6X1coFHB1da3zICKyNNtO5OHI+WI42svw3IB2YsexSa3dHDDt3vYAgHe2pKJUXyNyIjIXsxYce3t7hIeHIy4uzvSc0WhEXFwcIiMjb/jedevWQa/XY+zYsTf9OefPn8elS5fg48N5IojIOhmNgmnw61P9AuHprBA5ke16+s5ABLRyRH6JHp/GnRI7DpmJ2S9RzZgxA8uXL8fq1auRmpqKqVOnoqysDBMnTgQAjBs3DnPnzr3mfStWrMDIkSPRqlXdVXNLS0vx6quvYv/+/Th79izi4uIwYsQItG/fHtHR0ebeHSIis9h2Ig9p2hK4KOSYfGeQ2HFsmkIuw4IrA45X7MlERn6pyInIHOTm/gGPPfYYLl68iPnz50Or1SIsLAwxMTGmgcdZWVmQSuv2rPT0dOzZswfbtm275vNkMhmOHj2K1atXo6ioCL6+vhg0aBDeeustKBT8Fw8RWR9BEPDpjtozCeP7BkDlaCdyIts3INgbUZ29sT01H+/+noqVE3qLHYmamERogcPIdTodVCoViouLOR6HiES3Iy0PT606CEd7GfbMvhceTvZiR2oRMgvKcN+Sv1BjFPDdpD64s4OX2JHoJhrz/W3Rd1EREdk6QRDwSVztDRJP3tGW5aYZBXo6YVxkAIDaAccGY4v7975NY8EhIhLR7lMFSM4ugtJOiqc59qbZvTiwPVQOdkjTluDng5xCxJaw4BARieSfY2+e6NMWXi4cR9jc3BztTetUfbgtHSWVXKfKVrDgEBGJJCGzEAfOXoa9XIpn7ubZG7E8GdkWQZ5OKCitwrKdp8WOQ02EBYeISCRf/FX7ZfporzZQuypFTtNy2cmkmDu0MwDg6z2ZOH+5XORE1BRYcIiIRJCm1WFn+kVIJeC8NxYgqrM3IoNaoarGiPdj0sWOQ02ABYeISARf7ToDABjS1QdtWzmJnIYkEgleu78zJBJg05EcHMq6LHYkuk0sOEREzSy3uAIbk2sXepxyF8/eWIouvio83LMNAOC939O42riVY8EhImpm3+w9ixqjgIhAD3T3cxM7Dv3Dy/d1hEIuReLZQvyZni92HLoNLDhERM1IV1mNHxKyAIB3TlkgXzcHTOgXAAB4/490Tv5nxVhwiIia0Q8JWSjV16Cj2hn3dPQWOw7V47m728NVKUd6XgnWH74gdhy6RSw4RETNRF9jwDd7MwHU3jkllUpETkT1UTna4fkB7QEAS7alo7LaIHIiuhUsOEREzWRjcg7ydHqoXRUYEdZa7Dh0A+P7BsBHpUROcSW+iz8ndhy6BSw4RETNQBAErNp3FgAwoW8g7OX89WvJlHYyvHxfRwDAZ39moLiCSzhYG/4NIyJqBgfOXsbxHB2UdlI83sdP7DjUAKN6tkFHtTOKK6pNs06T9WDBISJqBqv21Y69ebBHa7g52ouchhpCJpVgVnQwAGDlnkxoiytFTkSNwYJDRGRmF4oqsPV4HoDasR1kPQZ29kbvAHfoa4z4ePtJseNQI7DgEBGZ2Xfx52AwCujbrhWCNa5ix6FGkEgkmDOk9izOzwezkZFfInIiaigWHCIiM6qoMmDtgdqJ/Sbw7I1VCm/rgftC1DAKwEexp8SOQw3EgkNEZEa/JV9AUXk12rg7YGBntdhx6BbNHNQREgmw5VguUi4Uix2HGoAFh4jITP55a/j4yADIOLGf1QrWuOKB7r4AgA+3pYuchhqCBYeIyEziz1xCmrYEDnYyPNqbt4Zbu5ejOkImleDP9Is4eLZQ7Dh0Eyw4RERmsmrvWQDAqPDWUDnYiRuGbluApxMe7dUGAPDB1nQIAhfitGQsOEREZnChqALbU6/cGh4ZIG4YajIv3NsB9nIpEjMLsftUgdhx6AZYcIiIzOCnxCwYBSAyqBU6qF3EjkNNxNfNAWMj2gIAFm/jWRxLxoJDRNTEqg1GrD2QDQAYc4e/yGmoqT03oB0c7WU4er7YNIEjWR4WHCKiJrb9RB7yS/TwdFZgUIhG7DjUxDydFXiqXyAAYElsOgxGnsWxRCw4RERNbE1C7cR+j/Vuw1XDbdTku4LgqpTjZF4pNh65IHYcqgf/5hERNaHMgjLsySiARAKM7s3LU7ZK5WCHZ+5uB6B2duNqg1HkRPRvLDhERE3ox8TaszcDOnnDz8NR5DRkThP7BcDT2R5ZheX4+WC22HHoX1hwiIiaSGW1AeuufNGNieDZG1vnaC/H8wPaAwA+jctAZbVB5ET0T81ScJYuXYqAgAAolUpEREQgMTHxutuuWrUKEomkzkOpVNbZRhAEzJ8/Hz4+PnBwcEBUVBROneICaEQkrj9ScnG5vBq+KiXu6eQtdhxqBk9E+MNXpYRWV4nv958TOw79g9kLzk8//YQZM2ZgwYIFOHToELp3747o6Gjk5+df9z2urq7Izc01Pc6dq/s/mg8++ACffPIJvvjiCyQkJMDJyQnR0dGorKw09+4QEV3Xmv21l6ce7+PPdadaCIVchpeiOgAAPt95GqX6GpET0VVmLzhLlizB5MmTMXHiRISEhOCLL76Ao6MjVq5ced33SCQSaDQa00Ot/nsFXkEQ8PHHH+O1117DiBEj0K1bN3z77bfIycnBhg0bzL07RET1StPqcPDcZcilEjzGdadalFE92yDQ0wmFZVVYuSdT7Dh0hVkLTlVVFZKSkhAVFfX3D5RKERUVhfj4+Ou+r7S0FG3btoWfnx9GjBiB48ePm17LzMyEVqut85kqlQoRERHX/Uy9Xg+dTlfnQUTUlNYm1o69uS9EDW9X5U22Jlsil0nx8n0dAQDLd51BUXmVyIkIMHPBKSgogMFgqHMGBgDUajW0Wm297+nUqRNWrlyJ3377Dd9//z2MRiP69u2L8+fPA4DpfY35zIULF0KlUpkefn781xURNZ3KagPWH66dC+XxPhxc3BLdH+qDYI0LSvQ1+OKvM2LHIVjgXVSRkZEYN24cwsLCcPfdd+PXX3+Fl5cXvvzyy1v+zLlz56K4uNj0yM7m7XxE1HS2HteiuKIard0c0L+9p9hxSARSqQSvDOoEAFi1LxP5JRwTKjazFhxPT0/IZDLk5dVdqyMvLw8aTcOmL7ezs0OPHj2QkZEBAKb3NeYzFQoFXF1d6zyIiJrK1TlQHg5vAykHF7dYAzt7I8zPDZXVRizdkSF2nBbPrAXH3t4e4eHhiIuLMz1nNBoRFxeHyMjIBn2GwWDAsWPH4OPjAwAIDAyERqOp85k6nQ4JCQkN/kwioqaSdakcezMuQSIBHunVRuw4JCKJRIJZ0bVncX5IzML5y+UiJ2rZzH6JasaMGVi+fDlWr16N1NRUTJ06FWVlZZg4cSIAYNy4cZg7d65p+zfffBPbtm3DmTNncOjQIYwdOxbnzp3D008/DaD2f0DTp0/H22+/jY0bN+LYsWMYN24cfH19MXLkSHPvDhFRHeuSas/e9G/viTbunLm4pevb3hN927VCtUHA/23n/Gxikpv7Bzz22GO4ePEi5s+fD61Wi7CwMMTExJgGCWdlZUEq/btnXb58GZMnT4ZWq4W7uzvCw8Oxb98+hISEmLaZNWsWysrKMGXKFBQVFaF///6IiYm5ZkJAIiJzMhgFrDtYewMEbw2nq16J7oSHPt+HXw6dx7P3tEM7L2exI7VIEkEQWtw67zqdDiqVCsXFxRyPQ0S37M+0fExcdQDujnbY/5+BUMhlYkciC/H06gPYnpqPYd18sPSJnmLHsRmN+f62uLuoiIisxU8Hai9PjezRmuWG6ph55Y6qLUdzcTynWOQ0LRMLDhHRLSgo1WN7au3dnLw8Rf/W2ccVw7v7AgCWbDspcpqWiQWHiOgWrD90ATVGAd393BCs4aVuutbLUR0gk0oQl5aPpHOXxY7T4rDgEBE1kiAIWHugdmHNx3rx7A3VL8jLGQ/3rJ06YNHWNLTAIa+iYsEhImqkQ1mXcfpiGRzsZBje3UfsOGTBXozqAHuZFPvPFGJvxiWx47QoLDhERI109dbwoaE+cFHaiZyGLFlrNwc8EVG7Ptmibek8i9OMWHCIiBqhstqALUdzAdQuzUB0M88PaA8HOxmOZBch9kTezd9ATYIFh4ioEbadyEOJvgat3RwQEeghdhyyAl4uCkzsFwAA+HDbSRiNPIvTHFhwiIga4Zek2stTD/VszYU1qcGeuasdXJRypOeVYNPRHLHjtAgsOEREDZSnq8TuUxcBAA/15OUpajiVox2euSsIAPBR7ElUG4wiJ7J9LDhERA204fAFGAUgvK07Aj2dxI5DVmZiv0C0crLH2Uvl+N+VM4FkPiw4REQNIAgCfjlU+6U0imdv6BY4KeR4bkB7AMAncadQWW0QOZFtY8EhImqA4zk6nMwrhb1cimHdOPcN3ZoxEf7wUSmRW1yJNQlZYsexaSw4REQNcPWSwqAQNVQOnPuGbo3SToYXB3YAAHz+ZwbK9DUiJ7JdLDhERDdRVWPExiO1d76M4tw3dJseDm+Dtq0ccamsCt/szRQ7js1iwSEiuomd6fkoLKuCl4sCd7b3FDsOWTk7mRQz7usIAPhy1xkUl1eLnMg2seAQEd3E1cHFI8N8IZfx1ybdvuHdfNFJ7YKSyhos++u02HFsEv+mEhHdwOWyKuxIywfAy1PUdKRSCV6N7gQA+GZvJnKKKkROZHtYcIiIbmDT0RxUGwR08XVFsMZV7DhkQwZ29kafQA/oa4xYEntS7Dg2hwWHiOgGri7NwLlvqKlJJBLMHRIMoPYyaJpWJ3Ii28KCQ0R0HRn5JThyvhhyqQQjwnzFjkM2qIe/O4aF+kAQgPf+SBM7jk1hwSEiuo71hy8AAO7p5IVWzgqR05CtejW6E+RSCXamX8S+jAKx49gMFhwionoIgoDfkmvnvhkR1lrkNGTLAjydMCbCHwCw8I80GI2CyIlsAwsOEVE9ks5dxvnLFXBWyBHVWS12HLJxLwzsAGeFHMcuFGPzsVyx49gEFhwionpcvTwV3UUDB3uZyGnI1nk6K/DMXUEAgEVb06Cv4UKct4sFh4joX6pqjNhy5V/RI3twcDE1j0l3BsLbRYHswgqs2c+FOG8XCw4R0b/sOnkRReXV8HJRoG87Ls1AzcPRXm5awuHTHadQXMElHG4HCw4R0b9sSK69PDW8my9kUonIaagleTi8DTp4O+NyeTWW/pkhdhyrxoJDRPQPpfoabE/NA8DLU9T85DIp/jOsM4DaJRwyC8pETmS9WHCIiP5ha4oWldVGBHk6IbS1Suw41AIN6OSNezp5odog4J0tqWLHsVosOERE/3D18tTIHq0hkfDyFInjtWEhkEsl2J6ahz2nOPnfrWiWgrN06VIEBARAqVQiIiICiYmJ1912+fLluPPOO+Hu7g53d3dERUVds/2ECRMgkUjqPAYPHmzu3SAiG5dfUom9V2aS5dIMJKb23s54MrItAODNzcdRYzCKnMj6mL3g/PTTT5gxYwYWLFiAQ4cOoXv37oiOjkZ+fn692+/cuROPP/44/vzzT8THx8PPzw+DBg3ChQsX6mw3ePBg5Obmmh4//vijuXeFiGzcpiO5MApAD383tG3lJHYcauFeGtgBbo52OJlXih8Tedt4Y5m94CxZsgSTJ0/GxIkTERISgi+++AKOjo5YuXJlvduvWbMGzz33HMLCwhAcHIyvv/4aRqMRcXFxdbZTKBTQaDSmh7u7u7l3hYhs3G9XL09xaQayAG6O9qbbxpfEnkRxOW8bbwyzFpyqqiokJSUhKirq7x8olSIqKgrx8fEN+ozy8nJUV1fDw8OjzvM7d+6Et7c3OnXqhKlTp+LSpUvX/Qy9Xg+dTlfnQUT0T6cvluLo+WLIpBIM6+YjdhwiAMATffzRUV172/jHcSfFjmNVzFpwCgoKYDAYoFbXXcdFrVZDq9U26DNmz54NX1/fOiVp8ODB+PbbbxEXF4f3338ff/31F4YMGQKDof6prRcuXAiVSmV6+Pn53fpOEZFN+u3K0gx3dvCEJ1cOJwshl0kx7/4QAMB38eeQkV8iciLrYdF3Ub333ntYu3Yt1q9fD6VSaXp+9OjReOCBBxAaGoqRI0di8+bNOHDgAHbu3Fnv58ydOxfFxcWmR3Z2djPtARFZA0EQsOHKyuG8PEWW5s4OXojqrEaNUcC8DcchCFxtvCHMWnA8PT0hk8mQl5dX5/m8vDxoNJobvnfx4sV47733sG3bNnTr1u2G2wYFBcHT0xMZGfXP+qhQKODq6lrnQUR01eHsImQVlsPRXoZBXbhyOFmeBcNDoLSTIv7MJWw8kiN2HKtg1oJjb2+P8PDwOgOErw4YjoyMvO77PvjgA7z11luIiYlBr169bvpzzp8/j0uXLsHHh9fNiajxrl6eGhSihqO9XOQ0RNfy83DEC/d2AAC8tTmV61Q1gNkvUc2YMQPLly/H6tWrkZqaiqlTp6KsrAwTJ04EAIwbNw5z5841bf/+++9j3rx5WLlyJQICAqDVaqHValFaWgoAKC0txauvvor9+/fj7NmziIuLw4gRI9C+fXtER0ebe3eIyMZUG4zYfLR25fARPXh5iizX03cGIsjLCQWleizZli52HItn9oLz2GOPYfHixZg/fz7CwsKQnJyMmJgY08DjrKws5ObmmrZftmwZqqqq8PDDD8PHx8f0WLx4MQBAJpPh6NGjeOCBB9CxY0dMmjQJ4eHh2L17NxQKDgwkosbZd/oSLpVVwcPJHv3bc+VwslwKuQxvjegKAPhu/zkcO18sciLLJhFa4GglnU4HlUqF4uJijschauFeWXcE/0s6j7F3+OPtkaFixyG6qRd/PIyNR3LQvY0Kvz7Xr0WteN+Y72+LvouKiMic9DUGbE2pnbJieDcuzUDW4bVhneGskOPI+WLOcHwDLDhE1GL9lX4RJfoaaFyV6B3gcfM3EFkAb1clZg6qneH4/Zg0aIsrRU5kmVhwiKjF2nRlcPH93XwgbUGn+cn6jYsMQHc/N5RU1uC1Dcc4N049WHCIqEUqr6rB9hO1c3QN787LU2RdZFIJFj3cDXYyCban5nNunHqw4BBRixSXmo+KagP8PRzRrY1K7DhEjdZR7YJpA2rnxnlj0wlcKtWLnMiysOAQUYu06cq/eId394FEwstTZJ2m3tMOwRoXFJZV4fVNJ8SOY1FYcIioxdFVVmNn+kUAvDxF1s1eLsWih7tDJpVg05EcbDvesIWsWwIWHCJqcbYdz0OVwYgO3s7opHYROw7RbQlto8LkO4MAAP9Zn8JLVVew4BBRi/P35SlfXp4imzA9qgM6qp1RUKrH7F94VxXAgkNELcylUj32ZBQAqL09nMgWKO1k+PixHrCXSbE9NQ9rD2SLHUl0LDhE1KL8kaKFwSiga2tXBHk5ix2HqMmE+Lri1ehOAIA3N53AmYulIicSFwsOEbUopstTXJqBbNCk/oHo264VKqoNePmnZFQbjGJHEg0LDhG1GNriSiSeLQQA3M+7p8gGSaUSfPhod6gc7HDkfDEWb00XO5JoWHCIqMXYciwXggD0auuO1m4OYschMgsflQPeHxUKAPhy15kWe+s4Cw4RtRj/vHuKyJYN7uqDp/oFAgBmrjuCrEvlIidqfiw4RNQiZBeWIzm7CFIJMCRUI3YcIrObMyQYPf1rF+ScuiYJldUGsSM1KxYcImoRNh2tPXsT2a4VvF2UIqchMj97uRSfPdETHk72OJ6jw2sbUlrU/DgsOETUImw6kguAd09Ry+Lr5oD/Gx0GqQT4X9J5LN99RuxIzYYFh4hsXkZ+CVJzdZBLJRjclZenqGW5s4MX5t0fAgBY+Ecatp/IEzlR82DBISKbd/XszV0dveDmaC9yGqLmN6FvAMZE+EMQgJfWHkZqrk7sSGbHgkNENk0QBNP4m+HduTQDtUwSiQSvP9AFfdu1QlmVARO+SUR2oW3fWcWCQ0Q27USuDmculkEhlyKqs1rsOESisZNJ8fmYnuiodkaeTo8nVyQgv6RS7Fhmw4JDRDbt6uWpe4O94aK0EzkNkbjcHO3x3aQItHF3wNlL5Ri3IhHFFdVixzILFhwislmCIHByP6J/UbsqsebpCHi5KJCmLcGEbxKhq7S9ksOCQ0Q263B2ES4UVcDJXoZ7g73FjkNkMdq2csK3T/WBysEOh7OK8MTy/SgsqxI7VpNiwSEim7UxufbszaAuGijtZCKnIbIsnX1c8ePkO9DKyR4pF3QY/VU88nW2MyaHBYeIbJLBKGDLsSuT+/HuKaJ6hfi64qdn7oDaVYGTeaV48PN9SNPaxi3kLDhEZJMSMi/hYokeKgc79G/vJXYcIovV3tsFPz8TiUBPJ1woqsCoz/dhR5r1TwbIgkNENunq3VNDumpgL+evOqIbadvKCeuf64vIoNp5cp5efRAfxZ5EjcEodrRbxr/1RGRzqg1G/JFy9fIU754iagg3R3usfqoPHu/jD6MA/F/cKYz+aj/OX7bOCQFZcIjI5uzJKEBReTU8nRW4I6iV2HGIrIa9XIqFD4Xi/0aHwVkhx8FzlzH44934Zm+m1Z3NaZaCs3TpUgQEBECpVCIiIgKJiYk33H7dunUIDg6GUqlEaGgofv/99zqvC4KA+fPnw8fHBw4ODoiKisKpU6fMuQtEZEWuzn0zLFQDmVQichoi6zMirDV+f/FO9PR3Q6m+Bm9sOoEHPtuLnen5EARB7HgNYvaC89NPP2HGjBlYsGABDh06hO7duyM6Ohr5+fn1br9v3z48/vjjmDRpEg4fPoyRI0di5MiRSElJMW3zwQcf4JNPPsEXX3yBhIQEODk5ITo6GpWVtnN7GxHdmspqA7Ydrx0gyctTRLfOv5Uj1j3bF2+P7ApXpRwncnWY8M0BjFq2D78fy0W1hZ/RkQhmrmIRERHo3bs3PvvsMwCA0WiEn58fXnjhBcyZM+ea7R977DGUlZVh8+bNpufuuOMOhIWF4YsvvoAgCPD19cXMmTPxyiuvAACKi4uhVquxatUqjB49+qaZdDodVCoViouL4erq2kR7SkSWICZFi2e/T4KvSok9s++FlGdwiG5bQakeX+w8je/2n4O+prbYeDorMCxUg3s6eSMiyAOO9nKz52jM97dZ01RVVSEpKQlz5841PSeVShEVFYX4+Ph63xMfH48ZM2bUeS46OhobNmwAAGRmZkKr1SIqKsr0ukqlQkREBOLj4+stOHq9Hnq93vRnnc489/gfyrqMDYcvwEUph4vSDj4qJYI1rgj0dOJdHETN5OrK4fd392W5IWoins4KvHZ/CKbcHYTV+87i54PncbFEj9Xx57A6/hwkEiCglROCPJ2gcrCDq4Mdegd4YFg38eagMmvBKSgogMFggFpddwVftVqNtLS0et+j1Wrr3V6r1Zpev/rc9bb5t4ULF+KNN964pX1ojBM5Onwbf+6a5x3sZOjbrhUGBHvj/m4+cHO0N3sWopaoTF+DuNQrl6e68fIUUVPzdlHi1ehgTI/qiL/SLyIuLR9/pecjp7gSmQVlyCwoM21bZTDabsGxFHPnzq1zVkin08HPz6/Jf07X1iq8cG97lFTWQFdRjXOF5UjXlqBUX4O4tHzEpeXjzc0nMLSrBk/1D0S3Nm5NnoGoJduemofKaiMCPZ3QtTUvPxOZi51MiqgQNaJC1BAEAQWlVTiZV4Kzl8pQUlmDkspqdBf5O86sBcfT0xMymQx5eXVnRMzLy4NGo6n3PRqN5obbX/2/eXl58PHxqbNNWFhYvZ+pUCigUChudTcaLMzPDWF+bnWeEwQBqbkl+DM9H1uO5uJErg4bknOwITkHUZ29MeO+Tgjx5S9ioqZwdXK/4d18IJHw8hRRc5BIJPByUcDLRYF+7T3FjmNi1oEh9vb2CA8PR1xcnOk5o9GIuLg4REZG1vueyMjIOtsDQGxsrGn7wMBAaDSaOtvodDokJCRc9zPFJJFIEOLriucHtMeWF/tj47R+eLBHa0glwPbUfNz/6W68vvG4TS5VT9Sciiuq8dfJ2rszefcUEZl95OuMGTOwfPlyrF69GqmpqZg6dSrKysowceJEAMC4cePqDEJ+6aWXEBMTgw8//BBpaWl4/fXXcfDgQUybNg1AbWGYPn063n77bWzcuBHHjh3DuHHj4Ovri5EjR5p7d26LRCJBtzZu+OixMMTOuBvDuvnAKACr9p1F1Id/YdfJi2JHJLJaW49rUW0Q0Entgg5qF7HjEJHIzD4G57HHHsPFixcxf/58aLVahIWFISYmxjRIOCsrC1Lp3z2rb9+++OGHH/Daa6/hP//5Dzp06IANGzaga9eupm1mzZqFsrIyTJkyBUVFRejfvz9iYmKgVCrNvTtNpp2XM5Y+0ROP9y7AvN9SkFlQhnErEzGpfyBmDe4EhVwmdkQiq3J1cr8Hwnj2hoiaYR4cS2Rp8+BUVhvwzpZUfLe/9g6sXm3dsWxsOLxczD9uiMgWFJTqEfFuHAxGAX+9eg/atnISOxIRmUFjvr85OYsFUNrJ8NbIrvh6XC+4KGvX/hjx2R4czykWOxqRVfgjRQuDUUD3NiqWGyICwIJjUaJC1NjwfD8Eejohp7gSDy+Lx+5THJdDdDNXL09xcDERXcWCY2HaeTljw3P90L+9JyqqDZi06iBiUuqfwJCIgNziChw4WwgAok4qRkSWhQXHAqkc7bBiQi8M6apBlcGI59Yk4Zek82LHIrJIW47mQhCAPgEe8FE5iB2HiCwEC46FUshl+PTxHngkvA2MAvDK/45g45XT8ET0t01Hr0zu151nb4jobyw4Fkwuk+L9Ud3weB9/CAIw46dkxJ7Iu/kbiVqIrEvlOJJdBKkEGBLKgkNEf2PBsXBSqQTvjOyKB3u0Ro1RwPNrDmFvRoHYsYgswtWVw/u194SnM6dVIKK/seBYAalUgkUPd8PgLrVjcp79Lgkn80rEjkUkOtPdU1w5nIj+hQXHSshlUvzf42HoE+CBEn0NJn5zAPkllWLHIhLNqbwSpGlLYCeTILpL/Yv3ElHLxYJjRRRyGb58MhyBnk64UFSBp1cfREWVQexYRKK4Orj47o5eUDnaiZyGiCwNC46VcXeyxzcTesPd0Q5Hzxdjxs/JaIGrbVALJwgCNl+5PHU/L08RUT1YcKxQgKcTlo/rBTuZBH+kaPHVrjNiRyJqVsdzdDhTUAaFXIqoELXYcYjIArHgWKleAR5YMLwLAOD9mDTs451V1IJcvXtqYGdvOCvkIqchIkvEgmPFxkT44+ErEwFO+/EwcooqxI5EZHZGo4DNR65M7sfLU0R0HSw4VkwikeDtkV3RxdcVhWVVeG7NIVQbjGLHIjKrw9mXcaGoAk72MgwI9hY7DhFZKBYcK6e0k+GLseFwVcqRnF2Ej2JPih2JyKw2XTl7M6iLBko7mchpiMhSseDYAD8PR7w3qhsAYNlfpzkeh2yWwShgM9eeIqIGYMGxEUNDfTC6tx8EAXj552RcLqsSOxJRk0s4cwkFpXqoHOzQv72X2HGIyIKx4NiQ+cNDEOTlhDydHrN+Ocr5ccjmXL17akhXDezl/PVFRNfH3xA2xNFejk9G94CdTILYE3n4MTFb7EhETaaqxog/UrQAgOHdefcUEd0YC46N6dpahVnRwQCAd7acQHZhuciJiJrG3owCFJVXw9NZgTuCWokdh4gsHAuODXqqfyB6tXVHWZUBc37lpSqyDVdXDh8WqoFMKhE5DRFZOhYcGySTSrDoke5Q2kmxN+MS1iRkiR2J6LZUVhuw7UQeAF6eIqKGYcGxUYGeTnj1yqWqhb+n8lIVWbWd6fko1dfAV6VET393seMQkRVgwbFhE/sGoHdA7aWq2byriqzY1cn97u/uCykvTxFRA7Dg2DCpVIJFD9deqtp3+hLWJZ0XOxJRo5XqaxCXduXyFNeeIqIGYsGxcQGeTphxX0cAwLu/p+JSqV7kRESNs+24FpXVRgR6OqFra1ex4xCRlWDBaQEm9gtEsMYFReXVePf3NLHjEDXKb8m1d0890N0XEgkvTxFRw7DgtAB2MinefSgUEgnwy6Hz2Heaa1WRdSgo1WPPlbXVRoTx8hQRNRwLTgvR098dYyPaAgBeW5+CymqDyImIbm7L0VwYjAK6tVEhyMtZ7DhEZEVYcFqQVwd3gpeLAmcKyrBs52mx4xDd1G/JFwDUXp4iImoMsxacwsJCjBkzBq6urnBzc8OkSZNQWlp6w+1feOEFdOrUCQ4ODvD398eLL76I4uLiOttJJJJrHmvXrjXnrtgEV6UdXh/eBQCwbOdpnLl4/f8WRGLLulSOQ1lFkEhYcIio8cxacMaMGYPjx48jNjYWmzdvxq5duzBlypTrbp+Tk4OcnBwsXrwYKSkpWLVqFWJiYjBp0qRrtv3mm2+Qm5treowcOdKMe2I7hoZqcE8nL1QZjHhr8wmx4xBd18YjtWdv+rZrBW9XpchpiMjayM31wampqYiJicGBAwfQq1cvAMCnn36KoUOHYvHixfD1vfZfZF27dsUvv/xi+nO7du3wzjvvYOzYsaipqYFc/ndcNzc3aDQac8W3WRKJBPPvD8HejF34M/0idqTl4d5gtdixiOoQBAEbrtw9NSKstchpiMgame0MTnx8PNzc3EzlBgCioqIglUqRkJDQ4M8pLi6Gq6trnXIDAM8//zw8PT3Rp08frFy5krP0NkKQlzOe6h8IAHhz0wnoazjgmCxLam4JMvJLYS+XYnBX/kOGiBrPbGdwtFotvL296/4wuRweHh7QarUN+oyCggK89dZb11zWevPNN3HvvffC0dER27Ztw3PPPYfS0lK8+OKL9X6OXq+HXv/3BHc6na6Re2N7Xri3A9YfuoCzl8qxYk8mnrunvdiRiEyuDi6+t5M3XJV2IqchImvU6DM4c+bMqXeQ7z8faWm3P5mcTqfDsGHDEBISgtdff73Oa/PmzUO/fv3Qo0cPzJ49G7NmzcKiRYuu+1kLFy6ESqUyPfz8/G47n7VzVsgxd2jtYpyf7ciAtrhS5EREtYxGARuP1F6eGtmDg4uJ6NY0uuDMnDkTqampN3wEBQVBo9EgPz+/zntrampQWFh407EzJSUlGDx4MFxcXLB+/XrY2d34X3ARERE4f/58nbM0/zR37lwUFxebHtnZ2Y3baRs1Mqw1evq7obzKgIV/pIodhwgAcOBsIXKLK+GikOOeTt43fwMRUT0afYnKy8sLXl5eN90uMjISRUVFSEpKQnh4OABgx44dMBqNiIiIuO77dDodoqOjoVAosHHjRiiVN797Ijk5Ge7u7lAoFPW+rlAorvtaSyaRSPDmiK4Y/tke/Jacg7F3tEXvAA+xY1ELd3Vw8eCuGijtZCKnISJrZbZBxp07d8bgwYMxefJkJCYmYu/evZg2bRpGjx5tuoPqwoULCA4ORmJiIoDacjNo0CCUlZVhxYoV0Ol00Gq10Gq1MBhqB8Ju2rQJX3/9NVJSUpCRkYFly5bh3XffxQsvvGCuXbFpXVurMLq3PwDg9Y3HYTRysDaJp6rGiN+P5QIARvbg3VNEdOvMNsgYANasWYNp06Zh4MCBkEqlGDVqFD755BPT69XV1UhPT0d5eTkA4NChQ6Y7rNq3rzvoNTMzEwEBAbCzs8PSpUvx8ssvQxAEtG/fHkuWLMHkyZPNuSs27ZVBHbH5SA6O5+iw/vAFjApvI3YkaqF2nbyI4opqeLkocEdQK7HjEJEVkwgt8P5qnU4HlUplugWdamc2fj8mDRpXJf585R442PPSADW/aT8cwuajuXiqXyDmDw8ROw4RWZjGfH9zLSoCAEzsF4DWbg7Q6iqxYs8ZseNQC1Sqr8H21DwAvHuKiG4fCw4BAJR2Mswa3AlA7dmc/BLeNk7NK/aEFpXVRgR6OiG0tUrsOERk5VhwyGR4N190b6NCWZUBH8WeEjsOtTAbDtfePfVAd19IJBKR0xCRtWPBIROpVIL/Dqsd9/DTgSyka0tETkQtRX5JJXafugiAd08RUdNgwaE6+gR6ILqLGkYBePd3Tv5HzWNjcg6MAtDD3w2Bnk5ixyEiG8CCQ9eYM6Qz5FIJ/jp5EbtOXhQ7DrUAvxyqXXvqoZ6cooCImgYLDl0j0NMJT0a2BVB7FoeT/5E5pebqkJqrg51MguHdfMSOQ0Q2ggWH6vXivR3gopAjTVuCTUdzxI5DNmz94dqzNwOD1XBztBc5DRHZChYcqpe7kz2euTsIAPDhtpOoqjGKnIhskcEoYMOVgvNgTw4uJqKmw4JD1/VU/0B4OiuQVViOHxOzxI5DNmhvRgHyS/Rwc7TDAK4cTkRNiAWHrsvRXo6XBtauCfbpjlMo09eInIhsza+HzgOonfvGXs5fR0TUdPgbhW5odB9/tG3liILSKqzYkyl2HLIhpfoabD1euzTDg5z7hoiaGAsO3ZCdTIqZg2qXcPhq1xlcKtWLnIhsRUyKFhXVBgR5OiHMz03sOERkY1hw6KbuD/VBF19XlOprsPTP02LHIRtx9fLUQz1bc2kGImpyLDh0U1KpBLMGBwMAvt9/Ducvl4uciKxdTlEF4s9cAgCMCOPlKSJqeiw41CB3dfBEZFArVBmMXIiTbtuG5AsQBCAi0AN+Ho5ixyEiG8SCQw0ikUgwe0jtWZxfD5/nQpx0ywRBwPorSzOM4tIMRGQmLDjUYGF+bhjSVQNBABZtTRM7DlmplAs6nMovhUIuxZBQjdhxiMhGseBQo7wS3QkyqQTbU/NxKOuy2HHICv1yZXDxoC4auCjtRE5DRLaKBYcapZ2XM0ZdmVJ/8dZ0kdOQtdHXGPBb8tWVwzm4mIjMhwWHGu3FgR1gJ5Ng3+lL2JdRIHYcsiJxqfm4XF4NjasSd3XwEjsOEdkwFhxqtDbujni8jz8AYPG2dAiCIHIishY/H8wGAIwKbw2ZlHPfEJH5sODQLZk2oD2UdlIcyirCn+n5YschK6AtrsSukxcBAA+H+4mchohsHQsO3RJvVyXGRwYAABZvPQmjkWdx6MZ+OXQeRgHoE+CBQE8nseMQkY1jwaFb9uzd7eCskONErg5/pGjFjkMWTBAErLtyeeqRXpz7hojMjwWHbpm7kz2e6h8IAFgSmw4Dz+LQdRw8dxlnL5XD0V6GoaE+YschohaABYduy9N3BkLlYIfTF8uw4fAFseOQhfr5QO3Zm/u7+cBJIRc5DRG1BCw4dFtclXZ49u52AICP406iqsYociKyNGX6Gmw5lgsAeKQXBxcTUfNgwaHbNr5vW3g6K5BdWGG6DZjoqi3HclFeZUCgpxN6tXUXOw4RtRAsOHTbHO3lmDag9izOpztOobLaIHIisiT/HFwskXDuGyJqHiw41CQej/CHr0qJPJ0e3+8/J3YcshBnLpbiwNnLkEq4cjgRNS+zFpzCwkKMGTMGrq6ucHNzw6RJk1BaWnrD99xzzz2QSCR1Hs8++2ydbbKysjBs2DA4OjrC29sbr776Kmpqasy5K3QTCrkMLw7sAABYtvM0yvT870HAuqTahTXv7ugFtatS5DRE1JKYteCMGTMGx48fR2xsLDZv3oxdu3ZhypQpN33f5MmTkZuba3p88MEHptcMBgOGDRuGqqoq7Nu3D6tXr8aqVaswf/58c+4KNcCo8DYIaOWIS2VV+GZvpthxSGTVBiPWHawtOI9ycDERNTOzFZzU1FTExMTg66+/RkREBPr3749PP/0Ua9euRU5Ozg3f6+joCI1GY3q4urqaXtu2bRtOnDiB77//HmFhYRgyZAjeeustLF26FFVVVebaHWoAO5kUL9/XEQDw5a4zKC6vFjkRiSkuNQ8FpXp4OisQFaIWOw4RtTBmKzjx8fFwc3NDr169TM9FRUVBKpUiISHhhu9ds2YNPD090bVrV8ydOxfl5eV1Pjc0NBRq9d+/MKOjo6HT6XD8+PGm3xFqlPu7+aKj2hkllTVYvvuM2HFIRGsSsgAAj/ZqAzsZh/sRUfMy24xbWq0W3t7edX+YXA4PDw9otdef1v+JJ55A27Zt4evri6NHj2L27NlIT0/Hr7/+avrcf5YbAKY/X+9z9Xo99Hq96c86ne6W9oluTiaVYMZ9nfDs90lYuTcTE/oFwNNZIXYsambZheXYfaoAADC6t7/IaYioJWr0P6vmzJlzzSDgfz/S0tJuOdCUKVMQHR2N0NBQjBkzBt9++y3Wr1+P06dP3/JnLly4ECqVyvTw8+N4AHOK7qJGtzYqlFcZsGznrf93I+u19kDt2Zs7O3jCv5WjyGmIqCVqdMGZOXMmUlNTb/gICgqCRqNBfn5+nffW1NSgsLAQGo2mwT8vIiICAJCRkQEA0Gg0yMvLq7PN1T9f73Pnzp2L4uJi0yM7m5PRmZNEIsHMQZ0AAN/tP4fc4gqRE1FzqjYY8fOVwcVP9OHZGyISR6MvUXl5ecHLy+um20VGRqKoqAhJSUkIDw8HAOzYsQNGo9FUWhoiOTkZAODj42P63HfeeQf5+fmmS2CxsbFwdXVFSEhIvZ+hUCigUPAySXO6q4Mn+gR4IPFsIT7dkYF3HwwVOxI1k7jUPFws4eBiIhKX2Ub+de7cGYMHD8bkyZORmJiIvXv3Ytq0aRg9ejR8fX0BABcuXEBwcDASExMBAKdPn8Zbb72FpKQknD17Fhs3bsS4ceNw1113oVu3bgCAQYMGISQkBE8++SSOHDmCrVu34rXXXsPzzz/PEmNBJBIJXomuPYvz84FsnC0oEzkRNZcfEv+euZiDi4lILGb97bNmzRoEBwdj4MCBGDp0KPr374+vvvrK9Hp1dTXS09NNd0nZ29tj+/btGDRoEIKDgzFz5kyMGjUKmzZtMr1HJpNh8+bNkMlkiIyMxNixYzFu3Di8+eab5twVugV9Aj1wTycv1BgFfLz9pNhxqBnUDi6+CAAY3Ztj3YhIPBJBEASxQzQ3nU4HlUqF4uLiOnPsUNNLuVCM+z/dA4kE+OOlOxGs4fG2ZYu3puOzPzPQv70nvn+64ZeiiYgaojHf3zx/TGbVtbUKw0J9IAjAh9t4FseW1Q4urr089UQEBxcTkbhYcMjsXr6vI6QSIPZEHg5nXRY7DplJ7Ik85Jfo4elsj6jOHFxMROJiwSGza+/tbFpJevG2dJHTkLms3ncWAPB4H3/Yy/mrhYjExd9C1CxeiuoAO5kEezMuYW9GgdhxqImlaXVIyCyETCrh5SkisggsONQs2rg7YkxEWwDAoq3paIFj223ad/HnAACDQtTwUTmInIaIiAWHmtFzA9rBwU6G5OwixJ7Iu/kbyCoUV1Tj10MXAADjIgPEDUNEdAULDjUbbxclJvYLAFB7R5XByLM4tuCXpPOoqDago9oZdwR5iB2HiAgACw41s2fuagdXpRzpeSXYdCRH7Dh0m4xGAd/tr7089WRkACQSiciJiIhqseBQs1I52uGZu9sBAJbEnkS1wShyIrodezIKkFlQBheFHA/1aC12HCIiExYcanYT+wXA09keWYXlponhyDp9G38WADAqvA2cFI1eu5eIyGxYcKjZOdrLMW1AewDAJ3GnUFltEDkR3YrswnLEpeUDAJ6MbCtyGiKiulhwSBSPR/ijtZsD8nR60y3GZF2+338OggDc2cET7bycxY5DRFQHCw6JQiGX4aWoDgCAz3dmoKSyWuRE1Bhl+hr8kJgFABjPW8OJyAKx4JBoHurRGkFeTrhcXo2vd2eKHYca4eeD2SiprEGgpxPuDfYWOw4R0TVYcEg0cpkUM+/rBAD4evcZFJTqRU5EDWEwCli5t7aQPtU/EFIpbw0nIsvDgkOiGtJVg+5tVCirMuCTuFNix6EGiD2hRXZhBdwc7fDwlUVUiYgsDQsOiUoqlWDOkM4AgB8SsnDmYqnIiehmrl5OHBvRFg72MpHTEBHVjwWHRBfZrhXuDfZGjVHAoq3pYsehGzicdRkHz12GnUyCcbw1nIgsGAsOWYTZg4MhlQB/pGiRdO6y2HHoOr7eU3v25oHureHtqhQ5DRHR9bHgkEXopHHBI+F+AICFv6dCELgQp6XJLizHH8dyAQCT+geKnIaI6MZYcMhivHxfRyjtpDh47jJiT+SJHYf+ZdW+szAKQP/2ngjxdRU7DhHRDbHgkMXQqJR4un8QAOC9mDTUcCFOi3G5rAo/XpnYb9KdPHtDRJaPBYcsyjN3B8HDyR5nLpbhJy7EaTFWx59FeZUBIT6uuKejl9hxiIhuigWHLIqL0g4vDaxdwuGj2FMo09eInIjK9DVYte8sAGDqPe0gkXBiPyKyfCw4ZHEe7+OPgFaOKCjV46tdZ8SO0+L9mJiFovJqBLRyxNBQH7HjEBE1CAsOWRx7uRSzBgcDAL7adQa5xRUiJ2q59DUGLN9dWzKfvbsdZFyWgYisBAsOWaQhXTXoE+CBimoD3v8jTew4Ldb6QxeQp9ND7arAgz1bix2HiKjBWHDIIkkkEswfHgKJBNiQnINDWZz8r7kZjAK+vHKJcPKdQVDIuSwDEVkPFhyyWF1bq/BIeO1ijm9sOgGjkZP/Nactx3KRWVAGN0c7PN7HX+w4RESNwoJDFu2V6E5wspfhSHYRNiRfEDtOi2EwCvi/7ScBAE/1C4STQi5yIiKixmHBIYvm7aLE8/e2BwC8H5PG28abyaYjOTh9sfbszcR+AWLHISJqNLMWnMLCQowZMwaurq5wc3PDpEmTUFpaet3tz549C4lEUu9j3bp1pu3qe33t2rXm3BUS0VP9AuHn4YA8nR5f/HVa7Dg2r8ZgxCdxpwDUjr1xUdqJnIiIqPHMWnDGjBmD48ePIzY2Fps3b8auXbswZcqU627v5+eH3NzcOo833ngDzs7OGDJkSJ1tv/nmmzrbjRw50py7QiJS2snw36GdAdTeNp5dWC5yItv2W3IOzhSUwd3RDuP7Bogdh4jolpjtwnpqaipiYmJw4MAB9OrVCwDw6aefYujQoVi8eDF8fX2veY9MJoNGo6nz3Pr16/Hoo4/C2dm5zvNubm7XbEu2K7qLBncEeWD/mUK8+3sqlo0NFzuSTaoxGPHpjtqzN1Puagdnjr0hIitltjM48fHxcHNzM5UbAIiKioJUKkVCQkKDPiMpKQnJycmYNGnSNa89//zz8PT0RJ8+fbBy5UoIAu+wsWUSiQQLhneBTCrBHyla7EzPFzuSTVp/+ALOXiqHh5M9xkW2FTsOEdEtM1vB0Wq18Pb2rvOcXC6Hh4cHtFptgz5jxYoV6Ny5M/r27Vvn+TfffBM///wzYmNjMWrUKDz33HP49NNPr/s5er0eOp2uzoOsT2cfV0y4cslkwcbjqKw2iBvIxlTVGPHJlbM3z94dxDuniMiqNbrgzJkz57oDga8+0tJuf+bZiooK/PDDD/WevZk3bx769euHHj16YPbs2Zg1axYWLVp03c9auHAhVCqV6eHn53fb+Ugc06M6QO2qwLlL5Rxw3MTWJJxDdmEFvFwUGHsHz94QkXVrdMGZOXMmUlNTb/gICgqCRqNBfn7dywg1NTUoLCxs0NiZ//3vfygvL8e4ceNuum1ERATOnz8PvV5f7+tz585FcXGx6ZGdnd2wnSWL46K0w7z7QwAAn+88jbMFZSInsg26ymrTnVMvR3WEoz3P3hCRdWv0bzEvLy94eXnddLvIyEgUFRUhKSkJ4eG1A0J37NgBo9GIiIiIm75/xYoVeOCBBxr0s5KTk+Hu7g6FQlHv6wqF4rqvkfUZFuqDnzpkY/epAszfeByrJ/aGRMJFIG/Hl3+dxuXyarTzcsKjvdqIHYeI6LaZbQxO586dMXjwYEyePBmJiYnYu3cvpk2bhtGjR5vuoLpw4QKCg4ORmJhY570ZGRnYtWsXnn766Ws+d9OmTfj666+RkpKCjIwMLFu2DO+++y5eeOEFc+0KWRiJRII3HugCe5kUu05eRExKw8Z0Uf20xZVYsScTADBrcDDkMs7/SUTWz6y/ydasWYPg4GAMHDgQQ4cORf/+/fHVV1+ZXq+urkZ6ejrKy+vOa7Jy5Uq0adMGgwYNuuYz7ezssHTpUkRGRiIsLAxffvkllixZggULFphzV8jCBHk549m7gwDUrlNVyhmOb9nH20+istqI8LbuGBSiFjsOEVGTkAgt8P5qnU4HlUqF4uJiuLq6ih2HblFltQGDPtqFrMJyjItsizdHdBU7ktU5lVeC6I93wSgAv0yNRHhbD7EjERFdV2O+v3kumqyW0k6Gdx8MBQB8G38OiZmFIieyLoIg4K0tqTAKwKAQNcsNEdkUFhyyav07eOKxXrW3/c/+5SjnxmmEuNR87Dp5EfYyKeZeWQqDiMhWsOCQ1fvPsM5QuyqQWVCGj7afFDuOVaisNuDNzScAAJPuDESgp5PIiYiImhYLDlk9lYMd3h5Ze6lq+a4zOHq+SNxAVmDFnkxkFZZD7arAtAHtxY5DRNTkWHDIJtwXosbw7r4wCsCs/x1FVY1R7EgWK7e4Ap/tyAAAzB3SmUsyEJFNYsEhm/H68BC4O9ohTVuC/4vjparreXtLKiqqDejV1h0jwnzFjkNEZBYsOGQzWjkr8M6Vu6qW7TyNA2d5V9W/xaXmYcvRXMikErwxogtngCYim8WCQzZlaKgPRvVsA6MAvPxTMkoqq8WOZDFK9TV4bUMKAODp/oHo4qsSORERkfmw4JDNef2BELRxd8D5yxV4Y9MJseNYjMVb05FbXAl/D0dMj+oodhwiIrNiwSGb46K0w5JHwyCVAP9LOo8/juWKHUl0h7MuY3X8WQDAOw92hYO9TNxARERmxoJDNqlPoAeevbsdAGDOr8eQXVh+k3fYrspqA2b/chSCADzUozXu7OAldiQiIrNjwSGbNT2qI7r7uaG4ohrTfjgEfU3LnOV48dZ0nMwrhaezAq/dHyJ2HCKiZsGCQzbLXi7F0id6QOVghyPni/HullSxIzW7fRkF+HpPJgDgg4dD4eFkL3IiIqLmwYJDNq2NuyM+eqw7AGB1/DlsPpojcqLmU1xRjVfWHQEAPBHhj3uD1SInIiJqPiw4ZPPuDVZj6j2143Fm/+8oTl8sFTmR+QmCgPm/pSCnuBIBrRzxXy6mSUQtDAsOtQgz7+uIPoEeKKsyYPLqgygut+35cX46kI3fknMgk0rw0WNhXI6BiFocFhxqEeQyKZY+0RO+KiXOFJTh+R8OocZgm+tVpVwoxvyNxwEAMwd1RA9/d5ETERE1PxYcajG8XBRYPr4XHOxk2JNRgLc2294kgMUV1XhuzSFU1RgxMNgbz97VTuxIRESiYMGhFqWLrwofPRYGoHbQ8bdXJr+zBQajgJd/SkZWYTnauDvgw0e7QyrlWlNE1DKx4FCLM7irBq9GdwIALNh43GburHpnSyp2pOVDIZfi8zE94ebIW8KJqOViwaEW6bl72mHsHf4QrizKuedUgdiRbsv3+89h5d7a+W4+fLQ7urVxEzcQEZHIWHCoRZJIJHjjga4Y1s0H1QYBU747iOTsIrFj3ZI/0/Ox4Oqg4vs64v5uviInIiISHwsOtVgyqQRLHu2O/u09UV5lwLgVCThiZSUn4cwlPPtdEgxGAQ/1aI1p97YXOxIRkUVgwaEWTSGX4csnw9GrrTt0lTUY+3UCks5dFjtWgxw9X4RJqw9CX2PEvcHeeG9UN0gkHFRMRASw4BDBSSHH6qf6oE+gB0r0NRi3IgHxpy+JHeuGjmQXYdzKRJTqa3BHkAc+H9MT9nL+dSYiuoq/EYlQW3JWTeyNyKBWKKsyYPzKRPyWfEHsWPWKP30JTyzfj6LyaoT5ueHr8b2htJOJHYuIyKKw4BBd4WgvxzcTe2NIVw2qDEa8tDYZS//MgCAIYkcz2XZci/HfJKKsyoDIoFb4/ukIOHMZBiKia7DgEP2D0k6GpU/0xNP9AwEAi7amY9oPh1FSKe7aVYIg4POdGXjm+yRU1RhxX4ga30zszXJDRHQdLDhE/yKVSvDa/SF4c0QXyKUSbDmWixGf7UWaVidKnpLKarzw42F8EJMOQQCeiPDHsjE9eVmKiOgGWHCIrmNcZAB+eiYSPlcW6Hzg0734NO4Uqptxkc6kc4UY+slubD6aC7lUgrdGdsW7D4ZCLuNfXSKiG5EIljTAoJnodDqoVCoUFxfD1dVV7Dhk4QrLqvDquiOIS8sHAHT2ccU7D3ZFTzOu0q2rrMZHsSexet9ZGAWgjbsDPn4sDL0CPMz2M4mILF1jvr9ZcFhwqAEEQcBvyTl4fdNxFJXXjscZGqrBzEGd0M7Lucl+jr7GgP8lncfH20/hYokeAPBgj9Z4Y0QXuCrtmuznEBFZo8Z8f5vtPPc777yDvn37wtHREW5ubg16jyAImD9/Pnx8fODg4ICoqCicOnWqzjaFhYUYM2YMXF1d4ebmhkmTJqG0tNQMe0D0N4lEgpE9WiP25bvxSHgbSCTA78e0iFryF55efRD7ThfAaLz1fysUllXh691nMGDRTvx3fQoulugR5OmE7yb1wUePhbHcEBE1ktnO4CxYsABubm44f/48VqxYgaKiopu+5/3338fChQuxevVqBAYGYt68eTh27BhOnDgBpVIJABgyZAhyc3Px5Zdforq6GhMnTkTv3r3xww8/NDgbz+DQ7UrXlmDxtnTEnsgzPeejUmJYqA/6dfBEr7bucLlBKREEAReKKrDnVAF2pOXjz/R8VBtq/yqqXRV49u52eCLCHwo5BxITEV1lUZeoVq1ahenTp9+04AiCAF9fX8ycOROvvPIKAKC4uBhqtRqrVq3C6NGjkZqaipCQEBw4cAC9evUCAMTExGDo0KE4f/48fH0btsggCw41ldMXS7FyTyY2HslBSWWN6XmpBPDzcETbVk7wdLKH0l4GQQB0FdXIL6nEybxSFFfUvfU8tLUKo/v4YVTPNrxDioioHo35/raYSTQyMzOh1WoRFRVlek6lUiEiIgLx8fEYPXo04uPj4ebmZio3ABAVFQWpVIqEhAQ8+OCD9X62Xq+HXq83/VmnE+d2X7I97byc8c6DoZh3fwj+OnkR20/kISGzEFmF5Th3qfZxPVIJ0N3PDfd09MZ9IWqE+LJsExE1FYspOFqtFgCgVqvrPK9Wq02vabVaeHt713ldLpfDw8PDtE19Fi5ciDfeeKOJExP9TWknQ3QXDaK7aAAA+SWVyLxYhrOXylBUXo3KaiMECFA52MHDyR7tvZ3RzsuZZ2qIiMykUQVnzpw5eP/992+4TWpqKoKDg28rVFObO3cuZsyYYfqzTqeDn5+fiInI1nm7KOHtokREUCuxoxARtUiNKjgzZ87EhAkTbrhNUFDQLQXRaGr/5ZuXlwcfHx/T83l5eQgLCzNtk5+fX+d9NTU1KCwsNL2/PgqFAgqF4pZyERERkfVpVMHx8vKCl5eXWYIEBgZCo9EgLi7OVGh0Oh0SEhIwdepUAEBkZCSKioqQlJSE8PBwAMCOHTtgNBoRERFhllxERERkfcw2D05WVhaSk5ORlZUFg8GA5ORkJCcn15mzJjg4GOvXrwdQO8/I9OnT8fbbb2Pjxo04duwYxo0bB19fX4wcORIA0LlzZwwePBiTJ09GYmIi9u7di2nTpmH06NENvoOKiIiIbJ/ZBhnPnz8fq1evNv25R48eAIA///wT99xzDwAgPT0dxcXFpm1mzZqFsrIyTJkyBUVFRejfvz9iYmJMc+AAwJo1azBt2jQMHDgQUqkUo0aNwieffGKu3SAiIiIrxKUaOA8OERGRVbCIpRqIiIiIxMKCQ0RERDaHBYeIiIhsDgsOERER2RwWHCIiIrI5LDhERERkc1hwiIiIyOaw4BAREZHNMdtMxpbs6tyGOp1O5CRERETUUFe/txsyR3GLLDglJSUAAD8/P5GTEBERUWOVlJRApVLdcJsWuVSD0WhETk4OXFxcIJFImvSzdTod/Pz8kJ2dzWUgzIjHuXnwODcPHufmw2PdPMx1nAVBQElJCXx9fSGV3niUTYs8gyOVStGmTRuz/gxXV1f+5WkGPM7Ng8e5efA4Nx8e6+ZhjuN8szM3V3GQMREREdkcFhwiIiKyOSw4TUyhUGDBggVQKBRiR7FpPM7Ng8e5efA4Nx8e6+ZhCce5RQ4yJiIiItvGMzhERERkc1hwiIiIyOaw4BAREZHNYcEhIiIim8OC04SWLl2KgIAAKJVKREREIDExUexIVmXhwoXo3bs3XFxc4O3tjZEjRyI9Pb3ONpWVlXj++efRqlUrODs7Y9SoUcjLy6uzTVZWFoYNGwZHR0d4e3vj1VdfRU1NTXPuilV57733IJFIMH36dNNzPM5N48KFCxg7dixatWoFBwcHhIaG4uDBg6bXBUHA/Pnz4ePjAwcHB0RFReHUqVN1PqOwsBBjxoyBq6sr3NzcMGnSJJSWljb3rlg0g8GAefPmITAwEA4ODmjXrh3eeuutOusV8Vg33q5duzB8+HD4+vpCIpFgw4YNdV5vqmN69OhR3HnnnVAqlfDz88MHH3zQNDsgUJNYu3atYG9vL6xcuVI4fvy4MHnyZMHNzU3Iy8sTO5rViI6OFr755hshJSVFSE5OFoYOHSr4+/sLpaWlpm2effZZwc/PT4iLixMOHjwo3HHHHULfvn1Nr9fU1Ahdu3YVoqKihMOHDwu///674OnpKcydO1eMXbJ4iYmJQkBAgNCtWzfhpZdeMj3P43z7CgsLhbZt2woTJkwQEhIShDNnzghbt24VMjIyTNu89957gkqlEjZs2CAcOXJEeOCBB4TAwEChoqLCtM3gwYOF7t27C/v37xd2794ttG/fXnj88cfF2CWL9c477witWrUSNm/eLGRmZgrr1q0TnJ2dhf/7v/8zbcNj3Xi///678N///lf49ddfBQDC+vXr67zeFMe0uLhYUKvVwpgxY4SUlBThxx9/FBwcHIQvv/zytvOz4DSRPn36CM8//7zpzwaDQfD19RUWLlwoYirrlp+fLwAQ/vrrL0EQBKGoqEiws7MT1q1bZ9omNTVVACDEx8cLglD7F1IqlQparda0zbJlywRXV1dBr9c37w5YuJKSEqFDhw5CbGyscPfdd5sKDo9z05g9e7bQv3//675uNBoFjUYjLFq0yPRcUVGRoFAohB9//FEQBEE4ceKEAEA4cOCAaZs//vhDkEgkwoULF8wX3soMGzZMeOqpp+o899BDDwljxowRBIHHuin8u+A01TH9/PPPBXd39zq/N2bPni106tTptjPzElUTqKqqQlJSEqKiokzPSaVSREVFIT4+XsRk1q24uBgA4OHhAQBISkpCdXV1neMcHBwMf39/03GOj49HaGgo1Gq1aZvo6GjodDocP368GdNbvueffx7Dhg2rczwBHuemsnHjRvTq1QuPPPIIvL290aNHDyxfvtz0emZmJrRabZ3jrFKpEBERUec4u7m5oVevXqZtoqKiIJVKkZCQ0Hw7Y+H69u2LuLg4nDx5EgBw5MgR7NmzB0OGDAHAY20OTXVM4+Pjcdddd8He3t60TXR0NNLT03H58uXbytgiF9tsagUFBTAYDHV+2QOAWq1GWlqaSKmsm9FoxPTp09GvXz907doVAKDVamFvbw83N7c626rVami1WtM29f13uPoa1Vq7di0OHTqEAwcOXPMaj3PTOHPmDJYtW4YZM2bgP//5Dw4cOIAXX3wR9vb2GD9+vOk41Xcc/3mcvb2967wul8vh4eHB4/wPc+bMgU6nQ3BwMGQyGQwGA9555x2MGTMGAHiszaCpjqlWq0VgYOA1n3H1NXd391vOyIJDFun5559HSkoK9uzZI3YUm5OdnY2XXnoJsbGxUCqVYsexWUajEb169cK7774LAOjRowdSUlLwxRdfYPz48SKnsy0///wz1qxZgx9++AFdunRBcnIypk+fDl9fXx7rFoyXqJqAp6cnZDLZNXeZ5OXlQaPRiJTKek2bNg2bN2/Gn3/+iTZt2pie12g0qKqqQlFRUZ3t/3mcNRpNvf8drr5GtZeg8vPz0bNnT8jlcsjlcvz111/45JNPIJfLoVareZybgI+PD0JCQuo817lzZ2RlZQH4+zjd6PeGRqNBfn5+nddrampQWFjI4/wPr776KubMmYPRo0cjNDQUTz75JF5++WUsXLgQAI+1OTTVMTXn7xIWnCZgb2+P8PBwxMXFmZ4zGo2Ii4tDZGSkiMmsiyAImDZtGtavX48dO3Zcc9oyPDwcdnZ2dY5zeno6srKyTMc5MjISx44dq/OXKjY2Fq6urtd82bRUAwcOxLFjx5CcnGx69OrVC2PGjDH9/zzOt69fv37XTHNw8uRJtG3bFgAQGBgIjUZT5zjrdDokJCTUOc5FRUVISkoybbNjxw4YjUZEREQ0w15Yh/Lyckildb/OZDIZjEYjAB5rc2iqYxoZGYldu3ahurratE1sbCw6dep0W5enAPA28aaydu1aQaFQCKtWrRJOnDghTJkyRXBzc6tzlwnd2NSpUwWVSiXs3LlTyM3NNT3Ky8tN2zz77LOCv7+/sGPHDuHgwYNCZGSkEBkZaXr96u3LgwYNEpKTk4WYmBjBy8uLty/fxD/vohIEHuemkJiYKMjlcuGdd94RTp06JaxZs0ZwdHQUvv/+e9M27733nuDm5ib89ttvwtGjR4URI0bUe5ttjx49hISEBGHPnj1Chw4dWvSty/UZP3680Lp1a9Nt4r/++qvg6ekpzJo1y7QNj3XjlZSUCIcPHxYOHz4sABCWLFkiHD58WDh37pwgCE1zTIuKigS1Wi08+eSTQkpKirB27VrB0dGRt4lbmk8//VTw9/cX7O3thT59+gj79+8XO5JVAVDv45tvvjFtU1FRITz33HOCu7u74OjoKDz44INCbm5unc85e/asMGTIEMHBwUHw9PQUZs6cKVRXVzfz3liXfxccHuemsWnTJqFr166CQqEQgoODha+++qrO60ajUZg3b56gVqsFhUIhDBw4UEhPT6+zzaVLl4THH39ccHZ2FlxdXYWJEycKJSUlzbkbFk+n0wkvvfSS4O/vLyiVSiEoKEj473//W+fWYx7rxvvzzz/r/Z08fvx4QRCa7pgeOXJE6N+/v6BQKITWrVsL7733XpPklwjCP6Z6JCIiIrIBHINDRERENocFh4iIiGwOCw4RERHZHBYcIiIisjksOERERGRzWHCIiIjI5rDgEBERkc1hwSEiIiKbw4JDRERENocFh4iIiGwOCw4RERHZHBYcIiIisjn/Dy4tnidtvQo0AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "## generate data\n",
    "# df/dt + D d2f/dx^2 = 0\n",
    "\n",
    "CFL = 0.05\n",
    "def dt_cfl(dx, D_m):\n",
    "    # dt of simulation should be set satisfying CFL condition for stability\n",
    "    return CFL*dx**2/(1.+abs(D_m)) #CFL*min(dx/abs(A_m+1e-15),dx**2/abs(D_m+1e-15))\n",
    "    \n",
    "def heat_equation(D_m, f0_m, dx_m, dt_m, Nt_m):\n",
    "    f_m = np.zeros((Nt_m, len(f0_m)))\n",
    "    f_m[0,:] = f0_m\n",
    "    for i in range(Nt_m-1):\n",
    "        f_m[i+1,:] = f_m[i,:] - D_m * np.gradient(np.gradient(f_m[i,:]))/dx_m**2 * dt_m\n",
    "    return f_m\n",
    "\n",
    "L = 1.0  # Length of the domain\n",
    "Nx = 1000  # Number of spatial grid points\n",
    "D_ex = -1.0  # Thermal diffusivity\n",
    "\n",
    "dx = L/Nx\n",
    "dt = dt_cfl(dx, D_ex)\n",
    "Nt = 1000\n",
    "T = dt*Nt\n",
    "\n",
    "# Initial condition\n",
    "x =  np.linspace(0, L, Nx)\n",
    "f0 = 5.*np.sin(2.* np.pi * x)*x*(x-L)\n",
    "fs = heat_equation(D_ex, f0, dx, dt, Nt)\n",
    "\n",
    "alpha = 16\n",
    "nsize = Nt/alpha\n",
    "idx = [i for i in range(0,Nt,int(Nt/nsize))]\n",
    "idx = np.sort(idx)\n",
    "fs = fs[idx, :]\n",
    "\n",
    "nt = np.diff(idx)+1\n",
    "dts = [dt for _ in range(len(nt))]\n",
    "\n",
    "dx = np.array([dx])\n",
    "x = np.array([x])\n",
    "f0 = np.array([f0])\n",
    "fs = np.array([fs])\n",
    "\n",
    "plt.plot(fs[0,0,:])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "dabf70aa-0b26-469c-bfa8-98db4f6d5a01",
   "metadata": {},
   "source": [
    "#### Discover PDE using adjoint method"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "id": "0052167d-3097-4394-bd43-dd000b238c03",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Execution time: 46.51514172554016\n",
      "total number of terms: 18\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "problem = \"1D_heat_equation\"\n",
    "ds = np.array([[1], [2], [3]])\n",
    "ps = np.array([[1], [2], [3]])\n",
    "\n",
    "start_time = time.time()\n",
    "estimated_params, eps = AdjointFindPDE(fs, dx, nt=nt, dt=dts, avg=False, gamma=1e-3, epochs=50, epthr=50, beta = 0.1, ds=ds, ps=ps, V = L, tol = 1e-15, eps0=1e-16)\n",
    "end_time = time.time()\n",
    "\n",
    "i_pde = 0\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if ( d[0]==2 and p[0]==1 ):\n",
    "            plt.plot(estimated_params[:,i_pde,id,ip], label=r\"$α_{d=\"+str(d[0])+\", p=\"+str(p[0])+\"}$\", color=\"blue\", marker=\"o\", markevery=4)\n",
    "plt.axhline(D_ex, linestyle = \"--\", color=\"black\", label=r\"$D$\")\n",
    "plt.legend()\n",
    "plt.ylabel(r'Coefficient')\n",
    "plt.xlabel('Epochs')\n",
    "name = problem + \"_\" + \"Dconv\"\n",
    "plt.savefig(name+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "plt.show()\n",
    "\n",
    "\n",
    "print(\"Execution time: \"+str(end_time-start_time))\n",
    "\n",
    "i_pde = 0\n",
    "err_other = np.zeros_like(estimated_params[:,0,0,0])\n",
    "count = 0\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if not ( d[0]==2 and p[0]==1 ):\n",
    "            err_other += abs(estimated_params[:,i_pde,id,ip])\n",
    "            count += 1\n",
    "            \n",
    "## coeff of u\n",
    "i_pde = 0\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==2 and p[0]==1:\n",
    "            plt.plot(eps[1:], abs(estimated_params[1:,i_pde,id,ip]-D_ex),#/abs(D_ex),\n",
    "                     label=r\"$e(D)$\", marker=\"o\", markevery=4, color=\"black\")\n",
    "plt.plot(eps[1:], err_other[1:]/count, marker=\"s\", markevery=4, color=\"blue\", label=r\"$||e(\\mathbf{\\alpha}^*)||_1$\")\n",
    "plt.yscale('log')\n",
    "plt.ylabel(r'Error')\n",
    "plt.xlabel('Epochs')\n",
    "plt.legend()\n",
    "name = problem + \"_\" + \"D\"+str(nsize/Nt)\n",
    "plt.savefig(name+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "\n",
    "print(\"total number of terms: \"+str(numPDE*len(ds)*len(ps)))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "872f8c56-fe78-48c1-971d-1d89740fce22",
   "metadata": {},
   "source": [
    "#### Discover PDE using PDE-FIND"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 113,
   "id": "eb844b95-7be7-43b9-a90a-0d9ac8d4d9e9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4e-07\n",
      "['1', 'u_{x}', 'u_{xx}', 'u_{xxx}', 'u', 'u^2', 'u^3', 'uu_{x}', 'u^2u_{x}', 'u^3u_{x}', 'uu_{xx}', 'u^2u_{xx}', 'u^3u_{xx}', 'uu_{xxx}', 'u^2u_{xxx}', 'u^3u_{xxx}']\n",
      "u_t = (0.999735 +0.000000i)u_{xx}\n",
      "    + (-2.769027 +0.000000i)u\n",
      "    + (4.051878 +0.000000i)u^3\n",
      "    + (1.398126 +0.000000i)uu_{x}\n",
      "    + (0.185073 +0.000000i)u^3u_{x}\n",
      "    + (0.055569 +0.000000i)u^2u_{xx}\n",
      "    + (0.016480 +0.000000i)uu_{xxx}\n",
      "    + (0.002534 +0.000000i)u^3u_{xxx}\n",
      "   \n",
      "Execution time: 8.507201671600342\n"
     ]
    }
   ],
   "source": [
    "import sys; sys.path.append('PDE-FIND/')\n",
    "from PDE_FIND import *\n",
    "import scipy.io as sio\n",
    "import itertools\n",
    "\n",
    "start_time = time.time()\n",
    "\n",
    "#(numPDE, Nt, Nx0, Nx1, ...)\n",
    "ntt = len(nt)-1 #Nt-1\n",
    "\n",
    "dt = dt*(nt[0]-1)\n",
    "print(dt)\n",
    "\n",
    "# Take up to second order derivatives.\n",
    "u = np.zeros((ntt, Nx))\n",
    "ut = np.zeros((ntt, Nx))\n",
    "ux = np.zeros((ntt, Nx))\n",
    "uxx = np.zeros((ntt, Nx))\n",
    "uxxx = np.zeros((ntt, Nx))\n",
    "\n",
    "\n",
    "for i in range(ntt):\n",
    "    u[i,:] = fs[0, i, :]\n",
    "    ut[i,:] = (fs[0, i+1, :]-fs[0, i, :])/dt\n",
    "    ux[i,:] = np.gradient(u[i,:], axis=0) / dx[0]\n",
    "    uxx[i,:] = np.gradient( np.gradient(u[i,:],axis=0), axis=0) / dx[0]**2\n",
    "    uxxx[i,:] = np.gradient( np.gradient( np.gradient(u[i,:],axis=0), axis=0), axis=0) / dx[0]**3\n",
    "\n",
    "u = u.reshape((ntt * Nx, 1))\n",
    "ut = ut.reshape((ntt * Nx, 1))\n",
    "ux = ux.reshape((ntt * Nx, 1))\n",
    "uxx = uxx.reshape((ntt * Nx, 1))\n",
    "uxxx = uxxx.reshape((ntt * Nx, 1))\n",
    "\n",
    "num_points = ntt * Nx\n",
    "\n",
    "X_data = np.hstack([u])\n",
    "X_ders = np.hstack([np.ones((num_points,1)), ux, uxx, uxxx])\n",
    "X_ders_descr = ['','u_{x}', 'u_{xx}', 'u_{xxx}']\n",
    "X, description = build_Theta(X_data, X_ders, X_ders_descr, 3, data_description = ['u'])\n",
    "print(['1'] + description[1:])\n",
    "\n",
    "c = TrainSTRidge(X,ut,10**-5,0.1)\n",
    "print_pde(c, description)\n",
    "\n",
    "end_time = time.time()\n",
    "print(\"Execution time: \"+str(end_time-start_time))\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8b40a16d-5e00-4b92-9ba6-f14e84901836",
   "metadata": {},
   "source": [
    "### Revisit Burgers' equation"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a3d8f766-379e-4b58-b98f-1136aa95e2e0",
   "metadata": {},
   "source": [
    "#### Generate Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "id": "b1f22f7f-ae04-4d4a-810d-9f8a29c87160",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x18c566a10>]"
      ]
     },
     "execution_count": 114,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "## generate data\n",
    "# df/dt + A*f*df/dx = 0\n",
    "\n",
    "CFL = 0.01\n",
    "def dt_cfl(dx, A_m):\n",
    "    # dt of simulation should be set satisfying CFL condition for stability\n",
    "    return CFL*dx/(1.+abs(A_m)) #CFL*min(dx/abs(A_m+1e-15),dx**2/abs(D_m+1e-15))\n",
    "    \n",
    "def burger_equation(A_m, f0_m, dx_m, dt_m, Nt_m):\n",
    "    f_m = np.zeros((Nt_m, len(f0_m)))\n",
    "    f_m[0,:] = f0_m\n",
    "    for i in range(Nt_m-1):\n",
    "        f_m[i+1,:] = f_m[i,:] - np.gradient( A_m*f_m[i,:]**2)/dx_m * dt_m\n",
    "    return f_m\n",
    "\n",
    "L = 1.0  # Length of the domain\n",
    "Nx = 100  # Number of spatial grid points\n",
    "A_ex = -1.0  # Advection coefficient\n",
    "\n",
    "dx = L/Nx\n",
    "dt = dt_cfl(dx, A_ex)\n",
    "Nt = 1000\n",
    "T = dt*Nt\n",
    "\n",
    "# Initial condition\n",
    "x =  np.linspace(0, L, Nx)\n",
    "f0 = 5.*np.sin(2.* np.pi * x)*x*(x-L)\n",
    "fs = burger_equation(A_ex, f0, dx, dt, Nt)\n",
    "\n",
    "\n",
    "alpha = 16\n",
    "nsize = Nt/alpha\n",
    "idx = [i for i in range(0,Nt,int(Nt/nsize))]\n",
    "idx = np.sort(idx)\n",
    "fs = fs[idx, :]\n",
    "\n",
    "nt = np.diff(idx)+1\n",
    "dts = [dt for _ in range(len(nt))]\n",
    "\n",
    "dx = np.array([dx])\n",
    "x = np.array([x])\n",
    "f0 = np.array([f0])\n",
    "fs = np.array([fs])\n",
    "\n",
    "fs0 = fs.copy()\n",
    "\n",
    "plt.plot(fs[0,0,:])\n",
    "plt.plot(fs[0,-1,:])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0661bafe-a535-490a-9f8f-3a188a971eb9",
   "metadata": {},
   "source": [
    "#### Discover PDE using adjoint method"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 115,
   "id": "26597ff9-44ec-4f2f-989e-4e47f187b717",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Execution time: 65.33126401901245\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "total number of terms: 18\n",
      "4.431721527557838e-07\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "problem = \"1D_burgers_eq_sparse\"\n",
    "\n",
    "fs = fs0.copy()\n",
    "\n",
    "ds = np.array([[1], [2], [3]])\n",
    "ps = np.array([[1], [2], [3]])\n",
    "\n",
    "start_time = time.time()\n",
    "estimated_params, eps = AdjointFindPDE(fs, dx, nt=nt, dt=dts, avg=False, gamma=1e-3, epochs=100, epthr=100, beta = 0.00004, ds=ds, ps=ps, V = L, tol = 1e-15, eps0=1e-16)\n",
    "end_time = time.time()\n",
    "print(\"Execution time: \"+str(end_time-start_time))\n",
    "\n",
    "i_pde = 0\n",
    "\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if ( d[0]==1 and p[0]==2 ):\n",
    "            plt.plot(estimated_params[:,i_pde,id,ip], label=r\"$α_{d=\"+str(d[0])+\", p=\"+str(p[0])+\"}$\", color=\"blue\",marker=\"o\", markevery=5)\n",
    "            total_error = estimated_params[-1,i_pde,id,ip]\n",
    "total_error = abs(total_error-A_ex)\n",
    "plt.axhline(A_ex, color=\"black\", linestyle = \"--\", label=r\"$A$\")\n",
    "plt.ylabel('Coefficient')\n",
    "plt.xlabel('Epochs')\n",
    "plt.legend()\n",
    "name = problem + \"_\" + \"Aconv\"\n",
    "plt.savefig(name+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "plt.show()\n",
    "\n",
    "err_other = np.zeros_like(estimated_params[:,0,0,0])\n",
    "count = 0\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if not ( d[0]==1 and p[0]==2 ):\n",
    "            err_other += abs(estimated_params[:,i_pde,id,ip])\n",
    "            count += 1\n",
    "\n",
    "i_pde = 0\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==1 and p[0]==2:\n",
    "            plt.plot(eps[1:], abs(estimated_params[1:,i_pde,id,ip]-A_ex),\n",
    "                     label=r\"$e(A)$\", marker=\"o\", markevery=5, color=\"blue\")\n",
    "plt.plot(eps[1:], err_other[1:]/count, marker=\"s\", markevery=5, color=\"black\", label=r\"$||e(\\mathbf{\\alpha}^*)||_1$\")\n",
    "plt.yscale('log')\n",
    "plt.ylabel(r'Error')\n",
    "plt.xlabel('Epochs')\n",
    "plt.legend()\n",
    "name = problem + \"_\" + \"A\"\n",
    "plt.savefig(name+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "\n",
    "print(\"total number of terms: \"+str(numPDE*len(ds)*len(ps)))\n",
    "\n",
    "total_error += err_other[-1]\n",
    "print(total_error)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "badc5ed7-9737-4ca3-b3df-ad0324116e58",
   "metadata": {},
   "source": [
    "#### Discover PDE using PDE-FIND"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "id": "ff88fcd1-9d2b-4890-a074-2efa976ca869",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0008\n",
      "['1', 'u_{x}', 'u_{xx}', 'u_{xxx}', 'u', 'u^2', 'u^3', 'uu_{x}', 'u^2u_{x}', 'u^3u_{x}', 'uu_{xx}', 'u^2u_{xx}', 'u^3u_{xx}', 'uu_{xxx}', 'u^2u_{xxx}', 'u^3u_{xxx}']\n",
      "u_t = (0.086862 +0.000000i)u\n",
      "    + (0.116872 +0.000000i)u^3\n",
      "    + (2.021158 +0.000000i)uu_{x}\n",
      "    + (0.005648 +0.000000i)u^2u_{xx}\n",
      "    + (0.000074 +0.000000i)uu_{xxx}\n",
      "   \n",
      "Execution time: 0.6930291652679443\n"
     ]
    }
   ],
   "source": [
    "import sys; sys.path.append('PDE-FIND/')\n",
    "from PDE_FIND import *\n",
    "import scipy.io as sio\n",
    "import itertools\n",
    "\n",
    "fs = fs0.copy()\n",
    "start_time = time.time()\n",
    "\n",
    "#(numPDE, Nt, Nx0, Nx1, ...)\n",
    "ntt = len(nt)-1 #Nt-1\n",
    "\n",
    "dt = dt*(nt[0]-1)\n",
    "print(dt)\n",
    "\n",
    "# Take up to second order derivatives.\n",
    "u = np.zeros((ntt, Nx))\n",
    "ut = np.zeros((ntt, Nx))\n",
    "ux = np.zeros((ntt, Nx))\n",
    "uxx = np.zeros((ntt, Nx))\n",
    "uxxx = np.zeros((ntt, Nx))\n",
    "\n",
    "\n",
    "for i in range(ntt):\n",
    "    u[i,:] = fs[0, i, :]\n",
    "    ut[i,:] = (fs[0, i+1, :]-fs[0, i, :])/dt\n",
    "    ux[i,:] = np.gradient(u[i,:], axis=0) / dx[0]\n",
    "    uxx[i,:] = np.gradient( np.gradient(u[i,:],axis=0), axis=0) / dx[0]**2\n",
    "    uxxx[i,:] = np.gradient( np.gradient( np.gradient(u[i,:],axis=0), axis=0), axis=0) / dx[0]**3\n",
    "\n",
    "u = u.reshape((ntt * Nx, 1))\n",
    "ut = ut.reshape((ntt * Nx, 1))\n",
    "ux = ux.reshape((ntt * Nx, 1))\n",
    "uxx = uxx.reshape((ntt * Nx, 1))\n",
    "uxxx = uxxx.reshape((ntt * Nx, 1))\n",
    "\n",
    "num_points = ntt * Nx\n",
    "\n",
    "X_data = np.hstack([u])\n",
    "X_ders = np.hstack([np.ones((num_points,1)), ux, uxx, uxxx])\n",
    "X_ders_descr = ['','u_{x}', 'u_{xx}', 'u_{xxx}']\n",
    "X, description = build_Theta(X_data, X_ders, X_ders_descr, 3, data_description = ['u'])\n",
    "print(['1'] + description[1:])\n",
    "\n",
    "c = TrainSTRidge(X,ut,10**-5,0.1)\n",
    "print_pde(c, description)\n",
    "\n",
    "end_time = time.time()\n",
    "print(\"Execution time: \"+str(end_time-start_time))\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "33950fd4-26cf-4fec-9757-44913c4d7dbe",
   "metadata": {},
   "source": [
    "## Sensitivity to noise"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "26107820-2b5b-4f76-adf2-182f2d79d149",
   "metadata": {},
   "source": [
    "### Revisit Heat Equation"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2eab1cc0-ddba-4160-8012-24960e9f1952",
   "metadata": {},
   "source": [
    "#### Generate Noisy data for heat equation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 117,
   "id": "eb9351f8-d64a-4b6c-9a44-9f6dff8752ca",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1, 100)\n",
      "(1, 100)\n",
      "(1, 100, 100)\n"
     ]
    }
   ],
   "source": [
    "## generate data, Heat\n",
    "# df/dt + D d2f/dx^2 = 0\n",
    "\n",
    "eps = 0.01 # noise in percentage\n",
    "CFL = 0.05\n",
    "def dt_cfl(dx, D_m):\n",
    "    # dt of simulation should be set satisfying CFL condition for stability\n",
    "    return CFL*dx**2/(1.+abs(D_m)) #CFL*min(dx/abs(A_m+1e-15),dx**2/abs(D_m+1e-15))\n",
    "    \n",
    "def heat_equation(D_m, f0_m, dx_m, dt_m, Nt_m):\n",
    "    f_m = np.zeros((Nt_m, len(f0_m)))\n",
    "    f_m[0,:] = f0_m\n",
    "    for i in range(Nt_m-1):\n",
    "        f_m[i+1,:] = f_m[i,:] - D_m * np.gradient(np.gradient(f_m[i,:]))/dx_m**2 * dt_m\n",
    "    return f_m\n",
    "\n",
    "L = 1.0  # Length of the domain\n",
    "Nx = 100  # Number of spatial grid points\n",
    "D_ex = -1.0  # Thermal diffusivity\n",
    "\n",
    "dx = L/Nx\n",
    "dt = dt_cfl(dx, D_ex)\n",
    "Nt = 100\n",
    "T = dt*Nt\n",
    "\n",
    "# Initial condition\n",
    "x =  np.linspace(0, L, Nx)\n",
    "f0 = 5.*np.sin(2.* np.pi * x)*x*(x-L)\n",
    "fs = heat_equation(D_ex, f0, dx, dt, Nt) #*np.random.normal(0.,0.001,(Nt,Nx)) # (Nt, Nx)\n",
    "\n",
    "dx = np.array([dx])\n",
    "x = np.array([x])\n",
    "f0 = np.array([f0])\n",
    "fs = np.array([fs])\n",
    "\n",
    "print(x.shape)\n",
    "print(f0.shape)\n",
    "print(fs.shape)\n",
    "\n",
    "\n",
    "fs0 = fs.copy()\n",
    "\n",
    "fn = fs + eps/100.*np.std(fs)*np.random.normal(0.,1, fs.shape)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a7153ed2-2aca-4039-b9d5-86f94ad2c616",
   "metadata": {},
   "source": [
    "#### Denoise Data using SVD"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 118,
   "id": "f8f459ab-dcab-4135-a69f-d7280fa494fa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAi8AAAGdCAYAAADaPpOnAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAAA1qUlEQVR4nO3df3SU5Z3//9ckIRN+JIMhS35gUqi1qxFNNCQR9fsRNB7AfuMCqx/WozbifugpnbjY6XaF9gjltC72uMuyrXNkdQ+lLVap+y20as1agy2LjSYEY00jIG1a+UgmASmZJEgCM/f3D5yBkEBmJjP3PbnzfJwz5zj3fc/cV+5zZF7nut7XdTkMwzAEAAAwRqRY3QAAAIBoEF4AAMCYQngBAABjCuEFAACMKYQXAAAwphBeAADAmEJ4AQAAYwrhBQAAjClpVjcg3oLBoI4cOaLMzEw5HA6rmwMAACJgGIZ6enpUUFCglJRL963YLrwcOXJEhYWFVjcDAADE4PDhw7r88ssveY3twktmZqaks398VlaWxa0BAACR8Pv9KiwsDP+OX0rShZfDhw/rgQceUFdXl9LS0vTYY4/pnnvuifjzoaGirKwswgsAAGNMJCUfSRde0tLStGnTJpWWlsrn86msrEx33nmnJk+ebHXTAABAEki68JKfn6/8/HxJUl5ennJycnT8+HHCCwAAkJSAqdK7d+9WdXW1CgoK5HA4tHPnziHXeL1ezZw5UxkZGaqsrFRjY+Ow39Xc3KxAIEABLgAACIt7eOnr61NJSYm8Xu+w57dv3y6Px6N169Zp3759Kikp0YIFC9TV1TXouuPHj+uLX/yinnnmmUver7+/X36/f9ALAADYl8MwDCNhX+5waMeOHVq8eHH4WGVlpcrLy/XUU09JOrsuS2FhoR5++GGtXr1a0tlAcscdd2jFihV64IEHLnmPb33rW1q/fv2Q493d3RTsAgAwRvj9frlcroh+v01dYXdgYEDNzc2qqqo614CUFFVVVamhoUHS2UVqHnzwQd12220jBhdJWrNmjbq7u8Ovw4cPJ6z9AADAeqaGl2PHjikQCCg3N3fQ8dzcXPl8PknSm2++qe3bt2vnzp0qLS1VaWmp3nvvvYt+p9PpVFZWln784x/rxhtv1O23357QvwEAAFgr6WYb3XLLLQoGg1F/zu12y+12h7udAACAPZkaXnJycpSamqrOzs5Bxzs7O5WXl2dmU6IWCBpqbD+urp5Tmp6ZoYpZ2UpNYe8kAADMZmp4SU9PV1lZmerr68NFvMFgUPX19aqtrR3Vd3u9Xnm9XgUCgTi0dLC61g6tf6lNHd2nwsfyXRlaV12shbPz434/AABwcXGveent7VVLS4taWlokSe3t7WppadGHH34oSfJ4PHr22Wf1wx/+UO+//75Wrlypvr4+LV++fFT3dbvdamtrU1NT02j/hEHqWju0ctu+QcFFknzdp7Ry2z7VtXbE9X4AAODS4t7zsnfvXs2fPz/83uPxSJJqamq0detWLVu2TEePHtXatWvl8/lUWlqqurq6IUW8ySAQNLT+pTYNN5fckOSQtP6lNt1RnMcQEgAAJknoOi9mOn/Y6ODBg3FZ56XhDx/r3mffGvG651fcqLlXTBvVvQAAGM+Sdp2XRErEsFFXz6mRL4riOgAAMHq2CS+JMD0zI67XAQCA0bNNePF6vSouLlZ5eXncvrNiVrbyXRm6WDWLQ2dnHVXMyo7bPQEAwKXZJrwkYtgoNcWhddXFw54LBZp11cUU6wIAYCLbhJdEWTg7X0/ff4P+aopz0PE8V4aevv8G1nkBAMBkSbc9QDJaODtf110+VTc9sUsOh/ST/1OpilnT6HEBAMACtul5SUTNy/kmp5/NeYYhlX2GrQEAALCKbcJLolbYDXFOOPeoTp2J/xYEAAAgMrYJL4nmTEuR49POllOnCS8AAFiF8BIhh8OhjLRUSVL/6aDFrQEAYPwivEQh49Oho0/oeQEAwDK2CS+JLtiVpIwJZ3teGDYCAMA6tgkviS7YlaSJ4fDCsBEAAFaxTXgxg5OeFwAALEd4iQI1LwAAWI/wEoXQbCN6XgAAsA7hJQoT05kqDQCA1WwTXsyZbXT2cbHCLgAA1rFNeDFjtlFo2OiTAcILAABWsU14MYOTqdIAAFiO8BKF8DovDBsBAGAZwksUwjUvzDYCAMAyhJcosD0AAADWI7xE4VzPCzUvAABYhfAShYn0vAAAYDnCSxTY2wgAAOvZJryYs0jdp+u8EF4AALCMbcKLOYvUUfMCAIDVbBNezBDa24hhIwAArEN4iUJo2Kj/DD0vAABYhfASBfY2AgDAeoSXKLCrNAAA1iO8RIEVdgEAsB7hJQoZ5+0qbRiGxa0BAGB8IrxEITRsJFG0CwCAVZIyvCxZskSXXXaZ7r77bqubMkio50Vi6AgAAKskZXhZtWqVfvSjH1ndjCEmpKYoLcUhiYXqAACwSlKGl3nz5ikzM9PqZgyLol0AAKwV9/Cye/duVVdXq6CgQA6HQzt37hxyjdfr1cyZM5WRkaHKyko1NjbGuxkJE6p7YX8jAACsEffw0tfXp5KSEnm93mHPb9++XR6PR+vWrdO+fftUUlKiBQsWqKurK6b79ff3y+/3D3olkjONnhcAAKwU9/CyaNEifec739GSJUuGPb9x40atWLFCy5cvV3FxsTZv3qxJkyZpy5YtMd1vw4YNcrlc4VdhYeFomj+ic/sbUfMCAIAVTK15GRgYUHNzs6qqqs41ICVFVVVVamhoiOk716xZo+7u7vDr8OHD8WrusFhlFwAAa6WZebNjx44pEAgoNzd30PHc3Fzt378//L6qqkrvvvuu+vr6dPnll+vFF1/U3Llzh/1Op9Mpp9OZ0HafL7S/0Sn2NwIAwBKmhpdIvf7661F/xuv1yuv1KhBIbKgIzzai5wUAAEuYOmyUk5Oj1NRUdXZ2Djre2dmpvLy8UX232+1WW1ubmpqaRvU9Izl/iwAAAGA+U8NLenq6ysrKVF9fHz4WDAZVX19/0WGhSHm9XhUXF6u8vHy0zbykcM0Ls40AALBE3IeNent7dejQofD79vZ2tbS0KDs7W0VFRfJ4PKqpqdGcOXNUUVGhTZs2qa+vT8uXLx/Vfd1ut9xut/x+v1wu12j/jIsK9bywzgsAANaIe3jZu3ev5s+fH37v8XgkSTU1Ndq6dauWLVumo0ePau3atfL5fCotLVVdXd2QIt5kda7nhWEjAACsEPfwMm/ePBmGcclramtrVVtbG9f7mlWwO/HTnpd+el4AALBEUu5tFAvzC3YJLwAAWME24cUs1LwAAGAt24QXs2YbOdOoeQEAwEq2CS9mDRud29uInhcAAKxgm/BilvD2AGfoeQEAwAqElyiFC3bZ2wgAAEvYJryYvsIuexsBAGAJ24QX02pemCoNAIClbBNezOJkY0YAACxFeIlSaNiIdV4AALAG4SVKrLALAIC1bBNezCrYPbe3EcNGAABYwTbhxey9jQYCQQWCl96AEgAAxJ9twotZQjUvEkNHAABYgfASpdAKuxLhBQAAKxBeopSS4lB6aHNGtggAAMB0hJcYZIR3lqbnBQAAs9kmvJg120g6V7T7CfsbAQBgOtuEF7NmG0nnwks/+xsBAGA624QXM01kiwAAACxDeIlBeGdpal4AADAd4SUGoc0Z2d8IAADzEV5ikMGwEQAAliG8xGAiw0YAAFiG8BIDdpYGAMA6hJcYhLYIILwAAGA+24QXcxepCw0bUfMCAIDZbBNeTF2kLp2eFwAArGKb8GKm8LARK+wCAGA6wksMzu1txLARAABmI7zEIFzzQs8LAACmI7zEILS3UT81LwAAmI7wEgNW2AUAwDqElxiEho3Y2wgAAPMRXmLgZIVdAAAsk5Th5eWXX9Zf//Vf68orr9R//ud/Wt2cISYSXgAAsEya1Q240JkzZ+TxePTGG2/I5XKprKxMS5Ys0bRp06xuWhg1LwAAWCfpel4aGxt1zTXXaMaMGZoyZYoWLVqk1157zepmDZLBrtIAAFgm7uFl9+7dqq6uVkFBgRwOh3bu3DnkGq/Xq5kzZyojI0OVlZVqbGwMnzty5IhmzJgRfj9jxgx99NFH8W7mqLAxIwAA1ol7eOnr61NJSYm8Xu+w57dv3y6Px6N169Zp3759Kikp0YIFC9TV1RXvpiTMxNDeRmcYNgIAwGxxDy+LFi3Sd77zHS1ZsmTY8xs3btSKFSu0fPlyFRcXa/PmzZo0aZK2bNkiSSooKBjU0/LRRx+poKDgovfr7++X3+8f9Eq0UM9LIGjodIAAAwCAmUyteRkYGFBzc7OqqqrONSAlRVVVVWpoaJAkVVRUqLW1VR999JF6e3v16quvasGCBRf9zg0bNsjlcoVfhYWFCf87nBPOPTbWegEAwFymhpdjx44pEAgoNzd30PHc3Fz5fD5JUlpamv71X/9V8+fPV2lpqb72ta9dcqbRmjVr1N3dHX4dPnw4oX+DJDnTUuRwnP1v6l4AADBX0k2VlqS77rpLd911V0TXOp1OOZ1Oeb1eeb1eBQKJDxMOh0MZaan65HRA/UyXBgDAVKb2vOTk5Cg1NVWdnZ2Djnd2diovL29U3+12u9XW1qampqZRfU+kmC4NAIA1TA0v6enpKisrU319ffhYMBhUfX295s6dO6rv9nq9Ki4uVnl5+WibGZHQQnXUvAAAYK64Dxv19vbq0KFD4fft7e1qaWlRdna2ioqK5PF4VFNTozlz5qiiokKbNm1SX1+fli9fPqr7ut1uud1u+f1+uVyu0f4ZI2KVXQAArBH38LJ3717Nnz8//N7j8UiSampqtHXrVi1btkxHjx7V2rVr5fP5VFpaqrq6uiFFvMkug/2NAACwRNzDy7x582QYxiWvqa2tVW1tbVzva2bBrkTNCwAAVkm6vY1iZXrBbho1LwAAWME24cVsoZ4XpkoDAGAu24QXs2cbndvfiJ4XAADMZJvwYtWwETUvAACYyzbhxWzO0DovAwwbAQBgJsJLjMKzjRg2AgDAVLYJL6bXvLDOCwAAlrBNeDF/byNW2AUAwAq2CS9mY5E6AACsQXiJEdsDAABgDcJLjAgvAABYwzbhxeyCXWpeAACwhm3Ci/mL1J19dOxtBACAuWwTXszGsBEAANYgvMQotLdR/xmGjQAAMBPhJUbsbQQAgDUILzEKrfNCzQsAAOayTXixbrYR4QUAADPZJrxYuT2AYRim3BMAANgovJgtNGwkUbQLAICZCC8xCvW8SAwdAQBgJsJLjCakpig1xSGJVXYBADAT4WUUJlK0CwCA6QgvoxCqezl1hvACAIBZCC8xCgQN6dNJRk3tx8++BwAACUd4iUFda4du+e4uHesbkCQ99vPf65bv7lJda4fFLQMAwP5sE17MWqSurrVDK7ftU0f3qUHHfd2ntHLbPgIMAAAJ5jBstsKa3++Xy+VSd3e3srKy4vrdgaChW767a0hwCXFIynNlaM+jt4VnIgEAgJFF8/ttm54XMzS2H79ocJHOlsB0dJ9SY/tx8xoFAMA4Q3iJQlfPxYNLLNcBAIDoEV6iMD0zI67XAQCA6BFeolAxK1v5rgxdrJrFISnflaGKWdlmNgsAgHGF8BKF1BSH1lUXS9KQABN6v666mGJdAAASiPASpYWz8/X0/TcozzV4aCjPlaGn779BC2fnW9QyAADGB8JLDBbOzteeR2/T/TcWSZJuvmKa9jx6G8EFAAATJGV4WbJkiS677DLdfffdVjflolJTHCrOd0mSJjnTGCoCAMAkSRleVq1apR/96EdWN2NEk51nd5U+OXDG4pYAADB+JGV4mTdvnjIzM61uxogmpadJkvr62VUaAACzRB1edu/ererqahUUFMjhcGjnzp1DrvF6vZo5c6YyMjJUWVmpxsbGeLQ16UxOp+cFAACzRR1e+vr6VFJSIq/XO+z57du3y+PxaN26ddq3b59KSkq0YMECdXV1ha8pLS3V7Nmzh7yOHDkS+19igUlOel4AADBbWrQfWLRokRYtWnTR8xs3btSKFSu0fPlySdLmzZv1yiuvaMuWLVq9erUkqaWlJbbWDqO/v1/9/f3h936/P27fPRJ6XgAAMF9ca14GBgbU3NysqqqqczdISVFVVZUaGhrieauwDRs2yOVyhV+FhYUJuc9wwj0vA/S8AABglriGl2PHjikQCCg3N3fQ8dzcXPl8voi/p6qqSvfcc49++ctf6vLLL79k8FmzZo26u7vDr8OHD8fc/miFel4GzgR1OhA07b4AAIxnUQ8bmeH111+P+Fqn0ymn0ymv1yuv16tAwLxekNBsI0k6ORCQa2JSTt4CAMBW4vprm5OTo9TUVHV2dg463tnZqby8vHjeagi32622tjY1NTUl9D7nS09L0YTUs4vT9fVT9wIAgBniGl7S09NVVlam+vr68LFgMKj6+nrNnTs3nrcawuv1qri4WOXl5Qm9z4Umf1r3QtEuAADmiHrYqLe3V4cOHQq/b29vV0tLi7Kzs1VUVCSPx6OamhrNmTNHFRUV2rRpk/r6+sKzjxLF7XbL7XbL7/fL5XIl9F7nm5yephMnTzNdGgAAk0QdXvbu3av58+eH33s8HklSTU2Ntm7dqmXLluno0aNau3atfD6fSktLVVdXN6SI1y4mfVq020fPCwAApog6vMybN0+GYVzymtraWtXW1sbcqFhYUbArnZsufZKeFwAATGGb6TFWFOxK56ZL0/MCAIA5bBNerBKaLn2SheoAADAF4WWUJjs/7XlhqjQAAKawTXixaqo0PS8AAJjLNuGFmhcAAMYH24QXqzDbCAAAcxFeRomeFwAAzGWb8GJZzcunPS8U7AIAYA7bhBeral6mfDrbiIJdAADMYZvwYpXQbCN6XgAAMAfhZZQmM1UaAABT2Sa8WFfzQsEuAABmsk14sW6dF6ZKAwBgJtuEF6tMYqo0AACmIryM0uRPp0qfOh1UIGhY3BoAAOyP8DJKoZ4XSTpJ7wsAAAlHeBklZ1qKUlMckphxBACAGWwTXqyabeRwOM7VvbDWCwAACWeb8GLVbCOJtV4AADCTbcKLlcJrvdDzAgBAwhFe4mBKaHNGCnYBAEg4wkscnKt5YdgIAIBEI7zEwbmaF3peAABINMJLHEwKDRvR8wIAQMIRXuJg8qfDRvS8AACQeISXOJiUHirYpecFAIBEs014sWqROkma/OlU6ZNMlQYAIOFsE16sXKSOnhcAAMxjm/BipXDPCzUvAAAkHOElDsI9L8w2AgAg4QgvccBsIwAAzEN4iQPWeQEAwDyElziYEtqYkZ4XAAASjvASB9S8AABgHsJLHLC3EQAA5km68HL48GHNmzdPxcXFuu666/Tiiy9a3aQRTQpPlQ4oGDQsbg0AAPaWZnUDLpSWlqZNmzaptLRUPp9PZWVluvPOOzV58mSrm3ZRoZ4XSfrkdECTnUn3WAEAsI2k+5XNz89Xfn6+JCkvL085OTk6fvx4UoeXjAkpcjgkwzhbtEt4AQAgcaIeNtq9e7eqq6tVUFAgh8OhnTt3DrnG6/Vq5syZysjIUGVlpRobG2NqXHNzswKBgAoLC2P6vFkcDse5uheKdgEASKiow0tfX59KSkrk9XqHPb99+3Z5PB6tW7dO+/btU0lJiRYsWKCurq7wNaWlpZo9e/aQ15EjR8LXHD9+XF/84hf1zDPPxPBnmW9SOtOlAQAwQ9TjG4sWLdKiRYsuen7jxo1asWKFli9fLknavHmzXnnlFW3ZskWrV6+WJLW0tFzyHv39/Vq8eLFWr16tm266acRr+/v7w+/9fn+Ef0l8TXamST39OsnmjAAAJFRcZxsNDAyoublZVVVV526QkqKqqio1NDRE9B2GYejBBx/UbbfdpgceeGDE6zds2CCXyxV+WTXEFO556afnBQCARIpreDl27JgCgYByc3MHHc/NzZXP54voO958801t375dO3fuVGlpqUpLS/Xee+9d9Po1a9aou7s7/Dp8+PCo/oZYnVvrhZ4XAAASKemmxdxyyy0KBoMRX+90OuV0OuX1euX1ehUIWBMeQmu90PMCAEBixbXnJScnR6mpqers7Bx0vLOzU3l5efG81RBut1ttbW1qampK6H0uJjQ9mp4XAAASK67hJT09XWVlZaqvrw8fCwaDqq+v19y5c+N5q6Qz+dOal156XgAASKioh416e3t16NCh8Pv29na1tLQoOztbRUVF8ng8qqmp0Zw5c1RRUaFNmzapr68vPPsoUSwfNmJ/IwAATBF1eNm7d6/mz58ffu/xeCRJNTU12rp1q5YtW6ajR49q7dq18vl8Ki0tVV1d3ZAi3nhzu91yu93y+/1yuVwJvddwJodrXhg2AgAgkaIOL/PmzZNhXHrzwdraWtXW1sbcqFjQ8wIAwPiQdLtKx8rygt3wCrv0vAAAkEi2CS9WmxSabUTBLgAACUV4iZPQInX0vAAAkFi2CS9er1fFxcUqLy+35P6hReqoeQEAILFsE16sr3kJDRvR8wIAQCLZJrxYLbwxIz0vAAAkFOElTsLbA9DzAgBAQtkmvFhd8zL5vJ6XkdbBAQAAsbNNeLG85uXTnpegIZ06Hfmu2AAAIDq2CS9WmzghNfzf1L0AAJA4hJc4SUlxhIt2qXsBACBxbBNerK55kc7tb0TPCwAAiWOb8GJ1zYt0bmdpFqoDACBxbBNekkG454VhIwAAEobwEkeh6dL0vAAAkDiElzgK7SxNzwsAAIlDeIkjel4AAEg8wkscnZttRM8LAACJYpvwkgxTpcOzjfrpeQEAIFFsE16SYao0PS8AACSebcJLMpjCOi8AACQc4SWOQj0vvcw2AgAgYQgvcTQx/ezj/OPRXjX84WMFgobFLQIAwH4IL3FS19qh7756QJL0+yN+3fvsW7rlu7tU19phccsAALAXwksc1LV2aOW2fTrxyelBx33dp7Ry2z4CDAAAcUR4GaVA0ND6l9o03ABR6Nj6l9oYQgIAIE5sE16sWuelsf24OrpPXfS8Iamj+5Qa24+b1ygAAGzMNuHFqnVeunouHlxiuQ4AAFyabcKLVaZnZsT1OgAAcGmEl1GqmJWtfFeGHBc575CU78pQxaxsM5sFAIBtEV5GKTXFoXXVxZJ00QCzrrpYqSkXOwsAAKJBeImDhbPz9fT9NyjPNXRo6J6yy9V/JsiidQAAxInDMAxb/aL6/X65XC51d3crKyvL1HsHgoYa24+rq+eU/vN//qj3PvIPOp/vytBjX7hal012qqvnlKZnnhtOCn0udIyeGgDAeBLN73eaSW0aF1JTHJp7xTTVtXYMCS7S2SnTX/nJO4OOTZ00QZJ04uS5Be7yspy6t6JIM3MmE3AAALgA4SXOQovWRer80BLi8/fr317/IPyegAMAwDlJF15OnDihqqoqnTlzRmfOnNGqVau0YsUKq5sVsZEWrYtFIgNO2WcuU/Of/8IwFgBgzEi68JKZmandu3dr0qRJ6uvr0+zZs7V06VJNmzbN6qZFxKrF6GINOCkO6fw64uGuGa5Wh9ADALBK0oWX1NRUTZo0SZLU398vwzA0lmqKk3kxuuECzoUToIa7ZrhanUhCD0NbAIBEiDq87N69W08++aSam5vV0dGhHTt2aPHixYOu8Xq9evLJJ+Xz+VRSUqLvf//7qqioiPgeJ06c0K233qoPPvhATz75pHJycqJtpmVCi9b5uk8Nu1mjXUQSehjaAgAkQtThpa+vTyUlJXrooYe0dOnSIee3b98uj8ejzZs3q7KyUps2bdKCBQt04MABTZ8+XZJUWlqqM2fODPnsa6+9poKCAk2dOlXvvvuuOjs7tXTpUt19993Kzc2N4c8zX2jRupXb9skh2TrARCsZhrYIOAAw9o1qnReHwzGk56WyslLl5eV66qmnJEnBYFCFhYV6+OGHtXr16qjv8ZWvfEW33Xab7r777mHP9/f3q7+/P/ze7/ersLDQknVezlfX2qH1L7XFvXgXkbsw9FC7AwDJy7J1XgYGBtTc3Kw1a9aEj6WkpKiqqkoNDQ0RfUdnZ6cmTZqkzMxMdXd3a/fu3Vq5cuVFr9+wYYPWr18/6rbH28LZ+bqjOG/Qj+Bf+gb07VcGB5rhehEQHxcObVG7AwD2ENfwcuzYMQUCgSFDPLm5udq/f39E3/HnP/9ZX/rSl8KFug8//LCuvfbai16/Zs0aeTye8PtQz0syCC1ad74Fs/OG/OhJ534I/3TspJ5v/FA+PwHHDGbW7kRaz0MIAoBLS7rZRhUVFWppaYn4eqfTKafTKa/XK6/Xq0AgkLjGxcFwgUbSoGO1t32OgJPEYg04kdTzULsDACOLa3jJyclRamqqOjs7Bx3v7OxUXl5ePG81hNvtltvtDo+ZjWVmBpxIhk0QveGeXyRT1SMZ2iLgABjv4hpe0tPTVVZWpvr6+nARbzAYVH19vWpra+N5q3EvHgEn0oLV4Wp1CD3mSWTAkajdATD2RB1eent7dejQofD79vZ2tbS0KDs7W0VFRfJ4PKqpqdGcOXNUUVGhTZs2qa+vT8uXL49rwy80VoaNzBRJwBnu/XDHLqzVGemHkKEtc8WrOJnQA2AsiHqq9K9//WvNnz9/yPGamhpt3bpVkvTUU0+FF6krLS3V9773PVVWVsalwSOJZqoVEisQNBjasgFmZAEwQzS/36Na5yUZEV7GlpECTjyHtmAeAg6AaI3L8HL+sNHBgwcJL+PQhUHowtBD7U5yIeAAON+4DC8h9LzgUkYKONTuJJd4rqlD6AGSG+GF8II4ilftTiT1PIhepM+aXh0guY3L8MKwEawUSe1OJPU81O6YJ9KAQ5gBzDEuw0sIPS8Y6+JRu4P4GG7qOIEGSAzCC+EFNkdxsnUiGX5ixWMgeoQXwgsQdXEyoSc2se5ZRc0NMNi4DC/UvADxwYwsc1BUDAw2LsNLCD0vgPniNSMLgxFwMJ4QXggvQNIh4CQGAQd2QXghvABjUiLX1BnPmBaOsYDwQngBbCuWNXXo1RkZRcWw2rgMLxTsAriUWHp1xjt6bGCmcRleQuh5ARCrCwPOcFPHMVi+K0Prqou1cHa+1U3BGEd4IbwAiJPzA02kw0/jacVjhyRD0lerrgz3xrBIH2JBeCG8AEiQSGpuIlnx2M41N8Mt0kfvDEZCeCG8AEgy43mq+HC9M/TG4EKEF8ILgDFoPAUc1qLBhcZleGG2EYDxwK4Bh8X2MC7DSwg9LwDGO7tOCx8u4FBPYx+EF8ILAFxSJNPCx0KPDfU09kF4IbwAQNTs0mPDQnpjE+GF8AIACXHhujebXj8o6WzvR7JiaGlsiOb3O82kNgEAbCA1xaG5V0wLv//rvCla/9Lg4aZkW6TP131KX962j4X0bISeFwDAqFw43HR+MEjW3pnhFtIbbmNKAo15GDYivABA0qhr7RjSOzMWMNxkrnEZXljnBQCSVyx7RCWLv795pqqK8+iJSbBxGV5C6HkBgOQ3FhfbG25oidqZ+CG8EF4AYMyLJOBYXU/DJpTxQ3ghvADAuJBs9TQsmhc7wgvhBQDGjZHqaaxGb0xkCC+EFwAYt5JtIb1Qn8vT999AgLkEFqkDAIxbybaQXug239jxnj45HVReFkNJo0XPCwDA9i61kN7FNqZMJIaShmLYiPACAIhSKOD8qs2nLW/+KVx8mwgMJQ3FsBEAAFEKDTfNvWKaKmZlJ3QWUygUrf7/3lNmxgTd+NlpDCNFIWl7Xk6ePKmrr75a99xzj/7lX/4l4s/R8wIAiIcLh5qGG1qKV+0Mw0g26Xl5/PHHdeONN1rdDADAOHVh4a8kLZidl5BNKH3dp7Ry2z6GkSKUlOHlgw8+0P79+1VdXa3W1larmwMAgKThA81IM5siwYyk6KRE+4Hdu3erurpaBQUFcjgc2rlz55BrvF6vZs6cqYyMDFVWVqqxsTGqe/zjP/6jNmzYEG3TAACw1MLZ+drz6G16fsWN+rf/XaLsyemKJn4c7zutr25v0b3PvqVbvrtLda0dCWvrWBZ1z0tfX59KSkr00EMPaenSpUPOb9++XR6PR5s3b1ZlZaU2bdqkBQsW6MCBA5o+fbokqbS0VGfOnBny2ddee01NTU36/Oc/r89//vP67W9/O2J7+vv71d/fH37v9/uj/ZMAAIib83tnJqanauW2fTHNXOroPqUvb9vHrtbDGFXBrsPh0I4dO7R48eLwscrKSpWXl+upp56SJAWDQRUWFurhhx/W6tWrR/zONWvWaNu2bUpNTVVvb69Onz6tr33ta1q7du2w13/rW9/S+vXrhxynYBcAkAzitf+S3Yt6TVvn5cLwMjAwoEmTJum//uu/BgWampoanThxQj//+c+j+v6tW7eqtbX1krONhut5KSwsJLwAAJJGIGjorT98LPdP9unEJ6dj+g67rw0TTXiJuublUo4dO6ZAIKDc3NxBx3Nzc+Xz+eJ5qzCn06msrCz9+Mc/1o033qjbb789IfcBACBWqSkO3Xxljp7422vlkKKqgwkxPn19Y8d72vHOR2r4w8cKmLXHQZJJytlGIQ8++GDE17rdbrnd7nByAwAg2Sycna+n779hVMNIoaJeScrLcureiiLNzJms6ZnjZ4ZSXMNLTk6OUlNT1dnZOeh4Z2en8vLy4nkrAADGpIWz83VH8dn1Ynzdn+jbr7yvv/QNxLQVgc/fr397/YPwe7vXxYTEddgoPT1dZWVlqq+vDx8LBoOqr6/X3Llz43mrIbxer4qLi1VeXp7Q+wAAMFqhGUlLbrhc/7xktqTYhpIuFFrszu5TrKMOL729vWppaVFLS4skqb29XS0tLfrwww8lSR6PR88++6x++MMf6v3339fKlSvV19en5cuXx7XhF3K73Wpra1NTU1NC7wMAQDyFhpLyXBmj/q5Q7836l9psXQ8T9bDR3r17NX/+/PB7j8cj6eyMoq1bt2rZsmU6evSo1q5dK5/Pp9LSUtXV1Q0p4gUAAGedP5Q02l2tDZ1dI6ax/fiQ1YDtImk3ZoyW1+uV1+tVIBDQwYMHmSoNABiz4rE2zL//Xan+pnRGHFuVWKat85KM2FUaAGAHoV2tYy3qrZ3/Od38uZwxMwOJ8EJ4AQDYSF1rh1Zu2ycp+qGksTIDybJF6qzEbCMAgF2NpqjXjjOQ6HkBAGCMCA0ldfWc0p+OndTzjR/K5x+5LsYhKc+VoT2P3pa0Q0jR/H4n9Qq7AADgnPN3rJak2ts+p8b243rz0FE99cYfLvq50AykrW+268GbZyVtgImUbYaNAAAYb0Jh5srczIiu//Yr7+uW7+4a80NItgkv1LwAAMar6ZmR18LYoQaGmhcAAMa4QNDQLd/dJV/3qYhnI2VPnqDH/t9rlJeVHBs6jsvZRgAAjFepKQ6tqy6WFPkeSaHdqe999q0xN5REeAEAwAbG03RqwgsAADaxcHa+9jx6mx77wtVRfW6sbehom/BCwS4AAGeHkB68eZbyXRkRDyFJgzd0THa2CS9ut1ttbW1qamqyuikAAFgqlhqYkFdbO9Twh4+TugeG2UYAANjUaHanNntPJDZmJLwAACAp9t2pQz02T99/gykBhu0BAACApMFbCkxMT9XKbfvk0Mi7Uxs6G2DWv9SmO4rzLF8H5ny2qXkBAACXFu106mQt4rVNz4vX65XX61UgELC6KQAAJK2Fs/N1R3GeGtuP69XWDv2o4c8jfqarJ/qamUSyTc8Ls40AAIhMaChpUYS1LNHsnWQG24QXAAAQnYpZ2ZdcD8ahs7OOKmZlm9msERFeAAAYp0ZaD8aQdOfss0NMybTuC1OlAQAY5yJZDybR676wzgvhBQCAqITWg/lVm09b3vzTkPOJXvclmt9vho0AAIBSUxyqmJWtV1t9w55Pps0bCS8AAECS1Nh+/JJDR8my7gvhBQAASIp8PRer132xTXjxer0qLi5WeXm51U0BAGBMinQ9F6vXfbFNeGGROgAARmesrPtim/ACAABGZ6R1XyRpXXWx5Zs0El4AAEDYxTZvzMpIS9g06WjZZmNGAAAQH+dv3vh844f6xbtHdEPR1KQILhLhBQAADCO0eaNr4gT94t0jerv9L+o/E5AzLdXqpjFsBAAALu7q/Ez9VaZTn5wOaO+f/mJ1cyQRXgAAwCU4HA79ryv/SpK0++BRi1tzFuEFAABc0v/6fI4k6TdJEl6SsuZl5syZysrKUkpKii677DK98cYbVjcJAIBx6/+58q/kcEj7fT3q8p/S9CxrF6lLyvAiSb/97W81ZcoUq5sBAMC4lz05XdfOcOl3/7dbW978k67Oz9T0zLOL1Vmx5kvShhcAAJA8ZkydqN/9325t/s0fwsfyXRlaV11s+hTqqGtedu/ererqahUUFMjhcGjnzp1DrvF6vZo5c6YyMjJUWVmpxsbGqO7hcDh06623qry8XM8991y0TQQAAHFU19qhV1t9Q477uk9p5bZ9qmvtMLU9Ufe89PX1qaSkRA899JCWLl065Pz27dvl8Xi0efNmVVZWatOmTVqwYIEOHDig6dOnS5JKS0t15syZIZ997bXXVFBQoD179mjGjBnq6OhQVVWVrr32Wl133XXDtqe/v1/9/f3h936/P9o/CQAAXEQgaGj9S23DnjN0dhuB9S+16Y7iPNOGkByGYRgxf9jh0I4dO7R48eLwscrKSpWXl+upp56SJAWDQRUWFurhhx/W6tWro77H17/+dV1zzTV68MEHhz3/rW99S+vXrx9yvLu7W1lZWVHfDwAAnNPwh49177NvjXjd8ytu1NwrpsV8H7/fL5fLFdHvd1ynSg8MDKi5uVlVVVXnbpCSoqqqKjU0NET0HX19ferp6ZEk9fb2ateuXbrmmmsuev2aNWvU3d0dfh0+fHh0fwQAAAjr6jkV1+viIa4Fu8eOHVMgEFBubu6g47m5udq/f39E39HZ2aklS5ZIkgKBgFasWKHy8vKLXu90OuV0OmNvNAAAuKjpmZFNi470unhIutlGn/3sZ/Xuu+9G/Tmv1yuv16tAIJCAVgEAMD5VzMpWvitDvu5TGq7OxCEpz3V22rRZ4jpslJOTo9TUVHV2dg463tnZqby8vHjeagi32622tjY1NTUl9D4AAIwnqSkOrasulnQ2qJwv9H5ddbGp673ENbykp6errKxM9fX14WPBYFD19fWaO3duPG81hNfrVXFx8SWHmAAAQPQWzs7X0/ffoDzX4KGhPFeGnr7/BtPXeYl6tlFvb68OHTokSbr++uu1ceNGzZ8/X9nZ2SoqKtL27dtVU1Oj//iP/1BFRYU2bdqkn/70p9q/f/+QWphEiKZaGQAARC4QNNTYflxdPafivsJuNL/fUde87N27V/Pnzw+/93g8kqSamhpt3bpVy5Yt09GjR7V27Vr5fD6Vlpaqrq7OlOACAAASJzXFMarp0PEyqnVeksn5BbsHDx6k5wUAgDEkmp4X24SXEIaNAAAYeyxbpA4AACDRbBNemG0EAMD4wLARAACwHMNGAADAtggvAABgTLFNeKHmBQCA8YGaFwAAYLmErrCb7EJZzO/3W9wSAAAQqdDvdiR9KrYLLz09PZKkwsJCi1sCAACi1dPTI5fLdclrbDdsFAwGdeTIEWVmZsrhiO/23H6/X4WFhTp8+DBDUgnGszYPz9o8PGvz8KzNE69nbRiGenp6VFBQoJSUS5fk2q7nJSUlRZdffnlC75GVlcX/DCbhWZuHZ20enrV5eNbmicezHqnHJcQ2s40AAMD4QHgBAABjCuElCk6nU+vWrZPT6bS6KbbHszYPz9o8PGvz8KzNY8Wztl3BLgAAsDd6XgAAwJhCeAEAAGMK4QUAAIwphBcAADCmEF4AAMCYQniJkNfr1cyZM5WRkaHKyko1NjZa3aQxb8OGDSovL1dmZqamT5+uxYsX68CBA4OuOXXqlNxut6ZNm6YpU6bob//2b9XZ2WlRi+3jiSeekMPh0COPPBI+xrOOn48++kj333+/pk2bpokTJ+raa6/V3r17w+cNw9DatWuVn5+viRMnqqqqSh988IGFLR6bAoGAHnvsMc2aNUsTJ07UFVdcoW9/+9uDNvbjWcdu9+7dqq6uVkFBgRwOh3bu3DnofCTP9vjx47rvvvuUlZWlqVOn6u///u/V29s7+sYZGNELL7xgpKenG1u2bDF+//vfGytWrDCmTp1qdHZ2Wt20MW3BggXGD37wA6O1tdVoaWkx7rzzTqOoqMjo7e0NX/PlL3/ZKCwsNOrr6429e/caN954o3HTTTdZ2Oqxr7Gx0Zg5c6Zx3XXXGatWrQof51nHx/Hjx43PfOYzxoMPPmi8/fbbxh//+Efjv//7v41Dhw6Fr3niiScMl8tl7Ny503j33XeNu+66y5g1a5bxySefWNjysefxxx83pk2bZrz88stGe3u78eKLLxpTpkwx/v3f/z18Dc86dr/85S+Nb37zm8bPfvYzQ5KxY8eOQecjebYLFy40SkpKjLfeesv4n//5H+Nzn/ucce+99466bYSXCFRUVBhutzv8PhAIGAUFBcaGDRssbJX9dHV1GZKM3/zmN4ZhGMaJEyeMCRMmGC+++GL4mvfff9+QZDQ0NFjVzDGtp6fHuPLKK41f/epXxq233hoOLzzr+Hn00UeNW2655aLng8GgkZeXZzz55JPhYydOnDCcTqfx/PPPm9FE2/jCF75gPPTQQ4OOLV261LjvvvsMw+BZx9OF4SWSZ9vW1mZIMpqamsLXvPrqq4bD4TA++uijUbWHYaMRDAwMqLm5WVVVVeFjKSkpqqqqUkNDg4Uts5/u7m5JUnZ2tiSpublZp0+fHvTsr7rqKhUVFfHsY+R2u/WFL3xh0DOVeNbx9Itf/EJz5szRPffco+nTp+v666/Xs88+Gz7f3t4un8836Fm7XC5VVlbyrKN00003qb6+XgcPHpQkvfvuu9qzZ48WLVokiWedSJE824aGBk2dOlVz5swJX1NVVaWUlBS9/fbbo7q/7XaVjrdjx44pEAgoNzd30PHc3Fzt37/folbZTzAY1COPPKKbb75Zs2fPliT5fD6lp6dr6tSpg67Nzc2Vz+ezoJVj2wsvvKB9+/apqalpyDmedfz88Y9/1NNPPy2Px6NvfOMbampq0j/8wz8oPT1dNTU14ec53L8pPOvorF69Wn6/X1dddZVSU1MVCAT0+OOP67777pMknnUCRfJsfT6fpk+fPuh8WlqasrOzR/38CS9ICm63W62trdqzZ4/VTbGlw4cPa9WqVfrVr36ljIwMq5tja8FgUHPmzNE///M/S5Kuv/56tba2avPmzaqpqbG4dfby05/+VM8995x+8pOf6JprrlFLS4seeeQRFRQU8KxtjmGjEeTk5Cg1NXXIrIvOzk7l5eVZ1Cp7qa2t1csvv6w33nhDl19+efh4Xl6eBgYGdOLEiUHX8+yj19zcrK6uLt1www1KS0tTWlqafvOb3+h73/ue0tLSlJuby7OOk/z8fBUXFw86dvXVV+vDDz+UpPDz5N+U0fv617+u1atX6+/+7u907bXX6oEHHtBXv/pVbdiwQRLPOpEiebZ5eXnq6uoadP7MmTM6fvz4qJ8/4WUE6enpKisrU319ffhYMBhUfX295s6da2HLxj7DMFRbW6sdO3Zo165dmjVr1qDzZWVlmjBhwqBnf+DAAX344Yc8+yjdfvvteu+999TS0hJ+zZkzR/fdd1/4v3nW8XHzzTcPmfJ/8OBBfeYzn5EkzZo1S3l5eYOetd/v19tvv82zjtLJkyeVkjL4Zyw1NVXBYFASzzqRInm2c+fO1YkTJ9Tc3By+ZteuXQoGg6qsrBxdA0ZV7jtOvPDCC4bT6TS2bt1qtLW1GV/60peMqVOnGj6fz+qmjWkrV640XC6X8etf/9ro6OgIv06ePBm+5stf/rJRVFRk7Nq1y9i7d68xd+5cY+7cuRa22j7On21kGDzreGlsbDTS0tKMxx9/3Pjggw+M5557zpg0aZKxbdu28DVPPPGEMXXqVOPnP/+58bvf/c74m7/5G6bvxqCmpsaYMWNGeKr0z372MyMnJ8f4p3/6p/A1POvY9fT0GO+8847xzjvvGJKMjRs3Gu+8847x5z//2TCMyJ7twoULjeuvv954++23jT179hhXXnklU6XN9P3vf98oKioy0tPTjYqKCuOtt96yukljnqRhXz/4wQ/C13zyySfGV77yFeOyyy4zJk2aZCxZssTo6OiwrtE2cmF44VnHz0svvWTMnj3bcDqdxlVXXWU888wzg84Hg0HjscceM3Jzcw2n02ncfvvtxoEDByxq7djl9/uNVatWGUVFRUZGRobx2c9+1vjmN79p9Pf3h6/hWcfujTfeGPbf6JqaGsMwInu2H3/8sXHvvfcaU6ZMMbKysozly5cbPT09o26bwzDOW4oQAAAgyVHzAgAAxhTCCwAAGFMILwAAYEwhvAAAgDGF8AIAAMYUwgsAABhTCC8AAGBMIbwAAIAxhfACAADGFMILAAAYUwgvAABgTPn/AenyEAWi9q79AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def condition(x): return x < thr\n",
    "\n",
    "#uw,sigmaw,vw = svd(W, full_matrices=False); vw = vw.T\n",
    "ufn,sigmafn,vfn = np.linalg.svd(fn[0,:,:].T, full_matrices=False); vfn = vfn.T\n",
    "\n",
    "plt.figure()\n",
    "plt.semilogy(sigmafn, marker=\"o\")\n",
    "\n",
    "thr = 1e-4\n",
    "\n",
    "dim_f = [idx for idx, element in enumerate(abs(np.diff(sigmafn))) if condition(element)][0]\n",
    "\n",
    "fd = ufn[:,0:dim_f].dot(np.diag(sigmafn[0:dim_f]).dot(vfn[:,0:dim_f].T))\n",
    "fd = (fd.T)[None,:]\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "35313429-00ee-400f-a528-c053e54c22ae",
   "metadata": {},
   "source": [
    "##### Adjoint for denoised data for heat equation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 119,
   "id": "8038e7c7-546a-4ec0-8354-45078cbe84ad",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Execution time: 76.56187391281128\n",
      "total number of terms: 18\n",
      "8.534209576738228e-05\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "ds = np.array([[1], [2], [3]])\n",
    "ps = np.array([[1], [2], [3]])\n",
    "\n",
    "start_time = time.time()\n",
    "estimated_params, eps = AdjointFindPDE(fd, dx, data_dt=dt, avg=True, gamma=1e-3, epochs=1000, epthr=100, beta = 0.05, ds=ds, ps=ps, V = L, tol = 1e-10, eps0=1e-9)\n",
    "end_time = time.time()\n",
    "\n",
    "i_pde = 0\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if ( d[0]==2 and p[0]==1 ):\n",
    "            plt.plot(estimated_params[:,i_pde,id,ip], label=r\"$α_{d=\"+str(d[0])+\", p=\"+str(p[0])+\"}$\", color=\"blue\", marker=\"o\", markevery=4)\n",
    "            err_D = estimated_params[-1,i_pde,id,ip]\n",
    "err_D = abs(err_D - D_ex)\n",
    "plt.axhline(D_ex, linestyle = \"--\", color=\"black\", label=r\"$D$\")\n",
    "plt.legend()\n",
    "plt.ylabel(r'Coefficient')\n",
    "plt.xlabel('Epochs')\n",
    "name = problem + \"_\" + \"Dconv\"\n",
    "#plt.savefig(name+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "plt.show()\n",
    "\n",
    "end_time = time.time()\n",
    "print(\"Execution time: \"+str(end_time-start_time))\n",
    "\n",
    "i_pde = 0\n",
    "err_other = np.zeros_like(estimated_params[:,0,0,0])\n",
    "count = 0\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if not ( d[0]==2 and p[0]==1 ):\n",
    "            err_other += abs(estimated_params[:,i_pde,id,ip])\n",
    "            count += 1\n",
    "\n",
    "## coeff of u\n",
    "i_pde = 0\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==2 and p[0]==1:\n",
    "            plt.plot(eps[1:], abs(estimated_params[1:,i_pde,id,ip]-D_ex),#/abs(D_ex),\n",
    "                     label=r\"$e(D)$\", marker=\"o\", markevery=4, color=\"black\")\n",
    "plt.plot(eps[1:], err_other[1:]/count, marker=\"s\", markevery=4, color=\"blue\", label=r\"$||e(\\mathbf{\\alpha}^*)||_1$\")\n",
    "plt.yscale('log')\n",
    "plt.ylabel(r'Error')\n",
    "plt.xlabel('Epochs')\n",
    "plt.legend()\n",
    "#name = problem + \"_\" + \"D\"\n",
    "#plt.savefig(name+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "\n",
    "print(\"total number of terms: \"+str(numPDE*len(ds)*len(ps)))\n",
    "print((err_other[-1])+err_D)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4a2eb56e-8b4e-4354-a42b-cfef1df9d994",
   "metadata": {},
   "source": [
    "##### Using PDE-FIND"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 120,
   "id": "51b76322-3914-4c5a-9b11-05a51fe0b2a1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['1', 'u_{x}', 'u_{xx}', 'u_{xxx}', 'u', 'u^2', 'u^3', 'uu_{x}', 'u^2u_{x}', 'u^3u_{x}', 'uu_{xx}', 'u^2u_{xx}', 'u^3u_{xx}', 'uu_{xxx}', 'u^2u_{xxx}', 'u^3u_{xxx}']\n",
      "u_t = (1.020101 +0.000000i)u_{xx}\n",
      "    + (-18.700150 +0.000000i)u\n",
      "    + (80.302027 +0.000000i)u^3\n",
      "    + (7.264465 +0.000000i)uu_{x}\n",
      "    + (-7.018686 +0.000000i)u^3u_{x}\n",
      "    + (1.016071 +0.000000i)u^2u_{xx}\n",
      "    + (0.073288 +0.000000i)uu_{xxx}\n",
      "    + (-0.093372 +0.000000i)u^3u_{xxx}\n",
      "   \n",
      "Execution time: 1.0946869850158691\n",
      "[1.02010149]\n",
      "[114.48816032]\n"
     ]
    }
   ],
   "source": [
    "import sys; sys.path.append('PDE-FIND/')\n",
    "from PDE_FIND import *\n",
    "import scipy.io as sio\n",
    "import itertools\n",
    "\n",
    "start_time = time.time()\n",
    "\n",
    "#(numPDE, Nt, Nx0, Nx1, ...)\n",
    "nt = Nt-1\n",
    "\n",
    "# Take up to second order derivatives.\n",
    "u = np.zeros((nt, Nx))\n",
    "ut = np.zeros((nt, Nx))\n",
    "ux = np.zeros((nt, Nx))\n",
    "uxx = np.zeros((nt, Nx))\n",
    "uxxx = np.zeros((nt, Nx))\n",
    "\n",
    "for i in range(nt):\n",
    "    u[i,:] = fd[0, i, :]\n",
    "    ut[i,:] = (fd[0, i+1, :]-fd[0, i, :])/dt\n",
    "    ux[i,:] = np.gradient(u[i,:], axis=0) / dx[0]\n",
    "    uxx[i,:] = np.gradient( np.gradient(u[i,:],axis=0), axis=0) / dx[0]**2\n",
    "    uxxx[i,:] = np.gradient( np.gradient( np.gradient(u[i,:],axis=0), axis=0), axis=0) / dx[0]**3\n",
    "\n",
    "u = u.reshape((nt * Nx, 1))\n",
    "ut = ut.reshape((nt * Nx, 1))\n",
    "ux = ux.reshape((nt * Nx, 1))\n",
    "uxx = uxx.reshape((nt * Nx, 1))\n",
    "uxxx = uxxx.reshape((nt * Nx, 1))\n",
    "\n",
    "num_points = nt * Nx\n",
    "\n",
    "X_data = np.hstack([u])\n",
    "X_ders = np.hstack([np.ones((num_points,1)), ux, uxx, uxxx])\n",
    "X_ders_descr = ['','u_{x}', 'u_{xx}', 'u_{xxx}']\n",
    "X, description = build_Theta(X_data, X_ders, X_ders_descr, 3, data_description = ['u'])\n",
    "print(['1'] + description[1:])\n",
    "\n",
    "c = TrainSTRidge(X,ut,10**-6,10)\n",
    "print_pde(c, description)\n",
    "\n",
    "end_time = time.time()\n",
    "print(\"Execution time: \"+str(end_time-start_time))\n",
    "\n",
    "coeff_pdefind = []\n",
    "for i in range(len(c)):\n",
    "        if c[i] != 0:\n",
    "            coeff_pdefind.append( abs(c[i]) )\n",
    "coeff_pdefind = np.array( coeff_pdefind )\n",
    "print(coeff_pdefind[0])\n",
    "print(np.sum(coeff_pdefind[1:]) + abs(-coeff_pdefind[0]-D_ex))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e12a6a9b-b568-4250-8347-b8d89b270690",
   "metadata": {},
   "source": [
    "### Revisit Burgers' equation"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e9e54c21-2318-4843-a031-5bdb7ec01d48",
   "metadata": {},
   "source": [
    "#### Generate noisy data set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 121,
   "id": "e3ea38b7-2a95-45da-b075-0ea21eb104f2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1, 100)\n",
      "(1, 100)\n",
      "(1, 100, 100)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x18c3387d0>]"
      ]
     },
     "execution_count": 121,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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fTvJycna9+eoV69ebNy4kaSkpNJHp06dGDJkSOnX2tflo3v37n+73cGOHTto0KABAI0aNSI8PLzMvs7KymLFihXa1+coLy8Pq7XsR53NZsPhcADa165yNvs1Li6OjIwM1qxZU7rNggULcDgcxMbG/vsQ/3qYshiG4bxM3Nvb2/jkk0+MLVu2GCNHjjQCAwONlJQUs6NVaaNGjTICAgKMRYsWGUeOHCl95OXllW5z5513GvXr1zcWLFhgrF692oiLizPi4uJMTO0+/vsqKsPQvi4vK1euNDw8PIznnnvO2LlzpzFt2jTDz8/P+OKLL0q3eeGFF4zAwEDjp59+MjZs2GBceeWVunT5PNxyyy1G3bp1Sy8T/+GHH4yQkBDjkUceKd1G+/r8ZGdnG+vWrTPWrVtnAMZrr71mrFu3zti/f79hGGe3X/v27Wu0b9/eWLFihfH7778bzZo102XildFbb71l1K9f3/Dy8jK6dOliLF++3OxIVR5wysfHH39cuk1+fr5x1113GUFBQYafn59x1VVXGUeOHDEvtBv534KjfV1+Zs2aZbRu3drw9vY2oqOjjffff7/MeofDYYwfP94ICwszvL29jV69ehnbt283KW3VlZWVZdx///1G/fr1DR8fH6Nx48bG448/bhQWFpZuo319fhYuXHjKv8+33HKLYRhnt1+PHz9u3HDDDUbNmjUNf39/Y9iwYUZ2dna55LMYxn/dzlFERETEDWgMjoiIiLgdFRwRERFxOyo4IiIi4nZUcERERMTtqOCIiIiI21HBEREREbejgiMiIiJuRwVHRERE3I4KjoiIiLgdFRwRERFxOyo4IiIi4nZUcERERMTt/D8baMXYGvGZAwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "## generate data, burgers' equation\n",
    "# df/dt + A*f*df/dx = 0\n",
    "\n",
    "eps = 0.1 # noise in percentage\n",
    "\n",
    "CFL = 0.01\n",
    "def dt_cfl(dx, A_m):\n",
    "    # dt of simulation should be set satisfying CFL condition for stability\n",
    "    return CFL*dx/(1.+abs(A_m)) #CFL*min(dx/abs(A_m+1e-15),dx**2/abs(D_m+1e-15))\n",
    "    \n",
    "def burger_equation(A_m, f0_m, dx_m, dt_m, Nt_m):\n",
    "    f_m = np.zeros((Nt_m, len(f0_m)))\n",
    "    f_m[0,:] = f0_m\n",
    "    for i in range(Nt_m-1):\n",
    "        f_m[i+1,:] = f_m[i,:] - np.gradient( A_m*f_m[i,:]**2)/dx_m * dt_m\n",
    "    return f_m\n",
    "\n",
    "L = 1.0  # Length of the domain\n",
    "Nx = 100  # Number of spatial grid points\n",
    "A_ex = -1.0  # Advection coefficient\n",
    "\n",
    "dx = L/Nx\n",
    "dt = dt_cfl(dx, A_ex)\n",
    "Nt = 100\n",
    "T = dt*Nt\n",
    "\n",
    "# Initial condition\n",
    "x =  np.linspace(0, L, Nx)\n",
    "f0 = 5.*np.sin(2.* np.pi * x)*x*(x-L)\n",
    "fs = burger_equation(A_ex, f0, dx, dt, Nt) #*np.random.normal(0.,0.001,(Nt,Nx)) # (Nt, Nx)\n",
    "\n",
    "dx = np.array([dx])\n",
    "x = np.array([x])\n",
    "f0 = np.array([f0])\n",
    "fs = np.array([fs])\n",
    "\n",
    "fs0 = fs.copy()\n",
    "\n",
    "print(x.shape)\n",
    "print(f0.shape)\n",
    "print(fs.shape)\n",
    "\n",
    "\n",
    "fn = fs + eps/100.*np.std(fs)*np.random.normal(0.,1, fs.shape)\n",
    "\n",
    "plt.plot(fs[0,0,:])\n",
    "plt.plot(fn[0,-1,:])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e0a17324-4be4-484d-897a-3b3e92af70dc",
   "metadata": {},
   "source": [
    "#### Denoise data set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 122,
   "id": "60cc6fc9-262e-498a-9a87-60e424e32612",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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XWbcddddxmuvvWa89957xu9+9zvjwIED4XseeeQRw+v1Glu2bDHeeOMN48YbbzRmz55tnDhxwsaWp56HH37YmDZtmvHcc88ZnZ2dxtNPP21MnjzZ+Pd///fwPfR17H7zm98Y3/ve94xf//rXhiRj8+bNoz6PpG8XLFhglJeXG6+++qrx3//938YnP/lJ47bbbou7bYSXCFRXVxuNjY3h94FAwCguLjZWrVplY6ucp7e315Bk/P73vzcMwzCOHj1qTJgwwXj66afD97z11luGJKOlpcWuZqa0Y8eOGVdccYXx4osvGl/84hfD4YW+Ns8DDzxgXH/99ef9PBgMGoWFhcbq1avD144ePWp4PB7jySeftKKJjvGVr3zFuPvuu0ddu/nmm43bb7/dMAz62kznhpdI+rajo8OQZOzatSt8z29/+1vD5XIZBw8ejKs9TBtdxPDwsNra2lRXVxe+5na7VVdXp5aWFhtb5jx9fX2SpLy8PElSW1ubTp06Narvr7zySs2cOZO+j1FjY6O+8pWvjOpTib4203/9139pzpw5uvXWWzV9+nRdffXV2rBhQ/jzzs5O9fT0jOprr9ermpoa+jpKn//859Xc3Kz9+/dLkt544w3t3LlTCxculERfJ1IkfdvS0qKpU6dqzpw54Xvq6urkdrv12muvxfV8x50qbbbDhw8rEAiooKBg1PWCggK9/fbbNrXKeYLBoO6//35dd911KisrkyT19PQoKytLU6dOHXVvQUGBenp6bGhlanvqqae0Z88e7dq1a8xn9LV53nvvPT322GNqamrSP/3TP2nXrl36h3/4B2VlZamhoSHcn+P9bwp9HZ1ly5apv79fV155pTIyMhQIBPTwww/r9ttvlyT6OoEi6duenh5Nnz591OeZmZnKy8uLu/8JL0gKjY2N2rt3r3bu3Gl3Uxypq6tL9913n1588UVlZ2fb3RxHCwaDmjNnjv7lX/5FknT11Vdr7969Wr9+vRoaGmxunbP853/+p375y1/qV7/6lT772c+qvb1d999/v4qLi+lrh2Pa6CLy8/OVkZExZtWF3+9XYWGhTa1ylnvuuUfPPfecXn75Zc2YMSN8vbCwUMPDwzp69Oio++n76LW1tam3t1fXXHONMjMzlZmZqd///vdau3atMjMzVVBQQF+bpKioSKWlpaOufeYzn9EHH3wgSeH+5H9T4vfd735Xy5Yt09/93d/pqquu0p133qlvfetbWrVqlST6OpEi6dvCwkL19vaO+vz06dM6cuRI3P1PeLmIrKwsVVZWqrm5OXwtGAyqublZtbW1NrYs9RmGoXvuuUebN2/Wtm3bNHv27FGfV1ZWasKECaP6ft++ffrggw/o+yh9+ctf1ptvvqn29vbwa86cObr99tvD/01fm+O6664bs+R///79uuyyyyRJs2fPVmFh4ai+7u/v12uvvUZfR+n48eNyu0f/jGVkZCgYDEqirxMpkr6tra3V0aNH1dbWFr5n27ZtCgaDqqmpia8BcZX7pomnnnrK8Hg8xsaNG42Ojg7j7//+742pU6caPT09djctpS1dutTwer3G9u3bje7u7vDr+PHj4Xu+8Y1vGDNnzjS2bdtm7N6926itrTVqa2ttbLVznL3ayDDoa7O0trYamZmZxsMPP2y88847xi9/+UsjJyfHeOKJJ8L3PPLII8bUqVONZ555xvjDH/5g/M3f/A3Ld2PQ0NBgXHrppeGl0r/+9a+N/Px84x//8R/D99DXsTt27Jjx+uuvG6+//rohyXj00UeN119/3Xj//fcNw4isbxcsWGBcffXVxmuvvWbs3LnTuOKKK1gqbaUf//jHxsyZM42srCyjurraePXVV+1uUsqTNO7rZz/7WfieEydOGN/85jeNSy65xMjJyTEWLVpkdHd329doBzk3vNDX5nn22WeNsrIyw+PxGFdeeaXxk5/8ZNTnwWDQePDBB42CggLD4/EYX/7yl419+/bZ1NrU1d/fb9x3333GzJkzjezsbOMTn/iE8b3vfc8YGhoK30Nfx+7ll18e93+jGxoaDMOIrG8/+ugj47bbbjMmT55s5ObmGosXLzaOHTsWd9tchnHWVoQAAABJjpoXAACQUggvAAAgpRBeAABASiG8AACAlEJ4AQAAKYXwAgAAUgrhBQAApBTCCwAASCmEFwAAkFIILwAAIKUQXgAAQEr5/7UGX3hA0iJOAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def condition(x): return x < thr\n",
    "\n",
    "ufn,sigmafn,vfn = np.linalg.svd(fn[0,:,:].T, full_matrices=False); vfn = vfn.T\n",
    "\n",
    "plt.figure()\n",
    "plt.semilogy(sigmafn, marker=\"o\")\n",
    "\n",
    "thr = 1e-3\n",
    "\n",
    "dim_f = [idx for idx, element in enumerate(abs(np.diff(sigmafn))) if condition(element)][0]\n",
    "\n",
    "fd = ufn[:,0:dim_f].dot(np.diag(sigmafn[0:dim_f]).dot(vfn[:,0:dim_f].T))\n",
    "fd = (fd.T)[None,:]\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b4f8f539-1978-43f1-b5c8-40b6498a282e",
   "metadata": {},
   "source": [
    "#### Find PDE using Adjoint method"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 123,
   "id": "68cf95e2-5bf9-4f54-a617-c60c7d812106",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAQ8AAAD1CAYAAABOUXD1AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAAAwcUlEQVR4nO3de1hUdf4H8PfMACOgMKLggKBgEKJ5QS1C11uSgm2JmBVRq+aT2nrX3X30V2rW9rC/1i3L9adP/trMWxqp5VK23lMLUcG8gfzUUBEYUEcYFBwu8/n9Mc3EyMwwc+YOn9fznEfnnO8558th/Pg936uIiAiMMWYlsaszwBjzTBw8GGOCcPBgjAnCwYMxJggHD8aYIBw8GGOCcPBgjAnCwYMxJoiXqzPg7jQaDcrKytCpUyeIRCJXZ4cxuyEi1NTUICwsDGKx9eUIDh6tKCsrQ0REhKuzwZjDlJSUIDw83OrzOHi0olOnTgC0DzggIMDFuWHMflQqFSIiIvTfcWtx8GiF7lUlICCAgwdrk4S+jnPwsEFTE3DsGFBeDoSGAsOHAxKJq3PFmHN4XGvL2rVrERkZiQ4dOiAhIQEnT540mz4rKwu9e/dGhw4d0K9fP3z33Xd2yceuXUBkJDB6NPDyy9o/IyO1+xlrDzwqeOzYsQOLFi3CihUrkJ+fjwEDBmDcuHGorKw0mv6nn35Ceno6pk+fjjNnziA1NRWpqam4cOGCTfnYtQt4/nng5k3D/aWl2v0cQFh7IPKk+TwSEhLw+OOP45///CcAbTNqREQE5s6diyVLlrRI/+KLL+L+/fvIzs7W73vyyScxcOBArF+/3qJ7qlQqBAYGorq6GgEBAWhq0pYwHg4cOiIREB4OFBe3nVeYpqYmNDQ0uDobzEre3t6QmPkSPvzdtpbH1HnU19cjLy8PS5cu1e8Ti8VISkpCTk6O0XNycnKwaNEig33jxo3D119/bfI+arUaarVa/1mlUhkcP3bMdOAAACKgpESbbtQo0+k8ARFBoVCgqqrK1VlhAslkMsjlcof0UfKY4HH79m00NTWhW7duBvu7deuGS5cuGT1HoVAYTa9QKEzeJzMzEytXrjR5vLzcsvxams6d6QJHSEgI/Pz8uJOcByEi1NbW6l/pQ0ND7X4PjwkezrJ06VKD0oquLVzH0t+BA35XTtXU1KQPHF26dHF1dpgAvr6+AIDKykqEhISYfYURwmOCR9euXSGRSFBRUWGwv6KiAnK53Og5crncqvQAIJVKIZVKTR4fPlxbp1Faqn1FeZiuzmP4cDM/jAfQ1XH4+fm5OCfMFrrfX0NDg92Dh8e0tvj4+GDw4ME4ePCgfp9Go8HBgweRmJho9JzExESD9ACwf/9+k+ktIZEAH32k/fvDpXjd59Wr205lKb+qeDaH/v7Ig2zfvp2kUilt3LiRCgoKaMaMGSSTyUihUBAR0auvvkpLlizRp//xxx/Jy8uLVq1aRYWFhbRixQry9vam8+fPW3zP6upqAkDV1dUG+3fuJAoPJ9KWP7RbRIR2f1tQV1dHBQUFVFdX5+qsMBuY+z2a+m5byqOCBxHRmjVrqEePHuTj40NPPPEEnThxQn9s5MiRNGXKFIP0X375JT366KPk4+NDffv2pW+//daq+5l7wI2NRKmp2sDx6qvaz22FPYNHYyPR4cNE27Zp/2xLz8ndOTJ4eEydh86cOXMwZ84co8eOHDnSYt/kyZMxefJkh+RFIgFiY7V/79q17byq2NOuXcD8+YbN2+Hh2le/tDTX5YvZzmPqPNyVv7/2z/v3XZsPd+TqnrgnT57EqFGj4Ovri969e+P06dP45JNP8Nxzzzn2xu2Ex5U83E3Hjto/791zbT6cgQiorbUsbVMTMG+e8RYpIm3l8vz5QFKSZSU2P7+WFdTmnDhxAqNHj8Y777yDDRs24C9/+QveeecdXLx4EV999ZXlF2ImccnDRu2p5FFbqw2WlmyBgdoShilE2hJJYKBl17M0aOksWrQIkydPxp///GfExMQgPT0d3377LQYMGID4+Hij5yQlJeHy5cvW3QjAxIkT0blzZzz//PNWnytESUkJRo0ahT59+qB///7Iyspyyn0fxsHDRu2p5OEpbt68iZycHMyaNUu/z8vLC0Rktvfw5cuX8cgjj1h9v/nz52PTpk2C8iqEl5cXVq9ejYKCAuzbtw8LFizAfRf878WvLTZqTyUPPz/Lg+TRo8D48a2n++47YMQIy+5tqcLCQgDAoEGD9PuKiorwxBNPoF+/fvp9Fy9exGuvvYa6ujq8+OKLkMvlgubyHDVqlNHKemMmTpwIqVSKq1evQqlUYseOHRgyZIhV9wsNDdV3N5fL5ejatSuUSiX8dV9GJ+HgYaP2VPIQiX4Llq0ZO9aynrhjx9q/laq6uhoSiUTfQUqpVGLVqlUYMGCAPo1arcaLL76IL774Av369UNqair69+9vcJ2EhASDQZI6//73vwXPa3vu3DnMnDkT27dvx9atW/GPf/wDX3zxheB75uXloampySXz7HLwsFF7KnlYQ9cT9/nntYGieQBxdE/cgQMHoqmpCe+//z4mT56M+fPnIzIyEgUFBbh+/Tp69uyJr7/+GiNHjtSXROLi4hAWFmZwndzcXLvm6969e3jw4AEWL16sv+fmzZsF31OpVOIPf/gDNmzYYNd8WorrPGzUnkoe1kpLA776Cuje3XB/eLh2v6P6eURHR+Odd97BRx99hPj4eISFhWHfvn3o3r07kpOTAQDnz5/HwIED9efk5eUZLXkMHDiwxVZSUiIoX+fPn0ffvn31Y0zy8/MNXqOsuadarUZqaiqWLFmCoUOHCsqPrbjkYSMueZiXlgZMmOD8uV6XLVuGZcuWGezLy8vT/z0oKEg/o9y+fftw4MAB7NixwyC9rSWPMWPGYNOmTej+a/Q8d+4crl+/joaGBqhUKqxZswa7HursYsk9iQhTp07FU089hVdffdWmPNqCg4eNdCWP2lpAowEE1Le1eRKJ+02M9MorryAlJQXx8fF47LHH0LNnT3Tu3FnQtZKSknD27Fncv38f4eHhyMrKwpNPPokrV64gKChIn+7cuXMYP348Bg8eDCLC+++/L6h158cff8SOHTvQv39//cRWmzdvblGKcTQOHjZqXoGo6wfB3F9ISIhBScQWBw4caLGvsLAQkyZN0s+pAWiDx7Zt2/Dhhx/adL/f/e530Gg0Nl3DHvj/SRv5+v5W2qipcW1emPuIi4vDBx98YLCvtLS0Ta0+yMHDRiIRoKukF1iPxtqJX375xdVZsCsOHnYQFaX9s419Nxgzi4OHHfTqpf2TgwdrTzh42IGu5FFc7Np8MOZMHDzsgEserD3i4GEHXOfB2iMOHnYQF6f989o14PZtl2aFMafh4GEHXboAjz2m/fv//A/wxRfAkSPa2bQYa6u4h6mdhIcDFy4AK1YY7uOJfllbxSUPO9i1C/j++5b7nTXRL2Ou4DHBQ6lUIiMjAwEBAZDJZJg+fTrumRkHr1QqMXfuXMTGxsLX1xc9evTAvHnzUF1dbdd8NTVpJ/I1RjeHxYIF/ArD2h6PCR4ZGRm4ePEi9u/fj+zsbBw9ehQzZswwmb6srAxlZWVYtWoVLly4gI0bN+L777/H9OnT7ZqvY8daLi3QHJG22/qxY3a9LbPAyJEjIRKJIBKJ4OXlhdDQUKSlpeHEiROuzlrbYNNyVE5SUFBAAOjUqVP6fXv37iWRSESlpaUWX+fLL78kHx8famhosPic1lbV2rbNcMlJU9u2bRbf0i14+nKTGo2GOnXqRH/729+ovLyciouL6dChQzRp0iTy8vKiffv2uTqLTuHIFeM8ouSRk5MDmUxmMFFsUlISxGKxVRO2VFdXIyAgAF5epuuJ1Wo1VCqVwWbOr/PQtsrSdMw+Ll++jJqaGowYMQJyuRyRkZEYPXo0srKykJiYiDfffNPVWfR4HtHaolAoEBISYrDPy8sLQUFBUCgUFl3j9u3bePfdd82+6gBAZmam2en5HzZ8uPmJfgEgOBhw0UxxDmFumn+JRIIOHTpYlFYsFhvMd2EqrZBZwfPy8iCRSAwmPQa0q8Y//fTTePfdd62+JjPk0pLHkiVL9O+kprZLly7ZfB+VSoVnnnkGffr0wdtvv2027dKlS1FdXa3fWpuvUjfRL2B6RbNbt4BHHmk7rS4dO3Y0uU2aNMkgbUhIiMm0KSkpBmkjIyONphMiPz8fsbGx8DOyZoOPjw+8vb0FXZf9xqUlj8WLF2Pq1Klm0/Tq1QtyuRyVlZUG+xsbG6FUKiGXy82eX1NTg+TkZHTq1Am7d+9u9UsjlUohlUotyr+ObqLfhxd0bk7XbOvIiX/Zb/Lz8zF48GCjx4qKitC7d28n56jtcWnwCA4ORnBwcKvpEhMTUVVVhby8PP0X4tChQ9BoNEhISDB5nkqlwrhx4yCVSrFnzx6D4rS9paUBv/+99hXm1q2Wx3Xrsy5YoJ0Q2NETADuSuSZyyUM/2MNBv7mHF1i6du2aTflqLj8/H88++2yL/ffv38eePXuwaNEiu92r3bK1NtdZkpOTKT4+nnJzc+n48eMUExND6enp+uM3b96k2NhYys3NJSJtTXJCQgL169ePrly5QuXl5fqtsbHR4vtaUyN9+LBlLS+HD1v70zufJ7e2XL16lQDQDz/8YLC/sbGRXnnlFQoPD6eqqioX5c65HNna4hEVpgCwdetWzJkzB2PGjIFYLMakSZPw8ccf6483NDSgqKgItb+uiJyfn69viYmOjja4VnFxMSIjI+2ex/Jy+6ZjwugmNg4NDYVCoYBKpUJeXh4++ugjlJSUIDs7G4GBgS7OpefzmOARFBSEbdu2mTweGRkJatbcMWrUKIPPzsDNtu4hPz8fAPDoo49CIpFAJpMhNjYWzz33HGbNmmWwHAITTkTO/hfmYVQqFQIDA/V9RMxpagIiI1tvtr15E/DxsX9e7enBgwcoLi5GVFSUQ+uKmGOZ+z1a8902xiM6iXmK9thsy9ovDh52Zmp91uZ4tC1rCzh4OEBaGnD1qvYVxRgebcvaAg4eDvLTT8b7e+jwaFvm6Th4OEhbabbl+nTP5sjfHwcPB7G0Obaiwj1fXXTd+HX9Zphn0v3+HDGWR1BT7TvvvIM//elPLQYd1dXV4e9//zuWL19utwy6mtDmLEuabXXcda7T8vJyVFVVISQkBH5+fhCZakJiboeIUFtbi8rKSshkMoQa+d/M1qZaQcFDIpGgvLy8xTD5O3fuICQkBE3u+F+pQLY84F27tK0qgPkAovs36W6D5ogICoUCVVVVrs4KE0gmk0EulxsN/LYGD0E9TInIaGbOnj3LvfeasWS0LeC+g+ZEIhFCQ0MREhKChoYGV2eHWcnb27vFQEV7sip4dO7cWT/PxqOPPmoQQJqamnDv3j3MmjXL7pn0ZGlp2oCwZg2wcKHpdM1bX0aNclr2LCKRSBz6JWSeyargsXr1ahARXnvtNaxcudJgcJGPjw8iIyORmJho90x6OokE6NbNsrSlpY7NC2P2YlXwmDJlCgAgKioKQ4cO5dmYrGBp68vChYCvr3vVfTBmjOCBcRqNBleuXEFlZSU0Go3BsREjRtglc+7A1kolHUtbX9y18pS1PS6pMD1x4gRefvllXL9+vUUnFJFI1KZaW+xFN2hO1/piirtWnjL2MEGdxGbNmoUhQ4bgwoULUCqVuHv3rn5TKpX2zmOboWt96drVfDruus48gaCSx+XLl/HVV1+1mKGLtS4tDairA155pfW0XHnK3JmgkkdCQgKuXLli77y0G+aG6ze3cCEP22fuS1DJY+7cuVi8eDEUCgX69evXotWlf//+dslcW2XJQlEAcPs2L9fA3Jeg1paHp8wHtBWlup6nbanC1F6tLQ/TdV1v7emLRNpAU1zMlafMvlzS2lJcXCzkNNaMrvJ05kxtCcMUd+55yto3QcGjZ8+e9s5Hu2RN5enBg9rXHS59MHcheD6PzZs3Y9iwYQgLC8P169cBaLuvf/PNN3bLXHNKpRIZGRkICAiATCbD9OnTza5c1hwRISUlBSKRCF9//bVD8ieUpZWnf/2rtpMZV6AydyEoeKxbtw6LFi3C+PHjUVVVpa/jkMlkWL16tT3zp5eRkYGLFy9i//79yM7OxtGjR1td8V5n9erVbjsXha7y1JLs8cTJzK0IWWYuLi6Odu/eTUREHTt2pKtXrxIR0fnz56lLly5CLmlWQUEBAaBTp07p9+3du5dEIhGVlpaaPffMmTPUvXt3Ki8vJwD6fFvK1iX5LLFzJ5FIpN1aW6pSJCKKiCCyYsVMxoyy9bstqORRXFyM+Pj4FvulUinu379vUzAzJicnBzKZDEOGDNHvS0pKglgs1i8paUxtbS1efvllrF27FnK53KJ7qdVqqFQqg83RLFmuQYd7nzJ3ISh4REVF4eeff26x//vvv0dcXJyteWpBoVC0mLXMy8sLQUFBUCgUJs9buHAhhg4digkTJlh8r8zMTAQGBuq3iIgIwfm2RloacO0a8NZblqXn3qfM1QQFj0WLFmH27NnYsWMHiAgnT57Ee++9h6VLl+Ivf/mLxddZsmSJfnIhU9ulS5eEZBF79uzBoUOHrK6DWbp0Kaqrq/VbSUmJoPsLIZEAY8ZYlpZ7nzKXE/q+tGXLFoqOjiaRSEQikYi6d+9O//u//2vVNSorK6mwsNDsplar6dNPPyWZTGZwbkNDA0kkEtq1a5fRa8+fP59EIhFJJBL9BoDEYjGNHDnS4jw6o86jucZGovDw1us/dHUkO3c6JVusDbL1u23zQte1tbW4d+9ei9cKeyosLESfPn1w+vRpDB48GACwb98+JCcn4+bNmwgLC2txjkKhwO2Hel/169cPH330EZ599llERUVZdG9H9TA1h3ufMmew+btt11DmQMnJyRQfH0+5ubl0/PhxiomJofT0dP3xmzdvUmxsLOXm5pq8Bty0tcWYnTuJunZtvfUFIDp82KlZY22Erd9ti3uYDho0CAcPHkTnzp0RHx9vtt9Efn6+9VGsFVu3bsWcOXMwZswYiMViTJo0CR9//LH+eENDA4qKitrMIkU8dJ+5O4uDx4QJEyCVSgEAqampjsqPSUFBQdi2bZvJ45GRka0urdfacXdjzdB9nveUOZvNdR5tnSvqPHR43lPmSLZ+twU11Z46dcpo56zc3FycPn1ayCWZEbp5T1ujCywLFrjnuresbRIUPGbPnm20/0NpaSlmz55tc6bYb6yd93TNGg4gzDkEBY+CggIMGjSoxf74+HgUFBTYnClmKC0NsLSv28KFPPqWOYeg4CGVSlFRUdFif3l5Oby8BE0RwlphaeUpwKNvmXMICh5jx47Vd+PWqaqqwn/913/h6aeftlvm2G+sGbrPdSDMGQQFj1WrVqGkpAQ9e/bE6NGjMXr0aERFRUGhUOAf//iHvfPIYFh5amkAKSkBjhxxaLZYOya4qfb+/fvYunUrzp49C19fX/Tv3x/p6eltbv1aVzbVGrNrFzB/PnDzpmXpg4KADRu4CZe1ZOt3m/t5tMLdggegfRVZs0ZbOWoJkYj7gLCWnBY89uzZg5SUFHh7e2PPnj1m0z733HNWZ8RduWPwACzvQAbwADpmnNOCh1gs1k/KY2zdFv0Fed0Wp7F09K3OgQOWzxfC2j6n9TDVaDT6Yfcajcbk1pYCh7vTdSALCrIs/QsvcPMtsx+Lg0dQUJB+fozXXnsNNTU1DssUs1xaGvDll5alVSq5/wezH4uDR319vX4y4M8//xwPHjxwWKaYdUaNsrwPCMD9P5h9WNwdNDExEampqRg8eDCICPPmzYOvr6/RtP/617/slkHWOl0fkOefbz1t8zEwc+dyBSoTzuKSx5YtWzB+/Hj9Km3V1dW4e/eu0Y05n7X1HzwGhtlKUD+PqKgonD59Gl26dHFEntyKO7e2GHPwIJCUZFlangekfXNaa0vzCtPRo0fDx8fH6psxx7Om/kM3C+qsWUB9vcOzxtoYrjBtY6wdAwMAt25pAw6/wjBrcIVpG6Sr/7BmDMytW9oKV36FYZYSVGEqEom4wtTN6Zav/PBD687jZlxmKa4wbYWnVZg+zJoxMDrcjb19cMkEyMXFxfrA4ay6D6VSiYyMDAQEBEAmk2H69On6ZmNzcnJy8NRTT8Hf3x8BAQEYMWIE6urqnJBj92DpJMrNcTd2ZglBwUOj0eDdd99F9+7d0bFjR/zyyy8AgGXLluHTTz+1awZ1MjIycPHiRezfvx/Z2dk4evQoZsyYYfacnJwcJCcnY+zYsTh58iROnTqFOXPmmB3Y1xZZOomyDndjZxYRsszcypUrqVevXrRlyxby9fWlq1evEhHR9u3b6cknnxS0dJ05BQUFBIBOnTql37d3714SiURUWlpq8ryEhAR66623bLq3q5abdAS1mig42LIlLAGioCCiAwe0i2+ztsfW77ag/4I3bdqETz75BBkZGZA06988YMAAXLp0yT5RrZmcnBzIZDIMGTJEvy8pKQlisdjo+jEAUFlZidzcXISEhGDo0KHo1q0bRo4ciePHj9s9f57CxwdYv97yJlylUtvhjHuiMmMEBY/S0lJER0e32K/RaNDQ0GBzph6mm0ekOS8vLwQFBUGhUBg9R/cq9fbbb+P111/H999/j0GDBmHMmDG4fPmyyXup1WqoVCqDrS2xths7wLOxM+MEBY8+ffrg2LFjLfZ/9dVXiI+Pt/g6S5YsgUgkMrsJLcloNBoAwMyZMzFt2jTEx8fjww8/RGxsrNl+KJmZmQgMDNRvERERgu7vzqwZxg9wT1RmnKBFVpYvX44pU6agtLQUGo0Gu3btQlFRETZt2oTs7GyLr7N48WJMnTrVbJpevXpBLpejsrLSYH9jYyOUSiXkcrnR80JDQwFoA11zcXFxuHHjhsn7LV26FIsWLdJ/VqlUbTKA6LqxW9OEq+uJun49dyRjEFZhSkR09OhRSkpKouDgYPL19aVhw4bRf/7zH6GXM0tXYXr69Gn9vv/85z9mK0w1Gg2FhYW1qDAdOHAgLV261OJ7t6UK04ft3EkkEmk3SytRAW36nTtdnXtmK1u/24KDh7MlJydTfHw85ebm0vHjxykmJobS09P1x2/evEmxsbGUm5ur3/fhhx9SQEAAZWVl0eXLl+mtt96iDh060JUrVyy+b1sOHkTaIBAebl3wALStNmq1q3PPbOHS4HH69GnavHkzbd68mfLz8225VKvu3LlD6enp1LFjRwoICKBp06ZRTU2N/nhxcTEBoMOHDxucl5mZSeHh4eTn50eJiYl07Ngxq+7b1oMHkbYp9sABbdOstQGESyCey9bvtqDu6ZWVlXjppZdw5MgRyGQyANrlJkePHo3t27cjODjYXm9VLufp3dOtYe1s7ACvCePJXNI9fe7cuaipqcHFixehVCqhVCpx4cIFqFQqzJs3T8glmRuwticqoA00r7+unYSIB9S1L4JKHoGBgThw4AAef/xxg/0nT57E2LFjUVVVZa/8uVx7Knno1NdrW1Vu3bLuvPBw7TgaLoV4BpeUPDQajdE1ab29vfX9K5jnsrYnqg53JmtfBAWPp556CvPnz0dZWZl+X2lpKRYuXIgxPJa7TRD6CsOdydoPQcHjn//8J1QqFSIjI/HII4/gkUceQVRUFFQqFdasWWPvPDIXSUvTliasrf/maQ3bB0F1HgBARDhw4IC++3hcXBySLJ2224O0xzqPh+laYQDrWmIAYOVK4M03eX0Yd2Tzd9uadt2DBw9SXFyc0Xbhqqoq6tOnDx09elRQm7G7ag/9PCwhtDMZoD2P+4O4H6cOyV+9ejVef/11o1EqMDAQM2fOxAcffGB9BGNuTzcn6oED1o3IBbSTMHNFattjVfA4e/YskpOTTR4fO3Ys8vLybM4Uc08SiXZu0w0brG+J4f4gbY9VwaOiosJoE62Ol5cXblnbOYB5HCEtMQBPLtTWWBU8unfvjgsXLpg8fu7cOf1QeNa2CW2JAbSvMZMmAe+8w6UQT2ZV8Bg/fjyWLVtmdMb0uro6rFixAr///e/tljnm3oR2JtNZsYJLIZ7MqqbaiooKDBo0CBKJBHPmzEFsbCwA4NKlS1i7di2ampqQn5+Pbt26OSzDzsZNta3btQuYN09bEhFqwQJgwgRg+HBu1nUWpzbVEhFdu3aNUlJSSCwWk0gkIpFIRGKxmFJSUuiXX34R1OTjzrip1jKNjUQrVwpryuVmXddwyZB8ALh79y6uXLkCIkJMTAw6d+4s5DJuj0se1tm1y7o1ck3hzmWOZ+t3W3DwaC84eFivqQk4ckS78pxSKfw6PErXsVwyqpYxc2zpD9Icdy5zbxw8mMPo+oN0727bdRYs4CZdd8TBgzlUWhpw/bq2DkMIIqCkBDCyTBBzMQ4ezOEkEmD5cmDnTm09hhDl5fbNE7MdBw/mNLrBdYcPa19FrMEdl90PBw/mVBKJdrW6Dz/UlkRaqw8RiYCICG3nMeZePCZ4KJVKZGRkICAgADKZDNOnT8e9e/fMnqNQKPDqq69CLpfD398fgwYNws6dO52UY9aa1upDdC01q1dzfw935DHBIyMjAxcvXsT+/fuRnZ2No0ePYsaMGWbP+cMf/oCioiLs2bMH58+fR1paGl544QWcOXPGSblmrTFXHxIezmvCuDX7dXZ1HN1atadOndLv27t3r9m1aomI/P39adOmTQb7goKCaMOGDRbfm7unO09jI9GWLdpu6t7eRHV1rs5R2+bUmcRcJScnBzKZDEOGDNHvS0pKglgsRm5ursnzhg4dih07dkCpVEKj0WD79u148OABRo0a5YRcM2tJJMDLLwOBgUBDA/Dr9LjMTXlE8FAoFAgJCTHY5+XlhaCgICgUCpPnffnll2hoaECXLl0glUoxc+ZM7N69G9HR0SbPUavVUKlUBhtzHpEIGDRI+/fTp12bF2aeS4PHkiVLIBKJzG6XbPjvZ9myZaiqqsKBAwdw+vRpLFq0CC+88ALOnz9v8pzMzEwEBgbqt4iICMH3Z8LoCphmCpXMDbh0YNytW7dw584ds2l69eqFLVu2YPHixbh7965+f2NjIzp06ICsrCxMnDixxXlXr15FdHQ0Lly4gL59++r3JyUlITo6GuvXrzd6P7VaDbVarf+sUqkQERHBA+OcKDsbePZZ4JFHgCtXXJ2btsvWgXFeDsiTxYKDgxFswTx2iYmJqKqqQl5eHgYPHgwAOHToEDQaDRISEoyeU1tbCwAQiw0LVxKJxOySmFKpFFKp1NIfgTnAiBGAWAxcvQqsWQP068eTBLklu1bfOlBycjLFx8dTbm4uHT9+nGJiYig9PV1//ObNmxQbG0u5ublERFRfX0/R0dE0fPhwys3NpStXrtCqVatIJBLRt99+a/F9ubXF+XbuJPLx4UmCHM3W77bHBI87d+5Qeno6dezYkQICAmjatGlUU1OjP15cXEwA6PDhw/p9//d//0dpaWkUEhJCfn5+1L9//xZNt63h4OFcO3cSiUQtZxgTibQbBxD7cdlMYu0FTwbkPE1N2gmRTc1CJhJpO44VF/MrjD3wZECszTh2zPz0hTw8371w8GBuw9Jh9zw83z1w8GBuw9Jh9zw83z1w8GBuY/hwbZ2GqXlPeXi+e+HgwdyGRKKdLR0wHUB4eL774ODB3IqpSZO9vYG33wbUau2yDjwhsutxU20ruKnWNZqatK0qFy4Ac+e2PM5rutiOm2pZm6SbrjAszPjx0lJe08XVOHgwt9XUpF260hhdeZnXdHEdDh7MbXGnMffGwYO5Le405t44eDC3ZWlnsIcmmWNOwsGDua3WOo3pTJ3KFaeuwMGDuS1LOo0B3PLiKhw8mFvTdRoz1WQL/Dbrx6xZQH298/LW3nHwYG4vLQ34/PPW0926pX3N4RKIc3DwYB6hstKydLdu8SuMs3DwYB7BmmH4RMDrrwMHD3IHMkfi4ME8gqUtLzpKJZCUBMjlwMKFPJjOETh4MI/QvOXFGrdva4fxjx7NgcTeeFRtK3hUrXvZtQuYOVMbFGzRvTswYwYQE6N9JWqP68LY+t3m4NEKDh7up75e+wpz65b9rtm1K/DKK8Dvf6/9XFmpDSpDhwI//aTtAq/ryVpZafh3d0xnSUDk4OFgHDzc065d2lYV4LcRto4gkVj2iuOO6Vqb86TdzOfx3nvvYejQofDz84NMJrPoHCLC8uXLERoaCl9fXyQlJeHy5cuOzShzClMzjtmbpXUj7pjO0T1vPSZ41NfXY/LkyXjjjTcsPuf999/Hxx9/jPXr1yM3Nxf+/v4YN24cHjx44MCcMmdJSwOuXQMOHACCglydG/fj6DlPPO61ZePGjViwYAGqqqrMpiMihIWFYfHixfjTn/4EAKiurka3bt2wceNGvPTSSxbdT1e0KysrM1q0k0gk6NChg/7z/fv3TV5LLBbD19dXUNra2lqY+lWJRCL4+fkJSltXV2d24W9/f39BaR88eIAmM99Ya9L6+flB9GsbrVqtRmNjY4s033wDZGQAgB8AXXuuGkDLtL/xxW//f9YDaLBT2g4AJALSNvya3hQpflub3pq0jfjuOzVGjDBMoVKpEBYWJvyV3MblLp3us88+o8DAwFbTXb16lQDQmTNnDPaPGDGC5s2bZ/K8Bw8eUHV1tX4rKSkhACa38ePHG5zv5+dnMu3IkSMN0nbt2tVk2iFDhhik7dmzp8m0ffr0MUjbp08fk2l79uxpkHbIkCEm03bt2tUg7ciRI02m9fPzM0g7fvx4s8+tueeff95s2nv37unTTpkyxWza0NDKZmvc/tFsWqC4Wdo/tZL2QrO0K1pJe7JZ2vdbSXu4Wdp/tpI2u1naz1pJ+2WztF+aTSt0rVqPeW2xlkKhAAB069bNYH+3bt30x4zJzMxEYGCgfouIiHBoPpl95ecDhw9ri+rNCoTMAVz62rJkyRL893//t9k0hYWF6N27t/6zpa8tP/30E4YNG4aysjKENuvb/MILL0AkEmHHjh1Gz1Or1VCr1frPKpUKERER/NpiZVpnv7YYS1tbq8YPPzTi22+BHTuM9Q1p+68tIhHQvXsjLl5Ut2i2tfW1xav1JI6zePFiTJ061WyaXr16Cbq2XC4HAFRUVBgEj4qKCgwcONDkeVKpFFKptMV+f39/gy+8KZakEZK2+T94e6ZtHqDsmbaDFf/tW5PW1O/HGD8/KVJSpEhJ0TZZHjum7Q9x+TKwYcPD86P6/LpZwlFpvX/d7JNW15X/o4+8EBDQ8p+6uYBtCZcGj+DgYAQHBzvk2lFRUZDL5Th48KA+WKhUKuTm5lrVYsPaBt1SDjpvvqkNJt98A2zdarrDmTv237A0XXi4tmu+o9a2cWnwsMaNGzegVCpx48YNNDU14eeffwYAREdHo2PHjgCA3r17IzMzExMnToRIJMKCBQvw17/+FTExMYiKisKyZcsQFhaG1NRU1/0gzC3ogsmoUcCqVb+VSty956g9e5jaTFA1qwuYqmU/fPiwPg0A+uyzz/SfNRoNLVu2jLp160ZSqZTGjBlDRUVFVt23urraphppxtyVrd9tj+vn4WzcPZ21VbZ+tz3mtcVVdLFVpVK5OCeM2ZfuOy20/MDBoxU1NTUAwP09WJtVU1ODwMBAq8/j15ZWaDQalJWVoVOnTvr+A83p+oGUlJTwa40d8PO0n9aeJRGhpqYGYWFhEIut7y/KJY9WiMVihIeHt5ouICCAv+x2xM/Tfsw9SyElDp022z2dMeZYHDwYY4Jw8LCRVCrFihUrLO4yzczj52k/jn6WXGHKGBOESx6MMUE4eDDGBOHgwRgThIMHY0wQDh42Wrt2LSIjI9GhQwckJCTg5MmTrs6S2zl69CieffZZhIWFQSQS4euvvzY4ThYskaFUKpGRkYGAgADIZDJMnz4d9+7dc+JP4R4yMzPx+OOPo1OnTggJCUFqaiqKiooM0jx48ACzZ89Gly5d0LFjR0yaNAkVFRUGaW7cuIFnnnkGfn5+CAkJwZ///GezM7QZw8HDBjt27MCiRYuwYsUK5OfnY8CAARg3bhwqKytdnTW3cv/+fQwYMABr1641etySJTIyMjJw8eJF7N+/H9nZ2Th69ChmzJjhrB/Bbfzwww+YPXs2Tpw4gf3796OhoQFjx441mNJy4cKF+Pe//42srCz88MMPKCsrQ1qzGYGamprwzDPPoL6+Hj/99BM+//xzbNy4EcuXL7cuM3aZGKCdeuKJJ2j27Nn6z01NTRQWFkaZmZkuzJV7A0C7d+/Wf9ZoNCSXy+nvf/+7fl9VVRVJpVL64osviIiooKCAANCpU6f0afbu3UsikYhKS0udlnd3VFlZSQDohx9+ICLts/P29qasrCx9msLCQgJAOTk5RET03XffkVgsJoVCoU+zbt06CggIILVabfG9ueQhUH19PfLy8pCUlKTfJxaLkZSUhJycHBfmzLMUFxdDoVAYPMfAwEAkJCTon2NOTg5kMhmGDBmiT5OUlASxWIzc3Fyn59mdVFdXAwCCfl31Ki8vDw0NDQbPs3fv3ujRo4fB8+zXr5/BygLjxo2DSqXCxYsXLb43Bw+Bbt++jaamJquXdmCGLFkiQ6FQIEQ3x96vvLy8EBQU1K6ftUajwYIFCzBs2DA89thjALTPysfHp8WSrA8/T2PPW3fMUjyqljEPNXv2bFy4cAHHjx93yf255CFQ165dIZFIWtRiV1RU6Jd9YK1rvkRGc82fo1wub1EJ3djYCKVS2W6f9Zw5c5CdnY3Dhw8bTBkhl8tRX1/fYl2jh5+nseetO2YpDh4C+fj4YPDgwTh48KB+n0ajwcGDB5GYmOjCnHmW5ktk6OiWyNA9x8TERFRVVSEvL0+f5tChQ9BoNEhISHB6nl2JiDBnzhzs3r0bhw4dQlRUlMHxwYMHw9vb2+B5FhUV4caNGwbP8/z58wYBef/+/QgICECfPn2sygwTaPv27SSVSmnjxo1UUFBAM2bMIJlMZlCLzYhqamrozJkzdObMGQJAH3zwAZ05c4auX79ORER/+9vfSCaT0TfffEPnzp2jCRMmUFRUFNXV1emvkZycTPHx8ZSbm0vHjx+nmJgYSk9Pd9WP5DJvvPEGBQYG0pEjR6i8vFy/1dbW6tPMmjWLevToQYcOHaLTp09TYmIiJSYm6o83NjbSY489RmPHjqWff/6Zvv/+ewoODqalS5dalRcOHjZas2YN9ejRg3x8fOiJJ56gEydOuDpLbufw4cNGl82YMmUKEVm2RMadO3coPT2dOnbsSAEBATRt2jSqqalxwU/jWsaeIx5acqSuro7++Mc/UufOncnPz48mTpxI5eXlBte5du0apaSkkK+vL3Xt2pUWL15MDQ0NVuWFh+QzxgThOg/GmCAcPBhjgnDwYIwJwsGDMSYIBw/GmCAcPBhjgnDwYIwJwsGDeSRjM5Ix5+Lgwaw2depUiESiFltycrKrs8aciIfkM0GSk5Px2WefGezjVd7aFy55MEGkUinkcrnB1rlzZwDaV4p169YhJSUFvr6+6NWrF7766iuD88+fP4+nnnoKvr6+6NKlC2bMmNFiQuN//etf6Nu3L6RSKUJDQzFnzhyD47dv38bEiRPh5+eHmJgY7NmzR3/s7t27yMjIQHBwMHx9fRETE9Mi2DHbcPBgDrFs2TJMmjQJZ8+eRUZGBl566SUUFhYC0E6IPG7cOHTu3BmnTp1CVlYWDhw4YBAc1q1bh9mzZ2PGjBk4f/489uzZg+joaIN7rFy5Ei+88ALOnTuH8ePHIyMjA0qlUn//goIC7N27F4WFhVi3bh26du3qvAfQHtg+zo+1N1OmTCGJREL+/v4G23vvvUdE2pGfs2bNMjgnISGB3njjDSIi+uSTT6hz58507949/fFvv/3WYFLesLAwevPNN03mAQC99dZb+s/37t0jALR3714iInr22Wdp2rRp9vmBmVFc58EEGT16NNatW2ewTzcJL4AWEyIlJibi559/BgAUFhZiwIAB8Pf31x8fNmwYNBoNioqKIBKJUFZWhjFjxpjNQ//+/fV/9/f3R0BAgH6CmzfeeAOTJk1Cfn4+xo4di9TUVAwdOlTQz8qM4+DBBPH392/xGmEvvr6+FqXz9vY2+CwSiaDRaAAAKSkpuH79Or777jvs378fY8aMwezZs7Fq1Sq757e94joP5hAnTpxo8TkuLg4AEBcXh7NnzxosVPTjjz9CLBYjNjYWnTp1QmRkpMFUekIEBwdjypQp2LJlC1avXo1PPvnEpusxQ1zyYIKo1eoW0/R7eXnpKyWzsrIwZMgQ/O53v8PWrVtx8uRJfPrppwC0q7+tWLECU6ZMwdtvv41bt25h7ty5ePXVV/VLALz99tuYNWsWQkJCkJKSgpqaGvz444+YO3euRflbvnw5Bg8ejL59+0KtViM7O1sfvJiduLrShXmeKVOmGJ0KLzY2loi0lZlr166lp59+mqRSKUVGRtKOHTsMrnHu3DkaPXo0dejQgYKCguj1119vMa3g+vXrKTY2lry9vSk0NJTmzp2rP4aHVp4jIgoMDNRPx/fuu+9SXFwc+fr6UlBQEE2YMIF++eUX+z+MdoynIWR2JxKJsHv3bqSmpro6K8yBuM6DMSYIBw/GmCBcYcrsjt+E2wcueTDGBOHgwRgThIMHY0wQDh6MMUE4eDDGBOHgwRgThIMHY0wQDh6MMUE4eDDGBPl/akPc0LIBETkAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Execution time: 21.100581884384155\n",
      "total number of terms: 18\n",
      "0.0023730128364090053\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "ds = np.array([[1], [2], [3]])\n",
    "ps = np.array([[1], [2], [3]])\n",
    "\n",
    "start_time = time.time()\n",
    "estimated_params, eps = AdjointFindPDE(fd, dx, data_dt=dt, avg=True, gamma=1e-3, epochs=200, epthr=100, beta = 0.005, ds=ds, ps=ps, V = L, tol = 1e-10, eps0=1e-16)\n",
    "end_time = time.time()\n",
    "\n",
    "i_pde = 0\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if ( d[0]==1 and p[0]==2 ):\n",
    "            plt.plot(estimated_params[:,i_pde,id,ip], label=r\"$α_{d=\"+str(d[0])+\", p=\"+str(p[0])+\"}$\", color=\"blue\", marker=\"o\", markevery=4)\n",
    "            err_D = estimated_params[-1,i_pde,id,ip]\n",
    "err_D = abs(err_D - D_ex)\n",
    "plt.axhline(D_ex, linestyle = \"--\", color=\"black\", label=r\"$D$\")\n",
    "plt.legend()\n",
    "plt.ylabel(r'Coefficient')\n",
    "plt.xlabel('Epochs')\n",
    "name = problem + \"_\" + \"Aconv\"\n",
    "#plt.savefig(name+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "plt.show()\n",
    "\n",
    "end_time = time.time()\n",
    "print(\"Execution time: \"+str(end_time-start_time))\n",
    "\n",
    "i_pde = 0\n",
    "err_other = np.zeros_like(estimated_params[:,0,0,0])\n",
    "count = 0\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if not ( d[0]==1 and p[0]==2 ):\n",
    "            err_other += abs(estimated_params[:,i_pde,id,ip])\n",
    "            count += 1\n",
    "\n",
    "## coeff of u\n",
    "i_pde = 0\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        if d[0]==1 and p[0]==2:\n",
    "            plt.plot(eps[1:], abs(estimated_params[1:,i_pde,id,ip]-D_ex),#/abs(D_ex),\n",
    "                     label=r\"$e(D)$\", marker=\"o\", markevery=4, color=\"black\")\n",
    "plt.plot(eps[1:], err_other[1:]/count, marker=\"s\", markevery=4, color=\"blue\", label=r\"$||e(\\mathbf{\\alpha}^*)||_1$\")\n",
    "plt.yscale('log')\n",
    "plt.ylabel(r'Error')\n",
    "plt.xlabel('Epochs')\n",
    "plt.legend()\n",
    "#name = problem + \"_\" + \"D\"\n",
    "#plt.savefig(name+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "\n",
    "print(\"total number of terms: \"+str(numPDE*len(ds)*len(ps)))\n",
    "print((err_other[-1])+err_D)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "951c86f3-ade3-4ce8-b68c-7dbe32950cba",
   "metadata": {},
   "source": [
    "#### Discover PDE using PDE-FIND"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 124,
   "id": "bb5eec5f-a44e-41ab-82e6-b560d07c8178",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['1', 'u_{x}', 'u_{xx}', 'u_{xxx}', 'u', 'u^2', 'u^3', 'uu_{x}', 'u^2u_{x}', 'u^3u_{x}', 'uu_{xx}', 'u^2u_{xx}', 'u^3u_{xx}', 'uu_{xxx}', 'u^2u_{xxx}', 'u^3u_{xxx}']\n",
      "u_t = (2.001296 +0.000000i)uu_{x}\n",
      "   \n",
      "Execution time: 1.0586340427398682\n",
      "[2.00129562]\n",
      "error:  0.0012956242619734937\n"
     ]
    }
   ],
   "source": [
    "import sys; sys.path.append('PDE-FIND/')\n",
    "from PDE_FIND import *\n",
    "import scipy.io as sio\n",
    "import itertools\n",
    "\n",
    "start_time = time.time()\n",
    "\n",
    "#(numPDE, Nt, Nx0, Nx1, ...)\n",
    "nt = Nt-1\n",
    "\n",
    "# Take up to second order derivatives.\n",
    "u = np.zeros((nt, Nx))\n",
    "ut = np.zeros((nt, Nx))\n",
    "ux = np.zeros((nt, Nx))\n",
    "uxx = np.zeros((nt, Nx))\n",
    "uxxx = np.zeros((nt, Nx))\n",
    "\n",
    "for i in range(nt):\n",
    "    u[i,:] = fd[0, i, :]\n",
    "    ut[i,:] = (fd[0, i+1, :]-fd[0, i, :])/dt\n",
    "    ux[i,:] = np.gradient(u[i,:], axis=0) / dx[0]\n",
    "    uxx[i,:] = np.gradient( np.gradient(u[i,:],axis=0), axis=0) / dx[0]**2\n",
    "    uxxx[i,:] = np.gradient( np.gradient( np.gradient(u[i,:],axis=0), axis=0), axis=0) / dx[0]**3\n",
    "\n",
    "u = u.reshape((nt * Nx, 1))\n",
    "ut = ut.reshape((nt * Nx, 1))\n",
    "ux = ux.reshape((nt * Nx, 1))\n",
    "uxx = uxx.reshape((nt * Nx, 1))\n",
    "uxxx = uxxx.reshape((nt * Nx, 1))\n",
    "\n",
    "num_points = nt * Nx\n",
    "\n",
    "X_data = np.hstack([u])\n",
    "X_ders = np.hstack([np.ones((num_points,1)), ux, uxx, uxxx])\n",
    "X_ders_descr = ['','u_{x}', 'u_{xx}', 'u_{xxx}']\n",
    "X, description = build_Theta(X_data, X_ders, X_ders_descr, 3, data_description = ['u'])\n",
    "print(['1'] + description[1:])\n",
    "\n",
    "c = TrainSTRidge(X,ut,10**-6,10)\n",
    "print_pde(c, description)\n",
    "\n",
    "end_time = time.time()\n",
    "print(\"Execution time: \"+str(end_time-start_time))\n",
    "\n",
    "coeff_pdefind = []\n",
    "for i in range(len(c)):\n",
    "        if c[i] != 0:\n",
    "            coeff_pdefind.append( abs(c[i]) )\n",
    "coeff_pdefind = np.array( coeff_pdefind )\n",
    "print(coeff_pdefind[0])\n",
    "D_ex = 2\n",
    "print(\"error: \", np.sum(coeff_pdefind[1:]) + abs(coeff_pdefind[0]-D_ex)[0])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7a3074f9-4908-468d-823f-5f828718d24d",
   "metadata": {},
   "source": [
    "## Ill-posed problem"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "20b1da18-e0e7-44d5-b35e-848d2cc0a947",
   "metadata": {},
   "source": [
    "Consider a wave function $f(x,t)=\\sin(x-t)$. This function is the solution to the following group of PDEs among other\n",
    "\n",
    "$f_t + (k+1) f_x + k f_{xxx} + lf_{xx} + lf_{xxxx} = 0\\ \\ \\ \\ \\forall l,k=0,1,...$.\n",
    "\n",
    "If the considered family of PDEs in the dicovery task includes terms corresponding to more than one solution, the optimization problem is ill-posed.\n",
    "\n",
    "To resolve this issue, we need to add another constraint into our optimization problem to distinguish the target PDE from all possible solutions. Here, we do this by simply finding the PDE that minimizes $||.||_2^2$ of coefficients. Therefore, the unique solution to this problem is\n",
    "\n",
    "$f_t + f_x = 0$."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "63ae3fa2-34d0-4e86-899c-00aa5e77fa62",
   "metadata": {},
   "source": [
    "### Generate Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 125,
   "id": "45e49389-0e24-4bea-ac4c-e32f64a5e889",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAQoAAAD1CAYAAACoeLuxAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAAAzjklEQVR4nO2deVxU9frHP8M2gAqICojhbqmV4hKEmliS2iVLzX3BrLS6WG6VWbe8dVVs0Sz0qi1qqeWSa1aokamYu9LPhDSvpihbbsMmiDPP74/HwxEFZmDOdxb4vl+v85rDcM73+Z6ZM5/zXZ7n+eqIiCCRSCQV4GLvCkgkEsdHCoVEIjGLFAqJRGIWKRQSicQsUigkEolZpFBIJBKzSKGQSCRmkUIhkUjM4mbvCjgDJpMJ6enpqFOnDnQ6nb2rI5FoBhEhNzcXwcHBcHEpv90ghcIC0tPTERISYu9qSCTCSEtLw1133VXu/6VQWECdOnUA8Ifp4+Nj59pIJNqRk5ODkJCQknu8PKRQWIDS3fDx8ZFCIamWmOtSy8FMiURiFqcTil27dqFv374IDg6GTqfDxo0bzZ7zyy+/oGPHjtDr9WjZsiWWLVsmvJ4SSXXC6YQiPz8f7du3x4IFCyw6/syZM4iOjsbDDz+M5ORkTJw4Ec899xy2bt0quKYSSfXB6cYoHnvsMTz22GMWH79o0SI0a9YMc+bMAQC0adMGSUlJ+Oijj9C7d29R1ZRojNFoRHFxsb2r4XS4u7vD1dXV6nKcTigqy969exEVFVXqvd69e2PixInlnlNUVISioqKSv3NyckRVTyjXrwMbNgBbtwL79wNXrvD7LVoA4eHA0KFAp05AlV1DDAbg22+BhATg+HHg77+B2rWBpk2Bnj2BgQOB1q2tugYiQmZmJq5evWpVOTUZPz8/BAUFWeUDVO2FIjMzE4GBgaXeCwwMRE5ODq5duwYvL687zomLi8M777xjqypqjtEI/Pe/QFwckJFx5/8zMoCkJGDOHKBrV+D994EuXSphID8fmD0biI9nsbiVixeBv/4CfvkFeOstYMAAYMYMoE2bKl2LIhIBAQHw9vaWDm+VgIhQUFCA7OxsAEDDhg2rXFa1F4qqMG3aNEyePLnkb2Wu2Rn4809g5EjgwAH+u2FDYNQoIDISCA4GiouBEyeALVuATZuAPXtYLCZO5N++Xm/GwK+/AqNHA6dO8d9t2gBDhnAhgYFAbi63LjZuBH78EVi/no3Nng1MmABU4P13O0ajsUQk6tWrV5WPo8ajPAizs7MREBBQ9W4IOTEAaMOGDRUe89BDD9GECRNKvbdkyRLy8fGx2I7BYCAAZDAYqlBL2/HTT0R+fkQAkY8P0fz5REVF5R9//jzRmDF8PEAUFkaUnV2BgaVLidzc+OC77iL69lsio7H843//neixx1QDAwcSXbtm8fVcu3aNUlJSqKCgwOJzJHdSUFBAKSkpdK2Mz97Se9vpZj0qS0REBBITE0u9t337dkRERNipRmLYsAHo0we4epXHH44fB2JjAQ+P8s9p1AhYsoRbFv7+3Ap56CEgLa2Mg997DxgzBrhxAxg0CDh2DHjqqYpbCPfeC3z/PfeD3N15PKNPH251VALZ3bAOTT4/USomitzcXDp69CgdPXqUANDcuXPp6NGjdPbsWSIiev3112nUqFElx58+fZq8vb3p1VdfpdTUVFqwYAG5urpSQkKCxTYdvUXx3XdE7u780B4ypFIP7RJSU4lCQriMVq1ua1l8/LHaKpg2reJWRHkkJnIzByDq2ZOosNDsKUqLoqwnocRyKvocLb23nU4oduzYQQDu2EaPHk1ERKNHj6bIyMg7zgkNDSUPDw9q3rw5LV26tFI2HVkoDh8m8vLi39/QoUQ3blS9rLNniRo3VrsheXlEtHq1KhLTp1tX2f37iWrV4rIGDSIymSo8XAqFNtRIobAHjioU6elEjRrx765PH6LiYuvLTEkhqlv3ZuPhH8lk8vbmP15+2ewP2yJ++onIw4PLnDWrwkOdXSgmTpxI/fv317zc+fPnU5MmTUiv11NYWBjt37+/wuO1EIpqP0ZRXTEagREjgAsX2FVh1SrATYM5rDZteLyjrosBz/3QH7qCAuDRR3kuVYu+bs+ewPz5vP/mm8D27daX6aAcOHAAnTt31rTM1atXY/LkyZg+fTqOHDmC9u3bo3fv3iVToMKwStpqCI7Yopg1ix/KtWoR/fGH9uX/3imGCKAzaEopSZe0NzB2LF9AUBDRxYtlHnL7k9Bk4u6QPbbKNKaKiorIzc2tVNc4PDxci0+NwsLCKDY2tuRvo9FIwcHBFBcXV+45suthIxxNKA4fVmcplywRYGDNGiKAbsCFuiCJOnQgun5dYxsFBURt2lQ4XnH7DZ6Xpw6X2HrLy7P80oxGI+3fv58AUHJyMmVkZNCVK1dKHTNz5kyqVatWhZsyQK9QVFRErq6ud7gExMTE0BNPPFFufbQQCulw5WQUFwPPPsuzlAMHAk8/rbGBS5d4XhXAtYlv4I+vuuLyUWDWLGD6dA3teHkBy5cDDz4IrF0LDB7MF1QNcHFxQXp6OurVq4f27duXecwLL7yAwYMHV1hOcHBwqb8vXrwIo9FYpqfxH3/8YV2lzSCFwsmYOxdITgbq1uWuvuYuBq++yjEb996L2u+9hQXhwLBhLBTDhwOtWmloq1Mn4I03gHffZa/NXr2AChIDeXsDeXka2q8E3t6VO/7o0aPligQA+Pv7w9/f38pa2Q45mOlEpKUBSgjKRx+xx7Sm7NoFLF3K+59+Cnh4YMgQ9pG6fh0YP54b4poybRrQsiWQng78618VHqrTAbVq2WerrCAnJydXKBSzZs1C7dq1K9zOnTtX6pz69evD1dUVWVlZpd7PyspCUFBQ5SpYSaRQOBFTpwLXrrH3ZEyMxoUbjRzwAQDjxpVEiel0HPul1wPbtvGMiKZ4egILF/L+ggXsUloNOHbsGEJDQ8v9/wsvvIDk5OQKt9u7Hh4eHujUqVMpT2OTyYTExETxnsYVD8tIiBxjMHP3bh5U0+mIjhwRYGDJEjbg61tmwMdbb/G/W7asOH6kygwYoDqE3MSZ/SiaNGlCb7zxBl24cIGuXr2qWbmrVq0ivV5Py5Yto5SUFBo3bhz5+flRZmZmuefIWQ8bYW+hMJmIwsP5d/TccwIM5OXxNCVA9OGHZR6Sm0sUGMiHfPyxgDr8+afqh/7jj0Tk3EKxfPlyCg4OJgD0yiuvaFp2fHw8NW7cmDw8PCgsLIz27dtX4fFSKGyEvYVi40b+/Xh7szem5sTFsYFmzSqMwVi8mA/z9yfS8CGpMmkSGwgNJTIanVooHAnpmVkDMBrZgRHgiQErco+UzdWrHBkK8OxDBQkpnnmGvUAvXwY+/ljjegB8oXXq8LTO+vUCDEiqihQKB2fNGh7f8/PjmUvNmTOHxaJtW54HrQA3N+Df/+b9uXPV1HqaUa8eoCQMmj6dVVLiEEihcGBMJs4iBwBTprDvhKZcuaI2Df7zH8CC7EeDBnGaCYOBp2g1Z9IkvtCUFM6QJXEIpFA4MOvX8+/Fzw946SUBBubP5yQy990H9Otn0SkuLqovxyefAJrnHfb1VVsVn34qwHFDUhWkUDgoRGpr4uWX+fejKbm5wLx5vP/mm5XKZdm/P0eZGgyqC4SmjB/PYxUnT7LjiMTuSKFwULZtA377jb0CJ0wQYOCzz3hUslUr7k9UAhcXdv4CuPuh+W/Zz68k3gQGg2xVOABSKByUDz7g17FjOZ+lphQXq62JV1+1aGzidoYPBxo3BrKygC+/1LZ6AHisQq9n3/GCAgEGJJVBCoUDcuQIkJjIv98K1imqOt9+y4EjAQGcy78KuLurQwnz5vHAq6YEBABPPsn7Fy9qXLikskihcEBurn6IIUOAJk00LpwI+PBD3h8/nmMtqsgzz3Cw54kTgiYolBj63FygsFCAAYmlSKFwMNLT2XcC4Na35iQlcZPFywt48UWriqpTh7tGgKCp0ubNuZ4A93GcjEmTJmHAgAGalrlr1y707dsXwcHB0Ol02Lhxo6bll4cUCgdj8WJOStOlC6BxukUmPp5fR44E6te3uriXXuLBzcREXupDc5T8FJcu8QfjRIjImZmfn4/27dtjwYIFmpZrFlH+5dUJW8V6FBYSBQRwuMPq1QIMpKURubqygf/7P82KfeopLvKFFzQrkohuiVH47TeigweJKoiQdCRE5sy8FViwUh6RjPWodqxdC2Rn8wpe/fsLMLBoEbtFR0YC99+vWbHKTOby5XeuWawJyrqj2dmc4io/3/ZbJaZo3dzcsGfPHgCcwCYjIwMJCQmljqlK4hp7IlPhORCLFvHr88/zrIKmXL/OvhMAD2JqSI8eHCqSkgJ89ZUAL1I/Px6juHqVB0bsQV4eO7VYgKicmfZECoWDcOwYryzu6go895wAA5s28RO5YUN12lEjdDrgn/9k/Vm4kF81zeXp6srjKfn5GhYqluqWM1MKhYOweDG/9usnIJQcUJsrzz4roLnC7hivvQakprLgdeumsYEGDbhVsXs3x6YIuIYKqWR2XUtyZs6aNavCMlJSUtC4ceNK2RWFFAoHID+f+/cA8MILAgycPAn8/DM/5oU0V3hyYtgw4IsvOJZLc6Hw8uJuh07HPuN+fhob0JZjx47hqaeeKvf/sushqTRr13IUZosWwCOPCDDw+ef8+thjAjy4VMaNY6FYs4a9NTVvWdevz2MFf/8NBAUJWKtAO0wmE06cOIH09HTUqlULvrdF9VW165GXl4dTp06V/H3mzBkkJyfD399faOtDzno4AF98wa/PPFOpIE7LKC5WgzEU7yhBPPAA0L49UFQErFghwIC/P49XXL/O3poOzIwZM7Bs2TI0atQIM5QwYA04dOgQOnTogA4dOgAAJk+ejA4dOuDtt9/WzEZZ6G7Ox0oqICcnB76+vjAYDPCpYIGaqvDHHxyy7eLC4ReatzY3buS51sBANiC4bz9/Ps96hIYCR49aV1ZhYSHOnDmDZs2awVNxNT97llsU/v7suSkxS5mf400svbedskWxYMECNG3aFJ6enggPD8eBAwfKPXbZsmXQ6XSltts/LHuitCb+8Q8BInGrgZgYmwwADh8OeHhw2ktrhaJMFG/SK1eczlPTmXE6oajKsu8+Pj7IyMgo2c6ePWvDGpfPjRvqIOazzwowkJEB/PAD7z/zjAADd+LvrybLWrJEgAFvbx7YJOJ8GhKb4HRCMXfuXIwdOxZjxoxB27ZtsWjRInh7e2NJBXelTqdDUFBQyXb7Iq/2YutWnvGrX59bFJqzYgXHf3fpwumzbYSiSStXCgj61OnUVoUMP7cZTiUU169fx+HDhxEVFVXynouLC6KiorB3795yz8vLy0OTJk0QEhKCJ598EsfNLFtXVFSEnJycUpsIlDHGESO4ua4pRKqB0aM1LrxioqKAu+7i3sGWLQIM+PuzYBQUyFR5NsKphKKiZd8zMzPLPOeee+7BkiVLsGnTJqxYsQImkwldunTB+fPny7UTFxcHX1/fki0kJETT6wC41bxpE+8raRc05ehRzvOv1wNm5uu1xtWVg1MBtWulKe7uahLRS5cEGJDcjlMJRVWIiIhATEwMQkNDERkZifXr16NBgwZYrLhClsG0adNgMBhKtrS0NM3rtWYNz/K1a8czBJqjtCb69bOLc5KSOOuHH3iSwhrKnJhTAsUuXZI5Nc2gxcSmUwmFFsu+u7u7o0OHDqWcVm5Hr9fDx8en1KY1ip+B5quSA+w78c03Ag2Yp21bzqdx4wawalXVynC/OUtTUFbOTF9fbroUFzu8T4W9UT4/dytmvZzKM/PWZd/73RxaV5Z9H29hRKTRaMSxY8fwDyGjh5Zx+jTHQ7i4mF2cq2ps386P8YAAoFcvAQYsIyYGOHSo6hGlrq6u8PPzK5nR8vb2hu5Wb0wfHx4Iyc4WMMjj/BARCgoKkJ2dDT8/P7hWIYmyglMJBcCeaKNHj0bnzp0RFhaGefPmIT8/H2PGjAEAxMTEoFGjRoiLiwMAvPvuu3jwwQfRsmVLXL16FR988AHOnj2L5wTFPFjCypX82rOnIN8JpbkydCivA2gnhg7ldH6HDnG4yd13V74MpaVY5vR3URHPfFy6xPuau7VWD/z8/CxucZeH0wnFkCFD8Pfff+Ptt99GZmYmQkNDkZCQUDLAee7cObjccsNcuXIFY8eORWZmJurWrYtOnTrh119/Rdu2be1SfyL1d6wM+GlKbi57YwozYDkNGgC9e/M4xcqV6gpjlUGn06Fhw4YICAhAcXFx6X8ScUz7+fOckTg6WpuKVyPc3d2takmUUIUMXDUOLVPhHTzIaeO8vIhycjSo3O18+SUbuPtuIpNJgIHKsWIFV6dFC0HVefNNNvD44wIKr/7IVHgOijLG+MQTgpI1ff01v44Y4RDRlU8+yc6U//sfUIGnfdUZMYJfExKkA5ZApFDYEKNRnQEYPlyAgb//Bn76ifeFjJJWntq1VZduZWxGU9q0ATp04OmVdesEGJAAUihsyq5dvG6Hnx/33TVn7VpWo06deE1RB0ERRaV6mqOIotJck2iOFAobovQKBg5kh0nNUX4oDtKaUHj0UaBuXSAzE9i5U4CBIUP4ddcu4MIFAQYkUihsxPXrast46FABBs6d41XAdDr1h+MgeHgASla4qjpfVUjjxkDXrjwLsnq1AAMSKRQ24qef2DcoMJDT22uOsg5ht24ckeVgKI2cb79l0RRmQIgSSaRQ2AjlQTdwIHseCzMgpLliPZGRnObyyhV2HNWcgQPZ4ergQeDMGQEGajZSKGxAYaHqAyXkd3z6NLs/uriobXwHw9WVf8sAD2pqzq1NNaV1JdEMKRQ2YOtWzrLdqBHnkNEc5Yfx8MP8g3FQlKGTjRvZ41qYASkUmiOFwgYo9+2gQYLCEZRuh4MNYt5Oly4slgYDsG2bAAMDBnDT5cgRoILoYEnlkUIhmGvXgM2beV/I7/jUKc5k6+oqaGVj7XBxYbEEBD3069fn9FrCDNRcpFAIZutWXrMmJAQIDxdgQOnwP/KImkvSgVGSbW3aJCCfJqAqkZCBkJqLFArBKPfroEGCQi+UJ6eN091VlfBwnr3NzRXU/ejXj1tXycmy+6EhUigEUliodjuUB52m3NrtUAIqHBwXF3X249tvBRioV48TfQCyVaEhUigEIrzbofzSnKTboaCI5qZNgmY/hA6E1EykUAhE+R0PHCio26EYENJcEceDD/LsR06OIOer/v1l90NjpFAIoqhI7XYoTW1NOXMGOHyY2/JO0u1QuNUvTEjvoF49dVl4GXquCVIoBPHTT/zEDA7mJ6jmKD+AHj0455yToYjn5s2CYj+EDoTUPKRQCEK5P596SpCT1a39GiekSxeO/bh6Ffj5ZwEG+vXjD/7QIV4BXWIVUigEUFysrgImJPTi3Dlg/34e+HBwJ6vyuNU/TEjvICAA6N5doIGahRQKAezYwVGSAQEc9a0569fza7du/Fh2UpTG0IYNnMlOmAHZ/bAaKRQCUB5gyuC7MAMOGilqKd2787jjpUuCMl8pTZa9e2XmKyuRQqExRiM/IQFBv+PMTF5mDOAgKCfGzU2dsFEaSZoSHKyG6ypx/pIqIYVCY3bv5mTYdesKymS1YQOnfAsLY08uJ0cR0w0bAJNJgAFFTOU4hVVIodAY5cn4xBOAFWvClk816XYo9OzJS4hmZAD79gkwoAjFzp3WL6teg5FCoSEmkyoUQn7Hly4Bv/zC+07e7VDw8AD69uV9IQ/9Zs2Ajh35y1GmoiSVRgqFhhw8yGNmtWtzinrN+e47HgRp1w5o2VKAAfugiOr69dyrEmpAUiWkUGiIch9GRwOengINVJPWhELv3rzs4F9/AUePCjCgfF4//cTptSSVRgqFRhAJ7nbcmsChmoxPKHh7A489xvtCHvqtW/PSg8XFwJYtAgxUf6RQaMSxYxyoqNerN72m/PADR5q1agXce68AA/ZFeegL6x3I7odVOKVQLFiwAE2bNoWnpyfCw8NxwMwy2WvXrkXr1q3h6emJ+++/Hz/88IPmdVLuv969eYxCmIEBAxxilXKtiY7mWaLUVN40R1GiH38E8vMFGKjeOJ1QrF69GpMnT8b06dNx5MgRtG/fHr1790Z2dnaZx//6668YNmwYnn32WRw9ehT9+vVDv3798Pvvv2taL6HDB4WFwPff834163Yo+PqqeXGFPPRDQ4GmTTnbsZAcfNUcspBXX32Vrl27ZunhwggLC6PY2NiSv41GIwUHB1NcXFyZxw8ePJiio6NLvRceHk7PP/+8xTYNBgMBIIPBUOb/T54kAojc3IguXbK4WMvZvJkN3HUXkckkwIBj8NlnfJkdOwoyMHkyGxg5UpAB58Pcva1gcYti3rx5MNwcMX766adRUFAgSLrK5/r16zh8+DCilEcPABcXF0RFRWHv3r1lnrN3795SxwNA7969yz2+Kigu2w8/DPj7a1asSjXvdig88QRHhh85wjMgmqM09777TlASDMfCYACWL+dQfmuxWCiCg4ORnJwMAFi+fDny8vKst15JLl68CKPRiMDbVsMKDAxEZmZmmedkZmZW6ngAKCoqQk5OTqmtIoR2O4qL1VRZ1Wxa9HYCAoCHHuJ9RXw1JSKCo20NBg7xreZs2QLExPC6r9ZisVBMmTIFffv2xUM3v8mVK1fiwIEDuHbtmvW1cDDi4uLg6+tbsoVUEFNx4wb7Pvn5AU8+KaAyO3cCly9zFishMeuOhdDZj1vTBtaA2Q/lEhXPV2uwWCheeuklHDp0CH369AERYcGCBejSpQt8fHzQpk0bDB06FLNnz8aPP/5ofa3KoX79+nB1dUVWVlap97OyshBUTl6GoKCgSh0PANOmTYPBYCjZ0tLSyj3WzQ1YsYLDCBo2rMTFWIrybT/5pKCYdcdCiQzfswe47WvTBkWJNm5kL9dqSkEBT/AA2jREKzXr0a5dO7z55pto0aIF9u3bh9zcXCQlJWHixImoW7cuNm3ahMECF6Lx8PBAp06dkJiYWPKeyWRCYmIiIiIiyjwnIiKi1PEAsH379nKPBwC9Xg8fH59Smznc3Cy8iMpgMgmOWXc8QkKABx5gBzYhkeE9enDzLzsb+PVXAQYcg61beYKnSROgQwcNCtR6FNUkeFR+1apVpNfradmyZZSSkkLjxo0jPz8/yszMJCKiUaNG0euvv15y/J49e8jNzY0+/PBDSk1NpenTp5O7uzsdO3bMYpuWjgxrzp49PErv40NUVGRb23YkLo4vu1cvQQZiYtjAhAmCDNifkSP5EidNqvg4S+9tzYXCFsTHx1Pjxo3Jw8ODwsLCaN++fSX/i4yMpNGjR5c6fs2aNXT33XeTh4cH3XvvvfT9999Xyp7dhGLKFP62R4ywrV07c+KEOt18+bIAAxs3soGQkGo53VxUROTry5e4e3fFx1ZrobA1dhEKk4moWTP+ttets51dB+G++/jSv/xSQOEFBUS1arGBgwcFGLAvCQl8aYGBRDduVHys5n4UEhuTnMyL/Hh5sV94DUPo7IeXF/CPf/B+Ncx8pXxmWuZslULhqCjfdp8+QK1a9q2LHVCEQlm/VZiBdesEJcGwD0ajOgispduNFApHpZqlvKss7doBLVpwmIuQGffoaE6v9eefwPHjAgzYhz17eEJH65ytUigcESWE0t2db+gaiE4nOC9unTpAr14CDdgHUTlbpVA4Isq3HRXFc/41FKUx9f333LIQZqCaeGmaTKrmae3tL4XCERH1bTsZDzwANGrEYxTbtwsw0Lcvj/b93/9x1iEn5+BB4Px5zoeiNJa0QgqFo3H6NCeOdHERFDziPLi4CO5+1KvHIb/CDNgW5RIef1z7nK1SKBwNpRkcGcmBYDUcpXewaZOgyHDFgJMLBZHY8W8pFI6G8m0rC+zWcLp14/Dzq1cFRYb3788jpwcPAmfPCjBgG377jRujXl5icrZKoXAkzp/n5bJ0OjWMsobj6qp+FEIe+oGBahIMJx7UVBZsF+V2I4XCkVBu1C5dBMWsOydK42rDBs7/IcyA8mtzMoiAtWt5X1RDVAqFI6HcqLLbUYrISE4xePEisGuXAAPKiOmvv/JSb07G8ePAyZPsP/b442JsSKFwFDIygKQk3q+h3pjl4e6uJqYS8tBv1IhbcYBTdj+Uz6R3b17wWQRSKBwFZeHNBx/k7C2SUgwaxK/r1wtKTOXE3Q9bNESlUDgKsttRIT17cvxCVhawe7cAA0orbvdubt05Camp3PVwc9MmN2Z5SKFwBLKy1M637HaUibu76n8m5KHfuDEQHl56EVknQBnE7NWLhVQUUigcgXXr2FE/LIxXs5KUidL9WLdOUPdDMaD8+pwApapK1UUhhcIRUL5tgYmJqwNKjFxmpjruqylKt2/XLqfofqSmAr//Xrq1JQopFPYmM5PX7gDk+IQZPDxU56s1awQYaNKEB5Nv9Yd2YJTny6OPiu12AFIo7I+SYSk8nG9USYUoja5vvxXU/VAMCFEibVGqKLrbAUihsD+rV/OrLb7takDPnux8lZ2tNsQ0RWnVJSU5tPPV8eO8eXioPiYikUJhT86fVzvbcnzCItzdVUdKRWM1JSSEna+IHNqnQrn2Pn1sk9tICoU9WbuWb8hu3aSTVSVQNHXdOl7DWXOGDuXXVasEFG49RGrVhgyxjU0pFPZE+baVG1NiEQ8/zKHnly4Bt60WqQ2DBnHWnH37eMkEByM5mXMCe3qKdbK6FSkU9uLMGeDAAb4h5WxHpXBzU4d0hDz0g4LUFNYOOKipXHN0NOcItgVSKOyF8m336ME5ESSVQmmEbdggKPGug3Y/TCbgm294f9gw29mVQmEvvv6aX0eMsG89nJQuXXhYJydH0LofAwZw0yU5mT2bHIRffwXS0jhKVFnszBZIobAHx46xS52HR43PtF1VXFzUh/7KlQIM1KvHUwqAKuoOgFKV/v057Z2tkEJhD5RvOzq6Rq/bYS3Dh/Prli2AwSDAgNLa+/prh1h2sLhYHTJRrt1WSKGwNSaT2u+1ZSezGtK+PdC2LVBUJMjjum9fTkB5+jSwf78AA5Vj2zae6QkIAB55xLa2pVDYmj17gL/+4uFqUXnLagg6nfrQF9L9qFVLdXsUYqByrFjBr0OH8vCJLXEqobh8+TJGjBgBHx8f+Pn54dlnn0WemaWue/ToAZ1OV2p74YUXbFTjMli+nF8HDrRtJ7OaojTKduwQ5HGtKNGqVYK8uywjJ0ddpXzUKNvbdyqhGDFiBI4fP47t27djy5Yt2LVrF8aNG2f2vLFjxyIjI6Nke//9921Q2zIoLFQ7mfb4tqshzZqxYyuRoIf+o4/y9PXFi0BCggADlqFMA99zD9Cpk+3tO41QpKamIiEhAZ9//jnCw8PRrVs3xMfHY9WqVUhPT6/wXG9vbwQFBZVsPqIykJpDGXW76y5OLS3RhJgYfv3qKwFjjm5u6sih0hq0A0q3Y9Qo7nLZGqcRir1798LPzw+dO3cueS8qKgouLi7Yb2agaeXKlahfvz7uu+8+TJs2DQUFBRUeX1RUhJycnFKbJig32ogRPL8n0YRBgwC9nqMpk5MFGFBaf5s385JlNiYtTXVVt5fbjdPcrZmZmQgICCj1npubG/z9/ZGZmVnuecOHD8eKFSuwY8cOTJs2DcuXL8fIkSMrtBUXFwdfX9+SLUSLgK2sLOD773lfeQRKNMHPT83w9OWXAgyEhgL33svTK3Zw6V6+nFtKPXrYMVMi2ZmpU6cSgAq31NRUmjlzJt199913nN+gQQP673//a7G9xMREAkCnTp0q95jCwkIyGAwlW1paGgEgg8FQpWskIqK5c4kAorCwqpchKZctW/jjbdCAqKhIgIEPPmADDz4ooPDyMZmIWrVi00uXal++wWCw6N628STLnUyZMgVPP/10hcc0b94cQUFByM7OLvX+jRs3cPnyZQQFBVlsLzw8HABw6tQptGjRosxj9Ho99Hq9xWWahQhYupT3zVyrpGr07s2xXJmZ3HDTfOnWkSOB11/niNLUVKBNG40NlM2+fRwpWquWnWMHtdcoMaSkpBAAOnToUMl7W7duJZ1ORxcuXLC4nKSkJAJAv/32m8XnWKq65XL4MD8S9Hqiy5erVobELK+9xh9z376CDPTtywamThVk4E7GjmWTMTFiyrf03nYaoSAi6tOnD3Xo0IH2799PSUlJ1KpVKxo2bFjJ/8+fP0/33HMP7d+/n4iITp06Re+++y4dOnSIzpw5Q5s2baLmzZtT9+7dK2XXaqGIjeVve/Dgqp0vsYjUVP6YXV2JMjIEGFi/ng00bEhUXCzAQGlyc4lq12aTO3eKsVEtheLSpUs0bNgwql27Nvn4+NCYMWMoNze35P9nzpwhALRjxw4iIjp37hx1796d/P39Sa/XU8uWLenVV1+t9A/eKqHIzyfy9eVve9u2yp8vqRQREfxRz54toPCiIh4EAYg2bRJgoDRLlrCpVq14rEIE1VIo7IVVQvHVV/xtN21KZDRqXzlJKb74gj/uli0FfdyvvMIGHn9cQOGl6dJFoOjdxNJ722mmR52Wzz7j12eflb4TNmDIEA6jOXUK+OUXAQaee45ff/iBkyMLIiWFc0+4ugKjRwszYzHyzhVJaioveuviAowZY+/a1Ahq1eIJCgD49FMBBu65B+jenaOAlywRYIBZvJhf+/bl2Rx7I4VCJIsW8WvfvkCjRvatSw1i7Fh+Xb+e1//QHCW+6LPPgBs3NC8+P191HHvxRc2LrxJSKEThiN92DaFDB+CBBzjY84svBBgYOBCoX5+7Hlu2aF786tUcEtSiBa+36ghIoRDFqlXqt/3oo/auTY0jNpZfFy0SsPSgXq+OVfz3v5oWTQQsXMj7zz/vOMNaDlKNagYRsGAB7zvSt12DGDKE016eOyfkoc/fq04HbN8OnDihWbH79gGHDrEWOZITr7yDRZCUBBw9yiu0PPOMvWtTI/H05IkmAJg/X4CBpk0556nGBj75hF+HDwcaNNCsWKuRQiGCjz/m15gYfqxJ7MKLL3Jj7qefOOm55kyYwK9Ll2oSfn7hgrrc6UsvWV2cpkih0Jq//uJ0RADw8st2rUpNp2lTNThs3jwBBnr2BO67jweuNRg1XbiQJ1EeeogHZB0JKRRaEx/Pc+xRUZzDQGJXJk/m1xUrBEyV6nTAxIm8Hx9v1VRpXp46LqoU6UhIodCSK1dUL59XXrFvXSQAgIgIICyMc84o48uaogwmnD1rVVKbJUv49mnZUk3C40hIodCShQv50dCuHdCrl71rIwE/9BXNjo8HcnM1NuDlpXYx33+/Skk7b9wAPvqI96dMYbdtR0MKhVZcu6YOYr72mn0yoErKZMAA4O67Szf4NCU2FqhdG/jtN2Dr1kqfvno1D23Vr+8YcR1lIYVCKz77jDvBTZoAgwfbuzaSW3B1Ze0GgDlzuBuiKXXrqm7dM2dWqlVhNPIpADBpkuMu9SKFQgsKC4H33uP9adMAd3f71kdyB6NG8SoJGRnA558LMDBlCntJJSUBP/9s8Wnr1nHsoJ8fMH68gHpphBQKLfj8cyA9HQgJkVGiDoqHB/DGG7w/axb3FDUlOFhtVfz73xa1KkwmYMYM3p8wAdB8uZmcHF5KTYs1DMSlxKg+VJjco7CQqFEjzjBSiWzgEttTWEjUuDF/VfPmCTBw4QLnRbUwm9nKlXyojw/RpUsC6vPWW2ygdetys/jIxDW2ws2NR7ujoqS7toOj1wP/+hfvz5wpYAYkOBhQ1rWdOpWbDOVw/Trw1lu8/9prgL+/xnXJzATmzuX9GTOsjzcSoGPVDquT60ochuvX1XUy/vUvAQays4nq1GEDK1eWe9iCBXxIYCAn0dWcf/5TXUemgoSbskUhkZSBu7s67jxnjoBsdg0acGsC4EGRwsI7DrlyBXj7bd5/6y2eWdWUP/5Q54Hfe0+TqXopFJIaR79+QNeuPKCp/KY1ZdIkzmh29izwwQd3/Pudd4BLl4C2bdXxT80g4pHRGzeAxx/ndQg1QAqFpMah03GQmE4HfP01sGOHxga8vYEPP+T9WbPYm+omx4+rUenz5gmYSd+0Cdi2jad5FHdPDZBCIamRdO6sZiiMjeXBRU0ZMgSIjOSux0svAUQwGjkxltHI8RyaJz7LyVHdyV95hQNHNEIKhaTGMmMGEBDADk//+Y/Ghet0HIXm7s4ptr7+GgsXcgarOnUEJdN5/XUgLQ1o3lx1GtEIKRSSGkvdumpEaVwccPCgxgbuvbdk1NIY+xI+ei0DADB7NnuJasrPP6vJNj//nNct0BApFJIazcCBwNCh3B0YOVKAb8XUqTCFdoCr4QoWXxuFRyKNJa4WmpGdrS5m8vzzwMMPa2xACoVEgvnzeZLi5EnOs1mFSPHycXfHe+1WIh/eiEIi1neeqW2uZZOJQ04zMoA2bXjOVwBSKCQ1nnr1gLVr2cl27Vp1wkILvvgCeOOrNngBvBiU79x/q6kStWDqVCAhgbMJr1mjeZdDQQqFRALOhKXMJr72Gk+bWsu2berMSst/jwL++U9urgwfzqOa1rJokapqX3zB+TtFobXnaHVEunDXDEwmokmT2PPZ3Z1o7dqql5WYSOTpyWUNGXLTi7q4mCg6mt/09SXau7fqBhYv5nIAonfeqXIxlt7bTiUUM2bMoIiICPLy8iJfX1+LzjGZTPTWW29RUFAQeXp6Us+ePenkyZOVsiuFouZgNBKNGMG/PxcXDgiuIFSiTFauVINI+/YlKiq65Z+5uUTduvE/a9cm+v77yhVuMhHNnKmKxIQJla/gLVRLoXj77bdp7ty5NHnyZIuFYvbs2eTr60sbN26k3377jZ544glq1qwZXbt2zWK7UihqFjduEI0bp/4WR4wgunrV/Hm5uUQvv6ye168fh7bfQV4eUc+e6oFvvEFkyf2YkUHUv7963pQpVokEUTUVCoWlS5daJBQmk4mCgoLogw8+KHnv6tWrpNfr6ZtvvrHYnhSKmofJRBQXR+Tqyr/JevWI5swhunjxzmPz8jgaVMl1ARBNnVpuCgimsFCN8ASImjUjWrqUC7udzEyiGTM4cYXSL1q8WJPrlEJBRP/73/8IAB09erTU+927d6eXX3653PMKCwvJYDCUbGlpaVIoaih79nDeF+X37OZGFBFBFBNDNHIkUffuajcDIGralCghoRIG1qwhCg5WC6hdmygykujpp9lAp05sVPl/585Ehw5pdn1SKIhoz549BIDS09NLvT9o0CAaPHhwuedNnz6dANyxSaGomRQXE336KVFoqPp7vX1r2ZIoPr7sBoFZcnOJZs0iat68fAPh4URffcX9Ig2xVCjcxM2nWMbrr7+O95QEAeWQmpqK1q1b26hGwLRp0zBZWWIKQE5ODkJCQmxmX+JYuLkBY8fy9uefwJEjwOnTHMZRvz6HrLdsaUXah9q1OSnz1KnAsWOc4zI9nQ03aQKEh/OrHbG7UEyZMgVPm1nfvXnz5lUqOygoCACQlZWFhg0blryflZWF0NDQcs/T6/XQ6/VVsimp3rRqxZsQXFyA9u15czDsLhQNGjRAA0Hruzdr1gxBQUFITEwsEYacnBzs378fLyqeMBKJxCxO5Zl57tw5JCcn49y5czAajUhOTkZycjLy8vJKjmndujU23HSR1el0mDhxImbMmIHNmzfj2LFjiImJQXBwMPr162enq5BInA+7tygqw9tvv40vv/yy5O8ON9eG37FjB3rcTPl14sQJGAyGkmNee+015OfnY9y4cbh69Sq6deuGhIQEeHp62rTuEokzoyPSNFauWpKTkwNfX18YDAb4aL5Ki0RiPyy9t52q6yGRSOyDU3U97IXS6MrJybFzTSQSbVHuaXMdCykUFpB7M+2R9KWQVFdyc3Ph6+tb7v/lGIUFmEwmpKeno06dOtCV4VWjOGSlpaVVmzEMeU3OgbXXRETIzc1FcHAwXCpIvSVbFBbg4uKCuyzIhurj41NtbkAFeU3OgTXXVFFLQkEOZkokErNIoZBIJGaRQqEBer0e06dPr1bxIfKanANbXZMczJRIJGaRLQqJRGIWKRQSicQsUigkEolZpFBIJBKzSKHQgAULFqBp06bw9PREeHg4Dhw4YO8qVZm4uDg88MADqFOnDgICAtCvXz+cOHHC3tXSjNmzZ5fkKXF2Lly4gJEjR6JevXrw8vLC/fffj0OHDgmxJYXCSlavXo3Jkydj+vTpOHLkCNq3b4/evXsjOzvb3lWrEjt37kRsbCz27duH7du3o7i4GL169UJ+fr69q2Y1Bw8exOLFi9GuXTt7V8Vqrly5gq5du8Ld3R0//vgjUlJSMGfOHNStW1eMQU1T+tZAwsLCKDY2tuRvo9FIwcHBFBcXZ8daaUd2djYBoJ07d9q7KlaRm5tLrVq1ou3bt1NkZCRNmDDB3lWyiqlTp1K3bt1sZk+2KKzg+vXrOHz4MKKiokrec3FxQVRUFPbu3WvHmmmHki3M39/fzjWxjtjYWERHR5f6rpyZzZs3o3Pnzhg0aBACAgLQoUMHfPbZZ8LsSaGwgosXL8JoNCIwMLDU+4GBgcjMzLRTrbTDZDJh4sSJ6Nq1K+4TuVK2YFatWoUjR44gLi7O3lXRjNOnT2PhwoVo1aoVtm7dihdffBEvv/xyqVSRWiKjRyXlEhsbi99//x1JSUn2rkqVSUtLw4QJE7B9+/ZqlSfVZDKhc+fOmDVrFgDOH/v7779j0aJFGD16tOb2ZIvCCurXrw9XV1dkZWWVej8rK6tkTRFnZfz48diyZQt27NhhUYi9o3L48GFkZ2ejY8eOcHNzg5ubG3bu3IlPPvkEbm5uMBqN9q5ilWjYsCHatm1b6r02bdrg3LlzQuxJobACDw8PdOrUCYmJiSXvmUwmJCYmIiIiwo41qzpEhPHjx2PDhg34+eef0axZM3tXySp69uyJY8eOlSztkJycjM6dO2PEiBFITk6Gq6urvatYJbp27XrHtPXJkyfRRNSKYjYbNq2mrFq1ivR6PS1btoxSUlJo3Lhx5OfnR5mZmfauWpV48cUXydfXl3755RfKyMgo2QoKCuxdNc2oDrMeBw4cIDc3N5o5cyb9+eeftHLlSvL29qYVK1YIsSeFQgPi4+OpcePG5OHhQWFhYbRv3z57V6nKoIzFmQHQ0qVL7V01zagOQkFE9N1339F9991Her2eWrduTZ9++qkwWzLMXCKRmEWOUUgkErNIoZBIJGaRQiGRSMwihUIikZhFCoVEIjGLFAqJRGIWKRQSicQsUigkEolZpFBIJBKzSKGQSCRmkUIhcQi++eYbeHl5ISMjo+S9MWPGoF27diVZtiT2Q8Z6SBwCIkJoaCi6d++O+Ph4TJ8+HUuWLMG+ffvQqFEje1evxiMzXEkcAp1Oh5kzZ2LgwIEICgpCfHw8du/eLUXCQZAtColD0bFjRxw/fhzbtm1DZGSkvasjuYkco5A4DAkJCfjjjz/KTFgssS+yRSFxCI4cOYIePXpg8eLFWLZsGXx8fLB27Vp7V0tyEzlGIbE7f/31F6Kjo/HGG29g2LBhaN68OSIiInDkyBF07NjR3tWTQLYoJHbm8uXL6NKlC3r06IFFixaVvB8dHQ2j0YiEhAQ71k6iIIVCIpGYRQ5mSiQSs0ihkEgkZpFCIZFIzCKFQiKRmEUKhUQiMYsUColEYhYpFBKJxCxSKCQSiVmkUEgkErNIoZBIJGaRQiGRSMwihUIikZjl/wHhJCWbWymKVQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "problem = \"1D_ill-posed\"\n",
    "\n",
    "L = 2*np.pi\n",
    "Nx = 100\n",
    "Nt = 10\n",
    "data_dt = 1e-1\n",
    "dx = L/Nx\n",
    "\n",
    "x =  np.linspace(0, L, Nx)\n",
    "fs = np.zeros((1,Nt,Nx))\n",
    "\n",
    "for it in range(Nt):\n",
    "    fs[0,it,:] = np.sin(x-it*data_dt)\n",
    "\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "plt.plot(x, fs[0,0,:],color=\"blue\", label=r\"$t=0$\")\n",
    "plt.plot(x, fs[0,-1,:],color=\"red\", label=r\"$t=1$\")\n",
    "plt.ylabel(r'$f$')\n",
    "plt.xlabel(r'$x$')\n",
    "plt.legend()\n",
    "plt.savefig(problem+\"_data.pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "\n",
    "dx = np.array([dx])\n",
    "x = np.array([x])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fad04e33-99f5-42f9-b260-60703544b350",
   "metadata": {},
   "source": [
    "### Discover PDE using Adjoint method"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 147,
   "id": "9be877e8-f46a-4e87-a577-4dfaf278406e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Execution time: 412.8926029205322\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 236.221x236.221 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "array([[[0.99565453],\n",
       "        [0.        ],\n",
       "        [0.        ],\n",
       "        [0.        ],\n",
       "        [0.        ],\n",
       "        [0.        ]]])"
      ]
     },
     "execution_count": 147,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ps=np.array([[1]])\n",
    "ds=np.array([[1], [2], [3], [4], [5], [6]])\n",
    "\n",
    "start_time = time.time()\n",
    "estimated_params, eps = AdjointFindPDE(fs, dx, data_dt, Nt_fine=100, avg=True, gamma=1e-2, epochs=500, epthr=200, beta = 0.0000002, ds=ds, ps=ps, V = L, tol = 1e-12, eps0=1e-9)\n",
    "end_time = time.time()\n",
    "print(\"Execution time: \"+str(end_time-start_time))\n",
    "\n",
    "i_pde = 0\n",
    "plt.figure(figsize=(size*cm, size*cm))\n",
    "for id, d in enumerate(ds):\n",
    "    for ip, p in enumerate(ps):\n",
    "        plt.plot(estimated_params[:,i_pde,id,ip], label=r\"$α_{d=\"+str(d[0])+\", p=\"+str(p[0])+\"}$\", marker=\"o\", markevery=20)\n",
    "plt.legend(loc='center left', bbox_to_anchor=(1, 0.5))\n",
    "plt.ylabel(r'Coefficient')\n",
    "plt.xlabel('Epochs')\n",
    "name = problem + \"_\"\n",
    "plt.savefig(name+\".pdf\",format='pdf', bbox_inches=\"tight\", dpi=300)\n",
    "plt.show()\n",
    "\n",
    "estimated_params[-1,:]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d70e057b-5255-49b8-bea1-85669601a093",
   "metadata": {},
   "source": [
    "### Discover PDE using PDE-FIND"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 127,
   "id": "73bfd915-be85-4bd7-b8e6-213cce18b5d7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['1', 'u_{x}', 'u_{xx}', 'u_{xxx}', 'u_{xxxx}', 'u_{xxxxx}', 'u_{xxxxxx}', 'u', 'uu_{x}', 'uu_{xx}', 'uu_{xxx}', 'uu_{xxxx}', 'uu_{xxxxx}', 'uu_{xxxxxx}']\n",
      "u_t = (-0.989758 +0.000000i)u_{x}\n",
      "   \n",
      "Execution time: 0.08303117752075195\n",
      "[0.98975839]\n",
      "[0.01024161]\n"
     ]
    }
   ],
   "source": [
    "import sys; sys.path.append('PDE-FIND/')\n",
    "from PDE_FIND import *\n",
    "import scipy.io as sio\n",
    "import itertools\n",
    "\n",
    "start_time = time.time()\n",
    "\n",
    "dt = data_dt\n",
    "\n",
    "import sys; sys.path.append('PDE-FIND/')\n",
    "from PDE_FIND import *\n",
    "import scipy.io as sio\n",
    "import itertools\n",
    "\n",
    "start_time = time.time()\n",
    "\n",
    "#(numPDE, Nt, Nx0, Nx1, ...)\n",
    "nt = Nt-1\n",
    "\n",
    "# Take up to second order derivatives.\n",
    "u = np.zeros((nt, Nx))\n",
    "ut = np.zeros((nt, Nx))\n",
    "ux = np.zeros((nt, Nx))\n",
    "uxx = np.zeros((nt, Nx))\n",
    "uxxx = np.zeros((nt, Nx))\n",
    "uxxxx = np.zeros((nt, Nx))\n",
    "uxxxxx = np.zeros((nt, Nx))\n",
    "uxxxxxx = np.zeros((nt, Nx))\n",
    "\n",
    "\n",
    "for i in range(nt):\n",
    "    u[i,:] = fs[0, i, :]\n",
    "    ut[i,:] = (fs[0, i+1, :]-fs[0, i, :])/dt\n",
    "    ux[i,:] = np.gradient(u[i,:], axis=0) / dx[0]\n",
    "    uxx[i,:] = np.gradient( np.gradient(u[i,:],axis=0), axis=0) / dx[0]**2\n",
    "    uxxx[i,:] = np.gradient( np.gradient( np.gradient(u[i,:],axis=0), axis=0), axis=0) / dx[0]**3\n",
    "    uxxxx[i,:] = np.gradient( np.gradient( np.gradient( np.gradient(u[i,:],axis=0), axis=0), axis=0), axis=0) / dx[0]**4\n",
    "    uxxxxx[i,:] = np.gradient( np.gradient( np.gradient( np.gradient( np.gradient(u[i,:],axis=0), axis=0), axis=0), axis=0), axis=0) / dx[0]**5\n",
    "    uxxxxxx[i,:] = np.gradient( np.gradient( np.gradient( np.gradient( np.gradient( np.gradient(u[i,:],axis=0), axis=0), axis=0), axis=0), axis=0), axis=0) / dx[0]**6\n",
    "\n",
    "u = u.reshape((nt * Nx, 1))\n",
    "ut = ut.reshape((nt * Nx, 1))\n",
    "ux = ux.reshape((nt * Nx, 1))\n",
    "uxx = uxx.reshape((nt * Nx, 1))\n",
    "uxxx = uxxx.reshape((nt * Nx, 1))\n",
    "uxxxx = uxxxx.reshape((nt * Nx, 1))\n",
    "uxxxxx = uxxxxx.reshape((nt * Nx, 1))\n",
    "uxxxxxx = uxxxxxx.reshape((nt * Nx, 1))\n",
    "\n",
    "num_points = nt * Nx\n",
    "\n",
    "X_data = np.hstack([u])\n",
    "X_ders = np.hstack([np.ones((num_points,1)), ux, uxx, uxxx, uxxxx, uxxxxx, uxxxxxx])\n",
    "X_ders_descr = ['','u_{x}', 'u_{xx}', 'u_{xxx}', 'u_{xxxx}', 'u_{xxxxx}', 'u_{xxxxxx}']\n",
    "X, description = build_Theta(X_data, X_ders, X_ders_descr, 1, data_description = ['u'])\n",
    "print(['1'] + description[1:])\n",
    "\n",
    "c = TrainSTRidge(X,ut,10**-9,1)\n",
    "print_pde(c, description)\n",
    "\n",
    "end_time = time.time()\n",
    "print(\"Execution time: \"+str(end_time-start_time))\n",
    "\n",
    "coeff_pdefind = []\n",
    "for i in range(len(c)):\n",
    "        if c[i] != 0:\n",
    "            coeff_pdefind.append( abs(c[i]) )\n",
    "coeff_pdefind = np.array( coeff_pdefind )\n",
    "print(coeff_pdefind[0])\n",
    "print(np.sum(coeff_pdefind[1:]) + abs(coeff_pdefind[0]-1.))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.11.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
