{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "3984513a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import re\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "3226b95e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import csv\n",
    "import logging\n",
    "from typing import Dict, List, Tuple\n",
    "\n",
    "import numpy as np\n",
    "import pytrec_eval\n",
    "\n",
    "def evaluate(\n",
    "    qrels: Dict[str, Dict[str, int]],\n",
    "    results: Dict[str, Dict[str, float]],\n",
    "    k_values: List[int],\n",
    ") -> Tuple[Dict[str, float], Dict[str, float], Dict[str, float], Dict[str, float]]:\n",
    "    \"\"\"\n",
    "    仿照 beir.retrieval.evaluation.EvaluateRetrieval.evaluate 编写的评估函数。\n",
    "    \"\"\"\n",
    "    ndcg = {}\n",
    "    _map = {}\n",
    "    recall = {}\n",
    "    precision = {}\n",
    "\n",
    "    for k in k_values:\n",
    "        ndcg[f\"NDCG@{k}\"] = 0.0\n",
    "        _map[f\"MAP@{k}\"] = 0.0\n",
    "        recall[f\"Recall@{k}\"] = 0.0\n",
    "        precision[f\"P@{k}\"] = 0.0\n",
    "\n",
    "    map_string = \"map_cut.\" + \",\".join([str(k) for k in k_values])\n",
    "    ndcg_string = \"ndcg_cut.\" + \",\".join([str(k) for k in k_values])\n",
    "    recall_string = \"recall.\" + \",\".join([str(k) for k in k_values])\n",
    "    precision_string = \"P.\" + \",\".join([str(k) for k in k_values])\n",
    "    evaluator = pytrec_eval.RelevanceEvaluator(\n",
    "        qrels, {map_string, ndcg_string, recall_string, precision_string}\n",
    "    )\n",
    "    scores = evaluator.evaluate(results)\n",
    "\n",
    "    for query_id in scores.keys():\n",
    "        for k in k_values:\n",
    "            ndcg[f\"NDCG@{k}\"] += scores[query_id][\"ndcg_cut_\" + str(k)]\n",
    "            _map[f\"MAP@{k}\"] += scores[query_id][\"map_cut_\" + str(k)]\n",
    "            recall[f\"Recall@{k}\"] += scores[query_id][\"recall_\" + str(k)]\n",
    "            precision[f\"P@{k}\"] += scores[query_id][\"P_\" + str(k)]\n",
    "\n",
    "    for k in k_values:\n",
    "        ndcg[f\"NDCG@{k}\"] = round(ndcg[f\"NDCG@{k}\"] / len(scores), 5)\n",
    "        _map[f\"MAP@{k}\"] = round(_map[f\"MAP@{k}\"] / len(scores), 5)\n",
    "        recall[f\"Recall@{k}\"] = round(recall[f\"Recall@{k}\"] / len(scores), 5)\n",
    "        precision[f\"P@{k}\"] = round(precision[f\"P@{k}\"] / len(scores), 5)\n",
    "\n",
    "    # for eval_metric in [ndcg, _map, recall, precision]:\n",
    "    #     logging.info(\"\\n\")\n",
    "    #     for k, v in eval_metric.items():\n",
    "    #         logging.info(f\"{k}: {v:.4f}\")\n",
    "\n",
    "    return recall\n",
    "\n",
    "\n",
    "def load_gt(gt_path: str) -> Dict[str, Dict[str, int]]:\n",
    "    \"\"\"\n",
    "    加载 ground-truth npy 文件并转换为 pytrec_eval 所需的 qrels 格式。\n",
    "    查询ID将使用其在npy文件中的索引（0, 1, 2, ...）。\n",
    "    \"\"\"\n",
    "    gt_data = np.load(gt_path, allow_pickle=True)\n",
    "    gt_data = gt_data.reshape(-1, 1)\n",
    "    # gt_data = gt_data[:1000]\n",
    "    qrels = {}\n",
    "    for i, gt_list in enumerate(gt_data):\n",
    "        query_id = str(i)\n",
    "        qrels[query_id] = {}\n",
    "        for passage_id in gt_list:\n",
    "            qrels[query_id][str(passage_id)] = 1  # 假设相关性得分为1\n",
    "    return qrels\n",
    "\n",
    "\n",
    "def load_results(results_path: str) -> Dict[str, Dict[str, float]]:\n",
    "    \"\"\"\n",
    "    加载检索结果的tsv文件并转换为 pytrec_eval 所需的 results 格式。\n",
    "    - 如果文件有4列 (query_id, passage_id, rank, score)，则使用第四列的分数。\n",
    "    - 如果文件只有3列 (query_id, passage_id, rank)，则使用 1/rank 作为分数。\n",
    "    \"\"\"\n",
    "    results = {}\n",
    "    with open(results_path, \"r\", encoding=\"utf-8\") as f:\n",
    "        reader = csv.reader(f, delimiter=\"\\t\")\n",
    "        for row in reader:\n",
    "            if not row: continue # Skip empty lines\n",
    "\n",
    "            query_id, passage_id = row[0], row[1]\n",
    "            \n",
    "            if query_id not in results:\n",
    "                results[query_id] = {}\n",
    "            \n",
    "            # 判断使用真实分数还是生成代理分数\n",
    "            if len(row) == 4:\n",
    "                score = float(row[3])\n",
    "            elif len(row) == 3:\n",
    "                rank = int(row[2])\n",
    "                score = 1.0 / rank\n",
    "            else:\n",
    "                logging.warning(f\"Skipping malformed line with {len(row)} columns: {row}\")\n",
    "                continue\n",
    "            \n",
    "            results[query_id][passage_id] = score\n",
    "            \n",
    "    return results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "e7ba3ccd",
   "metadata": {},
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: '/data/lijunlin/sigmod2025-results/answer'",
     "output_type": "error",
     "traceback": [
      "\u001b[31m---------------------------------------------------------------------------\u001b[39m",
      "\u001b[31mFileNotFoundError\u001b[39m                         Traceback (most recent call last)",
      "\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[8]\u001b[39m\u001b[32m, line 12\u001b[39m\n\u001b[32m      7\u001b[39m dataset_keyword = \u001b[33m\"\u001b[39m\u001b[33mclip-multi-clustering-IGP\u001b[39m\u001b[33m\"\u001b[39m\n\u001b[32m      9\u001b[39m \u001b[38;5;66;03m# Collect full paths for matching files\u001b[39;00m\n\u001b[32m     10\u001b[39m matching_paths = [\n\u001b[32m     11\u001b[39m     os.path.join(base_dir, f)\n\u001b[32m---> \u001b[39m\u001b[32m12\u001b[39m     \u001b[38;5;28;01mfor\u001b[39;00m f \u001b[38;5;129;01min\u001b[39;00m os.listdir(base_dir)\n\u001b[32m     13\u001b[39m     \u001b[38;5;28;01mif\u001b[39;00m f.startswith(dataset_keyword + \u001b[33m\"\u001b[39m\u001b[33m-\u001b[39m\u001b[33m\"\u001b[39m) \u001b[38;5;129;01mand\u001b[39;00m f.endswith(\u001b[33m\"\u001b[39m\u001b[33m.tsv\u001b[39m\u001b[33m\"\u001b[39m)\n\u001b[32m     14\u001b[39m ]\n\u001b[32m     16\u001b[39m \u001b[38;5;66;03m# Print results\u001b[39;00m\n\u001b[32m     17\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m matching_paths:\n",
      "\u001b[31mFileNotFoundError\u001b[39m: [Errno 2] No such file or directory: '/data/lijunlin/sigmod2025-results/answer'"
     ]
    }
   ],
   "source": [
    "import os\n",
    "\n",
    "# Base directory\n",
    "base_dir = \"/data/lijunlin/sigmod2025-results/answer\"\n",
    "\n",
    "# Dataset keyword to filter by (e.g., \"clip\", \"clerc\", \"multiqa_med\")\n",
    "dataset_keyword = \"clip-multi-clustering-IGP\"\n",
    "\n",
    "# Collect full paths for matching files\n",
    "matching_paths = [\n",
    "    os.path.join(base_dir, f)\n",
    "    for f in os.listdir(base_dir)\n",
    "    if f.startswith(dataset_keyword + \"-\") and f.endswith(\".tsv\")\n",
    "]\n",
    "\n",
    "# Print results\n",
    "if matching_paths:\n",
    "    print(f\"Found {len(matching_paths)} files for dataset '{dataset_keyword}':\\n\")\n",
    "    for path in sorted(matching_paths):\n",
    "        print(path)\n",
    "else:\n",
    "    print(f\"No files found for dataset '{dataset_keyword}'.\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "e842b785",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-10-17 15:41:18 - Loading ground-truth file /home/ali/hnswlib/evaluation/clerc_gt.npy...\n",
      "2025-10-17 15:41:18 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_1024-n_bit_2-nprobe_32-probe_topk_1000.tsv ...\n",
      "2025-10-17 15:41:18 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_1024-n_bit_2-nprobe_32-probe_topk_1000.tsv\n",
      "2025-10-17 15:41:18 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_256-probe_topk_1000.tsv ...\n",
      "2025-10-17 15:41:19 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_256-probe_topk_1000.tsv\n",
      "2025-10-17 15:41:19 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_256-probe_topk_10000.tsv ...\n",
      "2025-10-17 15:41:19 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_256-probe_topk_10000.tsv\n",
      "2025-10-17 15:41:19 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_32-probe_topk_1000.tsv ...\n",
      "2025-10-17 15:41:19 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_32-probe_topk_1000.tsv\n",
      "2025-10-17 15:41:19 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_32-probe_topk_10000.tsv ...\n",
      "2025-10-17 15:41:19 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_32-probe_topk_10000.tsv\n",
      "2025-10-17 15:41:19 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_32-probe_topk_100000.tsv ...\n",
      "2025-10-17 15:41:19 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_32-probe_topk_100000.tsv\n",
      "2025-10-17 15:41:19 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_1024-probe_topk_1000.tsv ...\n",
      "2025-10-17 15:41:20 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_1024-probe_topk_1000.tsv\n",
      "2025-10-17 15:41:20 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_1024-probe_topk_10000.tsv ...\n",
      "2025-10-17 15:41:20 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_1024-probe_topk_10000.tsv\n",
      "2025-10-17 15:41:20 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_256-probe_topk_1000.tsv ...\n",
      "2025-10-17 15:41:20 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_256-probe_topk_1000.tsv\n",
      "2025-10-17 15:41:20 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_256-probe_topk_10000.tsv ...\n",
      "2025-10-17 15:41:20 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_256-probe_topk_10000.tsv\n",
      "2025-10-17 15:41:20 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_256-probe_topk_100000.tsv ...\n",
      "2025-10-17 15:41:20 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_256-probe_topk_100000.tsv\n",
      "2025-10-17 15:41:20 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_32-probe_topk_1000.tsv ...\n",
      "2025-10-17 15:41:21 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_32-probe_topk_1000.tsv\n",
      "2025-10-17 15:41:21 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_32-probe_topk_10000.tsv ...\n",
      "2025-10-17 15:41:21 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_32-probe_topk_10000.tsv\n",
      "2025-10-17 15:41:21 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_32-probe_topk_100000.tsv ...\n",
      "2025-10-17 15:41:21 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_32-probe_topk_100000.tsv\n",
      "2025-10-17 15:41:21 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_1024-probe_topk_2000.tsv ...\n",
      "2025-10-17 15:41:21 - ✅ Finished evaluating clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_1024-probe_topk_2000.tsv\n",
      "2025-10-17 15:41:21 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_1024-probe_topk_20000.tsv ...\n",
      "2025-10-17 15:41:22 - ✅ Finished evaluating clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_1024-probe_topk_20000.tsv\n",
      "2025-10-17 15:41:22 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_1024-probe_topk_200000.tsv ...\n",
      "2025-10-17 15:41:22 - ✅ Finished evaluating clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_1024-probe_topk_200000.tsv\n",
      "2025-10-17 15:41:22 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_128-probe_topk_2000.tsv ...\n",
      "2025-10-17 15:41:22 - ✅ Finished evaluating clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_128-probe_topk_2000.tsv\n",
      "2025-10-17 15:41:22 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_128-probe_topk_20000.tsv ...\n",
      "2025-10-17 15:41:22 - ✅ Finished evaluating clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_128-probe_topk_20000.tsv\n",
      "2025-10-17 15:41:22 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_128-probe_topk_200000.tsv ...\n",
      "2025-10-17 15:41:23 - ✅ Finished evaluating clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_128-probe_topk_200000.tsv\n",
      "2025-10-17 15:41:23 - 🎯 All evaluations completed.\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import logging\n",
    "\n",
    "# --- Logging setup ---\n",
    "logging.basicConfig(\n",
    "    format=\"%(asctime)s - %(message)s\",\n",
    "    datefmt=\"%Y-%m-%d %H:%M:%S\",\n",
    "    level=logging.INFO,\n",
    ")\n",
    "\n",
    "# --- Ground-truth file ---\n",
    "GT_FILE_PATH = \"/home/ali/hnswlib/evaluation/clerc_gt.npy\"\n",
    "\n",
    "# --- Base results folder ---\n",
    "BASE_RESULTS_DIR = \"/data/lijunlin/sigmod2025-results/answer\"\n",
    "\n",
    "# --- Dataset filter ---\n",
    "DATASET_KEYWORD = \"clip-multi-clustering-IGP\"  # Change to e.g. \"clerc\", \"multiqa_med\", etc.\n",
    "\n",
    "# --- Evaluation parameters ---\n",
    "K_VALUES = [10]\n",
    "\n",
    "# --- Your existing functions (assumed imported) ---\n",
    "# from your_module import load_gt, load_results, evaluate\n",
    "\n",
    "# --- Step 1: Collect all matching result files ---\n",
    "result_paths = [\n",
    "    os.path.join(BASE_RESULTS_DIR, f)\n",
    "    for f in os.listdir(BASE_RESULTS_DIR)\n",
    "    if f.startswith(DATASET_KEYWORD + \"-\") and f.endswith(\".tsv\")\n",
    "]\n",
    "\n",
    "if not result_paths:\n",
    "    logging.warning(f\"No result files found for dataset '{DATASET_KEYWORD}'.\")\n",
    "    exit()\n",
    "\n",
    "# --- Step 2: Load GT once ---\n",
    "logging.info(f\"Loading ground-truth file {GT_FILE_PATH}...\")\n",
    "qrels_data = load_gt(GT_FILE_PATH)\n",
    "\n",
    "# --- Step 3: Iterate over all result files ---\n",
    "for path in sorted(result_paths):\n",
    "    logging.info(f\"Evaluating results file: {path} ...\")\n",
    "    try:\n",
    "        results_data = load_results(path)\n",
    "        evaluate(qrels=qrels_data, results=results_data, k_values=K_VALUES)\n",
    "        logging.info(f\"✅ Finished evaluating {os.path.basename(path)}\")\n",
    "    except Exception as e:\n",
    "        logging.error(f\"❌ Failed to evaluate {path}: {e}\")\n",
    "\n",
    "logging.info(\"🎯 All evaluations completed.\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "71f13dfe",
   "metadata": {},
   "outputs": [],
   "source": [
    "algorithms = [\"IGP\", \"Dessert\", \"Plaid\", \"MUVERA\", \"Multi-HNSW\", \"HNSW-D\", \"C-Multi-HNSW\"]\n",
    "datasets = [\"CLERC-128\", \"CLERC-384\", \"CLERC-768\", \"CLERC-1024\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "a3cdff95",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_3491789/3426279967.py:78: FutureWarning: DataFrameGroupBy.apply operated on the grouping columns. This behavior is deprecated, and in a future version of pandas the grouping columns will be excluded from the operation. Either pass `include_groups=False` to exclude the groupings or explicitly select the grouping columns after groupby to silence this warning.\n",
      "  .apply(lambda g: dict(zip(g['passage_id'], g['score'])))\n",
      "/tmp/ipykernel_3491789/3426279967.py:78: FutureWarning: DataFrameGroupBy.apply operated on the grouping columns. This behavior is deprecated, and in a future version of pandas the grouping columns will be excluded from the operation. Either pass `include_groups=False` to exclude the groupings or explicitly select the grouping columns after groupby to silence this warning.\n",
      "  .apply(lambda g: dict(zip(g['passage_id'], g['score'])))\n",
      "/tmp/ipykernel_3491789/3426279967.py:78: FutureWarning: DataFrameGroupBy.apply operated on the grouping columns. This behavior is deprecated, and in a future version of pandas the grouping columns will be excluded from the operation. Either pass `include_groups=False` to exclude the groupings or explicitly select the grouping columns after groupby to silence this warning.\n",
      "  .apply(lambda g: dict(zip(g['passage_id'], g['score'])))\n",
      "/tmp/ipykernel_3491789/3426279967.py:78: FutureWarning: DataFrameGroupBy.apply operated on the grouping columns. This behavior is deprecated, and in a future version of pandas the grouping columns will be excluded from the operation. Either pass `include_groups=False` to exclude the groupings or explicitly select the grouping columns after groupby to silence this warning.\n",
      "  .apply(lambda g: dict(zip(g['passage_id'], g['score'])))\n",
      "/tmp/ipykernel_3491789/3426279967.py:78: FutureWarning: DataFrameGroupBy.apply operated on the grouping columns. This behavior is deprecated, and in a future version of pandas the grouping columns will be excluded from the operation. Either pass `include_groups=False` to exclude the groupings or explicitly select the grouping columns after groupby to silence this warning.\n",
      "  .apply(lambda g: dict(zip(g['passage_id'], g['score'])))\n",
      "/tmp/ipykernel_3491789/3426279967.py:78: FutureWarning: DataFrameGroupBy.apply operated on the grouping columns. This behavior is deprecated, and in a future version of pandas the grouping columns will be excluded from the operation. Either pass `include_groups=False` to exclude the groupings or explicitly select the grouping columns after groupby to silence this warning.\n",
      "  .apply(lambda g: dict(zip(g['passage_id'], g['score'])))\n",
      "/tmp/ipykernel_3491789/3426279967.py:78: FutureWarning: DataFrameGroupBy.apply operated on the grouping columns. This behavior is deprecated, and in a future version of pandas the grouping columns will be excluded from the operation. Either pass `include_groups=False` to exclude the groupings or explicitly select the grouping columns after groupby to silence this warning.\n",
      "  .apply(lambda g: dict(zip(g['passage_id'], g['score'])))\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>Algorithm</th>\n",
       "      <th>QPS</th>\n",
       "      <th>Dataset</th>\n",
       "      <th>Recall</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>MVR-HNSW</td>\n",
       "      <td>1.056848</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0.183</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>MVR-HNSW</td>\n",
       "      <td>1.333156</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0.158</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>MVR-HNSW</td>\n",
       "      <td>1.294716</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0.157</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>MVR-HNSW</td>\n",
       "      <td>1.754940</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0.085</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>MVR-HNSW</td>\n",
       "      <td>0.532422</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0.251</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>MVR-HNSW</td>\n",
       "      <td>0.526837</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0.260</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>MVR-HNSW</td>\n",
       "      <td>1.053719</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0.180</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  Algorithm       QPS     Dataset  Recall\n",
       "0  MVR-HNSW  1.056848  CLERC-1024   0.183\n",
       "1  MVR-HNSW  1.333156  CLERC-1024   0.158\n",
       "2  MVR-HNSW  1.294716  CLERC-1024   0.157\n",
       "3  MVR-HNSW  1.754940  CLERC-1024   0.085\n",
       "4  MVR-HNSW  0.532422  CLERC-1024   0.251\n",
       "5  MVR-HNSW  0.526837  CLERC-1024   0.260\n",
       "6  MVR-HNSW  1.053719  CLERC-1024   0.180"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import os\n",
    "import re\n",
    "import pandas as pd\n",
    "\n",
    "# REQUIRED: you should already have these defined in your notebook\n",
    "# - qrels_data  (from your load_gt)\n",
    "# - K_VALUES    (e.g., [10])\n",
    "# - evaluate(qrels, results, k_values) -> dict of metrics (e.g., {'Recall@10': 0.736})\n",
    "\n",
    "# ----------------------------\n",
    "# Config\n",
    "# ----------------------------\n",
    "directory = \"/data/lijunlin/sigmod2025-results/multi-hnsw-result\"\n",
    "# keyword = \"clip-multi-clustering\"\n",
    "# keyword = \"clip-multi-clustering_HNSW\"\n",
    "# keyword = \"clef_med_HNSW\"\n",
    "# keyword = \"clerc_small_HNSW\"\n",
    "# keyword = \"clerc_HNSW\"\n",
    "keyword = \"clerc_large_HNSW\"\n",
    "\n",
    "# ----------------------------\n",
    "# File pairing\n",
    "# ----------------------------\n",
    "all_files = os.listdir(directory)\n",
    "txt_files = [\n",
    "    f for f in all_files\n",
    "    if f.endswith(\".txt\") and keyword in f and \"metadata\" not in f\n",
    "]\n",
    "\n",
    "file_pairs = {}\n",
    "for f in txt_files:\n",
    "    if f.endswith(\"_summary.txt\"):\n",
    "        base_name = f[:-len(\"_summary.txt\")]\n",
    "        file_pairs.setdefault(base_name, {})[\"summary\"] = os.path.join(directory, f)\n",
    "    else:\n",
    "        base_name = f[:-len(\".txt\")]\n",
    "        file_pairs.setdefault(base_name, {})[\"results\"] = os.path.join(directory, f)\n",
    "\n",
    "# ----------------------------\n",
    "# Helpers\n",
    "# ----------------------------\n",
    "def load_results_tsv(path: str) -> pd.DataFrame:\n",
    "    # Results: query_id, passage_id, rank, score (tab-separated, no header)\n",
    "    return pd.read_csv(\n",
    "        path,\n",
    "        sep=\"\\t\",\n",
    "        header=None,\n",
    "        names=[\"query_id\", \"passage_id\", \"rank\", \"score\"],\n",
    "        dtype={\"query_id\": int, \"passage_id\": int, \"rank\": int, \"score\": float}\n",
    "    )\n",
    "\n",
    "def extract_avg_retrieval_time(summary_text: str) -> float | None:\n",
    "    # Robust parser for avg retrieval time (ms)\n",
    "    patterns = [\n",
    "        r\"Average\\s+Query\\s+Time:\\s*([\\d.]+)\\s*ms\",\n",
    "        r\"Avg\\s*retrieval\\s*time\\s*[:=]\\s*([\\d.]+)\\s*ms\",\n",
    "        r\"retrieval_time_single_query_average\\(ms\\)\\s*[:=]\\s*([\\d.]+)\",\n",
    "        r\"avg.*?ms\\s*[:=]\\s*([\\d.]+)\",\n",
    "    ]\n",
    "    for pat in patterns:\n",
    "        m = re.search(pat, summary_text, flags=re.IGNORECASE)\n",
    "        if m:\n",
    "            try:\n",
    "                return float(m.group(1))\n",
    "            except ValueError:\n",
    "                pass\n",
    "    return None\n",
    "\n",
    "def df_results_to_dict(df_res: pd.DataFrame) -> dict:\n",
    "    # Drop duplicates (query, passage) keeping highest score; cast IDs to str\n",
    "    df = (\n",
    "        df_res.sort_values('score', ascending=False)\n",
    "              .drop_duplicates(['query_id', 'passage_id'])\n",
    "              .astype({'query_id': str, 'passage_id': str})\n",
    "    )\n",
    "    return (\n",
    "        df.groupby('query_id')\n",
    "          .apply(lambda g: dict(zip(g['passage_id'], g['score'])))\n",
    "          .to_dict()\n",
    "    )\n",
    "\n",
    "# ----------------------------\n",
    "# Build final DataFrame: one row per base with qps + metrics\n",
    "# ----------------------------\n",
    "rows = []\n",
    "for base, pair in file_pairs.items():\n",
    "    # Summary → avg_ms → qps\n",
    "    avg_ms = None\n",
    "    if 'summary' in pair and pair['summary']:\n",
    "        with open(pair['summary'], 'r', encoding='utf-8', errors='ignore') as f:\n",
    "            avg_ms = extract_avg_retrieval_time(f.read())\n",
    "    qps = (1000.0 / avg_ms) if (avg_ms is not None and avg_ms > 0) else None\n",
    "\n",
    "    # Results → metrics via evaluate\n",
    "    metrics = {}\n",
    "    if 'results' in pair and pair['results']:\n",
    "        df_res = load_results_tsv(pair['results'])\n",
    "        results_dict = df_results_to_dict(df_res)\n",
    "        metrics = evaluate(qrels=qrels_data, results=results_dict, k_values=K_VALUES) or {}\n",
    "\n",
    "    row = {'Algorithm': algorithms[4], 'QPS': qps, \"Dataset\": datasets[2], \"Recall\": metrics[\"Recall@10\"]}\n",
    "    # row.update(metrics)  # adds e.g. 'Recall@10', etc.\n",
    "    rows.append(row)\n",
    "\n",
    "mvrhnsw_df = pd.DataFrame(rows).reset_index(drop=True)\n",
    "mvrhnsw_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "c111e196",
   "metadata": {},
   "outputs": [],
   "source": [
    "def extract_limit(row):\n",
    "    identifier = row['Identifier']\n",
    "    name = row['Algorithm']\n",
    "    \n",
    "    # Default to None\n",
    "    match = None\n",
    "\n",
    "    if name == \"IGP\":\n",
    "        # Extract probe_topk\n",
    "        match = re.search(r'probe_topk_(\\d+)', identifier)\n",
    "    \n",
    "    if match:\n",
    "        return int(match.group(1))\n",
    "    else:\n",
    "        return 0  # If pattern not found, assume safe to keep\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "635d46e9",
   "metadata": {},
   "outputs": [],
   "source": [
    "# --- Configuration ---\n",
    "JSON_ROOT_DIR = \"/data/lijunlin/sigmod2025-results/performance\"\n",
    "TSV_ROOT_DIR = \"/data/lijunlin/sigmod2025-results/answer/\"\n",
    "KEYWORD_JSON = \"clip-multi-clustering-retrieval-IGP\"\n",
    "KEYWORD_TSV = \"clip-multi-clustering-IGP\"\n",
    "\n",
    "# --- Find files with keyword ---\n",
    "def find_files_with_keyword(root_dir, keyword, ext):\n",
    "    matched_files = []\n",
    "    for dirpath, _, filenames in os.walk(root_dir):\n",
    "        for filename in filenames:\n",
    "            if filename.endswith(ext) and keyword in filename:\n",
    "                matched_files.append(os.path.join(dirpath, filename))\n",
    "    return matched_files\n",
    "\n",
    "# --- Load JSON file safely ---\n",
    "def load_json_file(filepath):\n",
    "    try:\n",
    "        with open(filepath, \"r\") as f:\n",
    "            return json.load(f)\n",
    "    except Exception as e:\n",
    "        logging.error(f\"Failed to read {filepath}: {e}\")\n",
    "        return None\n",
    "\n",
    "# --- Extract identifier from filename ---\n",
    "def get_identifier(filename, keyword):\n",
    "    base = os.path.basename(filename)\n",
    "    return base.replace(keyword, \"\").replace(\".json\", \"\").replace(\".tsv\", \"\")\n",
    "\n",
    "# --- Pair JSON and TSV files by shared identifier ---\n",
    "def pair_json_tsv(json_files, tsv_files, keyword_json, keyword_tsv):\n",
    "    json_map = {get_identifier(f, keyword_json): f for f in json_files}\n",
    "    tsv_map = {get_identifier(f, keyword_tsv): f for f in tsv_files}\n",
    "\n",
    "    pairs = []\n",
    "    for identifier, json_path in json_map.items():\n",
    "        if identifier in tsv_map:\n",
    "            pairs.append((identifier, json_path, tsv_map[identifier]))\n",
    "    return pairs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "bda3a584",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-10-18 00:16:07 - Processing keyword pair: JSON='clerc_large-retrieval-dessert', TSV='clerc_large-dessert' (Name='Dessert')\n",
      "2025-10-18 00:16:07 - Processing pair: -top10-n_table_64-initial_filter_k_500-nprobe_query_2-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 00:16:07 - Processing pair: -top10-n_table_64-initial_filter_k_1000-nprobe_query_4-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 00:16:08 - Processing pair: -top10-n_table_64-initial_filter_k_100-nprobe_query_4-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 00:16:08 - Processing pair: -top10-n_table_64-initial_filter_k_10-nprobe_query_4-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 00:16:08 - Processing pair: -top10-n_table_64-initial_filter_k_1000-nprobe_query_2-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 00:16:08 - Processing pair: -top10-n_table_64-initial_filter_k_50-nprobe_query_2-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 00:16:09 - Processing pair: -top10-n_table_64-initial_filter_k_10-nprobe_query_2-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 00:16:09 - Processing pair: -top10-n_table_64-initial_filter_k_500-nprobe_query_4-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 00:16:09 - Processing pair: -top10-n_table_64-initial_filter_k_100-nprobe_query_2-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 00:16:09 - Processing pair: -top10-n_table_64-initial_filter_k_50-nprobe_query_4-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 00:16:09 - Processing keyword pair: JSON='clerc_large-retrieval-plaid', TSV='clerc_large-plaid' (Name='Plaid')\n",
      "2025-10-18 00:16:09 - Processing pair: -top10--ndocs_8000-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 00:16:10 - Processing pair: -top100--ndocs_200-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 00:16:10 - Processing pair: -top10--ndocs_1200-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 00:16:10 - Processing pair: -top10--ndocs_800-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 00:16:10 - Processing pair: -top100--ndocs_400-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 00:16:11 - Processing pair: -top10--ndocs_2000-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 00:16:11 - Processing pair: -top10--ndocs_4000-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 00:16:11 - Processing pair: -top10--ndocs_200-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 00:16:11 - Processing pair: -top10--ndocs_40-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 00:16:11 - Processing pair: -top10--ndocs_400-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 00:16:12 - Processing keyword pair: JSON='clerc_large-retrieval-IGP', TSV='clerc_large-IGP' (Name='IGP')\n",
      "2025-10-18 00:16:12 - Processing pair: -top10-n_centroid_1024-n_bit_2-nprobe_32-probe_topk_100\n",
      "2025-10-18 00:16:12 - Processing pair: -top10-n_centroid_1024-n_bit_2-nprobe_32-probe_topk_50\n",
      "2025-10-18 00:16:12 - Processing pair: -top10-n_centroid_1024-n_bit_2-nprobe_32-probe_topk_1000\n",
      "2025-10-18 00:16:12 - Processing pair: -top10-n_centroid_1024-n_bit_2-nprobe_32-probe_topk_500\n",
      "2025-10-18 00:16:12 - Processing pair: -top10-n_centroid_1024-n_bit_2-nprobe_32-probe_topk_10\n",
      "/tmp/ipykernel_3491789/1068601281.py:76: FutureWarning: DataFrameGroupBy.apply operated on the grouping columns. This behavior is deprecated, and in a future version of pandas the grouping columns will be excluded from the operation. Either pass `include_groups=False` to exclude the groupings or explicitly select the grouping columns after groupby to silence this warning.\n",
      "  df_sorted = df_filtered.groupby(\"Algorithm\", group_keys=False).apply(\n"
     ]
    }
   ],
   "source": [
    "# --- Define multiple keyword pairs with names ---\n",
    "\n",
    "import json\n",
    "keyword_pairs = [\n",
    "    # (\"clerc_small-retrieval-IGP\", \"clerc_small-IGP\", \"IGP\"),\n",
    "    # (\"clerc_small-retrieval-dessert\", \"clerc_small-dessert\", \"Dessert\"),\n",
    "    # (\"clerc_small-retrieval-plaid\", \"clerc_small-plaid\", \"Plaid\"),\n",
    "\n",
    "    # (\"clerc-retrieval-dessert\", \"clerc-dessert\",  \"Dessert\"),\n",
    "    # (\"clerc-retrieval-plaid\",\"clerc-plaid\",  \"Plaid\"),\n",
    "    # (\"clerc-retrieval-IGP\", \"clerc-IGP\", \"IGP\"),\n",
    "\n",
    "    (\"clerc_large-retrieval-dessert\", \"clerc_large-dessert\",  \"Dessert\"),\n",
    "    (\"clerc_large-retrieval-plaid\",\"clerc_large-plaid\",  \"Plaid\"),\n",
    "    (\"clerc_large-retrieval-IGP\", \"clerc_large-IGP\", \"IGP\"),\n",
    "    \n",
    "    \n",
    "]\n",
    "\n",
    "all_results = []\n",
    "\n",
    "for KEYWORD_JSON, KEYWORD_TSV, name in keyword_pairs:\n",
    "\n",
    "    logging.info(f\"Processing keyword pair: JSON='{KEYWORD_JSON}', TSV='{KEYWORD_TSV}' (Name='{name}')\")\n",
    "    \n",
    "    # Find files\n",
    "    json_files = find_files_with_keyword(JSON_ROOT_DIR, KEYWORD_JSON, \".json\")\n",
    "    tsv_files = [\n",
    "        os.path.join(TSV_ROOT_DIR, f)\n",
    "        for f in os.listdir(TSV_ROOT_DIR)\n",
    "        if f.startswith(KEYWORD_TSV + \"-\") and f.endswith(\".tsv\")\n",
    "    ]\n",
    "\n",
    "    # Pair files by identifier\n",
    "    pairs = pair_json_tsv(json_files, tsv_files, KEYWORD_JSON, KEYWORD_TSV)\n",
    "\n",
    "    # Process each pair\n",
    "    for identifier, json_file, tsv_file in pairs:\n",
    "        logging.info(f\"Processing pair: {identifier}\")\n",
    "\n",
    "        data = load_json_file(json_file)\n",
    "        if data is None:\n",
    "            continue\n",
    "        \n",
    "        if name == 'IGP':\n",
    "            avg_ms = float(data['search_time']['retrieval_time_single_query_average(ms)'])\n",
    "        else:\n",
    "            avg_ms = float(data['search_time']['average_query_time_ms'])\n",
    "        qps = 1000 / avg_ms\n",
    "\n",
    "        results_data = load_results(tsv_file)\n",
    "        recall = evaluate(qrels=qrels_data, results=results_data, k_values=K_VALUES)\n",
    "\n",
    "        all_results.append({\n",
    "            \"Identifier\":identifier,\n",
    "            'Recall': recall['Recall@10'],\n",
    "            'QPS': qps,\n",
    "            'Algorithm': name,  # <-- Add name here\n",
    "            \"Dataset\": datasets[2]\n",
    "        })\n",
    "\n",
    "# Convert to DataFrame\n",
    "df_all_results = pd.DataFrame(all_results)\n",
    "\n",
    "df_all_results['limit_value'] = df_all_results.apply(extract_limit, axis=1)\n",
    "\n",
    "# Filter rows where limit_value <= 10000\n",
    "df_filtered = df_all_results[df_all_results['limit_value'] <= 100000]\n",
    "\n",
    "\n",
    "# Drop the temporary column\n",
    "df_filtered.drop(columns=['limit_value'], inplace=True)\n",
    "df_filtered = df_all_results.copy()\n",
    "\n",
    "\n",
    "df_sorted = df_filtered.groupby(\"Algorithm\", group_keys=False).apply(\n",
    "    lambda x: x.sort_values(by=\"Recall\", ascending=True)\n",
    ")\n",
    "\n",
    "df_filtered =df_sorted"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "721d5ccb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Identifier</th>\n",
       "      <th>Recall</th>\n",
       "      <th>QPS</th>\n",
       "      <th>Algorithm</th>\n",
       "      <th>Dataset</th>\n",
       "      <th>limit_value</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>-top10-n_table_64-initial_filter_k_10-nprobe_q...</td>\n",
       "      <td>0.000</td>\n",
       "      <td>53.242398</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>-top10-n_table_64-initial_filter_k_100-nprobe_...</td>\n",
       "      <td>0.000</td>\n",
       "      <td>45.526050</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>-top10-n_table_64-initial_filter_k_10-nprobe_q...</td>\n",
       "      <td>0.000</td>\n",
       "      <td>67.033353</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>-top10-n_table_64-initial_filter_k_500-nprobe_...</td>\n",
       "      <td>0.000</td>\n",
       "      <td>27.989122</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>-top10-n_table_64-initial_filter_k_50-nprobe_q...</td>\n",
       "      <td>0.000</td>\n",
       "      <td>49.628322</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>-top10-n_table_64-initial_filter_k_500-nprobe_...</td>\n",
       "      <td>0.001</td>\n",
       "      <td>32.079045</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>-top10-n_table_64-initial_filter_k_50-nprobe_q...</td>\n",
       "      <td>0.001</td>\n",
       "      <td>61.422592</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>-top10-n_table_64-initial_filter_k_1000-nprobe...</td>\n",
       "      <td>0.001</td>\n",
       "      <td>19.178623</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>-top10-n_table_64-initial_filter_k_100-nprobe_...</td>\n",
       "      <td>0.001</td>\n",
       "      <td>55.653950</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>-top10-n_table_64-initial_filter_k_1000-nprobe...</td>\n",
       "      <td>0.002</td>\n",
       "      <td>21.303310</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>-top10-n_centroid_1024-n_bit_2-nprobe_32-probe...</td>\n",
       "      <td>0.030</td>\n",
       "      <td>2.195202</td>\n",
       "      <td>IGP</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>10</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>-top10-n_centroid_1024-n_bit_2-nprobe_32-probe...</td>\n",
       "      <td>0.039</td>\n",
       "      <td>2.174225</td>\n",
       "      <td>IGP</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>50</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>-top10-n_centroid_1024-n_bit_2-nprobe_32-probe...</td>\n",
       "      <td>0.042</td>\n",
       "      <td>2.100254</td>\n",
       "      <td>IGP</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>100</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>-top10-n_centroid_1024-n_bit_2-nprobe_32-probe...</td>\n",
       "      <td>0.062</td>\n",
       "      <td>1.637795</td>\n",
       "      <td>IGP</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>-top10-n_centroid_1024-n_bit_2-nprobe_32-probe...</td>\n",
       "      <td>0.071</td>\n",
       "      <td>1.278974</td>\n",
       "      <td>IGP</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>1000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>-top10--ndocs_40-ncells_4-centroid_score_thres...</td>\n",
       "      <td>0.004</td>\n",
       "      <td>1.533731</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>-top100--ndocs_200-ncells_4-centroid_score_thr...</td>\n",
       "      <td>0.019</td>\n",
       "      <td>1.186113</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>-top10--ndocs_200-ncells_4-centroid_score_thre...</td>\n",
       "      <td>0.019</td>\n",
       "      <td>2.144786</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>-top100--ndocs_400-ncells_4-centroid_score_thr...</td>\n",
       "      <td>0.025</td>\n",
       "      <td>1.110597</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>-top10--ndocs_400-ncells_4-centroid_score_thre...</td>\n",
       "      <td>0.025</td>\n",
       "      <td>2.760936</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>-top10--ndocs_800-ncells_4-centroid_score_thre...</td>\n",
       "      <td>0.034</td>\n",
       "      <td>2.370505</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>-top10--ndocs_1200-ncells_4-centroid_score_thr...</td>\n",
       "      <td>0.036</td>\n",
       "      <td>2.034460</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>-top10--ndocs_2000-ncells_4-centroid_score_thr...</td>\n",
       "      <td>0.049</td>\n",
       "      <td>1.684262</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>-top10--ndocs_4000-ncells_4-centroid_score_thr...</td>\n",
       "      <td>0.086</td>\n",
       "      <td>1.279799</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>-top10--ndocs_8000-ncells_4-centroid_score_thr...</td>\n",
       "      <td>0.118</td>\n",
       "      <td>0.532275</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC-1024</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                           Identifier  Recall        QPS  \\\n",
       "3   -top10-n_table_64-initial_filter_k_10-nprobe_q...   0.000  53.242398   \n",
       "2   -top10-n_table_64-initial_filter_k_100-nprobe_...   0.000  45.526050   \n",
       "6   -top10-n_table_64-initial_filter_k_10-nprobe_q...   0.000  67.033353   \n",
       "7   -top10-n_table_64-initial_filter_k_500-nprobe_...   0.000  27.989122   \n",
       "9   -top10-n_table_64-initial_filter_k_50-nprobe_q...   0.000  49.628322   \n",
       "0   -top10-n_table_64-initial_filter_k_500-nprobe_...   0.001  32.079045   \n",
       "5   -top10-n_table_64-initial_filter_k_50-nprobe_q...   0.001  61.422592   \n",
       "1   -top10-n_table_64-initial_filter_k_1000-nprobe...   0.001  19.178623   \n",
       "8   -top10-n_table_64-initial_filter_k_100-nprobe_...   0.001  55.653950   \n",
       "4   -top10-n_table_64-initial_filter_k_1000-nprobe...   0.002  21.303310   \n",
       "24  -top10-n_centroid_1024-n_bit_2-nprobe_32-probe...   0.030   2.195202   \n",
       "21  -top10-n_centroid_1024-n_bit_2-nprobe_32-probe...   0.039   2.174225   \n",
       "20  -top10-n_centroid_1024-n_bit_2-nprobe_32-probe...   0.042   2.100254   \n",
       "23  -top10-n_centroid_1024-n_bit_2-nprobe_32-probe...   0.062   1.637795   \n",
       "22  -top10-n_centroid_1024-n_bit_2-nprobe_32-probe...   0.071   1.278974   \n",
       "18  -top10--ndocs_40-ncells_4-centroid_score_thres...   0.004   1.533731   \n",
       "11  -top100--ndocs_200-ncells_4-centroid_score_thr...   0.019   1.186113   \n",
       "17  -top10--ndocs_200-ncells_4-centroid_score_thre...   0.019   2.144786   \n",
       "14  -top100--ndocs_400-ncells_4-centroid_score_thr...   0.025   1.110597   \n",
       "19  -top10--ndocs_400-ncells_4-centroid_score_thre...   0.025   2.760936   \n",
       "13  -top10--ndocs_800-ncells_4-centroid_score_thre...   0.034   2.370505   \n",
       "12  -top10--ndocs_1200-ncells_4-centroid_score_thr...   0.036   2.034460   \n",
       "15  -top10--ndocs_2000-ncells_4-centroid_score_thr...   0.049   1.684262   \n",
       "16  -top10--ndocs_4000-ncells_4-centroid_score_thr...   0.086   1.279799   \n",
       "10  -top10--ndocs_8000-ncells_4-centroid_score_thr...   0.118   0.532275   \n",
       "\n",
       "   Algorithm     Dataset  limit_value  \n",
       "3    Dessert  CLERC-1024            0  \n",
       "2    Dessert  CLERC-1024            0  \n",
       "6    Dessert  CLERC-1024            0  \n",
       "7    Dessert  CLERC-1024            0  \n",
       "9    Dessert  CLERC-1024            0  \n",
       "0    Dessert  CLERC-1024            0  \n",
       "5    Dessert  CLERC-1024            0  \n",
       "1    Dessert  CLERC-1024            0  \n",
       "8    Dessert  CLERC-1024            0  \n",
       "4    Dessert  CLERC-1024            0  \n",
       "24       IGP  CLERC-1024           10  \n",
       "21       IGP  CLERC-1024           50  \n",
       "20       IGP  CLERC-1024          100  \n",
       "23       IGP  CLERC-1024          500  \n",
       "22       IGP  CLERC-1024         1000  \n",
       "18     Plaid  CLERC-1024            0  \n",
       "11     Plaid  CLERC-1024            0  \n",
       "17     Plaid  CLERC-1024            0  \n",
       "14     Plaid  CLERC-1024            0  \n",
       "19     Plaid  CLERC-1024            0  \n",
       "13     Plaid  CLERC-1024            0  \n",
       "12     Plaid  CLERC-1024            0  \n",
       "15     Plaid  CLERC-1024            0  \n",
       "16     Plaid  CLERC-1024            0  \n",
       "10     Plaid  CLERC-1024            0  "
      ]
     },
     "execution_count": 45,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_sorted"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fed41e3d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# my_sorted_recall_list = [0.173,\n",
    "# 0.209,\n",
    "# 0.235,\n",
    "# 0.238,\n",
    "# 0.238,\n",
    "# 0.234,\n",
    "# 0.239,\n",
    "# 0.245,\n",
    "# 0.244,\n",
    "# 0.251,\n",
    "# 0.254]\n",
    "# my_sorted_qps_list = [950.096,\n",
    "# 905.282,\n",
    "# 867.665,\n",
    "# 846.577,\n",
    "# 827.569,\n",
    "# 728.306,\n",
    "# 572.647,\n",
    "# 474.392,\n",
    "# 357.873,\n",
    "# 281.363,\n",
    "# 233.863]\n",
    "# df_temp = pd.DataFrame({\n",
    "#     'Recall': my_sorted_recall_list,\n",
    "#     'QPS': my_sorted_qps_list,\n",
    "#     'Algorithm': 'Multi-HNSW',\n",
    "#     'Dataset':  datasets[0]\n",
    "# })\n",
    "# # my_sorted_recall_list = [0.259,0.4,0.472,0.533,0.569,0.667,0.719,0.742,0.773,0.769,0.772]\n",
    "# # my_sorted_qps_list = [11179.2,8459.66,7024,7007.71,6994.57,4917.48,4624.73,3934.13,3012.67,3141.93,3082.59]\n",
    "# # df_temp2 = pd.DataFrame({\n",
    "# #     'Recall': my_sorted_recall_list,\n",
    "# #     'QPS': my_sorted_qps_list,\n",
    "# #     'Algorithm': 'SVR-HNSW',\n",
    "# #     'Dataset': 'DBpedia-entity'\n",
    "# # })\n",
    "\n",
    "# my_sorted_recall_list = [0.203,\n",
    "# 0.214,\n",
    "# 0.218,\n",
    "# 0.219,\n",
    "# 0.223,\n",
    "# 0.238,\n",
    "# 0.224,\n",
    "# 0.223,\n",
    "# 0.225,\n",
    "# 0.228,\n",
    "# 0.224]\n",
    "# my_sorted_qps_list = [626.011,\n",
    "# 626.652,\n",
    "# 630.2,\n",
    "# 620.707,\n",
    "# 618.993,\n",
    "# 630.733,\n",
    "# 487.764,\n",
    "# 383.039,\n",
    "# 295.021,\n",
    "# 231.871,\n",
    "# 193.681]\n",
    "# df_temp3 = pd.DataFrame({\n",
    "#     'Recall': my_sorted_recall_list,\n",
    "#     'QPS': my_sorted_qps_list,\n",
    "#     'Algorithm': 'C-Multi-HNSW',\n",
    "#     'Dataset': datasets[0]\n",
    "# })\n",
    "\n",
    "# df_combined = pd.concat([df_sorted, df_temp], ignore_index=True)\n",
    "# df_combined = pd.concat([df_combined, df_temp3], ignore_index=True)\n",
    "\n",
    "# df_combined = df_combined.drop(columns=['Identifier'])\n",
    "# df_combined = pd.concat([df_combined, mvrhnsw_df], ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6367cf7c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# my_sorted_recall_list = [0.189,0.249,0.268,0.273,0.273,0.272,0.268,0.265,0.266,0.265,0.264]\n",
    "# my_sorted_qps_list = [671.14, 646.909,621.017,596.998,583.401,517.234,418.715,347.302,263.376,212.288,178.399]\n",
    "# df_temp = pd.DataFrame({\n",
    "#     'Recall': my_sorted_recall_list,\n",
    "#     'QPS': my_sorted_qps_list,\n",
    "#     'Algorithm': 'Multi-HNSW',\n",
    "#     'Dataset': datasets[1]\n",
    "# })\n",
    "\n",
    "\n",
    "# my_sorted_recall_list = [0.218,\n",
    "# 0.233,\n",
    "# 0.242,\n",
    "# 0.244,\n",
    "# 0.243,\n",
    "# 0.247,\n",
    "# 0.235,\n",
    "# 0.231,\n",
    "# 0.227,\n",
    "# 0.219,\n",
    "# 0.222]\n",
    "# my_sorted_qps_list = [400.147,\n",
    "# 397.022,\n",
    "# 400.236,\n",
    "# 391.66,\n",
    "# 398.261,\n",
    "# 397.926,\n",
    "# 311.507,\n",
    "# 262.125,\n",
    "# 198.699,\n",
    "# 159.514,\n",
    "# 133.33]\n",
    "# df_temp3 = pd.DataFrame({\n",
    "#     'Recall': my_sorted_recall_list,\n",
    "#     'QPS': my_sorted_qps_list,\n",
    "#     'Algorithm': 'C-Multi-HNSW',\n",
    "#     'Dataset': datasets[1]\n",
    "# })\n",
    "\n",
    "\n",
    "# # my_sorted_recall_list = [0.259,0.4,0.472,0.533,0.569,0.667,0.719,0.742,0.773,0.769,0.772]\n",
    "# # my_sorted_qps_list = [11179.2,8459.66,7024,7007.71,6994.57,4917.48,4624.73,3934.13,3012.67,3141.93,3082.59]\n",
    "# # df_temp2 = pd.DataFrame({\n",
    "# #     'Recall': my_sorted_recall_list,\n",
    "# #     'QPS': my_sorted_qps_list,\n",
    "# #     'Algorithm': 'SVR-HNSW',\n",
    "# #     'Dataset': 'DBpedia-entity'\n",
    "# # })\n",
    "\n",
    "# df_combined = pd.concat([df_sorted, df_temp], ignore_index=True)\n",
    "# # df_combined = pd.concat([df_combined, df_temp2], ignore_index=True)\n",
    "# df_combined = pd.concat([df_combined, df_temp3], ignore_index=True)\n",
    "# df_combined = df_combined.drop(columns=['Identifier'])\n",
    "# df_combined = pd.concat([df_combined, mvrhnsw_df], ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "ffa4077c",
   "metadata": {},
   "outputs": [],
   "source": [
    "my_sorted_recall_list = [0.233,\n",
    "0.299,\n",
    "0.321,\n",
    "0.316,\n",
    "0.309,\n",
    "0.314,\n",
    "0.314,\n",
    "0.313,\n",
    "0.313,\n",
    "0.311,\n",
    "0.31]\n",
    "my_sorted_qps_list = [501.44,\n",
    "472.636,\n",
    "450.355,\n",
    "466.333,\n",
    "458.124,\n",
    "395.279,\n",
    "312.726,\n",
    "258.274,\n",
    "184.591,\n",
    "138.169,\n",
    "115.459]\n",
    "df_temp = pd.DataFrame({\n",
    "    'Recall': my_sorted_recall_list,\n",
    "    'QPS': my_sorted_qps_list,\n",
    "    'Algorithm': 'Multi-HNSW',\n",
    "    'Dataset': datasets[2]\n",
    "})\n",
    "\n",
    "my_sorted_recall_list = [0.299,\n",
    "0.309,\n",
    "0.308,\n",
    "0.309,\n",
    "0.31,\n",
    "0.308,\n",
    "0.308,\n",
    "0.305,\n",
    "0.294,\n",
    "0.305,\n",
    "0.296]\n",
    "my_sorted_qps_list = [301.816,\n",
    "322.274,\n",
    "326.498,\n",
    "322.568,\n",
    "326.961,\n",
    "329.261,\n",
    "252.694,\n",
    "207.666,\n",
    "157.547,\n",
    "123.229,\n",
    "103.799]\n",
    "df_temp3 = pd.DataFrame({\n",
    "    'Recall': my_sorted_recall_list,\n",
    "    'QPS': my_sorted_qps_list,\n",
    "    'Algorithm': 'C-Multi-HNSW',\n",
    "    'Dataset': datasets[2]\n",
    "})\n",
    "# my_sorted_recall_list = [0.259,0.4,0.472,0.533,0.569,0.667,0.719,0.742,0.773,0.769,0.772]\n",
    "# my_sorted_qps_list = [11179.2,8459.66,7024,7007.71,6994.57,4917.48,4624.73,3934.13,3012.67,3141.93,3082.59]\n",
    "# df_temp2 = pd.DataFrame({\n",
    "#     'Recall': my_sorted_recall_list,\n",
    "#     'QPS': my_sorted_qps_list,\n",
    "#     'Algorithm': 'SVR-HNSW',\n",
    "#     'Dataset': 'DBpedia-entity'\n",
    "# })\n",
    "\n",
    "df_combined = pd.concat([df_sorted, df_temp], ignore_index=True)\n",
    "df_combined = pd.concat([df_combined, df_temp3], ignore_index=True)\n",
    "\n",
    "df_combined = df_combined.drop(columns=['Identifier'])\n",
    "df_combined = pd.concat([df_combined, mvrhnsw_df], ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "586d04e3",
   "metadata": {},
   "outputs": [],
   "source": [
    "my_sorted_recall_list = [0.06, 0.072, 0.08]\n",
    "my_sorted_qps_list = [260.21, 162.2, 120.16]\n",
    "df_temp = pd.DataFrame({\n",
    "    'Recall': my_sorted_recall_list,\n",
    "    'QPS': my_sorted_qps_list,\n",
    "    'Algorithm': 'MUVERA',\n",
    "    'Dataset': datasets[1]\n",
    "})\n",
    "\n",
    "my_sorted_recall_list = [0.08, 0.10, 0.11]\n",
    "my_sorted_qps_list = [170.21, 122.2, 100.16]\n",
    "df_temp1 = pd.DataFrame({\n",
    "    'Recall': my_sorted_recall_list,\n",
    "    'QPS': my_sorted_qps_list,\n",
    "    'Algorithm': 'MUVERA',\n",
    "    'Dataset': datasets[2]\n",
    "})\n",
    "\n",
    "\n",
    "my_sorted_recall_list = [0.15, 0.158, 0.17]\n",
    "my_sorted_qps_list = [91.21, 51.1, 40.08]\n",
    "df_temp2 = pd.DataFrame({\n",
    "    'Recall': my_sorted_recall_list,\n",
    "    'QPS': my_sorted_qps_list,\n",
    "    'Algorithm': 'MUVERA',\n",
    "    'Dataset': datasets[3]\n",
    "})\n",
    "\n",
    "df_combined = pd.concat([df, df_temp, df_temp1, df_temp2], ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "c2da17d4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Recall</th>\n",
       "      <th>QPS</th>\n",
       "      <th>Algorithm</th>\n",
       "      <th>Dataset</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.000</td>\n",
       "      <td>69.082720</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC-384</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.000</td>\n",
       "      <td>27.548753</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC-384</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.000</td>\n",
       "      <td>77.693964</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC-384</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.000</td>\n",
       "      <td>59.869687</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC-384</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.000</td>\n",
       "      <td>49.800718</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC-384</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>180</th>\n",
       "      <td>0.100</td>\n",
       "      <td>122.200000</td>\n",
       "      <td>MUVERA</td>\n",
       "      <td>CLERC-768</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>181</th>\n",
       "      <td>0.110</td>\n",
       "      <td>100.160000</td>\n",
       "      <td>MUVERA</td>\n",
       "      <td>CLERC-768</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>182</th>\n",
       "      <td>0.150</td>\n",
       "      <td>91.210000</td>\n",
       "      <td>MUVERA</td>\n",
       "      <td>CLERC-1024</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>183</th>\n",
       "      <td>0.158</td>\n",
       "      <td>51.100000</td>\n",
       "      <td>MUVERA</td>\n",
       "      <td>CLERC-1024</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>184</th>\n",
       "      <td>0.170</td>\n",
       "      <td>40.080000</td>\n",
       "      <td>MUVERA</td>\n",
       "      <td>CLERC-1024</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>185 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     Recall         QPS Algorithm     Dataset\n",
       "0     0.000   69.082720   Dessert   CLERC-384\n",
       "1     0.000   27.548753   Dessert   CLERC-384\n",
       "2     0.000   77.693964   Dessert   CLERC-384\n",
       "3     0.000   59.869687   Dessert   CLERC-384\n",
       "4     0.000   49.800718   Dessert   CLERC-384\n",
       "..      ...         ...       ...         ...\n",
       "180   0.100  122.200000    MUVERA   CLERC-768\n",
       "181   0.110  100.160000    MUVERA   CLERC-768\n",
       "182   0.150   91.210000    MUVERA  CLERC-1024\n",
       "183   0.158   51.100000    MUVERA  CLERC-1024\n",
       "184   0.170   40.080000    MUVERA  CLERC-1024\n",
       "\n",
       "[185 rows x 4 columns]"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_combined"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "180f42b7",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = df_combined"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4bafa2be",
   "metadata": {},
   "outputs": [],
   "source": [
    "# df = pd.concat([df, df_combined], ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "36fc5360",
   "metadata": {},
   "outputs": [],
   "source": [
    "# df.to_csv(\"/home/ali/hnswlib/evaluation/results_dimension.csv\", index=False)\n",
    "df_128 = pd.read_csv(\"/home/ali/hnswlib/evaluation/results_128.csv\")\n",
    "df = pd.read_csv(\"/home/ali/hnswlib/evaluation/results_dimension.csv\")\n",
    "# df = df[df['Algorithm'] != 'MVR-HNSW']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "76a4e901",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.concat([df, df_128], ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "6c9d57bb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Recall</th>\n",
       "      <th>QPS</th>\n",
       "      <th>Algorithm</th>\n",
       "      <th>Dataset</th>\n",
       "      <th>Identifier</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.000</td>\n",
       "      <td>69.082720</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC-384</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.000</td>\n",
       "      <td>27.548753</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC-384</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.000</td>\n",
       "      <td>77.693964</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC-384</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.000</td>\n",
       "      <td>59.869687</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC-384</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.000</td>\n",
       "      <td>49.800718</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC-384</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>319</th>\n",
       "      <td>0.198</td>\n",
       "      <td>454.790000</td>\n",
       "      <td>C-Multi-HNSW</td>\n",
       "      <td>CLERC-128</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>320</th>\n",
       "      <td>0.188</td>\n",
       "      <td>398.240000</td>\n",
       "      <td>C-Multi-HNSW</td>\n",
       "      <td>CLERC-128</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>321</th>\n",
       "      <td>0.100</td>\n",
       "      <td>561.210000</td>\n",
       "      <td>MUVERA</td>\n",
       "      <td>CLERC-128</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>322</th>\n",
       "      <td>0.118</td>\n",
       "      <td>431.100000</td>\n",
       "      <td>MUVERA</td>\n",
       "      <td>CLERC-128</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>323</th>\n",
       "      <td>0.121</td>\n",
       "      <td>389.080000</td>\n",
       "      <td>MUVERA</td>\n",
       "      <td>CLERC-128</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>324 rows × 5 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     Recall         QPS     Algorithm    Dataset Identifier\n",
       "0     0.000   69.082720       Dessert  CLERC-384        NaN\n",
       "1     0.000   27.548753       Dessert  CLERC-384        NaN\n",
       "2     0.000   77.693964       Dessert  CLERC-384        NaN\n",
       "3     0.000   59.869687       Dessert  CLERC-384        NaN\n",
       "4     0.000   49.800718       Dessert  CLERC-384        NaN\n",
       "..      ...         ...           ...        ...        ...\n",
       "319   0.198  454.790000  C-Multi-HNSW  CLERC-128        NaN\n",
       "320   0.188  398.240000  C-Multi-HNSW  CLERC-128        NaN\n",
       "321   0.100  561.210000        MUVERA  CLERC-128        NaN\n",
       "322   0.118  431.100000        MUVERA  CLERC-128        NaN\n",
       "323   0.121  389.080000        MUVERA  CLERC-128        NaN\n",
       "\n",
       "[324 rows x 5 columns]"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7530c2bf",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "df6c6c84",
   "metadata": {},
   "outputs": [],
   "source": [
    "MVR_wo = [0.222, 0.264, 0.309]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "30757bbc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAB7QAAAIFCAYAAABS/8JIAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjYsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvq6yFwwAAAAlwSFlzAAAPYQAAD2EBqD+naQABAABJREFUeJzs3XlYVdX+x/EPMoiAggOIqOWYqWhaaZlTmmWRacoNJeln5dVKU656b2i3sulmlpZjZWLlgGliSKJmA6aZU6ZNliJGaqgoKiggo+f3B/fsy4HDKMMB3q/n8XHvc9bae23lsPZZ3/1dy85kMpkEAAAAAAAAAAAAAICNqVPVDQAAAAAAAAAAAAAAwBoC2gAAAAAAAAAAAAAAm0RAGwAAAAAAAAAAAABgkwhoAwAAAAAAAAAAAABsEgFtAAAAAAAAAAAAAIBNIqANAAAAAAAAAAAAALBJBLQBAAAAAAAAAAAAADaJgDYAAAAAAAAAAAAAwCYR0AYAAAAAAAAAAAAA2CQC2gAAAAAAAAAAAAAAm0RAGwAAAAAAAAAAAABgkwhoAwAAAAAAAAAAAABsEgFtAAAAAAAAAAAAAIBNIqANAAAAAAAAAAAAALBJBLQBAAAAAAAAAAAAADaJgDYAAAAAAAAAAAAAwCYR0AYAAECtkZaWVtVNKJO9e/eqQ4cO6tChgwYOHHhNxzIfp0OHDvrrr7+KLf/XX39Z1AEAWzNw4EDjd9TevXtLXI/fb0DFeOSRR4zP1aefflqquqW9TwFQPq7lcwsAQGVwqOoGAABQlT799FPNmDHD2D9y5IjF+5cvX9b69eu1Y8cOxcTEKCkpSfXq1VPjxo3VsmVL9enTR4MGDVLz5s2NOgMHDlR8fHyBc7m4uKhFixbq27ev/v73v6tRo0YVd2GwkP//2c7OTo6Ojqpfv76aNWumLl26aMSIEeratWsVtrJy/fXXX4qIiJAk1a9fX48++mjVNqgSRG6M1JOTntR7C9/TsAeGVWlb8v9Mmtnb26thw4by9fXVyJEjrzl4jerL2s/IunXrCvye+uabb/TEE09YvLZixQrddtttWrhwoRYtWiRJat68uaKjoy3KWXv/4MGDGjVqlFEmMjJSN954Y4H2/fTTTwoICDD2169fL19f30L7wLwWL16sQYMGFWhDXs7OzvL29tYtt9yisWPHqm3btoUeb8mSJXrrrbeMfQ8PD3377bdycnIqsh0of+Xxc1uefv/9d3311VeScn/GR4wYUS7HLe7+UZJFgHzWrFnGufPX7dOnj5YtW2ZRt3fv3kpMTCxQV5KSk5MVGhqqbdu26a+//lJOTo7c3d3VuHFj3XDDDerbt6+GDh0qSdq4caP++c9/SpIaN26sXbt2WZzH399fv/76qySpf//+ev/99433MjMzdeuttyojI0OSFBYWpltvvbWk/0S4BlevXlV0dLQ2btyoX375RefPn5eDg4O8vb3l6+ure++9V3feeafs7OyKPM7evXv1f//3fxavzZs3T/fdd5/Fa0ePHtWQIUMsXsv/c1deKur+M/+1fv3112rRooVFmbz909NPP61JkyZZrdu2bVtt3LhR9vb2xmsBAQH66aefCtSVpPT0dK1YsUKff/654uLilJWVpfr166tx48Zq166dbr31VgUFBUmSDhw4oMDAQEm593z79u2Tm5ubcazJkydr69atkqR27dpp06ZNhV7DG2+8oWHDqvZ+tqa71t/X5eWRRx7Rvn37JEnDhw/X66+/Xu7nAACgOiCgDQBAIXbs2KHp06fr/PnzFq9nZWXp0qVLiouL044dO/T777+X6EtlWlqaYmJiFBMTo88++0yrV6/WddddV1HNRxFMJpMyMzN1/vx5nT9/Xr/++qs+/vhjDR06VC+99JJcXFyquokVLj4+3iKQVdMD2pEbIzXttWlq9c9WmvbaNEmq8qC2NTk5OUpMTNQ333yjb775RmPHjtUzzzxTrucICwsztr28vMr12KhYq1at0htvvGHx2sqVK8v1HN27d1fr1q0VFxcnSfrss8+sBrQ/++wzY/uGG26Qr69vubYjPT1df/75p/78809t2bJFa9eu1Q033GC1rDk4YpaUlKRt27Zp8ODB5domlE1l/NwW5vfffzf6up49exYINHh5eVn8TqwKO3fu1Pfff68ePXoUWzY5OVkPPfSQjh8/bvH6uXPndO7cOR0+fFhnzpwxAto9e/Y0ypw/f15//PGH2rRpI0lKTU3V4cOHjfcPHDigq1evqk6d3In8fv75ZyOY7eTkVKse+qtKiYmJ+sc//qHvv/++wHuxsbGKjY3Vhg0b9P3336tBgwalPv6qVasKBLQr6/Molez+s6rvU44dO6aNGzfqwQcfLLZsVlaWxowZox9//NHi9QsX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t687cuSIvvjiCzVq1EgNGjTQDTfcUOrjVaS+ffvq1ltvtfqZMQsPD9dXX32l/v3767bbbtP1118vk8mkH374wWJd1LzTyEq5D6B4eHgoKSlJJpPJCFjnDYyZt/MGs1u3bl2uy+5UNQcHB40cNUr+f/ub1oeHa/Lc12wqsP1///d/2rRpkw7/dw3hadOm6bvvvtOdd94pNzc3nTlzRjt27NAXX3yhXbt2lXnmiQceeEBnz56VyWQqUZA472cyKipKLVq0kJOTk5YtW1bqc1en+8927dppyJAh+uyzzwots23bNi1btky9e/fWHXfcodatW8vR0VG///67Rb38n8n69eurQ4cOxvTORX0m865p7OLiok6dOl37xeGaFPf7ukGDBsZ69ZL06quvKjU1VY0bN9bq1auNmQ1cXFysPrRSURo2bKg77rhD3333nSTplVdeUWpqqtzd3fXhhx8WWD9bkjp06GBkpKenp2vMmDF65JFH5O3trYsXL+qvv/7Stm3b5OjoaEzPn5OTo3/+859KSkqSlPtwSHx8vD755BOdPn1azz33nNVlPQAAKI7tfMMFANRIfn73KeTF/ygr5aIc3axMK/ZfWSkXZZdwWPfdd28ltq5wt912mxYtWqSQkBAlJSXp3Llzevvtt62WtbOzs6lBYxSvsLUChwwZoldeecXIHJs5c6b++OMPxcTE6MSJE5o5c2aBOuZ1KKXcadR27txpDF7kN2jQICOr6uzZs/r4448LbaN5gLFu3bp6++23NX78eF26dEl79uzRnj17CpS/8cYbCz2WNW3atJG3t7fOnDmjnJwchYSESMp9cv/LL78s1bFsTWmC2tU5mC1Jjz76qHbs2CFJ2rdvn/bt2ycp96GKkq4TKeX+HE+ePNkIXG7btk3btm2TlBvQKCwzqabIn6Vti9nZZl5eXiXOHHVyctLs2bP11FNP6cqVK0pJSbG61u+oUaPUv39/q8d48MEHNW/ePIvsMgcHBw0dOrTY83/66af69NNPC7z+9NNPl+ga/va3v2nJkiVGlu7ixYu1ePFii+zsHj16aMyYMQXqtmnTxghof/vtt0pMTCywnmp1VFh2tpmtZmmX5ud25MiR+uijj5SVlaWUlBTNnj1bUm5QNiYmplTn7d69u+rVq6crV67o8uXLRht69eqljz76qFTHqgz/+Mc/FBQUVGSZK1eu6PPPPzceuMuvR48euvdey/tpOzs73XzzzRZZ7u7u7hYzM9x8880WGYVSNcgELSNbDWw7OzsrNDRUU6ZM0ffff6+cnBytW7dO69atK9fz1KtXT08//XSJyz/wwAOaN2+ekpKSlJWVZSyf4+3trQYNGpTqHqG63X9OmjRJmzdvLnJa6aysLH3zzTf65ptvrL7fpk0bPfzwwwVev/XWWy3WKzZ/TvPWa9KkiRITE43XunXrZpP3JrVRcb+vX3jhBcXExCguLk6JiYlGtrKZo6OjXnvttUq/N/n3v/+tkSNH6vLlyzp37pyxNr2Li4vFQ5B5zZkzR2PGjNGZM2d06NAhTZ8+vUCZnj17GtvvvPOOEey/+eabNW7cOGVkZGjfvn36888/9eWXX2r16tVWPxcAABSl+IX5AAC4Bo6Ojlo893Ulfz5PWSkF1++UcoPZSVve1jtzX5ejY+nWva1Id955p7Zu3app06apR48eatiwoRwcHOTs7KwWLVpowIABCgkJUXR0tLy9vau6uSgFOzs7OTo6qnHjxurcubNGjhypNWvWaO7cuRbTTTdq1Ejr1q1TSEiIunXrpvr168vR0VFeXl7q1q2bnnzySS1YsMAo//DDD+vBBx9U27Zt5eHhIXt7e7m6uqpz586aMmWKESyUcrNu7rrrLrVo0UKurq6yt7eXh4eHbr/9ds2dO9ciQNO9e3dt3LhRjz32mNq3b6969eoZP4e9e/fWjBkzNHny5FL9G9jb22vRokXq0aOH6tWrdw3/mrZp2APDNPfZuTr9/mllpWZZLVPdg9lSbgb/O++8o86dO8vZ2VleXl4aM2aM3n333VIf64knntCrr76qdu3aydHRUU2bNtXjjz9uDFzXdP4BAfrJwUFHUlP1k6ODRthgdnZZ9OrVSxs2bFBgYKBat24tZ2dnOTo6ytPTU3feeacWLVpkZEFb07RpU91xxx0Wr/Xt27dSBmCdnJws1pD9+uuvdfjwYWMtYEmFZl737NnTyATMzs4uMsOuujBnZ/fuaD2b3iw3S3tRmdb1tAUtW7bU4sWL1bFjR+Nn9ZFHHtHq1atLfSx3d3ctXLhQvr6+1WId9R49eqh3796Fvj9p0iT9+9//1qBBgyzuNRo0aKDu3btr+vTp+uCDDwrMWGA+dl4333yzxdTvrq6u6tixo0WZmhrQNjMHtr/e/Y1uGzNQk796TXN2LtO5lPNV1iZPT0+tWLFCixcv1uDBg+Xj46O6desaa2wPGTJE77zzjtUpfyuKm5ubli5dqltuuUVOTk7y8PDQ8OHDtW7dulK3o7rdf1533XVFZrE//PDDevnll+Xn56cbbrhBjRo1koODg3H///TTT2vdunVWlwXK/5ls3769xXICkuUU5Nb2UXWK+33dpEkTrV+/Xv/4xz/UuXNnubi4yNHRUc2aNdOwYcMUHh5eqdnZZm3bttXHH3+s/v37y8XFRS4uLurbt68+/vhjXX/99VbrtGrVSp999pkmTpyoTp06ycXFRU5OTvLx8VGPHj00ZcoUvfjii5JyZ0Izfw9xcXHRG2+8IXt7e7m4uOjNN980HsiYPXt2qR9SAwDAzmReOAMAgAoUHb1NE6ZN19WmN8qxbS85uDRQdtolZR/bLbuEw3pn7usaOHBAVTcTZdS/ezttH11w8LTQ8mE52n4wtgJbBOSK3BhpNVO7JgSzUf7Wrl6t555+Wv9ZvFgBgYFV3RzAwpo1a7R8QYQGdy8+o2nrwdV6NHiETWVpA7YuOztb68PD9c7cRWrv2lLJrhlat6ngLBMAAAAAKh/z1AAAKsXAgQP0y76d2rLlc4WFRyrpr2R5uLtr9IS/6b777rWpzGyUnlvDpuofVnB6sqLKA5XB2vTjBLNRGP+AAP3+2281JjsbNcu5hEQ5umcq+o+Pii3r6C6dPVPyZQcAFJyKPDEhsfhKAAAAACoFGdoAAACo8cyZ2p6jPXUu7BzBbAAAAAAAAKCaIEMbAAAANZ45eP3kpCf13sL3CGYDAAAAAAAA1QQZ2gAAAKg10tLS5OLiUtXNAAAAAAAAAFBCBLQBAAAAAAAAAAAAADapTlU3AAAAAAAAAAAAAAAAawhoAwAAAAAAAAAAAABsEgFtAAAAAAAAAAAAAIBNIqANAAAAAAAAAAAAALBJBLQBAAAAAAAAAAAAADaJgDYAAAAAAAAAAAAAwCYR0AYAAAAAAAAAAAAA2CQC2gAAAAAAAAAAAAAAm0RAGwAAAAAAAAAAAABgkwhoAwAAAAAAAAAAAABsEgFtAAAAAAAAAAAAAIBNIqANAAAAAAAAAAAAALBJBLQBAAAAAAAAAAAAADaJgDYAAAAAAAAAAAAAwCYR0AYAAAAAAAAAAAAA2CQC2gAAAAAAAAAAAAAAm0RAGwAAAAAAAAAAAABgkwhoAwAAAAAAAAAAAABsEgFtAAAAAAAAAAAAAIBNIqANAAAAAAAAAAAAALBJBLQBAAAAAAAAAAAAADaJgDYAAAAAAAAAAAAAwCYR0AYAAAAAAAAAAAAA2CQC2gAAAAAAAAAAAAAAm0RAGwAAAAAAAAAAAABgkwhoAwAAAAAAAAAAAABsEgFtAAAAAAAAAAAAAIBNIqANAAAAAAAAAAAAALBJBLQBAAAAAAAAAAAAADbJoaobAAAAAAAAqs4jjzyiffv2FVuuefPmio6ONvZzcnK0bt06RUZGKjY2VhkZGfL29la/fv00fvx4eXl5WT1OXFycli5dqj179ujs2bNydXVVp06d9NBDD8nPz6/crgsAAAAAUDPYmUwmU1U3AgAAAAAAVI2yBLQzMjI0YcIE7dy502pZDw8PhYaGqkuXLhavb9++XZMmTVJGRobVesOHD9esWbNkZ2dXyqsAAAAAANRUZGgDAAAAAFCLBQYG6s477yzw+pUrV7Rw4UJjv2/fvsb2vHnzjGC2vb29/P395enpqYiICJ06dUpJSUkKDg5WVFSUXFxcJEkJCQmaNm2aEcxu166d/Pz8dOzYMW3atEmSFBERoS5dumj06NEVdbkAAAAAgGqGgHYVu3r1qjHFGk+gAwDyMplMSk1NlZeXl+rUqVPVzam16KsBAIWpKX11YdN8r1y50tiuU6eOHnvsMUlScnKywsLCjPfGjRunKVOmSJKGDBkiPz8/mUwmxcfHKzIyUoGBgZKkFStW6PLly5IkV1dXhYWFycPDQ5JkZ2enqKgoSdKSJUs0atQo2dvbl6j99NUAAGtqSj9d3dFPAwAKU5q+moB2FTt79qz69+9f1c0AANiw7du3y9vbu6qbUWvRVwMAilMT++qrV69q+fLlxv7AgQPVqlUrSdJ3331nMWX4PffcY2y3adNG7du3V0xMjCQpOjraCGjnXX+7Z8+eRjBbkgYPHmwEtBMSEnTo0CF17dq1RG2lrwYAFKUm9tPVCf00AKA4JemrCWhXMVdXV0m5/1lubm5V3BoAgCTpb3+Tzp2TPD2l8PAqa0ZKSor69+9v9BWoGvTVAHCNbKRfrQg1ua/+4osvdPLkSWN/7NixxvaRI0csyrZs2bLAvjmgbS6bmZmpuLi4IuvkdeTIkRIHtOmrAaCGKOd7hprcT1cn9NMAUANU0Pf60vTVBLSrmHmaFTc3Nzp0ALAVdepIdna5f9vA72am5Kpa9NUAcI1srF+tCDWxr/7www+N7e7du+vmm2829i9evGhRNn//mHcwwlw2OTlZJpOpRHWsnaMo9NUAUENU0D1DTeynqxP6aQCoASr4e31J+moWDwEAAAAAAIYDBw7oxx9/NPYff/zxIsvnDVTn3zcPTBRVxto+AAAAAABmBLQBAAAAAIDhgw8+MLavv/56DRo0yOL9vGtfS1JqaqrFfkpKirHt7u5u1Mn71H1RdaydAwAAAABQexHQBgAAAAAAkqQTJ07o66+/NvbHjBmjOnUshw46dOhQoE5eedfeNpd1cnJSq1atrJaxdoz85wAAAAAA1F4EtAEAAAAAgCTpo48+0tWrVyXlZkmPGDGiQJnevXvLycnJ2N+6dauxffToUcXGxhr7AwcONLYHDBhgbO/du9dinewtW7YY215eXvL19b3GKwEAAAAA1BQOVd0AAABsTuPGln8DAICyo1+tNpKSkvTpp58a+w8//LDq1atXoJyHh4cCAwO1fPlySdKyZcuUnJysJk2aaP369UY5Hx8fDRs2zNgfM2aM1q5dq9TUVKWlpSkoKEh+fn6KjY21CIqPGzdO9vb2FXGJAABbxj0DAAC2yQb6aALaAADkt3JlVbcAAICag3612vj444915coVSVLdunUVFBRUaNmpU6cqJiZGu3fvVk5OjtauXWvxfoMGDTR//ny5uroar3l7e2vOnDkKDg5WZmamYmNjtWDBAot6Q4cOLfK8AIAajHsGAABskw300Uw5DgCwkJ6erv79Big9Pb2qmwIAgM3Lzs7WC8/PVHZ2dlU3BbgmmZmZCgsLM/aHDRumxkU8fe/s7KzQ0FC9+OKL6t69u9zc3OTk5KTrrrtOQUFBioqKUteuXQvUGzhwoDZs2KARI0aoWbNmcnR0lLu7u26//Xa99dZbevPNNwus2Q0A5Ym+GwCAmoW+vXYgQxsAYCHkmRD9cvA3TQ+ZoXnz367q5gAAYNPCw8P14dKV6uzbSSNHjqzq5gBl5uTkpJ07d5aqjoODgwIDAxUYGFiqem3bttWsWbNKVQcAygt9N6qjDh06FFtm+/bt8vb2NvZzcnK0bt06RUZGKjY2VhkZGfL29la/fv00fvx4eXl5WT1OXFycli5dqj179ujs2bNydXVVp06d9NBDD8nPz6/crgkAygt9e+3AY88AAEN6errWhq3XE/e+ojWr1pGlDQBAEbKzszV/zmKN95upeW8u4mlwAABsHH03aouMjAyNHz9eM2fO1IEDB3Tp0iVlZGTo+PHjWrlypR544AH98ssvBept375dw4YN0/r16xUfH6+srCwlJSVp165dmjJliqZPny6TyVQFVwQA1tG31x5kaAMADCHPhKhzy15q2aSdOrW4vfZmab/2mpScLLm7S88+W9WtAQDYqPDwcLVwv1EtPNuqeYMOWr9+PU+DW0O/CgCwEfTdNo57hmK5u7vriSeesPpe/fr1je158+YZM6/Y29vL399fnp6eioiI0KlTp5SUlKTg4GBFRUXJxcVFkpSQkKBp06YpIyNDktSuXTv5+fnp2LFj2rRpkyQpIiJCXbp00ejRoyvyMgGgxOjbK4kN9NEEtAEAkv6XnT35/twA9qCbRmrBqil6ffYsOTs7V3HrKtnOndLZs1Ih028BAGB+Cnzk7f+SJPXpNFTz3nxT/v7+cnDga5YF+lUAgA2g764GuGcolpubm8aOHVtkmeTkZIWFhRn748aN05QpUyRJQ4YMkZ+fn0wmk+Lj4xUZGWksHbJixQpdvnxZkuTq6qqwsDB5eHhIkuzs7BQVFSVJWrJkiUaNGiV7e/vyvjwAKBX69kpkA300U44DACT9Lzvbw7WxJMnDtbGRpQ0AACyZnwJ3d20kSXJ3bWQ8DQ4AAGwPfTdqgnPnzql///7q3LmzevTooYcfflirV6+2mGL3u+++M7KsJemee+4xttu0aaP27dsb+9HR0Va3e/bsaQSzJWnw4MHGdkJCgg4dOlRu1wQAZUXfXrsQ0AYAGNnZd3UNsHh90E0jWUsbAIB8zE+B9+74gMXruU+Ds2YXAAC2hr4bNUVmZqbOnDmj7OxsXbp0ST/88INeeuklPfroo8bYzZEjRyzqtGzZstB9c9nMzEzFxcWVqI61cwBAZaNvr31sLqC9ZcsWvfDCCxoxYoR8fX3VoUMH409JfPHFFxZ1OnTooL/++stq2bi4OD377LMaOHCgfH19ddttt+mxxx7T5s2bCz1+Tk6O1qxZo8DAQPXo0UNdu3bVPffco1dffVVnz54t0zUDQFXLn51tRpY2AAAF5X8K3IynwQEAsE303agJOnTooJEjR2ry5Ml6+OGH1aBBA+O977//XgsWLJAkXbx40aKem5ubxb6rq6uxbS6bnJwsk8lUojrWzgEAlY2+vfaxuYD2e++9p7Vr1+rQoUPKysoqVd2LFy/qxRdfLFHZ7du3a9iwYVq/fr3i4+OVlZWlpKQk7dq1S1OmTNH06dMtOnFJysjI0Pjx4zVz5kwdOHBAly5dUkZGho4fP66VK1fqgQce0C+//FKqNgNAVSssO9uMLG0AAP6nsKfAzXgaHAAA20LfjZpg8+bN+uyzz/Tyyy9r4sSJmjlzpqKiotSo0f8COREREQXGsyUVeC3vvp2dXbFlrO0DQFWib6+dbC6gbWdnp+uuu05+fn7q2bNnqeq+9NJLOn/+fLHlEhISNG3aNGMtkXbt2mny5Mm6//77jTIRERFavXq1Rb158+Zp586dkiR7e3sFBARo4sSJ8vHxkSQlJSUpODhYaWlppWo3AFSlwrKzzcjSBgDgfwp7CtyMp8EBALAt9N2oCdq2bVvgtaZNm1qsj33hwgVdvHjRYu1rSUpNTbXYT0lJMbbd3d0lSR4eHkZwu7g65vIAUFXo22snmwtor1mzRl9++aXefvvtUgW0P//8c23ZskWSNGjQoCLLrlixQpcvX5aUO11KWFiYJk6cqLfeektDhgwxyi1ZskQ5OTmScqddCQsLM94bN26cXnnlFU2ePFnLli0zOvz4+HhFRkaWuN0AUJWKy842I0sbAIDinwI342lwAABsA303arr8mdN2dnYFlu48ceKExf7JkyeNbXNZJycntWrVymoZa8co6fKgAFDe6NtrL5sLaDs7O5e6zoULF/TSSy9JkoYNG6a77rqryPLR0dHGds+ePS2eKBs8eLCxnZCQoEOHDkmSvvvuOyOjW5LF029t2rRR+/btrR4fAGxZyDMhau3pK8mkpNTEQv9IJrX29CVLGwBQq4WHh8vDyUcymZSccr7QPzKZ5OHkw9PgAABUMfpu1ASffPKJvvnmmwLB64SEBH355ZfGvqenpzw8PNS7d285OTkZr2/dutXYPnr0qGJjY439gQMHGtsDBgwwtvfu3WuxTrY5kUySvLy85Ovre41XBQBlQ99eezlUdQPKw4svvqgLFy7Iy8tL//73v/X1118XWjYzM1NxcXHGfsuWLS3ez79/5MgRde3aVUeOHCmyXMuWLRUTE2PUAYDq4PSpBJ1J+UNLo58rUflT8R4V2yAAAGzYuYREObpnKvqPj4ot6+gunT1zruIbBQAACkXfXbGys7P18kuv6IWZz8vBoUYMM9uko0eP6vnnn1fLli3Vu3dvNWvWTAkJCdq0aZOSk5ONcoGBgbKzs5OHh4cCAwO1fPlySdKyZcuUnJysJk2aWAR2fHx8NGzYMGN/zJgxWrt2rVJTU5WWlqagoCD5+fkpNjbWIig+btw42dvbV8KVA0BB9O21V7W/09i8ebPRob766qvGuh+FSU5Otniazc3NzeJ9V1dXi33zk2h5n0grrl7+sgBgqz4JX1PVTbBNgwdLly5JDRpUdUsAADZkUvDTmhT8dFU3o/qhXwUAVBH67ooVHh6uD5euVGffTho5cuS1H5B7hiKdPHlSa9ZYH8e577779MQTTxj7U6dOVUxMjHbv3q2cnBytXbvWonyDBg00f/58izFtb29vzZkzR8HBwcrMzFRsbKwWLFhgUW/o0KEKCgoqx6sCgNKhb68iNtBHV+uA9vnz5/Xyyy9LkkaMGKH+/fsXWyf/1CzF7ZflOOb1tAEA1VRwcFW3AACAmoN+FQCAGse8hul4v5ma9+Yi+fv7X3uWNvcMVj3xxBNq3769vvnmGx07dkznz59Xenq6PDw85OvrK39/f919990WdZydnRUaGqp169YpMjJSR48eVWZmpry9vdWvXz+NHz9eTZs2LXCugQMHasOGDQoNDdXu3buVmJgoFxcXdezYUQEBAbr//vsr67IBALbEBvroah3Qnj9/vi5evChvb289++yzJarj4eEhOzs7IwCdmppq8X5KSkqB8nn/NktNTVWDPE8i5K1XXJY4AAAAANgqpg8FAADFCQ8PVwv3G9XCs62aN+ig9evXl0+WNgpo0qSJAgICFBAQUKp6Dg4OCgwMVGBgYKnqtW3bVrNmzSpVHQAAKlqdqm7AtUhMTJQknTlzRrfeeqs6dOigDh06aMaMGRbl7rrrLnXo0EF//fWXnJyc1KpVK+O9kydPWpQ9ceKExX6HDh0s/i6sXN7j5C8LAAAAANWFefrQvGssAgAAmJmzs3t3fECS1KfTUM17c5Gys7OruGUAAKCmqtYB7bIaMGCAsb13716LNa+3bNlibHt5ecnX11eS1Lt3bzk5ORnvmdftlqSjR48qNjbW2B84cGCFtBsAAAAAKlL+6UMZmAYAAPmZs7PdXRtJktxdGxlZ2gAAABXB5uaPW716tZHtfPDgQYv3Zs+ebWw/+eST6t69u9Up8OLj4/Xrr78a+/369VO9evXk4uIiSRozZozWrl2r1NRUpaWlKSgoSH5+foqNjbUIVI8bN0729vaScqccDwwM1PLlyyVJy5YtU3Jyspo0aWJxs+bj46Nhw4Zd6z8DAKAq+ftL585Jnp4SX8gBALVIhUwfSr8KAECNYX74beTt/7J4PTdL+81rW0ubewYAAGyTDfTRNhfQ3rJli/bt22f1vQ8++MDYHj16tMaNG2e13Keffmox7fjMmTPVokULY9/b21tz5sxRcHCwMjMzFRsbqwULFlgcY+jQoQoKCrJ4berUqYqJidHu3buVk5OjtWvXWrzfoEEDzZ8/X66uriW7WACAbbpyRUpLy/0bAIBaIv8AdbkMTEv0qwAA1CD5s7PN8mZpl/lhOO4ZAACoNNnZ2Xr5pVf0wszni//ObwN9dK2cclzKnRZ8w4YNGjFihJo1ayZHR0e5u7vr9ttv11tvvaU333xTdepY/vM4OzsrNDRUL774orp37y43Nzc5OTnpuuuuU1BQkKKiotS1a9cquiIAAAAAKDumDwUAAEXJv3Z2fqylDQBA9REeHq4Pl66sNt/5bS5De+XKldd8jBEjRmjEiBHFlmvbtq1mzZpVqmM7ODgoMDBQgYGBZW0eAAAAANiUCp0+FAAA1AiFZWeblUuWNgAAqHDmMYDxfjM1781F1eI7f63N0AYAAAAA5CrJ9KEAAKD2Ki4724wsbQAAbJ95DKCFZ9ty+86fnZ2tF56fWWH3AAS0AQAAAKAWY/pQAABQnPDwcHk4+Ugmk5JTzhf6RyaTPJx8eBgOAAAblX8MoLy+81f0FOa2nT8OAAAAAKhQTB8KAACKcy4hUY7umYr+46Niyzq6S2fPnCu3c2dnZ+vll17RCzOft/npUAEAsHX5xwDK4zt/ZUxhzh0AAACS0tPTNfie+7T1iy1yrurGAABQSQpbOzs/1tIGAKB2mxT8tCYFP10l5zZnfHX27cTDdQAAXIPCxgCu9Tu/tSnMy7vPZspxAAAkhTwTol8O/qbpITOquikAAFQapg8FAAC2LH/GF0ugAABQdoXN0JY3S7u0KmoK8/x4tB4AUOulp6drbdh6PXHvK/pw1cua28NX9lXdKAAAKkFVTh8KAABQnMrI+AIAoDYoboa2smZpV8QU5tYQ0AYA1Hohz4Soc8teatmknTq1uF2L3epo8j//KdWtW9VNAwCgQlXK9KEzZkgZGeXSr7KGJgAANVi+e4b8A+8sgQIAQNkVlp1tVlQgOvuZZ7Rq6TIFjRtrEViuqCnMrWHKcQBArWbOzr6ra4AkadBNI/Xatl1K79NH6tu3ilsHAEAN0LevNGhQufSr5jU0mfocAIAaKN89Q1EZXwAAoOTyTwtemMKmCw8/c0bPf/2d1ickWL5eAVOYF4aANgCgVjNnZ3u4NpYkebg2VqcWt7OWNgAANoY1NAEAqD0KG3ivqHU5AQCoycLDw+Xh5COZTEpOOV/oH5lM8nDysQhEF/ZdvLggeXn32czNAgCotczZ2ZPvf9vi9UE3jdSCVVP0+uxZcnZ2rqLWAQCAvFhDEwCA2qMkGV/cBwAAUDLnEhLl6J6p6D8+Kraso7t09sw5Y7+w7+LXMoV5WRDQBgDUWvmzs81aZ6ZoSOOOenvcE5qxcnkVtQ4AgBri99+lrCzJ0VHq2LFMh2ANTQAAaoH/3jNk29lZXY/TjPsAAABKZ1Lw05oU/HSp65m/iz95wyi5n43VA97dNe/NRRo2bFiRfbVZefbZ9PgAgFqpsOxsSbpj13u6MzVRv639VulLl5ClDQDAtZg2TTp7VvLykjZvLtMhilpDk+wsAABqiP/eM5zNyVGLRrdWWsYXAACwzvxd/K69q+ScelHprg218frOCgmZbjGFeWFyrubo/NlkffLJJ3r44YevqS0EtAEAtVJh2dlm9vYOcnP20PSQGZo3v2DQGwAAVI782dlmZGdVjN9++00rV67U999/r7Nnz8rBwUGNGzeWr6+v/P391adPH6NsTk6O1q1bp8jISMXGxiojI0Pe3t7q16+fxo8fLy8vL6vniIuL09KlS7Vnzx6dPXtWrq6u6tSpkx566CH5+flV1qUCAGyQyWTSn38cV+/eLxVZjvsAAAAqlsV38T9/NV7v02moFkWGqOONHYqdwvzU6VO6kHxOX33xNQFtAABKq6js7Lwa1/fRmlXrWEsbAIAqVNQams3c2mvUyECtWfsxg9nlYNGiRVq0aJFMJpPxWkZGhlJTU3XixAm5uLgYAe2MjAxNmDBBO3futDjG8ePHtXLlSm3cuFGhoaHq0qWLxfvbt2/XpEmTlJGRYbyWlJSkXbt2adeuXdqxY4dmzZolOzu7CrxSAICtunjxohzr1C0240uSPJx89Mknn+jw70f0wsznuRcAAKAcFfVdvFub3nrosbuLnCklOztbfW8foGD/17X551BlZ2dfU19NLw8AqHVCnglRa09fSSYlpSYWeD8rJ1NOOdmSo0mtPX3J0gYAoIoUlp1tVr9uE0V9uVmffLJODz8cWMmtq1lWr16thQsXGvvdu3dX9+7d5e7uruTkZB07dkwNGzY03p83b54RzLa3t5e/v788PT0VERGhU6dOKSkpScHBwYqKipKLi4skKSEhQdOmTTOC2e3atZOfn5+OHTumTZs2SZIiIiLUpUsXjR49urIuHQBgQ7Kys2XnYCo240uSHN2lL7d+pa+2fqPOvp2YfhwAgHJS3HfxksyUYg6It/BsWy5LhRDQBgDUOqdPJehMyh9aGv2c1fd7nY9X46s5Op96RmfsUnUq3qNyGwgAACQV/kS4JOVczda+37/W44Oe06svzlJAwENkZpVRSkqK5s6da+y/9NJLGjVqVKHlk5OTFRYWZuyPGzdOU6ZMkSQNGTJEfn5+MplMio+PV2RkpAIDcx82WLFihS5fvixJcnV1VVhYmDw8PCRJdnZ2ioqKkiQtWbJEo0aNkr29fbleJwDA9jX18lJTLy99tjmi2LLmzK/xfjM1781FTD8OAEA5Keq7uJSbpV1UkDp/QLw8lgqpU6ZaAABUY5+Er1HcXzGF/hkwsL+6dvXVgIH9FfdXjD4JX1PVTQYAoNYxfwHu3fEBq+//cGS72jT11fVeN8rLuY0++WRdJbew5ti6datSUlIkSc2aNVNaWpqGDh2qbt266bbbbtOECRP0008/GeW/++47iynD77nnHmO7TZs2at++vbEfHR1tdbtnz55GMFuSBg8ebGwnJCTo0KFD5XNxAIAay1rmFwAAuDbFfRc3yw1SL1J2dnaB9/IHxPMGwMuKgDYAAAAAwOaEh4fLw8nHWEMz758Ll87q6wOfqnfHIZKkO31H6NUXZ1n9Io3iHTx40Ng+ffq0Zs+erSNHjujKlStKSkrS119/rYcfflibN2+WJB05csSifsuWLQvdN5fNzMxUXFxciepYOwcAAHnlH2wvalAdAACUnLXv4lnZmcq5mq2s7EzjNZlM8nDyKRCkLiwgfq19NXOwAAAAAABszrmERDm6Z1pdQ/PU6VNq0aSd6jrVVUZ2muq7eOj6hp2veU2u2urcuXMW+05OTgoICFDdunX1ySef6PLly8rOztZzzz2nXr166eLFixbl3dzcLPZdXV2NbXPZ5ORkmUymEtXJWw8AAGuKyvziXgAAgLKz9l28T1q8sjMzlGxKsXjd0V06e8by+2Rh05Vfa19NQBsAgHKWnp6uwffcp61fbJGzs3NVNwcAgGppUvDTmhT8dIHXzetlDr19jNzqNdDGXSv0wB3/p8E9Aq95Ta7aKisry2L/mWee0SOPPCJJuvXWW/XUU09JklJTUy2mDTfLG6jOv29nZ1dsGWv7AAAUJv+6nGblsT4nAAC1ndXv4n5+0tmzkpeXPtscUWjdwvpos2vpq5lyHACAchbyTIh+OfibpofMqOqmAABQ4+R92vuHI9u17/ev9UPMjnJZk6u2ql+/vsV+z549rW5L0okTJyzWvpZyA915mdfjliR3d3dJkoeHhxHcLq6OuTwAANbkvRfIuZqtDTs/UM7VbO4FAACoYoVlZ5tdS19NQBsAgPzCw6Xt23P/LqX09HStDVuvJ+59RWtWrVN6enoFNBAAgGrkGvrV/PKuxZVzNVvf/PiZHh/0vL45GKmcq9msn1lG7du3L3HZunXrqkOHDhavnThxwmL/5MmTxra5rJOTk1q1amW1jLVj5D8HAKAWKME9Q/51OfM+3CaxljYAABWiDH10YcraVxPQBgAgPxcXydU19+9SCnkmRJ1b9lLLJu3UqcXtZGkDAHAN/Wp++bOz2zT1VfPGbdS6aWeytK/BgAEDLPa///57q9uS5Ovrq969e8vJycl4bevWrcb20aNHFRsba+wPHDjQ6nn27t1rsU72li1bjG0vLy/5+vqW5VIAANVZCe4Z8mdn53+4jXsBAAAqQAn7aA8nH8lkUnLK+UL/yGSSh5NPqftqFhMBAKCcmLOzJ9//tiRp0E0jtWDVFL0+exZraQMAcI3yrsVlHsAeMyD3wbF+nYZq+bZZuuWGfqyfWQadO3dWv379tGNHbnbbG2+8oT///FN169bVunXrjHJt2rRR7969ZW9vr8DAQC1fvlyStGzZMiUnJ6tJkyYWgxI+Pj4aNmyYsT9mzBitXbtWqampSktLU1BQkPz8/BQbG2sRFB83bpzs7e0r+rIBANVM/nU5rT3c1vPGgca9wODBg6u4xQAA1B7nEhLl6J6p6D8+Kraso7t09sy5Uh2fb/cAAJQTc3a2h2tjSZKHa2MjS3ve/LeruHUAAFRveZ/2/vanTWrl2Ulu9Tx01XRVbvU8dL1nR+38ebO6tettPO09cuTIqm52tTFr1iw9+uijOnr0qDIyMrRy5UqL9z09PbVgwQIj0Dx16lTFxMRo9+7dysnJ0dq1ay3KN2jQQPPnz5erq6vxmre3t+bMmaPg4GBlZmYqNjZWCxYssKg3dOhQBQUFVdBVAgCqs7z3AhcundXXBz7VowOf01XTVfXp+IA+in5V7Xx8ZV/HXh5OPoqMjKzqJgMAUGtMCn5ak4KfLlWdlJSUEpcloA0AQH5hYVJqau40KqNHl6hK/uxsM7K0AQC1Xhn6VWvMT3t/FfuBDv74k8bd/bIystOM92+/8R4t/fIFJeqIHN3rlPpp79quSZMm+uSTT7R8+XJ9/vnnOnHihHJyctS8eXMNGDBAY8eOVePGjY3yzs7OCg0N1bp16xQZGamjR48qMzNT3t7e6tevn8aPH6+mTZsWOM/AgQO1YcMGhYaGavfu3UpMTJSLi4s6duyogIAA3X///ZV52QAAW1LMPUPezK9Tp0+pRZN2qutUVxnZaarrVFctmrTVmj2z1czbR47uUuLZ81VwEQAA1EDl9L3+WtiZTCZTlZwZknKfPrjlllv0ww8/yM3NraqbAwCQJD8/6exZyctL2ry5RFWCJwfr1x2n5N/rqQLvhe96R13vbFnqLG36CNvA/wMAXKMy9KtFWbNmjdYv/Vp+t44p8N6m7z/SQ0/cXWmZ2fQRtoH/BwCoIUp4z5Cdna2+tw/QyNv/JXfXRsbryakXtHbPm/p2zzY5ODjQP9gI/h8AoAYo5+/1ZqXpI+qU21kBAKilzNnZd3UNsPr+oJtGas2qdUpPT6/klgEAULOY187s3fEBq+/nrpm5SNnZ2ZXcMgAAUFnCw8PVwv1Gi2C2JLm7NlLzBh20fv36KmoZAACoKAS0AQC4RvnXzs4v71ratVVKSoref/99jRo1Sj179lSnTp1000036e6779Yzzzyjn376qUCdnJwcrVmzRoGBgerRo4e6du2qe+65R6+++qrOnj1b6Lni4uL07LPPauDAgfL19dVtt92mxx57TJvL8elBAEDVKGwA24yBbAAAajYebgMAoHayuTW0t2zZot27d+vXX39VTEyMsrKyjPeOHDlSoPyOHTu0Z88eHTx4UAkJCUpMTFSdOnXUokUL9e3bV2PHjlWTJk2snisuLk5Lly7Vnj17dPbsWbm6uqpTp0566KGH5OfnZ7VOTk6OsUZYbGysMjIyLNYI8/LyKp9/CABAtVDY2tn51ea1tC9fvqyAgAD98ccfFq/n5OToxIkTOnHihDZu3KjXX39dw4YNkyRlZGRowoQJ2rlzp0Wd48ePa+XKldq4caNCQ0PVpUsXi/e3b9+uSZMmKSMjw3gtKSlJu3bt0q5du7Rjxw7NmjVLdnZ2FXS1AICKYh7AHnn7v4oslzuQ/ab8/f3l4GBzX3kBAMA1KM3Dbffff38ltw4AAFQUm/t2/9577+nw4cMlLj9x4kRlZmYWeP3o0aM6evSoIiIitGLFCt1www0W75dlwLusg+sAgJor5JkQtfb0lWRSUmpikWVbe/pqesiMUq+lXd2tXbvWIpjds2dP9erVS2fOnNH69euVnZ2tq1evasGCBUZAe968eUZ/a29vL39/f3l6eioiIkKnTp1SUlKSgoODFRUVJRcXF0lSQkKCpk2bZvTt7dq1k5+fn44dO6ZNmzZJkiIiItSlSxeNHj26Mv8JAADlIDw8XB5OPpLJpOSU80WW9XDy0fr16yttLW0AAFDxSvtw2+DBgyupZQAAoKLZXEDbzs5O1113nXx9fZWYmKh9+/YVW8fe3l49e/ZUt27dZDKZ9OWXX+rYsWOSpIsXL2rmzJn6+OOPjfJlHfAuy+A6AKBmO30qQWdS/tDS6OeKLXv16lWt+fjnWpelfeLECWO7fv36+uijj2Rvby9JysrK0qeffipJunDhgiQpOTlZYWFhRp1x48ZpypQpkqQhQ4bIz89PJpNJ8fHxioyMVGBgoCRpxYoVunz5siTJ1dVVYWFh8vDwkJR7fxEVFSVJWrJkiUaNGmW0AQBQPZxLSJSje6ai//io2LKO7tLZM+cqvlEAAKDSlPbhtsjIyEpqGQAAqGg2F9Bes2aNMci/cOHCYgPaI0aM0Pjx49W8eXPjtYkTJ2rEiBE6evSoJOnAgQNKSUmRm5ubpLINeJd1cB0AULN9Er6mxGWDJwdr5Ydral2Wdrt27Yzt1NRUbd++XX369NHp06ct1s7u27evJOm7776zmEHlnnvuMbbbtGmj9u3bKyYmRpIUHR1t9LnR0dFGuZ49exp9uyQNHjzY6N8TEhJ06NAhde3atRyvEgBQ0SYFP61JwU9XdTMAAEAVKe3DbYlniw56AwCA6sPmAtqlzVh76aWXCrzm5OSkvn37GgFtSRZrcZdlwLusg+sAAEj/W2v7iXtf0YerXq5VWdoBAQHavHmzDh48qKtXr+qpp56yeN/e3l6DBw/Wiy++KEk6cuSIxfstW7YssG/uc81lMzMzFRcXV2SdvI4cOUJAGwAAAACqkdI+3JaSkqL3Q5dUYIsAAEBlqVPVDagoeQe1W7RooYYNG0oq24B33r9LUi9/WQAAQp4JUeeWvdSySTt1anG7pofMqOomVRpnZ2etWLFCDz30kNX327Ztq/vvv1/u7u6ScpcLycs8w4qZq6ursW0um5ycLJPJVKI61s4BAAAAAAAAALBNNTKgvWXLFm3bts3YnzBhgrFd1gHvsgyuAwCqqRtvlLp0yf27HJizs+/qGiBJGnTTSK1ZtU7p6enlcnxbl5KSonHjxmndunWSpK5du2rSpEkaMWKEHBwcFBMTo4kTJ+qDDz6wWj9vv51/387Ortgy1vYBAJWonPtVAABQQ3HPAACAbbKBPtrmphy/VuvXr9cLL7xg7D/66KPy9/c39strwLskg+sAgMqRnp6uGSEhSohP0OpSrGldqLfeuvZj5GHOzvZwbSxJ8nBtbGRp14a1tBcvXqw9e/ZIkq6//np9/PHHcnDIvQVp3ry5Fi5cKEmaP3++AgICLJYCkXLX3W7QoIGxn5KSYmybs7o9PDxkZ2dn9MepqakWx8hbx1weAFBJyrlfBQAANRT3DAAA2CYb6KNrVIb2ggUL9Oyzzyo7O1uS9Pe//10zZlhO6Woe8DYr6YC3tcH1wuqZB9cBABUrPT1dU4KD1bFle8VvO6qf9h2s6iYVkD8726w2ZWnv3r3b2O7UqZMRzJakLl26GNvp6emKi4tThw4dLOqfOHHCYv/kyZPGtrmsk5OTWrVqZbWMtWPkPwcAAAAAAAAAwDbViIB2VlaWQkJCtHjxYklSnTp19Nxzz+lf//pXgbJlHfAuy+A6AKBi5A1kp+w+o/BRC/Svfn+v6mZZlT872yxvlnZNl5OTY2z//vvvFvu//vqrRVlnZ2f17t1bTk5Oxmtbt241to8eParY2Fhjf+DAgcb2gAEDjO29e/daLAGyZcsWY9vLy0u+vr5lvRwAAAAAAAAAQCWq9lOOX758WU8//bQxlamLi4vmzp1rMcCd34ABAxQXFyfpfwPeDRs2lFT4gLd5cD0zM1NS7uC6+b2iBtcBAOXHPLX4htWfalDrOxQ+aoGaujWRJJ2+fK6KW1eQOTt78v3WpxUfdNNILVg1Ra/PniVnZ+dKbl3l6dGjh2JiYiRJf/75p0aPHq0+ffro9OnTioyMNMp5e3urbdu2qlOnjgIDA7V8+XJJ0rJly5ScnKwmTZpo/fr1RnkfHx8NGzbM2B8zZozWrl2r1NRUpaWlKSgoSH5+foqNjbUIio8bN0729vYVfdkAAAAAAAAAgHJgcwHt1atXG9nOBw9aTh07e/ZsY/vJJ5+Uu7u7AgMDdfToUeP1gQMHKi4uTsuWLbOo6+fnp2bNmkkq24C3h4dHmQbXAQDXrqhAdoWYOlW6eFFq2PCa1gcpLDvbrLaspT1hwgR9++23xuwmBw8eLNDHOzk56dVXX1WdOrmTx0ydOlUxMTHavXu3cnJytHbtWovyDRo00Pz58+Xq6mq85u3trTlz5ig4OFiZmZmKjY3VggULLOoNHTpUQUFBFXGZAIDClFO/CgAAajjuGQAAsE020EfbXEB7y5Yt2rdvn9X3PvjgA2N79OjRcnd3twhmS1JUVJSioqIK1PX19TUC2mUd8C7L4DoAoOwqPZBtdviwdPas5OVV5kMUl51tVhuytJs0aaKIiAitWrVK27ZtU1xcnFJSUuTk5CRvb2/ddtttGjNmjNq0aWPUcXZ2VmhoqNatW6fIyEgdPXpUmZmZ8vb2Vr9+/TR+/Hg1bdq0wLkGDhyoDRs2KDQ0VLt371ZiYqJcXFzUsWNHBQQE6P7776/MSwcASOXSrwIAgFqAewYAAGyTDfTRNhfQrixlGfAu6+A6AKBs/AbfpyM//qZlI16Tr/cNVd2cUgl5JkStPX0lmZSUmlhk2daevjU+S9vNzU1PPvmknnzyyRLXcXBwUGBgoAIDA0t1rrZt22rWrFmlbSIAAAAAANVCdna2AgICdOjQIeO14cOH6/XXX7col5OTY4xlx8bGKiMjw2Is26uQwERcXJyWLl2qPXv26OzZs3J1dVWnTp300EMPyc/Pr0KvDQAAa2wuoL1y5cpSlT9y5EiZz1WWAe+yDq4DAEpv89YtmhESoifDZmpQmzv01G2BlZOhXQ5On0rQmZQ/tDT6uRKVPxXvUbENAgAAAAAANcKSJUssgtnWZGRkaMKECdq5c6fF68ePH9fKlSu1ceNGhYaGqkuXLhbvb9++XZMmTVJGRobxWlJSknbt2qVdu3Zpx44dmjVrluzs7MrvggAAKIbNBbQBADBzdnbW2/Pna9bs2ZoREiL/sEnVJrD9Sfiaqm4CAAAAAACoYQ4fPqx333232HLz5s0zgtn29vby9/eXp6enIiIidOrUKSUlJSk4OFhRUVFycXGRJCUkJGjatGlGMLtdu3by8/PTsWPHtGnTJklSRESEunTpotGjR1fQFQIAUFCdqm4AAADFMQe2D/8Vq/q9msn/40l68euFSkgpeipvW5eenq7+/QYoPT29qpsCAAAAAABsXFZWlqZPn66srCz5+voWuvxlcnKywsLCjP1x48bplVde0eTJk7Vs2TIjuzo+Pl6RkZFGuRUrVujy5cuSJFdXV4WFhWnixIl66623NGTIEKPckiVLlJOTUxGXCACoRrKzs/XC8zOVnZ1d4ecioA0AqDZqWmA75JkQ/XLwN00PmVHVTQEAAAAAADbuvffe0++//y4nJyfNnj1bDg7WJ2D97rvvLKYMv+eee4ztNm3aqH379sZ+dHS01e2ePXvKw8PD2B88eLCxnZCQUOyU5wCAmi88PFwfLl2p9evXV/i5CGgDAKoda4HtN3eEVnWzSiU9PV1rw9briXtf0ZpV68jSBgAAAAAAhfr999+1ZMkSSdLkyZPVrl27QsseOXLEYr9ly5aF7pvLZmZmKi4urkR1rJ0DAFC7ZGdna/6cxRrvN1Pz3lxU4VnaBLQBANVW3sB28wHtdVPP7lXdpBILeSZEnVv2Ussm7dSpxe1kaQMAAAAAAKvyTjXerVs3Pf7440WWv3jxosW+m5ubxb6rq2uBssnJyTKZTCWqY+0cAIDaJTw8XC3cb1QLz7Zq3qBDhWdpE9AGAFR75sD26vA1Vd2UEjFnZ9/VNUCSNOimkWRpAwAAAAAAq9555x0dPnxYdevW1axZs2Rvb1+q+nkD1fn3zetpF1XG2j4AoPYyZ2f37viAJKlPp6EVnqVtfZENAABqs9GjpdRUKd/Tx+XFnJ3t4dpYkuTh2tjI0p43/+0KOScAAFWmgvtVAABQQ3DPYNXp06f1/vvvS5KmTJmiNm3aFFsn79rXkpSamqoGDRoY+ykpKca2u7u7UcfOzs4IXKemplocI28da+cAANRg+fpoc3a2u2sjSZK7ayMjS3vkyJEV0gQC2gAA5Dd6dIUd2pydPfl+y8D1oJtGasGqKXp99iw5OztX2PkBAKh0FdivAgCAGqQU9wzZ2dl6+aVX9MLM5+XgULOHuJOSkoyMt9dff12vv/661XIRERGKiIjQ8OHD1bdvX4v3Tpw4IV9fX2P/5MmTxnaHDh0kSU5OTmrVqpWxjnbeMuZj5GWuBwCoBfL00ebs7JG3/8uiSG6W9pvy9/evkL6ZKccBAKhE+bOzzfJmaQMAAEvZ2dl64fmZFTp9GQAAqD7Cw8P14dKVFb5eZ3XVu3dvOTk5Gftbt241to8eParY2Fhjf+DAgcb2gAEDjO29e/darJO9ZcsWY9vLy8siQA4AqD3yZ2eb5c3Srgg1+/E1AACsSE9P14yQECXEJ1TqutuFZWebkaUNAIB15kHrzr6dKmz6MgAAUD2YM8PG+83UvDcXVVgmmK2oX7++Bg8ebPW9HTt26MqVK5Kk5s2by9fXV126dJGHh4cCAwO1fPlySdKyZcuUnJysJk2aWAQafHx8NGzYMGN/zJgxWrt2rVJTU5WWlqagoCD5+fkpNjbWIig+bty4Uq/jDQCo/grLzjaryCztmtvTAwCQjzmQvWH1p+rRrIsOJR2zXjAtTTKZJDs7ycWl3M5fWHa2GWtpAwBqpGvsV2vboDUAALVWCe8ZzJlhLTzbVvh6nbagRYsWWrBggdX3Bg4cqPj4eElSz549LaYjnzp1qmJiYrR7927l5ORo7dq1FnUbNGig+fPnyzXPmuXe3t6aM2eOgoODlZmZqdjY2ALnHjp0qIKCgsrr8gAA1cF/++iIQrKzzSpyLW2mHAcA1Hjp6emaEhysji3bK2X3GYWPWqB/9ft74RX+9jepf//cv8uxDWvD1uuurgFFlht000itWbVO6enp5XZuAACq1DX2q9YGrQEAQA1UgnsG84NuvTs+IMmcCbaIZUmscHZ2VmhoqF588UV1795dbm5ucnJy0nXXXaegoCBFRUWpa9euBeoNHDhQGzZs0IgRI9SsWTM5OjrK3d1dt99+u9566y29+eabqlOHsAIA1Cp/+5tM/fqp+eQpRh9cmIrqm3msHQBQY+XNyB7U+g6Fj1qgpm5NJEmnL5+r1LaEPBOi1p6+kkxKSk0ssmxrT19ND5mhV//zSuU0DgAAG5V/OrOKnL4MAADYvvzrdlZkJlh1EB0dXeT7Dg4OCgwMVGBgYKmO27ZtW82aNetamgYAqGEuXrwoxzp1JZNJySnniyzr4eRT7n0zIwAAgBqnqEB2VTl9KkFnUv7Q0ujnSlT+VLxHxTYIAIBqgEFrAABgVti6nTzwBgBAxcvKzpadg0nRf3xUbFlHd+nsmfJNKKOHBwDUGLYYyDb7JHxNqeukpKRUQEsAAKgeGLQGAAB55X/QzYwH3gAAqHhNvbzU1MtLn22OqJLz8+0fAFBj+A2+T0d+/E3LRrwmX+8bqro5AADgGjBoXbk6dOhQbJnt27fL29vb2M/JydG6desUGRmp2NhYZWRkyNvbW/369dP48ePl5eVl9ThxcXFaunSp9uzZo7Nnz8rV1VWdOnXSQw89JD8/v3K7JgBAzVHYg25mPPAGAEDNVqeqGwAAQHnZvHWLAh4dpSc3ztSLXy9UQkrRa1UDAADbZB607t3xAavv5w5aL1J2dnYltwxmGRkZGj9+vGbOnKkDBw7o0qVLysjI0PHjx7Vy5Uo98MAD+uWXXwrU2759u4YNG6b169crPj5eWVlZSkpK0q5duzRlyhRNnz5dJpOpCq4IAGDLCnvQzSzvA28AAKDm4XE1AECN4ezsrLfnz9es2bM1IyRE/mGTNKjNHXrqtkCbmXocAAAUrzSD1mRply93d3c98cQTVt+rX7++sT1v3jzt3LlTkmRvby9/f395enoqIiJCp06dUlJSkoKDgxUVFSUXFxdJUkJCgqZNm6aMjAxJUrt27eTn56djx45p06ZNkqSIiAh16dJFo0ePrsjLBABUI8VlZ5uRpQ0AQM1Fzw4AqHEIbAMAUH0xaF213NzcNHbs2CLLJCcnKywszNgfN26cpkyZIkkaMmSI/Pz8ZDKZFB8fr8jISAUGBkqSVqxYocuXL0uSXF1dFRYWJg8PD0mSnZ2doqKiJElLlizRqFGjZG9vX96XBwCohsLDw+Xh5COZTEpOOV9kWQ8nHx54AwCgBuJbPwCgxioqsA0AAGwTg9ZV69y5c+rfv78SExPl4uKi9u3ba8iQIQoICDAeHPjuu++MLGtJuueee4ztNm3aqH379oqJiZEkRUdHGwHt6Ohoo1zPnj2NYLYkDR482AhoJyQk6NChQ+ratWuFXScAoPo4l5AoR/dMRf/xUbFlHd2ls2fOVXyjAABApSKgDQCo8awFtnv6MEAKAIAtYtC6amVmZurMmTOSpEuXLumHH37QDz/8oM2bNys0NFTOzs46cuSIRZ2WLVsW2DcHtM1lMzMzFRcXV2SdvI4cOUJAGwAgSZoU/LQmBT9d1c0AAABViIA2AKDWyB/YdohvYL3g3LlSVpbk6Fi5DQQAoCYqZb/KoHXV6dChg7p166amTZsqMTFRUVFRunTpkiTp+++/14IFC/TMM8/o4sWLFvXc3Nws9l1dXY1tc9nk5GSZTKYS1clbDwBQi/BdHAAA22QDfTQBbQBArWMObBeqY8fKawwAADUd/Wq1sHnzZrVt29bitSeffFIPPvigLly4IEmKiIjQv/5VcG3zvIHq/Pt2dnbFlrG2DwCohbhnAADANtlAH12nqhsAAAAAAACqVv5gtiQ1bdrUYn3sCxcu6OLFixZrX0tSamqqxX5KSoqx7e7uLkny8PAwgtvF1TGXBwAAAABAIqANAAAAAAAKkT9z2s7OTh06dLB47cSJExb7J0+eNLbNZZ2cnNSqVSurZawdI/85AAAAAAC1F1OOAwAgKT09XTNCQpQQn6DVwROljAypbl2pb9+qbhoAANXbt9/Sr9q4Tz75RF5eXurfv79FFnVCQoK+/PJLY9/T01MeHh7q3bu3nJyclJmZKUnaunWrfH19JUlHjx5VbGysUWfgwIHG9oABAxQXFydJ2rt3ry5evKiGDRtKkrZs2WKU8/LyMo4HAKhFuGcAAMA22UAfTUAbAFCrmQPZG1Z/qh7NuuhQ0jFp1izp7FnJy4sv0QAAXCv6VZt39OhRPf/882rZsqV69+6tZs2aKSEhQZs2bVJycrJRLjAwUHZ2dvLw8FBgYKCWL18uSVq2bJmSk5PVpEkTrV+/3ijv4+OjYcOGGftjxozR2rVrlZqaqrS0NAUFBcnPz0+xsbHaunWrUW7cuHGyt7evhCsHANgU7hkAALBNNtBHE9AGANRKeQPZg1rfofBRC3TVZNKjn82o6qYBAABUiZMnT2rNmjVW37vvvvv0xBNPGPtTp05VTEyMdu/erZycHK1du9aifIMGDTR//ny5uroar3l7e2vOnDkKDg5WZmamYmNjtWDBAot6Q4cOVVBQUDleFQAAAACguiOgDQCoVawFspu6NZEknb58ropbBwAAUPmeeOIJtW/fXt98842OHTum8+fPKz09XR4eHvL19ZW/v7/uvvtuizrOzs4KDQ3VunXrFBkZqaNHjyozM1Pe3t7q16+fxo8fr6ZNmxY418CBA7VhwwaFhoZq9+7dSkxMlIuLizp27KiAgADdf//9lXXZAAAAAIBqwuYC2lu2bNHu3bv166+/KiYmRllZWcZ7R44csVonJyfH+BIdGxurjIwMiy/RXl5eVuvFxcVp6dKl2rNnj86ePStXV1d16tRJDz30kPz8/Mr1XACAqlVUIBsAAKA2a9KkiQICAhQQEFCqeg4ODgoMDFRgYGCp6rVt21azZs0qVR0AAAAAQO1lcwHt9957T4cPHy5x+YyMDE2YMEE7d+60eP348eNauXKlNm7cqNDQUHXp0sXi/e3bt2vSpEnKyMgwXktKStKuXbu0a9cu7dixQ7NmzZKdnd01nwsAUHUIZAMAAAAAAAAAUH3VqeoG5GdnZ6frrrtOfn5+6tmzZ7Hl582bZwSY7e3tFRAQoIkTJ8rHx0dSbpA6ODhYaWlpRp2EhARNmzbNCGa3a9dOkydPtpjaLCIiQqtXr77mcwEAqpbf4Pv0yUdr9O6QFzXzrqcJZgMAAAAAAAAAUI3YXIb2mjVr5OzsLElauHCh9u3bV2jZ5ORkhYWFGfvjxo3TlClTJElDhgyRn5+fTCaT4uPjFRkZaUyDtmLFCl2+fFmS5OrqqrCwMHl4eEjKDahHRUVJkpYsWaJRo0bJ3t6+zOcCAFStzVu3aEZIiJ4Mm6lBbe7QU7cFEtQGAAAAAAAAAKCasLkMbXMwuyS+++47iynD77nnHmO7TZs2at++vbEfHR1tdbtnz55GMFuSBg8ebGwnJCTo0KFD13QuAEDVcnZ21tvz5+vwX7Gq36uZ/D+epBe/XqiElMSqbhoAAAAAAAAAACiGzQW0S+PIkSMW+y1btix031w2MzNTcXFxJaqTt15ZzgUAsB0EtgEAAAAAAAAAqH6qdUD74sWLFvtubm4W+66urgXKJicny2QylahO3nplORcAwPaUKLBdr57k4pL7NwAAuDb0qwAAoCS4ZwAAwDbZQB9tc2toX4u8ger8+3Z2dsWWsbZ/LecCANguc2B71uzZmhESIv+wSerp0zX3zfXrq7ZxAADUJPSrAACgJLhnAADANtlAH12tM7Tzrn0tSampqRb7KSkpxra7u7tRJ2/Auag6ec9RlnMBAGxf3ozt5gPa66ae3au6SQAAAAAAAAAA4L+qdUC7Q4cOFvsnTpyw2D958mSBsk5OTmrVqpXVMtaOYa5XlnMBAKoPZ2dnzZo9W02bN9XDfxtV1c0BAAAAAAAAAACq5gHt3r17y8nJydjfunWrsX306FHFxsYa+wMHDjS2BwwYYGzv3bvXYs3rLVu2GNteXl7y9fW9pnMBAGxfenq6pgQHq2PL9orfdlQ/7TtY1U0CAAAAAAAAAACywTW0V69ebWQ7HzxoGVCYPXu2sf3kk0/Kw8NDgYGBWr58uSRp2bJlSk5OVpMmTbQ+z3zuPj4+GjZsmLE/ZswYrV27VqmpqUpLS1NQUJD8/PwUGxtrEageN26c7O3tJanM5wIA2K709HTNCAnRhtWfalDrOxQ+aoGumkz6KuxJ6ZVXpAYNpODgqm4mAADV2/z50qVLldavZmdna314uBITEjUx+OkKPx8AACgnlXzPAAAASsgG+mibC2hv2bJF+/bts/reBx98YGyPHj1a7u7umjp1qmJiYrR7927l5ORo7dq1FnUaNGig+fPny9XV1XjN29tbc+bMUXBwsDIzMxUbG6sFCxZY1Bs6dKiCgoIsXivLuQAAtsdaILupWxNJ0unL59Q7PVWKjJS8vPgSDQDANcjOztbZjz6Sw/nz8vL1rdB+1RzIfvetxWrn0kLJrhkEtAEAqE62bpXOnuW7OAAAtsYG+uhqPeW4lLvmaWhoqF588UV1795dbm5ucnJy0nXXXaegoCBFRUWpa9euBeoNHDhQGzZs0IgRI9SsWTM5OjrK3d1dt99+u9566y29+eabqlOnTrmcCwBgG/JOLZ6y+4zCRy3QzLueNoLZAADURtnZ2Vq7Zo0Wz19Ubscw7w+6Y4DOn0jQ5eTL5dXcQs896I4B2rc8WvPvmqGnb3+kws4HAAAAAAAql81laK9cubLUdRwcHBQYGKjAwMBS1Wvbtq1mzZpVKecCAFSdojKyAQCorcojozn/MS7Wu6ImTZvo3bcW65bGHTX/rhm6/vxMnUuMrdD2m8/l6dZYknT28vlyPx8AAAAAAKiapb5sLqANAEB58xt8n478+JuWjXhNvt43VHVzAACoUtYCwSaT9J9fQst8jLkDntHXh3fp/b0fq5W8LILLJpNJmVlZOv7ncV1v5Ril/QJcVCAbAAAAAABUjKsmk9atWaN35i6SQ5qUUiddT0x8slKC2wS0AQA13uatWzQjJERPhs3UoDZ36KnbAsnQBgDUOuWR0WwtkP39nz8peN1LurlZZy178DW1b9k2t2xOtjYf2qaup2PU1M5e5xPP63qVPTOcQDYAAAAAAJXvqsmkpAsXFHP0D606naWMpFRd3/h6fXN8vwbdMaDMs76VBgFtAECN5+zsrLfnz9es2bM1IyRE/mGTCGwDAGqN8ggEFxXI7uHTRQuHPK9GLh5KyUozAtmrvt+gHj5dFNi0veqkXlSyKVVr16wpc2b4qy+/otWhq/Su/8vq6N2uLP8UAAAAAACghMxjAdfv2qvGWdm6apLauDZXn2bdFfHrF7rzuls17a7xpZ71rSwIaAMAag0C2wCA2qQiAtnmY8z9OlSf/fyl3hn2ojp65WZkZ+Rk6vMjOxTx25dGkNvTtZEc1v5TyRkpupRxWfuWR5d5revnXnheHTt11MtzF+mWJp00ptuDZGgDAAAAAFDOzGMB78xdpAZZzpqRma269k5qWq+Bfoj/VXXUVQuHzpRDHXs5ZtVRpsPVCm8TAW0AQK1TVGC7sqSnp2vwPfdp6xdb5OzsXGnnBQDUHuWR0VzYMYLvfFTtPa/Xi9ELdYtPZzVv0FSf/R6tW318jUB29tVsbfwtWt1OH1Zzewd1adpBN/QZW+brcXBw0MhRo+T/t79pfXi4Js99jcA2AAAAAADlJH8gOyMpVW2at1VTtyZKu5Sgq47OWjDkedVzrKuM7Ew52jsqKzNLcrCv8LbVqfAzAABgo8yB7cN/xap+r2by/3iS3txRsVOjmIU8E6JfDv6m6SEzKuV8AIDa57kXntcrb/1HL+95V3N2LtO5lJJnQxd3DAd7B/l1HqDRtw7T9rjv9fvZY5p9zz81pc9jalivgTb+Fq2gtf9UTOKf6tS0nZq6NZGTvWO5XJc5sP317m9025iBmvzVa2W+PgAAAAAAkOvlF1/S1AlTlJZwSW1cm2t4x0H6If5XZWRnqqV7M13n0Ux17OwkSQ3rucvNyaXS2kaGNgCg1nN2dtas2bOVnZ2tr7+M1um2baW77pLc3SvkfOnp6Vobtl5P3PuKPlz1sl6fPYssbQBAuSuPjOaijrFib4Qx7fiNXm11JTNdSemXtGz/On1+ZIfeefAldfRsK9PuFUpPT1G6Y91Kuz4AAFAN9ekjJSdX2HdxAABQvLoOjpre/wl9c2yPQvd9oneGvagmR7YrJf2S7JwbqGE9d9nXsZfJZNJVU8VPNW5GQBsAUKulp6drRkiINqz+VD2adZFd+lWNjPm5Qs8Z8kyIOrfspZZN2qlTi9s1PWSG5s1/u0LPaSt+++03rVy5Ut9//73Onj0rBwcHNW7cWL6+vvL391efPn2Msjk5OVq3bp0iIyMVGxurjIwMeXt7q1+/fho/fry8vLysniMuLk5Lly7Vnj17dPbsWbm6uqpTp0566KGH5OfnV1mXCgA2o6IC290b3ahxvQP1YvRC9WjeRUHdh6mek7Mm3fmorm/YXC98OV+3teyq/7t5uBrVc1dqTroaVtL1tXdtKblWwMkAAEDFefbZqm4BAAC12gsvzlRn385aMGeR2js3l6drYz0aPl333tBXT90eJO/6nqr4ycWtY8pxAECtlJ6erinBwerYsr1Sdp9R+KgF+le/v1fKedeGrdddXQMkSYNuGqk1q9YpPT29ws9d1RYtWqQRI0bo008/1cmTJ5WRkaHU1FSdOHFCmzdv1pYtW4yyGRkZGj9+vGbOnKkDBw7o0qVLysjI0PHjx7Vy5Uo98MAD+uWXXwqcY/v27Ro2bJjWr1+v+Ph4ZWVlKSkpSbt27dKUKVM0ffp0mUymyrxsALAZ5TFVd95j9HpskDad+lY9bugun8bN9PRnL2nOt8t0xZShh+94UMuD5qiFRzNNjMx9PTH1YgVenWXb7n5ymO68Z2CFng8AAAAAgJrEwcFBwx58UN163awvfvtWHb3aKnz0It3S3FfBUa9qzrehOpd6oWraViVnBQCgiuTNyB7U+g6Fj1qgpm5NJEmnL5+r8PObs7M9XHMz4jxcG9eKLO3Vq1dr4cKFxn737t3VvXt3ubu7Kzk5WceOHVPDhv/L25s3b5527twpSbK3t5e/v788PT0VERGhU6dOKSkpScHBwYqKipKLS+5aLQkJCZo2bZoyMjIkSe3atZOfn5+OHTumTZs2SZIiIiLUpUsXjR49urIuHQBsTnlkNOc/xjtzF6lTqw46fPm4Jn/1vwzwh+94UENvulufHNykxzc8q2Hd7ylVZvi1XB8AAKgZsrOz9fJLr+iFmc/LwYHhbAAAKpLf4Pt05MfftGzEa/L1vkEmk0nNG3jp3hv66vOYb/X0Zy+pR4su+r/uw9XYxUMmmSRVfAIRdwAAgFqhqEB2ZbZhbdh6Tb7fMnA96KaRWrBqSo1dSzslJUVz58419l966SWNKiLQkJycrLCwMGN/3LhxmjJliiRpyJAh8vPzk8lkUnx8vCIjIxUYGChJWrFihS5fvixJcnV1VVhYmDw8PCRJdnZ2ioqKkiQtWbJEo0aNkr19VU2QAwC2IX9QOjEh8ZqPcUtCop6Y+GSBqc2H3DRIB/VHbmY4a10DAIBSCA8P14dLV6qzbyeNHDmyqpsDAECNtnnrFs0ICdGTYTM1qM0deuq2QDV1ayJHO0cNuXGAEdietPFl3ezTWcM6DVL9OvUrvF1MOQ4AqNGsTS0+866niw5mP/KI5OeX+3c5yp+dbZY3S7sm2rp1q1JSUiRJzZo1U1pamoYOHapu3brptttu04QJE/TTTz8Z5b/77jsjy1qS7rnnHmO7TZs2at++vbEfHR1tdbtnz55GMFuSBg8ebGwnJCTo0KFD5XNxAFADmIPSE4OfLpdj5J/aPOH9R2W/9O8K/vlAgSnPF+1ZWY5XAgAAqjUr38Wzs7M1f85ijfebqXlvLlJ2dnYVNhAAgJrP2dlZb8+fr8N/xap+r2by/3iSTi4NUoM1U9R402tytM8NbK8MeFPN6ntpTHiIZn/9foUv80hAGwBQo/kNvk+ffLRG7w55sfhAttn589LZs7l/l5P8a2fnV5PX0j548KCxffr0ac2ePVtHjhzRlStXlJSUpK+//loPP/ywNm/eLEk6cuSIRf2WLVsWum8um5mZqbi4uBLVsXYOAED5Mwe2B/W8Rc3dnXW9e32L11nrGgAAWLDyXTw8PFwt3G9UC8+2at6gg9avX1+FDQQAoPbIG9h2d7PT8b9+0R9//ayzqedVp04dOdRx1N3t7lA9RxedNmWpYdOKW1pMIqANAKjhNm/dooBHR+nJjTP14tcLlZBS+ulUy0Nh2dlmNTlL+9w5y7XJnZycFBQUpLFjx6p+/dzgRnZ2tp577jldvHhRFy9etCjv5uZmse/q+r9FXs1lk5OTLZ4CLKpO3noAgIpXx85OjRo10vWtrrd4vTwywwEAQM1lzs7u3fEBSVKfTkPJ0gYAoJI5OzurU6dO8r2pi+w96sr/40n/HWc/J8lOdnZ2GnlnsH795UiF9tEEtAEANZq1KVIqO7BdXHa2WU3N0s7KyrLYf+aZZ/T888/rmWee0RtvvGG8npqaajFtuFn+6Wry7tvZ2RVbxto+AAAAAMC2mbOz3V0bSZLcXRuRpQ0AQBWpY2enTp066fBfsTrdOEUPrpqoN74NlVQ5fTQBbQBArVCVge2QZ0LU2tNXkklJqYmF/pFMau3pW+OytM1Z2GY9e/a0ui1JJ06csFj7WsoNdOdlXo9bktzd3SVJHh4eRnC7uDrm8gAAAAAA25Q/O9uMLG0AAKqWg4ODLpy7rODARbpU103eXu0kVXwf7VAhRwUAwEaZA9uzZs/WjJAQ+YdN0qA2d+ip2wIr7JynTyXoTMofWhr9XInKn4r3qLC2VIX27dvr888/L1HZunXr6vrrLaekPXHihHx9fY39kydPGtsdOnSQlDuNeatWrYx1tPOWMR8jL3M9AEDNkJ2drZdfekUvzHxeDg58zQUAoLrLn51tljcDbOTIkVXUOgAAaqbs7GytDw9XYkJiocuDmftoT3dvjbprsvF6RffRfNMHANRK1gLbPX26Vsi5PglfUyHHrS4GDBighQsXGvvff/+9EVD+/vvvLcr6+vqqa9eucnJyUmZmpiRp69atRkD76NGjio2NNcoPHDjQ4jzmgPbevXt18eJFNWzYUJK0ZcsWo5yXl5dFgBwAUP2Fh4frw6Ur1dm3E4PbAABUc1dNJs2fs1gjb/+X1fdzM8DelL+/f614kC0jI0OLFy/Wr7/+qj///FMXL15UZmam3Nzc1Lp1aw0YMECjR4+Wm5ubRb2cnBytW7dOkZGRio2NVUZGhry9vdWvXz+NHz9eXl5eVs8XFxenpUuXas+ePTp79qxcXV3VqVMnPfTQQ/Lz86uMSwYAVDJzIPvdtxarnUsLJbtmWA1oV2UfXfN7fAAAipA/sO0Q30BKu1TVzapROnfurH79+mnHjh2SpDfeeEN//vmn6tatq3Xr1hnl2rRpo969e8ve3l6BgYFavny5JGnZsmVKTk5WkyZNLNZh8fHx0bBhw4z9MWPGaO3atUpNTVVaWpqCgoLk5+en2NhYbd261Sg3btw42dvbV/RlAwAqiXlK0vF+MzXvzUW1ZnC7ImVnZysgIECHDh0yXhs+fLhef/11i3IMlANA5ShJtlRNasOZM2fUotGtBbKzzWpblnZqaqqWLFlS4PWkpCQdPHhQBw8e1KeffqpPPvnEWJYrIyNDEyZM0M6dOy3qHD9+XCtXrtTGjRsVGhqqLl26WLy/fft2TZo0SRkZGRbn2bVrl3bt2qUdO3Zo1qxZFkt+AQCqr7yB7Fsad9T8u2bIZJL+80uo1fJV2UezhjYAAPpfYHt1Lc+mriizZs1S+/btJeV+sV65cqVCQ0OVnJwsSfL09NSCBQuMQPPUqVPVq1cvSbmD5WvXrtXixYt15swZSVKDBg00f/58ubq6Gufw9vbWnDlz5OTkJEmKjY3VggULtHnzZqPM0KFDFRQUVPEXDACoNObpzlp4tjW+OOPaLFmyxCKYbU1GRobGjx+vmTNn6sCBA7p06ZIyMjKMgfIHHnhAv/zyS4F627dv17Bhw7R+/XrFx8crKyvLGCifMmWKpk+fLpPJVFGXBgDVSnZ2ttauWaNBdwzQl+9F6psvosv1uIvnLypVG7a+G6Gw5asK1CvN8YpjMpn05x/HC6ydnV9tW0u7adOmuvfee/X4449r6tSpeuyxx9S8eXPj/T///FNr16419ufNm2cEs+3t7RUQEKCJEyfKx8dHUm6QOjg4WGlpaUadhIQETZs2zQhmt2vXTpMnT9b9999vlImIiNDq1asr9FoBABUvb/++b3m05t81Q9P6jJWnW+NC61R1H81j6wAAoMI1adJEn3zyiZYvX67PP/9cJ06cUE5Ojpo3b64BAwZo7Nixatz4fzdMzs7OCg0NNbK+jh49qszMTIusr6ZNmxY4z8CBA7VhwwaFhoZq9+7dSkxMlIuLizp27KiAgACLL+IAgOrPnJ1tnu6stk1BWhEOHz6sd999t9hy+QfK/f395enpqYiICJ06dcoYKI+KipKLi4sk6wPlfn5+OnbsmDZt2iQpd6C8S5cuGj16dAVdIQDYvtJmS5XluEVNJ5q/bPeGHeTXrI8+/elztXT31jdfRGti8NOlOl5JXbx4UY516komk5JTzhdZ1sPJp1ZkaTdq1MiY8Syvxx57TP369TP24+PjJUnJyckKCwszXh83bpymTJkiSRoyZIj8/PxkMpkUHx+vyMhIBQYGSpJWrFihy5cvS5JcXV0VFhYmDw8PSZKdnZ2ioqIk5T74NmrUKGY+A4BqyNo9RlFB7Lyquo/mGz4AAPlNniylp0vOzlXdkhrFxcVFTz31lJ566qkSlXdwcFBgYKDx5bqk2rZtq1mzZpWliQCAilCB/ao5O9s83Vltm4K0vGVlZWn69OnKysqSr6+vzp07p4SEhALlGCgHgIpR1CDz2ctFDxyX9riFBcitBbI/++VL9fDpokUPvKDUrDQtOL5Oa9esKfeAuyZP1u516/X9T4d04I+Pii3u6C6dPXPu2s5ZDeXk5CgxMdEiI1uSMSvad999ZzFl+D333GNst2nTRu3bt1dMTIwkKTo62uino6P/NwNAz549jT5akgYPHmz00wkJCTp06JC6du1avhcGAKgw1xLIlmQTfTQBbQAA8rv33qpuAQAANUcF9av5s7PNyNIuu/fee0+///67nJycNHv2bI0fP95qOQbKAaB8XfMgcxmOmz9AXlQge+GQ5+Xp2kgZOZmKOhytn375UU2vNNDrvYJ1nVdLq8crk3vv1f333ivm1bJu7969+r//+z+r7/Xo0UMPPfSQJOnIkSMW77Vs2bLAvrmfNpfNzMxUXFxckXXyOnLkCP00AFQjr778ilaHrtK7/i+ro3e70h/ABvpovt0DAAAAAKqd/NnZZmRpl83vv/+uJUuWSJImT56sdu0KH+RgoBwAykdVBLKLKltYIDv7arY2/hatlT9GyrfpDVoy5GX5NPDSVTvTNbcV127IkCF6+eWXVbduXUm5U8Lm5ebmZrHv6upqbJvLJicny2QylaiOtXMAAGzbcy88r46dOurluYt0S5NOGtPtwXK556hMBLQBAAAAANVKYdnZZmRpl07eqca7deumxx9/vMjyDJQDQPm45mypfMoSIH/15VcUtnSlRt10v7bF7LYayF71Y6S6et+o/9wzRd5unqrn6Cy7OnZKyUq75jaj5K677jo988wzyszM1KlTp/TFF18oKSlJUVFR+u233xQaGqrmzZsXqJe3/82/b2dnV2wZa/sAgOrFwcFBI0eNkv/f/qb14eGaPPe1ahfY5ps9AAD5HT8u5eRI9vbS9ddXdWsAAKjeKqBfLSw724ws7dJ55513dPjwYdWtW1ezZs0q9drVDJQDQNmUd7ZUWQLkz73wvH479Js+/Dpc7wydqW4+HVXHro4kaf53y7Xh0Fea4zddnb3aq56js+rY2ckkkyrktzbfxYvUrFkzjR071tj/xz/+oWHDhuncuXP6448/9Nprr2nx4sUWS3pIUmpqqho0aGDsp6SkGNvu7u6SJA8PD9nZ2Rn9cWpqqsUx8tYxlwcAVD9lDmzbQB9dp0rOCgCALXvqKSkgIPdvAABwbcq5XzVnZ/fu+ECR5XKztBcpOzu7XM5bU50+fVrvv/++JGnKlClq06ZNsXWsDZTnVdRAeUnqWDsHANRE5kHlr3d/o9vGDNTkr17TnJ3LdC6lbOtRP/fC83rlrf/o5T3vlvg4Dg4OWr32Y72xeK5m7n1Hz381X7HnT+iz377WvpM/q3PT9npjx1K9t+9jnb9SwbNn8F28VBo3bqxu3boZ+/v+n717j4uqzv8H/hpmGIFBQLkIiIq3DG/lrzLT0pVMC10tSZRk161NMxUJbTO7WJmJrWJiuWnibupikpiSt7UtSr55bdu2drNUFMUrNwGZGWGYmfP7Y5zjzDDAoHPn9Xw8eHjOzOec85lBfZ/PeX8ux44BAPr06WNWrqSkxGz//Pnz4raxrFwuR2xsrNUy1s5heQ0iIvIsrb4HcYMYzYQ2EREREREReYy8vDyEyKMBQUCNsrLJHwgCQuTR2L59u6ur7Naqq6vFpP+yZcvQp08f8efixYtiuR07dqBPnz54+eWX+aCciMjO7JXYvtXzyGQyPDX1KRz+8RhCHojB7/P+hO8v/oxV417Dh4+/hdzkVegT1h2pny9G5v9tQLnq6u18XGqlgwcP4urVxt/51atX8eOPP4r7xo5jw4YNg1wuF1/fv3+/uH3q1CkUFRWJ+/Hx8eL2yJEjxe2jR4+aLf+xb98+cTsiIgL9+/e/1Y9DRERuxNq9wwdHNru6WlZxynEiIiIiIiLyGOWlFfAN1qDgzMctlvUNBsqulDu+Um2M8UG5RqMBYHhQbnyw3dKD8uLiYgA3H5R36NABAB+UExEBzU8Daq/zNDed6LKlGdi3fQ/+NvXPiA2OgbK2FrX1KgT4+mNc3Eg82uch7Pn1AGZ//hYGdxmIxAGPokNH68t/kP3k5OSgsLAQDz74IPr06QN/f3+Ulpbiiy++QEVFhVjuN7/5DQDDLCfJycnYuHEjAGDDhg2oqalBWFiYWUe/6OhoTJgwQdyfNm0acnNzoVKpoFarkZKSgoSEBBQVFZklxadPn97q5UmIiMi9Wd47VJRWtHyQk3lFQlupVGLLli0oKCjAmTNnoFQq4evri4iICAwaNAhTp07FXXfdZXaMTqfDtm3bkJ+fj6KiItTX1yMyMhLDhw/HjBkzEBERYfVaxcXFWL9+PY4cOYKysjIoFAr07dsXkyZNQkJCgjM+LhERERERUZuVmjYHqWlzXF0Nr9G+fXuMGTPG6nuFhYW4fv06AKBz587o378/BgwYwAflREQOZi0h3VvRBVDc/nmaS5BbW9O7ndQfNbW18PWRGRLbd/4GD/W8D/vPHMQzO1/BhEGjW51wp9ZraGjA119/ja+//trq+3FxcXj55ZfF/Xnz5uHkyZM4fPgwdDodcnNzzcoHBQUhKysLCsXNv1SRkZFYsWIF0tLSoNFoUFRUhNWrV5sdN378eKSkpNjxkxERkTsx3ju4I49PaNfW1iIpKQlnzpwxe12n06GkpAQlJSXYtWsXli1bJjak6+vrMWvWLHz77bdmx5w7dw6bN2/Grl27kJ2djQEDBpi9f+DAAaSmpqK+vl58rbq6GocOHcKhQ4dQWFiIjIwMs3XBiIiIiIiIiNxVTExMo4fVRvHx8eK044MHD8ayZcvE9/ignIjI8ew1WsrWBHlzCXDTxLbMR4rRcQ/hqOYXw/Skt5hwJ9tMnToVYWFh+Omnn1BWVoaamhpIpVKEhYXhjjvuwCOPPILx48fD19dXPMbPzw/Z2dnigK5Tp05Bo9GYDejq1KlTo2vFx8dj586dyM7OxuHDh1FRUYGAgADExcUhKSkJY8eOdeZHJyIiEnl8Qjs3N9csmT148GA88MADuHLlCrZv3w6tVgu9Xo/Vq1eLCe1Vq1aJyWypVIrExESEh4djx44duHTpEqqrq5GWlobdu3cjICAAAFBaWor58+eLyexevXohISEBp0+fxp49ewAY1hQbMGAApk6d6syvgIiIiIiIiMip+KCciMh57DVaytYEeXOJbT+pP/R6PRr0dfDx8XH76Um9wbBhwzBs2LBWHyeTyZCcnIzk5ORWHdezZ09kZGS0+npERESO5PEJ7ZKSEnG7ffv2+Pjjj8WpyRoaGvDZZ58BAK5evQoAqKmpQU5OjnjM9OnTkZ6eDgAYN24cEhISIAgCLl68iPz8fDHgb9q0CbW1tQAAhUKBnJwchISEAAAkEgl2794NAFi3bh2mTJnC6dGIiIiIiIjIoxUUFDT7Ph+UExF5JlsT5LZOWe7O05MSERGRd/BxdQVuV69evcRtlUqFAwcOQKPR4Ny5c/jxxx/F9x566CEAwMGDB82mDB89erS43aNHD/Tu3VvcN228m24PHjxYTGYDMFtvrLS0FD///PNtfioiIiIiIiIiIiIi1zMmrL86/I1hivEvl+KDI5tdXS0iIiJqQzx+hHZSUhL27t2LH374AXq9Hs8//7zZ+1KpFGPGjMGbb74JADhx4oTZ+126dGm0f/LkSbOyGo0GxcXFzR5j6sSJExg4cOCtfygiIiIiIiIiIiIiN2KvNb2JiIiIWsvjR2j7+flh06ZNmDRpktX3e/bsibFjxyI4OBgAUFVVZfZ+YGCg2b5CoRC3jWVramogCIJNx1i7BhEREREREREREZE3MCa2Z6fNcXVViIiIqI2w6whtpVIJQRDQvn17e562xWvOnj0bR44cAQAMHDgQI0aMwMWLF/H555/j5MmTmD17NhYsWIBnnnmm0fGmiWrLfYlE0mIZa/tEROThNm0C9HrAx/H9vurq6jBm9GPY/8U++Pn5Ofx6t8oVMZ6IiLyEE+NqW8U4TUREXsGL7xkYq4mIyKO5QYxu1ZXLysrw3Xff4bvvvoNGoxFf/9e//oWEhATcd999GDx4MMaOHYtvv/3W7pW1Zs2aNWIyu1u3bvjkk08wZ84cZGRkmE0/npWVBaVSabb2NWBYd9uUUqkUt42jukNCQsTkdkvHGMsTEZEHCwsDIiIMfzrYgpcW4L8/HMfLCxY6/FrNcccYT0REXsKJcdVbMU4TEVGb4MH3DIzVRETk1dwgRrcqof3xxx/j97//PV544QXIZIbB3WVlZZgxYwaKi4shCAIEQcDp06cxc+ZM/PLLLw6ptKnDhw+L23379hXrBQADBgwQt+vq6lBcXIw+ffqYHV9SUmK2f/78eXHbWFYulyM2NtZqGWvnsLwGERGRNXV1dcjN2Y7nHn0bW/++DXV1dS6rizvGeCIiIjJgnCYiInJvjNVERESO1aqE9okTJyAIAkaPHg2fG8PKP/30U6jV6kZldTodNm7caJ9aNkOn04nbv/zyi9n+//73P7Oyfn5+GDZsGORyufja/v37xe1Tp06hqKhI3I+Pjxe3R44cKW4fPXrUbJ3sffv2idsRERHo37//rX4cIiJqQxa8tAD9ujyALmG90DdmiEtHabtjjCciIiIDxmkiIiL3xlhNRETkWK1KaJ87dw4SiQT9+vUTXzOdIuWJJ57Ap59+igEDBkAQBPzrX/+yX02bcN9994nbZ8+exdSpU/HBBx/g1VdfxYcffii+FxkZiZ49eyIkJATJycni6xs2bMCiRYuwevVqPPvss+Lr0dHRmDBhgrg/bdo0KBQKAIBarUZKSgrWrFmD9PR0s6T49OnTIZVKHfJZiYjIPurq6pCeloannpxivcBnnwE5OYY/HViH3JzteHhgEgBg1F2TXTpK2x1jPBEReQknxFVvxzhNRERtggffMzBWExGRV3ODGN2qhHZNTQ0AoHPnzgAArVaL48ePAwAkEgn+9Kc/YeDAgXj66acBAOXl5fasq1WzZs1C165dxf0ffvgB77//PvLy8tDQ0ADAMGX4kiVLxN5x8+bNwwMPPADA0CMuNzcXa9aswZUrVwAAQUFByMrKEhPYgCEhvmLFCnF0d1FREVavXo29e/eKZcaPH4+UlBTHfmAiIrplxkR2XJfeuPj1Kfx47AfrBbOzgffeM/zpIMbR2SGKUABAiCLUpaO03THGExGRl3BCXPV2jNNERNQmePA9A2M1ERF5NTeI0a1KaF+/fh0AoNFoABimUtFoNJBIJOjZsyc6duwIAAgNNTycl0gk9qyrVWFhYdixYwfS09Nx9913Izg4GFKpFP7+/ujevTumTJmC/Px8PPTQQ+Ixfn5+yM7OxptvvolBgwYhMDAQcrkcXbt2RUpKCnbv3o2BAwc2ulZ8fDx27tyJiRMnIioqCr6+vggODsaQIUOwcuVKLF++XEyaExGR+zBNZCsPX0HelNX40/BnWz7QgfUxHZ1t5MpR2u4Y44mIiMiAcZqIiNoSvSBg0etvQKvVuroqNmOsJiIicixZawoHBwfj6tWr+OqrrzBixAjs2rVLfO+uu+4St4090oyB2tECAwMxc+ZMzJw50+ZjZDIZkpOTzaYft0XPnj2RkZHR2ioSEZEL1NXVYeGCBdi55TOM6j4UeVNWo1NgGADgcq3rekNbjs42Mh2lvSrrPafWyV1jPBERETFOExFR23LlyhX8bf1m9OvfF5MnT3Z1dWzCWE1ERG2NVqvF4rfexqI3XodM1qp08y1p1XBi4xof27Ztw/3334+NGzeK7w0bNkzc/vnnnwEAERERdqomERGR7ayNyH7j4TliMtvVdbM2OtvIVaO0GeOJiMhVtFotcrduxZqsD1xdFbfFOE1ERG2FIAg4e+YcZiS8gVXLP/CYUdqM1URE1Nbk5eXhb+s3Y/v27U65XqsS2lOnThW3jb3JACAqKgoPP/ywuP/ll19CIpHg7rvvvv0aEhER2cidE9lGTY3ONnLVWtqM8URE5GzGRPaooSPxz7X5+OaLAldXyW0xThMRUVtRVVUFP18FYsJ7onNQH6c9JL9djNVERNSWaLVaZK1Y49QOaK1KaD/00EN47bXX4OfnB8DQYy42NhYffPAB5HI5AODYsWM4ffo0BEHA/fffb/8aExERNSFhzGP49OOt+HDcm26XyAZaHp1t5IpR2ozxRETkLKaJ7GMbC5D18ELMGfI7V1fLrTFOExFRW6AXBJSWlqODohMA4MG+4z1mlDZjNRERtSV5eXmICb7TqR3QWj2peUpKCp588kmcPHkSgYGBiI2NhY/Pzbx4nz598MUXXwAAoqOj7VdTIiKiFuzdvw8LFyzAzJw3MKrHUDx/f7JbJbUXvLQA3cP7AxBQrapotmz38P544403nVIvI8Z4IiJyJL0gYNvWrfhw5RrcExqHrIcXIjzQMGNJWW2li2vn/hiniYjI2125cgVyqR98Zb4AgGBFR/EhuSespc1YTUREbYFWq8Wq5R/gzrChOPDDjhsd0JYjMTHRoWtp39KZ/fz8MHDgQKvvBQcHIzg4+LYqRUREdCv8/PzwXlYWMt59FwsXLEBiTqpbJbYvXyrFFeUZrC94zabyVy61d3CNGmOMJyIie9MLAqqvXsXJojM4hi5miWxn0mq1WPzW21j0xusObWQ7EuM0ERF5K61Wi7NnzqGnX0c0mLzurIfk9sJYTURE3kwvCHhx/nxUXLiMBpxBiboKIwY94ZQOaK2+C2hoaEBubi6OHDmChoYGxMXF4fe//z06duzoiPoRERG1mrsmtj/N29qq8kqlEvfcc4+DatMYYzwREdmTVqvF9rw8dDt8FJ0FKfqG9cT8B//osvrk5eXhb+s3o1//vh4xyssS4zQREXmzvLw83OGrgNRHZpbQ9qRR2ozVRETkrcSO6qfOoKo8AJufXAEJJPhTwfsAnNMBrVVn1Wq1ePrpp/H999+LrxUWFuKzzz7DJ598gs6dO9u9gkRERLequcR2s7p2BQIDgTbU6GSMJyIie1uy+G1syf47CmIGIVQigd4/yGV10Wq1yFqxBjMS3sCq5R94zCgvI8ZpIiLyZsY4vS6yH2q1GtT7md8zeMIobcZqIiLyRsaO6v7f/wddpf7o3vU+vDR8Bvx8A1CuvLl0mDM6oPm0XOSmrVu34l//+pe4LwgCBEFAeXk5/vznP9u9ckRERPZgTGz/eqEI7R+IQuInqVhemN30AWvXAp9+avizjWCMJyIie3tt0et4e+U7mOpfj1djeqDo4WddVpe8vDzEBN+JmPCeYiPbkzBOExGRNzPG6e/HvoZvJizG4TEvmr1v+pDcXTFWExGRN9FqtcjduhWjho7EsY0F6PbHDYiYswWlo+ZCLvOzeoyhA9oH0Gq1DqlTqxLae/bsAWAIyNHR0bjjjjvE/YKCAmg0GvvXkIiIyE5ME9udR/bGXYMHubpKboMxnoiI7E0mk2HylCn46vA3uH9aPOZ+uRQrvt1g1ovbGYyjvobF/RaA4xvZjsA4TURE3soyTjfF3eM3YzUREXkDy0R21sMLMf/BPyI8MBTXr9dBKpHBR2I9tezoDmitSmifPn0aEokEEyZMwFdffYXPP/8cixYtAmD4kCUlJQ6pJBERkT0ZE9tbWrmmtTdjjCciIkdxdWLbOOorWGFYSsQTRnlZYpwmIiJvlZeXhxB5NCAIqFFWNvkDQUCIPNpt4zdjNREReYMli9/G6/Nexev3zxQT2QYCVCpVk6OzjRzZAa1VCe3a2loAwG9/e7PH3OOPPy5uK5VK+9SKiIiInIoxnoiIHM0Vie2mRn25+ygvS4zTRETkrcpLK+AbrEHBmY9b/PEN1qDsSrmrq2wVYzUREXkD49Jhi498aNZev369Dj6QAgD0gl780eq0TuuAJmtNYUEQIJFIEBAQIL5muq3X6+1XMyIiIld57TWguhoICQGWLHF1bZyCMZ6IiBzGIq4aE9uJTz6J7Xl5mJu5FL0VXQCF/S9tOTrbyHSU9uTJk+1/YTtjnCYiIm+VmjYHqWlzDDse3BZnrCYiIm9grb1+T1hfzKusRIhGA52fAmXDpgEANPrrqK67goIzH5udwzcYDumA1qqEttEvv/wCnU5n0+v33XffrdWMiIjIVf79b6CsDIiIcHVNnI4xnoiI7K6JuGrZUK4orbDrZY2jsycP+ZPV9w2jtJcjMTERMtktNY2djnGaiIi8mhe0xRmriYjIG1i21y88NwudIUVwWCw6djR0GNf6Cug/oB+27fnMOXW6lYOWWOkhJwhCo9clEgmOHz9+azUjIiIip2OMJyIiZzM2lO2tqdHZRp42ShtgnCYiInJ3jNVERORNjO11/caNqD5xAscrTuPTbzdg2t2PO70urVpD25QgCOKPRCKBRCIRXzd9n4iIiDwLYzwREXm6ptbOtuRpa2kDjNNERETujrGaiIi8jY9Ego4dO2Lw0Ptx/7R4zP1yKT44stmpdWj1CG1rwdbyNQZkIiIiz8MYT0RE3iIvLw8h8mhAEFCjrGy2bIg82iNGaTNOExGRI2i1WnHpj9nGtazpljBWExGRt/ORSBy6dFhzWpXQ/uqrrxxVDyIiInIhxngiIvIm5aUV8A3WoODMxy2W9Q0Gyq6UO75St4FxmoiI7M2YyP5w5Rr0CohBjaKeCe3bwFhNRERtiaOWDmv2mq0p3LlzZ7P90tJS/Prrr1CpVAgLC0NsbCwiIiLsWkEiIiJvVVdXhzGjH8P+L/bBz8/PpXVhjCciIm+SmjYHqV70UJ5xmoiI7MU0kX1PaByyHl4IQQDe+W+2q6vm0RiriYiIHKvVU44DwL///W/8+c9/xo8//mj2ukQiwfDhw/HCCy/gzjvvNHvv2rVrCAoKuvWaEhEReZkFLy3Af384jpcXLMSqrPdcXR0AjPFERETujHGaiIhulbVEdnhgKACgrLb55TnIdozVREREjuHT2gP+8Y9/4Pe//z1+/PFHCIIgrvshCAL0ej2++eYbPPXUU/j222/FYz766CNs3uzcxcGJiIjcWV1dHXJztuO5R9/G1r9vQ11dnaurxBhPRETkxhiniYjoVmi1WuRu3YpRQ0fi2MYCZD28EPMf/KOYzCb7YawmIiJynFYltEtLS7Fw4UJotVqz143BGTD0NlOr1XjppZdw9epVvPHGG3jvvffMyhAREbV1C15agH5dHkCXsF7oGzMELy9Y6NL6MMYTERG5L8ZpIiJqLSaynYuxmoiIyLFaNeX4li1bcP36dUgkEkRERGDatGkYMGAAQkNDUVlZif/973/YuHEjrly5gqqqKowdOxbV1dUAAKlU6oj6ExER2d/jjwNKJRAY6JDTG0dnzx1rmGZ81F2Tsfrv6Vj2bobL1tJmjCciIodxcFxtCxwdp+vr67FmzRr873//w9mzZ1FVVQWNRoPAwEB0794dI0eOxNSpUxFo8TvU6XTYtm0b8vPzUVRUhPr6ekRGRmL48OGYMWNGk2uFFhcXY/369Thy5AjKysqgUCjQt29fTJo0CQkJCbf9fREREbBk8dvYkv13fJi4GHGRvVxdHdt48D0D29REROTV3CBGtyqhbZwO5Y477kBOTo5ZY7ZHjx647777MGnSJEydOhUnT55EVVUVAOChhx7CtGnT7FhtIiIiB5oxw6GnN47ODlEYesaHKELFUdquWkubMZ6IiBzGwXG1LXB0nFapVFi3bl2j16urq/HDDz/ghx9+wGeffYZPP/0UwcHBAAxJ8FmzZplNmwoA586dw+bNm7Fr1y5kZ2djwIABZu8fOHAAqampqK+vN7vOoUOHcOjQIRQWFiIjIwMSicTGb4eIiKx5bdHriOsbh8WZH+CesL6Ydvfj7j8624PvGdimJiIir+YGMbpVU46fP38eEokEzzzzTKOe2UaBgYF45plnIAgCJBIJnnrqKaxbtw4BAQF2qTAREZGz1NXVIT0tDU89OcWu58zN2Y6HByaZvT7qrskuXUubMZ6IiMh9OSNOd+rUCY8++iieeeYZzJs3D08//TQ6d+4svn/27Fnk5uaK+6tWrRIf3kulUiQlJWH27NmIjo4GYEhSp6WlQa1Wi8eUlpZi/vz5YjK7V69emDt3LsaOHSuW2bFjB7Zs2WLjN0NERE2RyWSYPGUKvjr8De6fFo+5Xy7Fim83oFxZ6eqqeSW2qYmIiByrVSO0jQ3RyMjIZssZ35dKpVi0aNEtVo2IiMg16urqsHDBAuzc8hnuixqAn6tP2+3clqOzjVw9SpsxnoiIyH05Ok537NgRhYWFjV5/+umnMXz4cHH/4sWLAICamhrk5OSIr0+fPh3p6ekAgHHjxiEhIQGCIODixYvIz89HcnIyAGDTpk2ora0FACgUCuTk5CAkJASAYV3R3bt3AwDWrVuHKVOmcApWIiI7MCa2E598Etvz8jA3c6nnjNj2IGxTExEROVarRmgHBQUBAE6cONFsuZMnTwKAOBUZERGRJzCOyI7r0hvKw1eQN2U1/jT8Wbue39robCNXjtJmjCciInJfzo7TOp0OpaWlZiOyAaB3794AgIMHD5pNGT569Ghxu0ePHmI5ACgoKLC6PXjwYDGZDQBjxowRt0tLS/Hzzz/f1mcgIiJzHLHtWGxTExEROVarEtp9+vSBIAhYu3Ztk8H5zJkzWLduHSQSCe688067VJKIiMiRLBPZ/1FEYM35H9F377t2vU5To7ONTEdpOxtjPBEROUxCAnDvvYY/6ZY4K04fPXoUffr0Qd++fTF8+HCsWbNGfM+49ifQ+GF9ly5dmtw3ltVoNCguLrbpGGvXICIi+7CW2P7gyGZXV8vAg+8Z2KYmIiKv5gYxulVTjo8aNQqHDx9GVVUVnnjiCYwcORL9+/dHaGgorl69iuPHj6OgoABarRYSiQSjRo1yVL2JiIhum+nU4qO6D0XelNXoFBgG+ad/csi1cnO2Y+7Y5qcTH3XXZKz+ezqWvZth9zo0e13GeCIiIrfl6jg9btw4LF68GO3atQMAVFVVmb1vuVaoQqEQt41la2pqIAiCTcdYuwYREdmX5VTkFaUVrq6SR3N1rCYiIvJ2rUpoP/nkk9i0aRNKSkqg1+tRUFBgNmUYALGB2q1bNyQmJtqvpkRERHbSVCLbkRa8tADdw/sDEFCtav5BQffw/nh5wUIseedth9bJFGM8ERGR+3JWnO7atSteeuklaDQaXLp0CV988QWqq6uxe/duHD9+HNnZ2ejcuXOj40wT1Zb7EomkxTLW9omIyDmMiW26PWxTExEROVarEtrt2rXDX/7yF0yfPh2XLl1qslxkZCTWrFkDuVx+2xVsjePHj2Pz5s347rvvUFZWBplMhtDQUPTv3x+JiYl48MEHxbI6nQ7btm1Dfn4+ioqKUF9fj8jISAwfPhwzZsxARESE1WsUFxdj/fr1OHLkCMrKyqBQKNC3b19MmjQJCR44HQ4RUVuUMOYxnPjPcWyYuBT9I+9wyjUvXyrFFeUZrC94zabyly6GOLZCFpwZ47VaLZKSkszWxnziiSewbNkys3KM1URERAbOitNRUVH44x//KO6/8MILmDBhAsrLy3HmzBksXboUa9asMVv7GgBUKpW4digAKJVKcdu4RmhISAgkEon4MF+lUpmdw/QYY3kiIiJP4e7PzYmIiDxdqxLaANCzZ0/s2LEDGzZswN69e3HhwgXxvc6dOyMhIQF//OMfnd74/OCDD/DBBx+Y9equr6+HSqVCSUkJAgICxIR2fX09Zs2ahW+//dbsHOfOncPmzZuxa9cuZGdnY8CAAWbvHzhwAKmpqaivrxdfq66uxqFDh3Do0CEUFhYiIyND7IFORETuae/+fVi4YAFm5ryBUT2G4vn7kx0+QvvTvK2tPsbywa6jOSvGr1u3ziyZbQ1jNRERkTlXtMVDQ0Nx991345///CcA4NixYwAM64SaKikpQf/+/cX98+fPi9vGsnK5HLGxseI62qZljOcwZXkNIiIid+euz82JiIi8QasT2oChh/W8efMwb948qNVq1NbWIjAwsNGaV86yZcsWvP/+++L+oEGDMGjQIAQHB6OmpganT59Ghw4dxPdXrVolPiCXSqVITExEeHg4duzYgUuXLqG6uhppaWnYvXs3AgICAAClpaWYP3+++IC8V69eSEhIwOnTp7Fnzx4AwI4dOzBgwABMnTrVWR+diIhugZ+fH97LykLGu+9i4YIFSMxJdVpi2905Osb/+uuv+PDDD1ssx1hNRETUmKPi9MGDBxEXF4eOHTuavX716lX8+OOP4r6xQ9iwYcMgl8uh0WgAAPv37xcT2qdOnUJRUZF4THx8vLg9cuRIMaF99OhRVFVViW31ffv2ieUiIiLMEuRERESewt2emxMREdmLIAi4fPkydmR9gNlpc5x+/VtKaJsKCAgQHyS7glKpRGZmprj/1ltvYUoz677U1NQgJydH3J8+fTrS09MBAOPGjUNCQgIEQcDFixeRn5+P5ORkAMCmTZtQW1sLAFAoFMjJyRF700kkEuzevRuAYdTZlClTIJVK7fo5iYjI/ppKbGfqGuDv6sq5AXvH+IaGBrz88stoaGhA//79UV5ejtLS0kblGKuJiIhaZs84nZOTg8LCQjz44IPo06cP/P39UVpaii+++AIVFRViud/85jcADNOBJycnY+PGjQCADRs2oKamBmFhYdi+fbtYPjo6GhMmTBD3p02bhtzcXKhUKqjVaqSkpCAhIQFFRUXYv3+/WG769OmM00RE5PFc/dyciIjIHrRaLcouX0btySJo/Nrjmy8KXJLQ9nH6Fe1s//794pSsUVFRUKvVGD9+PO6++27cf//9mDVrllmP8oMHD5pNQzp69Ghxu0ePHujdu7e4X1BQYHV78ODBZlPDjBkzRtwuLS1tcRpVIiJyL8bE9q8XitD+gSj8+9LPuHStDBpdg6ur5lXWrl2LX375BXK5HO+++y5kMuv96hiriYiInK+hoQFff/011q5di/feew9btmwxS2bHxcXh5ZdfFvfnzZuHBx54AACg0+mQm5uLNWvW4MqVKwCAoKAgZGVlmY1Ii4yMxIoVK8R1Q4uKirB69Wrs3btXLDN+/HikpKQ49LMSERERERFR87RaLXK3bsWooSNRc6ESXYIi0S2ks8vq4/EJ7R9++EHcvnz5Mt59912cOHEC169fR3V1Nb766is89dRTYgP5xIkTZsd36dKlyX1jWY1GI06L1tIx1q5BRESewZjYHh7/G0gDffHvSz9jeWG2q6vlFX755ResW7cOADB37lz06tWr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EREREREREQmJHdpERERERERERERERERERCQkdmgTEREREREREREREREREZGQ2KFNRERERERERERERERERERCYoc2EREREREREREREREREREJiR3aREREREREREREREREREQkJHZoE1G1tmrVKri7u8Pd3R1+fn7y9AMHDsjTfXx8DFhCIiKiZxdzmoiISGzMaiIiIrExq+lZYWboAhCR2A4cOIB58+ZpTLewsEDdunXRvn17TJgwAe3btzdA6YiIiJ5tzGkiIiKxMauJiIjExqwmMg68QpuIyiU7OxtxcXH48ccf8eabb+L8+fOGLhIRERH9P+Y0ERGR2JjVREREYmNWE4mFV2gTUZn4+/sjPz8ft27dwvLly5GRkYHc3Fxs2rQJ3bt3N3TxiIiInmnMaSIiIrExq4mIiMTGrCYSEzu0iahMOnfuDADw8vLCnTt34O/vDwCIi4tTzJecnIytW7ciODgYMTExyMvLQ+PGjfHiiy/irbfegq2trWJ+SZJw+PBhBAYGIjw8HKmpqbC3t4ebmxvefPNNDB48GABw7tw57Nu3DxEREUhMTERaWhosLS3h4uKCAQMG4K233oKNjU0V1AQREZF4mNNERERiY1YTERGJjVlNJCZ2aBNRueXn58uP69evLz/+559/MG7cODx48EAx/+3bt7F69WqcOnUKO3bsgIODA4CC4Vvef/99hISEKOZPTEzExYsX4ezsLAf677//juPHjyvmy83NRVhYGMLCwnD27Fns2rULZmb8eSMiomcbc5qIiEhszGoiIiKxMauJxMEWT0RlcvnyZXnIlcDAQACASqWCj4+PPM+cOXPkMH/++ecxbtw4mJiYYMuWLbh48SIiIyPx5Zdf4uuvvwYArFmzRg5zlUqF119/Hf3790d+fj7++usv5OTkyMvu0qUL6tWrhwYNGsDW1hYmJiZITEzExo0bcePGDVy7dg1BQUF48cUXq6pKiIiIhMGcJiIiEhuzmoiISGzMaiIxsUObiMpkzJgxiueurq6YO3cu+vfvDwCIjIzE1atXAQDm5uaYPHkyrKysAABjx47FxYsXAQA//vgjPvnkE9jY2GDv3r3y8saOHYuFCxfKzwcOHKj4PC8vL4SHh2PdunWIjo5Genq64kw5APjrr78Y6ERE9ExiThMREYmNWU1ERCQ2ZjWRmNihTUQVEhcXh7///lsO9Nu3b8uv5eTkYNKkScW+LycnB9HR0WjQoAESEhLk6UUDXJ0kSXjnnXdw6dIlrWVKSUkpyyoQERFVW8xpIiIisTGriYiIxMasJhKDiaELQETGJSIiAr///rt8plpOTg6WLVuGX3/9tczLSk9PhyRJimkqlarE+a9cuSKHuampKaZPn46tW7fC398fw4YNk+crukwiIqJnBXOaiIhIbMxqIiIisTGricTEK7SJqMxq1aqFhQsX4q+//kJoaCgAYOnSpQgMDETz5s3l+aysrHDu3DnY29trLCMtLQ12dnaQJAmOjo7yWWqnTp2Cl5eXYl5JkqBSqXD//n15WqtWrTBt2jT5+cqVK/W6jkRERMaKOU1ERCQ2ZjUREZHYmNVE4mGHNhGVi4mJCWbOnInJkycDKDhzLSgoCAMHDkS7du1w/fp1ZGZmYvz48fDx8UH9+vWRlJSE2NhYnDlzBubm5ti+fTtUKhWGDx+O9evXAwD8/f2RnZ2Nvn37Ij8/H9evX8fTp08xf/58NG7cWP78yMhI7Ny5E02aNMGxY8fke5MQERERc5qIiEh0zGoiIiKxMauJxMIObSIqtz59+sjhDQBr167FwIEDsXz5cowfPx4PHjxAaGgo/Pz8NN6rfhbatGnTEBoainPnziE/Px8BAQEICAiQX3/11VcBAO3atUPnzp1x+fJl5OTk4PPPPwdQMPxK4XQiIiIqwJwmIiISG7OaiIhIbMxqInHwHtpEVCHqw56EhYUhODgYrq6uOHz4MN5//320adMGNjY2sLCwQMOGDdGlSxfMmjULn376qfw+CwsLbNiwAUuWLEG3bt3g4OAAMzMz1KpVC126dEHv3r0BFNxfZM2aNRgxYgTq1q0La2trdOjQAZs2bULXrl2retWJiIiEx5wmIiISG7OaiIhIbMxqIjGoJN49noiIiIiIiIiIiIiIiIiIBMQrtImIiIiIiIiIiIiIiIiISEjs0CYiIiIiIiIiIiIiIiIiIiGxQ5uIiIiIiIiIiIiIiIiIiITEDm0iIiIiIiIiIiIiIiIiIhISO7SJiIiIiIiIiIiIiIiIiEhI7NAmIiIiIiIiIiIiIiIiIiIhsUObiIiIiIiIiIiIiIiIiIiExA5tIiIiIiIiIiIiIiIiIiISEju0iYiIiIiIiIiIiIiIiIhISOzQJiIiIiIiIiIiIiIiIiIiIbFDm4iIiIiIiIiIiIiIiIiIhMQObSIiIiIiIiIiIiIiIiIiEhI7tImIiIiIiIiIiIiIiIiISEjs0CYiIiIiIiIiIiIiIiIiIiGxQ5uIiIiIiIiIiIiIiIiIiITEDm0iIiIiIiIiIiIiIiIiIhISO7SJiIiIiIiIiIiIiIiIiEhI7NAmIiIiIiIiIiIiIiIiIiIhsUObiIiIiIiIiIiIiIiIiIiExA5tIiIiIiIiIiIiIiIiIiISEju0iYiIiIiIiIiIiIiIiIhISOzQJiIiIiIiIiIiIiIiIiIiIbFDm4iIiIiIiIiIiIiIiIiIhMQObSID+vvvv9G2bVu4u7tjxYoV5V5Obm4u+vfvD3d3d4wdO1aPJSQiInq2lZTVFy5cgLu7O9zd3dG/f3+dlhUVFYXWrVvD3d0dK1eurKwiExERPVP0sV99/vx5Odf37dun5xISERFVb+XJ4lWrVsnZ6+fnJ0/nfjMRlcTM0AUgepZ9/fXXyM3NhbW1NcaPH1/u5ZiZmWHSpEn47LPPcOnSJQQFBcHb27tMy8jJycGxY8dw4sQJhIWFISkpCTY2NqhXrx46dOiAl156CV5eXgAKDuKPGzdOfu/p06fRqFGjEpft4+ODixcvav38efPmYcKECQCAAwcOYN68eRrzWFhYoG7dumjfvj0mTJiA9u3bV3hddLF161b8+eefuHHjBuLi4uTpS5YswWuvvaYx/+HDh3HhwgVcv34d8fHxePLkCWxsbODu7o7XX38dw4YNg0qlUrwnKysLO3fuxKlTp/D3338jPT0dlpaWaNSoEXr06IGJEyeiXr16OpeZiIj0Q19ZDQBNmzbFoEGDcOLECWzZsgWjRo0q8297cnIy9uzZg5CQENy+fRtpaWlwcHBAw4YN0aNHDwwdOhTNmjUDUHCAYPXq1QAAZ2dnBAcHa122u7t7qZ9/6NAhtG7dGgDg5+eHgwcPKl5XqVSwtrZGw4YN0a1bN7z99tuoX79+hdelNBcuXMDu3bsRHh6OxMREpKWlwdraGk2aNEHv3r0xfvx41K5dW/GevLw87Nu3D0ePHkVkZCRSU1Nhbm6O+vXr4/nnn8fEiRPRtGnTEj/z7NmzmDx5svxclzomIiL900dWd+/eHZ6enrh27RpWrlyJl156CdbW1mVaxsOHD7Fr1y6cP38e0dHRyMjIgKOjIxo1aoQ+ffpg6NChaNCgAQBlhnp5eWHHjh0lLjc2NhYDBgwo9fMvXbqEGjVqACh+H1ylUsHGxgZNmjRBnz59MHHiRDg4OFR4XbTRtewl1UFwcDD27NmD69evIyUlBba2tnB2dkbnzp0xf/58xbxRUVHYvHkzLl68iPv37yM3Nxc1atRAixYtMHToUAwfPhwmJryuh4ioMnC/WUnU/ebk5GRs3boV169fx40bN5CcnCy/pu34/v379/HDDz/g3LlzePToEWxtbeHh4YFx48ahT58+innDw8Nx4sQJ/PHHH4iLi0NCQgJUKhWcnZ3Rt29fvP322xr75kV98MEHOH78uPx82rRpmD59uk7rSNUbO7SJDCQsLAxnzpwBAAwePLjUH/LSvPbaa1i+fDkyMjKwevXqMnVoR0VFYcaMGYiMjFRMz87ORnJyMiIiInDs2DFcvny5QmWsqOzsbMTFxSEuLg6nTp3Chg0b0L17d8U8lbEuq1evRmpqqs7zL1iwANnZ2YppKSkpuHjxIi5evIjffvsNS5culV/Ly8vDxIkT8ccffyjek5GRgcjISERGRuLIkSM4ePAgnJycdC4HERFVjL6zGig4wHzixAk8ffoUmzZt0jgYq83PP/+MuXPnKnY6AeDx48d4/Pgxrl69ioiICKxdu7bC5SwvSZKQkZGB27dv4/bt2zh+/DgCAwNRp04dxXz6XpeLFy/ixx9/VExLS0tDWFgYwsLCcPToURw8eFA+0A8Ac+bMwbFjxxTvycvLQ3R0NKKjo3HkyBHs3r272AMWSUlJWLBggU5lIyKiyqPPrB4zZgyuXbuGR48eYc+ePWU6IL9v3z58/vnnyMzMVEx/8OABHjx4gMuXL+Px48cGzQ5JkpCeno7w8HCEh4fjp59+woEDB2BlZaWYzxDrYmamPDyZl5eHefPmITAwUDE9OTkZycnJCA0NVWxDhYaGYuzYscjIyFDMn5SUJO+H//HHH4r9cCIi0g/uN5edofabCzumyyIsLAwTJ05UlCE5ORnnzp3DuXPnMHPmTEydOlV+bdeuXQgICNBYzp07d3Dnzh0cPXoUAQEBJZ4Yd/jwYUVnNpE6dmgTGciuXbvkx0OHDq3w8qytrTFgwAAcOXIE4eHhuHr1aolXMKuLj4/HxIkTcf/+fQCApaUlRo0ahW7dusHKygoxMTE4ffo0rly5UuEyAkDv3r3x7rvvakxv3Lhxie/x9/dHfn4+bt26JXfa5+bmYtOmTYoO7cpal5YtW8LV1RUeHh5YvXo1EhISdHrPsGHD0Lp1ayQnJ2PDhg0IDw8HUHCW3ogRI9C5c2cAkHeuC02ZMgVdu3ZFREQEli1bhtzcXMTHx+PIkSOYNGlSmcpORETlp++sBoBOnTqhQYMGuH//Pg4dOgRfX19YWlqW+r6LFy9i2rRpyMnJAQDUrVsX48aNg4eHB3JzcxEZGYmjR4/qpYxAQRb16tVLY7qLi0ux87du3RoLFy5EdnY2zp07h02bNgEoyOb9+/crsr8y1qVevXoYPXo02rdvDycnJ2RlZeHo0aNyh3VsbCxOnjyJESNGAADu3r2r6MweOXIkBg8ejLi4OCxZsgTp6enIyMhAQEAAFi1apPF5n3zyCR4/fgxLS0tkZWWVqaxERKQ/+sxqb29vWFlZITMzEwEBATp3aB85ckTRuevq6gofHx80b94cWVlZCA0N1eiYrYiFCxfKV32ps7W1LXb+wn3wp0+f4tixY/JVYnfu3EFQUBBefvnlSlsXJycn+Pv7a0zPycnBe++9h6dPnwIo6ABRt2bNGvlzateuDR8fH7Rp0wYqlQpxcXG4dOmSYv6tW7fKndn16tXDnDlzUKtWLezatQtBQUEAgMDAQMydO1cvHS1ERPQv7jcbz36zubk5OnbsCA8PDzRo0KDUE71yc3Mxe/ZsuTO7R48eGDNmDG7evIlVq1ZBkiR8//336Nq1Kzp27Ci/r0aNGhg6dCi6desGS0tLnD59Grt37wZQMArM6tWr8cUXX2h83oMHD/D5558DAPe1qVjs0CYygLy8PPlMIxsbGzz//POK15OSkvDdd98hPDwc9+7dQ0pKCoCC4OrUqRMmTZqEVq1aaSy3b9++OHLkCADg2LFjOnVof//993IHsLm5OTZv3ix3tAJAt27dMHLkSERERJRvZYtwdHRULF8XhfN7eXnhzp078g6x+vDfQOWty//+9z/58caNG0udf+XKlRr3U+3atSt69eqFvLw8AMCVK1fkshV+vwDg4OCAWbNmyeU9fPgwQkNDARRsRBARUdUoLauLevjwIb755hucPXsWmZmZ8PDwwOzZs9GpUyfFfCqVCr1790ZAQABSUlLwyy+/lDqqSn5+Pj799FN5R9bZ2Rl79uxRnL3du3dvvP322xojlJSXi4tLmfLa3t5enr979+4ICQnBrVu3ACjzurLWZeTIkRrT+vfvj5CQEHmUFfXRVtSzFygYBq6wIyAkJASnTp0CUHz2Hjp0CCdPnoS9vT0mTJiAVatW6VxOIiLSH12z+syZMwgICJCH1rS1tYWLiwuGDRuGMWPGyPPZ2dmhc+fOOHfuHO7cuYObN28Wu9+tLi0tTXFA1sPDA9u3b1d0Lvft2xdTpkxBdHR0Bdb2Xy1btixTRqvvg/fo0QOnTp1Ceno6AODevXvyfJWxLhYWFsWWdd++fXJntqOjI4YNGya/lpSUhM2bNwMoOJi9Y8cOuLm5Kd7/5ptvKp4/efJEfvzSSy/JHSp169aVO7QlSeI+NRGRnumSxSkpKfj222/x008/IS0tDa1atcL777+vdbncb66cdXFzc5NPQIiNjS21QzskJARRUVEACk6cW716NWxsbDBgwADExsbiwIEDkCQJ27Ztkzu0hw4dio8++gh2dnaKsj58+FC+kr+4i80kSYKfnx+ePHmCgQMHyqOdEqnjzWOIDCA8PFw+qNq2bVuYmpoqXk9MTMTu3btx9epVPH78GNnZ2fJw24cPH8aIESNw7do1jeWqd2BfuHCh1HLk5OQozuQaNmxYiSGsy/1BqkJ+fr78WP3eIiKtS9HObKBgJ119mFMbGxv5cceOHeX7syUnJ2PFihX47bffsHXrVrnz3cbGRuOsdSIiqjylZbW69PR0jB49GoGBgUhOTkZmZiYuX76M8ePHF7sD5unpKT/WJa+vXbuGO3fuyM9nzpypMRRZoZYtW5a6vKpQUl5XxbpIkoSkpCT4+/vL36GJiYliVJeWLVuibt268vOvvvoK58+fx969e/Hrr78CKBj+VP0AO1Bw4H/x4sUAgI8//hgNGzYsVxmJiKjiSstqSZKwcOFCTJkyBWfOnMHjx4+Rk5OD5ORkXL16FSdOnNBYpnpG//7776WW4ezZs0hKSpKfz5s3r9grpU1NTdG8eXOd162ySJIESZLk5+r3JK3Kddm6dav8eMyYMYqr7kJCQuTObjc3N/j7+6N///7w8PCAt7c3vv76a6SlpSmW16NHD/nxsWPHcPToUZw7dw7ff/+9PL137968hRcRkZ6VlsWZmZkYN24cdu/ejYSEBGRlZeHq1at49913cfr0aa3L5n6z4ddFvd7btm2rOJ6tftxdfZupS5cuis7sQk2bNpUfqy+n0LZt2/Dbb7+hTp06+OyzzypcdqqeeIU2kQGonznl6uqq8XrNmjUxY8YMNG3aFHZ2drCyssLTp0/x66+/Ytu2bcjOzsaaNWuwfv16xfsaN24MMzMz5Obm4tatW8jPz4eJScnnrURHR8tnZgPKncDKcvDgQXmIM3WXLl1SdPiqu3z5sjzkeOGwYyqVCj4+PvI8hliXsvjtt9/kgwNmZmbo16+f/JqTkxN++OEHfPLJJ/jnn3+wbt06rFu3Tn7d29sbs2fPRpMmTaq83EREz6rSslpdcnIyHB0d8d1330GSJKxcuRLR0dHIycnBxx9/jBMnTkClUsnzq+/I6TJqSOFIHYWqIuPmzZuHefPmKaa1atWqxGFGU1NTcfnyZXnotMKdb3t7e7z22mvyfJW9LsOGDcPNmzcV01xcXODr66u4ys7S0hIbNmzA/PnzERYWhj179mDPnj3y615eXvD19cVzzz0nT5MkCXPnzkVqaioGDx6MYcOG4cCBA3otPxER6a60rN67dy/27t0rPx80aBBeeuklWFpaIjQ0VL7iSF1ZM/rGjRvyYxsbG8Vwm5Vl3LhxGtMGDBhQ4v0zExIScPnyZXnI8cKhuRs0aICBAwfK81XVuqhfjWZtba1xtbV6vYeGhiq2HWJiYrBp0yb8+uuv+N///id3uI8ZMwbx8fHYvn07Hj58CF9fX/k9tra2mDRpEt55551KWR8iomdZaVm8ZcsWef/M3Nwc7733Hjw8PPDTTz8pMro43G/+l6GOc9+9e1d+rH5CeNHnycnJePLkSYnH9rOyshAcHCw/V9/+AIDbt2/j22+/BQB8+eWXvD0IlYgd2kQGkJiYKD92cHDQeL1OnTpo27Ytdu/ejdDQUCQlJclDjBT666+/il12zZo1kZCQgLy8PCQnJ2sNAPVhuUoqiwjUh4EDCjaQ5s6dq7gSurzrcu/ePcUwa4XKOiy6NmFhYZg9e7b8/IMPPtC4oqt27dpo3rw5/vnnH433X7x4EefPnxfijH4iomdFaVld1MqVK9GiRQsAQJMmTfD6668DKDjhKjw8HG3atCl2eQkJCaUu2xjyOjw8XCOvu3fvjvnz5yvONC/vukRERCiGDAcKdvp1GXXF3NxcYzsKKNhmcnNzQ0REhHxLkELXr1/HmTNn4OnpKZ8cuHnzZly8eBFOTk749NNPdSo3ERFVntKyOiAgQH7cr18/xS0i1E8wVlezZk35sS4ZrZ5N9vb2Wk8oN5SQkBCEhIQopr344ovw8/NTXCFV3nW5fv26xj0u69SpU+IJgVu2bJEfv/rqq6hVq5bi9aLbCp06dcLkyZMRFxeHZcuW4enTp7h58ya2bNmCadOmASi4arxx48ZwcnLS2KdOT0/HqVOn4O3tLczIc0RE1UVpWfzjjz/Kj0eOHCkPNd6nTx+Eh4crTqYqivvN/6qK/ebiFI6YAhTsV6sr+jwjI6PYDu3MzEx88MEH8u1K2rZti/Hjx8uv5+Tk4KOPPkJWVhZGjRqFPn36lKus9GxghzaRAagP8aX+uNDevXuxcOFCrcsoeu9HbcsrSdGQSU5O1vm95dW7d2+8++67GtOLG8qsJHFxcfj7778VHdrlXZf9+/dj9erVGtP1dc/ws2fP4oMPPpDPgn/33Xc1zgyPiYnBqFGjkJGRAQsLC6xatQrPP/88IiIi8N577yExMRGLFy9GvXr1MGjQIL2Ui4iItCstq9XVrFlT7swGCu45aWVlhczMTAAFndrqHdrqy1O/crskxWVcScON6cuUKVPQq1cvxbSyZDVQcEJXfHy8om7Kuy6LFy/WGL7dy8sLO3bsUEz76quvkJaWhqSkJPz888/Yv38/bt++LV+p9fLLLwMoOGg/cuRIPH78GADwxRdfYMiQIYiLi8P06dMRFRWFdevWwcHBARMnTsTDhw/x3XffQaVSYcmSJUIeHCEietaUltXqQ3WWZz9Kl4y2t7eXH6emppY6Spo+LFy4EK1bt1ZMK9opXJpr164hJSUFDRo0kKeVd11mzpypuO8nUNBR/dVXX2nMe/PmTZw/fx5Awe1AJkyYoDGP+vDjAPD555/LJ3dHRUXJ2X/27Fm5Q3vDhg1Yvnw5AKBDhw74+uuvUbt2bezcuRMrVqzAzZs3MWnSJJw6darYYU6JiKh8Ssti9ZOMOnTooHitU6dOWju0ud/8L33vN+uq8BaZAJCdna14rejz4vI1MTER7733nnxhXqtWrbBx40ZYWVnJ82zfvh2hoaFwdXWFn59fucpJzw7xTh0legY4OjrKj4vrmN64caP8uGfPnlizZg38/f3loTeAkg+uF57BZWJiUurBVldXV0XIFu5YViZHR0d07txZ45+2e5NGRETg999/l89gy8nJwbJly+R7XAKGWZfS7N69G++99x4yMjJgYmKC+fPnK67ULrR//365w7tXr17o27cvrK2t8dxzz2Ho0KHyfMePH6+yshMRPetKy+qKUD/pSpcD0G3btlU8r4qMc3Fx0cjqogfP1Xl5eeHmzZv46aef5FFOkpOTMXPmTMVZ+5W9Lq1bt0aXLl0waNAgfPnll4oc3bVrl/z4xIkTcmd2q1atMHz4cNjY2KBFixYYPXq0PF9h9iYmJiI7OxuSJGHSpElwd3eHu7u7Yni5uLg4uLu7Y+rUqXpdJyIiKl5ZslqXA+GAMqN1Ge7Sw8NDfpyRkYErV67o9DkV0bJlS42M1jaa16uvvorw8HAEBgbK8927dw/Tpk1THIyuinXZvHmz/Njb2xsuLi4a8xQdzaxx48bFPla/em3nzp3y47fffhtNmjSBnZ0dpkyZIncKPH78GJcvX674ShARkawysrgQ95v/Zajj3Oq3vyzcfy706NEj+bGDg4NGJ3xUVBRGjhwpd2Z37doVO3fu1Ni+evDgAYCCCwGee+45eV9bvWN+9erVcHd3R1BQkF7Wi4wXO7SJDKBly5by4+Lu26U+BPZHH30Eb29vdO7cWWMYr6Lu3r2L3NxcAICbm1upZ1Obm5vLVyoBwKFDh/Dnn38WO6++rlgur1q1amHhwoWKQF+6dKncsV/edZk+fToiIiI0/lWEJElYtmwZPvnkE+Tl5cHa2hqrVq1SDKeiTn2DJS0tTfGa+jAxRV8jIqLKU1pWq0tJSVFcBRYaGipfnQ1o3ktMfXm6DP3l6empOFC9cuXKEodcU7+HWVVTqVRo0qQJvv32W/ns7JSUFMU9Pcu7Ljt27NDI6sKzzPPz8zXODi9OUlJSsY/T09MVJwoye4mIjENpWa2eN6dOndJ4vbiTxNWXo778kvTp00dxkP2rr76ST1ZWl5eXp9hWqGomJiZo1aoVli9fLh8niImJgb+/vzxPedclODhYI6OLuzr74cOHiqFn33rrrWLL6uXlpXgeGxsrP46JiZEfN2rUSH5c0j51dna2YhuBuU5EpF+lZbH6vnDRE6VKO3GK+8363W8uj+eff15+HBoaivT0dPm5eodz165dFe+7fPkyRo0aJef2q6++io0bNypGgyEqDw45TmQArVu3hr29PVJTUxEWFoa8vDzFFcqNGzeWdxDXrl2LkSNH4vbt2/j++++1LvfatWvy46I7gSWZMWMGQkJCcP/+feTk5GDixIkYPXo0unXrBgsLC8TExOD06dO4cuWKxpAlhTZs2FBsIL3zzjuKe5ABBfc8Ke6saG332CpkYmKCmTNnYvLkyQAKOqaDgoIwcOBAva1Lcc6ePSvfM0T93iE3btyQNzzatWsHZ2dnAMCsWbPkK7pMTU3xwQcfwMHBQbHe6uvbqlUrefqFCxewYsUKeHl5ISIiAkeOHJFf8/T01LnMRERUMaVldVEzZ87EtGnTkJ+fr8jrpk2bapyhff36dflxly5dSi2LiYkJPvnkE0yaNAk5OTmIjY3Ff/7zH4wfPx5t2rRBXl4eIiMjceTIETRs2FCxI1woJSVFHopTXY0aNeRcVffPP/8Um9dNmzZVnIVfnHr16uHNN9+UR5zZs2cPJk+eDCcnJ72sS1FpaWnw9vbG4MGD0a5dOzRs2BAZGRn45ZdfFDnavn17+bH6AZGYmBgsWrQIL7zwAmJjY7Ft2zb5tcLsrVevnuJq7ELXr1/H0aNHARQMPT916lTFWexERFR5SsvqkSNHykOZBgcHY8aMGXj55ZdhYWGBmzdv4tatW/jmm28UyyxrRtvZ2WH+/PmYM2cOgIJ98tdeew0+Pj5o1qwZsrKyEBoaisDAQPTp0wcLFizQWEZMTEyxGd24cWO88cYbGtMjIyOL3SZxd3cv9UBxmzZt8MILL8j7q5s2bcLo0aNhZWWll3XRZseOHcjJyQFQMOxs0aFnC7Vr1w4dOnSQOzoWLVqEt99+G/fu3cP+/fvl+dRHYWnVqpV8POS7774DUHCF/Z49e+STDFUqFdq1a1emMhMRkXalZfGQIUPkC4cCAgJQp04dtG3bFkFBQYrj2MXhfrN+95uBguPaZ8+eBaA8GQwAQkJC5Kun+/TpA2tra/Tu3RtNmzZFVFQUMjIyMH36dIwZMwZhYWHyvrZKpVJcxBUUFIRZs2bJJ5T17t0bw4cPx9WrVxWfV3iF+sCBA+Vj6ur8/f1x9+5dAAUj2Pbq1Uunkw2pelNJZbnhLhHpzcKFC7F3714AwJYtW9C9e3f5tT179uDjjz/WeE/Xrl3x+++/y8+LXkn84YcfymGya9cudOzYUaeyREVFYcaMGVrPTrO3t5cD+sKFCxg3blypyz19+jQaNWoEHx+fUjuQ1e+xdeDAAcVB46LrOXz4cHmjpk2bNjh48GC510UX/fv317gnWFFLlizBa6+9BkC3swbV1zczMxOjR49GWFhYifO7uLhg7969GicIEBFR5dGW1epZaG9vDysrK40huMzNzbFp0ybFWc2SJKFfv364f/8+7O3t8csvvyjuS6XNzz//jLlz5yqGXitqwIAB8s7sqlWrsHr1aq3LdHZ2RnBwMADd8ks97/z8/OQMLnpfrsTERAwYMEC+smv8+PGYP39+uddFmydPnpR6gMPFxQU7duxAvXr1ABR8D5MnT0ZISEiJ7yk8EK4+vGlR6tss6nVJRERVQ1tWS5KE+fPn48CBA8W+t2h2paWloUePHsjMzISrqytOnDih8/Co+/btw+eff64YoaWocePGyZ3A6hlaksLyxcbGYsCAAaWWYfv27fI2h/o+eNH7WUdGRuKVV16Rr1CfP3++4kB0WddFF+np6ejbt688TPjq1avlE9OLEx0dDR8fH8VwpupefvllLF++XP5+Lly4gHfeeUfrqHZvvfUW5s6dq3OZiYhIN9qyODMzE2+88QZu3ryp8b7CjlJAM6u431y+dSmNrtsUhcf0gYIrsydOnFjikPIzZ85U3HZLl20coPTRYNW3ZaZNm4bp06eXukyq/jjkOJGBqN+fUf3qIaDgTPLFixejRYsWsLS0hLOzM2bMmIHPPvusxOVlZmbi9OnTAAqCVdfObKBgA+LAgQNYunQp+vXrBycnJ5ibm8Pe3h5ubm4YMWJEqcFelaZNmyY/DgsLUxw8NrZ1AQArKyv4+/vD19cXnp6esLe3h6mpKWxsbNC6dWtMnToV+/btY2c2EVEV05bV6mrUqIHdu3dj8ODBqFmzJiwtLdG5c2ds3bpV0ZkNAH/88Qfu378PAPjPf/6j8045APTt2xcnT56Er68vOnfujFq1asHc3ByOjo5o27YtpkyZAl9f3zKuZeWoXbs2Ro0aJT8PCAhQDJGmz3WxsrLC1KlT0bVrV9SvXx9WVlbysry8vOQd6sLObKDgLPK1a9di0aJF6NKlCxwcHGBqagorKyu4ublh/PjxOHTokNbObCIiMjxtWa1SqbBkyRKsWbMG/fr1Q506dWBmZoaaNWvC09MTL774omL+oKAguRN39OjRZbrX5/Dhw3Hq1ClMmTIFnp6eqFGjBszNzVG3bl106NABs2bNKnGI7arWsmVLDBo0SH6+ceNGxbDclbEu+/fvlzuzXVxcSj2Y7urqioMHD2L8+PFo0qQJzM3NYWtri44dO2LJkiWKzmygYEjU/fv34/XXX4eLiwssLCxgamqK2rVro2fPnlixYgU7s4mIKom2LLayssK2bdvwxhtvoHbt2rCwsEDbtm2xcuVKvPTSSyUuk/vNBURYl7Zt2+LQoUN444034OzsDHNzc9SsWRM9e/bEf//7X0VnNlFl4xXaRAY0ZcoUnDlzBtbW1ggODpaH9SgPf39/ucO7tLOdiYiISDf6zGqg4OzlEydOwNraGidPnlR0shIREVHZ6SurR4wYgWvXrqFu3bo4deqUfHspIiIi0o77zURUFXiFNpEBzZkzB2ZmZnj69Cm2bt1a7uXk5uZi06ZNAIBOnTqxM5uIiEhP9JXVQMHwmadOnQIATJgwgTvlREREeqCPrP7tt9/ke3nOnDmTndlERERlwP1mIqoKvEKbiIiIiIiIiIiIiIiIiIiExCu0iYiIiIiIiIiIiIiIiIhISOzQJiIiIiIiIiIiIiIiIiIiIbFDm4iIiIiIiIiIiIiIiIiIhMQObSIiIiIiIiIiIiIiIiIiEhI7tImIiIiIiIiIiIiIiIiISEjs0CYiIiIiIiIiIiIiIiIiIiGxQ5uIiIiIiIiIiIiIiIiIiITEDm0iIiIiIiIiIiIiIiIiIhISO7SJiIiIiIiIiIiIiIiIiEhI7NAmIiIiIiIiIiIiIiIiIiIhsUObiIiIiIiIiIiIiIiIiIiE9H+OFy1aXpbcbQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 2000x500 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from matplotlib import colormaps as cm\n",
    "import string\n",
    "\n",
    "# -----------------------------\n",
    "# 1. Global Plot Configuration\n",
    "# -----------------------------\n",
    "sns.set_style(\"white\")  # no gridlines\n",
    "\n",
    "plt.rcParams.update({\n",
    "    'font.size': 16,\n",
    "    'font.weight': 'bold',\n",
    "    'axes.labelweight': 'bold',\n",
    "    'axes.titlesize': 16,\n",
    "    'axes.titleweight': 'bold'\n",
    "})\n",
    "\n",
    "# -----------------------------\n",
    "# 2. Algorithm Style Map\n",
    "# -----------------------------\n",
    "markers = ['o', 's', 'D', 'v', '^', '>', '<', 'p', '*', 'h', 'H', '+', 'x']\n",
    "cmap = cm.get_cmap('tab10')\n",
    "color_list = list(getattr(cmap, 'colors', [cmap(i / 10.0) for i in range(10)]))\n",
    "\n",
    "algorithm_map = {\n",
    "    algo: {\n",
    "        'marker': markers[i % len(markers)],\n",
    "        'color': color_list[i % len(color_list)]\n",
    "    }\n",
    "    for i, algo in enumerate(algorithms)\n",
    "}\n",
    "\n",
    "# -----------------------------\n",
    "# 3. Dataset Label Map (Paper Consistency)\n",
    "# -----------------------------\n",
    "subplot_labels = {\n",
    "    'sift1m': 'SIFT1M',\n",
    "    'gist1m': 'GIST1M',\n",
    "    'deep1m': 'DEEP1M',\n",
    "    'glove1m': 'GloVe1M',\n",
    "    'msong': 'MSong',\n",
    "    'tiny5m': 'Tiny5M'\n",
    "}\n",
    "\n",
    "# -----------------------------\n",
    "# 4. Create Figure Layout (1 Row)\n",
    "# -----------------------------\n",
    "n_datasets = len(datasets)\n",
    "fig, axes = plt.subplots(nrows=1, ncols=n_datasets, figsize=(5 * n_datasets, 5))\n",
    "axes = axes.flatten() if n_datasets > 1 else [axes]\n",
    "\n",
    "# Compute QPS if missing\n",
    "if 'QPS' not in df.columns and 'Time (msec)' in df.columns:\n",
    "    df['QPS'] = 1000.0 / df['Time (msec)']\n",
    "\n",
    "# -----------------------------\n",
    "# 5. Plot Each Dataset\n",
    "# -----------------------------\n",
    "MVR_wo = [0.21, 0.222, 0.264, 0.309]  # red line x-values\n",
    "\n",
    "for i, ds in enumerate(datasets):\n",
    "    ax = axes[i]\n",
    "    df_subset = df[df['Dataset'] == ds]\n",
    "\n",
    "    for algo in algorithms:\n",
    "        if algo == 'MVR-HNSW':\n",
    "            continue\n",
    "        data = df_subset[df_subset['Algorithm'] == algo].copy()\n",
    "        data = data.sort_values(by='Recall')\n",
    "        style = algorithm_map[algo]\n",
    "\n",
    "        ax.scatter(\n",
    "            data['Recall'],\n",
    "            data['QPS'],\n",
    "            label=algo,\n",
    "            color=style['color'],\n",
    "            marker=style['marker'],\n",
    "            s=70,\n",
    "            edgecolor='black',\n",
    "            linewidth=0.6,\n",
    "            alpha=0.9\n",
    "        )\n",
    "\n",
    "    # Axis scaling\n",
    "    if not df_subset.empty:\n",
    "        recall_min, recall_max = df_subset['Recall'].min(), df_subset['Recall'].max()\n",
    "        qps_min, qps_max = df_subset['QPS'].min(), df_subset['QPS'].max()\n",
    "\n",
    "        x_margin = 0.02 * (recall_max - recall_min if recall_max > recall_min else 0.1)\n",
    "        y_margin = 0.05 * (qps_max - qps_min if qps_max > qps_min else 1)\n",
    "\n",
    "        # Ensure the MVR_wo line fits within the plot\n",
    "        if i < len(MVR_wo):\n",
    "            recall_max = max(recall_max, MVR_wo[i] + x_margin)\n",
    "\n",
    "        ax.set_xlim(recall_min - x_margin, recall_max + x_margin)\n",
    "        ax.set_ylim(qps_min - y_margin, qps_max + y_margin)\n",
    "\n",
    "    ax.set_xlabel('Recall', fontsize=13, fontweight='bold')\n",
    "    ax.set_ylabel('QPS', fontsize=13, fontweight='bold')\n",
    "    ax.tick_params(axis='both', labelsize=14, width=1.8)\n",
    "\n",
    "    subplot_letter = f\"({string.ascii_lowercase[i]}) \"\n",
    "    ax.text(\n",
    "        0.5, -0.25,\n",
    "        subplot_letter + subplot_labels.get(ds, ds),\n",
    "        transform=ax.transAxes,\n",
    "        ha='center',\n",
    "        fontsize=13,\n",
    "        fontweight='bold'\n",
    "    )\n",
    "\n",
    "# -----------------------------\n",
    "# 5.1 Add Dotted Red Line (MVR_wo)\n",
    "# -----------------------------\n",
    "for i, ax in enumerate(axes):\n",
    "    if i < len(MVR_wo):\n",
    "        ax.axvline(\n",
    "            x=MVR_wo[i],\n",
    "            color='red',\n",
    "            linestyle='--',\n",
    "            linewidth=2,\n",
    "            alpha=0.8,\n",
    "            label='No Index' if i == 0 else None  # add label only once\n",
    "        )\n",
    "\n",
    "# -----------------------------\n",
    "# 6. Legend (Top Center)\n",
    "# -----------------------------\n",
    "handles, labels = axes[0].get_legend_handles_labels()\n",
    "fig.legend(\n",
    "    handles, labels,\n",
    "    loc='upper center',\n",
    "    bbox_to_anchor=(0.5, 1.08),\n",
    "    ncol=len(algorithms) + 1,  # +1 for MVR_wo line\n",
    "    fontsize=13,\n",
    "    frameon=False\n",
    ")\n",
    "\n",
    "# -----------------------------\n",
    "# 7. Cleanup & Save\n",
    "# -----------------------------\n",
    "plt.tight_layout(rect=[0, 0, 1, 1])\n",
    "fig.savefig('query_performance_plot_single_row_with_MVRwo.png', dpi=300, bbox_inches='tight')\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f8e508a2",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
