{
 "cells": [
  {
   "cell_type": "markdown",
   "source": [
    "# Comparison of Different Interpolation Methods and Their Running Times\n",
    "In this notebook, we compare the performance of different interpolation methods on the same example curve. We also compare the running times of the different methods by running it on 1000 different (synthetic) curves.\n",
    "\n",
    "To run this comparison, you will need to install the `rpy2` package, which allows us to use the `splinefun` method from R. You can install it using `pip install rpy2`. You will also need to have R installed and be set properly in the current environment on your machine.\n",
    "\n",
    "Due to the complexity of dependencies, we will not include the installation of R in this notebook. If you are interested in using the `splinefun` method, you can refer to the [rpy2 official documentation](https://rpy2.github.io/doc/latest/html/introduction.html) for installation instructions.\n",
    "\n"
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "af48427c3b559439"
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "initial_id",
   "metadata": {
    "collapsed": true,
    "ExecuteTime": {
     "end_time": "2023-08-16T06:44:17.850213246Z",
     "start_time": "2023-08-16T06:44:17.680052824Z"
    }
   },
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "outputs": [],
   "source": [
    "%matplotlib inline"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2023-08-16T06:44:18.476229700Z",
     "start_time": "2023-08-16T06:44:18.471812883Z"
    }
   },
   "id": "5f34339ea351abce"
  },
  {
   "cell_type": "markdown",
   "source": [
    "## Make one toy example for Visual Comparison"
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "e2140d8686e0693d"
  },
  {
   "cell_type": "markdown",
   "source": [],
   "metadata": {
    "collapsed": false
   },
   "id": "2cd12ad22f49574e"
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "outputs": [],
   "source": [
    "times_coordinate = np.array([0, 5, 8, 10, 25, 30, 50])\n",
    "survival_curve = np.array([1, 0.9, 0.88, 0.85, 0.7, 0.6, 0.4])"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2023-08-16T06:44:20.021453838Z",
     "start_time": "2023-08-16T06:44:20.008122726Z"
    }
   },
   "id": "b0822c005ad5b6f"
  },
  {
   "cell_type": "markdown",
   "source": [
    "Fitting different interpolation curves"
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "68286f8cc49e94fa"
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "outputs": [],
   "source": [
    "from scipy.interpolate import interp1d, CubicSpline, PchipInterpolator\n",
    "import rpy2.robjects as robjects\n",
    "\n",
    "linear = interp1d(times_coordinate, survival_curve)\n",
    "cs = CubicSpline(times_coordinate, survival_curve)\n",
    "pchip = PchipInterpolator(times_coordinate, survival_curve)\n",
    "x = robjects.FloatVector(times_coordinate)\n",
    "y = robjects.FloatVector(survival_curve)\n",
    "r_splinefun = robjects.r['splinefun']  # extract splinefun method from R\n",
    "spline_hyman = r_splinefun(x, y, method='hyman')"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2023-08-16T06:44:21.540241973Z",
     "start_time": "2023-08-16T06:44:21.272799860Z"
    }
   },
   "id": "4aab203f0b96d7"
  },
  {
   "cell_type": "markdown",
   "source": [
    "Plot the interpolated curves. We can see that the linear interpolation is not smooth, while the cubic spline is not monotonic (violating the important property of survival curve) and pchip, hyman are smooth and monotonic. The hyman and cubic are basically identical, except in the last bin."
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "bd9f7de83ab68ef4"
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 640x480 with 1 Axes>",
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAGwCAYAAABVdURTAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACQPElEQVR4nOzddVyVd//H8dd1Dt0hJaKgYCs2xuyu6VwY22znrE2dvdk62znbOdtt9pwds6azO0AsFINQJKThnPP7g3ts/FQEBQ7xeT4e53HDOdf1vT6Xt4O33+sbik6n0yGEEEIIkU+o9F2AEEIIIURWknAjhBBCiHxFwo0QQggh8hUJN0IIIYTIVyTcCCGEECJfkXAjhBBCiHxFwo0QQggh8hUDfReQ07RaLU+ePMHS0hJFUfRdjhBCCCEyQKfT8eLFCwoXLoxKlX7fTIELN0+ePMHNzU3fZQghhBDiLTx8+JAiRYqke0yBCzeWlpZAyh+OlZWVnqsRQgghREZERUXh5uaW+ns8PQUu3PzzKMrKykrCjRBCCJHHZGRIiQwoFkIIIUS+IuFGCCGEEPmKhBshhBBC5CsFbsyNEEKIrKHRaEhKStJ3GSIfMTIyeuM074yQcCOEECJTdDodwcHBRERE6LsUkc+oVCo8PDwwMjJ6p3Yk3AghhMiUf4KNo6MjZmZmsiCqyBL/LLIbFBRE0aJF3+nvlYQbIYQQGabRaFKDjb29vb7LEfmMg4MDT548ITk5GUNDw7duRwYUCyGEyLB/xtiYmZnpuRKRH/3zOEqj0bxTOxJuhBBCZJo8ihLZIav+XsljqSyi1eoIuh1BTFQC5lbGuHjZoFLJf/xCCCFETtNrz81ff/1F27ZtKVy4MIqisH379jeec/ToUapUqYKxsTGenp6sXr062+t8k7uXQlk75iTbf7jEwRW+bP/hEmvHnOTupVB9lyaEEEIUOHoNNzExMXh7e7No0aIMHR8QEEDr1q1p2LAhly9fZvDgwfTu3Zv9+/dnc6Wvd/dSKPuWXScmIiHN+zERCexbdl0CjhBC5AEZ/Qe2yBv0+liqZcuWtGzZMsPHL126FA8PD+bMmQNAmTJlOHHiBD/88APNmzfPrjJfS6vVcXzj7XSPObHpNh7eDvKISggh9Kx79+5ERES8MsQEBQVha2ub80WJbJGnBhSfOnWKJk2apHmvefPmnDp16rXnJCQkEBUVleaVVYJuR7zUY/P/RYcnEHQ7IsuuKYQQIus5OztjbGys1xp0Oh3Jycl6rSG/yFPhJjg4GCcnpzTvOTk5ERUVRVxc3CvPmTZtGtbW1qkvNze3LKsnJir9YJPZ44QQIq/R6XTEJibr5aXT6bLsPv77WOr+/fsoisK2bdto2LAhZmZmeHt7v/QP6RMnTlC3bl1MTU1xc3Pjq6++IiYmJvXzdevWUa1aNSwtLXF2dqZLly6Ehv47VOHo0aMoisLevXupWrUqxsbGnDhxIsvuqSDL97OlRo8ezdChQ1O/j4qKyrKAY26VsZSf0eOEECKviUvSUHacfsY9+k5qjplR9v0a+/bbb5k9ezZeXl58++23dO7cmTt37mBgYMDdu3dp0aIFU6ZMYeXKlTx9+pSBAwcycOBAVq1aBaSsCTR58mRKlSpFaGgoQ4cOpXv37uzZsyfNdUaNGsXs2bMpXry4PBrLInkq3Dg7OxMSEpLmvZCQEKysrDA1NX3lOcbGxtnW1ejiZYO5jfFrH03pAEvblGnhQggh8pZhw4bRunVrACZOnEi5cuW4c+cOpUuXZtq0aXz66acMHjwYAC8vL+bPn0/9+vVZsmQJJiYm9OzZM7Wt4sWLM3/+fKpXr050dDQWFhapn02aNImmTZvm6L3ld3kq3NSqVeulxHvw4EFq1aqll3pUKoW6Hb3Yt+z6S5/pdDpQQF3VTgYTCyHyLVNDNb6Tcn5Cxz/Xzk4VK1ZM/drFxQWA0NBQSpcuzZUrV7h69Sq//PJL6jE6nQ6tVktAQABlypThwoULTJgwgStXrhAeHo5WqwUgMDCQsmXLpp5XrVq1bL2Pgkiv4SY6Opo7d+6kfh8QEMDly5exs7OjaNGijB49msePH7N27VoAvvzySxYuXMiIESPo2bMnhw8fZtOmTezevVtft0CJyo606Fue4xtvp+nBMUoMZ0/pvVy/3JJi3oWo6+WgtxqFECK7KIqSrY+G9Om/exv9s3LuPwElOjqavn378tVXX710XtGiRYmJiaF58+Y0b96cX375BQcHBwIDA2nevDmJiYlpjjc3N8/GuyiY9Po38vz58zRs2DD1+3/GxnTr1o3Vq1cTFBREYGBg6uceHh7s3r2bIUOG8OOPP1KkSBF+/vlnvUwD/68SlR3x8HZImT0V8ozwsUOwDLnHNTuFm0U19Ftvyaa+tShb2EqvdQohhMgaVapUwdfXF09Pz1d+fu3aNcLCwpg+fXrqOM/z58/nZIkFml7DTYMGDdId7f6q1YcbNGjApUuXsrGqt6NSKbiWsoVStoRVgdC9Ot4/reNYhfPERFamx2o1v/evQ2GbV48NEkIIkf0iIyO5fPlymvfeZnfzkSNHUrNmTQYOHEjv3r0xNzfH19eXgwcPsnDhQooWLYqRkRELFizgyy+/5Pr160yePDmL7kK8SZ6aCp5X2PT/DpWhliJhUO2WDssi2wl58YLuq84SGZek7/KEEKLAOnr0KJUrV07zmjhxYqbbqVixIseOHePWrVvUrVuXypUrM27cOAoXLgyAg4MDq1evZvPmzZQtW5bp06cze/bsrL4d8RqKLisXCsgDoqKisLa2JjIyEiur7HtMFNqzNmEnw3ngomJ4NwWDmLqEP2xDzeJ2rOlZA2OD7B0IJ4QQ2SE+Pp6AgAA8PDwwMTHRdzkin0nv71dmfn9Lz002ses/DEWtpViQlgr3dSRbnMDCOoDT954zfPNVtNoClSmFEEKIHCPhJpsYVP0Am/IpqbPvuZRxNvYe2zFQJ7LjyhNm7vfXZ3lCCCFEviXhJrsoCva9+oCiw/FuDLXD7HmeEMJ7PqcBWHrsLutO3ddvjUIIIUQ+JOEmGxk26oO1V8rjp4F/pbx3IXwPn9SNBWD8jhsc9A153elCCCGEeAsSbrKTgTEOvbuiqHQY3AzhK019AC7GLuPDavZodTDot4tcCgzXc6FCCCFE/iHhJpsZthiMTemUFS0bbfXFzaIIIbEhGDj8ToNSDsQnaem15jz3n8W8oSUhhBBCZISEm+xmZE6hPr1Q1FoS7wYxnQ9QK2r23N9D29rBlHe14nlMIt1WnSUs+tUbcAohhBAi4yTc5ACDxgOxK5cy9sZi6Xr6VugDwKwL3zP148IUsTXlQVgsvdacJy5Ro89ShRBCiDxPwk1OMDLHvk8fVIZaEh4+5RM/ayo7ViYmKYZZF8ezolsVrE0Nufwwgq82XEIja+AIIUSBcfToURRFISIi4rXHrF69GhsbmxyrCV6uSx81vC0JNzlEXX8ADlVTvg77YS7fV/oWC0MLrjy9wqHgX/m5WzWMDFQc9A1hwo4b6e65JYQQInO6d++OoigoioKRkRGenp5MmjSJ5OTkd2o3ODiYQYMGUbx4cYyNjXFzc6Nt27YcOnQoiypP0bFjR27dupXh4wMCAujSpQuFCxfGxMSEIkWK0K5dO27evJljNeiThJucYmSGbf9RGFkloXkRh+GKDYytORaAZVeXYWD2gHkdK6EosO70A5b9dU/PBQshRP7SokULgoKCuH37Nt988w0TJkxg1qxZb93e/fv3qVq1KocPH2bWrFlcu3aNffv20bBhQwYMGJCFlYOpqSmOjo4ZOjYpKYmmTZsSGRnJtm3b8Pf3Z+PGjVSoUCHd3qGsrEHfJNzkIKVaV5wa2ALw/NeNNFbK0KZ4G7Q6LSP/GkltL1O+a10WgOl7b/LH5cf6LFcIIfIVY2NjnJ2dKVasGP369aNJkybs2LGDmJgYrKys2LJlS5rjt2/fjrm5OS9evHhle/3790dRFM6ePcuHH35IyZIlKVeuHEOHDuX06ZQFW+/fv4+iKGl2Io+IiEBRFI4ePZqmvb///puKFStiYmJCzZo1uX79eupnr3oktHPnTqpXr46JiQmFChXigw8+AODGjRvcvXuXxYsXU7NmTYoVK0adOnWYMmUKNWvWTFPXhg0bqF27NiYmJpQvX55jx4699s/v/9cwYcIEKlWqxLp163B3d8fa2ppOnTql+fPSarVMmzYNDw8PTE1N8fb2funPOTtIuMlJKjUWX0zH3CUetDpCJnzHmBpjKGpZlKCYIMacGEOPOsXoWccDgGGbr3DqbpieixZCiHTodJAYo5/XOz6+NzU1JTExEXNzczp16sSqVavSfL5q1So++ugjLC0tXzr3+fPn7Nu3jwEDBmBubv7S528zNmX48OHMmTOHc+fO4eDgQNu2bUlKSnrlsbt37+aDDz6gVatWXLp0iUOHDlGjRg0gZUdylUrFli1b0GjSn6QyfPhwvvnmGy5dukStWrVo27YtYWEZ/71z9+5dtm/fzq5du9i1axfHjh1j+vTpqZ9PmzaNtWvXsnTpUm7cuMGQIUP47LPP0g1RWcEgW1sXL/NsjFO7sgT8dJeYMxexPnCMOQ3m8OnuTzn++Dgrr6/ku9a9CI6KY8+1YL5Yd56t/WpT0unl/7iEEELvkmLh+8L6ufaYJ2D0crB4E51Ox6FDh9i/fz+DBg0CoHfv3tSuXZugoCBcXFwIDQ1lz549/Pnnn69s486dO+h0OkqXLv1Ot/Bf48ePp2nTpgCsWbOGIkWK8Pvvv/PJJ5+8dOzUqVPp1KkTEydOTH3P29sbAFdXV+bPn8+IESOYOHEi1apVo2HDhnz66acUL148TTsDBw7kww8/BGDJkiXs27ePFStWMGLEiAzVrNVqWb16dWoA/Pzzzzl06BBTp04lISGB77//nj///JNatWoBULx4cU6cOMGyZcuoX79+Jv+EMk56bvTAuMtsCpVPWbQvZPIEPBUnxviMAWDBpQVcCD3P3E8qUa2YLS/ik+m+8izBkfH6LFkIIfK8Xbt2YWFhgYmJCS1btqRjx45MmDABgBo1alCuXDnWrFkDwPr16ylWrBj16tV7ZVvZMenjnwAAYGdnR6lSpfDz83vlsZcvX6Zx48avbWvAgAEEBwfzyy+/UKtWLTZv3ky5cuU4ePDga69pYGBAtWrVXnvNV3F3d0/Ts/VPMISUABgbG0vTpk2xsLBIfa1du5a7d+9m+BpvQ3pu9MGxDPY9exA1/lcSImMI/X4KHWbO5mLoRXbc3cHwY8PZ3HYzy7tW48OlJ7n3NIbuq86y+ctaWJoY6rt6IYT4l6FZSg+Kvq6dCQ0bNmTJkiUYGRlRuHBhDAzS/grs3bs3ixYtYtSoUaxatYoePXqgKMor2/Ly8kJRlDfOPlKpUvoQ/huGXveoKTNMTU3feIylpSVt27albdu2TJkyhebNmzNlypTU3qGsYGiY9neSoihotSmr8kdHRwMpj9BcXV3THGdsbJxlNbyK9NzoidJoFC6NTAEdkTv3EHPiBN/6fIunjSdh8WEM/2s4FqYKa3rUoJCFMTeDX9Bv/UUSk7X6Ll0IIf6lKCmPhvTxek3weB1zc3M8PT0pWrToS8EG4LPPPuPBgwfMnz8fX19funXr9tq27OzsaN68OYsWLSIm5uXtc/6ZleTg4ABAUFBQ6mf/HVz8X/8MQgYIDw/n1q1blClT5pXHVqxYMVPTzRVFoXTp0i/V+t9rJicnc+HChddeM7PKli2LsbExgYGBeHp6pnm5ubllyTVeR8KNvhiZYdrrB2xLpvxFezJyOEbRCcxtMBczAzMuhFxgxtkZuNmZsbJ7NcyM1Jy484xR267KGjhCCJENbG1t6dChA8OHD6dZs2YUKVIk3eMXLVqERqOhRo0abN26ldu3b+Pn58f8+fNTH/eYmppSs2ZNpk+fjp+fH8eOHeO77757ZXuTJk3i0KFDXL9+ne7du1OoUCHat2//ymPHjx/Pb7/9xvjx4/Hz8+PatWvMmDEDSAlP7dq1Y8uWLfj6+nLnzh1WrFjBypUradeu3Uv38Pvvv3Pz5k0GDBhAeHg4PXv2zOSf3KtZWloybNgwhgwZwpo1a7h79y4XL15kwYIFqY//souEG33ybIJjp8Ypa988jyRozGjcrdyZXnc6Cgob/TeyyX8TFYvYsKhLFdQqhW0XH/PDwbyxiJIQQuQ1vXr1IjExMUO/4IsXL87Fixdp2LAh33zzDeXLl6dp06YcOnSIJUuWpB63cuVKkpOTqVq1KoMHD2bKlCmvbG/69Ol8/fXXVK1aleDgYHbu3ImRkdErj23QoAGbN29mx44dVKpUiUaNGnH27FkAihQpgru7OxMnTsTHx4cqVarw448/MnHiRL799tuXrjl9+nS8vb05ceIEO3bsoFChQhn943qjyZMnM3bsWKZNm0aZMmVo0aIFu3fvxsPDI8uu8SqKroB1A0RFRWFtbU1kZCRWVlb6LgdinxM/pTYB2wGtgvOkidh+8gnLry5n/qX5GCgGLG+2nGrO1dhwNpBR264BMK1DBTrXKKrX0oUQBU98fDwBAQF4eHhgYmKi73Ky3Lp16xgyZAhPnjx5bbDID+7fv4+HhweXLl2iUqVK+i4nVXp/vzLz+1t6bvTNzA6TXotxrBgFQMjUqcTfukXvCr1p4d6CZF0yQ48O5XH0YzrVKMpXjTwB+G77dY7cDNVn5UIIkW/ExsZy9+5dpk+fTt++ffN1sCkIJNzkBiUaYde1K+ZO8egSEnk0oD/aFy+YVGcSZezKEJ4QzqDDg4hOjGZI05J8WKUIGq2OAb9e5NqjSH1XL4QQed7MmTMpXbo0zs7OjB49Wt/liHck4SaXUJpOoPD7ThiaJZP08DGPvxmGicqY+Y3mY29iz+3w2ww5OoRkbTLTOlSgrlchYhM19Fh9jofPY/VdvhBC5GkTJkwgKSmJQ4cOYWFhoe9ysp27uzs6nS5XPZLKShJucgtDEwy6/4Jr4yQUtY6Y48d5umABzubOLGqyCFMDU04HnWb8yfEYqhUWf1qFMi5WPItOoNuqs4THJOr7DoQQQohcQcJNbmJfAtMvluNcLeVRU9iSpURs2UI5+3LMqT8HtaJm572dLLi0AEsTQ1Z1r05haxPuPY2hz9rzxCelv4eIEEIIURBIuMltvJpi02so9mVTdlUNGjee6GPHqFukLuNrjQdg+bXlbLi5AWdrE1b3rIGliQHnH4QzZONltNoCNflNCCGEeImEm9zovW9w+LQV1u6xoNXy6OuviLt8mQ+8PqC/d38App6Zyh93/qCkkyU/fV4NI7WKvdeDmbI743uCCCGEEPmRhJvcSKVCab8Il87VMHeORxefSGCvXsRdvsyX3l/yWZnPABh3chz7AvZRq4Q9sz6uCMDKvwP4+fg9fVYvhBBC6JWEm9xKbYjSeS1FPi6GmUMC2phYAnv2JP7KFUZUH8GHXh+i1WkZfXw0hwMP066SK6NalgZg6h4/9lwLesMFhBBCiPxJwk1uZmSOqsc23DoWSQk4sXEE9uxB7OnTjK05ltbFW5OsS2bYsWEcCjxE33rF6VqrGDodDN54mXP3n+v7DoQQQrxGgwYNGDx4cLrHKIrC9u3bc6Se/ETCTW5nZoeq907cuhTHzDEBbWw8gX36EL1zF1PqTKFpsaYkaZP45ug37AnYw/i25Wha1onEZC2915znTmi0vu9ACCH0rnv37iiKgqIoGBkZ4enpyaRJk0hOTs5Vbf5/QUFBtGzZMsvaKygk3OQFJtaoem7HrVsZLN3iIFnDk5GjCF/yEzPem07b4m3R6DSMPj6a3+9sZX6nylRysyEyLonuq84S+iJe33cghBB616JFC4KCgrh9+zbffPMNEyZMYNasWbmuzf9ydnbG2Ng4y9orKCTc5BXGFqi6/Y5rv1bYlU7pjXm2YAHBAwcxscJwOpbqiA4dE09NZOOtdfzctSru9mY8Co+j5+pzxCRk3b8khBAiLzI2NsbZ2ZlixYrRr18/mjRpwo4dO4iJicHKyootW7akOX779u2Ym5vz4sWLTLf5j7///psGDRpgZmaGra0tzZs3Jzw8PPVzrVbLiBEjsLOzw9nZmQkTJqRp/7+Ppe7fv4+iKGzYsIHatWtjYmJC+fLlOXbs2Lv/4eQzEm7yEgMjlA8W4TRiBC7VI1BUOqKP/sWDD9oz1Ox9epTvAcCcC3NYcn0WK7pVwc7ciOuPoxjw60WSNVo934AQIr/R6XTEJsXq5aXTvdu6XqampiQmJmJubk6nTp1YtWpVms9XrVrFRx99hKWlZabbBLh8+TKNGzembNmynDp1ihMnTtC2bVs0mn8XXF2zZg3m5uacOXOGmTNnMmnSJA4ePJjuNYYPH84333zDpUuXqFWrFm3btiUsLCwTd57/Gei7AJFJigK1B2HjVA7j5V/y+KCOpKBQHnTqxGd9elOo4RBmX5nHplubeBz9mIWffkfPVdc46v+U77ZfZ1qHCiiKou+7EELkE3HJcfj86qOXa5/pcgYzQ7NMn6fT6Th06BD79+9n0KBBAPTu3ZvatWsTFBSEi4sLoaGh7Nmzhz///POt25w5cybVqlVj8eLFqceVK1cuzXkVK1Zk/PiUBVq9vLxYuHAhhw4domnTpq+91sCBA/nwww8BWLJkCfv27WPFihWMGDEi438I+Zz03ORVJRphOvYkHv0qYlU0DrQ6wpYt570xG1joOAgTtQl/P/mbmVcHMra9AyoFNpx7yMLDd/RduRBC6MWuXbuwsLDAxMSEli1b0rFjx9THQDVq1KBcuXKsWbMGgPXr11OsWDHq1av31m3+03OTnooVK6b5/p9glZ5atWqlfm1gYEC1atXw85MFXP9Lem7yMvNCqHttwbXKeix/mkDwKTUJ9x7iMGQuaxpU5duqgdyJvMv8mAF0bjiIXw7bMufgLZytTfi4mpu+qxdC5AOmBqac6XJGb9fOjIYNG7JkyRKMjIwoXLgwBgZpfwX27t2bRYsWMWrUKFatWkWPHj3e2NOdXpumpm+uz9DQMM33iqKg1coQgnclPTd5naJAlc+xmnOW4sPrY1M8BtChHL3A9/PDGHLaDnVUDDuCZlCtyjFQkhi97Rp/3XqKVqvjsX84t84F89g/XPalEkJkmqIomBma6eWV2Ufs5ubmeHp6UrRo0ZeCDcBnn33GgwcPmD9/Pr6+vnTr1u2d2qxYsSKHDh3KVI0Zcfr06dSvk5OTuXDhAmXKlMny6+Rl0nOTX5jbY/DZclwaX8XmlzGEbPcl7pkxtY6EUv2Ewu4qsKf6HpxKX+FpwAfMWmHALZ0pCVFJ/zZhY0zdjl6UqOyoxxsRQgj9sLW1pUOHDgwfPpxmzZpRpEiRd2pv9OjRVKhQgf79+/Pll19iZGTEkSNH+PjjjylUqNBbt7to0SK8vLwoU6YMP/zwA+Hh4fTs2fOdas1v9N5zs2jRItzd3TExMcHHx4ezZ8++9tikpCQmTZpEiRIlMDExwdvbm3379uVgtXmAS0VMh+2i2Pr1FOnojoltIgZJOtqd0bF4sYYvtj+kRcJxmkeqiY9KTHNqTEQC+5Zd5+6l9J/3CiFEftWrVy8SExOzJCyULFmSAwcOcOXKFWrUqEGtWrX4448/XtlrlBnTp09n+vTpeHt7c+LECXbs2PFOYSk/UnTvOpfuHWzcuJGuXbuydOlSfHx8mDdvHps3b8bf3x9Hx5d7D0aOHMn69etZvnw5pUuXZv/+/QwdOpSTJ09SuXLlDF0zKioKa2trIiMjsbKyyupbynV0oTeJWTWRZ7vPExdqgA6FkzUnk2Bsk/JI6xUsbI35fGptVCqZVSWESCs+Pp6AgAA8PDwwMTHRdzlZbt26dQwZMoQnT55gZGSk73LSuH//Ph4eHly6dIlKlSrpu5xskd7fr8z8/tZrz83cuXPp06cPPXr0oGzZsixduhQzMzNWrlz5yuPXrVvHmDFjaNWqFcWLF6dfv360atWKOXPmvPYaCQkJREVFpXkVJIpjaSxG/ob7wYt4TO9NcpUKJJjYvjbYAESHJxB0OyLnihRCCD2LjY3l7t27TJ8+nb59++a6YCMyR2/hJjExkQsXLtCkSZN/i1GpaNKkCadOnXrlOQkJCS8lOVNTU06cOPHa60ybNg1ra+vUl5tbAZ0lZGyJSftvMBnyY4YOD9uzEV34o2wuSgghcoeZM2dSunRpnJ2dGT16tL7LEe9Ib+Hm2bNnaDQanJyc0rzv5OREcHDwK89p3rw5c+fO5fbt22i1Wg4ePMi2bdsICgp67XVGjx5NZGRk6uvhw4dZeh95jblVxvYoid64B/96jXnYpiIRU7qSfGk3aJLefKIQQuRBEyZMICkpiUOHDmFhYaHvcl7J3d0dnU6Xbx9JZaU8NVvqxx9/pE+fPpQuXRpFUShRogQ9evR47WMsSNn3QzYd+5eLlw3mNsbERCS88nMdOhRNOKqEO+iSVETfSSL6zjlYfxYTBy2WFd2xaN4G4yafo5jZ5nD1QgghxJvpreemUKFCqNVqQkJC0rwfEhKCs7PzK89xcHBg+/btxMTE8ODBA27evImFhQXFixfPiZLzBZVKoW5Hr9d+rqBg8b4B40eU4tuuarbWVghwSvkk/qmap4ceEjBiCXfq+BDUuRYxv0xDF1ewxjEJIYTI3fQWboyMjKhatWqaBY60Wi2HDh1Ks7T0q5iYmODq6kpycjJbt26lXbt22V1uvlKisiMt+pbH3CZtj5aFrTEt+panW9v27O/8O3MG7MSgz5d836cYXw5Qs6yFinNeCvGGkBynJuJSBIGT13KnTnVC+zQh4a8toL/Jd0IIIQSQC6aCd+vWjWXLllGjRg3mzZvHpk2buHnzJk5OTnTt2hVXV1emTZsGwJkzZ3j8+DGVKlXi8ePHTJgwgYCAAC5evIiNjU2GrlnQpoKnR6vVEXQ7gpioBMytjHHxsnnl9G+dTof/81usuryDY48Pk5j0kLIPdNT011Hzpg7z/zzhMnMzxK7jB1h8NgLFxDzT1xJC5G75fSq40K+smgqu1zE3HTt25OnTp4wbN47g4GAqVarEvn37UgcZBwYGolL927kUHx/Pd999x71797CwsKBVq1asW7cuw8FGpKVSKbiWevO4GUVRKG1fihmNhwPDuRZyh6Xnf2eV+1FWNntAlTs66l3XUfWOjtiHScTO3oTy0yacO7fEut8U7vlFc3zj7TTjfGQ1ZCGEENlFrz03+iA9N1nreMAtfrqwnSvPj2MfH0DzC1oaX9FhEZ/y+WN3b/zd+wCv7qVp0be8BBwh8hDpuRHZKV/03Ii8r65HSep6jCBJM4ztV31Za72bLZWP0/xmAG3P6Ljv/DHoeF224cSm23h4O8gjKiFErtSgQQMqVarEvHnz9F2KyAS97y0l8gdDtYqPK5dnZ7eR7O21FceO6/nxo66yGrIQIlfo3r07iqKgKAqGhoZ4eHgwYsQI4uPj9V2ayAbScyOynIOlMV83rExLcxcOrvR94/ExUa9ec0cIIbJSixYtWLVqFUlJSVy4cIFu3bqhKAozZszQd2kii0nPjcg25tYZWzwxo6smCyHEuzA2NsbZ2Rk3Nzfat29PkyZNOHjw4BvP02q1jBgxAjs7O5ydnZkwYULqZz179qRNmzZpjk9KSsLR0ZEVK1YAKY+2Bg0axODBg7G1tcXJyYnly5cTExNDjx49sLS0xNPTk71796a2odFo6NWrFx4eHpiamlKqVCl+/DHt9jndu3enffv2zJ49GxcXF+zt7RkwYABJSbKavIQbkW3+WQ35tXQ6FG04Rg6xOVeUECJL6XQ6tLGxenm9y3yY69evc/LkyQxtkLlmzRrMzc05c+YMM2fOZNKkSamhqHfv3uzbty/NNkC7du0iNjaWjh07pmmjUKFCnD17lkGDBtGvXz8+/vhjateuzcWLF2nWrBmff/45sbEpPw+1Wi1FihRh8+bN+Pr6Mm7cOMaMGcOmTZvS1HbkyBHu3r3LkSNHWLNmDatXr2b16tVv/eeSX8hsKZGt7l4KZd+y6y9/8L+/duVvLCfK5Crl5i+ieNmGOVydECKz/v9sFm1sLP5VquqlllIXL6AyM8vQsd27d2f9+vWYmJiQnJxMQkICKpWKTZs28eGHH772vAYNGqDRaDh+/HjqezVq1KBRo0ZMnz4dgHLlytGtWzdGjBgBwPvvv4+9vT2rVq16ZRsajQZra2s6dOjA2rVrAQgODsbFxYVTp05Rs2bNV9YycOBAgoOD2bJlS+o9HT16lLt376JWqwH45JNPUKlUbNiwIUN/LrlNVs2Wkp4bka1etxqyma0JKtPjWEZdwfORjsc9+nP9yGr9FCmEKBAaNmzI5cuXOXPmDN26daNHjx7pBpt/VKxYMc33Li4uhIaGpn7fu3fv1CATEhLC3r176dmz52vbUKvV2NvbU6FChdT3/lnf7b/tLlq0iKpVq+Lg4ICFhQU//fQTgYGBadotV65carB5VW0FlQwoFtmuRGVHPLwdXlqhWKOrxeJFhajy6yIKRUDM4BmcHhFAzU8n6rtkIUQGKaamlLp4QW/Xzgxzc3M8PT0BWLlyJd7e3qxYsYJevXqle56hoWHa6yoKWq029fuuXbsyatQoTp06xcmTJ/Hw8KBu3bpvbOO/7yn/m1X6T7sbNmxg2LBhzJkzh1q1amFpacmsWbM4c+ZMpmorqCTciBzxqtWQVSh8NWgAa92KEzt/GEWDdCRP3cTRRw9oMHK1fgoVQmSKoigoGXw0lJuoVCrGjBnD0KFD6dKlC6aZDEr/ZW9vT/v27Vm1ahWnTp2iR48e71zf33//Te3atenfv3/qe3fv3n3ndgsKeSwl9EpRFLp90Ard9E34eqox0ILTqjMc+qolOvnXhxAiG3388ceo1WoWLVr0zm317t2bNWvW4OfnR7du3d65PS8vL86fP8/+/fu5desWY8eO5dy5c+/cbkEh4UbkCi18yuO18BCnKqf866nwgfsc/rwOuqREPVcmhMivDAwMGDhwIDNnziQmJuad2mrSpAkuLi40b96cwoULv3Ntffv2pUOHDnTs2BEfHx/CwsLS9OKI9MlsKZGrBEXEsXFkM5oee4YKCPY0pt4vh1Bb2+u7NCEEsrfU60RHR+Pq6sqqVavo0KGDvsvJs2S2lMiXXGxM6f3jYXa0LU6iGpzvJHCyXT0SH93Rd2lCCPESrVZLaGgokydPxsbGhvfff1/fJQkk3IhcyMLEkBEzdrH70+pEm0ChYC0XP2pL5JUTaLU6HvuHc+tcMI/9w9FqC1THoxAilwkMDMTJyYlff/2VlStXYmAg83RyA/l/QeRKapXCmDFrmVNoBNV/3olDBJwdupCHFeKIi/93TQdzG2PqdvSiRGVH/RUrhCiw3N3d32mlZJE9pOdG5GrffDGTm2O+4EYJb2559iEuLu1f2ZiIBPYtu87dS7JolRBCiBQSbkSu1/v9wTwt9b9Ftv630NX/d2LTbXlEJYQQApBwI/KAoNsRaGPVrw02ANHhCQTdjsi5ooQQQuRaEm5ErhcTlZClxwkhhMjfJNyIXM/cyvjNBwFXnr6QgX1CCCEk3Ijcz8XL5qVdxdPQ6VAnPWfh1W/4YNlerjyMyLHahBBC5D4SbkSup1Ip1O3o9ZpPU3pqyvhv4fsttzF4OoYP189nyIZLBEXG5VyRQgghcg0JNyJPKFHZkRZ9y7/Ug2Nha0LjZmoctVexi4bxvyXQNmQj+55NpuEP25n35y3iEjV6qloI8Tr6WJCze/fuKbuYKwqGhoY4OTnRtGlTVq5ciTYTG/WuXr0aGxub7CtUvDNZxE/kGSUqO+Lh7UDQ7QhiohIwtzLGxcsGlUpB0/AwT3p3INo3nC/2aSnhfZMVjWez6Hwbfjtbl1EtS9PO2xWV6vUzroQQOePupVCOb7xNTMS/kwByakHOFi1asGrVKjQaDSEhIezbt4+vv/6aLVu2sGPHDllhOJ+QnhuRp6hUCq6lbClZ3RnXUrapYUVt50yRLSdw6FADFB2Nr+iY8kss7sZbibJexNBth/hg8d9cePBcz3cgRMF291Io+5ZdTxNsIOcW5DQ2NsbZ2RlXV1eqVKnCmDFj+OOPP9i7dy+rV68GYO7cuVSoUAFzc3Pc3Nzo378/0dHRABw9epQePXoQGRmZ2gs0YcIEANatW0e1atWwtLTE2dmZLl26EBoqC4zqg4QbkW8oKhWFvl+D26RBqIx1FA+BGas0NLx/C/Pi8/CL38qHS48z8NeLPAqP1Xe5QhQ4Wq2O4xtvp3uMPhbkbNSoEd7e3mzbtg0AlUrF/PnzuXHjBmvWrOHw4cOMGDECgNq1azNv3jysrKwICgoiKCiIYcOGAZCUlMTkyZO5cuUK27dv5/79+3Tv3j1H70WkkP43ke9YfDyA4t61eTKgBzxMYNBOLRXuJ7Ci2UHirC6z984HHJgTQu/3POjf0BMLY/nPQIicEHQ74qUem//vnwU5XUvZ5lBVKUqXLs3Vq1cBGDx4cOr77u7uTJkyhS+//JLFixdjZGSEtbU1iqLg7Oycpo2ePXumfl28eHHmz59P9erViY6OxsLCIkfuQ6SQnhuRLxmWrEzR3Wco1KYiKDoaXNMxe5WGEuFPMSu2HJXDbyw5foUGs46y8VwgGtm6QYhsl5sX5NTpdCj/WwX9zz//pHHjxri6umJpacnnn39OWFgYsbHp9/heuHCBtm3bUrRoUSwtLalfvz6QsnO4yFkSbkS+pRgZ4zB7I8VmDMPAXIfTc5i2JpmPj2sxsbyIpedcIg2PMHLrZdouOMGpu2H6LlmIfC2jC3Jm9Lis5Ofnh4eHB/fv36dNmzZUrFiRrVu3cuHCBRYtWgRAYmLia8+PiYmhefPmWFlZ8csvv3Du3Dl+//33N54nsoeEG5Hvmb3fG48du7EsY41Kq/DxCS1z1mgpEhaDifMOLEsswD/yIp2Xn+aLtee5/yxG3yULkS+9cUFOwMI2ZRZkTjp8+DDXrl3jww8/5MKFC2i1WubMmUPNmjUpWbIkT548SXO8kZERGk3aJSZu3rxJWFgY06dPp27dupQuXVoGE+uRhBtRIBi4lsB160kKD2yH2khH4RAds1Ym0+mUCpVBEGbFfsa0yHoO3vaj6Q/HmLrbl8i4JH2XLUS+kv6CnCne+8QrW5dsSEhIIDg4mMePH3Px4kW+//572rVrR5s2bejatSuenp4kJSWxYMEC7t27x7p161i6dGmaNtzd3YmOjubQoUM8e/aM2NhYihYtipGRUep5O3bsYPLkydl2HyJ9Em5EgaGoVFgPnE7x3zdg4WmGSqvQ4WgiS9aAZzAYWF7HssRcFLv9LD/hT8PZR1l3+gHJmowv7iWESN/rF+Q0pkXf8tm+zs2+fftwcXHB3d2dFi1acOTIEebPn88ff/yBWq3G29ubuXPnMmPGDMqXL88vv/zCtGnT0rRRu3ZtvvzySzp27IiDgwMzZ87EwcGB1atXs3nzZsqWLcv06dOZPXt2tt6LeD1FV8B2GoyKisLa2prIyEisrKz0XY7QE51GQ+SPwwhZvQdtogoUHRd8LPmxdhzxxgoqrTUxwU1IjqxKSScrvm1dlvolHfRdthB6Fx8fT0BAAB4eHpiYmLx1O1qt7pULcoqCLb2/X5n5/S3hRhRoyXcuEjKyH1E3olK+t1BY09aK/e7/G3eT6ExscEs0MSVpWMqRb1uXxdNRpnSKgiurwo0Qr5JV4UYeS4kCzcCzCq5bTuP2XTcMLXUYROvo9VskP20xxjPSFIyCMSu6CrOiP3PswSWaz/uLCTtuEB4jsx+EECK3knAjhKJg8dkoih84in3j4qDSYXM7hu+XRDHjhD3WiQaoze9i7rEQQ+ffWHPuIg1mH2XFiQASk2U8jhBC5DYSboT4H5WtM46LdlP85xlYeBiCTsHjeAg/L4pnyO0iKFodhtaXsSgxl3irbUzZe4YW8/7iT98QCtjTXSGEyNUk3Ajx/xjXbofb7ku4jfwYIxsdunioteU+G1aq6RxSFEjCyO5vLDxn8UjZSu/1f/HZijP4BUXpu3QhcowEepEdsurvlYQbIV5FpcaixySKH/wbpw4VURlqUZ4m8sHKe/z6mwmtIoqAKhHjQkex8JzJuYiNtF54kNHbrvEsOueXjhcipxgaGgK8cSsCId7GP6s5q9Xqd2pHZksJkQGaexcJmzKY52dC0WlSpqsmlLFleTNr/jJ7BIAu2YzEsPoYx77HgIbl6FHHHWODd/sPVIjcKCgoiIiICBwdHTEzM0vdk0mId6HVanny5AmGhoYULVr0pb9XeWoq+KJFi5g1axbBwcF4e3uzYMECatSo8drj582bx5IlSwgMDKRQoUJ89NFHTJs2LcNTEiXciHeRdGEPz2aOJ+LqC9ApgI6Yys4sq2/EadMgALTJFiQ+a4Cz0oAxLSvSoryz/PAX+YpOpyM4OJiIiAh9lyLyGZVKhYeHB0ZGRi99lmfCzcaNG+natStLly7Fx8eHefPmsXnzZvz9/XF0fHmVyl9//ZWePXuycuVKateuza1bt+jevTudOnVi7ty5GbqmhBvxznQ6Eo+u5+ncWUTd/neLhhcVHVhaV805q2cAaJMtSQyrh7d1C8a3rkyFItb6qliIbKHRaEhKkm1KRNYxMjJCpXr1iJk8E258fHyoXr06CxcuBFK6pNzc3Bg0aBCjRo166fiBAwfi5+fHoUOHUt/75ptvOHPmDCdOnHjlNRISEkhI+HcMRFRUFG5ubhJuxLvTaojfuYBny37ixT0tkNI7E1XOjp/eU3PWLjzlsGRzkp7XpVWxDxndohJOVrLwmRBCZFaeWMQvMTGRCxcu0KRJk3+LUalo0qQJp06deuU5tWvX5sKFC5w9exaAe/fusWfPHlq1avXa60ybNg1ra+vUl5ubW9beiCi4VGpM2g2myM4rFJ/ZFyvPlG0crG48Z9iyp6zcakn9J7ao1NEYO+7jzxdf02jFt8w+eJn4JM2b2xdCCPFWMh1u6tevz9q1a4mLi3unCz979gyNRoOTk1Oa952cnAgODn7lOV26dGHSpEm89957GBoaUqJECRo0aMCYMWNee53Ro0cTGRmZ+nr48OE71S3ES9SGGL8/BNc/rlB8zkCsS6lB0WFxK5wBa56ybq0xbf2tMVBiUNkdYPXDPtRZNoLfzt+U6bRCCJENMh1uKleuzLBhw3B2dqZPnz6cPn06O+p6paNHj/L999+zePFiLl68yLZt29i9e3e628obGxtjZWWV5iVEtlAbYNxqIIW3XabEgiHYVjREUWsxfhLL59vCWLdURZdz5pglxZFoeYCpVz+l3s/DOXrnnr4rF0KIfOWtxtwkJyezY8cO1qxZw969e/H09KRnz558/vnnL/XEvE5iYiJmZmZs2bKF9u3bp77frVs3IiIi+OOPP146p27dutSsWZNZs2alvrd+/Xq++OILoqOjXzsI6b9kQLHIMVotmvNbCF8+l+fnnqOJT5kWrjVSOFrJjG1V4gm1VdBpDXEzqM/UxoOoUri4nosWQojcKdvH3BgYGNChQwf++OMPHj16RJcuXRg7dixubm60b9+ew4cPv7ENIyMjqlatmmZwsFar5dChQ9SqVeuV58TGxr4UYP5Z6Ee690Wuo1KhrvEJhZafxnPLClzeL4qRVRKqRB2NzsawYKmGsZvVVLqfwGPNQboe+ID2mwZyPdRf35ULIUSeZvAuJ589e5ZVq1axYcMGHB0d6d69O48fP6ZNmzb079+f2bNnp3v+0KFD6datG9WqVaNGjRrMmzePmJgYevToAUDXrl1xdXVl2rRpALRt25a5c+dSuXJlfHx8uHPnDmPHjqVt27bvvJqhENlJ5VkXm5n7sQ65SczqiTzfd5aYICMq3Emgwh14aqtmV9VkjlY4Sue9xyhlWYux7w3E27GivksXQog8J9OPpUJDQ1m3bh2rVq3i9u3btG3blt69e9O8efPUhcpOnDhBixYtiI6OfmN7CxcuTF3Er1KlSsyfPx8fHx8AGjRogLu7O6tXrwZSHodNnTqVdevW8fjxYxwcHGjbti1Tp07FxsYmQ/XLYymRK7wIIWHXXMI3/07kbQVtUkqPZKIhHCmvsL+qikcOCqVtqjC0+pfUdKkpCwEKIQq0bF3nxsjIiBIlStCzZ0+6d++Og4PDKwto164dR44cyVzlOUDCjchVkhPQnN9A1LpFhJ9/TkKkYepHN4oq7K+icK6kQnG7svSv/AWNijZCpciWcEKIgidbw83x48epW7fuOxWoTxJuRK6k06F7eI7YDTMJP3iBF4+M/7e9A4RbwJ/eCocqqbB09aB3xV60Lt4aQ5XhGxoVQoj8I1vDTaNGjdi2bdtLj4GioqIyPJhYnyTciFwvKoikAwuI2LKF8JukzrLSKHC+ZEpvzrMyLnSv0IMOXh0wNTDVc8FCCJH9sjXcqNVqgoKCXtr7KTQ0FFdX11y/z4iEG5FnJCegu7KFqN8WEXEmmNinxqkfPbaDA1VUXKlqS4cqn9OpdCesjWXvKiFE/pWZ398Zni119epVIGXKta+vb5pVhDUaDfv27cPV1fUtSxZCvMTAGKXqp1hX/RTrxxeI2zGP8D3HiQowxvW5ih5/akk4GsaJcj/yRY2f8anfma7lulLItJC+KxdCCL3KcM+NSqVKna3xqlNMTU1ZsGABPXv2zNoKs5j03Ig8LSaMmL+WEbFhDfE3NST+ZwDyrcJwuJoRLm0/olvl3rhYuOixUCGEyFrZ8ljqwYMH6HQ6ihcvztmzZ9PMkjIyMsLR0TFPrDUj4UbkC1oNT87+TvjGH7DxfUTkQ1MU7f92JTeFY95qaNeMjo2/pphVMT0XK4QQ7y5bx9zkdRJuRH5z/vxpgv6YS5WbZ4m4Z4Qq5n/bPABXiys8a1mN5p3HULJQaf0WKoQQ7yDLw82OHTto2bIlhoaG7NixI91j33///cxVm8Mk3Ij8KFmjZcupmwQc/JkOj/eSHJCI6rFR6ueh1hBQ35PqfUZTzqu2HisVQoi3k+XhRqVSERwcjKOjY7qbUyqKgkajyXzFOUjCjcjPouKTWHToNr6ndtEtZg+FHwSQcM8Uk/iUR1bJKrhTyZ5i3ftRuWkXWfVYCJFnyGOpdEi4EQXBg7AYpu25ydUb1/lMOUidkJNE3TWkUMi//zgJdTbGvNPHVPrsawwsLPRYrRBCvJmEm3RIuBEFyel7YUze5cudJ89opTrDhwn7ibwXjettA4yTU45JMFageT1K9x6KScmS+i1YCCFeI8vDzfz58zN88a+++irDx+qDhBtR0Gi0OrZefMSs/f48fZFAReUufcz3E3//FvY3DHAJ/8+x5YtTtOcALJs2RTGU7R2EELlHlocbDw+PDF1YURTu3buXsSr1RMKNKKiiE5JZevQuy4/fIyFZi70SxQi3k7x4dBij61qq3gbV/34aaO0tcfliIDYff4TKzEy/hQshBPJYKl0SbkRB9yg8lhn7/Nl55QkAVkYwutwtnoRuJO5yFI0v67CJSTlWZ2GMQ7de2H72GQa2tnqsWghR0Em4SYeEGyFSXHgQzuRdvlx+GAGAq40pQ31e4Pd4MeHnHtLmjA7nlI/QGRlg37Ejdj17YegiKx8LIXJeloeboUOHMnnyZMzNzRk6dGi6x86dOzdz1eYwCTdC/Eur1bHjyhNm7LtJUGQ8ANWK2dK/roq/fKcTfOEWbU/rKB7yvxNUCjYftKfQgIEYFi6sv8KFEAVOloebhg0b8vvvv2NjY0PDhg1f35iicPjw4cxXnIMk3AjxsrhEDcuP32PJ0bvEJaWsVfVBZVc+q6mw+fwEHl29RbtTOsoH/u/HhYEK2w87YN9/IIZOTnqsXAhRUMhjqXRIuBHi9YIj45m135+tFx8BYGKoom+9EjQsF8PSU+MJ87vHJ8e1lH/wT8hRY9vxEwp92Q+D/+w3J4QQWS3Hws3Dhw8BcHNze9smcpyEGyHe7OqjCCbv8uXc/ZR54s5WJoxoUQoXx0B+PDUR/B7xyV9ayqRkIBQjA+w+/Qz7fv1Qy39XQohskK3hJjk5mYkTJzJ//nyio6MBsLCwYNCgQYwfPx7DXL42hoQbITJGp9Ox93ow3+/x41F4HADeRaz5rnUZwnRnmH96Gja3ntPxLy0lUyZeobYwpdCgr7Ht3BnFyCid1oUQInOyNdz069ePbdu2MWnSJGrVqgXAqVOnmDBhAu3bt2fJkiVvX3kOkHAjRObEJ2lY9fd9Fh25Q3RCyrLGrSu6MKyZJ2dCd7Lkwo+4+8fw2REtRcJSzjF0KYTjqO+wbNZM9q8SQmSJbA031tbWbNiwgZYtW6Z5f8+ePXTu3JnIyMjMV5yDJNwI8Xaevkhg7kF/Npx7iE4HRgYqer/nQbf3nPnFdzm/+q6j7mUNnxzXpq6TY1q+FE4Tp2Jarpx+ixdC5HmZ+f39+i2+X8PY2Bh3d/eX3vfw8MBIuqGFyLccLI2Z1qEiuwfVpXYJexKTtSw+epfW887jqnRkywe70Lapz1d91Wyuo5BgCHHX/bn/0UcEfzcSTS7/h48QIv/IdM/NpEmTuHnzJqtWrcLY2BiAhIQEevXqhZeXF+PHj8+WQrOK9NwI8e50Oh1/+oXy/R4/Ap6ldNOUdbHiuzZlUJndYcapKYQ9uc/nh7W855vyI0ZtYYLjiFFYf/QxiirT/64SQhRwWf5YqkOHDmm+//PPPzE2Nsbb2xuAK1eukJiYSOPGjdm2bds7lJ79JNwIkXUSk7WsPXWf+YduExWfMh6nWVknRrbw4vzzfSy8OA/XO1H0PKDF7VnKOaali+M8fQ4mpUvrsXIhRF6T5eGmR48eGb74qlWrMnysPki4ESLrPY9J5Mc/b7H+TCAarQ5DtUL32u50rePISt+F/H5zCy3P6/jkuBaTJEClYN/9UwoNHo5KHmcLITJAFvFLh4QbIbLP7ZAXTN3jx1H/pwDYmRsxpIkX5Twi+P7MREIf3qbHQS01/VN+7BgVtsNl9gLMqlTRZ9lCiDxAwk06JNwIkf2O+ocyZbcfd0JT1sLycrRgdOtSPNYcZOHF+VS4EUuvA//OqrL9+H0cR49HZWamx6qFELlZtoebLVu2sGnTJgIDA0lMTEzz2cWLFzPbXI6ScCNEzkjWaPn1bCA/HLxFeGwSAA1KOdCvcSE23l3ASf+DdDukpcG1//XiOFlTeP5STL0r6bFqIURula1TwefPn0+PHj1wcnLi0qVL1KhRA3t7e+7du/fS2jdCiILLQK2iay13jg5rSO/3PDBUKxz1f0qXpTexjOrFuCY/suUjR6Z2VBFmCYkhkdzv3Jlnc6ai02j0Xb4QIg/LdM9N6dKlGT9+PJ07d8bS0pIrV65QvHhxxo0bx/Pnz1m4cGF21ZolpOdGCP0IeBbD93v8OOgbAoCViQFfNnQlWL2ZA9e30me/ltp+KT+OTEu6UnjRKozy0L51Qojsla2PpczMzPDz86NYsWI4Ojpy8OBBvL29uX37NjVr1iQsLOydis9uEm6E0K+Td54xaZcvN4NfAOBRyJyP34vjj8DZeJ4NpucBLWaJoBipcBk/FusPO+m5YiFEbpCtj6WcnZ15/vw5AEWLFuX06dMABAQEUMDGJgsh3kJtz0Ls/qou0ztUoJCFEQHPYpi5XYtt1FjMW33CiF5qbhYBXaKWJ99OJGhoH7T/b2yfEEKkJ9PhplGjRuzYsQNIWf9myJAhNG3alI4dO/LBBx9keYFCiPxHrVLoVKMoR4Y1oF+DEhgZqDh9J4YtB6tRwmU8S3s4sbV2yoabEXtOcL9NAxIf3Ndv0UKIPCPTj6W0Wi1arRYDAwMANmzYwMmTJ/Hy8qJv3765fn8peSwlRO7z8Hks0/feZPe1IAAsTJIpW+4gJlePMHCnFst4wFihyPdTsGzdIf3GhBD5kqxzkw4JN0LkXufuP2fyLl+uPkrZZNPJxR971S/0/T2Wkk9Sjin0+fsUGjMdRVH0WKkQIqdle7gJDw9nxYoV+Pn5AVC2bFl69OiBnZ3d21WcgyTcCJG7abU6fr/0mJn7bxISlYBiEIVH0Q20PXqbFhdTflyZVC1GsZ+2ojI313O1Qoickq3h5q+//uL999/HysqKatWqAXDhwgUiIiLYuXMn9erVe/vKc4CEGyHyhtjEZJYeu8dPf90lPkmDmd0xWjzZQ48DWgy0oHM2xmvtVgyLltB3qUKIHJCt4aZChQrUqlWLJUuWoFarAdBoNPTv35+TJ09y7dq1t688B0i4ESJveRIRx6z9/vx+6TEqk4fU4ScG/hGHVRwkmSl4/vgDZnWb67tMIUQ2y9ZwY2pqyuXLlylVqlSa9/39/alUqRJxcXGZrzgHSbgRIm+6/DCCSTtvcPFRMOXNf2LA/kDcQyFZDQ6jv8Cxy2CCbkcQE5WAuZUxLl42qFQyLkeI/CJb17mpUqVK6lib//Lz88Pb2zuzzQGwaNEi3N3dMTExwcfHh7Nnz7722AYNGqAoykuv1q1bv9W1hRB5QyU3G7b2q82CjrV4rh7B1KaNuVRCwUADN5edYeWgXWz/4RIHV/iy/YdLrB1zkruXQvVdthBCDwwyctDVq1dTv/7qq6/4+uuvuXPnDjVr1gTg9OnTLFq0iOnTp2e6gI0bNzJ06FCWLl2Kj48P8+bNo3nz5vj7++Po6PjS8du2bUuzWWdYWBje3t58/PHHmb62ECJvURSFtt6FaVrWiRUnijFXV4beNn+jsegFycB/OmpiIhLYt+w6LfqWp0Tll3+WCCHyrww9llKpVCiK8sYViBVFQZPJDe98fHyoXr166p5UWq0WNzc3Bg0axKhRo954/rx58xg3bhxBQUGYZ2DmhDyWEiL/CImIY8P4U6jjda+dGm5ha8znU2vLIyoh8rjM/P7OUM9NQEBAlhT2/yUmJnLhwgVGjx6d+p5KpaJJkyacOnUqQ22sWLGCTp06vTbYJCQkkJCQkPp9VFTUuxUthMg1kkPiMUgA0lnzJjo8gaDbEbiWss25woQQepWhcFOsWLFsufizZ8/QaDQ4OTmled/JyYmbN2++8fyzZ89y/fp1VqxY8dpjpk2bxsSJE9+5ViFE7hMTlfDmgzJxnBAif8j0gGKAu3fvMmjQIJo0aUKTJk346quvuHv3blbX9kYrVqygQoUK1KhR47XHjB49msjIyNTXw4cPc7BCIUR2MrcyztLjhBD5Q6bDzf79+ylbtixnz56lYsWKVKxYkTNnzlCuXDkOHjyYqbYKFSqEWq0mJCQkzfshISE4Ozune25MTAwbNmygV69e6R5nbGyMlZVVmpcQIn9w8bLB3Cad4KLToU56zvOYYzlXlBBC7zIdbkaNGsWQIUM4c+YMc+fOZe7cuZw5c4bBgwczcuTITLVlZGRE1apVOXToUOp7Wq2WQ4cOUatWrXTP3bx5MwkJCXz22WeZvQUhRD6hUinU7ej1ys90pEyAKOO/hSeDR+N7aVtOliaE0KNMhxs/P79X9pb07NkTX1/fTBcwdOhQli9fzpo1a/Dz86Nfv37ExMTQo0cPALp27ZpmwPE/VqxYQfv27bG3t8/0NYUQ+UeJyo606Fv+pR4cCxsTwhyDMI29QtFQCBz8LX4XNuqpSiFETsrQgOL/cnBw4PLly3h5pf3X0uXLl1+5Ls2bdOzYkadPnzJu3DiCg4OpVKkS+/btSx1kHBgYiEqVNoP5+/tz4sQJDhw4kOnrCSHynxKVHfHwdnhpheLoxBqMJIqeuxdQLATufzMB9VyFklU+0XfJQohslOntFyZNmsQPP/zAqFGjqF27NgB///03M2bMYOjQoYwdOzZbCs0qss6NEAVLUGQcw6f+zNcHF2MRB/ddoNKCObiUb6Xv0oQQmZCte0vpdDrmzZvHnDlzePLkCQCFCxdm+PDhfPXVV69dSCu3kHAjRMHjH/yCMTOWM+rIcizi4YEL+CxejG2ZhvouTQiRQdkWbpKTk/n1119p3rw5Tk5OvHjxAgBLS8t3qzgHSbgRomA6dTeMGT/+xHd/rcU8Hh4UgXrL12Dm8fqlJIQQuUe2bZxpYGDAl19+SXx8PJASavJSsBFCFFy1StjTo2dXJtX9mFgjKPYIjg3ohubxFX2XJoTIYpmeLVWjRg0uXbqUHbUIIUS2alfJldYfdWNG3ZYkGoD7PTjavyO60Fv6Lk0IkYUyPVuqf//+fPPNNzx69IiqVau+tKdTxYoVs6w4IYTIal/UK86TiJ7M1UUy7OhJCvsrnB7QjprLD6DYuOm7PCFEFsj0gOL/Py0bSN0x/G12Bc9pMuZGCKHR6ui3/gIGp6Yw4Ig/KiC5hgEVlhwB80L6Lk8I8QpZviv4f2XXDuFCCJFT1CqF+Z0r0zn6G1Zrx9LzWAgGZ5MJGNocjx+PgIn8w0eIvCxTY26ioqK4desW169fx8zMjGLFir30EkKIvMDEUM2Kbj6c8xrNxtoWAMQfi+Xp2NaQFKfn6oQQ7yLD4eby5cuULl2aFi1a0LZtWzw9Pdm/f3921iaEENnKztyItT3qstNzGHurGAIQsvsp0TM/BE2SnqsTQrytDIebkSNH4uHhwYkTJ7hw4QKNGzdm4MCB2VmbEEJku6L2Zqz8vDkryvThdCkFtVYhYOM9En7qAZkbkiiEyCUyPKC4UKFCHDhwgCpVqgAQERGBnZ0dEREReWpgrgwoFkK8ypGboQz6fTaTDu2kzCPQmmko+W0HDD+cru/ShBBk0yJ+z58/p0iRIqnf29jYYG5uTlhY2NtXKoQQuUTD0o6MaTSA75tV5JE9qGLVBMzagubYYn2XJoTIpEzNlvL19SU4ODj1e51Oh5+fX+o2DCDr3Agh8q4uPsV4GD6aKQxm2sYQbCMMeThuNsUWuaGUb6vv8oQQGZThx1IqlSp1PZuXGpF1boQQ+YROp6PfxgM8ChjFpN/iMU0EK/cECv+0EaVodX2XJ0SBlS0bZz548CBDF8/t08El3Agh3iRJo+XDNcuxfDCfUZu1GGihUCUNDov2gn0JfZcnRIGUbbuC5wcSboQQGfEiPokWa76lyq3d9N+tBaBwY0OsZx6WVYyF0INs2xVcCCEKCksTQzZ3Gs/xkmXZXlMB4MmRRGJnfwhJ8XquTgiRHgk3QgjxGoWtzVnZ6gd+q2PPmVIKaBUebQsicU0fWQNHiFxMwo0QQqSjilsRvq0xg/mtjbjrDJoENQ9/OoVm//f6Lk0I8RoSboQQ4g06etemrddXzPxIzTNLSIwy5NG0FeiubNV3aUKIV5BwI4QQGTCxYU8KF27GjI/VxBtCbIgxwd8OR/fogr5LE0L8PxmaLVW5cmUURclQgxcvXnznorKTzJYSQrytBE0CTX/7hOI37zB8ixYV4OijxX7+YbB21Xd5QuRrmfn9naEVitu3b58VdQkhRJ5mrDbm1/cX01bzIesav6DbIS2hZxSMpn6A5ZQjYGSu7xKFEMg6N/ouRwiRBx0NPM6gQ/3pc0BD00s6VAZa3L8oh/HALaCSp/1CZAdZ50YIIbJRg6J16VOxPyubqrhRVEGbrOLhmmsk75ms79KEELxFuNFoNMyePZsaNWrg7OyMnZ1dmpcQQhQEA6v0pVrhesz9QEWotUJSjAGPZ65Bd32HvksTosDLdLiZOHEic+fOpWPHjkRGRjJ06FA6dOiASqViwoQJ2VCiEELkPipFxdxG0zGzL8KMj1UpM6hCjQn+dgiE3tR3eUIUaJkON7/88gvLly/nm2++wcDAgM6dO/Pzzz8zbtw4Tp8+nR01CiFErmRlZMWiJj8S7GTC/PdV6IAIfyPCx34McRH6Lk+IAivT4SY4OJgKFSoAYGFhQWRkJABt2rRh9+7dWVudEELkcqXsSjGx9njOl1SxoX7Kj9Tgv5KImdsJtBo9VydEwZTpcFOkSBGCgoIAKFGiBAcOHADg3LlzGBsbZ211QgiRB7Qt0ZZOpTrxey2Fv0urQafweOM9EjeO0HdpQhRImQ43H3zwAYcOHQJg0KBBjB07Fi8vL7p27UrPnj2zvEAhhMgLRlQfQXXnGixpAwFOKjSJah7N+wPtuV/1XZoQBc47r3Nz+vRpTp48iZeXF23bts2qurKNrHMjhMguEfERdNnzKTGPHzBzlRarWB0WbokUWb0VxbWSvssTIk/LzO/vTIeb+Ph4TExM3qlAfZJwI4TITgGRAXy6+1Oc70cxcb0GAy3YVVFwWvE3mNrquzwh8qxsXcTP0dGRbt26cfDgQbRa7VsXKYQQ+ZGHtQdzG87lbhEDlrVM+RH7/KKOiEmfgPzMFCJHZDrcrFmzhtjYWNq1a4erqyuDBw/m/Pnz2VGbEELkSTVdavJdzW85VlHFzhopmw4H7wgkdt1IPVcmRMHwVgOKN2/eTEhICN9//z2+vr7UrFmTkiVLMmnSpOyoUQgh8pyPS37MFxW/YH1DFZeKK+g0Kh7P+4Oks1v1XZoQ+V6WbJzp6+vLp59+ytWrV9Focve6DjLmRgiRU3Q6HZNPT2bX1U18v0aD63MwLqTBfetuVE5e+i5PiDwlRzbOjI+PZ9OmTbRv354qVarw/Plzhg8f/rbNCSFEvqMoCt/6fMt7pZox42M1McaQ8ExNYJ+P0CXG6bs8IfKtTIeb/fv3061bN5ycnOjXrx9OTk4cOHCABw8eMH369OyoUQgh8iy1Ss30utMpVrYmcz9QoVEg7lYiD4Z+qO/ShMi3Mv1YyszMjDZt2vDpp5/SqlUrDA0Ns6u2bCGPpYQQ+hCbFMuAQwNx2HWGHn9q0Sk6zPp9gGHzEcREJWBuZYyLlw0qlaLvUoXIlbL1sVRISAibNm2iXbt2WRJsFi1ahLu7OyYmJvj4+HD27Nl0j4+IiGDAgAG4uLhgbGxMyZIl2bNnzzvXIYQQ2cnM0IzFTRYR1qYmh7wVntpX4s9L1dj+wyUOrvBl+w+XWDvmJHcvheq7VCHyPIOMHBQVFZWaknQ6HVFRUa89NjO9IRs3bmTo0KEsXboUHx8f5s2bR/PmzfH398fR0fGl4xMTE2natCmOjo5s2bIFV1dXHjx4gI2NTYavKYQQ+mJqYMqiJov4NnAayoV6L30eE5HAvmXXadG3PCUqv/wzUAiRMRl6LKVWqwkKCsLR0RGVSoWivNxtqtPpUBQlU7OlfHx8qF69OgsXLgRAq9Xi5ubGoEGDGDVq1EvHL126lFmzZnHz5s237jWSx1JCCH3SanWsHfM30REJKLz6EZSFrTGfT60tj6iE+I/M/P7OUM/N4cOHsbOzS/36VeEmsxITE7lw4QKjR49OfU+lUtGkSRNOnTr1ynN27NhBrVq1GDBgAH/88QcODg506dKFkSNHolarX3lOQkICCQkJqd+n1+skhBDZLeh2BDERia8NNgDR4QkE3Y7AtZRs1yDE28hQuKlfv37q1w0aNMiSCz979gyNRoOTk1Oa952cnLh58+Yrz7l37x6HDx/m008/Zc+ePdy5c4f+/fuTlJTE+PHjX3nOtGnTmDhxYpbULIQQ7yomKuHNB2XiOCHEyzI9oNjLy4sJEyZw+/bt7KgnXVqtFkdHR3766SeqVq1Kx44d+fbbb1m6dOlrzxk9ejSRkZGpr4cPH+ZgxUIIkZa5lXGGjtt9K5SYhORsrkaI/CnT4aZ///7s3r2b0qVLU716dX788UeCg4MzfeFChQqhVqsJCQlJ835ISAjOzs6vPMfFxYWSJUumeQRVpkwZgoODSUxMfOU5xsbGWFlZpXkJIYS+uHjZYG6TTsDR6Yg1CGfJw99oMPsIm88/RKt954XkhShQMh1uhgwZwrlz5/Dz86NVq1YsWrQINzc3mjVrxtq1azPcjpGREVWrVuXQoUOp72m1Wg4dOkStWrVeeU6dOnW4c+dOmt3Ib926hYuLC0ZGRpm9FSGEyHEqlULdjq/ZeuF/8zs8AjZjZb+TFxbrGb71Au0W/c3ZgOc5WKUQedtbb79QsmRJJk6cyK1btzh+/DhPnz6lR48emWpj6NChLF++nDVr1uDn50e/fv2IiYlJbadr165pBhz369eP58+f8/XXX3Pr1i12797N999/z4ABA972NoQQIseVqOxIi77lX+rBMTdLpuKtZZS7e4VBO7UYWV/A0n0Z10Me8MmyU/Rbf4HAsFg9VS1E3pGhAcWvc/bsWX799Vc2btxIVFQUH3/8cabO79ixI0+fPmXcuHEEBwdTqVIl9u3blzrIODAwEJXq3/zl5ubG/v37GTJkCBUrVsTV1ZWvv/6akSNHvsttCCFEjitR2REPb4eU2VP/rFDsaU38gtUE/qSjxi347KQh6+o8wq7kYiLvd2HvdTjkF0qP99wZ2NATS5O8tUK8EDkl09sv3Lp1i19++YXffvuNgIAAGjVqxKeffkqHDh2wsLDIrjqzjKxzI4TI1RJjiBj6HkF/xgOwsYsrW4uFoFbUuCR3xu9WeQDszY34plkpOlZ3Qy3r4YgCIDO/vzMdblQqFdWrV6dLly506tTppancuZ2EGyFErhd6k5C+LXnuZwIGKnYN8WGtwTkAaju25pZvYwKepkyiKO1sydg2ZanjWUifFQuR7bIt3Gg0GlauXMlHH32ErW3eXFxKwo0QIi/QXfyFR8O/JfqxKSpLc85P7siMkHXo0OHtUIma5oNZfjSMyLgkAJqUcWRMqzIUd8j9PehCvI1s2zhTrVYzaNAgIiIi3qU+IYQQb6BU+RTXL1tiYpeI9kUMPrP2saTqdCyNLLny9DK/h4xgcU97etRxx0Cl8KdfKM1++ItJO32JjE3Sd/lC6FWmZ0uVL1+ee/fuZUctQggh/kPVfi5uHRwwNE8m6fETCk9aw6+NV1HCugShcaEMOtqHiqVvsX9IPRqXdiRZq2Pl3wHUn32E1X8HkKTRvvkiQuRDmQ43U6ZMYdiwYezatYugoCCioqLSvIQQQmQRQ1MMuq/DrXEcKiMt8VevYjB5IetbrKWRWyOStEmMOzmOjffms7RrJdb1qkEpJ0siYpOYsNOXFvP+4sjNUDI5tFKIPO+tBhSnnvyfDTTfZldwfZAxN0KIPOfKBmKXDSLwqD06rYJdt644jBrJsqvLWHx5MQDVnKoxp8EcrAxt2Hj+IXMP3CIsJmXQcb2SDnzXugwlnSz1eRdCvJNsnS117NixdD//7yabuZGEGyFEnrS9P5F/bOXJKTsAnMaMxq5rV44EHmH0idHEJMXgYu7CvIbzKGtflqj4JBYdvsPKvwNI0uhQqxQ613BjSJOS2FtkbH8rIXKTbA03eZ2EGyFEnpQYAz814NlfT3h61QoUBdc5s7Fq1Yp7Eff46shXPIh6gLHamPG1xtO2RFsAHoTFMG3PTfbdSNkD0NLEgK8aedGttjtGBm+9SL0QOS5bw81ff/2V7uf16tXLTHM5TsKNECLPCr6O7qdGhJw1IfyOORga4rZ0CRZ16hCVGMWov0Zx/PFxALqU7sKw6sMwVKWsYnz6XhiTd/ly40nK2Mhi9maMaVWGZmWd0gwxECK3yvZF/F5q5D//YciYGyGEyEbnVqDbOZTHp+14EWiCYmZGsTVrMK1QHo1Ww5IrS1h2dRkAVRyrMLv+bBzMHADQaHVsvfiIWfv9efoiAYCaxe0Y26Ys5Qpb6+2WhMiIbFvnBiA8PDzNKzQ0lH379lG9enUOHDjw1kULIYTIgGo9Ucq3o7DPc8xcFXSxsTz84gsSAgJQq9QMrDyQ+Q3nY2FowcXQi3Tc1ZHLoZcBUKsUPqnmxtFhDRjY0BNjAxWn7z2nzYITjNxyldAX8fq9NyGySJaNuTl27BhDhw7lwoULWdFctpGeGyFEnhcXAcvqonn6kMBTJYh/Eoth4cIU++03DJ0cAbgfeZ8hR4dwJ+IOBooBI2qMoFOpTml62h9HxDFj7012XHkCgLmRmv4NPen1ngcmhmp93JkQr5WtPTev4+TkhL+/f1Y1J4QQ4nVMbeCj1aiN1bjVuIeRsy1JT57wsHdvNJGRALhbu/NLq19o7t6cZF0y35/5nu/+/o745H97Z1xtTJnfuTJb+9WmkpsNMYkaZu33p/GcY+y88kTWxxF5VqZ7bq5evZrme51OR1BQENOnTyc5OZkTJ05kaYFZTXpuhBD5xt/z4eBYEuPNuP+XO5rnEZhWrUrRn5ejMjUFUn5Gr/Vdyw8XfkCj01DarjQ/NPiBIpZF0jSl1erYceUJM/bdJCgyJQBVK2bL2DZl8Xazyek7E+Il2T6gWFGUlxJ9zZo1WblyJaVLl858xTlIwo0QIt/QauHXT+DOQeIpwYPdarQvojGvU4ciSxajMjJKPfRs0FmG/zWc5/HPsTKyYma9mdRxrfNSk3GJGpYfv8eSo3eJS0qZIPJBZVdGtCiFi7Vpjt2aEP9ftoabBw8epPlepVLh4OCAiYlJ5ivVAwk3Qoh8JeYZLH0PXgQRa9OawDU30cXFYdG4MUXm/YBiaJh6aHBMMEOPDuXas2soKAysPJDeFXqjUl4eoRAcGc+s/f5svfgIABNDFX3rlaBv/eKYGRnk2O0J8Q9ZxC8dEm6EEPlOwHFY+z7otMR4juLhzA3oEhOxat2awjNnoKj/HRycqElk2tlpbLm1BYCGbg2Z+t5ULI1evTXD1UcRTN7ly7n74QA4W5kwokUp2ldyRaWS9XFEzsmWAcWnTp1i165dad5bu3YtHh4eODo68sUXX5CQkPB2FQshhHh7HnWh/kgAzB8swHXySDAwIGr3boLGj0en/Xd3cCO1EeNrjWdCrQkYqgw58vAIXXZ34W7E3Vc2XbGIDZv61mLxp1UoYmtKcFQ8Qzdd4YPFf3P+/vMcuT0hMivD4WbSpEncuHEj9ftr167Rq1cvmjRpwqhRo9i5cyfTpk3LliKFEEK8Qb3h4F4XkmKwDFqM6/TvQaUicstWQqZNf2mc5IclP2Rty7U4mztzP+o+nXd3Zv/9/a9sWlEUWlVw4c+h9RnZojQWxgZceRTJR0tPMeDXizx8HpsTdyhEhmX4sZSLiws7d+6kWrVqAHz77bccO3YsdXbU5s2bGT9+PL6+vtlXbRaQx1JCiHwrKgiW1oHYMKjxBREJdQgaPRoA+759cRwy+KVTnsc/Z8SxEZwJPgNA17JdGVx1cOq2Da/y9EUCcw/6s/HcQ7Q6MDJQ0fs9D/o39MTCWMbjiOyRLY+lwsPDcXJySv3+2LFjtGzZMvX76tWr8/Dhw7coVwghRJawcoEPUrZe4OxP2JRW4zRuLABhy5bxdNGil06xM7FjadOl9CjfA4C1vmvptb8XITEhr72Mg6Ux0zpUZNegutQuYU9ispbFR+/SYNZRNp4LRKMtUEM5RS6U4XDj5OREQEAAAImJiVy8eJGaNWumfv7ixQsMDV+f9IUQQuQAr6ZQe1DK138MwK7VezgOHw7AswULebrw5YBjoDJgaNWhzGswDwtDCy6FXuKTXZ9w6smpdC9VtrAVv/T2YXnXangUMudZdAIjt16j7YITnLz7LMtvTYiMynC4adWqFaNGjeL48eOMHj0aMzMz6tatm/r51atXKVGiRLYUKYQQIhMajQPXqhAfCVt6Yt/9cxyHfQPAs4WvDjgAjYs1ZlObTZS2K83z+Of0PdiXpVeWotVpX3k8pIzHaVrWif2D6/Fd6zJYmRjgGxRFl+Vn+GLtee4/i8mWWxQiPRkON5MnT8bAwID69euzfPlyli9fjtF/FohauXIlzZo1y5YihRBCZIKBEXy0Eoyt4dE5ODwF+9690wacBQtfeaqblRvrWq7jQ68P0aFj0eVF9P+zP+Hx4ele0shARe+6xTk6vCHdahVDrVI44BtC0x+OMXW3L5FxSVl+m0K8TqbXuYmMjMTCwgK1Ou2mas+fP8fCwiJN4MmNZECxEKLAuLEdNndL+fqzreDZhLAVKwidNRuAQgMG4DBo4GtP/+POH0w5PYV4TTxOZk7MaTAHbwfvDF36dsgLpu7x46j/UwDszI0Y0sSLzjWKYqDOsm0NRQEii/ilQ8KNEKJA2TUUzq8As0Lw5QmwciFsxUpCZ80C3hxwboXf4puj33A/6j4GigHDqg+jS+kuaXYXT89R/1Cm7PbjTmg0AF6OFnzXpiz1Szq8+72JAkXCTTok3AghCpSkePi5CYRcg2LvQbcdoFITtnIVoTNnAmDf70scvvrqtYElOjGa8SfHc+DBAQCaFWvGxNoTsTCyyFAJyRotv54N5IeDtwiPTXk81bCUA9+2LoOn46tXRhbi/5Nwkw4JN0KIAufZHVhWD5JioP4oaJiy9k3YqtWEzpgBgF23bjiOGvnagKPT6fj15q/MPj+bZG0yxayKMbfBXEralsxwGZGxSSw4fJs1p+6TpNGhVil85lOUwU1KYmueu4c0CP2TcJMOCTdCiALp6ibY1gdQoOsfULw+AM/X/0LIlCkA2Hz8Ec4TJqTZi+r/u/L0CsOODSM4JhgTtQljfMbQ3rN9hh9TAQQ8i+H7PX4c9E1ZS8fKxICvm5Tk85rFMDKQ8Tji1STcpEPCjRCiwPpjAFxaDxZO8OXfYJEy7iVi6zaCxo4FrTZls83p09LsJv7/hceHM/r4aP5+8jcAbYq34bua32FuaJ6pck7eecbk3X74BUUB4FHInG9blaFxGcdMhSVRMEi4SYeEGyFEgZUYA8sbwdObUKIRfLoVVCk9JVH79vF42HBITsaicWNc585BZWz82qa0Oi0/X/uZRZcXodVpcbdyZ1b9WZS2K52pkjRaHZvPP2T2AX+eRScCUMfTnu9al6WMi/yMFv+ScJMOCTdCiAIt1A9+agjJcdB4PNQdmvrRi6NHefzV1+gSEzGvXYsiCxeiMjNLt7mLIRcZ8dcIQmJDMFIZMbz6cDqW6pjpnpcX8UksPnqXFScCSEzWolKgY/WifNOsJIUsXh+yRMEh4SYdEm6EEAXexbWwYxAoauixB4r+u5VOzOkzPOzfH11sLKaVK+O2dAlqa+t0m4uIj+C7v7/j2KNjADQt1pQJtSdgZZT5n7EPn8cyfe9Ndl8LAsDC2ICBjTzpUccdY4PXjwUS+Z+Em3RIuBFCFHg6Xcrg4mubwaoIfHkczOxSP467fJnAL/qijYrC2MsTt59+wtDF5Q1N6ljvt565F+aSrE3G1cKVmfVmUtGh4luVeO7+cybv8uXqo0gA3OxMGd2yDC3LO8t4nAJKwk06JNwIIQSQ8CJlevjze1CyJXT+Df4TGuL9b/GwTx+SQ0MxcHam6M/LMfb0fGOzN57dYNixYTyKfoSBYsDXVb6ma7muqJTMz4LSanX8fukxM/ffJCQqAYAa7naMbVOWCkXS700S+Y+Em3RIuBFCiP8JupKywJ8mEZpPg1r903yc9PgxgX2+IPHePVTW1rgtWYxZlSpvbPZF4gsmnprI/vv7AajrWpep703F1sT2rcqMTUxm6bF7/PTXXeKTtCgKfFilCMObl8LJyuSt2hR5j4SbdEi4EUKI/zi7HPYMA5Uh9Nqfspv4fySHh/Poy37EXbmCYmyM69w5WDZu/MZmdTodm29tZua5mSRoEnA0dWR6velUd67+1qU+iYhj1n5/fr/0GAAzIzVf1i9Bn7rFMTWS8Tj5nYSbdEi4EUKI/9DpYNPn4LcTbIqljL8xSfvIRxsXx+MhQ4k+ehRUKpwnjMf2k08y1Pyt8FsMOzaMgMgAFBR6lu/JgEoDMFS/fh2dN7n8MIJJO29wMTACgMLWJoxsWZr3vQvLeJx8TMJNOiTcCCHE/xMXAcvqQkQglG0HH69JM/4GQJecTND48URu3Qb8bz+qQYNQVG8eSxObFMvMczPZensrAOXsyzG97nTcrd3fumSdTseuq0FM33uTxxFxAFRys2Fc27JUKfp2j79E7ibhJh0SboQQ4hUenYeVzUGbDK3nQvVeLx2i0+l4On8+YUuWAmDVqiUu06alu9jffx18cJAJJycQlRiFqYEpo2qM4gPPD96ptyU+ScOKEwEsOnKH2EQNAO97F2Zky9K42pi+dbsi98nM7+9csYnHokWLcHd3x8TEBB8fH86ePfvaY1evXo2iKGleJiYyoEwIId5JkWrQZGLK1/tGQ/C1lw5RFAXHr7/GZepUMDAgas9eArt1JzksLEOXaFqsKVvf30oN5xrEJccx/uR4vjn2DZEJkW9dtomhmgENPTk6rAGfVCuCosCOK09oNPsocw74E5OQ/NZti7xL7+Fm48aNDB06lPHjx3Px4kW8vb1p3rw5oaGhrz3HysqKoKCg1NeDBw9ysGIhhMinag2Aki1AkwCbu0NC9CsPs/mwA0V//hmVlRVxly9z/5OOJNy5k6FLOJs781PTnxhSdQgGigEHHxykw44OnAk6806lO1qZMPMjb3YOfA8fDzsSkrUsOHyHhrOPsvn8Q7TaAvWQosDT+2MpHx8fqlevzsKFCwHQarW4ubkxaNAgRo0a9dLxq1evZvDgwURERLzV9eSxlBBCpCP2OSx9D6IeQ8WO8MGyl8bf/CPhXgAPv/ySpMBAVBYWuP44D4s6dTJ8qRthNxj11yjuR91HQaF7+e4MqjTonQYbQ8rjs/03Qpi2148HYbEAlHe1YmzrsvgUt3+ntoX+5JnHUomJiVy4cIEmTZqkvqdSqWjSpAmnTp167XnR0dEUK1YMNzc32rVrx40bN157bEJCAlFRUWleQgghXsPMDj5ckbI1w9WNcPnX1x5qXNwD940bMK1aFW10NA+/6Ev4hg0ZvlQ5+3JsbLORD70+RIeOVddX8emeT7kXee+dbkFRFFqUd+bAkHqMaVUaS2MDrj+OouNPp+m3/gKB/ws8Iv/Sa7h59uwZGo0GJyenNO87OTkRHBz8ynNKlSrFypUr+eOPP1i/fj1arZbatWvz6NGjVx4/bdo0rK2tU19ubm5Zfh9CCJGvFKsFDcekfL37Gwjxfe2hBra2FF21Eqv324JGQ/CEiQSNG48uMTFDlzIzNGNC7Qn80OAHrIys8Hvuxyc7P2G973q0Ou073YaxgZov6pXg6PAGfFazKCoF9l4PpsncY0zb40dUfNI7tS9yL70+lnry5Amurq6cPHmSWrVqpb4/YsQIjh07xpkzb34Gm5SURJkyZejcuTOTJ09+6fOEhAQSEhJSv4+KisLNzU0eSwkhRHq0WvjlQ7h7GOy94IsjYGz52sN1Oh1hPy3n6bx5oNNhWrkyrj/Ow9DRMcOXDI4JZtzf4zgVlNJzX8O5BpPrTKawReF3vRsA/INfMGW3L8dvPwPA3tyIoc1K0ql6UdQqWR8nt8szj6UKFSqEWq0mJCQkzfshISE4OztnqA1DQ0MqV67MndcMZjM2NsbKyirNSwghxBuoVNBhOVgWhrDbKbuIp/NvYUVRKNT3C9yWLkFlaUncpUvc/+hj4q5ezfAlnc2dWdZ0Gd/5fIepgSlng8/SYUcHfr/9O1nx7/BSzpas7VmDld2rUdzBnLCYRL79/Tqt5x/nxP8Cj8gf9BpujIyMqFq1KocOHUp9T6vVcujQoTQ9OenRaDRcu3YNlzfsWCuEECKTzAvBx6tBZQA3fk/ZquENLOrXx33TRoxKlCA5NJQHn35GxP8W/ssIRVHoWLojm9tuxtvBm5ikGMadHMdXR77iWdy7BxBFUWhU2on9g+sxoW1ZrE0NuRn8gs9WnKHX6nPcffrqGWIib9H7VPChQ4eyfPly1qxZg5+fH/369SMmJoYePXoA0LVrV0aPHp16/KRJkzhw4AD37t3j4sWLfPbZZzx48IDevXvr6xaEECL/KuoDTf/3yH//mJTF/t7A2CNloLFFo0bokpII+vZbgidPyfA4HIBiVsVY02INX1f5GgOVAUcfHqXDHx04+ODgW95IWoZqFd3reHBseAN61HHHQKVw6GYozX/4i4k7bxARm/FaRe6j93DTsWNHZs+ezbhx46hUqRKXL19m3759qYOMAwMDCQoKSj0+PDycPn36UKZMGVq1akVUVBQnT56kbNmy+roFIYTI32r2gzLvgzYJNnVLmS7+BmoLC4osXEChAQMACP/lF+5//jlJT55k+LJqlZreFXqzofUGStqWJDwhnKFHhzL6+GiiErNm5quNmRHj25Zj/5B6NC7tSLJWx6q/79Ng9lFW/x1AkubdBjUL/dD7Ojc5Tda5EUKItxAfBT81gOd3wbMJdNmcMi4nA14cPsyTUaPRRkWhtram8MwZWNSvn6nLJ2mSWHJlCSuur0Cr0+Jo6si4WuOo75a5dt7k+O2nTNnlh3/ICwBKOJjzbesyNCzlKJty6pnsLZUOCTdCCPGWgq/Dz40hOR4afgf1h2f41MRHj3g8eAjx168DYP/FFzh8NQjFwCBTJVwOvcx3f3/Hg6iUlelbF2/NyOojsTXJus0ykzVaNp5/yNwDtwiLSXk8VderEGPblKWk0+tnjInsJeEmHRJuhBDiHVxaD38MAEUFn/8OxRtk+FRtYiKh02cQ/mvKwoBm1atTeM7sTE0XB4hPjmfx5cWs8V2DVqfFzsSOMT5jaFasWZb2rkTFJ7Ho8B1W/X2fRI0WlQJdfIoypElJ7C0ytlmoyDoSbtIh4UYIId7RHwNSQo65A/T9C6wytw5N1J49BH03Fm1sLOpChSg8fToW72V824Z/XHt6jXEnx3EnImUpkCZFm/BtzW8pZFoo022l50FYDNP23GTfjZTFZS1NDBjUyJNutd0xNlBn6bXE60m4SYeEGyGEeEdJcfBzEwi5DkVrQbedkMn9oBICAnj89WASbt0CwK5bNxy+GYrKyChT7SRqEll+bTk/X/2ZZF0yVkZWjKwxkrbF22b5GJnT98KYvMuXG09SBjMXszdjdMsyNC/nJONxcoCEm3RIuBFCiCwQdjdlgHFCFNQaCM2nZroJbXw8oTNnpT6mMi5VCtc5szH29Mx0W/7P/Rn791j8nvsB8J7re4yrOQ4Xi6xdA02j1bH14iNm7ffn6YuU1e9rFrfju9ZlKe9qnaXXEmlJuEmHhBshhMgivjtg0+cpX3+8Gsp98FbNvDhyhKBvv0Pz/DmKsTGOI0dg27lzpntDkrRJrLmxhsWXF5OkTcLUwJQBlQbwaZlPMVBlbuDym8QkJLPk6F2WH79HQrIWRYGPqxZhWPNSOFqaZOm1RAoJN+mQcCOEEFnowHdwcgEYmkOfQ+BY5q2aSX76lCdjviXm+HEALBo0wGXqFAzs7TPd1r2Ie0w8NZGLoRcBKG1XmvG1xlO+UPm3qi09jyPimLH3JjuupKzfY26kpn9DT3q954GJoYzHyUoSbtIh4UYIIbKQJhnWfwABf4FdCehzGExt3qopnVZL+Pr1hM6ajS4pCbWtLc7jx2HVokWm29LqtGy/s5055+cQlRiFgkKn0p34qvJXWBhZvFV96bnwIJzJu3y5/DACAFcbU0a1LE2bii4yHieLSLhJh4QbIYTIYjHPUsbfRD6Eki2g028ZXuDvVeL9/XkyfETqYGPLli1wHjsWAzu7TLcVFhfG7POz2XVvFwCOpo6M8hlFk6JNsjx0aLU6dlx5wox9NwmKjAegajFbxrYpSyU3myy9VkEk4SYdEm6EECIbPLkEK5qDJgEajIYGo96pOV1iIk+XLCHsp+Wg0aC2s8N5/Hismjd7q/ZOPTnFlNNTCHwRCED9IvUZ7TMaVwvXd6rzVeISNSw/fo8lR+8Sl6QB4IPKroxoUQoXa9Msv15BIeEmHRJuhBAim1z6Bf7on/J1541QKvOPk/6/uOs3CBo9moTbtwGwatUSp7FjMbDN/IrECZoEll9dzorrK0jWJmOsNqZX+V70KN8DE4OsHwQcHBnPrP3+bL34CAATQxV965Wgb/3imBll7QDngkDCTTok3AghRDbaNRTOrwBja/jiCNiXeOcmtYmJPFu8mLDlP6f24jiNGolV27dby+ZexD2mnpnK2eCzALhauDKi+ggaujXMlvExVx9FMHmXL+fuhwPgbGXCiBalaF/JFZVKxuNklISbdEi4EUKIbJScCGvawMMz4FAGev8JxlkzgDfu2nWCxoxJ7cUxq1UTl/HjMXJ3z3RbOp2O/Q/2M/vcbEJiQwCoU7gOI2uMxMPaI0vq/f/X23s9mO/3+PEoPA6AikWsGdemLNXcMz+WqCCScJMOCTdCCJHNooLgp/oQHZKy9s1HqyCLekR0iYmErVrNs8WL0SUkoBgZUajfl9j16pXp1Y0BYpNi+fnaz6y+sZokbRIGKgM+L/s5fSv2xdzQPEtq/q/4JA2r/r7PoiN3iE5IBqB1RRdGtSiNm51Zll8vP5Fwkw4JN0IIkQMCT8Pq1qBNhiYT4b3BWdp8YmAgwRMnEfP33wAYFS+Oy8QJmFWv/lbtBUYFMuPcDP569BcADqYODKk6hNbFW6NS3n7m1+s8fZHA3IP+bDz3EK0OjAxU9HrPg/4NSmBpkrmtLAoKCTfpkHAjhBA55Oxy2DMMUKDLRijZPEub1+l0RO3eQ8i0aWjCwgCwatsWx2+GYujs/FZtHnt4jBnnZvDwxUMAytqXZVi1YVR3frvQ9CZ+QVFM2e3L33dS6i9kYcywZiX5uJobahmPk4aEm3RIuBFCiByi08HOr+HiGjCyTBl/41g6yy+jiYwkdM5cIjZvBp0OxdSUQn2/wK5HD1TGxpluL0GTwDrfdfx87WdikmIAaOjWkKFVh+Ju7Z7F1aeEtD/9Qvl+jx8Bz1KuV8bFirFtylC7RNbucJ6XSbhJh4QbIYTIQcmJsK49PPgbbN2hzxEwy54BtHHXbxAydSpxly4BYOjqiuPIEVg2bfpWs6DC4sJYcmUJW25tQaPTYKAY8EmpT/jS+0tsTTI/Ff1NEpO1rD11n/mHbhMVnzIep2lZJ8a0KoNHoawf/5PXSLhJh4QbIYTIYTFhsLwBRASCe134/HdQZ8+4kn8eVYXOmkVySMosKDMfH5xGjcSkzNvte3Uv4h5zL8zl2KNjAFgaWtKnYh+6lOmCsTrzPUNv8jwmkR//vMX6M4FotDoM1QrdarkzqLEX1qYFdzyOhJt0SLgRQgg9CLkBK5pBYjRU7w2t52Tr5bSxsYT9/DNhP69Al5gIioJVmzY4fP0VRkWKvFWbp4NOM+f8HG4+vwmAk5kTX3p/STvPdhiqsj503A55wdQ9fhz1fwqArZkhQ5uWpHONohios36Qc24n4SYdEm6EEEJPbu6BDV0AXUq4qd472y+Z+OgxT+fOIWrP3pQ3DA2x7dSJQv2+fKu9qjRaDTvv7WThpYWp6+MUsyrGgEoDaO7ePFtmVh31D2Xqbj9uh0YD4OVowXdtylK/pEOWXys3k3CTDgk3QgihR8fnwqGJoKhTHk8Vr58jl427foOnc+cSc/IkACpzc+x69cS+WzdU5pkfz5KgSWCT/yZ+vvYzz+OfA1DStiRfVf6KekXqZflKx8kaLb+dDWTuwVuExyYB0KCUA9+1LoOno2WWXiu3knCTDgk3QgihRzodbPsCrm0CExvoczhLtmjIqJiTJwmdM5f4GzcAUNvZYd+zB7adO79VyIlJimG973pW31hNdFJKz4q3gzcDKg2gpkvNLA85kbFJLDh8mzWn7pOk0aFWKXzmU5TBTUpia575RQzzEgk36ZBwI4QQepYUl7LA3+MLYO8JvQ5m2wyqV9FptbzYt4/QeT+SFJiyS7jaxga7Hj2w/fRT1BaZDzmRCZGsvL6SX/1+JV4TD0BFh4r0rdiXuq51szzkBDyL4fs9fhz0TXk0ZmViwFeNvehayx0jg/w5HkfCTTok3AghRC7wIhh+bgKRD6FoLfh8Oxhm/c7c6dElJRG5azfPli4h6cH/Qo61NXY9uqeEHMvMP+55GvuUn6/9zNbbW0nQJAApCwF+UfELGro1zPIxOSfvPGPybj/8gqIA8ChkzphWZWhSxjFbNgHVJwk36ZBwI4QQuUSoX8oMqoQoKP8hdPgZVDnf66BLTiZqzx6eLVlKYkAAACorK2w7dcL2s08xdHTMdJvP4p6x+vpqNt3aRFxyykaZJW1L8kXFL2harGmWhhyNVsfm8w+ZfeAWz6JTAlUdT3u+a12WMi755/echJt0SLgRQohc5N5RWP9hyh5Udb+BxuP0VopOoyFqz16eLVlC4r17ACiGhli1bYt9j+4Ye3llus3n8c9Z57uO327+lrrasbuVO13LdaVt8baYGGRdb9WL+CQWH73LihMBJCZrUSnQsbobQ5uWwsEy69fjyWkSbtIh4UYIIXKZS7/AH/1Tvm47H6p202s5Oq2W6CNHCFu5irgLF1LfN69XF/uePTHz8cn0I5/IhEh+9fuVdX7reJH4AgA7Ezs6le5Ep1KdsnTF44fPY5m+9ya7rwUBYGFswICGnvSo446JoTrLrpPTJNykQ8KNEELkQoenwl8zU6aIf7oZPBvruyIA4i5fJmzVal4cPAhaLQDGXl7YdO6E9fvvo7awyFR7MUkx/H77d9b5ruNJzJOU9tTGtPdsz+dlP6eYVbEsq/3c/edM3uXL1UeRALjZmTK6ZRlalnfOk+NxJNykQ8KNEELkQjod/N4Xrm5M2WSz135wKqfvqlIlBgbyfM1aIrZtQxeXMoZGZWaGVdu22HbuhEnpzG0ImqxN5s8Hf7Lqxip8w3wBUFCoW6QunUp1oo5rnSwZl6PV6vj90mNm7r9JSFTKeJwa7naMbVOWCkWs37n9nCThJh0SboQQIpdKToB1HeDBCbB0gV4HwKaovqtKQxMVReQfOwj/7bfUcTkAppUrY9PxE6yaNUNlZpbh9nQ6HedDzrPmxprUvasAilgUoWOpjrT3bI+Nic071x2bmMyyY/dY9tdd4pNSeqA+rFKEES1K4WSVs7PU3paEm3RIuBFCiFwsLhxWtoCnN1PWwOm5H8wL6buql+h0OmLPniP8t9948eefkJyyi7diZoZVs2ZYt2+PWY3qKJmY/XU/8j4b/Tfyx50/eJGUMi7HWG1MC/cWdCrdiXL25d75cdKTiDhm7ffn90uPATA1VNOvQQn61C2OqVHuHo8j4SYdEm6EECKXi3wMK5unrIFTuDJ02wnGuXeLgaTQUCK3biXi9+2piwICGBYujFW797Fp1w4jd/cMtxebFMvegL1s8N+QukkngJetF+1LtKdNiTbYmbzbooeXH0YwaecNLgZGAOBibcLIFqV537swKlXuHI8j4SYdEm6EECIPeHY7JeDEhoFH/ZRBxga5ezqzTqcj7tIlIn//nai9+9BGR6d+Zly2DFbNW2DVojlGxTI2aFin03Hl6RU2+m/kwP0DJGoTATBQDKhXpB7tPdvzXpH33npHcp1Ox66rQUzfe5PHESnjiCq52TC2TVmqFsu62VtZRcJNOiTcCCFEHvH4AqxuC0kxULY9fLQSVLn70ck/tPHxvPjzEJHbt6ds1vm/mVYAxqVLY9WiOZbNm2Ps4ZGh9iITItkbsJftd7ZzI+xG6vt2Jna09GhJC/cWeDt4v9Vjq/gkDStOBLD4yB1iEjUAtPUuzMgWpShim/HxQ9lNwk06JNwIIUQecvcI/PIxaJOgWi9oPQfy2DTm5OfPefHnn7zYt5+YM2dAo0n9zKh4cSzq1cOiQX3MqlRBMXrz5pe3w2/zx50/2HlvZ+qO5AAu5i40d29OC/cWlLUvm+mgExoVz+wD/my+8AidDowNVPSpW5x+DUpgbmyQqbayg4SbdEi4EUKIPOb6NtjSE9BBveHQ6Dt9V/TWksPD/w06p0+nCToqc3PM69TBon59zN97D0On9Ld9SNImcfLxSfbe38uRwCPEJsemfuZm6UbTYk1p6NaQCoUqoM5Ej9f1x5FM3uXLmYCU4ORoacyw5qX4qEoRvY7HkXCTDgk3QgiRB537GXZ/k/J1o7FQb5h+68kCmqgoYv7+m+ijx4g+fhzN8+dpPjdyd8fMxwdznxqY1aiBQaHXzxqLT47nxOMT7Lu/j2MPj6XuTA4pj67qutaloVtDahWuhZnhmx816XQ69t8IYdpePx6EpYSm8q5WjG1dFp/i9m95x+9Gwk06JNwIIUQedWIe/Dk+5etmU6D2IL2Wk5V0Wi3x16+nBJ2//iL+xo2UhQ3/w8izBGbVq2NWqRImFSti5O7+ykdPsUmxHHt0jCOBRzjx+ETqtHIAI5UR1V2qU8ulFjVdauJl65XuYoEJyRrWnLzPgkN3eJGQMt29RTlnRrcqTTF78yy6+4yRcJMOCTdCCJGHHZsJR6amfN1yFvh8od96sokmMpLY8+eJOXOG2DNnSfD3f+kYtbU1JhUrYlqxIqbeFTEpUwZ1oUJpAk+SNomLIRc5+vAoxx4d4+GLh2nasDOxo4ZzDXxcfPBx9qGIZZFXBqaw6AR++PMWv54JRKsDI7WKHnXcGdDIEyuTf2drabU6gm5HEBOVgLmVMS5eNln2KEvCTTok3AghRB6m08HhyXB8Tsr3beZBtR56LSknJIeHE3v2HHEXLxJ35Qrxvr7oEhNfOk5ta4txqVKYlCqJccmSGJcshXFxD1Tm5uh0Ou5F3uPE4xOcDjrNhZALxCXHpTnfzsQObwdvKjlWwtvBm3L25dLsXO4f/IIpu305fvsZAPbmRgxtVpKO1dx4cPUZxzfeJiYiIfV4cxtj6nb0okTl9McPZUSeCzeLFi1i1qxZBAcH4+3tzYIFC6hRo8Ybz9uwYQOdO3emXbt2bN++PUPXknAjhBB5nE4HB76DUwsBBdovhkpd9F1VjtIlJhLvf4u4q1eIv3qVuKvXSHzwIM2U8/9SOxTCqFgxjIoWw6hoUYzci6EUduGWwTPOxN/kdMgZrj27RrI2Oc15BooBXrZelLIrRSnbUpSyK0VJm5JcuB/PlN1+3HsaA0ADM3OqP3n1tQFa9C3/zgEnT4WbjRs30rVrV5YuXYqPjw/z5s1j8+bN+Pv74+j4+j+I+/fv895771G8eHHs7Owk3AghREGi08HeEXD2J0CBdguh8mf6rkqvtPHxJNy5S4K/Pwm3/In3v0XCrVsvDVR+iYEBBg4OqJ0ciLUx4amZhofqSO5qQwhRx/DCFKJNFaJNIN4IEgzBztoZD1tP4mJsuXLXgM5362ChNUTh1Y+gLGyN+Xxq7Xd6RJWnwo2Pjw/Vq1dn4cKFAGi1Wtzc3Bg0aBCjRo165TkajYZ69erRs2dPjh8/TkRExGvDTUJCAgkJ/3aRRUVF4ebmJuFGCCHyOq0W9nwD51emfN96DlTvrd+aciFNZCSJgYEkPggk8cF9kv75+vEjNM/CXhq4nFHJqpSgE2brxZ3Sg994fPshlXEt9fYrH2cm3Oh1VZ7ExEQuXLjA6NGjU99TqVQ0adKEU6dOvfa8SZMm4ejoSK9evTh+/Hi615g2bRoTJ07MspqFEELkEioVtJ4LamM4syRlqnhyAtQaoO/KchW1tTWmFSpgWqHCS5/pkpJIfvaM5JAQkkJCSQ4JIflpKJqISDSR/3tFRKT+ry7+3ynmBlowSIAX2ox1FMREJbz5oCyi13Dz7NkzNBoNTk5Oad53cnLi5s2brzznxIkTrFixgsuXL2foGqNHj2bo0KGp3//TcyOEECIfUBRoMQ0MTeDED7B/DCTF5Yt1cHKCYmiIoYsLhi4umGbgeJ1Wiy4hAW18PLr4eLTx8f/X3r1HR1Xeaxz/ziSZSUxCEgnmwl1uqUAiBEmjoggpFC2CtUotBxGtFwwcUzw9B1ol2tUjqG2XqBy1eO05VRApWl0FjSHEilwDkZtGSdFgyUWgkJCAgcx7/tgymkIjMZPZmZ3ns9asNfvdOzO/+a2QediXdxO5p5bdKw5+489GdwnevcHsn0+5Ferq6pg2bRpLliwhsYXJjL7O6/Xi9Xbsm62JiEgbuFwwNh/Co2DtA9bVVCePwxW/DLlbNXR0LrcbV1QU7qivolDv3obo1QXU17uBM8+ZE5NgXRYeLLaGm8TERMLCwqiurm42Xl1dTXJy8mnbl5eX88knnzBx4kT/mO/LM8PDw8MpKyujX79+7Vu0iIh0PC4XjP4v687hb+fDOw9bdxS/8jchc7PNUOX++2ZGeR5hdf3dgIEznFR86fUDgnrrhn89LWEQeDweMjMzKSws9I/5fD4KCwvJzs4+bfu0tDR27NhBaWmp/3H11VdzxRVXUFpaqsNNIiKd3aV5VqDBZZ1o/PKNcOL4N/2UfFv/+AReuoF+3nV8f8gaouMjm62OSfAG5DLw1rL9sNScOXOYPn06I0aMYOTIkTzyyCPU19czY4Y1KdONN95I9+7dWbBgAZGRkQwZMqTZz8fHxwOcNi4iIp3UyFshuhv86Vb48A3432vghpcgKt7uypzl2GH44/XQcACS0+k3Yx59I6LbbYbi1rA93EyZMoXPP/+c+fPnU1VVxYUXXsjq1av9JxlXVFTgdtu6g0lERELN4MlwTldY+hOoeA+emwBTX4G47nZX5gxNJ6y9YgfKIDYVfrIMvDG4oU2XeweK7fPcBJsm8RMR6USqdsD//QiOVkFMsrUHp/twu6sKbT4fvJYL778IEdFw82pISW/3t23N97d2iYiIiHMlD4Vb3oJuaVbAee5K2PWq3VWFLmPgzXlWsHGFwY+eDUqwaS2FGxERcbaE3nBLAfT/Hpw8BsunQ/HD33pm3k5t7ULY+KT1fPL/wKDv21vPv6BwIyIizhfZxTov5Lt3WstFv4YVP4XGenvrCiXvPQbFC63nV/4GMn5sbz0tULgREZHOwR1mzWb8g0fAHQ47X4Gnc+DAHrsr6/j++lvrTuwAY+61rkjrwBRuRESkcxkxA258DaLPg5rd8PvRsPs1u6vqmIyBogeg8FfW8uh5MOpue2s6Cwo3IiLS+fS5FO74K/S6GBrrrMuaV/8CTjbaXVnH4fNZe2uKH7SWc+6H0XND4pYWCjciItI5xSbD9D/DxbOt5Q2L4ekx8HmZvXV1BCeOw4pbYP3j1vKEh6zZn0OEwo2IiHReYREw7tfw4xch6lxrXpynLoNNSzrv1VT1B+EPk2DXn8AdAZOfhKzb7a6qVRRuRERE0q6Cme9BvzHWHcX/8h/wx+vgyGd2VxZc1bvgmRzYtwG8cfBvK+DCG+yuqtUUbkRERAC6pMDUFfD9ByHMC3sKYHEWbPw9+Jrsrq79vb8UloyFQ3+DuF7W5IfnX253Vd+Kwo2IiMgpbjd89w64/R3omQWNR2HVz+HZ8VC92+7q2kdjA7yeBytvtyY57DcGblsL56XZXdm3pnAjIiLyz85Lgxmr4arfgicWPtsMT42CVXOh4ZDd1QXOvi8/V8lzgAsun2vdYDS6q92VtYnCjYiIyJm43XDRT2HWJkj7AfhOwsYn4LHhsPEp687YoerEMXj7Pnh2HBzcA7Ep1vk1V8yzJjsMcboruIiIyNkoL4I3f2FN/Adw7vlw2X/C0OsgLNze2s6WMfDhG9bnOFxhjaVPgQkPQlSCvbV9g9Z8fyvciIiInK2mk7DtD7Dmv6HhgDV27vlw2c+/DDkR9tbXksrtUHAv/G2ttRybClc+BN+ZaGtZZ0vhpgUKNyIi0mZfHIUtz8C6RdBw0BqLTYERt0DmTRDTzdbymtlfas0yXPYXaznMAxf/O4yaA55oW0trDYWbFijciIhIwJwKOe89DvU11liYBwZfYx3u6Xu5PYesmk5aYWbLM1/tqcEFQ66FMb+09jaFGIWbFijciIhIwJ1shN2vwsYn4e8lX43HJFmB4jsTocfI9g06xsD+bfDBn605a+oqrXGXG4b8yDp01m1g+71/O1O4aYHCjYiItKvPtkDpi7BrJRz72mXj3jjoNxr6XgbdR0DS4Lafo1NbCRXvwafvQdlqqP3ajMrR3WDYNOswWULvtr1PB6Bw0wKFGxERCYqTjVC+Bna+AnvehmP/aL4+PMoKOF37Qdf+EN8Lzulq3eMq8mvfT74mKyQ1HIT6z+FguXVzz8/L4EhF89eMiIYB34PBk2HQVRDuafePGSwKNy1QuBERkaDzNVmHjPa8Dfs2wmcl8MWRALywC5KHQO9LrPN7+l0BEVEBeN2OpzXf3yFyYb6IiEgIc4dBjxHWA8DnsybPq9kNh8rh4N+sQ0oNh6w9PF/UfvmDLuucmagEa6/OOV0hoY917kziQEgaAlHxNn2ojkvhRkREJNjcbiughPAJvh2Zbr8gIiIijqJwIyIiIo6icCMiIiKOonAjIiIijqJwIyIiIo6icCMiIiKOonAjIiIijqJwIyIiIo6icCMiIiKOonAjIiIijqJwIyIiIo6icCMiIiKOonAjIiIijqJwIyIiIo4SbncBwWaMAaC2ttbmSkRERORsnfrePvU93pJOF27q6uoA6Nmzp82ViIiISGvV1dURFxfX4jYuczYRyEF8Ph/79+8nNjYWl8sV0Neura2lZ8+e7Nu3jy5dugT0teUr6nNwqM/BoT4Hj3odHO3VZ2MMdXV1pKam4na3fFZNp9tz43a76dGjR7u+R5cuXfQPJwjU5+BQn4NDfQ4e9To42qPP37TH5hSdUCwiIiKOonAjIiIijqJwE0Ber5f8/Hy8Xq/dpTia+hwc6nNwqM/Bo14HR0foc6c7oVhEREScTXtuRERExFEUbkRERMRRFG5ERETEURRuRERExFEUbgJk8eLF9OnTh8jISLKysti0aZPdJYW8d955h4kTJ5KamorL5eLVV19ttt4Yw/z580lJSSEqKoqcnBw+/vhje4oNUQsWLOCiiy4iNjaW8847j8mTJ1NWVtZsm+PHj5Obm0vXrl2JiYnh2muvpbq62qaKQ9cTTzxBenq6f2Kz7OxsVq1a5V+vPgfewoULcblc5OXl+cfU58C47777cLlczR5paWn+9Xb3WeEmAJYtW8acOXPIz89n69atZGRkMH78eGpqauwuLaTV19eTkZHB4sWLz7j+oYce4tFHH+XJJ59k48aNREdHM378eI4fPx7kSkNXcXExubm5bNiwgYKCAk6cOMG4ceOor6/3b/Ozn/2M119/neXLl1NcXMz+/fv54Q9/aGPVoalHjx4sXLiQkpIStmzZwpgxY5g0aRK7du0C1OdA27x5M0899RTp6enNxtXnwBk8eDCVlZX+x7vvvutfZ3ufjbTZyJEjTW5urn+5qanJpKammgULFthYlbMAZuXKlf5ln89nkpOTzcMPP+wfO3z4sPF6veall16yoUJnqKmpMYApLi42xlg9jYiIMMuXL/dv88EHHxjArF+/3q4yHSMhIcE8/fTT6nOA1dXVmQEDBpiCggJz+eWXm7vuussYo9/nQMrPzzcZGRlnXNcR+qw9N23U2NhISUkJOTk5/jG3201OTg7r16+3sTJn27t3L1VVVc36HhcXR1ZWlvreBkeOHAHg3HPPBaCkpIQTJ04063NaWhq9evVSn9ugqamJpUuXUl9fT3Z2tvocYLm5uVx11VXN+gn6fQ60jz/+mNTUVM4//3ymTp1KRUUF0DH63OlunBloBw4coKmpiaSkpGbjSUlJfPjhhzZV5XxVVVUAZ+z7qXXSOj6fj7y8PC655BKGDBkCWH32eDzEx8c321Z9/nZ27NhBdnY2x48fJyYmhpUrV3LBBRdQWlqqPgfI0qVL2bp1K5s3bz5tnX6fAycrK4vnn3+eQYMGUVlZyf3338+oUaPYuXNnh+izwo2IANb/dnfu3NnsuLkE1qBBgygtLeXIkSO88sorTJ8+neLiYrvLcox9+/Zx1113UVBQQGRkpN3lONqECRP8z9PT08nKyqJ37968/PLLREVF2ViZRYel2igxMZGwsLDTzgKvrq4mOTnZpqqc71Rv1ffAmDVrFm+88QZFRUX06NHDP56cnExjYyOHDx9utr36/O14PB769+9PZmYmCxYsICMjg0WLFqnPAVJSUkJNTQ3Dhw8nPDyc8PBwiouLefTRRwkPDycpKUl9bifx8fEMHDiQPXv2dIjfZ4WbNvJ4PGRmZlJYWOgf8/l8FBYWkp2dbWNlzta3b1+Sk5Ob9b22tpaNGzeq761gjGHWrFmsXLmSNWvW0Ldv32brMzMziYiIaNbnsrIyKioq1OcA8Pl8fPHFF+pzgIwdO5YdO3ZQWlrqf4wYMYKpU6f6n6vP7ePo0aOUl5eTkpLSMX6fg3LassMtXbrUeL1e8/zzz5vdu3eb2267zcTHx5uqqiq7SwtpdXV1Ztu2bWbbtm0GML/73e/Mtm3bzKeffmqMMWbhwoUmPj7evPbaa2b79u1m0qRJpm/fvubYsWM2Vx46Zs6caeLi4szatWtNZWWl/9HQ0ODf5o477jC9evUya9asMVu2bDHZ2dkmOzvbxqpD09y5c01xcbHZu3ev2b59u5k7d65xuVzmrbfeMsaoz+3l61dLGaM+B8rdd99t1q5da/bu3WvWrVtncnJyTGJioqmpqTHG2N9nhZsAeeyxx0yvXr2Mx+MxI0eONBs2bLC7pJBXVFRkgNMe06dPN8ZYl4Pfe++9JikpyXi9XjN27FhTVlZmb9Eh5kz9Bcxzzz3n3+bYsWPmzjvvNAkJCeacc84x11xzjamsrLSv6BB18803m969exuPx2O6detmxo4d6w82xqjP7eWfw436HBhTpkwxKSkpxuPxmO7du5spU6aYPXv2+Nfb3WeXMcYEZx+RiIiISPvTOTciIiLiKAo3IiIi4igKNyIiIuIoCjciIiLiKAo3IiIi4igKNyIiIuIoCjciIiLiKAo3IiIi4igKNyISUm666SYmT55sdxki0oGF212AiMgpLperxfX5+fksWrQITawuIi1RuBGRDqOystL/fNmyZcyfP5+ysjL/WExMDDExMXaUJiIhRIelRKTDSE5O9j/i4uJwuVzNxmJiYk47LDV69Ghmz55NXl4eCQkJJCUlsWTJEurr65kxYwaxsbH079+fVatWNXuvnTt3MmHCBGJiYkhKSmLatGkcOHAgyJ9YRNqDwo2IhLwXXniBxMRENm3axOzZs5k5cybXXXcdF198MVu3bmXcuHFMmzaNhoYGAA4fPsyYMWMYNmwYW7ZsYfXq1VRXV3P99dfb/ElEJBAUbkQk5GVkZHDPPfcwYMAA5s2bR2RkJImJidx6660MGDCA+fPnc/DgQbZv3w7A448/zrBhw3jggQdIS0tj2LBhPPvssxQVFfHRRx/Z/GlEpK10zo2IhLz09HT/87CwMLp27crQoUP9Y0lJSQDU1NQA8P7771NUVHTG83fKy8sZOHBgO1csIu1J4UZEQl5ERESzZZfL1Wzs1FVYPp8PgKNHjzJx4kQefPDB014rJSWlHSsVkWBQuBGRTmf48OGsWLGCPn36EB6uP4MiTqNzbkSk08nNzeXQoUPccMMNbN68mfLyct58801mzJhBU1OT3eWJSBsp3IhIp5Oamsq6detoampi3LhxDB06lLy8POLj43G79WdRJNS5jKb6FBEREQfRf1FERETEURRuRERExFEUbkRERMRRFG5ERETEURRuRERExFEUbkRERMRRFG5ERETEURRuRERExFEUbkRERMRRFG5ERETEURRuRERExFH+H9+kC5g3I9F2AAAAAElFTkSuQmCC"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "times = np.linspace(0, 50, 1000)\n",
    "plt.plot(times, linear(times), label='Linear')\n",
    "plt.plot(times, cs(times), label='Py CubicSpline')\n",
    "plt.plot(times, pchip(times), label='Py Pchip')\n",
    "plt.plot(times, spline_hyman(robjects.FloatVector(times)), label='R hyman')\n",
    "plt.plot(times_coordinate, survival_curve, 'o', label='Data')\n",
    "\n",
    "plt.xlabel('Time')\n",
    "plt.ylabel('Survival Probability')\n",
    "plt.legend()\n",
    "plt.show()"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2023-08-16T06:44:23.443623782Z",
     "start_time": "2023-08-16T06:44:23.325013339Z"
    }
   },
   "id": "109b441cff7ad73b"
  },
  {
   "cell_type": "markdown",
   "source": [
    "## Compare Running Times\n",
    "First we would like to randomly generate 1000 curves to compare the running times of the different methods."
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "99ebbc10f6a6ee22"
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "outputs": [],
   "source": [
    "times_coordinate = np.array([0, 1, 5, 8, 10, 15, 25, 30, 50, 70, 100])\n",
    "times = np.linspace(0, 100, 1000)\n",
    "# randomize the survival curves\n",
    "pdf_pre = np.random.rand(len(times_coordinate), 1000)\n",
    "pdf = pdf_pre / pdf_pre.sum(axis=0)\n",
    "cdf = pdf.cumsum(axis=0)\n",
    "cdf = np.insert(cdf, 0, 0, axis=0)\n",
    "survival_curve = (1 - cdf).clip(min=0, max=1)\n",
    "survival_curve = survival_curve[:-1, ].T"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2023-08-16T06:44:24.998876977Z",
     "start_time": "2023-08-16T06:44:24.992346882Z"
    }
   },
   "id": "ce4778c028001932"
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[1.         0.99000991 0.98383243 0.84575129 0.64087232 0.47315719\n",
      "  0.35469346 0.27314956 0.23574757 0.16644224 0.0543155 ]\n",
      " [1.         0.90284451 0.81048243 0.79159778 0.66069779 0.54011476\n",
      "  0.50119073 0.44214459 0.38681926 0.24828344 0.14190133]\n",
      " [1.         0.97450667 0.94388436 0.83456417 0.72816452 0.64222135\n",
      "  0.47553668 0.45513829 0.34488453 0.23495475 0.15865596]\n",
      " [1.         0.82158957 0.70475668 0.64573626 0.4841139  0.45353438\n",
      "  0.41664692 0.29850521 0.26742307 0.14408521 0.01453842]\n",
      " [1.         0.89953754 0.8190252  0.76150169 0.72150274 0.66017807\n",
      "  0.64202433 0.46249787 0.28885175 0.2523546  0.12187288]]\n"
     ]
    }
   ],
   "source": [
    "print(survival_curve[:5])"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2023-08-16T06:44:25.688528573Z",
     "start_time": "2023-08-16T06:44:25.680325104Z"
    }
   },
   "id": "e2bfa2c4416dd674"
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 640x480 with 1 Axes>",
      "image/png": "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"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(times_coordinate, survival_curve[0, :], 'o-')\n",
    "plt.plot(times_coordinate, survival_curve[1, :], 'o-')\n",
    "plt.plot(times_coordinate, survival_curve[2, :], 'o-')\n",
    "plt.plot(times_coordinate, survival_curve[3, :], 'o-')\n",
    "plt.plot(times_coordinate, survival_curve[4, :], 'o-')\n",
    "plt.xlabel('Time')\n",
    "plt.ylabel('Survival Probability')\n",
    "plt.show()"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2023-08-16T06:44:26.519818294Z",
     "start_time": "2023-08-16T06:44:26.442270750Z"
    }
   },
   "id": "95900066706670cb"
  },
  {
   "cell_type": "markdown",
   "source": [
    "Measuring the time using certain function"
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "7b885a0fcf6a2dfc"
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "outputs": [],
   "source": [
    "from Evaluations.util import predict_mean_survival_time, predict_median_survival_time, predict_prob_from_curve\n",
    "\n",
    "predict_time_method = \"Median\"\n",
    "target_time = 20\n",
    "if predict_time_method == \"Median\":\n",
    "    predict_method = predict_median_survival_time\n",
    "elif predict_time_method == \"Mean\":\n",
    "    predict_method = predict_mean_survival_time\n",
    "\n",
    "def predict_time(predicted_curve, time_coordinates, interpolation):\n",
    "    predicted_times = []\n",
    "    for i in range(predicted_curve.shape[0]):\n",
    "        predicted_time = predict_method(predicted_curve[i, :], time_coordinates, interpolation)\n",
    "        predicted_times.append(predicted_time)\n",
    "    predicted_times = np.array(predicted_times)\n",
    "    return predicted_times\n",
    "\n",
    "def predict_prob(predicted_curve, time_coordinates, interpolation):\n",
    "    predict_probs = []\n",
    "    for i in range(predicted_curve.shape[0]):\n",
    "        predict_prob = predict_prob_from_curve(predicted_curve[i, :], time_coordinates,\n",
    "                                               target_time, interpolation)\n",
    "        predict_probs.append(predict_prob)\n",
    "    predict_probs = np.array(predict_probs)\n",
    "    return predict_probs"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2023-08-16T06:44:28.903828578Z",
     "start_time": "2023-08-16T06:44:28.121288015Z"
    }
   },
   "id": "cd7612c2cc917c2d"
  },
  {
   "cell_type": "markdown",
   "source": [
    "Choose the function to run, predict_time or predict_prob"
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "1941db9d675cf73a"
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "outputs": [],
   "source": [
    "function = predict_prob"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2023-08-16T06:44:30.449571935Z",
     "start_time": "2023-08-16T06:44:30.440003454Z"
    }
   },
   "id": "fe382d7c6258c023"
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Linear:  0:00:00.092402\n",
      "Pchip:  0:00:00.141584\n",
      "Hyman:  0:00:00.398595\n"
     ]
    }
   ],
   "source": [
    "import datetime\n",
    "\n",
    "start_time = datetime.datetime.now()\n",
    "predicted_times_linear = function(survival_curve, times_coordinate, 'Linear')\n",
    "end_time = datetime.datetime.now()\n",
    "linear_time = end_time - start_time\n",
    "print(\"Linear: \", linear_time)\n",
    "\n",
    "start_time = datetime.datetime.now()\n",
    "predicted_times_pchip = function(survival_curve, times_coordinate, 'Pchip')\n",
    "end_time = datetime.datetime.now()\n",
    "pchip_time = end_time - start_time\n",
    "print(\"Pchip: \", pchip_time)\n",
    "\n",
    "start_time = datetime.datetime.now()\n",
    "predicted_times_hyman = function(survival_curve, times_coordinate, 'Hyman')\n",
    "end_time = datetime.datetime.now()\n",
    "hyman_time = end_time - start_time\n",
    "print(\"Hyman: \", hyman_time)"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2023-08-16T06:44:34.124012536Z",
     "start_time": "2023-08-16T06:44:33.481743878Z"
    }
   },
   "id": "e8335e3d1148e46f"
  },
  {
   "cell_type": "markdown",
   "source": [
    "Plot the running times for visual comparison"
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "be9cf6a989bcc4c1"
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 640x480 with 1 Axes>",
      "image/png": "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9tprVVRUpI0bN0qSPv/8c1122WUeLxAAAMDT3D4DtGzZMgUEBOiVV17RihUr1KFDB0nSm2++qbS0NI8XCAAA4GlunwG6/PLL9dprr9VpX7x4sUcKAgAA8LYGBSB35vYwaRgAADR1DQpAbdu2lclkatCANTU1F1UQAACAtzUoAG3ZssX584EDBzRr1ixNmDDB+WTlwsJCrVu3Tjk5Od6pEgAAwIMaFIAGDRrk/Pnxxx/XokWLNG7cOGfbiBEj1KNHDz399NNKT0/3fJUAAAAe5PZdYIWFhUpKSqrTnpSUpKKiIo8UBQAA4E1uB6DY2FitWrWqTvszzzyj2NhYjxQFAADgTW7fBr948WLdcsstevPNN5WcnCxJKioq0r59+/SXv/zF4wUCAAB4mttngIYOHap9+/Zp+PDh+uabb/TNN99o+PDh+vzzzzV06FBv1AgAAOBRbp8BkqTLLrtMv//97z1dCwAAQKO4oABUVlamoqIiHTt2TLW1tS7rxo8f75HCAAAAvMXtAPSPf/xDd9xxhyoqKhQaGurygESTyUQAAgAATZ7bc4CmTZumu+66SxUVFSorK9OpU6ecyzfffOONGgEAADzK7QB0+PBhTZ06Va1atfJGPQAAAF7ndgBKTU3Vhx9+6I1aAAAAGoXbc4CGDRumGTNmaM+ePerRo4cuueQSl/UjRozwWHEAAADe4HYAmjRpkqQf3wn2cyaTibfBAwCAJs/tAPTz294BAACaG7fnAAEAADR3FxSA3n33XQ0fPlwJCQlKSEjQiBEj9N5773m6NgAAAK9wOwA9//zzslgsatWqlaZOnaqpU6cqODhYN954o1544QVv1AgAAOBRJofD4XBng27duunuu+/WQw895NK+aNEirVq1Snv37vVogb5gt9sVFham8vJyhYaG+rocAGhx4ma97usS4EMHcod5ZVx3/n67fQboP//5j4YPH16nfcSIEdq/f7+7wwEAADQ6twNQbGysbDZbnfZ33nlHsbGxHikKAADAm9y+DX7atGmaOnWqiouLdc0110iS/vWvf2nt2rVasmSJxwsEAADwNLcD0OTJkxUVFaWFCxfqpZdekvTjvKCNGzdq5MiRHi8QAADA09wOQJI0evRojR492tO1AAAANAq35wB98MEH2r59e5327du385JUAADQLLgdgO677z59/fXXddoPHz6s++67zyNFAQAAeJPbAWjPnj3q06dPnfbevXtrz549HikKAADAm9wOQGazWaWlpXXajx49qoCAC5pSpOXLlysuLk5BQUFKTk5WUVHROfuuWrVKAwcOVHh4uMLDw2WxWOr0nzBhgkwmk8uSlpZ2QbUBAICWx+0ANHjwYGVmZqq8vNzZVlZWpkceeUQ33XST2wVs3LhRVqtV2dnZ2rlzp3r16qXU1FQdO3as3v4FBQUaN26ctmzZosLCQsXGxmrw4ME6fPiwS7+0tDQdPXrUubz44otu1wYAAFomt1+FcfjwYV133XU6efKkevfuLUkqLi5WZGSkNm/e7PbDEJOTk9WvXz8tW7ZMklRbW6vY2Fjdf//9mjVr1nm3r6mpUXh4uJYtW6bx48dL+vEMUFlZmTZt2uRWLWfxKgwA8C5ehWFszfJVGB06dNDu3bs1f/58de/eXX379tWSJUv08ccfux1+qqurtWPHDlkslv8W5Ocni8WiwsLCBo1x5swZff/992rXrp1Le0FBgdq3b68uXbpo8uTJOnnypFu1AQCAluuCJu2EhITo7rvvvugvP3HihGpqahQZGenSHhkZqU8//bRBYzz88MOKiYlxCVFpaWm6+eabFR8fry+//FKPPPKIhgwZosLCQvn7+9cZo6qqSlVVVc7Pdrv9AvcIAAA0B26fAZKk9evXa8CAAYqJidFXX30lSVq8eLH+9re/ebS488nNzdWGDRv017/+VUFBQc72sWPHasSIEerRo4dGjRql1157TR988IEKCgrqHScnJ0dhYWHOhXeaAQDQsrkdgFasWCGr1aohQ4bo1KlTqqmpkSSFh4crLy/PrbEiIiLk7+9f566y0tJSRUVF/eK2CxYsUG5urt5++2317NnzF/t27NhRERER+uKLL+pdf3ZS99mlvuccAQCAlsPtAPTUU09p1apVevTRR11ue09KStLHH3/s1liBgYHq27evy9vla2trZbPZlJKScs7t5s+fr3nz5ik/P19JSUnn/Z5Dhw7p5MmTio6Orne92WxWaGioywIAAFoutwPQ/v37nXd//ZTZbFZlZaXbBVitVq1atUrr1q3T3r17NXnyZFVWViojI0OSNH78eGVmZjr7P/nkk3rssce0evVqxcXFqaSkRCUlJaqoqJAkVVRUaMaMGdq2bZsOHDggm82mkSNHKiEhQampqW7XBwAAWh63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gGpqarR27VrZbDYdO3ZMtbW1Luv/+c9/eqw4AAAAb3A7AD3wwANau3athg0bpquvvlomk8kbdQEAAHiN2wFow4YNeumllzR06FBv1AMAAOB1bt8FFhgYqISEBG/UAgAA0CjcDkDTpk3TkiVL5HA4vFEPAACA17l9CWzr1q3asmWL3nzzTV111VW65JJLXNa/+uqrHisOAADAG9wOQG3bttXo0aO9UQsAAECjcDsArVmzxht1AAAANBq35wABAAA0dw06A9SnTx/ZbDaFh4erd+/ev/jsn507d3qsOAAAAG9oUAAaOXKkzGazJGnUqFHerAcAAMDrGhSAsrOz6/3ZE5YvX64//OEPKikpUa9evfTUU0+pf//+9fb997//raysLO3YsUNfffWVFi9erAcffNClz5w5czR37lyXti5duujTTz/1aN0AAKD5uuCXoVZXV9f7LrDLL7+8wWNs3LhRVqtVK1euVHJysvLy8pSamqrPPvtM7du3r9P/zJkz6tixo2677TY99NBD5xz3qquu0jvvvOP8HBBwwbsJAABaILeTweeff66JEyfq/fffd2l3OBwymUyqqalp8FiLFi3SpEmTlJGRIUlauXKlXn/9da1evVqzZs2q079fv37q16+fJNW7/qyAgABFRUU1uA4AAGAsbgegjIwMBQQE6LXXXlN0dPQFvwy1urpaO3bsUGZmprPNz89PFotFhYWFFzTmWfv27VNMTIyCgoKUkpKinJycXzwzVVVVpaqqKudnu91+Ud8PAACaNrcDUHFxsXbs2KGuXbte1BefOHFCNTU1ioyMdGmPjIy8qPk6ycnJWrt2rbp06aKjR49q7ty5GjhwoD755BO1adOm3m1ycnLqzBsCAAAtl9vPAerevbtOnDjhjVo8YsiQIbrtttvUs2dPpaam6o033lBZWZleeumlc26TmZmp8vJy5/L11183YsUAAKCxuX0G6Mknn9TMmTP1+9//Xj169KjzLrDQ0NAGjRMRESF/f3+Vlpa6tJeWlnp0/k7btm115ZVX6osvvjhnH7PZ7LzNHwAAtHxunwGyWCzatm2bbrzxRrVv317h4eEKDw9X27ZtFR4e3uBxAgMD1bdvX9lsNmdbbW2tbDabUlJS3C3rnCoqKvTll18qOjraY2MCAIDmze0zQFu2bPHYl1utVqWnpyspKUn9+/dXXl6eKisr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IUGPP/64fvjhB4+MzzGNs871u6+goEAmk0llZWWNXhM8x+e3waN5O9cTuxuTw+FQTU2NAgI4nI0iLS1Na9asUVVVld544w3dd999uuSSS1xerHyhmsIxDcD7OAOEi/LTywUHDhyQyWTSq6++qhtuuEGtWrVSr169VFhY6LLN1q1bNXDgQAUHBys2NlZTp05VZWWlc/369euVlJSkNm3aKCoqSrfffruOHTvmXH/2/77efPNN9e3bV2azWVu3bm2U/UXTYDabFRUVpSuuuEKTJ0+WxWLR3//+d0nSv/71L11//fVq1aqVwsPDlZqaqlOnTjm3ra2t1cyZM9WuXTtFRUVpzpw5LmPXd0xv2LBB11xzjYKCgnT11Vfr3XffbaxdRRNWWVmp0NBQvfLKKy7tmzZtUkhIiE6fPu08hl566SXn771+/frp888/1wcffKCkpCS1bt1aQ4YM0fHjx51jfPDBB7rpppsUERGhsLAwDRo0SDt37nT5HpPJpGeeeUajR49Wq1at1LlzZ+d/Bzg/AhA87tFHH9X06dNVXFysK6+8UuPGjXNenvjyyy+VlpamW265Rbt379bGjRu1detWTZkyxbn9999/r3nz5umjjz7Spk2bdODAAU2YMKHO98yaNUu5ubnau3evevbs2Vi7hyYoODhY1dXVKi4u1o033qju3bursLBQW7du1fDhw1VTU+Psu27dOoWEhGj79u2aP3++Hn/8cW3evPkXx58xY4amTZumXbt2KSUlRcOHD9fJkye9vVto4kJCQjR27FitWbPGpX3NmjW69dZb1aZNG2dbdna2Zs+erZ07dyogIEC33367Zs6cqSVLlui9997TF198oaysLGf/06dPKz09XVu3btW2bdvUuXNnDR06VKdPn3b5rrlz5+p///d/tXv3bg0dOlR33HGHvvnmG+/ueEvhAM4jPT3dMXLkyHrXSXL89a9/dTgcDsf+/fsdkhzPPPOMc/2///1vhyTH3r17HQ6HwzFx4kTH3Xff7TLGe++95/Dz83N8++239X7HBx984JDkOH36tMPhcDi2bNnikOTYtGnTRe4ZmqOfHo+1tbWOzZs3O8xms2P69OmOcePGOa699tpzbjto0CDHgAEDXNr69evnePjhh52f6zumc3Nzneu///57x2WXXeZ48sknPbdTaJLS09Md/v7+jpCQEJclKCjIIclx6tQpx/bt2x3+/v6OI0eOOBwOh6O0tNQREBDgKCgocDgc9f9efPHFFx2SHDabzdmWk5Pj6NKlyzlrqampcbRp08bxj3/8w9kmyTF79mzn54qKCockx5tvvumxfwctGWeA4HE/PRsTHR0tSc5LWB999JHWrl2r1q1bO5fU1FTV1tZq//79kqQdO3Zo+PDhuvzyy9WmTRsNGjRI0o+vRfmppKSkxtgdNEGvvfaaWrduraCgIA0ZMkRjxozRnDlznGeAfsnPzxZGR0e7XGKtz09fpBwQEKCkpCTt3bv3wncAzcYNN9yg4uJil+WZZ55xru/fv7+uuuoqrVu3TpL0/PPP64orrtB1113nMs5Pj7uzr3rq0aOHS9tPj8PS0lJNmjRJnTt3VlhYmEJDQ1VRUVHn9+BPxw0JCVFoaOh5j2f8iFmj8LhLLrnE+bPJZJL047wLSaqoqNA999yjqVOn1tnu8ssvV2VlpVJTU5Wamqo///nPuvTSS3Xw4EGlpqaqurrapX9ISIgX9wJN2Q033KAVK1YoMDBQMTExzgnwwcHB5932p8en9OMxevb4BH4uJCRECQkJLm2HDh1y+fzb3/5Wy5cv16xZs7RmzRplZGQ4f/edVd/vxZ+3/fQ4TE9P18mTJ7VkyRJdccUVMpvNSklJqfN7kOP5wnEGCI2qT58+2rNnjxISEuosgYGB+vTTT3Xy5Enl5uZq4MCB6tq1K/83gzrO/lG6/PLLXe7+69mzp2w2m8e/b9u2bc6ff/jhB+3YsUPdunXz+Pegebrzzjv11VdfaenSpdqzZ4/S09Mvesx//etfmjp1qoYOHaqrrrpKZrNZJ06c8EC1OIszQGiQ8vJyFRcXu7T96le/cnuchx9+WL/+9a81ZcoU/fa3v1VISIj27NmjzZs3a9myZbr88ssVGBiop556Svfee68++eQTzZs3z0N7gZYuMzNTPXr00O9+9zvde++9CgwM1JYtW3TbbbcpIiLigsddvny5OnfurG7dumnx4sU6deqU7rrrLg9WjuYsPDxcN998s2bMmKHBgwfrsssuu+gxO3fu7Lwj1m63a8aMGQ06w4mG4wwQGqSgoEC9e/d2WebOnev2OD179tS7776rzz//XAMHDlTv3r2VlZWlmJgYSdKll16qtWvX6uWXX1b37t2Vm5urBQsWeHp30EJdeeWVevvtt/XRRx+pf//+SklJ0d/+9reLfkZUbm6ucnNz1atXL23dulV///vfLypQoeWZOHGiqqurPRaMn332WZ06dUp9+vTRb37zG02dOlXt27f3yNj4kcnhcDh8XQQANEUHDhxQfHy8du3apcTERF+XgyZs/fr1euihh3TkyBEFBgb6uhw0AJfAAAC4QGfOnNHRo0eVm5ure+65h/DTjHAJDACACzR//nx17dpVUVFRHnkVCxoPl8AAAIDhcAYIAAAYDgEIAAAYDgEIAAAYDgEIAAAYDgEIAAAYDgEIAAAYDgEIAAAYDgEIAAAYDgEIAAAYzv8D1wU52xHhDcoAAAAASUVORK5CYII="
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.bar(['Linear', 'Pchip', 'Hyman'], [linear_time.total_seconds(), pchip_time.total_seconds(), hyman_time.total_seconds()])\n",
    "plt.ylabel('Running Time (seconds)')\n",
    "plt.show()"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2023-08-16T06:44:36.725777911Z",
     "start_time": "2023-08-16T06:44:36.619957141Z"
    }
   },
   "id": "fab6ee6d8648c8e5"
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "outputs": [],
   "source": [],
   "metadata": {
    "collapsed": false
   },
   "id": "1f2497aa27349886"
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 2
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython2",
   "version": "2.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
