{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from collections import defaultdict\n",
    "\n",
    "import matplotlib.colors as mcolors\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "import torch\n",
    "from cycler import cycler\n",
    "from hydra import compose, initialize\n",
    "from torch_geometric.seed import seed_everything\n",
    "\n",
    "from graphsmodel.evaluation import compute_banzhaf, compute_loo\n",
    "from graphsmodel.training import get_logits, node_level_subset_training\n",
    "from graphsmodel.utils import (\n",
    "    get_appropriate_edge_index,\n",
    "    get_dataset,\n",
    "    get_margin_incorrect_vectorized,\n",
    "    get_model,\n",
    "    get_optimizer,\n",
    ")\n",
    "from graphsmodel.utils.visualization import get_figsize\n",
    "\n",
    "colors = sns.color_palette(\"Set2\")\n",
    "plt.rcParams['axes.prop_cycle'] = cycler(color=colors)\n",
    "\n",
    "\n",
    "def lighten_color(color, factor):\n",
    "    \"\"\"\n",
    "    Lightens the given color by a factor of `factor`.\n",
    "    factor should be between 0 (original color) and 1 (completely white).\n",
    "    \"\"\"\n",
    "\n",
    "    c = mcolors.to_rgba(color)  # Convert color to RGBA\n",
    "    white = mcolors.to_rgba('white')\n",
    "    lightened_color = tuple(c[i] + (white[i] - c[i]) * factor for i in range(4))\n",
    "    return mcolors.to_hex(lightened_color)  # Convert back to hex\n",
    "\n",
    "def get_label_from_key(key, color_map, alphas_lightness_dict=None):\n",
    "    if \"pc_perms\" in key:\n",
    "        return \"pc_winter_perms\", color_map[\"pc_perms\"]\n",
    "    elif \"pc\" in key:\n",
    "        return \"pc_winter\", color_map[\"pc\"]\n",
    "    \n",
    "    for label, color in color_map.items():\n",
    "        if label in key:\n",
    "            if \"0.\" in key:\n",
    "                assert alphas_lightness_dict is not None\n",
    "                light_factor = alphas_lightness_dict[float(key.split(\"_\")[-1])]\n",
    "                lightened_color = lighten_color(color, light_factor)\n",
    "                return f\"{label} {key.split('_')[-1]}\", lightened_color\n",
    "            return label, color\n",
    "\n",
    "\n",
    "banzhaf_line = plt.plot(np.arange(10), label=\"banzhaf\")\n",
    "banzhaf_color = banzhaf_line[0].get_color()\n",
    "\n",
    "shap_line = plt.plot(np.arange(10), label=\"shap\")\n",
    "shap_color = shap_line[0].get_color()\n",
    "\n",
    "loo_line = plt.plot(np.arange(10), label=\"loo\")\n",
    "loo_color = loo_line[0].get_color()\n",
    "\n",
    "pc_winter = plt.plot(np.arange(10), label=\"pc_winter\")\n",
    "pc_winter_color = pc_winter[0].get_color()\n",
    "\n",
    "dm_line = plt.plot(np.arange(10), label=\"datamodel\")\n",
    "dm_color = dm_line[0].get_color()\n",
    "\n",
    "pc_winter_perms = plt.plot(np.arange(10), label=\"pc_winter_perms\")\n",
    "pc_winter_perms_color = pc_winter_perms[0].get_color()\n",
    "\n",
    "rnd_line = plt.plot(np.arange(10), label=\"rnd\")\n",
    "rnd_color = rnd_line[0].get_color()\n",
    "\n",
    "degree_line = plt.plot(np.arange(10), label=\"degree\")\n",
    "degree_color = degree_line[0].get_color()\n",
    "\n",
    "color_map = {\"dm\": dm_color, \"shap\": shap_color, \"banzhaf\": banzhaf_color, \"loo\": loo_color, \"pc\": pc_winter_color, \"pc_perms\": pc_winter_perms_color, \"rnd\": rnd_color, \"degree\": degree_color}\n",
    "\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_datamodel(results_dir):\n",
    "    dm_results = torch.load(results_dir / \"datamodel_res.pt\")\n",
    "\n",
    "    margins_dm = dm_results['margins_dm']\n",
    "    test_accs_dm = dm_results['test_accs_dm']\n",
    "    val_accs_dm = dm_results['val_accs_dm']\n",
    "    sub_margins_dm = dm_results['sub_margins_dm']\n",
    "    sub_test_accs_dm = dm_results['sub_test_accs_dm']\n",
    "    sub_val_accs_dm = dm_results['sub_val_accs_dm']\n",
    "\n",
    "    return margins_dm, test_accs_dm, val_accs_dm, sub_margins_dm, sub_test_accs_dm, sub_val_accs_dm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_banzhaf(results_dir, cfg, data):\n",
    "    subsets_res = torch.load(results_dir / \"subsets_res.pt\")\n",
    "    subsets = subsets_res['subsets']\n",
    "    logits = subsets_res['logits']\n",
    "    sub_logits = subsets_res['sub_logits']\n",
    "    sub_y = subsets_res['sub_y']\n",
    "\n",
    "    (\n",
    "        margins_banzhaf,\n",
    "        test_accs_banzhaf,\n",
    "        val_accs_banzhaf,\n",
    "        sub_margins_banzhaf,\n",
    "        sub_test_accs_banzhaf,\n",
    "        sub_val_accs_banzhaf,\n",
    "    ) = compute_banzhaf(\n",
    "        subsets=subsets,\n",
    "        logits=logits,\n",
    "        sub_logits=sub_logits,\n",
    "        sub_y=sub_y,\n",
    "        data=data,\n",
    "        subset_mode=cfg.data.subset_mode,\n",
    "    )\n",
    "\n",
    "    return margins_banzhaf, test_accs_banzhaf, val_accs_banzhaf, sub_margins_banzhaf, sub_test_accs_banzhaf, sub_val_accs_banzhaf"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_loo(results_dir, cfg, dataset, data):\n",
    "\n",
    "    true_logits = []\n",
    "    for model_seed in range(cfg.train.n_models):\n",
    "        seed_everything(model_seed)\n",
    "        model = get_model(cfg, data, num_classes=dataset.num_classes)\n",
    "        if \"_target_\" in cfg.train.optimizer:\n",
    "            optimizer = get_optimizer(cfg.train.optimizer, model)\n",
    "            _, _, _, _, model_logits = node_level_subset_training(\n",
    "                data=data,\n",
    "                model=model,\n",
    "                optimizer=optimizer,\n",
    "                patience=cfg.train.patience,\n",
    "                max_epochs=cfg.train.epochs,\n",
    "            )\n",
    "        else:\n",
    "            edge_index = get_appropriate_edge_index(data)\n",
    "            fit_args = {\n",
    "                \"x\": data.x,\n",
    "                \"edge_index\": edge_index,\n",
    "                \"y\": data.y,\n",
    "                \"train_mask\": data.train_mask,\n",
    "            }\n",
    "            model.fit(**fit_args)\n",
    "            model_logits = get_logits(data, model)\n",
    "        true_logits.append(model_logits)\n",
    "    true_logits = torch.stack(true_logits)\n",
    "    true_margins = (\n",
    "        get_margin_incorrect_vectorized(true_logits.unsqueeze(0), data.y)\n",
    "        .squeeze(0)\n",
    "        .numpy()\n",
    "        .mean(0)\n",
    "    )\n",
    "    true_test_acc = (true_margins > 0)[data.test_mask].mean().item()\n",
    "    true_val_acc = (true_margins > 0)[data.val_mask].mean().item()\n",
    "\n",
    "    loo_res = torch.load(results_dir.parent / \"loo_res.pt\")\n",
    "    loo_logits = loo_res['logits']\n",
    "    loo_sub_logits = loo_res['sub_logits']\n",
    "    loo_sub_y = loo_res['sub_y']\n",
    "\n",
    "    (\n",
    "        margins_loo,\n",
    "        test_accs_loo,\n",
    "        val_accs_loo,\n",
    "        sub_margins_loo,\n",
    "        sub_test_accs_loo,\n",
    "        sub_val_accs_loo,\n",
    "    ) = compute_loo(\n",
    "        logits=loo_logits,\n",
    "        sub_logits=loo_sub_logits,\n",
    "        sub_y=loo_sub_y,\n",
    "        data=data,\n",
    "        true_test_acc=true_test_acc,\n",
    "        true_val_acc=true_val_acc,\n",
    "        true_margins=true_margins,\n",
    "    )\n",
    "\n",
    "    return margins_loo, test_accs_loo, val_accs_loo, sub_margins_loo, sub_test_accs_loo, sub_val_accs_loo"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_shap(results_dir):\n",
    "    shap_res = torch.load(results_dir.parent / \"shapley_res.pt\")\n",
    "\n",
    "    sub_test_accs_shap = shap_res['sub_test_accs_shap']\n",
    "    sub_val_accs_shap = shap_res['sub_val_accs_shap']\n",
    "    test_accs_shap = shap_res['test_accs_shap']\n",
    "    val_accs_shap = shap_res['val_accs_shap']\n",
    "    margins_shap = shap_res['margins_shap']\n",
    "    sub_margins_shap = shap_res['sub_margins_shap']\n",
    "\n",
    "    return margins_shap, test_accs_shap, val_accs_shap, sub_margins_shap, sub_test_accs_shap, sub_val_accs_shap"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_pc_winter(results_dir):\n",
    "    pc_winter_res = torch.load(results_dir.parent.parent / \"pc_winter_0_0.5_0.7_res.pt\")\n",
    "\n",
    "    sub_test_accs_pc = pc_winter_res['sub_test_accs_pc']\n",
    "    sub_val_accs_pc = pc_winter_res['sub_val_accs_pc']\n",
    "    test_accs_pc = pc_winter_res['test_accs_pc']\n",
    "    val_accs_pc = pc_winter_res['val_accs_pc']\n",
    "    margins_pc = pc_winter_res['margins_pc']\n",
    "    sub_margins_pc = pc_winter_res['sub_margins_pc']\n",
    "\n",
    "    return margins_pc, test_accs_pc, val_accs_pc, sub_margins_pc, sub_test_accs_pc, sub_val_accs_pc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_pc_winter_perms(results_dir):\n",
    "    pc_winter_perms_res = torch.load(results_dir.parent.parent / \"pc_winter_0_0.99_0.99_res.pt\")\n",
    "\n",
    "    sub_test_accs_pc = pc_winter_perms_res['sub_test_accs_pc']\n",
    "    sub_val_accs_pc = pc_winter_perms_res['sub_val_accs_pc']\n",
    "    test_accs_pc = pc_winter_perms_res['test_accs_pc']\n",
    "    val_accs_pc = pc_winter_perms_res['val_accs_pc']\n",
    "    margins_pc = pc_winter_perms_res['margins_pc']\n",
    "    sub_margins_pc = pc_winter_perms_res['sub_margins_pc']\n",
    "\n",
    "    return margins_pc, test_accs_pc, val_accs_pc, sub_margins_pc, sub_test_accs_pc, sub_val_accs_pc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "def top_k_intersection(train_signal_utility, overall_utility, top_k):\n",
    "    train_signal_rank = train_signal_utility.argsort()[::-1]\n",
    "    overall_rank = overall_utility.argsort()[::-1]\n",
    "\n",
    "    return len(np.intersect1d(train_signal_rank[:top_k], overall_rank[:top_k])) / top_k\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_name = \"sgc\"\n",
    "dataset_name = \"cora_ml\"\n",
    "task_type = \"node_level\" if dataset_name in [\"cora_ml\", \"citeseer\", \"pubmed\"] else \"graph_level\"\n",
    "datamodel_alpha = 0.1\n",
    "subset_mode = \"mixed\"\n",
    "n_models = 10 if model_name in [\"gcn\", \"gat\"] else 5 if dataset_name in [\"pubmed\", \"computers\", \"photo\", \"coauthor\"] else 1\n",
    "\n",
    "per_seed_results = defaultdict(list)\n",
    "for data_seed in [1, 12, 42, 123, 1234]:\n",
    "    with initialize(version_base=None, config_path=\"../../conf\"):\n",
    "        cfg = compose(config_name=\"experiment.yaml\", overrides=[f\"train/model={model_name}\", f\"train.n_models={n_models}\", f\"dataset={dataset_name}\", f\"data.alpha={datamodel_alpha}\", f\"data.data_seed={data_seed}\", f\"data.subset_mode={subset_mode}\", f\"task={task_type}\"])\n",
    "    results_dir = cfg.core.results_dir / f\"alpha_{datamodel_alpha}\"\n",
    "\n",
    "    dataset = get_dataset(cfg)\n",
    "    data = dataset[0]\n",
    "\n",
    "    top_k = int(data.num_nodes * 0.05)\n",
    "\n",
    "    margins_dm, test_accs_dm, val_accs_dm, sub_margins_dm, sub_test_accs_dm, sub_val_accs_dm = load_datamodel(results_dir)\n",
    "    per_seed_results[\"datamodel\"].append(top_k_intersection(test_accs_dm, sub_test_accs_dm, top_k))\n",
    "\n",
    "    margins_banzhaf, test_accs_banzhaf, val_accs_banzhaf, sub_margins_banzhaf, sub_test_accs_banzhaf, sub_val_accs_banzhaf = load_banzhaf(results_dir, cfg, data)\n",
    "    per_seed_results[\"banzhaf\"].append(top_k_intersection(test_accs_banzhaf, sub_test_accs_banzhaf, top_k))\n",
    "\n",
    "    margins_loo, test_accs_loo, val_accs_loo, sub_margins_loo, sub_test_accs_loo, sub_val_accs_loo = load_loo(results_dir, cfg, dataset, data)\n",
    "    per_seed_results[\"loo\"].append(top_k_intersection(test_accs_loo, sub_test_accs_loo, top_k))\n",
    "\n",
    "    margins_shap, test_accs_shap, val_accs_shap, sub_margins_shap, sub_test_accs_shap, sub_val_accs_shap = load_shap(results_dir)\n",
    "    per_seed_results[\"shap\"].append(top_k_intersection(test_accs_shap, sub_test_accs_shap, top_k))\n",
    "\n",
    "    margins_pc, test_accs_pc, val_accs_pc, sub_margins_pc, sub_test_accs_pc, sub_val_accs_pc = load_pc_winter(results_dir)\n",
    "    per_seed_results[\"pc\"].append(top_k_intersection(test_accs_pc, sub_test_accs_pc, top_k))\n",
    "\n",
    "    margins_pc_perms, test_accs_pc_perms, val_accs_pc_perms, sub_margins_pc_perms, sub_test_accs_pc_perms, sub_val_accs_pc_perms = load_pc_winter_perms(results_dir)\n",
    "    per_seed_results[\"pc_perms\"].append(top_k_intersection(test_accs_pc_perms, sub_test_accs_pc_perms, top_k))\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_3991511/1515755503.py:3: MatplotlibDeprecationWarning: The 'labels' parameter of boxplot() has been renamed 'tick_labels' since Matplotlib 3.9; support for the old name will be dropped in 3.11.\n",
      "  ax.boxplot(per_seed_results.values(), labels=labels)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Overlap in top 5%')"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAnoAAAJ6CAYAAAC/qu8MAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy80BEi2AAAACXBIWXMAAC4jAAAuIwF4pT92AACxY0lEQVR4nOzdd3wU1fo/8M9sEtJJJ6ElgBBq6MavCgKCgmLBSgdFxQY2wIaiIooF9F7h6vVeRVQQLiAWQEFFQKQYgUAKTSAJkJCENFJJ2+f3R3477mY3yWZStuTzfr3yYnd25szZhy3PnnPmHEVEBERERETkdHS2rgARERERNQ0mekREREROiokeERERkZNiokdERETkpJjoERERETkpJnpEREREToqJHhEREZGTYqJHRERE5KSY6BERERE5KSZ6RERERE6KiR4RERGRk2KiR0REROSkmOgREREROSkmekREREROiokeERERkZNiokdERETkpJjoERERETkpJnpEREREToqJHhEREZGTYqJHRERE5KSY6BERERE5KSZ6RERERE6KiR4RERGRk2KiR0REROSkmOgREREROSkmekREREROytXWFSD7k5eXh127dqn3O3bsCHd3dxvWiIiIyHGVlpbi3Llz6v1hw4bB39+/Wc7NRI/M7Nq1C+PGjbN1NYiIiJzSt99+i9tvv71ZzsWuWyIiIiInxUSPiIiIyEmx65bMdOzY0eT+t99+i65du9qoNkRERI7t1KlTJkOiqn/PNiUmemSm+oUXXbt2Re/evW1UGyIiIufSnBc4suuWiIiIyEmxRY8cTmlpqXqb077UD2OnDeOmDeOmHWOnDeNmjokeOZwjR45Ar9dDp9MhOjra1tVxKIydNoybNoybdoydNoybOXbdEhERETkpJnpEREREToqJHhEREZGTYqJHRERE5KSY6BERERE5KSZ6RERERE6KiR4RERGRk2KiR0REROSkmOgREREROSmujEEOJzAwUJ35nOqHsdOGcdOGcdOOsdOGcTPHRI/sgl6vR3Z2dp375OTkqPcrKyuRkZFh1Rs6KCjIKd/41sTNsB9jp13Xrl1tXQWHxLhpx9hpw7iZY6JHdiE7Oxtt2rRpsvIzMzMREhLSZOXbSlPHDXDe2BERtQQt+2c6ERERkRNjokdERETkpNh1S0RUh1OnTqkDvDkGyHqMm3aMnTaMmzkmemQXgoKCkJmZWes+WVlZ6NWrl8m2o0ePIjg42KrynZE1cQMYu4bKycnhlXwaMG7aMXbaMG7mmOiRXdDpdJoG/AcHB7foCwW0xg1g7IiIWgKmvEREREROii161CwqKiqQm5vboDKysrKs2qZFQEAAXF3t7+3QGHEDmi529ho3IiKqwk9oanKrVq3CrFmzcOnSpUYvu/q4M638/PywfPlyTJkypVHKawxNGTegcWJnj3EjIqK/seuWmlRFRUWTJiuN5dKlS5g1axYqKipsXRUAjBsRETUOJnrUpHJzc+0+WTG4dOlSo3STNgbGjYiIGgO7bqnZBHt72LoKNcoqumzrKtSIcSMiIq2Y6FGzSV84ydZVqJHrnBW2rkKNGDciItKKXbdERERETootekREdejXr5+tq+CQGDftGDttGDdzTPSI7JBer7d1FciIu7u7ravgkBg37Rg7bRg3c0z0qNmELfgKAHDs2FEEBdW9xmpTy87OQs+ejTMPX2PLzs5WbxviRkREVF9M9KjZGK7QFA8fKF6+Nq4NIEWXHeKqUUeoIxER2ScmeuRwCgsL1ds+Pj42rAkBVatjBAQE2LoaTYqvOW0YN+0YO20YN3NM9MjhHD16FHq9HjqdDtHR0bauTotmWALN2de75WtOG8ZNO8ZOG8bNnHN/OhM5qMjISCQmJppsCwoKgk5nOiOSXq9HTk6O1eXGxcVBRKAoCvr27WvVMYGBgWbnNQgICHD6JI+IyJHxE5rIDrm6uqJXL+suFAkNDbW63IKCAvXXbs+ePbVWj4iIHITTJXrl5eXIzc2FTqeDv78/WxuIiIioxXKKLOjnn3/GypUrsXfvXpw9e9bksW7dumHYsGF44IEH2F9vA5bmg7t48aLF/aztgkxKSlK7H319rbt611L3Y1ZWllXHEhEROSqHTvRSUlJw33334bffflO3iYjJPn/99Rf++usvfPLJJxg/fjw++ugj+Pn5NXdVWyzj+eAMevfubYOaEBERtTwOu9ZtcnIyhg4dit9++w0iov5VZ9gmIvjf//6HUaNGoaCgoLmrS0RERNTsHDbRu++++3D+/HmICFxcXDB+/HisXr0ahw4dwqlTpxAfH4/vv/8eTzzxBHx9faEoCkQEhw4dwrPPPmvr6pMdagnzwRERUcvikF23+/fvx2+//QZFURASEoLNmzdj8ODBZvv17t0bt9xyC55//nncdtttOHjwIEQEn376KRYtWoSgoCAb1J7sUUuZD46IiFoWh/xW27Ztm3p72bJlFpM8Y2FhYVi/fj26du0KvV6PyspK/PLLLxg/fnxTV7XFa4r54Bp7LjiA88EREZFzstk327Zt23DFFVega9eu9T723Llz6u2xY8dadUxERAT69OmDI0eOQFEUnD9/vt7npfprivngvLy81LngIiIiGlK9Fic0NFSNHVmPcdOGcdOOsdOGcTNns0Rv//79GDduHJ555hm89NJL8PT0tPpYFxcX9XZZWRm8vLysOq6srEy9zReB42Jypx1jpw3jpg3jph1jpw3jZs6m2U5paSneeustdO/eHevXr7f6uM6dO6u3N2zYYNUxCQkJOHbsmMUyiIiIiJyRzRK9K664Ai4uLhARnD9/HhMmTMCoUaNMkrGaGHfXzpkzB1u3bq11/+PHj+Ouu+5S77u7u2PUqFHaK09ERETkAGyW6E2ZMgUHDhzAkCFDAFTNc7djxw70798fc+bMqXWuu6ioKIwbNw4igoKCAowdOxbDhg3Du+++i++//x47d+7Ejz/+iA8//BB33303+vXrh1OnTgEAFEXBU089BR8fn2Z5nkRERES2ooilWYab2erVq/Hcc88hLS0NQFUyFhoairfffhtTp061eExWVhaGDRuGY8eOQVGUWss3XKEpIhg1ahQ2b96MVq1aNfrzcBaJiYno06ePej8hIcGuVrM4fvy4Oti2R48etq6OQ2HstGHctGHctGPstLHXuNnye9UurkiYPHkyTpw4gblz58LNzQ0igvT0dNx3330YOnQojhw5YnZMcHAwdu/ejfHjx5usjGHpD6i6+OKZZ57Bpk2bmOQ5uPz8fPWP6oex04Zx04Zx046x04ZxM2cXiR4AeHt745133kFcXBxuvPFGAFUtcXv37sXgwYPx+OOPIzc31+SYwMBArFmzBvHx8Xj22Wdx7bXXok2bNmjVqhU8PDzQtm1bjBw5EgsXLkRSUhKWLFkCd3d3Wzw9IiIiomZndzPEdu/eHVu3bsW3336LOXPmICkpCZWVlfj3v/+NdevW4c0338RDDz1kckzv3r3x1ltv2ajGRERERPbJblr0qhs3bhyOHj2KV155BZ6enhARZGdn45FHHkF0dDRiYmJsXUUiIiIiu2a3iR5QNQ3KK6+8gqNHj2LcuHEAqrpzDx48iGuuuQYPPPAALl68aNtKEhEREdkpu070DCIiIrBx40Zs27YNPXr0gIhAr9dj5cqV6N69O5YtWwa9Xm/rahIRERHZFYdI9AxuuOEGxMXF4e2334avry9EBHl5eXjqqacwcOBA7N6929ZVJCIiIrIbdncxRl1cXV0xb948TJ06FXPnzsVXX30FEUF8fDyGDx+OCRMmYMmSJWjbtq2tq0pEdkqv1yM7O9uq/XJycpCUlKTOxxkREWHVWtlBQUFcU5uIbM4uE72ysjLk5ubC1dUV/v7+cHFxMdsnLCwMq1atwiOPPILZs2erc+2tXbsWmzZtwssvv4ynn34arq52+RSJyIays7PRpk2bJj1HZmYmQkJCmvQcRER1sZufmzt27MDUqVPRqVMneHp6ol27dmjTpg3c3d0RFRWFJ5980uI6uEOGDMHBgwexfPlyBAYGQkRQWFiI559/Hn379sXPP/9sg2dDREREZAfExjIzM2Xs2LGi0+lEp9OJoihmf4bHXFxc5Omnn5by8nKLZWVnZ8vMmTPFxcXF5Ng777xTkpOTm/V55efnyyuvvCJ9+vQRb29vad26tQwePFiWLFkipaWlDSr7p59+knvuuUfCw8PF3d1dPDw8pHPnzjJp0iTZuXNng+uekJAgANS/hISEBpfZmCoqKtQ/qh/GrkpmZqbJa7wp/jIzM239NG2OrzftGDtt7DVutvxetWmil52dLb17964xwaue7Bn+veuuu2ot98CBA3L11VebHOvl5SULFy5scJJljeTkZOnUqZP6H+rl5SXu7u7q/QEDBkhOTk69y9Xr9fLwww+bvFg8PT3F09PTZNvTTz/doPrbe6JH1FBM9IioOdnye9WmXbdz5szB0aNH1fsdOnTAokWLsGvXLpw4cQJHjx7F1q1bMXfuXPj6+kJRFIgIvvnmG/z3v/+tsdxBgwZh7969WLFiBUJDQyEiKCkpwauvvoqePXti06ZNTfacKioqcOuttyI5ORlt27bFzz//jKKiIhQXF2Pt2rXw9fVFbGwspkyZUu+yV65ciY8//hgAcPfdd+PkyZMoLi5GcXExjh8/jttvvx0A8P777+Obb75p1OdF5EyCgoKQmZlZ55/x55PB0aNHrTo2KCjIBs+MiKiaZkspq8nIyBAXFxe1W3b06NFSVFRU4/7nzp2Tbt26qS17kZGRVp0nPz9fnnrqKXFzczNp4Vu2bFljPRUTn3zyiZqx79271+zxr776Sn38l19+qVfZw4cPFwDStWtXi93XZWVl0qVLFwEgEyZM0Pwc2KJHVMVSyx9b6oiovlpki9727duh1+shInBzc8OqVavg5eVV4/4dOnTAP//5T4gIAODUqVM4d+5cnefx9fXF+++/j8OHD2PEiBHq9pycnIY/CQs+//xzAMCIESNw9dVXmz0+YcIEdO7cGQDwxRdf1KvsCxcuAAD69etn8WpiNzc39O/fHwBQWFhYr7IdSV5eHnJzc5GXl2frqjgcxo6aE19v2jF22jBu5myW6J0/fx4AoCgK+vTpg+Dg4DqPGT58uMn91NRUq8/Xq1cvbN++Hf/73//QoUOHetXVWsXFxdizZw8A4KabbrK4j6IoGDNmDADgp59+qlf5Xbp0AQAcOXIEFRUVZo+Xl5fj8OHDAIDBgwfXq2xHcvLkSZw4cQInT560dVUcDmNHzYmvN+0YO20YN3M2S/RatWql3r58+bJVx5SWlprc1zJH3j333IPjx4+ra+c2pmPHjqlLsfXp06fG/QyPpaen16tl8dFHHwVQ1Zo5ceJEnDp1Sn3sxIkTuPfee3HmzBlcccUVePrpp7U8BSIiInIiNptN2NA6JSI4duwYEhMT0bt371qP2bBhg3pbURR06tRJ07k9PT3Rt29fTcfWJi0tTb3dvn37GvczfiwtLQ2BgYFWlX/rrbfi/fffx3PPPYcNGzZgw4YN8PT0BACUlJTA398fjz76KBYtWoTWrVtrfBbm4uPjUVRUVOs+kZGR8Pf3V+9XVlbi4MGDVpXfunVr9OjRw2RbSkoKMjIyLO6fm5urrlIQExODXr16wcfHR328tLRUnUC7LoGBgejatavJtlOnTlmdgPfr1w/u7u7q/cLCQosD+C0JDQ1FRESEybbjx48jPz/fquMHDRpkMpl4Xl5enb9iDbEzvG6MxcfHo6SkpM7zuri4YNCgQSbbLl68iKSkJKvqHRERgdDQUJNtsbGxKC8vr/NYd3d39OvXz2TbhQsXrBrGAQBdu3Y1e7/FxMTUuH9ubm6t5Z09exbp6elWnbtHjx4m78vy8nLExsZaday/vz8iIyNNtp05cwZZWVlWHR8VFWXyf15SUoL4+Hirjg0ODlY/rw1OnjxpVddYbm4ufH19TVYIyc/Px/Hjx606d1hYGMLDw022JSYm1vl5ZBAdHW1yPycnx+QHcm06duxotsLSkSNHzBocLHFzc8OAAQNMtmVkZCAlJcWqcxuG9xg7ePAgKisr6zzW09MTUVFRJttSU1Ot7gFrzs/y6pz5s/zMmTNWldUUbJbojRw5El5eXigpKYGIYNy4cfj2229rTPa2bduGOXPmQFEUAMCVV15pVXdvcyooKFBv1zbe0Pgx42Os8dRTT6Fbt26YMWMGMjMzTb6Yy8rKUFhYiEuXLlmdPFpDr9erLZU1MYydrH6cteXX55xSNS1QredoqnNrLbM5zi0iVv0/Wfq/aui5Dcdbo6bXijXHW9rHmudd17nrcz6t59ZSfm37NeR5N0bMrDm+ttea1nM3JObN9bwb+v9lSWVlpV2+R+raz1E/Txv73A2pR0PZLNHz8vLCc889h1deeQWKouD06dMYMGAARo0ahWuvvRZhYWHQ6/U4e/Ystm/fjj/++AMA1Jac1157zVZVt5ni4mLcf//9WLduHQYPHoxVq1apvxpjY2Px4osv4ssvv8SPP/6I7du3N1qrpU6nq3PNTkMCXv04a8uvzzkN51IUpcZ9murcWstsjnPXFg/jfWqrjzXntrQkoeF4a9T0WrHmeEv7WPO86zp3fc6n9dxayq9tv4Y878aImTXH1/R6a8i5GxLz5nreDf3/sqSm911jn7s5P8u1lumI57bluteK1PSTqxno9Xrce++92LhxozpHXk0fDMbVfPXVV7FgwYLmqqbVNm3ahNtuuw1AVRN/TYnWd999p44RjI+Pr3U8n7HHH38cH374Ibp3747Dhw/Dw8PD5PGSkhL0798fJ0+exJAhQ7B7925NzyMxMdGkTgkJCXV2qzenmJgY6PV66HQ6s64Zqh1jVz8XL140WxOXa9haj6837Rg7bew1brb8XrXphMk6nQ7r1q3Dm2++qXZnGrqWqv8BVf3ga9asscskDwDatWun3q5tPITxY8bH1KagoAD/+c9/AFQlfNWTPKBqbMasWbMAAL///jsyMzOtKpuIiIick826bg10Oh2ef/55PPbYY1i3bh1+++03daCvi4sLAgMDERUVheuvvx6333473NzcbF3lGvXs2RM6nQ56vR4JCQk1TrGSkJAAoGqgsbVj6U6ePKlOqXLFFVfUuF+3bt3U20lJSWatEURERNRy2DzRM2jdujUefPBBPPjgg7auimZeXl649tprsXv3bmzduhXz5s0z20dEsG3bNgDAjTfeaHXZxv37tV25ZXx1k6+vr9XlExERkfOxadetM5o+fToAYMeOHeoFJMbWr1+vXmY9bdo0q8vt0aOHOj3CJ598YnHC5MrKSrV7NyAgAN27d693/YmIiMh5MNFrZNOnT0dUVBREBHfddRe2b98OoOrCk/Xr1+Ohhx4CULVyxsiRI02OXblyJRRFgaIo2Llzp8ljnp6eamvnoUOHcOuttyI+Pl69hDsuLg4333wz9u7dC6BqGhZrr9JyNO3bt0eHDh1qnauQLGPsqDnx9aYdY6cN42bObrpunYWrqyu+//57jBgxAsnJyRg1ahS8vLyg1+vVFUAGDBiA1atX17vst99+G3/99Re2bt2q/hkmeDSexHPixImYP39+4zwhO8Q3sHaMHTUnvt60Y+y0YdzMsUWvCXTq1AlxcXFYsGAB+vTpA0VR4ObmhkGDBmHJkiXYv38/AgIC6l2up6cnfvjhB6xfvx633347OnTooF6R3LFjR9x1113YvHkzvvrqK6dtzSMiIiLr2XQevcai1+tx4cIFXLx4EeXl5QgJCUFYWJjFKUiobvY+jx5Rc+E8ekTUGGz5verQXbfffPMNvvzyS/z6669mS4m5urri6quvxh133IGHH36YSR8RERG1OA6Z6J08eRJTpkxRF1q21ChZXl6O3bt3Y/fu3Xj33Xfx4YcfqqtWkGMzXISi0+nMFu+m2jF21Jz4etOOsdOGcTNn0zF6Li4ucHFxgaurK3799Verjtm9ezeuvvpqHDx4UF01w3ClavU/oCoJTEtLw1133YUPP/ywKZ8ONZOSkhL1j+qHsaPmxNebdoydNoybOZsmetWXOKvLuXPncMcddyA3NxcATJI5oGruuDZt2sDFxcUsCaysrMQTTzxhdUJJRERE5OhsftWtIVmzxv3334+cnByTBG/YsGH4/vvvUVBQgKysLFy4cAElJSXYvXs3pk+frq4ooSgK9Ho9pk+frk5zQkREROTMbJ7oWWv//v349ddfoSgKRAQ6nQ7/+Mc/sGPHDtxyyy3w8vJS93VxccG1116Lzz77DD///DP8/f3Vx9LS0rBq1SobPAMiIiKi5uUwiZ5haS9Dd+zLL7+MJ554os7jhg8fjvXr16tduCKCjz/+uKmrS0RERGRzDpPo7dy5U+2y7dKlC15++WWrj73++usxefJkdSzf4cOHUVhY2CT1JCIiIrIXDpHoZWVlITk5GUDVWLtHHnmkXmP7AODxxx9Xb+v1esTExDRmFYmIiIjsjkMkepmZmQD+vrp2xIgR9S5j8ODB8PHxUe+fO3eucSpHREREZKccItHLyckxud+5c+d6l6HT6RAeHq7eN0zRQkREROSsHGJljOrLl/n5+Wkqp3Xr1urtoqKiBtWJbMfFxcXkX7IeY0fNia837Rg7bRg3cw6R6IWFhZncLyoqgq+vb73LMU7uuPat4xo0aJCtq+CwGDtqTny9acfYacO4mXOIrtsOHTqgbdu26v0LFy5oKse4C9h4bj0iIiIiZ2Q3LXrvvvuu1RMZJyQkIDIysl7l5+fnIzU1Vb1at2PHjvWuIxEREZEjsYtET0Tw008/Wb3/r7/+ijvvvLNe5zh06JB6LkVR0LVr13odT0RERORo7KLr1to58Qz7bdq0qd7n+P7779Xbvr6+6NKlS73LIPtw8eJF9Y/qh7Gj5sTXm3aMnTaMmzmbt+gZ5sarj3PnzmHLli0YO3asVftXVlaqy6ABHKzp6JKSkqDX66HT6RASEmLr6jgUxo6aE19v2jF22jBu5mya6CUlJWk+tj5TrHz55ZdITU1V72uZcJmIiIjI0dg00YuIiGiW83To0AGfffaZev/6669vlvMSERER2ZLNu26bw6hRo2xdBSIiIqJm1yISPSJqWSoqKhplmcOsrCyrtmkREBAAV1d+BBNR0+KnDBE5lVWrVmHWrFm4dOlSk5Tfq1evRinHz88Py5cvx5QpUxqlPCIiS+xiehUiosZQUVHRpEleY7p06RJmzZqFiooKW1eFiJwYEz0ichq5ubkOkeQZXLp0qVG6mImIasJEj4iIiMhJcYweETm1o0ePIjg4WNOxer0eOTk5iIuLU5dPHD58OHQ6bb+Rs7KyGm2MHxGRNZjokcOJiIhQv3Spflpi7IKDgxs0Q35oaCgCAwPVuIWGhjZi7ZxbS3y9NRbGThvGzRwTPXI4/KLVjrHThnHThnHTjrHThnEzxzF6RERERE6KiR4RERGRk2KiR0REROSkOEaPHE5sbCz0ej10Oh0GDBhg6+o4FMZOG8ZNG8ZNO8ZOG8bNHBM9cjjl5eXqG5nqh7HThnHThnHTjrHThnEzx0gQEREROSkmekREREROil23ROSUgr09AADK5UJIsUeDynItL1G7g6S4QHM5yuVCtV5ZRZcbVCciImsw0SMip5S+cFLVjfWLoG9gWf2Mbuv/+EJzOQH4u16uc1Y0rFJERFZwyETvxIkT2LVrF2JiYpCUlIS8vDwUFhbCx8cH/v7+6Ny5M6KjozFs2DB0797d1tUlIiIisgmHSvS+/vprvP/++9i3b5/JdhFRbyuKgp07d+Kzzz4DAPzf//0fnn76adx9993NWlciIiIiW3OIizHS09MxduxY3Hvvvdi3bx9ExCy5M/wZGPbZt28fxo8fj5tvvhlpaWm2qD4RERGRTdh9i15KSgpGjhyJpKQkiIia0FVP9iwxJH4igm3btmHo0KH49ddfERER0RxVJyIbClvwFQDg2LGjCAoKblBZsbGHjCZhHai5nOzsLPTs2atBdSEiqg+7TvRKS0sxevRonDlzBgDUBK9169a46667MHz4cPTp0wdBQUHw9vZGUVERsrOzER8fj127duHrr79Gfn6+elxSUhJGjx6NI0eOwN3d3cbPjrRyd3fnhJgataTYGa5qFQ8fKF6+DSrLxccfyv+PW0PKkqLLLepq25b0emtsjJ02jJs5RepqFrOh+fPnY/HixWrLnE6nw7x58zB//nx4e3vXeXxRUREWLVqEJUuWQK/Xqy2Czz//PN54442mrr7DSkxMRJ8+fdT7CQkJ6N27tw1rRGSdixcvok2bNibbMjMzERISYqMambL3+hFR07Dl96rdprwVFRX4+OOP1dY4FxcXrFu3Dm+++aZVSR4AeHt7Y/HixVi3bl3VL/H/X9bHH3+MysrKJn4GRERERLZlt4neb7/9hpycHABVXbbPPPMM7rjjDk1l3XHHHXjmmWfUMX25ubnYuXNnY1WViIiIyC7ZbaJnGJcnItDpdHjqqacaVN7TTz+ttuoZl09ERETkrOz2YoyLFy8CqGrN69SpE8LCwhpUXlhYGLp06YJTp05BURRkZWU1RjXJBi5cuKCOt2zbtq2tq+NQGDttGDdtGDftGDttGDdzdpvoGY/DCwwMbJQyAwICLJZPjuXcuXPqVVV8I9cPY6cN46YN46YdY6cN42bObrtuu3Xrpt5OT09vlDIzMjIslk9ERETkjOw20Rs6dCjc3d0hIjh//jxOnjzZoPJOnjyJs2fPAqiaZ2fo0KGNUU0iIiIiu2W3iZ6Pjw+mTp2q3l+4cGGDynvttdcAVI35mzp1Knx8fBpUHhEREZG9s9tEDwDefPNNhIWFQUSwZs0avPXWW5rKeeutt7BmzRooioJ27drhzTffbOSaEhEREdkfu070goODsW3bNrRr1w4igvnz52PcuHE4ceKEVccfP34ct99+O+bPnw8AaNeuHbZt24agoKCmrDYRERGRXbDbq26BqkmTAeC9997Dc889h5SUFGzatAmbNm3CoEGDTNa69fLyQnFxMbKyspCQkIBdu3bh4MGDAKrm4uvUqRPefvttZGVlqeXW5brrrmuy50ZERETU1Ow60Rs+fLg6wTEAdQkzADhw4ICayFlivISvoihISUnBhAkTrD63oiioqKjQUGsiIiIi+2DXiZ6BYfJDACaJn+Gx6hRFMduvpn2JiIiInJXdJ3qG5Kw+SRoTOiIiIiI7T/ReeeUVW1eB7FDXrl1NWnnJeoydNoybNoybdoydNoybOSZ65HAaa0m8loix04Zx04Zx046x04ZxM2fX06sQERERkXZM9IiIiIicFBM9IiIiIidl12P0iCyJiYmBXq+HTqdDdHS0ravjUBg7bRg3bRg37Rg7bRg3cw6b6F2+fBl//vknzp49i9zcXBQUFMDX1xcBAQGIiIjA4MGD4eHhYetqEhEREdmMQyV6paWl+Oqrr/Cf//wHBw8eRGVlZY37urq6YvDgwZg5cyYmTpyIVq1aNWNNiYiIiGzPYcbobdu2DVdccQUefPBBxMTEoKKiAiJS4195eTn279+PGTNm4IorrsDPP/9s66dARERE1KwcokXv9ddfx6uvvqqueGFY4qy2FTAMkyWKCFJTUzFmzBgsXLgQ8+fPb5Y6E1Hz0+v1ZtsuXrzYoPJycnKQlJSkTsIaEREBnU7bb+SsrCzNdSEi0sLuE70PP/xQnTjZOHnz9PTE4MGD0a9fPwQHB8Pb2xtFRUXIysrCkSNHcODAAZSUlJgcs2DBAgQFBeGRRx6x2fMhoqaTnZ1ttq137942qAkRkX2w60Tv7NmzmDNnjkmyFhYWhldffRUTJ06Er69vjccWFhbiq6++wmuvvYYLFy6oLYDPPPMMbr75ZoSHhzfX0yAiIiKyCbseo7dgwQKUlpaq96+//nocP34cM2fOrDXJAwAfHx/MnDkTx48fxw033KB2u5SWluLVV19t4poTEdXNz88PAQEBtq4GETkxu030Kioq8M0336gtcb1798aPP/6I1q1b16scX19fbN68GX369AFQ1Sq4cePGWq/YJSJqan5+fli+fDlcXe26Y4WIHJzdfsLs3bsXBQUFAKrG5i1duhRubm6aynJzc8PSpUsxevRoAEBBQQH27t2LoUOHNlp9icj2IiMjkZiYaLItKCjI7OKJrKws9OrVq0nrcvToUQQHB9f4eEBAAJM8Impydvspk5SUpN729/fHqFGjGlTeqFGjEBAQgNzcXADAmTNnmOg5KG9vb7UrnurH2WPn6ura5AmctYKDgxESEmLratiUs7/emhJjpw3jZs5uE73MzEwAVa15nTp1avB/mmFaBEOi15ApF8i2eBWldowdNSe+3rRj7LRh3MzZ7Rg9FxcX9XZ5eXmjlGk8Lk/rPFhEREREjsJuW/TatGkDoOriiZSUFJSXl2seowdUJYvJyclm5RNRyxMUFKT2GtTGMGGyscDAQKt+KAYFBWmuHxFRY7HbRK9bt27q7cLCQmzatAl33nmn5vI2bdqkXtxRvXwiall0Op3V4+dCQ0ObuDZERE3HbhO96OhoBAUFIScnByKCOXPmYNSoUfWeXgUA8vPzMXfuXHWqlsDAQERHRzdBrak5nD17Vh1sy4mv64ex04Zx04Zx046x04ZxM2e3A9UURcH48ePV/7CUlBSMGDECqamp9SonLS0NI0eORHJyslrWxIkTeUWOA0tPT8eFCxeQnp5u66o4HMZOG8ZNG8ZNO8ZOG8bNnN0megDwyiuvqCtgKIqC2NhY9OjRA6+88orJ9CuWJCcn49VXX0WPHj1w6NAhNbHz9fXFggULmrzuRERERLZmt123ABASEoL//ve/mDRpktoaV1RUhEWLFmHRokWIiIhA3759ERwcDG9vbxQVFSE7OxtHjhxBSkoKAKjHiQhcXFzwySef1DqJKREREZGzsOtEDwDuvfdeXLp0CbNmzUJFRYWatAFVrXaGhM6Y4XEA6v5ubm7417/+hbvvvrvZ6k5ERERkS3bddWvw0EMPYd++fejdu7eaxCmKUuM4O+PHRAR9+/bF/v378eCDDzZbnYmIiIhszSESPQAYOHAg4uLisHXrVtxzzz1o06YNRKTGvzZt2uDee+/FTz/9hMOHD2PAgAG2fgpEREREzcruu26ru/HGG3HjjTcCAFJSUpCSkoLc3FwUFhbCx8cHAQEBiIiIQEREhI1rSkRERGRbDpfoGWNCR0RERFQzh+m6JSIiIqL6sesWvS+++EK9PXr06AYtRZSeno6ffvpJvT9t2rQG1Y2IiIjI3tl1onffffepV8/+/PPPDUr0EhMTTcpjoue4evToYesqOCzGThvGTRvGTTvGThvGzZxdJ3rA3xMe22t5NSkoKMDSpUvx9ddfIykpCS4uLoiMjMSECRMwe/ZstGrVqkHl5+fn46OPPsJ3332Hv/76C/n5+QgJCUG3bt0wbNgwPPXUU/D392+cJ2NntKx3TFUYO20YN20YN+0YO20YN3N2n+g54pq0KSkpGD58OJKTkwEAXl5eKC0txYEDB3DgwAGsXr0a27dvR0BAgKbyd+zYgYkTJyIjIwMA0KpVK3h5eSE1NRWpqanYuXMnxo0bh/79+zfSMyIiIiJH1GIuxqi+WkZTqaiowK233ork5GS0bdsWP//8M4qKilBcXIy1a9fC19cXsbGxmDJliqby9+zZg7FjxyIjIwN33nkn/vzzT1y+fBm5ubkoKipCTEwM5s+fDz8/v0Z+ZkRERORo7L5Fr7EUFhaqt729vZvsPJ9//jni4+MBAF9//TWuvvpqAIBOp8P48eOh1+sxadIk/PDDD9i+fTtGjhxpddnFxcWYNm0aSkpKMHv2bHzwwQcmj3t5eeHKK6/ElVde2XhPyA6Vl5ert93c3GxYE8fD2GnDuGnDuGnH2GnDuJlrMYleXFyceltrl6k1Pv/8cwDAiBEj1CTP2IQJEzB//nwkJSXhiy++qFei9+WXX+LMmTMICwvDO++802h1djSxsbHQ6/XQ6XSIjo62dXUcCmOnDeOmDeOmHWOnDeNmrkV03SYlJeE///mPugZur169muQ8xcXF2LNnDwDgpptusriPoigYM2YMAJhM92INw3Qz99xzDzw8PBpQUyIiImoJbN6iN2PGDKv2e/fdd7Fq1SqryxURFBcXIykpCYcPH0ZlZaV6xe2IESO0VrdWx44dg16vBwD06dOnxv0Mj6WnpyMnJweBgYF1lm24mAMABg0ahLNnz2LRokX48ccfkZGRgYCAAERHR+ORRx7B2LFjG+HZEBERkaOzeaK3cuXKWi+OMFxEUd/Wr+rHG87h4+PTZHPopaWlqbfbt29f437Gj6WlpVmV6CUnJ6OsrAwAcObMGcyePRsFBQVo1aoVvL29kZmZic2bN2Pz5s148MEH1RbMxhAfH4+ioqJa94mMjDSZzqWyshIHDx60qvzWrVubzX2UkpKiXlVcXW5urpq0x8TEoFevXvDx8VEfLy0txZEjR6w6d2BgILp27Wqy7dSpU8jJybHq+H79+sHd3V29X1hYiKNHj1p1bGhoqNkSfsePH0d+fr5Vxw8aNAguLi7q/by8PJw8ebLWYwyx8/T0NHssPj4eJSUldZ7XxcUFgwYNMtl28eJFJCUlWVXviIgIszkxY2NjTcbW1MTd3R39+vUz2XbhwgWcO3fOqnN37drV7P0WExNT53G5ubnQ6XRmFzmdPXsW6enpVp27R48eJlM/lJeXIzY21qpj/f39ERkZabLtzJkzyMrKsur4qKgok//zkpISdSxxXYKDg9GlSxeTbSdPnkReXl6dx+bm5sLX1xc63d+dR/n5+Th+/LhV5w4LC0N4eLjJtsTExDo/jwyqd93l5OTg1KlTVh3bsWNHtG3b1mTbkSNHUFpaWuexbm5uGDBggMm2jIwMpKSkWHXuzp07m207ePAgKisr6zzW09MTUVFRJtsMMzJYozk/y6tz5s/yM2fOWFVWU7B5otfUDMmOiMDDwwOfffZZgyZerk1BQYF628vLq8b9jB8zPqY2ubm56u1FixbB398f69evx+233w43NzecPXsWc+fOxfr16/HJJ5+gZ8+eeOaZZzQ8C3N6vV5tqayJ8VXNxsdZW359ziki6vlq2qepzq21zOY4t4hY9f9k6f+qoec2HG+Nml4r1hxvaR9rnndd59ZyXH3PbUlDXisNed6NEbOGxK0h525IzJvreTf0/8uSyspKu36P1LSfo36eNva5G1KPhrKLRK+mD4P67mOJYaLiG2+8EY899hi6deumqRxbq/6C+fTTTzFu3Dh1W3h4ONauXYuTJ0/iyJEjePPNN/HEE0/A1bXh/8U6nc7kF7kllloP6zqmtv1qO6fhXIqi1LhPU51ba5nNce7a4mG8T231sebcxq2I1Y+3Rk2vFWuOt7SPNc+7rnNrOa6+57akIa+VhjzvxohZQ+LWkHM3JObN9bwb+v9lSU3vu8Y+d3N+lmst0xHP3ZB6NJQiWjOoRlJTU7aIoEuXLuqLbtWqVbjmmmusLlen08Hb2xutW7dulGTHGps2bcJtt90GoKqJv2/fvhb3++6779QkLT4+vtbxfAbx8fFqed26dauxi27VqlWYOnUqAGD//v246qqr6vs0kJiYaFKnhIQE9O7du97lNJWYmBheVaURY6cN46YN46YdY6eNvcbNlt+rNm/Rq96vXRNLfeD2pl27durt1NTUGhM947ESxsfUxnhcX21r+RlfUZySkqIp0SMiIiLnYNfTq4SHh6t/lgaP25uePXuqzbMJCQk17md4LCwszKoLMYCqgaa1XeBh0FwrgBAREZH9s+tELzk5GUlJSUhKSrI4+bC98fLywrXXXgsA2Lp1q8V9RATbtm0DANx44431Kt+w/7Fjx2rcx/gqIUtXbhEREVHLYdeJniOaPn06AGDHjh34448/zB5fv369epl1fad5uf/++wFUXTL+7bffmj2u1+uxZMkSAFVdvQMHDqxX+Y7C399f/aP6Yey0Ydy0Ydy0Y+y0YdwsEGpU5eXlEhUVJQCkffv28ssvv4iISGVlpaxbt05at24tAOSmm24yO/azzz4TAAJAduzYYbH8u+++WwBIUFCQbNiwQcrLy0VEJCUlRe699171+JUrV2p+DgkJCWo5ACQhIUFzWURERC2dLb9XbX4xhrNxdXXF999/jxEjRiA5ORmjRo2Cl5cX9Ho9Ll++DAAYMGAAVq9eran8lStXIjMzE7/99hvuvvtuuLu7w8vLy2SevVdeeUVtWSQiIqKWi123TaBTp06Ii4vDggUL0KdPHyiKAjc3NwwaNAhLlizB/v37ERAQoKlsb29v7NixA//9739x3XXXwdvbG4WFhWjfvj0mTJiAPXv24NVXX23cJ0REREQOyebz6JH9sfd59IiIiBxJi55Hj6i+zpw5o651W30NTqodY6cN46YN46YdY6cN42aOiR45nKysLHXmc76R64ex04Zx04Zx046x04ZxM8cxekREREROiokeERERkZNiokdERETkpJjoERERETkpJnpEREREToqJHhEREZGTYqJHRERE5KSY6BERERE5KSZ6RERERE7KIVfGKC4uRmpqKi5duoSSkhJoWa73uuuua4KaUXOIiopSl7ih+mHstGHctGHctGPstGHczDlMonfs2DF88skn+PHHH/HXX39Br9drLktRFFRUVDRi7ag5eXp62roKDoux04Zx04Zx046x04ZxM2f3iV5ZWRmeffZZ/Otf/4Jer9fUekdERETUEtl1oldRUYG7774bW7ZsURM8Q3MsEz4iIiKi2tl1ords2TJs3rwZiqJAURSICEQEffv2Rf/+/dGmTRt4e3vbuprUzAzjMhVFYTN9PTF22jBu2jBu2jF22jBu5uw20dPr9XjzzTfVBA8AxowZg/fffx/du3e3ce3IluLj46HX66HT6RAdHW3r6jgUxk4bxk0bxk07xk4bxs2c3SZ6+/fvR3Z2ttqaN3bsWHz77bfQ6TgjDBEREZE17DZrOnr0KIC/x+K9//77TPKIiIiI6sFuM6esrCz1dqdOnXDFFVfYsDZEREREjsduEz03NzcAVVfZtmnTxsa1ISIiInI8dpvode7cWb2dl5dnu4oQEREROSi7TfSGDh0KnU4HEUFSUhKKiopsXSUiIiIih2K3iV5ISAhuu+02AEB5eTm+/vprG9eIiIiIyLHYbaIHAG+//bY64eHLL7+M7OxsG9eIiIiIyHHYdaLXrVs3fP7559DpdDh//jxuuukmnD9/3tbVIiIiInIIdjthssHdd98NLy8vTJ06FQcPHkRUVBQeffRR3HvvvejXr5+69i21HMHBweoSN1Q/jJ02jJs2jJt2jJ02jJs5RQwzEtuhLl26qLfz8vLUq28N/4Fubm4IDAyEh4dHvcpVFAWnT59utHo6m8TERPTp00e9n5CQgN69e9uwRkRERI7Llt+rdt2il5ycrK51a1gKDfh7tYyysjKkp6fXu1xm+kRERNQS2HWiZ1A9MWtIombHDZhEREREjcquE73w8HC2vhERERFpZNeJXnJysq2rQHbo5MmT0Ov10Ol0iIyMtHV1HApjpw3jpg3jph1jpw3jZs6uEz0iS/Ly8tQ3MtUPY6cN46YN46YdY6cN42aOkSAiIiJyUkz0iIiIiJwUEz0iIiIiJ8VEj4iIiMhJMdEjIiIiclI2uep24cKFZtsWLFhg1X6NxdL5iIiIiJyJTRK9V1991WwiZEuJl6X9GgsTPSIiInJ2Nu+6be4lybgEGhEREbUUNpsw2dqEi4kZERERkTY2SfR27NjRqPtRyzJgwABbV8FhMXbaMG7aMG7aMXbaMG7mbJLoDRs2rFH3o5bFzc3N1lVwWIydNoybNoybdoydNoybOZuP0SMiIiKipsFEj4iIiMhJ2exiDCKt8vPz1dutW7e2YU0cD2OnDeOmDeOmHWOnDeNmjokeOZzjx49Dr9dDp9MhOjra1tVxKIydNoybNoybdoydNoybOXbdEhERETkpJnpEREREToqJHhEREZGTYqJHRERE5KSY6BERERE5KSZ6RERERE6KiR4RERGRk2KiR0REROSkmOgREREROSmujEEOJywsDCICRVFsXRWHw9hpw7hpw7hpx9hpw7iZY6JHDic8PNzWVXBYjJ02jJs2jJt2jJ02jJs5dt0SEREROSkmekREREROyqG7bs+fP4+kpCTk5eWhsLAQPj4+8Pf3R+fOndGhQwdbV4+IiIjIphwu0fvll1+wYsUK7Nq1C+np6TXuFxYWhuuuuw4zZszADTfc0Iw1pKaWmJioDrbt3bu3ravjUBg7bRg3bRg37Rg7bRg3cw6T6P3xxx+YOXMmEhISAAAiUuv+Fy5cwLp167Bu3Tr07t0b//nPf/B///d/zVFVamJFRUXQ6/XQ6TjyoL4YO20YN20YN+0YO20YN3MOEYl33nkHQ4YMQUJCgprgKYpS4+XTxo+JCBISEjBkyBAsXry42epMREREZGt236K3aNEivPLKK2pTrKIo6u1OnTqhT58+CAoKgre3N4qKipCdnY34+HgkJycDgJrw6fV6vPTSS6ioqMDLL79sw2dERERE1DzsOtHbv38/Xn31VQBQEzw/Pz/MmTMH06ZNq3W+nLNnz+Lzzz/He++9h0uXLqnHL1y4EDfeeCOuuuqqZnoWRERERLZh11238+bNg16vV+9fe+21OHnyJF566aU6J0UMDw/Hyy+/jBMnTuCaa65RWwErKysxb968pq46ERERkc3ZbaKXkpKCvXv3qi1xPXv2xM8//4yQkJB6ldOmTRv88ssv6NWrl7ptz549SElJaewqExEREdkVu0309u/fDxFRW+Lef/99eHh4aCrLw8MDS5cuNblSd9++fY1VVSIiIiK7ZLeJXmpqqnrb398fo0aNalB5N954IwICAtT7Fy5caFB5RERERPbObhO98vJyAFCvrq1pKhVrGcoxKCsra1B5RERERPbObhO9sLAw9bYh6Wso43KMyyciIiJyRnY7vcrgwYMBVE14nJSUhLKyMrRq1UpzeaWlpUhKSjIrnxxPdHS0ravgsBg7bRg3bRg37Rg7bRg3c3bbote7d2/1Stni4mJs2LChQeVt2LABRUVFUBQFPXv25Bp4RERE5PTsNtEDgIULF6q3586di/T0dE3lXLhwAXPn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tBS+vr6Neh5bc/hsKDQ0FKGhobauBhERETUSS2PxGru1zVJ57u7ujXoOe+DwiR61PK1bt4Zer+eFNRowdtowbtowbqSVr68vAgICTLpv4+Pj0bVr11qPq89rLi4uzuR+QEBAo7ca2gO7TvQaur4tOacePXrYugoOi7HThnHThnEjrRRFwcCBA7F9+3Z12969e3HHHXfUelx9XnP79u0zuT9o0CCnHM9v1z+zOnTogNtuuw0bNmyw2F9PREREzik6Otrk/qpVqxotFygrK8OXX35Z6/mchV0nehUVFdiyZQvGjx+Ptm3b4vHHH8cff/xh62oRERFRE5s4caLJ/fT0dKxatapRyl61apXJZMmWzucs7DrRMxAR5Obm4t///jeuueYa9OzZE2+99RbOnz9v66oRERFRE4iKisLQoUNNts2dOxcXLlxoULlpaWmYM2eOybbrrrvOKZc/A+w80evUqZPJChdAVdJ34sQJzJ8/H506dcINN9yA1atXo6SkxJZVpWaUkpKCpKQkpKSk2LoqDoex04Zx04Zxo4Z67rnnTO7n5ubi3nvvVZc5ra6u11xxcTHGjx+PvLy8Ws/jTOw60Ttz5gx27dqF+++/H76+vmbLmun1evz666+YNm0awsLC8MADD2DXrl02rjU1tYyMDPWP6oex04Zx04Zxo4YaO3asWZfq77//jtGjRyMtLc1s/9pec2lpaRg9ejR+//13k+2TJk3CzTff3LgVtyN2negBwNChQ/Hpp5+qffOjR49WL5s2buUrKCjAypUrcf3116NLly549dVXcfr0aVtWnYiIiBpo2bJlaNeuncm233//Hb1798aKFSvqvECjrKwMK1asQO/evc2SvHbt2uGDDz5o9DrbE7tP9Aw8PDwwadIk/Pjjjzh37hzefvtt9O7d22LXbnJyMl5//XVERkaqiWJ+fr4tq09EREQaBAUFYevWrSZr3QNAXl4eHnjgAYSHh2PevHnYuHEjzp07h+zsbJw7dw4bN27EvHnzEB4ejgceeMCsuzYgIABbt25FUFBQMz6b5mfX8+jVJCwsDPPmzcO8efMQGxuLlStXYu3atbh48SIA06Rv79692Lt3L5544gmMGzcO06ZNw4033uiUc+UQERE5o6ioKOzatQtjxowx67LNyMjAkiVL6lVeu3btsHXr1kZfP9ceOUyLXk0GDBiAf/7z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fjymTJkCoGwcn9ls1m7NtmnTBj/88ANOnTrFAbVERPSrHDt2DC1btkTfvn2xatUqex8OOSj26N2Di4sLxo8fjw4dOuD27duYNm0ahg0bhmvXrkEpBYPBAJPJhPj4eGRlZaFNmza4desWB9QSEdGvEhYWhpMnT2ohj/0uVBHYo/cLzp49i7Fjx2L79u0oKipCREQEfH194ebmhrNnzyI7Oxt169bF7t27ERQUZO/DJSKiRxALJVNFYdD7FS5evIgVK1Zg9uzZuH79urbd2dkZISEhWLt2LYKDg+14hERERER3YtD7DU6fPo0dO3bg3Llz0Ov1iIqKQtu2bVG7dm17HxoRERHRHRj0iIiIiBwUBwT8Rta5mBmZiIiIqjL26BERERE5KPboERERETkoBj0iIiIiB8WgR0REROSgGPSIiIiIHBSDHhEREZGDYtAjIiIiclAMekREREQOikGPiIiIyEEx6BERERE5KAY9IiIiIgfFoEdERETkoBj0iIiIiBwUgx4RERGRg2LQIyIiInJQDHpEREREDopBj4iIiMhBMegREREROSgGPSIiIiIHxaBHRERE5KAY9IiIiIgcFIMeERERkYNi0CMiIiJyUAx6RERERA6KQY+IiIjIQTHoERERETkoBj0iIiIiB8WgR0REROSgGPSIiIiIHBSDHhEREZGDYtAjIiIiclAMekREREQOikGPiIiIyEH9HxasZPbuwU1UAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 600x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 1, figsize=get_figsize(nrows=1, ncols=1))\n",
    "labels = per_seed_results.keys()\n",
    "ax.boxplot(per_seed_results.values(), labels=labels)\n",
    "ax.set_xticklabels(labels, rotation=45, ha='right')\n",
    "ax.set_ylabel(\"Overlap in top 5%\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "env",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
