{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "from torchdiffeq import odeint\n",
    "import sys; sys.path.append(2*'../')\n",
    "from src import *\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# device = torch.device('cuda:1') # for second gpu\n",
    "device = 'cpu' # feel free to change :)\n",
    "\n",
    "\n",
    "plt.rcParams.update({\n",
    "    \"text.usetex\": True,\n",
    "    \"font.family\": \"serif\",\n",
    "    \"font.serif\": [\"Palatino\"],\n",
    "})"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "source": [
    "m, k = 1, 0.5\n",
    "\n",
    "class ControlledSystem(nn.Module):\n",
    "    \"\"\"Spring-mass system\"\"\"\n",
    "    def __init__(self, u):\n",
    "        super().__init__()\n",
    "        self.u = u\n",
    "        \n",
    "    def forward(self, t, x):\n",
    "        q, p = x[...,:1], x[...,1:]\n",
    "        dq = p/m\n",
    "        dp = -k*q + self.u\n",
    "        return torch.cat([dq, dp], -1)\n",
    "    \n",
    "def R(X, u, Δt, method, hypereuler=None, base_solver='dopri5'):\n",
    "    t_span = torch.tensor([0, Δt]).to(device)\n",
    "    with torch.no_grad():\n",
    "        if base_solver == 'analytical':\n",
    "             x_fine = forward_linear_system(X, u, Δt)\n",
    "        else:\n",
    "             x_fine = odeint(ControlledSystem(u), X, t_span, method='dopri5')[-1]\n",
    "        if hypereuler:\n",
    "            xfu = torch.cat([X, ControlledSystem(u)(0, X), u], -1)\n",
    "            x_coarse =  X + Δt*ControlledSystem(u)(0, X) + (Δt**2)*hypereuler(xfu)\n",
    "        else:\n",
    "            x_coarse = odeint(ControlledSystem(u), X, t_span, method=method)[-1]\n",
    "        R = (x_fine - x_coarse)/(Δt**2)\n",
    "        L = torch.norm(R, dim=-1, p=2)\n",
    "        return L"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "source": [
    "\n",
    "hs_stochastic = torch.load('saved_models/hs_stochastic.pt')\n",
    "hs_active = torch.load('saved_models/hs_active.pt')"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "markdown",
   "source": [
    "## Plot residuals vs controller"
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "source": [
    "import matplotlib.pyplot as plt\n",
    "# Parameters from training\n",
    "x_min_train, x_max_train = -20, 20\n",
    "u_lim = 100\n",
    "Δt = 0.03\n",
    "n_x, n_u = 10000, 100\n",
    "\n",
    "x = torch.Tensor(n_x, 2).uniform_(x_min_train, x_max_train).to(device)\n",
    "qp = torch.linspace(x_min_train, x_max_train, 100) ; Q, P = torch.meshgrid(qp, qp) ; x = torch.cat([Q.reshape(-1, 1), P.reshape(-1, 1)], -1).to(device)\n",
    "u = torch.linspace(-u_lim, u_lim, n_u)[:,None].to(device)\n",
    "\n",
    "X = x.repeat(n_u, 1, 1)\n",
    "U = u.repeat(n_x, 1, 1).permute(1, 0, 2)\n",
    "X = X.cpu()\n",
    "U = U.cpu()\n",
    "\n",
    "res_euler = R(X, U, Δt, 'euler').cpu()\n",
    "res_hypereuler_stochastic = R(X, U, Δt, 'euler', hypereuler=hs_stochastic.cpu()).cpu()\n",
    "res_hypereuler_active = R(X, U, Δt, 'euler', hypereuler=hs_active.cpu()).cpu()\n",
    "# res_hypereuler_max = R(X, U, Δt, 'euler', hypereuler=hs_max.cpu()).cpu()\n",
    "res_midpoint = R(X, U, Δt, 'midpoint').cpu()\n",
    "res_rk = R(X, U, Δt, 'rk4').cpu()\n",
    "# res_dopri = R(X, U, Δt, 'dopri5').cpu()\n",
    "\n",
    "u = u.cpu().squeeze()\n",
    "\n",
    "alpha = .1\n",
    "\n",
    "fig, ax = plt.subplots(1, 1, figsize=(6, 6))\n",
    "ax.plot(u, res_euler.mean(1), label='Euler', color='r')\n",
    "ax.fill_between(u, res_euler.mean(1) - res_euler.std(1),\n",
    "                res_euler.mean(1) + res_euler.std(1), alpha=alpha, color='red')\n",
    "ax.plot(u, res_midpoint.mean(1), label='Midpoint', color='g')\n",
    "ax.fill_between(u, res_midpoint.mean(1) - res_midpoint.std(1),\n",
    "                res_midpoint.mean(1) + res_midpoint.std(1), alpha=alpha, color='green')\n",
    "ax.plot(u, res_rk.mean(1), label='RK4', color='orange')\n",
    "ax.fill_between(u, res_rk.mean(1) - res_rk.std(1),\n",
    "                res_rk.mean(1) + res_rk.std(1), alpha=alpha, color='orange')\n",
    "# ax.plot(u, res_dopri.mean(1), label='Dopri5', color='purple')\n",
    "# ax.fill_between(u, res_dopri.mean(1) - res_dopri.std(1),\n",
    "#                 res_dopri.mean(1) + res_dopri.std(1), alpha=alpha, color='purple')\n",
    "\n",
    "# HyperEuler\n",
    "ax.plot(u, res_hypereuler_stochastic.mean(1), label='HyperEuler Stochastic', color='k')\n",
    "ax.fill_between(u, res_hypereuler_stochastic.mean(1) - res_hypereuler_stochastic.std(1),\n",
    "                res_hypereuler_stochastic.mean(1) + res_hypereuler_stochastic.std(1), alpha=alpha, color='black')\n",
    "ax.plot(u, res_hypereuler_active.mean(1), label='HyperEuler Active', color='purple')\n",
    "ax.fill_between(u, res_hypereuler_active.mean(1) - res_hypereuler_active.std(1),\n",
    "                res_hypereuler_active.mean(1) + res_hypereuler_active.std(1), alpha=alpha, color='black')\n",
    "\n",
    "\n",
    "ax.set_xlabel(r'Controller value $[N]$')\n",
    "ax.set_ylabel(r'Residual $\\mathcal{R}$')\n",
    "ax.legend()\n",
    "ax.set_yscale('log')\n",
    "\n",
    "# plt.savefig('images/residuals_linear.pdf')\n",
    "\n",
    "# import tikzplotlib\n",
    "# tikzplotlib.save(\"images/residuals_linear.tex\")"
   ],
   "outputs": [
    {
     "output_type": "stream",
     "name": "stderr",
     "text": [
      "/home/botu/anaconda3/lib/python3.8/site-packages/torch/functional.py:445: UserWarning: torch.meshgrid: in an upcoming release, it will be required to pass the indexing argument. (Triggered internally at  ../aten/src/ATen/native/TensorShape.cpp:2157.)\n",
      "  return _VF.meshgrid(tensors, **kwargs)  # type: ignore[attr-defined]\n",
      "findfont: Font family ['serif'] not found. Falling back to DejaVu Sans.\n"
     ]
    },
    {
     "output_type": "display_data",
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     }
    }
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "source": [
    "def mae(yhat, y):\n",
    "    '''Calculate MAE: Mean Average Error\n",
    "    '''\n",
    "    with torch.no_grad():\n",
    "        err = torch.abs(yhat - y).mean(dim=2)\n",
    "    return err.mean(1).numpy(), err.std(1).numpy()\n",
    "\n",
    "def mape(yhat, y):\n",
    "    '''Calculate MAPE: Mean Average Percentage Error\n",
    "    '''    \n",
    "    with torch.no_grad():\n",
    "        err = torch.abs((yhat - y)/yhat).mean(dim=2)\n",
    "    return err.mean(1).numpy(), err.std(1).numpy() "
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "markdown",
   "source": [
    "## Propagate the system forward"
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "source": [
    "tf = 0.3\n",
    "t_span = torch.linspace(0, tf, int(tf/Δt) + 1)\n",
    "bs = 10000\n",
    "x0 = torch.Tensor(bs, 2).uniform_(x_min_train/5, x_max_train/5)\n",
    "\n",
    "# We propagate the system forward one step at a time\n",
    "def random_forward_propagation(x0, t_span, hypersolver=None, bang_bang=False, method='midpoint'):\n",
    "    sys = ControlledSystem(1)\n",
    "    x, x_nom = [x0[None]], [x0[None]]\n",
    "    xt, xt_nom = x0[None], x0[None]\n",
    "    bs = x0.shape[0]\n",
    "    for t in range(len(t_span)-1):\n",
    "        if bang_bang: u = 2*u_lim*torch.randint(2, (1, bs, 1), dtype=torch.float) - u_lim\n",
    "        # if bang_bang: u = torch.Tensor([100], dtype=torch.float).repead()\n",
    "        else: u = torch.Tensor(1, bs, 1).uniform_(-u_lim, u_lim)\n",
    "        sys.u = (u.float())\n",
    "        diff_span = torch.linspace(t, t+Δt, 2)\n",
    "        if hypersolver:\n",
    "            f = sys(t, xt)\n",
    "            xfu = torch.cat([xt, f, u], -1)\n",
    "            # Hypersolver\n",
    "            xt = xt + Δt*f + Δt**2*hypersolver(xfu)\n",
    "        else:\n",
    "            xt = odeint(sys, xt, diff_span, method=method)[-1]\n",
    "        # Nominal\n",
    "        xt_nom = odeint(sys, xt_nom, diff_span, method='dopri5')[-1]\n",
    "        # You can also change to the analytical version\n",
    "        # xt_nom = forward_linear_system(xt_nom, u, Δt) \n",
    "        x.append(xt); x_nom.append(xt_nom)\n",
    "    return torch.cat(x), torch.cat(x_nom)\n",
    "\n",
    "he_traj, nom_traj = random_forward_propagation(x0, t_span, hs_stochastic)\n",
    "he_traj_argmax, nom_traj_argmax = random_forward_propagation(x0, t_span, hs_active)\n",
    "mp_traj, nom_traj_mp = random_forward_propagation(x0, t_span, method='midpoint')\n",
    "he_traj_bb, nom_traj_bb = random_forward_propagation(x0, t_span, hs_stochastic, bang_bang=True)\n",
    "he_traj_argmax_bb, nom_traj_argmax_bb = random_forward_propagation(x0, t_span, hs_active, bang_bang=True)\n",
    "mp_traj_bb, nom_traj_mp_bb = random_forward_propagation(x0, t_span, method='midpoint', bang_bang=True)"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "source": [
    "# Plotting\n",
    "# stochastic, active hypersolvers and midpoint\n",
    "# random\n",
    "err_he, std_he = mae(nom_traj, he_traj)\n",
    "err_he_argmax, std_he_argmax = mae(nom_traj_argmax, he_traj_argmax)\n",
    "err_mp, std_mp = mae(mp_traj, nom_traj_mp)\n",
    "\n",
    "# bang-bang\n",
    "err_he_bb, std_he_bb = mae(nom_traj_bb, he_traj_bb)\n",
    "err_he_argmax_bb, std_he_argmax_bb = mae(nom_traj_argmax_bb, he_traj_argmax_bb)\n",
    "err_mp_bb, std_mp_bb = mae(mp_traj_bb, nom_traj_mp_bb)\n",
    "\n",
    "\n",
    "fig, ax = plt.subplots(2, 1, figsize=(3, 3))\n",
    "alpha = .1\n",
    "\n",
    "ax[0].plot(t_span, err_he, label='Stochastic exploration', color='tab:orange')\n",
    "ax[0].fill_between(t_span, err_he - std_he, err_he + std_he, alpha=alpha, color='tab:orange')\n",
    "ax[0].plot(t_span, err_he_argmax, label='Active residual minimization', color='grey')\n",
    "ax[0].fill_between(t_span, err_he_argmax - std_he_argmax, err_he_argmax + std_he_argmax, alpha=alpha,color='grey')\n",
    "ax[0].plot(t_span, err_mp, label='Midpoint', color='tab:green')\n",
    "ax[0].fill_between(t_span, err_mp - std_mp, err_mp + std_mp, alpha=alpha,color='tab:green')\n",
    "\n",
    "# ax[0].set_title(r'$Random~control~input$')\n",
    "ax[0].set_xlabel(r'$Time~[s]$')\n",
    "ax[0].set_ylabel(r'$MAE$')\n",
    "\n",
    "ax[1].plot(t_span, err_he_bb, label='Stochastic Exploration', color='tab:orange')\n",
    "ax[1].fill_between(t_span, err_he_bb - std_he_bb, err_he_bb + std_he_bb, alpha=alpha, color='tab:orange')\n",
    "ax[1].plot(t_span, err_he_argmax_bb, label='Active Error Minimization',color='grey')\n",
    "ax[1].fill_between(t_span, err_he_argmax_bb - std_he_argmax_bb, err_he_argmax_bb + std_he_argmax_bb, alpha=alpha, color='grey')\n",
    "ax[1].plot(t_span, err_mp_bb, label='Midpoint', color='tab:green')\n",
    "ax[1].fill_between(t_span, err_mp_bb - std_mp_bb, err_mp_bb + std_mp_bb, alpha=alpha,color='tab:green')\n",
    "ax[1].legend(loc='lower center', ncol=3, bbox_to_anchor=(0.5, -0.4))\n",
    "# ax[1].set_title(r'$Bang-bang~controller$')\n",
    "ax[1].set_xlabel(r'$Time~[s]$')\n",
    "ax[1].set_ylabel(r'$MAE$')\n",
    "# ax[0].set_yscale('log')\n",
    "# ax[1].set_yscale('log')\n",
    "\n",
    "for ax in ax:\n",
    "    ax.label_outer()\n",
    "    ax.yaxis.set_major_locator(plt.MaxNLocator(4))    \n",
    "    ax.ticklabel_format(style='sci', axis='y', scilimits=(0,0))\n",
    "    ax.set_ylim(bottom=0)\n",
    "# plt.suptitle('Error propagation with different hypersolver pre-training',fontsize=14, weight='semibold', y=.97)\n",
    "ax.legend(loc='upper center', bbox_to_anchor=(0.5, -0.4),\n",
    "          fancybox=True, shadow=False, ncol=1)\n",
    "\n",
    "plt.savefig('media/residuals_stochastic_active.pdf', bbox_inches='tight')\n",
    "import tikzplotlib\n",
    "tikzplotlib.save(\"media/residuals_stochastic_active.tex\")"
   ],
   "outputs": [
    {
     "output_type": "display_data",
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAANcAAAEQCAYAAAAj5+ENAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAABIOklEQVR4nO29e3Ac133n+zndPS+8By8+QVIARUoUrQdFPWLTj7XFKMotO3QiWWW6sje8V7Ei36vEVcu14zXXVRvbd2OFW7tx6q6jtW7RvlWyK5KtMLt7bdmUEsembb1ISTEFCSQBPsAnMAAGA2Bm+nXO/aO7Bw0Qb2CIB/tTNZxG90w/hv3t3zm/8/v9jlBKERERsfBoi30CERErlUhcERFlIhJXRESZiMQFCCHqhBDPL/Z5RKwsInF57FzsE4hYedzw4hJC1AH9/isiYsFYEeISQnxWCNE5bt0XhBAPCyGenubrDyiljpfx9CJuUMRyH+cSQrT6i0eUUm3+uoeBrFLqJSHEF4As8BzwwLivvwR81l9+FPiiUuql8p91xI2AsdgnMBOEEDuA+uDGF0I8APQrpY4rpbr8deGv7Aa+4S8fB3YrpbLADybY/VP+/h8F3ijPFUTciCwLcSmljgshHvBFVVo3xVdaGe1D9QN10+0fuHu+5xkREWbZ9Ll8q7UDzwpN13TLAvX+cr3/d0TEdWXZiMu3WseBI2ELNgmv4wkRPCv2d+U8t4iIiVgW4vL7RCilXgr1u3aEtj8MtAohPut/7ilgt79+uiZkRERZWPbewoiIpcqysFwREcuRSFwREWViWbjiGxsb1aZNmxb7NCIiruHYsWMZpVTTRNuWhbg2bdrEG29E47sRSw8hxLnJtkXNwoiIMhGJKyJiApRS2LbNyMgIruvOaR/LolkYEXG9cBwH0zQxTRMpJVJK4vE4uq7Pel+RuCJueFzXxbIsisUiruuiaRqGYSCEwDTNOe83ElfEDYmUEtu2KRaL2LaNEALDMDCMhZNEJK6IGwalFI7jUCwWMU0TIQS6rpNIJMpyvEhcESsapRSu62KaJsViEQBN04jH4+NzABecSFwRK5KgH1UoFJBSomkasVis7IIKsyjiEkLUKaWywftinEPEyiNwnxcKhTH9qFgstijnUxZx+XUrHmc0SbFfKbXb37YD+HbwBBFCRHUrIuZM0I8KvH1KKQzDKFs/ajaUy3JlQ8ViduAlLIb54yjHKmI+LIVm33SUK0LjudDyo0qp8YVhHhVCPB8kN0ZEzAQpJaZpMjg4yMDAAPl8vuTtW2rCgjJZrqAf5WcCj0+xz/rrssDzQoj+CcSHL7zPAmzYsKEcpxmxDBjvPgeWTLNvOsrt0HhUKfVIeEVQCg3AL9g5vskYfO6/Af8NYOfOnVG69A3GRM2+6+E+X0jKJi5fONdUuxVC7Aj1t9om+kzEjclEg7yL6e2bL+XyFu4AdiqlHh+37kuMrd50JGzJIm5MxlupckZNXE/K1ee6psimv+6Rib8RcaMx0ZjUUnRKzIcoQiPiuhKkdCy1MalyEIkrouxIKUvNviClYylbKdu2uXDhAl1dXZw9e5bHHntsTv2+SFwRZeF6R6DPl6GhIbq6ujhz5gznz5/HcRwMw2D9+vUUCgWqqqpmvc9IXBELynJxoUspuXz5MmfOnKGrq4tMJgNAbW0t27dvp7W1lfXr1+O6LrW1tXM6RiSuiHmz1AJmJ6NQKHD27FnOnDnD2bNnKRaLaJrG2rVr+dCHPkRrayvpdHrMg2Cu9TMgElfEPBjvnFhqzT6lFH19fXR1ddHV1cXly5dRSpFKpWhtbaW1tZWNGzde/2RJIcR/BJ5WSp0NrbsLGAivi7ixWOrOCSklFy9epLOzk87OTgYHBwFobm7mvvvu46abbmL16tXX5Xynslz9gYiEEL+vlHpBKfWmEOJbwBNlP7OIJUXYSgFLykpZlsXZs2fp7OzkzJkzFItFdF1nw4YN3HPPPbS2ts7JITFfphLXQGi5PrQcRVTcIIzvSy0lKzU8PExXVxenT5+mu7sb13VJJpO0trbS1tbGxo0bicfji3qOU4nrT4QQbXgTybWF1g9M8vmIFUKQ2hF4/JbCQG/Qf+rs7OT06dNcvXoV8Lx7d955J62traxbtw5NWzp1bqcS19N4E3DvBNJCiJ/iWbBa4JnrcG4R1xnHcSgUCksmaHay/tPq1avZtWsXra2tNDQ0LAlLOhGTiksp9W1/8U0gWEYI8bGZ7Diqk7E8UEphWRb5fL7koFjMcalw/6mrqwvTNJdE/2kuzMUV3zfdB6ark+HX2OjCmzz88Yn3ElFOgnJjhUJh0WP8hoeHS9Yp3H9qa2tbMv2nuTCVK74Gr0nYitfnCt5vAhpmsO8J62T42cnHlVIvCSFahRCf9RMjI8rMRCFJi+GgUEqRyWRKDonx/ae2tjbWrl27pPpPc2Eqy/UDQOH1vY7h5Wc96o91zYRHhRBfwsvZCotnN/ANf/m4/3dEGRnf9FsMN/pU/acPfOADtLW1Len+01yYqs/120KIP8CzWC/hWSyUUm/OYL9ZJq+T0Qr0+8v9QN1EO4hqaMyfxfb6LdXxp+vFlH0updQPhRC1wL/Ds2IvzGSn09TJyOJ5HcPvE+0jqqExR1zXpVgsUigUAIjFYtfN6xeMP3V2dnL+/PklOf50vZjWoaGUGgT+XAjxMSHE3wKnlVIHp/rONHUyXgd24Dk0Wrm2OlTEHAm70q+X108pRX9/f2n86cqVK4DXf7rjjjtoa2tbcuNP14sZewuVUi8DL/vjXVOKC9g5vk5GUENDKfWIEOLp4D89Kg46P4Ioinw+j+M4aJpW9qaflJJLly6V+k/ZbBaAVatWrdj+01yY0luolMpNsGnaOhgTef/CNTQi9/v8CQJoAydFLBYrq6hs2+bcuXOl8adCoYCu67S0tHD33XfT2tpKdXV12Y6/GCilUGruPZKpLNfzQojn8ZwOWf+9C08gUYTGIhH0p4IA2nJGUViWxZkzZzh16hRnzpzBtm0SiQQ33XQTmzdvLmu6xmIQTDcU5HAJIYjH43Nu0k4lrrPAp4CfAo14Xr164GNE4rrujA9NKtf4lGmadHV1cfLkSc6ePYvrulRUVHDrrbdy8803s379+jnND7wUcV23NO8xUApMTqVSGIaBruvz+o2ncsU/LoS4CXgY+NtQ+skfzPloEbNioqj0cjgpCoUCnZ2dnDp1quThq6qq4n3vex9btmxZEQO6gVWSUpaaeoZhkEwmicViaJq24A+N6VzxZ4C/8j2FDwDPKaV+uKBnEHEN16M/lc/nOX36NKdOnaK7uxspJTU1Ndx5553cfPPNrFmzZlk7JIJolEBIgbWPxWILYpVmwoy8hUqpl/3xrmeEEK9N54qPmBvl7k8NDw9z+vRpTp48ycWLF1FKUVdXx913383NN9/MqlWrlq2gpJQlywSjU7PG43F0XUfTtOt+bVOKSwjxUeC38calBoAjeNEaEQtIMKt8MD61kP2pfD7PqVOn6Ojo4MKFCwDU19dz7733smXLFhobG5eloMaLKTyVkK7rc2riKaVwleu9pIslLWxpUxevI6YvYN1CIUQ/XlTGF5VSfz7rPUdMSdCfGhkZWfB4v0KhULJQ58+fRylFOp3m/vvvLwlquRHuL4WL4YQt00yYUECujemaONIZ81khBI50qIpVEWNhi4J+zK+Z8Qd+sRqATqAuahbOnXB/aiHj/UzT5PTp03R0dHD+/HmklNTW1nLPPfewdevWZWWhws6H4G/DMMZ48aYS03gB2dLGci1M18RVbqkfplBoQkMXOrqmE9dDYVnSBSnJ23nwz2O2TOUtfNN//yHwQwDfe/iNyb4TMTlBEG0+nwcWpj9lWRadnZ1j3ObV1dXs2LGDLVu2LJs+VNDEm43zQSmFoxxc6SKVxHRNbNfGktYYC3SNgEQ82IEvIBekDVYBHNNblg4oCQiwhqFyFcQrZ31ds0qW9L2Hn5r1UW5gpJQUCoVSbb/5utJt2+bMmTN0dHTQ1dVVcpvfcccdbNmyZcl7+ZRS14hpfH8pcD5IJXGVW7I4lmt5L2nhyrHFOoUQ11og3/p4YjHBscG1QFreNqVAaID/LjQQOuhJCH5Dpzjna42KgpaJcGT6fAd9Hcfh7NmzJUHZtk1FRQXbt29n69atrFu3bskKaqKoB8MwqKiowDAMhCZQeM04W9kMW8OlZpyjHASj16UJDV3TMTSDhO43paX0RRQSkGN6Agqsj3cmnnA0DbQ46OUft1sUca3k+hqu65Ys1XwGfV3X5dy5c3R0dNDZ2YllWaRSKW699Va2bNnC+vXrl+TA7kQucd3QiSViKE2h8Jpzg3IQq2AhleekEEIgEJ4F0nRieoyECAlI+RbICVkg1/SEFUbooOmgJ3yrtHiUc2bJb+CVCXhughkmJ62vsVxZiHQP13Xp7u6mo6OD06dPY5omiUSCm2++ma1bt9LS0rKkQo/CTTwppScUTaHHdJShkEJiKxtXuWB7/R+BJx5NaMT1OBrCb6L5Fkg5YBfBscb1f6BkhYTwBHSdLNBcKZfl2qmU2g0ghOgcl98Fk9TXWI4E6R5BeNJsPX9SSi5cuEBHRwenTp2iWCwSj8dpa2tj69atbNy4cckISimF7dhYjlXyxEnNE5TUJLqmIzRPABqeEyGGTgINlOu9XBtk3rM+yg5ZnnDzze/7CG1s/2eZUa5pW8MpJ11cm208WX2NZUNYVLMdo1JKcfHixZKg8vk8sViM1tZWtm7dyqZNmzCMxesOu8rzwNmOjWmbo04EXDRdGx2oNTzx6Ag0pRC4nmikPWp5Aquj8EQixKjzYIlbnvlS1v9BIUQrXqWncAnsLJPX1wh/d0nW0HAch3w+j2VZsxKVUoqrV6/S0dFBR0cHw8PD6LpeEtRNN910XQtwliyPkjjSwXRNTMekaBeRKhwlbpCMx6jS48SFhqak19+xCmD6XjeE/wp73Za31VkIyv14fFwp9cXwimnqa4Q/t6RqaLiuSz6fp1gszmrgt6+vj/fee4+Ojg6y2SyaprFp0yY++MEP0tbWVtZ6EuHB1GAMKAjpGeN4UKADCUOnLh4nJkBTDhoOyBEwJRCyMJrfZNMSy97ySCXJ2cNkzUEGrEEGrBwD5iBZK8eANUhfIcPXd/1fpCrqp9/ZOMomLiHEF8YLy18/VX2NJUcwTlUoFNA0jWQyOe13crlcSVC9vb0AtLS0cM8997B582ZSqdTCnqM/HuRKF0c6WNKLRrClXfqMciXKdRASdBRxFAaSuKbQdBddCITQwC2Gmm466KllZ32KrsmglWPAypEtCSUQjSeirP/3oJVDcu2zW0eQFgZpJRgZvgJ1m2Z9HuXyFj4NPCCECLyEP8BrCn4JODK+vkY5zmG+BBEVIyMjpYzUqbx/IyMjnDx5ko6ODi5dugR4Nfk+8pGPsGXLlgUpIRaIyJGONxYkLSzHGw9SSiGUAiXRlERzwVAOyjbBddGFS8zQiRmxknvccxr4rusljC0dslaOrDXIoDXkicPMjQpo3Laia064nyQa9eg0KGhxXO50LBqsIg2ORYMraXBd6l2XBldSIyUYKdxkNa42t4dhuRwak9XImLb+xmKjlCqJarqICtM0SxHnQYBsQ0MDH/jAB9i6dSt1dXVzPocgtMeWNqY0sRwLW9kIpVCugyYUuhJo0iUpHaRp4vqWSjAaXmWkEmiGgTaHqO5yoZQi7xZKzS/PimQ96+ILJ2xdhp2RCfdjIKjHoE5BvStpc2zq7SL1tkW961LvSuqlS9oXTNJIopJpZKrOe1WlkUlvWaVGl51UmkwqDUaCfKGfVXUtc7rOKELDJ4hSHx4eRkpZyk4dj+u6nDlzhvb2ds6cOVOakPqee+7hlltumVXE+UR9Ii9GzvIHTh2QEgOJ5rpUSAeUi5IS11VIFC4ayjAwEklS8Wo0TUdfhNyloO8y4PddSn0YczAkmtEmmRVqsoapQadBCeql5FbHod62aLSLpEOWpd6VpKVLFZonilQamWpAVQfL9b6A0qXXcCrNsHF9631E4oKSqIKs3/FeO6UUPT09vPPOO7z33nsUi0UqKiq4/fbbueWWW2Y0DWjglXOUg+mYnjWyzZK7WkkHQ0l06ZCSEvBCd5RSKClwlcAVAvQYekwnntSJxQxvQLZMkRpB3yUbeg2Y4T5LloHiAAPWIIP2yIR9F0NBvS+WRsdmqx1qgknPonhNMZcakcBI1SITtahkDbKiDpmsQSVrfbHUl8RiptIUE1WLHoUxFTe0uBzHYWRkBMuyJkylHx4e5t1336W9vZ2+vj50XaetrY1t27axadOmSW9qRzola1SURSzbxHGLnjVyTTTXRZcOSZTnRAgQOkrouEL3shyEX+shoZMyYhiGF9kwVzFZrlUSRtYaGtNPGbSGyJqDDBb7yVo5Bp0RCpNYl6TfDGtwbTY4LnfJUYEEwkkToz5eRVWiFpVMo1K1yOToS4WXE7XIZA2D19mylJsbVlymaTI0NISu62M8gLZt09nZyTvvvFPqR61Zs4YHHniALVu2jPls0DcKHAxFp4hpjyBdx2vSORaGctGlS0pojIbvGBBLAhoKhXQlru8SF0IRM2IkE94gra5NXeshaI71m1n6zSwD5iB95gD95iAD5gD9xT76iwP0WzmG5cQd/bhSpKWi3nFocF02S0k66LO4LnVSktYrqI1XkY7XkUzWQbXfb0nWeQIJlv13jAQOk9Qqv0G44cSllCKfz1MoFEr9KqUUly5d4p133uHkyZNYlkV1dTX33nsv27ZtI51OA55FKjpFLGlRsPOY1ghK2QjXQbg2uusQFwpNBD+rBnocQuFLSnlCkrYLeBVyDT1GRcpA0zU0MZpuMWgNkTH76SsOkDEH6CsO0FfM0Jfv9YRj5eh38rgTNMdSUtHkOjS6LltdSaPj0uRbl7RUpI0UtbFqahO1pJL1qKo0Mpn2RBL0V4LOfqKm5FG0/VfE9NxQ4pJSMjw8jGVZxONxcrkc7e3ttLe3Mzg4iGEYbNmyhW3btrF+/XpcPG9df6GPgjWE61rgWgjHxJAuSRFYFT+QNB4nPNgaWCUpHRAKhZe75AiHnBii38oxYGXJFDL0jVymv5AhU+wnYw/R5xZwxolGKEW9K2lyPaHc6o4KpkHpNMYqScdrqU/Wk6xo8ARSEe7ke8sqWVPqqzjA0HX7H7ixuGHE5TgOuZxXnTufz/PSSy/R0dEBeAO89953L5vaNiF0Qd4a4sJgJ8oxEa6J5tgYmk5c6HhCioPhL/sovAjxYStHr9lHn5ml3+pnsHCFgWIPfeYAGTtHj5NnBPea86v2RdPsOrQ5Ls2uSyMGTUYlDbEaGpJp6iub0CoafdHUj/GMERsdi4msy9LghhBX0L8qFAq88cYb/OY3v0HXdXbs3MHmW25CTyhsu8DA4GlwTQwUSeGPb2kxSKRQCobdAhmzj4zZR+/IFfqHL9JX6KXPytLnDpORRQqMrbcglKLJdVnluLS5Lr8lFU1aiqZYNY3xWhpS9TRUriJR0ewLpr4kHMZ18OeeExuxGKxocQX9q4GBAd566y3eeustlFLctv02br5tI0LkwLqEcHQMpcjYQ/Tag2TMLJlCD/0jl+gt9JCxsvS4I+THCUcPCedWx6EZnWa9gqZ4LU2pBpoqVlNXvQ6tahVuVROyshmVqL4mnEgRCWfRUApQo++lFyipUMqZ4stTs2LFJaVkYGCA119/nbfeegvTNLl562Zu2b6BIfcKP7v8P2nPvktvMUOvPcjABJ60el84rY7D+11Fs56iOZGmuaKZpup11NZsQKtahaxswq1s8j2AY5n7f80NwmQ3t/KcPwp/phF/GaX8T0hQXiS+8v/1loT/mdJf/j79z/pZz2MSL9G8NE7dX68EaBqa0DFSDWjG3IKrV6S4TNPk17/+Na+//jr5fJ6WTeup3hyjY+jX/ODtv+WUkwVgre2wybbZ7rqsdlya9Aqa4nU0pVbTWNtCrHY9smYdqnYdsrLhmgFL138tW9ToUzpYVkp5N65/cyJDt64aXfbu6OCzYnS7GL25QwfyX9ro8cbc3AKFNnpz46WsaEJDaAYCHU3XvTIAuo7Au/HBCzbWNIHA82ZqWjAWqPtH0UDT8IsIgB+gHLwQlOp0BGUGgvf5sqLEJaXkzTff5Oc//znZXBa51mZoQye/KP4DV097cXm3mxZ/arrcV9lG0+q7kfU3Qe1aRO1qNH3sdDHXxSmgws0QiRfUNPqkVsp/Sodv8tDTPLixQztk9HmtSrfN2L/9daUbSPNemlcExrtpdYSmIXRvaEDTdO8GFsL/jQRCN8be5P53Nf+pjxDezQ2jN3joxi4NoPs3+ELf3ItNWVNO8LKQd48P5J1q21xQStHR0cGPX/4R7+Tb6au5xKX0RfJCkshL7i9a/O96mh0Nd1G5bRdq1VYwYjhCBSl+ALjK8UzRJE2V0Rt69GkfPMXH3uBQaoaMu8FLQir9Fv6NLRQahndDCx1NN9DQEGj+09q72b1xMN17QmsGwc0s0EqZvgKt1PQR/jYRDGJronST+/8Xo0/uFXBDLyXKlXLyMF4G8ktCiFYhxGeDdP6pts2F1986wv/7yvdp5xyZyl5klSLtunzM1LivspVbWz6AWHsXWjKFJgSOkgiK6K5NQosxemuNu7k0Hfwntf9I925ILUjV0PynuPf01kI3NqUb2v9O6YYPmiHa6PoV9KSOGEu5LNduRivzHvf/nsm2WfHk//NJfmachhSssnUediu4J/0+btr0r4jVriFhxEgYCWJ6ili8Al2Po+sJdCOJ0PTRjNpSE0mUnv4REfOlXOJqxZvmFf+9bobbSoRraADDQoiOiT6naWK1YYjce1K5P1PKVepVpdQzstRaW140ApnFPokFYqVcy3TXsXGyDeUSVxZvitfw+0y2lQjX0JgKIcQbpil3zv1Ulw5CiDeUUtG1LCHmcx3lSoZ5HW9OL/As1d/NcNuiIISo8ydXj4hYMMqV5v+UEOLpoJOulDruV9r9klLqkfHbynEOs2TZP2Ejlh5lc8WPd7H7Inpkom3zZF5FRYUQdXh9v/5pPno9WJYFUidhpVzLnK9DBNO4LGd858cXlVJtoXUzGksTQjyslPqBEOLpBRZ9xA3OsheXX9UXvDJtbf66h4GsP5b2BTynyXPAA+O+/hKjHslH8QS67CeFiFgaLIvwJ7+/Vh/c+H7dw36lVKlU9rhB2GvG0vypiq4pmw085e//UeCN8lxBxI3IshCX7xB5IFRMdDpHyIzG0sbt6+75nmdERJilW5dqHL7V2oFnhaZrumXxxtBgirG0iIhysmzE5Vut44wthz0ZS24sLeLGY1mIy+8ToZR6KdTv2hHa/jDQ6nsNUUo9Bez21y+VsbSIG4xl7y2MiFiqLAvLFRGxHInEFRFRJpaFK76xsVFt2rRpsU8jIuIajh07llFKNU20bVmIa9OmTbzxRjS+G7H0EEKcm2xb1CyMiCgTkbgiIiZDujCSAWfi2WGmY1k0CyMirjt2EYaugF2AWMWcdhGJKyIijFJQyMJIDxhJmMdc0pG4IiICXBuGr3rWKu5PCevOvTRsJK6ICABz2GsGCs0T1gIQiSvixkZKz2lRzHpznGkLJ4lIXBE3LoHTQjl+M3Bhi8FG4oq48RjvtDAqy3KYRRnn8isuld4jIq4brg25i5DPeNZKn9vcWzOhLOISQnxBCNEphDjmv46Etu0AXhZCHPPfp0t8jIhYGMxhGDgHjjXqDSwjZStnHarEtAMvGzjMH0cJjBHXjTI6LaaiXNJ9LrT8qFJqfNWlR4UQzweZwxERZcMuQPYcWDnPWl0nYUH5yllnoZR+P75+RdZflwWeF0L0TyC+MbOcbNiwoRynGbGScR3I93vWykh6r+tMuWX8qFLqkfCKoM4ggBDiaa5tMgafK81ysnPnzqgWQcTMUArMIRju8VzriepFO5Wy9eh84Tw9wfodoT/bmLhQZ0TE7HEszxM4dNWzVHMMuF0oyjVt6w5gZ7j2ejDLCWNLox0JW7KIiDkhJRQHId8LWhwSCxO+NF/K1ee6poJteJaTiIgFwy7AUA9IG2KVZXevz4YoQiNieSJdGOnzHRYJiJcnymI+ROKKWF4oBdaw57CAssQELhSRuCKWD47lxQNaec9ZoemLfUZTEokrYulTclhkQBjXxb2ulMKSNpY1Qko6cxJKJK6IpYtSYOe9JqB0PWtVJoeFUgpb2piuRd4pUHCLgMC2hlgvWxZWXEKI/wg8rZQ6G1p3FzAQXhcRURYcE0Z6/SZgasEjLJRSOMrBdCzyboGCU0Si0IRAFwYpPYWRu4j23v+E5tvndIypBNkfiEgI8ftKqReUUm8KIb4FPDGno0VETEc4bEmPL2gT0JY2tnQYcfIUnCKulAgBhhYjqSe92UmlS/z8r0md+Hvi3a+CEJi3fxoqG2d9vKnENRBarg8tR4O+EQvPmH6VNm8voFQSRzrY0qHgmhScAq5yUUBMGMS1OJo+2sQU+X5S7/4PUu3/gD58FbeykZGd++jd8H6aG7fO6RymEtefCCHa8CaSawutH5jk8xERs2cB+lVBE8+WDkXHpChNTNdCIACFIQxiWoyESFxz7Njlt0m9c5hE1z8hpIO1bie533qS4fX3UrQkQyMZGlx3Tpc2lbiexpuAeyeQFkL8FM+C1QLPzOloERFhwv0qIwnxmfWrbOngSAdL2hScIqZrIpVCCIEmNGLCoNKYPK5QWCMkT/6U1DsvYPR3IeNVFLb/PsO3foJ8ajWmZYHpYOj6+InsZ8Wk4lJKfdtffBMIlhFCfGzOR4uIAK9fVRjwXtP0q0oucdei4BYp+kJSKDQ0DM0Y7S9Ng97XReqdvyd58sdodgG7cSuDH/5z8jd9hLzUsG0bzbIxDMO3evNjLh7Gvpl8SAhRp5TKBu9zOE7ESmMG/arJXOIAhub3lWbTbHRtEl3/TOqdF4hffhulxylu/hj5bXvIpzdTNG1cU6JrEI8tbD2NqVzxNXhNwla8PlfwfhPQMNVO/Qj4bwdPEyHEF4O5jP2/v4DnGNkdjpyPWKEoBdaI1wQc168KxGS59qQu8Vk3zZTCyHSQfO9HJE+/hFYcxKlZx9Bv/Z+MbHmQokh5Tb+iiaHr6PMoWT0VU1muHwAKr+91DC+F5FF/rGsmTFgnw89OPq6UekkI0SqE+KyfGBmx0ig5KzLgmmAkUbEEjnKwnCJ5t0DeLuBlwqqxLvE5oOX7SJz8KamOH2H0d6H0OOZNH6Kw9SEKa3dQNB0sy0IIa8GaflMxVZ/rt4UQf4BnsV7Cs1gopd6c4b4fFUJ8CS9nKyye3cA3/OXj/t/XEKX5L2OU8lJBRjIou4ij69i6wYg95LnEg/ElMfP+0qS4FomzvyTZ8WPi519BKBd71W3kPvRvybd+BEtLYZoW7nABXdMWvOk3FVP2uZRSPxRC1AL/Ds+KvTDD/WaZvE5GK9DvL/cDdZMcO0rzX4ZIcxh76AqWNUxBSArSRVqqJKbx40tzQimM3vdIdvyI5KkjaOYQbmUT+Tv3MrLlQczKtRQtG9d0EcLE0LWyNf2mYlqHhlJqEPhzIcTHhBB/C5xWSh2c5jtT1cnI4rn0w+8RyxRXup4DojhIIXeRopkDPYYw4ugsgGUKoY1kSJ78CcmOH2EMnPWbfR9mZMvvkG++naIrcR0HUTAxDA09dv0FFWbG3kKl1Mt4RTx/CkwpLiHEjlB/q42xtTReB3bgOTRaubY6VMQSxot6sCk6RfJ2HtsagcIAwi5ixFKkUg0LJiYA7CKJc0dJdrxIvPtVhJJYq9/H4If+LUMbP4hJAttxwbQxDP26NvumY0pvoVIqN8GmmaTq7xxfJyOooaGUekQI8XTwHxAVB13aeONMFkWnyLA1jC1tb4zJcYibI1S4RW+CuIopHcizw3WIX3iN5KkjxM/8As0p4FY2M3LnZxjZ/NsMp1bh2A64oGuK+CJbqMmYynI9L4R4Hq9flPXfu/DENWWExkTev3ANjcj9vrRxpYvpmuSdPHk7j1QSIQRxLU6FMLxJDKxhT1QLNJcVShK7/C8kTh0h2fVPaMVBZKKa4uYHGG79VwzV34rten03XUpiZRKUUoqhoTxXr/Zz9Wo/V65kWPe/3k5N7ez3NZW4zgKfAn4KNOI5HuqBjxGFP604bNdr6o04IxSdIgrlDdrqcTSEH6rU54lKMxZGVEphZE56gjr9MvpID9JIUtz4AXIbP0Ku6Q6kXyFXRxCPLXz6oVKKXG6kJKarV/spFLwJxpPJOPUNlViWNad9T+WKf1wIcRPwMPC3ofSTP5jTkSKWFFJJL6TIKTBsDeMqLzg1pseoCOr9SemNUxUGPXEtkKXSs+dJnHqJ5OkjGNnzKKFTWHcPg3fuI7f2PpSRRNMEuq5jLPBYVCCmK1f6uHp1gJ6eUTGlUglWraovvWpqKskN91JTM7e0l+lc8WeAv/I9hQ8AzymlfjinI0UsKkqpkjNixB4h73jNPU1oxPX42Ihx1/EiKopZT2BGfN6i0oZ7SXS+TPLUT4n1dqAQFFe9j957f4/hlg+gkrXomkZsgTONlVIMDg6PsUzFomeJKioSrF7dUBJTdXXFgjpjZmRnlVIv++NdzwghXpvOFR+x+EglvbAixyLv5Cm6RaT0+k6TBrvaJpg5r+knBOhJMOZ+s2tDV0h0/oxE1z8Rv3oCgGL9ZgbueoyhjR9CVa9CExoLWWbGdSX9/YP09AzQ0zNAb+8ApulNGl5RkWTt2kaam+tZvbqeqqprxWS6Jll7iEE7x6A1xOWhi6xb/z5q5nAuU4pLCPFR4LfxXOcDwBG8aI2IJYYtbWzXxnQ8R0Tg1ROExGRM8FSWEpyiF6HumF5/yqiYc6Kilr1AvPMfSXT9jESmA4BiXSuZ9/0hwzd9GLduA8IPPFoIG2HbDr29WXp6+unpGSCTyeK6EoDq6grWrWuiojFBIm1gxSxy9hDv2e/xSt8Qg1c8AQ3aOQbtIbJWjqI0rznG7q0fp5mNsz63qVzx/XhRGV9USv35rPccUTZGg129PlPRKZb6TJrQiGmhftNkhJt+Ss65P6WUgv4zJDp/RurMP5PoPw1Aof5mMnf9b4xs/CBuzfrS5+crqELBpLd3oNRfGhgYQinPi1iXrqa+rZJ89TB9xgAdxRN0DZ9jpKcAPWP3o6FRG6umNl5NbayG1cnm0nJdzHuvjVejmTZrKtbM6Vynslwf82tm/IFfrAagE6iLmoXXH6UUpmsybA8zYo947nHfKsX0CbJsJ8OxvFlAzBwgQE/Mqv6flBIpXURvJ4mun1Fx7uckB88BUGi8lczdnyW/8YM4VavncJXjj+X1l/r6sr51GiCXGwFA6GA0CdytBQYTWS7Jq5zNd1OwitDnpfJvqmxhV9O9bKhYRzpeUxJMbayGKqNiRqkrg/RgzLE+4lTewjf99x8CPwTwvYffmOw7EQtLIKgRe4RhexgpJYY+h5Ai1wGn4Hn9pO2le8yw6eeJSWLbFvSeovLsz6nu/iWJXLfnlGjeTuaezzGyYRduZdO8rnV4uEAmk6Wvb5C+vkH6+3M4jotEUqwo4DSYDK0Zolfr5YJ52WvCFSFuxbipsoWPNP8Wm6s20la1iZaKNRjXcaK7iZjV0X3v4afKdC4RjEZE5K08Q/YQrnLRhU5CT6DNxrkQ9KXMYd9BoXlZv7Gpa6pLKb14QdvBKeZJXjpO5aXXaLr0OrF8L0poFFfdTu+tnyS/4QO4qfop9xe+roJbZNgZYdgZoW9kkMsDPfTk+ukbyZIt5iioIpZmYes2bsLBXm9jChNTjY4zJew4rVUb+Fh6ly+kjayvWIMull713ago6BIg6EON2CMMW8M4ykETmieo2bqmHcvrS5k5ry81zYCvKyXSdbEdB8u20YZ7qbr0GrWXXqPiyttorok0khTW3E32jj9kpOW3kMm6aU+j4BY5mevi3dwpTmRPcnKoa4xIxmCAXqVToaWojlXSEK+hOlZFlVFBVaySKqOSVclG2qo2sja1Gr3cM5ko1/vtpPTSZ+bIoogrKgHgYbmem3zIHCoJ6poxp5kwUbNPT1xTRUkphVQS6UpMy8FxbKRrkxo4TfXF16i69BqJAS+hwa5azdDND5Fffx+FVbd7Vm8KBqxB2gdPcSLbwYmBDi6Yl5AoUFBr17K+2EKFU0FNvIrGqjTNNQ2srW9ibbqZdKqGuBZf2IDfyQgLB+W/ShsB4XXodMObPUXhvc+Bck5+9w28MgHPTTAJ3qQlAFYyY6Ii7GEc10HT5iiocLPPHsFzToxt9gVicl0Xy3JwHAepFJo1QvXVN6m8/DqVF19HL2a95l7zbfTteIz8+vuxazdM2idTSnGxcIXf9L/HW5l3OTnSRb/0Ku5pUqPeqmdLcSvrWcvWmlbWNDfT0FBDQ0MtiUQ5o9ZVyOK4TCocTYd4wrPqmgGa5q0XunfNY6570Ns+B8pluXYqpXYDCCE6x6WgwCQlAFYapWIr/thTwSmglPIEpcVJxGcpKKW8Zp+dDzX7YiVBKaVwXRfXdbBttyQmlCQ1eI7aq29ScekNkld/g1Aubrya/Lp7POu0dicy4Q2VSiU9i+oMk7NHGHKGGSgMcnHwKu/lOjlrnacgigDE3TiNxUZ2qlZurtjE1vRmVjWmqa+vJZlcaCEFwvFfyJJmPDTP4uhxMAzvt5lCOEp5llX51aRQCiWl97dfqk0ttWbhuKj4Lq5NiJysBMCyx5FOqblXiihHYOgGKWNuxVauEZTf7FMIXClxLRPbdrEdu9RFiBf7qbv6FqnLx6m4fBytmOWiofNaej09N3+QTM1qBhKVDDkjDOVPkHv3FYacYYbtEYacEe9mm4Aqu4q17jpa4xvYVruFrU2baGioWyAhhcUTKsSppC8M3R/kTk5gdQzQREkwUnkikX5JAXD9n3P0ujRNK9U6LC1ro8sCgZ7QMYy5yaSsfS4hRCteMZpwCewsk5cACH93WdTQCJp6RXc030kg0DXdiyifS+dbKS9awi6MEZTS4rgKzzKZxTFiMqRJTe8JKi4fJ3XpOPHBc1w0dH5RXc+ra9ZxTF9Nj5sHFNhd0NdFQotTZVSSJEnCjVNpV1Fl1rDW1InLOAk3QU28iqbqBlbXNtLSsIr1TavnIaSg2eb3e3xrMdbyxMaJRx+1PFopBxAlVUlASiqEcFCOKglE1/XSSxOa1yIUYsxrJtjCnnNfsNwOjceVUl8Mr5imBED4c0u6hkbBKZAzcxScAkAp32nOmbCTCMoVBq5SWKaD7QyXxKQLRWW2k4pLx0ldPk6yt53LmuIfK6p4ta6ZNxq3cFV6TbfaGNxWu43/JdVKs9OEk1MUsza5/nwpIhygpqaS+voa6tfVUF9fS319DYnEbPOmfOsjXTxr4d+YSo51FOixkOUxxojH+zlGBSRdrwkY6qd7D69YvCQeoYlRi7NEZposm7iEEF8YLyx//VQlAJY8trQZKA4wYo0Q02Nza+oFTCAoVwqk0LEcsG0bhYVSoAtBMn+ViiteUy91+S163DxHU0leqW3ijU03cVl5Qqk2YtxStZkPaS00FZrQB2P0nx9iyLQY4ipCQE1NFWvWNJRElE5XE4/PVEi+eKQkaG7h12UvWZ94RUhAgeW51ntZskDSszwBgfVJGAkM3fBEExLQcqBc3sKngQeEEIGX8Ad4TcEvAUfGlwAoxzksNEophqwh+ov9CCGonOsE11KCa5UEJV0HV4KtdCzHRUqFpEjBLWIVruJefRs7046Z7SRvDTGkaZyqqOb1dc1cwov2rtJTtMU3coe7hvrhBrisYZkOCugVQ9TVVbF+fRP19bU0NNSQTtdgGDMYdFWu34QLT0SgvD6fFoN4yrNEJQEZY6xP6RuBBbLtMevHWyBd05edgKaiXA6NydL4Z1J/Y8lRdIr0FfqwpU3SSM6+HyWlZ6GsYS4NnuHo1eNcyveSc4qMOHnv5RbIOyPk7RHyyr52H7VxgkLHFVqKDWI9bcUmqgZqqMhXepHmQlBZV0n9ek9E9fW1pNPV0whJ+VbIBaS/yncgaHGvCWckphdQYIUc9xoPW8kKJRJjBKTN0cW9XIgiNKbAkQ5ZM8uQOUTciE8faR7GdcA1UcVhzvaf4p973uCXmbfoGukGoEqvoNJIUa0ENY7FanOY2mKOaimpQiNVuQZRtYlCbCNFt4bioEO+v4gqCgxloGsadXXV1K/1xo+Cpp2uTyYkea2IUIDuN+MqvXc9EJA+4TiXUgrpuiFP3MT9oJVmheZCJK4JUEoxbA3TX+wHwcybgH6khJvPcrLvJD/vOcav+t7mQvEKALdUtfLHjbv4WMGitaeDZOY3COmgNINc4210132UC8YmrhQS9PXnGL5Q8HdsUVtbRcvaNTQ21tHQUEtdXdUkQhovolBfyEh4fSEtNmqFJtjHaF/ILY35BARWyDAMry90g1ihuRCJaxyma5LJZ7CkRdJITh8Q6tgoO4890s87fe/yi543+fXA2/SYfWgIbk+t4+Hkzewe6GH9uV+iSRtX6FysuZPzq/+Qi2INV/M62Uwe1auALJWVSRoa6tiyZQONjbXU19cSu6Y4i/RCnaYTkW74lujam1/JUSsUFlBkhRaGSFw+rnTJmllyZo6YHqNysuhxf1BXWnms4T6OZ07wy8ybvDrwGwbsQQw0dhp1/LFVye6eLhrsc+RJcrb6bl6s/9dcdBvoGZI4OQk5iMddGhurWN+ymoaGWhob60ilxs+A6Hp9tjHNuZmJaLQv5CClLK0PjwcZhnFD9YWuFze0uPK2F0XRX+ynJ9+D6ZpeDpU0MV2zNDhsOSZFe4SiOUShmKNgFxm0h/mXXAc5Z4QEGu93dXYPZPnw8BCWGuRM5Z38rHIXF+1aBvIShkGMCNLpCto2p2lq8pp3Y4ui+M4Fp8hoXJzyHAtxf0Z7TR8N6wk+EQhISpTrTtiMW84u7eXKDSmuTCHDfz72n/kfnf9j0jCfyYgLnYQSpKTkA4URPjqc56ZCHVeSWzlv7OZbsUqKtoI8xOMGTU1pNm6po6kpTUNDuHknwXXB9YWk1GjOVbLae9d0ELHRyITSoKrrfdcnasaNxVUurnRxpFOKEQwT1BbRhOYNQAuBxmgo1EJxQ4nLljbff/f7/Ne3/yumY/KJtk+wqnIVFUYF1fFq4iJGHIg5DsK0iBWHqcl2Uztwlvq+Dqr7OzFVjPOsoyt5O91iPa+bSV4FKHoRDus2eEJqaqqjtrbK+49VrufswAbHpjRWpCfBqPSFNOqhK4lISpTvlg8345aLSzuYCDy4yWH0xgbQNb10gwc392z37ypPRFLJMQV5EkaCWq2WmB7D0AwUajTlRnkJoY5yxgjRlS5SyTHHcMeM8c2OG0Zcr1x+hb989S/pHOzknlX38Cd3/Al3Nd8F0qUvd5GBwYvE+s5R0dNBReY9Un3vkch1k6OKM2Ijv0newfnEg/SbXhSDZms0NtZyqy+kpiY/eFU6vpNBjVolEQy4JvxB1xgqJCKlFEiFcu2SiAzDuKYvNB8rFEToO9IBvBtbF6M390IglcTxJwMH74GQ1JPUJGqIG16cZXBjB7OjBC9LWdeMjwkhSucohPC+p0abvUIIEnqC6li11+zVDAzNmNf1lASILC3Hp8llm4wVL67Lw5f5qzf+iiPnjrC6YjX/4bf+Aw9u/G1SCuyOf8I98wvSV39DU++/oBX66KeO00YbZ+IfpjvRyJDl/UfFXJ2mpnrubE6zalU9DfVV6AJQ3o2EcsCRfrOuYkyzTkHJErmui2kNgfCq2yZiCRKxBDE9tuBNOVe6WNIqReanjBR1iTrAS9S0pIXlWmOe1sENHb6pp9q/Le2S1TCEQSqWosKoIKZ5FmPC70/igA0sh6vcUt3F4IHgSIeEniCpJzF0T0SGmGT/86B0/QtQTXHFist0Tb77znf59r98G4XiX2/713xmy6dp7j2N/P++iOo8Qmykh34aORe/hXPxPXTHaxmxARcSMkbzqjRbm9Osaqyhri7lN7/8p6tQniWKVZciuJXQx6Q64IIQjpcXpClUTJE0kqxOriYZS+JK1yuN5haxlAUShBKlG3O2BDekK/3S1FqMukQdSSNJTItN+kQPbmpHOTiugylHnTmBMIHSjRxYjrgepzpeXdr/fAvC6Jp3U8dYmrOWzJYVKa5/7v5n/vK1v+TC8AV2rd3F51Z/mFvOvo72swfoGXE4IzZyJvm7dBtpTBewoSZRwYYNjaxbVc+65gZSVQZZewRHCOLxajQj6Ucv6Cj0MdZIIEAqhHDRdZ1YLIau6UghcXAQCCpjlVTFq66p3FSd8OqQl4p6uiZF15v7KtyHCJpxYYI+je3aKKXQNZ3KWCUpI0Vcj8/4Zh9zUxtQzWht9KA/E5TC1tCIG/EpxRrhsaLEdT53nm+8/g1+fuHnbEit4j9X3cltb73F+ZF2XhAbOCcepiC8p2JdvJItGxpZv6qRdatXU1OX9mqiB805zSAlNIbNYfrMPhzXISF0NDwRGbpBPBYnZsTGOBZc5WK5FrayiWkxmhJNpIwU+jS172JabEwxz/ANXXAKFOwCprq2GmzKSFGTrCFpJCdvhs2DQKBz7XfcyJQ15QQvC3n3+EDeqbbNhbyd55nffJvvnPgOhlI8kqtn65lG3hJr+CWbQUBNZZLWNc20rFlFS0sL1ekmP5Yu5nno/BR5b6xIges151JGio3JjZjKJOd4cwFWxCvGiCUoh+bYDoYwqE3UUmlUEpvHPLxBsZq4HvcGtFOU+h62axPTY3NPxoy4LpQr5eRhvAzkl4QQrUKIzwbp/FNtmy3SdTn82t/y1ye/Sz8F2obXcsvAXSg3xYW4YsPaVbS0bGR9ywZq0g0ozUD6TStLKZSrENIu1bWIxWKehy7IYB3nXKiX9QzZQ2SLWTSpoWs6tuu5yivjlZ7XSk+UbWwp8IYljWRZ9h+xsJTLcu1mtDLvcf/vmWybFZ/7zu/zS6OLWquWB/vvYkdqFWtvv5X1bbdQV9+EMLwmnudQ8JptMV8042smzGSsSNd06hJ1VMWqyJk5TGnSlGryYhDnWPI4YuVSLnG14k3ziv9eN8NtJcI1NIBhIUTHRJ/TNLFGN7TsK86vbalKPmXle7SWXHmAaWgEMot9EgvESrmW6a5j0ulPyiWuLN4Ur+H3mWwrEa6hMRVCiDdc09k591NdOggh3lBKRdeyhJjPdZSrN/w63pxe4Fmqv5vhtoiIFUO50vyfEkI8HRp0PO5X2v2SUuqR8dvKcQ4REYtN2Vzx413svogemWjbPFlJRUWja1l6zPk6xHzK9UZERExONAIZEVEmInEtEkKILwghHvZrPI7f9lkhROdinFfEwrGsxDXNDTnptqVGKErlB0CnP6YXbGsFls2USpP97kKIHUKII0KIgeXwfwJTXkurEOJ5/3pmfC3LRlzT3JCTblui7MaLrQQvSqUt2KCU6louVYin+d13KqV2K6XSeNWXd0y8l6XBNNfSqpR6xJ8Wa6cQom4m+1w24mKKG3KabUuRGUWpLAOmekhMN43UUmOqa3kJShM3/t1MZ0NdTuKad0jVEiKLF50CU0SpLAOm/d0nmUZqKTLltfjzGzyAN7fcjKzwchJXlslvyKm2LUVWSpRKlul/92umkVqiZJniWpRSLymlnsL7v3p0JjtcTuJaMSFV/n/Sbr+dX4pgEUI8D6X2f+sy6DtO+btPNo3UEmXSawn+n3wagCMz2eGyGkT2PTVHgHql1H8bH1IV3raoJ3oDMdn/CV7T6oHQR3+w1IU2xbW8jtcHOwZ0BX2wafe3nMQVEbGcWE7NwoiIZUUkroiIMhGJKyKiTETiiogoE5G4IiLKRCSuiDH4WeIPTLD+YSHENyb6TsTErKiKuysdfzDzHqAPeBx4Gm/85Wm8iIIHFmCM79hE4zhKqR8IIeon+kLExETiWl50+Td5HV614qf82L1+P5g0GjxfQkTNwmVEqJjPTrzIbfyA2Ho/16jOzz065i9/w0+83BGsg1Ku1Wena+YFTcGJmokR0xNZruVJK15IDuAJTAiR9a1XVgjRhSfATrzo7i586+YLJVg3KX5c40shSxkxSyLLtTy5m6nF0er3m+7Gt3Chzz+O1z/rn6Z/9hLwtBBiRkGqEdcSiWt5sjNc79G3Rkf85R2MRnQHInsAL+gUoM5Pn5i2XqSfefs8nqWMmCWRuJYZvpBax/WDWoE2v/m2k9EaHFn/vZ7R5L/jM+xHfdFvGnZFhVvnRhQVHzGGqaZ0ms90TzcikeWKiCgTkbgixtM/WYQG03gYI8YSNQsjIspEZLkiIsrEsh9EPnbsWLNhGM8A24keFhELiwROOI7z2N13390z2y8ve3EZhvHM6tWrb21qahrQNC1q40YsGFJK0dvbu+3KlSvPAJ+Y7fdXwpN+e1NTUy4SVsRCo2maampqGsRrFc3++wt8PouBFgkrolz499acdLISxBURsSSJxBUxLzKZjL7Y57BUicQ1TzKZjP7EE0+sO3DgwKq9e/duPHToUDpYP9N9HDx4sPH973//zfM5h/Dft912263Tfefw4cPVNTU1dx44cGDVwYMHG4NrmM1xDx06lL7rrrumPdZ0hM9/Jue+XIjENU/+9E//dP1nPvOZga997WtXv/e9750L1s/mpvujP/qjgfmcw/hjvfPOO+9O9509e/YMtbS0mHv37h3Yv39/5lvf+tbFvXv3zuo89u3bN6/zDgif/0zOfbmw7F3xYzj8f7TQ016xoPts3pZnz//dPdnmgYEB/cUXX6zetWtXHrwb7ujRoxWDg4PGwYMHG/fv35954okn1rW1tZnHjx+v/NznPte7a9eu/MGDBxs7OzsTb7/9dsV//+//vQs8a/LGG29U7N27d2Dbtm1WeN3v/M7vDO3atSvf3t4ef/XVVyv7+vp0gPvvvz8fPtahQ4fSBw8eXB3cpOHj/OpXvzo12XUcPny4es+ePUMHDx5sfPnll2t+/OMfdwEcPXq04utf//pqgMcff7z3ueeeq9+9e3duImGNv85nn302/fOf/7xm3759vZ2dnYlvfetbF8dfT/i3amhocMPnPn5/L774YvWxY8cqH3/88d7xv9NSZGWJaxH4T//pP134N//m36xvaWnZDvAXf/EXFz/+8Y/namtrnT/6oz8aOHDgwKq2tjZz//79mfb29tz999+/7Stf+cqFhoYGd//+/RePHj1aAdDd3Z3YsmWLCfDYY49t/NWvfnXq6NGjFVu2bDEbGxvdT3/6063d3d0n/uZv/qbp3nvvzfv7izc3N7vBscAT91e+8pV14Alr/HHG8zd/8zdNbW1tZmdnZ2LPnj1D+/fvzxw/frwyk8no/+W//JfGz3/+85kvf/nLVz796U+3btmyxTxw4MDlRx55pC2dTjt79uwZCvYz0XXmcrm3hBCr77///vz999+fn+h6brnlFjM4/8bGRjc494n298orr7R/97vfbRr/O5Xz/3c+rCxxTWFhysW2bdus4Cnf3t4ev//++7ft27fvrZqaGrexsdE9duxY5ac+9amB4LMAL7zwQvqZZ545B7Br1658JpPRW1pazG3btlnb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",
      "text/plain": [
       "<Figure size 216x216 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     }
    }
   ],
   "metadata": {}
  }
 ],
 "metadata": {
  "kernelspec": {
   "name": "python3",
   "display_name": "Python 3.8.5 64-bit ('base': conda)"
  },
  "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.8.5"
  },
  "interpreter": {
   "hash": "d77f8d9122331bf0c813f643ab906d6086736a1197fa074182ffff0b1ac62f18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}