{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import os\n",
    "import json \n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "def get_list(root_dir):\n",
    "    child_dirs = [d for d in os.listdir(root_dir) if os.path.isdir(os.path.join(root_dir, d))]\n",
    "    result_list = []\n",
    "\n",
    "    for run_dir in child_dirs:\n",
    "        filename = root_dir + '/' + run_dir + '/test_results.json' \n",
    "        with open(filename, \"r\") as file:\n",
    "            result_dict = json.load(file)\n",
    "        result_list.append(result_dict['auprc'])\n",
    "\n",
    "    return result_list\n",
    "\n",
    "\n",
    "def get_list_DAG(root_dir):\n",
    "    child_dirs = [d for d in os.listdir(root_dir) if os.path.isdir(os.path.join(root_dir, d))]\n",
    "    result_list = []\n",
    "\n",
    "    for run_dir in child_dirs:\n",
    "\n",
    "        sub_dir = root_dir + '/' + run_dir\n",
    "        sub_child_dirs = [d for d in os.listdir(sub_dir) if os.path.isdir(os.path.join(sub_dir, d))]\n",
    "\n",
    "        filename = root_dir + '/' + run_dir + '/' + sub_child_dirs[0]+ '/'   + '/test_results.json' \n",
    "        with open(filename, \"r\") as file:\n",
    "            result_dict = json.load(file)\n",
    "        result_list.append(result_dict['auprc'])\n",
    "\n",
    "    return result_list\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "SDE = [0.0500958262517118,\n",
    " 0.05102905149917744,\n",
    " 0.050812627682081876,\n",
    " 0.052362554944149875,\n",
    " 0.05266473845938723]\n",
    "\n",
    "SDE_MLP = [0.06605525268385362,\n",
    " 0.06967626213563775,\n",
    " 0.0683144634977822,\n",
    " 0.05838392575631823,\n",
    " 0.04322580293045744]\n",
    "\n",
    "BICYCLES = [0.049708860193607214,\n",
    " 0.05983025191667639,\n",
    " 0.05338760658658187,\n",
    " 0.06136428295106645,\n",
    " 0.04998438194053555]\n",
    "\n",
    "\n",
    "methods = [\"SDE_sigmoid\"]*len(SDE) + [\"SDE_MLP\"]*len(SDE_MLP) + [\"BICYCLES\"]*len(BICYCLES) \n",
    "\n",
    "values = list(SDE) + list(SDE_MLP) + list(BICYCLES)\n",
    "\n",
    "df = pd.DataFrame({\"Method\": methods, \"AUPRC\": values})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/scratch/ipykernel_779024/3729633118.py:4: FutureWarning: \n",
      "\n",
      "Passing `palette` without assigning `hue` is deprecated and will be removed in v0.14.0. Assign the `y` variable to `hue` and set `legend=False` for the same effect.\n",
      "\n",
      "  sns.boxplot(\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAArIAAAGGCAYAAACHemKmAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABVL0lEQVR4nO3dd1QU598F8Lu0BalKF+kqKPZeolhQTFQ0sWGJYo8lYiyJJbYYg5qo0RhbVNBgJUbFrtjFGFtsiWIBC3ZQmgVQnvcP390fyy5NgWXgfs7Zozs75TszOzuXmWdmZEIIASIiIiIiidHRdgFERERERO+DQZaIiIiIJIlBloiIiIgkiUGWiIiIiCSJQZaIiIiIJIlBloiIiIgkiUGWiIiIiCSJQZaIiIiIJIlBloiIiIgkiUGWisSPP/4INzc36OrqolatWtouhyhHAQEBcHFxea9hW7RogRYtWhRoPSXZhyxrqZDJZJg+fbpWpl0cl++RI0cgk8lw5MgRbZdSaIYPH442bdpou4wi899//0FPTw9Xrlwp8mkzyJZSISEhkMlkypehoSEqV66MkSNH4vHjxwU6rf379+Prr79G06ZNERwcjB9++KFAx08ll+L7OWjQII2fT548WdlPXFxcEVdXMihCReZXuXLl0KhRI6xbt05rdb148QIzZ85EjRo1UKZMGZibm6NZs2ZYu3YtND1ZPXP9enp6KFeuHOrWrYvAwED8999/av3fvn1bbb4zv2bPnp1rjSdOnMDHH38MBwcHGBoawsnJCR07dsT69esLZBlo2w8//IBt27Zpbfqa9lPly5eHr68vFi1ahOTk5Pce98mTJzF9+nQkJCQUXMH/LyYmBitXrsSkSZM0fn716lXl/GQ3fRcXF3To0EHjZ2fPnoVMJkNISIiy2/Tp01WWVZkyZVC1alV8++23SEpKUvaXdZnq6enBwcEBAQEBuH//vsbpHTlyBJ999hns7OxgYGAAGxsbdOzYEX/++aeyn6pVq6J9+/aYOnVqLkun4OkV+RSpWPnuu+/g6uqK169f48SJE1i6dCl2796NK1euoEyZMgUyjUOHDkFHRwerVq2CgYFBgYyTSg9DQ0Ns2bIFS5YsUfv+bNiwAYaGhnj9+rWWqis5Ro0ahfr16wMA4uPjsWnTJvTp0wcJCQkYMWJEkdby+PFjtG7dGlevXoW/vz9GjhyJ169fY8uWLejXrx92796NdevWQVdXV2W4Nm3aoG/fvhBCIDExERcvXsSaNWuwZMkSzJkzB2PGjFGbVs+ePfHJJ5+oda9du3aONYaFhaFHjx6oVasWAgMDUbZsWcTExODYsWP47bff0KtXL2W/r169gp6e9Ha3P/zwA7p27YrOnTtrtQ7Ffio9PR2PHj3CkSNHMHr0aMyfPx/h4eGoUaNGvsd58uRJzJgxAwEBAbCwsCjQehcuXAhXV1e0bNlS4+ehoaGws7PD8+fP8ccff2T7h/r7WLp0KUxMTJCSkoL9+/dj1qxZOHToECIjIyGTyZT9Zd73nzp1CiEhIThx4gSuXLkCQ0NDZX/Tpk3Dd999h0qVKmHo0KFwdnZGfHw8du/ejS5dumDdunXK7/oXX3yBTz75BLdu3YK7u3uBzVOuBJVKwcHBAoA4c+aMSvcxY8YIAGL9+vUfPI0XL14IIYTo37+/MDY2/uDxKWRkZIiXL18W2PhIVUpKirZLUAIgOnfuLHR0dMS2bdtUPouMjBQARJcuXQQA8fTp0wKbbr9+/YSzs/N7Devt7S28vb0LrJbCdvjwYQFAhIWFqXRPTU0VDg4OokmTJoU6fU3L2tfXV+jo6Ijt27er9T9u3DgBQMyePVulOwAxYsQItf7j4uJE48aNBQCxa9cuZfeYmBgBQPz444/vVXfVqlWFl5eXSE1NVfvs8ePH7zXOwvAh32VjY2PRr1+/Aq1HiP995w4fPpxjf9ntp4QQ4uDBg8LIyEg4Ozu/1/7gxx9/FABETExMvofNSVpamrCyshLffvutxs8zMjKEi4uLGDNmjPj0009FixYtNPbn7Ows2rdvr/GzM2fOCAAiODhY2W3atGkafwc/++wzAUCcPHlSCJH9Mv3mm28EALFp0yZlt7CwMAFAdO3aVaSlpanVsXfvXrFjxw6VeS9btqyYMmWKxroLC5sWkIpWrVoBeHdqRCE0NBR169aFkZERypUrB39/f9y7d09luBYtWqBatWo4d+4cmjdvjjJlymDSpEmQyWQIDg7GixcvlKcyFKdD3rx5g5kzZ8Ld3R1yuRwuLi6YNGkSUlNTVcatOMWyb98+1KtXD0ZGRli+fLnylOjmzZsxY8YMODg4wNTUFF27dkViYiJSU1MxevRo2NjYwMTEBP3791cbd3BwMFq1agUbGxvI5XJUrVoVS5cuVVsuihpOnDiBBg0awNDQEG5ubli7dq1avwkJCfjqq6/g4uICuVyOChUqoG/fviqnvlNTUzFt2jRUrFgRcrkcjo6O+Prrr9Xq0+T48ePo1q0bnJyclMN+9dVXePXqlVq/165dQ/fu3WFtbQ0jIyN4eHhg8uTJys8Vp6P+++8/9OrVC2XLlsVHH32Ur/Vz9uxZ+Pr6wsrKCkZGRnB1dcWAAQNU+tm4cSPq1q0LU1NTmJmZoXr16li4cGGu8woADg4OaN68udrp2nXr1qF69eqoVq2axuHCwsKU31srKyv06dNH46mzbdu2oVq1ajA0NES1atWwdetWjePLyMjAzz//DC8vLxgaGsLW1hZDhw7F8+fPc52HX375BV5eXihTpgzKli2LevXq5en085MnTzBw4EDY2trC0NAQNWvWxJo1a1T6UZwi/+mnn7BixQrl+qpfvz7OnDmT6zSyY2BggLJly6odSczr9wIAlixZAi8vL8jlcpQvXx4jRozI9VTuqVOnsG/fPgQEBMDPz0/t86CgIFSqVAlz5szR+J3PytLSEhs3boSenh5mzZqVa/95devWLdSvX1/jWSYbGxuV91nbyCq2u+vXr6NPnz4wNzeHtbU1pkyZAiEE7t27h06dOsHMzAx2dnaYN2+eyvgUp4dv376t0j2vbU9/+uknNGnSBJaWljAyMkLdunXxxx9/qNX84sULrFmzRvnbHRAQoPz8/v37GDBgAGxtbSGXy+Hl5YXVq1erTSs2NhadO3eGsbExbGxs8NVXX+Xpdy43rVq1wpQpU3Dnzh2EhoYqu1+6dAkBAQFwc3ODoaEh7OzsMGDAAMTHxyv7mT59OsaPHw8AcHV1Vc6fYnnmdb+gyYkTJxAXFwcfHx+Nn0dGRuL27dvw9/eHv78/jh07htjY2PdcCrnTtE/XpFmzZgDefa8VpkyZgnLlymH16tXQ19dXG8bX11el+YO+vj5atGiB7du3F0TpeSa9cx1UqBRfYktLSwDArFmzMGXKFHTv3h2DBg3C06dP8csvv6B58+b4559/VE7JxMfH4+OPP4a/vz/69OkDW1tb1KtXDytWrMDp06excuVKAECTJk0AAIMGDcKaNWvQtWtXjB07Fn///TeCgoJw9epVtTARFRWFnj17YujQoRg8eDA8PDyUnwUFBcHIyAgTJkzAzZs38csvv0BfXx86Ojp4/vw5pk+frjx14urqqtKGZ+nSpfDy8oKfnx/09PSwY8cODB8+HBkZGWqnU2/evImuXbti4MCB6NevH1avXo2AgADUrVsXXl5eAICUlBQ0a9YMV69exYABA1CnTh3ExcUhPDwcsbGxsLKyQkZGBvz8/HDixAkMGTIEVapUweXLl7FgwQJcv3491zZpYWFhePnyJYYNGwZLS0ucPn0av/zyC2JjYxEWFqbs79KlS2jWrBn09fUxZMgQuLi44NatW9ixY4faDr1bt26oVKkSfvjhB2X7w7ysnydPnqBt27awtrbGhAkTYGFhgdu3b6u0nTpw4AB69uyJ1q1bY86cOQDetRGLjIxEYGBgjvOq0KtXLwQGBiIlJQUmJiZ48+YNwsLCMGbMGI3NCkJCQtC/f3/Ur18fQUFBePz4MRYuXIjIyEiV7+3+/fvRpUsXVK1aFUFBQYiPj0f//v1RoUIFtXEOHTpUOd5Ro0YhJiYGixcvxj///IPIyEiNP/QA8Ntvv2HUqFHo2rUrAgMD8fr1a1y6dAl///23yunnrF69eoUWLVrg5s2bGDlyJFxdXREWFoaAgAAkJCSoLbv169cjOTkZQ4cOhUwmw9y5c/HZZ58hOjo629oyS05OVv6x9ezZM6xfvx5XrlzBqlWrVPrL63Y7ffp0zJgxAz4+Phg2bBiioqKwdOlSnDlzJsfltWPHDgBA3759NX6up6eHXr16YcaMGYiMjMw2MGTm5OQEb29vHD58GElJSTAzM1N+9vLlS43tqy0sLHJsDuDs7IyDBw8iNjZW4/clL3r06IEqVapg9uzZ2LVrF77//nuUK1cOy5cvR6tWrTBnzhysW7cO48aNQ/369dG8efP3mk5WCxcuhJ+fH3r37o20tDRs3LgR3bp1w86dO9G+fXsAwO+//45BgwahQYMGGDJkCAAoTxc/fvwYjRo1gkwmw8iRI2FtbY09e/Zg4MCBSEpKwujRowG8+w63bt0ad+/exahRo1C+fHn8/vvvOHToUIHMx+eff45JkyZh//79GDx4MIB3vzfR0dHo378/7Ozs8O+//2LFihX4999/cerUKchkMnz22We4fv06NmzYgAULFsDKygoAYG1tDSB/+4WsTp48CZlMlm3TlHXr1sHd3R3169dHtWrVUKZMGWzYsEEZrAta1n16dhQhvmzZsgCAGzdu4Nq1axgwYABMTU3zPL26deti+/btattZoSrS479UbChOL0RERIinT5+Ke/fuiY0bNwpLS0thZGQkYmNjxe3bt4Wurq6YNWuWyrCXL18Wenp6Kt29vb0FALFs2TK1afXr10+tacGFCxcEADFo0CCV7orThocOHVJ2c3Z2FgDE3r17VfpVnJ6qVq2aymmPnj17CplMJj7++GOV/hs3bqx2ik3TKSlfX1/h5uam0k1Rw7Fjx5Tdnjx5IuRyuRg7dqyy29SpUwUA8eeff6qNNyMjQwghxO+//y50dHTE8ePHVT5ftmyZACAiIyPVhs2t5qCgICGTycSdO3eU3Zo3by5MTU1VumWuQ4j/nY7q2bOnSj95XT9bt27N9tSfQmBgoDAzMxNv3rzJcb40wf+fLn727JkwMDAQv//+uxBCiF27dgmZTCZu376tdkotLS1N2NjYiGrVqolXr14px7Vz504BQEydOlXZrVatWsLe3l4kJCQou+3fv18AUPmuHD9+XAAQ69atU6lv7969at2zNi3o1KmT8PLyyve8//zzzwKACA0NVXZLS0sTjRs3FiYmJiIpKUkI8b9T5JaWluLZs2fKfrdv3y4AqJz600SxHWV96ejoqG37ef1ePHnyRBgYGIi2bduKt2/fKvtbvHixACBWr16t7Jb11Hfnzp0FAPH8+fNsa/7zzz8FALFo0SJlN8V3JTuBgYECgLh48aIQ4n/LLbvXX3/9lf1CE0KsWrVKABAGBgaiZcuWYsqUKeL48eMq85u5tmnTpinfK76zQ4YMUXZ78+aNqFChgpDJZCrNJp4/fy6MjIxUTvErfr+znhbXdMpeU9OCrL8haWlpolq1aqJVq1Yq3bNrWjBw4EBhb28v4uLiVLr7+/sLc3Nz5fgV3+HNmzcr+3nx4oWoWLHiBzctUDA3Nxe1a9fOdt6EEGLDhg1qv985NS3I635Bkz59+ghLS0uNn6WlpQlLS0sxefJkZbdevXqJmjVrqvX7vk0LoqKixNOnT0VMTIxYvny5kMvlwtbWVtnUT9O+/48//hDW1tZCLpeLe/fuCSH+9/uxYMGCXOc5s/Xr1wsA4u+//87XcB+CTQtKOR8fH1hbW8PR0RH+/v4wMTHB1q1b4eDggD///BMZGRno3r074uLilC87OztUqlQJhw8fVhmXXC5H//798zTd3bt3A4DaxRdjx44FAOzatUulu6urK3x9fTWOq2/fvipHdxo2bAghhNrp7YYNG+LevXt48+aNspuRkZHy/4mJiYiLi4O3tzeio6ORmJioMnzVqlWVp1+Ad3+9e3h4IDo6Wtlty5YtqFmzJj799FO1OhUN7cPCwlClShV4enqqLFfFKaCsyzWrzDW/ePECcXFxaNKkCYQQ+OeffwAAT58+xbFjxzBgwAA4OTlprCOzL774QuV9XteP4sjmzp07kZ6errFeCwsLvHjxAgcOHMhxvnJStmxZtGvXDhs2bADw7uhjkyZN4OzsrNbv2bNn8eTJEwwfPlzlooX27dvD09NTWfvDhw9x4cIF9OvXD+bm5sr+2rRpg6pVq6qMMywsDObm5mjTpo3KOqtbty5MTExyXGcWFhaIjY3N92n+3bt3w87ODj179lR209fXx6hRo5CSkoKjR4+q9N+jRw/l0RTgf6cKM38/czJ16lQcOHAABw4cwKZNm9CzZ09MnjxZpQlIXr8XERERSEtLw+jRo6Gj87/dzODBg2FmZqa2fWemuBI9p6NAis8yX42dGxMTE5XxKwwZMkQ535lfWb8DWQ0YMAB79+5FixYtcOLECcycORPNmjVDpUqVcPLkyTzVlPkiH11dXdSrVw9CCAwcOFDZ3cLCQu135kNl/g15/vw5EhMT0axZM5w/fz7XYYUQ2LJlCzp27AghhMr24Ovri8TEROV4du/eDXt7e3Tt2lU5fJkyZZRHeAuCiYmJyjrNPG+vX79GXFwcGjVqBAB5mr+s48htv5BVfHy8ynaY2Z49exAfH6+yTffs2RMXL17Ev//+m6facuPh4QFra2u4urpi6NChqFixInbt2qV28XbmfX/Xrl1hbGyM8PBw5dkFxbaVn6OxwP+O6BblXWTYtKCU+/XXX1G5cmXo6enB1tYWHh4eyh3PjRs3IIRApUqVNA6b9dSgg4NDnu9KcOfOHejo6KBixYoq3e3s7GBhYYE7d+6odHd1dc12XFmDmiKUODo6qnXPyMhAYmKi8jRLZGQkpk2bhr/++gsvX75U6T8xMVEl4GSdDvBuo83cRvLWrVvo0qVLtrUC75br1atXlaexsnry5EmOw9+9exdTp05FeHi4WvtMxY+sYqeXXfvRrLIu37yuH29vb3Tp0gUzZszAggUL0KJFC3Tu3Bm9evWCXC4H8O5+ips3b1bepqht27bo3r072rVrl6faFHr16oXPP/8cd+/exbZt2zB37lyN/Slqy9z8RMHT0xMnTpxQ6U/T99vDw0Nlp3fjxg0kJiaqtX1UyGmdffPNN4iIiECDBg1QsWJFtG3bFr169ULTpk2zHUZRX6VKlVSCIABUqVJFpX6FrN9PxQ4lL214AaB69eoqp+m7d++OxMRETJgwAb169YK1tXWevxfZrQMDAwO4ubmp1Z6ZYseZnJyc7dXkeQm7WaWkpGgcplKlSnlqnqCJr68vfH198fLlS5w7dw6bNm3CsmXL0KFDB1y7di3b74uCpt8uQ0ND5anuzN0zt/H8UDt37sT333+PCxcuqLRX1fRHblZPnz5FQkICVqxYgRUrVmjsR7E93LlzBxUrVlQbr6Zt832lpKSoLOdnz55hxowZ2Lhxo9p2mVsIVcjPfkEToeH2cMC7601cXV0hl8tx8+ZNAO+aa5QpUwbr1q3L960pNa2vLVu2wMzMDPr6+qhQoUK2dw9Q7PsTExOxevVqHDt2TPmbDUDZLCC/tzhTzHtevksFhUG2lGvQoAHq1aun8bOMjAzIZDLs2bNH7TY3wP+OcChk/is2r/L6Zc9p3Jpqy6m7YkO7desWWrduDU9PT8yfPx+Ojo4wMDDA7t27sWDBAmRkZORrfHmVkZGB6tWrY/78+Ro/zxrAM3v79i3atGmDZ8+e4ZtvvoGnpyeMjY1x//59BAQEqNWcV9kt39zWj0wmwx9//IFTp05hx44d2LdvHwYMGIB58+bh1KlTMDExgY2NDS5cuIB9+/Zhz5492LNnD4KDg9G3b1+1C5dy4ufnB7lcjn79+iE1NRXdu3fP1zx+iIyMDNjY2GR7X9Xs/igB3gXPqKgo7Ny5E3v37lXeSmzq1KmYMWNGgdVYUN/PzFq3bo2dO3fi9OnTyraTQOHupKpUqYJt27bh0qVL2bYJvXTpEgDketQ0sytXrkBXVzfHP4rfV5kyZdCsWTM0a9YMVlZWmDFjBvbs2YN+/frlOJymdZaX9Zjd8n/79m2utR4/fhx+fn5o3rw5lixZAnt7e+jr6yM4ODhPFyAqfmP69OmT7fy9z+2w3kdsbCwSExNV/rDq3r07Tp48ifHjx6NWrVowMTFBRkYG2rVrl6ffx/zuF7KytLTU+MdjUlISduzYgdevX2v843n9+vWYNWuWct0aGhpmezGjIlxnPuOk0Lx5c7U/hDTJvO/v3LkzPvroI/Tq1QtRUVEwMTGBp6cnAODy5cu5jiszxbznpYaCwiBL2XJ3d4cQAq6urqhcuXKBjtvZ2RkZGRm4ceOG8ggT8O4igoSEBI2njAvajh07kJqaivDwcJUjI7md2s+Ju7t7rk82cXd3x8WLF9G6det8B4LLly/j+vXrWLNmjcrFMFlP27u5uQHAez9lJb/rp1GjRmjUqBFmzZqF9evXo3fv3ti4caPy1KmBgQE6duyIjh07IiMjA8OHD8fy5csxZcoUtaN72TEyMkLnzp0RGhqKjz/+ONsfSkVtUVFRyuYaClFRUcrPFf/euHFDbRxRUVEq793d3REREYGmTZu+1x9sxsbG6NGjB3r06IG0tDR89tlnmDVrFiZOnKhxZ6So79KlS8jIyFA5Knvt2jWV+guTohmO4mhmXr8XmdeB4rsIAGlpaYiJicnxCGiHDh0QFBSEtWvXagyyb9++xfr161G2bNlcj2or3L17F0ePHkXjxo3zfao0vxTh4OHDh4U2DcXR9qx3gMjpSLfCli1bYGhoiH379qkcgQsODlbrV9Pvk7W1NUxNTfH27dtcj2Q7OzvjypUrEEKojCvr9vW+fv/9dwBQNjt7/vw5Dh48iBkzZqhc1KtpG8/ut/dD9wuenp5Yt26d2pHbP//8E69fv8bSpUvVfruioqLw7bffIjIyUnnXGGdnZ40P8lD0r+inIOjq6iIoKAgtW7bE4sWLMWHCBFSuXBkeHh7Yvn07Fi5cqHbgKjsxMTHQ0dEp8MyQE7aRpWx99tln0NXVxYwZM9SO6gghPuhUl+IG5D///LNKd8VRysxHfwqL4shH5nlLTEzU+IOeV126dMHFixc13sJJMZ3u3bvj/v37+O2339T6efXqFV68eJGvmoUQareysra2RvPmzbF69WrcvXtXYx05yev6ef78udr4FI8gVpyyzPo90dHRUR6xye9teMaNG4dp06ZhypQp2fZTr1492NjYYNmyZSrj37NnD65evaqs3d7eHrVq1cKaNWtUTjkeOHBAbQfSvXt3vH37FjNnzlSb3ps3b3K8pVTW+TcwMEDVqlUhhMi2XTHwbh08evQImzZtUpnWL7/8AhMTE3h7e2c7bEHZuXMnAKBmzZrKmoDcvxc+Pj4wMDDAokWLVL4fq1atQmJiYo7bd5MmTeDj44Pg4GDl9DObPHkyrl+/jq+//jpPf1Q8e/YMPXv2xNu3b1VuPfehDh48qLG7oh1xQZ4+z0pxuvjYsWPKbm/fvs32VH9murq6kMlkKkdvb9++rfFuKcbGxmrfbV1dXXTp0gVbtmzR+Ify06dPlf//5JNP8ODBA5Vbe718+TJPdebm0KFDmDlzJlxdXdG7d29lbYD6b1zW7yvwbt4A9T8GPnS/0LhxYwghcO7cOZXuoaGhcHNzwxdffIGuXbuqvMaNGwcTExOVMz6ffPIJYmNj1dZLamoqVq5cCRsbG9SpUydPNeVFixYt0KBBA/z888/KO8HMmDED8fHxGDRokMq1JQr79+9X20bPnTsHLy+vXJtfFCQekaVsubu74/vvv8fEiRNx+/ZtdO7cGaampoiJicHWrVsxZMgQjBs37r3GXbNmTfTr1w8rVqxAQkICvL29cfr0aaxZswadO3fO9okoBalt27bKI4VDhw5FSkoKfvvtN9jY2Lz30ZTx48fjjz/+QLdu3TBgwADUrVsXz549Q3h4OJYtW4aaNWvi888/x+bNm/HFF1/g8OHDaNq0Kd6+fYtr165h8+bNyvvlauLp6Ql3d3eMGzcO9+/fh5mZGbZs2aLxVNaiRYvw0UcfoU6dOhgyZAhcXV1x+/Zt7Nq1CxcuXMhxPvK6fhRPTfr000/h7u6O5ORk/PbbbzAzM1OGnkGDBuHZs2do1aoVKlSogDt37uCXX35BrVq1VI7q5UXNmjWVoSo7+vr6mDNnDvr37w9vb2/07NlTefstFxcXfPXVV8p+g4KC0L59e3z00UcYMGAAnj17prznq+IoJPCuLfDQoUMRFBSECxcuoG3bttDX18eNGzcQFhaGhQsXqlzQklnbtm1hZ2eHpk2bwtbWFlevXsXixYvRvn37HI8ODhkyBMuXL0dAQADOnTsHFxcX/PHHH4iMjMTPP/9c4EcWjx8/rtyBKb6zR48ehb+/v/I0Y16/F9bW1pg4cSJmzJiBdu3awc/PD1FRUViyZAnq16+PPn365FjL2rVr0bp1a3Tq1Am9evVCs2bNkJqaij///BNHjhxBjx49NN6u6Pr16wgNDYUQAklJSbh48SLCwsKQkpKC+fPna2yXff78eZX7kCq4u7ujcePG2dbYqVMnuLq6omPHjnB3d8eLFy8QERGBHTt2oH79+ujYsWOO8/ghvLy80KhRI0ycOBHPnj1DuXLlsHHjRo1hI6v27dsrl0WvXr3w5MkT/Prrr6hYsaKyyYZC3bp1ERERgfnz56N8+fJwdXVFw4YNMXv2bBw+fBgNGzbE4MGDUbVqVTx79gznz59HREQEnj17BuDdxX2LFy9G3759ce7cOdjb2+P333/P91Mj9+zZg2vXruHNmzd4/PgxDh06hAMHDsDZ2Rnh4eHKsxpmZmZo3rw55s6di/T0dDg4OGD//v0a76Fat25dAO/+MPL394e+vj46duz4wfuFjz76CJaWloiIiFCeEXrw4AEOHz6MUaNGaRxGLpfD19cXYWFhWLRokfKWiatXr1buS2rXrq184t6VK1ewdu3aAn9S5vjx49GtWzeEhITgiy++QI8ePXD58mXMmjUL//zzD3r27Kl8stfevXtx8OBBleYo6enpOHr0KIYPH16gdeWqaG6OQMVNXm5rorBlyxbx0UcfCWNjY2FsbCw8PT3FiBEjRFRUlLIfb2/vbG8xpOn2W0IIkZ6eLmbMmCFcXV2Fvr6+cHR0FBMnThSvX79W6S+725Bk90Si7OZN05NPwsPDRY0aNYShoaFwcXERc+bMEatXr1a7LUt2NWh6ilN8fLwYOXKkcHBwEAYGBqJChQqiX79+KreqSUtLE3PmzBFeXl5CLpeLsmXLirp164oZM2aIxMRE9YWYyX///Sd8fHyEiYmJsLKyEoMHDxYXL15Uux2LEEJcuXJFfPrpp8LCwkIYGhoKDw8PlaeuZPc0GCHytn7Onz8vevbsKZycnIRcLhc2NjaiQ4cO4uzZs8p+/vjjD9G2bVthY2MjDAwMhJOTkxg6dKh4+PBhjvMpRO63VMppHjZt2iRq164t5HK5KFeunOjdu7eIjY1VG37Lli2iSpUqQi6Xi6pVq4o///wz26chrVixQtStW1cYGRkJU1NTUb16dfH111+LBw8eKPvJ+p1Yvny5aN68ubC0tBRyuVy4u7uL8ePH57qehXj3hKj+/fsLKysrYWBgIKpXr662jnN6QhWy3PZJE0233zIwMBCenp5i1qxZak/0yet2K8S72215enoKfX19YWtrK4YNG6Z2W63slnVycrKYPn268PLyUi7vpk2bipCQEJVbyGWeV8VLR0dHWFhYiNq1a4vAwEDx77//qvWf2+23cnui1YYNG4S/v79wd3cXRkZGwtDQUFStWlVMnjxZeWu0zLVpuv1W1u9sdr+Vmn5fb926JXx8fJS3V5o0aZI4cOBAnm6/tWrVKlGpUiUhl8uFp6enCA4OVtaU2bVr10Tz5s2FkZGR2jJ5/PixGDFihHB0dBT6+vrCzs5OtG7dWqxYsUJlHHfu3BF+fn6iTJkywsrKSgQGBipvW5fX229l/l7a2dmJNm3aiIULF6otZyGEiI2NVf7mmZubi27duokHDx5o3BZmzpwpHBwchI6Ojspvfl73C9kZNWqUqFixovL9vHnzBABx8ODBbIcJCQkRAFSeZvf8+XPx1VdfKbc1MzMz0bJlS7Fnzx614XP6Lc8sp33/27dvhbu7u3B3d1e5XeLBgwdFp06dhI2NjdDT0xPW1taiY8eOak/e27NnjwAgbty4kWMNBU0mxAdcCUBEREREStHR0fD09MSePXvQunVrbZdTZDp37gyZTJbt0xELC4MsERERUQEaNmwYbt68+UH3z5aSq1evonr16rhw4UKeb/tYUBhkiYiIiEiSeNcCIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkPhBBgjIyMvDgwQOYmpoW6jPPiYiIiIqaEALJyckoX768yiO6NWGQlaAHDx7A0dFR22UQERERFZp79+6hQoUKOfbDICtBikdT3rt3D2ZmZlquhoiIiKjgJCUlwdHRMU+P4maQlSBFcwIzMzMGWSIiIiqR8tJ8khd7EREREZEkMcgSERERkSQxyBIRERGRJDHIEhEREZEkMcgSERERkSQxyBIRERGRJDHIEhEREZEkMcgSERERkSQxyBIRERGRJDHIEhEREZEkMcgSERERkSQxyBIRERGRJDHIEhEREZEkMcgSERERkSQxyBIRERGRJDHIEhEREZEkMcgSERERkSTpabsAIio94uLikJycrJVpm5qawsrKSivTJiKiwsEgS0RFIi4uDmPHjUN6WppWpq9vYIB5P/3EMEtEVIIwyBJRkUhOTkZ6WhosmtaAnrkxAOBNYgoSIi/Doml16JmbFNq03yS+QELkJSQnJzPIEhGVIAyyRFSk9MyNoW9pnqWbiVo3IiKi3PBiLyIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiypfU1FTExMQgNTVV26V8sJI0L0REpRGDLBHly4MHDzB58mQ8ePBA26V8sJI0L0REpRGDLBERERFJEoMsEREREUkSgywRlXjPHz7Gw4cPER0dre1SiIioADHIElGJ9iz2Ia7/dQ5xcXEIDw9HVFSUtksiIqICwiBLRCVa0pM4lfd37txR/j86OppHaomIJIxBloiKhCI0Pn/4uEina2ZjpfLe2dkZABAVFYXw8HAeqSUikjAGWSIqdJlD4/W/zuFZ7MMim3a5Cvao3LgurKys4OfnBw8PDwCqR2Y1vSciouKPQZaICl3WkKg43a+4CKuwj9KWtbeFvb093NzclN0UR2aze09ERMUfgywRFbqsIdHMxkrlIqyiPkoLAB4eHvDz81M7UktERNJRIoNsSEgILCwstF0GACAgIACdO3fOsZ8WLVpg9OjRRVIPkTZkDo2VG9dFuQr2ahdhZX1fFNzc3NSO1BIRkXTkO8g+ffoUw4YNg5OTE+RyOezs7ODr64vIyEgAgIuLC2QyGWQyGYyMjODi4oLu3bvj0KFDKuO5ffu2sr+sr1OnTn3QTPXo0QPXr1//oHEUlIULFyIkJETbZRBpnSI0lrW3BaB+EVbW90RERLnRy+8AXbp0QVpaGtasWQM3Nzc8fvwYBw8eRHx8vLKf7777DoMHD0ZaWhpu376N0NBQ+Pj4YObMmZg8ebLK+CIiIuDl5aXSzdLS8j1n5x0jIyMYGRl90DgKirm5ubZLICqWFBdhxT5/jQr/f5SWiIgoP/J1RDYhIQHHjx/HnDlz0LJlSzg7O6NBgwaYOHEi/Pz8lP2ZmprCzs4OTk5OaN68OVasWIEpU6Zg6tSpare4sbS0hJ2dncpLX18/11ouXryIli1bwtTUFGZmZqhbty7Onj0LQHPTgu+//x42NjYwNTXFoEGDMGHCBNSqVUv5uaIJwA8//ABbW1tYWFjgu+++w5s3bzB+/HiUK1cOFSpUQHBwsMp4L1++jFatWsHIyAiWlpYYMmQIUlJS1Mar8OLFC/Tt2xcmJiawt7fHvHnzcp1XopJKcRGW4igtERFRfuQryJqYmMDExATbtm1DampqviYUGBgIIQS2b9+er+Gy07t3b1SoUAFnzpzBuXPnMGHChGwD8Lp16zBr1izMmTMH586dg5OTE5YuXarW36FDh/DgwQMcO3YM8+fPx7Rp09ChQweULVsWf//9N7744gsMHToUsbGxAN6FUl9fX5QtWxZnzpxBWFgYIiIiMHLkyGzrHj9+PI4ePYrt27dj//79OHLkCM6fP5/jvKampiIpKUnlRaQtivvB/vXXX4iJicnz6/79+9ouHffv3y92NRER0fvLV9MCPT09hISEYPDgwVi2bBnq1KkDb29v+Pv7o0aNGjkOW65cOdjY2OD27dsq3Zs0aQIdHdU8nfmIZnbu3r2L8ePHw9PTEwBQqVKlbPv95ZdfMHDgQPTv3x8AMHXqVOzfv19tOuXKlcOiRYugo6MDDw8PzJ07Fy9fvsSkSZMAABMnTsTs2bNx4sQJ+Pv7Y/369Xj9+jXWrl0LY2NjAMDixYvRsWNHzJkzB7a2qkeZUlJSsGrVKoSGhqJ169YAgDVr1qBChQo5zmtQUBBmzJiR6zIhKmyZ7wcbFBQEZ2dnmJmZabusPFuyZIm2SyAiogL0Xm1k27dvj+PHj+PUqVPYs2cP5s6di5UrVyIgICDHYYUQkMlkKt02bdqEKlWq5LcMjBkzBoMGDcLvv/8OHx8fdOvWDe7u7hr7jYqKwvDhw1W6NWjQQO0CNC8vL5VQbWtri2rVqinf6+rqwtLSEk+ePAEAXL16FTVr1lSGWABo2rQpMjIyEBUVpRZkb926hbS0NDRs2FDZrVy5crne9mfixIkYM2aM8n1SUhIcHR1zHIaoMGS+H2z9+vXRokULNGvWLE/D3r9/X+tBcvjw4XBwcFC+Lw41ERHR+8t3kAUAQ0NDtGnTBm3atMGUKVMwaNAgTJs2LccgGx8fj6dPn8LV1VWlu6OjIypWrJjvGqZPn45evXph165d2LNnD6ZNm4aNGzfi008/zfe4FLI2TZDJZBq7ZWRkvPc03odcLodcLi/SaRJpkvl+sKampmjYsKHaNl2cOTg4SKpeIiLKWYHcR7Zq1ap48eJFjv0sXLgQOjo6ud5TNT8qV66Mr776Cvv378dnn32mdiGWgoeHB86cOaPSLev791GlShVcvHhRZd4jIyOVTROycnd3h76+Pv7++29lt+fPnxebW4UR5YYPESAiouIkX0dk4+Pj0a1bNwwYMAA1atSAqakpzp49i7lz56JTp07K/pKTk/Ho0SOkp6cjJiYGoaGhWLlyJYKCgtSOvsbHx+PRo0cq3SwsLGBoaJhtHa9evcL48ePRtWtXuLq6IjY2FmfOnEGXLl009v/ll19i8ODBqFevHpo0aYJNmzbh0qVLH3wT9N69e2PatGno168fpk+fjqdPn+LLL7/E559/rtasAHh3sdzAgQMxfvx4WFpawsbGBpMnT1ZrI0xUnPEhAkREVFzkK8iamJigYcOGWLBgAW7duoX09HQ4Ojpi8ODByguigHcXU02dOhUGBgaws7NDo0aNcPDgQbRs2VJtnD4+PmrdNmzYAH9//2zr0NXVRXx8PPr27YvHjx/DysoKn332WbYXRPXu3RvR0dEYN24cXr9+je7duyMgIACnT5/Oz+yrKVOmDPbt24fAwEDUr18fZcqUQZcuXTB//vxsh/nxxx+RkpKCjh07wtTUFGPHjkViYuIH1UFERERUGsmEEELbRWhDmzZtYGdnh99//13bpeRbUlISzM3NkZiYKKkrxqlkiImJweTJkzFr1qx8tTdVDGf1SWPoW757UEh6fCLidv+l0q0wKKaTteb3nRciIio8+ck573Wxl9S8fPkSy5Ytg6+vL3R1dbFhwwZERETgwIED2i6NiIiIiN5TsW2c6eXlpXwAQ9bXunXr8jUumUyG3bt3o3nz5qhbty527NiBLVu2aGzWQERERETSUGyPyO7evRvp6ekaP9N0IVVOjIyMEBERURBlEREREVExUWyDbOb7VRIRERERZVVsmxYQEREREeWEQZaIiIiIJIlBloiIiIgkiUGWiIiIiCSJQZaIiIiIJIlBlojypXz58pg1axbKly+v7VI+WEmaFyKi0qjY3n6LiIonuVxeYh7nWpLmhYioNOIRWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQ9bRdARKXLm8QXmf6fovJvUUyTiIhKDgZZIioSpqam0DcwQELkJbXPEiIvF/r09Q0MYGpqWujTISKiosMgS0RFwsrKCvN++gnJyclamb6pqSmsrKy0Mm0iIiocDLJEVGSsrKwYJomIqMDwYi8iIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkPW0XQERE9L7i4uKQnJys7TKItMrU1BRWVlbaLkMrGGSJiEiS4uLiMG7sWKSlp2u7FCKtMtDXx0/z5pXKMMsgS0REkpScnIy09HT08SgH2zLcnVHBePwyHaFRz9HHoyxsy+hru5xcPX75BqFRz5CcnMwgS0REJDW2ZfTgaGKg7TKohLEto8/vlQTwYi8iIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiKSpLS0NABAeobQciVEpUNqaipiYmKQmpqq7VKUGGSJiEiSnj59CgB49vqNlishKh0ePHiAyZMn48GDB9ouRYlBloiIiIgkiUGWiIiIiCSJQZaIiIiIJIlBloiIiIgkiUGWiIiIiCSJQZaIiIiIJIlBloiIiIhyFR0djYcPHyI6OlrbpSgxyBIRkSTdvXsXDx8+RGzcc22XQlTiRUVFITw8HHFxcQgPD0dUVJS2SwLAIEtERBIUFRWFiIgIxMXF4ejlG7j5+Jm2SyIq0e7cuZPje21hkKVsRUVFYf/+/cXmry4iIoWsO9HY+EQtVUJUOjg7O+f4XluKbZB9+vQphg0bBicnJ8jlctjZ2cHX1xeRkZEAABcXF8hkMshkMhgZGcHFxQXdu3fHoUOHVMZz+/ZtZX9ZX6dOncq1jpCQEMhkMlSpUkXts7CwMMhkMri4uKj0b2Fhke34AgIClNM3MDBAxYoV8d133+HNm+L1iMWrV69i0aJF2LRpExYtWoSrV69quyQiIqWsO9EKluZaqoSodPDw8ICfnx+srKzg5+cHDw8PbZcEANDTdgHZ6dKlC9LS0rBmzRq4ubnh8ePHOHjwIOLj45X9fPfddxg8eDDS0tJw+/ZthIaGwsfHBzNnzsTkyZNVxhcREQEvLy+VbpaWlnmqxdjYGE+ePMFff/2Fxo0bK7uvWrUKTk5O+Z63du3aITg4GKmpqdi9ezdGjBgBfX19TJw4Md/jKgynT5/GDz/8gFu3bim73b9/H5MmTUKDBg20WBkR0TseHh7w8fFBTEwMvKvZo6JtOW2XRFTiubm5wd7eHm5ubtouRalYBtmEhAQcP34cR44cgbe3N4B3f31nDVGmpqaws7MDADg5OaF58+awt7fH1KlT0bVrV5W/FiwtLZX95peenh569eqF1atXK4NsbGwsjhw5gq+++gobNmzI1/gUR5gBYNiwYdi6dSvCw8OLRZA9ffo0Fi5ciMqVK8PR0RHm5uZITEyEkZERFi5ciMDAQIZZIioWnJycYG9vjwpWZbVdChFpSbFsWmBiYgITExNs27YNqamp+Ro2MDAQQghs3769QGsaMGAANm/ejJcvXwJ414SgXbt2sLW1/eBxGxkZIS0t7YPH86EyMjKwbt061K5dG7Nnz8bIkSPRvHlzjBw5ErNnz0bt2rWxbt06ZGRkaLtUIiIiouJ5RFZPTw8hISEYPHgwli1bhjp16sDb2xv+/v6oUaNGjsOWK1cONjY2uH37tkr3Jk2aQEdHNbenpKTkuabatWvDzc0Nf/zxBz7//HOEhIRg/vz5H3QvNSEEDh48iH379uHLL7/Mtr/U1FSVQJ+UlPTe08zJtWvX8PTpU4wcORI6Ojrw8PBQOart5+eH6dOn49q1a6hatWqh1EBERET5d//+/RIxjfwqlkEWeNdGtn379jh+/DhOnTqFPXv2YO7cuVi5ciUCAgJyHFYIAZlMptJt06ZNGi/Yyo8BAwYgODgYTk5OePHiBT755BMsXrw43+PZuXMnTExMkJ6ejoyMDPTq1QvTp0/Ptv+goCDMmDHjAyrPm4SEBACAo6Ojxs8V3RX9ERERUfGwZMkSbZegFcU2yAKAoaEh2rRpgzZt2mDKlCkYNGgQpk2blmOQjY+Px9OnT+Hq6qrS3dHRERUrVvygenr37o2vv/4a06dPx+effw49vfdbfC1btsTSpUthYGCA8uXL5zqeiRMnYsyYMcr3SUlJ2YbND6G428K9e/dQqVIltc/v3bun0h8REREVD8OHD4eDg0OhTuP+/fvFLjAX6yCbVdWqVbFt27Yc+1m4cCF0dHTQuXPnAp9+uXLl4Ofnh82bN2PZsmXvPR5jY+N8hWq5XA65XP7e08srT09PWFtbY/v27RgzZoxKU4yMjAyEh4fD2toanp6ehV4LERER5e72k+d4+PAhUlNT1Q7ilQbFMsjGx8ejW7duGDBgAGrUqAFTU1OcPXsWc+fORadOnZT9JScn49GjR0hPT0dMTAxCQ0OxcuVKBAUFqQXF+Ph4PHr0SKWbhYUFDA0N81VbSEgIlixZkuOtu96+fYsLFy6odJPL5R/ctKGw6ejooHfv3li4cCHmz58PPz8/ODo64t69ewgPD8c///yDwMBAtbbGREREVPRuPn6GfReiEBf3AuHh4ahQoUKxub9rUSmWQdbExAQNGzbEggULcOvWLaSnp8PR0RGDBw/GpEmTlP1NnToVU6dOhYGBAezs7NCoUSMcPHgQLVu2VBunj4+PWrcNGzbA398/X7UZGRnByMgox35SUlJQu3ZtlW7u7u64efNmvqalDQ0aNEBgYCDWrVun0m7X2tqat94iIiIqRrI+0e7OnTulLsjKhBBC20VQ/iQlJSnv72pmZlYo08jIyMC1a9eQkJAACwsLeHp68kgsERUrJ06cwJIlS9DHoyzq2RhruxwqIY5HP8bis3cxsp4Tmrl9+C02C9PNx88QEnkFfz16gVatWmH48OGFGmRjYmIwefJkzJo1q1CbMeQn5xTLI7KkfTo6OrzFFhERlSqZT9Xvu/AK9sb6xfqpcRVty8G3lgdunL1brB4bW5RK/SE2Ly8v5QMYsr7WrVun7fKIiIioiGQ9VZ/1fXHkYlO22D02tiiV+iOyu3fvRnp6usbPCuKpXURERCQNFSzNAdzL8p6Ks1IfZJ2dnbVdAhERERUDmU/V+9ZyKtbNCuidUh9kiYiIiBTenapPh4tNWW2XQnlQ6tvIEhEREZE0McgSERERkSQxyBIRERGRJDHIEhEREZEkMcgSERERkSQxyBIRkSRZW1sDAMoZ8gY8REWhfPnymDVrFsqXL6/tUpS49RMRkSQZGBgAAPR1ZFquhKh0kMvlcHV11XYZKnhEloiIiIgkiUGWiIiIiCSJQZaIiIiIJIlBloiIiIgkiUGWiIiIiCSJQZaIiIiIJIlBloiIiIgkiUGWiIiIiCSJQZaIiIiIJIlBloiIiIgkiUGWiIiIiCRJT9sFEBERfYjHL99ouwQqQR6/TFf5t7gr7d9/BlkiIpIkU1NTGOjrIzTqmbZLoRIoNOq5tkvIMwN9fZiammq7DK1gkCUiIkmysrLCT/PmITk5WdulEGmVqakprKystF2GVjDIEhGRZFlZWZXaHTgR8WIvIiIiIpIoBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkPW0XQETSERcXh+TkZG2XQaQ1pqamsLKy0nYZRPT/GGSJKE/i4uIwdtw4pKelabsUIq3RNzDAvJ9+YpglKiYYZIkoT5KTk5GelobKNX1QxqSstsvRqpcpz3H9YgSXRSmjWO/JyckMskTFBIMsEeVLGZOyMDG31nYZxQKXBRGRdvFiLyIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiIiIikiQGWSIiIiKSJAZZIiIiIpIkBlkiUpOamoqYmBikpqZquxSiUo/bI1H2GGSJSM2DBw8wefJkPHjwQNulEJV63B6JsscgS0RERESSxCBLRERERJLEIEtEREREksQgS0R5Eh0djYcPH+Lp4/vaLkXrnj6+z2VBRFQMMMgSUa6ioqIQHh6OuLg4XDh7HI8f3tV2SVrz+OFdXDh7nMuCiKgYYJAlolzduXNH5f2zuEdaqkT7ss57aV4WRETaxiBLRLlydnZWeV/Oyk5LlWhf1nkvzcuCiEjbGGSJKFceHh7w8/ODlZUVatVrBlt7J22XpDW29k6oVa8ZlwURUTHAIEtEeeLm5gZ7e3tY2zpouxSts7Z14LIgIioGil2QDQgIgEwmU74sLS3Rrl07XLp0SdmPTCbDtm3bVIY7fPgwPvnkE1haWqJMmTKoWrUqxo4di/v372PgwIGoXr060tLSVIbZvXs3DAwMcP78eQDAP//8g27dusHW1haGhoaoVKkSBg8ejOvXrwMAbt++DZlMhgsXLmisPSQkRKV2xcvQ0FDZz9OnTzFs2DA4OTlBLpfDzs4Ovr6+iIyMLIClR0RERFR6FLsgCwDt2rXDw4cP8fDhQxw8eBB6enro0KFDtv0vX74cPj4+sLOzw5YtW/Dff/9h2bJlSExMxLx587BgwQIkJydj2rRpymESEhIwePBgTJkyBXXq1MHOnTvRqFEjpKamYt26dbh69SpCQ0Nhbm6OKVOm5Ll2MzMzZe2KV+YLZbp06YJ//vkHa9aswfXr1xEeHo4WLVogPj7+/RYWERGVaIpb30VHR2u7FKJiR0/bBWiiOFIJAHZ2dpgwYQKaNWuGp0+fwtraWqXf2NhYjBo1CqNGjcKCBQuU3V1cXNC8eXMkJCTAzMwMwcHB8PX1RefOndGwYUOMHj0aDg4OmDhxIl6+fIn+/fvjk08+wdatW5XjcHV1RcOGDZGQkJDn2mUymbL2rBISEnD8+HEcOXIE3t7eAN5dRNOgQYM8j5+IiEqPzLe+Cw8PR4UKFeDh4aHtsoiKjWJ5RDazlJQUhIaGomLFirC0tFT7PCwsDGlpafj66681Dm9hYQEAaNmyJYYPH45+/fohLCwMmzdvxtq1a6Gnp4d9+/YhLi4u13F8KBMTE5iYmGDbtm1ITU0tkHESEVHJlfXWd1nfE5V2xfKI7M6dO2FiYgIAePHiBezt7bFz507o6Kjn7hs3bsDMzAz29va5jjcoKAh79+6Fv78/5s2bB09PT+U4ACjff4jExERl7QrNmjXDnj17oKenh5CQEAwePBjLli1DnTp14O3tDX9/f9SoUSPbcaampqoE36SkpA+ukygv7t+/r/H/RKVZUW4Lurq6SE5OVr7Peis8otKuWAbZli1bYunSpQCA58+fY8mSJfj4449x+vRptY1YCAGZTJan8RoZGWHcuHH46quvEBgYqDKOgmJqaqq8eCzzdBW6dOmC9u3b4/jx4zh16hT27NmDuXPnYuXKlQgICNA4zqCgIMyYMaPAaiTKqyVLlmi7BKJip6i3i6SkJFhZWcHPz4/NCoiyKJZB1tjYGBUrVlS+X7lyJczNzfHbb7/h+++/V+m3cuXKSExMxMOHD/N0VFZPTw+6uroq4bdy5coAgGvXrqFx48YfVLuOjo5K7ZoYGhqiTZs2aNOmDaZMmYJBgwZh2rRp2QbZiRMnYsyYMcr3SUlJcHR0/KA6ifJi+PDhcHB4d4up+/fvM9gSQXW7KAqKbc/Nza3IpkkkFcUyyGYlk8mgo6ODV69eqX3WtWtXTJgwAXPnzlW52EshISEh1zaubdu2hZWVFebOnatysVd+xvEhqlatqnY7sczkcjnkcnmhTZ8oOw4ODnB1ddV2GUTFCrcLouKjWAbZ1NRUPHr07vnlz58/x+LFi5GSkoKOHTuq9evo6IgFCxZg5MiRSEpKQt++feHi4oLY2FisXbsWJiYmmDdvXo7TMzY2xsqVK9GtWzf4+flh1KhRqFixIuLi4rB582bcvXsXGzduVPYfFRWlNg4vLy8A75opKGrPzMbGBs+fP0e3bt0wYMAA1KhRA6ampjh79izmzp2LTp065WsZEREREZV2xTLI7t27V9lMwNTUFJ6enggLC0OLFi009j98+HBUrlwZP/30Ez799FO8evUKLi4u6NChg8op+Zx06tQJJ0+eRFBQEHr16qU8fd+qVSu15gz+/v5qw9+7dw/Au9P+mpo4PHz4EGXLlkXDhg2xYMEC3Lp1C+np6XB0dMTgwYMxadKkPNVJRERERO8UuyAbEhKCkJCQHPvRdHGWj48PfHx8ch1/QEBAtm1R69Wrhy1btmQ7rIuLS44XhuU0boWgoCAEBQXlWicRERER5azY30eWiIioOHj6+D6fsEVUzDDIEpEaPhKTSNXjh3dx4exx5RO2NF0rQURFj0GWiFRkfSQmd9hEwLM41Yt4+YQtouKBQZaIVPCRmETqylnZqbznE7aIigcGWSJSkXUHzR02EWBr74Ra9ZrxCVtExQyDLBGp8PDwgJ+fH3fYRFlY2zrA3t6eT9giKkYYZIlIjZubG3fYRERU7DHIEhEREZEkMcgSERERkSQxyBIRERGRJDHIEpGa8uXLY9asWShfvry2SyEq9bg9EmVPT9sFEFHxI5fL4erqqu0yiAjcHolywiOyRERERCRJDLJEREREJEkMskREREQkSQyyRERERCRJDLJEREREJEkMskREREQkSQyyRERERCRJDLJEREREJEkMskREREQkSQyyRERERCRJDLJEREREJEl62i6AiKTlZcpzbZegdYplwGVRunB9ExU/DLJElCempqbQNzDA9YsR2i6l2OCyKH30DQxgamqq7TKI6P8xyBJRnlhZWWHeTz8hOTlZ26UQaY2pqSmsrKy0XQYR/T8GWSLKMysrK+7EiYio2ODFXkREREQkSQyyRERERCRJDLJEREREJEkMskREREQkSQyyRERERCRJDLJEREREJEkMskREREQkSQyyRERERCRJDLJEREREJEkMskREREQkSQyyRERERCRJDLJEREREJEkMskREREQkSQyyRERERCRJDLJEREREJEkMskREREQkSQyyRERERCRJetougPJPCAEASEpK0nIlRERERAVLkW8UeScnDLISlJycDABwdHTUciVEREREhSM5ORnm5uY59iMTeYm7VKxkZGTgwYMHMDU1hUwm03Y5hS4pKQmOjo64d+8ezMzMtF1OqcX1UDxwPRQPXA/FA9dD8VDQ60EIgeTkZJQvXx46Ojm3guURWQnS0dFBhQoVtF1GkTMzM+MPVTHA9VA8cD0UD1wPxQPXQ/FQkOshtyOxCrzYi4iIiIgkiUGWiIiIiCSJQZaKPblcjmnTpkEul2u7lFKN66F44HooHrgeigeuh+JBm+uBF3sRERERkSTxiCwRERERSRKDLBERERFJEoMsEREREUkSgywVK7Nnz4ZMJsPo0aOz7SckJAQymUzlZWhoWHRFlkDTp09XW6aenp45DhMWFgZPT08YGhqievXq2L17dxFVW3Lldz1wWyg89+/fR58+fWBpaQkjIyNUr14dZ8+ezXGYI0eOoE6dOpDL5ahYsSJCQkKKptgSLL/r4ciRI2rbhEwmw6NHj4qw6pLHxcVF43IdMWJEtsMU1T6CD0SgYuPMmTNYvnw5atSokWu/ZmZmiIqKUr4vDU84K2xeXl6IiIhQvtfTy/7n4eTJk+jZsyeCgoLQoUMHrF+/Hp07d8b58+dRrVq1oii3xMrPegC4LRSG58+fo2nTpmjZsiX27NkDa2tr3LhxA2XLls12mJiYGLRv3x5ffPEF1q1bh4MHD2LQoEGwt7eHr69vEVZfcrzPelCIiopSuTG/jY1NYZZa4p05cwZv375Vvr9y5QratGmDbt26aey/KPcRDLJULKSkpKB379747bff8P333+fav0wmg52dXRFUVnro6enleZkuXLgQ7dq1w/jx4wEAM2fOxIEDB7B48WIsW7asMMss8fKzHgBuC4Vhzpw5cHR0RHBwsLKb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",
      "text/plain": [
       "<Figure size 700x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(7, 4))\n",
    "\n",
    "# Draw the boxplot\n",
    "sns.boxplot(\n",
    "    x=\"AUPRC\",\n",
    "    y=\"Method\",\n",
    "    data=df,\n",
    "    orient=\"h\",\n",
    "    width=0.6,       # adjust box width if you like\n",
    "    palette=\"Set2\"   # choose a color palette\n",
    ")\n",
    "\n",
    "# Optionally add a stripplot (dots showing individual points)\n",
    "sns.stripplot(\n",
    "    x=\"AUPRC\",\n",
    "    y=\"Method\",\n",
    "    data=df,\n",
    "    color=\"black\",\n",
    "    alpha=0.5,\n",
    "    size=3,\n",
    "    orient=\"h\"\n",
    ")\n",
    "\n",
    "plt.xlabel(\"AUPRC\")\n",
    "plt.ylabel(\"\")  # you can leave method labels on the left\n",
    "plt.title(\"Performance across Models on BoolODE Simulated Data (AUPRC)\")\n",
    "\n",
    "# Format the x-axis in scientific notation, if desired:\n",
    "plt.ticklabel_format(style='sci', axis='x', scilimits=(0,0))\n",
    "\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "tf_ode",
   "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.10.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
