{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "bd753820-8748-4859-88a2-972415b37d67",
   "metadata": {
    "executionInfo": {
     "elapsed": 12174,
     "status": "ok",
     "timestamp": 1750103043946,
     "user": {
      "displayName": "subina khanal",
      "userId": "01847233947579723981"
     },
     "user_tz": -120
    },
    "id": "bd753820-8748-4859-88a2-972415b37d67"
   },
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "from sklearn.metrics import mean_squared_error, mean_absolute_error\n",
    "from sklearn.preprocessing import MinMaxScaler, StandardScaler\n",
    "import time\n",
    "import matplotlib.pyplot as plt\n",
    "import joblib\n",
    "\n",
    "from river import ensemble\n",
    "from river import metrics\n",
    "from river import preprocessing\n",
    "from river import forest"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3bef2571-d308-46ab-8558-4d65319ab450",
   "metadata": {
    "executionInfo": {
     "elapsed": 28089,
     "status": "ok",
     "timestamp": 1750103072033,
     "user": {
      "displayName": "subina khanal",
      "userId": "01847233947579723981"
     },
     "user_tz": -120
    },
    "id": "3bef2571-d308-46ab-8558-4d65319ab450"
   },
   "outputs": [],
   "source": [
    "df = pd.read_csv('5G_millisecond.csv')\n",
    "df = df.set_index('DATE')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "757323fe-c0b1-4cf6-a3f0-8b99e8a7f596",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 382,
     "status": "ok",
     "timestamp": 1750103072413,
     "user": {
      "displayName": "subina khanal",
      "userId": "01847233947579723981"
     },
     "user_tz": -120
    },
    "id": "757323fe-c0b1-4cf6-a3f0-8b99e8a7f596",
    "outputId": "9501c415-1d3e-47f3-d84f-177a75708381"
   },
   "outputs": [],
   "source": [
    "df = df[['mac_dl_brate']]\n",
    "\n",
    "target = 'mac_dl_brate'\n",
    "\n",
    "num_lags = 2\n",
    "for lag in range(1, num_lags + 1):\n",
    "    df[f'{target}_lag_{lag}'] = df[target].shift(lag)\n",
    "\n",
    "df.dropna(inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b743ac20",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total training time: 170.60 seconds\n",
      "Average training time per sample: 0.006523 seconds\n",
      "Total inference time (test set): 369.54 seconds\n",
      "Average inference time per test sample: 0.000595 seconds\n"
     ]
    }
   ],
   "source": [
    "horizon = 96\n",
    "split_point = int(len(df) * 0.8)\n",
    "test_start_time = df.index[split_point]\n",
    "\n",
    "\n",
    "model = preprocessing.StandardScaler() | forest.ARFRegressor(seed=42)\n",
    "records = []\n",
    "\n",
    "total_training_time = 0.0\n",
    "total_inference_time = 0.0\n",
    "test_prediction_count = 0\n",
    "train_sample_count = 0\n",
    "\n",
    "for t in range(horizon, len(df) - horizon):\n",
    "\n",
    "    #Prediction\n",
    "    if df.index[t] >= test_start_time:\n",
    "        start_pred = time.time()\n",
    "\n",
    "    for h in range(1, horizon + 1):\n",
    "        idx = t + h\n",
    "        row = df.iloc[idx]\n",
    "        x = {col: row[col] for col in df.columns if col != 'mac_dl_brate'}\n",
    "        pred = model.predict_one(x)\n",
    "        actual = row['mac_dl_brate']\n",
    "        timestamp = df.index[idx]\n",
    "        source_t = df.index[t]\n",
    "\n",
    "        records.append({\n",
    "            'timestamp': timestamp,\n",
    "            'source_t': source_t,\n",
    "            'horizon': h,\n",
    "            'actual': actual,\n",
    "            'prediction': pred\n",
    "        })\n",
    "\n",
    "    if df.index[t] >= test_start_time:\n",
    "        end_pred = time.time()\n",
    "        total_inference_time += (end_pred - start_pred)\n",
    "        test_prediction_count += horizon  \n",
    "\n",
    "    #Training timing \n",
    "    if df.index[t + 1] < test_start_time:\n",
    "        start_train = time.time()\n",
    "        row = df.iloc[t + 1]\n",
    "        x = {col: row[col] for col in df.columns if col != 'mac_dl_brate'}\n",
    "        y = row['mac_dl_brate']\n",
    "        model.learn_one(x, y)\n",
    "        end_train = time.time()\n",
    "        total_training_time += (end_train - start_train)\n",
    "        train_sample_count += 1\n",
    "\n",
    "df_forecasts = pd.DataFrame(records)\n",
    "\n",
    "print(f\"Total training time: {total_training_time:.2f} seconds\")\n",
    "if train_sample_count > 0:\n",
    "    avg_training_time = total_training_time / train_sample_count\n",
    "    print(f\"Average training time per sample: {avg_training_time:.6f} seconds\")\n",
    "\n",
    "print(f\"Total inference time (test set): {total_inference_time:.2f} seconds\")\n",
    "if test_prediction_count > 0:\n",
    "    avg_inference_time = total_inference_time / test_prediction_count\n",
    "    print(f\"Average inference time per test sample: {avg_inference_time:.6f} seconds\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "16943a1e",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_test_forecasts = df_forecasts[df_forecasts['source_t'] >= test_start_time]\n",
    "\n",
    "df_agg = df_test_forecasts.groupby('source_t').agg({\n",
    "    'actual': 'mean',\n",
    "    'prediction': 'mean'\n",
    "}).dropna().reset_index()\n",
    "\n",
    "train_actuals = df_forecasts[df_forecasts['source_t'] < test_start_time]['actual']\n",
    "scaler = MinMaxScaler()\n",
    "scaler.fit(train_actuals.values.reshape(-1, 1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "a2f5ad5c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Scaled RMSE: 0.0269\n",
      "Scaled MAE: 0.0189\n"
     ]
    }
   ],
   "source": [
    "actual_scaled = scaler.transform(df_test_forecasts['actual'].values.reshape(-1, 1)).flatten()\n",
    "pred_scaled = scaler.transform(df_test_forecasts['prediction'].values.reshape(-1, 1)).flatten()\n",
    "\n",
    "rmse = np.sqrt(mean_squared_error(actual_scaled, pred_scaled))\n",
    "mae = mean_absolute_error(actual_scaled, pred_scaled)\n",
    "\n",
    "print(f\"Scaled RMSE: {rmse:.4f}\")\n",
    "print(f\"Scaled MAE: {mae:.4f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "0c111f4a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAJOCAYAAACqS2TfAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAA05ZJREFUeJzs3QWYVGXbB/D/mdwOWLq7URAULAxAxc5XRcV+jdd8bT8DUTFeuwO7uyhpBEEaBOnuZbt3J8533c+Zmd3ZYnvq/7uu4cycqWdnhtm9z30/96Ppuq6DiIiIiIiIiBqcqeEfkoiIiIiIiIgEg24iIiIiIiKiRsKgm4iIiIiIiKiRMOgmIiIiIiIiaiQMuomIiIiIiIgaCYNuIiIiIiIiokbCoJuIiIiIiIiokTDoJiIiIiIiImokDLqJiIiIiIiIGgmDbiIiCpiPPvoImqZhx44dAXn+q6++Gp07dw7IcwcjeS3kNSEiIqKGw6CbiIjq7c0331TB8zHHHINgs2/fPjz++ONYtWoVgoUEtvJ6eU92ux09e/bEo48+iqKiokAPL2hfp7KnadOmIdgE42eNiIgCzxLoARARUej7/PPPVZZ0yZIl2LJlC7p3745gCoTGjx+vxnfkkUf6Xffee+/B7XYHZFwSaL///vvqfHZ2Nn7++WdMmDABW7duVa8nVXydyjriiCMQbKr7rBERUeRi0E1ERPWyfft2/Pnnn/jhhx/w73//WwWMjz32GEKB1WoN2HNbLBZcccUVvsu33HILjj32WHz55Zd48cUX0apVq4CNLZiUf50aUkFBAWJiYhrlsYmIiLxYXk5ERPUiQXZycjLOPPNMXHTRRVVmadetW4dTTjkF0dHRaN++PZ588slKs8yS8ZXHatu2rcpyduvWTWWAXS6X3+1OOukk9O/fH8uXL1fBqjxuly5d8Pbbb/tuM3fuXAwdOlSdv+aaa3ylyTKXvPycbofDgWbNmqnblZeTk4OoqCjcc889vn3FxcXq4IJk9WWcHTp0wH333af214WM6/jjj4eu69i2bZtv/86dO1VA3qtXL/UzNm/eHBdffHGFefDe+fELFy7E3XffjRYtWiA2Nhbnn38+Dh065HdbeQ55/eV9kKDz5JNPVu9PZWQs8nzy2shthw0bhsmTJ/vdRl5nee5vvvlGZXrbtWuH+Ph49XmQLL68JnfeeSdatmyJuLg49RrX9XWqanpDv3791Psgn5tbb70VWVlZVX5eTjzxRPWzPPTQQ7V6L2fMmKHeo6SkJPVzyHvifYzDfdaIiChyMdNNRET1IkH2BRdcAJvNhssuuwxvvfUWli5d6gtAxIEDB1Rg53Q68cADD6hg8N1331VBZHkSpEhAI4GjbGfPnq3mOkvg+/zzz/vdNjMzE2PGjMEll1yinluCvptvvlmN5dprr0WfPn3wxBNPqPvfeOONOOGEE9T9JEivLOstAapk7N955x31GF4//fSTCsAuvfRSdVkOFpxzzjlYsGCBelx5nr///hsvvfQSNm3apG5fF95AWg5ieMlrKZUE8twSJMtt5DWWIPKff/6pkKm97bbb1P0liJTbvvzyy/jPf/6Dr7/+2ncbeT0k6JbXTk4rVqzA6NGjUVJS4vdYBw8eVK+VZIRvv/12FfB//PHH6mf/7rvv1OtV1sSJE9V7Ku+xTDN47bXX1OtqMpnUeyXznRcvXqzeYzlAIuOoibS0NL/L8piJiYnqvDymBPojR45U7/3GjRt9n0E5AFG2miE9PR1nnHGGei0ley7VBDV9L+WgxFlnnYWBAweqz5QE5/IzynOI2nzWiIgowuhERER1tGzZMl1+lcyYMUNddrvdevv27fU77rjD73Z33nmnut1ff/3l25eamqonJiaq/du3b/ftLygoqPA8//73v/WYmBi9qKjIt2/EiBHqvi+88IJvX3FxsX7kkUfqLVu21EtKStS+pUuXqtt9+OGHFR533LhxeqdOnXyXp0+frm7766+/+t1uzJgxeteuXX2XP/30U91kMul//PGH3+3efvttdf+FCxdW+7rJ88bGxuqHDh1Spy1btuj/+9//dE3T9P79+6vXsbrXY9GiRep5PvnkE98++flk38iRI/3uf9ddd+lms1nPysryve42m00/88wz/W730EMPqfvL2Mq/b2V/ztzcXL1Lly56586ddZfLpfbNmTNH3U7G7n3dxWWXXaZ+pjPOOMNv/MOHD/d73at7neRxy5/kvS/7s4wePdo3FvH666+r233wwQcVPi/yHpVV0/fypZdeUpfl/apKdZ81IiKKXCwvJyKiemW5JVsoWWwh5bT/+te/8NVXX/mVg0+ZMkWVJR999NG+fVL+PHbs2AqPWTb7nZubq7KckjWUbOuGDRsqzPeVeeRekp2Wy6mp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3bu30vWx5XY9evSo9PFmzJjhe6zvvvvO77q///4bF110ETp16oSoqCj1PKNGjcJrr73md7vOnTv7jans6fTTT6/zz5qVlYUbb7wRLVq0QGxsLE4++WSsWLGixvdfv369ev64uDg0a9YMV155JQ4dOuR3mw0bNuC+++7DkUceifj4eLRp0wZnnnkmli1bVuXjfv311xg+fLgaU1JSEo499ljMnj3b7zYHDx7ENddcg5YtWyI6OhqDBw/Gt99+i/rwvqbXX399pdc//PDDvtvImuiVueSSS9T1999/f6XXz507t8r3Uk5fffVVncf/559/4vjjj0dMTAxat26N22+/HXl5eTW+/6RJk9CnTx/1WZTPc/nPodi4cSPuuusu9Z7I7WTMO3bsqPTxioqKMHHiRPTt21eNST7fF198MdatW1fp/xPv2JOTk9X/i6oel4iIQpsl0AMgIqLg8MQTT6BLly4qcFi8eLEKxhcsWIC1a9eqYKMsubxlyxYsWbIERx99tN91n3/+ubpeHqd8gCRBbseOHXHDDTeoIGn37t3quV555RXcdtttfreXoPW///1vhXG2bdu2Tj+f2+1Wwe/q1atx7733IiUlBW+++aY6iLB8+fIqDyJ47dmzByeeeCISExPx9NNPq+Duf//7nzqQIK+DzWZTt3v//fdVMHfhhRfilltuQXZ2Nt555x0MGzYM06ZNw8iRI/0e9/HHH1evvQRdcqDD4XCo17zsAY+cnBwVoEngfccdd6jX7ptvvlEBr7zel19+OepK3qvvv/9evRben8Hryy+/rPS9LDuuX3/9VR0kkds+88wzKiitjATEQ4cOrbBfDjbUxapVq3DqqaeqoPnFF19U74+8H5s3b8bUqVMPe395T2666Sb1Pt199934448/1BgLCgr8DiAsWrQIr776qgqk5bnkeasyduxY/PLLL+rzLQdF9u3bhzfeeEP9jPI5kYNN4rfffsO5556rbiOvmbyO8n9A3uOVK1eqg0JERBRGpHs5ERFFrg8//FBWsdCXLl3qt//+++9X+7/++mu//SNGjND79eun9+rVS7/zzjv9rissLNQTEhL0Cy+8UN3322+/9V03ZswYvUWLFnpmZmaFMRw8eNDvcqdOnfQzzzxTb0jyc5QfU2pqqp6UlKRfdtllh73/zTffrEdHR+s7d+707ZsxY4Z6zHfeece3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HM7pbmRHZU9HimUNonMuBNAr0MMhIiIiIiKiJsRMdyM7In0qbrP8hOS8LYEeChERERERETUxBt2NzG2OMs44igI9FCIiIiIiImpiDLobmdtiBN0mF4NuIiIiIiKiSMOgu4ky3ZqzMNBDISIiIiIioibGoLuxWaLVxuxkppuIiIiIiCjSMOhuZLqV5eVERERERBT8rr76apx33nm+yyeddBLuvPPOJh/H3LlzoWkasrKyEA4YdDcyzRqjtgy6iYiIiIiorsGwBKFystls6N69O5544gk4nc5Gfd4ffvgBEyZMiMhAuSFxne5GZosygm44OKebiIiIiIjq5vTTT8eHH36I4uJiTJkyBbfeeiusVisefPBBv9uVlJSowLwhNGvWrEEeJ9Ix093IbFGxaqsx001ERERERHVkt9vRunVrdOrUCTfffDNGjhyJX375xVcS/tRTT6Ft27bo1auXuv3u3btxySWXICkpSQXP5557Lnbs2OF7PJfLhbvvvltd37x5c9x3333Qdd3vOcuXl0vAf//996NDhw5qPJJxnzRpknrck08+Wd0mOTlZZbxlXMLtdmPixIno0qULoqOjccQRR+C7777zex45iNCzZ091vTxO2XGGA2a6G5k92gi6TWykRkREREQUXCTIdBQE5rllGqqm1fnuEqCmp6er87NmzUJCQgJmzJihLjscDpx22mkYPnw4/vjjD1gsFjz55JMqW75mzRqVCX/hhRfw0Ucf4YMPPkCfPn3U5R9//BGnnHJKlc951VVXYdGiRXj11VdV8Lx9+3akpaWpIPz777/HhRdeiI0bN6qxyPjExIkT8dlnn+Htt99Gjx49MH/+fFxxxRVo0aIFRowYoQ4OXHDBBSpzf+ONN2LZsmX473//i3DCoLuRRccYQbdNL0GRw4UoqznQQyIiIiIiIiEB99NtA/PcD+0DbEasUBuSjZYge/r06bjttttw6NAhxMbG4v333/eVlUuQKxlm2SdZZyGl6ZLVlrnXo0ePxssvv6xK0yXgFRIUy2NWZdOmTfjmm29UYC9ZdtG1a9cKpegtW7ZUz+PNjD/99NOYOXOmOgDgvc+CBQvwzjvvqKD7rbfeQrdu3VTQLyRT//fff+PZZ59FuGDQ3USZ7iitBDlFDgbdRERERERUa7/99hvi4uJUFlsC6ssvvxyPP/64yhAPGDDAbx736tWr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0E1ERERERBQpAp7pjhi+JcMk6GZ5ORERERERUSRg0N1U7EbXvDhmuomIiIiIiCIGg+4mn9NdwEw3ERERERFRhGDQ3eSZ7iLkFZauNU5EREREREThi0F3E2e6haMwL6BDISIiIiIioqbBoLupWKPgNhmLtLuKsgM9GiIiIiIiImoCDLqbkMvmyXYX5QR6KERERERERNQEGHQ3JW/QXZIb6JEQERERERFRE2DQHYB53eaSPLjdeqBHQ0RERERERI2MQXcTMkUnqm0cCpFfwrW6iYiIiIiIwh2D7iZkivKs1a3JWt0MuomIiIiIiMIdg+4mpHnX6kYhsgsdgR4OERERERERNTIG3QGY0x2vFWJ/dmGgR0NERERERESNjEF3U4oqzXSzvJyIiIiIiCj8MegORKYbnNNNREREREQUCRh0NyXvnG6tEHnFDLqJiIiIiIjCHYPuAGS61ZJhDLqJiIiIiIjCHoPuAGS6pZEay8uJiIiIiIjCH4PuAM3pZnk5ERERERFR+GPQHYjyco3l5URERERERJGAQXeA5nQz001ERERERBT+GHQHpHt5EfILiwM9GiIiIiIiImpkDLqbUpQRdAtXcW5Ah0JERERERESNj0F3U7LY4TbZ1FmNQTcREREREVHYY9DdxHRbnNoy6CYiIiIiIgp/DLoD1EzN5MiD260HejRERERERETUiBh0NzEtKtG3VneBwxXo4RAREREREVEjYtDdxLSo0mXDCrhsGBERERERUVhj0N3ENN+yYYXIL2Gmm4iIiIiIKJwx6A7QnG6V6S5hppuIiIiIiCicMegO0Frd8VoBCpjpJiIiIiIiCmsMugOU6Y5HIfI5p5uIiIiIiCisMegOYHl5ITPdREREREREYY1Bd1Ozl5aXs5EaERERERFReGPQHaCgOxZFbKRGREREREQU5hh0B6i8PIGN1IiIiIiIiMIeg+5ALhnGRmpERERERERhjUF3oIJurZBzuomIiIiIiMIcg+4ArdMtme68Ima6iYiIiIiIwhmD7gA1UovTipBXVBTo0RAREREREVEjYtAdoPJy4SrKC+hQiIiIiIiIqHEx6G5qFjtcJqs6q5XkBno0RERERERE1IgYdAeAyxqnthYG3URERERERGGNQXcAuD1Bt1aSH+ihEBERERERUSNi0B0AujVWbU1OBt1EREREREThjEF3AOg2I9NtZdBNREREREQU1hh0B4BmNzLdZmcBdF0P9HCIiIiIiIiokTDoDgBbtLFWt8VViOxCR6CHQ0RERERERI2EQXcAmKOMtbrjUIg9mYWBHg4RERERERE1EgbdgWAzystjtCJmuomIiIiIiMIYg+5AsBuN1GJRjNwiZ6BHQ0RERERERI2EQXcgM90oQm4RM91EREREREThikF3IHiWDIvTCpFXzEw3ERERERFRuGLQHdBMN8vLiYiIiIiIwlnAg+69e/fiiiuuQPPmzREdHY0BAwZg2bJliIRMd6zG8nIiIiIiIqJwZgnkk2dmZuK4447DySefjKlTp6JFixbYvHkzkpOTERFBN1heTkREREREFM4CGnQ/++yz6NChAz788EPfvi5duiCSystzWF5OREREREQUtgIadP/yyy847bTTcPHFF2PevHlo164dbrnlFtxwww2V3r64uFidvHJyctTW4XCoU8gwR8HqLS8vLAmtsYcY72vL15iIKPzxO5+IKLI4qvjeD7bfA5qu63qgnjwqKkpt7777bhV4L126FHfccQfefvttjBs3rsLtH3/8cYwfP77C/i+++AIxMTEIFbFFBzBy/X3I1aNxtvV93DXAFeghERERERERhYWCggJcfvnlyM7ORkJCQmQH3TabDUOGDMGff/7p23f77ber4HvRokU1ynRLeXpaWlpQvJg1lnsA1lf7w61rGB3/I6becXygRxS25CjXjBkzMGrUKFitUl9AREThit/5RESRxVHF977EiSkpKUETdAe0vLxNmzbo27ev374+ffrg+++/r/T2drtdncqTFzikfrnGGo3iTJoOt6MotMYeokLuM0JERHXG73wiosj+3rcG2e+AgC4ZJp3LN27c6Ldv06ZN6NSpE8KatbQU3uTID+hQiIiIiIiIKEyD7rvuuguLFy/G008/jS1btqi52e+++y5uvfVWhDWTCW5P4G1y5AV6NERERERERBSOQffQoUPx448/4ssvv0T//v0xYcIEvPzyyxg7dizCne5Zq9vqzEcAp9UTERERERFRuM7pFmeddZY6RZz4NkB+KjppB1DsdCPKag70iIiIiIiIiCicMt2RTEtop7ZJWj4KS7hkGBERERERUThi0B0gpuhEtY1DAQocDLqJiIiIiIjCEYPuQLEb68XFa4XMdBMREREREYUpBt2BYo9Xm3gUoIiZbiIi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QYMGYenSper8iBEj8Oijj+Lzzz/HnXfeif79+9drMFJqvnXrVrRp0waRwmIzGqnZdGegh0JERERERESBDrqffvppX1D81FNPITk5GTfffDMOHTqEd999t1aPdc8996gu6Dt27MCff/6J888/H2azGZdddhkihdkWrbY2BNdkfyIiIiIiImri8nKZ/i0l5d6MtpyfNm1anZ98z549KsBOT09HixYtcPzxx2Px4sXqfKSwWI1yeZvmhNvlhslc6+MgREREREREFC5Bd/fu3bFu3Tr06NGj3k/+1VdfIdJZ7EamWzgcRbCbQ7MLOxEREREREVVUq7SqNFCTYFsy09QwbHZjTrdwlBQFdCxERERERETUsGpdy/zMM8/g3nvvVWtpU/1ZPY3UhLOoMKBjISIiIiIiogAvGXbVVVepxcaPOOII2Gw2REeXlkeLjIyMhhxf2JPGcSW6GTbNBaeDmW4iIiIiIqKIDrpfeuklaJrWOKOJUCWwwYZCOB3FgR4KERERERERBTLovvrqqxvy+UkF3cbb4CpmppuIiIiIiCii53RLOXRqamqF/dJcTa6j2nNoVrV1sbyciIiIiIgosoNuWTasMsXFxWqON9WeA0bQzTndREREREREEVpe/uqrr6qtzOd+//33ERcX57vO5XJh/vz56N27d+OMMhIy3Trg5pJhREREREREkRl0SwM1b6b77bff9isllwx3586d1X6qPacn6HaxkRoREREREVFkBt3bt29X25NPPhk//PADkpOTG3NcEcWhGWX5bpaXExERERERRXb38jlz5jTOSCI90y1Bt5OZbiIiIiIioogLuu+++25MmDABsbGx6nx1XnzxxYYaW8RweTLdOsvLiYiIiIiIIi/oXrlyJRwOh+98VaTJGtWey8RMNxERERERUcQG3WVLylle3vBcJs9Sa07O6SYiIiIiIoroOd3U8Jze8nJnSaCHQkREVC9/78nG2a8vUOevPa4LHj27b6CHREREFFCm2txYstwvvPACFi5cqC6/88476NixI1q0aIEbbrgBhYWFjTXOsOb2ZbpZXk5ERKHt7m9W+c5/sHA73G49oOMhIiIKmaD7vffew6hRo9Ra3KeeeiomTpyI//73vzjzzDNxySWX4JtvvsH48eMbd7Rhym32BN0uBt1ERBS6CktcyMj3r9patjMzYOMhIiIKqaD7lVdewUsvvYTNmzfjp59+wqOPPoo33ngDb731ltq+//77+O677xp3tGGKmW4iIgoHr8/ZjPT8EiTHWJESZ1f7sgo4dYqIiCJbjYPubdu24ZxzzlHnTz/9dNWp/Oijj/Zdf8wxx2D37t2NM8qIyXTzDxMiIgpda/Zkq+1tp/RAr9Zx6nx+iTPAoyIiIgqRoLuoqAjR0dG+y3a7XZ3KXnY6+Yu1LnRPpltjppuIiELYgWxjFY6ereIRazN6teYVuwI7KCIiolDpXi6Z7dzcXERFRUHXdXU5Ly8POTk56nrvlmpPNxsHL0xuZrqJiCh07fcE3W2SohBnN/7EyC/mAXkiIopsNQ66JdDu2bOn3+VBgwb5XZZAnGpP95SXa2ykRkREISq3yIE8T4DdOiEKsQy6iYiIahd0y3Jh1EgsRqZbczkCPRIiIqJ6lZYnRFlUwF3idKvLH/25A/8d3SvAoyMiIgqBoHvEiBGNO5JI5gm6WV5OREShap8n6G6bFA04ijBt3QF1ObeImW4iIopsNW6kRo3IU17OoJuIiELVgexCtb1F/wp4qhVmtnkLVhgB98EcIyAnIiKKRAy6gyjTbXZzTjcREYWmfVlF6KXtwjnZn6vLLfbNxgzbver86t1ZAR4dERFR4DDoDgaWKLUxuzmnm4iIQndO9znmP/32dTYdRAtk+hqsERERRSIG3UHAZDHKy80sLyciohC1L7sQbbQM48JJD/n2n2j6G9mFPKhMRESRq9ZBd3VdzN944436jiciaZ7ycovOP0qIiCh0M90dtVTjQoueQOsB6mySlsegm4iIIlqtg+4LLrgAy5cvr7D/lVdewYMPPthQ44ooJqu3vJyZbiIiCk37s4vQwRt0J3cGOgxTZxMZdBMRUYSrddD9/PPP44wzzsCGDRt8+1544QU8+uijmDx5ckOPLyJoViPTrTvZSI2IiEJPbpEDjuICtNI8DdOSOgHRyepsIvIZdBMRUUSr8TrdXtdffz0yMjIwcuRILFiwAF9//TWefvppTJkyBccdd1zjjDLM7cl2qa0N/KOEiIhCs7S8m7bPuBCVaATc0UnqYi/THswv4O83IiKKXLUOusV9992H9PR0DBkyBC6XC9OnT8ewYUYZGdXe8N5tgRVG0F3kcCHKag70kIiIiGpsX3YROmkHjQst+gCaBriMKVPDTOvxYn5+YAdIREQU7EH3q6++WmFfu3btEBMTgxNPPBFLlixRJ3H77bc3/CjDXPsUIxtggxOFLjeDbiIiCil7MwvRwltaHt/K2PY9F5j5uDrbO2OWtDQP4AiJiIiCPOh+6aWXKt1vNpuxcOFCdRKapjHorgOrLdrYai7kOJxAlDXQQyIiIqqxvVkFaKFlGxfiPEF3s65wJnWBJWs7mpfsg67r6u8EIiKiSFOjoHv79u2NP5IIZrLHwaVrMGs6XDkHgfjOgR4SERFRje3LKsIx8GS6Y1v69rsHXAL88Sxa6OkoKHEh1l6nWW1ERESR1b2cGoE1ChlIUGfdeYcCPRoiIqJaScsrLpPpLg26rUnt1LaNloEsdjAnIqIIVetDztI47aOPPsKsWbOQmpoKt9vtd/3s2bMbcnwRo0Szqa2zpCDQQyEiIqqVzIKS0jnd3vJymXaWaATdrSXoLihBuyRjOhUREVEkqXXQfccdd6ig+8wzz0T//v05P6uBFMNYq9tVXBjooRAREdVKVoGj0kw3Etr7Mt1r85npJiKiyFTroPurr77CN998gzFjxjTOiCI5060Dbgcz3UREFFoy84uQUr6RmkhoqzZJWj627UtF37YJWLcvG8d3T+FBeyIiihi1ntNts9nQvXv3xhlNBCvRjEy3u4SZbiIiCh2Z+SWILslSK3DomgmIbVF6ZVQCis2x6uzenVsw7oMluHLSEvy8al/gBkxERBTsQfd///tfvPLKK2rpD2qMoLso0EMhIiKqsU0Hc9FBSzUuxLcFLEaPEi9nbGu1/XvDevy918iG3/n1qqYfKBERUaiUly9YsABz5szB1KlT0a9fP1it/mtK//DDDw05vojhMNkBF6CzvJyIiELI/uwitNeMlTe05E4Vrrc16wDkbEUbZPjtn7b2AE7vbwTkRERE4azWQXdSUhLOP//8xhlNBHNK0A1AZ6abiIhCyPa0fLTX0owLSR0rXG9N8jZTS/fbf9Nny/HG5YNx5sA2TTNQIiKiUAm6P/zww8YZSYTzBt1wMtNNREShY0d6PoZ4g+5EI8D2k2L0gelr2qkqusp6avI/DLqJiCjs1XpONzVyptvBRmpERBQ6dqQXqHW4lQRjXW4/bY5QmzHmJdhgH4dl9ptwlLZR7csqdLBHDBERhb0aZboHDx6MWbNmITk5GYMGDap2mY8VK1Y05PgiLujWnCwvJyKi0LEjLR9tvaXjniXC/LQ50nc2SnMgCg58bx+PbiVfoKDEhQM5RWiTGN2EIyYiIgrCoPvcc8+F3W4Eheedd15jjykiuc1Rasugm4iIQmm5sOzCEnSwe7qXJ3eueKOYZsBZLwO/3em3+/nYz3F37lhs2J/LoJuIiMJajYLuxx57rNLz1HBcDLqJiCjEbE/PRzJykaB5pkYlVexergy5Bti/Glhe2hfmAsdkHLCYsWRHN5zcu2UTjZiIiKjpcU53kHCbWV5OREShV1reqewa3VbjAHKlTn20wq5bLL9gzY4DjThCIiKiEMl0y1zu6uZxl5WR4b8OJ9WMy2yU1plcDLqJiCj47csqxN3frMY5poPGjmZdqr+DlJn3OQcozATOfR14xWiw5k7bAuCkJhgxERFREAfdL7/8cuOPJMK5LUZ2wOQqDvRQiIiIDuvteVvVtqM30518mKBb/OtT31ln26Gw7FuK5gU7UFDiRIyt1quYEhERhYQa/YYbN25c448k0nmCbjMz3UREFAJyi5xq20k7WHUTtWpYWvUG9i1FD9Me7MooQO/WCY0xTCIiotCc0+12u7Fp0yYsWLAA8+fP9zvV1TPPPKNK2O+807+7aaTQGXQTEVEIsZiMaWcdTak1Ky8vr2Vftemt7caOtIIGHx8REVGwqHUt1+LFi3H55Zdj586d0HXd7zoJml0uV60HsXTpUrzzzjsYOHAgIhaDbiIiCsFMd63Ky8tqZQTdPbXdmJGR3+DjIyIiCtlM90033YQhQ4Zg7dq1qmlaZmam71SXJmp5eXkYO3Ys3nvvPdWwLVLpVqORmsXNOd1ERBT8DuUVw44StNEy6pjp7qc20v18X2p6lTfr88g0dH5gMr74a1e9xktERBQyQffmzZvx9NNPo0+fPkhKSkJiYqLfqbZuvfVWnHnmmRg5ciQimifTzaCbiIhCwZ7MAnTwZrntCUB0LQ+cx7VAka0ZTJoOd+qGSm+SX+xEocOooHvox7+RmstqMCIiioDy8mOOOQZbtmxB9+7d6/3kX331FVasWKHKy2uiuLhYnbxycnLU1uFwqFNI86zTLUF3yP8sQcT7WvI1JSJqOPuzi3AwpxgDzEbQrSd1gtNplJvXRlFyT0QdXIy47E2Vfk//vTvT7/InC7fjjlOr/vuD3/lERJHFUcX3frD9Hqh10H3bbbfhv//9Lw4cOIABAwbAarX6XV/Tedm7d+/GHXfcgRkzZiAqysjyHs7EiRMxfvz4Cvt///13xMTEIJRt3mOU1lncRZgyZUqghxN25HNGREQNY12mNFEzo5c1TV0+UGTDkjr87upZHIMkSXrn78LkyVOgGb3ZfObt19BZS1Ul7Ivc/fDRgq3oUbzpsI/L73wiosgyo9z3fkFBcDXo1PTy3dAOw2SqWJEuDdTkYWrTSO2nn37C+eefD7PZ7Nsn95XHkOeQjHbZ66rKdHfo0AFpaWlISAjtpUZ+WrAGF887RZ13PHRIXtRADyksyFEu+U84atSoCgeIiIiobj78cyeenroBa2NuQpw7F64hN8B92sRaP47+52uwzRmPX13DMPiu79Ey3qj68nphxmb856+TEacV4VnHpXjLdQ4W3T8CKXH+t/Pidz4RUWRxVPG9L3FiSkoKsrOzgyJOrHWme/v27Q3yxKeeeir+/vtvv33XXHMNevfujfvvv79CwC3sdrs6lScvcKj/crVEx/rOWzUX4GmsRg0jHD4jRETBYldmIY7WNqiAW5iTO8Bcl+/Ylj3URuaGH8h1oF2zOL+r9+zepgJucb/1K8RrBdibPRxtkv1vVx6/84mIIou13Pd+sP0OqHXQ3alTpwZ54vj4ePTv399vX2xsLJo3b15hfyQw28oE2Y5CBt1ERBS0ZF3tVlqZ+damWv854bfMmHQw/z01F0d1Km3G5nbrSNk3DyhT+HWL5Rf8nDkRQzo3q/vgiYiIgr17eceOHXHVVVdh0qRJ2Lp1a+OMKgJZrTY4dHNp0E1ERBSktqflw4Iy08k6HFO3B0o2DuQna3nYe+CA31W7MwvQx2XM33YP+49vf9Ge1XV7LiIiolAJumW5MGl89uyzz6JHjx5qTvUVV1yh1tmW5cTqY+7cuXj55ZcRiaxmE4pgMy44uSQKEREFpyKHC/uyC5Gk5Rk7YpoD7YfU7cHs8cizGNntbZvW+V21fn8OepmMtblNHYZiV8JRxl0OrqzX+ImIiJparevBJMCWk9i/fz/mzZuH3377DbfccgvcbneNG6mRP7tVgm4r4lHITDcREQWtXRkFkBasHazZxo4BF9fr8fKi2yMuNxOudP+eMev3ZeNEba9xoVU/5DQbAOQsR1LO4buXExERBZM6TcKSFuwLFixQmek5c+Zg5cqVah72SSed1PAjjBBRVjOKmekmIqIgt+1Qvtr2sx0ASgA0r3rd7JqwtugG5P6NTtpBOFxuVfklig5uQYxWDKfJDktyF7hl/vcOIL54f4P8HEREREEbdB977LEqyO7Tp48Ksh944AGceOKJSE4ubX5CtRdlMaNItxkNY5jpJiKiILUjXYJuHX09863RekC9Hq9Z+57ANqCjloo9mYXokmKs5hGduV5tcxO6I9lsgSW5vbG/8KBvmVIiIqKwnNO9YcMG1WVclvaSkwTfDLjrL9pmQiEz3UREFOQO5RajvXYI8a4sWXoDaDuoXo+nNTM6mHfUDnoCeqig2nVwgzrvaN5bbdt06Kq2rbQMbD3kmU9OREQUjkF3eno6Zs+ejWHDhmH69Ok47rjj0K5dO1x++eWqmRrVjV0y3d6gm5luIiIKUlkFDnTX9hkXpLTcYq/fAzYzgunjzetwMNNY9/uzxTvR1WSUkce0MYLu5FadjafUcrF7/6H6PScREVEwB91SzjVw4EDcfvvt+O677zB16lSMGjUK3377LW666abGGWWEzOlW5eVyhJ9BNxERBansQge6aJ551c271f8BWw/0nXUfWKu2v/9zEEdqW9T5uPb9jSujS6vqHFvn1v95iYiIgjXoXrFiBV588UWcc845aN68OYYPH441a9bgtttuww8//NA4o4wA0bbSTLez2CivIyIiCjY5hQ700PYYF1J61f8BbTHYmTRMnbUeNNbgtmVuRhfTQeP61p6gW9NQaElUZxcuX6WCfyIiorBspHb00Udj0KBBGDFiBG644QbVRC0x0fglSHUXYzXDoRlBd15eHjhLnoiIgpEEu71MnqC7Vd+GedAWPYGsxdAytiO7wIHOmYsAq+e6xA6+m6X1uAQd1r+nMu0vz9yEx87u1zDPT0REFExBd0ZGBhISEhpnNBHMZNLgssQCbqC4wJjTRkREFGyyCorR05vpbtkwQXd0ShdgM5BQvB8rd2ein2mHccXJD6sMt1f73kOA9e/hasvveKDkkQZ5biIioqALur0B9/Lly7F+vbGcR9++fTF48OCGH12EKTHHqKDbVcSgm4iIgo/T5YYr7xDi7YV+TdDqK7aV0cG8pfsg/tiTjdO17cYVbY70u53WfqjvfOu90wGUzgcnIiIKmzndqampOPnkkzF06FDVTE1OQ4YMwamnnopDh9hNtD6clhi1dRdzKRQiIgo++SUutEWaOq/Hta5/53KPmNY91Labth/TVm5BN2939DZH+N8w2ehgLoZmTUNj2Zmej7Ne+wMbDuQ02nMQEVHkqHXQLQ3TZM7xunXrVKm5nNauXYucnBwVgFPdOaW8XDDoJiKiIFRY4kI7zQi6taTSudb1paX0hEM3I14rRLeMBTBpOoqjWgLxrfxvaDIj5/j/U2fznYDLraOhFTlcGPH8XKzdm4PTX/6jwR+fiIgiT62D7mnTpuHNN99Enz59fPukvPyNN95Qy4dR3elWT9BdwqCbiIiCT0GJEy20LONCfOuGe2CLDXs04/HONv+ptlrbclluj9hOR6ltV+zDgZwiNLSvluzyuyyN3YiIiJo06Ha73bBavS1FS8k+uY7qzmWLU1vNwSXDiIgo+BSUuJCI/ArrZjeEuHZGU7ZR5hVqa2s/qNLbmVv2VNtO2kHsSctGQ9t40OirEocCORyOJTsyGvw5iIgostQ66D7llFNwxx13YN8+z3wrAHv37sVdd92l5nVT3bmtRtBtcTDTTUREwafQ4UKi5gm6o5Ia9LGbtevuv6PjMZXfML4tijQ7rJoL0xcuwbxNDdtPZl9WES42z8XaqOuxI2os9mRK8E1ERNSEQffrr7+u5m937twZ3bp1U6cuXbqofa+99lo9hkJuW7zaWpwMuomIKNgz3Q0bdJuPusp/R7cqDuSbTMiOMRqq7dq4CuM+WIK0vOIGG8f+7EI8b33Xdznj4N4Ge2wiIopMtV4yrEOHDlixYgVmzpyJDRs2qH0yv3vkyJGNMb7IYjeCbquT5eVERBR8CkucjZbpRqtya36XWZ+7PFNKDyB/I7po+33dxlPi7A2yJJqWtgUoM4sua/m3wAXH1/uxiYgoctU60y00TcOoUaNUJ3M5MeBu2KDb7uQ63UREFKSZbq1xMt3KUVcb207VB7kprY3O6Q9bv1DbnekNUwK+M6MAnXX/RmrDTP/gxd83NsjjExFRZKpV0C2N0j744AOcddZZ6N+/PwYMGIBzzjkHn3zyCXS94ZftiDS6pylNlLsAcLFbKhERBV/QndBIjdSUM54DznkduPSzam+mNeviO3+KaQV2pDVMhdjujAK00jKNC54VRc40L8FHs1fB3QjLkxERUWSocdAtQbUE2Ndff71qnCYBd79+/bBz505cffXVOP/88xt3pBHAFJ0Et+4ppyv0/NInIiIKErlFjVheLix2YPCVhw/ovRlxAB/Y/gfT7kUN8vR7MgvR2ht09xzt2/+I5TO8NW9rgzwHERFFnhoH3R999BHmz5+PWbNmYeXKlfjyyy/x1VdfYfXq1Wp+9+zZs1XGm+ouymZDNjxrdRdwiRIiIgouuUWORmukVuvgvE3pOt5J6cYyYw0RdPsy3fL4pz2tzl5smY/z5o7Ge2+/gMVzJzfIcxERUeSocdAtQfZDDz2Ek08+udJlxB544AF8/vnnDT2+iBIfZUGmbiwbhkIG3UREFFzyCwoQqxU3Xqa7Nvpf6DurF+Y0yEPuzixAS3iC7vg2wLBbsD/BCO7baem44cATGDb3cjizSpdNJSIiarCge82aNTj99NOrvP6MM85QWW+qu4RoKzJhNFND3sFAD4eIiMiPq6DM1KeoxEAORQXE7pgW6mx75y7Veby+NuzPKS0vl6Bb05B42gMVbpc9l0ukEhFRIwTdGRkZaNWqVZXXy3WZmZyHXB+J0Vbs15sbF769ms3UiIgoKIPuEks8YDIHdjBmK3Dh++psX9MOpOeX1OvhpFGadEFvVTboBhDTYwRKUvr73da1niXmRETUCEG3y+WCxVL1st5msxlOp7MWT02VBd1+svcEaihEREQVmAqz1NZpD3BpuYepeTe1bYEspGYX1uuxJGi3uguRoHmWH4tvbWxtsbD9ZyHmn7cYv7mOUbuaFe8BXPybh4iIaqbqKLqS7uXSpdxut1d6fXGxZ44X1VlClAXz3ANxlnmxsaPI+OOGiIgoGJiLjSywK0iCbm9gbNNcyEzbD7TuUeeHOphTVJrltsUBUQl+1594ZB8sTfwCxR/1hl1zANm7gTJLlxEREdU70z1u3Di0bNkSiYmJlZ7kuquuuqqmD0dVzOn+wXVC6Q52MCcioiBiLck2zsQ0Q1AwW5FrMoLj/PT6NTfbk1mAVsjyz3KX0zklHjv1lup8yaEt9Xo+IiKKHDXOdH/44YeNOxKC1WwCTBb86eqLY83/cK1uIiIKKvaSLHW4XjvcOtpNqMDaDPHFOSjMql8D0o0H8tBKy/Cbz11eSpwNa7XW6Im9yNq7ES17jarXcxIRUWSocaabmobLrSMTnmXDmOkmIqIgId3Bo9256rwlztP0MwgURaWorTunfpnujQdzKjRRK0/TNOREtVXnC1J31Ov5iIgocjDoDkJZumfZMK7VTUREQSKv2IlkGEG3Nd4IdIOBI6692lpz69d8dMOB3DLLhVVeXi7cccZ1jqz99Xo+IiKKHAy6g5A30+3MSw/0UIiIiJTcIieStHx13hwsc7olCE7qrLZxhXUPuqVZ7J6MwtJMd4KRza6MKcHIgpvzD9T5+YiIKLIw6A4yb19xFDJ1b9CdFujhEBERKdmFDiR5Mt1B00hNMtzNjaA7qaTuQXBWgQMlLneZOd1VZ7qtSUZAHl18qM7PR0REkYVBd5A5vX9r5JmM8nI353QTEVEQZroRRI3UYpsbQXCCK0tlrOtif3aR2rYxebuXV53pjm3ewXg+Bw+MExFRzTDoDkae9U/1Qs/SLERERAGWU+RAkpZnXIgOnkx3YooRIDdHFnKKnHV6jF0ZcjBBR0scfk53q/ZGZj1WzwdKPAchiIiIqsGgOwi5o4ygWyvyHHEnIiIKsOwCh6+RGqKN31PBwJ5kzLFupuUhNdtzUKCWdqYXIAl5sMFx2KC7Q+tWKNDt6nx++t46PR8REUUWBt1ByBSdqLbmkpxAD4WIiEjJyc9DrFYcdHO6Jevu8vw5k51Wt47iO9Lz0U7zNC+NSQEsRlBdmdgoKw5pRnl95sFddXo+IiKKLAy6g5ApxvhlbinJlpaqgR4OERERSnKNoNQtfzrYjYPDQcFkQo7JyLznp9cx6E4rQFfNs8538+6HvX222VinPO/Q7jo9HxERRRYG3UHI4gm6zboTcBQGejhERERweJaxLLbEq0A3mBRYjd+bhdl162C+Mz0fXTVPwJ5y+KA7395CbYszWV5ORESHF1y/NUmxx8TDqXveGs7rJiKiIODON1bUKLEFz3xur2J7itq6clJrfd8ihwv7sovQ1eQJupv3OPzzRbVUWz2nbpl1IiKKLAy6g1BCjA05iDEuFDLoJiKiwNMKjc7eLs8KG8HEJfOwRV7t187enVGgtl1NB2tcXu6OMxqtmfM99yEiIqoGg+4gFB9lQbYea1wo4rJhREQUeKYiI+h2B9Ea3T5xRuY57eCeWt91e5qx7Fcrs6d5abzRDb06pgTjNvai2mfWiYgo8jDoDkLxUVbkwBt0M9NNRESBF1VSprt3sIlrpTYttCy49LoE3TqSdc/v2zhjvnZ1bMnG2uBxJWl1GCwREUUaBt1BmunO0VleTkREwSPBYZRum5LaIdh06tRVbVsgC3mepbZrav3+HCQiH1bdc8dYI2tenZjm7dU22ZXOVUaIiOiwGHQHa9DtndNdzLW6iYgosFxuHc0lwFRZXiPgDCa2JKPcu6WWhXxn7e674UAu2muHSgNua9Rh75PUqpPaRqMIKM6tw4iJiCiSMOgOQglSXu6b082gm4iIAisjvwStNSPojmrWPqjLywtrEXTruo49mYVor3nKxJM61uh+LZol+yrS8jNqP4+ciIgiC4PuYM90c043EREF2MGcIrTWjCXDLElBGHTHG93EE7UCOB3FNb5bTpETecXO0kx3Uoca3S/WbsEhGF3cc1MZdBMRUfUYdAdrIzVPpttdyO7lREQUWHn5+WiheSqvEoJvTjeiEpFrildno2vRUXxvZqHadrNl1irTLfI9z1eS77kvERFRFRh0B3mm21nAX+ZERBRYzuz9alsCKxDTDMEo22I0QLM7al4htjfLCLq7WNJrHXQXmby/pzkNjIiIqsegOwhZzSYUmuPUeXchf5kTEVFgOXON7HGOOQnQNASjYmui2lqcxrrbNbE3s0Bt23nndCfWIuj2/J52FrEijYiIqsegO0i5rEbZms453UREFGCOQqNDd4knuxuMHLYEtbXWJuj2ZLpbuA7WOtPtMBvTwHQeHCciosNg0B2kXJ4/HsAj6EREFGAuT9DtsHhW1ghCLrvR2MzmqnnQLZ3L41GAaFdurRqpiXxbC7U1Ze+s7VCJiCjCMOgOUnqUUSZnLuERdCIiCixXkRGUOi3Bm+k2xSSrrcVVu0y3r7Q8pjlgq/lBBVO7I9Q26tCa2g6ViIgiDIPuIKV5gm5LSa4sJBro4RARUQTTi42g22U15jEHI2usEXRHu/NrvEb3jrT80uXCEmue5Ratuw9S25SSvfw9TUREwRt0v/XWWxg4cCASEhLUafjw4Zg6dWoghxQ0zDFGmZxJd8pkukAPh4iIIllJntroQRx0W+Kaq22MXrOgO6vAodbp9mW6azGfWyS07KS20SgGCrnSCBERBWnQ3b59ezzzzDNYvnw5li1bhlNOOQXnnnsu1q1bh0hni4qHU/e8PWymRkREAWTyBN21Kb9uatY4YymzeN0z1sNYsMUItntFZdQp6E5JTkS6bjQ9dWTuqd1giYgoogQ06D777LMxZswY9OjRAz179sRTTz2FuLg4LF68GJEuPtrqW6ubzdSIiCiQTA4je6zZgzfTbUtur7atkK5Kx6vjduu47cuV6nwHrfZrdKubR1txUDcC/ZxUNlMjIqIQmNPtcrnw1VdfIT8/X5WZR7r4KCuydM8fN4XMdBMRUeCYPctwmaI8K2sEoajk1mqbjFwUO93V3nbl7tJy8LY4VKeg22TSkGU1Ophn7d9e+wETEVHEsAR6AH///bcKsouKilSW+8cff0Tfvn0rvW1xcbE6eeXkGJ29HQ6HOoWTGJuGHBhlfM68Q9DD7OdrKt7PRbh9PoiImpJv7WtbTNB+n9qijV4osVoxdmZnIcpqzPGuzNLtnuw2gM6WNEDap8S2kV8WtXrOwqiWQD5QkLE3aF8XIqJI/FvfEWTfyQEPunv16oVVq1YhOzsb3333HcaNG4d58+ZVGnhPnDgR48ePr7D/999/R0xM8C5jUhfbUzX08GS61/w1H7u3sDNqfcyYMSPQQyAiClnNHXmABmzfcxDrpkxBUNLdOFvXYNJ0zJ81HQnxRhBema/XmqVYHpd0yIf5kJH1/n3JejjNtSsTL3FGq23W7g2YEqyvCxFRBP6tX1BQgGAS8KDbZrOhe/fu6vxRRx2FpUuX4pVXXsE777xT4bYPPvgg7r77br9Md4cOHTB69GjV/TycWP45iOxdRqb7iJ4dMeCYMYEeUkiSo1zyn3DUqFGwWq2BHg4RUUj6Z+WTatt74BC0DuLfR7mrYpGIPAzs3Q19jzim0ttsO5SP7YsWwmzS8N/R3YDPAT0qEaPPvqjWzzcnZwOwFUixFmPYmOB9XYiIIu1v/RxPRXSwCHjQXZ7b7fYrIS/LbrerU3nyAodbQJUcG4XNuhF0m0tyYA6zn6+pheNnhIioqcToBSrTbY9vHtTfpXmmeCS681CSn1npOKXB2vsLjWz2ST1boJVulJlrSR3r9HNFN2uvgu7o4tSgfl1qqsTpxjNTN2BQxyScfUTbQA+HiKjOf+sH23dyQINuyVyfccYZ6NixI3Jzc/HFF19g7ty5mD59OiKdNFLL9szpZiM1IiIKFJdbR7xMXJbqtLhkBLNiSyJQsh+5GZ7maOVc8s4iLN1hlJOPGdAGyFplXJFkrLldW/EtO6htgtOz1neI+/jPHfhg4XZgIRh0ExGFS9CdmpqKq666Cvv370diYiIGDhyoAm4pD4h08VEWZPu6l5d2WSUiImpKhQ4XEmDMjYuON5bIClYltgSgBHDmV/y9+fOqvb6AWwzr1hxYutu4kGgEz7WV0rqz2jbTs6E7S6BZbAhlczel+i2rJh3aiYgoxIPuSZMmBfLpgz/o9mS69cIsqeojIiJqcgWFhWipGdO+bLFVNycLBi6bMT53YYbffofLjTu+WlVaaXdGb7RLigaydtVpuTCvFq3bwKGbYdVcyErdg+S2XRGKXpqxCdmFDizcUtrVfePBXPRuHQ9N418gRERhs043Vb1Ot6vA/48HIiKiplKcV5od1qISEczcnmXDtHLTslbvLr382XXH4N8juhkXfEF33TLddqsV6ZpRcp9+wPNYIeZQbjFembUZH/25w2//Ga/8ge9X7A3YuIiIwgmD7iBls5hQYIrzZbqJiIgCoSjXCLrzEQWYg67/qh8t2giALcX+vzcXbDHmXPdvl4Dje6SUXpGxvV5zukWWxXi8nEOeUvUQc+fXK6u87vFf1jXpWIiIwhWD7iDmtHuP2HNONxERBYazwBN0a57mnkHMHGvMObc6sv32vzxzs9peMqRMRluqyLxl6M3qXhZeaG+htsUZexCKypaUl5dX7GzSsRARhSsG3UHM7Qm6zSXZ0tEk0MMhIqII5CwwAtiCEAi6bfHNjTNlKsQOZBf5zvdpk1B649/uLD1v9zQurQNnbCu1dWXvR6jZnWE0yPN676ohGNnH+HnKLrNGRET1w6A7mHnnpuluoCQ30KMhIqII5CowAthCc90D06aS1KylsdXysD0tX3XgHjZxlu/6wR09S57l7AP++dk43/mEej2nFt9Gbc35B9U2u8CBWz9fobqll2/mdvl7i9H5gcl44feNWLI98P1aHvl5re/84gdPxag+LTEy82tcbJ7r25+RXxKg0RERhY/gnpwV4aKiY1Go2xCtlRjLhgV5AxsiIgrfoLvIHI9gl+gNupGHLWl5uPjtRX7Xm2UJrLxDwIt9Snde/k29ntOW3E5to4pSMeaVP/DP/hx1efLf+7FsRyYmnNdfXX599hb8udUo5X5t9hZ1untUT9x+ag80pTV7shBrt6BTsxjM3WisZ/7QmN5onRgF7F6KS7PexaVW4BrzdDzrvBR7s45D8zh7k46RiCjcMNMdIsuGlS2VIyIiaiquQqO83GkN/ky3HmOUl7fQsrHpQC7S8oylzsSfD5wCpK4H/te99A6nPgbYYur1nPEp7dU2tuSQL+Aeom1AH20nPl2801ee/cFCT9O2Ml6csck3b1pKvSULfs+3q9GYncrPeX0hTn1hHro/PNW3/8phxnrjmDTSt6+vaSc+tj2LPZmFjTYeIqJIwaA7iMXZLb5lw1Smm4iIqInp3qDbVmY+dLCKb6s2UiH2/rQlvt1rx5+GtpLJ/ehM/9sfd0e9n7JNhy5q2w6pGKxtwo6oy/Gd/QlMtT+IJOSiy4NTMHvDQbRPNoL7wR391zrv/9h0FXyf8Nwcdfm75XtQUNI4Dcw2Hqg4Va15rA3RNjOQb3R4L29vuXnfRERUewy6g1hc2Ux3ETPdRETU9LRiI+h2h0LQbbEjz2SM82jTerWVYFsOYmN8ElBQplP3HasBk7neTxnVzCgvj9WK8YP9cb/rfrffL4ctcO1Hy7DekwV/4ZIj8cHVQ/xu9+oso7u61zUfLkVOkQMN7YpJf1XYN/WOE4BZTwDPe9YuLyc7LTS7shMRBRMG3UEsPsqKbN1bXs5MNxERNT2zt5FnVAgE3QAyE4051H1Mu9R2n3QvT99aeoNeZwL/WQ4ke0qq6ysqCZnxvSq9qqWWhZYoPWguZecdC9ejW0r1Je1/bc/AwMd/R5HD1TBjrKIh2o5nzkRLaxHwxwtV3s+RtqPBxkBEFKkYdAexeLulTNDNTDcRETU9i8PI0Jo8K2oEu4xYY852X22n2g5snwis+rz0Bpd9AaSUmdddX5oGy1FjfRddlljgpgW+y1NOOYB+bRMwzPSPKjs3TzoVnV5vj5Wd38C7l/bF6f1a+257ZtJOnGYqLYvffDCvwYZ5wrOz/S5/ePVQ48yznfxveNrTfhfN2cbrSEREdcfu5UEsMdqKLHBONxERBY7NYWS6zTGhEXRnRxtB5Knmlbh+QBwePvcIYKJnLvewWxvlOeP7jALmPqrOm9v0B1oPALqeBGybi5Q/J2CylOc3awOUiaGTDyzE6H8ewOixX2LB1gxY9izCsHkPAjbgzpJb8JP7eBzMKcIAGCuXyBJomQUlpcue1VJ+SWnWfPvEMdA0DdhRenBAeTwb2FjaYE3EFOyu0/MREVEpZrqDWEJ0mfJyzukmIqIAsLuMSNEaIkF3TnQH3/n/++ccaBON7uJKv/Ma50lb9gFa9jXOX/qFsT3mZr+bmPL2V7zfpmnAE8k43vQ3hs27wrf7ZdubOErbiB9Xlq71ffL/5uKCN//EzvT8Wg/P20FdzLw0Hto/PwGvDvJvLHftdGPb7RSg5+nQzTbjR3MebJT55UREkYRBdxBjppuIiAItxm0E3fb4umVYm5rLHAV35xMqXhGTAnQ4unGeVLLG//4D+L9UIDbF2NfrdOAe/wZpytjvgBuMTuU+n1Y8GPC9fTym/b0HuUUOv7ndz0/fWOvhHfIsnWbW3Og27Urg26uBjG3+AXfHYcZ5ix24/Gto576hLnY0pWJfFpcNIyKqDwbdQR5053BONxERBVCsbmRWo+KbIVS4h9/uv2PoDcB9ZZqpNQazxQhYy4praZRsP5oBjH4SGPk40H0k0Kxr1Y9zfenc6+GmfzDg8d/xvzKB9m9r9iOroGJTtOrIGuCiT4IDWvnKubNeKg24y0oyyvTba4eQmlO63jkREdUe53QHscQYyXQbQbdemAkt0AMiIqKIortdiNULIb+AYkIo6Na9pd6KBpz5vwCnOMzAsbeVXpamdKMmALrL6Kb+yblA3kHg1r+AlB7QEztAy96NztoBLMAAvL9gu9/DfbtsD244sZrAvZyvlxrzssfZ5gBl42c5IFAVT3f3tkjH4iyZ19+ixs9HRET+mOkO8ky3d063BN1ERERNqSgvBybNmA8cl9QcISO2JWDy5BWOvwtB6bjbjbG16Ancuhi4ZbEKuIXW9ki1fdL6IcwwSsuvMU/Ft7bHkYB8PDVlPX5fd6DGT5WWV4IoFOPi3E9Kd17+TfV3imuJEs2u3v+iNHYwJyKqDwbdQSzWZkaOb043y8uJiKhp5eekqW2xbkVsjGe6UyiQOdaPpgMP7QNGPoagF5VoBN+V2Bp1JV7ouxWPWT/FUNMmXGcxuovf+OnyGj/83sxC3GspE2TLOuU9T6v+TpqGnKi26qwr3T/TTkREtcOgO4jJch6uKKNbrMmRD7jYPZSIiJpOQU6G2uZqMcYSU6HGFkIHCsoa/ZTfxQu3PeI7f4flB9/5Ymdpg7XqOpdvPJiLHtoeY0en42u8TnlRnNEJXstippuIqD4YdAc5c7SxPqfCbDcRETWhwpx0tc3XPFVX1DSSOwH3bKny6lNNRpZ7Z7rRIK06r8wyOqh3N3mWHzv1kdqNQzrX53GtbiKi+mDQHeTioqOQrccYFzivm4iImpAz95Da5pnKHACmphHXwmh0ds20ClfdGzNFbbemGsu5VeflmZvRGuloqxlVC2jRu8ZDsKcYzdoSi/fVfNxERFQBg+4glxBt8TVTQ/llPoiIiBqRK8+Y051vNaY6UQB0Gg5cNxPoey5w+bdqV2/neoy3fIith0qD7jV7snDu6wvQ+YHJeHPuFpQ43fhk0Q513bWWaf6d02sooa1Rht7GfRDZhZziRkRUV1wyLAQ6mGchDh1xiJluIiJqUnq+EXQXWZMDPZTI1mEo0MHTebzdEGDvMoyzzMB9B+8B0EPN2z7n9YW+mz83bSP2ZxXh08XGXOzhpnXGFW2OqNXTejPdHbRU1YxN/iYhIqLaY6Y7yCVElS4bxjndRETUlEyFxpzuEnvorNEd9s55zXe25d7fMX/TIVz1wZIKN/MG3FY4McBkZLwx4v7aPZdnTnczLQ8fzl5Tr2ETEUUyBt1BLkHW6vYtG8ZMNxERNX3Q7Y5m0B00WvX1ne2a/ZcKuP/YbFQkiOFd/ddTP9dcmgFHh2Nq91z2eKTr8ers2nUMuomI6opBd5CTUq7STDeDbiIiajrWIqP5llmaelHQcA2/TW2jUey3/73+/+A9/XF8ZZugmqeJu9v+Y1zZ8VggNqXWz6Ultlfb1t5GbEREVGsMuoNcQpQFmd5Md4HxC5SIiKgpRDmMg722hJaBHgqVYe46Qm27aAd8+y4yz8OoLU8ibv8iDDOtx8KY/+KXo/9B20N/GDc49/U6PVdCK6PEfJjpH2QXsJkaEVFdsJFaCJSXb9MTjAsFpeVjREREjS3OafQSiU5i0B1UUnqoTW/Tbmzu9jL+3p2BwSb/db3N7hIMXPOkcaHryUDzbnV6KotnXve/LZOxJiMfA2PYyZ6IqLaY6Q6BoDtN96yPmmesl0pERNTodB0Jeo46G9esTaBHQ2UldvCdte5d4h9wnyAdzcu56IO6P9fgK31n9xw4WPfHISKKYAy6Q6B7eRo8QXc+g24iImoa7sIsWOBS55NbtA70cKgskxloNaDy6075P+Cyr0svH3s7EFOPRnitByDLYszpL9jNZmpERHXBoDvIJUZbkO4tL2fQTURETSQ73ZgvnKdHoVmi5/cQBY8zXwA6HQeMfLx032lPA5oG9DoduOsfI8N96qP1fqrseKOcXUtdX+/HIiKKRJzTHUrl5YUZgMsJmPm2ERFR48rNOIBkAFlaAtqbeYw+6HQ8BrhmipoGAEcR4CoGht5Qen1iOyDxwgZ5qpJmPYHMPxGT4z9vnIiIaobRWwiUl2chDi5dg1nTjWZq8SzzIyKixpWfYWS6c01snBXUJLN98oON+hS2Vj2BrUBy4a5GfR4ionDFQ9dBLspqhsViQQbijR0sMSeqO8kI7V9tVIwQUbWKslPVtsDKoDvSJbTvq7btXHvgcLkDPRwiopDDTHcISIy2Ir04ES20HCDP+COIiGrJ7QKeKNNM6Kqfga4nBXJEREHNlWsc5C2x16MJF4WFpA6eoBtp2JOWgY6tUgI9JCKikMJMdwhIiLIgU/dkuouMNVOJqHa2rJzjd7nwi6uMzDcRVcqWs1Nti2PaBnooFGBaXEvkIRYmTUfazo2BHg4RUchh0B0CmsfakYto40JRdqCHQ1QvK3ZlovMDk/Hi7037h9s/q5f6XY52ZkNPZ1MgoqrE5+9Q2+KkroEeCgWapuGgzVgbvGA/O5gTEdUWg+4Q0DYpCjmINS4w6KYQd8Gbf6rtq7O3qODb2UTzA0t2LVfb95xj8Je7tzq/b/XMJnluolCUUmRkuvXmPQM9FAoCOXGd1dadtjnQQ6EgtnxnJq557EV8+OusQA+FKKgw6A4BrRKjkKPHGBeKcgI9HApRRYd2ImvlTxVKqnVdh9ut41BuMQ7mFDXqGLak5mKQthl/2O7A77Z7YUcJuj88Fae8MFeNodGe92Auhusr1Pmzzv0XDiYPUecLNv/RaM9JFNLy0xHvzi7tXE0Rz5XYRW2t2cbBGKLKzJz6Az7UxmPMsmsDPRSioMKgO0QaqeXAG3Qz0011c+itMUj6eRwyFn6ous/O2ZiKqX/vR5cHp6DrQ1Mw9KmZOObpWdifXYgdafmVBsxXTvoLY1/4Drsqub4mfli+B89Z30UH0yH0NO3F09ZJav+2Q/lYuTsTjeW5Dz5HOy0dhboNbY4YDXQ6Vu1P2v8H1u7l/ymiCtKNbOZevTlapbCRGgHWFGOaQXzhnkAPhYJYj6z5attKy0J+Oj8rRF7sXh4ia3Vv92W6GSBQ7Uk2u4Pb+OWX/fszGDGjHXKLK182a/jE2WrbKsGOvx4aiZ3p+bj+42VombYIH1ifh11zwvGaGbPa34RT/3UbkNCmxmNYsXYt7jPt9e270PyHOn3vOh73fGXBnPtPQ0NzuXUclT9ffdutjjsOw2wx6HHUqXCsNqsVAb5+6za81ut2vHjJkYi18yuRSDgOboQVwFZ3WwxI9PQUoYhmb9VNbVs49gV6KBTE2roP+s7v+/sP9DjpsoCOhyhYMNMdAhKY6aZ6ysounZbQxXQQxzsWYkfU5eq02n692p5mWoKzTIvQXduD+yxfISF3q5pzPer5Gbgl81l8bpuoAm5h1Vw4de8bSP3q1hqPYdnOTCRkrlPnS+I7AslGqaK40LwAA7Ln46eVpQF5Q3lu2j84y7xYnR94yr/Utk+n1tjV/ix1/j+Wn/HWlpE49qlp6sAAEQHpO9eq7W5TWyTFSPhNkS6prTHNoIWeAXdJYaCHQ8GoIAPDShb5LuZtXxLQ4RAFEwbdISA+yoIc3dNIrZhzuqn2Mvb5N755y/aK73yiVqC279hexuu21zDTfh9usfyCGfb70FXbh+et7+B888JKH7flvlnYvKvqrMfv6w7gxRmbkF/sxJO//YPrLFPVflv3EcAti4BOx/tu+6rtdTzxqxGUN5ScIgd2LfhalZYXm2IQ098ItEW36z+GI7a1Oi/L4Ixz/Ygd6cZrQRTpij0dqk0tekHTtEAPh4JA85ZtkadHqe/LrH1bAz0cCkK7//zG73LxTv9VQ4giGYPuECkvZ6ab6sNRx198s+334Fyz0W1cueJ74IHd+Ljj075dHScNVNvdGQVYu3ETtn52h2r4l5FXhHlfPIuj51+NMY9/jAN7tuMY0wbjTkdeDlijgWsmAzeUrp99SvFMzFp/EP/309+45O1FKtMup/fmb6vT+Cf9sR33W75S501HXQXYPevdC02D9d9zfRfvtHyPV7+bgZdmbKpxxluC+sISF/bu2YmsN0ej4I836jROoqBSnIdO6UaTQXOLHoEeDQUJq8WMvZpxoDJnPzuYU0U7/za+N1a7jfn/R+obcOggpyMQCQbdIaB5rM3XvVwvZNDd1FJzihq1s3ajy09H778eUGf/jhoC9BpTet2De4Eb5wLdTvW7i3vYf/wfo1lX4PFsoPtIICoB4669Fd86T1RX2TUHpi1ehfSXj0P/L4ei25aPgGc6oNn/WuEp6wc43rwO8+x346+oMo/ZcXjp+XaD4W7WXZ292fwLrvt4Geb/tRTddn+LcebpqvS92Yzb6vSjF+5agc4mY36Z9ehKOqnKfPRHM5Fha6OyN9quRXhl1mZ8tXT3YR9bDg4c/fiveGb8XWj3/kAkpf6FmFkPQc8tnc9GFIrk/42XvfMxAR0LBZd0m9HDozh1S6CHQkGoc/7favtz3KXYjnaI0hzIXD8v0MMiCgoMukNAp+YxZTLdWb79i7elY/nOjMANLIxIZvPeb1djzCt/+K0b/f3yPTj66Vmqu/euUC09XvGx7+ymZicDl30JPJKugk3Y44C2g4CLJgFnvwoceQVw1S8wnfIQ0O6o0se4+KMKD7tj8H2+87t+ew5HmmqYjR7+H5VlLss0wnisbqb9uN48GfPtd2GidRLGWz/2zfnOyzpU4x+5xOnGv95ZhMJtxtyygrhOQIteld/YZMLuFiPU2Rdtb+MT60RM/GERth3Kq/Y5nv7kZ2yIusY3Rq8DfxuN6IhC1apVy9R2nmsg+nVpG+jhUBDJiW6vtu6M7YEeCgUZd14a2juN5eQuOv9iHIgyst3FaTsCPDKi4MCgOwTIfDrdnmicdxYCLocqa/1z0n1o/8EgZOXkBnqIIW/s+3/h2+V78M/+HIx5tXTt5p8WrsYzlncxWNuEE5+fg5dnbsJni5tujVJZvku6h9dH3najtDxLj8XOzhcbO80WFWz6RCcDR40DznsD6DoCsMUCN8w2sttyanNEhce945zj8KPbyHbfaJlc8wENvb7ivn7n+87+n/XzSu829tkvalz2/fXSXYjeOQsTrMbBgqJe51Z7+559B/vOn2j+GzdbfsUpL8xD1wcnq/9rXu/ON5rLyWmW/d5KH2v/BqNpG1GosmYa83W36W3QNSUu0MOhIFIkBzClL0fOrkAPhYLMvtUz1HaT3gE9u3ZGYaznAE0mg+6GJsu+LtuRobYUOhh0hwhzVALcuic7WJiJ/em5uNv6nVoHMe3H+wM9vJAmc5H/3JquOne/b30ehalbsSezQAVWFx16HZda5uIH++OqzPmLmUvw9s+zsS+rtHPrn1vSVJDX0H5dvU8t3zXi+bl+gV+t6Dq0bUbm9QHHDejdJqHBxmezmHDsKef47cs8YbwK0gvu3IRd/95sBOx3rQNOmwjc+bdxuVlp13Ifiw3odWa1z/ez/VEMfvArLNicVuE6qULo/tAUDHt6Fv7YfAhf/fIbPrI977s+uduQah87ur//c0vQLU3kZFbB/d+tUcG+nJ6esgFnmP7CSvuNvtvqyZ3Vz/VX3/9Tl7X9a6p9LqJgF5VjVK107XMkTCY2UaMy5PsOQFzB4afgUGQpWG8E3dvjB8NiNkHz/K73HsQLR9PWHsCjP6/F5oNNk/zKyC9RPW96PDwVF729SG0LSipf/pWCD4PuEBETHYVMeDIO+YeQvb90PlX8TuOLjmpPumqf8NwcDNU2qM7dI80rMdn2ME5/djK6aXv9m4gBWBJ1K+bY/ostqxeoy0UOFy5//y/c//3fvgzo8p2ZDTK2x34p7eRd59L2vSsQiyJ1dpG7L87obzTBaSithl8GhyW29O+x4VepbUxSK3Rs09LYmdgeGH4LkNSx+ge77AvgsSzg7vXAA7uAy74GRj+J1J6X+m6yMuomvP65f3dUaWQmVQi99a04K/973DxpLibbH/a7jdZ+aPXPLWO84gegVX+/JnJf2Sbg4Lr56PLgFKzbl4OzTX+qzu/JWmnpuXbLX2rb/UijE3u/ktXYuJONYyh0JRca1Tz2VsYSUURe1hSjZDi5ZJ86qEukOIvRbt/v6mx+p5Fq26K7cbC7dcFG6O7Qy8i+MWcLznjlD2Tml1R6vSRnbvpsOTYunoYnXnldTU1MyyvGWa/9gRn/NHxvlyXbMzB4wgx8ttg/ydP30elc7jREWAI9AKr5smEZegKaa7nA9j/Qak1pY4pW7lRsWjEfPQcbpb5Uc5//tdO3XJVXglaAtVGVlEB7yBrVW2e8hyOGnoQjnjB+yZR14VtGoL7xydNht5jrNC6Zk5yZX4RnLe/DBRMO5R0maKzKknfU5nvXCZhw2QkNv/SPPQ7W/9sHpG81gmpzPdfzlfEleOaQ9jodwOloOTAV+J/RgVw84H4fLvfNMHsycE9PWY+B2lb8Yn9EXR5n9n9PnMNuhcX7mNXpfqpx2v4H8LGxtNgw03q8bH0DJ5a8ghs/WYbXLdP87rLv+KfQ1hqlzjfvMQwZSEQzLRu9PuwD/eGD0DzXEYWMohy0cRkHjWLbDwj0aCjIxLXqDKdugg0lQO4BoxklRTx930rEunORpicguf8ota/7gGPgnGJCMy0Hu3dtRYfOobMSggTPr01fg2bIxaAJxlK9fz5wCtomRftusz0tH8NM/+Ar25Pq8oXPdsHyHGOFlBs+WYYdz1RfvVdbz07bUPp3PzLwmW0i0vREXO54COv356Jv27pXMuYVO9XBhQ7NPP2jqFEw0x0iEqIsSJaAWxz8G532TfG7fteSnwMzsBCVVVCistJSLnyUthFtNKMhnTPRKJ3zc9GHwMP+Ry2vsUzHkCf83wOvBEgWVEev//MP0LykDOmUF+bip5V7K73+22W70fP/puJU00r8yzIXl1tmw7GjDvOEcw9CX/uDOvuR8zSkxNrQaJp3q3/AXZW4lqp823W9sbzXkaatGPHwR7hy0l/ILXJg8uK/fQG36GAq03DtkTRYTi9d3qxGupwAtC4NNjqaDiEJuUjPzkE/zTM37dw3gHPfRNtTbim9n6Yhu/Uw38V9K4w1yYlCiWPXMpigY4+eglZtjfm7RF6tkuOxT29uXMhkMzUyHFpp9HVZgx44umsLdT4qJg57rMZ3yP51RnVgsJFqRW+VolQ+ev2yah9es76O+fY7cbzJ6Mh+7DP+TVLX7Mn2BdzixAL5m09Hc2TDjhI15e2K9/9SUxjra82eLFVFeZJpJZ60TFKrwfQw7cVw8z/4zDoRD/1ojLEuJEt+3hsL1d+l1Y1VbiertnyzdDcz63XEoDtExEdZ8a7Tc9Rsj9FZVvzsOlZtrXuXBGpoIWnIkzN9AfL39vHGzpZ9Yblxlv8NNTPQ5xxAMpbS3dtaWkp9vXkKYlCEl6xvYGrS89ged62a970m6kbsiBqLZOSoL/KJU9b7vtTlNOql+cg7tAf/9/WfqsO2cLklSJ+Kc99YiHu/kznBOt63veB7LsvBOswTXvkpNLcDy9098LfeFZ1SSsceisztB2GVbiwt9r71BfyxOQ0DHv8dZ5qrOCAhHdfreiDg2t+B4+/yXVwV9W8M0LbBrjmhx7QAjhwLDBrr34xOlku57EXf+XZTrwbcrro9P1GAHPhnvtquNfVCSpw90MOhINMmIRo79VbqvPQ/IRLaVuNvp60tRiLWXlpEm5rQT23d+1cjGE1bsxtfWp/EfNsduOR/P/r+Hnv2t1UYZV4Oi+ZWGWX52+5M02Jc+q7xN5sEne9ML11aUZxvWoBHLZ9iedTNWGT/D9xuFxZsSVNTGF+dtVn9/ffm3LottffmnK3orO1XvWqusPj/nXqceR227d6jKiTr9BqsPYAtqXlwuPQqxycrJck0O1nS9b7v12B+Jb116PAYdIdQefkhPcm4cMgoMVnm7omdvW9Q54eb1iE3m8uH1cSq3VlwunV01A5irv3u0iv6XwDEphjNvv71uZHNfCzD6PQtpLv3w/vg8qxhfa1lCmbZ78H55oXoU7QSmtOYO+31qlVK1nW8M99/KS1p0CVHT6WEvdXO39QX8YszNqLY6cbq3VkqkH/W8p7ffazZdeiYvvsv34GZY7o0Q7syZVGhqk33QWrb27Rb/RL8r+UbXGX29DQot9Y4OtRjfWFbDDDycb9dn9ieVVtNMuFVlOlrie3x45BPfJf11aVl8UShwFtVk99iMJuoUQWJMVakWoyS8rz9mwM9HAoGRTlolrNenbV2PcHvKldKX7WNytyEYPTT95+rbLFUtI0smKoyvZLNvcvyfYXbvmF7FSu2HVRB+dZDeehv8q/0kMe41jMFrZmWh3ZaadXdizOMn/+5aRvx4A9r1GNU5edVe3HblyuRnlfs27crPR+/2fx71QhdM8K40eblWL2ndEnhmpDO5+/M24qbP1+BI7QtuN/yJb5fsg3ucmOTyxe+ZRxs8FqxM1P9vcqMd+0w6A6hoNu3VrfHJnc7dOx7DNK0ZNhknrGnuRdVbe3ebFVGc4JpjVoLWr4YfQHbiWWWgOpzFjDoikofw3yq0aW6hZbjK0uvzAnmtSrjLcuNCQ1uWODEM9b3EKU5fHPJO2gH8cac0ozB/6xvq7LyslLyNtb6Zy3Zt1Zt/3F3wguXVFzyKxS1Ot+/VPw2y0+qxEo3WYCLPlBrjMNsA8b8r3RueH3IAZh44w/MGM3zC7DP2dXeZfSoM7HbbZTXaT/fAmQ23RJzRPWi62iZY3xvxHU3qqiIysuOaqe2rnSWlxOAnQthhhvb3a3Qo2cfv6viOxpTtRJzt2BvmVVf6pqRHfTE72q+dUN4bdZmjDYZS6qKu6zfq6z07A2pGGUqrSgta7LtIXy3fDdu+3IVjjZ55lj3vxCI8Uy5KOPuAZU3YPtyyW68MrPygxCbDubijq9WqdVrjnpypkrKyFK1yal/Ik7zJHY6HgsMuRZ4aD+04+5Uu44zrcUni2r2t8aPK/eox5XO5xOnbvCtDiOrttxv+QpdH5qCORtT1f7p6w7g+Gf9y+rFK7M2q8rMn1ZVPk2SgjDonjhxIoYOHYr4+Hi0bNkS5513HjZurH1wESnl5Tm6f3nwdr0NTu7VEnvjjIAqYzPXB66OzKU+6zXjwMQt5l/8rzzaqBioEWs0MOAS/30StJ/2tG9da0e7o31XfW57Gh9e2guru7yJLVFX4WiT/2f8D/tdqinGv82/4mvbExhjLp0qsKvfzWrbp3g1HM5alCrnp8GWbzRD6tRnCNonh0lzDJnfLWXj5Wj9LgCik4w1xh85VLv383DG/ep/uYfRJKYqUlp3peMB32V9nVGyRhT00rcgzp2LIt2KuI5HBno0FKRKYo2g25TLP7gJKNhgVJst1PtjYPtEv+t6DTQqzjppqfhknpENr4vnpm3AfZ/Nx1nFk3HMk9PrOWKjPPzneYtxuWWO3/5TTCuwYNlydDPth1umF5YjB/lf+n4u1u/PxkVmYyoOOh0L3L4KaDcESOkJtDG+O8/fdL+qyJPT/x0bjaWnbsTRmvEavDp7S6VjGv3SfESjCJeZZyEB+Wr/yzPl4ECZgwBX/gic9ZJRkef5e+RU0wpMWb1bNUSrjsxbv+tr/1L/Htoe3/nrLFNhgwPXfLhUBeb//nQ59mUbwf7wrs0xfVxHtdqPVHGK31bvr/b5KIiC7nnz5uHWW2/F4sWLMWPGDDgcDowePRr5+cYHjarPdLuTu6pSL1P7wepy0Y6lqtkCVVTscKm51EIyz1JOpJz0IHD6M0CP02r3gHKfvucCEuzdtBC48gdg+K2+q61HGUtniWitBCf/dBQS9vsvP4YL3vedfcf2Ih60foljvEdORct+KBxeWv7+6/PX1LyU55+f1GatuzNGDe6FsNLvfOPghjS3k6XAZM79GUbpd6NI6eH7JaqqH+xGd9LqnHLssZjsMg685G5mBQqFhpJ/flPbv/UuaJvi/8czkU+iUUVkKzgQ6JFQoDmLEbNykjq7PX6oShCVZU1ohTxrc5g0HTlLPqtTlvrmz5bjs7mrsSbqBkywfqSW8izb9Kwuth7Kx816xelfz1jfx8mmVcYF+fviyp+A4+5QTVlLbMlq9xDTJrRDGtpradAlMB9wMRCVANwwC/jPUqCzsXxoWdevOB8tFo7HN/YJuNxszMl+Zab/9Iy0PCMz/rPtEUy0TlI/ryRkxIkmT18fmfpYdlWUDsfAbU9EglaI/tp2/LnFmGudmlukyr/Fgs1pOJBdhA8WbEe/x0oPWMgUS6msnGG/z28cR2oVDwhIY7hXU69Gr6+Px7f2JzA2ehHuHNkDL/6LB2dDZsmwadP8uzt/9NFHKuO9fPlynHgil786XKY7P97otN31yBOB9S+qDOnIN77GsGOOxblHtsOjP6/D+YPa4sYTuyFSybqJ2SXAOW+Wzke51eLp9B6VCIy4v8r5udWKbQ5cUjp3twIJzrJ2AvOfr/z6sd8B3U4BFr6iutEfafKf941htwAn3IMuduNLXlxQ/DNWbtqBQb26HHZ4Jf9MhvQq/8U1HHf2TEFYkl881xsN8RqdlK6v/xUYWvVScmU9enZfXPjX2TgTS2CTJoeyRmm5pmsNYemODFz89iJcNbwTnji3dI1xorooXjdFfW/8Y+6Lq5qHSXUMNThbcke1jStONZpFmuq2NCaFgX9KqwadnU+q9CbW424B5k7AZebZqontlqfOgMVcs9+HsizXlnXLsCaqNDAcatqEqz5dgk+uP7Zea15fbvYcEB88Duh8AvDD9WipZanAXphkCdFuJxsn+TkGnA8s/wADTNt8WW5NVjqRvyXLOukBYFHpMrTlPW2dhBXuHnhpJrAvqxDPXjRQ7d94IBfdtL3oaSqtIJEu5V66yQqtS7nYyGSGSYL8jZNxsnkVbvzUaDZbnevMk/GI9fOqr7dMxRKHMU1gpGk57rF8o3oNtXCWzlF/Kv5HYORTh30uCuJ1urOzs9W2WbNmlV5fXFysTl45OcbaeZIhl1M4i7GgQqbbGd9B/dy2DoPhsCbA6sjBTPt9uGzJw7h4sdExcv3+HLX8y7jhkbn0y8iXF2BvlnzMjWUQTjStxqnmleq848pfAWf9jpZW64T7Yc7aC9OaL4znu3sLtB3zoUv5UYve0iITuG4WLO+fBC3VyLy7+5wLd59zoPc5V13WdBd23/APOrxnNCM5NONFOLqWdsiulNsJ23ZjDs4q21GwanrY//9odAkdgWM8lQw1fC2PP+5kFCy2I8aZDceBdcZ7Xk870wtw9cfLMbRTEm46sasKuIXM5Xr49J5sfEV1p7thTzPmc29qdQacjfnd2Ii833X8zms8UcltkKNHIwGFcOz7G2hl/L1Bkce84hNVMiur63Rv37rS/3emI8fCOfcpDDRtV41kv1u2CxcONqYoHM7NH/+F6bb7K+xP3boaOfmDEW2r2wGfectW4XL5cwkmuE5+VAXO5q5fwLStdP6ys9OJ0Mv8PFr7obAs/wD/thjLowlX11PhLv8zm6KA+/cABemysD0sL3SDVpIPvXkPaOlGdnua/QF0LvoCXy/bjWFdkvD4b+uRXejEQvszVY5Z73MOnOboCn+DmDodB/PGybjT8gPec56JfFTXNFevNODWY1vCfcRYmP98CaeZl+E30yPor1WzOkHOXujPdIJTlnJNbI9g/d53BNnvgaAJut1uN+68804cd9xx6N+/f5VzwMeP9yzvVMbvv/+OmJjwPiq/PRfIR5mSEpnDnXYIU6YYa0W37HADhm8zlpj60vYUBhS9j1xPkP7klI1ITl8HS4S1zZNKbCPglg+6Uy3hIM3PvKYskzWXPesuNxKTdgoSe/ZAZkxXYI6Ul1uA7ZLVLs1sxzYfh676TGxPORV5UW0B6U2z3X8N8I320RhZ/Du6pc7Au99OQftqVv/qs+8b9PSc34NWvs8INS09B1jp7q6W81g35X3sbHFKvR/z080m5GXmY0pmNn5ctR/nmRbgZdub+NJ5Mj74vgRtYyPsPzk1mJjiVIxyFaBYt2BLXlTIf2/IlDVqHDszNWzSO2CItgmrZ36NvcnDAj0kCgTdjTG7lqig+yfXcRi5dQ2mHKp8edOj4/ujTe4a3Gn5Hrf/2BYHNq9GlypmauWUAI8sN/52kznQJnvptLp8awpiHWl4xPIpXviqHQan1L579r4CIGXfXMAKpNk7YtHshWp/vG0UTkFp0D151X5gden3oNXpxpgyj1NijsHU/IHA4b4r+74Ji7tIBczHFz2J5vn+TdTu+tZYY1vmUrfT0tX5Ne2vRL+9X8KsGwc/s6M6YDFOQFElz2V3xON0z/lTTCvxq9u/AkCmVNo1Bxa5++KCpB2Apx9bgbU58qLaYG/yMdjVfARisg7B27GmqoD75yM/wgmbJqBZwVZoRVlI/exGLOtSmo0Ptu/9goL6r5HekDQ9SPq933zzzZg6dSoWLFiA9u3b1zjT3aFDB6SlpSEhIQHhbPPBPIx5/U/VkMHr7ZOW4brjjBJzIVlUy+cXqPNr3F2QhDzMdg/C486rjceYMBrBak9mISZO24jf/0nF2KM74KEzesFWz6MEB3KKcMLzUgKkY5P9KtXhvSzHw6GzzmBuZhri3uinfoaXtStw60Mvl16p6zD99QZgiYF7yLUwfXQ6zHuXYbbrSCRf9wP6twvv/xvBSpaA+/Dpm3Cb+QfkdD8X0f8y5r3Vx0OfzMQTu4x+AScVv+hXevZmj0m44RKjQoKotgpW/4TE365XfSD2XTIVJ/cyOvCHGslsyB9eo0aNgtXqP7+UGoaUwa595xpcapkL1/H3wD2itHEkRZCD62B9fwRy9WgcUfweFj94CpJjZIJKRaYlb8M8w1j5ZUTxi9ipt8azF/TDBYMqZrx7PPK77/yTlklqXWpXv4vhPuc1mOY9q7Kx+/VmuDrxQ/x223G1HrY0MRux8Co1N9t5ymPQh99WOs65E2Fe+AJcpz0L95DrKtzXPPlOmFZ9ps47L/oEeq+yYXgNFGbC+mIPdbZYi8L9xdfiJ/fxKjEkzdLetL0K3RYL5z07Sqc+Sph2mGmQpukPwrzMWGp2WffbMbjwTyC2BUybplZ6e3e3kXBdWnFOu+X5TiorX/62pq0z4R54GVxnv6bGY/7lZpjWfgfnBZN8lZnB+L2fk5ODlJQUVUkdDHFiUGS6//Of/+C3337D/Pnzqwy4hd1uV6fy5AUO91+uLZOMrHWWHoskLR/POS5Bj8Ro/5+7x6nA0f8GlryjynjE1abfMdV1DP7S+6DIZcwNDyZyzOeur1fhp1VGp23x+ZLdmLspDQsfMDKDOUUORFnMtQ7CF207gBbIxNKo0gZnPsfeFlKfmWYt22B/8kC0yVqJO/XPsO3Aw+jawbMk1pL3gFnGmtLmPmegZN/fkIKrp5xjMaNjM5YcB4h8vLJbDQPSfoBl+2xV5g9L5X+Q1HRNzfhtkxFtNZqtlA24RccN78FkvhBmvt9UB4W7VkBmJm7QuuCi/g2w3F6ARcLfBYHStVUCftI9y4Yd2gwbX+fIdMCYqrfa3RVWiwUtE6spwTv6eujzn4NWnIOrzdMx3jkOr8/dhn8d3Rn7swuREmeH1WzyNIvV1dJV15qnwq4ZmV7zERfDbI8GjvsP9EWvoA0y0CxtCe79PhEvXzqoVsOevmgF/mvapLqTWwZdbvyy9hr1qDrJ31CVFq6f8yqQ0l01VLX0r0OwaW1pLDu6/lfY9SJVqfYy3vS7idbnHFhttfxb4YhLAE/QPWTLq4e9uanX6TBV9v/23q3AOyOANM8qOw/ugclsBzb/DlPXEaX3uWiSOgVFEFnN936w/Q4IaC2i/OeSgPvHH3/E7Nmz0aXL4RtERapmnqOHxxS/gaFFb+BN13loHlvxAIRq4FDOe7YXVNnK9HUHEUyKHC4MfWqmX8BtghsXm+fCnL1DLVcgp4GP/44Tn5ujbl8bczel4gFruSN592w2Oo8fdxdCTZvrv/Gd//ztp1DicALLPwam3FN6o5cHwKYXI0ePQXy7Pgy4A+yYk85Gqp6EGFcuXDuMEra6+t/vG3GuueJjuKKNHhhnmRdj4dqKXUeJasK0b4XaZiayIR9VL8ZmwaEoo8rOfdCzEghFHH2r0YV7hd4D7101pPobW6OhXfCuOnu2eRE0uLE7o1D9jTd84mwMnmCUBcu+c0yL1JrR3oDbtyyXiE2B1rKfbyrl1DV7ar6qC2TKYSF6lhjLdjla9AfiW9fuh5amgcffVeOmqpU67+2qr2veHTjlkdo/ZoejgUu/rNltRz8JVJLF9y2Je9104LoZwGNZxmotkizoc1aNVm6hIA66Zbmwzz77DF988YVaq/vAgQPqVFhYGMhhBSVv8FQMGw7B6GgtRwYriGlmLKd033bgOqOzc4JWgONMa3HPt/5r8+3OKMDsDQdr9YVVHwUlTlz30VK8PW8r/t6Tjd6PTPMtkSBHNrvHu7C05+d43vquWhLCu0aht1T8+GdL59pUpuzPIV3L/9ichkFamSUZ7l5vrPM87Gaj+3ioiWuJTUc8qM4+Yv0MtqeaA/MqXyrrb3cX/O8SLuUQaMf2aImFbuMPhD9+fKfOjyOf7U/m/YNuWukBKi9zmQ7u33xjlL0R1UrOfqSkLVVns1sODfRoKAQUNTeae9qztgIO/s0WcQoygI3G8lPT9WEY0rl0pZUqyYottnikaDnYHnWFZ71nQ26RE8MnzsJLMzfhQu/61149z/AP+IaWBowTTO+pta1r6o9Nh3C0Z2lWe+cA9SKwxxkB7fGlS8Iq7Y4CblkMJNasyVwFvceoVW/Q9WTghjnAtdON7cMHgP9LBW5dCjy0T1V6VruaSnSyEcTXZWUfCt6g+6233lJ19ieddBLatGnjO3399deBHFbQOrqzf1f3lPhqyk8k+O4wFDj6RnXxPE+G7P0/jAZexU4XTnhuDq79aBm6PDgFa/caneMb03lvLMSsDal4ZuoGnP26/9rFSzq/i5mOK9F8lzH/pK2WocqLTjCtwdOW9/G97TFE5e/FDyv2VHjc7EIHujw4Wf0cczamqn0rdmXBWpSBriZjHVHHneuBhNAvmex5+k3I0ONKd+QYS0tcrvl3vFyvd0LHZtWUelGTiLVbsALG0htD82Zj+56KQXN1pLrjyd/+wf3fr8Fl5jmI04rgSuig1gxVZWCyVnnzbtjXa5y6/XD8jS2peY3ys1CYKsoGXuwtPXyxw90KiR0HBHpEFAISW7RX090kY4n0arocU3ha9wM0dwn+cXdCVPsjVPXDYVnswMCLfRdlvWe1G071OdqfXYQfV+5FL9Nu4wZX/QyM+63i8qyyxFfbwersJZZ5sB1ai48WGlMqqyNrez/ww98qCaV0HYGAkYB25GPAoxlGAC6B8Q2zAXM9y6FPfQS46ieg3WCg4zBjK9lree1b9ARs/LswosvLKztdfbXR+Iv8De2S7Pf/1VtyXq0jLlOb00xLVeb4ycnrVXa71//5r5H++V+7Gny8hSUu9SUnc1GlhGjTwcqCAR2LjpqLlgfmVbhmrGUWPrU9g8sts3GUaTMW2O/AN9+XlliLb5buxhHjf1d9JsQ1Hy5Vz3XJO4twkmmVr+ujNJQIC9FJuLH5x367dli64c/CjkbH+hZHIVuPwefRY+vdiI4axtU3G1M+YrVizP/t01rd9405W/D+gu34cdkOXG02/s+aT/yv8Ys5NsVYq1ymHgw+w/d/5s8NFQ9MEVVp0Ru+s2v0rjitXy3LLSkidUqJwza9jXEhzb8bM0WATUazs59dx2J411pUDg42GoF6/Zn0KLZEXYVvbU/ADBdaIAut/7+9+wCPolr7AP7f9B5CeiAhEELoXWmi9CodFEEE/cSrgl4L105TL4r1WrChghVRFLAgiEiTauiEDgkdQgjpPTvfc87Z7GbTE7Jssvn/nmfdmdnZ2bORTOadc8776q5Bg071/DbuWTwXiuilvX8dNJd6cvU35+fw29Y95Y7a3HD0CkJ1lxFhdxGazh4Q9a2tTQxXFxf0IjAmm8er8lrEw9l0B0wE3A72FfjfF9IB8G8BF12unEcjiN7toraerN5M3s8tP4AWs1aj1ew1eHSJSrYhNNRdkXUaCxycGoDgGDXPR5qyCnjUtH9RL9h/gSHvbMboD7YgMT0HT/1YcnkKQZRqEi57t4MtWfZoP8x0MA1LWpOl6j+LEnFtzj6Jdtmfllrrnm68iBB/nGqlkp41Ov8bUrMqXjdy8RZV0u5Fh0UIs7uCLKf6QNs7iu2nC+9pWjnAkUJUCRdN59CXc+9GmK9tl9+k6tHYzx0n9YbRY1eZS6JOyc+DdlqUQAX+1rdG18oE3UHtjJ1BQkiW+rcjMom/4/yxMW+JTsxtLmsOsZ0ddOMWG1cfS3kD+8+VPWLzTGIG5jmoKiI6MUfcRaSOJLpxGHTXIh7OplyK/p4lzOcuibiD1nGSXJzsWjwJ085ne8vn01czKhUMlEbcadxx6iq+LdRz/vtBNcQ7SncGm9yexjqXp7Ht9muIeyQYHl8ZqgLaO6khs+E9gPpNgMm/mB1XHzlQPre2i8MTCTPhcW6jTLzRUBePUXab8ZzDN7Kc2pMOBT3hGvo5q3k7CR5q7pktcQ43zbsUtReLCvY2r+lO1hXeS43eucXuAA4dq9gFqsjomp+dhlkOX+Iuh/Vym1OnCSUPD3P2QKa7qvxQP5W9TlRx+ZfVzcnxOS+gfUt1A4+oPI183XBKMwTd7OmuWy7tgy4nVY6qO2EXjk6NKjCfu3Av9aiPgDuKj/q6Xfc3XnD8Rq0EV6CzJKI3MHGZXOxmdwjv/x4tc//MXHGwxF7vd1bvQ097w9Dy5rdXvM1E1YRBdy3i5epYtaCqzThAZ49meUfxzq0aujapj2/v74K4kWcR8HawDFb72O3GV9tPX3cbZ62MwZ2fbC/xte/b74NdfhZ0Wj6C/5wGLFQBv9Skl/lclsa3qoRw4vHMGdhN/B5nXKLkS/3s9+BLp/kIwDXMd1iIt50+xAMOv8nXHnFYIb9PnMtEeOddkUOIrno0g61x8m2MnfoonNCHYJu+FfbNNq/BXmKSPbIaO/9InHWJgoNOj4T9KvlMedYdjsdU+99wn4NpKohdzydL3f/SzSrJXsts84SJRKXKToN9srpBekzfEPNGcz43VUwjX3ecNAwvz483lBeiuiF2s3zaoW+BtqH14epUYnGtsrUcDrSbAPiEA/eWUEu6z/MVO05kf2R5hsNOpyE3bgfOXcuU17JbT16VCXUL/BB9FhG6iyUmYyO6UWpaiTUqQ+FAKimzEr3SImO3uCN44k+MSPsBIx74AkiMBb5+2rjLHIcvcNvq9ni4V9NKt0skZ/t1/0XsPZtktj0ywAMnrqTJ+dbDgq7B+3AZ5Qz6q4QaJTIMAQq47X5gzX+Mm3eWVH+7CC2iD/R2Va+NXFNFBXvhjpzZskd/eu9IeLs6Yni7EPy8Tw3dd7Rn1smaJt2/PXD2KOzjDXfay7F89zm8Zq+G8Enijr5IkFiKgkysofoL0PJzobvehCxk+66oYOmK5o1EePFmHVWYh7MDktwaAaKqU6JK0Ep1RJwKurfrW1ZuPndRoz40LYsOlpjlwM//VgnGxIjHCnJu0g3YF4dOdsewQa+qtkz8dEex/UbaqXwn+aHdYc+/j2QF7OmuRXw9TMFjfEp25d5801T1fGgFsOQu4F3zclJivuij9stxKTmrUof9clucTM5WNOCeZP8H1qYMR6zzBKyb4I33tELZtbs/CniGqDqBj+xWJ9sAleG5LC5dp0LrdF/pO7S9s1jCtPwB82CLgr0Lkm7o0C5UJRN5vL+pR//RvpFWahmVxjVU/c55pxyFXl92wheRfDDxwgmV8MXOEXj2nLyjXxafoEbI0JzhqMtHWjwvgql8aad3yecj+lDseqGftZtDtYxz/VD5bJ+bBmSnWrs5dCPk50I7s904ta1S87nL02oU8OyZSvdC68K6yedx9hvlSMdjzpPgjuJl7CINQbd9IKfRkHWwp7sW8XU39UK8UtlhgJGFhh8fXWVaHvAytEMroTv3D4bab8ffJxIwtpOaG1qR7ORiOHlhDXAFn4b8ghaJptrBET8NNe3w4BYgqDUw4CVUmk4H3bC3VcmJr8cCuYY63v7NgTGfqeMK+nwgJx1w8QJyxYiAw7DF+XQFekb6GRPbnJo3xFjTnWqWkKibgK1Aa+04jl9MRFSD0i9W9pxJws3aAbUS1LbshDIGrs6OOIQQtEQs0mOj4RmspmMQlSb51C6IAoRnXaPQk73cVEmB/v5Iu+wiSxki9XKFzlNUy105Cl1OGlI0N5yya4SOlZnPbSmGLOQi67ngpMtHjIsK3N/IHYf380fJ5WY6Q2UP//I7eYgsgT3dtYiPm2k4TFRQJf+4ieQVDU3JtySRJbz7I9ANf0+uNrM7j6+W/Ygjl1JkT9yqAxexMzax1ENO+qxg+I6Gu4POIqb7Bmxx+bdZwG2mzwumwPh6iKyTT51UPdtdHgQe3m5+XFGCQQTcNizQywXfTu2C3x69BS6OpvlUDLhrLseGHZCu84CnLhPH9xVPaljY2kOX0MdOZfHXNVflwCrioLPqTbc7rsq5EJVFl6CGl+fXt728F2R54kbvZc0QdKUWmi9LtuuKSlB7VGuIdmH1za4/rMY3otRAeobjD4Y8PxPQ3353xZO0EVkAg+5aRJQIW3TvTVgwoaMMuiptxAJV93DoWypTeMGcmYAWuNZU3Qlc6TwLzT8KxWezJmDIj83RdnEzXDhbfKjqifg0RJ9WdxU3Oj+Jl5OehvvuQqW/hPHfms/LKVQm4rqJmoajPwEGz1cZ2uug7hF+aBXCkhe1hr0D4n06yMWMk4Xmahchbnot3ByL9naGLOeNKl5L9ES9HvI5IHYFcLSE5DREhioTW09cgU+KCrp1IbwIpaqNuIovCLrTLlu7OXQjxKuRg8f1Da5vPnd1M3QeVUjRDiiiG4RBdy3TOyoAQ9uqjKGV5h8FTP1LzZcpkkTCp9tks/WpDmoIuqjvHb+ieBbJBetVQPCMw7dopFMlwYxuuh+440ug+VCgy0OGbVMB74oNWyeyVS4RKiiunxCNlFJK9N3/RbTMzB+oS4KmswOC21b4+H6temFrvqGE3JLxasgn0f7vgb9elvNu83KyMOC5T9D966Zw1TLky/6h7Ommygup54rLUDlF2NNdN2hXDEG31rB653Nfr9CbVO6TZ88DIR3V474SRnyJEZ5i5CeRFXBON5lKdPlGAlePF3vJPeWk7BnRGXqURT3v3/adw/8cF2Bk4ezK4oRXdE5XlwfUg4gQ1LYv8M+r6ITDmLV8P/53Vyez1y8kZcqSJ/3tTsp1nchXUFJd7lLcEhmIu35/DPvsDb9zF3YDURUfnk62J/PkNrj+ZEikuel1pMITa53Nk16FBwdYp3FUqwV4OuMfQ0+3lnIBdXPMWd2Se/EQRErfWLswdAgz3HCpKQquPx9Yb9o29E1ZMhfhPQG/ylfnIapOvN1DpnnQohd8xgmcuu8ArvSYjcMDv5MvNciJw7Pfqyy3wkNf78Yk3e/mAfe0nUyiQlQOXUgH5Nq7wUeXhlP7t+BsouppTM/OQ/gzv6H7q3/J9Z52hiRq4m59JTQP8oS9e338nK+yueJcdDV/A6ptDq//1mzdB6llJmYkqihRYu6ypsoY5iadt3ZzyNJys+CYfFou2gW0qBnzucsjRl52vpcBN9UIDLrJRCQf8/BHk7Aw+Pd/As069Zab3XTZmBYzHskZubiSmo38Uxsx0/Fr9R5x9/Bfm9XQdSIqm70jdE37ysU+9nuw/dRVufz40r3GXTyRgQmOG9VKy+GVOrxIpNelcX1s0qsh6Vpc2QnbyMalJ6DjuS/l4qK8gTivFR8OKrIQ14qLZ6pxxL+bZEdVpjM/6YK1m0OWlnAMOuiRpLnDL0iViyOiimPQTaWyd3JBQhs1LDHU7gr+3PgX/tp7HIscXzPtNGFppeacEtV1Ds1UPeTHHH7Cd9vVMPJLKVnG158IPQoHLQfwa2Ze6q+CBrUOwn69SmCoXdoP5OVUW9upFtE04PUIuXhM3wAv5k1Cj+x3sVMfhWTnYPTOfhM/5vfElJynrN1SqsVy3ILksy6VQXddyVx+TGuIiACObCSqLM7ppjL5DX8J6TFL4K5Pw5gdd2BTfhu42BsSQI3+tFLzTYlI1OYbZFxscOEPXEzugv3nklEPqfhwdDi6HdisXmw9tkqZ+Ye3C8Fj3zVAvFYPAblJQNwmoKkK9KkOOb7WuPhO3hgcfXkonBzsAG0ooOkR+9xqPJlrSHRJVEV6zxAgA3BJP68SN3oGWrtJZPHM5Q0R4e9h7dYQ1Trs6aayObrifMcZxtVb7dVc04u3vQa0HWfFhhHVUp5B0CLUEPOb7I6i2yt/wRk5WOE0C91WDQTObgdE1vKOk6p0eJHwcGynMKzJ76w2xKyoztZTbfHbE/Jph745/rLvoQJuQdzIsbPH6A4N5OoT/Zm5nKrO0Vv1dEtvt5Lzfsk2aYagW/R0Nw1g0E1UWQy6qVzNBk83W0/TXBDc+19Waw9RbafreI98HmGv5lwPtduOcLtC5b1ajwG8Qqp8/ObBXlinNyRhO7YG0OdfZ4upVkmMBZLPysXZuVPw26PFa73PH9sWn97TGVN7qqkIRFXh51VotJs+F0g6Y83mkAXlXVZBd6wuFA19XK3dHKJah0E3lU/U9J6TjG8cx8rVlAFvWbtFRLVbWFf55KXLxJeOr+Atp49Mr4nSfaLMyXVoEeyJf/RRSIUbkB4PnFRZ0alu0JZOlM8x+kY4ooWhSQlDQR3t7dCvZSBcnZhEjarO39MZ7+WNNG1Iv2LN5pCl5GTAwZC5PMsnEg72DB+IKou/NVRhE579BNrTpxHSQ13QEVEVeQYBAS3NpmxI4xYDj0QDLt7XdfjmQV5IhytW5nUrNr+XbNyuL6C7HCMXF+cPxCjDMHIiSwXdb+bdgWi9YZpCRoK1m0QWy1yuIVHzgG9AQ2u3hqhWYtBNFaazs4fOtZ61m0FkG0Z9BDgWSUTYYkS1HLq+uxOCvFywWd9Gbdj5MRCzvFqOTTXY2Z3AL48aV1dqt+GtO9pZtUlk2wI8XeTzNc0wmiLzmnUbRBbNXH6cmcuJqoxBNxGRNQS3A56/APSbC7j5qV5uu+o7JQd4OWOrvjVSdF5qw0//AtJVXXCyMZlJwEsBwGf9jZuGZs/D/bc2lYn1iCzZ0y2kQN1AzMtg0G2TCpKo6ZlEjaiqGHQTEVnTLY8BT50EWo2q1sPeeVOonNPdL/MVtSE/W/V4k2355TFgfiP1/9dgas4TiNHC0SsqwKpNozoUdGtu8jknLcnKLSKL1+hmuTCiKmHQTURkg0a0V3N54+GD020fUxs3zgc0zboNo+pzcT+wa5HZpq5Z72GtvjPGdmqImxvXt1rTqG7wcXOEvZ3O2NOdm55o7SaRBeQbMpeL4eVN/ItMiyKiCmHQTURkgzycHTColaqhO/d4E/N5v1T76fXAuheNq4/kTEd41re4BF8smdoVb4zjXG6yPDF94Y/HbzX2dOsz2NNtc3LSYW/IXJ7sEQF3Zwdrt4ioVuJvDhGRjWoV4oXVMZfw1zU/xAV0RnhKNHD4ZyCsi7WbRtdr23vAibXI1hxwe8482QMlHJw7UN5wIbpRxHBjNy9fIBPQMpPLf0NGokq45uCiSoxlp6hnz2AgsBXg5Fmt+S2okMRTQNoVIKQD4OBUsZt734yTiwmaF/wCWQ2BqKr4l5mIyEYNbB2EN9cek8tfpHfBbEQDF/ZY5sNiNwFfDFPLD20DAlVJNKpmORnyxom26XWIFGlz8ibLgPu+Ho0xaxh/5mQdelHmMBPQZSepQC09Hrh0ADi7Q5VHdPYCTm8Bjv8BXD5Y8QPXjwDqhQFehmAvrCvgFQI4ugGhNwN2hjrzYtpM4aSB+XmAli/64oHUi8ChlUD8IeBaHJCVDNRvooJ+OwcgL1O9Jy1elWvU5wHOnkB6AuDdEDi/C7h2Wt2s9I0EGnQEIvoC0Z8BuZlAh0lAQPPSv4Nom7jZeWQVMPy9igW7ReVmqXnVImgW39/OUX138bMVxxM/c3EjI+OqmFivlp3cVfsSjgFXT6jSkddi1fHsnQzfPVv9nMS6g6v8caFeI8AvEgi/BTi3S/1/Ez9S2HE+N9F1YNBNRGSjmgV6Yv2MXuj9xgZszQgFRM6jC3vVBZyjKvVz3RJOAO93Mt/2YTfgoa3qgi76c6DHY4Bf0+r5vLogLwdY8yzg6gO0GAb8/AhwcZ/ZLuLa+KQ+GEvze8s5lv8ZGGW15hLJYFXM8U7cB8wLMQWy5XGtrwJEEQDqc4u/nnhSPQrs/dq07OShAkyz4/moUoy56WWXLxMBeFVuLIqHCLYL2/Y+0PhWdWNAtEkE7SLIdfMFDq0w3/fMNuCm+4E24wDPIHWjQJwndfaAfaFLcnGOzkwEUi4C+5cCuxabJUssRrxf3mSoAPGzzs9RjwKF1y/tV4+DP5q9bXHeIERwPjdRlTHoJiKyYY393OHuZI+jOaG45uAPn9wrwKkNQNSgqh1Qnw8kn1MXtx/dAiSpuX7FfNjdtLznK9PFnujpaT+hap9dF+z/Hvhpqml90+ul7ip6uZ8c2ALTevOGBlnXNa9WuHTBB0G6a8UDbtE7DE0NHxc9zD3+rZZFwOnoah5ontkKJBxXwW3j29Q+IohNvQTEbVa9xiIgFNuKBtyCCLSLBtuiF1eUZRQ91Jpe9eJ6NQSSzwA6O8AjUA1vF7eynNwAl3pqyLtIVCh62UUP85Wj6twnepdLOueJ9laEeO/amepRmGiHaFuFidtuhZJilhRwi2H6bvUB3wjAMwTw8Ac6TQG8w1SPt/i8c/8A2amqx9zdT/WUn/hT9aiLUQGGm32fOE7Ch1mD8C17uomqjEE3EZGNiwz0xN6zSfg5qz0mO6xVvc+VDbpF76u4yP3tSSDmp+Kv3/YMcNtTQNzfwJfDSz6GuFBeOV1dwIqLz76zgfqNq/albNHlQ+YBdymODFmGCT8lIBFe+KQHf35kfS4e3hic/Qqea5uOcf16AN6havh24d7b8ojRNxF91KPLv8reVwSKl2NUMC4C85x0FVyL4eBimLi4KSgCyKA2KtCvznr14rMXDVG92wNeVoHptgXAge+BwNZqKL24edDrWXWTQAT54uex+U0V0JYUIJcVcAe2ATreA9w8VX2P/FzA3lH1kJ/eqs7LDTqrANvBWb0ubnCW9Z1FIC6IthUlhpUb26UhOycLr875S65GsEY3UZUx6CYisnFPDYrChIU78D0GYDLWAsfXqHmNhiGh5dr+EbD66ZJfEz0oj+1XF4FCk9uAB/9Wgb2Y67jhFTWPUwjtouZ4bvmfWo9ZDtz/FxDSXvUsiQvluhpsr/oPcPpvtS6ClScOy7mkW89mYsIfhnmrBX4Sw0C9ZHZ6V6cirxFZqXTYNXhhl3MrjAtoUep+8alZMtGfm9N1Xn6KOddifrc1iM9+cLNpXZy/xixUj7JM/F71lotEcsln1fkuK0mdQ8XQcTGUXGwX87DFzUiZ7My1eFK5gnOtCLAjehf/nILXq4NOhyXRl6DXVEWMAENddiKqPAbdREQ2rmOYj+z0iMkLMZ31X28KzBRDKstx7I/iAXezwWr+X+Oear62TodDF1Lw1fY4PN6vGQJE79Ltb6t97/waSLus5juKwHp+uPmxPu1jWh74CtDtYdQ5X41UPyPB0Q3a9H8wfXkcDl5wwOmrpQfVN7EON9UQ9dxUoPfdP2dx7lom/j6RYHytRbAXDl9MMa6Lut4NfVxx+mqGXHd2sMOAVkE4EZ8m95vSPRy3NPVDWnYesnLzkZiRg5jzKXLd191Jjqy20+kQ6uOGgxeSsfaQ+t3x93RGQlo2GtRzRb5ew8XkLNzdNQw5eXqcvJKOIG8XOSg7OTMXvaMCcPpqOvaeS8bEm8MQfToR30efM/tObRt6w9/DGeuOxJttf31sW4zu2FB+j8oQnyu+q4sY5u3hL7+bvXcjONobgmoxlB3FK0ukZ+dh/dF4ZOXqkZSRg2sZOcjN17Du8GW8NrYt2jSoJ7+3+J4XkjPh7eqI5IxcNPBxhZODHeq7O8HZwR77ziZhxIItuLWZPzqF+aC+hxOCvVzQu3mA/C7iZ1b0O60+eAlzflHz38Pqu8kScURUNQy6iYhsnIujPdqH1sOeM0k4F9ALDeM3qKD57D9A6E2q92XnQsArWA2ZFHMa5VxKPfDtONP8QHFRKBIQiURAkf3MLgqHvKt6flbsuYCYuQNhV3DxJnpj5MWkIcnRo3vVHG8RmP8wxbyhInmYGFpaVibgaqlvPVdlAC5vCOuNIIbIFgTcIiPybU9hwa5M/HbgYrlvvaOzKhNGZG3B3qa52YUDbqFwwC2I4K4g4Bay8/T4Zd8F4/rirXHyUVlXUlWiMRH0F/h6+5kS99183NRGEYyWZP+5ksuf/WfZfjzz0wF5nhPn1vJk5uSjxazVqIxpvSOQmJ4LcRr9ZkfJ30EY8+E2VNamY1fkozwiOC+8nwjiiajqGHQTEdUBLYO9ZND9c6Nn8bAIuoXPTIGzmab9gO6PAqufNW17aIvKtivmUPo0Mm5effAiHvx6t3E9MzcfTZ5bhYX3dMal5EzZIyN6rnaduYbE9BwMaBkOXd9Zhp2vAb8+DkQOVL3gIrPvj/cDdy9Tn1UdxJzKC7uBZfcByedVwqKCLMBiGKy4yWBN0YvUc4vhwJ1fIfyZ3wBcLbbbBxM7onWINxwddPIiPtzX3XRjg8jKekX5Y+7wVnLEi+hxfn/9iRL3e2FoC/RtEYhz1zLw3roT2BmXWG1tmNAlDPXdnOSUi43HrshgWgT0BXo09UVeviYDZXGe2hmrPrtdaD0kpmfL3uGUrDzj/gNbBaJBPTd8vsVQZqvIjYPmM02BdIewelgytas89vmkTPk7+vuBi0jKzMVnfxd/f3kWrC+Usb2adWvii3A/d9nOsoLvoq9dTSsjezoRlYtBNxFRHRDkpUqExWa4AtOjgfc7l76zSPYjHoWJ3mrR+10o4NY0DfNXHy3xEFO/jDYuv/irqTzPo32a4okBhvJWne9TD0HUwf3kNuDyAeDzgcC/NgMuXrhuG18DNswr+bWvxwAPbzclFbrRzkUDuwxBd6fJ+KdIACKG5TYN8MC749tzWCfVaA72dpjc3TR1ZEY5JexEVYWekf4lvibOK+JmnYOdTp5yqvJvvzoz+s8a1tJsfeaKg/hqu3kGc3FDs+Ws1bJM45FLqaUe694e4Vi0Jc4Y/E7pEY7LKVlySPgXW+Ow+0zxXvfmQZ54qFcERrQ31Co32H8uCU8t249ALxfMH9MWvh5O8mcmbjSIYeyi5z9fU0PGE1JzsO3UVUzsEmbWOy9GKYmRASlZuTh/LROnrqTJ9qVmm24+FBjVkSNriK4Hg24iojog0FsF3cfj0wC/dsCID4CVhvnTrccA3aapYeW//FuV5ikghnvf/VOJmXCf+fEAYhPS5fKb49phQKtAtJljSJpWinf/OoFJ3cJlb5gZEcxPWQUsGqxK1bzVAnjmbPEkQpUhsqT//VbJr7kHAOnxwHsdgab9VUKiqMEq03FV5OcBR1cBwe3MbkyUSmRY/rSvWm41Sg4t/37ZfuPLqx7tiZYh1XDTgaiWEUG2k0PNvcn00sjWsqf4pV8PwdFeJ28QCCLZWEkBd2h9VzzZPwojO6ig+Z5u4Yi7mi7nlRdWOKgWNx7Ku9nQtmE9rH6s+EidgqA6wHCjVS57upR4PnF3dkBUkKdcvslwz8R4U1Tcf41PxbaTV+X0gb4tzNtLRJXDoJuIqA5oZbjgOnQxRSbcceowEWjYGXD3V6VmCogAW2Q392umys4UKbeTm6/HpeQsmcxnafRZuU1k0R7TSfWC7Js1AB1fXosujevLIZyiB6iASOgjhpiLIeki8C4msCXQ/0Xgl0dVGZy93wAdJ1XtC4uh61+OBPKyVNb0+9aoZZFKScwzP7lO9XQLJ9aqx5rngOa3A2MXAQ5OFf+shBPA95PUfHchcgBw5zelH0OUHPpsgGl9yBvIztdjdcwlufrdA10ZcBPVYP93S2P5EPR6DdtPXZU9xqLXOszXDT5uTvJ817qBd4m9/OJRlpoysqVpgKd8ENH1Y9BNRFRH5nSLDMNJGbkysZGYxwj/EoaAikCxxbASjyHmKY7+cCuOXEqRU6ULPD/UVCLI280RJ+cNMfbWRM1cLYN80Tskhju+u+44Zq6Mkb0wA1uVMG+702Rg0+uqdM7P09VDZD6fuEwF5RVNlvb9PUDqBcDJAxj1sbpx4OhqPm9dZFZferf5e4/8Cmx9F7h1RsU+6/CvqrZ2rikxlCyRtvsLVVe3JEdXA9fEPE8dcO8q7Iy3wx0fq/mhfh7OuCmcWcmJaguRW6F7Uz9rN4OIarjrGLdHRES1heg5ERnMhR2xxRN1lUdkF2439w8ZsBcOuN+f0AGh9d1K/cwjLw7C8f8OxqSujdAz0nRh+q+vduFsYqFAtbCHtprX7E45D3w+SNW3LY/Y50UfIHaTqnd994+q5m1JxM2FOcnA7CRgZgLQdrzaLoL+xNiSe8/F8Pt3OwBvRAFzvIGlE00Bd3hPwDtULa+aAWx4Vd0AKNor/tP9avnW/wCNuuOOj00ZiPsayvcQERGR7WDQTURURxQkLtp+quIZgy8kZSLqhd/xyJI9yMkvEkACGNomuNxeoII6tKIH18dQz1f4wTA8vRiRQO3/1qrSZC6G4ZnZycDmN8tubMJxYMHNpvWB/wXCuqJcohfc3hEY9ZHKZi6GoS+5SwXZBbJSgPdvBnYtBhJPAWlqKLjUeiww8yow5VeVmE3MjRc2vAIsuEnN9xZy0s3LpHX5lxyqX8DT2QGP929WfnuJiIioVmHQTURUR4gsuIJI4lNRy/ecNyu7Izx4m8ikG4Kfp/eo9NzDPbMG4O0728nlZbvOydI7JfKLBIa+CTxzBhj5kdq27X3gwLKS91/3ksrInm4oc9PlQRW0V4b4Lrf/D9DZA1cOA++0By4dVMGymGcuEq8VdfMDwOiFgL1htpazBzD9H1OP99UTwEu+wLE1wLwQlZ1dGPUJ4O5nLMsjhv8fmDsQQYaEd0RERGQ7OKebiKiOEBl3BTGsOy9fL8v8lOf7Ir3REf7umN6nKTycq/7nY3DrYMxeGYMLyVmyTFbXJr5lv6H9XcDW94D4GODH/1M1vUWpMTF0+9RfwIl1wPYPTPvf8RXQcnjVGifKh43+RH1OVhLwUQ/z1/u/BPR4VNX/1vSAnan8jpFHAPD4QWDN8+pGgfDtHabXxZB3MaccwMELycYawkRERGSbGHQTEdURwV4ucr6wKHEj6sHe3Lj8hF0F87efGhSFh3tVT+1bUdJGDHX/7cBFjP9ku9z2eL9m+He/yNLfdM8K4A3D678+Drj5qqHeJ/8y7ePoDvSfW2oiuAprMxZIvQT88bz5du8wU11xWUC4hIC7MDG8PekMcPhn0zaRRd0w5D0tOw9L/1E3NUrKckxERES2gcPLiYjqCDG/umA4d+HkXSIbeeTzq2Q91sIOnk/GGUOys1GGGrPVRZTVKeztP4/haAk1bs16j2clqkzmgshOXjjgFp6OUxnDq6PcTvfpwMM7gMA2al2UEnvobzV8vDLu/AqYtlMNW3/2nNkc88JD929h9mMiIiKbxaCbiKgOcXMy9c5GxyXKrOSD/rdZ9n7ftXA7Fm0xZe2+/b2/jcuBntU71/juro2Kbftp97my3ySGck9Yar5NZAAXyctEQF6Z2toVEdBcBdoiw/n4b0xJ3SpLlGbrfC/gbF7v9sdd6vs+2b8ZfD2cq6PFREREVANxeDkRUR3y6yO3oM+bG+Xy2I9Mvd0F5v5ySM79jvAz9eg2C/SQveTVqUE9V+x4rq8sQZaRk4+Hv9mNdUfi8ewQU83vEgW1AV6IBza9ATg4Az2frJ6e7RssPiULe88myabfebMh6RoRERHZJPZ0ExHVIU38PfDmOJU9vLDIAFOQPfWLaJxMSDOur/73rRZpS6CXC3pFBaBHhB8c7HQ4EZ+G45fLGGJeQATbfZ4Hbp1RoYBb0zScvppeeqZ0K1h7+LJ8bhXihYBqHkVARERENQuDbiKiOkbMzw70Mg1nXnzvTVj7xG34Zfotcj1Pr+HeRf/I5cGtg6q9l7sobzdH9G4eIJf7v70JWbn51XZsUWe88bOrcNvrGxDx3Kqy543fICL4f375Qbk8ol31zpUnIiKimodBNxFRHSOC6IGtgozrt0b6y+c2DYvPWR7eLuSGtGlMR1PwOX/1kWo5pl6vofur5snWJn66HW+tPYZjFelRt5AVe87LZyd7O4zn0HIiIiKbx6CbiKgOerRvJAa0DMRHd3cy68kuHGR3CKuHwW2Cb0h7+jQPNC5/sTVOBszXa2dcYrFtCWk5eHfdcQx4exPiEtJhDbvOXJPPTQM84OniaJU2EBER0Y3DoJuIqA7y83DGJ/d0xqDWph5v4eVRrXFfj8bY9mwfLH+4xw1rj5ODHdY9eZtcFvH2T4be4KoS87gXrD8hl8d0bIjYV4YU2+epH/fDGvadTZLP0/tUT91zIiIiqtkYdBMRkZGXiyNmDWuJYG/XG/7ZEf4emNxNlRKb8cM+JGfkVvlYoub45uMJcvnurmHQ6XTyRoKns6lox87YRKw/Ei971UWt8uuZSx5zIRmv/n6k3N5z8RlHDPPK24XWq/LnERERUe3BkmFERFRjTOrWCF9sOy2Xl0afwQO3RlT6GLn5ejz0zW653KmRDzqE+chlcSPhwNyBcvnxpXuxfM953LtYJYwTQuu7YvNTfSrdo754a5wstSZ8tPEkukf44pv7u8hAv6if912QidR83Z0Q4s2s5URERHUBg24iIqoxmgZ4YvawljKInbfqCK6m5cg552KIuJgDXZ431hzF+4Zh5cKcYa1K3O/ffSNl0F3Y2cRMPL/8AP47qk2ZQfbHm07JoHn7qUT8uPtcsX22nryKk1fS5HcpatkutX+LYK8Sg3IiIiKyPRxeTkRENcqELmEIq+8ml0WA++GGk+j31kakZpU+3PzAuWQ5JL1wwN2mgXeJGdmFcD93HHlpEDwKDTcXvt15RpYZKy3gbjPnDzmM/D/L9hcLuMVc+AKi97uos4kZcki78OqY0gN7IiIisi1WDbo3bdqEYcOGISQkRN7xX7FihTWbQ0RENYCzgz0+ndy52HYR8CZnFg+8T19Nx7D3/zb2IheuP14WF0d7HJw7EHGvDpUPka1d0yB7u0vy4q+HkJadV2z7W3e0k+8Xc+H/d2d7ue3r7Wcw4O2Ncqh7gYWbT8nnnpF+aOijbioQERGR7bNq0J2eno527dphwYIF1mwGERHVMM0CPbFnZn98MLEjbgpXc7KFdnP/wHlDT/S9i3Yi/JnfcNvrG8zeKxKmiSDY18O5Up95Z2dVM3vT8QQkpGWbvbbnzDUs2mLqvZ43qg1ublwfe2f1x+iODY3bC2eDP3Y5DT3nr5dzuMWNgS8Nc9XHdjLtT0RERLbPqkH34MGD8fLLL2PUqFHWbAYREdVAPu5OGNImGN//qxt6NPU1bn/rj2O4lJyF9UevmO3vYKfDxv/0qnLm9YLgWQTJolZ4ATGsfdQHW+WyKGm+e2Z/OQRetKuem1Ox3vP1M3oZ1y+lZCHiuVXGgFvo39JUk5yIiIhsX61KpJadnS0fBVJSUuRzbm6ufBAVVfDvgv8+iGq3Rfd0xJtrT+DjzbFyLnVJCcwOzu4HeztdlX/fRVqzl0e0xAsrD2H7qavyOGIe9zM/quHmzg52WPPvHvB0KvszGno7IWZ2P7Sa+6dx22d/x8rnZwc1g6NO4znJQnjOJyKqW3JLOe/XtL8DOk1cUdQAYk738uXLMXLkyFL3mTNnDubOnVts+7fffgs3N86PIyKyZam5wAvR5veKg1w13BOZjwbu1fMZlzOBeXsdYK/T8FTbfHx21B7xWSrL+JDQfAxsWPE/mem5wHOF2iuOOa9zPlxq1e1uIiKi2icjIwMTJkxAcnIyvLy8rN2c2hV0l9TTHRoaioSEhBrxw6SaR9zlWrt2Lfr37w9HR0drN4eIrtM3O85gzq9HjOt/Pn4LGhkynVcH8Sfx3i92Y8vJq2bbvV0dsPWpXnByqNysrEVbT2Pe70fl8sCWAXj/LpVojSyD53wiorolt5TzvogT/fz8akzQXavutzs7O8tHUeIHzD+uVBb+GyGyDVNuiUD3yABZHuy5IS3QNLDkkmDX460728sEaDmGzOPtQuth5bQeVTrWA7c1hbuLI6LjrmHm7S15HrpBeM4nIqrb533HGvY3oFYF3URERCKz+c/Tb7HY8QO9XDBvdBvMW3VYlggrKANWVRO7NJIPIiIiqpusGnSnpaXhxIkTxvXY2Fjs3bsX9evXR1hYmDWbRkREdZgo68XSXkRERFTrg+7o6Gj07t3buP7EE0/I58mTJ2Px4sVWbBkRERERERFRLQ+6e/XqJZPWEBEREREREdmiyqVhJSIiIiIiIqIKY9BNREREREREZCEMuomIiIiIiIgshEE3ERERERERkYUw6CYiIiIiIiKyEAbdRERERERERBbCoJuIiIiIiIjIQhh0ExEREREREVkIg24iIiIiIiIiC2HQTURERERERGQhDLqJiIiIiIiILIRBNxEREREREZGFMOgmIiIiIiIishAG3UREREREREQWwqCbiIiIiIiIyEIYdBMRERERERFZCINuIiIiIiIiIgtxQC2maZp8TklJsXZTqIbKzc1FRkaG/Dfi6Oho7eYQEZEF8ZxPRFS35JZy3i+IDwviRWur1UF3amqqfA4NDbV2U4iIiIiIiKiGxYve3t7WbgZ0Wk0J/6tAr9fjwoUL8PT0hE6ns3ZzqAYSd7nETZmzZ8/Cy8vL2s0hIiIL4jmfiKhuSSnlvC9CXBFwh4SEwM7O+jOqa3VPt/gBNmzY0NrNoFpA/BLyAoyIqG7gOZ+IqG7xKuG8XxN6uAtYP+wnIiIiIiIislEMuomIiIiIiIgshEE32TRnZ2fMnj1bPhMRkW3jOZ+IqG5xriXn/VqdSI2IiIiIiIioJmNPNxEREREREZGFMOgmIiIiIiIishAG3UREREREREQWwqCbbqgFCxYgPDwcLi4u6NKlC3bu3Gn2+ieffIJevXrJOns6nQ5JSUnVctysrCxMmzYNvr6+8PDwwJgxY3D58uUKt/u7776T7Rk5cqTZ9ilTpsjthR+DBg2q8HGJiGxdbTrvL168uNg5XRy/MJEKZ9asWQgODoarqyv69euH48ePV/jnQURk62ztvD+lGq73GXTTDbN06VI88cQTMsPg7t270a5dOwwcOBDx8fHGfTIyMuQ/4ueee65aj/v444/jl19+wQ8//ICNGzfiwoULGD16dIWOHxcXhxkzZqBnz54lvi7ae/HiReNjyZIlFW47EZEtq43nfXERWPicfvr0abPXX3vtNbz77rv46KOPsGPHDri7u8vPFhd7RER1nS2e96vlel9kLye6EW6++WZt2rRpxvX8/HwtJCREe+WVV4rtu379epFVX7t27dp1HzcpKUlzdHTUfvjhB+M+hw8flsfftm1bmcfOy8vTunfvrn366afa5MmTtREjRpi9XtI2IiKqnef9RYsWad7e3qW+rtfrtaCgIO311183bhOf5ezsrC1ZsqTcdhMR2TpbO+9X1/U+e7rphsjJycGuXbvkMLwCdnZ2cn3btm0WPa54PTc312yf5s2bIywszOyzxXCVOXPmmB3/xRdfREBAAP7v//6v1DZs2LBB7hMVFYWHHnoIV69erfL3ISKyFbX1vJ+WloZGjRohNDQUI0aMQExMjPG12NhYXLp0yey43t7ecpjj9XwnIiJbYIvn/eq63mfQTTdEQkIC8vPzERgYaLZdrIsLGEseVzw7OTmhXr16ZX52REQE/Pz8jOt///03PvvsMyxcuLDUzxdDTb788kusW7cO8+fPl0NZBg8eLNtERFSX1cbzvriY+vzzz7Fy5Up8/fXX0Ov16N69O86dO2c8bsFxqvM7ERHZAls871fX9b5DhfcksnHiF6lAamoqJk2aJAPuwr+YRY0fP9643KZNG7Rt21b+Mou7YX379rV4m4mIqHrO+0K3bt3ko4C48GrRogU+/vhjvPTSS1ZoIRERWfu8Xx3X++zpphtCBK729vbFMgiK9aCgIIseVzyLYSlFMyOW9dknT56UCdSGDRsGBwcH+RB3uH7++We5LF4vSZMmTWSbTpw4UeXvRERkC2rbeb8kjo6O6NChg/GcXvDe6v5ORES2wBbP+9V1vc+gm24IMdyjU6dOZneXxPANsV747pIljiteF79Ahfc5evQozpw5U+pnizkgBw4cwN69e42P4cOHo3fv3nJZzPkoiRiKIuZ4iFIyRER1WW0775dEDB0UfwsKzumNGzeWF2+Fj5uSkiKzmF/PdyIisgW2eN6vtuv960rDRlQJ3333nczwunjxYu3QoUPaAw88oNWrV0+7dOmScZ+LFy9qe/bs0RYuXCizDW7atEmuX7169bqO++CDD2phYWHaX3/9pUVHR2vdunWTj8L69OmjvffeexXOXJiamqrNmDFDZkSMjY3V/vzzT61jx45aZGSklpWVdR0/KSIi21Dbzvtz587V1qxZo508eVLbtWuXNn78eM3FxUWLiYkx7vPqq6/Kz1q5cqW2f/9++XehcePGWmZmZjX+5IiIaidbO++nVtP1PoNuuqHEP3Lxy+Dk5CRT/2/fvt3s9dmzZ8tfvqIPkc7/eo4rLoYefvhhzcfHR3Nzc9NGjRolf+ELa9Sokfz8igbdGRkZ2oABAzR/f39ZokC8f+rUqWa//EREdV1tOu8/9thjxmMGBgZqQ4YM0Xbv3l2sbNjMmTPl6+ICsG/fvtrRo0ev4ydERGRbbOm8n1FN1/s68Z+K94sTERERERERUUVxTjcRERERERGRhTDoJiIiIiIiIrIQBt1EREREREREFsKgm4iIiIiIiMhCGHQTERERERERWQiDbiIiIiIiIiILYdBNREREREREZCEMuomIiIiIiIgshEE3ERFRNZsyZQpGjhxp7WYQERFRDeBg7QYQERHVJjqdrszXZ8+ejXfeeQeapsHagX9SUhJWrFhh1XYQERHVdQy6iYiIKuHixYvG5aVLl2LWrFk4evSocZuHh4d8EBEREQkcXk5ERFQJQUFBxoe3t7fs+S68TQTcRYeX9+rVC4888ggee+wx+Pj4IDAwEAsXLkR6ejruvfdeeHp6omnTpvj999/NPuvgwYMYPHiwPKZ4z6RJk5CQkGB8fdmyZWjTpg1cXV3h6+uLfv36yWPOmTMHX3zxBVauXCnbJx4bNmyQ73n66afRrFkzuLm5oUmTJpg5cyZyc3ONxxTvbd++PT7//HOEhYXJz3744YeRn5+P1157TX7HgIAA/Pe//zVrq/iMDz/8ULZXtEccW7SPiIiormPQTUREdAOIINjPzw87d+6UAfhDDz2EcePGoXv37ti9ezcGDBggg+qMjAy5vxga3qdPH3To0AHR0dFYvXo1Ll++jDvuuMPY437XXXfhvvvuw+HDh2VQPXr0aDmsfcaMGXK/QYMGyf3EQ3yOIAL8xYsX49ChQ3IYvAj+3377bbO2njx5Ut4AEJ+5ZMkSfPbZZxg6dCjOnTuHjRs3Yv78+XjhhRewY8cOs/eJAH7MmDHYt28fJk6ciPHjx8u2ERER1WU6zdqTzoiIiGopEbyK3msRIJc1n1r0dIue4s2bN8t1sSx6yUWQ/OWXX8ptly5dQnBwMLZt24auXbvi5ZdflvuvWbPGeFwR9IaGhsrh7GlpaejUqRPi4uLQqFGjKs/pfuONN/Ddd9/JwL6gp/v111+X7REBuiCCd/GZIhi3s1P365s3by4/45lnnjH2dD/44IOyt7uA+B4dO3bEBx98UMWfMBERUe3HOd1EREQ3QNu2bY3L9vb2cji4GBpeQAwfF+Lj4+Wz6C1ev359ifPDRfAresb79u0rjzFw4EC5PnbsWDl8vSxiHvq7774rjyEC97y8PHh5eZntEx4ebgy4C9om2lwQcBdsK2hrgW7duhVb37t3b7k/GyIiIlvG4eVEREQ3gKOjo9m66BkuvK0gK7per5fPIiAeNmyYDFoLP44fP45bb71VBsFr166Vw8BbtmyJ9957D1FRUYiNjS21DaIXXQz7HjJkCH799Vfs2bMHzz//PHJycirV1oJtBW0lIiKi0jHoJiIiqoHEsOyYmBjZ6yySrBV+uLu7GwPfHj16YO7cuTKAdnJywvLly+VrYlkMYy9s69atcii6CLQ7d+6MyMhInD59utravH379mLrLVq0qLbjExER1UYMuomIiGqgadOmITExUSZL++eff+RwcDG/W2Q7F8G0SGI2b948ORf7zJkz+Omnn3DlyhVjkCuC9f3798u52CLjuchQLoJssa+Ywy2OJ4aZFwTp1eGHH36QWc+PHTsm65WLpHHTp0+vtuMTERHVRgy6iYiIaqCQkBBs2bJFBthivraYuy2SttWrV0/OrRbzsDdt2iSHiosSYCKb+JtvvilLdglTp06Vw81Fj7a/v7881vDhw/H444/LQFiUBRM93yLjeHURPe4ioBfz10WCOJH5XAx9JyIiqsuYvZyIiIiumxjqLnrNC9cnJyIiIvZ0ExEREREREVkMg24iIiIiIiIiC2GdbiIiIrpunK1GRERUMvZ0ExEREREREVkIg24iIiIiIiIiC2HQTURERERERGQhDLqJiIiIiIiILIRBNxEREREREZGFMOgmIiIiIiIishAG3UREREREREQWwqCbiIiIiIiIyEIYdBMRERERERHBMv4fXVBZEosM6TkAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(10, 6))\n",
    "plt.plot(df_agg['source_t'], df_agg['actual'], label='Actual')\n",
    "plt.plot(df_agg['source_t'], df_agg['prediction'], label='Predicted')\n",
    "plt.title(f'Adaptive Random Forest\\nRMSE: {rmse:.4f}, MAE: {mae:.4f}')\n",
    "plt.xlabel('Timestamp')\n",
    "plt.ylabel('Downlink Bitrate')\n",
    "plt.legend()\n",
    "plt.grid(True)\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "75531916",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'\\nhorizon = 96\\nsplit_point = int(len(df) * 0.8)\\ntest_start_time = df.index[split_point]\\n\\ndef train_and_evaluate(seed):\\n    # Initialize model with seed\\n    model = preprocessing.StandardScaler() | forest.ARFRegressor(seed=seed)\\n\\n    records = []\\n    total_training_time = 0.0\\n    total_inference_time = 0.0\\n    test_prediction_count = 0\\n    train_sample_count = 0\\n\\n    for t in range(horizon, len(df) - horizon):\\n\\n        # --- Prediction timing (only for test set) ---\\n        if df.index[t] >= test_start_time:\\n            start_pred = time.time()\\n\\n        for h in range(1, horizon + 1):\\n            idx = t + h\\n            row = df.iloc[idx]\\n            x = {col: row[col] for col in df.columns if col != \\'mac_dl_brate\\'}\\n            pred = model.predict_one(x)\\n            actual = row[\\'mac_dl_brate\\']\\n            timestamp = df.index[idx]\\n            source_t = df.index[t]\\n\\n            records.append({\\n                \\'timestamp\\': timestamp,\\n                \\'source_t\\': source_t,\\n                \\'horizon\\': h,\\n                \\'actual\\': actual,\\n                \\'prediction\\': pred\\n            })\\n\\n        if df.index[t] >= test_start_time:\\n            end_pred = time.time()\\n            total_inference_time += (end_pred - start_pred)\\n            test_prediction_count += horizon  # horizon predictions per test window\\n\\n        # --- Training timing ---\\n        if df.index[t + 1] < test_start_time:\\n            start_train = time.time()\\n            row = df.iloc[t + 1]\\n            x = {col: row[col] for col in df.columns if col != \\'mac_dl_brate\\'}\\n            y = row[\\'mac_dl_brate\\']\\n            model.learn_one(x, y)\\n            end_train = time.time()\\n            total_training_time += (end_train - start_train)\\n            train_sample_count += 1\\n\\n    df_forecasts = pd.DataFrame(records)\\n    df_test_forecasts = df_forecasts[df_forecasts[\\'source_t\\'] >= test_start_time]\\n\\n    # Scale actuals & predictions\\n    train_actuals = df_forecasts[df_forecasts[\\'source_t\\'] < test_start_time][\\'actual\\']\\n    scaler = MinMaxScaler()\\n    scaler.fit(train_actuals.values.reshape(-1, 1))\\n\\n    actual_scaled = scaler.transform(df_test_forecasts[\\'actual\\'].values.reshape(-1, 1)).flatten()\\n    pred_scaled = scaler.transform(df_test_forecasts[\\'prediction\\'].values.reshape(-1, 1)).flatten()\\n\\n    # Metrics\\n    rmse = np.sqrt(mean_squared_error(actual_scaled, pred_scaled))\\n    mae = mean_absolute_error(actual_scaled, pred_scaled)\\n\\n    return rmse, mae\\n\\n\\n# === Run multiple seeds ===\\nseeds = [42, 99, 123]\\nrmse_array = np.empty(len(seeds))\\nmae_array = np.empty(len(seeds))\\n\\nfor i, seed in enumerate(seeds):\\n    print(f\"\\nTraining ARF model with seed {seed}...\")\\n    rmse, mae = train_and_evaluate(seed)\\n    rmse_array[i] = rmse\\n    mae_array[i] = mae\\n    print(f\"Seed {seed} → RMSE: {rmse:.4f}, MAE: {mae:.4f}\")\\n\\n# === Summary ===\\nprint(\"\\n--- Evaluation Summary ---\")\\nprint(f\"RMSE: {rmse_array.mean():.4f} ± {rmse_array.std():.4f}\")\\nprint(f\"MAE : {mae_array.mean():.4f} ± {mae_array.std():.4f}\")\\n'"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "def train_and_evaluate(seed):\n",
    "    model = preprocessing.StandardScaler() | forest.ARFRegressor(seed=seed)\n",
    "\n",
    "    records = []\n",
    "    total_training_time = 0.0\n",
    "    total_inference_time = 0.0\n",
    "    test_prediction_count = 0\n",
    "    train_sample_count = 0\n",
    "\n",
    "    for t in range(horizon, len(df) - horizon):\n",
    "\n",
    "        #Prediction\n",
    "        if df.index[t] >= test_start_time:\n",
    "            start_pred = time.time()\n",
    "\n",
    "        for h in range(1, horizon + 1):\n",
    "            idx = t + h\n",
    "            row = df.iloc[idx]\n",
    "            x = {col: row[col] for col in df.columns if col != 'mac_dl_brate'}\n",
    "            pred = model.predict_one(x)\n",
    "            actual = row['mac_dl_brate']\n",
    "            timestamp = df.index[idx]\n",
    "            source_t = df.index[t]\n",
    "\n",
    "            records.append({\n",
    "                'timestamp': timestamp,\n",
    "                'source_t': source_t,\n",
    "                'horizon': h,\n",
    "                'actual': actual,\n",
    "                'prediction': pred\n",
    "            })\n",
    "\n",
    "        if df.index[t] >= test_start_time:\n",
    "            end_pred = time.time()\n",
    "            total_inference_time += (end_pred - start_pred)\n",
    "            test_prediction_count += horizon  \n",
    "\n",
    "        #Training\n",
    "        if df.index[t + 1] < test_start_time:\n",
    "            start_train = time.time()\n",
    "            row = df.iloc[t + 1]\n",
    "            x = {col: row[col] for col in df.columns if col != 'mac_dl_brate'}\n",
    "            y = row['mac_dl_brate']\n",
    "            model.learn_one(x, y)\n",
    "            end_train = time.time()\n",
    "            total_training_time += (end_train - start_train)\n",
    "            train_sample_count += 1\n",
    "\n",
    "    df_forecasts = pd.DataFrame(records)\n",
    "    df_test_forecasts = df_forecasts[df_forecasts['source_t'] >= test_start_time]\n",
    "\n",
    "    train_actuals = df_forecasts[df_forecasts['source_t'] < test_start_time]['actual']\n",
    "    scaler = MinMaxScaler()\n",
    "    scaler.fit(train_actuals.values.reshape(-1, 1))\n",
    "\n",
    "    actual_scaled = scaler.transform(df_test_forecasts['actual'].values.reshape(-1, 1)).flatten()\n",
    "    pred_scaled = scaler.transform(df_test_forecasts['prediction'].values.reshape(-1, 1)).flatten()\n",
    "\n",
    "    rmse = np.sqrt(mean_squared_error(actual_scaled, pred_scaled))\n",
    "    mae = mean_absolute_error(actual_scaled, pred_scaled)\n",
    "\n",
    "    return rmse, mae\n",
    "\n",
    "\n",
    "#Run multiple seeds\n",
    "seeds = [42, 99, 123]\n",
    "rmse_array = np.empty(len(seeds))\n",
    "mae_array = np.empty(len(seeds))\n",
    "\n",
    "for i, seed in enumerate(seeds):\n",
    "    print(f\"\\nTraining ARF model with seed {seed}...\")\n",
    "    rmse, mae = train_and_evaluate(seed)\n",
    "    rmse_array[i] = rmse\n",
    "    mae_array[i] = mae\n",
    "    print(f\"Seed {seed} → RMSE: {rmse:.4f}, MAE: {mae:.4f}\")\n",
    "\n",
    "# Summary\n",
    "print(\"\\nEvaluation Summary\")\n",
    "print(f\"RMSE: {rmse_array.mean():.4f} ± {rmse_array.std():.4f}\")\n",
    "print(f\"MAE : {mae_array.mean():.4f} ± {mae_array.std():.4f}\")"
   ]
  }
 ],
 "metadata": {
  "colab": {
   "provenance": []
  },
  "kernelspec": {
   "display_name": "river-env",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
