{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "\n",
    "method = 'AdaRHD'\n",
    "methodopt = 'gd'\n",
    "ratio = 0.05"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 306 epochs\n",
      "Experiment 2 has 306 epochs\n",
      "Experiment 3 has 306 epochs\n",
      "Experiment 4 has 306 epochs\n",
      "Experiment 5 has 306 epochs\n"
     ]
    }
   ],
   "source": [
    "lr = 5.0\n",
    "with open(f'../results/hyrep_spd_{method}_{methodopt}_lr{lr}data_ratio{ratio}.pkl', 'rb') as handle:\n",
    "    data = pickle.load(handle)\n",
    "\n",
    "# Get the accuracy data from the data dictionary\n",
    "all_gradnorms = data['total_hgradnorm']\n",
    "new_all_gradnorms = []\n",
    "for i in range(len(all_gradnorms)):\n",
    "    new_all_gradnorms.append(all_gradnorms[i].cummin(dim=1)[0])\n",
    "all_gradnorms = new_all_gradnorms\n",
    "\n",
    "# Determine how many experiments we have\n",
    "num_experiments = len(all_gradnorms)\n",
    "print(f\"Found {num_experiments} experiments in the data\")\n",
    "\n",
    "# Prepare arrays for storing padded data\n",
    "train_gradnorms = []\n",
    "max_epochs = 301  # Target length for all experiments\n",
    "\n",
    "# Process each experiment\n",
    "for i in range(num_experiments):\n",
    "    # Extract accuracy data and reshape\n",
    "    train_gradnorm = all_gradnorms[i].reshape(-1)\n",
    "\n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(train_gradnorm)\n",
    "    print(f\"Experiment {i+1} has {num_epochs} epochs\")\n",
    "    \n",
    "    # If less than max_epochs, pad with the last value\n",
    "    if num_epochs < max_epochs:\n",
    "        train_gradnorm = np.pad(train_gradnorm, (0, max_epochs - num_epochs), \n",
    "                            'constant', constant_values=train_gradnorm[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        train_gradnorm = train_gradnorm[:max_epochs]\n",
    "        train_gradnorm = train_gradnorm.numpy()\n",
    "    \n",
    "    \n",
    "    # Add to our list\n",
    "    train_gradnorms.append(train_gradnorm)\n",
    "\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_gradnorms1 = np.array(train_gradnorms)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 306 epochs\n",
      "Experiment 2 has 306 epochs\n",
      "Experiment 3 has 306 epochs\n",
      "Experiment 4 has 306 epochs\n",
      "Experiment 5 has 306 epochs\n"
     ]
    }
   ],
   "source": [
    "lr = 1.0\n",
    "with open(f'../results/hyrep_spd_{method}_{methodopt}_lr{lr}data_ratio{ratio}.pkl', 'rb') as handle:\n",
    "    data = pickle.load(handle)\n",
    "\n",
    "# Get the accuracy data from the data dictionary\n",
    "all_gradnorms = data['total_hgradnorm']\n",
    "new_all_gradnorms = []\n",
    "for i in range(len(all_gradnorms)):\n",
    "    new_all_gradnorms.append(all_gradnorms[i].cummin(dim=1)[0])\n",
    "all_gradnorms = new_all_gradnorms\n",
    "\n",
    "# Determine how many experiments we have\n",
    "num_experiments = len(all_gradnorms)\n",
    "print(f\"Found {num_experiments} experiments in the data\")\n",
    "\n",
    "# Prepare arrays for storing padded data\n",
    "train_gradnorms = []\n",
    "max_epochs = 301  # Target length for all experiments\n",
    "\n",
    "# Process each experiment\n",
    "for i in range(num_experiments):\n",
    "    # Extract accuracy data and reshape\n",
    "    train_gradnorm = all_gradnorms[i].reshape(-1)\n",
    "\n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(train_gradnorm)\n",
    "    print(f\"Experiment {i+1} has {num_epochs} epochs\")\n",
    "    \n",
    "    # If less than max_epochs, pad with the last value\n",
    "    if num_epochs < max_epochs:\n",
    "        train_gradnorm = np.pad(train_gradnorm, (0, max_epochs - num_epochs), \n",
    "                            'constant', constant_values=train_gradnorm[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        train_gradnorm = train_gradnorm[:max_epochs]\n",
    "        train_gradnorm = train_gradnorm.numpy()\n",
    "    \n",
    "    \n",
    "    \n",
    "    # Add to our list\n",
    "    train_gradnorms.append(train_gradnorm)\n",
    "\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_gradnorms2 = np.array(train_gradnorms)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 306 epochs\n",
      "Experiment 2 has 306 epochs\n",
      "Experiment 3 has 306 epochs\n",
      "Experiment 4 has 306 epochs\n",
      "Experiment 5 has 306 epochs\n"
     ]
    }
   ],
   "source": [
    "lr = 0.5\n",
    "with open(f'../results/hyrep_spd_{method}_{methodopt}_lr{lr}data_ratio{ratio}.pkl', 'rb') as handle:\n",
    "    data = pickle.load(handle)\n",
    "\n",
    "# Get the accuracy data from the data dictionary\n",
    "all_gradnorms = data['total_hgradnorm']\n",
    "new_all_gradnorms = []\n",
    "for i in range(len(all_gradnorms)):\n",
    "    new_all_gradnorms.append(all_gradnorms[i].cummin(dim=1)[0])\n",
    "all_gradnorms = new_all_gradnorms\n",
    "\n",
    "# Determine how many experiments we have\n",
    "num_experiments = len(all_gradnorms)\n",
    "print(f\"Found {num_experiments} experiments in the data\")\n",
    "\n",
    "# Prepare arrays for storing padded data\n",
    "train_gradnorms = []\n",
    "max_epochs = 301  # Target length for all experiments\n",
    "\n",
    "# Process each experiment\n",
    "for i in range(num_experiments):\n",
    "    # Extract accuracy data and reshape\n",
    "    train_gradnorm = all_gradnorms[i].reshape(-1)\n",
    "\n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(train_gradnorm)\n",
    "    print(f\"Experiment {i+1} has {num_epochs} epochs\")\n",
    "    \n",
    "    # If less than max_epochs, pad with the last value\n",
    "    if num_epochs < max_epochs:\n",
    "        train_gradnorm = np.pad(train_gradnorm, (0, max_epochs - num_epochs), \n",
    "                            'constant', constant_values=train_gradnorm[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        train_gradnorm = train_gradnorm[:max_epochs]\n",
    "        train_gradnorm = train_gradnorm.numpy()\n",
    "        \n",
    "    # Add to our list\n",
    "    train_gradnorms.append(train_gradnorm)\n",
    "\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_gradnorms3 = np.array(train_gradnorms)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 306 epochs\n",
      "Experiment 2 has 306 epochs\n",
      "Experiment 3 has 306 epochs\n",
      "Experiment 4 has 306 epochs\n",
      "Experiment 5 has 306 epochs\n"
     ]
    }
   ],
   "source": [
    "lr = 0.1\n",
    "with open(f'../results/hyrep_spd_{method}_{methodopt}_lr{lr}data_ratio{ratio}.pkl', 'rb') as handle:\n",
    "    data = pickle.load(handle)\n",
    "\n",
    "# Get the accuracy data from the data dictionary\n",
    "all_gradnorms = data['total_hgradnorm']\n",
    "new_all_gradnorms = []\n",
    "for i in range(len(all_gradnorms)):\n",
    "    new_all_gradnorms.append(all_gradnorms[i].cummin(dim=1)[0])\n",
    "all_gradnorms = new_all_gradnorms\n",
    "\n",
    "# Determine how many experiments we have\n",
    "num_experiments = len(all_gradnorms)\n",
    "print(f\"Found {num_experiments} experiments in the data\")\n",
    "\n",
    "# Prepare arrays for storing padded data\n",
    "train_gradnorms = []\n",
    "max_epochs = 301  # Target length for all experiments\n",
    "\n",
    "# Process each experiment\n",
    "for i in range(num_experiments):\n",
    "    # Extract accuracy data and reshape\n",
    "    train_gradnorm = all_gradnorms[i].reshape(-1)\n",
    "\n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(train_gradnorm)\n",
    "    print(f\"Experiment {i+1} has {num_epochs} epochs\")\n",
    "    \n",
    "    # If less than max_epochs, pad with the last value\n",
    "    if num_epochs < max_epochs:\n",
    "        train_gradnorm = np.pad(train_gradnorm, (0, max_epochs - num_epochs), \n",
    "                            'constant', constant_values=train_gradnorm[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        train_gradnorm = train_gradnorm[:max_epochs]\n",
    "        train_gradnorm = train_gradnorm.numpy()\n",
    "    \n",
    "    \n",
    "    # Add to our list\n",
    "    train_gradnorms.append(train_gradnorm)\n",
    "\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_gradnorms4 = np.array(train_gradnorms)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 306 epochs\n",
      "Experiment 2 has 306 epochs\n",
      "Experiment 3 has 306 epochs\n",
      "Experiment 4 has 306 epochs\n",
      "Experiment 5 has 306 epochs\n"
     ]
    }
   ],
   "source": [
    "lr = 0.05\n",
    "with open(f'../results/hyrep_spd_{method}_{methodopt}_lr{lr}data_ratio{ratio}.pkl', 'rb') as handle:\n",
    "    data = pickle.load(handle)\n",
    "\n",
    "# Get the accuracy data from the data dictionary\n",
    "all_gradnorms = data['total_hgradnorm']\n",
    "new_all_gradnorms = []\n",
    "for i in range(len(all_gradnorms)):\n",
    "    new_all_gradnorms.append(all_gradnorms[i].cummin(dim=1)[0])\n",
    "all_gradnorms = new_all_gradnorms\n",
    "\n",
    "# Determine how many experiments we have\n",
    "num_experiments = len(all_gradnorms)\n",
    "print(f\"Found {num_experiments} experiments in the data\")\n",
    "\n",
    "# Prepare arrays for storing padded data\n",
    "train_gradnorms = []\n",
    "max_epochs = 301  # Target length for all experiments\n",
    "\n",
    "# Process each experiment\n",
    "for i in range(num_experiments):\n",
    "    # Extract accuracy data and reshape\n",
    "    train_gradnorm = all_gradnorms[i].reshape(-1)\n",
    "\n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(train_gradnorm)\n",
    "    print(f\"Experiment {i+1} has {num_epochs} epochs\")\n",
    "    \n",
    "    # If less than max_epochs, pad with the last value\n",
    "    if num_epochs < max_epochs:\n",
    "        train_gradnorm = np.pad(train_gradnorm, (0, max_epochs - num_epochs), \n",
    "                            'constant', constant_values=train_gradnorm[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        train_gradnorm = train_gradnorm[:max_epochs]\n",
    "        train_gradnorm = train_gradnorm.numpy()\n",
    "    \n",
    "    \n",
    "    \n",
    "    # Add to our list\n",
    "    train_gradnorms.append(train_gradnorm)\n",
    "\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_gradnorms5 = np.array(train_gradnorms)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAeoAAAGGCAYAAAC0W8IbAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/xnp5ZAAAACXBIWXMAAA9hAAAPYQGoP6dpAACeh0lEQVR4nOy9eZxU1Zn//75b7d3VezcNNDsqLqAoqIkaIgnBREeTOCaTKGLG33wzaDJfknEk30SNMWEyGmOiZMwkMWQZJ5pEzb5JdMiiUVDcEYEGGnrfaq+66++P01XdDQ003dV0N5y3r2tV3Tp176mqpj73ec6zKJ7neUgkEolEIpmQqOM9AYlEIpFIJIdHCrVEIpFIJBMYKdQSiUQikUxgpFBLJBKJRDKBkUItkUgkEskERgq1RCKRSCQTGCnUEolEIpFMYKRQSyQSiUQygdHHewInCq7r0tzcTElJCYqijPd0JBKJRHIc8TyPRCJBfX09qlpcG1gKdZFobm5m+vTp4z0NiUQikYwjTU1NTJs2rajHlEJdJEpKSgDxJZWWlo7zbCQSiURyPInH40yfPr2gBcVECnWRyLu7S0tLpVBLJBLJScpYLH3KYLJRsmHDBhYsWMB555033lORSCQSyQmIIrtnFYd4PE40GiUWi0mLWiKRSE4yxlIDpEUtkUgkEskERq5RSyQSyUmG67qYpjne05hUGIaBpmnjcm4p1BKJRHISYZomjY2NuK473lOZdJSVlVFXV3fca2VIoZZIJJKTBM/zaGlpQdM0pk+fXvTCHCcqnueRTqdpb28HYMqUKcf1/FKoDyKdTnPaaadx9dVXc88994z3dCQSiaRo2LZNOp2mvr6eUCg03tOZVASDQQDa29upqak5rm5weTl1EF/84hc5//zzx3saEolEUnQcxwHA5/ON80wmJ/mLG8uyjut5pVAP4K233mL79u2sXLlyvKcikUgkY4bsRzAyxutzO2GEevPmzVx++eXU19ejKApPPPHEIWM2bNjAzJkzCQQCLF26lOeee27Q85/+9KdZv379cZqxRCKRSCRH54QR6lQqxcKFC9mwYcOQzz/yyCOsXbuW22+/nRdeeIGFCxeyYsWKQnDAz372M+bPn8/8+fOP57QlEolEIjkiJ4xQr1y5krvuuourrrpqyOfvvfdebrzxRlavXs2CBQt48MEHCYVCPPTQQwA8++yz/OhHP2LmzJl8+tOf5lvf+hZ33nnnYc+Xy+WIx+ODNoDn19+Ba9vFf4MSiURyknLHHXegKMqg7dRTTx3vaR03ThihPhKmabJ161aWL19e2KeqKsuXL+eZZ54BYP369TQ1NbFnzx7uuecebrzxRm677bbDHnP9+vVEo9HClm9x2buzg2T7gbF9QxKJRHKScfrpp9PS0lLY/vznP4/3lI4bJ4VQd3Z24jgOtbW1g/bX1tbS2to6omOuW7eOWCxW2JqamgBIJj3SaWfUc5ZIJBJJP7quU1dXV9iqqqrGe0rHDZlHPQTXX3/9Ucf4/X78fj8bNmxgw4YNhbQHPHAd2edEIpFMfDwP0unxOXcoBMcSRP3WW29RX19PIBDgggsuYP369TQ0NIzdBCcQJ4VQV1VVoWkabW1tg/a3tbVRV1c3qmOvWbOGNWvWFDqneHi4jrSoJRLJxCedhkhkfM6dTEI4PLyxS5cuZePGjZxyyim0tLTw+c9/nosuuohXX32VkpKSsZ3oBOCkcH37fD4WL17Mpk2bCvtc12XTpk1ccMEFozr2wf2orecSIEvoSiQSSdFYuXIlV199NWeddRYrVqzg17/+Nb29vTz66KPjPbXjwgljUSeTSXbu3Fl43NjYyLZt26ioqKChoYG1a9eyatUqzj33XJYsWcJ9991HKpVi9erVozrvwRZ1e88MXEcqtUQimfiEQsKyHa9zj5SysjLmz58/6Df/ROaEEeotW7awbNmywuO1a9cCsGrVKjZu3Mg111xDR0cHt912G62trSxatIjf/va3hwSYHSsHr1F7KP3r1RKJRDKBUZThu58nEslkkl27dnHttdeO91SOC4rneTLyqQjkLeo7+QQf2fL/MXvx6eM9JYlEIhlENpulsbGRWbNmEQgExns6w+bTn/40l19+OTNmzKC5uZnbb7+dbdu28frrr1NdXX3c5nGkzy+vAbFYjNLS0qKe94SxqCcKHooMJpNIJJIisn//fj784Q/T1dVFdXU1b3/723n22WePq0iPJ1KoR8lQrm/Zj10ikUiKx49+9KPxnsK4clJEfY8la9as4fXXX+f5558HhFB7trSoJRKJRFIcpFAXGQ9FVBGQSCQSiaQISKEeJQfnUXsouJ70fUskEomkOEihHiVDub4tU1rUEolEIikOUqiLjIeCZY33LCQSiURyoiCFusgIoZaub4lEIpEUBynUo2SoNWorJ4VaIpFIJMVBCvUoGWqN2pRr1BKJRCIpElKox4BsWi5SSyQSiaQ4SKEeA8xsdrynIJFIJCcUmzdv5vLLL6e+vh5FUXjiiSfGe0rHDSnUY4CTtcd7ChKJRHJCkUqlWLhwIRs2bBjvqRx3ZK3vUXJwrW8AM2eO44wkEonkxGPlypWsXLlyvKcxLkiLepQcHEwGYEmLWiKRSCRFQlrUY4BpSotaIpFMfDzPI22lx+XcISOEoijjcu7JhhTqMcAxpUUtkUgmPmkrTWR9ZFzOnVyXJOwLj8u5JxvS9T0G2DmZniWRSCSS4iAt6jFAWtQSiWQyEDJCJNclx+3ckuEhhXoMsC3n6IMkEolknFEUZdK4n5PJJDt37iw8bmxsZNu2bVRUVNDQ0DCOMxt7pFCPAa4jhVoikUiKyZYtW1i2bFnh8dq1awFYtWoVGzduHKdZHR+kUI+SofKoXdnnUiKRSIrKO97xDjzv5OyjIIPJRslQedSOLS1qiUQikRQHKdRjgOfINpcSiUQiKQ5SqMcA15ZCLZFIJJLiIIV6DPAcuUYtkUgkkuIghXoM8OyTM+BBIpFIJMVHCnUfvb29nHvuuSxatIgzzjiDb33rWyM+lufKYDKJRCKRFAeZntVHSUkJmzdvJhQKkUqlOOOMM3j/+99PZWXlMR/Lc+UatUQikUiKg7So+9A0jVBIlLTL5XJ4njfinD1FCrVEIpFIisQJI9SbN2/m8ssvp76+HkVReOKJJw4Zs2HDBmbOnEkgEGDp0qU899xzg57v7e1l4cKFTJs2jX/913+lqqpqRHNxpetbIpFIJEXihBHqVCrFwoUL2bBhw5DPP/LII6xdu5bbb7+dF154gYULF7JixQra29sLY8rKynjppZdobGzk4Ycfpq2tbWST8aRFLZFIJJLicMII9cqVK7nrrru46qqrhnz+3nvv5cYbb2T16tUsWLCABx98kFAoxEMPPXTI2NraWhYuXMif/vSnw54vl8sRj8cHbXmk61sikUiKz9G8ogPZuHEjiqIM2gKBwHGcbfE4YYT6SJimydatW1m+fHlhn6qqLF++nGeeeQaAtrY2EokEALFYjM2bN3PKKacc9pjr168nGo0WtunTpxee81yZniWRSCTFZDhe0YMpLS2lpaWlsO3du/c4zrh4nBRC3dnZieM41NbWDtpfW1tLa2srAHv37uWiiy5i4cKFXHTRRdx8882ceeaZhz3munXriMViha2pqanwnHKSFo6XSCSSseJYvKJ5FEWhrq6usB2sAZMFmZ7Vx5IlS9i2bduwx/v9fvx+/5Dds/BkMJlEIpEUi7xXdN26dYV9B3tFhyKZTDJjxgxc1+Wcc87hS1/6EqeffvrxmHJROSmEuqqqCk3TDgkOa2tro66ublTHXrNmDWvWrCEejxONRgFQpOtbIpFMBjwPnPT4nFsLgaIMa+iRvKLbt28f8jWnnHIKDz30EGeddRaxWIx77rmHCy+8kNdee41p06aNevrHk5NCqH0+H4sXL2bTpk1ceeWVALiuy6ZNm7jppptGdeyhLGoPKdQSiWQS4KTh0cj4nPvvk6CHx+zwF1xwARdccEHh8YUXXshpp53GN7/5Tb7whS+M2XnHghNGqJPJJDt37iw8bmxsZNu2bVRUVNDQ0MDatWtZtWoV5557LkuWLOG+++4jlUqxevXqUZ1XWtQSiUQythTDK2oYBmefffYgnZgsnDBCvWXLFpYtW1Z4vHbtWgBWrVrFxo0bueaaa+jo6OC2226jtbWVRYsW8dvf/nbUwQVDWdSKzKOWSCSTAS0kLNvxOvcwKYZX1HEcXnnlFS677LKRzHZcGbVQd3V18atf/YrXXnuN3t5eLOvwLR4VReE73/nOaE85JO94xzuOWvLzpptuGrWr+2CGsqhBCrVEIpkEKMqYup+LydG8otdddx1Tp05l/fr1ANx5552cf/75zJ07l97eXu6++2727t3LP/7jP47n2xgRoxLqL33pS9x1113kcjmAowrlWAr1hELqtEQikRSVo3lF9+3bh6r2Zxz39PRw44030traSnl5OYsXL+avf/0rCxYsGK+3MGJGLNQbNmzgs5/9LADz5s1j2bJl1NTUoGla0SY3GRja9S3XqCUSiaTYHMkr+vTTTw96/NWvfpWvfvWrx2FWY8+IhfqBBx5AURRuvvlm7rvvviJOaXIxZDCZNKklEolEUiRGXJlsz549qKrKF7/4xWLO5wRBWtQSiUQiKQ4jFura2loikQjh8OQIRBgrNmzYwIIFCzjvvPMK+1SZniWRSCSSIjFioX7Pe95DPB7nzTffLOZ8Jh1r1qzh9ddf5/nnnx/vqUgkEonkBGTEQv25z32Ouro6/umf/olUKlXMOU1+PA8ZTyaRSCSSYjDiYLKpU6fyxz/+kWuvvZZZs2bxf/7P/+GMM844apWYiy++eKSnnDSofUI9zDK2EolEIpEcllHlUSuKwtSpU9myZcuwgsoURcG27dGccsIxZPcsPFwX1JOiiahEIpFIxpIRC/Xrr7/OxRdfTE9PDyDaPubrsZ5MDJmeJV3fEolEIikSIxbqdevW0d3dzYIFC/iv//ovLrjgAhTp6wVA8ZBCLZFIJJKiMGKh/vOf/4yiKPzkJz/h1FNPLeacTgCE61sikUgkktEy4lVU13UpKSmRIj0E0vUtkUgkxWfDhg3MnDmTQCDA0qVLee655w479rXXXuMDH/gAM2fORFGUSV1Bc8RCvWjRItLpNMnkOLVIm8Co0qKWSCSSovLII4+wdu1abr/9dl544QUWLlzIihUraG9vH3J8Op1m9uzZ/Pu///uwe1ZPVEYs1LfccguO45wwRc9HylCVyZBr1BKJRFJU7r33Xm688UZWr17NggULePDBBwmFQjz00ENDjj/vvPO4++67+dCHPoTf7z/Osy0uI16jXrlyJffffz+f+tSn2L9/P7fccgtz5swp5twmBUM35ZCub4lEMgnwPEinx+fcodCwi02YpsnWrVtZt25dYZ+qqixfvpxnnnlmrGY4YRixUM+ePRsATdP49re/zbe//W0CgUChN+hQKIrCrl27RnrKSYUUaolEMuFJpyESGZ9zJ5MwzF4RnZ2dOI5ziL7U1tayffv2sZjdhGLEQr1nz55D9mUymSH35zlZ0rcUD7lGLZFIJJKiMGKhfuqpp4o5jxMK6fqWSCSTglBIWLbjde5hki+m1dbWNmh/W1vbpA8UGw4jFupLLrmkmPM4oZAWtUQimRQoyrDdz+OJz+dj8eLFbNq0iSuvvBIQKcKbNm3ipptuGt/JHQdGLNTl5eWoqsrzzz9fWK+WCBSkUEskEkkxWbt2LatWreLcc89lyZIl3HfffaRSKVavXg3Addddx9SpU1m/fj0gAtBef/31wv0DBw6wbds2IpEIc+fOHbf3MRJGLNSmaeLz+U56kR6qKYfieQzq0SGRSCSSUXHNNdfQ0dHBbbfdRmtrK4sWLeK3v/1tIcBs3759qAM6ITU3N3P22WcXHt9zzz3cc889XHLJJTz99NPHe/qjQvG8ka2mnnHGGezatYtUKjXowzlZyadn3cqt1M/axRVPPcqMGeM9K4lEIuknm83S2NjIrFmzCAQC4z2dSceRPr+8BsRiMUpLS4t63hEr7NVXX41pmvz85z8v5nxOCBTgBOvmKZFIJJJxYsRC/W//9m+cc8453HjjjZPOjTDWKHjkcuM9C4lEIpGcCIx4jfo//uM/uPTSS/nGN77BpZdeysKFCzn//POprq4+Yk/q2267baSnnDQoHpjmeM9CIpFIJCcCIxbqO+64A0VRyC9xb9u2jZdeeumw4z3PQ1GUk0SopUUtkUgkkuIwYqG+7rrrTqhKY01NTVx77bW0t7ej6zqf+9znuPrqq0d0LAVpUUskEomkOIxYqDdu3FjEaYw/uq5z3333sWjRIlpbW1m8eDGXXXYZ4REUA5AWtUQikUiKxYiF+kRjypQpTJkyBYC6ujqqqqro7u4ekVADWFYxZyeRSCSSk5UTJgF68+bNXH755dTX16MoCk888cQhYzZs2MDMmTMJBAIsXbqU5557bshjbd26FcdxmD59+ojmonpIi1oikUgkRWHUQu04Do888ghXX301c+fOJRqNEo1GmTt3LldffTWPPvrooKpdY0UqlWLhwoVs2LBhyOcfeeQR1q5dy+23384LL7zAwoULWbFiBe3t7YPGdXd3c9111/Ff//Vfo5qPFGqJRCKRFINRub53797NBz/4wUK098AiZ4lEgt27d/PYY4+xaNEifvKTnzBr1qzRzfYIrFy5kpUrVx72+XvvvZcbb7yxUBf2wQcf5Fe/+hUPPfQQt956KwC5XI4rr7ySW2+9lQsvvPCI58vlcuQGqHE8Hu9/Uq5RSyQSiaRIjNiijsfjXHrppWzbtg2Av/u7v+NrX/saTzzxBE888QRf+9rXCl1OXnzxRS699NLBYnYcMU2TrVu3snz58sI+VVVZvnw5zzzzDCAuMq6//nre+c53cu211x71mOvXry94D6LR6CA3uYIio74lEomkyAx3+TLPj3/8Y0499VQCgQBnnnkmv/71rwc9f/3116MoyqDtPe95z1i+hRExYqG+55572Lt3L7NmzeLll1/mscce4+abb+aKK67giiuu4Oabb+axxx7jpZdeYubMmezdu5evfOUrxZz7sOns7MRxnELx9jy1tbW0trYC8Je//IVHHnmEJ554gkWLFrFo0SJeeeWVwx5z3bp1xGKxwtbU1NT/pOdJoZZIJJIiMtzlyzx//etf+fCHP8zHPvYxXnzxRa688kquvPJKXn311UHj3vOe99DS0lLY/ud//ud4vJ1jYsRC/fjjj6MoChs3buT0008/7LgzzjiD7373u3iex2OPPTbS0405b3/723Fdl23bthW2M88887Dj/X4/paWl/OAHP+D888/n0ksvLTwnLWqJRCIpLgOXLxcsWMCDDz5IKBTioYceGnL81772Nd7znvfwr//6r5x22ml84Qtf4JxzzuGBBx4YNM7v91NXV1fYysvLj8fbOSZGLNSNjY2Ew2Euuuiio4695JJLCIfDNDY2jvR0o6KqqgpN02hraxu0v62tjbq6ulEde82aNbz++us8//zzhX2KtKglEskkwPM8zJQ5LtuxNG4czvLlwTzzzDODxgOsWLHikPFPP/00NTU1nHLKKXz84x+nq6vrGD7B48OIg8k0TcMeZosoz/NwXfeINcDHEp/Px+LFi9m0aVNh3dx1XTZt2sRNN900qmMP1Y8aaVFLJJJJgJW2WB9ZPy7nXpdchy/sG9bYIy1fbt++fcjXtLa2HnG5E4Tb+/3vfz+zZs1i165dfOYzn2HlypU888wz46ZXQzFioZ4/fz4vvPACv/rVr3jve997xLG/+c1vyGQynHPOOSM93VFJJpPs3Lmz8LixsZFt27ZRUVFBQ0MDa9euZdWqVZx77rksWbKE++67j1QqVYgCHylr1qxhzZo1hV6kAMimHBKJRDLh+dCHPlS4f+aZZ3LWWWcxZ84cnn766UHLmePNiIX66quvZuvWrXzsYx/j8ccf54ILLhhy3ObNm/nYxz6Goihcc801I57o0diyZQvLli0rPF67di0Aq1atYuPGjVxzzTV0dHRw22230drayqJFi/jtb397yBXXsTKURS1rfUskksmAETJYl1w3buceLiNZvqyrqzvm5c7Zs2dTVVXFzp07J5RQK96xLBQMIJvNsnTpUl555RVUVeWSSy5h2bJlTJ06lVwux759+3j66af529/+hud5nHXWWfztb3/D7/cX+z1MCPIW9a3cyvy6Hbz6Dz9lnILcJRKJZEiy2SyNjY3MmjWLQCAw3tM5JpYuXcqSJUu4//77AbF82dDQwE033VSohTGQa665hnQ6zS9+8YvCvgsvvJCzzjqLBx98cMhz7N+/n4aGBp544gmuuOKKQ54/0ueX14BYLEZpaelo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tkH729raqKurG9Wxh+yeJV3fEolEIikSIxbqSCRCPB7npZdeOurYl156iXg8Xpwc5RHg8/lYvHgxmzZtKuxzXZdNmzYd0WoeDkP2o5YWtUQikUiKxIiF+l3vehee57Fq1SpaWloOO661tZVVq1ahKArvete7Rnq6o5JMJtm2bRvbtm0DhMW/bds29u3bB8DatWv51re+xfe+9z3eeOMNPv7xj5NKpQpR4CNlKIs6H0wmhVoikUgko2VYUd9Dcdddd/HLX/6SV155hVNOOYWPfOQjXHTRRYX0rJaWFjZv3szDDz9MIpEgGo3yhS98oWgTP5gtW7awbNmywuO1a9cCsGrVKjZu3Mg111xDR0cHt912G62trSxatIjf/va3hwSYFQNpUUskEomkWCieN/L6WS+88ALXXHMNu3btOmyOtOd5zJkzh0cffZSzzz57xBOdqGzYsIENGzbgOA47duzgVm6lRsuy1vkqjzwCf//34z1DiUQikYw18XicaDRKLBajtLS0qMceVa3vc845h1dffZXvfOc7XHbZZdTX1+Pz+fD5fNTX1/Pe976X73znO7z66qsnpEjDkV3fMphMIpFIJKNlxK7vPH6/n9WrV496rXeyMtCi7ke6viUSiURSHGT3rFEypEWNtKglEolEUhykUI8BUqglEolEUixG7foGeOqpp3j22WdpaWkhlUpxuPg0RVH4zne+U4xTTmjkGrVEIpFIisWohHrLli1ce+217NixY9D+vFAPjATPt7k80YR6qDVqmZ4lkUgkkmIxYqHeu3cv7373u+nt7eX0009n+fLlfO1rXyMSifAv//IvtLe38/TTT7Njxw4qKyv5p3/6p2GVG51srFmzhjVr1hRC80G6viUSiURSPEYs1P/xH/9Bb28vl19+OT/96U/Rdb0g1HfeeWdh3A9/+ENuvPFGnn32WX73u98VZdITHSnUEolEIikWIw4m+8Mf/oCiKHzpS19C1w+v9x/96Ef5yle+wlNPPcV999030tNNKmQJUYlEIpEUixEL9f79+zEMg9NPP73/YKpKNps9ZOzq1avRNI0f/vCHIz3dhEU25ZBIJBLJWDJioQ4EAod0wyopKSEWi5E7SKGCwSDhcJhdu3aN9HQTliPlUdv2eM1KIpFIJCcKIxbqadOm0dvbi2VZhX1z584F4Nlnnx00dt++fcRisZGeatIhhVoikUgkxWLEQr1w4UJc1+XFF18s7FuxYgWe5/Ev//IvNDU1AdDV1cWNN96IoigsXrx49DOeBOSFesA1jEQikUgkI2LEQv2+970Pz/N49NFHC/s++clPUllZycsvv8zMmTOpqamhtraWJ598EkVRWLduXVEmPdGRUd8SiUQiKRYjFuqrrrqKX/ziF1xxxRWFfdXV1fzxj3/knHPOwfM8Ojs7cV2Xuro6fvjDH/Lud7+7KJOeSMhgMolEIpGMJaPqR30k9u3bx4EDBygtLWXBggWH7Vd9opAveHIrtxIgwB3cxnveo/Cb34z3zCQSiUQy1oxlP+oRFzz5+c9/DsCFF15IVVXVIc83NDTQ0NAw8plNchSkRS2RSCSS0TNiob7yyivRdZ3u7u5izueEQcHDNE9sL4JEIpFIxp4RC3VlZSWe5xGJRIo5nxMGIdTgeXCCe/0lEolEMoaMOJhs0aJF9Pb2Sov6MOSF2nXHeyYSiUQimcyMWKg/8YlP4LouX/ziF4s5nxMGBY9cDgZ0v5RIJBKJ5JgZsVBffvnlfPnLX+b+++/n+uuv5+WXXy7mvCYNQ6VnASi4WJa0qCUSiUQyOkacnjV79mwAWltbC7W9g8EglZWVaJo29MkU5YSs9w2Hpmet5xZqpgd54w0Ih8d7dhKJRCIZSyZketaePXsO2ZdOp0mn04d9zYmeSz0YW65RSyQSiWTUjFion3rqqWLO44RDUywp1BKJRCIZNSMW6ksuuaSY8zjhMNQcliWDySQSiUQyOkYcTCY5MrpmSotaIpFIJKNGCvUAfvnLX3LKKacwb948vv3tb4/qWIZqSotaIpFIJKNmxK7vO++885jG+/1+ysrKOPXUU1myZAnBYHCkpx4TbNtm7dq1PPXUU0SjURYvXsxVV11FZWXlMR1HQQTR60oOz4NsdixmK5FIJJKThREL9R133DHiKO6SkhL+6Z/+iTvuuGPCCPZzzz3H6aefztSpUwFYuXIlv//97/nwhz98TMfJC7WhWgAcIQheIpFIJJKjMmLX93XXXce1115LNBot1Py+5JJLuOaaa7jmmmu45JJLiEQieJ5HWVkZH/3oR/m7v/s7GhoaiMfj3HPPPVx22WXYtl2UN7J582Yuv/xy6uvrURSFJ5544pAxGzZsYObMmQQCAZYuXcpzzz1XeK65ubkg0gBTp07lwIEDxzyPgkWtitzyVOqYDyGRSCQSSYERC/VDDz1Eb28v6XSar3/967S3t/PHP/6Rhx9+mIcffpg//vGPdHR08PWvf72QX/3YY4/R2NjIj3/8Y0KhEJs3b+Y73/lOUd5IKpVi4cKFbNiwYcjnH3nkEdauXcvtt9/OCy+8wMKFC1mxYgXt7e1FOX+evFAHDROATKaoh5dIJBLJScaIhfree+/lF7/4Bd/4xje46aab8Pv9h4zx+XzcdNNNbNiwgccee4yvfe1rAHzgAx/g7rvvxvM8Hn744ZHPfgArV67krrvu4qqrrjrsfG+88UZWr17NggULePDBBwmFQjz00EMA1NfXD7KgDxw4QH19/WHPl8vliMfjgzboF2q/LoRaur4lEolEMhpGLNQbN27EMAyuu+66o4699tprMQxjkPX8kY98BFVVee2110Y6hWFjmiZbt25l+fLlhX2qqrJ8+XKeeeYZAJYsWcKrr77KgQMHSCaT/OY3v2HFihWHPeb69euJRqOFbfr06cBAi1pEkUnXt0QikUhGw4iFurGxkWAwiK4fPR7NMAyCweCgOt8lJSWUlZWRTCZHOoVh09nZieM41NbWDtpfW1tLa2srALqu85WvfIVly5axaNEiPvWpTx0x4nvdunXEYrHC1tTUBPQLdUBa1BKJRCIpAiOO+o5EInR2dvLqq69yxhlnHHHsK6+8QiwWo7q6urDPcRxisRg1NTUjnULRueKKK7jiiiuGNdbv9+P3+9mwYQMbNmzA6UuY7hdqEUyWSIzNXCUSiURycjBii/qd73wnnudx/fXX09HRcdhxHR0drF69GkVRuPTSSwv7d+/ejeM4BZfxWFJVVYWmabS1tQ3a39bWRl1d3aiOvWbNGl5//XWef/554FChlq5viUQikYyGEVvUd911F7/61a948cUXmTdvHtdeey0XXnghU6ZMAaClpYW//vWv/PCHPyQWixGJRAYVSfnv//5vgEHiPVb4fD4WL17Mpk2buPLKKwFwXZdNmzZx0003jerYQ1nUHmBoUqglEolEMnpGLNRz5szhD3/4A9dccw379u3jG9/4Bt/4xjcOGed5Hg0NDfzoRz9i7ty5hf0LFy7kP//zP48YsHUsJJNJdu7cWXjc2NjItm3bqKiooKGhgbVr17Jq1SrOPfdclixZwn333UcqlWL16tWjOu+aNWtYs2ZNoRepiosL+BUp1BKJRCIZPSMWaoClS5eyfft2fvCDH/Czn/2Ml156ic7OTkC4mxcuXMgVV1zBtddee0gFssOlUY2ULVu2sGzZssLjtWvXArBq1So2btzINddcQ0dHB7fddhutra0sWrSI3/72t4cEmI2WMCliVBGwZTCZRCKRSEaP4nmeN5IX5vOGw+EwmqYVdVKTiYGu7x07dvAd5QM0eWcSm2Pw1V2fYfVq6EvVlkgkEskJSt6rGovFKC0tLeqxRxxMVlZWRkVFBc3NzcWcz6Tj4GCyqBIDwGeK0qi53LhNTSKRSCQnACMW6kgkQmlp6XGJ2p7IbNiwgQULFnDeeecBUKoKodZzIrhMds+SSCQSyWgYsVDPmzePVCqFaZrFnM+k42CLukQVSwJaVqwonOQfj0QikUhGyYiF+tprr8WyLH74wx8Wcz6TnmifRa3kRAtQ6fqWSCQSyWgYcdT3Jz7xCTZt2sTNN9+Mqqpcd911qOqIdf+EobTPoianoBm9pC0fpqOjKioKw+/fraknb4CeRCKRSPoZsVD/4z/+I5WVlWiaxsc+9jFuueUWzj33XKqrqw8bBa4oStHaWk4UDi54ElbT6FjYGJR+fDZ/qejBf9exHVNB4V1z3sXN592MohxZ3HVVpzZSS1APoiqHv1DSVA1DNfBpPnyaD10VX31AD2BoxrFNUCKRSCTHjRGnZ6mqiqIoHMvLFUUpCNqJRj40v3eGxg/2fpwuqti4aiN7Zu0Z8THPnXIuNeEj10Iv8ZdQE67Bp/rQtT7LvU/cFRQURUFBQVd0Qr4QPs2HoRpC1BXwq378hh9d0QtWvIpKwAgQ8UUI6kECeoCgESRkhAjqQUr8JUe8KJBIJJKTjbFMzxqxRX377bcXcx4nDMqKaqL/FaOLKqZ9/zvsMZYw5bRG/u4T/8uC0xmW8/v55uf5/svfZ0vLlqLOTVVUIr4IJb4S/Jofn+ajvqSekBHC0IzCvrzFrSoqhmrgN/yU+8sJGSH8up8SXwkzymZQF6mjPFhOxBfBp/mKOleJRCKRCEZsUUsGU7ia+tPtbFm+mT/lLgHgNRbwe97FP6yGT35aYe58P6hHdjVbrsW//v5feaX9FYJG8PADPWhONNOSbMF0TEzHxPXcvmrj4HquGOZ5ON7oPRmVwUpqw7VUhaqoi9QxIzqDGWUzCBpBKoIVVIeqifgilAXKqAhWUOIvGfU5JRKJZDIwlha1FOpRcnBlsljHPoK3zOcP313G8ywFQFUc5jTsZOllrxI4uwH/jEWUVPrw+xRAgUHr0GLf/vh+dvXspixYTsEOV8T/vAF2uYKClhd+Jd+7SwFFw0PBU8TxbE+h29PZSwldtk3Gg7iVpim+n5SZJudkydo5snaWnJMj13c/6+RImSkydmbI96+rOlWhKiqDlZQHy6kN1zK1ZCrzKucxMzqT6dHplAfLKQuUUeIrOeqau0QikUxGJoVQe55HV1cX6XSahoaGYhxyUjHoS3rjX+Gn/8WBb07lyfhy9jCrMK5Oa2FOZBcNlXupWNxN2bJe9OjxW7d30EgYlWT0KK6ioSg6qqqjoPYJvRB2ryCoQvyzjk2vnaPXytFqZnkpneW5eDdvmQ6tNrjAwD8kTdGYUz6H6dHpTCudxvzK+ZxadSozy2YWRF0Kt0QiOVGY0EL9pz/9iS9/+cs8/fTTZDIZFEXBtu3C8729vXzqU59CURS+/vWvEwqFRj3picigLykcgGc/j7nlaXqf7mXbc9NpbJtBq1M/xCs9wkaKcEWacG2WkooMJRVpqqfHmDK3k9LaNLruFTLelcLX5fX938PzXDzPK7i8lYGS6XmAAp6FZsfR3LGpwOIAzW6AvbZCq2WScRwcwPHEczkPLDQMI0zIF6UsVE1tyTTqo7Pwl87GVzqfsshUDM0n5quooPpAD4OvXDyWSCSSCcqEDCYDuPfee7nllltwXfewY8rKyujq6uIXv/gFF198Mdddd91oTjk50Hxwzs34pl5C9dwXmVbVzI7n63l2zxKisTaq6aSCLnx9aVwpK0KqLQJtQxzKD6FqjcpTdKae42P6+T7C5SI6W+nzmus6aJq4NQxxX1NdNNVDUQaItmtBpgXS+8Ax8QDbyeK4Nq7ngNdnF+dF33PxcMFzcV0H13PEWCeL7iTx20kCbgoVDw2YrmaZ7gMOG1fmAHGxWU3Q/QJ09z9romKpPhTVh+crRw3UokZmo9RcApHZYm1fNUAL9N/qJRCoBZl3LpFITlBGbFH/5S9/4eKLL8YwDO666y4+/OEPc+6559Le3n5ICtbPfvYzrrrqKq6++moeeeSRokx8onGkq6kDe21+8T8Jwok26Ghly6t+/tI4jZdba3kbf+bD/A/n8yw5AuxlJn+OriTsJDFSvQMs6D40Fa2uCt+CmfjPPQ2tqqzwlG6AzwBVBUN3CARcSkugNAoBv0coaBMNJ6gItqBn9oBn9YnzseHiYloZslYa00rh2HFyZgIl0wpmDM/N4XlC/BUPVEVBwSNlZUnaGbJWBtvJgmtSpsIMAyqPorOuGsAzoqj+chRfOQSnQvR08FVAsA4qzhFiLi1viUQyDkxI1/cHP/hBHn/8cdavX88tt9wCwJQpU4YU6t7eXioqKpg7dy47duwY/awnEIcEkw3xJXke/OlP8OabEIt5qGaOMGk0TF7Y6vH8CwZuaxs/z76bqTTzVy7gXfyBHH5qaGe6sp9Z7GEGewl5gxtcdwfrSUw9BeXMMyhpqCAahYoKKC0F2xa1xnO5Pg84wuKORqGy3CIUNCmJeJSWQm0tlJYIkT86Lrg2eA54trDU8YSVbqfIWUmydoZYLkbaTJHI9hLLdmOZCWw7jWKn0T0T27VpyiTYlepkf7KLtkw3nbkEpSrMMeA0HywPwZLA0LPwFA2v+iLUmmXgK4WSuRBdAIE6YW1L0ZZIJMeJCSnU9fX1tLW10dPTU5jU4YQahAvcsixSqdToZjxBGc6XFI9Dayu0tMDevdDWBoEAlJRAeTkom59m+devIGQneM7/dlaVPkFTqpxUOi84HjV0MJe3OI3tTGf/oOM3MY1XOYPXWEBWL6G2VghwXR1MmwZz58KMGZBMiq5eti0214VIBIJB4Tb3+yEUEm718nLxOBAQz/v94njHWi3W8zwydoakmRRbLk4s00Vnshkz0wZmN16uF8tO05xqZ1+qk13JLrYnOunOxZmuw3Qd6nWYb8CKsMrZfuENsFHZHj6bYM0FRP2l6L4KdD2I31+GEagBf6VY71YNcasFxC0MiLjvWxdX+lzqMshNIpEcAxNSqP1+P6FQiJ6ensK+Iwl1RUUFmUyGTGboNJ/JzrF+SdksvPUWNDfD/v3Q0yNE8ox9v+KdGz6IZmVJVzfwzO2/Y2/wVCxLCH2sx8HOWFgpE7utG+eNHfib91CSaikkbXnAXmbwKmfwOqeRJlw475w58I53QH09VFYKAdd1SKchkxGWt22D44j7A61xEIJ98cVw5pnF++xMxyRpJunN9hLLxuhMd9KWOICZ7UTJdaJnmtgfa+L5nmZeSnSyOy0anywNwJcq4Z198Ymv5eDBZID9SpRQoJwZ4QpW1MzhtGh9ocqayFbTQdXJp8IVUBTxnB4GPTL0ZBUVFA20IOihPvEfsGaevyDQgiLAQCKRnBRMSKGuq6ujo6ODdDqN3y9+kA4n1G1tbUyZMoWGhgb27Nkz6klPREbzJSUSQqzb2oR4R5//A1f89zUE0j3kglH++n9/TPL8dw35Ws92sHpTpHe30PPn10m9vg+zvbf/eUUhUTGDxsgZ/LF1AbHc4AIqug4rV8JHPyos5qPR0SHEe8ECqKmB2bOFlV1sHNchlosRy8aIZ2N0xffQFdtFOttJLttFZ6yRpmQru7NZzqKDWyIxqg9a5+6w4ekM7HJDOP4qKsrmcWbdecyOTqPUFyLkC6J6Ay3nPpe+kxEu/aHI/3PJr+97Xr/W5y1yVQPVL1zwJfMgPEMEGEokkhOWCSnU73vf+/jNb37Dz3/+c9773vcChxfqO++8kzvuuIN/+Id/OGHbYhbrS4rFoKkJuv/0Kufc9j4inXtxNB9/XnEnWy9ei6cfWtXM7+9zT/tc/FaS7O4D9PzpVVJvNGF1JfoHqirJ6pnsCp3JG5zGgU4/ib6ndV24yQ1DCLDfD2VlMHOmWPOePl1Y4JomxDoeF1Z3ba2w0mtqxLp4MCiO4fMV33ucs3N0pjvpyfbQGtuH1fEsJak3MV2blOdjWuplpplNlHlJDIb+s7Y9eNVUiStBIr4wFcFyygNlGHoQvx5CMyIQmCKs4sIad74oTd+mGmCUgS8KRrS/0pzn9K3d2+DkwIqJ+74K8FeArwy0kLDEjTLhkpdWt0RyQjAhhfrxxx/nAx/4AKeffjpPPfUUVVVVQwr1//zP/7Bq1Socx+Hpp5/moosuKtrkJxJj8iU1N+O973KUF18AILPofA78v/8kNW8RrivWlh0HOjuFwCeTkEr1ua1tGyWRgKa9eK9tJ7frAHZvsnBoRVMJnzGT2Iyz+O7fFrC/7egdtBQF5s+HT31KrFPbtjh3vK+zp98vBFrX+1PFQNwPhcQWifRfABijbNrlug6pnlew2jZjp5ro0aJ0m2lSuRSOnSBgdhBON6KbnZQ4cerIElbHoBCfFu4XbSMqBNlfIwLbIrPBTgor3TERKWoIF7sRhfJFIgjOOIyrXSKRTAompFADfOhDH+LRRx9l2rRpfOQjH+HBBx8kHo/zrW99i3379vGb3/yGLVu24HkeN954I9/85jeLOfcJxZh9SfE43Hwz/PCHQplLS+GrX4VVq4R5O4BkUgh2Lifc6YmECFzrbM6RbI5jvbkbbfdOrL0HcOL9sQKKoaPPn4Vz2hnY80+jvdvAtoUrfv9+6O4Wt/nrr0gEFi6E974XzjhD7MuvZ5umGJdf5wYx7Xzgmm0Lwa+tFcfRNBGYFg7DlCki4O2Y25pbceh4BnpfAV85tl5K2jHJ2Bni2Tgd6Q6SZpKMlcYze7CTu0nmeunMxunOxsFzMBTwKVClwSwdgppKRPMR1n0ENIOQ5iOoG2iKiubZqHYS1U6gHK2Guq8KoqeJdLLQVHEbrBdWeK4LrF4h7OEZUHqqsLL18JGPKZFIJhwTVqgty+JTn/oUGzZsAERk78CSkPnHn/zkJ7n77rsP26d6MjOc9KxRY5pCqD/zGaGeug5r1sDtt4uw7CPgeX1BaDFobvbYujlNprUXfe9urB2N5BpbcFLZwnjFp1Ny1izKLzqd8gsXoPqF2ZsX7rvvht27+8YqcMUVYn37WNapLQu6usQxPVFfBdMU1viVV8LUqcf6ASFczj0vQ+9LfS7nPgFV/eCvJodK3EyQttLEs3E6M53k7BwpO82eZDdvJTo5kEuwK9HJjkQbzhD55bqiUhsoYUqglPpgKVODUeYFSzg1XEKDP0CJ6hHCxO9k8OVaMOJvoDrpQ44DCHd46akw9Qqxlm129VWvKYHwTCiZLQq5SNGWSCYFE1ao87z11lt873vf49lnn6WlpQXXdamtreX8889n1apVnHbaacWY64RmLL8kQKjZli1w443w0kti39Kl8M1vCvN2mDQ2wquvQkebS7otQWJ/D2rjbrT9e8k0tuGmc4WxasAgctYsyt9+OmVLTkEL+bEseO012LwZnnxSjKurg3e/W1jXNTUi3Wwkbu0dO0RE+XnnHftrCzhZyHWCnRbu5uRuyDSDne0XQn8FrqqTsTIkckkydpruTDfdmW5MxySWS7E71c2OZBdN6V6a0t3sT/eQcw8TYAZMD5UzPVTGtGBUbKEyZgZLmeH1UEWWMi+JP9eJkWtDtRODX+yvgenvh9p3ijnnugBXlE4Nz4JAlbjgUPX+9LF8mplc45ZIJgQTXqglx0Go8+zZA7feCj/+sfApV1XBfffBNdcIS3uYWJZwjbe3w/8+aWF3xymxu0i9uofUG01k9rbjZvrrgqtBHyVnzqTs7adTes489JIAW7cqPPCAcI0fTDAoBFtVxZr0lCliq68XqV1DOQKam4Vn/+///hCv/sjxXCF8Zo+4Te6GbDsiiU3ti9gWvnbLc8k6JnErS082Tne2m4yV6WsXqhB3bFrNDK3ZDPsycfale9mX7mFfeogPAFBRmBKMcka0jgWltdQFSqgNllCt6VR4SRrS26nN7EDrs/5zejm9pWfSW3E+eqCWMBZ+J4WmqKh9m6ZqqKofXQ+iaP4+4fYL6zxQ0yfcyqHFXhRNBLLJ/HCJZEyQQj0JOG5CDcJv/O1vw7//O/T2CoG++Wa4806x8HuMvPGGqJyWSICXzuDF4yjdnTi79+HtO4B5oB0vZxXGa2E/4VOmEz3/FHynz+PZ10r423Mqu3eL6Ryh9DsgxHvatP5iKn6/CFJbulTkl3/wg0LUxwTXgnSTqHnu9SWLe+6AKms5sBLg2uTcHMlcioyVJpFLEDNj5KwMOScHrt1X49wj5zrszqTYk4mzKxVjd7qXXeleEvbQDVCCmo8pwVLqAqVMD4S50p/iSnUfAYTF7qIQ0yvo8E2h0zeFmFGPo/tRUVEVBR2PoKYT1n34FAXdczC8HJ7qQ9HEOEVVUdFQFbWvJryOp4Vw9RCeEcXTS/D0EGhBPKNUBMQpCoqioCkamqqhKRp+3U/EF0GVVd4kkiMy4YU6l8vx5JNP8uKLL9LR0QFAdXU1Z599NsuXLy/kWZ/IHFehBqFov/+9sK7feEPsW7YMvvMdmDXryK8dgu5uYV07jljT7u7ySHekadsZI7WvE3vnPtz9zbhtHWD1u4AVv0FozhRKz51H+fmnoleXkzE14nEh/K4rjt3c3F+RbefOoedQUQGf/CSsWCFEe9zIi/chu11SVpJYpoeslSCTi9OdaqUjsZ9EtgvFyWLgEFIUwm6OrBVnT6qLv3Q28laqhwOZBG3m0GvWIQUuC8PHo/0FXAaS9HQSSpCUGsLUS7D0ElyjFBeNlBamR69CwUF1XTzRiVy8UAE80VFN9yw0HDTXLjzvoWIpPnJqgKwaxFJ9oPnJqSVkfJVouo+QHiJoBNEVnbAvTE24Bl3V8Wk+QkaIsC9M2AhjaKMM45dIJjETVqhd1+Xuu+/my1/+MrFYbMgxZWVl/Nu//Ruf/vSnUY85nHfycNyFGoQKvvYafO5z8POfC4GZNg2+9S2xaFyEzzuRgN4el7ZdKZq3x2h/tYPul/eT29eK29YJuX6rUdFUAjNqKD1nLmUXnkawoQbVd6g7vqNDRJHHYiKILJGAX/9a7P+7v4OrrhKe/MBhanxPNCzHoj3VTk+2h+5MN13pLhJmgpyVJpfpIIBFtT9MqabiWSm6k/tpTbXTnO6hOd3D/lyKpmyaHjNDws5SjsWyELwzKER71jD0L+MpdLgGjqKhKCqKoqEqGqqqoSk6phYhY5Th6JE+a7oET49g9bnDNTeH6loofUVfHFTSRjndRg2daoQsOq7nYjkWlmsVLgA0VSOgB/Brfvyan7A/TImvhJAewq/7MTSj4LZXEBa7qqgFoTdUg8pQpbTYJZOeCSnUruvygQ98gJ///Od4nkcoFOLcc8+lvl70XG5ubmbr1q2kUikUReGKK67gscceGxQVPtG46qqrePrpp7n00kv5yU9+ckyvHRehztPcDP/5nyJtK5USvuT/7/+DL3xBdOAoIq7t0rYryZ6X42z5XRfpnc1ona1k93XgJAaUh1UU/FMrKV00i/K3nU5obn0hgnwo/vQnEVEeiQgnwfvfD5M5BtH1XFJmivZUO7t6drG3dy8pK4XjOqiKSonmo0zXKSND1GwnaLZha2FMPUrWsTiQ7qEp3U17NkE614Ni9uK344TdFKVelirVol4DvwIL/VA+ijX9Zlthu6XS6uqkPI0eDF60Q3QRoCEQZnbpFMrC0whHZxMunY/f6C9hZ7s2WTtLzslhORa2axduPQZUbcsz4NdGUzUM1WBGdAZzKubg1/0FMfdpPoJ6kJARwqf5JvTvhkQCE1Sov/a1r/F//+//Rdd17rzzTj7xiU8QCg322WUyGe6//34++9nP4jgO9913HzfffHNRJj4WPP300yQSCb73ve9NLqEGIdC/+AX8v//Xnz81bx587WvClzwG3ozdbzn89qcp3FiccK6LzN42srtaye7vHFwRDfDVlBE5cyblb1tA+PQG9ODg5RDHgZtuggMHYPly+MAHhFBfdNGYTP24c3At8+ZkM/FcnIyVwXEsqs1mplktBLEwjQowohiagaZoQ4qU7br0mCm6ckm6snHUXCeGk8B0smTsXN+WJWvnMJ0ctarNVM2hQvWo0aBGh2pN5I0fjn0W/DQJ34zBm/0hCkSMINXBcuojUzit6lQW1p7BrOgMUP24ikZ/JbcjY7s2pmPSkmzBcQfno2uqJqx03Y+hGpT4S4j4IoSMECEjhKEa+HV/wSr36/6Cle7X/FLYJcedCSnUZ511Fq+99hpf//rXWbNmzRHHbtiwgZtvvpkzzzyTl/KpRROUp59+mgceeGDyCTUItXvtNfjyl+GnPxUVSDRNhFGvXy9aZxWZ118XaVo+3aUqmMTuSZBr6SG7v4P0zhay+zsxW3sGvUYvCxM5fSZlF55K6dlz0SPCx/3888IJoKrwb/8mUr2uumpMpj3uuJ5L0kySyCVIWSkRrBbbiRJ/HX9qD4qTwnZssqjk1CC24sfQffhUH7qm49eEMB37eT1M1ybn2ORcC8dKE7Q6iFgdGHYK3c1S6sRocDow6BfPv+R0vtXr8auUQ+cQNV4iuo+54UrmRCqZHalmZul0pkSnU+ovxdB8eKg4qg9HDWBrQWz1yG1IbdcmZ+cwHRPLtQq3tjPAUvdAQUFVVQzNQFd0DM0goAWoDldTGaosiH3ICAmXvBFCU0+8eg6S8WdCCnUoFMJ1XeLxOD7fkRsO5HI5SktL0TSNdPowBSCOwubNm7n77rvZunUrLS0tPP7441x55ZWDxmzYsIG7776b1tZWFi5cyP3338+SJUuO6TyTWqjzdHbCL38pfMmvvy72lZfDv/wLfOITIl+qSHieiGV79lkRjO73Q8Dv4bNTKKkkZls3dms3uT3NZJs6yDV3g9MfqKWF/YRPa6DsgtOILpnPV78Z5s9/FgbZpZeKKV922cmVVWRnWsmmmsll2rGSjdjpA1im6O2dcnJkPJ2U62J7iNLjioqm+lEUXViVfZbmaNZ9FdcimmmkOr6NsvRb/cFpgKXoZDFIeCptlkOTmaPT9uhxoceBHhe6Heh2od0RgXBZ1U+pHiBq+Ck1QlQHo9SGKpldPpfTqk/HUX24io6naKCoIhxOUfEUHVfR8NCG/CPwPA/Hc7Acq3Cbc3Jk7AyWMyBTQdUIGkECWoASfwmVwUrKg+UFCzwfFBcyQnK9XDIixlIDjv2SvI/S0lJM0zyqSINoiRkOh4c19nCkUikWLlzIDTfcwPvf//5Dnn/kkUdYu3YtDz74IEuXLuW+++5jxYoVvPnmm9TU1ACwaNEibPvQohW///3vC2vrJwRVVXDttXDuufDgg/Df/y36aN5+Ozz8MHzpS3D55aMvto347VywQORHNzWJ5fKuLoVUKoKtRnDDtdjVWaz6U9BivZQlunCamjH3d2A2d+KkcsS3vEV8y1soPp33zpxC3Ywz+c3e03jyyQgzZggLe9GiMUzZmmDowToiwToiIK6ErF6RB24lcbPtWIldpLM95Ow0pmOStbOYVgrLSWHZOaycRa7P8vTw0PsCylRU4RLOu9MVFVXRULQgnubHVQyRb63oeKpBb3g+veH5+KwY1YltVCRfJ2B1YXg2BjYlQL0BZx/1z8im07H530yKp9Lwv73wh3YQl2u/54Lyei6sqKfcCBHSfYR1P2HdR4UvTJU/gqEZeIqGowZwFPEbIgRdCLeraLiKD0cLCKtd9+MES3FUH54ifuIsxyJrZ8naWdqT7ezr3YczoPyroRmFoLj8/YgRoSxQRtgXFmvmRpCgHiSgBwgZIelelxw3RmxRX3311Tz22GO88cYbzJ8//4hj33zzTU477TQ++MEP8uijj45oogNRFOUQi3rp0qWcd955PPDAA4AIdps+fTo333wzt95667CPPVyLOpfLkcv1V/GKx+NMnz59YljUA4nH4W9/E0VRfv/7/mLbK1aIPOyzziq6uep5or+1ZYnAdMsS1wnNzbBvl0mqLYndnSBzoAtn3wHc5jaR9pUbnHd8gHr2GnOoWTKTd984g/d/UCMsK2qKXHAnI8qm0leD1bPAc7Adi1QuTjrXQ9bOkDJTxHIxkmYc10rjOTnwbDzPBtfCcy00O4Hu5lBcCxVX1C/3PFFoRdVwfNWo/ii6qqO7Nj43he5k0dwsuptBc7Lortg0JyPuOxk0N4NupzDcNOpB3cyynsoux8dfU1lezsGrptiGcquXGQEqfSFKdB8R3SCiDbz1UW74qfIFqDQCVPuCVPgjGEYIVzFwFb1godtqAEsvwdaCQtC1EKZWAopSuODJ2Tkcz8FxnYLLHRCeC1R8fcsPISNEib+EskAZZYEyov4oYV+YgB4goAdGtCwhmdxMSNf3K6+8wgUXXMCiRYv49a9/fdiJJRIJVq5cybZt23j22Wc5I9/FYRQcLNSmaRIKhfjJT34ySLxXrVpFb28vP/vZz4Z97OEK9R133MHnP//5Q/ZPOKHO09wMv/0tfP3r/SVIQyFRkvSznxVW+HHAtoWIOw4keh1SHWlizUl2b+mm6W/NmHta8Dq68GLxQa/LqkFqF0/jnGvmcc5HTyNSK7tNjQTP83A9F8dzCsFcpp3DshLgZPBcE9NKkcnFSee6sZNNePHteHaKtGJgewqeoqApOobmI2iE8PWVMXVVn7B0D0LxHMK5FkoyeyjN7CWS3Y/mWYeMA0i5Cj2uQpcL7bbLXgt2WrDdhGeywpU+HCp9YRpCUcqNAGVGgKnBEmYGS2kIhKjzhygzArian6xRScZXg6MaFNqYHvyZASgKjivS00zXEVHurk3Gdcmg4/Slp+maTkALUBepoy5SR1mgrCDepf5SaYWfwExIod63bx9/+tOfuOmmmwgGg/zzP/8zF1988aD0rM2bN/Pggw+STqd54IEHePvb3z7ksRoaGo5t0gcJdXNzM1OnTuWvf/0rF1xwQWHcLbfcwv/+7//yt7/9bVjHXb58OS+99BKpVIqKigp+/OMfDzreQCaNRT0QxxHVRr7/fXjoIWhtFfsrK+EjH4F//mdRLGUUSxQjxXU99u/M0bIzRevOOLv+0k5i+wF698UJ9rbgZ4C1rSiUnVLDrOVzOOejpzF1yVT5AziGmKkmsl0v4qSasKwkGStFykwSz8VJmUkcz6HUV0JEVVFw8RQR5OV5HgoKrqLjqH5MvUQEkHkuAaubUK6NoNlOyOwgaLYTsHuPOhcXsFExPRUThYyncsDReMVUeSHr8OdUjtdyLkfT8yp/hLpACVFNp9zwMT1QQkOwlFp/iFLDT1T3EdX9hAyfKCAz8FeyL5BNrKNrOKqfnF5CUgmRVXTSrkKv45DyVFzVQO+LSq8KVXF6zelUBisHRalL6/vEYEIKdbE6YSmKMuS68dFeMxZCPRKOS/esYpNOw7Zt8MADolBKKiX2h0Lw9rcL0X7b2/o7bIwDB5oc/vy7NHteT/HGKzabnzSZx07m8RbVdA4aG6oOMeuds5h32TxOueIUAmWTpFLKZMPzRJlVzwU8XNemJdHM9s7tNHbvxM51EdYNyvxlhPQAquKhORkMO0HA6sFnx3DUIDm9FE89dGFbdU0MO4nuptGdDIaTxmfHhKib7YTM9mFN01F0kkqIJBpJT8N0XZpseDVrsyWdY2smxx4rv0Z+ZEqNANX+EqK+ELPCVVT6I0wLlXNq6RSmh8rRcPuWALL9BWOgLzhOFKCx0ch4Hr22RdIBzRcGLYSjhfD0UiLBKkoDUcqD5ZQFygjqQTRVE0sNqo6qqBiqUSgUIy9KJyYTUqiLWWXMPVpx6IMYS9f3SJlQUd/DpasLnnlGWNibNg3urjFrFrzjHfCe94hC3FVVwvIOBg97uGJjmvDyy7B1K7zyosXPfq6yv0WjnB7m8RbzeItZNKIPsJ8UVaHmzBpmL5/NKVecwvS3TUfVZBTvWNOV7uJA4gA7u3bSlmojZaYwNINSfykhI0RQgRKrk9J0Iz47jurZeIqCowax1SCO6j9qrITqmmhuDsWzUfs2zTUJWF2Ecm2EzDZCubbDutUHYqPSrFayXalkt2PQnEtzIJuky8zSa+VI2SaW55LyoNeFmAMHHzWk+ZhfWssppVM4tbSOU0rrmBGuQlcUVM9CdU1Uz0HBQfHya/8WruuIpQdULAwynkdCCZBQApiqH1svwdJCqJoPTdH6BRqFoBFkaulUZpXNImSE0FUdTdEKgi6FfPyYkEI9nhwumGzJkiXcf//9gBD/hoYGbrrppmMKJjtWJqVFPRDPE/U8X3hB1PF85hmRi52/eAoGRburc88Vodc1Nf0dNcrLReWzMa5I0tYmcqzfeEOkhre2eDTtsfndJh03Z/N3M15grr2DQE8LpDODXusr8TH9bdOZ+565nHrlqZTNKBvTuZ7seJ5Hd6ab9lQ7TfEmmuPNpO00OTuH67monkPYzVKuq1SqEHV6MdwUmpPFVXzYWrCQppUPBDvGCeC3e/os80yfsDv47RgBs4ug1UXA6kL1hrnYPQDbU8ihkHahx3HpdqDLhd0WvG7Cmya0OBr+YC1nlDdwYfVcFpZPxzhM3rbi2mhutu+CI4fqCc+ipehYqo+sEiSriRx6x3Nx8Ei7Gm2uBpofn+4vlGfNC7mu6oU18YAewFANgkaQUn8plaFKIr4ImqIVSrtKiocUaiCZTLKzr5vD2Wefzb333suyZcuoqKigoaGBRx55hFWrVvHNb36TJUuWcN999/Hoo4+yfft2amtrx3x+k9KiHojrihaa27aJYLMXXhDR4n1NVgCRf3322UK4p0+HcFjU/JwyBaqrhWiXlortGFpuDgfbFtcPL74o7mcy8PTT8Nhj/WPCIZfLTm3kTF5GaW3Fae8Ce/APcnRGtOAmn/2u2QSi0k0+lliORcJMkLbSpK00WTtLT6aHpngTPZkeclaGSl1jht8gbHYUrG3Fcwq3ruLD0kLYfR2+Ro3nErB6iKZ3Ecntx2/19p3LFhZwoSGLh+aaaN7QXdAOh+tBiwNNFux3oNM1wIgyLTqDuRVzsfUSMr7qIQPv8DxUT3gONNdE9SwUz8VDGCgeCrYWwvIU0mqYrBbCVjQsT8FWVBxPwfRE5ToLB8+DrKJjeSoBQ6Sf5Tuj5dPRAkaA8kC5aLwywEI3NANDNQYJv7TWD8+EFOrh5lAXi6effpply5Ydsn/VqlVs3LgRgAceeKBQ8GTRokV8/etfZ+lxasM06YU6j22LEqTbtolWV83N8OqrwtLOr2WDcIWfcw6cfroQ7bwFHgoJK7yiol+8S0qEoEcio87dNk0xxURCdONaswbeeguSSSHeAKcvcFl8eo5yX5Kqrjdh3z681nbc7oMaxygKVadVMfMdM5i7Yi4zl83EX3Lid3qbCNiuTVe6i850J1tbttKZ6sRTPFTXRvNsfAqEcAl7JhE3QYkTx+emcRU/KJqI0u4rjuIqPlBFPXBFUfrzxYuF5/ZZvBaqa6N6lkhFc7MYTpqA1U3A7CRgdeGzYmhHDWWDnKfwklfB675Z6CXziYaqqPGXHHXeimejOxkUz0FzTRTPBsVD8USEm9dXvtVTVLy+PuuO6sPUS0kqYVJo5BQfWQxyHjh4mK6D5Tqi4ttBFJqn9C1jlAfKCfvCBcHPC7uqqAVh92m+QunXgB44aSrBTUihrqys5B/+4R9YtWoV5557blEnNZmY9K7vw2FZsGuXEOz9+0UkeEsL/PnPwg89IOKdcBgWL4YlS0SBbkURqpnNCte6ogjxDgSEaFdWCus8HBZbKCRuR3Dh9/vfi+uI2bPhd78TbboHxibW1cElb7OpLcsSsbqJNL2BvacZt70TUgdVyVMVSufUULNkBtOWzWXeO2dQP+v4R8CfbOSblyTNJJZrFRqaxHPxghWu2knCuTZCdg+Ka+Jzs31Bba7IAfcccoqfrOLD7Ktipis6qqqi0tetS/cVgrLGzO3reehOCr8dR7djmJl2MLuJp9tJZzupVD1mGlBxkHa9ZcLLlk6TUkaLEqVFCWOqAfyqjk/V8Gk6Qc3HzHAlZ5VPJ3C4lqKeJwLaPLdQTU5zs8JC90wRra6oOKofT9H6hR1V5J2rGi4GnqqLWjso5NBIKgF6XYWkp2B7DgXZ6IuARxHLHioquqZjqEbBKvepvoI179f9BPQAQT2IT/MVcs4NzSgEz/n61ubz+yaLi35CCrWq9l+1LliwgNWrV/PRj360UAXsZOOEsagPJpcTgv3SS6JjRt5afv114Rp/7jnRrzKPqsLcuWI9e9EiOOUUsS+XE+KdywkBz6uppom6o36/EOvyciHioVC/dZ6/HULI9++Hn/1MHFLTxHXBCy/Ajh2wfbuo9zKQqiqPiy90aKjJEk63U7J/O1ZTK05b5yHr26gKtWfVMuudM5m7Yi7T3zYdX1gK9/HG9Vxs18b13P7NMXFdC8+1weyG1F7UdBOe2Yttxsm4JmlL5Dpbnk3WsUl6GllPxfHcvpptoPZ16xKWoB+tT9hRGBSkVQx6zTSvxZrpyMQI5lo532viVHqZrg2d9dJqw2smtNiQ9SDuwi9SsMMJsLh6PiVGkKDmI6j7CGk+gprR99gQj/v2R/QAUV9/EKjiOYVAN6Gyngh2w0UpCH3fflzheu8T95xRTtpXM6DUqyoqw6kGjuLDVgzheh+Qp5//7mzXLhSTcT23P2Xd6yuDq2gFK12UxRWWuk/zURYow6/5CRrBQmMWv+Yn4otQ4i/Bp43/v8sJKdS/+93v+O53v8vPf/5zstksiqKgaRqXXXYZ119/Pe973/vQi7xOORE5YS3qgzFN4RJ/+WWhjrou1qYNA958s1+0DxwY/Dq/H844Q1RAO/10YfoO/LtwnH7xzuXEZll9PxSIsX6/EOlgUKx/R6NC1AMBXF+AxpYAluqnuTvAq2/5iUQ1qqv717HfeAPa28US/MGl5mtrPUojHvU1FlN97ZS0NxLp2Uck1oKSGTxY0YSrvOFtDcxaNouGixooqR+f9DXJEHgumL2QbYdcOzimSCfDw8nFyGUO4FhJbMci5zrkPAVT0bFQiOXSpGwTt++/fGEY27VxcUUDEEXBUH3oA3pwF0PEdSeNkWkiHXuT0lwrtV6MCnJHfE2PAy/khJh3OtDpittuB1IeZFzIeGLfTgvmldRybuVMpgTLiOh+wrqfkO4jqPko94WYEixDPZLb3XPR3SyGnRAR+4hc+bwljaLiqAZeXzU4WwuR00tIBGfjaEePA8mLd74Qj+u5OPno+D7Bzz/Oi7yCgl/3E9SDlPhElbh84FzUHy10Wztea+sTUqjzxGIxfvSjH7Fx48ZCvrKiKFRWVvKRj3yE66+/noULFxZlshOZE9aiPhjLEor3yiuwb5/YV1dHobZnR4ewvvNBabGD1oV9PmFlL1ggtlNOERbzkc6Xy4kLhYHbwJQ+XQfDwDN8NLXqbN8TJKVE0KIRfGUhAlE/nuEj6/n562ul/O+WML0Jnbd2a2Rzh/8HvGRGGzecvRW9rYXONzrJ9mYPGVM6rZRp509j5rKZzLh4BtULqlFUGXAz4ciLuBUHKyZqp2c7wI6Da4Jj4Tg5HM/G7bMmHdfBdC1sx8FWIGVlSdk50o5DyjHJ2CauohIySigJlBXVRau6OYJmF0GzA93NoHg2fquXitQb6O6RRfxgehx4NgvPZWFrTgj8gYOMeJ+qEdEDfXXWRa31/P1qfwmzIlUsKp9OTSCKPkSWh7DSrQFBeTaamyHtqyMdmCLqtKv+vs2Hq47eAnY9l6ydJWNnyNk5ck6uIPiKohDQA/g0HyE9RGWokqpQFWFfGE3R8Ot91rivBONwywjHyIQW6oHs2LGD7373u/z3f/83+/fvFydQFBYuXMjq1av5h3/4ByorK4t1ugnFSSPUeRxHWNavvgqNjUJMq6uF2zp/9eq6IiBt2zYRsv366yLqayCqKnK2FywQ69vz5okUsGO5ArasQVtPh0XrPots0iIZc3Edj1BYuMZ1n4qi67iaTsIOsq29nqzr442uWjoyYbKOj96sny07y/A8ha+u2ckVKy0qy106GxM0PttK88tddO7sJdGS5OD4G1+pj/pz65lx8QxmXjKT+vPqpbt8IuNkwcmBmxP3vYMUzMkJUbdTQtDtFK6VIGMmSOfixHO9dKVaSZvi79rQDIJaAJ8RxFN0UVNcEc1BCgFeo7HuPA/Vs/pyx9vR3Qy6IwrE5AvFiBxzEfhmOAm0g98T0O2qdLsKGdcj7rikB1jhaQ/Sbv/tKyb8NiUsdQUo84UpNQIENAO/qhduI0aASn+ESl+YSn+EKl+IetWkxvBRYvhF4J9q4KJj6SVk/DWYWgmOauAqBp5q9HdQGyV5Ec/XcM/fB4Q17ikEDNFcZVrpNGZEZ1AbqSXii4z4gmvSCHUez/P4wx/+wPe+9z2eeOIJsllhiRiGwfve9z7+8R//kfe85z3FPu24ctIJdR7PE0FmO3YIF3g8LsS6uloo40BcV4j766/3b+1DVJuKRoVgz5sniq3Mmydc3iOYWmenOGVHR5+XPeOgeTbV5Q6GYotqUo6D4toojo3iOqiOzc1/uIKnmuZy1awX+Zez/khtDVTXqai6huZTUVSVeK/L3t02+94y6Wix6e2wcezB/5wUFapmRph2VgUN51Yz/ZwaKmZHUXRdfD6H21R18K02dJtHyTjgmKIJimuCa5MxY7TH99GTbqcz0UJPuh3TjFFt+KjUPPQ+CzO/Dix+clVMo1SknI0hiucQNNspye4nlGshnGslaHYMals6HHIe/D4NjydhpylEO+X23/a6h1yzDsKnalT6IlT5Q1T6QlT7/NQYfqp8QSr9Ecr9YUJagIARIKCLLmWaHhBr4KqBrQaFyCt6X+tTHVftu1X69w/330heyFNmirgZx3EdIr5IwXVeEawgbIQLgW756nD5YLh81HtQDxbc6pNOqEHkPT/yyCN84xvfYNu2bQw8jaIozJ8/n//4j//g8ssvH4vTHzdOmjXq4dDTIwLPXn9dKKNhQG3tkV3bnZ39or1jh3CrD1VStrZWiPbcuUK4Z84U6V7DJJcTh00mxSlaW/u953nNzNduURTYsqeKmx++gIBh89W/f4ZaX69IicElYDjUVdvU17oE/Q4+zcHO2KR7TfbvztG43aS92aar3SF3qLccfwDqp6lMn6XRMEunvkEnWKL3C7OiiNuBm6KI5w2jzzWgH/5+/jgHb3mxH+rYQz1WFHG8SKToefEnKp7n0ZXpYmf3Tl7veJ3edCcGNhHNoNJfSkjT0TyTQK6TSK4JD42sUXlcL8IU1yJodYmUsz53ter13R70WHOzlGb2ELB6jnhME5UOQux3fey2Vd40PX6XdHgtkyVhD/GPYBjoikpIM6jxh6jxhQhrOmHdx/xIOQ3BUqr9EWaFK/Hp/r4CORqu4sce4F53VR9ZXxWmfuTfZMd1ChkGOSdX6KJWiGrvIx/cpms6GqLHecQfIWJEMCyDS069ZHII9R//+Ec2btzI448/TjqdxvM8SktL+dCHPsRVV13FU089xfe//31aW1tRFIWHH36Ya665pphTGBdOWot6KLJZ4fLevl2sY5umSMkqLz96FTPTFK70t94S244dhwao5amsFII9Y4bYZs4UVdOOkqtt22Lp3Laht1dMN56A3h4h3p4nrO87/3ABLzdXETRsbr3sZd5xSguG5pLNQk8vaGp/nFu+YFtZmTiHY7lkkg6d+7PsfTXBgR1pOg/kiHXkcIdIs41WG9TPDjBtboCpc/xMmeEXQe6uO3jzvCPf97z+QLzhoihDb3nhDgb7I/LLy/sj9PMpd6GQ+MylxT+IlJmiKd5Eb6aXpngTBxIH8Gt+asI1Yu0020xF8g38dgy3r9+2pYVEXvhE+iw9j6DZQXlqO9HMbnQnjepaaJ4lhP0weeOOYtBUeSnt/gaaHYMuK0VXLklXTtx25pJ055J0mSl6cinSjknGMTGH+gdyGDRFZVa4gjnhCmr8YSqNAOdXTOG0cDkaHuBiayFRplbz4Sr96+T56neeopM1KoYd9Ga5FpZjFaxyy7VImklCboibLr5p4gr17t272bhxIz/4wQ/Yt29fwXq++OKLueGGG7j66qsJDqgRbZomn/3sZ7nnnns488wzeSnfdnESI4V6CFxXmK47dwrR7e4WP+pVVUe2sg8mmew/xltvCat9YMW0gagqTJ3aL+BTp0J9vYhQDxz+H6LjCK99XvdiMXjxFY3/+OO5bNnbn3I4JZpm2Wkt/N2ifUwrS2JZ4toikYRQEBoahI7lp1JaKrLZwMPMuKRiFgd2pNjzSpL2vRm6W0zS8UM9CIoCFfV+ps4LMe3UCFPnhaidGUQzxiCnNC/uB4u954mrmWxWvMl8RH5+gpomrlLyVytlZSJPPp8bbxjicz8Gz8eJiuu57OrexbP7n6Un04PlWqCA7uSo8dJEFYsyN01EEeVEKXQdE2VVRc7zxFz+UDwHnxUjYHWJ4i9WN5HsfsJmW2GMo/hI+WvJ+KrJ+Krpipx5WGG0XYeMY5G2Rc31tmycHjNFyjaJWWnejLfSkU1wINNL3MoMeYwKX5izyqcxN1LDqZEylkRrieoGSl/t9Xz6GQij2dIjJP31mEb5MS4KCOK5OD3JHB+79HMTS6iTySSPPvooGzdu5C9/+Qsg3D5Tpkxh1apV3HDDDcydO/ewr/c8j/LycrLZbGENezIjhfooJJPCut6+XVjIpimss4qKQ9eyh0MqJaz2/LZnj7gdWD3tYCorhWgP3KZOFW71IazwV16B7TsU/tA4l+//dR45e/A8w36LhooUixq6+PDS3QS8bOH0A7PL8n8OPp8IkC8v78s683nYOYfe9hxNb6TY90aSrgM5elpz5NKHNqpRdYWa6QGmzg8z7dQw9fNCVE0NoGrj8OOdF/G8gOcF3bLEVU9+TEUFLFwoovulYJO1s/Rme0lbov55xs6wN7aXWDZG2kzi5boJuGl8bo6gkyLkJPB5OdS+fGYdBc2IEPKV4OohHMXfl9M8wQTcc6mLPUdF8jVCZvshtdUdxUdbdDE94dPIGWXYavCY34PnebRl4+xItLE32UmPmWZfuputXXtI5wPH+lBROKNsKjMjVZToAU4preO0aD3TQ+UoeBhOEp+dHKoduTjXUeQ7Y6bpyPp47+U/mFhCXVJSUnBt67rO+973Pm644QYuu+yyYXfWmjlzJk1NTTjO8F0dEw25Rn2MuK7osrF7twg+6+4WClZdPfof8nz0WF689+0TJVCbm0XN0cOhqkLEq6uFaNfUQE0NmZIatu6vIR2qIlLuI2XqvLi3kl++NJ2/7KzF9fr/VRuaw3vP2s8pdTHCfouw36YinGNmeaywTm07kMv2LycHg/2VVQtLwJ6HmbFJdGTp3JOke3+aREeOWLuJlTtUvHVDobohwJQ5IernhZkyO0jNjCC6bwJUc3Jd8X10dYnP9swzhWiPsozsiYjjOnRnuulMd5JzRAMTz/PwXAvNERHnimuTTTcT632DdKaLsJtFx0Ltq03ueV6hjKqm6HiKAqg4agDVV0bAHx2X96Z4DgGzi5DZSsDsojy9g5A52CPmKAamHiXjqyRrVJHxVWJpEUy9hJxRcUyR4Jbr8Ervft6Mt7Iz0c6rvfvZk+oacuyUYJT3TV3I3884j1Jj5J0BzUwbyWSKlZc/PLGEWlVVTjnlFD72sY9x3XXXjagi2d/+9jey2SyXXHLJSKYwoZAW9QhIp6GpSaxDNzWJx9GoEM1i/5jH40KwW1r6xTu/ZYZ2n+XxUDAjFVjRKsySSsySStKRKtqUenZZ0/nxrnP4XfOZ5DjUlVdflmJGZRJd86gI5Vg6u4OI32RWRRy/amGag+u7HIyqQjDgUlNp46WztL6VoLMpQ2+rEO+Do8zzr6mo9/eJd4gps0PUzQ7hD41TzeW8YPf2wkUXiVKzkhETz8XZ3bMbz4yjuBlUV0SgK54DrknOTJAzE6LCmJNFy7VjZjuwrRSq6sPSAthaGEULFOqi5+t0D2TMSq16HmXpndTGniNoduBzkkcc7io6GaNKNCPRgn1rziHsvvuW2rev77GnHBr42JqJ8VzXbrpzKdpzCbbHWnkr0VpYDw9oBovKpzMzXEVdMMqUYJTaQCklRoCIHiCi+9GPULN8wgr1X//6Vy688MKiTmYyI4V6FHieWHPeu1dY2e3t/VZuNDq2bj3PEwLS1ibm0N4u7re3Q3s7Xns7ijm87klxrYx2vZ4OpYZ2pZZGcypNTj1t1A7aOqlC02Dh9G6qS7JURnIYmoumeKiqh093mVWVYG5NgspQhlRKrBzofdknPh8YuotPtcl2Z+g9kCTeliHVbZLoHNryBohW+6ibHaR+boj6uUK8w2XHsX9xd7d4IytXigp1kuODY9LZu4POnjdJJxoxsm14Vi+2k8ZxheVuuRaO6wys6omDJwIrFR1TjxIKlBHSQ0X/e1FcG58dx2/3iCIvVid+S7Qq9TnxYy7w4vS1S7W1EBmjis6SM8kZ5Yf0Pc86Fv/b9ibf2/0XdiUPE/MygHyueL6yW7kvxNRgOfWhMsJY+Ey4/bqnJ5ZQSwYjhbpImKZIfN65U0R/x+PCN1xVdcRgsDHD87C7Yuzb2k6isRM91o0R7yJidhFMdRFIdeFLdqFZw/8xcVDppIo2ammnhk6q6KJyyNusr5TqOp3zTk1QHjaZV9NLdThTiOtynL74LyBguKieTbY3R6I1iRXLkOrOkew2MdNDLy8FIhrV0wLUzAwyZU6Q2pkhahoC+IJjZH03NYkrjXe9SwT7SY4/rg25DrCSeJ6D6zmkzDiWnQPPwfNsFNfGdkwsO42dbiYdf4ueTA9xT8NSDdHMA/BQ8VBQ+mp1+3Qffk10zsrX6h4VnkfA6sJv9aC7GQwnPaDAS77YSxqj7/7R8sNdVBwtiK0GhZirQdK+Kl5UpvCnZJrmTC8tmV5aMzHaswmSdpaMYw1rqmFLJ/VFWwr1REYK9RjQ29sfgNbaKkS8omLkAWijxLZFdPfePSJlPC+WlulRZqSoVrvwJbowkj3oqV6MVC9Gsu+2b9PT8WMuNgGQw1cQbztQQrjcwBfxo5cEUEIhnECItBImp4exjDCmL0zSC2NqQXL4yaUccj0pvGQaM5kj0WmSSdiHrVJRWmVQ3RCkbla/gFdM8RcncG3vXrG0ccklcOqpoz+eZGxxbUjvI9G5jXRsB5YV67O+PTzPRfEcPM8l69r0WiZJzyPjKth4uK6Hoen4NT+6puNTfWPXEcvz0NxcX4W2NIaTpiy1o5BSNlSFtoGkjWosfWCcjPhbd/FwPBfH83BcF8dzsT0X03XIORZZ18ZyLTrTCleuyY6vUN95551FOeFtt91WlONMFGQw2XHAcYRQ79nTn+alqkKwB5YsPY64bl8vkZzIv37rLUimBgeN6rpwAgQCiG5MKqg4+LNxIeR9Iq5n4uiZhNjS4r6RjqP1PdaGeUV/JBwjgO0PFYTc0gNk1RBdbgXtZpQeu4S4HSaWC5K1hy5uoukKFVP8VDcEqJsVpG5OiLqZQSIVxrG7Q1taxFXOihWiiI1kcuBkwUoi+mWKNqO4FthpyLXjpvZh5rqxcr1YTpakEqTTcoibCUzHFDnIriWCkBV9QMMM0eBDVZRCf2sQjTfynbVG63JXXKvPCu+zxPss9NJMI2Wpt1AZeslouHRlfFT9ozm+Qj2wreVomMwR3kdCWtTHiWxWuE8bG4Vwx+P9rTfHMf0nkRAOgHy/EA9IJqC7z/LGO7R2STQqUpDzBcPy/7wG3sfzUK1cQcR7201eetNHa4uCkkkRsJNEiVFGb2Eb+DjCEdLVDkOKEO3U9Lnmxbp6BzVYDB3g5w+pVE4NUDMjQO3MUCHyPFhylGpm+/cLy/q882DOHJm+dSLguWAnwYxBah/EXgMrjqfqmGqQnBok59qkzBQ92R56sj2iCYoH4BU6aHlePiHKw3Vd7IOs4ZARQld1gnoQXR191TzNyVCa2YM6pNV9qEQqB8mmbcWJpy3Ou/qv4yvUM2fOPKxQNzU14XkeDQ0NRz1OY2Pjsc1wkiCFehyIxcSP/Y4dwkJLpUTBjcrK8VnPHgLLEtcW+Voiti1ue3v7q6Xm15mhP/rbdfvriAysHJovFpYna2m0xoK8eqCMl/dXkLM0TEdlb2eEXR2l6FiUEi8I96xQG/NKWilTYtT6e5ka6Cbkpajzd1OqJFBzmcKm5dIE4h3odhYPhR7K+oS7piDg3VSIRhNDEAxC+dQgFVMD1EwPUjtLCHlpVZ8Fnq8Tn0iIC60zzhCJ5sdaEEcycTF7INMC6f1iM3vF9+6vBH+laCEKhSJZjudgO/2tRfPCbTqmCGzzbGLZGG2pNmzXJm2lcT0XVVELbUfDRrhoHbGG/TYnatT3QKZMmUJ7e/sJay0PBynU40g+f/rAASHabW3CjM2Ldr5U2AQjmxVCnRdr6BfsZFIEoScS4rn8GMuC0iiUDqMNdixt8GZrFNNRaY8H+e6f59GeOHyu6NSyFGdN72ZqWZq6aAaf7nBmXSe+zmaiqQOUxA9Qkmmn0u3A6GlH726HRIJOqgvi3U4NHVQT5/A5u7pPobzWT0W9n+rpAWoa/NRFs1T4k2g+XXxv0ajIaa+u7n8ciUy8wh6S4WNnRJ/wTCt0bREda0LTRnQoDw/btenN9pIyUyTNJN3ZbhzXoTfbi0/zUx4oK4q1PRykUE8SpFBPEBxHpFY1NwvR7ugQ/uh8Lc8JKtqHw3HEZppCrDs74c0d4DpQVg66Nvy4umRO5/nGKlI5nYyl09gR4UBPmGRO542WMhz3UMu4JGDyn9f+lTnVCVxXXEAMXIs3vBwVTgdTaKEs24Yv0QXdXVidvST3dtPtlNFBFe1aPa1GA4mc77A544oK0SqDimqNymqVmkqXunqoqTfwVUSEiV5WJgrS5OuPB4PiOw0Ghdshn8MmmdjE34K2P4pANV8ZKDpoAfFHMAocz6El0UJjbyPdmW5czyWoi45YYynaUqgnCVKoJyCOI6zrvKXd1SUUr6RE/OBPUvdqezu88YYQzbwrHfrd4/mmV4YhNGw4hQJTOY0X9laxq72E5liItliQ/T1h9veECflsZlQmCRo258/p4IpF+/AbDj5N1AVPp8VcFKX/fIoCES9B/cu/ZsqWX+FL9wKw59LVvFV5AfEOk2S3STpmiS3u4DqH/ykKl2qUV2tUVSlUVXvU1qnUTVGIVPgGv9G8aOt6f73x/Daw0chQ94dze/D9oR4fvB+GHgNDv+5kIbETOp8VgWieLW6NEvDXwChF1XZtujPd9GZ7aUm20JXupsQXodRfOiZ1A6RQTxKkUE9wbFuIdnOzaOrR1SUqkoXDQrTD4Un1I5kvsZ3NCpG0bEjExT7XFdHoZt/zhtHf5bK0dPgdK+MZgzU/vIAdbYd3Y8+ujrNwejfnzerk/FltqJ5b6OuRD6xTbZM5z/8P8176Ka6i8fyyf+XAtKXguGiKg2e72BkTJ53Dy+YwExaZhEU6bpOJ24ct4ALgC6qU1xhU1OhUT9GpqVOprdeorFJQHHtwZ7GRMlBs848Ptw18/uCxA49xpHFDifzBbUgPd9FxuIuQoV5/8LwON5eh3sdw3/fR7nuiehqeKVziie2QbRcWtq8UjFLIrzcXXlf4AA/9jpSDHytYrkVTbD+NsUZSZgpUBV3RCfsjhPL9pAf82/cGHNPzDa+OuhTqCY5Mz5qEuK5wibe0CNFubxdql3etlpQMzwydwDiOqMja3i4C4x1HvMXubhFnl//9jkSOXK3VdhXeaiulMxGgPRHg4WfnsL8nPOTYoGFTX5bGp7tEgyZ10Qya6qKpHqfV9fJ/dn6aujeewlNU9l66mubFV5DNKbh9mT65nEcm5YLjoHounm3jmTYBzcROm6R7TNJxi0yfgGdTh/+90QyFaJWPiil+Kqf6qZouAtnqZgYwAseYgz+wm9jB2+GeH7j/4DFDPXfw7dGOcyzHh0OjFceKfJDg4Z4beP9gAVQUkepl9oLVIwLRnCzg9Qm2Dw6u+X2IeHOokPeNydk5knYK13NJWWmSuQQ51yTsC+NXfQB4B73WrIqQmV+HVX3koBAp1JMEaVFPUjxPqFdLi0j5am4WiqZpQrSj0eGboBMc0xS9UGIx8bazWXE//xuuqkLE/f5+Kzwv6Hk8T4i37aikcjqvHijnxX2VPLV9Cm3xIzc10LD5pvJxPuZ9G4CfGR/gS1PuB02nIpxjRmWS+XUx5lbHiPpzBas8kfDwbBfPcfBsBw2HiN9GcS2spEkuYZLssUn1WqRiNum4jXcYA1pRIFJuUFbno7LeT9W0IDUNAWpnBimpMFDUyeNVmXQcfPFw8AXKwfftnEj1yjSLiHHXEld0hdcB5D0EOqCBqvWJuS7Wu/Nr3oNeI0jbGbrSnbQn29A1g7ARHpx25YEeS+OEA8QumHNEsZZCPUmQQn2CEIuJ4ipNTaIqWl7J8pHHk3RdeygcR1RYy3erjMfFisDB0eilpf2tOg+H68GezggdiQCWo9KZCNCZDOB5kLZ0Nr9Zy/6eCODxz3yDe1mLH5Of8n7+H1/kTQZXKCsNmgR0hzk1Cd42t43pFUl01aMsmKMymCKb9rBtD111CQcc/LqDoTo4po2Zskn1mGRiJpm4RSZhk47ZpGI2jnX4nzt/SKO00qCsVljiFfV+qqYFqGkIEI5KER83PA/shBBq1xbr2flbJyc2NyNuPRs8R0Rb0rf0oSCEXOkTcUUXa+CKjqeodGZ62Nu7B9u18esBfJoPPV9gxfPwN/dilYWIvW0eTsnQaZ9SqCcJUqhPQDIZ4TvOW9vd3WJfIHDCuMgPxnUHt5ju7RVxePmW8aoq3nY+0lzThMNhOB9D2tSIpYWLsabxWZb8+g60vj7F+0pO5zfhD7Ix92Ge650/qIXowZQETC6e38qi6d0smtpBWMsWLixA5OS6louKg+Lm+zjbGKpJNt4v4tmEQzZlkU3Y2EdYBwcIhDVKKg3Ka32U1/mpqA9QPc1PdUOQUKk+Pj3BJYPxvD4BtwbcmqKSmpPuE/XM4DE44LkkzRS9VpZeK4PtWNjugMInrkeoOUmyIUrX4imohq9w0eZTfBi6gWfGSWa98Rfqd77znYd97i9/+Qu2bR+1XaWiKGzatOnYZjhJkEJ9guM4wtxsaxOVSvKFOhSlP4p8ghRZKTa9vRCLg20Jq7ujY3CMlmUJizrgFzF5+QDro6WNlex9lbpnnyC6ayuq23+Rn4nW0lE+n87oHLbYZ/NU8ly2pE7D8gw6En7S5uBFdbEenubMaT0sO7WF6pIsFaEcAd3GtkWgXS4r1sA928WxXVzLxbUdHNPBzthYGQsrZeJmLbBt7JyNlXYw0zaONTwRL6vxUVHvF2VWpwWomh4gVGqg6VLEJxSuA26uz5VugWOCHYdsJ46dImfnyDkmbqFCmliDMQ70kplTSe/p1ThBDcdzSZqJQoEW04nynvc8ODFKiI7GAFcU5YS1uqVQn2TE48Laztcgz3fp8PuFi7y0dFwahxwPslkhzHhCpDNZEXHe2gapZJ9wu4MDrT1EkRafb0AMkSLywI10jKrtf6bq1acJN7+FMsQCs6sZZCunkq6Yyh59Li9kT+OZ2AKe6jiTA0zFHqK8aW1phtnVcebWJJhdnaAqkkVVPVQFFMVDLWyiBntNKIlu54j3ONimg521cXIOZsbGSplYaRszbeNaNk7Wxs46uPaRRdwX0ghFDSKVPspq/ERr/UTrAlRNDRCJ6ug+BVVVCrEBknHE84TbfKj9uOIPf88ekcd/6ilQUYFVXUEmoGE5FtmMw7S6WeMr1Ndff31R8s+++93vjvoYY0FTUxPXXnst7e3t6LrO5z73Oa6++uphv14K9UlMvhJJvqd2a6sQcs8TYdX5te1JlP41Ety+37J8ilg+PQuE86GpSYh4Hs8b6K4Wm26mqI3vJBrbQ2nXHiKdewl17UOzD98T3EMhGaikValntzmNVq+WJreeTqpIEiFJhBThwv2BW0p0Ei4ca25NnCWzOzBUt3B01/HwXFA9m0V1rUwPdmJlbTzTwk5bZOMWZtrCygor3M462FkL7wh54QCaT0MP6hghg2CZj2h139r4FD/V0/2UlmmEwiqBwAm3wjJ5yXvWenvF47Iy0QHurLOIe96YaYBsc9lHS0sLbW1tLFq0iNbWVhYvXsyOHTsIh4dORTkYKdSSAqmUsLbb2oRwd3eLXKl8InNp6UlpPuXbgubJu82hv/paPqUsm+23yi3TxdfbTmlvE5HYASLxZkpSLYST7fjjHagD1xNHgIlBigiJI4j6wfvShMjhxx9Q8XSdHH4UXaOuLIOiKOQcDZ/qUq724lk2PjeLYprYWRs7Y+EdxRJHAc2v4QsZBEp8BMsMQuV+QmV+ghV+gqU+jICG2rdWGgjAaaedlH9W44fjCMFub4fp04kvXUp0zhwp1MeThQsX8stf/pLp06cPa7wUasmQ5Dtw5IPSmpr622z5/f3CfYKkgBWLfMU1xxHxewOFO50W10DJJORyLoFsjECqm6jTRdTrJZDuwUj1oKcTqFYOzcygWjlUM4NmZtGsLKqZQXVGJ/DHioNKDj8ZAvRSRjdV9FJGjChpNUyGMClCpNwQ7mEaneRRFZegYRPwuQSC4POrVNSo1E0ziNb4CZb78ZcGUAM+PMMHuoFnGKCJEqvRqFiGkBQBx4Hdu4lXVBBdvXpMNGDS/Dps3ryZu+++m61bt9LS0sLjjz/OlVdeOWjMhg0buPvuu2ltbWXhwoXcf//9LFmy5JjPtXXrVhzHGbZISySHJd83u6JCuMgsq99Nvm+fEPA9e4QChUJCtMPhE3Z9e7gMvG4JDpGePX++cKenUiq5XDmWVU5r6xz2dlJwFft84iM9nNtYcWxUK4tqZoWAmxlUM4tqiceqmekT9WxB7JVcFiUnxN6zRLS4aptorgmWhWfZGK6J4ebERr8LQcMlRIYQGSrpYQ4DOgkOWs9XSFBCT6HnWTm9lNHTdxunFNdTSZk+UiaQFK9r3A+84AFZ/APanva/UhyxVE2h6h5ewEAxdPFh57d8vfT87cHbaJ4/+DlNG9420ZeMNE10fEskxuwUk0aoU6kUCxcu5IYbbuD973//Ic8/8sgjrF27lgcffJClS5dy3333sWLFCt58801qamoAWLRoEbZ96FX073//e+rr6wHo7u7muuuu41vf+tbYviHJyYlhwJQpYjvrLGEudnQI8d6zR9y2tQnhDoeFcEcicpHyIFRVLP1HB1Q3nTVLfIQdHf2WeHMLaH2VMw/t16EDERQlImplhMFX3l+5rSh4LoptoVgWqmOh2ELQcxmXXMbFtWwScdjb6qe7VyOXcUgmwbMdAmQLm58cAbJESFBJByoims9DxUbHwoel+Eh6YTKEyBGgjTraqDt0Ti6EzBRlZi/lAy4HhKD3EKUXnQkU9JuvfzvcLT8+XzJ1OPeHei4UgmXLoE8bxpNJ6fpWFOUQi3rp0qWcd955PPDAAwC4rsv06dO5+eabufXWW4d13Fwux7ve9S5uvPFGrr322qOOzeVyhcfxeJzp06dL17dkdMTjYk07b3F3dgofLwjBLikRAi6F+6jk0+BTKeE6z/cFP5i8Sz1f+CWfMz4UijI4cl1VhTc5j983uCTrSL4m14P93WEaO0vY3VHC7o4IHYmgSIfzRGDbwPS4eMZHc7L/N8fAIjrIDu+hgm7K6SVKjAC5I5wdwMOnuQQMm6BhETYsysImFZEc0UCOEiOLT3UI+hwMxUH1bFTXRvcssZxgD9wskR9nW4P3WxZKvhF7vo/raOqxjxWqCh/6kNiORE8P8USC6E03ndyu7yNhmiZbt25l3bp1hX2qqrJ8+XKeeeaZYR3D8zyuv/563vnOdx5VpAHWr1/P5z//+RHPWSIZkvya9cyZcO65wp3W2SkUZ9++/nKniiIEWwr3YQkGYcaM4Y/PW+G9vUNrhgdkMyITL08uJ3QoPyCeEJoE/RcF+XKsxoA14byVny95nR8DoCrQUJmioTLFJae0Hn3eLvxky0y2NFZhO5DOaWxvq6DTrh5yvJ8s5fRSq7b3WdIxosSIer2UejEMbExHw3Q04tm+6LTuwcdQfZqIWg/o6H4dI6wTKvMRiPoIlPgwwgaaoaHqKqqmoGjqoKIwCqLV+Pz5A8oP5K888iXxDhbxg+8f7rn846PdP9q4xkbYsgUefljEk1x11VG/i7HihBDqzs5OHMehtrZ20P7a2lq2b98+rGP85S9/4ZFHHuGss87iiSeeAOAHP/gBZ5555pDj161bx9q1awuP8xa1RFI0FKVfuGfPhqVLRUnTri4h3E1NQrhbW8WPXN5VHgqd9GvcI0HThNMiEhn+awY25vI8EeiWj2S3beEYyVvz2RyFWtMH55qbprCkjb6l22BQCNhwvkZNhWuW7OGaJXsK+2xHIW32/7y7rlco9PI/z8/l4a2n0uoO4RbHI0x6wLq2sMqrlW6i9FLixdFwcU0H13Swkv1pcwO13FNUXMOHa/jxfH48nw8CfpRgECUUwB/20RCNsX8XNMxQCIZVNF1BM1RUzS8uYlRx0QJ9HgytbxshA5c/8u3Lj8pPfgLf/z5s3AhTp8IIYp6KwQkh1MXg7W9/O+4xuF78fj9+v39Q9yyJZExRFJG3WVYGc+bA+ef3C3dnZ7/F3draH5xWUiKUR0aVjwkHV2A72OM50HbI/0QMNBwH5pmnUmKVI5MRKyDxeF+bUBXCESHiB597YPEYY0ApV13zKA1aDMUnVu7k2ov3kcgaOJ6C7fR7qXM52LK3mtdbKnDdcuJWJX/rrMFytb7TeIRJCgucOFFilA64HyVGhBSK5/YF6GUhdegcXOBNfOzyqbzk99D8wkLXAjq6X8MI+9BDBv6IH9VQ0XQVRVNQVHGraiqKqhxT/fX8d6Uo4A9ATbX4p+TzC4NZO6gDKUDoyg+gdXTAb34DX/kKfOYzsHDhsM9ZLE6If71VVVVomkZbW9ug/W1tbdTVDXXVWDzWrFnDmjVrCulZEslx42DhXrJE/OLnhXv//v77jiNMtPw6t8zNOe4cbB0P/AoOtuIzGWGdp9Pi2qu9XewbyMFdLS1rcJOo0tJDxT1PNGhSHh66iMy5pyRhQER6PKPR1BHEtjyx5Gx57OkqZX9PCMcuwbYj7E2eSiwnmrAonkvQTRLykoTdFCEvSchNEu7bQm4CHxZ+TDCFN4EjBExnlQAZJUxGDZFVQ2TUMFk1RFYLkdHCmFoYUw+Aqg1YTlD6L2QU0DSP8pBJyGcTNBymReNMaYpTV5JCV72h69UrMG2qwhmr/xFt/3545RW4/XZ4xzvgbW+DU045ereaInFCCLXP52Px4sVs2rSpEGDmui6bNm3ipptuGtNzS4taMmEY6CqfNQvOO0+YaV1dYmtuFr/4Bw6IX0dd77e4g8GJnwZzEhEMiq2yEqZPH1zlDfqt8rww56vC5ZNaenvFdVpmaKOaru7BFuRAdF38SeSLp5QEHE5vSA4acz7p/rm4Ho7l9m99LnYzK6q0OaaD63q4tovrBFGUILGMwW93z2V7WxWGm6WEBCUkKO27zW8aLgEvS8DLUu52HfbzclFIEjno1QdvVaQJMrB5taE6TClNURr4/9u79+Coyvt/4O/dJLu5k8SQhIAEkItFIFAgabwhkC/EYfoTIjNoqU1EQSFSkcsU7BSw0xZ/ZmqpiuBtCi1WQL+CraNWJSGIxiiRFIUSCaYBNNkAca/Z+3m+f5ycs1kSQjCb7G7yfs2cSXIuu8+z50w++9xd0GpFu+CuQWK0CwtuqoXHY0X0wo3I1O1AcvVBoKxM3rRaeeTGwoXyTepFYdPr22q1oq6uDgAwZcoUPP3005g5cyZSUlIwfPhw7N27F0VFRXjhhReQk5ODrVu3Yt++fTh16lSHtuvewAlPKCw4nXIRTSmmnT8vl8JbW+X/ULGxclt3fHw3G/EoVClTuV5OCPl7m8nU+XVWqxzI23eKuzxKXF7lr23XOa7D+7UFaXUxFK8E4ZWglbyQvALNFn1b/zENvB7AI2nhlCJhckVDI0nQetzQeF3QelzQul3QuFzQuF3QuJzy5nahu18xJWjhioiBBfG45E2GUf1q4P8VwQkdAA3iopzIyTgLjRaIi/Lgp/Hl+B/L/yKtpRax33+rvq5p0m1o+J+7kf3HVQN7ZrJDhw5h5syZHfYXFRVh586dAIDnnntOnfBk8uTJeOaZZ5Cbm9sn6WOgprDk9cr/sZXgfe6c3K3ZapWPKcWruDi5iMfe5f2eEHL7uNopzgu02nxt7Mo5drvvi4AyBWx3o4nXKz9iDgcQEy2ggSSXuNs24RXQCi+ExwuPUw7ocoAXcn880VbFHaGBRgv5i4BbwOvywu2Q5HnX7V647W0/HVdfytTvM9BqYUECLknJbcHbV1qXInRIiXciK+I8Fjp24/+17kEEJBzRT8VtzuqBHahDVfuq76+//pqBmsJfa6scrFta5MlXGhvl/6qtbdWd0dFy4I6L67dLe1LvM5nkR8tg8FXZA3L7uuSVawS8Xt/64krJXHiltsAswevyyD3QJSEHcUk+TyYHcY1W7ngGjRLQ5R7rwu2F5PLIS5065dXS3Parr4jWnh3RENDgR/gPnHDgYexhoA5lLFFTv6WUur//Xt6amuRxRzab/N8UkEvbSrU5gzddg8ur1oWQHzlba9fV777zBSSPgMclweOW4HHJbeZulxcuuwSnzQuXwwuvB3A5JHg9Al6vgMulgcsFeIXce1wunWsgJMDrkuBxeuC0yV3ivW3LnnqcXthbBSSnG9rLlmO1a9z4/+L3nPAkFLEzGfV7ERG++coVTqccvI1GOXg3Nso/DQbf1F5K8I6NBddqpCvxG2bWJiLiWgYmtHXt7mIhE8krB3K3Sw7kbqcEj0uCyyHBYvTAbvPC4/K1pXs9gBBaWCxaWFujoG0L5B6vFm6PRl6SNUK0lcY9cF2ywiW1tu8sH1AsUQcIS9Q04LlcvuBtNsvB++JFuTHTbpeLRMocyjExcumbHdYoBAgh4PUIeFxtAb0tkHvcAo5WLxxWuVTutAtYzRIsZoHWVvk6QAOtsxXaaAcWlf2KJWoiCmE6nTwv5OB2U1d6PL7ZO8xm33SoVqtcAne7fRNoK2OSOLMa9TGNRoPIKA0iowDEdf7sCdEukLskeJxyIHc5vXAZPLA63EBZ76SPgZqIek9kZMdqc6XLsMkkb2az3Obd0iIPFVNWD9No5CpzJXiz+pyCSKPRIEqvQZReiw4rrw52w2zpveZPBuoeYhs10TVSxmvHxsrLfSokSS5pm0zyT6NRDtpGozzwV1n+Sqk+VzZWn1M/xzbqAGEbNVEvcbvlkrbF4lsGtLHRN1GLMranfdu3Xs+Z1qjvcJlLIhrQoqI6rz5vbZUDt1KF3tjom3FN6XmujPlWqs4ZvCkMMVATUfhR1uOOi/OvPld6nivjvg0GuQObst4kIJe22wdvtntTiGOg7iG2UROFkM56nrvdcuC2WOT27u++83VeU4aNRUb6An9MDHudU0hhG3WAsI2aKIy0HzZmMsmB22CQg7kyiXX7Tm+xsb7lpIguxzZqIqIA62zYmCT5OqyZzb4Z15SqdGXVCZ3O13EtJoa9zqnXMVATEQFyW/WgQfLWnt0uB26l5/nFi/J85zab/LvS61yn8437jo5mCZwChoGaiKgrSsm5/br2kiT3OleCtxLAL13yrT7mdPoWbtbrfQE8Oppt4HRNGKh7iJ3JiAYgrVZepzs+3r/XuTLrmhK8rVbf2G9lARNl/UZArjbX632BXK9nEKcO2JksQNiZjIi65HbL1eU2mxzAlfnOlUVMHA7f7GuArypdqU7X6TgOPFSxMxkRUT8QFQUkJcnb5VwuOXC3D+QtLXJVus0md2ZzOHxV6e07szGA93sM1EREwabTdeyFDsila4fDvyrdaJR7oyvzojud8nlK9bkynIxV6P0GAzURUajSaHwl57Q0336lLdxm803kYjB0vgKZMv95XJz8hYDCDgM1EVG4aT8ZS/tZ2NqvQKYE8KYmuS3822/ldnJALn3HxvpmYmPVeUhjoCYi6i+0WiAxUd7as9vloK0E8OZm33Ayu10+5/KJXCIZHkIF70QPcXgWEYU8Jfi2H0rm8fhmXTOZ5ODd3OwL5F6vb/ETpe2bk7gEBYdnBQiHZxFR2FOqzi0WOXgra3+bzfJELsokLkrpWymBD/SOaxyeRUREfaJ91fnQob79yiQuyjzozc3yQibKOuBC+Hd8U0rfXEI0IBioiYioa531PJckX+BWSuDNzXLHtQsXfMPG2o/7jo1lz/MfgIGaiIiunVbb+QQuLpev9K3MgX7hgvz799/7ep5HRvqqz3U6eWMJvFMM1EREFDg6HXDddfLWXmurr63bYpGDd3OzbxIXh0M+TwngyhzonP+cgVphNBqRn58Pj8cDj8eDRx99FEuXLg12soiI+gel9NyeEPKkLXa7b/z3xYtyAHc4fMeEkEvbyrznyixsAySAM1C3SUhIwOHDhxEbGwubzYYJEyagsLAQ113+rZCIiAJDo/GtQtZ+4hYh5Cp0pfRtMsnV5pcuyb8r06gK4Zs+Vafrt8PIGKjbREREILbt257T6YQQAhy5RkQUBBqNr9o7Odn/mMfjWz5U6Y3e0iIHcmU2NpfLN9ta+wAeHS0vjhJmwiZQHz58GKWlpaiurkZjYyP279+P+fPn+52zbds2lJaWoqmpCdnZ2Xj22WeRk5PT7fcwGo2YMWMGTp8+jdLSUqSmpgY4F0RE1CORkVdehUwpgVsscrW5yyWXwpXObMpELoAcyJWqdGUVshAN4mETqG02G7Kzs7FkyRIUFhZ2OL53716sXr0aO3bsQG5uLrZu3Yq5c+eitrYWaW1DCiZPngyPx9Ph2vfffx+ZmZlISkrCv//9bxgMBhQWFmLhwoVIT0/v9bwREVEAKO3gl//fViZysVrlYK4sZtLS4iuNu1xyaR2Q276V6nS9Xg7oQVxONCxnJtNoNB1K1Lm5uZg+fTqee+45AIAkSbj++uuxcuVKrF+//prfY8WKFZg1axYWLlzY6XGn0wmn06n+bTabcf3113NmMiKicKJUpdvtvk5tRqMcvM1muVOb0ylvgNypTSl9K0HcbofZZuPMZF1xuVyorq7Ghg0b1H1arRb5+fmorKzs1msYDAbExsYiISEBJpMJhw8fxvLly694/pYtW/DEE0/0OO1ERBREXVWlS5IcvJUqdaVt3GSSf7fZ5BK53S53iOutJPbaK/ehixcvwuv1dqimTk9Px6lTp7r1Gg0NDVi2bJnaiWzlypWYOHHiFc/fsGEDVq9erf6tlKiJiKif0Gp9a3m375WucLl8Vepmc68lo18E6kDIyclBTU1Nt8/X6/XQ6/VcPYuIaKDS6YCUFHnrxUDdL+ZrS01NRUREBAwGg99+g8GAjIyMXn3vkpISnDx5Ep9//nmvvg8REQ1M/SJQ63Q6TJ06FQcPHlT3SZKEgwcPIi8vr1ffe9u2bRg/fjymT5/eq+9DREQDU9hUfVutVtTV1al/19fXo6amBikpKRg+fDhWr16NoqIiTJs2DTk5Odi6dStsNhvuv//+Xk1XSUkJSkpK1PWoiYiIAilsAvXRo0cxc+ZM9W+lI1dRURF27tyJRYsW4cKFC9i4cSOampowefJkvPfeexwHTUREYS0sx1GHkvadyb7++muOoyYiGoCUWtXeiAEM1AHSmzeJiIhCW2/GgH7RmYyIiKi/YqDuIfb6JiKi3sSq7wBh1TcR0cDFqm8iIqIBioG6h1j1TUREvYlV3wFiMpmQlJSEc+fOseqbiGiAURZmMhqNAZ/8KmwmPAl1FosFALiCFhHRAGaxWAIeqFmiDhBJklBbW4vx48cP2FK18o2S+R94+R/IeQeYf+Zfzv/Jkycxbtw4aLWBbVVmiTpAtFothg4dCgBITEwckA+rgvkfuPkfyHkHmP+Bnv+hQ4cGPEgD7ExGREQU0hioiYiIQhgDdQDp9Xps2rQJer0+2EkJCuZ/4OZ/IOcdYP6Z/97NPzuTERERhTCWqImIiEIYAzUREVEIY6AmIiIKYQzUAbJt2zaMGDEC0dHRyM3NxWeffRbsJPWKzZs3Q6PR+G033nijetzhcKCkpATXXXcd4uPjcffdd8NgMAQxxT1z+PBh/PSnP0VmZiY0Gg0OHDjgd1wIgY0bN2LIkCGIiYlBfn4+Tp8+7XdOS0sLFi9ejMTERCQlJeGBBx6A1Wrtw1z8cFfLf3FxcYfnoaCgwO+ccM3/li1bMH36dCQkJCAtLQ3z589HbW2t3znded7Pnj2LefPmITY2FmlpaVi3bh08Hk9fZuUH6U7+77jjjg73/+GHH/Y7J1zzv337dkyaNEkdG56Xl4d3331XPd6X956BOgD27t2L1atXY9OmTfjiiy+QnZ2NuXPnorm5OdhJ6xU33XQTGhsb1e3IkSPqscceewz//Oc/8frrr6OiogLfffcdCgsLg5janrHZbMjOzsa2bds6Pf7UU0/hmWeewY4dO1BVVYW4uDjMnTsXDodDPWfx4sU4ceIEPvjgA7z99ts4fPgwli1b1ldZ6JGr5R8ACgoK/J6H1157ze94uOa/oqICJSUl+PTTT/HBBx/A7XZjzpw5sNls6jlXe969Xi/mzZsHl8uFTz75BLt27cLOnTuxcePGYGTpmnQn/wCwdOlSv/v/1FNPqcfCOf/Dhg3Dk08+ierqahw9ehSzZs3CXXfdhRMnTgDo43svqMdycnJESUmJ+rfX6xWZmZliy5YtQUxV79i0aZPIzs7u9JjRaBRRUVHi9ddfV/f95z//EQBEZWVlH6Ww9wAQ+/fvV/+WJElkZGSI0tJSdZ/RaBR6vV689tprQgghTp48KQCIzz//XD3n3XffFRqNRnz77bd9lvZAuDz/QghRVFQk7rrrrite05/y39zcLACIiooKIUT3nvd33nlHaLVa0dTUpJ6zfft2kZiYKJxOZ99moIcuz78QQsyYMUM8+uijV7ymP+VfCCGSk5PFyy+/3Of3niXqHnK5XKiurkZ+fr66T6vVIj8/H5WVlUFMWe85ffo0MjMzMWrUKCxevBhnz54FAFRXV8Ptdvt9FjfeeCOGDx/eLz+L+vp6NDU1+eV30KBByM3NVfNbWVmJpKQkTJs2TT0nPz8fWq0WVVVVfZ7m3nDo0CGkpaVh3LhxWL58OS5duqQe60/5N5lMAICUlBQA3XveKysrMXHiRKSnp6vnzJ07F2azWS2ZhYvL86949dVXkZqaigkTJmDDhg1obW1Vj/WX/Hu9XuzZswc2mw15eXl9fu8513cPXbx4EV6v1+9mAEB6ejpOnToVpFT1ntzcXOzcuRPjxo1DY2MjnnjiCdx222346quv0NTUBJ1Oh6SkJL9r0tPT0dTUFJwE9yIlT53de+VYU1MT0tLS/I5HRkYiJSWlX3wmBQUFKCwsxMiRI3HmzBk8/vjjuPPOO1FZWYmIiIh+k39JkrBq1SrccsstmDBhAgB063lvamrq9PlQjoWLzvIPAD/72c+QlZWFzMxMHD9+HL/61a9QW1uLN998E0D45//LL79EXl4eHA4H4uPjsX//fowfPx41NTV9eu8ZqOma3HnnnervkyZNQm5uLrKysrBv3z7ExMQEMWUUDPfcc4/6+8SJEzFp0iTccMMNOHToEGbPnh3ElAVWSUkJvvrqK7/+GAPJlfLfvq/BxIkTMWTIEMyePRtnzpzBDTfc0NfJDLhx48ahpqYGJpMJb7zxBoqKilBRUdHn6WDVdw+lpqYiIiKiQ28/g8GAjIyMIKWq7yQlJWHs2LGoq6tDRkYGXC4XjEaj3zn99bNQ8tTVvc/IyOjQqdDj8aClpaVffiajRo1Camoq6urqAPSP/D/yyCN4++23UV5ejmHDhqn7u/O8Z2RkdPp8KMfCwZXy35nc3FwA8Lv/4Zx/nU6H0aNHY+rUqdiyZQuys7Px5z//uc/vPQN1D+l0OkydOhUHDx5U90mShIMHDyIvLy+IKesbVqsVZ86cwZAhQzB16lRERUX5fRa1tbU4e/Zsv/wsRo4ciYyMDL/8ms1mVFVVqfnNy8uD0WhEdXW1ek5ZWRkkSVL/qfUn58+fx6VLlzBkyBAA4Z1/IQQeeeQR7N+/H2VlZRg5cqTf8e4873l5efjyyy/9vqx88MEHSExMxPjx4/smIz/Q1fLfmZqaGgDwu//hmv/OSJIEp9PZ9/c+ED3hBro9e/YIvV4vdu7cKU6ePCmWLVsmkpKS/Hr79Rdr1qwRhw4dEvX19eLjjz8W+fn5IjU1VTQ3NwshhHj44YfF8OHDRVlZmTh69KjIy8sTeXl5QU71D2exWMSxY8fEsWPHBADx9NNPi2PHjomGhgYhhBBPPvmkSEpKEm+99ZY4fvy4uOuuu8TIkSOF3W5XX6OgoEBMmTJFVFVViSNHjogxY8aIe++9N1hZuiZd5d9isYi1a9eKyspKUV9fLz788EPx4x//WIwZM0Y4HA71NcI1/8uXLxeDBg0Shw4dEo2NjerW2tqqnnO1593j8YgJEyaIOXPmiJqaGvHee++JwYMHiw0bNgQjS9fkavmvq6sTv/3tb8XRo0dFfX29eOutt8SoUaPE7bffrr5GOOd//fr1oqKiQtTX14vjx4+L9evXC41GI95//30hRN/eewbqAHn22WfF8OHDhU6nEzk5OeLTTz8NdpJ6xaJFi8SQIUOETqcTQ4cOFYsWLRJ1dXXqcbvdLlasWCGSk5NFbGysWLBggWhsbAxiinumvLxcAOiwFRUVCSHkIVq/+c1vRHp6utDr9WL27NmitrbW7zUuXbok7r33XhEfHy8SExPF/fffLywWSxByc+26yn9ra6uYM2eOGDx4sIiKihJZWVli6dKlHb6ghmv+O8s3APGXv/xFPac7z/t///tfceedd4qYmBiRmpoq1qxZI9xudx/n5tpdLf9nz54Vt99+u0hJSRF6vV6MHj1arFu3TphMJr/XCdf8L1myRGRlZQmdTicGDx4sZs+erQZpIfr23nP1LCIiohDGNmoiIqIQxkBNREQUwhioiYiIQhgDNRERUQhjoCYiIgphDNREREQhjIGaiIgohDFQExERhTAGaiIKCZs3b4ZGo0FxcXGwk0IUUhioicJEcXExNBpNt7ZDhw4FO7lEFCBcj5oozERFRSElJaXLc3Q6XR+lhoh6GwM1UZi5+eabWWImGkBY9U1ERBTCGKiJ+rkRI0ao7dYNDQ1YsmQJhg4diujoaIwdOxabN2+Gw+G44vVerxcvvPACbr31ViQnJyMmJgZjx47FqlWr0NjY2OV7Nzc34/HHH0d2djYSExMRHx+PH/3oRyguLkZZWVmX177yyiuYNm0a4uPjkZSUhIKCAlRVVV3x/PLychQWFiIzMxM6nQ7JyckYN24c7rnnHuzZs6frD4kolPVwyU4i6iNFRUUCgJgxY8Y1XZeVlSUAiBdffFFcd911AoBISEgQer1eXWM4Jyen0zWirVarmDVrlnqeTqcTiYmJ6t/Jycmiqqqq0/f98MMPxaBBg9Rz9Xq9SE5OFhqNRgAQWVlZfudv2rRJXeu6uLhYABCRkZEiPj7e7zU++uijDu/1/PPP+62ZnJCQIKKjo9W/09PTr+kzIwolLFETDRDr1q1DamoqKisrYTabYbVa8eqrryI+Ph6fffYZ1qxZ0+Gaxx57DGVlZYiNjcXOnTthtVphMplw7NgxTJkyBd9//z0WLFgAo9Hod11tbS3mz58Pk8mEn/zkJzhy5AjsdjtaWlpgNptx4MABzJ49u9N0vvXWW9i3bx9efvllWCwWWCwWnDhxApMmTYLT6cSqVav8zrfZbFi3bh0AYMOGDbhw4QLMZjPsdjuam5vxxhtvYN68eQH5DImCItjfFIioe5QSdVRUlEhPT7/iNnbsWL/rlBJ1TEyM+Oabbzq87t///ncBQGi1WnHu3Dl1/zfffCO0Wq0AIHbv3t3hOoPBIOLi4gQA8Yc//MHv2IIFCwQAMWXKFGG327uVP6VEDUC89NJLHY4fO3ZMPV5fX6/ur6qqEgDEjTfe2K33IQo3LFEThRm32w2DwdDl1plFixZh5MiRHfbfe++9GDFiBCRJwv79+9X9+/fvhyRJGDlyJBYvXtzhurS0NCxduhQA8MYbb6j7LRYL/vGPfwAAfve73yE6Ovqa8peZmYn777+/w/7Jkydj2LBhAIATJ06o+xMTEwEAJpMJra2t1/ReROGAgZoozMyYMQNCiCtul1dDt7/uSm6//XYAwLFjx9R9X3zxBQDgjjvuuOJ1M2fOBAAcP34cXq8XAHD06FF4vV5ERUVdsXq7KzfddBMiIiI6PTZ06FAA8Mvj6NGjccMNN6CxsRF5eXl48cUXUV9ff83vSxSqGKiJBojMzMyrHrtw4YK67+LFiwB8wbEzWVlZAACPx6MGz+bmZgBAeno69Hp9QNOplM7dbre6LzIyEq+++iqGDBmC48eP46GHHsKoUaOQmZmJ4uJiHD58+JrTQBRKGKiJqEtOpzPYSbiq3Nxc1NXV4a9//SsWL16M4cOHo7GxEbt27cKMGTOwYsWKYCeR6AdjoCYaIL777rurHhs8eLC6T/n97NmzV7yuoaEBgFyqTUpKAiCXpAHAYDD0aZCPjY3Ffffdh927d6OhoQGnTp3C8uXLAQDbt2/Hv/71rz5LC1EgMVATDRBdVQF/9NFHAIApU6ao+5TfP/74Y3g8nk6vKy8vBwBMmjRJbVeeOnUqIiMj4Xa7cfDgwYCk/YcYN24cnn/+edx6660AgIqKiqClhagnGKiJBoi9e/eqJeD29u3bh/r6ekRERGDBggXq/sLCQmi1Wpw/fx67d+/ucF1zczNeeuklAMDChQvV/QkJCZg/fz4A4Ne//nWXs54Fgsvl6vJ4TEwMAPR6Ooh6CwM10QARFRWFgoICfPbZZwDkDmB79uzBgw8+CAB44IEH1OFPgDz16AMPPAAAWLlyJXbv3q124qqpqUFBQQFsNhsyMzPVKmbF73//e8TFxaGmpgazZs3CJ598AiEEAMBqtWLv3r34+c9/HpB8vfPOO7j55pvxyiuv4Ny5c+p+i8WC0tJSfPjhhwCAuXPnBuT9iPoaV88iCjOffPIJMjIyujxn7dq1WLt2rd++0tJSbNiwAbm5uUhISIDb7VZLmTk5OfjjH//Y4XX+9Kc/oa6uDuXl5bjvvvvw4IMPQq/Xw2w2AwCSk5Px5ptvqu3TirFjx+LAgQO4++67UVlZiVtuuQXR0dGIjY2F0WiEJElqj/FAqKysRGVlJQC5rVqn0/kN4XrooYcYqClssURNFGa6M+GJ1WrtcN2YMWNQXV2N4uJixMfHQ5IkjB49Ghs3bkRFRQXi4+M7XBMXF4f3338f27dvR15eHvR6PZxOJ0aPHo1f/vKXOHHiBHJzcztNZ35+Pk6dOoW1a9di/Pjx0Gq1cLvdGDt2LJYsWYJdu3YF5POYNWsW/va3v+EXv/gFJkyYgOjoaFitVqSnp2PevHk4cOAAduzYEZD3IgoGjVDqo4ioXxoxYgQaGhpQXl7e5eQlRBSaWKImIiIKYQzUREREIYyBmoiIKIQxUBMREYUwdiYjIiIKYSxRExERhTAGaiIiohDGQE1ERBTCGKiJiIhCGAM1ERFRCGOgJiIiCmEM1ERERCGMgZqIiCiEMVATERGFsP8DZVFWbukf17gAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "# Calculate means and standard deviations across experiments\n",
    "mean_train_gradnorm1 = np.mean(train_gradnorms1, axis=0)\n",
    "std_train_gradnorm1 = np.std(train_gradnorms1, axis=0)\n",
    "mean_train_gradnorm2 = np.mean(train_gradnorms2, axis=0)\n",
    "std_train_gradnorm2 = np.std(train_gradnorms2, axis=0)\n",
    "mean_train_gradnorm3 = np.mean(train_gradnorms3, axis=0)\n",
    "std_train_gradnorm3 = np.std(train_gradnorms3, axis=0)\n",
    "mean_train_gradnorm4 = np.mean(train_gradnorms4, axis=0)\n",
    "std_train_gradnorm4 = np.std(train_gradnorms4, axis=0)\n",
    "mean_train_gradnorm5 = np.mean(train_gradnorms5, axis=0)\n",
    "std_train_gradnorm5 = np.std(train_gradnorms5, axis=0)\n",
    "\n",
    "# Create a figure\n",
    "plt.figure(figsize=(5, 4))\n",
    "\n",
    "# Plot mean accuracy with shaded std\n",
    "epochs = range(len(mean_train_gradnorm1))\n",
    "plt.semilogy(epochs, mean_train_gradnorm1, color='blue', label='5')\n",
    "plt.fill_between(epochs, mean_train_gradnorm1 - 0.5*std_train_gradnorm1, mean_train_gradnorm1 + 0.5*std_train_gradnorm1, \n",
    "                 color='blue', alpha=0.3)\n",
    "\n",
    "# Plot mean accuracy with shaded std\n",
    "epochs = range(len(mean_train_gradnorm2))\n",
    "plt.semilogy(epochs, mean_train_gradnorm2, color='green', label='1')\n",
    "plt.fill_between(epochs, mean_train_gradnorm2 - 0.5*std_train_gradnorm2, mean_train_gradnorm2 + 0.5*std_train_gradnorm2, \n",
    "                 color='green', alpha=0.3)\n",
    "\n",
    "# Plot mean accuracy with shaded std\n",
    "epochs = range(len(mean_train_gradnorm3))\n",
    "plt.semilogy(epochs, mean_train_gradnorm3, color='orange', label='0.5')\n",
    "plt.fill_between(epochs, mean_train_gradnorm3 - 0.5*std_train_gradnorm3, mean_train_gradnorm3 + 0.5*std_train_gradnorm3, \n",
    "                 color='orange', alpha=0.3)\n",
    "\n",
    "# Plot mean accuracy with shaded std\n",
    "epochs = range(len(mean_train_gradnorm4))\n",
    "plt.semilogy(epochs, mean_train_gradnorm4, color='red', label='0.1')\n",
    "plt.fill_between(epochs, mean_train_gradnorm4 - 0.5*std_train_gradnorm4, mean_train_gradnorm4 + 0.5*std_train_gradnorm4, \n",
    "                 color='red', alpha=0.3)\n",
    "\n",
    "# Plot mean accuracy with shaded std\n",
    "epochs = range(len(mean_train_gradnorm5))\n",
    "plt.semilogy(epochs, mean_train_gradnorm5, color='purple', label='0.05')\n",
    "plt.fill_between(epochs, mean_train_gradnorm5 - 0.5*std_train_gradnorm5, mean_train_gradnorm5 + 0.5*std_train_gradnorm5, \n",
    "                 color='purple', alpha=0.3)\n",
    "\n",
    "plt.xlabel('Epochs', fontsize=17)\n",
    "plt.xlim([-1, 301])\n",
    "plt.ylabel('Hypergrad Norm', fontsize=17)\n",
    "# plt.title('Validation Accuracy vs Epochs')\n",
    "plt.legend()\n",
    "# plt.grid(True, linestyle='--', alpha=0.7)\n",
    "plt.tight_layout()\n",
    "# plt.savefig(f'../fig/robust_dataratio{ratio}_deep_hyrep_spd_gradnorm_{method}_{methodopt}_bestiter.png')\n",
    "plt.savefig(f'../fig/robust_dataratio{ratio}_deep_hyrep_spd_gradnorm_{method}_{methodopt}_bestiter.pdf', format='pdf', bbox_inches='tight')\n",
    "plt.show()\n",
    "\n",
    "  \n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
