{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.read_json('ift_log/continue_pretrain.jsonl', lines=True)\n",
    "df1 = pd.read_json('ift_log/SFT_new.jsonl', lines=True)\n",
    "df = df.iloc[1124:].reset_index(drop=True)\n",
    "df1 = df1.iloc[len(df1)//2:].reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [],
   "source": [
    "# For df\n",
    "window_size = 20\n",
    "threshold = 0.5\n",
    "\n",
    "# Create a mask for rows to keep\n",
    "mask = ~(\n",
    "    (df.index > 100) & \n",
    "    (df['train/loss'] > df['train/loss'].rolling(window_size, center=True).mean() + threshold) & \n",
    "    (df['train/loss'] < 1.5))\n",
    "\n",
    "df = df[mask]\n",
    "\n",
    "\n",
    "# For df1\n",
    "mask1 = ~(\n",
    "    (df1.index > 100) & \n",
    "    (df1['train/loss'] > df1['train/loss'].rolling(window_size, center=True).mean() + threshold) & \n",
    "    (df1['train/loss'] < 1.5)\n",
    ")\n",
    "\n",
    "df1 = df1[mask1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>val/loss</th>\n",
       "      <th>train/time_ms</th>\n",
       "      <th>train/step_avg_ms</th>\n",
       "      <th>train/step</th>\n",
       "      <th>train/loss</th>\n",
       "      <th>lr</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>12.370827</td>\n",
       "      <td>45.295477</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>NaN</td>\n",
       "      <td>358.559608</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1</td>\n",
       "      <td>9.783445</td>\n",
       "      <td>0.000003</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>NaN</td>\n",
       "      <td>575.093985</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2</td>\n",
       "      <td>9.551009</td>\n",
       "      <td>0.000006</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>NaN</td>\n",
       "      <td>884.417534</td>\n",
       "      <td>NaN</td>\n",
       "      <td>3</td>\n",
       "      <td>9.245922</td>\n",
       "      <td>0.000009</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>NaN</td>\n",
       "      <td>1170.883894</td>\n",
       "      <td>NaN</td>\n",
       "      <td>4</td>\n",
       "      <td>9.012819</td>\n",
       "      <td>0.000012</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1967</th>\n",
       "      <td>NaN</td>\n",
       "      <td>455179.032803</td>\n",
       "      <td>233.664801</td>\n",
       "      <td>1958</td>\n",
       "      <td>0.671243</td>\n",
       "      <td>0.000031</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1968</th>\n",
       "      <td>NaN</td>\n",
       "      <td>455322.733402</td>\n",
       "      <td>233.618642</td>\n",
       "      <td>1959</td>\n",
       "      <td>0.680786</td>\n",
       "      <td>0.000030</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1969</th>\n",
       "      <td>NaN</td>\n",
       "      <td>455465.952873</td>\n",
       "      <td>233.572284</td>\n",
       "      <td>1960</td>\n",
       "      <td>0.669456</td>\n",
       "      <td>0.000030</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1970</th>\n",
       "      <td>NaN</td>\n",
       "      <td>455610.462189</td>\n",
       "      <td>233.526634</td>\n",
       "      <td>1961</td>\n",
       "      <td>0.679413</td>\n",
       "      <td>0.000030</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1971</th>\n",
       "      <td>8.198108</td>\n",
       "      <td>455667.217255</td>\n",
       "      <td>233.555724</td>\n",
       "      <td>1961</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1969 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "       val/loss  train/time_ms  train/step_avg_ms  train/step  train/loss  \\\n",
       "0     12.370827      45.295477                NaN           0         NaN   \n",
       "1           NaN     358.559608                NaN           1    9.783445   \n",
       "2           NaN     575.093985                NaN           2    9.551009   \n",
       "3           NaN     884.417534                NaN           3    9.245922   \n",
       "4           NaN    1170.883894                NaN           4    9.012819   \n",
       "...         ...            ...                ...         ...         ...   \n",
       "1967        NaN  455179.032803         233.664801        1958    0.671243   \n",
       "1968        NaN  455322.733402         233.618642        1959    0.680786   \n",
       "1969        NaN  455465.952873         233.572284        1960    0.669456   \n",
       "1970        NaN  455610.462189         233.526634        1961    0.679413   \n",
       "1971   8.198108  455667.217255         233.555724        1961         NaN   \n",
       "\n",
       "            lr  \n",
       "0          NaN  \n",
       "1     0.000003  \n",
       "2     0.000006  \n",
       "3     0.000009  \n",
       "4     0.000012  \n",
       "...        ...  \n",
       "1967  0.000031  \n",
       "1968  0.000030  \n",
       "1969  0.000030  \n",
       "1970  0.000030  \n",
       "1971       NaN  \n",
       "\n",
       "[1969 rows x 6 columns]"
      ]
     },
     "execution_count": 68,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "total_steps_pretrain = len(df)  \n",
    "total_steps_sft = len(df1)     \n",
    "epochs = 4\n",
    "\n",
    "df['epoch'] = df.index / total_steps_pretrain * epochs\n",
    "df1['epoch'] = df1.index / total_steps_sft * epochs\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAk4AAAHpCAYAAAB0qLM+AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB9yklEQVR4nO3dd1hT1/8H8HdCEvbeKIgIIrgVBy5wW7Wtra3aWnf1V2ut1tHdaqe2ta1a+Vpb62hrq1XrqHvjVtwo4MQt4mKvkNzfH9cEIitBICS8X8/Dk+TmJvmchPHmnHPPlQiCIICIiIiIyiQ1dgFEREREpoLBiYiIiEhPDE5EREREemJwIiIiItITgxMRERGRnhiciIiIiPTE4ERERESkJwYnIiIiIj0xOBERERHpicGJiIiISE8MTkRERER6Movg9MILL8DZ2RkvvfSSsUshIiIiM2YWwWnChAn4/fffjV0GERERmTmzCE6RkZGwt7c3dhlERERk5owenPbu3Ytnn30WPj4+kEgkWLt2bZF9oqKi4O/vDysrK7Rp0wZHjx6t+kKJiIioxpMZu4DMzEw0bdoUI0eOxIsvvljk/hUrVmDSpEn4+eef0aZNG8yePRs9e/bE+fPn4eHhYfDr5ebmIjc3V3tbrVbj4cOHcHV1hUQieaq2EBERkekRBAHp6enw8fGBVFpGn5JQjQAQ1qxZo7OtdevWwrhx47S3VSqV4OPjI8yYMUNnv927dwv9+/cv8zWmTZsmAOAXv/jFL37xi1/80vm6ceNGmTnC6D1OpcnLy8Px48fxwQcfaLdJpVJ069YNhw4dKtdzfvDBB5g0aZL2dmpqKvz8/JCYmFgh86SUSiV2796Nzp07Qy6XP/XzVXc1qb1sq3liW80T22qeKqut6enpqFu3rl45oFoHp/v370OlUsHT01Nnu6enJxISErS3u3XrhtOnTyMzMxO1a9fGypUrER4eXuxzWlpawtLSssh2FxcXODg4PHXNSqUSNjY2cHV1NftvYKBmtZdtNU9sq3liW81TZbVV81z6TNmp1sFJXzt27DB2CURERFQDGP2outK4ubnBwsICd+/e1dl+9+5deHl5GakqIiIiqqmqdXBSKBRo2bIldu7cqd2mVquxc+fOEofiiIiIiCqL0YfqMjIycOnSJe3txMREnDp1Ci4uLvDz88OkSZMwbNgwhIWFoXXr1pg9ezYyMzMxYsQII1ZNVDOp1Wrk5eUZu4wKpVQqIZPJkJOTA5VKZexyKhXbap7Y1rLJ5XJYWFhUSA1GD07Hjh1D586dtbc1R7wNGzYMS5YswcCBA3Hv3j18+umnSEpKQrNmzbBly5YiE8aJqHLl5eUhMTERarXa2KVUKEEQ4OXlhRs3bpj9Wm5sq3liW/Xj5OQELy+vp36PjB6cIiMjIS7hVLK33noLb731VhVVRERPEgQBd+7cgYWFBXx9fcteIM6EqNVqZGRkwM7OzqzaVRy21TyxraUTBAFZWVlITk4GAHh7ez9VDUYPTkRU/eXn5yMrKws+Pj6wsbExdjkVSjP8aGVlVSP+6LCt5odtLZu1tTUAIDk5GR4eHk81bGfe7zARVQjNXAKFQmHkSoiIykfzT59SqXyq52FwIiK9mfv8CSIyXxX1+4vBiYiIiEhPDE5ERJVkz549kEgkSElJMXYpJoPvWemGDx+Ofv36GbsMHf7+/pg9e/ZTPcf06dPRrFmzCqmnsjE4EZFZS0pKwvjx4xEQEABLS0v4+vri2Wef1VlYtyJERkZi4sSJOtvatWuHO3fuwNHRsUJfqzq5evUqJBIJTp06VSHPVxPeMzJtNfaouqioKERFRZn9YmFENdnVq1fRvn17ODk54bvvvkPjxo2hVCqxdetWjBs3Tudk4ZVBoVCY9OmhlEplhZ1INS8vT6+DC0z9PSPzV2N7nMaNG4e4uDjExMQYuxQikyMIArLy8o3yVda6b4W9+eabkEgkOHr0KPr374/69eujYcOGmDRpEg4fPqzd78aNG+jXrx/s7Ozg4OCAAQMG6JwjUzOM8Mcff8Df3x+Ojo4YNGgQ0tPTAYjDJ9HR0ZgzZw4kEgkkEgmuXr1aZNhpyZIlcHJywtatWxESEgI7Ozv06tULd+7c0b5WcT1X/fr1w/Dhw7W3c3NzMWXKFNSqVQu2trZo06YN9uzZU+p7IZFIMH/+fLz00kuwtbVFQEAAVq1apb1f03O0YsUKREREwMrKCsuWLQMALFy4ECEhIbCyskKDBg3wv//9T/u4unXrAgCaN28OiUSCyMhI7XvSr18/fPXVV/Dx8UFwcDAA4I8//kBYWBjs7e3h5eWFV199Vbu+DlB0qE6f96w40dHR6Nq1K6ytreHt7Y33338f+fn5Ou/z22+/jXfffRcuLi7w8vLC9OnTS31OTZtmzZoFb29vuLq6Yty4cTpHaZX22QiCAHd3d533vVmzZjrrCu3fvx+WlpbIysoqtRaNmJgYeHp6aofKyvpe1dT49ttvw8PDA1ZWVujQoYPO38KwsDDMmjVLe7tfv36Qy+XIyMgAANy8eRMSiUTnrB+FpaSk4PXXX4e7uzscHBzQpUsXnD59WmefmTNnwtPTE/b29hg1ahRycnJ07s/Pz8fbb78NJycnuLq64r333sOwYcPwwgsvaPdRq9WYMWMG6tatC2trazRt2lTnva0sNbbHiYjKL1upQuinW43y2nGf94SNouxfXQ8fPsSWLVvw1VdfwdbWtsj9Tk5OAMRfvoMHD4ajoyOio6ORn5+PcePGYeDAgTph5PLly1i7di02bNiAR48eYcCAAZg5cya++uorzJkzBxcuXECjRo3w+eefAwDc3d1x9erVIq+blZWFWbNm4Y8//oBUKsVrr72GKVOmaEOKPt566y3ExcVh+fLl8PHxwZo1a9CrVy/ExsYiKCioxMdNmzYNn376KebNm4dly5Zh0KBBiI2NRUhIiHaf999/H99//z2aN2+uDU+axzRv3hwnT57E6NGjYWtri2HDhuHo0aNo3bo1duzYgYYNG+r0Ku3cuRMODg7Yvn27dptSqcQXX3yB4OBgJCcnY9KkSRg+fDg2bdpUYt2Gvme3bt1C37598corr+CPP/7AhQsXMHr0aFhZWemEo6VLl2LSpEk4cuQIDh06hOHDh6N9+/bo3r17ibXs3r0b3t7e2L17Ny5duoSBAweiWbNmGD16tF6fTadOnbBnzx689NJLePToEeLj42FtbY2EhAQ0aNAA0dHRaNWqlV7rpe3atQsvvvgiZs6ciUGDBmm3l/a9CgDvvvsuVq9ejaVLl6JOnTr49ttv0bNnT1y6dAkuLi6IiIjAnj17MGXKFAiCgH379sHJyQn79+9Hr169EB0djVq1aiEwMLDYul5++WVYW1tj8+bNcHR0xIIFC9C1a1dcuHABLi4u+OeffzB9+nRERUWhQ4cO+OOPPzB37lwEBARon+Obb77BsmXLsHjxYoSEhGDOnDlYu3atNpgDwIwZM/Dnn3/i559/RlBQEPbu3YvXXnsN7u7uiIiIKPP9Ky8GJyIyS5cuXYIgCGjQoEGp++3cuRNxcXG4fPky6tSpAwD4/fff0bBhQ8TExKBVq1YAxIC1ZMkS2NvbAwCGDBmCnTt34quvvoKjoyMUCgVsbGzKHGZSKpX4+eefUa9ePQDiH1pN2NLH9evXsXjxYly/fh0+Pj4AgClTpmDLli1YvHgxvv766xIf+9JLL2Ho0KFwcHDAF198ge3bt+Onn37S6UGaOHEiXnzxRe3tadOm4fvvv9duq1u3LuLi4rBgwQIMGzYM7u7uAABXV9cibbe1tcXChQt1wtTIkSO11wMCAjB37ly0atVKuxp0cQx9z/73v//B19cX3333HRwdHREaGorbt2/jvffew6effqpdOLFJkyaYNm0aACAoKAjz5s3Dzp07Sw1Ozs7OmDdvHiwsLNCgQQP06dMHO3fuxOjRo/X6bCIjI7FgwQIAwN69e9G8eXN4eXlhz549aNCgAfbs2aPXH/01a9Zg6NChWLhwIV5++WWkpaVp7yvtezUzMxPz58/HkiVL8MwzzwAAfv31V2zfvh2//fYbpk6disjISPz2229QqVQ4e/YsFAqF9h+JXr16lVrj/v37cfToUSQnJ8PS0hIAMGvWLKxduxarVq3CmDFjMHv2bIwaNQqjRo0CAHz55ZfYsWOHTq/TTz/9hA8++EDbwzRv3jydcJ2bm4uvv/4aO3bsQHh4OADx+2n//v1YsGABgxMRVS/WcgvEfd7TaK+tD32H9BISElCrVi34+vpqt4WGhsLJyQnx8fHa4OTv76/9QwSIp20oPMSkLxsbG20AKM/zxMbGQqVSoX79+jrbc3Nz4erqWupj27Ztq3M7PDy8yKTusLAw7fXMzExcvnwZo0aN0vaoAOIwij6Ttxs3blxkXtPx48cxffp0nD59Go8ePdKe+/D69esIDQ0t9nkMfc/i4+PRtm1bnXV72rdvj4yMDNy8eRN+fn4AxOBUmD6fRcOGDXVWnfb29kZsbCwA/T6biIgITJgwAffu3UN0dDQiIyO1wWnUqFE4ePAg3n333VJrOHLkCDZs2IBVq1ahX79+Rc4fWdr36uXLl6FUKtG+fXvt/XK5HK1bt0Z8fDwAoGPHjkhPT8fJkydx8OBBREREIDIyEjNnzgQgDoNOnTq12NpOnz6NjIyMIt+L2dnZuHz5MgDx83njjTd07g8PD8fu3bsBAKmpqbh79y5at26tvd/CwgItW7bUzku+dOkSsrKyioTcvLw8NG/evLS376kxOBGRwSQSiV7DZcYUFBQEiURSYRPAn5wkLZFIynXC4+Kep3DIk0qlRUJf4Tk0GRkZsLCwwPHjx4ucNqKkHhtDFB7W1Mxp+fXXX9GmTRud/fQ5ZcWTQ6SZmZno2bMnevbsiWXLlsHd3R3Xr19Hz549kZeXV+LzlPWelVd5PtPSHqPPZ9O4cWO4uLggOjoa0dHR+Oqrr+Dl5YVvvvkGMTExUCqVaNeuXak11KtXD66urli0aBH69OlT5LWe9nvVyckJTZs2xZ49e3Do0CF0794dnTp1wsCBA3HhwgVcvHixxB6djIwMeHt7FzvnTjM8XhE035sbN25ErVq1dO7T9HRVlho7OZyIzJuLiwt69uyJqKgoZGZmFrlfM/m4QYMGuHXrFm7cuKG9Ly4uDikpKSX2gBRHoVBUyFG67u7uOhOfNcMlGs2bN4dKpUJycjICAwN1vsoaJjxy5IjO7cOHD+vMb3qSp6cnfHx8cOXKlSKvpZkUrulR0qftCQkJePDgAWbOnImOHTuiQYMG5eq1K0tISAgOHz6sE64OHDgAe3t71K5du8JfT0Ofz0YikaBjx45Yt24dzp07hw4dOqBJkybIzc3FggULEBYWVuycvMLc3Nywa9cuXLp0CQMGDDDoFCL16tWDQqHAgQMHtNuUSiViYmJ0vt8jIiKwe/du7N27F5GRkXBxcUFISAi++uoreHt7F+lV02jRogWSkpIgk8mKvAdubm4AxM+nuO9FDUdHR3h6eupMWFepVDhx4oT2dmhoKCwtLXH9+vUir1O497gyMDgRkdnSLDnSunVrrF69GhcvXkR8fDzmzp2rnRfRrVs3hIaGYsiQIThx4gSOHj2KoUOHIiIiQmfYqiz+/v44cuQIrl69ivv375erNwoAunTpgo0bN2Ljxo1ISEjA2LFjdRaDrF+/PgYPHoyhQ4fi33//RWJiIo4ePYoZM2Zg48aNpT73qlWr8Oeff+LChQuYNm0ajh49irfeeqvUx3z22WeYMWMG5s6diwsXLiA2NhaLFy/GDz/8AADw8PCAtbU1tmzZgrt37yI1NbXE5/Lz84NCocBPP/2EK1euYP369fjiiy/0f3P09Oabb+LGjRt49913kZCQgHXr1mHatGmYNGlSpZ4EV9/PJjIyEn///TeaNWsGOzs7SKVSdOrUCcuWLdN7bo6Hhwd27dqFhIQEvPrqqzpHDJbG1tYWY8eOxdSpU7FlyxbExcVh9OjRyMrK0s450tS4detWyGQy7TzByMjIMmvs1q0bwsPD0a9fP2zbtg1Xr17FwYMH8dFHH+HYsWMAgAkTJmDRokVYvHix9nvx3LlzOs8zfvx4zJgxA+vWrcP58+cxYcIEPHr0SDv8am9vjylTpuCdd97B0qVLcfnyZZw4cQI//fQTli5dqtd7UV4MTkRktgICAnDixAl07twZkydPRqNGjdC9e3fs3LkT8+fPByD2ACxbtgxOTk7o1KkTunXrhoCAAKxYscKg15oyZQosLCwQGhqqHYIqj5EjR2LYsGHa8BYQEIDOnTvr7LN48WIMHToUkydPRnBwMPr164eYmBjt3J2STJ8+Hf/++y+aNWuG33//HX///XeZvWqvv/46Fi5ciMWLF6Nx48aIiIjAkiVLtD1OMpkMc+fOxYIFC+Dj44Pnn3++xOdyd3fHkiVLsHLlSoSGhmLmzJk6h71XlFq1amHDhg04ceIEmjdvjjfeeAOjRo3Cxx9/XOGv9SR9PpuIiAioVCqdI8QiIyOLbCuLl5cXdu3ahbNnz2LMmDF693jOnDkT/fv3x5AhQ9CiRQtcunQJW7duhbOzs3afjh07Qq1W64QkfWqUSCTYtGkTOnXqhBEjRqB+/foYNGgQrl27Bk9PTwDAwIED8cknn+Ddd99Fy5Ytce3aNYwdO1bned577z288sorGDp0KMLDw2FnZ4eePXvCyspKu88XX3yBTz75BDNmzEBISAh69eqFjRs3ar83K4tEqIiBYhOWlpYGR0dHpKamwsHB4amfT6lUYtOmTejdu3eFLRxXndWk9tbktubk5CAxMRF169bV+cVlDtRqNdLS0uDg4FCpvRHGJpFIsHr1anTp0sXs2wrUnM8VqBltVavVCAkJwcsvv4wpU6aUq62l/R4zJAtU79mdREREVONcu3YN27ZtQ0REBHJzczFv3jwkJibilVdeMXZpHKojIiKi6kUqlWLJkiVo1aoV2rdvj9jYWOzYsaPUgxmqCnuciIhqAEEQtEM6RNWdr6+vzpF/GuU96KIisceJiIiISE8MTkRERER6YnAiIiIi0lONDU5RUVEIDQ3VnoeKiIiIqCw1NjiNGzcOcXFxOku6ExEREZWmxgYnIiIiIkMxOBERkV4iIyMxceJEY5ehQyKRYO3atU/1HMOHD0e/fv0qpB4yfwxORGS27t27h7Fjx8LPzw+Wlpbw8vJCz549ddaHCQgIgLOzMywsLCCRSCCRSFC7dm1Mnz5de7ukLyKqebgAJhGZrf79+yMvLw9Lly5FQEAA7t69i507d+LBgwc6+3344YcYN26c9txXFhYWsLa2xhtvvKHdp1WrVhgzZgxGjx5dpW0gouqFPU5EZDhBAPIyjfOl53nJU1JSsG/fPnzzzTfo3Lkz6tSpg9atW+ODDz7Ac889p7OvnZ0dvLy8tF/u7u5FtllYWMDe3l5nW0lWr16Nhg0bwtLSEv7+/vj+++917vf398fXX3+NkSNHwt7eHn5+fvjll19KbU9kZCTefvttvPvuu3BxcYGXlxemT59epM2vv/463N3d4eDggC5duuD06dMAgNTUVMjlcpw8eRKAuAKzi4sL2rZtq338n3/+CV9f3zLfW42NGzfC0dERy5YtA1Aw5DVr1ix4e3vD1dUV48aNg1Kp1D7m0aNHGDp0KJydnWFjY4NnnnkGFy9eBCCubu7u7o5Vq1Zp92/WrBm8vb21t/fv3w9LS0tkZWUVW9ONGzcwYMAAuLi4oG7duujXrx+uXr2qvV+lUmHSpElwcnKCq6sr3n33XTx5rvv09HQMHjwYtra28Pb2xo8//lhkmDI3NxdTpkxBrVq1YGtrizZt2mDPnj16v3dkutjjRESGU2YBX/sY57U/vA0obMvczc7ODnZ2dli7di3atm0LS0vLKigOOH78OAYMGIDp06dj4MCBOHjwIN588024urpi+PDh2v2+//57fPHFF/jwww+xatUqjB07FhEREQgODi7xuZcuXYpJkybhyJEjOHToEIYPH4727duje/fuAICXX34Z1tbW2Lx5MxwdHbFgwQJ07doVFy5cgIuLC5o1a4b9+/cjIiICsbGxkEgkOHnyJDIyMmBnZ4fo6GhERETo1c6//voLb7zxBv766y/07dtXu3337t3w9vbG7t27cenSJQwcOBDNmjXT9tQNHz4cFy9exPr16+Hg4ID33nsPvXv3RlxcHORyOTp16oQ9e/bgpZdewqNHjxAfHw9ra2skJCSgQYMGiI6ORqtWrWBjY1OkJqVSiZ49eyI8PBzR0dHIycnBnDlz0KtXL5w5cwYKhQLff/89lixZgkWLFiEkJATff/891qxZgy5dumifZ9KkSThw4ADWr18PT09PfPrppzhx4gSaNWum3eett95CXFwcli9fDh8fH6xZswa9evVCbGwsgoKC9HoPyTSxx6my5KYDS/oCv3YBVPnGroaoxpHJZFiyZAmWLl0KJycntG/fHh9++CHOnDlTZN/p06fDwcFBG7bmzp1b7tf94Ycf0LVrV3zyySeoX78+hg8fjrfeegvfffedzn69e/fGm2++icDAQLz33ntwc3PD7t27S33uJk2aYNq0aQgKCsLQoUMRFhaGnTt3AhB7Yo4ePYqVK1ciLCwMQUFBmDVrFpycnLQ9OBEREdi/fz8AYM+ePejevTtCQkJ0tukTnKKiovDmm2/iv//+0wlNAODs7Ix58+ahQYMG6Nu3L/r06aOtUROYFi5ciI4dO6Jp06ZYtmwZbt26pZ3gHRkZqe252bt3L5o3b66zrbQaV6xYAbVajYULF6Jx48YIDg7GokWLcP36de3jZ8+ejQ8++AAvvvgiQkJC8PPPP8PR0VH7HOnp6Vi6dClmzZqFrl27olGjRli8eDFUKpV2n+vXr2Px4sVYuXIlOnbsiHr16mHKlCno0KEDFi9eXOb7R6aNPU6VRSoDru4TryuzAAsH49ZDVJHkNmLPj7FeW0/9+/dHnz59sG/fPhw+fBibN2/Gt99+i4ULF+r0/owfPx5jxozRznFyc3Mrd3nx8fF4/vnndba1b98es2fPhkqlgoWFBQAxBGlIJBJ4eXkhOTm51Ocu/BgA8Pb21j7m9OnTyMjIgKurq84+2dnZuHz5MgCgU6dO+O2336BSqRAdHY0ePXrAy8sLe/bsQZMmTXDp0iVERkaWWsOqVauQnJyMAwcOFLuAcMOGDbVt1NQYGxsLQHxvZDIZ2rRpo73f1dUVwcHBiI+PByCGuwkTJuDevXuIjo5GZGSktsZRo0bh4MGDePfdd4ut7fTp07h06RLs7e11tufk5ODy5ctITU3FnTt3dF5fJpMhLCxMO1x35coVKJVKtG7dWruPo6OjTk9gbGwsVCoV6tevr/M6ubm5Rd5/Mj8MTpVFZgVAAkAAlNmAFYMTmRGJRK/hsurAysoK3bt3R/fu3fHJJ5/g9ddfx7Rp03SCk6urKwIDA7XBqSrI5XKd2xKJpMwzv5f2mIyMDHh7exc7z8bJyQmAGJwyMjJw4sQJ7N27F19//TW8vLwwc+ZMNG3aFD4+PmUOMzVv3hwnTpzAokWLEBYWVuTowvK0q7DGjRvDxcUF0dHRiI6OxldffQUvLy988803iImJgVKpRLt27Yp9bEZGBlq2bIlly5ZBrVZrhyClUinc3d31rqEsGRkZsLCwwPHjx3VCIiAOEZN541BdZSn8h0WZadxaiEgrNDQUmZmV9zMZEhKis9wBABw4cAD169cv8ke2IrVo0QJJSUmQyWQIDAzU+dL0oDk5OaFhw4aIioqCXC5HgwYN0KlTJ5w8eRIbNmzQa5iuXr162L17N9atW4fx48cbVGNISAjy8/Nx5MgR7bYHDx7g/PnzCA0NBSAGrY4dO2LdunU4d+4cOnTogCZNmiA3NxcLFixAWFgYbG2LD+0tWrTAxYsX4eHhgcDAQAQEBGjfA0dHRzg6OsLb21vn9fPz83H8+HHt7YCAAMjlcp2zSqSmpuLChQva282bN4dKpUJycnKR97q0gwbIPDA4VSa5tXiZV/zRH0RUeR48eIAuXbrgzz//xJkzZ5CYmIiVK1fi22+/LTKUVpEmT56MnTt34osvvsCFCxewdOlSzJs3D1OmTKm01wSAbt26ITw8HP369cO2bdtw9epVHDx4EB999BGOHTum3a9Dhw7466+/tCHJxcUFISEhWLFihd4Tw+vXr4/du3dj9erVBi2IGRQUhOeffx6jR4/G/v37cfr0abz22muoVauWzmcSGRmJv//+G82aNdP2GHXq1AnLli0rtcbBgwfDzc0Nzz//PPbt24dr165hz549ePvtt3Hz5k0AwIQJEzBz5kysXbsWCQkJePPNN5GSkqJ9Dnt7ewwbNgxTp07F7t27ce7cOYwaNQpSqVTbu1a/fn0MHjwYQ4cOxb///ovExEQcPXoUM2bMwMaNG/V+P8g0MThVJs1cDGW2cesgqoHs7OzQpk0b/Pjjj+jUqRMaNWqETz75BKNHj8a8efMq7XVbtGiBf/75B8uXL0ejRo3w6aef4vPPP9cZGqwMEokEmzZtQqdOnTBixAjUr18fgwYNwrVr1+Dp6andr3379lCpVDpzmSIjI4tsK0twcDB27dqFv//+G5MnT9b7cYsXL0bLli3Rt29fhIeHQxAEbNq0SWeILyIiolw12tjYYO/evfDz88NLL72ENm3aYPTo0cjJyYGDgzhdYvLkyRgyZAiGDRuG8PBw2Nvb44UXXtB5nh9++AHh4eHo27cvunXrhvbt2yMkJARWVlY67Rg6dCgmT56M4OBg9OvXDzExMfDz89P7vSDTJBGeXMCihklLS4OjoyNSU1O1P1hPQ6lUYtOmTejduzfkv3YCkuOAoeuAgMinL7Ya0mnvE3MbzE1NbmtOTg4SExNRt25dnT8e5kCtViMtLQ0ODg5VOsfJGNjW8snMzEStWrXw/fffY9SoURVUYcXh56qf0n6PGZIFODm8Mlk5iZdZD41aBhER6e/kyZNISEhA69atkZqais8//xwAKnWIl0wHg1Nlsn88STA9ybh1EBGRQWbNmoXz589DoVCgZcuW2Ldv31MtU0Hmg8GpMtl5iJeZpa/NQkRE1Ufz5s11jrQjKsy8B0ONzfLxImx5XI6AiIjIHNTY4BQVFYXQ0NBiV76tMJqj6hicyEzU8GNJiMiEVdTvrxobnMaNG4e4uDidRc4qnOLxCrIMTmTiNAs35uXlGbkSIqLyycoS11R82qOiOcepMmlWDmdwIhMnk8lgY2ODe/fuQS6Xm9Uhz2q1Gnl5ecjJyTGrdhWHbTVPbGvpBEFAVlYWkpOT4eTk9NQr+DM4VSYGJzITEokE3t7eSExMxLVr14xdToUSBAHZ2dmwtrYuct41c8O2mie2VT9OTk4VckocBqfKpA1OGcatg6gCKBQKBAUFmd1wnVKpxN69e9GpU6casbAp22p+2NayyeXyCjtXJINTZWKPE5kZqVRqdiuHW1hYID8/H1ZWVmb/R4dtNU9sa9Uy78FQY9MEJyVP8ktERGQOGJwqk5w9TkREROaEwakyFZ7jxPVviIiITB6DU2WydhIvBTWQm2bUUoiIiOjpMThVJrl1wXBd5n3j1kJERERPjcGpstm6ipcMTkRERCaPwamy2biJl1kMTkRERKaOwamy2bqLl+xxIiIiMnkMTpXNVtPj9MC4dRAREdFTY3CqbHJr8VKZbdw6iIiI6KkxOFU2C0vxUpVr3DqIiIjoqTE4VTaZQrxUKY1bBxERET01BqfKpulxymePExERkaljcKps2h4nBiciIiJTx+BU2bQ9TnnGrYOIiIieWo0NTlFRUQgNDUWrVq0q94VkmsnhDE5ERESmrsYGp3HjxiEuLg4xMTGV+0IWmqE6BiciIiJTV2ODU5XR9Djl5xi3DiIiInpqDE6VzcpJvMx+ZNQyiIiI6OkxOFU2G1fxkqdcISIiMnkMTpXNxkW8zGRwIiIiMnUMTpXNylG8VGYCapVxayEiIqKnwuBU2RR2Bddz041XBxERET01BqfKJrMEpHLxel6GcWshIiKip8LgVNkkEsDyca8Te5yIiIhMGoNTVbC0Fy9z2eNERERkyhicqoJCE5zSjFsHERERPRUGp6qg6XHiHCciIiKTxuBUFTjHiYiIyCwwOFUFznEiIiIyCwxOVUHBHiciIiJzwOBUFSwdxMs8BiciIiJTxuBUFbRznDhUR0REZMoYnKqCdo4Te5yIiIhMGYNTVdDMceJyBERERCaNwakqsMeJiIjILDA4VQUGJyIiIrPA4FQVGJyIiIjMAoNTVeAcJyIiIrPA4FQVeMoVIiIis8DgVBU0C2AqswC1yri1EBERUbnV2OAUFRWF0NBQtGrVqvJfTDNUB7DXiYiIyITV2OA0btw4xMXFISYmpvJfTGYJSOXidc5zIiIiMlk1NjhVKYmE85yIiIjMAINTVdEuScAeJyIiIlPF4FRVFJrglGbcOoiIiKjcGJyqiqbHiXOciIiITBaDU1XhHCciIiKTx+BUVawcxcucVOPWQUREROXG4FRVrF3Ey6yHxq2DiIiIyo3BqarYPA5O2QxOREREporBqaqwx4mIiMjkMThVFRtX8ZI9TkRERCaLwamq2DiLl+xxIiIiMlkMTlWFQ3VEREQmj8GpqnByOBERkcljcKoqmjlO+TlAXpZxayEiIqJyYXCqKgo7QCoXr7PXiYiIyCQxOFUViaTgfHU87QoREZFJYnCqSprz1eVlGrcOIiIiKhcGp6qk4Il+iYiITBmDU1XSBKe8DOPWQUREROXC4FSVLNnjREREZMoYnKqSnZd4mX7HuHUQERFRuTA4VSXHWuJl2m3j1kFERETlwuBUlSwdxMtcznEiIiIyRQxOVUluLV7m5xi3DiIiIioXBqeqJLMULxmciIiITBKDU1WSPe5xUmYbtw4iIiIqFwanqqTpcUqMNm4dREREVC4MTlVJIim4np5kvDqIiIioXBicqlJ2SsH1rAdGK4OIiIjKp8YGp6ioKISGhqJVq1ZV96IhzxZcz3pYda9LREREFaLGBqdx48YhLi4OMTExVfei1k6Ab1vxOnuciIiITE6NDU5GY2kvXvJEv0RERCaHwamqaU70m5dp3DqIiIjIYAxOVU3xODjlphu3DiIiIjIYg1NVU7DHiYiIyFQxOFU17VAd5zgRERGZGganqqawFS9zGZyIiIhMDYNTVVOwx4mIiMhUMThVNS5HQEREZLIYnKqaZqiOk8OJiIhMDoNTVdP0OOWkGrcOIiIiMhiDU1WzcRUvecoVIiIik8PgVNVs3MTLrIeAWm3cWoiIiMggDE5VzcZFvBRUQE6KUUshIiIiwzA4VTWZJWDpIF7ncB0REZFJYXAyBk2vU+Z949ZBREREBmFwMgZ7b/Ey9aZx6yAiIiKDMDgZg3sD8fJegnHrICIiIoMwOBmDtbN4ydXDiYiITAqDkzHIrcVLZbZx6yAiIiKDMDgZgyY45ecYtw4iIiIyCIOTMcisxEv2OBEREZkUBidj4FAdERGRSWJwMgZNjxOH6oiIiEwKg5MxWDmJl1wAk4iIyKQwOBmDW5B4+eASoFYZtxYiIiLSG4OTMWhWDlcrgZxU49ZCREREemNwMgaZAlDYi9ezHhq3FiIiItIbg5Ox2DxePTybwYmIiMhUMDgZi7WLeMkeJyIiIpPB4GQsNo+DE3uciIiITIbBwWnLli3Yv3+/9nZUVBSaNWuGV199FY8eParQ4swae5yIiIhMjsHBaerUqUhLSwMAxMbGYvLkyejduzcSExMxadKkCi/QbLHHiYiIyOTIDH1AYmIiQkNDAQCrV69G37598fXXX+PEiRPo3bt3hRdottjjREREZHIM7nFSKBTIysoCAOzYsQM9evQAALi4uGh7okgP7HEiIiIyOQb3OHXo0AGTJk1C+/btcfToUaxYsQIAcOHCBdSuXbvCCzRbNq7iJU+7QkREZDIM7nGaN28eZDIZVq1ahfnz56NWrVoAgM2bN6NXr14VXqDZcnwcMlNvGLcOIiIi0pvBPU5+fn7YsGFDke0//vhjhRRUY2iCU9ptQBAAicS49RAREVGZDA5OJ06cgFwuR+PGjQEA69atw+LFixEaGorp06dDoVBUeJEVKTc3F7m5udrbmnlZSqUSSqXyqZ9f8xxlPpfcAXIAUOdDmfEQsHJ46tc2Br3bawbYVvPEtponttU8VVZbDXk+iSAIgiFP3qpVK7z//vvo378/rly5goYNG+KFF15ATEwM+vTpg9mzZxtab5WaPn06PvvssyLb//rrL9jY2FRpLX1Ovw6ZOg/bQ2chy9KjSl+biIiIRFlZWXj11VeRmpoKB4fSOzIMDk6Ojo44ceIE6tWrh2+++Qa7du3C1q1bceDAAQwaNAg3blTvOTvF9Tj5+vri/v37Zb5Z+lAqldi+fTu6d+8OuVxe6r6yn5pCknYL+SO2QfBp8dSvbQyGtNfUsa3miW01T2yreaqstqalpcHNzU2v4GTwUJ0gCFCr1QDE5Qj69u0LANrwUd1ZWlrC0tKyyHa5XF6hH4Jez2dpDwCQqXMBE/9mr+j3rzpjW80T22qe2FbzVBl/s/Vl8FF1YWFh+PLLL/HHH38gOjoaffr0ASAujOnp6Wno09Vs8sdDg3lZxq2DiIiI9GJwcJo9ezZOnDiBt956Cx999BECAwMBAKtWrUK7du0qvECzprAVL5WZxq2DiIiI9GLwUF2TJk0QGxtbZPt3330HCwuLCimqxmCPExERkUkxODhpHD9+HPHx8QCA0NBQtGhhmpObjUrxODgpGZyIiIhMgcHBKTk5GQMHDkR0dDScnJwAACkpKejcuTOWL18Od3f3iq7RfFk7i5c87QoREZFJMHiO0/jx45GRkYFz587h4cOHePjwIc6ePYu0tDS8/fbblVGj+eJpV4iIiEyKwT1OW7ZswY4dOxASEqLdFhoaiqioKPTo0aNCizN7jn7iZcp149ZBREREejG4x0mtVhe73oFcLteu70R6cvIVL1PY40RERGQKDA5OXbp0wYQJE3D79m3ttlu3buGdd95B165dK7Q4s2f7eD5Y9kPj1kFERER6MTg4zZs3D2lpafD390e9evVQr1491K1bF2lpaZg7d25l1Gi+5NbipTLbuHUQERGRXgye4+Tr64sTJ05gx44dSEhIAACEhISgW7duFV6c2ZNZiZeCClDlAxblXh2CiIiIqkC5/lJLJBJ0794d3bt3125LSEjAc889hwsXLlRYcWZPE5wAID8HsLAzXi1ERERUJoOH6kqSm5uLy5cvV9TT1QxPBiciIiKq1iosOFE5SKWAhUK8zuBERERU7TE4GZtMM0GcwYmIiKi6Y3AyNoWteJmbZtw6iIiIqEx6Tw53dnaGRCIp8f78/PwKKajGsXMH0m8DmfeMXQkRERGVQe/gNHv27Eosowaz9RAvz60F6vc0ailERERUOr2D07BhwyqzjprLsZZ4mZls3DqIiIioTJzjZGwhz4mXaXeMWwcRERGVicHJ2Ow8xUv2OBEREVV7DE7GZmkvXuZmGLcOIiIiKhODk7FpglN+tni+OiIiIqq2GJyMTROcACAv3Xh1EBERUZkMPsmvSqXCkiVLsHPnTiQnJ0OtVuvcv2vXrgorrkawkIvnrMvPAXLTAWtnY1dEREREJTA4OE2YMAFLlixBnz590KhRo1IXxSQ9WdoXBCciIiKqtgwOTsuXL8c///yD3r17V0Y9NZPCTlw5nBPEiYiIqjWD5zgpFAoEBgZWRi01l/bIOvY4ERERVWcGB6fJkydjzpw5EAShMuqpmTTBiZPDiYiIqjWDh+r279+P3bt3Y/PmzWjYsCHkcrnO/f/++2+FFVdjsMeJiIjIJBgcnJycnPDCCy9URi01FxfBJCIiMgkGB6fFixdXRh01m8JOvGSPExERUbVmcHDSuHfvHs6fPw8ACA4Ohru7e4UVVeNoepwy7hq3DiIiIiqVwZPDMzMzMXLkSHh7e6NTp07o1KkTfHx8MGrUKGRlZVVGjeZPbi1eHvvNuHUQERFRqQwOTpMmTUJ0dDT+++8/pKSkICUlBevWrUN0dDQmT55cGTWaP5cA8dLRz7h1EBERUakMHqpbvXo1Vq1ahcjISO223r17w9raGgMGDMD8+fMrsr6awbOReJmfY9w6iIiIqFQG9zhlZWXB09OzyHYPDw8O1ZWXzEq8VOUatw4iIiIqlcHBKTw8HNOmTUNOTkHvSHZ2Nj777DOEh4dXaHE1hkwhXuYzOBEREVVnBg/VzZkzBz179kTt2rXRtGlTAMDp06dhZWWFrVu3VniBNYKmxyk/FxAEgCdOJiIiqpYMDk6NGjXCxYsXsWzZMiQkJAAAXnnlFQwePBjW1tYVXmCNYPG4xwkCoFIW9EARERFRtVKudZxsbGwwevToiq6l5tL0OAHiBHEGJyIiompJr+C0fv16PPPMM5DL5Vi/fn2p+z733HMVUliNYlEoKHGeExERUbWlV3Dq168fkpKS4OHhgX79+pW4n0QigUqlqqjaag6pFLByBHJSgawHgB1XYSciIqqO9ApOarW62OtUgRxqi8Ep7Sbg0cDY1RAREVExDF6O4Pfff0dubtHhpLy8PPz+++8VUlSNZP94bazM+8atg4iIiEpkcHAaMWIEUlNTi2xPT0/HiBEjKqSoGsnSQbzMSTNuHURERFQig4OTIAiQFLPO0M2bN+Ho6FghRdVIVo/fu5yioZSIiIiqB72XI2jevDkkEgkkEgm6du0KmazgoSqVComJiejVq1elFFkjWGl6nFKMWgYRERGVTO/gpDma7tSpU+jZsyfs7Oy09ykUCvj7+6N///4VXmCNoelxyuVQHRERUXWld3CaNm0aAMDf3x8DBw6ElZVVGY8gg1hyqI6IiKi6M3jl8GHDhlVGHaSd48QeJyIiourK4OCkUqnw448/4p9//sH169eRl5enc//Dhw8rrLgahZPDiYiIqj2Dj6r77LPP8MMPP2DgwIFITU3FpEmT8OKLL0IqlWL69OmVUGINoZ0czuBERERUXRkcnJYtW4Zff/0VkydPhkwmwyuvvIKFCxfi008/xeHDhyujxpqBk8OJiIiqPYODU1JSEho3bgwAsLOz0y6G2bdvX2zcuLFiq6tEUVFRCA0NRatWrYxdisiyUI+TIBi3FiIiIiqWwcGpdu3auHPnDgCgXr162LZtGwAgJiYGlpaWFVtdJRo3bhzi4uIQExNj7FJEmh4nVR6Qn2PcWoiIiKhYBgenF154ATt37gQAjB8/Hp988gmCgoIwdOhQjBw5ssILrDEUdoDk8cfBI+uIiIiqJYOPqps5c6b2+sCBA+Hn54dDhw4hKCgIzz77bIUWV6NIpYClvThUl5NacNJfIiIiqjYMDk5PCg8PR3h4eEXUQlaOYmjiBHEiIqJqSa/gtH79er2f8Lnnnit3MTWedvXwFKOWQURERMXTKzhpzlOnIZFIIDxx5JdEIgEgLpBJ5cRFMImIiKo1vSaHq9Vq7de2bdvQrFkzbN68GSkpKUhJScHmzZvRokULbNmypbLrNW/aRTA5VEdERFQdGTzHaeLEifj555/RoUMH7baePXvCxsYGY8aMQXx8fIUWWKOwx4mIiKhaM3g5gsuXL8PJyanIdkdHR1y9erUCSqrBGJyIiIiqNYODU6tWrTBp0iTcvXtXu+3u3buYOnUqWrduXaHF1Tg2ruJl1n3j1kFERETFMjg4LVq0CHfu3IGfnx8CAwMRGBgIPz8/3Lp1C7/99ltl1Fhz2HmIlxnJxq2DiIiIimXwHKfAwECcOXMG27dvR0JCAgAgJCQE3bp10x5ZR+XkWFu8vH1KPF8d308iIqJqpVwLYEokEvTo0QM9evSo6HpqNr/HC4lmJImLYGrmPBEREVG1oFdwmjt3LsaMGQMrKyvMnTu31H3ffvvtCimsRlLYAnJbQJkJZD1gcCIiIqpm9ApOP/74IwYPHgwrKyv8+OOPJe4nkUgYnJ6WjQuQmglkPQRcAoxdDRERERWiV3BKTEws9jpVAodaQOoN4MFloHaYsashIiKiQgw+qo4qmWeoePngonHrICIioiL06nGaNGmS3k/4ww8/lLsYAmBpL14qs41bBxERERWhV3A6efKkXk/G5QgqgNxGvFRmGbcOIiIiKkKv4LR79+7KroM0tMGJPU5ERETVDec4VTdya/EyL9O4dRAREVER5VoA89ixY/jnn39w/fp15OXl6dz377//VkhhNRZ7nIiIiKotg3ucli9fjnbt2iE+Ph5r1qyBUqnEuXPnsGvXLjg6csHGp2ZpJ17mphu3DiIiIirC4OD09ddf48cff8R///0HhUKBOXPmICEhAQMGDICfn19l1Fiz2LiKl1n3jVsHERERFWFwcLp8+TL69OkDAFAoFMjMzIREIsE777yDX375pcILrHFs3MTLTAYnIiKi6sbg4OTs7Iz0dHEYqVatWjh79iwAICUlBVlZPIT+qdk+Dk45KYAq36ilEBERkS6Dg1OnTp2wfft2AMDLL7+MCRMmYPTo0XjllVfQtWvXCi+wxrF2BvB4Pazsh0YthYiIiHTpfVTd2bNn0ahRI8ybNw85OTkAgI8++ghyuRwHDx5E//798fHHH1daoTWG1EIMT9kPxeE6Ow9jV0RERESP6R2cmjRpglatWuH111/HoEGDAABSqRTvv/9+pRVXY9m6icGJE8SJiIiqFb2H6qKjo9GwYUNMnjwZ3t7eGDZsGPbt21eZtdVcnCBORERULekdnDp27IhFixbhzp07+Omnn3D16lVERESgfv36+Oabb5CUlFSZddYstpolCR4Ytw4iIiLSYfDkcFtbW4wYMQLR0dG4cOECXn75ZURFRcHPzw/PPfdcZdRY81g7i5fZKUYtg4iIiHQ91bnqAgMD8eGHH+Ljjz+Gvb09Nm7cWFF11WyWDuJlbqpx6yAiIiId5TpXHQDs3bsXixYtwurVqyGVSjFgwACMGjWqImuruawen7omJ824dRAREZEOg4LT7du3sWTJEixZsgSXLl1Cu3btMHfuXAwYMAC2traVVWPNo+1xYnAiIiKqTvQOTs888wx27NgBNzc3DB06FCNHjkRwcHBl1lZzaU/0m2HcOoiIiEiH3sFJLpdj1apV6Nu3LywsLCqzJpJZiZf5Ocatg4iIiHToHZzWr19fmXVQYdrglGvcOoiIiEjHUx1VR5WEPU5ERETVEoNTdSSzFC/Z40RERFStMDhVR3Jr8TI/27h1EBERkQ4Gp+qIPU5ERETVEoNTdSS3ES8z7nIRTCIiomqEwak6cgkoWATzwUXj1kJERERaDE7VkUQCONQSr3MRTCIiomqDwam60qwensfgREREVF0wOFVXisfn/mOPExERUbXB4FRdWdqLlzzRLxERUbXB4FRdWTuLl3tnGbcOIiIi0mJwqq7S7oiXGUnGrYOIiIi0GJyqqw4TC64LgtHKICIiogIMTlUgISkNU1eeRnK6ASftrdWy4HpuesUXRURERAaTGbuAmuC1hUdwPyMP9zJysWREa/0eJLcGLCwBVS6QkwJYOVRqjURERFQ29jhVshylCvcz8gAAe87fM+zB1k7iZfajii2KiIiIyoXBqZLdz8hFPXdxTSYLqQQqtQHzlaycxMvslAqvi4iIiAzH4FTJajvbYNs7EZBIAJVawN00A+Y5aZYkYI8TERFRtcDgVAUspBL4OtsAAG6lZOv/QDt38fJRYiVURURERIZicKoitZysAQA3H2UZ8KDHR9Ylna2EioiIiMhQDE5VpJazGJxuPTKkx8lLvMx6UAkVERERkaEYnKpIbWdNj5MBwcnWTbzMul8JFREREZGhGJyqSO3Hc5yWx9zA7vPJ+j3IxkW8zHpYSVURERGRIRicqkibui7a6yMWxyA9R1n2g2we9zil3eJpV4iIiKoBBqcq4utig4DH6zkBwInrKWU/SDNUBwBX91d8UURERGQQBqcq9MeoNtrruxP0GK6T2xRcv3G4EioiIiIiQzA4VaFaTtZYODQMALDk4FVM/uc0rj3ILPkBEgnQ7DXxOlcPJyIiMjoGpyoWXs8VFlIJAGD1iZsY99eJ0h/gFiheckkCIiIio2NwqmK2ljI083XS3j57Kw074u6iz9x9eOWXwzhzM0X3AVaO4mVOWpXVSERERMVjcDKC6c82RH1PO+3t138/hnO303DoygMMXHAY99JzC3a2dBAvc1KruEoiIiJ6EoOTETSu7Yht70QUe1+2UoWDl8UFL2+lZCNFeHwk3vVDnOdERERkZAxORvS/wS1go7Aosn3C8lMI/HAT2s/chb7r1RAs7QFBBVzZbYQqiYiISENm7AJqst6NvdG7sTf+ibmBuDtp8HK0wszNCQCAfLW44OXNDOCCTxiCc3cDGXquOE5ERESVgsGpGhjQyhcAcPpGSrH3H0mWIVgG/LzxENTZXfFa2zpwsJJXYYVEREQEcKiuWgn0KJgw7udig1fb+MHRWo7rgoe4TbiFb7ecx/i/ThqrRCIiohqNPU7ViK2lDKveCMeZm6l4tY0frOQWaF/PDX8sPw0A6G1xFC7KNERfMHKhRERENRR7nKqZMH8XjOxQF1ZycdJ478ZemDhquPb+PxUzAAB/HbmOfJXaGCUSERHVWAxO1ZxEIkHbeu7a26HSawCAD9fEIvCjzcjIzTdWaURERDUOg5OpCBsFALgpuOlsPnSZp2IhIiKqKgxOpqLTFACAl+Qh5CjoZUrNVhqrIiIiohqHwclU2HsDCnvIoMbOJru0m68/zDJiUURERDULg5OpkEgAlXgOO78LS9AtWByyu8ngREREVGUYnEyJnZf26ttOewEANx4xOBEREVUVBidTYu2kvdrw3I8AgJirj5CUmmOkgoiIiGoWBidT0mqU9qpFfqb2et+f9iElK88YFREREdUoDE6mpPlQnZujO9YFANzPyMNHa84aoyIiIqIahcHJlEilgHdT8bqtOz7qEworufgRboy9g30X7xmxOCIiIvPH4GRq+v8mXmbeA+LW4d+x7bV3/d8fx41UFBERUc3A4GRq3IKApq+I13d/jdou1tq7svJURiqKiIioZmBwMkWB3cTLewlwuBujc5cgCEYoiIiIqGZgcDJFNq4F128ew7Z3Omlvnr2VZoSCiIiIagYGJ1MUEFlw/dZx1Pe0R49QTwDAgcv3jVMTERFRDcDgZIokEuCFX8TrcWsBZQ6a+jqJN2+zx4mIiKiymEVw+vTTT6FQKKBQKDBs2DBjl1M1gp8puJ56A6E+DgCAc7dTjVQQERGR+TP54JSTk4OZM2fi4MGDuH79Ov7++29cvHjR2GVVPisHwK2+eH1eGBq5iJPCr9zPRFZevhELIyIiMl8mH5yWLl0KNzc3hIWFwcvLCw0bNsTcuXONXVbVUBWcZsX9xla421tCEIDzSelGLIqIiMh8GT04/fTTT/D09ISFhQUkEgk++OCDIvsMGDAAMpkMEokEdnZ2WLx4sfa+CxcuwM3NTXvbx8cHiYmJVVK70bWfUHA99RbquNgAAG6n8KS/RERElUFm7AIePXqEoKAgDB8+HN9++22R+ydMmICVK1dixIgR6NevH9577z2MGjUKrVu3RsOGDQ1+vbS0NKSlFUygTk8Xe2eysrIgkz3925GfLw6TZWdnQ6lUPvXzlSpkAOQ3T0F+aikQPRMN/BriGCyw+vh1dKhrD7lF5efiKm2vkbGt5oltNU9sq3mqrLZmZWXpva9EqEYrJkokErz//vuYMWOGdpudnR0CAgJw5swZAOKbZmlpie7du2PLli1YsGABPvvsM9y+fRsA0Lx5c7Rr1w5RUVHFvkZkZCSio6OLbP/rr79gY2NTCa2qXJ6pp9D2yg8AgBPylngxfTIAYECACu09q81HS0REVG1lZWXh1VdfRWpqKhwcHErd1+g9TqXJyMhAZmYm+vTpo90mk8ng7++P06dPAwCGDRuG8ePH49ixY6hduzbOnTuHf/75p8TnXL9+fZEep9DQUHTu3LnMN0sf+fn52L17Nzp37lwhPVhlkaTUB34Rg1MLZcG56vY/sEXTRv6ICHKFi62i0l6/qttrTGyreWJbzRPbap4qq62Fc0FZqvU7fOHCBQBA3bp1dba7urri7t27AAArKytMnToV7dq1gyAIGDhwIIKCgkp8TgcHB52ApHmzbGxsKqTHSdN1aG1tDblc/tTPVyabEJ2bdshCBmxwOzUHH61PQPtAVyx7vW2lvXyVt9eI2FbzxLaaJ7bVPFVWWzVDgPow+uTwivDVV18hLy8PSqUSf/75p7HLqXovLtRe/bm3k85dBy49qOJiiIiIzFe1Dk7164vrFD15lNyDBw9gb29vjJKqp0b9tVcD7u0yYiFERETmrVoHJzs7O9ja2mLjxo3abfn5+bh69SqaNm1qxMqqGakUsHIEAPjE/k/nLluFhTEqIiIiMktGD05JSUlYsWIFVqxYAQCIj4/HihUrcOjQIQDAqFGjEBsbi9GjR2PDhg1o3LgxBEHArFmzjFl29ZNTcKoVC6i0193tLY1RDRERkVky+uTw5cuX45133tHeXrduHdatW4d69erh0qVLmDNnDm7fvo3Fixdj4cKFsLW1xa+//opGjRoZsepqaNDfwPJXAABfy37De/ljAADpOTz9ChERUUUxeo/TxIkTIQhCka9Lly5p91m5ciXy8/MhCAIyMjIwatQoI1ZcTTXorb06ULYHbhB7oBiciIiIKo7RgxNVoLoR2qsNpVcBAHkqNbLzVCU8gIiIiAzB4GROXligvfqJ7A944BEAICmN564jIiKqCAxO5sTBG+gjriIeKL2No1bjAAC3U7KNWRUREZHZYHAyNx6hRTYNXngEaTnmfeJHIiKiqsDgZG78dE+v4g1x5fDfD141QjFERETmpcYGp6ioKISGhqJVq1bGLqViSSTA6N3am+/KlwMAUrLY40RERPS0amxwGjduHOLi4hATE2PsUiqeV2Pt1YaSq/hK9ht8s84ZsSAiIiLzUGODk1mzkAN9ZwMA6ktvYbBsJ4bFvW7cmoiIiMwAg5O5CogssimVw3VERERPhcHJXDn7F9k0ZdXpqq+DiIjIjDA4mSuJBPDvqLPJ+/zvyMtXG6kgIiIi08fgZM4KTRIHgM/lS/HtlgQjFUNERGT6GJzMWeQHQLPBOpsW7k80UjFERESmj8HJnFk5AM9HFdn8x6GrVV8LERGRGWBwMncSic5NC6jwybpzuHg33UgFERERmS4Gp5rgtX+1V7cp3oWf5C7ikxiciIiIDMXgVBM41dFerSe9g1WKz3CBwYmIiMhgDE41gVsgUP8Z7U0PSQpcb2wzYkFERESmicGppuj9nc7NETc/xsOLh41UDBERkWlicKop7DyLbDr4+6fwf38jjlx5YISCiIiITA+DU00hU4jrOhVSR3IXAPDGn8eNUREREZHJkRm7gKqWm5uL3Nxc7e20tDQAgFKphFL59CfB1TxHRTxXhWv7NuR7ZmhvOksyAAB5+epy11ut21vB2FbzxLaaJ7bVPFVWWw15PokgCEKFvno1N336dHz22WdFtv/111+wsbExQkVVyynzCmQX1qI9Tmm3dcufjfGtXIxXFBERkRFlZWXh1VdfRWpqKhwcHErdt8YFp+J6nHx9fXH//v0y3yx9KJVKbN++Hd27d4dcLn/q56sMI5Yex9TrY9FUegUAcETSBC0+3FWu5zKF9lYUttU8sa3miW01T5XV1rS0NLi5uekVnGrcUJ2lpSUsLS2LbJfL5RX6IVT081UkB2s5PlGOwHrLTwAAbYQzSH90G3bufpA8sdK4vqpzeysa22qe2FbzxLaap8r4m60vTg6vgewsZbgpuOtss45qhud+2g+1ukZ1QBIRERmEwakGer1jAHKg0Nkmk6jx38O+SMnKLeFRRERExOBUA9X3tMf+j3oXe1/KvTtVXA0REZHpYHCqoVzsrYvdfiD+WhVXQkREZDoYnEjHX/vi0OzzbUhISjN2KURERNUOg1ONVvQIOltkIyVLic//izNCPURERNUbg1NN9u4VXBy0D98pB2g3vWyxFxZQITW70CqqggCo1UYokIiIqHphcKrJbFzgVCsYUap+eCdvLNSCBANle7BY/i2u305C9IV7gCofWNAJWNRTDFBEREQ1GINTDediKy5LsEbdEW8oJyJLsEQni1isVkzDx4v/w73/pgFJZ4CbR4G8DCNXq5+svHysPHYDqVnmf94mIiKqWgxONZyFtGCe0ynbDng571MkCc6oL72FtYpP4X5qnvb+facSjFGiwfrPP4Spq85g0YFEY5dCRERmhsGJsGF8B8wf3AJBnnY4J9TF87lfIFbtD1dJus5+HTd3A6Y7AscWATs/Bx5dLf4JNUN66UlVPjdKEATE3xGPCNwed7dKX5uIiMxfjTtXHRXVqJYjGtVyhKO1HAcuPcBduGBA3qeItxpZ/AM2vCNenvoLGHMAMlU2kJ8LyOViUFrUUxzaA4BGLwEv/VY1DQGQUmh4ztvRqspelwBsnwZcPwwM/BOwcy97fyIiE8QeJ9JqF+iGDeM7AACyYYU0wab0B6Tfgfz7AHQ/9w5kS3qJ27IfFYQmADi7quC6vr1PglDuieh303O013PyVeV6DioHtRo4+gtw4zDw3wQeSGAsKs7rI6psDE6ko1EtR/w9ui2WjGiFvwJmIkXmgYOq0FIfo1BlQXI3FvjGH+lxW4vcP+frqbh1cAUwtxkw3RHLl87TDqfh2GJx+O/XLkDmfeDsauAzJ+AzZ+Deed0nyk0HjiwA0ko+LUxyWsG59g5ceoBbVxKASzvFHjENVX5ZbwMZKv0OoMwSr5/fKPZGUtXa9jHwjT/w4LKxKyEyaxyqoyLC67kCACKDhwEYBsXVh3h2wTJcEzyRAwUuWA0r/oHZj2C/cWyRzRPyfgG2/aK9PSjxI2DBR7o73ToO9coRkF7d+3iDAES1BiLeAw7MAfILepKwdxYw+B8g4x7w39viH23PRsAz3+Jump92N288QK3fXy14XPfPgdungIvbgdG7APf6RdtwcYfYc9L3R8CxVinvUinuXwJi/wHCRgJX9wMBnQFb14L71WpAamb/szy4pHt783uAfwfAuY5x6qlpsh8BB38Sr++YJg6XElGlMLPf3lQZwvxdMOLlF5AGW+RBjhY5P1fK6xSEpkKiv9ENTQCQmQz8Egn89bIYmgDg7llgSW8kp2UDAOyQhYGy3bqP2/4pcO5fIC8diGoFnPhdDEpbPhTDjjIHWNYfuLgV+DFUvC9hE5CRDER/C4s1oxGWOE93UvzRX4FLO8QQF9UWiP4OWNpXrPv7YGD1KOC7AODWCXH4auUIYE5T4Moe4MLWguHL+xfFyfRPUuboDnsJApB6q+Q3URCAu3HAzx2B85tL3q84arXYnsS9+g21XYkueC80wSmwO+DbRnyP176pOzx75h9g/2wO41WGZS8XXM+4Z7w6arK8TGNXQFWkxvY4RUVFISoqCioV58Ho48UWtbH86A0cvfoQD+EA/5xlaCuNR2PJFfSzOICG0upxcuAOZz9BE/lNtJHGQyEp47NdP77g+uGoovcv669zUwqgFgD8L0zcILcFlE/8stz9ZfGv9Wtn3du/P1/8fm3GAum3gZTrQMoNIOu+uH34JiD1BrDm/8Tbjn7AoGVA7ErAvQHQZAAgqIHfugN3Tov7/D1I7FlTq4HomWLAG7gMcPIVhy+zHgCH5gFNBgJ9ZwOrRgIXxLAlk8pgG/w18PAy8Gc/oOdXQNptsRcpJw04twY4vrho/e7BQKtRwPwOwLX9wJb3xV63tmOB9W+J+9w+CQxYWvSxF7aKQ7XhbwHeTXTvUykBC3nx75kgAHdOAW71gdwM8fkDIoFL2wE7L6B2WMH7kfUAGL4RkFkWPD7jLizUucU9c9HXybwH2HmUvE96EnB8CdBiGODgXfJ+ueni0LRLXfG2Wg2c/hvwaADUall6HSolsO8HoF4XsW1qFXAzptD9xbTl/iVAIgEc/IreVxWSYgGZNeAWaJzXr2wH5wHbPgIgASLfF7/IbEkEoWb/+5eWlgZHR0ekpqbCwcHhqZ9PqVRi06ZN6N27N+TyEn7Rm6jULCUW7L2MWynZWHfqNgCgma8jLt+4g5bSC+guPY7Bsp2lPkes2h+NpVeroFrgstobcUIdPGtxuEpez6TZeog9eU+r74/iEOWxxcCGiSXv598R8GoMnN8EPPMt4N1U7KHTaPsm4BYEWFgC694s2N7oJUBuDUS8Cyx9FgjqAdQKA9aMEcNk6vWir9V4gDh0qmHrLoaO4GeAteN0w6+NKzD5AmBRzP+UWz4UA/aAP8TXTdgA1G4lDkfm54q9i/H/ifvWbgW8vkMMW8cWiSHz2bnifslxwMk/gdsnAKkMmBQv9sZtezx8/fJSoGE/cS7fld3iPntnAf1/Fd+n/T8CO6YX1OXXDrh+sOC2Rygw9qAYlAAx6H4bAKiVUDUfhg3oWvT3U/S3wOH/AS8tEt8bjeQEIPuh+LoK24Ltmj8bEokY8h1qib2OSbHi4y9sBQK7iiEzJw2Y6Svu/1GSGPA1z5V6U/w8CgfZ8sp6CFzeBTToA8itS/5d/OgaoM4HXOuJt5U54vtZq4X4D0hharUYtjVHiT68AvwzFGj3tvj9Y2kP3Lsg9mAXNj1V9/aNGMDGpeA19XX2XzFktyxhesRjpf7duREjThVwCTDstaubO2eAW8eQ71IfG2MfVPjfWEOyAIMTg5PBsvNUGP/3SYTXc8WRK/exLU78g3tmeg9Y3j2F7bE3sP7gGUyQ/Yv1qnb4RdUHb1msxSkhEPvUBT0JDsiEkyQDEggYbrEVI2TixPKpyjE4oGqE3ZaTYCkRJ3JvV7XAP6pI9LI4Cl9ZKloLsQAAdcsRkBbq+YiVNca67Cbo2Oc1KJ3q4fXfj8EKuRgvW4NxsvVV9RY9nV4zASc/wNEXWNDR2NUYZvgmwL+9+If1rwHAxW3GrshwEgvxj79PM8CzIbByeNmP8e8IXN1XvtezdRd7siqSpYP4R9qpDhC3tuT9+v8GbJwE5KQWva92K92erHpdAb9wMZgs7Ao0fUUMv6UF5AF/AIfn6wY7oGiY1QjsDry6ApBa6G4/t1bskWs3XpzPeP+C2NMqsxJ72P6bIPZWAuI+kR9AqRJwdfHrqOcshfTZOWJbUq6JwTPjrhh+By4Th+U173/7ieK8yiu7xWFrh1rAqT+BIWvEg0r+ehlFSOWA+omjGd88LNYnkYgHuUS1Frd/lATcOAK4BYs9ko+uAgsigJwU4MWFQN1O4hka7L2ADZOAM8vFx40/URC67l8EnOsCqjzxH48GfaFMS8KBbevQIbw1ZEeixF5bv7Zi0JvbXHzciC1iYKzbUfz5vLoP8GoC3Dom9mIG9RBrvX0SaPySYWH21gnx/Y94D7Aq5e/o3u/Envrwx/8MpSeJw8yNXgQ6vFP6azz+h0HdeCD+k/VhcDImBqens+HUTby1/DScbeQ4+WkPAMC6U7cwYfkp7T7b3+mELzfGQy0I2HfxfpHnaFTLAWdvpUEBJYIkt+AWGIZX2vjhzv2HSLmfhLo31+MvVTecS5UjM08cfnNAJtJQ8B+wFx5ADSmS4QwAWD02HA5WcnT/8cl5U+K3uyMy8a38FzS1T4OXj584jFWaOu2BawfKfkNe3wWcWCp+laThi+J/3cX9QYv8QLebf7pj2a9ZnXz6qGDie3qSbi8SVREJNN/nJqlWS6D5ELE3x9JBDAfFDQtreDUWe7qqG3sfcchYnV98SPRsJM7N1JdvW7EHL3598dME9OVURwyQpenzgzjkrpGfCxz5+XHQOi72kNbrLPa8/Tu64Hdjy+HiPqk3gf0/iNsGrwISH8+H1PTIBvcGnpsnzv8srOELwNUDYu/3a6vFA2seXQV+aqHdRdVmLDbkhTM4GROD09NRKpX4dtlmDHomAvU8xT/yeflq1P+4YGLy1Zl9tNdjb6biYnI6Jv1zWrttwZCWCPSwg7u9Je6l56Kuqy2khU4FoyEIAlKylLj5KBvT/zuH49celVjXvnc7w93eEg0+2VJmG97pVh9/HL6KqW3tMLC5B/BTC5xT10GfvBl4P0yCwPoN8cuh25jd4h5unTuEZoM/h/zeOfEXQ8fJ4n+7j64BLy8Wf1EC4n+rCjvA0k7sdTnxu7g94j2g84dIfXQfuX+8DAuZJXrfHIrxHb3xWmRzwMqxYIgFAP4aCFx43IYpF4E5zQp+YbYYBvg0B+r3EoetHlwsvaGRH4i/9LIeiJeAOKfqyPyCfRq9BPT4EsJPLSDRLC8AALVb667PVZw3jyDHOQhbzyXhVko2wuq4oLXt44n8+dmlP7YiNBsMnFpW+j4lDecVNmqHOGfq9inx0pA/bsbk5AdMjBWHnh5dFYfOHlwSj7IjMlTbcWIo9WoM/Nze2NVoqcLfxoacMAYnY2JwejoltfdWSjbe+OM4hrXzx0sta+s8Rq0W8M3WBCyIvgIA2Du1M/xcy1hs8wlfb4rHL3uvlHh/whe9YCW3wOIDifhyYzxUav2+zVeMaYvRv+xAJqyhgu5wQdcG7mhteQdKjxC83qkerOQWJTyLLkEQ8Mu2k2jikI3wcPEX0KglMdiZoDunqHDA1MpIFlfkDhsJ+LbSPKFuuNJsO7ZIDF6Je4G754B2bxX8B+cRIs6x0MhOASAA1mIPHfZ+BxxfKg5JuAVBqVRi64Y16NWsNmR12uoun5CXJQ5NKOwerxhvDQgCBIkEgxcewcHLD4pvkzJbnLMklYr/kT66Jg6fnPxDDGZWDuJ/tYDYK2fj8vgXdxNxErtULs61ubBZbGP4W+J2AGj+GvB8lDhReteXYi/FvSfOrdhpKtDlY3GoY16YOJTy7BzkZz6EsHIk5Orsoj1+GoueKTrcFDZSHNaL+bXo/oVJZeIwyZb3ANdAcZL79SNA72+BP14o2K/NWLG35d/XC7bZeYrzblJuiKuyZzw+8tKnhThHSsMlAHhpsTi8+KRTfwNr3xBD/ZU9pddaXi2Hi5PiK4LcRqw1N138unOqYp63sk1PBZb0Fb/vxh4Ufwav7AYu7xZPlE4VQhU+HhtyWjE4GROD09N5mvbefJSF+xl5aObrZPDr7rt4D0N+E3tAJnYLwuwdur0thf9gX0rOQLcfovV63lb+zoi5WnxPVuNaDjh3OxVqQYJXWvvig94heGb2PtxKyYaPoxV+GRqGRrUcsTP+LvacvwcvRyt8t1V3EU9NXf7vbyzy/N+91AQHLz9Av+a10DbABZYyC+QoVfjryHV0D/WEr0vZ4XLV8ZvIzM3HsHb+uPYgE38duY43OwfC0dqwz+bJzzUvX40Ld9MR6u1QbG8gABxNfIgBCw7pbGvu5wQ/FxvMGdTcoNcvVX6eOEfFyVc8gvBmDBA2qmiYVKvENbu8m4iTka2KH/ZUKpXYsmEdnmnsCpl/e0CmKLpTdgqw+yvxCETNUXoaggCcWSH2+Fg5Ag8TxYnt7sHixGFn/+KfU+OXzmIIGhcjri2WeguwUIhzTEqbLwKIvWIp14DQEo7SfLKtOVnYumkDevZ5DnILiXikZHqSGEhXjRBv95svHglZr4vYjj0zxHal3xEni989Kw6/aHohnvkWaPN/mhcQh6Z2fanbk/n2KfGzWvl4knOXT8Tgm5EEbPtEDHTD1os9gjYuup/lk5PhHf2AF34Wn+/gXLEu/45AcnzBUaiPJXi9gHojF0B+dL4YQqUW4ucTNgL4X1ux9xUABv0tvu7fg8Q1sQCg8ctiuLb3EpcauHZQDN93zwIJG8UhM43ID4HI98TvOZUSkD9xuqf8XGD922KoChsB7P2+7J5Pl3riUa2lcW8ADFwG1eGfkXzxOLxTTxS/39hD4kEJq0cBrkFA88G672lhTn5AxPvi8KfmK7eYOXD6cG9Q9B+Yp6R85wI27TnM4GRMDE5Px5jtjb5wD4EedqjlZI34O2kYsTgGSWk5GBBWG9++1FS7n0otoN6Hmyr89TsGuRU7Z6s00VMjUcfVttjg9KRfhrTEqRsp+N+ey7CUSXHs427IyM2Ht6M1VGoBSpVap9dLqVIj6CNxiHT/e53RL+oA7mfk4bmmPpj7imHB5cnPdcrK01h1/CamPRuKEe3rFvuYBdGXMWNz8b8k4z/vBWuFfj106TlK5KsEONuWEjYqkNF/ZlX54uRgW7dKf6kKaaumx/PeebHnMLBr0X3UKrGHzKc5oHgc+POygF8ixN6yFxfo/3qqfHGY2Ke52Lv5pMz7YjB+3POpCV16tfXUX8CNo0Cf74tOSC/Lwytij5gyR+wpLO5ITH0lx4uBy70BkHxO7GWVWoiBTWYtfn9c3C6GxR5fivOKUm8AwzYAMoVuW5PPAFs/FnthS1uEVqUUjwxNOisepVrSZHBBANJuiUuQuAUD9XuIRxvGrRWHgSM/ECeUH/1FHOr3DBWnKgz8U/wnIz8PgABIpGLvq0opTnrXLAcz4TRg7y3+E5CfLR4Z6dNcDJs+LcTpDmm3tf+wVNbPqyFZoMau40SmL6J+wYlkQ7wdcPjDYn6BA7CQSvBerwY4mvgA819riT3nk/HGnyX8Z2YAQ0MTAER8t0fvfcf8cVx7PTdfjcbTxSPUvB2t4Ggtx920HOyeEgkbhQwKmRQnr6do9796X+zNA4ADl+7j5qMs1HKyhuTJXplCBEHAm8tO4HZKNpaN0j28etXxmwCA+Xsulxiczt9NL/G5F+67gsw8FZ5r6oP50ZfRpq4LujTwgI+T7h9CQRDQ4ovtUKoExH3eEzaKyvsVpVSpsflsElr6Pv0/TE/FQlYhoSk1S4n7mbnYeOYO/N1s8VxTnwoorhia7yH3YPGrOFIL8ejKwhQ2wLijRXsGy2IhA+q0K/n+wu+doc/d7FXxqzwq8vB+j5CC6z6F/snRLNtg4wI0HSh+AaWfOL1WS2CkHovfWsjFofyGL5S+n0QCONYWj1bUkErFI+EavSjebvYq0Pu7gvs7Ti64/mRvq0wBtBgq9sRmPRAvAcCvjXipmSdamEMlfS+XE4MT1QhjI+thbKR4OG+vRt54rqkP1p++jf4tauNI4gO81TkQ7/9bDY/MKcad1BzcSRVXU2/2+XY4WMkwuUcwpq0/p93ntd+OaK8/yMxDh29248PeDTCmU/HryGTk5uO/07ex+aw4hybs6114LUCCNhm5GPVHwTpYyem52t6yNW+2g5ONAutO3YJCJsX5JDE4TXs2FNlKFb7dUjBM+f32CwCAn6PFoYf/TovrgCXO6I0T1x/h8JWHeCOiHuJup0GpEjvB4++ko4WfEx5lKeFSgb1P2XkqbI+/i0vJGZi78yK8HCzxQcMKe3qjGffXCey/VBDm+zb2LnFY1WgMDTZkvup2MnYF5cbgRDXSdy83wf9FBCDU2wESiQT5KjW+2ZKAR1mln10+yEGNa1ky5OWri71/1stNcfleBubvqboTrabl5OuEppJ8vSkBTWo74frDLNx4mIXrD7Nw7YF4/UFmns6+OUo1Fp63wMJvSp4b9sL/Dha7vXOwB+QyqU5wKknwJ1u072WItz1GLjmmva///IPo28QbG87cwc+vtUSvRl5lPp9Gdp4KcXdS0cLPGbsSkuFmZ4mmj+fSfb4hDn8fLZhfklToxNCmrHBoAoC4O2nwd7OFnSV/zRNVJP5EUY1kKbNAQ5+CycIyCylWjW2Hrt8XBIXXO9TFpB71kZWnwtDfjiLuThr6+asx5uVu+PS/ePx99AYAIMjDDsPb+6Ohj6N2ovvNR9naXhUNO0sZzn7WEwBw6PIDvPJr1a9oPuiXkl9TInn608hZyqTwdbGBWs8nKhxAd8QXXbl8wxnxXIQf/HsGvRp54VJyBs7dTsVzTX2QkqXE28tPwkIqweyBzeBkU9Ar9dGaWPx78ha8HKyQlCb2zmkm5hcOTRo5KmD1iVvoEuoFD3txYu+DjFy8tzoWA1v5onuop57vQOXIyssvddgyR1n09EJ9f9oPb0cr/D6yNX7ddwVjOgWgjrNVMY8ucPDyfdxLz8Xzzcp5gmuiGoDBieixeu522PduZxxJfIiwOs6o42oDiUQCG4UMf49pixv303H5hLg69IwXm+Crfo1LHAp5sXktbXCa/mwovtgYj59eLZi74GqnO/Rkq7DQLu4JAAqZFK+1qYNFBxLRMcgNswc2w/v/xuJRZh6OFbN+lb6hx9/VBr4uNvAr9OXrYgM/Vxs4WMlR94ONTxWe2ge6wUIqgQUkaOrrhNM3UvR+7F9HSj7K6FGWEtvOJWnnfVnJLbAz/q52nlnHb3YjPVdcZf7jPiH496R4ImRNaALE4cgHGcX3Lr13VAbgHPolPoKdlQxnbqYiwM0WO+LvYkf8XSTO6A21IM6XK68HGblIy8lHXTdx3kpKVh4creXaeWc/bL+Ak9cf4bdhraCQFSz/sPLYDUxddQbf9m+CAa18i33uu4XaWdid1BztIrD5KgH9W3hj7x0JbC/cQ7eGReeNvPqrOMTb0McBgR725W6rPgRBKHXOHVF1xeBEVIjv4yDxJEdrOWy87FF4AK60+SMR9d0xvJ0/AtxtMTTcHwNb+ekcVVbf0x4f9wnBf6dvw8Fajpn9m2D8XyeQo1RjQFhtDH88AXtIeB242CrgaC3Hr0PDsCLmujY4DQ2vg98PiSsAb3+nE6zkFvjj8DXt+lhAwfIK9lYyHP+4u84f5OJM6RGM77aex+DWvsi9dxWrEoseadQ2wAWHrzwEULDqu8aQ8IIjeFb+Xzhy8lVoMr1iTrtSeLL8zvi7+OfYTe1tTWgCgC83xhf7+EbTtpb5GmtPFfQSnrlZcAh23Q/EozJrOVljco/6cLZVoHNwKSf7LeTJNccOf9AVG87cxpcb4zHr5aaIDHZHXr4ac3eKS2qMWHIUGbkq/DqkJWwsZZi1TRzyfHf1GShkUnSq7474O2nYcOY2nG0U8HOx0Zmf92ZkPfyvmKHif0/eehwoLbD66kn0CL2NfLWAUR3qol09V0wvNNx781E26rrZ4WJyOup72Ff4XKmr9zPxwv8OYHi7upjQLahCn7s6yFepYSGVMBiaKQYnokoglUow/bmCGcfFHYr/escAvN6x4Micf98sujqvpndCo/Dw4oSuQdh45g4igz20vQN9GnvrBKd//i8cm88moZW/S5mhCQDGdApAK38XhHrZYue2RBx8aIXbqbq9GQuHtcJ3WxLQJsAVvRt7Iy9fjd8PXYWV3EInTChkUihkUozpFIDtcXfxxfONUMfVBh2/3a3zfJqJ+oYoHJqq0q2UbO2q978MaYkeDUued5Wdp8Lei/eKLNT61aZ4bW/klJWnizzuwCVxbaGpq87g8JUHyC00nDlxxalS6+vfojZGdahbbHB60ra4uwCAXQnJ+G1YGJYeKjgNx/DFMXi5ZW2sPH6z1IMKDJWRm48VMTewPS4Jj7KU+HHHBbMKTjcfZeHlnw/hTmoOGtVywBfPN8KRxId4sUUt7RBwSfJVauTkqzknzQTwEyIyIY1qOWLh0DDUdrGGq50ljnzYVWf4qEltJ22Pw4SuQZBIJOjd2Fvv55dbSNG6rguUSnGS/D9jWmPU7yd1lhqws5Ths+cbaW8rZFKdAPikD3uH4MPeBYdbrxjTFnN2XsRnzzWEShBQ29nG4OBUnAZe9khIKnlJhIo2ddUZNPdzhrt9wfo3qdlK7E5IxpazSYi+cA/Zxcw9enLuW0miLxh+4l9ND6WhFu5LLLJt5eMlKL7elKANToWH145fewhruQwh3vY6PSsPM/Ow53wyej8O8c62cgwN9wcAfLkhDstjbhhcn6kY8ttR7RGvZ2+laQ+guJCUju8HNMV/Z+7AWm6BAHdbZOTkaw9YAIBXfj2MY9ce4dhH3eBqZ8AJdqnKMTgRmZhuhSYqyyyK9iK926sBpvYMrpBhAk8HK2x9pxPO3U5Fn7n7n/r5AKBNgCv+CnDV2fZ2l0DM3XVJZ9uRD7siO0+FyFl7Sn2+um62uJ2SjR8GNIOVXIrn5x3QGbrTWDKiFe6k5sBCKsG7q/Q/BUZ4gCsOXXlQZHtqthKLDiRiZPu62B53F1vPJeHg5fva5RSqWl03WzSt7fh4Xp4FsvJ0Q5ubnSXulzDHq7j2FZacloOes/ciW6nC9ncicOpGCsb/fRIA8MXzDfFa2zoQBLGndeKKU9h74Z7O+Shfae0HuYUU604VDY2HLj/A+tO38FrbOjo9qvoSBAFHEh9ixqZ4TO4RjI5Bbvjg31jYW1qgUdkPL1Vmbj7Wn76Nvk28YW9VsNjik/OzklJzsDPhLhLvF3/i3YJhUl0Dw3wxs39j3E3L1Z6xYGdCMgaEFT+XjaoHBiciM1TRcysa+jhi8YhW8HUuZuXmCjCpRzAcbRT4YkMcAOCLfo3g6SAObfRs6Imt5+7iv7c6IMjTDiq1gIaP5yt1C/HAL0PCoBIEyB+HyF+HhWmPHuzd2AubYpMwqkNdRD4eRkx+YiK1QibVObqvnrstLt8T/wD+9Xob1HW3xXPzDkClFvDwiWUblh68ip+jL+tMqA/ysEOvRl5oU9dVZz2t4vRp7I1uoR7oGuKJX6KvYN7uS8Xu52gtR2p26Utl/Pl6G+3nHj21M+6l52Ll8RtYEXMD//xfOAI97PQ66XVxWn+9U3t93q5LOH0zRXv7k3Xn8Mm6c5BbSLD+rQ7YW0xP2burzmBNMcEBgPbo0jM3U7Hx7Y5615SXr4ZCJsW09ee0c/2GLjqK7e900vZqffr4eAylSg2VWoCV3AK3U7Lx7ZYEvNk5EPU9xSHuLzbEYWf8XXz3clOcup6C4e39IbeQYsHeK5i78yL+OXYD/45tB6VKwOcbzuHPw+KBDE19neDjaIW9F+7pHNyhrxXHbuDZpj4YuSRGu+1BRh6UKjVO30hBk9pOeg2xU9VicCIiveg7Gbq8RnWoixHt/CGR6Aa/ea+2wIOMPHg5FswR+b9OAVi4PxFjIwMhlUogRcH+bQNcMePFxnCylqNTfXf0a1YLnQqtMu/hYIUv+zXC8WuP4GqrQC0nS3y2QTxVzKtt/PDl841w5X4mJBLxSEsAOPphV0RfuIfhi8U/cCvGtMXAXw5re3Wa1nZEz0Ze6NnQS/uYss5m5WwjR9TgFtrbQ8Pr4GFWHoa0rYOk1ByMKPTHtGuIB0a0q4sr9zNw9lYqgr0c0Km+G/acvwcPe0tk56lQq9Aq7O72lnC3t8Sn3qH4uE+odjg3sr4b9ly4jw6Brghwt8MLzWuVuB5XSZLTc3ApOaPIdqVKwDNz9hX7mJJCU2HnbqfB//2NaF3XBYIgQC2gyKVaEGAhlSA8wBXLjlzHc818ihyNebFQbZ+flOHzk+LBCY7Wcmyf1Akjl8QgISkda0/dRlgdZ52jVF/+WTzXYmZePp5r6oPf9onz005eT9EeIFDY6RspOP2UI48L919BnqoguH+zJQHXH2bi76M3MKpDXXzSN/TpXoAqHM9Vx3PVPZWa1F62tfoQBAEZufk6wyfllZ2Tiwm/bsOQHq3RMbjk9Zpib6bi2XnicGXijN5YeewmsvLy0b2hl05oKWzGpngcSXyIU4+XZZjYLQjbzt1F3J20Mv8o3k7JxodrYhHgZoepPYP1Ptdfae6nZWHW8h1495VucLEXjx7t8v0eXLlX/BATGa5tgAseZORpA9zLLWtj2nMN9TqqsziFT1iukZuvglwq1R7tWPjnVSlI8O2W8+ga4oGOQe5FHmvqeK46IqJykEgkFRKaAHGeWB8/NdoGuJS6X6NaDni7axBqO4vn/CtpTaXCPng8KT7udhoOXLqPEe39MbFbfdxOydYORZbEx8kaS0a01r8henC0liPcU9B571a/0Q7Nv9ius99XLzTCnvP3sP3xkXfF8XOxwfWHWQCASd3r4++j17UTo59GgLstpvYQ5+hJJYBUIoFUCkgggUQinrZHsxxGddHK3xm3HmWjY5A7vn6xMSykEkRfuIc1J27ik2dDn+pIueS0HBxOfIjNsXfwZb9GuJeRi16zxZ69vVM7w8+1YPmUqw8y0X32AQDAkoNX0SHQDX+Maq3X0H1qthJfbohD/5a1kZKlxJHEB/iod0ix8yg1Lt5Nx4qYG1Cq1Bjctg7qe9ojISkNEkgQ7PV064Dl5auxKfYOOjfwgKN19frnrcYGp6ioKERFRUGlMnxcmohqHolEgknd65frsaE+Dgj1Kfgv9smTGxuTs60CRz/qivWnbiPudhpeaeOHVv4uGNymDp79aT9ib6Xio94hqO9ljz8OXdWu8O5mp8DLLWvj2sMsDA2vg2eb+mDZ4WtYuL/oEXr//F84mvk6ISM3Hy0KhTQXW0XReWMjWhe7llphFRWcAtxsIbeQlnqC6tIWl32ltS9mvNik2Psi6rvrnIh8wZCWGLfsBMZ3CcKhK/cxNNwfby4r+2TjheeXOdnIdd6vKStP4+chLbH5zC1I84EJK3QPeth/6T5irj5C67ql/1MAANPWncXaU7e1R1MCwM74ZGx7pxOWH72OPk18dI4gBYBec/ZBpRbfnOUxN3Dik+7aUHd6Wg/YW8p0ht6z81RYuO8K+jWvBXd7S+Sp1Pgn5gb+O3MHcwY2Q+KDTETWd4dEIsGSg4n4elMCGvo4oGUdZ9x8lI1vX2oCR0vjz/mqscFp3LhxGDdunLZ7joiopvKwtyp2SYmlI1vjzM0UdApyh1QqQYdAN9T7UJzrk6dSY3zXgjWYnGwU+LhvKPxcbWAhlcDV1hLj/z6Bb/o30f7htpcU/MmZ/mwoHmTm4adCR1NundipzNAUXq/giMxeDb3w/YCm+GZLgnaCOCCu3F/cUWyF7ZgUgUAPcT7a5tg7GLvsBJr5OuGXIS11woqPozUGtfLFjoRkvNNN7HF0slFgy9kk9Guu/6lpejb0wrnPe8JSZoEJEN83K7kUOcriz3tZnISkdKgLhbijVx8WCqIyAEUD4IAFh3D2s56l9nqduP5IZ/FXjesPs7QHFCw7ch2NazuiU5A7rj/MQnM/J21oAoDcfDV2JRScNunrjfFYcewG2ga4YPmYcADAp+vOYuXxm/h++wXUcrLGrZRs7f6ao2e/eL4hhoT7ayf4n7udhnO3xUV2Jyw/iSXDWpb8BlWRGhuciIiodC62Cu3RiIB4ypn3ejXA99vO66zNVZhmzSYAOPdZL52jwuQWUmyd2An5ajUa+jhic+wd7X2rx4brNbxjKbPQHmk5rJ0/bC1l+Pz5RjiflI4jiWJP1NjIekWCU3M/J0TUd8ecnRcxMMxXG5oAMdRsGN8B9T3toZBJsXhEK4x4fCDA/NdaoEltJ52QCACvta0DQ1nKdOeprRvXAT1n79Xe9nWxxvNNa2Hd6Vu48TD7yYfj9I0UneCkr592XcSQtnVQy8m62GG74YuOlvkcF5MzcDE5A/+eKDmQapaoAMQjBgGxd7DJ9K0Y2aGuTm9W4dBUmOYozeKMLmW9uKrE4ERERHobG1kPI9r7w0pe9mT14g6lLxyOejXywtSewWhS2xEt65Q9nKQxZ1Bz3HyUrRN+fn6tJfZevIe2Aa7wdLDCujfb4p+tB5Dj6IvVJ25jao9gtAt0w6BWfkXOFSmVStCoVsHIQ+dgDyTO6I3MPFWlruQd7GWPs5/1xKHLD1DXzRZ+LjZQyKSY0jMY/u9vLLK/JjQVHj7s18wHBy7dx72MvCL7ayyIvoIF0VfgaqtA49qOaFLLEU1qO6FJbUe42lkiLafoumcVKS0nH7N3XHyq5/B0sERksId2cV5jYnAiIiKD6BOa9CGRSDCuc2C5Xr9waALEuVrPNysYOgv1dkBrDwE9ezXElJ4N4O0ozisrvKxFWbVVxelP7Cxl6B5a9GjOwW38sOzIdfz0SnO0CXDBiqM38P32CwDESf45ShVylGoMCa+Dt7sE4PuV0dh4o+jnUs/dFtYKCyTcSceDzDzsOX8Pe86XvSr9v2+2w4sGLlXxtOq62eosImohlWiHA1/vUD16mwAGJyIiMmMWUok2NJmSz59vhDci6mnnfI3vGqQNTm3quuDNyEBYPO4pUyqV6FFbQJc2jZGnFk+ivGDvFbQPdMWy19sCAHKUKiQkpePMzRScuZmK2JupuJhcMGfqlda+UFhIsfTQNQwM80ULP2dM6l4fiw4kIiWraC9PXTdbbJ7QEV9ujNMuCAqI59Ccs7P03qXpz4aif8vasFXIsDMhGaN/P4ZX2/jh6xca44sNcfjt8QEGr3esi/b13LA97i6GtjN8aLSyMDgRERFVMxZSSZGJ8jsnR2DhviuY3CMYbsWcz+65pt6Qy+XIzVehuZ8Twuu5ae+zklugma8TmhU6P15mbj7i7qThxsMsdAv1hFwqRXg9N3QMEh/3dtcgvN01SDtsqJBJMbJ9Xfyy9zJmvtgYVnILfNmvMeyt5Jj/+MTSYzoFFAlObnaWmPFiY8zdeRHPNvXG8PZ1tfd1D/XEmeniEXgA8F6vBugW4omWdZy1Q72FF7CtDhiciIiITEA9d7sSlz8ozFJmgV6Nyj65t62lDK38XdDKv2B+Wa9GXkX205yWqGltR7z/TANM7BakM1w7uXt9PN/MB/U97CGVSrBgSEtsO3cXres6Y/GBq5j3agsEetgVOyQJAA6F1hVTyKQ6R05WRwxOREREVKLVb7TDwv1XMKVHMICic9xkFlI08CpYp6xnQ/H0QwAwsJVf1RVaRRiciIiIqESNaztizqDmxi6j2jD+EpxEREREJoLBiYiIiEhPDE5EREREemJwIiIiItITgxMRERGRnhiciIiIiPTE4ERERESkJwYnIiIiIj0xOBERERHpicGJiIiISE8MTkRERER6YnAiIiIi0hODExEREZGeGJyIiIiI9MTgRERERKQnmbELqGq5ubnIzc3V3k5NTQUAPHz4EEql8qmfX6lUIisrCw8ePIBcLn/q56vualJ72VbzxLaaJ7bVPFVWW9PT0wEAgiCUuW+NC04zZszAZ599VmR73bp1jVANERERVRfp6elwdHQsdR+JoE+8MiNP9jip1Wo8fPgQrq6ukEgkT/38aWlp8PX1xY0bN+Dg4PDUz1fd1aT2sq3miW01T2yreaqstgqCgPT0dPj4+EAqLX0WU43rcbK0tISlpaXONicnpwp/HQcHB7P/Bi6sJrWXbTVPbKt5YlvNU2W0tayeJg1ODiciIiLSE4MTERERkZ4YnCqYpaUlpk2bVmQ40FzVpPayreaJbTVPbKt5qg5trXGTw4mIiIjKiz1ORERERHpicCIiIiLSE4MTERERkZ4YnIiIiIj0xOBUDlFRUfD394eVlRXatGmDo0ePlrr/ypUr0aBBA1hZWaFx48bYtGlTFVX69Axp65IlSyCRSHS+rKysqrDa8tu7dy+effZZ+Pj4QCKRYO3atWU+Zs+ePWjRogUsLS0RGBiIJUuWVHqdFcHQtu7Zs6fI5yqRSJCUlFQ1BT+FGTNmoFWrVrC3t4eHhwf69euH8+fPl/k4U/yZLU9bTfVndv78+WjSpIl2EcTw8HBs3ry51MeY4mcKGN5WU/1MizNz5kxIJBJMnDix1P2q+rNlcDLQihUrMGnSJEybNg0nTpxA06ZN0bNnTyQnJxe7/8GDB/HKK69g1KhROHnyJPr164d+/frh7NmzVVy54QxtKyCu5nrnzh3t17Vr16qw4vLLzMxE06ZNERUVpdf+iYmJ6NOnDzp37oxTp05h4sSJeP3117F169ZKrvTpGdpWjfPnz+t8th4eHpVUYcWJjo7GuHHjcPjwYWzfvh1KpRI9evRAZmZmiY8x1Z/Z8rQVMM2f2dq1a2PmzJk4fvw4jh07hi5duuD555/HuXPnit3fVD9TwPC2Aqb5mT4pJiYGCxYsQJMmTUrdzyifrUAGad26tTBu3DjtbZVKJfj4+AgzZswodv8BAwYIffr00dnWpk0b4f/+7/8qtc6KYGhbFy9eLDg6OlZRdZUHgLBmzZpS93n33XeFhg0b6mwbOHCg0LNnz0qsrOLp09bdu3cLAIRHjx5VSU2VKTk5WQAgREdHl7iPKf/MFqZPW83lZ1YQBMHZ2VlYuHBhsfeZy2eqUVpbzeEzTU9PF4KCgoTt27cLERERwoQJE0rc1xifLXucDJCXl4fjx4+jW7du2m1SqRTdunXDoUOHin3MoUOHdPYHgJ49e5a4f3VRnrYCQEZGBurUqQNfX98y/ysyZab6uT6NZs2awdvbG927d8eBAweMXU65pKamAgBcXFxK3MdcPlt92gqY/s+sSqXC8uXLkZmZifDw8GL3MZfPVJ+2Aqb/mY4bNw59+vQp8pkVxxifLYOTAe7fvw+VSgVPT0+d7Z6eniXO90hKSjJo/+qiPG0NDg7GokWLsG7dOvz5559Qq9Vo164dbt68WRUlV6mSPte0tDRkZ2cbqarK4e3tjZ9//hmrV6/G6tWr4evri8jISJw4ccLYpRlErVZj4sSJaN++PRo1alTifqb6M1uYvm015Z/Z2NhY2NnZwdLSEm+88QbWrFmD0NDQYvc19c/UkLaa8mcKAMuXL8eJEycwY8YMvfY3xmcrq7RnphonPDxc57+gdu3aISQkBAsWLMAXX3xhxMroaQQHByM4OFh7u127drh8+TJ+/PFH/PHHH0aszDDjxo3D2bNnsX//fmOXUun0basp/8wGBwfj1KlTSE1NxapVqzBs2DBER0eXGChMmSFtNeXP9MaNG5gwYQK2b99erSe0MzgZwM3NDRYWFrh7967O9rt378LLy6vYx3h5eRm0f3VRnrY+SS6Xo3nz5rh06VJllGhUJX2uDg4OsLa2NlJVVad169YmFUDeeustbNiwAXv37kXt2rVL3ddUf2Y1DGnrk0zpZ1ahUCAwMBAA0LJlS8TExGDOnDlYsGBBkX1N/TM1pK1PMqXP9Pjx40hOTkaLFi2021QqFfbu3Yt58+YhNzcXFhYWOo8xxmfLoToDKBQKtGzZEjt37tRuU6vV2LlzZ4njzeHh4Tr7A8D27dtLHZ+uDsrT1iepVCrExsbC29u7sso0GlP9XCvKqVOnTOJzFQQBb731FtasWYNdu3ahbt26ZT7GVD/b8rT1Sab8M6tWq5Gbm1vsfab6mZaktLY+yZQ+065duyI2NhanTp3SfoWFhWHw4ME4depUkdAEGOmzrbRp52Zq+fLlgqWlpbBkyRIhLi5OGDNmjODk5CQkJSUJgiAIQ4YMEd5//33t/gcOHBBkMpkwa9YsIT4+Xpg2bZogl8uF2NhYYzVBb4a29bPPPhO2bt0qXL58WTh+/LgwaNAgwcrKSjh37pyxmqC39PR04eTJk8LJkycFAMIPP/wgnDx5Urh27ZogCILw/vvvC0OGDNHuf+XKFcHGxkaYOnWqEB8fL0RFRQkWFhbCli1bjNUEvRna1h9//FFYu3atcPHiRSE2NlaYMGGCIJVKhR07dhirCXobO3as4OjoKOzZs0e4c+eO9isrK0u7j7n8zJanrab6M/v+++8L0dHRQmJionDmzBnh/fffFyQSibBt2zZBEMznMxUEw9tqqp9pSZ48qq46fLYMTuXw008/CX5+foJCoRBat24tHD58WHtfRESEMGzYMJ39//nnH6F+/fqCQqEQGjZsKGzcuLGKKy4/Q9o6ceJE7b6enp5C7969hRMnThihasNpDrl/8kvTvmHDhgkRERFFHtOsWTNBoVAIAQEBwuLFi6u87vIwtK3ffPONUK9ePcHKykpwcXERIiMjhV27dhmneAMV104AOp+VufzMlqetpvozO3LkSKFOnTqCQqEQ3N3dha5du2qDhCCYz2cqCIa31VQ/05I8GZyqw2crEQRBqLz+LCIiIiLzwTlORERERHpicCIiIiLSE4MTERERkZ4YnIiIiIj0xOBEREREpCcGJyIiIiI9MTgRERER6YnBiYiIiEhPDE5EROUgkUiwdu1aY5dBRFWMwYmITM7w4cMhkUiKfPXq1cvYpRGRmZMZuwAiovLo1asXFi9erLPN0tLSSNUQUU3BHiciMkmWlpbw8vLS+XJ2dgYgDqPNnz8fzzzzDKytrREQEIBVq1bpPD42NhZdunSBtbU1XF1dMWbMGGRkZOjss2jRIjRs2BCWlpbw9vbGW2+9pXP//fv38cILL8DGxgZBQUFYv3595TaaiIyOwYmIzNInn3yC/v374/Tp0xg8eDAGDRqE+Ph4AEBmZiZ69uwJZ2dnxMTEYOXKldixY4dOMJo/fz7GjRuHMWPGIDY2FuvXr0dgYKDOa3z22WcYMGAAzpw5g969e2Pw4MF4+PBhlbaTiKqYQERkYoYNGyZYWFgItra2Ol9fffWVIAiCAEB44403dB7Tpk0bYezYsYIgCMIvv/wiODs7CxkZGdr7N27cKEilUiEpKUkQBEHw8fERPvrooxJrACB8/PHH2tsZGRkCAGHz5s0V1k4iqn44x4mITFLnzp0xf/58nW0uLi7a6+Hh4Tr3hYeH49SpUwCA+Ph4NG3aFLa2ttr727dvD7VajfPnz0MikeD27dvo2rVrqTU0adJEe93W1hYODg5ITk4ub5OIyAQwOBGRSbK1tS0ydFZRrK2t9dpPLpfr3JZIJFCr1ZVREhFVE5zjRERm6fDhw0Vuh4SEAABCQkJw+vRpZGZmau8/cOAApFIpgoODYW9vD39/f+zcubNKayai6o89TkRkknJzc5GUlKSzTSaTwc3NDQCwcuVKhIWFoUOHDli2bBmOHj2K3377DQAwePBgTJs2DcOGDcP06dNx7949jB8/HkOGDIGnpycAYPr06XjjjTfg4eGBZ555Bunp6Thw4ADGjx9ftQ0lomqFwYmITNKWLVvg7e2tsy04OBgJCQkAxCPeli9fjjfffBPe3t74+++/ERoaCgCwsbHB1q1bMWHCBLRq1Qo2Njbo378/fvjhB+1zDRs2DDk5Ofjxxx8xZcoUuLm54aWXXqq6BhJRtSQRBEEwdhFERBVJIpFgzZo16Nevn7FLISIzwzlORERERHpicCIiIiLSE+c4EZHZ4QwEIqos7HEiIiIi0hODExEREZGeGJyIiIiI9MTgRERERKQnBiciIiIiPTE4EREREemJwYmIiIhITwxORERERHr6f7uvtemFSJpMAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 600x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "def smooth_and_filter(df, column='train/loss', window=20, threshold=2.5):\n",
    "    rolling_mean = df[column].rolling(window, center=True).mean()\n",
    "    rolling_std = df[column].rolling(window, center=True).std()\n",
    "    lower_bound = rolling_mean - threshold * rolling_std\n",
    "    upper_bound = rolling_mean + threshold * rolling_std\n",
    "    filtered = df[(df[column] > lower_bound) & (df[column] < upper_bound)]\n",
    "    return filtered\n",
    "\n",
    "df['epoch'] = df.index / len(df) * 4\n",
    "df1['epoch'] = df1.index / len(df1) * 4\n",
    "\n",
    "df_filtered = smooth_and_filter(df)\n",
    "df1_filtered = smooth_and_filter(df1)\n",
    "\n",
    "plt.figure(figsize=(6, 5))\n",
    "plt.plot(df_filtered['epoch'], df_filtered['train/loss'], label='Continue pretrain on new knowledge')\n",
    "plt.plot(df1_filtered['epoch'], df1_filtered['train/loss'], label='SFT on new knowledge')\n",
    "plt.yscale('log')\n",
    "plt.yticks([0.5, 0.8, 1.0, 1,3, 10])\n",
    "plt.xlabel('Epoch')\n",
    "plt.ylabel('Validation Loss')\n",
    "plt.legend()\n",
    "plt.grid(True)\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
