{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "794ad920",
   "metadata": {},
   "source": [
    "# Deomnstrations for predictor-corrector in regression and object-tracking example\n",
    "\n",
    "## Regression model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "59484d04",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZIAAAERCAYAAABRpiGMAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAABqkUlEQVR4nO2deXxTVfr/P6dpui9p2SlICSAIsrWAKKOiFJgRl1EpuO+0ODPuSsFxm9+MYkFn3LUgiuMGtKPC+BW1ZdNxg7bslK0pS6F7G7pmf35/nNwsbdImTdIk5bxfr/tqeu65556Te3Ofe57nOc/DiAgCgUAgEHSXEH93QCAQCATBjRAkAoFAIPAIIUgEAoFA4BFCkAgEAoHAI4QgEQgEAoFHhPq7A/6gb9++lJyc7O9ueI2WlhZER0f7uxtepTeOCeid4+qNYwLEuBxRVFRUS0T92pefl4IkOTkZhYWF/u6G19i+fTtmzpzp7254ld44JqB3jqs3jgkQ43IEY+yko3Kh2hIIBAKBRwhBIhAIBAKPEIJEIBAIBB4hBIlAIBAIPEIIEoFAIBB4hBAkAoFAIPAIIUgEAoFA4BHn5ToSQe+isrISq1evxp49e2AymdDU1IS4uDgkJSXhwgsvxMiRIxETE4Pk5GQMHTrU390VCHodQpAIgha9Xo8333wTL7zwApqamrqszxjDH/7wB/zlL3/B3LlzERLSeybkWq0W9fX1aGpqgtFo7NFzx8fHo6SkpEfP2RP09nHJZDLExsYiMTER4eHhHrUpBIkg6Ghra8Onn36K5cuXQ6VSAQDmzZuHW2+9FREREYiJiUFjYyPKy8uxf/9+nD17Fk1NTSgqKsI333yDb775BqNGjcJbb72FOXPm+Hk0nqPVanHq1CkkJCQgOTkZcrkcjLEeO39TUxNiY2N77Hw9RW8eV0xMDPR6PRobG3Hq1ClccMEFHgkTIUgEQQERYffu3Vi3bh0+/PBD1NbWAgAuvPBC/POf/8S8efO6bKO2thZr1qzBO++8g2PHjmHu3LnIzMzEypUr/fLAaGhowP/+9z8cPXoUhYWFUKvVUCqVmD9/Pq644grIZDKX2qmvr0dCQgL69u3r4x73HEQEjUaD0NBQyOVyf3fHqxiNRrS0tCAqKgqhof55BDPGEBYWZrln6uvrMWjQoO63dz6m2p0yZQqJWFuBzbZt25CQkID6+nps27YN69atw/Hjxy37U1NT8dhjj2HhwoVu/xgNBgNWrlyJ559/Hnq9HsnJyfjwww+9+h1qNBr88MMP2LNnD+rr6y0PxuLiYrS0tODUqVOoq6tzevyAAQNwww034KqrrsLMmTMxcOBAp3WPHj2K5ORkhIWFea3/7uDNN3etVouamhrU1tbCYDAAAEJDQxEZGWm3hYSE4Ny5c1Cr1dBqtQgLC0NERATCwsKg0WjQ2toKg8EAuVyO+Ph4DBgwwO03bm/PSLRaLaqrq1FbWwuj0QjGGPr374+kpKQeVbO2H5dOp8OJEydw4YUXdnksY6yIiKZ0KBeCJPjpLYKkoqICxcXF+Omnn/DRRx/h7Nmzdvv79++PBQsW4LbbbsP06dM9Vt/s378fd999N3bv3g0AuPXWW5Geno6ZM2ciISGh2+1u3rwZGRkZKC8v77ReeHg4pk2bhkmTJuHiiy9GUlISfvrpJ2zYsAGlpaWWeowx/PGPf8Qrr7wCpVLZoZ2SkhKMGTOmR9VZtnjjgWswGHDmzBnU1NRYyuRyOYxGI0wmk6ddBABERkYiKSkJ8fHxLn1Xno7LaDRCo9FAq9VCrVajvr7esi8iIgIajcbyOTk5GTExMd0+lzu0HxcR4fDhw7jooou6PFYIEhuEIOmIyWSCSqVCU1MTxo8fj9DQUBARampqsHv3buzbtw8KhQKXXnopxo0b55WHlslkQm5uLj755BMUFhaisrLSbv/gwYMxYsQIjBkzBrfccguuvPJKl9U9rqLX6/HSSy/hH//4h+UNOCYmBg8++CAef/zxTmcC7WloaMDjjz+OtWvXAgDGjh2LtLQ0DBgwACEhIQgLC8O5c+dwzTXXYNiwYejfv7/DN1FJjffdd99hx44d2LZtG3Q6HWJjY/Hyyy8jMzPT7nsoKSlx6SHgKzx54BIR6urqUF5eDoPBAMYYEhIS0L9/f0uoc51Oh7a2NruNiBAVFYXExERERUVBq9VCo9FAp9MhIiICUVFRkMvl0Gq1qKysRGNjo8UJITo6GomJiejbt2+n95M0LiLCuXPn0NjYCL1eDyKC0WhEWFgY4uPjER8fj5CQEOj1erS2tqKlpQVNTU1oaWmB7fNVGtuAAQMQHR2NlpYWlJWVQaPRgDGGwYMHo3///l6/x22RvBrj4+Ptyl29h4QgsUEIEis6nQ6ff/45srOzLR4q0dHRSEpKwtmzZ9Hc3NzhmCFDhiAtLQ2TJk1Cnz59LD/khoYGHDlyBGVlZZDJZLj44otx2WWXYfr06XZv+FqtFrm5uXj55Zdx8OBBS3l8fDxSUlIwefJkJCUl4ZFHHvHpj8qWU6dOYdWqVfjhhx/w448/AuBvipmZmXj22WfRp0+fTo//7bffcPPNN+PMmTOIiIjAP/7xDzz66KMd+t+da1VRUYGHH34YeXl5ALhab+3atbj44osB+FaQEBEaGxstD+nw8HDExcUhIiLCUsddQUJE0Ov1aGtrQ0VFheUei4mJwbBhwxAZGen1cZhMJtTU1KCiosLywiCTyRATE2MR5owxxMTEICIiAjKZDG1tbQCAqqoqy2dHMMbAGHM4c4qMjER4eDgiIyPRr1+/DupHk8mE8vJyVFdXA+CzsH79+kEul8NkMkEmkyE6OhoRERHdfnlraWlBfX09mpub0drair59+2LYsGF2dYQg6Qa9WZDo9XocPHgQKpUKVVVV6NevH2bMmGFnSGttbUV+fj5+/vlnfPLJJxYVUr9+/RAXF2enVomNjcWECRMwceJENDQ0YOvWraiqqnK7jxdddBH69++P48eP48yZM5byIUOGYNmyZZgzZw6USqXlR+1Pdd2uXbvw4osvYuPGjQCAPn364NNPP8XcuXMd1l+7di0yMzOh0+kwffp0rF27FqNHj3ZYt7vjIiJ8+eWXeOSRR1BeXo7Y2Fh8/vnnmDdvntcFifTG3djYiLNnz1pUMLaEhISAiCCTyRAeHo74+HgoFAoYjUY0NzdbVFIymQw6nQ5arRYymcyi7pEe5gC3gQwZMgR9+vTxuXrOaDTi3LlzqKqqQktLi8vHSQ94SYDKZDJoNBo0NDRYBKFMJkNUVBSio6MRHR2N2NhYl+13jY2NOHPmjNM+hYSEIDo62mKgl2xCjDHLtVKr1SAiREREICQkBAaDAW1tbdDr9XZtKRQKjBw50q5MCJJu0BsFybhx4/Dqq69izZo1Fo8mW8aPH4+4uDicPn0ap0+ftptyX3zxxXj88cdxxx13QC6Xo7a2FpWVlRg8eDASEhLsftwmkwl79+7Fjh07UFpairq6OrS2tiI8PByxsbGWBYB6vR5FRUX4+eefUVhYCK1Wa2lDJpNhzJgxlnM6MhIHgt1n7969ePTRR7F9+3YwxvDMM8/g2WeftXgRVVRUYMmSJfjkk08AAH/+85/xr3/9q1MvI0/H1dzcjPvvvx8bNmwAADz00ENYvHgxxo4d2+02NRqN5W21paUFra2tdveHNAsJCwtDa2urnZqou8hkMkRGRiImJgYDBw7sce8lIoJWq0Vra6vlf5PJhMbGRhgMBhiNRhgMBkRERCAxMRGJiYlODeImk8kiND0RhNLs79y5czAajZDJZNDr9WhpaYFOp+t2uzKZDH369EF8fDyio6PR1tbWYQYpBEk36G2C5JNPPsHSpUstb/ojRozA2LFjMXDgQJw+fRo7duywm5qHhIQgJSUFv//97zFz5kxcffXVPn0T1Ol02Lt3L5qampCUlIRRo0Z16aUSCIIE4A+JF198Ec8//zyICGPGjMFdd92FiooKrF69GhqNBpGRkXjjjTfwwAMPdNmet+xZK1euxDPPPAODwYDvv/8ekydPdvmNnojQ0tKClpYWuzdqW2QyGcLCwtC/f3/06dPH7npJD12AG8nr6uqg1WrR0tICxhhiY2Mhl8sREhICo9EIuVyO8PBwGI1GhISEIDIy0mdrXVQqFbKyslBQUGBxp05JSUFmZibS0tIAAMXFxUhNTe1wrEKhwIIFC5CdnQ2FQhFQ60gkgdLW1mZnxAf47zkqKgoJCQmQyWTQarUwmUwWb7ewsDC779rRuDwVJGIdSZBTW1uLJ598ElVVVZg+fTr+9a9/4ZJLLrG7cTQaDYqKimAwGJCUlIRhw4b1qG9+WFgYpk6d2mPn8yYhISF49tlnMWPGDGRmZuLw4cN4+umnLftvvPFGvPzyyy65TnqzT1lZWUhLS8Pdd98No9GIEydOoKKiws7FVbIBxMTEWHT4ra2tFn25bXvx8fF2apnObFOMMct+aXX04MGDfTdgF8nLy0N6ejqUSiUyMjIwdepUqFQqrF+/Hunp6WhoaLCrn52djYyMDABcABUUFGD58uUoKChAfn4++vXrkJrcb8jlcigUCigUii7r+iPPvBAkQQwR4c4770RVVRWmTZuG/Px8hy6EERERmDFjhh962Hu4+uqrceDAAWzatAk//PADwsLCcOedd2LSpEl+61Nqair27t2L3bt3WzyUbFWIADo8PCVkMhkSEhIQExNjeZMNZgoKCpCeno758+cjNzfXbt+SJUtQUFDQ4RilUml5MKekpCAlJQUZGRmYNWsWUlNTcerUqZ7oeq8g4AQJYywFQJr536kAcoio413A6yoAZABQAVACKCCi4p7oZyDw73//G99++y3i4uKQl5fXY37o5yvh4eFIT09Henq6v7tiQfLqGT16NDQajZ1hVa/Xo6mpyWIHYIwhIiICcXFxvUJ42JKZmQmlUtlBiEhIaq2uUCgUWL16NVJTU/Haa6/h2Wef9WY3ey0BJ0gApBHRCsAiKMoYY7OcCIhcAJlEpDLXz2eMpRORusd66yeamprw5JNPAuBGXhHV9vxG0pO3pzeFTXFGXl4eVCoVcnJyvNJeSkoK0tLS8M9//lMIEhcJqPCn5tnIMul/s0AohHWGYltXAUApCREzKkd1eyNSvKlLL70Us2fP9nd3BAGKtMbBl1tcXJzHbXjCrl27AAALFizwxlcGAJg9ezbUajXUarXX2uzNBJQgMc862usNlADUDqpPcVCuBtDrn6pGoxGvv/46AOCpp57yW2gMgSAQKC7mygpXDNGuIoWi6U3enb4k4FRbtvYQxpgSQCKADQ6qKgDUtyurAxc8HWCMZYDbUzBgwABs377dC731D0VFRVCpVBg4cCDi4uLQ3Nwc1ONxRG8cE+CbccXHxzvNx9LY2OjVczlCWvPgCa7kk+ns/O60IS36a2trc3qMtLaptbXVo74FIkajscOYNBqNR/dlwAmSduQAmNWJzSPR1YaIaBWAVQBfRxIIaxS6i2RQvO+++zBr1qyAWXPhTXrjmADfjKukpMSv6x38vd5i6tSp2LZtG4xGo92sJDU11TJbAYDS0lIolUqLe2xkZKTTfh8+fBgAX6wbKGtJvIWj6xUREYHJkyd3u82AUm3ZwhhbAiC7Ey8sNfisxJY+6DhL6VWYTCZ8+eWXAICbbrrJz70RCPyPtEZJWu0vkZubi6KiImRnZ7vdpmR3cRRtWdCRgBQkjLH54K68Beb/HV3NQnSckSgA5Pu2d/5l165dqKiowLBhw5CSkuLv7ggEfmf+/PlQKpUdBIa0qt1dYaBSqZCXl4dHH33Ui73s3QScIGGMpQFQSzMRs3dWivmzUhIqkkdXOyEzBYDDNSe9ha1btwIA/vCHPwgju0BgJicnByqVyuM1Pmq1Gunp6VAoFHj88ce91LveT0DZSMxCId/82XaXFBgnE3zWkWn+Px1ABmNMBT47WdTb15Bs27YNAHDVVVf5uScCQeCQlpaG3NxcpKenIzU1FZmZmUhMTIRKpUJ+vmMlhUqlsrj31tfXo6CgANnZ2aivr8eWLVu86gXW2wkoQWJeE+L0NZuIstr9rwawwsfdChh0Oh1++uknAMCVV17p594IBIHF/PnzUVRUhOXLlyMrK8suaGN+fn4HFVdWVhaysqyPFEdBGwWuEVCCRNA5hYWFaG1txUUXXYQBAwb4uzsCQcCRkpLiNEyKbZ3zMeq5Lwk4G4nAOb/88gsA4PLLL/dzTwQCgcCKECRBxM6dOwEA06ZN83NPBAKBwIoQJEGE5NsuBIlAIAgkhCAJEmpra1FWVoaoqCiv5ucWCAQCTxGCJEiQZiOpqak9nt9aIBAIOkMIkiBh7969AOAw17RAIBD4EyFIgoRDhw4BAMaOHevnnggEAoE9QpAECUKQCASCQEUIkiDAZDKhpKQEAIShXSAQBBxCkAQBp0+fRmtrKwYMGIDERJdTsAgEAkGPIARJECDUWgKBIJARgiQIkASJUGsJBIJARAiSIKC0tBQAcOGFF/q5JwJB4FFcXAzGWIctNTUVK1Z0HhxcymGSkJAAxhgSEhIwe/ZsFBT06rRGXkcIkiBApVIBEGk/BYLOyM7ORkNDA0pLS1FUVISFCxciKysLs2fPdlg/Ly8PI0aMQHFxMTIyMpCbm4tly5ahvr6+ywjCAnvEEukgQJqRCEEiEDhHqVRCoVBYElKlpKQgLS0NqampWLVqFTIyMix1CwoKkJ6ejvnz53cQGkuWLLEkvBK4hpiRBDhGoxEnTpwAAAwfPty/nREIggwpZ3t7YZGZmemwXEJkR3QPMSMJcMrLy2EwGDBo0CBERUX5uzsCQdDRXijk5eVBpVIhJyfHPx3qhYgZSYAj7CMCQfdRqVQoLi62s5NIAVAXLFjgr271OnwiSBhjcb5o93xE2EcEHsGYz7fYuDjP2/EyarUaeXl5SE1NhVKpxJIlSyz7iouLAQj1lTfxqiBhjMUzxgoBqBljRsbYS+323cwYO+bNc/Z2pBmJsI8IBJ2Tnp5ucf1NSEhAeno60tLSUFRU5O+u9Xq8PSNZBWA5gAQAUwGEMMa+Y4zFEdE5IvoPgBFePmev5vTp0wCA5ORk/3ZEEJwQ+Xxramz0vB0vsGTJEpSWllo2IkJubm6HmUdKSgoACM8sL+JtQVJIRP8xC41iIloKYCGAFTbqLu/cNecJ5eXlAIAhQ4b4uScCQWAzYsQIKJVKy+aMqVOnAoBYdOhFfG5sJyI1ES0GkMEYE/oZNxGCRCDwLvPnz4dSqURWVpa/u9Jr8LYgKWCMLWKMHWOMTbLdQUSvAEgB4H3LWi+FiIQgEQh8QE5ODlQqFTIzMx3ul2yTAtfw6joSItrNGFMBUBHRHgf7/8MYEzYSF6mvr4dGo0FcXBxiY2P93R2BoNeQlpaGnJwcZGZmWgSKUqmESqXC+vXrUVBQgFOnTvm7m0GD11VbZvvIlk72l3n7nL0VMRsRCHxHRkaGxaMrPT0dqampSE9Ph1qtxpYtTh9hAgeIle0BzJkzZwAIQSIQdEZKSgqom55fKSkpyM/Pd7ivqanJk26dV7glSMx2D2+l6Kt3pP4SWJFmJEOHDvVzTwQCgcA57s5IpgJQeOncDQD2eKmtXolQbQkEgmDALUFCRKt91RFBRyRBkpSU5OeeCAQCgXNE0MYAprKyEgAwaNAgP/dEIBAInOOujeRm8PAn3qCeiL7wUlu9kqqqKgDAgAED/NwTgUAgcI67NhK1F899zott9UqEIBEIBMGAuzYS4VzdQ5hMJosg6d+/v597IxAIBM4RNpIApaGhAQaDAfHx8YiIiPB3dwQCgcApQpAEKEKtJRAIggVvJ7ZKttm6lSWRMaZkjOUyxtK6qLeEMZbNGEthjKUxxnpVAmZJkAwcONDPPREIBILO8ShEinml+2IAUwDEA1DBJrovY0wJvvBwPYCCrlay2wgPV/PKZpi3AgCL3Oh6wCNmJN6jrq4Ohw8fRmVlJcLDw3HFFVcgLk5kgw4WdDodjh8/DiJCREQEIiIiEB4eDplMhri4OMhkMn93sUeRwsEwc4pirVYLrVaLqKgoEBFCQ0Mt+3qKbgkSxtgsAJkAdgLIMecb6az+ZACzGWPLzPW3OqpHRAXm+vUudENNRN5yRfYrWq0WYWFhdhdfWkPiK0FiMplw8uRJHDlyBD///DMKCwtx7Ngx5OfnIzk5GUQErVYb9PaZjz/+GPfccw9MJpOlLDQ0FAMGDIBGo8Fvv/2GESOCMyB1c3MzoqOjXa6v1WrR1NQEuVyO2NhYhIRYFRImkwktLS2WOgaDATKZDAqFAomJXUdFMplMdu25g3Tuc+e4I2dISAhMJpMlooNcLofRaIRWq0VbW5vdsXK5HMnJyYiPj+/WubvCaDTCaDQiNDTU7fEZjUZoNBoYjUbLiwsR4fDhw5DL5YiOjkZCQoLT35her4fBYEBYWBja2trQ0tICjUaD1tZWJCUlWdo8d+4cTp06hcOHD2Pnzp2Qy+U4evQo/vWvfyE2Nhb9+/f3uWBxW5Awxl4GcJyIFrh6DBHtBrDbfPzNjLHlRLTM3XM76U8KuFAJ2AQClZWVqKurw7hx4wDwm+mtt97Cb7/9hp9++gknTpyATCbDqFGjcMUVV+Cpp57y2Yxk7969WLp0KX777Tc0NDTY7WOMWVRpUvj6cePGYdGiRbjhhhs8DtWyceNGhIaG4sorr0RMTIxHbTmjoqICx48fx5QpUxAZGYkbbrgBEyZMgFwuR1JSEqqrq/Hrr79aAmK2tLRYjs3KysIvv/yCGTNm4KKLLsKoUaMwYcIEtx7W3aWkpAQmkwmjR4/G4cOHcfr0abS0tEClUmHIkCG47bbbAAC7d+/Gc889hz179qC8vBxDhgzBhg0b0NDQgMjISISHh1seGkQExhiMRiMqKytRWVlpeZudOHGi5cF47NgxNDY2Ogx8aDtzq6urQ2VlJfr164f4+Hg0NTWhqakJjY2N6Nu3ryUCg16vx+nTp5GUlITw8HCnY25ra0N5eTmamprsBL1EQkICoqOjwRjDhRdeCL1eD61WC41GA51Oh9bWVrS1tXl1RqLX6yGXywHw72/v3r2WvsXHx0Mul0On00Gn06FPnz6WxcK1tbWor69HWFiYZb9WqwURITIy0vLbl4QmwFP9nj17FgqFAhERESAiDBw4EKGhoSAiHDp0CHq93mE/a2pqLNcmPDwcRqMRJSUluOuuuwAAW7ZswXXXXYevvvqqR7QazJ2omYyxRQA2EJFHa0AYY/EA0onofSf78wFkSzMUJ3UyANSDq7XSAEwlIqcpz8z1MwBgwIABqevWrfNgBK6Tn5+Pl19+GTExMdi4caOl/Prrr7dEF5XewCT++te/oqioCN9++y0ef/xxXHfddQCA1tZWnDhxApWVlTAYDLjkkksQHx+P5uZmuwdza2srDh48iBMnTkCv12P8+PEYP348AOD48eNYtIhrARMTEzFkyBCMGTMGY8eOxQUXXIDhw61JLDMyMnDs2DEAgEwmw6xZszB37lxMmjTJ6dvZrl27sH//fhiNRsTHxyM9Pd3yYHvkkUewb98+xMXFIT09HWPGjEFVVRV0Oh1Gjhxp6SOADmNyhPSg1Ov12Lx5M3bs2IHi4mIAwJo1ayzpVo1Go93Dprm5Gc3NzYiMjERMTAxkMhmam5uRnp4OjUZjdw6ZTIbk5GQ88cQTuOiiiwBYhVVkZCRCQ0NRVlaG0tJSlJWVISoqCitXrrQc//bbbyMmJgZJSUmIj49HXV0d9Ho9GhsbMWfOHPTr1w8AsHz5cnz//fcOxzlx4kS89tprlu93yZIlAKz3zebNm9G3b1+EhIRg5MiRYIyBiHDs2DHIZDIYjUaLkIiKioJMJsPgwYMt7ZeVlUGn0yE8PByhoaGIjo62PMyioqIQGsrfN6uqqpzmOY+KirIEF1Wr1aiqqkJISAgiIyMhk8lgMBjQ1taG6Ohoi8DRarU4ceIEAP4wlL5Po9GIiIgIxMTEdDoLICK0tbUhKirK8n9raysiIyO7nD2YTKYOD+m6ujq0trZi+PDhlu/tzJkz0Ol0MBqNHdpISkqy3KMNDQ2orq7uUCcsLAwREREYOHCg5brYCsLGxka7+sOHD0dYWBgAoLq6Gs3NzdDr9QgLC7O8KEjXyHaM27ZtwyOPPIK9e/eiqakJ5eXlmD59Oo4cOWIRdkaj0SIo2wvf48ePW2aEnXHVVVcVEdGUDjuIKOA2APkA0tw8ptTVY1JTU6knqKmpocjISAJAM2bMsNu3dOlSeuedd2jPnj1kMBiora2Ndu7cSX/605+ourqa5s2bRwDommuuoSlTptD48eOJMUbgOe8JAN13331ERLRt2zYqKSmhe+65h5KSkjrUGzNmDOn1eiIiamtro9zcXDp16hSZTKZO+9/W1kbvv/8+3XjjjRQSEmJp74ILLiCNRmOp9+GHH9Krr75Kc+bMsTsvAPriiy8s9d58802aMmVKhzoA6O2337bUO3jwIGVlZdHGjRtp8+bN9Prrr9P3339PTU1Ndv17/vnnad68eTRmzBhLO3K5nKZPn067d+92+3pVV1fTxo0b6ZlnnqGFCxfSxIkTLeN+/fXXLfVWrVrlcAwASCaTWb6bxsZGp/UA0Ndff21pc82aNTRkyBACQEOHDqXZs2fTH//4R1q0aBHl5uZa6lVUVFBeXh4dOXKEDAYDFRQU0A8//ECHDx+mI0eO2I1nz549tGvXLtq1axeVlJR0+P4kWlpaSKfTdfn9GI1Gqquro5KSEtq9ezcdOXKEKisrqbq62u5e0mg0dPToUcu5bTfbPppMJqqtrSWtVtvlubuioaGBbrjhBoqNjaW77rqL9u/fT2VlZVRZWUmVlZVUU1NjqdvW1ka7d+922L+ioiI6d+4cEfHrJ41Lp9NRVVUVVVdXU0NDA7W0tJDRaLS0qdfrqa6ujqqrq0mtVlNraysZDIYu+93W1kY1NTV05swZOnv2rOV3aktXv1OJoqIiu8/88c4xGo2We6SxsbHDsYcOHXLpHAAKycEz1a0ZiTMYY8lEdMLjhqztuTIjSSGiYpv/c8EzM3aZiHnKlClUWFjonc52wnvvvYcHH3wQaWlpTnMeOGP69On47bffkJCQYFFByeVyjB07FsOGDUNzczOWLl2K2bNnY/v27Thw4AAeeughANwGkJqaitTUVISHh0OhUODRRx/1yMBcVlaGnJwcrF+/HidOnIDRaLS8EY0dOxYlJSUAuCpk8eLFiIuLQ11dHX7/+99jzpw5lnaICFu3bsWrr76K5uZmKJVKREdHY+nSpZY32ocffhhvvvlmhz6Eh4fjvffewz333AODwYAhQ4ZYVIDJycn429/+hmuuuQZ9+/bt9jjb09zcjF9//RUAz6oHAN999x3effddNDc3o7W1FaNHj8bkyZMxYcIEDB48GCNHjkRISAiam5vx8ccf4+TJk/j1119hMpnAGMOIESPQt29f3HHHHZgwYYLddyO9fbpDSUmJZbZki8lkglarhUwmc7tNd2hqauqQwZPMb95ardby5h8fH98tW4OrNDQ0IDExES+//DJmzZplt48xhpSUFMus4NChQxY7EBHBZDIhNjbWTh3naFzdIT09HcuWLUNKSkqHfcXFxSgsLIRSqYRarYZCobDcZ54g5aPPzs4GwGcjZ8+eRWxsLGQyWYdxObuH2sMY892MBMC7DsriATwFYFI32ut0RgKe+73BwTEZrrTfUzOSO+64gwDQu+++6/axI0aMIAD0888/088//0w7d+6khoYGh3W3bdtGmzZtohdeeIH279/v0ttldzEajfTjjz/alWVnZ9ODDz5Ir7/+OlVXV3t8jlWrVtHVV19N1157Lc2aNYsWLlxIEyZMIACUnJxsedM7ffo0ffTRR7RmzRpqbm72+Lw9wbZt27zepqtvk77C0RuuPygtLSUAVFdXR83NzVRRUUEnT560bLYzBJ1O1+WbvifjKi0tpYyMDFqyZAkpFArKz893WGf+/Pl2ZfPnz7ebWXSHhoYGSktLc7rfFzOS7nptHQdXJRWbH+COBNQ5ACsZY7MYY1eTE08tN86pNLerIqJixlj7mYcSwAZPzuFtdu/eDQAO30S6ora2FgAwZswYJCR07Zx23XXXWWwpviQkJAS/+93v7Moknb23WLRoEUaNGoWZM2falVdUVFjeIgGep0UyLgoEBQUFUCqVFi+zzpwkJIO6r1AqlcjJ4Uvb8vLyHNbJzs5GZmamXdmyZcuQlZVl0WCsWrUKpaWlTs8ze/bsDjOYrKws5ObmetJ9t+nuOpJ0AAsBzAaQBYAYY1PADd/fE9E2qSIRbWGM3eRKo2YPrDTwdSlZjDElEa0y784ET6olffOFjLEl4IEkR4Ab79XdHI/XISIcPXoUACweG66i1+tx7tw5yGQyn7k1BiMinL6gM/Lz872iFuopNmzYYFFBSSiVShQUWDX6GRkZbrW5YsUKZGdnQ6FQWFRlPUG3BAnZuPMCAGPse/DZSSq4ACDz/wXgM5fZALoMGU/c5lEMYIWDfVlO6gYkOp0OixYtglqtdtt9tK6uDgD3qvKVPllwftAz69I8tyN4wVSLgoICrF69GqtWrUJiYiLy8/MxYsQIr8+YvYFKpYJarbZ4FkpID/7i4mK3NRl5eXmYP3++pY2CggLMnz/fG93tEo9WttugIqKl0j/mmcUscAGiBPCyl84TNISHh+Ptt9/u1rGSWsubRmOBoDdTXFwMtVqN/Px8i0opLS0NCQkJyMjI6LE3c1dx5kYtUV/vyppsKyqVCunp6XZlSqUy6ASJnULOZraw0nF1QWdIMxIhSASe4o03/a7wlneTJxQUFEChUFiEiC319fVdCpL09PQOD/f2649sycnJ6TCb8CdKpVJyOvILXhEkJPKUdKC8vBwVFRUYPny42wJBzEgEAvfIz8/HggX2wTYkF39XHviOjNOBICCDBbcU8IyxRd2N6tuunTjG2AOethPIfP7555g2bRqWL1/u9rFCkAgE7lFYWIjZs2fbleXm5gas8V2aITlTcbkS3yyQcDdD4mrG2MuMsZ3UzXzr5rzvU8hLsbYCFekG6c4NIQSJQOA6kn2kvdDYsGEDVq9eDQBdejC1ty8AgMFgsISHaU92drZHqi2lUgmFQtFB7SY9N7qzZMCfuK3aIqKl5rUhG8Cj/+ZRF6vaGWPJ4C7DU8Cj//ZqIQLAEkOnO6vJhSARCFxHWj9i+0CWhItkbN6wYUOnrrT+UG2lpaWhuLjYTiAVFhYG7CyqM7rr/rsFwBZzePjF5jwiBB5EUW2upgDQx1xeCC5wzhvjuzcESZ8+fbzap4Dh7Flg40bg22+B/fsBnQ4wGAC9nluHhw1D8vjxgFIJXHCBv3srCHAcrR+xfSDn5eV1sJ8EAtnZ2UhPT7fzrMrJybGENQkmPDK2O1hPEg8gEVyIqImozKPeBTGSIOnOG02v9dqqrweWLgU+/JALDmc0NCB5zx7g00+BW24BXn4ZMMfhEgjaU19f3+Hhu2DBAhQVFSEvLw8KhaLH3X/VajWWL18OtVoNlUqFrKwspKWl2a1EVyqVyM7OxooVK6BUKqFSqZCZmRl0ai3Ae+6/ACxhUTwKMd9bEDOSdhQVATfcAJw5A4SE8M/XXQfMmAFERQFyOd+IgL17UbV8OQb8+CPw2WfA118Dq1YBCxf6exSCAKSoqKhDmTNX4J5CoVBYhFtn/UhLSwtKVVZ7ui1IGGOTqIvUuecznggSKdpvsHluOOWXX4DZs4GWFmD6dD4jGTPGef20NJSEhmLA8OHAww8DmzbxmcmRI8Czz/bUcm2BQOAinsTfOMcYe1L6hzF2tRf602tYt24dfvvtN4wdO9btYyXPjUBbjdstjh8HrrmGC5HbbgO2b+9ciNgybBjw1VfA66/zWczzzwMvvujL3goEgm7QbUFitn9kMsZuYox9ByBgU936gxEjRmDatGlup5QlIsuMxJWovwGNRgMsWACo1cD11wMffQR0knrVIYzxWclnn3Fh8uyzwIaACvIsEJz3uC1IzK6/LzPGCsGj7q4Gj7x7wtudOx9pbm6G0WhEdHS0z0Nd+5wnnwR27+beV//+N+DEJ98lFi4EzOlmcd99wIEDXumiQCDwHLcFCRFtIaKlxLNkqcAFyWqv9yzIWbRoETIzMzvkhe4KaTYS9GqtvDzg7be5AX39esAb4fD/8hfg9tu5muymm4B2+a4FAoF/6LZqy+zqm2eO+pvhas6R8wEiwpo1a7Bq1Sq3w8BL9pGgVmuVlQH3388/v/IKMKVjZs5uwRj33powATh2jLsSCwQCv+OJsX0KgOUAd/vtbsiU3oherwcRQS6XO40e6oygt48QAZmZfLbwxz8C5jzyXiMqCvj4Y64me/ddYMcO77YvEAjcxhNj+xbzuhFBOzQaDQAgIiLC7WODXpB8+imQnw8kJgI5Ob5x1Z0wAXj6af75gQeA1lbvn0MgELhMtwQJY+wBxth6xtgu87aeMfakOabWeY8kSMLd9VBCkNtI6uqAxx7jn199Fejf33fn+utfgYsv5u7Fzz3nu/MIBIIu6Y7X1ssARoKn0d0AoAjce2sFgFKzYLnfq70MMs7bGcnTTwO1tcBVVwF33+3bc4WFAR98wF2C//UvYOdO355PIBA4pTv+mKVE1MFLizH2HnimxAUAljHGVgB4gIi+9LCPQYcngiRoje2HDgHvvw/IZMA77/TM6vOpU4HHH+cG/fvv52FYwsJ8f16BIAApKCgAwJ8hu3btwsKFC3ssbld3VFsjGGOOIhGS2W6SSUQjASwE8FfG2LuedTH4CA0NxfTp0zFx4kS3jw3aGcnSpYDJBGRkuL5y3Rv87W/AiBF8XUkQRk0VCLxFeno6pkyZgvnz52Pq1KlYtGhRj527O4IkB8A2xthV7crtXkGJqMC81qS4t2dDbI9SqcQvv/yCvLw8t48NShvJjh3Af/8LxMTwMCY9SVQUYE5ehH/8g8+MBILzkKKiIstzo76+vkdj9XVnQWIZuPpqtdkecqM5/a7DzPOO1GAC5wTdjITI6kG1ZAkwYEDP9+Gqq7j3lk4H3HUX/ys4r1Cr1UhPT0dCQgKysrL83R2/YJsgKzc3t0e/h255bRGRyqy+ygWwEkADgAWMsZcYY1fbem+ZP4/0Ql+DBqPRaFlL4i5BZyP53/+An38GEhKARx/1Xz9eeQVITuZ2kr/+1X/9EPgFhUKB3NxcqNVqTJ061d/dsSM9PR3FxcUO9xUXF2PVqlUoKChAXl6exc7RXVQqFVasWIH09PQeDU/vyYJEENEKs0CZC2ArgMXg3lyljDEjY8wIrgp7z+OeBhGbN29GWFgYrr/+erePDboZyfLl/O9DDwE+TEvaJfHxPLCjTMaFyvff+68vAr+gUvG4sYGQ30NKUpWVlYWCggLU19c7rLN8+XJkZGQgLS0N8+fPR05OjlOh4wpKpRIZGRmWpF49hVcSWxFRAbgAsc2SiPM1Q+J5s45kzx5g82Zup3j4YX/3Brj0UuCFF3iE4NtvBwoLeSh6wXmBo9zt/kKpVFoSWjl7oGdnZyMzM9OubNmyZcjKykJ+fj4AYNWqVSgtLXV6HtuMixIKhQLp6emYPXs2GhoaeuT78GqGREBkSQS8I0iCYkYieUllZACBks1x2TLgp594Pvgbb+Sqt6gof/dK0AM4yt0eyGzYsKGDHUOpVNqptzIyMlxqq6CgAFlZWZZskVPM8e3q6+t7RJB4pNoSOEar1QJwfx2JRqOBVqtFWFgYIiMjfdE173H6NJCby1VJjz/u795Ykcm4imvECB7C/v77uVvyeQxjzrdVq6z1Vq3qvK4tqanW8ri4WLt6ts++oqLO23SQJbfbFBQUYPbs2Vi1ahXy8vKQmZmJFStWeO8EXkSlUkGtVtsZyAGrJsJd9VZiYiIW2qSiLiwshFKp7NC+r/D6jETQ/QWJtrMRFujpZN97DzAaeZ6QoUP93Rt7EhKAjRt5Wt9167h66+WX/d0rgQ8pLi6GWq1Gfn6+RaWUlpaGhIQEZGRkBIS6yxbJqcYZjmwqnZGSkgKVSoVV5jeDoqIii3qsJxCCxAd4KkgC7abvgEZjfZX1dnRfbzFuHM+Jcu21XAU3dCjw5z/7u1d+wVXnwYwM+9lEZ9jOJJqamhDrxNEiNdX183tCQUEBFAqFRYjY4op6Jz09vcPD3Wg0Oo3enZOT02Nv+64yf/58v51bCBIf0F0bSdDYR9at4zG1Jk8GLrvM371xzty5fLHivfdygTd4MLebCHod+fn5WLBggV1ZYWEhALj0wM/Nze1Q1pmAFNgjbCQ+4Nprr8WaNWtwo5sPraBYQ0IEvPkm//zwwz0TU8sT7rkH+Pvfeb9vu40b4gW9jsLCQsyePduuLDc3N2CN79IMyZmKqydXpXsDn8xIGGPLiWiZL9oOBiZOnOhRnK2AVm0VFQHFxdxL65Zb/N0b1/jrX4Hycp4f5brrgK1bgUmT/N0rgZeQ7CPthcaGDRuw2hw+R61Wd/q7Sk9P71BmMBgQGur4EZmdne2RaktyU26vdpMES08FW/QWvlJtpQE4bwVJdwkK1daaNfzvnXcC3Yhu7BcYA956C6is5Eb4q6/mybdSU/3dM4EXcLR+RBIukt1gw4YNnbrS+kO1lZaWhuLiYjuBVFhYGLCzqM7wlWorwPUdviU/Px9vv/02Dh8+7NZxAS9IWlu5ay1gzckeLISGAuvXAzfcADQ0ALNmAVu2+LtXAi/gaP2I7QM5Ly+vg/0kEMjOzsZyKTKEmZycHGQHYRRrX81IesBPI3D5+OOP8fHHH2Pt2rUY40ZI9YC3keTl8Vzsl1zCsxMGG+HhfO3L7bfzv3Pn8nAqjzwS+LaeYMFg4C8cGg2g1/N1PTIZF+QyGb8GYWFe/b7r6+s7PHwXLFhgCROiUCh6XF2sVquxfPlyqNVqqFQqZGVlIS0tzW4lulKpRHZ2NlasWAGlUmkJqxJsai1AeG35hLa2NgC90P1XUmsF22zEFrkc+PxzYNQo4KWXeGrgX37h7szx8f7uXfBhMkHW2srTLDc2uhZ5WSYDIiP5Fh0NKBRc0HSTIgerGp25AvcUCoXCItw660daWlpQqrLaE3CChDGmBJANIMccw8tZPQWADAAqAEoABUTU/WhnXqS1tRUAEB0d7dZxAa3aOnoU+OEHHm7EZgVtUCKTAS++yA3u990HbNgA7NrF3ZqnTfN37wIbgwFobgZaWvjW3Iwo28gBISFWISGX86gCRiM/zmDgMxWpjeZmoKaGH5OQAPTrxwWLmB0GHQElSBhjkmh2xR0iF0AmEanMx+YzxtKJSO2r/rmKJEii3IzxFNCC5IMP+N+FC4G4OP/2xVukp3Nhcsst3BNtxgwezfjxx/nD7XxHrwfa2qxbczMXBO0whodDlpAAJCZyAdKVINDrufqrrQ04dw5oauIzmro6fnxSEp8dCoHSNUR8cxTHpgcJKEEizUAYY53GBzDPRpSSEDGjAvcW67nYyU5oaWkB0ItmJHo9sHYt/xzMai1HjBrF86lkZQGvvw489RQ3wn/0EdC/v79713PodPyB3tJiFRwGQ8d6jPFZQ0wMn53GxKBVq3XPu0ku54IiPh4YOJALp9pavrW1AceP85eVoUO5YBFY0euB+npArebfldFoDR0QGsrtTxER1llhTIxHakNXCShB4gZTAKjblakBzEYACJJuzUgMBrx27BgGAYgMtNW0338PVFUBo0cH9kr27hIeDrz2GncLvvdeHjl40iTgk094WW+CiAuNtjYuNLRa69/22KqpJHtGVFTH2ZqjY90hIgIYMoRHHqipAc6e5faWQ4e4oBk4kKsjAwWDgQvdpiY+diL+AFcovDuTMhj4tZL+qtV8Bucs5oykPjQ/fyyEhnKBEh0NRESA+SCIabAKEgWA9rOWOnSiEmOMZYDbVDBgwABs377d7ZNW3ncfppw5g2NPPIHIOXM67Nfr9WhqasKygwcxHcDeX35BXV2dy+1fpNFgEIAt27bhxOnTAIDq6mrExMTYCaVz587hp59+QkpKCgYOHIjm5uZujcdVxrzxBgYCKJsxAyd37PDZeWypqanBmjVrMGzYMKeLwrxOXBzC33sPF/3jH1Ds2wdKS8PJO+7Aibvvhkavx759+9Dc3IyrzcKloaEBGzduxJgxYzBt2jSEdKIOM5lMYIyhpaXF69cqPj4eTU1NDvcxnQ6hra0I0Wgg02oRotWCOXgQUUgIDJGRaAsLgyksDKHR0aDQUPuHIhEXOu0wGo1Oz+82UVFgw4cjrKYGYefOARUVMFVXQ69QQK9Q8D71ENK4mMHAv7+2Nst36VBU1NbCFBoKfXw89HFxILkcBLgegJUIIRoN5E1NkDU3I0Sv73AeAmCIiYEhNhbGyEjrNSICMxrB9HqE6HT8Wms0kGk0YAYDoFaDzF6h8vh4NIWF2bWr0Wg8uy+JyOsbgF0eHp8PIK2T/fMBFLUrWwIg15X2U1NTqTts6tOHCKCypUvpww8/pMsvv5w2bdpk2f/rr78SAJocEcE1lz/9REREd999Nz322GN2bf3zn/+kJ554glpaWixlt/bpQ0MB2padbSlbunQpRUdHU2FhoaXstddeIwD04osvEhHRtm3baNOmTTR8+HBatWqVpV5tbS2tWLGCPv/8c0uZVqul3Nxcu3pERKtXr6b77ruPqqurLWW7d++mD1etooPR0Xw8R44QEVF1dTWVlJRY6tXU1NCDDz5IzzzzDDU1NVnK33jjDXrjjTfIZDJZyr799lvKycmxO37r1q10zTXX0JNPPmkpe+uttwgAjR071vIdabVa+tvf/kYbN26067vBYKD2/Pjjj/Tee+/RyZMnLWULFiygyZMn02effWYpa2pqop07d9pdh7qqKtq0cCGdlDTQV19Ne7duJQA0ZcoUu+8yOjqaANhdn7fffpv+/ve/U0NDg6Vs3rx5lJSURP/v//0/S59vuukmuv7662nLli2Wekaj0e77IiKqr6+nlStX0nfffWdX9vTTT1NGRgYdOnTIUn727FkqKysjY1UV0YEDRLt2UcmuXbR/1y46t2sX0a5dRHv20Km9e2lPURHVnjhB1NxMZDJRTU0N7dq1i44fP243xrKyMqqtrbUrO3r0KFVWVhIRUWNjo+W7lD5LaDQaUqvVpNfrrd9vXV2HNpubm+n06dNUU1NjPbipiUwHD5JO6ndhIdGJE9RUW2t3nxERVVRU0MmTJ+2uY21tLVVUVNh9n3V1dXTkyBG7+7y1tZUOHz5MR44c4XW1WjLV1tKp/fupYc8efm7zVrNrF53YtYt0hw4RnTlD1NBAVSdO0IE9e+js7t2Wes3m71xVVER0+DCRSkXGigo6tH8/HT16lLRarXTBqbGqilpKS4n27rUcv2fXLiretYuMBw4QlZQQHT9ONaWldOjgQbvvWK1WU0VFhd1voLGxkY4dO0anT58mMpmI2tro9NGjtGvXLlLt3Uutp09Te2zvoc4AUEgOnqnBuiBRDT4rsaUPOs5SvMroNWtw4JNP0PfxxxEbG4sff/wR33zzjWV/W1sb+vbti8FSnJwjR1BUVISPPvoIGzZssGvr9ddfx6uvvorKykpL2cDBg3EaQMWBA5ayq666Ci0tLfjvf/9rd565c+di1KhRlrKTJ0+irKwMR44csZSdPn0aS5YssfOxJyKkp6dj8eLFdjnl16xZgw8++ACHDh2ylK1fvx73ZmRgY0sLV/VceCF2796NAQMG4KWXXrLUCw8Px7vvvos33njDbub0xhtv4OGHH0ZjY6OlbO3atcjMzMSvv/5qKTt69Ci++eYbuyCXcXFx6Nu3L+bOnWtps6KiAs8//3yHZEDTpk1DaGgoqqurLWXZ2dlYvHgxSkpKLGWzZs3C7t27LTYsAPj3v/+NadOm4dVXX7WULV+5EtevX49nZ8/mdpKtWxGyYAGunDTJbmFbWFgYli9fjqeeegqpNqvks7Oz8eyzz9rFURo9ejTOnDljcQmXyWQYPnw4Nm3ahObmZku9f/7znwgLC8PTTz9tKSsuLsZTTz1lt3hNp9PhpZdewubNmy1lRqMRlRUVqK2tBU6d4uqrkBDI5XJoAMiTk/l1nDgRSEiA3mSCPjzc4ikll8shl8vtrqFer0dtbS1Onz4Ng9lmwhjDuXPn7L5vgOfYOHLkiKUeAJw6dQrHjh2zqHsBrvqtra2FXq+3lLW1taGystLuXjFERGCfXo8jYWFcZUQE1NTgSFkZjhw+DNO5c5ZcM42NjaiurrY7t0ajQXl5OSoqKqzfm1aLxsZGtDU0cBXaqVOg06f5jKq5GWz3bmDfPrCyMtRoNFDp9TAwxlVDAwagNjISNQDakpK4Kk6hgD40FG16PUKTkrj6NyEBWpkMGgBkMlmcCQzl5WjRaKA9dw7yY8eAAweA4mKcOHUKR+rrYdDpuIpswACERUbCCKB12DBgzBiQUonK1la0tLZCLpdbxlNVVYXy8nK777e5uRlqtZrXYwyIiECfIUMAAOF9+8LgAzd3X80TOwau8S6FMKfztUEBPpPxGRfecIPl85w5c7BhwwbE2XgwzZw5EzU1NaAXXgD+9jfgyBEMueYa5Obm2qk9iAhLly5FTU2NnZHyuVtuwd3798M21+CcOXOwd+9eu4ff0qVLsXTpUru+paenY+rUqXYPgcTERDzxxBPoY5O9MDw8HLfeeitiY2NhMpksYbIXLVqEe++9F8nJyZa648ePx+3JyRh/4gRgfoAePnwYjDHE29yMsbGxeOeddxAREWE3zsWLF+OHH35Ac3Ozpb4kGKZOnWqpd+WVV2L9+vW44oorLGVDhw5FeXm5nbALDw/HsmXLUFtbC5PJhJCQEJhMJhw7dsyihuhvNpBPmzYNUVFRdsL21ltvxeDBg3H55ZdbypqbmzF8+HC78zzxxBMoLi7GBZdcAvrwQ7Bbb8XFP/6I7Q0NFjWCpPJ5yEEY/T/96U9obGy0uzdWrFiB66+/3u48jz32GFJSUuz6o9FoOsR4io2NxeLFizF+/HgQERhjUCgUeOGFF3DRRRfxSgYDTCdPYqjJBAMAFh7OvZ8UClxgNGKAVovImBhLmwMHDkT//v3tHkqxsbGYMGGCnSpGLpdj6NChiIqKstwroaGhGD58uCWBm0R0dDTCw8Oh1+st/Q8JCUFMTAzCbFQpCQkJCA8Pt7v3o6KiMHjwYLsyrVYLvV6PqPh47hTR1gZUVSG2thYmAIZjxxDGGCCXYwBjiIuIQFRdHVe/MYZYvR6G6GiENTdz93WNBgk6HSIBhDU2cjsMgHAAowCES7aD0FAgKgr9DAZQWBj0gwcj1Py76ltbiwSj0e6lp2/fvoiLi+PONSEhQGwsYnQ6jNFoECWXcwO5RoPQlhaMaW7m6kXzWjMCECWTQRcSgpaBAxHfvz/AGMYQwWAwWL5zIsLgwYMhk8ns1qfFxsYiLCzMLtx9TEwMhg8fbvcbjYyMRGpqKojI7lniLZjtjR0oMMbyAWSTzToS8/oSkI27L+zdf4sAzCIX3H+nTJlCUohpd2hpaUFubi769euHefPmOa+4bh1w6608ZPkXX7h+gm++AebN4wZeN8J3bN++HTNnznT9PK7S1sbfyJubgdJSQKmEwWCATqdz27XZXdwZk9FohNFoRGhoaKd2im5jMPDAj1K2vWuuAT78sFteXa6MS6fTwWQyubygtaSoCBeFhvIHVkgIf1Pu37/HXJh9FZPKaDRCp9MhPDzc/rrq9UB1NQ9148AduVPMb+iIiOBOFnI5FxzSFh5u8XLyWawto5H3W+pLD7uaOxpXSUmJ9aWkExhjRUQ0pX15QBnbGWMp4C68UwBkMcaURCQlA80En3Vkmv9PB5DBGFOBz04WuSJEPGHlypVo/tvfMB7gnhHOXBNHj+Z/bdRMLnHhhd07zlds3syFyJQpgDmwXGhoaM8Zv11EJpM5TUDkFUJDeXKsGTN4WPpvvgEmTAA+/hhoF7rcG4S1M4Q6paIC+MtfgEWLgL59ufolOTl4gml2gUwmc5xyWi7ns62kJK7a0uv5ZjBwLyppdb00ewwN5b9VSXj4e32KTMbVib2IgHoiEF+ZXgygQ6JlIspq97/aUT1fsm7dOnwFYAwAHDvGHyaOkNQpx4/ztw9XH3LJyfxHcuYMf4DbqCL8gmTXCcCAd37h+uuBffuAO+4AduwA5szhixmffhoYP77n+kHEF4g++SR3Cc3IAC64gK8M9/dDsqcJCeHCwc0kcr2dzMzMHg0RI5bvusHSpUtRct11qP7737lvuzNiYnjSpxdecC32kERoKDByJP989KhHffWYlhZAMvALQWJlyBCudvz737nQX7eOv1DccAPw22++P//x4zxy8QMPcCFyzTVWVdb5JkQEDikuLrbkbu8phCBxg3vuuQc3btqE/s8807V+/PXXgWXL3F+Z2121mLf55huuvrvkEmDYMP/2JdCQyYBnnuF2o4ce4iqTTZuA6dOB3/+eh1vxNgYDsHIln/ls28ZVWZ99Bnz9dY+sXBYEDyqVqscDvwpB4gYtLS2or6+3czH0OpIg8feM5Kuv+F8HmeMEZoYOBd54Azh5Eli6FIiNBb77jifMuuUW713D4mIu0Jcs4UbaO+4ASkq4Q4eYhQDgYdvT09ORkJDQwT38fCIvL8+SzKsn8aogYYwl22y9JLKfleeffx6D+vTBirlzuUqjM+rrgf/7P/eTJwXCjESv5zMSgNsFBJ3Tvz8P9lhWBjzxBNfXr18PjBkD/OEPXCi7o+KUaG3lwmPaNC5MLriAO0B8/DGfkQgsKBQK5ObmQq1W27mWBwLp6ekodjJLldRQBQUFyMvLQ0GB04DnXaJSqTxK/+sRjlYpuroBmATgPfB1HccAfAfge5vtOIBdAJ4EMMmTc3lz6+7KdgCUIK12jo7mq0adsXkzr3fVVe6d5Kef+HEpKS4fsm3bNvfO0RVbt/I+XHSRd9t1A6+PqSc5dYrogQeIwsOJpPulTx+iBx+kA88/T1Re3vm9YzAQffEFkVLJjw0JIXr0UaJ2q7klXF2V7Cvar2b3F6WlpQTALqKAJ3gyrtLSUsrIyKAlS5aQQqGg/Px8h3Xmz59vVzZ//nwqKirq1jlzc3MtnxUKhdN6jsbl6cr2bilXGWOzwN1wd4LnDVncRf3JAGYzxpaZ62/tznn9zZNPPon8/HxUR0Sg//jxfJ2Fs/UUkiuvu+oNW9WWzcK3HmXTJv5XzEa6x9ChwOrV3GV47Vq+5uTAAeDddzEO4ItVo6KAqVOBK6+0Rrk1mbjK6rPPuLoM4DaR998XeVJcwFHudn+hVCotXlN5eY7jyGZnZyMzM9OubNmyZcjKykJ+Pl9bvWrVKpSWljo9j5RxsaCgwK8JstwWJIyxlwEcJyKXXXmIaDeA3ebjb2aMLSeiZe6e29+sXLnS9crDhnEVh7uuvH368K2ujodwSErqXme7CxGwcSP/LASJZyQm8twmjz0G7N0LbNyI+q+/RuLx49zjascOvjlixAju+ffgg9w7TNAljnK3BzIbNmzoYM9RKpV26q2MjAy32pNQq9VYtWoV0tLSekbd5Wia4mwDsAhAvDvHOGknHsADnrbT3a27qi23GTeOqybcnapedhk/ziaYX2d4VQ104AA/d79+XMXiJ4JatdUJlnHV1BB9+SXRU08R3Xcf0a23Et1+O1FWFtF33xEZjS632ZVaQtKu2XLttbzMJuYo5eTwskWLrGVnzvCyQYPsj09J4eWFhVZVyfPP87Lnn7fWKyx0rKkdNIiXnznj2hhdQaFQUG5uLuXk5FBubi5lZGRQtk0AVHfxlspOqVR2UG1JajhHAOi2esu2DWf4XbVFRKu9JLzOAXjfG235jXPn+KyhM2l/4YXAwYNcTZWS4nrbo0fzZEtHjvR8PgxJrXXttYGVA6K30bcv8Mc/8k3gMcXFxVCr1cjPz7eolNLS0pCQkICMjIyAUHfZYhvQ0xH19d2LPyvNRAAgKysLmZmZPTIj8YoDOmMsmYhOeKOtoOB//wMuvxy49FL+wHdGdz2w/Om59e23/G9nscQEQQU5CKdnE0zaQkYG32wZPNjx8UVF1s9SKpIXXuCbLampjo8/e7azHrtPQUEBFAqFw9Xc9fX1XQqS9PT0Dg93o9HoNPROTk6O/zykOkGhUGDJkiVYsmRJj57XWyuZsgA8aFvAGIsHTySVT0R7vHSewGD0aG7/6ComkiQQ2oXbdql9oOcFSXMz8MsvPOzErFk9e26BwAPy8/PtQvwDgBSY1ZUHfm5ubocynwVt7IV012vrOIBS8LhYDkO3m9VXKxljsxhjV1OQemo5pF8/HkKkK9VPejpw8818oZo7+GtR4o4dfA3JJZfwtKECQZBQWFjYwQMqNzc3YI3v0gxJrVY7nC0lSjmNgoTuzkjSASwEz5GeBYAYY1MAFAD4noi2SRWJaAtj7CaPexpouGI/6G6ET6WSzwpOnODRTHsqIJ3Z5dAXEW0FAl8h2UfaC40NGzZg9Wpu1nX2wJZIdxDBoX1eGFuys7M9Um1Jbsrt1W6Sei3FHZtqANAtQUI27rwAwBj7Hnx2kgoe/p3M/xeAz1xmA3AjMUcQ4Yu1HuHhwPDhPJbT8ePAuHHebd8ZQpAIghBH60ck4SKFC9mwYUOnrrT+UG2lpaWhuLjYTiAVFhYG7CyqM7wVIkVFREuJaA4RhQCYCmADuGCZDeBlL50ncCgo4Cqou+/uvN6zz/I1JY6sm50xZgz/e/hw9/rnLmfOAIcO8VnU9Ok9c06BwAs4Wj9i+0DOy8vrYD8JBLKzs+3SJwPciG+bGjtY8Jax3U6ckzWviBsr+IKM2Fhuw+gqum9zM8+fffAgcN11rrc/ZgyP1dVTgkRaBDVzZtdOBAJBAFFfX9/h4btgwQIUFRUhLy8PCoWix91/1Wo1li9fDrVaDZVKhaysLKSlpVlWogNcvZWdnY0VK1ZAqVRCpVIhMzMz6NRagJcECRG5GZmwFzBxIrBnj3Xm4IyxY/nfQ4fca19Ke1lS4nbXuoVQawmClCJbX2QzzlyBewqFQmERbp31Iy0tLShVWe1xS7XFGFvkjai+jLE4xtgDnrbjVyIiuDDpyhAuCZKDB91rXxJQPSFIiKwzEiFIBAKBm7glSMwr25/2xAuLMXYzgGVEFNwr211FEiQlJTwon6tIM5LDh907rjvs3w9UVfHVZ9J5BQKBwEXcNrYT0VIA5xhjGxhjTzLGkrs6xpyf5CnG2HoADRSEARsd8sMPwO23A++847xOQgIwaBCPFCxFdHWFxESe56K1FSgv97yvnWGr1hKJkgQCgZt01/13C4At5vDwixljaQAIQD0AtbmaAkAfc3khgDwi6l3G96oqHvJbrQb+9Cfn9caOBSoquJ1k+HDX27/oIr4qvqSEJzXyFcI+IhAIPMAjY7uD9STxABLBhYiaiMo86l2gc/nlQE4OXwneGffeC8yZY12x7ipjxvDV5ocPA3Pndr+fnaHR8JkVIMKiCASCbuEt918AlrAo57zZZkAzcGDHKHeOuP327rXfE55bv/zC1W7jx/PxCAQCgZt4NWe7wMv0hCARaq1eATkKsSsQuIA37h2XBEl7V13G2AOMsfWMsV3mbb2rhvdex7FjwGuvdb5ynYjvX7mye55bQpAIOkEmk0Gv1/u7G4IgRa/XOw2X7yqdChLzeo/ltq665lS7I8HjaG0AUARgBIAVAErNguV+j3oVTPz6K0+l+tFHzuswBjzwALBkiXseWEOG8JAlNTU8iZa3qa/niSXCwri9RxCUxMbGorGx0d/dEAQpjY2NHscU62pG8j6A5e3KSs1xtVYT0UoiWkxEUwCsAjAHPDTKMsZYHWPsRo96FwxceimwaBEPF98ZUuBFd1a4M+bbmFvbt/PZ0qWXdj9SscDvJCYmoqGhAbW1tdDpdELNJegSIoJOp0NtbS0aGho8DlvflbF9EYBl5k1iBGMsloiaOvaNuwUDgNkl+GXG2BwiehC9lZEjAXNqy04ZOxbYto0Lkt//3vX2L7qIzxpKSoAZM7rfT0dsMUe26cpbq7ER+O474KefeGh7gM9gnniCfzYYeH6W+Hjv9k/gEuHh4bjgggtQX1+PEydOwGg09uj5NRoNIiIievScPUFvH5dMJkNsbCwuuOAChHuYqqJTQWL2wlrGGHvARr2VA2AbY+wp27wjAFi7YwsATDGHVXngvFnJ7gxphfuBA+4d58tQKV0JksOHgRdfBPLyuJuwLX36WD8fOwZMmMAF3ezZfEtJAZzkchB4n/DwcAwaNAiDBg3q8XNv374dkydP7vHz+hoxLtdx6ZduKwSIqIwxtgDA94yxBgAvgc9CHM6niWh10MfV6ormZh7AMToacHaBJkzgf/ftc69t21Ap3uTMGZ7KNyYGmDrVcZ0lS6xOBJdfzgWEpKJLTrbWq6nhKrIdO/j2zDPc7jJmDFeb/eMfQN++bnUv4swZ4MMPeXLvM2esW1sbz974/fdWddyvv/JIABde6NY5BAKBd+juynYVgJGMsSXgoeKHA1CbBUsBeH6SEwAPjwJunO+9fPYZkJkJ3Hor/+yI8eP534MHuSrI1bd1X3luSbORK68E5HL++cwZoKnJOgt64QUgKYkLlM5W5F9xBRcmW7dyL7AtW3hCrn37uLB67TVr3f/3/4CyMiAqigubqiqrsFi2DLjvPgCAYt8+YMUKx+djzD58/0MPAYWFwKRJwJ138uvghzdzgYvo9TzzZ2Ska5lGBQGPpyvbVwBYYbaHZAJYDGApeOpdqVqBeV/vZdo0PuMYNcp5nfh4/hbPGH94JiW51vbIkVzonDjB38a7yn/iKrZqLYMBePNN4LnneFIrySU4JQV4913X2ktI4A4HktNBczOwdy8XGpKe2WAAXnmFCytHlFkDIbQolcAdd/DvafBg/jcpic9Cmpp4KmIAMBr5TOTYMT4r3LMHeOopPnu6915g/nzxsPI3+/cD69dzW9/Ro/xeNpn4C0oQJnECwAXh6dPcfgjw3/eIEf7tkx/xVj6SAnCBYRsmBb0+RIrEpEn8odkVhw+7n39dLuc36JEj/Ec4cWK3umgHkVWQXHABV23t2cP/j431Tp74mBhuM7F1ENDpeEiZtjZunNdqeWBKSUgMGWKp2jR6NJ/ldYVMBnz6Kbfh/N//AR9/DHzzDXcO+O47YM0ayyxH0MOYTDx8UGGhfbk0o7R98G7eDKxezWfBkho40NizB/jiCz7z3rmTz6wk/vhH4Msv+eemJv6/Usln8klJ/Hc2bBgwdKhVA9CL8Lo19LwLk+IO3X04X3QRFyQlJd4RJEePclVSVBRw2238AZ+cDLz1FjBvnuftOyMqiqudfEFEhHVGVFcHrFvHt9tus9YxmawzGX+jVgMqFe+35IhRXg4sXcpnZk1NXNiaTFzwE3GnB8me9dFH3DY0bBi3DyUm8llhQgLQrx9/YPUUREBpKbeP/fAD8PbbfOYYEsIfoCoVnxn+/vdcbapU8t+CrZvyK6/wB/RXX/Fr9txzfrd5MaORz3ilGe3TT3OBB/CxDRvGv2/G7FW/KhUfy9atDhpl/CXuqqv4/xs38pdQhYJfw5EjuWbD1pnFGxgMPHCsr+4LIjrvttTUVPIJzc1EJ050Xa+11b12ly3jj5LnnnO4e9u2be619+ab0qOJb5mZRE1N7rXhY9weU1fU1RGNGUP09ttEer1323aF6mqiDz6gyrQ0ouRk63d/663WOseO2V+X9tsPP1jrPvig83rjxtmf+6GHiLKzib7+mt+fJpNnYzGZiI4cIVq1iui220jTt6/9+fPzrXUrKoi02q7bPHuW6JFHiMLCeBuMEd18M9GuXZ711R3a2oh+/ZX/Pm6/nXRxcfZjyc0lWryYaNMmIrXaeTvnzhFt3szvtaee4td4xgyiIUP4uA4ftta9+27H13DIEKInnvB8TFot0fvvE40YQTR5MpHJ5NFvC0AhOXimujUjYYxNgllt5QXqiWiPl9ryP/n5/I1r1izuUeSIM2e4FxNj7uUm8bbBfZvZazsmhuuur7nGO+0GMh99xFWLf/4zd2m++24eTFPyQvMlf/4z8N57gMmEAVJZVBR/Mx82zFpv0CCuihs5kuvco6L42zBjfLMNqnn//fztvrwcaGjgUQqkv7a2OrWa279siYnhs6CLL+bpD1JTefnx47y9mBj+xt3Swt9iT53iM6e//IXXO3PGLpJ1OMDfoK+4gjtv2KafdjUQ6KBB3Cnj0UeBl17i1+s//+HbZ595ZyZrMPCxVFXx36HEn//Mg5fu38/rmJEDwI8/AlIq3Pnz+dYVcXHO14rpdPaONjfeyFW6587xlBHHj3N7X3k5n9lItLUBxcVcVeiKo87hw8AHHwD//jcfL8BViRUVXR/bDdxVbU0FDxHvDRoA7PFSW/5n3Dj+Y7e5ETswYAD3btJo+A9coXCtbW+tbifiqhJJkBQUdB0Cv7fw6KP8of3001xNuHw530aNAq6/nqtWJNzxqmsPEbBrF1chSJ5jF1zABcLs2Tg2ejRG3Xcff4i3dwKIjnbdnpOaahUAnRESwoXYwYN8O3CAP7B27uTbggXWumvWAC+/7LidUaOsgmTIEO6UMWQIcOWV2BUdjal33+0dtWFyMl/g+8ILXLB8/LH9Q/nNN7mN4fLLeZ/Cwhy3c/w4Vy0dPWrdSkv5tY2P50JXcgjasoXfE4zx3/GUKcCUKdgZF4dpd93l+Zhsad/fG27gmy1EwO7d9knmtm3jauf4eO5IMncuF9ojR9rXq6oCbroJ+Plna9m4cdwjcuFCfl8fPerdMfE++1/VZLuBC6olAOab/6Z0UncJgGwAKQDSAOS4cg6fqbZaWrquk5rKp64//uh6u42N/JjwcCKDocNul6aqR44QTZvG1RsA0bBhnqs4fIjXVVsSJhNXEd13H1FiIv8ubrjBur+2lqtXJk3iaodXXyUqKOCqKWftqVREa9cS3X8/VyEARC+8YK3T0MDb9eW43KGmhmj7dqK33uKfJd59l+iKK4hSUogmTiS67DKiG2/kKqc333TanE/HZKuGNJmIBg60qn9CQogGD+bbgAH2fczJca4ymjnT/rf6zTdEO3Z0UO8GxLWSyMsjuvDCjuOJjOTPFAm9nigujigmhuiBB4h+/rnD79zvqq0eIhdAJvG1KmCM5TPG0olI7aR+hnkrAA/p4j+iorquM2ECd4Pctw/43e9cazc2lr/9lZdzQ+xIN5flnDzJp+enTwN//zsvu/zy8zOtLmN87Jdfzt/U9+yx/x5UKq5+kFyJbRk0CNi0ib+xAjxYZ24uV/XY0r+/vZu2qzPPnqJvX/42e+WV9uWLF/MtkLCdGRoMwPPP8xhxv/3G1VRnz1r3NzdbP0+ZwtWXF15o3UaOdPwb/cMffNZ9ryE5kqhU3BuxoICr3Wpq7GcYoaH8Hk1N5SrKHsJdG8nNABK8dO56IvqiXfsKAEpJiJhRgc828hy0oSYib/XHe3TmPuvJCvfycq7eckeQ1NfzqfDp08Bll3FXxN9+837crmBELu+4qn/qVK6vPnCAe9Ps22f9W1Fhv/6nupoLkT59+EvB5ZdzO8HkySI8jC+Qy+2FnVbLVTkhIfz7to1gm5ICrF3rl276FKUSePBBvhFxO1b72GrtXxB6AHfvdrUXz+3IRXiKg3OoAcyGY0ECAGCMpYALFZWzOj3C6dPAtdfyN1pnhvHuCpIxY7hBv6SEn8MVjEbuSnnsGHcb/r//s55fCBLnxMVxoXvZZdYyk4kvpLM1Hr/wAndTHTUqcNyKzyfCw7n96XyFsR6ddXSGW4KEeHRfX6IAUN+urA6A0tkBjLH54GqtNMZYJhFlOaknqcAwYMAAbN++3Rv9tT+H0YgZx44hxGDAzxs3wuAgGq68sREzABj27MH/tm51+QE0WCbDhQAqtm7FkXZv0c3NzQ7HM3TdOoz47jvo4uNRtHQp8P33uPT0aRiio/G/mhquIghQnI3J75w61bHMDU+YgB2XB/TGMQFiXG7hyHDirw3cwF7UrmwJgFwXjy8FkNZVPZ8Z24mI9u7l/uid8cYbRN9+69Bw7pQdO7hxberUDrscGs9OnSKKiODHfPMNL/v8c/7/H/7g+nn9REAZOr1IbxxXbxwTkRiXIxAkxnY1OroX90HHWQoArtIiomKbomJwNViBLzrnEq6Ed3joIffbtU2M5coK7SFDgHfe4b7nkjHxp5/4X6HWEggEXiTQFLuF6LjgUQEgv31Fs12kvapNAT4r6X306cP18y0tri1mZIwHLbRdjPa///G/QpAIBAIvElCChLiLbyFjzNYmMgXWgJBKaZ95JtLeHqIEzyPvXx57jK/8rax0vL+yki+Gc7b4yxnSrOTgQed1DIaO7qgAj920bx/3bpk2zb3zCgQCQScElCAxkw5gPmNsvtlAvoisa0gyYS88ChljSxhjGYyxbACdrTfpOQ4e5L7dzgxaTU18hfUbb7jX7sUXW9t3xpo13IuofViMX3/lKrGUFNfWuwgEAoGLBJqNRJqVOMxoRO08ssyzkmJHdf3KCy/wrIDSwrX2jBjBXUwrKvjmahImaUbiLF2vTsfP29bGw7HYIuwjAoHARwTijCT4uewyrj5yZhAPCeEzA4CvcneVrlRbn3zCFy2OHdsxuJywjwgEAh8hBIm/kALudUeQlJR0XM1qNFptLsuW2Qsxg4GrtgAhSAQCgdcRgsRX7NzJw5S/+qrj/d0RJPHx3K1Xo7EPMQ3whEDHjvHoqbfcYr9v3z7u7TViBPf8WrECuPpqHrNH4ptvePiFP//ZWkbEw33ceKPz9LgCgeC8RwgSX1Fby/MofPaZ4/3dESSAc4P7W2/xv48/bh/nqanJGiJdmo0cOcLDUtt6lbW18YCQth5fFRU8cOH//mcfiuEvf+H5MDoz+gsEgvMGIUh8xVVX8Tf/3FzH+0eO5ELhkkv4DMNVHBjcQ3Q6rsqKieERT22ZORP4/HP+WRIkDz1kTcQlMXs2z+HwwQfWsn79eMDC9eutEXKJeArbDz6wj3BbWWmfw1ogEJw3BJzXVq8hMhJ46inn+0NCeEY2d3FgcDeFhfHkPDU1QGsrd++VZiW33MKFjk5nDVs/aVLHduPi+GaLXN5xpT4R8PXXPAqx0ma5z7338vN89hmPgisQCM4bxIwk2JBUW45cgDds4HaQDz+0ls2fz4VIQoJ9CtTuEhLCs+Pdc4+1TFpt39BgTQsMcKEjEAh6PUKQ+JpPPgHmzOEhyB2hVvO0mq4iPaiPHOGqpK1bESuFrO/bl89Iim2W1kgpNy+7zHehzqOjuWArKuJ9ALgQkQROTY1vzisQCAICodryNf/9L7dH5OUBTz5pv+/kSe5lNWAAN2y7krEwJoYfc+IEkJ0NvPsuUs+e5fnI09O57cU2l3dPLUQMCeFhYSQOHeKeaydOAKtX+/bcAoHAr4gZia956CEetuTeezvuu+ACHoyxqsq1QIwSknrr2WeBs2ehi4/nqXRDQuyFCGAVJK6m9fUW48bx9S4ff8xtLQCfQV1xBTf+B6Laq7mZOxeYTP7uiec0NXG72d691jKTib/UqFSB+f27CxFX29o6ebS28pwx7ddZBTpE3GGlvcpaqw2K+1EIEl/zu98B993HBUZ7GOPqH8C6YLAzDAb+VzK4J/AswxXz5gFhYR3rnzvHDfpyufNwLb5kzBiu1pP46iueZ/q55/gDIJAwGIDBg7kjQlWVtfzZZ7nDwfr1fuuaS1RX26/1ef11/nKRk2Mtq6zk12PyZPtjv/sOKCwMvGsiQcS9H7Oy+INV4tFHeZbEd96xlv38M5+dX3JJj3fTZaqreRrgdeusZQYDD5U0caK9ELzrLv77/fhja9mpUzxnuzN1uR8QgsTfuCpINm3iAuTMGeuMxPzgqLR147Xll1/4jzA11d5V11/cfDPw/vvA229bc9qbTP5541Kp+MNWIjSUP3zGjrV/IJeWcmFs+wb/66/AokXA5s0919/O+NOfuHr0iy+sZWlpPEzPqFHWsrY2ns979mx7Ner99/Nc9bYPppMngcZGn3fdITodV4tKMMYF+ooV9p6OYWH8IWt7/8TG8kW3tuPW6bjwfOSRwJipbN/ONRQrV1rL5HKuGm5//+l0fHy2KYX/+19+DZcutW/XVsj2NI6yXfX2zacZEh1hMhG9+irR+PFEFRX2+/LzedbCadM6P/7qq3m9554jKi7mnwGiSy5xnvHsmWd4nSef9NpQvM7KlURXXUV0/LhdsU+z07W1ESUk8O+msNBabjR2rNvaSvTDD0R1dday557jxz76qLVMrSZ6/32iY8c6PbXH43rrLaJLLiE6etRa9sorRJGRRCtWuN+eTkd0661EKSn2GTtvvJFIJiP68ssum/DqtaqvJ+rbl2f3bG21lv/rX/x7LyuzlplMztvR6ayft2zh12vcOPs6mzYRlZc7bcIr42ppIfriC6JPP7WW6fVEd97JM6V2NgYJrZYfI7FuHdGVV/K/Evv3EykUREuWdNmcLzIk+v2h7o+txwUJEdENN/Cve/ly+3K1mogxIrm88xS9NTXWG0+j4ccARP/8p/Mb46qreB0XHgZ+oa2NaOhQ3sdvv7Xb5dWH0+HDRO++a/+gXLaM6K67Oggwlzh4kAvAn3+2ln39NR/HZZfZ162psfvX7XFVVNg/bNLT+XneeMNa1txs/+D0BvPmcUFi++BetYpowQKiH3+0q+rRtaqqIvrPf+zLLr2U6OKLiUpLu9+uLQYD0U8/WVNOExGdO8d/czIZUUODw8PcHldNDdH//R9Piy2xbx+/Xv362QtGb/Pqq/w8mZnWMqOR6MyZDlWFIAlmQXLgAFFuruO33nHj+KXYudNaVlfn/I3FZOJvbeYHsMMbQ6fjb6kA/7EGKtXVRDk59mX5+bRj8+butXf2LNF339mXTZ3qUFh5lf/9j+jmm4mys61lNTVEYWFEs2ZZ3ijd+hEvWMBfGIqLrWW//EKUl8eFh69pbLT/X3ox+ewza1lFBRW+9x5RU5Nrbdre/42NRFFR/GF+9qy1vKHBtTd1TygrI/rjH4l+/3v78htvJLrpJqLaWuu1amjg47Pte00Nn2kcOWIt27iRfz+2bZpMvM0VK3x/zfbts38x2rKFKCSE6IEH7KoJQRLMgqQz9uwhqqy0/m8wcDUYQPTmm46Puesuvv+ddxzfGDt38v2jRvmkyz7j5EkiuZw0fft2fJB1hVrN3zIBriKR+Mc/+Jv8Tz95t69d8e23XJj/4Q+Wom0FBUR33030wgv2dZcuJZo5k78pS/zpT0Th4URr1/ZMf7uitJTotdfsv9tnn+Xft+14fvuNq16WLrWWaTREAwcSxcfbt5meTnTttXzW6A9sBVZ5OR+LXE6k01l/V9ddx8ttX27++lde9vTT1rKSEqK0NK6CCwTeeIO/yLTrjy8EiVhH4g9OnQK2brWuDp840X6/TMYzKL7yCnD99Y7bmDwZ+Pe/eVBF29XkEv5y+/WU+npg4kSo4+MxIDaWl5lMPLZXaqrV44iIGxuPHbMamePjgRtu4G3U1Vm82vDXv/b8OABg7lzuKVVbaykKr60FPvqIG4Sff95a9/vv+ULS3bu5QRzgBuaXXuLjCgSUSm6wtsVkQrNSiRjJAQTgXm87dnDDt0RYGL8mBgN3s5aCgK5b57uFsq5g63QwcCD/PZ06ZXVZB7h7cWQkEBFhLZs2jbuyjxxpLRszhrtXBwoPPQTcdlvPnMuRdOntm19nJE1NVrvAV19Zy3fv5sY/W2wNbBKHD3Oj7n//y9uYOtXxG8ZNN/H977/vzd73DCYT/WCrz5acC1JS7OvFx/NyVw2wAcCP//0vvyZvv22/4+uv+aZW+6djHtDh/qutJdq61V4lR8TVV9625fgQnzp8+BExI+kNxMQAS5bwN+zZs3mZWs3ftKVAjmPH8vJQB5fn/ff5TOX++/n/+/aBSetLJEwm/kYI8Oi/wQZjMNq6K4eE8FX7/frZ13vmGZ5pcvBgu2MDGUNMDHDttR13zJvX853xFX368OjX7XE1pbQg6BCCxB/85S9ARoZ1EaFCweNVtbTwBVWSIGmP0Qh8+in/fP/9fHHf0aOIbp/k6uBBrkYYMsQ+Qm+wMnEiD0jZnvYhZwQCgV8QCxL9RfuV6JIe/7ffnB+zZQuPyTVyJF/IOG0aACDu8GH7etu3878zZwb8G7pAIAh+hCAJFCQ115Ytzuv8+9/87513cgFhFiSW6L8StoJEIBAIfIwQJIHC5MlcxVVWxrf2NDUBX37JP99xB//raEYS7PYRgUAQdAhBEijIZFYD5datHff/5z88sunvfme1e0ycCISHI+rkSauLaW+zjwgEgoBHCJJAIi2N/3UUDLB/f55TxDYne0QEMGMGGBGwbRsvE/YRgUDQwwivrUDiuuuA8nLgpps67rvmGr5RuzwSaWl8BlNQwF1kJRuLUGsJBIIeQsxIAomhQ/lK5s5yh7SfZUizmPx8vh5l82ZeZ+5cn3VTIBAIbBGCJNDR64HHHuO2D0ekpPAMiWVlfH2KTsdtLUOG9Gw/BQLBeYsQJIHI2rXcI6u6mmfme+01rrZqr9YCAJkMZyRVmLRY8c47e6qnAoFAIARJQPLll8CuXcDDD/PgjQBfxe3EeH7mppuAuDj+z9SpXOgIBAJBDyEESSDy3HPcHXj9euD0aR711tZbqx2GmBgePfbjj3nU3+joHuysQCA43xGCJBBJTeVCYfRobjT/6isuWDrjkkv4QkXb8NcCgUDQAwj330Dl1lv5JhAIBAGOmJEIBAKBwCOEIBEIBAKBRwhBIhAIBAKPEIJEIBAIBB4hBIlAIBAIPEIIEoFAIBB4hBAkAoFAIPAIIUgEAoFA4BGMHAUC7OUwxmoAnPR3P7xIXwC1/u6El+mNYwJ657h645gAMS5HDCOifu0Lz0tB0ttgjBUSUSdJTIKP3jgmoHeOqzeOCRDjcgeh2hIIBAKBRwhBIhAIBAKPEIKkd7DK3x3wAb1xTEDvHFdvHBMgxuUywkYiEAgEAo8QMxKBQCAQeIQQJAKBQCDwCJHYKsBhjCkAZABQAVACKCCiYid1lwDoA2A9gEQA6USU2UNddQvGmBJANoAcIiropJ4CLo4/EHBjXMF0rVIApJn/nYpOxhZM18vNcQXF9TKPKRGAAvz7BxGtcFJXAW9dKyISWwBvAPIBKNv9r3BSdwmABvOW66yevzfwH28agCIAad4av783N8cVFNdK6qvNZ4W5zym94Hq5M66guF7txwCAeuJaCdVWAGN+Y1ASkcqmWAXrW1R71ESUYN7SiUjt6z52ByIqIP7mV99ZvW6M36+4Oi4zQXGtzG+4y6T/zf0shINrEEzXy51xmQmK6wVgFplnFebrAQDq9pW8fa2EIAlspqDjTaAGMLuzgxhjKWYVS7DTrfEHE4F+rcwPpfR2xUo4eDghiK6Xm+OyECTXS2IBgLx2wkLCq9dKCJLARoGOb7d14DpQhzDG5oO/WaQwxrJ917UeQQE3xx9MBMu1Ihu7gfkhmghgg4OqCgTR9XJjXFKdoLhejDElYywDwGwiai8sJRTw4rUSgiTwcfnCEtEqIsojIjUR5QGYzxgLOLWCmwTkQ8hTgvha5YCrT9RO9gfr9ep0XMF0vYhIRUSrAOQzxnI7qeq1ayUESWCjBn9zsKUPnOjgzXpfW4oRgGoFN1DDjfEHE8F4rcyeS9nk3LNHjSC8Xi6MKyivl1mYpJnH1x41vHithCAJbArR8a1BAe5dYYf5Rt/ioG6pLzrWQ7g8/mAiGK+VWa0jORPAiZ0g6K6XK+MKlutltt+075MKwAgH1b16rYQgCWAkT5J2N/cUAJabXtpnfpvKateEEp3ofAORdmNSo5PxBxPBfK3MKhx1O2+gFPPnoL1ebowrWK6XGh2/ayXMwsGX10rE2gpw2i0aSgRQaHPjZ4P7fWea/5cWWKnB30LWdzZd9xc2/VwG/maUa56GOxqTAk7GH2i4Oa5guVZKOH7zTiWi4mC9Xt0YV7BcrzSYFyICSAVQ1BO/LSFIBAKBQOARQrUlEAgEAo8QgkQgEAgEHiEEiUAgEAg8QggSgUAgEHiEECQCgUAg8AghSAQCgUDgEUKQCAQCgcAjhCARCAIIJ2EuBIKARggSgSCwWAi+0lggCBqEIBEIAos08MiyAkHQIASJQBBYpCCAo+UKBI4QgkQg8DOMsTTGWA5jTBIg6eb/Azalq0BgiwjaKBAECOborGlElOrvvggE7iBmJAJB4JCCAM3dIRB0hhAkAkHgkAZhHxEEIUK1JRAEAObESUVExPzdF4HAXcSMRCAIDOzcfs3Z6wSCoEAIEoEgMJgNe/tIhr86IhC4ixAkAkFgoIY5h7g577YwuguCBiFIBILAYDmA2Yyx+QBARGJ1uyBoEMZ2gUAgEHiEmJEIBAKBwCOEIBEIBAKBRwhBIhAIBAKPEIJEIBAIBB4hBIlAIBAIPEIIEoFAIBB4hBAkAoFAIPAIIUgEAoFA4BFCkAgEAoHAI/4/U2VmxgYRD60AAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.lines import Line2D\n",
    "import regression_model\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "nums = [300, 3000, 30000, ]\n",
    "ltys = ['-', '--', ':',]\n",
    "lw = 2\n",
    "labelsize = 20\n",
    "ticksize = 15\n",
    "\n",
    "lines = [\n",
    "    Line2D([0], [0], color = 'k', linestyle='-', linewidth = lw), \n",
    "    Line2D([0], [0], color = 'r', linestyle='-', linewidth = lw),\n",
    "    ]\n",
    "labels = ['GD', 'PC']\n",
    "hs = [r'10^{-2}', r'10^{-3}', r'10^{-4}']\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "for num, lty, hstr in zip(nums, ltys, hs):\n",
    "    \n",
    "    t = np.linspace(0, 3, num = num)\n",
    "    theta_star =  regression_model.true_parameter(t, a = 0, omega = 1)\n",
    "    \n",
    "    \n",
    "    X = np.random.normal(size = (40, 2))\n",
    "    y = regression_model.observations(X, theta_star, tau = 0.5)\n",
    "    h = t[1] - t[0]\n",
    "    eta = h ** (0.3)\n",
    "    theta_gd, m1 = regression_model.gradient_descend(X, y, h = h, eta  = eta)\n",
    "    \n",
    "    eta = h ** (4/5)\n",
    "    theta_pc, m2, p = regression_model.prediction_correction(X, y, h = h, eta  = eta)\n",
    "    \n",
    "    \n",
    "    \n",
    "    m = m1\n",
    "    no_of_steps = theta_gd.shape[0]\n",
    "    err_gd = np.linalg.norm(theta_star[-no_of_steps:] - theta_gd, axis = -1)\n",
    "    err_pc = np.linalg.norm(theta_star[-no_of_steps:] - theta_pc, axis = -1)\n",
    "    plt.plot(t[m-1:], err_gd, color = 'k', linestyle = lty, lw = lw)\n",
    "    plt.plot(t[m-1:], err_pc, color = 'r', linestyle = lty, lw = lw)\n",
    "    lines.append(Line2D([0], [0], linestyle = lty, lw = 2, c = 'blue'))\n",
    "    labels.append(r'$h = ' + hstr + r'$')\n",
    "    \n",
    "    \n",
    "plt.ylabel(r'$\\|\\hat\\theta(t) - \\theta^\\star(t)\\|_2$', fontsize=labelsize)\n",
    "plt.xlabel(r'$t$', fontsize=labelsize)\n",
    "plt.legend(lines, labels, fontsize=labelsize)\n",
    "plt.tick_params('both', labelsize = ticksize)\n",
    "plt.grid()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6af881e0",
   "metadata": {},
   "source": [
    "## Object tracking"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "0c970495",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import object_tracking\n",
    "import numpy as np\n",
    "\n",
    "nums = [300, 3000, 30000, ]\n",
    "ltys = ['-', '--', ':',]\n",
    "lw = 2\n",
    "labelsize = 20\n",
    "ticksize = 15\n",
    "\n",
    "lines = [\n",
    "    Line2D([0], [0], color = 'k', linestyle='-', linewidth = lw), \n",
    "    Line2D([0], [0], color = 'r', linestyle='-', linewidth = lw),\n",
    "    ]\n",
    "labels = ['GD', 'PC']\n",
    "hs = [r'10^{-2}', r'10^{-3}', r'10^{-4}']\n",
    "\n",
    "for num, lty, hstr in zip(nums, ltys, hs):\n",
    "\n",
    "    t = np.linspace(0, 3, num = num)\n",
    "    theta_star =  object_tracking.true_parameter(t, a = 0, omega = 1)\n",
    "\n",
    "\n",
    "    xgrid = np.arange(-1, 1.1, step = 0.2)\n",
    "    ygrid = np.arange(-1, 1.1, step = 0.2)\n",
    "    XG, YG = np.meshgrid(xgrid, ygrid)\n",
    "    XG = XG.reshape((-1, ))\n",
    "    YG = YG.reshape((-1, ))\n",
    "\n",
    "    X = np.vstack((XG, YG))\n",
    "    X = X.T\n",
    "\n",
    "\n",
    "    y = object_tracking.observations(X, theta_star, tau = 0.5)\n",
    "    h = t[1] - t[0]\n",
    "    eta = h ** (0.3)\n",
    "    theta_gd, m1 = object_tracking.gradient_descend(X, y, h = h, eta  = eta)\n",
    "\n",
    "    eta = h ** (4/5)\n",
    "    theta_pc, m2, p = object_tracking.prediction_correction(X, y, h = h, eta  = eta)\n",
    "    \n",
    "    no_of_steps = m1\n",
    "    err_gd = np.linalg.norm(theta_star[no_of_steps:] - theta_gd[no_of_steps:], axis = -1)\n",
    "    err_pc = np.linalg.norm(theta_star[no_of_steps:] - theta_pc[no_of_steps:], axis = -1)\n",
    "    plt.plot(t[no_of_steps:], err_gd, color = 'k', linestyle = lty, lw = 2)\n",
    "    plt.plot(t[no_of_steps:], err_pc, color = 'r', linestyle = lty, lw = 2)\n",
    "    lines.append(Line2D([0], [0], linestyle = lty, lw = 2, c = 'blue'))\n",
    "    labels.append(r'$h = ' + hstr + r'$')\n",
    "    \n",
    "    \n",
    "plt.ylabel(r'$\\|\\hat\\theta(t) - \\theta^\\star(t)\\|_2$', fontsize=labelsize)\n",
    "plt.xlabel(r'$t$', fontsize=labelsize)\n",
    "plt.legend(lines, labels, fontsize=labelsize)\n",
    "plt.tick_params('both', labelsize = ticksize)\n",
    "plt.grid()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "53656473",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
