{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "7ebcf6f7",
   "metadata": {},
   "source": [
    "# Experiment Results Analysis\n",
    "\n",
    "This notebook loads experiment results and generates plots comparing different data loading strategies across the four classification tasks:\n",
    "- Cell line classification\n",
    "- Drug classification\n",
    "- MOA (broad) classification\n",
    "- MOA (fine) classification"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "6702348b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "✓ Setup complete\n"
     ]
    }
   ],
   "source": [
    "# Imports and setup\n",
    "import os\n",
    "import sys\n",
    "from pathlib import Path\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "# Add parent directory to path\n",
    "notebook_dir = Path().absolute()\n",
    "project_root = notebook_dir.parent.parent\n",
    "sys.path.insert(0, str(project_root))\n",
    "\n",
    "# Import analysis utilities\n",
    "from training_experiments.analysis import (\n",
    "    load_experiment_results,\n",
    "    load_multiple_run_results,  # For loading multiple runs from directories\n",
    "    extract_metrics,\n",
    "    create_comparison_dataframe,\n",
    "    create_comparison_dataframe_from_multiple_runs,  # For auto error bars from directories\n",
    "    create_comparison_dataframe_from_manual_runs,  # For manual multi-run data entry\n",
    "    get_time_comparison,\n",
    "    print_results_table,\n",
    "    STRATEGY_DISPLAY_NAMES,\n",
    "    TASK_DISPLAY_NAMES,\n",
    "    DEFAULT_YLIM,\n",
    ")\n",
    "from training_experiments.analysis.plotting import (\n",
    "    plot_comparison,\n",
    "    plot_training_curves,\n",
    "    plot_time_comparison,\n",
    ")\n",
    "\n",
    "# Set default plot style\n",
    "sns.set(style=\"whitegrid\", context=\"talk\")\n",
    "plt.rcParams['figure.dpi'] = 100\n",
    "\n",
    "print(\"✓ Setup complete\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9f853a6c",
   "metadata": {},
   "source": [
    "## Configuration\n",
    "\n",
    "Set the path to your experiment results directory:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c0e3f9ae",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Results directory: /path/to/scDataset/training_experiments/results/main\n",
      "Exists: True\n",
      "\n",
      "Contents:\n",
      "  comparison_pivot.csv\n",
      "  comparison_plot.pdf\n",
      "  comparison_plot.png\n",
      "  comparison_results.csv\n",
      "  time_comparison.pdf\n",
      "  time_comparison.png\n",
      "  training_curves.pdf\n",
      "  training_curves.png\n"
     ]
    }
   ],
   "source": [
    "# Path to experiment results\n",
    "# Update this to point to your results directory\n",
    "RESULTS_DIR = notebook_dir.parent / \"results\" / \"main\"\n",
    "\n",
    "# Alternative: absolute path\n",
    "# RESULTS_DIR = Path(\"/path/to/training_experiments/results\")\n",
    "\n",
    "print(f\"Results directory: {RESULTS_DIR}\")\n",
    "print(f\"Exists: {RESULTS_DIR.exists()}\")\n",
    "\n",
    "if RESULTS_DIR.exists():\n",
    "    print(\"\\nContents:\")\n",
    "    for p in sorted(RESULTS_DIR.iterdir()):\n",
    "        print(f\"  {p.name}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5b1ad9c0",
   "metadata": {},
   "source": [
    "## Loading Multiple Runs (for Error Bars)\n",
    "\n",
    "If you have results from multiple experiment runs (e.g., with different random seeds), you can load them all and automatically compute error bars (standard deviation across runs).\n",
    "\n",
    "**Directory structure for multiple runs:**\n",
    "```\n",
    "results/\n",
    "├── run_seed42/\n",
    "│   ├── streaming_64bs_0.001lr/\n",
    "│   ├── block_shuffling_64bs_0.001lr/\n",
    "│   └── ...\n",
    "├── run_seed43/\n",
    "│   ├── streaming_64bs_0.001lr/\n",
    "│   └── ...\n",
    "└── run_seed44/\n",
    "    ├── streaming_64bs_0.001lr/\n",
    "    └── ...\n",
    "```"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "57cb98be",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Example: Loading multiple runs for error bars\n",
    "# Uncomment and modify the paths to match your directory structure\n",
    "\n",
    "# Option 1: Multiple run directories (different seeds)\n",
    "# RUN_DIRS = [\n",
    "#     notebook_dir.parent / \"results\" / \"run_seed42\",\n",
    "#     notebook_dir.parent / \"results\" / \"run_seed43\", \n",
    "#     notebook_dir.parent / \"results\" / \"run_seed44\",\n",
    "# ]\n",
    "\n",
    "# Option 2: Auto-discover run directories matching a pattern\n",
    "# RESULTS_BASE = notebook_dir.parent / \"results\"\n",
    "# RUN_DIRS = sorted(RESULTS_BASE.glob(\"run_seed*\"))\n",
    "\n",
    "# Load all runs\n",
    "# results_list = load_multiple_run_results([str(d) for d in RUN_DIRS])\n",
    "# print(f\"Loaded {len(results_list)} runs\")\n",
    "\n",
    "# Create DataFrame with automatic error bars (std across runs)\n",
    "# df_with_errors = create_comparison_dataframe_from_multiple_runs(results_list, metric_name='f1_macro')\n",
    "# display(df_with_errors)\n",
    "\n",
    "# The 'Error' column now contains the standard deviation across runs\n",
    "# plot_comparison(df_with_errors) will automatically show error bars!\n",
    "\n",
    "USE_MULTIPLE_RUNS = False  # Set to True when you have multiple run directories"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "75f4913b",
   "metadata": {},
   "source": [
    "## Load Results\n",
    "\n",
    "Load all experiment results from the results directory:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "756bc11d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded results for 0 strategies:\n"
     ]
    }
   ],
   "source": [
    "# Load experiment results\n",
    "results = load_experiment_results(RESULTS_DIR)\n",
    "\n",
    "print(f\"Loaded results for {len(results)} strategies:\")\n",
    "for strategy in results:\n",
    "    status = results[strategy].get('status', 'unknown')\n",
    "    print(f\"  - {strategy}: {status}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "c40ac342",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "No results to display. Run experiments first.\n"
     ]
    }
   ],
   "source": [
    "# Print results summary table\n",
    "if results:\n",
    "    print_results_table(results, metric_name='f1_macro')\n",
    "else:\n",
    "    print(\"No results to display. Run experiments first.\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3c379088",
   "metadata": {},
   "source": [
    "## Manual Results Entry (Optional)\n",
    "\n",
    "You can manually enter results in two ways:\n",
    "1. **Single run** - Enter one set of results (no error bars)\n",
    "2. **Multiple runs** - Enter results from multiple runs and automatically compute error bars\n",
    "\n",
    "Both methods are shown below. Set the appropriate flag to use your preferred method."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "58710ffe",
   "metadata": {},
   "outputs": [],
   "source": [
    "# =============================================================================\n",
    "# MANUAL MULTI-RUN DATA ENTRY (for automatic error bars)\n",
    "# =============================================================================\n",
    "# Enter results from multiple experiment runs below.\n",
    "# Each run is a dictionary mapping strategy keys to their F1 scores per task.\n",
    "# Error bars (std deviation) will be computed automatically!\n",
    "\n",
    "manual_runs = [\n",
    "    # Run 1\n",
    "    {\n",
    "        'streaming': {\n",
    "            'cell_line': 0.934987,\n",
    "            'drug': 0.002345,\n",
    "            'moa_broad': 0.203723,\n",
    "            'moa_fine': 0.054910,\n",
    "        },\n",
    "        'streaming_buffer': {\n",
    "            'cell_line': 0.934966,\n",
    "            'drug': 0.002066,\n",
    "            'moa_broad': 0.194256,\n",
    "            'moa_fine': 0.054237,\n",
    "        },\n",
    "        'block_shuffling': {\n",
    "            'cell_line': 0.937310,\n",
    "            'drug': 0.029921,\n",
    "            'moa_broad': 0.270052,\n",
    "            'moa_fine': 0.102747,\n",
    "        },\n",
    "        'random_sampling': {\n",
    "            'cell_line': 0.937533,\n",
    "            'drug': 0.029771,\n",
    "            'moa_broad': 0.267968,\n",
    "            'moa_fine': 0.101868,\n",
    "        },\n",
    "    },\n",
    "    # Run 2\n",
    "    {\n",
    "        'streaming': {\n",
    "            'cell_line': 0.934980,\n",
    "            'drug': 0.002302,\n",
    "            'moa_broad': 0.203693,\n",
    "            'moa_fine': 0.054779,\n",
    "        },\n",
    "        'streaming_buffer': {\n",
    "            'cell_line': 0.935011,\n",
    "            'drug': 0.002064,\n",
    "            'moa_broad': 0.194179,\n",
    "            'moa_fine': 0.054187,\n",
    "        },\n",
    "        'block_shuffling': {\n",
    "            'cell_line': 0.937296,\n",
    "            'drug': 0.030829,\n",
    "            'moa_broad': 0.269570,\n",
    "            'moa_fine': 0.103001,\n",
    "        },\n",
    "        'random_sampling': {\n",
    "            'cell_line': 0.937409,\n",
    "            'drug': 0.030055,\n",
    "            'moa_broad': 0.268011,\n",
    "            'moa_fine': 0.104067,\n",
    "        },\n",
    "    },\n",
    "]\n",
    "\n",
    "\n",
    "# Custom display names for manual data\n",
    "# Must match the standard names used in other plots\n",
    "manual_method_names = {\n",
    "    'streaming': 'Streaming',\n",
    "    'streaming_buffer': 'Streaming (buffer)',\n",
    "    'block_shuffling': 'Block size = 16\\nFetch factor = 256',\n",
    "    'random_sampling': 'Random Sampling',\n",
    "}\n",
    "\n",
    "# =============================================================================\n",
    "# SINGLE RUN MANUAL DATA (alternative, no error bars)\n",
    "# =============================================================================\n",
    "# Uncomment to use single-run format instead:\n",
    "\n",
    "# manual_data = [\n",
    "#     # (Task, Method, Macro F1-score, Error)\n",
    "#     ('Cell line', 'Streaming', 0.935, 0.0),\n",
    "#     ('Cell line', 'Streaming (buffer)', 0.936, 0.0),\n",
    "#     ('Cell line', 'Block size = 16\\nFetch factor = 256', 0.937, 0.0),\n",
    "#     ('Cell line', 'Random Sampling', 0.930, 0.0),\n",
    "#     # ... add more rows for Drug, MOA (broad), MOA (fine)\n",
    "# ]\n",
    "# manual_df = pd.DataFrame(manual_data, columns=['Task', 'Method', 'Macro F1-score', 'Error'])\n",
    "\n",
    "# =============================================================================\n",
    "# CONFIGURATION FLAGS\n",
    "# =============================================================================\n",
    "USE_MANUAL_DATA = True  # Set to True to use manual data entry\n",
    "USE_MANUAL_MULTI_RUN = True  # If True, uses manual_runs with auto error bars"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6c6ead1f",
   "metadata": {},
   "source": [
    "## Create Comparison DataFrame\n",
    "\n",
    "Prepare data for plotting:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "1fc4bd5b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Created comparison DataFrame from 2 manual runs\n",
      "Expected: 4 methods × 4 tasks = 16 rows\n",
      "Note: 'Error' column contains std deviation across runs\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Task</th>\n",
       "      <th>Method</th>\n",
       "      <th>Macro F1-score</th>\n",
       "      <th>Error</th>\n",
       "      <th>N_runs</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Cell line</td>\n",
       "      <td>Streaming</td>\n",
       "      <td>0.934983</td>\n",
       "      <td>0.000005</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>Drug</td>\n",
       "      <td>Streaming</td>\n",
       "      <td>0.002324</td>\n",
       "      <td>0.000030</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>MOA (broad)</td>\n",
       "      <td>Streaming</td>\n",
       "      <td>0.203708</td>\n",
       "      <td>0.000021</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>MOA (fine)</td>\n",
       "      <td>Streaming</td>\n",
       "      <td>0.054845</td>\n",
       "      <td>0.000093</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>Cell line</td>\n",
       "      <td>Streaming (buffer)</td>\n",
       "      <td>0.934989</td>\n",
       "      <td>0.000032</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>Drug</td>\n",
       "      <td>Streaming (buffer)</td>\n",
       "      <td>0.002065</td>\n",
       "      <td>0.000001</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>MOA (broad)</td>\n",
       "      <td>Streaming (buffer)</td>\n",
       "      <td>0.194217</td>\n",
       "      <td>0.000054</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>MOA (fine)</td>\n",
       "      <td>Streaming (buffer)</td>\n",
       "      <td>0.054212</td>\n",
       "      <td>0.000035</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>Cell line</td>\n",
       "      <td>Block size = 16\\nFetch factor = 256</td>\n",
       "      <td>0.937303</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>Drug</td>\n",
       "      <td>Block size = 16\\nFetch factor = 256</td>\n",
       "      <td>0.030375</td>\n",
       "      <td>0.000642</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>MOA (broad)</td>\n",
       "      <td>Block size = 16\\nFetch factor = 256</td>\n",
       "      <td>0.269811</td>\n",
       "      <td>0.000341</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>MOA (fine)</td>\n",
       "      <td>Block size = 16\\nFetch factor = 256</td>\n",
       "      <td>0.102874</td>\n",
       "      <td>0.000180</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>Cell line</td>\n",
       "      <td>Random Sampling</td>\n",
       "      <td>0.937471</td>\n",
       "      <td>0.000088</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>Drug</td>\n",
       "      <td>Random Sampling</td>\n",
       "      <td>0.029913</td>\n",
       "      <td>0.000201</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>MOA (broad)</td>\n",
       "      <td>Random Sampling</td>\n",
       "      <td>0.267989</td>\n",
       "      <td>0.000030</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>MOA (fine)</td>\n",
       "      <td>Random Sampling</td>\n",
       "      <td>0.102968</td>\n",
       "      <td>0.001555</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "           Task                               Method  Macro F1-score  \\\n",
       "0     Cell line                            Streaming        0.934983   \n",
       "1          Drug                            Streaming        0.002324   \n",
       "2   MOA (broad)                            Streaming        0.203708   \n",
       "3    MOA (fine)                            Streaming        0.054845   \n",
       "4     Cell line                   Streaming (buffer)        0.934989   \n",
       "5          Drug                   Streaming (buffer)        0.002065   \n",
       "6   MOA (broad)                   Streaming (buffer)        0.194217   \n",
       "7    MOA (fine)                   Streaming (buffer)        0.054212   \n",
       "8     Cell line  Block size = 16\\nFetch factor = 256        0.937303   \n",
       "9          Drug  Block size = 16\\nFetch factor = 256        0.030375   \n",
       "10  MOA (broad)  Block size = 16\\nFetch factor = 256        0.269811   \n",
       "11   MOA (fine)  Block size = 16\\nFetch factor = 256        0.102874   \n",
       "12    Cell line                      Random Sampling        0.937471   \n",
       "13         Drug                      Random Sampling        0.029913   \n",
       "14  MOA (broad)                      Random Sampling        0.267989   \n",
       "15   MOA (fine)                      Random Sampling        0.102968   \n",
       "\n",
       "       Error  N_runs  \n",
       "0   0.000005       2  \n",
       "1   0.000030       2  \n",
       "2   0.000021       2  \n",
       "3   0.000093       2  \n",
       "4   0.000032       2  \n",
       "5   0.000001       2  \n",
       "6   0.000054       2  \n",
       "7   0.000035       2  \n",
       "8   0.000010       2  \n",
       "9   0.000642       2  \n",
       "10  0.000341       2  \n",
       "11  0.000180       2  \n",
       "12  0.000088       2  \n",
       "13  0.000201       2  \n",
       "14  0.000030       2  \n",
       "15  0.001555       2  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Priority order for data sources:\n",
    "# 1. Manual multi-run data (USE_MANUAL_DATA=True, USE_MANUAL_MULTI_RUN=True)\n",
    "# 2. Manual single-run data (USE_MANUAL_DATA=True, USE_MANUAL_MULTI_RUN=False)\n",
    "# 3. Multiple run directories (USE_MULTIPLE_RUNS=True)\n",
    "# 4. Single results directory (default)\n",
    "\n",
    "if USE_MANUAL_DATA and USE_MANUAL_MULTI_RUN:\n",
    "    # Create DataFrame from manually entered multi-run data with auto error bars\n",
    "    df = create_comparison_dataframe_from_manual_runs(\n",
    "        manual_runs,\n",
    "        method_names=manual_method_names\n",
    "    )\n",
    "    print(f\"Created comparison DataFrame from {len(manual_runs)} manual runs\")\n",
    "    print(f\"Expected: {len(manual_runs[0])} methods × 4 tasks = {len(manual_runs[0]) * 4} rows\")\n",
    "    print(\"Note: 'Error' column contains std deviation across runs\")\n",
    "    display(df)\n",
    "\n",
    "elif USE_MANUAL_DATA:\n",
    "    # Use single-run manual data (manual_df)\n",
    "    df = manual_df\n",
    "    print(f\"Using single-run manual data with {len(df)} rows (no error bars)\")\n",
    "    display(df)\n",
    "\n",
    "elif USE_MULTIPLE_RUNS:\n",
    "    # Load from multiple run directories and compute error bars automatically\n",
    "    RUN_DIRS = sorted((notebook_dir.parent / \"results\").glob(\"run_*\"))\n",
    "    results_list = load_multiple_run_results([str(d) for d in RUN_DIRS])\n",
    "    print(f\"Loaded {len(results_list)} runs from {len(RUN_DIRS)} directories\")\n",
    "    \n",
    "    # Create DataFrame with automatic error bars (std across runs)\n",
    "    df = create_comparison_dataframe_from_multiple_runs(results_list, metric_name='f1_macro')\n",
    "    print(f\"Created comparison DataFrame with {len(df)} rows\")\n",
    "    print(\"Note: 'Error' column contains std deviation across runs\")\n",
    "    display(df)\n",
    "    \n",
    "elif results:\n",
    "    # Create DataFrame from single run (no error bars)\n",
    "    df = create_comparison_dataframe(results, metric_name='f1_macro')\n",
    "    print(f\"Created comparison DataFrame with {len(df)} rows (single run, no error bars)\")\n",
    "    display(df)\n",
    "    \n",
    "else:\n",
    "    print(\"No data available. Please either:\")\n",
    "    print(\"  1. Set USE_MANUAL_DATA=True and enter data in manual_runs or manual_df\")\n",
    "    print(\"  2. Set USE_MULTIPLE_RUNS=True and configure RUN_DIRS\")\n",
    "    print(\"  3. Run experiments to generate results in RESULTS_DIR\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6ceff2b7",
   "metadata": {},
   "source": [
    "## Main Comparison Plot\n",
    "\n",
    "Generate the 2x2 comparison plot for all classification tasks:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "51799d1b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Figure saved to: /path/to/scDataset/training_experiments/results/main/comparison_plot.png\n",
      "Figure saved to: /path/to/scDataset/training_experiments/results/main/comparison_plot.pdf\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABWcAAAPWCAYAAACMaCr2AAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQABAABJREFUeJzs3Xl8Ddfj//F3ElmVICKCVKxJkEVKLUXa0FaoLrSoopSq2or40Kou0UU//aA+tXWxxlJULC2xlloqqq2g1tZStX0jiVizSvL7w898XDdBrpvc0Nfz8fCQmTkzc+beSXLyvmfOscvNzc0VAAAAAAAAAKBI2du6AgAAAAAAAADwT0Q4CwAAAAAAAAA2QDgLAAAAAAAAADZAOAsAAAAAAAAANkA4CwAAAAAAAAA2QDgLAAAAAAAAADZAOAsAAAAAAAAANkA4CwAAAAAAAAA2QDgLAAAAAAAAADZQwtYVAADgfubn52eybGdnpxIlSsjFxUXu7u6qVKmSAgIC1KZNG4WEhNimkkXg559/Vvfu3Y3lypUra8OGDTas0d178803tXTpUmM5OjpajRo1MpZvfO/vxevNzc3VypUrtWLFCu3fv18pKSlycHBQ6dKlVaZMGVWrVk21a9dW8+bNFRQUZOvqogB2796t77//Xjt37tSZM2d06dIllShRQhUqVJC/v7+aN2+uiIgIPfDAA7au6n1j4sSJmjRpkrE8ZswYtW/f3oY1AgAAxQXhLAAARSg3N1dZWVnKysrSpUuXdPLkSe3YsUOzZ89WSEiIPv30U1WtWtWq51yyZIneeustY3nAgAEaOHCgVc+B+0taWpr69eunbdu25bktISFBhw4d0urVq3X69GmzcLY4BlHh4eE6deqUsXzo0CEb1sY2EhISNHLkSG3dutVsW1ZWlo4fP67jx49rzZo12rRpk8l7CAAAgMJBOAsAQBFq0aKFXFxcdOnSJR06dEjnzp0ztu3atUvPPfecZsyYcV/3ov2nePLJJ42vy5UrZ8OaFNyECRNMgllnZ2cFBgbK3d1dqampOn78uE6fPm3DGqKg/v77b7344otKSkoyWV+hQgXVrl1bDg4OOnPmjA4fPqycnBzl5OTYqKb3pxo1apj8TKhcubINawMAAIoTwlkAAIrQe++9pypVqki61ov2hx9+0Pvvv6/ExERJ0pUrV9SvXz+tXLlSZcuWtWVVcZc+//xzW1fBIjk5OSbDNVSuXFmLFy82C5hPnz6t9evX6+rVq0VdRRRQVlaWXnvtNZNg9oEHHtCHH36oiIgIk7KJiYn65ptvdPz48aKu5n2tTZs2atOmja2rAQAAiiHCWQAAbMTOzk6tWrVStWrV9Pzzzys1NVWSlJycrOnTp2vYsGFG2V9//VVr167VgQMHdObMGV24cEFXrlyRq6urKlWqpNDQUL344ovy9/c39rl5OIPrJk2aZPK48o3DHMyZM0d79+7VH3/8oeTkZF28eFFXr15V6dKlVb16dYWFhenFF18s8rEoU1JStHDhQm3atElHjx7V5cuX5ebmJh8fHz3yyCPq0qWLvL29zfbbuHGjNm/erIMHDyohIUEXLlxQenq6se/DDz+sl156ST4+Pnme98yZM5o4caI2b96sCxcuqGLFimrdurX69u172zrfaszZvIaa6Ny5s7788ktt2LBBZ8+elbu7u1q0aKHBgwfLy8vL7PjZ2dmaN2+evv32Wx0/flyurq4KCQlR3759lZmZaTLG73PPPadPPvnktnWWpHPnzunChQsm15FXz99KlSqZnEMyH87gurfeesvkeq8Pc3DzWMTPPfec/vWvf2nKlCnauHGjzp49q/r162vOnDnKzMzUrFmzdPDgQf35559KSUkx6unu7q7atWurVatWev755+Xk5GQc8+bhDG68rhvdPMzBwYMH9c033+jXX3/VmTNnlJmZqXLlyikkJESdOnXSI488kufrZ8n7kpqaqkcffdS4Hm9vb/3www9ycHAwOfbMmTNN3sd3331XL730Up71uNGiRYt09OhRY9ne3l5Tp07Vww8/bFbW09NTgwYNUmZmptm2zMxMrVixQqtXr9b+/ft1/vx5OTo6qkKFCnrooYfUuXPnPMcfzmt85vT0dE2bNk379u2Tg4ODHnroIb3xxhsKCAhQbm6u5s+fr0WLFunYsWNydXVVo0aNNGTIEFWrVs3k2Hl9L3Xs2FFTpkzRpk2blJSUJA8PD7Vq1Ur9+/c3u5dPnjypxYsX6+DBgzp27JguXryoS5cuydHRUR4eHqpbt66effZZPfbYY2bXldfwHQEBAZo6dap+/fVXpaSkqF+/fho4cOBth/pISUnR3LlztXnzZh0/flxXrlyRs7OzypYtqypVqqhevXp69NFH1bBhQ7N67NmzRwsXLtRvv/2mhIQEZWVlqUyZMgoICFDr1q3Vrl07k+8JyXwc8Oeee06jRo3StGnTtHr1ap06dUpubm5q1KiR3njjDdWoUcPsvAAAwDoIZwEAsLEaNWro+eefV3R0tLFuxYoVJuFsbGys5s2bZ7bv5cuX9ccff+iPP/7Qt99+q9GjR+v555+3uC7jx483QuIbJScnKzk5Wb/88ou++eYbzZs3L88wtDDExcVpyJAhSklJMVl/8eJF7du3T/v27dOcOXP0wQcfqF27diZlFixYoB9//NHsmDfu+80332jixIlq0aKFSZlDhw7p5ZdfNjnv33//ra+++kobNmyw6mPJv//+u+bOnavz588b65KSkrRkyRL9/PPPWrZsmUqXLm1sy87O1oABA0wC34yMDP3444/avHmzOnToYHFdHB0dTZY3bdqkcePG6YknnlBAQIBKlCi85uPp06fVvn17/d///Z/ZtsuXL2vcuHF57peYmKjExET99NNP+vbbbxUdHa1SpUpZXI/PPvtMX375pXJzc03WJyQkaM2aNVqzZo3at2+vDz/80CRAtfR9cXNz04svvqgvvvhC0rUPBTZs2KDHH3/cpNx3331nss8zzzxzR9ezcuVKk+VHH300z2D2RjeHeadOnVL//v114MABk/VZWVn666+/9NdffykmJkY9evTQm2++KTs7u3yPHR0drfXr15us27hxo+Li4jRnzhxNmzZNa9asMbZlZGRozZo1+vnnn7VkyZJbfu8dPHhQzzzzjMn37f/93/9p7ty52rBhg+bMmWM8vSBJe/fu1dSpU82Ok5WVpdTUVJ04cUKrV69Whw4d9PHHH+d7XknasmWL3n33XWVlZd2y3M3OnTun559/3uxDhKtXr+rKlSs6efKktm/frhMnTpiEs7m5ufrkk080a9Yss2Ne/57YvHmzoqOjNXXqVFWqVCnfOpw4cULPPPOMTp48aazLzMzUmjVrFBcXp6VLl5q8bgAAwHoIZwEAKAbCwsJMwtkzZ87o9OnTJn9M29vby9fXV+XKlVPp0qV19epVnTp1SkeOHJF0LRgaPXq0WrRooQoVKqhy5cp68sknderUKe3du9c4To0aNVSzZk2T5RuVLFlSvr6+cnd3l6urq65cuaKDBw8aweGpU6f0wQcfaMqUKYXxUpg4cuSI+vXrZxIYXx8j8/jx4zpx4oSk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4cOH9dlnnxnLHh4emjZtmurUqWNSLisrS0uXLpWrq6vJ+qSkJEVHR2vTpk36+++/dfXqVVWsWFHNmjXTq6++qkqVKhXJdeTFz8/P+HrMmDFq3769JGnJkiV66623jG2///67pk+frmXLlunUqVMqV66c2rZtqyFDhsjJycnsuBs2bNC3336r33//XefPn5erq6sCAgL0/PPPq127dgz7AAAAcI9p3ry50VaUpCNHjqhPnz46efKkJGnBggVq2bKlWrRoYTYkwtq1a7V+/XotXrxYJ06cUIsWLTRlyhR169ZNO3bskCQ999xz+uSTT4x9bm6PHjp0yKQ+hw4d0meffWbsHxoaqsjISK1fv16TJk2SJFWuXFkbNmyw8isBANcQzgJAEZkzZ46ys7ON5ffff98smJWujcHVsWNHk3Xx8fF6/fXXlZKSYrL+77//1vz58/X999/riy++UIMGDQqn8lbSo0cP/fbbb8ZyQkKCZsyYoeTkZH366afG+pycHL355ptavny5yf5ZWVn6+eef9fPPP+uHH37Q+PHj5eDgUGT1BwAAgHXVqFFDn332mV544QVj3ezZs9WiRQuzsiNHjtSvv/5qtXP//vvv6t69u1JTU411W7Zs0Y4dO4p9uxrA/YNwFgCKyPbt242v3d3d1apVqzva7/Lly+rfv78RzFauXFkRERFycXHRmjVr9Oeff+rSpUsaOHCg1q5dq1KlShVK/a3ht99+0+OPP64aNWro+++/16lTpyRJ33//vSIjI+Xl5SVJmjZtmhHM2tnZ6YknnpC/v79Onjyp7777TllZWVq9erUCAgLUt29fm10PAAAA7l5QUJD8/f118OBBSdIvv/xi0qnhul9//VW1atXSY489ptzc3Lv6kD43N1cjR440CWafeuopValSRatXr9ZPP/1k8bEBoCAIZwGgiCQkJBhf+/r63vFEB0uWLFFycrKka6HukiVLVKZMGUnXxnpt2bKlzp07p3Pnzmnp0qVms+EWJy+//LJGjhwpSYqIiNAzzzwj6VpP2X379snLy0s5OTmaMWOGsU+/fv00aNAgY7l69er6z3/+I0maOXOm+vTpw6QRAAAA97hq1aoZ4WxGRoYuXLhgViYkJETR0dFydna+6/Pt3r1bf/zxh7H86quvatiwYZKkV155RY8//niedQAAayOcBYBibufOncbXFy5cUKNGjfItGx8fX6zD2S5duhhfV6tWzWTbxYsXJUnHjh0zGb5h8uTJmjx5cp7HO3/+vI4dO6YaNWoUQm0BAABQVHJzc29b5pVXXrFKMCtJe/fuNVl+9tlnja/d3d3VsmVLLVmyxCrnAoBboasRABSR64/sS9Jff/11Rw1QSQX6xP7cuXMFrldRqly5svH1zROA5eTkSLoWuBbEzePwAgAA4N7z119/GV87OzsbT4rdqHr16rc9zs1t7MzMzDzLXe8YcF358uVvuQwAhYWeswBQRBo3bmw0Oi9cuKAffvjhjsaddXd3N7729PRUz5498y3r7e191/UsTI6OjsbXdnZ2eZa5uSH+3HPPqVatWvke88bAFwAAAPee33//3RjSQJIaNmyY57BVrq6uee5/Y7syPT3dZNvx48fz3Kd06dImy8nJySbt0KSkpNvWGwCsgXAWAIpI165d9e233xqTG7z//vuqUqWK/P39TcplZWVp2bJlCg8Pl4eHh+rXr69Vq1ZJutZL9JFHHjHbJzc3V3FxcfLx8SmaiylE1apVU5kyZYwetOnp6erVq5dZueTkZO3cubPYB9IAAADI39GjRzV06FCTdbfqjJCXG4PWAwcOKDMzU05OTkpISNDSpUvz3KdevXomyytXrjTmObjekQIAigLhLAAUkVq1aumNN97Q+PHjJUmJiYnq0KGDHn30UQUEBMjOzk5///23tm7dqqSkJKNB2L59e02dOlUpKSm6evWqXnzxRbVu3VpVq1ZVZmamjh07ph07digpKUnR0dH3fEBrb2+vnj176rPPPpMkrVq1SidOnNAjjzyikiVLKjExUXv37tWePXv00EMP6fHHH7dxjQEAAHCntmzZopSUFF2+fFkHDhzQli1bdPXqVWP7Sy+9pGbNmhXomIGBgVq3bp2kaz1l27dvr+rVq+vnn3/Od8iskJAQ1a5d25gUbMqUKTp58qS8vb21evVqJgMDUGQIZwGgCL322mtydXXVf/7zH2VmZurq1atav3691q9fn+8+pUqV0pQpU9SvXz+lpKQoNTX1vp+coE+fPjp69KiWL18u6dqEDTdP2gAAAIB7T2xsrGJjY83WlyhRQv3791ffvn0LfMznn39eM2bMMILYP//8U3/++afs7e3VrFkzbd26Nc/9Pv74Y3Xv3l2pqanKzc012p5OTk5q3Lixtm/fLin/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R48e1eeffy7pWi/a5s2b65133lFUVJSysrL0wQcfqG3btvLy8irQNQIAAKB4Kay2rSS1adNG586d0+eff67ExEQFBARo2rRpxpNhZ86ckb39//pLhIaGauzYsZowYYLGjx8vX19fTZ48WbVr1zbKbNiwQW+99ZaxPGTIEEnSgAEDNHDgQDk6OiouLk7R0dFKTU2Vt7e3nnjiCfXr16/A9QcAAEDhsnhCsNatW+e7PTAwUBs3bizwcQvaeM3IyNCECRN04sQJubm5KSwsTJ9++qlKly5tlElOTtaIESN09uxZlSpVSn5+fpo+fboeeeQRo0yPHj2UmZmpMWPG6MKFC/L399eMGTNMxuMaO3asPvjgA7388suyt7fXE088oVGjRhX4GgEAAFC8FFbb9rquXbua9Hy90Zw5c8zWRUREKCIiIt/jtW/f3ui8kBdvb2/NnTu34BUFAABAkbMonM3MzFRWVtYtt1+fTbKgCtJ4ffjhhxUbG3vL43388cd3dN4+ffqoT58++W4vU6aMySNnAAAAuD8UZtsWAAAAuBWLxpytVauW1q1bl+e23NxcrV271myCLQAAAKA4om0LAAAAW7EonO3atat27typQYMG6dChQ7p69aquXr2qgwcP6o033tCuXbvUrVs3a9cVAAAAsDratgAAALAVi4Y1eOaZZ3TixAlNmTJF69atM8aBzcnJkZ2dnV5//XU999xzVq0oAAAAUBho2wIAAMBWLApnpWuzwT799NNat26dTpw4IUl68MEH1apVK5OJtAAAAIDijrYtAAAAbMHicFa61mDt1auXteoCAAAA2AxtWwAAABQ1i8acBQAAAAAAAADcHYt7zm7atEmzZs3S/v37denSJeXm5pqVOXDgwF1VDgAAACgKtG0BAABgCxb1nF2zZo369u2rpKQktWnTRjk5OWrbtq3atGkjFxcX+fn5qX///tauKwAAAGB1tG0BAABgKxb1nP3yyy8VFBSk+fPn68KFC/rmm2/UoUMHNWnSRCdPnlSnTp1UpUoVa9cVAAAAsDratgAAALAVi3rOHjlyRG3atJGDg4NKlLiW7169elWSVKVKFb344ov6+uuvrVdLAAAAoJDQtgUAAICtWBTOuri4yNHRUZJUunRpOTk5KTEx0dhevnx5nTx50jo1BAAAAAoRbVsAAADYikXhbLVq1XTkyBFjOSAg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dna2SblDhw6pc+fOysjIkJubmyZPnqyaNWsa25966ilVqlRJFSpU0KFDhzR27FgdO3ZMkyZNMsoMGjRIjRs3lqurq7Zu3aqoqCilpqaqe/fuVnwVAAAAcD8oW7asHBwczCb/Sk5ONusde1358uXNesneqnx+x8jKytLFixdNes8mJyfzBBgAAEAxU6zCWUu8/fbbGjVqlCIiImRnZycfHx+1b9/ebJKFatWqadmyZbp06ZLWrFmjESNGaO7cuUZA26lTJ6Osn5+fPD091aNHD/3999968MEHJUn9+/c3ytSpU0dpaWmaPn26xeEsj4ZZD4/5oKC4Z6yPR3zuL0X1mA/3zf2lKO6be6nnppOTk+rWrau4uDi1atVKkpSTk6O4uDh17do1z31CQkK0fft2k3Fnt23bVqBxYuvVqydHR0fFxcXpySeflCQdPXpUp0+fZrxZAACAYqZYhbOW9C4oV66cpkyZooyMDJ0/f14VKlTQ2LFj5ePjY1LOyclJVatWlXStwfr7778rOjpao0ePzvO4wcHBkqTjx48b4WxeZaZMmaLMzEyzoRXuBI+GWQ+P+aCguGeAWyMwhSW4b8z17NlTI0aMUL169RQUFKTZs2crLS1N7du3lyQNHz5cXl5eioyMlCR1795d3bp104wZMxQWFqbY2Fjt3bvXpM16/vx5nTlzRmfPnpUkHTt2TNK1HrOenp4qVaqUOnTooE8++UTu7u564IEH9OGHH6p+/fqEswAAAMVMsQpnLeldcJ2zs7O8vLyUlZWltWvXKiIi4pblc3JylJmZme/2AwcOSNItH/06cOCA3N3dLQpmAQAAcP9r06aNzp07p88//1yJiYkKCAjQtGnTjI4HZ86ckb29vVE+NDRUY8eO1YQJEzR+/Hj5+vpq8uTJql27tlFmw4YNeuutt4zlIUOGSJIGDBiggQMHSpJGjhwpe3t7DRo0SJmZmWrWrJnee++9orhkAAAAFECxCmelgvcu2L17txISEhQQEKCEhARNnDhROTk56t27t3HMcePGqUWLFvL29taVK1e0YsUK7dixQ9OnT5ck/f333/r+++8VFhamMmXK6NChQxozZowaNmwof39/SdcawcnJyQoODpazs7N++uknffnll3rllVeK+BUCAADAvaRr1675djSYM2eO2bqIiIhbdjRo37690TbOj7Ozs9577z0C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rJkiIyOttsXHx1sVZ995551sz1e5cmWtWrUql9GisLib+yY+Pt4yJUE67hsAAAAAAFCQmHMWAAAAAAAAAExAcRYAAAAAAAAATEBxFgAAAAAAAABMQHEWAAAAAAAAAExAcRYAAADIR6tXr1bbtm3l7e2t3r17a//+/dm237Rpkx577DF5e3urW7du+vbbb632G4ah999/XwEBAfLx8dGgQYN04sQJqzZt27aVu7u71deiRYvy+tIAAABwlyjOAgAAAPkkMjJS06ZN06hRoxQRESEPDw8FBQUpLi4u0/Z79+7VuHHj9MQTT2jDhg1q166dRo0apaNHj1raLF68WCtXrtTkyZO1du1aOTo6KigoSNevX7fqa8yYMdqxY4flKzAwMF+vFQAAADlHcRYAAADIJ8uWLVOfPn3Uq1cv1a1bV1OmTJGDg4PCw8MzbR8WFqaWLVtqyJAhqlOnjsaOHav69etr1apVkm6Mmg0LC9OIESPUvn17eXh4aMaMGTp37py2bNli1VfJkiXl4uJi+XJycsr36wUAAEDOUJwFAAAA8kFSUpIOHjwof39/yzZbW1v5+/srOjo602P27dunFi1aWG0LCAjQvn37JEl//vmnYmNjrfosXbq0GjZsmKHPxYsXq3nz5urRo4dCQ0OVkpKSR1cGAACAvFLM7AAys3r1ai1ZskSxsbHy8PDQpEmT5OPjk2nb5ORkffTRR9qwYYPOnj2rBx98UOPHj1erVq0sbf773//q448/1l9//SVJqlevnkaOHKnWrVtb2vTv318//vijVd99+/bVm2++aXl9+vRpTZ48Wbt27ZKTk5N69OihcePGqVixQvljBAAAgIkuXryo1NRUVaxY0Wp7xYoVdezYsUyPOX/+vJydnTO0P3/+vCQpNjbWsi2rNtKN3LZ+/foqW7asoqOjNXv2bMXGxurll1/O9fUYhqFr167l+njckJiYKElKSEiQYRgmR4N7BfdN3rO1tZWjo6PZYSAPJCQkKC0trUDOxX1TdBTUfVOyZMnbtil0VcX0ebmmTJmihg0basWKFQoKCtLmzZszJKGSNHfuXH322WeaOnWqateure3bt2v06NFas2aN6tevL0l64IEHNH78eNWsWVOGYWjDhg2Web/q1atn6atPnz4aM2aM5fXN/+BSU1M1bNgwOTs7a82aNTp37pyCg4NVvHhxvfji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me6vU6eOvvzyS8un5tKNedNKliypBx54QBUrVpSDg4N27typ6tWrZ3mep556SvXq1dPIkSP10Ucf3fa669evr/r162vYsGHq27evPv/880yT3OjoaL322mt68803M+z38vLSl19+qapVq2b6h1ZmXF1dLfPfZeXW+y2nGjVqpM2bN+vatWuWT6uPHz8uW1tbPfDAA3fVd27Z2tpq2LBhmj59urp16yYHBwft3btX7dq1U/fu3SXdSKJOnDiR6Xx5WalTp47+/vtvnTt3zjKKZN++fRnaREREKD4+3jICYe/evbK1tS2Q0WQ3/549ePCgDMPQxIkTLX8Qb9q0Kc/O9fPPP2d4nZOf5+08+OCD+uWXX6x+//3yyy951j+Q38hb723kreSt+Y281dr9mrdK5K7krvmHBcFwVy5evKgBAwbo008/1eHDh3Xq1Clt2rRJoaGhateunaQbj+hERUUpNjY2209u/f395evrq1GjRmnHjh36888/tXfvXs2ZM8fyD6VmzZr66quvdOjQIR0+fFjjxo0z5dOPUqVKqUePHpoxY4Z27typ3377Ta+++qrlf9z3ijt5/yTew5vVr19f5cuX1969ezPs27x5s9atW6fjx48rJCRE+/fvV2BgoCSpRo0aqly5subNm6cTJ05o27ZtWrp0aa5if/bZZxUdHa0333xThw4d0okTJ7Rlyxa9+eabtz02ISFBBw8eVEBAQK7OnVtJSUmKjY1VbGysYmJi9NZbb1k+qc9Mv3799Pfff+utt95STEyMtmzZonnz5mnw4MGytbVViRIl9Oyzz+q9997Thg0bdPLkSe3bt0+ffPJJhr769++v559/XsOGDdPu3bszPd+pU6c0a9YsRUdH66+//tKOHTt04sQJ1a5dO0Pb2NhYjR49Wl26dFFAQIDlutIfx+nXr58uX76sF198Ufv379fJkye1fft2vfzyy1n+sZj+eFh2X1ktQpHu999/16FDh3Tp0iVdvXpVhw4dsno8sWvXripXrpxefvll/f777/rpp5/03nvvqVevXgX6aNitHnvsMdna2mr16tWSbvyO+OGHH7R3717FxMTo9ddf1/nz53PUp7+/v2rVqqWJEyfq8OHD2r17t+bMmWPVplu3brK3t9fEiRN19OhR7dy5U2+99Za6d++e6QIduXUnv2dr1qyp5ORkrVy5UqdOndKG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V/OvNWvWWL7v0qVLrvrIqcI8OuFWFSpU0EMPPSRJunDhgv7v//7P5IgAAADyzv2a4/7111+W7729vTV+/HgFBQVZisGtWrVSUFCQgoKC1Llz51zFkFdujv9///ufiZEAKAgUZwEgE7a2N349hoeHKz4+3rJ91apVlkeL0h83ulVaWpomTZpk+WTezs5Oy5Yt05w5czRixAi98sorioyMlIeHh+WY1atX6+eff87Q16effqrU1FRJkpOTk1XCGxERkePr2rNnj06cOCFJqlSpkho2bHjbYyIjI9WzZ081bNhQLVq00Msvv6zz589btbn1kbk//vhDS5YsUadOndSgQQNNmDDB0jY1NVXr1q3TwIED1bx5c3l5eal58+bq37+/1q5dq5SUlAwxhIaGauTIkerYsaOaNWsmLy8vNWnSRE888YQ+/PBDq/foZl999ZWeeOIJ+fj4yN/fX6+88ori4uJue80dO3a0fB8eHn7b9gAAAPeC+zHHXb9+vdzd3a1G6u7ZsyfD1A3ZzTl7c567fv16ff/99+rfv7/8/Pzk5+enIUOG6Lfffss0tlOnTmnq1Knq1KmTfH195ePjo86dO2vmzJm6cOFCpse0adNGxYsXlyT98MMPOnPmTI5/JgDuHRRnASATbdu2lSRdvXrVkiD+888/lu/r16+vBx54INNjf/rpJx07dszyukuXLmrevLlVm9KlS+ull16y2nbzp/3pbk5O27Zta/Up/meffZZpITM733//veV7X19f2djYZNt+6dKleuGFF3Tw4EElJibqwoULWr9+vZ588sksk0lJeuWVVzRjxgwdO3bMksBLUnx8vAYOHKhXX31VO3fu1KVLl5SSkqJLly7pxx9/1KRJkzRgwABdu3bNqr/Fixfr66+/1okTJ3T58mWlpKTo6tWr+uWXXzR37lz17ds3wzEff/yxRo8erV9++UXXr19XXFycwsPD1adPn2xjT//ZpNu9ezcLgwEAgCKBHPfuffLJJwoKCtKPP/6o+Ph4xcfHa/v27QoMDMyQY27ZskXdunXTypUrdezYMSUkJOj69euKiYnR4sWL1aNHD8XExGQ4R8mSJeXm5ibpRlE8Kioq364HgPkozgJAJrp166by5ctLuvGJv3RjhEF6ATC7FVx3795t9fqxxx7LtF1AQIDKlCmT5XH79+/X77//bnndpUsXq0eczp8/n+MVXG8+R4MGDW7bftu2bWrevLlGjRqlFi1aWLafOnVK7733XrbnqVevnoYOHapnn33WMn/X1KlT9dNPP1naBQQEaPTo0QoICLBs27Nnj6ZOnWrV3wMPPKCOHTvqmWee0dixY/X888+rV69ecnJykiTL3Gbp/v77b02bNs3yumTJkho4cKAGDx6sK1euWP1cM1OnTh1L30lJSdq/f3+27QEAAO4F92OO6+3trQkTJlhtr169uiZMmKAJEybkeAqDvXv36sEHH9Tw4cPVunVry/ZLly5p3bp1ltenTp3SuHHjlJCQIEmqV6+eRowYoeHDh6tq1aqSpLNnz+q5556zjCK+Ne7Mrg9A0cOCYACQiRIlSqhv375auHChYmJitH37dksCW6FCBXXt2lXz58/P9Nj0hQjSpSdfmalSpYquXLmS6XE3P3pVtmxZBQQEyN7eXjVq1NDJkycl3Rh1kD4C4k6cOnXK8v2dLHQQEBCg0NBQ2djYyDAMDRkyxDI/2MaNG/X666/L0dExw3G+vr4KCwuzLLAgSRcvXtSGDRssrzt16qS5c+daXo8dO1abNm2SdONRtwkTJlj+ePj000919epV7d27V2fOnFFCQoLq1KkjLy8vS7F3x44devbZZyXdGHFx/fp1S98LFiywFJc7dOigp556KtvrtrOzk4uLi/744w9J0smTJ9WkSZPb/rwAAAAKs/sxx61Xr57q1aun3377TQcOHLC0CQoKuuP+b1a5cmV98sknlgXHHn/8cf3666+SpF9++cXSbtWqVUpMTJQk1apVS+Hh4Zbc+Omnn9Yjjzyi1NRUxcTEaNu2bWrXrp3VeW4ewXzz9QEoehg5CwBZ6Nevn2V12VdffdVSqOvTp4/s7e3z9dxJSUmKjIy0vH700Uct57z50/1vvvlGFy9evON+b37UqmzZsrdt361bN8tjYTY2NurWrZtlX3JycpYLNjzzzDNWhVnpxiiJm0cFPP7441b7b36dmppqGa2alpamGTNmqEWLFho6dKjeeOMNTZ8+XTNmzLAahfv3339bvk9PvCXJ2dnZatRvo0aNVK1atdtee7ly5Szf324aBAAAgHsFOe7d6d69u6UwK90ovKa7fPmy5fu9e/davj9x4oR8fHws89a2bNnSKi+Ojo7OcB5yUeD+QXEWALJQqVIldejQQdKNR44kqXjx4urXr1+2x7m4uFi9vnll2FudPn060+O2bNlildzd/KjXzd8nJydr48aN2cZzNypWrJjt6/QREbeqXbt2hm03X09O+g4LC9OSJUus5q7NzM37b46rQoUKGdo6Oztn25cky6IYAAAARQk57t25dcTwzQXtm/PHW3Pf7GRWfCUXBe4fTGsAANkYMGCA1af7HTp0UKVKlbI95tbH37/88ssMjylJNxYuuLmIePNxNz/uJUmDBw/O8nwREREaMGBAtjGlK1++vGW116wKqzeLi4vL9vXN84ndLLOpDm4dxXCnfadPdSBJrq6uWrBggTw8PGRvb68ZM2ZoyZIlGc51c1yZJbvnz5/PNO6b3ZxQZ1bgBQAAuFfd7znu3UgfdZwuq8XHbs5969Wrl+GpsZulr89wM3JR4P7ByFkAyIafn5/VZPzZLZKQrmnTplYjR7/44osMk/j/888/mjlzptW2vn37SroxguGHH3644xh//fVXHT58+I7aVq9e3fJ9egKbnY0bN1o+tTcMw2oEQ/HixS2ryN4JHx8f2dnZWV7fvErvra/t7Ozk4+Mj6cbiCukaNGggHx8f2dvb6/r16/rmm28yPdfNCz6cP3/eaoXbvXv36s8//8w21tTUVJ07d87y+uafGwAAwL3ufs9xC4Kfn5/l+9jYWHXt2lVBQUFWXwMHDlSNGjXUsGHDDMfffB13MiUXgHsXI2cB4DbeffddHT9+XMWKFbNKsrJia2urN998U4MHD1ZycrJSUlI0cOBAdezYUW5ubrp48aI2bdpkeYxMurEogK+vr6Qbi1/dPAdVmzZtMoxETUtL0+bNmy2v169fr1deeeW2sTVq1Eg//vijJFkWLsjOjh07NHDgQDVt2lR79uyxKnJ269Yt0xGyWSlfvrwef/xxyyq2mzZt0tWrV+Xr66t9+/ZZFhqTbszllb4Y2IMPPqgTJ05IkrZt26bXX39dzs7O+vLLL3Xs2LFMz9WtWzfNmzdPSUlJkqRRo0apd+/esrGxUXh4+G1jjYmJsaysW7x4cUuhGAAAoKi4n3PcgtC/f3+tWbNG169f16VLl9S9e3c99thjqly5suLj4/X777/rxx9/1JUrV/T1119neMrs5jUUWJgWKNoozgLAbdSpU0d16tTJ0TFNmzbVggULNGHCBF26dEkpKSn64osv9MUXX2RoO2DAAAUHB1te3zyCtFatWlq4cGGm53j66actoxU+//xzTZgwIcNjVrfy9/e39Ldv377bXkezZs20a9cu7dq1y2p71apVNX78+Nsef6v0RSfSF/LasWOHVVFWupFcv/baa5bXQ4YM0fbt25WSkqK0tDT973//kyQ5OTmpQ4cO+r//+78M56lcubImTpyoN998U5J07do1LV++XNKNqREqVKhgKfhm5uafTZMmTTIsbgYAAHCvu59z3IJQvXp1zZ49Wy+99JLi4+N18eJFffzxx3d07LVr1ywL79rY2Fgtbgug6GFaAwDIJ61bt9ZXX32ll156Sc2aNVOFChVUrFgxlSxZUvXq1dNTTz2lTz/9VK+++qol4dy3b5/VaNCePXtm2f/N++Li4rRt27bbxtSsWTPVqFFD0o2FGvbv359t+9GjR+vdd99V/fr1VaJECZUrV06PP/641qxZk2EBrzvh5OSk5cuXa+rUqWrevLnKlSunYsWKqWzZsmrWrJnefPNNrVy5UiVLlrQc06RJE4WGhsrPz0/29vYqXbq0WrdurTVr1mQ7rcLTTz+tkJAQeXl5yd7eXuXLl1f37t31ySefyNXVNds4v/zyS8v3vXr1yvF1AgAAFFVFIcctKO3bt9fGjRs1ePBgubm5ycnJSXZ2dipXrpz8/PwUFBSkjz/+OMO0Bd98841lsVt/f39VqVLFjPABFBAbgyUAAeC+Ehoaqvfee0/SjUUYJk6caHJEhcuFCxfUsmVLpaSkqHz58vr2228ZOQsAAFDIFaUcd8SIEdq6daskKSQkRB07djQ5IgD5iZGzAHCf6devn1xcXCRJ4eHh+ueff0yOqHBZvXq1UlJSJEnDhw+nMAsAAHAPKCo57smTJ/Xtt99Kkjw9PdWhQweTIwKQ3yjOAsB9xsnJSSNHjpQkXblyxTKHK6TExEStXr1aklSlShX169fP5IgAAABwJ4pKjrts2TLLwmkvvviibGxsTI4IQH5jWgMAAAAAAAAAMAEjZwEAAAAAAADABBRnAQAAAAAAAMAEFGcBAAAAAAAAwAQUZ01y5MgRHTlyxOwwAAAAgNsidwUAAMgfFGdNkpSUpKSkJLPDKDKuX7+uPXv26Pr162aHgnsE9wxyg/sGucF9g6KA3DXv8DsBucF9g9zgvkFOcc+Yo8gWZ1evXq22bdvK29tbvXv31v79+7Nsu3btWvXr109NmzZV06ZNNWjQoAztr127pjfffFOtWrWSj4+POnfurI8//ji/LwN3KDU11eq/wO1wzyA3uG+QG9w3AG7G7wTkBvcNcoP7BjnFPWOOIlmcjYyM1LRp0zRq1ChFRETIw8NDQUFBiouLy7T9rl271KVLF4WFhWnNmjWqXLmynnnmGZ09e9bSZvr06dq+fbvee+89RUZGauDAgXrrrbf09ddfF9RlAQAAAAAAAChCimRxdtmyZerTp4969eqlunXrasqUKXJwcFB4eHim7WfNmqWnn35anp6eqlOnjqZOnaq0tDRFRUVZ2kRHR6tHjx5q3ry5qlWrpr59+8rDwyPbEbkAAAAAAAAAkJUiV5xNSkrSwYMH5e/vb9lma2srf39/RUdH31EfCQkJSklJUdmyZS3b/Pz8tHXrVp09e1aGYWjnzp06fvy4AgIC8vwaAAAAAAAAABR9xcwOIK9dvHhRqampqlixotX2ihUr6tixY3fUx8yZM+Xq6mpV4J00aZImTZqkVq1aqVixYrKxsdHUqVPVtGnTPI0fAAAAAAAAwP2hyBVn79aiRYsUGRmpsLAwlShRwrJ95cqV2rdvnz788ENVqVJFu3fv1pQpUzIUcXPCMAxdu3Ytr0K/ryUmJkq6MerZMAyTo8G9gHsGucF9g9zgvslbJUuWNDsEAAAAIM8UueJs+fLlZWdnl2Hxr7i4ODk7O2d77JIlS7Ro0SItW7ZMHh4elu2JiYmaM2eO5s+fr0ceeUSS5OHhoUOHDmnJkiW5Ls7a2NjwB0YesbGxkSQ5OjrKycnJ5GhwL+CeQW5w3yA3uG9wO6tXr9aSJUsUGxsrDw8PTZo0ST4+Ppm2/e233xQSEqKDBw/qr7/+0ssvv6xBgwZZtfnpp5+0ZMkSHThwQLGxsVqwYIHat29fAFcCAACAnCpyc87a29vLy8vLajGv9MW9/Pz8sjxu8eLF+uCDDxQaGipvb2+rfSkpKUpOTrb8cZXOzs6OETAAAADItcjISE2bNk2jRo1SRESEPDw8FBQUlGGgQbqEhARVq1ZN48aNk4uLS6Zt4uPj5e7urjfeeCM/QwcAAEAeKHIjZyVp8ODBCg4OVoMGDeTj46MVK1YoISFBPXv2lCRNmDBBlSpV0rhx4yTdmMogJCREs2bNUtWqVRUbGytJcnJyUsmSJVWqVCk1a9ZM7733nhwcHFSlShX99NNP2rBhgyZOnGjadQIAAODetmzZMvXp00e9evWSJE2ZMkXbtm1TeHi4hg4dmqG9j4+PZVTtrFmzMu2zdevWat26df4FDQAAgDxTJIuznTt31oULFxQSEqLY2Fh5enoqNDTUMq3BmTNnZGv776DhNWvWKDk5WWPGjLHqZ/To0XruueckSbNnz9bs2bM1fvx4Xb58WVWqVNELL7ygp556quAuDAAAAEVGUlKSDh48qGHDhlm22drayt/fX9HR0SZGBgAAgIJSJIuzkhQYGKjAwMBM961cudLq9datW2/bn4uLi6ZNm5YnsQEAAAAXL15UamqqKlasaLW9YsWKOnbsmElRAQAAoCAV2eIsAAAAgLxjGIauXbtmdhj3vMTEREk35g9m/QrcKe4b5Ab3DXKKeybvlSxZ8rZtKM4CAAAAJihfvrzs7OwyLP4VFxdnmY6rMLGxsbmjPzCQvfRFhh0dHeXk5GRyNLhXcN8gN7hvkFPcM+awvX0TAAAAAHnN3t5eXl5eioqKsmxLS0tTVFSU/Pz8TIwMAAAABYWRswAAAIBJBg8erODgYDVo0EA+Pj5asWKFEhIS1LNnT0nShAkTVKlSJY0bN07SjUXEYmJiLN+fPXtWhw4dkpOTk2rWrClJunbtmk6ePGk5x59//qlDhw6pbNmyqlKlSgFfIQAAALJDcRYAAAAwSefOnXXhwgWFhIQoNjZWnp6eCg0NtUxrcObMGdna/vuw27lz59SjRw/L66VLl2rp0qVq1qyZZdHbAwcOaMCAAZY26YvaPv7445o+fXoBXBUAAADuFMVZAAAAwESBgYEKDAzMdF96wTVdtWrVdOTIkWz7a968+W3bAAAAoHCgOAsAuG+sXr1aS5YsUWxsrDw8PDRp0iT5+Phk2nbt2rXasGGDfvvtN0mSl5eXRo4cKTs7O0sbd3f3TI996aWXNGTIEEnSpUuX9NZbb+mbb76Rra2tOnTooFdffZVFdQAAAAAALAgGALg/REZGatq0aRo1apQiIiLk4eGhoKCgDKukp9u1a5e6dOmisLAwrVmzRpUrV9aIESN04cIFS5sdO3ZYfb3zzjuysbFRx44dLW3Gjx+v33//XcuWLdPChQu1e/duvf766/l+vQAAAACAwo/iLADgvrBs2TL16dNHvXr1Ut26dTVlyhQ5ODgoPDw80/azZs3S008/LU9PT9WpU0dTp06VYRg6cOCApY2Li4vV19dff63mzZurevXqkqSYmBht375dU6dOVcOGDdWkSRO99tpr+uKLL3T27NkCuW4AAAAAQOFFcRYAUOQlJSXp4MGD8vf3t2yztbWVv7+/oqOj76iPhIQEpaSkqFSpUpnuP3/+vL799ls98cQTlm3R0dEqU6aMvL29Ldv8/f1la2ur/fv35/JqAAAAAABFBcVZAECRd/HiRaWmpqpixYpW2ytWrKjz58/fUR8zZ86Ui4uLGjRokOn+iIgIlSxZUh06dLBsO3/+vCpUqGDVrlixYipbtqxiY2NzeBUAAAAAgKKGBcEAALiNRYsWKTIyUosWLVJqamqmbcLDw9WtWzeVKFGigKMDAAAAANyrGDkLACjyypcvLzs7uwyLf8XFxcnZ2TnbY5csWaJFixZpyZIlcnNzy7TN7t27dfz4cfXu3dtqu7Ozs9UCYpKUkpKiy5cvy8XFJRdXAgAAAAAoSijOAgCKPHt7e3l5eSkqKsqyLS0tTVFRUfLz88vyuMWLF+uDDz5QaGio1byxt1q3bp28vLzk4eFhtd3Pz09XrlyxWkRs586dSktLk4+Pz11cEQrS6tWr1bZtW3l7e6t3797Zzhe8du1a9evXT02bNlXTpk01aNAgq/c/XUxMjIYPH67GjRvL19dXvXr10unTpy37Y2Nj9dJLL+nhhx+Wr6+vHn/8cX355Zf5cn0AAAAoOnKSu/7222967rnn1LZtW7m7u2v16tW56vP1119X+/bt5ePjo4ceekgjRoxQTExMnl5XUUZxFgBwXxg8eLDWrl2riIgIxcTEaPLkyUpISFDPnj0lSRMmTNCsWbMs7RctWqT3339f77zzjqpWrarY2FidP39eiYmJVv3+888/2rx5c4ZRs5JUp04dtWzZUpMmTdL+/fu1Z88evfXWW+rSpYsqVaqUvxeMPBEZGalp06Zp1KhRioiIkIeHh4KCgjKMwk63a9cudenSRWFhYVqzZo0qV66sESNGWI2gPnnypPr166fatWtr5cqV+uyzzzRy5EirKTGCg4N1/Phxffjhh9q4caMeffRRjR07Vr/++mu+XzMAACgc7qbItnz58lz1SZHt3pbT3DUhIUHVqlXTuHHjsnyy70769PLy0rRp0xQZGaklS5bIMAwFBQVlOSUcrFGcBQDcFzp37qzg4GCFhISoe/fuOnTokEJDQy3TGpw5c8Zqka41a9YoOTlZY8aMUUBAgAICAvToo4/q888/t+r3iy++kGEY6tq1a6bnnTlzpmrXrq2BAwdq6NChatSokd588838u1DkqWXLlqlPnz7q1auX6tatqylTpsjBwUHh4eGZtp81a5aefvppeXp6qk6dOpo6daoMw7AaPTtnzhy1atVKEyZMUP369VWjRg21a9fOasG66OhoBQYGysfHR9WrV9fIkSNVpkwZHTx4MN+vGQAAmI8iG3Ijp7mrj4+PgoOD1aVLF9nb2+e6z759+6pp06aqVq2avLy8NHbsWJ05c0Z//fVXvlxnUcOCYACA+0ZgYKACAwMz3bdy5Uqr11u3bs3QJj4+XocOHbLa1rdvX/Xt2zfLc5YrV85qRC7uHUlJSTp48KCGDRtm2WZrayt/f39FR0ffUR8JCQlKSUlRqVKlJN2YTmPbtm0aMmSIgoKC9Ouvv6patWoaNmyY2rdvbznOz89PmzZt0iOPPKIyZcpo06ZNun79upo1a5a3FwkAAAqlmwtikjRlyhRt27ZN4eHhGjp0aIb2Pj4+lmmzsso976TPm/PaatWqaezYserevbv++usv1ahRI0+vEXkrL3LXvOgzPj5e69evV7Vq1fTAAw/k6rz3G0bOAgAAZOLixYtKTU21GtEqSRUrVtT58+fvqI+ZM2fKxcVFDRo0kHRjEbr4+HgtXrxYLVu21NKlS/Xoo49q9OjR+vHHHy3HzZ07VykpKWrevLm8vb31+uuva/78+apZs2beXSAAACiU0gti/v7+lm15VWTLSZ8U2e4teZG73k2fq1evlp+fn/z8/PTdd99p2bJlWY7GhTWKswAAAPlg0aJFioyM1KxZsyyJaVpamiSpXbt2GjRokDw9PTV06FA98sgjWrNmjeXY999/X1euXNHy5csVHh6uwYMHa+zYsTpy5Igp1wIAAAoORTbci/7zn/8oIiJCq1atUq1atTR27Fhdv37d7LDuCRRnAQAAMlG+fHnZ2dllmNstLi7OMldxVpYsWaJFixZpyZIlcnNzs+qzWLFiqlOnjlX7OnXq6PTp05JuLBi2atUqvfPOO2rRooU8PDw0evRoNWjQIMsVdAEAAPIKRbZ7093krnnRZ+nSpVWrVi01bdpUISEhOnbsmL766qtcnfd+Q3EWAAAgE/b29vLy8lJUVJRlW1pamqKiouTn55flcYsXL9YHH3yg0NBQeXt7Z+jT29tbx48ft9p+4sQJVa1aVdKNeWqlG48a3szOzk6GYdzVNQEAgMKPIhtyI7e5a371aRiGkpKScnXe+w3FWQAAgCwMHjxYa9euVUREhGJiYjR58mQlJCSoZ8+ekqQJEyZYLbqxaNEivf/++3rnnXdUtWpVxcbG6vz580pMTLS0CQoK0qZNm7R27Vr98ccfWrVqlb755hs99dRTkqTatWurZs2aev3117V//36dPHlSS5cu1ffff2+1aBgAACiaKLIht3KauyYlJenQoUM6dOiQkpKSdO7cOZ04cUInT5684z5PnTqljz76SAcOHNDp06e1d+9ejRkzRg4ODmrdunXB/gDuUcXMDgAAAKCw6ty5sy5cuKCQkBDFxsbK09NToaGhlhEmZ86csRrhumbNGiUnJ2vMmDFW/fTs2dPyh8+jjz6qyZMna9GiRZo6daoefPBBhYSEqEmTJpKk4sWLa9GiRZo1a5aGDx+u+Ph41ahRQ9OnTyfBBQDgPjF48GAFBwerQYMG8vHx0YoVKzIU2SpVqqRx48ZJulFki4mJsXx/9uxZHTlyRH///bc8PT3vqM9Tp04pMjJSDz/8sCpUqKC///5bixYtosh2D8lp7nru3Dn16NHD8josLEyS1LhxY/33v/+9oz7t7e21e/durVixQleuXFHFihXVpEkTffzxxxnmOEbmbAyejzPFL7/8IkkZHndE7sTHx+vQoUPy9PSUk5OT2eHgHsA9g9zgvkFucN+gKCB3zTv8TkBucN/cn1atWqUlS5ZYCmKvvfaaGjZsKEnq37+/qlatqunTp0uS/vzzT7Vr1y5DH56envrvf/9ruW+y6/Ps2bN67bXXdPDgQasi26hRo1S7du0CumqYid815mDkLAAAAAAAQCETGBiowMDATPetXLnS6nW1atV05MgRq23phbY77bNSpUpavHjxXUQMIDeYcxYAAAAAAAAATEBxFgAAAAAAAABMQHEWAAAAAAAAAExAcRYAAAAAAAAATMCCYAAA3OLs2bM6d+5chu2JiYk6fvy40tLS5ODgkGG/q6urKlWqVBAhAgAAAECu8PdO4UJxFgCAW6xatUqzZ8/O8XEvvviixo0blw8RAQAAAEDe4O+dwoXiLAAgz6SmpcrO1s7sMO5aYGCgOnToYLUtMTFRPXr0kCRt2LAhy0+Si4Ki8j4CAAAAyOh2f++sWbNG5cqVy3BcUfl7p7ChOAsAyDN2tnaa+N1EHbt8zOxQ7krS5SQlXU6y2paWlGb5ftKOSbK1zzhtu31Ze9mXtc/3+PJT7bK1Nb3VdLPDAAAAAJBPKlWqlGF6gvj4eMv3np6ecnZ2Luiw7lsUZwEAeerY5WM6dOGQ2WHclfgt8Urcmpjl/l9m/pLpdoe2DnJq75RfYQEAAAAAihiKswAA3MKhmYPsPXM+Ata2dMbRtAAAAAAAZIXiLAAAt7AtYyvbMhRaAQAAAAD5i788AQAAAAAAAMAEjJwFAADIAwcOHNDRo0czbE9KSlJsbKx+++032dtnnC7Dzc1NDRo0KIgQAQBAEXT27FmdO3cuw/bExEQdP35caWlpcnBwyLDf1dU1w6JQAAoexVkAAGAqIzVVNnZ2Zodx19544w3t3Lkzx8c99NBDCg8Pz4eIClZReR8BALjXrFq1SrNnz87xcS+++KLGjRuXDxHhXmdjY2N2CPcVirMAAMBUNnZ2+mv8S0o6dszsUO7K0GvX1KFO3RwfV+ufazres1c+RFRw7GvXVtWZ75kdBgAAOZKalio723v/g8WOHTvqwQcftNqWlJRkKbzOmjUry6d37nVmvIf3wwfSjo6OZoeQrwrbe0hxFgAAmC7p2DEl/vqr2WHclRr//ys3EvMyEAAAcEfsbO008buJOnb53v6A+OTGkzr1xaks92c1OrZ6l+qq0S232Yv5apetremtphf4eYvKwIJbJaSmWr4/8VQ/ORai4mVeKoyDCijOAgAAAACA+9Kxy8d06MIhs8O4K2neaSpTq0yOj7ta+uo9f+1mKQoDC26VaBj/fn/4MFMbFCCKswAAAAAAAPco2zK2si1ja3YYAHKJf70AAAAAAAAAYAKKswAAAAAAAABgAoqzAAAAAAAAAGAC5pwFAAAAAAAA7hNxaWm6cNMCYJL1gmC/p6bKIZMFwSrY2KiiLeM88xrFWQAAAAAAAOA+8XlyklYmJWW5/4WE+Ey397e318ASDvkV1n2L4iwAAAAAAABwn+ha3F7+xYrn+LgKmYymxd2jOAsAAAAAAADcJyra2qqi2UHAgokiAAAAAAAAAMAEFGcBAAAAk61evVpt27aVt7e3evfurf3792fZ9rffftNzzz2ntm3byt3dXcuXL7/rPgEAAGAOirMAAACAiSIjIzVt2jSNGjVKERER8vDwUFBQkOLi4jJtn5CQoGrVqmncuHFycXHJkz4BAABgDoqzAAAAgImWLVumPn36qFevXqpbt66mTJkiBwcHhYeHZ9rex8dHwcHB6tKli+zt7fOkTwAAAJiD4iwAAABgkqSkJB08eFD+/v6Wbba2tvL391d0dHSh6RMAAAD5o5jZAQAAAAD3q4sXLyo1NVUVK1qvmVyxYkUdO3as0PQpSYZh6Nq1a7k+HjckJiZKujE9hWEYJkeDewX3Td6ztbWVo6Oj2WEgDyQkJCgtLa1AzsV9U3QU1H1TsmTJ27ahOAsAAADgtmxsbO7oDwxkz8bGRpLk6OgoJycnk6PBvYL7BsgaxVLkRmG6b5jWAAAAADBJ+fLlZWdnl2Ghrri4ODk7OxeaPgEAAJA/KM4CAAAAJrG3t5eXl5eioqIs29LS0hQVFSU/P79C0ycAAADyB9MaAAAAACYaPHiwgoOD1aBBA/n4+GjFihVKSEhQz549JUkTJkxQpUqVNG7cOEk3FvyKiYmxfH/27FkdOnRITk5Oqlmz5h31CQAAgMKB4iwAAABgos6dO+vChQsKCQlRbGysPD09FRoaapmC4MyZM7K1/feBt3PnzqlHjx6W10uXLtXSpUvVrFkzrVy58o76BAAAQOFAcRYAAAAwWWBgoAIDAzPdl15wTVetWjUdOXLkrvoEAABA4cCcswAAAAAAAABggiJbnF29erXatm0rb29v9e7dW/v378+y7dq1a9WvXz81bdpUTZs21aBBgzJtHxMTo+HDh6tx48by9fVVr169dPr06fy8DAAAAAAAAABFVJEszkZGRmratGkaNWqUIiIi5OHhoaCgIMXFxWXafteuXerSpYvCwsK0Zs0aVa5cWc8884zOnj1raXPy5En169dPtWvX1sqVK/XZZ59p5MiRKlGiREFdFgAAAAAAAIAipEjOObts2TL16dNHvXr1kiRNmTJF27ZtU3h4uIYOHZqh/axZs6xeT506VV9++aWioqIsiy3MmTNHrVq10oQJEyztatSokX8XAQAAAAAAAKBIK3IjZ5OSknTw4EH5+/tbttna2srf31/R0dF31EdCQoJSUlJUtmxZSVJaWpq2bdumWrVqKSgoSC1atFDv3r21ZcuWfLkGAAAAAAAAAEVfkSvOXrx4UampqapYsaLV9ooVK+r8+fN31MfMmTPl6upqKfDGxcUpPj5eixcvVsuWLbV06VI9+uijGj16tH788cc8vwYAAAAAAAAARV+RnNbgbixatEiRkZEKCwuzzCeblpYmSWrXrp0GDRokSfL09NTevXu1Zs0aNWvWLFfnMgxD165dy5O473eJiYmSbox6NgzD5GhwL+CeyXu2trZydHQ0OwzkkYSEBMv///IT903RUhD3TcmSJfO1fwAAAKAgFbnibPny5WVnZ5dh8a+4uDg5Oztne+ySJUu0aNEiLVu2TB4eHlZ9FitWTHXq1LFqX6dOHe3ZsyfXsdrY2PAHRh6xsbGRJDk6OsrJycnkaHAv4J4BskfBFLnBfQMAAADkTJGb1sDe3l5eXl6KioqybEtLS1NUVJT8/PyyPG7x4sX64IMPFBoaKm9v7wx9ent76/jx41bbT5w4oapVq+btBQAAAAAAAAC4LxS5kbOSNHjwYAUHB6tBgwby8fHRihUrlJCQoJ49e0qSJkyYoEqVKmncuHGSbkxlEBISolmzZqlq1aqKjY2VJDk5OVlGtgYFBemFF15Q06ZN1bx5c23fvl3ffPONwsLCzLlIAAAAAAAAAPe0Ilmc7dy5sy5cuKCQkBDFxsbK09NToaGhlmkNzpw5I1vbfwcNr1mzRsnJyRozZoxVP6NHj9Zzzz0nSXr00Uc1efJkLVq0SFOnTtWDDz6okJAQNWnSpOAuDAAAAAAAAECRUSSLs5IUGBiowMDATPetXLnS6vXWrVvvqM8nnnhCTzzxxF3HBgAAAAAAAABFbs5ZAAAAAAAAALgXUJwFAAAAAAAAABNQnAUAAAAAAAAAE1CcBQAAAAAAAAATUJwFAAAAAAAAABNQnAUAAAAAAAAAE1CcBQAAAAAAAAATUJwFAAAAAAAAABNQnAUAAAAAAAAAE1CcBQAAAAAAAAATUJwFAAAAAAAAABNQnAUAAAAAAAAAE1CcBQAAAAAAAAATUJwFAAAAAAAAABNQnAUAAAAAAAAAE1CcBQAAAAAAAAATUJwFAAAAAAAAABNQnAUAAAAAAAAAE1CcBQAAAAAAAAATUJwFAAAAAAAAABNQnAUAAAAAAAAAE1CcBQAAAAAAAAATUJwFAAAAAAAAABNQnAUAAAAAAAAAE1CcBQAAAAAAAAATUJwFAAAAAAAAABNQnAUAAAAAAAAAE1CcBQAAAAAAAAATUJwFAAAAAAAAABNQnAUAAAAAAAAAE1CcBQAAAAAAAAATUJwFAAAAAAAAABNQnAUAAABMtnr1arVt21be3t7q3bu39u/fn237TZs26bHHHpO3t7e6deumb7/91mr/+fPnNXHiRAUEBKhhw4YKCgrSiRMn8vEKAAAAkBsUZwEAAAATRUZGatq0aRo1apQiIiLk4eGhoKAgxcXFZdp+7969GjdunJ544glt2LBB7dq106hRo3T06FFJkmEYGjVqlE6dOqUPPvhAERERqlq1qgYPHqz4+PiCvDQAAADcRqEoziYlJSk6OlpbtmzRhQsXzA4HAAAAyFR+5K3Lli1Tnz591KtXL9WtW1dTpkyRg4ODwsPDM20fFhamli1basiQIapTp47Gjh2r+vXra9WqVZKkEydOaN++fZo8ebJ8fHxUu3ZtTZ48WYmJifriiy/yJGYAAADkDdOLs2FhYQoICFC/fv303HPP6ciRI5KkCxcuqHnz5lq3bp3JEQIAAAD5k7cmJSXp4MGD8vf3t2yztbWVv7+/oqOjMz1m3759atGihdW2gIAA7du3z9KnJJUoUcKqT3t7e+3ZsyfHMQIAACD/mFqcDQ8P1zvvvKOWLVvq7bfflmEYln0VKlTQQw89pMjISBMjBAAAAPIvb7148aJSU1NVsWJFq+0VK1bU+fPnMz3m/PnzcnZ2zrJ97dq1VaVKFc2aNUuXL19WUlKSFi1apL///luxsbE5jhEAAAD5p5iZJ1+2bJnatWunWbNm6eLFixn2e3l5aeXKlSZEBgAAAPzrXspbixcvrnnz5unVV19Vs2bNZGdnpxYtWqhVq1ZWReWcMgxD165dy8NI70+JiYmSpISEhLt6P3B/4b7Je7a2tnJ0dDQ7DOSBhIQEpaWlFci5uG+KjoK6b0qWLHnbNqYWZ//44w/1798/y/3lypXTpUuXCi4gAAAAIBP5lbeWL19ednZ2GRb/iouLyzA6Np2zs3OGUbW3tm/QoIE+/fRTXb16VcnJyapQoYJ69+6tBg0a5DjGdDY2Nnf0BwayZ2NjI0lydHSUk5OTydHgXsF9A2SNYilyozDdN6ZOa1CmTJlMRx6k+/333+Xi4lKAEQEAAAAZ5Vfeam9vLy8vL0VFRVm2paWlKSoqSn5+fpke4+vrq507d1pt++GHH+Tr65uhbenSpVWhQgWdOHFCBw4cULt27XIcIwAAAPKPqcXZVq1aae3atbpy5UqGfb/99ps++eQTtW3b1oTIAAAAgH/lZ946ePBgrV27VhEREYqJidHkyZOVkJCgnj17SpImTJigWbNmWdoPGDBA27dv19KlSxUTE6N58+bpwIEDCgwMtLTZtGmTdu3apVOnTmnLli165pln1L59ewUEBOQqRgAAAOQPU6c1GDt2rPr06aOuXbuqTZs2srGx0YYNGxQeHq7/+7//k4uLi0aOHGlmiAAAAEC+5q2dO3fWhQsXFBISotjYWHl6eio0NNQyTcGZM2dka/vvmIpGjRpp5syZmjt3rmbPnq1atWppwYIFcnNzs7SJjY3V9OnTFRcXJxcXF3Xv3p28GgAAoBAytThbqVIlrV+/XrNnz9amTZtkGIY+/fRTlSxZUl26dNH48eNVoUIFM0MEAAAA8j1vDQwMtBr5erPMFhrr1KmTOnXqlGV/AwYM0IABA3IdDwAAAAqGacXZpKQkbd++XVWrVtXbb7+tt99+WxcuXFBaWpoqVKhgNToAAAAAMAt5KwAAAPKLaZlk8eLF9fzzzys6OtqyrUKFCnJ2dibBBQAAQKFB3goAAID8Ylo2aWNjo1q1amW76i0AAABgNvJWAAAA5BdTP+ofNmyYVq9erWPHjpkZBgAAAJAt8lYAAADkB1MXBPv5559Vrlw5devWTc2aNVPVqlXl4OCQod1rr71mQnQAAADADeStAAAAyA+mFmdXrVpl+T4qKirTNjY2NiS5AAAAMBV5KwAAAPKDqcXZw4cPm3l6AAAA4I6QtwIAACA/sLwsAAAAAAAAAJjA1JGz6U6dOqXvvvtOp0+fliRVqVJFrVq1UvXq1U2ODAAAAPgXeSsAAADykunF2enTpyssLExpaWlW221tbTVw4EAFBwebFBkAAADwL/JWAAAA5DVTi7NLly7V8uXL1bFjRz3zzDOqU6eOJCkmJkbLly/X8uXLValSJQ0aNMjMMAEAAHCfI28FAABAfjC1OLt27Vq1bdtW77//vtX2hg0bas6cObp+/brWrFlDkgsAAABTkbcCAAAgP5i6INhff/2lgICALPcHBATor7/+KsCIAAAAgIzIWwEAAJAfTC3OVqxYUYcPH85y/+HDh1WhQoUCjAgAAADIiLwVAAAA+cHU4uxjjz2mdevWadGiRYqPj7dsj4+P16JFi7Ru3Tp17tzZxAgBAAAA8lYAAADkD1PnnH3++ed16NAhzZ49WyEhIXJ1dZUknTt3TikpKWrevLnGjBljZogAAAAAeSsAAADyhanFWUdHR61YsUJbtmzRd999p9OnT0u6MWdX69at1bZtW9nY2JgZIgAAAEDeCgAAgHxhanE2Xfv27dW+fXuzwwAAAACyRd4KAACAvGTqnLOnTp3S1q1bs9y/detW/fnnnwUYEQAAAJAReSsAAADyg6kjZ2fMmKF//vlHbdu2zXT/6tWrVaZMGc2ZM6eAIwMAAAD+Rd4KAACA/GDqyNno6Gj5+/tnub9FixbavXt3rvpevXq12rZtK29vb/Xu3Vv79+/Psu3atWvVr18/NW3aVE2bNtWgQYOybf/666/L3d1dy5cvz1VsAAAAuLfkZ94KAACA+5epxdkrV66oZMmSWe53cnLSpUuXctxvZGSkpk2bplGjRikiIkIeHh4KCgpSXFxcpu137dqlLl26KCwsTGvWrFHlypX1zDPP6OzZsxnafvXVV/r5558tK/QCAACg6MuvvBUAAAD3N1OLs5UrV9bevXuz3L9nzx498MADOe532bJl6tOnj3r16qW6detqypQpcnBwUHh4eKbtZ82apaefflqenp6qU6eOpk6dqrS0NEVFRVm1O3v2rN566y3NnDlTxYsXz3FcAAAAuDflV94KAACA+5upxdmuXbvqiy++UFhYmNLS0izbU1NTtWLFCkVGRqpr16456jMpKUkHDx60euzM1tZW/v7+io6OvqM+EhISlJKSorJly1q2paWl6aWXXlJQUJDq1auXo5gAAABwb8uPvBUAAAAwdUGwYcOGac+ePXrnnXe0cOFCPfjgg5Kk48eP68KFC2rWrJlGjBiRoz4vXryo1NRUVaxY0Wp7xYoVdezYsTvqY+bMmXJ1dbUq8C5evFjFihXTgAEDchRPdgzD0LVr1/Ksv/tZYmKipBuFdcMwTI4G9wLumbxna2srR0dHs8NAHklISLAqQOUX7puipSDum+ymFshP+ZG3AgAAAKYWZ+3t7bV06VJFREToq6++0smTJyVJPj4+6tChg3r06CFb24Id3Lto0SJFRkYqLCxMJUqUkCQdOHBAYWFhWr9+vWxsbPLsXDY2Nqb9gVHUpL8vjo6OcnJyMjka3Au4Z4DsUTBFbhTl+6Yw5q0AAAC495lanJVujJjp1auXevXqlSf9lS9fXnZ2dhkW/4qLi5Ozs3O2xy5ZskSLFi3SsmXL5OHhYdm+e/duxcXFqU2bNpZtqampevfddxUWFqatW7fmSewAAAAovPI6bwUAAABML87eyjAM7dy5U0lJSWrcuLFKlSqVo+Pt7e3l5eWlqKgotW/fXpIsi3sFBgZmedzixYu1cOFCLVmyRN7e3lb7unfvbjXFgSQFBQWpe/fu6tmzZ47iAwAAQNFwt3krAAAAYGpxds6cOdq7d69Wrlwp6UaC+8wzz2jnzp0yDENVqlTR8uXLVaNGjRz1O3jwYAUHB6tBgwby8fHRihUrlJCQYCmkTpgwQZUqVdK4ceMk3ZjKICQkRLNmzVLVqlUVGxsrSXJyclLJkiVVvnx5lS9f3uocxYsXl7Ozs2rXrn23PwYAAAAUcvmVtwIAAOD+ZurEWF9++aV8fHwsrzdv3qyoqCiNHTtWH330kVJTUzVv3rwc99u5c2cFBwcrJCRE3bt316FDhxQaGmqZ1uDMmTOWAqwkrVmzRsnJyRozZowCAgIsX0uXLr37iwQAAMA9L7/yVgAAANzfTB05e/bsWdWsWdPy+quvvlLdunU1bNgwSdJTTz2ljz/+OFd9BwYGZjmNQfqIh3S5mTOWeWYBAADuH/mZtwIAAOD+ZerI2WLFiikpKUnSjUfDoqKi1LJlS8v+ihUr6uLFi2aFBwAAAEgibwUAAED+MLU4W69ePX322We6fPmywsPDdenSJbVu3dqy//Tp0xnmegUAAAAKGnkrAAAA8oOp0xqMGjVKw4cP10MPPSRJatSokeV7Sfr222/l7e1tVngAAACAJPJWAAAA5A9Ti7MPP/ywIiIi9P3336tMmTLq3LmzZd/ly5fVpEkTtWvXzsQIAQAAAPJWAAAA5A9Ti7OSVLduXdWtWzfD9rJly+qVV14xISIAAAAgI/JWAAAA5DVT55y91eXLlzVgwAD9+uuvZocCAAAAZIm8FQAAAHmhUBVnk5OT9eOPP+ry5ctmhwIAAABkibwVAAAAeaFQFWcBAAAAAAAA4H5BcRYAAAAAAAAATFCoirMODg56/PHH5erqanYoAAAAQJbIWwEAAJAXipkdwM1KlSqladOmmR0GAAAAkC3yVgAAAOSFQjVy9lb//POPTp8+bXYYAAAAQLbIWwEAAJAbhbo4u3LlSrVr187sMAAAAIBskbcCAAAgNwp1cRYAAAAAAAAAiqoCn3N2w4YNd9z20KFD+RcIAAAAkI2CzFtXr16tJUuWKDY2Vh4eHpo0aZJ8fHyybL9p0ya9//77+uuvv1SrVi2NHz9erVu3tuy/du2aZs2apS1btujSpUuqVq2a+vfvr6eeeuqu4gQAAEDeKvDi7MSJE2VjYyPDMO6ovY2NTT5HBAAAAGRUUHlrZGSkpk2bpilTpqhhw4ZasWKFgoKCtHnzZlWsWDFD+71792rcuHF68cUX1aZNG23cuFGjRo3S+vXr5ebmJkmaPn26du7cqffee09Vq1bV999/rylTpsjV1ZXpFwAAAAqRAi/Oli1bVh4eHnrppZdu23bdunX63//+VwBRAQAAANYKKm9dtmyZ+vTpo169ekmSpkyZom3btik8PFxDhw7N0D4sLEwtW7bUkCFDJEljx47VDz/8oFWrVunNN9+UJEVHR6tHjx5q3ry5JKlv37763//+p/3791OcBQAAKEQKvDjr7e2tY8eOqUGDBrdtu3379gKICAAAAMioIPLWpKQkHTx4UMOGDbNss7W1lb+/v6KjozM9Zt++fRo0aJDVtoCAAG3ZssXy2s/PT1u3btUTTzwhV1dX7dq1S8ePH9fLL7+cqzgBAACQPwp8QTAfHx+dPn1acXFxt21bpkwZVa5cuQCiAgAAAKwVRN568eJFpaamZpi+oGLFijp//nymx5w/f17Ozs7Ztp80aZLq1q2rVq1aqUGDBhoyZIjeeOMNNW3aNMcxAgAAIP8U+MjZIUOGqFevXipTpsxt2z799NN6+umnCyAqAAAAwNq9nLeuXLlS+/bt04cffqgqVapo9+7dljln/f39c9WnYRi6du1aHkd6/0lMTJQkJSQk3PF8xgD3Td6ztbWVo6Oj2WEgDyQkJCgtLa1AzsV9U3QU1H1TsmTJ27Yp8OKsk5OTnJycCvq0AAAAQI4URN5avnx52dnZZRidGxcXl2F0bDpnZ+cMo2pvbp+YmKg5c+Zo/vz5euSRRyRJHh4eOnTokJYsWZLr4qyNjc0d/YGB7KUvHOfo6MjfRbhj3DdA1iiWIjcK031T4NMaJCUlFfQpAQAAgBwriLzV3t5eXl5eioqKsmxLS0tTVFSU/Pz8Mj3G19dXO3futNr2ww8/yNfXV5KUkpKi5ORkSzEnnZ2dHSPuAAAACpkCL842bNhQGzdutLxOTEzU/Pnz9eeffxZ0KAAAAECWCipvHTx4sNauXauIiAjFxMRo8uTJSkhIUM+ePSVJEyZM0KxZsyztBwwYoO3bt2vp0qWKiYnRvHnzdODAAQUGBkqSSpUqpWbNmum9997Trl27dOrUKa1fv14bNmxQ+/bt8zR2AAAA3J0Cn9bg1k/rExIStGDBAjVu3FjVqlUr6HAAAACATBVU3tq5c2dduHBBISEhio2Nlaenp0JDQy3TFJw5c0a2tv+OqWjUqJFmzpypuXPnavbs2apVq5YWLFggNzc3S5vZs2dr9uzZGj9+vC5fvqwqVarohRde0FNPPZVncQMAAODuFXhxNjM8XgUAAIB7QX7lrYGBgZaRr7dauXJlhm2dOnVSp06dsuzPxcVF06ZNy7P4AAAAkD8KfFoDAAAAAAAAAIBJxdlbFyfIahsAAABgJvJWAAAA5CdTpjVYunSpPv/8c0k3VpOVpLlz56pcuXIZ2trY2OjDDz8syPAAAAAASeStAAAAyF8FXpytUqWKLl26pEuXLlltO3funM6dO5ehPSMTAAAAYAbyVgAAAOS3Ai/Obt26taBPCQAAAOQYeSsAAADyGwuCAQAAAAAAAIAJKM4CAAAAAAAAgAkozgIAAAAAAACACSjOAgAAAAAAAIAJKM4CAAAAAAAAgAkozgIAAAAAAACACYqZHUC633//XX/99ZckqWrVqqpbt67JEQEAAAAZkbcCAAAgr5henN2yZYumT59uSXDTVatWTRMnTlS7du1MigzA/2vvzsOqqPv/j78ARUBLScANtbJYRBBNM1QyzOVWNEtyydA0XDD3FbJMTctyFzXNXcj7NlOx5TYr86u3G7aIVu6hpuYGaK4oCPP7wx8nTywKAuPyfFwX1+WZ+cxn3nNmzvF93jPzGQAA8DfyVgAAABQ0U4uzGzduVP/+/VWxYkUNGjRI1apVkyQlJCRo+fLl6tevn+bMmaNnn33WzDABAADwgCNvBQAAQGEwtTj70UcfydPTU0uXLpWTk5Nl+vPPP6/Q0FB16tRJs2bNIskFAACAqchbAQAAUBhMfSDY/v379eKLL1oluJmcnJz00ksvaf/+/SZEBgAAAPyNvBUAAACFwdTibIkSJXT+/Pkc558/f14lSpQowogAAACArMhbAQAAUBhMLc7Wq1dP0dHRio+PzzJv165diomJUUBAgAmRAQAAAH8jbwUAAEBhMHXM2WHDhqljx47q1KmT/Pz89Nhjj0mSDh8+rF9++UVly5bV0KFDzQwRAAAAIG8FAABAoTD1ytnKlSvriy++UOfOnXX+/HmtWbNGa9as0fnz59WlSxd9/vnncnd3NzNEAAAAgLwVAAAAhcK0K2evXbumTz/9VN7e3hoxYoRGjBhhVigAAABAjshbAQAAUFhMu3K2RIkSmjRpkg4fPmxWCAAAAMAtkbcCAACgsJg6rMGTTz6pP//808wQAAAAgFsibwUAAEBhMLU4O2jQIC1btkxbt241MwwAAAAgV+StAAAAKAymjTkrSZ988onKlCmjsLAwubu7y93dXSVKlLBqY2Njo9mzZ5sUIQAAAEDeCgAAgMJhanH2wIEDkqQKFSooPT1df/zxR5Y2NjY2RR0WAAAAYIW8FQAAAIXB1OLs+vXrzVw9AAAAcFvIWwEAAFAYTB1zFgAAAAAAAAAeVKYWZ7ds2aIpU6bkOH/q1Knatm1bEUYEAAAAZEXeCgAAgMJganF29uzZOnnyZI7zT58+zUMVAAAAYDryVgAAABQGU4uzBw4cUM2aNXOc7+vrq/379xdhRAAAAEBW5K0AAAAoDKYWZ1NTU5WWlpbr/KtXrxZhRAAAAEBW5K0AAAAoDKYWZ5988kl999132c4zDEPffvutqlWrVsRRAQAAANbIWwEAAFAYTC3OhoaGaseOHerfv7/279+v69ev6/r169q3b58GDBignTt3qnPnzmaGCAAAAJC3AgAAoFAUM3Plbdq00bFjx/TRRx/pu+++k63tjVpxRkaGbGxs1Lt3b7300ktmhggAAACQtwIAAKBQmFqclaS+ffvqhRde0Hfffadjx45JkqpUqaImTZqoSpUqJkcHAAAA3EDeCgAAgIJmenFWupHUhoWFmR0GAAAAkCvyVgAAABQkU8ecBQAAAAAAAIAHlelXzm7cuFGLFy/Wnj17dPHiRRmGkaXN3r1789zv0qVLtWDBAiUmJsrLy0sjR46Un59ftm2XL1+u1atX6+DBg5IkHx8fDR482NI+LS1N06ZN0//+9z8dO3ZMpUqVUv369TVkyBCVK1cuz7EBAADg3lNYeSsAAAAeXKZeOfvNN98oPDxcSUlJatmypTIyMhQcHKyWLVvKwcFBnp6e6tOnTzNOe+cAAEaZSURBVJ77XbNmjcaPH68+ffooNjZWXl5eCgsLU3Jycrbtt2/fruDgYEVHR2vZsmWqUKGCXn/9dZ0+fVqSdPXqVe3Zs0e9e/fWqlWrNHPmTB0+fFi9e/e+o+0HAADAvaGw8lYAAAA82Ey9cvbjjz+Wn5+f/v3vf+v8+fP6z3/+o5CQEAUEBOj48ePq0KGD3N3d89zvokWL1L59e4WEhEiSxowZow0bNmjlypXq2bNnlvaTJ0+2ej1u3Dh988032rZtm1588UU99NBDWrRokVWbkSNHql27djpx4oQqVqyY5xgBAABw7yisvBUAAAAPNlOvnE1ISFDLli1lZ2enYsVu1ImvX78uSXJ3d9crr7yiefPm5anP1NRU7d69W/Xr17dMs7W1Vf369RUfH39bfaSkpOj69esqXbp0jm0uXbokGxsbPfzww3mKDwAAAPeewshbAQAAAFOvnHVwcFDx4sUlSQ8//LDs7e2VmJhome/i4qLjx4/nqc9z584pPT1dZcuWtZpetmxZHTp06Lb6mDRpktzc3KwKvDe7du2aJk2apODgYJUqVSpP8d3MMAxdvnw538vjb1evXpV0o7Ce3fhvwD9xzBQ8W1tbOTo6mh0GCkhKSooyMjIKfT0cN/eXojhuSpYsWaj956Qw8lYAAADA1OLsY489poSEBMtrb29vff7553rhhReUnp6ur776ShUqVCjSmObOnas1a9YoOjpaJUqUyDI/LS1NAwYMkGEYGjNmzB2ty8bGxrQfGPcbGxsbSZKjo6OcnJxMjgb3Ao4ZIHcUTJEf9/NxczfmrQAAALj3mTqsQdOmTfX9998rNTVVkhQeHq4ffvhBdevW1TPPPKOffvop2zFic+Ps7Cw7O7ssD/9KTk6Wi4tLrssuWLBAc+fO1YIFC+Tl5ZVlflpamgYOHKgTJ05o4cKFd3TVLAAAAO4dhZG3AgAAAKZeORsWFqawsDDL66CgIMXExOjbb7+VnZ2dGjVqpGeeeSZPfdrb28vHx0fbtm1TkyZNJEkZGRnatm2bQkNDc1xu3rx5mjNnjhYsWCBfX98s8zMLs3/88Yeio6Pl7Oycp7gAAABw7yqMvPVmS5cu1YIFC5SYmCgvLy+NHDlSfn5+Obb/+uuvNX36dP3555969NFHNXToUDVq1Mgy39PTM9vlhg0bpu7du+c7TgAAABQsU4uz2alTp47q1KlzR31069ZNERERqlGjhvz8/LRkyRKlpKSobdu2kqThw4erXLlyGjJkiKQbQxlERUVp8uTJqlSpkmX8MCcnJ5UsWVJpaWnq37+/9uzZo48//ljp6emWNqVLl5a9vf0dxQsAAIB7T0HkrZK0Zs0ajR8/XmPGjFHNmjW1ZMkShYWFae3atVmeoyBJO3bs0JAhQzR48GAFBQXpyy+/VJ8+fbRq1Sp5eHhIkjZv3my1zP/+9z+99dZbat68+R3HCwAAgIJz1xVnC0LLli119uxZRUVFKTExUd7e3po/f75lWIOTJ0/K1vbvER2WLVtmKcDerG/fvurXr59Onz6t9evXS5LatGlj1SY6Olr16tUr5C0CAADA/WrRokVq3769QkJCJEljxozRhg0btHLlymyHSoiOjlZgYKDlCtiBAwdq69at+uSTT/Tuu+9KklxdXa2W+f7771WvXj1Vrly5kLcGAAAAeVHkxdnw8PA8tbexsdHs2bPzvJ7Q0NAchzGIiYmxep1ZeM2Ju7u79u/fn+cYAAAAcO8qirw1NTVVu3fvVq9evSzTbG1tVb9+fcXHx2e7zM6dO9W1a1eraQ0bNtS6deuybZ+UlKSNGzfqgw8+yFNsAAAAKHxFXpzdsGGDSpQoIRcXFxmGccv2mU9UBwAAAIpSUeSt586dU3p6epbhC8qWLatDhw5lu0xSUlKWB92WLVtWSUlJ2baPjY1VyZIl1axZszzHdzPDMHT58uU76gPS1atXJUkpKSm3dVwBEsdNYbC1tZWjo6PZYaAApKSkKCMjo0jWxXFz/yiq46ZkyZK3bFPkxdly5crp9OnTcnZ2VqtWrRQcHJzltisAAADAbPdL3rpy5Uq1bt1aJUqUuKN+bGxsbusHBnKXWcR3dHSUk5OTydHgXsFxA+SMYiny4246bmxv3aRgbdy4UdHR0apevbpmz56t5557Tl27dtXKlSt16dKlog4HAAAAyFZR5K3Ozs6ys7NTcnKy1fTk5OQsV8dmcnFxyXKVbE7tf/rpJx0+fFjt2rUrkHgBAABQsIq8OCtJTz/9tN59911t3rxZ06dPV5kyZTR27FjVr19fffv21dq1a5WammpGaAAAAIBFYeet9vb28vHx0bZt2yzTMjIytG3bNtWqVSvbZfz9/RUXF2c1bevWrfL398/SdsWKFfLx8ZGXl1e+YwQAAEDhMaU4m6l48eJq0qSJpk2bpi1btujdd99VUlKSBg0apHnz5pkZGgAAAGBRmHlrt27dtHz5csXGxiohIUGjR49WSkqK2rZtK0kaPny4Jk+ebGnfpUsXbdq0SQsXLlRCQoJmzJih3377LcvDcC9duqS1a9dy1SwAAMBdrMjHnM1OamqqNm/erO+//1579uxRiRIlVKlSJbPDAgAAAKwURt7asmVLnT17VlFRUUpMTJS3t7fmz59vGabg5MmTsrX9+5qK2rVra9KkSZo2bZqmTJmiRx99VLNmzZKHh4dVv//9739lGIZatWp1R/EBAACg8JhWnM3IyNCWLVv03//+V+vWrdPVq1cVEBCgsWPHqmnTpgxyDgAAgLtCUeStoaGhWa58zRQTE5NlWosWLdSiRYtc++zQoYM6dOhwx7EBAACg8BR5cXbHjh366quvtHbtWv3111+qWbOmBg0apBYtWuiRRx4p6nAAAACAbJG3AgAAoLAVeXG2U6dOcnBw0LPPPqtWrVpZbgM7efKkTp48me0yPj4+RRkiAAAAQN4KAACAQmfKsAZXr17Vt99+q++++y7XdoZhyMbGRnv37i2iyAAAAIC/kbcCAACgMBV5cXb8+PFFvUoAAAAgz8hbAQAAUNiKvDj70ksvFfUqAQAAgDwjbwUAAEBhszU7AAAAAAAAAAB4EFGcBQAAAAAAAAATUJwFAAAAAAAAABNQnAUAAAAAAAAAE1CcBQAAAAAAAAATUJwFAAAAAAAAABNQnAUAAAAAAAAAE1CcBQAAAAAAAAATUJwFAAAAAAAAABNQnAUAAAAAAAAAE1CcBQAAAAAAAAATUJwFAAAAAAAAABNQnAUAAAAAAAAAE1CcBQAAAAAAAAATUJwFAAAAAAAAABNQnAUAAAAAAAAAE1CcxV1h6dKlaty4sXx9fdWuXTv98ssvObZdvny5OnXqpLp166pu3brq2rWrfvvtN6s2hmFo+vTpatiwofz8/NS1a1cdOXIk2/5SU1PVpk0beXp6au/evQW5WQAAAAAAAECOKM7CdGvWrNH48ePVp08fxcbGysvLS2FhYUpOTs62/fbt2xUcHKzo6GgtW7ZMFSpUUO/evXX27FlLm3nz5ikmJkajR4/W8uXL5ejoqLCwMF27di1LfxMmTJCbm1uhbR8AAAAAAACQHYqzMN2iRYvUvn17hYSE6IknntCYMWPk4OCglStXZtt+8uTJevXVV+Xt7a1q1app3LhxMgzDcvWsYRiKjo5W79691aRJE3l5eWnChAk6c+aM1q1bZ9XXxo0btWXLFkVERBT6dgIAAAAAAAA3ozgLU6Wmpmr37t2qX7++ZZqtra3q16+v+Pj42+ojJSVF169fV6lSpSRJx48fV2JiolWfDz30kGrWrGnVZ1JSkkaOHKkJEybIwcGhgLYIAAAAAAAAuD0UZ2Gqc+fOKT09XWXLlrWaXrZsWSUlJd1WH5MmTZKrq6tq1KghSUpMTLT0kVOfhmEoMjJSHTt2lK+v751uBgAAAAAAAJBnxcwOALgTc+fO1Zo1azR37lylp6ff9nIxMTG6fPmyevXqVYjRAQAAAAAAADnjylmYytnZWXZ2dlke/pWcnCwXF5dcl12wYIHmzp2rBQsWyMPDwzLd1dXV0kdOfcbFxWnnzp3y9fVV9erV1axZM0lSSEgI488CAAAAAACgSFCchans7e3l4+Ojbdu2WaZlZGRo27ZtqlWrVo7LzZs3Tx999JHmz5+fZVgCd3d3ubq6WvV56dIl7dq1y9Ln22+/rc8//1yrV6/W6tWrNXfuXEnS1KlTNWjQoILcRAAAAAAAACBbDGsA03Xr1k0RERGqUaOG/Pz8tGTJEqWkpKht27aSpOHDh6tcuXIaMmSIpBtDGURFRWny5MmqVKmSEhMTlZKSoqtXr0qSbGxs1KVLF82ePVtVq1aVu7u7pk+fLjc3NzVp0kSSVLFiRasYnJycJElVqlRR+fLli2rTAQAAAAAA8ACjOAvTtWzZUmfPnlVUVJQSExPl7e2t+fPnW4YgOHnypGxt/77Ie9myZUpLS1P//v2t+mnbtq3lytgePXooJSVF77zzji5cuKCnnnpK8+fPV4kSJYpuwwAAAAAAAIBcUJzFXSE0NFShoaHZzouJibF6vX79+ixtrly5or1791pe29jYaMCAARowYMBtrd/d3V379+/PQ8QAAAAAAADAnWHMWQAAAAAAAAAwAcVZAAAAAAAAADABxVkAAAAAAAAAMAHFWQAAAAAAAAAwAcVZAAAAAAAAADABxVkAAAAAAAAAMAHFWQAAAAAAAAAwAcVZAAAAAAAAADABxVkAAAAAAAAAMAHFWQAAAAAAAAAwAcVZAAAAAAAAADABxVkAAAAAAAAAMAHFWQAAAAAAAAAwQTGzAwDy4rffftOBAweyTE9NTVViYqIOHjwoe3v7LPM9PDxUo0aNoggRAAAgz5YuXaoFCxYoMTFRXl5eGjlypPz8/HJs//XXX2v69On6888/9eijj2ro0KFq1KiRVZuEhARNnDhRP/74o9LT01WtWjXNmDFDFStWLOzNAQAAwG2iOPuASM8wZGdrY3YYd2zUqFGKi4vL83LPPPOMVq5cWQgRFZ37ZR8CAABra9as0fjx4zVmzBjVrFlTS5YsUVhYmNauXauyZctmab9jxw4NGTJEgwcPVlBQkL788kv16dNHq1atkoeHhyTp6NGj6tSpk0JCQtS/f3+VKlVKBw8eVIkSJYp68wAAAJALirMPCDtbGw1YFq/fz1wyO5Q7csXrRVVxqZPn5c66uCs4alMhRFQ0nnArpekda5kdBgAAKASLFi1S+/btFRISIkkaM2aMNmzYoJUrV6pnz55Z2kdHRyswMFDdu3eXJA0cOFBbt27VJ598onfffVeSNHXqVD377LMaPny4ZbkqVaoUwdYAAAAgLyjOPkB+P3NJu09cMDuMO/SI5PxI3hdLl3TPbzsAALjfpKamavfu3erVq5dlmq2trerXr6/4+Phsl9m5c6e6du1qNa1hw4Zat26dJCkjI0MbNmxQ9+7dFRYWpj179sjd3V29evVSkyZNCm1bAAAAkHcUZwEAAACTnDt3Tunp6VmGLyhbtqwOHTqU7TJJSUlycXHJ0j4pKUmSlJycrCtXrmjevHkaOHCghg4dqk2bNqlv376Kjo7W008/na9YDcPQ5cuX87Us/nb16lVJUkpKigzDMDka3Cs4bgqera2tHB0dzQ4DBSAlJUUZGRlFsi6Om/tHUR03JUuWvGUbirMAAADAfSTzh8bzzz9vucLW29tbO3bs0LJly/JdnLWxsbmtHxjInY3NjWcIODo6ysnJyeRocK/guAFyRrEU+XE3HTe2ZgcAAAAAPKicnZ1lZ2en5ORkq+nJyclZro7N5OLiYrlKNrv2zs7OKlasmKpVq2bVplq1ajpx4kQBRg8AAIA7RXEWAAAAMIm9vb18fHy0bds2y7SMjAxt27ZNtWpl/zBQf39/xcXFWU3bunWr/P39LX36+vrq8OHDVm2OHDmiSpUqFewGPICWLl2qxo0by9fXV+3atdMvv/ySa/uvv/5a//rXv+Tr66vWrVtr0ybrh9RGRkbK09PT6i8sLMyqTePGjbO0mTt3boFvGwAAKHoMawAAAACYqFu3boqIiFCNGjXk5+enJUuWKCUlRW3btpUkDR8+XOXKldOQIUMkSV26dFHnzp21cOFCNWrUSGvWrNFvv/2md99919JnWFiYBg0apLp166pevXratGmT/u///k/R0dGmbOP9Ys2aNRo/frzGjBmjmjVrasmSJQoLC9PatWuzjBssSTt27NCQIUM0ePBgBQUF6csvv9TgwYP13nvvydvb29IuMDBQ48ePt7y2t7fP0lf//v3Vvn17y2uGmAAA4P5AcRYAAAAwUcuWLXX27FlFRUUpMTFR3t7emj9/vmWYgpMnT8rW9u8b3mrXrq1JkyZp2rRpmjJlih599FHNmjVLHh4eljZNmzbV6NGjNXfuXI0bN06PPfaYoqKiVKdOnSLfvvvJokWL1L59e4WEhEiSxowZow0bNmjlypXq2bNnlvbR0dEKDAxU9+7dJUkDBw7U5s2b9e2336pZs2aWdvb29nJ1dc113SVLlrxlGwAAcO+5b4uzS5cu1YIFC5SYmCgvLy+NHDlSfn5+2bZdvny5Vq9erYMHD0qSfHx8NHjwYKv2hmEoKipKn332mS5cuKDatWtr9OjRevTRR4ticwAAAHAfCw0NVWhoaLbzYmJiskxr0aKFWrRokWufL7/8sl5++eUCiQ9Samqqdu/erV69elmm2draqn79+oqPj892mZ07d1oeypYpICBAa9eutZr2ww8/KCAgQA8//LCeeeYZDRw4UM7OzlZt5s2bp9mzZ6tChQpq1aqVunbtqmLF7tufcwAAPDDuyzFnM2836tOnj2JjY+Xl5aWwsLAsD1rItH37dgUHBys6OlrLli1ThQoV9Prrr+v06dOWNvPmzVNMTIxGjx6t5cuXy9HRUWFhYbp27VpRbRaAm+RlvLeDBw+qX79+lvHaFi9enKXNpUuX9N577ykoKEh+fn7q2LFjrn2+8847OfYFAADuP+fOnVN6enqW4QvKli2b5QFtmZKSkrI82K1s2bL666+/LK8DAwP14YcfavHixRo2bJh+/PFH9ejRQ+np6ZY2nTt31pQpU7RkyRJ16NBBH3/8sSZOnFhwG4dCZ8ZYxZlSU1PVpk0beXp6au/evQW2TQCAgnFfFmdvvt3oiSee0JgxY+Tg4KCVK1dm237y5Ml69dVX5e3trWrVqmncuHGWBzFIN66ajY6OVu/evdWkSRN5eXlpwoQJOnPmjNatW1eUmwZAeT8Bk5KSInd3dw0ZMiTH2wHffvttbd26VRMmTNCXX36pBg0aqFu3blYnaTJ999132rVrl9zc3Ap0uwAAwIMnODhYzz//vDw9PdWkSRN9/PHH+vXXX/XDDz9Y2nTr1k316tWTl5eXXnnlFUVEROiTTz5RamqqiZHjduU1d80cq/jll1/W6tWr9fzzz2vw4ME6duyYVbvAwEBt3rzZ8jdlypRs+5swYQJ5KwDcxe674mzm7Ub169e3TLvV7Ub/lJKSouvXr6t06dKSpOPHjysxMdGqz4ceekg1a9a87T4BFJy8noDx8/NTRESEgoODs33AxtWrV/Xtt99q2LBhqlu3rqpWrap+/fqpatWq+ve//23V9vTp0xo7dqwmTZqk4sWLF8r2AQCAu4+zs7Ps7OyyFNSSk5OzXB2bycXFJctVtcnJySpTpkyO66lcubKcnZ31xx9/5NimZs2aun79uo4fP377GwDT5DV3vXms4mrVqmngwIHy9vbWt99+a9Uuc6zizL/M368327hxo7Zs2aKIiIhC2TYAwJ2774qz+bnd6J8mTZokNzc3SzE2MTHR0kd++wRQMAriBMw/Xb9+Xenp6SpRooTV9BIlSmjHjh2W1xkZGRo2bJjCwsL05JNP5m8DAADAPcne3l4+Pj6Wu+skWe62q1WrVrbL+Pv7Ky4uzmpaXFxcrnnEqVOn9Ndff+X68K+9e/fK1tY2y+8T3H3yk7vu3LlTAQEBVtMCAgIsz0jJlDlWcfPmzTVq1CidO3fOan5SUpJGjhypCRMmyMHBoYC2CABQ0BhB/h/mzp2rNWvWKDo6OkuhpqAZhqHLly8X6jqkG//5Ozo6Fvp6UPhSUlKUkZFhdhimSkxMVHp6upycnKw+Pw8//LB+//33W36mMjIylJqaqpSUFEk33lMHBwf5+flpxowZqlChgh555BGtXbtWO3fuVOXKlS19Lly4UDY2NgoJCdHly5ctfRXF5/hewHfN/aWovm84bu4vRXHclCxZslD7B3LTrVs3RUREqEaNGvLz89OSJUuUkpKitm3bSpKGDx+ucuXKaciQIZKkLl26qHPnzlq4cKEaNWqkNWvWaM+ePXrvvfckSZcvX9bMmTPVvHlzubi46NixY5o4caKqVq2qwMBASVJ8fLx27dqlZ555RiVLllR8fLzGjx+vF154IdsrJXF3ye3ioUOHDmW7zO2OVdy0aVO5u7vr2LFjmjJlinr06KFPP/1UdnZ2MgxDkZGR6tixo3x9fbnKGgDuYvddcTY/txtlWrBggebOnatFixbJy8vLMj3zrHVycrLVWD3JyclW7fLKxsaGHxjIEwoYNx7cJd14L27+/BQvXly2tra3/EzZ2trK3t7e8l46OjrKyclJkydP1ogRI9S8eXPZ2dmpevXqCg4O1u7du1WyZEn99ttvWrZsmVatWqVSpUpZ9cXnGPcjvm+QHxw3uN+1bNlSZ8+eVVRUlBITE+Xt7a358+dbfmecPHlStrZ/35xYu3ZtTZo0SdOmTdOUKVP06KOPasqUKZb2dnZ2OnDggFavXq2LFy/Kzc1NDRo00IABAyxDMdnb22vNmjWaOXOmUlNT5e7urq5du6pbt25F/wbgrhEcHGz5d+YDwZo0aWK5mjYmJkaXL19Wr169TIwSAHA77rvi7M23GzVp0kTS37cbhYaG5rjcvHnzNGfOHC1YsEC+vr5W89zd3eXq6qpt27bJ29tb0o0C0a5du/TKK68U3sYAyOJOTsDkpkqVKvrkk0905coVXbp0SW5ubho4cKAqV64sSfrpp5+UnJysoKAgyzLp6en68MMPFR0drfXr1+d73QAA4N4RGhqa4++KmJiYLNNatGihFi1aWF5fuXJFe/fulSQ5ODhowYIFua7Px8dHy5cvv4OIYSYzxioOCAhQXFycdu7cmeW3bUhIiFq3bq0PP/wwfxsEAChw911xVsr77UZz585VVFSUJk+erEqVKlnGmHVyclLJkiVlY2OjLl26aPbs2apatarc3d01ffp0ubm5WQrAAIpGfk/A3C4nJyc5OTnp/Pnz2rx5s4YNGyZJatOmjdVYYZIUFhamNm3aWL5bAAAAgJvlJ3fNHKu4a9eulml5Hav47bff1sCBAy3zz5w5o7CwME2dOlU1a9a88w0DABSY+7I4m9fbjZYtW6a0tDT179/fqp++ffuqX79+kqQePXooJSVF77zzji5cuKCnnnpK8+fPL/RxaQFkldcTMKmpqUpISLD8+/Tp09q/f79OnTpluRp+06ZNMgxDjz32mI4ePaoJEybo8ccft/Tp7OwsZ2dnqziKFy8uFxcXPf7440W16QAAALjHmDFWccWKFa1icHJyknTjbrHy5csX1aYDAG7DfVmclfJ2u9Ht3I5sY2OjAQMGaMCAAQUSH4D8y+sJmDNnzujFF1+0vF64cKEWLlwob29vyzAFFy9e1JQpU3Tq1CmVKVNGzZo106BBg1S8ePEi3TYAAADcX8wYqxgAcO+4b4uzAO5veTkB4+7urv3791tNu3m8N+lG0tyyZcs8xcA4swAAALgdRT1W8T9llw8DAO4OtrduAgAAAAAAAAAoaBRnAQAAAAAAAMAEFGcBAAAAAAAAwAQUZwEAAAAAAADABBRnAQAAAAAAAMAEFGcBAAAAAAAAwAQUZwEAAAAAAADABBRnAQAAAAAAAMAEFGcBAAAAAAAAwATFzA4AAAAAAO43p0+f1pkzZ7JMv3r1qg4fPqyMjAw5ODhkme/m5qZy5coVRYgAAOAuQHEWAAAAAArYnDlzNHfu3Dwv17NnT40aNaoQIgIAAHcjhjUAAAAAcFdJzzDMDgF3iH0IAMDt4cpZAAAAAHcVO1sbDVgWr9/PXDI7lHxLK15LHq+Nz/NyW4qXUXDUpkKIqOg84VZK0zvWMjsMAADuCRRnAdzXchvv7cSJE4z3BgDAXer3M5e0+8QFs8O4A3aSyuZ9sQuSLtzL2407Qe4KAA8eirMAcpaRLtnamR3FHXngx3u7D/YhAADALd0nOQ+56/2xHwEgLyjOAsiZrZ20sruUdMDsSPJvV1I+l/tU+vj7go2lqLl4SCHzzY4CAACg8N0PeatE7kruCuABRHEWQO6SDkgnd5kdRb6FP2GjthVt8rycm9Nl6eSfhRARAAAACsU9nrdK5K4A8CCiOAvgvlbOyVA5J54WDAAAgLsfuSsAPHhszQ4AAAAAAAAAAB5EFGcBAAAAAAAAwAQUZwEAAAAAAADABBRnAQAAAAAAAMAEFGcBAAAAAAAAwAQUZwEAAAAAAADABBRnAQAAAAAAAMAEFGcBAAAAAAAAwAQUZwEAAAAAAADABBRnAQAAAAAAAMAEFGcBAAAAAAAAwAQUZwEAAAAAAADABBRnAQAAAAAAAMAEFGcBAAAAAAAAwAQUZwEAAAAAAADABBRnAQAAAJMtXbpUjRs3lq+vr9q1a6dffvkl1/Zff/21/vWvf8nX11etW7fWxo0breZHRkbK09PT6i8sLKwwNwEAAAD5QHEWAAAAMNGaNWs0fvx49enTR7GxsfLy8lJYWJiSk5Ozbb9jxw4NGTJEL7/8slavXq3nn39effr00YEDB6zaBQYGavPmzZa/KVOmFMXmAAAAIA8ozgIAAAAmWrRokdq3b6+QkBA98cQTGjNmjBwcHLRy5cps20dHRyswMFDdu3dXtWrVNHDgQFWvXl2ffPKJVTt7e3u5urpa/kqXLl0UmwMAAIA8oDgLAAAAmCQ1NVW7d+9W/fr1LdNsbW1Vv359xcfHZ7vMzp07FRAQYDWtYcOG2rlzp9W0H374QQEBAWrevLlGjRqlc+fOFXj8AAAAuDPFzA4AAAAAeFCdO3dO6enpKlu2rNX0smXL6tChQ9kuk5SUJBcXlyztk5KSLK8DAwPVtGlTubu769ixY5oyZYp69OihTz/9VHZ2dgW/IQAAAMgXirMAAADAfSY4ONjy78wHgjVp0sRyNW1+GIahy5cvF1SIObK1tZWjo2OhrweFLyUlRRkZGYW+Ho6Z+wvHDfKqqI4ZiePmflJUx03JkiVv2YbiLAAAAGASZ2dn2dnZZXn4V3JycparYzO5uLhYXSV7q/aSVLlyZTk7O+uPP/7Id3HWxsbmtn5gAJkoYCA/OG6QVxwzyI+76bhhzFkAAADAJPb29vLx8dG2bdss0zIyMrRt2zbVqlUr22X8/f0VFxdnNW3r1q3y9/fPcT2nTp3SX3/9JVdX1wKJGwAAAAWD4iwAAABgom7dumn58uWKjY1VQkKCRo8erZSUFLVt21aSNHz4cE2ePNnSvkuXLtq0aZMWLlyohIQEzZgxQ7/99ptCQ0MlSZcvX9aHH36onTt36vjx49q2bZveeOMNVa1aVYGBgaZsIwAAALLHsAYAAACAiVq2bKmzZ88qKipKiYmJ8vb21vz58y3DFJw8eVK2tn9fU1G7dm1NmjRJ06ZN05QpU/Too49q1qxZ8vDwkCTZ2dnpwIEDWr16tS5evCg3Nzc1aNBAAwYMkL29vSnbCAAAgOxRnAUAAABMFhoaarny9Z9iYmKyTGvRooVatGiRbXsHBwctWLCgQOMDAABA4WBYAwAAAAAAAAAwAcVZAAAAAAAAADABxVkAAAAAAAAAMAHFWQAAAAAAAAAwAcVZAAAAAAAAADABxVkAAAAAAAAAMAHFWQAAAAAAAAAwAcVZAAAAAAAAADABxVkAAAAAAAAAMAHFWQAAAAAAAAAwAcVZAAAAAAAAADABxVkAAAAAAAAAMIGNYRiG2UE8iHbs2CHDMGRvb19k6zx14arSrmcU2fpQcIoXs1X5hx3MWfnFk9L1a+asG3emWAnpoQpFvtozV84oNSO1yNeLgmFvay83J7ciX+/106dlpKUV+XpRMGyKF1excuWKZF329vby9PQsknXhb+SuyAvTclfy1nsbuSvyyKy8VSJ3vZcVZd4q3V7uWqyIYsE/2NjYFPk6TSvu4d5mQoKEe5tZCRLubUWZIAHIO3JX3BPIW5EP5K7ID3JXFCSunAUAAAAAAAAAEzDmLAAAAAAAAACYgOIsAAAAAAAAAJiA4iwAAAAAAAAAmIDiLAAAAAAAAACYgOIsAAAAAAAAAJiA4iwAAAAAAAAAmIDiLAAAAAAAAACYgOIsAAAAAAAAAJiA4iwAAAAAAAAAmIDiLAAAAAAAAACYgOIsAAAAAAAAAJiA4iwgadWqVapTp47ZYeAOFPU+fPXVV/Xll19aXnt6emrdunV33O+6devUtGlTeXt767333stxWn6cPXtWAQEBOnXq1B3HWdCOHz8uT09P7d27967sb8aMGWrTpk2B9AXzFNTn9H5z8/tS0J8dAAWPvPXeR956a+St+Ufeev8gd83e/Zi7UpzFHTt79qxGjRql5557TjVq1FCDBg0UFhamn3/+WdK98YXSsmVLffPNN2aHYYpb7T+JffhP33//vZKSkhQcHFzgfb/zzjtq3ry5NmzYoAEDBuQ4LT8eeeQRvfjii4qKiiqocG9LZGSkPD09LX/16tVTWFiY9u3bV6Rx3InXX39dixcvNjuMHF27dk2RkZFq3bq1qlevrjfeeCPbdqmpqZo6daqCgoJUo0YNNW7cWCtWrCiyOG8+Fnx8fNS4cWNNmDBB165dK7IYzHA737N3iwoVKmjz5s168sknzQ4FKBTkrfc28ta8I2/NG/LWwnev5K0SuSu5a9EpZnYAuPf169dPaWlp+uCDD1S5cmUlJydr27Zt+uuvv267j9TUVNnb2xdekLfg4OAgBwcH09ZvpoLYf9KDtQ9jYmIUEhIiW9uCPb91+fJlJScnq2HDhipXrlyO0/Ijc/+0bdtWbdu21fDhw1WmTJkCivzWAgMDNX78eElSUlKSpk2bpvDwcG3YsKHIYrgTJUuWVMmSJc0OI0fp6ekqUaKEOnfunOuPvQEDBig5OVnvvfeeqlSposTERGVkZBRhpH8fC9evX9fu3bsVEREhGxsbDRs2rEjjKEoF9T1bFOzs7OTq6mp2GEChIW+9t5G35h15a96RtxaueylvlchdyV2LiAHcgfPnzxseHh7G9u3bs50fFBRkeHh4WP6CgoIMwzCMqKgo44UXXjCWL19uBAUFGZ6enpb+RowYYdSrV8+oVauW0blzZ2Pv3r2W/v744w8jPDzcCAgIMPz9/Y22bdsaW7ZsybLOWbNmGcOGDTP8/f2N5557zli3bp2RnJxshIeHG/7+/karVq2MX375xbLMypUrjaeeesryOjO+2NhYIygoyKhdu7YxcOBA4+LFi5Y2Fy9eNAYPHmzUrFnTaNCggbFo0SIjNDTUGDdu3J2/sUXkVvvPMNiH/5ScnGx4enoaBw4csJru4eFhLF261AgLCzN8fX2Nxo0bG19//bVlflxcnOHh4WGcP3/eMm3Pnj2Gh4eHcezYMcv8m/9ymmYYhvHjjz8ar7zyiuHr62s8++yzxtixY43Lly9bvYczZ840hg0bZtSqVcuIiIiwzGvcuLGxfPnyHLexoEVERBi9e/e2mvbjjz8aHh4eRnJysmEYhnHs2DHDw8PD2LNnj6XN9u3bjZCQEMPHx8do0KCBMXHiRCMtLc0yPz093Zg7d67RpEkTw8fHx2jUqJHx0UcfZdvf9evXjcjISKN58+bGn3/+mW2ccXFxRkhIiFGzZk3jqaeeMjp06GAcP37cMIy/j6dM/9wvN382DMMw9u/fb4SFhRn+/v5GQECAMXToUMu2Frbs3m/DMIyNGzcaTz31lHHu3LkiiSM72cXWt29f48UXX7S8Pnv2rDFo0CCjYcOGhp+fn9GqVSvjyy+/tFomNDTUGDt2rPHhhx8adevWNerXr29ERUVZtTl8+LDRqVMno0aNGkaLFi2MzZs3Gx4eHsZ3331nabNv3z6jc+fOhq+vr/H0008bb7/9tnHp0qUs8c6ePdsICAgwnnrqKWPGjBlGWlqa8cEHHxh169Y1AgMDjRUrVuS4zbfzPWsYhrFw4UKjVatWRs2aNY1nn33WGDVqlFUsmd9x69evN5o1a2b4+fkZ/fr1M65cuWKsWrXKCAoKMurUqWOMHTvWuH79umW5zO+CQYMGGTVr1jQaNmxofPLJJ1brvvl9+ednJ/N7aOvWrcZLL71k+Pn5GR06dDASEhKs+pg1a5bxzDPPGP7+/saIESOMiRMnWn1mgLsBeSt564O2D8lb8468lbz1ZuSuOSN3LVgMa4A74uTkJCcnJ61bt06pqalZ5mfedjB+/Hht3rzZ6jaEo0eP6ptvvtHMmTO1evVqSX+fHZs3b55WrVolHx8fvfbaa5YzNFeuXFGjRo20ePFixcbGKjAwUOHh4Tpx4oTVepcsWaLatWsrNjZWjRo10vDhwzV8+HC98MILWrVqlapUqaKIiAgZhpHjth09elTff/+95syZo48//lg//vij5s2bZ5n/wQcfKD4+XrNnz9bChQv1008/affu3fl9K01xq/0nsQ//6eeff5ajo6OqVauWZd706dPVvHlzff7552rdurUGDx6shISEXPvLVKtWLa1du1bSjXGiNm/enOO0o0ePqkePHmrWrJm++OILTZ06VT///LPGjh1r1efChQvl5eWl1atXW90u5OfnZ+otKZcvX9YXX3yhqlWr5ngVxOnTp9WzZ0/5+vrq888/1+jRo7VixQrNnj3b0mby5MmaN2+e3njjDa1Zs0aTJk2Si4tLlr5SU1M1YMAA7du3T//+979VsWLFLG2uX7+uPn36qG7duvriiy/06aefqkOHDrKxsck2vs2bN1v+vvvuO1WtWtUydtyFCxf02muvqXr16lqxYoXmz5+v5ORkDRw4MMf35MSJE6pVq1auf3PmzMnlXb219evXq0aNGpo/f74CAwPVvHlzffjhh7p69eod9XsnDhw4oPj4eBUvXtwyLTU1VT4+Ppo7d66++uortW/fXsOHD9cvv/xitWxsbKycnJy0fPlyDRs2TLNmzdKWLVskSRkZGerXr5+KFy+uzz77TGPGjNGkSZOslr9y5YrCwsJUunRprVixQtOmTdPWrVuzfI7i4uJ05swZffLJJ4qMjNSMGTPUq1cvlS5dWsuXL1fHjh01atSoHMfEu53vWUmysbHRW2+9pa+++koffPCB4uLiNHHiRKs2V69eVUxMjKZOnar58+dr+/bt6tu3rzZu3Ki5c+dqwoQJWrZsWZarUBYsWCAvLy/FxsaqZ8+eeu+99yzv1e2aOnWqIiMjtXLlStnZ2WnEiBGWeV988YXmzJmjoUOHatWqVapQoYL+85//5Kl/oCiQt5K3Pmj7kLz1zpG3ZvWg5q0SuevNyF0LmGllYdw31q5da9StW9fw9fU1OnToYEyePNnqjPM/z/YYxo2zeT4+PlZn5H788Uejdu3axrVr16zaNmnSxFi2bFmO6w8ODjZiYmIsr4OCgoyhQ4daXp85c8bw8PAwpk2bZpkWHx9veHh4GGfOnDEMI/uz1zVr1rQ6W/3hhx8a7dq1MwzjxplrHx8fqzPMFy5cMGrWrHlPXYFgGLfef4bBPrzZokWLjOeffz7LdA8PD+Odd96xmtauXTtj1KhRhmHc+goEw/j7LGXmVQY5TRsxYoQxcuRIq3X9+OOPhpeXl3H16lXDMG68h2+88Ua22/D+++8boaGhOW5jQYuIiDC8vb0Nf39/w9/f3/Dw8DAaNGhg/Pbbb5Y2/zzjOWXKFKN58+ZGRkaGpc0nn3xi+Pv7G+np6cbFixeNGjVq5HglRWZ/P/74o/Haa68Zr7zyinHhwoUcYzx37lyuZ4j/eQVCpoyMDKNPnz7GSy+9ZKSkpBiGceMs7Ouvv27V7uTJk4aHh4dx6NChbPtPS0szjhw5kuvf7V45kNMVCK+//rpRo0YNo2fPnsauXbuMDRs2GEFBQUZkZORt9VsQbj4WatSoYXh4eBheXl7G2rVrc12uZ8+exgcffGB5HRoaarzyyitWbUJCQoyJEycahmEYmzZtMqpXr26cOnXKMn/jxo1W32WffvqpUbduXasrdzZs2GB4eXkZiYmJlniDgoKM9PR0S5vmzZsbnTp1sry+fv264e/vb3z11Vc5xn8737P/9PXXXxtPP/205fXKlSsNDw8P448//rBMGzlypFGzZk2rqxRef/11q++HoKAgIywszKrvgQMHGt27d7e8vt2rD25+nzw8PCzfN+3atTPGjBljtY6OHTty5SzuSuStN5C3Phj7kLw178hbyVv/GR+5K7lrUWDMWdyx5s2b67nnntNPP/2knTt3atOmTZo/f77GjRuntm3b5rhcxYoV9cgjj1he79+/X1euXFG9evWs2l29elVHjx6VdOPM5cyZM7VhwwYlJiYqPT1dV69ezXL22tPT0/LvzDOSHh4elmlly5aVJCUnJ+c4PkmlSpVUqlQpy2s3NzclJydLuvFEwLS0NPn5+VnmP/TQQ3rsscdy3N67VX73n/Rg7sNr166pRIkS2c6rVauW1Wt/f/9CeWrkvn37tH//fqun7hqGoYyMDB0/ftxydUSNGjWyXd7BwaHIzzrXq1dPo0ePliSdP39e//nPf9SjRw999tlnqlSpUpb2CQkJqlWrltUVAE899ZSuXLmiU6dOKSkpSampqXrmmWdyXe+QIUNUvnx5LVmyJNex3cqUKaO2bdsqLCxMDRo0UEBAgFq0aCE3N7dc+58yZYp27typlStXWvrft2+ftm/fnuV4kG5cFZPdMVasWDFVrVo113XdKcMwZGNjo0mTJumhhx6SdOMhB/3799eoUaOKbOy7zGMhJSVFixcvlp2dnZo3b26Zn56erjlz5mjt2rU6ffq00tLSlJqamiW+m78jJMnV1dXy+U5ISFD58uWtxrv75/5ISEiQp6ennJycLNNq166tjIwMHT582PK988QTT1iN0+fi4mL1wAE7OzuVKVPGsu7s3M737NatW/Xxxx/r0KFDunTpktLT03Xt2jWlpKTI0dFRkuTo6KgqVapYxVKpUiWrceVcXFx09uxZq/X7+/tneb1kyZIc483Oze935nducnKyKlasqMOHD6tTp05W7f38/BQXF5endQBFgbz1BvLWB2MfkrfmD3nrDeStN5C7krsWBYqzKBAlSpRQgwYN1KBBA/Xp00dvvfWWZsyYkWuSlPmBzXT58mW5uroqJiYmS9vML+QPP/xQW7duVUREhKpUqSIHBwf1799faWlpVu2LFfv70M78T/LmWw8ypxm53Fp0cx+Zcmt/L8vP/pMezH3o7Oys8+fP53m5zP8gb17/P7f5dl25ckUdO3ZU586ds8yrUKGC5d//3D+Z/vrrL6sfJ0XB0dHRKonz8fFRnTp1tHz5cg0aNCjP/eX0Q+OfGjVqpC+++ELx8fEKCAjIte348ePVuXNnbdq0SV9//bWmTZumRYsWZUkOMn3++edavHixYmJirBKpK1euKCgoSEOHDs2yTE4/yE6cOHHLpyj36tVL4eHhubbJjaurq8qVK2f5LEpStWrVZBiGTp06pUcffTTffefFzcfC+++/rzZt2uizzz5Tu3btJN24jSk6OlojRoyQp6enHB0d9f777+f6HSHd+E4ojO/o7NaT3bRbPaAit+/Z48ePq1evXnrllVc0aNAglS5dWj///LPeeustpaWlWT7LBRVLfmT3nWzGQzmAgkDeem8jb7195K35Q956A3nrDeSu5K5FgeIsCsUTTzyhdevWSbqRmKSnp99yGR8fHyUlJcnOzk7u7u7ZtomPj9dLL72kpk2bSrqRVP35558FF/htcnd3V/HixfXrr79axgG6ePGijhw5Yhm/51528/6T2Ic38/b2VlJSks6fP6/SpUtbzdu5c6defPFFy+tdu3bJ29tbkixJZWJiomW5ffv25Sv26tWr6/fff8/3GeuDBw/q6aefzteyBcXGxkY2Nja6du1atvOrVaumb775xnLWXLoxblrJkiVVvnx5lS1bVg4ODoqLi1PlypVzXM8rr7yiJ598Um+88YY+/vjjW2539erVVb16dfXq1UsdOnTQV199lW2SGx8fr7ffflvvvvtulvk+Pj765ptvVKlSpWx/aGXHzc3NMv5dTv55vOVV7dq1tXbtWl2+fNlytvrw4cOytbVV+fLl76jv/LK1tVWvXr30wQcfqHXr1nJwcNCOHTv0/PPPq02bNpJuJFFHjhzJdry8nFSrVk2nTp3SmTNnLFeR7Ny5M0ub2NhYXblyxXIFwo4dO2Rra1skV5Pd/D27e/duGYahyMhIyw/ir7/+usDWtWvXriyv8/J+3spjjz2mX3/91er779dffy2w/oHCRt56byNvJW8tbOSt1h7UvFUidyV3LTw8EAx35Ny5c+rSpYs+//xz7du3T8eOHdPXX3+t+fPn6/nnn5d04xadbdu2KTExMdczt/Xr15e/v7/69OmjzZs36/jx49qxY4emTp1q+aBUrVpV3333nfbu3at9+/ZpyJAhppz9KFWqlF588UVNmDBBcXFxOnjwoN566y3Lf9z3itvZfxL78GbVq1eXs7OzduzYkWXe2rVrtWLFCh0+fFhRUVH65ZdfFBoaKkmqUqWKKlSooBkzZujIkSPasGGDFi5cmK/Ye/Toofj4eL377rvau3evjhw5onXr1undd9+95bIpKSnavXu3GjZsmK9151dqaqoSExOVmJiohIQEjR071nKmPjudOnXSqVOnNHbsWCUkJGjdunWaMWOGunXrJltbW5UoUUI9evTQxIkTtXr1ah09elQ7d+7UZ599lqWvzp07a8CAAerVq5d++umnbNd37NgxTZ48WfHx8frzzz+1efNmHTlyRI8//niWtomJierbt6+Cg4PVsGFDy3Zl3o7TqVMnnT9/XoMHD9Yvv/yio0ePatOmTXrzzTdz/LGYeXtYbn85PYQi0++//669e/fqr7/+0sWLF7V3716r2xNbtWqlMmXK6M0339Tvv/+uH3/8URMnTlRISEiR3hr2T//6179ka2urpUuXSrrxHbF1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",
      "text/plain": [
       "<Figure size 1400x1000 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Define custom y-axis limits for each task\n",
    "# Adjust these based on your results\n",
    "ylim_dict = {\n",
    "    'Cell line': (0.8, 0.95),\n",
    "    'Drug': (0.0, 0.035),\n",
    "    'MOA (broad)': (0.0, 0.35),\n",
    "    'MOA (fine)': (0.0, 0.09),\n",
    "}\n",
    "\n",
    "# Generate the comparison plot\n",
    "if 'df' in dir() and len(df) > 0:\n",
    "    fig, axes = plot_comparison(\n",
    "        df,\n",
    "        #ylim_dict=ylim_dict,\n",
    "        figsize=(14, 10),\n",
    "        title=\"Data Loading Strategy Comparison\"\n",
    "    )\n",
    "    \n",
    "    # Save figure (both PNG and PDF)\n",
    "    output_path_png = RESULTS_DIR / \"comparison_plot.png\"\n",
    "    output_path_pdf = RESULTS_DIR / \"comparison_plot.pdf\"\n",
    "    fig.savefig(output_path_png, dpi=150, bbox_inches='tight')\n",
    "    fig.savefig(output_path_pdf, bbox_inches='tight')\n",
    "    print(f\"\\nFigure saved to: {output_path_png}\")\n",
    "    print(f\"Figure saved to: {output_path_pdf}\")\n",
    "    \n",
    "    plt.show()\n",
    "else:\n",
    "    print(\"No data available for plotting\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "33b7d1c6",
   "metadata": {},
   "source": [
    "## Training Time Comparison"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "288bbeb3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "No results loaded\n"
     ]
    }
   ],
   "source": [
    "# Plot training time comparison\n",
    "if results:\n",
    "    time_df = get_time_comparison(results)\n",
    "    \n",
    "    if len(time_df) > 0:\n",
    "        fig, ax = plot_time_comparison(time_df)\n",
    "        \n",
    "        # Save figure (both PNG and PDF)\n",
    "        output_path_png = RESULTS_DIR / \"time_comparison.png\"\n",
    "        output_path_pdf = RESULTS_DIR / \"time_comparison.pdf\"\n",
    "        fig.savefig(output_path_png, dpi=150, bbox_inches='tight')\n",
    "        fig.savefig(output_path_pdf, bbox_inches='tight')\n",
    "        print(f\"Figure saved to: {output_path_png}\")\n",
    "        print(f\"Figure saved to: {output_path_pdf}\")\n",
    "        \n",
    "        plt.show()\n",
    "    else:\n",
    "        print(\"No timing data available\")\n",
    "else:\n",
    "    print(\"No results loaded\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f1888573",
   "metadata": {},
   "source": [
    "## Training Curves"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "ad099f42",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "No results loaded\n"
     ]
    }
   ],
   "source": [
    "# Plot training curves for each task\n",
    "if results:\n",
    "    tasks = ['cell_line', 'drug', 'moa_broad', 'moa_fine']\n",
    "    \n",
    "    fig, axes = plt.subplots(2, 2, figsize=(14, 10))\n",
    "    axes = axes.flatten()\n",
    "    \n",
    "    for idx, task in enumerate(tasks):\n",
    "        ax = axes[idx]\n",
    "        \n",
    "        for strategy, result in results.items():\n",
    "            if result.get('status') != 'success':\n",
    "                continue\n",
    "            \n",
    "            history = result.get('history', {})\n",
    "            metric_key = f'val_{task}_f1_macro'\n",
    "            \n",
    "            if metric_key in history:\n",
    "                values = history[metric_key]\n",
    "                epochs = list(range(1, len(values) + 1))\n",
    "                label = STRATEGY_DISPLAY_NAMES.get(strategy, strategy).replace('\\n', ' ')\n",
    "                ax.plot(epochs, values, label=label, marker='o', markersize=4)\n",
    "        \n",
    "        task_name = TASK_DISPLAY_NAMES.get(task, task)\n",
    "        ax.set_xlabel('Epoch')\n",
    "        ax.set_ylabel('Macro F1-score')\n",
    "        ax.set_title(task_name)\n",
    "        ax.legend(loc='best', fontsize=8)\n",
    "    \n",
    "    plt.suptitle('Training Curves by Task', fontsize=14, fontweight='bold', y=1.02)\n",
    "    plt.tight_layout()\n",
    "    \n",
    "    # Save figure (both PNG and PDF)\n",
    "    output_path_png = RESULTS_DIR / \"training_curves.png\"\n",
    "    output_path_pdf = RESULTS_DIR / \"training_curves.pdf\"\n",
    "    fig.savefig(output_path_png, dpi=150, bbox_inches='tight')\n",
    "    fig.savefig(output_path_pdf, bbox_inches='tight')\n",
    "    print(f\"Figure saved to: {output_path_png}\")\n",
    "    print(f\"Figure saved to: {output_path_pdf}\")\n",
    "    \n",
    "    plt.show()\n",
    "else:\n",
    "    print(\"No results loaded\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cf17fd9c",
   "metadata": {},
   "source": [
    "## Export Results to CSV"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "08e88035",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Results exported to: /path/to/scDataset/training_experiments/results/main/comparison_results.csv\n",
      "Pivot table exported to: /path/to/scDataset/training_experiments/results/main/comparison_pivot.csv\n",
      "\n",
      "Pivot Table:\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>Task</th>\n",
       "      <th>Cell line</th>\n",
       "      <th>Drug</th>\n",
       "      <th>MOA (broad)</th>\n",
       "      <th>MOA (fine)</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Block size = 16\\nFetch factor = 256</th>\n",
       "      <td>0.937303</td>\n",
       "      <td>0.030375</td>\n",
       "      <td>0.269811</td>\n",
       "      <td>0.102874</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Random Sampling</th>\n",
       "      <td>0.937471</td>\n",
       "      <td>0.029913</td>\n",
       "      <td>0.267989</td>\n",
       "      <td>0.102968</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Streaming</th>\n",
       "      <td>0.934983</td>\n",
       "      <td>0.002324</td>\n",
       "      <td>0.203708</td>\n",
       "      <td>0.054845</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Streaming (buffer)</th>\n",
       "      <td>0.934989</td>\n",
       "      <td>0.002065</td>\n",
       "      <td>0.194217</td>\n",
       "      <td>0.054212</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "Task                                 Cell line      Drug  MOA (broad)  \\\n",
       "Method                                                                  \n",
       "Block size = 16\\nFetch factor = 256   0.937303  0.030375     0.269811   \n",
       "Random Sampling                       0.937471  0.029913     0.267989   \n",
       "Streaming                             0.934983  0.002324     0.203708   \n",
       "Streaming (buffer)                    0.934989  0.002065     0.194217   \n",
       "\n",
       "Task                                 MOA (fine)  \n",
       "Method                                           \n",
       "Block size = 16\\nFetch factor = 256    0.102874  \n",
       "Random Sampling                        0.102968  \n",
       "Streaming                              0.054845  \n",
       "Streaming (buffer)                     0.054212  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Export comparison data to CSV\n",
    "if 'df' in dir() and len(df) > 0:\n",
    "    csv_path = RESULTS_DIR / \"comparison_results.csv\"\n",
    "    df.to_csv(csv_path, index=False)\n",
    "    print(f\"Results exported to: {csv_path}\")\n",
    "    \n",
    "    # Also create a pivot table\n",
    "    pivot_df = df.pivot(index='Method', columns='Task', values='Macro F1-score')\n",
    "    pivot_path = RESULTS_DIR / \"comparison_pivot.csv\"\n",
    "    pivot_df.to_csv(pivot_path)\n",
    "    print(f\"Pivot table exported to: {pivot_path}\")\n",
    "    \n",
    "    print(\"\\nPivot Table:\")\n",
    "    display(pivot_df)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ffe6ef0d",
   "metadata": {},
   "source": [
    "## Summary Statistics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "9d95d4cd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "============================================================\n",
      "SUMMARY STATISTICS\n",
      "============================================================\n",
      "\n",
      "Best method per task:\n",
      "  Cell line: Random Sampling (F1 = 0.9375)\n",
      "  Drug: Block size = 16 Fetch factor = 256 (F1 = 0.0304)\n",
      "  MOA (broad): Block size = 16 Fetch factor = 256 (F1 = 0.2698)\n",
      "  MOA (fine): Random Sampling (F1 = 0.1030)\n",
      "\n",
      "Mean performance across all tasks:\n",
      "  Block size = 16 Fetch factor = 256: 0.3351\n",
      "  Random Sampling: 0.3346\n",
      "  Streaming: 0.2990\n",
      "  Streaming (buffer): 0.2964\n",
      "\n",
      "============================================================\n"
     ]
    }
   ],
   "source": [
    "# Print summary statistics\n",
    "if 'df' in dir() and len(df) > 0:\n",
    "    print(\"\\n\" + \"=\"*60)\n",
    "    print(\"SUMMARY STATISTICS\")\n",
    "    print(\"=\"*60)\n",
    "    \n",
    "    # Best method per task\n",
    "    print(\"\\nBest method per task:\")\n",
    "    for task in df['Task'].unique():\n",
    "        task_data = df[df['Task'] == task]\n",
    "        best_idx = task_data['Macro F1-score'].idxmax()\n",
    "        best_row = df.loc[best_idx]\n",
    "        print(f\"  {task}: {best_row['Method'].replace(chr(10), ' ')} (F1 = {best_row['Macro F1-score']:.4f})\")\n",
    "    \n",
    "    # Overall method comparison\n",
    "    print(\"\\nMean performance across all tasks:\")\n",
    "    mean_by_method = df.groupby('Method')['Macro F1-score'].mean().sort_values(ascending=False)\n",
    "    for method, score in mean_by_method.items():\n",
    "        print(f\"  {method.replace(chr(10), ' ')}: {score:.4f}\")\n",
    "    \n",
    "    print(\"\\n\" + \"=\"*60)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5d7b25a7",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "scenv",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
