{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "35b60a5a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "from cycler import cycler\n",
    "import os\n",
    "\n",
    "mpl.rcParams[\"axes.prop_cycle\"] = cycler(\n",
    "    color=[\n",
    "        \"#D3A400\",\n",
    "        \"#008AB2\",\n",
    "        \"#30B87F\",\n",
    "    ]\n",
    ")\n",
    "colour_scheme = {\n",
    "    \"ASTRA better\": \"#D3A400\",\n",
    "    \"Same\": \"#008AB2\",\n",
    "    \"ASTRA worse\": \"#30B87F\",\n",
    "    \"Gains\": \"#D3A400\",\n",
    "    \"Losses\": \"#30B87F\",\n",
    "    \"Total\": \"#D0385E\",\n",
    "}\n",
    "plt.rcParams[\"font.family\"] = [\"DejaVu Sans Mono\"]\n",
    "plt.rcParams.update({\"font.size\": 10})\n",
    "os.makedirs(\"figures\", exist_ok=True)\n",
    "cm = 1 / 2.54"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8bf1aaee",
   "metadata": {},
   "source": [
    "# Synthetic Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "ee4475f4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pickle\n",
    "from scipy.stats import wilcoxon"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "47a1205c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_results(results_dict: dict, classification: bool = False):\n",
    "    \"\"\"\n",
    "    Plot benchmark results.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    results_dict : dict\n",
    "        Dictionary containing benchmark results.\n",
    "    classification : bool, optional\n",
    "        Whether the results are for classification tasks, by default False.\n",
    "    \"\"\"\n",
    "    fig, ax = plt.subplots(1, 2, figsize=(16 * cm, 8 * cm))\n",
    "    outperformance_counts_mean = {\"ASTRA better\": 0, \"Same\": 0, \"ASTRA worse\": 0}\n",
    "    outperformance_counts_median = {\"ASTRA better\": 0, \"Same\": 0, \"ASTRA worse\": 0}\n",
    "    for dataset in results_dict:\n",
    "        astra_score = results_dict[dataset][\"ASTRA\"]\n",
    "        best_mean_score = results_dict[dataset][\"Mean\"]\n",
    "        best_median_score = results_dict[dataset][\"Median\"]\n",
    "        if classification:  # higher is better\n",
    "            delta_mean = astra_score - best_mean_score\n",
    "            delta_median = astra_score - best_median_score\n",
    "        else:  # lower is better\n",
    "            delta_mean = best_mean_score - astra_score\n",
    "            delta_median = best_median_score - astra_score\n",
    "        if delta_mean > 0:\n",
    "            outperformance_counts_mean[\"ASTRA better\"] += 1\n",
    "        elif delta_mean == 0:\n",
    "            outperformance_counts_mean[\"Same\"] += 1\n",
    "        else:\n",
    "            outperformance_counts_mean[\"ASTRA worse\"] += 1\n",
    "        if delta_median > 0:\n",
    "            outperformance_counts_median[\"ASTRA better\"] += 1\n",
    "        elif delta_median == 0:\n",
    "            outperformance_counts_median[\"Same\"] += 1\n",
    "        else:\n",
    "            outperformance_counts_median[\"ASTRA worse\"] += 1\n",
    "    ax[0].bar(\n",
    "        outperformance_counts_mean.keys(),\n",
    "        outperformance_counts_mean.values(),\n",
    "        color=[colour_scheme[key] for key in outperformance_counts_mean.keys()],\n",
    "    )\n",
    "    print(outperformance_counts_mean)\n",
    "    ax[0].set_ylabel(\"Number of experiments\")\n",
    "    ax[0].set_title(\"ASTRA vs. best mean\")\n",
    "    ax[1].bar(\n",
    "        outperformance_counts_median.keys(),\n",
    "        outperformance_counts_median.values(),\n",
    "        color=[colour_scheme[key] for key in outperformance_counts_median.keys()],\n",
    "    )\n",
    "    print(outperformance_counts_median)\n",
    "    ax[1].set_ylabel(\"Number of experiments\")\n",
    "    ax[1].set_title(\"ASTRA vs. best median\")\n",
    "    plt.tight_layout()\n",
    "    plt.savefig(\n",
    "        f\"figures/synthetic_data_{'classification' if classification else 'regression'}.png\",\n",
    "        dpi=300,\n",
    "    )\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "def plot_results_quantitative(results_dict: dict, classification: bool = False):\n",
    "    \"\"\"\n",
    "    Plot benchmark results.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    results_dict : dict\n",
    "        Dictionary containing benchmark results.\n",
    "    classification : bool, optional\n",
    "        Whether the results are for classification tasks, by default False.\n",
    "    \"\"\"\n",
    "    fig, ax = plt.subplots(1, 2, figsize=(16 * cm, 8 * cm))\n",
    "    difference_mean = {\"Gains\": 0, \"Losses\": 0, \"Total\": 0}\n",
    "    denominator_mean = {\"Gains\": 0, \"Losses\": 0, \"Total\": 0}\n",
    "    difference_median = {\"Gains\": 0, \"Losses\": 0, \"Total\": 0}\n",
    "    denominator_median = {\"Gains\": 0, \"Losses\": 0, \"Total\": 0}\n",
    "    all_scores_astra = []\n",
    "    all_scores_best_mean = []\n",
    "    all_scores_best_median = []\n",
    "    for dataset in results_dict:\n",
    "        astra_score = results_dict[dataset][\"ASTRA\"]\n",
    "        all_scores_astra.append(astra_score)\n",
    "        best_mean_score = results_dict[dataset][\"Mean\"]\n",
    "        all_scores_best_mean.append(best_mean_score)\n",
    "        best_median_score = results_dict[dataset][\"Median\"]\n",
    "        all_scores_best_median.append(best_median_score)\n",
    "        if classification:  # higher is better\n",
    "            delta_mean = astra_score - best_mean_score\n",
    "            delta_median = astra_score - best_median_score\n",
    "        else:  # lower is better\n",
    "            delta_mean = (best_mean_score - astra_score) / best_mean_score * 100\n",
    "            delta_median = (best_median_score - astra_score) / best_median_score * 100\n",
    "        if delta_mean > 0:\n",
    "            difference_mean[\"Gains\"] += delta_mean\n",
    "            denominator_mean[\"Gains\"] += 1\n",
    "            difference_mean[\"Total\"] += delta_mean\n",
    "            denominator_mean[\"Total\"] += 1\n",
    "        elif delta_mean < 0:\n",
    "            difference_mean[\"Losses\"] += delta_mean\n",
    "            denominator_mean[\"Losses\"] += 1\n",
    "            difference_mean[\"Total\"] += delta_mean\n",
    "            denominator_mean[\"Total\"] += 1\n",
    "        else:\n",
    "            denominator_mean[\"Total\"] += 1\n",
    "        if delta_median > 0:\n",
    "            difference_median[\"Gains\"] += delta_median\n",
    "            denominator_median[\"Gains\"] += 1\n",
    "            difference_median[\"Total\"] += delta_median\n",
    "            denominator_median[\"Total\"] += 1\n",
    "        elif delta_median < 0:\n",
    "            difference_median[\"Losses\"] += delta_median\n",
    "            denominator_median[\"Losses\"] += 1\n",
    "            difference_median[\"Total\"] += delta_median\n",
    "            denominator_median[\"Total\"] += 1\n",
    "        else:\n",
    "            denominator_median[\"Total\"] += 1\n",
    "    for key in difference_mean:\n",
    "        difference_mean[key] /= denominator_mean[key]\n",
    "    for key in difference_median:\n",
    "        difference_median[key] /= denominator_median[key]\n",
    "    ax[0].bar(\n",
    "        difference_mean.keys(),\n",
    "        difference_mean.values(),\n",
    "        color=[colour_scheme[key] for key in difference_mean.keys()],\n",
    "    )\n",
    "    print(difference_mean)\n",
    "    ylabel = \"Mean AUROC change\" if classification else \"Mean relative MSE change [%]\"\n",
    "    ax[0].set_ylabel(ylabel)\n",
    "    ax[0].set_title(\"ASTRA vs. best mean\")\n",
    "    ax[0].axhline(0, color=\"black\", linestyle=\"--\", linewidth=0.8)\n",
    "    ax[1].bar(\n",
    "        difference_median.keys(),\n",
    "        difference_median.values(),\n",
    "        color=[colour_scheme[key] for key in difference_median.keys()],\n",
    "    )\n",
    "    print(difference_median)\n",
    "    ax[1].set_ylabel(ylabel)\n",
    "    ax[1].set_title(\"ASTRA vs. best median\")\n",
    "    ax[1].axhline(0, color=\"black\", linestyle=\"--\", linewidth=0.8)\n",
    "    plt.tight_layout()\n",
    "    plt.savefig(\n",
    "        f\"figures/synthetic_data_quantitative{'classification' if classification else 'regression'}.png\",\n",
    "        dpi=300,\n",
    "    )\n",
    "    # significance testing\n",
    "    _, p_value_mean = wilcoxon(\n",
    "        all_scores_astra,\n",
    "        all_scores_best_mean,\n",
    "        alternative=\"greater\" if classification else \"less\",\n",
    "        zero_method=\"pratt\",\n",
    "    )\n",
    "    _, p_value_median = wilcoxon(\n",
    "        all_scores_astra,\n",
    "        all_scores_best_median,\n",
    "        alternative=\"greater\" if classification else \"less\",\n",
    "        zero_method=\"pratt\",\n",
    "    )\n",
    "    print(\n",
    "        f\"One-sided (alternative {'greater' if classification else 'less'}) Wilcoxon signed-rank test (mean): p-value={p_value_mean}\"\n",
    "    )\n",
    "    print(\n",
    "        f\"One-sided (alternative {'greater' if classification else 'less'}) Wilcoxon signed-rank test (median): p-value={p_value_median}\"\n",
    "    )\n",
    "    _, p_value_mean = wilcoxon(\n",
    "        all_scores_astra,\n",
    "        all_scores_best_mean,\n",
    "        alternative=\"less\" if classification else \"greater\",\n",
    "        zero_method=\"pratt\",\n",
    "    )\n",
    "    _, p_value_median = wilcoxon(\n",
    "        all_scores_astra,\n",
    "        all_scores_best_median,\n",
    "        alternative=\"less\" if classification else \"greater\",\n",
    "        zero_method=\"pratt\",\n",
    "    )\n",
    "    print(\n",
    "        f\"One-sided (alternative {'less' if classification else 'greater'}) Wilcoxon signed-rank test (mean): p-value={p_value_mean}\"\n",
    "    )\n",
    "    print(\n",
    "        f\"One-sided (alternative {'less' if classification else 'greater'}) Wilcoxon signed-rank test (median): p-value={p_value_median}\"\n",
    "    )\n",
    "    _, p_value_mean = wilcoxon(\n",
    "        all_scores_astra,\n",
    "        all_scores_best_mean,\n",
    "        zero_method=\"pratt\",\n",
    "    )\n",
    "    _, p_value_median = wilcoxon(\n",
    "        all_scores_astra,\n",
    "        all_scores_best_median,\n",
    "        zero_method=\"pratt\",\n",
    "    )\n",
    "    print(f\"Regular Wilcoxon signed-rank test (mean): p-value={p_value_mean}\")\n",
    "    print(f\"Regular Wilcoxon signed-rank test (median): p-value={p_value_median}\")\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "04b987b1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "531"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open(\"results/classification_results_syn.pkl\", \"rb\") as f:\n",
    "    classification_results = pickle.load(f)\n",
    "len(classification_results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6232db39",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'ASTRA better': 483, 'Same': 19, 'ASTRA worse': 29}\n",
      "{'ASTRA better': 476, 'Same': 21, 'ASTRA worse': 34}\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmoAAAEwCAYAAAAHL11zAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAOhlJREFUeJzt3Qd4VNXW8PEVWiAgJRBAepWIwJUqHRRULoooShGwoVLkghRFUarXgl5BQJR6QUWkyAtSLKhUBRSIdES6IB1C7+W8z9rfd+adJBPMhJnkzJn/73nGzJwzmdkzOSzX7hGWZVkCAAAAx8mQ3gUAAACAbyRqAAAADkWiBgAA4FAkagAAAA5FogYAAOBQJGoAAAAORaIGAADgUCRqAAAADkWiBgAA4FAkakG2Y8cOiYiIMLfNmzf7fM6vv/4qTZs2lYIFC0r27Nnl9ttvl2effVb27dtnzj/99NOe10jups9RJUqU8BzLnDmzlCxZUtq3by/bt29Pdfnc4JNPPjGfcc+ePeny/kuWLJFBgwaly3sDN0KMcgZilH8iIiKSjal6XM+7BYlakM2ZM8fnfdsPP/wgderUkevXr8vo0aPlq6++kk6dOslvv/0mO3fuNM/p37+/rFy50nOrXLmyFC9ePMExfY6tZs2a5tiiRYukR48e8vXXX0v16tXlzz//9Lt8CFyiNnjwYL5OOA4xCm6LUc8995z5f6Br6F6fCJ66detapUuXtsqXL2/VqFEjyflGjRpZJUuWtK5cuZLk3KVLl3y+ZoMGDaxy5cr5PFe8eHHr/vvvT3Bs4sSJup+rNXjwYL/L5xaTJk0y38Hu3bvT5f0HDhxo3h9wGmKUMxCj/CMiJq6GA1rUgujYsWOyYsUK062pt9WrV8uBAwcSPGf//v2SL18+yZQpU5Lfz5IlS0DKcdddd5mfBw8e9Lt8KXH27FnTZfvSSy8lOTdgwADJmjWrnDx50nMsLi5OmjRpYj53VFSUxMbGSp8+fSQtrFmzxrQuaplKly4tY8eOTfIcbXl84oknJH/+/BIZGWlaMOfNm5fkeSn5HHZXtF1T9e6u9rcrVLtt9fe6d+8uhQoVkttuu00WLFgglSpVkujoaBk6dKjfn+Po0aPywgsvmO52/RvecsstUr9+fdPS66tbZunSpfLAAw9Ijhw5TKvuBx984NdngLMQo4hRTo9RSnuaKlSoYJ5Tvnx5+e6778SXMmXKJCi/L6EY80jUgkgvOO3StBMhrQTMnTs3wXOqVKliEiRNaHx1TQaCJoNKL3B/y5cSegE/9NBDMn36dPN63qZOnWou8ty5c5vH586dk/vvv18OHz4s48aNk/nz55vu2WB99sQ6duworVu3Nt09tWvXls6dO8usWbM853VcoCa2P//8s/znP/8x34cGmYcffli+//57z/NS+jlmz55tmuB1zKHy7q7W5vnU2L17t4wfP17i4+PN9963b19p27atvPbaa3L+/Hm/PseRI0fkxIkTJsHU62HmzJlmXOM///lP+eWXX5K89/PPP2/O6efS1+/Vq5fP5yE0EKOIUU6PUatXr5ZHH31UihYtasr64osvyjPPPOPzfTV+eX8WX0Iy5qV3k56bPfTQQ1ZUVJR14cIF6/Lly1bOnDmtJk2aJHjOvn37rCpVqphmXL1p12X37t2tbdu2Jfu6f9f1ed9995muVH3f3377zapcubJVr1496/z5836XL6Xmz59vyr9kyRLPsV9//dUcmzVrlufY6tWrzbHx48db6dGt0L9//wTH77jjDvP92J555hkrS5Ys1vbt2xM8T/9GtWrVSvXnCETXp3bben+fzZs3typVqmTur1271pxbv369X58jsatXr5prIXfu3Nbzzz+f5PsbOXKk59iZM2eszJkzJ/lOETqIUcQop8eoRx55xIqOjjb/n7KNGzfuhl2f/nyWUIh5tKgFyYULF0xT6j333GO62XQG5r333msG+J85c8bzvCJFisiqVatk4cKF0rNnT8mbN6+MHDlS7rzzTtPkmhpaG9H3y5Ytm2mxi4mJMU3F+tjf8qWUti7p+3zxxReeY3o/T548pkXNpt2N2tT8/vvvm6blbdu2mZa8tKI1o8Tl3rBhg1y9etU8/vbbb81kDO0O0GP2rW7duubvdPny5XT/HHbrZM6cORPcV6dPn/brc6iJEydKtWrVJFeuXKYLXrvctas6cVe50i4C75bUAgUK+HwenI8YRYwKhRgVFxcn9erVM/+fsnn/PyU1Qi3mkagFiSZLGgg1EdIxXHrT+3rx6QXqLWPGjObcsGHDzEWpF2mGDBlMM3Fq1KpVyzQX//TTTyb507LomIHUli8l9GLXLkVtRr5y5YrpAp0xY4a0bNkywVg7Tdw0KdXxXFq2cuXKmWVJ0qrf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",
      "text/plain": [
       "<Figure size 629.921x314.961 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_results(classification_results, classification=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "8f65da53",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'Gains': 0.2406197890015534, 'Losses': -0.1563820470717022, 'Total': 0.2103282085172711}\n",
      "{'Gains': 0.2398854514403057, 'Losses': -0.15745098039215677, 'Total': 0.20495695207580464}\n",
      "One-sided (alternative greater) Wilcoxon signed-rank test (mean): p-value=1.751904688047196e-77\n",
      "One-sided (alternative greater) Wilcoxon signed-rank test (median): p-value=4.078828943945483e-75\n",
      "One-sided (alternative less) Wilcoxon signed-rank test (mean): p-value=1.0\n",
      "One-sided (alternative less) Wilcoxon signed-rank test (median): p-value=1.0\n",
      "Regular Wilcoxon signed-rank test (mean): p-value=3.503809376094392e-77\n",
      "Regular Wilcoxon signed-rank test (median): p-value=8.157657887890966e-75\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 629.921x314.961 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_results_quantitative(classification_results, classification=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "16993287",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "432"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open(\"results/regression_results_syn.pkl\", \"rb\") as f:\n",
    "    regression_results = pickle.load(f)\n",
    "len(regression_results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "4efa5925",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'ASTRA better': 22, 'Same': 380, 'ASTRA worse': 30}\n",
      "{'ASTRA better': 13, 'Same': 399, 'ASTRA worse': 20}\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 629.921x314.961 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_results(regression_results, classification=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "589fb388",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'Gains': 8.806124177227456, 'Losses': -13.600764986839426, 'Total': -0.49603754098652475}\n",
      "{'Gains': 6.8143175837336605, 'Losses': -31.71301753190408, 'Total': -1.263134773262834}\n",
      "One-sided (alternative less) Wilcoxon signed-rank test (mean): p-value=0.8708594890896816\n",
      "One-sided (alternative less) Wilcoxon signed-rank test (median): p-value=0.8912652698127421\n",
      "One-sided (alternative greater) Wilcoxon signed-rank test (mean): p-value=0.12914051091031842\n",
      "One-sided (alternative greater) Wilcoxon signed-rank test (median): p-value=0.10873473018725788\n",
      "Regular Wilcoxon signed-rank test (mean): p-value=0.25828102182063684\n",
      "Regular Wilcoxon signed-rank test (median): p-value=0.21746946037451576\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 629.921x314.961 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_results_quantitative(regression_results, classification=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "25522c56",
   "metadata": {},
   "source": [
    "# ASAP Discovery x OpenADMET Challenge"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "63f0a8dd",
   "metadata": {},
   "source": [
    "## Dataset splits"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "174225ad",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "8601e3e2",
   "metadata": {},
   "outputs": [],
   "source": [
    "no_datapoints_per_fold = {}\n",
    "for dataset in [\"MDR1_MDCKII\", \"HLM\", \"KSOL\", \"MLM\", \"LogD\", \"MERS\", \"SARS\"]:\n",
    "    no_datapoints_per_fold[dataset] = {}\n",
    "    df = pd.read_pickle(f\"processed_data/{dataset}_train_splits.pkl\")\n",
    "    for random_seed in [42, 7, 21, 100, 1234]:\n",
    "        for clustering_type in [\"Random\", \"Butina\", \"BemisMurcko\", \"KMeans\"]:\n",
    "            no_datapoints_per_fold[dataset][\n",
    "                f\"{clustering_type}_Cluster_{random_seed}\"\n",
    "            ] = []\n",
    "            results = (\n",
    "                df[f\"{clustering_type}_Cluster_{random_seed}\"]\n",
    "                .value_counts()\n",
    "                .sort_index()\n",
    "            )\n",
    "            for fold in range(5):\n",
    "                no_datapoints_per_fold[dataset][\n",
    "                    f\"{clustering_type}_Cluster_{random_seed}\"\n",
    "                ].append(int(results[fold]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "4c270321",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dataset: MDR1_MDCKII, Clustering: Butina, Best Seed: 21, Std: 16.54\n",
      "Dataset: MDR1_MDCKII, Clustering: BemisMurcko, Best Seed: 100, Std: 9.14\n",
      "Dataset: MDR1_MDCKII, Clustering: KMeans, Best Seed: 100, Std: 11.85\n",
      "Dataset: HLM, Clustering: Butina, Best Seed: 100, Std: 20.69\n",
      "Dataset: HLM, Clustering: BemisMurcko, Best Seed: 7, Std: 8.41\n",
      "Dataset: HLM, Clustering: KMeans, Best Seed: 1234, Std: 8.47\n",
      "Dataset: KSOL, Clustering: Butina, Best Seed: 7, Std: 20.33\n",
      "Dataset: KSOL, Clustering: BemisMurcko, Best Seed: 1234, Std: 9.64\n",
      "Dataset: KSOL, Clustering: KMeans, Best Seed: 100, Std: 7.94\n",
      "Dataset: MLM, Clustering: Butina, Best Seed: 21, Std: 21.05\n",
      "Dataset: MLM, Clustering: BemisMurcko, Best Seed: 1234, Std: 10.11\n",
      "Dataset: MLM, Clustering: KMeans, Best Seed: 100, Std: 4.34\n",
      "Dataset: LogD, Clustering: Butina, Best Seed: 7, Std: 22.61\n",
      "Dataset: LogD, Clustering: BemisMurcko, Best Seed: 21, Std: 6.99\n",
      "Dataset: LogD, Clustering: KMeans, Best Seed: 42, Std: 7.37\n",
      "Dataset: MERS, Clustering: Butina, Best Seed: 1234, Std: 64.36\n",
      "Dataset: MERS, Clustering: BemisMurcko, Best Seed: 7, Std: 24.54\n",
      "Dataset: MERS, Clustering: KMeans, Best Seed: 42, Std: 23.36\n",
      "Dataset: SARS, Clustering: Butina, Best Seed: 42, Std: 45.80\n",
      "Dataset: SARS, Clustering: BemisMurcko, Best Seed: 1234, Std: 30.73\n",
      "Dataset: SARS, Clustering: KMeans, Best Seed: 100, Std: 22.95\n"
     ]
    }
   ],
   "source": [
    "# check which seed leads to the most balanced splits for each clustering type and dataset\n",
    "best_seeds = {}\n",
    "for dataset in no_datapoints_per_fold:\n",
    "    best_seeds[dataset] = {}\n",
    "    for clustering_type in [\"Butina\", \"BemisMurcko\", \"KMeans\"]:\n",
    "        seed_std = {}\n",
    "        for random_seed in [42, 7, 21, 100, 1234]:\n",
    "            seed_std[random_seed] = pd.Series(\n",
    "                no_datapoints_per_fold[dataset][\n",
    "                    f\"{clustering_type}_Cluster_{random_seed}\"\n",
    "                ]\n",
    "            ).std()\n",
    "        best_seed = min(seed_std, key=seed_std.get)\n",
    "        best_seeds[dataset][clustering_type] = best_seed\n",
    "        print(\n",
    "            f\"Dataset: {dataset}, Clustering: {clustering_type}, Best Seed: {best_seed}, Std: {seed_std[best_seed]:.2f}\"\n",
    "        )"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d6187c22",
   "metadata": {},
   "source": [
    "## Analyse results for `astra benchmark`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "9941e555",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "from scipy.stats import wilcoxon"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "64a29de2",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_astra_benchmark_results(results: list[dict], subset: str | None = None):\n",
    "    \"\"\"\n",
    "    Plot results of ASTRA benchmark.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    results : list[dict]\n",
    "        List of dictionaries containing benchmark results.\n",
    "    subset : str | None, optional\n",
    "        Subset of results to consider, by default None. Must be 'significant' or 'insignificant'.\n",
    "    \"\"\"\n",
    "    assert subset in (None, \"significant\", \"insignificant\"), (\n",
    "        \"subset must be 'significant', 'insignificant', or None\"\n",
    "    )\n",
    "    fig, ax = plt.subplots(1, 2, figsize=(16 * cm, 8 * cm))\n",
    "    outperformance_counts_mean = {\"ASTRA better\": 0, \"Same\": 0, \"ASTRA worse\": 0}\n",
    "    outperformance_counts_median = {\"ASTRA better\": 0, \"Same\": 0, \"ASTRA worse\": 0}\n",
    "    for result in results:\n",
    "        for split in [\"random\", \"butina\", \"bemismurcko\", \"kmeans\"]:\n",
    "            for feat in result:\n",
    "                if subset == \"insignificant\" and result[feat][split][\"p-value\"] < 0.05:\n",
    "                    continue\n",
    "                if subset == \"significant\" and result[feat][split][\"p-value\"] >= 0.05:\n",
    "                    continue\n",
    "                mse_astra = result[feat][split][\"ASTRA\"]\n",
    "                mse_best_mean = result[feat][split][\"Mean\"]\n",
    "                mse_best_median = result[feat][split][\"Median\"]\n",
    "                outperforms_mean = mse_astra < mse_best_mean\n",
    "                matches_mean = mse_astra == mse_best_mean\n",
    "                outperforms_median = mse_astra < mse_best_median\n",
    "                matches_median = mse_astra == mse_best_median\n",
    "                if outperforms_mean:\n",
    "                    outperformance_counts_mean[\"ASTRA better\"] += 1\n",
    "                elif matches_mean:\n",
    "                    outperformance_counts_mean[\"Same\"] += 1\n",
    "                else:\n",
    "                    outperformance_counts_mean[\"ASTRA worse\"] += 1\n",
    "                if outperforms_median:\n",
    "                    outperformance_counts_median[\"ASTRA better\"] += 1\n",
    "                elif matches_median:\n",
    "                    outperformance_counts_median[\"Same\"] += 1\n",
    "                else:\n",
    "                    outperformance_counts_median[\"ASTRA worse\"] += 1\n",
    "    ax[0].bar(\n",
    "        outperformance_counts_mean.keys(),\n",
    "        outperformance_counts_mean.values(),\n",
    "        color=[colour_scheme[key] for key in outperformance_counts_mean.keys()],\n",
    "    )\n",
    "    print(outperformance_counts_mean)\n",
    "    ax[0].set_ylabel(\"Number of experiments\")\n",
    "    ax[0].set_title(\"ASTRA vs. best mean\")\n",
    "    ax[1].bar(\n",
    "        outperformance_counts_median.keys(),\n",
    "        outperformance_counts_median.values(),\n",
    "        color=[colour_scheme[key] for key in outperformance_counts_median.keys()],\n",
    "    )\n",
    "    print(outperformance_counts_median)\n",
    "    ax[1].set_ylabel(\"Number of experiments\")\n",
    "    ax[1].set_title(\"ASTRA vs. best median\")\n",
    "    plt.tight_layout()\n",
    "    plt.savefig(\n",
    "        f\"figures/astra_benchmark{'_' + subset if subset is not None else ''}.png\",\n",
    "        dpi=300,\n",
    "    )\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "df108d8d",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_astra_benchmark_results_quantitative(\n",
    "    results: list[dict], subset: str | None = None\n",
    "):\n",
    "    \"\"\"\n",
    "    Plot results of ASTRA benchmark.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    results : list[dict]\n",
    "        List of dictionaries containing benchmark results.\n",
    "    subset : str | None, optional\n",
    "        Subset of results to consider, by default None. Must be 'significant' or 'insignificant'.\n",
    "    \"\"\"\n",
    "    assert subset in (None, \"significant\", \"insignificant\"), (\n",
    "        \"subset must be 'significant', 'insignificant', or None\"\n",
    "    )\n",
    "    fig, ax = plt.subplots(1, 2, figsize=(16 * cm, 8 * cm))\n",
    "    difference_mean = {\"Gains\": 0, \"Losses\": 0, \"Total\": 0}\n",
    "    denominator_mean = {\"Gains\": 0, \"Losses\": 0, \"Total\": 0}\n",
    "    difference_median = {\"Gains\": 0, \"Losses\": 0, \"Total\": 0}\n",
    "    denominator_median = {\"Gains\": 0, \"Losses\": 0, \"Total\": 0}\n",
    "    all_mses_astra = []\n",
    "    all_mses_best_mean = []\n",
    "    all_mses_best_median = []\n",
    "    for result in results:\n",
    "        for split in [\"random\", \"butina\", \"bemismurcko\", \"kmeans\"]:\n",
    "            for feat in result:\n",
    "                if subset == \"insignificant\" and result[feat][split][\"p-value\"] < 0.05:\n",
    "                    continue\n",
    "                if subset == \"significant\" and result[feat][split][\"p-value\"] >= 0.05:\n",
    "                    continue\n",
    "                mse_astra = result[feat][split][\"ASTRA\"]\n",
    "                all_mses_astra.append(mse_astra)\n",
    "                mse_best_mean = result[feat][split][\"Mean\"]\n",
    "                all_mses_best_mean.append(mse_best_mean)\n",
    "                mse_best_median = result[feat][split][\"Median\"]\n",
    "                all_mses_best_median.append(mse_best_median)\n",
    "                delta_mean = (mse_best_mean - mse_astra) / mse_best_mean * 100\n",
    "                delta_median = (mse_best_median - mse_astra) / mse_best_median * 100\n",
    "                if delta_mean > 0:\n",
    "                    difference_mean[\"Gains\"] += delta_mean\n",
    "                    denominator_mean[\"Gains\"] += 1\n",
    "                    difference_mean[\"Total\"] += delta_mean\n",
    "                    denominator_mean[\"Total\"] += 1\n",
    "                elif delta_mean < 0:\n",
    "                    difference_mean[\"Losses\"] += delta_mean\n",
    "                    denominator_mean[\"Losses\"] += 1\n",
    "                    difference_mean[\"Total\"] += delta_mean\n",
    "                    denominator_mean[\"Total\"] += 1\n",
    "                else:\n",
    "                    denominator_mean[\"Total\"] += 1\n",
    "                if delta_median > 0:\n",
    "                    difference_median[\"Gains\"] += delta_median\n",
    "                    denominator_median[\"Gains\"] += 1\n",
    "                    difference_median[\"Total\"] += delta_median\n",
    "                    denominator_median[\"Total\"] += 1\n",
    "                elif delta_median < 0:\n",
    "                    difference_median[\"Losses\"] += delta_median\n",
    "                    denominator_median[\"Losses\"] += 1\n",
    "                    difference_median[\"Total\"] += delta_median\n",
    "                    denominator_median[\"Total\"] += 1\n",
    "                else:\n",
    "                    denominator_median[\"Total\"] += 1\n",
    "    for key in difference_mean:\n",
    "        difference_mean[key] /= denominator_mean[key]\n",
    "    for key in difference_median:\n",
    "        difference_median[key] /= denominator_median[key]\n",
    "    ax[0].bar(\n",
    "        difference_mean.keys(),\n",
    "        difference_mean.values(),\n",
    "        color=[colour_scheme[key] for key in difference_mean.keys()],\n",
    "    )\n",
    "    print(difference_mean)\n",
    "    ax[0].set_ylabel(\"Mean relative MSE change [%]\")\n",
    "    ax[0].set_title(\"ASTRA vs. best mean\")\n",
    "    ax[0].axhline(0, color=\"black\", linestyle=\"--\", linewidth=0.8)\n",
    "    ax[1].bar(\n",
    "        difference_median.keys(),\n",
    "        difference_median.values(),\n",
    "        color=[colour_scheme[key] for key in difference_median.keys()],\n",
    "    )\n",
    "    print(difference_median)\n",
    "    ax[1].set_ylabel(\"Mean relative MSE change [%]\")\n",
    "    ax[1].set_title(\"ASTRA vs. best median\")\n",
    "    ax[1].axhline(0, color=\"black\", linestyle=\"--\", linewidth=0.8)\n",
    "    plt.tight_layout()\n",
    "    plt.savefig(\n",
    "        f\"figures/astra_benchmark_quantitative{'_' + subset if subset is not None else ''}.png\",\n",
    "        dpi=300,\n",
    "    )\n",
    "    # significance testing\n",
    "    _, p_value_mean = wilcoxon(\n",
    "        all_mses_astra, all_mses_best_mean, alternative=\"less\", zero_method=\"pratt\"\n",
    "    )\n",
    "    _, p_value_median = wilcoxon(\n",
    "        all_mses_astra, all_mses_best_median, alternative=\"less\", zero_method=\"pratt\"\n",
    "    )\n",
    "    print(\n",
    "        f\"One-sided (alternative: less) Wilcoxon signed-rank test (mean): p-value={p_value_mean}\"\n",
    "    )\n",
    "    print(\n",
    "        f\"One-sided (alternative: less) Wilcoxon signed-rank test (median): p-value={p_value_median}\"\n",
    "    )\n",
    "    _, p_value_mean = wilcoxon(\n",
    "        all_mses_astra, all_mses_best_mean, alternative=\"greater\", zero_method=\"pratt\"\n",
    "    )\n",
    "    _, p_value_median = wilcoxon(\n",
    "        all_mses_astra, all_mses_best_median, alternative=\"greater\", zero_method=\"pratt\"\n",
    "    )\n",
    "    print(\n",
    "        f\"One-sided (alternative: greater) Wilcoxon signed-rank test (mean): p-value={p_value_mean}\"\n",
    "    )\n",
    "    print(\n",
    "        f\"One-sided (alternative: greater) Wilcoxon signed-rank test (median): p-value={p_value_median}\"\n",
    "    )\n",
    "    _, p_value_mean = wilcoxon(all_mses_astra, all_mses_best_mean, zero_method=\"pratt\")\n",
    "    _, p_value_median = wilcoxon(\n",
    "        all_mses_astra, all_mses_best_median, zero_method=\"pratt\"\n",
    "    )\n",
    "    print(f\"Regular Wilcoxon signed-rank test (mean): p-value={p_value_mean}\")\n",
    "    print(f\"Regular Wilcoxon signed-rank test (median): p-value={p_value_median}\")\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "ee6ce68a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'ASTRA better': 52, 'Same': 246, 'ASTRA worse': 38}\n",
      "{'ASTRA better': 73, 'Same': 200, 'ASTRA worse': 63}\n"
     ]
    },
    {
     "data": {
      "image/png": "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4QabxyyYWHYFQKikZCwDgBRL1HQZFP/gpo9jYmKkRIkS1qk/mFh2BUCopGQsA4AUS9R0PToACHfEMgCuStReeeWVv32N3pH279//n5YJAEKGWAbAlYna33Ww1dGYOvqSRA2AkxHLALgyUUs4OaQ6fvy4TJ061TreFi9eXDp16hTs8gFAUBHLALi6j5r6+eef5e2335ZZs2bZwsbjxo2T++67L/ilAyJAuS9flkiy9n7nnC+xDIBrErVLly5Zk4EmaL///rs89dRTsn79eilatGhoSwgAQUQsA+DKRK1w4cK2PFP9+vWlS5cuthxTXFycbf4aN24cinICQFAQywC4MlE7ePCg/Zw/f75tyY361GWcAMCpiGUAXJmoedfTBIBwRiwDEJGLsgMAACC4SNQAAAAcikQNAADAoUjUAAAAHIpEDQAAwKFI1AAAAByKRA0AAMChSNQAAAAcikQNAADAoUjUAAAAHIpEDQAAwKFI1AAAAByKRA0AAMChSNQAAAAcikQNAADAoUjUAAAAHIpEDQAAwKFI1AAAAByKRA0AAMChSNQAAAAcikQNAADAoUjUAAAAHIpEDQAAwKFI1AAAAByKRA0AAMChSNQAAAAcikQNAADAocI+UfN4PNK/f3/JmzevZM2aVVq2bCknTpxI7WIBQMCIZwBcl6i98847MmrUKJk8ebLExsbKunXrpGPHjqldLAAIGPEMQELREuYmTpwonTp1koYNG9rzYcOGSZMmTWTcuHGSK1eueK89f/68bV7emreTJ09e02edPisR5Vq/lyT9FVlf1j/5ri6f+b9rMhJcy3flfY3WMEWSlIpnxLIAEMuuGbEsRPHME8b++usvT5o0aTzz5s3z7Tt69Kh+E56vv/460esHDhxox9j4DrgGwuMa2LVrlydSEM9S/3pj4zsQB8azKM91p3ipb+/evVKoUCH57rvvZMGCBbJ48WJZvXq1pEuXTqZNm2b91a52B3rlyhU5evSo3alGRUWJE2kmXqRIEdm1a5dky5YttYvjaHxX7vmuNCydOnVKChYsKGnShH0PjWvi9njm9GvOSfiu3PVdef5hPAvrpk//HDN37txy4403XvX1GTJksM1fTEyMhAO9AJ16EToN35U7vqvs2bNLJImUeObka85p+K7c8139k3gW1omaBjPNTg8fPiy9e/e2fceOHZPLly9Lnjx5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",
      "text/plain": [
       "<Figure size 629.921x314.961 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'ASTRA better': 34, 'Same': 161, 'ASTRA worse': 19}\n",
      "{'ASTRA better': 51, 'Same': 124, 'ASTRA worse': 39}\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 629.921x314.961 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'ASTRA better': 18, 'Same': 85, 'ASTRA worse': 19}\n",
      "{'ASTRA better': 22, 'Same': 76, 'ASTRA worse': 24}\n"
     ]
    },
    {
     "data": {
      "image/png": "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9GiTtIUSrj1wPcENsUwRzxzEcokxY8ZY999/vzVz5kyrTp06iY7169fPatiwYape5+6777Y6d+6cbH/p0qWtt99+2/t48+bNZnX6efPmeffFx8dbBQsWtDZu3GhVrlzZ+u677/w6h6FDh1pVq1a1Bg4caOXMmdMqVqyYNWnSpETPOXbsmNWpUycrX758Vv78+a1HHnnEOnr0qDm2Z88eUyZfm0fjxo19Hp86dar3OXFxcVavXr2swoULW7lz57ZatWplXjshfX6OHDmsH3/80apevboVERFhVapUyTp9+rRf56zn8fHHH6d4XM+3Xbt25rO44YYbrIoVK1qTJ09O9Jk1atTIqlChgnXrrbea60DLrWW+cuWK93mzZ882n23WrFmtKlWqWLNmzbLsEurXXocOHaynn37a57G77rrLGj58uPl9w4YNVv369c13XbRoUWvw4MHW1atXfV7Dc+bMsW666Sbz3Ntuu817fOnSpVatWrWsbNmymfJGRUVZFy9e9Ovac7tQv54UsSw0Y5kbrr8OLopnrqlB05orbXbUGrCYmBg5cOCA95jWdm3fvl3++OMPW97r0qVLMmPGDPN71qxZvft1SSpdO7R69erSvHnzZDV5qaHlPHz4sKm50xUUnnzySfntt9+8xx9++GE5evSoLFu2TFasWCEnT56URx991BwrWbKkqeFbu3atebxo0SJvTaDHnDlzzON69erJ448/7j2uNYwePXr0kF9++cU012o5ChcubJqEdQ3UhK5cuWKaJ998801Txn79+vl9vvrdLFmyJMXaxrNnz0qJEiXkyy+/NJ+N5zPRWlGPv//+23zWerc6e/ZsWbp0qaxatcpb+7l8+XLp3LmzPPfcc+bO9uWXXzaf2Zo1a8QOoX7t6bWQsKY4IT0fPX758mW57777pHjx4vLrr7/Khx9+aGoIpkyZkuxv9Pp99913zbHNmzdL+/btzX69fh566CGpW7euuV70e9fXvnr1qt/XnpuF+vXkQSwLvVjmhuuvnpvimeUCJ06csDJnzmzt3LnTPI6MjLQmTJiQ6M6ldu3aVnh4uPk5aNAga/v27X5n/XrXo7VG+jr60TVt2jTRnU3//v2t9u3bm98XLFhg3Xjjjcky8mvRbF3f459//vHu0/LqXYuKjo62smTJYp08edJ7fOvWraYsBw8e9O7z1KStW7cuxffS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",
      "text/plain": [
       "<Figure size 629.921x314.961 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "with open(\"results/LogD_results.pkl\", \"rb\") as f:\n",
    "    LogD_results = pickle.load(f)\n",
    "with open(\"results/HLM_results.pkl\", \"rb\") as f:\n",
    "    HLM_results = pickle.load(f)\n",
    "with open(\"results/KSOL_results.pkl\", \"rb\") as f:\n",
    "    KSOL_results = pickle.load(f)\n",
    "with open(\"results/MDR1_MDCKII_results.pkl\", \"rb\") as f:\n",
    "    MDR1_MDCKII_results = pickle.load(f)\n",
    "with open(\"results/MLM_results.pkl\", \"rb\") as f:\n",
    "    MLM_results = pickle.load(f)\n",
    "with open(\"results/SARS_results.pkl\", \"rb\") as f:\n",
    "    SARS_results = pickle.load(f)\n",
    "with open(\"results/MERS_results.pkl\", \"rb\") as f:\n",
    "    MERS_results = pickle.load(f)\n",
    "plot_astra_benchmark_results(\n",
    "    [\n",
    "        LogD_results,\n",
    "        HLM_results,\n",
    "        KSOL_results,\n",
    "        MDR1_MDCKII_results,\n",
    "        MLM_results,\n",
    "        SARS_results,\n",
    "        MERS_results,\n",
    "    ]\n",
    ")\n",
    "plot_astra_benchmark_results(\n",
    "    [\n",
    "        LogD_results,\n",
    "        HLM_results,\n",
    "        KSOL_results,\n",
    "        MDR1_MDCKII_results,\n",
    "        MLM_results,\n",
    "        SARS_results,\n",
    "        MERS_results,\n",
    "    ],\n",
    "    subset=\"insignificant\",\n",
    ")\n",
    "plot_astra_benchmark_results(\n",
    "    [\n",
    "        LogD_results,\n",
    "        HLM_results,\n",
    "        KSOL_results,\n",
    "        MDR1_MDCKII_results,\n",
    "        MLM_results,\n",
    "        SARS_results,\n",
    "        MERS_results,\n",
    "    ],\n",
    "    subset=\"significant\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "bcce4cea",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'Gains': 12.58981397050917, 'Losses': -14.65089724695398, 'Total': 0.2914768782209095}\n",
      "{'Gains': 12.337399575335219, 'Losses': -15.372388892390644, 'Total': -0.20187598577719976}\n",
      "One-sided (alternative: less) Wilcoxon signed-rank test (mean): p-value=0.06924576844256893\n",
      "One-sided (alternative: less) Wilcoxon signed-rank test (median): p-value=0.17512382861857034\n",
      "One-sided (alternative: greater) Wilcoxon signed-rank test (mean): p-value=0.9307542315574311\n",
      "One-sided (alternative: greater) Wilcoxon signed-rank test (median): p-value=0.8248761713814297\n",
      "Regular Wilcoxon signed-rank test (mean): p-value=0.13849153688513785\n",
      "Regular Wilcoxon signed-rank test (median): p-value=0.3502476572371407\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmsAAAEwCAYAAADo7TZNAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAO3hJREFUeJzt3QmcjXX7+PFrFmPs+5J93yPSIkIIlbImWZK1kD2ix9rjCdUjW0+ypyeEKCTylJ0KWbMUEhUhGWSbMef/ur6//zmdmTnDmXGW+9zzeb9etznne86c+d5njmuu+7uGORwOhwAAAMCSwoNdAQAAACSPZA0AAMDCSNYAAAAsjGQNAADAwkjWAAAALIxkDQAAwMJI1gAAACyMZA0AAMDCSNYAAAAsjGQtgI4cOSJhYWHm+P777z0+55tvvpHHH39c8ufPL5kyZZLy5ctLly5d5OTJk+bx559/3vUayR36HFWsWDFXWbp06aR48eLSvn17+fHHH1NdPzuYO3euOcfjx48H5eevX79eRo0aFZSfDdwOccoaiFMpExYWlmxc1XJ9PJSRrAXQp59+6vG209q1a6VmzZoSHx8v7777rnzyySfywgsvyHfffSdHjx41zxk+fLhs27bNdVStWlWKFi2aoEyf4/Tggw+asq+++kr69esnn332mdx3333y888/p7h+8F2yNnr0aN5OWBJxCnaLU127djV/B0Oa7g2KwKhVq5ajZMmSjgoVKjjuv//+JI/Xr1/fUbx4cUdsbGySx65fv+7xNevUqeMoW7asx8eKFi3qaNSoUYKy2bNn616wjtGjR6e4fnYxZ84c8x789NNPQfn5I0eOND8fsCLilDUQp1JGRExstSta1gLk3LlzsnXrVtPFqcf27dvlt99+S/CcX3/9VXLnzi2RkZFJvj8qKson9XjggQfM11OnTqW4ft64fPmy6b59+eWXkzw2YsQIiY6OlgsXLrjKdu7cKY0bNzbnnTFjRilXrpwMHjxYAmHHjh2mlVHrVLJkSXnvvfeSPEdbIDt06CB58+aV9OnTm5bMFStWJHmeN+fh7JZ2Xq26d12ntFtUu3D1+/r06SMFChSQMmXKyJo1a6Ry5cqSM2dO+fe//53i8zh79qz07NnTdL3r7zBLlixSu3Zt0+LrqXtmw4YN8sQTT0jmzJlN6+7bb7+donOA9RCniFNWj1NKe50qVapknlOhQgVZvXq1eFKqVKkE9fckVOIeyVqA6AdOuzedyZBeCCxfvjzBc6pVq2aSJE1qPHVT+oImhEo/4Cmtnzf0A/zUU0/JRx99ZF7P3YIFC8yHPHv27Ob+X3/9JY0aNZLff/9dpk+fLitXrjRdtf4698S6d+8uzzzzjOn2eeihh+TFF1+UpUuXuh7XcYKa3G7evFnefPNN835okGnWrJl88cUXrud5ex7Lli0zTfE6BlG5d11rM31q/PTTTzJjxgw5f/68ed+HDh0qbdu2lVdffVWuXLmSovM4c+aM/PnnnybJ1M/DkiVLzDjHxx57TL7++uskP7tbt27mMT0vff0BAwZ4fB5CB3GKOGX1OLV9+3Zp2bKlFC5c2NS1b9++0qlTJ48/V2OY+7l4EjJxL9hNe2nFU0895ciYMaPj6tWrjhs3bjiyZs3qaNy4cYLnnDx50lGtWjXTnKuHdmP26dPH8cMPPyT7urfrBm3YsKHpVtWf+9133zmqVq3qePjhhx1XrlxJcf28tXLlSlP/9evXu8q++eYbU7Z06VJX2fbt203ZjBkzHMHoXhg+fHiC8ooVK5r3x6lTp06OqKgox48//pjgefo7qlGjRqrPwxfdoNqF6/5+Nm3a1FG5cmVze9euXeaxPXv2pOg8EouLizOfhezZszu6deuW5P2bPHmyq+zSpUuOdOnSJXlPEVqIU8Qpq8ep5s2bO3LmzGn+VjlNnz79lt2gKTkXq8Y9WtYC4OrVq6ZJtV69eqbLTWdmPvroo2bQ/6VLl1zPK1SokHz77bfy5ZdfSv/+/SVXrlwyefJkueeee0zTa2roFYn+vAwZMpiWuzx58pgmY72f0vp5S1uZ9OfMnz/fVaa3c+TIYVrWnLTrUZuc33rrLdPE/MMPP5gWvUDRq6PE9d67d6/ExcWZ+59//rmZoKHdAlrmPGrVqmV+Tzdu3Aj6eThbKbNmzZrgtrp48WKKzkPNnj1bqlevLtmyZTPd8dr9rt3WibvNlXYVuLeo5suXz+PzEBqIU8SpUIhTO3fulIcfftj8rXJy/7uSGqEQ90jWAkATJg2EmgzpmC499LZ++PQD6i4iIsI8NmHCBPOh1A9peHi4aS5OjRo1aphm402bNpkEUOui4wdSWz9v6Idduxe1OTk2NtZ0hy5atEiefvrpBGPvNHnTxFTHd2ndypYta5YsCdQYAE2GE9+/efOm/PHHH67xOxs3bjTJq/uhCbQ+LyYmJujn4RyHoZ8R99vKmXR6ex76mdPuAh0not3Y+rnRQxNv/T0mpoEt8WfX0/MQGohTxKlQiFNnzpwx491uFctTIlTiXtKR7PA5HQyptG9bD3c6Xqp169bJfq8OgG/YsKGsW7cuVT9br170ikHpFYoOptSrCF0SRF/7TuuXHF3PberUqWYwqV4B6ZWHlnk6P/352hK1e/duM25A61CnTh3TEuhPzqTM/b4mmjpJQOlXHTPxr3/9y+P3a5JmhfO4HW/P47///a+5atSxJU4aSHU8B+yPOEWcCoU4lT9/fjP27VaxPCVCJe6RrPmZtirpgHPtypwyZUqCx3QQ+qpVq0xWrlcQp0+fNh/ExN+va6zp7BhfGD9+vGnx0kkM2mqWkvqlhA68LF26tOn+1GRNZ81ospgcvdrSK5tXXnlF/ve//8mJEyc8JjmHDh0yX7UV605pIqktj+4tC1oHvVJSOrtT66I/S5u7veHNeTivzLSLWbtP/c3b89C662yoxJNCnFe+sC/iFHEqVOJU9erVzRCda9euubpCU9MDFGpxj2TNz7Zs2WKadwcOHJgkWWnTpo0MGjTIjEdr0KCBdO7c2TQNt2rVSkqUKGGuHrQVbM+ePfLOO+/4pD46fVpb1SZNmmR2S9CuTm/rl1Lt2rUzs3q0tapXr15Jpk5rkjht2jRp0aKFmX2j5ztmzBhzBaWzMz3R6dXKF2PCNDnVlkedAv7BBx/I/v37Xa0L6rXXXjNBQK+6dMaRJpzaBK+zi7Sr2HklltLzcAbFYcOGmVlMGnD0qtLZoudr3p5HkyZNTL3HjRsn999/v1naRLtynWNMYF/EKeJUqMSpoUOHmln7zZs3l969e8svv/zicfFeLdfDeVu5z9rU8XEhFff8PoUhjRs4cKCZQXLw4MEkjx07dsw81qtXL3P/k08+MTNddBZn+vTpHXnz5nXUrl3bsWzZsmRfP6WL4qrTp0+bmZ862zMl9UupI0eOuGa2HjhwIMnjhw4dcrRu3dpRrFgx1/k2adLEsXPnzmRf0/l6d8I5q2fx4sVmppHOQNLFgD3N5jxx4oSZpXTXXXeZWT8FCxZ0PPnkkwl+J6k5jxEjRjgKFCjgCA8PT9Vijs5ZVuvWrTP3O3bsaD4Lnh7z9jx04WX9POhzoqOjHQ899JBj27Zt5r1x/xwlt1inft60Hgg9xCniVKjEKeffSp29r7G7XLlyjs8//zxJ/ZwzQJM7Qi3uhek/wU4YAQAA4BmzQQEAACyMZA0AAMDCSNYAAAAsjGQNAADAwkjWAAAALCwyrS8E+dtvv5kF/xKvAQbAmnQCuy7UqWsGOresAfEMsHM8S9PJmiZqhQsXDnY1AKTCyZMnpVChQrx3/x/xDLBvPEvTyZpzCw19k3QlewDWd/HiRXORFYgtcEIJ8QywbzxL08mas+tTEzWSNSC0MHTB8/tBPAPsF88Y8AEAAGBhJGsAAAAWRrIGAABgYSRrAAAAFkayBgAAYGFezQadMGFCil+4a9euzLAEYCnEMgChKMyhy+fehq6qq4u1RUREePWium7ZDz/8ICVKlBCrr2+SLVs2iYmJIbEEQsSd/L+1ayxTxDMg9Hj7/9brddZ27NghefPm9eq5LFYJwKqIZQBCjVfJ2siRIyVz5sxev+irr74qOXPmFLvZ/2Ha3D+0UrvbNr4CIYFY9jfiGWCzblC7Smm3AcENCD66+3zzvhDPgND5f8tsUAAAAAtLcbKm2d/HH39sbp87d87M+qxcubK0bdtWfvnlF3/UEQB8jlgGwLbJmjbXzZ4929zu2LGjFChQQL7++mupUqWKtG7d2h91BACfI5YBCBWp6gZt3LixfPbZZ7J//35p0qSJZMyY0Xw9dOiQ72sIAH5CLAMQCrxeukN9++23cv78eWnXrp28+OKLMnjwYHnuueekWbNmsnLlShk0aJD/agoAPkIsA2DLZG38+PGyZMkSyZcvn0RHR0uuXLnkiSeekAYNGsjevXulQ4cOUrFiRf/WFgDuELEMgG2TtXfffVeWLl0qFSpUMNNLP/30U5k2bZqMGzdOypYt699aAoCPEMsA2HbMmrakHT9+XH777TdJly6dPPLII7Jnzx6JjY31bw0BwIeIZQBs27L2zjvvSKdOneT69esyffp00xXar18/OX36tBQuXNi/tQQAHyGWAbBtsvbggw/KwYMHE5Q1atTIH3UCAL8hlgEINexgAAAAEOrJ2oQJE+TatWtev+jUqVPNflcAYCXEMgC2TdZ0/bRLly55/aKvvvqq2YoKAKyEWAbAtmPWHA6H1KlTRyIjvRvidvXq1TutFwD4XDBj2YEDB2T48OFmez6dVb948WJp1aqV6/H169dLnz595PDhw2Y5JO2hqF27ts9+PoDQ5VXEGjlyZIpfOGfOnKmpDwD4TTBj2eXLl6VEiRLy7LPPytNPP53gsd9//12efPJJ6dy5syxcuNCsBaf3jxw5Inny5PHJzwcQuvyWrAGA1QQzlt1///3m8OTDDz80eyy//fbbEh4eLhMnTpQFCxaYcl0iCUDaZvnZoNp10LJlSylYsKCEhYWZLa/caddB5cqVJX369Obrxo0bg1ZXAEiNnTt3So0aNUyipiIiIqRmzZqyY8eOZL9H17zUiVzuBwB7snyy5uw6mDRpUpLHnF0HupvCrl27zFgUvX/27Nmg1BUAUkNjVu7cuU0c025X3Whe798qlo0dO1ayZcvmOlicHLAvyydr2m3w5ptvJhiI66nrQPcs1a4D3QpLyz3hShSAVSc+qAwZMkiRIkUkU6ZMrrLkDB06VGJiYlzHyZMnA1RbAJbdwcAOXQd6JTp69OgA1xIAbi1v3rxmuaNy5crJ7t27Tdkff/xxy8kFOvRDDwD2Z/mWNV92HXAlCsCK7r33Xtm2bZvEx8eb+zdv3pStW7dK9erVg101ABYQnpa6DvQqNGvWrAkOAAiEGzdumFYzZ8vZ8ePHze3Tp09L27Zt5cqVK9K/f38zqUpngOrz27Vrxy8HQGgna4m7DipWrHjbrgMACAZdCLdq1armcO6moLenTZsm+fPnlxUrVshXX31lyjZs2GDuE8sAhPyYNe06GD9+vOk60HFrzq6Df/zjH8GuGgAkUKxYsVu2/NetW1f27dvHuwYg9FrW6DoAAABpmeWTNboOAABAWpbqbtAzZ87IsWPHzPgKf04fp+sAgD8FKpYBQMBa1nQA/xNPPGEGxOqaZr/++qsp19lMI0aMSHVFACCQiGUAbJus9enTx+zRuX//frN7gFPr1q1l2bJlvq4fAPgFsQyAbbtB16xZYzZL1+2d3Okm6tqVAAChgFgGwLYtazr1XJfISEy7QzNnzuyregGAXxHLANg2WdPxarpt06VLl8x97RLVRG3w4MHSpEkTf9QRAHyOWAbAtsnaxIkT5a+//jIra+v2KA8//LAUL15coqOj5a233vJPLQHAx4hlAGw7Zk03TF+3bp3ZDsW52vbdd98tderU8Uf9AMAviGUAbL/OmiZnJGgAQh2xDIDtkrV58+Yl+5guKFm0aFG5//77zV6dAGBVxDIAtk3WevXqJdeuXTMzQiMiIsyMKt1IPTIyUtKlSydXr16VMmXKyPLly81XALAiYhmAUJHi5q8xY8ZIw4YNzaK4usl6bGys7N27Vxo3biwTJkyQs2fPSvXq1aV3797+qTEA+ACxDECoCHNo01gK5M6dWzZv3izlypVLUH7o0CGpXbu22Wfv8OHD8uCDD8qff/4pVnbx4kXJli2bxMTESNasWW/7/P0fhklaVKldij4igKX+36aFWKaIZ94hniEU/9+muGVNx6Lt2LEjSfk333xjukSVLumh668BgFURywDYdszawIEDpUuXLmZMmi7ZobQbdMWKFfLaa6+Z+/pYtWrVfF9bAPARYhkA23aDOvfUmzlzpvz444/mfunSpaVbt25mLJtyvqTVW9foNvAO3QawYzeonWKZIp55h3iGUPx/m6p11ho1amSO5IRCYAMAYhkAWy+Kq8t1aCaYuGFOVwUHgFBBLANgu2Rt+/btZn2iXbt2mSDnpEmbtqjp+msAYHXEMgC2Tdaee+45KVy4sCxevFhy5Mjhn1oBgJ8RywDYNln75ZdfzMzPUqVK+adGABAAxDIAoSLF66w9/fTTsmXLFv/UBgAChFgGwLYta7oHaJ8+fWT+/PlSsmRJc9/d5MmTfVk/APALYhkA2yZruh6RLnir+4IePHgwwWMs2QEgVBDLANg2WVu3bp1/agIAAUQsA2DbMWsAAACw+KK4H374oXz++edy+fLlBGutOfcFBYBQQCwDYMuWtXHjxskLL7wg165dMwmbLoZ77NgxWb9+veTNm9c/tQQAH7NiLHv++efN2F/3Y9SoUUGpC4AQbll77733ZMGCBfLkk09KlixZZNKkSVKiRAkZMGBAkpmhAGBVVo1lDRo0kA8++MB1P3PmzEGrC4AQbVk7deqUVKlSxdyOjo42V6WqR48eMmfOHN/XEAD8wKqxLH369JI/f37XkVyydv36dbl48WKCA4A9pThZK1CggJw4ccLcLlq0qGzatMm1Gngw9gWl2wBAalgtljlt3rzZdMOWL19ehg4d6koiExs7dqxky5bNdeg2gADsKcXJWr169cygXNW1a1fp27evKWvRooW0bNlSgtVtoFfJzuPll18OSj0AhA4rxrLHH39cFi5cKF9++aUMGTJEZs2aJb169fL4XE3kYmJiXMfJkycDXl8AgZHigRnTp093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",
      "text/plain": [
       "<Figure size 629.921x314.961 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'Gains': 14.969499247181787, 'Losses': -15.367756013422314, 'Total': 1.013904720323162}\n",
      "{'Gains': 13.849030815092968, 'Losses': -16.209627231457155, 'Total': 0.34637901655566505}\n",
      "One-sided (alternative: less) Wilcoxon signed-rank test (mean): p-value=0.016824051275109143\n",
      "One-sided (alternative: less) Wilcoxon signed-rank test (median): p-value=0.08154295667227296\n",
      "One-sided (alternative: greater) Wilcoxon signed-rank test (mean): p-value=0.9831759487248909\n",
      "One-sided (alternative: greater) Wilcoxon signed-rank test (median): p-value=0.918457043327727\n",
      "Regular Wilcoxon signed-rank test (mean): p-value=0.03364810255021829\n",
      "Regular Wilcoxon signed-rank test (median): p-value=0.16308591334454592\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 629.921x314.961 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'Gains': 8.094852892349794, 'Losses': -13.934038480485643, 'Total': -0.975732615302713}\n",
      "{'Gains': 8.833163519533175, 'Losses': -14.011876591407562, 'Total': -1.1635691865905868}\n",
      "One-sided (alternative: less) Wilcoxon signed-rank test (mean): p-value=0.6156435762150234\n",
      "One-sided (alternative: less) Wilcoxon signed-rank test (median): p-value=0.6514500797158436\n",
      "One-sided (alternative: greater) Wilcoxon signed-rank test (mean): p-value=0.38435642378497653\n",
      "One-sided (alternative: greater) Wilcoxon signed-rank test (median): p-value=0.34854992028415643\n",
      "Regular Wilcoxon signed-rank test (mean): p-value=0.7687128475699531\n",
      "Regular Wilcoxon signed-rank test (median): p-value=0.6970998405683129\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmsAAAEwCAYAAADo7TZNAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAOdJJREFUeJzt3QmcTfX/+PH3rGbsxr7v2YWvFikKobJXkpJkKZRERF8MfX2jvn1lK2tISSGyJOpb9lTKHiokKrJlEMMs5/94f37/e7szc4c73Dtz7pnX8/E45t7PvXPv55x7ved9PtsJsSzLEgAAANhSaFZXAAAAAOkjWQMAALAxkjUAAAAbI1kDAACwMZI1AAAAGyNZAwAAsDGSNQAAABsjWQMAALAxkjUAAAAbI1nLRPv375eQkBCzff/9916f8/XXX8u9994rxYoVk1y5ckm1atWke/fucuTIEfP4448/7n6N9DZ9jipXrpy7LCIiQsqXLy+PPvqo/PTTT9dcPyeYM2eO2cdDhw5lyfuvXbtWRo4cmSXvDVwNccoeiFMZExISkm5c1XJ9PJiRrGWipUuXer3t8tlnn0nDhg0lOTlZpkyZIh999JE8+eSTsnXrVjlw4IB5zvDhw2Xz5s3urW7dulK2bNkUZfocl1tvvdWUffHFF9K/f3/5+OOP5aabbpJffvklw/WD/5K1UaNGcThhS8QpOC1O9ejRw/wdDGp6bVBkjttvv92qWLGiVb16devmm29O83jTpk2t8uXLWwkJCWkeu3TpktfXbNy4sVWlShWvj5UtW9Zq0aJFirJZs2bptWCtUaNGZbh+TjF79mxzDH7++ecsef/Y2Fjz/oAdEafsgTiVMSJiYqtT0bKWSU6ePClffvml6eLUbcuWLfL777+neM5vv/0mhQoVkvDw8DS/HxkZ6Zd63HLLLebn0aNHM1w/X5w/f9503z7//PNpHhsxYoRERUXJmTNn3GXfffedtGzZ0ux3zpw5pWrVqjJ48GDJDN9++61pZdQ6VaxYUaZNm5bmOdoC2aVLFylSpIjkyJHDtGQuX748zfN82Q9Xt7TrbNWz6zqj3aLahau/169fPylRooTccMMNsnr1aqldu7bExMTIf//73wzvx4kTJ6RPnz6m610/wzx58kijRo1Mi6+37pl169bJfffdJ7lz5zatu6+//nqG9gH2Q5wiTtk9TintdapZs6Z5TvXq1WXVqlXiTaVKlVLU35tgiXska5lEv3DavelKhvREYNmyZSmeU69ePZMkaVLjrZvSHzQhVPoFz2j9fKFf4DZt2sgHH3xgXs/T/PnzzZc8f/785v5ff/0lLVq0kD/++EOmT58uK1asMF21gdr31Hr16iUPPfSQ6fa57bbb5KmnnpLFixe7H9dxgprcbty4Uf7zn/+Y46FBpl27dvLpp5+6n+frfixZssQ0xesYROXZda3N9Nfi559/lhkzZsjp06fNcR86dKh07txZXnzxRblw4UKG9uP48ePy559/miRTvw+LFi0y4xzvuece+eqrr9K8d8+ePc1jul/6+gMGDPD6PAQP4hRxyu5xasuWLXL//fdL6dKlTV2fffZZ6datm9f31RjmuS/eBE3cy+qmveyiTZs2Vs6cOa2LFy9aly9ftvLmzWu1bNkyxXOOHDli1atXzzTn6qbdmP369bN+/PHHdF/3at2gzZs3N92q+r5bt2616tata91xxx3WhQsXMlw/X61YscLUf+3ate6yr7/+2pQtXrzYXbZlyxZTNmPGDCsruheGDx+eorxGjRrm+Lh069bNioyMtH766acUz9PPqEGDBte8H/7oBtUuXM/j2bZtW6t27drm9rZt28xjO3bsyNB+pJaYmGi+C/nz57d69uyZ5vhNnDjRXXbu3DkrIiIizTFFcCFOEafsHqfat29vxcTEmL9VLtOnT79iN2hG9sWucY+WtUxw8eJF06TapEkT0+WmMzPvvvtuM+j/3Llz7ueVKlVKvvnmG/n888/lueeek4IFC8rEiROlTp06pun1WugZib5fdHS0abkrXLiwaTLW+xmtn6+0lUnf57333nOX6e0CBQqYljUX7XrUJufXXnvNNDH/+OOPpkUvs+jZUep679y5UxITE839Tz75xEzQ0G4BLXNtt99+u/mcLl++nOX74WqlzJs3b4rb6uzZsxnaDzVr1iypX7++5MuXz3THa/e7dlun7jZX2lXg2aJatGhRr89DcCBOEaeCIU599913cscdd5i/VS6ef1euRTDEPZK1TKAJkwZCTYZ0TJduelu/fPoF9RQWFmYeGzdunPlS6pc0NDTUNBdfiwYNGphm4w0bNpgEUOui4weutX6+0C+7di9qc3JCQoLpDl2wYIE8+OCDKcbeafKmiamO79K6ValSxSxZ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v3B2/tLZEcfMmcfNbotxaxzxdyzZt2+fGd7hKw30pUqVkmBh9++YHXHMnHnMfIln4dk5uAFAZtm/f7+cP3/etObrWf/27dslMjLSLCPy5Zdfmq1p06bmD8tnn30m06ZNk7feeosPCEDWJWu+ILgBcIoePXrIunXrUvQElC1b1qzzFhUVZZYR0W5PXbJI13ybPn26PProo1laZwD2YOtkjeD2f7TrNjY2Nk0XLtLHMbs2HLfAudLVCHQW6NatWyU74DvGMeN7lnFZNsEAAAAAV2ePqVQAAADwimQNAADAxkjWAAAAbIxkDQAAwMZI1oKAXvM0vQWEgaw2Z84cs2K+brlz587q6sDGiGWwuzk2jWckawGmi1vedttt5qoMxYsXlyeeeMIsipkResHmxYsXixONHDlSatasmdXVCFp66SJXYPG26Rpevgaoaw1MDz30kBw9elTGjx9/Tb+P4EAsuzJi2fUjnqWPZC2AVq9eLffee69ZlXzLli3y8ccfS/ny5c31+zJCr/UXExMTsHoieE2YMMEkSrqNGDHCXG7IdV83vTZeoEVHR0uxYsVsdwko+A+xDJmBeJY+krUAGjRokFmB/F//+pfUqFHDLHw5fPhw05J06tQpefjhh6VkyZJmkcgqVaqkubTM6NGj3S0k3rpBXWdy48aNkyJFipg/mDNmzEjxHL2kTePGjd0JX7NmzdK94LQdffDBB+bY6GV59OfChQtTPK6tlHocCxUqJLly5ZJ//OMfaRYfnTx5slSsWNGsEq8rxv/zn/9M8bi2PrVr184cI2397Nu3r1y4cMH9+OXLl6V3797m+Gpiop9l6npkFU2QtF66af3DwsLc93XT+1c6hq4m/27duslff/3l9fumJxp33323Oca6/9pSrJdGQvZBLLt+xLKrI56lj2QtQLT1bNeuXdKxY0evj+s1ArUVZNGiReaapi+88IL06tVL1q9f737Oc889Z1pH9A9peg4ePCg///yzbNq0yTQhP/PMM3Ly5En34126dJHChQvLt99+Kxs3bjRJSUJCggSDvXv3SufOnc3+79692/zUxOyHH35wP0ev7KAJ6apVq2Tnzp0yZMgQSU5Odj/+3XffmWOirU76e3pJH01iPBOxFi1amCDxzTffyPLly83P559/3v2cSZMmyYcffigLFiyQPXv2yKuvvmqSICccQ88uTO2qd7XIeXa7//HHH9KqVSv53//+Z77TetKhLcbnzp3Lwj1DZiGWXT9imX/szc7xTK9gAP/bvHmzXhnC2rVrl7m/fv16K1euXGYbMGCA19+pV6+eNXTo0DTlffv2tRo3bpymPDY21rxefHy8uX/69Gnznl988YX7Oblz57YmTZpk2ZXuQ40aNbw+psdJj4mnunXrWgMHDnTfb9WqlXX//fen+/qLFi2ywsLCrDNnznh9fM6cOVaJEiWsxMREd9nHH39sRUVFWcnJyeb+008/bdWvX9+yu//85z9W2bJlM3wM1ezZs813yRdnz54137PVq1df82sgeBDLfEMs8y/iWUq0rAUuCTY/tetN1a9f37QAaRfapUuXJCkpSf79739LrVq1pECBAmZwtz6uLW4Zoa1zrmuG6usozwkM2n03YMAAadmypblItLYMBYv9+/eb4+Opdu3aptxFJ2ysWLFCbrrpJhk4cKA5W/Kk4wW1C7Rq1arStWtX003seQalrXHaLawta/oZ6PbAAw9IfHy8OSNTjzzyiPz444/ms9PZbEuWLHF/vk44hldz/Phx0+pbuXJlyZs3r+kqVhn9riI4EcuuH7HMP/Zn43hGshYgOjZKHTlyxPzUsT6VKlUyP5WOM3vttddMt512YWqipl86zy48X4SHh6cp80wktMtux44dptlXx3LVqVPHdIcGCx0/lXrfPMvat28vv/zyizz77LOmeVuT0ldeecX9eP78+U1T99y5c81gex3n17BhQ0lMTHQ/R8e56fF3bZrA/fTTT2YcoLr11lvNe+jv6u9p8tanTx9xyjG8Gu1q0K5hHfun3el6W2X0u4rgRCzzD2JZ5hxHp8YzkrUAKVGihDkDWLZsmdfHdWxa27ZtzR/+6tWrmxayw4cPB6Qu1apVMy1Ca9asMWcTOis1GGiLmCZOnjTx0nJPRYsWNRM53n33XXPG9NFHH6V4XAfW6wB5nbChrWL6GgcOHDCP6Wekt3UcmybTnptnIqxJ34MPPihTp041SVvq9wj2Y6jHyDOBTf1d7d+/vxnbd8MNN6R7BqqtktpqHCytjvANsez6Ecv8o2I2jmdpm2XgN9rCowmZDvDXFiCdAaoTAjRB0KRJBz1qVq+zGDWR0MHunlyzNnVmoj7muq+zOvXLeDX6OzpJQSc5lCtXTrZt22YmI6RuRs5q2uWoLVqetHm6e/fuZqDo2LFjpUOHDuZ4aSuhThJw0cRJWwt1n3RihSakd9xxh/vxlStXmlYynd2o//nefvtt0+VZpkwZ87gOTtXuaB2Yqq+lj+nZ1oYNG2TKlCnu6eTayqYtcBcvXjSTEOx2DNPjyzFUmpxqYFq6dKk0b97cTKBwfcf0u6oz2XQW6IkTJ2Tw4MFez2Tr1q1rzk6nT59uvvf6vdYZqgh+xDLfEMsCq3t2jmepxrDBz1auXGndfPPNZsB6yZIlrccff9w6duyYmQzQvn17MwGgWLFi1quvvmo1bdrUTCZw0Y/H27ZmzZp0B7Tq4wsXLjS3ExISrIcfftgqXbq0FRkZaZUrV84aPXq0rT5j3Qdv+9iiRQvz+Lx586zKlStb4eHh5uf777+f4vdffvllq1q1aub4FilSxBxfz8kEX375pZmckT9/fjP4vUGDBmayh6eDBw9aHTp0sPLly2eeowPwx48f73585syZ1o033mjlzJnTiomJMZ/b4cOHrWAYkOvLMXR57rnnrMKFC5vj7zmhZfv27e7vcNWqVa1Vq1aZSRuu75knPW76OehrPPvss37eQ2QlYtmVEcv8i3iWUoj+k3WpIgAAAK6EMWsAAAA2RrIGAABgYyRrAAAANkayBgAAYGMkawAAADZGsgYAAGBjJGsAAAA2RrIGAABgYyRrAAAANkayBgAAYGMkawAAAGJf/w+zicokAaWRQAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 629.921x314.961 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_astra_benchmark_results_quantitative(\n",
    "    [\n",
    "        LogD_results,\n",
    "        HLM_results,\n",
    "        KSOL_results,\n",
    "        MDR1_MDCKII_results,\n",
    "        MLM_results,\n",
    "        SARS_results,\n",
    "        MERS_results,\n",
    "    ]\n",
    ")\n",
    "plot_astra_benchmark_results_quantitative(\n",
    "    [\n",
    "        LogD_results,\n",
    "        HLM_results,\n",
    "        KSOL_results,\n",
    "        MDR1_MDCKII_results,\n",
    "        MLM_results,\n",
    "        SARS_results,\n",
    "        MERS_results,\n",
    "    ],\n",
    "    subset=\"insignificant\",\n",
    ")\n",
    "plot_astra_benchmark_results_quantitative(\n",
    "    [\n",
    "        LogD_results,\n",
    "        HLM_results,\n",
    "        KSOL_results,\n",
    "        MDR1_MDCKII_results,\n",
    "        MLM_results,\n",
    "        SARS_results,\n",
    "        MERS_results,\n",
    "    ],\n",
    "    subset=\"significant\",\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "733bc0c5",
   "metadata": {},
   "source": [
    "## Analyse results for `astra compare`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "169417b1",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/fd/sjoh5775/miniconda3/envs/astra_benchmark/lib/python3.11/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "from scipy.stats import spearmanr\n",
    "from sklearn.metrics import mean_squared_error\n",
    "from astra.utils import get_estimator_name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "ea74bc89",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_CV_scores(dirs: list[str]) -> dict:\n",
    "    \"\"\"\n",
    "    Get mean and median cross-validation scores for all models.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    dirs : list[str]\n",
    "        List of directories containing model results.\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    dict\n",
    "        Dictionary of cross-validation scores for all models.\n",
    "    \"\"\"\n",
    "    scores = {}\n",
    "    for dir in dirs:\n",
    "        with open(os.path.join(dir, \"final_CV.pkl\"), \"rb\") as f:\n",
    "            cv_scores = pickle.load(f)\n",
    "            mses = cv_scores[\"mse\"]\n",
    "            median = np.median(mses)\n",
    "            mean = np.mean(mses)\n",
    "            model_name = dir.split(\"/\")[-1]\n",
    "            scores[model_name] = {\"mean\": mean, \"median\": median}\n",
    "    return scores\n",
    "\n",
    "\n",
    "def get_test_score(model: str, test_X: np.ndarray, test_y: np.ndarray) -> float:\n",
    "    \"\"\"\n",
    "    Get the test mean squared error for a given model.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    model : str\n",
    "        Path to the model pickle file.\n",
    "    test_X : np.ndarray\n",
    "        Test features.\n",
    "    test_y : np.ndarray\n",
    "        Test target values.\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    float\n",
    "        Mean squared error on the test set.\n",
    "    \"\"\"\n",
    "    with open(model, \"rb\") as f:\n",
    "        estimator = pickle.load(f)\n",
    "    predictions = estimator.predict(test_X)\n",
    "    mse = mean_squared_error(test_y, predictions)\n",
    "    return mse\n",
    "\n",
    "\n",
    "def collect_all_test_scores(dirs: list[str], test_data: list[str]) -> dict:\n",
    "    \"\"\"\n",
    "    Collect test mean squared errors for all models.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    dirs : list[str]\n",
    "        List of directories containing model results.\n",
    "    test_data : list[str]\n",
    "        List of paths to the test data pickle files.\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    dict\n",
    "        Dictionary of test mean squared errors for all models.\n",
    "    \"\"\"\n",
    "    test_scores = {}\n",
    "    for dir, test_file in zip(dirs, test_data):\n",
    "        model_name = dir.split(\"/\")[-1]\n",
    "        model_path = os.path.join(dir, \"final_model.pkl\")\n",
    "        test_X_y = pd.read_pickle(test_file)\n",
    "        X_test = np.array(test_X_y[\"Features\"].to_list())\n",
    "        y_test = test_X_y[\"Target\"].values\n",
    "        mse = get_test_score(model_path, X_test, y_test)\n",
    "        test_scores[model_name] = mse\n",
    "    return test_scores\n",
    "\n",
    "\n",
    "def collect_results(\n",
    "    dirs: list[str], test_data: list[str], astra_model: str\n",
    ") -> tuple[float, float, float, float]:\n",
    "    \"\"\"\n",
    "    Get MSEs of the best mean, best median and the ASTRA model, along with Spearman correlation p-value.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    dirs : list[str]\n",
    "        List of directories containing model results.\n",
    "    test_data : list[str]\n",
    "        List of paths to the test data pickle files.\n",
    "    astra_model : str\n",
    "        Name of the ASTRA model.\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    tuple[float, float, float, float]\n",
    "        MSEs of best mean model, best median model, and ASTRA model,\n",
    "        and Spearman correlation p-value.\n",
    "    \"\"\"\n",
    "    CV_scores = get_CV_scores(dirs)\n",
    "    test_scores = collect_all_test_scores(dirs, test_data)\n",
    "    _, p_value = spearmanr(\n",
    "        [CV_scores[model][\"median\"] for model in CV_scores],\n",
    "        [test_scores[model] for model in test_scores],\n",
    "    )\n",
    "    best_mean_model = min(CV_scores, key=lambda x: CV_scores[x][\"mean\"])\n",
    "    best_median_model = min(CV_scores, key=lambda x: CV_scores[x][\"median\"])\n",
    "    mse_astra = test_scores[astra_model]\n",
    "    mse_best_mean = test_scores[best_mean_model]\n",
    "    mse_best_median = test_scores[best_median_model]\n",
    "    return mse_best_mean, mse_best_median, mse_astra, p_value\n",
    "\n",
    "\n",
    "def plot_astra_compare_results(\n",
    "    mses_average: list[float],\n",
    "    mses_median: list[float],\n",
    "    mses_astra: list[float],\n",
    "    pvals: list[float],\n",
    "    subset: str | None = None,\n",
    "):\n",
    "    \"\"\"\n",
    "    Plot benchmark results.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    mses_average : list[float]\n",
    "        List of MSEs of best mean models.\n",
    "    mses_median : list[float]\n",
    "        List of MSEs of best median models.\n",
    "    mses_astra : list[float]\n",
    "        List of MSEs of ASTRA models.\n",
    "    pvals : list[float]\n",
    "        List of Spearman correlation p-values.\n",
    "    subset : str | None, optional\n",
    "        Subset of results to consider, by default None. Must be 'significant' or 'insignificant'.\n",
    "    \"\"\"\n",
    "    fig, ax = plt.subplots(1, 2, figsize=(16 * cm, 8 * cm))\n",
    "    outperformance_counts_mean = {\"ASTRA better\": 0, \"Same\": 0, \"ASTRA worse\": 0}\n",
    "    outperformance_counts_median = {\"ASTRA better\": 0, \"Same\": 0, \"ASTRA worse\": 0}\n",
    "    for mse_mean, mse_median, mse_astra, p_value in zip(\n",
    "        mses_average, mses_median, mses_astra, pvals\n",
    "    ):\n",
    "        if subset == \"insignificant\" and p_value < 0.05:\n",
    "            continue\n",
    "        if subset == \"significant\" and p_value >= 0.05:\n",
    "            continue\n",
    "        delta_mean = mse_mean - mse_astra\n",
    "        delta_median = mse_median - mse_astra\n",
    "        if delta_mean > 0:\n",
    "            outperformance_counts_mean[\"ASTRA better\"] += 1\n",
    "        elif delta_mean == 0:\n",
    "            outperformance_counts_mean[\"Same\"] += 1\n",
    "        else:\n",
    "            outperformance_counts_mean[\"ASTRA worse\"] += 1\n",
    "        if delta_median > 0:\n",
    "            outperformance_counts_median[\"ASTRA better\"] += 1\n",
    "        elif delta_median == 0:\n",
    "            outperformance_counts_median[\"Same\"] += 1\n",
    "        else:\n",
    "            outperformance_counts_median[\"ASTRA worse\"] += 1\n",
    "    ax[0].bar(\n",
    "        outperformance_counts_mean.keys(),\n",
    "        outperformance_counts_mean.values(),\n",
    "        color=[colour_scheme[key] for key in outperformance_counts_mean.keys()],\n",
    "    )\n",
    "    print(outperformance_counts_mean)\n",
    "    ax[0].set_ylabel(\"Number of experiments\")\n",
    "    ax[0].set_title(\"ASTRA vs. best mean\")\n",
    "    ax[1].bar(\n",
    "        outperformance_counts_median.keys(),\n",
    "        outperformance_counts_median.values(),\n",
    "        color=[colour_scheme[key] for key in outperformance_counts_median.keys()],\n",
    "    )\n",
    "    print(outperformance_counts_median)\n",
    "    ax[1].set_ylabel(\"Number of experiments\")\n",
    "    ax[1].set_title(\"ASTRA vs. best median\")\n",
    "    plt.tight_layout()\n",
    "    plt.savefig(\n",
    "        f\"figures/astra_compare{'_' + subset if subset is not None else ''}.png\",\n",
    "        dpi=300,\n",
    "    )\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "def plot_astra_compare_results_quantitative(\n",
    "    mses_average: list[float],\n",
    "    mses_median: list[float],\n",
    "    mses_astra: list[float],\n",
    "    pvals: list[float],\n",
    "    subset: str | None = None,\n",
    "):\n",
    "    \"\"\"\n",
    "    Plot benchmark results.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    mses_average : list[float]\n",
    "        List of MSEs of best mean models.\n",
    "    mses_median : list[float]\n",
    "        List of MSEs of best median models.\n",
    "    mses_astra : list[float]\n",
    "        List of MSEs of ASTRA models.\n",
    "    pvals : list[float]\n",
    "        List of Spearman correlation p-values.\n",
    "    subset : str | None, optional\n",
    "        Subset of results to consider, by default None. Must be 'significant' or 'insignificant'.\n",
    "    \"\"\"\n",
    "    fig, ax = plt.subplots(1, 2, figsize=(16 * cm, 8 * cm))\n",
    "    difference_mean = {\"Gains\": 0, \"Losses\": 0, \"Total\": 0}\n",
    "    denominator_mean = {\"Gains\": 0, \"Losses\": 0, \"Total\": 0}\n",
    "    difference_median = {\"Gains\": 0, \"Losses\": 0, \"Total\": 0}\n",
    "    denominator_median = {\"Gains\": 0, \"Losses\": 0, \"Total\": 0}\n",
    "    clean_mses_astra = []\n",
    "    clean_mses_best_mean = []\n",
    "    clean_mses_best_median = []\n",
    "    for mse_mean, mse_median, mse_astra, p_value in zip(\n",
    "        mses_average, mses_median, mses_astra, pvals\n",
    "    ):\n",
    "        if subset == \"insignificant\" and p_value < 0.05:\n",
    "            continue\n",
    "        if subset == \"significant\" and p_value >= 0.05:\n",
    "            continue\n",
    "        clean_mses_astra.append(mse_astra)\n",
    "        clean_mses_best_mean.append(mse_mean)\n",
    "        clean_mses_best_median.append(mse_median)\n",
    "        delta_mean = (mse_mean - mse_astra) / mse_mean * 100\n",
    "        delta_median = (mse_median - mse_astra) / mse_median * 100\n",
    "        if delta_mean > 0:\n",
    "            difference_mean[\"Gains\"] += delta_mean\n",
    "            denominator_mean[\"Gains\"] += 1\n",
    "            difference_mean[\"Total\"] += delta_mean\n",
    "            denominator_mean[\"Total\"] += 1\n",
    "        elif delta_mean < 0:\n",
    "            difference_mean[\"Losses\"] += delta_mean\n",
    "            denominator_mean[\"Losses\"] += 1\n",
    "            difference_mean[\"Total\"] += delta_mean\n",
    "            denominator_mean[\"Total\"] += 1\n",
    "        else:\n",
    "            denominator_mean[\"Total\"] += 1\n",
    "        if delta_median > 0:\n",
    "            difference_median[\"Gains\"] += delta_median\n",
    "            denominator_median[\"Gains\"] += 1\n",
    "            difference_median[\"Total\"] += delta_median\n",
    "            denominator_median[\"Total\"] += 1\n",
    "        elif delta_median < 0:\n",
    "            difference_median[\"Losses\"] += delta_median\n",
    "            denominator_median[\"Losses\"] += 1\n",
    "            difference_median[\"Total\"] += delta_median\n",
    "            denominator_median[\"Total\"] += 1\n",
    "        else:\n",
    "            denominator_median[\"Total\"] += 1\n",
    "    for key in difference_mean:\n",
    "        difference_mean[key] /= denominator_mean[key]\n",
    "    for key in difference_median:\n",
    "        difference_median[key] /= denominator_median[key]\n",
    "    ax[0].bar(\n",
    "        difference_mean.keys(),\n",
    "        difference_mean.values(),\n",
    "        color=[colour_scheme[key] for key in difference_mean.keys()],\n",
    "    )\n",
    "    print(difference_mean)\n",
    "    ax[0].set_ylabel(\"Mean relative MSE change [%]\")\n",
    "    ax[0].set_title(\"ASTRA vs. best mean\")\n",
    "    ax[0].axhline(0, color=\"black\", linestyle=\"--\", linewidth=0.8)\n",
    "    ax[1].bar(\n",
    "        difference_median.keys(),\n",
    "        difference_median.values(),\n",
    "        color=[colour_scheme[key] for key in difference_median.keys()],\n",
    "    )\n",
    "    print(difference_median)\n",
    "    ax[1].set_ylabel(\"Mean relative MSE change [%]\")\n",
    "    ax[1].set_title(\"ASTRA vs. best median\")\n",
    "    ax[1].axhline(0, color=\"black\", linestyle=\"--\", linewidth=0.8)\n",
    "    plt.tight_layout()\n",
    "    plt.savefig(\n",
    "        f\"figures/astra_compare_quantitative{'_' + subset if subset is not None else ''}.png\",\n",
    "        dpi=300,\n",
    "    )\n",
    "    # significance testing\n",
    "    _, p_value_mean = wilcoxon(\n",
    "        clean_mses_astra, clean_mses_best_mean, alternative=\"less\", zero_method=\"pratt\"\n",
    "    )\n",
    "    _, p_value_median = wilcoxon(\n",
    "        clean_mses_astra,\n",
    "        clean_mses_best_median,\n",
    "        alternative=\"less\",\n",
    "        zero_method=\"pratt\",\n",
    "    )\n",
    "    print(\n",
    "        f\"One-sided (alternative: less) Wilcoxon signed-rank test (mean): p-value={p_value_mean}\"\n",
    "    )\n",
    "    print(\n",
    "        f\"One-sided (alternative: less) Wilcoxon signed-rank test (median): p-value={p_value_median}\"\n",
    "    )\n",
    "    _, p_value_mean = wilcoxon(\n",
    "        clean_mses_astra,\n",
    "        clean_mses_best_mean,\n",
    "        alternative=\"greater\",\n",
    "        zero_method=\"pratt\",\n",
    "    )\n",
    "    _, p_value_median = wilcoxon(\n",
    "        clean_mses_astra,\n",
    "        clean_mses_best_median,\n",
    "        alternative=\"greater\",\n",
    "        zero_method=\"pratt\",\n",
    "    )\n",
    "    print(\n",
    "        f\"One-sided (alternative: greater) Wilcoxon signed-rank test (mean): p-value={p_value_mean}\"\n",
    "    )\n",
    "    print(\n",
    "        f\"One-sided (alternative: greater) Wilcoxon signed-rank test (median): p-value={p_value_median}\"\n",
    "    )\n",
    "    _, p_value_mean = wilcoxon(\n",
    "        clean_mses_astra, clean_mses_best_mean, zero_method=\"pratt\"\n",
    "    )\n",
    "    _, p_value_median = wilcoxon(\n",
    "        clean_mses_astra, clean_mses_best_median, zero_method=\"pratt\"\n",
    "    )\n",
    "    print(f\"Regular Wilcoxon signed-rank test (mean): p-value={p_value_mean}\")\n",
    "    print(f\"Regular Wilcoxon signed-rank test (median): p-value={p_value_median}\")\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "def plot_fps_models(fp_list: list[str], model_list: list[str]):\n",
    "    \"\"\"\n",
    "    Plot distribution of fingerprints and models selected by ASTRA.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    fp_list : list[str]\n",
    "        List of fingerprints selected by ASTRA.\n",
    "    model_list : list[str]\n",
    "        List of models selected by ASTRA.\n",
    "    \"\"\"\n",
    "    fig, ax = plt.subplots(2, 1, figsize=(16 * cm, 16 * cm))\n",
    "    fp_counts = {}\n",
    "    for fp in fp_list:\n",
    "        if fp not in fp_counts:\n",
    "            fp_counts[fp] = 0\n",
    "        fp_counts[fp] += 1\n",
    "    fp_counts = dict(sorted(fp_counts.items(), key=lambda item: item[1], reverse=True))\n",
    "    ax[0].bar(\n",
    "        fp_counts.keys(),\n",
    "        fp_counts.values(),\n",
    "        color=mpl.rcParams[\"axes.prop_cycle\"].by_key()[\"color\"],\n",
    "    )\n",
    "    ax[0].set_ylabel(\"Number of selections\")\n",
    "    plt.setp(ax[0].get_xticklabels(), rotation=30, ha=\"right\")\n",
    "    model_counts = {}\n",
    "    for model_name in model_list:\n",
    "        model_name = model_name.replace(\"Regressor\", \"\")\n",
    "        if model_name not in model_counts:\n",
    "            model_counts[model_name] = 0\n",
    "        model_counts[model_name] += 1\n",
    "    model_counts = dict(\n",
    "        sorted(model_counts.items(), key=lambda item: item[1], reverse=True)\n",
    "    )\n",
    "    ax[1].bar(\n",
    "        model_counts.keys(),\n",
    "        model_counts.values(),\n",
    "        color=mpl.rcParams[\"axes.prop_cycle\"].by_key()[\"color\"],\n",
    "    )\n",
    "    ax[1].set_ylabel(\"Number of selections\")\n",
    "    plt.setp(ax[1].get_xticklabels(), rotation=30, ha=\"right\")\n",
    "    plt.tight_layout()\n",
    "    plt.savefig(\"figures/fingerprints_models.png\", dpi=300)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "806bb594",
   "metadata": {},
   "source": [
    "### Extract results\n",
    "\n",
    "ASTRA models were determined by running `astra compare`, as described in `README.md`. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "e6c354d9",
   "metadata": {},
   "outputs": [],
   "source": [
    "(\n",
    "    LogD_random_mse_best_mean,\n",
    "    LogD_random_mse_best_median,\n",
    "    LogD_random_mse_astra,\n",
    "    LogD_random_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/LogD_atompair_random\",\n",
    "        \"results/LogD_avalon_random\",\n",
    "        \"results/LogD_cats2d_random\",\n",
    "        \"results/LogD_desc2D_random\",\n",
    "        \"results/LogD_ecfp_random\",\n",
    "        \"results/LogD_estate_random\",\n",
    "        \"results/LogD_fcfp_random\",\n",
    "        \"results/LogD_maccs_random\",\n",
    "        \"results/LogD_pmapper_random\",\n",
    "        \"results/LogD_rdkit_random\",\n",
    "        \"results/LogD_scaffoldkeys_random\",\n",
    "        \"results/LogD_topological_random\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-admet-2025/LogD_atompair_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_avalon_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_cats2d_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_desc2D_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_ecfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_estate_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_fcfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_maccs_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_pmapper_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_rdkit_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"LogD_desc2D_random\",\n",
    ")\n",
    "(\n",
    "    LogD_butina_mse_best_mean,\n",
    "    LogD_butina_mse_best_median,\n",
    "    LogD_butina_mse_astra,\n",
    "    LogD_butina_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/LogD_atompair_butina\",\n",
    "        \"results/LogD_avalon_butina\",\n",
    "        \"results/LogD_cats2d_butina\",\n",
    "        \"results/LogD_desc2D_butina\",\n",
    "        \"results/LogD_ecfp_butina\",\n",
    "        \"results/LogD_estate_butina\",\n",
    "        \"results/LogD_fcfp_butina\",\n",
    "        \"results/LogD_maccs_butina\",\n",
    "        \"results/LogD_pmapper_butina\",\n",
    "        \"results/LogD_rdkit_butina\",\n",
    "        \"results/LogD_scaffoldkeys_butina\",\n",
    "        \"results/LogD_topological_butina\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-admet-2025/LogD_atompair_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_avalon_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_cats2d_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_desc2D_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_ecfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_estate_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_fcfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_maccs_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_pmapper_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_rdkit_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"LogD_desc2D_butina\",\n",
    ")\n",
    "(\n",
    "    LogD_bemismurcko_mse_best_mean,\n",
    "    LogD_bemismurcko_mse_best_median,\n",
    "    LogD_bemismurcko_mse_astra,\n",
    "    LogD_bemismurcko_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/LogD_atompair_bemismurcko\",\n",
    "        \"results/LogD_avalon_bemismurcko\",\n",
    "        \"results/LogD_cats2d_bemismurcko\",\n",
    "        \"results/LogD_desc2D_bemismurcko\",\n",
    "        \"results/LogD_ecfp_bemismurcko\",\n",
    "        \"results/LogD_estate_bemismurcko\",\n",
    "        \"results/LogD_fcfp_bemismurcko\",\n",
    "        \"results/LogD_maccs_bemismurcko\",\n",
    "        \"results/LogD_pmapper_bemismurcko\",\n",
    "        \"results/LogD_rdkit_bemismurcko\",\n",
    "        \"results/LogD_scaffoldkeys_bemismurcko\",\n",
    "        \"results/LogD_topological_bemismurcko\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-admet-2025/LogD_atompair_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_avalon_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_cats2d_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_desc2D_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_ecfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_estate_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_fcfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_maccs_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_pmapper_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_rdkit_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"LogD_desc2D_bemismurcko\",\n",
    ")\n",
    "(\n",
    "    LogD_kmeans_mse_best_mean,\n",
    "    LogD_kmeans_mse_best_median,\n",
    "    LogD_kmeans_mse_astra,\n",
    "    LogD_kmeans_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/LogD_atompair_kmeans\",\n",
    "        \"results/LogD_avalon_kmeans\",\n",
    "        \"results/LogD_cats2d_kmeans\",\n",
    "        \"results/LogD_desc2D_kmeans\",\n",
    "        \"results/LogD_ecfp_kmeans\",\n",
    "        \"results/LogD_estate_kmeans\",\n",
    "        \"results/LogD_fcfp_kmeans\",\n",
    "        \"results/LogD_maccs_kmeans\",\n",
    "        \"results/LogD_pmapper_kmeans\",\n",
    "        \"results/LogD_rdkit_kmeans\",\n",
    "        \"results/LogD_scaffoldkeys_kmeans\",\n",
    "        \"results/LogD_topological_kmeans\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-admet-2025/LogD_atompair_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_avalon_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_cats2d_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_desc2D_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_ecfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_estate_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_fcfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_maccs_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_pmapper_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_rdkit_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/LogD_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"LogD_desc2D_kmeans\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "10e94073",
   "metadata": {},
   "outputs": [],
   "source": [
    "(\n",
    "    HLM_random_mse_best_mean,\n",
    "    HLM_random_mse_best_median,\n",
    "    HLM_random_mse_astra,\n",
    "    HLM_random_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/HLM_atompair_random\",\n",
    "        \"results/HLM_avalon_random\",\n",
    "        \"results/HLM_cats2d_random\",\n",
    "        \"results/HLM_desc2D_random\",\n",
    "        \"results/HLM_ecfp_random\",\n",
    "        \"results/HLM_estate_random\",\n",
    "        \"results/HLM_fcfp_random\",\n",
    "        \"results/HLM_maccs_random\",\n",
    "        \"results/HLM_pmapper_random\",\n",
    "        \"results/HLM_rdkit_random\",\n",
    "        \"results/HLM_scaffoldkeys_random\",\n",
    "        \"results/HLM_topological_random\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-admet-2025/HLM_atompair_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_avalon_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_cats2d_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_desc2D_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_ecfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_estate_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_fcfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_maccs_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_pmapper_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_rdkit_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"HLM_atompair_random\",\n",
    ")\n",
    "(\n",
    "    HLM_butina_mse_best_mean,\n",
    "    HLM_butina_mse_best_median,\n",
    "    HLM_butina_mse_astra,\n",
    "    HLM_butina_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/HLM_atompair_butina\",\n",
    "        \"results/HLM_avalon_butina\",\n",
    "        \"results/HLM_cats2d_butina\",\n",
    "        \"results/HLM_desc2D_butina\",\n",
    "        \"results/HLM_ecfp_butina\",\n",
    "        \"results/HLM_estate_butina\",\n",
    "        \"results/HLM_fcfp_butina\",\n",
    "        \"results/HLM_maccs_butina\",\n",
    "        \"results/HLM_pmapper_butina\",\n",
    "        \"results/HLM_rdkit_butina\",\n",
    "        \"results/HLM_scaffoldkeys_butina\",\n",
    "        \"results/HLM_topological_butina\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-admet-2025/HLM_atompair_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_avalon_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_cats2d_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_desc2D_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_ecfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_estate_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_fcfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_maccs_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_pmapper_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_rdkit_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"HLM_atompair_butina\",\n",
    ")\n",
    "(\n",
    "    HLM_bemismurcko_mse_best_mean,\n",
    "    HLM_bemismurcko_mse_best_median,\n",
    "    HLM_bemismurcko_mse_astra,\n",
    "    HLM_bemismurcko_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/HLM_atompair_bemismurcko\",\n",
    "        \"results/HLM_avalon_bemismurcko\",\n",
    "        \"results/HLM_cats2d_bemismurcko\",\n",
    "        \"results/HLM_desc2D_bemismurcko\",\n",
    "        \"results/HLM_ecfp_bemismurcko\",\n",
    "        \"results/HLM_estate_bemismurcko\",\n",
    "        \"results/HLM_fcfp_bemismurcko\",\n",
    "        \"results/HLM_maccs_bemismurcko\",\n",
    "        \"results/HLM_pmapper_bemismurcko\",\n",
    "        \"results/HLM_rdkit_bemismurcko\",\n",
    "        \"results/HLM_scaffoldkeys_bemismurcko\",\n",
    "        \"results/HLM_topological_bemismurcko\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-admet-2025/HLM_atompair_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_avalon_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_cats2d_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_desc2D_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_ecfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_estate_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_fcfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_maccs_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_pmapper_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_rdkit_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"HLM_desc2D_bemismurcko\",\n",
    ")\n",
    "(\n",
    "    HLM_kmeans_mse_best_mean,\n",
    "    HLM_kmeans_mse_best_median,\n",
    "    HLM_kmeans_mse_astra,\n",
    "    HLM_kmeans_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/HLM_atompair_kmeans\",\n",
    "        \"results/HLM_avalon_kmeans\",\n",
    "        \"results/HLM_cats2d_kmeans\",\n",
    "        \"results/HLM_desc2D_kmeans\",\n",
    "        \"results/HLM_ecfp_kmeans\",\n",
    "        \"results/HLM_estate_kmeans\",\n",
    "        \"results/HLM_fcfp_kmeans\",\n",
    "        \"results/HLM_maccs_kmeans\",\n",
    "        \"results/HLM_pmapper_kmeans\",\n",
    "        \"results/HLM_rdkit_kmeans\",\n",
    "        \"results/HLM_scaffoldkeys_kmeans\",\n",
    "        \"results/HLM_topological_kmeans\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-admet-2025/HLM_atompair_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_avalon_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_cats2d_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_desc2D_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_ecfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_estate_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_fcfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_maccs_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_pmapper_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_rdkit_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/HLM_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"HLM_topological_kmeans\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "58d9245a",
   "metadata": {},
   "outputs": [],
   "source": [
    "(\n",
    "    KSOL_random_mse_best_mean,\n",
    "    KSOL_random_mse_best_median,\n",
    "    KSOL_random_mse_astra,\n",
    "    KSOL_random_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/KSOL_atompair_random\",\n",
    "        \"results/KSOL_avalon_random\",\n",
    "        \"results/KSOL_cats2d_random\",\n",
    "        \"results/KSOL_desc2D_random\",\n",
    "        \"results/KSOL_ecfp_random\",\n",
    "        \"results/KSOL_estate_random\",\n",
    "        \"results/KSOL_fcfp_random\",\n",
    "        \"results/KSOL_maccs_random\",\n",
    "        \"results/KSOL_pmapper_random\",\n",
    "        \"results/KSOL_rdkit_random\",\n",
    "        \"results/KSOL_scaffoldkeys_random\",\n",
    "        \"results/KSOL_topological_random\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-admet-2025/KSOL_atompair_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_avalon_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_cats2d_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_desc2D_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_ecfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_estate_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_fcfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_maccs_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_pmapper_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_rdkit_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"KSOL_desc2D_random\",\n",
    ")\n",
    "(\n",
    "    KSOL_butina_mse_best_mean,\n",
    "    KSOL_butina_mse_best_median,\n",
    "    KSOL_butina_mse_astra,\n",
    "    KSOL_butina_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/KSOL_atompair_butina\",\n",
    "        \"results/KSOL_avalon_butina\",\n",
    "        \"results/KSOL_cats2d_butina\",\n",
    "        \"results/KSOL_desc2D_butina\",\n",
    "        \"results/KSOL_ecfp_butina\",\n",
    "        \"results/KSOL_estate_butina\",\n",
    "        \"results/KSOL_fcfp_butina\",\n",
    "        \"results/KSOL_maccs_butina\",\n",
    "        \"results/KSOL_pmapper_butina\",\n",
    "        \"results/KSOL_rdkit_butina\",\n",
    "        \"results/KSOL_scaffoldkeys_butina\",\n",
    "        \"results/KSOL_topological_butina\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-admet-2025/KSOL_atompair_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_avalon_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_cats2d_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_desc2D_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_ecfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_estate_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_fcfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_maccs_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_pmapper_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_rdkit_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"KSOL_desc2D_butina\",\n",
    ")\n",
    "(\n",
    "    KSOL_bemismurcko_mse_best_mean,\n",
    "    KSOL_bemismurcko_mse_best_median,\n",
    "    KSOL_bemismurcko_mse_astra,\n",
    "    KSOL_bemismurcko_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/KSOL_atompair_bemismurcko\",\n",
    "        \"results/KSOL_avalon_bemismurcko\",\n",
    "        \"results/KSOL_cats2d_bemismurcko\",\n",
    "        \"results/KSOL_desc2D_bemismurcko\",\n",
    "        \"results/KSOL_ecfp_bemismurcko\",\n",
    "        \"results/KSOL_estate_bemismurcko\",\n",
    "        \"results/KSOL_fcfp_bemismurcko\",\n",
    "        \"results/KSOL_maccs_bemismurcko\",\n",
    "        \"results/KSOL_pmapper_bemismurcko\",\n",
    "        \"results/KSOL_rdkit_bemismurcko\",\n",
    "        \"results/KSOL_scaffoldkeys_bemismurcko\",\n",
    "        \"results/KSOL_topological_bemismurcko\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-admet-2025/KSOL_atompair_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_avalon_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_cats2d_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_desc2D_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_ecfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_estate_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_fcfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_maccs_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_pmapper_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_rdkit_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"KSOL_estate_bemismurcko\",\n",
    ")\n",
    "(\n",
    "    KSOL_kmeans_mse_best_mean,\n",
    "    KSOL_kmeans_mse_best_median,\n",
    "    KSOL_kmeans_mse_astra,\n",
    "    KSOL_kmeans_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/KSOL_atompair_kmeans\",\n",
    "        \"results/KSOL_avalon_kmeans\",\n",
    "        \"results/KSOL_cats2d_kmeans\",\n",
    "        \"results/KSOL_desc2D_kmeans\",\n",
    "        \"results/KSOL_ecfp_kmeans\",\n",
    "        \"results/KSOL_estate_kmeans\",\n",
    "        \"results/KSOL_fcfp_kmeans\",\n",
    "        \"results/KSOL_maccs_kmeans\",\n",
    "        \"results/KSOL_pmapper_kmeans\",\n",
    "        \"results/KSOL_rdkit_kmeans\",\n",
    "        \"results/KSOL_scaffoldkeys_kmeans\",\n",
    "        \"results/KSOL_topological_kmeans\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-admet-2025/KSOL_atompair_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_avalon_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_cats2d_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_desc2D_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_ecfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_estate_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_fcfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_maccs_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_pmapper_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_rdkit_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/KSOL_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"KSOL_avalon_kmeans\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "bccbdde1",
   "metadata": {},
   "outputs": [],
   "source": [
    "(\n",
    "    MDR1_MDCKII_random_mse_best_mean,\n",
    "    MDR1_MDCKII_random_mse_best_median,\n",
    "    MDR1_MDCKII_random_mse_astra,\n",
    "    MDR1_MDCKII_random_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/MDR1_MDCKII_atompair_random\",\n",
    "        \"results/MDR1_MDCKII_avalon_random\",\n",
    "        \"results/MDR1_MDCKII_cats2d_random\",\n",
    "        \"results/MDR1_MDCKII_desc2D_random\",\n",
    "        \"results/MDR1_MDCKII_ecfp_random\",\n",
    "        \"results/MDR1_MDCKII_estate_random\",\n",
    "        \"results/MDR1_MDCKII_fcfp_random\",\n",
    "        \"results/MDR1_MDCKII_maccs_random\",\n",
    "        \"results/MDR1_MDCKII_pmapper_random\",\n",
    "        \"results/MDR1_MDCKII_rdkit_random\",\n",
    "        \"results/MDR1_MDCKII_scaffoldkeys_random\",\n",
    "        \"results/MDR1_MDCKII_topological_random\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_atompair_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_avalon_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_cats2d_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_desc2D_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_ecfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_estate_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_fcfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_maccs_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_pmapper_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_rdkit_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"MDR1_MDCKII_desc2D_random\",\n",
    ")\n",
    "(\n",
    "    MDR1_MDCKII_butina_mse_best_mean,\n",
    "    MDR1_MDCKII_butina_mse_best_median,\n",
    "    MDR1_MDCKII_butina_mse_astra,\n",
    "    MDR1_MDCKII_butina_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/MDR1_MDCKII_atompair_butina\",\n",
    "        \"results/MDR1_MDCKII_avalon_butina\",\n",
    "        \"results/MDR1_MDCKII_cats2d_butina\",\n",
    "        \"results/MDR1_MDCKII_desc2D_butina\",\n",
    "        \"results/MDR1_MDCKII_ecfp_butina\",\n",
    "        \"results/MDR1_MDCKII_estate_butina\",\n",
    "        \"results/MDR1_MDCKII_fcfp_butina\",\n",
    "        \"results/MDR1_MDCKII_maccs_butina\",\n",
    "        \"results/MDR1_MDCKII_pmapper_butina\",\n",
    "        \"results/MDR1_MDCKII_rdkit_butina\",\n",
    "        \"results/MDR1_MDCKII_scaffoldkeys_butina\",\n",
    "        \"results/MDR1_MDCKII_topological_butina\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_atompair_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_avalon_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_cats2d_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_desc2D_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_ecfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_estate_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_fcfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_maccs_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_pmapper_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_rdkit_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"MDR1_MDCKII_desc2D_butina\",\n",
    ")\n",
    "(\n",
    "    MDR1_MDCKII_bemismurcko_mse_best_mean,\n",
    "    MDR1_MDCKII_bemismurcko_mse_best_median,\n",
    "    MDR1_MDCKII_bemismurcko_mse_astra,\n",
    "    MDR1_MDCKII_bemismurcko_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/MDR1_MDCKII_atompair_bemismurcko\",\n",
    "        \"results/MDR1_MDCKII_avalon_bemismurcko\",\n",
    "        \"results/MDR1_MDCKII_cats2d_bemismurcko\",\n",
    "        \"results/MDR1_MDCKII_desc2D_bemismurcko\",\n",
    "        \"results/MDR1_MDCKII_ecfp_bemismurcko\",\n",
    "        \"results/MDR1_MDCKII_estate_bemismurcko\",\n",
    "        \"results/MDR1_MDCKII_fcfp_bemismurcko\",\n",
    "        \"results/MDR1_MDCKII_maccs_bemismurcko\",\n",
    "        \"results/MDR1_MDCKII_pmapper_bemismurcko\",\n",
    "        \"results/MDR1_MDCKII_rdkit_bemismurcko\",\n",
    "        \"results/MDR1_MDCKII_scaffoldkeys_bemismurcko\",\n",
    "        \"results/MDR1_MDCKII_topological_bemismurcko\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_atompair_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_avalon_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_cats2d_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_desc2D_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_ecfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_estate_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_fcfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_maccs_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_pmapper_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_rdkit_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"MDR1_MDCKII_estate_bemismurcko\",\n",
    ")\n",
    "(\n",
    "    MDR1_MDCKII_kmeans_mse_best_mean,\n",
    "    MDR1_MDCKII_kmeans_mse_best_median,\n",
    "    MDR1_MDCKII_kmeans_mse_astra,\n",
    "    MDR1_MDCKII_kmeans_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/MDR1_MDCKII_atompair_kmeans\",\n",
    "        \"results/MDR1_MDCKII_avalon_kmeans\",\n",
    "        \"results/MDR1_MDCKII_cats2d_kmeans\",\n",
    "        \"results/MDR1_MDCKII_desc2D_kmeans\",\n",
    "        \"results/MDR1_MDCKII_ecfp_kmeans\",\n",
    "        \"results/MDR1_MDCKII_estate_kmeans\",\n",
    "        \"results/MDR1_MDCKII_fcfp_kmeans\",\n",
    "        \"results/MDR1_MDCKII_maccs_kmeans\",\n",
    "        \"results/MDR1_MDCKII_pmapper_kmeans\",\n",
    "        \"results/MDR1_MDCKII_rdkit_kmeans\",\n",
    "        \"results/MDR1_MDCKII_scaffoldkeys_kmeans\",\n",
    "        \"results/MDR1_MDCKII_topological_kmeans\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_atompair_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_avalon_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_cats2d_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_desc2D_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_ecfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_estate_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_fcfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_maccs_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_pmapper_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_rdkit_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MDR1_MDCKII_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"MDR1_MDCKII_cats2d_kmeans\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "c505109b",
   "metadata": {},
   "outputs": [],
   "source": [
    "(\n",
    "    MLM_random_mse_best_mean,\n",
    "    MLM_random_mse_best_median,\n",
    "    MLM_random_mse_astra,\n",
    "    MLM_random_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/MLM_atompair_random\",\n",
    "        \"results/MLM_avalon_random\",\n",
    "        \"results/MLM_cats2d_random\",\n",
    "        \"results/MLM_desc2D_random\",\n",
    "        \"results/MLM_ecfp_random\",\n",
    "        \"results/MLM_estate_random\",\n",
    "        \"results/MLM_fcfp_random\",\n",
    "        \"results/MLM_maccs_random\",\n",
    "        \"results/MLM_pmapper_random\",\n",
    "        \"results/MLM_rdkit_random\",\n",
    "        \"results/MLM_scaffoldkeys_random\",\n",
    "        \"results/MLM_topological_random\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-admet-2025/MLM_atompair_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_avalon_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_cats2d_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_desc2D_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_ecfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_estate_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_fcfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_maccs_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_pmapper_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_rdkit_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"MLM_fcfp_random\",\n",
    ")\n",
    "(\n",
    "    MLM_butina_mse_best_mean,\n",
    "    MLM_butina_mse_best_median,\n",
    "    MLM_butina_mse_astra,\n",
    "    MLM_butina_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/MLM_atompair_butina\",\n",
    "        \"results/MLM_avalon_butina\",\n",
    "        \"results/MLM_cats2d_butina\",\n",
    "        \"results/MLM_desc2D_butina\",\n",
    "        \"results/MLM_ecfp_butina\",\n",
    "        \"results/MLM_estate_butina\",\n",
    "        \"results/MLM_fcfp_butina\",\n",
    "        \"results/MLM_maccs_butina\",\n",
    "        \"results/MLM_pmapper_butina\",\n",
    "        \"results/MLM_rdkit_butina\",\n",
    "        \"results/MLM_scaffoldkeys_butina\",\n",
    "        \"results/MLM_topological_butina\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-admet-2025/MLM_atompair_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_avalon_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_cats2d_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_desc2D_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_ecfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_estate_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_fcfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_maccs_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_pmapper_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_rdkit_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"MLM_pmapper_butina\",\n",
    ")\n",
    "(\n",
    "    MLM_bemismurcko_mse_best_mean,\n",
    "    MLM_bemismurcko_mse_best_median,\n",
    "    MLM_bemismurcko_mse_astra,\n",
    "    MLM_bemismurcko_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/MLM_atompair_bemismurcko\",\n",
    "        \"results/MLM_avalon_bemismurcko\",\n",
    "        \"results/MLM_cats2d_bemismurcko\",\n",
    "        \"results/MLM_desc2D_bemismurcko\",\n",
    "        \"results/MLM_ecfp_bemismurcko\",\n",
    "        \"results/MLM_estate_bemismurcko\",\n",
    "        \"results/MLM_fcfp_bemismurcko\",\n",
    "        \"results/MLM_maccs_bemismurcko\",\n",
    "        \"results/MLM_pmapper_bemismurcko\",\n",
    "        \"results/MLM_rdkit_bemismurcko\",\n",
    "        \"results/MLM_scaffoldkeys_bemismurcko\",\n",
    "        \"results/MLM_topological_bemismurcko\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-admet-2025/MLM_atompair_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_avalon_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_cats2d_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_desc2D_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_ecfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_estate_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_fcfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_maccs_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_pmapper_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_rdkit_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"MLM_topological_bemismurcko\",\n",
    ")\n",
    "(\n",
    "    MLM_kmeans_mse_best_mean,\n",
    "    MLM_kmeans_mse_best_median,\n",
    "    MLM_kmeans_mse_astra,\n",
    "    MLM_kmeans_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/MLM_atompair_kmeans\",\n",
    "        \"results/MLM_avalon_kmeans\",\n",
    "        \"results/MLM_cats2d_kmeans\",\n",
    "        \"results/MLM_desc2D_kmeans\",\n",
    "        \"results/MLM_ecfp_kmeans\",\n",
    "        \"results/MLM_estate_kmeans\",\n",
    "        \"results/MLM_fcfp_kmeans\",\n",
    "        \"results/MLM_maccs_kmeans\",\n",
    "        \"results/MLM_pmapper_kmeans\",\n",
    "        \"results/MLM_rdkit_kmeans\",\n",
    "        \"results/MLM_scaffoldkeys_kmeans\",\n",
    "        \"results/MLM_topological_kmeans\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-admet-2025/MLM_atompair_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_avalon_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_cats2d_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_desc2D_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_ecfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_estate_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_fcfp_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_maccs_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_pmapper_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_rdkit_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-admet-2025/MLM_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"MLM_desc2D_kmeans\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "b638524a",
   "metadata": {},
   "outputs": [],
   "source": [
    "(\n",
    "    SARS_random_mse_best_mean,\n",
    "    SARS_random_mse_best_median,\n",
    "    SARS_random_mse_astra,\n",
    "    SARS_random_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/SARS_atompair_random\",\n",
    "        \"results/SARS_avalon_random\",\n",
    "        \"results/SARS_cats2d_random\",\n",
    "        \"results/SARS_desc2D_random\",\n",
    "        \"results/SARS_ecfp_random\",\n",
    "        \"results/SARS_estate_random\",\n",
    "        \"results/SARS_fcfp_random\",\n",
    "        \"results/SARS_maccs_random\",\n",
    "        \"results/SARS_pmapper_random\",\n",
    "        \"results/SARS_rdkit_random\",\n",
    "        \"results/SARS_scaffoldkeys_random\",\n",
    "        \"results/SARS_topological_random\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-potency-2025/SARS_atompair_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_avalon_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_cats2d_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_desc2D_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_ecfp_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_estate_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_fcfp_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_maccs_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_pmapper_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_rdkit_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"SARS_rdkit_random\",\n",
    ")\n",
    "(\n",
    "    SARS_butina_mse_best_mean,\n",
    "    SARS_butina_mse_best_median,\n",
    "    SARS_butina_mse_astra,\n",
    "    SARS_butina_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/SARS_atompair_butina\",\n",
    "        \"results/SARS_avalon_butina\",\n",
    "        \"results/SARS_cats2d_butina\",\n",
    "        \"results/SARS_desc2D_butina\",\n",
    "        \"results/SARS_ecfp_butina\",\n",
    "        \"results/SARS_estate_butina\",\n",
    "        \"results/SARS_fcfp_butina\",\n",
    "        \"results/SARS_maccs_butina\",\n",
    "        \"results/SARS_pmapper_butina\",\n",
    "        \"results/SARS_rdkit_butina\",\n",
    "        \"results/SARS_scaffoldkeys_butina\",\n",
    "        \"results/SARS_topological_butina\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-potency-2025/SARS_atompair_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_avalon_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_cats2d_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_desc2D_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_ecfp_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_estate_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_fcfp_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_maccs_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_pmapper_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_rdkit_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"SARS_desc2D_butina\",\n",
    ")\n",
    "(\n",
    "    SARS_bemismurcko_mse_best_mean,\n",
    "    SARS_bemismurcko_mse_best_median,\n",
    "    SARS_bemismurcko_mse_astra,\n",
    "    SARS_bemismurcko_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/SARS_atompair_bemismurcko\",\n",
    "        \"results/SARS_avalon_bemismurcko\",\n",
    "        \"results/SARS_cats2d_bemismurcko\",\n",
    "        \"results/SARS_desc2D_bemismurcko\",\n",
    "        \"results/SARS_ecfp_bemismurcko\",\n",
    "        \"results/SARS_estate_bemismurcko\",\n",
    "        \"results/SARS_fcfp_bemismurcko\",\n",
    "        \"results/SARS_maccs_bemismurcko\",\n",
    "        \"results/SARS_pmapper_bemismurcko\",\n",
    "        \"results/SARS_rdkit_bemismurcko\",\n",
    "        \"results/SARS_scaffoldkeys_bemismurcko\",\n",
    "        \"results/SARS_topological_bemismurcko\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-potency-2025/SARS_atompair_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_avalon_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_cats2d_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_desc2D_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_ecfp_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_estate_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_fcfp_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_maccs_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_pmapper_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_rdkit_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"SARS_pmapper_bemismurcko\",\n",
    ")\n",
    "(\n",
    "    SARS_kmeans_mse_best_mean,\n",
    "    SARS_kmeans_mse_best_median,\n",
    "    SARS_kmeans_mse_astra,\n",
    "    SARS_kmeans_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/SARS_atompair_kmeans\",\n",
    "        \"results/SARS_avalon_kmeans\",\n",
    "        \"results/SARS_cats2d_kmeans\",\n",
    "        \"results/SARS_desc2D_kmeans\",\n",
    "        \"results/SARS_ecfp_kmeans\",\n",
    "        \"results/SARS_estate_kmeans\",\n",
    "        \"results/SARS_fcfp_kmeans\",\n",
    "        \"results/SARS_maccs_kmeans\",\n",
    "        \"results/SARS_pmapper_kmeans\",\n",
    "        \"results/SARS_rdkit_kmeans\",\n",
    "        \"results/SARS_scaffoldkeys_kmeans\",\n",
    "        \"results/SARS_topological_kmeans\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-potency-2025/SARS_atompair_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_avalon_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_cats2d_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_desc2D_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_ecfp_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_estate_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_fcfp_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_maccs_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_pmapper_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_rdkit_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/SARS_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"SARS_atompair_kmeans\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "54ea09bd",
   "metadata": {},
   "outputs": [],
   "source": [
    "(\n",
    "    MERS_random_mse_best_mean,\n",
    "    MERS_random_mse_best_median,\n",
    "    MERS_random_mse_astra,\n",
    "    MERS_random_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/MERS_atompair_random\",\n",
    "        \"results/MERS_avalon_random\",\n",
    "        \"results/MERS_cats2d_random\",\n",
    "        \"results/MERS_desc2D_random\",\n",
    "        \"results/MERS_ecfp_random\",\n",
    "        \"results/MERS_estate_random\",\n",
    "        \"results/MERS_fcfp_random\",\n",
    "        \"results/MERS_maccs_random\",\n",
    "        \"results/MERS_pmapper_random\",\n",
    "        \"results/MERS_rdkit_random\",\n",
    "        \"results/MERS_scaffoldkeys_random\",\n",
    "        \"results/MERS_topological_random\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-potency-2025/MERS_atompair_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_avalon_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_cats2d_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_desc2D_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_ecfp_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_estate_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_fcfp_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_maccs_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_pmapper_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_rdkit_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"MERS_atompair_random\",\n",
    ")\n",
    "(\n",
    "    MERS_butina_mse_best_mean,\n",
    "    MERS_butina_mse_best_median,\n",
    "    MERS_butina_mse_astra,\n",
    "    MERS_butina_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/MERS_atompair_butina\",\n",
    "        \"results/MERS_avalon_butina\",\n",
    "        \"results/MERS_cats2d_butina\",\n",
    "        \"results/MERS_desc2D_butina\",\n",
    "        \"results/MERS_ecfp_butina\",\n",
    "        \"results/MERS_estate_butina\",\n",
    "        \"results/MERS_fcfp_butina\",\n",
    "        \"results/MERS_maccs_butina\",\n",
    "        \"results/MERS_pmapper_butina\",\n",
    "        \"results/MERS_rdkit_butina\",\n",
    "        \"results/MERS_scaffoldkeys_butina\",\n",
    "        \"results/MERS_topological_butina\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-potency-2025/MERS_atompair_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_avalon_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_cats2d_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_desc2D_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_ecfp_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_estate_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_fcfp_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_maccs_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_pmapper_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_rdkit_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"MERS_scaffoldkeys_butina\",\n",
    ")\n",
    "(\n",
    "    MERS_bemismurcko_mse_best_mean,\n",
    "    MERS_bemismurcko_mse_best_median,\n",
    "    MERS_bemismurcko_mse_astra,\n",
    "    MERS_bemismurcko_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/MERS_atompair_bemismurcko\",\n",
    "        \"results/MERS_avalon_bemismurcko\",\n",
    "        \"results/MERS_cats2d_bemismurcko\",\n",
    "        \"results/MERS_desc2D_bemismurcko\",\n",
    "        \"results/MERS_ecfp_bemismurcko\",\n",
    "        \"results/MERS_estate_bemismurcko\",\n",
    "        \"results/MERS_fcfp_bemismurcko\",\n",
    "        \"results/MERS_maccs_bemismurcko\",\n",
    "        \"results/MERS_pmapper_bemismurcko\",\n",
    "        \"results/MERS_rdkit_bemismurcko\",\n",
    "        \"results/MERS_scaffoldkeys_bemismurcko\",\n",
    "        \"results/MERS_topological_bemismurcko\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-potency-2025/MERS_atompair_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_avalon_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_cats2d_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_desc2D_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_ecfp_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_estate_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_fcfp_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_maccs_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_pmapper_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_rdkit_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"MERS_topological_bemismurcko\",\n",
    ")\n",
    "(\n",
    "    MERS_kmeans_mse_best_mean,\n",
    "    MERS_kmeans_mse_best_median,\n",
    "    MERS_kmeans_mse_astra,\n",
    "    MERS_kmeans_pvalue,\n",
    ") = collect_results(\n",
    "    [\n",
    "        \"results/MERS_atompair_kmeans\",\n",
    "        \"results/MERS_avalon_kmeans\",\n",
    "        \"results/MERS_cats2d_kmeans\",\n",
    "        \"results/MERS_desc2D_kmeans\",\n",
    "        \"results/MERS_ecfp_kmeans\",\n",
    "        \"results/MERS_estate_kmeans\",\n",
    "        \"results/MERS_fcfp_kmeans\",\n",
    "        \"results/MERS_maccs_kmeans\",\n",
    "        \"results/MERS_pmapper_kmeans\",\n",
    "        \"results/MERS_rdkit_kmeans\",\n",
    "        \"results/MERS_scaffoldkeys_kmeans\",\n",
    "        \"results/MERS_topological_kmeans\",\n",
    "    ],\n",
    "    [\n",
    "        \"features/antiviral-potency-2025/MERS_atompair_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_avalon_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_cats2d_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_desc2D_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_ecfp_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_estate_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_fcfp_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_maccs_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_pmapper_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_rdkit_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_scaffoldkeys_test.pkl\",\n",
    "        \"features/antiviral-potency-2025/MERS_topological_test.pkl\",\n",
    "    ],\n",
    "    astra_model=\"MERS_maccs_kmeans\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "a916e1ba",
   "metadata": {},
   "outputs": [],
   "source": [
    "astra_selected_models = [\n",
    "    \"LogD_desc2D_random\",\n",
    "    \"LogD_desc2D_butina\",\n",
    "    \"LogD_desc2D_bemismurcko\",\n",
    "    \"LogD_desc2D_kmeans\",\n",
    "    \"HLM_atompair_random\",\n",
    "    \"HLM_atompair_butina\",\n",
    "    \"HLM_desc2D_bemismurcko\",\n",
    "    \"HLM_topological_kmeans\",\n",
    "    \"KSOL_desc2D_random\",\n",
    "    \"KSOL_desc2D_butina\",\n",
    "    \"KSOL_estate_bemismurcko\",\n",
    "    \"KSOL_avalon_kmeans\",\n",
    "    \"MDR1_MDCKII_desc2D_random\",\n",
    "    \"MDR1_MDCKII_desc2D_butina\",\n",
    "    \"MDR1_MDCKII_estate_bemismurcko\",\n",
    "    \"MDR1_MDCKII_cats2d_kmeans\",\n",
    "    \"MLM_fcfp_random\",\n",
    "    \"MLM_pmapper_butina\",\n",
    "    \"MLM_topological_bemismurcko\",\n",
    "    \"MLM_desc2D_kmeans\",\n",
    "    \"SARS_rdkit_random\",\n",
    "    \"SARS_desc2D_butina\",\n",
    "    \"SARS_pmapper_bemismurcko\",\n",
    "    \"SARS_atompair_kmeans\",\n",
    "    \"MERS_atompair_random\",\n",
    "    \"MERS_scaffoldkeys_butina\",\n",
    "    \"MERS_topological_bemismurcko\",\n",
    "    \"MERS_maccs_kmeans\",\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "89bce43b",
   "metadata": {},
   "outputs": [],
   "source": [
    "selected_fingerprints = []\n",
    "for model in astra_selected_models:\n",
    "    fingerprint = model.split(\"_\")[-2]\n",
    "    selected_fingerprints.append(fingerprint)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "a666b8bd",
   "metadata": {},
   "outputs": [],
   "source": [
    "selected_models = []\n",
    "for model in astra_selected_models:\n",
    "    with open(os.path.join(\"results\", model, \"final_model.pkl\"), \"rb\") as f:\n",
    "        m = pickle.load(f)\n",
    "    selected_models.append(get_estimator_name(m))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9c331749",
   "metadata": {},
   "source": [
    "### Plot results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "7c70fc2b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'ASTRA better': 5, 'Same': 16, 'ASTRA worse': 7}\n",
      "{'ASTRA better': 8, 'Same': 16, 'ASTRA worse': 4}\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmsAAAEwCAYAAADo7TZNAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAOCRJREFUeJzt3Qd4FGW78PE7tNAJ1VAiXRAFDQYEqQoKooD0IgiiAsoRAUVeVJqvCipIEaUpcESRdkApKipFlCIdFORFemjSCTW0+a77Od/uSdlANuxuZmf/v+sakp3dnX12M9x7z1PDLMuyBAAAALaUIb0LAAAAgJSRrAEAANgYyRoAAICNkawBAADYGMkaAACAjZGsAQAA2BjJGgAAgI2RrAEAANgYyRoAAICNkawF2K5duyQsLMxs27Zt8/iY33//XRo1aiSRkZGSI0cOufvuu+W5556T2NhYc3/nzp3dx0hp08eoEiVKuPdlzpxZSpYsKR06dJC///47zeVzgqlTp5r3uG/fvnR5/eXLl8vgwYPT5bWBWyFO2QNxyjthYWEpxlXdr/cHK5K1APv22289/u7y008/SY0aNeTGjRsybtw4+eabb6Rbt26yceNG2b17t3nMgAEDZPXq1e4tOjpaihcvnmifPsalWrVqZt/SpUulV69esmjRIqlSpYrs37/f6/LBd8nakCFD+DhhS8QpOC1OPf/88+Z7MGjp2qAInJo1a1qlS5e2KlSoYFWtWjXZ/fXq1bNKlixpXb16Ndl98fHxHo9Zp04dq1y5ch7vK168uNWgQYNE+yZPnqzrwVpDhgzxunxOMWXKFPMZ7N27N11ef9CgQeb1ATsiTtkDcco7ImJiqxNRsxZAJ06ckFWrVpkmTt3WrVsnhw8fTvSYQ4cOSYECBSRTpkzJnp8lSxaflOPBBx80P48cOeJ1+VLj/Pnzpvn2tddeS3bfwIEDJWvWrHLmzBn3vg0bNkjDhg3N+86ePbuUL19eXn/9dQmE9evXm1pGLVPp0qVlwoQJyR6jNZAdO3aUQoUKSXh4uKnJXLBgQbLHpeZ9uJqlXVerCZuuvW0W1SZcfV7Pnj2lSJEictddd8nixYulUqVKki9fPhkxYoTX7+P48ePy0ksvmaZ3/RvmypVLateubWp8PTXP/PLLL/LEE09Izpw5Te3uyJEjvXoPsB/iFHHK7nFKaavTvffeax5ToUIF+eGHH8STMmXKJCq/J8EQ90jWAkhPOG3edCVDeiEwf/78RI+pXLmySZI0qfHUTOkLmhAqPcG9LV9q6AncpEkTmTlzpjleQl9//bU5ySMiIsztCxcuSIMGDeSff/6RiRMnysKFC01Trb/ee1Jdu3aVNm3amGafhx56SLp37y5z585136/9BDW5/e233+TDDz80n4cGmaeeekp+/PFH9+NS+z7mzZtnquK1D6JK2HSt1fRpsXfvXpk0aZKcOnXKfO79+/eX9u3byxtvvCEXL1706n0cO3ZMTp8+bZJMPR/mzJlj+jk+/vjjsmbNmmSv/cILL5j79H3p8fv06ePxcQgexCnilN3j1Lp166RFixYSFRVlyvrKK6/Is88+6/F1NYYlfC+eBEXcS++qvVDSpEkTK3v27NalS5esK1euWLlz57YaNmyY6DGxsbFW5cqVTXWubtqM2bNnT2vnzp0pHvdWzaCPPfaYaVbV1924caMVHR1t1apVy7p48aLX5UuthQsXmvIvX77cve/33383++bOnevet27dOrNv0qRJVno0LwwYMCDR/nvuucd8Pi7PPvuslSVLFuvvv/9O9Dj9G1WvXj3N78MXzaDahJvw82zatKlVqVIl8/umTZvMfVu2bPHqfSR17do1cy5ERERYL7zwQrLPb8yYMe59586dszJnzpzsM0VwIU4Rp+wep5o1a2bly5fPfFe5TJw48abNoN68FzvGPWrWAuTSpUumSvWRRx4xTW46MvPRRx81nf7PnTvnflyxYsVk7dq1smTJEundu7fkz59fxowZI/fff7+pek0LvSLR18uWLZupuStYsKCpMtbb3pYvtbSWSV9n+vTp7n36e968eU3Nmos2PWqV8/Dhw00V886dO02NXqDo1VHScm/dulWuXbtmbn///fdmgIY2C+g+11azZk3zd7py5Uq6vw9XLWXu3LkT/a7i4uK8eh9q8uTJEhMTI3ny5DHN8dr8rs3WSZvNlTYVJKxRveOOOzw+DsGBOEWcCoY4tWHDBqlVq5b5rnJJ+L2SFnaPeyRrAaIJkwZCTYa0T5du+ruefHqCJpQxY0Zz30cffWROSj1JM2TIYKqL06J69eqm2vjXX381CaCWRfsPpLV8qaEnuzYvanXy1atXTXPorFmzpFWrVon63mnypomp9u/SspUrV85MWRKovk+a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",
      "text/plain": [
       "<Figure size 629.921x314.961 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_astra_compare_results(\n",
    "    mses_average=[\n",
    "        LogD_random_mse_best_mean,\n",
    "        LogD_butina_mse_best_mean,\n",
    "        LogD_bemismurcko_mse_best_mean,\n",
    "        LogD_kmeans_mse_best_mean,\n",
    "        KSOL_random_mse_best_mean,\n",
    "        KSOL_butina_mse_best_mean,\n",
    "        KSOL_bemismurcko_mse_best_mean,\n",
    "        KSOL_kmeans_mse_best_mean,\n",
    "        HLM_random_mse_best_mean,\n",
    "        HLM_butina_mse_best_mean,\n",
    "        HLM_bemismurcko_mse_best_mean,\n",
    "        HLM_kmeans_mse_best_mean,\n",
    "        MDR1_MDCKII_random_mse_best_mean,\n",
    "        MDR1_MDCKII_butina_mse_best_mean,\n",
    "        MDR1_MDCKII_bemismurcko_mse_best_mean,\n",
    "        MDR1_MDCKII_kmeans_mse_best_mean,\n",
    "        MLM_random_mse_best_mean,\n",
    "        MLM_butina_mse_best_mean,\n",
    "        MLM_bemismurcko_mse_best_mean,\n",
    "        MLM_kmeans_mse_best_mean,\n",
    "        SARS_random_mse_best_mean,\n",
    "        SARS_butina_mse_best_mean,\n",
    "        SARS_bemismurcko_mse_best_mean,\n",
    "        SARS_kmeans_mse_best_mean,\n",
    "        MERS_random_mse_best_mean,\n",
    "        MERS_butina_mse_best_mean,\n",
    "        MERS_bemismurcko_mse_best_mean,\n",
    "        MERS_kmeans_mse_best_mean,\n",
    "    ],\n",
    "    mses_median=[\n",
    "        LogD_random_mse_best_median,\n",
    "        LogD_butina_mse_best_median,\n",
    "        LogD_bemismurcko_mse_best_median,\n",
    "        LogD_kmeans_mse_best_median,\n",
    "        KSOL_random_mse_best_median,\n",
    "        KSOL_butina_mse_best_median,\n",
    "        KSOL_bemismurcko_mse_best_median,\n",
    "        KSOL_kmeans_mse_best_median,\n",
    "        HLM_random_mse_best_median,\n",
    "        HLM_butina_mse_best_median,\n",
    "        HLM_bemismurcko_mse_best_median,\n",
    "        HLM_kmeans_mse_best_median,\n",
    "        MDR1_MDCKII_random_mse_best_median,\n",
    "        MDR1_MDCKII_butina_mse_best_median,\n",
    "        MDR1_MDCKII_bemismurcko_mse_best_median,\n",
    "        MDR1_MDCKII_kmeans_mse_best_median,\n",
    "        MLM_random_mse_best_median,\n",
    "        MLM_butina_mse_best_median,\n",
    "        MLM_bemismurcko_mse_best_median,\n",
    "        MLM_kmeans_mse_best_median,\n",
    "        SARS_random_mse_best_median,\n",
    "        SARS_butina_mse_best_median,\n",
    "        SARS_bemismurcko_mse_best_median,\n",
    "        SARS_kmeans_mse_best_median,\n",
    "        MERS_random_mse_best_median,\n",
    "        MERS_butina_mse_best_median,\n",
    "        MERS_bemismurcko_mse_best_median,\n",
    "        MERS_kmeans_mse_best_median,\n",
    "    ],\n",
    "    mses_astra=[\n",
    "        LogD_random_mse_astra,\n",
    "        LogD_butina_mse_astra,\n",
    "        LogD_bemismurcko_mse_astra,\n",
    "        LogD_kmeans_mse_astra,\n",
    "        KSOL_random_mse_astra,\n",
    "        KSOL_butina_mse_astra,\n",
    "        KSOL_bemismurcko_mse_astra,\n",
    "        KSOL_kmeans_mse_astra,\n",
    "        HLM_random_mse_astra,\n",
    "        HLM_butina_mse_astra,\n",
    "        HLM_bemismurcko_mse_astra,\n",
    "        HLM_kmeans_mse_astra,\n",
    "        MDR1_MDCKII_random_mse_astra,\n",
    "        MDR1_MDCKII_butina_mse_astra,\n",
    "        MDR1_MDCKII_bemismurcko_mse_astra,\n",
    "        MDR1_MDCKII_kmeans_mse_astra,\n",
    "        MLM_random_mse_astra,\n",
    "        MLM_butina_mse_astra,\n",
    "        MLM_bemismurcko_mse_astra,\n",
    "        MLM_kmeans_mse_astra,\n",
    "        SARS_random_mse_astra,\n",
    "        SARS_butina_mse_astra,\n",
    "        SARS_bemismurcko_mse_astra,\n",
    "        SARS_kmeans_mse_astra,\n",
    "        MERS_random_mse_astra,\n",
    "        MERS_butina_mse_astra,\n",
    "        MERS_bemismurcko_mse_astra,\n",
    "        MERS_kmeans_mse_astra,\n",
    "    ],\n",
    "    pvals=[\n",
    "        LogD_random_pvalue,\n",
    "        LogD_butina_pvalue,\n",
    "        LogD_bemismurcko_pvalue,\n",
    "        LogD_kmeans_pvalue,\n",
    "        KSOL_random_pvalue,\n",
    "        KSOL_butina_pvalue,\n",
    "        KSOL_bemismurcko_pvalue,\n",
    "        KSOL_kmeans_pvalue,\n",
    "        HLM_random_pvalue,\n",
    "        HLM_butina_pvalue,\n",
    "        HLM_bemismurcko_pvalue,\n",
    "        HLM_kmeans_pvalue,\n",
    "        MDR1_MDCKII_random_pvalue,\n",
    "        MDR1_MDCKII_butina_pvalue,\n",
    "        MDR1_MDCKII_bemismurcko_pvalue,\n",
    "        MDR1_MDCKII_kmeans_pvalue,\n",
    "        MLM_random_pvalue,\n",
    "        MLM_butina_pvalue,\n",
    "        MLM_bemismurcko_pvalue,\n",
    "        MLM_kmeans_pvalue,\n",
    "        SARS_random_pvalue,\n",
    "        SARS_butina_pvalue,\n",
    "        SARS_bemismurcko_pvalue,\n",
    "        SARS_kmeans_pvalue,\n",
    "        MERS_random_pvalue,\n",
    "        MERS_butina_pvalue,\n",
    "        MERS_bemismurcko_pvalue,\n",
    "        MERS_kmeans_pvalue,\n",
    "    ],\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "5e6c183d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'ASTRA better': 3, 'Same': 13, 'ASTRA worse': 6}\n",
      "{'ASTRA better': 7, 'Same': 12, 'ASTRA worse': 3}\n"
     ]
    },
    {
     "data": {
      "image/png": "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EGToKwEgEoQylmlN3f79+6VOnTqybt06s+7AgQMMEABgX4LWqVMnOXHihLlReqlSpYL9dQBwhVDGsoYNG8rLL79smlW1H9qpU6dk+fLl8uyzzzr6vgCiKEHTuX60Y2vdunWdKREAhIDdsez48ePmNX22b99uassqVqwoXbp0kcGDB0ufPn2kR48eZpoN3b9r1662vDcA7wl6kMA111xj5u4BgEhmdyzTyWkTEhLMovr162cejxs3ziRpOgHu4sWLzbply5aZ58yBBsC2GrSLL75YHnzwQbnlllukRo0aUqBA5pfo27dvsC8JACFndyyLj48/Y8f/li1byoYNG/JcXgDRJegETSdW1JFIX3zxRcC2mJgYEjQAEYFYBsBTCdq2bducKQkAhBCxDICn+qABAADAhXcSGDlypBn5pE2dOpeQeu6558y95YKhI57atWsnlStXNs2js2bNyrR96dKlUr9+fTNho/78+uuvgy0uADgeywAg7Ana0KFD5Z133pFevXqZpMqnWrVq8tZbbwX1WqmpqVK9enUZPXp0wLa9e/dK27Zt5aqrrjK3R2nRooV5ntOtUQAgXLEMAMKeoL333nsyefJkefjhh80Nf32uuOIK+fnnn4N6rcTERHnllVekffv22XbgjYuLk1GjRkm9evXk9ddfl4IFC5r1AHC27IxlABD2QQL79u2TSpUqBazXGbl1dmy7rFmzRpo0aWJm3VYaQK+88kozsWRO0tPTzeLDbacAhDuWAUBIatA0aZo4caL/ua9pQGu4NIGyizZlli1b1jRvli5dWlatWmWen6mJc/jw4VKiRAn/UqVKFdvKA8BbQhXLACAkNWivvvqqtGrVSpYsWWJqq5588knZtGmTuRpdtGiR2MU34aN23j3//PPlnHPOOeMkkGrAgAGZ5mHTGjSSNADhjGUAEJIE7ZJLLpHNmzfLG2+8YUZfqo4dO8qjjz4qZcqUEbuUL19e9u/fL3Xq1DH3s1MHDhw4461RdLSnLgDgllgGACFJ0JQ2OeqNf53UsGFDefnll81QeO2Hpn1Cli9fLs8++6yj7wsgeoQilgFASBK0v/76y4yk3LFjhxw9ejSg2XHSpEm5fq3jx4+budB8tm/fbmrL9MbCXbp0MYGzT58+0qNHD3n77bfN/l27dg22yADgaCwDgLAnaNdcc41JoC6//PIzNjfmxq5d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",
      "text/plain": [
       "<Figure size 629.921x314.961 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_astra_compare_results(\n",
    "    mses_average=[\n",
    "        LogD_random_mse_best_mean,\n",
    "        LogD_butina_mse_best_mean,\n",
    "        LogD_bemismurcko_mse_best_mean,\n",
    "        LogD_kmeans_mse_best_mean,\n",
    "        KSOL_random_mse_best_mean,\n",
    "        KSOL_butina_mse_best_mean,\n",
    "        KSOL_bemismurcko_mse_best_mean,\n",
    "        KSOL_kmeans_mse_best_mean,\n",
    "        HLM_random_mse_best_mean,\n",
    "        HLM_butina_mse_best_mean,\n",
    "        HLM_bemismurcko_mse_best_mean,\n",
    "        HLM_kmeans_mse_best_mean,\n",
    "        MDR1_MDCKII_random_mse_best_mean,\n",
    "        MDR1_MDCKII_butina_mse_best_mean,\n",
    "        MDR1_MDCKII_bemismurcko_mse_best_mean,\n",
    "        MDR1_MDCKII_kmeans_mse_best_mean,\n",
    "        MLM_random_mse_best_mean,\n",
    "        MLM_butina_mse_best_mean,\n",
    "        MLM_bemismurcko_mse_best_mean,\n",
    "        MLM_kmeans_mse_best_mean,\n",
    "        SARS_random_mse_best_mean,\n",
    "        SARS_butina_mse_best_mean,\n",
    "        SARS_bemismurcko_mse_best_mean,\n",
    "        SARS_kmeans_mse_best_mean,\n",
    "        MERS_random_mse_best_mean,\n",
    "        MERS_butina_mse_best_mean,\n",
    "        MERS_bemismurcko_mse_best_mean,\n",
    "        MERS_kmeans_mse_best_mean,\n",
    "    ],\n",
    "    mses_median=[\n",
    "        LogD_random_mse_best_median,\n",
    "        LogD_butina_mse_best_median,\n",
    "        LogD_bemismurcko_mse_best_median,\n",
    "        LogD_kmeans_mse_best_median,\n",
    "        KSOL_random_mse_best_median,\n",
    "        KSOL_butina_mse_best_median,\n",
    "        KSOL_bemismurcko_mse_best_median,\n",
    "        KSOL_kmeans_mse_best_median,\n",
    "        HLM_random_mse_best_median,\n",
    "        HLM_butina_mse_best_median,\n",
    "        HLM_bemismurcko_mse_best_median,\n",
    "        HLM_kmeans_mse_best_median,\n",
    "        MDR1_MDCKII_random_mse_best_median,\n",
    "        MDR1_MDCKII_butina_mse_best_median,\n",
    "        MDR1_MDCKII_bemismurcko_mse_best_median,\n",
    "        MDR1_MDCKII_kmeans_mse_best_median,\n",
    "        MLM_random_mse_best_median,\n",
    "        MLM_butina_mse_best_median,\n",
    "        MLM_bemismurcko_mse_best_median,\n",
    "        MLM_kmeans_mse_best_median,\n",
    "        SARS_random_mse_best_median,\n",
    "        SARS_butina_mse_best_median,\n",
    "        SARS_bemismurcko_mse_best_median,\n",
    "        SARS_kmeans_mse_best_median,\n",
    "        MERS_random_mse_best_median,\n",
    "        MERS_butina_mse_best_median,\n",
    "        MERS_bemismurcko_mse_best_median,\n",
    "        MERS_kmeans_mse_best_median,\n",
    "    ],\n",
    "    mses_astra=[\n",
    "        LogD_random_mse_astra,\n",
    "        LogD_butina_mse_astra,\n",
    "        LogD_bemismurcko_mse_astra,\n",
    "        LogD_kmeans_mse_astra,\n",
    "        KSOL_random_mse_astra,\n",
    "        KSOL_butina_mse_astra,\n",
    "        KSOL_bemismurcko_mse_astra,\n",
    "        KSOL_kmeans_mse_astra,\n",
    "        HLM_random_mse_astra,\n",
    "        HLM_butina_mse_astra,\n",
    "        HLM_bemismurcko_mse_astra,\n",
    "        HLM_kmeans_mse_astra,\n",
    "        MDR1_MDCKII_random_mse_astra,\n",
    "        MDR1_MDCKII_butina_mse_astra,\n",
    "        MDR1_MDCKII_bemismurcko_mse_astra,\n",
    "        MDR1_MDCKII_kmeans_mse_astra,\n",
    "        MLM_random_mse_astra,\n",
    "        MLM_butina_mse_astra,\n",
    "        MLM_bemismurcko_mse_astra,\n",
    "        MLM_kmeans_mse_astra,\n",
    "        SARS_random_mse_astra,\n",
    "        SARS_butina_mse_astra,\n",
    "        SARS_bemismurcko_mse_astra,\n",
    "        SARS_kmeans_mse_astra,\n",
    "        MERS_random_mse_astra,\n",
    "        MERS_butina_mse_astra,\n",
    "        MERS_bemismurcko_mse_astra,\n",
    "        MERS_kmeans_mse_astra,\n",
    "    ],\n",
    "    pvals=[\n",
    "        LogD_random_pvalue,\n",
    "        LogD_butina_pvalue,\n",
    "        LogD_bemismurcko_pvalue,\n",
    "        LogD_kmeans_pvalue,\n",
    "        KSOL_random_pvalue,\n",
    "        KSOL_butina_pvalue,\n",
    "        KSOL_bemismurcko_pvalue,\n",
    "        KSOL_kmeans_pvalue,\n",
    "        HLM_random_pvalue,\n",
    "        HLM_butina_pvalue,\n",
    "        HLM_bemismurcko_pvalue,\n",
    "        HLM_kmeans_pvalue,\n",
    "        MDR1_MDCKII_random_pvalue,\n",
    "        MDR1_MDCKII_butina_pvalue,\n",
    "        MDR1_MDCKII_bemismurcko_pvalue,\n",
    "        MDR1_MDCKII_kmeans_pvalue,\n",
    "        MLM_random_pvalue,\n",
    "        MLM_butina_pvalue,\n",
    "        MLM_bemismurcko_pvalue,\n",
    "        MLM_kmeans_pvalue,\n",
    "        SARS_random_pvalue,\n",
    "        SARS_butina_pvalue,\n",
    "        SARS_bemismurcko_pvalue,\n",
    "        SARS_kmeans_pvalue,\n",
    "        MERS_random_pvalue,\n",
    "        MERS_butina_pvalue,\n",
    "        MERS_bemismurcko_pvalue,\n",
    "        MERS_kmeans_pvalue,\n",
    "    ],\n",
    "    subset=\"insignificant\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "99361641",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'ASTRA better': 2, 'Same': 3, 'ASTRA worse': 1}\n",
      "{'ASTRA better': 1, 'Same': 4, 'ASTRA worse': 1}\n"
     ]
    },
    {
     "data": {
      "image/png": "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6XzeggULzHebNWtWq2LFitb8+fMtT/L3869jx45Wnz59En3s8ccft8LCwsztqKgoq06dOub3XbhwYWvEiBHW7du3Ez2PIyIirPvvv98895FHHnE+vnLlSuvhhx+2smXLZsrbvHlz69q1a26df/7M388VRaxKiFiVNudfxwCKVUFTg6Y1V9rsqDVgW7ZskWPHjjkf09qu3bt3yz///OOR97p+/bp8+eWX5nbWrFmd+3WZF12eqmrVqvLEE08kqMlLDi3nyZMnTc3dsGHDpEePHvLnn386H3/uuefk9OnTsmrVKvn555/NElldunQxj5UoUcLU8P3+++/m/o8//uisCXSIiIgw9x999FF58cUXnY9rDaODTgisKzxoc62WQ9dF1SZhXVcwLl0rVZsn33//fVPGgQMHuv159Xfz008/JVnbeOnSJSlevLhZj1W/G8d3orWiDkePHjXftda8LViwQFauXCnr16931n6uXr1aXnjhBbMqhdbSvfXWW+Y7++2338RT/P380/Mhbm1xXPp59PEbN25IixYtpFixYrJ161aZNm2aqfGcPXt2gtfoOTx+/Hjz2Pbt26VDhw5mv55DrVu3llq1aplzRn/3euzbt2+7ff75K38/VxyIVa6IVWlz/j0aSLHKCgLR0dFWxowZrT179pj71atXt2bMmOFyZVOjRg0rffr05ufw4cOt3bt3u31VqjU4Wmukx9GvtnHjxi61NIMGDbI6dOhgbkdGRlpFihRJkLHfiWbz+h7nzp1z7tPy6lW1WrNmjZUpUybr/Pnzzsd37txpynL8+HHnPkdN2qZNm5J8L61J69u3b4L9+tp06dJZu3btcu67ePGi2bdhwwaXGjR9j1WrVlmpoVdVefLkMVcfenWiv7fLly/f8TXVqlUzv0PHd9auXTtzW38OGzbM3NarIEctWcOGDa2hQ4e6HKNNmzZWz549LU8IhPNvy5Yt5vh6dajngNbMxsbGWv/88495Pz3n9Hel559+Hgc9N/UKMy79nej5sm/fvgTvo6/Vsi9dujTRciT3/PNXgXCuKGIVsYpYtT/VsSooatC0D5NmymXLljX39epUM1oH7dSvtSW//vqryW61hkUz9++//96t9xk0aJBERUWZKwLtZD9//nyzGLKD9m3T91b6+NmzZ521WclVtGhRl6VhdAFmx9W0Zvdaa6WfNWfOnGarWbOmeezff/8VT9A+err4RI0aNZzvoYMqdF/899CBCHXq1EnV++nv4/Dhw/Lxxx+bGkDt56eDOfRqVOmVyLvvvitVqlSRfPnymfJs27bN+XjcKzP9Gff21atXnd/bpEmTnJ9HNz0/PPWdBcL5p+XJlCmT+f3/8MMPpvxaXh1oUrFiRVOzs2/fPnN+xl1bUl+n++PT5913330J9utrdQCN1ti2bNnS1L5q/72UnH/+KBDOFQdiFbHKF+df1QCKVRklCGj1qP6Rd/xx1j/qWn168eJFyZUrlzOZ0OpJ3XS9PP3Sx44dK82aNUv2++gvTAOrbn/99Zd0797djA5V2nSmv3xdMFkHCTiqd7VsjzzySIo/m/6ytewOegLEbd5z0KDvKfrd6cmeMaPr6XPPPfe43Nf1UTNnzpzq99Pfkf5H0E2H75cuXdo0Veqgjg8//FDGjRsnU6dOldDQUPN++ry41cxJibvKmR5Xm4fj0lGjnhAI55/+rqtXr26q6TUp0AC7YsUK8z1rmR3inouJnZ8Od1p/Un+32hShTc8awN955x0TzO+//363zj9/FAjnSlKIVcSqtDj/MgZQrAr4BE37LumIyY8++shk4o5fhLYbax+spKa70BNnz549KX5fnaJCa3x++eUXqVevnjm5tLZL+0o5fPrpp2b/e++9l+zjan8q7VfmOGl27dol9evXN7e1FunUqVNmGg9976Q4kiatbbvTcxJ7XOdh0+8vOjpaateuLWmtYMGC5rPrHyylyaj2JejYsaO5HxsbK4cOHXKr5k6/N72icfyn8qRAOv80uOlV7N9//y3h4eHyn//8x0xL07lzZ/O4XmXq+annRkhIiPMqMrGrz7vRWlLd+vfvb37nGmj19+Pr88+bAulcUcQqYpWvzr9HAyRWBXwTp3aWv3z5srnKrFChgtkeeOAB54mgtHPg66+/bjqO61Qc2lF+xowZZpqMlNIrhPbt28uoUaNcOv46yqBbq1atTIKVWLVqUvSKWk8EPfGmTJlisnOtSVIa1DUx0UCuiYs2fWr1rk4tEj971+pWvWKJiYkxSU18eoLpMTTZ0ccdnRq19qpTp05mAIH+0dDERn9qgnTu3DnxNE2+5syZY66q9DProANNQhs3buz846TTmuh/Rn2OlkuvttyhzaY6jYfWxOkfOr3y+u9//yuff/55qssfSOefBj0NmjoFjQY1vSrU791xVarl1Rpc7RirV8V6fmnTtF4JJ5eebzrQY8OGDaa5QAOznqOaRPvi/EtLgXSuKGIVscpX59+jgRKrrACnHb2103h8H374oZU3b17rxo0b1s8//2w1bdrUKliwoBlGW6ZMGevNN990GS7r7tB1R8dq/Yq18752DIw7jNgxlFinkYj/uqQ4hvwOHjzYOc3G7NmzXZ6jnYi7du1qhvw6pox44403Ehzrs88+s0qVKuXsJBzfv//+a4bzZ8+ePcE0G9pJf8CAAabjsHY21uHHOqDg6tWrCabZSK333nvPTNOhn1cHCtSqVcv67rvvXDpVP/vss+ZxHSr9v//9z3R4dgxw0O/M8fvSn3rfMQgi7mf6+uuvzTQc+nn0PHj66aet33//PdXlD6Tz79SpU+Z4n3/+ubmv36V+hridx/U9a9eubb5HHVqu556+T2LncWJ0ShidYkJ/l46pWcLDw12ek5zzzx8F0rlCrCJWEausVMeqdPpPslNGAAAAeF3AN3ECAAD4GxI0AAAAmyFBAwAAsBkSNAAAAJshQQMAALAZEjQAAACbIUEDAACwGRI0AAAAmyFBAwAAsBkSNAAAAJshQQMAABB7+X8RKu5Pg1NA4AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 629.921x314.961 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_astra_compare_results(\n",
    "    mses_average=[\n",
    "        LogD_random_mse_best_mean,\n",
    "        LogD_butina_mse_best_mean,\n",
    "        LogD_bemismurcko_mse_best_mean,\n",
    "        LogD_kmeans_mse_best_mean,\n",
    "        KSOL_random_mse_best_mean,\n",
    "        KSOL_butina_mse_best_mean,\n",
    "        KSOL_bemismurcko_mse_best_mean,\n",
    "        KSOL_kmeans_mse_best_mean,\n",
    "        HLM_random_mse_best_mean,\n",
    "        HLM_butina_mse_best_mean,\n",
    "        HLM_bemismurcko_mse_best_mean,\n",
    "        HLM_kmeans_mse_best_mean,\n",
    "        MDR1_MDCKII_random_mse_best_mean,\n",
    "        MDR1_MDCKII_butina_mse_best_mean,\n",
    "        MDR1_MDCKII_bemismurcko_mse_best_mean,\n",
    "        MDR1_MDCKII_kmeans_mse_best_mean,\n",
    "        MLM_random_mse_best_mean,\n",
    "        MLM_butina_mse_best_mean,\n",
    "        MLM_bemismurcko_mse_best_mean,\n",
    "        MLM_kmeans_mse_best_mean,\n",
    "        SARS_random_mse_best_mean,\n",
    "        SARS_butina_mse_best_mean,\n",
    "        SARS_bemismurcko_mse_best_mean,\n",
    "        SARS_kmeans_mse_best_mean,\n",
    "        MERS_random_mse_best_mean,\n",
    "        MERS_butina_mse_best_mean,\n",
    "        MERS_bemismurcko_mse_best_mean,\n",
    "        MERS_kmeans_mse_best_mean,\n",
    "    ],\n",
    "    mses_median=[\n",
    "        LogD_random_mse_best_median,\n",
    "        LogD_butina_mse_best_median,\n",
    "        LogD_bemismurcko_mse_best_median,\n",
    "        LogD_kmeans_mse_best_median,\n",
    "        KSOL_random_mse_best_median,\n",
    "        KSOL_butina_mse_best_median,\n",
    "        KSOL_bemismurcko_mse_best_median,\n",
    "        KSOL_kmeans_mse_best_median,\n",
    "        HLM_random_mse_best_median,\n",
    "        HLM_butina_mse_best_median,\n",
    "        HLM_bemismurcko_mse_best_median,\n",
    "        HLM_kmeans_mse_best_median,\n",
    "        MDR1_MDCKII_random_mse_best_median,\n",
    "        MDR1_MDCKII_butina_mse_best_median,\n",
    "        MDR1_MDCKII_bemismurcko_mse_best_median,\n",
    "        MDR1_MDCKII_kmeans_mse_best_median,\n",
    "        MLM_random_mse_best_median,\n",
    "        MLM_butina_mse_best_median,\n",
    "        MLM_bemismurcko_mse_best_median,\n",
    "        MLM_kmeans_mse_best_median,\n",
    "        SARS_random_mse_best_median,\n",
    "        SARS_butina_mse_best_median,\n",
    "        SARS_bemismurcko_mse_best_median,\n",
    "        SARS_kmeans_mse_best_median,\n",
    "        MERS_random_mse_best_median,\n",
    "        MERS_butina_mse_best_median,\n",
    "        MERS_bemismurcko_mse_best_median,\n",
    "        MERS_kmeans_mse_best_median,\n",
    "    ],\n",
    "    mses_astra=[\n",
    "        LogD_random_mse_astra,\n",
    "        LogD_butina_mse_astra,\n",
    "        LogD_bemismurcko_mse_astra,\n",
    "        LogD_kmeans_mse_astra,\n",
    "        KSOL_random_mse_astra,\n",
    "        KSOL_butina_mse_astra,\n",
    "        KSOL_bemismurcko_mse_astra,\n",
    "        KSOL_kmeans_mse_astra,\n",
    "        HLM_random_mse_astra,\n",
    "        HLM_butina_mse_astra,\n",
    "        HLM_bemismurcko_mse_astra,\n",
    "        HLM_kmeans_mse_astra,\n",
    "        MDR1_MDCKII_random_mse_astra,\n",
    "        MDR1_MDCKII_butina_mse_astra,\n",
    "        MDR1_MDCKII_bemismurcko_mse_astra,\n",
    "        MDR1_MDCKII_kmeans_mse_astra,\n",
    "        MLM_random_mse_astra,\n",
    "        MLM_butina_mse_astra,\n",
    "        MLM_bemismurcko_mse_astra,\n",
    "        MLM_kmeans_mse_astra,\n",
    "        SARS_random_mse_astra,\n",
    "        SARS_butina_mse_astra,\n",
    "        SARS_bemismurcko_mse_astra,\n",
    "        SARS_kmeans_mse_astra,\n",
    "        MERS_random_mse_astra,\n",
    "        MERS_butina_mse_astra,\n",
    "        MERS_bemismurcko_mse_astra,\n",
    "        MERS_kmeans_mse_astra,\n",
    "    ],\n",
    "    pvals=[\n",
    "        LogD_random_pvalue,\n",
    "        LogD_butina_pvalue,\n",
    "        LogD_bemismurcko_pvalue,\n",
    "        LogD_kmeans_pvalue,\n",
    "        KSOL_random_pvalue,\n",
    "        KSOL_butina_pvalue,\n",
    "        KSOL_bemismurcko_pvalue,\n",
    "        KSOL_kmeans_pvalue,\n",
    "        HLM_random_pvalue,\n",
    "        HLM_butina_pvalue,\n",
    "        HLM_bemismurcko_pvalue,\n",
    "        HLM_kmeans_pvalue,\n",
    "        MDR1_MDCKII_random_pvalue,\n",
    "        MDR1_MDCKII_butina_pvalue,\n",
    "        MDR1_MDCKII_bemismurcko_pvalue,\n",
    "        MDR1_MDCKII_kmeans_pvalue,\n",
    "        MLM_random_pvalue,\n",
    "        MLM_butina_pvalue,\n",
    "        MLM_bemismurcko_pvalue,\n",
    "        MLM_kmeans_pvalue,\n",
    "        SARS_random_pvalue,\n",
    "        SARS_butina_pvalue,\n",
    "        SARS_bemismurcko_pvalue,\n",
    "        SARS_kmeans_pvalue,\n",
    "        MERS_random_pvalue,\n",
    "        MERS_butina_pvalue,\n",
    "        MERS_bemismurcko_pvalue,\n",
    "        MERS_kmeans_pvalue,\n",
    "    ],\n",
    "    subset=\"significant\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "407f8875",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'Gains': 11.28221857178723, 'Losses': -16.13958590933215, 'Total': -2.0202145895138894}\n",
      "{'Gains': 12.897818913202855, 'Losses': -11.20486422372321, 'Total': 2.084396228954643}\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "One-sided (alternative: less) Wilcoxon signed-rank test (mean): p-value=0.7115747892385155\n",
      "One-sided (alternative: less) Wilcoxon signed-rank test (median): p-value=0.08540361010386899\n",
      "One-sided (alternative: greater) Wilcoxon signed-rank test (mean): p-value=0.28842521076148453\n",
      "One-sided (alternative: greater) Wilcoxon signed-rank test (median): p-value=0.914596389896131\n",
      "Regular Wilcoxon signed-rank test (mean): p-value=0.5768504215229691\n",
      "Regular Wilcoxon signed-rank test (median): p-value=0.17080722020773798\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmsAAAEwCAYAAADo7TZNAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAP9tJREFUeJzt3QmczfX6wPFnVjNj7EvCWCtb1EhFCsVFRdlTKdmylUjKdK3lRupa0o0QyhWVKFTcbtmpkPVGhWRu9iUMM2Y7/9fzvf9znDNzhhnO8jtnPu/X62fmfM+ZM9/fOcczz++7hthsNpsAAADAkkL9XQEAAADkjGQNAADAwkjWAAAALIxkDQAAwMJI1gAAACyMZA0AAMDCSNYAAAAsjGQNAADAwkjWAAAALIxkzYf27t0rISEh5vjPf/7j9jHff/+9PPDAA1KmTBkpWLCg1KhRQ3r06CGJiYnm/qeeesrxHDkd+hhVqVIlR1lERIRUrlxZunTpIr/++utV1y8YzJkzx5zjgQMH/PL7V61aJaNGjfLL7wauhDhlDcSpvAkJCckxrmq53h/ISNZ86PPPP3f7vd3XX38tDRs2lMzMTJk6dap89tln0rt3b/nxxx9l37595jHDhw+XjRs3Oo74+HipWLGiS5k+xq5+/fqm7Ntvv5WBAwfKF198Ibfffrv8/vvvea4fPJesjR49mpcTlkScQrDFqZ49e5q/gwFN9waFb9x99922qlWr2mrWrGm74447st3ftGlTW+XKlW1paWnZ7rt48aLb52zcuLGtWrVqbu+rWLGirUWLFi5ls2bN0r1gbaNHj85z/YLF7NmzzWvw22+/+eX3jxw50vx+wIqIU9ZAnMobETGxNVjRsuYjJ06ckA0bNpguTj02bdokhw4dcnnMH3/8ISVLlpTw8PBsPx8ZGemRetx5553m6+HDh/Ncv9xISkoy3bcvvPBCtvtGjBghUVFR8ueffzrKtmzZIi1btjTnHRMTI9WrV5cXX3xRfGHz5s2mlVHrVLVqVXn33XezPUZbIJ944gkpXbq0FChQwLRkLl26NNvjcnMe9m5p+9Wqc9d1XrtFtQtXf27AgAFStmxZuemmm2TFihVSp04dKV68uPz973/P83kcP35c+vXrZ7re9T0sVKiQNGrUyLT4uuueWb16tTz44IMSGxtrWncnTpyYp3OA9RCniFNWj1NKe51uvvlm85iaNWvK8uXLxZ0bbrjBpf7uBErcI1nzEf3AafemPRnSC4ElS5a4PKZu3bomSdKkxl03pSdoQqj0A57X+uWGfoAfeugh+eijj8zzOZs/f775kBctWtTcPn/+vLRo0UKOHj0q06dPl2XLlpmuWm+de1ZPP/20PPLII6bb56677pI+ffrIokWLHPfrOEFNbtetWydvvPGGeT00yLRp00b+9a9/OR6X2/NYvHixaYrXMYjKuetam+mvxm+//SYzZsyQU6dOmdc9ISFBHnvsMXn55ZflwoULeTqPY8eOyenTp02SqZ+HhQsXmnGO999/v3z33XfZfnevXr3MfXpe+vzPP/+828chcBCniFNWj1ObNm2S9u3bS1xcnKnrc889J926dXP7ezWGOZ+LOwET9/zdtJdfPPTQQ7aYmBhbcnKyLTU11Va4cGFby5YtXR6TmJhoq1u3rmnO1UO7MQcMGGD75ZdfcnzeK3WDNm/e3HSr6u/98ccfbfHx8bZ77rnHduHChTzXL7eWLVtm6r9q1SpH2ffff2/KFi1a5CjbtGmTKZsxY4bNH90Lw4cPdymvVauWeX3sunXrZouMjLT9+uuvLo/T96hBgwZXfR6e6AbVLlzn1/Phhx+21alTx3y/detWc9/27dvzdB5Zpaenm89C0aJFbb169cr2+r311luOsnPnztkiIiKyvaYILMQp4pTV41Tbtm1txYsXN3+r7KZPn37ZbtC8nItV4x4taz6QnJxsmlTvu+8+0+WmMzP/8pe/mEH/586dczyufPny8sMPP8g333wjgwYNkhIlSshbb70lt956q2l6vRp6RaK/Lzo62rTclSpVyjQZ6+281i+3tJVJf8+HH37oKNPvixUrZlrW7LTrUZuc33zzTdPE/Msvv5gWPV/Rq6Os9d6xY4ekp6eb21999ZWZoKHdAlpmP+6++27zPqWmpvr9POytlIULF3b5Xp09ezZP56FmzZol9erVkyJFipjueO1+127rrN3mSrsKnFtUr7vuOrePQ2AgThGnAiFObdmyRe655x7zt8rO+e/K1QiEuEey5gOaMGkg1GRIx3Tpod/rh08/oM7CwsLMfRMmTDAfSv2QhoaGmubiq9GgQQPTbLx27VqTAGpddPzA1dYvN/TDrt2L2pyclpZmukM//vhj6dixo8vYO03eNDHV8V1at2rV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rjdVr1490wKkXWgXL16UjIwM+dvf/ia1a9eWYsWKmcHder+2uOWFts7Z9wzV51HOExi0++7555+Xli1byujRo03LUKDYu3eveX2c1alTx5Tb6YSNZcuWye233y6DBw82V0vOdLygdoFWr15dunbtarqJna+gtDVOu4W1ZU3fAz06dOggKSkp5opMPf744/LLL7+Y905nsy1evNjx/gbDa3glx44dM62+N954oxQuXNh0Fau8flYRmIhl145Y5hl783E8I1nzEh0bpRITE81XHetzww03mK9Kx5m9+eabpttOuzA1UdMPnXMXXm6Eh4dnK3NOJLTLbvv27abZV8dy3XrrraY7NFDo+Kms5+Zc1rZtW/n999/lueeeM83bmpS+/vrrjvuLFi1qmro/+OADM9hex/k1bNhQ0tPTHY/RcW76+tsPTeB+/fVXMw5Q1a9f3/wO/Vn9OU3e+vXrJ8HyGl6JdjVo17CO/dPudP1e5fWzisBELPMMYplvXsdgjWcka15StmxZcwWwZMkSt/fr2LSHH37Y/OGvWbOmaSE7ePCgV+pSo0YN0yK0cuVKczWhs1IDgbaIaeLkTBMvLXd23XXXmYkc//znP80V02effeZyvw6s1wHyOmFDW8X0Ofbt22fu0/dIv9dxbJpMOx/OibAmfR07dpRp06aZpC3r7wj011BfI+cENutndeDAgWZs30033ZTjFai2SmqrcaC0OiJ3iGXXjljmGVXzcTzL3iwDj9EWHk3IdIC/tgDpDFCdEKAJgiZNOuhRs3qdxaiJhA52d2aftakzE/U++22d1akfxivRn9FJCjrJoVKlSrJ161YzGSFrM7K/aZejtmg50+bpHj16mIGi48aNk3bt2pnXS1sJdZKAnSZO2lqo56QTKzQhveeeexz3f/nll6aVTGc36n++999/33R5VqhQwdyvg1O1O1oHpupz6X16tbV27VqZOnWqYzq5trJpC1xycrKZhGC11zAnuXkNlSanGpg+//xzad68uZlAYf+M6WdVZ7LpLNDjx4/Liy++6PZKNj4+3lydTp8+3Xzu9XOtM1QR+IhluUMs864e+TmeZRnDBg/78ssvbXfccYcZsF6uXDnbU089ZTty5IiZDNC2bVszAaBMmTK28ePH25o2bWomE9jp2+PuWLlyZY4DWvX+Tz75xHyflpZme/TRR21xcXG2yMhIW6VKlWxjxoyx1Hus5+DuHFu0aGHunzdvnu3GG2+0hYeHm68LFixw+fnXXnvNVqNGDfP6li5d2ry+zpMJNmzYYCZnFC1a1Ax+b9CggZns4Wz//v22du3a2YoUKWIeowPwJ02a5Lh/5syZtltuucUWExNjK168uHnfDh48aAuEAbm5eQ3tBg0aZCtVqpR5/Z0ntGzbts3xGa5evbpt+fLlZtKG/XPmTF83fR/0OZ577jkPnyH8iVh2ecQyzyKeuQrRf/yXKgIAAOByGLMGAABgYSRrAAAAFkayBgAAYGEkawAAABZGsgYAAGBhJGsAAAAWRrIGAABgYSRrAAAAFkayBgAAYGEkawAAABZGsgYAACDW9X91wjgW5qffigAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 629.921x314.961 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_astra_compare_results_quantitative(\n",
    "    mses_average=[\n",
    "        LogD_random_mse_best_mean,\n",
    "        LogD_butina_mse_best_mean,\n",
    "        LogD_bemismurcko_mse_best_mean,\n",
    "        LogD_kmeans_mse_best_mean,\n",
    "        KSOL_random_mse_best_mean,\n",
    "        KSOL_butina_mse_best_mean,\n",
    "        KSOL_bemismurcko_mse_best_mean,\n",
    "        KSOL_kmeans_mse_best_mean,\n",
    "        HLM_random_mse_best_mean,\n",
    "        HLM_butina_mse_best_mean,\n",
    "        HLM_bemismurcko_mse_best_mean,\n",
    "        HLM_kmeans_mse_best_mean,\n",
    "        MDR1_MDCKII_random_mse_best_mean,\n",
    "        MDR1_MDCKII_butina_mse_best_mean,\n",
    "        MDR1_MDCKII_bemismurcko_mse_best_mean,\n",
    "        MDR1_MDCKII_kmeans_mse_best_mean,\n",
    "        MLM_random_mse_best_mean,\n",
    "        MLM_butina_mse_best_mean,\n",
    "        MLM_bemismurcko_mse_best_mean,\n",
    "        MLM_kmeans_mse_best_mean,\n",
    "        SARS_random_mse_best_mean,\n",
    "        SARS_butina_mse_best_mean,\n",
    "        SARS_bemismurcko_mse_best_mean,\n",
    "        SARS_kmeans_mse_best_mean,\n",
    "        MERS_random_mse_best_mean,\n",
    "        MERS_butina_mse_best_mean,\n",
    "        MERS_bemismurcko_mse_best_mean,\n",
    "        MERS_kmeans_mse_best_mean,\n",
    "    ],\n",
    "    mses_median=[\n",
    "        LogD_random_mse_best_median,\n",
    "        LogD_butina_mse_best_median,\n",
    "        LogD_bemismurcko_mse_best_median,\n",
    "        LogD_kmeans_mse_best_median,\n",
    "        KSOL_random_mse_best_median,\n",
    "        KSOL_butina_mse_best_median,\n",
    "        KSOL_bemismurcko_mse_best_median,\n",
    "        KSOL_kmeans_mse_best_median,\n",
    "        HLM_random_mse_best_median,\n",
    "        HLM_butina_mse_best_median,\n",
    "        HLM_bemismurcko_mse_best_median,\n",
    "        HLM_kmeans_mse_best_median,\n",
    "        MDR1_MDCKII_random_mse_best_median,\n",
    "        MDR1_MDCKII_butina_mse_best_median,\n",
    "        MDR1_MDCKII_bemismurcko_mse_best_median,\n",
    "        MDR1_MDCKII_kmeans_mse_best_median,\n",
    "        MLM_random_mse_best_median,\n",
    "        MLM_butina_mse_best_median,\n",
    "        MLM_bemismurcko_mse_best_median,\n",
    "        MLM_kmeans_mse_best_median,\n",
    "        SARS_random_mse_best_median,\n",
    "        SARS_butina_mse_best_median,\n",
    "        SARS_bemismurcko_mse_best_median,\n",
    "        SARS_kmeans_mse_best_median,\n",
    "        MERS_random_mse_best_median,\n",
    "        MERS_butina_mse_best_median,\n",
    "        MERS_bemismurcko_mse_best_median,\n",
    "        MERS_kmeans_mse_best_median,\n",
    "    ],\n",
    "    mses_astra=[\n",
    "        LogD_random_mse_astra,\n",
    "        LogD_butina_mse_astra,\n",
    "        LogD_bemismurcko_mse_astra,\n",
    "        LogD_kmeans_mse_astra,\n",
    "        KSOL_random_mse_astra,\n",
    "        KSOL_butina_mse_astra,\n",
    "        KSOL_bemismurcko_mse_astra,\n",
    "        KSOL_kmeans_mse_astra,\n",
    "        HLM_random_mse_astra,\n",
    "        HLM_butina_mse_astra,\n",
    "        HLM_bemismurcko_mse_astra,\n",
    "        HLM_kmeans_mse_astra,\n",
    "        MDR1_MDCKII_random_mse_astra,\n",
    "        MDR1_MDCKII_butina_mse_astra,\n",
    "        MDR1_MDCKII_bemismurcko_mse_astra,\n",
    "        MDR1_MDCKII_kmeans_mse_astra,\n",
    "        MLM_random_mse_astra,\n",
    "        MLM_butina_mse_astra,\n",
    "        MLM_bemismurcko_mse_astra,\n",
    "        MLM_kmeans_mse_astra,\n",
    "        SARS_random_mse_astra,\n",
    "        SARS_butina_mse_astra,\n",
    "        SARS_bemismurcko_mse_astra,\n",
    "        SARS_kmeans_mse_astra,\n",
    "        MERS_random_mse_astra,\n",
    "        MERS_butina_mse_astra,\n",
    "        MERS_bemismurcko_mse_astra,\n",
    "        MERS_kmeans_mse_astra,\n",
    "    ],\n",
    "    pvals=[\n",
    "        LogD_random_pvalue,\n",
    "        LogD_butina_pvalue,\n",
    "        LogD_bemismurcko_pvalue,\n",
    "        LogD_kmeans_pvalue,\n",
    "        KSOL_random_pvalue,\n",
    "        KSOL_butina_pvalue,\n",
    "        KSOL_bemismurcko_pvalue,\n",
    "        KSOL_kmeans_pvalue,\n",
    "        HLM_random_pvalue,\n",
    "        HLM_butina_pvalue,\n",
    "        HLM_bemismurcko_pvalue,\n",
    "        HLM_kmeans_pvalue,\n",
    "        MDR1_MDCKII_random_pvalue,\n",
    "        MDR1_MDCKII_butina_pvalue,\n",
    "        MDR1_MDCKII_bemismurcko_pvalue,\n",
    "        MDR1_MDCKII_kmeans_pvalue,\n",
    "        MLM_random_pvalue,\n",
    "        MLM_butina_pvalue,\n",
    "        MLM_bemismurcko_pvalue,\n",
    "        MLM_kmeans_pvalue,\n",
    "        SARS_random_pvalue,\n",
    "        SARS_butina_pvalue,\n",
    "        SARS_bemismurcko_pvalue,\n",
    "        SARS_kmeans_pvalue,\n",
    "        MERS_random_pvalue,\n",
    "        MERS_butina_pvalue,\n",
    "        MERS_bemismurcko_pvalue,\n",
    "        MERS_kmeans_pvalue,\n",
    "    ],\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "829f672d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'Gains': 12.227553585741356, 'Losses': -18.17592830446081, 'Total': -3.289677684979128}\n",
      "{'Gains': 14.179667449110744, 'Losses': -13.632641785444216, 'Total': 2.652715763065571}\n",
      "One-sided (alternative: less) Wilcoxon signed-rank test (mean): p-value=0.8476790389816952\n",
      "One-sided (alternative: less) Wilcoxon signed-rank test (median): p-value=0.07946278619573893\n",
      "One-sided (alternative: greater) Wilcoxon signed-rank test (mean): p-value=0.15232096101830483\n",
      "One-sided (alternative: greater) Wilcoxon signed-rank test (median): p-value=0.9205372138042611\n",
      "Regular Wilcoxon signed-rank test (mean): p-value=0.30464192203660967\n",
      "Regular Wilcoxon signed-rank test (median): p-value=0.15892557239147787\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 629.921x314.961 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_astra_compare_results_quantitative(\n",
    "    mses_average=[\n",
    "        LogD_random_mse_best_mean,\n",
    "        LogD_butina_mse_best_mean,\n",
    "        LogD_bemismurcko_mse_best_mean,\n",
    "        LogD_kmeans_mse_best_mean,\n",
    "        KSOL_random_mse_best_mean,\n",
    "        KSOL_butina_mse_best_mean,\n",
    "        KSOL_bemismurcko_mse_best_mean,\n",
    "        KSOL_kmeans_mse_best_mean,\n",
    "        HLM_random_mse_best_mean,\n",
    "        HLM_butina_mse_best_mean,\n",
    "        HLM_bemismurcko_mse_best_mean,\n",
    "        HLM_kmeans_mse_best_mean,\n",
    "        MDR1_MDCKII_random_mse_best_mean,\n",
    "        MDR1_MDCKII_butina_mse_best_mean,\n",
    "        MDR1_MDCKII_bemismurcko_mse_best_mean,\n",
    "        MDR1_MDCKII_kmeans_mse_best_mean,\n",
    "        MLM_random_mse_best_mean,\n",
    "        MLM_butina_mse_best_mean,\n",
    "        MLM_bemismurcko_mse_best_mean,\n",
    "        MLM_kmeans_mse_best_mean,\n",
    "        SARS_random_mse_best_mean,\n",
    "        SARS_butina_mse_best_mean,\n",
    "        SARS_bemismurcko_mse_best_mean,\n",
    "        SARS_kmeans_mse_best_mean,\n",
    "        MERS_random_mse_best_mean,\n",
    "        MERS_butina_mse_best_mean,\n",
    "        MERS_bemismurcko_mse_best_mean,\n",
    "        MERS_kmeans_mse_best_mean,\n",
    "    ],\n",
    "    mses_median=[\n",
    "        LogD_random_mse_best_median,\n",
    "        LogD_butina_mse_best_median,\n",
    "        LogD_bemismurcko_mse_best_median,\n",
    "        LogD_kmeans_mse_best_median,\n",
    "        KSOL_random_mse_best_median,\n",
    "        KSOL_butina_mse_best_median,\n",
    "        KSOL_bemismurcko_mse_best_median,\n",
    "        KSOL_kmeans_mse_best_median,\n",
    "        HLM_random_mse_best_median,\n",
    "        HLM_butina_mse_best_median,\n",
    "        HLM_bemismurcko_mse_best_median,\n",
    "        HLM_kmeans_mse_best_median,\n",
    "        MDR1_MDCKII_random_mse_best_median,\n",
    "        MDR1_MDCKII_butina_mse_best_median,\n",
    "        MDR1_MDCKII_bemismurcko_mse_best_median,\n",
    "        MDR1_MDCKII_kmeans_mse_best_median,\n",
    "        MLM_random_mse_best_median,\n",
    "        MLM_butina_mse_best_median,\n",
    "        MLM_bemismurcko_mse_best_median,\n",
    "        MLM_kmeans_mse_best_median,\n",
    "        SARS_random_mse_best_median,\n",
    "        SARS_butina_mse_best_median,\n",
    "        SARS_bemismurcko_mse_best_median,\n",
    "        SARS_kmeans_mse_best_median,\n",
    "        MERS_random_mse_best_median,\n",
    "        MERS_butina_mse_best_median,\n",
    "        MERS_bemismurcko_mse_best_median,\n",
    "        MERS_kmeans_mse_best_median,\n",
    "    ],\n",
    "    mses_astra=[\n",
    "        LogD_random_mse_astra,\n",
    "        LogD_butina_mse_astra,\n",
    "        LogD_bemismurcko_mse_astra,\n",
    "        LogD_kmeans_mse_astra,\n",
    "        KSOL_random_mse_astra,\n",
    "        KSOL_butina_mse_astra,\n",
    "        KSOL_bemismurcko_mse_astra,\n",
    "        KSOL_kmeans_mse_astra,\n",
    "        HLM_random_mse_astra,\n",
    "        HLM_butina_mse_astra,\n",
    "        HLM_bemismurcko_mse_astra,\n",
    "        HLM_kmeans_mse_astra,\n",
    "        MDR1_MDCKII_random_mse_astra,\n",
    "        MDR1_MDCKII_butina_mse_astra,\n",
    "        MDR1_MDCKII_bemismurcko_mse_astra,\n",
    "        MDR1_MDCKII_kmeans_mse_astra,\n",
    "        MLM_random_mse_astra,\n",
    "        MLM_butina_mse_astra,\n",
    "        MLM_bemismurcko_mse_astra,\n",
    "        MLM_kmeans_mse_astra,\n",
    "        SARS_random_mse_astra,\n",
    "        SARS_butina_mse_astra,\n",
    "        SARS_bemismurcko_mse_astra,\n",
    "        SARS_kmeans_mse_astra,\n",
    "        MERS_random_mse_astra,\n",
    "        MERS_butina_mse_astra,\n",
    "        MERS_bemismurcko_mse_astra,\n",
    "        MERS_kmeans_mse_astra,\n",
    "    ],\n",
    "    pvals=[\n",
    "        LogD_random_pvalue,\n",
    "        LogD_butina_pvalue,\n",
    "        LogD_bemismurcko_pvalue,\n",
    "        LogD_kmeans_pvalue,\n",
    "        KSOL_random_pvalue,\n",
    "        KSOL_butina_pvalue,\n",
    "        KSOL_bemismurcko_pvalue,\n",
    "        KSOL_kmeans_pvalue,\n",
    "        HLM_random_pvalue,\n",
    "        HLM_butina_pvalue,\n",
    "        HLM_bemismurcko_pvalue,\n",
    "        HLM_kmeans_pvalue,\n",
    "        MDR1_MDCKII_random_pvalue,\n",
    "        MDR1_MDCKII_butina_pvalue,\n",
    "        MDR1_MDCKII_bemismurcko_pvalue,\n",
    "        MDR1_MDCKII_kmeans_pvalue,\n",
    "        MLM_random_pvalue,\n",
    "        MLM_butina_pvalue,\n",
    "        MLM_bemismurcko_pvalue,\n",
    "        MLM_kmeans_pvalue,\n",
    "        SARS_random_pvalue,\n",
    "        SARS_butina_pvalue,\n",
    "        SARS_bemismurcko_pvalue,\n",
    "        SARS_kmeans_pvalue,\n",
    "        MERS_random_pvalue,\n",
    "        MERS_butina_pvalue,\n",
    "        MERS_bemismurcko_pvalue,\n",
    "        MERS_kmeans_pvalue,\n",
    "    ],\n",
    "    subset=\"insignificant\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "a33f3892",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'Gains': 9.864216050856038, 'Losses': -3.921531538560188, 'Total': 2.6344834271919813}\n",
      "{'Gains': 3.9248791618476364, 'Losses': -3.921531538560188, 'Total': 0.0005579372145747552}\n",
      "One-sided (alternative: less) Wilcoxon signed-rank test (mean): p-value=0.25\n",
      "One-sided (alternative: less) Wilcoxon signed-rank test (median): p-value=0.5\n",
      "One-sided (alternative: greater) Wilcoxon signed-rank test (mean): p-value=0.875\n",
      "One-sided (alternative: greater) Wilcoxon signed-rank test (median): p-value=0.75\n",
      "Regular Wilcoxon signed-rank test (mean): p-value=0.5\n",
      "Regular Wilcoxon signed-rank test (median): p-value=1.0\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmsAAAEwCAYAAADo7TZNAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAPZ5JREFUeJzt3QucTPX/+PH3Xq1130K5Sy4RRVJyK4RECREpCbkVRSn9cuuryFcuqQhflC9KbiGXlGtIKkLoQmW7KJdcd9fe5v94f77/GTO7s8zsnpmdmX09H49jd86cnfmcs+O97/O5htlsNpsAAAAgIIXndgEAAACQNZI1AACAAEayBgAAEMBI1gAAAAIYyRoAAEAAI1kDAAAIYCRrAAAAAYxkDQAAIICRrAEAAAQwkjUf+umnnyQsLMxs3333ndtjdu7cKa1bt5ZrrrlGChQoIDfccIP07NlT4uPjzfOPPfaY4zWy2vQYVaFCBce+qKgoqVixonTr1k1+/PHHbJcvFMydO9ec4y+//JIr779p0yYZNWpUrrw3cCXEqcBAnPJOWFhYlnFV9+vzoYRkzYc++ugjt9/brV+/Xho0aCDp6ekybdo0Wb58ufTp00e++eYbOXz4sDlm+PDhsmPHDsdWu3ZtKV++vMs+Pcbu9ttvN/s2bNggTz/9tHz88cdy6623yq+//up1+WBdsjZ69GguJwIScQqhFqd69epl/g6GFF0bFL7RsGFDW6VKlWzVq1e31atXL9PzzZo1s1WsWNGWkpKS6bmLFy+6fc0mTZrYqlat6va58uXL21q2bOmyb/bs2br2q2306NFely9UzJkzx1yDn3/+OVfef+TIkeb9gUBEnAoMxCnviIiJrXkFNWs+cuLECdm+fbtp4tRt165d8scff7gc8/vvv8vVV18tkZGRmX4+OjraknLcdttt5uuff/7pdfk8cf78edN8++yzz2Z6bsSIERITEyOnT5927Pv666+lVatW5rxjY2OlWrVqMnToUPGHr776ytQyapkqVaok77zzTqZjtAbykUcekRIlSki+fPlMTebKlSszHefJedibpe13q85N1942i2oTrv7cwIEDpVSpUlKlShVZt26d1KpVS+Li4uT111/3+jyOHz8u/fv3N03v+jssVKiQNG7c2NT4umue2bx5s9x7771SsGBBU7s7adIkr84BgYc4RZwK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Wh8dAaoDAjQp0KRJO2trBq8jFzV50A7uzuyjNnU0oj5nf6yjOvWP6JXoz+ggBR3kUKFCBdm9e7cZjJCx+SuQaJOj1mg50ya2nj17ms7u48aNk/bt25trpzWGOkjAThMnrTnU89NBFpqcNmrUyPH86tWrTS2ZjmjUBOLdd981TZ7lypUzz2sHe22a1s71+lr6nN5lbd26VaZNm+YYRq61bFoDl5iYaAYhBPL1zIon11NpoqqJ1kcffSQtWrQwgynsnz39DOuoNh0Fevz4cRk6dKjbu9natWubO9QZM2aY/w/6edcRqgguxDPvEMv8oyexjAEGVli9erWtXr16ppN66dKlbY899pjt2LFjZjDAAw88YAYAXHPNNbbx48fbmjVrZgYT2OmvwN22cePGLDux6vMffvih+T4lJcXWpUsXW9myZW3R0dG2ChUq2MaMGWMLVHo+7s63ZcuW5vn58+fbKleubIuMjDRf33//fZeff/XVV2033HCDudYlSpQw19p5MMH27dvNQI2iRYuaDu/169c3Az+cHTlyxNa+fXtbkSJFzDHa6X7y5MmO52fNmmW76aabbLGxsba4uDjzOzx69Kgt2DrlenI97Z555hlb8eLFze/CeaDLnj17HJ/tatWq2dauXWsGcNg/f870GurvRF9j0KBBFp8h/IV45hlimW8Qy9wL03/8lBwDAADAS/RZAwAACGAkawAAAAGMZA0AACCAkawBAAAEMJI1AACAAEayBgAAEMBI1gAAAAIYyRoAAEAAI1kDAAAIYCRrAAAAAYxkDQAAQALX/wM1peZlBwIm8AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 629.921x314.961 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_astra_compare_results_quantitative(\n",
    "    mses_average=[\n",
    "        LogD_random_mse_best_mean,\n",
    "        LogD_butina_mse_best_mean,\n",
    "        LogD_bemismurcko_mse_best_mean,\n",
    "        LogD_kmeans_mse_best_mean,\n",
    "        KSOL_random_mse_best_mean,\n",
    "        KSOL_butina_mse_best_mean,\n",
    "        KSOL_bemismurcko_mse_best_mean,\n",
    "        KSOL_kmeans_mse_best_mean,\n",
    "        HLM_random_mse_best_mean,\n",
    "        HLM_butina_mse_best_mean,\n",
    "        HLM_bemismurcko_mse_best_mean,\n",
    "        HLM_kmeans_mse_best_mean,\n",
    "        MDR1_MDCKII_random_mse_best_mean,\n",
    "        MDR1_MDCKII_butina_mse_best_mean,\n",
    "        MDR1_MDCKII_bemismurcko_mse_best_mean,\n",
    "        MDR1_MDCKII_kmeans_mse_best_mean,\n",
    "        MLM_random_mse_best_mean,\n",
    "        MLM_butina_mse_best_mean,\n",
    "        MLM_bemismurcko_mse_best_mean,\n",
    "        MLM_kmeans_mse_best_mean,\n",
    "        SARS_random_mse_best_mean,\n",
    "        SARS_butina_mse_best_mean,\n",
    "        SARS_bemismurcko_mse_best_mean,\n",
    "        SARS_kmeans_mse_best_mean,\n",
    "        MERS_random_mse_best_mean,\n",
    "        MERS_butina_mse_best_mean,\n",
    "        MERS_bemismurcko_mse_best_mean,\n",
    "        MERS_kmeans_mse_best_mean,\n",
    "    ],\n",
    "    mses_median=[\n",
    "        LogD_random_mse_best_median,\n",
    "        LogD_butina_mse_best_median,\n",
    "        LogD_bemismurcko_mse_best_median,\n",
    "        LogD_kmeans_mse_best_median,\n",
    "        KSOL_random_mse_best_median,\n",
    "        KSOL_butina_mse_best_median,\n",
    "        KSOL_bemismurcko_mse_best_median,\n",
    "        KSOL_kmeans_mse_best_median,\n",
    "        HLM_random_mse_best_median,\n",
    "        HLM_butina_mse_best_median,\n",
    "        HLM_bemismurcko_mse_best_median,\n",
    "        HLM_kmeans_mse_best_median,\n",
    "        MDR1_MDCKII_random_mse_best_median,\n",
    "        MDR1_MDCKII_butina_mse_best_median,\n",
    "        MDR1_MDCKII_bemismurcko_mse_best_median,\n",
    "        MDR1_MDCKII_kmeans_mse_best_median,\n",
    "        MLM_random_mse_best_median,\n",
    "        MLM_butina_mse_best_median,\n",
    "        MLM_bemismurcko_mse_best_median,\n",
    "        MLM_kmeans_mse_best_median,\n",
    "        SARS_random_mse_best_median,\n",
    "        SARS_butina_mse_best_median,\n",
    "        SARS_bemismurcko_mse_best_median,\n",
    "        SARS_kmeans_mse_best_median,\n",
    "        MERS_random_mse_best_median,\n",
    "        MERS_butina_mse_best_median,\n",
    "        MERS_bemismurcko_mse_best_median,\n",
    "        MERS_kmeans_mse_best_median,\n",
    "    ],\n",
    "    mses_astra=[\n",
    "        LogD_random_mse_astra,\n",
    "        LogD_butina_mse_astra,\n",
    "        LogD_bemismurcko_mse_astra,\n",
    "        LogD_kmeans_mse_astra,\n",
    "        KSOL_random_mse_astra,\n",
    "        KSOL_butina_mse_astra,\n",
    "        KSOL_bemismurcko_mse_astra,\n",
    "        KSOL_kmeans_mse_astra,\n",
    "        HLM_random_mse_astra,\n",
    "        HLM_butina_mse_astra,\n",
    "        HLM_bemismurcko_mse_astra,\n",
    "        HLM_kmeans_mse_astra,\n",
    "        MDR1_MDCKII_random_mse_astra,\n",
    "        MDR1_MDCKII_butina_mse_astra,\n",
    "        MDR1_MDCKII_bemismurcko_mse_astra,\n",
    "        MDR1_MDCKII_kmeans_mse_astra,\n",
    "        MLM_random_mse_astra,\n",
    "        MLM_butina_mse_astra,\n",
    "        MLM_bemismurcko_mse_astra,\n",
    "        MLM_kmeans_mse_astra,\n",
    "        SARS_random_mse_astra,\n",
    "        SARS_butina_mse_astra,\n",
    "        SARS_bemismurcko_mse_astra,\n",
    "        SARS_kmeans_mse_astra,\n",
    "        MERS_random_mse_astra,\n",
    "        MERS_butina_mse_astra,\n",
    "        MERS_bemismurcko_mse_astra,\n",
    "        MERS_kmeans_mse_astra,\n",
    "    ],\n",
    "    pvals=[\n",
    "        LogD_random_pvalue,\n",
    "        LogD_butina_pvalue,\n",
    "        LogD_bemismurcko_pvalue,\n",
    "        LogD_kmeans_pvalue,\n",
    "        KSOL_random_pvalue,\n",
    "        KSOL_butina_pvalue,\n",
    "        KSOL_bemismurcko_pvalue,\n",
    "        KSOL_kmeans_pvalue,\n",
    "        HLM_random_pvalue,\n",
    "        HLM_butina_pvalue,\n",
    "        HLM_bemismurcko_pvalue,\n",
    "        HLM_kmeans_pvalue,\n",
    "        MDR1_MDCKII_random_pvalue,\n",
    "        MDR1_MDCKII_butina_pvalue,\n",
    "        MDR1_MDCKII_bemismurcko_pvalue,\n",
    "        MDR1_MDCKII_kmeans_pvalue,\n",
    "        MLM_random_pvalue,\n",
    "        MLM_butina_pvalue,\n",
    "        MLM_bemismurcko_pvalue,\n",
    "        MLM_kmeans_pvalue,\n",
    "        SARS_random_pvalue,\n",
    "        SARS_butina_pvalue,\n",
    "        SARS_bemismurcko_pvalue,\n",
    "        SARS_kmeans_pvalue,\n",
    "        MERS_random_pvalue,\n",
    "        MERS_butina_pvalue,\n",
    "        MERS_bemismurcko_pvalue,\n",
    "        MERS_kmeans_pvalue,\n",
    "    ],\n",
    "    subset=\"significant\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "f2fee53d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmsAAAJrCAYAAAC/TNTkAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAmm1JREFUeJzt3QmcjeX///HPWEIheyJJpSgtJO1JlDb1LRTybUGJCilKkUjR8m3XXtpIaKO+rUqUFokoLdYiVMi+FO7/43X9/tf53nPmDIazznk/H49h5syZmXvuuc91f67P9bmuKycIgsBEREREJC0VSfUBiIiIiEj+FKyJiIiIpDEFayIiIiJpTMGaiIiISBpTsCYiIiKSxhSsiYiIiKQxBWsiIiIiaayYFWJbt261xYsXW5kyZSwnJyfVhyMiIiISwVK3a9assWrVqlmRIkWyM1gjUKtRo0aqD0NEREQkXwsXLrR99tknO4M1Mmr+JJQtWzbVhyMiIiISsXr1apdU8vFKVgZrfuiTQE3BmoiIiKSj7ZVqaYKBiIiISBpTsCYiIiKSxhSsiYiIiKQxBWsiIiIiaUzBmoiIiEgaU7AmIiIiksYUrImIiIiksUK9zlqyfDc8PbeyqndxkOpDEBERkV2kzJqIiIhIGlOwJiIiIpLGFKyJiIiIpDEFayIiIiJpTMGaiIiISBpTsCYiIiKSxhSsiYiIiKQxBWsiIiIiaUzBmoiIiEgaU7AmIiIiUpiDta1bt9rs2bNt06ZN8TkiEREREdn5YK1fv342dOhQ9/7atWutQYMGdvDBB9vee+9tkydPLui3ExEREZF4BmsvvfSSC9AwcuRIW7ZsmX355ZfWtm1b6927d0G/nYiIiIjEM1hbunSp7bPPPu79Tz/91Dp06GBHH3209ezZ02bMmFGg7zVr1ixr2bKlVa9e3XJycmzMmDG5Pj9hwgQ7/PDDrUSJEu7/iRMnFvRwRURERLIrWCOw+uSTT2zNmjX2wQcfWOPGjd3j69ats+LFixfoezGMuv/++9uDDz6Y53O///67tWjRwpo0aWLTpk1zP4eP//zzz4IesoiIiEjGKlbQL+jRo4ddcsklVqxYMTvggAMiwZrPghVEo0aN3Fssw4cPt913393uv/9+K1KkiD3wwAP28ssvu8c5hliY5BCe6LB69eoCHY+IiIhIxmfWrrnmGvv6669dvdoXX3zhgjbUrl3bBg8eHLcDmzp1qh133HEuUEPRokXthBNOcD87P/z8PffcM/JWo0aNuB2PiIiISMYs3cEEgwsuuMAFRN6ZZ55pxx57bNwOjOHOSpUquSHQChUq2FdffeU+3tYwaJ8+fWzVqlWRt4ULF8bteEREREQyYhg0WYIgcP+XKlXK9t13X9tjjz0ij+WHiQi8iYiIiGRtsDZv3jy76aabbMqUKbZixYo8AVS86sSqVKnilgWpU6eOTZ8+3T22fPlyq1y5cly+v4iIiEihDNYuuugi++eff6x79+5Wvnz5xByVmR111FF21113uR0SqFvbsmWLW3T3lltuSdjPFBEREcn4YI210Sjyr1u37i7/8L///tt9P2/BggUui1a1alVr166d9e/f36677jrr3LmzPfbYY+75F1988S7/XBEREZFCO8GgWbNmNmfOnLj88MWLF1v9+vXdG3r16uXef/zxx13ANm7cOPvoo4/cY6ztxscaBhUREZFsUuDM2mGHHWZXXHGFnXfeeW6dNb90h8dOBjtqv/322+akgVNOOcVmzpxZ0EMUERERKTRygu1NsYxSq1at/L9ZTo6bgJAumOzA8iIs41G2bNmE/ZzvhudYOqp3cYH+tCIiIpKGcUqBM2vz58/f1WMTERERkUQuiisiIiIiabwo7uzZs+2pp55yEw0Y+qR2rVOnTnbQQQfF/whFREREsliBM2tjxoyxQw45xMaPH+/GWcuUKePeP/TQQ93nRERERCSFmbV+/frZoEGD7MYbb8z1+JAhQ6xv377WqlWrOB6eiIiISHYrcGaN2Z4tW7bM8ziPafKBiIiISIqDNZbueP311/M8/tprr21zWQ8RERERScIw6IABA9yWT6NGjXIL5DLBYMaMGTZt2jR76aWXduIQRERERCRumTU2cmdXgcaNG9uKFSts+fLldvLJJ7uArU2bNgX9diIiIiIS76U72MT93nvv3ZkvFREREZFULIq7bt06GzhwYLy+nYiIiIjEM1hbu3atq2cTERERkfjRdlMiIiIimV6zVrRoUVuyZIlVqVLFvS8iIiIiaRSssUxH+fLl3ftBELh9QcuVK5frOX/99Zd17tw5MUcpIiIikqVyAqKvAihSpIgtXbrUZdnCfv/9d6tWrZpt2bLF0sXq1avd/qWrVq2ysmXLJuznfDc8x9JRvYsL9KcVERGRNIxTClyzNmnSJKtYsWKex3fbbTe33pqIiIiIpHCdtRNOOCHm4wyTfvzxx/E4JhERERH5/zQbVERERKQwBWsdOnSwNWvW5Hl88+bN7nMiIiIiksJg7fnnn7cNGzbkeZyJBXxORERERFIYrDF5NCcn7+zHb7/9NrK8h4iIiIgkeYLBYYcd5oI03ho3bmzFihXLNQQ6f/58a926dZwOS0REREQKFKy1atXK/f/999/b2WefbaVLl861bMeBBx5o559/ftzP6sqVK61nz5729ttv2/r1661+/fp27733WqNGjfQXFBERkUIvboviJgqTFiZPnmzPPfecW99t0KBBLnBbtGiRlSxZcptfq0VxtSiuiIhI1i2K279//1xZtUT78ssvrW3btnbsscda7dq1rXfv3rZ8+XL75ZdfknYMIiIiIqmyU8Ha7rvvbsly0kkn2XvvvecCNGrjXnnlFatTp47tv//+eZ67adMmF6WG30REREQy2U5tN8WQZLQXX3zRJk6caPH24IMP2kEHHWSVKlVyw54Ea++8844VL148z3MHDx7s0on+rUaNGnE/HhEREZG0DtZ69eoVs1aModEbbrjB4u3RRx+1b775xj788EP76quv7LjjjrNzzjkn5lpvffr0ceO+/m3hwoVxPx4RERGRtN4bdObMmTFnYh5xxBFupmg8MaxJAPbqq69a06ZN3WNPP/20lStXzt544w1XyxZWokQJ9yYiIiKStZk1AqU5c+bkefznn392n4snluogYAsvwstsVD6OlVkTERERsWwP1lhvrWvXrq4+jYJ/3ni/W7ducV8Ulx0RyOL17dvXvvjiC5s9e7Z1797dtm7dak2aNInrzxIREREpFMOgQ4YMsWXLltkpp5xiRYsWdY8RPDEkSYF/vI0ZM8bVwp177rkum8ZOCm+99ZbVqlUr7j9LREREJOMXxfXYXooaNb68Xr16aRk8aVFcLYorIiKSrnY0TilwZs0jOEvHAE1EREQkq2vWsG7dOhs1apQbEmXvTsyaNcsNj4qIiIhI/BQ4szZjxgxr3ry5G/5kV4ELL7zQzQJ95JFH3MzNZ555Jo6HJyIiIpLdCpxZY9Znx44dbcmSJbkWxyVo++ijj+J9fCIiIiJZrcDB2tSpU61Dhw651j5DzZo1XQAnIiIiIikM1lj77JdffokZxFWvXj1exyUiIiIiOxOsMQR61VVX2Xvvvec+XrRokY0cOdItVkvGTURERERSOMHg1ltvdZMLLrjgArdILYvjUrvGBu8333xzHA9NRERERHZ6UVxmfrL9E2rXrp2WG6hrUVwtiisiIpK1i+ISnLFzgYiIiIik2aK4saxdu9Z69uwZr28nIiIiIvEM1tjV4MEHH9RJFREREUnHYO3NN9+0ypUrx+vbiYiIiMiO1qxtq+jNTzbYunWr3XfffTqpIiIiIskO1qhHe+CBB9yMhVhKly5t9evXt/333z+exyYiIiKS9XZ4NmibNm2sSpUqWX/CRERERNKuZm3YsGH5ZtVEREREJMWZtUsvvTSBhyAiIiIicZ0NOmXKFOvataudccYZtmTJEvfYiBEj3GbuIiIiIpLCYG306NHWuHFjW758uU2YMMHtD4p58+bZwIED43hoIiIiIlLgYI2AjBq2V155xYoXLx55vHnz5vbll1/qjIqIiIikMlibO3euHXPMMXkeL1eunNuIVERERERSGKwdcMAB9tlnn+V5fOzYsVa3bt14HZeIiIiI7Ohs0LBbb73VLrvsMvvuu+9sy5YtNmbMGFev9txzz7lJBiIiIiKSwsxa69at7a233nL1abvvvrvdfffd9tNPP9k777xjF1xwgSXCuHHj7KijjrKSJUvaXnvtZf369UvIzxERERHJ+MwamjRp4t6S4cMPP7RWrVq5jN7w4cNt8+bNtnjx4qT8bBEREZGMDNaSadCgQW5R3ltuuSXyWL169VJ6TCIiIiJpOww6ceJEt76ad88999gJJ5xgXbp0sTVr1sT14P755x+bPHmyHXTQQW5tN4ZAmzVrZjNmzIj5/E2bNtnq1atzvYmIiIhkVbB2/fXXuwVxMX78eLv55pvtyCOPtE8++cSuu+66uB7csmXLXMBGXdy///1vVxfHZvKs6bZ27do8zx88eLDbw9S/1ahRI67HIyIiIpL2wdoPP/xgDRo0cO8TPLVt29aGDh3qFsp9++2343pwW7dudf+3aNHCOnXq5H7uE0884YI4atmi9enTx6315t8WLlwY1+MRERERSfuatVKlStnKlSvd+5MmTbLu3bu79ytXrhz3YccKFSpYTk6OGwb1ypQpY5UqVbLffvstz/NLlCjh3kRERESyNlijZqx9+/Z26KGH2syZM+20005zj/N+rVq14npwBIYHH3ywW8fNW79+vRuGrV69elx/loiIiEihGAZ99NFH7dRTT7WNGze6RXDJqGH69OkuiIu3jh072osvvmijRo2y2bNnW48ePVzGrWnTpnH/WSIiIiIZn1krX768Pfzww3ke79+/vyVCz549bcWKFdatWzc3qYC6NWrlGA4VERERKexygiAIrJCiho5ZoUw2KFu2bMJ+znfDcywd1bu40P5pRUREsiZOKfAwqIiIiIgkj4I1ERERkTSmYE1EREQkjSlYExEREUljCtZERERE0piCNREREZE0pmBNREREJI0pWBMRERHJ9GBt4sSJtnnz5jzvi4iIiEgaBGtNmjRxWz5Fvy8iIiIiaRCslSpVylauXOneZ3eqnJz03F5JREREJCs3cj/55JPt9NNPt8MOO8x93L59eytRokTM544dOza+RygiIiKSxXYoWBsxYoQ9/vjjNnfuXJdVK1++vMu2iYiIiEhi5QSMaxZAkSJFbOnSpValShUrLLvZ76rvhqfnsHC9iwv0pxUREZE0jFMKvHTHpZdeqqyaiIiISDoNg4YNGzYsMUciIiIiInloUVwRERGRwhaskV1r1KiRVahQwSpWrOjef/bZZ+N/dCIiIiJZrsDDoP3797cHHnjAOnXqZFdffbVbd23GjBl23XXX2YIFC2zgwIGJOVIRERGRLFTgYO3pp5+2F154wc4777xcj5900knWtWtXBWsiIiIiqRwGZaupOnXq5Hm8bt26kV0ORERERCRFwVrDhg1twIABuQIz3ucxPiciIiIiKRwGfeSRR9wQaNWqVa1atWpuR4PffvvNffzGG2/E8dBEREREpMDB2hFHHGFz5syxd955x20/hQMOOMDOOOMMK168uM6oiIiISCqDNfdFxYpZixYt4nkcIiIiIpLpi+J269bNDbuOGTMm1YciIiIikhQZE6x98MEHbj03ERERkWyyU8OgycZyIazh9t///tcOOuigfJ+3adMm9xbezV5EREQkk2VEsNalSxfr3Lmz1a5de5vPGzx4sFtCRHZczj3j0u50Bb1UDykiIpIxw6Avvvii28aK7ay2p0+fPrZq1arI28KFC5NyjCIiIiJZmVkj2Lr++uvt448/tqJFi273+SVKlHBvIiIiIoVFWmfWpk6dasuWLbOjjjrKSpYs6d7Qrl079yYiIiJS2KV1Zq1Zs2Y2a9asPHuQ3nvvvdaqVauUHZeIiIhI2gZrbdq0cUFUp06dLNFKly4dc9N4trniTURERKSwK/Aw6NixY+3EE09MzNGIiIiIyK5l1ipVqmTr16+3VAmCIGU/W0RERCTtM2t9+/a1fv362dq1axNzRCIiIiKy85m1cePGuW2fatSoYYcddpiVK1cuzzCpiIiIiKRwGJQJBiIiIiKShsHasGHDEnMkIiIiIpJZi+KKiIiIZLtdCtaWLl1qW7dujd/RiIiIiMiuBWsbN260a665xnbffXfbZ5993Cbr6Nq1qz388MMF/XYiIiIiEs9g7YYbbrApU6bYmDFjcm2azkK5zz//fEG/nYiIiIjEc4LB66+/7pbvaNCggRUp8r9Y7+ijj7aff/65oN9OREREROKZWVuzZo3bszPaqlWrrFixtN4XXkRERCTjFDi6OvXUU23IkCH2zDPPuI9zcnLc9lO33XabNW3aNBHHKJJH/fduS8uzMq15eh6XiIhkUbD24IMPWvPmzW3fffe1DRs2WNu2bW3u3LlWoUIFe//99xNzlCIiIiJZqsDBWs2aNW3mzJk2YsQI9z+6dOnigrbddtstEccoIiIikrV2qsisePHidumll8b/aERERERk14O15cuX28svv+yGP6lZq127trVp08bKly+/M99OREREROI1G/Stt95y9Wp33nmnffvttzZt2jS7/fbb3WPvvfdeQb+diIiIiMQzs9ajRw/r3r27DRo0KLLOWhAEdvPNN9u1116rtdZEREREUplZW7JkiV1++eW5FsRlKLRDhw62aNGieB6biIiISNYrcLDWunVre+655/I8PmzYMPc5EREREUnyMOi5554bef/vv/+24cOHu4CtTp067rEff/zR/vjjD2vWrFkcD01EREREdihYq1ixYq6P27dvn+tjJheIiIiISIqCNYY4RURERCQDZoMy83PKlCn266+/uu2m+DjskksuiefxiYiIiGS1Agdr1K999tlndvDBB1vJkiVzfY5ZoQrWRERERFIYrJFV+/TTT+2QQw6xRLvjjjts5MiRNm/ePNtzzz3trLPOsiFDhlilSpUS/rNFREREMjJYu+WWW+yqq66yE088MU9mDbfeemu8js0+//xzu/HGG61hw4a2cuVK93MvuugiGz9+fNx+hoiIiEihCtaYbLB+/XqbP39+zGAtntjaKjoQbNmypa1atcpl2qJt2rTJvXmrV69O6PGJiIiIpF2wtm7dOhs7dqyrWUu233//3UqVKmUlSpSI+fnBgwfbgAEDkn5cIgXx3fCctDth9S7OPVEoPzn3jLN0E/RqkepDEBFJr2Bt7733thYtWrihyViZtWeffdYSYe3atXb//ffb1VdfnW9Gr0+fPtazZ89cmbUaNWok5HhERERE0jJYa9KkiSXb5s2brV27dlatWjU36SA/ZNzyy7qJiIiIZEWw1r9/f0umrVu3uuVA2ECeiQW77bZbUn++iIiISEYFa926ddvm5x966CGLFxbc7dixo82aNcs++ugjK1u2bNy+t4iIiEihDNZmzpyZJ/O1aNEi++WXX9xyHvHEUh0EacwKZQP5pUuXuscrV65sRYsWjevPEhERESkUwdrHH38c8/GXX37ZLZgbT08++aT7//DDD8/1OMuG7LfffnH9WSIiIiLpqEi8vlHbtm1t1KhRFk8Mg8Z6U6AmIiIi2aLAmbUVK1bEXFZj9OjR8TomEREREdnZYI19OdmwPVqZMmXsscceK+i3ExEREZF4BmsU/IeDNd4vV66c1a5d2+0uICIiIiIpDNZOOeWUOP54EREREYlLsDZw4MDtPocsW79+/Xb0W4qIiIhIvIK17U0g+PHHH92aawrWRERERFIQrEUvhouVK1fasGHD3MSC/fff37p06RLHQxMRERGRAtes4dtvv7WhQ4faK6+84jZ2f+SRR+z000/X2RQRERFJVbC2efNmNxRKkDZ79my3Z+eMGTOsZs2a8T4mERERESlosLbPPvvY8uXL7eyzz7arr77aSpQoYVOnTnVvYRdccMGOfksRERERiVew9scff7j/x44d697ymw26ZcuWHf2WIiJJUf+929LyTE9rvv3j+m543kXIU63excEOPS/nnnGWboJeLTLyetmRayWTr5d0vFZ29HpJq2CNmZ4iIiIikqEbuYuIiIhI/ClYExEREUljCtZERERE0piCNREREZE0pmBNREREJI0pWBMRERFJYwrWRERERNKYgjURERGRNKZgTURERCSNKVgTERERSWMK1kRERETSmII1ERERkTSW9sFaEATWr18/q1KlipUuXdratm1rq1atSvVhiYiIiCRF2gdrjz76qN1///321FNP2YQJE2z69Ol21VVXpfqwRERERJIi7YO1J554wrp06WLnnXeeNWzY0IYM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MzRUrly5tNtEOboGM/waZsizbNmykWEVfpd27drZgQceGBkOTcV174+V64DXaocOHVzN6MaNG93jtDFz58615s2bW5UqVeyyyy6zIUOGuMcffvjhlNdUMfGBY2GIk/P5yy+/uOPh/DLczOcZBi1ZsqR7/jXXXOPq79577z2bPXu2pdKoUaMiM2zD18qUKVOsfv367nqgjaHUJV2HyjkujnnNmjXuY95/6623rGnTpq52muudtp1rKB1LLBii9dfv4sWLberUqbZp0yYbO3asqwHn9XDdddfZjz/+aFkh1dFiJlu3bl3Qo0ePoF69esFbb73lelz0DmvVquWGUzBjxgyXcvaZEt8L69u3r+tZrlq1KiXHHu6pf/PNN8Evv/wS8/OvvPJKUL169bTKUIV7srzPcMrChQsjj/leF8MpFStWdOc6XXBsN9xwQ9CgQYOgX79+LqNDdjN8/Fw/RYsWdVmGcPb1p59+cr9rOvQqf/311zzZM4Y8W7VqFRx66KFpcYyxkOW++uqr3euRUgWPIRaGm332kuuKc0929rPPPkvJsX799dfuOuF83n333cExxxzjsiJPP/10JHNVuXLl4LHHHsv1NyBDWLZsWZc5Qar+FrRtZPpoIzm/jCY8++yzkeNs27ZtcNBBB7msicew/1577eXazVTidUbbF23p0qXBl19+6d6/9dZb3fDuf//7X/dxOmbYuB+1adPGZTRp07t16xZUqFDB/U95C9dUiRIlgssuuyxIF4xIcV65Pnjfa926dVC1alV3zVCew8f77rtvcNVVV0UyhIWZgrVdwAuXi57hhzCGg2688cZIg0r9TpkyZYI///wz8pwWLVq4uipeRKlCI9m4cWPXiDIskd+xUC/FUCg1SEiXG/Gjjz7qhge5IfA/NwIC6HDDSdBcunTpYPr06ZGvmzt3bpBKpPI53t122y1SFxU+5ieffNIFCeEbFue8e/furp4qldcM1zBDb/vvv78LMq+77rpcDeXnn38elCxZMvKaSJdrZf369W5Irly5ckHHjh1dEH/qqadGbsgMm3ODuOaaa4LVq1e7x1auXOmu/Zo1ayb9eLmOeU1yo/XHA4I3gk3fmaL9oQY2HDhzzfOa5m+T6iCCGyrXcu3atYMpU6bkuibeeOMNFyxQ++URxPG6YJguVcLni+vdD9NG+/bbb127yO9IO59KnNPw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wgTbfffd831eiRIl3JuIiIhIYZH2mbWxY8falVdeaW+88YY1aNAg1YcjIiIiklRpHay9++671r59e3vllVfs1FNPTfXhiIiIiGTXMOjff//t1lrzFixYYNOnT7eqVatG1mC7//77rX79+rZ06VL3nNKlS7s3ERERkWyQ0qU7CM5q1aqV5/H+/fu7zz3//PMxP3fbbbfFdUrsrtJs0Ng0G1RERCTDl+7Yb7/93Ppp+XnuueeSejwiIiIi6Sata9ZEREREsp2CNREREZE0pmBNREREpDAHa1u3brXZs2fn2pNTRERERFIUrPXr18/tJuD362Sh2oMPPtj23ntvmzx5cpwOS0RERER2Klh76aWXIjsJsA3UsmXL7Msvv7S2bdta7969dVZFRERE4qjAS3ewOO0+++zj3v/000+tQ4cOdvTRR1uFChXc4rUiIiIiksLMWvXq1e2TTz6xNWvW2AcffGCNGzd2j69bt86KFy8ex0MTERERkQIHaz169LBLLrnEKlas6Fbb9cHahAkT7PDDD9cZFREREUnlMOg111xjxx9/vNsOqmnTplas2P99i9q1a9vgwYPjeWwiIiIiWW+ntptigoGfZOCdeeaZWX8yRUREROJNi+KKiIiIFKZgbd68eXbhhRdarVq13E7x1K2F30REREQkhcOgF110kf3zzz/WvXt3K1++fBwPRURERER2OVibNWuWff3111a3bt2CfqmIiIiIJHoYtFmzZjZnzpyCfpmIiIiIJCOzdthhh9kVV1xh5513nh1wwAGRpTu8nj177sxxiIiIiEgMOUEQBFYATCzIT05OjpuAkC5Wr17tJkGsWrUqoZMfvhuek7DvncnqXVygS0tERCSrrN7BOKXAmbX58+fv6rGJiIiIyA7SOmsiIiIihW0Hg9mzZ9tTTz3lJhow9EntWqdOneyggw6K/xGKiIiIZLECZ9bGjBljhxxyiI0fP96Ns5YpU8a9f+ihh7rPFXQZkJYtW1r16tVd0Bf99X5z+BIlSrj/J06cWNDDFREREcmuYK1fv342aNAgmzp1qg0bNsyee+459/7tt99uffv2LdD3Wrt2re2///724IMP5vnc77//bi1atLAmTZrYtGnTrHHjxu7jP//8s6CHLCIiIpJd202RDYvGYwWdfNCoUSO75557rFWrVnk+N3z4cNt9993t/vvvd5m8Bx54wIoXL+4eFxEREckWBQ7WWLrj9ddfz/P4a6+9ts1lPQqKbN1xxx1nRYr83yEWLVrUTjjhBLd7Qn42bdrkpsGG30RERESyaoLBgAED7OKLL7ZRo0a5BXKpNZsxY4YbqnzppZfidmAMd+67777u+zZt2tTeffddq1Spki1atCjfrxk8eLA7PhEREZGszayxkfvMmTNdDdmKFSts+fLldvLJJ7uArU2bNnE7ML9Wb6lSpVzQtscee0Qey0+fPn3cwnL+beHChXE7HhEREZGMWbqDTdzvvfdeS6QqVarYsmXLrE6dOjZ9+nT3GIFh5cqV8/0aZo3yJiIiIlJYxG1R3HXr1tnAgQPj9e3sqKOOss8//9y2bt3qPt6yZYtNnjzZGjZsGLefISIiIpI1wRrLcBS0Xuzvv/92WTOfOVuwYIF7f+nSpdauXTtbv369XXfddW49th49erjnUy8nIiIiki1Sut3U4sWLrX79+u4NvXr1cu8//vjjVrVqVRs3bpx99NFH7rFPPvnEfbytYVARERGRrKxZY9mMJUuWuDoy3o+X/fbbb5uTBk455RQ3mUFEREQkW+1QsMYyHeXLl3fvE1yxL2i5cuVyPeevv/6yzp07J+YoRURERLJUTrC99TCisEgtNWVk2aK3h6pWrZqbCJAuWBSX/UtZxqNs2bIJ+znfDc9J2PfOZPUuLtClJSIiklVW72CcUuCatUmTJlnFihXzPL7bbru59dZEREREJIXrrLHlUywMk3788cfxOCYRERERSYfZoCIiIiIS52CtQ4cOtmbNmjyPb9682X1ORERERFIYrD3//PO2YcOGPI8zsYDPiYiIiEgKgzUmj+bk5J39+O2330aW9xARERGRJE8wOOyww1yQxlvjxo2tWLFiuYZA58+fb61bt47TYYmIiIhIgYK1Vq1auf+///57O/vss6106dK5lu048MAD7fzzz9dZFREREUnHRXHTkRbFTS0tiisiIpKCRXH79++fK6smIiIiImm0KC7BmoiIiIgkx05tN/Xcc8/lefzFF1+0iRMnxuu4RERERGRngrVevXpZyZIl8zzO0OgNN9ygkyoiIiKSymBt5syZ1qhRozyPH3HEEW6mqIiIiIikMFgrV66czZkzJ8/jP//8s/uciIiIiKQwWGO9ta5du7r6NBbD5Y33u3XrpkVxRURERFI9G3TIkCG2bNkyO+WUU6xo0aLusa1bt1rbtm1t8ODB8T4+ERERkaxW4GCtVKlSNnz4cBs0aJCrUWNN3Xr16lmtWrUSc4QiIiIiWazAwZpHcKYATURERCTNatawbt06GzVqlBsSXblypXts1qxZbnhURERERFIYrM2YMcNt2s6Egn79+tmKFSvc44888ojdeOONFm8Egx06dLC99trLypQpYyeffLJ99dVXcf85IiIiIoUiWCNI69ixoy1ZsiTX4rgXXnihffTRR/E+PuvZs6dNnjzZ3nzzTfvmm2/c0OtZZ51lGzdujPvPEhEREcn4YG3q1Kku05WTk5Pr8Zo1a7oALt6+/PJLN9P02GOPtdq1a1vv3r1t+fLl9ssvv+R57qZNm9wO9uE3ERERkawK1sqXLx8zUCKIq169usXbSSedZO+9954L0FjT7ZVXXrE6derY/vvvn+e5LB2y5557Rt5q1KgR9+MRERERSetgjSHQq666ygVQWLRokY0cOdK6d+/uMm7x9uCDD9pBBx1klSpVcsOuBGvvvPOOFS9ePM9z+/TpY6tWrYq8LVy4MO7HIyIiIpLWS3fceuutbm21Cy64wDZs2OAWxyWIYoP3m2++Oe4H+Oijj7patQ8//NBl9R566CE755xzbMqUKW7Nt7ASJUq4NxEREZHCIicg8toJ1IfNnj3bvU8tWSKCJH4Gw5mvvvqqnX322e4xhkLZg/Spp55ytWzbQs0aX0+WrWzZspYo3w3PXb8n/6fexTt1aYmIiGSF1TsYp+z0orgEZ+xckEjr1693AVt4MkORIkXcx2T1RERERAq7nVoUN5a1a9e6ZTbiiWHPRo0aWd++fe2LL75wmTxq49iLtEmTJnH9WSIiIiKFOlhjVwMmA8TbmDFj3DDrueeeaw0aNHCzTt966y1tdSUiIiJZYaeHQaOxaG3lypUt3lh+gxmgIiIiItloh4K17RXnU1fG0OR9990Xr+MSERERkR0N1qhHe+CBB9yMhVhKly5t9evXj7lQrYiIiIgkYRi0TZs2VqVKlV34USIiIiKSkAkGw4YNyzerJiIiIiIpzqxdeumlCTwEEREREYnr0h1s9dS1a1c744wzbMmSJe6xESNGuGU1RERERCSFwdro0aOtcePGtnz5cpswYUJkJ4F58+bZwIED43hoIiIiIlLgYI2AjBo21j4rXrx45PHmzZvbl19+qTMqIiIikspgbe7cuXbMMcfkeZzN1dmIVERERERSGKwdcMAB9tlnn+V5fOzYsVa3bt14HZeIiIiI7Mx2U7feeqtddtll9t1339mWLVvc3p3Uqz333HNukoGIiIiIpDCz1rp1a7eROvVpu+++u9199932008/2TvvvGMXXHBBHA9NRERERHZqI/cmTZq4NxERERFJw3XWRERERCRNg7WJEye69dW8e+65x0444QTr0qWLrVmzJt7HJyIiIpLVChysXX/99W5BXIwfP95uvvlmO/LII+2TTz6x6667LhHHKCIiIpK1Clyz9sMPP1iDBg3c+0wqaNu2rQ0dOtRNOPjXv/6ViGMUERERyVoFzqyVKlXKVq5c6d6fNGmS2x8UlStXttWrV8f/CEVERESyWIEza82aNbP27dvboYceajNnzrTTTjvNPc77tWrVSsQxioiIiGStAmfWHn30UTv11FNt48aNbhFcMmqYPn26C+JEREREJH5ygiAIrJBiWHbPPfd0e5aWLVs2YT/nu+E5CfvemazexYX20hIREUlanJIR66yNGzfOjjrqKCtZsqTttdde1q9fv1QfkoiIiEj67mCQTB9++KG1atXK7Uk6fPhw27x5sy1evDjVhyUiIiKSFGkfrA0aNMguvfRSu+WWWyKP1atXL+ZzN23a5N48zU4VERGRTJfWw6D//POPTZ482Q466CBr3LixGwJlNuqMGTNiPn/w4MFu7Ne/1ahRI+nHLCIiIpI1wdqyZctcwHb33Xfbv//9b7cIb5UqVax58+a2du3aPM/v06ePK9LzbwsXLkzJcYuIiIhkxTDo1q1b3f8tWrSwTp06ufefeOIJq1Chgqtli94xoUSJEu5NREREpLBI68waQVlOTo4bBvXKlCljlSpVst9++y2lxyYiIiKSDGkdrLG11cEHH2zz5s2LPLZ+/Xq3kXz16tVTemwiIiIilu3BGjp27GgvvviijRo1ymbPnm09evRwGbemTZum+tBERERE0qNmbeLEiXb88cdbsWLFcr2fDD179rQVK1ZYt27d3KSCBg0auIkGDIeKiIiIFHY7tN1U0aJFbcmSJW4mZvj9dKftplJL202JiIgkabspasdWrlzp3ie2o+hfRERERBJvh8YyTz75ZDv99NPtsMMOcx+3b98+3yUyxo4dG98jFBEREcliOxSsjRgxwh5//HGbO3euy6qVL1/eZdtEREREJA1q1sKKFCliS5cuVc1ayHfDNSwci2rWREREklSzFsam6sqqiYiIiCRHgdffGDZsWGKOREREREQyb1FcERERkWy2U8Ea2bVGjRq5nQQqVqzo3n/22Wfjf3QiIiIiWa7Aw6D9+/e3Bx54wDp16mRXX321W3dtxowZdt1119mCBQts4MCBiTlSERERkSxU4GDt6aefthdeeMHOO++8XI+fdNJJ1rVrVwVrElc594zTGY0S9GqhcyIikkUKPAzKPp116tTJ83jdunUjuxyIiIiISIqCtYYNG9qAAQNyBWa8z2N8TkRERERSOAz6yCOPuCHQqlWrWrVq1dyOBr/99pv7+I033ojjoYmIiIhIgYO1I444wubMmWPvvPOO234KBxxwgJ1xxhlWvHhxnVERERGRVAZr7ouKFbMWLVTkLCIiIpJoWhRXREREJI0pWBMRERFJYwrWRERERNKYgjURERGRNKZgTURERCSNKVgTERERSWMZFax169bNLcI7ZsyYVB+KiIiISFJkTLD2wQcf2IwZM1J9GCIiIiLpHay1adPGnn76aUsmNo/v2rWrPfXUU0n9uSIiIiIZF6yNHTvWTjzxREumLl26WOfOna127drbfN6mTZts9erVud5EREREsmq7qUqVKtn69estWV588UVbsGCBjRgxYrvPHTx4sA0YMCApxyWS6eq/d1uqDyHtTGuucyIihSCz1rdvX+vXr5+tXbvWEm3hwoV2/fXX27PPPmtFixbd7vP79Oljq1atirzx9SIiIiJZlVkbN26cK/SvUaOGHXbYYVauXLk8w6TxMnXqVFu2bJkdddRRuR5v166dvfbaa3mybSVKlHBvIiIiIlk9DNqsWTNLBn7OrFmzcj1Wt25du/fee61Vq1ZJOQYRERGRjArWhg0bZslSunRpq1OnTp7Hq1Wr5t5ERERECruMWWdNREREJBsVOLMWtnTpUqtSpYoVKZK8mC8IgqT9LBEREZFUK3CUtXHjRrvmmmts9913t3322cctqwEWrX344YcTcYwiIiIiWavAwdoNN9xgU6ZMcftzhmdeslDu888/H+/jExEREclqBR4Gff31193yHQ0aNMg1/Hn00Ufbzz//HO/jExEREclqBc6srVmzxs3SjMYitMWK7VIJnIiIiIjsarB26qmn2pAhQyKF/jk5OW77qdtuu82aNm1a0G8nIiIiIttQ4FTYgw8+aM2bN7d9993XNmzYYG3btrW5c+dahQoV7P333y/otxMRERGReAZrNWvWtJkzZ7qtnvgfXbp0cUHbbrvtVtBvJyIiIiLbsFNFZsWLF7dLL710Z75URERERBIdrC1fvtxefvllN/xJzVrt2rWtTZs2Vr58+Z35diIiIiISr2Dtrbfesosuusj23HNPt28nEw1GjhxpvXv3dmuvUc8mIpLNvhuek+pDSDv1LtbuMyJJC9Z69Ohh3bt3t0GDBkXWWSNgu/nmm+3aa6/VWmsiIiIiqVy6Y8mSJXb55ZfnWhCXodAOHTrYokWL4nlsIiIiIlmvwMFa69at7bnnnsvz+LBhw9znRERERCTJw6Dnnntu5P2///7bhg8f7gI2atbw448/2h9//GHNmjWL46GJiIiIyA4FaxUrVsz1cfv27XN9zAK5IiIiIpKiYI0hThERERHJgNmgzPycMmWK/frrr267Kb9HqHfJJZfE8/hEREREslqBgzXq1z777DM7+OCDrWTJkrk+x6xQBWsiIiIiKQzWyKp9+umndsghh8TxMEREREQkLsHaLbfcYldddZWdeOKJeTJruPXWWwv6LUVEREQkXsEakw3Wr19v8+fPjxmsiYiIiEgKg7V169bZ2LFjXc2aiIiIiKRZsLb33ntbixYtrGHDhjEza88++2y8js3uuOMOt0n8vHnz3MbxZ511lg0ZMsQqVaoUt58hIiIiUqiCtSZNmliyfP7553bjjTe6wHDlypWuVu6iiy6y8ePHJ+0YRERERDIqWOvfv78ly1tvvZVn8kLLli1t1apVLtMWbdOmTe7NW716dVKOU0RERCRtgrVu3bpt8/MPPfSQJcrvv/9upUqVshIlSsT8/ODBg23AgAEJ+/kiIpI6OfeM0+mPIejVYpfPS/33btO5jWFa89syM1ibOXNmro+3bt1qixYtsl9++cUt55Eoa9eutfvvv9+uvvrqfGeh9unTx3r27Jkrs1ajRo2EHZOIiIhI2gVrH3/8cczHX375ZbdgbiJs3rzZ2rVrZ9WqVXOTDvJDxi2/rJuIiIhIJioSr2/Utm1bGzVqlMUbmTu2sFqyZIlbMmS33XaL+88QERERKTSZtRUrVsQcohw9erTFG5vEd+zY0WbNmmUfffSRlS1bNu4/Q0RERKRQBWusccaG7dHKlCljjz32mMUTS3UQpDEr9O+//7alS5e6xytXrmxFixaN688SERERKRTBGsFTOFjj/XLlylnt2rXdTM14evLJJ93/hx9+eK7H2epqv/32i+vPEhERESkUwdopp5xiycIwqIiIiEg22+FgbeDAgdt9Dlm2fv367eoxiYiIiEhBg7XtTSD48ccf3cxNBWsiIiIiKQjWohfDBft1Dhs2zE0s2H///a1Lly5xPDQRERERKXDNGr799lsbOnSovfLKK25j90ceecROP/10nU0RERGRVAVr7CLAUChB2uzZs936ZzNmzLCaNWvG+5hEREREpKDB2j777GPLly+3s88+2+3PybZOU6dOdW9hF1xwwY5+SxERERGJV7D2xx9/uP/Z8om3/GaDbtmyZUe/pYiIiIjEK1hjpqeIiIiIZOhG7iIiIiISfwrWRERERNKYgjURERGRNKZgTURERCSNKVgTERERSWMK1kRERETSmII1ERERkTSmYE1EREQkjSlYExEREUljCtZERERE0piCNREREZE0pmBNREREJI0pWBMRERFJY2kfrAVBYP369bMqVapY6dKlrW3btrZq1apUH5aIiIhIUqR9sPboo4/a/fffb0899ZRNmDDBpk+fbldddVWqD0tEREQkKYpZmnviiSesS5cudt5557mPhwwZYi1btrRHHnnEKlasmOu5mzZtcm+ez8CtXr06oce4dn1Cv33Gist536iTm5DzamZb1v3vtSLxPbdqE/JSe5De51btQWyJjh/892cUcZuCNLZx48agSJEiweuvvx55bMWKFfxGwQcffJDn+f3793ef05vOga4BXQO6BnQN6BrQNWAZcg4WLly4zXgoh38sTS1evNiqV69ukyZNsnHjxtn48eNtypQpVrx4cXvxxRdd/dq2Mmtbt261FStWuAxcTk6OFXZE6DVq1LCFCxda2bJlU304hYrOrc5tptE1q3ObibLtug2CwNasWWPVqlWzIkWKZOYwaDiOrFSpku27777bfH6JEiXcW1i5cuUs23CBZ8NFngo6tzq3mUbXrM5tJsqm63bPPffc7nPSOlgjQCPSXLZsmfXq1cs99tdff9mWLVuscuXKqT48ERERkeyeDUqW7NBDD7XPPvss8tjEiROtaNGiVr9+/ZQem4iIiEgypHVmDZ07d7Ybb7zRTjrpJDeme9NNN1nr1q3zzASV/wtu+/fvn2coWHadzm3i6NzqvGYaXbM6t8mW1hMMwovisoTH+vXrrUWLFvb4449nZS2aiIiIZJ+0D9ZEREREslla16yJiIiIZDsFayIiIiJpTMGaiIiISBpTsCYiIiKSxhSsiYiIRGG7QmgOnqQDBWsZgl0b1GhIplm6dGmqD6FQtwmSmPN62WWX2VVXXaXTm6DzKwWnpTvS3C+//GL//POPHXjgge7jlStXao25OCMIzsnJife3zWpPPfWUWw+xePHibk/fnj172rHHHmubN2+2YsXSfi3utOY7bf6a1TmNr5kzZ9oRRxzh3v/iiy+sUaNGLsu2rU22ZceCNHYfCnfkqlatqnO7g3T1pbH58+fbJZdcYr1793Yft2/f3r0tX7481YdWaG56NCDhQE3Zy10zbdo0q1Onjg0cONDtPtKyZUubPXu2XX755e7zCtR2jb9eedu4caNddNFFLjBWtmLXzJo1y/7++2/3Puf23HPPdZ2LLl26uMcUqO0a2lUfqNFGkLm89tprdW4LQMFaGqtVq5a1a9fO9e5KlSplixcvtrvuuktbbcUxm0YDsmTJEnvhhRfsu+++s7/++st9Xje/gtm0aZOtXbvWhgwZYj///LMtXLjQrrzySuvVq5edd9557rHwHr+yc7heuXavvvpqGzRokL399ts2bNgwl4GXgiNjdsstt1i9evVcp5jruGbNmu58tmnTxnWMyRBDbcLOo60lSGvYsKHdcMMN9u6777r24MMPP3SfVyd5+xSspbGvv/7a7YW6bt0623///e2jjz5yG9ur0dh1Pps2YMAAO+igg+yxxx5zjTOZS4TT9bJtEydOtIMPPti93717dytZsqQNHz488vnp06dbhQoVrEaNGjqVu4gt98imTZo0yQ3PtWrVyg3bPf30065cQgquevXq7v/PP//c7rzzTtfRaNu2rc2ZM8d1lmkjGGr2gbIUHFlL9vjmPvbss8+6c0oC4qGHHnLXrcpQtk/BWpqgMYhulOk1sy8qPTvS8Pfdd1/Kjq+wzOwK++qrr2z06NH22muvuYZ6zJgxrsd33XXXpeQYM1WZMmVcBoIM8PHHH++G7m+++WYXsFGvxnXctGlTN9S0Zs0a9zW66e3YEH00hj45z2QsGarjxnf77bfbww8/bDNmzEjQX7hwefnll61bt25u+PiPP/6wTp06WbNmzVxAQWeYYJjrlOH8888/3wUVvhQlVjsi/5NfImHBggUu+UBpBJlL/mcY9Ndff3UdDZ3bHcDeoJI6W7duzfX+yJEjg8WLF7uPN2zY4P7/888/g6uvvjo49NBDg99++809tmnTphQdcWbhnIbP8T///BN5/9prrw0uvPBC9/5nn30WHHvssUG1atWCl156KSXHminWrFmT6+M5c+YETZs2DYYMGeI+/umnn4I6deoEOTk5wQsvvBB89913wUcffRQcdNBBwamnnhp8+umnka/dsmVL0o8/3YWv11WrVgUrV66MfDxjxozgyCOPzHWNck3XrVs3uOiii/L8beR/eI0ffPDBQa1atYLLLrssOPDAA4Pjjz/efe6dd95x1+sXX3wRPPjgg0HFihWDli1bus/dfffdwR577BHMmzcvz99HYr+OeY1PnDgx8jH3qwoVKgTPP/985DHuZWeddVZw3HHHBUuWLNG53Q4Fa2niqaeeCqpWrRocc8wxwWOPPRZ53DcMH3zwQdCoUaOge/fuub7OB3SS1+bNm3Pd0K655prgtttuC9atW+ce69u3b3D00UcHnTt3DsqWLRv06NEjWLZsmfucguHYHn/88eCAAw4I3n///VyPn3POOUH79u3d++vXrw8eeeSRYLfddgt+//33yHNmz57tznGVKlWC1q1b65LdjgEDBrjr8sQTTwzuvPPOyON02rp06RIsX7488ti9994blChRInj77bd1XmN49NFHXTB2ww03uLaAtuGTTz5xj3311VfuMTpu9evXD/7+++9g8uTJwcsvvxzpfDRu3Dg444wzdG63Y+3ata7jVqZMmaB8+fLufP/111+uPe3QoYNrb8Pt8k033eT+Bv3799e53Q4Fa2lgxIgRQY0aNYJhw4a54OuPP/6IBGq+x7Jx48bgjjvucAEd2TcaZTJBw4cPT/HRp49JkybF7OX16dMn6NmzZ1CzZk3Xq/7222/d4/Ty9tprL9dA+4wlFi1a5G6Gv/zyS5J/g/Q1d+7cyLmhQ3HSSSe5DoQ3atSooFy5cpGGmJ4y59VnJ8LZCAKLG2+80d0UszlL4V/n0chKEBRfcMEFwWuvveayQPvss0/w4osvRjp23AjHjBmT6xonWCOoIFiWIFeniywPQcG4ceNytRcEFitWrHAfz5w5MyhdunRw33335crC054888wzQfHixV3gls3I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HBgWrV27tlv9naUO2A+Ux/xyHJ6yaSIi6UUTDETSHMETtWcEVSwCGo21phYsWOBmb7K0hl/klhoeEKjxdaz4zixP9lI88sgj7aGHHorsOhCmQmwRkfSizJpIGvLZLT8U+cknn9jJJ58cM5D6+OOP3RIGbEbNxACyZaylttdee9m1115rZ599tgvW2C8R33//vatRO/XUU1Pwm4mISEEpWBPJIEwUOOSQQ6xGjRq5ZnSyTtrTTz/ttos6/vjj3dDntGnT3FpqzPb0Q6LbKsoWEZH0pGBNJA29++67LgPWsWNHt5vA888/75bXWLVqlQ0bNsxtWE2g5jNv/L927Vq3htrff//tVnFnj8+lS5faqFGj3HM0vCkikplUsyaSYn6D9TCW0bj11lvdPod8ngBt6NChbo9OVmafM2eOe55fsoP/CdQI5lgv7e2337YJEyZYo0aNXOZMgZqISOZSZk0kDZANI+AKL2rLcOcRRxxhzz77rNsHEUwkqFevnpso0K1bN/e4r29jyPOOO+5ww59fffWV9e7d2/r06ZPC30pEROJBmTWRFKPYv3LlypEN1VnIFk888YSNGzfO3nrrLVefxtt+++3ntojic9OnT3fPI1Djc2wfxaQB9klcuHBhJFDjcyIikrkUrImkGLM2WbD27rvvdstw+MkA1KStX7/erYfGXp1+MgF7IBLQjR492mXTmFhAFg3MCO3UqZOVLl3aDZ+SdfNfJyIimUmtuEgauO+++1xA9uabb9rcuXOtWbNm1rJlS7d47QcffOBq0AjQCL4YKuX5jzzyiB188MEuUKtfv36uFdz981SrJiKS+TRnXyQNsP0Tw5adO3d2WTH25nzqqaesVq1abhjz0UcftZNOOskaNGhgixYtcltGkTFjxmffvn0j38cHZwrSREQKD00wEEkTDHkSkFWtWtVl0jx2ImD9NLaUuvzyy+2mm25yW0sRsLEILrRemohI4aVgTSSNjBkzxtq2bet2JTjxxBMj66ixlRR7ek6aNMnt/UmdG/g8GTZl0kRECi8FayJppmnTpu5/ZoLuvvvukcfZiSC8l6cP5EREpHBTsCaSZliSo2HDhvbYY4/ZFVdcEVlHTUREspNmg4qkmSOPPNLVp82YMUOBmoiIKLMmko40YUBERDxl1kTSEPt55rdvqIiIZBfVrImIiIikMWXWRERERNKYgjURERGRNKZgTURERCSNKVgTERERSWMK1kRERETSmII1ERERkTSmYE1EREQkjSlYExEREUljCtZERERELH39Pws1+YzDsjykAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 629.921x629.921 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_fps_models(selected_fingerprints, selected_models)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "22d5d721",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "astra_benchmark",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
