{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "\n",
    "ratio = 0.05\n",
    "method = 'RHGD'\n",
    "methodopt = '20'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 302 epochs\n",
      "Experiment 2 has 302 epochs\n",
      "Experiment 3 has 302 epochs\n",
      "Experiment 4 has 302 epochs\n",
      "Experiment 5 has 302 epochs\n"
     ]
    }
   ],
   "source": [
    "lr = 5\n",
    "with open(f'../results/hyrep_spd_{method}_lr{lr}_loweriter{methodopt}data_ratio{ratio}.pkl', 'rb') as handle:\n",
    "    data = pickle.load(handle)\n",
    "\n",
    "# Get the accuracy data from the data dictionary\n",
    "all_accuracies = data['accuracy']\n",
    "new_all_accuracies = []\n",
    "for i in range(len(all_accuracies)):\n",
    "    new_all_accuracies.append(all_accuracies[i].cummax(dim=1)[0])\n",
    "all_accuracies = new_all_accuracies\n",
    "\n",
    "all_test_accuracies = data['test_accuracy']\n",
    "new_all_test_accuracies = []\n",
    "for i in range(len(all_test_accuracies)):\n",
    "    new_all_test_accuracies.append(all_test_accuracies[i].cummax(dim=1)[0])\n",
    "all_test_accuracies = new_all_test_accuracies\n",
    "\n",
    "# Determine how many experiments we have\n",
    "num_experiments = len(all_accuracies)\n",
    "print(f\"Found {num_experiments} experiments in the data\")\n",
    "\n",
    "# Prepare arrays for storing padded data\n",
    "train_accuracies = []\n",
    "test_accuracies = []\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_acc = all_accuracies[i].reshape(-1)\n",
    "    \n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(train_acc)\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_acc = np.pad(train_acc, (0, max_epochs - num_epochs), \n",
    "                            'constant', constant_values=train_acc[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        train_acc = train_acc[:max_epochs]\n",
    "        train_acc = train_acc.numpy()\n",
    "    \n",
    "    # Add to our list\n",
    "    train_accuracies.append(train_acc)\n",
    "    \n",
    "    # Same for test accuracy if available\n",
    "    if i < len(all_test_accuracies):\n",
    "        test_acc = all_test_accuracies[i].reshape(-1)\n",
    "        if len(test_acc) < max_epochs:\n",
    "            test_acc = np.pad(test_acc, (0, max_epochs - len(test_acc)),\n",
    "                                'constant', constant_values=test_acc[-1])\n",
    "        else:\n",
    "            test_acc = test_acc[:max_epochs]\n",
    "            test_acc = test_acc.numpy()\n",
    "        test_accuracies.append(test_acc)\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_accuracies1 = np.array(train_accuracies)\n",
    "test_accuracies1 = np.array(test_accuracies) if test_accuracies else None\n",
    "\n",
    "# val50times1 = data['val50_time']\n",
    "# val50times1 = np.array([t.item() for t in val50times1])\n",
    "# val50time_mean1 = np.mean(val50times1)\n",
    "# val50time_std1 = np.std(val50times1)\n",
    "\n",
    "# print(f\"Mean time for 50% val acc: {val50time_mean1:.2f} ± {val50time_std1:.2f} seconds\")\n",
    "\n",
    "# val70times1 = data['val70_time']\n",
    "# val70times1 = np.array([t.item() for t in val70times1])\n",
    "# val70time_mean1 = np.mean(val70times1)\n",
    "# val70time_std1 = np.std(val70times1)\n",
    "\n",
    "# print(f\"Mean time for 70% val acc: {val70time_mean1:.2f} ± {val70time_std1:.2f} seconds\")\n",
    "\n",
    "# val85times1 = data['val85_time']\n",
    "# val85times1 = np.array([t.item() for t in val85times1])\n",
    "# val85time_mean1 = np.mean(val85times1)\n",
    "# val85time_std1 = np.std(val85times1)\n",
    "\n",
    "# print(f\"Mean time for 85% val acc: {val85time_mean1:.2f} ± {val85time_std1:.2f} seconds\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 302 epochs\n",
      "Experiment 2 has 302 epochs\n",
      "Experiment 3 has 302 epochs\n",
      "Experiment 4 has 302 epochs\n",
      "Experiment 5 has 302 epochs\n"
     ]
    }
   ],
   "source": [
    "lr = 1\n",
    "with open(f'../results/hyrep_spd_{method}_lr{lr}_loweriter{methodopt}data_ratio{ratio}.pkl', 'rb') as handle:\n",
    "    data = pickle.load(handle)\n",
    "\n",
    "# Get the accuracy data from the data dictionary\n",
    "all_accuracies = data['accuracy']\n",
    "new_all_accuracies = []\n",
    "for i in range(len(all_accuracies)):\n",
    "    new_all_accuracies.append(all_accuracies[i].cummax(dim=1)[0])\n",
    "all_accuracies = new_all_accuracies\n",
    "\n",
    "all_test_accuracies = data['test_accuracy']\n",
    "new_all_test_accuracies = []\n",
    "for i in range(len(all_test_accuracies)):\n",
    "    new_all_test_accuracies.append(all_test_accuracies[i].cummax(dim=1)[0])\n",
    "all_test_accuracies = new_all_test_accuracies\n",
    "\n",
    "# Determine how many experiments we have\n",
    "num_experiments = len(all_accuracies)\n",
    "print(f\"Found {num_experiments} experiments in the data\")\n",
    "\n",
    "# Prepare arrays for storing padded data\n",
    "train_accuracies = []\n",
    "test_accuracies = []\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_acc = all_accuracies[i].reshape(-1)\n",
    "    \n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(train_acc)\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_acc = np.pad(train_acc, (0, max_epochs - num_epochs), \n",
    "                            'constant', constant_values=train_acc[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        train_acc = train_acc[:max_epochs]\n",
    "        train_acc = train_acc.numpy()\n",
    "    \n",
    "    # Add to our list\n",
    "    train_accuracies.append(train_acc)\n",
    "    \n",
    "    # Same for test accuracy if available\n",
    "    if i < len(all_test_accuracies):\n",
    "        test_acc = all_test_accuracies[i].reshape(-1)\n",
    "        if len(test_acc) < max_epochs:\n",
    "            test_acc = np.pad(test_acc, (0, max_epochs - len(test_acc)),\n",
    "                                'constant', constant_values=test_acc[-1])\n",
    "        else:\n",
    "            test_acc = test_acc[:max_epochs]\n",
    "            test_acc = test_acc.numpy()\n",
    "        test_accuracies.append(test_acc)\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_accuracies2 = np.array(train_accuracies)\n",
    "test_accuracies2 = np.array(test_accuracies) if test_accuracies else None\n",
    "\n",
    "# val50times2 = data['val50_time']\n",
    "# val50times2 = np.array([t.item() for t in val50times2])\n",
    "# val50time_mean2 = np.mean(val50times2)\n",
    "# val50time_std2 = np.std(val50times2)\n",
    "\n",
    "# print(f\"Mean time for 50% val acc: {val50time_mean2:.2f} ± {val50time_std2:.2f} seconds\")\n",
    "\n",
    "# val70times2 = data['val70_time']\n",
    "# val70times2 = np.array([t.item() for t in val70times2])\n",
    "# val70time_mean2 = np.mean(val70times2)\n",
    "# val70time_std2 = np.std(val70times2)\n",
    "\n",
    "# print(f\"Mean time for 70% val acc: {val70time_mean2:.2f} ± {val70time_std2:.2f} seconds\")\n",
    "\n",
    "# val85times2 = data['val85_time']\n",
    "# val85times2 = np.array([t.item() for t in val85times2])\n",
    "# val85time_mean2 = np.mean(val85times2)\n",
    "# val85time_std2 = np.std(val85times2)\n",
    "\n",
    "# print(f\"Mean time for 85% val acc: {val85time_mean2:.2f} ± {val85time_std2:.2f} seconds\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 302 epochs\n",
      "Experiment 2 has 302 epochs\n",
      "Experiment 3 has 302 epochs\n",
      "Experiment 4 has 302 epochs\n",
      "Experiment 5 has 302 epochs\n"
     ]
    }
   ],
   "source": [
    "lr = 0.5\n",
    "with open(f'../results/hyrep_spd_{method}_lr{lr}_loweriter{methodopt}data_ratio{ratio}.pkl', 'rb') as handle:\n",
    "    data = pickle.load(handle)\n",
    "\n",
    "# Get the accuracy data from the data dictionary\n",
    "all_accuracies = data['accuracy']\n",
    "new_all_accuracies = []\n",
    "for i in range(len(all_accuracies)):\n",
    "    new_all_accuracies.append(all_accuracies[i].cummax(dim=1)[0])\n",
    "all_accuracies = new_all_accuracies\n",
    "\n",
    "all_test_accuracies = data['test_accuracy']\n",
    "new_all_test_accuracies = []\n",
    "for i in range(len(all_test_accuracies)):\n",
    "    new_all_test_accuracies.append(all_test_accuracies[i].cummax(dim=1)[0])\n",
    "all_test_accuracies = new_all_test_accuracies\n",
    "\n",
    "# Determine how many experiments we have\n",
    "num_experiments = len(all_accuracies)\n",
    "print(f\"Found {num_experiments} experiments in the data\")\n",
    "\n",
    "# Prepare arrays for storing padded data\n",
    "train_accuracies = []\n",
    "test_accuracies = []\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_acc = all_accuracies[i].reshape(-1)\n",
    "    \n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(train_acc)\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_acc = np.pad(train_acc, (0, max_epochs - num_epochs), \n",
    "                            'constant', constant_values=train_acc[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        train_acc = train_acc[:max_epochs]\n",
    "        train_acc = train_acc.numpy()\n",
    "    \n",
    "    # Add to our list\n",
    "    train_accuracies.append(train_acc)\n",
    "    \n",
    "    # Same for test accuracy if available\n",
    "    if i < len(all_test_accuracies):\n",
    "        test_acc = all_test_accuracies[i].reshape(-1)\n",
    "        if len(test_acc) < max_epochs:\n",
    "            test_acc = np.pad(test_acc, (0, max_epochs - len(test_acc)),\n",
    "                                'constant', constant_values=test_acc[-1])\n",
    "        else:\n",
    "            test_acc = test_acc[:max_epochs]\n",
    "            test_acc = test_acc.numpy()\n",
    "        test_accuracies.append(test_acc)\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_accuracies3 = np.array(train_accuracies)\n",
    "test_accuracies3 = np.array(test_accuracies) if test_accuracies else None\n",
    "\n",
    "# val50times3 = data['val50_time']\n",
    "# val50times3 = np.array([t.item() for t in val50times3])\n",
    "# val50time_mean3 = np.mean(val50times3)\n",
    "# val50time_std3 = np.std(val50times3)\n",
    "\n",
    "# print(f\"Mean time for 50% val acc: {val50time_mean3:.2f} ± {val50time_std3:.2f} seconds\")\n",
    "\n",
    "# val70times3 = data['val70_time']\n",
    "# val70times3 = np.array([t.item() for t in val70times3])\n",
    "# val70time_mean3 = np.mean(val70times3)\n",
    "# val70time_std3 = np.std(val70times3)\n",
    "\n",
    "# print(f\"Mean time for 70% val acc: {val70time_mean3:.2f} ± {val70time_std3:.2f} seconds\")\n",
    "\n",
    "# val85times3 = data['val85_time']\n",
    "# val85times3 = np.array([t.item() for t in val85times3])\n",
    "# val85time_mean3 = np.mean(val85times3)\n",
    "# val85time_std3 = np.std(val85times3)\n",
    "\n",
    "# print(f\"Mean time for 85% val acc: {val85time_mean3:.2f} ± {val85time_std3:.2f} seconds\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 302 epochs\n",
      "Experiment 2 has 302 epochs\n",
      "Experiment 3 has 302 epochs\n",
      "Experiment 4 has 302 epochs\n",
      "Experiment 5 has 302 epochs\n",
      "Mean time for 50% val acc: 36.01 ± 12.37 seconds\n",
      "Mean time for 70% val acc: 168.47 ± 120.86 seconds\n",
      "Mean time for 85% val acc: 540.46 ± 88.54 seconds\n"
     ]
    }
   ],
   "source": [
    "lr = 0.1\n",
    "with open(f'../results/hyrep_spd_{method}_lr{lr}_loweriter{methodopt}data_ratio{ratio}.pkl', 'rb') as handle:\n",
    "    data = pickle.load(handle)\n",
    "\n",
    "# Get the accuracy data from the data dictionary\n",
    "all_accuracies = data['accuracy']\n",
    "new_all_accuracies = []\n",
    "for i in range(len(all_accuracies)):\n",
    "    new_all_accuracies.append(all_accuracies[i].cummax(dim=1)[0])\n",
    "all_accuracies = new_all_accuracies\n",
    "\n",
    "all_test_accuracies = data['test_accuracy']\n",
    "new_all_test_accuracies = []\n",
    "for i in range(len(all_test_accuracies)):\n",
    "    new_all_test_accuracies.append(all_test_accuracies[i].cummax(dim=1)[0])\n",
    "all_test_accuracies = new_all_test_accuracies\n",
    "\n",
    "# Determine how many experiments we have\n",
    "num_experiments = len(all_accuracies)\n",
    "print(f\"Found {num_experiments} experiments in the data\")\n",
    "\n",
    "# Prepare arrays for storing padded data\n",
    "train_accuracies = []\n",
    "test_accuracies = []\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_acc = all_accuracies[i].reshape(-1)\n",
    "    \n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(train_acc)\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_acc = np.pad(train_acc, (0, max_epochs - num_epochs), \n",
    "                            'constant', constant_values=train_acc[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        train_acc = train_acc[:max_epochs]\n",
    "        train_acc = train_acc.numpy()\n",
    "    \n",
    "    # Add to our list\n",
    "    train_accuracies.append(train_acc)\n",
    "    \n",
    "    # Same for test accuracy if available\n",
    "    if i < len(all_test_accuracies):\n",
    "        test_acc = all_test_accuracies[i].reshape(-1)\n",
    "        if len(test_acc) < max_epochs:\n",
    "            test_acc = np.pad(test_acc, (0, max_epochs - len(test_acc)),\n",
    "                                'constant', constant_values=test_acc[-1])\n",
    "        else:\n",
    "            test_acc = test_acc[:max_epochs]\n",
    "            test_acc = test_acc.numpy()\n",
    "        test_accuracies.append(test_acc)\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_accuracies4 = np.array(train_accuracies)\n",
    "test_accuracies4 = np.array(test_accuracies) if test_accuracies else None\n",
    "\n",
    "val50times4 = data['val50_time']\n",
    "val50times4 = np.array([t.item() for t in val50times4])\n",
    "val50time_mean4 = np.mean(val50times4)\n",
    "val50time_std4 = np.std(val50times4)\n",
    "\n",
    "print(f\"Mean time for 50% val acc: {val50time_mean4:.2f} ± {val50time_std4:.2f} seconds\")\n",
    "\n",
    "val70times4 = data['val70_time']\n",
    "val70times4 = np.array([t.item() for t in val70times4])\n",
    "val70time_mean4 = np.mean(val70times4)\n",
    "val70time_std4 = np.std(val70times4)\n",
    "\n",
    "print(f\"Mean time for 70% val acc: {val70time_mean4:.2f} ± {val70time_std4:.2f} seconds\")\n",
    "\n",
    "val85times4 = data['val85_time']\n",
    "val85times4 = np.array([t.item() for t in val85times4])\n",
    "val85time_mean4 = np.mean(val85times4)\n",
    "val85time_std4 = np.std(val85times4)\n",
    "\n",
    "print(f\"Mean time for 85% val acc: {val85time_mean4:.2f} ± {val85time_std4:.2f} seconds\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 5 experiments in the data\n",
      "Experiment 1 has 302 epochs\n",
      "Experiment 2 has 302 epochs\n",
      "Experiment 3 has 302 epochs\n",
      "Experiment 4 has 302 epochs\n",
      "Experiment 5 has 302 epochs\n",
      "Mean time for 50% val acc: 41.36 ± 6.88 seconds\n",
      "Mean time for 70% val acc: 179.11 ± 157.76 seconds\n"
     ]
    }
   ],
   "source": [
    "lr = 0.05\n",
    "with open(f'../results/hyrep_spd_{method}_lr{lr}_loweriter{methodopt}data_ratio{ratio}.pkl', 'rb') as handle:\n",
    "    data = pickle.load(handle)\n",
    "\n",
    "# Get the accuracy data from the data dictionary\n",
    "all_accuracies = data['accuracy']\n",
    "new_all_accuracies = []\n",
    "for i in range(len(all_accuracies)):\n",
    "    new_all_accuracies.append(all_accuracies[i].cummax(dim=1)[0])\n",
    "all_accuracies = new_all_accuracies\n",
    "\n",
    "all_test_accuracies = data['test_accuracy']\n",
    "new_all_test_accuracies = []\n",
    "for i in range(len(all_test_accuracies)):\n",
    "    new_all_test_accuracies.append(all_test_accuracies[i].cummax(dim=1)[0])\n",
    "all_test_accuracies = new_all_test_accuracies\n",
    "\n",
    "# Determine how many experiments we have\n",
    "num_experiments = len(all_accuracies)\n",
    "print(f\"Found {num_experiments} experiments in the data\")\n",
    "\n",
    "# Prepare arrays for storing padded data\n",
    "train_accuracies = []\n",
    "test_accuracies = []\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_acc = all_accuracies[i].reshape(-1)\n",
    "    \n",
    "    # Get the number of epochs in this experiment\n",
    "    num_epochs = len(train_acc)\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_acc = np.pad(train_acc, (0, max_epochs - num_epochs), \n",
    "                            'constant', constant_values=train_acc[-1])\n",
    "    else:\n",
    "        # If more than max_epochs, truncate\n",
    "        train_acc = train_acc[:max_epochs]\n",
    "        train_acc = train_acc.numpy()\n",
    "    \n",
    "    # Add to our list\n",
    "    train_accuracies.append(train_acc)\n",
    "    \n",
    "    # Same for test accuracy if available\n",
    "    if i < len(all_test_accuracies):\n",
    "        test_acc = all_test_accuracies[i].reshape(-1)\n",
    "        if len(test_acc) < max_epochs:\n",
    "            test_acc = np.pad(test_acc, (0, max_epochs - len(test_acc)),\n",
    "                                'constant', constant_values=test_acc[-1])\n",
    "        else:\n",
    "            test_acc = test_acc[:max_epochs]\n",
    "            test_acc = test_acc.numpy()\n",
    "        test_accuracies.append(test_acc)\n",
    "\n",
    "# Convert lists to numpy arrays for easier manipulation\n",
    "train_accuracies5 = np.array(train_accuracies)\n",
    "test_accuracies5 = np.array(test_accuracies) if test_accuracies else None\n",
    "\n",
    "val50times5 = data['val50_time']\n",
    "val50times5 = np.array([t.item() for t in val50times5])\n",
    "val50time_mean5 = np.mean(val50times5)\n",
    "val50time_std5 = np.std(val50times5)\n",
    "\n",
    "print(f\"Mean time for 50% val acc: {val50time_mean5:.2f} ± {val50time_std5:.2f} seconds\")\n",
    "\n",
    "val70times5 = data['val70_time']\n",
    "val70times5 = np.array([t.item() for t in val70times5])\n",
    "val70time_mean5 = np.mean(val70times5)\n",
    "val70time_std5 = np.std(val70times5)\n",
    "\n",
    "print(f\"Mean time for 70% val acc: {val70time_mean5:.2f} ± {val70time_std5:.2f} seconds\")\n",
    "\n",
    "# val85times5 = data['val85_time']\n",
    "# val85times5 = np.array([t.item() for t in val85times5])\n",
    "# val85time_mean5 = np.mean(val85times5)\n",
    "# val85time_std5 = np.std(val85times5)\n",
    "\n",
    "# print(f\"Mean time for 85% val acc: {val85time_mean5:.2f} ± {val85time_std5:.2f} seconds\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAekAAAGGCAYAAABfbHkYAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/xnp5ZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB4jElEQVR4nO3deXhU5dnA4d+ZNetk38nCjij7joIiKLigoLaICohLq9V+KtVWWhW1KlqtWltbrBsKLqgVtWpVRBaVTRAUUZZAICxZSEgmyySznu+PQwYiCZlMJjOT8NzXNZfJmbO8cxzynHd7XkVVVRUhhBBChB1dqAsghBBCiKZJkBZCCCHClARpIYQQIkxJkBZCCCHClARpIYQQIkxJkBZCCCHClARpIYQQIkxJkBZCCCHClCHUBQhXHo+HQ4cOERsbi6IooS6OEEKIMKaqKtXV1WRmZqLTBa7+K0G6GYcOHSI7OzvUxRBCCNGB7N+/ny5dugTsfBKkmxEbGwtoN9xisYS4NEIIIcJZVVUV2dnZ3tgRKBKkm9HQxG2xWCRICyGE8Emgu0dl4JgQQggRpiRICyGEEGFKgrQQQggRpiRICyGEEGFKgrQQQggRpiRICyGEEGGqQwTp1atXM3nyZDIzM1EUhffee6/FY1auXMngwYMxm8306NGDhQsXtns5hRBCiEDqEEG6traWAQMG8Oyzz/q0f0FBARdddBHjxo1jy5Yt3H777dxwww18+umn7VxSIYQQInA6RDKTCy64gAsuuMDn/RcsWEDXrl3561//CsBpp53GV199xVNPPcXEiRPbq5hCCCFEQHWImnRrrV27lgkTJjTaNnHiRNauXRuiEgkhhBCt1yFq0q1VXFxMWlpao21paWlUVVVRV1dHZGTkCcfY7Xbsdrv396qqqnYvpxBCCHEynTJI+2P+/Pk88MADoS6GEG2jqv4f63LBoUNQXR248rSVqmrlasvnEiLQ6upg8WJYv/7YdzMurl0u1SmDdHp6OiUlJY22lZSUYLFYmqxFA8ydO5c5c+Z4f29Y0USIkFFVcDh829dmg2++gaIi/6/ncsF338FxLUoh5XbD2rXw008SpEX4i49vl9N2yiA9atQoPv7440bbli1bxqhRo5o9xmw2Yzab27toQpxcVRXs3AlOJxw4oNVqfQlQhYWwZg2YTP5dV1Vhy5a2BXkhTiWpqXDmmRAdrf37iYuDf/4z4JfpEEG6pqaG/Px87+8FBQVs2bKFxMREcnJymDt3LgcPHuTVV18F4KabbuIf//gHv//977nuuuv44osveOutt/joo49C9RGEaFpdHezYoQVl0AL07t2wZ49Wi2zYfjKqCvv2Baa2GR0NycltP0+g5OTAmDEgD9Ai3JhMMGQI9Oql/e50nrpBeuPGjYwbN877e0Oz9KxZs1i4cCFFRUUUFhZ63+/atSsfffQRd9xxB3/729/o0qULL7zwgky/EoFRX6+9/OHxaE3YqqoF6M8+04KxTgdWK6xYAZWV/p172DDIyPDvWICEBBg/HgK8Hm6bHDkCsbHQp094lUt0SvZaF446t287m0zQqzeYjADUqbZ2KZOiqtLZ05Sqqiri4uKwWq1YLJZQF0eEUm2t1ucLWnP0+vVaQPVHw0Coykr4+GPYsKHpGnBkJEyeDL17+3belBStBtyW/mSnU/tc7dS35hezGc4+W6tRi07FXmWnrqIu1MXwctQ4OLTxEPUV/j2AqxaV0dePDnjM6BA1aSHaVUmJVmNrSl0dfP/9sRHPTqcWCOPjW1+zq6mBDz6AggI4fPhYQO3RAwwGrTY9YgRMnKg9pZeWasf4or4eKiogKqp1ZTqe2QzjxoVXrdVg8L+fXbSZx+3BbrXjcXmwV9mpPVwLAajWeVweir8rpq68jnCoJ6oelYMbDnJ422EUP777HrcHNaZ9PocEadE5ORywf7/WvHwyNptWm7Vamw5MtbXaeSIjtdHGy5bBrl2BKWOvXjB7tlZLbPhDVV8PBw9qDwPJyXDOOVqgaolOB2lpkJjYtgCr1/t/rOiQVI9K8XfFHP7xMKpHPeE9p82J2+mmfEc59ZV+dvP8TPn2coq+7WSDFOPb57QSpEV4au3TdWWlFkzdR/uT9u7VaqwtnaegALZuBaPxxPfcbi2A25roa9L5kaxPUaB/f7jkErBYtFpvba1WS284n9ms9S1HREB2NqSnt/46ImBUVaW+sv6E4NUSV52Lsu1l1FsDE9Tak+pRsRZaMcWY0Bl0jbYf2niIIzuPUF1cTfn28oBfW9GFSYsNEJMRQ98r+hKdFt3qY+ut9dR56uDxwJdLgrQIPY9Ha3KurNT6aysqtClFLdWCj1dVpR1z/ACsch/+qJSVtbxPdvaxEc9dusAVV2iDrPzhcmlTq+rrtaB94YWQlXWsBmsyNf3AIPzidvg4CKgJqkelaHMRJd+V4HG34rsIuF1u6g7XoTeFf8vEkd1H2LtyLy6bq9F2t9ON3XpsjIPOqCOlb0pAAqsp1kTvKb2Jz4lv87kCxePyYCu34ba3/jsTqYskwhLRDqWSIC1CRVW1mq/NpgXXnTu1PlpV1X622XyvrVZVweefa7XS1lIUrUm5uYFJGRkwcmTjstTWag8S/igthdxc7bw5OTIgqg1s5TaO7DrSbAC1HbZRd6RtA5PqjtQRlRqFMdL3ByePy8O6p9Zx6JtDbbp2ODBEGugxqQeRiZFkjcjCEGmA1j2vNMnj8WA7bKP6YPhkt1P0CjFpMcSkx/h1fL3aPq0mEqRFcJWWanN6Kyu1TFLHzw/+8Uctmcbu3f6d22w+NgBr+HBtAFZL/bnx8VotublmcYdDe4hoyPzl8Whzif2dt9utG5x7bniNoA4T9mq7FnRdLUcBVVUp315OTUkNOmPTD3N6kx5TjAn8rPjVHamjYGUB9orWjZi3ldso31GOolO0oBbmjJFGel7ck7T+aSe8F5Meg6JXcNvd1JZog8YUfdtr0oqi0GV4F5J6J4VPk7cCkYmR6PT+rTvVXus9hP83SHRsqqqNULbZtJHSX32lDYzS67U+36oqeO01LXA3MJth4EDfa9KKAoMHa3N8G5qNa2u15u6WmsyrqrQm7+YGTOl0kJen1XgVRfs9I8P/PL0GgwzOQguyNcU1lO8sx1WvNbPaDtuoOlTl8x9Jj9uD3qRHaSIKV+yp4Kd3f2rUXNtazjonqtu/EbuKTmHMn8aQOSzT7+sHk6qqTT4c1VfUY6+yY4o1kdQniZzRORijA9MdYzBL+PGF3CXRPmpqtH7XH3+E7duPJQDZtEnrd/38cyguPrZ/TAxcfDEkJcHQodrAqtb0SVdUaKOuGwJ7w8CrlqYkKYo2Krq5oNswatqXEdaiWW6nm8qCSqqLqnHZXdRX1GMr0/r/dCYdqqpSuaeSuoo6dD48nFUXVbNn2R6/g6ivkk9LJmdMTqtre8l9kjFEGCjfFfjBVgGnakG6qf5zo9lItwndSOyRiMFsCJ9a7ylE/vKIwNuzB1av1mqzZWWwcaM2WGrfvsZ9uZGRWjapkSNh2jStGdnj0fqqKytbV+OMjobzz9eCe8O509LCZ75vGHPZXdQU1wRk/mtTVI/K4R8PU7azDEVR0Bl1eFweCr8sxLpXSwpTX1VPRX7r+/kjEiOanNeqN+npPrE7WcOz/C63zqgjOjXar3mz9dZ6HFUOuozs4nfzabAoioIpxkRk4omLD+mMOqKS2jD3XrSZBGnRNrt2aUH4+BzTNTXHmrmffFJrUm6QlgZ9+2q13Isu0oJpwzE7dmi17ORkGD1aC+C+ioho3f6C+sp6rPutlP5QSk1RTbsnlYhMjqSmqAbrTis/vPHDCU3ROoOOrJFZ6I0tP5zpjDpyxuSQPuDkU9TcTv9HdwM4a50465ytfoCpO1JHlxFdyBktAwNF20iQFv776Sf44gvt54Zgq6ra3OMDB+DTT7UAnZ2tpbiMi9OashumGDmdWl+11arNFR4+XEvwYbFozd8i4I7kH9H6ge0ubKU27NV2jDFG4rvGN5ojG0hup5tdH+5i21vbcNYee5iLzYql1+ReGCIMKIpCyhkpRKe0fo5qU1SPSmVBpfZLGz6WwWTAGGVs9eCzxB6JpA+UOe6i7SRIC/+Ul2tzkd96q/Fc49raxoPA8vLgkUe06VVOp5YOs2GRCY9HqwFHR8OoUVoNWwZVtQtHrYPKgkr2fbkPt92N3qzHbDHjdrvZ9uY2Ld1jO6ktraWuTJsKFZkYiTnOTLcJ3ehxQY9GDwYuu4vqQ9U+Jw5x1blQVbXJ5mhVVYnJiCF7VHarpk/9nCHCgNlilr5YETISpEXrud3w9dfw979rg8J+zmiEs87SFn246CItUUlMjBaMjUatSdts1nJWJyVptfCI9kkE0Nk0jIq27rPisrtaPgBwVDuoKa6hvrIec5wZSxcL9dZ6fnj9B/I/yW91Ni1/RCZG0n9Gf/LG5XkDnq3Mhq3chk7RArWiV4jJiPE5qEbERRCbFdvslKCopCjMFlniUnRsEqRF6+3eDQ8/rAVokwl+9atjzdOKojVZJyVpv+/fr2XnOu88yOwY01HClepROfTtIQ6tP4Szzulz87TOqMMUa8Icb2bvF3upt9azb9U+b9Nz1vAs8sbl+T2fuCV6o57UfqkYIgzez1FZUIkxykje2XlExGsPaAazgdis2LAfaCVEMEmQFr4pKtKatZ1OLUBv2KBNT7rrLm3lpp9zu7X+ZodDAnQAeFweDqw/wMENB4lMjMSS4/tSeM46J9vf3c72pdsbpcmM7xrPoOsHNZnEoj3Yq+1UH6xGUbQac9dxXYnNlMF+QpyMBGnRsqoq+OgjWLtWqxkvW6Ztv+kmOP10LVvYz+n1WhDv2xe6dw9ueTuR6qJqSreW4qhxUFFQQUx6DK56F4VfFfp0fN2ROn76z0/eNXKTT0sm+bRkEromkH1WNjq9DrfT7dciEq3RUGvvMrILcdlxWt+0NEUL0SIJ0uLkamvhjTfgnnsaDxC78kqYMAHy82HIEG1qVQO9Xmv+Nhi0pRP9WTGqk/K4PVTsqWhUo1XdKrYjthMWOACoOlCFo8aBPkJPREIEP779I7s+2uVT6szjxaTHMODaAXQZ1aXRQKu68jpqD9cSkxYTkHSPzbFkWUjskUhi90QZhCVEK0iQFs3bskVL4/mnP2m1aYtFS485ZIiWHWz3bujaVRuZHXliIoRTnaqq1B2pO1ZDVaF8ZzkHNxw8YU6yoleanh+sA5PFxKFvDvHDGz/gqNZyiMd3jfcpPaOiU8galkWPC3s0On/D8oQ6g468cXmk9UuTNI1ChCH5Vykaa1hIorwc/v1vLVFJVZW2rvFf/qL1Ndvt2nrNvXrBmDESoJtRurWUwq8LG9V6XfUuYjNjGzX11pXXUfxd8QkpLmtLa9nxwQ5cdcdq2HE5cQycPZCMIRmtLo+9yo6jxoHH5cFpcxKbGUvu2Fzisv3MQy6EaHcSpIXGbtcC8s6dWkKSTz/V5kA3uPZabfBYSoqW2WvUKOjd2//VoDo4p81JXYVWS3banCf057odbg6sO4DOoCMqJcq7bc/ne9j10S7vfh6Xh0MbD510DVudQUdEQgR9f9GXbud1a/XoZ1VVqdpfBarW7G2MNmKINJAxMMM7sloIEZ4kSAvN2rWwcqXWn+xywQcfaNv79tVWmEpM1AaJnX22VnPuBP3MHreHwz8e9q7C5CvVoy2T2BCkm0qnWV9Zz7Yl27Adtnm3ueyuRrXi48V3jT8hR7JiUMg+M5vcMbkn9OO66l0+90vXFNUQmRRJ7phcErol+HSMECI8SJAW2lSpN96Al17SAnSDXr20bGEHD2r90WPHaglJOjinzUndkToqCio4uOGgXwsomGJNxOXGUX2wmpKtJSfkdt796W6shdYTjotMjqTHpB6N+n9ju8SSMTijxXKoqqqt61tai8fp8XmtYksXC3nn5BGd2vH/3wlxqpEgLeC//4UXX9T6m2NitNp0VBRcdZU2ejsiQpsL3QnyaddV1FGwvABroRWPy0Nsl1jMsa1rsi/fUc7W17dit9op+a6k2alLEYkRnPn7M7XczwAKxGbGNjlAzO1wN5lBzGlzYq+yaw8BqpamMiIxgi4juvgcdA1mQ5PLEAohwp/fQdrhcGAymQJZFhEKqgrz5mkBevRo+P3vtaZsp1NbcnLMGG3QWJcuoS5pmznrnOxetpuD6w9iijWx68NdHP7xcKtXOPp583jagLQT5vwaIg30mdIHS5cTk478PKjbq+zUlNQQEXti/7AhykDK8BQt13asmcjESCLiIyToCnGK8DtIZ2RkcNVVVzFr1iyGDh0ayDKJYPr0U22JSKMRrrtOW70KtPnR3brBwIFa6s8OTPWoOGoc/Pjuj6yat6rJZuhWUSBvXB4pfVOI7xpPUs+kJnerO1JH+c5ylOPybaqooNCoaVtv0pNzZg6pZ6Se0OStN+t9WrpRCNE5Kaqfi8jqdDrvH5S+ffsye/ZsrrnmGlJTUwNawFCpqqoiLi4Oq9WKxeJ7CsYOxeXSFsJYvx7OP19L39mt27GBYWecAVlZoS6l35x1Tpy1Tg5tOsT+NftZ8/gaXHUu9CYtMUhyn2T6TO1zrDnaR8Yoo7fmrKoq1Yeqcdc3Hp2tqqo2R3lEFhGWYzVkRadgjDI2Shyi0+uITo2WJB9CdGDtFTP8DtKffvopL7/8Mh988AH19fUoioJer+fCCy/k2muv5eKLL8Zg6Lhd3p06SNvt2uvOO+H557VFMe69VwvQU6dqg8Q6uJqSGnZ/upv9a/bz/eLvvWkpk/okcdbdZxGZ2La53W6HG3u1nfqKeiITI4nPiz9hn5j0GJJ6Jfk1ME0I0bGEXZBuYLVaefPNN1m4cCHr16/XTqooJCUlcfXVV3PttdcyYMCAgBQ2mDplkFZVKCyEL7+ETZvg6ae17TNnwqBBMGkS9OkT0iIGgupRWTFvBYVfFrJ/zX48Tm2qUmKPRM665yx0Oi1fNaoWbFv7T0D1aKOsI5MitZWcxuYRk97xB9UJIfwXtkH6eDt37uTll1/mtdde48DRvk1FURgwYACzZ8/mqquuIimp6f67cNPpgvSPP2ppPo8cgbo6LUAfOqTl3z7vPBg+XJti1YHnP6seleLviilYUcCy3y3zbs8clsngXw8GwF5hxxxvRm/Uo+gUTLEmn5d8bKAoCvF5Wl+0zqCTZmohRMcI0g1UVWXZsmW88sorvPfee9TXayvwGI1GLr74Ym644QYmTZoU6MsGVKcK0ocPw3vvwXffadOtCo+uoGSxwJw5MHQojBunTbvqgOoq6qgprqFiTwXbl24n/5N8qg9Wk3J6ClnDs0jqk4QpyoTerCdzaCZJvZIwRhpPGMAlhBD+aq+Y0S6dxoqiMHr0aPbv38/27dvZsmULqqricDh49913Wbp0Kb169eIvf/kLkydPbo8iCICaGm1QWH6+VnPevv3Ye3o9TJmiLZYxYUKHTO9Zua+Syr2VfPOPb6g6WEXJdyU4bVrfszHayMg7RqKqKqpbpfv53bXpS3GSBlMI0XEEPEh/8cUXLFy4kKVLl2Kz2VBVFYvFwpVXXsnUqVNZsWIFr776Kjt27GDKlCm8/vrrTJs2LdDFEKA1cW/aBIsWaQFar9dWr7rsMm0E9/79HTb/dm1pLfn/y2fDPzZweNth7/bo1GgikyPpNr4bdqsdY5SRzGGZJHSVdJhCiI4nIM3de/bsYeHChSxatIjCwkLvQJyxY8dy3XXX8Ytf/ILI41ZKcjgc3HPPPTzxxBP069eP7777rq1FCLgO39xdXQ1vv601cT/zjLa28+OPayO4a2uhslJr3p42Tcso1sF8t+g7Vj2wiordFeiMOnpN7kVcbhxdRnUBD1gLreSOySW5TzLmOLM0awsh2lXY9UnX1NTw1ltvsXDhQr7++mtA64vOyMhg1qxZXHfddfTo0aPZ41VVJSEhgfr6em+fdTjp8EH6m29g7lxYtUqbD33ZZXDppVBSoqX3NBigf38t3WcYaliL2e1waykz613ezGC2chuLJy7GWetEZ9Qx+FeDic+LR0FBZ9Sh0+uIyYih10W9MER03GmAQoiOI+z6pDMyMrzN2QaDgYsvvpjrrruOCy+8EJ0PI4QVRSE+Pp79+/f7WwTRnIoKeO01WL5c+33oUJg4URvZffbZ0KOH1sQdhutAO+ucVBZUUlFQgbXQitvhxlHjwFHt0LJ1AXuX78VZ68SSY+GsuWfhrHWSc1YOUUlRGKON6I16TDEmCdBCiA7P779itbW19O7dm+uvv56ZM2f6lWlsyZIlYVmL7vC+/x7+9z/t5wsvhBtvhF27tAA9bJiWvCQMqarK/q/3U7ylGNsRG7WltdQW17L7091NLss49OahuOpcxHeNJ2NQhuSzFkJ0On4H6a+++orRo0e36eIjwrSptUOzWmHFCti5U5vzPGUKFBVBZib06xe2Adrj8mDdb+XAugMUrChg38p9jRaiMEQajvUrK9DtvG4YTAaikqLIHpUtAVoI0Sn5HaTbGqBFOykshLfe0n4eOVJb/7mkRKtFh2HzNmgpPAuWF1D8XTHr/7Yet13Lg53aL5WI+Ajyzs0jrX9ao2OqCquISomi+3ndZZ1kIUSn5XeQrqio4L///S8JCQktznX+4IMPqKys5JJLLiE+Pt7fS4qTqa+H4mJYvBh++kkbGPbLX2pZxYYN06ZahSGPy8PBbw5iLbTy/aLvcdvdJPRIYPANg0npmwKAdb8V614riuFYK0BEfARdz+0qAVoI0an5HaQXLlzInXfeyX333ddikF69ejVPPfUUTz/9NL/97W/9vaRojscDX32lTbd65RVt2yWXaPOic3LgzDO1n8OMrdxG8ZZiNjyzgYqCCmqKajDHmRn34Dh0Bh1H8o/gcXuIiIug2/hujRKRGCINkphECNHp+Z2oeenSpQBMnz69xX2vv/56VFXlP//5j7+XEyezezf88AOUl2tN25GR2pSr+no47TStVh1mnHVOdn+2my/u+YI9y/ZQkV8BwIBrB+C2u7Hus5JyWgo9zu9Br4t6kdw7mZj0GO9LArQQ4lTg91/v3bt3ExkZSa9evVrc97TTTiMyMpLdu3f7eznRFI9HWzRjzRqtJr15s7Z9wgQtQKekQG5uSIvYnF0f7+KLP31BZUElKND/mv7Ed4snNjMWR42DvHF5pA9Ib/XiF0II0Zn4HaTLy8uJifF9eb6IiAgOHz7c8o7Cd6WlWoBesQLefVfbptPBBRdoc6LPOScsB4vtX7ufD677AHuVHb1Jz+BfDab7+d1x2V1Y91npfn530vqltXwiIYTo5PwO0klJSZSUlFBRUUFCwsnzIldUVFBZWUlKSoq/lxNNKS7WFtFYsUL7feRIbblJl0urQZ9xRmjLd5SqqtQU1eB2uKksrOSdae9gr7IT3zWeMfeMwRRtomJPBU6bk9R+qd4BY0IIcarzuy1x+PDhqKrKSy+91OK+L7zwAqqqMmzYMH8vJ35OVbW+6J9+0jKMJSXBXXdpq1p5PFqWsTCpRR/JP8L297ezZeEW3pv5HrXFtUSlRDH23rG47W6qD1WT2DOR3LG55IzOQaeXJm4hhIA21KRnz57N+++/zz333ENubi5XXHFFk/u9/fbb3HvvvSiKwnXXXed3QcXPHDkCW7cea+a+6CIwGrV50j16QF5eSIvncXuwW+3UlNTw2e8+o3RrKbZyG646F6YYEyNuG4GtzEZMegxdz+1KUs8kFF14JloRQohQ8TtIX3LJJVxxxRW88847TJs2jWHDhnHBBReQk5MDwL59+/jkk0/45ptvUFWVyy+/nKlTpwas4Ke0igptoNizz2rN3T17ak3dO3ZoK1v176/1TYeIrdxGwYoCbIdtHPrmEPn/y/e+l9AjgdN/eTqRiZFkDM4gpW8K5tiOt1SmEEIEQ5vm5ixatIi4uDhefPFFNmzYwDfffNPo/YYFtm688UaeeeaZtlxKNFBV+PJL+O9/oawMYmPh3nu1qVcjRkB2tvYKkdrSWvYs30NNUQ3GaCO7/rcLgG7nd6PbhG5EJUdhr7bTdVxXkvskh6ycQgjREbQpSJvNZp5//nn+7//+j8WLF7N+/XpKS0sBSEtLY+TIkVxzzTWcfvrpASmsQAvG+/drtWaAMWPAZNL6n3v1grTQjYquPlTNns/3UH2ompKtJWx/dzuueheRSZH0vKgniqJgr7KTPTqbpN5JISunEEJ0FAHJctGvXz8ee+yxQJxKtGTvXm0RjY0btd/POUfrn05N1eZFh4jb4Wbfl/vY/dlu8j/Jp668DoCkXkmccfUZGMwGYjNiSeyZSHKf5GOLZQghhGhW+KWiEk1zubSR3D/8ACtXaslK0tO1QWK7dsGoUSHrh3bZXez+dDfL7lxG1YEqAKJSohgwawDZZ2VzZOcR0gek02Vkl5CUTwghOioJ0h1FQQF8/jl88w0sW6ZtmzFDmyudmakF6yCyFlpx1Dqwldoozy/ny4e+pOpAFYZIA31/0Zdek3thMBuoKa4hIj5CmreFEMIPbQ7SNTU1vP3226xbt46ioiJqa2u9A8Z+TlEUli9f3tZLnpqqq6GyEt57T/t9xgwYPlzrnz73XGhF9re2slfb2bN8D3XldSg6hdJtpVTurcQQYWDSM5OISYtBVVWshVYUnULumFwiE8JjzrYQQnQkbQrSH330EbNmzaKiogJVVb39jMcH6eO3ST9kG+zfD0uXQl2dNkDs8svhwAFtJHeQa9EVeyqwldmITIjk+9e+Z9/KfQD0/WVfzBYztnIb9RX1RMRFkHdOHgndTp6RTgghRNP87sT84YcfuOKKKzhy5AjnnXceTz31FKqqYrFYeOGFF3jkkUc477zzAEhMTORvf/ubT9nJmvPss8+Sl5dHREQEI0aMYMOGDSfd/+mnn6Z3795ERkaSnZ3NHXfcQX19vd/XD6nDh+H667XkJYoCv/61NhWrrg769g3qMpQuu4tVD6xi5X0r+fDXH3oDdNcJXUnrl4btsA2AhG4J9JjUQwK0EEK0gd816ccffxy73c7s2bN58cUXAbjjjjuIjIz0Zha7++67+fLLL5kyZQovvPACa9eu9etaS5YsYc6cOSxYsIARI0bw9NNPM3HiRHbs2EFqauoJ+7/++uvcfffdvPTSS4wePZqdO3dy7bXXoigKTz75pL8fOXTeeUdbhjIhAf7v/7TkJaWlkJgY1FWuVFWl8MtCdn64E4/TA0DK6SkMum4QkUmRuOpc9LigB7GZseiN4bd+tRBCdDR+16RXrVqFoijcc889jbb/vD96zJgxPPvss2zdupVHH33Ur2s9+eST3HjjjcyePZu+ffuyYMECoqKimq2Zr1mzhjPPPJOrrrqKvLw8zj//fKZPn95i7TtsNSSJOessLTe306lNuxowAKKjg1IEt9NN6dZStizcgsfpITYrlkteuoRzHzkXS46F2pJa0gemE58bLwFaCCECxO8gXVxcTEREBF27dvVu0+v11NXVnbDvFVdcgclk4p133mn1dRwOB5s2bWLChAnebTqdjgkTJjRbMx89ejSbNm3yBuU9e/bw8ccfc+GFF7b6+mGhYZ3oXr3A7dZGenfvDv36BeXydRV15H+Sz+5luyneXAxA7tm5RCVH4apzUbmnktR+qaQPTA9KeYQQ4lThd3N3bGwsHo+n0ba4uDgqKiqora0l+rgansFgwGQysW/fvlZfp6ysDLfbTdrPMmmlpaWxffv2Jo+56qqrKCsr46yzzkJVVVwuFzfddBN//OMfm72O3W7Hbrd7f6+qqmp1WdtFw/xogC5dtDnR2dnHMo21E7fDTfF3xZTvKMdld1FXUYez1knZ9jIAEnsmUr6rHEVRyBiSQc6ZORgiZEafEEIEkt816ezsbKxWa6Oac58+fQCtKfx4P/74IzU1NZjaMagcb+XKlTzyyCP885//5Ntvv+Xdd9/lo48+4s9//nOzx8yfP5+4uDjvKzuE+a8b2bwZ7HYwm7Vm7n794MIL2y27mMfloWJPBTs/3MnelXtx2BwoegVjlJE1j69B9ahkn5lNVGIUWcOy6HlhT7qO6yoBWggh2oHfQXrw4MGoqtqon/fiiy9GVVV+85vf8OWXX2Kz2di8eTMzZ85EURTOPPPMVl8nOTkZvV5PSUlJo+0lJSWkpzfdvHrvvfcyY8YMbrjhBvr168fUqVN55JFHmD9//gm1/wZz587FarV6X/v37291WQPO44ElS7Sfs7K0AH3eeWCxtMvlKvdV8tO7P7H9/e1YD1hJ6JZAbEYskYmRbFqwCWetk+TTkjlj+hlEJkaSPSqb5N7JssSkEEK0E7+D9NSpU1FVlddff9277be//S1du3alsLCQc845h9jYWIYOHcq3336LyWTi/vvvb/V1TCYTQ4YMaZQExePxsHz5ckaNGtXkMTabDd3PUmTqj05Tai7RitlsxmKxNHqFXHU1NLRKdOmiNXO3w3Qre7Wd4i3F5P8vn+riaizZFhK6JqA3adfas2wPpVtL0Zv0jJwzErfdTXzXeHSG0C2HKYQQpwK/2ygvuOACtm7d2qgJOzo6mi+//JLbbruNDz/8ELvdjqIoDB8+nCeeeIKhQ4f6da05c+Ywa9Yshg4dyvDhw3n66aepra1l9uzZAMycOZOsrCzmz58PwOTJk3nyyScZNGgQI0aMID8/n3vvvZfJkyd7g3WHsGzZsYU0hg+HpMCm1lQ9KmU7yjiw7oCWnCQxkoSsBFRVZf/X+9nx/g7qrfXUFNUAcNoVpxGVHIWjykFsZmxAyyKEEOJEfgdpnU7X5BKUmZmZvP322zidTsrKyoiNjSWmjSkrp02bxuHDh7nvvvsoLi5m4MCBfPLJJ97BZIWFhY1qzvfcc493etjBgwdJSUlh8uTJPPzww20qR9A9+KD23zFjtKbuAAVpj9uDrcxGyXcllG4rxRhlJKlXEopOoXxnOZtf3EzZT2Xe/XUGHT0v7slpl52Gda+VqJQoYtKCl4ZUCCFOVYraXPtvC5555hlAm16VmZkZ0EKFg6qqKuLi4rBaraFp+i4uhowM7ef779cC9bnntvm0LruL/E/zqd5fjbPOiSXbgjHKiLPOycZ/bmTfKm0Evt6kp89lfUg9I5XYrFiikqKwFlqJiIug24RuxKRLkBZCiAbtFTP8rknfcccd6PV6brrppoAVRhzn88+1/3bpoi2eEaDR5uU7yinfWU5cdhyWKO2L5HF5+PrRr7U50Ap0Pbcr/a7pR1RSlPc41aPiqnORMS5DArQQQgSJ30E6JSUFp9MZtGlVp5zPPtP+262bthRlK9N/qh4Vt8MNaM3bNUU12KvtlHxfgtlixhhlBKBsexmbX9hM+c5y9GY9Z99/Nqmnn5hq1W61Y44zY+kSBgPqhBDiFOF3kB4xYgQffvghhw4d6pTN3SG3YoX2365d4fTTm0xc4rK7KNtehsfVeFqZ6lGx7rNSb60HFVRUHFUOVFVFZ9QRnxtPTXEN3736Hfu/0qaaGSIMjP796CYDtMflofZwLWn90zBbzIH/rEIIIZrkd5C+6667+Pjjj7nrrrt47bXXAlkmsW6dtgylosDAgZCX533LXmX3BuWiLUUUbSpCp288FUpVVYxRRkwxRwO7AlFJUegMOhy1Dr579Tt2frBTO48C3c7rRr+r+hGZeGzN57qKOmylNlC05UajkqJI7pPc3p9cCCHEcfwO0meddRaLFi3iV7/6FePGjeOOO+5g5MiRpKSkyLrRPnLVu7AWWnHZXcc2qiqW2+cSCTi6dKXCkAX76oA6bOU2juw84g3SjloHcTlx3qbrlqiqyqp5qyjfWQ5A2oA0Bl43kISux5aTdNldVBVWYYw2kjU8C0u2BZ1eR1RKFMZI364jhBAiMPwO0sfPN169ejWrV69u8RhFUXC5XC3u1xl43B6O5B+hvrKe2tJa7Fb7Cfu4XW7qyutQOPZQE/PTBtLWrwRgR85Eavbp4bM92psKRCVHoTdr9z4mI6ZVCUVKtpRQvrNca9q+azQZQzMaPVDVW+upLa4luU8yWcOziE4NzgpbQgghmuZ3kPZn5pafs706HI/bw4G1Bzj0zSE8Hg+GCIM3sB5Pp9eR0D2hUXN1xqtvA2A9fTSmfr1IHJgDlrYlDlE9KhV7KvjxnR8BrXk7c1jjcQRuh5uaohpyzswha3iWZBMTQogw4HeQLigoCGQ5Og1VVSnaVMTBDQeJTotu1UArXXERMdu0XOgVPYZqi2jEtn66U11FHftW7sNV70JVVQ5tOETFngrtTQV6Te7VaH+X3UXl3kqSeiaROTRTArQQQoQJv4N0biunBJ0qjuQf4cC6A0QmR7ZuJLTdTswHr6FzO7EnpmNPz9WmXzXTv6+qKt+/+n2jzGANKgoqcNU17lYwRBiITIok9+xc7zxnl91FTXENbrub5N7J5JyV483XLYQQIvRkfcEAO/zDYVAgMiGy5Z0blJfDD9uwbPwCgKq8/pCTA0mJzR5yYO0BfvrPT82+n9gzkcQe2vER8RH0uLAHEXERwNEpWvuteFwe4nLiSDkthcQeieiNEqCFECKcSJAOIEeNg9qyWiLiI3w/yKNC/m5Mu38kungPqqJQ1WMwpDVehlP1qBR+Wehttt63Wkvf2e38bmQMzmi0rynWROrpqU0uIamqKhW7K4hOjabLqC7E58WfMIVLCCFEePA7SF933XWtPkZRFF588UV/Lxn2bOU2HNUOolKiWt4ZyP8knz0f70StrsFQq0PPr/GYInGuiIFvNjVq6nbUOKgtrW10fFRqFINvHIzB7Pv/Rke1A2O0kW7ndZNFMoQQIsz5HaQXLlyIoignHbF9/PQeVVU7fZCuPVyL6lEb1Uw9bg+lW0tx1job7Wvdb+WH1384botFe9mBwy44XHnC+Y3RRvLOyUNv0qPoFHLPzm1VgAawldlI6pUkAVoIIToAv4P0vHnzTvq+1Wpl48aNfPXVVyQmJnLzzTdjMHTu1vWq/VUYoo59xuItxWx5aQuVeyubPaZf5mH6H/oEgPrM7pSdfjacdhokJjTeUYHEHomYY/1Ly6l6VG20t1v19lULIYQIb+0WpBusWbOGKVOmsGnTJj788EN/Lxf2HLUObOU2zLFmrPutfPfydxzaeAjQasDxefEnHJORZ+aCr/5JBKWUnXUp5YPOI0NV4azuENG2HNketwdXvTbC2+PwUFNSgynKREx6jCySIYQQHUS7V21Hjx7Nc889x+WXX85TTz3F7373u/a+ZEjYq+w4bU4q9lSw9vG1eFweFL1Czwt7cvq000+cjuVyY37vTSKspXj0RipGToKKam1UdysCtMuu1Y6P53F5qD5YjSlWy92t0+nIGpZFyukpGCONkt5TCCE6iKC0P19yySWYzWZefvnlTh2kK3ZXsGnBJjwuD+mD0hn8q8FYspqotbrcsP0nLN+uBKC250A8pijwWLUEJj5y1DioPlCNMfpnQVeBjMEZZAzOQNErKIqCKdYkOdWFEKKDCUqQ1uv16PV69uzZE4zLhUS9tZ6dH+zE7XCTMSSDMX8a0zhzl9sN1TXanOiDB1FKirDs2QJA1WkjoLQUoqNP7Is+iZqSGlL7pZI1IuuE9yLiIpqcgiWEEKLjCEqQXrduHTabjeTkzrvUYeGqQir3VqIz6Bj+2+FagPaocPAglJZAZSXU14PDARGRxJYVYLBV47QkUROfCUlJ0KM7RJ18+lZD87bH5UFBIblPcusSpwghTnkejweHwxHqYnQoRqOx0cJSwdKuQdrtdvPhhx9y++23oygK48ePb8/LhYzb6WbbO9sAyBmbo63L7HLDjz/Cnj2g10FEJMTFgckEqofEd5YBUDZoPHV1OkjMAoMFyuuavY69yo6qqt7UnXE5cViyZRCYEMJ3DoeDgoICPB5PqIvS4cTHx5Oenh7UrkO/g3S3bt1O+n59fT2HDx/G4/GgqipJSUn8+c9/9vdyYa2mpIbib4sB6D25t7Zx3z7YnQ9JyScMBLNsXYP58AHcpggKkwZjioiAOAtw8lXCLF0sZAzOwBynnc8QYZBsYUIIn6mqSlFREXq9nuzsbHQ6+fvhC1VVsdlslJaWApCRkdHCEYHjd5Deu3evT/uZzWYmT57M/Pnz6d69u7+XC2v7Pv4Rj8tDpMVAfP0h2FYE+wshJvaEAK2rt5GyfAkAB/pfSEKSnu6X9ESZNLzF6yg6RfqZhRB+c7lc2Gw2MjMziWqha000FhmpdSuWlpaSmpoatKZvv4P0ihUrTn5ig4H4+Hh69eqF0di5p/zs+1Br6k5LVVHyd2sbzSaIs6CqKlWHnbgcKqhu+ix/FkOtlTpLGuVDzqNHShX6bnkgy0MKIdqZ2+0GwGQyhbgkHVPDg43T6Qz/IH322WcHshwdV3U1+zeVAJDaJxEyYr1vqapKZYmTiGgd3QbGELP0FSIObEU1GnHd8n/0StYRk5ACsuynECKIZDqmf0Jx36T61kaO736irEjL7JWap61+5XGr2KpcHClyEBWrp8fgOJLtB4lY/j8AlLvuInbE6cS4KqF/f23qlRBCCPEzfgfpuro6Vq9ezTfffNPivt988w2rV6+mvr7e38uFp5IS9r21HlWFyFg9MfFGPG6VI0UOUCApw0z3QRZi4g3w3HPg8cCYMTByJFRUQGIi9OwZ6k8hhBBh7f7770dRlEavPn36hLpYQeF3kF60aBHjxo3jzTffbHHfF154gXHjxvHGG2/4e7nwU1EBa9dyaGcNAIkZZupqXBw5ZCch3UTfUQn0HhFPdLwRVq6E7dshIgJmz9aOLyuD3r3BIlOohBCiJaeffjpFRUXe11dffRXqIgWF30H67bffBmDmzJkt7vurX/0KVVVZsmSJv5cLL1YrfPgh5OdTYtWauC3JJuqr3eT0jaH7QAvmqKODCmw2ePll7edp0yA5WdtmNkMnHe0uhBCBZjAYSE9P9746c3Ks4/kdpHfu3InZbGbAgAEt7jt48GDMZjM7duzw93LhpbISDh+Gnj05fMAOgDlKR0K6mS59oo8FaIBly7T9MzPhkku0bcXF2kIa6elBL7oQQnREu3btIjMzk27dunH11VdTWFgY6iIFhd+ju0tKSoiNjW15R7QRcdHR0RQXF/t7ufDidIKq4lEVKoq11HrRcQaSu0ScOPpv1Srtv5Mng9EIdXWgqtCvH0giASFECKmq1rAXClFR4Otg6REjRrBw4UJ69+5NUVERDzzwAGPGjOGHH37wOQ51VH4H6bi4OI4cOUJtbS3RLYxOrq2tpbKykoQE3xePCGtHc96WFtbhdqnoDApJWWbiUn429/DAAcjP14LxWWdp2w4dgh49IC8vuGUWQoifsdkgJiY0166p8X1iywUXXOD9uX///owYMYLc3Fzeeustrr/++nYqYXjwuyo3ePBgPB6PT/3Mb775Jh6Px6em8Q7B6QTg4A7tETQ2wUBsogmD6bjbWVMDr72m/Tx4sJa3++hxnHGG1KKFEMJPDYmy8vPzQ12Udud3Tfqqq67i008/5Xe/+x19+/Zl5MiRTe63bt067rzzThRF4ZprrvG7oGHlaE26aHctADEJRqLjjsuqVlYGf/iD1m8N0PAUWFEBCQla/7QQQoRYVJRWnwjVtf1VU1PD7t27mTFjRuAKFKb8DtLXXHMNL7zwAl9++SVjx47l8ssvZ9KkSeTk5ACwb98+PvnkE959911cLhdjxoxh1qxZASt4SNXVgV5P0R5txarcqq0kLl4KkUcHjOXnawE6LQ1uugmGDNG2W60wfLi2EpYQQoSYonSMXEp33nknkydPJjc3l0OHDjFv3jz0ej3Tp08PddHand9BWlEU3n//faZNm8ayZct46623eOuttxrto6raqk7nn38+b7zxRudJRWez4dHpKT+oPYL2KV6BufhA430SE+HhhyE1Vfvd6dT+RWRnB7mwQgjRsR04cIDp06dTXl5OSkoKZ511FuvWrSMlJSXURWt3bVpPOj4+nk8//ZT//ve/LF68mPXr13uX8kpLS2PkyJHMmDGDCy+8MCCFDRv19VRaFew2Nwoe0inBc8ml6NLTtPf1eq3GnJR07JjKSq2pW6ZdCSFEq/iSNKuzalOQbjB58mQmT54ciFN1DDYbB/O1FKfJlOHI7UH09dedfD5BZaXW7G02N7+PEEIIcRwZYtxabjfs3EnZ+18DkK47TNW0G08eoI8uD0eXLkEooBBCiM5CFthorYICeOghiq3aAuDKab0x5GSd/BirVZuClZERhAIKIYToLGSBjdbauRPcbkoULeCactMxRbaw+HdVFWRltW3OgRBCiFOOLLDRWmVlqChUq1qantgEI6bIFm6jw3FslLcQQgjhI1lgo7XKyrARieforYtOMGA+WU1aVbWXLEkphBCilfwO0iUlJS3m7G7QqRbYKC+nBi2hu8GsEBNnRKc/yaAxu11bRzouLkgFFEII0Vn4HaTj4uKorKyktra2xX0bFtiICVUm90CqqKD6aJA2R+iJsrQwi81m0/qipSYthBCilWSBjdY6coRqtIcNc5Qec3QLg8ZsNi2JicyPFkII0Up+B+mrrroKVVX53e9+x7p165rdr9MtsFFZ6W3ujojRn7w/2uOB2loth7cQQgjRSn4H6WuuuYYxY8ZgtVoZO3Ys06dP55VXXmHFihWsWLGChQsXcuWVVzJ27FisVitnnXVW51hgo7LS29wdGa3HYGqmP7qiQpuuFR8vqUCFEKKNVq9ezeTJk8nMzERRFN57771QFykoZIGN1rJaqSEXgIhYPQajDsrLteUpj/98ZjOMGQN9+0p/tBBCtFFtbS0DBgzguuuu47LLLgt1cYJGFthoraqqYzXpWAOGumqt1jx2rFZrbhAZqaUB7QwPJkIIEWIXXHABF1xwQaiLEXSywEZrHRekY/T16CscMHIkDBsmAVkIIURABSRIt6SiooI333yTRYsWsWbNmmBcsn14PKg1tdQcHd0dm2yE88fDaadJgBZCdDiqqmJz2kJy7ShjVOfoAm1n7RaknU4nH374Ia+++ir/+9//cDqd7XWp4LFaqScC99HbFn/FBDi9b4gLJYQQ/rE5bcTMD03+ipq5NUSbfEuIdSoLeJBeu3Ytr776Km+99RaVlZXewWPJyclccsklgb5ccB03R9pgUojMSAhxgYQQQnRmAQnSe/bsYdGiRSxevJg9e/YAWjNKly5dmDJlCpdddhljx45Fp+vgy1cfOUId2hKVpggdhoig9BYIIUS7iDJGUTO3JmTXFi3zO8pUVlayZMkSFi1axNq1awEtMKemplJaWoqiKPzwww9YAjT96Nlnn+Xxxx+nuLiYAQMG8Pe//53hw4eftHx/+tOfePfddzly5Ai5ubk8/fTTbRtpXlZGPREAGMx6CdJCiA5NUZQO0+RcU1NDfn6+9/eCggK2bNlCYmIiOTk5ISxZ+2pVlHG5XHz00UcsWrSIjz76CIfDgaqqWCwWpk6dyvTp0xk/fjxGozGghVyyZAlz5sxhwYIFjBgxgqeffpqJEyeyY8cOUptYAtLhcHDeeeeRmprKO++8Q1ZWFvv27SP++ClS/jguSBsjDBKkhRAiSDZu3Mi4ceO8v8+ZMweAWbNmsXDhwhCVqv35HGVuvfVWlixZwpEjR1BVlYiICKZOncpVV13FRRddhLkdc1M/+eST3HjjjcyePRuABQsW8NFHH/HSSy9x9913n7D/Sy+9xJEjR1izZo33gSEvL6/tBSkvPxakoyRICyFEsJxzzjneMU6nEp87if/5z39y5MgRJkyYwMsvv0xxcTHvvPMOl112WbsGaIfDwaZNm5gwYYJ3m06nY8KECd5m9p/74IMPGDVqFLfccgtpaWmcccYZPPLII7jd7rYV5sgR7EeDtCnKgDEysC0GQgghxPFaPZJr165d7Nixg8LCwvYozwnKyspwu92k/WyRirS0tGbXp96zZw/vvPMObrebjz/+mHvvvZe//vWvPPTQQ81ex263U1VV1eh1gspKb03aFGNCb2phBSwhhBCiDXwO0n//+98ZNmwYe/fu5bHHHmPAgAH069eP+fPne0d0hwuPx0Nqair//ve/GTJkCNOmTeNPf/oTCxYsaPaY+fPnExcX531lZ2efuFN1daMgrehkIr4QQoj243OQvuWWW1i3bh07duxg7ty55OTksG3bNu655x569uzJyJEjeeaZZ5qt3forOTkZvV5PSUlJo+0lJSWkN7O6VEZGBr169UKvP1bTPe200yguLsbhcDR5zNy5c7Fard7X/v37T9ypqgo7WtO+Kcbk5ycSQgghfNPq5u6ePXvy0EMPUVBQwMqVK5k9ezYWi4UNGzZwxx13NKqBHjlypM0FNJlMDBkyhOXLl3u3eTweli9fzqhRo5o85swzzyQ/Px+Px+PdtnPnTjIyMjCZmg6uZrMZi8XS6HWCmppGNWkhhBCiPbUpu8jYsWN54YUXKC4u5o033mDSpEneXKyqqtKzZ0/OOeccnnnmGQ4cOOD3debMmcPzzz/PK6+8wk8//cTNN99MbW2td7T3zJkzmTt3rnf/m2++mSNHjnDbbbexc+dOPvroIx555BFuueWWtnzcRs3d5riItp1LCCGEaEFA5hCZzWamTZvGtGnTKC0t5fXXX2fRokVs3ryZ1atX8+WXX3LHHXcwdOhQ1q9f3+rzT5s2jcOHD3PfffdRXFzMwIED+eSTT7yDyQoLCxtlM8vOzubTTz/ljjvuoH///mRlZXHbbbfxhz/8oW0f9LiadFRKx0gAIIQQouNS1HacePbjjz/yyiuv8Prrr3Pw4EEURWn7NKggqaqqIi4uDqvVeqzpu1s3Hi+4AhvRTPn3BQy4sfmMZ0IIEW7q6+spKCiga9euRERIa2Brnez+NRkzAqBdk2n37duXxx57jMLCQj777DNmzJjRnpdrd2pN7bGadHpsiEsjhBCiswtKyixFUZgwYUKjhCQdkavWjgdtxHh0ZuCelIQQQoimdPBlqYJIVam3HR0trkBkoqzgIoQQwfTss8+Sl5dHREQEI0aMYMOGDc3uu3DhQhRFafTqiE38EqR9VVtL/dE50kaTItnGhBAiiBoWWpo3bx7ffvstAwYMYOLEiZSWljZ7jMVioaioyPvat29fEEscGBKkfXXc9CujWY/eKEFaCCGC5fiFlvr27cuCBQuIioripZdeavYYRVFIT0/3vn6eXrojkCDtq+OCtCFCLzVpIYQIEn8WWgJtDerc3Fyys7O59NJL2bZtWzCKG1Cy1qKvqqu9K2AZIw3ojPJ8I4To4FQV3LbQXFsfBYpv6x+cbKGl7du3N3lM7969eemll+jfvz9Wq5UnnniC0aNHs23bNrp06dLm4geLBGlfHd/cHWmQ5m4hRMfntsFbMaG59i9rwNB+SaFGjRrVKHX06NGjOe2003juuef485//3G7XDTSpDvrq+BWwoqQmLYQQweLPQks/ZzQaGTRoEPn5+e1RxHYjNWlfVVd7V8AyRhq8OcqFEKLD0kdpNdpQXdtHxy+0NGXKFODYQku33nqrT+dwu91s3bqVCy+80J/Shkybg7TH4+Grr75i27ZtVFZW4nQ6T7r/fffd19ZLhkZVFQ6MABgijSEujBBCBICitGuTcyDNmTOHWbNmMXToUIYPH87TTz99wkJLWVlZzJ8/H4AHH3yQkSNH0qNHDyorK3n88cfZt28fN9xwQyg/Rqu1KUi/88473HbbbT6tIa2qKoqidNwgXV2N82iQNkqQFkKIoGrtQksVFRXceOONFBcXk5CQwJAhQ1izZg19+/YN1Ufwi99B+pNPPmHatGmoqorZbGbYsGFkZWV1yIwuPqmqwom2hrQhUnoJhBAi2G699dZmm7dXrlzZ6PennnqKp556Kgilal9+R5v58+ejqirjx4/ntddeIzU1NZDlCj9VVd6atCHaFOLCCCGEOBX4PUR58+bNKIrCyy+/3PkDNDRq7jaYpSYthBCi/fkdpHU6HRaLpUNNCm+T6mocR5u7TZZO2qQvhBAirPgdpPv3709tbS21tbWBLE/4Oq4mbYo1h7gwQgghTgV+B+k77rgDl8vFggULAlme8HV8kI6LDHFhhBBCnAr8DtJTp05l3rx5/PGPf2TevHmdv0bdKEhLc7cQQoj25/cIqHPPPReAqKgoHnroIR577DHy8vLIzMxs9hhFUVi+fLm/lwyt+npvn7RZgrQQQogg8DtI/3xOmsPhYOfOnezcubPZYzp0Kk2n01uTjpAgLYQQIgj8DtIvv/xyIMsR9tx2Jx60la/McTJwTAghRPvzO0jPmjUrkOUIe0676v3ZFCvJTIQQQrQ/WW/RRw3rhiiK5O4WQohQePbZZ8nLyyMiIoIRI0awYcOGZvfdtm0bl19+OXl5eSiKwtNPPx28ggZQQIP0gQMH2Lx5M5s3b+bAgQOBPHXIORzaf/UGBZ1Bnm2EECKYlixZwpw5c5g3bx7ffvstAwYMYOLEiZSWlja5v81mo1u3bjz66KM+rzkdjtocbfbt28fNN99MSkoKubm5DB06lKFDh5Kbm0tqaiq/+c1v2LdvXyDKGlJOl/ZfvVFBp5cgLYQQwfTkk09y4403Mnv2bPr27cuCBQuIioripZdeanL/YcOG8fjjj3PllVdiNnfccURtSkL94YcfctVVV1FbW4uqqie8X1ZWxnPPPcfixYt58803O9xi214eD063NmhMb9Sh6DvwKHUhhGigqmCzhebaUVFa/6EPHA4HmzZtYu7cud5tOp2OCRMmsHbt2vYqYVjwO0jv3r2bX/7yl9TX15OTk8OcOXMYN24cubm5gFbD/uKLL3jqqacoLCzkiiuuYOvWrXTv3j1ghQ8ahwPH0elXepNeatJCiM7BZoOYmNBcu6YGoqN92rWsrAy32+1dO7pBWloa27dvb4/ShQ2/o82jjz5KfX095513Htu3b+f//u//6NevHxaLBYvFQr9+/bjtttvYvn0748ePp76+nsceeyyQZQ8eh+PYClgmvdSkhRBCBIXfNenPP/8cRVFYsGABERHNJ/eIiIhgwYIF9OzZk2XLlvl7udByOHAezTamNxtQdBKkhRCdQFSUVqMN1bV9lJycjF6vp6SkpNH2kpKSDj0ozBd+B+mioiLi4+Pp2rVri/t2796d+Ph4iouL/b1caB1Xk9abpblbCNFJKIrPTc6hZDKZGDJkCMuXL2fKlCkAeDweli9fzq233hrawrUzv4N0TEwM1dXV1NfXn7QmDVBfX09NTQ2xsbH+Xi60ju+TNktztxBCBNucOXOYNWsWQ4cOZfjw4Tz99NPU1tYye/ZsAGbOnElWVhbz588HtMFmP/74o/fngwcPsmXLFmJiYujRo0fIPkdr+V0lHDRokM9LVT733HO4XC6GDBni7+VC6/g+abNemruFECLIpk2bxhNPPMF9993HwIED2bJlC5988ol3MFlhYSFFRUXe/Q8dOsSgQYMYNGgQRUVFPPHEEwwaNIgbbrghVB/BL37XpG+44QaWL1/O73//e+rr67ntttuIjGy8znJlZSXPPPMMDz30EIqicOONN7a5wCFxXJ+0IcLQsRcKEUKIDurWW29ttnn754s+5eXlNTk1uKPxO0hPmzaNDz74gDfeeIM//elPPPLIIwwfPpysrCzsdjuFhYVs3boVm82GqqpcddVV/OIXvwhk2YPnuOZug7lNU8uFEEIIn7Up4ixatIjTTz+dxx57jOrqar744osT9omNjeXuu+/mD3/4Q1suFVrHN3dHSJAWQggRHG2KODqdjj/+8Y/cdtttfPbZZ3z77beUlZUBkJKSwqBBgzj//POJ7gCjB0/q+OZuqUkLIYQIkoBEnOjoaKZOncrUqVMDcbrwc3xNOlKCtBBCiOCQCb++kCAthBAiBCRI+8Julz5pIYQQQedTxOnWrRsAPXr04LPPPmu0rTUURWH37t2tPi7kHA4cR/ukjdGmEBdGCCHEqcKnIL13716ARpnFGra1RoedX+xw4Dp6qyRICyGECBafgvSKFSsAiDouIXrDtlOCBGkhhBAh4FOQPvvss33a1mk5HLjRA2CINIa4MEIIIU4VMnDMF8fVpE1REqSFECIUnn32WfLy8oiIiGDEiBFs2LDhpPu//fbb9OnTh4iICPr168fHH3/c6P1rr70WRVEavSZNmtSeH6HV/A7S3bp1Y+TIkT7vP2bMGLp37+7v5ULr+Jp0jDR3CyFEsC1ZsoQ5c+Ywb948vv32WwYMGMDEiRMpLS1tcv81a9Ywffp0rr/+ejZv3syUKVOYMmUKP/zwQ6P9Jk2aRFFRkff1xhtvBOPj+MzvIL13714KCwt93v/AgQN+DTYLC8cFaVO0OcSFEUKIU8+TTz7JjTfeyOzZs+nbty8LFiwgKiqKl156qcn9//a3vzFp0iTuuusuTjvtNP785z8zePBg/vGPfzTaz2w2k56e7n0lJCQE4+P4LGiTfp1OJzpdx2xdV+0O3EdvlSFamruFEJ2Dqqo4bc6QXNsYZfR5xo/D4WDTpk3MnTvXu02n0zFhwgTWrl3b5DFr165lzpw5jbZNnDiR9957r9G2lStXkpqaSkJCAueeey4PPfQQSUlJrfsw7SgoQbqqqorS0tKwe0LxlbvOAWjTz0wyulsI0Uk4bU7mx8wPybXn1sz1+e9pWVkZbrfbu3Z0g7S0NLZv397kMcXFxU3uX1xc7P190qRJXHbZZXTt2pXdu3fzxz/+kQsuuIC1a9ei1+tb+Ynah89B+vvvv2fLli2NttXV1fHqq682e4yqqlRWVvLuu+/idrsZNmyY3wUNpeODtFFGdwshRKdw5ZVXen/u168f/fv3p3v37qxcuZLx48eHsGTH+Bykly5dyoMPPthoW1VVFbNnz27xWFVVMZlMjZoqOhJX/bHmIEkLKoToLIxRRubWhObvsrEVM2WSk5PR6/WUlJQ02l5SUkJ6enqTx6Snp7dqf9AGRCcnJ5Ofn9/xgnReXh5jx471/r5q1SqMRiOjRo1q9hidTofFYuH0009nxowZ9O7du22lDRG3zQGAgorO0DH71YUQ4ucURekQXXgmk4khQ4awfPlypkyZAoDH42H58uXceuutTR4zatQoli9fzu233+7dtmzZspPGrAMHDlBeXk5GRkYgi98mPgfpWbNmMWvWLO/vOp2OxMTEUyLzmKveBYBe50HRddDUpkII0YHNmTOHWbNmMXToUIYPH87TTz9NbW2ttzV35syZZGVlMX++1sd+2223cfbZZ/PXv/6Viy66iDfffJONGzfy73//G4CamhoeeOABLr/8ctLT09m9eze///3v6dGjBxMnTgzZ5/w5v9tuV6xYgckU/k9ggeA+2tyt16kSpIUQIgSmTZvG4cOHue+++yguLmbgwIF88skn3sFhhYWFjWYQjR49mtdff5177rmHP/7xj/Ts2ZP33nuPM844AwC9Xs/333/PK6+8QmVlJZmZmZx//vn8+c9/xmwOn6m2iqqqaqgL4atnn32Wxx9/nOLiYgYMGMDf//53hg8f3uJxb775JtOnT+fSSy89Yfh9c6qqqoiLi8NqtVI79Wb+/UUvIk0ubj04l6jkqJZPIIQQYaa+vp6CggK6du3aaMEk4ZuT3b/jY4bFYgnYNTtMB2trs8002Lt3L3feeSdjxozx+9pub3O31KSFEEIET5uD9Jo1a5g1axa9e/fGYrGg1+ubfRkM/o+Mbm22GQC3283VV1/NAw884Nf61w1cdjcAOh0SpIUQQgRNm4L0vffey5gxY1i0aBG7du2ipqYGVVWbfXk8Hr+u05BtZsKECccK3kK2GYAHH3yQ1NRUrr/+er+u28Dt0IK0XoK0EEKIIPI7SH/00Uc8/PDDGAwGHn74Yb799lsAUlJSyM/PZ82aNTz88MOkp6eTlJTEf/7zHwoKCvy61smyzRyfPeZ4X331FS+++CLPP/+8T9ew2+1UVVU1ejVwO7WHC51egrQQQojg8TtI//Of/0RRFB555BHmzp3LwIEDAW3EXMMKWXPnzuX7778nIyODG264gWCNUauurmbGjBk8//zzJCcn+3TM/PnziYuL876ys7O977kcDUFakSAthBAiaPwO0hs3bgQ4oSn5503aycnJPPfcc1RUVPDQQw/5da3WZpvZvXs3e/fuZfLkyRgMBgwGA6+++ioffPABBoOB3bt3n3DM3LlzsVqt3tf+/fu97x2rSUuQFkJ0fB1oUk9YCcV98ztIV1ZWYrFYiI+P924zGo3U1NScsO+oUaOIjo5m2bJlfl3r+GwzDRqyzTSVPaZPnz5s3bqVLVu2eF+XXHIJ48aNY8uWLY1qyQ3MZjMWi6XRq4GrIUgbJEgLITquhkUjHA5HiEvSMdlsNkCLdcHi93Dr1NTURv22oNV4i4uLKS0tJTU11btdVVVcLtcJNeHWaE22mYiICO+E9QYNDxM/3+4Lt1N7etIbdBKkhRAdlsFgICoqisOHD2M0Gjvs8sHBpqoqNpuN0tJS4uPjg7pClt9BOicnh3Xr1lFeXu5de7MhA8zSpUv59a9/7d33s88+w263nzSxeUtam20mkFxHg7ROgrQQogNTFIWMjAwKCgrYt29fqIvT4cTHx7cpjvnD7yB95plnsm7dOlatWsVll10GwPTp0/nf//7HbbfdRmlpKUOGDGHHjh08/PDDKIrChRde2KbC3nrrrc0mU1+5cuVJj124cKHf13W7jgZpo16CtBCiQzOZTPTs2VOavFvJaDSGZI1pv9OCfvvtt0ycOJFJkyaxaNEi7/aLL76Yjz/+GEU5FsxUVfXWvIP9FOKv41O8bU79BSvto+l2egQzfvhDqIsmhBAizLRXWlC/a9KDBw/m8OHDJ2x/7733eO655/jPf/7DwYMHsVgsjB8/njvvvNPn6VDhxq3lMkFnCv5TlBBCiFOX/3k6mzuhwcAtt9zCLbfcEuhTh4zLrbUK6EwBv11CCCFEs2RoX0s8Htyqdpv0EqSFEEIEkQTpljiduNGauXWm4M2NE0IIIXyqGl533XUBuZiiKLz44osBOVfQOBzHgrRZatJCCCGCx6eos3DhQhRFaTIl2s9HcZ/svQ4ZpJ1OXEdvky7CFOLCCCGEOJX4FKTnzZvX5Ha73c6//vUvrFYrXbt2ZcyYMWRmZgJw6NAhvvrqK/bs2UN8fDw33XQTZrM5cCUPluNr0tInLYQQIoj8DtJ1dXWcc845ALz11ltcccUVTR777rvvcv3117NixQpWrFjhf0lDxeHw1qT1MgVLCCFEEPk9cOzhhx9m48aNvPDCC80GaIDLLruMF154gfXr1/Pwww/7e7nQOW7gmARpIYQQweR3kF6yZAkRERHelKAnc9lllxEREcGSJUv8vVzoHNcnrY+Q5m4hhBDB43eQPnDgAHq9vtHgsOYoioLBYODAgQP+Xi50jqtJG2V0txBCiCDyO0gnJSVRW1vL6tWrW9x31apV1NTUeFfL6lBcLm9N2hApQVoIIUTw+B2kJ0+ejKqqzJgxgy1btjS733fffcesWbNQFIVLLrnE38uFjsvlrUkbIiWZiRBCiODxu2r45z//mQ8//JD9+/czbNgwxo8fz9ixY71TsIqKili9ejWff/45breb7OxsHnzwwYAVPGiO65M2SJ+0EEKIIPI76iQnJ/P1119z9dVX8/XXX/PZZ5+xbNmyRvs0JDc566yzWLx4cYdt7j5Wk5YgLYQQInjaFHVycnL48ssvWbFiBe+++y5btmyhrKwM0IL4oEGDmDp1KuPGjQtIYUPiuIFjhkjJOCaEECJ4AlI1HDduXMcOxCdz3MAxY7T0SQshhAgeWQWrJcc3d0dJTVoIIUTwSJBugepw4G6oSUuftBBCiCBq1VKVGRkZ3tSe/ixf2RFXwXLbnd6fjVKTFkIIEUSK2tT6kz+j02kV7j59+vDjjz96tzW3fGWzF1MU3G63n0UNrqqqKuLi4ih9+l/88/YSAH7z3a9I6Z8R4pIJIYQINw0xw2q1YrFYAnbeVq2ClZycfMK2zs5V7/D+bIiSgWNCCCGCx++lKk+VIO2udwGgw4POKKtgCSGECB4ZONYCb5BWPCgGCdJCCCGCR4J0CzxHB47pFQ+KruUVv4QQQohAkSDdArddG+imV1QJ0kIIIYLKpz5pvT4wzbyKouByuQJyrmBxO5yAQWvuliAthBAiiHwK0q2ZZhWM8wST2+5CC9JSkxZCCBFcPgXpgoKC9i5H2HI7PIA0dwshhAg+n4J0bm5ue5cjbLmdWp+0TidBWgghRHBJMuoWeOwNU7AkSAshRJPcDnBVh7oUoeW0t8tpJUi3wO082twtNWkhhDiR2w5Fn0FtYahLElqumHY5bUCCdEFBAevWraOoqIja2tqTDhC77777AnHJoGlo7lYUJEgLIUQDVQXHEajYClXbISoblFM04ZOjEpy2djl1m4L03r17+dWvfsXy5ctb3FdVVRRF6XhB2tHQJy1BWgjRClU7wH4k1KVoP/ZSqDsEzhqI6gKG6FCXKHR0RqB9phf7HaTLysoYO3YsBw8eJCUlhVGjRvH+++8TGRnJ5ZdfTmlpKevXr8dqtZKUlMTFF18cyHIHjfvofddLkBZC+Er1QPlGsO0HXSdd4lZnBlMCRGRpTY2iXfgdpB9//HEOHDjAmWeeyUcffYTFYkGn0xEXF8err74KQH19PU888QTz5s3D4/HwyiuvBKzgweJ2yehuIUQruWq0V1QOGGNDXZr2VbkV9i4CT8dKVBVQqguc7dOS4HeQ/uijj1AUhSeeeKLZtTMjIiK455578Hg8PPDAA4wdO5brr7/e78KGgsep9a/r9IoEaSGEbxxWcNsgIi3UJWlfbjvseBrsh0NdktBzxbfLaf0O0nv37kWv1zNs2DDvNkVRcDgcJ+x7++238+CDD/LCCy90uCDdMLpbp9M+nxBCtMhZBR5P5x5Ipbph72ItQJtToMdNp26zt7MKaj3AMwE/td9BuqFpW6c7tkZHdHQ0VqsVt9vdKN+3xWLBYrGwffv2tpU2BNyuhpp0iAsihOg4HOXgqgV7eahL0j5shbBnIdQezUbZ7XpIGnbSQzo1ezno69rl1H4H6ezsbPLz8/F4PN5A3bVrV3744Qe+/fbbRjXssrIyKisriYiIaHuJg8ztPtbcLYQQPvnxL3Doo1CXov3poyHvakgeFeqSdFp+B+m+ffuyfft2tm7dyoABAwAYN24cW7duZe7cuXzwwQdERUXhdDq5/fbbAejXr19ACh1MDTVpvQRpEUoeN1TvhPpSbX6qCF8eJ5SsOPqLrnM2AetMkDYOcq8CY9NjkkRg+B2kL7zwQv7zn/+wdOlSb5C+/fbbeeGFF1ixYgXp6en06dOHvXv3Ul5ejqIo3mDdkUhz9ymi/jAc/ip8R6iqLm1OKvrO+Ue/M6nerQ0aM8TAqEWdu1+6Qf1hrV/2VOWxA+3zsOJ3kP7FL36BzWYjJSXFuy0vL4/333+fmTNnUlRUxMaNGwFtlPf999/P9OnT217iIPN4m7t1LewpOrSaPVC1C0zxoS5J86JyQN/xuoxOOaWrtP8mDj01ArTHCY4KSBgI+k46J9wX7ZNwzPcgPWrUKGbNmsUvf/lLEhMTiYmJ4ZZbbjlhv/Hjx7N3717Wrl3LwYMHsVgsjB49moSEhIAWPFgakpnoDBKkOy2PC6rztQAdmRHq0jStrgh2P6/NvRUBp6oqKoHpRlCqfkIBXAmDUT3OgJwzrNkOgjkFT+LwUzpIu00hTgu6fv16NmzYwO23386FF17IjBkzuPjiizEajSfsazQaGTt2bEALGioebQYWOqME6RapHu2puqOpL4bqXaCP1EbkhhuPA7Y/qaVhFO1COfoKFLdiYHVVNa6aFS3v3IEZPHaiXRUciOlHpfWtUBcnpCLdke1yXp+D9DXXXMN7771HTU0N77//Pu+//z7x8fFMmzaNGTNmMGpU5xzd59YSjp2azd0um/aU7AvVCVU7tYT7HU1NAfw4X5v3Gc4iMqDLpaEuRSMqUOOoxuZsn+knTfGoHqx2Kw6X42gJ2ng+VHSKDnMAa4FVpjQwRnfqZQYjXFUY1TqORHWnLiILo+7ECtupotpejcN+Yo6QQPD5O/Tqq69SV1fH0qVLWbRoEZ9//jkVFRU899xzPPfcc3Tr1o0ZM2ZwzTXX0K1bt3YpbCi4T9WatOqBw19DxXe+DVRS0ZLMh3OfblNUD+x9TQvQhhjQBafPV0XFo3pw+/hgYDfGszf1EuxKYjuXrHU8HpVSpweHy4hOCd6/kaioLsSY2r40oNPj5v0DW1hXtgdPQEfN70Ov2jv1SHxV0ePUR+PW/wR8FurihJTD7Wi3mrSinmxdyZMoLS3l9ddfZ/HixXz77bfayY7+MR81ahQzZ87kl7/8JfHx8QErbDBVVVURFxfHi5Ez2F/XnVFnKZz/ZcdawatZqkcbjek+SR+K0wr73gLFoDUDn/yEUPY1FH+hNc2GKbWJnwAUVFyKiW+73IjT0D5rwv6cR1U5UleOgoK+A08dUFWVYrsNV0Abi09+vTVlu1m6/1vq3W3/rnnUQPVEi1NdPPFU3l+J1WptNlW2P/wO0sfbvn07ixYt4vXXX2ffvn3aiRUFk8nExRdfzDXXXMNFF12EwdBxGn8agvS/zTM5ZO/GmeMMTPjiT+13Qbddmwfb1iZXjwvqDmjna3YftzYa01Pf/D4lK06NZAxHbYsby/7oM4J2vRqXnVWH92Bz+96Hb3DXo1PDq89/Y2UJG63FoS5GmyQZI7k2+3SSTIGrCamKnurIHOzGpICdU4SvGkcN2OH5Xz4fnkH6eF9++SWvvvoq//nPf6isrNQuoigkJiZy5ZVX8ve//z2Ql2s3DUF6gXEmxc5ujJkYybmf/L79LljxHRQta/scWFXVar/NLo+nQvk3cGQj0MwDgapC9Q7t58hMwIdmTHMiZF+uTRNqI7fqafM5bE4bVrsVz3Hnei1/JZ8d2ope1/hh0a4qVKnB7c7YV1uONYj9uO3JqDOQERW8YGQxxzCtx3n0im/7dw0g3hyLIcCtGapiwGZKhSB2AYjQKbeVU1dTx2/G/ib8g3QDh8PBhx9+yKJFi/jvf/+Lx+NBURTc7jAfnHNUQ5B+1nAth115nH1xNOf89872uZirDnb8TRukZWrDVDWPU6v9WrcGplxZl0L3ViyIorpPXoP3QUHlXvZa97Z5PNC+2jL2VB/2PvQU1lXyyr4tbTtpgHWNimNEvG9TvhRU7MY46o3JgR2G3EbRxmgmdZ9ESnRKyzuHKYfbQXFNMY4ANJ+LU5PD7cCiWtolSLdb+3NxcTE7duxg165dtNNzQFC4PdpfRJ25iVtlPwLuZpqMnVXatB6PD0GrthC++xPQ9hqkTwwx0OUyiOrS/D6meIjupjWL+8Lj1EZ2t6FPt7C6hAe2vIPN7UTXhiQQZQ4bX5TtazLO/yKrL6OTshttUwGPYqbemIQapGxekXozA5N7+FyDU1GwmdNxtzg+IPhUVQ1qgHN5XBysPhiwvyt6RU9OXA5pMZ18WUnRrjz17fP3O6BB2mq18tZbb7F48WK+/vprLUHA0X9Iw4cPZ+bMmYG8XFC4jzaD6iN+1nzsdsCh/zW/jqrqAp35JM3OxzmwFPCAKRHMbWw2jO6qNTsb45rfR28Gd93J5wSrbqjd43t5FD2kng2WnjRX1Vt3cB17K/Y2e4p/bP6Yrw9u8+16PugWn4vhuGA/NH0gV/W9rMlRyG6dGTXIU0hK7NVUO6p9P8BWAfj40BQkHtVDjaMGs94ctBq+gkLPxJ70TekbkBHlep2ezNhMDLqOM2ZGhJ+qqvZJi9rmb6XT6eSjjz5i8eLFfPzxx9jtdm9gzs3N5ZprrmHmzJn07NmzzYV99tlnefzxxykuLmbAgAH8/e9/Z/jw4U3u+/zzz/Pqq6/yww8/ADBkyBAeeeSRZvdvTkOQNkT+7A+406rVMiMytKD3c7UHtBpyS1Q3lK3Xfj7t9xDXt1Xla5Kj8uR5dO0O7SHC3EITZcIgiD9D6+NuiaJoU7CakX8kn5d+eBePx9PkH8MqexVfH/wGBYVLel/Spj+YekXP0MyhZMZmNpriZHfZ+amqKKhThZqjqipRxiiSo5I79OhugCGWIeTE5aAEKUorikJiZKIEVXFK8Ptb/tVXX7F48WLeeecdKiq0p3tVVbFYLPziF79gxowZAc06tmTJEubMmcOCBQsYMWIETz/9NBMnTmTHjh2kpqaesP/KlSuZPn06o0ePJiIigscee4zzzz+fbdu2kZWV5fN13UcHTekif1YjPvBfbX5tUyvAOK1QvoFWdazG9ITILHBYfT+mKU6rFjCN8U2+7VY9VLic1MecgTO6a8sD1apL2lYetO/F1e9ezYaDG1rcd0K3CVzS65I2X7OivoIaR02jP+QmvYlzcs8hPjK+zecPhDhzXIfuyxVCQF0dVFSAo516fFo1cGzHjh0nTLVSVRWDwcD555/PzJkzufTSSzGbm6hZttGIESMYNmwY//jHPwDweDxkZ2fz29/+lrvvvrvF491uNwkJCfzjH//wqdm9YeDYfG7GThqX/L4Xgx47ukCIux7+k9JyHmVLH1B8aELVGSFjkpY3uhULKDg9TgqthY0G43l0Rqos/aiPyGzymMO2w3xX8h1uT/AG8BVUFvDGD2+gV/T0TWm+pSDOHMd53c4jNz63zddMjkpmeNZwLOZjD1E6RYdRf+pmRRJCBN7q1fDtt2CxVHH99XGhGzg2dOhQNm/eDOBtzh40aBAzZ85k+vTpTdZmA8XhcLBp0ybmzp3r3abT6ZgwYQJr16716Rw2mw2n00liYusyNrnRmiL1Ucc9eBz8SAvQBgt0aarWp2hNxbE9fL9Q1Q5IGgrxA3w+5PP8T3i14HNvEhkAFR2qsrvJ/etd9azet5qK+tD0a07pM4VZA2Y1+36ZrQy3x83k3pNJiGjbgiyKLOcohGhndjvs2QNOp/Zze/A5SDdkFcvKyuLqq69m5syZ9O0bgP5TH5SVleF2u0lLazz6Mi0tje3bt/t0jj/84Q9kZmYyYcKEJt+32+3Yj7vLDYMAPEebuw3HB+mCRdp/U86EnF82f1HV7VtaQFctGKIhpjsYfBu9+2n+p0x+6xc+p5U8nkFnQB/kJfRy43IZmjGUXUd2NbuPTtExOns0iZHhlfpSCCGaUlysNXXHx4OrnZai9zlIz5w5kxkzZnDuued2uFrKo48+yptvvsnKlSuJiGi6OXn+/Pk88MADJ2x3o0cBdNERULwc1s5CrTuEAuwy98J+WEv64VY9vLJ7FW/s+RqHx4mCqnVJ+3irVHR4dH/0+TPVOGpwq266xnclJcr3fs3TUk5jUvdJ7Tboxu2GquoTe+PL6kqI8sQyPPGs5h8QFIU0MigqapeiCSFEQC1dCg89pAXoALZwN+LzX+qFCxe2Twl8kJycjF6vp6Sk8SCmkpIS0tPTT3rsE088waOPPsrnn39O//79m91v7ty5zJkzx/t7VVUV2dnZuNFjAAxR4FkzE129FqC/roOzlv2tLR+rzXol9uKu0Xe1qp+1xlHDoZpDmNq44k9d3YkDJVQVioqgpOTEBgS9YqanfjTr9J1n8RUhxKntqafgyNGF/3TtNGmkQ8xhMJlMDBkyhOXLlzNlyhRAGzi2fPlybr311maP+8tf/sLDDz/Mp59+ytChQ096DbPZ3OSAt4YgXVL7JD1MhzjoggsPwn6PkXhzBMdXlVOjkrmo2wRSo5PxoMfdjvNu9To96dHpKIrSKPVlS5KjkhmcMZiESP/7fItLYMUXYG9iIHqqGwZmgelnzwA69MQY2tbPLIQQ4WLHDigsBIMB/vAH0OvhwQcDf50OEaQB5syZw6xZsxg6dCjDhw/n6aefpra2ltmzZwNac3xWVhbz588H4LHHHuO+++7j9ddfJy8vj+JibRGAmJgYYmJ8z4qlHg3C2cpKAO4qg9rILnww5TUGZzUO/Ao6ftiq55CPSzC3WWXrD9Epenbua9sjX2kpFGyDn48VLCzUmn8qwivfhhBCBFzDpJpzzoEePbTWxfbQYYL0tGnTOHz4MPfddx/FxcUMHDiQTz75xDuYrLCwEN1x7Q3/+te/cDgcXHHFFY3OM2/ePO6///5WXz/N7KLKA1np4/lNl8voGjMIV11Uo30OHYK1Xx3N6xH6fBntoq4OnnkG9u8PdUmEECK0TCaYOrV9r9FhgjTArbfe2mzz9sqVKxv9vnfv3oBeW29w8019BNRNoqRsKP/9MfaEfX76CZYv77wBGqCsTOt3jojQRjQez2iE8eNh9Oi2L+YlhBDhLjYWqqq0cTg//3sYKB0qSIeSXu9hd202ppJrUT3J/DzhZ3U1PP98+82VCyeRkfDII9C9e6hLIoQQoVNVpbUujhunVVLagwRpH+hwoyoqzyx4gW1bk0+674ABcP75QSpYiPTtqw2SONrN30ht7bG+GiGE6OyGDoVhw7SKWnuQIO0DPW4OOvVs2zqW6GhIaWZacteu8OtfQ1RU0+93FocPQ00NNJW8LTcXsrO1IC6EEJ2ZokBOTvt270mQ9oFecVNiN3PhRfu45upcmhsc7nZDQQF4grQsdKhERMDZZ0O/fqEuiRBCdG4SpH2gV9wcro/k2usc1FY13cwLWnKP7t1h4MDOPXjMaIQuXUJdCiGE6PwkSPtAr7g5Yo/CVpFFvQ0GDWp6kIBeD6edBnFxwS+jEEKIzkeCtA/0ipsj9Rb09gjOOUeaeYUQQgSHBGkf6BU3VU4LV1+sIycn1KURQghxqujEPaeBo1fc1Lviyc4OdUmEEEKcSiRI+0CneHDrUySLlhBCiKCSIO0Dvc6N0ZwR6mIIIYQ4xUiQ9oFe5yYxUdq6hRBCBJcEaR/oFTcZGemhLoYQQohTjARpHyg6N4lJJ656JYQQQrQnCdK+UNxEREaHuhRCCCFOMRKkfaHzEBUhQVoIIURwSZD2gaqomCMiQ10MIYQQpxjJONaCbinf40l2EhUlNWkhhBDBJUG6BVEj09HX1xAd2cz6lEIIIUQ7kebuFng8LtDpiImOCnVRhBBCnGIkSLdA9XhQdHrMZlOoiyKEEOIUI0HaB4rOIHm7hRBCBJ0EaR8oOrlNQgghgk8GjrVgyJ9uRWd3hroYQgghTkESpFuQ3e80LBZLqIshhBDiFCTtuEIIIUSYkiAthBBChCkJ0kIIIUSYkiAthBBChCkJ0kIIIUSYkiAthBBChCkJ0kIIIUSYkiAthBBChCkJ0kIIIUSYkiAthBBChCkJ0kIIIUSYktzdzVBVFYCqqqoQl0QIIUS4a4gVDbEjUCRIN6O6uhqA7OzsEJdECCFER1FdXU1cXFzAzqeogQ77nYTH4+HQoUOoqkpOTg779+8/ZVfDqqqqIjs7+5S+ByD3oYHcB7kHDeQ+aBruw48//kjv3r3R6QLXkyw16WbodDq6dOnibcKwWCyn9JcQ5B40kPugkfsg96CB3AdNVlZWQAM0yMAxIYQQImxJkBZCCCHClATpFpjNZubNm4fZbA51UUJG7oFG7oNG7oPcgwZyHzTteR9k4JgQQggRpqQmLYQQQoQpCdJCCCFEmJIgLYQQQoQpCdIn8eyzz5KXl0dERAQjRoxgw4YNoS5Su7r//vtRFKXRq0+fPt736+vrueWWW0hKSiImJobLL7+ckpKSEJa47VavXs3kyZPJzMxEURTee++9Ru+rqsp9991HRkYGkZGRTJgwgV27djXa58iRI1x99dVYLBbi4+O5/vrrqampCeKnaLuW7sO11157wndj0qRJjfbp6Pdh/vz5DBs2jNjYWFJTU5kyZQo7duxotI8v/wYKCwu56KKLiIqKIjU1lbvuuguXyxXMj9ImvtyHc84554Tvw0033dRon45+H/71r3/Rv39/7xzwUaNG8b///c/7frC+CxKkm7FkyRLmzJnDvHnz+PbbbxkwYAATJ06ktLQ01EVrV6effjpFRUXe11dffeV974477uC///0vb7/9NqtWreLQoUNcdtllISxt29XW1jJgwACeffbZJt//y1/+wjPPPMOCBQtYv3490dHRTJw4kfr6eu8+V199Ndu2bWPZsmV8+OGHrF69ml/96lfB+ggB0dJ9AJg0aVKj78Ybb7zR6P2Ofh9WrVrFLbfcwrp161i2bBlOp5Pzzz+f2tpa7z4t/Rtwu91cdNFFOBwO1qxZwyuvvMLChQu57777QvGR/OLLfQC48cYbG30f/vKXv3jf6wz3oUuXLjz66KNs2rSJjRs3cu6553LppZeybds2IIjfBVU0afjw4eott9zi/d3tdquZmZnq/PnzQ1iq9jVv3jx1wIABTb5XWVmpGo1G9e233/Zu++mnn1RAXbt2bZBK2L4AdenSpd7fPR6Pmp6erj7++OPebZWVlarZbFbfeOMNVVVV9ccff1QB9ZtvvvHu87///U9VFEU9ePBg0MoeSD+/D6qqqrNmzVIvvfTSZo/pjPehtLRUBdRVq1apqurbv4GPP/5Y1el0anFxsXeff/3rX6rFYlHtdntwP0CA/Pw+qKqqnn322eptt93W7DGd8T6oqqomJCSoL7zwQlC/C1KTboLD4WDTpk1MmDDBu02n0zFhwgTWrl0bwpK1v127dpGZmUm3bt24+uqrKSwsBGDTpk04nc5G96RPnz7k5OR02ntSUFBAcXFxo88cFxfHiBEjvJ957dq1xMfHM3ToUO8+EyZMQKfTsX79+qCXuT2tXLmS1NRUevfuzc0330x5ebn3vc54H6xWKwCJiYmAb/8G1q5dS79+/UhLS/PuM3HiRKqqqrw1sI7m5/ehwWuvvUZycjJnnHEGc+fOxWazed/rbPfB7Xbz5ptvUltby6hRo4L6XZDc3U0oKyvD7XY3urkAaWlpbN++PUSlan8jRoxg4cKF9O7dm6KiIh544AHGjBnDDz/8QHFxMSaTifj4+EbHpKWlUVxcHJoCt7OGz9XU96DhveLiYlJTUxu9bzAYSExM7FT3ZdKkSVx22WV07dqV3bt388c//pELLriAtWvXotfrO9198Hg83H777Zx55pmcccYZAD79GyguLm7y+9LwXkfT1H0AuOqqq8jNzSUzM5Pvv/+eP/zhD+zYsYN3330X6Dz3YevWrYwaNYr6+npiYmJYunQpffv2ZcuWLUH7LkiQFl4XXHCB9+f+/fszYsQIcnNzeeutt4iMjAxhyUSoXXnlld6f+/XrR//+/enevTsrV65k/PjxISxZ+7jlllv44YcfGo3JOBU1dx+OH2vQr18/MjIyGD9+PLt376Z79+7BLma76d27N1u2bMFqtfLOO+8wa9YsVq1aFdQySHN3E5KTk9Hr9SeM1CspKSE9PT1EpQq++Ph4evXqRX5+Punp6TgcDiorKxvt05nvScPnOtn3ID09/YTBhC6XiyNHjnTa+wLQrVs3kpOTyc/PBzrXfbj11lv58MMPWbFiBV26dPFu9+XfQHp6epPfl4b3OpLm7kNTRowYAdDo+9AZ7oPJZKJHjx4MGTKE+fPnM2DAAP72t78F9bsgQboJJpOJIUOGsHz5cu82j8fD8uXLGTVqVAhLFlw1NTXs3r2bjIwMhgwZgtFobHRPduzYQWFhYae9J127diU9Pb3RZ66qqmL9+vXezzxq1CgqKyvZtGmTd58vvvgCj8fj/cPVGR04cIDy8nIyMjKAznEfVFXl1ltvZenSpXzxxRd07dq10fu+/BsYNWoUW7dubfTAsmzZMiwWC3379g3OB2mjlu5DU7Zs2QLQ6PvQ0e9DUzweD3a7PbjfhUCNeuts3nzzTdVsNqsLFy5Uf/zxR/VXv/qVGh8f32ikXmfzu9/9Tl25cqVaUFCgfv311+qECRPU5ORktbS0VFVVVb3pppvUnJwc9YsvvlA3btyojho1Sh01alSIS9021dXV6ubNm9XNmzergPrkk0+qmzdvVvft26eqqqo++uijanx8vPr++++r33//vXrppZeqXbt2Vevq6rznmDRpkjpo0CB1/fr16ldffaX27NlTnT59eqg+kl9Odh+qq6vVO++8U127dq1aUFCgfv755+rgwYPVnj17qvX19d5zdPT7cPPNN6txcXHqypUr1aKiIu/LZrN592np34DL5VLPOOMM9fzzz1e3bNmifvLJJ2pKSoo6d+7cUHwkv7R0H/Lz89UHH3xQ3bhxo1pQUKC+//77ardu3dSxY8d6z9EZ7sPdd9+trlq1Si0oKFC///579e6771YVRVE/++wzVVWD912QIH0Sf//739WcnBzVZDKpw4cPV9etWxfqIrWradOmqRkZGarJZFKzsrLUadOmqfn5+d736+rq1N/85jdqQkKCGhUVpU6dOlUtKioKYYnbbsWKFSpwwmvWrFmqqmrTsO699141LS1NNZvN6vjx49UdO3Y0Okd5ebk6ffp0NSYmRrVYLOrs2bPV6urqEHwa/53sPthsNvX8889XU1JSVKPRqObm5qo33njjCQ+sHf0+NPX5AfXll1/27uPLv4G9e/eqF1xwgRoZGakmJyerv/vd71Sn0xnkT+O/lu5DYWGhOnbsWDUxMVE1m81qjx491Lvuuku1Wq2NztPR78N1112n5ubmqiaTSU1JSVHHjx/vDdCqGrzvgqyCJYQQQoQp6ZMWQgghwpQEaSGEECJMSZAWQgghwpQEaSGEECJMSZAWQgghwpQEaSGEECJMSZAWQgghwpQEaSGEECJMSZAWQgTd/fffj6IoXHvttaEuihBhTYK0EGHo2muvRVEUn14rV64MdXGFEO1E1pMWIowZjUYSExNPuo/JZApSaYQQwSZBWogwNnr0aKkpC3EKk+ZuIYQQIkxJkBaiE8nLy/P2U+/bt4/rrruOrKwsIiIi6NWrF/fffz/19fXNHu92u3nuuec466yzSEhIIDIykl69enH77bdTVFR00muXlpbyxz/+kQEDBmCxWIiJieG0007j2muv5YsvvjjpsS+++CJDhw4lJiaG+Ph4Jk2axPr165vdf8WKFVx22WVkZmZiMplISEigd+/eXHnllbz55psnv0lCdCQBWHZTCBFgs2bNUgH17LPPbtVxubm5KqD++9//VpOSklRAjY2NVc1ms3dd4OHDhze5znNNTY167rnnevczmUyqxWLx/p6QkKCuX7++yet+/vnnalxcnHdfs9msJiQkqIqiqICam5vbaP958+Z516u+9tprVUA1GAxqTExMo3N8+eWXJ1zrn//8Z6N1jmNjY9WIiAjv72lpaa26Z0KEM6lJC9EJ3XXXXSQnJ7N27VqqqqqoqanhtddeIyYmhg0bNvC73/3uhGPuuOMOvvjiC6Kioli4cCE1NTVYrVY2b97MoEGDqKioYOrUqVRWVjY6bseOHUyZMgWr1crIkSP56quvqKur48iRI1RVVfHee+8xfvz4Jsv5/vvv89Zbb/HCCy9QXV1NdXU127Zto3///tjtdm6//fZG+9fW1nLXXXcBMHfuXA4fPkxVVRV1dXWUlpbyzjvvcNFFFwXkHgoRFkL9lCCEOFFDTdpoNKppaWnNvnr16tXouIaadGRkpLpnz54Tzvv666+rgKrT6dT9+/d7t+/Zs0fV6XQqoC5evPiE40pKStTo6GgVUB955JFG702dOlUF1EGDBql1dXU+fb6GmjSgPv/88ye8v3nzZu/7BQUF3u3r169XAbVPnz4+XUeIjk5q0kKEMafTSUlJyUlfTZk2bRpdu3Y9Yfv06dPJy8vD4/GwdOlS7/alS5fi8Xjo2rUrV1999QnHpaamcuONNwLwzjvveLdXV1fzwQcfAPDQQw8RERHRqs+XmZnJ7NmzT9g+cOBAunTpAsC2bdu82y0WCwBWqxWbzdaqawnREUmQFiKMnX322aiq2uzr503Pxx/XnLFjxwKwefNm77Zvv/0WgHPOOafZ48aNGwfA999/j9vtBmDjxo243W6MRmOzTdonc/rpp6PX65t8LysrC6DRZ+zRowfdu3enqKiIUaNG8e9//5uCgoJWX1eIjkKCtBCdUGZmZovvHT582LutrKwMOBYYm5KbmwuAy+XyBs7S0lIA0tLSMJvNAS1nQ63c6XR6txkMBl577TUyMjL4/vvv+fWvf023bt3IzMzk2muvZfXq1a0ugxDhTIK0EMLLbreHuggtGjFiBPn5+bz66qtcffXV5OTkUFRUxCuvvMLZZ5/Nb37zm1AXUYiAkSAtRCd06NChFt9LSUnxbmv4ubCwsNnj9u3bB2i12fj4eECrQQOUlJQENcBHRUUxY8YMFi9ezL59+9i+fTs333wzAP/617/49NNPg1YWIdqTBGkhOqGTNft++eWXAAwaNMi7reHnr7/+GpfL1eRxK1asAKB///7efuQhQ4ZgMBhwOp0sX748IGX3R+/evfnnP//JWWedBcCqVatCVhYhAkmCtBCd0JIlS7w13+O99dZbFBQUoNfrmTp1qnf7ZZddhk6n48CBAyxevPiE40pLS3n++ecBuOKKK7zbY2NjmTJlCgB/+tOfTprNLBAcDsdJ34+MjARo93IIESwSpIXohIxGI5MmTWLDhg2ANtjrzTff5IYbbgDg+uuv905xAi2d6PXXXw/Ab3/7WxYvXuwdsLVlyxYmTZpEbW0tmZmZ3mblBg8//DDR0dFs2bKFc889lzVr1qCqKgA1NTUsWbKEa665JiCf6+OPP2b06NG8+OKL7N+/37u9urqaxx9/nM8//xyAiRMnBuR6QoSarIIlRBhbs2YN6enpJ93nzjvv5M4772y07fHHH2fu3LmMGDGC2NhYnE6nt3Y5fPhw/vrXv55wnqeeeor8/HxWrFjBjBkzuOGGGzCbzVRVVQGQkJDAu+++6+2PbtCrVy/ee+89Lr/8ctauXcuZZ55JREQEUVFRVFZW4vF4vCPDA2Ht2rWsXbsW0PqmTSZTo2lav/71ryVIi05DatJChDFfkpnU1NSccFzPnj3ZtGkT1157LTExMXg8Hnr06MF9993HqlWriImJOeGY6OhoPvvsM/71r38xatQozGYzdrudHj168H//939s27aNESNGNFnOCRMmsH37du6880769u2LTqfD6XTSq1cvrrvuOl555ZWA3I9zzz2XRYsWMXPmTM444wwiIiKoqakhLS2Niy66iPfee48FCxYE5FpChANFbWiXEkJ0eHl5eezbt48VK1acNDGJEKJjkJq0EEIIEaYkSAshhBBhSoK0EEIIEaYkSAshhBBhSgaOCSGEEGFKatJCCCFEmJIgLYQQQoQpCdJCCCFEmJIgLYQQQoQpCdJCCCFEmJIgLYQQQoQpCdJCCCFEmJIgLYQQQoQpCdJCCCFEmPp/xy09qsNtWXQAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Calculate means and standard deviations across experiments\n",
    "mean_train_acc1 = np.mean(train_accuracies1, axis=0)\n",
    "std_train_acc1 = np.std(train_accuracies1, axis=0)\n",
    "mean_test_acc1 = np.mean(test_accuracies1, axis=0)\n",
    "std_test_acc1 = np.std(test_accuracies1, axis=0)\n",
    "\n",
    "mean_train_acc2 = np.mean(train_accuracies2, axis=0)\n",
    "std_train_acc2 = np.std(train_accuracies2, axis=0)\n",
    "mean_test_acc2 = np.mean(test_accuracies2, axis=0)\n",
    "std_test_acc2 = np.std(test_accuracies2, axis=0)\n",
    "\n",
    "mean_train_acc3 = np.mean(train_accuracies3, axis=0)\n",
    "std_train_acc3 = np.std(train_accuracies3, axis=0)\n",
    "mean_test_acc3 = np.mean(test_accuracies3, axis=0)\n",
    "std_test_acc3 = np.std(test_accuracies3, axis=0)\n",
    "\n",
    "mean_train_acc4 = np.mean(train_accuracies4, axis=0)\n",
    "std_train_acc4 = np.std(train_accuracies4, axis=0)\n",
    "mean_test_acc4 = np.mean(test_accuracies4, axis=0)\n",
    "std_test_acc4 = np.std(test_accuracies4, axis=0)\n",
    "\n",
    "mean_train_acc5 = np.mean(train_accuracies5, axis=0)\n",
    "std_train_acc5 = np.std(train_accuracies5, axis=0)\n",
    "mean_test_acc5 = np.mean(test_accuracies5, axis=0)\n",
    "std_test_acc5 = np.std(test_accuracies5, 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_acc1))\n",
    "plt.plot(epochs, mean_train_acc1, color='blue', label='5')\n",
    "plt.fill_between(epochs, mean_train_acc1 - 0.5*std_train_acc1, mean_train_acc1 + 0.5*std_train_acc1, \n",
    "                 color='blue', alpha=0.3)\n",
    "\n",
    "epochs = range(len(mean_train_acc2))\n",
    "plt.plot(epochs, mean_train_acc2, color='green', label='1')\n",
    "plt.fill_between(epochs, mean_train_acc2 - 0.5*std_train_acc2, mean_train_acc2 + 0.5*std_train_acc2, \n",
    "                 color='green', alpha=0.3)\n",
    "\n",
    "epochs = range(len(mean_train_acc3))\n",
    "plt.plot(epochs, mean_train_acc3, color='orange', label='0.5')\n",
    "plt.fill_between(epochs, mean_train_acc3 - 0.5*std_train_acc3, mean_train_acc3 + 0.5*std_train_acc3, \n",
    "                 color='orange', alpha=0.3)\n",
    "epochs = range(len(mean_train_acc4))\n",
    "\n",
    "plt.plot(epochs, mean_train_acc4, color='red', label='0.1')\n",
    "plt.fill_between(epochs, mean_train_acc4 - 0.5*std_train_acc4, mean_train_acc4 + 0.5*std_train_acc4, \n",
    "                 color='red', alpha=0.3)\n",
    "\n",
    "epochs = range(len(mean_train_acc5))\n",
    "plt.plot(epochs, mean_train_acc5, color='purple', label='0.05')\n",
    "plt.fill_between(epochs, mean_train_acc5 - 0.5*std_train_acc5, mean_train_acc5 + 0.5*std_train_acc5, \n",
    "                 color='purple', alpha=0.3)\n",
    "\n",
    "plt.xlabel('Epochs', fontsize=17)\n",
    "plt.xlim([-1, 301])\n",
    "plt.ylabel('Validation Accuracy', 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_acc_{method}_{methodopt}_bestiter.png')\n",
    "plt.savefig(f'../fig/robust_dataratio{ratio}_deep_hyrep_spd_acc_{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
}
